roleElementMap.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = void 0;
  6. var _iterationDecorator = _interopRequireDefault(require("./util/iterationDecorator"));
  7. var _rolesMap = _interopRequireDefault(require("./rolesMap"));
  8. function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
  9. function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
  10. function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
  11. function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
  12. function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
  13. function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
  14. function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
  15. var roleElement = [];
  16. var keys = _rolesMap.default.keys();
  17. for (var i = 0; i < keys.length; i++) {
  18. var key = keys[i];
  19. var role = _rolesMap.default.get(key);
  20. var relationConcepts = [];
  21. if (role) {
  22. var concepts = [].concat(role.baseConcepts, role.relatedConcepts);
  23. for (var k = 0; k < concepts.length; k++) {
  24. var relation = concepts[k];
  25. if (relation.module === 'HTML') {
  26. var concept = relation.concept;
  27. if (concept != null) {
  28. relationConcepts.push(concept);
  29. }
  30. }
  31. }
  32. if (relationConcepts.length > 0) {
  33. roleElement.push([key, relationConcepts]);
  34. }
  35. }
  36. }
  37. var roleElementMap = {
  38. entries: function entries() {
  39. return roleElement;
  40. },
  41. forEach: function forEach(fn) {
  42. var thisArg = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
  43. for (var _i = 0, _roleElement = roleElement; _i < _roleElement.length; _i++) {
  44. var _roleElement$_i = _slicedToArray(_roleElement[_i], 2),
  45. _key = _roleElement$_i[0],
  46. values = _roleElement$_i[1];
  47. fn.call(thisArg, values, _key, roleElement);
  48. }
  49. },
  50. get: function get(key) {
  51. var item = roleElement.filter(function (tuple) {
  52. return tuple[0] === key ? true : false;
  53. })[0];
  54. return item && item[1];
  55. },
  56. has: function has(key) {
  57. return !!roleElementMap.get(key);
  58. },
  59. keys: function keys() {
  60. return roleElement.map(function (_ref) {
  61. var _ref2 = _slicedToArray(_ref, 1),
  62. key = _ref2[0];
  63. return key;
  64. });
  65. },
  66. values: function values() {
  67. return roleElement.map(function (_ref3) {
  68. var _ref4 = _slicedToArray(_ref3, 2),
  69. values = _ref4[1];
  70. return values;
  71. });
  72. }
  73. };
  74. var _default = exports.default = (0, _iterationDecorator.default)(roleElementMap, roleElementMap.entries());