@schukai/monster 1.29.1 → 1.30.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (190) hide show
  1. package/CHANGELOG +19 -0
  2. package/README.md +3 -3
  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 +2 -2
  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 +2 -2
  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 +2 -2
  27. package/dist/modules/data/pipe.js +1 -1
  28. package/dist/modules/data/transformer.js +2 -2
  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 +2 -2
  34. package/dist/modules/dom/events.js +1 -1
  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 +2 -2
  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 +2 -2
  49. package/dist/modules/i18n/formatter.js +2 -2
  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 +2 -2
  64. package/dist/modules/monster.js +1 -1
  65. package/dist/modules/namespace.js +1 -1
  66. package/dist/modules/text/formatter.js +2 -2
  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 +2 -2
  70. package/dist/modules/types/binary.js +1 -1
  71. package/dist/modules/types/dataurl.js +2 -2
  72. package/dist/modules/types/global.js +1 -1
  73. package/dist/modules/types/id.js +2 -2
  74. package/dist/modules/types/is.js +1 -1
  75. package/dist/modules/types/mediatype.js +2 -2
  76. package/dist/modules/types/namespace.js +1 -1
  77. package/dist/modules/types/node.js +1 -1
  78. package/dist/modules/types/nodelist.js +1 -1
  79. package/dist/modules/types/noderecursiveiterator.js +1 -1
  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 +2 -2
  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 +2 -2
  90. package/dist/modules/types/uuid.js +2 -2
  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/deadmansswitch.js +1 -1
  96. package/dist/modules/util/freeze.js +1 -1
  97. package/dist/modules/util/namespace.js +1 -1
  98. package/dist/modules/util/processing.js +1 -1
  99. package/dist/modules/util/trimspaces.js +2 -2
  100. package/dist/monster.dev.js +394 -255
  101. package/dist/monster.dev.js.map +1 -1
  102. package/dist/monster.js +2 -2
  103. package/package.json +1 -1
  104. package/source/constraints/andoperator.js +5 -5
  105. package/source/constraints/invalid.js +3 -3
  106. package/source/constraints/isarray.js +3 -3
  107. package/source/constraints/isobject.js +3 -3
  108. package/source/constraints/oroperator.js +5 -5
  109. package/source/constraints/valid.js +3 -3
  110. package/source/data/buildmap.js +12 -5
  111. package/source/data/buildtree.js +2 -2
  112. package/source/data/datasource/restapi.js +3 -3
  113. package/source/data/datasource/storage/localstorage.js +2 -2
  114. package/source/data/datasource/storage/sessionstorage.js +2 -2
  115. package/source/data/datasource/storage.js +3 -3
  116. package/source/data/datasource.js +3 -3
  117. package/source/data/diff.js +3 -3
  118. package/source/data/extend.js +2 -2
  119. package/source/data/pathfinder.js +5 -4
  120. package/source/data/pipe.js +3 -3
  121. package/source/data/transformer.js +3 -3
  122. package/source/dom/assembler.js +2 -2
  123. package/source/dom/attributes.js +27 -27
  124. package/source/dom/constants.js +11 -1
  125. package/source/dom/customcontrol.js +1 -1
  126. package/source/dom/customelement.js +137 -31
  127. package/source/dom/events.js +6 -6
  128. package/source/dom/focusmanager.js +2 -2
  129. package/source/dom/locale.js +2 -2
  130. package/source/dom/resource/data.js +2 -2
  131. package/source/dom/resource/link/stylesheet.js +2 -2
  132. package/source/dom/resource/link.js +2 -2
  133. package/source/dom/resource/script.js +2 -2
  134. package/source/dom/resource.js +2 -2
  135. package/source/dom/resourcemanager.js +2 -2
  136. package/source/dom/template.js +5 -5
  137. package/source/dom/theme.js +3 -3
  138. package/source/dom/updater.js +3 -3
  139. package/source/dom/util.js +6 -6
  140. package/source/dom/worker/factory.js +2 -2
  141. package/source/i18n/formatter.js +4 -4
  142. package/source/i18n/locale.js +4 -4
  143. package/source/i18n/provider.js +2 -2
  144. package/source/i18n/providers/fetch.js +3 -3
  145. package/source/i18n/translations.js +4 -4
  146. package/source/logging/handler/console.js +2 -2
  147. package/source/logging/handler.js +2 -2
  148. package/source/logging/logentry.js +2 -2
  149. package/source/logging/logger.js +2 -2
  150. package/source/math/random.js +2 -2
  151. package/source/namespace.js +1 -1
  152. package/source/text/formatter.js +3 -3
  153. package/source/types/base.js +2 -2
  154. package/source/types/basewithoptions.js +2 -2
  155. package/source/types/binary.js +4 -4
  156. package/source/types/dataurl.js +4 -4
  157. package/source/types/global.js +4 -4
  158. package/source/types/id.js +2 -2
  159. package/source/types/is.js +20 -20
  160. package/source/types/mediatype.js +4 -4
  161. package/source/types/node.js +2 -2
  162. package/source/types/nodelist.js +2 -2
  163. package/source/types/noderecursiveiterator.js +4 -4
  164. package/source/types/observer.js +3 -3
  165. package/source/types/observerlist.js +2 -2
  166. package/source/types/proxyobserver.js +5 -5
  167. package/source/types/queue.js +3 -3
  168. package/source/types/randomid.js +2 -2
  169. package/source/types/regex.js +2 -2
  170. package/source/types/stack.js +2 -2
  171. package/source/types/tokenlist.js +2 -2
  172. package/source/types/typeof.js +3 -3
  173. package/source/types/uniquequeue.js +2 -2
  174. package/source/types/uuid.js +2 -2
  175. package/source/types/validate.js +20 -20
  176. package/source/types/version.js +6 -6
  177. package/source/util/clone.js +2 -2
  178. package/source/util/comparator.js +3 -3
  179. package/source/util/deadmansswitch.js +3 -3
  180. package/source/util/freeze.js +2 -2
  181. package/source/util/processing.js +3 -3
  182. package/source/util/trimspaces.js +2 -2
  183. package/test/cases/dom/customelement.js +236 -3
  184. package/test/cases/dom/resource/link.js +3 -5
  185. package/test/cases/monster.js +1 -1
  186. package/test/util/jsdom.js +1 -0
  187. package/test/web/monster-dev.html +3 -3
  188. package/test/web/monster.html +2 -2
  189. package/test/web/test.html +3 -2
  190. package/test/web/tests.js +7 -13
@@ -20,7 +20,7 @@ import {ATTRIBUTE_OBJECTLINK} from "./constants.js";
20
20
  *
21
21
  * ```
22
22
  * <script type="module">
23
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
23
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
24
24
  * console.log(Monster.DOM.findClosestObjectLink())
25
25
  * </script>
26
26
  * ```
@@ -29,7 +29,7 @@ import {ATTRIBUTE_OBJECTLINK} from "./constants.js";
29
29
  *
30
30
  * ```
31
31
  * <script type="module">
32
- * import {getUpdaterFromNode} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/updater.js';
32
+ * import {getUpdaterFromNode} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/updater.js';
33
33
  * console.log(findClosestObjectLink())
34
34
  * </script>
35
35
  * ```
@@ -50,7 +50,7 @@ function findClosestObjectLink(element) {
50
50
  *
51
51
  * ```
52
52
  * <script type="module">
53
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
53
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
54
54
  * Monster.DOM.addToObjectLink();
55
55
  * </script>
56
56
  * ```
@@ -59,7 +59,7 @@ function findClosestObjectLink(element) {
59
59
  *
60
60
  * ```
61
61
  * <script type="module">
62
- * import {addToObjectLink} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
62
+ * import {addToObjectLink} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
63
63
  * addToObjectLink();
64
64
  * </script>
65
65
  * ```
@@ -92,7 +92,7 @@ function addToObjectLink(element, symbol, object) {
92
92
  *
93
93
  * ```
94
94
  * <script type="module">
95
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
95
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
96
96
  * Monster.DOM.removeObjectLink();
97
97
  * </script>
98
98
  * ```
@@ -101,7 +101,7 @@ function addToObjectLink(element, symbol, object) {
101
101
  *
102
102
  * ```
103
103
  * <script type="module">
104
- * import {removeObjectLink} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
104
+ * import {removeObjectLink} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
105
105
  * removeObjectLink();
106
106
  * </script>
107
107
  * ```
@@ -134,7 +134,7 @@ function removeObjectLink(element, symbol) {
134
134
  *
135
135
  * ```
136
136
  * <script type="module">
137
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
137
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
138
138
  * Monster.DOM.hasObjectLink();
139
139
  * </script>
140
140
  * ```
@@ -143,7 +143,7 @@ function removeObjectLink(element, symbol) {
143
143
  *
144
144
  * ```
145
145
  * <script type="module">
146
- * import {hasObjectLink} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
146
+ * import {hasObjectLink} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
147
147
  * hasObjectLink();
148
148
  * </script>
149
149
  * ```
@@ -180,7 +180,7 @@ function hasObjectLink(element, symbol) {
180
180
  *
181
181
  * ```
182
182
  * <script type="module">
183
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
183
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
184
184
  * Monster.DOM.getLinkedObjects();
185
185
  * </script>
186
186
  * ```
@@ -189,7 +189,7 @@ function hasObjectLink(element, symbol) {
189
189
  *
190
190
  * ```
191
191
  * <script type="module">
192
- * import {getLinkedObjects} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
192
+ * import {getLinkedObjects} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
193
193
  * getLinkedObjects();
194
194
  * </script>
195
195
  * ```
@@ -225,7 +225,7 @@ function getLinkedObjects(element, symbol) {
225
225
  *
226
226
  * ```
227
227
  * <script type="module">
228
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
228
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
229
229
  * Monster.DOM.toggleAttributeToken();
230
230
  * </script>
231
231
  * ```
@@ -234,7 +234,7 @@ function getLinkedObjects(element, symbol) {
234
234
  *
235
235
  * ```
236
236
  * <script type="module">
237
- * import {toggleAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
237
+ * import {toggleAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
238
238
  * toggleAttributeToken();
239
239
  * </script>
240
240
  * ```
@@ -263,13 +263,13 @@ function toggleAttributeToken(element, key, token) {
263
263
  }
264
264
 
265
265
  /**
266
- * this method can be used to add a token to an attribute. Tokens are always separated by a space.
266
+ * This method can be used to add a token to an attribute. Tokens are always separated by a space.
267
267
  *
268
268
  * You can call the method via the monster namespace `new Monster.DOM.addAttributeToken()`.
269
269
  *
270
270
  * ```
271
271
  * <script type="module">
272
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
272
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
273
273
  * Monster.DOM.addAttributeToken();
274
274
  * </script>
275
275
  * ```
@@ -278,7 +278,7 @@ function toggleAttributeToken(element, key, token) {
278
278
  *
279
279
  * ```
280
280
  * <script type="module">
281
- * import {addAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
281
+ * import {addAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
282
282
  * addAttributeToken();
283
283
  * </script>
284
284
  * ```
@@ -315,7 +315,7 @@ function addAttributeToken(element, key, token) {
315
315
  *
316
316
  * ```
317
317
  * <script type="module">
318
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
318
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
319
319
  * Monster.DOM.removeAttributeToken();
320
320
  * </script>
321
321
  * ```
@@ -324,7 +324,7 @@ function addAttributeToken(element, key, token) {
324
324
  *
325
325
  * ```
326
326
  * <script type="module">
327
- * import {removeAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
327
+ * import {removeAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
328
328
  * removeAttributeToken();
329
329
  * </script>
330
330
  * ```
@@ -360,7 +360,7 @@ function removeAttributeToken(element, key, token) {
360
360
  *
361
361
  * ```
362
362
  * <script type="module">
363
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
363
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
364
364
  * Monster.DOM.containsAttributeToken();
365
365
  * </script>
366
366
  * ```
@@ -369,7 +369,7 @@ function removeAttributeToken(element, key, token) {
369
369
  *
370
370
  * ```
371
371
  * <script type="module">
372
- * import {containsAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
372
+ * import {containsAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
373
373
  * containsAttributeToken();
374
374
  * </script>
375
375
  * ```
@@ -402,7 +402,7 @@ function containsAttributeToken(element, key, token) {
402
402
  *
403
403
  * ```
404
404
  * <script type="module">
405
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
405
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
406
406
  * Monster.DOM.replaceAttributeToken();
407
407
  * </script>
408
408
  * ```
@@ -411,7 +411,7 @@ function containsAttributeToken(element, key, token) {
411
411
  *
412
412
  * ```
413
413
  * <script type="module">
414
- * import {replaceAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
414
+ * import {replaceAttributeToken} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
415
415
  * replaceAttributeToken();
416
416
  * </script>
417
417
  * ```
@@ -447,7 +447,7 @@ function replaceAttributeToken(element, key, from, to) {
447
447
  *
448
448
  * ```
449
449
  * <script type="module">
450
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
450
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
451
451
  * Monster.DOM.clearAttributeTokens();
452
452
  * </script>
453
453
  * ```
@@ -456,7 +456,7 @@ function replaceAttributeToken(element, key, from, to) {
456
456
  *
457
457
  * ```
458
458
  * <script type="module">
459
- * import {clearAttributeTokens} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
459
+ * import {clearAttributeTokens} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
460
460
  * clearAttributeTokens();
461
461
  * </script>
462
462
  * ```
@@ -504,7 +504,7 @@ function clearAttributeTokens(element, key) {
504
504
  *
505
505
  * ```
506
506
  * <script type="module">
507
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
507
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
508
508
  * Monster.DOM.findClosestByAttribute();
509
509
  * </script>
510
510
  * ```
@@ -513,7 +513,7 @@ function clearAttributeTokens(element, key) {
513
513
  *
514
514
  * ```
515
515
  * <script type="module">
516
- * import {findClosestByAttribute} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
516
+ * import {findClosestByAttribute} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
517
517
  * findClosestByAttribute();
518
518
  * </script>
519
519
  * ```
@@ -569,7 +569,7 @@ function findClosestByAttribute(element, key, value) {
569
569
  *
570
570
  * ```
571
571
  * <script type="module">
572
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
572
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
573
573
  * Monster.DOM.findClosestByClass();
574
574
  * </script>
575
575
  * ```
@@ -578,7 +578,7 @@ function findClosestByAttribute(element, key, value) {
578
578
  *
579
579
  * ```
580
580
  * <script type="module">
581
- * import {findClosestByClass} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/attributes.js';
581
+ * import {findClosestByClass} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/attributes.js';
582
582
  * findClosestByClass();
583
583
  * </script>
584
584
  * ```
@@ -29,6 +29,15 @@ const ATTRIBUTE_PREFIX = 'data-monster-';
29
29
  */
30
30
  const ATTRIBUTE_OPTIONS = ATTRIBUTE_PREFIX + 'options';
31
31
 
32
+ /**
33
+ * This is the name of the attribute to pass options to a control
34
+ *
35
+ * @memberOf Monster.DOM
36
+ * @since 1.30.0
37
+ * @type {string}
38
+ */
39
+ const ATTRIBUTE_OPTIONS_SELECTOR = ATTRIBUTE_PREFIX + 'options-selector';
40
+
32
41
  /**
33
42
  * @memberOf Monster.DOM
34
43
  * @type {string}
@@ -430,5 +439,6 @@ export {
430
439
  ATTRIBUTE_VALUE,
431
440
  objectUpdaterLinkSymbol,
432
441
  ATTRIBUTE_TEMPLATE_PREFIX,
433
- ATTRIBUTE_UPDATER_SELECT_THIS
442
+ ATTRIBUTE_UPDATER_SELECT_THIS,
443
+ ATTRIBUTE_OPTIONS_SELECTOR
434
444
  }
@@ -30,7 +30,7 @@ const attachedInternalSymbol = Symbol('attachedInternal');
30
30
  *
31
31
  * ```
32
32
  * <script type="module">
33
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
33
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
34
34
  * document.createElement('monster-')
35
35
  * </script>
36
36
  * ```
@@ -15,11 +15,18 @@ import {Observer} from "../types/observer.js";
15
15
  import {ProxyObserver} from "../types/proxyobserver.js";
16
16
  import {validateFunction, validateInstance, validateObject, validateString} from "../types/validate.js";
17
17
  import {clone} from "../util/clone.js";
18
- import {addToObjectLink, getLinkedObjects, hasObjectLink} from "./attributes.js";
19
- import {ATTRIBUTE_DISABLED, ATTRIBUTE_OPTIONS, objectUpdaterLinkSymbol} from "./constants.js";
18
+ import {addAttributeToken, addToObjectLink, getLinkedObjects, hasObjectLink} from "./attributes.js";
19
+ import {
20
+ ATTRIBUTE_DISABLED,
21
+ ATTRIBUTE_ERRORMESSAGE,
22
+ ATTRIBUTE_OPTIONS,
23
+ ATTRIBUTE_OPTIONS_SELECTOR,
24
+ objectUpdaterLinkSymbol
25
+ } from "./constants.js";
20
26
  import {findDocumentTemplate, Template} from "./template.js";
21
27
  import {Updater} from "./updater.js";
22
28
 
29
+
23
30
  /**
24
31
  * @memberOf Monster.DOM
25
32
  * @type {symbol}
@@ -96,7 +103,7 @@ const attributeObserverSymbol = Symbol('attributeObserver');
96
103
  *
97
104
  * ```
98
105
  * <script type="module">
99
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
106
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
100
107
  * document.createElement('monster-')
101
108
  * </script>
102
109
  * ```
@@ -200,7 +207,7 @@ class CustomElement extends HTMLElement {
200
207
  */
201
208
  constructor() {
202
209
  super();
203
- this[internalSymbol] = new ProxyObserver({'options': extend({}, this.defaults, getOptionsFromAttributes.call(this))});
210
+ this[internalSymbol] = new ProxyObserver({'options': extend({}, this.defaults)});
204
211
  this[attributeObserverSymbol] = {};
205
212
  initOptionObserver.call(this);
206
213
  this[initMethodSymbol]();
@@ -242,6 +249,19 @@ class CustomElement extends HTMLElement {
242
249
  * })),'application/json',true).toString()
243
250
  * ```
244
251
  *
252
+ * The attribute data-monster-options-selector can be used to access a script tag that contains additional configuration.
253
+ *
254
+ * As value a selector must be specified, which belongs to a script tag and contains the configuration as json.
255
+ *
256
+ * ```
257
+ * <script id="id-for-this-config" type="application/json">
258
+ * {
259
+ * "config-key": "config-value"
260
+ * }
261
+ * </script>
262
+ * ```
263
+ *
264
+ *
245
265
  * @property {boolean} disabled=false Object The Boolean disabled attribute, when present, makes the element not mutable, focusable, or even submitted with the form.
246
266
  * @property {string} shadowMode=open `open` Elements of the shadow root are accessible from JavaScript outside the root, for example using. `close` Denies access to the node(s) of a closed shadow root from JavaScript outside it
247
267
  * @property {Boolean} delegatesFocus=true A boolean that, when set to true, specifies behavior that mitigates custom element issues around focusability. When a non-focusable part of the shadow DOM is clicked, the first focusable part is given focus, and the shadow host is given any available :focus styling.
@@ -373,7 +393,7 @@ class CustomElement extends HTMLElement {
373
393
  setOptions(options) {
374
394
 
375
395
  if (isString(options)) {
376
- options = parseOptionsJSON(options)
396
+ options = parseOptionsJSON.call(this, options)
377
397
  }
378
398
 
379
399
  const self = this;
@@ -403,6 +423,17 @@ class CustomElement extends HTMLElement {
403
423
  const self = this;
404
424
  let elements, nodeList;
405
425
 
426
+ const AttributeOptions = getOptionsFromAttributes.call(self);
427
+ if (isObject(AttributeOptions) && Object.keys(AttributeOptions).length > 0) {
428
+ self.setOptions(AttributeOptions);
429
+ }
430
+
431
+ const ScriptOptions = getOptionsFromScriptTag.call(self);
432
+ if (isObject(ScriptOptions) && Object.keys(ScriptOptions).length > 0) {
433
+ self.setOptions(ScriptOptions);
434
+ }
435
+
436
+
406
437
  if (self.getOption('shadowMode', false) !== false) {
407
438
  try {
408
439
  initShadowRoot.call(self);
@@ -415,7 +446,7 @@ class CustomElement extends HTMLElement {
415
446
  try {
416
447
  initCSSStylesheet.call(this);
417
448
  } catch (e) {
418
-
449
+ addAttributeToken(self, ATTRIBUTE_ERRORMESSAGE, e.toString());
419
450
  }
420
451
  }
421
452
 
@@ -662,7 +693,7 @@ function initOptionObserver() {
662
693
  }));
663
694
 
664
695
  // disabled
665
- self[attributeObserverSymbol][ATTRIBUTE_DISABLED] = (newVal) => {
696
+ self[attributeObserverSymbol][ATTRIBUTE_DISABLED] = () => {
666
697
  if (self.hasAttribute(ATTRIBUTE_DISABLED)) {
667
698
  self.setOption(ATTRIBUTE_DISABLED, true);
668
699
  } else {
@@ -673,7 +704,15 @@ function initOptionObserver() {
673
704
  // data-monster-options
674
705
  self[attributeObserverSymbol][ATTRIBUTE_OPTIONS] = () => {
675
706
  const options = getOptionsFromAttributes.call(self);
676
- if (isObject(options)) {
707
+ if (isObject(options) && Object.keys(options).length > 0) {
708
+ self.setOptions(options);
709
+ }
710
+ }
711
+
712
+ // data-monster-options-selector
713
+ self[attributeObserverSymbol][ATTRIBUTE_OPTIONS_SELECTOR] = () => {
714
+ const options = getOptionsFromScriptTag.call(self);
715
+ if (isObject(options) && Object.keys(options).length > 0) {
677
716
  self.setOptions(options);
678
717
  }
679
718
  }
@@ -684,14 +723,45 @@ function initOptionObserver() {
684
723
  /**
685
724
  * @private
686
725
  * @return {object}
687
- * @throws {Error} the options attribute does not contain a valid json definition.
726
+ * @throws {TypeError} value is not a object
727
+ */
728
+ function getOptionsFromScriptTag() {
729
+ const self = this;
730
+
731
+ if (!self.hasAttribute(ATTRIBUTE_OPTIONS_SELECTOR)) {
732
+ return {};
733
+ }
734
+
735
+ const node = document.querySelector(self.getAttribute(ATTRIBUTE_OPTIONS_SELECTOR));
736
+ if (!(node instanceof HTMLScriptElement)) {
737
+ addAttributeToken(self, ATTRIBUTE_ERRORMESSAGE, 'the selector ' + ATTRIBUTE_OPTIONS_SELECTOR + ' for options was specified (' + self.getAttribute(ATTRIBUTE_OPTIONS_SELECTOR) + ') but not found.');
738
+ return {};
739
+ }
740
+
741
+ let obj = {};
742
+
743
+ try {
744
+ obj = parseOptionsJSON.call(this, node.textContent.trim())
745
+ } catch (e) {
746
+ addAttributeToken(self, ATTRIBUTE_ERRORMESSAGE, 'when analyzing the configuration from the script tag there was an error. ' + e);
747
+ }
748
+
749
+ return obj;
750
+
751
+ }
752
+
753
+ /**
754
+ * @private
755
+ * @return {object}
688
756
  */
689
757
  function getOptionsFromAttributes() {
758
+ const self = this;
759
+
690
760
  if (this.hasAttribute(ATTRIBUTE_OPTIONS)) {
691
761
  try {
692
- return parseOptionsJSON(this.getAttribute(ATTRIBUTE_OPTIONS))
762
+ return parseOptionsJSON.call(self, this.getAttribute(ATTRIBUTE_OPTIONS))
693
763
  } catch (e) {
694
- throw new Error('the options attribute ' + ATTRIBUTE_OPTIONS + ' does not contain a valid json definition (actual: ' + this.getAttribute(ATTRIBUTE_OPTIONS) + ').');
764
+ addAttributeToken(self, ATTRIBUTE_ERRORMESSAGE, 'the options attribute ' + ATTRIBUTE_OPTIONS + ' does not contain a valid json definition (actual: ' + this.getAttribute(ATTRIBUTE_OPTIONS) + ').' + e);
695
765
  }
696
766
  }
697
767
 
@@ -704,27 +774,30 @@ function getOptionsFromAttributes() {
704
774
  * @return {Object}
705
775
  */
706
776
  function parseOptionsJSON(data) {
707
- if (isString(data)) {
708
777
 
709
- // the configuration can be specified as a data url.
710
- try {
711
- let dataUrl = parseDataURL(data);
712
- data = dataUrl.content;
713
- } catch (e) {
778
+ const self = this, obj = {};
714
779
 
715
- }
780
+ if (!isString(data)) {
781
+ return obj;
782
+ }
716
783
 
784
+ // the configuration can be specified as a data url.
785
+ try {
786
+ let dataUrl = parseDataURL(data);
787
+ data = dataUrl.content;
788
+ } catch (e) {
717
789
 
718
- try {
719
- let obj = JSON.parse(data);
720
- validateObject(obj);
721
- return obj;
722
- } catch (e) {
723
- throw new Error('the options does not contain a valid json definition (actual: ' + data + ').');
724
- }
725
790
  }
726
791
 
727
- return {};
792
+ try {
793
+ let obj = JSON.parse(data);
794
+ return validateObject(obj);
795
+ } catch (e) {
796
+ throw e;
797
+ }
798
+
799
+
800
+ return obj;
728
801
  }
729
802
 
730
803
  /**
@@ -755,6 +828,7 @@ function initHtmlContent() {
755
828
  * @memberOf Monster.DOM
756
829
  * @this CustomElement
757
830
  * @since 1.16.0
831
+ * @throws {TypeError} value is not an instance of
758
832
  */
759
833
  function initCSSStylesheet() {
760
834
  const self = this;
@@ -764,14 +838,46 @@ function initCSSStylesheet() {
764
838
  }
765
839
 
766
840
  const styleSheet = this.constructor.getCSSStyleSheet();
841
+
767
842
  if (styleSheet instanceof CSSStyleSheet) {
768
- this.shadowRoot.adoptedStyleSheets = [styleSheet];
843
+ if (styleSheet.cssRules.length > 0) {
844
+ this.shadowRoot.adoptedStyleSheets = [styleSheet];
845
+ }
769
846
  } else if (isArray(styleSheet)) {
770
- this.shadowRoot.adoptedStyleSheets = styleSheet;
847
+ const assign = [];
848
+ for (let s of styleSheet) {
849
+
850
+ if (isString(s)) {
851
+ let trimedStyleSheet = s.trim()
852
+ if (trimedStyleSheet !== '') {
853
+ const style = document.createElement('style')
854
+ style.innerHTML = trimedStyleSheet;
855
+ self.shadowRoot.prepend(style);
856
+ }
857
+ continue;
858
+ }
859
+
860
+ validateInstance(s, CSSStyleSheet);
861
+
862
+ if (s.cssRules.length > 0) {
863
+ assign.push(s);
864
+ }
865
+
866
+ }
867
+
868
+ if (assign.length > 0) {
869
+ this.shadowRoot.adoptedStyleSheets = assign;
870
+ }
871
+
771
872
  } else if (isString(styleSheet)) {
772
- const style = self.shadowRoot.createElement('<style>')
773
- style.innerText = styleSheet;
774
- this.shadowRoot.adoptedStyleSheets = styleSheet;
873
+
874
+ let trimedStyleSheet = styleSheet.trim()
875
+ if (trimedStyleSheet !== '') {
876
+ const style = document.createElement('style')
877
+ style.innerHTML = styleSheet;
878
+ self.shadowRoot.prepend(style);
879
+ }
880
+
775
881
  }
776
882
 
777
883
  return self;
@@ -14,7 +14,7 @@ import {getDocument} from "./util.js";
14
14
  *
15
15
  * ```
16
16
  * <script type="module">
17
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
17
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
18
18
  * new Monster.DOM.fireEvent()
19
19
  * </script>
20
20
  * ```
@@ -23,7 +23,7 @@ import {getDocument} from "./util.js";
23
23
  *
24
24
  * ```
25
25
  * <script type="module">
26
- * import {fireEvent} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/events.js';
26
+ * import {fireEvent} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/events.js';
27
27
  * fireEvent()
28
28
  * </script>
29
29
  * ```
@@ -70,7 +70,7 @@ function fireEvent(element, type) {
70
70
  *
71
71
  * ```
72
72
  * <script type="module">
73
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
73
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
74
74
  * new Monster.DOM.fireCustomEvent()
75
75
  * </script>
76
76
  * ```
@@ -79,7 +79,7 @@ function fireEvent(element, type) {
79
79
  *
80
80
  * ```
81
81
  * <script type="module">
82
- * import {fireCustomEvent} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/events.js';
82
+ * import {fireCustomEvent} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/events.js';
83
83
  * fireCustomEvent()
84
84
  * </script>
85
85
  * ```
@@ -130,7 +130,7 @@ function fireCustomEvent(element, type, detail) {
130
130
  *
131
131
  * ```
132
132
  * <script type="module">
133
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
133
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
134
134
  * new Monster.DOM.findTargetElementFromEvent()
135
135
  * </script>
136
136
  * ```
@@ -139,7 +139,7 @@ function fireCustomEvent(element, type, detail) {
139
139
  *
140
140
  * ```
141
141
  * <script type="module">
142
- * import {findTargetElementFromEvent} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/events.js';
142
+ * import {findTargetElementFromEvent} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/events.js';
143
143
  * findTargetElementFromEvent()
144
144
  * </script>
145
145
  * ```
@@ -41,7 +41,7 @@ const stackSymbol = Symbol('stack');
41
41
  *
42
42
  * ```
43
43
  * <script type="module">
44
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
44
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
45
45
  * new Monster.DOM.FocusManager()
46
46
  * </script>
47
47
  * ```
@@ -50,7 +50,7 @@ const stackSymbol = Symbol('stack');
50
50
  *
51
51
  * ```
52
52
  * <script type="module">
53
- * import {FocusManager} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/focusmanager.js';
53
+ * import {FocusManager} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/focusmanager.js';
54
54
  * new FocusManager()
55
55
  * </script>
56
56
  * ```
@@ -26,7 +26,7 @@ const DEFAULT_LANGUAGE = 'en';
26
26
  *
27
27
  * ```
28
28
  * <script type="module">
29
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
29
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
30
30
  * new Monster.DOM.getLocaleOfDocument()
31
31
  * </script>
32
32
  * ```
@@ -35,7 +35,7 @@ const DEFAULT_LANGUAGE = 'en';
35
35
  *
36
36
  * ```
37
37
  * <script type="module">
38
- * import {getLocaleOfDocument} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/locale.js';
38
+ * import {getLocaleOfDocument} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/locale.js';
39
39
  * new getLocaleOfDocument()
40
40
  * </script>
41
41
  * ```
@@ -27,7 +27,7 @@ import {KEY_DOCUMENT, KEY_QUERY, referenceSymbol, Resource} from "../resource.js
27
27
  *
28
28
  * ```
29
29
  * <script type="module">
30
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
30
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
31
31
  * new Monster.DOM.Resource.Data()
32
32
  * </script>
33
33
  * ```
@@ -36,7 +36,7 @@ import {KEY_DOCUMENT, KEY_QUERY, referenceSymbol, Resource} from "../resource.js
36
36
  *
37
37
  * ```
38
38
  * <script type="module">
39
- * import {Data} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/resource/data.js';
39
+ * import {Data} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/resource/data.js';
40
40
  * new Data()
41
41
  * </script>
42
42
  * ```
@@ -16,7 +16,7 @@ import {Link} from "../link.js";
16
16
  *
17
17
  * ```
18
18
  * <script type="module">
19
- * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/monster.js';
19
+ * import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/monster.js';
20
20
  * new Monster.DOM.Resource.Link.Stylesheet()
21
21
  * </script>
22
22
  * ```
@@ -25,7 +25,7 @@ import {Link} from "../link.js";
25
25
  *
26
26
  * ```
27
27
  * <script type="module">
28
- * import {Style} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.29.1/dist/modules/dom/resource/link/stylesheet.js';
28
+ * import {Style} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.30.1/dist/modules/dom/resource/link/stylesheet.js';
29
29
  * new Stylesheet()
30
30
  * </script>
31
31
  * ```