mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 18:17:59 +00:00
d21bfb1320
Rebranded terminology: - Polkadot → Pezkuwi - Kusama → Dicle - Westend → Zagros - Rococo → PezkuwiChain - Substrate → Bizinikiwi - parachain → teyrchain Custom logos with Kurdistan brand colors (#e6007a → #86e62a): - bizinikiwi-hexagon.svg - sora-bizinikiwi.svg - hezscanner.svg - heztreasury.svg - pezkuwiscan.svg - pezkuwistats.svg - pezkuwiassembly.svg - pezkuwiholic.svg
45 lines
1.3 KiB
TypeScript
45 lines
1.3 KiB
TypeScript
// Copyright 2017-2025 @pezkuwi/react-query authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { Option } from '@pezkuwi/types';
|
|
import type { AccountId, AccountIndex, Address, StakingLedger } from '@pezkuwi/types/interfaces';
|
|
|
|
import React from 'react';
|
|
|
|
import { useApi, useCall } from '@pezkuwi/react-hooks';
|
|
|
|
import FormatBalance from './FormatBalance.js';
|
|
|
|
interface Props {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
params?: AccountId | AccountIndex | Address | string | Uint8Array | null;
|
|
label?: React.ReactNode;
|
|
}
|
|
|
|
const OPT_C = {
|
|
transform: (value: Option<AccountId>) => value.unwrapOr(null)
|
|
};
|
|
|
|
const OPT_L = {
|
|
transform: (value: Option<StakingLedger>) => value.unwrapOr(null)
|
|
};
|
|
|
|
function BondedDisplay ({ children, className = '', label, params }: Props): React.ReactElement<Props> {
|
|
const { api } = useApi();
|
|
const controllerId = useCall<AccountId | null>(api.query.staking?.bonded, [params], OPT_C);
|
|
const stakingLedger = useCall<StakingLedger | null>(controllerId && api.query.staking?.ledger, [controllerId], OPT_L);
|
|
|
|
return (
|
|
<FormatBalance
|
|
className={className}
|
|
label={label}
|
|
value={stakingLedger?.active}
|
|
>
|
|
{children}
|
|
</FormatBalance>
|
|
);
|
|
}
|
|
|
|
export default React.memo(BondedDisplay);
|