@iamproperty/components 7.6.4--beta7 → 7.6.4--beta8

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 (97) 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/actionbar.global.css +1 -1
  4. package/assets/css/components/actionbar.global.css.map +1 -1
  5. package/assets/css/components/config.component.css +1 -0
  6. package/assets/css/components/config.component.css.map +1 -0
  7. package/assets/css/components/notification.css +1 -1
  8. package/assets/css/components/notification.css.map +1 -1
  9. package/assets/css/components/table-basic.global.css +1 -1
  10. package/assets/css/components/table-basic.global.css.map +1 -1
  11. package/assets/css/components/table.global.css +1 -1
  12. package/assets/css/components/table.global.css.map +1 -1
  13. package/assets/css/core.min.css +1 -1
  14. package/assets/css/core.min.css.map +1 -1
  15. package/assets/css/style.min.css +1 -1
  16. package/assets/css/style.min.css.map +1 -1
  17. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  18. package/assets/js/components/actionbar/actionbar.component.js +7 -6
  19. package/assets/js/components/actionbar/actionbar.component.min.js +5 -5
  20. package/assets/js/components/actionbar/actionbar.component.min.js.map +1 -1
  21. package/assets/js/components/address-lookup/address-lookup.component.js +11 -1
  22. package/assets/js/components/address-lookup/address-lookup.component.min.js +3 -3
  23. package/assets/js/components/address-lookup/address-lookup.component.min.js.map +1 -1
  24. package/assets/js/components/advanced-select/advanced-select.component.min.js +1 -1
  25. package/assets/js/components/applied-filters/applied-filters.component.min.js +1 -1
  26. package/assets/js/components/barchart/barchart.component.min.js +1 -1
  27. package/assets/js/components/bento-grid/bento-grid.component.min.js +1 -1
  28. package/assets/js/components/calendar/calendar.component.min.js +1 -1
  29. package/assets/js/components/card/card.component.min.js +1 -1
  30. package/assets/js/components/carousel/carousel.component.min.js +1 -1
  31. package/assets/js/components/collapsible-side/collapsible-side.component.min.js +1 -1
  32. package/assets/js/components/config/config.component.js +532 -0
  33. package/assets/js/components/config/config.component.min.js +59 -0
  34. package/assets/js/components/config/config.component.min.js.map +1 -0
  35. package/assets/js/components/content/content.component.min.js +1 -1
  36. package/assets/js/components/darkmode/darkmode.component.min.js +1 -1
  37. package/assets/js/components/doughnutchart/doughnutchart.component.min.js +1 -1
  38. package/assets/js/components/fileupload/fileupload.component.min.js +1 -1
  39. package/assets/js/components/filter-card/filter-card.component.min.js +1 -1
  40. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  41. package/assets/js/components/form/form.component.min.js +1 -1
  42. package/assets/js/components/header/header.component.min.js +1 -1
  43. package/assets/js/components/inline-edit/inline-edit.component.min.js +1 -1
  44. package/assets/js/components/input/input.component.min.js +1 -1
  45. package/assets/js/components/input-range/input-range.component.min.js +1 -1
  46. package/assets/js/components/marketing/marketing.component.min.js +1 -1
  47. package/assets/js/components/menu/menu.component.min.js +1 -1
  48. package/assets/js/components/milestone/milestone.component.min.js +1 -1
  49. package/assets/js/components/milestone-group/milestone-group.component.min.js +1 -1
  50. package/assets/js/components/modal/modal.component.min.js +1 -1
  51. package/assets/js/components/multi-step/multi-step.component.min.js +1 -1
  52. package/assets/js/components/multi-step-modal/multi-step-modal.component.min.js +1 -1
  53. package/assets/js/components/multiselect/multiselect.component.min.js +1 -1
  54. package/assets/js/components/nav/nav.component.min.js +1 -1
  55. package/assets/js/components/notification/notification.component.js +69 -30
  56. package/assets/js/components/notification/notification.component.min.js +5 -5
  57. package/assets/js/components/notification/notification.component.min.js.map +1 -1
  58. package/assets/js/components/pagination/pagination.component.min.js +1 -1
  59. package/assets/js/components/password/password.component.min.js +1 -1
  60. package/assets/js/components/popover/popover.component.min.js +1 -1
  61. package/assets/js/components/rank/rank.component.min.js +1 -1
  62. package/assets/js/components/rankings/rankings.component.min.js +1 -1
  63. package/assets/js/components/rating/rating.component.min.js +1 -1
  64. package/assets/js/components/record-card/record-card.component.min.js +1 -1
  65. package/assets/js/components/search/search.component.min.js +1 -1
  66. package/assets/js/components/slider/slider.component.min.js +1 -1
  67. package/assets/js/components/split-button/split-button.component.min.js +1 -1
  68. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js +4 -4
  69. package/assets/js/components/std-address-lookup/std-address-lookup.component.min.js.map +1 -1
  70. package/assets/js/components/table/table.component.min.js +2 -2
  71. package/assets/js/components/table-ajax/table-ajax.component.min.js +2 -2
  72. package/assets/js/components/table-basic/table-basic.component.min.js +2 -2
  73. package/assets/js/components/table-no-submit/table-no-submit.component.min.js +2 -2
  74. package/assets/js/components/table-submit/table-submit.component.min.js +2 -2
  75. package/assets/js/components/tabs/tabs.component.min.js +1 -1
  76. package/assets/js/components/tag/tag.component.min.js +1 -1
  77. package/assets/js/components/tooltip/tooltip.component.min.js +1 -1
  78. package/assets/js/components/video-card/video-card.component.min.js +1 -1
  79. package/assets/js/components/video-modal/video-modal.component.min.js +1 -1
  80. package/assets/js/components/word-count/word-count.component.min.js +1 -1
  81. package/assets/js/scripts.bundle.js +1 -1
  82. package/assets/js/scripts.bundle.min.js +1 -1
  83. package/assets/sass/components/actionbar.component.scss +13 -4
  84. package/assets/sass/components/actionbar.global.scss +8 -0
  85. package/assets/sass/components/config.component.scss +235 -0
  86. package/assets/sass/components/notification.scss +4 -14
  87. package/assets/sass/components/table-basic.global.scss +4 -4
  88. package/assets/sass/foundations/root.scss +0 -4
  89. package/assets/ts/components/actionbar/actionbar.component.ts +7 -6
  90. package/assets/ts/components/address-lookup/address-lookup.component.ts +16 -1
  91. package/assets/ts/components/config/config.component.ts +699 -0
  92. package/assets/ts/components/notification/notification.component.ts +98 -47
  93. package/assets/ts/components/std-address-lookup/std-address-lookup.component.ts +1 -0
  94. package/dist/components.es.js +28 -28
  95. package/dist/components.umd.js +273 -216
  96. package/package.json +1 -1
  97. package/src/components/Config/Config.vue +23 -0
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * iamKey v7.6.4--beta7
2
+ * iamKey v7.6.4--beta8
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})});
@@ -3,6 +3,7 @@
3
3
  @use '../elements/prefix.scss' as *;
4
4
  @use '../elements/forms.scss' as *;
5
5
  @use '../elements/buttons.scss' as *;
6
+ @use '../elements/badge-tag.scss' as *;
6
7
  @use '../elements/dialog.scss' as *;
7
8
  @use '../elements/popover.scss' as *;
8
9
 
@@ -42,6 +43,14 @@ slot[name='selectall'] {
42
43
  }
43
44
  }
44
45
 
46
+ :host([data-view="square"]) .views [data-view="square"],
47
+ :host([data-view="list"]) .views [data-view="list"],
48
+ :host([data-view="small"]) .views [data-view="small"] {
49
+
50
+ background: #e9f9fd;
51
+ outline: 1px solid #1ebee6;
52
+ }
53
+
45
54
  .selectall,
46
55
  slot[name='selectall'] {
47
56
  width: 2.5rem;
@@ -69,7 +78,7 @@ slot[name='selectall'] {
69
78
  :is(.actionbar, .actionbar--selected, .actionbar--search) {
70
79
  border-top-left-radius: var(--actionbar-radius, #{rem(10)});
71
80
  border-top-right-radius: var(--actionbar-radius, #{rem(10)});
72
- padding: 0 1.5rem;
81
+ padding: 0 1rem;
73
82
  flex-wrap: nowrap;
74
83
  justify-content: flex-end;
75
84
  align-items: center;
@@ -81,7 +90,7 @@ slot[name='selectall'] {
81
90
  }
82
91
 
83
92
  @media screen and (min-width: 36em) {
84
- padding: 0 2rem;
93
+ padding: 0 1.5rem;
85
94
  }
86
95
  }
87
96
 
@@ -361,6 +370,8 @@ slot[name='selectall'] {
361
370
  height: 1rem;
362
371
  width: 1rem;
363
372
  border-radius: 50%;
373
+ mask-image:unset;
374
+ -webkit-mask-image:unset;
364
375
  }
365
376
  }
366
377
 
@@ -407,6 +418,4 @@ slot[name="filters"]{
407
418
  }
408
419
  }
409
420
 
410
-
411
-
412
421
  // #endregion
@@ -105,3 +105,11 @@ iam-actionbar:has(.selectall input:checked) {
105
105
  --selectall-actionbar-opactiy: 0;
106
106
  --selectall-action-pe: none;
107
107
  }
108
+
109
+ // #region filters
110
+
111
+ iam-actionbar [slot="filters"]:not(:has(+[slot="filters"])) {
112
+ margin-inline-end: auto!important;
113
+ }
114
+
115
+ // #endregion
@@ -0,0 +1,235 @@
1
+ @use '../_func.scss' as *;
2
+
3
+ @use '../_grid' as *;
4
+
5
+ @use '../elements/forms' as *;
6
+ @use '../elements/admin-panel' as *;
7
+
8
+ @use '../elements/type' as *;
9
+ @use '../elements/buttons' as *;
10
+ @use '../utilities/margins';
11
+ @use '../utilities/paddings';
12
+ @use '../utilities/colours.scss';
13
+ @use '../utilities/visually-hidden.scss';
14
+
15
+ @use '../utilities/font-awesome-iso-fallbacks.scss';
16
+
17
+ *,
18
+ *::before,
19
+ *::after {
20
+ box-sizing: border-box;
21
+ }
22
+
23
+ :host {
24
+ display: block!important;
25
+ }
26
+
27
+ // #region enable icons
28
+ .fa-chevron-up {
29
+ --fa: "\f077";
30
+ }
31
+
32
+ .fa-chevron-down {
33
+ --fa: "\f078";
34
+ }
35
+
36
+ .fa-trash {
37
+ --fa: "\f1f8";
38
+ }
39
+
40
+ .fa-plus {
41
+ --fa: "\2b";
42
+ }
43
+
44
+ .fa-pen-to-square {
45
+ --fa: "\f044";
46
+ }
47
+
48
+ .fa-floppy-disk {
49
+
50
+ --fa: "\f0c7";
51
+ }
52
+
53
+ [class*="fa-"]{
54
+
55
+ &:before {
56
+ content: var(--fa);
57
+ font-weight: 600;
58
+ font-family: "Font Awesome 6 Pro";
59
+ }
60
+ }
61
+ // #endregion
62
+
63
+ // #region basic structure
64
+
65
+ #wrapper {
66
+ container-type: inline-size;
67
+ display: flex;
68
+ flex-direction: column;
69
+
70
+ .admin-panel {
71
+ order: 1;
72
+ justify-content: flex-end;
73
+ display: flex;
74
+ max-width: fit-content;
75
+ gap: 0.75rem;
76
+ padding: 1rem;
77
+
78
+ > * {
79
+ margin: 0;
80
+ }
81
+ }
82
+
83
+ #items {
84
+ order: 2;
85
+ display: block!important;
86
+ }
87
+ }
88
+ // #endregion
89
+
90
+ // #region buckets
91
+ #buckets {
92
+
93
+ display: block!important;
94
+ }
95
+
96
+ .bucket {
97
+ display: block;
98
+ min-height: 10rem;
99
+ background-color: blue;
100
+ margin-bottom: 2rem;
101
+ padding: 1rem;
102
+ }
103
+
104
+ .bucket:empty {
105
+ display: block;
106
+ min-height: 10rem;
107
+ background-color: red;
108
+ margin-bottom: 2rem;
109
+ padding: 1rem;
110
+ }
111
+
112
+ .bucket__wrapper {
113
+
114
+ padding-right: 10.25rem;
115
+ position: relative;
116
+ border-bottom: 1px solid var(--colour-border);
117
+ margin-bottom: 2rem;
118
+ padding-bottom: 1rem;
119
+
120
+ > .btn__group {
121
+ position: absolute;
122
+ top: 0.25rem;
123
+ right: 0;
124
+ gap: 0;
125
+ padding: 0;
126
+ }
127
+ }
128
+ // #endregion
129
+
130
+ // #region item
131
+ #items [data-bucket] {
132
+
133
+ display: block;
134
+
135
+ form {
136
+ --btns-width: 2.5rem;
137
+ --col-size: calc((100% - (var(--gap) * 11)) / 12);
138
+ column-gap: var(--gap);
139
+ grid-column: var(--col-start, col-1-start) / var(--col-end, col-12-end);
140
+ grid-template-columns: [content-start col-1-start] var(--col-size) [col-1-end col-2-start] var(--col-size) [col-2-end col-3-start] var(--col-size) [col-3-end col-4-start] var(--col-size) [col-4-end col-5-start] var(--col-size) [col-5-end col-6-start] var(--col-size) [col-6-end col-7-start] var(--col-size) [col-7-end col-8-start] var(--col-size) [col-8-end col-9-start] var(--col-size) [col-9-end col-10-start] var(--col-size) [col-10-end col-11-start] var(--col-size) [col-11-end col-12-start] var(--col-size) [col-12-end content-end];
141
+
142
+ padding-right: calc(var(--btns-width) + 0.5rem);
143
+ position: relative;
144
+
145
+ .btn__group {
146
+ position: absolute;
147
+ top: 0.25rem;
148
+ right: 0;
149
+ gap: 0;
150
+ width: var(--btns-width);
151
+ padding-top: 1.75rem;
152
+ margin: 0;
153
+
154
+ .btn:not(.fa-trash){
155
+ display: none;
156
+ }
157
+ }
158
+
159
+ &:not(:where(main)):has(>[class*=col-]) {
160
+ .btn__group {
161
+ left: 100%;
162
+ margin-left: 0.5rem;
163
+ right: auto;
164
+ }
165
+ }
166
+ }
167
+ }
168
+
169
+ :host([data-order]) #items [data-bucket] form {
170
+
171
+ --btns-width: 10rem;
172
+
173
+ .btn:not(.fa-trash) {
174
+ display: inline-block;
175
+ }
176
+ }
177
+ // #endregion
178
+
179
+ // #region criteria
180
+ .criteria {
181
+ display: flex;
182
+ gap: 1rem;
183
+ padding-right: 5.25rem;
184
+ position: relative;
185
+
186
+ .btn__group {
187
+ position: absolute;
188
+ top: 0.25rem;
189
+ right: 0;
190
+ gap: 0;
191
+ padding: 0;
192
+ }
193
+
194
+ label {
195
+ flex-grow: 1;
196
+ }
197
+ label:nth-child(2) {
198
+ flex-grow: 0;
199
+ }
200
+ }
201
+ // #endregion
202
+
203
+ // #region expand criteria
204
+ .bucket__wrapper:not(.bucket--expanded) {
205
+ > label > span { // TODO add a selector if the input matches the only criteria item
206
+ display: none;
207
+ }
208
+ .criteria {
209
+ display: none;
210
+ }
211
+ .criteria label:nth-child(3):has(:disabled){
212
+ display: none;
213
+ }
214
+ }
215
+
216
+ .bucket__wrapper.bucket--expanded {
217
+
218
+ .btn__group .fa-pen-to-square {
219
+ --fa: "\e0a6";
220
+ }
221
+ }
222
+ // #endregion
223
+
224
+ // #region Disable top and bottom buttons
225
+
226
+ #buckets .bucket__wrapper:first-child .btn__group [data-direction="up"],
227
+ #buckets .bucket__wrapper:last-child .btn__group [data-direction="down"],
228
+ [data-bucket] form:first-child .btn__group [data-direction="up"],
229
+ [data-bucket] form:last-child .btn__group [data-direction="down"] {
230
+
231
+ opacity: 0.6;
232
+ pointer-events: none;
233
+ }
234
+
235
+ // #endregion
@@ -33,22 +33,12 @@
33
33
  }
34
34
 
35
35
 
36
- :host(.colour-warning),
37
- .iam-notification.colour-warning {
38
- background: var(--colour-notification-warning-bg);
36
+ :host([class*="colour-"]) {
37
+
38
+ --bg-colour: color-mix(in oklab, var(--colour), #ffffff 80%) !important;
39
+ background: light-dark(var(--bg-colour),var(--colour-canvas-2));
39
40
  }
40
41
 
41
- :host(.colour-danger),
42
- .iam-notification.colour-danger {
43
-
44
- background: var(--colour-notification-danger-bg);
45
- }
46
-
47
- :host(.colour-success),
48
- .iam-notification.colour-success {
49
-
50
- background: var(--colour-notification-success-bg);
51
- }
52
42
 
53
43
  :host(.bg-white),
54
44
  .iam-notification.bg-white {
@@ -396,13 +396,13 @@ table {
396
396
  padding-top: 0;
397
397
  }
398
398
  :is(#{$selector}).table--fullwidth iam-actionbar {
399
- margin: -2rem -2rem 2rem -2rem;
399
+ margin: -2rem -1.5rem 2rem -1.5rem;
400
400
  box-shadow: none;
401
401
  border-radius: 0;
402
402
  }
403
403
 
404
404
  :is(#{$selector}).table--fullwidth iam-actionbar:has(+ table input:checked) {
405
- margin: -2rem -2rem 2rem -2rem;
405
+ margin: -2rem -1.5rem 2rem -1.5rem;
406
406
  box-shadow: none;
407
407
  border-radius: 0;
408
408
  background-color: #e6eaec;
@@ -453,8 +453,8 @@ table {
453
453
  @container (width > 36em) {
454
454
  :is(#{$selector}).table--fullwidth iam-actionbar,
455
455
  :is(#{$selector}) iam-actionbar {
456
- margin-left: -2rem;
457
- margin-right: -2rem;
456
+ margin-left: -1.5rem;
457
+ margin-right: -1.5rem;
458
458
  margin-top: -2rem;
459
459
  margin-bottom: 2rem;
460
460
  }
@@ -75,10 +75,6 @@
75
75
 
76
76
  --colour-inverted: #fcfcfc;
77
77
 
78
- --colour-notification-bg: light-dark(#e9f9fd,var(--colour-canvas-2));
79
- --colour-notification-warning-bg: light-dark(#fff6e6,var(--colour-canvas-2));
80
- --colour-notification-danger-bg: light-dark(#fcebec,var(--colour-canvas-2));
81
- --colour-notification-success-bg: light-dark(#f8fdf6,var(--colour-canvas-2));
82
78
  /* #endregion */
83
79
  /* #region Wider colours */
84
80
  --wider-colour-1: #EEEEEE;
@@ -208,20 +208,20 @@ class iamActionbar extends HTMLElement {
208
208
  const viewList = this.getAttribute('data-switchviews')?.split(',');
209
209
 
210
210
  viewList?.forEach((view) => {
211
- let icon = 'fa-grid-2';
211
+ let icon = 'fa-grid';
212
212
 
213
- if (view == 'list') icon = 'fa-grip-lines';
214
- else if (view == 'small') icon = 'fa-bars';
213
+ if (view == 'list') icon = 'fa-list';
214
+ else if (view == 'small') icon = 'fa-table';
215
215
 
216
- btns += `<button class="btn btn-action btn-compact btn-sm mb-0 fa-regular ${icon}">${view}</button>`;
216
+ btns += `<button class="tag tag--toggle mb-0" data-view="${view}"><i class="fa-regular ${icon} m-0"></i><span class="visually-hidden">${view}</span></button>`;
217
217
  });
218
218
 
219
219
  actionbarWrapper?.insertAdjacentHTML('afterbegin', `<div class="views m-0">${btns}</div>`);
220
220
  const views = this.shadowRoot?.querySelector('.views');
221
221
 
222
222
  views?.addEventListener('click', (event) => {
223
- if (event && event.target instanceof HTMLElement && event.target.closest('.btn-action')) {
224
- const btn = event.target.closest('.btn-action');
223
+ if (event && event.target instanceof HTMLElement && event.target.closest('.tag--toggle')) {
224
+ const btn = event.target.closest('.tag--toggle');
225
225
 
226
226
  this.setAttribute('data-view', btn.textContent);
227
227
 
@@ -249,6 +249,7 @@ class iamActionbar extends HTMLElement {
249
249
  if (event && event.target instanceof HTMLElement && event.target.closest('button[data-search]')) {
250
250
  searchBar.classList.toggle('show');
251
251
  searchBtn.toggleAttribute('aria-expanded');
252
+ searchInput.focus();
252
253
  }
253
254
  });
254
255
 
@@ -315,12 +315,27 @@ class iamAddressLookup extends HTMLElement {
315
315
  addresses.forEach((address) => {
316
316
  // Deal with agent platform response
317
317
  if (typeof address.attributes == 'object' && address.attributes.label) {
318
+ const attributes = {};
319
+
318
320
  if (address.id) address.attributes.id = address.id;
319
321
 
320
322
  if (address.relationships)
321
323
  address.attributes = Object.assign(address.attributes, address.relationships);
322
324
 
323
- const values = JSON.stringify(address.attributes);
325
+ Object.keys(address.attributes).forEach((key) => {
326
+
327
+ const attribute = address.attributes[key];
328
+
329
+ if(typeof attribute == 'object'){
330
+ attributes[key] = attribute?.id;
331
+ }
332
+ else {
333
+ attributes[key] = attribute;
334
+ }
335
+ });
336
+
337
+ const values = JSON.stringify(attributes);
338
+
324
339
  listString += `<option data-values='${values}' >${address.attributes.label}</option>`;
325
340
  } else if (typeof address.value == 'object') {
326
341
  if (address.id) address.attributes.id = address.id;