1
0
Fork 0
mirror of synced 2024-09-21 11:53:49 +12:00
budibase/packages/builder/src/components/integration/QueryFieldsBuilder.svelte

99 lines
2.1 KiB
Svelte
Raw Normal View History

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>