highmark-markdown 1.2.104 → 1.2.105

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.
@@ -12,7 +12,6 @@ const _easywithstyle = /*#__PURE__*/ _interop_require_default(require("easy-with
12
12
  const _easy = require("easy");
13
13
  const _index = require("../index");
14
14
  const _easylayout = require("easy-layout");
15
- const _Downloads = /*#__PURE__*/ _interop_require_default(require("./view/div/Downloads"));
16
15
  const _indexOptions = /*#__PURE__*/ _interop_require_default(require("./indexOptions"));
17
16
  const _pageButtons = /*#__PURE__*/ _interop_require_default(require("./view/div/pageButtons"));
18
17
  const _left = /*#__PURE__*/ _interop_require_default(require("./view/div/sizeable/left"));
@@ -120,8 +119,7 @@ class View extends _easy.Element {
120
119
  const divisionHTMLNOdeParseTree = divisionHTMLNode.asParseTree(), htmlParseTree = divisionHTMLNOdeParseTree, divisionHTMLNodes = topmostHTMLNode.getDivisionHTMLNodes(), length = divisionHTMLNodes.length; ///
121
120
  context = {
122
121
  tokens,
123
- pathToURL,
124
- JSXElements
122
+ pathToURL
125
123
  };
126
124
  this.updatePreviewDiv(divisionHTMLNode, context);
127
125
  this.updatePlainTextTextarea(divisionHTMLNode, context);
@@ -286,7 +284,7 @@ class View extends _easy.Element {
286
284
  this.setMarkdownStyle(markdownStyle);
287
285
  this.setMarkdown(markdown);
288
286
  }
289
- static initialMarkdown = _importer.initialMarkdown;
287
+ static initialMarkdown = `<DownloadsDiv/>`;
290
288
  static initialMarkdownStyle = "";
291
289
  static tagName = "div";
292
290
  static ignoredProperties = [
@@ -301,12 +299,9 @@ const _default = (0, _easywithstyle.default)(View)`
301
299
  padding: 1rem;
302
300
 
303
301
  `;
304
- const JSXElements = [
305
- _Downloads.default
306
- ];
307
302
  function pathToURL(path) {
308
303
  const url = `https://djalbat.com/${path}`;
309
304
  return url;
310
305
  }
311
306
 
312
- //# 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 DownloadsDiv from \"./view/div/Downloads\";\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 { 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      JSXElements\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          tokens = markdownStyleTokens, ///\n          context = {\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.html();\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\nconst JSXElements = [\n  DownloadsDiv\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","JSXElements","updatePreviewDiv","updatePlainTextTextarea","updateHTMLParseTreeTextarea","updatePageButtonsDiv","options","indexOptions","updateXMP","getMarkdownStyleTokens","markdownStyleElement","getMarkdownStyleElement","getDocumentMarkdownStyleNode","EMPTY_STRING","setCSS","clearCSSParseTreeTextarea","clearCSS","topmostCSSNode","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","DownloadsDiv","path","url"],"mappings":"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"}
307
+ //# 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 { 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          tokens = markdownStyleTokens, ///\n          context = {\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.html();\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 = `<DownloadsDiv/>`;\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","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":"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"}
@@ -67,46 +67,51 @@ class XMLElementHTMLNode extends _html.default {
67
67
  return selfClosingTag;
68
68
  }
69
69
  createDOMElement(context) {
70
- let domElement = null;
71
- const jsx = this.isJSX(context);
72
- if (jsx) {
73
- const jsxDOMElement = this.createJSXDomElement(context);
70
+ let domElement;
71
+ const jsxDOMElement = this.createJSXDOMElement(context);
72
+ if (jsxDOMElement !== null) {
74
73
  domElement = jsxDOMElement; ///
75
74
  } else {
76
- const tagName = this.tagName(context);
77
- domElement = document.createElement(tagName);
78
- const attributeNames = this.attributeNames(context), attributeValues = this.attributeValues(context);
79
- attributeNames.forEach((attributeName, index)=>{
80
- const attributeValue = attributeValues[index];
81
- domElement.setAttribute(attributeName, attributeValue);
82
- });
75
+ const nativeDOMElement = this.createNativeDOMElement(context);
76
+ domElement = nativeDOMElement; ///
83
77
  }
84
78
  return domElement;
85
79
  }
86
- createJSXDomElement(context) {
80
+ createJSXDOMElement(context) {
87
81
  let jsxDOMElement = null;
88
- const { JSXElements = [] } = context, tagName = this.tagName(context), JSXElement = JSXElements.find((JSXElement)=>{
89
- const { defaultProperties = {} } = JSXElement, { name } = defaultProperties, nameTagName = name === tagName;
90
- if (nameTagName) {
91
- return true;
82
+ const jsx = this.isJSX(context);
83
+ if (jsx) {
84
+ const tagName = this.tagName(context), JSXElement = (0, _jsx.findJSXElement)(tagName, context);
85
+ if (JSXElement !== null) {
86
+ const properties = this.properties(context), jsxElement = /*#__PURE__*/ React.createElement(JSXElement, properties), domElement = jsxElement.getDOMElement();
87
+ jsxDOMElement = domElement; ///
92
88
  }
93
- }) || null;
94
- if (JSXElement !== null) {
95
- const properties = this.properties(context), jsxElement = /*#__PURE__*/ React.createElement(JSXElement, properties), domElement = jsxElement.getDOMElement();
96
- jsxDOMElement = domElement; ///
97
89
  }
98
90
  return jsxDOMElement;
99
91
  }
92
+ createNativeDOMElement(context) {
93
+ let nativeDOMElement;
94
+ const tagName = this.tagName(context);
95
+ nativeDOMElement = document.createElement(tagName);
96
+ const attributeNames = this.attributeNames(context), attributeValues = this.attributeValues(context);
97
+ attributeNames.forEach((attributeName, index)=>{
98
+ const attributeValue = attributeValues[index];
99
+ nativeDOMElement.setAttribute(attributeName, attributeValue);
100
+ });
101
+ return nativeDOMElement;
102
+ }
100
103
  mount(parentDOMElement, siblingDOMElement, context) {
101
104
  siblingDOMElement = super.mount(parentDOMElement, siblingDOMElement, context);
102
- if (this.domElement !== null) {
103
- (0, _jsx.mountElement)(this.domElement);
105
+ const jsxElement = this.domElement.__element__; ///
106
+ if (jsxElement) {
107
+ (0, _jsx.mountJSXElement)(jsxElement);
104
108
  }
105
109
  return siblingDOMElement;
106
110
  }
107
111
  unmount(parentDOMElement) {
108
- if (this.domElement !== null) {
109
- (0, _jsx.unmountElement)(this.domElement);
112
+ const jsxElement = this.domElement.__element__; ///
113
+ if (jsxElement) {
114
+ (0, _jsx.unmountJSXElement)(jsxElement);
110
115
  }
111
116
  super.unmount(parentDOMElement);
112
117
  }
@@ -118,4 +123,4 @@ class XMLElementHTMLNode extends _html.default {
118
123
  }
119
124
  }
120
125
 
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/node/html/xmlElement.js"],"sourcesContent":["\"use strict\";\n\nimport HTMLNode from \"../../node/html\";\n\nimport { EMPTY_STRING } from \"../../constants\";\nimport { mountElement, unmountElement } from \"../../utilities/jsx\";\n\nconst jsxNameRegularExpression = /^[A-Z]/;\n\nexport default class XMLElementHTMLNode extends HTMLNode {\n  isJSX(context) {\n    const tagName = this.tagName(context),\n          tagNameJSXName = jsxNameRegularExpression.test(tagName),\n          jsx = tagNameJSXName; ///\n\n    return jsx;\n  }\n\n  tagName(context) {\n    const markdownNode = this.getMarkdownNode(),\n          tagName = markdownNode.tagName(context);\n\n    return tagName;\n  }\n\n  properties(context) {\n    const markdownNode = this.getMarkdownNode(),\n          properties = markdownNode.properties(context);\n\n    return properties;\n  }\n\n  attributeNames(context) {\n    const markdownNode = this.getMarkdownNode(),\n      attributeNames = markdownNode.attributeNames(context);\n\n    return attributeNames;\n  }\n\n  attributeValues(context) {\n    const markdownNode = this.getMarkdownNode(),\n          attributeValues = markdownNode.attributeValues(context);\n\n    return attributeValues;\n  }\n\n  startingTag(context) {\n    let startingTag = EMPTY_STRING;\n\n    const tagName = this.tagName(context);\n\n    startingTag = `${startingTag}<${tagName}`;\n\n    const attributeNames = this.attributeNames(context),\n          attributeValues = this.attributeValues(context);\n\n    attributeNames.forEach((attributeName, index) => {\n      const attributeValue = attributeValues[index];\n\n      startingTag = `${startingTag} ${attributeName}=\"${attributeValue}\"`;\n    });\n\n    startingTag = `${startingTag}/>`;\n\n    return startingTag;\n  }\n\n  closingTag(context) {\n    const tagName = this.tagName(context),\n          closingTag = `</${tagName}>`;\n\n    return closingTag;\n  }\n\n  selfClosingTag(context) {\n    let selfClosingTag = EMPTY_STRING;\n\n    const tagName = this.tagName(context);\n\n    selfClosingTag = `${selfClosingTag}<${tagName}`;\n\n    const attributeNames = this.attributeNames(context),\n          attributeValues = this.attributeValues(context);\n\n    attributeNames.forEach((attributeName, index) => {\n      const attributeValue = attributeValues[index];\n\n      selfClosingTag = `${selfClosingTag} ${attributeName}=\"${attributeValue}\"`;\n\n    });\n\n    selfClosingTag = `${selfClosingTag}/>`;\n\n    return selfClosingTag;\n  }\n\n  createDOMElement(context) {\n    let domElement = null;\n\n    const jsx = this.isJSX(context);\n\n    if (jsx) {\n      const jsxDOMElement = this.createJSXDomElement(context);\n\n      domElement = jsxDOMElement; ///\n    } else {\n      const tagName = this.tagName(context);\n\n      domElement = document.createElement(tagName);\n\n      const attributeNames = this.attributeNames(context),\n            attributeValues = this.attributeValues(context);\n\n      attributeNames.forEach((attributeName, index) => {\n        const attributeValue = attributeValues[index];\n\n        domElement.setAttribute(attributeName, attributeValue);\n      });\n    }\n\n    return domElement;\n  }\n\n  createJSXDomElement(context) {\n    let jsxDOMElement = null;\n\n    const { JSXElements = [] } = context,\n          tagName = this.tagName(context),\n          JSXElement = JSXElements.find((JSXElement) => {\n            const { defaultProperties = {} } = JSXElement,\n                  { name } = defaultProperties,\n                  nameTagName = (name === tagName);\n\n            if (nameTagName) {\n              return true;\n            }\n          }) || null;\n\n    if (JSXElement !== null) {\n      const properties = this.properties(context),\n            jsxElement =\n\n              <JSXElement {...properties} />\n\n            ,\n            domElement = jsxElement.getDOMElement();\n\n      jsxDOMElement = domElement; ///\n    }\n\n    return jsxDOMElement;\n  }\n\n  mount(parentDOMElement, siblingDOMElement, context) {\n    siblingDOMElement = super.mount(parentDOMElement, siblingDOMElement, context);\n\n    if (this.domElement !== null) {\n      mountElement(this.domElement);\n    }\n\n    return siblingDOMElement;\n  }\n\n  unmount(parentDOMElement) {\n    if (this.domElement !== null) {\n      unmountElement(this.domElement);\n    }\n\n    super.unmount(parentDOMElement);\n  }\n\n  static fromNothing(Class) { return HTMLNode.fromNothing(Class); }\n\n  static fromOuterNode(Class, outerNode) { return HTMLNode.fromOuterNode(Class, outerNode); }\n}\n"],"names":["XMLElementHTMLNode","jsxNameRegularExpression","HTMLNode","isJSX","context","tagName","tagNameJSXName","test","jsx","markdownNode","getMarkdownNode","properties","attributeNames","attributeValues","startingTag","EMPTY_STRING","forEach","attributeName","index","attributeValue","closingTag","selfClosingTag","createDOMElement","domElement","jsxDOMElement","createJSXDomElement","document","createElement","setAttribute","JSXElements","JSXElement","find","defaultProperties","name","nameTagName","jsxElement","getDOMElement","mount","parentDOMElement","siblingDOMElement","mountElement","unmount","unmountElement","fromNothing","Class","fromOuterNode","outerNode"],"mappings":"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"}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/node/html/xmlElement.js"],"sourcesContent":["\"use strict\";\n\nimport HTMLNode from \"../../node/html\";\n\nimport { EMPTY_STRING } from \"../../constants\";\nimport { findJSXElement, mountJSXElement, unmountJSXElement } from \"../../utilities/jsx\";\n\nconst jsxNameRegularExpression = /^[A-Z]/;\n\nexport default class XMLElementHTMLNode extends HTMLNode {\n  isJSX(context) {\n    const tagName = this.tagName(context),\n          tagNameJSXName = jsxNameRegularExpression.test(tagName),\n          jsx = tagNameJSXName; ///\n\n    return jsx;\n  }\n\n  tagName(context) {\n    const markdownNode = this.getMarkdownNode(),\n          tagName = markdownNode.tagName(context);\n\n    return tagName;\n  }\n\n  properties(context) {\n    const markdownNode = this.getMarkdownNode(),\n          properties = markdownNode.properties(context);\n\n    return properties;\n  }\n\n  attributeNames(context) {\n    const markdownNode = this.getMarkdownNode(),\n      attributeNames = markdownNode.attributeNames(context);\n\n    return attributeNames;\n  }\n\n  attributeValues(context) {\n    const markdownNode = this.getMarkdownNode(),\n          attributeValues = markdownNode.attributeValues(context);\n\n    return attributeValues;\n  }\n\n  startingTag(context) {\n    let startingTag = EMPTY_STRING;\n\n    const tagName = this.tagName(context);\n\n    startingTag = `${startingTag}<${tagName}`;\n\n    const attributeNames = this.attributeNames(context),\n          attributeValues = this.attributeValues(context);\n\n    attributeNames.forEach((attributeName, index) => {\n      const attributeValue = attributeValues[index];\n\n      startingTag = `${startingTag} ${attributeName}=\"${attributeValue}\"`;\n    });\n\n    startingTag = `${startingTag}/>`;\n\n    return startingTag;\n  }\n\n  closingTag(context) {\n    const tagName = this.tagName(context),\n          closingTag = `</${tagName}>`;\n\n    return closingTag;\n  }\n\n  selfClosingTag(context) {\n    let selfClosingTag = EMPTY_STRING;\n\n    const tagName = this.tagName(context);\n\n    selfClosingTag = `${selfClosingTag}<${tagName}`;\n\n    const attributeNames = this.attributeNames(context),\n          attributeValues = this.attributeValues(context);\n\n    attributeNames.forEach((attributeName, index) => {\n      const attributeValue = attributeValues[index];\n\n      selfClosingTag = `${selfClosingTag} ${attributeName}=\"${attributeValue}\"`;\n\n    });\n\n    selfClosingTag = `${selfClosingTag}/>`;\n\n    return selfClosingTag;\n  }\n\n  createDOMElement(context) {\n    let domElement;\n\n    const jsxDOMElement = this.createJSXDOMElement(context);\n\n    if (jsxDOMElement !== null) {\n      domElement = jsxDOMElement; ///\n    } else {\n      const nativeDOMElement = this.createNativeDOMElement(context);\n\n      domElement = nativeDOMElement;  ///\n    }\n\n    return domElement;\n  }\n\n  createJSXDOMElement(context) {\n    let jsxDOMElement = null;\n\n    const jsx = this.isJSX(context);\n\n    if (jsx) {\n      const tagName = this.tagName(context),\n            JSXElement = findJSXElement(tagName, context);\n\n      if (JSXElement !== null) {\n        const properties = this.properties(context),\n              jsxElement =\n\n                <JSXElement {...properties} />\n\n              ,\n              domElement = jsxElement.getDOMElement();\n\n        jsxDOMElement = domElement; ///\n      }\n    }\n\n    return jsxDOMElement;\n  }\n\n  createNativeDOMElement(context) {\n    let nativeDOMElement;\n\n    const tagName = this.tagName(context);\n\n    nativeDOMElement = document.createElement(tagName);\n\n    const attributeNames = this.attributeNames(context),\n          attributeValues = this.attributeValues(context);\n\n    attributeNames.forEach((attributeName, index) => {\n      const attributeValue = attributeValues[index];\n\n      nativeDOMElement.setAttribute(attributeName, attributeValue);\n    });\n\n    return nativeDOMElement;\n  }\n\n  mount(parentDOMElement, siblingDOMElement, context) {\n    siblingDOMElement = super.mount(parentDOMElement, siblingDOMElement, context);\n\n    const jsxElement = this.domElement.__element__;  ///\n\n    if (jsxElement) { ///\n      mountJSXElement(jsxElement);\n    }\n\n    return siblingDOMElement;\n  }\n\n  unmount(parentDOMElement) {\n    const jsxElement = this.domElement.__element__;  ///\n\n    if (jsxElement) { ///\n      unmountJSXElement(jsxElement);\n    }\n\n    super.unmount(parentDOMElement);\n  }\n\n  static fromNothing(Class) { return HTMLNode.fromNothing(Class); }\n\n  static fromOuterNode(Class, outerNode) { return HTMLNode.fromOuterNode(Class, outerNode); }\n}\n"],"names":["XMLElementHTMLNode","jsxNameRegularExpression","HTMLNode","isJSX","context","tagName","tagNameJSXName","test","jsx","markdownNode","getMarkdownNode","properties","attributeNames","attributeValues","startingTag","EMPTY_STRING","forEach","attributeName","index","attributeValue","closingTag","selfClosingTag","createDOMElement","domElement","jsxDOMElement","createJSXDOMElement","nativeDOMElement","createNativeDOMElement","JSXElement","findJSXElement","jsxElement","getDOMElement","document","createElement","setAttribute","mount","parentDOMElement","siblingDOMElement","__element__","mountJSXElement","unmount","unmountJSXElement","fromNothing","Class","fromOuterNode","outerNode"],"mappings":"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"}
package/lib/node/html.js CHANGED
@@ -184,28 +184,24 @@ class HTMLNode extends _occamdom.Node {
184
184
  }
185
185
  mount(parentDOMElement, siblingDOMElement, context) {
186
186
  this.domElement = this.createDOMElement(context);
187
- if (this.domElement !== null) {
188
- siblingDOMElement !== null ? (0, _dom.insertAfter)(this.domElement, parentDOMElement, siblingDOMElement) : (0, _dom.insertBeforehand)(this.domElement, parentDOMElement);
189
- parentDOMElement = this.domElement; ///
190
- siblingDOMElement = null;
191
- this.childNodes.forEach((childNode)=>{
192
- siblingDOMElement = childNode.mount(parentDOMElement, siblingDOMElement, context);
193
- });
194
- siblingDOMElement = this.domElement; ///
195
- }
187
+ siblingDOMElement !== null ? (0, _dom.insertAfter)(this.domElement, parentDOMElement, siblingDOMElement) : (0, _dom.insertBeforehand)(this.domElement, parentDOMElement);
188
+ parentDOMElement = this.domElement; ///
189
+ siblingDOMElement = null;
190
+ this.childNodes.forEach((childNode)=>{
191
+ siblingDOMElement = childNode.mount(parentDOMElement, siblingDOMElement, context);
192
+ });
193
+ siblingDOMElement = this.domElement; ///
196
194
  return siblingDOMElement;
197
195
  }
198
196
  unmount(parentDOMElement) {
199
- if (this.domElement !== null) {
200
- {
201
- const parentDOMElement = this.domElement; ///
202
- this.childNodes.forEach((childNode)=>{
203
- childNode.unmount(parentDOMElement);
204
- });
205
- }
206
- (0, _dom.remove)(this.domElement, parentDOMElement);
207
- this.domElement = null;
197
+ {
198
+ const parentDOMElement = this.domElement; ///
199
+ this.childNodes.forEach((childNode)=>{
200
+ childNode.unmount(parentDOMElement);
201
+ });
208
202
  }
203
+ (0, _dom.remove)(this.domElement, parentDOMElement);
204
+ this.domElement = null;
209
205
  }
210
206
  asHTML(indent, context) {
211
207
  if (context === undefined) {
@@ -283,4 +279,4 @@ ${childNodePlainText}`;
283
279
  Object.assign(HTMLNode.prototype, _node.default);
284
280
  const _default = HTMLNode;
285
281
 
286
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/html.js"],"sourcesContent":["\"use strict\";\n\nimport { Node } from \"occam-dom\";\n\nimport nodeMixins from \"../mixins/node\";\n\nimport { EMPTY_STRING, DOUBLE_SPACE } from \"../constants\";\nimport { remove, insertAfter, insertBeforehand } from \"../utilities/dom\";\n\nclass HTMLNode extends Node {\n  constructor(outerNode, parentNode, childNodes, domElement) {\n    super(outerNode, parentNode, childNodes);\n\n    this.domElement = domElement;\n  }\n\n  getDOMElement() {\n    return this.domElement;\n  }\n\n  setDOMElement(domElement) {\n    this.domElement = domElement;\n  }\n\n  resetDOMElement() {\n    this.domElement = null;\n  }\n\n  getRuleName() {\n    const markdownNode = this.getMarkdownNode(),\n          ruleName = markdownNode.getRuleName();\n\n    return ruleName;\n  }\n\n  isTerminalNode() {\n    const terminalNode = false;\n\n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = true;\n\n    return nonTerminalNode;\n  }\n\n  getMarkdownNode() {\n    const outerNode = this.getOuterNode(),\n          markdownNode = outerNode; ///\n\n    return markdownNode;\n  }\n\n  getParentHTMLNode() {\n    const parentNode = this.getParentNode(),\n          parentHTMLNode = parentNode;  ///\n\n    return parentHTMLNode;\n  }\n\n  getChildHTMLNodes() {\n    const childNodes = this.getChildNodes(),\n          childHTMLNodes = childNodes;  ///\n\n    return childHTMLNodes;\n  }\n\n  getAncestorHTMLNodes() {\n    const ancestorNodes = this.getAncestorNodes(),\n          ancestorHTMLNodes = ancestorNodes;  ///\n\n    return ancestorHTMLNodes;\n  }\n\n  reduceChildHTMLNode(callback, initialValue) { return this.reduceChildNode(callback, initialValue); }\n\n  someAncestorHTMLNode(callback) { return this.someAncestorNode(callback); }\n\n  someChildHTMLNode(callback) { return this.someChildNode(callback); }\n\n  retrieveHTMLNode(callback) {\n    let htmlNode = null;\n\n    if (htmlNode === null) {\n      const childHTMLNodes = this.getChildHTMLNodes();\n\n      childHTMLNodes.some((childHTMLNode) => {\n        htmlNode = childHTMLNode.retrieveHTMLNode(callback);\n\n        if (htmlNode !== null) {\n          return true;\n        }\n      });\n    }\n\n    if (htmlNode === null) {\n      htmlNode = this;\n\n      const result = callback(htmlNode);\n\n      if (!result) {\n        htmlNode = null;\n      }\n    }\n\n    return htmlNode;\n  }\n\n  removeChildHTMLNodes(removedChildHTMLNodes = null) {\n    let childHTMLNodes;\n\n    childHTMLNodes = this.getChildHTMLNodes();\n\n    if (removedChildHTMLNodes !== null) {\n      childHTMLNodes = childHTMLNodes.filter((childHTMLNode) => { ///\n        const markdownNode = childHTMLNode.getMarkdownNode(),\n              index = removedChildHTMLNodes.findIndex((removedChildHTMLNode) => {\n                const markdownNodeMatches = removedChildHTMLNode.matchMarkdownNode(markdownNode);\n\n                if (markdownNodeMatches) {\n                  return true;\n                }\n              });\n\n        if (index !== -1) {\n          return true;\n        }\n      });\n    }\n\n    let removedChildNodes = childHTMLNodes;  ///\n\n    removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n    removedChildHTMLNodes = removedChildNodes;  ///\n\n    return removedChildHTMLNodes;\n  }\n\n  matchMarkdownNode(markdownNode) {\n    const outerNode = markdownNode, ///\n          outerNodeMatches = this.matchOuterNode(outerNode),\n          markdownNodeMatches = outerNodeMatches; ///\n\n    return markdownNodeMatches;\n  }\n\n  addChildHTMLNodes(addedChildHTMLNodes, startHTNLIndex) {\n    const addedChildNodes = addedChildHTMLNodes,  ///\n          startIndex = startHTNLIndex;  ///\n\n    this.addChildNodes(addedChildNodes, startIndex);\n  }\n\n  adjustIndent(indent) {\n    if (indent !== null) {\n      indent = `${DOUBLE_SPACE}${indent}`;\n    }\n\n    return indent;\n  }\n\n  lines(context) {\n    let lines;\n\n    ({ lines = null } = this.constructor);\n\n    if (lines === null) {\n      lines = this.reduceChildNode((lines, childNode) => {\n        const childNodeLines = childNode.lines(context);\n\n        lines += childNodeLines;\n\n        return lines;\n      }, 0);\n    }\n\n    return lines;\n  }\n\n  tagName(context) {\n    const { tagName } = this.constructor;\n\n    return tagName;\n  }\n\n  depth() {\n    const { depth = null } = this.constructor;\n\n    return depth;\n  }\n\n  className(context) {\n    const { className } = this.constructor;\n\n    return className;\n  }\n\n  closingTag(context) {\n    const tagName = this.tagName(context),\n          closingTag = `</${tagName}>`;\n\n    return closingTag;\n  }\n\n  startingTag(context) {\n    const tagName = this.tagName(context),\n          className = this.className(context),\n          attributeName = this.attributeName(context),\n          attributeValue = this.attributeValue(context),\n          classHTML = (className !== null) ?\n                       ` class=\"${className}\"` :\n                          EMPTY_STRING,\n          attributeHTML = ((attributeName !== null) && (attributeValue !== null)) ?\n                           ` ${attributeName}=\"${attributeValue}\"` :\n                              EMPTY_STRING,\n          startingTag = `<${tagName}${classHTML}${attributeHTML}>`;\n\n    return startingTag;\n  }\n\n  selfClosingTag(context) {\n    const tagName = this.tagName(context),\n          selfClosingTag = `<${tagName}/>`;\n\n    return selfClosingTag;\n  }\n\n  attributeName(context) {\n    const attributeName = null;\n\n    return attributeName;\n  }\n\n  attributeValue(context) {\n    const attributeValue = null;\n\n    return attributeValue;\n  }\n\n  createDOMElement(context) {\n    let domElement;\n\n    const tagName = this.tagName(context);\n\n    domElement = document.createElement(tagName);\n\n    const className = this.className(context),\n          attributeName = this.attributeName(context),\n          attributeValue = this.attributeValue(context);\n\n    if (className !== null) {\n      Object.assign(domElement, {\n        className\n      });\n    }\n\n    if ((attributeName !== null) && (attributeValue !== null)) {\n      domElement.setAttribute(attributeName, attributeValue);\n    }\n\n    return domElement;\n  }\n\n  mount(parentDOMElement, siblingDOMElement, context) {\n    this.domElement = this.createDOMElement(context);\n\n    if (this.domElement !== null) {\n      (siblingDOMElement !== null) ?\n        insertAfter(this.domElement, parentDOMElement, siblingDOMElement) :\n          insertBeforehand(this.domElement, parentDOMElement);\n\n      parentDOMElement = this.domElement; ///\n\n      siblingDOMElement = null;\n\n      this.childNodes.forEach((childNode) => {\n        siblingDOMElement = childNode.mount(parentDOMElement, siblingDOMElement, context);\n      });\n\n      siblingDOMElement = this.domElement;  ///\n    }\n\n    return siblingDOMElement;\n  }\n\n  unmount(parentDOMElement) {\n    if (this.domElement !== null) {\n      {\n        const parentDOMElement = this.domElement; ///\n\n        this.childNodes.forEach((childNode) => {\n          childNode.unmount(parentDOMElement);\n        });\n      }\n\n      remove(this.domElement, parentDOMElement);\n\n      this.domElement = null;\n    }\n  }\n\n  asHTML(indent, context) {\n    if (context === undefined) {\n      context = indent; ///\n\n      indent = EMPTY_STRING;\n    }\n\n    let html;\n\n    indent = this.adjustIndent(indent);\n\n    const className = this.className(context),\n          attributeName = this.attributeName(context),\n          childNodesHTML = this.childNodesAsHTML(indent, context);\n\n    if ((childNodesHTML !== EMPTY_STRING) || (className !== null) || (attributeName !== null)) {\n      const startingTag = this.startingTag(context),\n            closingTag = this.closingTag(context);\n\n      html = (indent === null) ?\n               `${startingTag}${childNodesHTML}${closingTag}` :\n                 `${indent}${startingTag}\n${childNodesHTML}${indent}${closingTag}\n`;\n    } else {\n      const selfClosingTag = this.selfClosingTag(context);\n\n      html = (indent === null) ?\n               `${selfClosingTag}` :\n                 `${indent}${selfClosingTag}\n`;\n    }\n\n    return html;\n  }\n\n  asPlainText(context) {\n    const childNodesPlainText = this.childNodesAsPlainText(context),\n          plainText = childNodesPlainText;  ///\n\n    return plainText;\n  }\n\n  childNodesAsHTML(indent, context) {\n    const childNodesHTML = this.reduceChildNode((childNodesHTML, childNode) => {\n      const childNodeHTML = childNode.asHTML(indent, context);\n\n      childNodesHTML = `${childNodesHTML}${childNodeHTML}`;\n\n      return childNodesHTML;\n    }, EMPTY_STRING);\n\n    return childNodesHTML;\n  }\n\n  childNodesAsPlainText(context) {\n    const childNodesPlainText = this.reduceChildNode((childNodesPlainText, childNode) => {\n      const childNodePlainText = childNode.asPlainText(context);\n\n      childNodesPlainText = `${childNodesPlainText}\n${childNodePlainText}`;\n\n      return childNodesPlainText;\n    }, EMPTY_STRING);\n\n    return childNodesPlainText;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = HTMLNode; ///\n    }\n\n    const domElement = null,\n          htmlNode = Node.fromNothing(Class, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n\n  static fromOuterNode(Class, outerNode, ...remainingArguments) {\n    if (outerNode === undefined) {\n      outerNode = Class;  ///\n\n      Class = HTMLNode; ///\n    }\n\n    const domElement = null,\n          htmlNode = Node.fromOuterNode(Class, outerNode, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n\n  static fromDOMElement(Class, domElement, ...remainingArguments) {\n    if (domElement === undefined) {\n      domElement = Class; ///\n\n      Class = HTMLNode; ///\n    }\n\n    const htmlNode = Node.fromNothing(Class, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n\n  static fromChildHTMLNodes(Class, childHTMLNodes, ...remainingArguments) {\n    if (childHTMLNodes === undefined) {\n      childHTMLNodes = Class;  ///\n\n      Class = HTMLNode; ///\n    }\n\n    const childNodes = childHTMLNodes,  ///\n          domElement = null,\n          htmlNode = Node.fromChildNodes(Class, childNodes, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n}\n\nObject.assign(HTMLNode.prototype, nodeMixins);\n\nexport default HTMLNode;\n"],"names":["HTMLNode","Node","outerNode","parentNode","childNodes","domElement","getDOMElement","setDOMElement","resetDOMElement","getRuleName","markdownNode","getMarkdownNode","ruleName","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getOuterNode","getParentHTMLNode","getParentNode","parentHTMLNode","getChildHTMLNodes","getChildNodes","childHTMLNodes","getAncestorHTMLNodes","ancestorNodes","getAncestorNodes","ancestorHTMLNodes","reduceChildHTMLNode","callback","initialValue","reduceChildNode","someAncestorHTMLNode","someAncestorNode","someChildHTMLNode","someChildNode","retrieveHTMLNode","htmlNode","some","childHTMLNode","result","removeChildHTMLNodes","removedChildHTMLNodes","filter","index","findIndex","removedChildHTMLNode","markdownNodeMatches","matchMarkdownNode","removedChildNodes","removeChildNodes","outerNodeMatches","matchOuterNode","addChildHTMLNodes","addedChildHTMLNodes","startHTNLIndex","addedChildNodes","startIndex","addChildNodes","adjustIndent","indent","DOUBLE_SPACE","lines","context","childNode","childNodeLines","tagName","depth","className","closingTag","startingTag","attributeName","attributeValue","classHTML","EMPTY_STRING","attributeHTML","selfClosingTag","createDOMElement","document","createElement","Object","assign","setAttribute","mount","parentDOMElement","siblingDOMElement","insertAfter","insertBeforehand","forEach","unmount","remove","asHTML","undefined","html","childNodesHTML","childNodesAsHTML","asPlainText","childNodesPlainText","childNodesAsPlainText","plainText","childNodeHTML","childNodePlainText","fromNothing","Class","remainingArguments","fromOuterNode","fromDOMElement","fromChildHTMLNodes","fromChildNodes","prototype","nodeMixins"],"mappings":"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"}
282
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/html.js"],"sourcesContent":["\"use strict\";\n\nimport { Node } from \"occam-dom\";\n\nimport nodeMixins from \"../mixins/node\";\n\nimport { EMPTY_STRING, DOUBLE_SPACE } from \"../constants\";\nimport { remove, insertAfter, insertBeforehand } from \"../utilities/dom\";\n\nclass HTMLNode extends Node {\n  constructor(outerNode, parentNode, childNodes, domElement) {\n    super(outerNode, parentNode, childNodes);\n\n    this.domElement = domElement;\n  }\n\n  getDOMElement() {\n    return this.domElement;\n  }\n\n  setDOMElement(domElement) {\n    this.domElement = domElement;\n  }\n\n  resetDOMElement() {\n    this.domElement = null;\n  }\n\n  getRuleName() {\n    const markdownNode = this.getMarkdownNode(),\n          ruleName = markdownNode.getRuleName();\n\n    return ruleName;\n  }\n\n  isTerminalNode() {\n    const terminalNode = false;\n\n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = true;\n\n    return nonTerminalNode;\n  }\n\n  getMarkdownNode() {\n    const outerNode = this.getOuterNode(),\n          markdownNode = outerNode; ///\n\n    return markdownNode;\n  }\n\n  getParentHTMLNode() {\n    const parentNode = this.getParentNode(),\n          parentHTMLNode = parentNode;  ///\n\n    return parentHTMLNode;\n  }\n\n  getChildHTMLNodes() {\n    const childNodes = this.getChildNodes(),\n          childHTMLNodes = childNodes;  ///\n\n    return childHTMLNodes;\n  }\n\n  getAncestorHTMLNodes() {\n    const ancestorNodes = this.getAncestorNodes(),\n          ancestorHTMLNodes = ancestorNodes;  ///\n\n    return ancestorHTMLNodes;\n  }\n\n  reduceChildHTMLNode(callback, initialValue) { return this.reduceChildNode(callback, initialValue); }\n\n  someAncestorHTMLNode(callback) { return this.someAncestorNode(callback); }\n\n  someChildHTMLNode(callback) { return this.someChildNode(callback); }\n\n  retrieveHTMLNode(callback) {\n    let htmlNode = null;\n\n    if (htmlNode === null) {\n      const childHTMLNodes = this.getChildHTMLNodes();\n\n      childHTMLNodes.some((childHTMLNode) => {\n        htmlNode = childHTMLNode.retrieveHTMLNode(callback);\n\n        if (htmlNode !== null) {\n          return true;\n        }\n      });\n    }\n\n    if (htmlNode === null) {\n      htmlNode = this;\n\n      const result = callback(htmlNode);\n\n      if (!result) {\n        htmlNode = null;\n      }\n    }\n\n    return htmlNode;\n  }\n\n  removeChildHTMLNodes(removedChildHTMLNodes = null) {\n    let childHTMLNodes;\n\n    childHTMLNodes = this.getChildHTMLNodes();\n\n    if (removedChildHTMLNodes !== null) {\n      childHTMLNodes = childHTMLNodes.filter((childHTMLNode) => { ///\n        const markdownNode = childHTMLNode.getMarkdownNode(),\n              index = removedChildHTMLNodes.findIndex((removedChildHTMLNode) => {\n                const markdownNodeMatches = removedChildHTMLNode.matchMarkdownNode(markdownNode);\n\n                if (markdownNodeMatches) {\n                  return true;\n                }\n              });\n\n        if (index !== -1) {\n          return true;\n        }\n      });\n    }\n\n    let removedChildNodes = childHTMLNodes;  ///\n\n    removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n    removedChildHTMLNodes = removedChildNodes;  ///\n\n    return removedChildHTMLNodes;\n  }\n\n  matchMarkdownNode(markdownNode) {\n    const outerNode = markdownNode, ///\n          outerNodeMatches = this.matchOuterNode(outerNode),\n          markdownNodeMatches = outerNodeMatches; ///\n\n    return markdownNodeMatches;\n  }\n\n  addChildHTMLNodes(addedChildHTMLNodes, startHTNLIndex) {\n    const addedChildNodes = addedChildHTMLNodes,  ///\n          startIndex = startHTNLIndex;  ///\n\n    this.addChildNodes(addedChildNodes, startIndex);\n  }\n\n  adjustIndent(indent) {\n    if (indent !== null) {\n      indent = `${DOUBLE_SPACE}${indent}`;\n    }\n\n    return indent;\n  }\n\n  lines(context) {\n    let lines;\n\n    ({ lines = null } = this.constructor);\n\n    if (lines === null) {\n      lines = this.reduceChildNode((lines, childNode) => {\n        const childNodeLines = childNode.lines(context);\n\n        lines += childNodeLines;\n\n        return lines;\n      }, 0);\n    }\n\n    return lines;\n  }\n\n  tagName(context) {\n    const { tagName } = this.constructor;\n\n    return tagName;\n  }\n\n  depth() {\n    const { depth = null } = this.constructor;\n\n    return depth;\n  }\n\n  className(context) {\n    const { className } = this.constructor;\n\n    return className;\n  }\n\n  closingTag(context) {\n    const tagName = this.tagName(context),\n          closingTag = `</${tagName}>`;\n\n    return closingTag;\n  }\n\n  startingTag(context) {\n    const tagName = this.tagName(context),\n          className = this.className(context),\n          attributeName = this.attributeName(context),\n          attributeValue = this.attributeValue(context),\n          classHTML = (className !== null) ?\n                       ` class=\"${className}\"` :\n                          EMPTY_STRING,\n          attributeHTML = ((attributeName !== null) && (attributeValue !== null)) ?\n                           ` ${attributeName}=\"${attributeValue}\"` :\n                              EMPTY_STRING,\n          startingTag = `<${tagName}${classHTML}${attributeHTML}>`;\n\n    return startingTag;\n  }\n\n  selfClosingTag(context) {\n    const tagName = this.tagName(context),\n          selfClosingTag = `<${tagName}/>`;\n\n    return selfClosingTag;\n  }\n\n  attributeName(context) {\n    const attributeName = null;\n\n    return attributeName;\n  }\n\n  attributeValue(context) {\n    const attributeValue = null;\n\n    return attributeValue;\n  }\n\n  createDOMElement(context) {\n    let domElement;\n\n    const tagName = this.tagName(context);\n\n    domElement = document.createElement(tagName);\n\n    const className = this.className(context),\n          attributeName = this.attributeName(context),\n          attributeValue = this.attributeValue(context);\n\n    if (className !== null) {\n      Object.assign(domElement, {\n        className\n      });\n    }\n\n    if ((attributeName !== null) && (attributeValue !== null)) {\n      domElement.setAttribute(attributeName, attributeValue);\n    }\n\n    return domElement;\n  }\n\n  mount(parentDOMElement, siblingDOMElement, context) {\n    this.domElement = this.createDOMElement(context);\n\n    (siblingDOMElement !== null) ?\n      insertAfter(this.domElement, parentDOMElement, siblingDOMElement) :\n        insertBeforehand(this.domElement, parentDOMElement);\n\n    parentDOMElement = this.domElement; ///\n\n    siblingDOMElement = null;\n\n    this.childNodes.forEach((childNode) => {\n      siblingDOMElement = childNode.mount(parentDOMElement, siblingDOMElement, context);\n    });\n\n    siblingDOMElement = this.domElement;  ///\n\n    return siblingDOMElement;\n  }\n\n  unmount(parentDOMElement) {\n    {\n      const parentDOMElement = this.domElement; ///\n\n      this.childNodes.forEach((childNode) => {\n        childNode.unmount(parentDOMElement);\n      });\n    }\n\n    remove(this.domElement, parentDOMElement);\n\n    this.domElement = null;\n  }\n\n  asHTML(indent, context) {\n    if (context === undefined) {\n      context = indent; ///\n\n      indent = EMPTY_STRING;\n    }\n\n    let html;\n\n    indent = this.adjustIndent(indent);\n\n    const className = this.className(context),\n          attributeName = this.attributeName(context),\n          childNodesHTML = this.childNodesAsHTML(indent, context);\n\n    if ((childNodesHTML !== EMPTY_STRING) || (className !== null) || (attributeName !== null)) {\n      const startingTag = this.startingTag(context),\n            closingTag = this.closingTag(context);\n\n      html = (indent === null) ?\n               `${startingTag}${childNodesHTML}${closingTag}` :\n                 `${indent}${startingTag}\n${childNodesHTML}${indent}${closingTag}\n`;\n    } else {\n      const selfClosingTag = this.selfClosingTag(context);\n\n      html = (indent === null) ?\n               `${selfClosingTag}` :\n                 `${indent}${selfClosingTag}\n`;\n    }\n\n    return html;\n  }\n\n  asPlainText(context) {\n    const childNodesPlainText = this.childNodesAsPlainText(context),\n          plainText = childNodesPlainText;  ///\n\n    return plainText;\n  }\n\n  childNodesAsHTML(indent, context) {\n    const childNodesHTML = this.reduceChildNode((childNodesHTML, childNode) => {\n      const childNodeHTML = childNode.asHTML(indent, context);\n\n      childNodesHTML = `${childNodesHTML}${childNodeHTML}`;\n\n      return childNodesHTML;\n    }, EMPTY_STRING);\n\n    return childNodesHTML;\n  }\n\n  childNodesAsPlainText(context) {\n    const childNodesPlainText = this.reduceChildNode((childNodesPlainText, childNode) => {\n      const childNodePlainText = childNode.asPlainText(context);\n\n      childNodesPlainText = `${childNodesPlainText}\n${childNodePlainText}`;\n\n      return childNodesPlainText;\n    }, EMPTY_STRING);\n\n    return childNodesPlainText;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = HTMLNode; ///\n    }\n\n    const domElement = null,\n          htmlNode = Node.fromNothing(Class, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n\n  static fromOuterNode(Class, outerNode, ...remainingArguments) {\n    if (outerNode === undefined) {\n      outerNode = Class;  ///\n\n      Class = HTMLNode; ///\n    }\n\n    const domElement = null,\n          htmlNode = Node.fromOuterNode(Class, outerNode, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n\n  static fromDOMElement(Class, domElement, ...remainingArguments) {\n    if (domElement === undefined) {\n      domElement = Class; ///\n\n      Class = HTMLNode; ///\n    }\n\n    const htmlNode = Node.fromNothing(Class, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n\n  static fromChildHTMLNodes(Class, childHTMLNodes, ...remainingArguments) {\n    if (childHTMLNodes === undefined) {\n      childHTMLNodes = Class;  ///\n\n      Class = HTMLNode; ///\n    }\n\n    const childNodes = childHTMLNodes,  ///\n          domElement = null,\n          htmlNode = Node.fromChildNodes(Class, childNodes, domElement, ...remainingArguments);\n\n    return htmlNode;\n  }\n}\n\nObject.assign(HTMLNode.prototype, nodeMixins);\n\nexport default HTMLNode;\n"],"names":["HTMLNode","Node","outerNode","parentNode","childNodes","domElement","getDOMElement","setDOMElement","resetDOMElement","getRuleName","markdownNode","getMarkdownNode","ruleName","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getOuterNode","getParentHTMLNode","getParentNode","parentHTMLNode","getChildHTMLNodes","getChildNodes","childHTMLNodes","getAncestorHTMLNodes","ancestorNodes","getAncestorNodes","ancestorHTMLNodes","reduceChildHTMLNode","callback","initialValue","reduceChildNode","someAncestorHTMLNode","someAncestorNode","someChildHTMLNode","someChildNode","retrieveHTMLNode","htmlNode","some","childHTMLNode","result","removeChildHTMLNodes","removedChildHTMLNodes","filter","index","findIndex","removedChildHTMLNode","markdownNodeMatches","matchMarkdownNode","removedChildNodes","removeChildNodes","outerNodeMatches","matchOuterNode","addChildHTMLNodes","addedChildHTMLNodes","startHTNLIndex","addedChildNodes","startIndex","addChildNodes","adjustIndent","indent","DOUBLE_SPACE","lines","context","childNode","childNodeLines","tagName","depth","className","closingTag","startingTag","attributeName","attributeValue","classHTML","EMPTY_STRING","attributeHTML","selfClosingTag","createDOMElement","document","createElement","Object","assign","setAttribute","mount","parentDOMElement","siblingDOMElement","insertAfter","insertBeforehand","forEach","unmount","remove","asHTML","undefined","html","childNodesHTML","childNodesAsHTML","asPlainText","childNodesPlainText","childNodesAsPlainText","plainText","childNodeHTML","childNodePlainText","fromNothing","Class","remainingArguments","fromOuterNode","fromDOMElement","fromChildHTMLNodes","fromChildNodes","prototype","nodeMixins"],"mappings":"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"}
@@ -9,19 +9,27 @@ function _export(target, all) {
9
9
  });
10
10
  }
11
11
  _export(exports, {
12
- get mountElement () {
13
- return mountElement;
12
+ get findJSXElement () {
13
+ return findJSXElement;
14
14
  },
15
- get unmountElement () {
16
- return unmountElement;
15
+ get mountJSXElement () {
16
+ return mountJSXElement;
17
+ },
18
+ get unmountJSXElement () {
19
+ return unmountJSXElement;
17
20
  }
18
21
  });
19
- function mountElement(domElement) {
20
- const element = domElement.__element__;
21
- if (!element) {
22
- return;
23
- }
24
- const descendantElements = element.getDescendantElements(), elements = [
22
+ function findJSXElement(tagName, context) {
23
+ const { JSXElements = [] } = context, JSXElement = JSXElements.find((JSXElement)=>{
24
+ const { defaultProperties = {} } = JSXElement, { name } = defaultProperties, nameTagName = name === tagName;
25
+ if (nameTagName) {
26
+ return true;
27
+ }
28
+ }) || null;
29
+ return JSXElement;
30
+ }
31
+ function mountJSXElement(jsxElement) {
32
+ const element = jsxElement, descendantElements = element.getDescendantElements(), elements = [
25
33
  element,
26
34
  ...descendantElements
27
35
  ];
@@ -30,12 +38,8 @@ function mountElement(domElement) {
30
38
  element.didMount && element.didMount();
31
39
  });
32
40
  }
33
- function unmountElement(domElement) {
34
- const element = domElement.__element__;
35
- if (!element) {
36
- return;
37
- }
38
- const descendantElements = element.getDescendantElements(), elements = [
41
+ function unmountJSXElement(jsxElement) {
42
+ const element = jsxElement, descendantElements = element.getDescendantElements(), elements = [
39
43
  element,
40
44
  ...descendantElements
41
45
  ];
@@ -44,4 +48,4 @@ function unmountElement(domElement) {
44
48
  });
45
49
  }
46
50
 
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvanN4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5leHBvcnQgZnVuY3Rpb24gbW91bnRFbGVtZW50KGRvbUVsZW1lbnQpIHtcbiAgY29uc3QgZWxlbWVudCA9IGRvbUVsZW1lbnQuX19lbGVtZW50X187XG5cbiAgaWYgKCFlbGVtZW50KSB7IC8vL1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGRlc2NlbmRhbnRFbGVtZW50cyA9IGVsZW1lbnQuZ2V0RGVzY2VuZGFudEVsZW1lbnRzKCksXG4gICAgICAgIGVsZW1lbnRzID0gW1xuICAgICAgICAgIGVsZW1lbnQsXG4gICAgICAgICAgLi4uZGVzY2VuZGFudEVsZW1lbnRzXG4gICAgICAgIF07XG5cbiAgZWxlbWVudHMucmV2ZXJzZSgpOyAvLy9cblxuICBlbGVtZW50cy5mb3JFYWNoKChlbGVtZW50KSA9PiB7XG4gICAgZWxlbWVudC5kaWRNb3VudCAmJiBlbGVtZW50LmRpZE1vdW50KCk7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdW5tb3VudEVsZW1lbnQoZG9tRWxlbWVudCkge1xuICBjb25zdCBlbGVtZW50ID0gZG9tRWxlbWVudC5fX2VsZW1lbnRfXztcblxuICBpZiAoIWVsZW1lbnQpIHsgLy8vXG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgZGVzY2VuZGFudEVsZW1lbnRzID0gZWxlbWVudC5nZXREZXNjZW5kYW50RWxlbWVudHMoKSxcbiAgICAgICAgZWxlbWVudHMgPSBbXG4gICAgICAgICAgZWxlbWVudCxcbiAgICAgICAgICAuLi5kZXNjZW5kYW50RWxlbWVudHNcbiAgICAgICAgXTtcblxuICBlbGVtZW50cy5mb3JFYWNoKChlbGVtZW50KSA9PiB7XG4gICAgZWxlbWVudC53aWxsVW5tb3VudCAmJiBlbGVtZW50LndpbGxVbm1vdW50KCk7XG4gIH0pO1xufVxuIl0sIm5hbWVzIjpbIm1vdW50RWxlbWVudCIsInVubW91bnRFbGVtZW50IiwiZG9tRWxlbWVudCIsImVsZW1lbnQiLCJfX2VsZW1lbnRfXyIsImRlc2NlbmRhbnRFbGVtZW50cyIsImdldERlc2NlbmRhbnRFbGVtZW50cyIsImVsZW1lbnRzIiwicmV2ZXJzZSIsImZvckVhY2giLCJkaWRNb3VudCIsIndpbGxVbm1vdW50Il0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7UUFFZ0JBO2VBQUFBOztRQW9CQUM7ZUFBQUE7OztBQXBCVCxTQUFTRCxhQUFhRSxVQUFVO0lBQ3JDLE1BQU1DLFVBQVVELFdBQVdFLFdBQVc7SUFFdEMsSUFBSSxDQUFDRCxTQUFTO1FBQ1o7SUFDRjtJQUVBLE1BQU1FLHFCQUFxQkYsUUFBUUcscUJBQXFCLElBQ2xEQyxXQUFXO1FBQ1RKO1dBQ0dFO0tBQ0o7SUFFUEUsU0FBU0MsT0FBTyxJQUFJLEdBQUc7SUFFdkJELFNBQVNFLE9BQU8sQ0FBQyxDQUFDTjtRQUNoQkEsUUFBUU8sUUFBUSxJQUFJUCxRQUFRTyxRQUFRO0lBQ3RDO0FBQ0Y7QUFFTyxTQUFTVCxlQUFlQyxVQUFVO0lBQ3ZDLE1BQU1DLFVBQVVELFdBQVdFLFdBQVc7SUFFdEMsSUFBSSxDQUFDRCxTQUFTO1FBQ1o7SUFDRjtJQUVBLE1BQU1FLHFCQUFxQkYsUUFBUUcscUJBQXFCLElBQ2xEQyxXQUFXO1FBQ1RKO1dBQ0dFO0tBQ0o7SUFFUEUsU0FBU0UsT0FBTyxDQUFDLENBQUNOO1FBQ2hCQSxRQUFRUSxXQUFXLElBQUlSLFFBQVFRLFdBQVc7SUFDNUM7QUFDRiJ9
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvanN4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5leHBvcnQgZnVuY3Rpb24gZmluZEpTWEVsZW1lbnQodGFnTmFtZSwgY29udGV4dCkge1xuICBjb25zdCB7IEpTWEVsZW1lbnRzID0gW10gfSA9IGNvbnRleHQsXG4gICAgICAgIEpTWEVsZW1lbnQgPSBKU1hFbGVtZW50cy5maW5kKChKU1hFbGVtZW50KSA9PiB7XG4gICAgICAgICAgY29uc3QgeyBkZWZhdWx0UHJvcGVydGllcyA9IHt9IH0gPSBKU1hFbGVtZW50LFxuICAgICAgICAgICAgICAgIHsgbmFtZSB9ID0gZGVmYXVsdFByb3BlcnRpZXMsXG4gICAgICAgICAgICAgICAgbmFtZVRhZ05hbWUgPSAobmFtZSA9PT0gdGFnTmFtZSk7XG5cbiAgICAgICAgICBpZiAobmFtZVRhZ05hbWUpIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICAgIH1cbiAgICAgICAgfSkgfHwgbnVsbDtcblxuICByZXR1cm4gSlNYRWxlbWVudDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1vdW50SlNYRWxlbWVudChqc3hFbGVtZW50KSB7XG4gIGNvbnN0IGVsZW1lbnQgPSBqc3hFbGVtZW50LCAvLy9cbiAgICAgICAgZGVzY2VuZGFudEVsZW1lbnRzID0gZWxlbWVudC5nZXREZXNjZW5kYW50RWxlbWVudHMoKSxcbiAgICAgICAgZWxlbWVudHMgPSBbXG4gICAgICAgICAgZWxlbWVudCxcbiAgICAgICAgICAuLi5kZXNjZW5kYW50RWxlbWVudHNcbiAgICAgICAgXTtcblxuICBlbGVtZW50cy5yZXZlcnNlKCk7IC8vL1xuXG4gIGVsZW1lbnRzLmZvckVhY2goKGVsZW1lbnQpID0+IHtcbiAgICBlbGVtZW50LmRpZE1vdW50ICYmIGVsZW1lbnQuZGlkTW91bnQoKTtcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1bm1vdW50SlNYRWxlbWVudChqc3hFbGVtZW50KSB7XG4gIGNvbnN0IGVsZW1lbnQgPSBqc3hFbGVtZW50LCAvLy9cbiAgICAgICAgZGVzY2VuZGFudEVsZW1lbnRzID0gZWxlbWVudC5nZXREZXNjZW5kYW50RWxlbWVudHMoKSxcbiAgICAgICAgZWxlbWVudHMgPSBbXG4gICAgICAgICAgZWxlbWVudCxcbiAgICAgICAgICAuLi5kZXNjZW5kYW50RWxlbWVudHNcbiAgICAgICAgXTtcblxuICBlbGVtZW50cy5mb3JFYWNoKChlbGVtZW50KSA9PiB7XG4gICAgZWxlbWVudC53aWxsVW5tb3VudCAmJiBlbGVtZW50LndpbGxVbm1vdW50KCk7XG4gIH0pO1xufVxuIl0sIm5hbWVzIjpbImZpbmRKU1hFbGVtZW50IiwibW91bnRKU1hFbGVtZW50IiwidW5tb3VudEpTWEVsZW1lbnQiLCJ0YWdOYW1lIiwiY29udGV4dCIsIkpTWEVsZW1lbnRzIiwiSlNYRWxlbWVudCIsImZpbmQiLCJkZWZhdWx0UHJvcGVydGllcyIsIm5hbWUiLCJuYW1lVGFnTmFtZSIsImpzeEVsZW1lbnQiLCJlbGVtZW50IiwiZGVzY2VuZGFudEVsZW1lbnRzIiwiZ2V0RGVzY2VuZGFudEVsZW1lbnRzIiwiZWxlbWVudHMiLCJyZXZlcnNlIiwiZm9yRWFjaCIsImRpZE1vdW50Iiwid2lsbFVubW91bnQiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQUVnQkE7ZUFBQUE7O1FBZUFDO2VBQUFBOztRQWVBQztlQUFBQTs7O0FBOUJULFNBQVNGLGVBQWVHLE9BQU8sRUFBRUMsT0FBTztJQUM3QyxNQUFNLEVBQUVDLGNBQWMsRUFBRSxFQUFFLEdBQUdELFNBQ3ZCRSxhQUFhRCxZQUFZRSxJQUFJLENBQUMsQ0FBQ0Q7UUFDN0IsTUFBTSxFQUFFRSxvQkFBb0IsQ0FBQyxDQUFDLEVBQUUsR0FBR0YsWUFDN0IsRUFBRUcsSUFBSSxFQUFFLEdBQUdELG1CQUNYRSxjQUFlRCxTQUFTTjtRQUU5QixJQUFJTyxhQUFhO1lBQ2YsT0FBTztRQUNUO0lBQ0YsTUFBTTtJQUVaLE9BQU9KO0FBQ1Q7QUFFTyxTQUFTTCxnQkFBZ0JVLFVBQVU7SUFDeEMsTUFBTUMsVUFBVUQsWUFDVkUscUJBQXFCRCxRQUFRRSxxQkFBcUIsSUFDbERDLFdBQVc7UUFDVEg7V0FDR0M7S0FDSjtJQUVQRSxTQUFTQyxPQUFPLElBQUksR0FBRztJQUV2QkQsU0FBU0UsT0FBTyxDQUFDLENBQUNMO1FBQ2hCQSxRQUFRTSxRQUFRLElBQUlOLFFBQVFNLFFBQVE7SUFDdEM7QUFDRjtBQUVPLFNBQVNoQixrQkFBa0JTLFVBQVU7SUFDMUMsTUFBTUMsVUFBVUQsWUFDVkUscUJBQXFCRCxRQUFRRSxxQkFBcUIsSUFDbERDLFdBQVc7UUFDVEg7V0FDR0M7S0FDSjtJQUVQRSxTQUFTRSxPQUFPLENBQUMsQ0FBQ0w7UUFDaEJBLFFBQVFPLFdBQVcsSUFBSVAsUUFBUU8sV0FBVztJQUM1QztBQUNGIn0=
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "highmark-markdown",
3
3
  "author": "James Smith",
4
- "version": "1.2.104",
4
+ "version": "1.2.105",
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.",
@@ -6,7 +6,6 @@ import { Element } from "easy";
6
6
  import { grammarUtilities } from "../index"; ///
7
7
  import { RowsDiv, ColumnDiv, ColumnsDiv, VerticalSplitterDiv } from "easy-layout";
8
8
 
9
- import DownloadsDiv from "./view/div/Downloads";
10
9
  import indexOptions from "./indexOptions";
11
10
  import PageButtonsDiv from "./view/div/pageButtons";
12
11
  import LeftSizeableDiv from "./view/div/sizeable/left";
@@ -179,8 +178,7 @@ class View extends Element {
179
178
 
180
179
  context = {
181
180
  tokens,
182
- pathToURL,
183
- JSXElements
181
+ pathToURL
184
182
  };
185
183
 
186
184
  this.updatePreviewDiv(divisionHTMLNode, context);
@@ -436,7 +434,7 @@ class View extends Element {
436
434
  this.setMarkdown(markdown);
437
435
  }
438
436
 
439
- static initialMarkdown = initialMarkdown;
437
+ static initialMarkdown = `<DownloadsDiv/>`;
440
438
 
441
439
  static initialMarkdownStyle = "";
442
440
 
@@ -457,10 +455,6 @@ export default withStyle(View)`
457
455
 
458
456
  `;
459
457
 
460
- const JSXElements = [
461
- DownloadsDiv
462
- ]
463
-
464
458
  function pathToURL(path) {
465
459
  const url = `https://djalbat.com/${path}`;
466
460
 
@@ -3,7 +3,7 @@
3
3
  import HTMLNode from "../../node/html";
4
4
 
5
5
  import { EMPTY_STRING } from "../../constants";
6
- import { mountElement, unmountElement } from "../../utilities/jsx";
6
+ import { findJSXElement, mountJSXElement, unmountJSXElement } from "../../utilities/jsx";
7
7
 
8
8
  const jsxNameRegularExpression = /^[A-Z]/;
9
9
 
@@ -95,75 +95,82 @@ export default class XMLElementHTMLNode extends HTMLNode {
95
95
  }
96
96
 
97
97
  createDOMElement(context) {
98
- let domElement = null;
98
+ let domElement;
99
99
 
100
- const jsx = this.isJSX(context);
101
-
102
- if (jsx) {
103
- const jsxDOMElement = this.createJSXDomElement(context);
100
+ const jsxDOMElement = this.createJSXDOMElement(context);
104
101
 
102
+ if (jsxDOMElement !== null) {
105
103
  domElement = jsxDOMElement; ///
106
104
  } else {
107
- const tagName = this.tagName(context);
108
-
109
- domElement = document.createElement(tagName);
110
-
111
- const attributeNames = this.attributeNames(context),
112
- attributeValues = this.attributeValues(context);
113
-
114
- attributeNames.forEach((attributeName, index) => {
115
- const attributeValue = attributeValues[index];
105
+ const nativeDOMElement = this.createNativeDOMElement(context);
116
106
 
117
- domElement.setAttribute(attributeName, attributeValue);
118
- });
107
+ domElement = nativeDOMElement; ///
119
108
  }
120
109
 
121
110
  return domElement;
122
111
  }
123
112
 
124
- createJSXDomElement(context) {
113
+ createJSXDOMElement(context) {
125
114
  let jsxDOMElement = null;
126
115
 
127
- const { JSXElements = [] } = context,
128
- tagName = this.tagName(context),
129
- JSXElement = JSXElements.find((JSXElement) => {
130
- const { defaultProperties = {} } = JSXElement,
131
- { name } = defaultProperties,
132
- nameTagName = (name === tagName);
116
+ const jsx = this.isJSX(context);
133
117
 
134
- if (nameTagName) {
135
- return true;
136
- }
137
- }) || null;
118
+ if (jsx) {
119
+ const tagName = this.tagName(context),
120
+ JSXElement = findJSXElement(tagName, context);
138
121
 
139
- if (JSXElement !== null) {
140
- const properties = this.properties(context),
141
- jsxElement =
122
+ if (JSXElement !== null) {
123
+ const properties = this.properties(context),
124
+ jsxElement =
142
125
 
143
- <JSXElement {...properties} />
126
+ <JSXElement {...properties} />
144
127
 
145
- ,
146
- domElement = jsxElement.getDOMElement();
128
+ ,
129
+ domElement = jsxElement.getDOMElement();
147
130
 
148
- jsxDOMElement = domElement; ///
131
+ jsxDOMElement = domElement; ///
132
+ }
149
133
  }
150
134
 
151
135
  return jsxDOMElement;
152
136
  }
153
137
 
138
+ createNativeDOMElement(context) {
139
+ let nativeDOMElement;
140
+
141
+ const tagName = this.tagName(context);
142
+
143
+ nativeDOMElement = document.createElement(tagName);
144
+
145
+ const attributeNames = this.attributeNames(context),
146
+ attributeValues = this.attributeValues(context);
147
+
148
+ attributeNames.forEach((attributeName, index) => {
149
+ const attributeValue = attributeValues[index];
150
+
151
+ nativeDOMElement.setAttribute(attributeName, attributeValue);
152
+ });
153
+
154
+ return nativeDOMElement;
155
+ }
156
+
154
157
  mount(parentDOMElement, siblingDOMElement, context) {
155
158
  siblingDOMElement = super.mount(parentDOMElement, siblingDOMElement, context);
156
159
 
157
- if (this.domElement !== null) {
158
- mountElement(this.domElement);
160
+ const jsxElement = this.domElement.__element__; ///
161
+
162
+ if (jsxElement) { ///
163
+ mountJSXElement(jsxElement);
159
164
  }
160
165
 
161
166
  return siblingDOMElement;
162
167
  }
163
168
 
164
169
  unmount(parentDOMElement) {
165
- if (this.domElement !== null) {
166
- unmountElement(this.domElement);
170
+ const jsxElement = this.domElement.__element__; ///
171
+
172
+ if (jsxElement) { ///
173
+ unmountJSXElement(jsxElement);
167
174
  }
168
175
 
169
176
  super.unmount(parentDOMElement);
package/src/node/html.js CHANGED
@@ -266,39 +266,35 @@ class HTMLNode extends Node {
266
266
  mount(parentDOMElement, siblingDOMElement, context) {
267
267
  this.domElement = this.createDOMElement(context);
268
268
 
269
- if (this.domElement !== null) {
270
- (siblingDOMElement !== null) ?
271
- insertAfter(this.domElement, parentDOMElement, siblingDOMElement) :
272
- insertBeforehand(this.domElement, parentDOMElement);
269
+ (siblingDOMElement !== null) ?
270
+ insertAfter(this.domElement, parentDOMElement, siblingDOMElement) :
271
+ insertBeforehand(this.domElement, parentDOMElement);
273
272
 
274
- parentDOMElement = this.domElement; ///
273
+ parentDOMElement = this.domElement; ///
275
274
 
276
- siblingDOMElement = null;
275
+ siblingDOMElement = null;
277
276
 
278
- this.childNodes.forEach((childNode) => {
279
- siblingDOMElement = childNode.mount(parentDOMElement, siblingDOMElement, context);
280
- });
277
+ this.childNodes.forEach((childNode) => {
278
+ siblingDOMElement = childNode.mount(parentDOMElement, siblingDOMElement, context);
279
+ });
281
280
 
282
- siblingDOMElement = this.domElement; ///
283
- }
281
+ siblingDOMElement = this.domElement; ///
284
282
 
285
283
  return siblingDOMElement;
286
284
  }
287
285
 
288
286
  unmount(parentDOMElement) {
289
- if (this.domElement !== null) {
290
- {
291
- const parentDOMElement = this.domElement; ///
287
+ {
288
+ const parentDOMElement = this.domElement; ///
292
289
 
293
- this.childNodes.forEach((childNode) => {
294
- childNode.unmount(parentDOMElement);
295
- });
296
- }
290
+ this.childNodes.forEach((childNode) => {
291
+ childNode.unmount(parentDOMElement);
292
+ });
293
+ }
297
294
 
298
- remove(this.domElement, parentDOMElement);
295
+ remove(this.domElement, parentDOMElement);
299
296
 
300
- this.domElement = null;
301
- }
297
+ this.domElement = null;
302
298
  }
303
299
 
304
300
  asHTML(indent, context) {
@@ -1,13 +1,23 @@
1
1
  "use strict";
2
2
 
3
- export function mountElement(domElement) {
4
- const element = domElement.__element__;
5
-
6
- if (!element) { ///
7
- return;
8
- }
3
+ export function findJSXElement(tagName, context) {
4
+ const { JSXElements = [] } = context,
5
+ JSXElement = JSXElements.find((JSXElement) => {
6
+ const { defaultProperties = {} } = JSXElement,
7
+ { name } = defaultProperties,
8
+ nameTagName = (name === tagName);
9
+
10
+ if (nameTagName) {
11
+ return true;
12
+ }
13
+ }) || null;
14
+
15
+ return JSXElement;
16
+ }
9
17
 
10
- const descendantElements = element.getDescendantElements(),
18
+ export function mountJSXElement(jsxElement) {
19
+ const element = jsxElement, ///
20
+ descendantElements = element.getDescendantElements(),
11
21
  elements = [
12
22
  element,
13
23
  ...descendantElements
@@ -20,14 +30,9 @@ export function mountElement(domElement) {
20
30
  });
21
31
  }
22
32
 
23
- export function unmountElement(domElement) {
24
- const element = domElement.__element__;
25
-
26
- if (!element) { ///
27
- return;
28
- }
29
-
30
- const descendantElements = element.getDescendantElements(),
33
+ export function unmountJSXElement(jsxElement) {
34
+ const element = jsxElement, ///
35
+ descendantElements = element.getDescendantElements(),
31
36
  elements = [
32
37
  element,
33
38
  ...descendantElements
@@ -1,38 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", {
3
- value: true
4
- });
5
- Object.defineProperty(exports, "default", {
6
- enumerable: true,
7
- get: function() {
8
- return _default;
9
- }
10
- });
11
- const _easywithstyle = /*#__PURE__*/ _interop_require_default(require("easy-with-style"));
12
- const _easy = require("easy");
13
- function _interop_require_default(obj) {
14
- return obj && obj.__esModule ? obj : {
15
- default: obj
16
- };
17
- }
18
- class DownloadsDiv extends _easy.Element {
19
- didMount() {
20
- const { fileName } = this.properties;
21
- console.log(fileName);
22
- }
23
- childElements() {
24
- return /*#__PURE__*/ React.createElement("p", null, "Downloads");
25
- }
26
- static tagName = "div";
27
- static defaultProperties = {
28
- name: "DownloadsDiv",
29
- className: "downloads"
30
- };
31
- }
32
- const _default = (0, _easywithstyle.default)(DownloadsDiv)`
33
-
34
- background: red;
35
-
36
- `;
37
-
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9leGFtcGxlL3ZpZXcvZGl2L0Rvd25sb2Fkcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHdpdGhTdHlsZSBmcm9tIFwiZWFzeS13aXRoLXN0eWxlXCI7ICAvLy9cblxuaW1wb3J0IHsgRWxlbWVudCB9IGZyb20gXCJlYXN5XCI7XG5cbmNsYXNzIERvd25sb2Fkc0RpdiBleHRlbmRzIEVsZW1lbnQge1xuICBkaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IGZpbGVOYW1lIH0gPSB0aGlzLnByb3BlcnRpZXM7XG5cbiAgICBjb25zb2xlLmxvZyhmaWxlTmFtZSk7XG4gIH1cblxuICBjaGlsZEVsZW1lbnRzKCkge1xuICAgIHJldHVybiAoXG5cbiAgICAgIDxwPlxuICAgICAgICBEb3dubG9hZHNcbiAgICAgIDwvcD5cblxuICAgICk7XG4gIH1cblxuICBzdGF0aWMgdGFnTmFtZSA9IFwiZGl2XCI7XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wZXJ0aWVzID0ge1xuICAgIG5hbWU6IFwiRG93bmxvYWRzRGl2XCIsXG4gICAgY2xhc3NOYW1lOiBcImRvd25sb2Fkc1wiXG4gIH07XG59XG5cbmV4cG9ydCBkZWZhdWx0IHdpdGhTdHlsZShEb3dubG9hZHNEaXYpYFxuXG4gIGJhY2tncm91bmQ6IHJlZDtcbiAgXG5gO1xuIl0sIm5hbWVzIjpbIkRvd25sb2Fkc0RpdiIsIkVsZW1lbnQiLCJkaWRNb3VudCIsImZpbGVOYW1lIiwicHJvcGVydGllcyIsImNvbnNvbGUiLCJsb2ciLCJjaGlsZEVsZW1lbnRzIiwicCIsInRhZ05hbWUiLCJkZWZhdWx0UHJvcGVydGllcyIsIm5hbWUiLCJjbGFzc05hbWUiLCJ3aXRoU3R5bGUiXSwibWFwcGluZ3MiOiJBQUFBOzs7OytCQStCQTs7O2VBQUE7OztzRUE3QnNCO3NCQUVFOzs7Ozs7QUFFeEIsTUFBTUEscUJBQXFCQyxhQUFPO0lBQ2hDQyxXQUFXO1FBQ1QsTUFBTSxFQUFFQyxRQUFRLEVBQUUsR0FBRyxJQUFJLENBQUNDLFVBQVU7UUFFcENDLFFBQVFDLEdBQUcsQ0FBQ0g7SUFDZDtJQUVBSSxnQkFBZ0I7UUFDZCxxQkFFRSxvQkFBQ0MsV0FBRTtJQUtQO0lBRUEsT0FBT0MsVUFBVSxNQUFNO0lBRXZCLE9BQU9DLG9CQUFvQjtRQUN6QkMsTUFBTTtRQUNOQyxXQUFXO0lBQ2IsRUFBRTtBQUNKO01BRUEsV0FBZUMsSUFBQUEsc0JBQVMsRUFBQ2IsYUFBYSxDQUFDOzs7O0FBSXZDLENBQUMifQ==
@@ -1,36 +0,0 @@
1
- "use strict";
2
-
3
- import withStyle from "easy-with-style"; ///
4
-
5
- import { Element } from "easy";
6
-
7
- class DownloadsDiv extends Element {
8
- didMount() {
9
- const { fileName } = this.properties;
10
-
11
- console.log(fileName);
12
- }
13
-
14
- childElements() {
15
- return (
16
-
17
- <p>
18
- Downloads
19
- </p>
20
-
21
- );
22
- }
23
-
24
- static tagName = "div";
25
-
26
- static defaultProperties = {
27
- name: "DownloadsDiv",
28
- className: "downloads"
29
- };
30
- }
31
-
32
- export default withStyle(DownloadsDiv)`
33
-
34
- background: red;
35
-
36
- `;