Rapport:
Audit digitale toegankelijkheid Kamerdebatten
- Onderzoeker
- Sophie, Swink; Michiel, Swink
- Datum
- 16 april 2025
- Opdrachtgever
- Ministerie van Binnenlandse Zaken en Koninkrijksrelaties
Samenvatting onderzoeksresultaat
De website Kamerdebat voldoet nog niet aan WCAG 2.1 niveau AA. Er zijn 10 van de 50 succescriteria waar één of meer fouten zijn gevonden. In dit document is vastgelegd in hoeverre de website voldoet aan de toegankelijkheidseisen die vastgelegd zijn in WCAG, de Web Content Accessibility Guidelines.
De website https://kda.staging.rijksapplicaties.nl/ is onderzocht tussen 11 en 16 april 2025. Het onderzoek is uitgevoerd aan de hand van de evaluatiemethode WCAG-EM. Doel van dit rapport is om te bepalen welke verbeteringen nodig zijn om dit digitaal kanaal toegankelijker te krijgen.
Enkele opvallende bevindingen zijn:
- pictogrammen zonder alternatieve tekst, wat impact heeft op screenreaders.
- niet-interactieve elementen die in de lees- en tabvolgorde staan, wat impact heeft op screenreader
- knoppen zonder toegankelijke naam, wat impact heeft op spraakbesturing en screenreaders
Het onderzoek richt zich specifiek op de toegankelijkheid van de website voor mensen met een functiebeperking, zoals mensen die blind, doof, laaggeletterd zijn of andere functieproblemen hebben. Voor hen is het van belang dat de website technisch en inhoudelijk zo is ingericht dat de site voor hen goed bruikbaar is. Een website optimaliseren voor toegankelijkheid heeft meer voordelen; het maakt de website beter bruikbaar voor iedereen (bijvoorbeeld ook voor mensen die op hun mobieltje kijken in een zonnige omgeving) en het maakt de site beter vindbaar in zoekmachines.
Scope van de evaluatie
Naam website | Kamerdebat |
---|---|
Scope van de website |
Binnen de scope van het onderzoek valt:
|
Conformiteitsdoel | WCAG 2.1 niveau AA |
Basisniveau van toegankelijkheid ondersteund | Gangbare browsers en hulpsoftware. |
Overzicht toetsresultaat
Principe | Voldoende | Onvoldoende | Onbekend |
---|---|---|---|
1 Waarneembaar | 16 | 4 | 0 |
2 Bedienbaar | 14 | 3 | 0 |
3 Begrijpelijk | 8 | 2 | 0 |
4 Robuust | 2 | 1 | 0 |
Totaal | 40 | 10 | 0 |
Leeswijzer
Dit onderzoek is een momentopname. De website kan inmiddels veranderd zijn. De gevonden problemen zijn slechts voorbeelden. Ga daarom bij elk probleem de gehele website na of dit ook op andere plaatsen voorkomt. Dit onderzoek is slechts een steekproef van een aantal pagina's. Er zijn zo veel mogelijk verschillende type pagina's opgenomen in de sample om zo een goede indruk te krijgen van de toegankelijkheid. Let op! Bij het aanbrengen van verbeteringen of wijzigingen op de website/app kunnen nieuwe problemen ontstaan. Succescriteria gemarkeerd met "Niet aanwezig" worden automatisch goedgekeurd. Succescriteria gemarkeerd met "Onbekend" worden niet goedgekeurd.
Uitgebreide toetsresultaten
1. Waarneembaar
1.1 Tekstalternatieven
1.1.1 Niet-tekstuele content (Niveau A)
Alle niet-tekstuele content die aan de gebruiker wordt gepresenteerd, heeft een tekstalternatief dat een gelijkwaardig doel dient, behalve voor de hierna vermelde situaties.
- Bedieningselementen, invoer: Als niet-tekstuele content een bedieningselement is of gebruikersinvoer accepteert, dan heeft ze een naam die het doel ervan beschrijft. (We verwijzen naar succescriterium 4.1.2 voor aanvullende eisen over bedieningselementen en content die gebruikersinvoer accepteren.)
- Op tijd gebaseerde media: Als niet-tekstuele content op tijd gebaseerde media is, dan leveren tekstalternatieven ten minste een beschrijving van de niet-tekstuele content. (We verwijzen naar Richtlijn 1.2 voor aanvullende eisen ten aanzien van media.)
- Test: Als niet-tekstuele content een test of oefening is die, als ze door middel van tekst gepresenteerd wordt onjuist zou zijn, dan leveren tekstalternatieven ten minste een beschrijving van de niet-tekstuele content.
- Zintuiglijk: Als niet-tekstuele content primair is bedoeld om een specifieke zintuiglijke ervaring te creëren, dan leveren tekstalternatieven ten minste een beschrijving van de niet-tekstuele content.
- CAPTCHA: Als het doel van niet-tekstuele content is om te bevestigen dat content wordt gebruikt door een persoon in plaats van een computer, dan worden tekstalternatieven geleverd die het doel van de niet-tekstuele content identificeren en beschrijven. En er worden alternatieve vormen van CAPTCHA aangeboden gebruikmakend van uitvoermodes voor verschillende soorten van zintuiglijke perceptie om tegemoet te komen aan verschillende functiebeperkingen.
- Decoratie, opmaak, onzichtbaar: Als niet-tekstuele content puur decoratief is, slechts voor visuele opmaak wordt gebruikt, of niet aan gebruikers wordt gerepresenteerd, dan wordt het op zo'n manier geïmplementeerd dat het genegeerd kan worden door hulptechnologie.
Informatie over succescriterium 1.1.1 Niet-tekstuele content
Uitkomst: Onvoldoende
Bevindingen: Op https://kda.staging.rijksapplicaties.nl/vragen wordt met een pictogram aangegeven of de vraag terug te luisteren is. Deze informatie is niet beschikbaar voor hulpsoftware. Voeg dit pictogram als afbeelding toe en geef deze alt-tekst. Hetzelfde komt vaker voor in de website, bijvoorbeeld op de pagina "Gebruikersbeheer" in https://kda.staging.rijksapplicaties.nl/beheer bij de knoppen met een vergrootglas icoon waarmee het modaal "Gebruiker bewerken" wordt geopend.
Op de pagina https://kda.staging.rijksapplicaties.nl/beheer onder de knop "versie info" wordt met een pictogram aangegeven of iets zichtbaar is of niet. Deze informatie is echter niet beschikbaar voor hulpsoftware. Implementeer de pictogrammen als afbeeldingen, in plaats van icon fonts, en geef ze alt-tekst. Of gebruik gewoon "ja" of "nee" als tekst in die kolom.
Op https://kda.staging.rijksapplicaties.nl/debatten kan de inhoud van de tabel middels de koppen van de tabel gesorteerd worden. Het pictogram hiervoor is een chevron, dat met JavaScript klikbaar is gemaakt, en wordt ingeladen middels een <i> element. Er wordt gebruik gemaakt van font-awesome. Door middel van icon fonts kan men via CSS letters en andere tekens toevoegen. Dit gebeurt via de CSS- pseudo-elementen ::before en ::after, die het gewenste pictogram laten zien. Tekst die via CSS wordt toegevoegd komt in de accessibility tree. Screenreaders spreken dat karakter dus uit, en niet het pictogram. Als het gebruikte karakter een andere betekenis heeft dan het icoon, kan dat verwarrend zijn voor gebruikers. Het et aria-label "Oplopend gesorteerd" of "Aflopend gesorteerd" op het i element zou dit probleem kunnen oplossen omdat een aria-label de inhoud van een element overschrijft, maar dan moet het i element een andere rol krijgen want aria-label mag alleen bij interactieve elementen zoals bijvoorbeeld links en buttons gebruikt worden.
Op pagina https://kda.staging.rijksapplicaties.nl/voorbereid staan de logo's van de partijen die een vraag hebben voorbereid met een lege alt. Deze afbeeldingen hebben betekenis dus er is een alternatieve tekst nodig. Geef een alternatieve tekst aan de afbeeldingen, bijvoorbeeld "logo D66".
1.2 Op tijd gebaseerde media
1.2.1 Louter-geluid en louter-videobeeld (vooraf opgenomen) (Niveau A)
Voor media met vooraf opgenomen louter-geluid en vooraf opgenomen louter-videobeeld is het volgende waar, behalve als de audio of video een media-alternatief voor tekst is en duidelijk als zodanig is gelabeld:
- Vooraf opgenomen louter-geluid: Er wordt een alternatief geleverd voor op tijd gebaseerde media dat equivalente informatie geeft voor vooraf opgenomen louter-geluid content.
- Vooraf opgenomen louter-videobeeld: Er wordt een alternatief geleverd voor op tijd gebaseerde media of een geluidsspoor dat equivalente informatie geeft voor vooraf opgenomen louter-videobeeld content.
Informatie over succescriterium 1.2.1 Louter-geluid en louter-videobeeld (vooraf opgenomen)
Uitkomst: Niet aanwezig
1.2.2 Ondertitels voor doven en slechthorenden (vooraf opgenomen) (Niveau A)
Er worden ondertitels voor doven en slechthorenden geleverd voor alle vooraf opgenomen audiocontent in gesynchroniseerde media, behalve als het mediabestand een media-alternatief voor tekst is en duidelijk als zodanig is gelabeld.
Informatie over succescriterium 1.2.2 Ondertitels voor doven en slechthorenden (vooraf opgenomen)
Uitkomst: Niet aanwezig
1.2.3 Audiodescriptie of media-alternatief (vooraf opgenomen) (Niveau A)
Er wordt een alternatief geleverd voor op tijd gebaseerde media of audiodescriptie van de vooraf opgenomen videocontent geleverd voor gesynchroniseerde media, behalve als het mediabestand een media-alternatief voor tekst is en duidelijk als zodanig is gelabeld.
Informatie over succescriterium 1.2.3 Audiodescriptie of media-alternatief (vooraf opgenomen)
Uitkomst: Niet aanwezig
1.2.4 Ondertitels voor doven en slechthorenden (live) (Niveau AA)
Er worden ondertitels voor doven en slechthorenden geleverd voor alle live audiocontent in gesynchroniseerde media.
Informatie over succescriterium 1.2.4 Ondertitels voor doven en slechthorenden (live)
Uitkomst: Niet aanwezig
1.2.5 Audiodescriptie (vooraf opgenomen) (Niveau AA)
Er wordt een audiodescriptie geleverd voor alle vooraf opgenomen videocontent in gesynchroniseerde media.
Informatie over succescriterium 1.2.5 Audiodescriptie (vooraf opgenomen)
Uitkomst: Niet aanwezig
1.3 Aanpasbaar
1.3.1 Info en relaties (Niveau A)
Informatie, structuur en relaties overgebracht door presentatie kunnen door software bepaald worden of zijn beschikbaar in tekst.
Informatie over succescriterium 1.3.1 Info en relaties
Uitkomst: Onvoldoende
Bevindingen: Op https://kda.staging.rijksapplicaties.nl/ is het hoofdmenu opgemaakt als een lijst in de code. Echter is er geen <ul> element waarin de <li> elementen staan. Dit komt door het gebruik van role=navigation op het ul-element, hierdoor wordt de semantiek van lijst-elementen overschreven met een landmark rol. Verwijder het role attribuut en nest de lijst in een <nav>-element.
Op https://kda.staging.rijksapplicaties.nl/debatten zijn de knoppen "Huidig" en "Gearchiveerd" in de code als een lijst opgemaakt. Echter is er geen <ul> element waarin de <li> elementen staan. Dit komt door het gebruik van role=navigation op het ul-element, hierdoor wordt de semantiek van lijst-elementen overschreven met een landmark rol. Verwijder de rol.
Op https://kda.staging.rijksapplicaties.nl/debatten blijft de knop van een geselecteerd debat focus krijgen, waardoor het lijkt alsof deze gedeselecteerd kan worden. Visueel door het gebruik van een checkbox, lijkt dat ook visueel zo. Maar dat is niet mogelijk. Dit is verwarrend voor gebruikers van hulpsoftware en bemoeilijkt het selecteren van een debat met spraakbesturing. In plaats van knoppen, gebruik hier een radiobutton. Dat zorgt ervoor dat slechts 1 debat steeds gekozen kan worden, wat de bedoeling is in deze applicatie, en zorgt ervoor dat de status van gekozen of niet gekozen automatisch naar hulpsoftware toe wordt gecommuniceerd.
Op https://kda.staging.rijksapplicaties.nl/vragen is er bij de vragen sprake van geneste tabellen. De kolom met C of T als inhoud maakt namelijk gebruik van een geneste tabel om C of T weer te kunnen geven. Geneste tabellen kunnen gecompliceerd zijn voor hulpsoftware. Gebruik 1 tabel om alle informatie te kunnen weergeven. Als een tabel gebruikt wordt voor opmaak kan role="presentation" er voor zorgen dat hulpsoftware de tabel informatie negeert
Bij het toevoegen van een nieuwe vraag op https://kda.staging.rijksapplicaties.nl/vragen zijn er zaken die men kan aanvinken, onder andere "commissielid" en "thema". Visueel zijn het checkboxen, maar in de code zijn het knoppen en functioneel zijn het radiobuttons. Dat is verwarrend voor bezoekers, omdat dit een hele andere manier van bedienen met toetsenbord betekent. Ook heeft het impact op spraakbesturing. Semantisch is het ook niet correct: als je wil dat mensen iets selecteren, gebruik dan het native radiobutton element. Dat communiceert ook automatisch de status naar hulpsoftware toe. Gebruik dus radiobuttons in plaats van knoppen, en groepeer deze met fieldset en legend.
In de lijst met vragen op https://kda.staging.rijksapplicaties.nl/voorbereid, is de vraag zelf opgemaakt met het strong-element. Dit is niet toegestaan, want dat is bedoeld om een woord (of enkele woorden) in een zin nadruk te geven. Het mag dus niet worden gebruikt om zaken vetgedrukt te maken of om koppen aan te duiden. Verwijder het element en maak de vraag op als een kop.
1.3.2 Betekenisvolle volgorde (Niveau A)
Als de volgorde waarin content wordt gepresenteerd van invloed is op zijn betekenis, kan een correcte leesvolgorde door software bepaald worden.
Informatie over succescriterium 1.3.2 Betekenisvolle volgorde
Uitkomst: Voldoende
1.3.3 Zintuiglijke eigenschappen (Niveau A)
Instructies die geleverd worden om content te begrijpen en te bedienen zijn niet alleen afhankelijk van zintuiglijke eigenschappen van componenten zoals vorm, kleur, omvang, visuele locatie, oriëntatie of geluid.
Informatie over succescriterium 1.3.3 Zintuiglijke eigenschappen
Uitkomst: Voldoende
1.3.4 Weergavestand (Niveau AA)
De content beperkt de weergave en bediening niet tot een enkele presentatie-oriëntatie, zoals staand of liggend, tenzij een specifieke presentatie-oriëntatie essentieel is.
Informatie over succescriterium 1.3.4 Weergavestand
Uitkomst: Voldoende
1.3.5 Identificeer het doel van de input (Niveau AA)
Het doel van elk invoerveld waarmee informatie van de gebruiker wordt verzameld, kan door software bepaald worden wanneer:
- Het invoerveld een doel dient dat is geïdentificeerd in de paragraaf Inputdoelen voor Componenten van de Gebruikersinterface; en
- De content wordt geïmplementeerd met behulp van technologieën die ondersteuning bieden bij het identificeren van de verwachte betekenis van formulier-invoergegevens.
Informatie over succescriterium 1.3.5 Identificeer het doel van de input
Uitkomst: Niet aanwezig
1.4 Onderscheidbaar
1.4.1 Gebruik van kleur (Niveau A)
Kleur wordt niet als het enige visuele middel gebruikt om informatie over te brengen, een actie aan te geven, tot een reactie op te roepen of een visueel element te onderscheiden.
Informatie over succescriterium 1.4.1 Gebruik van kleur
Uitkomst: Onvoldoende
Bevindingen: Als men op https://kda.staging.rijksapplicaties.nl/vragen een vraag opent kan men de knop "Vraag terugluisteren" gebruiken. Bij het indrukken verandert deze enkel van kleur, functiegewijs gebeurt er niets. Kies een HTML-element dat duidelijker uitdraagt wat de bedoeling is van de knop en wat de verandering van staat (ingeschakeld of niet) betekent. Deze informatie ontbreekt nu en heeft veel impact op hulpsoftware.
1.4.2 Geluidsbediening (Niveau A)
Als een geluidsweergave op een webpagina automatisch meer dan 3 seconden speelt, is er of een mechanisme beschikbaar om de geluidsweergave te pauzeren of te stoppen, of er is een mechanisme beschikbaar om het geluidsvolume onafhankelijk van het overall systeemvolume te regelen.
Informatie over succescriterium 1.4.2 Geluidsbediening
Uitkomst: Niet aanwezig
1.4.3 Contrast (minimum) (Niveau AA)
De visuele weergave van tekst en afbeeldingen van tekst heeft een contrastverhouding van ten minste 4,5:1, behalve in de volgende gevallen:
- Grote tekst: Grote tekst en afbeeldingen van grote tekst hebben een contrastverhouding van ten minste 3:1;
- Incidenteel: Tekst of afbeeldingen van tekst die deel zijn van een inactieve component van de gebruikersinterface, die puur decoratief zijn, die voor niemand zichtbaar zijn, of die onderdeel zijn van een afbeelding die significant andere visuele content bevat, hebben geen contrasteis.
- Woordmerken: Tekst die onderdeel is van een logo of merknaam heeft geen contrasteis.
Informatie over succescriterium 1.4.3 Contrast (minimum)
Uitkomst: Voldoende
1.4.4 Herschalen van tekst (Niveau AA)
Behalve voor ondertitels voor doven en slechthorenden en afbeeldingen van tekst, kan tekst zonder hulptechnologie tot 200% geschaald worden zonder verlies van content of functionaliteit.
Informatie over succescriterium 1.4.4 Herschalen van tekst
Uitkomst: Voldoende
1.4.5 Afbeeldingen van tekst (Niveau AA)
Als de gebruikte technologieën de visuele weergave tot stand kunnen brengen, wordt tekst gebruikt in plaats van afbeeldingen van tekst om informatie over te brengen, behalve in de volgende gevallen:
- Aanpasbaar: De afbeelding van tekst kan visueel aangepast worden aan de eisen van de gebruiker;
- Essentieel: Een specifieke weergave van tekst is essentieel voor de informatie die wordt overgebracht.
Informatie over succescriterium 1.4.5 Afbeeldingen van tekst
Uitkomst: Niet aanwezig
1.4.10 Reflow (Niveau AA)
Content kan zonder verlies van informatie of functionaliteit en zonder te moeten scrollen in twee dimensies, worden weergegeven voor:
- Verticaal scrollbare content met een breedte gelijkwaardig aan 320 CSS-pixels;
- Horizontaal scrollbare content met een hoogte gelijkwaardig aan 256 CSS-pixels.
Met uitzondering van delen van de content die voor het gebruik of de betekenis een tweedimensionale lay-out vereisen.
Informatie over succescriterium 1.4.10 Reflow
Uitkomst: Onvoldoende
Bevindingen: Op https://kda.staging.rijksapplicaties.nl/vragen springt de pagina steeds terug naar de originele grootte als men de tekst en viewport aanpast. Zorg ervoor dat deze pagina meeschaalt als de tekst en viewport aangepast worden.
1.4.11 Contrast van niet-tekstuele content (Niveau AA)
De visuele weergave van het volgende heeft een contrastverhouding van ten minste 3:1 ten opzichte van aangrenzende kleuren:
- Componenten van de gebruikersinterface: Visuele informatie die vereist is om componenten van de gebruikersinterface en statussen te identificeren, met uitzondering van inactieve componenten of componenten waarvan de weergave van de component wordt bepaald door de user agent en niet wordt aangepast door de auteur;
- Grafische objecten: Delen van afbeeldingen die vereist zijn om de content te begrijpen, behalve wanneer een specifieke weergave van afbeeldingen essentieel is voor de informatie die wordt overgebracht.
Informatie over succescriterium 1.4.11 Contrast van niet-tekstuele content
Uitkomst: Voldoende
1.4.12 Tekstafstand (Niveau AA)
Bij content die wordt geïmplementeerd met opmaaktalen die de volgende stijleigenschappen voor tekst ondersteunen, is er geen sprake van verlies van content of functionaliteit door het instellen van alle volgende, en door het niet wijzigen van andere stijleigenschappen:
- Regelhoogte (regelafstand) naar minstens 1,5 keer de lettergrootte;
- Afstand tussen alinea's naar minstens 2 keer de lettergrootte;
- Letterafstand (spatieren van letters) naar minstens 0,12 keer de lettergrootte;
- Spatieren van woorden naar minstens 0,16 keer de lettergrootte.
Uitzondering: Menselijke talen en scripts die geen gebruik maken van een of meer van deze stijleigenschappen voor tekst in schriftelijke tekst, kunnen voldoen aan de eisen door alleen gebruik te maken van de eigenschappen die bestaan voor de betreffende combinatie van taal en script.
Informatie over succescriterium 1.4.12 Tekstafstand
Uitkomst: Voldoende
1.4.13 Content bij hover of focus (Niveau AA)
Wanneer aanvullende content zichtbaar wordt en daarna weer verborgen, door het gebruik van hover met de aanwijzer of focus met het toetsenbord, gelden de volgende zaken:
- Sluiten: Er is een mechanisme beschikbaar waarmee de aanvullende content kan worden gesloten zonder de aanwijzer hover of de toetsenbordfocus te verplaatsen, tenzij de aanvullende content een invoerfout communiceert of andere content niet verbergt of vervangt;
- Aanwijsbaar: Wanneer een aanwijzer hover aanvullende content kan activeren, dan kan de aanwijzer over de aanvullende content worden bewogen zonder dat deze verdwijnt;
- Aanhouden: De aanvullende content blijft zichtbaar totdat de oorzaak voor de hover of focus is verwijderd, de gebruiker de content sluit of de informatie niet langer geldig is.
Uitzondering: De visuele weergave van de aanvullende content wordt beheerd door de user agent en wordt niet aangepast door de auteur.
Informatie over succescriterium 1.4.13 Content bij hover of focus
Uitkomst: Voldoende
2. Bedienbaar
2.1 Toetsenbordtoegankelijk
2.1.1 Toetsenbord (Niveau A)
Alle functionaliteit van de content is bedienbaar via een toetsenbordinterface zonder dat afzonderlijke toetsaanslagen aan tijd gebonden zijn, behalve als de onderliggende functie een invoer vereist die afhangt van het pad dat de gebruiker aflegt en niet alleen van de eindpunten.
Informatie over succescriterium 2.1.1 Toetsenbord
Uitkomst: Onvoldoende
Bevindingen: De tooltip in de kolom 'Actief" op de pagina account domeinen in https://kda.staginzg.rijksapplicaties.nl/beheer laat enkel informatie zien bij muis. De tooltip kan niet worden geopend of gesloten met toetsenbord. Zorg ervoor dat de tooltip een knop is die daarna de informatie uitklapt. Zorg ervoor dat de knop een duidelijke toegankelijke naam heeft en vergeet niet om aria-expanded te gebruiken.
Als men de vraag bekijkt op https://kda.staging.rijksapplicaties.nl/voorbereid, kan men het antwoord kopiëren. Deze knop is niet te bedienen met het toetsenbord, omdat er geen interactief element als een knop is gebruikt. Gebruik een knop om dit op te lossen.
2.1.2 Geen toetsenbordval (Niveau A)
Als de toetsenbordfocus met de toetsenbordinterface verplaatst kan worden naar een component van de pagina, dan kan de focus ook met alleen de toetsenbordinterface weer van dat component weg worden bewogen. En, als er meer nodig is dan de standaard pijl- of tabtoetsen of andere standaard methoden om de focus te verplaatsen, dan wordt de gebruiker geïnformeerd over de manier waarop de focus kan worden verplaatst.
Informatie over succescriterium 2.1.2 Geen toetsenbordval
Uitkomst: Voldoende
2.1.4 Enkel teken sneltoets (Niveau A)
Wanneer een sneltoets in content wordt geïmplementeerd door alleen letters (inclusief hoofdletters en kleine letters), leestekens, cijfers of symbolen te gebruiken, geldt ten minste één van de volgende zaken:
- Uitzetten: Er is een mechanisme beschikbaar waarmee de sneltoets kan worden uitgezet;
- Opnieuw toewijzen: Er is een mechanisme beschikbaar om de sneltoets opnieuw toe te wijzen aan één of meerdere niet-afdrukbare tekens (bijvoorbeeld Ctrl, Alt, enz.);
- Alleen actief bij focus: De sneltoets voor een component van de gebruikersinterface is alleen actief wanneer de betreffende component de focus heeft.
Informatie over succescriterium 2.1.4 Enkel teken sneltoets
Uitkomst: Niet aanwezig
2.2 Genoeg tijd
2.2.1 Timing aanpasbaar (Niveau A)
Voor elke tijdslimiet die door de content wordt ingesteld, geldt ten minste één van de volgende zaken:
- Uitzetten: De gebruiker kan de tijdslimiet uitzetten voordat die wordt bereikt; of
- Aanpassen: De gebruiker mag de tijdslimiet aanpassen voordat deze is verstreken over een bereik van ten minste tien keer de standaardinstelling; of
- Verlengen: De gebruiker wordt gewaarschuwd voor de tijd afloopt en krijgt ten minste 20 seconden om de tijdslimiet met een eenvoudige handeling te verlengen (bijvoorbeeld, "druk op de spatiebalk"), en de gebruiker mag de tijdslimiet ten minste tien keer verlengen; of
- Real-time uitzondering: De tijdslimiet is onderdeel van een realtime gebeurtenis (een veiling bijvoorbeeld) en er is geen alternatief voor de tijdslimiet mogelijk; of
- Essentiële uitzondering: De tijdslimiet is essentieel en verlenging zou de activiteit ongeldig maken; of
- 20 uur uitzondering: De tijdslimiet is langer dan 20 uur.
Informatie over succescriterium 2.2.1 Timing aanpasbaar
Uitkomst: Onvoldoende
Bevindingen: De pagina https://kda.staging.rijksapplicaties.nl/vragen ververst ongeveer elke 10 seconden. Voor bezoekers die met behulp van het toetsenbord navigeren komt de toetsenbordfocus dan weer op het eerst interactieve element op de pagina. Voor tijdslimieten geldt dat de bezoeker die moet kunnen uitzetten, aanpassen of verlengen. Dat is nu niet het geval.
2.2.2 Pauzeren, stoppen, verbergen (Niveau A)
Voor alle bewegende, knipperende, scrollende of automatisch actualiserende informatie gelden alle volgende zaken:
- Bewegen, knipperen, scrollen: Voor bewegende, knipperende of scrollende informatie die (1) automatisch start, (2) langer dan vijf seconden duurt, en (3) parallel met andere content wordt getoond, is er een mechanisme voor de gebruiker om dit te pauzeren, te stoppen of te verbergen, tenzij de beweging, knippering of scrolling, onderdeel is van een activiteit waar ze essentieel is en
- Automatisch actualiserend: Voor elke soort automatisch actualiserende informatie die (1) automatisch start en (2) parallel met andere content wordt gepresenteerd, is er een mechanisme voor de gebruiker om dit te pauzeren, te stoppen of te verbergen of de frequentie van de actualisering in te stellen, tenzij de automatische actualisering onderdeel is van een activiteit waar ze essentieel is.
Informatie over succescriterium 2.2.2 Pauzeren, stoppen, verbergen
Uitkomst: Voldoende
2.3 Toevallen en fysieke reacties
2.3.1 Drie flitsen of beneden drempelwaarde (Niveau A)
Webpagina's bevatten niets wat meer dan drie keer flitst in enige periode van één seconde of de flits is beneden de algemene flits- en rodeflitsdrempelwaarden.
Informatie over succescriterium 2.3.1 Drie flitsen of beneden drempelwaarde
Uitkomst: Voldoende
2.4 Navigeerbaar
2.4.1 Blokken omzeilen (Niveau A)
Er is een mechanisme beschikbaar om blokken content die op meerdere webpagina's worden herhaald te omzeilen.
Informatie over succescriterium 2.4.1 Blokken omzeilen
Uitkomst: Voldoende
2.4.2 Paginatitel (Niveau A)
Webpagina's hebben titels die het onderwerp of doel beschrijven.
Informatie over succescriterium 2.4.2 Paginatitel
Uitkomst: Voldoende
Bevindingen: De paginatitel is uniek, maar we adviseren om achter de titel ook de naam van de website of organisatie te vermelden. Bijvoorbeeld "Beheer - kamerdebatten".
2.4.3 Focus volgorde (Niveau A)
Als een webpagina sequentieel genavigeerd kan worden en de navigatiesequenties hebben invloed op de betekenis of het gebruik, dan krijgen focusbare componenten de focus in de juiste volgorde waardoor betekenis en bedienbaarheid behouden blijft.
Informatie over succescriterium 2.4.3 Focus volgorde
Uitkomst: Onvoldoende
Bevindingen: Op https://kda.staging.rijksapplicaties.nl/ staat het hoofdmenu extra in de lees- en tabvolgorde doordat op de container <div class="navbar navbar-default"> het attribuut tabindex=0 wordt gebruikt. Voor niet-interactieve elementen is het niet toegestaan om zaken middels dit attribuut in de lees- en tabvolgorde te zetten. Het attribuut maakt een element door het toepassen ervan ook niet operabel of interactief. Verwijder het attribuut.
Op https://kda.staging.rijksapplicaties.nl/debatten staan de koppen van de tabel in de lees- en tabvolgorde. Dit komt door het tabindex=0 attribuut. Voor niet-interactieve elementen is het niet toegestaan om zaken middels dit attribuut in de lees- en tabvolgorde te zetten. Het attribuut maakt een element door het toepassen ervan ook niet operabel of interactief. Verwijder het attribuut.
2.4.4 Linkdoel (in context) (Niveau A)
Het linkdoel kan bepaald worden uit enkel de linktekst of uit de linktekst samen met zijn door software bepaalde linkcontext, behalve daar waar het doel van de link een dubbelzinnige betekenis zou kunnen hebben voor gebruikers in het algemeen.
Informatie over succescriterium 2.4.4 Linkdoel (in context)
Uitkomst: Voldoende
2.4.5 Meerdere manieren (Niveau AA)
Er is meer dan één manier beschikbaar om een webpagina binnen een verzameling webpagina's te vinden, behalve wanneer de webpagina het resultaat is van, of een stap in, een proces.
Informatie over succescriterium 2.4.5 Meerdere manieren
Uitkomst: Voldoende
2.4.6 Koppen en labels (Niveau AA)
Koppen en labels beschrijven het onderwerp of doel.
Informatie over succescriterium 2.4.6 Koppen en labels
Uitkomst: Voldoende
2.4.7 Focus zichtbaar (Niveau AA)
Elke gebruikersinterface die met een toetsenbord te bedienen is, heeft een bedieningswijze waarbij de indicator van de toetsenbordfocus zichtbaar is.
Informatie over succescriterium 2.4.7 Focus zichtbaar
Uitkomst: Voldoende
2.5 Input modaliteiten
2.5.1 Aanwijzergebaren (Niveau A)
Alle functionaliteit waarmee bij de bediening gebruik wordt gemaakt van meerpunts- of padgebaseerde gebaren, kan worden bediend met een enkele aanwijzer zonder een padgebaseerd gebaar, tenzij een meerpunts- of padgebaseerd gebaar essentieel is.
Informatie over succescriterium 2.5.1 Aanwijzergebaren
Uitkomst: Niet aanwezig
2.5.2 Aanwijzerannulering (Niveau A)
Voor functionaliteit die kan worden bediend met een enkele aanwijzer, geldt ten minste één van de volgende zaken:
- Geen down-event: Het down-event van de aanwijzer wordt niet gebruikt om enig onderdeel van de functie uit te voeren;
- Afbreken of ongedaan maken: De functie wordt voltooid door het up-event en er is een mechanisme beschikbaar om de functie af te breken voordat deze wordt voltooid of om de functie ongedaan te maken als deze is voltooid;
- Up reversal: Met het up-event wordt elk resultaat van het voorgaande down-event ongedaan gemaakt;
- Essentieel: Het voltooien van de functie met het down-event is essentieel.
Informatie over succescriterium 2.5.2 Aanwijzerannulering
Uitkomst: Niet aanwezig
2.5.3 Label in naam (Niveau A)
Bij componenten van de gebruikersinterface met labels die tekst of afbeeldingen van tekst bevatten, bevat de naam de tekst die visueel wordt weergegeven.
Informatie over succescriterium 2.5.3 Label in naam
Uitkomst: Voldoende
2.5.4 Bewegingsactivering (Niveau A)
Functionaliteit die kan worden bediend door de beweging van een apparaat of beweging van een gebruiker, kan ook worden bediend met componenten van de gebruikersinterface. De reactie op de beweging kan worden uitgeschakeld om onbedoelde activering te voorkomen, behalve wanneer:
- Ondersteunde interface: De beweging wordt gebruikt om de functionaliteit te bedienen via een door toegankelijkheid ondersteunde interface;
- Essentieel: De beweging is essentieel voor de functie en wanneer de reactie op de beweging wordt uitgeschakeld, wordt de activiteit ongeldig gemaakt.
Informatie over succescriterium 2.5.4 Bewegingsactivering
Uitkomst: Niet aanwezig
3. Begrijpelijk
3.1 Leesbaar
3.1.1 Taal van de pagina (Niveau A)
De standaard menselijke taal van elke webpagina kan door software bepaald worden.
Informatie over succescriterium 3.1.1 Taal van de pagina
Uitkomst: Voldoende
3.1.2 Taal van onderdelen (Niveau AA)
De menselijke taal van elke passage of zin in de content kan door software bepaald worden, behalve waar het gaat om eigennamen, technische termen, woorden uit een onbepaalde taal en woorden of zinsdelen die deel zijn gaan uitmaken van het jargon van de onmiddellijk omringende tekst.
Informatie over succescriterium 3.1.2 Taal van onderdelen
Uitkomst: Onvoldoende
Bevindingen: Op https://kda.staging.rijksapplicaties.nl/ wordt het hoofdmenu in mobile view gepresenteerd met een hamburgermenu. De knop daarvoor heeft als toegankelijke naam "Toggle navigation". Geef de knop een toegankelijke naam in het Nederlands.
3.2 Voorspelbaar
3.2.1 Bij focus (Niveau A)
Als een component van de gebruikersinterface de focus krijgt, dan veroorzaakt dat geen contextwijziging.
Informatie over succescriterium 3.2.1 Bij focus
Uitkomst: Voldoende
3.2.2 Bij input (Niveau A)
Verandering van de instelling van een component van de gebruikersinterface veroorzaakt niet automatisch een contextwijziging, tenzij de gebruiker geïnformeerd is over het gedrag vóór het gebruik van de component.
Informatie over succescriterium 3.2.2 Bij input
Uitkomst: Voldoende
3.2.3 Consistente navigatie (Niveau AA)
Navigatiemechanismen, die op meerdere webpagina's binnen een verzameling webpagina's herhaald worden, komen elke keer dat ze worden herhaald in dezelfde relatieve volgorde voor, tenzij een verandering wordt geïnitieerd door de gebruiker.
Informatie over succescriterium 3.2.3 Consistente navigatie
Uitkomst: Voldoende
3.2.4 Consistente identificatie (Niveau AA)
Componenten die dezelfde functionaliteit hebben binnen een verzameling webpagina's worden consistent geïdentificeerd.
Informatie over succescriterium 3.2.4 Consistente identificatie
Uitkomst: Voldoende
3.3 Assistentie bij invoer
3.3.1 Foutidentificatie (Niveau A)
Als een invoerfout automatisch ontdekt wordt, dan wordt het onderdeel waar de fout zit geïdentificeerd en wordt de fout tekstueel aan de gebruiker meegedeeld.
Informatie over succescriterium 3.3.1 Foutidentificatie
Uitkomst: Voldoende
3.3.2 Labels of instructies (Niveau A)
Als de content gebruikersinvoer vereist, dan worden labels of instructies geleverd.
Informatie over succescriterium 3.3.2 Labels of instructies
Uitkomst: Onvoldoende
Bevindingen: Op de pagina "Gebruikersbeheer" in https://kda.staging.rijksapplicaties.nl/beheer heeft het invoerveld om te filteren op naam geen label. Dit heeft impact op hulpsoftware als screenreaders en spraakbesturing. Voeg een label toe om dit op te lossen.
Op de pagina "Gebruikersbeheer" in https://kda.staging.rijksapplicaties.nl/beheer heeft de checkbox om te filteren op gearchiveerde gebruikers geen label. Dit heeft impact op hulpsoftware als screenreaders en spraakbesturing. Voeg een label toe om dit op te lossen.
3.3.3 Foutsuggestie (Niveau AA)
Als een invoerfout automatisch ontdekt wordt en suggesties voor verbetering bekend zijn, dan worden de suggesties aan de gebruiker geleverd, tenzij dit de beveiliging of het doel van de content in gevaar zou brengen.
Informatie over succescriterium 3.3.3 Foutsuggestie
Uitkomst: Voldoende
3.3.4 Foutpreventie (wettelijk, financieel, gegevens) (Niveau AA)
Voor webpagina's die wettelijke verplichtingen of financiële transacties voor de gebruiker uitvoeren, die, door de gebruiker te beheren gegevens in gegevensopslagplaatsen verwijderen of wijzigen, of die antwoorden van de gebruiker verzenden, geldt minstens één van de volgende zaken:
- Omkeerbaar: Verzendingen kunnen ongedaan gemaakt worden.
- Gecontroleerd: Door de gebruiker ingevoerde gegevens worden gecontroleerd op invoerfouten en de gebruiker wordt de mogelijkheid gegeven om ze te verbeteren.
- Bevestigd: Er is een mechanisme beschikbaar voor het beoordelen, bevestigen en verbeteren van informatie voordat de verzending wordt voltooid.
Informatie over succescriterium 3.3.4 Foutpreventie (wettelijk, financieel, gegevens)
Uitkomst: Niet aanwezig
4. Robuust
4.1 Compatibel
4.1.1 Parsen (Niveau A)
In content die geïmplementeerd is met opmaaktalen hebben elementen volledige begin- en eindtags, zijn elementen genest volgens hun specificatie, bevatten elementen geen dubbele attributen en zijn alle ID's uniek, behalve waar de specificatie deze eigenschappen toelaat.
Informatie over succescriterium 4.1.1 Parsen
Uitkomst: Voldoende
4.1.2 Naam, rol, waarde (Niveau A)
Voor alle componenten van de gebruikersinterface (inclusief, maar niet uitsluitend voor formulierelementen, links en door scripts gegenereerde componenten), kunnen de naam (name) en rol (role) door software bepaald worden; toestanden (states), eigenschappen (properties) en waarden (values) die door de gebruiker ingesteld kunnen worden, kunnen door software ingesteld worden; en kennisgeving van veranderingen in deze items is beschikbaar voor user agents, met inbegrip van hulptechnologieën.
Informatie over succescriterium 4.1.2 Naam, rol, waarde
Uitkomst: Onvoldoende
Bevindingen: Op https://kda.staging.rijksapplicaties.nl/debatten kan de inhoud van de tabel middels de koppen van de tabel gesorteerd worden. Dit is mogelijk met de muis en in principe door tabindex=0 ook met het toetsenbord. Maar hulpsoftware krijgt niet mee dat dit interactief is, omdat er geen interactief element is gebruikt. Dit heeft vooral impact op spraakbesturing en kan verwarrend zijn bij gebruik van screenreaders. Voeg in elke kolom een knop in de <th> toe naast de naam voor de kolom en geef die knop een duidelijk label/toegankelijke naam. Dit speelt ook op https://kda.staging.rijksapplicaties.nl/dossier, https://kda.staging.rijksapplicaties.nl/beheer bij account domeinen
Op https://kda.staging.rijksapplicaties.nl/debatten kan de inhoud van de tabel middels de koppen van de tabel gesorteerd worden. Het pictogram hiervoor is een chevron, dat met JavaScript klikbaar is gemaakt, en wordt ingeladen middels een <i> element. Met een aria-label attribuut wordt een toegankelijke naam/label gegeven. Dit is op HTML-elementen met een generieke rol (o.a ook div en span) niet toegestaan. Verwijder het attribuut en gebruik een knop (geef die knop uiteraard een toegankelijke naam). Dit komt ook voor op https://kda.staging.rijksapplicaties.nl/dossier en account domeinen op https://kda.staging.rijksapplicaties.nl/beheer.
Op https://kda.staging.rijksapplicaties.nl zit het hoofdmenu in de volgende container: <div id="main-nav" class="navbar-collapse collapse" role="button" tabindex="0"> Deze knop heeft geen toegankelijke naam en de functie van de knop is onduidelijk, omdat deze niets met het hoofdmenu doet en ook niet de knop is voor het hamburgermenu in mobile view. Verwijder de rol en het tabindex-attribuut.
Op https://kda.staging.rijksapplicaties.nl/debatten blijft de knop van een geselecteerd debat focus krijgen, waardoor het lijkt alsof deze gedeselecteerd kan worden. Visueel door het gebruik van een checkbox, lijkt dat ook visueel zo. Maar dat is niet mogelijk. Dit is verwarrend voor gebruikers van hulpsoftware en bemoeilijkt het selecteren van een debat met spraakbesturing. In plaats van knoppen, gebruik hier een radiobutton. Dat zorgt ervoor dat slechts 1 debat steeds gekozen kan worden, wat de bedoeling is in deze applicatie, en zorgt ervoor dat de status van gekozen of niet gekozen automatisch naar hulpsoftware toe wordt gecommuniceerd.
Op https://kda.staging.rijksapplicaties.nl/vragen worden in veel knoppen slechts een pictogram gebruikt voor een visueel label. Dit is toegestaan als het pictogram door iedereen begrepen kan worden en het een standaard is, zoals het vergrootglas voor zoeken. Voor de knoppen op deze pagina is dat echter niet het geval en dient er ook tekst naast het pictogram in de knop te staan.
Als men op https://kda.staging.rijksapplicaties.nl/vragen een vraag opent kan men de knop "Vraag terugluisteren" gebruiken. Bij het indrukken verandert deze enkel van kleur, functiegewijs gebeurt er niets. Kies een HTML-element dat duidelijker uitdraagt wat de bedoeling is van de knop en wat de verandering van staat (ingeschakeld of niet) betekent. Deze informatie ontbreekt nu en heeft veel impact op hulpsoftware.
Op de pagina "Gebruikersbeheer" in https://kda.staging.rijksapplicaties.nl/beheer heeft de knop om de actieve filters te wissen geen toegankelijke naam. Dit heeft impact op screenreaders en spraakbesturing. Voeg een toegankelijke naam toe om dit op te lossen.
4.1.3 Statusberichten (Niveau AA)
In content die is geïmplementeerd met opmaaktalen kunnen statusberichten door software bepaald worden met behulp van rol (role) of eigenschappen (properties), zodat hulptechnologieën de berichten aan de gebruiker kunnen presenteren zonder dat ze de focus krijgen.
Informatie over succescriterium 4.1.3 Statusberichten
Uitkomst: Voldoende
Onderbouwing van de evaluatie
Het onderzoek is uitgevoerd op basis van de evaluatiemethode van het W3C, WCAG-EM. Dit gebeurt grotendeels handmatig door een steekproef te nemen. Voor een quickscan geldt dat we slechts delen uit deze methodiek gebruiken. Ondanks alle zorgvuldigheid en ervaring van de onderzoeker kan het voorkomen dat een probleem niet gesignaleerd is. Houd er rekening mee dat in een volgend onderzoek bepaalde onderdelen anders worden beoordeeld omdat technologieën en hulpsoftware worden doorontwikkeld. Bij het handmatig onderzoek wordt gebruik gemaakt van tools.
Steekproef getoetste webpagina's
- https://kda.staging.rijksapplicaties.nl/
- https://kda.staging.rijksapplicaties.nl/vragen
- https://kda.staging.rijksapplicaties.nl/voorbereid
- https://kda.staging.rijksapplicaties.nl/dossier
- https://kda.staging.rijksapplicaties.nl/beheer
- https://kda.staging.rijksapplicaties.nl/beheer?sv=638799622049743389_KqFll4qLiY8Xoy2x8O4Be0ku6GV%2BqG7OiBxD%2FRBO0WM%3D
- https://kda.staging.rijksapplicaties.nl/beheer?sv=638799622301783466_PYXetWwnDhkezOAdgYAQ07KF%2FmbFGFSljGaGxOpnDX8%3D
- https://kda.staging.rijksapplicaties.nl/beheer?sv=638799622512369718_9f9snNO%2BeqpXsrXRxFBAo9QA%2FbrfnCSouCtTn4rZhKI%3D
- https://kda.staging.rijksapplicaties.nl/beheer?sv=638799622771422231_ae3Y4lnj62T8a2BhMV17yP0r%2FYy7w%2BIvH7cZWXWAf7M%3D
- https://kda.staging.rijksapplicaties.nl/user/privacyverklaring
- https://kda.staging.rijksapplicaties.nl/user/versie-informatie
Ondersteunende technieken
Webbrowsers (useragents) en andere software
Bij dit onderzoek is de volgende software gebruikt:- Chrome, versie 135
- Safari, versie 18.3
- VoiceOver
Bronnen
-
Website Accessibility Conformance Evaluation Methodology (WCAG-EM) Overview
www.w3.org/WAI/eval/conformance (Engels) -
Web Content Accessibility Guidelines (WCAG) 2.1 (Geautoriseerde Nederlandse vertaling)
www.w3.org/Translations/WCAG21-nl -
Website Accessibility Conformance Evaluation Methodology (WCAG-EM)
www.w3.org/WAI/eval/conformance -
Web Content Accessibility Guidelines (WCAG)
www.w3.org/WAI/intro/wcag -
How to Meet WCAG 2.1 Quick Reference
www.w3.org/WAI/WCAG21/quickref/
Deze rapportage is grotendeels gemaakt met de online evaluatietool van W3C.