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

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 (577) 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/notification.css +1 -1
  59. package/assets/css/components/notification.css.map +1 -1
  60. package/assets/favicons/README.md +20 -20
  61. package/assets/favicons/browserconfig.xml +9 -9
  62. package/assets/favicons/manifest.json +31 -31
  63. package/assets/favicons/safari-pinned-tab.svg +35 -35
  64. package/assets/favicons/site.webmanifest +20 -20
  65. package/assets/js/components/accordion/accordion.component.js +14 -14
  66. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  67. package/assets/js/components/accordion/accordion.component.min.js.map +1 -1
  68. package/assets/js/components/actionbar/actionbar.component.js +66 -66
  69. package/assets/js/components/actionbar/actionbar.component.min.js +1 -1
  70. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  71. package/assets/js/components/address-lookup/address-lookup.component.js +58 -58
  72. package/assets/js/components/address-lookup/address-lookup.component.min.js +1 -1
  73. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  74. package/assets/js/components/advanced-select/advanced-select.component.js +18 -18
  75. package/assets/js/components/advanced-select/advanced-select.component.min.js +1 -1
  76. package/assets/js/components/advanced-select/advanced-select.component.min.js.map +1 -1
  77. package/assets/js/components/applied-filters/applied-filters.component.js +6 -6
  78. package/assets/js/components/applied-filters/applied-filters.component.min.js +1 -1
  79. package/assets/js/components/applied-filters/applied-filters.component.min.js.map +1 -1
  80. package/assets/js/components/barchart/barchart.component.min.js +1 -1
  81. package/assets/js/components/barchart/barchart.component.min.js.map +1 -1
  82. package/assets/js/components/bento-grid/bento-grid.component.js +9 -9
  83. package/assets/js/components/bento-grid/bento-grid.component.min.js +1 -1
  84. package/assets/js/components/bento-grid/bento-grid.component.min.js.map +1 -1
  85. package/assets/js/components/calendar/calendar.component.min.js +1 -1
  86. package/assets/js/components/card/card.component.min.js +1 -1
  87. package/assets/js/components/card/card.component.min.js.map +1 -1
  88. package/assets/js/components/carousel/carousel.component.min.js +1 -1
  89. package/assets/js/components/collapsible-side/collapsible-side.component.js +20 -20
  90. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +1 -1
  91. package/assets/js/components/collapsible-side/collapsible-side.component.min.js.map +1 -1
  92. package/assets/js/components/config/config.component.js +53 -53
  93. package/assets/js/components/config/config.component.min.js +1 -1
  94. package/assets/js/components/config/config.component.min.js.map +1 -1
  95. package/assets/js/components/content/content.component.js +9 -9
  96. package/assets/js/components/content/content.component.min.js +1 -1
  97. package/assets/js/components/content/content.component.min.js.map +1 -1
  98. package/assets/js/components/darkmode/darkmode.component.js +4 -4
  99. package/assets/js/components/darkmode/darkmode.component.min.js +1 -1
  100. package/assets/js/components/darkmode/darkmode.component.min.js.map +1 -1
  101. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +1 -1
  102. package/assets/js/components/doughnutchart/doughnutchart.component.min.js.map +1 -1
  103. package/assets/js/components/fileupload/fileupload.component.js +16 -16
  104. package/assets/js/components/fileupload/fileupload.component.min.js +1 -1
  105. package/assets/js/components/fileupload/fileupload.component.min.js.map +1 -1
  106. package/assets/js/components/filter-card/filter-card.component.js +7 -7
  107. package/assets/js/components/filter-card/filter-card.component.min.js +1 -1
  108. package/assets/js/components/filter-card/filter-card.component.min.js.map +1 -1
  109. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  110. package/assets/js/components/form/form.component.js +4 -4
  111. package/assets/js/components/form/form.component.min.js +1 -1
  112. package/assets/js/components/form/form.component.min.js.map +1 -1
  113. package/assets/js/components/header/header.component.js +53 -53
  114. package/assets/js/components/header/header.component.min.js +1 -1
  115. package/assets/js/components/header/header.component.min.js.map +1 -1
  116. package/assets/js/components/inline-edit/inline-edit.component.js +16 -16
  117. package/assets/js/components/inline-edit/inline-edit.component.min.js +1 -1
  118. package/assets/js/components/inline-edit/inline-edit.component.min.js.map +1 -1
  119. package/assets/js/components/input/input.component.js +10 -10
  120. package/assets/js/components/input/input.component.min.js +1 -1
  121. package/assets/js/components/input/input.component.min.js.map +1 -1
  122. package/assets/js/components/input-range/input-range.component.js +8 -8
  123. package/assets/js/components/input-range/input-range.component.min.js +1 -1
  124. package/assets/js/components/input-range/input-range.component.min.js.map +1 -1
  125. package/assets/js/components/marketing/marketing.component.js +10 -10
  126. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  127. package/assets/js/components/marketing/marketing.component.min.js.map +1 -1
  128. package/assets/js/components/menu/menu.component.js +6 -6
  129. package/assets/js/components/menu/menu.component.min.js +1 -1
  130. package/assets/js/components/menu/menu.component.min.js.map +1 -1
  131. package/assets/js/components/milestone/milestone.component.min.js +1 -1
  132. package/assets/js/components/milestone-group/milestone-group.component.min.js +1 -1
  133. package/assets/js/components/modal/modal.component.js +21 -21
  134. package/assets/js/components/modal/modal.component.min.js +1 -1
  135. package/assets/js/components/modal/modal.component.min.js.map +1 -1
  136. package/assets/js/components/multi-step/multi-step.component.min.js +1 -1
  137. package/assets/js/components/multi-step-modal/multi-step-modal.component.js +11 -11
  138. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js +1 -1
  139. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js.map +1 -1
  140. package/assets/js/components/multiselect/multiselect.component.js +20 -20
  141. package/assets/js/components/multiselect/multiselect.component.min.js +1 -1
  142. package/assets/js/components/multiselect/multiselect.component.min.js.map +1 -1
  143. package/assets/js/components/nav/nav.component.js +45 -45
  144. package/assets/js/components/nav/nav.component.min.js +1 -1
  145. package/assets/js/components/nav/nav.component.min.js.map +1 -1
  146. package/assets/js/components/notification/notification.component.js +14 -13
  147. package/assets/js/components/notification/notification.component.min.js +5 -4
  148. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  149. package/assets/js/components/pagination/pagination.component.js +39 -39
  150. package/assets/js/components/pagination/pagination.component.min.js +1 -1
  151. package/assets/js/components/pagination/pagination.component.min.js.map +1 -1
  152. package/assets/js/components/password/password.component.js +10 -10
  153. package/assets/js/components/password/password.component.min.js +1 -1
  154. package/assets/js/components/password/password.component.min.js.map +1 -1
  155. package/assets/js/components/popover/popover.component.js +7 -7
  156. package/assets/js/components/popover/popover.component.min.js +1 -1
  157. package/assets/js/components/popover/popover.component.min.js.map +1 -1
  158. package/assets/js/components/rank/rank.component.js +359 -359
  159. package/assets/js/components/rank/rank.component.min.js +1 -1
  160. package/assets/js/components/rank/rank.component.min.js.map +1 -1
  161. package/assets/js/components/rankings/rankings.component.js +16 -16
  162. package/assets/js/components/rankings/rankings.component.min.js +1 -1
  163. package/assets/js/components/rankings/rankings.component.min.js.map +1 -1
  164. package/assets/js/components/rating/rating.component.js +9 -9
  165. package/assets/js/components/rating/rating.component.min.js +1 -1
  166. package/assets/js/components/rating/rating.component.min.js.map +1 -1
  167. package/assets/js/components/record-card/record-card.component.min.js +1 -1
  168. package/assets/js/components/record-card/record-card.component.min.js.map +1 -1
  169. package/assets/js/components/search/search.component.js +17 -17
  170. package/assets/js/components/search/search.component.min.js +1 -1
  171. package/assets/js/components/search/search.component.min.js.map +1 -1
  172. package/assets/js/components/slider/slider.component.js +12 -12
  173. package/assets/js/components/slider/slider.component.min.js +1 -1
  174. package/assets/js/components/slider/slider.component.min.js.map +1 -1
  175. package/assets/js/components/split-button/split-button.component.js +18 -18
  176. package/assets/js/components/split-button/split-button.component.min.js +1 -1
  177. package/assets/js/components/split-button/split-button.component.min.js.map +1 -1
  178. package/assets/js/components/std-address-lookup/std-address-lookup.component.js +113 -113
  179. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js +1 -1
  180. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js.map +1 -1
  181. package/assets/js/components/table/table.component.js +15 -15
  182. package/assets/js/components/table/table.component.min.js +1 -1
  183. package/assets/js/components/table/table.component.min.js.map +1 -1
  184. package/assets/js/components/table-ajax/table-ajax.component.js +15 -15
  185. package/assets/js/components/table-ajax/table-ajax.component.min.js +1 -1
  186. package/assets/js/components/table-ajax/table-ajax.component.min.js.map +1 -1
  187. package/assets/js/components/table-basic/table-basic.component.js +15 -15
  188. package/assets/js/components/table-basic/table-basic.component.min.js +1 -1
  189. package/assets/js/components/table-basic/table-basic.component.min.js.map +1 -1
  190. package/assets/js/components/table-no-submit/table-no-submit.component.js +15 -15
  191. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +1 -1
  192. package/assets/js/components/table-no-submit/table-no-submit.component.min.js.map +1 -1
  193. package/assets/js/components/table-submit/table-submit.component.js +15 -15
  194. package/assets/js/components/table-submit/table-submit.component.min.js +1 -1
  195. package/assets/js/components/table-submit/table-submit.component.min.js.map +1 -1
  196. package/assets/js/components/tabs/tabs.component.js +17 -17
  197. package/assets/js/components/tabs/tabs.component.min.js +1 -1
  198. package/assets/js/components/tabs/tabs.component.min.js.map +1 -1
  199. package/assets/js/components/tag/tag.component.js +12 -12
  200. package/assets/js/components/tag/tag.component.min.js +1 -1
  201. package/assets/js/components/tag/tag.component.min.js.map +1 -1
  202. package/assets/js/components/tooltip/tooltip.component.js +8 -8
  203. package/assets/js/components/tooltip/tooltip.component.min.js +1 -1
  204. package/assets/js/components/tooltip/tooltip.component.min.js.map +1 -1
  205. package/assets/js/components/video/video.component.js +9 -9
  206. package/assets/js/components/video/video.component.min.js +1 -1
  207. package/assets/js/components/video/video.component.min.js.map +1 -1
  208. package/assets/js/components/video-card/video-card.component.js +12 -12
  209. package/assets/js/components/video-card/video-card.component.min.js +1 -1
  210. package/assets/js/components/video-card/video-card.component.min.js.map +1 -1
  211. package/assets/js/components/video-modal/video-modal.component.js +13 -13
  212. package/assets/js/components/video-modal/video-modal.component.min.js +1 -1
  213. package/assets/js/components/video-modal/video-modal.component.min.js.map +1 -1
  214. package/assets/js/components/word-count/word-count.component.min.js +1 -1
  215. package/assets/js/modules/card.module.js +14 -14
  216. package/assets/js/modules/chart.module.js +4 -4
  217. package/assets/js/modules/integration-tests.js +3 -3
  218. package/assets/js/modules/table.js +2 -2
  219. package/assets/js/modules/videos.js +6 -6
  220. package/assets/js/scripts.bundle.js +1 -1
  221. package/assets/js/scripts.bundle.js.map +1 -1
  222. package/assets/js/scripts.bundle.min.js +1 -1
  223. package/assets/js/scripts.bundle.min.js.map +1 -1
  224. package/assets/sass/_bs_grid.scss +41 -41
  225. package/assets/sass/_bs_utilities.scss +51 -51
  226. package/assets/sass/_components.scss +162 -162
  227. package/assets/sass/_corefiles.scss +31 -31
  228. package/assets/sass/_elements.scss +30 -30
  229. package/assets/sass/_fonts.scss +28 -28
  230. package/assets/sass/_func.scss +2 -2
  231. package/assets/sass/_functions/bs_functions.scss +487 -487
  232. package/assets/sass/_functions/bs_mixins.scss +2103 -2103
  233. package/assets/sass/_functions/bs_utilities.scss +922 -922
  234. package/assets/sass/_functions/bs_variables.scss +1701 -1701
  235. package/assets/sass/_functions/functions.scss +48 -48
  236. package/assets/sass/_functions/mixins.scss +1 -1
  237. package/assets/sass/_grid.scss +320 -320
  238. package/assets/sass/_print.scss +64 -64
  239. package/assets/sass/_utilities.scss +35 -35
  240. package/assets/sass/components/actionbar.component.scss +421 -421
  241. package/assets/sass/components/actionbar.global.scss +115 -115
  242. package/assets/sass/components/address-lookup.component.scss +160 -160
  243. package/assets/sass/components/address-lookup.preload.scss +90 -90
  244. package/assets/sass/components/applied-filters.scss +19 -19
  245. package/assets/sass/components/barchart.component.scss +347 -347
  246. package/assets/sass/components/bento-grid.component.scss +109 -109
  247. package/assets/sass/components/bento-grid.global.scss +248 -248
  248. package/assets/sass/components/calendar.component.scss +1272 -1272
  249. package/assets/sass/components/calendar.config.scss +423 -423
  250. package/assets/sass/components/card.component.scss +187 -187
  251. package/assets/sass/components/card.module.scss +154 -154
  252. package/assets/sass/components/carousel.component.scss +631 -631
  253. package/assets/sass/components/carousel.config.scss +84 -84
  254. package/assets/sass/components/charts.config.scss +86 -86
  255. package/assets/sass/components/charts.module.scss +588 -588
  256. package/assets/sass/components/charts.scss +1298 -1298
  257. package/assets/sass/components/collapsible-side.scss +307 -307
  258. package/assets/sass/components/config.component.scss +235 -235
  259. package/assets/sass/components/content.component.scss +18 -18
  260. package/assets/sass/components/darkmode.component.scss +20 -20
  261. package/assets/sass/components/doughnutchart.component.scss +206 -206
  262. package/assets/sass/components/fileupload.scss +162 -162
  263. package/assets/sass/components/filter-card.component.scss +99 -99
  264. package/assets/sass/components/header.scss +251 -251
  265. package/assets/sass/components/inline-edit.preload.scss +203 -203
  266. package/assets/sass/components/inline-edit.scss +40 -40
  267. package/assets/sass/components/input-range.component.scss +46 -46
  268. package/assets/sass/components/input.component.scss +101 -101
  269. package/assets/sass/components/marketing.component.scss +65 -65
  270. package/assets/sass/components/menu.component.scss +161 -161
  271. package/assets/sass/components/menu.global.scss +82 -82
  272. package/assets/sass/components/milestone.scss +216 -216
  273. package/assets/sass/components/modal.component.scss +252 -252
  274. package/assets/sass/components/multi-step-modal.component.scss +255 -255
  275. package/assets/sass/components/multi-step-modal.global.scss +91 -91
  276. package/assets/sass/components/multi-step.component.scss +144 -144
  277. package/assets/sass/components/multiselect.preload.scss +8 -8
  278. package/assets/sass/components/multiselect.scss +238 -238
  279. package/assets/sass/components/nav.component.scss +718 -718
  280. package/assets/sass/components/nav.docs.scss +55 -55
  281. package/assets/sass/components/nav.global.scss +870 -870
  282. package/assets/sass/components/nav.preload.scss +54 -54
  283. package/assets/sass/components/notification.scss +204 -217
  284. package/assets/sass/components/pagination.scss +237 -237
  285. package/assets/sass/components/password.component.scss +55 -55
  286. package/assets/sass/components/popover.component.scss +28 -28
  287. package/assets/sass/components/property-searchbar.scss +139 -139
  288. package/assets/sass/components/rank.component.scss +275 -275
  289. package/assets/sass/components/rankings.component.scss +70 -70
  290. package/assets/sass/components/rankings.global.scss +140 -140
  291. package/assets/sass/components/rating.component.css +211 -211
  292. package/assets/sass/components/record-card.component.scss +191 -191
  293. package/assets/sass/components/slider.scss +127 -127
  294. package/assets/sass/components/snapshot.scss +65 -65
  295. package/assets/sass/components/split-button.component.scss +83 -83
  296. package/assets/sass/components/stepper.scss +157 -157
  297. package/assets/sass/components/table-basic.component.scss +136 -136
  298. package/assets/sass/components/table-basic.global.scss +676 -676
  299. package/assets/sass/components/table.component.scss +51 -51
  300. package/assets/sass/components/table.global.scss +398 -398
  301. package/assets/sass/components/tabs.component.scss +34 -34
  302. package/assets/sass/components/tabs.config.scss +258 -258
  303. package/assets/sass/components/tag.component.scss +59 -59
  304. package/assets/sass/components/tag.preload.scss +20 -20
  305. package/assets/sass/components/testimonial.scss +125 -125
  306. package/assets/sass/components/timeline.scss +92 -92
  307. package/assets/sass/components/tooltip.component.scss +148 -148
  308. package/assets/sass/components/video-card.component.scss +48 -48
  309. package/assets/sass/components/video-modal.component.scss +26 -26
  310. package/assets/sass/components/video.component.scss +74 -74
  311. package/assets/sass/components/word-count.component.scss +26 -26
  312. package/assets/sass/core.scss +4 -4
  313. package/assets/sass/elements/admin-panel.css +310 -310
  314. package/assets/sass/elements/badge-tag.css +101 -101
  315. package/assets/sass/elements/brand.css +80 -80
  316. package/assets/sass/elements/button__group.css +135 -135
  317. package/assets/sass/elements/buttons--action.css +71 -71
  318. package/assets/sass/elements/buttons--compact.css +168 -168
  319. package/assets/sass/elements/buttons--global.css +239 -239
  320. package/assets/sass/elements/buttons--secondary.css +18 -18
  321. package/assets/sass/elements/buttons--special.css +164 -164
  322. package/assets/sass/elements/buttons--tertiary.css +51 -51
  323. package/assets/sass/elements/buttons.scss +9 -9
  324. package/assets/sass/elements/code.css +45 -45
  325. package/assets/sass/elements/container.scss +118 -118
  326. package/assets/sass/elements/details.css +224 -224
  327. package/assets/sass/elements/dialog.scss +75 -75
  328. package/assets/sass/elements/dropdown.css +85 -85
  329. package/assets/sass/elements/feature.css +174 -174
  330. package/assets/sass/elements/forms.scss +1337 -1337
  331. package/assets/sass/elements/highlight.css +76 -76
  332. package/assets/sass/elements/hr.css +41 -41
  333. package/assets/sass/elements/icons.css +48 -48
  334. package/assets/sass/elements/input.scss +212 -212
  335. package/assets/sass/elements/label.css +20 -20
  336. package/assets/sass/elements/links--collapsible-side.scss +129 -129
  337. package/assets/sass/elements/links--global.scss +155 -155
  338. package/assets/sass/elements/links--video.scss +73 -73
  339. package/assets/sass/elements/links.scss +4 -4
  340. package/assets/sass/elements/lists--breadcrumbs.scss +26 -26
  341. package/assets/sass/elements/lists--steps.css +171 -171
  342. package/assets/sass/elements/lists--tick-list.scss +112 -112
  343. package/assets/sass/elements/lists.scss +99 -99
  344. package/assets/sass/elements/media.css +20 -20
  345. package/assets/sass/elements/modal.scss +411 -411
  346. package/assets/sass/elements/popover.scss +259 -259
  347. package/assets/sass/elements/prefix.scss +139 -139
  348. package/assets/sass/elements/progress.scss +208 -208
  349. package/assets/sass/elements/table.element.scss +144 -144
  350. package/assets/sass/elements/textarea.css +84 -84
  351. package/assets/sass/elements/toggle-button.css +49 -49
  352. package/assets/sass/elements/tooltips.scss +152 -152
  353. package/assets/sass/elements/type.css +166 -166
  354. package/assets/sass/email.scss +68 -68
  355. package/assets/sass/error.scss +31 -31
  356. package/assets/sass/foundations/animations.scss +2 -2
  357. package/assets/sass/foundations/colours.scss +104 -104
  358. package/assets/sass/foundations/reboot.scss +166 -166
  359. package/assets/sass/foundations/root.scss +269 -269
  360. package/assets/sass/main.scss +7 -7
  361. package/assets/sass/templates/auth.scss +106 -106
  362. package/assets/sass/templates/form.scss +95 -95
  363. package/assets/sass/utilities/align.css +24 -24
  364. package/assets/sass/utilities/border.css +65 -65
  365. package/assets/sass/utilities/clearfix.css +8 -8
  366. package/assets/sass/utilities/colours.scss +43 -43
  367. package/assets/sass/utilities/columns.css +61 -61
  368. package/assets/sass/utilities/display.scss +89 -89
  369. package/assets/sass/utilities/fixed.css +16 -16
  370. package/assets/sass/utilities/flex.scss +291 -291
  371. package/assets/sass/utilities/font-awesome-iso-fallbacks.css +43 -43
  372. package/assets/sass/utilities/gap.css +25 -25
  373. package/assets/sass/utilities/gradients.css +39 -39
  374. package/assets/sass/utilities/js-display.css +12 -12
  375. package/assets/sass/utilities/line-clamp.css +24 -24
  376. package/assets/sass/utilities/margins.scss +74 -74
  377. package/assets/sass/utilities/max-height.scss +93 -93
  378. package/assets/sass/utilities/opacity.css +20 -20
  379. package/assets/sass/utilities/order.css +104 -104
  380. package/assets/sass/utilities/overflow.css +16 -16
  381. package/assets/sass/utilities/paddings.scss +33 -33
  382. package/assets/sass/utilities/pointer-events.css +8 -8
  383. package/assets/sass/utilities/position.css +67 -67
  384. package/assets/sass/utilities/ratio.css +33 -33
  385. package/assets/sass/utilities/rounded.css +56 -56
  386. package/assets/sass/utilities/shadow.css +6 -6
  387. package/assets/sass/utilities/sizes.css +92 -92
  388. package/assets/sass/utilities/sticky.css +38 -38
  389. package/assets/sass/utilities/text-truncate.css +6 -6
  390. package/assets/sass/utilities/text.css +190 -190
  391. package/assets/sass/utilities/visible.css +8 -8
  392. package/assets/sass/utilities/visually-hidden.css +13 -13
  393. package/assets/sass/utilities/wider-colours.scss +8 -8
  394. package/assets/svg/illustrations/table.svg +165 -165
  395. package/assets/svg/logo.svg +56 -56
  396. package/assets/ts/components/accordion/accordion.component.ts +77 -77
  397. package/assets/ts/components/actionbar/actionbar.component.ts +567 -567
  398. package/assets/ts/components/address-lookup/address-lookup.component.ts +672 -672
  399. package/assets/ts/components/advanced-select/advanced-select.component.ts +116 -116
  400. package/assets/ts/components/applied-filters/applied-filters.component.ts +37 -37
  401. package/assets/ts/components/bento-grid/bento-grid.component.ts +88 -88
  402. package/assets/ts/components/collapsible-side/collapsible-side.component.ts +165 -165
  403. package/assets/ts/components/config/config.component.ts +699 -699
  404. package/assets/ts/components/content/content.component.ts +78 -78
  405. package/assets/ts/components/darkmode/darkmode.component.ts +108 -108
  406. package/assets/ts/components/fileupload/fileupload.component.ts +74 -74
  407. package/assets/ts/components/filter-card/filter-card.component.ts +106 -106
  408. package/assets/ts/components/form/form.component.ts +102 -102
  409. package/assets/ts/components/header/header.component.ts +97 -97
  410. package/assets/ts/components/inline-edit/inline-edit.component.ts +212 -212
  411. package/assets/ts/components/input/input.component.ts +278 -278
  412. package/assets/ts/components/input-range/input-range.component.ts +78 -78
  413. package/assets/ts/components/marketing/marketing.component.ts +44 -44
  414. package/assets/ts/components/menu/menu.component.ts +212 -212
  415. package/assets/ts/components/modal/modal.component.ts +184 -184
  416. package/assets/ts/components/multi-step-modal/multi-step-modal.component.ts +304 -304
  417. package/assets/ts/components/multiselect/multiselect.component.ts +349 -349
  418. package/assets/ts/components/nav/nav.component.ts +369 -369
  419. package/assets/ts/components/notification/notification.component.ts +173 -172
  420. package/assets/ts/components/pagination/pagination.component.ts +213 -213
  421. package/assets/ts/components/password/password.component.ts +118 -118
  422. package/assets/ts/components/popover/popover.component.ts +50 -50
  423. package/assets/ts/components/rank/rank.component.ts +394 -394
  424. package/assets/ts/components/rankings/rankings.component.ts +79 -79
  425. package/assets/ts/components/rating/rating.component.ts +86 -86
  426. package/assets/ts/components/search/search.component.ts +244 -244
  427. package/assets/ts/components/slider/slider.component.ts +170 -170
  428. package/assets/ts/components/split-button/split-button.component.ts +63 -63
  429. package/assets/ts/components/std-address-lookup/std-address-lookup.component.ts +1919 -1919
  430. package/assets/ts/components/table/table.component.ts +94 -94
  431. package/assets/ts/components/table-ajax/table-ajax.component.ts +70 -70
  432. package/assets/ts/components/table-basic/table-basic.component.ts +56 -56
  433. package/assets/ts/components/table-no-submit/table-no-submit.component.ts +130 -130
  434. package/assets/ts/components/table-submit/table-submit.component.ts +71 -71
  435. package/assets/ts/components/tabs/tabs.component.ts +70 -70
  436. package/assets/ts/components/tag/tag.component.ts +104 -104
  437. package/assets/ts/components/tooltip/tooltip.component.ts +98 -98
  438. package/assets/ts/components/video/video.component.ts +74 -74
  439. package/assets/ts/components/video-card/video-card.component.ts +129 -129
  440. package/assets/ts/components/video-modal/video-modal.component.ts +88 -88
  441. package/assets/ts/modules/advanced-select.ts +186 -186
  442. package/assets/ts/modules/applied-filters.ts +238 -238
  443. package/assets/ts/modules/card.module.ts +46 -46
  444. package/assets/ts/modules/chart.module.ts +594 -594
  445. package/assets/ts/modules/data-layer.md +71 -71
  446. package/assets/ts/modules/dialogs.ts +259 -259
  447. package/assets/ts/modules/dropdown.ts +216 -216
  448. package/assets/ts/modules/helper.test.ts +143 -143
  449. package/assets/ts/modules/helpers.ts +212 -212
  450. package/assets/ts/modules/integration-tests.ts +525 -525
  451. package/assets/ts/modules/modal.ts +45 -45
  452. package/assets/ts/modules/password.ts +82 -82
  453. package/assets/ts/modules/table.ts +1500 -1500
  454. package/assets/ts/modules/test.ts +22 -22
  455. package/assets/ts/modules/videos.ts +233 -233
  456. package/assets/ts/scripts.ts +111 -111
  457. package/dist/components.es.js +24 -24
  458. package/dist/components.umd.js +3 -2
  459. package/package.json +115 -115
  460. package/src/components/AdvancedSelect/AdvancedSelect.vue +28 -28
  461. package/src/components/Config/Config.vue +23 -23
  462. package/src/components/DarkMode/DarkMode.vue +19 -19
  463. package/src/components/Filterlist/Filterlist.vue +23 -23
  464. package/src/components/Form/Form.vue +22 -22
  465. package/src/components/Header/Header.vue +36 -36
  466. package/src/components/Input/Input.vue +22 -22
  467. package/src/components/InputRange/InputRange.vue +22 -22
  468. package/src/components/Modal/Modal.vue +22 -22
  469. package/src/components/MultiStepModal/MultiStepModal.vue +23 -23
  470. package/src/components/NoteFeed/NoteFeed.vue +82 -82
  471. package/src/components/Password/Password.vue +23 -23
  472. package/src/components/Popover/Popover.vue +22 -22
  473. package/src/components/PropertySearchbar/PropertySearchbar.vue +235 -235
  474. package/src/components/PropertySearchbar/README.md +25 -25
  475. package/src/components/Rating/Rating.vue +22 -22
  476. package/src/components/STDAddressLookup/STDAddressLookup.vue +22 -22
  477. package/src/components/Snapshot/Snapshot.vue +30 -30
  478. package/src/components/Tag/Tag.vue +22 -22
  479. package/src/components/Tooltip/Tooltip.vue +22 -22
  480. package/src/components/Video/Video.vue +22 -22
  481. package/src/components/VideoModal/VideoModal.vue +22 -22
  482. package/assets/bootstrap/dist/css/bootstrap-grid.css +0 -4124
  483. package/assets/bootstrap/dist/css/bootstrap-grid.css.map +0 -1
  484. package/assets/bootstrap/dist/css/bootstrap-grid.min.css +0 -7
  485. package/assets/bootstrap/dist/css/bootstrap-grid.min.css.map +0 -1
  486. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.css +0 -4123
  487. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.css.map +0 -1
  488. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.min.css +0 -7
  489. package/assets/bootstrap/dist/css/bootstrap-grid.rtl.min.css.map +0 -1
  490. package/assets/bootstrap/dist/css/bootstrap-reboot.css +0 -488
  491. package/assets/bootstrap/dist/css/bootstrap-reboot.css.map +0 -1
  492. package/assets/bootstrap/dist/css/bootstrap-reboot.min.css +0 -7
  493. package/assets/bootstrap/dist/css/bootstrap-reboot.min.css.map +0 -1
  494. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.css +0 -485
  495. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.css.map +0 -1
  496. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.min.css +0 -7
  497. package/assets/bootstrap/dist/css/bootstrap-reboot.rtl.min.css.map +0 -1
  498. package/assets/bootstrap/dist/css/bootstrap-utilities.css +0 -4197
  499. package/assets/bootstrap/dist/css/bootstrap-utilities.css.map +0 -1
  500. package/assets/bootstrap/dist/css/bootstrap-utilities.min.css +0 -7
  501. package/assets/bootstrap/dist/css/bootstrap-utilities.min.css.map +0 -1
  502. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.css +0 -4188
  503. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.css.map +0 -1
  504. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.min.css +0 -7
  505. package/assets/bootstrap/dist/css/bootstrap-utilities.rtl.min.css.map +0 -1
  506. package/assets/bootstrap/dist/css/bootstrap.css +0 -10907
  507. package/assets/bootstrap/dist/css/bootstrap.css.map +0 -1
  508. package/assets/bootstrap/dist/css/bootstrap.min.css +0 -7
  509. package/assets/bootstrap/dist/css/bootstrap.min.css.map +0 -1
  510. package/assets/bootstrap/dist/css/bootstrap.rtl.css +0 -10867
  511. package/assets/bootstrap/dist/css/bootstrap.rtl.css.map +0 -1
  512. package/assets/bootstrap/dist/css/bootstrap.rtl.min.css +0 -7
  513. package/assets/bootstrap/dist/css/bootstrap.rtl.min.css.map +0 -1
  514. package/assets/bootstrap/dist/js/bootstrap.bundle.js +0 -7066
  515. package/assets/bootstrap/dist/js/bootstrap.bundle.js.map +0 -1
  516. package/assets/bootstrap/dist/js/bootstrap.bundle.min.js +0 -7
  517. package/assets/bootstrap/dist/js/bootstrap.bundle.min.js.map +0 -1
  518. package/assets/bootstrap/dist/js/bootstrap.esm.js +0 -5204
  519. package/assets/bootstrap/dist/js/bootstrap.esm.js.map +0 -1
  520. package/assets/bootstrap/dist/js/bootstrap.esm.min.js +0 -7
  521. package/assets/bootstrap/dist/js/bootstrap.esm.min.js.map +0 -1
  522. package/assets/bootstrap/dist/js/bootstrap.js +0 -5251
  523. package/assets/bootstrap/dist/js/bootstrap.js.map +0 -1
  524. package/assets/bootstrap/dist/js/bootstrap.min.js +0 -7
  525. package/assets/bootstrap/dist/js/bootstrap.min.js.map +0 -1
  526. package/assets/bootstrap/js/dist/alert.js +0 -100
  527. package/assets/bootstrap/js/dist/alert.js.map +0 -1
  528. package/assets/bootstrap/js/dist/base-component.js +0 -100
  529. package/assets/bootstrap/js/dist/base-component.js.map +0 -1
  530. package/assets/bootstrap/js/dist/button.js +0 -82
  531. package/assets/bootstrap/js/dist/button.js.map +0 -1
  532. package/assets/bootstrap/js/dist/carousel.js +0 -471
  533. package/assets/bootstrap/js/dist/carousel.js.map +0 -1
  534. package/assets/bootstrap/js/dist/collapse.js +0 -311
  535. package/assets/bootstrap/js/dist/collapse.js.map +0 -1
  536. package/assets/bootstrap/js/dist/dom/data.js +0 -67
  537. package/assets/bootstrap/js/dist/dom/data.js.map +0 -1
  538. package/assets/bootstrap/js/dist/dom/event-handler.js +0 -284
  539. package/assets/bootstrap/js/dist/dom/event-handler.js.map +0 -1
  540. package/assets/bootstrap/js/dist/dom/manipulator.js +0 -85
  541. package/assets/bootstrap/js/dist/dom/manipulator.js.map +0 -1
  542. package/assets/bootstrap/js/dist/dom/selector-engine.js +0 -86
  543. package/assets/bootstrap/js/dist/dom/selector-engine.js.map +0 -1
  544. package/assets/bootstrap/js/dist/dropdown.js +0 -471
  545. package/assets/bootstrap/js/dist/dropdown.js.map +0 -1
  546. package/assets/bootstrap/js/dist/modal.js +0 -397
  547. package/assets/bootstrap/js/dist/modal.js.map +0 -1
  548. package/assets/bootstrap/js/dist/offcanvas.js +0 -298
  549. package/assets/bootstrap/js/dist/offcanvas.js.map +0 -1
  550. package/assets/bootstrap/js/dist/popover.js +0 -102
  551. package/assets/bootstrap/js/dist/popover.js.map +0 -1
  552. package/assets/bootstrap/js/dist/scrollspy.js +0 -308
  553. package/assets/bootstrap/js/dist/scrollspy.js.map +0 -1
  554. package/assets/bootstrap/js/dist/tab.js +0 -334
  555. package/assets/bootstrap/js/dist/tab.js.map +0 -1
  556. package/assets/bootstrap/js/dist/toast.js +0 -237
  557. package/assets/bootstrap/js/dist/toast.js.map +0 -1
  558. package/assets/bootstrap/js/dist/tooltip.js +0 -663
  559. package/assets/bootstrap/js/dist/tooltip.js.map +0 -1
  560. package/assets/bootstrap/js/dist/util/backdrop.js +0 -166
  561. package/assets/bootstrap/js/dist/util/backdrop.js.map +0 -1
  562. package/assets/bootstrap/js/dist/util/component-functions.js +0 -47
  563. package/assets/bootstrap/js/dist/util/component-functions.js.map +0 -1
  564. package/assets/bootstrap/js/dist/util/config.js +0 -80
  565. package/assets/bootstrap/js/dist/util/config.js.map +0 -1
  566. package/assets/bootstrap/js/dist/util/focustrap.js +0 -130
  567. package/assets/bootstrap/js/dist/util/focustrap.js.map +0 -1
  568. package/assets/bootstrap/js/dist/util/index.js +0 -351
  569. package/assets/bootstrap/js/dist/util/index.js.map +0 -1
  570. package/assets/bootstrap/js/dist/util/sanitizer.js +0 -123
  571. package/assets/bootstrap/js/dist/util/sanitizer.js.map +0 -1
  572. package/assets/bootstrap/js/dist/util/scrollbar.js +0 -139
  573. package/assets/bootstrap/js/dist/util/scrollbar.js.map +0 -1
  574. package/assets/bootstrap/js/dist/util/swipe.js +0 -156
  575. package/assets/bootstrap/js/dist/util/swipe.js.map +0 -1
  576. package/assets/bootstrap/js/dist/util/template-factory.js +0 -178
  577. package/assets/bootstrap/js/dist/util/template-factory.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"actionbar.component.min.js","sources":["../../modules/helpers.js","../menu/menu.component.js","actionbar.component.js"],"sourcesContent":["/**\n * Global helper functions to help maintain and enhance framework elements.\n * @module Helpers\n */\n/**\n * Add global classes used by the CSS and later JavaScript.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addBodyClasses = (body) => {\n body.classList.add('js-enabled');\n if (navigator.userAgent.indexOf('MSIE') !== -1 || navigator.appVersion.indexOf('Trident/') > 0) {\n body.classList.add('ie');\n }\n};\n/**\n * Add global events.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addGlobalEvents = (body) => {\n const checkElements = function (hash) {\n const label = document.querySelector(`label[for=\"${hash.replace('#', '')}\"]`);\n const summary = document.querySelector(hash + ' summary');\n const dialog = document.querySelector(`dialog${hash}`);\n const detail = document.querySelector(`detail${hash}`);\n if (label instanceof HTMLElement)\n label.click();\n else if (summary instanceof HTMLElement)\n summary.click();\n else if (dialog instanceof HTMLElement)\n dialog.showModal();\n else if (detail instanceof HTMLElement)\n detail.addAttribute('open');\n };\n if (location.hash)\n checkElements(location.hash);\n window.addEventListener('hashchange', function () {\n checkElements(location.hash);\n }, false);\n addEventListener('popstate', (event) => {\n if (event && event.state && event.state.type && event.state.type == 'pagination') {\n const form = document.querySelector(`#${event.state.form}`);\n const pageInput = document.querySelector(`#${event.state.form} [data-pagination]`);\n if (pageInput)\n pageInput.value = event.state.page;\n else\n form.innerHTML += `<input name=\"page\" type=\"hidden\" data-pagination=\"true\" value=\"${event.state.page}\" />`;\n form.dispatchEvent(new Event('submit'));\n }\n });\n Array.from(document.querySelectorAll('form')).forEach((form) => {\n if (!(form === null || form === void 0 ? void 0 : form.closest('iam-form'))) {\n form.addEventListener('submit', (event) => {\n var _a;\n if (form.querySelector(':invalid')) {\n form.classList.add('was-validated');\n (_a = form === null || form === void 0 ? void 0 : form.querySelector('input:invalid')) === null || _a === void 0 ? void 0 : _a.scrollIntoView();\n event.preventDefault();\n }\n });\n }\n });\n document.addEventListener('click', (event) => {\n var _a;\n if (event && event.target instanceof HTMLElement && event.target.matches('form button:not([type=button])')) {\n const form = event.target.closest('form');\n if (!(form === null || form === void 0 ? void 0 : form.closest('iam-form'))) {\n // Reset password types\n Array.from(form.querySelectorAll('[data-password-type]')).forEach((input) => {\n input.setAttribute('type', 'password');\n });\n if (form.querySelector(':invalid') ||\n form.querySelector('.pwd-checker[data-strength=\"1\"]') ||\n form.querySelector('.pwd-checker[data-strength=\"2\"]')) {\n form.classList.add('was-validated');\n (_a = form === null || form === void 0 ? void 0 : form.querySelector('input:invalid')) === null || _a === void 0 ? void 0 : _a.scrollIntoView();\n event.preventDefault();\n }\n if (form.querySelector('iam-multiselect[data-is-required][data-error]')) {\n form.classList.add('was-validated');\n event.preventDefault();\n }\n }\n }\n });\n document.addEventListener('keydown', (e) => {\n if (e.key === 'Escape') {\n if (document.querySelector('.dialog--transactional[open], .dialog--acknowledgement[open]')) {\n e.preventDefault();\n e.stopPropagation();\n }\n }\n });\n Array.from(document.querySelectorAll('label progress')).forEach((progress) => {\n const label = progress.closest('label');\n label.setAttribute('data-percent', progress.getAttribute('value'));\n });\n};\nexport const isNumeric = function (str) {\n if (typeof str != 'string')\n return false; // we only process strings!\n return (!isNaN(str) && // use type coercion to parse the _entirety_ of the string (`parseFloat` alone does not do this)...\n !isNaN(parseFloat(str))); // ...and ensure strings of whitespace fail\n};\nexport const zeroPad = (num, places) => String(num).padStart(places, '0');\nexport const ucfirst = (str) => str.charAt(0).toUpperCase() + str.slice(1);\nexport const ucwords = (str) => str\n .split(' ')\n .map((s) => ucfirst(s))\n .join(' ');\nexport const unsnake = (str) => str.replace(/_/g, ' ');\nexport const snake = (str) => str.replace(/ /g, '_');\nexport const safeID = function (str) {\n str = str.toLowerCase();\n str = snake(str);\n str = str.replace(/\\W/g, '');\n return str;\n};\nexport const numberOfDays = function (startDateString, endDateString) {\n const convertStart = startDateString.split('/');\n const convertEnd = endDateString.split('/');\n const dateStart = new Date(convertStart[1] + '/' + convertStart[0] + '/' + convertStart[2]);\n const dateEnd = new Date(convertEnd[1] + '/' + convertEnd[0] + '/' + convertEnd[2]);\n if (dateStart == 'Invalid Date')\n throw 'Start date is not a valid date';\n if (dateEnd == 'Invalid Date')\n throw 'End date is not a valid date';\n // To calculate the time difference of two dates\n const diffTime = dateEnd.getTime() - dateStart.getTime();\n const numberOfDays = diffTime / (1000 * 3600 * 24) + 1;\n if (numberOfDays < 0)\n throw 'The start date should be before the end date';\n return numberOfDays;\n};\n// Used to get values from nested json objects\nexport const resolvePath = (object, path, defaultValue) => path\n // eslint-disable-next-line no-useless-escape\n .split(/[\\.\\[\\]\\'\\\"]/)\n .filter((p) => p)\n .reduce((o, p) => (o ? o[p] : defaultValue), object);\nexport const isTraversable = (o) => Array.isArray(o) || (o !== null && ['function', 'object'].includes(typeof o));\nexport const getSwipeDirection = (touchstartX, touchstartY, touchendX, touchendY) => {\n const limit = Math.tan(((45 * 1.5) / 180) * Math.PI);\n const pageWidth = window.innerWidth || document.body.clientWidth;\n const treshold = Math.max(1, Math.floor(0.01 * pageWidth));\n const x = touchendX - touchstartX;\n const y = touchendY - touchstartY;\n const xy = Math.abs(x / y);\n const yx = Math.abs(y / x);\n if (Math.abs(x) > treshold || Math.abs(y) > treshold) {\n if (yx <= limit) {\n if (x < 0) {\n return 'left';\n }\n else {\n return 'right';\n }\n }\n if (xy <= limit) {\n if (y < 0) {\n return 'top';\n }\n else {\n return 'bottom';\n }\n }\n }\n else {\n return 'tap';\n }\n};\nexport const uniqueID = (index = 1) => {\n const ID = Math.floor(Math.random() * Date.now() * (index + 1));\n return ID;\n};\nexport const isValidPostcode = (searchValue) => {\n const regexp = /^([A-Z][A-HJ-Y]?[0-9][A-Z0-9]? ?[0-9][A-Z]{2}|GIR ?0A{2})$/gmi;\n return regexp.test(searchValue.trim());\n};\n","class iamMenu extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n const assetLocation = document.body.hasAttribute('data-assets-location')\n ? document.body.getAttribute('data-assets-location')\n : '/assets';\n const menuCSS = `@import \"${assetLocation}/css/components/menu.component.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\r\n <style>\r\n ${menuCSS}\r\n </style>\r\n <div class=\"menu--inner\" part=\"inner\">\r\n <slot></slot>\r\n </div>`;\n this.shadowRoot.appendChild(template.content.cloneNode(true));\n }\n connectedCallback() {\n const menuID = this.hasAttribute('id') ? this.getAttribute('id') : false;\n const menuButton = document.querySelector(`[popovertarget=\"${menuID}\"]`);\n let topLevelmenuItems = this.querySelectorAll(':scope > a, :scope > button, :scope > details > summary');\n let menuItems = this.querySelectorAll('a, button');\n if (this.closest('.menu__wrapper')) {\n menuItems = this.shadowRoot.querySelector('slot').assignedElements({ flatten: true });\n topLevelmenuItems = menuItems;\n }\n const subMenus = this.querySelectorAll('details');\n let subNextIndex;\n let subPrevIndex;\n // Set the needed CSS styles to connect the ID attribute to the anchor name\n if (menuID && menuButton) {\n this.setAttribute('role', 'menu');\n this.setAttribute('popover', 'auto');\n this.style['position-anchor'] = `--${menuID}`;\n menuButton === null || menuButton === void 0 ? void 0 : menuButton.setAttribute('aria-haspopup', 'true');\n menuButton === null || menuButton === void 0 ? void 0 : menuButton.style['anchor-name'] = `--${menuID}`;\n menuButton === null || menuButton === void 0 ? void 0 : menuButton.setAttribute('aria-controls', menuID);\n }\n menuItems.forEach((item, index) => {\n item.setAttribute('role', 'menuitem');\n item.setAttribute('tabindex', '0');\n if (index == 0) {\n item.setAttribute('autofocus', true);\n }\n });\n this.addEventListener('keydown', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('a, button, summary')) {\n const activeItem = document.activeElement;\n const prevIndex = Array.from(topLevelmenuItems).indexOf(activeItem) - 1;\n const nextIndex = Array.from(topLevelmenuItems).indexOf(activeItem) + 1;\n switch (event.keyCode // change to event.key to key to use the above variable\n ) {\n case 27: // Esc\n if (activeItem.closest('details')) {\n event.stopPropagation();\n event.preventDefault();\n activeItem.closest('details').removeAttribute('open');\n activeItem.closest('details').querySelector(':scope summary').focus();\n }\n else {\n event.stopPropagation();\n menuButton.focus();\n }\n break;\n case 32: // Space\n case 13: // Enter\n break;\n case 35: // end\n event.stopPropagation();\n event.preventDefault();\n this.querySelector('details[open]').removeAttribute('open');\n Array.from(menuItems)[menuItems.length - 1].focus();\n break;\n case 36: // home\n event.stopPropagation();\n event.preventDefault();\n this.querySelector('details[open]').removeAttribute('open');\n Array.from(menuItems)[0].focus();\n break;\n case 38: // up\n event.stopPropagation();\n event.preventDefault();\n if (Array.from(topLevelmenuItems).indexOf(activeItem) > -1) {\n if (Array.from(topLevelmenuItems)[prevIndex] != undefined)\n Array.from(topLevelmenuItems)[prevIndex].focus();\n else\n Array.from(topLevelmenuItems)[topLevelmenuItems.length - 1].focus();\n }\n else if (activeItem.closest('details')) {\n const subMenuItems = activeItem\n .closest('details')\n .querySelectorAll('a, button, :scope details > summary');\n subPrevIndex = Array.from(subMenuItems).indexOf(activeItem) - 1;\n if (Array.from(subMenuItems)[subPrevIndex] != undefined)\n Array.from(subMenuItems)[subPrevIndex].focus();\n else\n Array.from(subMenuItems)[subMenuItems.length - 1].focus();\n }\n break;\n case 40: // down\n event.stopPropagation();\n event.preventDefault();\n if (Array.from(topLevelmenuItems).indexOf(activeItem) > -1) {\n if (Array.from(topLevelmenuItems)[nextIndex] != undefined)\n Array.from(topLevelmenuItems)[nextIndex].focus();\n else\n Array.from(topLevelmenuItems)[0].focus();\n }\n else if (activeItem.closest('details')) {\n const subMenuItems = activeItem\n .closest('details')\n .querySelectorAll('a, button, :scope details > summary');\n subNextIndex = Array.from(subMenuItems).indexOf(activeItem) + 1;\n if (Array.from(subMenuItems)[subNextIndex] != undefined)\n Array.from(subMenuItems)[subNextIndex].focus();\n else\n Array.from(subMenuItems)[0].focus();\n }\n break;\n }\n }\n });\n this.addEventListener('toggle', (e) => {\n var _a, _b, _c, _d;\n const updateEvent = new CustomEvent(e.newState, { detail: { id: this.getAttribute('id'), target: e.target } });\n this.dispatchEvent(updateEvent);\n // Fix the focus\n if (this.closest('.menu__wrapper')) {\n menuItems[0].focus();\n }\n if (this.hasAttribute('popover-open')) {\n e.preventDefault();\n this.removeAttribute('popover-open');\n this.hidePopover();\n }\n if (this.matches(':popover-open') && document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) {\n (_a = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _a === void 0 ? void 0 : _a.setAttribute('aria-pressed', 'true');\n (_b = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _b === void 0 ? void 0 : _b.classList.add('active');\n }\n else {\n (_c = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _c === void 0 ? void 0 : _c.removeAttribute('aria-pressed');\n (_d = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _d === void 0 ? void 0 : _d.classList.remove('active');\n }\n });\n this.addEventListener('click', (event) => {\n if (event &&\n event.target instanceof HTMLElement &&\n event.target.closest('button:has(+ iam-menu:not([popover]))')) {\n const button = event.target.closest('button:has(+ iam-menu)');\n button === null || button === void 0 ? void 0 : button.classList.toggle('open');\n }\n else if (event && event.target instanceof HTMLElement && event.target.closest('button.selectable')) {\n const button = event.target.closest('button.selectable');\n if (this.hasAttribute('multiple')) {\n button.classList.toggle('selected');\n }\n else if (button === null || button === void 0 ? void 0 : button.classList.contains('selected')) {\n this.querySelectorAll('.selected').forEach((item) => {\n item.classList.remove('selected');\n });\n }\n else {\n this.querySelectorAll('.selected').forEach((item) => {\n item.classList.remove('selected');\n });\n button.classList.add('selected');\n }\n }\n });\n // safari and firefox anchor fix for cards\n if (!CSS.supports('top', 'anchor(top)')) {\n document.addEventListener('click', (event) => {\n if (event.originalTarget && event.originalTarget.matches('[popovertarget]')) {\n const button = event.originalTarget;\n const popoverID = button.getAttribute('popovertarget');\n const popover = document.getElementById(popoverID);\n const viewportOffset = button.getBoundingClientRect();\n const top = viewportOffset.top;\n const left = viewportOffset.left;\n popover.style.setProperty('top', top + 'px');\n popover.style.setProperty('left', left + button.clientWidth + 'px');\n }\n });\n }\n }\n}\nexport default iamMenu;\n","import { uniqueID } from '../../modules/helpers';\nimport iamMenu from '../menu/menu.component';\nwindow.dataLayer = window.dataLayer || [];\nwindow.dataLayer.push({\n event: 'customElementRegistered',\n element: 'action bar',\n});\nfunction setSelectAllInput(element, value) {\n if (element && value == 'all') {\n element.querySelector('input').indeterminate = false;\n element.querySelector('input').checked = true;\n element.querySelector('label').textContent = `Select all`;\n }\n else if (element && value == 0) {\n element.querySelector('input').indeterminate = false;\n element.querySelector('input').checked = false;\n element.querySelector('label').textContent = `Select all`;\n }\n else if (element && value) {\n element.querySelector('input').indeterminate = true;\n element.querySelector('input').checked = false;\n element.querySelector('label').textContent = `${value} item${value > 1 ? 's' : ''} selected`;\n }\n else if (element) {\n element.querySelector('input').checked = false;\n element.querySelector('input').indeterminate = false;\n element.querySelector('label').textContent = `Select all`;\n }\n}\nclass iamActionbar extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n const assetLocation = document.body.hasAttribute('data-assets-location')\n ? document.body.getAttribute('data-assets-location')\n : '/assets';\n if (!window.customElements.get(`iam-menu`))\n window.customElements.define(`iam-menu`, iamMenu);\n const loadCSS = `@import \"${assetLocation}/css/components/actionbar.component.css\";`;\n const loadExtraCSS = `@import \"${assetLocation}/css/components/actionbar.global.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\r\n <style>\r\n ${loadCSS}\r\n ${this.hasAttribute('css') ? `@import \"${this.getAttribute('css')}\";` : ``}\r\n </style>\r\n <link rel=\"stylesheet\" href=\"https://kit.fontawesome.com/8bd0fca975.css\" crossorigin=\"anonymous\">\r\n <div class=\"actionbar__wrapper\">\r\n \r\n <div class=\"actionbar\" part=\"actionbar\">\r\n <slot name=\"selectall\"></slot>\r\n <slot name=\"filters\"></slot>\r\n <div class=\"safe-area\">\r\n <slot></slot>\r\n <div class=\"body\">\r\n <div class=\"menu__wrapper menu__wrapper --right dialog-overflow d-none show\">\r\n <button class=\"btn btn-secondary btn-compact btn-sm fa-ellipsis-vertical m-0\" popovertarget=\"overflow\" style=\"anchor-name: --anchor-overflow;\">More actions</button>\r\n <iam-menu class=\"dialog--list\" part=\"overflow\" id=\"overflow\" style=\"position-anchor: --anchor-overflow;\" popover>\r\n <slot name=\"overflow\"></slot>\r\n <slot name=\"menu\"></slot>\r\n </iam-menu>\r\n </div>\r\n\r\n\r\n <div class=\"menu__wrapper menu__wrapper --right filter-columns\">\r\n <button class=\"btn btn-secondary btn-compact btn-sm mb-0 me-0 fa-regular fa-table-columns\" title=\"Select colums\" popovertarget=\"filter\" style=\"anchor-name: --anchor-filter;\">Filter</button>\r\n <iam-menu class=\"dialog--list\" id=\"filter\" style=\"position-anchor: --anchor-filter;\" popover>\r\n <div class=\"pb-0 mb-0 checklists\">\r\n \r\n </div>\r\n <div class=\"text-right checklist-btns\"><button id=\"cancelColumns\" class=\"btn btn-action\">Cancel</button><button id=\"saveColumns\" class=\"btn btn-action btn-secondary\">Save</button></div>\r\n </iam-menu>\r\n </div>\r\n\r\n <button class=\"btn btn-secondary btn-compact btn-sm fa-search\" data-search=\"\" part=\"search-btn\">Search</button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"actionbar--selected\">\r\n <div class=\"safe-area\">\r\n <slot name=\"selected\"></slot>\r\n <div class=\"body\">\r\n <div class=\"menu__wrapper menu__wrapper --right dialog-overflow d-none show\">\r\n <button class=\"btn btn-secondary btn-compact btn-sm fa-ellipsis-vertical m-0\" popovertarget=\"selected-overflow\" style=\"anchor-name: --anchor-selected-overflow;\">More actions</button>\r\n <iam-menu class=\"dialog--list\" part=\"selected-overflow\" id=\"selected-overflow\" style=\"position-anchor: --anchor-selected-overflow;\" popover>\r\n <slot name=\"selected-overflow\"></slot>\r\n </iam-menu>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"actionbar--search\">\r\n <button data-search class=\"btn btn-compact fa-xmark-large btn-secondary mb-0\" >Close</button>\r\n\r\n <div class=\"search-wrapper\" part=\"search\">\r\n <label for=\"search\" class=\"visually-hidden\">Input field label</label>\r\n <button class=\"suffix\" part=\"search-btn\"><i class=\"fa-regular fa-search\"></i></button>\r\n <input type=\"text\" id=\"search\" name=\"search\" required=\"\" part=\"search-input\">\r\n <button class=\"empty btn btn-action\"><i class=\"fa-light fa-times me-0\" aria-hidden=\"true\"></i></button>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n <div class=\"no-columns\">\r\n <span class=\"d-block\">No columns selected</span>\r\n </div>\r\n `;\n this.shadowRoot.appendChild(template.content.cloneNode(true));\n // insert extra CSS\n if (!document.getElementById('actionbarGlobal'))\n document.head.insertAdjacentHTML('beforeend', `<style id=\"actionbarGlobal\">${loadExtraCSS}</style>`);\n }\n connectedCallback() {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;\n const actionbarWrapper = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.actionbar__wrapper');\n const checklistHolder = (_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.checklists');\n const assetLocation = document.body.hasAttribute('data-assets-location')\n ? document.body.getAttribute('data-assets-location')\n : '/assets';\n const dialog = this.querySelector('.dialog__wrapper dialog');\n // Transform dialog into a menu custom element\n if (dialog) {\n const btn = dialog.parentElement.querySelector('.btn');\n const id = `menu${uniqueID(1)}`;\n dialog.setAttribute('id', id);\n dialog.setAttribute('popover', 'auto');\n btn.setAttribute('popovertarget', id);\n dialog.outerHTML = dialog.outerHTML.replace(/<dialog/g, '<iam-menu').replace(/<\\/dialog>/g, '</iam-menu>');\n (_c = dialog.parentElement) === null || _c === void 0 ? void 0 : _c.classList.add('menu__wrapper');\n (_d = dialog.parentElement) === null || _d === void 0 ? void 0 : _d.classList.remove('dialog__wrapper');\n }\n // #region select all\n if (this.hasAttribute('data-selectall')) {\n actionbarWrapper === null || actionbarWrapper === void 0 ? void 0 : actionbarWrapper.insertAdjacentHTML('afterbegin', `<div class=\"selectall pb-0\"><input type=\"checkbox\" name=\"selectall\" id=\"selectall\"><label for=\"selectall\" class=\"m-0\">Select all</label></div>`);\n const selectAll = (_e = this.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('.selectall');\n if (this.hasAttribute('data-selected')) {\n setSelectAllInput(selectAll, this.getAttribute('data-selected'));\n }\n selectAll === null || selectAll === void 0 ? void 0 : selectAll.addEventListener('change', (event) => {\n var _a;\n if (event && event.target instanceof HTMLElement && event.target.closest('input')) {\n if ((_a = event.target.closest('input')) === null || _a === void 0 ? void 0 : _a.checked)\n this.setAttribute('data-selected', 'all');\n else\n this.setAttribute('data-selected', '0');\n }\n });\n const cancelButton = this.querySelector('button[data-cancel]');\n if (cancelButton) {\n cancelButton.addEventListener('click', () => {\n this.setAttribute('data-selected', '0');\n });\n }\n }\n // Wtach div for the select inputs\n if (this.hasAttribute('data-select-watch')) {\n const element = document.getElementById(this.getAttribute('data-select-watch'));\n element === null || element === void 0 ? void 0 : element.setAttribute('data-select-container', 'true');\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n (_a = input.parentElement) === null || _a === void 0 ? void 0 : _a.setAttribute('slot', 'checkbox');\n });\n element === null || element === void 0 ? void 0 : element.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('[type=\"checkbox\"]')) {\n const count = element.querySelectorAll('input[type=\"checkbox\"]').length;\n const countChecked = element.querySelectorAll('input[type=\"checkbox\"]:checked').length;\n this.setAttribute('data-selected', count == countChecked ? 'all' : String(countChecked));\n if (countChecked) {\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.setAttribute('data-selected', 'true');\n });\n }\n else {\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.removeAttribute('data-selected');\n });\n }\n }\n });\n }\n // #endregion\n // #region switchviews\n if (this.hasAttribute('data-switchviews')) {\n let btns = '';\n const viewList = (_f = this.getAttribute('data-switchviews')) === null || _f === void 0 ? void 0 : _f.split(',');\n viewList === null || viewList === void 0 ? void 0 : viewList.forEach((view) => {\n let icon = 'fa-grid';\n if (view == 'list')\n icon = 'fa-list';\n else if (view == 'small')\n icon = 'fa-table';\n btns += `<button class=\"tag tag--toggle mb-0\" data-view=\"${view}\"><i class=\"fa-regular ${icon} m-0\"></i><span class=\"visually-hidden\">${view}</span></button>`;\n });\n actionbarWrapper === null || actionbarWrapper === void 0 ? void 0 : actionbarWrapper.insertAdjacentHTML('afterbegin', `<div class=\"views m-0\">${btns}</div>`);\n const views = (_g = this.shadowRoot) === null || _g === void 0 ? void 0 : _g.querySelector('.views');\n views === null || views === void 0 ? void 0 : views.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('.tag--toggle')) {\n const btn = event.target.closest('.tag--toggle');\n this.setAttribute('data-view', btn.textContent);\n const switchEvent = new CustomEvent('switch-view', { detail: { view: btn.textContent } });\n this.dispatchEvent(switchEvent);\n }\n });\n }\n // #endregion\n // #region search\n const searchBar = (_h = this.shadowRoot) === null || _h === void 0 ? void 0 : _h.querySelector('.actionbar--search');\n if (this.hasAttribute('data-search-value')) {\n ((_j = this.shadowRoot) === null || _j === void 0 ? void 0 : _j.querySelector('#search')).value = String(this.getAttribute('data-search-value'));\n }\n if (this.hasAttribute('data-search') && this.getAttribute('data-search') == 'show')\n searchBar === null || searchBar === void 0 ? void 0 : searchBar.classList.add('show');\n const searchBtn = this.shadowRoot.querySelector('button[data-search]');\n this.shadowRoot.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('button[data-search]')) {\n searchBar.classList.toggle('show');\n searchBtn.toggleAttribute('aria-expanded');\n searchInput.focus();\n }\n });\n searchBar.addEventListener('keyup', () => {\n const keyupEvent = new CustomEvent('search-keyup', {\n detail: { search: searchBar.querySelector('input').value },\n });\n this.dispatchEvent(keyupEvent);\n });\n searchBar.addEventListener('change', () => {\n const changeEvent = new CustomEvent('search-change', {\n detail: { search: searchBar.querySelector('input').value },\n });\n this.dispatchEvent(changeEvent);\n });\n searchBar.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('button.suffix')) {\n const submitEvent = new CustomEvent('search-submit', {\n detail: { search: searchBar.querySelector('input').value },\n });\n this.dispatchEvent(submitEvent);\n searchBar.classList.toggle('show');\n searchBtn.toggleAttribute('aria-expanded');\n }\n });\n const clearBtn = searchBar.querySelector('.empty');\n const searchInput = searchBar.querySelector('#search');\n clearBtn.addEventListener('click', function (e) {\n searchInput.removeAttribute('placeholder');\n searchInput.removeAttribute('data-value');\n searchInput.value = '';\n });\n // #endregion\n // #region Reponsive safe area\n const hideButtons = () => {\n const wrapperWidth = actionbarWrapper.scrollWidth;\n const screenWidth = document.documentElement.scrollWidth;\n let safeAreaWidth = 750;\n let elementMargin = 16;\n let tabletSafeWidth = 450;\n let mobileSafeWidth = (this === null || this === void 0 ? void 0 : this.hasAttribute('data-switchviews')) ? 144 : 210;\n if (this.hasAttribute('data-large-safe-area')) {\n safeAreaWidth = 1048;\n tabletSafeWidth = 620;\n mobileSafeWidth = 260;\n }\n // We need to modify the widths to mimic the CSS's scaling functionality\n let modifier = 1;\n if (screenWidth >= 992 && screenWidth <= 1280) {\n modifier = screenWidth / 1280;\n }\n else if (screenWidth >= 576 && screenWidth < 992) {\n modifier = screenWidth / 768;\n }\n else if (screenWidth < 576) {\n modifier = screenWidth / 375;\n }\n // Work out the safe sapce width depending upon the wrappers width and modifier comp\n if (wrapperWidth >= 992 && wrapperWidth <= 1280) {\n safeAreaWidth = safeAreaWidth * modifier;\n }\n else if (wrapperWidth >= 576 && wrapperWidth < 992) {\n safeAreaWidth = tabletSafeWidth * modifier;\n }\n else if (wrapperWidth < 576) {\n safeAreaWidth = mobileSafeWidth * modifier;\n }\n // Margin in between elements\n elementMargin = elementMargin * modifier;\n // If the wrapper width is small we want to reduce the btn sizes by adding or removing btn-compact classes\n if (wrapperWidth < 576) {\n Array.from(this.querySelectorAll(':scope > .btn:not(.js-updated), :scope > .menu__wrapper > .btn[class*=\"fa-\"]:first-child:not(.js-updated)')).forEach((element) => {\n element.className = element.className.replace(' btn-compact', ' _btn-compact');\n element.classList.add('btn-compact');\n element.classList.add('js-updated');\n });\n }\n else {\n Array.from(this.querySelectorAll(':scope > .btn.js-updated, :scope > .menu__wrapper > .btn.js-updated:first-child')).forEach((element) => {\n element.classList.remove('btn-compact');\n element.classList.remove('js-updated');\n element.className = element.className.replace(' _btn-compact', ' btn-compact');\n });\n }\n // Reset the elements before we decide what elements become slotted into the overflow\n Array.from(this.querySelectorAll('[slot]')).forEach((element) => {\n if (element.getAttribute('slot') == 'overflow')\n element.removeAttribute('slot');\n if (element.getAttribute('slot') == 'selected-overflow')\n element.setAttribute('slot', 'selected');\n });\n Array.from(this.querySelectorAll('.show')).forEach((element) => {\n element.classList.remove('show');\n });\n // Foreach safe area lets check what elements are slotted in them and if they need an overflow\n Array.from(this.shadowRoot.querySelectorAll('.safe-area')).forEach((element) => {\n var _a, _b, _c;\n // Decide on which overflow slot to use\n let overflowSlot = 'overflow';\n if (((_a = element.querySelector('slot')) === null || _a === void 0 ? void 0 : _a.hasAttribute('name')) &&\n ((_b = element.querySelector('slot')) === null || _b === void 0 ? void 0 : _b.getAttribute('name')) == 'selected')\n overflowSlot = 'selected-overflow';\n // Get the slotted elements, remember they aren't children of the safe area\n const elements = (_c = element.querySelector('slot')) === null || _c === void 0 ? void 0 : _c.assignedElements();\n let tempWidth = 44 * modifier; // Allow space for the overflow button\n // If search then allow for the search button width\n if (this.hasAttribute('data-search'))\n tempWidth += 44 * modifier;\n // Foreach element this isn't an action button or dialog wrapper add to the width, these will not be moved into the overflow slot\n for (let i = 0; i < elements.length; i++) {\n if (!elements[i].classList.contains('btn-action') && !elements[i].classList.contains('menu__wrapper ')) {\n tempWidth += elements[i].offsetWidth;\n tempWidth += elementMargin;\n }\n }\n // Foreach dialog wrapper decide if safe in safe area or move into the overflow slot, dialog wrappers have priority over the action buttons\n for (let i = 0; i < elements.length; i++) {\n if (elements[i].classList.contains('menu__wrapper ')) {\n elements[i].classList.add('show');\n tempWidth += elements[i].offsetWidth;\n tempWidth += elementMargin / 2;\n // If we have exceeded the safe area then lets break the loop\n if (tempWidth - elementMargin / 2 > safeAreaWidth) {\n elements[i].classList.remove('show');\n break;\n }\n }\n }\n // Foreach action button\n for (let i = 0; i < elements.length; i++) {\n if (elements[i].classList.contains('btn-action')) {\n elements[i].classList.add('show');\n tempWidth += elements[i].offsetWidth;\n tempWidth += elementMargin / 2;\n // If we have exceeded the safe area then lets break the loop\n if (tempWidth - elementMargin / 2 > safeAreaWidth) {\n elements[i].classList.remove('show');\n break;\n }\n }\n }\n const overflowDialog = element.querySelector('.dialog-overflow');\n if (overflowDialog)\n overflowDialog.classList.add('d-none');\n // Decide which elements go into the overflow slot\n for (let i = 0; i < elements.length; i++) {\n if (elements[i].classList.contains('btn-action') || elements[i].classList.contains('menu__wrapper ')) {\n if (!elements[i].classList.contains('show')) {\n // Move to the slot by changing the attribute\n elements[i].setAttribute('slot', overflowSlot);\n // if an element has been added to overflow slot then make sure we show the overflow menu button\n if (overflowDialog)\n overflowDialog.classList.remove('d-none');\n }\n }\n }\n });\n };\n // Check buttons on load and when the wrapper element gets resized.\n hideButtons();\n new ResizeObserver(hideButtons).observe(actionbarWrapper);\n // #endregion\n // #region cloumn filters\n const setColumnFilters = () => {\n let columnsHidden = '';\n Array.from(checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.querySelectorAll('label input')).forEach((element, index) => {\n columnsHidden += this.hasAttribute(`data-hide-col${index + 1}`) ? `${index + 1},` : '';\n });\n this.setAttribute('data-columns-shown', checklistHolder.querySelectorAll('input:checked').length);\n const dispatchedEvent = new CustomEvent('columm-filters-set', {\n detail: {\n columnsHidden: columnsHidden.slice(0, -1),\n },\n });\n this.dispatchEvent(dispatchedEvent);\n };\n if (this.hasAttribute('data-filter-columns') || this.hasAttribute('data-filter-columns-save')) {\n const columns = this.closest('iam-table').querySelectorAll('thead th');\n Array.from(columns).forEach((element, index) => {\n if (element.textContent) {\n checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.insertAdjacentHTML('beforeend', `<label class=\"m-0\" title=\"Change the display of \"><input name=\"hideCol${index + 1}\" value=\"${index + 1}\" type=\"checkbox\" ${this.hasAttribute('data-hide-col' + (index + 1)) ? '' : 'checked'} /> ${element.textContent}</label>`);\n }\n });\n }\n this.setAttribute('data-columns-shown', checklistHolder.querySelectorAll('input:checked').length);\n if (this.hasAttribute('data-filter-columns') && !this.hasAttribute('data-filter-columns-save')) {\n checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('input')) {\n const checkbox = event.target.closest('input');\n if ((checkbox === null || checkbox === void 0 ? void 0 : checkbox.checked) == false) {\n this.setAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value), 'true');\n }\n else {\n this.removeAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value));\n }\n setColumnFilters();\n }\n });\n }\n if (this.hasAttribute('data-filter-columns-save')) {\n const checklistHolder = (_k = this.shadowRoot) === null || _k === void 0 ? void 0 : _k.querySelector('.checklists');\n const checklistSave = (_l = this.shadowRoot) === null || _l === void 0 ? void 0 : _l.querySelector('#saveColumns');\n const checklistCancel = (_m = this.shadowRoot) === null || _m === void 0 ? void 0 : _m.querySelector('#cancelColumns');\n checklistSave === null || checklistSave === void 0 ? void 0 : checklistSave.addEventListener('click', (event) => {\n var _a;\n Array.from(checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.querySelectorAll('label input')).forEach((checkbox) => {\n if ((checkbox === null || checkbox === void 0 ? void 0 : checkbox.checked) == false) {\n this.setAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value), 'true');\n }\n else {\n this.removeAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value));\n }\n });\n setColumnFilters();\n (_a = checklistSave.closest('dialog')) === null || _a === void 0 ? void 0 : _a.close();\n });\n // Revert back to what was previously saved\n checklistCancel === null || checklistCancel === void 0 ? void 0 : checklistCancel.addEventListener('click', (event) => {\n var _a, _b;\n const checklistHolder = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.checklists');\n Array.from(checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.querySelectorAll('label input')).forEach((element, index) => {\n element.checked = this.hasAttribute(`data-hide-col${index + 1}`) ? false : true;\n });\n setColumnFilters();\n (_b = checklistSave.closest('dialog')) === null || _b === void 0 ? void 0 : _b.close();\n });\n }\n // #endregion\n }\n static get observedAttributes() {\n return ['data-selected'];\n }\n attributeChangedCallback(attrName, oldVal, newVal) {\n switch (attrName) {\n case 'data-selected': {\n const selectAll = this.shadowRoot.querySelector('.selectall');\n if (selectAll)\n setSelectAllInput(selectAll, newVal);\n const event = new CustomEvent('selected', { detail: { selected: newVal } });\n this.dispatchEvent(event);\n if (newVal == 'all' && this.hasAttribute('data-select-watch')) {\n const element = document.getElementById(String(this.getAttribute('data-select-watch')));\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n input.checked = true;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.setAttribute('data-selected', 'true');\n });\n }\n if (newVal == '0' && this.hasAttribute('data-select-watch')) {\n const element = document.getElementById(String(this.getAttribute('data-select-watch')));\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n input.checked = false;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.removeAttribute('data-selected');\n });\n }\n break;\n }\n }\n }\n}\nexport default iamActionbar;\n"],"names":["uniqueID","index","iamMenu","template","menuID","menuButton","topLevelmenuItems","menuItems","subNextIndex","subPrevIndex","item","event","activeItem","prevIndex","nextIndex","subMenuItems","_a","_b","_c","_d","updateEvent","button","popoverID","popover","viewportOffset","top","left","setSelectAllInput","element","value","iamActionbar","_e","_f","_g","_h","_j","_k","_l","_m","actionbarWrapper","checklistHolder","dialog","btn","id","selectAll","cancelButton","input","count","countChecked","btns","viewList","view","icon","views","switchEvent","searchBar","searchBtn","searchInput","keyupEvent","changeEvent","submitEvent","clearBtn","e","hideButtons","wrapperWidth","screenWidth","safeAreaWidth","elementMargin","tabletSafeWidth","mobileSafeWidth","modifier","overflowSlot","elements","tempWidth","i","overflowDialog","setColumnFilters","columnsHidden","dispatchedEvent","columns","checkbox","checklistSave","checklistCancel","attrName","oldVal","newVal"],"mappings":"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"}
1
+ {"version":3,"file":"actionbar.component.min.js","sources":["../../modules/helpers.js","../menu/menu.component.js","actionbar.component.js"],"sourcesContent":["/**\n * Global helper functions to help maintain and enhance framework elements.\n * @module Helpers\n */\n/**\n * Add global classes used by the CSS and later JavaScript.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addBodyClasses = (body) => {\n body.classList.add('js-enabled');\n if (navigator.userAgent.indexOf('MSIE') !== -1 || navigator.appVersion.indexOf('Trident/') > 0) {\n body.classList.add('ie');\n }\n};\n/**\n * Add global events.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addGlobalEvents = (body) => {\n const checkElements = function (hash) {\n const label = document.querySelector(`label[for=\"${hash.replace('#', '')}\"]`);\n const summary = document.querySelector(hash + ' summary');\n const dialog = document.querySelector(`dialog${hash}`);\n const detail = document.querySelector(`detail${hash}`);\n if (label instanceof HTMLElement)\n label.click();\n else if (summary instanceof HTMLElement)\n summary.click();\n else if (dialog instanceof HTMLElement)\n dialog.showModal();\n else if (detail instanceof HTMLElement)\n detail.addAttribute('open');\n };\n if (location.hash)\n checkElements(location.hash);\n window.addEventListener('hashchange', function () {\n checkElements(location.hash);\n }, false);\n addEventListener('popstate', (event) => {\n if (event && event.state && event.state.type && event.state.type == 'pagination') {\n const form = document.querySelector(`#${event.state.form}`);\n const pageInput = document.querySelector(`#${event.state.form} [data-pagination]`);\n if (pageInput)\n pageInput.value = event.state.page;\n else\n form.innerHTML += `<input name=\"page\" type=\"hidden\" data-pagination=\"true\" value=\"${event.state.page}\" />`;\n form.dispatchEvent(new Event('submit'));\n }\n });\n Array.from(document.querySelectorAll('form')).forEach((form) => {\n if (!(form === null || form === void 0 ? void 0 : form.closest('iam-form'))) {\n form.addEventListener('submit', (event) => {\n var _a;\n if (form.querySelector(':invalid')) {\n form.classList.add('was-validated');\n (_a = form === null || form === void 0 ? void 0 : form.querySelector('input:invalid')) === null || _a === void 0 ? void 0 : _a.scrollIntoView();\n event.preventDefault();\n }\n });\n }\n });\n document.addEventListener('click', (event) => {\n var _a;\n if (event && event.target instanceof HTMLElement && event.target.matches('form button:not([type=button])')) {\n const form = event.target.closest('form');\n if (!(form === null || form === void 0 ? void 0 : form.closest('iam-form'))) {\n // Reset password types\n Array.from(form.querySelectorAll('[data-password-type]')).forEach((input) => {\n input.setAttribute('type', 'password');\n });\n if (form.querySelector(':invalid') ||\n form.querySelector('.pwd-checker[data-strength=\"1\"]') ||\n form.querySelector('.pwd-checker[data-strength=\"2\"]')) {\n form.classList.add('was-validated');\n (_a = form === null || form === void 0 ? void 0 : form.querySelector('input:invalid')) === null || _a === void 0 ? void 0 : _a.scrollIntoView();\n event.preventDefault();\n }\n if (form.querySelector('iam-multiselect[data-is-required][data-error]')) {\n form.classList.add('was-validated');\n event.preventDefault();\n }\n }\n }\n });\n document.addEventListener('keydown', (e) => {\n if (e.key === 'Escape') {\n if (document.querySelector('.dialog--transactional[open], .dialog--acknowledgement[open]')) {\n e.preventDefault();\n e.stopPropagation();\n }\n }\n });\n Array.from(document.querySelectorAll('label progress')).forEach((progress) => {\n const label = progress.closest('label');\n label.setAttribute('data-percent', progress.getAttribute('value'));\n });\n};\nexport const isNumeric = function (str) {\n if (typeof str != 'string')\n return false; // we only process strings!\n return (!isNaN(str) && // use type coercion to parse the _entirety_ of the string (`parseFloat` alone does not do this)...\n !isNaN(parseFloat(str))); // ...and ensure strings of whitespace fail\n};\nexport const zeroPad = (num, places) => String(num).padStart(places, '0');\nexport const ucfirst = (str) => str.charAt(0).toUpperCase() + str.slice(1);\nexport const ucwords = (str) => str\n .split(' ')\n .map((s) => ucfirst(s))\n .join(' ');\nexport const unsnake = (str) => str.replace(/_/g, ' ');\nexport const snake = (str) => str.replace(/ /g, '_');\nexport const safeID = function (str) {\n str = str.toLowerCase();\n str = snake(str);\n str = str.replace(/\\W/g, '');\n return str;\n};\nexport const numberOfDays = function (startDateString, endDateString) {\n const convertStart = startDateString.split('/');\n const convertEnd = endDateString.split('/');\n const dateStart = new Date(convertStart[1] + '/' + convertStart[0] + '/' + convertStart[2]);\n const dateEnd = new Date(convertEnd[1] + '/' + convertEnd[0] + '/' + convertEnd[2]);\n if (dateStart == 'Invalid Date')\n throw 'Start date is not a valid date';\n if (dateEnd == 'Invalid Date')\n throw 'End date is not a valid date';\n // To calculate the time difference of two dates\n const diffTime = dateEnd.getTime() - dateStart.getTime();\n const numberOfDays = diffTime / (1000 * 3600 * 24) + 1;\n if (numberOfDays < 0)\n throw 'The start date should be before the end date';\n return numberOfDays;\n};\n// Used to get values from nested json objects\nexport const resolvePath = (object, path, defaultValue) => path\n // eslint-disable-next-line no-useless-escape\n .split(/[\\.\\[\\]\\'\\\"]/)\n .filter((p) => p)\n .reduce((o, p) => (o ? o[p] : defaultValue), object);\nexport const isTraversable = (o) => Array.isArray(o) || (o !== null && ['function', 'object'].includes(typeof o));\nexport const getSwipeDirection = (touchstartX, touchstartY, touchendX, touchendY) => {\n const limit = Math.tan(((45 * 1.5) / 180) * Math.PI);\n const pageWidth = window.innerWidth || document.body.clientWidth;\n const treshold = Math.max(1, Math.floor(0.01 * pageWidth));\n const x = touchendX - touchstartX;\n const y = touchendY - touchstartY;\n const xy = Math.abs(x / y);\n const yx = Math.abs(y / x);\n if (Math.abs(x) > treshold || Math.abs(y) > treshold) {\n if (yx <= limit) {\n if (x < 0) {\n return 'left';\n }\n else {\n return 'right';\n }\n }\n if (xy <= limit) {\n if (y < 0) {\n return 'top';\n }\n else {\n return 'bottom';\n }\n }\n }\n else {\n return 'tap';\n }\n};\nexport const uniqueID = (index = 1) => {\n const ID = Math.floor(Math.random() * Date.now() * (index + 1));\n return ID;\n};\nexport const isValidPostcode = (searchValue) => {\n const regexp = /^([A-Z][A-HJ-Y]?[0-9][A-Z0-9]? ?[0-9][A-Z]{2}|GIR ?0A{2})$/gmi;\n return regexp.test(searchValue.trim());\n};\n","class iamMenu extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n const assetLocation = document.body.hasAttribute('data-assets-location')\n ? document.body.getAttribute('data-assets-location')\n : '/assets';\n const menuCSS = `@import \"${assetLocation}/css/components/menu.component.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\n <style>\n ${menuCSS}\n </style>\n <div class=\"menu--inner\" part=\"inner\">\n <slot></slot>\n </div>`;\n this.shadowRoot.appendChild(template.content.cloneNode(true));\n }\n connectedCallback() {\n const menuID = this.hasAttribute('id') ? this.getAttribute('id') : false;\n const menuButton = document.querySelector(`[popovertarget=\"${menuID}\"]`);\n let topLevelmenuItems = this.querySelectorAll(':scope > a, :scope > button, :scope > details > summary');\n let menuItems = this.querySelectorAll('a, button');\n if (this.closest('.menu__wrapper')) {\n menuItems = this.shadowRoot.querySelector('slot').assignedElements({ flatten: true });\n topLevelmenuItems = menuItems;\n }\n const subMenus = this.querySelectorAll('details');\n let subNextIndex;\n let subPrevIndex;\n // Set the needed CSS styles to connect the ID attribute to the anchor name\n if (menuID && menuButton) {\n this.setAttribute('role', 'menu');\n this.setAttribute('popover', 'auto');\n this.style['position-anchor'] = `--${menuID}`;\n menuButton === null || menuButton === void 0 ? void 0 : menuButton.setAttribute('aria-haspopup', 'true');\n menuButton === null || menuButton === void 0 ? void 0 : menuButton.style['anchor-name'] = `--${menuID}`;\n menuButton === null || menuButton === void 0 ? void 0 : menuButton.setAttribute('aria-controls', menuID);\n }\n menuItems.forEach((item, index) => {\n item.setAttribute('role', 'menuitem');\n item.setAttribute('tabindex', '0');\n if (index == 0) {\n item.setAttribute('autofocus', true);\n }\n });\n this.addEventListener('keydown', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('a, button, summary')) {\n const activeItem = document.activeElement;\n const prevIndex = Array.from(topLevelmenuItems).indexOf(activeItem) - 1;\n const nextIndex = Array.from(topLevelmenuItems).indexOf(activeItem) + 1;\n switch (event.keyCode // change to event.key to key to use the above variable\n ) {\n case 27: // Esc\n if (activeItem.closest('details')) {\n event.stopPropagation();\n event.preventDefault();\n activeItem.closest('details').removeAttribute('open');\n activeItem.closest('details').querySelector(':scope summary').focus();\n }\n else {\n event.stopPropagation();\n menuButton.focus();\n }\n break;\n case 32: // Space\n case 13: // Enter\n break;\n case 35: // end\n event.stopPropagation();\n event.preventDefault();\n this.querySelector('details[open]').removeAttribute('open');\n Array.from(menuItems)[menuItems.length - 1].focus();\n break;\n case 36: // home\n event.stopPropagation();\n event.preventDefault();\n this.querySelector('details[open]').removeAttribute('open');\n Array.from(menuItems)[0].focus();\n break;\n case 38: // up\n event.stopPropagation();\n event.preventDefault();\n if (Array.from(topLevelmenuItems).indexOf(activeItem) > -1) {\n if (Array.from(topLevelmenuItems)[prevIndex] != undefined)\n Array.from(topLevelmenuItems)[prevIndex].focus();\n else\n Array.from(topLevelmenuItems)[topLevelmenuItems.length - 1].focus();\n }\n else if (activeItem.closest('details')) {\n const subMenuItems = activeItem\n .closest('details')\n .querySelectorAll('a, button, :scope details > summary');\n subPrevIndex = Array.from(subMenuItems).indexOf(activeItem) - 1;\n if (Array.from(subMenuItems)[subPrevIndex] != undefined)\n Array.from(subMenuItems)[subPrevIndex].focus();\n else\n Array.from(subMenuItems)[subMenuItems.length - 1].focus();\n }\n break;\n case 40: // down\n event.stopPropagation();\n event.preventDefault();\n if (Array.from(topLevelmenuItems).indexOf(activeItem) > -1) {\n if (Array.from(topLevelmenuItems)[nextIndex] != undefined)\n Array.from(topLevelmenuItems)[nextIndex].focus();\n else\n Array.from(topLevelmenuItems)[0].focus();\n }\n else if (activeItem.closest('details')) {\n const subMenuItems = activeItem\n .closest('details')\n .querySelectorAll('a, button, :scope details > summary');\n subNextIndex = Array.from(subMenuItems).indexOf(activeItem) + 1;\n if (Array.from(subMenuItems)[subNextIndex] != undefined)\n Array.from(subMenuItems)[subNextIndex].focus();\n else\n Array.from(subMenuItems)[0].focus();\n }\n break;\n }\n }\n });\n this.addEventListener('toggle', (e) => {\n var _a, _b, _c, _d;\n const updateEvent = new CustomEvent(e.newState, { detail: { id: this.getAttribute('id'), target: e.target } });\n this.dispatchEvent(updateEvent);\n // Fix the focus\n if (this.closest('.menu__wrapper')) {\n menuItems[0].focus();\n }\n if (this.hasAttribute('popover-open')) {\n e.preventDefault();\n this.removeAttribute('popover-open');\n this.hidePopover();\n }\n if (this.matches(':popover-open') && document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) {\n (_a = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _a === void 0 ? void 0 : _a.setAttribute('aria-pressed', 'true');\n (_b = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _b === void 0 ? void 0 : _b.classList.add('active');\n }\n else {\n (_c = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _c === void 0 ? void 0 : _c.removeAttribute('aria-pressed');\n (_d = document.querySelector(`[popovertarget=\"${this.getAttribute('id')}\"]`)) === null || _d === void 0 ? void 0 : _d.classList.remove('active');\n }\n });\n this.addEventListener('click', (event) => {\n if (event &&\n event.target instanceof HTMLElement &&\n event.target.closest('button:has(+ iam-menu:not([popover]))')) {\n const button = event.target.closest('button:has(+ iam-menu)');\n button === null || button === void 0 ? void 0 : button.classList.toggle('open');\n }\n else if (event && event.target instanceof HTMLElement && event.target.closest('button.selectable')) {\n const button = event.target.closest('button.selectable');\n if (this.hasAttribute('multiple')) {\n button.classList.toggle('selected');\n }\n else if (button === null || button === void 0 ? void 0 : button.classList.contains('selected')) {\n this.querySelectorAll('.selected').forEach((item) => {\n item.classList.remove('selected');\n });\n }\n else {\n this.querySelectorAll('.selected').forEach((item) => {\n item.classList.remove('selected');\n });\n button.classList.add('selected');\n }\n }\n });\n // safari and firefox anchor fix for cards\n if (!CSS.supports('top', 'anchor(top)')) {\n document.addEventListener('click', (event) => {\n if (event.originalTarget && event.originalTarget.matches('[popovertarget]')) {\n const button = event.originalTarget;\n const popoverID = button.getAttribute('popovertarget');\n const popover = document.getElementById(popoverID);\n const viewportOffset = button.getBoundingClientRect();\n const top = viewportOffset.top;\n const left = viewportOffset.left;\n popover.style.setProperty('top', top + 'px');\n popover.style.setProperty('left', left + button.clientWidth + 'px');\n }\n });\n }\n }\n}\nexport default iamMenu;\n","import { uniqueID } from '../../modules/helpers';\nimport iamMenu from '../menu/menu.component';\nwindow.dataLayer = window.dataLayer || [];\nwindow.dataLayer.push({\n event: 'customElementRegistered',\n element: 'action bar',\n});\nfunction setSelectAllInput(element, value) {\n if (element && value == 'all') {\n element.querySelector('input').indeterminate = false;\n element.querySelector('input').checked = true;\n element.querySelector('label').textContent = `Select all`;\n }\n else if (element && value == 0) {\n element.querySelector('input').indeterminate = false;\n element.querySelector('input').checked = false;\n element.querySelector('label').textContent = `Select all`;\n }\n else if (element && value) {\n element.querySelector('input').indeterminate = true;\n element.querySelector('input').checked = false;\n element.querySelector('label').textContent = `${value} item${value > 1 ? 's' : ''} selected`;\n }\n else if (element) {\n element.querySelector('input').checked = false;\n element.querySelector('input').indeterminate = false;\n element.querySelector('label').textContent = `Select all`;\n }\n}\nclass iamActionbar extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n const assetLocation = document.body.hasAttribute('data-assets-location')\n ? document.body.getAttribute('data-assets-location')\n : '/assets';\n if (!window.customElements.get(`iam-menu`))\n window.customElements.define(`iam-menu`, iamMenu);\n const loadCSS = `@import \"${assetLocation}/css/components/actionbar.component.css\";`;\n const loadExtraCSS = `@import \"${assetLocation}/css/components/actionbar.global.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\n <style>\n ${loadCSS}\n ${this.hasAttribute('css') ? `@import \"${this.getAttribute('css')}\";` : ``}\n </style>\n <link rel=\"stylesheet\" href=\"https://kit.fontawesome.com/8bd0fca975.css\" crossorigin=\"anonymous\">\n <div class=\"actionbar__wrapper\">\n \n <div class=\"actionbar\" part=\"actionbar\">\n <slot name=\"selectall\"></slot>\n <slot name=\"filters\"></slot>\n <div class=\"safe-area\">\n <slot></slot>\n <div class=\"body\">\n <div class=\"menu__wrapper menu__wrapper --right dialog-overflow d-none show\">\n <button class=\"btn btn-secondary btn-compact btn-sm fa-ellipsis-vertical m-0\" popovertarget=\"overflow\" style=\"anchor-name: --anchor-overflow;\">More actions</button>\n <iam-menu class=\"dialog--list\" part=\"overflow\" id=\"overflow\" style=\"position-anchor: --anchor-overflow;\" popover>\n <slot name=\"overflow\"></slot>\n <slot name=\"menu\"></slot>\n </iam-menu>\n </div>\n\n\n <div class=\"menu__wrapper menu__wrapper --right filter-columns\">\n <button class=\"btn btn-secondary btn-compact btn-sm mb-0 me-0 fa-regular fa-table-columns\" title=\"Select colums\" popovertarget=\"filter\" style=\"anchor-name: --anchor-filter;\">Filter</button>\n <iam-menu class=\"dialog--list\" id=\"filter\" style=\"position-anchor: --anchor-filter;\" popover>\n <div class=\"pb-0 mb-0 checklists\">\n \n </div>\n <div class=\"text-right checklist-btns\"><button id=\"cancelColumns\" class=\"btn btn-action\">Cancel</button><button id=\"saveColumns\" class=\"btn btn-action btn-secondary\">Save</button></div>\n </iam-menu>\n </div>\n\n <button class=\"btn btn-secondary btn-compact btn-sm fa-search\" data-search=\"\" part=\"search-btn\">Search</button>\n </div>\n </div>\n </div>\n <div class=\"actionbar--selected\">\n <div class=\"safe-area\">\n <slot name=\"selected\"></slot>\n <div class=\"body\">\n <div class=\"menu__wrapper menu__wrapper --right dialog-overflow d-none show\">\n <button class=\"btn btn-secondary btn-compact btn-sm fa-ellipsis-vertical m-0\" popovertarget=\"selected-overflow\" style=\"anchor-name: --anchor-selected-overflow;\">More actions</button>\n <iam-menu class=\"dialog--list\" part=\"selected-overflow\" id=\"selected-overflow\" style=\"position-anchor: --anchor-selected-overflow;\" popover>\n <slot name=\"selected-overflow\"></slot>\n </iam-menu>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"actionbar--search\">\n <button data-search class=\"btn btn-compact fa-xmark-large btn-secondary mb-0\" >Close</button>\n\n <div class=\"search-wrapper\" part=\"search\">\n <label for=\"search\" class=\"visually-hidden\">Input field label</label>\n <button class=\"suffix\" part=\"search-btn\"><i class=\"fa-regular fa-search\"></i></button>\n <input type=\"text\" id=\"search\" name=\"search\" required=\"\" part=\"search-input\">\n <button class=\"empty btn btn-action\"><i class=\"fa-light fa-times me-0\" aria-hidden=\"true\"></i></button>\n </div>\n\n </div>\n </div>\n <div class=\"no-columns\">\n <span class=\"d-block\">No columns selected</span>\n </div>\n `;\n this.shadowRoot.appendChild(template.content.cloneNode(true));\n // insert extra CSS\n if (!document.getElementById('actionbarGlobal'))\n document.head.insertAdjacentHTML('beforeend', `<style id=\"actionbarGlobal\">${loadExtraCSS}</style>`);\n }\n connectedCallback() {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;\n const actionbarWrapper = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.actionbar__wrapper');\n const checklistHolder = (_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.checklists');\n const assetLocation = document.body.hasAttribute('data-assets-location')\n ? document.body.getAttribute('data-assets-location')\n : '/assets';\n const dialog = this.querySelector('.dialog__wrapper dialog');\n // Transform dialog into a menu custom element\n if (dialog) {\n const btn = dialog.parentElement.querySelector('.btn');\n const id = `menu${uniqueID(1)}`;\n dialog.setAttribute('id', id);\n dialog.setAttribute('popover', 'auto');\n btn.setAttribute('popovertarget', id);\n dialog.outerHTML = dialog.outerHTML.replace(/<dialog/g, '<iam-menu').replace(/<\\/dialog>/g, '</iam-menu>');\n (_c = dialog.parentElement) === null || _c === void 0 ? void 0 : _c.classList.add('menu__wrapper');\n (_d = dialog.parentElement) === null || _d === void 0 ? void 0 : _d.classList.remove('dialog__wrapper');\n }\n // #region select all\n if (this.hasAttribute('data-selectall')) {\n actionbarWrapper === null || actionbarWrapper === void 0 ? void 0 : actionbarWrapper.insertAdjacentHTML('afterbegin', `<div class=\"selectall pb-0\"><input type=\"checkbox\" name=\"selectall\" id=\"selectall\"><label for=\"selectall\" class=\"m-0\">Select all</label></div>`);\n const selectAll = (_e = this.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('.selectall');\n if (this.hasAttribute('data-selected')) {\n setSelectAllInput(selectAll, this.getAttribute('data-selected'));\n }\n selectAll === null || selectAll === void 0 ? void 0 : selectAll.addEventListener('change', (event) => {\n var _a;\n if (event && event.target instanceof HTMLElement && event.target.closest('input')) {\n if ((_a = event.target.closest('input')) === null || _a === void 0 ? void 0 : _a.checked)\n this.setAttribute('data-selected', 'all');\n else\n this.setAttribute('data-selected', '0');\n }\n });\n const cancelButton = this.querySelector('button[data-cancel]');\n if (cancelButton) {\n cancelButton.addEventListener('click', () => {\n this.setAttribute('data-selected', '0');\n });\n }\n }\n // Wtach div for the select inputs\n if (this.hasAttribute('data-select-watch')) {\n const element = document.getElementById(this.getAttribute('data-select-watch'));\n element === null || element === void 0 ? void 0 : element.setAttribute('data-select-container', 'true');\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n (_a = input.parentElement) === null || _a === void 0 ? void 0 : _a.setAttribute('slot', 'checkbox');\n });\n element === null || element === void 0 ? void 0 : element.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('[type=\"checkbox\"]')) {\n const count = element.querySelectorAll('input[type=\"checkbox\"]').length;\n const countChecked = element.querySelectorAll('input[type=\"checkbox\"]:checked').length;\n this.setAttribute('data-selected', count == countChecked ? 'all' : String(countChecked));\n if (countChecked) {\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.setAttribute('data-selected', 'true');\n });\n }\n else {\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.removeAttribute('data-selected');\n });\n }\n }\n });\n }\n // #endregion\n // #region switchviews\n if (this.hasAttribute('data-switchviews')) {\n let btns = '';\n const viewList = (_f = this.getAttribute('data-switchviews')) === null || _f === void 0 ? void 0 : _f.split(',');\n viewList === null || viewList === void 0 ? void 0 : viewList.forEach((view) => {\n let icon = 'fa-grid';\n if (view == 'list')\n icon = 'fa-list';\n else if (view == 'small')\n icon = 'fa-table';\n btns += `<button class=\"tag tag--toggle mb-0\" data-view=\"${view}\"><i class=\"fa-regular ${icon} m-0\"></i><span class=\"visually-hidden\">${view}</span></button>`;\n });\n actionbarWrapper === null || actionbarWrapper === void 0 ? void 0 : actionbarWrapper.insertAdjacentHTML('afterbegin', `<div class=\"views m-0\">${btns}</div>`);\n const views = (_g = this.shadowRoot) === null || _g === void 0 ? void 0 : _g.querySelector('.views');\n views === null || views === void 0 ? void 0 : views.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('.tag--toggle')) {\n const btn = event.target.closest('.tag--toggle');\n this.setAttribute('data-view', btn.textContent);\n const switchEvent = new CustomEvent('switch-view', { detail: { view: btn.textContent } });\n this.dispatchEvent(switchEvent);\n }\n });\n }\n // #endregion\n // #region search\n const searchBar = (_h = this.shadowRoot) === null || _h === void 0 ? void 0 : _h.querySelector('.actionbar--search');\n if (this.hasAttribute('data-search-value')) {\n ((_j = this.shadowRoot) === null || _j === void 0 ? void 0 : _j.querySelector('#search')).value = String(this.getAttribute('data-search-value'));\n }\n if (this.hasAttribute('data-search') && this.getAttribute('data-search') == 'show')\n searchBar === null || searchBar === void 0 ? void 0 : searchBar.classList.add('show');\n const searchBtn = this.shadowRoot.querySelector('button[data-search]');\n this.shadowRoot.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('button[data-search]')) {\n searchBar.classList.toggle('show');\n searchBtn.toggleAttribute('aria-expanded');\n searchInput.focus();\n }\n });\n searchBar.addEventListener('keyup', () => {\n const keyupEvent = new CustomEvent('search-keyup', {\n detail: { search: searchBar.querySelector('input').value },\n });\n this.dispatchEvent(keyupEvent);\n });\n searchBar.addEventListener('change', () => {\n const changeEvent = new CustomEvent('search-change', {\n detail: { search: searchBar.querySelector('input').value },\n });\n this.dispatchEvent(changeEvent);\n });\n searchBar.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('button.suffix')) {\n const submitEvent = new CustomEvent('search-submit', {\n detail: { search: searchBar.querySelector('input').value },\n });\n this.dispatchEvent(submitEvent);\n searchBar.classList.toggle('show');\n searchBtn.toggleAttribute('aria-expanded');\n }\n });\n const clearBtn = searchBar.querySelector('.empty');\n const searchInput = searchBar.querySelector('#search');\n clearBtn.addEventListener('click', function (e) {\n searchInput.removeAttribute('placeholder');\n searchInput.removeAttribute('data-value');\n searchInput.value = '';\n });\n // #endregion\n // #region Reponsive safe area\n const hideButtons = () => {\n const wrapperWidth = actionbarWrapper.scrollWidth;\n const screenWidth = document.documentElement.scrollWidth;\n let safeAreaWidth = 750;\n let elementMargin = 16;\n let tabletSafeWidth = 450;\n let mobileSafeWidth = (this === null || this === void 0 ? void 0 : this.hasAttribute('data-switchviews')) ? 144 : 210;\n if (this.hasAttribute('data-large-safe-area')) {\n safeAreaWidth = 1048;\n tabletSafeWidth = 620;\n mobileSafeWidth = 260;\n }\n // We need to modify the widths to mimic the CSS's scaling functionality\n let modifier = 1;\n if (screenWidth >= 992 && screenWidth <= 1280) {\n modifier = screenWidth / 1280;\n }\n else if (screenWidth >= 576 && screenWidth < 992) {\n modifier = screenWidth / 768;\n }\n else if (screenWidth < 576) {\n modifier = screenWidth / 375;\n }\n // Work out the safe sapce width depending upon the wrappers width and modifier comp\n if (wrapperWidth >= 992 && wrapperWidth <= 1280) {\n safeAreaWidth = safeAreaWidth * modifier;\n }\n else if (wrapperWidth >= 576 && wrapperWidth < 992) {\n safeAreaWidth = tabletSafeWidth * modifier;\n }\n else if (wrapperWidth < 576) {\n safeAreaWidth = mobileSafeWidth * modifier;\n }\n // Margin in between elements\n elementMargin = elementMargin * modifier;\n // If the wrapper width is small we want to reduce the btn sizes by adding or removing btn-compact classes\n if (wrapperWidth < 576) {\n Array.from(this.querySelectorAll(':scope > .btn:not(.js-updated), :scope > .menu__wrapper > .btn[class*=\"fa-\"]:first-child:not(.js-updated)')).forEach((element) => {\n element.className = element.className.replace(' btn-compact', ' _btn-compact');\n element.classList.add('btn-compact');\n element.classList.add('js-updated');\n });\n }\n else {\n Array.from(this.querySelectorAll(':scope > .btn.js-updated, :scope > .menu__wrapper > .btn.js-updated:first-child')).forEach((element) => {\n element.classList.remove('btn-compact');\n element.classList.remove('js-updated');\n element.className = element.className.replace(' _btn-compact', ' btn-compact');\n });\n }\n // Reset the elements before we decide what elements become slotted into the overflow\n Array.from(this.querySelectorAll('[slot]')).forEach((element) => {\n if (element.getAttribute('slot') == 'overflow')\n element.removeAttribute('slot');\n if (element.getAttribute('slot') == 'selected-overflow')\n element.setAttribute('slot', 'selected');\n });\n Array.from(this.querySelectorAll('.show')).forEach((element) => {\n element.classList.remove('show');\n });\n // Foreach safe area lets check what elements are slotted in them and if they need an overflow\n Array.from(this.shadowRoot.querySelectorAll('.safe-area')).forEach((element) => {\n var _a, _b, _c;\n // Decide on which overflow slot to use\n let overflowSlot = 'overflow';\n if (((_a = element.querySelector('slot')) === null || _a === void 0 ? void 0 : _a.hasAttribute('name')) &&\n ((_b = element.querySelector('slot')) === null || _b === void 0 ? void 0 : _b.getAttribute('name')) == 'selected')\n overflowSlot = 'selected-overflow';\n // Get the slotted elements, remember they aren't children of the safe area\n const elements = (_c = element.querySelector('slot')) === null || _c === void 0 ? void 0 : _c.assignedElements();\n let tempWidth = 44 * modifier; // Allow space for the overflow button\n // If search then allow for the search button width\n if (this.hasAttribute('data-search'))\n tempWidth += 44 * modifier;\n // Foreach element this isn't an action button or dialog wrapper add to the width, these will not be moved into the overflow slot\n for (let i = 0; i < elements.length; i++) {\n if (!elements[i].classList.contains('btn-action') && !elements[i].classList.contains('menu__wrapper ')) {\n tempWidth += elements[i].offsetWidth;\n tempWidth += elementMargin;\n }\n }\n // Foreach dialog wrapper decide if safe in safe area or move into the overflow slot, dialog wrappers have priority over the action buttons\n for (let i = 0; i < elements.length; i++) {\n if (elements[i].classList.contains('menu__wrapper ')) {\n elements[i].classList.add('show');\n tempWidth += elements[i].offsetWidth;\n tempWidth += elementMargin / 2;\n // If we have exceeded the safe area then lets break the loop\n if (tempWidth - elementMargin / 2 > safeAreaWidth) {\n elements[i].classList.remove('show');\n break;\n }\n }\n }\n // Foreach action button\n for (let i = 0; i < elements.length; i++) {\n if (elements[i].classList.contains('btn-action')) {\n elements[i].classList.add('show');\n tempWidth += elements[i].offsetWidth;\n tempWidth += elementMargin / 2;\n // If we have exceeded the safe area then lets break the loop\n if (tempWidth - elementMargin / 2 > safeAreaWidth) {\n elements[i].classList.remove('show');\n break;\n }\n }\n }\n const overflowDialog = element.querySelector('.dialog-overflow');\n if (overflowDialog)\n overflowDialog.classList.add('d-none');\n // Decide which elements go into the overflow slot\n for (let i = 0; i < elements.length; i++) {\n if (elements[i].classList.contains('btn-action') || elements[i].classList.contains('menu__wrapper ')) {\n if (!elements[i].classList.contains('show')) {\n // Move to the slot by changing the attribute\n elements[i].setAttribute('slot', overflowSlot);\n // if an element has been added to overflow slot then make sure we show the overflow menu button\n if (overflowDialog)\n overflowDialog.classList.remove('d-none');\n }\n }\n }\n });\n };\n // Check buttons on load and when the wrapper element gets resized.\n hideButtons();\n new ResizeObserver(hideButtons).observe(actionbarWrapper);\n // #endregion\n // #region cloumn filters\n const setColumnFilters = () => {\n let columnsHidden = '';\n Array.from(checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.querySelectorAll('label input')).forEach((element, index) => {\n columnsHidden += this.hasAttribute(`data-hide-col${index + 1}`) ? `${index + 1},` : '';\n });\n this.setAttribute('data-columns-shown', checklistHolder.querySelectorAll('input:checked').length);\n const dispatchedEvent = new CustomEvent('columm-filters-set', {\n detail: {\n columnsHidden: columnsHidden.slice(0, -1),\n },\n });\n this.dispatchEvent(dispatchedEvent);\n };\n if (this.hasAttribute('data-filter-columns') || this.hasAttribute('data-filter-columns-save')) {\n const columns = this.closest('iam-table').querySelectorAll('thead th');\n Array.from(columns).forEach((element, index) => {\n if (element.textContent) {\n checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.insertAdjacentHTML('beforeend', `<label class=\"m-0\" title=\"Change the display of \"><input name=\"hideCol${index + 1}\" value=\"${index + 1}\" type=\"checkbox\" ${this.hasAttribute('data-hide-col' + (index + 1)) ? '' : 'checked'} /> ${element.textContent}</label>`);\n }\n });\n }\n this.setAttribute('data-columns-shown', checklistHolder.querySelectorAll('input:checked').length);\n if (this.hasAttribute('data-filter-columns') && !this.hasAttribute('data-filter-columns-save')) {\n checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('input')) {\n const checkbox = event.target.closest('input');\n if ((checkbox === null || checkbox === void 0 ? void 0 : checkbox.checked) == false) {\n this.setAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value), 'true');\n }\n else {\n this.removeAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value));\n }\n setColumnFilters();\n }\n });\n }\n if (this.hasAttribute('data-filter-columns-save')) {\n const checklistHolder = (_k = this.shadowRoot) === null || _k === void 0 ? void 0 : _k.querySelector('.checklists');\n const checklistSave = (_l = this.shadowRoot) === null || _l === void 0 ? void 0 : _l.querySelector('#saveColumns');\n const checklistCancel = (_m = this.shadowRoot) === null || _m === void 0 ? void 0 : _m.querySelector('#cancelColumns');\n checklistSave === null || checklistSave === void 0 ? void 0 : checklistSave.addEventListener('click', (event) => {\n var _a;\n Array.from(checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.querySelectorAll('label input')).forEach((checkbox) => {\n if ((checkbox === null || checkbox === void 0 ? void 0 : checkbox.checked) == false) {\n this.setAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value), 'true');\n }\n else {\n this.removeAttribute('data-hide-col' + (checkbox === null || checkbox === void 0 ? void 0 : checkbox.value));\n }\n });\n setColumnFilters();\n (_a = checklistSave.closest('dialog')) === null || _a === void 0 ? void 0 : _a.close();\n });\n // Revert back to what was previously saved\n checklistCancel === null || checklistCancel === void 0 ? void 0 : checklistCancel.addEventListener('click', (event) => {\n var _a, _b;\n const checklistHolder = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.checklists');\n Array.from(checklistHolder === null || checklistHolder === void 0 ? void 0 : checklistHolder.querySelectorAll('label input')).forEach((element, index) => {\n element.checked = this.hasAttribute(`data-hide-col${index + 1}`) ? false : true;\n });\n setColumnFilters();\n (_b = checklistSave.closest('dialog')) === null || _b === void 0 ? void 0 : _b.close();\n });\n }\n // #endregion\n }\n static get observedAttributes() {\n return ['data-selected'];\n }\n attributeChangedCallback(attrName, oldVal, newVal) {\n switch (attrName) {\n case 'data-selected': {\n const selectAll = this.shadowRoot.querySelector('.selectall');\n if (selectAll)\n setSelectAllInput(selectAll, newVal);\n const event = new CustomEvent('selected', { detail: { selected: newVal } });\n this.dispatchEvent(event);\n if (newVal == 'all' && this.hasAttribute('data-select-watch')) {\n const element = document.getElementById(String(this.getAttribute('data-select-watch')));\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n input.checked = true;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.setAttribute('data-selected', 'true');\n });\n }\n if (newVal == '0' && this.hasAttribute('data-select-watch')) {\n const element = document.getElementById(String(this.getAttribute('data-select-watch')));\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input) => {\n var _a;\n input.checked = false;\n if (input.closest('iam-card'))\n (_a = input.closest('iam-card')) === null || _a === void 0 ? void 0 : _a.removeAttribute('data-selected');\n });\n }\n break;\n }\n }\n }\n}\nexport default iamActionbar;\n"],"names":["uniqueID","index","iamMenu","template","menuID","menuButton","topLevelmenuItems","menuItems","subNextIndex","subPrevIndex","item","event","activeItem","prevIndex","nextIndex","subMenuItems","_a","_b","_c","_d","updateEvent","button","popoverID","popover","viewportOffset","top","left","setSelectAllInput","element","value","iamActionbar","_e","_f","_g","_h","_j","_k","_l","_m","actionbarWrapper","checklistHolder","dialog","btn","id","selectAll","cancelButton","input","count","countChecked","btns","viewList","view","icon","views","switchEvent","searchBar","searchBtn","searchInput","keyupEvent","changeEvent","submitEvent","clearBtn","e","hideButtons","wrapperWidth","screenWidth","safeAreaWidth","elementMargin","tabletSafeWidth","mobileSafeWidth","modifier","overflowSlot","elements","tempWidth","i","overflowDialog","setColumnFilters","columnsHidden","dispatchedEvent","columns","checkbox","checklistSave","checklistCancel","attrName","oldVal","newVal"],"mappings":"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"}
@@ -25,64 +25,64 @@ class iamAddressLookup extends HTMLElement {
25
25
  : '/assets';
26
26
  const loadCSS = `@import "${assetLocation}/css/components/address-lookup.component.css";`;
27
27
  const template = document.createElement('template');
28
- template.innerHTML = `
29
- <style>
30
- ${loadCSS}
31
-
32
- </style>
33
- <link rel="stylesheet" href="https://kit.fontawesome.com/8bd0fca975.css" crossorigin="anonymous" />
34
- <div class="wrapper">
35
-
36
- <div class="matched d-none">
37
- <div class="inner">
38
- <p><span class="matched-address"></span></p>
39
- <button class="link use-matched">Yes, use this address</button>
40
- <button class="link use-entered">No, use the address I entered</button>
41
- </div>
42
- <span class="invalid-feedback">We found a matching address based on the details you entered. Is this address correct?</span>
43
- </div>
44
- <div class="postcode-lookup was-validated">
45
- <div>
46
- <label class="mb-1"><span class="title text-lowercase"></span>
47
- <span>
48
- <input type="text" name="postcode" class="${this.hasAttribute('data-input-class') ? this.getAttribute('data-input-class') : ''}" list="address-lookup__addressess" autocomplete="one-time-code" aria-autocomplete="none" placeholder="${(this === null || this === void 0 ? void 0 : this.hasAttribute('data-placeholder')) ? this === null || this === void 0 ? void 0 : this.getAttribute('data-placeholder') : 'Postcode'}" value="${this.hasAttribute('data-postcode-value') ? this.getAttribute('data-postcode-value') : ''}" part="input" />
49
- <button id="postcode__submit" class="suffix fa-regular fa-search" part="suffix"></button>
50
- </span>
51
- </label>
52
- <span class="invalid-feedback mb-2" id="invalid-feedback-address-lookup">${this.hasAttribute('data-error-msg') ? this.getAttribute('data-error-msg') : 'Required address fields'}</span>
53
-
54
- <div class="datalist__wrapper ${this.hasAttribute('data-list-class') ? this.getAttribute('data-list-class') : ''}" tabindex="0" part="list-wrapper">
55
- <slot name="beforeList"></slot>
56
- <slot name="preloadedList"></slot>
57
- <datalist id="address-lookup__addressess" class=""></datalist>
58
- <div id="paginationWrapper"></div>
59
- <slot name="afterList"></slot>
60
- </div>
61
- </div>
62
- <slot name="hint"></slot>
63
- <div class="actions">
64
- <button class="btn btn-tertiary switch-to-manual-btn" type="button" part="manualButton">Or enter address manually</button>
65
- <slot name="actions"></slot>
66
- </div>
67
- </div>
68
-
69
- <div class="manual-address pb-2 js-hide">
70
- <slot part="contents"></slot>
71
- <button class="btn btn-tertiary switch-to-lookup-btn" type="button" part="button">${this.hasAttribute('data-postcode-lookup-label') ? this.getAttribute('data-postcode-lookup-label') : 'Use postcode lookup'}</button>
72
- <slot name="after"></slot>
73
- </div>
74
- <div class="pre-filled p-2 js-hide">
75
- <strong class="title text-primary d-block"></strong>
76
- <p><span class="pre-filled-address"></span>
77
- <button class="link m-0 text-primary ms-2 cursor-pointer" type="button" part="edit-button">
78
- <i class="fa-regular fa-pen-to-square m-0"></i> <span class="visually-hidden">Edit</span>
79
- </button>
80
- <button class="link m-0 text-primary ms-2 cursor-pointer" type="button" part="remove-button">
81
- <i class="fa-regular fa-trash m-0"></i> <span class="visually-hidden">Remove</span>
82
- </button>
83
- <slot name="prefilled"></slot></p>
84
- </div>
85
- </div>
28
+ template.innerHTML = `
29
+ <style>
30
+ ${loadCSS}
31
+
32
+ </style>
33
+ <link rel="stylesheet" href="https://kit.fontawesome.com/8bd0fca975.css" crossorigin="anonymous" />
34
+ <div class="wrapper">
35
+
36
+ <div class="matched d-none">
37
+ <div class="inner">
38
+ <p><span class="matched-address"></span></p>
39
+ <button class="link use-matched">Yes, use this address</button>
40
+ <button class="link use-entered">No, use the address I entered</button>
41
+ </div>
42
+ <span class="invalid-feedback">We found a matching address based on the details you entered. Is this address correct?</span>
43
+ </div>
44
+ <div class="postcode-lookup was-validated">
45
+ <div>
46
+ <label class="mb-1"><span class="title text-lowercase"></span>
47
+ <span>
48
+ <input type="text" name="postcode" class="${this.hasAttribute('data-input-class') ? this.getAttribute('data-input-class') : ''}" list="address-lookup__addressess" autocomplete="one-time-code" aria-autocomplete="none" placeholder="${(this === null || this === void 0 ? void 0 : this.hasAttribute('data-placeholder')) ? this === null || this === void 0 ? void 0 : this.getAttribute('data-placeholder') : 'Postcode'}" value="${this.hasAttribute('data-postcode-value') ? this.getAttribute('data-postcode-value') : ''}" part="input" />
49
+ <button id="postcode__submit" class="suffix fa-regular fa-search" part="suffix"></button>
50
+ </span>
51
+ </label>
52
+ <span class="invalid-feedback mb-2" id="invalid-feedback-address-lookup">${this.hasAttribute('data-error-msg') ? this.getAttribute('data-error-msg') : 'Required address fields'}</span>
53
+
54
+ <div class="datalist__wrapper ${this.hasAttribute('data-list-class') ? this.getAttribute('data-list-class') : ''}" tabindex="0" part="list-wrapper">
55
+ <slot name="beforeList"></slot>
56
+ <slot name="preloadedList"></slot>
57
+ <datalist id="address-lookup__addressess" class=""></datalist>
58
+ <div id="paginationWrapper"></div>
59
+ <slot name="afterList"></slot>
60
+ </div>
61
+ </div>
62
+ <slot name="hint"></slot>
63
+ <div class="actions">
64
+ <button class="btn btn-tertiary switch-to-manual-btn" type="button" part="manualButton">Or enter address manually</button>
65
+ <slot name="actions"></slot>
66
+ </div>
67
+ </div>
68
+
69
+ <div class="manual-address pb-2 js-hide">
70
+ <slot part="contents"></slot>
71
+ <button class="btn btn-tertiary switch-to-lookup-btn" type="button" part="button">${this.hasAttribute('data-postcode-lookup-label') ? this.getAttribute('data-postcode-lookup-label') : 'Use postcode lookup'}</button>
72
+ <slot name="after"></slot>
73
+ </div>
74
+ <div class="pre-filled p-2 js-hide">
75
+ <strong class="title text-primary d-block"></strong>
76
+ <p><span class="pre-filled-address"></span>
77
+ <button class="link m-0 text-primary ms-2 cursor-pointer" type="button" part="edit-button">
78
+ <i class="fa-regular fa-pen-to-square m-0"></i> <span class="visually-hidden">Edit</span>
79
+ </button>
80
+ <button class="link m-0 text-primary ms-2 cursor-pointer" type="button" part="remove-button">
81
+ <i class="fa-regular fa-trash m-0"></i> <span class="visually-hidden">Remove</span>
82
+ </button>
83
+ <slot name="prefilled"></slot></p>
84
+ </div>
85
+ </div>
86
86
  `;
87
87
  (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(template.content.cloneNode(true));
88
88
  }
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * iamKey v7.7.1--beta6
2
+ * iamKey v7.7.1--beta7
3
3
  * Copyright 2022-2026 iamproperty
4
4
  *//*! js-cookie v3.0.5 | MIT */function O(d){for(var i=1;i<arguments.length;i++){var s=arguments[i];for(var b in s)d[b]=s[b]}return d}var it={read:function(d){return d[0]==='"'&&(d=d.slice(1,-1)),d.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(d){return encodeURIComponent(d).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}};function Y(d,i){function s(e,m,l){if(!(typeof document>"u")){l=O({},i,l),typeof l.expires=="number"&&(l.expires=new Date(Date.now()+l.expires*864e5)),l.expires&&(l.expires=l.expires.toUTCString()),e=encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);var g="";for(var t in l)l[t]&&(g+="; "+t,l[t]!==!0&&(g+="="+l[t].split(";")[0]));return document.cookie=e+"="+d.write(m,e)+g}}function b(e){if(!(typeof document>"u"||arguments.length&&!e)){for(var m=document.cookie?document.cookie.split("; "):[],l={},g=0;g<m.length;g++){var t=m[g].split("="),o=t.slice(1).join("=");try{var c=decodeURIComponent(t[0]);if(l[c]=d.read(o,c),e===c)break}catch{}}return e?l[e]:l}}return Object.create({set:s,get:b,remove:function(e,m){s(e,"",O({},m,{expires:-1}))},withAttributes:function(e){return Y(this.converter,O({},this.attributes,e))},withConverter:function(e){return Y(O({},this.converter,e),this.attributes)}},{attributes:{value:Object.freeze(i)},converter:{value:Object.freeze(d)}})}var at=Y(it,{path:"/"});function ot(d,i,s,b=!1){let e=-1;s.closest(".datalist__wrapper")&&s.closest(".datalist__wrapper"),i.setAttribute("data-list",i.getAttribute("list")),i.setAttribute("list",""),i.hasAttribute("placeholder")&&i.setAttribute("data-placeholder",i.getAttribute("placeholder")),i.hasAttribute("placeholder")&&i.setAttribute("data-original-placeholder",i.getAttribute("placeholder")),i.addEventListener("focus",function(){i.value!=""&&(i.setAttribute("placeholder",i.value),i.setAttribute("data-value",i.value)),i.value=""}),i.addEventListener("blur",function(){i.hasAttribute("data-value")&&(i.value=i.getAttribute("data-value")),i.hasAttribute("data-placeholder")&&i.setAttribute("placeholder",i.getAttribute("data-placeholder"))});for(const o of s.options)o.innerHTML==""&&(o.innerHTML=o.value);s.addEventListener("click",function(o){var c;if(o&&o.target instanceof HTMLElement&&o.target.closest("option")){const v=o.target.closest("option"),S=((c=v.textContent)===null||c===void 0?void 0:c.trim())||v.value,$=d.querySelector('input[type="hidden"]');$&&($.value=v.value,$.setAttribute("value",v.value)),i.value=S,i.setAttribute("data-value",S),i.setAttribute("placeholder",S),typeof window.triggerDynamicEvent=="function"&&window.triggerDynamicEvent(i);for(const N of s.options)N.classList.remove("active");v.classList.add("active"),setTimeout(()=>{d.dispatchEvent(new CustomEvent("update-value",{detail:{value:v.value,text:S}}))},0)}}),i.addEventListener("input",function(){if(i.removeAttribute("data-value"),e=-1,d.tagName!="IAM-ADDRESS-LOOKUP"){const o=i.value.toUpperCase();for(const c of s.options)(c.textContent||c.value).toUpperCase().indexOf(o)>-1?(c.style.display="block",c.classList.remove("hide")):(c.style.display="none",c.classList.add("hide"))}}),d.addEventListener("keydown",function(o){o.keyCode==40?(e++,m(s.options)):o.keyCode==38?(e--,m(s.options)):o.keyCode==13&&(o.preventDefault(),e>-1&&s.options&&s.options[e].click())});function m(o){if(!o)return!1;l(o),e>=o.length&&(e=0),e<0&&(e=o.length-1),o[e].classList.add("active")}function l(o){if(!o)return!1;for(let c=0;c<o.length;c++)o[c].classList.remove("active")}i.closest("label").insertAdjacentHTML("beforeend",'<button class="empty btn btn-action" type="button"><i class="fa-light fa-times me-0"></i></button>');const g=()=>{const o=d.querySelector('input[type="hidden"]');o&&(o.value="",o.setAttribute("value","")),i.removeAttribute("placeholder"),i.hasAttribute("data-original-placeholder")&&i.setAttribute("placeholder",i.getAttribute("data-original-placeholder")),i.removeAttribute("data-value"),i.value="";for(const v of s.options)v.classList.remove("active"),v.classList.remove("hide"),v.removeAttribute("style");const c=new CustomEvent("close-button-pressed");d.dispatchEvent(c),d.dispatchEvent(new CustomEvent("update-value",{detail:{value:"",text:""}}))};(d.querySelector(".empty")?d.querySelector(".empty"):d.shadowRoot.querySelector(".empty")).addEventListener("click",function(o){g()}),d.addEventListener("empty",function(o){g()})}const rt=d=>/^([A-Z][A-HJ-Y]?[0-9][A-Z0-9]? ?[0-9][A-Z]{2}|GIR ?0A{2})$/gmi.test(d.trim());var tt=function(d,i,s,b){function e(m){return m instanceof s?m:new s(function(l){l(m)})}return new(s||(s=Promise))(function(m,l){function g(c){try{o(b.next(c))}catch(v){l(v)}}function t(c){try{o(b.throw(c))}catch(v){l(v)}}function o(c){c.done?m(c.value):e(c.value).then(g,t)}o((b=b.apply(d,i||[])).next())})};window.dataLayer=window.dataLayer||[],window.dataLayer.push({event:"customElementRegistered",element:"Address Lookup"});class nt extends HTMLElement{constructor(){var i;super(),this.attachShadow({mode:"open"}),document.body.hasAttribute("data-assets-location")&&document.body.getAttribute("data-assets-location");const s=document.createElement("template");s.innerHTML=`
5
5
  <style>