mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-30 08:28:00 +00:00
d21bfb1320
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
42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
// Copyright 2017-2025 @pezkuwi/react-hooks authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { QueryableStorageEntry } from '@pezkuwi/api/types';
|
|
|
|
import { useEffect, useRef, useState } from 'react';
|
|
|
|
import { stringify } from '@pezkuwi/util';
|
|
|
|
interface Options <T> {
|
|
transform?: (value: any[]) => T[];
|
|
}
|
|
|
|
// FIXME This is generic, we cannot really use createNamedHook
|
|
export function useMapKeys <T = any> (entry: QueryableStorageEntry<'promise'> | null | false | undefined, params?: unknown[] | null, { transform }: Options<T> = {}, at?: string | null | false): T[] | undefined {
|
|
const [state, setState] = useState<T[] | undefined>();
|
|
const checkRef = useRef<string | null>(null);
|
|
|
|
useEffect((): void => {
|
|
if (entry && params) {
|
|
const check = stringify({ at, params });
|
|
|
|
if (check !== checkRef.current) {
|
|
checkRef.current = check;
|
|
|
|
(
|
|
at && at !== '0'
|
|
// eslint-disable-next-line deprecation/deprecation
|
|
? entry.keysAt(at, ...params)
|
|
: entry.keys(...params)
|
|
).then((keys) => setState(
|
|
transform
|
|
? transform(keys)
|
|
: keys as unknown as T[]
|
|
)).catch(console.error);
|
|
}
|
|
}
|
|
}, [at, entry, params, transform]);
|
|
|
|
return state;
|
|
}
|