48 lines
1.7 KiB
JavaScript
48 lines
1.7 KiB
JavaScript
|
import { canReceive, canSend, isConfigured, Status } from '@/wallets/common'
|
||
|
import { useWalletLogs } from '@/components/wallet-logger'
|
||
|
import styles from '@/styles/wallet.module.css'
|
||
|
|
||
|
export function useWalletStatus (wallet) {
|
||
|
const { logs } = useWalletLogs(wallet)
|
||
|
|
||
|
return statusFromLogs(wallet, {
|
||
|
any: wallet.config?.enabled && isConfigured(wallet) ? Status.Enabled : Status.Disabled,
|
||
|
send: wallet.config?.enabled && canSend(wallet) ? Status.Enabled : Status.Disabled,
|
||
|
recv: wallet.config?.enabled && canReceive(wallet) ? Status.Enabled : Status.Disabled
|
||
|
}, logs)
|
||
|
}
|
||
|
|
||
|
const statusFromLogs = (wallet, status, logs) => {
|
||
|
if (status.any === Status.Disabled) return status
|
||
|
|
||
|
// override status depending on if there have been warnings or errors in the logs recently
|
||
|
// find first log from which we can derive status (logs are sorted by recent first)
|
||
|
const walletLogs = logs.filter(l => l.wallet === wallet.def.name)
|
||
|
const sendLevel = walletLogs.find(l => l.context?.status && l.context?.send)?.level
|
||
|
const recvLevel = walletLogs.find(l => l.context?.status && l.context?.recv)?.level
|
||
|
|
||
|
const levelToStatus = (level) => {
|
||
|
switch (level?.toLowerCase()) {
|
||
|
case 'ok':
|
||
|
case 'success': return Status.Enabled
|
||
|
case 'error': return Status.Error
|
||
|
case 'warn': return Status.Warning
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
any: status.any,
|
||
|
send: levelToStatus(sendLevel) || status.send,
|
||
|
recv: levelToStatus(recvLevel) || status.recv
|
||
|
}
|
||
|
}
|
||
|
|
||
|
export const statusToClass = status => {
|
||
|
switch (status) {
|
||
|
case Status.Enabled: return styles.success
|
||
|
case Status.Disabled: return styles.disabled
|
||
|
case Status.Error: return styles.error
|
||
|
case Status.Warning: return styles.warning
|
||
|
}
|
||
|
}
|