@iamproperty/components 7.0.0 → 7.1.0--beta2

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 (411) hide show
  1. package/assets/css/components/actionbar.css.map +1 -1
  2. package/assets/css/components/actionbar.global.css.map +1 -1
  3. package/assets/css/components/address-lookup.css.map +1 -1
  4. package/assets/css/components/applied-filters.css.map +1 -1
  5. package/assets/css/components/barchart.component.css +1 -1
  6. package/assets/css/components/barchart.component.css.map +1 -1
  7. package/assets/css/components/card.component.css +1 -1
  8. package/assets/css/components/card.component.css.map +1 -1
  9. package/assets/css/components/card.module.css.map +1 -1
  10. package/assets/css/components/carousel.component.css +1 -1
  11. package/assets/css/components/carousel.component.css.map +1 -1
  12. package/assets/css/components/carousel.config.css.map +1 -1
  13. package/assets/css/components/charts.config.css.map +1 -1
  14. package/assets/css/components/charts.css +1 -1
  15. package/assets/css/components/charts.css.map +1 -1
  16. package/assets/css/components/charts.module.css +1 -1
  17. package/assets/css/components/charts.module.css.map +1 -1
  18. package/assets/css/components/collapsible-side.css.map +1 -1
  19. package/assets/css/components/fileupload.css.map +1 -1
  20. package/assets/css/components/filter-card.component.css.map +1 -1
  21. package/assets/css/components/header.css.map +1 -1
  22. package/assets/css/components/inline-edit.css.map +1 -1
  23. package/assets/css/components/inline-edit.preload.css.map +1 -1
  24. package/assets/css/components/marketing.css.map +1 -1
  25. package/assets/css/components/multi-step.component.css.map +1 -1
  26. package/assets/css/components/multiselect.css +1 -1
  27. package/assets/css/components/multiselect.css.map +1 -1
  28. package/assets/css/components/multiselect.preload.css.map +1 -1
  29. package/assets/css/components/nav.css +1 -1
  30. package/assets/css/components/nav.css.map +1 -1
  31. package/assets/css/components/nav.docs.css.map +1 -1
  32. package/assets/css/components/nav.global.css +1 -1
  33. package/assets/css/components/nav.global.css.map +1 -1
  34. package/assets/css/components/nav.old.css +1 -1
  35. package/assets/css/components/nav.old.css.map +1 -1
  36. package/assets/css/components/nav.preload.css.map +1 -1
  37. package/assets/css/components/notification.css.map +1 -1
  38. package/assets/css/components/notification.global.css.map +1 -1
  39. package/assets/css/components/pagination.css.map +1 -1
  40. package/assets/css/components/property-searchbar.css +1 -1
  41. package/assets/css/components/property-searchbar.css.map +1 -1
  42. package/assets/css/components/record-card.component.css.map +1 -1
  43. package/assets/css/components/slider.css.map +1 -1
  44. package/assets/css/components/snapshot.css.map +1 -1
  45. package/assets/css/components/stepper.css.map +1 -1
  46. package/assets/css/components/table.css +1 -1
  47. package/assets/css/components/table.css.map +1 -1
  48. package/assets/css/components/table.global.css +1 -1
  49. package/assets/css/components/table.global.css.map +1 -1
  50. package/assets/css/components/tabs.css.map +1 -1
  51. package/assets/css/components/testimonial.css.map +1 -1
  52. package/assets/css/components/timeline.css +1 -1
  53. package/assets/css/components/timeline.css.map +1 -1
  54. package/assets/css/components/video-card.component.css.map +1 -1
  55. package/assets/css/core.min.css +1 -1
  56. package/assets/css/core.min.css.map +1 -1
  57. package/assets/css/style.min.css +1 -1
  58. package/assets/css/style.min.css.map +1 -1
  59. package/assets/js/components/_global.js +8 -8
  60. package/assets/js/components/accordion/accordion.component.js +13 -10
  61. package/assets/js/components/accordion/accordion.component.min.js +4 -4
  62. package/assets/js/components/accordion/accordion.component.min.js.map +1 -1
  63. package/assets/js/components/actionbar/actionbar.component.js +97 -83
  64. package/assets/js/components/actionbar/actionbar.component.min.js +5 -5
  65. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  66. package/assets/js/components/address-lookup/address-lookup.component.js +30 -26
  67. package/assets/js/components/address-lookup/address-lookup.component.min.js +4 -4
  68. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  69. package/assets/js/components/applied-filters/applied-filters.component.js +10 -6
  70. package/assets/js/components/applied-filters/applied-filters.component.min.js +3 -3
  71. package/assets/js/components/applied-filters/applied-filters.component.min.js.map +1 -1
  72. package/assets/js/components/barchart/barchart.component.js +8 -7
  73. package/assets/js/components/barchart/barchart.component.min.js +4 -4
  74. package/assets/js/components/barchart/barchart.component.min.js.map +1 -1
  75. package/assets/js/components/card/card.component.js +27 -12
  76. package/assets/js/components/card/card.component.min.js +3 -3
  77. package/assets/js/components/card/card.component.min.js.map +1 -1
  78. package/assets/js/components/carousel/carousel.component.js +18 -12
  79. package/assets/js/components/carousel/carousel.component.min.js +4 -4
  80. package/assets/js/components/carousel/carousel.component.min.js.map +1 -1
  81. package/assets/js/components/chart/chart.component.js +9 -8
  82. package/assets/js/components/collapsible-side/collapsible-side.component.js +20 -8
  83. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +1 -1
  84. package/assets/js/components/collapsible-side/collapsible-side.component.min.js.map +1 -1
  85. package/assets/js/components/fileupload/fileupload.component.js +11 -7
  86. package/assets/js/components/fileupload/fileupload.component.min.js +2 -2
  87. package/assets/js/components/fileupload/fileupload.component.min.js.map +1 -1
  88. package/assets/js/components/filter-card/filter-card.component.js +19 -9
  89. package/assets/js/components/filter-card/filter-card.component.min.js +2 -2
  90. package/assets/js/components/filter-card/filter-card.component.min.js.map +1 -1
  91. package/assets/js/components/filterlist/filterlist.component.js +10 -6
  92. package/assets/js/components/filterlist/filterlist.component.min.js +3 -3
  93. package/assets/js/components/filterlist/filterlist.component.min.js.map +1 -1
  94. package/assets/js/components/header/header.component.js +8 -4
  95. package/assets/js/components/header/header.component.min.js +1 -1
  96. package/assets/js/components/header/header.component.min.js.map +1 -1
  97. package/assets/js/components/inline-edit/inline-edit.component.js +43 -23
  98. package/assets/js/components/inline-edit/inline-edit.component.min.js +4 -4
  99. package/assets/js/components/inline-edit/inline-edit.component.min.js.map +1 -1
  100. package/assets/js/components/marketing/marketing.component.js +11 -5
  101. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  102. package/assets/js/components/marketing/marketing.component.min.js.map +1 -1
  103. package/assets/js/components/multi-step/multi-step.component.js +22 -19
  104. package/assets/js/components/multiselect/multiselect.component.js +62 -45
  105. package/assets/js/components/multiselect/multiselect.component.min.js +5 -5
  106. package/assets/js/components/multiselect/multiselect.component.min.js.map +1 -1
  107. package/assets/js/components/nav/nav.component.js +57 -38
  108. package/assets/js/components/nav/nav.component.min.js +5 -5
  109. package/assets/js/components/nav/nav.component.min.js.map +1 -1
  110. package/assets/js/components/notification/notification.component.js +9 -5
  111. package/assets/js/components/notification/notification.component.min.js +5 -5
  112. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  113. package/assets/js/components/pagination/pagination.component.js +18 -14
  114. package/assets/js/components/pagination/pagination.component.min.js +2 -2
  115. package/assets/js/components/pagination/pagination.component.min.js.map +1 -1
  116. package/assets/js/components/record-card/record-card.component.js +10 -8
  117. package/assets/js/components/record-card/record-card.component.min.js +2 -2
  118. package/assets/js/components/record-card/record-card.component.min.js.map +1 -1
  119. package/assets/js/components/search/search.component.js +22 -17
  120. package/assets/js/components/search/search.component.min.js +4 -4
  121. package/assets/js/components/search/search.component.min.js.map +1 -1
  122. package/assets/js/components/slider/slider.component.js +25 -21
  123. package/assets/js/components/slider/slider.component.min.js +3 -3
  124. package/assets/js/components/slider/slider.component.min.js.map +1 -1
  125. package/assets/js/components/table/table.component.js +30 -24
  126. package/assets/js/components/table/table.component.min.js +7 -7
  127. package/assets/js/components/table/table.component.min.js.map +1 -1
  128. package/assets/js/components/tabs/tabs.component.js +10 -6
  129. package/assets/js/components/tabs/tabs.component.min.js +3 -3
  130. package/assets/js/components/tabs/tabs.component.min.js.map +1 -1
  131. package/assets/js/components/video-card/video-card.component.js +45 -33
  132. package/assets/js/components/video-card/video-card.component.min.js +3 -3
  133. package/assets/js/components/video-card/video-card.component.min.js.map +1 -1
  134. package/assets/js/components.bundle.js +1 -1
  135. package/assets/js/components.bundle.js.map +1 -1
  136. package/assets/js/components.js +35 -8
  137. package/assets/js/modules/applied-filters.js +20 -20
  138. package/assets/js/modules/carousel.js +65 -60
  139. package/assets/js/modules/chart.js +184 -134
  140. package/assets/js/modules/chart.module.js +74 -63
  141. package/assets/js/modules/data-layer.js +17 -17
  142. package/assets/js/modules/dialogs.js +47 -38
  143. package/assets/js/modules/drawer.js +1 -1
  144. package/assets/js/modules/dynamicEvents.js +24 -24
  145. package/assets/js/modules/file-upload.js +8 -9
  146. package/assets/js/modules/fileupload.js +5 -5
  147. package/assets/js/modules/filterlist.js +4 -4
  148. package/assets/js/modules/form.js +22 -18
  149. package/assets/js/modules/helpers.js +54 -44
  150. package/assets/js/modules/inputs.js +25 -21
  151. package/assets/js/modules/nav.js +3 -1
  152. package/assets/js/modules/notification.js +6 -6
  153. package/assets/js/modules/orderablelist.js +12 -12
  154. package/assets/js/modules/pagination.js +5 -5
  155. package/assets/js/modules/table.js +242 -181
  156. package/assets/js/modules/tabs.js +71 -60
  157. package/assets/js/modules/testimonial.js +11 -12
  158. package/assets/js/scripts.bundle.js +1 -1
  159. package/assets/js/scripts.bundle.js.map +1 -1
  160. package/assets/js/scripts.bundle.min.js +1 -1
  161. package/assets/js/scripts.bundle.min.js.map +1 -1
  162. package/assets/js/scripts.js +1 -1
  163. package/assets/js/tests/chart.spec.js +5 -5
  164. package/assets/js/tests/filterlist.spec.js +2 -2
  165. package/assets/js/tests/slider.spec.js +2 -2
  166. package/assets/js/tests/table.spec.js +2 -2
  167. package/assets/js/vendor/hibp.js +4 -4
  168. package/assets/sass/_components.scss +28 -40
  169. package/assets/sass/_corefiles.scss +22 -29
  170. package/assets/sass/_elements.scss +19 -19
  171. package/assets/sass/_fonts.scss +10 -7
  172. package/assets/sass/_func.scss +14 -14
  173. package/assets/sass/_functions/functions.scss +115 -90
  174. package/assets/sass/_functions/mixins.scss +72 -112
  175. package/assets/sass/_functions/utilities.scss +447 -393
  176. package/assets/sass/_functions/variables.scss +1357 -1371
  177. package/assets/sass/_print.scss +18 -16
  178. package/assets/sass/_tests/colours.spec.scss +15 -14
  179. package/assets/sass/_tests/func.spec.scss +1 -2
  180. package/assets/sass/_tests/mixins.spec.scss +9 -14
  181. package/assets/sass/_tests/typography.spec.scss +1 -2
  182. package/assets/sass/_utilities.scss +8 -12
  183. package/assets/sass/components/actionbar.global.scss +45 -64
  184. package/assets/sass/components/actionbar.scss +58 -84
  185. package/assets/sass/components/address-lookup.scss +9 -11
  186. package/assets/sass/components/applied-filters.scss +3 -7
  187. package/assets/sass/components/barchart.component.scss +68 -99
  188. package/assets/sass/components/card.component.scss +35 -50
  189. package/assets/sass/components/card.module.scss +34 -37
  190. package/assets/sass/components/carousel.component.scss +198 -177
  191. package/assets/sass/components/carousel.config.scss +13 -19
  192. package/assets/sass/components/charts.config.scss +16 -23
  193. package/assets/sass/components/charts.module.scss +139 -178
  194. package/assets/sass/components/charts.scss +173 -232
  195. package/assets/sass/components/collapsible-side.scss +65 -98
  196. package/assets/sass/components/fileupload.scss +17 -23
  197. package/assets/sass/components/filter-card.component.scss +21 -28
  198. package/assets/sass/components/header.scss +24 -37
  199. package/assets/sass/components/inline-edit.preload.scss +24 -45
  200. package/assets/sass/components/inline-edit.scss +4 -5
  201. package/assets/sass/components/marketing.scss +19 -14
  202. package/assets/sass/components/multi-step.component.scss +36 -42
  203. package/assets/sass/components/multiselect.preload.scss +9 -12
  204. package/assets/sass/components/multiselect.scss +20 -24
  205. package/assets/sass/components/nav.docs.scss +7 -15
  206. package/assets/sass/components/nav.global.scss +123 -177
  207. package/assets/sass/components/nav.old.scss +64 -135
  208. package/assets/sass/components/nav.preload.scss +11 -12
  209. package/assets/sass/components/nav.scss +126 -173
  210. package/assets/sass/components/notification.global.scss +2 -3
  211. package/assets/sass/components/notification.scss +17 -32
  212. package/assets/sass/components/pagination.scss +32 -44
  213. package/assets/sass/components/property-searchbar.scss +2 -6
  214. package/assets/sass/components/record-card.component.scss +42 -55
  215. package/assets/sass/components/slider.scss +38 -35
  216. package/assets/sass/components/snapshot.scss +4 -10
  217. package/assets/sass/components/stepper.scss +14 -22
  218. package/assets/sass/components/table.global.scss +130 -171
  219. package/assets/sass/components/table.scss +17 -27
  220. package/assets/sass/components/tabs.scss +23 -32
  221. package/assets/sass/components/testimonial.scss +6 -14
  222. package/assets/sass/components/timeline.scss +8 -12
  223. package/assets/sass/components/video-card.component.scss +9 -14
  224. package/assets/sass/components.reset.scss +5 -5
  225. package/assets/sass/core.scss +3 -3
  226. package/assets/sass/elements/admin-panel.scss +41 -45
  227. package/assets/sass/elements/badge-tag.scss +16 -26
  228. package/assets/sass/elements/brand.scss +13 -16
  229. package/assets/sass/elements/buttons.scss +80 -106
  230. package/assets/sass/elements/container.scss +24 -133
  231. package/assets/sass/elements/details.scss +30 -50
  232. package/assets/sass/elements/dialog.scss +4 -6
  233. package/assets/sass/elements/forms.scss +421 -437
  234. package/assets/sass/elements/icons.scss +3 -4
  235. package/assets/sass/elements/links.scss +17 -25
  236. package/assets/sass/elements/lists.scss +30 -47
  237. package/assets/sass/elements/media.scss +1 -4
  238. package/assets/sass/elements/modal.scss +54 -80
  239. package/assets/sass/elements/popover.scss +28 -45
  240. package/assets/sass/elements/progress.scss +30 -40
  241. package/assets/sass/elements/table.element.scss +10 -15
  242. package/assets/sass/elements/tooltips.scss +27 -49
  243. package/assets/sass/elements/type.scss +47 -53
  244. package/assets/sass/email.scss +7 -9
  245. package/assets/sass/error.scss +23 -20
  246. package/assets/sass/foundations/bs_grid.scss +0 -1
  247. package/assets/sass/foundations/grid.scss +120 -122
  248. package/assets/sass/foundations/reboot.scss +27 -35
  249. package/assets/sass/foundations/root.scss +21 -31
  250. package/assets/sass/helpers/dynamic.scss +5 -5
  251. package/assets/sass/helpers/line-clamp.scss +1 -2
  252. package/assets/sass/helpers/max-height.scss +28 -36
  253. package/assets/sass/helpers/wider-colours.scss +2 -5
  254. package/assets/sass/main.scss +4 -4
  255. package/assets/sass/templates/auth.scss +11 -18
  256. package/assets/sass/templates/form.scss +16 -29
  257. package/assets/ts/components/_global.ts +14 -17
  258. package/assets/ts/components/accordion/accordion.component.ts +23 -19
  259. package/assets/ts/components/actionbar/README.md +8 -7
  260. package/assets/ts/components/actionbar/actionbar.component.ts +170 -220
  261. package/assets/ts/components/address-lookup/address-lookup.component.ts +94 -130
  262. package/assets/ts/components/applied-filters/README.md +1 -1
  263. package/assets/ts/components/applied-filters/applied-filters.component.ts +16 -15
  264. package/assets/ts/components/barchart/barchart.component.ts +29 -26
  265. package/assets/ts/components/card/card.component.ts +56 -57
  266. package/assets/ts/components/carousel/README.md +8 -9
  267. package/assets/ts/components/carousel/carousel.component.ts +30 -33
  268. package/assets/ts/components/chart/README.md +1 -3
  269. package/assets/ts/components/chart/chart.component.ts +24 -36
  270. package/assets/ts/components/collapsible-side/README.md +1 -1
  271. package/assets/ts/components/collapsible-side/collapsible-side.component.ts +44 -57
  272. package/assets/ts/components/fileupload/README.md +3 -3
  273. package/assets/ts/components/fileupload/fileupload.component.ts +23 -28
  274. package/assets/ts/components/filter-card/filter-card.component.ts +32 -33
  275. package/assets/ts/components/filterlist/README.md +3 -3
  276. package/assets/ts/components/filterlist/filterlist.component.ts +18 -16
  277. package/assets/ts/components/header/README.md +8 -9
  278. package/assets/ts/components/header/header.component.ts +15 -16
  279. package/assets/ts/components/inline-edit/README.md +1 -0
  280. package/assets/ts/components/inline-edit/inline-edit.component.ts +71 -71
  281. package/assets/ts/components/marketing/marketing.component.ts +17 -16
  282. package/assets/ts/components/multi-step/multi-step.component.ts +114 -156
  283. package/assets/ts/components/multiselect/README.md +5 -5
  284. package/assets/ts/components/multiselect/multiselect.component.ts +116 -133
  285. package/assets/ts/components/nav/README.md +13 -13
  286. package/assets/ts/components/nav/nav.component.ts +171 -167
  287. package/assets/ts/components/notification/README.md +9 -9
  288. package/assets/ts/components/notification/notification.component.ts +33 -32
  289. package/assets/ts/components/pagination/README.md +12 -12
  290. package/assets/ts/components/pagination/pagination.component.ts +51 -69
  291. package/assets/ts/components/record-card/record-card.component.ts +24 -34
  292. package/assets/ts/components/search/README.md +6 -7
  293. package/assets/ts/components/search/search.component.ts +75 -91
  294. package/assets/ts/components/slider/slider.component.ts +62 -77
  295. package/assets/ts/components/table/README.md +8 -8
  296. package/assets/ts/components/table/table.component.ts +97 -134
  297. package/assets/ts/components/tabs/README.md +4 -4
  298. package/assets/ts/components/tabs/tabs.component.ts +16 -14
  299. package/assets/ts/components/video-card/video-card.component.ts +89 -93
  300. package/assets/ts/components.ts +44 -20
  301. package/assets/ts/html.d.ts +1 -7
  302. package/assets/ts/modules/applied-filters.ts +104 -135
  303. package/assets/ts/modules/card.module.ts +13 -18
  304. package/assets/ts/modules/carousel.ts +194 -195
  305. package/assets/ts/modules/chart.module.ts +201 -246
  306. package/assets/ts/modules/chart.ts +454 -472
  307. package/assets/ts/modules/data-layer.md +35 -31
  308. package/assets/ts/modules/data-layer.ts +18 -18
  309. package/assets/ts/modules/dialogs.ts +113 -117
  310. package/assets/ts/modules/drawer.ts +7 -9
  311. package/assets/ts/modules/dynamicEvents.ts +67 -100
  312. package/assets/ts/modules/file-upload.ts +43 -40
  313. package/assets/ts/modules/fileupload.ts +38 -60
  314. package/assets/ts/modules/filterlist.ts +14 -20
  315. package/assets/ts/modules/form.ts +126 -128
  316. package/assets/ts/modules/helpers.ts +114 -120
  317. package/assets/ts/modules/inputs.ts +88 -120
  318. package/assets/ts/modules/nav.ts +19 -18
  319. package/assets/ts/modules/notification.ts +28 -32
  320. package/assets/ts/modules/orderablelist.ts +90 -82
  321. package/assets/ts/modules/pagination.ts +14 -19
  322. package/assets/ts/modules/table.ts +516 -599
  323. package/assets/ts/modules/tabs.ts +120 -145
  324. package/assets/ts/modules/testimonial.ts +59 -64
  325. package/assets/ts/scripts.ts +7 -9
  326. package/assets/ts/tests/chart.spec.ts +11 -20
  327. package/assets/ts/tests/data-layer.spec.js +3 -4
  328. package/assets/ts/tests/filterlist.spec.ts +3 -6
  329. package/assets/ts/tests/slider.spec.ts +9 -15
  330. package/assets/ts/tests/table.spec.ts +7 -24
  331. package/assets/ts/vendor/hibp.ts +43 -43
  332. package/dist/components.es.js +280 -270
  333. package/dist/components.umd.js +67 -67
  334. package/dist/style.css +1 -1
  335. package/package.json +14 -4
  336. package/src/components/Accordion/Accordion.spec.js +25 -31
  337. package/src/components/Accordion/Accordion.vue +16 -19
  338. package/src/components/Accordion/AccordionItem.vue +39 -37
  339. package/src/components/Accordion/README.md +10 -12
  340. package/src/components/Actionbar/Actionbar.vue +15 -18
  341. package/src/components/Actionbar/README.md +8 -7
  342. package/src/components/AddressLookup/AddressLookup.vue +14 -16
  343. package/src/components/AppliedFilters/AppliedFilters.vue +14 -16
  344. package/src/components/Banner/Banner.spec.js +13 -15
  345. package/src/components/Banner/Banner.vue +19 -19
  346. package/src/components/Banner/README.md +8 -10
  347. package/src/components/BarChart/BarChart.vue +14 -16
  348. package/src/components/Card/Card.vue +13 -16
  349. package/src/components/Card/README.md +8 -8
  350. package/src/components/Carousel/Carousel.vue +15 -18
  351. package/src/components/Carousel/README.md +7 -7
  352. package/src/components/Chart/Chart.spec.js +64 -87
  353. package/src/components/Chart/Chart.vue +41 -40
  354. package/src/components/Chart/README.md +8 -9
  355. package/src/components/CollapsibleSideMenu/CollapsibleSideMenu.vue +8 -10
  356. package/src/components/CollapsibleSideMenu/README.md +1 -1
  357. package/src/components/FileUpload/FileUpload.vue +35 -40
  358. package/src/components/FileUpload/README.md +3 -3
  359. package/src/components/FilterCard/FilterCard.vue +14 -16
  360. package/src/components/Filterlist/Filterlist.vue +7 -9
  361. package/src/components/Filterlist/README.md +3 -3
  362. package/src/components/Header/Header.vue +23 -26
  363. package/src/components/Header/README.md +8 -9
  364. package/src/components/InlineEdit/InlineEdit.vue +26 -32
  365. package/src/components/Input/Input.vue +323 -233
  366. package/src/components/Input/README.md +11 -11
  367. package/src/components/Marketing/Marketing.vue +24 -27
  368. package/src/components/Marketing/README.md +7 -7
  369. package/src/components/MultiStep/MultiStep.vue +13 -15
  370. package/src/components/Multiselect/Multiselect.vue +14 -17
  371. package/src/components/Nav/Nav.vue +15 -29
  372. package/src/components/Nav/README.md +12 -12
  373. package/src/components/Nav-old/Nav.vue +88 -93
  374. package/src/components/Nav-old/README.md +11 -12
  375. package/src/components/NoteFeed/NoteFeed.vue +59 -56
  376. package/src/components/NoteFeed/README.md +6 -6
  377. package/src/components/Notification/Notification.vue +11 -15
  378. package/src/components/Notification/README.md +9 -9
  379. package/src/components/Pagination/Pagination.vue +14 -24
  380. package/src/components/Pagination/README.md +12 -12
  381. package/src/components/PropertySearchbar/PropertySearchbar.vue +191 -160
  382. package/src/components/PropertySearchbar/README.md +14 -15
  383. package/src/components/RecordCard/RecordCard.vue +14 -16
  384. package/src/components/Search/README.md +1 -1
  385. package/src/components/Search/Search.vue +13 -16
  386. package/src/components/Slider/Slider.vue +13 -16
  387. package/src/components/Snapshot/README.md +9 -10
  388. package/src/components/Snapshot/Snapshot.vue +15 -17
  389. package/src/components/Stepper/README.md +12 -13
  390. package/src/components/Stepper/Step.vue +22 -18
  391. package/src/components/Stepper/Stepper.spec.js +41 -46
  392. package/src/components/Stepper/Stepper.vue +17 -18
  393. package/src/components/Table/README.md +12 -11
  394. package/src/components/Table/Table.spec.js +17 -28
  395. package/src/components/Table/Table.vue +49 -48
  396. package/src/components/Tabs/README.md +8 -8
  397. package/src/components/Tabs/Tab.vue +21 -21
  398. package/src/components/Tabs/Tabs.vue +14 -17
  399. package/src/components/Testimonial/README.md +11 -12
  400. package/src/components/Testimonial/Testimonial.spec.js +22 -26
  401. package/src/components/Testimonial/Testimonial.vue +31 -25
  402. package/src/components/Timeline/README.md +3 -3
  403. package/src/components/Timeline/Timeline.spec.js +9 -11
  404. package/src/components/Timeline/Timeline.vue +10 -10
  405. package/src/components/VideoCard/VideoCard.vue +14 -16
  406. package/src/foundations/Logo/Logo.spec.js +30 -30
  407. package/src/foundations/Logo/Logo.vue +28 -28
  408. package/src/foundations/Logo/README.md +5 -4
  409. package/src/helpers/strings.js +11 -8
  410. package/src/index.js +27 -28
  411. package/src/vue-shim.d.ts +4 -4
@@ -1 +1 @@
1
- {"version":3,"file":"actionbar.component.min.js","sources":["../../modules/dialogs.js","actionbar.component.js"],"sourcesContent":["// @ts-nocheck\nconst extendDialogs = (body) => {\n Array.from(body.querySelectorAll('dialog[open]')).forEach((dialog, index) => {\n let parent = dialog.closest('.dialog__wrapper');\n if (!parent) {\n dialog.removeAttribute('open');\n dialog.showModal();\n dialog.focus();\n createDialog(dialog);\n }\n });\n // Dialogs/modals\n body.addEventListener('click', (event) => {\n if (event.target.tagName == 'IAM-ACTIONBAR')\n return false;\n // Modal\n if (event && event.target instanceof HTMLElement && event.target.closest('[data-modal]')) {\n const button = event.target.closest('[data-modal]');\n const modalID = button.hasAttribute('data-modal') ? button.getAttribute('data-modal') : button.getAttribute('data-filter');\n const dialog = document.querySelector(`dialog#${modalID}`);\n createDialog(dialog);\n // Open the modal!\n dialog.showModal();\n dialog.focus();\n if (!dialog.querySelector('iam-multi-step')) {\n let firstWidth = dialog.offsetWidth;\n dialog.setAttribute('style', `max-width: ${firstWidth}px;`);\n }\n // When the modal is opened we want to make sure any duplicate checkboxes are matching the originals\n Array.from(dialog.querySelectorAll('[data-duplicate]')).forEach((element, index) => {\n const id = element.getAttribute('data-duplicate');\n const originalInput = document.getElementById(id);\n if (element.checked != originalInput.checked) {\n element.checked = originalInput.checked;\n let changeEvent = new Event('change');\n element.dispatchEvent(changeEvent);\n }\n });\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"openModal\",\n \"id\": modalID\n });\n }\n ;\n // Close modal\n if (event && event.target instanceof HTMLElement && event.target.closest('button.dialog__close')) {\n const dialog = event.target.closest('dialog[open]');\n event.preventDefault();\n dialog.close();\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.classList.remove('active');\n });\n let closeEvent = new CustomEvent('dialog-closed', {\n bubbles: true,\n cancelable: true,\n detail: { modalId: dialog.id }\n });\n event.target.dispatchEvent(closeEvent);\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n // Track default close buttons\n if (event && event.target instanceof HTMLElement && event.target.closest('button[formmethod=\"dialog\"]')) {\n const dialog = event.target.closest('dialog[open]');\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.classList.remove('active');\n });\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n // Close the modal when clicked on the backdrop\n if (event && event.target instanceof HTMLElement && event.target.closest('dialog[open]')) {\n let dialog = event.target.closest('dialog[open]');\n // Small fix to make sure the dialog isn't a dialog inside of a dialog.\n var style = window.getComputedStyle(dialog);\n if (style.display === 'contents')\n dialog = dialog.parentNode.closest('dialog[open]');\n // Dont allow the backdrop to be clicked when transactional\n if (!dialog.classList.contains('dialog--transactional') && !dialog.classList.contains('dialog--acknowledgement')) {\n const dialogDimensions = dialog.getBoundingClientRect();\n if (event.clientX < dialogDimensions.left || event.clientX > dialogDimensions.right || event.clientY < dialogDimensions.top || event.clientY > dialogDimensions.bottom) {\n if (!event.target.closest('dialog *')) // Weird bug when interacting with radio input fields within dialogs cuases it to close\n dialog.close();\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n }\n }\n // Popover\n if (event && event.target instanceof HTMLElement && event.target.closest('.dialog__wrapper > button')) {\n event.stopPropagation();\n let btn = event.target.closest('.dialog__wrapper > button');\n let parent = btn.parentNode;\n let dataEvent = \"openPopover\";\n let popover = parent.querySelector(':scope > dialog');\n // close open dialogs\n if (document.querySelector('*:not([data-keep-open]) > dialog[open]') && document.querySelector('*:not([data-keep-open]) > dialog[open]') != popover) {\n // Check that the ope dialog isn't a parent of the dialog being opened\n if (btn.closest('dialog[open]') != document.querySelector('*:not([data-keep-open]) > dialog[open]')) {\n document.querySelector('*:not([data-keep-open]) > dialog[open]').close();\n }\n }\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.removeAttribute('aria-expanded');\n });\n if (popover.hasAttribute('open')) {\n popover.close();\n dataEvent = \"closePopover\";\n popover.removeAttribute('style');\n btn.removeAttribute('aria-expanded');\n }\n else {\n popover.show();\n btn.setAttribute('aria-expanded', true);\n var position = btn.getBoundingClientRect();\n let topOffset = position.top;\n let leftOffset = position.left;\n if (btn.closest('iam-table')) {\n let container = btn.closest('iam-table').parentNode.getBoundingClientRect();\n topOffset -= container.top;\n leftOffset -= container.left;\n }\n if (popover.classList.contains('dialog--fix')) {\n popover.setAttribute('style', `position:fixed;top: ${topOffset}px; left: ${leftOffset}px; margin: 3rem 0 0 0;`);\n }\n }\n // When the dialog is fixed it could dip under the viewport\n // Lets check the dimensions and transform it to appear above\n let boundingRec = popover.getBoundingClientRect();\n let popoverBottom = boundingRec.bottom - window.scrollY;\n let windowPos = window.innerHeight - window.scrollY;\n if (popoverBottom > windowPos) {\n let currentStyle = popover.hasAttribute('style') ? popover.getAttribute('style') + ' ' : '';\n popover.setAttribute('style', currentStyle + `transform: translate(0, calc(-100% - 4rem))`);\n // Check that the dialog doesn't go over the top of the page\n boundingRec = popover.getBoundingClientRect();\n let popoverTop = boundingRec.top - window.scrollY;\n if (popoverTop < 100)\n popover.removeAttribute('style');\n }\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": dataEvent,\n \"id\": btn.textContent\n });\n }\n ;\n // Close popovers when clicked away\n if (event && event.target instanceof HTMLElement && !event.target.closest('dialog[open]') && !event.target.closest('.dialog__wrapper > button')) {\n if (document.querySelector('.dialog__wrapper:not([data-keep-open]) > dialog[open]'))\n document.querySelector('.dialog__wrapper:not([data-keep-open]) > dialog[open]').close();\n Array.from(document.querySelectorAll('.dialog__wrapper:not([data-keep-open]) > button')).forEach((btnElement, index) => {\n btnElement.removeAttribute('aria-expanded');\n });\n }\n });\n return null;\n};\nexport const createDialog = (dialog) => {\n // If you are using Vue eevents and bindings its recommended to add in the .mh-lg div manually to the dialog\n if (!dialog.querySelector(':scope .mh-lg') && !dialog.querySelector('iam-multi-step')) {\n dialog.innerHTML = `<div class=\"mh-lg\">${dialog.innerHTML}</div>`;\n let dialogContent = dialog.querySelector('.mh-lg');\n let titleElement = dialog.querySelector('.mh-lg :is(.h1,.h2,.h3,.h4,.h5,.h6)');\n if (titleElement) {\n let optionalElement = titleElement.previousSibling;\n dialogContent.before(titleElement);\n if (optionalElement)\n titleElement.before(optionalElement);\n }\n }\n // Create close button is needed\n if (!dialog.querySelector(':scope > button:first-child'))\n dialog.insertAdjacentHTML('afterbegin', `<button class=\"dialog__close\">Close</button>`);\n};\nexport default extendDialogs;\n","// @ts-nocheck\nimport extendDialogs from \"../../modules/dialogs.js\";\n// Data layer Web component created\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') ? document.body.getAttribute('data-assets-location') : '/assets';\n const coreCSS = document.body.hasAttribute('data-core-css') ? document.body.getAttribute('data-core-css') : `${assetLocation}/css/core.min.css`;\n const loadCSS = `@import \"${assetLocation}/css/components/actionbar.css\";`;\n const loadExtraCSS = `@import \"${assetLocation}/css/components/actionbar.global.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\n <style>\n @import \"${coreCSS}\";\n ${loadCSS}\n ${this.hasAttribute('css') ? `@import \"${this.getAttribute('css')}\";` : ``}\n </style>\n <link rel=\"stylesheet\" href=\"https://kit.fontawesome.com/26fdbf0179.css\" crossorigin=\"anonymous\">\n <div class=\"actionbar__wrapper\">\n \n <div class=\"actionbar\" part=\"actionbar\">\n <slot name=\"selectall\"></slot>\n <div class=\"safe-area\">\n <slot></slot>\n <div class=\"body\">\n <div class=\"dialog__wrapper dialog__wrapper--right dialog-overflow d-none show\">\n <button class=\"btn btn-secondary btn-compact fa-ellipsis-vertical m-0\">More actions</button>\n <dialog class=\"dialog--list\" part=\"overflow\">\n <slot name=\"overflow\"></slot>\n <slot name=\"menu\"></slot>\n </dialog>\n </div>\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=\"dialog__wrapper dialog__wrapper--right dialog-overflow d-none show\">\n <button class=\"btn btn-secondary btn-compact fa-ellipsis-vertical m-0\">More actions</button>\n <dialog class=\"dialog--list\" part=\"selected-overflow\">\n <slot name=\"selected-overflow\"></slot>\n </dialog>\n </div>\n </div>\n </div>\n </div>\n <div class=\"actionbar--search\">\n <button data-search class=\"btn btn-compact fa-xmark-large btn-secondary m-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 </div>\n\n </div>\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 let that = this;\n const actionbarWrapper = this.shadowRoot.querySelector('.actionbar__wrapper');\n // #region select all\n if (this.hasAttribute('data-selectall')) {\n 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 let selectAll = this.shadowRoot.querySelector('.selectall');\n if (this.hasAttribute('data-selected')) {\n setSelectAllInput(selectAll, this.getAttribute('data-selected'));\n }\n selectAll.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('input')) {\n if (event.target.closest('input').checked)\n this.setAttribute('data-selected', 'all');\n else\n this.setAttribute('data-selected', 0);\n }\n });\n let cancelButton = this.querySelector('button[data-cancel]');\n if (cancelButton) {\n cancelButton.addEventListener('click', (event) => {\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.setAttribute('data-select-container', 'true');\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input, index) => {\n input.parentElement.setAttribute('slot', 'checkbox');\n });\n element.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('[type=\"checkbox\"]')) {\n let count = element.querySelectorAll('input[type=\"checkbox\"]').length;\n let countChecked = element.querySelectorAll('input[type=\"checkbox\"]:checked').length;\n that.setAttribute('data-selected', count == countChecked ? \"all\" : countChecked);\n let input = event.target.closest('[type=\"checkbox\"]');\n if (countChecked) {\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input, index) => {\n if (input.closest('iam-card'))\n input.closest('iam-card').setAttribute('data-selected', 'true');\n });\n }\n else {\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input, index) => {\n if (input.closest('iam-card'))\n input.closest('iam-card').removeAttribute('data-selected');\n });\n }\n }\n ;\n });\n }\n // #endregion\n // #region switchviews\n if (this.hasAttribute('data-switchviews')) {\n let btns = '';\n let viewList = this.getAttribute('data-switchviews').split(',');\n viewList.forEach((view, index) => {\n let icon = 'fa-grid-2';\n if (view == \"list\")\n icon = 'fa-grip-lines';\n else if (view == \"small\")\n icon = 'fa-bars';\n btns += `<button class=\"btn btn-action btn-compact mb-0 fa-regular ${icon}\">${view}</button>`;\n });\n actionbarWrapper.insertAdjacentHTML('afterbegin', `<div class=\"views m-0\">${btns}</div>`);\n let views = this.shadowRoot.querySelector('.views');\n views.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('.btn-action')) {\n let btn = event.target.closest('.btn-action');\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 = this.shadowRoot.querySelector('.actionbar--search');\n if (this.hasAttribute('data-search-value')) {\n this.shadowRoot.querySelector('#search').value = this.getAttribute('data-search-value');\n }\n if (this.hasAttribute('data-search') && this.getAttribute('data-search') == 'show')\n 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 }\n });\n searchBar.addEventListener('keyup', (event) => {\n const keyupEvent = new CustomEvent(\"search-keyup\", { detail: { search: searchBar.querySelector('input').value } });\n this.dispatchEvent(keyupEvent);\n });\n searchBar.addEventListener('change', (event) => {\n const changeEvent = new CustomEvent(\"search-change\", { detail: { search: searchBar.querySelector('input').value } });\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\", { detail: { search: searchBar.querySelector('input').value } });\n this.dispatchEvent(submitEvent);\n }\n });\n // #endregion\n // Make sure dialogs created in the shadow dom work\n Array.from(this.shadowRoot.querySelectorAll('.body')).forEach((element, index) => {\n extendDialogs(element);\n });\n // #region Reponsive safe area\n function 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 = that.hasAttribute('data-switchviews') ? 144 : 210;\n if (that.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(that.querySelectorAll(':scope > .btn:not(.js-updated), :scope > .dialog__wrapper > .btn[class*=\"fa-\"]:first-child:not(.js-updated)')).forEach((element, index) => {\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(that.querySelectorAll(':scope > .btn.js-updated, :scope > .dialog__wrapper > .btn.js-updated:first-child')).forEach((element, index) => {\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(that.querySelectorAll('[slot]')).forEach((element, index) => {\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(that.querySelectorAll('.show')).forEach((element, index) => {\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(that.shadowRoot.querySelectorAll('.safe-area')).forEach((element, index) => {\n // Decide on which overflow slot to use\n let overflowSlot = \"overflow\";\n if (element.querySelector('slot').hasAttribute('name') && element.querySelector('slot').getAttribute('name') == \"selected\")\n overflowSlot = \"selected-overflow\";\n // Get the slotted elements, remember they aren't children of the safe area\n let elements = element.querySelector('slot').assignedElements();\n let tempWidth = 44 * modifier; // Allow space for the overflow button\n // If search then allow for the search button width\n if (that.hasAttribute('data-search'))\n tempWidth += 44 * modifier;\n // Foreach element that 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('dialog__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('dialog__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 let 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('dialog__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 }\n static get observedAttributes() {\n return [\"data-selected\"];\n }\n attributeChangedCallback(attrName, oldVal, newVal) {\n switch (attrName) {\n case \"data-selected\": {\n let 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(this.getAttribute('data-select-watch'));\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input, index) => {\n input.checked = true;\n if (input.closest('iam-card'))\n input.closest('iam-card').setAttribute('data-selected', 'true');\n });\n }\n if (newVal == \"0\" && this.hasAttribute('data-select-watch')) {\n const element = document.getElementById(this.getAttribute('data-select-watch'));\n Array.from(element.querySelectorAll('input[type=\"checkbox\"]')).forEach((input, index) => {\n input.checked = false;\n if (input.closest('iam-card'))\n input.closest('iam-card').removeAttribute('data-selected', 'true');\n });\n }\n break;\n }\n }\n }\n}\nexport default iamActionbar;\n"],"names":["extendDialogs","body","dialog","index","createDialog","event","button","modalID","firstWidth","element","id","originalInput","changeEvent","btnElement","closeEvent","style","dialogDimensions","btn","parent","dataEvent","popover","position","topOffset","leftOffset","container","boundingRec","popoverBottom","windowPos","currentStyle","dialogContent","titleElement","optionalElement","setSelectAllInput","value","iamActionbar","assetLocation","coreCSS","template","that","actionbarWrapper","selectAll","cancelButton","input","count","countChecked","btns","view","icon","switchEvent","searchBar","searchBtn","keyupEvent","submitEvent","hideButtons","wrapperWidth","screenWidth","safeAreaWidth","elementMargin","tabletSafeWidth","mobileSafeWidth","modifier","overflowSlot","elements","tempWidth","i","overflowDialog","attrName","oldVal","newVal"],"mappings":"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"}
1
+ {"version":3,"file":"actionbar.component.min.js","sources":["../../modules/dialogs.js","actionbar.component.js"],"sourcesContent":["// @ts-nocheck\nconst extendDialogs = (body) => {\n Array.from(body.querySelectorAll('dialog[open]')).forEach((dialog, index) => {\n const parent = dialog.closest('.dialog__wrapper');\n if (!parent) {\n dialog.removeAttribute('open');\n dialog.showModal();\n dialog.focus();\n createDialog(dialog);\n }\n });\n // Dialogs/modals\n body.addEventListener('click', (event) => {\n if (event.target.tagName == 'IAM-ACTIONBAR')\n return false;\n // Modal\n if (event && event.target instanceof HTMLElement && event.target.closest('[data-modal]')) {\n const button = event.target.closest('[data-modal]');\n const modalID = button.hasAttribute('data-modal')\n ? button.getAttribute('data-modal')\n : button.getAttribute('data-filter');\n const dialog = document.querySelector(`dialog#${modalID}`);\n createDialog(dialog);\n // Open the modal!\n dialog.showModal();\n dialog.focus();\n if (!dialog.querySelector('iam-multi-step')) {\n const firstWidth = dialog.offsetWidth;\n dialog.setAttribute('style', `max-width: ${firstWidth}px;`);\n }\n // When the modal is opened we want to make sure any duplicate checkboxes are matching the originals\n Array.from(dialog.querySelectorAll('[data-duplicate]')).forEach((element, index) => {\n const id = element.getAttribute('data-duplicate');\n const originalInput = document.getElementById(id);\n if (element.checked != originalInput.checked) {\n element.checked = originalInput.checked;\n const changeEvent = new Event('change');\n element.dispatchEvent(changeEvent);\n }\n });\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n event: 'openModal',\n id: modalID,\n });\n }\n // Close modal\n if (event && event.target instanceof HTMLElement && event.target.closest('button.dialog__close')) {\n const dialog = event.target.closest('dialog[open]');\n event.preventDefault();\n dialog.close();\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.classList.remove('active');\n });\n const closeEvent = new CustomEvent('dialog-closed', {\n bubbles: true,\n cancelable: true,\n detail: { modalId: dialog.id },\n });\n event.target.dispatchEvent(closeEvent);\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n event: 'closeModal',\n id: dialog.getAttribute('id'),\n });\n }\n // Track default close buttons\n if (event && event.target instanceof HTMLElement && event.target.closest('button[formmethod=\"dialog\"]')) {\n const dialog = event.target.closest('dialog[open]');\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.classList.remove('active');\n });\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n event: 'closeModal',\n id: dialog.getAttribute('id'),\n });\n }\n // Close the modal when clicked on the backdrop\n if (event && event.target instanceof HTMLElement && event.target.closest('dialog[open]')) {\n let dialog = event.target.closest('dialog[open]');\n // Small fix to make sure the dialog isn't a dialog inside of a dialog.\n const style = window.getComputedStyle(dialog);\n if (style.display === 'contents')\n dialog = dialog.parentNode.closest('dialog[open]');\n // Dont allow the backdrop to be clicked when transactional\n if (!dialog.classList.contains('dialog--transactional') &&\n !dialog.classList.contains('dialog--acknowledgement')) {\n const dialogDimensions = dialog.getBoundingClientRect();\n if (event.clientX < dialogDimensions.left ||\n event.clientX > dialogDimensions.right ||\n event.clientY < dialogDimensions.top ||\n event.clientY > dialogDimensions.bottom) {\n if (!event.target.closest('dialog *'))\n // Weird bug when interacting with radio input fields within dialogs cuases it to close\n dialog.close();\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n event: 'closeModal',\n id: dialog.getAttribute('id'),\n });\n }\n }\n }\n // Popover\n if (event && event.target instanceof HTMLElement && event.target.closest('.dialog__wrapper > button')) {\n event.stopPropagation();\n const btn = event.target.closest('.dialog__wrapper > button');\n const parent = btn.parentNode;\n let dataEvent = 'openPopover';\n const popover = parent.querySelector(':scope > dialog');\n // close open dialogs\n if (document.querySelector('*:not([data-keep-open]) > dialog[open]') &&\n document.querySelector('*:not([data-keep-open]) > dialog[open]') != popover) {\n // Check that the ope dialog isn't a parent of the dialog being opened\n if (btn.closest('dialog[open]') != document.querySelector('*:not([data-keep-open]) > dialog[open]')) {\n document.querySelector('*:not([data-keep-open]) > dialog[open]').close();\n }\n }\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.removeAttribute('aria-expanded');\n });\n if (popover.hasAttribute('open')) {\n popover.close();\n dataEvent = 'closePopover';\n popover.removeAttribute('style');\n btn.removeAttribute('aria-expanded');\n }\n else {\n popover.show();\n btn.setAttribute('aria-expanded', true);\n const position = btn.getBoundingClientRect();\n let topOffset = position.top;\n let leftOffset = position.left;\n if (btn.closest('iam-table')) {\n const container = btn.closest('iam-table').parentNode.getBoundingClientRect();\n topOffset -= container.top;\n leftOffset -= container.left;\n }\n if (popover.classList.contains('dialog--fix')) {\n popover.setAttribute('style', `position:fixed;top: ${topOffset}px; left: ${leftOffset}px; margin: 3rem 0 0 0;`);\n }\n }\n // When the dialog is fixed it could dip under the viewport\n // Lets check the dimensions and transform it to appear above\n let boundingRec = popover.getBoundingClientRect();\n const popoverBottom = boundingRec.bottom - window.scrollY;\n const windowPos = window.innerHeight - window.scrollY;\n if (popoverBottom > windowPos) {\n const currentStyle = popover.hasAttribute('style') ? popover.getAttribute('style') + ' ' : '';\n popover.setAttribute('style', currentStyle + `transform: translate(0, calc(-100% - 4rem))`);\n // Check that the dialog doesn't go over the top of the page\n boundingRec = popover.getBoundingClientRect();\n const popoverTop = boundingRec.top - window.scrollY;\n if (popoverTop < 100)\n popover.removeAttribute('style');\n }\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n event: dataEvent,\n id: btn.textContent,\n });\n }\n // Close popovers when clicked away\n if (event &&\n event.target instanceof HTMLElement &&\n !event.target.closest('dialog[open]') &&\n !event.target.closest('.dialog__wrapper > button')) {\n if (document.querySelector('.dialog__wrapper:not([data-keep-open]) > dialog[open]'))\n document.querySelector('.dialog__wrapper:not([data-keep-open]) > dialog[open]').close();\n Array.from(document.querySelectorAll('.dialog__wrapper:not([data-keep-open]) > button')).forEach((btnElement, index) => {\n btnElement.removeAttribute('aria-expanded');\n });\n }\n });\n return null;\n};\nexport const createDialog = (dialog) => {\n // If you are using Vue eevents and bindings its recommended to add in the .mh-lg div manually to the dialog\n if (!dialog.querySelector(':scope .mh-lg') && !dialog.querySelector('iam-multi-step')) {\n dialog.innerHTML = `<div class=\"mh-lg\">${dialog.innerHTML}</div>`;\n const dialogContent = dialog.querySelector('.mh-lg');\n const titleElement = dialog.querySelector('.mh-lg :is(.h1,.h2,.h3,.h4,.h5,.h6)');\n if (titleElement) {\n const optionalElement = titleElement.previousSibling;\n dialogContent.before(titleElement);\n if (optionalElement)\n titleElement.before(optionalElement);\n }\n }\n // Create close button is needed\n if (!dialog.querySelector(':scope > button:first-child'))\n dialog.insertAdjacentHTML('afterbegin', `<button class=\"dialog__close\">Close</button>`);\n};\nexport default extendDialogs;\n","import extendDialogs from '../../modules/dialogs.js';\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 const coreCSS = document.body.hasAttribute('data-core-css')\n ? document.body.getAttribute('data-core-css')\n : `${assetLocation}/css/core.min.css`;\n const loadCSS = `@import \"${assetLocation}/css/components/actionbar.css\";`;\n const loadExtraCSS = `@import \"${assetLocation}/css/components/actionbar.global.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\n <style>\n @import \"${coreCSS}\";\n ${loadCSS}\n ${this.hasAttribute('css') ? `@import \"${this.getAttribute('css')}\";` : ``}\n </style>\n <link rel=\"stylesheet\" href=\"https://kit.fontawesome.com/26fdbf0179.css\" crossorigin=\"anonymous\">\n <div class=\"actionbar__wrapper\">\n \n <div class=\"actionbar\" part=\"actionbar\">\n <slot name=\"selectall\"></slot>\n <div class=\"safe-area\">\n <slot></slot>\n <div class=\"body\">\n <div class=\"dialog__wrapper dialog__wrapper--right dialog-overflow d-none show\">\n <button class=\"btn btn-secondary btn-compact fa-ellipsis-vertical m-0\">More actions</button>\n <dialog class=\"dialog--list\" part=\"overflow\">\n <slot name=\"overflow\"></slot>\n <slot name=\"menu\"></slot>\n </dialog>\n </div>\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=\"dialog__wrapper dialog__wrapper--right dialog-overflow d-none show\">\n <button class=\"btn btn-secondary btn-compact fa-ellipsis-vertical m-0\">More actions</button>\n <dialog class=\"dialog--list\" part=\"selected-overflow\">\n <slot name=\"selected-overflow\"></slot>\n </dialog>\n </div>\n </div>\n </div>\n </div>\n <div class=\"actionbar--search\">\n <button data-search class=\"btn btn-compact fa-xmark-large btn-secondary m-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 </div>\n\n </div>\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;\n const actionbarWrapper = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.actionbar__wrapper');\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 = (_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.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 = (_c = this.getAttribute('data-switchviews')) === null || _c === void 0 ? void 0 : _c.split(',');\n viewList === null || viewList === void 0 ? void 0 : viewList.forEach((view) => {\n let icon = 'fa-grid-2';\n if (view == 'list')\n icon = 'fa-grip-lines';\n else if (view == 'small')\n icon = 'fa-bars';\n btns += `<button class=\"btn btn-action btn-compact mb-0 fa-regular ${icon}\">${view}</button>`;\n });\n actionbarWrapper === null || actionbarWrapper === void 0 ? void 0 : actionbarWrapper.insertAdjacentHTML('afterbegin', `<div class=\"views m-0\">${btns}</div>`);\n const views = (_d = this.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.views');\n views === null || views === void 0 ? void 0 : views.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('.btn-action')) {\n const btn = event.target.closest('.btn-action');\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 = (_e = this.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('.actionbar--search');\n if (this.hasAttribute('data-search-value')) {\n ((_f = this.shadowRoot) === null || _f === void 0 ? void 0 : _f.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 }\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 }\n });\n // #endregion\n // Make sure dialogs created in the shadow dom work\n Array.from(this.shadowRoot.querySelectorAll('.body')).forEach((element, index) => {\n extendDialogs(element);\n });\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 > .dialog__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 > .dialog__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('dialog__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('dialog__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('dialog__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 }\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":["extendDialogs","body","dialog","index","createDialog","event","button","modalID","firstWidth","element","id","originalInput","changeEvent","btnElement","closeEvent","dialogDimensions","btn","parent","dataEvent","popover","position","topOffset","leftOffset","container","boundingRec","popoverBottom","windowPos","currentStyle","dialogContent","titleElement","optionalElement","setSelectAllInput","value","iamActionbar","assetLocation","coreCSS","template","_a","_b","_c","_d","_e","_f","actionbarWrapper","selectAll","cancelButton","input","count","countChecked","btns","viewList","view","icon","views","switchEvent","searchBar","searchBtn","keyupEvent","submitEvent","hideButtons","wrapperWidth","screenWidth","safeAreaWidth","elementMargin","tabletSafeWidth","mobileSafeWidth","modifier","overflowSlot","elements","tempWidth","i","overflowDialog","attrName","oldVal","newVal"],"mappings":"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"}
@@ -7,20 +7,23 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
7
7
  step((generator = generator.apply(thisArg, _arguments || [])).next());
8
8
  });
9
9
  };
10
- // @ts-nocheck
11
10
  import Cookies from 'js-cookie';
12
- // Data layer Web component created
13
11
  window.dataLayer = window.dataLayer || [];
14
12
  window.dataLayer.push({
15
- "event": "customElementRegistered",
16
- "element": "Address Lookup"
13
+ event: 'customElementRegistered',
14
+ element: 'Address Lookup',
17
15
  });
18
16
  class iamAddressLookup extends HTMLElement {
19
17
  constructor() {
18
+ var _a;
20
19
  super();
21
20
  this.attachShadow({ mode: 'open' });
22
- const assetLocation = document.body.hasAttribute('data-assets-location') ? document.body.getAttribute('data-assets-location') : '/assets';
23
- const coreCSS = document.body.hasAttribute('data-core-css') ? document.body.getAttribute('data-core-css') : `${assetLocation}/css/core.min.css`;
21
+ const assetLocation = document.body.hasAttribute('data-assets-location')
22
+ ? document.body.getAttribute('data-assets-location')
23
+ : '/assets';
24
+ const coreCSS = document.body.hasAttribute('data-core-css')
25
+ ? document.body.getAttribute('data-core-css')
26
+ : `${assetLocation}/css/core.min.css`;
24
27
  const loadCSS = `@import "${assetLocation}/css/components/address-lookup.css";`;
25
28
  const template = document.createElement('template');
26
29
  template.innerHTML = `
@@ -59,7 +62,7 @@ class iamAddressLookup extends HTMLElement {
59
62
  </div>
60
63
  </div>
61
64
  `;
62
- this.shadowRoot.appendChild(template.content.cloneNode(true));
65
+ (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(template.content.cloneNode(true));
63
66
  }
64
67
  connectedCallback() {
65
68
  return __awaiter(this, void 0, void 0, function* () {
@@ -72,15 +75,15 @@ class iamAddressLookup extends HTMLElement {
72
75
  const list = this.shadowRoot.querySelector('datalist');
73
76
  const switchManualBtn = this.shadowRoot.querySelector('.switch-to-manual-btn');
74
77
  const switchLookupBtn = this.shadowRoot.querySelector('.switch-to-lookup-btn');
75
- const title = this.hasAttribute('data-title') ? this.getAttribute('data-title') : "Property address";
78
+ const title = this.hasAttribute('data-title') ? this.getAttribute('data-title') : 'Property address';
76
79
  const preFilledAddressBtn = this.shadowRoot.querySelector('.pre-filled-address + button');
77
80
  Array.from(this.shadowRoot.querySelectorAll('.title')).forEach((titleElement, index) => {
78
81
  titleElement.innerHTML = title;
79
82
  });
80
83
  function checkFilled(component) {
81
- let preFilledAddress = component.shadowRoot.querySelector('.pre-filled-address');
84
+ const preFilledAddress = component.shadowRoot.querySelector('.pre-filled-address');
82
85
  let preFilled = true;
83
- preFilledAddress.innerHTML = "";
86
+ preFilledAddress.innerHTML = '';
84
87
  Array.from(component.querySelectorAll('input[required],input[data-required],select[required],select[data-required]')).forEach((input, index) => {
85
88
  const value = input.value;
86
89
  if (!value)
@@ -100,18 +103,18 @@ class iamAddressLookup extends HTMLElement {
100
103
  checkFilled(this);
101
104
  });
102
105
  if (this.hasAttribute('data-use')) {
103
- let useLabel = this.hasAttribute('data-use-label') ? this.getAttribute('data-use-label') : 'Use saved address';
104
- let useCheckbox = `<div><input type="checkbox" name="use" id="use" value="yes"><label for="use">${useLabel}</label></div>`;
106
+ const useLabel = this.hasAttribute('data-use-label') ? this.getAttribute('data-use-label') : 'Use saved address';
107
+ const useCheckbox = `<div><input type="checkbox" name="use" id="use" value="yes"><label for="use">${useLabel}</label></div>`;
105
108
  lookupWrapper.insertAdjacentHTML('afterbegin', useCheckbox);
106
109
  this.shadowRoot.addEventListener('change', (event) => {
107
110
  if (event && event.target instanceof HTMLElement && event.target.closest('[name="use"]')) {
108
- let checkbox = event.target.closest('[name="use"]');
111
+ const checkbox = event.target.closest('[name="use"]');
109
112
  if (checkbox.checked) {
110
113
  lookupWrapper.classList.add('js-hide');
111
114
  manualWrapper.classList.remove('js-hide');
112
- let values = JSON.parse(this.getAttribute('data-use'));
115
+ const values = JSON.parse(this.getAttribute('data-use'));
113
116
  Object.keys(values).forEach((key, index) => {
114
- let value = values[key];
117
+ const value = values[key];
115
118
  if (this.querySelector(`[data-name="${key}"]`))
116
119
  this.querySelector(`[data-name="${key}"]`).value = value;
117
120
  else if (this.querySelector(`[name="${key}"]`))
@@ -158,9 +161,9 @@ class iamAddressLookup extends HTMLElement {
158
161
  if (list.querySelector(`[value="${lookup.value}"]`)) {
159
162
  lookupWrapper.classList.add('js-hide');
160
163
  manualWrapper.classList.remove('js-hide');
161
- let values = JSON.parse(list.querySelector(`[value="${lookup.value}"]`).getAttribute('data-values'));
164
+ const values = JSON.parse(list.querySelector(`[value="${lookup.value}"]`).getAttribute('data-values'));
162
165
  Object.keys(values).forEach((key, index) => {
163
- let value = values[key];
166
+ const value = values[key];
164
167
  if (this.querySelector(`[data-name="${key}"]`) && value != '')
165
168
  this.querySelector(`[data-name="${key}"]`).value = value;
166
169
  else if (this.querySelector(`[data-name-alt="${key}"]`) && value != '')
@@ -202,30 +205,31 @@ class iamAddressLookup extends HTMLElement {
202
205
  'Content-Type': 'application/json',
203
206
  Accept: 'application/json',
204
207
  'X-Requested-With': 'XMLHttpRequest',
205
- 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN')
206
- })
208
+ 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN'),
209
+ }),
207
210
  })
208
- .then((response) => response.json()).then((response) => {
211
+ .then((response) => response.json())
212
+ .then((response) => {
209
213
  // populate datalist
210
214
  let listString = '';
211
215
  response.forEach((address, index) => {
212
216
  // Deal with agent platform response
213
- if (typeof address.value == "object") {
214
- let values = JSON.stringify(address.value);
217
+ if (typeof address.value == 'object') {
218
+ const values = JSON.stringify(address.value);
215
219
  listString += `<option value="${address['label']}, ${postcode}" data-values='${values}'></option>`;
216
220
  }
217
221
  else {
218
- let values = JSON.stringify(address);
222
+ const values = JSON.stringify(address);
219
223
  if (component.hasAttribute('data-display-text')) {
220
224
  listString += `<option value="${address[component.getAttribute('data-display-text')]}, ${postcode}" data-values='${values}'></option>`;
221
225
  }
222
226
  else {
223
227
  let itemString = '';
224
228
  for (const [key, value] of Object.entries(address)) {
225
- if (key == "address_number_name")
229
+ if (key == 'address_number_name')
226
230
  itemString += `${value} `;
227
- else if (key != "postcode" && key != "address_title")
228
- itemString += `${value}${(/^-?\d+$/.test(value) ? '' : ',')} `;
231
+ else if (key != 'postcode' && key != 'address_title')
232
+ itemString += `${value}${/^-?\d+$/.test(value) ? '' : ','} `;
229
233
  }
230
234
  listString += `<option value="${itemString}${postcode}" data-values='${values}'></option>`;
231
235
  }
@@ -1,9 +1,9 @@
1
1
  /*!
2
- * iamKey v7.0.0
2
+ * iamKey v7.1.0--beta2
3
3
  * Copyright 2022-2025 iamproperty
4
- */import x from"js-cookie";var g=function(S,h,a,o){function l(c){return c instanceof a?c:new a(function(u){u(c)})}return new(a||(a=Promise))(function(c,u){function b(d){try{m(o.next(d))}catch(f){u(f)}}function v(d){try{m(o.throw(d))}catch(f){u(f)}}function m(d){d.done?c(d.value):l(d.value).then(b,v)}m((o=o.apply(S,h||[])).next())})};window.dataLayer=window.dataLayer||[],window.dataLayer.push({event:"customElementRegistered",element:"Address Lookup"});class j extends HTMLElement{constructor(){super(),this.attachShadow({mode:"open"});const h=document.body.hasAttribute("data-assets-location")?document.body.getAttribute("data-assets-location"):"/assets",a=document.body.hasAttribute("data-core-css")?document.body.getAttribute("data-core-css"):`${h}/css/core.min.css`,o=document.createElement("template");o.innerHTML=`
4
+ */import x from"js-cookie";var g=function(S,c,a,i){function n(u){return u instanceof a?u:new a(function(p){p(u)})}return new(a||(a=Promise))(function(u,p){function b(d){try{m(i.next(d))}catch(f){p(f)}}function v(d){try{m(i.throw(d))}catch(f){p(f)}}function m(d){d.done?u(d.value):n(d.value).then(b,v)}m((i=i.apply(S,c||[])).next())})};window.dataLayer=window.dataLayer||[],window.dataLayer.push({event:"customElementRegistered",element:"Address Lookup"});class j extends HTMLElement{constructor(){var c;super(),this.attachShadow({mode:"open"});const a=document.body.hasAttribute("data-assets-location")?document.body.getAttribute("data-assets-location"):"/assets",i=document.body.hasAttribute("data-core-css")?document.body.getAttribute("data-core-css"):`${a}/css/core.min.css`,n=document.createElement("template");n.innerHTML=`
5
5
  <style>
6
- @import "${a}";
6
+ @import "${i}";
7
7
  :host{margin-bottom:1rem;display:block}input[name=postcode]{border-color:var(--error-border, var(--colour-primary)) !important}:is([name=postcode]):is(:focus,.focus):not(:disabled){border-color:var(--colour-info) !important}div:has(input[name=postcode]) .suffix{border-color:var(--error-border, var(--colour-primary)) !important}.invalid-feedback{display:var(--error-display, none) !important}.optional{display:var(--req-display, inline-block) !important}.pre-filled p{padding-bottom:1rem}.pre-filled button{border:none;background:none;cursor:pointer}/*# sourceMappingURL=assets/css/components/address-lookup.css.map */
8
8
 
9
9
 
@@ -37,5 +37,5 @@
37
37
  <p><span class="pre-filled-address"></span><button class="text-primary text-decoration-none ms-1 cursor-pointer" type="button"><i class="fa-regular fa-pen-to-square"></i><span class="visually-hidden">Edit</span></button><slot name="prefilled"></slot></p>
38
38
  </div>
39
39
  </div>
40
- `,this.shadowRoot.appendChild(o.content.cloneNode(!0))}connectedCallback(){return g(this,void 0,void 0,function*(){const h=this;this.shadowRoot.querySelector(".wrapper");const a=this.shadowRoot.querySelector('[name="postcode"]'),o=this.shadowRoot.querySelector(".postcode-lookup"),l=this.shadowRoot.querySelector(".manual-address"),c=this.shadowRoot.querySelector(".pre-filled"),u=this.shadowRoot.querySelector("datalist"),b=this.shadowRoot.querySelector(".switch-to-manual-btn"),v=this.shadowRoot.querySelector(".switch-to-lookup-btn"),m=this.hasAttribute("data-title")?this.getAttribute("data-title"):"Property address",d=this.shadowRoot.querySelector(".pre-filled-address + button");Array.from(this.shadowRoot.querySelectorAll(".title")).forEach((t,s)=>{t.innerHTML=m});function f(t){let s=t.shadowRoot.querySelector(".pre-filled-address"),e=!0;s.innerHTML="",Array.from(t.querySelectorAll("input[required],input[data-required],select[required],select[data-required]")).forEach((n,r)=>{const i=n.value;i?s.innerHTML+=i+(/^-?\d+$/.test(i)?" ":", "):e=!1}),s.innerHTML=s.innerHTML.slice(0,-2),e&&(c.classList.remove("js-hide"),o.classList.add("js-hide"),l.classList.add("js-hide"))}if(f(this),this.addEventListener("filled",t=>{f(this)}),this.hasAttribute("data-use")){let s=`<div><input type="checkbox" name="use" id="use" value="yes"><label for="use">${this.hasAttribute("data-use-label")?this.getAttribute("data-use-label"):"Use saved address"}</label></div>`;o.insertAdjacentHTML("afterbegin",s),this.shadowRoot.addEventListener("change",e=>{if(e&&e.target instanceof HTMLElement&&e.target.closest('[name="use"]')&&e.target.closest('[name="use"]').checked){o.classList.add("js-hide"),l.classList.remove("js-hide");let r=JSON.parse(this.getAttribute("data-use"));Object.keys(r).forEach((i,$)=>{let p=r[i];this.querySelector(`[data-name="${i}"]`)?this.querySelector(`[data-name="${i}"]`).value=p:this.querySelector(`[name="${i}"]`)&&(this.querySelector(`[name="${i}"]`).value=p)})}})}this.hasAttribute("data-manual")&&(o.classList.add("js-hide"),l.classList.remove("js-hide"),Array.from(l.querySelectorAll("[data-required]")).forEach((t,s)=>{t.setAttribute("required","true")}));function L(){o.classList.add("js-hide"),l.classList.remove("js-hide"),Array.from(l.querySelectorAll("[data-required]")).forEach((t,s)=>{t.setAttribute("required","true")}),l.scrollIntoView()}d.addEventListener("click",t=>{c.classList.add("js-hide"),L()}),b.addEventListener("click",t=>{L()}),v.addEventListener("click",t=>{o.classList.remove("js-hide"),l.classList.add("js-hide"),o.scrollIntoView()}),a.addEventListener("keyup",t=>{a.value.length>=3&&A(a.value)}),a.addEventListener("change",t=>{if(a.value.length>=3&&(A(a.value),u.querySelector(`[value="${a.value}"]`))){o.classList.add("js-hide"),l.classList.remove("js-hide");let s=JSON.parse(u.querySelector(`[value="${a.value}"]`).getAttribute("data-values"));Object.keys(s).forEach((e,n)=>{let r=s[e];this.querySelector(`[data-name="${e}"]`)&&r!=""?this.querySelector(`[data-name="${e}"]`).value=r:this.querySelector(`[data-name-alt="${e}"]`)&&r!=""?this.querySelector(`[data-name-alt="${e}"]`).value=r:this.querySelector(`[name="${e}"]`)&&r!=""&&(this.querySelector(`[name="${e}"]`).value=r),this.querySelector(`[data-name-2="${e}"]`)&&(this.querySelector(`[data-name-2="${e}"]`).value+=" "+r)}),this.querySelector("[name]").focus(),Array.from(this.querySelectorAll("[data-required]")).forEach((e,n)=>{e.setAttribute("required","true")}),a.removeAttribute("required"),this.shadowRoot.querySelector('[name="use"]')&&(this.shadowRoot.querySelector('[name="use"]').checked=!1)}});const A=t=>g(this,void 0,void 0,function*(){let s=this.getAttribute("data-url");s+=`${encodeURI(t)}`,window.controller||(window.controller=[]),window.controller[s]&&window.controller[s].abort(),window.controller[s]=new AbortController;const{signal:e}=controller[s];try{yield fetch(s,{signal:e,method:"get",credentials:"same-origin",headers:new Headers({"Content-Type":"application/json",Accept:"application/json","X-Requested-With":"XMLHttpRequest","X-XSRF-TOKEN":x.get("XSRF-TOKEN")})}).then(n=>n.json()).then(n=>{let r="";return n.forEach((i,$)=>{if(typeof i.value=="object"){let p=JSON.stringify(i.value);r+=`<option value="${i.label}, ${t}" data-values='${p}'></option>`}else{let p=JSON.stringify(i);if(h.hasAttribute("data-display-text"))r+=`<option value="${i[h.getAttribute("data-display-text")]}, ${t}" data-values='${p}'></option>`;else{let y="";for(const[w,q]of Object.entries(i))w=="address_number_name"?y+=`${q} `:w!="postcode"&&w!="address_title"&&(y+=`${q}${/^-?\d+$/.test(q)?"":","} `);r+=`<option value="${y}${t}" data-values='${p}'></option>`}}}),u.innerHTML=r,n})}catch(n){console.log(n)}})})}}export{j as default};
40
+ `,(c=this.shadowRoot)===null||c===void 0||c.appendChild(n.content.cloneNode(!0))}connectedCallback(){return g(this,void 0,void 0,function*(){const c=this;this.shadowRoot.querySelector(".wrapper");const a=this.shadowRoot.querySelector('[name="postcode"]'),i=this.shadowRoot.querySelector(".postcode-lookup"),n=this.shadowRoot.querySelector(".manual-address"),u=this.shadowRoot.querySelector(".pre-filled"),p=this.shadowRoot.querySelector("datalist"),b=this.shadowRoot.querySelector(".switch-to-manual-btn"),v=this.shadowRoot.querySelector(".switch-to-lookup-btn"),m=this.hasAttribute("data-title")?this.getAttribute("data-title"):"Property address",d=this.shadowRoot.querySelector(".pre-filled-address + button");Array.from(this.shadowRoot.querySelectorAll(".title")).forEach((t,s)=>{t.innerHTML=m});function f(t){const s=t.shadowRoot.querySelector(".pre-filled-address");let e=!0;s.innerHTML="",Array.from(t.querySelectorAll("input[required],input[data-required],select[required],select[data-required]")).forEach((l,o)=>{const r=l.value;r?s.innerHTML+=r+(/^-?\d+$/.test(r)?" ":", "):e=!1}),s.innerHTML=s.innerHTML.slice(0,-2),e&&(u.classList.remove("js-hide"),i.classList.add("js-hide"),n.classList.add("js-hide"))}if(f(this),this.addEventListener("filled",t=>{f(this)}),this.hasAttribute("data-use")){const s=`<div><input type="checkbox" name="use" id="use" value="yes"><label for="use">${this.hasAttribute("data-use-label")?this.getAttribute("data-use-label"):"Use saved address"}</label></div>`;i.insertAdjacentHTML("afterbegin",s),this.shadowRoot.addEventListener("change",e=>{if(e&&e.target instanceof HTMLElement&&e.target.closest('[name="use"]')&&e.target.closest('[name="use"]').checked){i.classList.add("js-hide"),n.classList.remove("js-hide");const o=JSON.parse(this.getAttribute("data-use"));Object.keys(o).forEach((r,$)=>{const h=o[r];this.querySelector(`[data-name="${r}"]`)?this.querySelector(`[data-name="${r}"]`).value=h:this.querySelector(`[name="${r}"]`)&&(this.querySelector(`[name="${r}"]`).value=h)})}})}this.hasAttribute("data-manual")&&(i.classList.add("js-hide"),n.classList.remove("js-hide"),Array.from(n.querySelectorAll("[data-required]")).forEach((t,s)=>{t.setAttribute("required","true")}));function L(){i.classList.add("js-hide"),n.classList.remove("js-hide"),Array.from(n.querySelectorAll("[data-required]")).forEach((t,s)=>{t.setAttribute("required","true")}),n.scrollIntoView()}d.addEventListener("click",t=>{u.classList.add("js-hide"),L()}),b.addEventListener("click",t=>{L()}),v.addEventListener("click",t=>{i.classList.remove("js-hide"),n.classList.add("js-hide"),i.scrollIntoView()}),a.addEventListener("keyup",t=>{a.value.length>=3&&A(a.value)}),a.addEventListener("change",t=>{if(a.value.length>=3&&(A(a.value),p.querySelector(`[value="${a.value}"]`))){i.classList.add("js-hide"),n.classList.remove("js-hide");const s=JSON.parse(p.querySelector(`[value="${a.value}"]`).getAttribute("data-values"));Object.keys(s).forEach((e,l)=>{const o=s[e];this.querySelector(`[data-name="${e}"]`)&&o!=""?this.querySelector(`[data-name="${e}"]`).value=o:this.querySelector(`[data-name-alt="${e}"]`)&&o!=""?this.querySelector(`[data-name-alt="${e}"]`).value=o:this.querySelector(`[name="${e}"]`)&&o!=""&&(this.querySelector(`[name="${e}"]`).value=o),this.querySelector(`[data-name-2="${e}"]`)&&(this.querySelector(`[data-name-2="${e}"]`).value+=" "+o)}),this.querySelector("[name]").focus(),Array.from(this.querySelectorAll("[data-required]")).forEach((e,l)=>{e.setAttribute("required","true")}),a.removeAttribute("required"),this.shadowRoot.querySelector('[name="use"]')&&(this.shadowRoot.querySelector('[name="use"]').checked=!1)}});const A=t=>g(this,void 0,void 0,function*(){let s=this.getAttribute("data-url");s+=`${encodeURI(t)}`,window.controller||(window.controller=[]),window.controller[s]&&window.controller[s].abort(),window.controller[s]=new AbortController;const{signal:e}=controller[s];try{yield fetch(s,{signal:e,method:"get",credentials:"same-origin",headers:new Headers({"Content-Type":"application/json",Accept:"application/json","X-Requested-With":"XMLHttpRequest","X-XSRF-TOKEN":x.get("XSRF-TOKEN")})}).then(l=>l.json()).then(l=>{let o="";return l.forEach((r,$)=>{if(typeof r.value=="object"){const h=JSON.stringify(r.value);o+=`<option value="${r.label}, ${t}" data-values='${h}'></option>`}else{const h=JSON.stringify(r);if(c.hasAttribute("data-display-text"))o+=`<option value="${r[c.getAttribute("data-display-text")]}, ${t}" data-values='${h}'></option>`;else{let y="";for(const[w,q]of Object.entries(r))w=="address_number_name"?y+=`${q} `:w!="postcode"&&w!="address_title"&&(y+=`${q}${/^-?\d+$/.test(q)?"":","} `);o+=`<option value="${y}${t}" data-values='${h}'></option>`}}}),p.innerHTML=o,l})}catch(l){console.log(l)}})})}}export{j as default};
41
41
  //# sourceMappingURL=address-lookup.component.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"address-lookup.component.min.js","sources":["address-lookup.component.js"],"sourcesContent":["var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n// @ts-nocheck\nimport Cookies from 'js-cookie';\n// Data layer Web component created\nwindow.dataLayer = window.dataLayer || [];\nwindow.dataLayer.push({\n \"event\": \"customElementRegistered\",\n \"element\": \"Address Lookup\"\n});\nclass iamAddressLookup extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n const assetLocation = document.body.hasAttribute('data-assets-location') ? document.body.getAttribute('data-assets-location') : '/assets';\n const coreCSS = document.body.hasAttribute('data-core-css') ? document.body.getAttribute('data-core-css') : `${assetLocation}/css/core.min.css`;\n const loadCSS = `@import \"${assetLocation}/css/components/address-lookup.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\n <style>\n @import \"${coreCSS}\";\n ${loadCSS}\n \n ${this.hasAttribute('css') ? `@import \"${this.getAttribute('css')}\";` : ``}\n </style>\n <link rel=\"stylesheet\" href=\"https://kit.fontawesome.com/26fdbf0179.css\" crossorigin=\"anonymous\" />\n <div class=\"wrapper\">\n\n <div class=\"postcode-lookup\">\n <div>\n <label class=\"mb-2\">Search <span class=\"title text-lowercase\"></span> <span class=\"optional\">(Optional)</span>\n <span>\n <input type=\"text\" name=\"postcode\" list=\"address-lookup__addressess\" autocomplete=\"off\" aria-autocomplete=\"none\" placeholder=\"Postcode\" />\n <span class=\"suffix fa-regular fa-search\"></span>\n </span>\n <span class=\"invalid-feedback\">Required Adddress fields missing</span>\n </label>\n\n </div>\n <button class=\"btn btn-tertiary switch-to-manual-btn\" type=\"button\">Or enter address manually</button>\n </div>\n <datalist id=\"address-lookup__addressess\"></datalist>\n\n <div class=\"manual-address pb-2 js-hide\">\n <slot></slot>\n <button class=\"btn btn-tertiary switch-to-lookup-btn\" type=\"button\">Use postcode lookup</button>\n <slot name=\"after\"></slot>\n </div>\n <div class=\"pre-filled pb-2 js-hide\">\n <strong class=\"title text-primary d-block\"></strong>\n <p><span class=\"pre-filled-address\"></span><button class=\"text-primary text-decoration-none ms-1 cursor-pointer\" type=\"button\"><i class=\"fa-regular fa-pen-to-square\"></i><span class=\"visually-hidden\">Edit</span></button><slot name=\"prefilled\"></slot></p>\n </div>\n </div>\n `;\n this.shadowRoot.appendChild(template.content.cloneNode(true));\n }\n connectedCallback() {\n return __awaiter(this, void 0, void 0, function* () {\n const component = this;\n const wrapper = this.shadowRoot.querySelector('.wrapper');\n const lookup = this.shadowRoot.querySelector('[name=\"postcode\"]');\n const lookupWrapper = this.shadowRoot.querySelector('.postcode-lookup');\n const manualWrapper = this.shadowRoot.querySelector('.manual-address');\n const preFilledWrapper = this.shadowRoot.querySelector('.pre-filled');\n const list = this.shadowRoot.querySelector('datalist');\n const switchManualBtn = this.shadowRoot.querySelector('.switch-to-manual-btn');\n const switchLookupBtn = this.shadowRoot.querySelector('.switch-to-lookup-btn');\n const title = this.hasAttribute('data-title') ? this.getAttribute('data-title') : \"Property address\";\n const preFilledAddressBtn = this.shadowRoot.querySelector('.pre-filled-address + button');\n Array.from(this.shadowRoot.querySelectorAll('.title')).forEach((titleElement, index) => {\n titleElement.innerHTML = title;\n });\n function checkFilled(component) {\n let preFilledAddress = component.shadowRoot.querySelector('.pre-filled-address');\n let preFilled = true;\n preFilledAddress.innerHTML = \"\";\n Array.from(component.querySelectorAll('input[required],input[data-required],select[required],select[data-required]')).forEach((input, index) => {\n const value = input.value;\n if (!value)\n preFilled = false;\n else\n preFilledAddress.innerHTML += value + (/^-?\\d+$/.test(value) ? ' ' : ', ');\n });\n preFilledAddress.innerHTML = preFilledAddress.innerHTML.slice(0, -2);\n if (preFilled) {\n preFilledWrapper.classList.remove('js-hide');\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.add('js-hide');\n }\n }\n checkFilled(this);\n this.addEventListener('filled', (event) => {\n checkFilled(this);\n });\n if (this.hasAttribute('data-use')) {\n let useLabel = this.hasAttribute('data-use-label') ? this.getAttribute('data-use-label') : 'Use saved address';\n let useCheckbox = `<div><input type=\"checkbox\" name=\"use\" id=\"use\" value=\"yes\"><label for=\"use\">${useLabel}</label></div>`;\n lookupWrapper.insertAdjacentHTML('afterbegin', useCheckbox);\n this.shadowRoot.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('[name=\"use\"]')) {\n let checkbox = event.target.closest('[name=\"use\"]');\n if (checkbox.checked) {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n let values = JSON.parse(this.getAttribute('data-use'));\n Object.keys(values).forEach((key, index) => {\n let value = values[key];\n if (this.querySelector(`[data-name=\"${key}\"]`))\n this.querySelector(`[data-name=\"${key}\"]`).value = value;\n else if (this.querySelector(`[name=\"${key}\"]`))\n this.querySelector(`[name=\"${key}\"]`).value = value;\n });\n }\n }\n });\n }\n if (this.hasAttribute('data-manual')) {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n Array.from(manualWrapper.querySelectorAll('[data-required]')).forEach((input, index) => {\n input.setAttribute('required', 'true');\n });\n }\n function openManualWrapper() {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n Array.from(manualWrapper.querySelectorAll('[data-required]')).forEach((input, index) => {\n input.setAttribute('required', 'true');\n });\n manualWrapper.scrollIntoView();\n }\n preFilledAddressBtn.addEventListener('click', (event) => {\n preFilledWrapper.classList.add('js-hide');\n openManualWrapper();\n });\n switchManualBtn.addEventListener('click', (event) => {\n openManualWrapper();\n });\n switchLookupBtn.addEventListener('click', (event) => {\n lookupWrapper.classList.remove('js-hide');\n manualWrapper.classList.add('js-hide');\n lookupWrapper.scrollIntoView();\n });\n lookup.addEventListener('keyup', (event) => {\n if (lookup.value.length >= 3)\n search(lookup.value);\n });\n lookup.addEventListener('change', (event) => {\n if (lookup.value.length >= 3) {\n search(lookup.value);\n if (list.querySelector(`[value=\"${lookup.value}\"]`)) {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n let values = JSON.parse(list.querySelector(`[value=\"${lookup.value}\"]`).getAttribute('data-values'));\n Object.keys(values).forEach((key, index) => {\n let value = values[key];\n if (this.querySelector(`[data-name=\"${key}\"]`) && value != '')\n this.querySelector(`[data-name=\"${key}\"]`).value = value;\n else if (this.querySelector(`[data-name-alt=\"${key}\"]`) && value != '')\n this.querySelector(`[data-name-alt=\"${key}\"]`).value = value;\n else if (this.querySelector(`[name=\"${key}\"]`) && value != '')\n this.querySelector(`[name=\"${key}\"]`).value = value;\n if (this.querySelector(`[data-name-2=\"${key}\"]`))\n this.querySelector(`[data-name-2=\"${key}\"]`).value += ' ' + value;\n });\n // Focus on first input\n this.querySelector('[name]').focus();\n Array.from(this.querySelectorAll('[data-required]')).forEach((input, index) => {\n input.setAttribute('required', 'true');\n });\n lookup.removeAttribute('required');\n if (this.shadowRoot.querySelector('[name=\"use\"]'))\n this.shadowRoot.querySelector('[name=\"use\"]').checked = false;\n }\n }\n });\n const search = (postcode) => __awaiter(this, void 0, void 0, function* () {\n let ajaxURL = this.getAttribute('data-url');\n ajaxURL += `${encodeURI(postcode)}`;\n // Setup controller vars if not already set\n if (!window.controller)\n window.controller = [];\n // Abort if controller already present for this url\n if (window.controller[ajaxURL])\n window.controller[ajaxURL].abort();\n // Create a new controller so it can be aborted if new fetch made\n window.controller[ajaxURL] = new AbortController();\n const { signal } = controller[ajaxURL];\n try {\n yield fetch(ajaxURL, {\n signal: signal,\n method: 'get',\n credentials: 'same-origin',\n headers: new Headers({\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n 'X-Requested-With': 'XMLHttpRequest',\n 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN')\n })\n })\n .then((response) => response.json()).then((response) => {\n // populate datalist\n let listString = '';\n response.forEach((address, index) => {\n // Deal with agent platform response\n if (typeof address.value == \"object\") {\n let values = JSON.stringify(address.value);\n listString += `<option value=\"${address['label']}, ${postcode}\" data-values='${values}'></option>`;\n }\n else {\n let values = JSON.stringify(address);\n if (component.hasAttribute('data-display-text')) {\n listString += `<option value=\"${address[component.getAttribute('data-display-text')]}, ${postcode}\" data-values='${values}'></option>`;\n }\n else {\n let itemString = '';\n for (const [key, value] of Object.entries(address)) {\n if (key == \"address_number_name\")\n itemString += `${value} `;\n else if (key != \"postcode\" && key != \"address_title\")\n itemString += `${value}${(/^-?\\d+$/.test(value) ? '' : ',')} `;\n }\n listString += `<option value=\"${itemString}${postcode}\" data-values='${values}'></option>`;\n }\n }\n });\n list.innerHTML = listString;\n return response;\n });\n }\n catch (error) {\n console.log(error);\n }\n });\n });\n }\n}\nexport default iamAddressLookup;\n"],"names":["__awaiter","thisArg","_arguments","P","generator","adopt","value","resolve","reject","fulfilled","step","e","rejected","result","iamAddressLookup","assetLocation","coreCSS","template","component","lookup","lookupWrapper","manualWrapper","preFilledWrapper","list","switchManualBtn","switchLookupBtn","title","preFilledAddressBtn","titleElement","index","checkFilled","preFilledAddress","preFilled","input","event","useCheckbox","values","key","openManualWrapper","search","postcode","ajaxURL","signal","Cookies","response","listString","address","itemString","error"],"mappings":"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"}
1
+ {"version":3,"file":"address-lookup.component.min.js","sources":["address-lookup.component.js"],"sourcesContent":["var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport Cookies from 'js-cookie';\nwindow.dataLayer = window.dataLayer || [];\nwindow.dataLayer.push({\n event: 'customElementRegistered',\n element: 'Address Lookup',\n});\nclass iamAddressLookup extends HTMLElement {\n constructor() {\n var _a;\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 coreCSS = document.body.hasAttribute('data-core-css')\n ? document.body.getAttribute('data-core-css')\n : `${assetLocation}/css/core.min.css`;\n const loadCSS = `@import \"${assetLocation}/css/components/address-lookup.css\";`;\n const template = document.createElement('template');\n template.innerHTML = `\n <style>\n @import \"${coreCSS}\";\n ${loadCSS}\n \n ${this.hasAttribute('css') ? `@import \"${this.getAttribute('css')}\";` : ``}\n </style>\n <link rel=\"stylesheet\" href=\"https://kit.fontawesome.com/26fdbf0179.css\" crossorigin=\"anonymous\" />\n <div class=\"wrapper\">\n\n <div class=\"postcode-lookup\">\n <div>\n <label class=\"mb-2\">Search <span class=\"title text-lowercase\"></span> <span class=\"optional\">(Optional)</span>\n <span>\n <input type=\"text\" name=\"postcode\" list=\"address-lookup__addressess\" autocomplete=\"off\" aria-autocomplete=\"none\" placeholder=\"Postcode\" />\n <span class=\"suffix fa-regular fa-search\"></span>\n </span>\n <span class=\"invalid-feedback\">Required Adddress fields missing</span>\n </label>\n\n </div>\n <button class=\"btn btn-tertiary switch-to-manual-btn\" type=\"button\">Or enter address manually</button>\n </div>\n <datalist id=\"address-lookup__addressess\"></datalist>\n\n <div class=\"manual-address pb-2 js-hide\">\n <slot></slot>\n <button class=\"btn btn-tertiary switch-to-lookup-btn\" type=\"button\">Use postcode lookup</button>\n <slot name=\"after\"></slot>\n </div>\n <div class=\"pre-filled pb-2 js-hide\">\n <strong class=\"title text-primary d-block\"></strong>\n <p><span class=\"pre-filled-address\"></span><button class=\"text-primary text-decoration-none ms-1 cursor-pointer\" type=\"button\"><i class=\"fa-regular fa-pen-to-square\"></i><span class=\"visually-hidden\">Edit</span></button><slot name=\"prefilled\"></slot></p>\n </div>\n </div>\n `;\n (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(template.content.cloneNode(true));\n }\n connectedCallback() {\n return __awaiter(this, void 0, void 0, function* () {\n const component = this;\n const wrapper = this.shadowRoot.querySelector('.wrapper');\n const lookup = this.shadowRoot.querySelector('[name=\"postcode\"]');\n const lookupWrapper = this.shadowRoot.querySelector('.postcode-lookup');\n const manualWrapper = this.shadowRoot.querySelector('.manual-address');\n const preFilledWrapper = this.shadowRoot.querySelector('.pre-filled');\n const list = this.shadowRoot.querySelector('datalist');\n const switchManualBtn = this.shadowRoot.querySelector('.switch-to-manual-btn');\n const switchLookupBtn = this.shadowRoot.querySelector('.switch-to-lookup-btn');\n const title = this.hasAttribute('data-title') ? this.getAttribute('data-title') : 'Property address';\n const preFilledAddressBtn = this.shadowRoot.querySelector('.pre-filled-address + button');\n Array.from(this.shadowRoot.querySelectorAll('.title')).forEach((titleElement, index) => {\n titleElement.innerHTML = title;\n });\n function checkFilled(component) {\n const preFilledAddress = component.shadowRoot.querySelector('.pre-filled-address');\n let preFilled = true;\n preFilledAddress.innerHTML = '';\n Array.from(component.querySelectorAll('input[required],input[data-required],select[required],select[data-required]')).forEach((input, index) => {\n const value = input.value;\n if (!value)\n preFilled = false;\n else\n preFilledAddress.innerHTML += value + (/^-?\\d+$/.test(value) ? ' ' : ', ');\n });\n preFilledAddress.innerHTML = preFilledAddress.innerHTML.slice(0, -2);\n if (preFilled) {\n preFilledWrapper.classList.remove('js-hide');\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.add('js-hide');\n }\n }\n checkFilled(this);\n this.addEventListener('filled', (event) => {\n checkFilled(this);\n });\n if (this.hasAttribute('data-use')) {\n const useLabel = this.hasAttribute('data-use-label') ? this.getAttribute('data-use-label') : 'Use saved address';\n const useCheckbox = `<div><input type=\"checkbox\" name=\"use\" id=\"use\" value=\"yes\"><label for=\"use\">${useLabel}</label></div>`;\n lookupWrapper.insertAdjacentHTML('afterbegin', useCheckbox);\n this.shadowRoot.addEventListener('change', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('[name=\"use\"]')) {\n const checkbox = event.target.closest('[name=\"use\"]');\n if (checkbox.checked) {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n const values = JSON.parse(this.getAttribute('data-use'));\n Object.keys(values).forEach((key, index) => {\n const value = values[key];\n if (this.querySelector(`[data-name=\"${key}\"]`))\n this.querySelector(`[data-name=\"${key}\"]`).value = value;\n else if (this.querySelector(`[name=\"${key}\"]`))\n this.querySelector(`[name=\"${key}\"]`).value = value;\n });\n }\n }\n });\n }\n if (this.hasAttribute('data-manual')) {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n Array.from(manualWrapper.querySelectorAll('[data-required]')).forEach((input, index) => {\n input.setAttribute('required', 'true');\n });\n }\n function openManualWrapper() {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n Array.from(manualWrapper.querySelectorAll('[data-required]')).forEach((input, index) => {\n input.setAttribute('required', 'true');\n });\n manualWrapper.scrollIntoView();\n }\n preFilledAddressBtn.addEventListener('click', (event) => {\n preFilledWrapper.classList.add('js-hide');\n openManualWrapper();\n });\n switchManualBtn.addEventListener('click', (event) => {\n openManualWrapper();\n });\n switchLookupBtn.addEventListener('click', (event) => {\n lookupWrapper.classList.remove('js-hide');\n manualWrapper.classList.add('js-hide');\n lookupWrapper.scrollIntoView();\n });\n lookup.addEventListener('keyup', (event) => {\n if (lookup.value.length >= 3)\n search(lookup.value);\n });\n lookup.addEventListener('change', (event) => {\n if (lookup.value.length >= 3) {\n search(lookup.value);\n if (list.querySelector(`[value=\"${lookup.value}\"]`)) {\n lookupWrapper.classList.add('js-hide');\n manualWrapper.classList.remove('js-hide');\n const values = JSON.parse(list.querySelector(`[value=\"${lookup.value}\"]`).getAttribute('data-values'));\n Object.keys(values).forEach((key, index) => {\n const value = values[key];\n if (this.querySelector(`[data-name=\"${key}\"]`) && value != '')\n this.querySelector(`[data-name=\"${key}\"]`).value = value;\n else if (this.querySelector(`[data-name-alt=\"${key}\"]`) && value != '')\n this.querySelector(`[data-name-alt=\"${key}\"]`).value = value;\n else if (this.querySelector(`[name=\"${key}\"]`) && value != '')\n this.querySelector(`[name=\"${key}\"]`).value = value;\n if (this.querySelector(`[data-name-2=\"${key}\"]`))\n this.querySelector(`[data-name-2=\"${key}\"]`).value += ' ' + value;\n });\n // Focus on first input\n this.querySelector('[name]').focus();\n Array.from(this.querySelectorAll('[data-required]')).forEach((input, index) => {\n input.setAttribute('required', 'true');\n });\n lookup.removeAttribute('required');\n if (this.shadowRoot.querySelector('[name=\"use\"]'))\n this.shadowRoot.querySelector('[name=\"use\"]').checked = false;\n }\n }\n });\n const search = (postcode) => __awaiter(this, void 0, void 0, function* () {\n let ajaxURL = this.getAttribute('data-url');\n ajaxURL += `${encodeURI(postcode)}`;\n // Setup controller vars if not already set\n if (!window.controller)\n window.controller = [];\n // Abort if controller already present for this url\n if (window.controller[ajaxURL])\n window.controller[ajaxURL].abort();\n // Create a new controller so it can be aborted if new fetch made\n window.controller[ajaxURL] = new AbortController();\n const { signal } = controller[ajaxURL];\n try {\n yield fetch(ajaxURL, {\n signal: signal,\n method: 'get',\n credentials: 'same-origin',\n headers: new Headers({\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n 'X-Requested-With': 'XMLHttpRequest',\n 'X-XSRF-TOKEN': Cookies.get('XSRF-TOKEN'),\n }),\n })\n .then((response) => response.json())\n .then((response) => {\n // populate datalist\n let listString = '';\n response.forEach((address, index) => {\n // Deal with agent platform response\n if (typeof address.value == 'object') {\n const values = JSON.stringify(address.value);\n listString += `<option value=\"${address['label']}, ${postcode}\" data-values='${values}'></option>`;\n }\n else {\n const values = JSON.stringify(address);\n if (component.hasAttribute('data-display-text')) {\n listString += `<option value=\"${address[component.getAttribute('data-display-text')]}, ${postcode}\" data-values='${values}'></option>`;\n }\n else {\n let itemString = '';\n for (const [key, value] of Object.entries(address)) {\n if (key == 'address_number_name')\n itemString += `${value} `;\n else if (key != 'postcode' && key != 'address_title')\n itemString += `${value}${/^-?\\d+$/.test(value) ? '' : ','} `;\n }\n listString += `<option value=\"${itemString}${postcode}\" data-values='${values}'></option>`;\n }\n }\n });\n list.innerHTML = listString;\n return response;\n });\n }\n catch (error) {\n console.log(error);\n }\n });\n });\n }\n}\nexport default iamAddressLookup;\n"],"names":["__awaiter","thisArg","_arguments","P","generator","adopt","value","resolve","reject","fulfilled","step","e","rejected","result","iamAddressLookup","_a","assetLocation","coreCSS","template","component","lookup","lookupWrapper","manualWrapper","preFilledWrapper","list","switchManualBtn","switchLookupBtn","title","preFilledAddressBtn","titleElement","index","checkFilled","preFilledAddress","preFilled","input","event","useCheckbox","values","key","openManualWrapper","search","postcode","ajaxURL","signal","Cookies","response","listString","address","itemString","error"],"mappings":"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"}
@@ -1,19 +1,23 @@
1
1
  // @ts-nocheck
2
- import createAppliedFilters from "../../modules/applied-filters.js";
2
+ import createAppliedFilters from '../../modules/applied-filters.js';
3
3
  // Data layer Web component created
4
4
  window.dataLayer = window.dataLayer || [];
5
5
  window.dataLayer.push({
6
- "event": "customElementRegistered",
7
- "element": "Applied Filters"
6
+ event: 'customElementRegistered',
7
+ element: 'Applied Filters',
8
8
  });
9
9
  class iamAppliedFilters extends HTMLElement {
10
10
  constructor() {
11
11
  super();
12
12
  this.attachShadow({ mode: 'open' });
13
- const assetLocation = document.body.hasAttribute('data-assets-location') ? document.body.getAttribute('data-assets-location') : '/assets';
14
- const coreCSS = document.body.hasAttribute('data-core-css') ? document.body.getAttribute('data-core-css') : `${assetLocation}/css/core.min.css`;
13
+ const assetLocation = document.body.hasAttribute('data-assets-location')
14
+ ? document.body.getAttribute('data-assets-location')
15
+ : '/assets';
16
+ const coreCSS = document.body.hasAttribute('data-core-css')
17
+ ? document.body.getAttribute('data-core-css')
18
+ : `${assetLocation}/css/core.min.css`;
15
19
  const loadCSS = `@import "${assetLocation}/css/components/applied-filters.css";`;
16
- let classList = this.classList.toString();
20
+ const classList = this.classList.toString();
17
21
  const template = document.createElement('template');
18
22
  template.innerHTML = `
19
23
  <style>