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