2020-10-09 10:06:44 +13:00
|
|
|
<script>
|
|
|
|
import { Select, Label } from "@budibase/bbui"
|
2021-01-20 06:38:24 +13:00
|
|
|
import { store, currentAsset } from "builderStore"
|
|
|
|
import {
|
|
|
|
getDataProviderComponents,
|
|
|
|
getDatasourceForProvider,
|
|
|
|
getSchemaForDatasource,
|
|
|
|
} from "builderStore/dataBinding"
|
2020-10-09 10:06:44 +13:00
|
|
|
import SaveFields from "./SaveFields.svelte"
|
|
|
|
|
|
|
|
export let parameters
|
|
|
|
|
2021-01-20 06:38:24 +13:00
|
|
|
$: dataProviderComponents = getDataProviderComponents(
|
2021-02-16 09:03:29 +13:00
|
|
|
$currentAsset,
|
2021-01-20 04:39:04 +13:00
|
|
|
$store.selectedComponentId
|
|
|
|
)
|
2021-01-20 06:38:24 +13:00
|
|
|
$: providerComponent = dataProviderComponents.find(
|
|
|
|
provider => provider._id === parameters.providerId
|
|
|
|
)
|
|
|
|
$: schemaFields = getSchemaFields(providerComponent)
|
2020-10-09 10:06:44 +13:00
|
|
|
|
2021-01-20 06:38:24 +13:00
|
|
|
const getSchemaFields = component => {
|
|
|
|
const datasource = getDatasourceForProvider(component)
|
|
|
|
const { schema } = getSchemaForDatasource(datasource)
|
|
|
|
return Object.values(schema || {})
|
2020-10-09 10:06:44 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
const onFieldsChanged = e => {
|
|
|
|
parameters.fields = e.detail
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<div class="root">
|
2021-01-20 06:38:24 +13:00
|
|
|
{#if !dataProviderComponents.length}
|
2020-10-09 10:06:44 +13:00
|
|
|
<div class="cannot-use">
|
2021-01-20 06:38:24 +13:00
|
|
|
Save Row can only be used within a component that provides data, such as a
|
|
|
|
Repeater
|
2020-10-09 10:06:44 +13:00
|
|
|
</div>
|
|
|
|
{:else}
|
|
|
|
<Label size="m" color="dark">Datasource</Label>
|
2021-01-20 06:38:24 +13:00
|
|
|
<Select secondary bind:value={parameters.providerId}>
|
2020-10-09 10:06:44 +13:00
|
|
|
<option value="" />
|
2021-01-20 06:38:24 +13:00
|
|
|
{#each dataProviderComponents as provider}
|
|
|
|
<option value={provider._id}>{provider._instanceName}</option>
|
2020-10-09 10:06:44 +13:00
|
|
|
{/each}
|
|
|
|
</Select>
|
|
|
|
|
2021-01-20 07:51:51 +13:00
|
|
|
{#if parameters.providerId}
|
|
|
|
<SaveFields
|
|
|
|
parameterFields={parameters.fields}
|
|
|
|
{schemaFields}
|
|
|
|
on:fieldschanged={onFieldsChanged} />
|
|
|
|
{/if}
|
2020-10-09 10:06:44 +13:00
|
|
|
{/if}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
.root {
|
|
|
|
display: grid;
|
|
|
|
column-gap: var(--spacing-s);
|
|
|
|
row-gap: var(--spacing-s);
|
|
|
|
grid-template-columns: auto 1fr auto 1fr auto;
|
|
|
|
align-items: baseline;
|
|
|
|
}
|
|
|
|
|
|
|
|
.root :global(> div:nth-child(2)) {
|
|
|
|
grid-column-start: 2;
|
|
|
|
grid-column-end: 6;
|
|
|
|
}
|
|
|
|
|
|
|
|
.cannot-use {
|
|
|
|
color: var(--red);
|
|
|
|
font-size: var(--font-size-s);
|
|
|
|
text-align: center;
|
|
|
|
width: 70%;
|
|
|
|
margin: auto;
|
|
|
|
}
|
|
|
|
</style>
|