Files
pwap/pezkuwi-sdk-ui/packages/react-hooks/src/useParaApi.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

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);