1
0
Fork 0
mirror of synced 2024-09-13 07:53:31 +12:00
budibase/packages/builder/src/components/common/Dropzone.svelte

34 lines
761 B
Svelte

<script>
import { Dropzone, notifications } from "@budibase/bbui"
import api from "builderStore/api"
export let value = []
export let label
const BYTES_IN_MB = 1000000
function handleFileTooLarge(fileSizeLimit) {
notifications.error(
`Files cannot exceed ${
fileSizeLimit / BYTES_IN_MB
}MB. Please try again with smaller files.`
)
}
async function processFiles(fileList) {
let data = new FormData()
for (let i = 0; i < fileList.length; i++) {
data.append("file", fileList[i])
}
const response = await api.post(`/api/attachments/process`, data, {})
return await response.json()
}
</script>
<Dropzone
bind:value
{label}
{...$$restProps}
{processFiles}
{handleFileTooLarge}
/>