mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-05-07 09:37:58 +00:00
7a4bbeac25
- Update @pezkuwi/extension-inject to ^0.62.13 with proper /types exports - Update @pezkuwi/extension-dapp to ^0.62.13 - Update @pezkuwi/extension-compat-metamask to ^0.62.13 - Fix IconTheme type to include 'bizinikiwi' and 'pezkuwi' themes - Fix endpoint array issues (getTeleports -> direct array references) - Add type assertions for external package compatibility (acala, moonbeam, parallel) - Fix subspace.ts dynamic class typing - Fix conviction type in page-referenda - Update Pallet type names to Pezpallet prefix across codebase - Define InjectedExtension types locally for module resolution - Add styled-components DefaultTheme augmentation - Add react-copy-to-clipboard type declaration for React 18 Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
68 lines
2.1 KiB
TypeScript
68 lines
2.1 KiB
TypeScript
// Copyright 2017-2026 @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 { PezpalletBrokerScheduleItem } 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: PezpalletBrokerScheduleItem[], 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<PezpalletBrokerScheduleItem>[]]>(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);
|