Files
pezkuwi-apps/packages/react-params/src/Param/Base.tsx
T

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);