@iamproperty/components 7.7.0 → 7.7.1--beta1

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 (215) hide show
  1. package/assets/css/components/actionbar.component.css +1 -1
  2. package/assets/css/components/actionbar.component.css.map +1 -1
  3. package/assets/css/components/address-lookup.component.css +1 -1
  4. package/assets/css/components/address-lookup.component.css.map +1 -1
  5. package/assets/css/components/barchart.component.css +1 -1
  6. package/assets/css/components/barchart.component.css.map +1 -1
  7. package/assets/css/components/calendar.component.css +1 -1
  8. package/assets/css/components/calendar.component.css.map +1 -1
  9. package/assets/css/components/card.component.css +1 -1
  10. package/assets/css/components/card.component.css.map +1 -1
  11. package/assets/css/components/carousel.component.css +1 -1
  12. package/assets/css/components/carousel.component.css.map +1 -1
  13. package/assets/css/components/collapsible-side.css +1 -1
  14. package/assets/css/components/collapsible-side.css.map +1 -1
  15. package/assets/css/components/config.component.css +1 -1
  16. package/assets/css/components/config.component.css.map +1 -1
  17. package/assets/css/components/content.component.css +1 -1
  18. package/assets/css/components/content.component.css.map +1 -1
  19. package/assets/css/components/doughnutchart.component.css +1 -1
  20. package/assets/css/components/doughnutchart.component.css.map +1 -1
  21. package/assets/css/components/fileupload.css +1 -1
  22. package/assets/css/components/fileupload.css.map +1 -1
  23. package/assets/css/components/header.css +1 -1
  24. package/assets/css/components/header.css.map +1 -1
  25. package/assets/css/components/input.component.css +1 -1
  26. package/assets/css/components/input.component.css.map +1 -1
  27. package/assets/css/components/modal.component.css +1 -1
  28. package/assets/css/components/modal.component.css.map +1 -1
  29. package/assets/css/components/multi-step-modal.component.css +1 -1
  30. package/assets/css/components/multi-step-modal.component.css.map +1 -1
  31. package/assets/css/components/multiselect.css +1 -1
  32. package/assets/css/components/multiselect.css.map +1 -1
  33. package/assets/css/components/nav.component.css +1 -1
  34. package/assets/css/components/nav.component.css.map +1 -1
  35. package/assets/css/components/nav.global.css +1 -1
  36. package/assets/css/components/pagination.css +1 -1
  37. package/assets/css/components/pagination.css.map +1 -1
  38. package/assets/css/components/record-card.component.css +1 -1
  39. package/assets/css/components/record-card.component.css.map +1 -1
  40. package/assets/css/components/split-button.component.css +1 -1
  41. package/assets/css/components/split-button.component.css.map +1 -1
  42. package/assets/css/components/table-basic.global.css +1 -1
  43. package/assets/css/components/table-basic.global.css.map +1 -1
  44. package/assets/css/components/table.global.css +1 -1
  45. package/assets/css/components/table.global.css.map +1 -1
  46. package/assets/css/components/tabs.component.css +1 -1
  47. package/assets/css/components/tabs.component.css.map +1 -1
  48. package/assets/css/components/tag.component.css +1 -1
  49. package/assets/css/components/tag.component.css.map +1 -1
  50. package/assets/css/components/video-modal.component.css +1 -1
  51. package/assets/css/components/video-modal.component.css.map +1 -1
  52. package/assets/css/core.min.css +1 -1
  53. package/assets/css/core.min.css.map +1 -1
  54. package/assets/css/elements/admin-panel.css +1 -0
  55. package/assets/css/elements/admin-panel.css.map +1 -0
  56. package/assets/css/elements/badge-tag.css +1 -0
  57. package/assets/css/elements/badge-tag.css.map +1 -0
  58. package/assets/css/elements/brand.css +1 -0
  59. package/assets/css/elements/brand.css.map +1 -0
  60. package/assets/css/elements/button__group.css +1 -0
  61. package/assets/css/elements/button__group.css.map +1 -0
  62. package/assets/css/elements/buttons--action.css +1 -0
  63. package/assets/css/elements/buttons--action.css.map +1 -0
  64. package/assets/css/elements/buttons--compact.css +1 -0
  65. package/assets/css/elements/buttons--compact.css.map +1 -0
  66. package/assets/css/elements/buttons--global.css +1 -0
  67. package/assets/css/elements/buttons--global.css.map +1 -0
  68. package/assets/css/elements/buttons--secondary.css +1 -0
  69. package/assets/css/elements/buttons--secondary.css.map +1 -0
  70. package/assets/css/elements/buttons--special.css +1 -0
  71. package/assets/css/elements/buttons--special.css.map +1 -0
  72. package/assets/css/elements/buttons--tertiary.css +1 -0
  73. package/assets/css/elements/buttons--tertiary.css.map +1 -0
  74. package/assets/css/elements/buttons.css +1 -0
  75. package/assets/css/elements/buttons.css.map +1 -0
  76. package/assets/css/elements/code.css +1 -0
  77. package/assets/css/elements/code.css.map +1 -0
  78. package/assets/css/elements/container.css +1 -0
  79. package/assets/css/elements/container.css.map +1 -0
  80. package/assets/css/elements/details.css +1 -0
  81. package/assets/css/elements/details.css.map +1 -0
  82. package/assets/css/elements/dialog.css +1 -0
  83. package/assets/css/elements/dialog.css.map +1 -0
  84. package/assets/css/elements/dropdown.css +1 -0
  85. package/assets/css/elements/dropdown.css.map +1 -0
  86. package/assets/css/elements/feature.css +1 -0
  87. package/assets/css/elements/feature.css.map +1 -0
  88. package/assets/css/elements/forms.css +1 -0
  89. package/assets/css/elements/forms.css.map +1 -0
  90. package/assets/css/elements/highlight.css +1 -0
  91. package/assets/css/elements/highlight.css.map +1 -0
  92. package/assets/css/elements/hr.css +1 -0
  93. package/assets/css/elements/hr.css.map +1 -0
  94. package/assets/css/elements/icons.css +1 -0
  95. package/assets/css/elements/icons.css.map +1 -0
  96. package/assets/css/elements/input.css +1 -0
  97. package/assets/css/elements/input.css.map +1 -0
  98. package/assets/css/elements/label.css +1 -0
  99. package/assets/css/elements/label.css.map +1 -0
  100. package/assets/css/elements/links.css +1 -0
  101. package/assets/css/elements/links.css.map +1 -0
  102. package/assets/css/elements/lists--breadcrumbs.css +1 -0
  103. package/assets/css/elements/lists--breadcrumbs.css.map +1 -0
  104. package/assets/css/elements/lists--steps.css +1 -0
  105. package/assets/css/elements/lists--steps.css.map +1 -0
  106. package/assets/css/elements/lists--tick-list.css +1 -0
  107. package/assets/css/elements/lists--tick-list.css.map +1 -0
  108. package/assets/css/elements/lists.css +1 -0
  109. package/assets/css/elements/lists.css.map +1 -0
  110. package/assets/css/elements/media.css +1 -0
  111. package/assets/css/elements/media.css.map +1 -0
  112. package/assets/css/elements/modal.css +1 -0
  113. package/assets/css/elements/modal.css.map +1 -0
  114. package/assets/css/elements/popover.css +1 -0
  115. package/assets/css/elements/popover.css.map +1 -0
  116. package/assets/css/elements/prefix.css +1 -0
  117. package/assets/css/elements/prefix.css.map +1 -0
  118. package/assets/css/elements/progress.css +1 -0
  119. package/assets/css/elements/progress.css.map +1 -0
  120. package/assets/css/elements/table.element.css +1 -0
  121. package/assets/css/elements/table.element.css.map +1 -0
  122. package/assets/css/elements/textarea.css +1 -0
  123. package/assets/css/elements/textarea.css.map +1 -0
  124. package/assets/css/elements/toggle-button.css +1 -0
  125. package/assets/css/elements/toggle-button.css.map +1 -0
  126. package/assets/css/elements/tooltips.css +1 -0
  127. package/assets/css/elements/tooltips.css.map +1 -0
  128. package/assets/css/elements/type.css +1 -0
  129. package/assets/css/elements/type.css.map +1 -0
  130. package/assets/css/style.min.css +1 -1
  131. package/assets/css/style.min.css.map +1 -1
  132. package/assets/img/logos/ee.png +0 -0
  133. package/assets/img/logos/o2.png +0 -0
  134. package/assets/img/logos/three.png +0 -0
  135. package/assets/img/logos/vodaphone.png +0 -0
  136. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  137. package/assets/js/components/actionbar/actionbar.component.min.js +2 -2
  138. package/assets/js/components/address-lookup/address-lookup.component.min.js +2 -2
  139. package/assets/js/components/advanced-select/advanced-select.component.js +17 -0
  140. package/assets/js/components/advanced-select/advanced-select.component.min.js +3 -3
  141. package/assets/js/components/advanced-select/advanced-select.component.min.js.map +1 -1
  142. package/assets/js/components/applied-filters/applied-filters.component.min.js +1 -1
  143. package/assets/js/components/barchart/barchart.component.min.js +2 -2
  144. package/assets/js/components/bento-grid/bento-grid.component.min.js +1 -1
  145. package/assets/js/components/calendar/calendar.component.min.js +2 -2
  146. package/assets/js/components/card/card.component.min.js +2 -2
  147. package/assets/js/components/carousel/carousel.component.min.js +2 -2
  148. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +2 -2
  149. package/assets/js/components/config/config.component.min.js +3 -3
  150. package/assets/js/components/content/content.component.min.js +2 -2
  151. package/assets/js/components/darkmode/darkmode.component.min.js +1 -1
  152. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +2 -2
  153. package/assets/js/components/fileupload/fileupload.component.min.js +2 -2
  154. package/assets/js/components/filter-card/filter-card.component.min.js +1 -1
  155. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  156. package/assets/js/components/form/form.component.min.js +1 -1
  157. package/assets/js/components/header/header.component.js +42 -33
  158. package/assets/js/components/header/header.component.min.js +41 -36
  159. package/assets/js/components/header/header.component.min.js.map +1 -1
  160. package/assets/js/components/inline-edit/inline-edit.component.min.js +1 -1
  161. package/assets/js/components/input/input.component.min.js +2 -2
  162. package/assets/js/components/input-range/input-range.component.min.js +1 -1
  163. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  164. package/assets/js/components/menu/menu.component.min.js +1 -1
  165. package/assets/js/components/milestone/milestone.component.min.js +1 -1
  166. package/assets/js/components/milestone-group/milestone-group.component.min.js +1 -1
  167. package/assets/js/components/modal/modal.component.js +1 -1
  168. package/assets/js/components/modal/modal.component.min.js +4 -4
  169. package/assets/js/components/modal/modal.component.min.js.map +1 -1
  170. package/assets/js/components/multi-step/multi-step.component.min.js +1 -1
  171. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js +2 -2
  172. package/assets/js/components/multiselect/multiselect.component.min.js +4 -4
  173. package/assets/js/components/nav/nav.component.min.js +3 -3
  174. package/assets/js/components/notification/notification.component.min.js +1 -1
  175. package/assets/js/components/pagination/pagination.component.min.js +2 -2
  176. package/assets/js/components/password/password.component.min.js +1 -1
  177. package/assets/js/components/popover/popover.component.min.js +1 -1
  178. package/assets/js/components/rank/rank.component.min.js +1 -1
  179. package/assets/js/components/rankings/rankings.component.min.js +1 -1
  180. package/assets/js/components/rating/rating.component.min.js +1 -1
  181. package/assets/js/components/record-card/record-card.component.min.js +2 -2
  182. package/assets/js/components/search/search.component.min.js +1 -1
  183. package/assets/js/components/slider/slider.component.min.js +1 -1
  184. package/assets/js/components/split-button/split-button.component.min.js +2 -2
  185. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js +2 -2
  186. package/assets/js/components/table/table.component.min.js +2 -2
  187. package/assets/js/components/table-ajax/table-ajax.component.min.js +2 -2
  188. package/assets/js/components/table-basic/table-basic.component.min.js +2 -2
  189. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +2 -2
  190. package/assets/js/components/table-submit/table-submit.component.min.js +2 -2
  191. package/assets/js/components/tabs/tabs.component.min.js +2 -2
  192. package/assets/js/components/tag/tag.component.min.js +4 -4
  193. package/assets/js/components/tag/tag.component.min.js.map +1 -1
  194. package/assets/js/components/tooltip/tooltip.component.min.js +1 -1
  195. package/assets/js/components/video-card/video-card.component.min.js +1 -1
  196. package/assets/js/components/video-modal/video-modal.component.min.js +2 -2
  197. package/assets/js/components/word-count/word-count.component.min.js +1 -1
  198. package/assets/js/scripts.bundle.js +1 -1
  199. package/assets/js/scripts.bundle.min.js +1 -1
  200. package/assets/sass/_grid.scss +12 -1
  201. package/assets/sass/components/header.scss +72 -8
  202. package/assets/sass/components/modal.component.scss +2 -2
  203. package/assets/sass/elements/admin-panel.css +37 -0
  204. package/assets/sass/elements/buttons--compact.css +1 -1
  205. package/assets/sass/elements/buttons--global.scss +0 -1
  206. package/assets/sass/elements/lists--tick-list.scss +38 -19
  207. package/assets/sass/foundations/root.scss +1 -0
  208. package/assets/sass/utilities/position.scss +22 -60
  209. package/assets/ts/components/advanced-select/advanced-select.component.ts +24 -4
  210. package/assets/ts/components/header/header.component.ts +44 -33
  211. package/assets/ts/components/modal/modal.component.ts +1 -1
  212. package/dist/components.es.js +89 -89
  213. package/dist/components.umd.js +167 -327
  214. package/package.json +2 -3
  215. package/src/components/AdvancedSelect/AdvancedSelect.vue +9 -2
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * iamKey v7.7.0
2
+ * iamKey v7.7.1--beta1
3
3
  * Copyright 2022-2026 iamproperty
4
4
  */(function(w){typeof define=="function"&&define.amd?define(w):w()})((function(){"use strict";var w=a=>{a.classList.add("js-enabled"),(navigator.userAgent.indexOf("MSIE")!==-1||navigator.appVersion.indexOf("Trident/")>0)&&a.classList.add("ie")},H=a=>{var e=function(n){var r=document.querySelector('label[for="'.concat(n.replace("#",""),'"]')),s=document.querySelector(n+" summary"),u=document.querySelector("dialog".concat(n)),i=document.querySelector("detail".concat(n));r instanceof HTMLElement?r.click():s instanceof HTMLElement?s.click():u instanceof HTMLElement?u.showModal():i instanceof HTMLElement&&i.addAttribute("open")};location.hash&&e(location.hash),window.addEventListener("hashchange",function(){e(location.hash)},!1),addEventListener("popstate",o=>{if(o&&o.state&&o.state.type&&o.state.type=="pagination"){var n=document.querySelector("#".concat(o.state.form)),r=document.querySelector("#".concat(o.state.form," [data-pagination]"));r?r.value=o.state.page:n.innerHTML+='<input name="page" type="hidden" data-pagination="true" value="'.concat(o.state.page,'" />'),n.dispatchEvent(new Event("submit"))}}),Array.from(document.querySelectorAll("form")).forEach(o=>{o?.closest("iam-form")||o.addEventListener("submit",n=>{var r;o.querySelector(":invalid")&&(o.classList.add("was-validated"),(r=o?.querySelector("input:invalid"))===null||r===void 0||r.scrollIntoView(),n.preventDefault())})}),document.addEventListener("click",o=>{var n;if(o&&o.target instanceof HTMLElement&&o.target.matches("form button:not([type=button])")){var r=o.target.closest("form");r?.closest("iam-form")||(Array.from(r.querySelectorAll("[data-password-type]")).forEach(s=>{s.setAttribute("type","password")}),(r.querySelector(":invalid")||r.querySelector('.pwd-checker[data-strength="1"]')||r.querySelector('.pwd-checker[data-strength="2"]'))&&(r.classList.add("was-validated"),(n=r?.querySelector("input:invalid"))===null||n===void 0||n.scrollIntoView(),o.preventDefault()),r.querySelector("iam-multiselect[data-is-required][data-error]")&&(r.classList.add("was-validated"),o.preventDefault()))}}),document.addEventListener("keydown",o=>{o.key==="Escape"&&document.querySelector(".dialog--transactional[open], .dialog--acknowledgement[open]")&&(o.preventDefault(),o.stopPropagation())}),Array.from(document.querySelectorAll("label progress")).forEach(o=>{var n=o.closest("label");n.setAttribute("data-percent",o.getAttribute("value"))})};function N(){window.dataLayer=window.dataLayer||[],window.dataLayer.push({event:"Pageview",pageTitle:document.title}),document.addEventListener("click",a=>{var e=a.target.closest("[open] summary");if(e)window.dataLayer.push({event:"closeDetails",detailsTitle:e.textContent||""});else{var o=a.target.closest("summary"),n=a.target.closest("a"),r=a.target.closest("button");o&&window.dataLayer.push({event:"openDetails",detailsTitle:o.textContent||""}),n&&window.dataLayer.push({event:"linkClicked",linkText:n.hasAttribute("title")?n.getAttribute("title")||"":n.textContent||"",class:n.hasAttribute("class")&&n.getAttribute("class")||"",href:n.getAttribute("href")||""}),r&&window.dataLayer.push({event:"buttonClicked",buttonText:r.textContent||"",class:r.hasAttribute("class")&&r.getAttribute("class")||""})}})}window.triggerDynamicEvent=function(a){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"change";console.log("event"),a.hasAttribute("data-change-events")&&e=="change"&&v(a,a.getAttribute("data-change-events")),a.hasAttribute("data-click-events")&&e=="click"&&v(a,a.getAttribute("data-click-events"))};var M=()=>{document.addEventListener("change",a=>{a&&a.target instanceof HTMLElement&&a.target.closest("[data-change-events]")&&v(a.target,a.target.closest("[data-change-events]").getAttribute("data-change-events"))}),document.addEventListener("keyup",a=>{a&&a.target instanceof HTMLElement&&a.target.closest("[data-change-events]")&&v(a.target,a.target.closest("[data-change-events]").getAttribute("data-change-events"))}),document.addEventListener("click",a=>{a&&a.target instanceof HTMLElement&&a.target.closest("[data-click-events]")&&v(a.target,a.target.closest("[data-click-events]").getAttribute("data-click-events"))})},v=(a,e)=>{if(e||(e=a.parentNode.getAttribute("data-change-events")),!e)return!1;Array.from(JSON.parse(e)).forEach(o=>{C(a,o)})},C=(a,e)=>{if("matches"in e)return e.matches=="any"||a.value==e.matches?f(a,e,"if"):f(a,e,"else"),!1;if("in-list"in e){var o=document.querySelector("".concat(e["in-list"],' option[value="').concat(a.value,'"]'));return document.querySelector("".concat(e["in-list"],' option[value="').concat(a.value,'"]'))?f(o,e,"if"):f(o,e,"else"),!1}else"event"in e&&f(a,e,"event")},f=(a,e,o)=>{if(!(o in e))return!1;switch(e[o]){case"hide":if(document.querySelector(e.target)){var n=document.querySelector(e.target);n.classList.add("js-hide"),Array.from(n.querySelectorAll("[data-required]")).forEach(i=>{i.removeAttribute("required")})}break;case"show":if(document.querySelector(e.target)){var r=document.querySelector(e.target);r.classList.remove("js-hide"),Array.from(r.querySelectorAll("[data-required]")).forEach(i=>{i.closest(".js-hide")||i.setAttribute("required","true")})}break;case"populate-form":D(a,e);break;case"dispatchEvent":var s=new Event(e.value);document.querySelector("".concat(e.target)).dispatchEvent(s);break;case"setAttribute":Array.from(document.querySelectorAll("".concat(e.target))).forEach(function(i){i.setAttribute(e.attribute,e.value)});break;case"focus":document.querySelector("".concat(e.target)).focus();break;case"removeAttribute":Array.from(document.querySelectorAll("".concat(e.target))).forEach(function(i){i.removeAttribute(e.attribute)});break;case"updateValue":document.querySelector("".concat(e.target)).value=e.value?e.value:"";var u=new Event("change");document.querySelector("".concat(e.target)).dispatchEvent(u);break;case"submitForm":document.querySelector("".concat(e.target)).submit();break;case"openLink":document.querySelector("".concat(e.target)).value&&(window.location.href=document.querySelector("".concat(e.target)).value);break}},D=function(e,o){var n=JSON.parse(e.getAttribute("data-values")),r=document.querySelector(o.target);if(!n)return!1;Object.keys(n).forEach(s=>{document.getElementById(s)&&document.getElementById(s).tagName=="SPAN"&&(document.getElementById(s).innerHTML=n[s]),r.querySelector('select[name="'.concat(s,'"] [value="').concat(n[s],'"]'))?(r.querySelector('select[name="'.concat(s,'"]')).value=n[s],e.hasAttribute("data-lock-fields")&&(r.querySelector('select[name="'.concat(s,'"]')).disabled=!0)):r.querySelector('input[name="'.concat(s,'"][type="radio"][value="').concat(n[s],'"]'))?(Array.from(r.querySelectorAll('input[name="'.concat(s,'"][type="radio"]'))).forEach(function(u){u.disabled=!0}),r.querySelector('input[name="'.concat(s,'"][type="radio"][value="').concat(n[s],'"]')).checked=!0,r.querySelector('input[name="'.concat(s,'"][type="radio"][value="').concat(n[s],'"]')).disabled=!1):r.querySelector('input[name="'.concat(s,'"]'))&&(r.querySelector('input[name="'.concat(s,'"]')).value=n[s],e.hasAttribute("data-lock-fields")&&r.querySelector('input[name="'.concat(s,'"]')).setAttribute("readonly","true"))})},F=()=>{var a=[],e={},o="These tests run against mark-up and content meant to test how a component or element has been integrated. Making sure that guidance setout in the design system is being followed.";window.integrationTestsIntro=o,console.log("%cVirgin Money Framework Tests","color: #E10A0A; font-size: 24px; font-weight: bold; margin-top: 20px; margin-bottom: 10px;"),console.log("%c"+o,"font-size: 14px; margin-bottom: 20px;"),console.log("%cKey","font-size: 16px;font-weight:bold;"),console.log("%c %cSuccessfully implemented","background-color: green; margin-right: 10px","background-color: transparent"),console.log("%c %cNOT implemented correctly","background-color: red; margin-right: 10px","background-color: transparent"),console.log("%c %cN/A","background-color: grey; margin-right: 10px","background-color: transparent"),console.log("%c %cWarning - No action needed","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("%c ? %cWarning - Action needed","background-color: orange; margin-right: 10px","background-color: transparent"),e={Test:"Each card with in a card deck has a footer with some CTA text via a button link",Total:0,Passes:0,Fails:0},Array.from(document.querySelectorAll(".card-deck .card")).forEach((t,c)=>{if(t.closest(".navbar")==null){var l=t.querySelector(".btn-link");l!=null&&l.textContent.length?e.Passes++:e.Fails++}}),e.Total=e.Passes+e.Fails,a.push(e),e={Test:"Article Decks need to have a background colour applied",Total:0,Passes:0,Fails:0},Array.from(document.querySelectorAll(".article-deck")).forEach((t,c)=>{var l=t.closest(".container");l!=null&&l.matches('[class*="bg-"]')?e.Passes++:e.Fails++}),e.Total=e.Passes+e.Fails,a.push(e),e={Test:"Tabs Carousel has a h2 title with a display-4 class. It should always have a strapline next to it also.",Total:0,Passes:0,Fails:0,Notes:"The site nav contains cards without a footer by design."},Array.from(document.querySelectorAll(".tabs__container--carousel")).forEach((t,c)=>{var l=t.querySelector("h2.display-4:first-child"),d=t.querySelector("h2.display-4:first-child + .strapline");l!=null&&d!=null?e.Passes++:e.Fails++}),e.Total=e.Passes+e.Fails,a.push(e),e={Test:"Split Containers can only have multiple of two columns. So either 2, 4, 6 and so on.",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll(".container.container--split")).forEach((t,c)=>{t.querySelectorAll(':scope > .row > [class*="col"]').length%2===0?e.Passes++:e.Fails++}),e.Total=e.Passes+e.Fails,a.push(e),e={Test:"Statement Containers with only one paragraph or text element should have the class of .h6",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll(".container.container--statement")).forEach((t,c)=>{t.querySelectorAll(":scope > *").length==1&&t.querySelectorAll(":scope > .h6:first-child").length==1?e.Passes++:t.querySelectorAll(":scope > *").length==1&&e.Fails++}),e.Total=e.Passes+e.Fails,a.push(e),e={Test:"CTA Containers title should always have the class of .h1",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll(".container.container--cta")).forEach((t,c)=>{t.querySelectorAll("h2.h1:first-child").length==1?e.Passes++:e.Fails++}),e.Total=e.Passes+e.Fails,a.push(e),console.log("%cImplementation Tests","font-size: 16px;font-weight:bold; margin-top: 20px;"),a.forEach(function(t){var c="green";t.Total===0?c="grey":t.Fails!=0&&(c="red"),t.Type=="warning"&&(c="orange"),console.groupCollapsed("%c %c"+t.Test,"background-color: "+c+"; margin-right: 10px","background-color: transparent"),console.table({Passed:{value:t.Passes},Failed:{value:t.Fails},Total:{value:t.Total}}),t.Notes!=""&&console.log(t.Notes),console.groupEnd()}),window.integrationTests=a;var n=[];e={Test:"There are XX padding classes being used on this page",Type:"warning",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll('[class*="p-"],[class*="pt-"],[class*="pb-"],[class*="pl-"],[class*="pr-"],[class*="px-"],[class*="py-"]')).forEach((t,c)=>{e.Total++}),e.Test=e.Test.replace("XX",e.Total),n.push(e),e={Test:"There are XX margin classes being used on this page",Type:"warning",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll('[class*="m-"],[class*="mt-"],[class*="mb-"],[class*="ml-"],[class*="mr-"],[class*="mx-"],[class*="my-"]')).forEach((t,c)=>{e.Total++}),e.Test=e.Test.replace("XX",e.Total),n.push(e),e={Test:"There are XX text modifier classes being used on this page",Type:"warning",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll('[class*="text-"]')).forEach((t,c)=>{e.Total++}),e.Test=e.Test.replace("XX",e.Total),n.push(e),console.log("%cUtility classes","font-size: 16px;font-weight:bold;"),console.log("The use of certain utility classes is necessary at times but the over use of these classes will lead to design/layout inconsistencies."),n.forEach(function(t){var c="green";t.Total===0?c="grey":t.Fails!=0&&(c="red"),t.Type=="warning"&&(c="orange"),console.groupCollapsed("%c %c"+t.Test,"background-color: "+c+"; margin-right: 10px","background-color: transparent"),console.table({Total:{value:t.Total}}),t.Notes!=""&&console.log(t.Notes),console.groupEnd()}),console.log("%cAccessibility and Best practice Tests","font-size: 16px;font-weight:bold;");var r="green",s=1,u={};Array.from(document.querySelectorAll("h1,h2,h3,h4,h5,h6")).forEach((t,c)=>{var l=1,d=t.textContent;t.matches("h2")?l=2:t.matches("h3")?l=3:t.matches("h4")?l=4:t.matches("h5")?l=5:t.matches("h6")&&(l=6);var h=l-s<=1;c==0&&l!=1&&(h=!1);var p={"Heading Level":l,"In order":h};h?s=l:r="red",u[d]=p}),console.groupCollapsed("%c %cHeadings are in the correct order","background-color: "+r+"; margin-right: 10px","background-color: transparent"),console.table(u),console.groupEnd(),console.groupCollapsed("%c ? %cDo all of the headings make sense out of context and do they introduce the content that follows?","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("You should be able to read the below table and get an understanding of what the page content consists of. The titles should make sense when read in order and child titles should be relevant to the parent title."),console.table(u),console.groupEnd();var i={};Array.from(document.querySelectorAll("a")).forEach((t,c)=>{var l=t.getAttribute("href"),d=t.textContent,h=t.getAttribute("title"),p={Text:d,Title:h};i[l]=p}),console.groupCollapsed("%c ? %cDo all of the links make sense out of context and do they describe the page/section that it links to?","background-color: orange; margin-right: 10px","background-color: transparent"),console.table(i),console.groupEnd();var A={},m={};Array.from(document.querySelectorAll("img[alt]")).forEach((t,c)=>{var l=t.getAttribute("src"),d=t.getAttribute("alt");if(d!=""){var h={Alt:d};A[l]=h}else{var l=t.getAttribute("src"),p={};m[l]=p}}),console.groupCollapsed("%c ? %cDo all of the images with an alt tag make sense out of context and describes the image appropriately?","background-color: orange; margin-right: 10px","background-color: transparent"),console.table(A),console.log("%cImages with an empty alt tag:","font-weight: bold;"),console.table(m),console.groupEnd(),console.groupCollapsed("%c ? %cCan you navigation the page links by tabbing through the page?","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("Are all of the links, input fields and buttons accessible through using the keyboard only?"),console.groupEnd(),console.log("%cLighthouse","font-size: 16px;font-weight:bold;"),console.groupCollapsed("%c ? %cHave you ran a lighthouse report on this page","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("If you are in a modern version of chrome you can a lighthouse report by opening the lighthouse window within the devtools. This should appear as a tab link above."),console.log("This report will give you more detail about the above the tests aswell as extra tests. "),console.groupEnd(),console.log("%cImage sizes","font-size: 16px;font-weight:bold;"),console.log("The below tests work from the current screen size, so if you have your screen at a mobile viewport the scaling and sizes of images will reflect that. It is worth running the image tests in both mobile and desktop views. Simply change the screen size and refresh the page."),Array.from(document.querySelectorAll("img")).forEach((t,c)=>{if(!t.matches("[src*='http']")&&!t.matches("[src$='.svg']")){var l=t.getAttribute("src"),d=new XMLHttpRequest;d.open("HEAD",l,!0),d.onreadystatechange=function(){if(d.readyState==4)if(d.status==200){var h=d.getResponseHeader("Content-Length");if(h>1024){var p=t.naturalWidth,P=t.naturalHeight,S=t.clientWidth,O=t.clientHeight,k=(S/p).toFixed(2)=="0.00"?"Hidden":(S/p).toFixed(2),B=Math.floor(h/1024),E=(h/(p*P)).toFixed(2),b="green",L="green",q="green",x="",T="";E>.5?(b="red",L="red",x="The image has a VERY large 'Bytes per pixel' score, trying optimising the image using https://tinypng.com/."):E>.2&&(b="orange",L="orange",x="The image has a large 'Bytes per pixel' score, trying optimising the image using https://tinypng.com/."),k>1.2?(b="red",q="red",T="The image size is smaller than the size shown on screen this may cause the image to appear blurry and low quality."):k<.5?(b="red",q="red",T="The image size is VERY large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software."):k<.8&&(b="orange",q="orange",T="The image size is large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software."),console.log("%c %c "+t.src,"background: url("+t.src+"); border: 3px solid "+b+"; line-height: 30px; width: 30px; background-size: cover;","background-color: transparent"),x!=""&&console.log("%c %c"+x,"background-color: "+L+"; margin-right: 10px","background-color: transparent"),T!=""&&console.log("%c %c"+T,"background-color: "+q+"; margin-right: 10px","background-color: transparent"),console.table({Image:{Dimensions:p+"x"+P,"Scaled to":S+"x"+O,Scale:k,Filesize:B+"Kb","Bytes per pixel":E}}),console.groupEnd()}}else console.log("%c %c"+t.src+" not loaded","background-color: red; margin-right: 10px","background-color: transparent")},d.send(null)}});var g=[];if(typeof window.integrationTests<"u"&&window.integrationTests.forEach(function(t){t.Total!=0&&t.Type!="warning"&&g.push(t.Test)}),g.length!=0){var y=document.querySelector("#vmtests-display");if(y!=null){y.innerHTML=`<div class="container">
5
5
  <h2>Integration notes</h2>
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * iamKey v7.7.0
2
+ * iamKey v7.7.1--beta1
3
3
  * Copyright 2022-2026 iamproperty
4
4
  */
5
5
  !function(e){"function"==typeof define&&define.amd?define(e):e()}(function(){"use strict";window.triggerDynamicEvent=function(t){var a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"change";console.log("event"),t.hasAttribute("data-change-events")&&"change"==a&&e(t,t.getAttribute("data-change-events")),t.hasAttribute("data-click-events")&&"click"==a&&e(t,t.getAttribute("data-click-events"))};var e=(e,a)=>{if(a||(a=e.parentNode.getAttribute("data-change-events")),!a)return!1;Array.from(JSON.parse(a)).forEach(a=>{t(e,a)})},t=(e,t)=>{if("matches"in t)return"any"==t.matches||e.value==t.matches?a(e,t,"if"):a(e,t,"else"),!1;if("in-list"in t){var o=document.querySelector("".concat(t["in-list"],' option[value="').concat(e.value,'"]'));return document.querySelector("".concat(t["in-list"],' option[value="').concat(e.value,'"]'))?a(o,t,"if"):a(o,t,"else"),!1}"event"in t&&a(e,t,"event")},a=(e,t,a)=>{if(!(a in t))return!1;switch(t[a]){case"hide":if(document.querySelector(t.target)){var n=document.querySelector(t.target);n.classList.add("js-hide"),Array.from(n.querySelectorAll("[data-required]")).forEach(e=>{e.removeAttribute("required")})}break;case"show":if(document.querySelector(t.target)){var r=document.querySelector(t.target);r.classList.remove("js-hide"),Array.from(r.querySelectorAll("[data-required]")).forEach(e=>{e.closest(".js-hide")||e.setAttribute("required","true")})}break;case"populate-form":o(e,t);break;case"dispatchEvent":var s=new Event(t.value);document.querySelector("".concat(t.target)).dispatchEvent(s);break;case"setAttribute":Array.from(document.querySelectorAll("".concat(t.target))).forEach(function(e){e.setAttribute(t.attribute,t.value)});break;case"focus":document.querySelector("".concat(t.target)).focus();break;case"removeAttribute":Array.from(document.querySelectorAll("".concat(t.target))).forEach(function(e){e.removeAttribute(t.attribute)});break;case"updateValue":document.querySelector("".concat(t.target)).value=t.value?t.value:"";var l=new Event("change");document.querySelector("".concat(t.target)).dispatchEvent(l);break;case"submitForm":document.querySelector("".concat(t.target)).submit();break;case"openLink":document.querySelector("".concat(t.target)).value&&(window.location.href=document.querySelector("".concat(t.target)).value)}},o=function(e,t){var a=JSON.parse(e.getAttribute("data-values")),o=document.querySelector(t.target);if(!a)return!1;Object.keys(a).forEach(t=>{document.getElementById(t)&&"SPAN"==document.getElementById(t).tagName&&(document.getElementById(t).innerHTML=a[t]),o.querySelector('select[name="'.concat(t,'"] [value="').concat(a[t],'"]'))?(o.querySelector('select[name="'.concat(t,'"]')).value=a[t],e.hasAttribute("data-lock-fields")&&(o.querySelector('select[name="'.concat(t,'"]')).disabled=!0)):o.querySelector('input[name="'.concat(t,'"][type="radio"][value="').concat(a[t],'"]'))?(Array.from(o.querySelectorAll('input[name="'.concat(t,'"][type="radio"]'))).forEach(function(e){e.disabled=!0}),o.querySelector('input[name="'.concat(t,'"][type="radio"][value="').concat(a[t],'"]')).checked=!0,o.querySelector('input[name="'.concat(t,'"][type="radio"][value="').concat(a[t],'"]')).disabled=!1):o.querySelector('input[name="'.concat(t,'"]'))&&(o.querySelector('input[name="'.concat(t,'"]')).value=a[t],e.hasAttribute("data-lock-fields")&&o.querySelector('input[name="'.concat(t,'"]')).setAttribute("readonly","true"))})},n=()=>{var e=[],t={},a="These tests run against mark-up and content meant to test how a component or element has been integrated. Making sure that guidance setout in the design system is being followed.";window.integrationTestsIntro=a,console.log("%cVirgin Money Framework Tests","color: #E10A0A; font-size: 24px; font-weight: bold; margin-top: 20px; margin-bottom: 10px;"),console.log("%c"+a,"font-size: 14px; margin-bottom: 20px;"),console.log("%cKey","font-size: 16px;font-weight:bold;"),console.log("%c %cSuccessfully implemented","background-color: green; margin-right: 10px","background-color: transparent"),console.log("%c %cNOT implemented correctly","background-color: red; margin-right: 10px","background-color: transparent"),console.log("%c %cN/A","background-color: grey; margin-right: 10px","background-color: transparent"),console.log("%c %cWarning - No action needed","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("%c ? %cWarning - Action needed","background-color: orange; margin-right: 10px","background-color: transparent"),t={Test:"Each card with in a card deck has a footer with some CTA text via a button link",Total:0,Passes:0,Fails:0},Array.from(document.querySelectorAll(".card-deck .card")).forEach((e,a)=>{if(null==e.closest(".navbar")){var o=e.querySelector(".btn-link");null!=o&&o.textContent.length?t.Passes++:t.Fails++}}),t.Total=t.Passes+t.Fails,e.push(t),t={Test:"Article Decks need to have a background colour applied",Total:0,Passes:0,Fails:0},Array.from(document.querySelectorAll(".article-deck")).forEach((e,a)=>{var o=e.closest(".container");null!=o&&o.matches('[class*="bg-"]')?t.Passes++:t.Fails++}),t.Total=t.Passes+t.Fails,e.push(t),t={Test:"Tabs Carousel has a h2 title with a display-4 class. It should always have a strapline next to it also.",Total:0,Passes:0,Fails:0,Notes:"The site nav contains cards without a footer by design."},Array.from(document.querySelectorAll(".tabs__container--carousel")).forEach((e,a)=>{var o=e.querySelector("h2.display-4:first-child"),n=e.querySelector("h2.display-4:first-child + .strapline");null!=o&&null!=n?t.Passes++:t.Fails++}),t.Total=t.Passes+t.Fails,e.push(t),t={Test:"Split Containers can only have multiple of two columns. So either 2, 4, 6 and so on.",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll(".container.container--split")).forEach((e,a)=>{e.querySelectorAll(':scope > .row > [class*="col"]').length%2==0?t.Passes++:t.Fails++}),t.Total=t.Passes+t.Fails,e.push(t),t={Test:"Statement Containers with only one paragraph or text element should have the class of .h6",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll(".container.container--statement")).forEach((e,a)=>{1==e.querySelectorAll(":scope > *").length&&1==e.querySelectorAll(":scope > .h6:first-child").length?t.Passes++:1==e.querySelectorAll(":scope > *").length&&t.Fails++}),t.Total=t.Passes+t.Fails,e.push(t),t={Test:"CTA Containers title should always have the class of .h1",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll(".container.container--cta")).forEach((e,a)=>{1==e.querySelectorAll("h2.h1:first-child").length?t.Passes++:t.Fails++}),t.Total=t.Passes+t.Fails,e.push(t),console.log("%cImplementation Tests","font-size: 16px;font-weight:bold; margin-top: 20px;"),e.forEach(function(e){var t="green";0===e.Total?t="grey":0!=e.Fails&&(t="red"),"warning"==e.Type&&(t="orange"),console.groupCollapsed("%c %c"+e.Test,"background-color: "+t+"; margin-right: 10px","background-color: transparent"),console.table({Passed:{value:e.Passes},Failed:{value:e.Fails},Total:{value:e.Total}}),""!=e.Notes&&console.log(e.Notes),console.groupEnd()}),window.integrationTests=e;var o=[];t={Test:"There are XX padding classes being used on this page",Type:"warning",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll('[class*="p-"],[class*="pt-"],[class*="pb-"],[class*="pl-"],[class*="pr-"],[class*="px-"],[class*="py-"]')).forEach((e,a)=>{t.Total++}),t.Test=t.Test.replace("XX",t.Total),o.push(t),t={Test:"There are XX margin classes being used on this page",Type:"warning",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll('[class*="m-"],[class*="mt-"],[class*="mb-"],[class*="ml-"],[class*="mr-"],[class*="mx-"],[class*="my-"]')).forEach((e,a)=>{t.Total++}),t.Test=t.Test.replace("XX",t.Total),o.push(t),t={Test:"There are XX text modifier classes being used on this page",Type:"warning",Total:0,Passes:0,Fails:0,Notes:""},Array.from(document.querySelectorAll('[class*="text-"]')).forEach((e,a)=>{t.Total++}),t.Test=t.Test.replace("XX",t.Total),o.push(t),console.log("%cUtility classes","font-size: 16px;font-weight:bold;"),console.log("The use of certain utility classes is necessary at times but the over use of these classes will lead to design/layout inconsistencies."),o.forEach(function(e){var t="green";0===e.Total?t="grey":0!=e.Fails&&(t="red"),"warning"==e.Type&&(t="orange"),console.groupCollapsed("%c %c"+e.Test,"background-color: "+t+"; margin-right: 10px","background-color: transparent"),console.table({Total:{value:e.Total}}),""!=e.Notes&&console.log(e.Notes),console.groupEnd()}),console.log("%cAccessibility and Best practice Tests","font-size: 16px;font-weight:bold;");var n="green",r=1,s={};Array.from(document.querySelectorAll("h1,h2,h3,h4,h5,h6")).forEach((e,t)=>{var a=1,o=e.textContent;e.matches("h2")?a=2:e.matches("h3")?a=3:e.matches("h4")?a=4:e.matches("h5")?a=5:e.matches("h6")&&(a=6);var l=a-r<=1;0==t&&1!=a&&(l=!1);var c={"Heading Level":a,"In order":l};l?r=a:n="red",s[o]=c}),console.groupCollapsed("%c %cHeadings are in the correct order","background-color: "+n+"; margin-right: 10px","background-color: transparent"),console.table(s),console.groupEnd(),console.groupCollapsed("%c ? %cDo all of the headings make sense out of context and do they introduce the content that follows?","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("You should be able to read the below table and get an understanding of what the page content consists of. The titles should make sense when read in order and child titles should be relevant to the parent title."),console.table(s),console.groupEnd();var l={};Array.from(document.querySelectorAll("a")).forEach((e,t)=>{var a=e.getAttribute("href"),o={Text:e.textContent,Title:e.getAttribute("title")};l[a]=o}),console.groupCollapsed("%c ? %cDo all of the links make sense out of context and do they describe the page/section that it links to?","background-color: orange; margin-right: 10px","background-color: transparent"),console.table(l),console.groupEnd();var c={},i={};Array.from(document.querySelectorAll("img[alt]")).forEach((e,t)=>{var a=e.getAttribute("src"),o=e.getAttribute("alt");if(""!=o){var n={Alt:o};c[a]=n}else a=e.getAttribute("src"),i[a]={}}),console.groupCollapsed("%c ? %cDo all of the images with an alt tag make sense out of context and describes the image appropriately?","background-color: orange; margin-right: 10px","background-color: transparent"),console.table(c),console.log("%cImages with an empty alt tag:","font-weight: bold;"),console.table(i),console.groupEnd(),console.groupCollapsed("%c ? %cCan you navigation the page links by tabbing through the page?","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("Are all of the links, input fields and buttons accessible through using the keyboard only?"),console.groupEnd(),console.log("%cLighthouse","font-size: 16px;font-weight:bold;"),console.groupCollapsed("%c ? %cHave you ran a lighthouse report on this page","background-color: orange; margin-right: 10px","background-color: transparent"),console.log("If you are in a modern version of chrome you can a lighthouse report by opening the lighthouse window within the devtools. This should appear as a tab link above."),console.log("This report will give you more detail about the above the tests aswell as extra tests. "),console.groupEnd(),console.log("%cImage sizes","font-size: 16px;font-weight:bold;"),console.log("The below tests work from the current screen size, so if you have your screen at a mobile viewport the scaling and sizes of images will reflect that. It is worth running the image tests in both mobile and desktop views. Simply change the screen size and refresh the page."),Array.from(document.querySelectorAll("img")).forEach((e,t)=>{if(!e.matches("[src*='http']")&&!e.matches("[src$='.svg']")){var a=e.getAttribute("src"),o=new XMLHttpRequest;o.open("HEAD",a,!0),o.onreadystatechange=function(){if(4==o.readyState)if(200==o.status){var t=o.getResponseHeader("Content-Length");if(t>1024){var a=e.naturalWidth,n=e.naturalHeight,r=e.clientWidth,s=e.clientHeight,l="0.00"==(r/a).toFixed(2)?"Hidden":(r/a).toFixed(2),c=Math.floor(t/1024),i=(t/(a*n)).toFixed(2),u="green",d="green",g="green",h="",p="";i>.5?(u="red",d="red",h="The image has a VERY large 'Bytes per pixel' score, trying optimising the image using https://tinypng.com/."):i>.2&&(u="orange",d="orange",h="The image has a large 'Bytes per pixel' score, trying optimising the image using https://tinypng.com/."),l>1.2?(u="red",g="red",p="The image size is smaller than the size shown on screen this may cause the image to appear blurry and low quality."):l<.5?(u="red",g="red",p="The image size is VERY large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software."):l<.8&&(u="orange",g="orange",p="The image size is large compared to the size shown on screen, this means unnecessary kb's are being downloaded. Try resizing the image in photoshop or other image editing software."),console.log("%c %c "+e.src,"background: url("+e.src+"); border: 3px solid "+u+"; line-height: 30px; width: 30px; background-size: cover;","background-color: transparent"),""!=h&&console.log("%c %c"+h,"background-color: "+d+"; margin-right: 10px","background-color: transparent"),""!=p&&console.log("%c %c"+p,"background-color: "+g+"; margin-right: 10px","background-color: transparent"),console.table({Image:{Dimensions:a+"x"+n,"Scaled to":r+"x"+s,Scale:l,Filesize:c+"Kb","Bytes per pixel":i}}),console.groupEnd()}}else console.log("%c %c"+e.src+" not loaded","background-color: red; margin-right: 10px","background-color: transparent")},o.send(null)}});var u=[];if(typeof window.integrationTests<"u"&&window.integrationTests.forEach(function(e){0!=e.Total&&"warning"!=e.Type&&u.push(e.Test)}),0!=u.length){var d=document.querySelector("#vmtests-display");if(null!=d){d.innerHTML='<div class="container">\n <h2>Integration notes</h2>\n <ul id="integrationTests"></ul>\n </div>';var g=document.getElementById("integrationTests");null!=g&&u.forEach(function(e){g.innerHTML+="<li>"+e+"</li>"})}}return null},r=Object.freeze({__proto__:null,default:n});["localhost"].includes(window.location.hostname)&&Promise.resolve().then(function(){return r}).then(e=>{window.iamTest=()=>{n()}}).catch(e=>{console.log(e.message)}),document.addEventListener("DOMContentLoaded",()=>{return t=void 0,a=void 0,n=function*(){var t,a;window.dataLayer=window.dataLayer||[],window.dataLayer.push({event:"Pageview",pageTitle:document.title}),document.addEventListener("click",e=>{var t=e.target.closest("[open] summary");if(t)window.dataLayer.push({event:"closeDetails",detailsTitle:t.textContent||""});else{var a=e.target.closest("summary"),o=e.target.closest("a"),n=e.target.closest("button");a&&window.dataLayer.push({event:"openDetails",detailsTitle:a.textContent||""}),o&&window.dataLayer.push({event:"linkClicked",linkText:o.hasAttribute("title")?o.getAttribute("title")||"":o.textContent||"",class:o.hasAttribute("class")&&o.getAttribute("class")||"",href:o.getAttribute("href")||""}),n&&window.dataLayer.push({event:"buttonClicked",buttonText:n.textContent||"",class:n.hasAttribute("class")&&n.getAttribute("class")||""})}}),document.addEventListener("change",t=>{t&&t.target instanceof HTMLElement&&t.target.closest("[data-change-events]")&&e(t.target,t.target.closest("[data-change-events]").getAttribute("data-change-events"))}),document.addEventListener("keyup",t=>{t&&t.target instanceof HTMLElement&&t.target.closest("[data-change-events]")&&e(t.target,t.target.closest("[data-change-events]").getAttribute("data-change-events"))}),document.addEventListener("click",t=>{t&&t.target instanceof HTMLElement&&t.target.closest("[data-click-events]")&&e(t.target,t.target.closest("[data-click-events]").getAttribute("data-click-events"))}),(a=document.body).classList.add("js-enabled"),(-1!==navigator.userAgent.indexOf("MSIE")||navigator.appVersion.indexOf("Trident/")>0)&&a.classList.add("ie"),t=function(e){var t=document.querySelector('label[for="'.concat(e.replace("#",""),'"]')),a=document.querySelector(e+" summary"),o=document.querySelector("dialog".concat(e)),n=document.querySelector("detail".concat(e));t instanceof HTMLElement?t.click():a instanceof HTMLElement?a.click():o instanceof HTMLElement?o.showModal():n instanceof HTMLElement&&n.addAttribute("open")},location.hash&&t(location.hash),window.addEventListener("hashchange",function(){t(location.hash)},!1),addEventListener("popstate",e=>{if(e&&e.state&&e.state.type&&"pagination"==e.state.type){var t=document.querySelector("#".concat(e.state.form)),a=document.querySelector("#".concat(e.state.form," [data-pagination]"));a?a.value=e.state.page:t.innerHTML+='<input name="page" type="hidden" data-pagination="true" value="'.concat(e.state.page,'" />'),t.dispatchEvent(new Event("submit"))}}),Array.from(document.querySelectorAll("form")).forEach(e=>{e?.closest("iam-form")||e.addEventListener("submit",t=>{var a;e.querySelector(":invalid")&&(e.classList.add("was-validated"),null===(a=e?.querySelector("input:invalid"))||void 0===a||a.scrollIntoView(),t.preventDefault())})}),document.addEventListener("click",e=>{var t;if(e&&e.target instanceof HTMLElement&&e.target.matches("form button:not([type=button])")){var a=e.target.closest("form");a?.closest("iam-form")||(Array.from(a.querySelectorAll("[data-password-type]")).forEach(e=>{e.setAttribute("type","password")}),(a.querySelector(":invalid")||a.querySelector('.pwd-checker[data-strength="1"]')||a.querySelector('.pwd-checker[data-strength="2"]'))&&(a.classList.add("was-validated"),null===(t=a?.querySelector("input:invalid"))||void 0===t||t.scrollIntoView(),e.preventDefault()),a.querySelector("iam-multiselect[data-is-required][data-error]")&&(a.classList.add("was-validated"),e.preventDefault()))}}),document.addEventListener("keydown",e=>{"Escape"===e.key&&document.querySelector(".dialog--transactional[open], .dialog--acknowledgement[open]")&&(e.preventDefault(),e.stopPropagation())}),Array.from(document.querySelectorAll("label progress")).forEach(e=>{e.closest("label").setAttribute("data-percent",e.getAttribute("value"))})},new((o=void 0)||(o=Promise))(function(e,r){function s(e){try{c(n.next(e))}catch(e){r(e)}}function l(e){try{c(n.throw(e))}catch(e){r(e)}}function c(t){t.done?e(t.value):function(e){return e instanceof o?e:new o(function(t){t(e)})}(t.value).then(s,l)}c((n=n.apply(t,a||[])).next())});var t,a,o,n})});
@@ -202,9 +202,20 @@ $breakpoints: (
202
202
  // #endregion
203
203
 
204
204
  // #region Grid utility classes
205
- .grid:not(.admin-panel) {
205
+ .grid {
206
206
  display: grid !important;
207
207
  grid-template-columns: subgrid !important;
208
+
209
+ > * {
210
+ grid-column: var(--col-start, col-1-start) / var(--col-end, col-#{$columns}-end);
211
+ }
212
+ }
213
+ .sub-grid {
214
+
215
+ display: grid !important;
216
+ grid-template-rows: auto !important;
217
+ grid-template-columns: [content-start col-1-start] 1fr [col-1-end col-2-start] 1fr [col-2-end col-3-start] 1fr [col-3-end col-4-start] 1fr [col-4-end col-5-start] 1fr [col-5-end col-6-start] 1fr [col-6-end col-7-start] 1fr [col-7-end col-8-start] 1fr [col-8-end col-9-start] 1fr [col-9-end col-10-start] 1fr [col-10-end col-11-start] 1fr [col-11-end col-12-start] 1fr [col-12-end content-end] !important;
218
+ column-gap: var(--gap) !important;
208
219
 
209
220
  > * {
210
221
  grid-column: var(--col-start, col-1-start) / var(--col-end, col-#{$columns}-end);
@@ -21,7 +21,7 @@
21
21
  .header-banner {
22
22
  padding-top: 2.75rem; /* 44*/
23
23
  max-width: 120rem; /* 1920 */
24
- min-height: 25rem; /* 400 */
24
+ //min-height: 25rem; /* 400 */
25
25
  margin-inline: auto;
26
26
  display: block;
27
27
 
@@ -32,7 +32,14 @@
32
32
  //padding-top: 5.25rem; /* 84 */
33
33
  }
34
34
 
35
- > picture {
35
+ > .picture-overflow {
36
+ overflow: hidden;
37
+ position: absolute;
38
+ inset: 0;
39
+ z-index: 3;
40
+ }
41
+
42
+ > .picture-overflow picture {
36
43
  display: block;
37
44
  position: absolute;
38
45
  top: 0;
@@ -43,7 +50,6 @@
43
50
  overflow: hidden;
44
51
  min-height: 25rem; /* 400 */
45
52
  max-height: 25rem; /* 400 */
46
- z-index: 3;
47
53
 
48
54
  img {
49
55
  display: block;
@@ -91,10 +97,22 @@
91
97
  }
92
98
 
93
99
  ::slotted(*:not(.btn__group):last-child) {
94
- padding-bottom: 0 !important;
95
- margin-bottom: 0 !important;
100
+ //padding-bottom: 0 !important;
101
+ //margin-bottom: 0 !important;
96
102
  }
97
103
 
104
+ // #region Breadcrumbs
105
+ :host(.has-breadcrumbs) {
106
+
107
+ .header-banner {
108
+ padding-top: 1rem;
109
+ }
110
+
111
+ ::slotted(.breadcrumbs) {
112
+ margin-bottom: 2rem!important;
113
+ }
114
+ }
115
+ // #endregion
98
116
 
99
117
  // #region badge
100
118
 
@@ -107,12 +125,14 @@ slot[name="badge"] {
107
125
  // #endregion
108
126
 
109
127
  // #region panel
110
- :host(.has-panel) .admin-panel{
128
+ :host(.has-panel) [name="panel"]{
111
129
 
112
130
  display: block;
113
131
  text-align: center;
114
132
  margin-bottom: 1rem;
133
+ max-height: fit-content;
115
134
  }
135
+
116
136
  ::slotted([slot="panel"]) {
117
137
 
118
138
  color-scheme: light !important;
@@ -176,16 +196,60 @@ slot[name="badge"] {
176
196
  }
177
197
  // #endregion
178
198
 
199
+
200
+ // #region toolbox
201
+ :host(.has-toolbox) {
202
+
203
+ margin-bottom: 4rem;
204
+ }
205
+ :host(.has-toolbox) [name="toolbox"]{
206
+
207
+ display: flex;
208
+ flex-wrap: wrap;
209
+ text-align: center;
210
+ margin-bottom: -3rem;
211
+ width: fit-content;
212
+ margin-inline: auto;
213
+
214
+ gap: 0.5rem;
215
+ }
216
+
217
+ ::slotted([slot="toolbox"]) {
218
+
219
+ margin: 0!important;
220
+
221
+ color-scheme: light !important;
222
+ --colour-heading: var(--colour-primary-theme);
223
+ --colour-body: var(--colour-primary-theme);
224
+ --colour-underline: var(--colour-secondary-theme);
225
+ color: var(--colour-primary-theme);
226
+ }
227
+
228
+ ::slotted(hr[slot="toolbox"]) {
229
+
230
+ display: inline-block;
231
+ vertical-align: top !important;
232
+ margin-top: -0.25rem !important;
233
+ margin-bottom: -0.25rem !important;
234
+ background-color: var(--colour-muted) !important;
235
+ width: 1px !important;
236
+ height: 2.5rem !important;
237
+ }
238
+
239
+ // #endregion
240
+
179
241
  // #region gradient background
180
- :host {
242
+ .gradient-overflow {
181
243
  overflow: hidden;
244
+ position: absolute;
245
+ inset: 0;
246
+ z-index: 2;
182
247
  }
183
248
  .gradient-background {
184
249
  position: absolute;
185
250
  left: 75%;
186
251
  top: 50%;
187
252
  transform: translate(-50%, -50%);
188
- z-index: 2;
189
253
  width: 54rem; /* 874px */
190
254
  aspect-ratio: 1 / 1;
191
255
  }
@@ -206,10 +206,10 @@
206
206
  height: 3rem;
207
207
  width: 3rem;
208
208
  margin-top: 0;
209
- margin-bottom: 1.5rem;
209
+ margin-bottom: 0;
210
210
  line-height: 1;
211
211
  color: var(--colour-heading);
212
- margin-inline: auto;
212
+ margin-inline: auto;
213
213
 
214
214
  @media screen and (min-width: 62em) {
215
215
  font-size: 4rem;
@@ -172,6 +172,10 @@
172
172
  grid-column: var(--col-start, col-1-start) / var(--col-end, col-12-end);
173
173
  }
174
174
  }
175
+
176
+ & > hr {
177
+ margin-inline: calc(var(--padding-x) * -1);
178
+ }
175
179
  }
176
180
 
177
181
  [class*='col'].admin-panel:first-child:last-child:not(
@@ -270,4 +274,37 @@
270
274
 
271
275
  margin-bottom: calc(var(--padding-bottom) * -1)!important;
272
276
  }
277
+
278
+ /* #region */
279
+ .sub-panel {
280
+ background: var(--colour-canvas);
281
+ padding: var(--spacer-1);
282
+ border: 1px solid var(--colour-border);
283
+ border-radius: 0.25rem;
284
+ font-weight: normal;
285
+ margin-bottom: 1rem;
286
+
287
+ & > :is(h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6) {
288
+
289
+ font-size: 1rem;
290
+ line-height: 1;
291
+ margin-bottom: 0;
292
+ padding-bottom: 0.5rem;
293
+ font-weight: normal;
294
+ }
295
+
296
+ strong {
297
+ font-weight: normal;
298
+ }
299
+
300
+ .logo {
301
+ height: 1.5rem;
302
+ width: 1.5rem;
303
+ object-fit: contain;
304
+ padding: 0;
305
+ margin: 0 auto 0.25rem auto;
306
+ display: block;
307
+ }
308
+ }
309
+ /* #endregion */
273
310
  }
@@ -35,7 +35,7 @@
35
35
  font-weight: 900;
36
36
  }
37
37
 
38
- &[class*='fa-']:before {
38
+ [class*='fa-']:before {
39
39
  line-height: calc(var(--compact-size) - 0.25rem);
40
40
 
41
41
  @container style(--theme: dark) {
@@ -162,7 +162,6 @@
162
162
  &[class*='fa-']:before {
163
163
  content: var(--fa);
164
164
  font-family: 'Font Awesome 7 Pro';
165
- line-height: 1em;
166
165
  }
167
166
 
168
167
  &.btn[class*='fa-after'] {
@@ -8,54 +8,73 @@
8
8
  padding-left: 0;
9
9
 
10
10
  li {
11
+ --fa-family: var(--fa-family-duotone);
11
12
  position: relative;
12
13
  list-style: none;
13
14
  padding-bottom: 1rem;
14
- padding-left: 1.75em;
15
+ padding-left: 1.5em;
15
16
 
16
- &:before {
17
- content: '\f058';
17
+ &:before {
18
+ content: var(--fa,'\f058');
18
19
  position: absolute;
19
20
  top: 0;
20
21
  left: 0;
21
- width: 1.25em;
22
- height: 1.25em;
23
- font-size: 1.25em;
24
- line-height: 1;
22
+ width: 1em;
23
+ height: 1em;
24
+ font-size: 1em;
25
+ //color: var(--tick-colour, var(--colour-complete));
26
+ font-family: var(--fa-family,'Font Awesome 7 Pro');
27
+ font-weight: var(--icon-weight, 900);
28
+ color: var(--colour-white);
29
+ }
25
30
 
26
- color: var(--tick-colour, var(--colour-complete));
27
- font-family: 'Font Awesome 7 Pro';
31
+ &:after {
32
+ content: var(--fa,'\f058');
33
+ position: absolute;
34
+ top: 0;
35
+ left: 0;
36
+ width: 1em;
37
+ height: 1em;
38
+ font-size: 1em;
39
+ color: var(--tick-colour, var(--colour-success));
40
+ font-family: var(--fa-family,'Font Awesome 7 Pro');
28
41
  font-weight: var(--icon-weight, 900);
42
+ font-feature-settings: "ss01";
29
43
  }
30
44
  }
31
45
 
32
- .tick--warning:before {
33
- content: '\f071';
34
- font-weight: var(--icon-weight, 900);
35
- color: var(--colour-warning);
46
+ .tick--warning {
47
+ --fa: '\f071';
48
+ --tick-colour: var(--colour-warning);
36
49
  }
37
-
38
- .tick--danger:before {
39
- content: '\f06a';
40
- font-weight: var(--icon-weight, 900);
41
- color: var(--colour-danger);
50
+
51
+ .tick--danger {
52
+ --fa: '\f06a';
53
+ --tick-colour: var(--colour-danger);
42
54
  }
43
55
 
44
56
  .tick--incomplete:before {
57
+ font-family: 'Font Awesome 7 Pro';
45
58
  background: var(--colour-admin);
46
59
  mask-image: none;
47
60
  -webkit-mask-image: none;
48
61
  border-radius: 50%;
49
62
  transform: scale(0.8);
50
63
  }
64
+ .tick--incomplete:after {
65
+ display: none;
66
+ }
51
67
  .tick--loading:before {
68
+ font-family: 'Font Awesome 7 Pro';
52
69
  content: '\f3f4';
53
70
  font-weight: var(--icon-weight, 900);
54
71
  color: var(--colour-heading);
55
72
  animation: spin 1.5s infinite steps(10);
56
- line-height: 1.25;
57
73
  font-size: 1em;
58
74
  }
75
+ .tick--loading:after {
76
+ display: none;
77
+ }
59
78
 
60
79
  li[class*='bg-'] {
61
80
  padding: 1rem;
@@ -218,6 +218,7 @@
218
218
  --icon-error: #{escape-svg($icon-error)};
219
219
  --icon-tick: #{escape-svg($icon-tick)};
220
220
 
221
+ --fa-secondary-opacity: 0.1;
221
222
  // #endregion
222
223
 
223
224
  // #region spacing
@@ -1,4 +1,26 @@
1
1
  @layer utilities {
2
+
3
+
4
+ .position-static {
5
+ position: static !important;
6
+ }
7
+
8
+ .position-relative {
9
+ position: relative !important;
10
+ }
11
+
12
+ .position-absolute {
13
+ position: absolute !important;
14
+ }
15
+
16
+ .position-fixed {
17
+ position: fixed !important;
18
+ }
19
+
20
+ .position-sticky {
21
+ position: sticky !important;
22
+ }
23
+
2
24
  $breakpoints: (
3
25
  sm: 36em,
4
26
  md: 62em,
@@ -25,66 +47,6 @@
25
47
  .position-#{$breakpoint}-sticky {
26
48
  position: sticky !important;
27
49
  }
28
-
29
- .top-#{$breakpoint}-0 {
30
- top: 0 !important;
31
- }
32
-
33
- .top-#{$breakpoint}-50 {
34
- top: 50% !important;
35
- }
36
-
37
- .top-#{$breakpoint}-100 {
38
- top: 100% !important;
39
- }
40
-
41
- .bottom-#{$breakpoint}-0 {
42
- bottom: 0 !important;
43
- }
44
-
45
- .bottom-#{$breakpoint}-50 {
46
- bottom: 50% !important;
47
- }
48
-
49
- .bottom-#{$breakpoint}-100 {
50
- bottom: 100% !important;
51
- }
52
-
53
- .start-#{$breakpoint}-0 {
54
- left: 0 !important;
55
- }
56
-
57
- .start-#{$breakpoint}-50 {
58
- left: 50% !important;
59
- }
60
-
61
- .start-#{$breakpoint}-100 {
62
- left: 100% !important;
63
- }
64
-
65
- .end-#{$breakpoint}-0 {
66
- right: 0 !important;
67
- }
68
-
69
- .end-#{$breakpoint}-50 {
70
- right: 50% !important;
71
- }
72
-
73
- .end-#{$breakpoint}-100 {
74
- right: 100% !important;
75
- }
76
-
77
- .translate-#{$breakpoint}-middle {
78
- transform: translate(-50%, -50%) !important;
79
- }
80
-
81
- .translate-#{$breakpoint}-middle-x {
82
- transform: translateX(-50%) !important;
83
- }
84
-
85
- .translate-#{$breakpoint}-middle-y {
86
- transform: translateY(-50%) !important;
87
- }
88
50
  }
89
51
  }
90
52
  }
@@ -45,12 +45,15 @@ class iamAdvancedSelect extends HTMLElement {
45
45
 
46
46
  connectedCallback(): void {
47
47
  // Clone original input field, re-name and use for display purposes
48
- const inputField = this.querySelector('input');
49
- const displayInputField = inputField.cloneNode();
48
+ const inputField = this.querySelector('input') as HTMLInputElement | null;
49
+ if (!inputField) return;
50
+
51
+ const displayInputField = inputField.cloneNode() as HTMLInputElement;
50
52
  displayInputField.setAttribute('name', `${inputField.getAttribute('name')}Alt`);
51
53
  inputField.removeAttribute('data-change-events');
52
54
  displayInputField.removeAttribute('id');
53
- let datalist = this.querySelector('datalist');
55
+
56
+ let datalist = this.querySelector('datalist') as HTMLDataListElement | null;
54
57
 
55
58
  inputField.after(displayInputField);
56
59
 
@@ -68,8 +71,25 @@ class iamAdvancedSelect extends HTMLElement {
68
71
  }
69
72
 
70
73
  advancedSelect(this, displayInputField, datalist);
74
+
75
+ // Apply initial value passed to the component host
76
+ const initialValue = this.getAttribute('value') || '';
77
+ if (!initialValue) return;
78
+
79
+ inputField.value = initialValue;
80
+ inputField.setAttribute('value', initialValue);
81
+
82
+ displayInputField.value = '';
83
+ displayInputField.setAttribute('placeholder', initialValue);
84
+ displayInputField.setAttribute('data-value', initialValue);
85
+
86
+ if (datalist) {
87
+ Array.from(datalist.querySelectorAll('option')).forEach((option) => {
88
+ const isMatch = option.getAttribute('value') === initialValue;
89
+ option.classList.toggle('active', isMatch);
90
+ });
91
+ }
71
92
  }
72
93
  }
73
94
 
74
-
75
95
  export default iamAdvancedSelect;