feat: initial Pezkuwi Apps rebrand from polkadot-apps

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
This commit is contained in:
2026-01-07 13:05:27 +03:00
commit d21bfb1320
5867 changed files with 329019 additions and 0 deletions
+44
View File
@@ -0,0 +1,44 @@
// 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);