stacker.news/components/hidden-wallet-summary.js

25 lines
877 B
JavaScript
Raw Permalink Normal View History

2024-04-17 22:21:56 +00:00
import { useState, useMemo } from 'react'
import { abbrNum, numWithUnits } from '@/lib/format'
import { useMe } from './me'
export default function HiddenWalletSummary ({ abbreviate, fixedWidth }) {
const me = useMe()
const [hover, setHover] = useState(false)
2024-04-17 22:21:56 +00:00
const fixedWidthAbbrSats = useMemo(() => {
const abbr = abbrNum(me.privates?.sats).toString()
if (abbr.length >= 6) return abbr
// add leading spaces if abbr is shorter than 6 characters
return ' '.repeat(6 - abbr.length) + abbr
}, [me.privates?.sats])
return (
<span
2024-04-17 22:21:56 +00:00
className='text-monospace' style={{ whiteSpace: 'pre-wrap' }} align='right' onPointerEnter={() => setHover(true)} onPointerLeave={() => setHover(false)}
>
2024-04-17 22:21:56 +00:00
{hover ? (abbreviate ? fixedWidthAbbrSats : numWithUnits(me.privates?.sats, { abbreviate: false, format: true })) : '******'}
</span>
)
}