@schukai/monster 1.26.0 → 1.28.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (193) hide show
  1. package/CHANGELOG +36 -1
  2. package/README.md +4 -4
  3. package/dist/modules/constants.js +1 -1
  4. package/dist/modules/constraints/abstract.js +1 -1
  5. package/dist/modules/constraints/abstractoperator.js +1 -1
  6. package/dist/modules/constraints/andoperator.js +1 -1
  7. package/dist/modules/constraints/invalid.js +1 -1
  8. package/dist/modules/constraints/isarray.js +1 -1
  9. package/dist/modules/constraints/isobject.js +1 -1
  10. package/dist/modules/constraints/namespace.js +1 -1
  11. package/dist/modules/constraints/oroperator.js +1 -1
  12. package/dist/modules/constraints/valid.js +1 -1
  13. package/dist/modules/data/buildmap.js +2 -2
  14. package/dist/modules/data/buildtree.js +2 -2
  15. package/dist/modules/data/datasource/namespace.js +1 -1
  16. package/dist/modules/data/datasource/restapi/writeerror.js +1 -1
  17. package/dist/modules/data/datasource/restapi.js +1 -1
  18. package/dist/modules/data/datasource/storage/localstorage.js +1 -1
  19. package/dist/modules/data/datasource/storage/namespace.js +1 -1
  20. package/dist/modules/data/datasource/storage/sessionstorage.js +1 -1
  21. package/dist/modules/data/datasource/storage.js +1 -1
  22. package/dist/modules/data/datasource.js +1 -1
  23. package/dist/modules/data/diff.js +1 -1
  24. package/dist/modules/data/extend.js +1 -1
  25. package/dist/modules/data/namespace.js +1 -1
  26. package/dist/modules/data/pathfinder.js +1 -1
  27. package/dist/modules/data/pipe.js +1 -1
  28. package/dist/modules/data/transformer.js +1 -1
  29. package/dist/modules/dom/assembler.js +1 -1
  30. package/dist/modules/dom/attributes.js +2 -2
  31. package/dist/modules/dom/constants.js +2 -2
  32. package/dist/modules/dom/customcontrol.js +1 -1
  33. package/dist/modules/dom/customelement.js +1 -1
  34. package/dist/modules/dom/events.js +2 -2
  35. package/dist/modules/dom/focusmanager.js +1 -1
  36. package/dist/modules/dom/locale.js +1 -1
  37. package/dist/modules/dom/namespace.js +1 -1
  38. package/dist/modules/dom/resource/data.js +1 -1
  39. package/dist/modules/dom/resource/link/stylesheet.js +1 -1
  40. package/dist/modules/dom/resource/link.js +1 -1
  41. package/dist/modules/dom/resource/script.js +1 -1
  42. package/dist/modules/dom/resource.js +1 -1
  43. package/dist/modules/dom/resourcemanager.js +1 -1
  44. package/dist/modules/dom/template.js +2 -2
  45. package/dist/modules/dom/theme.js +1 -1
  46. package/dist/modules/dom/updater.js +2 -2
  47. package/dist/modules/dom/util.js +1 -1
  48. package/dist/modules/dom/worker/factory.js +1 -1
  49. package/dist/modules/i18n/formatter.js +1 -1
  50. package/dist/modules/i18n/locale.js +1 -1
  51. package/dist/modules/i18n/namespace.js +1 -1
  52. package/dist/modules/i18n/provider.js +1 -1
  53. package/dist/modules/i18n/providers/fetch.js +1 -1
  54. package/dist/modules/i18n/providers/namespace.js +1 -1
  55. package/dist/modules/i18n/translations.js +1 -1
  56. package/dist/modules/logging/handler/console.js +1 -1
  57. package/dist/modules/logging/handler/namespace.js +1 -1
  58. package/dist/modules/logging/handler.js +1 -1
  59. package/dist/modules/logging/logentry.js +1 -1
  60. package/dist/modules/logging/logger.js +1 -1
  61. package/dist/modules/logging/namespace.js +1 -1
  62. package/dist/modules/math/namespace.js +1 -1
  63. package/dist/modules/math/random.js +1 -1
  64. package/dist/modules/monster.js +1 -1
  65. package/dist/modules/namespace.js +1 -1
  66. package/dist/modules/text/formatter.js +1 -1
  67. package/dist/modules/text/namespace.js +1 -1
  68. package/dist/modules/types/base.js +1 -1
  69. package/dist/modules/types/basewithoptions.js +1 -1
  70. package/dist/modules/types/binary.js +1 -1
  71. package/dist/modules/types/dataurl.js +1 -1
  72. package/dist/modules/types/global.js +1 -1
  73. package/dist/modules/types/id.js +1 -1
  74. package/dist/modules/types/is.js +1 -1
  75. package/dist/modules/types/mediatype.js +1 -1
  76. package/dist/modules/types/namespace.js +1 -1
  77. package/dist/modules/types/node.js +2 -2
  78. package/dist/modules/types/nodelist.js +2 -2
  79. package/dist/modules/types/noderecursiveiterator.js +2 -2
  80. package/dist/modules/types/observer.js +1 -1
  81. package/dist/modules/types/observerlist.js +1 -1
  82. package/dist/modules/types/proxyobserver.js +1 -1
  83. package/dist/modules/types/queue.js +1 -1
  84. package/dist/modules/types/randomid.js +1 -1
  85. package/dist/modules/types/regex.js +1 -1
  86. package/dist/modules/types/stack.js +1 -1
  87. package/dist/modules/types/tokenlist.js +1 -1
  88. package/dist/modules/types/typeof.js +1 -1
  89. package/dist/modules/types/uniquequeue.js +1 -1
  90. package/dist/modules/types/uuid.js +1 -1
  91. package/dist/modules/types/validate.js +1 -1
  92. package/dist/modules/types/version.js +2 -2
  93. package/dist/modules/util/clone.js +1 -1
  94. package/dist/modules/util/comparator.js +1 -1
  95. package/dist/modules/util/freeze.js +1 -1
  96. package/dist/modules/util/namespace.js +1 -1
  97. package/dist/modules/util/processing.js +1 -1
  98. package/dist/modules/util/trimspaces.js +1 -1
  99. package/dist/monster.dev.js +883 -604
  100. package/dist/monster.dev.js.map +1 -1
  101. package/dist/monster.js +2 -2
  102. package/package.json +1 -1
  103. package/source/constraints/andoperator.js +5 -5
  104. package/source/constraints/invalid.js +3 -3
  105. package/source/constraints/isarray.js +3 -3
  106. package/source/constraints/isobject.js +3 -3
  107. package/source/constraints/oroperator.js +5 -5
  108. package/source/constraints/valid.js +3 -3
  109. package/source/data/buildmap.js +8 -10
  110. package/source/data/buildtree.js +51 -17
  111. package/source/data/datasource/restapi.js +3 -3
  112. package/source/data/datasource/storage/localstorage.js +2 -2
  113. package/source/data/datasource/storage/sessionstorage.js +2 -2
  114. package/source/data/datasource/storage.js +3 -3
  115. package/source/data/datasource.js +3 -3
  116. package/source/data/diff.js +3 -3
  117. package/source/data/extend.js +2 -2
  118. package/source/data/pathfinder.js +4 -4
  119. package/source/data/pipe.js +3 -3
  120. package/source/data/transformer.js +3 -3
  121. package/source/dom/assembler.js +2 -2
  122. package/source/dom/attributes.js +111 -28
  123. package/source/dom/constants.js +17 -1
  124. package/source/dom/customcontrol.js +1 -1
  125. package/source/dom/customelement.js +1 -1
  126. package/source/dom/events.js +68 -12
  127. package/source/dom/focusmanager.js +2 -2
  128. package/source/dom/locale.js +2 -2
  129. package/source/dom/resource/data.js +2 -2
  130. package/source/dom/resource/link/stylesheet.js +2 -2
  131. package/source/dom/resource/link.js +2 -2
  132. package/source/dom/resource/script.js +2 -2
  133. package/source/dom/resource.js +2 -2
  134. package/source/dom/resourcemanager.js +2 -2
  135. package/source/dom/template.js +55 -15
  136. package/source/dom/theme.js +3 -3
  137. package/source/dom/updater.js +156 -96
  138. package/source/dom/util.js +6 -6
  139. package/source/dom/worker/factory.js +2 -2
  140. package/source/i18n/formatter.js +4 -4
  141. package/source/i18n/locale.js +4 -4
  142. package/source/i18n/provider.js +2 -2
  143. package/source/i18n/providers/fetch.js +3 -3
  144. package/source/i18n/translations.js +4 -4
  145. package/source/logging/handler/console.js +2 -2
  146. package/source/logging/handler.js +2 -2
  147. package/source/logging/logentry.js +2 -2
  148. package/source/logging/logger.js +2 -2
  149. package/source/math/random.js +2 -2
  150. package/source/namespace.js +1 -1
  151. package/source/text/formatter.js +3 -3
  152. package/source/types/base.js +2 -2
  153. package/source/types/basewithoptions.js +2 -2
  154. package/source/types/binary.js +4 -4
  155. package/source/types/dataurl.js +4 -4
  156. package/source/types/global.js +4 -4
  157. package/source/types/id.js +2 -2
  158. package/source/types/is.js +20 -20
  159. package/source/types/mediatype.js +4 -4
  160. package/source/types/node.js +33 -2
  161. package/source/types/nodelist.js +9 -5
  162. package/source/types/noderecursiveiterator.js +29 -7
  163. package/source/types/observer.js +3 -3
  164. package/source/types/observerlist.js +2 -2
  165. package/source/types/proxyobserver.js +5 -5
  166. package/source/types/queue.js +3 -3
  167. package/source/types/randomid.js +2 -2
  168. package/source/types/regex.js +2 -2
  169. package/source/types/stack.js +2 -2
  170. package/source/types/tokenlist.js +2 -2
  171. package/source/types/typeof.js +3 -3
  172. package/source/types/uniquequeue.js +2 -2
  173. package/source/types/uuid.js +2 -2
  174. package/source/types/validate.js +20 -20
  175. package/source/types/version.js +6 -6
  176. package/source/util/clone.js +2 -2
  177. package/source/util/comparator.js +3 -3
  178. package/source/util/freeze.js +2 -2
  179. package/source/util/processing.js +3 -3
  180. package/source/util/trimspaces.js +2 -2
  181. package/test/cases/data/buildtree.js +84 -21
  182. package/test/cases/dom/attributes.js +29 -6
  183. package/test/cases/dom/events.js +66 -1
  184. package/test/cases/dom/template.js +72 -14
  185. package/test/cases/dom/updater.js +102 -75
  186. package/test/cases/monster.js +1 -1
  187. package/test/cases/types/node.js +57 -1
  188. package/test/cases/types/nodelist.js +7 -0
  189. package/test/cases/types/noderecursiveiterator.js +21 -0
  190. package/test/web/monster-dev.html +3 -3
  191. package/test/web/monster.html +2 -2
  192. package/test/web/test.html +3 -3
  193. package/test/web/tests.js +2 -2
@@ -14,7 +14,7 @@ import {validateObject} from '../types/validate.js';
14
14
  *
15
15
  * ```
16
16
  * <script type="module">
17
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.26.0/dist/monster.js';
17
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.28.1/dist/monster.js';
18
18
  * Monster.Util.deepFreeze({})
19
19
  * </script>
20
20
  * ```
@@ -23,7 +23,7 @@ import {validateObject} from '../types/validate.js';
23
23
  *
24
24
  * ```
25
25
  * <script type="module">
26
- * import {deepFreeze} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.26.0/dist/modules/util/freeze.js';
26
+ * import {deepFreeze} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.28.1/dist/modules/util/freeze.js';
27
27
  * deepFreeze({})
28
28
  * </script>
29
29
  * ```
@@ -77,7 +77,7 @@ class Callback {
77
77
  *
78
78
  * ```
79
79
  * <script type="module">
80
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.26.0/dist/monster.js';
80
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.28.1/dist/monster.js';
81
81
  * new Monster.Util.Processing()
82
82
  * </script>
83
83
  * ```
@@ -86,13 +86,13 @@ class Callback {
86
86
  *
87
87
  * ```
88
88
  * <script type="module">
89
- * import {Processing} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.26.0/dist/modules/util/processing.js';
89
+ * import {Processing} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.28.1/dist/modules/util/processing.js';
90
90
  * new Processing();
91
91
  * </script>
92
92
  * ```
93
93
  *
94
94
  * @example
95
- * import {Processing} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.26.0/dist/modules/util/processing.js';
95
+ * import {Processing} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.28.1/dist/modules/util/processing.js';
96
96
  *
97
97
  * let startTime = +new Date();
98
98
  *
@@ -16,7 +16,7 @@ import {validateString} from "../types/validate.js";
16
16
  *
17
17
  * ```
18
18
  * <script type="module">
19
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.26.0/dist/monster.js';
19
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.28.1/dist/monster.js';
20
20
  * Monster.Util.trimSpaces(" hello ")
21
21
  * </script>
22
22
  * ```
@@ -25,7 +25,7 @@ import {validateString} from "../types/validate.js";
25
25
  *
26
26
  * ```
27
27
  * <script type="module">
28
- * import {trimSpaces} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.26.0/dist/modules/util/trimspaces.js';
28
+ * import {trimSpaces} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.28.1/dist/modules/util/trimspaces.js';
29
29
  * trimSpaces(' hello \\ ')
30
30
  * </script>
31
31
  * ```
@@ -3,7 +3,6 @@
3
3
  import {expect} from "chai"
4
4
  import {buildTree} from "../../../source/data/buildtree.js";
5
5
  import {NodeList} from "../../../source/types/nodelist.js";
6
- import {NodeRecursiveIterator} from "../../../source/types/noderecursiveiterator.js";
7
6
 
8
7
 
9
8
  describe('buildTree', function () {
@@ -50,18 +49,9 @@ describe('buildTree', function () {
50
49
 
51
50
  const nodes = buildTree(objects, 'dataset.*', 'id', 'parent');
52
51
 
53
- let result = ""
54
- nodes.forEach(node => {
55
- new NodeRecursiveIterator(node).forEach(n => {
56
- result +="".padStart(n.level * 2, '.') + (n.value.name);
57
- });
58
-
59
- });
60
-
61
- expect(result).to.be.equal('vehicle..car....SUV....sports car..truck..motorcycle');
62
52
  expect(nodes).to.be.instanceOf(NodeList);
63
53
  expect(nodes.length).to.equal(1);
64
- expect(nodes.length).to.equal(1);
54
+ expect(nodes.toString()).to.be.equal('{"id":"1","name":"vehicle","parent":null}\n ├{"id":"2","name":"car","parent":"1"}\n | ├{"id":"5","name":"SUV","parent":"2"}\n | └{"id":"6","name":"sports car","parent":"2"}\n ├{"id":"3","name":"truck","parent":"1"}\n └{"id":"4","name":"motorcycle","parent":"1"}' );
65
55
 
66
56
 
67
57
  })
@@ -116,9 +106,9 @@ describe('buildTree', function () {
116
106
  });
117
107
 
118
108
  [
119
- [obj1, 'dataset.*', '1,2,3,4,6,5'],
109
+ [obj1, 'dataset.*', '{"id":"1","name":"Test 1","address":"Here 1","parent":null}\n ├{"id":"2","name":"Test 2","address":"Here 2","parent":"1"}\n | ├{"id":"3","name":"Test 3","address":"Here 3","parent":"2"}\n | └{"id":"4","name":"Test 4","address":"Here 4","parent":"2"}\n | | └{"id":"6","name":"Test 6","address":"Here 6","parent":"4"}\n └{"id":"5","name":"Test 5","address":"Here 5","parent":"1"}'],
120
110
  [obj1, 'x', ''],
121
- [obj1, 'dataset.*', '1,2,3,4,6,5'],
111
+ [obj1, 'dataset.*', '{"id":"1","name":"Test 1","address":"Here 1","parent":null}\n ├{"id":"2","name":"Test 2","address":"Here 2","parent":"1"}\n | ├{"id":"3","name":"Test 3","address":"Here 3","parent":"2"}\n | └{"id":"4","name":"Test 4","address":"Here 4","parent":"2"}\n | | └{"id":"6","name":"Test 6","address":"Here 6","parent":"4"}\n └{"id":"5","name":"Test 5","address":"Here 5","parent":"1"}'],
122
112
  ].forEach(function (data) {
123
113
 
124
114
  let a = data.shift()
@@ -127,18 +117,91 @@ describe('buildTree', function () {
127
117
 
128
118
  it('buildTree(' + JSON.stringify(a) + ',' + JSON.stringify(b) + ') should return ' + JSON.stringify(c) + ' ', function () {
129
119
  let nodelist = buildTree(a, b, 'id', 'parent');
120
+ expect(nodelist.toString()).to.be.eql(c);
121
+ });
122
+ });
130
123
 
131
- let result = [];
132
124
 
133
- const firstNode = nodelist.toArray().shift();
134
-
135
- if (firstNode) {
136
- for (const node of new NodeRecursiveIterator(firstNode)) {
137
- result.push(node.value.id);
138
- }
125
+ });
126
+
127
+ describe('buildTree() test 2', function () {
128
+
129
+ /**
130
+ * 2
131
+ * 1
132
+ * 3
133
+ * 4
134
+ * 6
135
+ * 5
136
+ *
137
+ */
138
+ let obj1 = {
139
+ dataset: {
140
+ "1": {
141
+ id: "1",
142
+ name: "Test 1",
143
+ address: "Here 1",
144
+ parent: "2"
145
+ },
146
+ "2": {
147
+ id: "2",
148
+ name: "Test 2",
149
+ address: "Here 2",
150
+ parent: "0"
151
+ },
152
+ "3": {
153
+ id: "3",
154
+ name: "Test 3",
155
+ address: "Here 3",
156
+ parent: "2"
157
+ },
158
+ "4": {
159
+ id: "4",
160
+ name: "Test 4",
161
+ address: "Here 4",
162
+ parent: "0"
163
+ },
164
+ "5": {
165
+ id: "5",
166
+ name: "Test 5",
167
+ address: "Here 5",
168
+ parent: "0"
169
+ },
170
+ "6": {
171
+ id: "6",
172
+ name: "Test 6",
173
+ address: "Here 6",
174
+ parent: "4"
175
+ },
176
+ "7": {
177
+ id: "7",
178
+ name: "Test 7",
179
+ address: "Here 7",
180
+ parent: "1"
139
181
  }
182
+ }
183
+ };
184
+
185
+ it('should return Node Instance.', function () {
186
+ expect(buildTree({}, '')).to.be.instanceOf(NodeList);
187
+ });
188
+
189
+ [
190
+ [obj1, 'dataset.*', '{"id":"2","name":"Test 2","address":"Here 2","parent":"0"}\n ├{"id":"1","name":"Test 1","address":"Here 1","parent":"2"}\n | └{"id":"7","name":"Test 7","address":"Here 7","parent":"1"}\n └{"id":"3","name":"Test 3","address":"Here 3","parent":"2"}\n{"id":"4","name":"Test 4","address":"Here 4","parent":"0"}\n └{"id":"6","name":"Test 6","address":"Here 6","parent":"4"}\n{"id":"5","name":"Test 5","address":"Here 5","parent":"0"}'],
191
+ [obj1, 'x', ''],
192
+ ].forEach(function (data) {
193
+
194
+ let a = data.shift()
195
+ let b = data.shift()
196
+ let c = data.shift()
197
+
198
+ it('buildTree(' + JSON.stringify(a) + ',' + JSON.stringify(b) + ') should return ' + JSON.stringify(c) + ' ', function () {
199
+ let nodelist = buildTree(a, b, 'id', 'parent', {
200
+ rootReferences: ['0']
201
+ });
202
+
203
+ expect(nodelist.toString()).to.be.equal(c);
140
204
 
141
- expect(result.join(',')).to.be.equal(c);
142
205
  });
143
206
  });
144
207
 
@@ -14,7 +14,8 @@ import {
14
14
  removeAttributeToken,
15
15
  removeObjectLink,
16
16
  replaceAttributeToken,
17
- toggleAttributeToken
17
+ toggleAttributeToken,
18
+ findClosestByClass
18
19
  } from "../../../source/dom/attributes.js";
19
20
 
20
21
  import {initJSDOM} from "../../util/jsdom.js";
@@ -37,12 +38,13 @@ describe('Attributes', function () {
37
38
  </div>
38
39
  </div>
39
40
  `;
41
+
40
42
  html3 = `<div data-monster-role="test1">
41
- <div data-monster-role="sub1" id="a1">
42
- <div data-monster-role="sub2" id="a2">
43
- <div data-monster-role="sub3" id="a3">
44
- <div data-monster-role="sub4" id="a4">
45
- <div data-monster-role="sub5" id="a5"></div>
43
+ <div data-monster-role="sub1" id="a1" class="sub1">
44
+ <div data-monster-role="sub2" id="a2" class="sub2">
45
+ <div data-monster-role="sub3" id="a3" class="sub3">
46
+ <div data-monster-role="sub4" id="a4" class="sub4">
47
+ <div data-monster-role="sub5" id="a5" class="sub5"></div>
46
48
  </div>
47
49
  </div>
48
50
  </div>
@@ -154,6 +156,27 @@ describe('Attributes', function () {
154
156
  })
155
157
 
156
158
 
159
+ });
160
+ });
161
+
162
+ describe('find closest Element with class', function () {
163
+
164
+ [
165
+ ['a5', 'sub3', 'sub3'],
166
+ ['a5', 'sub1', 'sub1'],
167
+ ['a4', 'sub1', 'sub1'],
168
+ ['a3', 'sub1', 'sub1'],
169
+ ['a5', 'sub5', 'sub5']
170
+ ].forEach(function (data) {
171
+
172
+ let a = data.shift()
173
+ let b = data.shift()
174
+ let c = data.shift()
175
+ it('findClosestByClass(' + a + ', ' + b + ') should return ' + c, function () {
176
+ expect(findClosestByClass(document.getElementById(a), b).getAttribute('class')).to.be.equal(c);
177
+ })
178
+
179
+
157
180
  });
158
181
  });
159
182
  });
@@ -2,7 +2,7 @@
2
2
 
3
3
  import {expect} from "chai"
4
4
 
5
- import {fireEvent, findTargetElementFromEvent} from "../../../source/dom/events.js";
5
+ import {fireEvent, findTargetElementFromEvent, fireCustomEvent} from "../../../source/dom/events.js";
6
6
  import {initJSDOM} from "../../util/jsdom.js";
7
7
 
8
8
  describe('Events', function () {
@@ -78,6 +78,71 @@ describe('Events', function () {
78
78
  expect(() => fireEvent({}, 'touch')).to.throw(Error);
79
79
 
80
80
  });
81
+ });
82
+
83
+ describe('fireCustomEvent()', function () {
84
+ it('should fire a click event', function (done) {
85
+ let div = document.createElement('div');
86
+ div.addEventListener('click', () => {
87
+ done();
88
+ })
89
+ fireCustomEvent(div, 'click');
90
+ });
91
+
92
+ it('should fire a touch event', function (done) {
93
+ let div = document.createElement('div');
94
+ div.addEventListener('touch', () => {
95
+ done();
96
+ })
97
+ fireCustomEvent(div, 'touch');
98
+ });
99
+
100
+ it('should fire a touch event on collection1', function (done) {
101
+ let div = document.createElement('div');
102
+ div.addEventListener('touch', (e) => {
103
+ if(e.detail.detail!=='hello world') {
104
+ done('error');
105
+ }
106
+ done();
107
+ })
108
+
109
+ div.appendChild(document.createElement('div'));
110
+ let collection = div.querySelectorAll('div');
111
+
112
+ fireCustomEvent(collection, 'touch', "hello world");
113
+ });
114
+
115
+ it('should fire a touch event on collection2', function (done) {
116
+ let div = document.createElement('div');
117
+ div.addEventListener('touch', (e) => {
118
+ if(e.detail.a!=='hello world') {
119
+ done('error');
120
+ }
121
+ done();
122
+ })
123
+
124
+ div.appendChild(document.createElement('div'));
125
+ let collection = div.querySelectorAll('div');
126
+
127
+ fireCustomEvent(collection, 'touch', {a:"hello world"});
128
+ });
129
+
130
+ it('should fire a touch event', function (done) {
131
+ let div = document.createElement('div');
132
+ div.addEventListener('touch', () => {
133
+ done();
134
+ })
135
+
136
+ div.appendChild(document.createElement('div'));
137
+ let collection = div.querySelectorAll('div');
138
+
139
+
140
+ fireCustomEvent(collection, 'touch');
141
+ });
142
+
143
+ it('should throw error', function () {
144
+ expect(() => fireCustomEvent({}, 'touch')).to.throw(Error);
145
+ });
81
146
  });
82
147
 
83
148
 
@@ -1,16 +1,11 @@
1
1
  'use strict';
2
2
 
3
3
  import {expect} from "chai"
4
+ import {ATTRIBUTE_THEME_NAME} from "../../../source/dom/constants.js";
4
5
 
5
6
  import {findDocumentTemplate, Template} from "../../../source/dom/template.js";
6
7
  import {initJSDOM} from "../../util/jsdom.js";
7
8
 
8
- const html1 = `
9
-
10
- <template id="mytemplate"></template>
11
-
12
- `;
13
-
14
9
 
15
10
  describe('Template', function () {
16
11
 
@@ -20,7 +15,8 @@ describe('Template', function () {
20
15
 
21
16
  beforeEach(() => {
22
17
  let mocks = document.getElementById('mocks');
23
- mocks.innerHTML = html1;
18
+ mocks.innerHTML = `
19
+ <template id="mytemplate"></template>`;
24
20
  })
25
21
 
26
22
  afterEach(() => {
@@ -75,14 +71,76 @@ describe('Template', function () {
75
71
  });
76
72
 
77
73
  describe('.findDocumentTemplate()', function () {
78
- it('should throw Template not found', function () {
79
- const div = document.createElement('div');
80
- div.remove();
81
- let t = findDocumentTemplate("mytemplate", div);
82
- expect(t).is.instanceof(Template);
74
+ describe('Template', function () {
75
+ it('should find template over ownerDocument', function () {
76
+ const div = document.createElement('div');
77
+ div.remove();
78
+ let t = findDocumentTemplate("mytemplate", div);
79
+ expect(t).is.instanceof(Template);
80
+
81
+ })
82
+ });
83
83
 
84
- })
85
- });
84
+ describe('Thmened Template', function () {
85
+ let memAttributeValue;
86
+
87
+ beforeEach(() => {
88
+ let mocks = document.getElementById('mocks');
89
+ mocks.innerHTML = `
90
+ <template id="mytemplate"><p>1</p></template>
91
+ <template id="mytemplate-monster"><p>2</p></template>
92
+ <template id="mytemplate-testtheme"><p>4</p></template>
93
+ <template id="myprefix-mytemplate-monster"><p>3</p></template>
94
+ `;
95
+
96
+ let html = document.querySelector('html');
97
+ if (html.hasAttribute(ATTRIBUTE_THEME_NAME)) {
98
+ memAttributeValue = html.getAttribute(ATTRIBUTE_THEME_NAME)
99
+ }
100
+
101
+ })
102
+
103
+ afterEach(() => {
104
+ let mocks = document.getElementById('mocks');
105
+ mocks.innerHTML = "";
86
106
 
107
+ let html = document.querySelector('html');
87
108
 
109
+ if (html.hasAttribute(ATTRIBUTE_THEME_NAME)) {
110
+ html.removeAttribute(ATTRIBUTE_THEME_NAME);
111
+ }
112
+
113
+ if (memAttributeValue) {
114
+ html.setAttribute(ATTRIBUTE_THEME_NAME, memAttributeValue)
115
+ }
116
+
117
+ })
118
+
119
+
120
+ it('should find template over ownerDocument', function () {
121
+ let html = document.querySelector('html');
122
+ const div = document.createElement('div');
123
+ div.setAttribute('data-monster-template-prefix', 'myprefix')
124
+ div.remove();
125
+ let t1 = findDocumentTemplate("mytemplate", div);
126
+ expect(t1).is.instanceof(Template);
127
+ expect(t1.createDocumentFragment().textContent).is.equal("3");
128
+
129
+ div.removeAttribute('data-monster-template-prefix')
130
+ let t2 = findDocumentTemplate("mytemplate", div);
131
+ expect(t2).is.instanceof(Template);
132
+ expect(t2.createDocumentFragment().textContent).is.equal("2");
133
+
134
+ html.setAttribute(ATTRIBUTE_THEME_NAME,'testtheme');
135
+ let a= html.outerHTML;
136
+ let t3 = findDocumentTemplate("mytemplate", div);
137
+ expect(t3).is.instanceof(Template);
138
+ expect(t3.createDocumentFragment().textContent).is.equal("4");
139
+
140
+
141
+ })
142
+ });
143
+
144
+
145
+ });
88
146
  });