highmark-markdown 0.0.339 → 0.0.341

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.
@@ -2,17 +2,42 @@
2
2
 
3
3
  import MarkdownNode from "../../node/markdown";
4
4
 
5
- import { htmlFromChildNodes, domElementsFromChildNodes } from "../../utilities/childNodes";
5
+ import { contentFromNode } from "../../utilities/content";
6
6
 
7
7
  export default class BlockLineMarkdownNode extends MarkdownNode {
8
+ content(context) {
9
+ let content;
10
+
11
+ const { tokens } = context,
12
+ node = this; ///
13
+
14
+ content = contentFromNode(node, context);
15
+
16
+ const firstSignificantToken = this.getFirstSignificantToken(),
17
+ firstSignificantTokenIndex = tokens.indexOf(firstSignificantToken),
18
+ previousTokenIndex = firstSignificantTokenIndex - 1,
19
+ previousToken = tokens[previousTokenIndex],
20
+ previousTokenWhitespaceToken = previousToken.isWhitespaceToken();
21
+
22
+ if (previousTokenWhitespaceToken) {
23
+ const whitespaceToken = previousToken, ///
24
+ whitespaceTokenContent = whitespaceToken.getContent();
25
+
26
+ content = `${whitespaceTokenContent}${content}`;
27
+ }
28
+
29
+ const childNodesHTML = content; ///
30
+
31
+ return childNodesHTML;
32
+ }
33
+
8
34
  asHTML(indent, context) {
9
35
  indent = this.adjustIndent(indent);
10
36
 
11
37
  const childNodesHTML = this.childNodesAsHTML(indent, context),
12
38
  startingTag = this.startingTag(context),
13
39
  closingTag = this.closingTag(context),
14
- html = `${indent}${startingTag}${childNodesHTML}${closingTag}
15
- `;
40
+ html = `${indent}${startingTag}${childNodesHTML}${closingTag}`;
16
41
 
17
42
  return html;
18
43
  }
@@ -34,24 +59,24 @@ export default class BlockLineMarkdownNode extends MarkdownNode {
34
59
  }
35
60
 
36
61
  childNodesAsHTML(indent, context) {
37
- const childNodes = this.getChildNodes(),
38
- html = htmlFromChildNodes(childNodes, context);
62
+ const content = this.content(context),
63
+ childNodesHTML = content; ///
39
64
 
40
- return html;
65
+ return childNodesHTML;
41
66
  }
42
67
 
43
68
  createChildNodeDOMElements(context) {
44
- const domElement = this.getDOMElement(),
45
- childNodes = this.getChildNodes(),
46
- domElements = domElementsFromChildNodes(childNodes, context),
47
- parentDOMElement = domElement, ///
48
- childNodeDOMElements = domElements; ///
69
+ let domElement;
49
70
 
50
- childNodeDOMElements.forEach((childNodeDOMElement) => {
51
- const domElement = childNodeDOMElement; ///
71
+ domElement = this.getDOMElement();
52
72
 
53
- parentDOMElement.appendChild(domElement);
54
- });
73
+ const content = this.content(context),
74
+ textNode = document.createTextNode(content),
75
+ parentDOMElement = domElement; ///
76
+
77
+ domElement = textNode; ///
78
+
79
+ parentDOMElement.appendChild(domElement);
55
80
  }
56
81
 
57
82
  static fromRuleNameChildNodesAndOpacity(ruleName, childNodes, opacity) { return MarkdownNode.fromRuleNameChildNodesAndOpacity(BlockLineMarkdownNode, ruleName, childNodes, opacity); }
@@ -5,14 +5,21 @@ import MarkdownNode from "../../node/markdown";
5
5
  import { CARRIAGE_RETURN } from "../../constants";
6
6
 
7
7
  export default class EndOfLineMarkdownNode extends MarkdownNode {
8
+ content(context) {
9
+ const content = CARRIAGE_RETURN;
10
+
11
+ return content;
12
+ }
13
+
8
14
  asHTML(indent, context) {
9
- const html = CARRIAGE_RETURN; ///
15
+ const content = this.content(context),
16
+ html = content; ///
10
17
 
11
18
  return html;
12
19
  }
13
20
 
14
21
  createDOMElement(context) {
15
- const content = CARRIAGE_RETURN, ///
22
+ const content = this.content(context),
16
23
  textNode = document.createTextNode(content),
17
24
  domElement = textNode; ///
18
25
 
@@ -1,7 +1,36 @@
1
1
  "use strict";
2
2
 
3
+ import { arrayUtilities } from "necessary";
4
+
3
5
  import MarkdownNode from "../../node/markdown";
4
6
 
7
+ const { first } = arrayUtilities;
8
+
5
9
  export default class TableCellMarkdownNode extends MarkdownNode {
10
+ childNodesAsHTML(indent, context) {
11
+ const childNodes = this.getChildNodes(),
12
+ firstChildNode = first(childNodes),
13
+ lineMarkdownNode = firstChildNode, ///
14
+ lineMarkdownNodeHTML = lineMarkdownNode.asHTML(indent, context),
15
+ childNodesHTML = lineMarkdownNodeHTML; ///
16
+
17
+ return childNodesHTML;
18
+ }
19
+
20
+ createChildNodeDOMElements(domElement, context) {
21
+ const childNodes = this.getChildNodes(),
22
+ firstChildNode = first(childNodes),
23
+ lineMarkdownNode = firstChildNode; ///
24
+
25
+ lineMarkdownNode.createDOMElement(context);
26
+
27
+ const domElements = lineMarkdownNode.getDOMElements(),
28
+ parentDOMElement = domElement; ///
29
+
30
+ domElements.forEach((domElement) => {
31
+ parentDOMElement.appendChild(domElement)
32
+ });
33
+ }
34
+
6
35
  static fromRuleNameChildNodesAndOpacity(ruleName, childNodes, opacity) { return MarkdownNode.fromRuleNameChildNodesAndOpacity(TableCellMarkdownNode, ruleName, childNodes, opacity); }
7
36
  }
@@ -176,9 +176,3 @@ function contentFromPlainTextMarkdownNodes(plainTextMarkdownNodes, childNodes, c
176
176
 
177
177
  return content;
178
178
  }
179
-
180
- export default {
181
- htmlFromChildNodes,
182
- plainTextFromChildNodes,
183
- domElementsFromChildNodes
184
- };