12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { type Ref, onMounted, watch } from 'vue'
- import type { SelectOption } from '#shared/components/CommonSelect/types.ts'
- import useValue from '#shared/components/Form/composables/useValue.ts'
- import type { FlatSelectOption } from '#shared/components/Form/fields/FieldTreeSelect/types.ts'
- import type { FormFieldContext } from '#shared/components/Form/types/field.ts'
- const useSelectPreselect = (
- options: Ref<SelectOption[] | FlatSelectOption[]>,
- context: Ref<
- FormFieldContext<{
- clearable?: boolean
- multiple?: boolean
- }>
- >,
- ) => {
- const { hasValue } = useValue(context)
- // Consider only enabled options.
- const getPreselectValue = () =>
- options.value?.find((option) => !option.disabled)?.value
- // Remember function to use it during the next value check.
- context.value.getPreselectValue = getPreselectValue
- // Pre-select the first option of a single select when and only when the field is not clearable nor disabled.
- // This mimics the behavior of the native select field.
- const preselectOption = () => {
- if (
- !hasValue.value &&
- !context.value.disabled &&
- !context.value.multiple &&
- !context.value.clearable &&
- options.value &&
- options.value.length > 0
- ) {
- context.value.node.input(getPreselectValue(), false)
- }
- }
- onMounted(() => {
- if (!context.value.noInitialAutoPreselect) preselectOption()
- watch(
- () =>
- !hasValue.value &&
- !context.value.disabled &&
- !context.value.multiple &&
- !context.value.clearable &&
- options.value,
- preselectOption,
- )
- })
- }
- export default useSelectPreselect
|