mirror of
https://github.com/pezkuwichain/pwap.git
synced 2026-07-04 04:57:22 +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
71 lines
1.7 KiB
TypeScript
71 lines
1.7 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/react-components authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { Props as ExpanderProps } from './Expander.js';
|
|
|
|
import React, { useCallback, useMemo } from 'react';
|
|
|
|
import Table from './Table/index.js';
|
|
import Expander from './Expander.js';
|
|
import { styled } from './styled.js';
|
|
|
|
interface Props extends ExpanderProps {
|
|
empty?: string;
|
|
renderChildren?: (() => React.ReactNode[] | undefined | null) | null;
|
|
}
|
|
|
|
function mapRow (row: React.ReactNode, key: number): React.ReactNode {
|
|
return (
|
|
<tr key={key}>
|
|
<td>{row}</td>
|
|
</tr>
|
|
);
|
|
}
|
|
|
|
function ExpanderScroll ({ children, className, empty, renderChildren, summary }: Props): React.ReactElement<Props> {
|
|
const hasContent = useMemo(
|
|
() => !!(renderChildren || children),
|
|
[children, renderChildren]
|
|
);
|
|
|
|
const innerRender = useCallback(
|
|
(): React.ReactNode => (renderChildren || children) && (
|
|
<div className='tableContainer'>
|
|
<Table
|
|
empty={empty}
|
|
isInline
|
|
>
|
|
{renderChildren
|
|
? renderChildren()?.map(mapRow)
|
|
: Array.isArray(children)
|
|
? children.map(mapRow)
|
|
: <tr><td>{children}</td></tr>
|
|
}
|
|
</Table>
|
|
</div>
|
|
),
|
|
[children, empty, renderChildren]
|
|
);
|
|
|
|
return (
|
|
<StyledExpander
|
|
className={className}
|
|
renderChildren={hasContent ? innerRender : undefined}
|
|
summary={summary}
|
|
/>
|
|
);
|
|
}
|
|
|
|
const StyledExpander = styled(Expander)`
|
|
.tableContainer {
|
|
overflow-y: scroll;
|
|
display: block;
|
|
margin: 0 0 0 auto;
|
|
max-height: 13.75rem;
|
|
max-width: 25rem;
|
|
overflow-x: hidden;
|
|
}
|
|
`;
|
|
|
|
export default React.memo(ExpanderScroll);
|