@iamproperty/components 7.6.4--beta7 → 7.7.0

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 (344) hide show
  1. package/assets/css/components/actionbar.component.css +1 -1
  2. package/assets/css/components/actionbar.component.css.map +1 -1
  3. package/assets/css/components/actionbar.global.css +1 -1
  4. package/assets/css/components/actionbar.global.css.map +1 -1
  5. package/assets/css/components/address-lookup.component.css +1 -1
  6. package/assets/css/components/address-lookup.component.css.map +1 -1
  7. package/assets/css/components/applied-filters.css +1 -1
  8. package/assets/css/components/applied-filters.css.map +1 -1
  9. package/assets/css/components/barchart.component.css +1 -1
  10. package/assets/css/components/barchart.component.css.map +1 -1
  11. package/assets/css/components/bento-grid.global.css +1 -1
  12. package/assets/css/components/calendar.component.css +1 -1
  13. package/assets/css/components/calendar.component.css.map +1 -1
  14. package/assets/css/components/calendar.config.css +1 -1
  15. package/assets/css/components/card.component.css +1 -1
  16. package/assets/css/components/card.component.css.map +1 -1
  17. package/assets/css/components/card.module.css +1 -1
  18. package/assets/css/components/carousel.component.css +1 -1
  19. package/assets/css/components/carousel.component.css.map +1 -1
  20. package/assets/css/components/charts.config.css +1 -1
  21. package/assets/css/components/charts.css +1 -1
  22. package/assets/css/components/charts.css.map +1 -1
  23. package/assets/css/components/charts.module.css +1 -1
  24. package/assets/css/components/charts.module.css.map +1 -1
  25. package/assets/css/components/collapsible-side.css +1 -1
  26. package/assets/css/components/collapsible-side.css.map +1 -1
  27. package/assets/css/components/config.component.css +1 -0
  28. package/assets/css/components/config.component.css.map +1 -0
  29. package/assets/css/components/content.component.css +1 -1
  30. package/assets/css/components/content.component.css.map +1 -1
  31. package/assets/css/components/doughnutchart.component.css +1 -1
  32. package/assets/css/components/doughnutchart.component.css.map +1 -1
  33. package/assets/css/components/fileupload.css +1 -1
  34. package/assets/css/components/fileupload.css.map +1 -1
  35. package/assets/css/components/filter-card.component.css +1 -1
  36. package/assets/css/components/header.css +1 -1
  37. package/assets/css/components/header.css.map +1 -1
  38. package/assets/css/components/inline-edit.css +1 -1
  39. package/assets/css/components/inline-edit.css.map +1 -1
  40. package/assets/css/components/input.component.css +1 -1
  41. package/assets/css/components/input.component.css.map +1 -1
  42. package/assets/css/components/menu.component.css +1 -1
  43. package/assets/css/components/menu.component.css.map +1 -1
  44. package/assets/css/components/milestone.css +1 -1
  45. package/assets/css/components/modal.component.css +1 -1
  46. package/assets/css/components/modal.component.css.map +1 -1
  47. package/assets/css/components/multi-step-modal.component.css +1 -1
  48. package/assets/css/components/multi-step-modal.component.css.map +1 -1
  49. package/assets/css/components/multiselect.css +1 -1
  50. package/assets/css/components/multiselect.css.map +1 -1
  51. package/assets/css/components/nav.component.css +1 -1
  52. package/assets/css/components/nav.component.css.map +1 -1
  53. package/assets/css/components/nav.global.css +1 -1
  54. package/assets/css/components/nav.global.css.map +1 -1
  55. package/assets/css/components/notification.css +1 -1
  56. package/assets/css/components/notification.css.map +1 -1
  57. package/assets/css/components/pagination.css +1 -1
  58. package/assets/css/components/pagination.css.map +1 -1
  59. package/assets/css/components/password.component.css +1 -1
  60. package/assets/css/components/password.component.css.map +1 -1
  61. package/assets/css/components/property-searchbar.css +1 -1
  62. package/assets/css/components/property-searchbar.css.map +1 -1
  63. package/assets/css/components/rank.component.css +1 -1
  64. package/assets/css/components/rank.component.css.map +1 -1
  65. package/assets/css/components/record-card.component.css +1 -1
  66. package/assets/css/components/record-card.component.css.map +1 -1
  67. package/assets/css/components/slider.css +1 -1
  68. package/assets/css/components/slider.css.map +1 -1
  69. package/assets/css/components/split-button.component.css +1 -1
  70. package/assets/css/components/split-button.component.css.map +1 -1
  71. package/assets/css/components/table-basic.component.css +1 -1
  72. package/assets/css/components/table-basic.component.css.map +1 -1
  73. package/assets/css/components/table-basic.global.css +1 -1
  74. package/assets/css/components/table-basic.global.css.map +1 -1
  75. package/assets/css/components/table.component.css +1 -1
  76. package/assets/css/components/table.component.css.map +1 -1
  77. package/assets/css/components/table.global.css +1 -1
  78. package/assets/css/components/table.global.css.map +1 -1
  79. package/assets/css/components/tabs.component.css +1 -1
  80. package/assets/css/components/tabs.component.css.map +1 -1
  81. package/assets/css/components/tag.component.css +1 -1
  82. package/assets/css/components/tag.component.css.map +1 -1
  83. package/assets/css/components/tooltip.component.css +1 -1
  84. package/assets/css/components/tooltip.component.css.map +1 -1
  85. package/assets/css/components/video-card.component.css +1 -1
  86. package/assets/css/components/video-modal.component.css +1 -1
  87. package/assets/css/components/video-modal.component.css.map +1 -1
  88. package/assets/css/core.min.css +1 -1
  89. package/assets/css/core.min.css.map +1 -1
  90. package/assets/css/style.min.css +1 -1
  91. package/assets/css/style.min.css.map +1 -1
  92. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  93. package/assets/js/components/actionbar/actionbar.component.js +8 -7
  94. package/assets/js/components/actionbar/actionbar.component.min.js +7 -7
  95. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  96. package/assets/js/components/address-lookup/address-lookup.component.js +12 -2
  97. package/assets/js/components/address-lookup/address-lookup.component.min.js +5 -5
  98. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  99. package/assets/js/components/advanced-select/advanced-select.component.js +1 -1
  100. package/assets/js/components/advanced-select/advanced-select.component.min.js +2 -2
  101. package/assets/js/components/advanced-select/advanced-select.component.min.js.map +1 -1
  102. package/assets/js/components/applied-filters/applied-filters.component.min.js +4 -4
  103. package/assets/js/components/barchart/barchart.component.min.js +6 -6
  104. package/assets/js/components/barchart/barchart.component.min.js.map +1 -1
  105. package/assets/js/components/bento-grid/bento-grid.component.min.js +2 -2
  106. package/assets/js/components/calendar/calendar.component.min.js +2 -2
  107. package/assets/js/components/card/card.component.min.js +7 -7
  108. package/assets/js/components/carousel/carousel.component.min.js +4 -4
  109. package/assets/js/components/collapsible-side/collapsible-side.component.js +1 -1
  110. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +5 -5
  111. package/assets/js/components/collapsible-side/collapsible-side.component.min.js.map +1 -1
  112. package/assets/js/components/config/config.component.js +532 -0
  113. package/assets/js/components/config/config.component.min.js +59 -0
  114. package/assets/js/components/config/config.component.min.js.map +1 -0
  115. package/assets/js/components/content/content.component.min.js +4 -4
  116. package/assets/js/components/darkmode/darkmode.component.min.js +1 -1
  117. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +7 -7
  118. package/assets/js/components/fileupload/fileupload.component.min.js +4 -4
  119. package/assets/js/components/filter-card/filter-card.component.min.js +2 -2
  120. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  121. package/assets/js/components/form/form.component.min.js +1 -1
  122. package/assets/js/components/header/header.component.js +39 -1
  123. package/assets/js/components/header/header.component.min.js +40 -4
  124. package/assets/js/components/header/header.component.min.js.map +1 -1
  125. package/assets/js/components/inline-edit/inline-edit.component.js +1 -1
  126. package/assets/js/components/inline-edit/inline-edit.component.min.js +4 -4
  127. package/assets/js/components/inline-edit/inline-edit.component.min.js.map +1 -1
  128. package/assets/js/components/input/input.component.js +1 -1
  129. package/assets/js/components/input/input.component.min.js +3 -3
  130. package/assets/js/components/input/input.component.min.js.map +1 -1
  131. package/assets/js/components/input-range/input-range.component.js +1 -1
  132. package/assets/js/components/input-range/input-range.component.min.js +2 -2
  133. package/assets/js/components/input-range/input-range.component.min.js.map +1 -1
  134. package/assets/js/components/marketing/marketing.component.js +1 -1
  135. package/assets/js/components/marketing/marketing.component.min.js +2 -2
  136. package/assets/js/components/marketing/marketing.component.min.js.map +1 -1
  137. package/assets/js/components/menu/menu.component.min.js +2 -2
  138. package/assets/js/components/milestone/milestone.component.min.js +1 -1
  139. package/assets/js/components/milestone-group/milestone-group.component.min.js +1 -1
  140. package/assets/js/components/modal/modal.component.js +1 -1
  141. package/assets/js/components/modal/modal.component.min.js +5 -5
  142. package/assets/js/components/modal/modal.component.min.js.map +1 -1
  143. package/assets/js/components/multi-step/multi-step.component.min.js +1 -1
  144. package/assets/js/components/multi-step-modal/multi-step-modal.component.js +1 -1
  145. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js +5 -5
  146. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js.map +1 -1
  147. package/assets/js/components/multiselect/multiselect.component.min.js +2 -2
  148. package/assets/js/components/nav/nav.component.js +1 -1
  149. package/assets/js/components/nav/nav.component.min.js +6 -6
  150. package/assets/js/components/nav/nav.component.min.js.map +1 -1
  151. package/assets/js/components/notification/notification.component.js +69 -30
  152. package/assets/js/components/notification/notification.component.min.js +5 -5
  153. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  154. package/assets/js/components/pagination/pagination.component.js +1 -1
  155. package/assets/js/components/pagination/pagination.component.min.js +4 -4
  156. package/assets/js/components/pagination/pagination.component.min.js.map +1 -1
  157. package/assets/js/components/password/password.component.js +1 -1
  158. package/assets/js/components/password/password.component.min.js +5 -5
  159. package/assets/js/components/password/password.component.min.js.map +1 -1
  160. package/assets/js/components/popover/popover.component.min.js +1 -1
  161. package/assets/js/components/rank/rank.component.min.js +1 -1
  162. package/assets/js/components/rankings/rankings.component.min.js +1 -1
  163. package/assets/js/components/rating/rating.component.min.js +1 -1
  164. package/assets/js/components/record-card/record-card.component.min.js +2 -2
  165. package/assets/js/components/search/search.component.js +1 -1
  166. package/assets/js/components/search/search.component.min.js +2 -2
  167. package/assets/js/components/search/search.component.min.js.map +1 -1
  168. package/assets/js/components/slider/slider.component.min.js +2 -2
  169. package/assets/js/components/split-button/split-button.component.js +0 -4
  170. package/assets/js/components/split-button/split-button.component.min.js +6 -7
  171. package/assets/js/components/split-button/split-button.component.min.js.map +1 -1
  172. package/assets/js/components/std-address-lookup/std-address-lookup.component.js +41 -11
  173. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js +9 -17
  174. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js.map +1 -1
  175. package/assets/js/components/table/table.component.min.js +4 -4
  176. package/assets/js/components/table-ajax/table-ajax.component.min.js +7 -7
  177. package/assets/js/components/table-basic/table-basic.component.min.js +5 -5
  178. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +4 -4
  179. package/assets/js/components/table-submit/table-submit.component.min.js +7 -7
  180. package/assets/js/components/tabs/tabs.component.js +1 -1
  181. package/assets/js/components/tabs/tabs.component.min.js +5 -5
  182. package/assets/js/components/tabs/tabs.component.min.js.map +1 -1
  183. package/assets/js/components/tag/tag.component.min.js +4 -4
  184. package/assets/js/components/tag/tag.component.min.js.map +1 -1
  185. package/assets/js/components/tooltip/tooltip.component.min.js +2 -2
  186. package/assets/js/components/video-card/video-card.component.min.js +2 -2
  187. package/assets/js/components/video-modal/video-modal.component.js +1 -1
  188. package/assets/js/components/video-modal/video-modal.component.min.js +4 -4
  189. package/assets/js/components/video-modal/video-modal.component.min.js.map +1 -1
  190. package/assets/js/components/word-count/word-count.component.min.js +1 -1
  191. package/assets/js/modules/helper.test.js +84 -0
  192. package/assets/js/modules/test.js +19 -0
  193. package/assets/js/scripts.bundle.js +1 -1
  194. package/assets/js/scripts.bundle.min.js +1 -1
  195. package/assets/sass/_components.scss +7 -7
  196. package/assets/sass/_corefiles.scss +8 -7
  197. package/assets/sass/_elements.scss +16 -16
  198. package/assets/sass/_functions/bs_mixins.scss +3 -3
  199. package/assets/sass/_utilities.scss +4 -3
  200. package/assets/sass/components/actionbar.component.scss +37 -28
  201. package/assets/sass/components/actionbar.global.scss +12 -4
  202. package/assets/sass/components/address-lookup.component.scss +7 -7
  203. package/assets/sass/components/applied-filters.scss +2 -2
  204. package/assets/sass/components/barchart.component.scss +6 -6
  205. package/assets/sass/components/bento-grid.component.scss +2 -2
  206. package/assets/sass/components/bento-grid.global.scss +3 -3
  207. package/assets/sass/components/calendar.component.scss +14 -14
  208. package/assets/sass/components/calendar.config.scss +4 -4
  209. package/assets/sass/components/card.component.scss +10 -10
  210. package/assets/sass/components/card.module.scss +2 -2
  211. package/assets/sass/components/carousel.component.scss +8 -8
  212. package/assets/sass/components/carousel.config.scss +2 -2
  213. package/assets/sass/components/charts.config.scss +3 -3
  214. package/assets/sass/components/charts.module.scss +4 -18
  215. package/assets/sass/components/charts.scss +3 -3
  216. package/assets/sass/components/collapsible-side.scss +16 -16
  217. package/assets/sass/components/config.component.scss +235 -0
  218. package/assets/sass/components/content.component.scss +1 -1
  219. package/assets/sass/components/darkmode.component.scss +1 -1
  220. package/assets/sass/components/doughnutchart.component.scss +11 -10
  221. package/assets/sass/components/fileupload.scss +9 -9
  222. package/assets/sass/components/filter-card.component.scss +3 -3
  223. package/assets/sass/components/header.scss +121 -23
  224. package/assets/sass/components/inline-edit.preload.scss +1 -1
  225. package/assets/sass/components/inline-edit.scss +1 -1
  226. package/assets/sass/components/input.component.scss +2 -1
  227. package/assets/sass/components/marketing.component.scss +1 -1
  228. package/assets/sass/components/menu.component.scss +10 -10
  229. package/assets/sass/components/milestone.scss +2 -2
  230. package/assets/sass/components/modal.component.scss +22 -22
  231. package/assets/sass/components/multi-step-modal.component.scss +15 -15
  232. package/assets/sass/components/multi-step-modal.global.scss +1 -1
  233. package/assets/sass/components/multi-step.component.scss +3 -3
  234. package/assets/sass/components/multiselect.scss +9 -9
  235. package/assets/sass/components/nav.component.scss +24 -24
  236. package/assets/sass/components/nav.docs.scss +1 -1
  237. package/assets/sass/components/nav.global.scss +120 -119
  238. package/assets/sass/components/nav.preload.scss +1 -1
  239. package/assets/sass/components/notification.scss +36 -19
  240. package/assets/sass/components/pagination.scss +7 -7
  241. package/assets/sass/components/password.component.scss +1 -1
  242. package/assets/sass/components/popover.component.scss +3 -3
  243. package/assets/sass/components/property-searchbar.scss +1 -1
  244. package/assets/sass/components/rank.component.scss +19 -19
  245. package/assets/sass/components/rankings.component.scss +1 -1
  246. package/assets/sass/components/rankings.global.scss +2 -2
  247. package/assets/sass/components/record-card.component.scss +15 -15
  248. package/assets/sass/components/slider.scss +4 -4
  249. package/assets/sass/components/snapshot.scss +1 -1
  250. package/assets/sass/components/split-button.component.scss +2 -2
  251. package/assets/sass/components/table-basic.component.scss +3 -3
  252. package/assets/sass/components/table-basic.global.scss +34 -14
  253. package/assets/sass/components/table.component.scss +27 -16
  254. package/assets/sass/components/table.global.scss +51 -49
  255. package/assets/sass/components/tabs.component.scss +3 -3
  256. package/assets/sass/components/tabs.config.scss +1 -1
  257. package/assets/sass/components/tag.component.scss +2 -2
  258. package/assets/sass/components/testimonial.scss +2 -2
  259. package/assets/sass/components/timeline.scss +3 -3
  260. package/assets/sass/components/tooltip.component.scss +13 -8
  261. package/assets/sass/components/video-card.component.scss +2 -2
  262. package/assets/sass/components/video-modal.component.scss +1 -1
  263. package/assets/sass/components/word-count.component.scss +1 -1
  264. package/assets/sass/core.scss +1 -1
  265. package/assets/sass/elements/{admin-panel.scss → admin-panel.css} +17 -24
  266. package/assets/sass/elements/{badge-tag.scss → badge-tag.css} +11 -19
  267. package/assets/sass/elements/button__group.css +3 -2
  268. package/assets/sass/elements/{buttons--action.scss → buttons--action.css} +11 -19
  269. package/assets/sass/elements/{buttons--compact.scss → buttons--compact.css} +8 -36
  270. package/assets/sass/elements/buttons--global.scss +12 -18
  271. package/assets/sass/elements/buttons--special.scss +1 -1
  272. package/assets/sass/elements/buttons.scss +6 -6
  273. package/assets/sass/elements/container.scss +6 -6
  274. package/assets/sass/elements/details.scss +13 -13
  275. package/assets/sass/elements/dialog.scss +7 -7
  276. package/assets/sass/elements/dropdown.scss +1 -1
  277. package/assets/sass/elements/feature.scss +114 -6
  278. package/assets/sass/elements/forms.scss +24 -25
  279. package/assets/sass/elements/icons.css +1 -1
  280. package/assets/sass/elements/links.scss +5 -5
  281. package/assets/sass/elements/lists--tick-list.scss +18 -6
  282. package/assets/sass/elements/modal.scss +24 -24
  283. package/assets/sass/elements/popover.scss +14 -14
  284. package/assets/sass/elements/prefix.scss +18 -4
  285. package/assets/sass/elements/progress.scss +14 -14
  286. package/assets/sass/elements/table.element.scss +9 -5
  287. package/assets/sass/elements/tooltips.scss +4 -4
  288. package/assets/sass/email.scss +1 -1
  289. package/assets/sass/foundations/animations.scss +2 -0
  290. package/assets/sass/foundations/colours.scss +1 -1
  291. package/assets/sass/foundations/reboot.scss +1 -1
  292. package/assets/sass/foundations/root.scss +29 -96
  293. package/assets/sass/templates/auth.scss +7 -7
  294. package/assets/sass/templates/form.scss +8 -8
  295. package/assets/sass/utilities/border.scss +6 -18
  296. package/assets/sass/utilities/font-awesome-iso-fallbacks.scss +6 -0
  297. package/assets/sass/utilities/shadow.scss +7 -0
  298. package/assets/sass/utilities/wider-colours.scss +0 -2
  299. package/assets/ts/components/actionbar/actionbar.component.ts +8 -7
  300. package/assets/ts/components/address-lookup/address-lookup.component.ts +17 -2
  301. package/assets/ts/components/advanced-select/advanced-select.component.ts +1 -1
  302. package/assets/ts/components/collapsible-side/collapsible-side.component.ts +1 -1
  303. package/assets/ts/components/config/config.component.ts +699 -0
  304. package/assets/ts/components/header/header.component.ts +40 -1
  305. package/assets/ts/components/inline-edit/inline-edit.component.ts +1 -1
  306. package/assets/ts/components/input/input.component.ts +1 -1
  307. package/assets/ts/components/input-range/input-range.component.ts +1 -1
  308. package/assets/ts/components/marketing/marketing.component.ts +1 -1
  309. package/assets/ts/components/modal/modal.component.ts +1 -1
  310. package/assets/ts/components/multi-step-modal/multi-step-modal.component.ts +1 -1
  311. package/assets/ts/components/nav/nav.component.ts +1 -1
  312. package/assets/ts/components/notification/notification.component.ts +98 -47
  313. package/assets/ts/components/pagination/pagination.component.ts +1 -1
  314. package/assets/ts/components/password/password.component.ts +1 -1
  315. package/assets/ts/components/search/search.component.ts +1 -1
  316. package/assets/ts/components/split-button/split-button.component.ts +0 -4
  317. package/assets/ts/components/std-address-lookup/std-address-lookup.component.ts +47 -12
  318. package/assets/ts/components/tabs/tabs.component.ts +1 -1
  319. package/assets/ts/components/video-modal/video-modal.component.ts +1 -1
  320. package/assets/ts/modules/helper.test.ts +143 -0
  321. package/assets/ts/modules/test.ts +22 -0
  322. package/dist/components.es.js +29 -29
  323. package/dist/components.umd.js +372 -288
  324. package/package.json +9 -21
  325. package/src/components/Config/Config.vue +23 -0
  326. package/assets/js/tests/helpers.spec.js +0 -79
  327. package/assets/js/ui-tests/card.spec.js +0 -14
  328. package/assets/js/ui-tests/carousel.spec.js +0 -60
  329. package/assets/js/ui-tests/chart.spec.js +0 -59
  330. package/assets/js/ui-tests/fileupload.spec.js +0 -22
  331. package/assets/js/ui-tests/filterlist.spec.js +0 -22
  332. package/assets/js/ui-tests/multistep.spec.js +0 -68
  333. package/assets/js/ui-tests/slider.spec.js +0 -20
  334. package/assets/js/ui-tests/table.spec.js +0 -81
  335. package/assets/ts/tests/helpers.spec.ts +0 -137
  336. package/assets/ts/ui-tests/card.spec.ts +0 -19
  337. package/assets/ts/ui-tests/carousel.spec.ts +0 -66
  338. package/assets/ts/ui-tests/chart.spec.ts +0 -71
  339. package/assets/ts/ui-tests/data-layer.spec.js +0 -68
  340. package/assets/ts/ui-tests/fileupload.spec.ts +0 -30
  341. package/assets/ts/ui-tests/filterlist.spec.ts +0 -26
  342. package/assets/ts/ui-tests/multistep.spec.ts +0 -78
  343. package/assets/ts/ui-tests/slider.spec.ts +0 -27
  344. package/assets/ts/ui-tests/table.spec.ts +0 -91
@@ -0,0 +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;