@iamproperty/components 7.7.1--beta21 → 7.7.1--beta23

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 (174) 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/banner.component.css +1 -1
  6. package/assets/css/components/banner.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/card.module.css +1 -1
  12. package/assets/css/components/card.module.css.map +1 -1
  13. package/assets/css/components/carousel.config.css +1 -1
  14. package/assets/css/components/carousel.config.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/fileupload.css +1 -1
  18. package/assets/css/components/fileupload.css.map +1 -1
  19. package/assets/css/components/filter-card.component.css +1 -1
  20. package/assets/css/components/filter-card.component.css.map +1 -1
  21. package/assets/css/components/header.component.css +1 -1
  22. package/assets/css/components/header.component.css.map +1 -1
  23. package/assets/css/components/modal.component.css +1 -1
  24. package/assets/css/components/modal.component.css.map +1 -1
  25. package/assets/css/components/multi-step-modal.component.css +1 -1
  26. package/assets/css/components/multi-step-modal.component.css.map +1 -1
  27. package/assets/css/components/multiselect.css +1 -1
  28. package/assets/css/components/multiselect.css.map +1 -1
  29. package/assets/css/components/nav.component.css +1 -1
  30. package/assets/css/components/nav.component.css.map +1 -1
  31. package/assets/css/components/nav.global.css +1 -1
  32. package/assets/css/components/nav.global.css.map +1 -1
  33. package/assets/css/components/record-card.component.css +1 -1
  34. package/assets/css/components/record-card.component.css.map +1 -1
  35. package/assets/css/components/search.component.css +1 -1
  36. package/assets/css/components/search.component.css.map +1 -1
  37. package/assets/css/components/std-nav-standalone.component.css +1 -1
  38. package/assets/css/components/std-nav-standalone.component.css.map +1 -1
  39. package/assets/css/components/tabs.component.css +1 -1
  40. package/assets/css/components/tabs.component.css.map +1 -1
  41. package/assets/css/components/tag.component.css +1 -1
  42. package/assets/css/components/tag.component.css.map +1 -1
  43. package/assets/css/components/video-card.component.css +1 -1
  44. package/assets/css/components/video-card.component.css.map +1 -1
  45. package/assets/css/components/video-modal.component.css +1 -1
  46. package/assets/css/components/video-modal.component.css.map +1 -1
  47. package/assets/css/core.min.css +1 -1
  48. package/assets/css/core.min.css.map +1 -1
  49. package/assets/css/elements/admin-panel.css +1 -1
  50. package/assets/css/elements/admin-panel.css.map +1 -1
  51. package/assets/css/elements/dialog.css +1 -1
  52. package/assets/css/elements/dialog.css.map +1 -1
  53. package/assets/css/elements/icons.css +1 -1
  54. package/assets/css/elements/icons.css.map +1 -1
  55. package/assets/css/elements/links--global.css +1 -1
  56. package/assets/css/elements/links--global.css.map +1 -1
  57. package/assets/css/elements/links.css +1 -1
  58. package/assets/css/elements/links.css.map +1 -1
  59. package/assets/css/style.min.css +1 -1
  60. package/assets/css/style.min.css.map +1 -1
  61. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  62. package/assets/js/components/actionbar/actionbar.component.min.js +2 -2
  63. package/assets/js/components/address-lookup/address-lookup.component.min.js +4 -4
  64. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  65. package/assets/js/components/advanced-select/advanced-select.component.min.js +2 -2
  66. package/assets/js/components/advanced-select/advanced-select.component.min.js.map +1 -1
  67. package/assets/js/components/applied-filters/applied-filters.component.min.js +1 -1
  68. package/assets/js/components/banner/banner.component.min.js +2 -2
  69. package/assets/js/components/barchart/barchart.component.min.js +1 -1
  70. package/assets/js/components/bento-grid/bento-grid.component.min.js +1 -1
  71. package/assets/js/components/bone/bone.component.min.js +1 -1
  72. package/assets/js/components/button/button.component.min.js +1 -1
  73. package/assets/js/components/calendar/calendar.component.min.js +2 -2
  74. package/assets/js/components/card/card.component.js +1 -1
  75. package/assets/js/components/card/card.component.min.js +6 -6
  76. package/assets/js/components/card/card.component.min.js.map +1 -1
  77. package/assets/js/components/carousel/carousel.component.min.js +1 -1
  78. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +1 -1
  79. package/assets/js/components/config/config.component.min.js +2 -2
  80. package/assets/js/components/content/content.component.js +6 -1
  81. package/assets/js/components/content/content.component.min.js +3 -3
  82. package/assets/js/components/content/content.component.min.js.map +1 -1
  83. package/assets/js/components/darkmode/darkmode.component.min.js +1 -1
  84. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +1 -1
  85. package/assets/js/components/fileupload/fileupload.component.min.js +3 -3
  86. package/assets/js/components/filter-card/filter-card.component.min.js +5 -5
  87. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  88. package/assets/js/components/form/form.component.min.js +1 -1
  89. package/assets/js/components/header/header.component.min.js +2 -2
  90. package/assets/js/components/inline-edit/inline-edit.component.min.js +1 -1
  91. package/assets/js/components/input/input.component.min.js +1 -1
  92. package/assets/js/components/input-range/input-range.component.min.js +1 -1
  93. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  94. package/assets/js/components/menu/menu.component.min.js +1 -1
  95. package/assets/js/components/milestone/milestone.component.min.js +1 -1
  96. package/assets/js/components/milestone-group/milestone-group.component.min.js +1 -1
  97. package/assets/js/components/modal/modal.component.js +1 -0
  98. package/assets/js/components/modal/modal.component.min.js +5 -4
  99. package/assets/js/components/modal/modal.component.min.js.map +1 -1
  100. package/assets/js/components/multi-step/multi-step.component.min.js +1 -1
  101. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js +2 -2
  102. package/assets/js/components/multiselect/multiselect.component.min.js +2 -2
  103. package/assets/js/components/nav/nav.component.min.js +3 -3
  104. package/assets/js/components/notification/notification.component.min.js +1 -1
  105. package/assets/js/components/pagination/pagination.component.min.js +1 -1
  106. package/assets/js/components/password/password.component.min.js +1 -1
  107. package/assets/js/components/popover/popover.component.min.js +1 -1
  108. package/assets/js/components/rank/rank.component.min.js +1 -1
  109. package/assets/js/components/rankings/rankings.component.min.js +1 -1
  110. package/assets/js/components/rating/rating.component.min.js +1 -1
  111. package/assets/js/components/record-card/record-card.component.min.js +4 -4
  112. package/assets/js/components/search/search.component.js +8 -3
  113. package/assets/js/components/search/search.component.min.js +6 -6
  114. package/assets/js/components/search/search.component.min.js.map +1 -1
  115. package/assets/js/components/skeleton/skeleton.component.min.js +1 -1
  116. package/assets/js/components/slider/slider.component.min.js +1 -1
  117. package/assets/js/components/split-button/split-button.component.min.js +1 -1
  118. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js +6 -6
  119. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js.map +1 -1
  120. package/assets/js/components/std-nav/std-nav.component.js +9 -0
  121. package/assets/js/components/std-nav/std-nav.component.min.js +11 -11
  122. package/assets/js/components/std-nav/std-nav.component.min.js.map +1 -1
  123. package/assets/js/components/std-nav-standalone/std-nav-standalone.component.js +5 -0
  124. package/assets/js/components/std-nav-standalone/std-nav-standalone.component.min.js +8 -8
  125. package/assets/js/components/std-nav-standalone/std-nav-standalone.component.min.js.map +1 -1
  126. package/assets/js/components/table/table.component.min.js +1 -1
  127. package/assets/js/components/table-ajax/table-ajax.component.min.js +1 -1
  128. package/assets/js/components/table-basic/table-basic.component.min.js +1 -1
  129. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +1 -1
  130. package/assets/js/components/table-submit/table-submit.component.min.js +1 -1
  131. package/assets/js/components/tabs/tabs.component.min.js +4 -4
  132. package/assets/js/components/tag/tag.component.min.js +2 -2
  133. package/assets/js/components/tooltip/tooltip.component.min.js +1 -1
  134. package/assets/js/components/video/video.component.min.js +1 -1
  135. package/assets/js/components/video-card/video-card.component.min.js +3 -3
  136. package/assets/js/components/video-card/video-card.component.min.js.map +1 -1
  137. package/assets/js/components/video-modal/video-modal.component.min.js +3 -3
  138. package/assets/js/components/video-modal/video-modal.component.min.js.map +1 -1
  139. package/assets/js/components/word-count/word-count.component.min.js +1 -1
  140. package/assets/js/modules/advanced-select.js +1 -1
  141. package/assets/js/modules/modal.js +2 -2
  142. package/assets/js/modules/nav.js +2 -2
  143. package/assets/js/scripts.bundle.js +1 -1
  144. package/assets/js/scripts.bundle.min.js +1 -1
  145. package/assets/sass/_components.scss +0 -4
  146. package/assets/sass/components/banner.component.scss +2 -1
  147. package/assets/sass/components/card.component.scss +43 -41
  148. package/assets/sass/components/card.module.scss +26 -13
  149. package/assets/sass/components/carousel.config.scss +21 -0
  150. package/assets/sass/components/fileupload.scss +7 -0
  151. package/assets/sass/components/modal.component.scss +4 -3
  152. package/assets/sass/components/nav.global.scss +30 -12
  153. package/assets/sass/components/search.component.scss +17 -0
  154. package/assets/sass/components/std-nav-standalone.component.scss +3 -2
  155. package/assets/sass/elements/admin-panel.css +0 -1
  156. package/assets/sass/elements/dialog.scss +13 -0
  157. package/assets/sass/elements/icons.css +4 -0
  158. package/assets/sass/elements/links--global.scss +31 -1
  159. package/assets/sass/foundations/colours.scss +7 -0
  160. package/assets/sass/foundations/reboot.scss +13 -1
  161. package/assets/sass/foundations/root.scss +20 -3
  162. package/assets/ts/components/card/card.component.ts +1 -1
  163. package/assets/ts/components/content/content.component.ts +7 -1
  164. package/assets/ts/components/modal/modal.component.ts +1 -0
  165. package/assets/ts/components/nav/nav.component.ts +1 -0
  166. package/assets/ts/components/search/search.component.ts +10 -3
  167. package/assets/ts/components/std-nav/std-nav.component.ts +19 -0
  168. package/assets/ts/components/std-nav-standalone/std-nav-standalone.component.ts +9 -0
  169. package/assets/ts/modules/advanced-select.ts +2 -2
  170. package/assets/ts/modules/modal.ts +2 -2
  171. package/assets/ts/modules/nav.ts +2 -2
  172. package/dist/components.es.js +25 -25
  173. package/dist/components.umd.js +42 -41
  174. package/package.json +1 -1
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * iamKey v7.7.1--beta21
2
+ * iamKey v7.7.1--beta23
3
3
  * Copyright 2022-2026 iamproperty
4
4
  */const o=i=>{window.dataLayer=window.dataLayer||[],window.dataLayer.push({event:"customElementRegistered",element:i})};o("iam-word-count");class n extends HTMLElement{constructor(){super(),this.attachShadow({mode:"open"}),document.body.hasAttribute("data-assets-location")&&document.body.getAttribute("data-assets-location");const t=document.createElement("template");t.innerHTML=`
5
5
  <style>
@@ -104,7 +104,7 @@ function advancedSelect(advancedSelect, displayInputField, datalist, isSearch =
104
104
  currentFocus--;
105
105
  addActive(datalist.options);
106
106
  }
107
- else if (e.keyCode == 13) {
107
+ else if (e.keyCode == 13 && !e.target.closest('form')) {
108
108
  e.preventDefault();
109
109
  if (currentFocus > -1) {
110
110
  /*and simulate a click on the "active" item:*/
@@ -1,6 +1,6 @@
1
1
  export const openModal = (modal) => {
2
2
  var _a;
3
- const dialog = (_a = modal.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('dialog');
3
+ const dialog = modal.closest('dialog') || ((_a = modal.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('dialog'));
4
4
  const id = modal.hasAttribute('id') ? modal.getAttribute('id') : 'unknown';
5
5
  dialog === null || dialog === void 0 ? void 0 : dialog.showModal();
6
6
  dialog === null || dialog === void 0 ? void 0 : dialog.focus();
@@ -18,7 +18,7 @@ export const openModal = (modal) => {
18
18
  };
19
19
  export const closeModal = (modal) => {
20
20
  var _a;
21
- const dialog = (_a = modal.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('dialog');
21
+ const dialog = modal.closest('dialog') || ((_a = modal.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('dialog'));
22
22
  const id = modal.hasAttribute('id') ? modal.getAttribute('id') : 'unknown';
23
23
  dialog === null || dialog === void 0 ? void 0 : dialog.close();
24
24
  const closeEvent = new CustomEvent('modal-closed', {
@@ -41,8 +41,8 @@ export const populateSections = (data) => {
41
41
  let html = ``;
42
42
  data.forEach((section) => {
43
43
  html += `<span class="section section--${section.layout}">
44
- ${section.title ? `<span class="lead text-heading section-title" data-product="${section.id}" data-title>${section.title}</span>` : ''}
45
- ${section.description ? `<span class="lead section-desc" data-product="${section.id}">! ${section.description}</span>` : ''}
44
+ ${section.title ? `<span class="lead section-title" data-product="${section.id}" data-title>${section.title}:</span>` : ''}
45
+ ${section.description ? `<span class="lead section-desc" data-product="${section.id}"><i class="fa-solid fa-sparkles colour-warning"></i> ${section.description}</span>` : ''}
46
46
  ${populateLinks(section.links)}
47
47
  </span>`;
48
48
  });
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * iamKey v7.7.1--beta21
2
+ * iamKey v7.7.1--beta23
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.1--beta21
2
+ * iamKey v7.7.1--beta23
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})});
@@ -98,10 +98,6 @@
98
98
  /* #endregion */
99
99
 
100
100
  /* Search */
101
- iam-search input:not(.is-invalid):not(:invalid) {
102
- background: none !important;
103
- }
104
-
105
101
  iam-search .optional-text {
106
102
  display: none !important;
107
103
  }
@@ -11,8 +11,9 @@
11
11
  border-radius: 0.5rem;
12
12
  box-shadow: 0px 6px 12px rgba(0, 0, 0, 0.11);
13
13
 
14
- margin-bottom: 2rem;
14
+ margin-bottom: 1rem;
15
15
  position: relative;
16
+ overflow: hidden;
16
17
  }
17
18
 
18
19
  :host(:not([class*="bg-"])) {
@@ -4,18 +4,6 @@
4
4
  @use '../elements/popover' as *;
5
5
  @use '../elements/buttons' as *;
6
6
 
7
- :host {
8
- --card-right-padding: 1rem;
9
- /* --card-head-height: 10rem; */
10
- --card-icon-right: 1rem;
11
- position: relative;
12
- }
13
-
14
- :host(:is(:hover, :focus, .hover):not(.prevent-hover)) {
15
- --hover-outline-colour-default: var(--colour, var(--colour-primary));
16
- outline: 2px solid var(--hover-outline-colour, var(--hover-outline-colour-default));
17
- outline-offset: -2px;
18
- }
19
7
 
20
8
  :host(:is(:active, .active):not(.prevent-hover)) {
21
9
  --card-icon-right: var(--card-icon-right-overide, 0.5rem);
@@ -31,23 +19,26 @@
31
19
  }
32
20
 
33
21
  /* #region Right arrow */
34
- :host(.show-icon) .card__body {
22
+ :host(.show-icon) {
35
23
  --card-right-padding: 3.5rem;
24
+ }
25
+ :host(.show-icon) .card__body {
36
26
 
37
27
  &:before,
38
28
  &:after {
39
29
  content: '';
30
+ display: var(--card-right-arrow-display, block);
40
31
  position: absolute;
41
32
  right: var(--card-icon-right);
42
33
  bottom: var(--card-bottom-padding);
43
34
  height: 1.5rem;
44
35
  width: 1.5rem;
45
- background: var(--colour-warning);
36
+ background: var(--card-icon-bg);
46
37
  border-radius: 50%;
47
38
  }
48
39
 
49
40
  &:after {
50
- background: var(--colour-primary-theme);
41
+ background: var(--card-icon-colour);
51
42
  mask-image: var(--icon, var(--icon-arrow));
52
43
  mask-size: 50%;
53
44
  mask-repeat: no-repeat;
@@ -60,30 +51,6 @@
60
51
  }
61
52
  }
62
53
 
63
- :host(.show-icon) .card__footer {
64
-
65
- --card-right-padding: 3.5rem;
66
- }
67
-
68
- :host(:is(:hover, :focus, .hover):not(.prevent-hover):not([class*='colour-'])) {
69
- .card__body {
70
- &:before {
71
- background: var(--hover-icon-bg, var(--colour-primary-theme));
72
- }
73
- &:after {
74
- background: var(--hover-icon-colour, #ffffff);
75
- }
76
- }
77
- }
78
-
79
- :host(:is(:active, .active):not(.prevent-hover):not([class*='colour-'])) {
80
- .card__body:before {
81
- background: var(--hover-icon-bg, var(--colour-primary-theme));
82
- }
83
- .card__body:after {
84
- background: var(--hover-icon-colour, #ffffff);
85
- }
86
- }
87
54
  /* #endregion */
88
55
 
89
56
  /* #region illustration */
@@ -180,8 +147,8 @@ slot[name='secondary'] {
180
147
  border: none;
181
148
  }
182
149
  :host(:not(.prevent-hover)) ::slotted([slot='primary-action']:is(:hover, :focus, .hover)) {
183
- --hover-outline-colour-default: var(--colour, var(--colour-primary));
184
- outline: 2px solid var(--hover-outline-colour, var(--hover-outline-colour-default));
150
+
151
+ outline: 2px solid var(--hover-outline-colour);
185
152
  outline-offset: -2px;
186
153
  border-radius: var(--card-border-radius) !important;
187
154
  }
@@ -211,4 +178,39 @@ slot[name='secondary'] {
211
178
  display: none!important;
212
179
  }
213
180
 
181
+ /* #endregion */
182
+
183
+ /* #region article cards */
184
+
185
+ :host(.card--article) {
186
+
187
+ --card-head-height: 5rem;
188
+ --card-fs: 1rem;
189
+ --card-gap: 0.5rem;
190
+ --card-body-top-padding: 1rem;
191
+ --card-body-bottom-padding: 0.5rem;
192
+ --card-left-padding: 0.5rem;
193
+ --card-right-padding: 0.75rem;
194
+ --card-right-arrow-display: none;
195
+
196
+ --card-body-fs: 0.6875rem;
197
+ --card-body-lh: 1rem;
198
+
199
+ --card-footer-bottom-padding: 0.5rem;
200
+
201
+ }
202
+
203
+ ::slotted(span:is(.duration):not([class*=pt-])) {
204
+
205
+ font-size: var(--card-fs)!important;
206
+ line-height: var(--card-lh)!important;
207
+ padding-top: 0!important;
208
+
209
+ &:before {
210
+ content: '\f017';
211
+ font-family: var(--fa-family-classic);
212
+ color: var(--colour-warning);
213
+ padding-right: 0.25rem;
214
+ }
215
+ }
214
216
  /* #endregion */
@@ -1,15 +1,17 @@
1
1
  @use '../_func' as *;
2
2
 
3
3
  :host {
4
- --card-icon-right: 1rem;
5
- --card-head-top-padding: 2rem;
6
- --card-head-bottom-padding: 2rem;
7
- --card-footer-bottom-padding: 1.5rem;
8
- --card-head-height: 6rem;
4
+
5
+
6
+
7
+ position: relative;
9
8
 
10
9
  border-radius: var(--card-border-radius);
11
10
  margin-bottom: 2rem;
12
11
  display: block;
12
+
13
+ outline: var(--card-outline);
14
+ outline-offset: -2px;
13
15
  }
14
16
 
15
17
  .wrapper {
@@ -18,8 +20,8 @@
18
20
  box-shadow: var(--card-box-shadow);
19
21
  position: relative;
20
22
  font-weight: bold;
21
- font-size: 1.125rem; /* 18/16 */
22
- line-height: 1.5rem;
23
+ font-size: var(--card-fs);
24
+ line-height: var(--card-lh);
23
25
  color: var(--colour-primary);
24
26
  min-height: 100%;
25
27
  width: 100%;
@@ -64,18 +66,28 @@
64
66
  height: calc(100% + 4px);
65
67
  object-fit: cover;
66
68
  }
69
+
70
+ &:after {
71
+ content: "";
72
+ position: absolute;
73
+ top: 0;
74
+ left: 0;
75
+ width: 100%;
76
+ height: 100%;
77
+ background: var(--card-head-overlay);
78
+ }
67
79
  }
68
80
 
69
81
  .card__body {
70
82
  /* position: relative; */
71
- padding: var(--card-head-top-padding) var(--card-right-padding) var(--card-head-bottom-padding)
83
+ padding: var(--card-body-top-padding) var(--card-right-padding) var(--card-body-bottom-padding)
72
84
  var(--card-left-padding);
73
85
  /* z-index: -1; */
74
86
  }
75
87
 
76
88
  .card__footer {
77
- margin-top: 0;
78
- padding: 0 var(--card-right-padding) 0 var(--card-left-padding);
89
+ margin-top: auto;
90
+ padding: var(--card-footer-top-padding,0) var(--card-right-padding) var(--card-footer-bottom-padding,0) var(--card-left-padding);
79
91
  }
80
92
 
81
93
  ::slotted(i) {
@@ -93,17 +105,18 @@
93
105
  ::slotted(span:not(.badge,.title)) {
94
106
  display: block !important;
95
107
  font-weight: normal !important;
96
- font-size: 1rem !important;
108
+ font-size: var(--card-body-fs, 1rem) !important;
109
+ line-height: var(--card-body-lh, inherit) !important;
97
110
  }
98
111
  ::slotted(small) {
99
- padding-top: 1rem !important;
112
+ padding-top: var(--card-gap, 1rem) !important;
100
113
  display: block !important;
101
114
  font-weight: normal !important;
102
115
  padding-bottom: 0 !important;
103
116
  color: var(--colour-body);
104
117
  }
105
118
  ::slotted(span:not(.badge,.title):not([class*='pt-'])) {
106
- padding-top: 1.5rem !important;
119
+ padding-top: var(--card-gap, 1.5rem) !important;
107
120
  }
108
121
 
109
122
  ::slotted(:is(a, button)[slot='footer']) {
@@ -713,4 +713,25 @@
713
713
  }
714
714
 
715
715
  /* #endregion */
716
+
717
+ /* #region article cards */
718
+
719
+ iam-carousel.carousel--article-cards {
720
+
721
+ --card-head-height: 5rem;
722
+ --card-fs: 1rem;
723
+ --card-gap: 0.5rem;
724
+ --card-body-top-padding: 1rem;
725
+ --card-body-bottom-padding: 0.5rem;
726
+ --card-left-padding: 0.5rem;
727
+ --card-right-padding: 0.75rem;
728
+ --card-right-arrow-display: none;
729
+ --card-body-fs: 0.6875rem;
730
+ --card-body-lh: 1rem;
731
+
732
+
733
+ --card-footer-bottom-padding: 0.5rem;
734
+ }
735
+ /* #endregon */
716
736
  }
737
+
@@ -2,6 +2,7 @@
2
2
  @use '../_func' as *;
3
3
  @use '../elements/forms' as *;
4
4
  @use '../elements/buttons' as *;
5
+ @use '../elements/type' as *;
5
6
 
6
7
  @use '../utilities/display' as *;
7
8
 
@@ -47,9 +48,15 @@ hr {
47
48
 
48
49
  .helper-text {
49
50
  max-width: 16.875rem; /* (270); */
51
+ padding-bottom: 2rem;
50
52
  }
51
53
  }
52
54
 
55
+ :host(.fileupload--hide-title) .file-upload .file-upload__title{
56
+
57
+ display: none!important;
58
+ }
59
+
53
60
  .files {
54
61
  span {
55
62
  display: block;
@@ -20,8 +20,10 @@
20
20
  }
21
21
 
22
22
  @layer components {
23
- dialog[open] {
24
- /* overflow-y: hidden; */
23
+ dialog {
24
+
25
+ display: var(--modal-inner-dialog-display,block);
26
+
25
27
  width: 90vw;
26
28
  max-width: 20.25rem; /* col-width*4 324px */
27
29
 
@@ -105,7 +107,6 @@
105
107
  top: calc(var(--dialog-padding) - 0.75rem);
106
108
  right: calc(var(--dialog-padding) - 0.75rem);
107
109
  }
108
-
109
110
  }
110
111
 
111
112
 
@@ -130,17 +130,17 @@ nav:has(:is(iam-nav,.iam-nav)) {
130
130
  }
131
131
  }
132
132
 
133
- nav:has(:is(iam-nav,.iam-nav).nav--sticky) {
133
+ nav:has(.nav--sticky) {
134
134
  position: sticky;
135
135
  top: 0;
136
136
  left: 0;
137
137
  right: 0;
138
138
  z-index: 9999;
139
139
 
140
- :is(iam-nav,.iam-nav) {
140
+ .nav--sticky {
141
141
  position: fixed;
142
142
  outline: 2px solid #eeeeee;
143
- transition: margin 1s;
143
+ transition: margin 1s;
144
144
  }
145
145
  }
146
146
 
@@ -244,17 +244,17 @@ body[data-direction='down'].past100 nav:has(.nav--sticky) .nav--sticky{
244
244
  }
245
245
 
246
246
  &[data-product][data-feature]:not([data-is-enabled="true"]) {
247
+ padding-left: 2rem!important;
247
248
  &:before {
248
- content: "! ";
249
- }
250
- }
251
-
252
- &[data-product][data-feature]:not([data-is-enabled="true"]) {
253
- &:before {
254
- content: "! ";
249
+ content: "\f890";
250
+ font-family: var(--fa-family, var(--fa-style-family, "Font Awesome 7 Pro"));
251
+ padding-right: 0.5em;
252
+ position: absolute;
253
+ left: 0;
254
+ font-weight: 700;
255
255
  }
256
256
  }
257
-
257
+
258
258
  }
259
259
 
260
260
  /* #region standard nav sections */
@@ -340,6 +340,14 @@ body[data-direction='down'].past100 nav:has(.nav--sticky) .nav--sticky{
340
340
  width: auto;
341
341
  position: relative;
342
342
 
343
+ .section [data-title].section-title {
344
+
345
+ color: var(--colour-body) !important;
346
+ font-size: 1rem;
347
+ font-weight: normal;
348
+ font-weight: normal;
349
+ }
350
+
343
351
  summary {
344
352
  background-color: var(--colour-canvas-2);
345
353
 
@@ -386,7 +394,7 @@ body[data-direction='down'].past100 nav:has(.nav--sticky) .nav--sticky{
386
394
  border: none;
387
395
  color: var(--colour-link);
388
396
  margin: 0;
389
- margin-left: 3rem;
397
+ margin-left: 3rem!important;
390
398
  padding: 1.5rem 0 1.5rem 0;
391
399
  font-size: 1rem;
392
400
  line-height: 1.5rem;
@@ -788,6 +796,16 @@ body[data-direction='down'].past100 nav:has(.nav--sticky) .nav--sticky{
788
796
  }
789
797
  }
790
798
 
799
+ :is(iam-nav,.iam-nav) a:not([slot='logo']):not(.btn):not(:has(iam-card)) {
800
+
801
+
802
+ &[data-product][data-feature]:not([data-is-enabled="true"]) {
803
+
804
+ &:before {
805
+ left: 0.5rem;
806
+ }
807
+ }
808
+ }
791
809
  nav:has(:is(iam-nav,.iam-nav).open) {
792
810
  min-height: 100vh !important;
793
811
  max-height: 100vh;
@@ -2,6 +2,23 @@
2
2
  @use 'advanced-select.component';
3
3
 
4
4
  @layer components {
5
+
6
+ @media (prefers-color-scheme: light) {
7
+ :host {
8
+ color-scheme: light;
9
+ }
10
+
11
+ ::slotted(*) {
12
+
13
+ --colour-heading: var(--colour-primary-theme);
14
+ --colour-body: var(--colour-primary-theme);
15
+ color: var(--colour-primary-theme);
16
+
17
+ color-scheme: light;
18
+ }
19
+ }
20
+
21
+
5
22
  :host(.search--stylised) ::slotted(input) {
6
23
 
7
24
  outline: 1px solid var(--colour-border)!important;
@@ -60,6 +60,7 @@
60
60
  .iam-nav {
61
61
  background-color: transparent;
62
62
  padding: 0;
63
+ top: 2rem!important;
63
64
  }
64
65
 
65
66
  .iam-nav a {
@@ -150,7 +151,7 @@
150
151
  width: 0;
151
152
  }
152
153
 
153
- .section + .section {
154
+ .section:has(a:not([href=null])) + .section {
154
155
  border-top: 1px solid var(--colour-border);
155
156
  display: block;
156
157
  padding-top: 0.5rem;
@@ -211,7 +212,7 @@
211
212
  position: absolute;
212
213
  top: 100%;
213
214
  left: 0;
214
- height: calc(100vh - var(--nav-height));
215
+ height: calc(100vh - 2rem)!important;
215
216
  width: 100%;
216
217
  z-index: -1;
217
218
  pointer-events: none;
@@ -12,7 +12,6 @@
12
12
  border-radius: 0.5rem;
13
13
  margin-bottom: 1.5rem;
14
14
  outline: var(--contrast-outline-width, 0px) solid var(--colour-primary);
15
- overflow: hidden;
16
15
 
17
16
  &:has(
18
17
  :is([class*='cols-'], [class*='col-start-'], [class*='col-end-'], [class*='col-span-'])
@@ -33,6 +33,19 @@
33
33
  padding-bottom: 0;
34
34
  }
35
35
  }
36
+ dialog[open]:has(iam-modal) {
37
+ --modal-inner-dialog-display: contents;
38
+ place-self: center;
39
+ }
40
+ @media (prefers-color-scheme: light) {
41
+ dialog[open]:has(iam-modal) {
42
+
43
+ color-scheme: light;
44
+ --colour-body: #595959;
45
+ --colour-heading: var(--colour-primary-theme);
46
+
47
+ }
48
+ }
36
49
 
37
50
  dialog::backdrop {
38
51
  background: rgba(0, 0, 0, 0.3);
@@ -45,4 +45,8 @@
45
45
  border-radius: 50% !important;
46
46
  display: inline-block;
47
47
  }
48
+
49
+ [class*='fa-'][class*='colour-'] {
50
+ color: var(--colour,inherit);
51
+ }
48
52
  }