2021-04-16 15:30:33 +02:00
|
|
|
<script>
|
|
|
|
import Field from "./Field.svelte"
|
|
|
|
import RadioGroup from "./Core/RadioGroup.svelte"
|
|
|
|
import { createEventDispatcher } from "svelte"
|
|
|
|
|
|
|
|
export let value = null
|
2021-04-16 17:00:10 +02:00
|
|
|
export let label = null
|
2021-04-16 15:30:33 +02:00
|
|
|
export let disabled = false
|
|
|
|
export let labelPosition = "above"
|
|
|
|
export let error = null
|
|
|
|
export let options = []
|
|
|
|
export let getOptionLabel = option => extractProperty(option, "label")
|
|
|
|
export let getOptionValue = option => extractProperty(option, "value")
|
|
|
|
|
|
|
|
const dispatch = createEventDispatcher()
|
|
|
|
const onChange = e => {
|
|
|
|
dispatch("change", e.detail)
|
|
|
|
value = e.detail
|
|
|
|
}
|
|
|
|
const extractProperty = (value, property) => {
|
|
|
|
if (value && typeof value === "object") {
|
|
|
|
return value[property]
|
|
|
|
}
|
|
|
|
return value
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<Field {label} {labelPosition} {disabled} {error}>
|
|
|
|
<RadioGroup
|
|
|
|
{error}
|
|
|
|
{disabled}
|
|
|
|
{value}
|
|
|
|
{options}
|
|
|
|
{getOptionLabel}
|
|
|
|
{getOptionValue}
|
|
|
|
on:change={onChange} />
|
|
|
|
</Field>
|