From 41166cdfe0dee0b4e5f535383766f96d503efa9b Mon Sep 17 00:00:00 2001 From: Emerson Pfeiffer <epfeiffe@umich.edu> Date: Fri, 28 Jun 2024 10:31:27 -0700 Subject: [PATCH] Update Props and Usage Description for File Uploader Beta (#5336) --- .../yard/config/file-uploader-beta.ts | 51 ++++++++++++++----- .../pages/components/file-uploader-beta.mdx | 11 +++- 2 files changed, 48 insertions(+), 14 deletions(-) diff --git a/documentation-site/components/yard/config/file-uploader-beta.ts b/documentation-site/components/yard/config/file-uploader-beta.ts index e742494c01..27026e3da7 100644 --- a/documentation-site/components/yard/config/file-uploader-beta.ts +++ b/documentation-site/components/yard/config/file-uploader-beta.ts @@ -19,9 +19,6 @@ const changeHandlers = [ "onDragEnter", "onDragOver", "onDragLeave", - "onDrop", - "onDropAccepted", - "onDropRejected", "onFileDialogCancel", "onCancel", "onRetry", @@ -43,16 +40,37 @@ const FileUploaderBetaConfig: TConfig = { description: "Set accepted file types. See https://github.com/okonet/attr-accept for more information", }, + disabled: { + value: false, + type: PropTypes.Boolean, + description: "Renders component in disabled state.", + }, fileRows: { value: "[]", type: PropTypes.Array, description: "Array of file objects.", stateful: true, }, - setFileRows: { - value: "newFileRows => setFileRows(newFileRows)", - type: PropTypes.Function, - description: "Function to set file rows.", + hint: { + value: undefined, + type: PropTypes.String, + description: "Hint text to be displayed below the file rows.", + }, + itemPreview: { + value: false, + type: PropTypes.Boolean, + description: + "Renders a file preview thumbnail. Works best with image files.", + }, + label: { + value: undefined, + type: PropTypes.String, + description: "Label text to be displayed above the file uploader.", + }, + maxFiles: { + value: undefined, + type: PropTypes.Number, + description: "Maximum number of files that can be uploaded.", }, maxSize: { value: undefined, @@ -64,27 +82,36 @@ const FileUploaderBetaConfig: TConfig = { type: PropTypes.Number, description: "Minimum file size (in bytes).", }, + processFileOnDrop: { + value: undefined, + type: PropTypes.Function, + description: + "Application defined callback function that runs on file drop. Takes a File as input and returns a Promise<{ errorMessage: string | null; fileInfo?: any }>.", + }, + setFileRows: { + value: "newFileRows => setFileRows(newFileRows)", + type: PropTypes.Function, + description: "Function to set file rows.", + }, multiple: { value: undefined, type: PropTypes.Boolean, description: "Allow drag n drop (or selection from the file dialog) of multiple files", + hidden: true, }, disableClick: { value: undefined, type: PropTypes.Boolean, description: "Disallow clicking on the dropzone container to open file dialog.", - }, - disabled: { - value: false, - type: PropTypes.Boolean, - description: "Renders component in disabled state.", + hidden: true, }, errorMessage: { value: undefined, type: PropTypes.String, description: "Error message to be displayed.", + hidden: true, }, ...changeHandlers.reduce((acc, current) => { //@ts-ignore diff --git a/documentation-site/pages/components/file-uploader-beta.mdx b/documentation-site/pages/components/file-uploader-beta.mdx index 38c26b7b76..93cd769542 100644 --- a/documentation-site/pages/components/file-uploader-beta.mdx +++ b/documentation-site/pages/components/file-uploader-beta.mdx @@ -13,15 +13,22 @@ export default Layout; <Yard placeholderHeight={120} {...fileUploaderBetaYardConfig} /> -Creates a dropzone for file uploads with file row state binding, props to control errors, and props to control uploads. Inherits all style props from the `FileUploader` component. +Creates a dropzone for file uploads with file row state binding, props to control errors, and props to control uploads. ## Accessibility - "Browse files" has `aria-controls="fileupload"` set. -## When to use +## Inheritance + +- Inherits all props from the `FileUploader` component except for `onDrop`, `onDropAccepted`, and `onDropRejected`. These three props are replaced by the `processFileOnDrop` function prop. +- Inherits all style props from the `FileUploader` component. + +## How to use - Enable file(s) upload through drag and drop or the system _Browse files_ dialog. +- Leverage `accept`, `maxFiles`, `maxSize`, and `minSize` for built in error handling. +- Leverage `processFileOnDrop` for custom error handling and upload capabilities. Should take a `file: File` and input and return `Promise<{ errorMessage: string | null; fileInfo?: any }>` where `errorMessage` determines if an error is shown. ## Security considerations