2020-06-02 09:55:44 +12:00
|
|
|
<script>
|
|
|
|
import { backendUiStore } from "builderStore"
|
2020-08-31 02:28:46 +12:00
|
|
|
import { Input, Label } from "@budibase/bbui"
|
2020-06-02 09:55:44 +12:00
|
|
|
|
|
|
|
export let value
|
2020-09-14 22:51:52 +12:00
|
|
|
$: modelId = value && value.model ? value.model._id : ""
|
|
|
|
$: schemaFields = Object.keys(value && value.model ? value.model.schema : {})
|
|
|
|
|
|
|
|
function onChangeModel(e) {
|
|
|
|
value.model = $backendUiStore.models.find(x => x._id === e.target.value)
|
|
|
|
}
|
2020-09-03 23:02:15 +12:00
|
|
|
|
|
|
|
function setParsedValue(evt, field) {
|
|
|
|
const fieldSchema = value.model.schema[field]
|
|
|
|
if (fieldSchema.type === "number") {
|
|
|
|
value[field] = parseInt(evt.target.value)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
value[field] = evt.target.value
|
|
|
|
}
|
2020-06-02 09:55:44 +12:00
|
|
|
</script>
|
|
|
|
|
2020-09-10 18:46:01 +12:00
|
|
|
<div class="block-field">
|
2020-09-14 22:51:52 +12:00
|
|
|
<select
|
|
|
|
class="budibase__input"
|
|
|
|
value={modelId}
|
|
|
|
on:blur={onChangeModel}
|
|
|
|
on:change={onChangeModel}>
|
2020-09-12 08:14:58 +12:00
|
|
|
<option value="">Choose an option</option>
|
2020-08-31 01:49:25 +12:00
|
|
|
{#each $backendUiStore.models as model}
|
2020-09-12 08:14:58 +12:00
|
|
|
<option value={model._id}>{model.name}</option>
|
2020-08-31 01:49:25 +12:00
|
|
|
{/each}
|
|
|
|
</select>
|
2020-06-02 09:55:44 +12:00
|
|
|
</div>
|
|
|
|
|
2020-09-14 22:51:52 +12:00
|
|
|
{#if schemaFields.length}
|
2020-08-23 08:34:46 +12:00
|
|
|
<div class="bb-margin-xl block-field">
|
2020-09-02 08:28:38 +12:00
|
|
|
<Label small forAttr={'fields'}>Fields</Label>
|
2020-09-14 22:51:52 +12:00
|
|
|
{#each schemaFields as field}
|
2020-08-31 01:49:25 +12:00
|
|
|
<div class="bb-margin-xl">
|
2020-09-03 23:02:15 +12:00
|
|
|
<Input
|
|
|
|
thin
|
|
|
|
value={value[field]}
|
|
|
|
label={field}
|
|
|
|
on:change={e => setParsedValue(e, field)} />
|
2020-06-02 09:55:44 +12:00
|
|
|
</div>
|
|
|
|
{/each}
|
|
|
|
</div>
|
|
|
|
{/if}
|