highmark-markdown 1.0.41 → 1.0.42

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 (53) hide show
  1. package/example.js +3151 -1252
  2. package/lib/example/customEventTypes.js +17 -1
  3. package/lib/example/importer.js +2 -6
  4. package/lib/example/view/{div/sizeable/right.js → button/tab/css.js} +44 -33
  5. package/lib/example/view/button/tab/html.js +146 -0
  6. package/lib/example/view/button/tab/markdown.js +2 -23
  7. package/lib/example/view/button/tab/markdownStyle.js +2 -23
  8. package/lib/example/view/button/tab/plainText.js +146 -0
  9. package/lib/example/view/button/tab/preview.js +146 -0
  10. package/lib/example/view/button/tab.js +2 -2
  11. package/lib/example/view/div/container/css.js +186 -0
  12. package/lib/example/view/div/container/html.js +188 -0
  13. package/lib/example/view/div/container/plainText.js +186 -0
  14. package/lib/example/view/div/container/preview.js +212 -0
  15. package/lib/example/view/div/container.js +2 -2
  16. package/lib/example/view/div/preview.js +2 -2
  17. package/lib/example/view/div/tabButtons/left.js +206 -0
  18. package/lib/example/view/div/tabButtons/right.js +246 -0
  19. package/lib/example/view/div/tabButtons.js +3 -59
  20. package/lib/example/view/textarea/css.js +2 -2
  21. package/lib/example/view/textarea/plainText.js +183 -0
  22. package/lib/example/view/textarea.js +2 -2
  23. package/lib/example/view.js +99 -47
  24. package/lib/node/markdown/tableBodyCell.js +8 -1
  25. package/lib/node/markdown/tableHeadCell.js +8 -1
  26. package/package.json +5 -5
  27. package/src/example/customEventTypes.js +4 -0
  28. package/src/example/importer.js +1 -5
  29. package/src/example/view/button/tab/css.js +23 -0
  30. package/src/example/view/button/tab/html.js +23 -0
  31. package/src/example/view/button/tab/markdown.js +1 -15
  32. package/src/example/view/button/tab/markdownStyle.js +1 -13
  33. package/src/example/view/button/tab/plainText.js +23 -0
  34. package/src/example/view/button/tab/preview.js +23 -0
  35. package/src/example/view/button/tab.js +4 -5
  36. package/src/example/view/div/container/css.js +30 -0
  37. package/src/example/view/div/container/html.js +30 -0
  38. package/src/example/view/div/container/plainText.js +30 -0
  39. package/src/example/view/div/container/preview.js +43 -0
  40. package/src/example/view/div/container.js +0 -3
  41. package/src/example/view/div/preview.js +1 -2
  42. package/src/example/view/div/tabButtons/left.js +66 -0
  43. package/src/example/view/div/tabButtons/right.js +106 -0
  44. package/src/example/view/div/tabButtons.js +0 -49
  45. package/src/example/view/textarea/css.js +1 -1
  46. package/src/example/view/textarea/plainText.js +46 -0
  47. package/src/example/view/textarea.js +2 -0
  48. package/src/example/view.js +112 -71
  49. package/src/node/markdown/tableBodyCell.js +9 -0
  50. package/src/node/markdown/tableHeadCell.js +9 -0
  51. package/lib/example/view/subHeading.js +0 -39
  52. package/src/example/view/div/sizeable/right.js +0 -19
  53. package/src/example/view/subHeading.js +0 -16
@@ -10,18 +10,18 @@ Object.defineProperty(exports, "default", {
10
10
  });
11
11
  var _easywithstyle = /*#__PURE__*/ _interop_require_default(require("easy-with-style"));
12
12
  var _easy = require("easy");
13
- var _index = require("../index");
14
13
  var _easylayout = require("easy-layout");
15
- var _html = /*#__PURE__*/ _interop_require_default(require("./view/div/html"));
14
+ var _index = require("../index");
16
15
  var _importer = /*#__PURE__*/ _interop_require_wildcard(require("./importer"));
17
- var _preview = /*#__PURE__*/ _interop_require_default(require("./view/div/preview"));
18
- var _subHeading = /*#__PURE__*/ _interop_require_default(require("./view/subHeading"));
19
- var _css = /*#__PURE__*/ _interop_require_default(require("./view/textarea/css"));
20
16
  var _indexOptions = /*#__PURE__*/ _interop_require_default(require("./indexOptions"));
21
- var _tabButtons = /*#__PURE__*/ _interop_require_default(require("./view/div/tabButtons"));
22
17
  var _left = /*#__PURE__*/ _interop_require_default(require("./view/div/sizeable/left"));
23
- var _right = /*#__PURE__*/ _interop_require_default(require("./view/div/sizeable/right"));
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"));
24
23
  var _markdown = /*#__PURE__*/ _interop_require_default(require("./view/div/container/markdown"));
24
+ var _plainText = /*#__PURE__*/ _interop_require_default(require("./view/div/container/plainText"));
25
25
  var _markdownStyle = /*#__PURE__*/ _interop_require_default(require("./view/div/container/markdownStyle"));
26
26
  var _constants = require("./constants");
27
27
  var _processing = require("../utilities/processing");
@@ -249,27 +249,51 @@ var View = /*#__PURE__*/ function(Element) {
249
249
  _this.clearPage();
250
250
  _this.updatePage(index);
251
251
  });
252
+ _define_property(_assert_this_initialized(_this), "plainTextCustomHandler", function(event, element) {
253
+ _this.plainText();
254
+ });
252
255
  _define_property(_assert_this_initialized(_this), "markdownCustomHandler", function(event, element) {
253
256
  _this.markdown();
254
257
  });
258
+ _define_property(_assert_this_initialized(_this), "previewCustomHandler", function(event, element) {
259
+ _this.preview();
260
+ });
255
261
  _define_property(_assert_this_initialized(_this), "keyUpCustomHandler", function(event, element) {
256
262
  _this.update();
257
263
  });
264
+ _define_property(_assert_this_initialized(_this), "htmlCustomHandler", function(event, element) {
265
+ _this.html();
266
+ });
267
+ _define_property(_assert_this_initialized(_this), "cssCustomHandler", function(event, element) {
268
+ _this.css();
269
+ });
258
270
  return _this;
259
271
  }
260
272
  _create_class(View, [
261
273
  {
262
- key: "updateMarkdownStyle",
263
- value: function updateMarkdownStyle() {
264
- var markdownStyleElement = this.properties.markdownStyleElement, markdownStyle = this.getMarkdownStyle(), css = markdownStyleElement.update(markdownStyle);
265
- this.setCSS(css);
266
- var lexer = markdownStyleLexer, parser = markdownStyleParser, content = markdownStyle, tokens = lexer.tokenise(content), startRule = parser.getStartRule(), startOfContent = true, node = parser.parse(tokens, startRule, startOfContent);
267
- if (node !== null) {
268
- var parseTree = node.asParseTree(tokens);
269
- this.updateMarkdownStyleParseTreeTextarea(parseTree);
270
- } else {
271
- this.clearMarkdownStyleParseTreeTextarea();
272
- }
274
+ key: "update",
275
+ value: function update() {
276
+ this.updateMarkdown();
277
+ this.updateMarkdownStyle();
278
+ }
279
+ },
280
+ {
281
+ key: "clearPage",
282
+ value: function clearPage() {
283
+ this.clearXMP();
284
+ this.clearPreviewDiv();
285
+ }
286
+ },
287
+ {
288
+ key: "updatePage",
289
+ value: function updatePage(index) {
290
+ var divisionMarkdownNodes = this.getDivisionMarkdownNodes(), divisionMarkdownNode = divisionMarkdownNodes[index], tokens = this.getTokens(), context = {
291
+ tokens: tokens
292
+ }, length = null, html = divisionMarkdownNode.asHTML(context), plainText = divisionMarkdownNode.asPlainText(context);
293
+ this.updateXMP(html);
294
+ this.updatePreviewDiv(divisionMarkdownNode, context);
295
+ this.updatePageButtonsDiv(length, index);
296
+ this.updatePlainTextTextarea(plainText);
273
297
  }
274
298
  },
275
299
  {
@@ -287,11 +311,7 @@ var View = /*#__PURE__*/ function(Element) {
287
311
  nodeFromTokens: nodeFromTokens,
288
312
  tokensFromContent: tokensFromContent,
289
313
  charactersPerLine: charactersPerLine
290
- }, // markdownNodes = postprocess(divisionMarkdownNode, context),
291
- // divisionMarkdownNodes = divisionMarkdownNodesFromMarkdownNodes(markdownNodes);
292
- divisionMarkdownNodes = [
293
- divisionMarkdownNode
294
- ];
314
+ }, markdownNodes = (0, _processing.postprocess)(divisionMarkdownNode, context), divisionMarkdownNodes = (0, _processing.divisionMarkdownNodesFromMarkdownNodes)(markdownNodes);
295
315
  this.setDivisionMarkdownNodes(divisionMarkdownNodes);
296
316
  var parseTree = divisionMarkdownNode.asParseTree(tokens);
297
317
  this.updateMarkdownParseTreeTextarea(parseTree);
@@ -303,6 +323,7 @@ var View = /*#__PURE__*/ function(Element) {
303
323
  } else {
304
324
  this.clearPage();
305
325
  this.clearPageButtonsDiv();
326
+ this.clearPlainTextTextarea();
306
327
  this.clearMarkdownParseTreeTextarea();
307
328
  var divisionMarkdownNodes1 = null;
308
329
  this.setDivisionMarkdownNodes(divisionMarkdownNodes1);
@@ -310,21 +331,17 @@ var View = /*#__PURE__*/ function(Element) {
310
331
  }
311
332
  },
312
333
  {
313
- key: "updatePage",
314
- value: function updatePage(index) {
315
- var divisionMarkdownNodes = this.getDivisionMarkdownNodes(), divisionMarkdownNode = divisionMarkdownNodes[index], tokens = this.getTokens(), context = {
316
- tokens: tokens
317
- }, length = null, html = divisionMarkdownNode.asHTML(context);
318
- this.updateXMP(html);
319
- this.updatePreviewDiv(divisionMarkdownNode, context);
320
- this.updatePageButtonsDiv(length, index);
321
- }
322
- },
323
- {
324
- key: "clearPage",
325
- value: function clearPage() {
326
- this.clearXMP();
327
- this.clearPreviewDiv();
334
+ key: "updateMarkdownStyle",
335
+ value: function updateMarkdownStyle() {
336
+ var markdownStyleElement = this.properties.markdownStyleElement, markdownStyle = this.getMarkdownStyle(), css = markdownStyleElement.update(markdownStyle);
337
+ this.setCSS(css);
338
+ var lexer = markdownStyleLexer, parser = markdownStyleParser, content = markdownStyle, tokens = lexer.tokenise(content), startRule = parser.getStartRule(), startOfContent = true, node = parser.parse(tokens, startRule, startOfContent);
339
+ if (node !== null) {
340
+ var parseTree = node.asParseTree(tokens);
341
+ this.updateMarkdownStyleParseTreeTextarea(parseTree);
342
+ } else {
343
+ this.clearMarkdownStyleParseTreeTextarea();
344
+ }
328
345
  }
329
346
  },
330
347
  {
@@ -334,6 +351,15 @@ var View = /*#__PURE__*/ function(Element) {
334
351
  this.showMarkdownStyleContainerDiv();
335
352
  }
336
353
  },
354
+ {
355
+ key: "plainText",
356
+ value: function plainText() {
357
+ this.hideCSSContainerDiv();
358
+ this.hideHTMLContainerDiv();
359
+ this.hidePreviewContainerDiv();
360
+ this.showPlainTextContainerDiv();
361
+ }
362
+ },
337
363
  {
338
364
  key: "markdown",
339
365
  value: function markdown() {
@@ -342,10 +368,30 @@ var View = /*#__PURE__*/ function(Element) {
342
368
  }
343
369
  },
344
370
  {
345
- key: "update",
346
- value: function update() {
347
- this.updateMarkdown();
348
- this.updateMarkdownStyle();
371
+ key: "preview",
372
+ value: function preview() {
373
+ this.hideCSSContainerDiv();
374
+ this.hideHTMLContainerDiv();
375
+ this.showPreviewContainerDiv();
376
+ this.hidePlainTextContainerDiv();
377
+ }
378
+ },
379
+ {
380
+ key: "html",
381
+ value: function html() {
382
+ this.hideCSSContainerDiv();
383
+ this.showHTMLContainerDiv();
384
+ this.hidePreviewContainerDiv();
385
+ this.hidePlainTextContainerDiv();
386
+ }
387
+ },
388
+ {
389
+ key: "css",
390
+ value: function css() {
391
+ this.showCSSContainerDiv();
392
+ this.hideHTMLContainerDiv();
393
+ this.hidePreviewContainerDiv();
394
+ this.hidePlainTextContainerDiv();
349
395
  }
350
396
  },
351
397
  {
@@ -391,16 +437,21 @@ var View = /*#__PURE__*/ function(Element) {
391
437
  {
392
438
  key: "childElements",
393
439
  value: function childElements() {
394
- return /*#__PURE__*/ React.createElement(_easylayout.ColumnsDiv, null, /*#__PURE__*/ React.createElement(_left.default, null, /*#__PURE__*/ React.createElement(_tabButtons.default, {
440
+ return /*#__PURE__*/ React.createElement(_easylayout.ColumnsDiv, null, /*#__PURE__*/ React.createElement(_left.default, null, /*#__PURE__*/ React.createElement(_left1.default, {
395
441
  onCustomMarkdown: this.markdownCustomHandler,
396
442
  onCustomMarkdownStyle: this.markdownStyleCustomHandler
397
443
  }), /*#__PURE__*/ React.createElement(_markdown.default, {
398
444
  onCustomKeyUp: this.keyUpCustomHandler
399
445
  }), /*#__PURE__*/ React.createElement(_markdownStyle.default, {
400
446
  onCustomKeyUp: this.keyUpCustomHandler
401
- })), /*#__PURE__*/ React.createElement(_easylayout.VerticalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.ColumnDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_right.default, null, /*#__PURE__*/ React.createElement(_subHeading.default, null, "HTML"), /*#__PURE__*/ React.createElement(_html.default, null)), /*#__PURE__*/ React.createElement(_easylayout.HorizontalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.RowDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_subHeading.default, null, "CSS"), /*#__PURE__*/ React.createElement(_css.default, null), /*#__PURE__*/ React.createElement(_subHeading.default, null, "Preview"), /*#__PURE__*/ React.createElement(_preview.default, {
447
+ })), /*#__PURE__*/ React.createElement(_easylayout.VerticalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.ColumnDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_right.default, {
448
+ onCustomCSS: this.cssCustomHandler,
449
+ onCustomHTML: this.htmlCustomHandler,
450
+ onCustomPreview: this.previewCustomHandler,
451
+ onCustomPlainText: this.plainTextCustomHandler
452
+ }), /*#__PURE__*/ React.createElement(_css.default, null), /*#__PURE__*/ React.createElement(_html.default, null), /*#__PURE__*/ React.createElement(_preview.default, {
402
453
  onCustomPageUpdate: this.pageUpdateCustomHandler
403
- }))))));
454
+ }), /*#__PURE__*/ React.createElement(_plainText.default, null))));
404
455
  }
405
456
  },
406
457
  {
@@ -412,6 +463,7 @@ var View = /*#__PURE__*/ function(Element) {
412
463
  this.setMarkdown(markdown);
413
464
  this.setMarkdownStyle(markdownStyle);
414
465
  this.update();
466
+ this.css();
415
467
  }
416
468
  }
417
469
  ]);
@@ -426,7 +478,7 @@ _define_property(View, "defaultProperties", {
426
478
  });
427
479
  _define_property(View, "initialMarkdown", _importer.defaultContent) ///
428
480
  ;
429
- _define_property(View, "initialMarkdownStyle", "width: 100%;\nposition: absolute;\nmin-height: 100%; \npadding-top: 5rem; \n");
481
+ _define_property(View, "initialMarkdownStyle", "\n\nwidth: 100%;\nheight: 199%; \nposition: absolute;\nmin-height: 100%; \npadding-top: 5rem; \n\n");
430
482
  var _default = (0, _easywithstyle.default)(View)(_templateObject());
431
483
  function tokensFromContent(content) {
432
484
  var tokens = markdownLexer.tokenise(content);
@@ -438,4 +490,4 @@ function nodeFromTokens(tokens) {
438
490
  return node;
439
491
  }
440
492
 
441
- //# 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 { MarkdownLexer, MarkdownParser, MarkdownStyleLexer, MarkdownStyleParser } from \"../index\";\nimport { RowDiv, RowsDiv, ColumnDiv, ColumnsDiv, VerticalSplitterDiv, HorizontalSplitterDiv } from \"easy-layout\";\n\nimport HTMLDiv from \"./view/div/html\";\nimport importer from \"./importer\";\nimport PreviewDiv from \"./view/div/preview\";\nimport SubHeading from \"./view/subHeading\";\nimport CSSTextarea from \"./view/textarea/css\";\nimport indexOptions from \"./indexOptions\";\nimport TabButtonsDiv from \"./view/div/tabButtons\";\nimport LeftSizeableDiv from \"./view/div/sizeable/left\";\nimport RightSizeableDiv from \"./view/div/sizeable/right\";\nimport MarkdownContainerDiv from \"./view/div/container/markdown\";\nimport MarkdownStyleContainerDiv from \"./view/div/container/markdownStyle\";\n\nimport { defaultContent } from \"./importer\";\nimport { LINES_PER_PAGE, CONTENTS_DEPTH, CHARACTERS_PER_LINE } from \"./constants\";\nimport { postprocess, divisionMarkdownNodesFromMarkdownNodes } from \"../utilities/processing\";\n\nconst markdownLexer = MarkdownLexer.fromNothing(),\n      markdownParser = MarkdownParser.fromNothing(),\n      markdownStyleLexer = MarkdownStyleLexer.fromNothing(),\n      markdownStyleParser = MarkdownStyleParser.fromNothing();\n\nclass View extends Element {\n  markdownStyleCustomHandler = (event, element) => {\n    this.markdownStyle();\n  }\n\n  pageUpdateCustomHandler = (event, element, index) => {\n    this.clearPage();\n\n    this.updatePage(index);\n  }\n\n  markdownCustomHandler = (event, element) => {\n    this.markdown();\n  }\n\n  keyUpCustomHandler = (event, element) => {\n    this.update();\n  }\n\n  updateMarkdownStyle() {\n    const { markdownStyleElement } = this.properties,\n          markdownStyle = this.getMarkdownStyle(),\n          css = markdownStyleElement.update(markdownStyle);\n\n    this.setCSS(css);\n\n    const lexer = markdownStyleLexer, ///\n          parser = markdownStyleParser, ///\n          content = markdownStyle,  ///\n          tokens = lexer.tokenise(content),\n          startRule = parser.getStartRule(),\n          startOfContent = true,\n          node = parser.parse(tokens, startRule, startOfContent);\n\n    if (node !== null) {\n      const parseTree = node.asParseTree(tokens);\n\n      this.updateMarkdownStyleParseTreeTextarea(parseTree);\n    } else {\n      this.clearMarkdownStyleParseTreeTextarea();\n    }\n  }\n\n  updateMarkdown() {\n    const markdown = this.getMarkdown(),\n          lexer = markdownLexer,  ///\n          parser =  markdownParser, ///\n          content = markdown, ///\n          startOfContent = true,\n          startRule = parser.getStartRule(),\n          tokens = lexer.tokenise(content),\n          node = parser.parse(tokens, startRule, startOfContent);\n\n    this.setTokens(tokens);\n\n    if (node !== null) {\n      const divisionMarkdownNode = node,  ///\n            charactersPerLine = CHARACTERS_PER_LINE,\n            contentsDepth = CONTENTS_DEPTH,\n            linesPerPage = LINES_PER_PAGE,\n            context = {\n              tokens,\n              importer,\n              indexOptions,\n              linesPerPage,\n              contentsDepth,\n              nodeFromTokens,\n              tokensFromContent,\n              charactersPerLine\n            },\n            // markdownNodes = postprocess(divisionMarkdownNode, context),\n            // divisionMarkdownNodes = divisionMarkdownNodesFromMarkdownNodes(markdownNodes);\n            divisionMarkdownNodes = [\n              divisionMarkdownNode\n            ];\n\n      this.setDivisionMarkdownNodes(divisionMarkdownNodes);\n\n      const parseTree = divisionMarkdownNode.asParseTree(tokens);\n\n      this.updateMarkdownParseTreeTextarea(parseTree);\n\n      const index = 0,\n            length = divisionMarkdownNodes.length;\n\n      if (length > 0) {\n        this.updatePage(index);\n\n        this.updatePageButtonsDiv(length);\n      }\n    } else {\n      this.clearPage();\n\n      this.clearPageButtonsDiv();\n\n      this.clearMarkdownParseTreeTextarea();\n\n      const divisionMarkdownNodes = null;\n\n      this.setDivisionMarkdownNodes(divisionMarkdownNodes);\n    }\n  }\n\n  updatePage(index) {\n    const divisionMarkdownNodes = this.getDivisionMarkdownNodes(),\n          divisionMarkdownNode = divisionMarkdownNodes[index],\n          tokens = this.getTokens(),\n          context = {\n            tokens\n          },\n          length = null,\n          html = divisionMarkdownNode.asHTML(context);\n\n    this.updateXMP(html);\n\n    this.updatePreviewDiv(divisionMarkdownNode, context);\n\n    this.updatePageButtonsDiv(length, index);\n  }\n\n  clearPage() {\n    this.clearXMP();\n\n    this.clearPreviewDiv();\n  }\n\n  markdownStyle() {\n    this.hideMarkdownContainerDiv();\n    this.showMarkdownStyleContainerDiv();\n  }\n\n  markdown() {\n    this.showMarkdownContainerDiv();\n    this.hideMarkdownStyleContainerDiv();\n  }\n\n  update() {\n    this.updateMarkdown();\n    this.updateMarkdownStyle();\n  }\n\n  getTokens() {\n    const { tokens } = this.getState();\n\n    return tokens;\n  }\n\n  setTokens(tokens) {\n    this.updateState({\n      tokens\n    });\n  }\n\n  getDivisionMarkdownNodes() {\n    const { divisionMarkdownNodes } = this.getState();\n\n    return divisionMarkdownNodes;\n  }\n\n  setDivisionMarkdownNodes(divisionMarkdownNodes) {\n    this.updateState({\n      divisionMarkdownNodes\n    });\n  }\n\n  setInitialState() {\n    const tokens = null,\n          divisionMarkdownNodes = null;\n\n    this.setState({\n      tokens,\n      divisionMarkdownNodes\n    });\n  }\n\n  childElements() {\n    return (\n\n      <ColumnsDiv>\n        <LeftSizeableDiv>\n          <TabButtonsDiv 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            <RightSizeableDiv>\n              <SubHeading>\n                HTML\n              </SubHeading>\n              <HTMLDiv/>\n            </RightSizeableDiv>\n            <HorizontalSplitterDiv/>\n            <RowDiv>\n              <RowsDiv>\n                <SubHeading>\n                  CSS\n                </SubHeading>\n                <CSSTextarea/>\n                <SubHeading>\n                  Preview\n                </SubHeading>\n                <PreviewDiv onCustomPageUpdate={this.pageUpdateCustomHandler} />\n              </RowsDiv>\n            </RowDiv>\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.setMarkdown(markdown);\n\n    this.setMarkdownStyle(markdownStyle);\n\n    this.update();\n  }\n\n  static tagName = \"div\";\n\n  static ignoredProperties = [\n    \"markdownStyleElement\"\n  ];\n\n  static defaultProperties = {\n    className: \"view\"\n  };\n\n  static initialMarkdown = defaultContent;  ///\n\n  static initialMarkdownStyle = `width: 100%;\nposition: absolute;\nmin-height: 100%;  \npadding-top: 5rem;  \n`;\n}\n\nexport default withStyle(View)`\n\n  padding: 1rem;\n  \n`;\n\nfunction tokensFromContent(content) {\n  const tokens = markdownLexer.tokenise(content);\n\n  return tokens;\n}\n\nfunction nodeFromTokens(tokens, startRuleName = null) {\n  const ruleMap = markdownParser.getRuleMap(),\n        startRule = (startRuleName !== null) ?\n                      ruleMap[startRuleName] :\n                        markdownParser.getStartRule(),\n        startOfContent = true,\n        node = markdownParser.parse(tokens, startRule, startOfContent);\n\n  return node;\n}\n"],"names":["markdownLexer","MarkdownLexer","fromNothing","markdownParser","MarkdownParser","markdownStyleLexer","MarkdownStyleLexer","markdownStyleParser","MarkdownStyleParser","View","markdownStyleCustomHandler","event","element","markdownStyle","pageUpdateCustomHandler","index","clearPage","updatePage","markdownCustomHandler","markdown","keyUpCustomHandler","update","updateMarkdownStyle","markdownStyleElement","properties","getMarkdownStyle","css","setCSS","lexer","parser","content","tokens","tokenise","startRule","getStartRule","startOfContent","node","parse","parseTree","asParseTree","updateMarkdownStyleParseTreeTextarea","clearMarkdownStyleParseTreeTextarea","updateMarkdown","getMarkdown","setTokens","divisionMarkdownNode","charactersPerLine","CHARACTERS_PER_LINE","contentsDepth","CONTENTS_DEPTH","linesPerPage","LINES_PER_PAGE","context","importer","indexOptions","nodeFromTokens","tokensFromContent","divisionMarkdownNodes","setDivisionMarkdownNodes","updateMarkdownParseTreeTextarea","length","updatePageButtonsDiv","clearPageButtonsDiv","clearMarkdownParseTreeTextarea","getDivisionMarkdownNodes","getTokens","html","asHTML","updateXMP","updatePreviewDiv","clearXMP","clearPreviewDiv","hideMarkdownContainerDiv","showMarkdownStyleContainerDiv","showMarkdownContainerDiv","hideMarkdownStyleContainerDiv","getState","updateState","setInitialState","setState","childElements","ColumnsDiv","LeftSizeableDiv","TabButtonsDiv","onCustomMarkdown","onCustomMarkdownStyle","MarkdownContainerDiv","onCustomKeyUp","MarkdownStyleContainerDiv","VerticalSplitterDiv","ColumnDiv","RowsDiv","RightSizeableDiv","SubHeading","HTMLDiv","HorizontalSplitterDiv","RowDiv","CSSTextarea","PreviewDiv","onCustomPageUpdate","initialise","assignContext","constructor","initialMarkdown","initialMarkdownStyle","setMarkdown","setMarkdownStyle","Element","tagName","ignoredProperties","defaultProperties","className","defaultContent","withStyle","startRuleName","ruleMap","getRuleMap"],"mappings":"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"}
493
+ //# 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 { RowsDiv, ColumnDiv, ColumnsDiv, VerticalSplitterDiv } from \"easy-layout\";\nimport { MarkdownLexer, MarkdownParser, MarkdownStyleLexer, MarkdownStyleParser } from \"../index\";\n\nimport importer from \"./importer\";\nimport indexOptions from \"./indexOptions\";\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 PlainTextContainerDiv from \"./view/div/container/plainText\";\nimport MarkdownStyleContainerDiv from \"./view/div/container/markdownStyle\";\n\nimport { defaultContent } from \"./importer\";\nimport { LINES_PER_PAGE, CONTENTS_DEPTH, CHARACTERS_PER_LINE } from \"./constants\";\nimport { postprocess, divisionMarkdownNodesFromMarkdownNodes } from \"../utilities/processing\";\n\nconst markdownLexer = MarkdownLexer.fromNothing(),\n      markdownParser = MarkdownParser.fromNothing(),\n      markdownStyleLexer = MarkdownStyleLexer.fromNothing(),\n      markdownStyleParser = MarkdownStyleParser.fromNothing();\n\nclass View extends Element {\n  markdownStyleCustomHandler = (event, element) => {\n    this.markdownStyle();\n  }\n\n  pageUpdateCustomHandler = (event, element, index) => {\n    this.clearPage();\n\n    this.updatePage(index);\n  }\n\n  plainTextCustomHandler = (event, element) => {\n    this.plainText();\n  }\n\n  markdownCustomHandler = (event, element) => {\n    this.markdown();\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.updateMarkdown();\n    this.updateMarkdownStyle();\n  }\n\n  clearPage() {\n    this.clearXMP();\n    this.clearPreviewDiv();\n  }\n\n  updatePage(index) {\n    const divisionMarkdownNodes = this.getDivisionMarkdownNodes(),\n          divisionMarkdownNode = divisionMarkdownNodes[index],\n          tokens = this.getTokens(),\n          context = {\n            tokens\n          },\n          length = null,\n          html = divisionMarkdownNode.asHTML(context),\n          plainText = divisionMarkdownNode.asPlainText(context);\n\n    this.updateXMP(html);\n\n    this.updatePreviewDiv(divisionMarkdownNode, context);\n\n    this.updatePageButtonsDiv(length, index);\n\n    this.updatePlainTextTextarea(plainText);\n  }\n\n  updateMarkdown() {\n    const markdown = this.getMarkdown(),\n          lexer = markdownLexer,  ///\n          parser =  markdownParser, ///\n          content = markdown, ///\n          startOfContent = true,\n          startRule = parser.getStartRule(),\n          tokens = lexer.tokenise(content),\n          node = parser.parse(tokens, startRule, startOfContent);\n\n    this.setTokens(tokens);\n\n    if (node !== null) {\n      const divisionMarkdownNode = node,  ///\n            charactersPerLine = CHARACTERS_PER_LINE,\n            contentsDepth = CONTENTS_DEPTH,\n            linesPerPage = LINES_PER_PAGE,\n            context = {\n              tokens,\n              importer,\n              indexOptions,\n              linesPerPage,\n              contentsDepth,\n              nodeFromTokens,\n              tokensFromContent,\n              charactersPerLine\n            },\n            markdownNodes = postprocess(divisionMarkdownNode, context),\n            divisionMarkdownNodes = divisionMarkdownNodesFromMarkdownNodes(markdownNodes);\n\n      this.setDivisionMarkdownNodes(divisionMarkdownNodes);\n\n      const parseTree = divisionMarkdownNode.asParseTree(tokens);\n\n      this.updateMarkdownParseTreeTextarea(parseTree);\n\n      const index = 0,\n            length = divisionMarkdownNodes.length;\n\n      if (length > 0) {\n        this.updatePage(index);\n\n        this.updatePageButtonsDiv(length);\n      }\n    } else {\n      this.clearPage();\n\n      this.clearPageButtonsDiv();\n\n      this.clearPlainTextTextarea();\n\n      this.clearMarkdownParseTreeTextarea();\n\n      const divisionMarkdownNodes = null;\n\n      this.setDivisionMarkdownNodes(divisionMarkdownNodes);\n    }\n  }\n\n  updateMarkdownStyle() {\n    const { markdownStyleElement } = this.properties,\n          markdownStyle = this.getMarkdownStyle(),\n          css = markdownStyleElement.update(markdownStyle);\n\n    this.setCSS(css);\n\n    const lexer = markdownStyleLexer, ///\n          parser = markdownStyleParser, ///\n          content = markdownStyle,  ///\n          tokens = lexer.tokenise(content),\n          startRule = parser.getStartRule(),\n          startOfContent = true,\n          node = parser.parse(tokens, startRule, startOfContent);\n\n    if (node !== null) {\n      const parseTree = node.asParseTree(tokens);\n\n      this.updateMarkdownStyleParseTreeTextarea(parseTree);\n    } else {\n      this.clearMarkdownStyleParseTreeTextarea();\n    }\n  }\n\n  markdownStyle() {\n    this.hideMarkdownContainerDiv();\n    this.showMarkdownStyleContainerDiv();\n  }\n\n  plainText() {\n    this.hideCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.showPlainTextContainerDiv();\n  }\n\n  markdown() {\n    this.showMarkdownContainerDiv();\n    this.hideMarkdownStyleContainerDiv();\n  }\n\n  preview() {\n    this.hideCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.showPreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n  }\n\n  html() {\n    this.hideCSSContainerDiv();\n    this.showHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n  }\n\n  css() {\n    this.showCSSContainerDiv();\n    this.hideHTMLContainerDiv();\n    this.hidePreviewContainerDiv();\n    this.hidePlainTextContainerDiv();\n  }\n\n  getTokens() {\n    const { tokens } = this.getState();\n\n    return tokens;\n  }\n\n  setTokens(tokens) {\n    this.updateState({\n      tokens\n    });\n  }\n\n  getDivisionMarkdownNodes() {\n    const { divisionMarkdownNodes } = this.getState();\n\n    return divisionMarkdownNodes;\n  }\n\n  setDivisionMarkdownNodes(divisionMarkdownNodes) {\n    this.updateState({\n      divisionMarkdownNodes\n    });\n  }\n\n  setInitialState() {\n    const tokens = null,\n          divisionMarkdownNodes = null;\n\n    this.setState({\n      tokens,\n      divisionMarkdownNodes\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            <CSSContainerDiv/>\n            <HTMLContainerDiv/>\n            <PreviewContainerDiv onCustomPageUpdate={this.pageUpdateCustomHandler} />\n            <PlainTextContainerDiv/>\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.setMarkdown(markdown);\n\n    this.setMarkdownStyle(markdownStyle);\n\n    this.update();\n\n    this.css();\n  }\n\n  static tagName = \"div\";\n\n  static ignoredProperties = [\n    \"markdownStyleElement\"\n  ];\n\n  static defaultProperties = {\n    className: \"view\"\n  };\n\n  static initialMarkdown = defaultContent;  ///\n\n  static initialMarkdownStyle = `\n\nwidth: 100%;\nheight: 199%;  \nposition: absolute;\nmin-height: 100%;  \npadding-top: 5rem;  \n\n`;\n}\n\nexport default withStyle(View)`\n\n  padding: 1rem;\n  \n`;\n\nfunction tokensFromContent(content) {\n  const tokens = markdownLexer.tokenise(content);\n\n  return tokens;\n}\n\nfunction nodeFromTokens(tokens, startRuleName = null) {\n  const ruleMap = markdownParser.getRuleMap(),\n        startRule = (startRuleName !== null) ?\n                      ruleMap[startRuleName] :\n                        markdownParser.getStartRule(),\n        startOfContent = true,\n        node = markdownParser.parse(tokens, startRule, startOfContent);\n\n  return node;\n}\n"],"names":["markdownLexer","MarkdownLexer","fromNothing","markdownParser","MarkdownParser","markdownStyleLexer","MarkdownStyleLexer","markdownStyleParser","MarkdownStyleParser","View","markdownStyleCustomHandler","event","element","markdownStyle","pageUpdateCustomHandler","index","clearPage","updatePage","plainTextCustomHandler","plainText","markdownCustomHandler","markdown","previewCustomHandler","preview","keyUpCustomHandler","update","htmlCustomHandler","html","cssCustomHandler","css","updateMarkdown","updateMarkdownStyle","clearXMP","clearPreviewDiv","divisionMarkdownNodes","getDivisionMarkdownNodes","divisionMarkdownNode","tokens","getTokens","context","length","asHTML","asPlainText","updateXMP","updatePreviewDiv","updatePageButtonsDiv","updatePlainTextTextarea","getMarkdown","lexer","parser","content","startOfContent","startRule","getStartRule","tokenise","node","parse","setTokens","charactersPerLine","CHARACTERS_PER_LINE","contentsDepth","CONTENTS_DEPTH","linesPerPage","LINES_PER_PAGE","importer","indexOptions","nodeFromTokens","tokensFromContent","markdownNodes","postprocess","divisionMarkdownNodesFromMarkdownNodes","setDivisionMarkdownNodes","parseTree","asParseTree","updateMarkdownParseTreeTextarea","clearPageButtonsDiv","clearPlainTextTextarea","clearMarkdownParseTreeTextarea","markdownStyleElement","properties","getMarkdownStyle","setCSS","updateMarkdownStyleParseTreeTextarea","clearMarkdownStyleParseTreeTextarea","hideMarkdownContainerDiv","showMarkdownStyleContainerDiv","hideCSSContainerDiv","hideHTMLContainerDiv","hidePreviewContainerDiv","showPlainTextContainerDiv","showMarkdownContainerDiv","hideMarkdownStyleContainerDiv","showPreviewContainerDiv","hidePlainTextContainerDiv","showHTMLContainerDiv","showCSSContainerDiv","getState","updateState","setInitialState","setState","childElements","ColumnsDiv","LeftSizeableDiv","LeftTabButtonsDiv","onCustomMarkdown","onCustomMarkdownStyle","MarkdownContainerDiv","onCustomKeyUp","MarkdownStyleContainerDiv","VerticalSplitterDiv","ColumnDiv","RowsDiv","RightTabButtonsDiv","onCustomCSS","onCustomHTML","onCustomPreview","onCustomPlainText","CSSContainerDiv","HTMLContainerDiv","PreviewContainerDiv","onCustomPageUpdate","PlainTextContainerDiv","initialise","assignContext","constructor","initialMarkdown","initialMarkdownStyle","setMarkdown","setMarkdownStyle","Element","tagName","ignoredProperties","defaultProperties","className","defaultContent","withStyle","startRuleName","ruleMap","getRuleMap"],"mappings":"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"}
@@ -115,6 +115,13 @@ var TableBodyCellMarkdownNode = /*#__PURE__*/ function(MarkdownNode) {
115
115
  var childNodes = this.getChildNodes(), firstChildNode = first(childNodes), tableCellMarkdownNode = firstChildNode, childNodesHTML = tableCellMarkdownNode.childNodesAsHTML(indent, context);
116
116
  return childNodesHTML;
117
117
  }
118
+ },
119
+ {
120
+ key: "childNodesAsPlainText",
121
+ value: function childNodesAsPlainText(indent, context) {
122
+ var childNodes = this.getChildNodes(), firstChildNode = first(childNodes), tableCellMarkdownNode = firstChildNode, childNodesPlainText = tableCellMarkdownNode.childNodesAsPlainText(indent, context);
123
+ return childNodesPlainText;
124
+ }
118
125
  }
119
126
  ], [
120
127
  {
@@ -127,4 +134,4 @@ var TableBodyCellMarkdownNode = /*#__PURE__*/ function(MarkdownNode) {
127
134
  return TableBodyCellMarkdownNode;
128
135
  }(_markdown.default);
129
136
 
130
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ub2RlL21hcmtkb3duL3RhYmxlQm9keUNlbGwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7IGFycmF5VXRpbGl0aWVzIH0gZnJvbSBcIm5lY2Vzc2FyeVwiO1xuXG5pbXBvcnQgTWFya2Rvd25Ob2RlIGZyb20gXCIuLi8uLi9ub2RlL21hcmtkb3duXCI7XG5cbmNvbnN0IHsgZmlyc3QgfSA9IGFycmF5VXRpbGl0aWVzO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBUYWJsZUJvZHlDZWxsTWFya2Rvd25Ob2RlIGV4dGVuZHMgTWFya2Rvd25Ob2RlIHtcbiAgY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpIHtcbiAgICBjb25zdCBjaGlsZE5vZGVzID0gdGhpcy5nZXRDaGlsZE5vZGVzKCksXG4gICAgICAgICAgZmlyc3RDaGlsZE5vZGUgPSBmaXJzdChjaGlsZE5vZGVzKSxcbiAgICAgICAgICB0YWJsZUNlbGxNYXJrZG93bk5vZGUgPSBmaXJzdENoaWxkTm9kZSwgLy8vXG4gICAgICAgICAgY2hpbGROb2Rlc0hUTUwgPSB0YWJsZUNlbGxNYXJrZG93bk5vZGUuY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpO1xuXG4gICAgcmV0dXJuIGNoaWxkTm9kZXNIVE1MO1xuICB9XG5cbiAgc3RhdGljIGZyb21SdWxlTmFtZUNoaWxkTm9kZXNBbmRPcGFjaXR5KHJ1bGVOYW1lLCBjaGlsZE5vZGVzLCBvcGFjaXR5KSB7IHJldHVybiBNYXJrZG93bk5vZGUuZnJvbVJ1bGVOYW1lQ2hpbGROb2Rlc0FuZE9wYWNpdHkoVGFibGVCb2R5Q2VsbE1hcmtkb3duTm9kZSwgcnVsZU5hbWUsIGNoaWxkTm9kZXMsIG9wYWNpdHkpOyB9XG59XG4iXSwibmFtZXMiOlsiVGFibGVCb2R5Q2VsbE1hcmtkb3duTm9kZSIsImZpcnN0IiwiYXJyYXlVdGlsaXRpZXMiLCJjaGlsZE5vZGVzQXNIVE1MIiwiaW5kZW50IiwiY29udGV4dCIsImNoaWxkTm9kZXMiLCJnZXRDaGlsZE5vZGVzIiwiZmlyc3RDaGlsZE5vZGUiLCJ0YWJsZUNlbGxNYXJrZG93bk5vZGUiLCJjaGlsZE5vZGVzSFRNTCIsImZyb21SdWxlTmFtZUNoaWxkTm9kZXNBbmRPcGFjaXR5IiwicnVsZU5hbWUiLCJvcGFjaXR5IiwiTWFya2Rvd25Ob2RlIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztlQVFxQkE7Ozt5QkFOVTsrREFFTjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUV6QixJQUFNLEFBQUVDLFFBQVVDLHlCQUFjLENBQXhCRDtBQUVPLElBQUEsQUFBTUQsMENBQUQsQUFBTDtjQUFNQTsrQkFBQUE7YUFBQUE7Z0NBQUFBOzs7a0JBQUFBOztZQUNuQkcsS0FBQUE7bUJBQUFBLFNBQUFBLGlCQUFpQkMsTUFBTSxFQUFFQyxPQUFPO2dCQUM5QixJQUFNQyxhQUFhLElBQUksQ0FBQ0MsYUFBYSxJQUMvQkMsaUJBQWlCUCxNQUFNSyxhQUN2Qkcsd0JBQXdCRCxnQkFDeEJFLGlCQUFpQkQsc0JBQXNCTixnQkFBZ0IsQ0FBQ0MsUUFBUUM7Z0JBRXRFLE9BQU9LO1lBQ1Q7Ozs7WUFFT0MsS0FBQUE7bUJBQVAsU0FBT0EsaUNBQWlDQyxRQUFRLEVBQUVOLFVBQVUsRUFBRU8sT0FBTztnQkFBSSxPQUFPQyxpQkFBWSxDQUFDSCxnQ0FBZ0MsQ0FWMUdYLDJCQVVzSVksVUFBVU4sWUFBWU87WUFBVTs7O1dBVnRLYjtFQUFrQ2MsaUJBQVkifQ==
137
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ub2RlL21hcmtkb3duL3RhYmxlQm9keUNlbGwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7IGFycmF5VXRpbGl0aWVzIH0gZnJvbSBcIm5lY2Vzc2FyeVwiO1xuXG5pbXBvcnQgTWFya2Rvd25Ob2RlIGZyb20gXCIuLi8uLi9ub2RlL21hcmtkb3duXCI7XG5cbmNvbnN0IHsgZmlyc3QgfSA9IGFycmF5VXRpbGl0aWVzO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBUYWJsZUJvZHlDZWxsTWFya2Rvd25Ob2RlIGV4dGVuZHMgTWFya2Rvd25Ob2RlIHtcbiAgY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpIHtcbiAgICBjb25zdCBjaGlsZE5vZGVzID0gdGhpcy5nZXRDaGlsZE5vZGVzKCksXG4gICAgICAgICAgZmlyc3RDaGlsZE5vZGUgPSBmaXJzdChjaGlsZE5vZGVzKSxcbiAgICAgICAgICB0YWJsZUNlbGxNYXJrZG93bk5vZGUgPSBmaXJzdENoaWxkTm9kZSwgLy8vXG4gICAgICAgICAgY2hpbGROb2Rlc0hUTUwgPSB0YWJsZUNlbGxNYXJrZG93bk5vZGUuY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpO1xuXG4gICAgcmV0dXJuIGNoaWxkTm9kZXNIVE1MO1xuICB9XG5cbiAgY2hpbGROb2Rlc0FzUGxhaW5UZXh0KGluZGVudCwgY29udGV4dCkge1xuICAgIGNvbnN0IGNoaWxkTm9kZXMgPSB0aGlzLmdldENoaWxkTm9kZXMoKSxcbiAgICAgICAgICBmaXJzdENoaWxkTm9kZSA9IGZpcnN0KGNoaWxkTm9kZXMpLFxuICAgICAgICAgIHRhYmxlQ2VsbE1hcmtkb3duTm9kZSA9IGZpcnN0Q2hpbGROb2RlLCAvLy9cbiAgICAgICAgICBjaGlsZE5vZGVzUGxhaW5UZXh0ID0gdGFibGVDZWxsTWFya2Rvd25Ob2RlLmNoaWxkTm9kZXNBc1BsYWluVGV4dChpbmRlbnQsIGNvbnRleHQpO1xuXG4gICAgcmV0dXJuIGNoaWxkTm9kZXNQbGFpblRleHQ7XG4gIH1cblxuICBzdGF0aWMgZnJvbVJ1bGVOYW1lQ2hpbGROb2Rlc0FuZE9wYWNpdHkocnVsZU5hbWUsIGNoaWxkTm9kZXMsIG9wYWNpdHkpIHsgcmV0dXJuIE1hcmtkb3duTm9kZS5mcm9tUnVsZU5hbWVDaGlsZE5vZGVzQW5kT3BhY2l0eShUYWJsZUJvZHlDZWxsTWFya2Rvd25Ob2RlLCBydWxlTmFtZSwgY2hpbGROb2Rlcywgb3BhY2l0eSk7IH1cbn1cbiJdLCJuYW1lcyI6WyJUYWJsZUJvZHlDZWxsTWFya2Rvd25Ob2RlIiwiZmlyc3QiLCJhcnJheVV0aWxpdGllcyIsImNoaWxkTm9kZXNBc0hUTUwiLCJpbmRlbnQiLCJjb250ZXh0IiwiY2hpbGROb2RlcyIsImdldENoaWxkTm9kZXMiLCJmaXJzdENoaWxkTm9kZSIsInRhYmxlQ2VsbE1hcmtkb3duTm9kZSIsImNoaWxkTm9kZXNIVE1MIiwiY2hpbGROb2Rlc0FzUGxhaW5UZXh0IiwiY2hpbGROb2Rlc1BsYWluVGV4dCIsImZyb21SdWxlTmFtZUNoaWxkTm9kZXNBbmRPcGFjaXR5IiwicnVsZU5hbWUiLCJvcGFjaXR5IiwiTWFya2Rvd25Ob2RlIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztlQVFxQkE7Ozt5QkFOVTsrREFFTjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUV6QixJQUFNLEFBQUVDLFFBQVVDLHlCQUFjLENBQXhCRDtBQUVPLElBQUEsQUFBTUQsMENBQUQsQUFBTDtjQUFNQTsrQkFBQUE7YUFBQUE7Z0NBQUFBOzs7a0JBQUFBOztZQUNuQkcsS0FBQUE7bUJBQUFBLFNBQUFBLGlCQUFpQkMsTUFBTSxFQUFFQyxPQUFPO2dCQUM5QixJQUFNQyxhQUFhLElBQUksQ0FBQ0MsYUFBYSxJQUMvQkMsaUJBQWlCUCxNQUFNSyxhQUN2Qkcsd0JBQXdCRCxnQkFDeEJFLGlCQUFpQkQsc0JBQXNCTixnQkFBZ0IsQ0FBQ0MsUUFBUUM7Z0JBRXRFLE9BQU9LO1lBQ1Q7OztZQUVBQyxLQUFBQTttQkFBQUEsU0FBQUEsc0JBQXNCUCxNQUFNLEVBQUVDLE9BQU87Z0JBQ25DLElBQU1DLGFBQWEsSUFBSSxDQUFDQyxhQUFhLElBQy9CQyxpQkFBaUJQLE1BQU1LLGFBQ3ZCRyx3QkFBd0JELGdCQUN4Qkksc0JBQXNCSCxzQkFBc0JFLHFCQUFxQixDQUFDUCxRQUFRQztnQkFFaEYsT0FBT087WUFDVDs7OztZQUVPQyxLQUFBQTttQkFBUCxTQUFPQSxpQ0FBaUNDLFFBQVEsRUFBRVIsVUFBVSxFQUFFUyxPQUFPO2dCQUFJLE9BQU9DLGlCQUFZLENBQUNILGdDQUFnQyxDQW5CMUdiLDJCQW1Cc0ljLFVBQVVSLFlBQVlTO1lBQVU7OztXQW5CdEtmO0VBQWtDZ0IsaUJBQVkifQ==
@@ -115,6 +115,13 @@ var TableHeadCellMarkdownNode = /*#__PURE__*/ function(MarkdownNode) {
115
115
  var childNodes = this.getChildNodes(), firstChildNode = first(childNodes), tableCellMarkdownNode = firstChildNode, childNodesHTML = tableCellMarkdownNode.childNodesAsHTML(indent, context);
116
116
  return childNodesHTML;
117
117
  }
118
+ },
119
+ {
120
+ key: "childNodesAsPlainText",
121
+ value: function childNodesAsPlainText(indent, context) {
122
+ var childNodes = this.getChildNodes(), firstChildNode = first(childNodes), tableCellMarkdownNode = firstChildNode, childNodesPlainText = tableCellMarkdownNode.childNodesAsPlainText(indent, context);
123
+ return childNodesPlainText;
124
+ }
118
125
  }
119
126
  ], [
120
127
  {
@@ -127,4 +134,4 @@ var TableHeadCellMarkdownNode = /*#__PURE__*/ function(MarkdownNode) {
127
134
  return TableHeadCellMarkdownNode;
128
135
  }(_markdown.default);
129
136
 
130
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ub2RlL21hcmtkb3duL3RhYmxlSGVhZENlbGwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7IGFycmF5VXRpbGl0aWVzIH0gZnJvbSBcIm5lY2Vzc2FyeVwiO1xuXG5pbXBvcnQgTWFya2Rvd25Ob2RlIGZyb20gXCIuLi8uLi9ub2RlL21hcmtkb3duXCI7XG5cbmNvbnN0IHsgZmlyc3QgfSA9IGFycmF5VXRpbGl0aWVzO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBUYWJsZUhlYWRDZWxsTWFya2Rvd25Ob2RlIGV4dGVuZHMgTWFya2Rvd25Ob2RlIHtcbiAgY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpIHtcbiAgICBjb25zdCBjaGlsZE5vZGVzID0gdGhpcy5nZXRDaGlsZE5vZGVzKCksXG4gICAgICAgICAgZmlyc3RDaGlsZE5vZGUgPSBmaXJzdChjaGlsZE5vZGVzKSxcbiAgICAgICAgICB0YWJsZUNlbGxNYXJrZG93bk5vZGUgPSBmaXJzdENoaWxkTm9kZSwgLy8vXG4gICAgICAgICAgY2hpbGROb2Rlc0hUTUwgPSB0YWJsZUNlbGxNYXJrZG93bk5vZGUuY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpO1xuXG4gICAgcmV0dXJuIGNoaWxkTm9kZXNIVE1MO1xuICB9XG5cbiAgc3RhdGljIGZyb21SdWxlTmFtZUNoaWxkTm9kZXNBbmRPcGFjaXR5KHJ1bGVOYW1lLCBjaGlsZE5vZGVzLCBvcGFjaXR5KSB7IHJldHVybiBNYXJrZG93bk5vZGUuZnJvbVJ1bGVOYW1lQ2hpbGROb2Rlc0FuZE9wYWNpdHkoVGFibGVIZWFkQ2VsbE1hcmtkb3duTm9kZSwgcnVsZU5hbWUsIGNoaWxkTm9kZXMsIG9wYWNpdHkpOyB9XG59XG4iXSwibmFtZXMiOlsiVGFibGVIZWFkQ2VsbE1hcmtkb3duTm9kZSIsImZpcnN0IiwiYXJyYXlVdGlsaXRpZXMiLCJjaGlsZE5vZGVzQXNIVE1MIiwiaW5kZW50IiwiY29udGV4dCIsImNoaWxkTm9kZXMiLCJnZXRDaGlsZE5vZGVzIiwiZmlyc3RDaGlsZE5vZGUiLCJ0YWJsZUNlbGxNYXJrZG93bk5vZGUiLCJjaGlsZE5vZGVzSFRNTCIsImZyb21SdWxlTmFtZUNoaWxkTm9kZXNBbmRPcGFjaXR5IiwicnVsZU5hbWUiLCJvcGFjaXR5IiwiTWFya2Rvd25Ob2RlIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztlQVFxQkE7Ozt5QkFOVTsrREFFTjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUV6QixJQUFNLEFBQUVDLFFBQVVDLHlCQUFjLENBQXhCRDtBQUVPLElBQUEsQUFBTUQsMENBQUQsQUFBTDtjQUFNQTsrQkFBQUE7YUFBQUE7Z0NBQUFBOzs7a0JBQUFBOztZQUNuQkcsS0FBQUE7bUJBQUFBLFNBQUFBLGlCQUFpQkMsTUFBTSxFQUFFQyxPQUFPO2dCQUM5QixJQUFNQyxhQUFhLElBQUksQ0FBQ0MsYUFBYSxJQUMvQkMsaUJBQWlCUCxNQUFNSyxhQUN2Qkcsd0JBQXdCRCxnQkFDeEJFLGlCQUFpQkQsc0JBQXNCTixnQkFBZ0IsQ0FBQ0MsUUFBUUM7Z0JBRXRFLE9BQU9LO1lBQ1Q7Ozs7WUFFT0MsS0FBQUE7bUJBQVAsU0FBT0EsaUNBQWlDQyxRQUFRLEVBQUVOLFVBQVUsRUFBRU8sT0FBTztnQkFBSSxPQUFPQyxpQkFBWSxDQUFDSCxnQ0FBZ0MsQ0FWMUdYLDJCQVVzSVksVUFBVU4sWUFBWU87WUFBVTs7O1dBVnRLYjtFQUFrQ2MsaUJBQVkifQ==
137
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ub2RlL21hcmtkb3duL3RhYmxlSGVhZENlbGwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7IGFycmF5VXRpbGl0aWVzIH0gZnJvbSBcIm5lY2Vzc2FyeVwiO1xuXG5pbXBvcnQgTWFya2Rvd25Ob2RlIGZyb20gXCIuLi8uLi9ub2RlL21hcmtkb3duXCI7XG5cbmNvbnN0IHsgZmlyc3QgfSA9IGFycmF5VXRpbGl0aWVzO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBUYWJsZUhlYWRDZWxsTWFya2Rvd25Ob2RlIGV4dGVuZHMgTWFya2Rvd25Ob2RlIHtcbiAgY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpIHtcbiAgICBjb25zdCBjaGlsZE5vZGVzID0gdGhpcy5nZXRDaGlsZE5vZGVzKCksXG4gICAgICAgICAgZmlyc3RDaGlsZE5vZGUgPSBmaXJzdChjaGlsZE5vZGVzKSxcbiAgICAgICAgICB0YWJsZUNlbGxNYXJrZG93bk5vZGUgPSBmaXJzdENoaWxkTm9kZSwgLy8vXG4gICAgICAgICAgY2hpbGROb2Rlc0hUTUwgPSB0YWJsZUNlbGxNYXJrZG93bk5vZGUuY2hpbGROb2Rlc0FzSFRNTChpbmRlbnQsIGNvbnRleHQpO1xuXG4gICAgcmV0dXJuIGNoaWxkTm9kZXNIVE1MO1xuICB9XG5cbiAgY2hpbGROb2Rlc0FzUGxhaW5UZXh0KGluZGVudCwgY29udGV4dCkge1xuICAgIGNvbnN0IGNoaWxkTm9kZXMgPSB0aGlzLmdldENoaWxkTm9kZXMoKSxcbiAgICAgICAgICBmaXJzdENoaWxkTm9kZSA9IGZpcnN0KGNoaWxkTm9kZXMpLFxuICAgICAgICAgIHRhYmxlQ2VsbE1hcmtkb3duTm9kZSA9IGZpcnN0Q2hpbGROb2RlLCAvLy9cbiAgICAgICAgICBjaGlsZE5vZGVzUGxhaW5UZXh0ID0gdGFibGVDZWxsTWFya2Rvd25Ob2RlLmNoaWxkTm9kZXNBc1BsYWluVGV4dChpbmRlbnQsIGNvbnRleHQpO1xuXG4gICAgcmV0dXJuIGNoaWxkTm9kZXNQbGFpblRleHQ7XG4gIH1cblxuICBzdGF0aWMgZnJvbVJ1bGVOYW1lQ2hpbGROb2Rlc0FuZE9wYWNpdHkocnVsZU5hbWUsIGNoaWxkTm9kZXMsIG9wYWNpdHkpIHsgcmV0dXJuIE1hcmtkb3duTm9kZS5mcm9tUnVsZU5hbWVDaGlsZE5vZGVzQW5kT3BhY2l0eShUYWJsZUhlYWRDZWxsTWFya2Rvd25Ob2RlLCBydWxlTmFtZSwgY2hpbGROb2Rlcywgb3BhY2l0eSk7IH1cbn1cbiJdLCJuYW1lcyI6WyJUYWJsZUhlYWRDZWxsTWFya2Rvd25Ob2RlIiwiZmlyc3QiLCJhcnJheVV0aWxpdGllcyIsImNoaWxkTm9kZXNBc0hUTUwiLCJpbmRlbnQiLCJjb250ZXh0IiwiY2hpbGROb2RlcyIsImdldENoaWxkTm9kZXMiLCJmaXJzdENoaWxkTm9kZSIsInRhYmxlQ2VsbE1hcmtkb3duTm9kZSIsImNoaWxkTm9kZXNIVE1MIiwiY2hpbGROb2Rlc0FzUGxhaW5UZXh0IiwiY2hpbGROb2Rlc1BsYWluVGV4dCIsImZyb21SdWxlTmFtZUNoaWxkTm9kZXNBbmRPcGFjaXR5IiwicnVsZU5hbWUiLCJvcGFjaXR5IiwiTWFya2Rvd25Ob2RlIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztlQVFxQkE7Ozt5QkFOVTsrREFFTjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUV6QixJQUFNLEFBQUVDLFFBQVVDLHlCQUFjLENBQXhCRDtBQUVPLElBQUEsQUFBTUQsMENBQUQsQUFBTDtjQUFNQTsrQkFBQUE7YUFBQUE7Z0NBQUFBOzs7a0JBQUFBOztZQUNuQkcsS0FBQUE7bUJBQUFBLFNBQUFBLGlCQUFpQkMsTUFBTSxFQUFFQyxPQUFPO2dCQUM5QixJQUFNQyxhQUFhLElBQUksQ0FBQ0MsYUFBYSxJQUMvQkMsaUJBQWlCUCxNQUFNSyxhQUN2Qkcsd0JBQXdCRCxnQkFDeEJFLGlCQUFpQkQsc0JBQXNCTixnQkFBZ0IsQ0FBQ0MsUUFBUUM7Z0JBRXRFLE9BQU9LO1lBQ1Q7OztZQUVBQyxLQUFBQTttQkFBQUEsU0FBQUEsc0JBQXNCUCxNQUFNLEVBQUVDLE9BQU87Z0JBQ25DLElBQU1DLGFBQWEsSUFBSSxDQUFDQyxhQUFhLElBQy9CQyxpQkFBaUJQLE1BQU1LLGFBQ3ZCRyx3QkFBd0JELGdCQUN4Qkksc0JBQXNCSCxzQkFBc0JFLHFCQUFxQixDQUFDUCxRQUFRQztnQkFFaEYsT0FBT087WUFDVDs7OztZQUVPQyxLQUFBQTttQkFBUCxTQUFPQSxpQ0FBaUNDLFFBQVEsRUFBRVIsVUFBVSxFQUFFUyxPQUFPO2dCQUFJLE9BQU9DLGlCQUFZLENBQUNILGdDQUFnQyxDQW5CMUdiLDJCQW1Cc0ljLFVBQVVSLFlBQVlTO1lBQVU7OztXQW5CdEtmO0VBQWtDZ0IsaUJBQVkifQ==
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "highmark-markdown",
3
3
  "author": "James Smith",
4
- "version": "1.0.41",
4
+ "version": "1.0.42",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/highmark-markdown",
7
7
  "description": "Highmark's Markdown and Markdown Style languages.",
@@ -18,12 +18,12 @@
18
18
  },
19
19
  "devDependencies": {
20
20
  "@swc/core": "^1.5.6",
21
- "easy": "^19.0.1",
22
- "easy-layout": "^6.0.175",
23
- "easy-with-style": "^3.0.391",
21
+ "easy": "^19.0.4",
22
+ "easy-layout": "^6.0.176",
23
+ "easy-with-style": "^3.0.392",
24
24
  "esbuild": "^0.9.2",
25
25
  "express": "^4.17.1",
26
- "juxtapose": "^4.0.96",
26
+ "juxtapose": "^4.0.98",
27
27
  "lively-cli": "^2.0.65",
28
28
  "watchful-cli": "^1.7.56"
29
29
  },
@@ -1,6 +1,10 @@
1
1
  "use strict";
2
2
 
3
+ export const CSS_CUSTOM_EVENT_TYPE = "css";
4
+ export const HTML_CUSTOM_EVENT_TYPE = "html";
3
5
  export const KEY_UP_CUSTOM_EVENT_TYPE = "key-up";
6
+ export const PREVIEW_CUSTOM_EVENT_TYPE = "preview";
4
7
  export const MARKDOWN_CUSTOM_EVENT_TYPE = "markdown";
8
+ export const PLAIN_TEXT_CUSTOM_EVENT_TYPE = "plain-text";
5
9
  export const PAGE_UPDATE_CUSTOM_EVENT_TYPE = "page-update";
6
10
  export const MARKDOWN_STYLE_CUSTOM_EVENT_TYPE = "markdown-style";
@@ -43,11 +43,7 @@ const INDEX_PATH = "index.md",
43
43
  INSTALLING_THE_CLI_PATH = "installing-the-cli.md",
44
44
  GETTING_TO_GRIPS_WITH_THE_IDE_PATH = "getting-to-grips-with-the-ide.md";
45
45
 
46
- export const defaultContent = `|asdfsdf|
47
- ------------
48
- |asdfsadf|`
49
-
50
- export const _defaultContent = `@ignore
46
+ export const defaultContent = `@ignore
51
47
 
52
48
  @include ${FRONT_MATTER_PATH}
53
49
  @include ${CONTENT_PATH}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ import TabButton from "../../button/tab";
4
+
5
+ export default class CSSTabButton extends TabButton {
6
+ childElements() {
7
+ return "CSS";
8
+ }
9
+
10
+ parentContext() {
11
+ const enableCSSTabButton = this.enable.bind(this), ///
12
+ disableCSSTabButton = this.disable.bind(this); ///
13
+
14
+ return ({
15
+ enableCSSTabButton,
16
+ disableCSSTabButton
17
+ });
18
+ }
19
+
20
+ static defaultProperties = {
21
+ className: "css"
22
+ }
23
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ import TabButton from "../../button/tab";
4
+
5
+ export default class HTMLTabButton extends TabButton {
6
+ childElements() {
7
+ return "HTML";
8
+ }
9
+
10
+ parentContext() {
11
+ const enableHTMLTabButton = this.enable.bind(this), ///
12
+ disableHTMLTabButton = this.disable.bind(this); ///
13
+
14
+ return ({
15
+ enableHTMLTabButton,
16
+ disableHTMLTabButton
17
+ });
18
+ }
19
+
20
+ static defaultProperties = {
21
+ className: "html"
22
+ }
23
+ }
@@ -1,10 +1,8 @@
1
1
  "use strict";
2
2
 
3
- import withStyle from "easy-with-style"; ///
4
-
5
3
  import TabButton from "../../button/tab";
6
4
 
7
- class MarkdownTabButton extends TabButton {
5
+ export default class MarkdownTabButton extends TabButton {
8
6
  childElements() {
9
7
  return "Markdown";
10
8
  }
@@ -23,15 +21,3 @@ class MarkdownTabButton extends TabButton {
23
21
  className: "markdown"
24
22
  }
25
23
  }
26
-
27
- export default withStyle(MarkdownTabButton)`
28
-
29
- border-right-width: 0;
30
-
31
- border-left-width: 1px;
32
-
33
- :enabled {
34
- border-left-width: 0;
35
- }
36
-
37
- `;
@@ -1,10 +1,8 @@
1
1
  "use strict";
2
2
 
3
- import withStyle from "easy-with-style"; ///
4
-
5
3
  import TabButton from "../../button/tab";
6
4
 
7
- class MarkdownStyleTabButton extends TabButton {
5
+ export default class MarkdownStyleTabButton extends TabButton {
8
6
  childElements() {
9
7
  return "Markdown style";
10
8
  }
@@ -23,13 +21,3 @@ class MarkdownStyleTabButton extends TabButton {
23
21
  className: "markdown-style"
24
22
  }
25
23
  }
26
-
27
- export default withStyle(MarkdownStyleTabButton)`
28
-
29
- border-right-width: 1px;
30
-
31
- :enabled {
32
- border-right-width: 0;
33
- }
34
-
35
- `;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ import TabButton from "../../button/tab";
4
+
5
+ export default class PlainTextTabButton extends TabButton {
6
+ childElements() {
7
+ return "PlainText";
8
+ }
9
+
10
+ parentContext() {
11
+ const enablePlainTextTabButton = this.enable.bind(this), ///
12
+ disablePlainTextTabButton = this.disable.bind(this); ///
13
+
14
+ return ({
15
+ enablePlainTextTabButton,
16
+ disablePlainTextTabButton
17
+ });
18
+ }
19
+
20
+ static defaultProperties = {
21
+ className: "plainText"
22
+ }
23
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ import TabButton from "../../button/tab";
4
+
5
+ export default class PreviewTabButton extends TabButton {
6
+ childElements() {
7
+ return "Preview";
8
+ }
9
+
10
+ parentContext() {
11
+ const enablePreviewTabButton = this.enable.bind(this), ///
12
+ disablePreviewTabButton = this.disable.bind(this); ///
13
+
14
+ return ({
15
+ enablePreviewTabButton,
16
+ disablePreviewTabButton
17
+ });
18
+ }
19
+
20
+ static defaultProperties = {
21
+ className: "preview"
22
+ }
23
+ }
@@ -14,20 +14,19 @@ export default withStyle(TabButton)`
14
14
 
15
15
  color: black;
16
16
  cursor: pointer;
17
- border: 1px solid black;
18
17
  padding: 1rem;
19
18
  font-size: 2rem;
20
19
  background: transparent;
21
20
  font-family: serif;
22
21
 
22
+ border: 1px solid black;
23
23
  font-weight: bold;
24
- border-top-width: 1px;
25
- border-bottom-width: 0;
24
+ border-bottom: 0;
26
25
 
27
26
  :enabled {
27
+ border: 0;
28
28
  font-weight: normal;
29
- border-top-width: 0;
30
- border-bottom-width: 1px;
29
+ border-bottom: 1px solid black;
31
30
  }
32
31
 
33
32
  `;