govuk_publishing_components 30.4.1 → 30.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/javascripts/govuk_publishing_components/analytics-ga4/ga4-event-tracker.js +63 -51
- data/app/assets/javascripts/govuk_publishing_components/analytics-ga4/ga4-link-tracker.js +8 -8
- data/app/assets/javascripts/govuk_publishing_components/analytics-ga4/ga4-page-views.js +11 -10
- data/app/assets/javascripts/govuk_publishing_components/analytics-ga4/init-ga4.js +26 -0
- data/app/assets/javascripts/govuk_publishing_components/analytics-ga4.js +1 -3
- data/app/assets/stylesheets/govuk_publishing_components/components/_organisation-logo.scss +2 -4
- data/app/views/govuk_publishing_components/component_guide/show.html.erb +28 -27
- data/lib/govuk_publishing_components/version.rb +1 -1
- data/node_modules/axe-core/README.md +83 -53
- data/node_modules/axe-core/axe.d.ts +403 -224
- data/node_modules/axe-core/axe.js +23281 -21919
- data/node_modules/axe-core/axe.min.js +3 -3
- data/node_modules/axe-core/locales/da.json +795 -780
- data/node_modules/axe-core/locales/de.json +932 -621
- data/node_modules/axe-core/locales/es.json +786 -771
- data/node_modules/axe-core/locales/eu.json +787 -0
- data/node_modules/axe-core/locales/fr.json +982 -840
- data/node_modules/axe-core/locales/ja.json +988 -880
- data/node_modules/axe-core/locales/ko.json +999 -775
- data/node_modules/axe-core/locales/nl.json +46 -34
- data/node_modules/axe-core/locales/pl.json +965 -0
- data/node_modules/axe-core/locales/pt_BR.json +966 -880
- data/node_modules/axe-core/package.json +189 -145
- data/node_modules/axe-core/sri-history.json +312 -192
- data/node_modules/govuk-frontend/govuk/all.js +64 -44
- data/node_modules/govuk-frontend/govuk/components/accordion/_index.scss +1 -1
- data/node_modules/govuk-frontend/govuk/components/accordion/accordion.js +3 -13
- data/node_modules/govuk-frontend/govuk/components/accordion/fixtures.json +12 -12
- data/node_modules/govuk-frontend/govuk/components/accordion/template.njk +5 -1
- data/node_modules/govuk-frontend/govuk/components/character-count/fixtures.json +1 -1
- data/node_modules/govuk-frontend/govuk/components/details/details.js +8 -20
- data/node_modules/govuk-frontend/govuk/components/details/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/details/template.njk +1 -1
- data/node_modules/govuk-frontend/govuk/components/error-message/fixtures.json +9 -0
- data/node_modules/govuk-frontend/govuk/components/error-summary/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/error-summary/template.njk +2 -2
- data/node_modules/govuk-frontend/govuk/components/footer/fixtures.json +59 -20
- data/node_modules/govuk-frontend/govuk/components/footer/macro-options.json +40 -0
- data/node_modules/govuk-frontend/govuk/components/footer/template.njk +17 -7
- data/node_modules/govuk-frontend/govuk/components/header/_index.scss +14 -21
- data/node_modules/govuk-frontend/govuk/components/header/fixtures.json +11 -11
- data/node_modules/govuk-frontend/govuk/components/header/header.js +53 -11
- data/node_modules/govuk-frontend/govuk/components/header/macro-options.json +2 -2
- data/node_modules/govuk-frontend/govuk/components/header/template.njk +1 -1
- data/node_modules/govuk-frontend/govuk/components/input/_index.scss +9 -10
- data/node_modules/govuk-frontend/govuk/components/inset-text/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/inset-text/template.njk +1 -1
- data/node_modules/govuk-frontend/govuk/components/notification-banner/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/notification-banner/template.njk +2 -2
- data/node_modules/govuk-frontend/govuk/components/panel/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/panel/template.njk +2 -2
- data/node_modules/govuk-frontend/govuk/components/select/_index.scss +6 -0
- data/node_modules/govuk-frontend/govuk/components/select/fixtures.json +15 -1
- data/node_modules/govuk-frontend/govuk/components/summary-list/_index.scss +37 -10
- data/node_modules/govuk-frontend/govuk/components/summary-list/fixtures.json +69 -4
- data/node_modules/govuk-frontend/govuk/components/summary-list/template.njk +3 -3
- data/node_modules/govuk-frontend/govuk/components/tabs/fixtures.json +13 -13
- data/node_modules/govuk-frontend/govuk/components/tabs/template.njk +5 -1
- data/node_modules/govuk-frontend/govuk/helpers/_typography.scss +14 -7
- data/node_modules/govuk-frontend/govuk/overrides/_spacing.scss +56 -12
- data/node_modules/govuk-frontend/govuk/settings/_spacing.scss +4 -8
- data/node_modules/govuk-frontend/govuk/template.njk +5 -5
- data/node_modules/govuk-frontend/govuk-esm/components/accordion/accordion.mjs +3 -13
- data/node_modules/govuk-frontend/govuk-esm/components/details/details.mjs +8 -20
- data/node_modules/govuk-frontend/govuk-esm/components/header/header.mjs +53 -11
- data/node_modules/govuk-frontend/package.json +1 -1
- metadata +6 -584
- data/node_modules/axe-core/CHANGELOG.md +0 -1053
- data/node_modules/axe-core/CONTRIBUTING.md +0 -187
- data/node_modules/axe-core/bower.json +0 -40
- data/node_modules/axe-core/doc/API.md +0 -889
- data/node_modules/axe-core/doc/accessibility-supported.md +0 -33
- data/node_modules/axe-core/doc/act-rules-format.md +0 -37
- data/node_modules/axe-core/doc/aria-supported.md +0 -13
- data/node_modules/axe-core/doc/backwards-compatibility-doc.md +0 -94
- data/node_modules/axe-core/doc/check-message-template.md +0 -124
- data/node_modules/axe-core/doc/code-submission-guidelines.md +0 -178
- data/node_modules/axe-core/doc/developer-guide.md +0 -514
- data/node_modules/axe-core/doc/examples/chrome-debugging-protocol/README.md +0 -13
- data/node_modules/axe-core/doc/examples/chrome-debugging-protocol/axe-cdp.js +0 -81
- data/node_modules/axe-core/doc/examples/chrome-debugging-protocol/package.json +0 -11
- data/node_modules/axe-core/doc/examples/html-handlebars.md +0 -164
- data/node_modules/axe-core/doc/examples/jasmine/README.md +0 -35
- data/node_modules/axe-core/doc/examples/jasmine/karma.conf.js +0 -29
- data/node_modules/axe-core/doc/examples/jasmine/package.json +0 -21
- data/node_modules/axe-core/doc/examples/jasmine/spec/a11y.js +0 -36
- data/node_modules/axe-core/doc/examples/jest_react/README.md +0 -41
- data/node_modules/axe-core/doc/examples/jest_react/link.js +0 -7
- data/node_modules/axe-core/doc/examples/jest_react/link.test.js +0 -24
- data/node_modules/axe-core/doc/examples/jest_react/package.json +0 -28
- data/node_modules/axe-core/doc/examples/jest_react/test-helpers.js +0 -21
- data/node_modules/axe-core/doc/examples/jsdom/package.json +0 -15
- data/node_modules/axe-core/doc/examples/mocha/README.md +0 -35
- data/node_modules/axe-core/doc/examples/mocha/karma.conf.js +0 -29
- data/node_modules/axe-core/doc/examples/mocha/package.json +0 -22
- data/node_modules/axe-core/doc/examples/phantomjs/README.md +0 -17
- data/node_modules/axe-core/doc/examples/phantomjs/axe-phantom.js +0 -53
- data/node_modules/axe-core/doc/examples/phantomjs/package.json +0 -19
- data/node_modules/axe-core/doc/examples/puppeteer/README.md +0 -12
- data/node_modules/axe-core/doc/examples/puppeteer/axe-puppeteer.js +0 -60
- data/node_modules/axe-core/doc/examples/puppeteer/package.json +0 -13
- data/node_modules/axe-core/doc/examples/qunit/README.md +0 -37
- data/node_modules/axe-core/doc/examples/qunit/package.json +0 -21
- data/node_modules/axe-core/doc/examples/test-examples.js +0 -32
- data/node_modules/axe-core/doc/plugins.md +0 -123
- data/node_modules/axe-core/doc/projects.md +0 -48
- data/node_modules/axe-core/doc/rule-descriptions.md +0 -129
- data/node_modules/axe-core/doc/rule-development.md +0 -123
- data/node_modules/axe-core/doc/rule-proposal.md +0 -106
- data/node_modules/axe-core/lib/checks/aria/abstractrole.js +0 -10
- data/node_modules/axe-core/lib/checks/aria/abstractrole.json +0 -14
- data/node_modules/axe-core/lib/checks/aria/allowed-attr.js +0 -39
- data/node_modules/axe-core/lib/checks/aria/allowed-attr.json +0 -14
- data/node_modules/axe-core/lib/checks/aria/aria-allowed-role.js +0 -28
- data/node_modules/axe-core/lib/checks/aria/aria-allowed-role.json +0 -22
- data/node_modules/axe-core/lib/checks/aria/aria-hidden-body.js +0 -1
- data/node_modules/axe-core/lib/checks/aria/aria-hidden-body.json +0 -11
- data/node_modules/axe-core/lib/checks/aria/aria-roledescription.js +0 -14
- data/node_modules/axe-core/lib/checks/aria/aria-roledescription.json +0 -23
- data/node_modules/axe-core/lib/checks/aria/errormessage.js +0 -33
- data/node_modules/axe-core/lib/checks/aria/errormessage.json +0 -14
- data/node_modules/axe-core/lib/checks/aria/fallbackrole.js +0 -1
- data/node_modules/axe-core/lib/checks/aria/fallbackrole.json +0 -11
- data/node_modules/axe-core/lib/checks/aria/has-widget-role.js +0 -6
- data/node_modules/axe-core/lib/checks/aria/has-widget-role.json +0 -12
- data/node_modules/axe-core/lib/checks/aria/implicit-role-fallback.js +0 -6
- data/node_modules/axe-core/lib/checks/aria/implicit-role-fallback.json +0 -12
- data/node_modules/axe-core/lib/checks/aria/invalidrole.js +0 -17
- data/node_modules/axe-core/lib/checks/aria/invalidrole.json +0 -14
- data/node_modules/axe-core/lib/checks/aria/no-implicit-explicit-label.js +0 -21
- data/node_modules/axe-core/lib/checks/aria/no-implicit-explicit-label.json +0 -11
- data/node_modules/axe-core/lib/checks/aria/required-attr.js +0 -53
- data/node_modules/axe-core/lib/checks/aria/required-attr.json +0 -14
- data/node_modules/axe-core/lib/checks/aria/required-children.js +0 -154
- data/node_modules/axe-core/lib/checks/aria/required-children.json +0 -32
- data/node_modules/axe-core/lib/checks/aria/required-parent.js +0 -87
- data/node_modules/axe-core/lib/checks/aria/required-parent.json +0 -14
- data/node_modules/axe-core/lib/checks/aria/unsupportedattr.js +0 -39
- data/node_modules/axe-core/lib/checks/aria/unsupportedattr.json +0 -11
- data/node_modules/axe-core/lib/checks/aria/unsupportedrole.js +0 -1
- data/node_modules/axe-core/lib/checks/aria/unsupportedrole.json +0 -11
- data/node_modules/axe-core/lib/checks/aria/valid-attr-value.js +0 -80
- data/node_modules/axe-core/lib/checks/aria/valid-attr-value.json +0 -19
- data/node_modules/axe-core/lib/checks/aria/valid-attr.js +0 -25
- data/node_modules/axe-core/lib/checks/aria/valid-attr.json +0 -15
- data/node_modules/axe-core/lib/checks/aria/valid-scrollable-semantics.js +0 -62
- data/node_modules/axe-core/lib/checks/aria/valid-scrollable-semantics.json +0 -12
- data/node_modules/axe-core/lib/checks/color/color-contrast.js +0 -86
- data/node_modules/axe-core/lib/checks/color/color-contrast.json +0 -30
- data/node_modules/axe-core/lib/checks/color/link-in-text-block.js +0 -85
- data/node_modules/axe-core/lib/checks/color/link-in-text-block.json +0 -19
- data/node_modules/axe-core/lib/checks/forms/autocomplete-appropriate.js +0 -67
- data/node_modules/axe-core/lib/checks/forms/autocomplete-appropriate.json +0 -11
- data/node_modules/axe-core/lib/checks/forms/autocomplete-valid.js +0 -2
- data/node_modules/axe-core/lib/checks/forms/autocomplete-valid.json +0 -11
- data/node_modules/axe-core/lib/checks/forms/fieldset-after.js +0 -25
- data/node_modules/axe-core/lib/checks/forms/fieldset.js +0 -109
- data/node_modules/axe-core/lib/checks/forms/fieldset.json +0 -20
- data/node_modules/axe-core/lib/checks/forms/group-labelledby-after.js +0 -16
- data/node_modules/axe-core/lib/checks/forms/group-labelledby.js +0 -66
- data/node_modules/axe-core/lib/checks/forms/group-labelledby.json +0 -17
- data/node_modules/axe-core/lib/checks/keyboard/accesskeys-after.js +0 -19
- data/node_modules/axe-core/lib/checks/keyboard/accesskeys.js +0 -5
- data/node_modules/axe-core/lib/checks/keyboard/accesskeys.json +0 -12
- data/node_modules/axe-core/lib/checks/keyboard/focusable-content.js +0 -16
- data/node_modules/axe-core/lib/checks/keyboard/focusable-content.json +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/focusable-disabled.js +0 -30
- data/node_modules/axe-core/lib/checks/keyboard/focusable-disabled.json +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/focusable-element.js +0 -12
- data/node_modules/axe-core/lib/checks/keyboard/focusable-element.json +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/focusable-modal-open.js +0 -14
- data/node_modules/axe-core/lib/checks/keyboard/focusable-modal-open.json +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/focusable-no-name.js +0 -6
- data/node_modules/axe-core/lib/checks/keyboard/focusable-no-name.json +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/focusable-not-tabbable.js +0 -30
- data/node_modules/axe-core/lib/checks/keyboard/focusable-not-tabbable.json +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/landmark-is-top-level.js +0 -18
- data/node_modules/axe-core/lib/checks/keyboard/landmark-is-top-level.json +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/page-has-elm-after.js +0 -11
- data/node_modules/axe-core/lib/checks/keyboard/page-has-elm.js +0 -13
- data/node_modules/axe-core/lib/checks/keyboard/page-has-heading-one.json +0 -15
- data/node_modules/axe-core/lib/checks/keyboard/page-has-main.json +0 -15
- data/node_modules/axe-core/lib/checks/keyboard/page-no-duplicate-after.js +0 -2
- data/node_modules/axe-core/lib/checks/keyboard/page-no-duplicate-banner.json +0 -16
- data/node_modules/axe-core/lib/checks/keyboard/page-no-duplicate-contentinfo.json +0 -16
- data/node_modules/axe-core/lib/checks/keyboard/page-no-duplicate-main.json +0 -15
- data/node_modules/axe-core/lib/checks/keyboard/page-no-duplicate.js +0 -36
- data/node_modules/axe-core/lib/checks/keyboard/tabindex.js +0 -6
- data/node_modules/axe-core/lib/checks/keyboard/tabindex.json +0 -11
- data/node_modules/axe-core/lib/checks/label/alt-space-value.js +0 -3
- data/node_modules/axe-core/lib/checks/label/alt-space-value.json +0 -11
- data/node_modules/axe-core/lib/checks/label/duplicate-img-label.js +0 -22
- data/node_modules/axe-core/lib/checks/label/duplicate-img-label.json +0 -11
- data/node_modules/axe-core/lib/checks/label/explicit.js +0 -15
- data/node_modules/axe-core/lib/checks/label/explicit.json +0 -11
- data/node_modules/axe-core/lib/checks/label/help-same-as-label.js +0 -23
- data/node_modules/axe-core/lib/checks/label/help-same-as-label.json +0 -12
- data/node_modules/axe-core/lib/checks/label/hidden-explicit-label.js +0 -12
- data/node_modules/axe-core/lib/checks/label/hidden-explicit-label.json +0 -11
- data/node_modules/axe-core/lib/checks/label/implicit.js +0 -7
- data/node_modules/axe-core/lib/checks/label/implicit.json +0 -11
- data/node_modules/axe-core/lib/checks/label/label-content-name-mismatch.js +0 -59
- data/node_modules/axe-core/lib/checks/label/label-content-name-mismatch.json +0 -15
- data/node_modules/axe-core/lib/checks/label/multiple-label.js +0 -39
- data/node_modules/axe-core/lib/checks/label/multiple-label.json +0 -11
- data/node_modules/axe-core/lib/checks/label/title-only.js +0 -5
- data/node_modules/axe-core/lib/checks/label/title-only.json +0 -11
- data/node_modules/axe-core/lib/checks/landmarks/landmark-is-unique-after.js +0 -23
- data/node_modules/axe-core/lib/checks/landmarks/landmark-is-unique.js +0 -7
- data/node_modules/axe-core/lib/checks/landmarks/landmark-is-unique.json +0 -12
- data/node_modules/axe-core/lib/checks/language/has-lang.js +0 -20
- data/node_modules/axe-core/lib/checks/language/has-lang.json +0 -14
- data/node_modules/axe-core/lib/checks/language/valid-lang.js +0 -26
- data/node_modules/axe-core/lib/checks/language/valid-lang.json +0 -11
- data/node_modules/axe-core/lib/checks/language/xml-lang-mismatch.js +0 -5
- data/node_modules/axe-core/lib/checks/language/xml-lang-mismatch.json +0 -11
- data/node_modules/axe-core/lib/checks/lists/dlitem.js +0 -23
- data/node_modules/axe-core/lib/checks/lists/dlitem.json +0 -11
- data/node_modules/axe-core/lib/checks/lists/listitem.js +0 -21
- data/node_modules/axe-core/lib/checks/lists/listitem.json +0 -14
- data/node_modules/axe-core/lib/checks/lists/only-dlitems.js +0 -42
- data/node_modules/axe-core/lib/checks/lists/only-dlitems.json +0 -11
- data/node_modules/axe-core/lib/checks/lists/only-listitems.js +0 -58
- data/node_modules/axe-core/lib/checks/lists/only-listitems.json +0 -14
- data/node_modules/axe-core/lib/checks/lists/structured-dlitems.js +0 -22
- data/node_modules/axe-core/lib/checks/lists/structured-dlitems.json +0 -11
- data/node_modules/axe-core/lib/checks/media/caption.js +0 -8
- data/node_modules/axe-core/lib/checks/media/caption.json +0 -11
- data/node_modules/axe-core/lib/checks/media/description.js +0 -8
- data/node_modules/axe-core/lib/checks/media/description.json +0 -11
- data/node_modules/axe-core/lib/checks/media/frame-tested.js +0 -28
- data/node_modules/axe-core/lib/checks/media/frame-tested.json +0 -15
- data/node_modules/axe-core/lib/checks/media/no-autoplay-audio.js +0 -93
- data/node_modules/axe-core/lib/checks/media/no-autoplay-audio.json +0 -15
- data/node_modules/axe-core/lib/checks/mobile/css-orientation-lock.js +0 -251
- data/node_modules/axe-core/lib/checks/mobile/css-orientation-lock.json +0 -15
- data/node_modules/axe-core/lib/checks/mobile/meta-viewport-large.json +0 -15
- data/node_modules/axe-core/lib/checks/mobile/meta-viewport-scale.js +0 -55
- data/node_modules/axe-core/lib/checks/mobile/meta-viewport.json +0 -14
- data/node_modules/axe-core/lib/checks/navigation/header-present.js +0 -4
- data/node_modules/axe-core/lib/checks/navigation/header-present.json +0 -11
- data/node_modules/axe-core/lib/checks/navigation/heading-order-after.js +0 -14
- data/node_modules/axe-core/lib/checks/navigation/heading-order.js +0 -15
- data/node_modules/axe-core/lib/checks/navigation/heading-order.json +0 -12
- data/node_modules/axe-core/lib/checks/navigation/identical-links-same-purpose-after.js +0 -100
- data/node_modules/axe-core/lib/checks/navigation/identical-links-same-purpose.js +0 -31
- data/node_modules/axe-core/lib/checks/navigation/identical-links-same-purpose.json +0 -12
- data/node_modules/axe-core/lib/checks/navigation/internal-link-present.js +0 -4
- data/node_modules/axe-core/lib/checks/navigation/internal-link-present.json +0 -11
- data/node_modules/axe-core/lib/checks/navigation/landmark.js +0 -3
- data/node_modules/axe-core/lib/checks/navigation/landmark.json +0 -11
- data/node_modules/axe-core/lib/checks/navigation/meta-refresh.js +0 -4
- data/node_modules/axe-core/lib/checks/navigation/meta-refresh.json +0 -11
- data/node_modules/axe-core/lib/checks/navigation/p-as-heading.js +0 -93
- data/node_modules/axe-core/lib/checks/navigation/p-as-heading.json +0 -30
- data/node_modules/axe-core/lib/checks/navigation/region.js +0 -107
- data/node_modules/axe-core/lib/checks/navigation/region.json +0 -11
- data/node_modules/axe-core/lib/checks/navigation/skip-link.js +0 -5
- data/node_modules/axe-core/lib/checks/navigation/skip-link.json +0 -12
- data/node_modules/axe-core/lib/checks/navigation/unique-frame-title-after.js +0 -9
- data/node_modules/axe-core/lib/checks/navigation/unique-frame-title.js +0 -6
- data/node_modules/axe-core/lib/checks/navigation/unique-frame-title.json +0 -12
- data/node_modules/axe-core/lib/checks/parsing/duplicate-id-active.json +0 -12
- data/node_modules/axe-core/lib/checks/parsing/duplicate-id-after.js +0 -8
- data/node_modules/axe-core/lib/checks/parsing/duplicate-id-aria.json +0 -12
- data/node_modules/axe-core/lib/checks/parsing/duplicate-id.js +0 -17
- data/node_modules/axe-core/lib/checks/parsing/duplicate-id.json +0 -12
- data/node_modules/axe-core/lib/checks/shared/aria-label.js +0 -2
- data/node_modules/axe-core/lib/checks/shared/aria-label.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/aria-labelledby.js +0 -2
- data/node_modules/axe-core/lib/checks/shared/aria-labelledby.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/avoid-inline-spacing.js +0 -18
- data/node_modules/axe-core/lib/checks/shared/avoid-inline-spacing.json +0 -14
- data/node_modules/axe-core/lib/checks/shared/button-has-visible-text.js +0 -12
- data/node_modules/axe-core/lib/checks/shared/button-has-visible-text.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/doc-has-title.js +0 -2
- data/node_modules/axe-core/lib/checks/shared/doc-has-title.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/exists.js +0 -1
- data/node_modules/axe-core/lib/checks/shared/exists.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/has-alt.js +0 -6
- data/node_modules/axe-core/lib/checks/shared/has-alt.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/has-visible-text.js +0 -1
- data/node_modules/axe-core/lib/checks/shared/has-visible-text.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/is-on-screen.js +0 -4
- data/node_modules/axe-core/lib/checks/shared/is-on-screen.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/non-empty-alt.js +0 -2
- data/node_modules/axe-core/lib/checks/shared/non-empty-alt.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/non-empty-if-present.js +0 -15
- data/node_modules/axe-core/lib/checks/shared/non-empty-if-present.json +0 -14
- data/node_modules/axe-core/lib/checks/shared/non-empty-title.js +0 -2
- data/node_modules/axe-core/lib/checks/shared/non-empty-title.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/non-empty-value.js +0 -2
- data/node_modules/axe-core/lib/checks/shared/non-empty-value.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/role-none.js +0 -1
- data/node_modules/axe-core/lib/checks/shared/role-none.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/role-presentation.js +0 -1
- data/node_modules/axe-core/lib/checks/shared/role-presentation.json +0 -11
- data/node_modules/axe-core/lib/checks/shared/svg-non-empty-title.js +0 -4
- data/node_modules/axe-core/lib/checks/shared/svg-non-empty-title.json +0 -11
- data/node_modules/axe-core/lib/checks/tables/caption-faked.js +0 -10
- data/node_modules/axe-core/lib/checks/tables/caption-faked.json +0 -11
- data/node_modules/axe-core/lib/checks/tables/has-caption.js +0 -1
- data/node_modules/axe-core/lib/checks/tables/has-caption.json +0 -12
- data/node_modules/axe-core/lib/checks/tables/has-summary.js +0 -1
- data/node_modules/axe-core/lib/checks/tables/has-summary.json +0 -12
- data/node_modules/axe-core/lib/checks/tables/has-th.js +0 -31
- data/node_modules/axe-core/lib/checks/tables/has-th.json +0 -12
- data/node_modules/axe-core/lib/checks/tables/headers-visible-text.js +0 -30
- data/node_modules/axe-core/lib/checks/tables/html5-scope.js +0 -5
- data/node_modules/axe-core/lib/checks/tables/html5-scope.json +0 -11
- data/node_modules/axe-core/lib/checks/tables/same-caption-summary.js +0 -7
- data/node_modules/axe-core/lib/checks/tables/same-caption-summary.json +0 -11
- data/node_modules/axe-core/lib/checks/tables/scope-value.js +0 -5
- data/node_modules/axe-core/lib/checks/tables/scope-value.json +0 -11
- data/node_modules/axe-core/lib/checks/tables/td-has-header.js +0 -30
- data/node_modules/axe-core/lib/checks/tables/td-has-header.json +0 -11
- data/node_modules/axe-core/lib/checks/tables/td-headers-attr.js +0 -61
- data/node_modules/axe-core/lib/checks/tables/td-headers-attr.json +0 -12
- data/node_modules/axe-core/lib/checks/tables/th-has-data-cells.js +0 -76
- data/node_modules/axe-core/lib/checks/tables/th-has-data-cells.json +0 -12
- data/node_modules/axe-core/lib/checks/tables/th-single-row-column.js +0 -39
- data/node_modules/axe-core/lib/checks/visibility/hidden-content.js +0 -21
- data/node_modules/axe-core/lib/checks/visibility/hidden-content.json +0 -12
- data/node_modules/axe-core/lib/commons/aria/arialabel-text.js +0 -18
- data/node_modules/axe-core/lib/commons/aria/arialabelledby-text.js +0 -52
- data/node_modules/axe-core/lib/commons/aria/attributes.js +0 -45
- data/node_modules/axe-core/lib/commons/aria/get-element-unallowed-roles.js +0 -113
- data/node_modules/axe-core/lib/commons/aria/get-owned-virtual.js +0 -24
- data/node_modules/axe-core/lib/commons/aria/get-role.js +0 -44
- data/node_modules/axe-core/lib/commons/aria/index.js +0 -2424
- data/node_modules/axe-core/lib/commons/aria/is-accessible-ref.js +0 -59
- data/node_modules/axe-core/lib/commons/aria/is-aria-role-allowed-on-element.js +0 -41
- data/node_modules/axe-core/lib/commons/aria/is-unsupported-role.js +0 -14
- data/node_modules/axe-core/lib/commons/aria/label-virtual.js +0 -54
- data/node_modules/axe-core/lib/commons/aria/named-from-contents.js +0 -39
- data/node_modules/axe-core/lib/commons/aria/roles.js +0 -208
- data/node_modules/axe-core/lib/commons/aria/validate-attr-value.js +0 -62
- data/node_modules/axe-core/lib/commons/color/center-point-of-rect.js +0 -30
- data/node_modules/axe-core/lib/commons/color/contrast.js +0 -178
- data/node_modules/axe-core/lib/commons/color/element-has-image.js +0 -36
- data/node_modules/axe-core/lib/commons/color/element-is-distinct.js +0 -88
- data/node_modules/axe-core/lib/commons/color/get-background-color.js +0 -285
- data/node_modules/axe-core/lib/commons/color/get-foreground-color.js +0 -61
- data/node_modules/axe-core/lib/commons/color/get-own-background-color.js +0 -22
- data/node_modules/axe-core/lib/commons/color/incomplete-data.js +0 -50
- data/node_modules/axe-core/lib/commons/color/index.js +0 -8
- data/node_modules/axe-core/lib/commons/dom/elements-below-floating.js +0 -39
- data/node_modules/axe-core/lib/commons/dom/find-elms-in-context.js +0 -28
- data/node_modules/axe-core/lib/commons/dom/find-up.js +0 -63
- data/node_modules/axe-core/lib/commons/dom/get-composed-parent.js +0 -25
- data/node_modules/axe-core/lib/commons/dom/get-element-by-reference.js +0 -34
- data/node_modules/axe-core/lib/commons/dom/get-element-coordinates.js +0 -38
- data/node_modules/axe-core/lib/commons/dom/get-element-stack.js +0 -589
- data/node_modules/axe-core/lib/commons/dom/get-root-node.js +0 -12
- data/node_modules/axe-core/lib/commons/dom/get-scroll-offset.js +0 -33
- data/node_modules/axe-core/lib/commons/dom/get-tabbable-elements.js +0 -24
- data/node_modules/axe-core/lib/commons/dom/get-viewport-size.js +0 -37
- data/node_modules/axe-core/lib/commons/dom/has-content-virtual.js +0 -75
- data/node_modules/axe-core/lib/commons/dom/idrefs.js +0 -36
- data/node_modules/axe-core/lib/commons/dom/index.js +0 -9
- data/node_modules/axe-core/lib/commons/dom/is-focusable.js +0 -95
- data/node_modules/axe-core/lib/commons/dom/is-hidden-with-css.js +0 -73
- data/node_modules/axe-core/lib/commons/dom/is-html5.js +0 -17
- data/node_modules/axe-core/lib/commons/dom/is-in-text-block.js +0 -94
- data/node_modules/axe-core/lib/commons/dom/is-modal-open.js +0 -98
- data/node_modules/axe-core/lib/commons/dom/is-node.js +0 -13
- data/node_modules/axe-core/lib/commons/dom/is-offscreen.js +0 -62
- data/node_modules/axe-core/lib/commons/dom/is-skip-link.js +0 -45
- data/node_modules/axe-core/lib/commons/dom/is-visible.js +0 -176
- data/node_modules/axe-core/lib/commons/dom/is-visual-content.js +0 -49
- data/node_modules/axe-core/lib/commons/dom/shadow-elements-from-point.js +0 -42
- data/node_modules/axe-core/lib/commons/dom/url-props-from-attribute.js +0 -152
- data/node_modules/axe-core/lib/commons/dom/visually-contains.js +0 -111
- data/node_modules/axe-core/lib/commons/dom/visually-overlaps.js +0 -46
- data/node_modules/axe-core/lib/commons/forms/index.js +0 -8
- data/node_modules/axe-core/lib/commons/forms/is-aria-combobox.js +0 -13
- data/node_modules/axe-core/lib/commons/forms/is-aria-listbox.js +0 -13
- data/node_modules/axe-core/lib/commons/forms/is-aria-range.js +0 -14
- data/node_modules/axe-core/lib/commons/forms/is-aria-textbox.js +0 -13
- data/node_modules/axe-core/lib/commons/forms/is-native-select.js +0 -13
- data/node_modules/axe-core/lib/commons/forms/is-native-textbox.js +0 -28
- data/node_modules/axe-core/lib/commons/index.js +0 -11
- data/node_modules/axe-core/lib/commons/intro.stub +0 -1
- data/node_modules/axe-core/lib/commons/matches/attributes.js +0 -27
- data/node_modules/axe-core/lib/commons/matches/condition.js +0 -19
- data/node_modules/axe-core/lib/commons/matches/from-definition.js +0 -52
- data/node_modules/axe-core/lib/commons/matches/from-function.js +0 -38
- data/node_modules/axe-core/lib/commons/matches/from-primative.js +0 -30
- data/node_modules/axe-core/lib/commons/matches/index.js +0 -39
- data/node_modules/axe-core/lib/commons/matches/node-name.js +0 -24
- data/node_modules/axe-core/lib/commons/matches/properties.js +0 -28
- data/node_modules/axe-core/lib/commons/outro.stub +0 -2
- data/node_modules/axe-core/lib/commons/table/get-all-cells.js +0 -28
- data/node_modules/axe-core/lib/commons/table/get-cell-position.js +0 -28
- data/node_modules/axe-core/lib/commons/table/get-headers.js +0 -79
- data/node_modules/axe-core/lib/commons/table/get-scope.js +0 -54
- data/node_modules/axe-core/lib/commons/table/index.js +0 -9
- data/node_modules/axe-core/lib/commons/table/is-column-header.js +0 -13
- data/node_modules/axe-core/lib/commons/table/is-data-cell.js +0 -22
- data/node_modules/axe-core/lib/commons/table/is-data-table.js +0 -189
- data/node_modules/axe-core/lib/commons/table/is-header.js +0 -22
- data/node_modules/axe-core/lib/commons/table/is-row-header.js +0 -13
- data/node_modules/axe-core/lib/commons/table/to-grid.js +0 -38
- data/node_modules/axe-core/lib/commons/table/traverse.js +0 -78
- data/node_modules/axe-core/lib/commons/text/accessible-text-virtual.js +0 -152
- data/node_modules/axe-core/lib/commons/text/form-control-value.js +0 -192
- data/node_modules/axe-core/lib/commons/text/index.js +0 -8
- data/node_modules/axe-core/lib/commons/text/is-human-interpretable.js +0 -51
- data/node_modules/axe-core/lib/commons/text/is-icon-ligature.js +0 -210
- data/node_modules/axe-core/lib/commons/text/is-valid-autocomplete.js +0 -117
- data/node_modules/axe-core/lib/commons/text/label-text.js +0 -58
- data/node_modules/axe-core/lib/commons/text/label-virtual.js +0 -53
- data/node_modules/axe-core/lib/commons/text/native-element-types.js +0 -100
- data/node_modules/axe-core/lib/commons/text/native-text-alternative.js +0 -50
- data/node_modules/axe-core/lib/commons/text/native-text-methods.js +0 -122
- data/node_modules/axe-core/lib/commons/text/sanitize.js +0 -18
- data/node_modules/axe-core/lib/commons/text/subtree-text.js +0 -89
- data/node_modules/axe-core/lib/commons/text/title-text.js +0 -33
- data/node_modules/axe-core/lib/commons/text/unicode.js +0 -147
- data/node_modules/axe-core/lib/commons/text/unsupported.js +0 -5
- data/node_modules/axe-core/lib/commons/text/visible-text-nodes.js +0 -25
- data/node_modules/axe-core/lib/commons/text/visible-virtual.js +0 -46
- data/node_modules/axe-core/lib/commons/utils/index.js +0 -10
- data/node_modules/axe-core/lib/core/base/audit.js +0 -781
- data/node_modules/axe-core/lib/core/base/cache.js +0 -33
- data/node_modules/axe-core/lib/core/base/check-result.js +0 -33
- data/node_modules/axe-core/lib/core/base/check.js +0 -170
- data/node_modules/axe-core/lib/core/base/context.js +0 -274
- data/node_modules/axe-core/lib/core/base/rule-result.js +0 -39
- data/node_modules/axe-core/lib/core/base/rule.js +0 -560
- data/node_modules/axe-core/lib/core/base/virtual-node/abstract-virtual-node.js +0 -40
- data/node_modules/axe-core/lib/core/base/virtual-node/serial-virtual-node.js +0 -88
- data/node_modules/axe-core/lib/core/base/virtual-node/virtual-node.js +0 -136
- data/node_modules/axe-core/lib/core/constants.js +0 -76
- data/node_modules/axe-core/lib/core/imports/index.js +0 -51
- data/node_modules/axe-core/lib/core/index.js +0 -43
- data/node_modules/axe-core/lib/core/log.js +0 -12
- data/node_modules/axe-core/lib/core/public/cleanup-plugins.js +0 -53
- data/node_modules/axe-core/lib/core/public/configure.js +0 -110
- data/node_modules/axe-core/lib/core/public/get-rules.js +0 -29
- data/node_modules/axe-core/lib/core/public/load.js +0 -66
- data/node_modules/axe-core/lib/core/public/plugins.js +0 -47
- data/node_modules/axe-core/lib/core/public/reporter.js +0 -24
- data/node_modules/axe-core/lib/core/public/reset.js +0 -12
- data/node_modules/axe-core/lib/core/public/run-rules.js +0 -96
- data/node_modules/axe-core/lib/core/public/run-virtual-rule.js +0 -50
- data/node_modules/axe-core/lib/core/public/run.js +0 -159
- data/node_modules/axe-core/lib/core/reporters/helpers/failure-summary.js +0 -35
- data/node_modules/axe-core/lib/core/reporters/helpers/get-environment-data.js +0 -39
- data/node_modules/axe-core/lib/core/reporters/helpers/incomplete-fallback-msg.js +0 -13
- data/node_modules/axe-core/lib/core/reporters/helpers/index.js +0 -3
- data/node_modules/axe-core/lib/core/reporters/helpers/process-aggregate.js +0 -102
- data/node_modules/axe-core/lib/core/reporters/na.js +0 -24
- data/node_modules/axe-core/lib/core/reporters/no-passes.js +0 -18
- data/node_modules/axe-core/lib/core/reporters/raw-env.js +0 -12
- data/node_modules/axe-core/lib/core/reporters/raw.js +0 -32
- data/node_modules/axe-core/lib/core/reporters/v1.js +0 -29
- data/node_modules/axe-core/lib/core/reporters/v2.js +0 -22
- data/node_modules/axe-core/lib/core/utils/aggregate.js +0 -19
- data/node_modules/axe-core/lib/core/utils/aggregateChecks.js +0 -85
- data/node_modules/axe-core/lib/core/utils/aggregateNodeResults.js +0 -61
- data/node_modules/axe-core/lib/core/utils/aggregateResult.js +0 -37
- data/node_modules/axe-core/lib/core/utils/are-styles-set.js +0 -21
- data/node_modules/axe-core/lib/core/utils/assert.js +0 -12
- data/node_modules/axe-core/lib/core/utils/check-helper.js +0 -38
- data/node_modules/axe-core/lib/core/utils/clone.js +0 -27
- data/node_modules/axe-core/lib/core/utils/collect-results-from-frames.js +0 -127
- data/node_modules/axe-core/lib/core/utils/contains.js +0 -44
- data/node_modules/axe-core/lib/core/utils/css-parser.js +0 -7
- data/node_modules/axe-core/lib/core/utils/dq-element.js +0 -97
- data/node_modules/axe-core/lib/core/utils/element-matches.js +0 -43
- data/node_modules/axe-core/lib/core/utils/escape-selector.js +0 -78
- data/node_modules/axe-core/lib/core/utils/extend-meta-data.js +0 -17
- data/node_modules/axe-core/lib/core/utils/finalize-result.js +0 -11
- data/node_modules/axe-core/lib/core/utils/find-by.js +0 -14
- data/node_modules/axe-core/lib/core/utils/flattened-tree.js +0 -156
- data/node_modules/axe-core/lib/core/utils/get-all-checks.js +0 -12
- data/node_modules/axe-core/lib/core/utils/get-base-lang.js +0 -16
- data/node_modules/axe-core/lib/core/utils/get-check-message.js +0 -21
- data/node_modules/axe-core/lib/core/utils/get-check-option.js +0 -39
- data/node_modules/axe-core/lib/core/utils/get-friendly-uri-end.js +0 -144
- data/node_modules/axe-core/lib/core/utils/get-node-attributes.js +0 -21
- data/node_modules/axe-core/lib/core/utils/get-root-node.js +0 -17
- data/node_modules/axe-core/lib/core/utils/get-scroll.js +0 -39
- data/node_modules/axe-core/lib/core/utils/get-selector.js +0 -409
- data/node_modules/axe-core/lib/core/utils/get-stylesheet-factory.js +0 -51
- data/node_modules/axe-core/lib/core/utils/get-xpath.js +0 -83
- data/node_modules/axe-core/lib/core/utils/index.js +0 -10
- data/node_modules/axe-core/lib/core/utils/inject-style.js +0 -38
- data/node_modules/axe-core/lib/core/utils/is-hidden.js +0 -52
- data/node_modules/axe-core/lib/core/utils/is-html-element.js +0 -135
- data/node_modules/axe-core/lib/core/utils/is-shadow-root.js +0 -40
- data/node_modules/axe-core/lib/core/utils/is-xhtml.js +0 -14
- data/node_modules/axe-core/lib/core/utils/matches.js +0 -263
- data/node_modules/axe-core/lib/core/utils/memoize.js +0 -17
- data/node_modules/axe-core/lib/core/utils/merge-results.js +0 -116
- data/node_modules/axe-core/lib/core/utils/node-sorter.js +0 -21
- data/node_modules/axe-core/lib/core/utils/parse-crossorigin-stylesheet.js +0 -54
- data/node_modules/axe-core/lib/core/utils/parse-sameorigin-stylesheet.js +0 -96
- data/node_modules/axe-core/lib/core/utils/parse-stylesheet.js +0 -70
- data/node_modules/axe-core/lib/core/utils/performance-timer.js +0 -126
- data/node_modules/axe-core/lib/core/utils/pollyfills.js +0 -299
- data/node_modules/axe-core/lib/core/utils/preload-cssom.js +0 -253
- data/node_modules/axe-core/lib/core/utils/preload-media.js +0 -65
- data/node_modules/axe-core/lib/core/utils/preload.js +0 -144
- data/node_modules/axe-core/lib/core/utils/process-message.js +0 -72
- data/node_modules/axe-core/lib/core/utils/publish-metadata.js +0 -106
- data/node_modules/axe-core/lib/core/utils/qsa.js +0 -110
- data/node_modules/axe-core/lib/core/utils/queue.js +0 -138
- data/node_modules/axe-core/lib/core/utils/respondable.js +0 -261
- data/node_modules/axe-core/lib/core/utils/rule-should-run.js +0 -82
- data/node_modules/axe-core/lib/core/utils/scroll-state.js +0 -57
- data/node_modules/axe-core/lib/core/utils/select.js +0 -135
- data/node_modules/axe-core/lib/core/utils/to-array.js +0 -21
- data/node_modules/axe-core/lib/core/utils/token-list.js +0 -15
- data/node_modules/axe-core/lib/core/utils/uuid.js +0 -244
- data/node_modules/axe-core/lib/core/utils/valid-input-type.js +0 -35
- data/node_modules/axe-core/lib/core/utils/valid-langs.js +0 -8152
- data/node_modules/axe-core/lib/intro.stub +0 -15
- data/node_modules/axe-core/lib/misc/any-failure-summary.json +0 -6
- data/node_modules/axe-core/lib/misc/incomplete-fallback.json +0 -3
- data/node_modules/axe-core/lib/misc/none-failure-summary.json +0 -6
- data/node_modules/axe-core/lib/outro.stub +0 -2
- data/node_modules/axe-core/lib/rules/accesskeys.json +0 -13
- data/node_modules/axe-core/lib/rules/area-alt.json +0 -21
- data/node_modules/axe-core/lib/rules/aria-allowed-attr-matches.js +0 -11
- data/node_modules/axe-core/lib/rules/aria-allowed-attr.json +0 -12
- data/node_modules/axe-core/lib/rules/aria-allowed-role-matches.js +0 -7
- data/node_modules/axe-core/lib/rules/aria-allowed-role.json +0 -14
- data/node_modules/axe-core/lib/rules/aria-dpub-role-fallback-matches.js +0 -10
- data/node_modules/axe-core/lib/rules/aria-dpub-role-fallback.json +0 -14
- data/node_modules/axe-core/lib/rules/aria-form-field-name-matches.js +0 -50
- data/node_modules/axe-core/lib/rules/aria-has-attr-matches.js +0 -11
- data/node_modules/axe-core/lib/rules/aria-hidden-body.json +0 -13
- data/node_modules/axe-core/lib/rules/aria-hidden-focus-matches.js +0 -18
- data/node_modules/axe-core/lib/rules/aria-hidden-focus.json +0 -18
- data/node_modules/axe-core/lib/rules/aria-input-field-name.json +0 -13
- data/node_modules/axe-core/lib/rules/aria-required-attr.json +0 -12
- data/node_modules/axe-core/lib/rules/aria-required-children.json +0 -12
- data/node_modules/axe-core/lib/rules/aria-required-parent.json +0 -12
- data/node_modules/axe-core/lib/rules/aria-roledescription.json +0 -12
- data/node_modules/axe-core/lib/rules/aria-roles.json +0 -13
- data/node_modules/axe-core/lib/rules/aria-toggle-field-name.json +0 -18
- data/node_modules/axe-core/lib/rules/aria-valid-attr-value.json +0 -12
- data/node_modules/axe-core/lib/rules/aria-valid-attr.json +0 -12
- data/node_modules/axe-core/lib/rules/audio-caption.json +0 -20
- data/node_modules/axe-core/lib/rules/autocomplete-matches.js +0 -49
- data/node_modules/axe-core/lib/rules/autocomplete-valid.json +0 -12
- data/node_modules/axe-core/lib/rules/avoid-inline-spacing.json +0 -12
- data/node_modules/axe-core/lib/rules/blink.json +0 -19
- data/node_modules/axe-core/lib/rules/button-name.json +0 -25
- data/node_modules/axe-core/lib/rules/bypass-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/bypass.json +0 -20
- data/node_modules/axe-core/lib/rules/checkboxgroup.json +0 -13
- data/node_modules/axe-core/lib/rules/color-contrast-matches.js +0 -161
- data/node_modules/axe-core/lib/rules/color-contrast.json +0 -13
- data/node_modules/axe-core/lib/rules/css-orientation-lock.json +0 -13
- data/node_modules/axe-core/lib/rules/data-table-large-matches.js +0 -11
- data/node_modules/axe-core/lib/rules/data-table-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/definition-list.json +0 -13
- data/node_modules/axe-core/lib/rules/dlitem.json +0 -13
- data/node_modules/axe-core/lib/rules/document-title.json +0 -13
- data/node_modules/axe-core/lib/rules/duplicate-id-active-matches.js +0 -8
- data/node_modules/axe-core/lib/rules/duplicate-id-active.json +0 -14
- data/node_modules/axe-core/lib/rules/duplicate-id-aria-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/duplicate-id-aria.json +0 -14
- data/node_modules/axe-core/lib/rules/duplicate-id-misc-matches.js +0 -11
- data/node_modules/axe-core/lib/rules/duplicate-id.json +0 -14
- data/node_modules/axe-core/lib/rules/empty-heading.json +0 -13
- data/node_modules/axe-core/lib/rules/focus-order-semantics.json +0 -13
- data/node_modules/axe-core/lib/rules/form-field-multiple-labels.json +0 -13
- data/node_modules/axe-core/lib/rules/frame-tested.json +0 -12
- data/node_modules/axe-core/lib/rules/frame-title-has-text.js +0 -2
- data/node_modules/axe-core/lib/rules/frame-title-unique.json +0 -13
- data/node_modules/axe-core/lib/rules/frame-title.json +0 -25
- data/node_modules/axe-core/lib/rules/heading-matches.js +0 -15
- data/node_modules/axe-core/lib/rules/heading-order.json +0 -13
- data/node_modules/axe-core/lib/rules/hidden-content.json +0 -13
- data/node_modules/axe-core/lib/rules/html-has-lang.json +0 -13
- data/node_modules/axe-core/lib/rules/html-lang-valid.json +0 -12
- data/node_modules/axe-core/lib/rules/html-namespace-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/html-xml-lang-mismatch.json +0 -13
- data/node_modules/axe-core/lib/rules/identical-links-same-purpose-matches.js +0 -13
- data/node_modules/axe-core/lib/rules/identical-links-same-purpose.json +0 -14
- data/node_modules/axe-core/lib/rules/image-alt.json +0 -25
- data/node_modules/axe-core/lib/rules/img-redundant-alt.json +0 -12
- data/node_modules/axe-core/lib/rules/input-button-name.json +0 -26
- data/node_modules/axe-core/lib/rules/input-image-alt.json +0 -18
- data/node_modules/axe-core/lib/rules/inserted-into-focus-order-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/label-content-name-mismatch-matches.js +0 -45
- data/node_modules/axe-core/lib/rules/label-content-name-mismatch.json +0 -12
- data/node_modules/axe-core/lib/rules/label-matches.js +0 -11
- data/node_modules/axe-core/lib/rules/label-title-only.json +0 -13
- data/node_modules/axe-core/lib/rules/label.json +0 -26
- data/node_modules/axe-core/lib/rules/landmark-banner-is-top-level.json +0 -13
- data/node_modules/axe-core/lib/rules/landmark-complementary-is-top-level.json +0 -12
- data/node_modules/axe-core/lib/rules/landmark-contentinfo-is-top-level.json +0 -13
- data/node_modules/axe-core/lib/rules/landmark-has-body-context.js +0 -8
- data/node_modules/axe-core/lib/rules/landmark-main-is-top-level.json +0 -12
- data/node_modules/axe-core/lib/rules/landmark-no-duplicate-banner.json +0 -12
- data/node_modules/axe-core/lib/rules/landmark-no-duplicate-contentinfo.json +0 -12
- data/node_modules/axe-core/lib/rules/landmark-no-duplicate-main.json +0 -12
- data/node_modules/axe-core/lib/rules/landmark-one-main.json +0 -12
- data/node_modules/axe-core/lib/rules/landmark-unique-matches.js +0 -41
- data/node_modules/axe-core/lib/rules/landmark-unique.json +0 -13
- data/node_modules/axe-core/lib/rules/layout-table-matches.js +0 -8
- data/node_modules/axe-core/lib/rules/layout-table.json +0 -14
- data/node_modules/axe-core/lib/rules/link-in-text-block-matches.js +0 -14
- data/node_modules/axe-core/lib/rules/link-in-text-block.json +0 -14
- data/node_modules/axe-core/lib/rules/link-name.json +0 -25
- data/node_modules/axe-core/lib/rules/list.json +0 -13
- data/node_modules/axe-core/lib/rules/listitem.json +0 -13
- data/node_modules/axe-core/lib/rules/marquee.json +0 -13
- data/node_modules/axe-core/lib/rules/meta-refresh.json +0 -20
- data/node_modules/axe-core/lib/rules/meta-viewport-large.json +0 -13
- data/node_modules/axe-core/lib/rules/meta-viewport.json +0 -13
- data/node_modules/axe-core/lib/rules/no-autoplay-audio-matches.js +0 -18
- data/node_modules/axe-core/lib/rules/no-autoplay-audio.json +0 -15
- data/node_modules/axe-core/lib/rules/no-empty-role-matches.js +0 -9
- data/node_modules/axe-core/lib/rules/no-role-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/not-html-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/object-alt.json +0 -25
- data/node_modules/axe-core/lib/rules/p-as-heading-matches.js +0 -17
- data/node_modules/axe-core/lib/rules/p-as-heading.json +0 -13
- data/node_modules/axe-core/lib/rules/page-has-heading-one.json +0 -12
- data/node_modules/axe-core/lib/rules/radiogroup.json +0 -13
- data/node_modules/axe-core/lib/rules/region.json +0 -12
- data/node_modules/axe-core/lib/rules/role-img-alt.json +0 -19
- data/node_modules/axe-core/lib/rules/scope-attr-valid.json +0 -12
- data/node_modules/axe-core/lib/rules/scrollable-region-focusable-matches.js +0 -30
- data/node_modules/axe-core/lib/rules/scrollable-region-focusable.json +0 -12
- data/node_modules/axe-core/lib/rules/server-side-image-map.json +0 -18
- data/node_modules/axe-core/lib/rules/skip-link-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/skip-link.json +0 -13
- data/node_modules/axe-core/lib/rules/svg-img-alt.json +0 -24
- data/node_modules/axe-core/lib/rules/svg-namespace-matches.js +0 -1
- data/node_modules/axe-core/lib/rules/tabindex.json +0 -12
- data/node_modules/axe-core/lib/rules/table-duplicate-name.json +0 -12
- data/node_modules/axe-core/lib/rules/table-fake-caption.json +0 -20
- data/node_modules/axe-core/lib/rules/td-has-header.json +0 -20
- data/node_modules/axe-core/lib/rules/td-headers-attr.json +0 -12
- data/node_modules/axe-core/lib/rules/th-has-data-cells.json +0 -13
- data/node_modules/axe-core/lib/rules/valid-lang.json +0 -13
- data/node_modules/axe-core/lib/rules/video-caption.json +0 -19
- data/node_modules/axe-core/lib/rules/video-description.json +0 -21
- data/node_modules/axe-core/lib/rules/window-is-top.js +0 -3
- data/node_modules/axe-core/lib/rules/xml-lang-mismatch-matches.js +0 -12
- data/node_modules/axe-core/typings/axe-core/axe-core-tests.ts +0 -188
@@ -1,560 +0,0 @@
|
|
1
|
-
/*global RuleResult, createExecutionContext, SupportError */
|
2
|
-
|
3
|
-
function Rule(spec, parentAudit) {
|
4
|
-
'use strict';
|
5
|
-
|
6
|
-
this._audit = parentAudit;
|
7
|
-
|
8
|
-
/**
|
9
|
-
* The code, or string ID of the rule
|
10
|
-
* @type {String}
|
11
|
-
*/
|
12
|
-
this.id = spec.id;
|
13
|
-
|
14
|
-
/**
|
15
|
-
* Selector that this rule applies to
|
16
|
-
* @type {String}
|
17
|
-
*/
|
18
|
-
this.selector = spec.selector || '*';
|
19
|
-
|
20
|
-
/**
|
21
|
-
* Whether to exclude hiddden elements form analysis. Defaults to true.
|
22
|
-
* @type {Boolean}
|
23
|
-
*/
|
24
|
-
this.excludeHidden =
|
25
|
-
typeof spec.excludeHidden === 'boolean' ? spec.excludeHidden : true;
|
26
|
-
|
27
|
-
/**
|
28
|
-
* Flag to enable or disable rule
|
29
|
-
* @type {Boolean}
|
30
|
-
*/
|
31
|
-
this.enabled = typeof spec.enabled === 'boolean' ? spec.enabled : true;
|
32
|
-
|
33
|
-
/**
|
34
|
-
* Denotes if the rule should be run if Context is not an entire page AND whether
|
35
|
-
* the Rule should be satisified regardless of Node
|
36
|
-
* @type {Boolean}
|
37
|
-
*/
|
38
|
-
this.pageLevel = typeof spec.pageLevel === 'boolean' ? spec.pageLevel : false;
|
39
|
-
|
40
|
-
/**
|
41
|
-
* Checks that any may return true to satisfy rule
|
42
|
-
* @type {Array}
|
43
|
-
*/
|
44
|
-
this.any = spec.any || [];
|
45
|
-
|
46
|
-
/**
|
47
|
-
* Checks that must all return true to satisfy rule
|
48
|
-
* @type {Array}
|
49
|
-
*/
|
50
|
-
this.all = spec.all || [];
|
51
|
-
|
52
|
-
/**
|
53
|
-
* Checks that none may return true to satisfy rule
|
54
|
-
* @type {Array}
|
55
|
-
*/
|
56
|
-
this.none = spec.none || [];
|
57
|
-
|
58
|
-
/**
|
59
|
-
* Tags associated to this rule
|
60
|
-
* @type {Array}
|
61
|
-
*/
|
62
|
-
this.tags = spec.tags || [];
|
63
|
-
|
64
|
-
/**
|
65
|
-
* Preload necessary for this rule
|
66
|
-
*/
|
67
|
-
this.preload = spec.preload ? true : false;
|
68
|
-
|
69
|
-
if (spec.matches) {
|
70
|
-
/**
|
71
|
-
* Optional function to test if rule should be run against a node, overrides Rule#matches
|
72
|
-
* @type {Function}
|
73
|
-
*/
|
74
|
-
this.matches = createExecutionContext(spec.matches);
|
75
|
-
}
|
76
|
-
}
|
77
|
-
|
78
|
-
/**
|
79
|
-
* Optionally test each node against a `matches` function to determine if the rule should run against
|
80
|
-
* a given node. Defaults to `true`.
|
81
|
-
* @return {Boolean} Whether the rule should run
|
82
|
-
*/
|
83
|
-
Rule.prototype.matches = function() {
|
84
|
-
'use strict';
|
85
|
-
|
86
|
-
return true;
|
87
|
-
};
|
88
|
-
|
89
|
-
/**
|
90
|
-
* Selects `HTMLElement`s based on configured selector
|
91
|
-
* @param {Context} context The resolved Context object
|
92
|
-
* @param {Mixed} options Options specific to this rule
|
93
|
-
* @return {Array} All matching `HTMLElement`s
|
94
|
-
*/
|
95
|
-
Rule.prototype.gather = function(context, options = {}) {
|
96
|
-
const markStart = 'mark_gather_start_' + this.id;
|
97
|
-
const markEnd = 'mark_gather_end_' + this.id;
|
98
|
-
const markHiddenStart = 'mark_isHidden_start_' + this.id;
|
99
|
-
const markHiddenEnd = 'mark_isHidden_end_' + this.id;
|
100
|
-
|
101
|
-
if (options.performanceTimer) {
|
102
|
-
axe.utils.performanceTimer.mark(markStart);
|
103
|
-
}
|
104
|
-
|
105
|
-
var elements = axe.utils.select(this.selector, context);
|
106
|
-
if (this.excludeHidden) {
|
107
|
-
if (options.performanceTimer) {
|
108
|
-
axe.utils.performanceTimer.mark(markHiddenStart);
|
109
|
-
}
|
110
|
-
|
111
|
-
elements = elements.filter(function(element) {
|
112
|
-
return !axe.utils.isHidden(element.actualNode);
|
113
|
-
});
|
114
|
-
|
115
|
-
if (options.performanceTimer) {
|
116
|
-
axe.utils.performanceTimer.mark(markHiddenEnd);
|
117
|
-
axe.utils.performanceTimer.measure(
|
118
|
-
'rule_' + this.id + '#gather_axe.utils.isHidden',
|
119
|
-
markHiddenStart,
|
120
|
-
markHiddenEnd
|
121
|
-
);
|
122
|
-
}
|
123
|
-
}
|
124
|
-
|
125
|
-
if (options.performanceTimer) {
|
126
|
-
axe.utils.performanceTimer.mark(markEnd);
|
127
|
-
axe.utils.performanceTimer.measure(
|
128
|
-
'rule_' + this.id + '#gather',
|
129
|
-
markStart,
|
130
|
-
markEnd
|
131
|
-
);
|
132
|
-
}
|
133
|
-
|
134
|
-
return elements;
|
135
|
-
};
|
136
|
-
|
137
|
-
Rule.prototype.runChecks = function(
|
138
|
-
type,
|
139
|
-
node,
|
140
|
-
options,
|
141
|
-
context,
|
142
|
-
resolve,
|
143
|
-
reject
|
144
|
-
) {
|
145
|
-
'use strict';
|
146
|
-
|
147
|
-
var self = this;
|
148
|
-
|
149
|
-
var checkQueue = axe.utils.queue();
|
150
|
-
|
151
|
-
this[type].forEach(function(c) {
|
152
|
-
var check = self._audit.checks[c.id || c];
|
153
|
-
var option = axe.utils.getCheckOption(check, self.id, options);
|
154
|
-
checkQueue.defer(function(res, rej) {
|
155
|
-
check.run(node, option, context, res, rej);
|
156
|
-
});
|
157
|
-
});
|
158
|
-
|
159
|
-
checkQueue
|
160
|
-
.then(function(results) {
|
161
|
-
results = results.filter(function(check) {
|
162
|
-
return check;
|
163
|
-
});
|
164
|
-
resolve({ type: type, results: results });
|
165
|
-
})
|
166
|
-
.catch(reject);
|
167
|
-
};
|
168
|
-
|
169
|
-
/**
|
170
|
-
* Run a check for a rule synchronously.
|
171
|
-
*/
|
172
|
-
Rule.prototype.runChecksSync = function(type, node, options, context) {
|
173
|
-
'use strict';
|
174
|
-
|
175
|
-
const self = this;
|
176
|
-
let results = [];
|
177
|
-
|
178
|
-
this[type].forEach(function(c) {
|
179
|
-
const check = self._audit.checks[c.id || c];
|
180
|
-
const option = axe.utils.getCheckOption(check, self.id, options);
|
181
|
-
results.push(check.runSync(node, option, context));
|
182
|
-
});
|
183
|
-
|
184
|
-
results = results.filter(function(check) {
|
185
|
-
return check;
|
186
|
-
});
|
187
|
-
|
188
|
-
return { type: type, results: results };
|
189
|
-
};
|
190
|
-
|
191
|
-
/**
|
192
|
-
* Runs the Rule's `evaluate` function
|
193
|
-
* @param {Context} context The resolved Context object
|
194
|
-
* @param {Mixed} options Options specific to this rule
|
195
|
-
* @param {Function} callback Function to call when evaluate is complete; receives a RuleResult instance
|
196
|
-
*/
|
197
|
-
Rule.prototype.run = function(context, options = {}, resolve, reject) {
|
198
|
-
if (options.performanceTimer) {
|
199
|
-
this._trackPerformance();
|
200
|
-
}
|
201
|
-
|
202
|
-
const q = axe.utils.queue();
|
203
|
-
const ruleResult = new RuleResult(this);
|
204
|
-
let nodes;
|
205
|
-
|
206
|
-
try {
|
207
|
-
// Matches throws an error when it lacks support for document methods
|
208
|
-
nodes = this.gatherAndMatchNodes(context, options);
|
209
|
-
} catch (error) {
|
210
|
-
// Exit the rule execution if matches fails
|
211
|
-
reject(new SupportError({ cause: error, ruleId: this.id }));
|
212
|
-
return;
|
213
|
-
}
|
214
|
-
|
215
|
-
if (options.performanceTimer) {
|
216
|
-
this._logGatherPerformance(nodes);
|
217
|
-
}
|
218
|
-
|
219
|
-
nodes.forEach(node => {
|
220
|
-
q.defer((resolveNode, rejectNode) => {
|
221
|
-
var checkQueue = axe.utils.queue();
|
222
|
-
|
223
|
-
['any', 'all', 'none'].forEach(type => {
|
224
|
-
checkQueue.defer((res, rej) => {
|
225
|
-
this.runChecks(type, node, options, context, res, rej);
|
226
|
-
});
|
227
|
-
});
|
228
|
-
|
229
|
-
checkQueue
|
230
|
-
.then(function(results) {
|
231
|
-
const result = getResult(results);
|
232
|
-
if (result) {
|
233
|
-
result.node = new axe.utils.DqElement(node.actualNode, options);
|
234
|
-
ruleResult.nodes.push(result);
|
235
|
-
}
|
236
|
-
resolveNode();
|
237
|
-
})
|
238
|
-
.catch(err => rejectNode(err));
|
239
|
-
});
|
240
|
-
});
|
241
|
-
|
242
|
-
// Defer the rule's execution to prevent "unresponsive script" warnings.
|
243
|
-
// See https://github.com/dequelabs/axe-core/pull/1172 for discussion and details.
|
244
|
-
q.defer(resolve => setTimeout(resolve, 0));
|
245
|
-
|
246
|
-
if (options.performanceTimer) {
|
247
|
-
this._logRulePerformance();
|
248
|
-
}
|
249
|
-
|
250
|
-
q.then(() => resolve(ruleResult)).catch(error => reject(error));
|
251
|
-
};
|
252
|
-
|
253
|
-
/**
|
254
|
-
* Runs the Rule's `evaluate` function synchronously
|
255
|
-
* @param {Context} context The resolved Context object
|
256
|
-
* @param {Mixed} options Options specific to this rule
|
257
|
-
*/
|
258
|
-
Rule.prototype.runSync = function(context, options = {}) {
|
259
|
-
if (options.performanceTimer) {
|
260
|
-
this._trackPerformance();
|
261
|
-
}
|
262
|
-
|
263
|
-
const ruleResult = new RuleResult(this);
|
264
|
-
let nodes;
|
265
|
-
|
266
|
-
try {
|
267
|
-
nodes = this.gatherAndMatchNodes(context, options);
|
268
|
-
} catch (error) {
|
269
|
-
// Exit the rule execution if matches fails
|
270
|
-
throw new SupportError({ cause: error, ruleId: this.id });
|
271
|
-
}
|
272
|
-
|
273
|
-
if (options.performanceTimer) {
|
274
|
-
this._logGatherPerformance(nodes);
|
275
|
-
}
|
276
|
-
|
277
|
-
nodes.forEach(node => {
|
278
|
-
let results = [];
|
279
|
-
['any', 'all', 'none'].forEach(type => {
|
280
|
-
results.push(this.runChecksSync(type, node, options, context));
|
281
|
-
});
|
282
|
-
|
283
|
-
const result = getResult(results);
|
284
|
-
if (result) {
|
285
|
-
result.node = node.actualNode
|
286
|
-
? new axe.utils.DqElement(node.actualNode, options)
|
287
|
-
: null;
|
288
|
-
ruleResult.nodes.push(result);
|
289
|
-
}
|
290
|
-
});
|
291
|
-
|
292
|
-
if (options.performanceTimer) {
|
293
|
-
this._logRulePerformance();
|
294
|
-
}
|
295
|
-
|
296
|
-
return ruleResult;
|
297
|
-
};
|
298
|
-
|
299
|
-
/**
|
300
|
-
* Add performance tracking properties to the rule
|
301
|
-
* @private
|
302
|
-
*/
|
303
|
-
Rule.prototype._trackPerformance = function() {
|
304
|
-
this._markStart = 'mark_rule_start_' + this.id;
|
305
|
-
this._markEnd = 'mark_rule_end_' + this.id;
|
306
|
-
this._markChecksStart = 'mark_runchecks_start_' + this.id;
|
307
|
-
this._markChecksEnd = 'mark_runchecks_end_' + this.id;
|
308
|
-
};
|
309
|
-
|
310
|
-
/**
|
311
|
-
* Log performance of rule.gather
|
312
|
-
* @private
|
313
|
-
* @param {Rule} rule The rule to log
|
314
|
-
* @param {Array} nodes Result of rule.gather
|
315
|
-
*/
|
316
|
-
Rule.prototype._logGatherPerformance = function(nodes) {
|
317
|
-
axe.log(
|
318
|
-
'gather (',
|
319
|
-
nodes.length,
|
320
|
-
'):',
|
321
|
-
axe.utils.performanceTimer.timeElapsed() + 'ms'
|
322
|
-
);
|
323
|
-
axe.utils.performanceTimer.mark(this._markChecksStart);
|
324
|
-
};
|
325
|
-
|
326
|
-
/**
|
327
|
-
* Log performance of the rule
|
328
|
-
* @private
|
329
|
-
* @param {Rule} rule The rule to log
|
330
|
-
*/
|
331
|
-
Rule.prototype._logRulePerformance = function() {
|
332
|
-
axe.utils.performanceTimer.mark(this._markChecksEnd);
|
333
|
-
axe.utils.performanceTimer.mark(this._markEnd);
|
334
|
-
axe.utils.performanceTimer.measure(
|
335
|
-
'runchecks_' + this.id,
|
336
|
-
this._markChecksStart,
|
337
|
-
this._markChecksEnd
|
338
|
-
);
|
339
|
-
|
340
|
-
axe.utils.performanceTimer.measure(
|
341
|
-
'rule_' + this.id,
|
342
|
-
this._markStart,
|
343
|
-
this._markEnd
|
344
|
-
);
|
345
|
-
};
|
346
|
-
|
347
|
-
/**
|
348
|
-
* Process the results of each check and return the result if a check
|
349
|
-
* has a result
|
350
|
-
* @private
|
351
|
-
* @param {Array} results Array of each check result
|
352
|
-
* @returns {Object|null}
|
353
|
-
*/
|
354
|
-
function getResult(results) {
|
355
|
-
if (results.length) {
|
356
|
-
let hasResults = false,
|
357
|
-
result = {};
|
358
|
-
results.forEach(function(r) {
|
359
|
-
const res = r.results.filter(function(result) {
|
360
|
-
return result;
|
361
|
-
});
|
362
|
-
result[r.type] = res;
|
363
|
-
if (res.length) {
|
364
|
-
hasResults = true;
|
365
|
-
}
|
366
|
-
});
|
367
|
-
|
368
|
-
if (hasResults) {
|
369
|
-
return result;
|
370
|
-
}
|
371
|
-
|
372
|
-
return null;
|
373
|
-
}
|
374
|
-
}
|
375
|
-
|
376
|
-
/**
|
377
|
-
* Selects `HTMLElement`s based on configured selector and filters them based on
|
378
|
-
* the rules matches function
|
379
|
-
* @param {Rule} rule The rule to check for after checks
|
380
|
-
* @param {Context} context The resolved Context object
|
381
|
-
* @param {Mixed} options Options specific to this rule
|
382
|
-
* @return {Array} All matching `HTMLElement`s
|
383
|
-
*/
|
384
|
-
Rule.prototype.gatherAndMatchNodes = function(context, options) {
|
385
|
-
const markMatchesStart = 'mark_matches_start_' + this.id;
|
386
|
-
const markMatchesEnd = 'mark_matches_end_' + this.id;
|
387
|
-
|
388
|
-
let nodes = this.gather(context, options);
|
389
|
-
|
390
|
-
if (options.performanceTimer) {
|
391
|
-
axe.utils.performanceTimer.mark(markMatchesStart);
|
392
|
-
}
|
393
|
-
|
394
|
-
nodes = nodes.filter(node => this.matches(node.actualNode, node, context));
|
395
|
-
|
396
|
-
if (options.performanceTimer) {
|
397
|
-
axe.utils.performanceTimer.mark(markMatchesEnd);
|
398
|
-
axe.utils.performanceTimer.measure(
|
399
|
-
'rule_' + this.id + '#matches',
|
400
|
-
markMatchesStart,
|
401
|
-
markMatchesEnd
|
402
|
-
);
|
403
|
-
}
|
404
|
-
|
405
|
-
return nodes;
|
406
|
-
};
|
407
|
-
|
408
|
-
/**
|
409
|
-
* Iterates the rule's Checks looking for ones that have an after function
|
410
|
-
* @private
|
411
|
-
* @param {Rule} rule The rule to check for after checks
|
412
|
-
* @return {Array} Checks that have an after function
|
413
|
-
*/
|
414
|
-
function findAfterChecks(rule) {
|
415
|
-
'use strict';
|
416
|
-
|
417
|
-
return axe.utils
|
418
|
-
.getAllChecks(rule)
|
419
|
-
.map(function(c) {
|
420
|
-
var check = rule._audit.checks[c.id || c];
|
421
|
-
return check && typeof check.after === 'function' ? check : null;
|
422
|
-
})
|
423
|
-
.filter(Boolean);
|
424
|
-
}
|
425
|
-
|
426
|
-
/**
|
427
|
-
* Finds and collates all results for a given Check on a specific Rule
|
428
|
-
* @private
|
429
|
-
* @param {Array} nodes RuleResult#nodes; array of 'detail' objects
|
430
|
-
* @param {String} checkID The ID of the Check to find
|
431
|
-
* @return {Array} Matching CheckResults
|
432
|
-
*/
|
433
|
-
function findCheckResults(nodes, checkID) {
|
434
|
-
'use strict';
|
435
|
-
|
436
|
-
var checkResults = [];
|
437
|
-
nodes.forEach(function(nodeResult) {
|
438
|
-
var checks = axe.utils.getAllChecks(nodeResult);
|
439
|
-
checks.forEach(function(checkResult) {
|
440
|
-
if (checkResult.id === checkID) {
|
441
|
-
checkResults.push(checkResult);
|
442
|
-
}
|
443
|
-
});
|
444
|
-
});
|
445
|
-
return checkResults;
|
446
|
-
}
|
447
|
-
|
448
|
-
function filterChecks(checks) {
|
449
|
-
'use strict';
|
450
|
-
|
451
|
-
return checks.filter(function(check) {
|
452
|
-
return check.filtered !== true;
|
453
|
-
});
|
454
|
-
}
|
455
|
-
|
456
|
-
function sanitizeNodes(result) {
|
457
|
-
'use strict';
|
458
|
-
var checkTypes = ['any', 'all', 'none'];
|
459
|
-
|
460
|
-
var nodes = result.nodes.filter(function(detail) {
|
461
|
-
var length = 0;
|
462
|
-
checkTypes.forEach(function(type) {
|
463
|
-
detail[type] = filterChecks(detail[type]);
|
464
|
-
length += detail[type].length;
|
465
|
-
});
|
466
|
-
return length > 0;
|
467
|
-
});
|
468
|
-
|
469
|
-
if (result.pageLevel && nodes.length) {
|
470
|
-
nodes = [
|
471
|
-
nodes.reduce(function(a, b) {
|
472
|
-
if (a) {
|
473
|
-
checkTypes.forEach(function(type) {
|
474
|
-
a[type].push.apply(a[type], b[type]);
|
475
|
-
});
|
476
|
-
return a;
|
477
|
-
}
|
478
|
-
})
|
479
|
-
];
|
480
|
-
}
|
481
|
-
return nodes;
|
482
|
-
}
|
483
|
-
|
484
|
-
/**
|
485
|
-
* Runs all of the Rule's Check#after methods
|
486
|
-
* @param {RuleResult} result The "pre-after" RuleResult
|
487
|
-
* @param {Mixed} options Options specific to the rule
|
488
|
-
* @return {RuleResult} The RuleResult as filtered by after functions
|
489
|
-
*/
|
490
|
-
Rule.prototype.after = function(result, options) {
|
491
|
-
'use strict';
|
492
|
-
|
493
|
-
var afterChecks = findAfterChecks(this);
|
494
|
-
var ruleID = this.id;
|
495
|
-
afterChecks.forEach(function(check) {
|
496
|
-
var beforeResults = findCheckResults(result.nodes, check.id);
|
497
|
-
var option = axe.utils.getCheckOption(check, ruleID, options);
|
498
|
-
|
499
|
-
var afterResults = check.after(beforeResults, option);
|
500
|
-
beforeResults.forEach(function(item) {
|
501
|
-
if (afterResults.indexOf(item) === -1) {
|
502
|
-
item.filtered = true;
|
503
|
-
}
|
504
|
-
});
|
505
|
-
});
|
506
|
-
|
507
|
-
result.nodes = sanitizeNodes(result);
|
508
|
-
return result;
|
509
|
-
};
|
510
|
-
|
511
|
-
/**
|
512
|
-
* Reconfigure a rule after it has been added
|
513
|
-
* @param {Object} spec - the attributes to be reconfigured
|
514
|
-
*/
|
515
|
-
Rule.prototype.configure = function(spec) {
|
516
|
-
/*eslint no-eval:0 */
|
517
|
-
'use strict';
|
518
|
-
|
519
|
-
if (spec.hasOwnProperty('selector')) {
|
520
|
-
this.selector = spec.selector;
|
521
|
-
}
|
522
|
-
|
523
|
-
if (spec.hasOwnProperty('excludeHidden')) {
|
524
|
-
this.excludeHidden =
|
525
|
-
typeof spec.excludeHidden === 'boolean' ? spec.excludeHidden : true;
|
526
|
-
}
|
527
|
-
|
528
|
-
if (spec.hasOwnProperty('enabled')) {
|
529
|
-
this.enabled = typeof spec.enabled === 'boolean' ? spec.enabled : true;
|
530
|
-
}
|
531
|
-
|
532
|
-
if (spec.hasOwnProperty('pageLevel')) {
|
533
|
-
this.pageLevel =
|
534
|
-
typeof spec.pageLevel === 'boolean' ? spec.pageLevel : false;
|
535
|
-
}
|
536
|
-
|
537
|
-
if (spec.hasOwnProperty('any')) {
|
538
|
-
this.any = spec.any;
|
539
|
-
}
|
540
|
-
|
541
|
-
if (spec.hasOwnProperty('all')) {
|
542
|
-
this.all = spec.all;
|
543
|
-
}
|
544
|
-
|
545
|
-
if (spec.hasOwnProperty('none')) {
|
546
|
-
this.none = spec.none;
|
547
|
-
}
|
548
|
-
|
549
|
-
if (spec.hasOwnProperty('tags')) {
|
550
|
-
this.tags = spec.tags;
|
551
|
-
}
|
552
|
-
|
553
|
-
if (spec.hasOwnProperty('matches')) {
|
554
|
-
if (typeof spec.matches === 'string') {
|
555
|
-
this.matches = new Function('return ' + spec.matches + ';')();
|
556
|
-
} else {
|
557
|
-
this.matches = spec.matches;
|
558
|
-
}
|
559
|
-
}
|
560
|
-
};
|
@@ -1,40 +0,0 @@
|
|
1
|
-
const whitespaceRegex = /[\t\r\n\f]/g;
|
2
|
-
|
3
|
-
class AbstractVirtualNode {
|
4
|
-
constructor() {
|
5
|
-
this.children = [];
|
6
|
-
this.parent = null;
|
7
|
-
}
|
8
|
-
|
9
|
-
get props() {
|
10
|
-
throw new Error(
|
11
|
-
'VirtualNode class must have a "props" object consisting ' +
|
12
|
-
'of "nodeType" and "nodeName" properties'
|
13
|
-
);
|
14
|
-
}
|
15
|
-
|
16
|
-
attr() {
|
17
|
-
throw new Error('VirtualNode class must have a "attr" function');
|
18
|
-
}
|
19
|
-
|
20
|
-
hasAttr() {
|
21
|
-
throw new Error('VirtualNode class must have a "hasAttr" function');
|
22
|
-
}
|
23
|
-
|
24
|
-
hasClass(className) {
|
25
|
-
// get the value of the class attribute as svgs return a SVGAnimatedString
|
26
|
-
// if you access the className property
|
27
|
-
let classAttr = this.attr('class');
|
28
|
-
if (!classAttr) {
|
29
|
-
return false;
|
30
|
-
}
|
31
|
-
|
32
|
-
let selector = ' ' + className + ' ';
|
33
|
-
return (
|
34
|
-
(' ' + classAttr + ' ').replace(whitespaceRegex, ' ').indexOf(selector) >=
|
35
|
-
0
|
36
|
-
);
|
37
|
-
}
|
38
|
-
}
|
39
|
-
|
40
|
-
axe.AbstractVirtualNode = AbstractVirtualNode;
|
@@ -1,88 +0,0 @@
|
|
1
|
-
// eslint-disable-next-line no-unused-vars
|
2
|
-
class SerialVirtualNode extends axe.AbstractVirtualNode {
|
3
|
-
/**
|
4
|
-
* Convert a serialised node into a VirtualNode object
|
5
|
-
* @param {Object} node Serialised node
|
6
|
-
*/
|
7
|
-
constructor(serialNode) {
|
8
|
-
super();
|
9
|
-
this._props = normaliseProps(serialNode);
|
10
|
-
this._attrs = normaliseAttrs(serialNode);
|
11
|
-
}
|
12
|
-
|
13
|
-
// Accessof for DOM node properties
|
14
|
-
get props() {
|
15
|
-
return this._props;
|
16
|
-
}
|
17
|
-
|
18
|
-
/**
|
19
|
-
* Get the value of the given attribute name.
|
20
|
-
* @param {String} attrName The name of the attribute.
|
21
|
-
* @return {String|null} The value of the attribute or null if the attribute does not exist
|
22
|
-
*/
|
23
|
-
attr(attrName) {
|
24
|
-
return this._attrs[attrName] || null;
|
25
|
-
}
|
26
|
-
|
27
|
-
/**
|
28
|
-
* Determine if the element has the given attribute.
|
29
|
-
* @param {String} attrName The name of the attribute
|
30
|
-
* @return {Boolean} True if the element has the attribute, false otherwise.
|
31
|
-
*/
|
32
|
-
hasAttr(attrName) {
|
33
|
-
return this._attrs[attrName] !== undefined;
|
34
|
-
}
|
35
|
-
}
|
36
|
-
|
37
|
-
/**
|
38
|
-
* Convert between serialised props and DOM-like properties
|
39
|
-
* @param {Object} serialNode
|
40
|
-
* @return {Object} normalProperties
|
41
|
-
*/
|
42
|
-
function normaliseProps(serialNode) {
|
43
|
-
let { nodeName, nodeType = 1 } = serialNode;
|
44
|
-
axe.utils.assert(
|
45
|
-
nodeType === 1,
|
46
|
-
`nodeType has to be undefined or 1, got '${nodeType}'`
|
47
|
-
);
|
48
|
-
axe.utils.assert(
|
49
|
-
typeof nodeName === 'string',
|
50
|
-
`nodeName has to be a string, got '${nodeName}'`
|
51
|
-
);
|
52
|
-
|
53
|
-
const props = {
|
54
|
-
...serialNode,
|
55
|
-
nodeType,
|
56
|
-
nodeName: nodeName.toLowerCase()
|
57
|
-
};
|
58
|
-
delete props.attributes;
|
59
|
-
return Object.freeze(props);
|
60
|
-
}
|
61
|
-
|
62
|
-
/**
|
63
|
-
* Convert between serialised attributes and DOM-like attributes
|
64
|
-
* @param {Object} serialNode
|
65
|
-
* @return {Object} normalAttributes
|
66
|
-
*/
|
67
|
-
function normaliseAttrs({ attributes = {} }) {
|
68
|
-
const attrMap = {
|
69
|
-
htmlFor: 'for',
|
70
|
-
className: 'class'
|
71
|
-
};
|
72
|
-
|
73
|
-
return Object.keys(attributes).reduce((attrs, attrName) => {
|
74
|
-
const value = attributes[attrName];
|
75
|
-
axe.utils.assert(
|
76
|
-
typeof value !== 'object' || value === null,
|
77
|
-
`expects attributes not to be an object, '${attrName}' was`
|
78
|
-
);
|
79
|
-
|
80
|
-
if (value !== undefined) {
|
81
|
-
const mappedName = attrMap[attrName] || attrName;
|
82
|
-
attrs[mappedName] = value !== null ? String(value) : null;
|
83
|
-
}
|
84
|
-
return attrs;
|
85
|
-
}, {});
|
86
|
-
}
|
87
|
-
|
88
|
-
axe.SerialVirtualNode = SerialVirtualNode;
|