stacker.news/components/wallet-card.js

59 lines
1.6 KiB
JavaScript
Raw Normal View History

import { Badge, Card } from 'react-bootstrap'
import styles from '@/styles/wallet.module.css'
import Plug from '@/svgs/plug.svg'
import Gear from '@/svgs/settings-5-fill.svg'
2024-01-07 17:00:24 +00:00
import Link from 'next/link'
2024-06-03 22:41:15 +00:00
import { useWallet, Status } from './wallet'
2024-07-03 02:21:20 +00:00
import { useEffect, useState } from 'react'
2024-06-03 22:41:15 +00:00
export function WalletCard ({ name, title, badges, status }) {
const wallet = useWallet(name)
2024-07-03 02:21:20 +00:00
const [mounted, setMounted] = useState(false)
useEffect(() => {
// fix mismatched className props during hydration
setMounted(true)
}, [])
let indicator = styles.disabled
2024-07-03 02:21:20 +00:00
switch (mounted && wallet.status) {
case Status.Enabled:
case true:
indicator = styles.success
break
case Status.Locked:
indicator = styles.warning
break
case Status.Error:
indicator = styles.error
break
case Status.Initialized:
case false:
indicator = styles.disabled
break
}
2024-01-07 17:00:24 +00:00
return (
<Card className={styles.card}>
<div className={`${styles.indicator} ${indicator}`} />
2024-01-07 17:00:24 +00:00
<Card.Body>
<Card.Title>{title}</Card.Title>
<Card.Subtitle className='mt-2'>
{badges?.map(
badge =>
<Badge className={styles.badge} key={badge} bg={null}>
{badge}
</Badge>)}
</Card.Subtitle>
</Card.Body>
2024-06-03 22:41:15 +00:00
<Link href={`/settings/wallets/${name}`}>
<Card.Footer className={styles.attach}>
{wallet.isConfigured
? <>configure<Gear width={14} height={14} /></>
: <>attach<Plug width={14} height={14} /></>}
</Card.Footer>
</Link>
2024-01-07 17:00:24 +00:00
</Card>
)
}