mathpix-markdown-it 1.0.72 → 1.0.73

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/.idea/vcs.xml +1 -0
  2. package/.idea/workspace.xml +649 -92
  3. package/README.md +133 -1
  4. package/doc/ACCESSIBILITY.md +156 -0
  5. package/es5/bundle.js +1 -1
  6. package/es5/context-menu.js +1 -0
  7. package/es5/index.js +1 -1
  8. package/lib/components/mathpix-markdown/index.js +3 -2
  9. package/lib/components/mathpix-markdown/index.js.map +1 -1
  10. package/lib/contex-menu/index.d.ts +16 -0
  11. package/lib/contex-menu/index.js +108 -0
  12. package/lib/contex-menu/index.js.map +1 -0
  13. package/lib/contex-menu/menu/consts.d.ts +16 -0
  14. package/lib/contex-menu/menu/consts.js +21 -0
  15. package/lib/contex-menu/menu/consts.js.map +1 -0
  16. package/lib/contex-menu/menu/helper.d.ts +10 -0
  17. package/lib/contex-menu/menu/helper.js +113 -0
  18. package/lib/contex-menu/menu/helper.js.map +1 -0
  19. package/lib/contex-menu/menu/index.d.ts +5 -0
  20. package/lib/contex-menu/menu/index.js +106 -0
  21. package/lib/contex-menu/menu/index.js.map +1 -0
  22. package/lib/contex-menu/menu/interfaces.d.ts +6 -0
  23. package/lib/contex-menu/menu/interfaces.js +3 -0
  24. package/lib/contex-menu/menu/interfaces.js.map +1 -0
  25. package/lib/contex-menu/menu/menu-item-actions.d.ts +7 -0
  26. package/lib/contex-menu/menu/menu-item-actions.js +112 -0
  27. package/lib/contex-menu/menu/menu-item-actions.js.map +1 -0
  28. package/lib/contex-menu/menu/menu-item.d.ts +1 -0
  29. package/lib/contex-menu/menu/menu-item.js +66 -0
  30. package/lib/contex-menu/menu/menu-item.js.map +1 -0
  31. package/lib/contex-menu/menu/menu-items.d.ts +1 -0
  32. package/lib/contex-menu/menu/menu-items.js +34 -0
  33. package/lib/contex-menu/menu/menu-items.js.map +1 -0
  34. package/lib/contex-menu/styles.d.ts +1 -0
  35. package/lib/contex-menu/styles.js +8 -0
  36. package/lib/contex-menu/styles.js.map +1 -0
  37. package/lib/context-menu.d.ts +7 -0
  38. package/lib/context-menu.js +10 -0
  39. package/lib/context-menu.js.map +1 -0
  40. package/lib/helpers/parse-mmd-element.d.ts +6 -0
  41. package/lib/helpers/parse-mmd-element.js +82 -0
  42. package/lib/helpers/parse-mmd-element.js.map +1 -0
  43. package/lib/markdown/index.js +3 -2
  44. package/lib/markdown/index.js.map +1 -1
  45. package/lib/markdown/mathpix-markdown-plugins.js +3 -2
  46. package/lib/markdown/mathpix-markdown-plugins.js.map +1 -1
  47. package/lib/markdown/md-ascii/index.js +3 -1
  48. package/lib/markdown/md-ascii/index.js.map +1 -1
  49. package/lib/markdown/mdPluginRaw.js +14 -4
  50. package/lib/markdown/mdPluginRaw.js.map +1 -1
  51. package/lib/mathjax/index.d.ts +14 -26
  52. package/lib/mathjax/index.js +139 -136
  53. package/lib/mathjax/index.js.map +1 -1
  54. package/lib/mathjax/mathjax.d.ts +24 -0
  55. package/lib/mathjax/mathjax.js +97 -0
  56. package/lib/mathjax/mathjax.js.map +1 -0
  57. package/lib/mathpix-markdown-model/index.d.ts +8 -1
  58. package/lib/mathpix-markdown-model/index.js +24 -65
  59. package/lib/mathpix-markdown-model/index.js.map +1 -1
  60. package/lib/sre/index.d.ts +5 -0
  61. package/lib/sre/index.js +53 -0
  62. package/lib/sre/index.js.map +1 -0
  63. package/lib/sre/sre-browser.d.ts +1 -0
  64. package/lib/sre/sre-browser.js +11 -0
  65. package/lib/sre/sre-browser.js.map +1 -0
  66. package/lib/sre/sre-node.d.ts +6 -0
  67. package/lib/sre/sre-node.js +34 -0
  68. package/lib/sre/sre-node.js.map +1 -0
  69. package/package.json +6 -2
@@ -9,7 +9,7 @@ var MathpixMarkdown = /** @class */ (function (_super) {
9
9
  return _super !== null && _super.apply(this, arguments) || this;
10
10
  }
11
11
  MathpixMarkdown.prototype.render = function () {
12
- var _a = this.props, text = _a.text, _b = _a.alignMathBlock, alignMathBlock = _b === void 0 ? 'center' : _b, _c = _a.display, display = _c === void 0 ? 'block' : _c, _d = _a.isCheckFormula, isCheckFormula = _d === void 0 ? false : _d, _e = _a.showTimeLog, showTimeLog = _e === void 0 ? false : _e, _f = _a.isDisableFancy, isDisableFancy = _f === void 0 ? false : _f, _g = _a.isDisableEmoji, isDisableEmoji = _g === void 0 ? false : _g, _h = _a.isDisableEmojiShortcuts, isDisableEmojiShortcuts = _h === void 0 ? false : _h, _j = _a.htmlTags, htmlTags = _j === void 0 ? false : _j, _k = _a.width, width = _k === void 0 ? 0 : _k, _l = _a.breaks, breaks = _l === void 0 ? true : _l, _m = _a.typographer, typographer = _m === void 0 ? false : _m, _o = _a.linkify, linkify = _o === void 0 ? false : _o, _p = _a.xhtmlOut, xhtmlOut = _p === void 0 ? false : _p, _q = _a.outMath, outMath = _q === void 0 ? {} : _q, _r = _a.mathJax, mathJax = _r === void 0 ? {} : _r, _s = _a.htmlSanitize, htmlSanitize = _s === void 0 ? {} : _s, _t = _a.smiles, smiles = _t === void 0 ? {} : _t, _u = _a.openLinkInNewWindow, openLinkInNewWindow = _u === void 0 ? true : _u, _v = _a.enableFileLinks, enableFileLinks = _v === void 0 ? false : _v;
12
+ var _a = this.props, text = _a.text, _b = _a.alignMathBlock, alignMathBlock = _b === void 0 ? 'center' : _b, _c = _a.display, display = _c === void 0 ? 'block' : _c, _d = _a.isCheckFormula, isCheckFormula = _d === void 0 ? false : _d, _e = _a.showTimeLog, showTimeLog = _e === void 0 ? false : _e, _f = _a.isDisableFancy, isDisableFancy = _f === void 0 ? false : _f, _g = _a.isDisableEmoji, isDisableEmoji = _g === void 0 ? false : _g, _h = _a.isDisableEmojiShortcuts, isDisableEmojiShortcuts = _h === void 0 ? false : _h, _j = _a.htmlTags, htmlTags = _j === void 0 ? false : _j, _k = _a.width, width = _k === void 0 ? 0 : _k, _l = _a.breaks, breaks = _l === void 0 ? true : _l, _m = _a.typographer, typographer = _m === void 0 ? false : _m, _o = _a.linkify, linkify = _o === void 0 ? false : _o, _p = _a.xhtmlOut, xhtmlOut = _p === void 0 ? false : _p, _q = _a.outMath, outMath = _q === void 0 ? {} : _q, _r = _a.mathJax, mathJax = _r === void 0 ? {} : _r, _s = _a.htmlSanitize, htmlSanitize = _s === void 0 ? {} : _s, _t = _a.smiles, smiles = _t === void 0 ? {} : _t, _u = _a.openLinkInNewWindow, openLinkInNewWindow = _u === void 0 ? true : _u, _v = _a.enableFileLinks, enableFileLinks = _v === void 0 ? false : _v, _w = _a.accessibility, accessibility = _w === void 0 ? null : _w;
13
13
  var disableRules = isDisableFancy ? mathpix_markdown_model_1.MathpixMarkdownModel.disableFancyArrayDef : this.props.disableRules || [];
14
14
  var markdownItOptions = {
15
15
  isDisableFancy: isDisableFancy,
@@ -27,7 +27,8 @@ var MathpixMarkdown = /** @class */ (function (_super) {
27
27
  htmlSanitize: htmlSanitize,
28
28
  smiles: smiles,
29
29
  openLinkInNewWindow: openLinkInNewWindow,
30
- enableFileLinks: enableFileLinks
30
+ enableFileLinks: enableFileLinks,
31
+ accessibility: accessibility
31
32
  };
32
33
  mathpix_markdown_model_1.MathpixMarkdownModel.setOptions(disableRules, isCheckFormula, showTimeLog);
33
34
  return (React.createElement("div", { id: 'preview', style: { justifyContent: alignMathBlock, padding: '10px', overflowY: 'auto', willChange: 'transform' } },
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/mathpix-markdown/index.tsx"],"names":[],"mappings":";;;AAAA,6BAA+B;AAC/B,uEAAoH;AAOpH;IAA8B,2CAAqC;IAAnE;;IAsCA,CAAC;IArCG,gCAAM,GAAN;QACU,IAAA,KAKF,IAAI,CAAC,KAAK,EALN,IAAI,UAAA,EAAE,sBAAuB,EAAvB,cAAc,mBAAC,QAAQ,KAAA,EAAE,eAAe,EAAf,OAAO,mBAAC,OAAO,KAAA,EAAE,sBAAoB,EAApB,cAAc,mBAAC,KAAK,KAAA,EAAE,mBAAiB,EAAjB,WAAW,mBAAC,KAAK,KAAA,EAAC,sBAAoB,EAApB,cAAc,mBAAC,KAAK,KAAA,EAClH,sBAAsB,EAAtB,cAAc,mBAAG,KAAK,KAAA,EAAE,+BAA+B,EAA/B,uBAAuB,mBAAG,KAAK,KAAA,EACvD,gBAAc,EAAd,QAAQ,mBAAC,KAAK,KAAA,EAAE,aAAO,EAAP,KAAK,mBAAC,CAAC,KAAA,EAAE,cAAW,EAAX,MAAM,mBAAC,IAAI,KAAA,EAAE,mBAAiB,EAAjB,WAAW,mBAAC,KAAK,KAAA,EAAE,eAAa,EAAb,OAAO,mBAAC,KAAK,KAAA,EAAE,gBAAc,EAAd,QAAQ,mBAAC,KAAK,KAAA,EACtF,eAAU,EAAV,OAAO,mBAAC,EAAE,KAAA,EAAE,eAAU,EAAV,OAAO,mBAAC,EAAE,KAAA,EAAE,oBAAiB,EAAjB,YAAY,mBAAG,EAAE,KAAA,EAAE,cAAW,EAAX,MAAM,mBAAG,EAAE,KAAA,EAAE,2BAA0B,EAA1B,mBAAmB,mBAAG,IAAI,KAAA,EAClF,uBAAuB,EAAvB,eAAe,mBAAG,KAAK,KACX,CAAC;QACf,IAAM,YAAY,GAAG,cAAc,CAAC,CAAC,CAAC,6CAAE,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC;QAC9F,IAAM,iBAAiB,GAAuB;YAC1C,cAAc,EAAE,cAAc;YAC9B,cAAc,EAAE,cAAc;YAC9B,uBAAuB,EAAE,uBAAuB;YAChD,YAAY,EAAE,YAAY;YAC1B,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,WAAW;YACxB,OAAO,EAAE,OAAO;YAChB,KAAK,EAAE,KAAK;YACZ,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,OAAO;YAChB,YAAY,EAAE,YAAY;YAC1B,MAAM,EAAE,MAAM;YACd,mBAAmB,EAAE,mBAAmB;YACxC,eAAe,EAAE,eAAe;SACnC,CAAC;QAED,6CAAE,CAAC,UAAU,CAAC,YAAY,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;QAC1D,OAAO,CACH,6BAAK,EAAE,EAAC,SAAS,EAAC,KAAK,EAAE,EAAC,cAAc,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAC;YAClH,6BAAK,EAAE,EAAC,kBAAkB,GAAO;YACjC,6BAAK,EAAE,EAAC,SAAS,EAAC,KAAK,EAAE,EAAC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,SAAS,EAAC,EACjE,uBAAuB,EAAE,EAAE,MAAM,EAAE,6CAAE,CAAC,aAAa,CAAC,IAAI,EAAE,iBAAiB,CAAC,EAAC,GAChF,CACA,CACT,CAAC;IACN,CAAC;IACL,sBAAC;AAAD,CAAC,AAtCD,CAA8B,KAAK,CAAC,SAAS,GAsC5C;AACD,kBAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/mathpix-markdown/index.tsx"],"names":[],"mappings":";;;AAAA,6BAA+B;AAC/B,uEAAoH;AAOpH;IAA8B,2CAAqC;IAAnE;;IAwCA,CAAC;IAvCG,gCAAM,GAAN;QACU,IAAA,KAMF,IAAI,CAAC,KAAK,EANN,IAAI,UAAA,EAAE,sBAAuB,EAAvB,cAAc,mBAAC,QAAQ,KAAA,EAAE,eAAe,EAAf,OAAO,mBAAC,OAAO,KAAA,EAAE,sBAAoB,EAApB,cAAc,mBAAC,KAAK,KAAA,EAAE,mBAAiB,EAAjB,WAAW,mBAAC,KAAK,KAAA,EAAC,sBAAoB,EAApB,cAAc,mBAAC,KAAK,KAAA,EAClH,sBAAsB,EAAtB,cAAc,mBAAG,KAAK,KAAA,EAAE,+BAA+B,EAA/B,uBAAuB,mBAAG,KAAK,KAAA,EACvD,gBAAc,EAAd,QAAQ,mBAAC,KAAK,KAAA,EAAE,aAAO,EAAP,KAAK,mBAAC,CAAC,KAAA,EAAE,cAAW,EAAX,MAAM,mBAAC,IAAI,KAAA,EAAE,mBAAiB,EAAjB,WAAW,mBAAC,KAAK,KAAA,EAAE,eAAa,EAAb,OAAO,mBAAC,KAAK,KAAA,EAAE,gBAAc,EAAd,QAAQ,mBAAC,KAAK,KAAA,EACtF,eAAU,EAAV,OAAO,mBAAC,EAAE,KAAA,EAAE,eAAU,EAAV,OAAO,mBAAC,EAAE,KAAA,EAAE,oBAAiB,EAAjB,YAAY,mBAAG,EAAE,KAAA,EAAE,cAAW,EAAX,MAAM,mBAAG,EAAE,KAAA,EAAE,2BAA0B,EAA1B,mBAAmB,mBAAG,IAAI,KAAA,EAClF,uBAAuB,EAAvB,eAAe,mBAAG,KAAK,KAAA,EACvB,qBAAoB,EAApB,aAAa,mBAAG,IAAI,KACR,CAAC;QACf,IAAM,YAAY,GAAG,cAAc,CAAC,CAAC,CAAC,6CAAE,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC;QAC9F,IAAM,iBAAiB,GAAuB;YAC1C,cAAc,EAAE,cAAc;YAC9B,cAAc,EAAE,cAAc;YAC9B,uBAAuB,EAAE,uBAAuB;YAChD,YAAY,EAAE,YAAY;YAC1B,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,WAAW;YACxB,OAAO,EAAE,OAAO;YAChB,KAAK,EAAE,KAAK;YACZ,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,OAAO;YAChB,YAAY,EAAE,YAAY;YAC1B,MAAM,EAAE,MAAM;YACd,mBAAmB,EAAE,mBAAmB;YACxC,eAAe,EAAE,eAAe;YAChC,aAAa,EAAE,aAAa;SAC/B,CAAC;QAED,6CAAE,CAAC,UAAU,CAAC,YAAY,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;QAC1D,OAAO,CACH,6BAAK,EAAE,EAAC,SAAS,EAAC,KAAK,EAAE,EAAC,cAAc,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAC;YAClH,6BAAK,EAAE,EAAC,kBAAkB,GAAO;YACjC,6BAAK,EAAE,EAAC,SAAS,EAAC,KAAK,EAAE,EAAC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,SAAS,EAAC,EACjE,uBAAuB,EAAE,EAAE,MAAM,EAAE,6CAAE,CAAC,aAAa,CAAC,IAAI,EAAE,iBAAiB,CAAC,EAAC,GAChF,CACA,CACT,CAAC;IACN,CAAC;IACL,sBAAC;AAAD,CAAC,AAxCD,CAA8B,KAAK,CAAC,SAAS,GAwC5C;AACD,kBAAe,eAAe,CAAC"}
@@ -0,0 +1,16 @@
1
+ export declare const handleTouchStart: (e: any) => void;
2
+ export declare const handleClick: (e: any) => void;
3
+ export declare const handleKeyUp: (e: any) => void;
4
+ export declare const handleResize: () => void;
5
+ export declare const addContextMenuListener: () => void;
6
+ export declare const removeContextMenuListener: () => void;
7
+ export declare const addClickListener: () => void;
8
+ export declare const removeClickListener: () => void;
9
+ export declare const addKeyUpListener: () => void;
10
+ export declare const removeKeyUpListener: () => void;
11
+ export declare const addResizeListener: () => void;
12
+ export declare const removeResizeListener: () => void;
13
+ export declare const addTouchStartListener: () => void;
14
+ export declare const removeTouchStartListener: () => void;
15
+ export declare const addListenerContextMenuEvents: () => void;
16
+ export declare const removeListenerContextMenuEvents: () => void;
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.removeListenerContextMenuEvents = exports.addListenerContextMenuEvents = exports.removeTouchStartListener = exports.addTouchStartListener = exports.removeResizeListener = exports.addResizeListener = exports.removeKeyUpListener = exports.addKeyUpListener = exports.removeClickListener = exports.addClickListener = exports.removeContextMenuListener = exports.addContextMenuListener = exports.handleResize = exports.handleKeyUp = exports.handleClick = exports.handleTouchStart = void 0;
4
+ var menu_1 = require("./menu");
5
+ var helper_1 = require("./menu/helper");
6
+ var consts_1 = require("./menu/consts");
7
+ var menu_item_actions_1 = require("./menu/menu-item-actions");
8
+ var isCloseByTouchStart = false;
9
+ var handleContextMenu = function (e) {
10
+ var elMath = helper_1.clickInsideElement(e, 'MathJax');
11
+ if (elMath && elMath.parentElement) {
12
+ e.preventDefault();
13
+ menu_1.toggleMenuOn(elMath.parentElement, e);
14
+ }
15
+ else {
16
+ menu_1.toggleMenuOff();
17
+ }
18
+ };
19
+ exports.handleTouchStart = function (e) {
20
+ var elItem = helper_1.clickInsideElement(e, consts_1.classNameMenuItem);
21
+ isCloseByTouchStart = false;
22
+ if (menu_1.isOpenContextMenu() && !elItem) {
23
+ e.stopPropagation();
24
+ menu_1.toggleMenuOff();
25
+ isCloseByTouchStart = true;
26
+ }
27
+ };
28
+ exports.handleClick = function (e) {
29
+ if ("ontouchstart" in document.documentElement) {
30
+ var elMath = helper_1.clickInsideElement(e, 'MathJax');
31
+ if (elMath) {
32
+ if (isCloseByTouchStart) {
33
+ isCloseByTouchStart = false;
34
+ return;
35
+ }
36
+ e.stopPropagation();
37
+ if (menu_1.isOpenContextMenu()) {
38
+ menu_1.toggleMenuOff();
39
+ }
40
+ else {
41
+ menu_1.toggleMenuOn(elMath.parentElement, e);
42
+ }
43
+ return;
44
+ }
45
+ }
46
+ var elItem = helper_1.clickInsideElement(e, consts_1.classNameMenuItem);
47
+ if (elItem) {
48
+ e.stopPropagation();
49
+ menu_item_actions_1.clearActiveItem();
50
+ menu_item_actions_1.chooseItem(elItem);
51
+ }
52
+ else {
53
+ menu_1.toggleMenuOff();
54
+ }
55
+ };
56
+ exports.handleKeyUp = function (e) {
57
+ if (e.key === 'Escape') {
58
+ menu_1.toggleMenuOff();
59
+ }
60
+ };
61
+ exports.handleResize = function () {
62
+ menu_1.toggleMenuOff();
63
+ };
64
+ exports.addContextMenuListener = function () {
65
+ document.addEventListener("contextmenu", handleContextMenu);
66
+ };
67
+ exports.removeContextMenuListener = function () {
68
+ document.removeEventListener("contextmenu", handleContextMenu);
69
+ };
70
+ exports.addClickListener = function () {
71
+ document.addEventListener("click", exports.handleClick);
72
+ };
73
+ exports.removeClickListener = function () {
74
+ document.removeEventListener("click", exports.handleClick);
75
+ };
76
+ exports.addKeyUpListener = function () {
77
+ document.addEventListener("keyup", exports.handleKeyUp);
78
+ };
79
+ exports.removeKeyUpListener = function () {
80
+ document.removeEventListener("keyup", exports.handleKeyUp);
81
+ };
82
+ exports.addResizeListener = function () {
83
+ document.addEventListener("resize", exports.handleResize);
84
+ };
85
+ exports.removeResizeListener = function () {
86
+ document.removeEventListener("resize", exports.handleResize);
87
+ };
88
+ exports.addTouchStartListener = function () {
89
+ document.addEventListener("touchstart", exports.handleTouchStart);
90
+ };
91
+ exports.removeTouchStartListener = function () {
92
+ document.removeEventListener("touchstart", exports.handleTouchStart);
93
+ };
94
+ exports.addListenerContextMenuEvents = function () {
95
+ exports.addContextMenuListener();
96
+ exports.addClickListener();
97
+ exports.addKeyUpListener();
98
+ exports.addResizeListener();
99
+ exports.addTouchStartListener();
100
+ };
101
+ exports.removeListenerContextMenuEvents = function () {
102
+ exports.removeContextMenuListener();
103
+ exports.removeClickListener();
104
+ exports.removeKeyUpListener();
105
+ exports.removeResizeListener();
106
+ exports.removeTouchStartListener();
107
+ };
108
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/contex-menu/index.ts"],"names":[],"mappings":";;;AAAA,+BAAwE;AACxE,wCAAmD;AACnD,wCAAkD;AAClD,8DAAuE;AAEvE,IAAI,mBAAmB,GAAG,KAAK,CAAC;AAEhC,IAAM,iBAAiB,GAAG,UAAC,CAAC;IAC1B,IAAI,MAAM,GAAG,2BAAkB,CAAE,CAAC,EAAE,SAAS,CAAE,CAAC;IAChD,IAAI,MAAM,IAAI,MAAM,CAAC,aAAa,EAAE;QAClC,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,mBAAY,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;KACvC;SAAM;QACL,oBAAa,EAAE,CAAC;KACjB;AACH,CAAC,CAAC;AAEW,QAAA,gBAAgB,GAAG,UAAC,CAAC;IAChC,IAAM,MAAM,GAAG,2BAAkB,CAAE,CAAC,EAAE,0BAAiB,CAAE,CAAC;IAE1D,mBAAmB,GAAG,KAAK,CAAC;IAC5B,IAAI,wBAAiB,EAAE,IAAI,CAAC,MAAM,EAAE;QAClC,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,oBAAa,EAAE,CAAC;QAChB,mBAAmB,GAAG,IAAI,CAAC;KAC5B;AACH,CAAC,CAAC;AAEW,QAAA,WAAW,GAAG,UAAC,CAAC;IAC3B,IAAI,cAAc,IAAI,QAAQ,CAAC,eAAe,EAAE;QAC9C,IAAI,MAAM,GAAG,2BAAkB,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QAC9C,IAAI,MAAM,EAAE;YACV,IAAI,mBAAmB,EAAE;gBACvB,mBAAmB,GAAG,KAAK,CAAC;gBAC5B,OAAO;aACR;YACD,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,IAAI,wBAAiB,EAAE,EAAE;gBACvB,oBAAa,EAAE,CAAC;aACjB;iBAAM;gBACL,mBAAY,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;aACvC;YACD,OAAO;SACR;KACF;IAED,IAAM,MAAM,GAAG,2BAAkB,CAAE,CAAC,EAAE,0BAAiB,CAAE,CAAC;IAC1D,IAAI,MAAM,EAAE;QACV,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,mCAAe,EAAE,CAAC;QAClB,8BAAU,CAAC,MAAM,CAAC,CAAC;KACpB;SAAM;QACL,oBAAa,EAAE,CAAC;KACjB;AACH,CAAC,CAAC;AAEW,QAAA,WAAW,GAAG,UAAC,CAAC;IAC3B,IAAI,CAAC,CAAC,GAAG,KAAK,QAAQ,EAAE;QACtB,oBAAa,EAAE,CAAC;KACjB;AACH,CAAC,CAAC;AAEW,QAAA,YAAY,GAAG;IAC1B,oBAAa,EAAE,CAAC;AAClB,CAAC,CAAC;AAEW,QAAA,sBAAsB,GAAG;IACpC,QAAQ,CAAC,gBAAgB,CAAE,aAAa,EAAE,iBAAiB,CAAC,CAAC;AAC/D,CAAC,CAAC;AAEW,QAAA,yBAAyB,GAAG;IACvC,QAAQ,CAAC,mBAAmB,CAAE,aAAa,EAAE,iBAAiB,CAAC,CAAC;AAClE,CAAC,CAAC;AAEW,QAAA,gBAAgB,GAAG;IAC9B,QAAQ,CAAC,gBAAgB,CAAE,OAAO,EAAE,mBAAW,CAAC,CAAC;AACnD,CAAC,CAAC;AAEW,QAAA,mBAAmB,GAAG;IACjC,QAAQ,CAAC,mBAAmB,CAAE,OAAO,EAAE,mBAAW,CAAC,CAAC;AACtD,CAAC,CAAC;AAEW,QAAA,gBAAgB,GAAG;IAC9B,QAAQ,CAAC,gBAAgB,CAAE,OAAO,EAAE,mBAAW,CAAC,CAAC;AACnD,CAAC,CAAC;AAEW,QAAA,mBAAmB,GAAG;IACjC,QAAQ,CAAC,mBAAmB,CAAE,OAAO,EAAE,mBAAW,CAAC,CAAC;AACtD,CAAC,CAAC;AAEW,QAAA,iBAAiB,GAAG;IAC/B,QAAQ,CAAC,gBAAgB,CAAE,QAAQ,EAAE,oBAAY,CAAC,CAAC;AACrD,CAAC,CAAC;AAEW,QAAA,oBAAoB,GAAG;IAClC,QAAQ,CAAC,mBAAmB,CAAE,QAAQ,EAAE,oBAAY,CAAC,CAAC;AACxD,CAAC,CAAC;AAEW,QAAA,qBAAqB,GAAG;IACnC,QAAQ,CAAC,gBAAgB,CAAE,YAAY,EAAE,wBAAgB,CAAC,CAAC;AAC7D,CAAC,CAAC;AAEW,QAAA,wBAAwB,GAAG;IACtC,QAAQ,CAAC,mBAAmB,CAAE,YAAY,EAAE,wBAAgB,CAAC,CAAC;AAChE,CAAC,CAAC;AAEW,QAAA,4BAA4B,GAAG;IAC1C,8BAAsB,EAAE,CAAC;IACzB,wBAAgB,EAAE,CAAC;IACnB,wBAAgB,EAAE,CAAC;IACnB,yBAAiB,EAAE,CAAC;IACpB,6BAAqB,EAAE,CAAC;AAC1B,CAAC,CAAC;AAEW,QAAA,+BAA+B,GAAG;IAC7C,iCAAyB,EAAE,CAAC;IAC5B,2BAAmB,EAAE,CAAC;IACtB,2BAAmB,EAAE,CAAC;IACtB,4BAAoB,EAAE,CAAC;IACvB,gCAAwB,EAAE,CAAC;AAC7B,CAAC,CAAC"}
@@ -0,0 +1,16 @@
1
+ export declare const classNameContextMenu = "mmd-context-menu";
2
+ export declare const classNameMenu = "mmd-menu";
3
+ export declare const classNameMenuItem = "mmd-menu-item";
4
+ export declare const classNameMenuItemSource = "mmd-menu-item-source";
5
+ export declare const SMALL_SCREEN_BREAKPOINT = 580;
6
+ export declare const heightMenuItem = 52;
7
+ export declare const paddingMenu = 5;
8
+ export declare const paddingMenuBottomSmall = 34;
9
+ export declare const maxWidthMenu = 320;
10
+ export declare const mathExportTypes: string[];
11
+ export declare enum eMathType {
12
+ latex = "latex",
13
+ asciimath = "asciimath",
14
+ mathml = "mathml",
15
+ mathmlword = "mathmlword"
16
+ }
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.eMathType = exports.mathExportTypes = exports.maxWidthMenu = exports.paddingMenuBottomSmall = exports.paddingMenu = exports.heightMenuItem = exports.SMALL_SCREEN_BREAKPOINT = exports.classNameMenuItemSource = exports.classNameMenuItem = exports.classNameMenu = exports.classNameContextMenu = void 0;
4
+ exports.classNameContextMenu = 'mmd-context-menu';
5
+ exports.classNameMenu = 'mmd-menu';
6
+ exports.classNameMenuItem = 'mmd-menu-item';
7
+ exports.classNameMenuItemSource = 'mmd-menu-item-source';
8
+ exports.SMALL_SCREEN_BREAKPOINT = 580;
9
+ exports.heightMenuItem = 52;
10
+ exports.paddingMenu = 5;
11
+ exports.paddingMenuBottomSmall = 34;
12
+ exports.maxWidthMenu = 320;
13
+ exports.mathExportTypes = ['latex', 'asciimath', 'mathml', 'mathmlword'];
14
+ var eMathType;
15
+ (function (eMathType) {
16
+ eMathType["latex"] = "latex";
17
+ eMathType["asciimath"] = "asciimath";
18
+ eMathType["mathml"] = "mathml";
19
+ eMathType["mathmlword"] = "mathmlword";
20
+ })(eMathType = exports.eMathType || (exports.eMathType = {}));
21
+ //# sourceMappingURL=consts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../src/contex-menu/menu/consts.ts"],"names":[],"mappings":";;;AAAa,QAAA,oBAAoB,GAAG,kBAAkB,CAAC;AAC1C,QAAA,aAAa,GAAG,UAAU,CAAC;AAC3B,QAAA,iBAAiB,GAAG,eAAe,CAAC;AACpC,QAAA,uBAAuB,GAAG,sBAAsB,CAAC;AACjD,QAAA,uBAAuB,GAAG,GAAG,CAAC;AAE9B,QAAA,cAAc,GAAG,EAAE,CAAC;AACpB,QAAA,WAAW,GAAG,CAAC,CAAC;AAChB,QAAA,sBAAsB,GAAG,EAAE,CAAC;AAC5B,QAAA,YAAY,GAAG,GAAG,CAAC;AAEnB,QAAA,eAAe,GAAG,CAAC,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;AAE9E,IAAY,SAKX;AALD,WAAY,SAAS;IACnB,4BAAe,CAAA;IACf,oCAAuB,CAAA;IACvB,8BAAiB,CAAA;IACjB,sCAAyB,CAAA;AAC3B,CAAC,EALW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAKpB"}
@@ -0,0 +1,10 @@
1
+ import { IMenuPosition } from "./interfaces";
2
+ export declare const getPosition: (e: any) => {
3
+ x: number;
4
+ y: number;
5
+ };
6
+ export declare const getMenuElement: () => Element;
7
+ export declare const getContextMenuElement: () => Element;
8
+ export declare const positionMenu: (e: any) => void;
9
+ export declare const getPositionMenuByClick: (e: any, itemsLength: any) => IMenuPosition;
10
+ export declare const clickInsideElement: (e: any, className: any) => any;
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.clickInsideElement = exports.getPositionMenuByClick = exports.positionMenu = exports.getContextMenuElement = exports.getMenuElement = exports.getPosition = void 0;
4
+ var consts_1 = require("./consts");
5
+ exports.getPosition = function (e) {
6
+ var posX = 0;
7
+ var posY = 0;
8
+ if (!e) {
9
+ e = window.event;
10
+ }
11
+ if (e.pageX || e.pageY) {
12
+ posX = e.pageX;
13
+ posY = e.pageY;
14
+ }
15
+ else if (e.clientX || e.clientY) {
16
+ posX = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft;
17
+ posY = e.clientY + document.body.scrollTop + document.documentElement.scrollTop;
18
+ }
19
+ return {
20
+ x: posX,
21
+ y: posY
22
+ };
23
+ };
24
+ exports.getMenuElement = function () {
25
+ return document.querySelector("." + consts_1.classNameMenu);
26
+ };
27
+ exports.getContextMenuElement = function () {
28
+ return document.querySelector("." + consts_1.classNameContextMenu);
29
+ };
30
+ exports.positionMenu = function (e) {
31
+ var elMenu = exports.getMenuElement();
32
+ if (!elMenu) {
33
+ return;
34
+ }
35
+ var clickCoords = exports.getPosition(e);
36
+ var clickCoordsX = clickCoords.x;
37
+ var clickCoordsY = clickCoords.y;
38
+ var menuWidth = elMenu.offsetWidth + 4;
39
+ var menuHeight = elMenu.offsetHeight + 4;
40
+ var windowWidth = window.innerWidth;
41
+ var windowHeight = window.innerHeight;
42
+ if (windowWidth <= consts_1.SMALL_SCREEN_BREAKPOINT) {
43
+ elMenu.style.left = 0;
44
+ elMenu.style.bottom = 0;
45
+ elMenu.style.maxWidth = '100vw';
46
+ elMenu.classList.add('mmd-menu-sm');
47
+ var elContextMenu = exports.getContextMenuElement();
48
+ if (elContextMenu && !elContextMenu.classList.contains(consts_1.classNameContextMenu + "-overlay")) {
49
+ elContextMenu.classList.add(consts_1.classNameContextMenu + "-overlay");
50
+ }
51
+ return;
52
+ }
53
+ if ((windowWidth - clickCoordsX) < menuWidth) {
54
+ elMenu.style.left = windowWidth - menuWidth + "px";
55
+ }
56
+ else {
57
+ elMenu.style.left = clickCoordsX + "px";
58
+ }
59
+ if ((windowHeight - clickCoordsY) < menuHeight) {
60
+ elMenu.style.top = windowHeight - menuHeight + "px";
61
+ }
62
+ else {
63
+ elMenu.style.top = clickCoordsY + "px";
64
+ }
65
+ };
66
+ exports.getPositionMenuByClick = function (e, itemsLength) {
67
+ var clickCoords = exports.getPosition(e);
68
+ var clickCoordsX = clickCoords.x;
69
+ var clickCoordsY = clickCoords.y;
70
+ var menuHeight = consts_1.heightMenuItem * itemsLength + consts_1.paddingMenu + 2;
71
+ var menuWidth = consts_1.maxWidthMenu + 4;
72
+ var windowWidth = window.innerWidth;
73
+ var windowHeight = window.innerHeight;
74
+ var scrollTop = document.body.scrollTop + document.documentElement.scrollTop;
75
+ var res = {};
76
+ if (windowWidth <= consts_1.SMALL_SCREEN_BREAKPOINT) {
77
+ menuHeight += consts_1.paddingMenuBottomSmall;
78
+ res.left = "0px";
79
+ res.top = windowHeight + scrollTop - menuHeight + "px";
80
+ res.maxWidth = '100vw';
81
+ res.className = 'mmd-menu-sm';
82
+ return res;
83
+ }
84
+ menuHeight += consts_1.paddingMenu;
85
+ if ((windowWidth - clickCoordsX) < menuWidth) {
86
+ res.left = windowWidth - menuWidth + "px";
87
+ }
88
+ else {
89
+ res.left = clickCoordsX + "px";
90
+ }
91
+ if ((windowHeight + scrollTop - clickCoordsY) < menuHeight) {
92
+ res.top = windowHeight + scrollTop - menuHeight + "px";
93
+ }
94
+ else {
95
+ res.top = clickCoordsY + "px";
96
+ }
97
+ return res;
98
+ };
99
+ exports.clickInsideElement = function (e, className) {
100
+ var el = e.target;
101
+ if (el.classList.contains(className)) {
102
+ return el;
103
+ }
104
+ else {
105
+ while (el = el.parentNode) {
106
+ if (el.classList && el.classList.contains(className)) {
107
+ return el;
108
+ }
109
+ }
110
+ }
111
+ return null;
112
+ };
113
+ //# sourceMappingURL=helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helper.js","sourceRoot":"","sources":["../../../src/contex-menu/menu/helper.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export declare const createContextMenu: (el: any, e: any) => void;
2
+ export declare const dropContextMenu: (elContextMenu?: any) => void;
3
+ export declare const isOpenContextMenu: () => boolean;
4
+ export declare const toggleMenuOn: (el: any, e: any) => void;
5
+ export declare const toggleMenuOff: () => void;
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.toggleMenuOff = exports.toggleMenuOn = exports.isOpenContextMenu = exports.dropContextMenu = exports.createContextMenu = void 0;
4
+ var menu_items_1 = require("./menu-items");
5
+ var menu_item_actions_1 = require("./menu-item-actions");
6
+ var consts_1 = require("./consts");
7
+ var helper_1 = require("./helper");
8
+ var handleKeyDownMenuItem = function (e) {
9
+ switch (e.key) {
10
+ case 'ArrowDown':
11
+ case 'ArrowRight':
12
+ menu_item_actions_1.chooseNextItem();
13
+ break;
14
+ case 'ArrowUp':
15
+ case 'ArrowLeft':
16
+ menu_item_actions_1.choosePreviousItem();
17
+ break;
18
+ }
19
+ };
20
+ var addEventListenerToMenu = function (elMenu) {
21
+ elMenu.addEventListener('keydown', handleKeyDownMenuItem);
22
+ };
23
+ var removeEventListenerFromMenu = function () {
24
+ var elMenu = document.querySelector("." + consts_1.classNameMenu);
25
+ if (!elMenu) {
26
+ return;
27
+ }
28
+ elMenu.removeEventListener('keydown', handleKeyDownMenuItem);
29
+ };
30
+ var findContextMenuElement = function () {
31
+ return document.querySelector("." + consts_1.classNameContextMenu);
32
+ };
33
+ exports.createContextMenu = function (el, e) {
34
+ try {
35
+ var items = menu_items_1.mathMenuItems(el);
36
+ if (!items || !items.length) {
37
+ return;
38
+ }
39
+ var elCtxtMenu = document.createElement('div');
40
+ elCtxtMenu.setAttribute('class', consts_1.classNameContextMenu);
41
+ elCtxtMenu.setAttribute('style', 'position: absolute; left: 0px; top: 0px; z-index: 200; width: 100%; height: 100%; border: 0px; padding: 0px; margin: 0px;');
42
+ var elPosition = document.createElement('div');
43
+ elPosition.setAttribute('style', 'position: fixed; left: 0px; top: 0px; z-index: 200; width: 100%; height: 100%; border: 0px; padding: 0px; margin: 0px;');
44
+ elCtxtMenu.appendChild(elPosition);
45
+ var elMenu = document.createElement('div');
46
+ elMenu.setAttribute('class', consts_1.classNameMenu);
47
+ elMenu.setAttribute('role', 'menu');
48
+ elMenu.setAttribute('aria-label', 'Copy to Clipboard');
49
+ elMenu.setAttribute('tabindex', '0');
50
+ for (var i = 0; i < items.length; i++) {
51
+ elMenu.appendChild(items[i]);
52
+ }
53
+ var resPos = helper_1.getPositionMenuByClick(e, items.length);
54
+ if (resPos.className === 'mmd-menu-sm') {
55
+ elMenu.style.left = resPos.left;
56
+ elMenu.style.bottom = "0";
57
+ elMenu.style.position = 'fixed';
58
+ elMenu.style.maxWidth = resPos.maxWidth;
59
+ elMenu.classList.add(resPos.className);
60
+ elPosition.classList.add(consts_1.classNameContextMenu + "-overlay");
61
+ }
62
+ else {
63
+ elMenu.style.left = resPos.left;
64
+ elMenu.style.top = resPos.top;
65
+ }
66
+ addEventListenerToMenu(elMenu);
67
+ elCtxtMenu.appendChild(elMenu);
68
+ document.body.appendChild(elCtxtMenu);
69
+ elMenu.focus();
70
+ }
71
+ catch (err) {
72
+ console.error(err);
73
+ }
74
+ };
75
+ exports.dropContextMenu = function (elContextMenu) {
76
+ try {
77
+ if (!elContextMenu) {
78
+ elContextMenu = findContextMenuElement();
79
+ }
80
+ if (elContextMenu) {
81
+ removeEventListenerFromMenu();
82
+ document.body.removeChild(elContextMenu);
83
+ }
84
+ }
85
+ catch (err) {
86
+ console.error(err);
87
+ }
88
+ };
89
+ exports.isOpenContextMenu = function () {
90
+ var elContextMenu = findContextMenuElement();
91
+ return Boolean(elContextMenu);
92
+ };
93
+ exports.toggleMenuOn = function (el, e) {
94
+ var elContextMenu = findContextMenuElement();
95
+ if (!elContextMenu) {
96
+ exports.createContextMenu(el, e);
97
+ }
98
+ else {
99
+ exports.dropContextMenu(elContextMenu);
100
+ exports.createContextMenu(el, e);
101
+ }
102
+ };
103
+ exports.toggleMenuOff = function () {
104
+ exports.dropContextMenu();
105
+ };
106
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/contex-menu/menu/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ export interface IMenuPosition {
2
+ left?: string;
3
+ top?: string;
4
+ maxWidth?: string;
5
+ className?: string;
6
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=interfaces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/contex-menu/menu/interfaces.ts"],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ export declare const getMenuItems: () => NodeListOf<Element>;
2
+ export declare const getMenuItemActive: () => Element;
3
+ export declare const findIndexActiveItem: (elem: any, items?: any) => number;
4
+ export declare const clearActiveItem: () => void;
5
+ export declare const chooseItem: (el: any) => void;
6
+ export declare const chooseNextItem: () => void;
7
+ export declare const choosePreviousItem: () => void;
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.choosePreviousItem = exports.chooseNextItem = exports.chooseItem = exports.clearActiveItem = exports.findIndexActiveItem = exports.getMenuItemActive = exports.getMenuItems = void 0;
4
+ var copy = require("copy-to-clipboard");
5
+ var consts_1 = require("./consts");
6
+ var parse_mmd_element_1 = require("../../helpers/parse-mmd-element");
7
+ exports.getMenuItems = function () {
8
+ return document.querySelectorAll("." + consts_1.classNameMenuItem);
9
+ };
10
+ exports.getMenuItemActive = function () {
11
+ return document.querySelector("." + consts_1.classNameMenuItem + ".active");
12
+ };
13
+ exports.findIndexActiveItem = function (elem, items) {
14
+ if (!elem || !items || !items.length) {
15
+ return -1;
16
+ }
17
+ for (var i = 0; i < items.length; i++) {
18
+ if (items[i] === elem) {
19
+ return i;
20
+ }
21
+ }
22
+ return -1;
23
+ };
24
+ exports.clearActiveItem = function () {
25
+ var items = document.querySelectorAll("." + consts_1.classNameMenuItem + ".active");
26
+ if (!items || !items.length) {
27
+ return;
28
+ }
29
+ for (var i = 0; i < items.length; i++) {
30
+ items[i].classList.remove('active');
31
+ }
32
+ };
33
+ exports.chooseItem = function (el) {
34
+ try {
35
+ if (!el) {
36
+ return;
37
+ }
38
+ var elSource = el.querySelector("." + consts_1.classNameMenuItemSource);
39
+ if (elSource) {
40
+ el.focus();
41
+ var source = elSource.innerHTML;
42
+ var dataType = elSource.getAttribute('data-type');
43
+ if (dataType === consts_1.eMathType.mathmlword) {
44
+ source = parse_mmd_element_1.formatSourceHtmlWord(source);
45
+ }
46
+ else {
47
+ source = dataType === consts_1.eMathType.mathml
48
+ ? source
49
+ : parse_mmd_element_1.formatSourceHtml(source);
50
+ }
51
+ copy(source, {
52
+ format: 'text/plain',
53
+ debug: true
54
+ });
55
+ }
56
+ if (!el.classList.contains('active')) {
57
+ el.classList.add('active');
58
+ }
59
+ }
60
+ catch (err) {
61
+ console.error(err);
62
+ }
63
+ };
64
+ exports.chooseNextItem = function () {
65
+ var items = exports.getMenuItems();
66
+ if (!items || !items.length) {
67
+ return;
68
+ }
69
+ var elActive = exports.getMenuItemActive();
70
+ var index = exports.findIndexActiveItem(elActive, items);
71
+ var len = items && items.length ? items.length - 1 : 0;
72
+ if (elActive) {
73
+ index++;
74
+ elActive.classList.remove('active');
75
+ var next = items[index];
76
+ if (typeof next !== undefined && index <= len) {
77
+ elActive = next;
78
+ }
79
+ else {
80
+ elActive = items[0];
81
+ }
82
+ exports.chooseItem(elActive);
83
+ }
84
+ else {
85
+ exports.chooseItem(items[0]);
86
+ }
87
+ };
88
+ exports.choosePreviousItem = function () {
89
+ var items = exports.getMenuItems();
90
+ if (!items || !items.length) {
91
+ return;
92
+ }
93
+ var elActive = exports.getMenuItemActive();
94
+ var index = exports.findIndexActiveItem(elActive, items);
95
+ var len = items && items.length ? items.length - 1 : 0;
96
+ if (elActive) {
97
+ index--;
98
+ elActive.classList.remove('active');
99
+ var next = items[index];
100
+ if (typeof next !== undefined && index >= 0) {
101
+ elActive = next;
102
+ }
103
+ else {
104
+ elActive = items[len];
105
+ }
106
+ exports.chooseItem(elActive);
107
+ }
108
+ else {
109
+ exports.chooseItem(items[len]);
110
+ }
111
+ };
112
+ //# sourceMappingURL=menu-item-actions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-item-actions.js","sourceRoot":"","sources":["../../../src/contex-menu/menu/menu-item-actions.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare const createMathMenuItem: (type: any, value: string) => HTMLDivElement;