1
0
Fork 0
mirror of synced 2024-07-02 21:10:43 +12:00

initial work on handling single vs multiple values in builder components

This commit is contained in:
Keviin Åberg Kultalahti 2021-02-09 15:35:09 +01:00
parent b8130183bb
commit b4cc7c6776

View file

@ -8,6 +8,8 @@
export let schema
export let linkedRows = []
console.log(schema)
console.log(linkedRows)
let rows = []
$: label = capitalise(schema.name)
@ -31,6 +33,12 @@
function getPrettyName(row) {
return row[linkedTable.primaryDisplay || "_id"]
}
let oneToManyRow = getPrettyName(linkedRows[0]) || ''
function oneToManyValueSetter(value) {
linkedRows = [value]
}
</script>
{#if linkedTable.primaryDisplay == null}
@ -41,13 +49,22 @@
table.
</Label>
{:else}
<Multiselect
secondary
bind:value={linkedRows}
{label}
placeholder="Choose some options">
{#each rows as row}
<option value={row._id}>{getPrettyName(row)}</option>
{/each}
</Multiselect>
{#if schema.oneToMany}
<Select on:change={e => oneToManyValueSetter(e.target.value)} value={getPrettyName(oneToManyRow)} name="Test" label="Flavour">
<option value="">Choose an option</option>
{#each rows as row}
<option value={row._id}>{getPrettyName(row)}</option>
{/each}
</Select>
{:else}
<Multiselect
secondary
bind:value={linkedRows}
{label}
placeholder="Choose some options">
{#each rows as row}
<option value={row._id}>{getPrettyName(row)}</option>
{/each}
</Multiselect>
{/if}
{/if}