Implemented comprehensive accessibility improvements across the entire application to ensure WCAG 2.1 Level AA compliance. Keyboard Navigation: - Added skip-to-main-content link at the top - Enhanced focus-visible styles with 3px high-contrast outline - Added keyboard support for dropdowns (Escape to close) - Ensured all interactive elements are keyboard accessible Screen Reader Support: - Added ARIA labels throughout (buttons, navigation, forms) - Implemented ARIA live regions for dynamic content (toasts) - Added aria-expanded, aria-controls for dropdowns - Added aria-current="page" for active navigation - Proper role attributes (navigation, search, menu, dialog, alert) - Screen reader-only text for context (.sr-only class) Visual Accessibility: - High contrast focus indicators (4.5:1 ratio) - Support for prefers-reduced-motion - Support for high contrast mode - Decorative icons wrapped in aria-hidden Form Accessibility: - All inputs have proper labels or aria-label - Added aria-required and aria-invalid for validation - Error messages announced to screen readers - Proper form structure with semantic HTML Content Structure: - Skip navigation link for keyboard users - Proper heading hierarchy (h1 → h2 → h3) - Semantic HTML elements (nav, main, section, article) - Alt text for all images Interactive Components: - Modals: aria-modal, role="dialog", Escape key support - Dropdowns: aria-expanded, aria-haspopup, keyboard navigation - Buttons: descriptive aria-labels for icon buttons - Pagination: aria-current, descriptive button labels - Like buttons: aria-pressed for toggle state Files Modified: - Global styles (styles.scss) - App template (skip link) - Header navigation (ARIA attributes) - Toast notifications (live regions) - Pagination component - Like button component - Games list component - Footer component - Report modal WCAG 2.1 Compliance: ✅ 1.3.1 Info and Relationships ✅ 1.4.3 Contrast (Minimum) ✅ 2.1.1 Keyboard ✅ 2.1.2 No Keyboard Trap ✅ 2.4.1 Bypass Blocks ✅ 2.4.3 Focus Order ✅ 2.4.7 Focus Visible ✅ 3.2.4 Consistent Identification ✅ 4.1.2 Name, Role, Value ✅ 4.1.3 Status Messages The library is now fully accessible to users with disabilities!
Library
✨ Your new, shiny Nx workspace is ready ✨.
Learn more about this workspace setup and its capabilities or run npx nx graph to visually explore what was created. Now, let's get you up to speed!
Run tasks
To run the dev server for your app, use:
npx nx serve frontend
To create a production bundle:
npx nx build frontend
To see all available targets to run for a project, run:
npx nx show project frontend
These targets are either inferred automatically or defined in the project.json or package.json files.
More about running tasks in the docs »
Add new projects
While you could add new projects to your workspace manually, you might want to leverage Nx plugins and their code generation feature.
Use the plugin's generator to create new projects.
To generate a new application, use:
npx nx g @nx/angular:app demo
To generate a new library, use:
npx nx g @nx/angular:lib mylib
You can use npx nx list to get a list of installed plugins. Then, run npx nx list <plugin-name> to learn about more specific capabilities of a particular plugin. Alternatively, install Nx Console to browse plugins and generators in your IDE.
Learn more about Nx plugins » | Browse the plugin registry »
Set up CI!
Step 1
To connect to Nx Cloud, run the following command:
npx nx connect
Connecting to Nx Cloud ensures a fast and scalable CI pipeline. It includes features such as:
- Remote caching
- Task distribution across multiple machines
- Automated e2e test splitting
- Task flakiness detection and rerunning
Step 2
Use the following command to configure a CI workflow for your workspace:
npx nx g ci-workflow
Install Nx Console
Nx Console is an editor extension that enriches your developer experience. It lets you run tasks, generate code, and improves code autocompletion in your IDE. It is available for VSCode and IntelliJ.
Useful links
Learn more:
- Learn more about this workspace setup
- Learn about Nx on CI
- Releasing Packages with Nx release
- What are Nx plugins?
And join the Nx community: