occam-dom 5.2.52 → 5.3.1
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.
- package/example.js +44 -12
- package/lib/utilities/node.js +44 -12
- package/package.json +1 -1
- package/src/utilities/node.js +51 -20
package/lib/utilities/node.js
CHANGED
|
@@ -21,9 +21,18 @@ _export(exports, {
|
|
|
21
21
|
get isGreaterThan () {
|
|
22
22
|
return isGreaterThan;
|
|
23
23
|
},
|
|
24
|
+
get isGreaterThanOfEqualTo () {
|
|
25
|
+
return isGreaterThanOfEqualTo;
|
|
26
|
+
},
|
|
24
27
|
get isLessThan () {
|
|
25
28
|
return isLessThan;
|
|
26
29
|
},
|
|
30
|
+
get isLessThanOfEqualTo () {
|
|
31
|
+
return isLessThanOfEqualTo;
|
|
32
|
+
},
|
|
33
|
+
get orderNodes () {
|
|
34
|
+
return orderNodes;
|
|
35
|
+
},
|
|
27
36
|
get topmostNodeFromOuterNodes () {
|
|
28
37
|
return topmostNodeFromOuterNodes;
|
|
29
38
|
}
|
|
@@ -44,6 +53,36 @@ function isLessThan(nodeA, nodeB) {
|
|
|
44
53
|
}
|
|
45
54
|
return lessThan;
|
|
46
55
|
}
|
|
56
|
+
function isGreaterThan(nodeA, nodeB) {
|
|
57
|
+
var lessThan = isLessThan(nodeA, nodeB), greaterThan = !lessThan;
|
|
58
|
+
return greaterThan;
|
|
59
|
+
}
|
|
60
|
+
function isLessThanOfEqualTo(nodeA, nodeB) {
|
|
61
|
+
var lessThanOrEqualTo = false;
|
|
62
|
+
if (nodeA === nodeB) {
|
|
63
|
+
lessThanOrEqualTo = true;
|
|
64
|
+
} else {
|
|
65
|
+
var lessThan = isLessThan(nodeA, nodeB);
|
|
66
|
+
lessThanOrEqualTo = lessThan; ///
|
|
67
|
+
}
|
|
68
|
+
return lessThanOrEqualTo;
|
|
69
|
+
}
|
|
70
|
+
function isGreaterThanOfEqualTo(nodeA, nodeB) {
|
|
71
|
+
var greaterThanOrEqualTo = false;
|
|
72
|
+
if (nodeA === nodeB) {
|
|
73
|
+
greaterThanOrEqualTo = true;
|
|
74
|
+
} else {
|
|
75
|
+
var greaterThan = isGreaterThan(nodeA, nodeB);
|
|
76
|
+
greaterThanOrEqualTo = greaterThan; ///
|
|
77
|
+
}
|
|
78
|
+
return greaterThanOrEqualTo;
|
|
79
|
+
}
|
|
80
|
+
function orderNodes(nodes) {
|
|
81
|
+
nodes.sort(function(nodeA, nodeB) {
|
|
82
|
+
var nodeALessThanNodeB = isLessThan(nodeA, nodeB), result = nodeALessThanNodeB ? -1 : +1;
|
|
83
|
+
return result;
|
|
84
|
+
});
|
|
85
|
+
}
|
|
47
86
|
function isAncestorOf(nodeA, nodeB) {
|
|
48
87
|
var ancestorOf = nodeB.someAncestorNode(function(ancestorNodeB) {
|
|
49
88
|
if (nodeA === ancestorNodeB) {
|
|
@@ -52,10 +91,6 @@ function isAncestorOf(nodeA, nodeB) {
|
|
|
52
91
|
});
|
|
53
92
|
return ancestorOf;
|
|
54
93
|
}
|
|
55
|
-
function isGreaterThan(nodeA, nodeB) {
|
|
56
|
-
var lessThan = isLessThan(nodeA, nodeB), greaterThan = !lessThan;
|
|
57
|
-
return greaterThan;
|
|
58
|
-
}
|
|
59
94
|
function isDescendantOf(nodeA, nodeB) {
|
|
60
95
|
var nodeBAncestorOfNodeA = isAncestorOf(nodeB, nodeA), nodeADescendantOfNodeB = nodeBAncestorOfNodeA, descendantOf = nodeADescendantOfNodeB; ///
|
|
61
96
|
return descendantOf;
|
|
@@ -81,17 +116,14 @@ function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {
|
|
|
81
116
|
}
|
|
82
117
|
var _default = {
|
|
83
118
|
isLessThan: isLessThan,
|
|
84
|
-
isAncestorOf: isAncestorOf,
|
|
85
119
|
isGreaterThan: isGreaterThan,
|
|
120
|
+
isLessThanOfEqualTo: isLessThanOfEqualTo,
|
|
121
|
+
isGreaterThanOfEqualTo: isGreaterThanOfEqualTo,
|
|
122
|
+
orderNodes: orderNodes,
|
|
123
|
+
isAncestorOf: isAncestorOf,
|
|
86
124
|
isDescendantOf: isDescendantOf,
|
|
87
125
|
topmostNodeFromOuterNodes: topmostNodeFromOuterNodes
|
|
88
126
|
};
|
|
89
|
-
function orderNodes(nodes) {
|
|
90
|
-
nodes.sort(function(nodeA, nodeB) {
|
|
91
|
-
var nodeALessThanNodeB = isLessThan(nodeA, nodeB), result = nodeALessThanNodeB ? -1 : +1;
|
|
92
|
-
return result;
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
127
|
function ancestorNodesFromNode(node) {
|
|
96
128
|
var ancestorNodes = node.getAncestorNodes();
|
|
97
129
|
ancestorNodes.unshift(node);
|
|
@@ -99,4 +131,4 @@ function ancestorNodesFromNode(node) {
|
|
|
99
131
|
return ancestorNodes;
|
|
100
132
|
}
|
|
101
133
|
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/node.js"],"sourcesContent":["\"use strict\";\n\nexport function isLessThan(nodeA, nodeB) {\n  let lessThan = null;\n\n  const nodeAAncestorNodes = ancestorNodesFromNode(nodeA),\n        nodeBAncestorNodes = ancestorNodesFromNode(nodeB),\n        nodeAAncestorNodesLength = nodeAAncestorNodes.length,\n        nodeBAncestorNodesLength = nodeBAncestorNodes.length,\n        minimumAncestorNodesLength = Math.min(nodeAAncestorNodesLength, nodeBAncestorNodesLength);\n\n  for (let index = 0; index < minimumAncestorNodesLength; index++) {\n    const nodeAAncestorNode = nodeAAncestorNodes[index],\n          nodeBAncestorNode = nodeBAncestorNodes[index];\n\n    if (nodeAAncestorNode !== nodeBAncestorNode) {\n      const parentIndex = index - 1,\n            nodeAAncestorNodeParentNode = nodeAAncestorNodes[parentIndex],\n            parentNode = nodeAAncestorNodeParentNode, ///\n            childNodeA = nodeAAncestorNode, ///\n            childNodeB = nodeBAncestorNode, ///\n            indexA = parentNode.indexOfChildNode(childNodeA),\n            indexB = parentNode.indexOfChildNode(childNodeB);\n\n      lessThan = (indexA < indexB);\n\n      break;\n    }\n  }\n\n  if (lessThan === null) {\n    lessThan = (nodeAAncestorNodesLength < nodeBAncestorNodesLength);\n  }\n\n  return lessThan;\n}\n\nexport function isAncestorOf(nodeA, nodeB) {\n  const ancestorOf = nodeB.someAncestorNode((ancestorNodeB) => {\n    if (nodeA === ancestorNodeB) {\n      return true;\n    }\n  });\n\n  return ancestorOf;\n}\n\nexport function isGreaterThan(nodeA, nodeB) {\n  const lessThan = isLessThan(nodeA, nodeB),\n        greaterThan = !lessThan;\n\n  return greaterThan;\n}\n\nexport function isDescendantOf(nodeA, nodeB) {\n  const nodeBAncestorOfNodeA = isAncestorOf(nodeB, nodeA),\n        nodeADescendantOfNodeB = nodeBAncestorOfNodeA,  ///\n        descendantOf = nodeADescendantOfNodeB;  ///\n\n  return descendantOf;\n}\n\nexport function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {\n  const nodes = outerNodes; ///\n\n  orderNodes(nodes);\n\n  const outerNode = null,\n        Class = ClassFromOuterNode(outerNode),\n        topmostNode = Class.fromNothing(),\n        outerNodeToNodeMap = new WeakMap();\n\n  outerNodes.forEach((outerNode) => {\n    let parentNode = topmostNode; ///\n\n    outerNode.someAncestorNode((ancestorNode) => {\n      const outerNode = ancestorNode, ///\n            node = outerNodeToNodeMap.get(outerNode) || null;\n\n      if (node !== null) {\n        parentNode = node;  ///\n\n        return true;\n      }\n    });\n\n    const Class = ClassFromOuterNode(outerNode),\n          node = Class.fromOuterNode(outerNode),\n          appendedChildNode = node; ///\n\n    parentNode.appendChildNode(appendedChildNode);\n\n    outerNodeToNodeMap.set(outerNode, node);\n  });\n\n  return topmostNode;\n}\n\nexport default {\n  isLessThan,\n  isAncestorOf,\n  isGreaterThan,\n  isDescendantOf,\n  topmostNodeFromOuterNodes\n};\n\nfunction orderNodes(nodes) {\n  nodes.sort((nodeA, nodeB) => {\n    const nodeALessThanNodeB = isLessThan(nodeA, nodeB),\n          result = nodeALessThanNodeB ?\n                     -1 :\n                       +1;\n\n    return result;\n  });\n}\n\nfunction ancestorNodesFromNode(node) {\n  const ancestorNodes = node.getAncestorNodes();\n\n  ancestorNodes.unshift(node);\n\n  ancestorNodes.reverse();\n\n  return ancestorNodes;\n}\n"],"names":["isAncestorOf","isDescendantOf","isGreaterThan","isLessThan","topmostNodeFromOuterNodes","nodeA","nodeB","lessThan","nodeAAncestorNodes","ancestorNodesFromNode","nodeBAncestorNodes","nodeAAncestorNodesLength","length","nodeBAncestorNodesLength","minimumAncestorNodesLength","Math","min","index","nodeAAncestorNode","nodeBAncestorNode","parentIndex","nodeAAncestorNodeParentNode","parentNode","childNodeA","childNodeB","indexA","indexOfChildNode","indexB","ancestorOf","someAncestorNode","ancestorNodeB","greaterThan","nodeBAncestorOfNodeA","nodeADescendantOfNodeB","descendantOf","ClassFromOuterNode","outerNodes","nodes","orderNodes","outerNode","Class","topmostNode","fromNothing","outerNodeToNodeMap","WeakMap","forEach","ancestorNode","node","get","fromOuterNode","appendedChildNode","appendChildNode","set","sort","nodeALessThanNodeB","result","ancestorNodes","getAncestorNodes","unshift","reverse"],"mappings":"AAAA;;;;;;;;;;;QAkGA;eAAA;;QA7DgBA;eAAAA;;QAiBAC;eAAAA;;QAPAC;eAAAA;;QA7CAC;eAAAA;;QA4DAC;eAAAA;;;AA5DT,SAASD,WAAWE,KAAK,EAAEC,KAAK;IACrC,IAAIC,WAAW;IAEf,IAAMC,qBAAqBC,sBAAsBJ,QAC3CK,qBAAqBD,sBAAsBH,QAC3CK,2BAA2BH,mBAAmBI,MAAM,EACpDC,2BAA2BH,mBAAmBE,MAAM,EACpDE,6BAA6BC,KAAKC,GAAG,CAACL,0BAA0BE;IAEtE,IAAK,IAAII,QAAQ,GAAGA,QAAQH,4BAA4BG,QAAS;QAC/D,IAAMC,oBAAoBV,kBAAkB,CAACS,MAAM,EAC7CE,oBAAoBT,kBAAkB,CAACO,MAAM;QAEnD,IAAIC,sBAAsBC,mBAAmB;YAC3C,IAAMC,cAAcH,QAAQ,GACtBI,8BAA8Bb,kBAAkB,CAACY,YAAY,EAC7DE,aAAaD,6BACbE,aAAaL,mBACbM,aAAaL,mBACbM,SAASH,WAAWI,gBAAgB,CAACH,aACrCI,SAASL,WAAWI,gBAAgB,CAACF;YAE3CjB,WAAYkB,SAASE;YAErB;QACF;IACF;IAEA,IAAIpB,aAAa,MAAM;QACrBA,WAAYI,2BAA2BE;IACzC;IAEA,OAAON;AACT;AAEO,SAASP,aAAaK,KAAK,EAAEC,KAAK;IACvC,IAAMsB,aAAatB,MAAMuB,gBAAgB,CAAC,SAACC;QACzC,IAAIzB,UAAUyB,eAAe;YAC3B,OAAO;QACT;IACF;IAEA,OAAOF;AACT;AAEO,SAAS1B,cAAcG,KAAK,EAAEC,KAAK;IACxC,IAAMC,WAAWJ,WAAWE,OAAOC,QAC7ByB,cAAc,CAACxB;IAErB,OAAOwB;AACT;AAEO,SAAS9B,eAAeI,KAAK,EAAEC,KAAK;IACzC,IAAM0B,uBAAuBhC,aAAaM,OAAOD,QAC3C4B,yBAAyBD,sBACzBE,eAAeD,wBAAyB,GAAG;IAEjD,OAAOC;AACT;AAEO,SAAS9B,0BAA0B+B,kBAAkB,EAAEC,UAAU;IACtE,IAAMC,QAAQD,YAAY,GAAG;IAE7BE,WAAWD;IAEX,IAAME,YAAY,MACZC,QAAQL,mBAAmBI,YAC3BE,cAAcD,MAAME,WAAW,IAC/BC,qBAAqB,IAAIC;IAE/BR,WAAWS,OAAO,CAAC,SAACN;QAClB,IAAIjB,aAAamB,aAAa,GAAG;QAEjCF,UAAUV,gBAAgB,CAAC,SAACiB;YAC1B,IAAMP,cAAYO,cACZC,OAAOJ,mBAAmBK,GAAG,CAACT,gBAAc;YAElD,IAAIQ,SAAS,MAAM;gBACjBzB,aAAayB,MAAO,GAAG;gBAEvB,OAAO;YACT;QACF;QAEA,IAAMP,QAAQL,mBAAmBI,YAC3BQ,OAAOP,MAAMS,aAAa,CAACV,YAC3BW,oBAAoBH,MAAM,GAAG;QAEnCzB,WAAW6B,eAAe,CAACD;QAE3BP,mBAAmBS,GAAG,CAACb,WAAWQ;IACpC;IAEA,OAAON;AACT;IAEA,WAAe;IACbtC,YAAAA;IACAH,cAAAA;IACAE,eAAAA;IACAD,gBAAAA;IACAG,2BAAAA;AACF;AAEA,SAASkC,WAAWD,KAAK;IACvBA,MAAMgB,IAAI,CAAC,SAAChD,OAAOC;QACjB,IAAMgD,qBAAqBnD,WAAWE,OAAOC,QACvCiD,SAASD,qBACE,CAAC,IACC,CAAC;QAEpB,OAAOC;IACT;AACF;AAEA,SAAS9C,sBAAsBsC,IAAI;IACjC,IAAMS,gBAAgBT,KAAKU,gBAAgB;IAE3CD,cAAcE,OAAO,CAACX;IAEtBS,cAAcG,OAAO;IAErB,OAAOH;AACT"}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/node.js"],"sourcesContent":["\"use strict\";\n\nexport function isLessThan(nodeA, nodeB) {\n  let lessThan = null;\n\n  const nodeAAncestorNodes = ancestorNodesFromNode(nodeA),\n        nodeBAncestorNodes = ancestorNodesFromNode(nodeB),\n        nodeAAncestorNodesLength = nodeAAncestorNodes.length,\n        nodeBAncestorNodesLength = nodeBAncestorNodes.length,\n        minimumAncestorNodesLength = Math.min(nodeAAncestorNodesLength, nodeBAncestorNodesLength);\n\n  for (let index = 0; index < minimumAncestorNodesLength; index++) {\n    const nodeAAncestorNode = nodeAAncestorNodes[index],\n          nodeBAncestorNode = nodeBAncestorNodes[index];\n\n    if (nodeAAncestorNode !== nodeBAncestorNode) {\n      const parentIndex = index - 1,\n            nodeAAncestorNodeParentNode = nodeAAncestorNodes[parentIndex],\n            parentNode = nodeAAncestorNodeParentNode, ///\n            childNodeA = nodeAAncestorNode, ///\n            childNodeB = nodeBAncestorNode, ///\n            indexA = parentNode.indexOfChildNode(childNodeA),\n            indexB = parentNode.indexOfChildNode(childNodeB);\n\n      lessThan = (indexA < indexB);\n\n      break;\n    }\n  }\n\n  if (lessThan === null) {\n    lessThan = (nodeAAncestorNodesLength < nodeBAncestorNodesLength);\n  }\n\n  return lessThan;\n}\n\nexport function isGreaterThan(nodeA, nodeB) {\n  const lessThan = isLessThan(nodeA, nodeB),\n        greaterThan = !lessThan;\n\n  return greaterThan;\n}\n\nexport function isLessThanOfEqualTo(nodeA, nodeB) {\n  let lessThanOrEqualTo = false;\n\n  if (nodeA === nodeB) {\n    lessThanOrEqualTo = true;\n  } else {\n    const lessThan = isLessThan(nodeA, nodeB);\n\n    lessThanOrEqualTo = lessThan; ///\n  }\n\n  return lessThanOrEqualTo;\n}\n\nexport function isGreaterThanOfEqualTo(nodeA, nodeB) {\n  let greaterThanOrEqualTo = false;\n\n  if (nodeA === nodeB) {\n    greaterThanOrEqualTo = true;\n  } else {\n    const greaterThan = isGreaterThan(nodeA, nodeB);\n\n    greaterThanOrEqualTo = greaterThan; ///\n  }\n\n  return greaterThanOrEqualTo;\n}\n\nexport function orderNodes(nodes) {\n  nodes.sort((nodeA, nodeB) => {\n    const nodeALessThanNodeB = isLessThan(nodeA, nodeB),\n          result = nodeALessThanNodeB ?\n                    -1 :\n                      +1;\n\n    return result;\n  });\n}\n\nexport function isAncestorOf(nodeA, nodeB) {\n  const ancestorOf = nodeB.someAncestorNode((ancestorNodeB) => {\n    if (nodeA === ancestorNodeB) {\n      return true;\n    }\n  });\n\n  return ancestorOf;\n}\n\nexport function isDescendantOf(nodeA, nodeB) {\n  const nodeBAncestorOfNodeA = isAncestorOf(nodeB, nodeA),\n        nodeADescendantOfNodeB = nodeBAncestorOfNodeA,  ///\n        descendantOf = nodeADescendantOfNodeB;  ///\n\n  return descendantOf;\n}\n\nexport function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {\n  const nodes = outerNodes; ///\n\n  orderNodes(nodes);\n\n  const outerNode = null,\n        Class = ClassFromOuterNode(outerNode),\n        topmostNode = Class.fromNothing(),\n        outerNodeToNodeMap = new WeakMap();\n\n  outerNodes.forEach((outerNode) => {\n    let parentNode = topmostNode; ///\n\n    outerNode.someAncestorNode((ancestorNode) => {\n      const outerNode = ancestorNode, ///\n            node = outerNodeToNodeMap.get(outerNode) || null;\n\n      if (node !== null) {\n        parentNode = node;  ///\n\n        return true;\n      }\n    });\n\n    const Class = ClassFromOuterNode(outerNode),\n          node = Class.fromOuterNode(outerNode),\n          appendedChildNode = node; ///\n\n    parentNode.appendChildNode(appendedChildNode);\n\n    outerNodeToNodeMap.set(outerNode, node);\n  });\n\n  return topmostNode;\n}\n\nexport default {\n  isLessThan,\n  isGreaterThan,\n  isLessThanOfEqualTo,\n  isGreaterThanOfEqualTo,\n  orderNodes,\n  isAncestorOf,\n  isDescendantOf,\n  topmostNodeFromOuterNodes,\n};\n\nfunction ancestorNodesFromNode(node) {\n  const ancestorNodes = node.getAncestorNodes();\n\n  ancestorNodes.unshift(node);\n\n  ancestorNodes.reverse();\n\n  return ancestorNodes;\n}\n"],"names":["isAncestorOf","isDescendantOf","isGreaterThan","isGreaterThanOfEqualTo","isLessThan","isLessThanOfEqualTo","orderNodes","topmostNodeFromOuterNodes","nodeA","nodeB","lessThan","nodeAAncestorNodes","ancestorNodesFromNode","nodeBAncestorNodes","nodeAAncestorNodesLength","length","nodeBAncestorNodesLength","minimumAncestorNodesLength","Math","min","index","nodeAAncestorNode","nodeBAncestorNode","parentIndex","nodeAAncestorNodeParentNode","parentNode","childNodeA","childNodeB","indexA","indexOfChildNode","indexB","greaterThan","lessThanOrEqualTo","greaterThanOrEqualTo","nodes","sort","nodeALessThanNodeB","result","ancestorOf","someAncestorNode","ancestorNodeB","nodeBAncestorOfNodeA","nodeADescendantOfNodeB","descendantOf","ClassFromOuterNode","outerNodes","outerNode","Class","topmostNode","fromNothing","outerNodeToNodeMap","WeakMap","forEach","ancestorNode","node","get","fromOuterNode","appendedChildNode","appendChildNode","set","ancestorNodes","getAncestorNodes","unshift","reverse"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/utilities/node.js
CHANGED
|
@@ -35,6 +35,52 @@ export function isLessThan(nodeA, nodeB) {
|
|
|
35
35
|
return lessThan;
|
|
36
36
|
}
|
|
37
37
|
|
|
38
|
+
export function isGreaterThan(nodeA, nodeB) {
|
|
39
|
+
const lessThan = isLessThan(nodeA, nodeB),
|
|
40
|
+
greaterThan = !lessThan;
|
|
41
|
+
|
|
42
|
+
return greaterThan;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export function isLessThanOfEqualTo(nodeA, nodeB) {
|
|
46
|
+
let lessThanOrEqualTo = false;
|
|
47
|
+
|
|
48
|
+
if (nodeA === nodeB) {
|
|
49
|
+
lessThanOrEqualTo = true;
|
|
50
|
+
} else {
|
|
51
|
+
const lessThan = isLessThan(nodeA, nodeB);
|
|
52
|
+
|
|
53
|
+
lessThanOrEqualTo = lessThan; ///
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return lessThanOrEqualTo;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export function isGreaterThanOfEqualTo(nodeA, nodeB) {
|
|
60
|
+
let greaterThanOrEqualTo = false;
|
|
61
|
+
|
|
62
|
+
if (nodeA === nodeB) {
|
|
63
|
+
greaterThanOrEqualTo = true;
|
|
64
|
+
} else {
|
|
65
|
+
const greaterThan = isGreaterThan(nodeA, nodeB);
|
|
66
|
+
|
|
67
|
+
greaterThanOrEqualTo = greaterThan; ///
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
return greaterThanOrEqualTo;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export function orderNodes(nodes) {
|
|
74
|
+
nodes.sort((nodeA, nodeB) => {
|
|
75
|
+
const nodeALessThanNodeB = isLessThan(nodeA, nodeB),
|
|
76
|
+
result = nodeALessThanNodeB ?
|
|
77
|
+
-1 :
|
|
78
|
+
+1;
|
|
79
|
+
|
|
80
|
+
return result;
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
|
|
38
84
|
export function isAncestorOf(nodeA, nodeB) {
|
|
39
85
|
const ancestorOf = nodeB.someAncestorNode((ancestorNodeB) => {
|
|
40
86
|
if (nodeA === ancestorNodeB) {
|
|
@@ -45,13 +91,6 @@ export function isAncestorOf(nodeA, nodeB) {
|
|
|
45
91
|
return ancestorOf;
|
|
46
92
|
}
|
|
47
93
|
|
|
48
|
-
export function isGreaterThan(nodeA, nodeB) {
|
|
49
|
-
const lessThan = isLessThan(nodeA, nodeB),
|
|
50
|
-
greaterThan = !lessThan;
|
|
51
|
-
|
|
52
|
-
return greaterThan;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
94
|
export function isDescendantOf(nodeA, nodeB) {
|
|
56
95
|
const nodeBAncestorOfNodeA = isAncestorOf(nodeB, nodeA),
|
|
57
96
|
nodeADescendantOfNodeB = nodeBAncestorOfNodeA, ///
|
|
@@ -98,23 +137,15 @@ export function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {
|
|
|
98
137
|
|
|
99
138
|
export default {
|
|
100
139
|
isLessThan,
|
|
101
|
-
isAncestorOf,
|
|
102
140
|
isGreaterThan,
|
|
141
|
+
isLessThanOfEqualTo,
|
|
142
|
+
isGreaterThanOfEqualTo,
|
|
143
|
+
orderNodes,
|
|
144
|
+
isAncestorOf,
|
|
103
145
|
isDescendantOf,
|
|
104
|
-
topmostNodeFromOuterNodes
|
|
146
|
+
topmostNodeFromOuterNodes,
|
|
105
147
|
};
|
|
106
148
|
|
|
107
|
-
function orderNodes(nodes) {
|
|
108
|
-
nodes.sort((nodeA, nodeB) => {
|
|
109
|
-
const nodeALessThanNodeB = isLessThan(nodeA, nodeB),
|
|
110
|
-
result = nodeALessThanNodeB ?
|
|
111
|
-
-1 :
|
|
112
|
-
+1;
|
|
113
|
-
|
|
114
|
-
return result;
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
|
|
118
149
|
function ancestorNodesFromNode(node) {
|
|
119
150
|
const ancestorNodes = node.getAncestorNodes();
|
|
120
151
|
|