1128 lines
89 KiB
JSON
1128 lines
89 KiB
JSON
{
|
||
"lang": "ru",
|
||
"rules": {
|
||
"accesskeys": {
|
||
"description": "Убедитесь, что значение атрибута accesskey является уникальным",
|
||
"help": "Значение атрибута accesskey должно быть уникальным"
|
||
},
|
||
"area-alt": {
|
||
"description": "Убедитесь, что элементы <area> карт изображений имеют альтернативный текст",
|
||
"help": "Активные элементы <area> должны иметь альтернативный текст"
|
||
},
|
||
"aria-allowed-attr": {
|
||
"description": "Убедитесь, что роль элемента поддерживает его ARIA атрибуты",
|
||
"help": "Элементы должны использовать только поддерживаемые ARIA атрибуты"
|
||
},
|
||
"aria-allowed-role": {
|
||
"description": "Убедитесь, что атрибут role имеет допустимое значение для элемента",
|
||
"help": "ARIA роль должна быть подходящей для элемента"
|
||
},
|
||
"aria-braille-equivalent": {
|
||
"description": "Убедитесь, что aria-braillelabel и aria-brailleroledescription имеют эквивалентный текст не для шрифта Брайля",
|
||
"help": "Атрибуты aria-braille должны иметь эквивалентный текст не для шрифта Брайля"
|
||
},
|
||
"aria-command-name": {
|
||
"description": "Убедитесь, что каждая ARIA кнопка, ссылка и пункт меню имеет доступное имя",
|
||
"help": "ARIA команды должны иметь доступное имя"
|
||
},
|
||
"aria-conditional-attr": {
|
||
"description": "Убедитесь, что ARIA атрибуты используются в соответствии со спецификацией роли элемента",
|
||
"help": "ARIA атрибуты должны использоваться в соответствии с ролью элемента"
|
||
},
|
||
"aria-deprecated-role": {
|
||
"description": "Убедитесь, что элементы не используют устаревшие роли",
|
||
"help": "Устаревшие ARIA роли не должны использоваться"
|
||
},
|
||
"aria-dialog-name": {
|
||
"description": "Убедитесь, что каждая ARIA диалоговая форма и alertdialog узел имеют доступное имя",
|
||
"help": "ARIA диалоговые формы и alertdialog узлы должны иметь доступное имя"
|
||
},
|
||
"aria-hidden-body": {
|
||
"description": "Убедитесь, что aria-hidden=\"true\" отсутствует на теле документа.",
|
||
"help": "aria-hidden=\"true\" не должно присутствовать на теле документа"
|
||
},
|
||
"aria-hidden-focus": {
|
||
"description": "Убедитесь, что aria-hidden элементы не могут быть сфокусированы и не содержат фокусируемых элементов",
|
||
"help": "ARIA скрытые элементы не должны быть фокусируемыми или содержать фокусируемые элементы"
|
||
},
|
||
"aria-input-field-name": {
|
||
"description": "Убедитесь, что каждое ARIA поле ввода имеет доступное имя",
|
||
"help": "ARIA поля ввода должны иметь доступное имя"
|
||
},
|
||
"aria-meter-name": {
|
||
"description": "Убедитесь, что каждый ARIA meter узел имеет доступное имя",
|
||
"help": "ARIA meter узлы должны иметь доступное имя"
|
||
},
|
||
"aria-progressbar-name": {
|
||
"description": "Убедитесь, что каждый ARIA progressbar узел имеет доступное имя",
|
||
"help": "ARIA progressbar узлы должны иметь доступное имя"
|
||
},
|
||
"aria-prohibited-attr": {
|
||
"description": "Убедитесь, что ARIA атрибуты не запрещены для роли элемента",
|
||
"help": "Элементы должны использовать только разрешенные ARIA атрибуты"
|
||
},
|
||
"aria-required-attr": {
|
||
"description": "Убедитесь, что элементы с ARIA ролями имеют все необходимые ARIA атрибуты",
|
||
"help": "Необходимые ARIA атрибуты должны быть предоставлены"
|
||
},
|
||
"aria-required-children": {
|
||
"description": "Убедитесь, что элементы с ARIA ролями, требующими дочерние роли, содержат их",
|
||
"help": "Некоторые ARIA роли должны содержать определенные дочерние роли"
|
||
},
|
||
"aria-required-parent": {
|
||
"description": "Убедитесь, что элементы с ARIA ролями, требующими родительские роли, содержатся ими",
|
||
"help": "Некоторые ARIA роли должны содержаться в определенных родительских ролях"
|
||
},
|
||
"aria-roledescription": {
|
||
"description": "Убедитесь, что aria-roledescription используется только на элементах с явной или неявной ролью",
|
||
"help": "aria-roledescription должен использоваться на элементах с семантической ролью"
|
||
},
|
||
"aria-roles": {
|
||
"description": "Убедитесь, что все элементы с атрибутом role используют допустимое значение",
|
||
"help": "ARIA роли должны соответствовать допустимым значениям"
|
||
},
|
||
"aria-text": {
|
||
"description": "Убедитесь, что роль=\"text\" используется на элементах без фокусируемых потомков",
|
||
"help": "\"роль=text\" не должна иметь фокусируемых потомков"
|
||
},
|
||
"aria-toggle-field-name": {
|
||
"description": "Убедитесь, что каждое ARIA toggle поле имеет доступное имя",
|
||
"help": "ARIA toggle поля должны иметь доступное имя"
|
||
},
|
||
"aria-tooltip-name": {
|
||
"description": "Убедитесь, что каждый ARIA tooltip узел имеет доступное имя",
|
||
"help": "ARIA tooltip узлы должны иметь доступное имя"
|
||
},
|
||
"aria-treeitem-name": {
|
||
"description": "Убедитесь, что каждый ARIA treeitem узел имеет доступное имя",
|
||
"help": "ARIA treeitem узлы должны иметь доступное имя"
|
||
},
|
||
"aria-valid-attr-value": {
|
||
"description": "Убедитесь, что все ARIA атрибуты имеют допустимые значения",
|
||
"help": "ARIA атрибуты должны соответствовать допустимым значениям"
|
||
},
|
||
"aria-valid-attr": {
|
||
"description": "Убедитесь, что атрибуты, начинающиеся с aria-, являются допустимыми ARIA атрибутами",
|
||
"help": "ARIA атрибуты должны соответствовать допустимым именам"
|
||
},
|
||
"audio-caption": {
|
||
"description": "Убедитесь, что элементы <audio> имеют субтитры",
|
||
"help": "Элементы <audio> должны иметь трек субтитров"
|
||
},
|
||
"autocomplete-valid": {
|
||
"description": "Убедитесь, что атрибут autocomplete правильный и подходит для поля формы",
|
||
"help": "Атрибут autocomplete должен использоваться правильно"
|
||
},
|
||
"avoid-inline-spacing": {
|
||
"description": "Убедитесь, что расстояние между текстом, установленное через атрибуты стиля, можно настроить с помощью пользовательских таблиц стилей",
|
||
"help": "Встроенное текстовое пространство должно быть регулируемым с помощью пользовательских таблиц стилей"
|
||
},
|
||
"blink": {
|
||
"description": "Убедитесь, что элементы <blink> не используются",
|
||
"help": "Элементы <blink> устарели и не должны использоваться"
|
||
},
|
||
"button-name": {
|
||
"description": "Убедитесь, что кнопки имеют различимый текст",
|
||
"help": "Кнопки должны иметь различимый текст"
|
||
},
|
||
"bypass": {
|
||
"description": "Убедитесь, что на каждой странице есть хотя бы один механизм, позволяющий пользователю обходить навигацию и переходить непосредственно к содержимому",
|
||
"help": "На странице должен быть способ обойти повторяющиеся блоки"
|
||
},
|
||
"color-contrast-enhanced": {
|
||
"description": "Убедитесь, что контраст между цветами переднего и заднего плана соответствует пороговым значениям улучшенной контрастности WCAG 2 AAA",
|
||
"help": "Элементы должны соответствовать пороговым значениям улучшенной контрастности цвета"
|
||
},
|
||
"color-contrast": {
|
||
"description": "Убедитесь, что контраст между цветами переднего и заднего плана соответствует минимальным пороговым значениям контрастности WCAG 2 AA",
|
||
"help": "Элементы должны соответствовать минимальным пороговым значениям контрастности цвета"
|
||
},
|
||
"css-orientation-lock": {
|
||
"description": "Убедитесь, что содержимое не привязано к определенной ориентации дисплея, и оно доступно во всех ориентациях дисплея",
|
||
"help": "Медиа-запросы CSS не должны блокировать ориентацию дисплея"
|
||
},
|
||
"definition-list": {
|
||
"description": "Убедитесь, что элементы <dl> структурированы правильно",
|
||
"help": "Элементы <dl> должны содержать только группы <dt> и <dd>, <script>, <template> или <div> элементы"
|
||
},
|
||
"dlitem": {
|
||
"description": "Убедитесь, что элементы <dt> и <dd> находятся внутри <dl>",
|
||
"help": "Элементы <dt> и <dd> должны быть размещены внутри <dl>"
|
||
},
|
||
"document-title": {
|
||
"description": "Убедитесь, что каждый HTML-документ содержит непустой элемент <title>",
|
||
"help": "Документы должны иметь элемент <title> для навигации"
|
||
},
|
||
"duplicate-id-active": {
|
||
"description": "Убедитесь, что каждое значение атрибута id активных элементов уникально",
|
||
"help": "Идентификаторы активных элементов должны быть уникальными"
|
||
},
|
||
"duplicate-id-aria": {
|
||
"description": "Убедитесь, что каждое значение атрибута id, используемого в ARIA и метках, уникально",
|
||
"help": "Идентификаторы, используемые в ARIA и метках, должны быть уникальными"
|
||
},
|
||
"duplicate-id": {
|
||
"description": "Убедитесь, что каждое значение атрибута id уникально",
|
||
"help": "Значение атрибута id должно быть уникальным"
|
||
},
|
||
"empty-heading": {
|
||
"description": "Убедитесь, что заголовки содержат различимый текст",
|
||
"help": "Заголовки не должны быть пустыми"
|
||
},
|
||
"empty-table-header": {
|
||
"description": "Убедитесь, что заголовки таблиц содержат различимый текст",
|
||
"help": "Текст заголовка таблицы не должен быть пустым"
|
||
},
|
||
"focus-order-semantics": {
|
||
"description": "Убедитесь, что элементы в порядке фокуса имеют роль, соответствующую интерактивному содержимому",
|
||
"help": "Элементы в порядке фокуса должны иметь соответствующую роль"
|
||
},
|
||
"form-field-multiple-labels": {
|
||
"description": "Убедитесь, что поле формы не имеет нескольких элементов label",
|
||
"help": "Поле формы не должно иметь несколько элементов label"
|
||
},
|
||
"frame-focusable-content": {
|
||
"description": "Убедитесь, что элементы <frame> и <iframe> с фокусируемым содержимым не имеют tabindex=-1",
|
||
"help": "Фреймы с фокусируемым содержимым не должны иметь tabindex=-1"
|
||
},
|
||
"frame-tested": {
|
||
"description": "Убедитесь, что элементы <iframe> и <frame> содержат скрипт axe-core",
|
||
"help": "Фреймы должны быть протестированы с помощью axe-core"
|
||
},
|
||
"frame-title-unique": {
|
||
"description": "Убедитесь, что элементы <iframe> и <frame> содержат уникальный атрибут title",
|
||
"help": "Фреймы должны иметь уникальный атрибут title"
|
||
},
|
||
"frame-title": {
|
||
"description": "Убедитесь, что элементы <iframe> и <frame> имеют доступное имя",
|
||
"help": "Фреймы должны иметь доступное имя"
|
||
},
|
||
"heading-order": {
|
||
"description": "Убедитесь, что порядок заголовков соответствует семантической структуре",
|
||
"help": "Уровни заголовков должны увеличиваться на единицу"
|
||
},
|
||
"hidden-content": {
|
||
"description": "Информирует пользователей о скрытом содержимом.",
|
||
"help": "Скрытое содержимое на странице должно быть проанализировано"
|
||
},
|
||
"html-has-lang": {
|
||
"description": "Убедитесь, что каждый HTML-документ имеет атрибут lang",
|
||
"help": "Элемент <html> должен иметь атрибут lang"
|
||
},
|
||
"html-lang-valid": {
|
||
"description": "Убедитесь, что атрибут lang элемента <html> имеет допустимое значение",
|
||
"help": "Элемент <html> должен иметь допустимое значение для атрибута lang"
|
||
},
|
||
"html-xml-lang-mismatch": {
|
||
"description": "Убедитесь, что HTML элементы с атрибутами lang и xml:lang согласуются в базовом языке страницы",
|
||
"help": "HTML элементы с атрибутами lang и xml:lang должны согласоваться в базовом языке"
|
||
},
|
||
"identical-links-same-purpose": {
|
||
"description": "Убедитесь, что ссылки с одинаковым доступным именем выполняют схожую цель",
|
||
"help": "Ссылки с одинаковым именем должны выполнять схожую цель"
|
||
},
|
||
"image-alt": {
|
||
"description": "Убедитесь, что элементы <img> имеют альтернативный текст или роль \"none\" или \"presentation\"",
|
||
"help": "Изображения должны иметь альтернативный текст"
|
||
},
|
||
"image-redundant-alt": {
|
||
"description": "Убедитесь, что альтернативный текст изображения не повторяется в тексте",
|
||
"help": "Альтернативный текст изображения не должен повторяться в тексте"
|
||
},
|
||
"input-button-name": {
|
||
"description": "Убедитесь, что кнопки ввода имеют различимый текст",
|
||
"help": "Кнопки ввода должны иметь различимый текст"
|
||
},
|
||
"input-image-alt": {
|
||
"description": "Убедитесь, что элементы <input type=\"image\"> имеют альтернативный текст",
|
||
"help": "Кнопки изображения должны иметь альтернативный текст"
|
||
},
|
||
"label-content-name-mismatch": {
|
||
"description": "Убедитесь, что элементы, маркированные через их содержимое, содержат видимый текст как часть доступного имени",
|
||
"help": "Элементы должны содержать видимый текст как часть доступного имени"
|
||
},
|
||
"label-title-only": {
|
||
"description": "Убедитесь, что каждый элемент формы имеет видимую метку и не маркируется исключительно скрытыми метками, или атрибутами title или aria-describedby",
|
||
"help": "Элементы формы должны иметь видимую метку"
|
||
},
|
||
"label": {
|
||
"description": "Убедитесь, что каждый элемент формы имеет метку",
|
||
"help": "Элементы формы должны иметь метки"
|
||
},
|
||
"landmark-banner-is-top-level": {
|
||
"description": "Убедитесь, что область баннера находится на верхнем уровне",
|
||
"help": "Область баннера не должна быть вложена в другую область"
|
||
},
|
||
"landmark-complementary-is-top-level": {
|
||
"description": "Убедитесь, что дополнительная область или aside находятся на верхнем уровне",
|
||
"help": "Aside не должен быть вложен в другую область"
|
||
},
|
||
"landmark-contentinfo-is-top-level": {
|
||
"description": "Убедитесь, что область contentinfo находится на верхнем уровне",
|
||
"help": "Область contentinfo не должна быть вложена в другую область"
|
||
},
|
||
"landmark-main-is-top-level": {
|
||
"description": "Убедитесь, что область main находится на верхнем уровне",
|
||
"help": "Область main не должна быть вложена в другую область"
|
||
},
|
||
"landmark-no-duplicate-banner": {
|
||
"description": "Убедитесь, что документ содержит не более одного баннера",
|
||
"help": "Документ не должен содержать более одного баннера"
|
||
},
|
||
"landmark-no-duplicate-contentinfo": {
|
||
"description": "Убедитесь, что документ содержит не более одной области contentinfo",
|
||
"help": "Документ не должен содержать более одной области contentinfo"
|
||
},
|
||
"landmark-no-duplicate-main": {
|
||
"description": "Убедитесь, что документ содержит не более одной области main",
|
||
"help": "Документ не должен содержать более одной области main"
|
||
},
|
||
"landmark-one-main": {
|
||
"description": "Убедитесь, что документ содержит одну основную область",
|
||
"help": "Документ должен содержать одну основную область"
|
||
},
|
||
"landmark-unique": {
|
||
"description": "Убедитесь, что области уникальны",
|
||
"help": "Области должны иметь уникальную роль или комбинацию роли/метки/названия (т.е. доступное имя)"
|
||
},
|
||
"link-in-text-block": {
|
||
"description": "Убедитесь, что ссылки выделяются на фоне окружающего текста, не полагаясь только на цвет",
|
||
"help": "Ссылки должны быть различимы без использования цвета"
|
||
},
|
||
"link-name": {
|
||
"description": "Убедитесь, что ссылки содержат различимый текст",
|
||
"help": "Ссылки должны содержать различимый текст"
|
||
},
|
||
"list": {
|
||
"description": "Убедитесь, что списки структурированы правильно",
|
||
"help": "Элементы <ul> и <ol> должны содержать только элементы <li>, <script> или <template>"
|
||
},
|
||
"listitem": {
|
||
"description": "Убедитесь, что элементы <li> используются семантически правильно",
|
||
"help": "Элементы <li> должны быть вложены в <ul> или <ol>"
|
||
},
|
||
"marquee": {
|
||
"description": "Убедитесь, что элементы <marquee> не используются",
|
||
"help": "Элементы <marquee> устарели и не должны использоваться"
|
||
},
|
||
"meta-refresh-no-exceptions": {
|
||
"description": "Убедитесь, что <meta http-equiv=\"refresh\"> не используется для отложенного обновления",
|
||
"help": "Отложенное обновление не должно использоваться"
|
||
},
|
||
"meta-refresh": {
|
||
"description": "Убедитесь, что <meta http-equiv=\"refresh\"> не используется для отложенного обновления",
|
||
"help": "Отложенное обновление менее 20 часов не должно использоваться"
|
||
},
|
||
"meta-viewport-large": {
|
||
"description": "Убедитесь, что <meta name=\"viewport\"> позволяет значительное масштабирование",
|
||
"help": "Пользователи должны иметь возможность увеличивать и масштабировать текст до 500%"
|
||
},
|
||
"meta-viewport": {
|
||
"description": "Убедитесь, что <meta name=\"viewport\"> не отключает масштабирование и увеличение текста",
|
||
"help": "Масштабирование и увеличение текста не должны быть отключены"
|
||
},
|
||
"nested-interactive": {
|
||
"description": "Убедитесь, что интерактивные элементы не вложены, так как они могут не озвучиваться экранными считывателями или вызывать проблемы с фокусом для вспомогательных технологий",
|
||
"help": "Интерактивные элементы не должны быть вложены"
|
||
},
|
||
"no-autoplay-audio": {
|
||
"description": "Убедитесь, что элементы <video> или <audio> не воспроизводят аудио автоматически более 3 секунд без механизма для его остановки или отключения",
|
||
"help": "Элементы <video> или <audio> не должны воспроизводиться автоматически"
|
||
},
|
||
"object-alt": {
|
||
"description": "Убедитесь, что элементы <object> имеют альтернативный текст",
|
||
"help": "Элементы <object> должны иметь альтернативный текст"
|
||
},
|
||
"p-as-heading": {
|
||
"description": "Убедитесь, что текст, оформленный как жирный, курсивный или с измененным размером шрифта, не используется для оформления элементов <p> в качестве заголовков",
|
||
"help": "Оформленные элементы <p> не должны использоваться как заголовки"
|
||
},
|
||
"page-has-heading-one": {
|
||
"description": "Убедитесь, что страница или хотя бы один из ее фреймов содержит заголовок первого уровня",
|
||
"help": "Страница должна содержать заголовок первого уровня"
|
||
},
|
||
"presentation-role-conflict": {
|
||
"description": "Элементы, отмеченные как презентационные, не должны иметь глобальные ARIA атрибуты или tabindex, чтобы все экранные считыватели игнорировали их",
|
||
"help": "Убедитесь, что элементы, отмеченные как презентационные, последовательно игнорируются"
|
||
},
|
||
"region": {
|
||
"description": "Убедитесь, что все содержимое страницы заключено в ориентиры",
|
||
"help": "Все содержимое страницы должно быть заключено в ориентиры"
|
||
},
|
||
"role-img-alt": {
|
||
"description": "Убедитесь, что элементы с ролью [role=\"img\"] имеют альтернативный текст",
|
||
"help": "Элементы с ролью [role=\"img\"] должны иметь альтернативный текст"
|
||
},
|
||
"scope-attr-valid": {
|
||
"description": "Убедитесь, что атрибут scope используется правильно в таблицах",
|
||
"help": "Атрибут scope должен использоваться правильно"
|
||
},
|
||
"scrollable-region-focusable": {
|
||
"description": "Убедитесь, что элементы с прокручиваемым содержимым доступны с клавиатуры",
|
||
"help": "Прокручиваемая область должна быть доступна с клавиатуры"
|
||
},
|
||
"select-name": {
|
||
"description": "Убедитесь, что элемент select имеет доступное имя",
|
||
"help": "Элемент select должен иметь доступное имя"
|
||
},
|
||
"server-side-image-map": {
|
||
"description": "Убедитесь, что серверные карты изображений не используются",
|
||
"help": "Серверные карты изображений не должны использоваться"
|
||
},
|
||
"skip-link": {
|
||
"description": "Убедитесь, что все ссылки для пропуска имеют фокусируемую цель",
|
||
"help": "Цель ссылки для пропуска должна существовать и быть фокусируемой"
|
||
},
|
||
"summary-name": {
|
||
"description": "Убедитесь, что элементы summary содержат различимый текст",
|
||
"help": "Элементы summary должны содержать различимый текст"
|
||
},
|
||
"svg-img-alt": {
|
||
"description": "Убедитесь, что элементы <svg> с ролью img, graphics-document или graphics-symbol имеют доступный текст",
|
||
"help": "Элементы <svg> с ролью img должны иметь альтернативный текст"
|
||
},
|
||
"tabindex": {
|
||
"description": "Убедитесь, что значения атрибута tabindex не превышают 0",
|
||
"help": "Элементы не должны иметь tabindex больше нуля"
|
||
},
|
||
"table-duplicate-name": {
|
||
"description": "Убедитесь, что элемент <caption> не содержит тот же текст, что и атрибут summary",
|
||
"help": "Таблицы не должны иметь одинаковый summary и caption"
|
||
},
|
||
"table-fake-caption": {
|
||
"description": "Убедитесь, что таблицы с заголовком используют элемент <caption>",
|
||
"help": "Данные или заголовочные ячейки не должны использоваться для заголовка таблицы"
|
||
},
|
||
"target-size": {
|
||
"description": "Убедитесь, что целевые элементы для касания имеют достаточный размер и пространство",
|
||
"help": "Все целевые элементы для касания должны быть не менее 24px или иметь достаточное пространство"
|
||
},
|
||
"td-has-header": {
|
||
"description": "Убедитесь, что каждая непустая ячейка данных в таблице больше 3 на 3 имеет один или несколько заголовков таблицы",
|
||
"help": "Непустые элементы <td> в больших таблицах должны иметь связанные заголовки таблицы"
|
||
},
|
||
"td-headers-attr": {
|
||
"description": "Убедитесь, что каждая ячейка в таблице, использующая атрибут headers, ссылается только на другие элементы <th> в этой таблице",
|
||
"help": "Атрибуты headers ячеек таблицы должны ссылаться на другие элементы <th> в той же таблице"
|
||
},
|
||
"th-has-data-cells": {
|
||
"description": "Убедитесь, что элементы <th> и элементы с ролью columnheader/rowheader имеют ячейки данных, которые они описывают",
|
||
"help": "Заголовки таблицы в таблице данных должны ссылаться на ячейки данных"
|
||
},
|
||
"valid-lang": {
|
||
"description": "Убедитесь, что атрибуты lang имеют допустимые значения",
|
||
"help": "Атрибут lang должен иметь допустимое значение"
|
||
},
|
||
"video-caption": {
|
||
"description": "Убедитесь, что элементы <video> имеют субтитры",
|
||
"help": "Элементы <video> должны иметь субтитры"
|
||
}
|
||
},
|
||
"checks": {
|
||
"abstractrole": {
|
||
"pass": "Абстрактные роли не используются",
|
||
"fail": {
|
||
"singular": "Абстрактная роль не может быть использована напрямую: ${data.values}",
|
||
"plural": "Абстрактные роли не могут быть использованы напрямую: ${data.values}"
|
||
}
|
||
},
|
||
"aria-allowed-attr": {
|
||
"pass": "ARIA атрибуты используются правильно для заданной роли",
|
||
"fail": {
|
||
"singular": "ARIA атрибут не допускается: ${data.values}",
|
||
"plural": "ARIA атрибуты не допускаются: ${data.values}"
|
||
},
|
||
"incomplete": "Проверьте, не возникает ли проблема, если атрибут ARIA будет проигнорирован на этом элементе: ${data.values}"
|
||
},
|
||
"aria-allowed-role": {
|
||
"pass": "ARIA роль допустима для данного элемента",
|
||
"fail": {
|
||
"singular": "ARIA роль ${data.values} не допускается для данного элемента",
|
||
"plural": "ARIA роли ${data.values} не допускаются для данного элемента"
|
||
},
|
||
"incomplete": {
|
||
"singular": "ARIA роль ${data.values} должна быть удалена, когда элемент становится видимым, так как она не допускается для элемента",
|
||
"plural": "ARIA роли ${data.values} должны быть удалены, когда элемент становится видимым, так как они не допускаются для элемента"
|
||
}
|
||
},
|
||
"aria-busy": {
|
||
"pass": "Элемент имеет атрибут aria-busy",
|
||
"fail": "Элемент использует aria-busy=\"true\", пока отображается индикатор загрузки"
|
||
},
|
||
"aria-conditional-attr": {
|
||
"pass": "ARIA атрибут допустим",
|
||
"fail": {
|
||
"checkbox": "Удалите aria-checked или установите его значение в \"${data.checkState}\", чтобы оно соответствовало фактическому состоянию флажка",
|
||
"rowSingular": "Этот атрибут поддерживается для строк treegrid, но не для ${data.ownerRole}: ${data.invalidAttrs}",
|
||
"rowPlural": "Эти атрибуты поддерживаются для строк treegrid, но не для ${data.ownerRole}: ${data.invalidAttrs}"
|
||
}
|
||
},
|
||
"aria-errormessage": {
|
||
"pass": "aria-errormessage существует и ссылается на элементы, видимые для экранных считывателей, которые используют поддерживаемую технику aria-errormessage",
|
||
"fail": {
|
||
"singular": "Значение aria-errormessage `${data.values}` должно использовать технику для объявления сообщения (например, aria-live, aria-describedby, role=alert и т.д.)",
|
||
"plural": "Значения aria-errormessage `${data.values}` должны использовать технику для объявления сообщения (например, aria-live, aria-describedby, role=alert и т.д.)",
|
||
"hidden": "Значение aria-errormessage `${data.values}` не может ссылаться на скрытый элемент"
|
||
},
|
||
"incomplete": {
|
||
"singular": "Убедитесь, что значение aria-errormessage `${data.values}` ссылается на существующий элемент",
|
||
"plural": "Убедитесь, что значения aria-errormessage `${data.values}` ссылаются на существующие элементы",
|
||
"idrefs": "Невозможно определить, существует ли элемент aria-errormessage на странице: ${data.values}"
|
||
}
|
||
},
|
||
"aria-hidden-body": {
|
||
"pass": "Атрибут aria-hidden отсутствует на теле документа",
|
||
"fail": "aria-hidden=true не должно присутствовать на теле документа"
|
||
},
|
||
"aria-level": {
|
||
"pass": "Значения aria-level допустимы",
|
||
"incomplete": "Значения aria-level больше 6 не поддерживаются всеми комбинациями экранных считывателей и браузеров"
|
||
},
|
||
"aria-prohibited-attr": {
|
||
"pass": "ARIA атрибут допустим",
|
||
"fail": {
|
||
"hasRolePlural": "Атрибуты ${data.prohibited} не могут использоваться с ролью \"${data.role}\".",
|
||
"hasRoleSingular": "Атрибут ${data.prohibited} не может использоваться с ролью \"${data.role}\".",
|
||
"noRolePlural": "Атрибуты ${data.prohibited} не могут использоваться на ${data.nodeName} без допустимого атрибута role.",
|
||
"noRoleSingular": "Атрибут ${data.prohibited} не может использоваться на ${data.nodeName} без допустимого атрибута role."
|
||
},
|
||
"incomplete": {
|
||
"hasRoleSingular": "Атрибут ${data.prohibited} не поддерживается с ролью \"${data.role}\".",
|
||
"hasRolePlural": "Атрибуты ${data.prohibited} не поддерживаются с ролью \"${data.role}\".",
|
||
"noRoleSingular": "Атрибут ${data.prohibited} не поддерживается на ${data.nodeName} без допустимого атрибута role.",
|
||
"noRolePlural": "Атрибуты ${data.prohibited} не поддерживаются на ${data.nodeName} без допустимого атрибута role."
|
||
}
|
||
},
|
||
"aria-required-attr": {
|
||
"pass": "Все необходимые ARIA атрибуты присутствуют",
|
||
"fail": {
|
||
"singular": "Необходимый ARIA атрибут отсутствует: ${data.values}",
|
||
"plural": "Необходимые ARIA атрибуты отсутствуют: ${data.values}"
|
||
}
|
||
},
|
||
"aria-required-children": {
|
||
"pass": {
|
||
"default": "Необходимые ARIA дочерние элементы присутствуют",
|
||
"aria-busy": "Элемент имеет атрибут aria-busy, поэтому разрешено пропускать необходимые дочерние элементы"
|
||
},
|
||
"fail": {
|
||
"singular": "Необходимая ARIA дочерняя роль отсутствует: ${data.values}",
|
||
"plural": "Необходимые ARIA дочерние роли отсутствуют: ${data.values}",
|
||
"unallowed": "Элемент имеет недопустимые дочерние элементы: ${data.values}"
|
||
},
|
||
"incomplete": {
|
||
"singular": "Ожидается добавление ARIA дочерней роли: ${data.values}",
|
||
"plural": "Ожидается добавление ARIA дочерних ролей: ${data.values}"
|
||
}
|
||
},
|
||
"aria-required-parent": {
|
||
"pass": "Необходимая ARIA родительская роль присутствует",
|
||
"fail": {
|
||
"singular": "Необходимая ARIA родительская роль отсутствует: ${data.values}",
|
||
"plural": "Необходимые ARIA родительские роли отсутствуют: ${data.values}"
|
||
}
|
||
},
|
||
"aria-roledescription": {
|
||
"pass": "aria-roledescription используется на поддерживаемой семантической роли",
|
||
"incomplete": "Проверьте, объявляется ли aria-roledescription поддерживаемыми экранными считывателями",
|
||
"fail": "Назначьте элементу роль, поддерживающую aria-roledescription"
|
||
},
|
||
"aria-unsupported-attr": {
|
||
"pass": "ARIA атрибут поддерживается",
|
||
"fail": "ARIA атрибут не поддерживается в большинстве экранных считывателей и вспомогательных технологий: ${data.values}"
|
||
},
|
||
"aria-valid-attr-value": {
|
||
"pass": "Значения ARIA атрибутов допустимы",
|
||
"fail": {
|
||
"singular": "Недопустимое значение ARIA атрибута: ${data.values}",
|
||
"plural": "Недопустимые значения ARIA атрибутов: ${data.values}"
|
||
},
|
||
"incomplete": {
|
||
"noId": "Элемент ID атрибута ARIA не существует на странице: ${data.needsReview}",
|
||
"noIdShadow": "Элемент ID атрибута ARIA не существует на странице или является потомком другого дерева теневых DOM: ${data.needsReview}",
|
||
"ariaCurrent": "Значение атрибута ARIA недопустимо и будет трактоваться как \"aria-current=true\": ${data.needsReview}",
|
||
"idrefs": "Невозможно определить, существует ли элемент ID атрибута ARIA на странице: ${data.needsReview}",
|
||
"empty": "Значение атрибута ARIA игнорируется, если оно пустое: ${data.needsReview}",
|
||
"controlsWithinPopup": "Невозможно определить, существует ли ссылка на ID атрибута aria-controls на странице при использовании aria-haspopup: ${data.needsReview}"
|
||
}
|
||
},
|
||
"aria-valid-attr": {
|
||
"pass": "Имя ARIA атрибута допустимо",
|
||
"fail": {
|
||
"singular": "Недопустимое имя ARIA атрибута: ${data.values}",
|
||
"plural": "Недопустимые имена ARIA атрибутов: ${data.values}"
|
||
}
|
||
},
|
||
"braille-label-equivalent": {
|
||
"pass": "aria-braillelabel используется на элементе с доступным текстом",
|
||
"fail": "aria-braillelabel используется на элементе без доступного текста",
|
||
"incomplete": "Не удалось вычислить доступный текст"
|
||
},
|
||
"braille-roledescription-equivalent": {
|
||
"pass": "aria-brailleroledescription используется на элементе с aria-roledescription",
|
||
"fail": {
|
||
"noRoleDescription": "aria-brailleroledescription используется на элементе без aria-roledescription",
|
||
"emptyRoleDescription": "aria-brailleroledescription используется на элементе с пустым aria-roledescription"
|
||
}
|
||
},
|
||
"deprecatedrole": {
|
||
"pass": "ARIA роль не устарела",
|
||
"fail": "Используемая роль устарела: ${data}"
|
||
},
|
||
"fallbackrole": {
|
||
"pass": "Используется только одно значение роли",
|
||
"fail": "Используйте только одно значение роли, так как резервные роли не поддерживаются в старых браузерах",
|
||
"incomplete": "Используйте только роль 'presentation' или 'none', так как они являются синонимами."
|
||
},
|
||
"has-global-aria-attribute": {
|
||
"pass": {
|
||
"singular": "Элемент имеет глобальный ARIA атрибут: ${data.values}",
|
||
"plural": "Элемент имеет глобальные ARIA атрибуты: ${data.values}"
|
||
},
|
||
"fail": "Элемент не имеет глобального ARIA атрибута"
|
||
},
|
||
"has-widget-role": {
|
||
"pass": "Элемент имеет роль виджета.",
|
||
"fail": "Элемент не имеет роли виджета."
|
||
},
|
||
"invalidrole": {
|
||
"pass": "ARIA роль допустима",
|
||
"fail": {
|
||
"singular": "Роль должна быть одной из допустимых ARIA ролей: ${data.values}",
|
||
"plural": "Роли должны быть одной из допустимых ARIA ролей: ${data.values}"
|
||
}
|
||
},
|
||
"is-element-focusable": {
|
||
"pass": "Элемент может быть сфокусирован.",
|
||
"fail": "Элемент не может быть сфокусирован."
|
||
},
|
||
"no-implicit-explicit-label": {
|
||
"pass": "Нет несоответствия между <label> и доступным именем",
|
||
"incomplete": "Проверьте, нужно ли, чтобы <label> был частью имени поля ARIA ${data}"
|
||
},
|
||
"unsupportedrole": {
|
||
"pass": "ARIA роль поддерживается",
|
||
"fail": "Используемая роль не поддерживается большинством экранных считывателей и вспомогательных технологий: ${data}"
|
||
},
|
||
"valid-scrollable-semantics": {
|
||
"pass": "Элемент имеет допустимую семантику для элемента в порядке фокусировки.",
|
||
"fail": "Элемент имеет недопустимую семантику для элемента в порядке фокусировки."
|
||
},
|
||
"color-contrast-enhanced": {
|
||
"pass": "Элемент имеет достаточный цветовой контраст ${data.contrastRatio}",
|
||
"fail": {
|
||
"default": "Элемент имеет недостаточный цветовой контраст ${data.contrastRatio} (цвет переднего плана: ${data.fgColor}, цвет фона: ${data.bgColor}, размер шрифта: ${data.fontSize}, толщина шрифта: ${data.fontWeight}). Ожидаемый коэффициент контрастности ${data.expectedContrastRatio}",
|
||
"fgOnShadowColor": "Элемент имеет недостаточный цветовой контраст ${data.contrastRatio} между цветом переднего плана и тенью (цвет переднего плана: ${data.fgColor}, цвет текстовой тени: ${data.shadowColor}, размер шрифта: ${data.fontSize}, толщина шрифта: ${data.fontWeight}). Ожидаемый коэффициент контрастности ${data.expectedContrastRatio}",
|
||
"shadowOnBgColor": "Элемент имеет недостаточный цветовой контраст ${data.contrastRatio} между цветом тени и фоном (цвет текстовой тени: ${data.shadowColor}, цвет фона: ${data.bgColor}, размер шрифта: ${data.fontSize}, толщина шрифта: ${data.fontWeight}). Ожидаемый коэффициент контрастности ${data.expectedContrastRatio}"
|
||
},
|
||
"incomplete": {
|
||
"default": "Невозможно определить коэффициент контрастности",
|
||
"bgImage": "Невозможно определить цвет фона элемента из-за изображения на фоне",
|
||
"bgGradient": "Невозможно определить цвет фона элемента из-за градиента на фоне",
|
||
"imgNode": "Невозможно определить цвет фона элемента, так как он содержит изображение",
|
||
"bgOverlap": "Невозможно определить цвет фона элемента, так как он перекрыт другим элементом",
|
||
"fgAlpha": "Невозможно определить цвет переднего плана элемента из-за прозрачности альфа-канала",
|
||
"elmPartiallyObscured": "Невозможно определить цвет фона элемента, так как он частично перекрыт другим элементом",
|
||
"elmPartiallyObscuring": "Невозможно определить цвет фона элемента, так как он частично перекрывает другие элементы",
|
||
"outsideViewport": "Невозможно определить цвет фона элемента, так как он находится за пределами видимой области",
|
||
"equalRatio": "Элемент имеет коэффициент контрастности 1:1 с фоном",
|
||
"shortTextContent": "Содержимое элемента слишком короткое, чтобы определить, является ли оно текстом",
|
||
"nonBmp": "Содержимое элемента содержит только не текстовые символы",
|
||
"pseudoContent": "Невозможно определить цвет фона элемента из-за псевдоэлемента"
|
||
}
|
||
},
|
||
"color-contrast": {
|
||
"pass": {
|
||
"default": "Элемент имеет достаточный цветовой контраст ${data.contrastRatio}",
|
||
"hidden": "Элемент скрыт"
|
||
},
|
||
"fail": {
|
||
"default": "Элемент имеет недостаточный цветовой контраст ${data.contrastRatio} (цвет переднего плана: ${data.fgColor}, цвет фона: ${data.bgColor}, размер шрифта: ${data.fontSize}, толщина шрифта: ${data.fontWeight}). Ожидаемый коэффициент контрастности ${data.expectedContrastRatio}",
|
||
"fgOnShadowColor": "Элемент имеет недостаточный цветовой контраст ${data.contrastRatio} между цветом переднего плана и тенью (цвет переднего плана: ${data.fgColor}, цвет текстовой тени: ${data.shadowColor}, размер шрифта: ${data.fontSize}, толщина шрифта: ${data.fontWeight}). Ожидаемый коэффициент контрастности ${data.expectedContrastRatio}",
|
||
"shadowOnBgColor": "Элемент имеет недостаточный цветовой контраст ${data.contrastRatio} между цветом тени и фоном (цвет текстовой тени: ${data.shadowColor}, цвет фона: ${data.bgColor}, размер шрифта: ${data.fontSize}, толщина шрифта: ${data.fontWeight}). Ожидаемый коэффициент контрастности ${data.expectedContrastRatio}"
|
||
},
|
||
"incomplete": {
|
||
"default": "Невозможно определить коэффициент контрастности",
|
||
"bgImage": "Невозможно определить цвет фона элемента из-за изображения на фоне",
|
||
"bgGradient": "Невозможно определить цвет фона элемента из-за градиента на фоне",
|
||
"imgNode": "Невозможно определить цвет фона элемента, так как он содержит изображение",
|
||
"bgOverlap": "Невозможно определить цвет фона элемента, так как он перекрыт другим элементом",
|
||
"complexTextShadows": "Невозможно определить контрастность элемента из-за сложных теней текста",
|
||
"fgAlpha": "Невозможно определить цвет переднего плана элемента из-за прозрачности альфа-канала",
|
||
"elmPartiallyObscured": "Невозможно определить цвет фона элемента, так как он частично перекрыт другим элементом",
|
||
"elmPartiallyObscuring": "Невозможно определить цвет фона элемента, так как он частично перекрывает другие элементы",
|
||
"outsideViewport": "Невозможно определить цвет фона элемента, так как он находится за пределами видимой области",
|
||
"equalRatio": "Элемент имеет коэффициент контрастности 1:1 с фоном",
|
||
"shortTextContent": "Содержимое элемента слишком короткое, чтобы определить, является ли оно текстом",
|
||
"nonBmp": "Содержимое элемента содержит только не текстовые символы",
|
||
"pseudoContent": "Невозможно определить цвет фона элемента из-за псевдоэлемента"
|
||
}
|
||
},
|
||
"link-in-text-block-style": {
|
||
"pass": "Ссылки могут быть выделены среди окружающего текста с помощью визуального стиля",
|
||
"incomplete": {
|
||
"default": "Проверьте, нужно ли оформлять ссылку, чтобы отличить её от окружающего текста",
|
||
"pseudoContent": "Проверьте, достаточно ли псевдо-стиля ссылки, чтобы отличить её от окружающего текста"
|
||
},
|
||
"fail": "Ссылка не имеет стиля (например, подчеркивания), чтобы отличить её от окружающего текста"
|
||
},
|
||
"link-in-text-block": {
|
||
"pass": "Ссылки можно отличить от окружающего текста каким-либо способом, кроме цвета",
|
||
"fail": {
|
||
"fgContrast": "У ссылки недостаточный цветовой контраст ${data.contrastRatio}:1 с окружающим текстом. (Минимальный контраст ${data.requiredContrastRatio}:1, текст ссылки: ${data.nodeColor}, окружающий текст: ${data.parentColor})",
|
||
"bgContrast": "Фон ссылки имеет недостаточный цветовой контраст ${data.contrastRatio} (Минимальный контраст ${data.requiredContrastRatio}:1, цвет фона ссылки: ${data.nodeBackgroundColor}, цвет фона окружающего текста: ${data.parentBackgroundColor})"
|
||
},
|
||
"incomplete": {
|
||
"default": "Невозможно определить контрастность переднего плана элемента",
|
||
"bgContrast": "Невозможно определить контрастность фона элемента",
|
||
"bgImage": "Невозможно определить контрастность элемента из-за изображения на фоне",
|
||
"bgGradient": "Невозможно определить контрастность элемента из-за градиента на фоне",
|
||
"imgNode": "Невозможно определить контрастность элемента, так как он содержит изображение",
|
||
"bgOverlap": "Невозможно определить контрастность элемента, так как он перекрыт другим элементом"
|
||
}
|
||
},
|
||
"autocomplete-appropriate": {
|
||
"pass": "Значение autocomplete подходит для данного элемента",
|
||
"fail": "Значение autocomplete не подходит для этого типа ввода"
|
||
},
|
||
"autocomplete-valid": {
|
||
"pass": "Атрибут autocomplete правильно отформатирован",
|
||
"fail": "Атрибут autocomplete неправильно отформатирован",
|
||
"incomplete": "Атрибут autocomplete имеет нестандартное значение. Проверьте, можно ли использовать вместо него какое-либо стандартное значение."
|
||
},
|
||
"accesskeys": {
|
||
"pass": "Значение атрибута accesskey уникально",
|
||
"fail": "Документ содержит несколько элементов с одинаковым значением accesskey"
|
||
},
|
||
"focusable-content": {
|
||
"pass": "Элемент содержит фокусируемые элементы",
|
||
"fail": "Элемент должен содержать фокусируемое содержимое"
|
||
},
|
||
"focusable-disabled": {
|
||
"pass": "Внутри элемента нет фокусируемых элементов",
|
||
"incomplete": "Проверьте, немедленно ли индикатор фокуса перемещается на фокусируемые элементы",
|
||
"fail": "Фокусируемое содержимое должно быть отключено или удалено из DOM"
|
||
},
|
||
"focusable-element": {
|
||
"pass": "Элемент является фокусируемым",
|
||
"fail": "Элемент должен быть фокусируемым"
|
||
},
|
||
"focusable-modal-open": {
|
||
"pass": "Нет фокусируемых элементов при открытии модального окна",
|
||
"incomplete": "Проверьте, что фокусируемые элементы не являются доступными в текущем состоянии"
|
||
},
|
||
"focusable-no-name": {
|
||
"pass": "Элемент не находится в таб-ордре или имеет доступный текст",
|
||
"fail": "Элемент находится в таб-ордре и не имеет доступного текста",
|
||
"incomplete": "Невозможно определить, есть ли у элемента доступное имя"
|
||
},
|
||
"focusable-not-tabbable": {
|
||
"pass": "Внутри элемента нет фокусируемых элементов",
|
||
"incomplete": "Проверьте, немедленно ли индикатор фокуса перемещается на фокусируемые элементы",
|
||
"fail": "Фокусируемое содержимое должно иметь tabindex=\"-1\" или быть удалено из DOM"
|
||
},
|
||
"frame-focusable-content": {
|
||
"pass": "Элемент не имеет фокусируемых потомков",
|
||
"fail": "Элемент имеет фокусируемых потомков",
|
||
"incomplete": "Невозможно определить, есть ли у элемента потомки"
|
||
},
|
||
"landmark-is-top-level": {
|
||
"pass": "${data.role} область находится на верхнем уровне.",
|
||
"fail": "${data.role} область содержится в другой области."
|
||
},
|
||
"no-focusable-content": {
|
||
"pass": "Элемент не имеет фокусируемых потомков",
|
||
"fail": {
|
||
"default": "Элемент имеет фокусируемых потомков",
|
||
"notHidden": "Использование отрицательного tabindex на элементе внутри интерактивного управления не предотвращает фокусировку элемента вспомогательными технологиями (даже с aria-hidden=\"true\")"
|
||
},
|
||
"incomplete": "Невозможно определить, есть ли у элемента потомки"
|
||
},
|
||
"page-has-heading-one": {
|
||
"pass": "На странице есть хотя бы один заголовок первого уровня",
|
||
"fail": "На странице должен быть заголовок первого уровня"
|
||
},
|
||
"page-has-main": {
|
||
"pass": "В документе есть хотя бы одна основная область",
|
||
"fail": "В документе нет основной области"
|
||
},
|
||
"page-no-duplicate-banner": {
|
||
"pass": "В документе нет более одного баннера",
|
||
"fail": "В документе более одного баннера"
|
||
},
|
||
"page-no-duplicate-contentinfo": {
|
||
"pass": "В документе нет более одной области contentinfo",
|
||
"fail": "В документе более одной области contentinfo"
|
||
},
|
||
"page-no-duplicate-main": {
|
||
"pass": "В документе нет более одной основной области",
|
||
"fail": "В документе более одной основной области"
|
||
},
|
||
"tabindex": {
|
||
"pass": "Элемент не имеет tabindex больше 0",
|
||
"fail": "Элемент имеет tabindex больше 0"
|
||
},
|
||
"alt-space-value": {
|
||
"pass": "Элемент имеет допустимое значение атрибута alt",
|
||
"fail": "Элемент имеет атрибут alt, содержащий только пробельный символ, который не игнорируется всеми экранными считывателями"
|
||
},
|
||
"duplicate-img-label": {
|
||
"pass": "Элемент не дублирует существующий текст в тексте атрибута alt <img>",
|
||
"fail": "Элемент содержит <img> с текстом атрибута alt, дублирующим существующий текст"
|
||
},
|
||
"explicit-label": {
|
||
"pass": "Элемент формы имеет явную <label>",
|
||
"fail": "Элемент формы не имеет явной <label>",
|
||
"incomplete": "Невозможно определить, имеет ли элемент формы явную <label>"
|
||
},
|
||
"help-same-as-label": {
|
||
"pass": "Текст помощи (title или aria-describedby) не дублирует текст метки",
|
||
"fail": "Текст помощи (title или aria-describedby) совпадает с текстом метки"
|
||
},
|
||
"hidden-explicit-label": {
|
||
"pass": "Элемент формы имеет видимую явную <label>",
|
||
"fail": "Элемент формы имеет явную <label>, которая скрыта",
|
||
"incomplete": "Невозможно определить, имеет ли элемент формы явную <label>, которая скрыта"
|
||
},
|
||
"implicit-label": {
|
||
"pass": "Элемент формы имеет неявную (обернутую) <label>",
|
||
"fail": "Элемент формы не имеет неявной (обернутой) <label>",
|
||
"incomplete": "Невозможно определить, имеет ли элемент формы неявную (обернутую) <label>"
|
||
},
|
||
"label-content-name-mismatch": {
|
||
"pass": "Элемент содержит видимый текст как часть его доступного имени",
|
||
"fail": "Текст внутри элемента не включен в доступное имя"
|
||
},
|
||
"multiple-label": {
|
||
"pass": "Поле формы не имеет нескольких элементов label",
|
||
"incomplete": "Использование нескольких элементов label не поддерживается большинством вспомогательных технологий. Убедитесь, что первый элемент label содержит всю необходимую информацию."
|
||
},
|
||
"title-only": {
|
||
"pass": "Элемент формы не использует только атрибут title для своей метки",
|
||
"fail": "Для создания метки элемента формы используется только атрибут title"
|
||
},
|
||
"landmark-is-unique": {
|
||
"pass": "Ориентиры должны иметь уникальную роль или комбинацию роли/метки/названия (т.е. доступное имя)",
|
||
"fail": "Ориентир должен иметь уникальный aria-label, aria-labelledby или title, чтобы сделать ориентиры различимыми"
|
||
},
|
||
"has-lang": {
|
||
"pass": "Элемент <html> имеет атрибут lang",
|
||
"fail": {
|
||
"noXHTML": "Атрибут xml:lang недействителен на HTML страницах, используйте атрибут lang.",
|
||
"noLang": "Элемент <html> не имеет атрибута lang"
|
||
}
|
||
},
|
||
"valid-lang": {
|
||
"pass": "Значение атрибута lang включено в список допустимых языков",
|
||
"fail": "Значение атрибута lang не включено в список допустимых языков"
|
||
},
|
||
"xml-lang-mismatch": {
|
||
"pass": "Атрибуты lang и xml:lang имеют один и тот же базовый язык",
|
||
"fail": "Атрибуты lang и xml:lang не имеют один и тот же базовый язык"
|
||
},
|
||
"dlitem": {
|
||
"pass": "Элемент описания списка имеет родительский элемент <dl>",
|
||
"fail": "Элемент описания списка не имеет родительского элемента <dl>"
|
||
},
|
||
"listitem": {
|
||
"pass": "Элемент списка имеет родительский элемент <ul>, <ol> или роль=\"list\"",
|
||
"fail": {
|
||
"default": "Элемент списка не имеет родительского элемента <ul>, <ol>",
|
||
"roleNotValid": "Родительский элемент списка имеет роль, которая не является ролью=\"list\""
|
||
}
|
||
},
|
||
"only-dlitems": {
|
||
"pass": "Элемент dl содержит только допустимые дочерние элементы; <dt>, <dd> или <div> элементы",
|
||
"fail": "Элемент dl содержит недопустимые дочерние элементы: ${data.values}"
|
||
},
|
||
"only-listitems": {
|
||
"pass": "Элемент списка содержит только допустимые дочерние элементы <li>",
|
||
"fail": "Элемент списка содержит недопустимые дочерние элементы: ${data.values}"
|
||
},
|
||
"structured-dlitems": {
|
||
"pass": "Когда элемент не пустой, он имеет как минимум один элемент <dt> и один элемент <dd>",
|
||
"fail": "Когда элемент не пустой, он не содержит по крайней мере одного элемента <dt>, за которым следует по крайней мере один элемент <dd>"
|
||
},
|
||
"caption": {
|
||
"pass": "Мультимедийный элемент имеет дорожку субтитров",
|
||
"incomplete": "Проверьте, доступны ли субтитры для элемента"
|
||
},
|
||
"frame-tested": {
|
||
"pass": "Элемент iframe был протестирован с помощью axe-core",
|
||
"fail": "Не удалось протестировать элемент iframe с помощью axe-core",
|
||
"incomplete": "Элемент iframe все еще должен быть протестирован с помощью axe-core"
|
||
},
|
||
"no-autoplay-audio": {
|
||
"pass": "<video> или <audio> не воспроизводит аудио более допустимой продолжительности или имеет механизмы управления",
|
||
"fail": "<video> или <audio> воспроизводит аудио более допустимой продолжительности и не имеет механизмов управления",
|
||
"incomplete": "Проверьте, не воспроизводит ли <video> или <audio> аудио более допустимой продолжительности или предоставляет ли механизмы управления"
|
||
},
|
||
"css-orientation-lock": {
|
||
"pass": "Дисплей работает, блокировка ориентации отсутствует",
|
||
"fail": "CSS блокировка ориентации применяется и делает дисплей неработоспособным",
|
||
"incomplete": "Невозможно определить, применяется ли CSS блокировка ориентации"
|
||
},
|
||
"meta-viewport-large": {
|
||
"pass": "Тег <meta> не предотвращает значительное масштабирование на мобильных устройствах",
|
||
"fail": "Тег <meta> ограничивает масштабирование на мобильных устройствах"
|
||
},
|
||
"meta-viewport": {
|
||
"pass": "Тег <meta> не отключает масштабирование на мобильных устройствах",
|
||
"fail": "${data} на теге <meta> отключает масштабирование на мобильных устройствах"
|
||
},
|
||
"target-offset": {
|
||
"pass": {
|
||
"default": "Целевой элемент имеет достаточное пространство от ближайших соседей. Безопасное кликабельное пространство имеет диаметр ${data.closestOffset}px, что не менее ${data.minOffset}px.",
|
||
"large": "Целевой элемент значительно превышает минимальный размер в ${data.minOffset}px."
|
||
},
|
||
"fail": "Целевой элемент имеет недостаточное пространство до ближайших соседей. Безопасное кликабельное пространство имеет диаметр ${data.closestOffset}px вместо как минимум ${data.minOffset}px.",
|
||
"incomplete": {
|
||
"default": "Элемент с отрицательным tabindex имеет недостаточное пространство до ближайших соседей. Безопасное кликабельное пространство имеет диаметр ${data.closestOffset}px вместо как минимум ${data.minOffset}px. Является ли это целевым элементом?",
|
||
"nonTabbableNeighbor": "Целевой элемент имеет недостаточное пространство до ближайших соседей. Безопасное кликабельное пространство имеет диаметр ${data.closestOffset}px вместо как минимум ${data.minOffset}px. Является ли сосед целевым элементом?",
|
||
"tooManyRects": "Не удалось определить размер целевого элемента из-за слишком большого количества перекрывающихся элементов"
|
||
}
|
||
},
|
||
"target-size": {
|
||
"pass": {
|
||
"default": "Контрол имеет достаточный размер (${data.width}px на ${data.height}px, должно быть как минимум ${data.minSize}px на ${data.minSize}px)",
|
||
"obscured": "Контрол игнорируется, так как он полностью скрыт и, следовательно, не кликабелен",
|
||
"large": "Целевой элемент значительно превышает минимальный размер в ${data.minSize}px."
|
||
},
|
||
"fail": {
|
||
"default": "Целевой элемент имеет недостаточный размер (${data.width}px на ${data.height}px, должно быть как минимум ${data.minSize}px на ${data.minSize}px)",
|
||
"partiallyObscured": "Целевой элемент имеет недостаточный размер, так как он частично скрыт (наименьшее пространство ${data.width}px на ${data.height}px, должно быть как минимум ${data.minSize}px на ${data.minSize}px)"
|
||
},
|
||
"incomplete": {
|
||
"default": "Элемент с отрицательным tabindex имеет недостаточный размер (${data.width}px на ${data.height}px, должно быть как минимум ${data.minSize}px на ${data.minSize}px). Является ли это целевым элементом?",
|
||
"contentOverflow": "Размер элемента не может быть точно определен из-за переполненного содержимого",
|
||
"partiallyObscured": "Элемент с отрицательным tabindex имеет недостаточный размер, так как он частично скрыт (наименьшее пространство ${data.width}px на ${data.height}px, должно быть как минимум ${data.minSize}px на ${data.minSize}px). Является ли это целевым элементом?",
|
||
"partiallyObscuredNonTabbable": "Целевой элемент имеет недостаточный размер, так как он частично скрыт соседом с отрицательным tabindex (наименьшее пространство ${data.width}px на ${data.height}px, должно быть как минимум ${data.minSize}px на ${data.minSize}px). Является ли сосед целевым элементом?",
|
||
"tooManyRects": "Не удалось определить размер целевого элемента из-за слишком большого количества перекрывающихся элементов"
|
||
}
|
||
},
|
||
"header-present": {
|
||
"pass": "На странице есть заголовок",
|
||
"fail": "На странице нет заголовка"
|
||
},
|
||
"heading-order": {
|
||
"pass": "Порядок заголовков корректен",
|
||
"fail": "Порядок заголовков некорректен",
|
||
"incomplete": "Невозможно определить предыдущий заголовок"
|
||
},
|
||
"identical-links-same-purpose": {
|
||
"pass": "Нет других ссылок с тем же именем, которые ведут на другой URL",
|
||
"incomplete": "Проверьте, имеют ли ссылки одинаковую цель, или они намеренно неоднозначны."
|
||
},
|
||
"internal-link-present": {
|
||
"pass": "Найдена допустимая ссылка для пропуска",
|
||
"fail": "Допустимая ссылка для пропуска не найдена"
|
||
},
|
||
"landmark": {
|
||
"pass": "На странице есть область-ориентир",
|
||
"fail": "На странице нет области-ориентира"
|
||
},
|
||
"meta-refresh-no-exceptions": {
|
||
"pass": "Тег <meta> не вызывает немедленное обновление страницы",
|
||
"fail": "Тег <meta> вызывает обновление страницы по таймеру"
|
||
},
|
||
"meta-refresh": {
|
||
"pass": "Тег <meta> не вызывает немедленное обновление страницы",
|
||
"fail": "Тег <meta> вызывает обновление страницы по таймеру (менее 20 часов)"
|
||
},
|
||
"p-as-heading": {
|
||
"pass": "Элементы <p> не оформлены как заголовки",
|
||
"fail": "Для заголовков должны использоваться элементы <h1> - <h6>, а не стилизованные <p>",
|
||
"incomplete": "Невозможно определить, оформлены ли элементы <p> как заголовки"
|
||
},
|
||
"region": {
|
||
"pass": "Все содержимое страницы заключено в ориентиры",
|
||
"fail": "Некоторое содержимое страницы не заключено в ориентиры"
|
||
},
|
||
"skip-link": {
|
||
"pass": "Целевая ссылка для пропуска существует",
|
||
"incomplete": "Целевая ссылка для пропуска должна стать видимой при активации",
|
||
"fail": "Целевая ссылка для пропуска не найдена"
|
||
},
|
||
"unique-frame-title": {
|
||
"pass": "Атрибут title элемента является уникальным",
|
||
"fail": "Атрибут title элемента не является уникальным"
|
||
},
|
||
"duplicate-id-active": {
|
||
"pass": "Документ не содержит активных элементов с одинаковым значением id атрибута",
|
||
"fail": "Документ содержит активные элементы с одинаковым значением id атрибута: ${data}"
|
||
},
|
||
"duplicate-id-aria": {
|
||
"pass": "Документ не содержит элементов, ссылающихся на ARIA или метки с одинаковым значением id атрибута",
|
||
"fail": "Документ содержит несколько элементов, ссылающихся на ARIA, с одинаковым значением id атрибута: ${data}"
|
||
},
|
||
"duplicate-id": {
|
||
"pass": "Документ не содержит статических элементов с одинаковым значением id атрибута",
|
||
"fail": "Документ содержит несколько статических элементов с одинаковым значением id атрибута: ${data}"
|
||
},
|
||
"aria-label": {
|
||
"pass": "Атрибут aria-label существует и не пуст",
|
||
"fail": "Атрибут aria-label не существует или пуст"
|
||
},
|
||
"aria-labelledby": {
|
||
"pass": "Атрибут aria-labelledby существует и ссылается на элементы, видимые для экранных считывателей",
|
||
"fail": "Атрибут aria-labelledby не существует, ссылается на несуществующие элементы или ссылается на пустые элементы",
|
||
"incomplete": "Убедитесь, что aria-labelledby ссылается на существующий элемент"
|
||
},
|
||
"avoid-inline-spacing": {
|
||
"pass": "Внутренние стили с '!important', которые влияют на интервал текста, не указаны",
|
||
"fail": {
|
||
"singular": "Удалите '!important' из внутреннего стиля ${data.values}, так как переопределение этого стиля не поддерживается большинством браузеров",
|
||
"plural": "Удалите '!important' из внутренних стилей ${data.values}, так как переопределение этих стилей не поддерживается большинством браузеров"
|
||
}
|
||
},
|
||
"button-has-visible-text": {
|
||
"pass": "Элемент содержит внутренний текст, видимый для экранных считывателей",
|
||
"fail": "Элемент не содержит внутренний текст, видимый для экранных считывателей",
|
||
"incomplete": "Невозможно определить, есть ли у элемента дочерние элементы"
|
||
},
|
||
"doc-has-title": {
|
||
"pass": "Документ содержит непустой элемент <title>",
|
||
"fail": "Документ не содержит непустой элемент <title>"
|
||
},
|
||
"exists": {
|
||
"pass": "Элемент не существует",
|
||
"incomplete": "Элемент существует"
|
||
},
|
||
"has-alt": {
|
||
"pass": "Элемент имеет атрибут alt",
|
||
"fail": "Элемент не имеет атрибута alt"
|
||
},
|
||
"has-visible-text": {
|
||
"pass": "Элемент содержит текст, видимый для экранных считывателей",
|
||
"fail": "Элемент не содержит текст, видимый для экранных считывателей",
|
||
"incomplete": "Невозможно определить, есть ли у элемента дочерние элементы"
|
||
},
|
||
"important-letter-spacing": {
|
||
"pass": "Letter-spacing в атрибуте стиля не установлен на !important, либо соответствует минимальному значению",
|
||
"fail": "Letter-spacing в атрибуте стиля не должен использовать !important, или должен быть не менее ${data.minValue}em (текущее значение ${data.value}em)"
|
||
},
|
||
"important-line-height": {
|
||
"pass": "Line-height в атрибуте стиля не установлен на !important, либо соответствует минимальному значению",
|
||
"fail": "Line-height в атрибуте стиля не должен использовать !important, или должен быть не менее ${data.minValue}em (текущее значение ${data.value}em)"
|
||
},
|
||
"important-word-spacing": {
|
||
"pass": "Word-spacing в атрибуте стиля не установлен на !important, либо соответствует минимальному значению",
|
||
"fail": "Word-spacing в атрибуте стиля не должен использовать !important, или должен быть не менее ${data.minValue}em (текущее значение ${data.value}em)"
|
||
},
|
||
"is-on-screen": {
|
||
"pass": "Элемент не виден",
|
||
"fail": "Элемент виден"
|
||
},
|
||
"non-empty-alt": {
|
||
"pass": "Элемент имеет непустой атрибут alt",
|
||
"fail": {
|
||
"noAttr": "Элемент не имеет атрибута alt",
|
||
"emptyAttr": "Элемент имеет пустой атрибут alt"
|
||
}
|
||
},
|
||
"non-empty-if-present": {
|
||
"pass": {
|
||
"default": "Элемент не имеет атрибута value",
|
||
"has-label": "Элемент имеет непустой атрибут value"
|
||
},
|
||
"fail": "Элемент имеет атрибут value, и этот атрибут пуст"
|
||
},
|
||
"non-empty-placeholder": {
|
||
"pass": "Элемент имеет атрибут placeholder",
|
||
"fail": {
|
||
"noAttr": "Элемент не имеет атрибута placeholder",
|
||
"emptyAttr": "Элемент имеет пустой атрибут placeholder"
|
||
}
|
||
},
|
||
"non-empty-title": {
|
||
"pass": "Элемент имеет атрибут title",
|
||
"fail": {
|
||
"noAttr": "Элемент не имеет атрибута title",
|
||
"emptyAttr": "Элемент имеет пустой атрибут title"
|
||
}
|
||
},
|
||
"non-empty-value": {
|
||
"pass": "Элемент имеет непустой атрибут value",
|
||
"fail": {
|
||
"noAttr": "Элемент не имеет атрибута value",
|
||
"emptyAttr": "Элемент имеет пустой атрибут value"
|
||
}
|
||
},
|
||
"presentational-role": {
|
||
"pass": "Стандартная семантика элемента была переопределена с помощью role=\"${data.role}\"",
|
||
"fail": {
|
||
"default": "Стандартная семантика элемента не была переопределена с помощью role=\"none\" или role=\"presentation\"",
|
||
"globalAria": "Роль элемента не является презентационной, так как у него есть глобальный ARIA атрибут",
|
||
"focusable": "Роль элемента не является презентационной, так как он может быть сфокусирован",
|
||
"both": "Роль элемента не является презентационной, так как у него есть глобальный ARIA атрибут и он может быть сфокусирован",
|
||
"iframe": "Использование атрибута \"title\" на элементе ${data.nodeName} с презентационной ролью ведет себя непоследовательно между экранными считывателями"
|
||
}
|
||
},
|
||
"role-none": {
|
||
"pass": "Стандартная семантика элемента была переопределена с помощью role=\"none\"",
|
||
"fail": "Стандартная семантика элемента не была переопределена с помощью role=\"none\""
|
||
},
|
||
"role-presentation": {
|
||
"pass": "Стандартная семантика элемента была переопределена с помощью role=\"presentation\"",
|
||
"fail": "Стандартная семантика элемента не была переопределена с помощью role=\"presentation\""
|
||
},
|
||
"svg-non-empty-title": {
|
||
"pass": "Элемент имеет дочерний элемент title",
|
||
"fail": {
|
||
"noTitle": "Элемент не имеет дочернего элемента title",
|
||
"emptyTitle": "Дочерний элемент title пуст"
|
||
},
|
||
"incomplete": "Невозможно определить, имеет ли элемент дочерний элемент title"
|
||
},
|
||
"caption-faked": {
|
||
"pass": "Первая строка таблицы не используется в качестве заголовка",
|
||
"fail": "Первый дочерний элемент таблицы должен быть заголовком, а не ячейкой таблицы"
|
||
},
|
||
"html5-scope": {
|
||
"pass": "Атрибут scope используется только для элементов заголовков таблицы (<th>)",
|
||
"fail": "В HTML 5 атрибуты scope могут использоваться только для элементов заголовков таблицы (<th>)"
|
||
},
|
||
"same-caption-summary": {
|
||
"pass": "Содержимое атрибута summary и элемента <caption> не дублируется",
|
||
"fail": "Содержимое атрибута summary и элемента <caption> идентично",
|
||
"incomplete": "Невозможно определить, есть ли у элемента <table> заголовок"
|
||
},
|
||
"scope-value": {
|
||
"pass": "Атрибут scope используется правильно",
|
||
"fail": "Значение атрибута scope может быть только 'row' или 'col'"
|
||
},
|
||
"td-has-header": {
|
||
"pass": "Все непустые ячейки данных имеют заголовки таблицы",
|
||
"fail": "Некоторые непустые ячейки данных не имеют заголовков таблицы"
|
||
},
|
||
"td-headers-attr": {
|
||
"pass": "Атрибут headers используется исключительно для ссылки на другие ячейки таблицы",
|
||
"incomplete": "Атрибут headers пуст",
|
||
"fail": {
|
||
"cell-header-not-in-table": "Атрибут headers не используется исключительно для ссылки на другие заголовочные ячейки в таблице",
|
||
"cell-header-not-th": "Атрибут headers должен ссылаться на заголовочные ячейки, а не на ячейки с данными",
|
||
"header-refs-self": "Элемент с атрибутом headers ссылается на самого себя"
|
||
}
|
||
},
|
||
"th-has-data-cells": {
|
||
"pass": "Все ячейки заголовков таблицы ссылаются на ячейки данных",
|
||
"fail": "Не все ячейки заголовков таблицы ссылаются на ячейки данных",
|
||
"incomplete": "Ячейки данных таблицы отсутствуют или пусты"
|
||
},
|
||
"hidden-content": {
|
||
"pass": "Все содержимое страницы было проанализировано.",
|
||
"fail": "Возникли проблемы с анализом содержимого на этой странице.",
|
||
"incomplete": "На странице есть скрытое содержимое, которое не было проанализировано. Вам нужно будет включить отображение этого содержимого, чтобы его проанализировать."
|
||
}
|
||
},
|
||
"failureSummaries": {
|
||
"any": {
|
||
"failureMessage": "Исправьте любое из следующего:{{~it:value}}\n {{=value.split('\\n').join('\\n ')}}{{~}}"
|
||
},
|
||
"none": {
|
||
"failureMessage": "Исправьте все из следующего:{{~it:value}}\n {{=value.split('\\n').join('\\n ')}}{{~}}"
|
||
}
|
||
},
|
||
"incompleteFallbackMessage": "axe не смог определить причину. Время использовать инспектор элементов!"
|
||
}
|