apps/ui-library/content/docs/tanstack/dropzone.mdx
<ComponentPreview name="dropzone-demo" description="An alert with an icon, title and description. The title says 'Heads up!' and the description is 'You can add components to your app using the cli.'." showCode={false} />
<BlockItem name="dropzone-tanstack" description="Displays a control for easier uploading of files directly to Supabase Storage" />
Uploading files should be easy—this component handles the tricky parts for you.
The File Upload component makes it easy to add file uploads to your app, with built-in support for drag-and-drop, file type restrictions, image previews, and configurable limits on file size and number of files. All the essentials, ready to go.
Features
<Dropzone /> component to your page and it will handle the rest.props object to the component.import { Dropzone, DropzoneContent, DropzoneEmptyState } from '@/components/dropzone'
import { useSupabaseUpload } from '@/hooks/use-supabase-upload'
const FileUploadDemo = () => {
const props = useSupabaseUpload({
bucketName: 'test',
path: 'test',
allowedMimeTypes: ['image/*'],
maxFiles: 2,
maxFileSize: 1000 * 1000 * 10, // 10MB,
})
return (
<div className="w-[500px]">
<Dropzone {...props}>
<DropzoneEmptyState />
<DropzoneContent />
</Dropzone>
</div>
)
}
export { FileUploadDemo }
| Prop | Type | Default | Description |
|---|---|---|---|
bucketName | string | null | The name of the Supabase Storage bucket to upload to |
path | string | null | The path or subfolder to upload the file to |
allowedMimeTypes | string[] | [] | The MIME types to allow for upload |
maxFiles | number | 1 | Maximum number of files to upload |
maxFileSize | number | 1000 | Maximum file size in bytes |