mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 07:48:00 +00:00
42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
// Copyright 2017-2026 @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 useMapEntries <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.entriesAt(at, ...params)
|
|
: entry.entries(...params)
|
|
).then((entries) => setState(
|
|
transform
|
|
? transform(entries)
|
|
: entries as unknown as T
|
|
)).catch(console.error);
|
|
}
|
|
}
|
|
}, [at, entry, params, transform]);
|
|
|
|
return state;
|
|
}
|