mirror of
https://github.com/pezkuwichain/pwap.git
synced 2026-05-08 16:17:55 +00:00
c71ddb6e0d
- Clone Polkadot.js Apps repository - Update package.json with Pezkuwi branding - Add Pezkuwi endpoint to production chains (wss://pezkuwichain.app:9944) - Create comprehensive README for SDK UI - Set up project structure with all packages Next steps: - Apply Kurdistan colors (Kesk, Sor, Zer, Spi + Black) to UI theme - Replace logos with Pezkuwi branding - Test build and deployment
39 lines
1.3 KiB
TypeScript
39 lines
1.3 KiB
TypeScript
// Copyright 2017-2025 @polkadot/react-hooks authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { ApiPromise } from '@polkadot/api';
|
|
import type { Vec } from '@polkadot/types';
|
|
import type { PalletBrokerScheduleItem } from '@polkadot/types/lookup';
|
|
import type { Reservation } from './types.js';
|
|
|
|
import { useEffect, useState } from 'react';
|
|
|
|
import { createNamedHook, useCall } from '@polkadot/react-hooks';
|
|
|
|
import { processHexMask } from './utils/dataProcessing.js';
|
|
|
|
function useBrokerReservationsImpl (api: ApiPromise, ready: boolean): Reservation[] | undefined {
|
|
const reservations = useCall<[any, Vec<Vec<PalletBrokerScheduleItem>>[]]>(ready && api?.query.broker.reservations);
|
|
const [state, setState] = useState<Reservation[]>();
|
|
|
|
useEffect((): void => {
|
|
if (!reservations) {
|
|
return;
|
|
}
|
|
|
|
setState(
|
|
reservations.map((info: PalletBrokerScheduleItem[]) => {
|
|
return {
|
|
mask: processHexMask(info[0]?.mask),
|
|
maskBits: processHexMask(info[0]?.mask)?.length ?? 0,
|
|
task: info[0]?.assignment?.isTask ? info[0]?.assignment?.asTask.toString() : info[0]?.assignment?.isPool ? 'Pool' : ''
|
|
};
|
|
}
|
|
));
|
|
}, [reservations]);
|
|
|
|
return state;
|
|
}
|
|
|
|
export const useBrokerReservations = createNamedHook('useBrokerReservations', useBrokerReservationsImpl);
|