mirror of https://github.com/Budibase/budibase.git
8 changed files with 143 additions and 19 deletions
@ -0,0 +1,56 @@ |
|||
<script> |
|||
import { Select, Label, Input } from "@budibase/bbui" |
|||
import { onMount } from "svelte" |
|||
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte" |
|||
|
|||
export let parameters |
|||
export let bindings = [] |
|||
|
|||
const typeOptions = [ |
|||
{ |
|||
label: "Set value", |
|||
value: "set", |
|||
}, |
|||
{ |
|||
label: "Delete value", |
|||
value: "delete", |
|||
}, |
|||
] |
|||
|
|||
onMount(() => { |
|||
if (!parameters.type) { |
|||
parameters.type = "set" |
|||
} |
|||
}) |
|||
</script> |
|||
|
|||
<div class="root"> |
|||
<Label small>Type</Label> |
|||
<Select |
|||
placeholder={null} |
|||
bind:value={parameters.type} |
|||
options={typeOptions} |
|||
/> |
|||
<Label small>Key</Label> |
|||
<Input bind:value={parameters.key} /> |
|||
{#if parameters.type === "set"} |
|||
<Label small>Value</Label> |
|||
<DrawerBindableInput |
|||
{bindings} |
|||
value={parameters.value} |
|||
on:change={e => (parameters.value = e.detail)} |
|||
/> |
|||
{/if} |
|||
</div> |
|||
|
|||
<style> |
|||
.root { |
|||
display: grid; |
|||
column-gap: var(--spacing-l); |
|||
row-gap: var(--spacing-s); |
|||
grid-template-columns: 60px 1fr; |
|||
align-items: center; |
|||
max-width: 400px; |
|||
margin: 0 auto; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,8 @@ |
|||
<script> |
|||
import Provider from "./Provider.svelte" |
|||
import { stateStore } from "../store" |
|||
</script> |
|||
|
|||
<Provider key="state" data={$stateStore}> |
|||
<slot /> |
|||
</Provider> |
|||
@ -0,0 +1,25 @@ |
|||
import { writable } from "svelte/store" |
|||
|
|||
const createStateStore = () => { |
|||
const store = writable({}) |
|||
|
|||
const setValue = (key, value) => { |
|||
store.update(state => { |
|||
state[key] = value |
|||
return state |
|||
}) |
|||
} |
|||
const deleteValue = key => { |
|||
store.update(state => { |
|||
delete state[key] |
|||
return state |
|||
}) |
|||
} |
|||
|
|||
return { |
|||
subscribe: store.subscribe, |
|||
actions: { setValue, deleteValue }, |
|||
} |
|||
} |
|||
|
|||
export const stateStore = createStateStore() |
|||
Loading…
Reference in new issue