mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-06-13 17:31:07 +00:00
feat: initial Pezkuwi Apps rebrand from polkadot-apps
Rebranded terminology: - Polkadot → Pezkuwi - Kusama → Dicle - Westend → Zagros - Rococo → PezkuwiChain - Substrate → Bizinikiwi - parachain → teyrchain Custom logos with Kurdistan brand colors (#e6007a → #86e62a): - bizinikiwi-hexagon.svg - sora-bizinikiwi.svg - hezscanner.svg - heztreasury.svg - pezkuwiscan.svg - pezkuwistats.svg - pezkuwiassembly.svg - pezkuwiholic.svg
This commit is contained in:
@@ -0,0 +1,55 @@
|
||||
// Copyright 2017-2025 @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);
|
||||
Reference in New Issue
Block a user