// Copyright 2017-2026 @pezkuwi/react-components authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { AccountId, AccountIndex, Address } from '@pezkuwi/types/interfaces'; import type { BN } from '@pezkuwi/util'; import React from 'react'; import { BalanceFree, FormatBalance } from '@pezkuwi/react-query'; import { BN_ZERO } from '@pezkuwi/util'; export interface RenderProps { className?: string; label?: React.ReactNode; value?: BN | BN[]; } export interface Props { balance?: BN | BN[]; className?: string; label?: React.ReactNode; params?: AccountId | AccountIndex | Address | string | Uint8Array | null; withLabel?: boolean; } export function renderProvided ({ className = '', label, value }: RenderProps): React.ReactNode { let others: undefined | React.ReactNode; if (Array.isArray(value)) { const totals = value.filter((_, index): boolean => index !== 0); const total = totals.reduce((total, value): BN => total.add(value), BN_ZERO).gtn(0); if (total) { others = totals.map((balance, index): React.ReactNode => ); } } return ( {others && (  (+{others}) )} ); } function BalanceDisplay (props: Props): React.ReactElement | null { const { balance, className = '', label, params } = props; if (!params) { return null; } return balance ? <>{renderProvided({ className, label, value: balance })} : ( ); } export default React.memo(BalanceDisplay);