Pickers readonly prop

This commit is contained in:
Mel O'Hagan 2023-11-01 14:56:28 +00:00
parent 5c049e0465
commit 5c36d70a01
5 changed files with 40 additions and 0 deletions

View File

@ -8,6 +8,7 @@
export let options = [] export let options = []
export let error = null export let error = null
export let disabled = false export let disabled = false
export let readonly = false
export let getOptionLabel = option => option export let getOptionLabel = option => option
export let getOptionValue = option => option export let getOptionValue = option => option
@ -40,6 +41,11 @@
> >
<input <input
on:change={onChange} on:change={onChange}
on:click={e => {
if (readonly) {
e.preventDefault()
}
}}
type="checkbox" type="checkbox"
class="spectrum-Checkbox-input" class="spectrum-Checkbox-input"
value={optionValue} value={optionValue}

View File

@ -8,6 +8,7 @@
export let options = [] export let options = []
export let error = null export let error = null
export let disabled = false export let disabled = false
export let readonly = false
export let getOptionLabel = option => option export let getOptionLabel = option => option
export let getOptionValue = option => option export let getOptionValue = option => option
export let getOptionTitle = option => option export let getOptionTitle = option => option
@ -43,6 +44,11 @@
> >
<input <input
on:change={onChange} on:change={onChange}
on:click={e => {
if (readonly) {
e.preventDefault()
}
}}
bind:group={value} bind:group={value}
value={getOptionValue(option)} value={getOptionValue(option)}
type="radio" type="radio"

View File

@ -3071,6 +3071,17 @@
"key": "disabled", "key": "disabled",
"defaultValue": false "defaultValue": false
}, },
{
"type": "boolean",
"label": "Read only",
"key": "readonly",
"defaultValue": false,
"dependsOn": {
"setting": "disabled",
"value": true,
"invert": true
}
},
{ {
"type": "select", "type": "select",
"label": "Options source", "label": "Options source",
@ -3196,6 +3207,17 @@
"key": "disabled", "key": "disabled",
"defaultValue": false "defaultValue": false
}, },
{
"type": "boolean",
"label": "Read only",
"key": "readonly",
"defaultValue": false,
"dependsOn": {
"setting": "disabled",
"value": true,
"invert": true
}
},
{ {
"type": "select", "type": "select",
"label": "Type", "label": "Type",

View File

@ -6,6 +6,7 @@
export let label export let label
export let placeholder export let placeholder
export let disabled = false export let disabled = false
export let readonly = false
export let validation export let validation
export let defaultValue export let defaultValue
export let optionsSource = "schema" export let optionsSource = "schema"
@ -71,6 +72,7 @@
getOptionValue={flatOptions ? x => x : x => x.value} getOptionValue={flatOptions ? x => x : x => x.value}
id={fieldState.fieldId} id={fieldState.fieldId}
disabled={fieldState.disabled} disabled={fieldState.disabled}
{readonly}
on:change={handleChange} on:change={handleChange}
{placeholder} {placeholder}
{options} {options}
@ -81,6 +83,7 @@
value={fieldState.value || []} value={fieldState.value || []}
id={fieldState.fieldId} id={fieldState.fieldId}
disabled={fieldState.disabled} disabled={fieldState.disabled}
{readonly}
error={fieldState.error} error={fieldState.error}
{options} {options}
{direction} {direction}

View File

@ -6,6 +6,7 @@
export let label export let label
export let placeholder export let placeholder
export let disabled = false export let disabled = false
export let readonly = false
export let optionsType = "select" export let optionsType = "select"
export let validation export let validation
export let defaultValue export let defaultValue
@ -58,6 +59,7 @@
value={fieldState.value} value={fieldState.value}
id={fieldState.fieldId} id={fieldState.fieldId}
disabled={fieldState.disabled} disabled={fieldState.disabled}
{readonly}
error={fieldState.error} error={fieldState.error}
{options} {options}
{placeholder} {placeholder}
@ -72,6 +74,7 @@
value={fieldState.value} value={fieldState.value}
id={fieldState.fieldId} id={fieldState.fieldId}
disabled={fieldState.disabled} disabled={fieldState.disabled}
{readonly}
error={fieldState.error} error={fieldState.error}
{options} {options}
{direction} {direction}