mirror of
https://github.com/pezkuwichain/pwap.git
synced 2026-05-08 01:07:55 +00:00
971df8edba
- 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
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);
|