123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- export function getLocalName(element) {
- var _element$localName;
- return (
- (_element$localName = element.localName) !== null && _element$localName !== void 0 ? _element$localName :
-
- element.tagName.toLowerCase()
- );
- }
- var localNameToRoleMappings = {
- article: "article",
- aside: "complementary",
- button: "button",
- datalist: "listbox",
- dd: "definition",
- details: "group",
- dialog: "dialog",
- dt: "term",
- fieldset: "group",
- figure: "figure",
-
- form: "form",
- footer: "contentinfo",
- h1: "heading",
- h2: "heading",
- h3: "heading",
- h4: "heading",
- h5: "heading",
- h6: "heading",
- header: "banner",
- hr: "separator",
- html: "document",
- legend: "legend",
- li: "listitem",
- math: "math",
- main: "main",
- menu: "list",
- nav: "navigation",
- ol: "list",
- optgroup: "group",
-
- option: "option",
- output: "status",
- progress: "progressbar",
-
- section: "region",
- summary: "button",
- table: "table",
- tbody: "rowgroup",
- textarea: "textbox",
- tfoot: "rowgroup",
-
- td: "cell",
- th: "columnheader",
- thead: "rowgroup",
- tr: "row",
- ul: "list"
- };
- var prohibitedAttributes = {
- caption: new Set(["aria-label", "aria-labelledby"]),
- code: new Set(["aria-label", "aria-labelledby"]),
- deletion: new Set(["aria-label", "aria-labelledby"]),
- emphasis: new Set(["aria-label", "aria-labelledby"]),
- generic: new Set(["aria-label", "aria-labelledby", "aria-roledescription"]),
- insertion: new Set(["aria-label", "aria-labelledby"]),
- paragraph: new Set(["aria-label", "aria-labelledby"]),
- presentation: new Set(["aria-label", "aria-labelledby"]),
- strong: new Set(["aria-label", "aria-labelledby"]),
- subscript: new Set(["aria-label", "aria-labelledby"]),
- superscript: new Set(["aria-label", "aria-labelledby"])
- };
- function hasGlobalAriaAttributes(element, role) {
-
-
- return ["aria-atomic", "aria-busy", "aria-controls", "aria-current", "aria-describedby", "aria-details",
-
- "aria-dropeffect",
-
- "aria-flowto", "aria-grabbed",
-
- "aria-hidden",
-
- "aria-keyshortcuts", "aria-label", "aria-labelledby", "aria-live", "aria-owns", "aria-relevant", "aria-roledescription"].some(function (attributeName) {
- var _prohibitedAttributes;
- return element.hasAttribute(attributeName) && !((_prohibitedAttributes = prohibitedAttributes[role]) !== null && _prohibitedAttributes !== void 0 && _prohibitedAttributes.has(attributeName));
- });
- }
- function ignorePresentationalRole(element, implicitRole) {
-
- return hasGlobalAriaAttributes(element, implicitRole);
- }
- export default function getRole(element) {
- var explicitRole = getExplicitRole(element);
- if (explicitRole === null || explicitRole === "presentation") {
- var implicitRole = getImplicitRole(element);
- if (explicitRole !== "presentation" || ignorePresentationalRole(element, implicitRole || "")) {
- return implicitRole;
- }
- }
- return explicitRole;
- }
- function getImplicitRole(element) {
- var mappedByTag = localNameToRoleMappings[getLocalName(element)];
- if (mappedByTag !== undefined) {
- return mappedByTag;
- }
- switch (getLocalName(element)) {
- case "a":
- case "area":
- case "link":
- if (element.hasAttribute("href")) {
- return "link";
- }
- break;
- case "img":
- if (element.getAttribute("alt") === "" && !ignorePresentationalRole(element, "img")) {
- return "presentation";
- }
- return "img";
- case "input":
- {
- var _ref = element,
- type = _ref.type;
- switch (type) {
- case "button":
- case "image":
- case "reset":
- case "submit":
- return "button";
- case "checkbox":
- case "radio":
- return type;
- case "range":
- return "slider";
- case "email":
- case "tel":
- case "text":
- case "url":
- if (element.hasAttribute("list")) {
- return "combobox";
- }
- return "textbox";
- case "search":
- if (element.hasAttribute("list")) {
- return "combobox";
- }
- return "searchbox";
- case "number":
- return "spinbutton";
- default:
- return null;
- }
- }
- case "select":
- if (element.hasAttribute("multiple") || element.size > 1) {
- return "listbox";
- }
- return "combobox";
- }
- return null;
- }
- function getExplicitRole(element) {
- var role = element.getAttribute("role");
- if (role !== null) {
- var explicitRole = role.trim().split(" ")[0];
-
-
- if (explicitRole.length > 0) {
- return explicitRole;
- }
- }
- return null;
- }
|