highmark-markdown 1.2.70 → 1.2.72

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 (245) hide show
  1. package/.aiignore +7 -9
  2. package/.swcrc +4 -3
  3. package/example.js +11655 -33035
  4. package/lib/attributeNames.js +7 -7
  5. package/lib/constants.js +19 -19
  6. package/lib/example/constants.js +7 -7
  7. package/lib/example/customEventTypes.js +9 -9
  8. package/lib/example/importer.js +72 -28
  9. package/lib/example/indexOptions.js +3 -3
  10. package/lib/example/view/button/page.js +34 -135
  11. package/lib/example/view/button/tab/css.js +14 -114
  12. package/lib/example/view/button/tab/html.js +14 -114
  13. package/lib/example/view/button/tab/markdown.js +14 -114
  14. package/lib/example/view/button/tab/markdownStyle.js +14 -114
  15. package/lib/example/view/button/tab/plainText.js +14 -114
  16. package/lib/example/view/button/tab/preview.js +14 -114
  17. package/lib/example/view/button/tab.js +36 -136
  18. package/lib/example/view/div/container/css.js +15 -153
  19. package/lib/example/view/div/container/html.js +19 -157
  20. package/lib/example/view/div/container/markdown.js +38 -190
  21. package/lib/example/view/div/container/markdownStyle.js +39 -191
  22. package/lib/example/view/div/container/plainText.js +15 -153
  23. package/lib/example/view/div/container/preview.js +25 -177
  24. package/lib/example/view/div/container.js +20 -156
  25. package/lib/example/view/div/html.js +18 -173
  26. package/lib/example/view/div/pageButtons.js +63 -236
  27. package/lib/example/view/div/preview.js +58 -268
  28. package/lib/example/view/div/sizeable/left.js +13 -104
  29. package/lib/example/view/div/tabButtons/left.js +42 -161
  30. package/lib/example/view/div/tabButtons/right.js +75 -198
  31. package/lib/example/view/div/tabButtons.js +15 -172
  32. package/lib/example/view/textarea/css.js +29 -147
  33. package/lib/example/view/textarea/markdown.js +29 -145
  34. package/lib/example/view/textarea/markdownStyle.js +29 -145
  35. package/lib/example/view/textarea/parseTree/css.js +21 -132
  36. package/lib/example/view/textarea/parseTree/html.js +21 -132
  37. package/lib/example/view/textarea/parseTree/markdown.js +17 -129
  38. package/lib/example/view/textarea/parseTree/markdownStyle.js +17 -129
  39. package/lib/example/view/textarea/parseTree.js +20 -135
  40. package/lib/example/view/textarea/plainText.js +32 -153
  41. package/lib/example/view/textarea.js +16 -23
  42. package/lib/example/view/xmp.js +30 -187
  43. package/lib/example/view.js +281 -518
  44. package/lib/example.js +10 -10
  45. package/lib/index/item.js +25 -87
  46. package/lib/index/list.js +29 -62
  47. package/lib/index/match.js +23 -62
  48. package/lib/index.js +34 -34
  49. package/lib/letters.js +3 -3
  50. package/lib/map/className.js +6 -6
  51. package/lib/map/node/css.js +50 -42
  52. package/lib/map/node/html.js +108 -71
  53. package/lib/map/nonTerminalNode/markdown.js +49 -40
  54. package/lib/map/nonTerminalNode/markdownStyle.js +49 -40
  55. package/lib/map/tagName.js +6 -6
  56. package/lib/markdown/bnf.js +300 -3
  57. package/lib/markdown/entries.js +3 -3
  58. package/lib/markdown/lexer.js +23 -126
  59. package/lib/markdown/parser.js +18 -121
  60. package/lib/markdownStyle/bnf.js +80 -3
  61. package/lib/markdownStyle/entries.js +8 -8
  62. package/lib/markdownStyle/lexer.js +23 -126
  63. package/lib/markdownStyle/parser.js +18 -121
  64. package/lib/mixins/node.js +53 -53
  65. package/lib/mixins/token.js +13 -13
  66. package/lib/node/css/amount.js +16 -110
  67. package/lib/node/css/argument.js +8 -95
  68. package/lib/node/css/arguments.js +13 -127
  69. package/lib/node/css/class.js +13 -127
  70. package/lib/node/css/colour.js +16 -110
  71. package/lib/node/css/content.js +12 -103
  72. package/lib/node/css/declaration.js +19 -109
  73. package/lib/node/css/identifier.js +16 -110
  74. package/lib/node/css/name.js +13 -127
  75. package/lib/node/css/pseudoClass.js +13 -127
  76. package/lib/node/css/ruleName.js +43 -137
  77. package/lib/node/css/ruleSet.js +45 -139
  78. package/lib/node/css/selector.js +8 -95
  79. package/lib/node/css/selectors.js +19 -110
  80. package/lib/node/css/selectorsList.js +22 -115
  81. package/lib/node/css/string.js +16 -110
  82. package/lib/node/css/target.js +12 -103
  83. package/lib/node/css/topmost.js +70 -182
  84. package/lib/node/css/value.js +12 -126
  85. package/lib/node/css/values.js +16 -107
  86. package/lib/node/css/verbatim.js +35 -132
  87. package/lib/node/css.js +66 -275
  88. package/lib/node/html/anchor/contents.js +8 -92
  89. package/lib/node/html/anchor/footnote.js +8 -92
  90. package/lib/node/html/anchor/index.js +8 -92
  91. package/lib/node/html/anchor.js +38 -157
  92. package/lib/node/html/container.js +24 -154
  93. package/lib/node/html/directive/contents.js +8 -95
  94. package/lib/node/html/directive/footnotes.js +8 -95
  95. package/lib/node/html/directive/index.js +8 -95
  96. package/lib/node/html/directive/pageNumber.js +8 -95
  97. package/lib/node/html/directive.js +23 -123
  98. package/lib/node/html/division.js +127 -273
  99. package/lib/node/html/error.js +41 -179
  100. package/lib/node/html/footnote.js +40 -149
  101. package/lib/node/html/heading/index.js +61 -183
  102. package/lib/node/html/heading/primary.js +12 -112
  103. package/lib/node/html/heading/quaternary.js +12 -112
  104. package/lib/node/html/heading/secondary.js +12 -112
  105. package/lib/node/html/heading/tertiary.js +12 -112
  106. package/lib/node/html/heading.js +30 -147
  107. package/lib/node/html/image.js +76 -207
  108. package/lib/node/html/item/contents.js +20 -124
  109. package/lib/node/html/item/footnote.js +21 -125
  110. package/lib/node/html/item/index.js +39 -145
  111. package/lib/node/html/item/ordered.js +23 -133
  112. package/lib/node/html/item/unordered.js +10 -110
  113. package/lib/node/html/line/block.js +15 -119
  114. package/lib/node/html/line.js +89 -242
  115. package/lib/node/html/link/contents.js +36 -153
  116. package/lib/node/html/link/email.js +89 -243
  117. package/lib/node/html/link/footnote.js +94 -238
  118. package/lib/node/html/link/hyper.js +89 -243
  119. package/lib/node/html/link/index.js +67 -222
  120. package/lib/node/html/list/contents.js +20 -124
  121. package/lib/node/html/list/footnotes.js +40 -160
  122. package/lib/node/html/list/index.js +20 -124
  123. package/lib/node/html/list/ordered.js +10 -110
  124. package/lib/node/html/list/unordered.js +10 -110
  125. package/lib/node/html/listing/block.js +33 -177
  126. package/lib/node/html/listing/inline.js +35 -174
  127. package/lib/node/html/pageNumber.js +65 -216
  128. package/lib/node/html/paragraph.js +10 -110
  129. package/lib/node/html/reference.js +10 -110
  130. package/lib/node/html/table.js +10 -110
  131. package/lib/node/html/tableBody.js +10 -110
  132. package/lib/node/html/tableBodyCell.js +10 -110
  133. package/lib/node/html/tableBodyRow.js +10 -110
  134. package/lib/node/html/tableHead.js +10 -110
  135. package/lib/node/html/tableHeadCell.js +10 -110
  136. package/lib/node/html/tableHeadRow.js +10 -110
  137. package/lib/node/html/text/block.js +10 -110
  138. package/lib/node/html/text/comma.js +21 -128
  139. package/lib/node/html/text/emphasised.js +14 -118
  140. package/lib/node/html/text/index.js +28 -143
  141. package/lib/node/html/text/inline.js +34 -147
  142. package/lib/node/html/text/plain.js +10 -110
  143. package/lib/node/html/text/strong.js +14 -118
  144. package/lib/node/html/text/stronglyEmphasised.js +66 -208
  145. package/lib/node/html/text.js +24 -162
  146. package/lib/node/html/topmost.js +100 -240
  147. package/lib/node/html.js +256 -554
  148. package/lib/node/markdown/blockEnd.js +5 -89
  149. package/lib/node/markdown/blockStart.js +18 -113
  150. package/lib/node/markdown/className.js +12 -100
  151. package/lib/node/markdown/container.js +18 -113
  152. package/lib/node/markdown/directive/embed.js +39 -137
  153. package/lib/node/markdown/directive/include.js +39 -137
  154. package/lib/node/markdown/division.js +70 -216
  155. package/lib/node/markdown/document.js +44 -147
  156. package/lib/node/markdown/error.js +12 -100
  157. package/lib/node/markdown/footnote.js +12 -100
  158. package/lib/node/markdown/hyperlink.js +34 -131
  159. package/lib/node/markdown/image.js +12 -100
  160. package/lib/node/markdown/item/ordered.js +15 -103
  161. package/lib/node/markdown/link/email.js +34 -131
  162. package/lib/node/markdown/link/footnote.js +14 -102
  163. package/lib/node/markdown/listng/block.js +12 -100
  164. package/lib/node/markdown/listng/inline.js +18 -106
  165. package/lib/node/markdown/path.js +12 -100
  166. package/lib/node/markdown/reference.js +15 -103
  167. package/lib/node/markdown/subDivision.js +35 -126
  168. package/lib/node/markdown/text/block.js +5 -89
  169. package/lib/node/markdown/text/plain.js +5 -89
  170. package/lib/node/markdown/text.js +46 -134
  171. package/lib/node/markdown.js +34 -169
  172. package/lib/node/markdownStyle/amount.js +13 -101
  173. package/lib/node/markdownStyle/argument.js +5 -89
  174. package/lib/node/markdownStyle/arguments.js +5 -89
  175. package/lib/node/markdownStyle/colour.js +12 -100
  176. package/lib/node/markdownStyle/content.js +21 -109
  177. package/lib/node/markdownStyle/declaration.js +5 -89
  178. package/lib/node/markdownStyle/document.js +5 -89
  179. package/lib/node/markdownStyle/error.js +5 -89
  180. package/lib/node/markdownStyle/identifier.js +13 -101
  181. package/lib/node/markdownStyle/name.js +5 -89
  182. package/lib/node/markdownStyle/nonsense.js +5 -89
  183. package/lib/node/markdownStyle/pseudoClass.js +5 -89
  184. package/lib/node/markdownStyle/ruleName.js +12 -100
  185. package/lib/node/markdownStyle/ruleSet.js +5 -89
  186. package/lib/node/markdownStyle/selector.js +5 -89
  187. package/lib/node/markdownStyle/selectors.js +5 -89
  188. package/lib/node/markdownStyle/selectorsList.js +5 -89
  189. package/lib/node/markdownStyle/string.js +12 -100
  190. package/lib/node/markdownStyle/target.js +12 -100
  191. package/lib/node/markdownStyle/value.js +5 -89
  192. package/lib/node/markdownStyle/values.js +5 -89
  193. package/lib/node/markdownStyle/verbatim.js +5 -89
  194. package/lib/node/markdownStyle.js +16 -135
  195. package/lib/prepends.js +4 -4
  196. package/lib/queries/markdown.js +7 -7
  197. package/lib/queries/markdownStyle.js +7 -7
  198. package/lib/ruleNames/markdown.js +145 -145
  199. package/lib/ruleNames/markdownStyle.js +51 -51
  200. package/lib/style/defaultMarkdown.js +247 -3
  201. package/lib/style/font.js +54 -3
  202. package/lib/styleElement/markdown/default.js +17 -131
  203. package/lib/styleElement/markdown.js +30 -151
  204. package/lib/styleElement.js +30 -69
  205. package/lib/targets.js +3 -3
  206. package/lib/tokenTypes.js +39 -39
  207. package/lib/transform/css/ruleSet.js +15 -106
  208. package/lib/transform/css/selectors.js +17 -108
  209. package/lib/transform/css/selectorsList.js +28 -121
  210. package/lib/transform/css.js +35 -139
  211. package/lib/transform/html/anchor/index.js +11 -99
  212. package/lib/transform/html/division.js +18 -112
  213. package/lib/transform/html/footnote.js +25 -122
  214. package/lib/transform/html/heading/index.js +7 -91
  215. package/lib/transform/html/index.js +44 -139
  216. package/lib/transform/html/item/contents.js +23 -111
  217. package/lib/transform/html/item/footnote.js +11 -99
  218. package/lib/transform/html/item/index.js +11 -99
  219. package/lib/transform/html/line.js +10 -98
  220. package/lib/transform/html/link/contents.js +20 -111
  221. package/lib/transform/html/link/footnote.js +36 -140
  222. package/lib/transform/html/list/contents.js +37 -151
  223. package/lib/transform/html/list/footnotes.js +19 -110
  224. package/lib/transform/html/list/index.js +16 -100
  225. package/lib/transform/html/pageNumber.js +15 -106
  226. package/lib/transform/html.js +28 -132
  227. package/lib/transform/markdown/directive/embed.js +9 -120
  228. package/lib/transform/markdown/directive/ignore.js +6 -90
  229. package/lib/transform/markdown/directive/include.js +15 -129
  230. package/lib/transform/markdown/subDivision.js +6 -90
  231. package/lib/transform/markdown.js +7 -134
  232. package/lib/utilities/contents.js +74 -145
  233. package/lib/utilities/css.js +12 -16
  234. package/lib/utilities/dom.js +11 -11
  235. package/lib/utilities/entities.js +2 -2
  236. package/lib/utilities/entries.js +5 -5
  237. package/lib/utilities/grammar.js +57 -86
  238. package/lib/utilities/html.js +21 -25
  239. package/lib/utilities/index.js +76 -89
  240. package/lib/utilities/markdown.js +14 -17
  241. package/lib/utilities/markdownStyle.js +2 -2
  242. package/lib/utilities/object.js +16 -16
  243. package/lib/utilities/query.js +13 -14
  244. package/lib/utilities/string.js +2 -2
  245. package/package.json +3 -3
@@ -8,539 +8,302 @@ Object.defineProperty(exports, "default", {
8
8
  return _default;
9
9
  }
10
10
  });
11
- var _easywithstyle = /*#__PURE__*/ _interop_require_default(require("easy-with-style"));
12
- var _easy = require("easy");
13
- var _index = require("../index");
14
- var _easylayout = require("easy-layout");
15
- var _indexOptions = /*#__PURE__*/ _interop_require_default(require("./indexOptions"));
16
- var _pageButtons = /*#__PURE__*/ _interop_require_default(require("./view/div/pageButtons"));
17
- var _left = /*#__PURE__*/ _interop_require_default(require("./view/div/sizeable/left"));
18
- var _css = /*#__PURE__*/ _interop_require_default(require("./view/div/container/css"));
19
- var _html = /*#__PURE__*/ _interop_require_default(require("./view/div/container/html"));
20
- var _left1 = /*#__PURE__*/ _interop_require_default(require("./view/div/tabButtons/left"));
21
- var _right = /*#__PURE__*/ _interop_require_default(require("./view/div/tabButtons/right"));
22
- var _preview = /*#__PURE__*/ _interop_require_default(require("./view/div/container/preview"));
23
- var _markdown = /*#__PURE__*/ _interop_require_default(require("./view/div/container/markdown"));
24
- var _css1 = /*#__PURE__*/ _interop_require_default(require("./view/textarea/parseTree/css"));
25
- var _html1 = /*#__PURE__*/ _interop_require_default(require("./view/textarea/parseTree/html"));
26
- var _plainText = /*#__PURE__*/ _interop_require_default(require("./view/div/container/plainText"));
27
- var _markdownStyle = /*#__PURE__*/ _interop_require_default(require("./view/div/container/markdownStyle"));
28
- var _targets = require("../targets");
29
- var _importer = require("./importer");
30
- var _constants = require("./constants");
31
- function _assert_this_initialized(self) {
32
- if (self === void 0) {
33
- throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
34
- }
35
- return self;
36
- }
37
- function _call_super(_this, derived, args) {
38
- derived = _get_prototype_of(derived);
39
- return _possible_constructor_return(_this, _is_native_reflect_construct() ? Reflect.construct(derived, args || [], _get_prototype_of(_this).constructor) : derived.apply(_this, args));
40
- }
41
- function _class_call_check(instance, Constructor) {
42
- if (!(instance instanceof Constructor)) {
43
- throw new TypeError("Cannot call a class as a function");
44
- }
45
- }
46
- function _construct(Parent, args, Class) {
47
- if (_is_native_reflect_construct()) {
48
- _construct = Reflect.construct;
49
- } else {
50
- _construct = function construct(Parent, args, Class) {
51
- var a = [
52
- null
53
- ];
54
- a.push.apply(a, args);
55
- var Constructor = Function.bind.apply(Parent, a);
56
- var instance = new Constructor();
57
- if (Class) _set_prototype_of(instance, Class.prototype);
58
- return instance;
59
- };
60
- }
61
- return _construct.apply(null, arguments);
62
- }
63
- function _defineProperties(target, props) {
64
- for(var i = 0; i < props.length; i++){
65
- var descriptor = props[i];
66
- descriptor.enumerable = descriptor.enumerable || false;
67
- descriptor.configurable = true;
68
- if ("value" in descriptor) descriptor.writable = true;
69
- Object.defineProperty(target, descriptor.key, descriptor);
70
- }
71
- }
72
- function _create_class(Constructor, protoProps, staticProps) {
73
- if (protoProps) _defineProperties(Constructor.prototype, protoProps);
74
- if (staticProps) _defineProperties(Constructor, staticProps);
75
- return Constructor;
76
- }
77
- function _define_property(obj, key, value) {
78
- if (key in obj) {
79
- Object.defineProperty(obj, key, {
80
- value: value,
81
- enumerable: true,
82
- configurable: true,
83
- writable: true
84
- });
85
- } else {
86
- obj[key] = value;
87
- }
88
- return obj;
89
- }
90
- function _get_prototype_of(o) {
91
- _get_prototype_of = Object.setPrototypeOf ? Object.getPrototypeOf : function getPrototypeOf(o) {
92
- return o.__proto__ || Object.getPrototypeOf(o);
93
- };
94
- return _get_prototype_of(o);
95
- }
96
- function _inherits(subClass, superClass) {
97
- if (typeof superClass !== "function" && superClass !== null) {
98
- throw new TypeError("Super expression must either be null or a function");
99
- }
100
- subClass.prototype = Object.create(superClass && superClass.prototype, {
101
- constructor: {
102
- value: subClass,
103
- writable: true,
104
- configurable: true
105
- }
106
- });
107
- if (superClass) _set_prototype_of(subClass, superClass);
108
- }
11
+ const _easywithstyle = /*#__PURE__*/ _interop_require_default(require("easy-with-style"));
12
+ const _easy = require("easy");
13
+ const _index = require("../index");
14
+ const _easylayout = require("easy-layout");
15
+ const _indexOptions = /*#__PURE__*/ _interop_require_default(require("./indexOptions"));
16
+ const _pageButtons = /*#__PURE__*/ _interop_require_default(require("./view/div/pageButtons"));
17
+ const _left = /*#__PURE__*/ _interop_require_default(require("./view/div/sizeable/left"));
18
+ const _css = /*#__PURE__*/ _interop_require_default(require("./view/div/container/css"));
19
+ const _html = /*#__PURE__*/ _interop_require_default(require("./view/div/container/html"));
20
+ const _left1 = /*#__PURE__*/ _interop_require_default(require("./view/div/tabButtons/left"));
21
+ const _right = /*#__PURE__*/ _interop_require_default(require("./view/div/tabButtons/right"));
22
+ const _preview = /*#__PURE__*/ _interop_require_default(require("./view/div/container/preview"));
23
+ const _markdown = /*#__PURE__*/ _interop_require_default(require("./view/div/container/markdown"));
24
+ const _css1 = /*#__PURE__*/ _interop_require_default(require("./view/textarea/parseTree/css"));
25
+ const _html1 = /*#__PURE__*/ _interop_require_default(require("./view/textarea/parseTree/html"));
26
+ const _plainText = /*#__PURE__*/ _interop_require_default(require("./view/div/container/plainText"));
27
+ const _markdownStyle = /*#__PURE__*/ _interop_require_default(require("./view/div/container/markdownStyle"));
28
+ const _targets = require("../targets");
29
+ const _importer = require("./importer");
30
+ const _constants = require("./constants");
109
31
  function _interop_require_default(obj) {
110
32
  return obj && obj.__esModule ? obj : {
111
33
  default: obj
112
34
  };
113
35
  }
114
- function _is_native_function(fn) {
115
- return Function.toString.call(fn).indexOf("[native code]") !== -1;
116
- }
117
- function _possible_constructor_return(self, call) {
118
- if (call && (_type_of(call) === "object" || typeof call === "function")) {
119
- return call;
120
- }
121
- return _assert_this_initialized(self);
122
- }
123
- function _set_prototype_of(o, p) {
124
- _set_prototype_of = Object.setPrototypeOf || function setPrototypeOf(o, p) {
125
- o.__proto__ = p;
126
- return o;
36
+ const { tokensFromMarkdown, tokensFromMarkdownStyle, documentMarkdownNodeFromTokens, htmlFromMarkdownOptionsAndImporter, documentMarkdownStyleNodeFromTokens, topmostHTMLNodeFromDocumentMarkdownNode, cssFromMarkdownStyleAndCSSSelectorsString, topmostCSSNodeFromDocumentMarkdownStyleNode } = _index.grammarUtilities;
37
+ class View extends _easy.Element {
38
+ pageUpdateCustomHandler = (event, element, index)=>{
39
+ this.updateHTML(index);
127
40
  };
128
- return _set_prototype_of(o, p);
129
- }
130
- function _tagged_template_literal(strings, raw) {
131
- if (!raw) {
132
- raw = strings.slice(0);
41
+ markdownStyleCustomHandler = (event, element)=>{
42
+ this.markdownStyle();
43
+ };
44
+ markdownCustomHandler = (event, element)=>{
45
+ this.markdown();
46
+ };
47
+ plainTextCustomHandler = (event, element)=>{
48
+ this.plainText();
49
+ };
50
+ previewCustomHandler = (event, element)=>{
51
+ this.preview();
52
+ };
53
+ keyUpCustomHandler = (event, element)=>{
54
+ this.update();
55
+ };
56
+ htmlCustomHandler = (event, element)=>{
57
+ this.html();
58
+ };
59
+ cssCustomHandler = (event, element)=>{
60
+ this.css();
61
+ };
62
+ update() {
63
+ this.updateMarkdownStyle();
64
+ this.updateMarkdown();
65
+ this.updateHTML();
66
+ this.updateCSS();
133
67
  }
134
- return Object.freeze(Object.defineProperties(strings, {
135
- raw: {
136
- value: Object.freeze(raw)
68
+ updateMarkdownStyle() {
69
+ const markdownStyle = this.getMarkdownStyle(), tokens = tokensFromMarkdownStyle(markdownStyle), documentMarkdownStyleNode = documentMarkdownStyleNodeFromTokens(tokens);
70
+ if (documentMarkdownStyleNode === null) {
71
+ this.resetMarkdownStyleTokens();
72
+ this.resetDocumentMarkdownStyleNode();
73
+ this.clearMarkdownStyleParseTreeTextarea();
74
+ return;
137
75
  }
138
- }));
139
- }
140
- function _type_of(obj) {
141
- "@swc/helpers - typeof";
142
- return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
143
- }
144
- function _wrap_native_super(Class) {
145
- var _cache = typeof Map === "function" ? new Map() : undefined;
146
- _wrap_native_super = function wrapNativeSuper(Class) {
147
- if (Class === null || !_is_native_function(Class)) return Class;
148
- if (typeof Class !== "function") {
149
- throw new TypeError("Super expression must either be null or a function");
76
+ const node = documentMarkdownStyleNode, parseTree = node.asParseTree(tokens), markdownStyleTokens = tokens; ///
77
+ this.setMarkdownStyleTokens(markdownStyleTokens);
78
+ this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);
79
+ this.updateMarkdownStyleParseTreeTextarea(parseTree);
80
+ }
81
+ updateMarkdown() {
82
+ const markdown = this.getMarkdown(), tokens = tokensFromMarkdown(markdown), documentMarkdownNode = documentMarkdownNodeFromTokens(tokens);
83
+ if (documentMarkdownNode === null) {
84
+ this.resetMarkdownTokens();
85
+ this.resetDocumentMarkdownNode();
86
+ this.clearMarkdownParseTreeTextarea();
87
+ return;
150
88
  }
151
- if (typeof _cache !== "undefined") {
152
- if (_cache.has(Class)) return _cache.get(Class);
153
- _cache.set(Class, Wrapper);
89
+ let context;
90
+ context = {
91
+ tokens,
92
+ importer: _importer.importer
93
+ };
94
+ documentMarkdownNode.resolve(context);
95
+ const documentMarkdownNodeParseTree = documentMarkdownNode.asParseTree(tokens), markdownParseTree = documentMarkdownNodeParseTree, markdownTokens = tokens; ///
96
+ this.setMarkdownTokens(markdownTokens);
97
+ this.setDocumentMarkdownNode(documentMarkdownNode);
98
+ this.updateMarkdownParseTreeTextarea(markdownParseTree);
99
+ }
100
+ updateHTML(index = 0) {
101
+ this.clearXMP();
102
+ this.clearPreviewDiv();
103
+ this.clearPlainTextTextarea();
104
+ this.clearHTMLParseTreeTextarea();
105
+ this.clearPageButtonsDiv();
106
+ const documentMarkdownNode = this.getDocumentMarkdownNode(), topmostHTMLNode = topmostHTMLNodeFromDocumentMarkdownNode(documentMarkdownNode);
107
+ if (topmostHTMLNode === null) {
108
+ return;
154
109
  }
155
- function Wrapper() {
156
- return _construct(Class, arguments, _get_prototype_of(this).constructor);
110
+ let context;
111
+ const markdownTokens = this.getMarkdownTokens(), tokens = markdownTokens; ///
112
+ context = {
113
+ tokens
114
+ };
115
+ topmostHTMLNode.resolve(context);
116
+ const divisionHTMLNode = topmostHTMLNode.getDivisionHTMLNodeAt(index);
117
+ if (divisionHTMLNode === null) {
118
+ return;
119
+ }
120
+ const divisionHTMLNOdeParseTree = divisionHTMLNode.asParseTree(), htmlParseTree = divisionHTMLNOdeParseTree, divisionHTMLNodes = topmostHTMLNode.getDivisionHTMLNodes(), length = divisionHTMLNodes.length; ///
121
+ context = {
122
+ tokens,
123
+ pathToURL
124
+ };
125
+ this.updatePreviewDiv(divisionHTMLNode, context);
126
+ this.updatePlainTextTextarea(divisionHTMLNode, context);
127
+ this.updateHTMLParseTreeTextarea(htmlParseTree);
128
+ this.updatePageButtonsDiv(length, index);
129
+ const markdown = this.getMarkdown(), options = _indexOptions.default, html = htmlFromMarkdownOptionsAndImporter(markdown, options, _importer.importer);
130
+ this.updateXMP(html, context);
131
+ }
132
+ updateCSS() {
133
+ const markdownStyleTokens = this.getMarkdownStyleTokens(), markdownStyleElement = this.getMarkdownStyleElement(), documentMarkdownStyleNode = this.getDocumentMarkdownStyleNode();
134
+ if (documentMarkdownStyleNode === null) {
135
+ const css = _constants.EMPTY_STRING;
136
+ markdownStyleElement.setCSS(css);
137
+ this.clearCSSParseTreeTextarea();
138
+ this.clearCSS();
139
+ return;
157
140
  }
158
- Wrapper.prototype = Object.create(Class.prototype, {
159
- constructor: {
160
- value: Wrapper,
161
- enumerable: false,
162
- writable: true,
163
- configurable: true
164
- }
141
+ const topmostCSSNode = topmostCSSNodeFromDocumentMarkdownStyleNode(documentMarkdownStyleNode), target = _targets.WEB_TARGET, tokens = markdownStyleTokens, context = {
142
+ target,
143
+ tokens
144
+ };
145
+ topmostCSSNode.resolve(context);
146
+ const topmostCSSNodeParseTree = topmostCSSNode.asParseTree(tokens), cssParseTree = topmostCSSNodeParseTree; ///
147
+ this.updateCSSParseTreeTextarea(cssParseTree);
148
+ const cssSelectorsString = _constants.CSS_SELECTORS_STRING, markdownStyle = this.getMarkdownStyle(), css = cssFromMarkdownStyleAndCSSSelectorsString(markdownStyle, cssSelectorsString);
149
+ markdownStyleElement.setCSS(css);
150
+ this.setCSS(css);
151
+ }
152
+ markdownStyle() {
153
+ this.hideMarkdownContainerDiv();
154
+ this.showMarkdownStyleContainerDiv();
155
+ }
156
+ markdown() {
157
+ this.showMarkdownContainerDiv();
158
+ this.hideMarkdownStyleContainerDiv();
159
+ }
160
+ plainText() {
161
+ this.hideCSSContainerDiv();
162
+ this.hideHTMLContainerDiv();
163
+ this.hidePreviewContainerDiv();
164
+ this.showPlainTextContainerDiv();
165
+ this.hideCSSParseTreeTextarea();
166
+ this.showHTMLParseTreeTextarea();
167
+ }
168
+ preview() {
169
+ this.hideCSSContainerDiv();
170
+ this.hideHTMLContainerDiv();
171
+ this.showPreviewContainerDiv();
172
+ this.hidePlainTextContainerDiv();
173
+ this.hideCSSParseTreeTextarea();
174
+ this.showHTMLParseTreeTextarea();
175
+ }
176
+ html() {
177
+ this.hideCSSContainerDiv();
178
+ this.showHTMLContainerDiv();
179
+ this.hidePreviewContainerDiv();
180
+ this.hidePlainTextContainerDiv();
181
+ this.hideCSSParseTreeTextarea();
182
+ this.showHTMLParseTreeTextarea();
183
+ }
184
+ css() {
185
+ this.showCSSContainerDiv();
186
+ this.hideHTMLContainerDiv();
187
+ this.hidePreviewContainerDiv();
188
+ this.hidePlainTextContainerDiv();
189
+ this.showCSSParseTreeTextarea();
190
+ this.hideHTMLParseTreeTextarea();
191
+ }
192
+ resetMarkdownTokens() {
193
+ const markdownTokens = null;
194
+ this.setMarkdownTokens(markdownTokens);
195
+ }
196
+ resetMarkdownStyleTokens() {
197
+ const markdownStyleTokens = null;
198
+ this.setMarkdownStyleTokens(markdownStyleTokens);
199
+ }
200
+ resetDocumentMarkdownNode() {
201
+ const documentMarkdownNode = null;
202
+ this.setDocumentMarkdownNode(documentMarkdownNode);
203
+ }
204
+ resetDocumentMarkdownStyleNode() {
205
+ const documentMarkdownStyleNode = null;
206
+ this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);
207
+ }
208
+ getMarkdownStyleElement() {
209
+ const { markdownStyleElement } = this.properties;
210
+ return markdownStyleElement;
211
+ }
212
+ getMarkdownTokens() {
213
+ const { markdownTokens } = this.getState();
214
+ return markdownTokens;
215
+ }
216
+ getMarkdownStyleTokens() {
217
+ const { markdownStyleTokens } = this.getState();
218
+ return markdownStyleTokens;
219
+ }
220
+ getDocumentMarkdownNode() {
221
+ const { topmostMMarkdownNode } = this.getState();
222
+ return topmostMMarkdownNode;
223
+ }
224
+ getDocumentMarkdownStyleNode() {
225
+ const { topmostMMarkdownStyleNode } = this.getState();
226
+ return topmostMMarkdownStyleNode;
227
+ }
228
+ setMarkdownTokens(markdownTokens) {
229
+ this.updateState({
230
+ markdownTokens
165
231
  });
166
- return _set_prototype_of(Wrapper, Class);
167
- };
168
- return _wrap_native_super(Class);
169
- }
170
- function _is_native_reflect_construct() {
171
- try {
172
- var result = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() {}));
173
- } catch (_) {}
174
- return (_is_native_reflect_construct = function() {
175
- return !!result;
176
- })();
177
- }
178
- function _templateObject() {
179
- var data = _tagged_template_literal([
180
- "\n\n padding: 1rem;\n \n"
181
- ]);
182
- _templateObject = function _templateObject() {
183
- return data;
184
- };
185
- return data;
186
- }
187
- var tokensFromMarkdown = _index.grammarUtilities.tokensFromMarkdown, tokensFromMarkdownStyle = _index.grammarUtilities.tokensFromMarkdownStyle, documentMarkdownNodeFromTokens = _index.grammarUtilities.documentMarkdownNodeFromTokens, htmlFromMarkdownOptionsAndImporter = _index.grammarUtilities.htmlFromMarkdownOptionsAndImporter, documentMarkdownStyleNodeFromTokens = _index.grammarUtilities.documentMarkdownStyleNodeFromTokens, topmostHTMLNodeFromDocumentMarkdownNode = _index.grammarUtilities.topmostHTMLNodeFromDocumentMarkdownNode, cssFromMarkdownStyleAndCSSSelectorsString = _index.grammarUtilities.cssFromMarkdownStyleAndCSSSelectorsString, topmostCSSNodeFromDocumentMarkdownStyleNode = _index.grammarUtilities.topmostCSSNodeFromDocumentMarkdownStyleNode;
188
- var View = /*#__PURE__*/ function(Element) {
189
- _inherits(View, Element);
190
- function View() {
191
- _class_call_check(this, View);
192
- var _this;
193
- _this = _call_super(this, View, arguments), _define_property(_this, "pageUpdateCustomHandler", function(event, element, index) {
194
- _this.updateHTML(index);
195
- }), _define_property(_this, "markdownStyleCustomHandler", function(event, element) {
196
- _this.markdownStyle();
197
- }), _define_property(_this, "markdownCustomHandler", function(event, element) {
198
- _this.markdown();
199
- }), _define_property(_this, "plainTextCustomHandler", function(event, element) {
200
- _this.plainText();
201
- }), _define_property(_this, "previewCustomHandler", function(event, element) {
202
- _this.preview();
203
- }), _define_property(_this, "keyUpCustomHandler", function(event, element) {
204
- _this.update();
205
- }), _define_property(_this, "htmlCustomHandler", function(event, element) {
206
- _this.html();
207
- }), _define_property(_this, "cssCustomHandler", function(event, element) {
208
- _this.css();
232
+ }
233
+ setMarkdownStyleTokens(markdownStyleTokens) {
234
+ this.updateState({
235
+ markdownStyleTokens
209
236
  });
210
- return _this;
211
237
  }
212
- _create_class(View, [
213
- {
214
- key: "update",
215
- value: function update() {
216
- this.updateMarkdownStyle();
217
- this.updateMarkdown();
218
- this.updateHTML();
219
- this.updateCSS();
220
- }
221
- },
222
- {
223
- key: "updateMarkdownStyle",
224
- value: function updateMarkdownStyle() {
225
- var markdownStyle = this.getMarkdownStyle(), tokens = tokensFromMarkdownStyle(markdownStyle), documentMarkdownStyleNode = documentMarkdownStyleNodeFromTokens(tokens);
226
- if (documentMarkdownStyleNode === null) {
227
- this.resetMarkdownStyleTokens();
228
- this.resetDocumentMarkdownStyleNode();
229
- this.clearMarkdownStyleParseTreeTextarea();
230
- return;
231
- }
232
- var node = documentMarkdownStyleNode, parseTree = node.asParseTree(tokens), markdownStyleTokens = tokens; ///
233
- this.setMarkdownStyleTokens(markdownStyleTokens);
234
- this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);
235
- this.updateMarkdownStyleParseTreeTextarea(parseTree);
236
- }
237
- },
238
- {
239
- key: "updateMarkdown",
240
- value: function updateMarkdown() {
241
- var markdown = this.getMarkdown(), tokens = tokensFromMarkdown(markdown), documentMarkdownNode = documentMarkdownNodeFromTokens(tokens);
242
- if (documentMarkdownNode === null) {
243
- this.resetMarkdownTokens();
244
- this.resetDocumentMarkdownNode();
245
- this.clearMarkdownParseTreeTextarea();
246
- return;
247
- }
248
- var context;
249
- context = {
250
- tokens: tokens,
251
- importer: _importer.importer
252
- };
253
- documentMarkdownNode.resolve(context);
254
- var documentMarkdownNodeParseTree = documentMarkdownNode.asParseTree(tokens), markdownParseTree = documentMarkdownNodeParseTree, markdownTokens = tokens; ///
255
- this.setMarkdownTokens(markdownTokens);
256
- this.setDocumentMarkdownNode(documentMarkdownNode);
257
- this.updateMarkdownParseTreeTextarea(markdownParseTree);
258
- }
259
- },
260
- {
261
- key: "updateHTML",
262
- value: function updateHTML() {
263
- var index = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 0;
264
- this.clearXMP();
265
- this.clearPreviewDiv();
266
- this.clearPlainTextTextarea();
267
- this.clearHTMLParseTreeTextarea();
268
- this.clearPageButtonsDiv();
269
- var documentMarkdownNode = this.getDocumentMarkdownNode(), topmostHTMLNode = topmostHTMLNodeFromDocumentMarkdownNode(documentMarkdownNode);
270
- if (topmostHTMLNode === null) {
271
- return;
272
- }
273
- var context;
274
- var markdownTokens = this.getMarkdownTokens(), tokens = markdownTokens; ///
275
- context = {
276
- tokens: tokens
277
- };
278
- topmostHTMLNode.resolve(context);
279
- var divisionHTMLNode = topmostHTMLNode.getDivisionHTMLNodeAt(index);
280
- if (divisionHTMLNode === null) {
281
- return;
282
- }
283
- var divisionHTMLNOdeParseTree = divisionHTMLNode.asParseTree(), htmlParseTree = divisionHTMLNOdeParseTree, divisionHTMLNodes = topmostHTMLNode.getDivisionHTMLNodes(), length = divisionHTMLNodes.length; ///
284
- context = {
285
- tokens: tokens,
286
- pathToURL: pathToURL
287
- };
288
- this.updatePreviewDiv(divisionHTMLNode, context);
289
- this.updatePlainTextTextarea(divisionHTMLNode, context);
290
- this.updateHTMLParseTreeTextarea(htmlParseTree);
291
- this.updatePageButtonsDiv(length, index);
292
- var markdown = this.getMarkdown(), options = _indexOptions.default, html = htmlFromMarkdownOptionsAndImporter(markdown, options, _importer.importer);
293
- this.updateXMP(html, context);
294
- }
295
- },
296
- {
297
- key: "updateCSS",
298
- value: function updateCSS() {
299
- var markdownStyleTokens = this.getMarkdownStyleTokens(), markdownStyleElement = this.getMarkdownStyleElement(), documentMarkdownStyleNode = this.getDocumentMarkdownStyleNode();
300
- if (documentMarkdownStyleNode === null) {
301
- var css = _constants.EMPTY_STRING;
302
- markdownStyleElement.setCSS(css);
303
- this.clearCSSParseTreeTextarea();
304
- this.clearCSS();
305
- return;
306
- }
307
- var topmostCSSNode = topmostCSSNodeFromDocumentMarkdownStyleNode(documentMarkdownStyleNode), target = _targets.WEB_TARGET, tokens = markdownStyleTokens, context = {
308
- target: target,
309
- tokens: tokens
310
- };
311
- topmostCSSNode.resolve(context);
312
- var topmostCSSNodeParseTree = topmostCSSNode.asParseTree(tokens), cssParseTree = topmostCSSNodeParseTree; ///
313
- this.updateCSSParseTreeTextarea(cssParseTree);
314
- var cssSelectorsString = _constants.CSS_SELECTORS_STRING, markdownStyle = this.getMarkdownStyle(), css1 = cssFromMarkdownStyleAndCSSSelectorsString(markdownStyle, cssSelectorsString);
315
- markdownStyleElement.setCSS(css1);
316
- this.setCSS(css1);
317
- }
318
- },
319
- {
320
- key: "markdownStyle",
321
- value: function markdownStyle() {
322
- this.hideMarkdownContainerDiv();
323
- this.showMarkdownStyleContainerDiv();
324
- }
325
- },
326
- {
327
- key: "markdown",
328
- value: function markdown() {
329
- this.showMarkdownContainerDiv();
330
- this.hideMarkdownStyleContainerDiv();
331
- }
332
- },
333
- {
334
- key: "plainText",
335
- value: function plainText() {
336
- this.hideCSSContainerDiv();
337
- this.hideHTMLContainerDiv();
338
- this.hidePreviewContainerDiv();
339
- this.showPlainTextContainerDiv();
340
- this.hideCSSParseTreeTextarea();
341
- this.showHTMLParseTreeTextarea();
342
- }
343
- },
344
- {
345
- key: "preview",
346
- value: function preview() {
347
- this.hideCSSContainerDiv();
348
- this.hideHTMLContainerDiv();
349
- this.showPreviewContainerDiv();
350
- this.hidePlainTextContainerDiv();
351
- this.hideCSSParseTreeTextarea();
352
- this.showHTMLParseTreeTextarea();
353
- }
354
- },
355
- {
356
- key: "html",
357
- value: function html() {
358
- this.hideCSSContainerDiv();
359
- this.showHTMLContainerDiv();
360
- this.hidePreviewContainerDiv();
361
- this.hidePlainTextContainerDiv();
362
- this.hideCSSParseTreeTextarea();
363
- this.showHTMLParseTreeTextarea();
364
- }
365
- },
366
- {
367
- key: "css",
368
- value: function css() {
369
- this.showCSSContainerDiv();
370
- this.hideHTMLContainerDiv();
371
- this.hidePreviewContainerDiv();
372
- this.hidePlainTextContainerDiv();
373
- this.showCSSParseTreeTextarea();
374
- this.hideHTMLParseTreeTextarea();
375
- }
376
- },
377
- {
378
- key: "resetMarkdownTokens",
379
- value: function resetMarkdownTokens() {
380
- var markdownTokens = null;
381
- this.setMarkdownTokens(markdownTokens);
382
- }
383
- },
384
- {
385
- key: "resetMarkdownStyleTokens",
386
- value: function resetMarkdownStyleTokens() {
387
- var markdownStyleTokens = null;
388
- this.setMarkdownStyleTokens(markdownStyleTokens);
389
- }
390
- },
391
- {
392
- key: "resetDocumentMarkdownNode",
393
- value: function resetDocumentMarkdownNode() {
394
- var documentMarkdownNode = null;
395
- this.setDocumentMarkdownNode(documentMarkdownNode);
396
- }
397
- },
398
- {
399
- key: "resetDocumentMarkdownStyleNode",
400
- value: function resetDocumentMarkdownStyleNode() {
401
- var documentMarkdownStyleNode = null;
402
- this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);
403
- }
404
- },
405
- {
406
- key: "getMarkdownStyleElement",
407
- value: function getMarkdownStyleElement() {
408
- var markdownStyleElement = this.properties.markdownStyleElement;
409
- return markdownStyleElement;
410
- }
411
- },
412
- {
413
- key: "getMarkdownTokens",
414
- value: function getMarkdownTokens() {
415
- var markdownTokens = this.getState().markdownTokens;
416
- return markdownTokens;
417
- }
418
- },
419
- {
420
- key: "getMarkdownStyleTokens",
421
- value: function getMarkdownStyleTokens() {
422
- var markdownStyleTokens = this.getState().markdownStyleTokens;
423
- return markdownStyleTokens;
424
- }
425
- },
426
- {
427
- key: "getDocumentMarkdownNode",
428
- value: function getDocumentMarkdownNode() {
429
- var topmostMMarkdownNode = this.getState().topmostMMarkdownNode;
430
- return topmostMMarkdownNode;
431
- }
432
- },
433
- {
434
- key: "getDocumentMarkdownStyleNode",
435
- value: function getDocumentMarkdownStyleNode() {
436
- var topmostMMarkdownStyleNode = this.getState().topmostMMarkdownStyleNode;
437
- return topmostMMarkdownStyleNode;
438
- }
439
- },
440
- {
441
- key: "setMarkdownTokens",
442
- value: function setMarkdownTokens(markdownTokens) {
443
- this.updateState({
444
- markdownTokens: markdownTokens
445
- });
446
- }
447
- },
448
- {
449
- key: "setMarkdownStyleTokens",
450
- value: function setMarkdownStyleTokens(markdownStyleTokens) {
451
- this.updateState({
452
- markdownStyleTokens: markdownStyleTokens
453
- });
454
- }
455
- },
456
- {
457
- key: "setDocumentMarkdownNode",
458
- value: function setDocumentMarkdownNode(topmostMMarkdownNode) {
459
- this.updateState({
460
- topmostMMarkdownNode: topmostMMarkdownNode
461
- });
462
- }
463
- },
464
- {
465
- key: "setDocumentMarkdownStyleNode",
466
- value: function setDocumentMarkdownStyleNode(topmostMMarkdownStyleNode) {
467
- this.updateState({
468
- topmostMMarkdownStyleNode: topmostMMarkdownStyleNode
469
- });
470
- }
471
- },
472
- {
473
- key: "setInitialState",
474
- value: function setInitialState() {
475
- var markdownTokens = null, markdownStyleTokens = null, documentMarkdownNode = null, documentMarkdownStyleNode = null;
476
- this.setState({
477
- markdownTokens: markdownTokens,
478
- markdownStyleTokens: markdownStyleTokens,
479
- documentMarkdownNode: documentMarkdownNode,
480
- documentMarkdownStyleNode: documentMarkdownStyleNode
481
- });
482
- }
483
- },
484
- {
485
- key: "didMount",
486
- value: function didMount() {
487
- this.markdown();
488
- this.preview();
489
- this.update();
490
- }
491
- },
492
- {
493
- key: "willUnmount",
494
- value: function willUnmount() {
495
- ///
496
- }
497
- },
498
- {
499
- key: "childElements",
500
- value: function childElements() {
501
- return /*#__PURE__*/ React.createElement(_easylayout.ColumnsDiv, null, /*#__PURE__*/ React.createElement(_left.default, null, /*#__PURE__*/ React.createElement(_left1.default, {
502
- onCustomMarkdown: this.markdownCustomHandler,
503
- onCustomMarkdownStyle: this.markdownStyleCustomHandler
504
- }), /*#__PURE__*/ React.createElement(_markdown.default, {
505
- onCustomKeyUp: this.keyUpCustomHandler
506
- }), /*#__PURE__*/ React.createElement(_markdownStyle.default, {
507
- onCustomKeyUp: this.keyUpCustomHandler
508
- })), /*#__PURE__*/ React.createElement(_easylayout.VerticalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.ColumnDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_right.default, {
509
- onCustomCSS: this.cssCustomHandler,
510
- onCustomHTML: this.htmlCustomHandler,
511
- onCustomPreview: this.previewCustomHandler,
512
- onCustomPlainText: this.plainTextCustomHandler
513
- }), /*#__PURE__*/ React.createElement(_pageButtons.default, {
514
- onCustomPageUpdate: this.pageUpdateCustomHandler
515
- }), /*#__PURE__*/ React.createElement(_css.default, null), /*#__PURE__*/ React.createElement(_html.default, null), /*#__PURE__*/ React.createElement(_preview.default, null), /*#__PURE__*/ React.createElement(_plainText.default, null), /*#__PURE__*/ React.createElement(_html1.default, null), /*#__PURE__*/ React.createElement(_css1.default, null))));
516
- }
517
- },
518
- {
519
- key: "initialise",
520
- value: function initialise() {
521
- this.assignContext();
522
- this.setInitialState();
523
- var _this_constructor = this.constructor, _$initialMarkdown = _this_constructor.initialMarkdown, initialMarkdownStyle = _this_constructor.initialMarkdownStyle, markdownStyle = initialMarkdownStyle, markdown = _$initialMarkdown; ///
524
- this.setMarkdownStyle(markdownStyle);
525
- this.setMarkdown(markdown);
526
- }
527
- }
528
- ]);
529
- return View;
530
- }(_wrap_native_super(_easy.Element));
531
- _define_property(View, "initialMarkdown", _importer.initialMarkdown);
532
- _define_property(View, "initialMarkdownStyle", "");
533
- _define_property(View, "tagName", "div");
534
- _define_property(View, "ignoredProperties", [
535
- "markdownStyleElement"
536
- ]);
537
- _define_property(View, "defaultProperties", {
538
- className: "view"
539
- });
540
- var _default = (0, _easywithstyle.default)(View)(_templateObject());
238
+ setDocumentMarkdownNode(topmostMMarkdownNode) {
239
+ this.updateState({
240
+ topmostMMarkdownNode
241
+ });
242
+ }
243
+ setDocumentMarkdownStyleNode(topmostMMarkdownStyleNode) {
244
+ this.updateState({
245
+ topmostMMarkdownStyleNode
246
+ });
247
+ }
248
+ setInitialState() {
249
+ const markdownTokens = null, markdownStyleTokens = null, documentMarkdownNode = null, documentMarkdownStyleNode = null;
250
+ this.setState({
251
+ markdownTokens,
252
+ markdownStyleTokens,
253
+ documentMarkdownNode,
254
+ documentMarkdownStyleNode
255
+ });
256
+ }
257
+ didMount() {
258
+ this.markdown();
259
+ this.preview();
260
+ this.update();
261
+ }
262
+ willUnmount() {
263
+ ///
264
+ }
265
+ childElements() {
266
+ return /*#__PURE__*/ React.createElement(_easylayout.ColumnsDiv, null, /*#__PURE__*/ React.createElement(_left.default, null, /*#__PURE__*/ React.createElement(_left1.default, {
267
+ onCustomMarkdown: this.markdownCustomHandler,
268
+ onCustomMarkdownStyle: this.markdownStyleCustomHandler
269
+ }), /*#__PURE__*/ React.createElement(_markdown.default, {
270
+ onCustomKeyUp: this.keyUpCustomHandler
271
+ }), /*#__PURE__*/ React.createElement(_markdownStyle.default, {
272
+ onCustomKeyUp: this.keyUpCustomHandler
273
+ })), /*#__PURE__*/ React.createElement(_easylayout.VerticalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.ColumnDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_right.default, {
274
+ onCustomCSS: this.cssCustomHandler,
275
+ onCustomHTML: this.htmlCustomHandler,
276
+ onCustomPreview: this.previewCustomHandler,
277
+ onCustomPlainText: this.plainTextCustomHandler
278
+ }), /*#__PURE__*/ React.createElement(_pageButtons.default, {
279
+ onCustomPageUpdate: this.pageUpdateCustomHandler
280
+ }), /*#__PURE__*/ React.createElement(_css.default, null), /*#__PURE__*/ React.createElement(_html.default, null), /*#__PURE__*/ React.createElement(_preview.default, null), /*#__PURE__*/ React.createElement(_plainText.default, null), /*#__PURE__*/ React.createElement(_html1.default, null), /*#__PURE__*/ React.createElement(_css1.default, null))));
281
+ }
282
+ initialise() {
283
+ this.assignContext();
284
+ this.setInitialState();
285
+ const { initialMarkdown, initialMarkdownStyle } = this.constructor, markdownStyle = initialMarkdownStyle, markdown = initialMarkdown; ///
286
+ this.setMarkdownStyle(markdownStyle);
287
+ this.setMarkdown(markdown);
288
+ }
289
+ static initialMarkdown = _importer.initialMarkdown;
290
+ static initialMarkdownStyle = "";
291
+ static tagName = "div";
292
+ static ignoredProperties = [
293
+ "markdownStyleElement"
294
+ ];
295
+ static defaultProperties = {
296
+ className: "view"
297
+ };
298
+ }
299
+ const _default = (0, _easywithstyle.default)(View)`
300
+
301
+ padding: 1rem;
302
+
303
+ `;
541
304
  function pathToURL(path) {
542
- var url = "https://djalbat.com/".concat(path);
305
+ const url = `https://djalbat.com/${path}`;
543
306
  return url;
544
307
  }
545
308
 
546
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/example/view.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { Element } from \"easy\";\nimport { grammarUtilities } from \"../index\";  ///\nimport { RowsDiv, ColumnDiv, ColumnsDiv, VerticalSplitterDiv } from \"easy-layout\";\n\nimport indexOptions from \"./indexOptions\";\nimport PageButtonsDiv from \"./view/div/pageButtons\";\nimport LeftSizeableDiv from \"./view/div/sizeable/left\";\nimport CSSContainerDiv from \"./view/div/container/css\";\nimport HTMLContainerDiv from \"./view/div/container/html\";\nimport LeftTabButtonsDiv from \"./view/div/tabButtons/left\";\nimport RightTabButtonsDiv from \"./view/div/tabButtons/right\";\nimport PreviewContainerDiv from \"./view/div/container/preview\";\nimport MarkdownContainerDiv from \"./view/div/container/markdown\";\nimport CSSParseTreeTextarea from \"./view/textarea/parseTree/css\";\nimport HTMLParseTreeTextarea from \"./view/textarea/parseTree/html\";\nimport PlainTextContainerDiv from \"./view/div/container/plainText\";\nimport MarkdownStyleContainerDiv from \"./view/div/container/markdownStyle\";\n\nimport { WEB_TARGET } from \"../targets\";\nimport { initialMarkdown, importer } from \"./importer\";\nimport { EMPTY_STRING, CSS_SELECTORS_STRING } from \"./constants\";\n\nconst { tokensFromMarkdown,\n        tokensFromMarkdownStyle,\n        documentMarkdownNodeFromTokens,\n        htmlFromMarkdownOptionsAndImporter,\n        documentMarkdownStyleNodeFromTokens,\n        topmostHTMLNodeFromDocumentMarkdownNode,\n        cssFromMarkdownStyleAndCSSSelectorsString,\n        topmostCSSNodeFromDocumentMarkdownStyleNode } = grammarUtilities;\n\nclass View extends Element {\n  pageUpdateCustomHandler = (event, element, index) => {\n    this.updateHTML(index);\n  }\n\n  markdownStyleCustomHandler = (event, element) => {\n    this.markdownStyle();\n  }\n\n  markdownCustomHandler = (event, element) => {\n    this.markdown();\n  }\n\n  plainTextCustomHandler = (event, element) => {\n    this.plainText();\n  }\n\n  previewCustomHandler = (event, element) => {\n    this.preview();\n  }\n\n  keyUpCustomHandler = (event, element) => {\n    this.update();\n  }\n\n  htmlCustomHandler = (event, element) => {\n    this.html();\n  }\n\n  cssCustomHandler = (event, element) => {\n    this.css();\n  }\n\n  update() {\n    this.updateMarkdownStyle();\n\n    this.updateMarkdown();\n\n    this.updateHTML();\n\n    this.updateCSS();\n  }\n\n  updateMarkdownStyle() {\n    const markdownStyle = this.getMarkdownStyle(),\n          tokens = tokensFromMarkdownStyle(markdownStyle),\n          documentMarkdownStyleNode = documentMarkdownStyleNodeFromTokens(tokens);\n\n    if (documentMarkdownStyleNode === null) {\n      this.resetMarkdownStyleTokens();\n\n      this.resetDocumentMarkdownStyleNode();\n\n      this.clearMarkdownStyleParseTreeTextarea();\n\n      return;\n    }\n\n    const node = documentMarkdownStyleNode, ///\n          parseTree = node.asParseTree(tokens),\n          markdownStyleTokens = tokens; ///\n\n    this.setMarkdownStyleTokens(markdownStyleTokens);\n\n    this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);\n\n    this.updateMarkdownStyleParseTreeTextarea(parseTree);\n  }\n\n  updateMarkdown() {\n    const markdown = this.getMarkdown(),\n          tokens = tokensFromMarkdown(markdown),\n          documentMarkdownNode = documentMarkdownNodeFromTokens(tokens);\n\n    if (documentMarkdownNode === null) {\n      this.resetMarkdownTokens();\n\n      this.resetDocumentMarkdownNode();\n\n      this.clearMarkdownParseTreeTextarea();\n\n      return;\n    }\n\n    let context;\n\n    context = {\n      tokens,\n      importer\n    };\n\n    documentMarkdownNode.resolve(context);\n\n    const documentMarkdownNodeParseTree = documentMarkdownNode.asParseTree(tokens),\n          markdownParseTree = documentMarkdownNodeParseTree, ///\n          markdownTokens = tokens;  ///\n\n    this.setMarkdownTokens(markdownTokens);\n\n    this.setDocumentMarkdownNode(documentMarkdownNode);\n\n    this.updateMarkdownParseTreeTextarea(markdownParseTree);\n  }\n\n  updateHTML(index = 0) {\n    this.clearXMP();\n\n    this.clearPreviewDiv();\n\n    this.clearPlainTextTextarea();\n\n    this.clearHTMLParseTreeTextarea();\n\n    this.clearPageButtonsDiv();\n\n    const documentMarkdownNode = this.getDocumentMarkdownNode(),\n          topmostHTMLNode = topmostHTMLNodeFromDocumentMarkdownNode(documentMarkdownNode);\n\n    if (topmostHTMLNode === null) {\n      return;\n    }\n\n    let context;\n\n    const markdownTokens = this.getMarkdownTokens(),\n          tokens = markdownTokens;  ///\n\n    context = {\n      tokens\n    };\n\n    topmostHTMLNode.resolve(context);\n\n    const divisionHTMLNode = topmostHTMLNode.getDivisionHTMLNodeAt(index);\n\n    if (divisionHTMLNode === null) {\n      return;\n    }\n\n    const divisionHTMLNOdeParseTree = divisionHTMLNode.asParseTree(),\n          htmlParseTree = divisionHTMLNOdeParseTree,  ///\n          divisionHTMLNodes = topmostHTMLNode.getDivisionHTMLNodes(),\n          length = divisionHTMLNodes.length;  ///\n\n    context = {\n      tokens,\n      pathToURL\n    };\n\n    this.updatePreviewDiv(divisionHTMLNode, context);\n\n    this.updatePlainTextTextarea(divisionHTMLNode, context);\n\n    this.updateHTMLParseTreeTextarea(htmlParseTree);\n\n    this.updatePageButtonsDiv(length, index);\n\n    const markdown = this.getMarkdown(),\n          options = indexOptions, ///\n          html = htmlFromMarkdownOptionsAndImporter(markdown, options, importer);\n\n    this.updateXMP(html, context);\n  }\n\n  updateCSS() {\n    const markdownStyleTokens = this.getMarkdownStyleTokens(),\n          markdownStyleElement = this.getMarkdownStyleElement(),\n          documentMarkdownStyleNode = this.getDocumentMarkdownStyleNode();\n\n    if (documentMarkdownStyleNode === null) {\n      const css = EMPTY_STRING;\n\n      markdownStyleElement.setCSS(css);\n\n      this.clearCSSParseTreeTextarea();\n\n      this.clearCSS();\n\n      return;\n    }\n\n    const topmostCSSNode = topmostCSSNodeFromDocumentMarkdownStyleNode(documentMarkdownStyleNode),\n          target = WEB_TARGET,\n          tokens = markdownStyleTokens, ///\n          context = {\n            target,\n            tokens\n          };\n\n    topmostCSSNode.resolve(context);\n\n    const topmostCSSNodeParseTree = topmostCSSNode.asParseTree(tokens),\n          cssParseTree = topmostCSSNodeParseTree; ///\n\n    this.updateCSSParseTreeTextarea(cssParseTree);\n\n    const cssSelectorsString = CSS_SELECTORS_STRING,\n          markdownStyle = this.getMarkdownStyle(),\n          css = cssFromMarkdownStyleAndCSSSelectorsString(markdownStyle, cssSelectorsString);\n\n    markdownStyleElement.setCSS(css);\n\n    this.setCSS(css);\n  }\n\n  markdownStyle() {\n    this.hideMarkdownContainerDiv();\n    this.showMarkdownStyleContainerDiv();\n  }\n\n  markdown() {\n    this.showMarkdownContainerDiv();\n    this.hideMarkdownStyleContainerDiv();\n  }\n\n  plainText() {\n    this.hideCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.showPlainTextContainerDiv();\n\n    this.hideCSSParseTreeTextarea();\n    this.showHTMLParseTreeTextarea();\n  }\n\n  preview() {\n    this.hideCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.showPreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n\n    this.hideCSSParseTreeTextarea();\n    this.showHTMLParseTreeTextarea();\n  }\n\n  html() {\n    this.hideCSSContainerDiv();\n    this.showHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n\n    this.hideCSSParseTreeTextarea();\n    this.showHTMLParseTreeTextarea();\n  }\n\n  css() {\n    this.showCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n\n    this.showCSSParseTreeTextarea();\n    this.hideHTMLParseTreeTextarea();\n  }\n\n  resetMarkdownTokens() {\n    const markdownTokens = null;\n\n    this.setMarkdownTokens(markdownTokens);\n  }\n\n  resetMarkdownStyleTokens() {\n    const markdownStyleTokens = null;\n\n    this.setMarkdownStyleTokens(markdownStyleTokens);\n  }\n\n  resetDocumentMarkdownNode() {\n    const documentMarkdownNode = null;\n\n    this.setDocumentMarkdownNode(documentMarkdownNode);\n  }\n\n  resetDocumentMarkdownStyleNode() {\n    const documentMarkdownStyleNode = null;\n\n    this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);\n  }\n\n  getMarkdownStyleElement() {\n    const { markdownStyleElement } = this.properties;\n\n    return markdownStyleElement;\n  }\n\n  getMarkdownTokens() {\n    const { markdownTokens } = this.getState();\n\n    return markdownTokens;\n  }\n\n  getMarkdownStyleTokens() {\n    const { markdownStyleTokens } = this.getState();\n\n    return markdownStyleTokens;\n  }\n\n  getDocumentMarkdownNode() {\n    const { topmostMMarkdownNode } = this.getState();\n\n    return topmostMMarkdownNode;\n  }\n\n  getDocumentMarkdownStyleNode() {\n    const { topmostMMarkdownStyleNode } = this.getState();\n\n    return topmostMMarkdownStyleNode;\n  }\n\n  setMarkdownTokens(markdownTokens) {\n    this.updateState({\n      markdownTokens\n    });\n  }\n\n  setMarkdownStyleTokens(markdownStyleTokens) {\n    this.updateState({\n      markdownStyleTokens\n    });\n  }\n\n  setDocumentMarkdownNode(topmostMMarkdownNode) {\n    this.updateState({\n      topmostMMarkdownNode\n    });\n  }\n\n  setDocumentMarkdownStyleNode(topmostMMarkdownStyleNode) {\n    this.updateState({\n      topmostMMarkdownStyleNode\n    });\n  }\n\n  setInitialState() {\n    const markdownTokens = null,\n          markdownStyleTokens = null,\n          documentMarkdownNode = null,\n          documentMarkdownStyleNode = null;\n\n    this.setState({\n      markdownTokens,\n      markdownStyleTokens,\n      documentMarkdownNode,\n      documentMarkdownStyleNode\n    });\n  }\n\n  didMount() {\n    this.markdown();\n\n    this.preview();\n\n    this.update();\n  }\n\n  willUnmount() {\n    ///\n  }\n\n  childElements() {\n    return (\n\n      <ColumnsDiv>\n        <LeftSizeableDiv>\n          <LeftTabButtonsDiv onCustomMarkdown={this.markdownCustomHandler} onCustomMarkdownStyle={this.markdownStyleCustomHandler} />\n          <MarkdownContainerDiv onCustomKeyUp={this.keyUpCustomHandler} />\n          <MarkdownStyleContainerDiv onCustomKeyUp={this.keyUpCustomHandler} />\n        </LeftSizeableDiv>\n        <VerticalSplitterDiv/>\n        <ColumnDiv>\n          <RowsDiv>\n            <RightTabButtonsDiv onCustomCSS={this.cssCustomHandler}\n                                onCustomHTML={this.htmlCustomHandler}\n                                onCustomPreview={this.previewCustomHandler}\n                                onCustomPlainText={this.plainTextCustomHandler}\n            />\n            <PageButtonsDiv onCustomPageUpdate={this.pageUpdateCustomHandler} />\n            <CSSContainerDiv/>\n            <HTMLContainerDiv/>\n            <PreviewContainerDiv/>\n            <PlainTextContainerDiv/>\n            <HTMLParseTreeTextarea/>\n            <CSSParseTreeTextarea/>\n          </RowsDiv>\n        </ColumnDiv>\n      </ColumnsDiv>\n\n    );\n  }\n\n  initialise() {\n    this.assignContext();\n\n    this.setInitialState();\n\n    const { initialMarkdown, initialMarkdownStyle } = this.constructor,\n          markdownStyle = initialMarkdownStyle, ///\n          markdown = initialMarkdown; ///\n\n    this.setMarkdownStyle(markdownStyle);\n\n    this.setMarkdown(markdown);\n  }\n\n  static initialMarkdown = initialMarkdown;\n\n  static initialMarkdownStyle = \"\";\n\n  static tagName = \"div\";\n\n  static ignoredProperties = [\n    \"markdownStyleElement\"\n  ];\n\n  static defaultProperties = {\n    className: \"view\"\n  };\n}\n\nexport default withStyle(View)`\n\n  padding: 1rem;\n  \n`;\n\nfunction pathToURL(path) {\n  const url = `https://djalbat.com/${path}`;\n\n  return url;\n}\n"],"names":["tokensFromMarkdown","grammarUtilities","tokensFromMarkdownStyle","documentMarkdownNodeFromTokens","htmlFromMarkdownOptionsAndImporter","documentMarkdownStyleNodeFromTokens","topmostHTMLNodeFromDocumentMarkdownNode","cssFromMarkdownStyleAndCSSSelectorsString","topmostCSSNodeFromDocumentMarkdownStyleNode","View","pageUpdateCustomHandler","event","element","index","updateHTML","markdownStyleCustomHandler","markdownStyle","markdownCustomHandler","markdown","plainTextCustomHandler","plainText","previewCustomHandler","preview","keyUpCustomHandler","update","htmlCustomHandler","html","cssCustomHandler","css","updateMarkdownStyle","updateMarkdown","updateCSS","getMarkdownStyle","tokens","documentMarkdownStyleNode","resetMarkdownStyleTokens","resetDocumentMarkdownStyleNode","clearMarkdownStyleParseTreeTextarea","node","parseTree","asParseTree","markdownStyleTokens","setMarkdownStyleTokens","setDocumentMarkdownStyleNode","updateMarkdownStyleParseTreeTextarea","getMarkdown","documentMarkdownNode","resetMarkdownTokens","resetDocumentMarkdownNode","clearMarkdownParseTreeTextarea","context","importer","resolve","documentMarkdownNodeParseTree","markdownParseTree","markdownTokens","setMarkdownTokens","setDocumentMarkdownNode","updateMarkdownParseTreeTextarea","clearXMP","clearPreviewDiv","clearPlainTextTextarea","clearHTMLParseTreeTextarea","clearPageButtonsDiv","getDocumentMarkdownNode","topmostHTMLNode","getMarkdownTokens","divisionHTMLNode","getDivisionHTMLNodeAt","divisionHTMLNOdeParseTree","htmlParseTree","divisionHTMLNodes","getDivisionHTMLNodes","length","pathToURL","updatePreviewDiv","updatePlainTextTextarea","updateHTMLParseTreeTextarea","updatePageButtonsDiv","options","indexOptions","updateXMP","getMarkdownStyleTokens","markdownStyleElement","getMarkdownStyleElement","getDocumentMarkdownStyleNode","EMPTY_STRING","setCSS","clearCSSParseTreeTextarea","clearCSS","topmostCSSNode","target","WEB_TARGET","topmostCSSNodeParseTree","cssParseTree","updateCSSParseTreeTextarea","cssSelectorsString","CSS_SELECTORS_STRING","hideMarkdownContainerDiv","showMarkdownStyleContainerDiv","showMarkdownContainerDiv","hideMarkdownStyleContainerDiv","hideCSSContainerDiv","hideHTMLContainerDiv","hidePreviewContainerDiv","showPlainTextContainerDiv","hideCSSParseTreeTextarea","showHTMLParseTreeTextarea","showPreviewContainerDiv","hidePlainTextContainerDiv","showHTMLContainerDiv","showCSSContainerDiv","showCSSParseTreeTextarea","hideHTMLParseTreeTextarea","properties","getState","topmostMMarkdownNode","topmostMMarkdownStyleNode","updateState","setInitialState","setState","didMount","willUnmount","childElements","ColumnsDiv","LeftSizeableDiv","LeftTabButtonsDiv","onCustomMarkdown","onCustomMarkdownStyle","MarkdownContainerDiv","onCustomKeyUp","MarkdownStyleContainerDiv","VerticalSplitterDiv","ColumnDiv","RowsDiv","RightTabButtonsDiv","onCustomCSS","onCustomHTML","onCustomPreview","onCustomPlainText","PageButtonsDiv","onCustomPageUpdate","CSSContainerDiv","HTMLContainerDiv","PreviewContainerDiv","PlainTextContainerDiv","HTMLParseTreeTextarea","CSSParseTreeTextarea","initialise","assignContext","initialMarkdown","initialMarkdownStyle","setMarkdownStyle","setMarkdown","Element","tagName","ignoredProperties","defaultProperties","className","withStyle","path","url"],"mappings":"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"}
309
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/example/view.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { Element } from \"easy\";\nimport { grammarUtilities } from \"../index\";  ///\nimport { RowsDiv, ColumnDiv, ColumnsDiv, VerticalSplitterDiv } from \"easy-layout\";\n\nimport indexOptions from \"./indexOptions\";\nimport PageButtonsDiv from \"./view/div/pageButtons\";\nimport LeftSizeableDiv from \"./view/div/sizeable/left\";\nimport CSSContainerDiv from \"./view/div/container/css\";\nimport HTMLContainerDiv from \"./view/div/container/html\";\nimport LeftTabButtonsDiv from \"./view/div/tabButtons/left\";\nimport RightTabButtonsDiv from \"./view/div/tabButtons/right\";\nimport PreviewContainerDiv from \"./view/div/container/preview\";\nimport MarkdownContainerDiv from \"./view/div/container/markdown\";\nimport CSSParseTreeTextarea from \"./view/textarea/parseTree/css\";\nimport HTMLParseTreeTextarea from \"./view/textarea/parseTree/html\";\nimport PlainTextContainerDiv from \"./view/div/container/plainText\";\nimport MarkdownStyleContainerDiv from \"./view/div/container/markdownStyle\";\n\nimport { WEB_TARGET } from \"../targets\";\nimport { initialMarkdown, importer } from \"./importer\";\nimport { EMPTY_STRING, CSS_SELECTORS_STRING } from \"./constants\";\n\nconst { tokensFromMarkdown,\n        tokensFromMarkdownStyle,\n        documentMarkdownNodeFromTokens,\n        htmlFromMarkdownOptionsAndImporter,\n        documentMarkdownStyleNodeFromTokens,\n        topmostHTMLNodeFromDocumentMarkdownNode,\n        cssFromMarkdownStyleAndCSSSelectorsString,\n        topmostCSSNodeFromDocumentMarkdownStyleNode } = grammarUtilities;\n\nclass View extends Element {\n  pageUpdateCustomHandler = (event, element, index) => {\n    this.updateHTML(index);\n  }\n\n  markdownStyleCustomHandler = (event, element) => {\n    this.markdownStyle();\n  }\n\n  markdownCustomHandler = (event, element) => {\n    this.markdown();\n  }\n\n  plainTextCustomHandler = (event, element) => {\n    this.plainText();\n  }\n\n  previewCustomHandler = (event, element) => {\n    this.preview();\n  }\n\n  keyUpCustomHandler = (event, element) => {\n    this.update();\n  }\n\n  htmlCustomHandler = (event, element) => {\n    this.html();\n  }\n\n  cssCustomHandler = (event, element) => {\n    this.css();\n  }\n\n  update() {\n    this.updateMarkdownStyle();\n\n    this.updateMarkdown();\n\n    this.updateHTML();\n\n    this.updateCSS();\n  }\n\n  updateMarkdownStyle() {\n    const markdownStyle = this.getMarkdownStyle(),\n          tokens = tokensFromMarkdownStyle(markdownStyle),\n          documentMarkdownStyleNode = documentMarkdownStyleNodeFromTokens(tokens);\n\n    if (documentMarkdownStyleNode === null) {\n      this.resetMarkdownStyleTokens();\n\n      this.resetDocumentMarkdownStyleNode();\n\n      this.clearMarkdownStyleParseTreeTextarea();\n\n      return;\n    }\n\n    const node = documentMarkdownStyleNode, ///\n          parseTree = node.asParseTree(tokens),\n          markdownStyleTokens = tokens; ///\n\n    this.setMarkdownStyleTokens(markdownStyleTokens);\n\n    this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);\n\n    this.updateMarkdownStyleParseTreeTextarea(parseTree);\n  }\n\n  updateMarkdown() {\n    const markdown = this.getMarkdown(),\n          tokens = tokensFromMarkdown(markdown),\n          documentMarkdownNode = documentMarkdownNodeFromTokens(tokens);\n\n    if (documentMarkdownNode === null) {\n      this.resetMarkdownTokens();\n\n      this.resetDocumentMarkdownNode();\n\n      this.clearMarkdownParseTreeTextarea();\n\n      return;\n    }\n\n    let context;\n\n    context = {\n      tokens,\n      importer\n    };\n\n    documentMarkdownNode.resolve(context);\n\n    const documentMarkdownNodeParseTree = documentMarkdownNode.asParseTree(tokens),\n          markdownParseTree = documentMarkdownNodeParseTree, ///\n          markdownTokens = tokens;  ///\n\n    this.setMarkdownTokens(markdownTokens);\n\n    this.setDocumentMarkdownNode(documentMarkdownNode);\n\n    this.updateMarkdownParseTreeTextarea(markdownParseTree);\n  }\n\n  updateHTML(index = 0) {\n    this.clearXMP();\n\n    this.clearPreviewDiv();\n\n    this.clearPlainTextTextarea();\n\n    this.clearHTMLParseTreeTextarea();\n\n    this.clearPageButtonsDiv();\n\n    const documentMarkdownNode = this.getDocumentMarkdownNode(),\n          topmostHTMLNode = topmostHTMLNodeFromDocumentMarkdownNode(documentMarkdownNode);\n\n    if (topmostHTMLNode === null) {\n      return;\n    }\n\n    let context;\n\n    const markdownTokens = this.getMarkdownTokens(),\n          tokens = markdownTokens;  ///\n\n    context = {\n      tokens\n    };\n\n    topmostHTMLNode.resolve(context);\n\n    const divisionHTMLNode = topmostHTMLNode.getDivisionHTMLNodeAt(index);\n\n    if (divisionHTMLNode === null) {\n      return;\n    }\n\n    const divisionHTMLNOdeParseTree = divisionHTMLNode.asParseTree(),\n          htmlParseTree = divisionHTMLNOdeParseTree,  ///\n          divisionHTMLNodes = topmostHTMLNode.getDivisionHTMLNodes(),\n          length = divisionHTMLNodes.length;  ///\n\n    context = {\n      tokens,\n      pathToURL\n    };\n\n    this.updatePreviewDiv(divisionHTMLNode, context);\n\n    this.updatePlainTextTextarea(divisionHTMLNode, context);\n\n    this.updateHTMLParseTreeTextarea(htmlParseTree);\n\n    this.updatePageButtonsDiv(length, index);\n\n    const markdown = this.getMarkdown(),\n          options = indexOptions, ///\n          html = htmlFromMarkdownOptionsAndImporter(markdown, options, importer);\n\n    this.updateXMP(html, context);\n  }\n\n  updateCSS() {\n    const markdownStyleTokens = this.getMarkdownStyleTokens(),\n          markdownStyleElement = this.getMarkdownStyleElement(),\n          documentMarkdownStyleNode = this.getDocumentMarkdownStyleNode();\n\n    if (documentMarkdownStyleNode === null) {\n      const css = EMPTY_STRING;\n\n      markdownStyleElement.setCSS(css);\n\n      this.clearCSSParseTreeTextarea();\n\n      this.clearCSS();\n\n      return;\n    }\n\n    const topmostCSSNode = topmostCSSNodeFromDocumentMarkdownStyleNode(documentMarkdownStyleNode),\n          target = WEB_TARGET,\n          tokens = markdownStyleTokens, ///\n          context = {\n            target,\n            tokens\n          };\n\n    topmostCSSNode.resolve(context);\n\n    const topmostCSSNodeParseTree = topmostCSSNode.asParseTree(tokens),\n          cssParseTree = topmostCSSNodeParseTree; ///\n\n    this.updateCSSParseTreeTextarea(cssParseTree);\n\n    const cssSelectorsString = CSS_SELECTORS_STRING,\n          markdownStyle = this.getMarkdownStyle(),\n          css = cssFromMarkdownStyleAndCSSSelectorsString(markdownStyle, cssSelectorsString);\n\n    markdownStyleElement.setCSS(css);\n\n    this.setCSS(css);\n  }\n\n  markdownStyle() {\n    this.hideMarkdownContainerDiv();\n    this.showMarkdownStyleContainerDiv();\n  }\n\n  markdown() {\n    this.showMarkdownContainerDiv();\n    this.hideMarkdownStyleContainerDiv();\n  }\n\n  plainText() {\n    this.hideCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.showPlainTextContainerDiv();\n\n    this.hideCSSParseTreeTextarea();\n    this.showHTMLParseTreeTextarea();\n  }\n\n  preview() {\n    this.hideCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.showPreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n\n    this.hideCSSParseTreeTextarea();\n    this.showHTMLParseTreeTextarea();\n  }\n\n  html() {\n    this.hideCSSContainerDiv();\n    this.showHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n\n    this.hideCSSParseTreeTextarea();\n    this.showHTMLParseTreeTextarea();\n  }\n\n  css() {\n    this.showCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n\n    this.showCSSParseTreeTextarea();\n    this.hideHTMLParseTreeTextarea();\n  }\n\n  resetMarkdownTokens() {\n    const markdownTokens = null;\n\n    this.setMarkdownTokens(markdownTokens);\n  }\n\n  resetMarkdownStyleTokens() {\n    const markdownStyleTokens = null;\n\n    this.setMarkdownStyleTokens(markdownStyleTokens);\n  }\n\n  resetDocumentMarkdownNode() {\n    const documentMarkdownNode = null;\n\n    this.setDocumentMarkdownNode(documentMarkdownNode);\n  }\n\n  resetDocumentMarkdownStyleNode() {\n    const documentMarkdownStyleNode = null;\n\n    this.setDocumentMarkdownStyleNode(documentMarkdownStyleNode);\n  }\n\n  getMarkdownStyleElement() {\n    const { markdownStyleElement } = this.properties;\n\n    return markdownStyleElement;\n  }\n\n  getMarkdownTokens() {\n    const { markdownTokens } = this.getState();\n\n    return markdownTokens;\n  }\n\n  getMarkdownStyleTokens() {\n    const { markdownStyleTokens } = this.getState();\n\n    return markdownStyleTokens;\n  }\n\n  getDocumentMarkdownNode() {\n    const { topmostMMarkdownNode } = this.getState();\n\n    return topmostMMarkdownNode;\n  }\n\n  getDocumentMarkdownStyleNode() {\n    const { topmostMMarkdownStyleNode } = this.getState();\n\n    return topmostMMarkdownStyleNode;\n  }\n\n  setMarkdownTokens(markdownTokens) {\n    this.updateState({\n      markdownTokens\n    });\n  }\n\n  setMarkdownStyleTokens(markdownStyleTokens) {\n    this.updateState({\n      markdownStyleTokens\n    });\n  }\n\n  setDocumentMarkdownNode(topmostMMarkdownNode) {\n    this.updateState({\n      topmostMMarkdownNode\n    });\n  }\n\n  setDocumentMarkdownStyleNode(topmostMMarkdownStyleNode) {\n    this.updateState({\n      topmostMMarkdownStyleNode\n    });\n  }\n\n  setInitialState() {\n    const markdownTokens = null,\n          markdownStyleTokens = null,\n          documentMarkdownNode = null,\n          documentMarkdownStyleNode = null;\n\n    this.setState({\n      markdownTokens,\n      markdownStyleTokens,\n      documentMarkdownNode,\n      documentMarkdownStyleNode\n    });\n  }\n\n  didMount() {\n    this.markdown();\n\n    this.preview();\n\n    this.update();\n  }\n\n  willUnmount() {\n    ///\n  }\n\n  childElements() {\n    return (\n\n      <ColumnsDiv>\n        <LeftSizeableDiv>\n          <LeftTabButtonsDiv onCustomMarkdown={this.markdownCustomHandler} onCustomMarkdownStyle={this.markdownStyleCustomHandler} />\n          <MarkdownContainerDiv onCustomKeyUp={this.keyUpCustomHandler} />\n          <MarkdownStyleContainerDiv onCustomKeyUp={this.keyUpCustomHandler} />\n        </LeftSizeableDiv>\n        <VerticalSplitterDiv/>\n        <ColumnDiv>\n          <RowsDiv>\n            <RightTabButtonsDiv onCustomCSS={this.cssCustomHandler}\n                                onCustomHTML={this.htmlCustomHandler}\n                                onCustomPreview={this.previewCustomHandler}\n                                onCustomPlainText={this.plainTextCustomHandler}\n            />\n            <PageButtonsDiv onCustomPageUpdate={this.pageUpdateCustomHandler} />\n            <CSSContainerDiv/>\n            <HTMLContainerDiv/>\n            <PreviewContainerDiv/>\n            <PlainTextContainerDiv/>\n            <HTMLParseTreeTextarea/>\n            <CSSParseTreeTextarea/>\n          </RowsDiv>\n        </ColumnDiv>\n      </ColumnsDiv>\n\n    );\n  }\n\n  initialise() {\n    this.assignContext();\n\n    this.setInitialState();\n\n    const { initialMarkdown, initialMarkdownStyle } = this.constructor,\n          markdownStyle = initialMarkdownStyle, ///\n          markdown = initialMarkdown; ///\n\n    this.setMarkdownStyle(markdownStyle);\n\n    this.setMarkdown(markdown);\n  }\n\n  static initialMarkdown = initialMarkdown;\n\n  static initialMarkdownStyle = \"\";\n\n  static tagName = \"div\";\n\n  static ignoredProperties = [\n    \"markdownStyleElement\"\n  ];\n\n  static defaultProperties = {\n    className: \"view\"\n  };\n}\n\nexport default withStyle(View)`\n\n  padding: 1rem;\n  \n`;\n\nfunction pathToURL(path) {\n  const url = `https://djalbat.com/${path}`;\n\n  return url;\n}\n"],"names":["tokensFromMarkdown","tokensFromMarkdownStyle","documentMarkdownNodeFromTokens","htmlFromMarkdownOptionsAndImporter","documentMarkdownStyleNodeFromTokens","topmostHTMLNodeFromDocumentMarkdownNode","cssFromMarkdownStyleAndCSSSelectorsString","topmostCSSNodeFromDocumentMarkdownStyleNode","grammarUtilities","View","Element","pageUpdateCustomHandler","event","element","index","updateHTML","markdownStyleCustomHandler","markdownStyle","markdownCustomHandler","markdown","plainTextCustomHandler","plainText","previewCustomHandler","preview","keyUpCustomHandler","update","htmlCustomHandler","html","cssCustomHandler","css","updateMarkdownStyle","updateMarkdown","updateCSS","getMarkdownStyle","tokens","documentMarkdownStyleNode","resetMarkdownStyleTokens","resetDocumentMarkdownStyleNode","clearMarkdownStyleParseTreeTextarea","node","parseTree","asParseTree","markdownStyleTokens","setMarkdownStyleTokens","setDocumentMarkdownStyleNode","updateMarkdownStyleParseTreeTextarea","getMarkdown","documentMarkdownNode","resetMarkdownTokens","resetDocumentMarkdownNode","clearMarkdownParseTreeTextarea","context","importer","resolve","documentMarkdownNodeParseTree","markdownParseTree","markdownTokens","setMarkdownTokens","setDocumentMarkdownNode","updateMarkdownParseTreeTextarea","clearXMP","clearPreviewDiv","clearPlainTextTextarea","clearHTMLParseTreeTextarea","clearPageButtonsDiv","getDocumentMarkdownNode","topmostHTMLNode","getMarkdownTokens","divisionHTMLNode","getDivisionHTMLNodeAt","divisionHTMLNOdeParseTree","htmlParseTree","divisionHTMLNodes","getDivisionHTMLNodes","length","pathToURL","updatePreviewDiv","updatePlainTextTextarea","updateHTMLParseTreeTextarea","updatePageButtonsDiv","options","indexOptions","updateXMP","getMarkdownStyleTokens","markdownStyleElement","getMarkdownStyleElement","getDocumentMarkdownStyleNode","EMPTY_STRING","setCSS","clearCSSParseTreeTextarea","clearCSS","topmostCSSNode","target","WEB_TARGET","topmostCSSNodeParseTree","cssParseTree","updateCSSParseTreeTextarea","cssSelectorsString","CSS_SELECTORS_STRING","hideMarkdownContainerDiv","showMarkdownStyleContainerDiv","showMarkdownContainerDiv","hideMarkdownStyleContainerDiv","hideCSSContainerDiv","hideHTMLContainerDiv","hidePreviewContainerDiv","showPlainTextContainerDiv","hideCSSParseTreeTextarea","showHTMLParseTreeTextarea","showPreviewContainerDiv","hidePlainTextContainerDiv","showHTMLContainerDiv","showCSSContainerDiv","showCSSParseTreeTextarea","hideHTMLParseTreeTextarea","properties","getState","topmostMMarkdownNode","topmostMMarkdownStyleNode","updateState","setInitialState","setState","didMount","willUnmount","childElements","ColumnsDiv","LeftSizeableDiv","LeftTabButtonsDiv","onCustomMarkdown","onCustomMarkdownStyle","MarkdownContainerDiv","onCustomKeyUp","MarkdownStyleContainerDiv","VerticalSplitterDiv","ColumnDiv","RowsDiv","RightTabButtonsDiv","onCustomCSS","onCustomHTML","onCustomPreview","onCustomPlainText","PageButtonsDiv","onCustomPageUpdate","CSSContainerDiv","HTMLContainerDiv","PreviewContainerDiv","PlainTextContainerDiv","HTMLParseTreeTextarea","CSSParseTreeTextarea","initialise","assignContext","initialMarkdown","initialMarkdownStyle","setMarkdownStyle","setMarkdown","tagName","ignoredProperties","defaultProperties","className","withStyle","path","url"],"mappings":"AAAA;;;;+BAscA;;;eAAA;;;sEApcsB;sBAEE;uBACS;4BACmC;qEAE3C;oEACE;6DACC;4DACA;6DACC;8DACC;8DACC;gEACC;iEACC;6DACA;8DACC;kEACA;sEACI;yBAEX;0BACe;2BACS;;;;;;AAEnD,MAAM,EAAEA,kBAAkB,EAClBC,uBAAuB,EACvBC,8BAA8B,EAC9BC,kCAAkC,EAClCC,mCAAmC,EACnCC,uCAAuC,EACvCC,yCAAyC,EACzCC,2CAA2C,EAAE,GAAGC,uBAAgB;AAExE,MAAMC,aAAaC,aAAO;IACxBC,0BAA0B,CAACC,OAAOC,SAASC;QACzC,IAAI,CAACC,UAAU,CAACD;IAClB,EAAC;IAEDE,6BAA6B,CAACJ,OAAOC;QACnC,IAAI,CAACI,aAAa;IACpB,EAAC;IAEDC,wBAAwB,CAACN,OAAOC;QAC9B,IAAI,CAACM,QAAQ;IACf,EAAC;IAEDC,yBAAyB,CAACR,OAAOC;QAC/B,IAAI,CAACQ,SAAS;IAChB,EAAC;IAEDC,uBAAuB,CAACV,OAAOC;QAC7B,IAAI,CAACU,OAAO;IACd,EAAC;IAEDC,qBAAqB,CAACZ,OAAOC;QAC3B,IAAI,CAACY,MAAM;IACb,EAAC;IAEDC,oBAAoB,CAACd,OAAOC;QAC1B,IAAI,CAACc,IAAI;IACX,EAAC;IAEDC,mBAAmB,CAAChB,OAAOC;QACzB,IAAI,CAACgB,GAAG;IACV,EAAC;IAEDJ,SAAS;QACP,IAAI,CAACK,mBAAmB;QAExB,IAAI,CAACC,cAAc;QAEnB,IAAI,CAAChB,UAAU;QAEf,IAAI,CAACiB,SAAS;IAChB;IAEAF,sBAAsB;QACpB,MAAMb,gBAAgB,IAAI,CAACgB,gBAAgB,IACrCC,SAASjC,wBAAwBgB,gBACjCkB,4BAA4B/B,oCAAoC8B;QAEtE,IAAIC,8BAA8B,MAAM;YACtC,IAAI,CAACC,wBAAwB;YAE7B,IAAI,CAACC,8BAA8B;YAEnC,IAAI,CAACC,mCAAmC;YAExC;QACF;QAEA,MAAMC,OAAOJ,2BACPK,YAAYD,KAAKE,WAAW,CAACP,SAC7BQ,sBAAsBR,QAAQ,GAAG;QAEvC,IAAI,CAACS,sBAAsB,CAACD;QAE5B,IAAI,CAACE,4BAA4B,CAACT;QAElC,IAAI,CAACU,oCAAoC,CAACL;IAC5C;IAEAT,iBAAiB;QACf,MAAMZ,WAAW,IAAI,CAAC2B,WAAW,IAC3BZ,SAASlC,mBAAmBmB,WAC5B4B,uBAAuB7C,+BAA+BgC;QAE5D,IAAIa,yBAAyB,MAAM;YACjC,IAAI,CAACC,mBAAmB;YAExB,IAAI,CAACC,yBAAyB;YAE9B,IAAI,CAACC,8BAA8B;YAEnC;QACF;QAEA,IAAIC;QAEJA,UAAU;YACRjB;YACAkB,UAAAA,kBAAQ;QACV;QAEAL,qBAAqBM,OAAO,CAACF;QAE7B,MAAMG,gCAAgCP,qBAAqBN,WAAW,CAACP,SACjEqB,oBAAoBD,+BACpBE,iBAAiBtB,QAAS,GAAG;QAEnC,IAAI,CAACuB,iBAAiB,CAACD;QAEvB,IAAI,CAACE,uBAAuB,CAACX;QAE7B,IAAI,CAACY,+BAA+B,CAACJ;IACvC;IAEAxC,WAAWD,QAAQ,CAAC,EAAE;QACpB,IAAI,CAAC8C,QAAQ;QAEb,IAAI,CAACC,eAAe;QAEpB,IAAI,CAACC,sBAAsB;QAE3B,IAAI,CAACC,0BAA0B;QAE/B,IAAI,CAACC,mBAAmB;QAExB,MAAMjB,uBAAuB,IAAI,CAACkB,uBAAuB,IACnDC,kBAAkB7D,wCAAwC0C;QAEhE,IAAImB,oBAAoB,MAAM;YAC5B;QACF;QAEA,IAAIf;QAEJ,MAAMK,iBAAiB,IAAI,CAACW,iBAAiB,IACvCjC,SAASsB,gBAAiB,GAAG;QAEnCL,UAAU;YACRjB;QACF;QAEAgC,gBAAgBb,OAAO,CAACF;QAExB,MAAMiB,mBAAmBF,gBAAgBG,qBAAqB,CAACvD;QAE/D,IAAIsD,qBAAqB,MAAM;YAC7B;QACF;QAEA,MAAME,4BAA4BF,iBAAiB3B,WAAW,IACxD8B,gBAAgBD,2BAChBE,oBAAoBN,gBAAgBO,oBAAoB,IACxDC,SAASF,kBAAkBE,MAAM,EAAG,GAAG;QAE7CvB,UAAU;YACRjB;YACAyC;QACF;QAEA,IAAI,CAACC,gBAAgB,CAACR,kBAAkBjB;QAExC,IAAI,CAAC0B,uBAAuB,CAACT,kBAAkBjB;QAE/C,IAAI,CAAC2B,2BAA2B,CAACP;QAEjC,IAAI,CAACQ,oBAAoB,CAACL,QAAQ5D;QAElC,MAAMK,WAAW,IAAI,CAAC2B,WAAW,IAC3BkC,UAAUC,qBAAY,EACtBtD,OAAOxB,mCAAmCgB,UAAU6D,SAAS5B,kBAAQ;QAE3E,IAAI,CAAC8B,SAAS,CAACvD,MAAMwB;IACvB;IAEAnB,YAAY;QACV,MAAMU,sBAAsB,IAAI,CAACyC,sBAAsB,IACjDC,uBAAuB,IAAI,CAACC,uBAAuB,IACnDlD,4BAA4B,IAAI,CAACmD,4BAA4B;QAEnE,IAAInD,8BAA8B,MAAM;YACtC,MAAMN,MAAM0D,uBAAY;YAExBH,qBAAqBI,MAAM,CAAC3D;YAE5B,IAAI,CAAC4D,yBAAyB;YAE9B,IAAI,CAACC,QAAQ;YAEb;QACF;QAEA,MAAMC,iBAAiBpF,4CAA4C4B,4BAC7DyD,SAASC,mBAAU,EACnB3D,SAASQ,qBACTS,UAAU;YACRyC;YACA1D;QACF;QAENyD,eAAetC,OAAO,CAACF;QAEvB,MAAM2C,0BAA0BH,eAAelD,WAAW,CAACP,SACrD6D,eAAeD,yBAAyB,GAAG;QAEjD,IAAI,CAACE,0BAA0B,CAACD;QAEhC,MAAME,qBAAqBC,+BAAoB,EACzCjF,gBAAgB,IAAI,CAACgB,gBAAgB,IACrCJ,MAAMvB,0CAA0CW,eAAegF;QAErEb,qBAAqBI,MAAM,CAAC3D;QAE5B,IAAI,CAAC2D,MAAM,CAAC3D;IACd;IAEAZ,gBAAgB;QACd,IAAI,CAACkF,wBAAwB;QAC7B,IAAI,CAACC,6BAA6B;IACpC;IAEAjF,WAAW;QACT,IAAI,CAACkF,wBAAwB;QAC7B,IAAI,CAACC,6BAA6B;IACpC;IAEAjF,YAAY;QACV,IAAI,CAACkF,mBAAmB;QACxB,IAAI,CAACC,oBAAoB;QACzB,IAAI,CAACC,uBAAuB;QAC5B,IAAI,CAACC,yBAAyB;QAE9B,IAAI,CAACC,wBAAwB;QAC7B,IAAI,CAACC,yBAAyB;IAChC;IAEArF,UAAU;QACR,IAAI,CAACgF,mBAAmB;QACxB,IAAI,CAACC,oBAAoB;QACzB,IAAI,CAACK,uBAAuB;QAC5B,IAAI,CAACC,yBAAyB;QAE9B,IAAI,CAACH,wBAAwB;QAC7B,IAAI,CAACC,yBAAyB;IAChC;IAEAjF,OAAO;QACL,IAAI,CAAC4E,mBAAmB;QACxB,IAAI,CAACQ,oBAAoB;QACzB,IAAI,CAACN,uBAAuB;QAC5B,IAAI,CAACK,yBAAyB;QAE9B,IAAI,CAACH,wBAAwB;QAC7B,IAAI,CAACC,yBAAyB;IAChC;IAEA/E,MAAM;QACJ,IAAI,CAACmF,mBAAmB;QACxB,IAAI,CAACR,oBAAoB;QACzB,IAAI,CAACC,uBAAuB;QAC5B,IAAI,CAACK,yBAAyB;QAE9B,IAAI,CAACG,wBAAwB;QAC7B,IAAI,CAACC,yBAAyB;IAChC;IAEAlE,sBAAsB;QACpB,MAAMQ,iBAAiB;QAEvB,IAAI,CAACC,iBAAiB,CAACD;IACzB;IAEApB,2BAA2B;QACzB,MAAMM,sBAAsB;QAE5B,IAAI,CAACC,sBAAsB,CAACD;IAC9B;IAEAO,4BAA4B;QAC1B,MAAMF,uBAAuB;QAE7B,IAAI,CAACW,uBAAuB,CAACX;IAC/B;IAEAV,iCAAiC;QAC/B,MAAMF,4BAA4B;QAElC,IAAI,CAACS,4BAA4B,CAACT;IACpC;IAEAkD,0BAA0B;QACxB,MAAM,EAAED,oBAAoB,EAAE,GAAG,IAAI,CAAC+B,UAAU;QAEhD,OAAO/B;IACT;IAEAjB,oBAAoB;QAClB,MAAM,EAAEX,cAAc,EAAE,GAAG,IAAI,CAAC4D,QAAQ;QAExC,OAAO5D;IACT;IAEA2B,yBAAyB;QACvB,MAAM,EAAEzC,mBAAmB,EAAE,GAAG,IAAI,CAAC0E,QAAQ;QAE7C,OAAO1E;IACT;IAEAuB,0BAA0B;QACxB,MAAM,EAAEoD,oBAAoB,EAAE,GAAG,IAAI,CAACD,QAAQ;QAE9C,OAAOC;IACT;IAEA/B,+BAA+B;QAC7B,MAAM,EAAEgC,yBAAyB,EAAE,GAAG,IAAI,CAACF,QAAQ;QAEnD,OAAOE;IACT;IAEA7D,kBAAkBD,cAAc,EAAE;QAChC,IAAI,CAAC+D,WAAW,CAAC;YACf/D;QACF;IACF;IAEAb,uBAAuBD,mBAAmB,EAAE;QAC1C,IAAI,CAAC6E,WAAW,CAAC;YACf7E;QACF;IACF;IAEAgB,wBAAwB2D,oBAAoB,EAAE;QAC5C,IAAI,CAACE,WAAW,CAAC;YACfF;QACF;IACF;IAEAzE,6BAA6B0E,yBAAyB,EAAE;QACtD,IAAI,CAACC,WAAW,CAAC;YACfD;QACF;IACF;IAEAE,kBAAkB;QAChB,MAAMhE,iBAAiB,MACjBd,sBAAsB,MACtBK,uBAAuB,MACvBZ,4BAA4B;QAElC,IAAI,CAACsF,QAAQ,CAAC;YACZjE;YACAd;YACAK;YACAZ;QACF;IACF;IAEAuF,WAAW;QACT,IAAI,CAACvG,QAAQ;QAEb,IAAI,CAACI,OAAO;QAEZ,IAAI,CAACE,MAAM;IACb;IAEAkG,cAAc;IACZ,GAAG;IACL;IAEAC,gBAAgB;QACd,qBAEE,oBAACC,sBAAU,sBACT,oBAACC,aAAe,sBACd,oBAACC,cAAiB;YAACC,kBAAkB,IAAI,CAAC9G,qBAAqB;YAAE+G,uBAAuB,IAAI,CAACjH,0BAA0B;0BACvH,oBAACkH,iBAAoB;YAACC,eAAe,IAAI,CAAC3G,kBAAkB;0BAC5D,oBAAC4G,sBAAyB;YAACD,eAAe,IAAI,CAAC3G,kBAAkB;2BAEnE,oBAAC6G,+BAAmB,uBACpB,oBAACC,qBAAS,sBACR,oBAACC,mBAAO,sBACN,oBAACC,cAAkB;YAACC,aAAa,IAAI,CAAC7G,gBAAgB;YAClC8G,cAAc,IAAI,CAAChH,iBAAiB;YACpCiH,iBAAiB,IAAI,CAACrH,oBAAoB;YAC1CsH,mBAAmB,IAAI,CAACxH,sBAAsB;0BAElE,oBAACyH,oBAAc;YAACC,oBAAoB,IAAI,CAACnI,uBAAuB;0BAChE,oBAACoI,YAAe,uBAChB,oBAACC,aAAgB,uBACjB,oBAACC,gBAAmB,uBACpB,oBAACC,kBAAqB,uBACtB,oBAACC,cAAqB,uBACtB,oBAACC,aAAoB;IAM/B;IAEAC,aAAa;QACX,IAAI,CAACC,aAAa;QAElB,IAAI,CAAC9B,eAAe;QAEpB,MAAM,EAAE+B,eAAe,EAAEC,oBAAoB,EAAE,GAAG,IAAI,CAAC,WAAW,EAC5DvI,gBAAgBuI,sBAChBrI,WAAWoI,iBAAiB,GAAG;QAErC,IAAI,CAACE,gBAAgB,CAACxI;QAEtB,IAAI,CAACyI,WAAW,CAACvI;IACnB;IAEA,OAAOoI,kBAAkBA,yBAAe,CAAC;IAEzC,OAAOC,uBAAuB,GAAG;IAEjC,OAAOG,UAAU,MAAM;IAEvB,OAAOC,oBAAoB;QACzB;KACD,CAAC;IAEF,OAAOC,oBAAoB;QACzBC,WAAW;IACb,EAAE;AACJ;MAEA,WAAeC,IAAAA,sBAAS,EAACtJ,KAAK,CAAC;;;;AAI/B,CAAC;AAED,SAASkE,UAAUqF,IAAI;IACrB,MAAMC,MAAM,CAAC,oBAAoB,EAAED,MAAM;IAEzC,OAAOC;AACT"}