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,83 @@
// Copyright 2017-2025 @pezkuwi/app-coretime authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { RelayName } from './types.js';
import React, { useCallback, useEffect, useRef, useState } from 'react';
import { Table } from '@pezkuwi/react-components';
import { type CoretimeInformation } from '@pezkuwi/react-hooks/types';
import Filters from './Overview/Filters.js';
import TeyrchainTableRow from './TeyrchainTableRow.js';
import { useTranslation } from './translate.js';
interface Props {
coretimeInfo: CoretimeInformation
relayName: RelayName
}
function TeyrchainsTable ({ coretimeInfo, relayName }: Props): React.ReactElement<Props> {
const { t } = useTranslation();
const headerRef = useRef<([React.ReactNode?, string?, number?] | false)[]>([
[t('teyrchains'), 'start'],
[t('name'), 'start media--800'],
[t('core number'), 'start'],
[t('type'), 'start'],
[t('last block'), 'start media--800'],
[t('end date (approx)'), 'start media--1000'],
[t('renewal'), 'start media--1200'],
[t('renewal price'), 'start media--1200'],
[t('links'), 'start media--800'],
[t('other cores'), 'end']
]);
const [taskIds, setTaskIds] = useState<number[]>([]);
const onFilter = useCallback((filteredData: number[]) => {
setTaskIds(filteredData);
}, []);
useEffect(() => {
if (coretimeInfo?.taskIds) {
setTaskIds(coretimeInfo?.taskIds);
}
}, [coretimeInfo?.taskIds]);
return (
<>
<Filters
chainInfo={coretimeInfo?.chainInfo}
data={coretimeInfo?.taskIds}
onFilter={onFilter}
/>
<Table
emptySpinner={false}
header={headerRef.current}
isSplit={false}
>
{taskIds?.map((taskId: number) => {
const chain = coretimeInfo.chainInfo[taskId];
if (!chain) {
return null;
}
return (
<TeyrchainTableRow
chain={chain}
key={chain.id}
lastCommittedTimeslice={coretimeInfo.status.lastCommittedTimeslice}
regionBegin={coretimeInfo.salesInfo.regionBegin}
regionEnd={coretimeInfo.salesInfo.regionEnd}
relayName={relayName}
/>
);
})}
</Table>
</>
);
}
export default React.memo(TeyrchainsTable);