mirror of
https://github.com/pezkuwichain/pwap.git
synced 2026-05-08 16:17:55 +00:00
c71ddb6e0d
- Clone Polkadot.js Apps repository - Update package.json with Pezkuwi branding - Add Pezkuwi endpoint to production chains (wss://pezkuwichain.app:9944) - Create comprehensive README for SDK UI - Set up project structure with all packages Next steps: - Apply Kurdistan colors (Kesk, Sor, Zer, Spi + Black) to UI theme - Replace logos with Pezkuwi branding - Test build and deployment
56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
// Copyright 2017-2025 @polkadot/react-hooks authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { ApiPromise } from '@polkadot/api';
|
|
import type { LinkOption } from '@polkadot/apps-config/endpoints/types';
|
|
import type { BN } from '@polkadot/util';
|
|
|
|
import { useEffect, useState } from 'react';
|
|
|
|
import { arrayShuffle } from '@polkadot/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);
|