Files
pwap/pezkuwi-sdk-ui/packages/react-components/src/Balance.tsx
T
pezkuwichain 971df8edba Rebrand: Remove 3rd party chains, update domains to PezkuwiChain
- Remove all 3rd party parachain configurations from endpoints:
  - productionRelayPolkadot.ts: Keep only system parachains
  - productionRelayDicle.ts: Keep only system parachains
  - testingRelayZagros.ts: Keep only system parachains
  - testingRelayTeyrChain.ts: Keep only system parachains

- Update domain references:
  - polkadot.js.org → pezkuwichain.app
  - wiki.polkadot.network → wiki.pezkuwichain.io
  - dotapps.io → pezkuwichain.app
  - statement.polkadot.network → docs.pezkuwichain.io/statement
  - support.polkadot.network → docs.pezkuwichain.io

- Update repository references:
  - github.com/pezkuwi-js/apps → github.com/pezkuwichain/pwap

- Rename system parachains to Pezkuwi ecosystem:
  - PolkadotAssetHub → PezkuwiAssetHub
  - polkadotBridgeHub → pezkuwiBridgeHub
  - polkadotCollectives → pezkuwiCollectives
  - polkadotCoretime → pezkuwiCoretime
  - polkadotPeople → pezkuwiPeople

- Update network name in claims utility:
  - Polkadot → Pezkuwi
2026-01-09 03:08:11 +03:00

75 lines
1.8 KiB
TypeScript

// 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 =>
<FormatBalance
key={index}
value={balance}
/>
);
}
}
return (
<FormatBalance
className={`${className} ui--Balance`}
label={label}
value={Array.isArray(value) ? value[0] : value}
>
{others && (
<span>&nbsp;(+{others})</span>
)}
</FormatBalance>
);
}
function BalanceDisplay (props: Props): React.ReactElement<Props> | null {
const { balance, className = '', label, params } = props;
if (!params) {
return null;
}
return balance
? <>{renderProvided({ className, label, value: balance })}</>
: (
<BalanceFree
className={`${className} ui--Balance`}
label={label}
params={params}
/>
);
}
export default React.memo(BalanceDisplay);