Skip to content

Commit

Permalink
dark/light mode images on wallet pages
Browse files Browse the repository at this point in the history
  • Loading branch information
huumn committed Nov 19, 2024
1 parent f3cc0f9 commit 66ec5d5
Showing 1 changed file with 11 additions and 4 deletions.
15 changes: 11 additions & 4 deletions pages/settings/wallets/[wallet].js
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,12 @@ import { canReceive, canSend, isConfigured } from '@/wallets/common'
import { SSR } from '@/lib/constants'
import WalletButtonBar from '@/components/wallet-buttonbar'
import { useWalletConfigurator } from '@/wallets/config'
import { useCallback, useMemo } from 'react'
import { useCallback, useEffect, useMemo, useState } from 'react'
import { useMe } from '@/components/me'
import validateWallet from '@/wallets/validate'
import { ValidationError } from 'yup'
import { useFormikContext } from 'formik'
import useDarkMode from '@/components/dark-mode'

export const getServerSideProps = getGetServerSideProps({ authRequired: true })

Expand All @@ -28,6 +29,8 @@ export default function WalletSettings () {
const wallet = useWallet(name)
const { me } = useMe()
const { save, detach } = useWalletConfigurator(wallet)
const [dark] = useDarkMode()
const [imgSrc, setImgSrc] = useState(wallet?.def.card?.image?.src)

const initial = useMemo(() => {
const initial = wallet?.def.fields.reduce((acc, field) => {
Expand Down Expand Up @@ -69,12 +72,16 @@ export default function WalletSettings () {

const { card: { image, title, subtitle } } = wallet?.def || { card: {} }

useEffect(() => {
if (!imgSrc) return
// wallet.png <-> wallet-dark.png
setImgSrc(dark ? image?.src.replace(/\.([a-z]{3})$/, '-dark.$1') : image?.src)
}, [dark])

return (
<CenterLayout>
{image
? typeof image === 'object'
? <img {...image} alt={title} className='pb-2' />
: <img src={image} width='33%' alt={title} className='pb-2' />
? <img alt={title} {...image} src={imgSrc} className='pb-3 px-2 mw-100' />
: <h2 className='pb-2'>{title}</h2>}
<h6 className='text-muted text-center pb-3'><Text>{subtitle}</Text></h6>
<Form
Expand Down

0 comments on commit 66ec5d5

Please sign in to comment.