mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 20:37:57 +00:00
42 lines
958 B
TypeScript
42 lines
958 B
TypeScript
// Copyright 2017-2026 @pezkuwi/react-params authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { Size } from '../types.js';
|
|
|
|
import React from 'react';
|
|
|
|
import { Labelled } from '@pezkuwi/react-components';
|
|
|
|
import Bare from './Bare.js';
|
|
|
|
interface Props {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
isDisabled?: boolean;
|
|
isOuter?: boolean;
|
|
label?: React.ReactNode;
|
|
labelExtra?: React.ReactNode;
|
|
size?: Size;
|
|
withLabel?: boolean;
|
|
}
|
|
|
|
function Base ({ children, className = '', isOuter, label, labelExtra, size = 'full', withLabel }: Props): React.ReactElement<Props> {
|
|
return (
|
|
<Bare className={className}>
|
|
<Labelled
|
|
className={size}
|
|
isOuter
|
|
label={label}
|
|
labelExtra={labelExtra}
|
|
withEllipsis
|
|
withLabel={withLabel}
|
|
>
|
|
{!isOuter && children}
|
|
</Labelled>
|
|
{isOuter && children}
|
|
</Bare>
|
|
);
|
|
}
|
|
|
|
export default React.memo(Base);
|