51 lines
1.5 KiB
Svelte
51 lines
1.5 KiB
Svelte
|
<script>
|
||
|
import { onMount } from "svelte"
|
||
|
import "@spectrum-css/checkbox/dist/index-vars.css"
|
||
|
import SpectrumField from "./SpectrumField.svelte"
|
||
|
|
||
|
export let field
|
||
|
export let label
|
||
|
export let text
|
||
|
|
||
|
let fieldState
|
||
|
let fieldApi
|
||
|
|
||
|
const onChange = event => {
|
||
|
fieldApi.setValue(event.target.checked)
|
||
|
}
|
||
|
|
||
|
// Ensure a valid boolean value is set
|
||
|
onMount(() => {
|
||
|
fieldApi.setValue($fieldState.value || false)
|
||
|
})
|
||
|
</script>
|
||
|
|
||
|
<SpectrumField {label} {field} bind:fieldState bind:fieldApi>
|
||
|
{#if fieldState}
|
||
|
<div class="spectrum-FieldGroup spectrum-FieldGroup--horizontal">
|
||
|
<label class="spectrum-Checkbox" class:is-invalid={!$fieldState.valid}>
|
||
|
<input
|
||
|
on:change={onChange}
|
||
|
type="checkbox"
|
||
|
class="spectrum-Checkbox-input"
|
||
|
id={$fieldState.fieldId} />
|
||
|
<span class="spectrum-Checkbox-box">
|
||
|
<svg
|
||
|
class="spectrum-Icon spectrum-UIIcon-Checkmark75 spectrum-Checkbox-checkmark"
|
||
|
focusable="false"
|
||
|
aria-hidden="true">
|
||
|
<use xlink:href="#spectrum-css-icon-Checkmark75" />
|
||
|
</svg>
|
||
|
<svg
|
||
|
class="spectrum-Icon spectrum-UIIcon-Dash75 spectrum-Checkbox-partialCheckmark"
|
||
|
focusable="false"
|
||
|
aria-hidden="true">
|
||
|
<use xlink:href="#spectrum-css-icon-Dash75" />
|
||
|
</svg>
|
||
|
</span>
|
||
|
<span class="spectrum-Checkbox-label">{text || 'Checkbox'}</span>
|
||
|
</label>
|
||
|
</div>
|
||
|
{/if}
|
||
|
</SpectrumField>
|