mirror of
https://github.com/YunoHost/yunohost-admin.git
synced 2024-09-03 20:06:15 +02:00
fix: SelectItem: handle _none
choice
This commit is contained in:
parent
9649627bb8
commit
3e877c1380
1 changed files with 16 additions and 2 deletions
|
@ -23,7 +23,21 @@ defineEmits<{
|
||||||
'update:modelValue': [value: string | null]
|
'update:modelValue': [value: string | null]
|
||||||
}>()
|
}>()
|
||||||
|
|
||||||
const model = defineModel<string | number | null>()
|
const model = defineModel<string | number | null>({
|
||||||
|
set: (value) => {
|
||||||
|
if (value === 'null') {
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
return value
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
const isOptionalSelectOption = computed(() => {
|
||||||
|
// FIXME `None` handling for config panels is a bit weird
|
||||||
|
return props.choices?.some(
|
||||||
|
(choice) => typeof choice !== 'string' && choice.value === '_none',
|
||||||
|
)
|
||||||
|
})
|
||||||
|
|
||||||
const touch = inject(ValidationTouchSymbol)
|
const touch = inject(ValidationTouchSymbol)
|
||||||
|
|
||||||
|
@ -41,7 +55,7 @@ const required = computed(() => 'required' in (props?.validation ?? {}))
|
||||||
:required="required"
|
:required="required"
|
||||||
@blur="touch?.(touchKey)"
|
@blur="touch?.(touchKey)"
|
||||||
>
|
>
|
||||||
<template #first>
|
<template v-if="!isOptionalSelectOption" #first>
|
||||||
<BFormSelectOption value="null" :disabled="required">
|
<BFormSelectOption value="null" :disabled="required">
|
||||||
-- {{ required ? $t('select_an_option') : $t('words.none') }} --
|
-- {{ required ? $t('select_an_option') : $t('words.none') }} --
|
||||||
</BFormSelectOption>
|
</BFormSelectOption>
|
||||||
|
|
Loading…
Reference in a new issue