Files
pwap/pezkuwi-sdk-ui/packages/react-hooks/src/useBrokerPotentialRenewals.ts
T
pezkuwichain 971df8edba Rebrand: Remove 3rd party chains, update domains to PezkuwiChain
- Remove all 3rd party parachain configurations from endpoints:
  - productionRelayPolkadot.ts: Keep only system parachains
  - productionRelayDicle.ts: Keep only system parachains
  - testingRelayZagros.ts: Keep only system parachains
  - testingRelayTeyrChain.ts: Keep only system parachains

- Update domain references:
  - polkadot.js.org → pezkuwichain.app
  - wiki.polkadot.network → wiki.pezkuwichain.io
  - dotapps.io → pezkuwichain.app
  - statement.polkadot.network → docs.pezkuwichain.io/statement
  - support.polkadot.network → docs.pezkuwichain.io

- Update repository references:
  - github.com/pezkuwi-js/apps → github.com/pezkuwichain/pwap

- Rename system parachains to Pezkuwi ecosystem:
  - PolkadotAssetHub → PezkuwiAssetHub
  - polkadotBridgeHub → pezkuwiBridgeHub
  - polkadotCollectives → pezkuwiCollectives
  - polkadotCoretime → pezkuwiCoretime
  - polkadotPeople → pezkuwiPeople

- Update network name in claims utility:
  - Polkadot → Pezkuwi
2026-01-09 03:08:11 +03:00

76 lines
2.7 KiB
TypeScript

// Copyright 2017-2026 @pezkuwi/react-hooks authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { ApiPromise } from '@pezkuwi/api';
import type { Option, StorageKey, u32 } from '@pezkuwi/types';
import type { PezpalletBrokerPotentialRenewalId, PezpalletBrokerPotentialRenewalRecord } from '@pezkuwi/types/lookup';
import type { PotentialRenewal } from './types.js';
import { useEffect, useState } from 'react';
import { createNamedHook, useCall, useMapKeys } from '@pezkuwi/react-hooks';
import { BN_ZERO } from '@pezkuwi/util';
import { processHexMask } from './utils/dataProcessing.js';
function extractInfo (info: Option<PezpalletBrokerPotentialRenewalRecord>, item: PezpalletBrokerPotentialRenewalId): PotentialRenewal | undefined {
const unwrapped: PezpalletBrokerPotentialRenewalRecord | null = info.isSome ? info.unwrap() : null;
let mask: string[] = [];
let task = '';
if (!unwrapped) {
return;
}
const completion = unwrapped?.completion;
if (completion?.isComplete) {
const complete = completion?.asComplete[0];
task = complete.assignment.isTask ? complete?.assignment.asTask.toString() : complete?.assignment.isPool ? 'Pool' : 'Idle';
mask = processHexMask(complete.mask);
} else if (completion?.isPartial) {
mask = processHexMask(completion?.asPartial);
task = '';
} else {
mask = [];
}
return {
// How much of a core has been assigned or, if completely assigned, the workload itself.
completion: completion?.type,
core: item?.core.toNumber(),
mask,
maskBits: mask?.length,
price: unwrapped?.price.toBn() || BN_ZERO,
task,
when: item?.when.toNumber()
};
}
const OPT_KEY = {
transform: (keys: StorageKey<[u32]>[]): u32[] =>
keys.map(({ args: [id] }) => id)
};
function useBrokerPotentialRenewalsImpl (api: ApiPromise, ready: boolean): PotentialRenewal[] | undefined {
const keys = useMapKeys(ready && api?.query.broker.potentialRenewals, [], OPT_KEY);
const potentialRenewals = useCall<[[PezpalletBrokerPotentialRenewalId[]], Option<PezpalletBrokerPotentialRenewalRecord>[]]>(ready && api?.query.broker.potentialRenewals.multi, [keys], { withParams: true });
const [state, setState] = useState<PotentialRenewal[] | undefined>();
useEffect((): void => {
if (!potentialRenewals) {
return;
}
const renewals = potentialRenewals[0][0].map((info, index) => extractInfo(potentialRenewals[1][index], info));
setState(renewals.filter((renewal): renewal is PotentialRenewal => !!renewal));
}, [potentialRenewals]);
return state;
}
export const useBrokerPotentialRenewals = createNamedHook('useBrokerPotentialRenewals', useBrokerPotentialRenewalsImpl);