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
@@ -0,0 +1,120 @@
// Copyright 2017-2025 @pezkuwi/app-staking authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { BN } from '@pezkuwi/util';
import React, { useMemo } from 'react';
import { Badge } from '@pezkuwi/react-components';
import { useAccounts } from '@pezkuwi/react-hooks';
import MaxBadge from '../../MaxBadge.js';
interface Props {
isChilled?: boolean;
isElected: boolean;
isMain?: boolean;
isPara?: boolean;
isRelay?: boolean;
nominators?: { nominatorId: string }[];
onlineCount?: false | BN;
onlineMessage?: boolean;
}
const NO_NOMS: { nominatorId: string }[] = [];
function Status ({ isChilled, isElected, isMain, isPara, isRelay, nominators = NO_NOMS, onlineCount, onlineMessage }: Props): React.ReactElement<Props> {
const { allAccounts } = useAccounts();
const blockCount = onlineCount && onlineCount.toNumber();
const isNominating = useMemo(
() => nominators.some(({ nominatorId }) => allAccounts.includes(nominatorId)),
[allAccounts, nominators]
);
return (
<>
{isNominating
? (
<Badge
className='media--1100'
color='green'
icon='hand-paper'
/>
)
: (
<Badge
className='media--1100'
color='transparent'
/>
)
}
{isRelay && (
isPara
? (
<Badge
className='media--1100'
color='purple'
icon='vector-square'
/>
)
: (
<Badge
className='media--1100'
color='transparent'
/>
)
)}
{isChilled
? (
<Badge
className='media--1000'
color='red'
icon='cancel'
/>
)
: isElected
? (
<Badge
className='media--1000'
color='blue'
icon='chevron-right'
/>
)
: (
<Badge
className='media--1000'
color='transparent'
/>
)
}
{isMain && (
blockCount
? (
<Badge
className='media--900'
color='green'
info={blockCount}
/>
)
: onlineMessage
? (
<Badge
className='media--900'
color='green'
icon='envelope'
/>
)
: (
<Badge
className='media--900'
color='transparent'
/>
)
)}
<MaxBadge numNominators={nominators.length} />
</>
);
}
export default React.memo(Status);