642c5b7322
Add the a11y foundation and bring login, lobby, and the in-game shell to WCAG 2.2 AA: - Primitives: .sr-only + .skip-link (base.css), trapFocus (modal focus trap + restore) and restoreFocus (menu focus restore) actions, the --color-focus visible ring. - In-game shell: skip link + focusable main landmark; WAI-ARIA sidebar tabs (roving tabindex, arrow/Home/End, tabpanel wiring); menu Escape + focus restore (account / view / turn-navigator / map-toggles / bottom-tabs); mail compose as a role=dialog modal with a focus trap. - login / lobby / lobby-create: skip link + main landmark, field labels, role=alert / role=status live regions. - Map canvas: aria-label naming it a visual overview, with its data reachable by keyboard via the sidebar inspector and tables (accessible alternative; in-canvas keyboard nav deferred). Gates (chromium-desktop): tests/e2e/a11y-axe.spec.ts scans every top-level view for WCAG 2.2 AA violations (zero); a11y-keyboard.spec.ts covers the skip link, menu Escape+restore, and tab roving. Adds @axe-core/playwright. Docs: ui/docs/a11y.md (+ index). Marks F1 and F2 done in ui/PLAN-finalize.md. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
44 lines
1.2 KiB
JSON
44 lines
1.2 KiB
JSON
{
|
|
"name": "galaxy-ui-frontend",
|
|
"version": "0.0.1",
|
|
"private": true,
|
|
"type": "module",
|
|
"scripts": {
|
|
"dev": "vite dev",
|
|
"build": "vite build",
|
|
"preview": "vite preview",
|
|
"check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json",
|
|
"test": "vitest run",
|
|
"test:e2e": "playwright test"
|
|
},
|
|
"dependencies": {
|
|
"flatbuffers": "^25.9.23",
|
|
"idb": "^8.0.3",
|
|
"pixi-viewport": "^6.0.3",
|
|
"pixi.js": "^8.18.1"
|
|
},
|
|
"devDependencies": {
|
|
"@axe-core/playwright": "4.11.3",
|
|
"@bufbuild/protobuf": "^2.12.0",
|
|
"@bufbuild/protoc-gen-es": "^2.12.0",
|
|
"@connectrpc/connect": "^2.1.1",
|
|
"@connectrpc/connect-web": "^2.1.1",
|
|
"@playwright/test": "^1.59.1",
|
|
"@sveltejs/adapter-static": "^3.0.0",
|
|
"@sveltejs/kit": "^2.59.0",
|
|
"@sveltejs/vite-plugin-svelte": "^7.0.0",
|
|
"@testing-library/jest-dom": "^6.9.1",
|
|
"@testing-library/svelte": "^5.2.0",
|
|
"@types/node": "^22.0.0",
|
|
"fake-indexeddb": "^6.2.5",
|
|
"jsdom": "^25.0.0",
|
|
"playwright": "^1.59.1",
|
|
"svelte": "^5.0.0",
|
|
"svelte-check": "^4.0.0",
|
|
"tslib": "^2.6.0",
|
|
"typescript": "^5.5.0",
|
|
"vite": "^8.0.0",
|
|
"vitest": "^4.0.0"
|
|
}
|
|
}
|