govuk_publishing_components 30.4.1 → 30.5.2
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-core.js +20 -0
- 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 +27 -0
- data/app/assets/javascripts/govuk_publishing_components/analytics-ga4.js +2 -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/config/locales/en.yml +8 -8
- 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 +7 -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,45 +0,0 @@
|
|
1
|
-
/* global dom */
|
2
|
-
|
3
|
-
// test for hrefs that start with # or /# (for angular)
|
4
|
-
const isInternalLinkRegex = /^\/?#[^/!]/;
|
5
|
-
|
6
|
-
/**
|
7
|
-
* Determines if element is a skip link
|
8
|
-
* @method isSkipLink
|
9
|
-
* @memberof axe.commons.dom
|
10
|
-
* @instance
|
11
|
-
* @param {Element} element
|
12
|
-
* @return {Boolean}
|
13
|
-
*/
|
14
|
-
dom.isSkipLink = function(element) {
|
15
|
-
if (!isInternalLinkRegex.test(element.getAttribute('href'))) {
|
16
|
-
return false;
|
17
|
-
}
|
18
|
-
|
19
|
-
let firstPageLink;
|
20
|
-
if (typeof axe._cache.get('firstPageLink') !== 'undefined') {
|
21
|
-
firstPageLink = axe._cache.get('firstPageLink');
|
22
|
-
} else {
|
23
|
-
// define a skip link as any anchor element whose href starts with `#...`
|
24
|
-
// and which precedes the first anchor element whose href doesn't start
|
25
|
-
// with `#...` (that is, a link to a page)
|
26
|
-
firstPageLink = axe.utils.querySelectorAll(
|
27
|
-
axe._tree,
|
28
|
-
'a:not([href^="#"]):not([href^="/#"]):not([href^="javascript"])'
|
29
|
-
)[0];
|
30
|
-
|
31
|
-
// null will signify no first page link
|
32
|
-
axe._cache.set('firstPageLink', firstPageLink || null);
|
33
|
-
}
|
34
|
-
|
35
|
-
// if there are no page links then all all links will need to be
|
36
|
-
// considered as skip links
|
37
|
-
if (!firstPageLink) {
|
38
|
-
return true;
|
39
|
-
}
|
40
|
-
|
41
|
-
return (
|
42
|
-
element.compareDocumentPosition(firstPageLink.actualNode) ===
|
43
|
-
element.DOCUMENT_POSITION_FOLLOWING
|
44
|
-
);
|
45
|
-
};
|
@@ -1,176 +0,0 @@
|
|
1
|
-
/* global dom */
|
2
|
-
const clipRegex = /rect\s*\(([0-9]+)px,?\s*([0-9]+)px,?\s*([0-9]+)px,?\s*([0-9]+)px\s*\)/;
|
3
|
-
const clipPathRegex = /(\w+)\((\d+)/;
|
4
|
-
|
5
|
-
/**
|
6
|
-
* Determines if an element is hidden with a clip or clip-path technique
|
7
|
-
* @method isClipped
|
8
|
-
* @memberof axe.commons.dom
|
9
|
-
* @private
|
10
|
-
* @param {CSSStyleDeclaration} style Computed style
|
11
|
-
* @return {Boolean}
|
12
|
-
*/
|
13
|
-
function isClipped(style) {
|
14
|
-
'use strict';
|
15
|
-
|
16
|
-
const matchesClip = style.getPropertyValue('clip').match(clipRegex);
|
17
|
-
const matchesClipPath = style
|
18
|
-
.getPropertyValue('clip-path')
|
19
|
-
.match(clipPathRegex);
|
20
|
-
if (matchesClip && matchesClip.length === 5) {
|
21
|
-
return (
|
22
|
-
matchesClip[3] - matchesClip[1] <= 0 &&
|
23
|
-
matchesClip[2] - matchesClip[4] <= 0
|
24
|
-
);
|
25
|
-
}
|
26
|
-
if (matchesClipPath) {
|
27
|
-
const type = matchesClipPath[1];
|
28
|
-
const value = parseInt(matchesClipPath[2], 10);
|
29
|
-
|
30
|
-
switch (type) {
|
31
|
-
case 'inset':
|
32
|
-
return value >= 50;
|
33
|
-
case 'circle':
|
34
|
-
return value === 0;
|
35
|
-
default:
|
36
|
-
}
|
37
|
-
}
|
38
|
-
|
39
|
-
return false;
|
40
|
-
}
|
41
|
-
|
42
|
-
/**
|
43
|
-
* Check `AREA` element is visible
|
44
|
-
* - validate if it is a child of `map`
|
45
|
-
* - ensure `map` is referred by `img` using the `usemap` attribute
|
46
|
-
* @param {Element} areaEl `AREA` element
|
47
|
-
* @retruns {Boolean}
|
48
|
-
*/
|
49
|
-
function isAreaVisible(el, screenReader, recursed) {
|
50
|
-
/**
|
51
|
-
* Note:
|
52
|
-
* - Verified that `map` element cannot refer to `area` elements across different document trees
|
53
|
-
* - Verified that `map` element does not get affected by altering `display` property
|
54
|
-
*/
|
55
|
-
const mapEl = dom.findUp(el, 'map');
|
56
|
-
if (!mapEl) {
|
57
|
-
return false;
|
58
|
-
}
|
59
|
-
|
60
|
-
const mapElName = mapEl.getAttribute('name');
|
61
|
-
if (!mapElName) {
|
62
|
-
return false;
|
63
|
-
}
|
64
|
-
|
65
|
-
/**
|
66
|
-
* `map` element has to be in light DOM
|
67
|
-
*/
|
68
|
-
const mapElRootNode = dom.getRootNode(el);
|
69
|
-
if (!mapElRootNode || mapElRootNode.nodeType !== 9) {
|
70
|
-
return false;
|
71
|
-
}
|
72
|
-
|
73
|
-
const refs = axe.utils.querySelectorAll(
|
74
|
-
axe._tree,
|
75
|
-
`img[usemap="#${axe.utils.escapeSelector(mapElName)}"]`
|
76
|
-
);
|
77
|
-
if (!refs || !refs.length) {
|
78
|
-
return false;
|
79
|
-
}
|
80
|
-
|
81
|
-
return refs.some(({ actualNode }) =>
|
82
|
-
dom.isVisible(actualNode, screenReader, recursed)
|
83
|
-
);
|
84
|
-
}
|
85
|
-
|
86
|
-
/**
|
87
|
-
* Determine whether an element is visible
|
88
|
-
* @method isVisible
|
89
|
-
* @memberof axe.commons.dom
|
90
|
-
* @instance
|
91
|
-
* @param {HTMLElement} el The HTMLElement
|
92
|
-
* @param {Boolean} screenReader When provided, will evaluate visibility from the perspective of a screen reader
|
93
|
-
* @param {Boolean} recursed
|
94
|
-
* @return {Boolean} The element's visibilty status
|
95
|
-
*/
|
96
|
-
dom.isVisible = function(el, screenReader, recursed) {
|
97
|
-
'use strict';
|
98
|
-
const node = axe.utils.getNodeFromTree(el);
|
99
|
-
const cacheName = '_isVisible' + (screenReader ? 'ScreenReader' : '');
|
100
|
-
|
101
|
-
// 9 === Node.DOCUMENT
|
102
|
-
if (el.nodeType === 9) {
|
103
|
-
return true;
|
104
|
-
}
|
105
|
-
|
106
|
-
// 11 === Node.DOCUMENT_FRAGMENT_NODE
|
107
|
-
if (el.nodeType === 11) {
|
108
|
-
el = el.host; // grab the host Node
|
109
|
-
}
|
110
|
-
|
111
|
-
if (node && typeof node[cacheName] !== 'undefined') {
|
112
|
-
return node[cacheName];
|
113
|
-
}
|
114
|
-
|
115
|
-
const style = window.getComputedStyle(el, null);
|
116
|
-
if (style === null) {
|
117
|
-
return false;
|
118
|
-
}
|
119
|
-
|
120
|
-
const nodeName = el.nodeName.toUpperCase();
|
121
|
-
/**
|
122
|
-
* check visibility of `AREA` * check visibility of `AREA`
|
123
|
-
* Note:
|
124
|
-
* Firefox's user-agent always sets `AREA` element to `display:none`
|
125
|
-
* hence excluding the edge case, for visibility computation
|
126
|
-
*/
|
127
|
-
if (nodeName === 'AREA') {
|
128
|
-
return isAreaVisible(el, screenReader, recursed);
|
129
|
-
}
|
130
|
-
|
131
|
-
// always hidden
|
132
|
-
if (
|
133
|
-
style.getPropertyValue('display') === 'none' ||
|
134
|
-
['STYLE', 'SCRIPT', 'NOSCRIPT', 'TEMPLATE'].includes(nodeName)
|
135
|
-
) {
|
136
|
-
return false;
|
137
|
-
}
|
138
|
-
|
139
|
-
// hidden from screen readers
|
140
|
-
if (screenReader && el.getAttribute('aria-hidden') === 'true') {
|
141
|
-
return false;
|
142
|
-
}
|
143
|
-
|
144
|
-
// hidden from visual users
|
145
|
-
if (
|
146
|
-
!screenReader &&
|
147
|
-
(isClipped(style) ||
|
148
|
-
style.getPropertyValue('opacity') === '0' ||
|
149
|
-
(axe.utils.getScroll(el) &&
|
150
|
-
parseInt(style.getPropertyValue('height')) === 0))
|
151
|
-
) {
|
152
|
-
return false;
|
153
|
-
}
|
154
|
-
|
155
|
-
// visibility is only accurate on the first element and
|
156
|
-
// position does not matter if it was already calculated
|
157
|
-
if (
|
158
|
-
!recursed &&
|
159
|
-
(style.getPropertyValue('visibility') === 'hidden' ||
|
160
|
-
(!screenReader && axe.commons.dom.isOffscreen(el)))
|
161
|
-
) {
|
162
|
-
return false;
|
163
|
-
}
|
164
|
-
|
165
|
-
const parent = el.assignedSlot ? el.assignedSlot : el.parentNode;
|
166
|
-
let isVisible = false;
|
167
|
-
if (parent) {
|
168
|
-
isVisible = dom.isVisible(parent, screenReader, true);
|
169
|
-
}
|
170
|
-
|
171
|
-
if (node) {
|
172
|
-
node[cacheName] = isVisible;
|
173
|
-
}
|
174
|
-
|
175
|
-
return isVisible;
|
176
|
-
};
|
@@ -1,49 +0,0 @@
|
|
1
|
-
/*global dom */
|
2
|
-
|
3
|
-
const visualRoles = [
|
4
|
-
'checkbox',
|
5
|
-
'img',
|
6
|
-
'radio',
|
7
|
-
'range',
|
8
|
-
'slider',
|
9
|
-
'spinbutton',
|
10
|
-
'textbox'
|
11
|
-
];
|
12
|
-
|
13
|
-
/**
|
14
|
-
* Check if an element is an inherently visual element
|
15
|
-
* @method isVisualContent
|
16
|
-
* @memberof axe.commons.dom
|
17
|
-
* @instance
|
18
|
-
* @param {Element} element The element to check
|
19
|
-
* @return {Boolean}
|
20
|
-
*/
|
21
|
-
dom.isVisualContent = function(element) {
|
22
|
-
/*eslint indent: 0*/
|
23
|
-
const role = element.getAttribute('role');
|
24
|
-
if (role) {
|
25
|
-
return visualRoles.indexOf(role) !== -1;
|
26
|
-
}
|
27
|
-
|
28
|
-
switch (element.nodeName.toUpperCase()) {
|
29
|
-
case 'IMG':
|
30
|
-
case 'IFRAME':
|
31
|
-
case 'OBJECT':
|
32
|
-
case 'VIDEO':
|
33
|
-
case 'AUDIO':
|
34
|
-
case 'CANVAS':
|
35
|
-
case 'SVG':
|
36
|
-
case 'MATH':
|
37
|
-
case 'BUTTON':
|
38
|
-
case 'SELECT':
|
39
|
-
case 'TEXTAREA':
|
40
|
-
case 'KEYGEN':
|
41
|
-
case 'PROGRESS':
|
42
|
-
case 'METER':
|
43
|
-
return true;
|
44
|
-
case 'INPUT':
|
45
|
-
return element.type !== 'hidden';
|
46
|
-
default:
|
47
|
-
return false;
|
48
|
-
}
|
49
|
-
};
|
@@ -1,42 +0,0 @@
|
|
1
|
-
/* global axe, dom */
|
2
|
-
/**
|
3
|
-
* Get elements from point across shadow dom boundaries
|
4
|
-
* @method shadowElementsFromPoint
|
5
|
-
* @memberof axe.commons.dom
|
6
|
-
* @instance
|
7
|
-
* @param {Number} nodeX X coordinates of point
|
8
|
-
* @param {Number} nodeY Y coordinates of point
|
9
|
-
* @param {Object} [root] Shadow root or document root
|
10
|
-
* @return {Array}
|
11
|
-
*/
|
12
|
-
dom.shadowElementsFromPoint = function(nodeX, nodeY, root = document, i = 0) {
|
13
|
-
if (i > 999) {
|
14
|
-
throw new Error('Infinite loop detected');
|
15
|
-
}
|
16
|
-
return (
|
17
|
-
// IE can return null when there are no elements
|
18
|
-
Array.from(root.elementsFromPoint(nodeX, nodeY) || [])
|
19
|
-
// As of Chrome 66, elementFromPoint will return elements from parent trees.
|
20
|
-
// We only want to touch each tree once, so we're filtering out nodes on other trees.
|
21
|
-
.filter(nodes => dom.getRootNode(nodes) === root)
|
22
|
-
.reduce((stack, elm) => {
|
23
|
-
if (axe.utils.isShadowRoot(elm)) {
|
24
|
-
const shadowStack = dom.shadowElementsFromPoint(
|
25
|
-
nodeX,
|
26
|
-
nodeY,
|
27
|
-
elm.shadowRoot,
|
28
|
-
i + 1
|
29
|
-
);
|
30
|
-
stack = stack.concat(shadowStack);
|
31
|
-
// filter host nodes which get included regardless of overlap
|
32
|
-
// TODO: refactor multiline overlap checking inside shadow dom
|
33
|
-
if (stack.length && axe.commons.dom.visuallyContains(stack[0], elm)) {
|
34
|
-
stack.push(elm);
|
35
|
-
}
|
36
|
-
} else {
|
37
|
-
stack.push(elm);
|
38
|
-
}
|
39
|
-
return stack;
|
40
|
-
}, [])
|
41
|
-
);
|
42
|
-
};
|
@@ -1,152 +0,0 @@
|
|
1
|
-
/* global dom */
|
2
|
-
|
3
|
-
/**
|
4
|
-
* Parse resource object for a given node from a specified attribute
|
5
|
-
* @method urlPropsFromAttribute
|
6
|
-
* @param {HTMLElement} node given node
|
7
|
-
* @param {String} attribute attribute of the node from which resource should be parsed
|
8
|
-
* @returns {Object}
|
9
|
-
*/
|
10
|
-
dom.urlPropsFromAttribute = function urlPropsFromAttribute(node, attribute) {
|
11
|
-
if (!node.hasAttribute(attribute)) {
|
12
|
-
return undefined;
|
13
|
-
}
|
14
|
-
|
15
|
-
const nodeName = node.nodeName.toUpperCase();
|
16
|
-
let parser = node;
|
17
|
-
|
18
|
-
/**
|
19
|
-
* Note:
|
20
|
-
* The need to create a parser, is to keep this function generic, to be able to parse resource from element(s) like `iframe` with `src` attribute,
|
21
|
-
*
|
22
|
-
* Also, when `a` or `area` is nested inside an svg document,
|
23
|
-
* they do not have url properties as a HTML Node, hence the check for `ownerSVGElement`
|
24
|
-
*/
|
25
|
-
if (!['A', 'AREA'].includes(nodeName) || node.ownerSVGElement) {
|
26
|
-
parser = document.createElement('a');
|
27
|
-
parser.href = node.getAttribute(attribute);
|
28
|
-
}
|
29
|
-
|
30
|
-
/**
|
31
|
-
* Curate `https` and `ftps` to `http` and `ftp` as they will resolve to same resource
|
32
|
-
*/
|
33
|
-
const protocol = [`https:`, `ftps:`].includes(parser.protocol)
|
34
|
-
? parser.protocol.replace(/s:$/, ':')
|
35
|
-
: parser.protocol;
|
36
|
-
|
37
|
-
/**
|
38
|
-
* certain browser (in this case IE10 & 11)
|
39
|
-
* does not resolve pathname with a beginning slash, thence prepending with a beginning slash
|
40
|
-
*/
|
41
|
-
const parserPathname = /^\//.test(parser.pathname)
|
42
|
-
? parser.pathname
|
43
|
-
: `/${parser.pathname}`;
|
44
|
-
const { pathname, filename } = getPathnameOrFilename(parserPathname);
|
45
|
-
|
46
|
-
return {
|
47
|
-
protocol,
|
48
|
-
hostname: parser.hostname,
|
49
|
-
port: getPort(parser.port),
|
50
|
-
pathname: /\/$/.test(pathname) ? pathname : `${pathname}/`,
|
51
|
-
search: getSearchPairs(parser.search),
|
52
|
-
hash: getHashRoute(parser.hash),
|
53
|
-
filename
|
54
|
-
};
|
55
|
-
};
|
56
|
-
|
57
|
-
/**
|
58
|
-
* Resolve given port excluding default port(s)
|
59
|
-
* @param {String} port port
|
60
|
-
* @returns {String}
|
61
|
-
*/
|
62
|
-
function getPort(port) {
|
63
|
-
const excludePorts = [
|
64
|
-
`443`, // default `https` port
|
65
|
-
`80`
|
66
|
-
];
|
67
|
-
return !excludePorts.includes(port) ? port : ``;
|
68
|
-
}
|
69
|
-
|
70
|
-
/**
|
71
|
-
* Resolve if a given pathname has filename & resolve the same as parts
|
72
|
-
* @method getPathnameOrFilename
|
73
|
-
* @param {String} pathname pathname part of a given uri
|
74
|
-
* @returns {Array<Object>}
|
75
|
-
*/
|
76
|
-
function getPathnameOrFilename(pathname) {
|
77
|
-
const filename = pathname.split('/').pop();
|
78
|
-
if (!filename || filename.indexOf('.') === -1) {
|
79
|
-
return {
|
80
|
-
pathname,
|
81
|
-
filename: ``
|
82
|
-
};
|
83
|
-
}
|
84
|
-
|
85
|
-
return {
|
86
|
-
// remove `filename` from `pathname`
|
87
|
-
pathname: pathname.replace(filename, ''),
|
88
|
-
|
89
|
-
// ignore filename when index.*
|
90
|
-
filename: /index./.test(filename) ? `` : filename
|
91
|
-
};
|
92
|
-
}
|
93
|
-
|
94
|
-
/**
|
95
|
-
* Parse a given query string to key/value pairs sorted alphabetically
|
96
|
-
* @param {String} searchStr search string
|
97
|
-
* @returns {Object}
|
98
|
-
*/
|
99
|
-
function getSearchPairs(searchStr) {
|
100
|
-
const query = {};
|
101
|
-
|
102
|
-
if (!searchStr || !searchStr.length) {
|
103
|
-
return query;
|
104
|
-
}
|
105
|
-
|
106
|
-
// `substring` to remove `?` at the beginning of search string
|
107
|
-
const pairs = searchStr.substring(1).split(`&`);
|
108
|
-
if (!pairs || !pairs.length) {
|
109
|
-
return query;
|
110
|
-
}
|
111
|
-
|
112
|
-
for (let index = 0; index < pairs.length; index++) {
|
113
|
-
const pair = pairs[index];
|
114
|
-
const [key, value = ''] = pair.split(`=`);
|
115
|
-
query[decodeURIComponent(key)] = decodeURIComponent(value);
|
116
|
-
}
|
117
|
-
|
118
|
-
return query;
|
119
|
-
}
|
120
|
-
|
121
|
-
/**
|
122
|
-
* Interpret a given hash
|
123
|
-
* if `hash`
|
124
|
-
* -> is `hashbang` -or- `hash` is followed by `slash`
|
125
|
-
* -> it resolves to a different resource
|
126
|
-
* @method getHashRoute
|
127
|
-
* @param {String} hash hash component of a parsed uri
|
128
|
-
* @returns {String}
|
129
|
-
*/
|
130
|
-
function getHashRoute(hash) {
|
131
|
-
if (!hash) {
|
132
|
-
return ``;
|
133
|
-
}
|
134
|
-
|
135
|
-
/**
|
136
|
-
* Check for any conventionally-formatted hashbang that may be present
|
137
|
-
* eg: `#, #/, #!, #!/`
|
138
|
-
*/
|
139
|
-
const hashRegex = /#!?\/?/g;
|
140
|
-
const hasMatch = hash.match(hashRegex);
|
141
|
-
if (!hasMatch) {
|
142
|
-
return ``;
|
143
|
-
}
|
144
|
-
|
145
|
-
// do not resolve inline link as hash
|
146
|
-
const [matchedStr] = hasMatch;
|
147
|
-
if (matchedStr === '#') {
|
148
|
-
return ``;
|
149
|
-
}
|
150
|
-
|
151
|
-
return hash;
|
152
|
-
}
|
@@ -1,111 +0,0 @@
|
|
1
|
-
/* global dom */
|
2
|
-
|
3
|
-
/**
|
4
|
-
* Return the ancestor node that is a scroll region.
|
5
|
-
* @param {VirtualNode}
|
6
|
-
* @return {VirtualNode|null}
|
7
|
-
*/
|
8
|
-
function getScrollAncestor(node) {
|
9
|
-
const vNode = axe.utils.getNodeFromTree(node);
|
10
|
-
let ancestor = vNode.parent;
|
11
|
-
|
12
|
-
while (ancestor) {
|
13
|
-
if (axe.utils.getScroll(ancestor.actualNode)) {
|
14
|
-
return ancestor.actualNode;
|
15
|
-
}
|
16
|
-
|
17
|
-
ancestor = ancestor.parent;
|
18
|
-
}
|
19
|
-
}
|
20
|
-
|
21
|
-
/**
|
22
|
-
* Checks whether a parent element visually contains its child, either directly or via scrolling.
|
23
|
-
* Assumes that |parent| is an ancestor of |node|.
|
24
|
-
* @param {Element} node
|
25
|
-
* @param {Element} parent
|
26
|
-
* @return {boolean} True if node is visually contained within parent
|
27
|
-
*/
|
28
|
-
function contains(node, parent) {
|
29
|
-
const rectBound = node.getBoundingClientRect();
|
30
|
-
const margin = 0.01;
|
31
|
-
const rect = {
|
32
|
-
top: rectBound.top + margin,
|
33
|
-
bottom: rectBound.bottom - margin,
|
34
|
-
left: rectBound.left + margin,
|
35
|
-
right: rectBound.right - margin
|
36
|
-
};
|
37
|
-
|
38
|
-
const parentRect = parent.getBoundingClientRect();
|
39
|
-
const parentTop = parentRect.top;
|
40
|
-
const parentLeft = parentRect.left;
|
41
|
-
const parentScrollArea = {
|
42
|
-
top: parentTop - parent.scrollTop,
|
43
|
-
bottom: parentTop - parent.scrollTop + parent.scrollHeight,
|
44
|
-
left: parentLeft - parent.scrollLeft,
|
45
|
-
right: parentLeft - parent.scrollLeft + parent.scrollWidth
|
46
|
-
};
|
47
|
-
|
48
|
-
const style = window.getComputedStyle(parent);
|
49
|
-
|
50
|
-
// if parent element is inline, scrollArea will be too unpredictable
|
51
|
-
if (style.getPropertyValue('display') === 'inline') {
|
52
|
-
return true;
|
53
|
-
}
|
54
|
-
|
55
|
-
//In theory, we should just be able to look at the scroll area as a superset of the parentRect,
|
56
|
-
//but that's not true in Firefox
|
57
|
-
if (
|
58
|
-
(rect.left < parentScrollArea.left && rect.left < parentRect.left) ||
|
59
|
-
(rect.top < parentScrollArea.top && rect.top < parentRect.top) ||
|
60
|
-
(rect.right > parentScrollArea.right && rect.right > parentRect.right) ||
|
61
|
-
(rect.bottom > parentScrollArea.bottom && rect.bottom > parentRect.bottom)
|
62
|
-
) {
|
63
|
-
return false;
|
64
|
-
}
|
65
|
-
|
66
|
-
if (rect.right > parentRect.right || rect.bottom > parentRect.bottom) {
|
67
|
-
return (
|
68
|
-
style.overflow === 'scroll' ||
|
69
|
-
style.overflow === 'auto' ||
|
70
|
-
style.overflow === 'hidden' ||
|
71
|
-
parent instanceof HTMLBodyElement ||
|
72
|
-
parent instanceof HTMLHtmlElement
|
73
|
-
);
|
74
|
-
}
|
75
|
-
|
76
|
-
return true;
|
77
|
-
}
|
78
|
-
|
79
|
-
/**
|
80
|
-
* Checks whether a parent element visually contains its child, either directly or via scrolling.
|
81
|
-
* Assumes that |parent| is an ancestor of |node|.
|
82
|
-
* @method visuallyContains
|
83
|
-
* @memberof axe.commons.dom
|
84
|
-
* @instance
|
85
|
-
* @param {Element} node
|
86
|
-
* @param {Element} parent
|
87
|
-
* @return {boolean} True if node is visually contained within parent
|
88
|
-
*/
|
89
|
-
dom.visuallyContains = function visuallyContains(node, parent) {
|
90
|
-
const parentScrollAncestor = getScrollAncestor(parent);
|
91
|
-
|
92
|
-
// if the elements share a common scroll parent, we can check if the
|
93
|
-
// parent visually contains the node. otherwise we need to check each
|
94
|
-
// scroll parent in between the node and the parent since if the
|
95
|
-
// element is off screen due to the scroll, it won't be visually contained
|
96
|
-
// by the parent
|
97
|
-
do {
|
98
|
-
const nextScrollAncestor = getScrollAncestor(node);
|
99
|
-
|
100
|
-
if (
|
101
|
-
nextScrollAncestor === parentScrollAncestor ||
|
102
|
-
nextScrollAncestor === parent
|
103
|
-
) {
|
104
|
-
return contains(node, parent);
|
105
|
-
}
|
106
|
-
|
107
|
-
node = nextScrollAncestor;
|
108
|
-
} while (node);
|
109
|
-
|
110
|
-
return false;
|
111
|
-
};
|
@@ -1,46 +0,0 @@
|
|
1
|
-
/* global dom */
|
2
|
-
|
3
|
-
/**
|
4
|
-
* Checks whether a parent element visually overlaps a rectangle, either directly or via scrolling.
|
5
|
-
* @method visuallyOverlaps
|
6
|
-
* @memberof axe.commons.dom
|
7
|
-
* @instance
|
8
|
-
* @param {DOMRect} rect
|
9
|
-
* @param {Element} parent
|
10
|
-
* @return {boolean} True if rect is visually contained within parent
|
11
|
-
*/
|
12
|
-
dom.visuallyOverlaps = function(rect, parent) {
|
13
|
-
var parentRect = parent.getBoundingClientRect();
|
14
|
-
var parentTop = parentRect.top;
|
15
|
-
var parentLeft = parentRect.left;
|
16
|
-
var parentScrollArea = {
|
17
|
-
top: parentTop - parent.scrollTop,
|
18
|
-
bottom: parentTop - parent.scrollTop + parent.scrollHeight,
|
19
|
-
left: parentLeft - parent.scrollLeft,
|
20
|
-
right: parentLeft - parent.scrollLeft + parent.scrollWidth
|
21
|
-
};
|
22
|
-
|
23
|
-
//In theory, we should just be able to look at the scroll area as a superset of the parentRect,
|
24
|
-
//but that's not true in Firefox
|
25
|
-
if (
|
26
|
-
(rect.left > parentScrollArea.right && rect.left > parentRect.right) ||
|
27
|
-
(rect.top > parentScrollArea.bottom && rect.top > parentRect.bottom) ||
|
28
|
-
(rect.right < parentScrollArea.left && rect.right < parentRect.left) ||
|
29
|
-
(rect.bottom < parentScrollArea.top && rect.bottom < parentRect.top)
|
30
|
-
) {
|
31
|
-
return false;
|
32
|
-
}
|
33
|
-
|
34
|
-
var style = window.getComputedStyle(parent);
|
35
|
-
|
36
|
-
if (rect.left > parentRect.right || rect.top > parentRect.bottom) {
|
37
|
-
return (
|
38
|
-
style.overflow === 'scroll' ||
|
39
|
-
style.overflow === 'auto' ||
|
40
|
-
parent instanceof HTMLBodyElement ||
|
41
|
-
parent instanceof HTMLHtmlElement
|
42
|
-
);
|
43
|
-
}
|
44
|
-
|
45
|
-
return true;
|
46
|
-
};
|
@@ -1,13 +0,0 @@
|
|
1
|
-
/* global forms */
|
2
|
-
|
3
|
-
/**
|
4
|
-
* Determines if an element is an aria combobox element
|
5
|
-
* @method isAriaCombobox
|
6
|
-
* @memberof axe.commons.forms
|
7
|
-
* @param {Element} node Node to determine if aria combobox
|
8
|
-
* @returns {Bool}
|
9
|
-
*/
|
10
|
-
forms.isAriaCombobox = function(node) {
|
11
|
-
const role = axe.commons.aria.getRole(node, { noImplicit: true });
|
12
|
-
return role === 'combobox';
|
13
|
-
};
|
@@ -1,13 +0,0 @@
|
|
1
|
-
/* global forms */
|
2
|
-
|
3
|
-
/**
|
4
|
-
* Determines if an element is an aria listbox element
|
5
|
-
* @method isAriaListbox
|
6
|
-
* @memberof axe.commons.forms
|
7
|
-
* @param {Element} node Node to determine if aria listbox
|
8
|
-
* @returns {Bool}
|
9
|
-
*/
|
10
|
-
forms.isAriaListbox = function(node) {
|
11
|
-
const role = axe.commons.aria.getRole(node, { noImplicit: true });
|
12
|
-
return role === 'listbox';
|
13
|
-
};
|
@@ -1,14 +0,0 @@
|
|
1
|
-
/* global forms */
|
2
|
-
const rangeRoles = ['progressbar', 'scrollbar', 'slider', 'spinbutton'];
|
3
|
-
|
4
|
-
/**
|
5
|
-
* Determines if an element is an aria range element
|
6
|
-
* @method isAriaRange
|
7
|
-
* @memberof axe.commons.forms
|
8
|
-
* @param {Element} node Node to determine if aria range
|
9
|
-
* @returns {Bool}
|
10
|
-
*/
|
11
|
-
forms.isAriaRange = function(node) {
|
12
|
-
const role = axe.commons.aria.getRole(node, { noImplicit: true });
|
13
|
-
return rangeRoles.includes(role);
|
14
|
-
};
|
@@ -1,13 +0,0 @@
|
|
1
|
-
/* global forms */
|
2
|
-
|
3
|
-
/**
|
4
|
-
* Determines if an element is an aria textbox element
|
5
|
-
* @method isAriaTextbox
|
6
|
-
* @memberof axe.commons.forms
|
7
|
-
* @param {Element} node Node to determine if aria textbox
|
8
|
-
* @returns {Bool}
|
9
|
-
*/
|
10
|
-
forms.isAriaTextbox = function(node) {
|
11
|
-
const role = axe.commons.aria.getRole(node, { noImplicit: true });
|
12
|
-
return role === 'textbox';
|
13
|
-
};
|