mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-25 14:57:59 +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,42 @@
|
||||
// Copyright 2017-2025 @pezkuwi/react-components authors & contributors
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
import React, { useEffect, useState } from 'react';
|
||||
|
||||
import { nextTick } from '@pezkuwi/util';
|
||||
|
||||
import Spinner from './Spinner.js';
|
||||
|
||||
interface Props {
|
||||
children: React.ReactNode[];
|
||||
isActive?: boolean;
|
||||
}
|
||||
|
||||
function NextTick ({ children, isActive = true }: Props): React.ReactElement<Props> {
|
||||
const [visibility, setVisibility] = useState(() => new Array<boolean>(children.length).fill(false));
|
||||
|
||||
useEffect((): void => {
|
||||
if (isActive) {
|
||||
const index = visibility.findIndex((v) => !v);
|
||||
|
||||
if (index !== -1) {
|
||||
nextTick(() =>
|
||||
setVisibility(
|
||||
visibility.map((v, i) => (i === index) || v)
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
||||
}, [isActive, visibility]);
|
||||
|
||||
return (
|
||||
<>
|
||||
{isActive
|
||||
? visibility.map((isVisible, index) => isVisible && children[index])
|
||||
: <Spinner />
|
||||
}
|
||||
</>
|
||||
);
|
||||
}
|
||||
|
||||
export default React.memo(NextTick);
|
||||
Reference in New Issue
Block a user