@schukai/monster 3.65.0 → 3.65.21

Sign up to get free protection for your applications and to get access to all the features.
Files changed (383) hide show
  1. package/CHANGELOG.md +48 -327
  2. package/README.md +44 -40
  3. package/package.json +1 -48
  4. package/source/components/constants.mjs +10 -3
  5. package/source/components/datatable/change-button.mjs +18 -11
  6. package/source/components/datatable/columnbar.mjs +10 -1
  7. package/source/components/datatable/constants.mjs +11 -4
  8. package/source/components/datatable/dataset.mjs +212 -203
  9. package/source/components/datatable/datasource/dom.mjs +14 -1
  10. package/source/components/datatable/datasource/rest.mjs +10 -1
  11. package/source/components/datatable/datasource.mjs +10 -1
  12. package/source/components/datatable/datatable/header.mjs +220 -218
  13. package/source/components/datatable/datatable.mjs +754 -752
  14. package/source/components/datatable/embedded-pagination.mjs +10 -1
  15. package/source/components/datatable/filter/abstract-base.mjs +10 -1
  16. package/source/components/datatable/filter/date-range.mjs +10 -1
  17. package/source/components/datatable/filter/input.mjs +10 -1
  18. package/source/components/datatable/filter/range.mjs +10 -1
  19. package/source/components/datatable/filter/select.mjs +11 -4
  20. package/source/components/datatable/filter/settings.mjs +14 -0
  21. package/source/components/datatable/filter/util.mjs +14 -0
  22. package/source/components/datatable/filter-button.mjs +10 -1
  23. package/source/components/datatable/filter.mjs +15 -11
  24. package/source/components/datatable/pagination.mjs +18 -9
  25. package/source/components/datatable/save-button.mjs +280 -270
  26. package/source/components/datatable/status.mjs +15 -5
  27. package/source/components/datatable/stylesheet/change-button.mjs +16 -7
  28. package/source/components/datatable/stylesheet/column-bar.mjs +16 -7
  29. package/source/components/datatable/stylesheet/dataset.mjs +16 -7
  30. package/source/components/datatable/stylesheet/datasource.mjs +16 -7
  31. package/source/components/datatable/stylesheet/datatable.mjs +16 -7
  32. package/source/components/datatable/stylesheet/embedded-pagination.mjs +16 -7
  33. package/source/components/datatable/stylesheet/filter-button.mjs +16 -7
  34. package/source/components/datatable/stylesheet/filter-controls-defaults.mjs +16 -7
  35. package/source/components/datatable/stylesheet/filter-date-range.mjs +16 -7
  36. package/source/components/datatable/stylesheet/filter-range.mjs +16 -7
  37. package/source/components/datatable/stylesheet/filter.mjs +16 -7
  38. package/source/components/datatable/stylesheet/pagination.mjs +16 -7
  39. package/source/components/datatable/stylesheet/save-button.mjs +16 -7
  40. package/source/components/datatable/stylesheet/select-filter.mjs +16 -7
  41. package/source/components/datatable/stylesheet/status.mjs +16 -7
  42. package/source/components/datatable/util.mjs +16 -8
  43. package/source/components/form/action-button.mjs +11 -3
  44. package/source/components/form/api-button.mjs +11 -3
  45. package/source/components/form/button-bar.mjs +11 -3
  46. package/source/components/form/button.mjs +254 -249
  47. package/source/components/form/confirm-button.mjs +11 -3
  48. package/source/components/form/constants.mjs +10 -3
  49. package/source/components/form/context-error.mjs +69 -52
  50. package/source/components/form/context-help.mjs +11 -3
  51. package/source/components/form/field-set.mjs +10 -15
  52. package/source/components/form/form.mjs +12 -4
  53. package/source/components/form/message-state-button.mjs +11 -3
  54. package/source/components/form/popper-button.mjs +11 -3
  55. package/source/components/form/popper.mjs +6 -6
  56. package/source/components/form/reload.mjs +12 -4
  57. package/source/components/form/select.mjs +44 -33
  58. package/source/components/form/shadow-reload.mjs +11 -3
  59. package/source/components/form/state-button.mjs +11 -3
  60. package/source/components/form/stylesheet/action-button.mjs +16 -7
  61. package/source/components/form/stylesheet/api-button.mjs +16 -7
  62. package/source/components/form/stylesheet/button-bar.mjs +16 -7
  63. package/source/components/form/stylesheet/button.mjs +16 -7
  64. package/source/components/form/stylesheet/confirm-button.mjs +16 -7
  65. package/source/components/form/stylesheet/context-error.mjs +16 -7
  66. package/source/components/form/stylesheet/context-help.mjs +16 -7
  67. package/source/components/form/stylesheet/field-set.mjs +16 -7
  68. package/source/components/form/stylesheet/form.mjs +16 -7
  69. package/source/components/form/stylesheet/message-state-button.mjs +16 -7
  70. package/source/components/form/stylesheet/popper-button.mjs +16 -7
  71. package/source/components/form/stylesheet/select.mjs +16 -7
  72. package/source/components/form/stylesheet/state-button.mjs +16 -7
  73. package/source/components/form/stylesheet/toggle-switch.mjs +16 -7
  74. package/source/components/form/stylesheet/tree-select.mjs +16 -7
  75. package/source/components/form/tabs.mjs +12 -8
  76. package/source/components/form/template.mjs +11 -3
  77. package/source/components/form/toggle-switch.mjs +12 -8
  78. package/source/components/form/tree-select.mjs +10 -3
  79. package/source/components/form/types/state.mjs +10 -3
  80. package/source/components/form/util/fetch.mjs +10 -3
  81. package/source/components/form/util/floating-ui.mjs +10 -3
  82. package/source/components/form/util/popper.mjs +10 -3
  83. package/source/components/host/call-button.mjs +10 -1
  84. package/source/components/host/collapse.mjs +4 -6
  85. package/source/components/host/config-manager.mjs +2 -0
  86. package/source/components/host/constants.mjs +2 -0
  87. package/source/components/host/details.mjs +5 -8
  88. package/source/components/host/host.mjs +10 -1
  89. package/source/components/host/overlay.mjs +10 -1
  90. package/source/components/host/stylesheet/call-button.mjs +16 -7
  91. package/source/components/host/stylesheet/config-manager.mjs +16 -7
  92. package/source/components/host/stylesheet/host.mjs +16 -7
  93. package/source/components/host/stylesheet/overlay.mjs +16 -7
  94. package/source/components/host/stylesheet/toggle-button.mjs +16 -7
  95. package/source/components/host/stylesheet/viewer.mjs +16 -7
  96. package/source/components/host/toggle-button.mjs +10 -1
  97. package/source/components/host/util.mjs +14 -0
  98. package/source/components/host/viewer.mjs +10 -1
  99. package/source/components/layout/collapse.mjs +4 -3
  100. package/source/components/layout/details.mjs +2 -0
  101. package/source/components/layout/panel.mjs +179 -169
  102. package/source/components/layout/popper.mjs +324 -320
  103. package/source/components/layout/split-panel.mjs +329 -303
  104. package/source/components/layout/stylesheet/collapse.mjs +16 -7
  105. package/source/components/layout/stylesheet/details.mjs +16 -7
  106. package/source/components/layout/stylesheet/panel.mjs +16 -7
  107. package/source/components/layout/stylesheet/popper.mjs +16 -7
  108. package/source/components/layout/stylesheet/split-panel.mjs +16 -7
  109. package/source/components/layout/stylesheet/tabs.mjs +16 -7
  110. package/source/components/layout/stylesheet/width-toggle.mjs +16 -7
  111. package/source/components/layout/tabs.mjs +39 -24
  112. package/source/components/layout/width-toggle.mjs +148 -138
  113. package/source/components/navigation/style/table-of-content.pcss +20 -5
  114. package/source/components/navigation/stylesheet/table-of-content.mjs +17 -8
  115. package/source/components/navigation/table-of-content.mjs +394 -266
  116. package/source/components/notify/constants.mjs +10 -3
  117. package/source/components/notify/message.mjs +16 -9
  118. package/source/components/notify/notify.mjs +11 -4
  119. package/source/components/notify/stylesheet/message.mjs +16 -7
  120. package/source/components/notify/stylesheet/notify.mjs +16 -7
  121. package/source/components/state/log/entry.mjs +10 -1
  122. package/source/components/state/log.mjs +10 -1
  123. package/source/components/state/state.mjs +10 -1
  124. package/source/components/state/stylesheet/log.mjs +16 -7
  125. package/source/components/state/stylesheet/state.mjs +16 -7
  126. package/source/components/style/mixin/form.pcss +0 -1
  127. package/source/components/stylesheet/badge.mjs +16 -7
  128. package/source/components/stylesheet/border.mjs +16 -7
  129. package/source/components/stylesheet/button.mjs +16 -7
  130. package/source/components/stylesheet/card.mjs +16 -7
  131. package/source/components/stylesheet/color.mjs +16 -7
  132. package/source/components/stylesheet/common.mjs +16 -7
  133. package/source/components/stylesheet/control.mjs +16 -7
  134. package/source/components/stylesheet/data-grid.mjs +16 -7
  135. package/source/components/stylesheet/display.mjs +16 -7
  136. package/source/components/stylesheet/floating-ui.mjs +16 -7
  137. package/source/components/stylesheet/form.mjs +16 -7
  138. package/source/components/stylesheet/host.mjs +16 -7
  139. package/source/components/stylesheet/icons.mjs +16 -7
  140. package/source/components/stylesheet/link.mjs +16 -7
  141. package/source/components/stylesheet/mixin/badge.mjs +16 -7
  142. package/source/components/stylesheet/mixin/button.mjs +16 -7
  143. package/source/components/stylesheet/mixin/form.mjs +16 -7
  144. package/source/components/stylesheet/mixin/hover.mjs +16 -7
  145. package/source/components/stylesheet/mixin/icon.mjs +16 -7
  146. package/source/components/stylesheet/mixin/media.mjs +16 -7
  147. package/source/components/stylesheet/mixin/property.mjs +16 -7
  148. package/source/components/stylesheet/mixin/skeleton.mjs +16 -7
  149. package/source/components/stylesheet/mixin/spinner.mjs +16 -7
  150. package/source/components/stylesheet/mixin/typography.mjs +16 -7
  151. package/source/components/stylesheet/normalize.mjs +16 -7
  152. package/source/components/stylesheet/popper.mjs +16 -7
  153. package/source/components/stylesheet/property.mjs +16 -7
  154. package/source/components/stylesheet/ripple.mjs +16 -7
  155. package/source/components/stylesheet/skeleton.mjs +16 -7
  156. package/source/components/stylesheet/space.mjs +16 -7
  157. package/source/components/stylesheet/spinner.mjs +16 -7
  158. package/source/components/stylesheet/table.mjs +16 -7
  159. package/source/components/stylesheet/theme.mjs +16 -7
  160. package/source/components/stylesheet/tree-menu.mjs +10 -3
  161. package/source/components/stylesheet/typography.mjs +16 -7
  162. package/source/components/tree-menu/stylesheet/tree-menu.mjs +16 -7
  163. package/source/components/tree-menu/tree-menu.mjs +19 -8
  164. package/source/constants.mjs +10 -6
  165. package/source/constraints/abstract.mjs +10 -3
  166. package/source/constraints/abstractoperator.mjs +10 -3
  167. package/source/constraints/andoperator.mjs +10 -3
  168. package/source/constraints/invalid.mjs +10 -3
  169. package/source/constraints/isarray.mjs +10 -3
  170. package/source/constraints/isobject.mjs +10 -3
  171. package/source/constraints/oroperator.mjs +10 -3
  172. package/source/constraints/valid.mjs +10 -3
  173. package/source/data/buildmap.mjs +10 -3
  174. package/source/data/buildtree.mjs +10 -3
  175. package/source/data/datasource/dom.mjs +95 -87
  176. package/source/data/datasource/server/restapi/data-fetch-error.mjs +10 -3
  177. package/source/data/datasource/server/restapi/writeerror.mjs +10 -3
  178. package/source/data/datasource/server/restapi.mjs +10 -3
  179. package/source/data/datasource/server/webconnect.mjs +10 -3
  180. package/source/data/datasource/server.mjs +10 -3
  181. package/source/data/datasource/storage/localstorage.mjs +10 -3
  182. package/source/data/datasource/storage/sessionstorage.mjs +10 -3
  183. package/source/data/datasource/storage.mjs +10 -3
  184. package/source/data/datasource.mjs +10 -3
  185. package/source/data/diff.mjs +10 -3
  186. package/source/data/extend.mjs +10 -3
  187. package/source/data/pathfinder.mjs +10 -3
  188. package/source/data/pipe.mjs +10 -3
  189. package/source/data/transformer.mjs +34 -10
  190. package/source/dom/assembler.mjs +10 -3
  191. package/source/dom/attributes.mjs +10 -3
  192. package/source/dom/constants.mjs +10 -3
  193. package/source/dom/customcontrol.mjs +11 -4
  194. package/source/dom/customelement.mjs +31 -17
  195. package/source/dom/dimension.mjs +10 -3
  196. package/source/dom/events.mjs +10 -3
  197. package/source/dom/focusmanager.mjs +10 -3
  198. package/source/dom/locale.mjs +10 -3
  199. package/source/dom/ready.mjs +2 -1
  200. package/source/dom/resource/data.mjs +133 -123
  201. package/source/dom/resource/link/stylesheet.mjs +10 -3
  202. package/source/dom/resource/link.mjs +10 -3
  203. package/source/dom/resource/script.mjs +10 -3
  204. package/source/dom/resource.mjs +10 -4
  205. package/source/dom/resourcemanager.mjs +10 -3
  206. package/source/dom/slotted.mjs +14 -0
  207. package/source/dom/template.mjs +124 -136
  208. package/source/dom/theme.mjs +10 -3
  209. package/source/dom/updater.mjs +10 -3
  210. package/source/dom/util/extract-keys.mjs +10 -3
  211. package/source/dom/util/init-options-from-attributes.mjs +68 -61
  212. package/source/dom/util/set-option-from-attribute.mjs +10 -3
  213. package/source/dom/util.mjs +11 -4
  214. package/source/dom/worker/factory.mjs +10 -3
  215. package/source/i18n/formatter.mjs +10 -3
  216. package/source/i18n/locale.mjs +10 -3
  217. package/source/i18n/provider.mjs +10 -3
  218. package/source/i18n/providers/embed.mjs +10 -3
  219. package/source/i18n/providers/fetch.mjs +10 -3
  220. package/source/i18n/translations.mjs +10 -3
  221. package/source/logging/handler/console.mjs +10 -3
  222. package/source/logging/handler.mjs +10 -3
  223. package/source/logging/logentry.mjs +10 -3
  224. package/source/logging/logger.mjs +10 -3
  225. package/source/math/random.mjs +10 -3
  226. package/source/monster.mjs +3 -9
  227. package/source/net/webconnect/message.mjs +10 -3
  228. package/source/net/webconnect.mjs +20 -5
  229. package/source/text/bracketed-key-value-hash.mjs +10 -3
  230. package/source/text/formatter.mjs +10 -3
  231. package/source/text/generate-range-comparison-expression.mjs +10 -3
  232. package/source/text/util.mjs +14 -0
  233. package/source/types/base.mjs +10 -3
  234. package/source/types/basewithoptions.mjs +10 -3
  235. package/source/types/binary.mjs +10 -3
  236. package/source/types/dataurl.mjs +10 -3
  237. package/source/types/global.mjs +14 -7
  238. package/source/types/id.mjs +10 -3
  239. package/source/types/internal.mjs +11 -3
  240. package/source/types/is.mjs +10 -3
  241. package/source/types/mediatype.mjs +10 -3
  242. package/source/types/node.mjs +10 -3
  243. package/source/types/nodelist.mjs +10 -3
  244. package/source/types/noderecursiveiterator.mjs +10 -3
  245. package/source/types/observablequeue.mjs +10 -3
  246. package/source/types/observer.mjs +10 -3
  247. package/source/types/observerlist.mjs +10 -3
  248. package/source/types/proxyobserver.mjs +10 -3
  249. package/source/types/queue.mjs +10 -3
  250. package/source/types/randomid.mjs +10 -3
  251. package/source/types/regex.mjs +10 -3
  252. package/source/types/stack.mjs +10 -3
  253. package/source/types/tokenlist.mjs +10 -3
  254. package/source/types/typeof.mjs +10 -3
  255. package/source/types/uniquequeue.mjs +10 -3
  256. package/source/types/uuid.mjs +10 -3
  257. package/source/types/validate.mjs +10 -3
  258. package/source/types/version.mjs +10 -3
  259. package/source/util/clone.mjs +10 -3
  260. package/source/util/comparator.mjs +10 -3
  261. package/source/util/deadmansswitch.mjs +10 -3
  262. package/source/util/freeze.mjs +10 -3
  263. package/source/util/processing.mjs +10 -3
  264. package/source/util/runtime.mjs +10 -7
  265. package/source/util/sleep.mjs +10 -10
  266. package/source/util/trimspaces.mjs +10 -3
  267. package/test/cases/data/datasource/server/websocket.mjs +7 -9
  268. package/test/cases/data/transformer.mjs +47 -15
  269. package/test/cases/dom/customcontrol.mjs +0 -1
  270. package/test/cases/dom/customelement.mjs +1 -3
  271. package/test/cases/dom/template.mjs +3 -1
  272. package/test/util/jsdom.mjs +8 -7
  273. package/test/util/websocket.mjs +5 -1
  274. package/test/web/import.js +2 -1
  275. package/test/web/puppeteer.mjs +111 -0
  276. package/test/web/test.html +2 -2
  277. package/test/web/tests.js +2036 -1189
  278. package/example/components/form/button.mjs +0 -10
  279. package/example/components/form/field-set.mjs +0 -4
  280. package/example/components/form/select.mjs +0 -25
  281. package/example/components/form/toggle-switch.mjs +0 -7
  282. package/example/components/form/tree-select.mjs +0 -27
  283. package/example/components/host/host.mjs +0 -0
  284. package/example/components/notify/message.mjs +0 -4
  285. package/example/components/notify/notify.mjs +0 -4
  286. package/example/components/state/log.mjs +0 -0
  287. package/example/components/state/state.mjs +0 -0
  288. package/example/constraints/andoperator.mjs +0 -17
  289. package/example/constraints/invalid.mjs +0 -6
  290. package/example/constraints/isarray.mjs +0 -11
  291. package/example/constraints/isobject.mjs +0 -12
  292. package/example/constraints/oroperator.mjs +0 -15
  293. package/example/constraints/valid.mjs +0 -6
  294. package/example/data/buildmap.mjs +0 -67
  295. package/example/data/datasource/server/restapi.mjs +0 -20
  296. package/example/data/datasource/server/webconnect.mjs +0 -9
  297. package/example/data/datasource.mjs +0 -7
  298. package/example/data/diff.mjs +0 -39
  299. package/example/data/pathfinder-1.mjs +0 -23
  300. package/example/data/pathfinder-2.mjs +0 -19
  301. package/example/data/pipe.mjs +0 -14
  302. package/example/data/transformer.mjs +0 -9
  303. package/example/dom/customelement.mjs +0 -14
  304. package/example/dom/theme.mjs +0 -5
  305. package/example/dom/updater.mjs +0 -23
  306. package/example/i18n/formatter.mjs +0 -10
  307. package/example/i18n/providers/embed.mjs +0 -5
  308. package/example/i18n/providers/fetch.mjs +0 -5
  309. package/example/i18n/translations.mjs +0 -20
  310. package/example/net/webconnect.mjs +0 -16
  311. package/example/types/basewithoptions.mjs +0 -10
  312. package/example/types/is-1.mjs +0 -5
  313. package/example/types/is-10.mjs +0 -6
  314. package/example/types/is-2.mjs +0 -4
  315. package/example/types/is-3.mjs +0 -4
  316. package/example/types/is-4.mjs +0 -5
  317. package/example/types/is-5.mjs +0 -4
  318. package/example/types/is-6.mjs +0 -4
  319. package/example/types/is-7.mjs +0 -4
  320. package/example/types/is-8.mjs +0 -4
  321. package/example/types/is-9.mjs +0 -6
  322. package/example/types/noderecursiveiterator.mjs +0 -32
  323. package/example/types/observer.mjs +0 -9
  324. package/example/types/proxyobserver.mjs +0 -25
  325. package/example/types/queue.mjs +0 -20
  326. package/example/types/tokenlist-1.mjs +0 -4
  327. package/example/types/tokenlist-2.mjs +0 -7
  328. package/example/types/tokenlist-3.mjs +0 -5
  329. package/example/types/tokenlist-4.mjs +0 -5
  330. package/example/types/tokenlist-5.mjs +0 -5
  331. package/example/types/typeof.mjs +0 -9
  332. package/example/types/version-1.mjs +0 -6
  333. package/example/types/version-2.mjs +0 -3
  334. package/example/util/comparator.mjs +0 -10
  335. package/example/util/deadmansswitch.mjs +0 -9
  336. package/example/util/processing.mjs +0 -17
  337. package/source/components/datatable/datasource/namespace.mjs +0 -13
  338. package/source/components/datatable/datatable/namespace.mjs +0 -13
  339. package/source/components/datatable/events.mjs +0 -24
  340. package/source/components/datatable/filter/namespace.mjs +0 -13
  341. package/source/components/datatable/namespace.mjs +0 -11
  342. package/source/components/datatable/stylesheet/namespace.mjs +0 -13
  343. package/source/components/events.mjs +0 -17
  344. package/source/components/form/events.mjs +0 -108
  345. package/source/components/form/namespace.mjs +0 -13
  346. package/source/components/form/stylesheet/namespace.mjs +0 -13
  347. package/source/components/form/types/namespace.mjs +0 -13
  348. package/source/components/form/util/namespace.mjs +0 -13
  349. package/source/components/host/events.mjs +0 -131
  350. package/source/components/host/namespace.mjs +0 -13
  351. package/source/components/host/stylesheet/namespace.mjs +0 -13
  352. package/source/components/layout/events.mjs +0 -30
  353. package/source/components/layout/namespace.mjs +0 -13
  354. package/source/components/namespace.mjs +0 -14
  355. package/source/components/notify/events.mjs +0 -15
  356. package/source/components/notify/namespace.mjs +0 -15
  357. package/source/components/notify/stylesheet/namespace.mjs +0 -15
  358. package/source/components/state/log/namespace.mjs +0 -13
  359. package/source/components/state/namespace.mjs +0 -13
  360. package/source/components/stylesheet/namespace.mjs +0 -13
  361. package/source/components/tree-menu/namespace.mjs +0 -13
  362. package/source/components/tree-menu/stylesheet/namespace.mjs +0 -13
  363. package/source/constraints/namespace.mjs +0 -13
  364. package/source/data/datasource/namespace.mjs +0 -13
  365. package/source/data/datasource/server/namespace.mjs +0 -13
  366. package/source/data/datasource/server/restapi/namespace.mjs +0 -13
  367. package/source/data/datasource/storage/namespace.mjs +0 -13
  368. package/source/data/namespace.mjs +0 -13
  369. package/source/dom/namespace.mjs +0 -13
  370. package/source/dom/resource/link/namespace.mjs +0 -13
  371. package/source/dom/resource/namespace.mjs +0 -13
  372. package/source/dom/util/namespace.mjs +0 -13
  373. package/source/dom/worker/namespace.mjs +0 -13
  374. package/source/i18n/namespace.mjs +0 -13
  375. package/source/i18n/providers/namespace.mjs +0 -13
  376. package/source/logging/handler/namespace.mjs +0 -11
  377. package/source/logging/namespace.mjs +0 -13
  378. package/source/math/namespace.mjs +0 -13
  379. package/source/net/namespace.mjs +0 -13
  380. package/source/net/webconnect/namespace.mjs +0 -13
  381. package/source/text/namespace.mjs +0 -13
  382. package/source/types/namespace.mjs +0 -13
  383. package/source/util/namespace.mjs +0 -13
@@ -1,34 +1,44 @@
1
1
  /**
2
- * Copyright 2023 schukai GmbH
2
+ * Copyright © schukai GmbH and all contributing authors, {{copyRightYear}}. All rights reserved.
3
+ * Node module: @schukai/monster
4
+ *
5
+ * This source code is licensed under the GNU Affero General Public License version 3 (AGPLv3).
6
+ * The full text of the license can be found at: https://www.gnu.org/licenses/agpl-3.0.en.html
7
+ *
8
+ * For those who do not wish to adhere to the AGPLv3, a commercial license is available.
9
+ * Acquiring a commercial license allows you to use this software without complying with the AGPLv3 terms.
10
+ * For more information about purchasing a commercial license, please contact schukai GmbH.
11
+ *
3
12
  * SPDX-License-Identifier: AGPL-3.0
4
13
  */
5
14
 
6
- import {instanceSymbol, internalSymbol} from "../../constants.mjs";
7
- import {diff} from "../../data/diff.mjs";
8
- import {addAttributeToken} from "../../dom/attributes.mjs";
9
- import {ATTRIBUTE_ERRORMESSAGE} from "../../dom/constants.mjs";
15
+ import { instanceSymbol, internalSymbol } from "../../constants.mjs";
16
+ import { diff } from "../../data/diff.mjs";
17
+ import { addAttributeToken } from "../../dom/attributes.mjs";
18
+ import { ATTRIBUTE_ERRORMESSAGE } from "../../dom/constants.mjs";
10
19
  import {
11
- assembleMethodSymbol,
12
- CustomElement,
13
- attributeObserverSymbol,
14
- registerCustomElement,
20
+ assembleMethodSymbol,
21
+ CustomElement,
22
+ attributeObserverSymbol,
23
+ registerCustomElement,
15
24
  } from "../../dom/customelement.mjs";
16
- import {isString, isArray} from "../../types/is.mjs";
17
- import {Observer} from "../../types/observer.mjs";
18
- import {TokenList} from "../../types/tokenlist.mjs";
19
- import {clone} from "../../util/clone.mjs";
20
- import {State} from "../form/types/state.mjs";
21
- import {ATTRIBUTE_DATASOURCE_SELECTOR} from "./constants.mjs";
22
- import {Datasource} from "./datasource.mjs";
23
- import {BadgeStyleSheet} from "../stylesheet/badge.mjs";
24
- import {SaveButtonStyleSheet} from "./stylesheet/save-button.mjs";
25
+ import {findElementWithSelectorUpwards} from "../../dom/util.mjs";
26
+ import { isString, isArray } from "../../types/is.mjs";
27
+ import { Observer } from "../../types/observer.mjs";
28
+ import { TokenList } from "../../types/tokenlist.mjs";
29
+ import { clone } from "../../util/clone.mjs";
30
+ import { State } from "../form/types/state.mjs";
31
+ import { ATTRIBUTE_DATASOURCE_SELECTOR } from "./constants.mjs";
32
+ import { Datasource } from "./datasource.mjs";
33
+ import { BadgeStyleSheet } from "../stylesheet/badge.mjs";
34
+ import { SaveButtonStyleSheet } from "./stylesheet/save-button.mjs";
25
35
 
26
36
  import {
27
- handleDataSourceChanges,
28
- datasourceLinkedElementSymbol,
37
+ handleDataSourceChanges,
38
+ datasourceLinkedElementSymbol,
29
39
  } from "./util.mjs";
30
40
 
31
- export {SaveButton};
41
+ export { SaveButton };
32
42
 
33
43
  /**
34
44
  * @private
@@ -43,194 +53,194 @@ const stateButtonElementSymbol = Symbol("stateButtonElement");
43
53
  const badgeElementSymbol = Symbol("badgeElement");
44
54
 
45
55
  class SaveButton extends CustomElement {
46
- /**
47
- * This method is called by the `instanceof` operator.
48
- * @returns {symbol}
49
- */
50
- static get [instanceSymbol]() {
51
- return Symbol.for(
52
- "@schukai/monster/components/datasource/save-button@@instance",
53
- );
54
- }
55
-
56
- /**
57
- * To set the options via the html tag the attribute `data-monster-options` must be used.
58
- * @see {@link https://monsterjs.org/en/doc/#configurate-a-monster-control}
59
- *
60
- * The individual configuration values can be found in the table.
61
- *
62
- * @property {Object} templates Template definitions
63
- * @property {string} templates.main Main template
64
- * @property {object} datasource The datasource
65
- * @property {string} datasource.selector The selector of the datasource
66
- * @property {string} labels.button The button label
67
- * @property {Object} classes The classes
68
- * @property {string} classes.bar The bar class
69
- * @property {string} classes.badge The badge class
70
- * @property {object} mapping The mapping
71
- * @property {string} mapping.data The data
72
- * @property {number} mapping.index The index
73
- * @property {Array} ignoreChanges The ignore changes (regex)
74
- * @property {Array} data The data
75
- * @return {Object}
76
- */
77
- get defaults() {
78
- const obj = Object.assign({}, super.defaults, {
79
- templates: {
80
- main: getTemplate(),
81
- },
82
-
83
- labels: {
84
- button: "save",
85
- },
86
-
87
- classes: {
88
- bar: "monster-button-primary",
89
- badge: "monster-badge-secondary hidden",
90
- },
91
-
92
- datasource: {
93
- selector: null,
94
- },
95
-
96
- changes: "0",
97
-
98
- mapping: {
99
- data: "dataset",
100
- index: 0,
101
- },
102
-
103
- ignoreChanges: [],
104
-
105
- data: {},
106
-
107
- disabled: false,
108
- });
109
-
110
- updateOptionsFromArguments.call(this, obj);
111
- return obj;
112
- }
113
-
114
- /**
115
- *
116
- * @return {string}
117
- */
118
- static getTag() {
119
- return "monster-datasource-save-button";
120
- }
121
-
122
- /**
123
- * This method is responsible for assembling the component.
124
- *
125
- * It calls the parent's assemble method first, then initializes control references and event handlers.
126
- * If the `datasource.selector` option is provided and is a string, it searches for the corresponding
127
- * element in the DOM using that selector.
128
- *
129
- * If the selector matches exactly one element, it checks if the element is an instance of the `Datasource` class.
130
- *
131
- * If it is, the component's `datasourceLinkedElementSymbol` property is set to the element, and the component
132
- * attaches an observer to the datasource's changes.
133
- *
134
- * The observer is a function that calls the `handleDataSourceChanges` method in the context of the component.
135
- * Additionally, the component attaches an observer to itself, which also calls the `handleDataSourceChanges`
136
- * method in the component's context.
137
- */
138
- [assembleMethodSymbol]() {
139
- super[assembleMethodSymbol]();
140
- const self = this;
141
-
142
- initControlReferences.call(this);
143
- initEventHandler.call(this);
144
-
145
- const selector = this.getOption("datasource.selector");
146
-
147
- if (isString(selector)) {
148
- const elements = document.querySelectorAll(selector);
149
- if (elements.length !== 1) {
150
- throw new Error("the selector must match exactly one element");
151
- }
152
-
153
- const element = elements[0];
154
- if (!(element instanceof Datasource)) {
155
- throw new TypeError("the element must be a datasource");
156
- }
157
-
158
- this[datasourceLinkedElementSymbol] = element;
159
- element.datasource.attachObserver(
160
- new Observer(handleDataSourceChanges.bind(this)),
161
- );
162
-
163
- let originValues;
164
-
165
- element.datasource.attachObserver(
166
- new Observer(function () {
167
- if (!originValues) {
168
- originValues = clone(self[datasourceLinkedElementSymbol].data);
169
- }
170
-
171
- const currentValues = this.getRealSubject();
172
- const ignoreChanges = self.getOption("ignoreChanges");
173
-
174
- const result = diff(originValues, currentValues);
175
- if (isArray(ignoreChanges) && ignoreChanges.length > 0) {
176
- const itemsToRemove = [];
177
- for (const item of result) {
178
- for (const ignorePattern of ignoreChanges) {
179
- const p = new RegExp(ignorePattern);
180
- if (p.test(item.path)) {
181
- itemsToRemove.push(item);
182
- break;
183
- }
184
- }
185
- }
186
-
187
- for (const itemToRemove of itemsToRemove) {
188
- const index = result.indexOf(itemToRemove);
189
- if (index > -1) {
190
- result.splice(index, 1);
191
- }
192
- }
193
- }
194
-
195
- if (isArray(result) && result.length > 0) {
196
- self[stateButtonElementSymbol].setState("changed");
197
- self[stateButtonElementSymbol].setOption("disabled", false);
198
- self.setOption("changes", result.length);
199
- self.setOption(
200
- "classes.badge",
201
- new TokenList(self.getOption("classes.badge"))
202
- .remove("hidden")
203
- .toString(),
204
- );
205
- } else {
206
- self[stateButtonElementSymbol].removeState();
207
- self[stateButtonElementSymbol].setOption("disabled", true);
208
- self.setOption("changes", 0);
209
- self.setOption(
210
- "classes.badge",
211
- new TokenList(self.getOption("classes.badge"))
212
- .add("hidden")
213
- .toString(),
214
- );
215
- }
216
- }),
217
- );
218
- }
219
-
220
- this.attachObserver(
221
- new Observer(() => {
222
- handleDataSourceChanges.call(this);
223
- }),
224
- );
225
- }
226
-
227
- /**
228
- *
229
- * @return [CSSStyleSheet]
230
- */
231
- static getCSSStyleSheet() {
232
- return [SaveButtonStyleSheet, BadgeStyleSheet];
233
- }
56
+ /**
57
+ * This method is called by the `instanceof` operator.
58
+ * @returns {symbol}
59
+ */
60
+ static get [instanceSymbol]() {
61
+ return Symbol.for(
62
+ "@schukai/monster/components/datasource/save-button@@instance",
63
+ );
64
+ }
65
+
66
+ /**
67
+ * To set the options via the html tag the attribute `data-monster-options` must be used.
68
+ * @see {@link https://monsterjs.org/en/doc/#configurate-a-monster-control}
69
+ *
70
+ * The individual configuration values can be found in the table.
71
+ *
72
+ * @property {Object} templates Template definitions
73
+ * @property {string} templates.main Main template
74
+ * @property {object} datasource The datasource
75
+ * @property {string} datasource.selector The selector of the datasource
76
+ * @property {string} labels.button The button label
77
+ * @property {Object} classes The classes
78
+ * @property {string} classes.bar The bar class
79
+ * @property {string} classes.badge The badge class
80
+ * @property {object} mapping The mapping
81
+ * @property {string} mapping.data The data
82
+ * @property {number} mapping.index The index
83
+ * @property {Array} ignoreChanges The ignore changes (regex)
84
+ * @property {Array} data The data
85
+ * @return {Object}
86
+ */
87
+ get defaults() {
88
+ const obj = Object.assign({}, super.defaults, {
89
+ templates: {
90
+ main: getTemplate(),
91
+ },
92
+
93
+ labels: {
94
+ button: "save",
95
+ },
96
+
97
+ classes: {
98
+ bar: "monster-button-primary",
99
+ badge: "monster-badge-secondary hidden",
100
+ },
101
+
102
+ datasource: {
103
+ selector: null,
104
+ },
105
+
106
+ changes: "0",
107
+
108
+ mapping: {
109
+ data: "dataset",
110
+ index: 0,
111
+ },
112
+
113
+ ignoreChanges: [],
114
+
115
+ data: {},
116
+
117
+ disabled: false,
118
+ });
119
+
120
+ updateOptionsFromArguments.call(this, obj);
121
+ return obj;
122
+ }
123
+
124
+ /**
125
+ *
126
+ * @return {string}
127
+ */
128
+ static getTag() {
129
+ return "monster-datasource-save-button";
130
+ }
131
+
132
+ /**
133
+ * This method is responsible for assembling the component.
134
+ *
135
+ * It calls the parent's assemble method first, then initializes control references and event handlers.
136
+ * If the `datasource.selector` option is provided and is a string, it searches for the corresponding
137
+ * element in the DOM using that selector.
138
+ *
139
+ * If the selector matches exactly one element, it checks if the element is an instance of the `Datasource` class.
140
+ *
141
+ * If it is, the component's `datasourceLinkedElementSymbol` property is set to the element, and the component
142
+ * attaches an observer to the datasource's changes.
143
+ *
144
+ * The observer is a function that calls the `handleDataSourceChanges` method in the context of the component.
145
+ * Additionally, the component attaches an observer to itself, which also calls the `handleDataSourceChanges`
146
+ * method in the component's context.
147
+ */
148
+ [assembleMethodSymbol]() {
149
+ super[assembleMethodSymbol]();
150
+ const self = this;
151
+
152
+ initControlReferences.call(this);
153
+ initEventHandler.call(this);
154
+
155
+ const selector = this.getOption("datasource.selector");
156
+
157
+ if (isString(selector)) {
158
+
159
+ const element = findElementWithSelectorUpwards( this,selector);
160
+ if (element===null) {
161
+ throw new Error("the selector must match exactly one element");
162
+ }
163
+
164
+ if (!(element instanceof Datasource)) {
165
+ throw new TypeError("the element must be a datasource");
166
+ }
167
+
168
+ this[datasourceLinkedElementSymbol] = element;
169
+ element.datasource.attachObserver(
170
+ new Observer(handleDataSourceChanges.bind(this)),
171
+ );
172
+
173
+ let originValues;
174
+
175
+ element.datasource.attachObserver(
176
+ new Observer(function () {
177
+ if (!originValues) {
178
+ originValues = clone(self[datasourceLinkedElementSymbol].data);
179
+ }
180
+
181
+ const currentValues = this.getRealSubject();
182
+ const ignoreChanges = self.getOption("ignoreChanges");
183
+
184
+ const result = diff(originValues, currentValues);
185
+ if (isArray(ignoreChanges) && ignoreChanges.length > 0) {
186
+ const itemsToRemove = [];
187
+ for (const item of result) {
188
+ for (const ignorePattern of ignoreChanges) {
189
+ const p = new RegExp(ignorePattern);
190
+ if (p.test(item.path)) {
191
+ itemsToRemove.push(item);
192
+ break;
193
+ }
194
+ }
195
+ }
196
+
197
+ for (const itemToRemove of itemsToRemove) {
198
+ const index = result.indexOf(itemToRemove);
199
+ if (index > -1) {
200
+ result.splice(index, 1);
201
+ }
202
+ }
203
+ }
204
+
205
+ if (isArray(result) && result.length > 0) {
206
+ self[stateButtonElementSymbol].setState("changed");
207
+ self[stateButtonElementSymbol].setOption("disabled", false);
208
+ self.setOption("changes", result.length);
209
+ self.setOption(
210
+ "classes.badge",
211
+ new TokenList(self.getOption("classes.badge"))
212
+ .remove("hidden")
213
+ .toString(),
214
+ );
215
+ } else {
216
+ self[stateButtonElementSymbol].removeState();
217
+ self[stateButtonElementSymbol].setOption("disabled", true);
218
+ self.setOption("changes", 0);
219
+ self.setOption(
220
+ "classes.badge",
221
+ new TokenList(self.getOption("classes.badge"))
222
+ .add("hidden")
223
+ .toString(),
224
+ );
225
+ }
226
+ }),
227
+ );
228
+ }
229
+
230
+ this.attachObserver(
231
+ new Observer(() => {
232
+ handleDataSourceChanges.call(this);
233
+ }),
234
+ );
235
+ }
236
+
237
+ /**
238
+ *
239
+ * @return [CSSStyleSheet]
240
+ */
241
+ static getCSSStyleSheet() {
242
+ return [SaveButtonStyleSheet, BadgeStyleSheet];
243
+ }
234
244
  }
235
245
 
236
246
  /**
@@ -238,77 +248,77 @@ class SaveButton extends CustomElement {
238
248
  * @return {Monster.Components.Datatable.Form}
239
249
  */
240
250
  function initControlReferences() {
241
- if (!this.shadowRoot) {
242
- throw new Error("no shadow-root is defined");
243
- }
244
-
245
- this[stateButtonElementSymbol] = this.shadowRoot.querySelector(
246
- "[data-monster-role=state-button]",
247
- );
248
-
249
- this[badgeElementSymbol] = this.shadowRoot.querySelector(
250
- "[data-monster-role=badge]",
251
- );
252
-
253
- if (this[stateButtonElementSymbol]) {
254
- setTimeout(() => {
255
- const states = {
256
- changed: new State(
257
- "changed",
258
- '<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-cloud-arrow-up" viewBox="0 0 16 16">\n' +
259
- ' <path fill-rule="evenodd" d="M7.646 5.146a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 6.707V10.5a.5.5 0 0 1-1 0V6.707L6.354 7.854a.5.5 0 1 1-.708-.708z"/>\n' +
260
- ' <path d="M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383m.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z"/>\n' +
261
- "</svg>",
262
- ),
263
- };
264
-
265
- this[stateButtonElementSymbol].removeState();
266
- this[stateButtonElementSymbol].setOption("disabled", "disabled");
267
- this[stateButtonElementSymbol].setOption("states", states);
268
- this[stateButtonElementSymbol].setOption(
269
- "labels.button",
270
- this.getOption("labels.button"),
271
- );
272
- }, 1);
273
- }
274
-
275
- return this;
251
+ if (!this.shadowRoot) {
252
+ throw new Error("no shadow-root is defined");
253
+ }
254
+
255
+ this[stateButtonElementSymbol] = this.shadowRoot.querySelector(
256
+ "[data-monster-role=state-button]",
257
+ );
258
+
259
+ this[badgeElementSymbol] = this.shadowRoot.querySelector(
260
+ "[data-monster-role=badge]",
261
+ );
262
+
263
+ if (this[stateButtonElementSymbol]) {
264
+ setTimeout(() => {
265
+ const states = {
266
+ changed: new State(
267
+ "changed",
268
+ '<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-cloud-arrow-up" viewBox="0 0 16 16">\n' +
269
+ ' <path fill-rule="evenodd" d="M7.646 5.146a.5.5 0 0 1 .708 0l2 2a.5.5 0 0 1-.708.708L8.5 6.707V10.5a.5.5 0 0 1-1 0V6.707L6.354 7.854a.5.5 0 1 1-.708-.708z"/>\n' +
270
+ ' <path d="M4.406 3.342A5.53 5.53 0 0 1 8 2c2.69 0 4.923 2 5.166 4.579C14.758 6.804 16 8.137 16 9.773 16 11.569 14.502 13 12.687 13H3.781C1.708 13 0 11.366 0 9.318c0-1.763 1.266-3.223 2.942-3.593.143-.863.698-1.723 1.464-2.383m.653.757c-.757.653-1.153 1.44-1.153 2.056v.448l-.445.049C2.064 6.805 1 7.952 1 9.318 1 10.785 2.23 12 3.781 12h8.906C13.98 12 15 10.988 15 9.773c0-1.216-1.02-2.228-2.313-2.228h-.5v-.5C12.188 4.825 10.328 3 8 3a4.53 4.53 0 0 0-2.941 1.1z"/>\n' +
271
+ "</svg>",
272
+ ),
273
+ };
274
+
275
+ this[stateButtonElementSymbol].removeState();
276
+ this[stateButtonElementSymbol].setOption("disabled", "disabled");
277
+ this[stateButtonElementSymbol].setOption("states", states);
278
+ this[stateButtonElementSymbol].setOption(
279
+ "labels.button",
280
+ this.getOption("labels.button"),
281
+ );
282
+ }, 1);
283
+ }
284
+
285
+ return this;
276
286
  }
277
287
 
278
288
  /**
279
289
  * @private
280
290
  */
281
291
  function initEventHandler() {
282
- setTimeout(() => {
283
- this[stateButtonElementSymbol].setOption("actions.click", () => {
284
- this[datasourceLinkedElementSymbol]
285
- .write()
286
- .then(() => {
287
- this[stateButtonElementSymbol].removeState();
288
- this[stateButtonElementSymbol].setOption("disabled", true);
289
- this.setOption("changes", 0);
290
- this.setOption(
291
- "classes.badge",
292
- new TokenList(this.getOption("classes.badge"))
293
- .add("hidden")
294
- .toString(),
295
- );
296
- })
297
- .catch((error) => {
298
- addAttributeToken(this, ATTRIBUTE_ERRORMESSAGE, e.toString());
299
- });
300
- });
301
- }, 1);
292
+ setTimeout(() => {
293
+ this[stateButtonElementSymbol].setOption("actions.click", () => {
294
+ this[datasourceLinkedElementSymbol]
295
+ .write()
296
+ .then(() => {
297
+ this[stateButtonElementSymbol].removeState();
298
+ this[stateButtonElementSymbol].setOption("disabled", true);
299
+ this.setOption("changes", 0);
300
+ this.setOption(
301
+ "classes.badge",
302
+ new TokenList(this.getOption("classes.badge"))
303
+ .add("hidden")
304
+ .toString(),
305
+ );
306
+ })
307
+ .catch((error) => {
308
+ addAttributeToken(this, ATTRIBUTE_ERRORMESSAGE, e.toString());
309
+ });
310
+ });
311
+ }, 1);
302
312
  }
303
313
 
304
314
  /**
305
315
  * @param {Object} options
306
316
  */
307
317
  function updateOptionsFromArguments(options) {
308
- const selector = this.getAttribute(ATTRIBUTE_DATASOURCE_SELECTOR);
309
- if (selector) {
310
- options.datasource.selector = selector;
311
- }
318
+ const selector = this.getAttribute(ATTRIBUTE_DATASOURCE_SELECTOR);
319
+ if (selector) {
320
+ options.datasource.selector = selector;
321
+ }
312
322
  }
313
323
 
314
324
  /**
@@ -316,8 +326,8 @@ function updateOptionsFromArguments(options) {
316
326
  * @return {string}
317
327
  */
318
328
  function getTemplate() {
319
- // language=HTML
320
- return `
329
+ // language=HTML
330
+ return `
321
331
  <div data-monster-role="control" part="control"
322
332
  data-monster-attributes="disabled path:disabled | if:true">
323
333
  <monster-state-button data-monster-role="state-button">save</monster-state-button>
@@ -1,5 +1,14 @@
1
1
  /**
2
- * Copyright 2023 schukai GmbH
2
+ * Copyright © schukai GmbH and all contributing authors, {{copyRightYear}}. All rights reserved.
3
+ * Node module: @schukai/monster
4
+ *
5
+ * This source code is licensed under the GNU Affero General Public License version 3 (AGPLv3).
6
+ * The full text of the license can be found at: https://www.gnu.org/licenses/agpl-3.0.en.html
7
+ *
8
+ * For those who do not wish to adhere to the AGPLv3, a commercial license is available.
9
+ * Acquiring a commercial license allows you to use this software without complying with the AGPLv3 terms.
10
+ * For more information about purchasing a commercial license, please contact schukai GmbH.
11
+ *
3
12
  * SPDX-License-Identifier: AGPL-3.0
4
13
  */
5
14
 
@@ -8,6 +17,7 @@ import {
8
17
  CustomElement,
9
18
  registerCustomElement,
10
19
  } from "../../dom/customelement.mjs";
20
+ import {findElementWithSelectorUpwards} from "../../dom/util.mjs";
11
21
  import { ThemeStyleSheet } from "../stylesheet/theme.mjs";
12
22
  import { Datasource } from "./datasource.mjs";
13
23
  import { SpinnerStyleSheet } from "../stylesheet/spinner.mjs";
@@ -165,12 +175,12 @@ function initEventHandler() {
165
175
  const self = this;
166
176
 
167
177
  if (isString(selector)) {
168
- const elements = document.querySelectorAll(selector);
169
- if (elements.length !== 1) {
178
+
179
+ const element = findElementWithSelectorUpwards( this,selector);
180
+ if (element===null) {
170
181
  throw new Error("the selector must match exactly one element");
171
182
  }
172
-
173
- const element = elements[0];
183
+
174
184
  if (!(element instanceof Datasource)) {
175
185
  throw new TypeError("the element must be a datasource");
176
186
  }