12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- <!-- Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { markRaw, defineAsyncComponent, nextTick } from 'vue'
- import type { SelectValue } from '#shared/components/CommonSelect/types.ts'
- import type { AutoCompleteProps } from '#shared/components/Form/fields/FieldAutocomplete/types.ts'
- import { AutocompleteSearchUserDocument } from '#shared/components/Form/fields/FieldCustomer/graphql/queries/autocompleteSearch/user.api.ts'
- import type { AutoCompleteCustomerUserOption } from '#shared/components/Form/fields/FieldCustomer/types.ts'
- import type { FormFieldContext } from '#shared/components/Form/types/field.ts'
- import type { User } from '#shared/graphql/types.ts'
- import type { ObjectLike } from '#shared/types/utils.ts'
- import { closeDialog } from '#mobile/composables/useDialog.ts'
- import { useUserCreate } from '#mobile/entities/user/composables/useUserCreate.ts'
- import FieldCustomerOptionIcon from './FieldCustomerOptionIcon.vue'
- const FieldAutoCompleteInput = defineAsyncComponent(
- () =>
- import(
- '#mobile/components/Form/fields/FieldAutoComplete/FieldAutoCompleteInput.vue'
- ),
- )
- interface Props {
- context: FormFieldContext<
- AutoCompleteProps & {
- options?: AutoCompleteCustomerUserOption[]
- }
- >
- }
- const props = defineProps<Props>()
- const buildEntityOption = (entity: User) => {
- return {
- value: entity.internalId,
- label: entity.fullname || entity.phone || entity.login,
- heading: entity.organization?.name,
- user: entity,
- }
- }
- const { openCreateUserDialog } = useUserCreate({
- async onUserCreated(user) {
- const { props: nodeProps } = props.context.node
- // If the user is not in options, add it
- if (
- !nodeProps.options?.some(
- (v: AutoCompleteCustomerUserOption) => v.value === user.internalId,
- )
- ) {
- nodeProps.options = [
- ...(nodeProps.options || []),
- buildEntityOption(user),
- ]
- }
- await nextTick()
- props.context.node.input(user.internalId, false)
- closeDialog(`field-auto-complete-${props.context.id}`)
- },
- })
- Object.assign(props.context, {
- optionIconComponent: markRaw(FieldCustomerOptionIcon),
- initialOptionBuilder: (
- initialEntityObject: ObjectLike,
- value: SelectValue,
- context: Props['context'],
- ) => {
- if (!context.belongsToObjectField || !initialEntityObject) return null
- const belongsToObject = initialEntityObject[context.belongsToObjectField]
- if (!belongsToObject) return null
- return buildEntityOption(belongsToObject)
- },
- actionIcon: 'new-customer',
- actionLabel: __('Create new customer'),
- gqlQuery: AutocompleteSearchUserDocument,
- onActionClick: openCreateUserDialog,
- })
- </script>
- <template>
- <FieldAutoCompleteInput :context="context" v-bind="$attrs" />
- </template>
|