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

40 lines
989 B
TypeScript

// Copyright 2017-2026 @pezkuwi/react-params authors & contributors
// SPDX-License-Identifier: Apache-2.0
import React from 'react';
import { InputFile } from '@pezkuwi/react-components';
import Bare from './Bare.js';
interface Props {
className?: string;
defaultValue?: unknown;
isDisabled?: boolean;
isError?: boolean;
label?: React.ReactNode;
labelExtra?: React.ReactNode;
onChange?: (contents: Uint8Array) => void;
placeholder?: string;
withLabel?: boolean;
}
function File ({ className = '', isDisabled, isError = false, label, labelExtra, onChange, placeholder, withLabel }: Props): React.ReactElement<Props> {
return (
<Bare className={className}>
<InputFile
isDisabled={isDisabled}
isError={isError}
label={label}
labelExtra={labelExtra}
onChange={onChange}
placeholder={placeholder}
withEllipsis
withLabel={withLabel}
/>
</Bare>
);
}
export default React.memo(File);