mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-25 11:37:55 +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,68 @@
|
||||
// Copyright 2017-2025 @pezkuwi/react-components authors & contributors
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
import React from 'react';
|
||||
|
||||
import { isString } from '@pezkuwi/util';
|
||||
|
||||
import CopyButton from './CopyButton.js';
|
||||
import Labelled from './Labelled.js';
|
||||
import { styled } from './styled.js';
|
||||
|
||||
interface Props {
|
||||
children?: React.ReactNode;
|
||||
className?: string;
|
||||
isDisabled?: boolean;
|
||||
isError?: boolean;
|
||||
isFull?: boolean;
|
||||
isHidden?: boolean;
|
||||
isMonospace?: boolean;
|
||||
isSmall?: boolean;
|
||||
isTrimmed?: boolean;
|
||||
label?: React.ReactNode;
|
||||
labelExtra?: React.ReactNode;
|
||||
value?: React.ReactNode | string | null;
|
||||
withCopy?: boolean;
|
||||
withLabel?: boolean;
|
||||
}
|
||||
|
||||
function Output ({ children, className = '', isDisabled, isError, isFull, isHidden, isMonospace, isSmall, isTrimmed, label, labelExtra, value, withCopy = false, withLabel }: Props): React.ReactElement<Props> {
|
||||
return (
|
||||
<StyledLabelled
|
||||
className={`${className} ui--Output`}
|
||||
isFull={isFull}
|
||||
isHidden={isHidden}
|
||||
isSmall={isSmall}
|
||||
label={label}
|
||||
labelExtra={labelExtra}
|
||||
withLabel={withLabel}
|
||||
>
|
||||
<div className={`ui--output ui dropdown selection ${isError ? ' error' : ''}${isMonospace ? ' monospace' : ''}${isDisabled ? 'isDisabled' : ''}`}>
|
||||
{isTrimmed && isString(value) && (value.length > 512)
|
||||
? `${value.slice(0, 256)}…${value.slice(-256)}`
|
||||
: value
|
||||
}
|
||||
{children}
|
||||
</div>
|
||||
{withCopy && (
|
||||
<CopyButton value={value} />
|
||||
)}
|
||||
</StyledLabelled>
|
||||
);
|
||||
}
|
||||
|
||||
const StyledLabelled = styled(Labelled)`
|
||||
.ui.selection.dropdown.ui--output.isDisabled {
|
||||
background: transparent;
|
||||
border-style: dashed;
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
pre {
|
||||
margin: 0;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
`;
|
||||
|
||||
export default React.memo(Output);
|
||||
Reference in New Issue
Block a user