import { timeSince } from '@/lib/time' import styles from '@/styles/log.module.css' import { Fragment, useState } from 'react' export default function LogMessage ({ showWallet, wallet, level, message, context, ts }) { const [show, setShow] = useState(false) let className switch (level.toLowerCase()) { case 'ok': case 'success': level = 'ok' className = 'text-success'; break case 'error': className = 'text-danger'; break case 'warn': className = 'text-warning'; break default: className = 'text-info' } const filtered = context ? Object.keys(context) .filter(key => !['send', 'recv', 'status'].includes(key)) .reduce((obj, key) => { obj[key] = context[key] return obj }, {}) : {} const hasContext = context && Object.keys(filtered).length > 0 const handleClick = () => { if (hasContext) { setShow(show => !show) } } const style = hasContext ? { cursor: 'pointer' } : { cursor: 'inherit' } const indicator = hasContext ? (show ? '-' : '+') : <> return ( <> {timeSince(new Date(ts))} {showWallet ? [{wallet}] : } {level} {message} {indicator} {show && hasContext && Object.entries(filtered) .map(([key, value], i) => { const last = i === Object.keys(filtered).length - 1 return ( {key} {value} ) })} ) }