Extract mapper
This commit is contained in:
parent
21597a44c9
commit
5df68cfca7
|
@ -16,18 +16,14 @@
|
|||
export let span
|
||||
export let helpText = null
|
||||
export let type = FieldType.ATTACHMENT
|
||||
export let fieldApiMapper = {
|
||||
get: value => value,
|
||||
set: value => value,
|
||||
}
|
||||
|
||||
let fieldState
|
||||
let fieldApi
|
||||
|
||||
$: isSingle = type === FieldType.ATTACHMENT_SINGLE
|
||||
$: value =
|
||||
isSingle && !Array.isArray(fieldState?.value)
|
||||
? fieldState?.value
|
||||
? [fieldState.value]
|
||||
: []
|
||||
: fieldState?.value
|
||||
|
||||
const { API, notificationStore } = getContext("sdk")
|
||||
const formContext = getContext("form")
|
||||
const BYTES_IN_MB = 1000000
|
||||
|
@ -73,10 +69,7 @@
|
|||
}
|
||||
|
||||
const handleChange = e => {
|
||||
let value = e.detail
|
||||
if (isSingle) {
|
||||
value = value[0] || null
|
||||
}
|
||||
const value = fieldApiMapper.set(e.detail)
|
||||
const changed = fieldApi.setValue(value)
|
||||
if (onChange && changed) {
|
||||
onChange({ value })
|
||||
|
@ -99,7 +92,7 @@
|
|||
>
|
||||
{#if fieldState}
|
||||
<CoreDropzone
|
||||
{value}
|
||||
value={fieldApiMapper.get(fieldState.value)}
|
||||
disabled={fieldState.disabled || fieldState.readonly}
|
||||
error={fieldState.error}
|
||||
on:change={handleChange}
|
||||
|
@ -107,7 +100,7 @@
|
|||
{deleteAttachments}
|
||||
{handleFileTooLarge}
|
||||
{handleTooManyFiles}
|
||||
maximum={isSingle ? 1 : maximum}
|
||||
{maximum}
|
||||
{extensions}
|
||||
{compact}
|
||||
/>
|
||||
|
|
|
@ -1,6 +1,16 @@
|
|||
<script>
|
||||
import { FieldType } from "@budibase/types"
|
||||
import AttachmentField from "./AttachmentField.svelte"
|
||||
|
||||
const fieldApiMapper = {
|
||||
get: value => (!Array.isArray(value) && value ? [value] : value) || [],
|
||||
set: value => value[0] || null,
|
||||
}
|
||||
</script>
|
||||
|
||||
<AttachmentField {...$$restProps} type={FieldType.ATTACHMENT_SINGLE} />
|
||||
<AttachmentField
|
||||
{...$$restProps}
|
||||
type={FieldType.ATTACHMENT_SINGLE}
|
||||
maximum={1}
|
||||
{fieldApiMapper}
|
||||
/>
|
||||
|
|
Loading…
Reference in New Issue