budibase/packages/builder/src/components/userInterface/FlatButtonGroup.svelte

56 lines
1.1 KiB
Svelte
Raw Normal View History

2020-05-07 15:30:04 +02:00
<script>
import { onMount } from "svelte"
import FlatButton from "./FlatButton.svelte"
export let buttonProps = []
export let isMultiSelect = false
export let value = []
export let initialValue = ""
export let onChange = selected => {}
onMount(() => {
if (!value && !!initialValue) {
value = initialValue
}
})
function onButtonClicked(v) {
let val
if (isMultiSelect) {
if (value.includes(v)) {
let idx = value.findIndex(i => i === v)
val = [...value].splice(idx, 1)
} else {
val = [...value, v]
}
} else {
val = v
}
onChange(val)
}
2020-06-01 17:31:58 +02:00
const checkSelected = val =>
isMultiSelect ? value.includes(val) : value === val
2020-05-07 15:30:04 +02:00
</script>
<div class="flatbutton-group">
{#each buttonProps as props}
<div class="button-container">
<FlatButton
2020-06-01 19:04:45 +02:00
selected={isMultiSelect ? value.includes(props.value) : value === props.value}
2020-05-07 15:30:04 +02:00
onClick={onButtonClicked}
{...props} />
</div>
{/each}
</div>
<style>
.flatbutton-group {
display: flex;
2020-06-24 16:41:33 +02:00
width: 100%;
2020-05-07 15:30:04 +02:00
}
.button-container {
flex: 1;
}
</style>