@iamproperty/components 7.7.1--beta6 → 7.7.1--beta8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (593) hide show
  1. package/README.md +4 -4
  2. package/assets/bootstrap/README.md +247 -247
  3. package/assets/bootstrap/js/index.esm.js +19 -19
  4. package/assets/bootstrap/js/index.umd.js +34 -34
  5. package/assets/bootstrap/js/src/alert.js +87 -87
  6. package/assets/bootstrap/js/src/base-component.js +85 -85
  7. package/assets/bootstrap/js/src/button.js +72 -72
  8. package/assets/bootstrap/js/src/carousel.js +475 -475
  9. package/assets/bootstrap/js/src/collapse.js +302 -302
  10. package/assets/bootstrap/js/src/dom/data.js +55 -55
  11. package/assets/bootstrap/js/src/dom/event-handler.js +320 -320
  12. package/assets/bootstrap/js/src/dom/manipulator.js +71 -71
  13. package/assets/bootstrap/js/src/dom/selector-engine.js +83 -83
  14. package/assets/bootstrap/js/src/dropdown.js +445 -445
  15. package/assets/bootstrap/js/src/modal.js +373 -373
  16. package/assets/bootstrap/js/src/offcanvas.js +283 -283
  17. package/assets/bootstrap/js/src/popover.js +97 -97
  18. package/assets/bootstrap/js/src/scrollspy.js +290 -290
  19. package/assets/bootstrap/js/src/tab.js +307 -307
  20. package/assets/bootstrap/js/src/toast.js +220 -220
  21. package/assets/bootstrap/js/src/tooltip.js +651 -651
  22. package/assets/bootstrap/js/src/util/backdrop.js +149 -149
  23. package/assets/bootstrap/js/src/util/component-functions.js +34 -34
  24. package/assets/bootstrap/js/src/util/config.js +66 -66
  25. package/assets/bootstrap/js/src/util/focustrap.js +115 -115
  26. package/assets/bootstrap/js/src/util/index.js +336 -336
  27. package/assets/bootstrap/js/src/util/sanitizer.js +118 -118
  28. package/assets/bootstrap/js/src/util/scrollbar.js +114 -114
  29. package/assets/bootstrap/js/src/util/swipe.js +146 -146
  30. package/assets/bootstrap/js/src/util/template-factory.js +160 -160
  31. package/assets/bootstrap/package.json +180 -180
  32. package/assets/bootstrap/scss/_accordion.scss +146 -146
  33. package/assets/bootstrap/scss/_button-group.scss +142 -142
  34. package/assets/bootstrap/scss/_buttons.scss +186 -186
  35. package/assets/bootstrap/scss/_carousel.scss +229 -229
  36. package/assets/bootstrap/scss/_dropdown.scss +248 -248
  37. package/assets/bootstrap/scss/_functions.scss +302 -302
  38. package/assets/bootstrap/scss/_list-group.scss +191 -191
  39. package/assets/bootstrap/scss/_modal.scss +237 -237
  40. package/assets/bootstrap/scss/_nav.scss +172 -172
  41. package/assets/bootstrap/scss/_navbar.scss +276 -276
  42. package/assets/bootstrap/scss/_offcanvas.scss +143 -143
  43. package/assets/bootstrap/scss/_pagination.scss +109 -109
  44. package/assets/bootstrap/scss/_popover.scss +196 -196
  45. package/assets/bootstrap/scss/_toasts.scss +70 -70
  46. package/assets/bootstrap/scss/_variables-dark.scss +87 -87
  47. package/assets/bootstrap/scss/_variables.scss +1633 -1633
  48. package/assets/bootstrap/scss/bootstrap-utilities.scss +15 -15
  49. package/assets/bootstrap/scss/forms/_floating-labels.scss +74 -74
  50. package/assets/bootstrap/scss/forms/_input-group.scss +129 -129
  51. package/assets/bootstrap/scss/helpers/_focus-ring.scss +5 -5
  52. package/assets/bootstrap/scss/helpers/_icon-link.scss +25 -25
  53. package/assets/bootstrap/scss/mixins/_banner.scss +9 -9
  54. package/assets/bootstrap/scss/mixins/_color-mode.scss +21 -21
  55. package/assets/bootstrap/scss/mixins/_forms.scss +152 -152
  56. package/assets/bootstrap/scss/mixins/_table-variants.scss +24 -24
  57. package/assets/bootstrap/scss/mixins/_utilities.scss +97 -97
  58. package/assets/css/components/{header.css → header.component.css} +1 -1
  59. package/assets/css/components/header.component.css.map +1 -0
  60. package/assets/css/components/header.preload.css +1 -0
  61. package/assets/css/components/header.preload.css.map +1 -0
  62. package/assets/css/components/nav.component.css +1 -1
  63. package/assets/css/components/nav.component.css.map +1 -1
  64. package/assets/css/components/notification.css +1 -1
  65. package/assets/css/components/notification.css.map +1 -1
  66. package/assets/css/components/table-basic.global.css +1 -1
  67. package/assets/css/components/table-basic.global.css.map +1 -1
  68. package/assets/css/components/table.global.css +1 -1
  69. package/assets/css/components/table.global.css.map +1 -1
  70. package/assets/css/core.min.css +1 -1
  71. package/assets/css/core.min.css.map +1 -1
  72. package/assets/css/style.min.css +1 -1
  73. package/assets/css/style.min.css.map +1 -1
  74. package/assets/favicons/README.md +20 -20
  75. package/assets/favicons/browserconfig.xml +9 -9
  76. package/assets/favicons/manifest.json +31 -31
  77. package/assets/favicons/safari-pinned-tab.svg +35 -35
  78. package/assets/favicons/site.webmanifest +20 -20
  79. package/assets/js/components/accordion/accordion.component.js +14 -14
  80. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  81. package/assets/js/components/accordion/accordion.component.min.js.map +1 -1
  82. package/assets/js/components/actionbar/actionbar.component.js +66 -66
  83. package/assets/js/components/actionbar/actionbar.component.min.js +1 -1
  84. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  85. package/assets/js/components/address-lookup/address-lookup.component.js +58 -58
  86. package/assets/js/components/address-lookup/address-lookup.component.min.js +1 -1
  87. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  88. package/assets/js/components/advanced-select/advanced-select.component.js +18 -18
  89. package/assets/js/components/advanced-select/advanced-select.component.min.js +1 -1
  90. package/assets/js/components/advanced-select/advanced-select.component.min.js.map +1 -1
  91. package/assets/js/components/applied-filters/applied-filters.component.js +6 -6
  92. package/assets/js/components/applied-filters/applied-filters.component.min.js +1 -1
  93. package/assets/js/components/applied-filters/applied-filters.component.min.js.map +1 -1
  94. package/assets/js/components/barchart/barchart.component.min.js +1 -1
  95. package/assets/js/components/barchart/barchart.component.min.js.map +1 -1
  96. package/assets/js/components/bento-grid/bento-grid.component.js +9 -9
  97. package/assets/js/components/bento-grid/bento-grid.component.min.js +1 -1
  98. package/assets/js/components/bento-grid/bento-grid.component.min.js.map +1 -1
  99. package/assets/js/components/calendar/calendar.component.min.js +1 -1
  100. package/assets/js/components/card/card.component.min.js +1 -1
  101. package/assets/js/components/card/card.component.min.js.map +1 -1
  102. package/assets/js/components/carousel/carousel.component.min.js +1 -1
  103. package/assets/js/components/collapsible-side/collapsible-side.component.js +20 -20
  104. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +1 -1
  105. package/assets/js/components/collapsible-side/collapsible-side.component.min.js.map +1 -1
  106. package/assets/js/components/config/config.component.js +53 -53
  107. package/assets/js/components/config/config.component.min.js +1 -1
  108. package/assets/js/components/config/config.component.min.js.map +1 -1
  109. package/assets/js/components/content/content.component.js +9 -9
  110. package/assets/js/components/content/content.component.min.js +1 -1
  111. package/assets/js/components/content/content.component.min.js.map +1 -1
  112. package/assets/js/components/darkmode/darkmode.component.js +4 -4
  113. package/assets/js/components/darkmode/darkmode.component.min.js +1 -1
  114. package/assets/js/components/darkmode/darkmode.component.min.js.map +1 -1
  115. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +1 -1
  116. package/assets/js/components/doughnutchart/doughnutchart.component.min.js.map +1 -1
  117. package/assets/js/components/fileupload/fileupload.component.js +16 -16
  118. package/assets/js/components/fileupload/fileupload.component.min.js +1 -1
  119. package/assets/js/components/fileupload/fileupload.component.min.js.map +1 -1
  120. package/assets/js/components/filter-card/filter-card.component.js +7 -7
  121. package/assets/js/components/filter-card/filter-card.component.min.js +1 -1
  122. package/assets/js/components/filter-card/filter-card.component.min.js.map +1 -1
  123. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  124. package/assets/js/components/form/form.component.js +4 -4
  125. package/assets/js/components/form/form.component.min.js +1 -1
  126. package/assets/js/components/form/form.component.min.js.map +1 -1
  127. package/assets/js/components/header/header.component.js +54 -54
  128. package/assets/js/components/header/header.component.min.js +2 -2
  129. package/assets/js/components/header/header.component.min.js.map +1 -1
  130. package/assets/js/components/inline-edit/inline-edit.component.js +16 -16
  131. package/assets/js/components/inline-edit/inline-edit.component.min.js +1 -1
  132. package/assets/js/components/inline-edit/inline-edit.component.min.js.map +1 -1
  133. package/assets/js/components/input/input.component.js +10 -10
  134. package/assets/js/components/input/input.component.min.js +1 -1
  135. package/assets/js/components/input/input.component.min.js.map +1 -1
  136. package/assets/js/components/input-range/input-range.component.js +8 -8
  137. package/assets/js/components/input-range/input-range.component.min.js +1 -1
  138. package/assets/js/components/input-range/input-range.component.min.js.map +1 -1
  139. package/assets/js/components/marketing/marketing.component.js +10 -10
  140. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  141. package/assets/js/components/marketing/marketing.component.min.js.map +1 -1
  142. package/assets/js/components/menu/menu.component.js +6 -6
  143. package/assets/js/components/menu/menu.component.min.js +1 -1
  144. package/assets/js/components/menu/menu.component.min.js.map +1 -1
  145. package/assets/js/components/milestone/milestone.component.min.js +1 -1
  146. package/assets/js/components/milestone-group/milestone-group.component.min.js +1 -1
  147. package/assets/js/components/modal/modal.component.js +21 -21
  148. package/assets/js/components/modal/modal.component.min.js +1 -1
  149. package/assets/js/components/modal/modal.component.min.js.map +1 -1
  150. package/assets/js/components/multi-step/multi-step.component.min.js +1 -1
  151. package/assets/js/components/multi-step-modal/multi-step-modal.component.js +11 -11
  152. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js +1 -1
  153. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js.map +1 -1
  154. package/assets/js/components/multiselect/multiselect.component.js +20 -20
  155. package/assets/js/components/multiselect/multiselect.component.min.js +1 -1
  156. package/assets/js/components/multiselect/multiselect.component.min.js.map +1 -1
  157. package/assets/js/components/nav/nav.component.js +45 -45
  158. package/assets/js/components/nav/nav.component.min.js +2 -2
  159. package/assets/js/components/nav/nav.component.min.js.map +1 -1
  160. package/assets/js/components/notification/notification.component.js +14 -13
  161. package/assets/js/components/notification/notification.component.min.js +5 -4
  162. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  163. package/assets/js/components/pagination/pagination.component.js +39 -39
  164. package/assets/js/components/pagination/pagination.component.min.js +1 -1
  165. package/assets/js/components/pagination/pagination.component.min.js.map +1 -1
  166. package/assets/js/components/password/password.component.js +10 -10
  167. package/assets/js/components/password/password.component.min.js +1 -1
  168. package/assets/js/components/password/password.component.min.js.map +1 -1
  169. package/assets/js/components/popover/popover.component.js +7 -7
  170. package/assets/js/components/popover/popover.component.min.js +1 -1
  171. package/assets/js/components/popover/popover.component.min.js.map +1 -1
  172. package/assets/js/components/rank/rank.component.js +359 -359
  173. package/assets/js/components/rank/rank.component.min.js +1 -1
  174. package/assets/js/components/rank/rank.component.min.js.map +1 -1
  175. package/assets/js/components/rankings/rankings.component.js +16 -16
  176. package/assets/js/components/rankings/rankings.component.min.js +1 -1
  177. package/assets/js/components/rankings/rankings.component.min.js.map +1 -1
  178. package/assets/js/components/rating/rating.component.js +9 -9
  179. package/assets/js/components/rating/rating.component.min.js +1 -1
  180. package/assets/js/components/rating/rating.component.min.js.map +1 -1
  181. package/assets/js/components/record-card/record-card.component.min.js +1 -1
  182. package/assets/js/components/record-card/record-card.component.min.js.map +1 -1
  183. package/assets/js/components/search/search.component.js +17 -17
  184. package/assets/js/components/search/search.component.min.js +1 -1
  185. package/assets/js/components/search/search.component.min.js.map +1 -1
  186. package/assets/js/components/slider/slider.component.js +12 -12
  187. package/assets/js/components/slider/slider.component.min.js +1 -1
  188. package/assets/js/components/slider/slider.component.min.js.map +1 -1
  189. package/assets/js/components/split-button/split-button.component.js +18 -18
  190. package/assets/js/components/split-button/split-button.component.min.js +1 -1
  191. package/assets/js/components/split-button/split-button.component.min.js.map +1 -1
  192. package/assets/js/components/std-address-lookup/std-address-lookup.component.js +113 -113
  193. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js +1 -1
  194. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js.map +1 -1
  195. package/assets/js/components/table/table.component.js +15 -15
  196. package/assets/js/components/table/table.component.min.js +2 -2
  197. package/assets/js/components/table/table.component.min.js.map +1 -1
  198. package/assets/js/components/table-ajax/table-ajax.component.js +15 -15
  199. package/assets/js/components/table-ajax/table-ajax.component.min.js +2 -2
  200. package/assets/js/components/table-ajax/table-ajax.component.min.js.map +1 -1
  201. package/assets/js/components/table-basic/table-basic.component.js +15 -15
  202. package/assets/js/components/table-basic/table-basic.component.min.js +2 -2
  203. package/assets/js/components/table-basic/table-basic.component.min.js.map +1 -1
  204. package/assets/js/components/table-no-submit/table-no-submit.component.js +15 -15
  205. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +2 -2
  206. package/assets/js/components/table-no-submit/table-no-submit.component.min.js.map +1 -1
  207. package/assets/js/components/table-submit/table-submit.component.js +15 -15
  208. package/assets/js/components/table-submit/table-submit.component.min.js +2 -2
  209. package/assets/js/components/table-submit/table-submit.component.min.js.map +1 -1
  210. package/assets/js/components/tabs/tabs.component.js +17 -17
  211. package/assets/js/components/tabs/tabs.component.min.js +1 -1
  212. package/assets/js/components/tabs/tabs.component.min.js.map +1 -1
  213. package/assets/js/components/tag/tag.component.js +12 -12
  214. package/assets/js/components/tag/tag.component.min.js +1 -1
  215. package/assets/js/components/tag/tag.component.min.js.map +1 -1
  216. package/assets/js/components/tooltip/tooltip.component.js +8 -8
  217. package/assets/js/components/tooltip/tooltip.component.min.js +1 -1
  218. package/assets/js/components/tooltip/tooltip.component.min.js.map +1 -1
  219. package/assets/js/components/video/video.component.js +9 -9
  220. package/assets/js/components/video/video.component.min.js +1 -1
  221. package/assets/js/components/video/video.component.min.js.map +1 -1
  222. package/assets/js/components/video-card/video-card.component.js +12 -12
  223. package/assets/js/components/video-card/video-card.component.min.js +1 -1
  224. package/assets/js/components/video-card/video-card.component.min.js.map +1 -1
  225. package/assets/js/components/video-modal/video-modal.component.js +13 -13
  226. package/assets/js/components/video-modal/video-modal.component.min.js +1 -1
  227. package/assets/js/components/video-modal/video-modal.component.min.js.map +1 -1
  228. package/assets/js/components/word-count/word-count.component.min.js +1 -1
  229. package/assets/js/modules/card.module.js +14 -14
  230. package/assets/js/modules/chart.module.js +4 -4
  231. package/assets/js/modules/integration-tests.js +3 -3
  232. package/assets/js/modules/table.js +2 -2
  233. package/assets/js/modules/videos.js +6 -6
  234. package/assets/js/scripts.bundle.js +1 -1
  235. package/assets/js/scripts.bundle.js.map +1 -1
  236. package/assets/js/scripts.bundle.min.js +1 -1
  237. package/assets/js/scripts.bundle.min.js.map +1 -1
  238. package/assets/sass/_bs_grid.scss +41 -41
  239. package/assets/sass/_bs_utilities.scss +51 -51
  240. package/assets/sass/_components.scss +151 -162
  241. package/assets/sass/_corefiles.scss +31 -31
  242. package/assets/sass/_elements.scss +30 -30
  243. package/assets/sass/_fonts.scss +28 -28
  244. package/assets/sass/_func.scss +2 -2
  245. package/assets/sass/_functions/bs_functions.scss +487 -487
  246. package/assets/sass/_functions/bs_mixins.scss +2103 -2103
  247. package/assets/sass/_functions/bs_utilities.scss +922 -922
  248. package/assets/sass/_functions/bs_variables.scss +1701 -1701
  249. package/assets/sass/_functions/functions.scss +48 -48
  250. package/assets/sass/_functions/mixins.scss +1 -1
  251. package/assets/sass/_grid.scss +320 -320
  252. package/assets/sass/_print.scss +64 -64
  253. package/assets/sass/_utilities.scss +35 -35
  254. package/assets/sass/components/actionbar.component.scss +421 -421
  255. package/assets/sass/components/actionbar.global.scss +115 -115
  256. package/assets/sass/components/address-lookup.component.scss +160 -160
  257. package/assets/sass/components/address-lookup.preload.scss +90 -90
  258. package/assets/sass/components/applied-filters.scss +19 -19
  259. package/assets/sass/components/barchart.component.scss +347 -347
  260. package/assets/sass/components/bento-grid.component.scss +109 -109
  261. package/assets/sass/components/bento-grid.global.scss +248 -248
  262. package/assets/sass/components/calendar.component.scss +1272 -1272
  263. package/assets/sass/components/calendar.config.scss +423 -423
  264. package/assets/sass/components/card.component.scss +187 -187
  265. package/assets/sass/components/card.module.scss +154 -154
  266. package/assets/sass/components/carousel.component.scss +631 -631
  267. package/assets/sass/components/carousel.config.scss +84 -84
  268. package/assets/sass/components/charts.config.scss +86 -86
  269. package/assets/sass/components/charts.module.scss +588 -588
  270. package/assets/sass/components/charts.scss +1298 -1298
  271. package/assets/sass/components/collapsible-side.scss +307 -307
  272. package/assets/sass/components/config.component.scss +235 -235
  273. package/assets/sass/components/content.component.scss +18 -18
  274. package/assets/sass/components/darkmode.component.scss +20 -20
  275. package/assets/sass/components/doughnutchart.component.scss +206 -206
  276. package/assets/sass/components/fileupload.scss +162 -162
  277. package/assets/sass/components/filter-card.component.scss +99 -99
  278. package/assets/sass/components/{header.scss → header.component.scss} +249 -251
  279. package/assets/sass/components/header.preload.scss +26 -0
  280. package/assets/sass/components/inline-edit.preload.scss +203 -203
  281. package/assets/sass/components/inline-edit.scss +40 -40
  282. package/assets/sass/components/input-range.component.scss +46 -46
  283. package/assets/sass/components/input.component.scss +101 -101
  284. package/assets/sass/components/marketing.component.scss +65 -65
  285. package/assets/sass/components/menu.component.scss +161 -161
  286. package/assets/sass/components/menu.global.scss +82 -82
  287. package/assets/sass/components/milestone.scss +216 -216
  288. package/assets/sass/components/modal.component.scss +252 -252
  289. package/assets/sass/components/multi-step-modal.component.scss +255 -255
  290. package/assets/sass/components/multi-step-modal.global.scss +91 -91
  291. package/assets/sass/components/multi-step.component.scss +144 -144
  292. package/assets/sass/components/multiselect.preload.scss +8 -8
  293. package/assets/sass/components/multiselect.scss +238 -238
  294. package/assets/sass/components/nav.component.scss +718 -718
  295. package/assets/sass/components/nav.docs.scss +55 -55
  296. package/assets/sass/components/nav.global.scss +870 -870
  297. package/assets/sass/components/nav.preload.scss +54 -54
  298. package/assets/sass/components/notification.scss +204 -217
  299. package/assets/sass/components/pagination.scss +237 -237
  300. package/assets/sass/components/password.component.scss +55 -55
  301. package/assets/sass/components/popover.component.scss +28 -28
  302. package/assets/sass/components/property-searchbar.scss +139 -139
  303. package/assets/sass/components/rank.component.scss +275 -275
  304. package/assets/sass/components/rankings.component.scss +70 -70
  305. package/assets/sass/components/rankings.global.scss +140 -140
  306. package/assets/sass/components/rating.component.css +211 -211
  307. package/assets/sass/components/record-card.component.scss +191 -191
  308. package/assets/sass/components/slider.scss +127 -127
  309. package/assets/sass/components/snapshot.scss +65 -65
  310. package/assets/sass/components/split-button.component.scss +83 -83
  311. package/assets/sass/components/stepper.scss +157 -157
  312. package/assets/sass/components/table-basic.component.scss +136 -136
  313. package/assets/sass/components/table-basic.global.scss +676 -676
  314. package/assets/sass/components/table.component.scss +51 -51
  315. package/assets/sass/components/table.global.scss +399 -398
  316. package/assets/sass/components/tabs.component.scss +34 -34
  317. package/assets/sass/components/tabs.config.scss +258 -258
  318. package/assets/sass/components/tag.component.scss +59 -59
  319. package/assets/sass/components/tag.preload.scss +20 -20
  320. package/assets/sass/components/testimonial.scss +125 -125
  321. package/assets/sass/components/timeline.scss +92 -92
  322. package/assets/sass/components/tooltip.component.scss +148 -148
  323. package/assets/sass/components/video-card.component.scss +48 -48
  324. package/assets/sass/components/video-modal.component.scss +26 -26
  325. package/assets/sass/components/video.component.scss +74 -74
  326. package/assets/sass/components/word-count.component.scss +26 -26
  327. package/assets/sass/core.scss +4 -4
  328. package/assets/sass/elements/admin-panel.css +310 -310
  329. package/assets/sass/elements/badge-tag.css +101 -101
  330. package/assets/sass/elements/brand.css +80 -80
  331. package/assets/sass/elements/button__group.css +135 -135
  332. package/assets/sass/elements/buttons--action.css +71 -71
  333. package/assets/sass/elements/buttons--compact.css +168 -168
  334. package/assets/sass/elements/buttons--global.css +239 -239
  335. package/assets/sass/elements/buttons--secondary.css +18 -18
  336. package/assets/sass/elements/buttons--special.css +164 -164
  337. package/assets/sass/elements/buttons--tertiary.css +51 -51
  338. package/assets/sass/elements/buttons.scss +9 -9
  339. package/assets/sass/elements/code.css +45 -45
  340. package/assets/sass/elements/container.scss +118 -118
  341. package/assets/sass/elements/details.css +224 -224
  342. package/assets/sass/elements/dialog.scss +75 -75
  343. package/assets/sass/elements/dropdown.css +85 -85
  344. package/assets/sass/elements/feature.css +174 -174
  345. package/assets/sass/elements/forms.scss +1337 -1337
  346. package/assets/sass/elements/highlight.css +76 -76
  347. package/assets/sass/elements/hr.css +41 -41
  348. package/assets/sass/elements/icons.css +48 -48
  349. package/assets/sass/elements/input.scss +212 -212
  350. package/assets/sass/elements/label.css +20 -20
  351. package/assets/sass/elements/links--collapsible-side.scss +129 -129
  352. package/assets/sass/elements/links--global.scss +155 -155
  353. package/assets/sass/elements/links--video.scss +73 -73
  354. package/assets/sass/elements/links.scss +4 -4
  355. package/assets/sass/elements/lists--breadcrumbs.scss +26 -26
  356. package/assets/sass/elements/lists--steps.css +171 -171
  357. package/assets/sass/elements/lists--tick-list.scss +112 -112
  358. package/assets/sass/elements/lists.scss +99 -99
  359. package/assets/sass/elements/media.css +20 -20
  360. package/assets/sass/elements/modal.scss +411 -411
  361. package/assets/sass/elements/popover.scss +259 -259
  362. package/assets/sass/elements/prefix.scss +139 -139
  363. package/assets/sass/elements/progress.scss +208 -208
  364. package/assets/sass/elements/table.element.scss +144 -144
  365. package/assets/sass/elements/textarea.css +84 -84
  366. package/assets/sass/elements/toggle-button.css +49 -49
  367. package/assets/sass/elements/tooltips.scss +152 -152
  368. package/assets/sass/elements/type.css +166 -166
  369. package/assets/sass/email.scss +68 -68
  370. package/assets/sass/error.scss +31 -31
  371. package/assets/sass/foundations/animations.scss +2 -2
  372. package/assets/sass/foundations/colours.scss +104 -104
  373. package/assets/sass/foundations/reboot.scss +166 -166
  374. package/assets/sass/foundations/root.scss +269 -269
  375. package/assets/sass/main.scss +7 -7
  376. package/assets/sass/templates/auth.scss +106 -106
  377. package/assets/sass/templates/form.scss +95 -95
  378. package/assets/sass/utilities/align.css +24 -24
  379. package/assets/sass/utilities/border.css +65 -65
  380. package/assets/sass/utilities/clearfix.css +8 -8
  381. package/assets/sass/utilities/colours.scss +43 -43
  382. package/assets/sass/utilities/columns.css +61 -61
  383. package/assets/sass/utilities/display.scss +89 -89
  384. package/assets/sass/utilities/fixed.css +16 -16
  385. package/assets/sass/utilities/flex.scss +291 -291
  386. package/assets/sass/utilities/font-awesome-iso-fallbacks.css +43 -43
  387. package/assets/sass/utilities/gap.css +25 -25
  388. package/assets/sass/utilities/gradients.css +39 -39
  389. package/assets/sass/utilities/js-display.css +12 -12
  390. package/assets/sass/utilities/line-clamp.css +24 -24
  391. package/assets/sass/utilities/margins.scss +74 -74
  392. package/assets/sass/utilities/max-height.scss +93 -93
  393. package/assets/sass/utilities/opacity.css +20 -20
  394. package/assets/sass/utilities/order.css +104 -104
  395. package/assets/sass/utilities/overflow.css +16 -16
  396. package/assets/sass/utilities/paddings.scss +33 -33
  397. package/assets/sass/utilities/pointer-events.css +8 -8
  398. package/assets/sass/utilities/position.css +67 -67
  399. package/assets/sass/utilities/ratio.css +33 -33
  400. package/assets/sass/utilities/rounded.css +56 -56
  401. package/assets/sass/utilities/shadow.css +6 -6
  402. package/assets/sass/utilities/sizes.css +92 -92
  403. package/assets/sass/utilities/sticky.css +38 -38
  404. package/assets/sass/utilities/text-truncate.css +6 -6
  405. package/assets/sass/utilities/text.css +190 -190
  406. package/assets/sass/utilities/visible.css +8 -8
  407. package/assets/sass/utilities/visually-hidden.css +13 -13
  408. package/assets/sass/utilities/wider-colours.scss +8 -8
  409. package/assets/svg/illustrations/table.svg +165 -165
  410. package/assets/svg/logo.svg +56 -56
  411. package/assets/ts/components/accordion/accordion.component.ts +77 -77
  412. package/assets/ts/components/actionbar/actionbar.component.ts +567 -567
  413. package/assets/ts/components/address-lookup/address-lookup.component.ts +672 -672
  414. package/assets/ts/components/advanced-select/advanced-select.component.ts +116 -116
  415. package/assets/ts/components/applied-filters/applied-filters.component.ts +37 -37
  416. package/assets/ts/components/bento-grid/bento-grid.component.ts +88 -88
  417. package/assets/ts/components/collapsible-side/collapsible-side.component.ts +165 -165
  418. package/assets/ts/components/config/config.component.ts +699 -699
  419. package/assets/ts/components/content/content.component.ts +78 -78
  420. package/assets/ts/components/darkmode/darkmode.component.ts +108 -108
  421. package/assets/ts/components/fileupload/fileupload.component.ts +74 -74
  422. package/assets/ts/components/filter-card/filter-card.component.ts +106 -106
  423. package/assets/ts/components/form/form.component.ts +102 -102
  424. package/assets/ts/components/header/header.component.ts +97 -97
  425. package/assets/ts/components/inline-edit/inline-edit.component.ts +212 -212
  426. package/assets/ts/components/input/input.component.ts +278 -278
  427. package/assets/ts/components/input-range/input-range.component.ts +78 -78
  428. package/assets/ts/components/marketing/marketing.component.ts +44 -44
  429. package/assets/ts/components/menu/menu.component.ts +212 -212
  430. package/assets/ts/components/modal/modal.component.ts +184 -184
  431. package/assets/ts/components/multi-step-modal/multi-step-modal.component.ts +304 -304
  432. package/assets/ts/components/multiselect/multiselect.component.ts +349 -349
  433. package/assets/ts/components/nav/nav.component.ts +369 -369
  434. package/assets/ts/components/notification/notification.component.ts +173 -172
  435. package/assets/ts/components/pagination/pagination.component.ts +213 -213
  436. package/assets/ts/components/password/password.component.ts +118 -118
  437. package/assets/ts/components/popover/popover.component.ts +50 -50
  438. package/assets/ts/components/rank/rank.component.ts +394 -394
  439. package/assets/ts/components/rankings/rankings.component.ts +79 -79
  440. package/assets/ts/components/rating/rating.component.ts +86 -86
  441. package/assets/ts/components/search/search.component.ts +244 -244
  442. package/assets/ts/components/slider/slider.component.ts +170 -170
  443. package/assets/ts/components/split-button/split-button.component.ts +63 -63
  444. package/assets/ts/components/std-address-lookup/std-address-lookup.component.ts +1919 -1919
  445. package/assets/ts/components/table/table.component.ts +94 -94
  446. package/assets/ts/components/table-ajax/table-ajax.component.ts +70 -70
  447. package/assets/ts/components/table-basic/table-basic.component.ts +56 -56
  448. package/assets/ts/components/table-no-submit/table-no-submit.component.ts +130 -130
  449. package/assets/ts/components/table-submit/table-submit.component.ts +71 -71
  450. package/assets/ts/components/tabs/tabs.component.ts +70 -70
  451. package/assets/ts/components/tag/tag.component.ts +104 -104
  452. package/assets/ts/components/tooltip/tooltip.component.ts +98 -98
  453. package/assets/ts/components/video/video.component.ts +74 -74
  454. package/assets/ts/components/video-card/video-card.component.ts +129 -129
  455. package/assets/ts/components/video-modal/video-modal.component.ts +88 -88
  456. package/assets/ts/modules/advanced-select.ts +186 -186
  457. package/assets/ts/modules/applied-filters.ts +238 -238
  458. package/assets/ts/modules/card.module.ts +46 -46
  459. package/assets/ts/modules/chart.module.ts +594 -594
  460. package/assets/ts/modules/data-layer.md +71 -71
  461. package/assets/ts/modules/dialogs.ts +259 -259
  462. package/assets/ts/modules/dropdown.ts +216 -216
  463. package/assets/ts/modules/helper.test.ts +143 -143
  464. package/assets/ts/modules/helpers.ts +212 -212
  465. package/assets/ts/modules/integration-tests.ts +525 -525
  466. package/assets/ts/modules/modal.ts +45 -45
  467. package/assets/ts/modules/password.ts +82 -82
  468. package/assets/ts/modules/table.ts +1500 -1500
  469. package/assets/ts/modules/test.ts +22 -22
  470. package/assets/ts/modules/videos.ts +233 -233
  471. package/assets/ts/scripts.ts +111 -111
  472. package/dist/components.es.js +25 -25
  473. package/dist/components.umd.js +10 -9
  474. package/package.json +115 -115
  475. package/src/components/AdvancedSelect/AdvancedSelect.vue +28 -28
  476. package/src/components/Config/Config.vue +23 -23
  477. package/src/components/DarkMode/DarkMode.vue +19 -19
  478. package/src/components/Filterlist/Filterlist.vue +23 -23
  479. package/src/components/Form/Form.vue +22 -22
  480. package/src/components/Header/Header.vue +36 -36
  481. package/src/components/Input/Input.vue +22 -22
  482. package/src/components/InputRange/InputRange.vue +22 -22
  483. package/src/components/Modal/Modal.vue +22 -22
  484. package/src/components/MultiStepModal/MultiStepModal.vue +23 -23
  485. package/src/components/NoteFeed/NoteFeed.vue +82 -82
  486. package/src/components/Password/Password.vue +23 -23
  487. package/src/components/Popover/Popover.vue +22 -22
  488. package/src/components/PropertySearchbar/PropertySearchbar.vue +235 -235
  489. package/src/components/PropertySearchbar/README.md +25 -25
  490. package/src/components/Rating/Rating.vue +22 -22
  491. package/src/components/STDAddressLookup/STDAddressLookup.vue +22 -22
  492. package/src/components/Snapshot/Snapshot.vue +30 -30
  493. package/src/components/Tag/Tag.vue +22 -22
  494. package/src/components/Tooltip/Tooltip.vue +22 -22
  495. package/src/components/Video/Video.vue +22 -22
  496. package/src/components/VideoModal/VideoModal.vue +22 -22
  497. package/assets/bootstrap/dist/css/bootstrap-grid.css +0 -4124
  498. package/assets/bootstrap/dist/css/bootstrap-grid.css.map +0 -1
  499. package/assets/bootstrap/dist/css/bootstrap-grid.min.css +0 -7
  500. package/assets/bootstrap/dist/css/bootstrap-grid.min.css.map +0 -1
  501. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.css +0 -4123
  502. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.css.map +0 -1
  503. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.min.css +0 -7
  504. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.min.css.map +0 -1
  505. package/assets/bootstrap/dist/css/bootstrap-reboot.css +0 -488
  506. package/assets/bootstrap/dist/css/bootstrap-reboot.css.map +0 -1
  507. package/assets/bootstrap/dist/css/bootstrap-reboot.min.css +0 -7
  508. package/assets/bootstrap/dist/css/bootstrap-reboot.min.css.map +0 -1
  509. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.css +0 -485
  510. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.css.map +0 -1
  511. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.min.css +0 -7
  512. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.min.css.map +0 -1
  513. package/assets/bootstrap/dist/css/bootstrap-utilities.css +0 -4197
  514. package/assets/bootstrap/dist/css/bootstrap-utilities.css.map +0 -1
  515. package/assets/bootstrap/dist/css/bootstrap-utilities.min.css +0 -7
  516. package/assets/bootstrap/dist/css/bootstrap-utilities.min.css.map +0 -1
  517. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.css +0 -4188
  518. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.css.map +0 -1
  519. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.min.css +0 -7
  520. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.min.css.map +0 -1
  521. package/assets/bootstrap/dist/css/bootstrap.css +0 -10907
  522. package/assets/bootstrap/dist/css/bootstrap.css.map +0 -1
  523. package/assets/bootstrap/dist/css/bootstrap.min.css +0 -7
  524. package/assets/bootstrap/dist/css/bootstrap.min.css.map +0 -1
  525. package/assets/bootstrap/dist/css/bootstrap.rtl.css +0 -10867
  526. package/assets/bootstrap/dist/css/bootstrap.rtl.css.map +0 -1
  527. package/assets/bootstrap/dist/css/bootstrap.rtl.min.css +0 -7
  528. package/assets/bootstrap/dist/css/bootstrap.rtl.min.css.map +0 -1
  529. package/assets/bootstrap/dist/js/bootstrap.bundle.js +0 -7066
  530. package/assets/bootstrap/dist/js/bootstrap.bundle.js.map +0 -1
  531. package/assets/bootstrap/dist/js/bootstrap.bundle.min.js +0 -7
  532. package/assets/bootstrap/dist/js/bootstrap.bundle.min.js.map +0 -1
  533. package/assets/bootstrap/dist/js/bootstrap.esm.js +0 -5204
  534. package/assets/bootstrap/dist/js/bootstrap.esm.js.map +0 -1
  535. package/assets/bootstrap/dist/js/bootstrap.esm.min.js +0 -7
  536. package/assets/bootstrap/dist/js/bootstrap.esm.min.js.map +0 -1
  537. package/assets/bootstrap/dist/js/bootstrap.js +0 -5251
  538. package/assets/bootstrap/dist/js/bootstrap.js.map +0 -1
  539. package/assets/bootstrap/dist/js/bootstrap.min.js +0 -7
  540. package/assets/bootstrap/dist/js/bootstrap.min.js.map +0 -1
  541. package/assets/bootstrap/js/dist/alert.js +0 -100
  542. package/assets/bootstrap/js/dist/alert.js.map +0 -1
  543. package/assets/bootstrap/js/dist/base-component.js +0 -100
  544. package/assets/bootstrap/js/dist/base-component.js.map +0 -1
  545. package/assets/bootstrap/js/dist/button.js +0 -82
  546. package/assets/bootstrap/js/dist/button.js.map +0 -1
  547. package/assets/bootstrap/js/dist/carousel.js +0 -471
  548. package/assets/bootstrap/js/dist/carousel.js.map +0 -1
  549. package/assets/bootstrap/js/dist/collapse.js +0 -311
  550. package/assets/bootstrap/js/dist/collapse.js.map +0 -1
  551. package/assets/bootstrap/js/dist/dom/data.js +0 -67
  552. package/assets/bootstrap/js/dist/dom/data.js.map +0 -1
  553. package/assets/bootstrap/js/dist/dom/event-handler.js +0 -284
  554. package/assets/bootstrap/js/dist/dom/event-handler.js.map +0 -1
  555. package/assets/bootstrap/js/dist/dom/manipulator.js +0 -85
  556. package/assets/bootstrap/js/dist/dom/manipulator.js.map +0 -1
  557. package/assets/bootstrap/js/dist/dom/selector-engine.js +0 -86
  558. package/assets/bootstrap/js/dist/dom/selector-engine.js.map +0 -1
  559. package/assets/bootstrap/js/dist/dropdown.js +0 -471
  560. package/assets/bootstrap/js/dist/dropdown.js.map +0 -1
  561. package/assets/bootstrap/js/dist/modal.js +0 -397
  562. package/assets/bootstrap/js/dist/modal.js.map +0 -1
  563. package/assets/bootstrap/js/dist/offcanvas.js +0 -298
  564. package/assets/bootstrap/js/dist/offcanvas.js.map +0 -1
  565. package/assets/bootstrap/js/dist/popover.js +0 -102
  566. package/assets/bootstrap/js/dist/popover.js.map +0 -1
  567. package/assets/bootstrap/js/dist/scrollspy.js +0 -308
  568. package/assets/bootstrap/js/dist/scrollspy.js.map +0 -1
  569. package/assets/bootstrap/js/dist/tab.js +0 -334
  570. package/assets/bootstrap/js/dist/tab.js.map +0 -1
  571. package/assets/bootstrap/js/dist/toast.js +0 -237
  572. package/assets/bootstrap/js/dist/toast.js.map +0 -1
  573. package/assets/bootstrap/js/dist/tooltip.js +0 -663
  574. package/assets/bootstrap/js/dist/tooltip.js.map +0 -1
  575. package/assets/bootstrap/js/dist/util/backdrop.js +0 -166
  576. package/assets/bootstrap/js/dist/util/backdrop.js.map +0 -1
  577. package/assets/bootstrap/js/dist/util/component-functions.js +0 -47
  578. package/assets/bootstrap/js/dist/util/component-functions.js.map +0 -1
  579. package/assets/bootstrap/js/dist/util/config.js +0 -80
  580. package/assets/bootstrap/js/dist/util/config.js.map +0 -1
  581. package/assets/bootstrap/js/dist/util/focustrap.js +0 -130
  582. package/assets/bootstrap/js/dist/util/focustrap.js.map +0 -1
  583. package/assets/bootstrap/js/dist/util/index.js +0 -351
  584. package/assets/bootstrap/js/dist/util/index.js.map +0 -1
  585. package/assets/bootstrap/js/dist/util/sanitizer.js +0 -123
  586. package/assets/bootstrap/js/dist/util/sanitizer.js.map +0 -1
  587. package/assets/bootstrap/js/dist/util/scrollbar.js +0 -139
  588. package/assets/bootstrap/js/dist/util/scrollbar.js.map +0 -1
  589. package/assets/bootstrap/js/dist/util/swipe.js +0 -156
  590. package/assets/bootstrap/js/dist/util/swipe.js.map +0 -1
  591. package/assets/bootstrap/js/dist/util/template-factory.js +0 -178
  592. package/assets/bootstrap/js/dist/util/template-factory.js.map +0 -1
  593. package/assets/css/components/header.css.map +0 -1
@@ -1,699 +1,699 @@
1
- import Cookies from '../../../../node_modules/js-cookie/dist/js.cookie.mjs';
2
- import { trackComponent, trackComponentRegistered } from '../_global';
3
-
4
- trackComponentRegistered('iam-config');
5
-
6
- class iamConfig extends HTMLElement {
7
- constructor() {
8
- super();
9
- this.attachShadow({ mode: 'open' });
10
-
11
- const assetLocation = document.body.hasAttribute('data-assets-location')
12
- ? document.body.getAttribute('data-assets-location')
13
- : '/assets';
14
-
15
- const loadCSS = `@import "${assetLocation}/css/components/config.component.css";`;
16
-
17
- const template = document.createElement('template');
18
-
19
- template.innerHTML = /* HTML */ `
20
- <style>
21
- ${loadCSS}
22
- </style>
23
- <div id="wrapper">
24
- <div id="items">
25
- <div id="buckets"></div>
26
- <div id="any" data-bucket="any"></div>
27
- </div>
28
- <div class="admin-panel">
29
- <button class="btn btn-action fa-plus" command="add-bucket">Add bucket</button>
30
- <button class="btn btn-action fa-plus" command="add-item">Add ${this.getAttribute('data-item-name')??'item'}</button> <!-- Changes to open a model if we want to validate the add form first -->
31
-
32
- </div>
33
- <button id="save" class="btn btn-sm btn-primary fa-floppy-disk" >Save items</button>
34
- </div>
35
- `;
36
- this.shadowRoot?.appendChild(template.content.cloneNode(true));
37
- }
38
-
39
- async importData(ajaxURL): void {
40
-
41
- // Setup controller vars if not already set
42
- if (!window.controller) window.controller = [];
43
-
44
- // Abort if controller already present for this url
45
- if (window.controller[ajaxURL]) window.controller[ajaxURL].abort();
46
-
47
- // Create a new controller so it can be aborted if new fetch made
48
- window.controller[ajaxURL] = new AbortController();
49
- const { signal } = window.controller[ajaxURL];
50
-
51
- try {
52
- return await fetch(ajaxURL, {
53
- signal: signal,
54
- method: 'get',
55
- credentials: 'same-origin',
56
- headers: new Headers({
57
- 'Content-Type': 'application/json',
58
- Accept: 'application/json',
59
- 'X-Requested-With': 'XMLHttpRequest',
60
- 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN'),
61
- }),
62
- })
63
- .then((response) => response.json())
64
- .then((response) => {
65
-
66
- const returnData = response['data'] ? response['data'] : response;
67
-
68
- return returnData;
69
- });
70
- } catch (error) {
71
- //console.log(error);
72
- return 'There has been a problem. Please try again in a few moments.';
73
- }
74
-
75
- }
76
-
77
- getBucketsData = (data): void => {
78
-
79
- if(!data)
80
- return [];
81
-
82
- const buckets = [];
83
- // TODO: check local storage first
84
- data.forEach(bucket => {
85
-
86
- if(typeof bucket.attributes?.criteria == "object" && Array.isArray(bucket.attributes?.criteria)){
87
-
88
- buckets.push(bucket);
89
- }
90
- });
91
-
92
- return buckets;
93
- }
94
-
95
- createBuckets = (buckets): void => {
96
-
97
- console.log(buckets);
98
-
99
- const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
100
-
101
- if(!buckets)
102
- return false;
103
-
104
- buckets.forEach((bucket) => {
105
-
106
- this.createBucket(bucket);
107
-
108
- });
109
-
110
- return true;
111
- }
112
-
113
- createBucket = (bucket): void => {
114
-
115
-
116
- const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
117
-
118
- const bucketElement = document.createElement('div');
119
- bucketElement.innerHTML = this.addBucketHTML(bucket);
120
- //bucketElement.setAttribute('data-bucket',bucket.id);
121
- bucketElement.classList.add('bucket__wrapper');
122
-
123
- bucketsContainer?.insertAdjacentElement('beforeend', bucketElement);
124
-
125
- //this.addButtonEvents(bucketElement,true);
126
- this.createEditBucketsEvents(bucketElement);
127
-
128
-
129
- const criteriaContainer = bucketElement.querySelector('.criteria--container');
130
-
131
- if(bucket.attributes){
132
- bucket.attributes.criteria.forEach((criteria) => {
133
- const criteriaForm = document.createElement('form');
134
- criteriaForm.classList.add('criteria');
135
-
136
- criteriaForm.innerHTML = this.addCriteriaHTML(criteria.attributes);
137
-
138
- // TODO add to HTML
139
- criteriaForm.querySelector('[name="attribute"]')?.value = criteria.attributes.attribute;
140
- criteriaForm.querySelector('[name="rule"]')?.value = criteria.attributes.rule;
141
- criteriaForm.querySelector('[name="match"]')?.value = criteria.attributes.match;
142
-
143
- criteriaContainer?.appendChild(criteriaForm);
144
-
145
- // TODO add buttons
146
- // TODO add events
147
- });
148
- this.createForms(bucket.attributes.items, bucket.id);
149
- }
150
-
151
-
152
- return bucketElement;
153
- }
154
-
155
- addCriteriaHTML = (attributes): void => {
156
- return /*HTML*/ `<label>
157
- <span class="visually-hidden">Attribute</span>
158
- ${this.createCriteriaDropdown(attributes.attribute)}
159
- </label>
160
- <label>
161
- <span class="visually-hidden">Rule</span>
162
- <select name="rule" class="mt-0 select--sm">
163
- <option value="set">is not empty</option>
164
- <option value="empty">is empty</option>
165
- <option value="equals">equals</option>
166
- <option value="not">is not</option>
167
- <option value="greater">greater than</option>
168
- <option value="less">less than</option>
169
- </select>
170
- </label>
171
- <label>
172
- <span class="visually-hidden">Match</span>
173
- <input type="text" name="match" class="mt-0 input--sm" /> <!-- TODO Add datalist or transform into select -->
174
- </label>
175
- <div class="btn__group">
176
- <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-plus" type="button" data-direction="add" title="Delete">Add</button>
177
- <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-trash" type="button" data-direction="delete" title="Delete">Delete</button>
178
- </div>`;
179
- }
180
-
181
- addBucketHTML = (bucket):void => {
182
-
183
- return /*HTML*/ `<label>
184
- <span class="visually-hidden">Name</span>
185
- <input type="text" name="bucket" value="${bucket.attributes?.name ?? ''}"/>
186
- </label>
187
- <div class="btn__group text-end"><button class="btn btn-compact btn-sm mt-0 btn-secondary fa-pen-to-square" data-expand title="Expand to see more options">Edit</button>${this.buttonHTML}</div>
188
- <div class="criteria--container">
189
- </div>
190
- <div data-bucket="${bucket.id ?? ''}" class="bucket">
191
- </div>`;
192
- }
193
-
194
- createCriteriaDropdown = (attribute):void => {
195
-
196
- const form = this.querySelector('form');
197
-
198
- const formData = new FormData(form);
199
- const formDataObj = Object.fromEntries(formData.entries());
200
-
201
- let optionsHtml = '';
202
- Object.keys(formDataObj).forEach(function(key){
203
- optionsHtml += `<option value="${key}" ${key == attribute ? ' selected="selected"' : ''}>${key}</option>`;
204
- });
205
-
206
- return `<select name="attributes[criteria]" class="mt-0 select--sm">
207
- <option value=""></option>
208
- ${optionsHtml}
209
- </select>`;
210
- }
211
-
212
- createEditBucketsEvents = (bucket):Void => {
213
- this.addButtonEvents(bucket,true);
214
- const expandButton = bucket?.querySelector('[data-expand]');
215
-
216
- expandButton?.addEventListener('click',() => {
217
-
218
- bucket.classList.toggle('bucket--expanded');
219
- });
220
- }
221
-
222
- async importAttributeData(comonponent): void {
223
-
224
- }
225
-
226
- createForms = (data, bucketId = "any"):void => {
227
-
228
- data.forEach(item => {
229
-
230
- if(typeof item.attributes?.criteria == "undefined"){
231
-
232
- const formElement = this.createForm(item, bucketId);
233
-
234
- Object.keys(item.attributes).forEach(function(key){
235
-
236
- if(formElement.querySelector(`[name="${key}"]`)){
237
-
238
- const element = formElement.querySelector(`[name="${key}"]`);
239
-
240
- if(element.matches('select[data-import]') && !element.querySelector(`option[value="${item.attributes[key]}"]`)){
241
- const optionElement = document.createElement('option');
242
- optionElement.value = item.attributes[key];
243
- optionElement.innerHTML = item.attributes[key];
244
- element.appendChild(optionElement);
245
- }
246
- element.value = item.attributes[key];
247
- }
248
- });
249
- }
250
- });
251
- }
252
-
253
- checkCriteria = (attributes, bucket):void => {
254
-
255
- if(attributes[bucket])
256
- return true;
257
-
258
- return false;
259
- }
260
-
261
- checkBuckets = (attributes):any => {
262
-
263
- const anyContainer = this.shadowRoot.querySelector('#any'); // TODO: rename
264
- let container = anyContainer;
265
-
266
- if(!this.hasAttribute('data-buckets'))
267
- return container;
268
-
269
-
270
- let buckets = [];
271
- let addedToBucket = false;
272
-
273
- // If data attribute set
274
- buckets = this.getAttribute('data-buckets').split(',');
275
-
276
- // TODO: If importing the config from a json file
277
-
278
- buckets.forEach((bucket)=>{
279
-
280
- const addToBucket = !addedToBucket ? this.checkCriteria(attributes, bucket) : false;
281
-
282
- if(addToBucket){
283
- addedToBucket = true;
284
- container = this.shadowRoot.querySelector(`[data-bucket="${bucket}"]`);
285
- }
286
- });
287
-
288
- return container;
289
- }
290
-
291
- createForm = (item, bucketId = "any"):void => {
292
-
293
- const anyContainer = this.shadowRoot.querySelector(`#items [data-bucket="${bucketId}"]`); // TODO: rename
294
- //const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
295
- //const container = this.checkBuckets(item.attributes); TODO: re-enable
296
- const container = anyContainer;
297
-
298
- const formElement = this.querySelector(`form`)?.cloneNode(true);
299
- //formTemplate.setAttribute('id', item.id);
300
-
301
- // TODO check if it matches a bucket
302
- container?.insertAdjacentElement('beforeend',formElement);
303
- //const formElement = container?.querySelector(`[id="${item.id}"]`);
304
- formElement?.addEventListener('submit', (event) => {
305
-
306
- event.preventDefault();
307
- });
308
-
309
- this.addButtons(formElement);
310
-
311
-
312
- return formElement;
313
- }
314
-
315
- getCurrentIds = ():void => {
316
-
317
- const idsArr = [];
318
-
319
- Array.from(this.shadowRoot?.querySelectorAll('#items form')).forEach((form) => {
320
- idsArr.push(parseInt(form.getAttribute('id')));
321
- });
322
-
323
- return idsArr;
324
- }
325
-
326
- generateId = ():any => {
327
-
328
- return Math.max(...this.getCurrentIds()) + 1;
329
- }
330
-
331
- addButtonEvents = (element, scrollIntoView:boolean = true):void => {
332
-
333
- const upButton = element?.querySelector('[data-direction="up"]');
334
- const downButton = element?.querySelector('[data-direction="down"]');
335
- const deleteButton = element?.querySelector('[data-direction="delete"]');
336
-
337
- upButton?.addEventListener('click',() => {
338
-
339
- if(element?.previousElementSibling){
340
- element?.parentNode.insertBefore(element, element.previousElementSibling);
341
-
342
- if(scrollIntoView)
343
- element?.scrollIntoView({ behavior: "instant", block: "center" });
344
- }
345
- });
346
-
347
- downButton?.addEventListener('click',() => {
348
-
349
- if(element.nextElementSibling){
350
- element?.parentNode.insertBefore(element, element.nextElementSibling.nextElementSibling);
351
- }
352
- else {
353
- element?.parentNode.insertAdjacentElement('beforeend',element);
354
- }
355
-
356
- if(scrollIntoView)
357
- element?.scrollIntoView({ behavior: "instant", block: "center" });
358
- });
359
-
360
- deleteButton?.addEventListener('click',() => {
361
-
362
- element.remove();
363
- });
364
- }
365
-
366
- addButtons = (form):void => {
367
-
368
- form?.insertAdjacentHTML('beforeend',`<div class="btn__group">${this.buttonHTML}</div>`);
369
-
370
- this.addButtonEvents(form);
371
- }
372
-
373
- async connectedCallback(): void {
374
- this.buttonHTML = /* HTML */`
375
- <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-trash" type="button" data-direction="delete" title="Delete">Delete</button>
376
- <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-chevron-down" type="button" data-direction="down" title="Move down">Down</button>
377
- <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-chevron-up" type="button" data-direction="up" title="Move up">Up</button>
378
- `;
379
-
380
- const dataImportUrl = this.getAttribute('data-import');
381
- const getBucketsData = this.getBucketsData;
382
- const createBuckets = this.createBuckets;
383
-
384
-
385
- const createForms = this.createForms;
386
- const createForm = this.createForm;
387
- const itemsContainer = this.shadowRoot.querySelector('#items'); // TODO: rename
388
- const anyContainer = this.shadowRoot.querySelector('#any'); // TODO: rename
389
- const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
390
-
391
- const editBuckets = this.shadowRoot.querySelector('#editBuckets'); // TODO: rename
392
-
393
- const saveButton = this.shadowRoot.querySelector('#save');
394
- const addButton = this.shadowRoot?.querySelector('[data-add-item]')
395
- const addForm = this.shadowRoot?.querySelector('#addForm');
396
-
397
- const editBucketsDialog = this.shadowRoot?.querySelector('#editBucketsDialog');
398
- const editBucketsForm = this.shadowRoot?.querySelector('#editBucketsForm');
399
- const editBucketsFormSubmit = this.shadowRoot?.querySelector('#editBucketsForm .btn-primary');
400
- const addBucketButton = this?.shadowRoot.querySelector('[command="add-bucket"]');
401
- const addItemButton = this?.shadowRoot.querySelector('[command="add-item"]');
402
-
403
-
404
- const templateForm = this?.querySelector('form');
405
-
406
- let editBucketsOriginalState = '';
407
-
408
- let buckets = [];
409
-
410
- // Prevent the template form from submitting anything
411
- templateForm?.addEventListener('submit', (event) => {
412
-
413
- event.preventDefault();
414
- });
415
-
416
-
417
- // TODO: add this to an on change event on the select
418
- Array.from(this.querySelectorAll('select[data-import]')).forEach(async(select) =>{
419
-
420
-
421
- const ajaxURL = select.getAttribute('data-import');
422
-
423
- this.importData(ajaxURL).then(
424
- (data) => {
425
- if(typeof data == 'string')
426
- return data;
427
-
428
- data.forEach(item =>{
429
-
430
- const optionElement = document.createElement('option');
431
- optionElement.value = item.id;
432
- optionElement.innerHTML = item.attributes.name;
433
- select.appendChild(optionElement);
434
- });
435
-
436
- return true;
437
- }
438
- );
439
- });
440
-
441
-
442
-
443
-
444
- // #region import data
445
- // TODO load from web storage if its newer
446
-
447
- const storedData = localStorage.getItem(`config-${this.getAttribute('data-name')}`);
448
- //const buckets = this.getBucketsData(); // TODO: load from local storage
449
-
450
- if(storedData){
451
-
452
- //createForms(JSON.parse(storedData), buckets);
453
- }
454
- else if(dataImportUrl){
455
-
456
- const dataImport = await this.importData(dataImportUrl).then(
457
- (data) => {
458
- if(typeof data == 'string')
459
- return data;
460
-
461
- const buckets = getBucketsData(data);
462
-
463
- if(buckets){
464
-
465
- createBuckets(buckets);
466
- }
467
- createForms(data); // any bucket
468
-
469
- return true;
470
- }
471
- );
472
- }
473
- // #endregion
474
-
475
- // #region Add buckets to edit modal
476
- /*
477
- editBucketsForm?.addEventListener('submit', (event) => {
478
-
479
- event.stopPropagation();
480
- event.preventDefault();
481
-
482
- if(event.submitter == editBucketsFormSubmit){
483
-
484
- // Clear what is there already
485
- //anyContainer?.innerHTML = '';
486
-
487
- Array.from(itemsContainer?.querySelectorAll('form')).forEach((formElement:HTMLElement, index):void => {
488
-
489
- anyContainer?.insertAdjacentElement('beforeend',formElement);
490
- });
491
-
492
- // Empty the buckets
493
- bucketsContainer?.innerHTML = '';
494
-
495
- // Load the new bucket data then recreate them
496
- const buckets = [];
497
- Array.from(editBuckets?.querySelectorAll('[data-bucket]')).forEach((editBucketElement:HTMLElement, index):void => {
498
-
499
- bucketsContainer?.insertAdjacentHTML('beforeend',`<div class="bucket" data-bucket="${editBucketElement.getAttribute('data-bucket')}"></div>`);
500
-
501
- const bucket = {}
502
-
503
- bucket.id = editBucketElement.getAttribute('data-bucket');
504
- bucket.attributes = {};
505
-
506
- bucket.attributes.name = editBucketElement.querySelector('[name="bucket"]')?.value;
507
-
508
- //const formData = new FormData(editBucketElement);
509
- //const formDataObj = Object.fromEntries(formData.entries());
510
- // TODO cycle through the criteria forms
511
-
512
- buckets.push(bucket);
513
- });
514
-
515
-
516
- console.log(buckets);
517
- // this.createBuckets(buckets); TODO: re-enable
518
-
519
- /*
520
- // Move items back into buckets
521
- Array.from(itemsContainer?.querySelectorAll('form')).forEach((formElement:HTMLElement, index):void => {
522
-
523
- const formData = new FormData(formElement);
524
- const formDataObj = Object.fromEntries(formData.entries());
525
- const newContainer = this.checkBuckets(formDataObj);
526
-
527
- if(newContainer != anyContainer){
528
- newContainer?.insertAdjacentElement('beforeend',formElement);
529
- }
530
- });
531
-
532
-
533
- editBucketsOriginalState = editBuckets.innerHTML;
534
- }
535
-
536
- editBucketsDialog?.close();
537
- });
538
- */
539
- /*
540
-
541
- addBucketButton?.addEventListener('click', (event) => {
542
-
543
- const editBucket = document.createElement('div');
544
- editBucket.classList.add('bucket--edit');
545
- editBucket.innerHTML = this.addBucketHTML();
546
-
547
- editBuckets?.insertAdjacentElement('beforeend', editBucket)
548
-
549
- this.addButtonEvents(editBucket,false);
550
- const expandButton = editBucket?.querySelector('[data-expand]');
551
-
552
- expandButton?.addEventListener('click',() => {
553
-
554
- editBucket.classList.toggle('bucket--expanded');
555
- });
556
- });
557
-
558
- */
559
-
560
-
561
-
562
- // #endregion
563
-
564
- // #region add data
565
-
566
- addItemButton?.addEventListener("click", (event) => {
567
-
568
- const form = this.createForm({});
569
- form?.scrollIntoView({ behavior: "instant", block: "center" });
570
- // TODO scroll into view
571
- });
572
-
573
- addBucketButton?.addEventListener("click", (event) => {
574
-
575
- const bucket = this.createBucket({});
576
- bucket?.scrollIntoView({ behavior: "instant", block: "center" });
577
- });
578
-
579
- // #endregion
580
-
581
-
582
- // #region update values
583
-
584
- this.shadowRoot.addEventListener('change', (event) => {
585
-
586
- const container = event.target.closest('[data-bucket]');
587
-
588
- if(!container)
589
- return false;
590
-
591
- const attribute = event.target.name;
592
- const value = event.target.value;
593
- const attributes = {};
594
- attributes[attribute] = value;
595
- const newContainer = this.checkBuckets(attributes);
596
-
597
- if(newContainer != container){
598
- const form = event.target.closest(`form`);
599
- // TODO a confirmation modal
600
- newContainer?.insertAdjacentElement('beforeend',form);
601
-
602
-
603
- form?.scrollIntoView({ behavior: "instant", block: "center" });
604
- }
605
-
606
- });
607
- // #endregion
608
-
609
- // #region save data
610
- saveButton?.addEventListener('click', (event) => {
611
-
612
- event.preventDefault();
613
-
614
- // TODO validation
615
-
616
- const entries = [];
617
-
618
- // Save buckets data
619
- Array.from(itemsContainer?.querySelectorAll('.bucket__wrapper')).forEach((bucketElement:HTMLElement, index):void => {
620
-
621
- const bucket = {};
622
- bucket.attributes = {};
623
- bucket.id = bucketElement?.querySelector('[name="bucket"]').value;
624
- bucket.type = 'bucket';
625
- bucket.attributes.index = index;
626
-
627
-
628
- const criteria = [];
629
- // TODO populate criteria
630
- Array.from(bucketElement?.querySelectorAll('.criteria--container form')).forEach((formElement:HTMLElement, criteriaIndex):void => {
631
-
632
- const item = {};
633
- //item.id = formElement.getAttribute('id');
634
- item.type = 'criteria';
635
- item.index = criteriaIndex;
636
- const formData = new FormData(formElement);
637
- const formDataObj = Object.fromEntries(formData.entries());
638
-
639
- item.attributes = formDataObj;
640
-
641
- criteria.push(item);
642
- });
643
- bucket.attributes.criteria = criteria;
644
-
645
- const items = [];
646
- Array.from(bucketElement?.querySelectorAll('[data-bucket] form')).forEach((formElement:HTMLElement, itemIndex):void => {
647
-
648
- const item = {};
649
- //item.id = formElement.getAttribute('id');
650
- item.type = 'item';
651
- item.index = itemIndex;
652
- const formData = new FormData(formElement);
653
- const formDataObj = Object.fromEntries(formData.entries());
654
-
655
- item.attributes = formDataObj;
656
-
657
- items.push(item);
658
- });
659
- bucket.attributes.items = items;
660
-
661
- entries.push(bucket);
662
- });
663
-
664
-
665
- Array.from(itemsContainer?.querySelectorAll('[data-bucket="any"] form')).forEach((formElement:HTMLElement, index):void => {
666
-
667
- const entry = {};
668
- //entry.id = formElement.getAttribute('id');
669
- entry.type = 'item';
670
- entry.index = index;
671
- const formData = new FormData(formElement);
672
- const formDataObj = Object.fromEntries(formData.entries());
673
-
674
- entry.attributes = formDataObj;
675
-
676
- entries.push(entry);
677
- });
678
-
679
- const entriesJson = JSON.stringify(entries);
680
-
681
- console.log(entries);
682
-
683
- // TODO add toast message
684
- // TODO save locally for now but when pushing to endpoint the web storage file should get deleted
685
-
686
- //localStorage.setItem(`config-${this.getAttribute('data-name')}`, entriesJson);
687
-
688
-
689
-
690
- //const bucketsJson = JSON.stringify(buckets);
691
-
692
- //localStorage.setItem(`config-buckets-${this.getAttribute('data-name')}`, bucketsJson);
693
-
694
- });
695
- // #endregion
696
- }
697
- }
698
-
699
- export default iamConfig;
1
+ import Cookies from '../../../../node_modules/js-cookie/dist/js.cookie.mjs';
2
+ import { trackComponent, trackComponentRegistered } from '../_global';
3
+
4
+ trackComponentRegistered('iam-config');
5
+
6
+ class iamConfig extends HTMLElement {
7
+ constructor() {
8
+ super();
9
+ this.attachShadow({ mode: 'open' });
10
+
11
+ const assetLocation = document.body.hasAttribute('data-assets-location')
12
+ ? document.body.getAttribute('data-assets-location')
13
+ : '/assets';
14
+
15
+ const loadCSS = `@import "${assetLocation}/css/components/config.component.css";`;
16
+
17
+ const template = document.createElement('template');
18
+
19
+ template.innerHTML = /* HTML */ `
20
+ <style>
21
+ ${loadCSS}
22
+ </style>
23
+ <div id="wrapper">
24
+ <div id="items">
25
+ <div id="buckets"></div>
26
+ <div id="any" data-bucket="any"></div>
27
+ </div>
28
+ <div class="admin-panel">
29
+ <button class="btn btn-action fa-plus" command="add-bucket">Add bucket</button>
30
+ <button class="btn btn-action fa-plus" command="add-item">Add ${this.getAttribute('data-item-name')??'item'}</button> <!-- Changes to open a model if we want to validate the add form first -->
31
+
32
+ </div>
33
+ <button id="save" class="btn btn-sm btn-primary fa-floppy-disk" >Save items</button>
34
+ </div>
35
+ `;
36
+ this.shadowRoot?.appendChild(template.content.cloneNode(true));
37
+ }
38
+
39
+ async importData(ajaxURL): void {
40
+
41
+ // Setup controller vars if not already set
42
+ if (!window.controller) window.controller = [];
43
+
44
+ // Abort if controller already present for this url
45
+ if (window.controller[ajaxURL]) window.controller[ajaxURL].abort();
46
+
47
+ // Create a new controller so it can be aborted if new fetch made
48
+ window.controller[ajaxURL] = new AbortController();
49
+ const { signal } = window.controller[ajaxURL];
50
+
51
+ try {
52
+ return await fetch(ajaxURL, {
53
+ signal: signal,
54
+ method: 'get',
55
+ credentials: 'same-origin',
56
+ headers: new Headers({
57
+ 'Content-Type': 'application/json',
58
+ Accept: 'application/json',
59
+ 'X-Requested-With': 'XMLHttpRequest',
60
+ 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN'),
61
+ }),
62
+ })
63
+ .then((response) => response.json())
64
+ .then((response) => {
65
+
66
+ const returnData = response['data'] ? response['data'] : response;
67
+
68
+ return returnData;
69
+ });
70
+ } catch (error) {
71
+ //console.log(error);
72
+ return 'There has been a problem. Please try again in a few moments.';
73
+ }
74
+
75
+ }
76
+
77
+ getBucketsData = (data): void => {
78
+
79
+ if(!data)
80
+ return [];
81
+
82
+ const buckets = [];
83
+ // TODO: check local storage first
84
+ data.forEach(bucket => {
85
+
86
+ if(typeof bucket.attributes?.criteria == "object" && Array.isArray(bucket.attributes?.criteria)){
87
+
88
+ buckets.push(bucket);
89
+ }
90
+ });
91
+
92
+ return buckets;
93
+ }
94
+
95
+ createBuckets = (buckets): void => {
96
+
97
+ console.log(buckets);
98
+
99
+ const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
100
+
101
+ if(!buckets)
102
+ return false;
103
+
104
+ buckets.forEach((bucket) => {
105
+
106
+ this.createBucket(bucket);
107
+
108
+ });
109
+
110
+ return true;
111
+ }
112
+
113
+ createBucket = (bucket): void => {
114
+
115
+
116
+ const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
117
+
118
+ const bucketElement = document.createElement('div');
119
+ bucketElement.innerHTML = this.addBucketHTML(bucket);
120
+ //bucketElement.setAttribute('data-bucket',bucket.id);
121
+ bucketElement.classList.add('bucket__wrapper');
122
+
123
+ bucketsContainer?.insertAdjacentElement('beforeend', bucketElement);
124
+
125
+ //this.addButtonEvents(bucketElement,true);
126
+ this.createEditBucketsEvents(bucketElement);
127
+
128
+
129
+ const criteriaContainer = bucketElement.querySelector('.criteria--container');
130
+
131
+ if(bucket.attributes){
132
+ bucket.attributes.criteria.forEach((criteria) => {
133
+ const criteriaForm = document.createElement('form');
134
+ criteriaForm.classList.add('criteria');
135
+
136
+ criteriaForm.innerHTML = this.addCriteriaHTML(criteria.attributes);
137
+
138
+ // TODO add to HTML
139
+ criteriaForm.querySelector('[name="attribute"]')?.value = criteria.attributes.attribute;
140
+ criteriaForm.querySelector('[name="rule"]')?.value = criteria.attributes.rule;
141
+ criteriaForm.querySelector('[name="match"]')?.value = criteria.attributes.match;
142
+
143
+ criteriaContainer?.appendChild(criteriaForm);
144
+
145
+ // TODO add buttons
146
+ // TODO add events
147
+ });
148
+ this.createForms(bucket.attributes.items, bucket.id);
149
+ }
150
+
151
+
152
+ return bucketElement;
153
+ }
154
+
155
+ addCriteriaHTML = (attributes): void => {
156
+ return /*HTML*/ `<label>
157
+ <span class="visually-hidden">Attribute</span>
158
+ ${this.createCriteriaDropdown(attributes.attribute)}
159
+ </label>
160
+ <label>
161
+ <span class="visually-hidden">Rule</span>
162
+ <select name="rule" class="mt-0 select--sm">
163
+ <option value="set">is not empty</option>
164
+ <option value="empty">is empty</option>
165
+ <option value="equals">equals</option>
166
+ <option value="not">is not</option>
167
+ <option value="greater">greater than</option>
168
+ <option value="less">less than</option>
169
+ </select>
170
+ </label>
171
+ <label>
172
+ <span class="visually-hidden">Match</span>
173
+ <input type="text" name="match" class="mt-0 input--sm" /> <!-- TODO Add datalist or transform into select -->
174
+ </label>
175
+ <div class="btn__group">
176
+ <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-plus" type="button" data-direction="add" title="Delete">Add</button>
177
+ <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-trash" type="button" data-direction="delete" title="Delete">Delete</button>
178
+ </div>`;
179
+ }
180
+
181
+ addBucketHTML = (bucket):void => {
182
+
183
+ return /*HTML*/ `<label>
184
+ <span class="visually-hidden">Name</span>
185
+ <input type="text" name="bucket" value="${bucket.attributes?.name ?? ''}"/>
186
+ </label>
187
+ <div class="btn__group text-end"><button class="btn btn-compact btn-sm mt-0 btn-secondary fa-pen-to-square" data-expand title="Expand to see more options">Edit</button>${this.buttonHTML}</div>
188
+ <div class="criteria--container">
189
+ </div>
190
+ <div data-bucket="${bucket.id ?? ''}" class="bucket">
191
+ </div>`;
192
+ }
193
+
194
+ createCriteriaDropdown = (attribute):void => {
195
+
196
+ const form = this.querySelector('form');
197
+
198
+ const formData = new FormData(form);
199
+ const formDataObj = Object.fromEntries(formData.entries());
200
+
201
+ let optionsHtml = '';
202
+ Object.keys(formDataObj).forEach(function(key){
203
+ optionsHtml += `<option value="${key}" ${key == attribute ? ' selected="selected"' : ''}>${key}</option>`;
204
+ });
205
+
206
+ return `<select name="attributes[criteria]" class="mt-0 select--sm">
207
+ <option value=""></option>
208
+ ${optionsHtml}
209
+ </select>`;
210
+ }
211
+
212
+ createEditBucketsEvents = (bucket):Void => {
213
+ this.addButtonEvents(bucket,true);
214
+ const expandButton = bucket?.querySelector('[data-expand]');
215
+
216
+ expandButton?.addEventListener('click',() => {
217
+
218
+ bucket.classList.toggle('bucket--expanded');
219
+ });
220
+ }
221
+
222
+ async importAttributeData(comonponent): void {
223
+
224
+ }
225
+
226
+ createForms = (data, bucketId = "any"):void => {
227
+
228
+ data.forEach(item => {
229
+
230
+ if(typeof item.attributes?.criteria == "undefined"){
231
+
232
+ const formElement = this.createForm(item, bucketId);
233
+
234
+ Object.keys(item.attributes).forEach(function(key){
235
+
236
+ if(formElement.querySelector(`[name="${key}"]`)){
237
+
238
+ const element = formElement.querySelector(`[name="${key}"]`);
239
+
240
+ if(element.matches('select[data-import]') && !element.querySelector(`option[value="${item.attributes[key]}"]`)){
241
+ const optionElement = document.createElement('option');
242
+ optionElement.value = item.attributes[key];
243
+ optionElement.innerHTML = item.attributes[key];
244
+ element.appendChild(optionElement);
245
+ }
246
+ element.value = item.attributes[key];
247
+ }
248
+ });
249
+ }
250
+ });
251
+ }
252
+
253
+ checkCriteria = (attributes, bucket):void => {
254
+
255
+ if(attributes[bucket])
256
+ return true;
257
+
258
+ return false;
259
+ }
260
+
261
+ checkBuckets = (attributes):any => {
262
+
263
+ const anyContainer = this.shadowRoot.querySelector('#any'); // TODO: rename
264
+ let container = anyContainer;
265
+
266
+ if(!this.hasAttribute('data-buckets'))
267
+ return container;
268
+
269
+
270
+ let buckets = [];
271
+ let addedToBucket = false;
272
+
273
+ // If data attribute set
274
+ buckets = this.getAttribute('data-buckets').split(',');
275
+
276
+ // TODO: If importing the config from a json file
277
+
278
+ buckets.forEach((bucket)=>{
279
+
280
+ const addToBucket = !addedToBucket ? this.checkCriteria(attributes, bucket) : false;
281
+
282
+ if(addToBucket){
283
+ addedToBucket = true;
284
+ container = this.shadowRoot.querySelector(`[data-bucket="${bucket}"]`);
285
+ }
286
+ });
287
+
288
+ return container;
289
+ }
290
+
291
+ createForm = (item, bucketId = "any"):void => {
292
+
293
+ const anyContainer = this.shadowRoot.querySelector(`#items [data-bucket="${bucketId}"]`); // TODO: rename
294
+ //const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
295
+ //const container = this.checkBuckets(item.attributes); TODO: re-enable
296
+ const container = anyContainer;
297
+
298
+ const formElement = this.querySelector(`form`)?.cloneNode(true);
299
+ //formTemplate.setAttribute('id', item.id);
300
+
301
+ // TODO check if it matches a bucket
302
+ container?.insertAdjacentElement('beforeend',formElement);
303
+ //const formElement = container?.querySelector(`[id="${item.id}"]`);
304
+ formElement?.addEventListener('submit', (event) => {
305
+
306
+ event.preventDefault();
307
+ });
308
+
309
+ this.addButtons(formElement);
310
+
311
+
312
+ return formElement;
313
+ }
314
+
315
+ getCurrentIds = ():void => {
316
+
317
+ const idsArr = [];
318
+
319
+ Array.from(this.shadowRoot?.querySelectorAll('#items form')).forEach((form) => {
320
+ idsArr.push(parseInt(form.getAttribute('id')));
321
+ });
322
+
323
+ return idsArr;
324
+ }
325
+
326
+ generateId = ():any => {
327
+
328
+ return Math.max(...this.getCurrentIds()) + 1;
329
+ }
330
+
331
+ addButtonEvents = (element, scrollIntoView:boolean = true):void => {
332
+
333
+ const upButton = element?.querySelector('[data-direction="up"]');
334
+ const downButton = element?.querySelector('[data-direction="down"]');
335
+ const deleteButton = element?.querySelector('[data-direction="delete"]');
336
+
337
+ upButton?.addEventListener('click',() => {
338
+
339
+ if(element?.previousElementSibling){
340
+ element?.parentNode.insertBefore(element, element.previousElementSibling);
341
+
342
+ if(scrollIntoView)
343
+ element?.scrollIntoView({ behavior: "instant", block: "center" });
344
+ }
345
+ });
346
+
347
+ downButton?.addEventListener('click',() => {
348
+
349
+ if(element.nextElementSibling){
350
+ element?.parentNode.insertBefore(element, element.nextElementSibling.nextElementSibling);
351
+ }
352
+ else {
353
+ element?.parentNode.insertAdjacentElement('beforeend',element);
354
+ }
355
+
356
+ if(scrollIntoView)
357
+ element?.scrollIntoView({ behavior: "instant", block: "center" });
358
+ });
359
+
360
+ deleteButton?.addEventListener('click',() => {
361
+
362
+ element.remove();
363
+ });
364
+ }
365
+
366
+ addButtons = (form):void => {
367
+
368
+ form?.insertAdjacentHTML('beforeend',`<div class="btn__group">${this.buttonHTML}</div>`);
369
+
370
+ this.addButtonEvents(form);
371
+ }
372
+
373
+ async connectedCallback(): void {
374
+ this.buttonHTML = /* HTML */`
375
+ <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-trash" type="button" data-direction="delete" title="Delete">Delete</button>
376
+ <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-chevron-down" type="button" data-direction="down" title="Move down">Down</button>
377
+ <button class="btn btn-compact btn-sm mt-0 btn-secondary fa-chevron-up" type="button" data-direction="up" title="Move up">Up</button>
378
+ `;
379
+
380
+ const dataImportUrl = this.getAttribute('data-import');
381
+ const getBucketsData = this.getBucketsData;
382
+ const createBuckets = this.createBuckets;
383
+
384
+
385
+ const createForms = this.createForms;
386
+ const createForm = this.createForm;
387
+ const itemsContainer = this.shadowRoot.querySelector('#items'); // TODO: rename
388
+ const anyContainer = this.shadowRoot.querySelector('#any'); // TODO: rename
389
+ const bucketsContainer = this.shadowRoot.querySelector('#buckets'); // TODO: rename
390
+
391
+ const editBuckets = this.shadowRoot.querySelector('#editBuckets'); // TODO: rename
392
+
393
+ const saveButton = this.shadowRoot.querySelector('#save');
394
+ const addButton = this.shadowRoot?.querySelector('[data-add-item]')
395
+ const addForm = this.shadowRoot?.querySelector('#addForm');
396
+
397
+ const editBucketsDialog = this.shadowRoot?.querySelector('#editBucketsDialog');
398
+ const editBucketsForm = this.shadowRoot?.querySelector('#editBucketsForm');
399
+ const editBucketsFormSubmit = this.shadowRoot?.querySelector('#editBucketsForm .btn-primary');
400
+ const addBucketButton = this?.shadowRoot.querySelector('[command="add-bucket"]');
401
+ const addItemButton = this?.shadowRoot.querySelector('[command="add-item"]');
402
+
403
+
404
+ const templateForm = this?.querySelector('form');
405
+
406
+ let editBucketsOriginalState = '';
407
+
408
+ let buckets = [];
409
+
410
+ // Prevent the template form from submitting anything
411
+ templateForm?.addEventListener('submit', (event) => {
412
+
413
+ event.preventDefault();
414
+ });
415
+
416
+
417
+ // TODO: add this to an on change event on the select
418
+ Array.from(this.querySelectorAll('select[data-import]')).forEach(async(select) =>{
419
+
420
+
421
+ const ajaxURL = select.getAttribute('data-import');
422
+
423
+ this.importData(ajaxURL).then(
424
+ (data) => {
425
+ if(typeof data == 'string')
426
+ return data;
427
+
428
+ data.forEach(item =>{
429
+
430
+ const optionElement = document.createElement('option');
431
+ optionElement.value = item.id;
432
+ optionElement.innerHTML = item.attributes.name;
433
+ select.appendChild(optionElement);
434
+ });
435
+
436
+ return true;
437
+ }
438
+ );
439
+ });
440
+
441
+
442
+
443
+
444
+ // #region import data
445
+ // TODO load from web storage if its newer
446
+
447
+ const storedData = localStorage.getItem(`config-${this.getAttribute('data-name')}`);
448
+ //const buckets = this.getBucketsData(); // TODO: load from local storage
449
+
450
+ if(storedData){
451
+
452
+ //createForms(JSON.parse(storedData), buckets);
453
+ }
454
+ else if(dataImportUrl){
455
+
456
+ const dataImport = await this.importData(dataImportUrl).then(
457
+ (data) => {
458
+ if(typeof data == 'string')
459
+ return data;
460
+
461
+ const buckets = getBucketsData(data);
462
+
463
+ if(buckets){
464
+
465
+ createBuckets(buckets);
466
+ }
467
+ createForms(data); // any bucket
468
+
469
+ return true;
470
+ }
471
+ );
472
+ }
473
+ // #endregion
474
+
475
+ // #region Add buckets to edit modal
476
+ /*
477
+ editBucketsForm?.addEventListener('submit', (event) => {
478
+
479
+ event.stopPropagation();
480
+ event.preventDefault();
481
+
482
+ if(event.submitter == editBucketsFormSubmit){
483
+
484
+ // Clear what is there already
485
+ //anyContainer?.innerHTML = '';
486
+
487
+ Array.from(itemsContainer?.querySelectorAll('form')).forEach((formElement:HTMLElement, index):void => {
488
+
489
+ anyContainer?.insertAdjacentElement('beforeend',formElement);
490
+ });
491
+
492
+ // Empty the buckets
493
+ bucketsContainer?.innerHTML = '';
494
+
495
+ // Load the new bucket data then recreate them
496
+ const buckets = [];
497
+ Array.from(editBuckets?.querySelectorAll('[data-bucket]')).forEach((editBucketElement:HTMLElement, index):void => {
498
+
499
+ bucketsContainer?.insertAdjacentHTML('beforeend',`<div class="bucket" data-bucket="${editBucketElement.getAttribute('data-bucket')}"></div>`);
500
+
501
+ const bucket = {}
502
+
503
+ bucket.id = editBucketElement.getAttribute('data-bucket');
504
+ bucket.attributes = {};
505
+
506
+ bucket.attributes.name = editBucketElement.querySelector('[name="bucket"]')?.value;
507
+
508
+ //const formData = new FormData(editBucketElement);
509
+ //const formDataObj = Object.fromEntries(formData.entries());
510
+ // TODO cycle through the criteria forms
511
+
512
+ buckets.push(bucket);
513
+ });
514
+
515
+
516
+ console.log(buckets);
517
+ // this.createBuckets(buckets); TODO: re-enable
518
+
519
+ /*
520
+ // Move items back into buckets
521
+ Array.from(itemsContainer?.querySelectorAll('form')).forEach((formElement:HTMLElement, index):void => {
522
+
523
+ const formData = new FormData(formElement);
524
+ const formDataObj = Object.fromEntries(formData.entries());
525
+ const newContainer = this.checkBuckets(formDataObj);
526
+
527
+ if(newContainer != anyContainer){
528
+ newContainer?.insertAdjacentElement('beforeend',formElement);
529
+ }
530
+ });
531
+
532
+
533
+ editBucketsOriginalState = editBuckets.innerHTML;
534
+ }
535
+
536
+ editBucketsDialog?.close();
537
+ });
538
+ */
539
+ /*
540
+
541
+ addBucketButton?.addEventListener('click', (event) => {
542
+
543
+ const editBucket = document.createElement('div');
544
+ editBucket.classList.add('bucket--edit');
545
+ editBucket.innerHTML = this.addBucketHTML();
546
+
547
+ editBuckets?.insertAdjacentElement('beforeend', editBucket)
548
+
549
+ this.addButtonEvents(editBucket,false);
550
+ const expandButton = editBucket?.querySelector('[data-expand]');
551
+
552
+ expandButton?.addEventListener('click',() => {
553
+
554
+ editBucket.classList.toggle('bucket--expanded');
555
+ });
556
+ });
557
+
558
+ */
559
+
560
+
561
+
562
+ // #endregion
563
+
564
+ // #region add data
565
+
566
+ addItemButton?.addEventListener("click", (event) => {
567
+
568
+ const form = this.createForm({});
569
+ form?.scrollIntoView({ behavior: "instant", block: "center" });
570
+ // TODO scroll into view
571
+ });
572
+
573
+ addBucketButton?.addEventListener("click", (event) => {
574
+
575
+ const bucket = this.createBucket({});
576
+ bucket?.scrollIntoView({ behavior: "instant", block: "center" });
577
+ });
578
+
579
+ // #endregion
580
+
581
+
582
+ // #region update values
583
+
584
+ this.shadowRoot.addEventListener('change', (event) => {
585
+
586
+ const container = event.target.closest('[data-bucket]');
587
+
588
+ if(!container)
589
+ return false;
590
+
591
+ const attribute = event.target.name;
592
+ const value = event.target.value;
593
+ const attributes = {};
594
+ attributes[attribute] = value;
595
+ const newContainer = this.checkBuckets(attributes);
596
+
597
+ if(newContainer != container){
598
+ const form = event.target.closest(`form`);
599
+ // TODO a confirmation modal
600
+ newContainer?.insertAdjacentElement('beforeend',form);
601
+
602
+
603
+ form?.scrollIntoView({ behavior: "instant", block: "center" });
604
+ }
605
+
606
+ });
607
+ // #endregion
608
+
609
+ // #region save data
610
+ saveButton?.addEventListener('click', (event) => {
611
+
612
+ event.preventDefault();
613
+
614
+ // TODO validation
615
+
616
+ const entries = [];
617
+
618
+ // Save buckets data
619
+ Array.from(itemsContainer?.querySelectorAll('.bucket__wrapper')).forEach((bucketElement:HTMLElement, index):void => {
620
+
621
+ const bucket = {};
622
+ bucket.attributes = {};
623
+ bucket.id = bucketElement?.querySelector('[name="bucket"]').value;
624
+ bucket.type = 'bucket';
625
+ bucket.attributes.index = index;
626
+
627
+
628
+ const criteria = [];
629
+ // TODO populate criteria
630
+ Array.from(bucketElement?.querySelectorAll('.criteria--container form')).forEach((formElement:HTMLElement, criteriaIndex):void => {
631
+
632
+ const item = {};
633
+ //item.id = formElement.getAttribute('id');
634
+ item.type = 'criteria';
635
+ item.index = criteriaIndex;
636
+ const formData = new FormData(formElement);
637
+ const formDataObj = Object.fromEntries(formData.entries());
638
+
639
+ item.attributes = formDataObj;
640
+
641
+ criteria.push(item);
642
+ });
643
+ bucket.attributes.criteria = criteria;
644
+
645
+ const items = [];
646
+ Array.from(bucketElement?.querySelectorAll('[data-bucket] form')).forEach((formElement:HTMLElement, itemIndex):void => {
647
+
648
+ const item = {};
649
+ //item.id = formElement.getAttribute('id');
650
+ item.type = 'item';
651
+ item.index = itemIndex;
652
+ const formData = new FormData(formElement);
653
+ const formDataObj = Object.fromEntries(formData.entries());
654
+
655
+ item.attributes = formDataObj;
656
+
657
+ items.push(item);
658
+ });
659
+ bucket.attributes.items = items;
660
+
661
+ entries.push(bucket);
662
+ });
663
+
664
+
665
+ Array.from(itemsContainer?.querySelectorAll('[data-bucket="any"] form')).forEach((formElement:HTMLElement, index):void => {
666
+
667
+ const entry = {};
668
+ //entry.id = formElement.getAttribute('id');
669
+ entry.type = 'item';
670
+ entry.index = index;
671
+ const formData = new FormData(formElement);
672
+ const formDataObj = Object.fromEntries(formData.entries());
673
+
674
+ entry.attributes = formDataObj;
675
+
676
+ entries.push(entry);
677
+ });
678
+
679
+ const entriesJson = JSON.stringify(entries);
680
+
681
+ console.log(entries);
682
+
683
+ // TODO add toast message
684
+ // TODO save locally for now but when pushing to endpoint the web storage file should get deleted
685
+
686
+ //localStorage.setItem(`config-${this.getAttribute('data-name')}`, entriesJson);
687
+
688
+
689
+
690
+ //const bucketsJson = JSON.stringify(buckets);
691
+
692
+ //localStorage.setItem(`config-buckets-${this.getAttribute('data-name')}`, bucketsJson);
693
+
694
+ });
695
+ // #endregion
696
+ }
697
+ }
698
+
699
+ export default iamConfig;