@highlight-ui/file-management
v4.2.11
Published
This is file management package consisting of file uploader and file list
Downloads
2,168
Maintainers
Keywords
Readme
@highlight-ui/file-management
Installation
Using npm:
npm install @highlight-ui/file-management
Using yarn:
yarn add @highlight-ui/file-management
Using pnpm:
pnpm install @highlight-ui/file-management
In your (S)CSS file:
@import url('@highlight-ui/file-management');
Once the package is installed, you can import the library:
import { FileUploader, FileList } from '@highlight-ui/file-management';
Usage
import React, { useState } from 'react';
import { FileUploader, FileList } from '@highlight-ui/file-management';
export default function FileManagementExample() {
return (
<>
<FileUploader
disabled={false}
description="Drag and drop files here or click to upload"
maxFileSize={20840}
onDrop={handleDrop}
onDragOverText="Drop here!"
showIcon
title="Primary text"
image=""
/>
<FileList files={files} />
</>
);
}
Props 📜
FileUploader
| 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 |
FileList
| 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
|
FileListItem
| 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 |
Contributing 🖌️
Please visit personio.design for usage guidelines and visual examples.
If you're interested in contributing, please visit our contribution page.