mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 14:47:58 +00:00
56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/react-hooks authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { ApiPromise } from '@pezkuwi/api';
|
|
import type { LinkOption } from '@pezkuwi/apps-config/endpoints/types';
|
|
import type { BN } from '@pezkuwi/util';
|
|
|
|
import { useEffect, useState } from 'react';
|
|
|
|
import { arrayShuffle } from '@pezkuwi/util';
|
|
|
|
import { createNamedHook } from './createNamedHook.js';
|
|
import { useApiUrl } from './useApiUrl.js';
|
|
import { useIsMountedRef } from './useIsMountedRef.js';
|
|
import { useParaEndpoints } from './useParaEndpoints.js';
|
|
|
|
interface Result {
|
|
api?: ApiPromise | null;
|
|
endpoints: LinkOption[];
|
|
urls: string[];
|
|
}
|
|
|
|
function useParaApiImpl (paraId: BN | number): Result {
|
|
const mountedRef = useIsMountedRef();
|
|
const endpoints = useParaEndpoints(paraId);
|
|
const [state, setState] = useState<Result>(() => ({
|
|
api: null,
|
|
endpoints,
|
|
urls: []
|
|
}));
|
|
const api = useApiUrl(state.urls);
|
|
|
|
useEffect((): void => {
|
|
mountedRef.current && setState({
|
|
api: null,
|
|
endpoints,
|
|
urls: arrayShuffle(
|
|
endpoints
|
|
.filter(({ isDisabled, isUnreachable }) => !isDisabled && !isUnreachable)
|
|
.map(({ value }) => value))
|
|
});
|
|
}, [endpoints, mountedRef]);
|
|
|
|
useEffect((): void => {
|
|
mountedRef.current && setState(({ endpoints, urls }) => ({
|
|
api,
|
|
endpoints,
|
|
urls
|
|
}));
|
|
}, [api, mountedRef]);
|
|
|
|
return state;
|
|
}
|
|
|
|
export const useParaApi = createNamedHook('useParaApi', useParaApiImpl);
|