2020-10-08 11:42:53 +02:00
|
|
|
<script>
|
2020-11-17 13:08:24 +01:00
|
|
|
import { getContext } from "svelte"
|
2020-10-08 23:06:44 +02:00
|
|
|
import { Label, DatePicker, Input, Select, Toggle } from "@budibase/bbui"
|
2020-10-08 11:42:53 +02:00
|
|
|
import Dropzone from "./attachments/Dropzone.svelte"
|
2020-10-09 20:10:28 +02:00
|
|
|
import LinkedRowSelector from "./LinkedRowSelector.svelte"
|
2020-10-08 11:42:53 +02:00
|
|
|
import { capitalise } from "./helpers"
|
2020-11-18 20:18:18 +01:00
|
|
|
|
|
|
|
const { styleable, screenStore } = getContext("app")
|
|
|
|
const dataProviderStore = getContext("data")
|
2020-10-08 11:42:53 +02:00
|
|
|
|
|
|
|
export let wide = false
|
2020-11-17 13:08:24 +01:00
|
|
|
export let styles
|
2020-10-08 11:42:53 +02:00
|
|
|
|
2020-11-18 22:06:12 +01:00
|
|
|
$: row = $dataProviderStore?.row
|
|
|
|
$: schema = $dataProviderStore?.table && $dataProviderStore.table.schema
|
2020-10-08 11:42:53 +02:00
|
|
|
$: fields = schema ? Object.keys(schema) : []
|
|
|
|
</script>
|
|
|
|
|
2020-11-17 13:08:24 +01:00
|
|
|
<div class="form-content" use:styleable={styles}>
|
|
|
|
<!-- <ErrorsBox errors={$store.saveRowErrors || {}} />-->
|
2020-10-08 23:06:44 +02:00
|
|
|
{#each fields as field}
|
|
|
|
<div class="form-field" class:wide>
|
|
|
|
{#if !(schema[field].type === 'boolean' && !wide)}
|
2020-10-16 09:34:56 +02:00
|
|
|
<Label extraSmall={!wide} grey>{capitalise(schema[field].name)}</Label>
|
2020-10-08 23:06:44 +02:00
|
|
|
{/if}
|
|
|
|
{#if schema[field].type === 'options'}
|
2020-11-17 13:08:24 +01:00
|
|
|
<Select secondary bind:value={row[field]}>
|
2020-10-08 23:06:44 +02:00
|
|
|
<option value="">Choose an option</option>
|
|
|
|
{#each schema[field].constraints.inclusion as opt}
|
|
|
|
<option>{opt}</option>
|
|
|
|
{/each}
|
|
|
|
</Select>
|
|
|
|
{:else if schema[field].type === 'datetime'}
|
2020-11-17 13:08:24 +01:00
|
|
|
<DatePicker bind:value={row[field]} />
|
2020-10-08 23:06:44 +02:00
|
|
|
{:else if schema[field].type === 'boolean'}
|
|
|
|
<Toggle
|
|
|
|
text={wide ? null : capitalise(schema[field].name)}
|
2020-11-17 13:08:24 +01:00
|
|
|
bind:checked={row[field]} />
|
2020-10-08 23:06:44 +02:00
|
|
|
{:else if schema[field].type === 'number'}
|
2020-11-17 13:08:24 +01:00
|
|
|
<Input type="number" bind:value={row[field]} />
|
2020-10-08 23:06:44 +02:00
|
|
|
{:else if schema[field].type === 'string'}
|
2020-11-17 13:08:24 +01:00
|
|
|
<Input bind:value={row[field]} />
|
2020-10-08 23:06:44 +02:00
|
|
|
{:else if schema[field].type === 'attachment'}
|
2020-11-17 13:08:24 +01:00
|
|
|
<Dropzone bind:files={row[field]} />
|
2020-10-08 23:06:44 +02:00
|
|
|
{:else if schema[field].type === 'link'}
|
2020-10-12 14:34:32 +02:00
|
|
|
<LinkedRowSelector
|
2020-10-08 23:06:44 +02:00
|
|
|
secondary
|
|
|
|
showLabel={false}
|
2020-11-17 13:08:24 +01:00
|
|
|
bind:linkedRows={row[field]}
|
2020-10-08 23:06:44 +02:00
|
|
|
schema={schema[field]} />
|
|
|
|
{/if}
|
2020-10-08 11:42:53 +02:00
|
|
|
</div>
|
2020-10-08 23:06:44 +02:00
|
|
|
{/each}
|
|
|
|
</div>
|
2020-10-08 11:42:53 +02:00
|
|
|
|
|
|
|
<style>
|
|
|
|
.form {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
align-items: center;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-content {
|
|
|
|
display: grid;
|
|
|
|
gap: var(--spacing-xl);
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-field {
|
|
|
|
display: grid;
|
|
|
|
}
|
|
|
|
.form-field.wide {
|
|
|
|
align-items: center;
|
2020-10-16 09:34:56 +02:00
|
|
|
grid-template-columns: 20% 1fr;
|
2020-10-08 11:42:53 +02:00
|
|
|
gap: var(--spacing-xl);
|
|
|
|
}
|
|
|
|
.form-field.wide :global(label) {
|
|
|
|
margin-bottom: 0;
|
|
|
|
}
|
|
|
|
</style>
|