ship-gis/node_modules/axe-core/locales/ru.json

1128 lines
89 KiB
JSON
Raw Normal View 히스토리

2026-01-22 09:14:01 +09:00
{
"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 не смог определить причину. Время использовать инспектор элементов!"
}