@iamproperty/components 3.4.6 → 3.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (304) hide show
  1. package/assets/bootstrap/LICENSE +22 -0
  2. package/assets/bootstrap/README.md +246 -0
  3. package/assets/bootstrap/js/src/alert.js +87 -0
  4. package/assets/bootstrap/js/src/base-component.js +85 -0
  5. package/assets/bootstrap/js/src/button.js +72 -0
  6. package/assets/bootstrap/js/src/carousel.js +475 -0
  7. package/assets/bootstrap/js/src/collapse.js +302 -0
  8. package/assets/bootstrap/js/src/dom/data.js +55 -0
  9. package/assets/bootstrap/js/src/dom/event-handler.js +320 -0
  10. package/assets/bootstrap/js/src/dom/manipulator.js +71 -0
  11. package/assets/bootstrap/js/src/dom/selector-engine.js +83 -0
  12. package/assets/bootstrap/js/src/dropdown.js +454 -0
  13. package/assets/bootstrap/js/src/modal.js +377 -0
  14. package/assets/bootstrap/js/src/offcanvas.js +283 -0
  15. package/assets/bootstrap/js/src/popover.js +97 -0
  16. package/assets/bootstrap/js/src/scrollspy.js +294 -0
  17. package/assets/bootstrap/js/src/tab.js +305 -0
  18. package/assets/bootstrap/js/src/toast.js +225 -0
  19. package/assets/bootstrap/js/src/tooltip.js +633 -0
  20. package/assets/bootstrap/js/src/util/backdrop.js +149 -0
  21. package/assets/bootstrap/js/src/util/component-functions.js +34 -0
  22. package/assets/bootstrap/js/src/util/config.js +66 -0
  23. package/assets/bootstrap/js/src/util/focustrap.js +115 -0
  24. package/assets/bootstrap/js/src/util/index.js +336 -0
  25. package/assets/bootstrap/js/src/util/sanitizer.js +118 -0
  26. package/assets/bootstrap/js/src/util/scrollbar.js +114 -0
  27. package/assets/bootstrap/js/src/util/swipe.js +146 -0
  28. package/assets/bootstrap/js/src/util/template-factory.js +160 -0
  29. package/assets/bootstrap/package.json +181 -0
  30. package/assets/bootstrap/scss/_accordion.scss +149 -0
  31. package/assets/bootstrap/scss/_alert.scss +71 -0
  32. package/assets/bootstrap/scss/_badge.scss +38 -0
  33. package/assets/bootstrap/scss/_breadcrumb.scss +40 -0
  34. package/assets/bootstrap/scss/_button-group.scss +142 -0
  35. package/assets/bootstrap/scss/_buttons.scss +207 -0
  36. package/assets/bootstrap/scss/_card.scss +234 -0
  37. package/assets/bootstrap/scss/_carousel.scss +226 -0
  38. package/assets/bootstrap/scss/_close.scss +40 -0
  39. package/assets/bootstrap/scss/_containers.scss +41 -0
  40. package/assets/bootstrap/scss/_dropdown.scss +249 -0
  41. package/assets/bootstrap/scss/_forms.scss +9 -0
  42. package/assets/bootstrap/scss/_functions.scss +302 -0
  43. package/assets/bootstrap/scss/_grid.scss +33 -0
  44. package/assets/bootstrap/scss/_helpers.scss +10 -0
  45. package/assets/bootstrap/scss/_images.scss +42 -0
  46. package/assets/bootstrap/scss/_list-group.scss +192 -0
  47. package/assets/bootstrap/scss/_maps.scss +54 -0
  48. package/assets/bootstrap/scss/_mixins.scss +43 -0
  49. package/assets/bootstrap/scss/_modal.scss +237 -0
  50. package/assets/bootstrap/scss/_nav.scss +172 -0
  51. package/assets/bootstrap/scss/_navbar.scss +278 -0
  52. package/assets/bootstrap/scss/_offcanvas.scss +144 -0
  53. package/assets/bootstrap/scss/_pagination.scss +109 -0
  54. package/assets/bootstrap/scss/_placeholders.scss +51 -0
  55. package/assets/bootstrap/scss/_popover.scss +196 -0
  56. package/assets/bootstrap/scss/_progress.scss +59 -0
  57. package/assets/bootstrap/scss/_reboot.scss +610 -0
  58. package/assets/bootstrap/scss/_root.scss +73 -0
  59. package/assets/bootstrap/scss/_spinners.scss +85 -0
  60. package/assets/bootstrap/scss/_tables.scss +164 -0
  61. package/assets/bootstrap/scss/_toasts.scss +73 -0
  62. package/assets/bootstrap/scss/_tooltip.scss +120 -0
  63. package/assets/bootstrap/scss/_transitions.scss +27 -0
  64. package/assets/bootstrap/scss/_type.scss +106 -0
  65. package/assets/bootstrap/scss/_utilities.scss +647 -0
  66. package/assets/bootstrap/scss/_variables.scss +1634 -0
  67. package/assets/bootstrap/scss/bootstrap-grid.scss +64 -0
  68. package/assets/bootstrap/scss/bootstrap-reboot.scss +9 -0
  69. package/assets/bootstrap/scss/bootstrap-utilities.scss +18 -0
  70. package/assets/bootstrap/scss/bootstrap.scss +51 -0
  71. package/assets/bootstrap/scss/forms/_floating-labels.scss +75 -0
  72. package/assets/bootstrap/scss/forms/_form-check.scss +175 -0
  73. package/assets/bootstrap/scss/forms/_form-control.scss +194 -0
  74. package/assets/bootstrap/scss/forms/_form-range.scss +91 -0
  75. package/assets/bootstrap/scss/forms/_form-select.scss +71 -0
  76. package/assets/bootstrap/scss/forms/_form-text.scss +11 -0
  77. package/assets/bootstrap/scss/forms/_input-group.scss +132 -0
  78. package/assets/bootstrap/scss/forms/_labels.scss +36 -0
  79. package/assets/bootstrap/scss/forms/_validation.scss +12 -0
  80. package/assets/bootstrap/scss/helpers/_clearfix.scss +3 -0
  81. package/assets/bootstrap/scss/helpers/_color-bg.scss +10 -0
  82. package/assets/bootstrap/scss/helpers/_colored-links.scss +12 -0
  83. package/assets/bootstrap/scss/helpers/_position.scss +36 -0
  84. package/assets/bootstrap/scss/helpers/_ratio.scss +26 -0
  85. package/assets/bootstrap/scss/helpers/_stacks.scss +15 -0
  86. package/assets/bootstrap/scss/helpers/_stretched-link.scss +15 -0
  87. package/assets/bootstrap/scss/helpers/_text-truncation.scss +7 -0
  88. package/assets/bootstrap/scss/helpers/_visually-hidden.scss +8 -0
  89. package/assets/bootstrap/scss/helpers/_vr.scss +8 -0
  90. package/assets/bootstrap/scss/mixins/_alert.scss +15 -0
  91. package/assets/bootstrap/scss/mixins/_backdrop.scss +14 -0
  92. package/assets/bootstrap/scss/mixins/_banner.scss +9 -0
  93. package/assets/bootstrap/scss/mixins/_border-radius.scss +78 -0
  94. package/assets/bootstrap/scss/mixins/_box-shadow.scss +18 -0
  95. package/assets/bootstrap/scss/mixins/_breakpoints.scss +127 -0
  96. package/assets/bootstrap/scss/mixins/_buttons.scss +70 -0
  97. package/assets/bootstrap/scss/mixins/_caret.scss +64 -0
  98. package/assets/bootstrap/scss/mixins/_clearfix.scss +9 -0
  99. package/assets/bootstrap/scss/mixins/_color-scheme.scss +7 -0
  100. package/assets/bootstrap/scss/mixins/_container.scss +11 -0
  101. package/assets/bootstrap/scss/mixins/_deprecate.scss +10 -0
  102. package/assets/bootstrap/scss/mixins/_forms.scss +152 -0
  103. package/assets/bootstrap/scss/mixins/_gradients.scss +47 -0
  104. package/assets/bootstrap/scss/mixins/_grid.scss +151 -0
  105. package/assets/bootstrap/scss/mixins/_image.scss +16 -0
  106. package/assets/bootstrap/scss/mixins/_list-group.scss +24 -0
  107. package/assets/bootstrap/scss/mixins/_lists.scss +7 -0
  108. package/assets/bootstrap/scss/mixins/_pagination.scss +10 -0
  109. package/assets/bootstrap/scss/mixins/_reset-text.scss +17 -0
  110. package/assets/bootstrap/scss/mixins/_resize.scss +6 -0
  111. package/assets/bootstrap/scss/mixins/_table-variants.scss +24 -0
  112. package/assets/bootstrap/scss/mixins/_text-truncate.scss +8 -0
  113. package/assets/bootstrap/scss/mixins/_transition.scss +26 -0
  114. package/assets/bootstrap/scss/mixins/_utilities.scss +97 -0
  115. package/assets/bootstrap/scss/mixins/_visually-hidden.scss +29 -0
  116. package/assets/bootstrap/scss/utilities/_api.scss +47 -0
  117. package/assets/bootstrap/scss/vendor/_rfs.scss +354 -0
  118. package/assets/css/components/accordion.css +1 -1
  119. package/assets/css/components/accordion.css.map +1 -1
  120. package/assets/css/components/admin-panel.css +1 -0
  121. package/assets/css/components/admin-panel.css.map +1 -0
  122. package/assets/css/components/alert.css +1 -1
  123. package/assets/css/components/alert.css.map +1 -1
  124. package/assets/css/components/applied-filters.css +1 -0
  125. package/assets/css/components/applied-filters.css.map +1 -0
  126. package/assets/css/components/card.css +1 -1
  127. package/assets/css/components/card.css.map +1 -1
  128. package/assets/css/components/carousel.css +1 -1
  129. package/assets/css/components/carousel.css.map +1 -1
  130. package/assets/css/components/charts.css +1 -1
  131. package/assets/css/components/charts.css.map +1 -1
  132. package/assets/css/components/container.css +1 -1
  133. package/assets/css/components/container.css.map +1 -1
  134. package/assets/css/components/dialog.css +1 -0
  135. package/assets/css/components/dialog.css.map +1 -0
  136. package/assets/css/components/forms.css +1 -1
  137. package/assets/css/components/forms.css.map +1 -1
  138. package/assets/css/components/header.css +1 -1
  139. package/assets/css/components/header.css.map +1 -1
  140. package/assets/css/components/lists.css +1 -1
  141. package/assets/css/components/lists.css.map +1 -1
  142. package/assets/css/components/nav.css +1 -1
  143. package/assets/css/components/nav.css.map +1 -1
  144. package/assets/css/components/pagination.css +1 -0
  145. package/assets/css/components/pagination.css.map +1 -0
  146. package/assets/css/components/property-searchbar.css +1 -1
  147. package/assets/css/components/property-searchbar.css.map +1 -1
  148. package/assets/css/components/stepper.css +1 -1
  149. package/assets/css/components/stepper.css.map +1 -1
  150. package/assets/css/components/table.css +1 -0
  151. package/assets/css/components/table.css.map +1 -0
  152. package/assets/css/components/tabs.css +1 -1
  153. package/assets/css/components/tabs.css.map +1 -1
  154. package/assets/css/components/tooltips.css +1 -1
  155. package/assets/css/components/tooltips.css.map +1 -1
  156. package/assets/css/core.min.css +1 -1
  157. package/assets/css/core.min.css.map +1 -1
  158. package/assets/css/style.min.css +1 -1
  159. package/assets/css/style.min.css.map +1 -1
  160. package/assets/js/bundle.js +18 -11
  161. package/assets/js/components/accordion/accordion.component.js +6 -0
  162. package/assets/js/components/accordion/accordion.component.min.js +3 -3
  163. package/assets/js/components/accordion/accordion.component.min.js.map +1 -1
  164. package/assets/js/components/applied-filters/applied-filters.component.js +26 -0
  165. package/assets/js/components/card/card.component.js +91 -0
  166. package/assets/js/components/card/card.component.min.js +21 -0
  167. package/assets/js/components/card/card.component.min.js.map +1 -0
  168. package/assets/js/components/filterlist/filterlist.component.js +49 -0
  169. package/assets/js/components/filterlist/filterlist.component.min.js +23 -0
  170. package/assets/js/components/filterlist/filterlist.component.min.js.map +1 -0
  171. package/assets/js/components/header/header.component.js +6 -0
  172. package/assets/js/components/header/header.component.min.js +5 -5
  173. package/assets/js/components/header/header.component.min.js.map +1 -1
  174. package/assets/js/components/pagination/pagination.component.js +34 -0
  175. package/assets/js/components/table/table.component.js +108 -0
  176. package/assets/js/components/table/table.component.min.js +24 -0
  177. package/assets/js/components/table/table.component.min.js.map +1 -0
  178. package/assets/js/components/tabs/tabs.component.js +6 -0
  179. package/assets/js/components/tabs/tabs.component.min.js +17 -0
  180. package/assets/js/components/tabs/tabs.component.min.js.map +1 -0
  181. package/assets/js/dynamic.js +7 -18
  182. package/assets/js/dynamic.min.js +2 -53
  183. package/assets/js/dynamic.min.js.map +1 -1
  184. package/assets/js/flat-components.js +27 -9
  185. package/assets/js/modules/applied-filters.js +100 -0
  186. package/assets/js/modules/data-layer.js +45 -0
  187. package/assets/js/modules/filterlist.js +32 -0
  188. package/assets/js/modules/helpers.js +102 -49
  189. package/assets/js/modules/pagination.js +33 -0
  190. package/assets/js/modules/table.js +506 -420
  191. package/assets/js/modules/tabs.js +6 -0
  192. package/assets/js/modules/youtubevideo.js +53 -61
  193. package/assets/js/scripts.bundle.js +77 -62
  194. package/assets/js/scripts.bundle.js.map +1 -1
  195. package/assets/js/scripts.bundle.min.js +2 -2
  196. package/assets/js/scripts.bundle.min.js.map +1 -1
  197. package/assets/js/tests/filterlist.spec.js +22 -0
  198. package/assets/js/tests/pagination.spec.js +15 -0
  199. package/assets/js/tests/table.spec.js +149 -0
  200. package/assets/sass/_components.scss +1 -2
  201. package/assets/sass/_corefiles.scss +20 -19
  202. package/assets/sass/_forms.scss +7 -7
  203. package/assets/sass/_functions/functions.scss +1 -1
  204. package/assets/sass/_functions/mixins.scss +19 -21
  205. package/assets/sass/_functions/utilities.scss +67 -9
  206. package/assets/sass/_functions/variables.scss +109 -55
  207. package/assets/sass/_tests/colours.spec.scss +8 -22
  208. package/assets/sass/components/accordion.scss +13 -0
  209. package/assets/sass/components/admin-panel.scss +106 -0
  210. package/assets/sass/components/alert.scss +22 -0
  211. package/assets/sass/components/applied-filters.scss +65 -0
  212. package/assets/sass/components/card.scss +177 -233
  213. package/assets/sass/components/carousel.scss +72 -0
  214. package/assets/sass/components/charts.scss +41 -1
  215. package/assets/sass/components/container.scss +8 -3
  216. package/assets/sass/components/dialog.scss +208 -0
  217. package/assets/sass/components/forms.scss +37 -5
  218. package/assets/sass/components/lists.scss +29 -0
  219. package/assets/sass/components/nav.scss +6 -2
  220. package/assets/sass/components/pagination.scss +140 -0
  221. package/assets/sass/components/stepper.scss +3 -3
  222. package/assets/sass/components/table.scss +423 -0
  223. package/assets/sass/components/tabs.scss +20 -7
  224. package/assets/sass/components/tooltips.scss +1 -1
  225. package/assets/sass/foundations/buttons.scss +366 -0
  226. package/assets/sass/foundations/icons.scss +1 -1
  227. package/assets/sass/foundations/links.scss +125 -0
  228. package/assets/sass/foundations/media.scss +1 -1
  229. package/assets/sass/foundations/reboot.scss +21 -17
  230. package/assets/sass/foundations/root.scss +9 -29
  231. package/assets/sass/foundations/type.scss +1 -1
  232. package/assets/svg/illustrations/table.svg +165 -0
  233. package/assets/ts/bundle.ts +23 -12
  234. package/assets/ts/components/accordion/accordion.component.ts +7 -0
  235. package/assets/ts/components/applied-filters/README.md +5 -0
  236. package/assets/ts/components/applied-filters/applied-filters.component.ts +33 -0
  237. package/assets/ts/components/card/README.md +22 -0
  238. package/assets/ts/components/card/card.component.ts +117 -0
  239. package/assets/ts/components/filterlist/README.md +17 -0
  240. package/assets/ts/components/filterlist/filterlist.component.ts +60 -0
  241. package/assets/ts/components/header/header.component.ts +8 -0
  242. package/assets/ts/components/pagination/README.md +11 -0
  243. package/assets/ts/components/pagination/pagination.component.ts +45 -0
  244. package/assets/ts/components/table/README.md +23 -0
  245. package/assets/ts/components/table/table.component.ts +133 -0
  246. package/assets/ts/components/tabs/tabs.component.ts +7 -0
  247. package/assets/ts/dynamic.ts +12 -19
  248. package/assets/ts/flat-components.ts +37 -9
  249. package/assets/ts/modules/applied-filters.ts +146 -0
  250. package/assets/ts/modules/data-layer.ts +58 -0
  251. package/assets/ts/modules/filterlist.ts +46 -0
  252. package/assets/ts/modules/helpers.ts +129 -58
  253. package/assets/ts/modules/pagination.ts +44 -0
  254. package/assets/ts/modules/table.ts +598 -433
  255. package/assets/ts/modules/tabs.ts +8 -1
  256. package/assets/ts/modules/youtubevideo.ts +58 -63
  257. package/assets/ts/tests/filterlist.spec.ts +29 -0
  258. package/assets/ts/tests/pagination.spec.ts +21 -0
  259. package/assets/ts/tests/table.spec.ts +194 -0
  260. package/dist/components.es.js +1267 -1295
  261. package/dist/components.umd.js +70 -65
  262. package/dist/style.css +1 -1
  263. package/package.json +8 -5
  264. package/src/components/AppliedFilters/AppliedFilters.vue +20 -0
  265. package/src/components/AppliedFilters/README.md +5 -0
  266. package/src/components/Card/Card.vue +11 -112
  267. package/src/components/Card/README.md +16 -18
  268. package/src/components/Carousel/Carousel.vue +49 -10
  269. package/src/components/Chart/Chart.vue +46 -4
  270. package/src/components/Filterlist/Filterlist.vue +20 -0
  271. package/src/components/Filterlist/README.md +17 -0
  272. package/src/components/Pagination/Pagination.vue +30 -0
  273. package/src/components/Pagination/README.md +11 -0
  274. package/src/components/Table/README.md +29 -44
  275. package/src/components/Table/Table.spec.js +5 -37
  276. package/src/components/Table/Table.vue +16 -91
  277. package/src/foundations/YoutubeVideo/YoutubeVideo.vue +1 -1
  278. package/src/index.js +3 -2
  279. package/assets/css/components/buttons.css +0 -1
  280. package/assets/css/components/buttons.css.map +0 -1
  281. package/assets/css/components/cardDeck.css +0 -1
  282. package/assets/css/components/cardDeck.css.map +0 -1
  283. package/assets/css/components/links.css +0 -1
  284. package/assets/css/components/links.css.map +0 -1
  285. package/assets/css/components/modal.css +0 -1
  286. package/assets/css/components/modal.css.map +0 -1
  287. package/assets/css/components/panel.css +0 -1
  288. package/assets/css/components/panel.css.map +0 -1
  289. package/assets/css/components/tables.css +0 -1
  290. package/assets/css/components/tables.css.map +0 -1
  291. package/assets/js/modules/modal.js +0 -69
  292. package/assets/sass/components/buttons.scss +0 -252
  293. package/assets/sass/components/cardDeck.scss +0 -108
  294. package/assets/sass/components/links.scss +0 -99
  295. package/assets/sass/components/modal.scss +0 -136
  296. package/assets/sass/components/panel.scss +0 -161
  297. package/assets/sass/components/tables.scss +0 -291
  298. package/assets/ts/modules/modal.ts +0 -91
  299. package/src/components/CardDeck/CardDeck.spec.js +0 -99
  300. package/src/components/CardDeck/CardDeck.vue +0 -77
  301. package/src/components/CardDeck/README.md +0 -25
  302. package/src/components/Modal/Modal.spec.js +0 -22
  303. package/src/components/Modal/Modal.vue +0 -43
  304. package/src/components/Modal/README.md +0 -20
@@ -1,10 +1,10 @@
1
- import { openBlock as l, createElementBlock as c, createElementVNode as a, toDisplayString as k, normalizeClass as v, createCommentVNode as p, Fragment as x, renderList as L, renderSlot as b, withDirectives as N, mergeProps as T, vModelDynamic as F, vModelText as X, vModelSelect as ee, resolveComponent as H, createVNode as S, createTextVNode as j, normalizeStyle as te, withModifiers as se } from "vue";
2
- const g = (e, r) => {
3
- const t = e.__vccOpts || e;
4
- for (const [o, f] of r)
5
- t[o] = f;
6
- return t;
7
- }, ae = {
1
+ import { openBlock as c, createElementBlock as d, createElementVNode as o, toDisplayString as L, normalizeClass as v, createCommentVNode as _, Fragment as $, renderList as T, renderSlot as p, withDirectives as N, mergeProps as H, vModelDynamic as P, vModelText as se, vModelSelect as ie, resolveComponent as E, createVNode as S, createTextVNode as le, normalizeStyle as ne, withModifiers as re } from "vue";
2
+ const A = (t, a) => {
3
+ const e = t.__vccOpts || t;
4
+ for (const [s, r] of a)
5
+ e[s] = r;
6
+ return e;
7
+ }, oe = {
8
8
  name: "Icon",
9
9
  props: {
10
10
  id: {
@@ -18,16 +18,16 @@ const g = (e, r) => {
18
18
  default: "/svg/icons.svg"
19
19
  }
20
20
  }
21
- }, ie = { class: "icon" }, ne = ["xlink:href"];
22
- function re(e, r, t, o, f, s) {
23
- return l(), c("svg", ie, [
24
- a("title", null, k(t.id), 1),
25
- a("use", {
26
- "xlink:href": t.path + "#icon-" + t.id
27
- }, null, 8, ne)
21
+ }, ce = { class: "icon" }, de = ["xlink:href"];
22
+ function ue(t, a, e, s, r, n) {
23
+ return c(), d("svg", ce, [
24
+ o("title", null, L(e.id), 1),
25
+ o("use", {
26
+ "xlink:href": e.path + "#icon-" + e.id
27
+ }, null, 8, de)
28
28
  ]);
29
29
  }
30
- const oe = /* @__PURE__ */ g(ae, [["render", re]]), le = {
30
+ const he = /* @__PURE__ */ A(oe, [["render", ue]]), me = {
31
31
  name: "Logo",
32
32
  props: {
33
33
  id: {
@@ -52,390 +52,393 @@ const oe = /* @__PURE__ */ g(ae, [["render", re]]), le = {
52
52
  return "brand brand--" + this.id;
53
53
  }
54
54
  }
55
- }, ce = ["xlink:href"], de = ["innerHTML"];
56
- function ue(e, r, t, o, f, s) {
57
- return l(), c("div", {
58
- class: v(s.className)
55
+ }, fe = ["xlink:href"], ye = ["innerHTML"];
56
+ function be(t, a, e, s, r, n) {
57
+ return c(), d("div", {
58
+ class: v(n.className)
59
59
  }, [
60
- (l(), c("svg", null, [
61
- a("title", null, "iam " + k(t.id), 1),
62
- a("use", {
63
- "xlink:href": t.path + s.src
64
- }, null, 8, ce)
60
+ (c(), d("svg", null, [
61
+ o("title", null, "iam " + L(e.id), 1),
62
+ o("use", {
63
+ "xlink:href": e.path + n.src
64
+ }, null, 8, fe)
65
65
  ])),
66
- t.desc ? (l(), c("span", {
66
+ e.desc ? (c(), d("span", {
67
67
  key: 0,
68
- innerHTML: t.desc
69
- }, null, 8, de)) : p("", !0)
68
+ innerHTML: e.desc
69
+ }, null, 8, ye)) : _("", !0)
70
70
  ], 2);
71
71
  }
72
- const fe = /* @__PURE__ */ g(le, [["render", ue]]), W = (e) => e.charAt(0).toUpperCase() + e.slice(1), K = (e) => e.replace(/_/g, " "), he = (e) => e.replace(/ /g, "_"), me = function(e) {
73
- return e = e.toLowerCase(), e = he(e), e = e.replace(/\W/g, ""), e;
74
- }, _e = function(e) {
75
- return typeof e != "string" ? !1 : !isNaN(e) && // use type coercion to parse the _entirety_ of the string (`parseFloat` alone does not do this)...
76
- !isNaN(parseFloat(e));
77
- }, ye = (e, r) => String(e).padStart(r, "0");
78
- function Z(e) {
79
- if (typeof e != "object")
72
+ const _e = /* @__PURE__ */ A(me, [["render", be]]), pe = function(t) {
73
+ return typeof t != "string" ? !1 : !isNaN(t) && // use type coercion to parse the _entirety_ of the string (`parseFloat` alone does not do this)...
74
+ !isNaN(parseFloat(t));
75
+ }, ge = (t, a) => String(t).padStart(a, "0"), ve = (t) => t.charAt(0).toUpperCase() + t.slice(1), F = function(t, a) {
76
+ if (!t.getAttribute("data-pages"))
80
77
  return !1;
81
- const r = e.querySelector("thead"), t = e.querySelector("tbody"), o = t.cloneNode(!0), f = new Event("sorted"), s = new Event("filtered"), i = new Event("reordered"), n = "table_" + Math.random().toString(36).substr(2, 9);
82
- let h;
83
- e.setAttribute("id", n);
84
- const w = function(m, u) {
85
- let d = [];
86
- Array.from(t.querySelectorAll("tr")).forEach((y, q) => {
87
- let A = y.querySelector('td[data-label="' + m + '"], th[data-label="' + m + '"]').textContent;
88
- _e(A) && (A = ye(A, 10));
89
- const V = {
90
- index: A,
91
- row: y
92
- };
93
- d.push(V);
94
- }), d.sort((y, q) => y.index > q.index ? 1 : -1), u == "descending" && (d = d.reverse());
95
- let _ = "";
96
- d.forEach((y, q) => {
97
- _ += y.row.outerHTML;
98
- }), t.innerHTML = _, e.dispatchEvent(f);
99
- };
100
- if (e.addEventListener("click", function(m) {
101
- for (var u = m.target; u && u != this; u = u.parentNode)
102
- if (u.matches("[data-sortable]")) {
103
- let d = u.getAttribute("aria-sort") == "ascending" ? "descending" : "ascending";
104
- Array.from(e.querySelectorAll("[data-sortable]")).forEach((_, y) => {
105
- _.setAttribute("aria-sort", "none");
106
- }), u.setAttribute("aria-sort", d), e.setAttribute("data-sort", d), e.setAttribute("data-sortBy", u.textContent), w(u.textContent, d), Array.from(e.querySelectorAll("tr[draggable]")).forEach((_, y) => {
107
- _.removeAttribute("draggable");
108
- });
109
- break;
78
+ t.getAttribute("data-page") || t.setAttribute("data-page", 1);
79
+ let e = t.getAttribute("data-page"), s = t.getAttribute("data-pages"), r = t.getAttribute("data-total"), n = t.getAttribute("data-show"), i = t.getAttribute("data-increment");
80
+ if (s <= 1)
81
+ return a.innerHTML = "", !1;
82
+ let l = "";
83
+ for (let h = 1; h <= s; h++)
84
+ h == e ? l += `<li class="page-item active" aria-current="page"><span class="page-link">${h}</span></li>` : l += `<li class="page-item"><a href="?page=${h}" class="page-link" data-page="${h}">${h}</a></li>`;
85
+ return a.innerHTML = `<ul class="pagination mb-0 d-none d-sm-flex">
86
+ ${e == 1 ? '<li class="page-item disabled"><span class="page-link">Previous</span></li>' : `<li class="page-item"><a href="?page=${parseInt(e) - 1}" class="page-link" data-page="${parseInt(e) - 1}">Previous</a></li>`}
87
+ ${l}
88
+ ${e == s ? '<li class="page-item disabled"><span class="page-link">Next</span></li>' : `<li class="page-item"><a href="?page=${parseInt(e) + 1}" class="page-link" data-page="${parseInt(e) + 1}">Next</a></li>`}
89
+ </ul>`, a.innerHTML += `<div class="d-sm-none text-center">
90
+ <span class="d-block pb-2">You've viewed ${n} of ${r} results</span>
91
+ <a href="?show=${parseInt(n) + parseInt(i)}" class="btn btn-primary w-100 m-0" data-show="${parseInt(n) + parseInt(i)}">Load more results</a>
92
+ </div>`, !0;
93
+ }, G = (t) => {
94
+ const a = Array.from(t.querySelectorAll("thead th"));
95
+ Array.from(t.querySelectorAll("tbody tr")).forEach((s, r) => {
96
+ const n = Array.from(s.querySelectorAll("th, td")), i = ["Low", "Medium", "High", "N/A", "Pending", "Verified", "Incomplete", "Completed", "Requires approval"];
97
+ n.forEach((l, h) => {
98
+ const u = a[h];
99
+ if (typeof u < "u") {
100
+ let m = document.createElement("div");
101
+ m.innerHTML = u.innerHTML;
102
+ let f = m.textContent || m.innerText || "";
103
+ l.setAttribute("data-label", f), u.hasAttribute("class") && l.setAttribute("class", u.getAttribute("class")), u.hasAttribute("data-format") && (l.setAttribute("data-format", u.getAttribute("data-format")), l.innerHTML = D("date", l.textContent.trim())), i.includes(l.textContent.trim()) && l.setAttribute("data-content", l.textContent.trim());
110
104
  }
111
- }, !1), e.getAttribute("data-sortBy")) {
112
- let m = e.getAttribute("data-sort") == "ascending" ? "descending" : "ascending";
113
- Array.from(e.querySelectorAll("[data-sortable]")).forEach((u, d) => {
114
- u.textContent == e.getAttribute("data-sortBy") && (u.setAttribute("aria-sort", m), u.click());
115
105
  });
116
- }
117
- const $ = function(m) {
118
- const u = document.createElement("div");
119
- u.classList.add("table__filters"), u.classList.add("row"), u.classList.add("pt-1"), u.classList.add("pb-3");
120
- const d = Array.from(e.querySelectorAll("th[data-filterable]"));
121
- let _ = {};
122
- d.forEach((A, V) => {
123
- Array.from(e.querySelectorAll('td[data-label="' + A.textContent + '"]')).forEach((R, li) => {
124
- _[R.textContent] = R.textContent;
125
- });
126
- });
127
- const y = d.length == 1 ? "Filter by " + d[0].textContent : "Filter", q = d.length == 1 ? "d-none" : "d-sm-flex";
128
- u.innerHTML = `<div class="col-sm-6 col-md-4 pb-3">
129
- <div class="form-control__wrapper form-control-inline mb-0">
130
- <label for="${n}_filter" class="form-label">${y}:</label>
131
- <input type="search" name="${n}_filter" id="${n}_filter" class="form-control form-control-sm" placeholder="" list="${n}_list" />
132
- </div>
133
- <datalist id="${n}_list">
134
- ${Object.keys(_).map((A) => `<option value="${A}"></option>`).join("")}
135
- </datalist>
136
- </div>
137
- <div class="col-md-8 align-items-center pb-3 ${q}">
138
- ${'<span class="pe-3 text-nowrap h5 mb-0">Filter by: </span>' + d.map((A) => `<div class="form-check pe-3 mt-0 mb-0"><input class="form-check-input" type="checkbox" id="${n}_${A.textContent.replace(" ", "_").toLowerCase()}" checked="checked" /><label class="form-check-label text-nowrap" for="${n}_${A.textContent.replace(" ", "_").toLowerCase()}">${A.textContent}</label></div>`).join("")}
139
- </div>`, e.prepend(u);
140
- }, M = function(m) {
141
- let u = [];
142
- Array.from(o.querySelectorAll("tr")).forEach((_, y) => {
143
- let q = "";
144
- if (Array.from(e.querySelectorAll('[type="checkbox"]:checked + label')).forEach((A, V) => {
145
- q += _.querySelector('td[data-label="' + A.textContent + '"]').textContent + " | ";
146
- }), q.indexOf(m) >= 0) {
147
- const A = { row: _ };
148
- u.push(A);
149
- }
106
+ });
107
+ }, Ae = (t) => {
108
+ let a = 0;
109
+ return Array.from(t.querySelectorAll("tr")).forEach((e, s) => {
110
+ let r = window.getComputedStyle(document.querySelector("html")), n = e.querySelector(":scope > *:last-child > *:first-child");
111
+ if (n) {
112
+ let l = n.offsetWidth / parseFloat(r.fontSize);
113
+ l += 1.5, a = a > l ? a : l;
114
+ }
115
+ let i = e.offsetHeight / parseFloat(r.fontSize);
116
+ e.style.setProperty("--row-height", `${i}rem`);
117
+ }), a;
118
+ }, we = (t) => {
119
+ if (t.closest(".table--fullwidth"))
120
+ return !1;
121
+ Array.from(t.querySelectorAll("tbody tr")).forEach((a, e) => {
122
+ let s = a.querySelector(":scope > :is(td,th):first-child"), r = s.textContent;
123
+ s.innerHTML = `<span class="td__content">${r}</span><button type="button" class="d-none">${r}</button>`;
124
+ });
125
+ }, Se = (t) => {
126
+ t.addEventListener("click", (a) => {
127
+ if (a && a.target instanceof HTMLElement && a.target.closest("tr > :is(td,th):first-child button")) {
128
+ let e = a.target.closest("tr > :is(td,th):first-child button"), s = e.parentNode.closest("tr");
129
+ s.getAttribute("data-view") == "full" ? s.setAttribute("data-view", "default") : s.setAttribute("data-view", "full"), e.blur();
130
+ }
131
+ });
132
+ }, Q = (t, a) => {
133
+ let e = a.querySelector("[data-search]");
134
+ if (!e)
135
+ return !1;
136
+ const s = e.getAttribute("id"), r = e.getAttribute("data-search").split(",");
137
+ let n = e.parentNode, i = {};
138
+ r.forEach((l, h) => {
139
+ Array.from(t.querySelectorAll('td[data-label="' + l.trim() + '"]')).forEach((u, m) => {
140
+ u.querySelector(".td__content") ? i[u.querySelector(".td__content").textContent] = u.querySelector(".td__content").textContent : i[u.textContent] = u.textContent;
150
141
  });
151
- let d = "";
152
- u.forEach((_, y) => {
153
- d += _.row.outerHTML;
154
- }), t.innerHTML = d, e.dispatchEvent(s);
155
- }, I = function() {
156
- let m = [];
157
- Array.from(e.querySelectorAll('[type="checkbox"]:checked + label')).forEach((_, y) => {
158
- m.push(_.textContent);
142
+ }), e.setAttribute("list", `${s}_list`), e.setAttribute("autocomplete", "off"), n.querySelector("datalist") || (n.innerHTML += `<datalist id="${s}_list"></datalist>`), n.querySelector("datalist").innerHTML = `${Object.keys(i).map((l) => `<option value="${l}"></option>`).join("")}`;
143
+ }, Le = (t, a, e, s, r) => {
144
+ var n;
145
+ let i = function() {
146
+ a.hasAttribute("data-ajax") ? J(t, a, e, s) : a.hasAttribute("data-submit") ? a.submit() : (Y(t, a, s), F(s, e));
147
+ };
148
+ a.addEventListener("keyup", (l) => {
149
+ clearTimeout(n), l && l.target instanceof HTMLElement && l.target.closest("[data-search]") && (n = setTimeout(function() {
150
+ i();
151
+ }, 500));
152
+ }), a.addEventListener("change", (l) => {
153
+ clearTimeout(n), l && l.target instanceof HTMLElement && l.target.closest("[data-sort]") && (a.hasAttribute("data-submit") || U(t, a, r), i()), l && l.target instanceof HTMLElement && l.target.closest("[data-search]") && i(), l && l.target instanceof HTMLElement && l.target.closest("[data-filter]") && !l.target.closest("form dialog") && i(), l && l.target instanceof HTMLElement && l.target.closest("[data-show]") && i();
154
+ }), a.addEventListener("click", (l) => {
155
+ clearTimeout(n), l && l.target instanceof HTMLElement && l.target.closest('dialog button:not([type="button"])') && l.target.closest('dialog button:not([type="button"])').closest("dialog").close(), l && l.target instanceof HTMLElement && l.target.closest(".dialog__close") && (l.preventDefault(), l.stopPropagation()), l && l.target instanceof HTMLElement && l.target.closest("[data-clear]") && (a.reset(), a.hasAttribute("data-submit") || U(t, a, r), i());
156
+ }), a.addEventListener("submit", (l) => {
157
+ clearTimeout(n), a.hasAttribute("data-submit") || l.preventDefault(), i();
158
+ });
159
+ }, U = (t, a, e) => {
160
+ if (a.getAttribute("data-ajax"))
161
+ return !1;
162
+ let s = t.querySelector("tbody"), r = a.querySelector("[data-sort]"), n = r.querySelector(`option:nth-child(${r.selectedIndex + 1})`), i = n.getAttribute("data-sort"), l = n.getAttribute("data-order"), h = n.getAttribute("data-format");
163
+ if (!i)
164
+ return s.innerHTML = e.innerHTML, G(t), !1;
165
+ let u = [];
166
+ ["asc", "desc", "descending"].includes(l) || (u = l.split(","));
167
+ let m = [];
168
+ Array.from(s.querySelectorAll("tr")).forEach((b, g) => {
169
+ let y = b.querySelector('td[data-label="' + i + '"], th[data-label="' + i + '"]').textContent.trim();
170
+ u.length && u.includes(y) && (y = u.indexOf(y)), pe(y) && (y = ge(y, 10)), h && h == "date" && (y = new Date(y));
171
+ const C = {
172
+ index: y,
173
+ row: b
174
+ };
175
+ m.push(C);
176
+ }), m.sort((b, g) => b.index > g.index ? 1 : -1), (l == "descending" || l == "desc") && (m = m.reverse());
177
+ let f = "";
178
+ m.forEach((b, g) => {
179
+ f += b.row.outerHTML;
180
+ }), s.innerHTML = f;
181
+ }, Y = (t, a, e) => {
182
+ t.classList.remove("table--filtered");
183
+ let s = [], r = [], n = 0, i = a.querySelector("[data-pagination]") ? parseInt(a.querySelector("[data-pagination]").value) : 1, l = a.querySelector("[data-show]") ? parseInt(a.querySelector("[data-show]").value) : 15;
184
+ if (Array.from(a.querySelectorAll("[data-filter]")).forEach((u, m) => {
185
+ if (!(u.type == "radio" && !u.checked) && !(u.type == "checkbox" && !u.checked))
186
+ if (u.getAttribute("data-filter") == "multi")
187
+ for (const [f, b] of Object.entries(JSON.parse(u.value)))
188
+ s[u.getAttribute("data-filter")].push(b);
189
+ else
190
+ u.value && (s[u.getAttribute("data-filter")] || (s[u.getAttribute("data-filter")] = new Array()), s[u.getAttribute("data-filter")].push(u.value));
191
+ }), a.querySelector("[data-search]")) {
192
+ let u = a.querySelector("[data-search]");
193
+ a.querySelector("[data-search]").getAttribute("data-search").split(",").forEach((f, b) => {
194
+ r.push({ column: `${f.trim()}`, value: `${u.value}` });
159
195
  });
160
- let u = [];
161
- m.forEach((_, y) => {
162
- Array.from(e.querySelectorAll('td[data-label="' + _ + '"]')).forEach((q, A) => {
163
- u[q.textContent] = q.textContent;
164
- });
196
+ }
197
+ if (Array.from(a.querySelectorAll("[data-filter-count]")).forEach((u, m) => {
198
+ u.innerHTML = "";
199
+ }), s.length && Array.from(a.querySelectorAll("[data-filter-count]")).forEach((u, m) => {
200
+ u.innerHTML += `(${s.length})`;
201
+ }), !Object.keys(r).length && !Object.keys(s).length)
202
+ return !1;
203
+ t.classList.add("table--filtered"), Array.from(t.querySelectorAll("tbody tr")).forEach((u, m) => {
204
+ u.classList.remove("filtered"), u.classList.remove("filtered--matched"), u.classList.remove("filtered--show"), u.removeAttribute("data-filtered-by");
205
+ });
206
+ for (const [u, m] of Object.entries(s))
207
+ Array.from(t.querySelectorAll("tbody tr:not(.filtered)")).forEach((f, b) => {
208
+ let g = !1;
209
+ m.forEach((y, C) => {
210
+ let M = f.querySelector(`[data-label="${u}"]`);
211
+ if (y && y == "$today")
212
+ y = D("date", /* @__PURE__ */ new Date());
213
+ else if (y && y == "$yesterday") {
214
+ let w = /* @__PURE__ */ new Date();
215
+ w.setDate(w.getDate() - 1), y = D("date", w);
216
+ } else if (y && (y == "$thisWeek" || y == "$lastWeek")) {
217
+ let w = /* @__PURE__ */ new Date(), q = new Date(w.setDate(w.getDate() - (w.getDay() - 1))), x = new Date(w.setDate(w.getDate() - w.getDay() + 7)), k = new Date(M.textContent.toLowerCase());
218
+ if (w.setHours(0, 0, 0, 0), q.setHours(0, 0, 0, 0), x.setHours(0, 0, 0, 0), k.setHours(0, 0, 0, 0), y == "$thisWeek")
219
+ g = k >= q && k <= x;
220
+ else {
221
+ let W = new Date(q.setDate(q.getDate() - 7)), j = new Date(x.setDate(x.getDate() - 7));
222
+ W.setHours(0, 0, 0, 0), j.setHours(0, 0, 0, 0), g = k >= W && k <= j;
223
+ }
224
+ } else if (y && y == "$thisMonth") {
225
+ let w = /* @__PURE__ */ new Date(), q = w.getFullYear(), x = w.getMonth();
226
+ var B = new Date(q, x, 1), V = new Date(q, x + 1, 0);
227
+ let k = new Date(M.textContent.toLowerCase());
228
+ B.setHours(0, 0, 0, 0), V.setHours(0, 0, 0, 0), k.setHours(0, 0, 0, 0), g = k >= B && k <= V;
229
+ } else if (y && y == "$lastMonth") {
230
+ let w = /* @__PURE__ */ new Date(), q = w.getFullYear(), x = w.getMonth();
231
+ var z = new Date(q, x - 1, 1), O = new Date(q, x, 0);
232
+ let k = new Date(M.textContent.toLowerCase());
233
+ z.setHours(0, 0, 0, 0), O.setHours(0, 0, 0, 0), k.setHours(0, 0, 0, 0), g = k >= z && k <= O;
234
+ }
235
+ M && M.textContent.toLowerCase().includes(y.toLowerCase()) && (g = !0);
236
+ }), g || (f.classList.add("filtered"), f.setAttribute("data-filtered-by", u));
165
237
  });
166
- let d = e.querySelector("datalist");
167
- d.innerHTML = Object.keys(u).map((_) => `<option value="${_}"></option>`).join("");
168
- };
169
- Array.from(e.querySelectorAll("[data-filterable]")).length && ($(e, Array.from(e.querySelectorAll("[data-filterable]")).length), e.addEventListener("keyup", function(m) {
170
- for (var u = m.target; u && u != this; u = u.parentNode)
171
- if (u.matches('input[type="search"]')) {
172
- const d = u.value;
173
- M(d);
174
- }
175
- }), e.addEventListener("change", function(m) {
176
- for (var u = m.target; u && u != this; u = u.parentNode)
177
- if (u.matches('input[type="search"]')) {
178
- const d = u.value;
179
- M(d);
180
- }
181
- }), e.addEventListener("change", function(m) {
182
- for (var u = m.target; u && u != this; u = u.parentNode)
183
- if (u.matches('input[type="checkbox"]')) {
184
- const d = e.querySelector('input[type="search"]').value;
185
- M(d), I();
186
- }
187
- }));
188
- const C = function(m, u) {
189
- let d = document.getElementById(n + "_style");
190
- d == null && (d = document.createElement("style"), d.setAttribute("id", n + "_style"));
191
- const _ = m * (u - 1) + 1, y = m * u;
192
- d.innerHTML = `
193
- #${n} tbody tr {
194
- display: none;
195
- }
196
- #${n} tbody tr:nth-child(${_}),
197
- #${n} tbody tr:nth-child(${_}) ~ tr{
198
- display: block;
238
+ Array.from(t.querySelectorAll("tbody tr:not(.filtered)")).forEach((u, m) => {
239
+ let f = !(r.length > 0 && r[0].value.length >= 3);
240
+ r.forEach((b, g) => {
241
+ let y = u.querySelector(`[data-label="${b.column}"]`);
242
+ y && b.value.length >= 3 && y.textContent.toLowerCase().includes(b.value.toLowerCase()) && (f = !0);
243
+ }), f || u.classList.add("filtered");
244
+ }), Array.from(t.querySelectorAll("tbody tr:not(.filtered")).forEach((u, m) => {
245
+ n++, u.classList.add("filtered--matched"), Math.ceil(n / l) == parseInt(i) && u.classList.add("filtered--show");
246
+ }), e && (e.setAttribute("data-page", i), e.setAttribute("data-pages", Math.ceil(n / l)), e.setAttribute("data-total", n), e.setAttribute("data-show", l)), Z(t, a);
247
+ }, Z = (t, a) => {
248
+ Array.from(a.querySelectorAll("[data-query]")).forEach((s, r) => {
249
+ let n = s.getAttribute("data-query"), i;
250
+ if (n == "total")
251
+ i = t.classList.contains("table--filtered") ? t.querySelectorAll("tbody tr:not(.filtered)").length : t.querySelectorAll("tbody tr").length;
252
+ else if (!n.includes(" == ") && n.includes(" & ")) {
253
+ let l = n.split(" & "), h = "";
254
+ l.forEach((u) => {
255
+ h += `:not([data-filtered-by="${u}"])`;
256
+ }), i = Array.from(t.querySelectorAll(`tbody tr${h}`)).length;
257
+ } else if (!n.includes(" == "))
258
+ i = Array.from(t.querySelectorAll(`tbody tr:not([data-filtered-by="${n}"])`)).length;
259
+ else if (n.includes(" && ")) {
260
+ let l = n.split(" && ");
261
+ i = Array.from(t.querySelectorAll("tbody tr:not(.filtered)")).filter(function(h) {
262
+ let u = !0;
263
+ for (const [m, f] of Object.entries(l)) {
264
+ let b = f.split(" == ");
265
+ (!h.querySelector(`td[data-label="${b[0]}"]`) || h.querySelector(`td[data-label="${b[0]}"]`).textContent != `${b[1]}`) && (u = !1);
266
+ }
267
+ return u;
268
+ }).length;
269
+ } else {
270
+ let l = n.split(" == ");
271
+ i = Array.from(t.querySelectorAll(`tbody tr:not([class*="filtered"]) td[data-label="${l[0]}"], tbody tr[data-filtered-by="${l[0]}"] td[data-label="${l[0]}"]`)).filter(function(h) {
272
+ return h.textContent === l[1];
273
+ }).length;
199
274
  }
200
- @media screen and (min-width: 36em) {
201
- #${n} tbody tr:nth-child(${_}),
202
- #${n} tbody tr:nth-child(${_}) ~ tr{
203
- display: table-row;
204
- }
275
+ s.hasAttribute("data-total") ? s.setAttribute("data-total", i) : s.innerHTML = i;
276
+ });
277
+ }, ke = function(t, a, e, s) {
278
+ e.addEventListener("click", (r) => {
279
+ if (r && r.target instanceof HTMLElement && r.target.closest("[data-page]")) {
280
+ r.preventDefault();
281
+ let n = a.querySelector("[data-pagination]"), i = r.target.closest("[data-page]").getAttribute("data-page");
282
+ n.value = i, s.setAttribute("data-page", i), a.dispatchEvent(new Event("submit"));
283
+ const l = new URL(location);
284
+ l.searchParams.set("page", i), history.pushState({ type: "pagination", form: a.getAttribute("id"), page: i }, "", l);
205
285
  }
206
- #${n} tbody tr:nth-child(${y}) ~ tr{
207
- display: none;
286
+ if (r && r.target instanceof HTMLElement && r.target.closest("[data-show]")) {
287
+ r.preventDefault();
288
+ let n = a.querySelector("[data-show]"), i = r.target.closest("[data-show]").getAttribute("data-show");
289
+ n.value = i, s.setAttribute("data-show", i), a.dispatchEvent(new Event("submit"));
208
290
  }
209
- `, e.append(d);
210
- };
211
- if (e.getAttribute("data-show")) {
212
- const m = parseInt(e.getAttribute("data-show")), u = parseInt(e.getAttribute("data-page")) ? parseInt(e.getAttribute("data-page")) : 1, d = e.querySelectorAll("tbody tr").length;
213
- m < d && (C(m, u), U(n, e, m, u, d), B(n, e, m, u, d), e.addEventListener("change", function(_) {
214
- for (var y = _.target; y && y != this; y = y.parentNode)
215
- y.matches('.table__pagination input[type="number"]') && (C(y.value, u), B(n, e, y.value, u, d), e.setAttribute("data-show", y.value));
216
- }), e.addEventListener("click", function(_) {
217
- for (var y = _.target; y && y != this; y = y.parentNode)
218
- y.matches(".page-item:not(.active):not(.disabled) .page-link") && (C(e.getAttribute("data-show"), y.getAttribute("data-page")), B(n, e, e.getAttribute("data-show"), y.getAttribute("data-page"), d));
219
- }, !1), e.addEventListener("change", function(_) {
220
- for (var y = _.target; y && y != this; y = y.parentNode)
221
- y.matches(".table__pagination select") && (C(e.getAttribute("data-show"), y.value), B(n, e, e.getAttribute("data-show"), y.value, d));
222
- }));
291
+ });
292
+ }, qe = (t, a) => {
293
+ if (!t)
294
+ return !1;
295
+ t.addEventListener("click", (e) => {
296
+ xe(a);
297
+ });
298
+ }, xe = function(t) {
299
+ for (var a = [], e = t.getElementsByTagName("tr"), s = 0; s < e.length; s++) {
300
+ for (var r = e[s].querySelectorAll("td,th"), n = [], i = 0; i < r.length; i++)
301
+ n.push(`"${r[i].textContent}"`);
302
+ a.push(n.join(","));
223
303
  }
224
- function J(m) {
225
- m.dataTransfer.setData("text/plain", m.target.id), h = m.target, m.target.classList.add("tr--dragging");
304
+ a = a.join(`
305
+ `);
306
+ let l = new Blob([a], {
307
+ type: "text/csv"
308
+ });
309
+ var h = document.createElement("a");
310
+ h.download = "export.csv";
311
+ var u = window.URL.createObjectURL(l);
312
+ h.href = u, h.style.display = "none", document.body.appendChild(h), h.click(), document.body.removeChild(h);
313
+ }, X = function(t, a, e, s) {
314
+ if (we(t), G(t), Z(t, a), s && s.classList.contains("table--cta")) {
315
+ const r = Ae(t);
316
+ s.style.setProperty("--cta-width", `${r}rem`);
226
317
  }
227
- const z = function() {
228
- Array.from(t.querySelectorAll("tr")).forEach((m, u) => {
229
- if (m.querySelector('[data-label="Order"]') == null) {
230
- const d = document.createElement("th");
231
- d.innerHTML = u + 1, d.setAttribute("data-label", "Order"), m.prepend(d);
232
- }
233
- m.setAttribute("id", n + "_row_" + (u + 1)), m.setAttribute("data-order", u + 1), m.setAttribute("draggable", "true"), m.addEventListener("dragstart", J);
234
- });
235
- };
236
- if (e.getAttribute("data-reorder") && e.getAttribute("data-reorder") != "false") {
237
- const m = document.createElement("th");
238
- m.innerHTML = "Order", m.title = "Click here to enable re-ordering via drag and drop", m.classList.add("table-order-reset"), r.querySelector("tr").prepend(m), z(), e.addEventListener("click", function(u) {
239
- for (var d = u.target; d && d != this; d = d.parentNode)
240
- if (d.matches(".table-order-reset")) {
241
- Array.from(e.querySelectorAll("[data-sortable]")).forEach((_, y) => {
242
- _.setAttribute("aria-sort", "none");
243
- }), e.removeAttribute("data-sort"), e.removeAttribute("data-sortBy"), w("Order", "ascending"), Array.from(e.querySelectorAll("tbody tr")).forEach((_, y) => {
244
- _.setAttribute("draggable", "true");
318
+ }, J = function(t, a, e, s) {
319
+ const r = (l, h, u) => h.split(/[\.\[\]\'\"]/).filter((m) => m).reduce((m, f) => m ? m[f] : u, l);
320
+ new URLSearchParams(new FormData(a)).toString();
321
+ let n = t.querySelectorAll("thead tr th"), i = t.querySelector("tbody");
322
+ fetch(a.getAttribute("data-ajax"), {
323
+ method: "get",
324
+ credentials: "same-origin",
325
+ headers: new Headers({
326
+ "Content-Type": "application/json",
327
+ Accept: "application/json",
328
+ "X-Requested-With": "XMLHttpRequest"
329
+ })
330
+ }).then((l) => l.json()).then((l) => {
331
+ l.data ? (i.innerHTML = "", l.data.forEach((h, u) => {
332
+ var m = document.createElement("tr");
333
+ n.forEach((f, b) => {
334
+ let g = "";
335
+ var y = document.createElement("td");
336
+ if (y.setAttribute("data-label", f.innerText), f.getAttribute("data-output")) {
337
+ var C = f.getAttribute("data-output");
338
+ g = C.replace(new RegExp(/{(.*?)}/, "gm"), function(M) {
339
+ return r(h, M.replace("{", "").replace("}", ""));
245
340
  });
246
- break;
247
341
  }
248
- }, !1), document.addEventListener("dragover", function(u) {
249
- u.preventDefault();
250
- }, !1), document.addEventListener("dragenter", function(u) {
251
- u.preventDefault(), u.dataTransfer.dropEffect = "move";
252
- for (var d = u.target; d && d != this; d = d.parentNode)
253
- d.matches("[data-reorder] tbody tr") && d.classList.add("tr--dropable");
254
- }, !1), document.addEventListener("dragleave", function(u) {
255
- u.preventDefault();
256
- for (var d = u.target; d && d != this; d = d.parentNode)
257
- d.matches("[data-reorder] tbody tr") && d.classList.remove("tr--dropable");
258
- }, !1), document.addEventListener("drop", function(u) {
259
- u.preventDefault();
260
- for (var d = u.target; d && d != this; d = d.parentNode)
261
- if (d.matches("[data-reorder] tbody tr")) {
262
- d.parentNode != null && h.parentNode != null && d != h && (h.parentNode.removeChild(h), h.getAttribute("data-order") > d.getAttribute("data-order") ? d.parentNode.insertBefore(h, d) : d.parentNode.insertBefore(h, d.nextElementSibling), Array.from(t.querySelectorAll("tr")).forEach((_, y) => {
263
- _.classList.remove("tr--dragging"), _.classList.remove("tr--dropable"), _.querySelector("th").innerHTML = y + 1, _.setAttribute("data-order", y + 1);
264
- }), e.dispatchEvent(i));
265
- break;
266
- }
267
- }, !1);
268
- }
269
- e.addEventListener("filtered", function(m) {
270
- if (e.getAttribute("data-sortBy") && e.getAttribute("data-sort") && w(e.getAttribute("data-sortBy"), e.getAttribute("data-sort")), e.getAttribute("data-show")) {
271
- const u = parseInt(e.getAttribute("data-show")), d = e.querySelectorAll("tbody tr").length, _ = e.querySelector(".table__pagination");
272
- _ != null && _.remove(), u < d && (C(u, 1), U(n, e, u, 1, d), B(n, e, u, 1, d));
273
- }
274
- e.getAttribute("data-reorder") && z();
275
- }, !1), e.addEventListener("sorted", function(m) {
276
- e.getAttribute("data-reorder") && z();
277
- }, !1), e.addEventListener("populated", function(m) {
278
- var u = e.querySelector(".table__filters");
279
- u.remove();
280
- var d = e.querySelector(".table__pagination");
281
- d.remove();
282
- var _ = e.cloneNode(!0);
283
- e.parentNode.replaceChild(_, e), Z(_);
284
- }, !1);
285
- }
286
- const U = function(e, r, t, o, f) {
287
- const s = document.createElement("div");
288
- s.classList.add("table__pagination"), s.classList.add("row"), s.classList.add("pt-3"), s.classList.add("pb-3"), s.innerHTML = `<div class="col mw-fit-content mb-3">
289
- <div class="form-control__wrapper form-control-inline mb-0">
290
- <label for="${e}_showing" class="form-label">Showing:</label>
291
- <input type="number" name="${e}_showing" id="${e}_showing" class="form-control form-control-sm showing-input-field" placeholder="" list="${e}_pagination" value="${t}" min="1" max="${f}" />
292
- </div>
293
- <datalist id="${e}_pagination">
294
- <option value="5">5</option>
295
- ${f > 10 ? '<option value="10">10</option>' : ""}
296
- ${f > 20 ? '<option value="20">20</option>' : ""}
297
- <option value="${f}">${f}</option>
298
- </datalist>
299
- </div>
300
- <div class="col mw-fit-content me-auto d-flex align-items-center mb-3"><span class="label">per page</span></div>
301
- <div class="col mw-fit-content d-sm-flex justify-content-end align-items-center" id="${e}_paginationBtns"></div>`, r.append(s);
302
- }, B = function(e, r, t, o, f) {
303
- const s = document.getElementById(e + "_paginationBtns");
304
- if (s == null)
305
- return !1;
306
- const i = Math.ceil(f / t);
307
- if (i == 1)
308
- s.innerHTML = "";
309
- else if (i < 5) {
310
- let n = "";
311
- for (let h = 1; h <= i; h++)
312
- h == o ? n += `<li class="page-item active" aria-current="page"><span class="page-link">${h}</span></li>` : n += `<li class="page-item"><button class="page-link" data-page="${h}">${h}</button></li>`;
313
- s.innerHTML = `<span class="pe-2 mb-3">Page: </span><ul class="pagination mb-3">
314
- ${o == 1 ? '<li class="page-item disabled"><span class="page-link">Previous</span></li>' : `<li class="page-item"><button class="page-link" data-page="${parseInt(o) - 1}">Previous</button></li>`}
315
- ${n}
316
- ${o == i ? '<li class="page-item disabled"><span class="page-link">Next</span></li>' : `<li class="page-item"><button class="page-link" data-page="${parseInt(o) + 1}">Next</button></li>`}
317
- </ul>`;
318
- } else {
319
- let n = "";
320
- for (let h = 1; h <= i; h++)
321
- h == o ? n += `<option value="${h}" selected>Page ${h}</option>` : n += `<option value="${h}">Page ${h}</option>`;
322
- s.innerHTML = `
323
- <div class="form-control__wrapper page-number mb-2">
324
- <select class="form-select">
325
- ${n}
326
- </select>
327
- </div>
328
- `;
342
+ f.hasAttribute("data-format") && (g = D(f.getAttribute("data-format"), g)), y.innerHTML = g, m.appendChild(y);
343
+ }), i.appendChild(m);
344
+ }), Q(t, a), X(t, a, e, s), s.setAttribute("data-total", l.meta.total ? l.meta.total : 1), s.setAttribute("data-page", l.meta.current_page ? l.meta.current_page : 1), s.setAttribute("data-pages", Math.ceil(s.getAttribute("data-total") / s.getAttribute("data-show"))), F(s, e), l.data.length == 0 && (i.innerHTML = '<tr><td colspan="100%"><span class="h4 m-0">No results found</span></td></tr>')) : i.innerHTML = '<tr><td colspan="100%"><span class="h6 m-0">Error loading table</span></td></tr>';
345
+ });
346
+ }, D = (t, a) => {
347
+ switch (t) {
348
+ case "date":
349
+ a = new Date(a).toLocaleDateString("en-gb", { year: "2-digit", month: "long", day: "numeric" });
350
+ break;
351
+ case "capitalise":
352
+ a = ve(a);
353
+ break;
329
354
  }
355
+ return a;
330
356
  };
331
- let G = function(e) {
332
- return typeof e != "string" ? e : (e = e.replace("£", ""), e = e.replace("%", ""), Number.isNaN(Number.parseFloat(e)) ? 0 : Number.parseFloat(e));
333
- };
334
- const pe = {
357
+ class $e extends HTMLElement {
358
+ constructor() {
359
+ super(), this.attachShadow({ mode: "open" });
360
+ const a = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", e = this.classList.contains("table--cta"), s = this.classList.contains("table--export");
361
+ let r = this.classList.toString();
362
+ r = r.replace("table--cta", "");
363
+ const n = document.createElement("template");
364
+ n.innerHTML = `
365
+ <style>
366
+ @import "${a}/css/core.min.css";
367
+ </style>
368
+ ${e ? '<div class="table--cta">' : ""}
369
+ <div class="table__wrapper ${r}">
370
+ <slot></slot>
371
+ </div>
372
+ ${e ? "</div>" : ""}
373
+ ${s ? '<button class="link" type="button" data-export>Export table as CSV</button>' : ""}
374
+ <div class="table__pagination"></div>
375
+ `, this.shadowRoot.appendChild(n.content.cloneNode(!0));
376
+ const i = new URLSearchParams(window.location.search);
377
+ this.hasAttribute("data-total") || this.setAttribute("data-total", this.querySelectorAll("table tbody tr").length), this.hasAttribute("data-page") || this.setAttribute("data-page", i.has("page") ? i.get("page") : 1), this.hasAttribute("data-show") || this.setAttribute("data-show", 15), this.setAttribute("data-pages", Math.ceil(this.getAttribute("data-total") / this.getAttribute("data-show")));
378
+ }
379
+ connectedCallback() {
380
+ this.table = this.querySelector("table"), this.savedTableBody = this.querySelector("tbody").cloneNode(!0), this.pagination = this.shadowRoot.querySelector(".table__pagination"), this.form = document.createElement("form"), this.hasAttribute("data-filterby") && (this.form = document.querySelector(`#${this.getAttribute("data-filterby")}`), Q(this.table, this.form), this.form.querySelector("[data-page]") || (this.form.innerHTML += `<input name="page" type="hidden" value="${this.getAttribute("data-page")}" data-pagination="true" />`), this.form.querySelector("[data-show]") || (this.form.innerHTML += `<input name="show" type="hidden" value="${this.getAttribute("data-show")}" data-show="true" />`)), Se(this.table), Le(this.table, this.form, this.pagination, this, this.savedTableBody), ke(this.table, this.form, this.pagination, this), qe(this.shadowRoot.querySelector("[data-export]"), this.table), this.form.getAttribute("data-ajax") ? J(this.table, this.form, this.pagination, this) : (X(this.table, this.form, this.pagination, this), Y(this.table, this.form, this), F(this, this.pagination)), this.shadowRoot.querySelector(".table__wrapper").addEventListener("scroll", (a) => {
381
+ this.table.querySelector("dialog[open]") && this.table.querySelector("dialog[open]").close();
382
+ });
383
+ }
384
+ static get observedAttributes() {
385
+ return ["data-total", "data-pages", "data-page", "data-show"];
386
+ }
387
+ attributeChangedCallback(a, e, s) {
388
+ }
389
+ }
390
+ const Te = (t) => t.charAt(0).toUpperCase() + t.slice(1), He = (t) => t.replace(/_/g, " "), Ce = (t) => t.replace(/ /g, "_"), Me = function(t) {
391
+ return t = t.toLowerCase(), t = Ce(t), t = t.replace(/\W/g, ""), t;
392
+ }, Ee = {
335
393
  name: "Table",
336
394
  props: {
337
- reorder: {
338
- type: Boolean,
339
- required: !1
340
- },
341
- page: {
342
- type: Number,
343
- required: !1
344
- },
345
- show: {
346
- type: Number,
347
- required: !1
348
- },
349
- sortby: {
350
- type: String,
351
- required: !1
352
- },
353
- sort: {
354
- type: String,
355
- required: !1
356
- },
357
- headingclass: {
358
- type: String,
359
- required: !1
360
- },
361
395
  items: {
362
396
  type: Array,
363
- required: !0
397
+ required: !1
364
398
  },
365
399
  fields: {
366
400
  type: Array,
367
- required: !0
401
+ required: !1
368
402
  }
369
403
  },
370
404
  computed: {
371
405
  cellHeading() {
372
- return (e) => `${W(K(e))}`;
373
- },
374
- numericValue() {
375
- return (e) => (e = G(e), e);
406
+ return (t) => `${Te(He(t))}`;
376
407
  }
377
408
  },
378
- mounted() {
409
+ created() {
379
410
  this.$nextTick(function() {
380
- Z(this.$refs.wrapper), this.$el.addEventListener("sorted", function(e) {
381
- console.log("Table sorted");
382
- }, !1), this.$el.addEventListener("filtered", function(e) {
383
- console.log("Table filtered");
384
- }, !1);
411
+ window.customElements.get("iam-table") || window.customElements.define("iam-table", $e);
385
412
  });
386
413
  },
387
414
  updated() {
388
- this.$nextTick(function() {
389
- let e = this.$refs.wrapper.querySelector("tbody"), r = "";
390
- this.items.forEach((o, f) => {
391
- let s = o.rowid ? o.rowid : "";
392
- o = Object.fromEntries(Object.entries(o).filter(([i]) => i !== "rowid")), r += `<tr data-row-id="${s}">${Object.keys(o).map((i) => `<td data-label="${W(K(i))}" data-numeric="${G(o[i])}">${o[i]}</td>`).join("")}</tr>`;
393
- }), e.innerHTML = r;
394
- const t = new Event("filtered");
395
- this.$refs.wrapper.dispatchEvent(t);
396
- });
397
415
  }
398
- }, be = ["data-sortby", "data-sort", "data-show", "data-page", "data-reorder"], ve = { key: 0 }, ge = ["data-sortable", "data-filterable"], Ae = { key: 1 }, we = ["data-row-id"], ke = ["innerHTML", "data-label", "data-numeric"];
399
- function Se(e, r, t, o, f, s) {
400
- return l(), c("div", {
401
- class: "table__wrapper",
402
- ref: "wrapper",
403
- "data-sortby": t.sortby,
404
- "data-sort": t.sort,
405
- "data-show": t.show,
406
- "data-page": t.page,
407
- "data-reorder": t.reorder
408
- }, [
409
- a("table", null, [
410
- t.fields ? (l(), c("thead", ve, [
411
- a("tr", {
412
- class: v(t.headingclass)
413
- }, [
414
- (l(!0), c(x, null, L(t.fields, (i) => (l(), c("th", {
415
- key: i.key,
416
- "data-sortable": i.sortable,
417
- "data-filterable": i.filterable
418
- }, k(s.cellHeading(i.key)), 9, ge))), 128))
419
- ], 2)
420
- ])) : p("", !0),
421
- t.items ? (l(), c("tbody", Ae, [
422
- (l(!0), c(x, null, L(t.items, (i, n) => (l(), c("tr", {
423
- key: n,
416
+ }, Ne = { key: 0 }, De = { key: 0 }, Re = ["data-row-id"], Pe = ["innerHTML"];
417
+ function Ie(t, a, e, s, r, n) {
418
+ return c(), d("iam-table", null, [
419
+ e.fields ? (c(), d("table", Ne, [
420
+ o("thead", null, [
421
+ o("tr", null, [
422
+ (c(!0), d($, null, T(e.fields, (i) => (c(), d("th", {
423
+ key: i.key
424
+ }, L(n.cellHeading(i.key)), 1))), 128))
425
+ ])
426
+ ]),
427
+ e.items ? (c(), d("tbody", De, [
428
+ (c(!0), d($, null, T(e.items, (i, l) => (c(), d("tr", {
429
+ key: l,
424
430
  "data-row-id": i.rowid
425
431
  }, [
426
- (l(!0), c(x, null, L(Object.fromEntries(Object.entries(i).filter(([h]) => h !== "rowid")), (h, w) => (l(), c("td", {
427
- key: w,
428
- innerHTML: h,
429
- "data-label": s.cellHeading(w),
430
- "data-numeric": s.numericValue(h)
431
- }, null, 8, ke))), 128))
432
- ], 8, we))), 128))
433
- ])) : p("", !0)
434
- ]),
435
- b(e.$slots, "default")
436
- ], 8, be);
432
+ (c(!0), d($, null, T(Object.fromEntries(Object.entries(i).filter(([h]) => h !== "rowid")), (h, u) => (c(), d("td", {
433
+ key: u,
434
+ innerHTML: h
435
+ }, null, 8, Pe))), 128))
436
+ ], 8, Re))), 128))
437
+ ])) : _("", !0)
438
+ ])) : p(t.$slots, "default", { key: 1 })
439
+ ]);
437
440
  }
438
- const E = /* @__PURE__ */ g(pe, [["render", Se]]), $e = {
441
+ const ee = /* @__PURE__ */ A(Ee, [["render", Ie]]), Fe = {
439
442
  name: "Input",
440
443
  props: {
441
444
  value: {
@@ -597,176 +600,176 @@ const E = /* @__PURE__ */ g(pe, [["render", Se]]), $e = {
597
600
  get() {
598
601
  return this.value == null && this.options != null && this.type == "select" ? this.$attrs.multiple ? [] : this.options[0].value : this.value;
599
602
  },
600
- set(e) {
601
- this.$emit("input", e);
603
+ set(t) {
604
+ this.$emit("input", t);
602
605
  }
603
606
  }
604
607
  },
605
608
  mounted() {
606
609
  this.$nextTick(function() {
607
- let e = this.$refs.wrapper;
608
- if (e.parentNode && e.parentNode.classList.contains("form-check") || e.classList.length == 0) {
609
- const r = document.createDocumentFragment();
610
- Array.from(e.childNodes).forEach((t) => r.appendChild(t)), e.parentNode.insertBefore(r, e), e.parentNode.removeChild(e);
610
+ let t = this.$refs.wrapper;
611
+ if (t.parentNode && t.parentNode.classList.contains("form-check") || t.classList.length == 0) {
612
+ const a = document.createDocumentFragment();
613
+ Array.from(t.childNodes).forEach((e) => a.appendChild(e)), t.parentNode.insertBefore(a, t), t.parentNode.removeChild(t);
611
614
  }
612
615
  });
613
616
  },
614
617
  methods: {
615
- inputKeyup(e) {
616
- this.$emit("keyupEvent", e);
618
+ inputKeyup(t) {
619
+ this.$emit("keyupEvent", t);
617
620
  },
618
621
  clickEvent() {
619
622
  this.$emit("bus");
620
623
  }
621
624
  }
622
- }, qe = ["for", "innerHTML", "title"], xe = ["innerHTML"], Le = ["innerHTML"], Te = ["type", "name", "id", "pattern", "list"], Me = ["type", "name", "id", "pattern"], He = {
625
+ }, Be = ["for", "innerHTML", "title"], Ve = ["innerHTML"], ze = ["innerHTML"], Oe = ["type", "name", "id", "pattern", "list"], We = ["type", "name", "id", "pattern"], je = {
623
626
  key: 5,
624
627
  class: "input-group"
625
- }, Ce = ["type", "name", "id", "pattern", "list"], Ne = { class: "input-group-text border-0 col-2 col-sm-1 px-0" }, Be = {
628
+ }, Ue = ["type", "name", "id", "pattern", "list"], Ke = { class: "input-group-text border-0 col-2 col-sm-1 px-0" }, Ge = {
626
629
  key: 6,
627
630
  class: "input-group"
628
- }, Pe = ["type", "name", "id", "pattern", "list"], De = { class: "input-group-text flex-fill" }, Ie = ["type", "name", "id", "pattern"], ze = ["value"], Ve = ["id"], Fe = ["value"], Oe = ["type", "name", "id"], je = ["for", "innerHTML"], Re = ["type", "name", "id"], We = ["for", "innerHTML"], Ke = ["innerHTML"];
629
- function Ue(e, r, t, o, f, s) {
630
- return l(), c("div", {
631
- class: v(s.wrapperClass()),
631
+ }, Qe = ["type", "name", "id", "pattern", "list"], Ye = { class: "input-group-text flex-fill" }, Ze = ["type", "name", "id", "pattern"], Xe = ["value"], Je = ["id"], et = ["value"], tt = ["type", "name", "id"], at = ["for", "innerHTML"], st = ["type", "name", "id"], it = ["for", "innerHTML"], lt = ["innerHTML"];
632
+ function nt(t, a, e, s, r, n) {
633
+ return c(), d("div", {
634
+ class: v(n.wrapperClass()),
632
635
  ref: "wrapper"
633
636
  }, [
634
- s.needsLabel() ? (l(), c("label", {
637
+ n.needsLabel() ? (c(), d("label", {
635
638
  key: 0,
636
- class: v(`form-label${t.labelclass ? ` ${t.labelclass}` : ""}`),
637
- for: t.id,
638
- innerHTML: s.displayLabel(),
639
- title: t.title
640
- }, null, 10, qe)) : p("", !0),
641
- t.prefix ? (l(), c("span", {
639
+ class: v(`form-label${e.labelclass ? ` ${e.labelclass}` : ""}`),
640
+ for: e.id,
641
+ innerHTML: n.displayLabel(),
642
+ title: e.title
643
+ }, null, 10, Be)) : _("", !0),
644
+ e.prefix ? (c(), d("span", {
642
645
  key: 1,
643
- class: v(`prefix ${this.prefixClass} ${t.size ? `prefix-${t.size}` : ""}`),
644
- innerHTML: t.prefix,
646
+ class: v(`prefix ${this.prefixClass} ${e.size ? `prefix-${e.size}` : ""}`),
647
+ innerHTML: e.prefix,
645
648
  role: "presentation"
646
- }, null, 10, xe)) : p("", !0),
647
- t.suffix ? (l(), c("span", {
649
+ }, null, 10, Ve)) : _("", !0),
650
+ e.suffix ? (c(), d("span", {
648
651
  key: 2,
649
- class: v(`suffix ${this.suffixClass} ${t.size ? `suffix-${t.size}` : ""}`),
650
- innerHTML: t.suffix,
652
+ class: v(`suffix ${this.suffixClass} ${e.size ? `suffix-${e.size}` : ""}`),
653
+ innerHTML: e.suffix,
651
654
  role: "presentation"
652
- }, null, 10, Le)) : p("", !0),
653
- s.isInput() ? N((l(), c("input", T({
655
+ }, null, 10, ze)) : _("", !0),
656
+ n.isInput() ? N((c(), d("input", H({
654
657
  key: 3,
655
- "onUpdate:modelValue": r[0] || (r[0] = (i) => s.inputVal = i),
656
- class: `form-control${t.size ? ` form-control-${t.size}` : ""}${t.inputclass ? ` ${t.inputclass}` : ""}`,
657
- type: t.type,
658
- name: t.name ? t.name : t.id,
659
- id: t.id,
660
- pattern: s.needPattern(),
661
- list: s.hasOptions()
662
- }, e.$attrs, {
663
- onKeyup: r[1] || (r[1] = (...i) => s.inputKeyup && s.inputKeyup(...i))
664
- }), null, 16, Te)), [
665
- [F, s.inputVal]
666
- ]) : p("", !0),
667
- t.type == "textarea" ? N((l(), c("textarea", T({
658
+ "onUpdate:modelValue": a[0] || (a[0] = (i) => n.inputVal = i),
659
+ class: `form-control${e.size ? ` form-control-${e.size}` : ""}${e.inputclass ? ` ${e.inputclass}` : ""}`,
660
+ type: e.type,
661
+ name: e.name ? e.name : e.id,
662
+ id: e.id,
663
+ pattern: n.needPattern(),
664
+ list: n.hasOptions()
665
+ }, t.$attrs, {
666
+ onKeyup: a[1] || (a[1] = (...i) => n.inputKeyup && n.inputKeyup(...i))
667
+ }), null, 16, Oe)), [
668
+ [P, n.inputVal]
669
+ ]) : _("", !0),
670
+ e.type == "textarea" ? N((c(), d("textarea", H({
668
671
  key: 4,
669
- "onUpdate:modelValue": r[2] || (r[2] = (i) => s.inputVal = i),
670
- class: `form-control${t.size ? ` form-control-${t.size}` : ""}${t.inputclass ? ` ${t.inputclass}` : ""}`,
671
- type: t.type,
672
- name: t.name ? t.name : t.id,
673
- id: t.id,
674
- pattern: s.needPattern()
675
- }, e.$attrs), null, 16, Me)), [
676
- [X, s.inputVal]
677
- ]) : p("", !0),
678
- t.type == "range" ? (l(), c("div", He, [
679
- N(a("input", T({
680
- "onUpdate:modelValue": r[3] || (r[3] = (i) => s.inputVal = i),
681
- class: `form-range${t.inputclass ? ` ${t.inputclass}` : ""}`,
682
- type: t.type,
683
- name: t.name ? t.name : t.id,
684
- id: t.id,
685
- pattern: s.needPattern(),
686
- list: s.hasOptions()
687
- }, e.$attrs, { oninput: "this.nextElementSibling.value=this.value;" }), null, 16, Ce), [
688
- [F, s.inputVal]
672
+ "onUpdate:modelValue": a[2] || (a[2] = (i) => n.inputVal = i),
673
+ class: `form-control${e.size ? ` form-control-${e.size}` : ""}${e.inputclass ? ` ${e.inputclass}` : ""}`,
674
+ type: e.type,
675
+ name: e.name ? e.name : e.id,
676
+ id: e.id,
677
+ pattern: n.needPattern()
678
+ }, t.$attrs), null, 16, We)), [
679
+ [se, n.inputVal]
680
+ ]) : _("", !0),
681
+ e.type == "range" ? (c(), d("div", je, [
682
+ N(o("input", H({
683
+ "onUpdate:modelValue": a[3] || (a[3] = (i) => n.inputVal = i),
684
+ class: `form-range${e.inputclass ? ` ${e.inputclass}` : ""}`,
685
+ type: e.type,
686
+ name: e.name ? e.name : e.id,
687
+ id: e.id,
688
+ pattern: n.needPattern(),
689
+ list: n.hasOptions()
690
+ }, t.$attrs, { oninput: "this.nextElementSibling.value=this.value;" }), null, 16, Ue), [
691
+ [P, n.inputVal]
689
692
  ]),
690
- a("output", Ne, k(t.value), 1)
691
- ])) : p("", !0),
692
- t.type == "color" ? (l(), c("div", Be, [
693
- N(a("input", T({
694
- "onUpdate:modelValue": r[4] || (r[4] = (i) => s.inputVal = i),
695
- class: `form-control form-control-color${t.inputclass ? ` ${t.inputclass}` : ""}`,
696
- type: t.type,
697
- name: t.name ? t.name : t.id,
698
- id: t.id,
699
- pattern: s.needPattern(),
700
- list: s.hasOptions()
701
- }, e.$attrs, { oninput: "this.nextElementSibling.value=this.value;" }), null, 16, Pe), [
702
- [F, s.inputVal]
693
+ o("output", Ke, L(e.value), 1)
694
+ ])) : _("", !0),
695
+ e.type == "color" ? (c(), d("div", Ge, [
696
+ N(o("input", H({
697
+ "onUpdate:modelValue": a[4] || (a[4] = (i) => n.inputVal = i),
698
+ class: `form-control form-control-color${e.inputclass ? ` ${e.inputclass}` : ""}`,
699
+ type: e.type,
700
+ name: e.name ? e.name : e.id,
701
+ id: e.id,
702
+ pattern: n.needPattern(),
703
+ list: n.hasOptions()
704
+ }, t.$attrs, { oninput: "this.nextElementSibling.value=this.value;" }), null, 16, Qe), [
705
+ [P, n.inputVal]
703
706
  ]),
704
- a("output", De, k(t.value ? e.vale : "#000000"), 1)
705
- ])) : p("", !0),
706
- t.type == "select" ? N((l(), c("select", T({
707
+ o("output", Ye, L(e.value ? t.vale : "#000000"), 1)
708
+ ])) : _("", !0),
709
+ e.type == "select" ? N((c(), d("select", H({
707
710
  key: 7,
708
- "onUpdate:modelValue": r[5] || (r[5] = (i) => s.inputVal = i),
709
- class: `form-select${t.size ? ` form-select-${t.size}` : ""}${t.inputclass ? ` ${t.inputclass}` : ""}`,
710
- type: t.type,
711
- name: t.id,
712
- id: t.id,
713
- pattern: s.needPattern()
714
- }, e.$attrs), [
715
- (l(!0), c(x, null, L(t.options, (i, n) => (l(), c("option", {
716
- key: n,
711
+ "onUpdate:modelValue": a[5] || (a[5] = (i) => n.inputVal = i),
712
+ class: `form-select${e.size ? ` form-select-${e.size}` : ""}${e.inputclass ? ` ${e.inputclass}` : ""}`,
713
+ type: e.type,
714
+ name: e.id,
715
+ id: e.id,
716
+ pattern: n.needPattern()
717
+ }, t.$attrs), [
718
+ (c(!0), d($, null, T(e.options, (i, l) => (c(), d("option", {
719
+ key: l,
717
720
  value: i.value
718
- }, k(i.display ? i.display : i.value), 9, ze))), 128))
719
- ], 16, Ie)), [
720
- [ee, s.inputVal]
721
- ]) : p("", !0),
722
- s.allowDatalist() ? (l(), c("datalist", {
721
+ }, L(i.display ? i.display : i.value), 9, Xe))), 128))
722
+ ], 16, Ze)), [
723
+ [ie, n.inputVal]
724
+ ]) : _("", !0),
725
+ n.allowDatalist() ? (c(), d("datalist", {
723
726
  key: 8,
724
- id: t.id + "-list"
727
+ id: e.id + "-list"
725
728
  }, [
726
- (l(!0), c(x, null, L(t.options, (i, n) => (l(), c("option", {
727
- key: n,
729
+ (c(!0), d($, null, T(e.options, (i, l) => (c(), d("option", {
730
+ key: l,
728
731
  value: i.value
729
- }, k(i.value), 9, Fe))), 128))
730
- ], 8, Ve)) : p("", !0),
731
- t.type == "checkbox" || t.type == "radio" ? (l(), c("input", T({
732
+ }, L(i.value), 9, et))), 128))
733
+ ], 8, Je)) : _("", !0),
734
+ e.type == "checkbox" || e.type == "radio" ? (c(), d("input", H({
732
735
  key: 9,
733
736
  class: "form-check-input",
734
- type: t.type,
735
- name: t.name ? t.name : t.id,
736
- id: t.id
737
- }, e.$attrs), null, 16, Oe)) : p("", !0),
738
- t.type == "checkbox" || t.type == "radio" ? (l(), c("label", {
737
+ type: e.type,
738
+ name: e.name ? e.name : e.id,
739
+ id: e.id
740
+ }, t.$attrs), null, 16, tt)) : _("", !0),
741
+ e.type == "checkbox" || e.type == "radio" ? (c(), d("label", {
739
742
  key: 10,
740
- class: v(`form-label form-check-label${t.labelclass ? ` ${t.labelclass}` : ""}`),
741
- for: t.id,
742
- innerHTML: t.label
743
- }, null, 10, je)) : p("", !0),
744
- t.type == "checkbox-btn" || t.type == "radio-btn" ? (l(), c("input", T({
743
+ class: v(`form-label form-check-label${e.labelclass ? ` ${e.labelclass}` : ""}`),
744
+ for: e.id,
745
+ innerHTML: e.label
746
+ }, null, 10, at)) : _("", !0),
747
+ e.type == "checkbox-btn" || e.type == "radio-btn" ? (c(), d("input", H({
745
748
  key: 11,
746
- class: `btn-check${t.inputclass ? ` ${t.inputclass}` : ""}`,
747
- type: t.type.replace("-btn", ""),
749
+ class: `btn-check${e.inputclass ? ` ${e.inputclass}` : ""}`,
750
+ type: e.type.replace("-btn", ""),
748
751
  autocomplete: "off",
749
- name: t.name ? t.name : t.id,
750
- id: t.id
751
- }, e.$attrs), null, 16, Re)) : p("", !0),
752
- t.type == "checkbox-btn" || t.type == "radio-btn" ? (l(), c("label", {
752
+ name: e.name ? e.name : e.id,
753
+ id: e.id
754
+ }, t.$attrs), null, 16, st)) : _("", !0),
755
+ e.type == "checkbox-btn" || e.type == "radio-btn" ? (c(), d("label", {
753
756
  key: 12,
754
- class: v(`btn${t.labelclass ? ` ${t.labelclass}` : ""}`),
755
- for: t.id,
756
- innerHTML: t.label,
757
- onClick: r[6] || (r[6] = (...i) => s.clickEvent && s.clickEvent(...i))
758
- }, null, 10, We)) : p("", !0),
759
- t.errormsg ? (l(), c("p", {
757
+ class: v(`btn${e.labelclass ? ` ${e.labelclass}` : ""}`),
758
+ for: e.id,
759
+ innerHTML: e.label,
760
+ onClick: a[6] || (a[6] = (...i) => n.clickEvent && n.clickEvent(...i))
761
+ }, null, 10, it)) : _("", !0),
762
+ e.errormsg ? (c(), d("p", {
760
763
  key: 13,
761
764
  class: "invalid-feedback mb-0",
762
- innerHTML: t.errormsg
763
- }, null, 8, Ke)) : p("", !0),
764
- b(e.$slots, "default")
765
+ innerHTML: e.errormsg
766
+ }, null, 8, lt)) : _("", !0),
767
+ p(t.$slots, "default")
765
768
  ], 2);
766
769
  }
767
- const D = /* @__PURE__ */ g($e, [["render", Ue]]), Ge = {
770
+ const R = /* @__PURE__ */ A(Fe, [["render", nt]]), rt = {
768
771
  components: {
769
- Input: D
772
+ Input: R
770
773
  },
771
774
  name: "FileUploads",
772
775
  props: {
@@ -787,95 +790,100 @@ const D = /* @__PURE__ */ g($e, [["render", Ue]]), Ge = {
787
790
  required: !1
788
791
  }
789
792
  }
790
- }, Ze = { class: "multiple-file-uploads mb-4" }, Ee = { class: "row" }, Qe = { class: "col-12 col-md me-auto" }, Ye = /* @__PURE__ */ a("div", { class: "col mw-fit-content" }, [
791
- /* @__PURE__ */ a("button", {
793
+ }, ot = { class: "multiple-file-uploads mb-4" }, ct = { class: "row" }, dt = { class: "col-12 col-md me-auto" }, ut = /* @__PURE__ */ o("div", { class: "col mw-fit-content" }, [
794
+ /* @__PURE__ */ o("button", {
792
795
  type: "button",
793
796
  class: "btn btn-tertiary me-0",
794
797
  "data-delete": ""
795
798
  }, "Delete")
796
- ], -1), Je = ["data-maxfiles"];
797
- function Xe(e, r, t, o, f, s) {
798
- const i = H("Input");
799
- return l(), c("div", Ze, [
800
- a("div", Ee, [
801
- a("div", {
802
- class: v(`${t.inputcolclass ? t.inputcolclass : "col-12 col-sm-4"}`)
799
+ ], -1), ht = ["data-maxfiles"];
800
+ function mt(t, a, e, s, r, n) {
801
+ const i = E("Input");
802
+ return c(), d("div", ot, [
803
+ o("div", ct, [
804
+ o("div", {
805
+ class: v(`${e.inputcolclass ? e.inputcolclass : "col-12 col-sm-4"}`)
803
806
  }, [
804
807
  S(i, {
805
808
  type: "file",
806
- id: t.id,
807
- name: `${t.id}[]`,
809
+ id: e.id,
810
+ name: `${e.id}[]`,
808
811
  label: "Add new file",
809
812
  labelclass: "d-none",
810
813
  class: "form-control-inline col",
811
814
  required: "",
812
- "data-filesize": t.maxfilesize
815
+ "data-filesize": e.maxfilesize
813
816
  }, null, 8, ["id", "name", "data-filesize"])
814
817
  ], 2),
815
- a("div", Qe, [
816
- b(e.$slots, "default")
818
+ o("div", dt, [
819
+ p(t.$slots, "default")
817
820
  ]),
818
- Ye
821
+ ut
819
822
  ]),
820
- a("button", {
823
+ o("button", {
821
824
  type: "button",
822
825
  class: "btn btn-secondary me-0",
823
826
  "data-add": "",
824
- "data-maxfiles": t.maxfiles
825
- }, "+ Add file", 8, Je)
827
+ "data-maxfiles": e.maxfiles
828
+ }, "+ Add file", 8, ht)
826
829
  ]);
827
830
  }
828
- const di = /* @__PURE__ */ g(Ge, [["render", Xe]]);
829
- function et(e) {
830
- let r = e.querySelectorAll("details"), t = e.querySelectorAll("summary");
831
- if (r.forEach((o) => {
832
- o.classList.add("accordion-item");
833
- }), t.forEach((o) => {
834
- o.classList.add("accordion-header"), o.classList.add("accordion-button"), o.classList.add("h4");
835
- }), !e.classList.contains("accordion--keep-open")) {
836
- const o = e.querySelectorAll(":scope > details");
837
- o.forEach((f) => {
838
- f.addEventListener("click", () => {
839
- o.forEach((s) => {
840
- s !== f && s.removeAttribute("open");
831
+ const oi = /* @__PURE__ */ A(rt, [["render", mt]]);
832
+ function ft(t) {
833
+ let a = t.querySelectorAll("details"), e = t.querySelectorAll("summary");
834
+ if (a.forEach((s) => {
835
+ s.classList.add("accordion-item");
836
+ }), e.forEach((s) => {
837
+ s.classList.add("accordion-header"), s.classList.add("accordion-button"), s.classList.add("h4");
838
+ }), !t.classList.contains("accordion--keep-open")) {
839
+ const s = t.querySelectorAll(":scope > details");
840
+ s.forEach((r) => {
841
+ r.addEventListener("click", () => {
842
+ s.forEach((n) => {
843
+ n !== r && n.removeAttribute("open");
841
844
  });
842
845
  });
843
846
  });
844
847
  }
845
848
  }
846
- const O = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets";
847
- class tt extends HTMLElement {
849
+ window.dataLayer = window.dataLayer || [];
850
+ window.dataLayer.push({
851
+ event: "customElementRegistered",
852
+ element: "accordion"
853
+ });
854
+ const I = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets";
855
+ class yt extends HTMLElement {
848
856
  constructor() {
849
857
  super(), this.attachShadow({ mode: "open" });
850
- const r = document.createElement("template");
851
- r.innerHTML = `
858
+ const a = document.createElement("template");
859
+ a.innerHTML = `
852
860
  <style>
853
- @import "${O}/css/core.min.css";
854
- @import "${O}/css/components/accordion.css";
861
+ @import "${I}/css/core.min.css";
862
+ @import "${I}/css/components/accordion.css";
855
863
  ${this.hasAttribute("css") ? `@import "${this.getAttribute("css")}";` : ""}
856
864
  </style>
857
865
  <div class="accordion">
858
866
  <slot></slot>
859
867
  </div>
860
- `, this.shadowRoot.appendChild(r.content.cloneNode(!0));
868
+ `, this.shadowRoot.appendChild(a.content.cloneNode(!0));
861
869
  }
862
870
  connectedCallback() {
863
- et(this), this.insertAdjacentHTML("beforebegin", `<link rel="stylesheet" href="${O}/css/components/accordion.css">`);
871
+ ft(this), this.insertAdjacentHTML("beforebegin", `<link rel="stylesheet" href="${I}/css/components/accordion.css">`);
864
872
  }
865
873
  }
866
- window.customElements.get("iam-accordion") || window.customElements.define("iam-accordion", tt);
867
- const st = {
874
+ window.customElements.get("iam-accordion") || window.customElements.define("iam-accordion", yt);
875
+ const bt = {
868
876
  name: "Accordion",
869
877
  props: {},
870
878
  mounted() {
871
879
  }
872
- }, at = { ref: "wrapper" };
873
- function it(e, r, t, o, f, s) {
874
- return l(), c("iam-accordion", at, [
875
- b(e.$slots, "default")
880
+ }, _t = { ref: "wrapper" };
881
+ function pt(t, a, e, s, r, n) {
882
+ return c(), d("iam-accordion", _t, [
883
+ p(t.$slots, "default")
876
884
  ], 512);
877
885
  }
878
- const ui = /* @__PURE__ */ g(st, [["render", it]]), nt = {
886
+ const ci = /* @__PURE__ */ A(bt, [["render", pt]]), gt = {
879
887
  name: "AccordionItem",
880
888
  props: {
881
889
  title: {
@@ -902,7 +910,7 @@ const ui = /* @__PURE__ */ g(st, [["render", it]]), nt = {
902
910
  },
903
911
  computed: {
904
912
  createID() {
905
- return (e) => `${me(e)}`;
913
+ return (t) => `${Me(t)}`;
906
914
  }
907
915
  },
908
916
  data() {
@@ -910,24 +918,24 @@ const ui = /* @__PURE__ */ g(st, [["render", it]]), nt = {
910
918
  show: !this.lazy
911
919
  };
912
920
  }
913
- }, rt = ["id"], ot = ["classList"];
914
- function lt(e, r, t, o, f, s) {
915
- return l(), c("details", {
916
- id: s.createID(t.title)
921
+ }, vt = ["id"], At = ["classList"];
922
+ function wt(t, a, e, s, r, n) {
923
+ return c(), d("details", {
924
+ id: n.createID(e.title)
917
925
  }, [
918
- a("summary", {
919
- classList: `${t.titlecolour ? `bg-${t.titlecolour}` : ""}`
926
+ o("summary", {
927
+ classList: `${e.titlecolour ? `bg-${e.titlecolour}` : ""}`
920
928
  }, [
921
- j(k(t.title), 1),
922
- t.badge ? (l(), c("span", {
929
+ le(L(e.title), 1),
930
+ e.badge ? (c(), d("span", {
923
931
  key: 0,
924
- class: v(`badge bg-${t.badgecolour}`)
925
- }, k(t.badge), 3)) : p("", !0)
926
- ], 8, ot),
927
- b(e.$slots, "default")
928
- ], 8, rt);
932
+ class: v(`badge bg-${e.badgecolour}`)
933
+ }, L(e.badge), 3)) : _("", !0)
934
+ ], 8, At),
935
+ p(t.$slots, "default")
936
+ ], 8, vt);
929
937
  }
930
- const fi = /* @__PURE__ */ g(nt, [["render", lt]]), ct = {
938
+ const di = /* @__PURE__ */ A(gt, [["render", wt]]), St = {
931
939
  name: "Header",
932
940
  props: {
933
941
  title: {
@@ -944,181 +952,150 @@ const fi = /* @__PURE__ */ g(nt, [["render", lt]]), ct = {
944
952
  required: !1
945
953
  }
946
954
  }
947
- }, dt = { class: "container" }, ut = { class: "row" }, ft = { class: "col-sm-6" }, ht = { class: "pt-5 pb-3 px-4" }, mt = { class: "col-sm-6 col-md-5 ms-auto" }, _t = ["src"];
948
- function yt(e, r, t, o, f, s) {
949
- return l(), c("div", dt, [
950
- a("div", {
951
- class: v("bg-" + t.background + " mb-4")
955
+ }, Lt = { class: "container" }, kt = { class: "row" }, qt = { class: "col-sm-6" }, xt = { class: "pt-5 pb-3 px-4" }, $t = { class: "col-sm-6 col-md-5 ms-auto" }, Tt = ["src"];
956
+ function Ht(t, a, e, s, r, n) {
957
+ return c(), d("div", Lt, [
958
+ o("div", {
959
+ class: v("bg-" + e.background + " mb-4")
952
960
  }, [
953
- a("div", ut, [
954
- a("div", ft, [
955
- a("div", ht, [
956
- a("h2", null, k(t.title), 1),
957
- b(e.$slots, "default")
961
+ o("div", kt, [
962
+ o("div", qt, [
963
+ o("div", xt, [
964
+ o("h2", null, L(e.title), 1),
965
+ p(t.$slots, "default")
958
966
  ])
959
967
  ]),
960
- a("div", mt, [
961
- t.image ? (l(), c("img", {
968
+ o("div", $t, [
969
+ e.image ? (c(), d("img", {
962
970
  key: 0,
963
- src: t.image,
971
+ src: e.image,
964
972
  alt: "",
965
973
  class: "h-100 w-100 object-cover"
966
- }, null, 8, _t)) : p("", !0)
974
+ }, null, 8, Tt)) : _("", !0)
967
975
  ])
968
976
  ])
969
977
  ], 2)
970
978
  ]);
971
979
  }
972
- const hi = /* @__PURE__ */ g(ct, [["render", yt]]);
973
- const pt = {
974
- name: "Card",
975
- props: {
976
- link: {
977
- type: String,
978
- required: !1
979
- },
980
- cardClass: {
981
- type: String,
982
- required: !1,
983
- default: ""
984
- },
985
- titleclass: {
986
- type: String,
987
- required: !1,
988
- default: "h4"
989
- },
990
- title: {
991
- type: String,
992
- required: !1
993
- },
994
- subtitle: {
995
- type: String,
996
- required: !1
997
- },
998
- content: {
999
- type: String,
1000
- required: !1
1001
- },
1002
- type: {
1003
- type: String,
1004
- required: !1
1005
- },
1006
- btntype: {
1007
- type: String,
1008
- required: !1,
1009
- default: "secondary"
1010
- },
1011
- ctatext: {
1012
- type: String,
1013
- required: !1,
1014
- default: "Find out more"
1015
- },
1016
- hidectatext: {
1017
- type: Boolean,
1018
- required: !1,
1019
- default: !1
1020
- },
1021
- image: {
1022
- type: String,
1023
- required: !1
1024
- },
1025
- target: {
1026
- type: String,
1027
- required: !1
1028
- },
1029
- details: {
1030
- type: Object,
1031
- required: !1
1032
- }
1033
- },
1034
- computed: {
1035
- cardStatus() {
1036
- return () => this.details && this.details.status ? `${this.details.status == "Live now" ? '<span class="text-danger lh-0 fs-1 align-middle">&#8226;</span>&nbsp;&nbsp;' : ""}${this.details.status}` : "";
1037
- },
1038
- cardMedia() {
1039
- return () => `<svg xmlns='http://www.w3.org/2000/svg' width='30' height='28' viewBox='0 0 30 28' class="icon text-white"><title>Images </title><path d='M15 10.5c2.484 0 4.5 2.016 4.5 4.5s-2.016 4.5-4.5 4.5-4.5-2.016-4.5-4.5 2.016-4.5 4.5-4.5zM26 4c2.203 0 4 1.797 4 4v14c0 2.203-1.797 4-4 4h-22c-2.203 0-4-1.797-4-4v-14c0-2.203 1.797-4 4-4h3.5l0.797-2.125c0.391-1.031 1.609-1.875 2.703-1.875h8c1.094 0 2.312 0.844 2.703 1.875l0.797 2.125h3.5zM15 22c3.859 0 7-3.141 7-7s-3.141-7-7-7-7 3.141-7 7 3.141 7 7 7z'></path></svg> ${this.details && this.details.images ? `${this.details.images}` : "0"}&nbsp;&nbsp;|&nbsp;&nbsp;<svg xmlns='http://www.w3.org/2000/svg' width='30' height='28' viewBox='0 0 28 28' class="icon text-white ms-0"><title>Videos </title><path d="M11.109 17.625l7.562-3.906-7.562-3.953v7.859zM14 4.156c5.891 0 9.797 0.281 9.797 0.281 0.547 0.063 1.75 0.063 2.812 1.188 0 0 0.859 0.844 1.109 2.781 0.297 2.266 0.281 4.531 0.281 4.531v2.125s0.016 2.266-0.281 4.531c-0.25 1.922-1.109 2.781-1.109 2.781-1.062 1.109-2.266 1.109-2.812 1.172 0 0-3.906 0.297-9.797 0.297v0c-7.281-0.063-9.516-0.281-9.516-0.281-0.625-0.109-2.031-0.078-3.094-1.188 0 0-0.859-0.859-1.109-2.781-0.297-2.266-0.281-4.531-0.281-4.531v-2.125s-0.016-2.266 0.281-4.531c0.25-1.937 1.109-2.781 1.109-2.781 1.062-1.125 2.266-1.125 2.812-1.188 0 0 3.906-0.281 9.797-0.281v0z"></path></svg> ${this.details && this.details.videos ? `${this.details.videos}` : "0"}`;
1040
- },
1041
- cardContent() {
1042
- return () => {
1043
- const e = function(f) {
1044
- switch (f) {
1045
- case "Modern method":
1046
- return "bg-secondary text-primary";
1047
- case "Freehold":
1048
- return "bg-light text-dark";
1049
- default:
1050
- return "bg-body text-white";
1051
- }
1052
- }, r = this.details && this.details.tags ? this.details.tags.map((f) => `<span class="badge rounded-pill py-2 px-3 mb-3 me-2 ${e(f)}">${f}</span>`).join("") : "", t = this.title ? `<span class="card-title d-block ${this.titleclass}">${this.title}${this.subtitle ? ` <span class="d-block fw-normal font-body text-body small">${this.subtitle}</span>` : ""}</span>` : "", o = `
1053
- ${this.details && this.details.guideprice ? `<span class="d-block h6 text-dark mb-1">Price guide: ${this.details.guideprice}</span>` : ""}
1054
- ${this.details && this.details.auctiontime ? `<span class="d-block h6 text-primary mb-4">Auction time left: ${this.details.auctiontime}</span>` : ""}
1055
- ${this.details && this.details.readtime ? `<span class="d-block h6 text-primary mb-4"><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="22" height="23" viewBox="0 0 22 23" class="icon ms-0 me-2"><path d="M11 1.63c-5.176 0-9.37 4.194-9.37 9.37 0 5.176 4.194 9.37 9.37 9.37 5.176 0 9.37-4.194 9.37-9.37 0-5.176-4.194-9.37-9.37-9.37M11 0c6.075 0 11 4.925 11 11s-4.925 11-11 11S0 17.075 0 11 4.925 0 11 0" fill="var(--colour-secondary)" /><path d="M9.62 5.39c0-.473.368-.856.82-.856.454 0 .822.383.822.855v6.27l3.25 1.898c.395.23.536.75.314 1.16-.22.412-.72.558-1.115.328l-4.09-2.39V5.39z" fill="var(--colour-primary)"/></svg>${this.details.readtime}</span>` : ""}
1056
- `;
1057
- return `${r}${t}${o}${this.content}`;
1058
- };
980
+ const ui = /* @__PURE__ */ A(St, [["render", Ht]]);
981
+ class Ct extends HTMLElement {
982
+ constructor() {
983
+ super(), this.attachShadow({ mode: "open" });
984
+ const a = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", e = `@import "${a}/css/components/card.css";`;
985
+ this.querySelector(".icon") && this.classList.add("card--has-icon");
986
+ let s = this.classList.toString();
987
+ const r = document.createElement("template");
988
+ r.innerHTML = `
989
+ <style>
990
+ @import "${a}/css/core.min.css";
991
+ ${e}
992
+ ${this.hasAttribute("css") ? `@import "${this.getAttribute("css")}";` : ""}
993
+ </style>
994
+ <div class="card ${s}" tabindex="0" role="button">
995
+ ${this.hasAttribute("data-image") ? `<div class="card__head"><img src="${this.getAttribute("data-image")}" alt="" loading="lazy" /></div>` : ""}
996
+ <div class="card__body">
997
+ ${this.classList.contains("card--filter") && this.hasAttribute("data-total") ? `<div class="card__total">${this.getAttribute("data-total")}</div>` : ""}
998
+ ${this.hasAttribute("data-illustration") ? `<div class="card__illustration"><img src="${this.getAttribute("data-illustration")}" alt="" loading="lazy" /></div>` : ""}
999
+ <slot></slot>
1000
+ </div>
1001
+ ${this.hasAttribute("data-cta") ? `<div class="card__footer"><span class="link">${this.getAttribute("data-cta")}</span></div>` : ""}
1002
+ </div>
1003
+ `, this.shadowRoot.appendChild(r.content.cloneNode(!0));
1004
+ }
1005
+ connectedCallback() {
1006
+ const a = this.parentNode.closest("a, button, label"), e = this.shadowRoot.querySelector(".card");
1007
+ a.setAttribute("tabindex", "-1"), a.matches("label[for]") && document.getElementById(a.getAttribute("for")).checked && e.classList.add("active"), e.addEventListener("click", (s) => {
1008
+ a.matches("label[for]") ? document.getElementById(a.getAttribute("for")).checked ? e.classList.remove("active") : e.classList.add("active") : a.click();
1009
+ }), e.addEventListener("keydown", (s) => {
1010
+ switch (s.keyCode) {
1011
+ case 32:
1012
+ case 13:
1013
+ a.matches("label[for]") ? document.getElementById(a.getAttribute("for")).checked ? e.classList.remove("active") : e.classList.add("active") : a.click();
1014
+ break;
1015
+ }
1016
+ });
1017
+ }
1018
+ static get observedAttributes() {
1019
+ return ["data-total", "class"];
1020
+ }
1021
+ attributeChangedCallback(a, e, s) {
1022
+ switch (a) {
1023
+ case "data-total": {
1024
+ this.shadowRoot.querySelector(".card__total").innerHTML = s;
1025
+ break;
1026
+ }
1027
+ case "class": {
1028
+ let r = this.classList.toString();
1029
+ this.querySelector(".icon") && (r += " card--has-icon"), this.shadowRoot.querySelector(".card").setAttribute("class", `card ${r}`);
1030
+ break;
1031
+ }
1059
1032
  }
1060
1033
  }
1061
- }, bt = ["href", "title", "target"], vt = {
1062
- key: 0,
1063
- class: "card-header__wrapper"
1064
- }, gt = ["src"], At = { class: "card-header" }, wt = ["innerHTML"], kt = ["innerHTML"], St = ["src"], $t = ["innerHTML"], qt = {
1065
- key: 1,
1066
- class: "card-footer"
1067
- }, xt = { class: "visually-hidden" };
1068
- function Lt(e, r, t, o, f, s) {
1069
- return l(), c("a", {
1070
- href: t.link,
1071
- class: v("card" + (t.type ? " card--" + t.type : "") + " " + t.cardClass),
1072
- title: t.ctatext + ": " + t.title + (t.subtitle ? " - " + t.subtitle : ""),
1073
- target: t.target
1074
- }, [
1075
- t.image ? (l(), c("div", vt, [
1076
- a("img", {
1077
- src: t.image,
1078
- alt: "",
1079
- loading: "lazy",
1080
- class: "card-image"
1081
- }, null, 8, gt),
1082
- a("div", At, [
1083
- this.details && this.details.status ? (l(), c("span", {
1084
- key: 0,
1085
- class: "badge bg-primary p-2 me-2",
1086
- innerHTML: s.cardStatus()
1087
- }, null, 8, wt)) : p("", !0),
1088
- this.details && (this.details.images || this.details.videos) ? (l(), c("span", {
1089
- key: 1,
1090
- class: "badge bg-black bg-opacity-50 p-2 align-self-end",
1091
- innerHTML: s.cardMedia()
1092
- }, null, 8, kt)) : p("", !0)
1093
- ]),
1094
- t.details && t.details.logo ? (l(), c("img", {
1095
- key: 0,
1096
- src: t.details.logo,
1097
- alt: "",
1098
- loading: "lazy",
1099
- class: "card-logo"
1100
- }, null, 8, St)) : p("", !0)
1101
- ])) : p("", !0),
1102
- a("div", {
1103
- class: "card-body",
1104
- innerHTML: s.cardContent()
1105
- }, null, 8, $t),
1106
- t.hidectatext == !1 ? (l(), c("div", qt, [
1107
- a("span", {
1108
- class: v(`${t.btntype == "link" ? "link" : `btn btn-${t.btntype}`} mb-0`)
1109
- }, [
1110
- j(k(t.ctatext), 1),
1111
- a("span", xt, ": " + k(t.title), 1)
1112
- ], 2)
1113
- ])) : p("", !0)
1114
- ], 10, bt);
1115
1034
  }
1116
- const Q = /* @__PURE__ */ g(pt, [["render", Lt]]);
1117
- const Tt = {
1035
+ const Mt = {
1036
+ name: "Card",
1037
+ created() {
1038
+ this.$nextTick(function() {
1039
+ window.customElements.get("iam-card") || window.customElements.define("iam-card", Ct);
1040
+ });
1041
+ }
1042
+ };
1043
+ function Et(t, a, e, s, r, n) {
1044
+ return c(), d("iam-card", null, [
1045
+ p(t.$slots, "default")
1046
+ ]);
1047
+ }
1048
+ const Nt = /* @__PURE__ */ A(Mt, [["render", Et]]);
1049
+ function Dt(t) {
1050
+ var a;
1051
+ let e = t.querySelector(".carousel__inner"), s = t.querySelectorAll(".carousel__item").length;
1052
+ t.getAttribute("data-cols");
1053
+ let r = t.getAttribute("data-sm-cols"), n = t.getAttribute("data-md-cols");
1054
+ t.querySelector(".carousel__controls a").classList.add("active"), e.addEventListener("scroll", function(i) {
1055
+ clearTimeout(a), a = setTimeout(function() {
1056
+ let l = e.clientWidth, h = e.scrollWidth, u = e.scrollLeft, m = Math.round(u / h * s) + 1, f = t.querySelector(".carousel__item:last-child").offsetLeft;
1057
+ Array.from(t.querySelectorAll(".carousel__controls a")).forEach((b, g) => {
1058
+ b.classList.remove("active");
1059
+ }), t.querySelector(".control-" + m).classList.add("active"), m == 1 ? t.querySelector(".btn-prev").setAttribute("disabled", "disabled") : t.querySelector(".btn-prev").removeAttribute("disabled"), e.scrollLeft + l > f ? t.querySelector(".btn-next").setAttribute("disabled", "disabled") : t.querySelector(".btn-next").removeAttribute("disabled");
1060
+ }, 100);
1061
+ }, !1), t.addEventListener("click", function(i) {
1062
+ for (var l = i.target; l && l != this; l = l.parentNode)
1063
+ if (l.matches(".carousel__controls a")) {
1064
+ i.preventDefault(), Array.from(t.querySelectorAll(".carousel__controls a")).forEach((u, m) => {
1065
+ u.classList.remove("active");
1066
+ }), l.classList.add("active");
1067
+ const h = document.querySelector(l.getAttribute("href"));
1068
+ e.scroll({
1069
+ top: 0,
1070
+ left: h.offsetLeft,
1071
+ behavior: "smooth"
1072
+ });
1073
+ break;
1074
+ }
1075
+ }, !1), t.addEventListener("click", function(i) {
1076
+ for (var l = i.target; l && l != this; l = l.parentNode)
1077
+ if (l.matches(".btn-next, .btn-prev")) {
1078
+ i.preventDefault();
1079
+ let h = l.classList.contains("btn-prev") ? e.scrollLeft - e.clientWidth : e.scrollLeft + e.clientWidth;
1080
+ e.scroll({
1081
+ top: 0,
1082
+ left: h,
1083
+ behavior: "smooth"
1084
+ });
1085
+ break;
1086
+ }
1087
+ }, !1), s == 1 && t.classList.add("hide-btns"), r >= s && t.classList.add("hide-sm-btns"), n >= s && t.classList.add("hide-md-btns");
1088
+ }
1089
+ const Rt = {
1118
1090
  components: {
1119
- Card: Q
1091
+ Card: Nt
1092
+ },
1093
+ name: "Carousel",
1094
+ data() {
1095
+ return {
1096
+ id: null
1097
+ };
1120
1098
  },
1121
- name: "CardDeck",
1122
1099
  props: {
1123
1100
  items: {
1124
1101
  type: Array,
@@ -1168,94 +1145,7 @@ const Tt = {
1168
1145
  type: Boolean,
1169
1146
  required: !1,
1170
1147
  default: !1
1171
- }
1172
- }
1173
- }, Mt = ["data-card-type"];
1174
- function Ht(e, r, t, o, f, s) {
1175
- const i = H("Card");
1176
- return l(), c("div", {
1177
- class: "container card-deck prevent-invert",
1178
- "data-card-type": t.cardtype
1179
- }, [
1180
- b(e.$slots, "default"),
1181
- a("div", {
1182
- class: v(`row row-cols-${t.cols} row-cols-sm-${t.smcols} row-cols-md-${t.mdcols} ${t.gap ? `g-${t.gap}` : ""}`)
1183
- }, [
1184
- (l(!0), c(x, null, L(t.items, (n, h) => (l(), c("div", {
1185
- class: "col",
1186
- key: h
1187
- }, [
1188
- S(i, T(n, {
1189
- class: t.cardclass,
1190
- type: t.cardtype,
1191
- btntype: n.btntype ? n.btntype : t.btntype,
1192
- titleclass: n.titleclass ? n.titleclass : t.titleclass,
1193
- ctatext: n.ctatext,
1194
- hidectatext: t.hidectatext
1195
- }), null, 16, ["class", "type", "btntype", "titleclass", "ctatext", "hidectatext"])
1196
- ]))), 128))
1197
- ], 2),
1198
- b(e.$slots, "after")
1199
- ], 8, Mt);
1200
- }
1201
- const Ct = /* @__PURE__ */ g(Tt, [["render", Ht]]);
1202
- function Nt(e) {
1203
- var r;
1204
- let t = e.querySelector(".carousel__inner"), o = e.querySelectorAll(".carousel__item").length;
1205
- e.getAttribute("data-cols");
1206
- let f = e.getAttribute("data-sm-cols"), s = e.getAttribute("data-md-cols");
1207
- e.querySelector(".carousel__controls a").classList.add("active"), t.addEventListener("scroll", function(i) {
1208
- clearTimeout(r), r = setTimeout(function() {
1209
- let n = t.clientWidth, h = t.scrollWidth, w = t.scrollLeft, $ = Math.round(w / h * o) + 1, M = e.querySelector(".carousel__item:last-child").offsetLeft;
1210
- Array.from(e.querySelectorAll(".carousel__controls a")).forEach((I, C) => {
1211
- I.classList.remove("active");
1212
- }), e.querySelector(".control-" + $).classList.add("active"), $ == 1 ? e.querySelector(".btn-prev").setAttribute("disabled", "disabled") : e.querySelector(".btn-prev").removeAttribute("disabled"), t.scrollLeft + n > M ? e.querySelector(".btn-next").setAttribute("disabled", "disabled") : e.querySelector(".btn-next").removeAttribute("disabled");
1213
- }, 100);
1214
- }, !1), e.addEventListener("click", function(i) {
1215
- for (var n = i.target; n && n != this; n = n.parentNode)
1216
- if (n.matches(".carousel__controls a")) {
1217
- i.preventDefault(), Array.from(e.querySelectorAll(".carousel__controls a")).forEach((w, $) => {
1218
- w.classList.remove("active");
1219
- }), n.classList.add("active");
1220
- const h = document.querySelector(n.getAttribute("href"));
1221
- t.scroll({
1222
- top: 0,
1223
- left: h.offsetLeft,
1224
- behavior: "smooth"
1225
- });
1226
- break;
1227
- }
1228
- }, !1), e.addEventListener("click", function(i) {
1229
- for (var n = i.target; n && n != this; n = n.parentNode)
1230
- if (n.matches(".btn-next, .btn-prev")) {
1231
- i.preventDefault();
1232
- let h = n.classList.contains("btn-prev") ? t.scrollLeft - t.clientWidth : t.scrollLeft + t.clientWidth;
1233
- t.scroll({
1234
- top: 0,
1235
- left: h,
1236
- behavior: "smooth"
1237
- });
1238
- break;
1239
- }
1240
- }, !1), o == 1 && e.classList.add("hide-btns"), f >= o && e.classList.add("hide-sm-btns"), s >= o && e.classList.add("hide-md-btns");
1241
- }
1242
- let P = Ct.props;
1243
- P.gap.default = 0;
1244
- P.cols.default = 1;
1245
- P.smcols.default = 2;
1246
- P.mdcols.default = 4;
1247
- const Bt = {
1248
- components: {
1249
- Card: Q
1250
- },
1251
- name: "Carousel",
1252
- data() {
1253
- return {
1254
- id: null
1255
- };
1256
- },
1257
- props: {
1258
- ...P,
1148
+ },
1259
1149
  colclass: {
1260
1150
  type: String,
1261
1151
  required: !1
@@ -1267,45 +1157,45 @@ const Bt = {
1267
1157
  },
1268
1158
  computed: {
1269
1159
  content() {
1270
- return (e) => `${e.image ? `<img src="${e.image}" alt="" />` : ""}${e.content ? e.content : ""}`;
1160
+ return (t) => `${t.image ? `<img src="${t.image}" alt="" />` : ""}${t.content ? t.content : ""}`;
1271
1161
  }
1272
1162
  },
1273
1163
  mounted() {
1274
1164
  this.id = this._uid, this.$nextTick(function() {
1275
- Nt(this.$refs.wrapper);
1165
+ Dt(this.$refs.wrapper);
1276
1166
  });
1277
1167
  }
1278
- }, Pt = ["id", "data-cols", "data-sm-cols", "data-md-cols"], Dt = { class: "carousel__wrapper" }, It = { class: "carousel__inner" }, zt = ["id"], Vt = ["innerHTML", "id"], Ft = ["href"], Ot = /* @__PURE__ */ a("button", {
1168
+ }, Pt = ["id", "data-cols", "data-sm-cols", "data-md-cols"], It = { class: "carousel__wrapper" }, Ft = { class: "carousel__inner" }, Bt = ["id"], Vt = ["innerHTML", "id"], zt = ["href"], Ot = /* @__PURE__ */ o("button", {
1279
1169
  class: "btn btn-prev",
1280
1170
  "data-go": "0",
1281
1171
  disabled: ""
1282
- }, "Prev", -1), jt = /* @__PURE__ */ a("button", {
1172
+ }, "Prev", -1), Wt = /* @__PURE__ */ o("button", {
1283
1173
  class: "btn btn-next",
1284
1174
  "data-go": "2"
1285
1175
  }, "Next", -1);
1286
- function Rt(e, r, t, o, f, s) {
1287
- const i = H("Card");
1288
- return l(), c("div", {
1176
+ function jt(t, a, e, s, r, n) {
1177
+ const i = E("Card");
1178
+ return c(), d("div", {
1289
1179
  class: "container carousel",
1290
- id: "carousel" + f.id,
1180
+ id: "carousel" + r.id,
1291
1181
  ref: "wrapper",
1292
1182
  "data-cols": e.cols,
1293
1183
  "data-sm-cols": e.smcols,
1294
1184
  "data-md-cols": e.mdcols
1295
1185
  }, [
1296
- b(e.$slots, "default"),
1297
- a("div", Dt, [
1298
- a("div", It, [
1299
- t.type == "card" ? (l(), c("div", {
1186
+ p(t.$slots, "default"),
1187
+ o("div", It, [
1188
+ o("div", Ft, [
1189
+ e.type == "card" ? (c(), d("div", {
1300
1190
  key: 0,
1301
1191
  class: v(`row row-cols-${e.cols} row-cols-sm-${e.smcols} row-cols-md-${e.mdcols} ${e.gap ? `g-${e.gap}` : ""}`)
1302
1192
  }, [
1303
- (l(!0), c(x, null, L(e.items, (n, h) => (l(), c("div", {
1304
- class: v(`col carousel__item${t.colclass ? ` ${t.colclass}` : ""}`),
1193
+ (c(!0), d($, null, T(e.items, (l, h) => (c(), d("div", {
1194
+ class: v(`col carousel__item${e.colclass ? ` ${e.colclass}` : ""}`),
1305
1195
  key: h,
1306
- id: "carousel" + f.id + "slide" + (h + 1)
1196
+ id: "carousel" + r.id + "slide" + (h + 1)
1307
1197
  }, [
1308
- S(i, T(n, {
1198
+ S(i, H(l, {
1309
1199
  class: e.cardclass,
1310
1200
  type: e.cardtype,
1311
1201
  btnyype: e.btntype,
@@ -1313,43 +1203,48 @@ function Rt(e, r, t, o, f, s) {
1313
1203
  ctatext: e.ctatext,
1314
1204
  hidectatext: e.hidectatext
1315
1205
  }), null, 16, ["class", "type", "btnyype", "titleclass", "ctatext", "hidectatext"])
1316
- ], 10, zt))), 128))
1317
- ], 2)) : p("", !0),
1318
- t.type != "card" ? (l(), c("div", {
1206
+ ], 10, Bt))), 128))
1207
+ ], 2)) : _("", !0),
1208
+ e.type != "card" ? (c(), d("div", {
1319
1209
  key: 1,
1320
1210
  class: v(`row row-cols-${e.cols} row-cols-sm-${e.smcols} row-cols-md-${e.mdcols} ${e.gap ? `g-${e.gap}` : ""}`)
1321
1211
  }, [
1322
- (l(!0), c(x, null, L(e.items, (n, h) => (l(), c("div", {
1323
- class: v(`col carousel__item${t.colclass ? ` ${t.colclass}` : ""}`),
1212
+ (c(!0), d($, null, T(e.items, (l, h) => (c(), d("div", {
1213
+ class: v(`col carousel__item${e.colclass ? ` ${e.colclass}` : ""}`),
1324
1214
  key: h,
1325
- innerHTML: s.content(n),
1326
- id: "carousel" + f.id + "slide" + (h + 1)
1215
+ innerHTML: n.content(l),
1216
+ id: "carousel" + r.id + "slide" + (h + 1)
1327
1217
  }, null, 10, Vt))), 128))
1328
- ], 2)) : p("", !0)
1218
+ ], 2)) : _("", !0)
1329
1219
  ]),
1330
- a("div", {
1220
+ o("div", {
1331
1221
  class: v(`carousel__controls cols-${e.cols} cols-sm-${e.smcols} cols-md-${e.mdcols}`)
1332
1222
  }, [
1333
- (l(!0), c(x, null, L(e.items, (n, h) => (l(), c("a", {
1223
+ (c(!0), d($, null, T(e.items, (l, h) => (c(), d("a", {
1334
1224
  key: h,
1335
- href: "#carousel" + f.id + "slide" + (h + 1),
1225
+ href: "#carousel" + r.id + "slide" + (h + 1),
1336
1226
  class: v(`control-${h + 1}`)
1337
- }, "Slide " + k(h + 1), 11, Ft))), 128))
1227
+ }, "Slide " + L(h + 1), 11, zt))), 128))
1338
1228
  ], 2),
1339
1229
  Ot,
1340
- jt
1230
+ Wt
1341
1231
  ])
1342
1232
  ], 8, Pt);
1343
1233
  }
1344
- const mi = /* @__PURE__ */ g(Bt, [["render", Rt]]);
1345
- class Wt extends HTMLElement {
1234
+ const hi = /* @__PURE__ */ A(Rt, [["render", jt]]);
1235
+ window.dataLayer = window.dataLayer || [];
1236
+ window.dataLayer.push({
1237
+ event: "customElementRegistered",
1238
+ element: "header"
1239
+ });
1240
+ class Ut extends HTMLElement {
1346
1241
  constructor() {
1347
1242
  super(), this.attachShadow({ mode: "open" });
1348
- const r = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", t = `@import "${r}/css/components/header.css";`, o = document.createElement("template");
1349
- o.innerHTML = `
1243
+ const a = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", e = `@import "${a}/css/components/header.css";`, s = document.createElement("template");
1244
+ s.innerHTML = `
1350
1245
  <style>
1351
- @import "${r}/css/core.min.css";
1352
- ${t}
1246
+ @import "${a}/css/core.min.css";
1247
+ ${e}
1353
1248
  ${this.hasAttribute("css") ? `@import "${this.getAttribute("css")}";` : ""}
1354
1249
  :host {
1355
1250
  max-width:100%!important;
@@ -1370,14 +1265,14 @@ class Wt extends HTMLElement {
1370
1265
  <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" alt="" lazy="" />
1371
1266
  </picture>
1372
1267
  </div>
1373
- `, this.shadowRoot.appendChild(o.content.cloneNode(!0));
1268
+ `, this.shadowRoot.appendChild(s.content.cloneNode(!0));
1374
1269
  }
1375
1270
  connectedCallback() {
1376
- const r = this.shadowRoot.querySelector("picture"), t = this.shadowRoot.querySelector("picture source");
1377
- this.hasAttribute("image") ? t.setAttribute("srcset", this.getAttribute("image")) : r.remove();
1271
+ const a = this.shadowRoot.querySelector("picture"), e = this.shadowRoot.querySelector("picture source");
1272
+ this.hasAttribute("image") ? e.setAttribute("srcset", this.getAttribute("image")) : a.remove();
1378
1273
  }
1379
1274
  }
1380
- window.customElements.get("iam-header") || window.customElements.define("iam-header", Wt);
1275
+ window.customElements.get("iam-header") || window.customElements.define("iam-header", Ut);
1381
1276
  const Kt = {
1382
1277
  name: "Header",
1383
1278
  props: {
@@ -1390,50 +1285,50 @@ const Kt = {
1390
1285
  required: !1
1391
1286
  }
1392
1287
  }
1393
- }, Ut = ["image"], Gt = ["innerHTML"];
1394
- function Zt(e, r, t, o, f, s) {
1395
- return l(), c("iam-header", {
1288
+ }, Gt = ["image"], Qt = ["innerHTML"];
1289
+ function Yt(t, a, e, s, r, n) {
1290
+ return c(), d("iam-header", {
1396
1291
  class: "bg-secondary",
1397
- image: t.image
1292
+ image: e.image
1398
1293
  }, [
1399
- b(e.$slots, "breadcrumb"),
1400
- t.title ? (l(), c("h1", {
1294
+ p(t.$slots, "breadcrumb"),
1295
+ e.title ? (c(), d("h1", {
1401
1296
  key: 0,
1402
- innerHTML: t.title
1403
- }, null, 8, Gt)) : p("", !0),
1404
- b(e.$slots, "default")
1405
- ], 8, Ut);
1297
+ innerHTML: e.title
1298
+ }, null, 8, Qt)) : _("", !0),
1299
+ p(t.$slots, "default")
1300
+ ], 8, Gt);
1406
1301
  }
1407
- const _i = /* @__PURE__ */ g(Kt, [["render", Zt]]);
1408
- function Et(e) {
1409
- var r;
1410
- const t = e.querySelector(".testimonial__images"), o = t.querySelectorAll("img").length;
1411
- if (o == 1)
1302
+ const mi = /* @__PURE__ */ A(Kt, [["render", Yt]]);
1303
+ function Zt(t) {
1304
+ var a;
1305
+ const e = t.querySelector(".testimonial__images"), s = e.querySelectorAll("img").length;
1306
+ if (s == 1)
1412
1307
  return !1;
1413
- e.classList.add("testimonial--multi");
1414
- const f = function(s) {
1415
- const i = e.querySelector(".btn-next"), n = e.querySelector(".btn-prev");
1416
- i.setAttribute("data-go", s + 1), n.setAttribute("data-go", s - 1), i.removeAttribute("disabled"), n.removeAttribute("disabled"), s == 1 ? n.setAttribute("disabled", !0) : s == o && i.setAttribute("disabled", !0);
1308
+ t.classList.add("testimonial--multi");
1309
+ const r = function(n) {
1310
+ const i = t.querySelector(".btn-next"), l = t.querySelector(".btn-prev");
1311
+ i.setAttribute("data-go", n + 1), l.setAttribute("data-go", n - 1), i.removeAttribute("disabled"), l.removeAttribute("disabled"), n == 1 ? l.setAttribute("disabled", !0) : n == s && i.setAttribute("disabled", !0);
1417
1312
  };
1418
- t.addEventListener("scroll", function(s) {
1419
- clearTimeout(r), r = setTimeout(function() {
1420
- let i = t.scrollWidth, n = t.scrollHeight, h = t.scrollLeft, w = t.scrollTop, $ = Math.round(h / i * o) + 1;
1421
- h == 0 && w != 0 && ($ = Math.round(w / n * o) + 1), e.setAttribute("data-show", $), f($);
1313
+ e.addEventListener("scroll", function(n) {
1314
+ clearTimeout(a), a = setTimeout(function() {
1315
+ let i = e.scrollWidth, l = e.scrollHeight, h = e.scrollLeft, u = e.scrollTop, m = Math.round(h / i * s) + 1;
1316
+ h == 0 && u != 0 && (m = Math.round(u / l * s) + 1), t.setAttribute("data-show", m), r(m);
1422
1317
  }, 300);
1423
- }, !1), e.addEventListener("click", function(s) {
1424
- for (var i = s.target; i && i != this; i = i.parentNode)
1318
+ }, !1), t.addEventListener("click", function(n) {
1319
+ for (var i = n.target; i && i != this; i = i.parentNode)
1425
1320
  if (i.matches("[data-go]")) {
1426
- let n = parseInt(i.getAttribute("data-go")), h = 0, w = 0, $ = t.scrollWidth, M = t.scrollHeight;
1427
- $ > M ? w = Math.floor($ * ((n - 1) / o)) : h = Math.floor(M * ((n - 1) / o)), t.scroll({
1321
+ let l = parseInt(i.getAttribute("data-go")), h = 0, u = 0, m = e.scrollWidth, f = e.scrollHeight;
1322
+ m > f ? u = Math.floor(m * ((l - 1) / s)) : h = Math.floor(f * ((l - 1) / s)), e.scroll({
1428
1323
  top: h,
1429
- left: w,
1324
+ left: u,
1430
1325
  behavior: "smooth"
1431
1326
  });
1432
1327
  break;
1433
1328
  }
1434
1329
  }, !1);
1435
1330
  }
1436
- const Qt = {
1331
+ const Xt = {
1437
1332
  name: "Testimonial",
1438
1333
  props: {
1439
1334
  items: {
@@ -1447,68 +1342,68 @@ const Qt = {
1447
1342
  }
1448
1343
  },
1449
1344
  mounted() {
1450
- Et(this.$refs.wrapper);
1345
+ Zt(this.$refs.wrapper);
1451
1346
  }
1452
- }, Yt = {
1347
+ }, Jt = {
1453
1348
  class: "container testimonial mb-5",
1454
1349
  "data-show": "1",
1455
1350
  ref: "wrapper"
1456
- }, Jt = { class: "row" }, Xt = { class: "col-md-5 position-relative" }, es = { class: "testimonial__images" }, ts = ["src"], ss = /* @__PURE__ */ a("div", { class: "testimonial__controls" }, [
1457
- /* @__PURE__ */ a("button", {
1351
+ }, ea = { class: "row" }, ta = { class: "col-md-5 position-relative" }, aa = { class: "testimonial__images" }, sa = ["src"], ia = /* @__PURE__ */ o("div", { class: "testimonial__controls" }, [
1352
+ /* @__PURE__ */ o("button", {
1458
1353
  "data-go": "0",
1459
1354
  disabled: "",
1460
1355
  class: "btn-prev"
1461
1356
  }, "Previous"),
1462
- /* @__PURE__ */ a("button", {
1357
+ /* @__PURE__ */ o("button", {
1463
1358
  "data-go": "2",
1464
1359
  class: "btn-next"
1465
1360
  }, "Next")
1466
- ], -1), as = { class: "col-md-7" }, is = /* @__PURE__ */ a("h2", null, "What our customers think…", -1), ns = { class: "testimonial__content" }, rs = ["innerHTML"], os = ["innerHTML"], ls = { class: "testimonial__after" }, cs = /* @__PURE__ */ a("span", { class: "circle circle--dots d-none d-md-block" }, null, -1);
1467
- function ds(e, r, t, o, f, s) {
1468
- return l(), c("div", Yt, [
1469
- a("div", {
1470
- class: v("bg-" + t.background)
1361
+ ], -1), la = { class: "col-md-7" }, na = /* @__PURE__ */ o("h2", null, "What our customers think…", -1), ra = { class: "testimonial__content" }, oa = ["innerHTML"], ca = ["innerHTML"], da = { class: "testimonial__after" }, ua = /* @__PURE__ */ o("span", { class: "circle circle--dots d-none d-md-block" }, null, -1);
1362
+ function ha(t, a, e, s, r, n) {
1363
+ return c(), d("div", Jt, [
1364
+ o("div", {
1365
+ class: v("bg-" + e.background)
1471
1366
  }, [
1472
- a("div", Jt, [
1473
- a("div", Xt, [
1474
- a("div", es, [
1475
- (l(!0), c(x, null, L(t.items, (i, n) => (l(), c("img", {
1476
- key: n,
1367
+ o("div", ea, [
1368
+ o("div", ta, [
1369
+ o("div", aa, [
1370
+ (c(!0), d($, null, T(e.items, (i, l) => (c(), d("img", {
1371
+ key: l,
1477
1372
  src: i.image ? i.image : "data:image/gif;base64,R0lGODlhAQABAIAAAHd3dwAAACH5BAAAAAAALAAAAAABAAEAAAICRAEAOw==",
1478
1373
  alt: "",
1479
1374
  class: v("h-100 w-100 object-cover" + (i.image ? "" : " opacity-0"))
1480
- }, null, 10, ts))), 128))
1375
+ }, null, 10, sa))), 128))
1481
1376
  ]),
1482
- ss
1377
+ ia
1483
1378
  ]),
1484
- a("div", as, [
1485
- is,
1486
- a("div", ns, [
1487
- (l(!0), c(x, null, L(t.items, (i, n) => (l(), c("blockquote", {
1488
- key: n,
1379
+ o("div", la, [
1380
+ na,
1381
+ o("div", ra, [
1382
+ (c(!0), d($, null, T(e.items, (i, l) => (c(), d("blockquote", {
1383
+ key: l,
1489
1384
  class: v(i.class)
1490
1385
  }, [
1491
- a("div", {
1386
+ o("div", {
1492
1387
  innerHTML: i.quote
1493
- }, null, 8, rs),
1494
- a("cite", {
1388
+ }, null, 8, oa),
1389
+ o("cite", {
1495
1390
  innerHTML: i.cite
1496
- }, null, 8, os)
1391
+ }, null, 8, ca)
1497
1392
  ], 2))), 128))
1498
1393
  ]),
1499
- a("div", ls, [
1500
- b(e.$slots, "default")
1394
+ o("div", da, [
1395
+ p(t.$slots, "default")
1501
1396
  ])
1502
1397
  ])
1503
1398
  ]),
1504
- cs
1399
+ ua
1505
1400
  ], 2)
1506
1401
  ], 512);
1507
1402
  }
1508
- const yi = /* @__PURE__ */ g(Qt, [["render", ds]]);
1509
- const us = {
1403
+ const fi = /* @__PURE__ */ A(Xt, [["render", ha]]);
1404
+ const ma = {
1510
1405
  components: {
1511
- Input: D
1406
+ Input: R
1512
1407
  },
1513
1408
  name: "PropertySearchbar",
1514
1409
  props: {
@@ -1633,8 +1528,8 @@ const us = {
1633
1528
  };
1634
1529
  },
1635
1530
  methods: {
1636
- locationKeyup: function(e) {
1637
- this.$emit("locationKeyup", e);
1531
+ locationKeyup: function(t) {
1532
+ this.$emit("locationKeyup", t);
1638
1533
  }
1639
1534
  },
1640
1535
  computed: {
@@ -1642,8 +1537,8 @@ const us = {
1642
1537
  get() {
1643
1538
  return this.locationSave ? this.locationSave : this.location;
1644
1539
  },
1645
- set(e) {
1646
- this.locationSave = e, this.$emit("input", e);
1540
+ set(t) {
1541
+ this.locationSave = t, this.$emit("input", t);
1647
1542
  }
1648
1543
  },
1649
1544
  locationsList() {
@@ -1652,43 +1547,43 @@ const us = {
1652
1547
  ];
1653
1548
  }
1654
1549
  }
1655
- }, fs = {
1550
+ }, fa = {
1656
1551
  class: "container",
1657
1552
  ref: "wrapper"
1658
- }, hs = { class: "property-searchbar" }, ms = ["action", "method"], _s = { class: "col-12 col-md-3" }, ys = { class: "col-12 col-md" }, ps = /* @__PURE__ */ a("span", { class: "form-label d-none d-md-block" }, "Price range", -1), bs = {
1553
+ }, ya = { class: "property-searchbar" }, ba = ["action", "method"], _a = { class: "col-12 col-md-3" }, pa = { class: "col-12 col-md" }, ga = /* @__PURE__ */ o("span", { class: "form-label d-none d-md-block" }, "Price range", -1), va = {
1659
1554
  class: "row",
1660
1555
  "data-input-range": ""
1661
- }, vs = { class: "col-12 col-md" }, gs = /* @__PURE__ */ a("span", { class: "form-label d-none d-md-block" }, "Number of beds", -1), As = {
1556
+ }, Aa = { class: "col-12 col-md" }, wa = /* @__PURE__ */ o("span", { class: "form-label d-none d-md-block" }, "Number of beds", -1), Sa = {
1662
1557
  class: "row",
1663
1558
  "data-input-range": ""
1664
- }, ws = { class: "col-12 col-md-2" }, ks = /* @__PURE__ */ a("div", { class: "col-12 col-md mw-md-fit-content d-flex property-searchbar__btn" }, [
1665
- /* @__PURE__ */ a("button", {
1559
+ }, La = { class: "col-12 col-md-2" }, ka = /* @__PURE__ */ o("div", { class: "col-12 col-md mw-md-fit-content d-flex property-searchbar__btn" }, [
1560
+ /* @__PURE__ */ o("button", {
1666
1561
  class: "btn w-100 me-0",
1667
1562
  type: "submit",
1668
1563
  value: "submit"
1669
1564
  }, "Search")
1670
1565
  ], -1);
1671
- function Ss(e, r, t, o, f, s) {
1672
- const i = H("Input");
1673
- return l(), c("div", fs, [
1674
- b(e.$slots, "default"),
1675
- a("div", hs, [
1676
- a("form", {
1566
+ function qa(t, a, e, s, r, n) {
1567
+ const i = E("Input");
1568
+ return c(), d("div", fa, [
1569
+ p(t.$slots, "default"),
1570
+ o("div", ya, [
1571
+ o("form", {
1677
1572
  class: "row",
1678
- action: t.formaction,
1679
- method: t.formmethod
1573
+ action: e.formaction,
1574
+ method: e.formmethod
1680
1575
  }, [
1681
- a("fieldset", _s, [
1576
+ o("fieldset", _a, [
1682
1577
  S(i, {
1683
1578
  inputClass: "input--locations",
1684
- modelValue: s.locationSet,
1685
- "onUpdate:modelValue": r[0] || (r[0] = (n) => s.locationSet = n),
1579
+ modelValue: n.locationSet,
1580
+ "onUpdate:modelValue": a[0] || (a[0] = (l) => n.locationSet = l),
1686
1581
  label: "Location",
1687
1582
  id: "location",
1688
- options: s.locationsList(),
1583
+ options: n.locationsList(),
1689
1584
  required: "",
1690
1585
  placeholder: "i.e. Newcastle or NE1",
1691
- onKeyupEvent: r[1] || (r[1] = (n) => s.locationKeyup(...arguments)),
1586
+ onKeyupEvent: a[1] || (a[1] = (l) => n.locationKeyup(...arguments)),
1692
1587
  ref: "search"
1693
1588
  }, null, 8, ["modelValue", "options"]),
1694
1589
  S(i, {
@@ -1696,19 +1591,19 @@ function Ss(e, r, t, o, f, s) {
1696
1591
  label: "Miles",
1697
1592
  id: "miles",
1698
1593
  type: "select",
1699
- options: t.distances
1594
+ options: e.distances
1700
1595
  }, null, 8, ["options"])
1701
1596
  ]),
1702
- a("fieldset", ys, [
1703
- ps,
1704
- a("div", bs, [
1597
+ o("fieldset", pa, [
1598
+ ga,
1599
+ o("div", va, [
1705
1600
  S(i, {
1706
1601
  class: "col-6",
1707
1602
  label: "Minimum price",
1708
1603
  id: "price-min",
1709
1604
  "data-min": "true",
1710
1605
  type: "select",
1711
- options: t.pricemin
1606
+ options: e.pricemin
1712
1607
  }, null, 8, ["options"]),
1713
1608
  S(i, {
1714
1609
  class: "col-6",
@@ -1716,20 +1611,20 @@ function Ss(e, r, t, o, f, s) {
1716
1611
  id: "price-max",
1717
1612
  "data-max": "true",
1718
1613
  type: "select",
1719
- options: t.pricemax
1614
+ options: e.pricemax
1720
1615
  }, null, 8, ["options"])
1721
1616
  ])
1722
1617
  ]),
1723
- a("fieldset", vs, [
1724
- gs,
1725
- a("div", As, [
1618
+ o("fieldset", Aa, [
1619
+ wa,
1620
+ o("div", Sa, [
1726
1621
  S(i, {
1727
1622
  class: "col-6",
1728
1623
  label: "Minimum beds",
1729
1624
  id: "beds-min",
1730
1625
  "data-min": "true",
1731
1626
  type: "select",
1732
- options: t.bedsmin
1627
+ options: e.bedsmin
1733
1628
  }, null, 8, ["options"]),
1734
1629
  S(i, {
1735
1630
  class: "col-6",
@@ -1737,41 +1632,41 @@ function Ss(e, r, t, o, f, s) {
1737
1632
  id: "beds-max",
1738
1633
  "data-max": "true",
1739
1634
  type: "select",
1740
- options: t.bedsmax
1635
+ options: e.bedsmax
1741
1636
  }, null, 8, ["options"])
1742
1637
  ])
1743
1638
  ]),
1744
- a("fieldset", ws, [
1639
+ o("fieldset", La, [
1745
1640
  S(i, {
1746
1641
  label: "Property type",
1747
1642
  id: "property-type",
1748
1643
  type: "select",
1749
- options: t.propertytypes
1644
+ options: e.propertytypes
1750
1645
  }, null, 8, ["options"])
1751
1646
  ]),
1752
- ks
1753
- ], 8, ms)
1647
+ ka
1648
+ ], 8, ba)
1754
1649
  ]),
1755
- b(e.$slots, "after")
1650
+ p(t.$slots, "after")
1756
1651
  ], 512);
1757
1652
  }
1758
- const pi = /* @__PURE__ */ g(us, [["render", Ss]]), $s = (e) => {
1759
- Array.from(e.querySelectorAll("details")).forEach((r, t) => {
1760
- r.addEventListener("mouseenter", function(o) {
1761
- window.matchMedia("(min-width: 62em)").matches && r.setAttribute("open", "true");
1762
- }, !1), r.addEventListener("mouseleave", function(o) {
1763
- window.matchMedia("(min-width: 62em)").matches && r.removeAttribute("open");
1653
+ const yi = /* @__PURE__ */ A(ma, [["render", qa]]), xa = (t) => {
1654
+ Array.from(t.querySelectorAll("details")).forEach((a, e) => {
1655
+ a.addEventListener("mouseenter", function(s) {
1656
+ window.matchMedia("(min-width: 62em)").matches && a.setAttribute("open", "true");
1657
+ }, !1), a.addEventListener("mouseleave", function(s) {
1658
+ window.matchMedia("(min-width: 62em)").matches && a.removeAttribute("open");
1764
1659
  }, !1);
1765
1660
  }), "IntersectionObserver" in window && new IntersectionObserver(
1766
- ([t]) => t.target.classList.toggle("is-stuck", t.intersectionRatio < 1),
1661
+ ([e]) => e.target.classList.toggle("is-stuck", e.intersectionRatio < 1),
1767
1662
  { threshold: [1] }
1768
- ).observe(e);
1663
+ ).observe(t);
1769
1664
  };
1770
- const qs = {
1665
+ const $a = {
1771
1666
  components: {
1772
- Input: D,
1773
- Logo: fe,
1774
- Icon: oe
1667
+ Input: R,
1668
+ Logo: _e,
1669
+ Icon: he
1775
1670
  },
1776
1671
  name: "Nav",
1777
1672
  props: {
@@ -1818,8 +1713,8 @@ const qs = {
1818
1713
  };
1819
1714
  },
1820
1715
  methods: {
1821
- subIsActive(e) {
1822
- return (Array.isArray(e) ? e : [e]).some((t) => this.$route.path.indexOf(t) === 0);
1716
+ subIsActive(t) {
1717
+ return (Array.isArray(t) ? t : [t]).some((e) => this.$route.path.indexOf(e) === 0);
1823
1718
  }
1824
1719
  },
1825
1720
  computed: {
@@ -1841,61 +1736,61 @@ const qs = {
1841
1736
  },
1842
1737
  mounted() {
1843
1738
  this.$nextTick(function() {
1844
- $s(this.$refs.wrapper);
1739
+ xa(this.$refs.wrapper);
1845
1740
  });
1846
1741
  }
1847
- }, xs = /* @__PURE__ */ a("input", {
1742
+ }, Ta = /* @__PURE__ */ o("input", {
1848
1743
  type: "checkbox",
1849
1744
  name: "showMenu",
1850
1745
  id: "showMenu",
1851
1746
  class: "d-none"
1852
- }, null, -1), Ls = /* @__PURE__ */ a("input", {
1747
+ }, null, -1), Ha = /* @__PURE__ */ o("input", {
1853
1748
  type: "checkbox",
1854
1749
  name: "showSearch",
1855
1750
  id: "showSearch",
1856
1751
  class: "d-none"
1857
- }, null, -1), Ts = /* @__PURE__ */ a("input", {
1752
+ }, null, -1), Ca = /* @__PURE__ */ o("input", {
1858
1753
  type: "checkbox",
1859
1754
  name: "showAccount",
1860
1755
  id: "showAccount",
1861
1756
  class: "d-none"
1862
- }, null, -1), Ms = { class: "nav__mobile-bar" }, Hs = { class: "container" }, Cs = { class: "row" }, Ns = {
1757
+ }, null, -1), Ma = { class: "nav__mobile-bar" }, Ea = { class: "container" }, Na = { class: "row" }, Da = {
1863
1758
  key: 0,
1864
1759
  class: "col mw-md-fit-content nav__logo"
1865
- }, Bs = {
1760
+ }, Ra = {
1866
1761
  key: 1,
1867
1762
  class: "col mw-md-fit-content nav__logo"
1868
- }, Ps = {
1763
+ }, Pa = {
1869
1764
  href: "/",
1870
1765
  class: "text-decoration-none mb-0"
1871
- }, Ds = /* @__PURE__ */ a("div", { class: "col mw-fit-content d-md-none flex-row align-items-center nav__menu-btn" }, [
1872
- /* @__PURE__ */ a("label", { for: "showMenu" }, "Menu")
1873
- ], -1), Is = { class: "nav__inner" }, zs = { class: "container" }, Vs = { class: "row" }, Fs = {
1766
+ }, Ia = /* @__PURE__ */ o("div", { class: "col mw-fit-content d-md-none flex-row align-items-center nav__menu-btn" }, [
1767
+ /* @__PURE__ */ o("label", { for: "showMenu" }, "Menu")
1768
+ ], -1), Fa = { class: "nav__inner" }, Ba = { class: "container" }, Va = { class: "row" }, za = {
1874
1769
  key: 0,
1875
1770
  class: "col mw-md-fit-content nav__logo"
1876
- }, Os = {
1771
+ }, Oa = {
1877
1772
  key: 1,
1878
1773
  class: "col mw-md-fit-content nav__logo"
1879
- }, js = {
1774
+ }, Wa = {
1880
1775
  href: "/",
1881
1776
  class: "text-decoration-none mb-0"
1882
- }, Rs = {
1777
+ }, ja = {
1883
1778
  key: 2,
1884
1779
  class: "col mw-fit-content nav__search-btn flex-row align-items-center"
1885
- }, Ws = /* @__PURE__ */ a("label", { for: "showSearch" }, [
1886
- /* @__PURE__ */ a("svg", {
1780
+ }, Ua = /* @__PURE__ */ o("label", { for: "showSearch" }, [
1781
+ /* @__PURE__ */ o("svg", {
1887
1782
  class: "icon",
1888
1783
  viewBox: "0 0 32 32"
1889
1784
  }, [
1890
- /* @__PURE__ */ a("title", null, "Search"),
1891
- /* @__PURE__ */ a("ellipse", {
1785
+ /* @__PURE__ */ o("title", null, "Search"),
1786
+ /* @__PURE__ */ o("ellipse", {
1892
1787
  cx: "14.92",
1893
1788
  cy: "13.81",
1894
1789
  rx: "11.92",
1895
1790
  ry: "11.81",
1896
1791
  class: "icon__outline"
1897
1792
  }),
1898
- /* @__PURE__ */ a("line", {
1793
+ /* @__PURE__ */ o("line", {
1899
1794
  x1: "22.68",
1900
1795
  y1: "22.75",
1901
1796
  x2: "30",
@@ -1903,237 +1798,152 @@ const qs = {
1903
1798
  class: "icon__outline"
1904
1799
  })
1905
1800
  ])
1906
- ], -1), Ks = [
1907
- Ws
1908
- ], Us = /* @__PURE__ */ a("div", { class: "col mw-fit-content d-md-none flex-row align-items-center nav__menu-btn" }, [
1909
- /* @__PURE__ */ a("label", { for: "showMenu" }, "Menu")
1910
- ], -1), Gs = { class: "col-12 col-md nav__menu ms-auto flex-row align-items-center" }, Zs = {
1801
+ ], -1), Ka = [
1802
+ Ua
1803
+ ], Ga = /* @__PURE__ */ o("div", { class: "col mw-fit-content d-md-none flex-row align-items-center nav__menu-btn" }, [
1804
+ /* @__PURE__ */ o("label", { for: "showMenu" }, "Menu")
1805
+ ], -1), Qa = { class: "col-12 col-md nav__menu ms-auto flex-row align-items-center" }, Ya = {
1911
1806
  key: 3,
1912
1807
  class: "col nav__account-btn flex-row align-items-center"
1913
- }, Es = /* @__PURE__ */ a("label", { for: "showAccount" }, [
1914
- /* @__PURE__ */ a("svg", {
1808
+ }, Za = /* @__PURE__ */ o("label", { for: "showAccount" }, [
1809
+ /* @__PURE__ */ o("svg", {
1915
1810
  class: "icon",
1916
1811
  viewBox: "0 0 28 28"
1917
1812
  }, [
1918
- /* @__PURE__ */ a("path", {
1813
+ /* @__PURE__ */ o("path", {
1919
1814
  d: "M14,28a13.861,13.861,0,0,1-9.268-3.533l-.023.047-.721-.738L3.62,23.4l.012-.023a14,14,0,1,1,20.735,0l.012.023-.367.377-.722.738-.024-.045A13.855,13.855,0,0,1,14,28Zm0-9.58a10.5,10.5,0,0,0-1.368.092c-.085.012-.17.03-.252.047-.061.013-.124.026-.187.037l-.077.013c-.266.047-.54.095-.8.165-.108.029-.215.065-.318.1-.063.022-.125.043-.188.063l-.08.026c-.223.071-.454.144-.671.234-.125.05-.245.11-.362.168l-.146.072-.045.021c-.208.1-.423.2-.623.312-.131.074-.257.158-.379.239l-.106.07-.068.044c-.176.114-.359.232-.528.359-.137.1-.267.218-.393.327l-.054.047c-.174.15-.355.306-.519.47-.132.134-.258.277-.38.416l-.018.021c-.16.184-.3.35-.437.527-.12.161-.23.33-.337.494-.076.117-.146.238-.214.356a12.495,12.495,0,0,0,17.109,0l-.022-.037c-.061-.1-.125-.212-.192-.315-.1-.156-.214-.333-.338-.5-.141-.188-.293-.363-.436-.526-.113-.13-.253-.292-.4-.438-.161-.162-.337-.314-.517-.468l-.08-.069c-.118-.1-.24-.209-.368-.307-.183-.137-.379-.264-.568-.387l-.026-.017-.106-.07c-.125-.083-.251-.166-.381-.24-.207-.118-.429-.222-.643-.322l-.024-.011-.152-.074c-.116-.057-.235-.116-.356-.165-.214-.087-.438-.159-.656-.229l-.1-.031c-.066-.021-.132-.043-.2-.066-.1-.035-.2-.07-.309-.1-.264-.07-.538-.118-.8-.165l-.078-.014c-.063-.011-.126-.024-.187-.037-.082-.017-.167-.035-.252-.047A10.483,10.483,0,0,0,14,18.421Zm0-1.473a11.871,11.871,0,0,1,1.54.1c.1.013.192.033.284.052.069.014.139.028.209.04.34.058.672.118,1,.2.14.036.278.082.412.127l.151.05c.309.1.587.188.859.3.148.059.293.127.433.194l.13.061c.306.142.553.266.775.389.188.107.368.22.535.328.26.166.489.322.7.478.156.117.316.244.49.389.209.176.412.361.622.567.156.154.3.293.43.443.209.23.4.472.542.657l.051.066c.1.134.21.272.308.416.021.031.045.061.068.09a1.267,1.267,0,0,1,.085.117,12.525,12.525,0,1,0-19.24,0c.026-.04.056-.078.084-.114s.05-.064.073-.1c.1-.141.2-.278.3-.409l.046-.059c.2-.264.378-.478.555-.672.137-.152.281-.3.417-.43.215-.21.422-.4.635-.578.18-.15.332-.271.479-.381.208-.155.433-.31.709-.486.174-.111.346-.219.526-.319.274-.153.55-.285.783-.393l.112-.053c.144-.069.293-.14.445-.2.282-.113.578-.208.864-.3l.159-.052c.132-.044.265-.088.4-.124.331-.087.675-.148,1-.2.068-.012.137-.026.2-.039.094-.019.191-.039.288-.052A11.827,11.827,0,0,1,14,16.948Z",
1920
1815
  transform: "translate(0 -0.001)"
1921
1816
  }),
1922
- /* @__PURE__ */ a("path", {
1817
+ /* @__PURE__ */ o("path", {
1923
1818
  d: "M5.2,10.4a5.2,5.2,0,1,1,5.2-5.2A5.206,5.206,0,0,1,5.2,10.4Zm0-8.915A3.714,3.714,0,1,0,8.915,5.2,3.719,3.719,0,0,0,5.2,1.486Z",
1924
1819
  transform: "translate(8.8 4.8)"
1925
1820
  })
1926
1821
  ]),
1927
- /* @__PURE__ */ a("span", null, "My account")
1928
- ], -1), Qs = [
1929
- Es
1930
- ], Ys = {
1822
+ /* @__PURE__ */ o("span", null, "My account")
1823
+ ], -1), Xa = [
1824
+ Za
1825
+ ], Ja = {
1931
1826
  key: 4,
1932
1827
  class: "col-12 col-md nav__btn mw-md-fit-content flex-row align-items-center"
1933
- }, Js = ["href", "innerHTML"], Xs = {
1828
+ }, es = ["href", "innerHTML"], ts = {
1934
1829
  key: 0,
1935
1830
  class: "nav__menu--secondary"
1936
- }, ea = { class: "container" }, ta = {
1831
+ }, as = { class: "container" }, ss = {
1937
1832
  key: 1,
1938
1833
  class: "nav__menu--search"
1939
- }, sa = { class: "bg-gradient pt-4" }, aa = { class: "container" }, ia = {
1834
+ }, is = { class: "bg-gradient pt-4" }, ls = { class: "container" }, ns = {
1940
1835
  key: 0,
1941
1836
  class: "nav__menu--account"
1942
- }, na = { class: "container" }, ra = { class: "row mb-4" }, oa = {
1837
+ }, rs = { class: "container" }, os = { class: "row mb-4" }, cs = {
1943
1838
  key: 0,
1944
1839
  class: "col mw-md-fit-content nav__logo"
1945
- }, la = {
1840
+ }, ds = {
1946
1841
  key: 1,
1947
1842
  class: "col mw-md-fit-content nav__logo"
1948
- }, ca = {
1843
+ }, us = {
1949
1844
  href: "/",
1950
1845
  class: "text-decoration-none mb-0"
1951
- }, da = /* @__PURE__ */ a("div", { class: "col mw-fit-content d-md-none flex-row align-items-center nav__menu-btn" }, [
1952
- /* @__PURE__ */ a("label", { for: "showAccount" }, "Account")
1953
- ], -1), ua = { class: "container" }, fa = /* @__PURE__ */ a("span", { class: "nav__bg" }, null, -1);
1954
- function ha(e, r, t, o, f, s) {
1955
- const i = H("Logo");
1956
- return l(), c("nav", {
1957
- class: v(`nav${s.hasSecondarySlot ? " has-secondary" : ""}`),
1846
+ }, hs = /* @__PURE__ */ o("div", { class: "col mw-fit-content d-md-none flex-row align-items-center nav__menu-btn" }, [
1847
+ /* @__PURE__ */ o("label", { for: "showAccount" }, "Account")
1848
+ ], -1), ms = { class: "container" }, fs = /* @__PURE__ */ o("span", { class: "nav__bg" }, null, -1);
1849
+ function ys(t, a, e, s, r, n) {
1850
+ const i = E("Logo");
1851
+ return c(), d("nav", {
1852
+ class: v(`nav${n.hasSecondarySlot ? " has-secondary" : ""}`),
1958
1853
  ref: "wrapper"
1959
1854
  }, [
1960
- xs,
1961
- Ls,
1962
- Ts,
1963
- a("div", Ms, [
1964
- a("div", Hs, [
1965
- a("div", Cs, [
1966
- s.hasLogoSlot ? (l(), c("div", Ns, [
1967
- b(e.$slots, "logo")
1968
- ])) : (l(), c("div", Bs, [
1969
- a("a", Ps, [
1855
+ Ta,
1856
+ Ha,
1857
+ Ca,
1858
+ o("div", Ma, [
1859
+ o("div", Ea, [
1860
+ o("div", Na, [
1861
+ n.hasLogoSlot ? (c(), d("div", Da, [
1862
+ p(t.$slots, "logo")
1863
+ ])) : (c(), d("div", Ra, [
1864
+ o("a", Pa, [
1970
1865
  S(i, {
1971
- id: t.logo,
1972
- path: t.logopath,
1973
- desc: t.logotext,
1866
+ id: e.logo,
1867
+ path: e.logopath,
1868
+ desc: e.logotext,
1974
1869
  class: "pb-0"
1975
1870
  }, null, 8, ["id", "path", "desc"])
1976
1871
  ])
1977
1872
  ])),
1978
- Ds
1873
+ Ia
1979
1874
  ])
1980
1875
  ])
1981
1876
  ]),
1982
- a("div", Is, [
1983
- a("div", zs, [
1984
- a("div", Vs, [
1985
- s.hasLogoSlot ? (l(), c("div", Fs, [
1986
- b(e.$slots, "logo")
1987
- ])) : (l(), c("div", Os, [
1988
- a("a", js, [
1877
+ o("div", Fa, [
1878
+ o("div", Ba, [
1879
+ o("div", Va, [
1880
+ n.hasLogoSlot ? (c(), d("div", za, [
1881
+ p(t.$slots, "logo")
1882
+ ])) : (c(), d("div", Oa, [
1883
+ o("a", Wa, [
1989
1884
  S(i, {
1990
- id: t.logo,
1991
- path: t.logopath,
1992
- desc: t.logotext,
1885
+ id: e.logo,
1886
+ path: e.logopath,
1887
+ desc: e.logotext,
1993
1888
  class: "pb-0"
1994
1889
  }, null, 8, ["id", "path", "desc"])
1995
1890
  ])
1996
1891
  ])),
1997
- s.hasSearchSlot ? (l(), c("div", Rs, Ks)) : p("", !0),
1998
- Us,
1999
- a("div", Gs, [
2000
- b(e.$slots, "default")
1892
+ n.hasSearchSlot ? (c(), d("div", ja, Ka)) : _("", !0),
1893
+ Ga,
1894
+ o("div", Qa, [
1895
+ p(t.$slots, "default")
2001
1896
  ]),
2002
- s.hasAccountSlot ? (l(), c("div", Zs, Qs)) : p("", !0),
2003
- t.btnlink ? (l(), c("div", Ys, [
2004
- a("a", {
2005
- href: t.btnlink,
1897
+ n.hasAccountSlot ? (c(), d("div", Ya, Xa)) : _("", !0),
1898
+ e.btnlink ? (c(), d("div", Ja, [
1899
+ o("a", {
1900
+ href: e.btnlink,
2006
1901
  class: "btn me-0",
2007
- innerHTML: t.btntext
2008
- }, null, 8, Js)
2009
- ])) : p("", !0)
1902
+ innerHTML: e.btntext
1903
+ }, null, 8, es)
1904
+ ])) : _("", !0)
2010
1905
  ])
2011
1906
  ]),
2012
- s.hasSecondarySlot ? (l(), c("div", Xs, [
2013
- a("div", ea, [
2014
- b(e.$slots, "secondary")
1907
+ n.hasSecondarySlot ? (c(), d("div", ts, [
1908
+ o("div", as, [
1909
+ p(t.$slots, "secondary")
2015
1910
  ])
2016
- ])) : p("", !0),
2017
- s.hasSearchSlot ? (l(), c("div", ta, [
2018
- a("div", sa, [
2019
- a("div", aa, [
2020
- b(e.$slots, "search")
1911
+ ])) : _("", !0),
1912
+ n.hasSearchSlot ? (c(), d("div", ss, [
1913
+ o("div", is, [
1914
+ o("div", ls, [
1915
+ p(t.$slots, "search")
2021
1916
  ])
2022
1917
  ])
2023
- ])) : p("", !0)
1918
+ ])) : _("", !0)
2024
1919
  ]),
2025
- s.hasAccountSlot ? (l(), c("div", ia, [
2026
- a("div", na, [
2027
- a("div", ra, [
2028
- s.hasLogoSlot ? (l(), c("div", oa, [
2029
- b(e.$slots, "logo")
2030
- ])) : (l(), c("div", la, [
2031
- a("a", ca, [
1920
+ n.hasAccountSlot ? (c(), d("div", ns, [
1921
+ o("div", rs, [
1922
+ o("div", os, [
1923
+ n.hasLogoSlot ? (c(), d("div", cs, [
1924
+ p(t.$slots, "logo")
1925
+ ])) : (c(), d("div", ds, [
1926
+ o("a", us, [
2032
1927
  S(i, {
2033
- id: t.logo,
2034
- path: t.logopath,
2035
- desc: t.logotext,
1928
+ id: e.logo,
1929
+ path: e.logopath,
1930
+ desc: e.logotext,
2036
1931
  class: "pb-0"
2037
1932
  }, null, 8, ["id", "path", "desc"])
2038
1933
  ])
2039
1934
  ])),
2040
- da
1935
+ hs
2041
1936
  ])
2042
1937
  ]),
2043
- a("div", ua, [
2044
- b(e.$slots, "account")
1938
+ o("div", ms, [
1939
+ p(t.$slots, "account")
2045
1940
  ])
2046
- ])) : p("", !0),
2047
- fa
1941
+ ])) : _("", !0),
1942
+ fs
2048
1943
  ], 2);
2049
1944
  }
2050
- const bi = /* @__PURE__ */ g(qs, [["render", ha]]), ma = (e) => {
2051
- const r = e.querySelectorAll(".modal__outer a, .modal__outer button"), t = r[0], o = r[r.length - 1], f = e.getAttribute("id"), s = function() {
2052
- document.querySelector('[href="' + window.location.hash + '"]').focus(), window.location.hash = "close", history.replaceState("", document.title, window.location.pathname + window.location.search), typeof window.player < "u" && typeof window.player.pauseVideo == "function" && window.player.pauseVideo();
2053
- };
2054
- e.addEventListener("keydown", function(n) {
2055
- n.key === "Tab" && n.shiftKey && document.activeElement == t ? (n.preventDefault(), o.focus()) : n.key === "Tab" && !n.shiftKey && document.activeElement == o && (n.preventDefault(), t.focus());
2056
- }), document.addEventListener("keydown", function(n) {
2057
- n.key === "Escape" && document.querySelector(".modal:target") && s();
2058
- }), e.addEventListener("click", function(n) {
2059
- for (var h = n.target; h && h != this; h = h.parentNode)
2060
- if (h.matches('[href="#close"]')) {
2061
- n.preventDefault(), s();
2062
- break;
2063
- } else if (h.matches(".modal__dock--right")) {
2064
- n.preventDefault(), e.classList.contains("modal--left") || e.classList.add("modal--right"), e.classList.remove("modal--left");
2065
- break;
2066
- } else if (h.matches(".modal__dock--left")) {
2067
- n.preventDefault(), e.classList.contains("modal--right") || e.classList.add("modal--left"), e.classList.remove("modal--right");
2068
- break;
2069
- }
2070
- });
2071
- function i() {
2072
- if (location.hash === "#" + f) {
2073
- console.log("Modal is now open");
2074
- const n = document.querySelector(".modal:target .modal__inner > .youtube-embed:first-child:last-child a");
2075
- console.log(n), n && n.click();
2076
- }
2077
- }
2078
- window.onhashchange = i;
2079
- };
2080
- const _a = {
2081
- name: "Modal",
2082
- props: {
2083
- id: {
2084
- type: String,
2085
- required: !0
2086
- },
2087
- returnid: {
2088
- type: String,
2089
- default: "close",
2090
- required: !1
2091
- }
2092
- },
2093
- mounted() {
2094
- this.$nextTick(function() {
2095
- ma(this.$refs.modal);
2096
- });
2097
- }
2098
- }, ya = ["id"], pa = ["href"], ba = /* @__PURE__ */ a("span", { class: "visually-hidden" }, "Close", -1), va = [
2099
- ba
2100
- ], ga = { class: "modal__outer" }, Aa = ["href"], wa = /* @__PURE__ */ a("span", { class: "visually-hidden" }, "Close", -1), ka = { class: "modal__inner" }, Sa = /* @__PURE__ */ a("button", {
2101
- class: "modal__dock--left btn btn-prev",
2102
- tabindex: "-1"
2103
- }, "Left", -1), $a = /* @__PURE__ */ a("button", {
2104
- class: "modal__dock--right btn btn-next",
2105
- tabindex: "-1"
2106
- }, "Right", -1);
2107
- function qa(e, r, t, o, f, s) {
2108
- return l(), c("div", {
2109
- class: "modal",
2110
- id: t.id,
2111
- role: "dialog",
2112
- modal: "true",
2113
- ref: "modal"
2114
- }, [
2115
- a("a", {
2116
- href: `#${t.returnid ? t.returnid : ""}`,
2117
- tabindex: "-1"
2118
- }, va, 8, pa),
2119
- a("div", ga, [
2120
- a("a", {
2121
- href: `#${t.returnid ? t.returnid : ""}`,
2122
- class: "btn btn-tertiary py-1 px-2"
2123
- }, [
2124
- wa,
2125
- j("✕")
2126
- ], 8, Aa),
2127
- a("div", ka, [
2128
- b(e.$slots, "default")
2129
- ])
2130
- ]),
2131
- Sa,
2132
- $a
2133
- ], 8, ya);
2134
- }
2135
- const vi = /* @__PURE__ */ g(_a, [["render", qa]]);
2136
- const xa = {
1945
+ const bi = /* @__PURE__ */ A($a, [["render", ys]]);
1946
+ const bs = {
2137
1947
  name: "Stepper",
2138
1948
  props: {
2139
1949
  label: {
@@ -2146,25 +1956,25 @@ const xa = {
2146
1956
  default: "Complete"
2147
1957
  }
2148
1958
  }
2149
- }, La = { class: "container" }, Ta = ["aria-label"], Ma = {
1959
+ }, _s = { class: "container" }, ps = ["aria-label"], gs = {
2150
1960
  key: 0,
2151
1961
  class: "h6 stepper__start"
2152
- }, Ha = { class: "list-unstyled" }, Ca = { class: "h6 stepper__end" };
2153
- function Na(e, r, t, o, f, s) {
2154
- return l(), c("div", La, [
2155
- a("nav", {
1962
+ }, vs = { class: "list-unstyled" }, As = { class: "h6 stepper__end" };
1963
+ function ws(t, a, e, s, r, n) {
1964
+ return c(), d("div", _s, [
1965
+ o("nav", {
2156
1966
  class: "stepper",
2157
- "aria-label": t.label ? t.label : "Progress"
1967
+ "aria-label": e.label ? e.label : "Progress"
2158
1968
  }, [
2159
- t.label ? (l(), c("span", Ma, k(t.label), 1)) : p("", !0),
2160
- a("ol", Ha, [
2161
- b(e.$slots, "default")
1969
+ e.label ? (c(), d("span", gs, L(e.label), 1)) : _("", !0),
1970
+ o("ol", vs, [
1971
+ p(t.$slots, "default")
2162
1972
  ]),
2163
- a("span", Ca, k(t.endlabel), 1)
2164
- ], 8, Ta)
1973
+ o("span", As, L(e.endlabel), 1)
1974
+ ], 8, ps)
2165
1975
  ]);
2166
1976
  }
2167
- const gi = /* @__PURE__ */ g(xa, [["render", Na]]), Ba = {
1977
+ const _i = /* @__PURE__ */ A(bs, [["render", ws]]), Ss = {
2168
1978
  name: "Stepper",
2169
1979
  props: {
2170
1980
  url: {
@@ -2180,69 +1990,77 @@ const gi = /* @__PURE__ */ g(xa, [["render", Na]]), Ba = {
2180
1990
  required: !1
2181
1991
  }
2182
1992
  }
2183
- }, Pa = ["href", "aria-current"], Da = {
1993
+ }, Ls = ["href", "aria-current"], ks = {
2184
1994
  key: 0,
2185
1995
  class: "visually-hidden"
2186
1996
  };
2187
- function Ia(e, r, t, o, f, s) {
2188
- return l(), c("li", null, [
2189
- a("a", {
2190
- href: t.url,
2191
- class: v(`${t.status ? "bg-" + t.status : ""}${typeof t.current < "u" ? "current" : ""}`),
2192
- "aria-current": typeof t.current < "u"
1997
+ function qs(t, a, e, s, r, n) {
1998
+ return c(), d("li", null, [
1999
+ o("a", {
2000
+ href: e.url,
2001
+ class: v(`${e.status ? "bg-" + e.status : ""}${typeof e.current < "u" ? "current" : ""}`),
2002
+ "aria-current": typeof e.current < "u"
2193
2003
  }, [
2194
- a("span", null, [
2195
- b(e.$slots, "default")
2004
+ o("span", null, [
2005
+ p(t.$slots, "default")
2196
2006
  ]),
2197
- t.status ? (l(), c("em", Da, " - status: " + k(t.status), 1)) : p("", !0)
2198
- ], 10, Pa)
2007
+ e.status ? (c(), d("em", ks, " - status: " + L(e.status), 1)) : _("", !0)
2008
+ ], 10, Ls)
2199
2009
  ]);
2200
2010
  }
2201
- const Ai = /* @__PURE__ */ g(Ba, [["render", Ia]]), za = function(e) {
2202
- const r = e.querySelectorAll(":scope > details");
2203
- e.querySelectorAll(":scope > details > summary");
2204
- let t = e.querySelector(":scope > .tabs__links");
2205
- e.shadowRoot && e.shadowRoot.querySelector(".tabs__links") && (t = e.shadowRoot.querySelector(".tabs__links")), t || (t = document.createElement("div"), t.classList.add("tabs__links"), e.prepend(t)), r.forEach((o, f) => {
2206
- let s = o.querySelector(":scope > summary");
2207
- s.classList.add("visually-hidden");
2011
+ const pi = /* @__PURE__ */ A(Ss, [["render", qs]]), xs = function(t) {
2012
+ const a = t.querySelectorAll(":scope > details");
2013
+ t.querySelectorAll(":scope > details > summary");
2014
+ let e = t.querySelector(":scope > .tabs__links");
2015
+ t.shadowRoot && t.shadowRoot.querySelector(".tabs__links") && (e = t.shadowRoot.querySelector(".tabs__links")), e || (e = document.createElement("div"), e.classList.add("tabs__links"), t.prepend(e)), a.forEach((s, r) => {
2016
+ let n = s.querySelector(":scope > summary");
2017
+ n.classList.add("visually-hidden");
2208
2018
  let i = document.createElement("button");
2209
- o.hasAttribute("id") && (i = document.createElement("a"), i.setAttribute("href", `#${o.getAttribute("id")}`)), o.hasAttribute("open") && i.setAttribute("aria-pressed", !0), i.innerHTML = `${s.innerText}`, i.classList.add("link"), i.setAttribute("data-index", f), i.setAttribute("tabindex", "-1"), t.appendChild(i);
2019
+ s.hasAttribute("id") && (i = document.createElement("a"), i.setAttribute("href", `#${s.getAttribute("id")}`)), s.hasAttribute("open") && i.setAttribute("aria-pressed", !0), i.innerHTML = `${n.innerText}`, i.classList.add("link"), i.setAttribute("data-index", r), i.setAttribute("tabindex", "-1"), e.appendChild(i);
2210
2020
  });
2211
- }, Va = function(e) {
2212
- let r = e.querySelectorAll(":scope > details"), t = e.querySelectorAll(":scope > details > summary"), o = e.querySelectorAll(":scope > .tabs__links > button, .tabs__links > a");
2213
- e.shadowRoot && (o = e.shadowRoot.querySelectorAll(".tabs__links > button, .tabs__links > a")), o.forEach((f) => {
2214
- f.addEventListener("click", (s) => {
2215
- s.preventDefault(), o.forEach((i) => {
2216
- let n = i == f;
2217
- i.setAttribute("aria-pressed", n);
2218
- }), r.forEach((i, n) => {
2219
- let h = f.getAttribute("data-index") == n;
2021
+ }, $s = function(t) {
2022
+ let a = t.querySelectorAll(":scope > details"), e = t.querySelectorAll(":scope > details > summary"), s = t.querySelectorAll(":scope > .tabs__links > button, .tabs__links > a");
2023
+ t.shadowRoot && (s = t.shadowRoot.querySelectorAll(".tabs__links > button, .tabs__links > a")), s.forEach((r) => {
2024
+ r.addEventListener("click", (n) => {
2025
+ n.preventDefault(), s.forEach((i) => {
2026
+ let l = i == r;
2027
+ i.setAttribute("aria-pressed", l);
2028
+ }), a.forEach((i, l) => {
2029
+ let h = r.getAttribute("data-index") == l;
2220
2030
  h ? i.setAttribute("open", h) : i.removeAttribute("open");
2221
- }), f.hasAttribute("href") && history.pushState(void 0, void 0, f.getAttribute("href"));
2031
+ }), r.hasAttribute("href") && history.pushState(void 0, void 0, r.getAttribute("href")), window.dataLayer = window.dataLayer || [], window.dataLayer.push({
2032
+ event: "openTab",
2033
+ tabTitle: r.textContent
2034
+ });
2222
2035
  });
2223
- }), t.forEach((f, s) => {
2224
- f.addEventListener("focus", (i) => {
2225
- o.forEach((n) => {
2226
- n.classList.remove("focus");
2227
- }), o[s].classList.add("focus");
2228
- }), f.addEventListener("click", (i) => {
2229
- i.preventDefault(), o[s].click();
2036
+ }), e.forEach((r, n) => {
2037
+ r.addEventListener("focus", (i) => {
2038
+ s.forEach((l) => {
2039
+ l.classList.remove("focus");
2040
+ }), s[n].classList.add("focus");
2041
+ }), r.addEventListener("click", (i) => {
2042
+ i.preventDefault(), s[n].click();
2230
2043
  });
2231
2044
  });
2232
- }, Fa = function(e) {
2233
- let r = e.querySelectorAll(":scope > details"), t = e.querySelectorAll(":scope > .tabs__links > button, .tabs__links > a");
2234
- e.shadowRoot && (t = e.shadowRoot.querySelectorAll(".tabs__links > button, .tabs__links > a")), location.hash && e.querySelector(`.tabs__links [href="${location.hash}"]`) ? (e.querySelector(`[href="${location.hash}"]`).setAttribute("open", !0), e.querySelector(`details[id="${location.hash.replace("#", "")}"]`).setAttribute("open", !0)) : e.querySelector("details[open]") || (r[0].setAttribute("open", !0), t[0].setAttribute("aria-pressed", !0));
2235
- }, Oa = function(e) {
2236
- za(e), Va(e), Fa(e);
2045
+ }, Ts = function(t) {
2046
+ let a = t.querySelectorAll(":scope > details"), e = t.querySelectorAll(":scope > .tabs__links > button, .tabs__links > a");
2047
+ t.shadowRoot && (e = t.shadowRoot.querySelectorAll(".tabs__links > button, .tabs__links > a")), location.hash && t.querySelector(`.tabs__links [href="${location.hash}"]`) ? (t.querySelector(`[href="${location.hash}"]`).setAttribute("open", !0), t.querySelector(`details[id="${location.hash.replace("#", "")}"]`).setAttribute("open", !0)) : t.querySelector("details[open]") || (a[0].setAttribute("open", !0), e[0].setAttribute("aria-pressed", !0));
2048
+ }, Hs = function(t) {
2049
+ xs(t), $s(t), Ts(t);
2237
2050
  };
2238
- class ja extends HTMLElement {
2051
+ window.dataLayer = window.dataLayer || [];
2052
+ window.dataLayer.push({
2053
+ event: "customElementRegistered",
2054
+ element: "tabs"
2055
+ });
2056
+ class Cs extends HTMLElement {
2239
2057
  constructor() {
2240
2058
  super(), this.attachShadow({ mode: "open" });
2241
- const r = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", t = `@import "${r}/css/components/tabs.css";`, o = document.createElement("template");
2242
- o.innerHTML = `
2059
+ const a = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", e = `@import "${a}/css/components/tabs.css";`, s = document.createElement("template");
2060
+ s.innerHTML = `
2243
2061
  <style>
2244
- @import "${r}/css/core.min.css";
2245
- ${t}
2062
+ @import "${a}/css/core.min.css";
2063
+ ${e}
2246
2064
 
2247
2065
  ${this.hasAttribute("css") ? `@import "${this.getAttribute("css")}";` : ""}
2248
2066
  </style>
@@ -2250,22 +2068,22 @@ class ja extends HTMLElement {
2250
2068
  <div class="tabs__links"></div>
2251
2069
  <slot></slot>
2252
2070
  </div>
2253
- `, this.shadowRoot.appendChild(o.content.cloneNode(!0));
2071
+ `, this.shadowRoot.appendChild(s.content.cloneNode(!0));
2254
2072
  }
2255
2073
  connectedCallback() {
2256
- Oa(this);
2074
+ Hs(this);
2257
2075
  }
2258
2076
  }
2259
- window.customElements.get("iam-tabs") || window.customElements.define("iam-tabs", ja);
2260
- const Ra = {
2077
+ window.customElements.get("iam-tabs") || window.customElements.define("iam-tabs", Cs);
2078
+ const Ms = {
2261
2079
  name: "Tabs"
2262
- }, Wa = { ref: "wrapper" };
2263
- function Ka(e, r, t, o, f, s) {
2264
- return l(), c("iam-tabs", Wa, [
2265
- b(e.$slots, "default")
2080
+ }, Es = { ref: "wrapper" };
2081
+ function Ns(t, a, e, s, r, n) {
2082
+ return c(), d("iam-tabs", Es, [
2083
+ p(t.$slots, "default")
2266
2084
  ], 512);
2267
2085
  }
2268
- const wi = /* @__PURE__ */ g(Ra, [["render", Ka]]), Ua = {
2086
+ const gi = /* @__PURE__ */ A(Ms, [["render", Ns]]), Ds = {
2269
2087
  name: "Tab",
2270
2088
  props: {
2271
2089
  title: {
@@ -2283,44 +2101,44 @@ const wi = /* @__PURE__ */ g(Ra, [["render", Ka]]), Ua = {
2283
2101
  };
2284
2102
  },
2285
2103
  watch: {
2286
- show(e, r) {
2287
- console.log(e);
2104
+ show(t, a) {
2105
+ console.log(t);
2288
2106
  }
2289
2107
  }
2290
- }, Ga = { class: "tab" }, Za = ["innerHTML"];
2291
- function Ea(e, r, t, o, f, s) {
2292
- return l(), c("details", Ga, [
2293
- a("summary", { innerHTML: t.title }, null, 8, Za),
2294
- b(e.$slots, "default")
2108
+ }, Rs = { class: "tab" }, Ps = ["innerHTML"];
2109
+ function Is(t, a, e, s, r, n) {
2110
+ return c(), d("details", Rs, [
2111
+ o("summary", { innerHTML: e.title }, null, 8, Ps),
2112
+ p(t.$slots, "default")
2295
2113
  ]);
2296
2114
  }
2297
- const ki = /* @__PURE__ */ g(Ua, [["render", Ea]]);
2298
- function Qa(e) {
2299
- if (e.addEventListener("click", function(t) {
2300
- for (var o = t.target; o && o != this; o = o.parentNode)
2301
- if (o.matches(".btn-close")) {
2302
- t.preventDefault(), e.classList.remove("show"), setTimeout(function() {
2303
- e.remove();
2115
+ const vi = /* @__PURE__ */ A(Ds, [["render", Is]]);
2116
+ function Fs(t) {
2117
+ if (t.addEventListener("click", function(e) {
2118
+ for (var s = e.target; s && s != this; s = s.parentNode)
2119
+ if (s.matches(".btn-close")) {
2120
+ e.preventDefault(), t.classList.remove("show"), setTimeout(function() {
2121
+ t.remove();
2304
2122
  }, 300);
2305
2123
  break;
2306
2124
  }
2307
- }, !1), e.hasAttribute("data-timeout")) {
2308
- let t = e.getAttribute("data-timeout");
2125
+ }, !1), t.hasAttribute("data-timeout")) {
2126
+ let e = t.getAttribute("data-timeout");
2309
2127
  setTimeout(function() {
2310
- e.classList.remove("show"), setTimeout(function() {
2311
- e.remove();
2128
+ t.classList.remove("show"), setTimeout(function() {
2129
+ t.remove();
2312
2130
  }, 300);
2313
- }, t);
2131
+ }, e);
2314
2132
  }
2315
2133
  if (!document.querySelector(".alert__holder")) {
2316
2134
  document.getElementsByTagName("BODY")[0];
2317
- let t = document.createElement("div");
2318
- t.classList.add("alert__holder"), document.querySelector("main") ? document.querySelector("main").appendChild(t) : document.body.appendChild(t);
2135
+ let e = document.createElement("div");
2136
+ e.classList.add("alert__holder"), document.querySelector("main") ? document.querySelector("main").appendChild(e) : document.body.appendChild(e);
2319
2137
  }
2320
- let r = document.querySelector(".alert__holder");
2321
- e.classList.contains("alert--fixed") && !e.parentNode.classList.contains("alert__wrapper") && r.appendChild(e);
2138
+ let a = document.querySelector(".alert__holder");
2139
+ t.classList.contains("alert--fixed") && !t.parentNode.classList.contains("alert__wrapper") && a.appendChild(t);
2322
2140
  }
2323
- const Ya = {
2141
+ const Bs = {
2324
2142
  name: "Alert",
2325
2143
  props: {
2326
2144
  dismissible: {
@@ -2339,38 +2157,38 @@ const Ya = {
2339
2157
  }
2340
2158
  },
2341
2159
  mounted() {
2342
- Qa(this.$refs.wrapper);
2160
+ Fs(this.$refs.wrapper);
2343
2161
  }
2344
- }, Ja = ["data-timeout"], Xa = {
2162
+ }, Vs = ["data-timeout"], zs = {
2345
2163
  key: 0,
2346
2164
  type: "button",
2347
2165
  class: "btn-close",
2348
2166
  "data-bs-dismiss": "alert",
2349
2167
  "aria-label": "Close"
2350
2168
  };
2351
- function ei(e, r, t, o, f, s) {
2352
- return l(), c("div", {
2353
- class: v(`container alert pb-0 ${t.dismissible ? "alert--dismissible fade show" : ""}`),
2169
+ function Os(t, a, e, s, r, n) {
2170
+ return c(), d("div", {
2171
+ class: v(`container alert pb-0 ${e.dismissible ? "alert--dismissible fade show" : ""}`),
2354
2172
  ref: "wrapper",
2355
- "data-timeout": t.timeout,
2356
- style: te(t.timeout ? `--animation-length: ${t.timeout}ms` : "")
2173
+ "data-timeout": e.timeout,
2174
+ style: ne(e.timeout ? `--animation-length: ${e.timeout}ms` : "")
2357
2175
  }, [
2358
- a("div", {
2359
- class: v(`alert__inner bg-${t.colour}`),
2176
+ o("div", {
2177
+ class: v(`alert__inner bg-${e.colour}`),
2360
2178
  role: "alert"
2361
2179
  }, [
2362
- t.dismissible ? (l(), c("button", Xa)) : p("", !0),
2363
- b(e.$slots, "default")
2180
+ e.dismissible ? (c(), d("button", zs)) : _("", !0),
2181
+ p(t.$slots, "default")
2364
2182
  ], 2)
2365
- ], 14, Ja);
2183
+ ], 14, Vs);
2366
2184
  }
2367
- const Si = /* @__PURE__ */ g(Ya, [["render", ei]]);
2368
- let Y = E.props;
2369
- Y.fields.required = !1;
2370
- const ti = {
2185
+ const Ai = /* @__PURE__ */ A(Bs, [["render", Os]]);
2186
+ let te = ee.props;
2187
+ te.fields.required = !1;
2188
+ const Ws = {
2371
2189
  components: {
2372
- Table: E,
2373
- Input: D
2190
+ Table: ee,
2191
+ Input: R
2374
2192
  },
2375
2193
  data() {
2376
2194
  return {
@@ -2379,17 +2197,17 @@ const ti = {
2379
2197
  };
2380
2198
  },
2381
2199
  methods: {
2382
- submitForm: function(e) {
2200
+ submitForm: function(t) {
2383
2201
  console.log(this);
2384
- const r = new FormData(e.target);
2385
- let t = /* @__PURE__ */ new Date();
2386
- const o = t.getFullYear();
2387
- let f = t.getMonth() + 1, s = t.getDate();
2388
- s < 10 && (s = "0" + s), f < 10 && (f = "0" + f), t = s + "/" + f + "/" + o, this.itemsData.unshift({
2389
- date_added: t,
2390
- user: r.get("user"),
2391
- note: r.get("addNote")
2392
- }), this.$emit("formSubmitted", e);
2202
+ const a = new FormData(t.target);
2203
+ let e = /* @__PURE__ */ new Date();
2204
+ const s = e.getFullYear();
2205
+ let r = e.getMonth() + 1, n = e.getDate();
2206
+ n < 10 && (n = "0" + n), r < 10 && (r = "0" + r), e = n + "/" + r + "/" + s, this.itemsData.unshift({
2207
+ date_added: e,
2208
+ user: a.get("user"),
2209
+ note: a.get("addNote")
2210
+ }), this.$emit("formSubmitted", t);
2393
2211
  }
2394
2212
  },
2395
2213
  name: "NoteFeed",
@@ -2398,7 +2216,7 @@ const ti = {
2398
2216
  type: String,
2399
2217
  required: !0
2400
2218
  },
2401
- ...Y,
2219
+ ...te,
2402
2220
  title: {
2403
2221
  type: String,
2404
2222
  required: !1
@@ -2413,62 +2231,216 @@ const ti = {
2413
2231
  required: !1
2414
2232
  }
2415
2233
  }
2416
- }, si = { class: "container note-feed mb-2" }, ai = ["innerHTML"], ii = ["action", "method"], ni = ["value"], ri = /* @__PURE__ */ a("button", { class: "btn btn-tertiary" }, "Submit note", -1);
2417
- function oi(e, r, t, o, f, s) {
2418
- const i = H("Table"), n = H("Input");
2419
- return l(), c("div", si, [
2420
- t.title ? (l(), c("span", {
2234
+ }, js = { class: "container note-feed mb-2" }, Us = ["innerHTML"], Ks = ["action", "method"], Gs = ["value"], Qs = /* @__PURE__ */ o("button", { class: "btn btn-tertiary" }, "Submit note", -1);
2235
+ function Ys(t, a, e, s, r, n) {
2236
+ const i = E("Table"), l = E("Input");
2237
+ return c(), d("div", js, [
2238
+ e.title ? (c(), d("span", {
2421
2239
  key: 0,
2422
2240
  class: "h3",
2423
- innerHTML: t.title
2424
- }, null, 8, ai)) : p("", !0),
2425
- S(i, T({
2241
+ innerHTML: e.title
2242
+ }, null, 8, Us)) : _("", !0),
2243
+ S(i, H({
2426
2244
  fields: [{ key: "date_added" }, { key: "user" }, { key: "note" }],
2427
- items: f.itemsData
2428
- }, e.$props, { class: "mb-0" }), null, 16, ["items"]),
2429
- a("form", {
2430
- action: t.action,
2431
- method: t.method,
2432
- onSubmit: r[0] || (r[0] = se((h) => s.submitForm(...arguments), ["prevent"]))
2245
+ items: r.itemsData
2246
+ }, t.$props, { class: "mb-0" }), null, 16, ["items"]),
2247
+ o("form", {
2248
+ action: e.action,
2249
+ method: e.method,
2250
+ onSubmit: a[0] || (a[0] = re((h) => n.submitForm(...arguments), ["prevent"]))
2433
2251
  }, [
2434
- a("input", {
2252
+ o("input", {
2435
2253
  type: "hidden",
2436
- value: t.user,
2254
+ value: e.user,
2437
2255
  name: "user"
2438
- }, null, 8, ni),
2439
- S(n, {
2256
+ }, null, 8, Gs),
2257
+ S(l, {
2440
2258
  id: "addNote",
2441
2259
  type: "textarea",
2442
2260
  label: "Add note",
2443
2261
  required: "",
2444
2262
  class: "mw-100"
2445
2263
  }),
2446
- ri
2447
- ], 40, ii)
2264
+ Qs
2265
+ ], 40, Ks)
2266
+ ]);
2267
+ }
2268
+ const wi = /* @__PURE__ */ A(Ws, [["render", Ys]]);
2269
+ function Zs(t, a) {
2270
+ function e(s, r) {
2271
+ let n = !1, i = r.getAttribute("name");
2272
+ i.includes("[]") && (i = i.replace("[]", `[${r.value}]`));
2273
+ let l = s.querySelector(`[data-name="${i}"]`);
2274
+ l && r.getAttribute("type") == "checkbox" && (n = !0);
2275
+ let h = r.getAttribute("data-filter-text");
2276
+ if (l || (l = document.createElement("button"), s.appendChild(l)), l.setAttribute("type", "button"), l.classList.add("filter"), l.setAttribute("data-name", i), l.innerHTML = h.replace("$value", r.value), (!r.value || n) && l.remove(), r.parentNode.closest("[data-filter-text]")) {
2277
+ let u = r.parentNode.closest("[data-filter-text]"), m = !0;
2278
+ if (i = "", u.querySelectorAll("input").forEach((f, b) => {
2279
+ let g = f.getAttribute("name");
2280
+ if (i += `${b != 0 ? "," : ""}${g}`, s.querySelector(`[data-name="${g}"]`) && s.querySelector(`[data-name="${g}"]`).remove(), f.value) {
2281
+ let y = document.createElement("button");
2282
+ y.setAttribute("type", "button"), y.classList.add("filter"), y.setAttribute("data-name", g), y.innerHTML = h.replace("$value", f.value), s.appendChild(y);
2283
+ } else
2284
+ m = !1;
2285
+ }), s.querySelector(`[data-name="${i}"]`) && s.querySelector(`[data-name="${i}"]`).remove(), m) {
2286
+ let f = u.getAttribute("data-filter-text");
2287
+ u.querySelectorAll("input").forEach((g, y) => {
2288
+ let C = g.getAttribute("name");
2289
+ s.querySelector(`[data-name="${C}"]`) && s.querySelector(`[data-name="${C}"]`).remove(), f = f.replace(`$${y + 1}`, g.value);
2290
+ });
2291
+ let b = document.createElement("button");
2292
+ b.setAttribute("type", "button"), b.classList.add("filter"), b.setAttribute("data-name", i), b.innerHTML = f, s.appendChild(b);
2293
+ }
2294
+ }
2295
+ }
2296
+ Array.from(t.querySelectorAll('input[type="checkbox"]:checked')).forEach((s, r) => {
2297
+ e(a, s);
2298
+ }), t.addEventListener("change", function(s) {
2299
+ if (s && s.target instanceof HTMLElement && s.target.closest("input[data-filter-text]")) {
2300
+ let r = s.target.closest("input[data-filter-text]");
2301
+ e(a, r);
2302
+ }
2303
+ }, !1), a.addEventListener("click", function(s) {
2304
+ if (s && s.target instanceof HTMLElement && s.target.closest(".filter")) {
2305
+ let i = s.target.closest(".filter"), l = i.getAttribute("data-name").split(",");
2306
+ for (var r = 0; r < l.length; r++) {
2307
+ let h = l[r], u = `[name="${h}"]`;
2308
+ if (h.match(/\[(.*)\]/)) {
2309
+ let f = h.replace(/\[(.*)\]/, "[]"), b = h.replace(/.*\[(.*)\]/, "$1");
2310
+ u = `[name="${f}"][value="${b}"]`;
2311
+ }
2312
+ let m = t.querySelectorAll(u);
2313
+ for (var n = 0; n < m.length; n++) {
2314
+ let f = m[n];
2315
+ f.getAttribute("type") != "radio" && f.getAttribute("type") != "checkbox" && (m[n].value = ""), m[n].checked = !1;
2316
+ }
2317
+ }
2318
+ i.remove();
2319
+ }
2320
+ }, !1);
2321
+ }
2322
+ const ae = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", Xs = `@import "${ae}/css/components/applied-filters.css";`;
2323
+ class Js extends HTMLElement {
2324
+ constructor() {
2325
+ super(), this.attachShadow({ mode: "open" });
2326
+ let a = this.classList.toString();
2327
+ const e = document.createElement("template");
2328
+ e.innerHTML = `
2329
+ <style>
2330
+ @import "${ae}/css/core.min.css";
2331
+ ${Xs}
2332
+ ${this.hasAttribute("css") ? `@import "${this.getAttribute("css")}";` : ""}
2333
+ </style>
2334
+ <div class="applied-filters ${a}"></div>
2335
+ <slot></slot>
2336
+ `, this.shadowRoot.appendChild(e.content.cloneNode(!0));
2337
+ }
2338
+ connectedCallback() {
2339
+ Zs(this, this.shadowRoot.querySelector(".applied-filters"));
2340
+ }
2341
+ }
2342
+ window.customElements.get("iam-applied-filters") || window.customElements.define("iam-applied-filters", Js);
2343
+ const ei = {
2344
+ name: "Header"
2345
+ };
2346
+ function ti(t, a, e, s, r, n) {
2347
+ return c(), d("iam-applied-filters", null, [
2348
+ p(t.$slots, "default")
2349
+ ]);
2350
+ }
2351
+ const Si = /* @__PURE__ */ A(ei, [["render", ti]]);
2352
+ function ai(t, a) {
2353
+ si(t, a);
2354
+ }
2355
+ function si(t, a) {
2356
+ var e;
2357
+ a.addEventListener("keyup", (s) => {
2358
+ clearTimeout(e), e = setTimeout(function() {
2359
+ K(t, a.value);
2360
+ }, 500);
2361
+ }), a.addEventListener("change", (s) => {
2362
+ clearTimeout(e), K(t, a.value);
2363
+ });
2364
+ }
2365
+ const K = function(t, a) {
2366
+ Array.from(t.querySelectorAll(":scope > li")).forEach((e, s) => {
2367
+ let r = e.textContent.toLowerCase();
2368
+ e.classList.add("d-none"), r.includes(a.toLowerCase()) && e.classList.remove("d-none");
2369
+ }), window.dataLayer = window.dataLayer || [], window.dataLayer.push({
2370
+ event: "Filtered list",
2371
+ value: a
2372
+ });
2373
+ };
2374
+ window.dataLayer = window.dataLayer || [];
2375
+ window.dataLayer.push({
2376
+ event: "customElementRegistered",
2377
+ element: "filterlist"
2378
+ });
2379
+ class ii extends HTMLElement {
2380
+ constructor() {
2381
+ super(), this.attachShadow({ mode: "open" });
2382
+ const a = document.body.hasAttribute("data-assets-location") ? document.body.getAttribute("data-assets-location") : "/assets", e = document.createElement("template");
2383
+ e.innerHTML = `
2384
+ <style>
2385
+ @import "${a}/css/core.min.css";
2386
+ ${this.hasAttribute("css") ? `@import "${this.getAttribute("css")}";` : ""}
2387
+
2388
+ :host {
2389
+ margin-bottom: 3rem;
2390
+ display:block;
2391
+ }
2392
+ </style>
2393
+ <div class="form-control__wrapper">
2394
+ <label for="search" class="visually-hidden">Search</label>
2395
+ <span class="suffix" role="presentation"><slot name="icon"></slot></span>
2396
+ <input name="search" id="search" type="text" class="form-control" autocomplete="off">
2397
+ </div>
2398
+ <div class="list__wrapper">
2399
+ <slot></slot>
2400
+ </div>
2401
+ `, this.shadowRoot.appendChild(e.content.cloneNode(!0));
2402
+ }
2403
+ connectedCallback() {
2404
+ const a = {
2405
+ small: "12.5rem",
2406
+ medium: "25rem",
2407
+ large: "37.5rem"
2408
+ };
2409
+ let e = this.hasAttribute("data-max-height") && a[this.getAttribute("data-max-height")] ? "list__wrapper--" + this.getAttribute("data-max-height") : "";
2410
+ this.shadowRoot.querySelector(".list__wrapper").classList.add(e), this.querySelector("i.fa-search") || (this.innerHTML += '<i class="fa fa-light fa-search" aria-hidden="true" slot="icon"></i>'), ai(this.querySelector("ul"), this.shadowRoot.querySelector("#search"));
2411
+ }
2412
+ }
2413
+ window.customElements.get("iam-filterlist") || window.customElements.define("iam-filterlist", ii);
2414
+ const li = {
2415
+ name: "Filter list"
2416
+ };
2417
+ function ni(t, a, e, s, r, n) {
2418
+ return c(), d("iam-filterlist", null, [
2419
+ p(t.$slots, "default")
2448
2420
  ]);
2449
2421
  }
2450
- const $i = /* @__PURE__ */ g(ti, [["render", oi]]);
2422
+ const Li = /* @__PURE__ */ A(li, [["render", ni]]);
2451
2423
  export {
2452
- ui as Accordion,
2453
- fi as AccordionItem,
2454
- Si as Alert,
2455
- hi as Banner,
2456
- Q as Card,
2457
- Ct as CardDeck,
2458
- mi as Carousel,
2459
- di as FileUploads,
2460
- _i as Header,
2461
- oe as Icon,
2462
- D as Input,
2463
- fe as Logo,
2464
- vi as Modal,
2424
+ ci as Accordion,
2425
+ di as AccordionItem,
2426
+ Ai as Alert,
2427
+ Si as AppliedFilters,
2428
+ ui as Banner,
2429
+ Nt as Card,
2430
+ hi as Carousel,
2431
+ oi as FileUploads,
2432
+ Li as Filterlist,
2433
+ mi as Header,
2434
+ he as Icon,
2435
+ R as Input,
2436
+ _e as Logo,
2465
2437
  bi as Nav,
2466
- $i as NoteFeed,
2467
- pi as PropertySearchbar,
2468
- Ai as Step,
2469
- gi as Stepper,
2470
- ki as Tab,
2471
- E as Table,
2472
- wi as Tabs,
2473
- yi as Testimonial
2438
+ wi as NoteFeed,
2439
+ yi as PropertySearchbar,
2440
+ pi as Step,
2441
+ _i as Stepper,
2442
+ vi as Tab,
2443
+ ee as Table,
2444
+ gi as Tabs,
2445
+ fi as Testimonial
2474
2446
  };