This is file management package consisting of file uploader and file list
npm install @highlight-ui/file-management


Using npm:
``bash`
npm install @highlight-ui/file-management
Using yarn:
`bash`
yarn add @highlight-ui/file-management
Using pnpm:
`bash`
pnpm install @highlight-ui/file-management
In your (S)CSS file:
`scss`
@import url('@highlight-ui/file-management');
Once the package is installed, you can import the library:
`ts`
import { FileUploader, FileList } from '@highlight-ui/file-management';
`tsx
import React, { useState } from 'react';
import { FileUploader, FileList } from '@highlight-ui/file-management';
export default function FileManagementExample() {
return (
<>
description="Drag and drop files here or click to upload"
maxFileSize={20840}
onDrop={handleDrop}
onDragOverText="Drop here!"
showIcon
title="Primary text"
image=""
/>
>
);
}
`
| Prop | Type | Required | Default | Description |
| :--------------- | :---------------------------------------------------------------- | :------- | :------ | :------------------------------------------------------------------------------------------------------ |
| description | string | Yes | | Allows providing the description message which is shown on the uploader |onDragOverText
| | string | Yes | | Allows providing a text to be shown when dragging over the uploader |onDrop
| | (acceptedFiles: File[], rejectedFiles: FileRejection[]) => void | Yes | | Allows providing a callback for when drop event occurs |accept
| | string | No | | Allows providing a list of supported file extensions |multiple
| | boolean | No | true | Allows user to select multiple files or restrict it to only single file |className
| | string | No | | Allows providing a custom class name |disabled
| | boolean | No | false | Allows disabling the uploader |image
| | string | No | | Allows providing an image for the uploader, this value will be passed to src attribute of the image tag |maxFileSize
| | number | No | | Allows providing the maximum file size supported by the uploader |showIcon
| | boolean | No | true | Allows showing or hiding the image |title
| | string | No | | Allows providing a title to be shown for the uploader |onDragEnter
| | () => void | No | | Allows providing a callback for when dragenter event occurs |onDragLeave
| | () => void | No | | Allows providing a callback for when dragleave event occurs |onDragOver
| | () => void | No | | Allows providing a callback for when dragover event occurs |
| Prop | Type | Required | Default | Description |
| :---------- | :------------------------ | :------- | :-------- | :------------------------------------------------------------------------------------------------------- |
| files | FileListItem[] | Yes | | A list of files. See FileListItem definition below. |className
| | string | No | | Allows providing a custom class name |onDelete
| | (id) => void | No | | Allows providing a callback for when deleting a file |variant
| | 'default', 'selectable' | No | default | The FileList variant. When selectable, users can provide addition props selectedItems and onSelect |
| Prop | Type | Required | Default | Description |
| :------------------ | :-------------------------------------------- | :------- | :------ | :-------------------------------------- |
| id | string | Yes | | List item unique id |filename
| | string | Yes | | List item file name |canDelete
| | boolean | No | false | Can this item be deleted |downloadUrl
| | string | No | | The download url of the list item |previewUrl
| | string | No | | The preview url of the list item |validationStatus
| | "valid", "validating", "invalid", "warning" | No | | The validation status of the list item |validationMessage
| | string` | No | | The validation message of the list item |
Please visit personio.design for usage guidelines and visual examples.
If you're interested in contributing, please visit our contribution page.