/** * Critical a11y fix — bottom sheets on /account (data-mode warning and * leave-confirm) now respond to Escape via the focusTrap action. They were * previously click-only, blocking keyboard / switch-control users. */ import { test, expect } from '../../fixtures/test'; test.describe('Mobile a11y — sheets dismiss on Escape', () => { test('data-mode warning sheet closes on Escape', async ({ page, guest, signIn }) => { const g = await guest('SheetEsc'); await signIn(page, g); await page.goto('/account'); // Click the "Original" radio in the Datennutzung section to open the warning sheet. const originalRadio = page.getByRole('radio', { name: /Original$/i }); await originalRadio.click(); const sheet = page.locator('[role="dialog"][aria-labelledby="data-mode-title"]'); await expect(sheet).toBeVisible(); await page.keyboard.press('Escape'); await expect(sheet).not.toBeVisible({ timeout: 2_000 }); }); test('leave-confirm sheet (built on ConfirmSheet) closes on Escape', async ({ page, guest, signIn }) => { const g = await guest('LeaveEsc'); await signIn(page, g); await page.goto('/account'); await page.getByRole('button', { name: /Event verlassen/i }).click(); const sheet = page.getByTestId('confirm-sheet'); await expect(sheet).toBeVisible(); await page.keyboard.press('Escape'); await expect(sheet).not.toBeVisible({ timeout: 2_000 }); }); });