78 lines
2.5 KiB
JavaScript
78 lines
2.5 KiB
JavaScript
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'
|
|
import Link from 'next/link'
|
|
import { Status } from 'wallets'
|
|
import DraggableIcon from '@/svgs/draggable.svg'
|
|
|
|
export default function WalletCard ({ wallet, draggable, onDragStart, onDragEnter, onDragEnd, onTouchStart, sourceIndex, targetIndex, index }) {
|
|
const { card: { title, badges } } = wallet
|
|
|
|
let indicator = styles.disabled
|
|
switch (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
|
|
}
|
|
|
|
return (
|
|
<Card
|
|
className={styles.card}
|
|
// we attach the drag listeners to the whole card to have a proper drag image
|
|
draggable={draggable}
|
|
onDragStart={onDragStart}
|
|
onDragEnter={onDragEnter}
|
|
onDragEnd={onDragEnd}
|
|
>
|
|
<div className={styles.cardMeta}>
|
|
{wallet.status === Status.Enabled && <DraggableIcon className={styles.drag} width={16} height={16} />}
|
|
<div className={`${styles.indicator} ${indicator}`} />
|
|
</div>
|
|
<Card.Body
|
|
// we attach touch listener only to card body to not interfere with wallet link
|
|
onTouchStart={onTouchStart}
|
|
className={draggable
|
|
? (`${sourceIndex === index ? styles.drag : ''} ${draggable && targetIndex === index ? styles.drop : ''}`)
|
|
: ''}
|
|
style={{ cursor: draggable ? 'move' : 'default' }}
|
|
>
|
|
<Card.Title>{title}</Card.Title>
|
|
<Card.Subtitle className='mt-2'>
|
|
{badges?.map(
|
|
badge => {
|
|
let style = ''
|
|
switch (badge) {
|
|
case 'receive': style = styles.receive; break
|
|
case 'send': style = styles.send; break
|
|
}
|
|
return (
|
|
<Badge className={`${styles.badge} ${style}`} key={badge} bg={null}>
|
|
{badge}
|
|
</Badge>
|
|
)
|
|
})}
|
|
</Card.Subtitle>
|
|
</Card.Body>
|
|
<Link href={`/settings/wallets/${wallet.name}`}>
|
|
<Card.Footer className={styles.attach}>
|
|
{wallet.isConfigured
|
|
? <>configure<Gear width={14} height={14} /></>
|
|
: <>attach<Plug width={14} height={14} /></>}
|
|
</Card.Footer>
|
|
</Link>
|
|
</Card>
|
|
)
|
|
}
|