123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { visitView } from '#tests/support/components/visitView.ts'
- import { mockApplicationConfig } from '#tests/support/mock-applicationConfig.ts'
- import { mockPermissions } from '#tests/support/mock-permissions.ts'
- import { waitForFormUpdaterQueryCalls } from '#shared/components/Form/graphql/queries/formUpdater.mocks.ts'
- import { mockTemplatesQuery } from '../graphql/queries/templates.mocks.ts'
- describe('ticket create view - apply template', async () => {
- beforeEach(() => {
- mockApplicationConfig({
- ui_ticket_create_available_types: ['phone-in', 'phone-out', 'email-out'],
- customer_ticket_create: true,
- })
- mockPermissions(['ticket.agent'])
- })
- it('renders no "Apply Template" button', async () => {
- mockTemplatesQuery({ templates: [] })
- const view = await visitView('/ticket/create')
- expect(
- view.queryByRole('button', { name: 'Apply Template' }),
- ).not.toBeInTheDocument()
- })
- it('renders the "Apply Template" button and can apply the ', async () => {
- mockTemplatesQuery({
- templates: [
- { id: '1', name: 'template1' },
- { id: '2', name: 'template2' },
- ],
- })
- const view = await visitView('/ticket/create')
- const applyTemplateButton = view.getByRole('button', {
- name: 'Apply Template',
- })
- expect(applyTemplateButton).toBeInTheDocument()
- await view.events.click(applyTemplateButton)
- const templateButton = view.getByRole('button', { name: 'template1' })
- expect(templateButton).toBeInTheDocument()
- await view.events.click(templateButton)
- const formUpdaterCalls = await waitForFormUpdaterQueryCalls()
- expect(formUpdaterCalls.at(-1)?.variables).toEqual(
- expect.objectContaining({
- meta: expect.objectContaining({
- additionalData: expect.objectContaining({
- templateId: 'gid://zammad/Template/1',
- }),
- }),
- }),
- )
- })
- })
|