index.ts 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
  2. import type { AutocompleteSelectValue } from '#shared/components/Form/fields/FieldAutocomplete/types.ts'
  3. import createInput from '#shared/form/core/createInput.ts'
  4. import addLink from '#shared/form/features/addLink.ts'
  5. import formUpdaterTrigger from '#shared/form/features/formUpdaterTrigger.ts'
  6. import FieldAutoCompleteInput from './FieldAutoCompleteInput.vue'
  7. import type { AutoCompleteProps } from './types.ts'
  8. import type { FormKitBaseSlots, FormKitInputs } from '@formkit/inputs'
  9. declare module '@formkit/inputs' {
  10. interface FormKitInputProps<Props extends FormKitInputs<Props>> {
  11. autocomplete: AutoCompleteProps & {
  12. type: 'autocomplete'
  13. value: AutocompleteSelectValue | null
  14. }
  15. }
  16. interface FormKitInputSlots<Props extends FormKitInputs<Props>> {
  17. autocomplete: FormKitBaseSlots<Props>
  18. }
  19. }
  20. export const autoCompleteProps = [
  21. 'actions',
  22. 'alternativeBackground',
  23. 'additionalQueryParams',
  24. 'clearable',
  25. 'debounceInterval',
  26. 'defaultFilter',
  27. 'limit',
  28. 'multiple',
  29. 'noOptionsLabelTranslation',
  30. 'belongsToObjectField',
  31. 'optionIconComponent',
  32. 'dialogNotFoundMessage',
  33. 'dialogEmptyMessage',
  34. 'options',
  35. 'initialOptionBuilder',
  36. 'autocompleteOptionsPreprocessor',
  37. 'sorting',
  38. 'complexValue',
  39. 'clearValue',
  40. 'emptyInitialLabelText',
  41. 'alwaysApplyDefaultFilter',
  42. ]
  43. const fieldDefinition = createInput(
  44. FieldAutoCompleteInput,
  45. [...autoCompleteProps, 'gqlQuery'],
  46. { features: [addLink, formUpdaterTrigger()] },
  47. )
  48. export default {
  49. fieldType: 'autocomplete',
  50. definition: fieldDefinition,
  51. }