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,67 @@
// Copyright 2017-2025 @pezkuwi/react-hooks authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { ApiPromise } from '@pezkuwi/api';
import type { StorageKey, u32, Vec } from '@pezkuwi/types';
import type { PalletBrokerScheduleItem } from '@pezkuwi/types/lookup';
import type { BN } from '@pezkuwi/util';
import type { CoreWorkload } from './types.js';
import { useEffect, useState } from 'react';
import { createNamedHook, useCall, useMapKeys } from '@pezkuwi/react-hooks';
import { processHexMask } from './utils/dataProcessing.js';
export function sortByCore<T extends { core: number }> (dataArray?: T | T[]): T[] {
if (!dataArray) {
return [];
}
const sanitized = Array.isArray(dataArray) ? dataArray : [dataArray];
return sanitized.sort((a, b) => a.core - b.core);
}
function extractInfo (info: PalletBrokerScheduleItem[], core: number): CoreWorkload {
const mask: string[] = processHexMask(info[0]?.mask);
const assignment = info[0].assignment;
return {
core,
info: {
isPool: assignment.isPool,
isTask: assignment.isTask,
mask,
maskBits: mask.length,
task: assignment.isTask ? assignment.asTask.toString() : assignment.isPool ? 'Pool' : 'Idle'
}
};
}
const OPT_KEY = {
transform: (keys: StorageKey<[u32]>[]): u32[] =>
keys.map(({ args: [core] }) => core)
};
function useWorkloadInfosImpl (api: ApiPromise, ready: boolean): CoreWorkload[] | undefined {
const cores = useMapKeys(ready && api?.query.broker.workload, [], OPT_KEY);
const workloadInfo = useCall<[[BN[]], Vec<PalletBrokerScheduleItem>[]]>(ready && api?.query.broker.workload.multi, [cores], { withParams: true });
const [state, setState] = useState<CoreWorkload[] | undefined>();
useEffect((): void => {
if (!workloadInfo?.[0]?.[0]) {
return;
}
const cores = workloadInfo[0][0];
setState(
sortByCore(cores.map((core, index) => extractInfo(workloadInfo[1][index], core.toNumber())))
);
}, [workloadInfo]);
return state;
}
export const useWorkloadInfos = createNamedHook('useWorkloadInfos', useWorkloadInfosImpl);