1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { afterEach, expect } from 'vitest'
- import renderComponent from '#tests/support/components/renderComponent.ts'
- import CommonOverlayContainer from '#desktop/components/CommonOverlayContainer/CommonOverlayContainer.vue'
- const html = String.raw
- describe('CommonOverlayContainer', () => {
- let app: HTMLElement
- let wrapper: ReturnType<typeof renderComponent>
- beforeEach(() => {
- app = document.createElement('div')
- app.id = 'app'
- document.body.appendChild(app)
- wrapper = renderComponent(CommonOverlayContainer, {
- props: { tag: 'div' },
- attachTo: app,
- })
- })
- afterEach(() => {
- document.body.innerHTML = ''
- })
- it('renders correctly with a11y specification', async () => {
- expect(wrapper.getByRole('dialog')).toBeInTheDocument()
- expect(app.querySelector('[role=presentation]')).toBeInTheDocument()
- await wrapper.rerender({ tag: 'aside' })
- expect(wrapper.getByRole('complementary')).toBeInTheDocument()
- })
- it('hides background when showBackdrop is false', async () => {
- await wrapper.rerender({ showBackdrop: false })
- expect(app.querySelector('[role=presentation]')).not.toBeInTheDocument()
- })
- it('should emit close event when backdrop is clicked, by default', async () => {
- const view = renderComponent({
- template: html`<div id="test-backdrop"></div>`,
- })
- const dialog = renderComponent(CommonOverlayContainer, {
- props: {
- tag: 'div',
- teleportTo: '#test-backdrop',
- },
- })
- await view.events.click(
- view
- .getAllByRole('presentation', {
- hidden: true,
- })
- .at(-1) as HTMLElement,
- )
- expect(dialog.emitted('click-background')).toHaveLength(1)
- })
- it('should not emit close event when backdrop is clicked, if specified', async () => {
- const view = renderComponent({
- template: html`<div id="test-backdrop"></div>`,
- })
- const dialog = renderComponent(CommonOverlayContainer, {
- props: {
- tag: 'div',
- teleportTo: '#test-backdrop',
- noCloseOnBackdropClick: true,
- },
- })
- await view.events.click(
- view
- .getAllByRole('presentation', {
- hidden: true,
- })
- .at(-1) as HTMLElement,
- )
- expect(dialog.emitted('click-background')).toBeUndefined()
- })
- })
|