budibase/packages/builder/src/userInterface/StateBindingControl.svelte

178 lines
3.9 KiB
Svelte
Raw Normal View History

2019-09-20 09:01:35 +02:00
<script>
import {
isString
} from "lodash/fp";
import IconButton from "../common/IconButton.svelte";
import {
isBinding, getBinding, setBinding
} from "../common/binding";
export let value="";
export let onChanged= () => {};
export let type="";
export let options=[];
let isBound=false;
let bindingPath="";
let bindingFallbackValue="";
let bindingSource="store";
2019-09-20 09:01:35 +02:00
let isExpanded = false;
let forceIsBound = false;
let canOnlyBind = false;
2019-09-20 09:01:35 +02:00
$: {
canOnlyBind = type === "state";
if(!forceIsBound && canOnlyBind)
forceIsBound = true;
2019-09-20 09:01:35 +02:00
isBound= forceIsBound || isBinding(value);
if(isBound) {
const binding = getBinding(value);
bindingPath= binding.path;
bindingFallbackValue= binding.fallback;
bindingSource = binding.source || "store";
2019-09-20 09:01:35 +02:00
} else {
bindingPath="";
bindingFallbackValue="";
bindingSource="store";
2019-09-20 09:01:35 +02:00
}
}
const clearBinding = () => {
forceIsBound = false;
onChanged("");
}
const bind = (path, fallback, source) => {
2019-09-20 09:01:35 +02:00
if(!path) {
clearBinding("");
return;
}
const binding = setBinding({path, fallback, source});
2019-09-20 09:01:35 +02:00
onChanged(binding);
}
const setBindingPath = ev => {
forceIsBound = canOnlyBind;
bind(ev.target.value, bindingFallbackValue, bindingSource)
2019-09-20 09:01:35 +02:00
}
const setBindingFallback = ev => {
bind(bindingPath, ev.target.value, bindingSource);
2019-09-20 09:01:35 +02:00
}
const setBindingSource = ev => {
bind(bindingPath, bindingFallbackValue, ev.target.value);
}
2019-09-20 09:01:35 +02:00
// const makeBinding = () => {
// forceIsBound=true;
// isExpanded=true;
// }
2019-09-20 09:01:35 +02:00
</script>
{#if isBound}
<div>
<div class="bound-header">
<div>{isExpanded ? "" : bindingPath}</div>
<IconButton icon={isExpanded ? "chevron-up" : "chevron-down"}
2019-09-20 09:01:35 +02:00
size="12"
on:click={() => isExpanded=!isExpanded}/>
{#if !canOnlyBind}
<IconButton icon="trash"
2019-09-20 09:01:35 +02:00
size="12"
on:click={clearBinding}/>
{/if}
2019-09-20 09:01:35 +02:00
</div>
{#if isExpanded}
<div>
<div class="binding-prop-label">Binding Path</div>
<input class="uk-input uk-form-small"
value={bindingPath}
on:change={setBindingPath} >
<div class="binding-prop-label">Fallback Value</div>
<input class="uk-input uk-form-small"
value={bindingFallbackValue}
on:change={setBindingFallback} >
<div class="binding-prop-label">Binding Source</div>
<select class="uk-select uk-form-small"
value={bindingSource}
on:change={setBindingSource}>
<option>store</option>
<option>context</option>
</select>
2019-09-20 09:01:35 +02:00
</div>
{/if}
</div>
{:else}
<div class="unbound-container">
{#if type === "bool"}
<div>
<IconButton icon={value == true ? "check-square" : "square"}
size="19"
on:click={() => onChanged(!value)} />
2019-09-20 09:01:35 +02:00
</div>
{:else if type === "options"}
<select class="uk-select uk-form-small"
value={value}
2019-10-18 18:32:03 +02:00
on:change={ev => onChanged(ev.target.value)}>
2019-09-20 09:01:35 +02:00
{#each options as option}
<option value={option}>{option}</option>
{/each}
</select>
{:else}
<input on:change={ev => onChanged(ev.target.value)}
bind:value={value}
style="flex: 1 0 auto;" />
2019-09-20 09:01:35 +02:00
{/if}
2019-09-20 09:01:35 +02:00
</div>
{/if}
<style>
.unbound-container {
display:flex;
}
2019-09-20 09:01:35 +02:00
.bound-header {
display: flex;
}
2019-09-20 09:01:35 +02:00
.bound-header > div:nth-child(1) {
flex: 1 0 auto;
width: 30px;
color: var(--secondary50);
padding-left: 5px;
}
2019-09-20 09:01:35 +02:00
.binding-prop-label {
color: var(--secondary50);
}
2019-09-20 09:01:35 +02:00
input {
font-size: 12px;
font-weight: 700;
color: #163057;
opacity: 0.7;
padding: 5px 10px;
box-sizing: border-box;
border: 1px solid #DBDBDB;
border-radius: 2px;
outline: none;
}
</style>