Update DeleteRow button action to take explicit props and fix massive width

This commit is contained in:
Andrew Kingston 2021-03-19 14:04:37 +00:00
parent 12ea52f3b1
commit 5a891054cb
1 changed files with 26 additions and 48 deletions

View File

@ -1,53 +1,35 @@
<script> <script>
import { Select, Label } from "@budibase/bbui" import { Select, Label } from "@budibase/bbui"
import { store, currentAsset } from "builderStore" import { store, currentAsset, backendUiStore } from "builderStore"
import { import { getBindableProperties } from "builderStore/dataBinding"
getDataProviderComponents, import DrawerBindableInput from "components/common/DrawerBindableInput.svelte"
getDatasourceForProvider,
getSchemaForDatasource,
} from "builderStore/dataBinding"
export let parameters export let parameters
$: dataProviderComponents = getDataProviderComponents( $: tableOptions = $backendUiStore.tables || []
$currentAsset, $: bindings = getBindableProperties($currentAsset, $store.selectedComponentId)
$store.selectedComponentId
)
$: {
// Automatically set rev and table ID based on row ID
if (parameters.providerId) {
parameters.rowId = `{{ ${parameters.providerId}._id }}`
parameters.revId = `{{ ${parameters.providerId}._rev }}`
const providerComponent = dataProviderComponents.find(
provider => provider._id === parameters.providerId
)
const datasource = getDatasourceForProvider(
$currentAsset,
providerComponent
)
const { table } = getSchemaForDatasource(datasource)
if (table) {
parameters.tableId = table._id
}
}
}
</script> </script>
<div class="root"> <div class="root">
{#if dataProviderComponents.length === 0} <Label small>Table</Label>
<div class="cannot-use"> <Select thin secondary bind:value={parameters.tableId}>
Delete row can only be used within a component that provides data, such as
a List
</div>
{:else}
<Label small>Datasource</Label>
<Select thin secondary bind:value={parameters.providerId}>
<option value="" /> <option value="" />
{#each dataProviderComponents as provider} {#each tableOptions as table}
<option value={provider._id}>{provider._instanceName}</option> <option value={table._id}>{table.name}</option>
{/each} {/each}
</Select> </Select>
{/if}
<Label small>Row ID</Label>
<DrawerBindableInput
{bindings}
value={parameters.rowId}
on:change={value => (parameters.rowId = value.detail)} />
<Label small>Row Rev</Label>
<DrawerBindableInput
{bindings}
value={parameters.revId}
on:change={value => (parameters.revId = value.detail)} />
</div> </div>
<style> <style>
@ -57,11 +39,7 @@
row-gap: var(--spacing-s); row-gap: var(--spacing-s);
grid-template-columns: auto 1fr; grid-template-columns: auto 1fr;
align-items: baseline; align-items: baseline;
} max-width: 800px;
margin: 0 auto;
.cannot-use {
color: var(--red);
font-size: var(--font-size-s);
margin: auto;
} }
</style> </style>