1110 lines
61 KiB
JSON
1110 lines
61 KiB
JSON
{
|
||
"lang": "pl",
|
||
"rules": {
|
||
"accesskeys": {
|
||
"description": "Wartość każdego atrybutu accessskey jest unikalna.",
|
||
"help": "Wartość atrybutu accessskey musi być unikalna."
|
||
},
|
||
"area-alt": {
|
||
"description": "Elementy <area> w graficznych mapach odnośników mają tekst zastępczy.",
|
||
"help": "Elementy aktywne <area> muszą mieć tekst alternatywny."
|
||
},
|
||
"aria-allowed-attr": {
|
||
"description": "Użyte atrybuty ARIA są dozwolone dla elementu z określoną rolą.",
|
||
"help": "Elementy mogą używać tylko dozwolonych atrybutów ARIA."
|
||
},
|
||
"aria-allowed-role": {
|
||
"description": "Atrybut role ma odpowiednią wartość dla danego elementu.",
|
||
"help": "Rola ARIA musi być odpowiednia dla danego elementu."
|
||
},
|
||
"aria-braille-equivalent": {
|
||
"description": "Upewnij się, że aria-braillelabel i aria-brailleroledescription mają odpowiednik niebrajlowski",
|
||
"help": "Atrybuty aria-braille muszą mieć odpowiednik niebrajlowski."
|
||
},
|
||
"aria-command-name": {
|
||
"description": "Każdy element button, link i menuitem ARIA ma dostępną nazwę.",
|
||
"help": "Przyciski, łącza, pozycje menu ARIA muszą mieć dostępną nazwę."
|
||
},
|
||
"aria-conditional-attr": {
|
||
"description": "Upewnij się, że atrybuty ARIA są używane zgodnie ze specyfikacją roli elementu.",
|
||
"help": "Atrybuty ARIA muszą być używane w sposób określony dla roli elementu"
|
||
},
|
||
"aria-deprecated-role": {
|
||
"description": "Upewnij się, że elementy nie używają przestarzałych ról.",
|
||
"help": "Przestarzałe role ARIA nie mogą być używane."
|
||
},
|
||
"aria-dialog-name": {
|
||
"description": "Każde okno dialogowe ARIA i węzeł alertdialog ma dostępną nazwę.",
|
||
"help": "Okno dialogowe ARIA i węzły alertdialog muszą mieć dostępną nazwę."
|
||
},
|
||
"aria-hidden-body": {
|
||
"description": "Element body nie ma atrybutu aria-hidden='true'.",
|
||
"help": "Element body nie może mieć atrybutu aria-hidden='true'."
|
||
},
|
||
"aria-hidden-focus": {
|
||
"description": "Elementy z aria-hidden=true nie mogą obejmować elementów przyjmujących fokus.",
|
||
"help": "Ukryty element ARIA nie może zawierać elementów przyjmujących fokus."
|
||
},
|
||
"aria-input-field-name": {
|
||
"description": "Każde pole ARIA do wprowadzania danych ma dostępną nazwę.",
|
||
"help": "Pola ARIA do wprowadzania danych muszą mieć dostępną nazwę."
|
||
},
|
||
"aria-meter-name": {
|
||
"description": "Każdy element ARIA meter (licznik) ma dostępną nazwę.",
|
||
"help": "Liczniki ARIA (meter) muszą mieć dostępne nazwy."
|
||
},
|
||
"aria-progressbar-name": {
|
||
"description": "Każdy element ARIA progressbar (pasek postępu) ma dostępną nazwę.",
|
||
"help": "Paski postępu ARIA (progressbar) muszą mieć dostępne nazwy."
|
||
},
|
||
"aria-prohibited-attr": {
|
||
"description": "Upewnij się, że atrybuty ARIA nie są zabronione dla roli elementu.",
|
||
"help": "Elementy mogą używać tylko dozwolonych atrybutów ARIA."
|
||
},
|
||
"aria-required-attr": {
|
||
"description": "Elementy z rolą ARIA mają wszystkie wymagane atrybuty aria-*",
|
||
"help": "Wymagane atrybuty ARIA muszą istnieć."
|
||
},
|
||
"aria-required-children": {
|
||
"description": "Elementy z atrybutem ARIA role, które muszą zawierać elementy potomne z wymaganym atrybutem role, zawierają je.",
|
||
"help": "Niektóre role ARIA muszą obejmować określone dzieci."
|
||
},
|
||
"aria-required-parent": {
|
||
"description": "Elementy z atrybutem ARIA role, które wymagają elementu rodzica z atrybutem role, są zawarte w elementach z takimi rolami.",
|
||
"help": "Elementy z niektórymi atrybutami role ARIA muszą znajdować się wewnątrz nadrzędnego elementu rodzica z wymaganym atrybutem role."
|
||
},
|
||
"aria-roledescription": {
|
||
"description": "Atrybut aria-roledescription jest używany tylko w elementach, które mają rolę określoną domyślnie lub jawnie.",
|
||
"help": "Użyj aria-roledescription w elementach o roli semantycznej."
|
||
},
|
||
"aria-roles": {
|
||
"description": "Wartości atrybutu role są poprawne.",
|
||
"help": "Stosowane role ARIA muszą mieć poprawne wartości."
|
||
},
|
||
"aria-text": {
|
||
"description": "Atrybut role=\"text\" jest używany dla elementów, które nie mają potomków przyjmujących fokus",
|
||
"help": "Element z atrybutem role=\"text\" nie może mieć potomków przyjmujących fokus."
|
||
},
|
||
"aria-toggle-field-name": {
|
||
"description": "Każdy element ARIA toggle (przełącznik) ma dostępną nazwę.",
|
||
"help": "Przełączniki ARIA (toggle) muszą mieć dostępną nazwę."
|
||
},
|
||
"aria-tooltip-name": {
|
||
"description": "Każdy element ARIA tooltip (podpowiedź) ma dostępną nazwę.",
|
||
"help": "Podpowiedzi ARIA (tooltip) muszą mieć dostępną nazwę."
|
||
},
|
||
"aria-treeitem-name": {
|
||
"description": "Każdy element ARIA treeitem (węzeł drzewa) ma dostępną nazwę.",
|
||
"help": "Węzły drzewa elementów ARIA (treeitem) muszą mieć dostępną nazwę."
|
||
},
|
||
"aria-valid-attr-value": {
|
||
"description": "Wszystkie atrybuty ARIA mają poprawne wartości.",
|
||
"help": "Atrybuty ARIA muszą mieć poprawne wartości."
|
||
},
|
||
"aria-valid-attr": {
|
||
"description": "Wszystkie atrybuty aria-* mają poprawne nazwy.",
|
||
"help": "Atrybuty ARIA muszą mieć poprawne nazwy."
|
||
},
|
||
"audio-caption": {
|
||
"description": "Elementy <audio> mają napisy rozszerzone.",
|
||
"help": "Elementy <audio> muszą mieć ścieżkę z napisami."
|
||
},
|
||
"autocomplete-valid": {
|
||
"description": "Pola formularza, które zbierają dane osobowe, mają poprawne atrybuty autocomplete",
|
||
"help": "Atrybut autocomplete musi być użyty poprawnie."
|
||
},
|
||
"avoid-inline-spacing": {
|
||
"description": "Odstępy w tekście można regulować za pomocą własnych arkuszy stylów.",
|
||
"help": "Odstępy w tekście muszą być regulowane za pomocą własnych arkuszy stylów."
|
||
},
|
||
"blink": {
|
||
"description": "Elementy <blink> nie są używane.",
|
||
"help": "Elementy <blink> są przestarzałe i nie mogą być używane."
|
||
},
|
||
"button-name": {
|
||
"description": "Każdy przycisk ma odróżniającą go dostępną nazwę.",
|
||
"help": "Przyciski muszą mieć odróżniający je tekst nazwy."
|
||
},
|
||
"bypass": {
|
||
"description": "Każda strona ma co najmniej jeden mechanizm, który pozwala ominąć nawigację i przejść od razu do treści.",
|
||
"help": "Strona musi mieć środki do ominięcia powtarzających bloków treści."
|
||
},
|
||
"color-contrast-enhanced": {
|
||
"description": "Kontrast między kolorami pierwszego planu i tła spełnia wyższe progi współczynnika kontrastu WCAG 2 AAA.",
|
||
"help": "Elementy muszą spełniać wyższe progi współczynnika kontrastu kolorów"
|
||
},
|
||
"color-contrast": {
|
||
"description": "Kontrast między kolorami pierwszego planu i tła spełnia progi kontrastu WCAG 2 AA.",
|
||
"help": "Elementy muszą mieć wystarczający kontrast kolorów."
|
||
},
|
||
"css-orientation-lock": {
|
||
"description": "Treść nie jest przypisana do żadnej konkretnej orientacji wyświetlacza i można ją obsługiwać we wszystkich orientacjach wyświetlacza.",
|
||
"help": "Zapytania medialne nie są wykorzystywane do blokowania orientacji wyświetlacza."
|
||
},
|
||
"definition-list": {
|
||
"description": "Elementy <dl> mają poprawną strukturę.",
|
||
"help": "Elementy <dl> mogą bezpośrednio zawierać tylko odpowiednio uporządkowane grupy <dt> i <dd> oraz elementy <script>, <template> lub <div>."
|
||
},
|
||
"dlitem": {
|
||
"description": "Elementy <dt> i <dd> znajdują się bezpośrednio w <dl>.",
|
||
"help": "Elementy <dt> i <dd> są wewnątrz elementu <dl>."
|
||
},
|
||
"document-title": {
|
||
"description": "Każdy dokument HTML ma niepusty element <title>.",
|
||
"help": "Dokumenty muszą mieć element <title> pomagający w nawigacji."
|
||
},
|
||
"duplicate-id-active": {
|
||
"description": "Wartość każdego atrybutu id aktywnych elementów jest unikalna.",
|
||
"help": "ID aktywnych elementów, które otrzymują fokus, muszą być unikalne."
|
||
},
|
||
"duplicate-id-aria": {
|
||
"description": "Każdy atrybut id używany w ARIA i w etykietach jest unikalny.",
|
||
"help": "Identyfikatory stosowane w ARIA i etykietach muszą być unikalne."
|
||
},
|
||
"duplicate-id": {
|
||
"description": "Wartość każdego atrybutu id jest unikalna.",
|
||
"help": "Wartość atrybutu id musi być unikalna."
|
||
},
|
||
"empty-heading": {
|
||
"description": "Nagłówki mają odróżniający je tekst.",
|
||
"help": "Nagłówki nie mogą być puste."
|
||
},
|
||
"empty-table-header": {
|
||
"description": "Upewnij się, że nagłówki tabel mają opisowy tekst.",
|
||
"help": "Tekst nagłówka tabeli nie może być pusty."
|
||
},
|
||
"focus-order-semantics": {
|
||
"description": "Elementy w porządku otrzymywania fokusu mają odpowiednią rolę.",
|
||
"help": "Elementy w porządku otrzymywania fokusu muszą mieć rolę odpowiednią dla treści interaktywnych."
|
||
},
|
||
"form-field-multiple-labels": {
|
||
"description": "Żadne pole formularza nie ma wielu etykiet (elementów label).",
|
||
"help": "Pole formularza nie może mieć wielu elementów label."
|
||
},
|
||
"frame-focusable-content": {
|
||
"description": "Elementy <frame> i <iframe> z treścią przyjmującą fokus nie mają tabindex=-1.",
|
||
"help": "Ramki z treścią przyjmującą fokus nie mogą mieć tabindex=-1."
|
||
},
|
||
"frame-tested": {
|
||
"description": "Elementy <iframe> i <frame> muszą być testowane ze skryptem axe-core.",
|
||
"help": "Ramki muszą być testowane ze skryptem axe-core."
|
||
},
|
||
"frame-title-unique": {
|
||
"description": "Elementy <iframe> i <frame> mają unikalny atrybut title.",
|
||
"help": "Ramki muszą mieć unikalny atrybut title."
|
||
},
|
||
"frame-title": {
|
||
"description": "Elementy <iframe> i <frame> mają niepusty atrybut title.",
|
||
"help": "Ramki muszą mieć niepusty atrybut title."
|
||
},
|
||
"heading-order": {
|
||
"description": "Kolejność nagłówków jest semantycznie poprawna.",
|
||
"help": "Poziomy nagłówków powinny wzrastać tylko o jeden."
|
||
},
|
||
"hidden-content": {
|
||
"description": "Na stronie są ukryte treści.",
|
||
"help": "Ukrytych treści na stronie nie można analizować."
|
||
},
|
||
"html-has-lang": {
|
||
"description": "Każdy dokument HTML ma atrybut lang.",
|
||
"help": "Element <html> musi mieć atrybut lang."
|
||
},
|
||
"html-lang-valid": {
|
||
"description": "Atrybut lang elementu <html> ma poprawną wartość.",
|
||
"help": "Element <html> musi mieć poprawną wartość atrybutu lang."
|
||
},
|
||
"html-xml-lang-mismatch": {
|
||
"description": "Element HTML z poprawnym atrybutem lang xml:lang ma ten sam podstawowy język strony.",
|
||
"help": "Element HTML z lang i xml:lang musi mieć ten sam język podstawowy."
|
||
},
|
||
"identical-links-same-purpose": {
|
||
"description": "Łącza o tej samej dostępnej nazwie służą temu samemu celowi.",
|
||
"help": "Łącza o tej samej nazwie mają ten sam cel."
|
||
},
|
||
"image-alt": {
|
||
"description": "Elementy <img> mają atrybut alt lub rolę none albo presentation.",
|
||
"help": "Obrazy muszą mieć tekst alternatywny."
|
||
},
|
||
"image-redundant-alt": {
|
||
"description": "Tekst alternatywny obrazu nie jest powtarzany w tekście.",
|
||
"help": "Tekst alternatywny obrazów nie powinien być powtarzany w tekście."
|
||
},
|
||
"input-button-name": {
|
||
"description": "Przyciski input type=button mają odróżniający je tekst.",
|
||
"help": "Przyciski input type=button muszą mieć odróżniający je tekst."
|
||
},
|
||
"input-image-alt": {
|
||
"description": "Elementy <input type=\"image\"> mają tekst alternatywny.",
|
||
"help": "Przyciski graficzne muszą mieć tekst alternatywny."
|
||
},
|
||
"label-content-name-mismatch": {
|
||
"description": "Elementy oznakowane swoją treścią mają swój widoczny tekst jako część ich dostępnej nazwy",
|
||
"help": "Elementy muszą mieć swój widoczny tekst jako część ich dostępnej nazwy."
|
||
},
|
||
"label-title-only": {
|
||
"description": "Żaden element formularza nie jest oznaczony wyłącznie za pomocą atrybutu title lub aria-describedby.",
|
||
"help": "Element formularza powinien mieć widoczną etykietę."
|
||
},
|
||
"label": {
|
||
"description": "Każdy element formularza ma etykietę.",
|
||
"help": "Element formularza musi mieć etykietę."
|
||
},
|
||
"landmark-banner-is-top-level": {
|
||
"description": "Obszar banner jest obszarem kluczowym najwyższego poziomu.",
|
||
"help": "Punkt orientacyjny banner nie może być zawarty wewnątrz innego obszaru kluczowego."
|
||
},
|
||
"landmark-complementary-is-top-level": {
|
||
"description": "Obszary aside lub z role=complementary są obszarami kluczowymi najwyższego poziomu.",
|
||
"help": "Punkt orientacyjny complementary nie może być zawarty wewnątrz innego obszaru kluczowego."
|
||
},
|
||
"landmark-contentinfo-is-top-level": {
|
||
"description": "Obszar kluczowy z role=contentinfo jest obszarem kluczowym najwyższego poziomu.",
|
||
"help": "Punkt orientacyjny contentinfo nie może być zawarty wewnątrz innego obszaru kluczowego."
|
||
},
|
||
"landmark-main-is-top-level": {
|
||
"description": "Obszar main jest obszarem kluczowym najwyższego poziomu.",
|
||
"help": "Punkt orientacyjny main nie może być zawarty wewnątrz innego obszaru kluczowego."
|
||
},
|
||
"landmark-no-duplicate-banner": {
|
||
"description": "Dokument ma co najwyżej jeden punkt orientacyjny banner.",
|
||
"help": "Dokument nie może mieć więcej niż jednego obszaru kluczowego banner."
|
||
},
|
||
"landmark-no-duplicate-contentinfo": {
|
||
"description": "Dokument ma co najwyżej jeden punkt orientacyjny contentinfo.",
|
||
"help": "Dokument nie może mieć więcej niż jednego obszaru kluczowego contentinfo."
|
||
},
|
||
"landmark-no-duplicate-main": {
|
||
"description": "Dokument ma co najwyżej jeden punkt orientacyjny main.",
|
||
"help": "Dokument nie może mieć więcej niż jednego obszaru kluczowego main."
|
||
},
|
||
"landmark-one-main": {
|
||
"description": "Dokument ma punkt orientacyjny main.",
|
||
"help": "Dokument może mieć tylko jeden obszar kluczowy main."
|
||
},
|
||
"landmark-unique": {
|
||
"help": "Punkty orientacyjne są unikalne",
|
||
"description": "Punkty orientacyjne (obszary kluczowe) mają unikalną rolę lub kombinację roli/etykiety/tytułu (tj. dostępną nazwę)."
|
||
},
|
||
"link-in-text-block": {
|
||
"description": "Łącza można rozróżniać bez opierania się na kolorze.",
|
||
"help": "Łącza muszą być odróżnialne od sąsiadującego tekstu w sposób, który nie opiera się na kolorze."
|
||
},
|
||
"link-name": {
|
||
"description": "Łącza mają odróżniający je tekst.",
|
||
"help": "Łącza muszą mieć odróżniający je tekst."
|
||
},
|
||
"list": {
|
||
"description": "Listy mają poprawną strukturę.",
|
||
"help": "Elementy <ul> i <ol> mogą bezpośrednio zawierać tylko elementy <li>, <script> lub <template>."
|
||
},
|
||
"listitem": {
|
||
"description": "Elementy <li> są używane semantycznie.",
|
||
"help": " Elementy <li> muszą być zawarte bezpośrednio w <ul> lub <ol>."
|
||
},
|
||
"marquee": {
|
||
"description": "Elementy <marquee> nie są używane.",
|
||
"help": "Elementy <marquee> są przestarzałe i nie mogą być używane."
|
||
},
|
||
"meta-refresh-no-exceptions": {
|
||
"description": "Upewnij się, że <meta http-equiv=\"refresh\"> nie jest używany do opóźnionego odświeżania",
|
||
"help": "Nie wolno stosować opóźnionego odświeżania"
|
||
},
|
||
"meta-refresh": {
|
||
"description": "Znacznik <meta http-equiv=\"refresh\"> nie jest używany do opóźnionego odświeżania.",
|
||
"help": "Opóźnione odświeżanie poniżej 20 godzin nie może być stosowane."
|
||
},
|
||
"meta-viewport-large": {
|
||
"description": "Element <meta name=\"viewport\"> umożliwia znaczne powiększanie.",
|
||
"help": "Użytkownicy mogą powiększać i skalować tekst do 500%."
|
||
},
|
||
"meta-viewport": {
|
||
"description": "Element <meta name=\"viewport\"> nie wyłącza skalowania i powiększania tekstu.",
|
||
"help": "Powiększanie i skalowanie nie może być wyłączone."
|
||
},
|
||
"nested-interactive": {
|
||
"description": "Upewnij się, że kontrolki interaktywne nie są zagnieżdżone, ponieważ nie zawsze są ogłaszane przez czytniki ekranu lub mogą powodować problemy technologii wspomagających z fokusem.",
|
||
"help": "Kontrolki interaktywne nie mogą być zagnieżdżone"
|
||
},
|
||
"no-autoplay-audio": {
|
||
"description": "Elementy <video> lub <audio> nie odtwarzają automatycznie dźwięku przez dłużej niż 3 sekundy bez mechanizmu, który go zatrzymuje lub wycisza.",
|
||
"help": "Elementy <video> lub <audio> nie odtwarzają dźwięku automatycznie."
|
||
},
|
||
"object-alt": {
|
||
"description": "Elementy <object> mają tekst zastępczy.",
|
||
"help": "Elementy <object> muszą mieć alternatywę tekstową."
|
||
},
|
||
"p-as-heading": {
|
||
"description": "Pogrubienie, kursywa i rozmiar czcionki nie są używane do stylizacji elementów <p> jako nagłówków.",
|
||
"help": "Stylizowane elementy <p> nie mogą być używane jako nagłówki."
|
||
},
|
||
"page-has-heading-one": {
|
||
"description": "Strona lub co najmniej jedna z jej ramek, zawiera nagłówek pierwszego poziomu.",
|
||
"help": "Strona musi zawierać nagłówek poziomu 1."
|
||
},
|
||
"presentation-role-conflict": {
|
||
"description": "Elementy oznaczone jako prezentacyjne nie powinny mieć globalnego ARIA ani tabindex, aby zapewnić, że wszystkie czytniki ekranu je zignorują.",
|
||
"help": "Upewnij się, że elementy oznaczone jako prezentacyjne są konsekwentnie ignorowane."
|
||
},
|
||
"region": {
|
||
"description": "Cała treść strony jest objęta przez punkty orientacyjne.",
|
||
"help": "Cała treść strony musi być zawarta w obszarach kluczowych."
|
||
},
|
||
"role-img-alt": {
|
||
"description": "Elementy z [role='img'] mają tekst alternatywny.",
|
||
"help": "Elementy z [role='img'] muszą mieć tekst alternatywny."
|
||
},
|
||
"scope-attr-valid": {
|
||
"description": "Atrybut scope w tabelach jest stosowany poprawnie.",
|
||
"help": "Atrybut scope ma poprawną wartość."
|
||
},
|
||
"scrollable-region-focusable": {
|
||
"description": "Elementy, których treść można przewijać, są osiągalne za pomocą klawiatury.",
|
||
"help": "Obszary przewijane muszą być osiągalne z klawiatury."
|
||
},
|
||
"select-name": {
|
||
"description": "Element select ma dostępną nazwę.",
|
||
"help": "Element select musi mieć dostępną nazwę."
|
||
},
|
||
"server-side-image-map": {
|
||
"description": "Graficzne mapy odnośników (mapy obrazkowe) obsługiwane po stronie serwera nie są używane.",
|
||
"help": "Nie wolno używać map odnośników po stronie serwera."
|
||
},
|
||
"skip-link": {
|
||
"description": "Wszystkie łącza pomijania mają cel przyjmujący fokus.",
|
||
"help": "Cel łącza pomijającego powinien istnieć i przyjmować fokus."
|
||
},
|
||
"svg-img-alt": {
|
||
"description": "Elementy <svg> z rolą img, graphics-document lub graphics-symbol mają dostępny tekst.",
|
||
"help": "Elementy svg z rolą img muszą mieć tekst alternatywny."
|
||
},
|
||
"tabindex": {
|
||
"description": "Wartości atrybutów tabindex nie są większe niż 0.",
|
||
"help": "Elementy nie powinny mieć wartości tabindex większej niż zero."
|
||
},
|
||
"table-duplicate-name": {
|
||
"description": "Podpis tabeli (element <caption>) nie może zawierać takiego samego tekstu co atrybut summary.",
|
||
"help": "Atrybut summary w tabeli ma inny tekst niż element caption."
|
||
},
|
||
"table-fake-caption": {
|
||
"description": "Tabele używają jako podpisu elementu <caption>.",
|
||
"help": "Komórki danych i nagłówkowe w tabeli danych nie są używane do umieszczania podpisu tabeli."
|
||
},
|
||
"target-size": {
|
||
"description": "Sprawdź, czy cel dotykowy ma wystarczający rozmiar i przestrzeń wokół.",
|
||
"help": "Wszystkie cele dotykowe muszą mieć rozmiar 24px lub pozostawiać wystarczającą ilość miejsca wokół."
|
||
},
|
||
"td-has-header": {
|
||
"description": "Wszystkie niepuste komórki danych w tabelach danych większych niż 3 na 3 mają jeden lub więcej nagłówków tabeli.",
|
||
"help": "Każdy niepusty element <td> w dużej tabeli musi mieć powiązany nagłówek tabeli"
|
||
},
|
||
"td-headers-attr": {
|
||
"description": "Każda komórka tabeli używająca atrybutu headers odwołuje się do innej komórki w tej tabeli.",
|
||
"help": "Wszystkie komórki z atrybutem headers odnoszą się tylko do innych komórek tej samej tabeli."
|
||
},
|
||
"th-has-data-cells": {
|
||
"description": "Wszystkie elementy th i elementy z role=columnheader/rowheader mają komórki danych, które opisują.",
|
||
"help": "Każdy nagłówek tabeli w tabeli danych musi odnosić się do komórek danych."
|
||
},
|
||
"valid-lang": {
|
||
"description": "Atrybuty lang mają poprawne wartości.",
|
||
"help": "Atrybuty lang muszą mieć poprawną wartość."
|
||
},
|
||
"video-caption": {
|
||
"description": "Elementy <video> mają napisy rozszerzone.",
|
||
"help": "Elementy <video> muszą mieć napisy rozszerzone."
|
||
}
|
||
},
|
||
"checks": {
|
||
"abstractrole": {
|
||
"pass": "Role abstrakcyjne nie są wykorzystywane.",
|
||
"fail": {
|
||
"singular": "Rola abstrakcyjna nie może być użyta bezpośrednio: ${data.values}.",
|
||
"plural": ": Role abstrakcyjne nie mogą być używane bezpośrednio: ${data.values}."
|
||
}
|
||
},
|
||
"aria-allowed-attr": {
|
||
"pass": "Atrybuty ARIA są używane poprawnie dla zdefiniowanej roli.",
|
||
"fail": {
|
||
"singular": "Atrybut ARIA nie jest dozwolony: ${data.values}.",
|
||
"plural": ": Atrybuty ARIA nie są dozwolone: ${data.values}."
|
||
},
|
||
"incomplete": "Sprawdź, czy nie ma problemu, jeśli atrybut ARIA jest ignorowany w tym elemencie: ${data.values}"
|
||
},
|
||
"aria-allowed-role": {
|
||
"pass": "Rola ARIA jest dozwolona dla danego elementu.",
|
||
"fail": {
|
||
"singular": "Rola ARIA ${data.values} nie jest dozwolona dla tego elementu.",
|
||
"plural": ": Role ARIA ${data.values} nie są dozwolone dla tego elementu."
|
||
},
|
||
"incomplete": {
|
||
"singular": "Rola ARIA ${data.values} musi być usunięta, gdy element jest widoczny, ponieważ nie jest to dozwolone dla elementu.",
|
||
"plural": ": Role ARIA ${data.values} muszą być usunięte, gdy element jest widoczny, ponieważ nie są one dozwolone dla elementu."
|
||
}
|
||
},
|
||
"aria-busy": {
|
||
"pass": "Element ma atrybut aria-busy",
|
||
"fail": "Element używa aria-busy=\"true\" podczas pokazywania ładowania"
|
||
},
|
||
"aria-conditional-attr": {
|
||
"pass": "Atrybut ARIA jest dozwolony",
|
||
"fail": {
|
||
"checkbox": "Usuń aria-checked lub ustaw jego wartość na \"${data.checkState}\", aby dopasować ją do rzeczywistego stanu pola wyboru.",
|
||
"rowSingular": "Ten atrybut jest obsługiwany przez wiersze siatki, ale nie przez ${data.ownerRole}: ${data.invalidAttrs}",
|
||
"rowPlural": "Te atrybuty są obsługiwane przez wiersze siatki, ale nie przez ${data.ownerRole}: ${data.invalidAttrs}"
|
||
}
|
||
},
|
||
"aria-errormessage": {
|
||
"pass": "Istnieje aria-errormessage oraz elementy referencyjne widoczne dla czytników ekranowych, które wykorzystują wspieraną technikę aria-errormessage.",
|
||
"fail": {
|
||
"singular": "Wartość aria-errormessage ${data.values} musi używać techniki ogłoszenia wiadomości (np. aria-live, aria-describedby, role=alert, etc.).",
|
||
"plural": "Wartości aria-errormessage ${data.values} muszą używać techniki ogłoszenia wiadomości (np. aria-live, aria-describedby, role=alert, etc.).",
|
||
"hidden": "Wartość aria-errormessage ${data.values} nie może odwoływać się do ukrytego elementu."
|
||
},
|
||
"incomplete": {
|
||
"singular": "Upewnij się, że wartość aria-errormessage ${data.values} odnosi się do istniejącego elementu.",
|
||
"plural": "Upewnij się, że wartości aria-errormessage ${data.values} odnoszą się do istniejących elementów.",
|
||
"idrefs": "Nie można określić, czy na stronie istnieje element aria-errormessage: ${data.values}"
|
||
}
|
||
},
|
||
"aria-hidden-body": {
|
||
"pass": "Nie ma żadnego atrybutu aria-hidden w elemencie body dokumentu.",
|
||
"fail": "Atrybut aria-hidden=true nie może być użyty w elemencie body dokumentu."
|
||
},
|
||
"aria-level": {
|
||
"pass": "Wartość aria-level jest poprawna",
|
||
"incomplete": "Wartości aria-level większe niż 6 nie są obsługiwane we wszystkich kombinacjach czytników ekranu i przeglądarek"
|
||
},
|
||
"aria-prohibited-attr": {
|
||
"pass": "Atrybut ARIA jest dozwolony",
|
||
"fail": {
|
||
"hasRolePlural": "Atrybuty ${data.prohibited} nie mogą być używane z rolą \"${data.role}\".",
|
||
"hasRoleSingular": "Atrybut ${data.prohibited} nie może być użyty z rolą \"${data.role}\".",
|
||
"noRolePlural": "Atrybuty ${data.prohibited} nie mogą być używane w ${data.nodeName} bez poprawnego atrybutu roli.",
|
||
"noRoleSingular": "Atrybut ${data.prohibited} nie może być użyty w ${data.nodeName} bez poprawnego atrybutu roli."
|
||
},
|
||
"incomplete": {
|
||
"hasRoleSingular": "Atrybut ${data.prohibited} nie jest dobrze obsługiwany przez rolę \"${data.role}\".",
|
||
"hasRolePlural": "Atrybuty ${data.prohibited} nie są dobrze obsługiwane przez role \"${data.role}\".",
|
||
"noRoleSingular": "Atrybut ${data.prohibited} nie jest dobrze obsługiwany przez ${data.nodeName} bez poprawnego atrybutu roli.",
|
||
"noRolePlural": "Atrybuty ${data.prohibited} nie są dobrze obsługiwane przez ${data.nodeName} bez poprawnego atrybutu roli."
|
||
}
|
||
},
|
||
"aria-required-attr": {
|
||
"pass": "Wszystkie wymagane atrybuty ARIA istnieją.",
|
||
"fail": {
|
||
"singular": "Wymagany atrybut ARIA nie istnieje: ${data.values}.",
|
||
"plural": "Wymagane atrybuty ARIA nie istnieją: ${data.values}."
|
||
}
|
||
},
|
||
"aria-required-children": {
|
||
"pass": {
|
||
"default": "Wymagane dzieci ARIA istnieją."
|
||
},
|
||
"fail": {
|
||
"singular": "Wymagana rola dziecka ARIA nie istnieje: ${data.values}.",
|
||
"plural": "Wymagane role dzieci ARIA nie istnieją: ${data.values",
|
||
"unallowed": "Element ma dzieci, które nie są dozwolone: ${data.values}"
|
||
},
|
||
"incomplete": {
|
||
"singular": "Należy dodać oczekiwaną rolę dziecka ARIA: ${data.values}.",
|
||
"plural": "Należy dodać oczekiwane role dzieci ARIA: ${data.values}."
|
||
}
|
||
},
|
||
"aria-required-parent": {
|
||
"pass": "Wymagana rola rodzica ARIA istnieje.",
|
||
"fail": {
|
||
"singular": "Wymagana rola rodzica ARIA nie istnieje: ${data.values}.",
|
||
"plural": "Wymagane role rodziców ARIA nie istnieją: ${data.values}."
|
||
}
|
||
},
|
||
"aria-roledescription": {
|
||
"pass": "Atrybut aria-roledescription jest używany z obsługiwaną rolą semantyczną.",
|
||
"incomplete": "Sprawdź, czy aria-roledescription jest ogłaszany przez obsługiwane czytniki ekranu.",
|
||
"fail": "Nadaj temu elementowi rolę, która obsługuje aria-roledescription."
|
||
},
|
||
"aria-unsupported-attr": {
|
||
"pass": "Atrybut ARIA jest obsługiwany.",
|
||
"fail": "Atrybut ARIA nie jest dostatecznie obsługiwany przez czytniki ekranu i inne technologie wspomagające: ${data.values}."
|
||
},
|
||
"aria-valid-attr-value": {
|
||
"pass": "Wartości atrybutu ARIA są poprawne.",
|
||
"fail": {
|
||
"singular": "Niepoprawna wartość atrybutu ARIA: ${data.values}",
|
||
"plural": "Niepoprawne wartości atrybutu ARIA: ${data.values}"
|
||
},
|
||
"incomplete": {
|
||
"noId": "Identyfikator elementu atrybutu ARIA nie istnieje na stronie: ${data.needsReview}",
|
||
"noIdShadow": "ID elementu atrybutu ARIA nie istnieje na stronie lub jest potomkiem innego drzewa shadow DOM: ${data.needsReview}",
|
||
"ariaCurrent": "Wartość atrybutu ARIA jest niepoprawna i będzie traktowana jako \"aria-current=true\": ${data.needsReview}",
|
||
"idrefs": "Nie można określić, czy atrybut ARIA element ID istnieje na stronie: ${data.needsReview}",
|
||
"empty": "Wartość atrybutu ARIA jest ignorowana, gdy jest pusty: ${data.needsReview}"
|
||
}
|
||
},
|
||
"aria-valid-attr": {
|
||
"pass": "Nazwa atrybutu ARIA jest poprawna.",
|
||
"fail": {
|
||
"singular": "Niepoprawna nazwa atrybutu ARIA: ${data.values}.",
|
||
"plural": "Niepoprawne nazwy atrybutów ARIA: ${data.values}."
|
||
}
|
||
},
|
||
"braille-label-equivalent": {
|
||
"pass": "Atrybut aria-braillelabel jest użyty w elemencie z dostępnym tekstem.",
|
||
"fail": "Atrybut aria-braillelabel jest użyty w elemencie, który nie ma dostępnego tekstu.",
|
||
"incomplete": "Nie można wyliczyć dostępnego tekstu."
|
||
},
|
||
"braille-roledescription-equivalent": {
|
||
"pass": "Atrybut aria-brailleroledescription nie jest używany w elemencie, który nie ma dostępnego tekstu.",
|
||
"fail": {
|
||
"noRoleDescription": "Atrybut aria-brailleroledescription jest użyty w elemencie bez atrybutu aria-roledescription.",
|
||
"emptyRoleDescription": "Atrybut aria-brailleroledescription jest użyty w elemencie z pustym atrybutem aria-roledescription."
|
||
}
|
||
},
|
||
"deprecatedrole": {
|
||
"pass": "Rola ARIA nie jest przestarzała",
|
||
"fail": "Użyta rola jest przestarzała: ${data}"
|
||
},
|
||
"fallbackrole": {
|
||
"pass": "Użyto tylko jednej wartości roli.",
|
||
"fail": "Użyj tylko jednej wartości roli, ponieważ role rezerwowe nie są obsługiwane w starszych przeglądarkach.",
|
||
"incomplete": "Używaj tylko roli 'presentation' lub 'none', ponieważ są one synonimami."
|
||
},
|
||
"has-global-aria-attribute": {
|
||
"pass": {
|
||
"singular": "Element ma ogólny atrybut ARIA: ${data.values}.",
|
||
"plural": ": Element ma ogólne atrybuty ARIA: ${data.values}."
|
||
},
|
||
"fail": "Element nie ma ogólnego atrybutu ARIA"
|
||
},
|
||
"has-widget-role": {
|
||
"pass": "Element ma rolę widżetu.",
|
||
"fail": "Element nie ma roli widżetu."
|
||
},
|
||
"invalidrole": {
|
||
"pass": "Rola ARIA jest poprawna.",
|
||
"fail": {
|
||
"singular": "Rola musi być jedną z poprawnych ról ARIA: ${data.values}.",
|
||
"plural": ": Role muszą być jedną z poprawnych ról ARIA: ${data.values}."
|
||
}
|
||
},
|
||
"is-element-focusable": {
|
||
"pass": "Element przyjmuje fokus.",
|
||
"fail": "Element nie przyjmuje fokusu."
|
||
},
|
||
"no-implicit-explicit-label": {
|
||
"pass": "Nie ma rozbieżności między label a dostępną nazwą.",
|
||
"incomplete": "Sprawdź, czy label nie musi być częścią nazwy pola ARIA ${data}."
|
||
},
|
||
"unsupportedrole": {
|
||
"pass": "Rola ARIA jest obsługiwana.",
|
||
"fail": "Zastosowana rola nie jest szeroko obsługiwana w czytnikach ekranu i technologiach wspomagających: ${data.values}."
|
||
},
|
||
"valid-scrollable-semantics": {
|
||
"pass": "Element w porządku otrzymywania fokusu ma poprawną semantykę.",
|
||
"fail": "Element w porządku otrzymywania fokusu ma niepoprawną semantykę."
|
||
},
|
||
"color-contrast-enhanced": {
|
||
"pass": "Element ma wystarczający kontrast kolorów ${data.contrastRatio}",
|
||
"fail": {
|
||
"default": "Element ma niewystarczający kontrast kolorów ${data.contrastRatio} (kolor pierwszego planu: ${data.fgColor}, kolor tła: ${data.bgColor}, rozmiar czcionki: ${data.fontSize}, waga czcionki: ${data.fontWeight}). Oczekiwany współczynnik kontrastu: ${data.expectedContrastRatio}",
|
||
"fgOnShadowColor": "Element ma niewystarczający kontrast kolorów ${data.contrastRatio} pomiędzy kolorem pierwszego planu a kolorem cienia tekstu (kolor pierwszego planu: ${data.fgColor}, kolor cienia tekstu: ${data.shadowColor}, rozmiar czcionki: ${data.fontSize}, waga czcionki: ${data.fontWeight}). Oczekiwany współczynnik kontrastu: ${data.expectedContrastRatio}",
|
||
"shadowOnBgColor": "Element ma niewystarczający kontrast kolorów ${data.contrastRatio} pomiędzy kolorem cienia tekstu a kolorem tła (kolor cienia tekstu: ${data.shadowColor}, kolor tła: ${data.bgColor}, rozmiar czcionki: ${data.fontSize}, waga czcionki: ${data.fontWeight}). Oczekiwany współczynnik kontrastu: ${data.expectedContrastRatio}"
|
||
},
|
||
"incomplete": {
|
||
"default": "Nie można określić współczynnika kontrastu.",
|
||
"bgImage": "Nie można określić koloru tła elementu, ponieważ element ma obraz tła.",
|
||
"bgGradient": "Nie można określić koloru tła elementu, ponieważ element ma gradientowe tło.",
|
||
"imgNode": "Nie można określić koloru tła elementu, ponieważ element zawiera węzeł obrazu.",
|
||
"bgOverlap": "Nie można określić koloru tła elementu, ponieważ nakłada się na niego inny element.",
|
||
"fgAlpha": "Nie można określić koloru pierwszego planu elementu z powodu przezroczystości alfa.",
|
||
"elmPartiallyObscured": "Nie można określić koloru tła elementu, ponieważ jest on częściowo zasłonięty przez inny element.",
|
||
"elmPartiallyObscuring": "Nie można określić koloru tła elementu, ponieważ częściowo nakłada się on na inne elementy.",
|
||
"outsideViewport": "Nie można określić koloru tła elementu, ponieważ znajduje się on poza obszarem operacyjnym.",
|
||
"equalRatio": "Element ma współczynnik kontrastu 1:1 z tłem.",
|
||
"shortTextContent": "Treść elementu jest zbyt krótka, aby określić, czy jest to rzeczywista treść tekstowa.",
|
||
"nonBmp": "Treść elementu zawiera tylko znaki nietekstowe.",
|
||
"pseudoContent": "Nie można określić koloru tła elementu, ponieważ jest to pseudoelement."
|
||
}
|
||
},
|
||
"color-contrast": {
|
||
"pass": {
|
||
"default": "Element ma wystarczający kontrast kolorów ${data.contrastRatio}",
|
||
"hidden": "Element jest ukryty"
|
||
},
|
||
"fail": {
|
||
"default": "Element ma niewystarczający kontrast kolorów ${data.contrastRatio} (kolor pierwszego planu: ${data.fgColor}, kolor tła: ${data.bgColor}, rozmiar czcionki: ${data.fontSize}, waga czcionki: ${data.fontWeight}). Oczekiwany współczynnik kontrastu: ${data.expectedContrastRatio}",
|
||
"fgOnShadowColor": "Element ma niewystarczający kontrast kolorów ${data.contrastRatio} pomiędzy kolorem pierwszego planu a kolorem cienia tekstu (kolor pierwszego planu: ${data.fgColor}, kolor cienia tekstu: ${data.shadowColor}, rozmiar czcionki: ${data.fontSize}, waga czcionki: ${data.fontWeight}). Oczekiwany współczynnik kontrastu: ${data.expectedContrastRatio}",
|
||
"shadowOnBgColor": "Element ma niewystarczający kontrast kolorów ${data.contrastRatio} pomiędzy kolorem cienia tekstu a kolorem tła (kolor cienia tekstu: ${data.shadowColor}, kolor tła: ${data.bgColor}, rozmiar czcionki: ${data.fontSize}, waga czcionki: ${data.fontWeight}). Oczekiwany współczynnik kontrastu: ${data.expectedContrastRatio}"
|
||
},
|
||
"incomplete": {
|
||
"default": "Nie można określić współczynnika kontrastu.",
|
||
"bgImage": "Nie można określić koloru tła elementu, ponieważ element ma obraz tła.",
|
||
"bgGradient": "Nie można określić koloru tła elementu, ponieważ element ma gradientowe tło.",
|
||
"imgNode": "Nie można określić koloru tła elementu, ponieważ element zawiera węzeł obrazu.",
|
||
"bgOverlap": "Nie można określić koloru tła elementu, ponieważ nakłada się na niego inny element.",
|
||
"fgAlpha": "Nie można określić koloru pierwszego planu elementu z powodu przezroczystości alfa.",
|
||
"elmPartiallyObscured": "Nie można określić koloru tła elementu, ponieważ jest on częściowo zasłonięty przez inny element.",
|
||
"elmPartiallyObscuring": "Nie można określić koloru tła elementu, ponieważ częściowo nakłada się on na inne elementy.",
|
||
"outsideViewport": "Nie można określić koloru tła elementu, ponieważ znajduje się on poza obszarem operacyjnym.",
|
||
"equalRatio": "Element ma współczynnik kontrastu 1:1 z tłem.",
|
||
"shortTextContent": "Treść elementu jest zbyt krótka, aby określić, czy jest to rzeczywista treść tekstowa.",
|
||
"nonBmp": "Treść elementu zawiera tylko znaki nietekstowe.",
|
||
"pseudoContent": "Nie można określić koloru tła elementu, ponieważ jest to pseudoelement."
|
||
}
|
||
},
|
||
"link-in-text-block-style": {
|
||
"pass": "Łącza mogą być odróżnione od sąsiadującego tekstu poprzez wizualną stylizację",
|
||
"incomplete": {
|
||
"default": "Sprawdź, czy łącze wymaga stylizacji, aby odróżnić je od sąsiadującego tekstu.",
|
||
"pseudoContent": "Sprawdź, czy pseudostyl łącza jest wystarczający, aby odróżnić je od sąsiadującego tekstu."
|
||
},
|
||
"fail": "Łącze nie ma żadnej stylizacji (np. podkreślenia), która odróżniałaby je od sąsiadującego tekstu"
|
||
},
|
||
"link-in-text-block": {
|
||
"pass": "Łącza można odróżnić od sąsiadującego tekstu w inny sposób niż za pomocą koloru.",
|
||
"fail": {
|
||
"fgContrast": "Łącze ma niewystarczający kontrast kolorów ${data.contrastRatio}:1 z sąsiadującym tekstem. (Minimalny kontrast to: ${data.requiredContrastRatio}:1, kolor tekstu łącza: ${data.nodeColor}, kolor sąsiadującego tekstu: ${data.parentColor})",
|
||
"bgContrast": "Tło łącza ma niewystarczający kontrast kolorów ${data.contrastRatio} (Minimalny kontrast to: ${data.requiredContrastRatio}:1, kolor tła łącza: ${data.nodeBackgroundColor}, sąsiadujący kolor tła: ${data.parentBackgroundColor})"
|
||
},
|
||
"incomplete": {
|
||
"default": "Nie można określić współczynnika kontrastu.",
|
||
"bgContrast": "Nie można określić współczynnika kontrastu elementu. Sprawdź, czy nie ma odrębnego stylu stanów hover/fokus.",
|
||
"bgImage": "Nie można określić współczynnika kontrastu elementu ze względu na obraz tła.",
|
||
"bgGradient": "Nie można określić współczynnika kontrastu elementu ze względu na gradient tła.",
|
||
"imgNode": "Nie można określić współczynnika kontrastu elementu, ponieważ element zawiera węzeł obrazu.",
|
||
"bgOverlap": "Nie można określić współczynnika kontrastu elementu ze względu na nakładanie się elementów."
|
||
}
|
||
},
|
||
"autocomplete-appropriate": {
|
||
"pass": "Wartość autocomplete jest odpowiednia dla tego typu pola formularza.",
|
||
"fail": "Wartość autocomplete jest niewłaściwa dla tego typu pola formularza."
|
||
},
|
||
"autocomplete-valid": {
|
||
"pass": "Atrybut autocomplete jest sformatowany poprawnie.",
|
||
"fail": "Atrybut autocomplete jest sformatowany niepoprawnie."
|
||
},
|
||
"accesskeys": {
|
||
"pass": "Wartość atrybutu accesskey jest unikalna.",
|
||
"fail": "Dokument ma wiele elementów z tym samym klawiszem dostępu."
|
||
},
|
||
"focusable-content": {
|
||
"pass": "Element zawiera elementy przyjmujące fokus.",
|
||
"fail": "Element powinien przyjmować fokus."
|
||
},
|
||
"focusable-disabled": {
|
||
"pass": "W elemencie nie ma elementów przyjmujących fokus.",
|
||
"incomplete": "Sprawdź, czy elementy, na których można ustawić fokus, natychmiast otrzymują wskaźnik fokusu",
|
||
"fail": "Treść z możliwością ustawiania fokusu powinna być wyłączona lub usunięta z DOM."
|
||
},
|
||
"focusable-element": {
|
||
"pass": "Element może przyjmować fokus.",
|
||
"fail": "Element powinien przyjmować fokus."
|
||
},
|
||
"focusable-modal-open": {
|
||
"pass": "Nie ma elementów przyjmujących fokus, gdy otwarte jest okno modalne.",
|
||
"incomplete": "Sprawdź, czy elementy, które mogą przyjmować fokus, nie są tabulowane w aktualnym stanie."
|
||
},
|
||
"focusable-no-name": {
|
||
"pass": "Element nie znajduje się w porządku tabulacji lub ma dostępny tekst.",
|
||
"fail": "Element znajduje się w porządku tabulacji i nie ma dostępnego tekstu.",
|
||
"incomplete": "Nie można ustalić, czy element ma dostępną nazwę."
|
||
},
|
||
"focusable-not-tabbable": {
|
||
"pass": "Nie ma elementów przyjmujących fokus wewnątrz elementu.",
|
||
"incomplete": "Sprawdź, czy elementy, na których można ustawić fokus, natychmiast otrzymują wskaźnik fokusu",
|
||
"fail": "Treść przyjmująca fokus powinna mieć tabindex=-1 lub być usunięta z DOM."
|
||
},
|
||
"frame-focusable-content": {
|
||
"pass": "Element nie ma potomków przyjmujących fokus",
|
||
"fail": "Element ma elementy potomne przyjmujące fokus",
|
||
"incomplete": "Nie można ustalić, czy element ma elementy potomne"
|
||
},
|
||
"landmark-is-top-level": {
|
||
"pass": "Punkt orientacyjny ${data.role} jest na najwyższym poziomie.",
|
||
"fail": "Punkt orientacyjny {data.role} jest wewnątrz innego obszaru kluczowego."
|
||
},
|
||
"no-focusable-content": {
|
||
"pass": "Element nie ma potomków przyjmujących fokus",
|
||
"fail": {
|
||
"default": "Element ma elementy potomne przyjmujące fokus",
|
||
"notHidden": "Użycie ujemnej wartości tabindex elementu wewnątrz interaktywnej kontrolki nie zapobiega ustawianiu na elemencie fokusu przez technologie wspomagające (nawet z 'aria-hidden=true')"
|
||
},
|
||
"incomplete": "Nie można ustalić, czy element ma elementy potomne"
|
||
},
|
||
"page-has-heading-one": {
|
||
"pass": "Strona ma co najmniej jeden nagłówek 1. poziomu.",
|
||
"fail": "Strona musi mieć nagłówek 1. poziomu."
|
||
},
|
||
"page-has-main": {
|
||
"pass": "Dokument ma co najmniej jeden główny punkt orientacyjny.",
|
||
"fail": "Dokument nie ma głównego punktu orientacyjnego."
|
||
},
|
||
"page-no-duplicate-banner": {
|
||
"pass": "W dokumencie nie ma więcej niż jeden obszar kluczowy banner.",
|
||
"fail": "W dokumencie jest więcej niż jeden obszar kluczowy banner."
|
||
},
|
||
"page-no-duplicate-contentinfo": {
|
||
"pass": "W dokumencie nie ma więcej niż jeden obszar kluczowy contentinfo.",
|
||
"fail": "W dokumencie jest więcej niż jeden obszar kluczowy contentinfo."
|
||
},
|
||
"page-no-duplicate-main": {
|
||
"pass": "W dokumencie nie ma więcej niż jeden obszar kluczowy main.",
|
||
"fail": "W dokumencie jest więcej niż jeden obszar kluczowy main."
|
||
},
|
||
"tabindex": {
|
||
"pass": "Element nie ma wartości tabindex większej niż 0.",
|
||
"fail": "Element nie ma wartości tabindex większą od 0."
|
||
},
|
||
"alt-space-value": {
|
||
"pass": "Element ma poprawną wartość atrybutu alt.",
|
||
"fail": "Element ma atrybut alt zawierający tylko znak spacji, który nie przez wszystkie czytniki ekranu jest ignorowany ."
|
||
},
|
||
"duplicate-img-label": {
|
||
"pass": "Element nie powiela tekstu istniejącego w atrybucie alt elementu img.",
|
||
"fail": "Element powiela tekst istniejący w atrybucie alt elementu img."
|
||
},
|
||
"explicit-label": {
|
||
"pass": "Element formularza ma jawnie określoną label.",
|
||
"fail": "Element formularza nie ma jawnie określonej label.",
|
||
"incomplete": "Nie można określić, czy element formularza ma jawnie określoną label."
|
||
},
|
||
"help-same-as-label": {
|
||
"pass": "Tekst pomocy (title lub aria-describedby) nie powiela tekstu etykiety.",
|
||
"fail": "Tekst pomocy (title lub aria-describedby) jest taki sam jak tekst etykiety."
|
||
},
|
||
"hidden-explicit-label": {
|
||
"pass": "Element formularza ma widoczną jednoznaczną etykietę label.",
|
||
"fail": "Element formularza ma jednoznaczną etykietę label, która jest ukryta.",
|
||
"incomplete": "Nie można określić, czy element formularza ma jawną etykietę (label), gdy jest ukryta."
|
||
},
|
||
"implicit-label": {
|
||
"pass": "Element formularza ma dorozumianą etykietę (jest owinięty w label).",
|
||
"fail": "Element formularza nie ma dorozumianej etykiety (nie jest owinięty w label).",
|
||
"incomplete": "Nie można określić, czy element formularza ma dorozumianą etykietę (jest owinięty w label)."
|
||
},
|
||
"label-content-name-mismatch": {
|
||
"pass": "Widoczny tekst elementu jest częścią dostępnej nazwy elementu.",
|
||
"fail": "Widoczny tekst wewnątrz elementu nie jest częścią dostępnej nazwy."
|
||
},
|
||
"multiple-label": {
|
||
"pass": "Pole formularza nie ma wielu label.",
|
||
"incomplete": "Technologie wspomagające nie obsługują wystarczająco dobrze wielu elementów label. Upewnij się, że pierwsza etykieta zawiera wszystkie niezbędne informacje."
|
||
},
|
||
"title-only": {
|
||
"pass": "Element formularza nie używa wyłącznie atrybutu title jako swojej etykiety.",
|
||
"fail": "Tylko atrybut title jest używany do wygenerowania etykiety dla elementu formularza."
|
||
},
|
||
"landmark-is-unique": {
|
||
"pass": "Punkty orientacyjne muszą mieć unikalną kombinację roli lub roli etykiety i tytułu (tj. dostępną nazwę).",
|
||
"fail": "Punkt orientacyjny musi mieć unikalną aria-label, aria-labelledby lub title, aby był rozpoznawalny."
|
||
},
|
||
"has-lang": {
|
||
"pass": "Element <html> ma atrybut lang.",
|
||
"fail": {
|
||
"noXHTML": "Atrybut xml:lang nie jest poprawny na stronach HTML, użyj atrybutu lang.",
|
||
"noLang": "Element <html> nie ma atrybutu lang."
|
||
}
|
||
},
|
||
"valid-lang": {
|
||
"pass": "Wartość atrybutu lang jest na liście poprawnych kodów języków.",
|
||
"fail": "Wartości atrybutu lang nie ma na liście poprawnych kodów języków."
|
||
},
|
||
"xml-lang-mismatch": {
|
||
"pass": "Atrybuty lang i xml:lang mają ten sam język podstawowy.",
|
||
"fail": "Atrybuty lang i xml:lang nie mają tego samego języka podstawowego."
|
||
},
|
||
"dlitem": {
|
||
"pass": "Element listy opisowej ma element nadrzędny dl.",
|
||
"fail": "Pozycja listy opisowej nie ma elementu nadrzędnego dl."
|
||
},
|
||
"listitem": {
|
||
"pass": "Element listy ma ul, ol lub role=\"list\" jako bezpośredni element rodzicielski.",
|
||
"fail": {
|
||
"default": "Element listy nie ma nadrzędnego elementu ul lub ol.",
|
||
"roleNotValid": "Element listy nie ma nadrzędnego elementu ul, ol, ani nadrzędnego elementu z role=\"list\"."
|
||
}
|
||
},
|
||
"only-dlitems": {
|
||
"pass": "Element dl ma wewnątrz tylko dozwolone jako bezpośrednie elementy potomne (dzieci) elementy dt lub dd.",
|
||
"fail": "Element listy ma wewnątrz bezpośrednie elementy dzieci, które nie są dozwolone wewnątrz listy opisowej."
|
||
},
|
||
"only-listitems": {
|
||
"pass": "Element lista ma wewnątrz tylko dozwolone jako bezpośrednie elementy potomne (dzieci) elementy li.",
|
||
"fail": "Element listy ma bezpośrednie elementy potomne, które nie są dozwolone: ${data.values}"
|
||
},
|
||
"structured-dlitems": {
|
||
"pass": "Gdy elemet dl nie jest pusty, ma zarówno elementy dt, jak i dd.",
|
||
"fail": "Element nie jest pusty, ale nie ma co najmniej jednego elementu dt, po którym następuje co najmniej jeden element dd."
|
||
},
|
||
"caption": {
|
||
"pass": "Element multimedialny ma ścieżkę z napisami rozszerzonymi.",
|
||
"incomplete": "Sprawdź, czy istnieją napisy rozszerzone dla tego elementu."
|
||
},
|
||
"frame-tested": {
|
||
"pass": "Ramka iframe została przetestowana z axe-core.",
|
||
"fail": "Ramka iframe nie mogła być przetestowana z axe-core.",
|
||
"incomplete": "Nadal wymagane jest przetestowanie ramki iframe z axe-core."
|
||
},
|
||
"no-autoplay-audio": {
|
||
"pass": "Element <video> lub <audio> nie emituje dźwięku przez czas dłuższy niż dozwolony lub posiada mechanizm sterujący.",
|
||
"fail": "Element <video> lub <audio> emituje dźwięk przez czas dłuższy niż dozwolony i nie posiada mechanizmu sterowania.",
|
||
"incomplete": "Sprawdź, czy <video> lub <audio> nie emituje dźwięku dłuższej niż przez dozwolony czas lub czy ma mechanizm sterujący."
|
||
},
|
||
"css-orientation-lock": {
|
||
"pass": "Wyświetlacz działa sprawnie, orientacja nie jest blokowana.",
|
||
"fail": "Zastosowano blokadę orientacji wyświetlacza, w rezultacie wyświetlacz nie działa sprawnie.",
|
||
"incomplete": "Nie można blokować orientacji wyświetlacza za pomocą ustawień CSS."
|
||
},
|
||
"meta-viewport-large": {
|
||
"pass": "Znacznik <meta> nie ogranicza znacznego powiększenia na urządzeniach przenośnych.",
|
||
"fail": "Znacznik <meta> znacznik ogranicza powiększanie na urządzeniach przenośnych."
|
||
},
|
||
"meta-viewport": {
|
||
"pass": "Znacznik <meta> nie wyłącza powiększania na urządzeniach przenośnych.",
|
||
"fail": "${data} w znaczniku <meta> wyłącza powiększanie na urządzeniach przenośnych."
|
||
},
|
||
"target-offset": {
|
||
"pass": "Cel ma wystarczające odsunięcie od swojego najbliższego sąsiada: (${data.closestOffset}px, które powinno wynosić co najmniej ${data.minOffset}px)",
|
||
"fail": "Cel ma niewystarczające odsunięcie od najbliższego sąsiada: (${data.closestOffset}px, które powinno wynosić co najmniej ${data.minOffset}px)",
|
||
"incomplete": {
|
||
"default": "Element z ujemnym tabindeksem ma niewystarczające odsunięcie od najbliższego sąsiada: (${data.closestOffset}px, które powinno wynosić co najmniej${data.minOffset}px). Czy to jest cel?",
|
||
"nonTabbableNeighbor": "Cel ma niewystarczające odsunięcie od sąsiada z ujemnym tabindeksem: (${data.closestOffset}px, które powinno wynosić co najmniej ${data.minOffset}px). Czy sąsiad jest celem?"
|
||
}
|
||
},
|
||
"target-size": {
|
||
"pass": {
|
||
"default": "Kontrolka ma wystarczający rozmiar (${data.width}px na ${data.height}px, który powinnien wynosić co najmniej ${data.minSize}px na ${data.minSize}px)",
|
||
"obscured": "Kontrolka jest ignorowana, ponieważ jest całkowicie zasłonięta i nie można jej kliknąć."
|
||
},
|
||
"fail": {
|
||
"default": "Cel ma niewystarczający rozmiar (${data.width}px na ${data.height}px, który powinnien wynosić co najmniej ${data.minSize}px na ${data.minSize}px)",
|
||
"partiallyObscured": "Cel ma niewystarczający rozmiar, ponieważ jest częściowo przesłonięty (najmniejsza przestrzeń to ${data.width}px na ${data.height}px, powinna wynosić ${data.minSize}px na ${data.minSize}px)"
|
||
},
|
||
"incomplete": {
|
||
"default": "Element z ujemnym tabindex ma niewystarczający rozmiar (${data.width}px na ${data.height}px, powinnien wynosić co najmniej ${data.minSize}px na ${data.minSize}px). Czy to jest cel?",
|
||
"contentOverflow": "Rozmiar elementu nie mógł być dokładnie określony z powodu przepełnienia zawartości",
|
||
"partiallyObscured": "Element z ujemnym tabindex ma niewystarczający rozmiar, ponieważ jest częściowo przesłonięty (najmniejsza przestrzeń to ${data.width}px na ${data.height}px, powinna wynosić co najmniej ${data.minSize}px na ${data.minSize}px). Czy to jest cel?",
|
||
"partiallyObscuredNonTabbable": "Cel ma niewystarczający rozmiar, ponieważ jest częściowo przesłonięty przez sąsiada o ujemnym tabindeksie (najmniejsza przestrzeń to ${data.width}px na ${data.height}px, powinna wynosić co najmniej ${data.minSize}px na ${data.minSize}px). Czy sąsiad jest celem?"
|
||
}
|
||
},
|
||
"header-present": {
|
||
"pass": "Strona ma nagłówek.",
|
||
"fail": "Strona nie ma nagłówka."
|
||
},
|
||
"heading-order": {
|
||
"pass": "Kolejność nagłówków jest poprawna.",
|
||
"fail": "Kolejność nagłówków jest niepoprawna.",
|
||
"incomplete": "Nie można określić poprzedniego nagłówka"
|
||
},
|
||
"identical-links-same-purpose": {
|
||
"pass": "Nie ma żadnych innych łączy o tej samej nazwie, które kierują na inny adres URL.",
|
||
"incomplete": "Sprawdź, czy łącza mają ten sam cel lub są celowo niejednoznaczne."
|
||
},
|
||
"internal-link-present": {
|
||
"pass": "Znaleziono poprawne łącze pomijające.",
|
||
"fail": "Nie znaleziono poprawnych łączy pomijających."
|
||
},
|
||
"landmark": {
|
||
"pass": "Strona ma punkt orientacyjny (obszar kluczowy).",
|
||
"fail": "Strona nie ma żadnego punktu orientacyjnego (obszaru kluczowego)."
|
||
},
|
||
"meta-refresh-no-exceptions": {
|
||
"pass": "Znacznik <meta> nie powoduje natychmiastowego odświeżenia strony",
|
||
"fail": "Znacznik <meta> tag wymusza czasowe odświeżenie strony"
|
||
},
|
||
"meta-refresh": {
|
||
"pass": "Znacznik <meta> nie odświeża od razu strony.",
|
||
"fail": "Znacznik <meta> wymusza odświeżenie strony."
|
||
},
|
||
"p-as-heading": {
|
||
"pass": "Elementy <p> nie są stylizowane na nagłówki.",
|
||
"fail": "Zamiast stylizowanych na nagłówki elementów <p> muszą być użyte nagłówki semantyczne.",
|
||
"incomplete": "Nie można określić, czy elementy <p> są stylizowane na nagłówki"
|
||
},
|
||
"region": {
|
||
"pass": "Cała treść strony jest zawarta w obszarach kluczowych.",
|
||
"fail": "Pewna część strony znajduje się poza punktami orientacyjnymi."
|
||
},
|
||
"skip-link": {
|
||
"pass": "Cel łącza pomijajacego istnieje.",
|
||
"incomplete": "Cel łącza pomijania powinien być widoczny po aktywacji.",
|
||
"fail": "Nie istnieje cel łącza pomijającego."
|
||
},
|
||
"unique-frame-title": {
|
||
"pass": "Atrybut title elementu jest unikalny.",
|
||
"fail": "Atrybut title elementu nie jest unikalny."
|
||
},
|
||
"duplicate-id-active": {
|
||
"pass": "W dokumencie nie ma aktywnych elementów z takim samym atrybutem id.",
|
||
"fail": "W dokumencie są aktywne elementy z tą samą wartością atrybutu id: ${data}."
|
||
},
|
||
"duplicate-id-aria": {
|
||
"pass": "W dokumencie nie ma żadnych elementów, do których odwołuje się ARIA lub <label>, które mają ten sam atrybut id.",
|
||
"fail": "W dokumencie jest wiele elementów, do których odnosi się ARIA z tym samym atrybutem id: ${data}."
|
||
},
|
||
"duplicate-id": {
|
||
"pass": "W dokumencie nie ma wielu elementów statycznych z takim samym atrybutem id.",
|
||
"fail": "W dokumencie jest wiele elementów statycznych z takim samym atrybutem id: ${data}."
|
||
},
|
||
"aria-label": {
|
||
"pass": "Atrybut aria-label istnieje i nie jest pusty.",
|
||
"fail": "Atrybut aria-label nie istnieje lub jest pusty."
|
||
},
|
||
"aria-labelledby": {
|
||
"pass": "Atrybut aria-labelledby oraz elementy, do których się odwołuje, istnieją i są widoczne dla czytników ekranu.",
|
||
"fail": "Atrybut aria-labelledby nie istnieje albo elementy, do których odwołuje atrybut aria-labelledby, nie istnieją lub są puste.",
|
||
"incomplete": "Spowoduj, aby istniał element, do którego istnieje odwołanie w atrybucie aria-labelldeby."
|
||
},
|
||
"avoid-inline-spacing": {
|
||
"pass": "Nie określono żadnych stylów wewnętrznych (inline) z '!important', które wpływają na odstępy w tekście.",
|
||
"fail": {
|
||
"singular": "Usuń dyrektywę '!important' ze stylu inline ${data.values}, ponieważ nadpisywanie tego nie jest obsługiwane przez większość przeglądarek.",
|
||
"plural": "Usuń dyrektywy '!important' ze stylów inline ${data.values}, ponieważ nadpisywanie tego nie jest obsługiwane przez większość przeglądarek."
|
||
}
|
||
},
|
||
"button-has-visible-text": {
|
||
"pass": "Element ma tekst wewnętrzny widoczny dla czytników ekranu.",
|
||
"fail": "Element nie ma wewnętrznego tekstu, który jest widoczny dla czytników ekranu.",
|
||
"incomplete": "Nie można określić, czy element ma elementy potomne."
|
||
},
|
||
"doc-has-title": {
|
||
"pass": "Dokument ma niepusty element <title>.",
|
||
"fail": "Dokument nie ma niepustego elementu <title>."
|
||
},
|
||
"exists": {
|
||
"pass": "Element nie istnieje.",
|
||
"incomplete": "Element istnieje."
|
||
},
|
||
"has-alt": {
|
||
"pass": "Element ma atrybut alt.",
|
||
"fail": "Element nie ma atrybutu alt."
|
||
},
|
||
"has-visible-text": {
|
||
"pass": "Element ma tekst, który jest widoczny dla czytników ekranu.",
|
||
"fail": "Element nie ma tekstu, który jest widoczny dla czytników ekranu.",
|
||
"incomplete": "Nie można określić, czy element ma elementy dzieci."
|
||
},
|
||
"important-letter-spacing": {
|
||
"pass": "Odstępy między literami (letter-spacing) w atrybucie style nie są ustawione na !important lub spełniają minimum",
|
||
"fail": "Odstępy między literami w atrybucie style nie mogą używać !important lub muszą mieć ${data.minValue}em (aktualnie: ${data.value}em)"
|
||
},
|
||
"important-line-height": {
|
||
"pass": "Właściwość line-height w atrybucie style nie jest ustawiona na !important lub spełnia minimum.",
|
||
"fail": "Właściwość line-height w atrybucie style nie może używać !important lub musi mieć ${data.minValue}em (aktualnie: ${data.value}em)."
|
||
},
|
||
"important-word-spacing": {
|
||
"pass": "Odstępy miedzy wyrazami (word-spacing) w atrybucie style nie są ustawione na !important lub spełniają minimum",
|
||
"fail": "Odstępy miedzy wyrazami (word-spacing) w atrybucie style nie mogą używać !important lub muszą mieć ${data.minValue}em (aktualnie: ${data.value}em)"
|
||
},
|
||
"is-on-screen": {
|
||
"pass": "Element nie jest widoczny.",
|
||
"fail": "Element jest widoczny."
|
||
},
|
||
"non-empty-alt": {
|
||
"pass": "Element ma niepusty atrybut alt.",
|
||
"fail": {
|
||
"noAttr": "Element nie ma atrybutu alt.",
|
||
"emptyAttr": "Element ma pusty atrybut alt."
|
||
}
|
||
},
|
||
"non-empty-if-present": {
|
||
"pass": {
|
||
"default": "Element nie posiada atrybutu bez określonej wartości.",
|
||
"has-label": "Element ma atrybuty bez określonej wartości."
|
||
},
|
||
"fail": "Element ma atrybut wartości, a atrybut wartości jest pusty."
|
||
},
|
||
"non-empty-placeholder": {
|
||
"pass": "Element ma atrybut placeholder.",
|
||
"fail": {
|
||
"noAttr": "Element nie ma atrybutu placeholder.",
|
||
"emptyAttr": "Element ma pusty atrybut placeholder."
|
||
}
|
||
},
|
||
"non-empty-title": {
|
||
"pass": "Element ma atrybut title.",
|
||
"fail": {
|
||
"noAttr": "Element nie ma atrybutu title.",
|
||
"emptyAttr": "Element ma pusty atrybut title."
|
||
}
|
||
},
|
||
"non-empty-value": {
|
||
"pass": "Element ma atrybut z niepustą wartością.",
|
||
"fail": {
|
||
"noAttr": "Element nie ma atrybutu z wartością.",
|
||
"emptyAttr": "Element ma atrybut z pustą wartością."
|
||
}
|
||
},
|
||
"presentational-role": {
|
||
"pass": "Domyślna semantyka elementu została zastąpiona przez role=\"${data.role}\".",
|
||
"fail": {
|
||
"default": "Domyślna semantyka elementu nie została nadpisana przez role=\"none\" ani role=\"presentation\".",
|
||
"globalAria": "Rola elementu nie jest prezentacyjna, ponieważ ma on ogólny atrybut ARIA.",
|
||
"focusable": "Rola elementu nie jest prezentacyjna, ponieważ może on przyjmować fokus.",
|
||
"both": "Rola elementu nie jest prezentacyjna, ponieważ ma on ogólny atrybut ARIA i może przyjmować fokus.",
|
||
"iframe": "Użycie atrybutu \"title\" na elemencie ${data.nodeName} z rolą prezentacyjną zachowuje się niespójnie pomiędzy czytnikami ekranu."
|
||
}
|
||
},
|
||
"role-none": {
|
||
"pass": "Domyślna semantyka elementu została zastąpiona przez role=\"none\".",
|
||
"fail": "Domyślna semantyka elementu nie została nadpisana przez role=\"none\"."
|
||
},
|
||
"role-presentation": {
|
||
"pass": "Domyślna semantyka elementu została zastąpiona przez role=\"presentation\".",
|
||
"fail": "Domyślna semantyka elementu nie została nadpisana przez role=\"presentation\"."
|
||
},
|
||
"svg-non-empty-title": {
|
||
"pass": "Element ma dziecko, które jest tytułem.",
|
||
"fail": {
|
||
"noTitle": "Element nie ma dziecka, które jest tytułem.",
|
||
"emptyTitle": "Element title dziecka jest pusty."
|
||
},
|
||
"incomplete": "Nie można ustalić, czy element ma dziecko, które jest tytułem."
|
||
},
|
||
"caption-faked": {
|
||
"pass": "Pierwszy wiersz tabeli nie jest używany jako podpis.",
|
||
"fail": "Pierwszym elementem potomnym (dzieckiem) w tabeli powinien być caption zamiast komórki tabeli."
|
||
},
|
||
"html5-scope": {
|
||
"pass": "Atrybut scope jest używany tylko w elementach nagłówków tabeli (<th>).",
|
||
"fail": "W HTML 5, atrybuty scope mogą być używane tylko w elementach nagłówkowych tabeli (<th>)."
|
||
},
|
||
"same-caption-summary": {
|
||
"pass": "Treści atrybutu summary i elementu <caption> nie są powielane.",
|
||
"fail": "Treści atrybutu summary i elementu <caption> są identyczne.",
|
||
"incomplete": "Nie można określić, czy element <table> ma caption"
|
||
},
|
||
"scope-value": {
|
||
"pass": "Atrybut scope ma poprawną wartość.",
|
||
"fail": "Wartością atrybutu scope może być tylko 'row' lub 'col'."
|
||
},
|
||
"td-has-header": {
|
||
"pass": "Wszystkie niepuste komórki danych mają nagłówki tabeli.",
|
||
"fail": "Niektóre niepuste komórki danych nie mają nagłówków tabeli."
|
||
},
|
||
"td-headers-attr": {
|
||
"pass": "Atrybut headers jest używany wyłącznie w odniesieniu do innych komórek w tabeli.",
|
||
"incomplete": "Atrybut headers jest pusty.",
|
||
"fail": "Atrybut headers nie jest używany wyłącznie w odniesieniu do innych komórek w tabeli."
|
||
},
|
||
"th-has-data-cells": {
|
||
"pass": "Wszystkie komórki nagłówkowe tabeli odnoszą się do komórek danych.",
|
||
"fail": "Nie wszystkie komórki nagłówkowe tabeli odnoszą się do komórek danych.",
|
||
"incomplete": "Komórki danych tabeli są puste lub nie istnieją."
|
||
},
|
||
"hidden-content": {
|
||
"pass": "Wszystkie treści na stronie zostały przeanalizowane.",
|
||
"fail": "Były problemy z analizą treści na tej stronie.",
|
||
"incomplete": "Na tej stronie jest ukryta treść, która nie została przeanalizowana. Musisz uruchomić wyświetlanie tej treści, aby ją przeanalizować."
|
||
}
|
||
},
|
||
"failureSummaries": {
|
||
"any": {
|
||
"failureMessage": "Napraw następujące elementy: {{~it:value}}\n {{=value.split('\\n').join('\\n ')}}{{~}}"
|
||
},
|
||
"none": {
|
||
"failureMessage": "Napraw wszystkie poniższe: {{~it:value}}\n {{=value.split('\\n').join('\\n ')}}{{~}}"
|
||
}
|
||
},
|
||
"incompleteFallbackMessage": "AXE nie potrafił określić powodu. Czas użyć inspektora elementów!"
|
||
}
|