2021-01-14 03:11:53 +13:00
|
|
|
<script>
|
|
|
|
import {
|
|
|
|
Button,
|
|
|
|
TextArea,
|
|
|
|
Label,
|
|
|
|
Input,
|
|
|
|
Heading,
|
|
|
|
Select
|
|
|
|
} from "@budibase/bbui"
|
|
|
|
|
|
|
|
export let fields = {}
|
|
|
|
export let schema
|
2021-01-15 03:22:24 +13:00
|
|
|
export let editable
|
2021-01-14 03:11:53 +13:00
|
|
|
|
|
|
|
let draftField = {}
|
|
|
|
|
2021-01-15 09:51:03 +13:00
|
|
|
$: fieldKeys = Object.keys(fields)
|
|
|
|
$: schemaKeys = Object.keys(schema.fields)
|
|
|
|
|
|
|
|
$: console.log({ fields, schema })
|
|
|
|
|
2021-01-14 03:11:53 +13:00
|
|
|
function addField() {
|
|
|
|
// Add the new field to custom fields for the query
|
2021-01-15 09:51:03 +13:00
|
|
|
schema.fields[draftField.name] = {
|
2021-01-14 03:11:53 +13:00
|
|
|
type: draftField.type
|
|
|
|
}
|
|
|
|
// reset the draft field
|
|
|
|
draftField = {}
|
|
|
|
}
|
2021-01-15 09:51:03 +13:00
|
|
|
|
|
|
|
function removeField(field) {
|
|
|
|
delete fields[field]
|
|
|
|
fields = fields
|
|
|
|
|
|
|
|
delete schema.fields[field]
|
|
|
|
schema = schema
|
|
|
|
}
|
2021-01-14 03:11:53 +13:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<form on:submit|preventDefault>
|
2021-01-15 09:51:03 +13:00
|
|
|
{#each schemaKeys as field}
|
2021-01-14 03:11:53 +13:00
|
|
|
<Label extraSmall grey>{field}</Label>
|
2021-01-15 09:51:03 +13:00
|
|
|
<div class="field">
|
|
|
|
<Input
|
|
|
|
disabled={!editable}
|
|
|
|
type={schema.fields[field]?.type}
|
|
|
|
required={schema.fields[field]?.required}
|
|
|
|
bind:value={fields[field]} />
|
|
|
|
{#if !schema.fields[field]?.required}
|
|
|
|
<i class="ri-close-circle-line" on:click={() => removeField(field)} />
|
|
|
|
{/if}
|
|
|
|
</div>
|
2021-01-14 03:11:53 +13:00
|
|
|
{/each}
|
|
|
|
</form>
|
2021-01-15 09:51:03 +13:00
|
|
|
{#if schema.customisable && editable}
|
|
|
|
<div>
|
|
|
|
<Label>Add Custom Field</Label>
|
|
|
|
<div class="new-field">
|
|
|
|
<Label extraSmall grey>Name</Label>
|
|
|
|
<Label extraSmall grey>Type</Label>
|
|
|
|
<Input thin bind:value={draftField.name} />
|
|
|
|
<Select thin secondary bind:value={draftField.type}>
|
|
|
|
<option value={"text"}>String</option>
|
|
|
|
<option value={"number"}>Number</option>
|
|
|
|
</Select>
|
|
|
|
</div>
|
|
|
|
<Button small thin secondary on:click={addField}>Add Field</Button>
|
|
|
|
</div>
|
|
|
|
{/if}
|
|
|
|
|
2021-01-14 03:11:53 +13:00
|
|
|
|
|
|
|
<style>
|
|
|
|
.new-field {
|
|
|
|
display: grid;
|
|
|
|
grid-template-columns: 1fr 1fr;
|
|
|
|
grid-gap: var(--spacing-m);
|
|
|
|
margin-top: var(--spacing-m);
|
|
|
|
margin-bottom: var(--spacing-m);
|
|
|
|
}
|
2021-01-15 09:51:03 +13:00
|
|
|
|
|
|
|
.field {
|
|
|
|
margin-bottom: var(--spacing-m);
|
|
|
|
display: grid;
|
|
|
|
grid-template-columns: 1fr 2%;
|
|
|
|
grid-gap: var(--spacing-m);
|
|
|
|
align-items: center;
|
|
|
|
}
|
|
|
|
|
|
|
|
i {
|
|
|
|
transition: all 0.2s;
|
|
|
|
}
|
|
|
|
|
|
|
|
i:hover {
|
|
|
|
transform: scale(1.1);
|
|
|
|
font-weight: 500;
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
|
2021-01-14 03:11:53 +13:00
|
|
|
</style>
|