123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { renderComponent } from '#tests/support/components/index.ts'
- import { waitForNextTick } from '#tests/support/utils.ts'
- import { useConfirmation } from '#shared/composables/useConfirmation.ts'
- import CommonConfirmationDialog from '../CommonConfirmationDialog.vue'
- const { confirmationOptions } = useConfirmation()
- beforeAll(() => {
- const app = document.createElement('div')
- app.id = 'app'
- document.body.appendChild(app)
- })
- afterAll(() => {
- document.body.innerHTML = ''
- })
- describe('dialog confirm behaviour', () => {
- beforeEach(() => {
- confirmationOptions.value = undefined
- })
- it('renders confirmation dialog with default values', async () => {
- const confirmCallbackSpy = vi.fn()
- const wrapper = renderComponent(CommonConfirmationDialog)
- confirmationOptions.value = {
- text: 'Test heading',
- confirmCallback: confirmCallbackSpy,
- cancelCallback: vi.fn(),
- closeCallback: vi.fn(),
- }
- await waitForNextTick()
- expect(wrapper.getByText('Test heading')).toBeInTheDocument()
- expect(wrapper.getByText('Yes')).toBeInTheDocument()
- await wrapper.events.click(wrapper.getByRole('button', { name: 'Yes' }))
- expect(confirmCallbackSpy).toHaveBeenCalledTimes(1)
- })
- it('renders confirmation dialog with variant', async () => {
- const confirmCallbackSpy = vi.fn()
- const wrapper = renderComponent(CommonConfirmationDialog)
- confirmationOptions.value = {
- confirmationVariant: 'delete',
- confirmCallback: confirmCallbackSpy,
- cancelCallback: vi.fn(),
- closeCallback: vi.fn(),
- }
- await waitForNextTick()
- expect(
- wrapper.getByRole('dialog', { name: 'Delete Object' }),
- ).toBeInTheDocument()
- expect(
- wrapper.getByText('Are you sure you want to delete this object?'),
- ).toBeInTheDocument()
- await wrapper.events.click(
- wrapper.getByRole('button', { name: 'Delete Object' }),
- )
- expect(confirmCallbackSpy).toHaveBeenCalledTimes(1)
- })
- it('renders confirmation dialog with custom values', async () => {
- const confirmCallbackSpy = vi.fn()
- const wrapper = renderComponent(CommonConfirmationDialog)
- confirmationOptions.value = {
- text: 'Test heading',
- buttonLabel: 'Custom button title',
- buttonVariant: 'danger',
- confirmCallback: confirmCallbackSpy,
- cancelCallback: vi.fn(),
- closeCallback: vi.fn(),
- }
- await waitForNextTick()
- expect(
- wrapper.getByRole('button', { name: 'Custom button title' }),
- ).toBeInTheDocument()
- expect(
- wrapper.getByRole('button', { name: 'Custom button title' }),
- ).toHaveClass('bg-pink-100')
- })
- it('closes the confirmation dialog by using cancel', async () => {
- const confirmCallbackSpy = vi.fn()
- const cancelCallbackSpy = vi.fn()
- const wrapper = renderComponent(CommonConfirmationDialog)
- confirmationOptions.value = {
- text: 'Test heading',
- confirmCallback: confirmCallbackSpy,
- cancelCallback: cancelCallbackSpy,
- closeCallback: vi.fn(),
- }
- await waitForNextTick()
- await wrapper.events.click(
- wrapper.getByRole('button', { name: 'Cancel & Go Back' }),
- )
- expect(cancelCallbackSpy).toHaveBeenCalledTimes(1)
- })
- })
|