LongFormField readonly prop

This commit is contained in:
Mel O'Hagan 2023-11-01 13:54:18 +00:00
parent 7af61ef249
commit 5c049e0465
6 changed files with 46 additions and 1 deletions

View File

@ -4,6 +4,7 @@
export let value = "" export let value = ""
export let placeholder = null export let placeholder = null
export let disabled = false export let disabled = false
export let readonly = false
export let error = null export let error = null
export let height = null export let height = null
export let id = null export let id = null
@ -20,6 +21,7 @@
{fullScreenOffset} {fullScreenOffset}
{disabled} {disabled}
{easyMDEOptions} {easyMDEOptions}
{readonly}
on:change on:change
/> />
</div> </div>

View File

@ -5,6 +5,7 @@
export let value = "" export let value = ""
export let placeholder = null export let placeholder = null
export let disabled = false export let disabled = false
export let readonly = false
export let error = null export let error = null
export let id = null export let id = null
export let height = null export let height = null
@ -61,6 +62,7 @@
class="spectrum-Textfield-input" class="spectrum-Textfield-input"
style={align ? `text-align: ${align}` : ""} style={align ? `text-align: ${align}` : ""}
{disabled} {disabled}
{readonly}
{id} {id}
on:focus={() => (focus = true)} on:focus={() => (focus = true)}
on:blur={onChange} on:blur={onChange}

View File

@ -8,6 +8,7 @@
export let id = null export let id = null
export let fullScreenOffset = 0 export let fullScreenOffset = 0
export let disabled = false export let disabled = false
export let readonly = false
export let easyMDEOptions export let easyMDEOptions
const dispatch = createEventDispatcher() const dispatch = createEventDispatcher()
@ -19,6 +20,7 @@
// control // control
$: checkValue(value) $: checkValue(value)
$: mde?.codemirror.on("change", debouncedUpdate) $: mde?.codemirror.on("change", debouncedUpdate)
$: mde?.codemirror.setOption("readOnly", readonly)
const checkValue = val => { const checkValue = val => {
if (mde && val !== latestValue) { if (mde && val !== latestValue) {
@ -43,7 +45,7 @@
const debouncedUpdate = debounce(update, 250) const debouncedUpdate = debounce(update, 250)
</script> </script>
{#key height} {#key (height, readonly)}
<SpectrumMDE <SpectrumMDE
bind:mde bind:mde
scroll={true} scroll={true}
@ -54,6 +56,7 @@
easyMDEOptions={{ easyMDEOptions={{
initialValue: value, initialValue: value,
placeholder, placeholder,
toolbar: readonly ? false : undefined,
...easyMDEOptions, ...easyMDEOptions,
}} }}
/> />

View File

@ -2589,6 +2589,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": "text", "type": "text",
"label": "Initial form step", "label": "Initial form step",
@ -2738,6 +2749,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": "validation/string", "type": "validation/string",
"label": "Validation", "label": "Validation",
@ -3427,6 +3449,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": "validation/string", "type": "validation/string",
"label": "Validation", "label": "Validation",

View File

@ -8,6 +8,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 format = "auto" export let format = "auto"
@ -71,6 +72,7 @@
value={fieldState.value} value={fieldState.value}
on:change={handleChange} on:change={handleChange}
disabled={fieldState.disabled} disabled={fieldState.disabled}
{readonly}
error={fieldState.error} error={fieldState.error}
id={fieldState.fieldId} id={fieldState.fieldId}
{placeholder} {placeholder}
@ -88,6 +90,7 @@
value={fieldState.value} value={fieldState.value}
on:change={handleChange} on:change={handleChange}
disabled={fieldState.disabled} disabled={fieldState.disabled}
{readonly}
error={fieldState.error} error={fieldState.error}
id={fieldState.fieldId} id={fieldState.fieldId}
{placeholder} {placeholder}

View File

@ -11,6 +11,7 @@
export let defaultValue = "" export let defaultValue = ""
export let align export let align
export let onChange export let onChange
export let readonly = false
let fieldState let fieldState
let fieldApi let fieldApi
@ -44,6 +45,7 @@
{placeholder} {placeholder}
{type} {type}
{align} {align}
{readonly}
/> />
{/if} {/if}
</Field> </Field>