@iamproperty/components 3.7.0 → 3.7.1

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 (34) hide show
  1. package/assets/css/components/table.css +1 -1
  2. package/assets/css/components/table.css.map +1 -1
  3. package/assets/css/core.min.css +1 -1
  4. package/assets/css/core.min.css.map +1 -1
  5. package/assets/css/style.min.css +1 -1
  6. package/assets/css/style.min.css.map +1 -1
  7. package/assets/js/components/accordion/accordion.component.min.js +1 -1
  8. package/assets/js/components/card/card.component.min.js +1 -1
  9. package/assets/js/components/filterlist/filterlist.component.min.js +1 -1
  10. package/assets/js/components/header/header.component.min.js +1 -1
  11. package/assets/js/components/table/table.component.js +8 -1
  12. package/assets/js/components/table/table.component.min.js +13 -13
  13. package/assets/js/components/table/table.component.min.js.map +1 -1
  14. package/assets/js/components/tabs/tabs.component.min.js +1 -1
  15. package/assets/js/dynamic.min.js +2 -2
  16. package/assets/js/dynamic.min.js.map +1 -1
  17. package/assets/js/modules/applied-filters.js +1 -1
  18. package/assets/js/modules/dialogs.js +12 -1
  19. package/assets/js/modules/table.js +103 -29
  20. package/assets/js/scripts.bundle.js +19 -19
  21. package/assets/js/scripts.bundle.js.map +1 -1
  22. package/assets/js/scripts.bundle.min.js +2 -2
  23. package/assets/js/scripts.bundle.min.js.map +1 -1
  24. package/assets/js/tests/table.spec.js +19 -13
  25. package/assets/sass/components/table.scss +80 -53
  26. package/assets/sass/foundations/reboot.scss +7 -3
  27. package/assets/ts/components/table/table.component.ts +12 -1
  28. package/assets/ts/modules/applied-filters.ts +1 -1
  29. package/assets/ts/modules/dialogs.ts +16 -5
  30. package/assets/ts/modules/table.ts +139 -34
  31. package/assets/ts/tests/table.spec.ts +6 -6
  32. package/dist/components.es.js +758 -724
  33. package/dist/components.umd.js +21 -21
  34. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"dynamic.min.js","sources":["modules/helpers.js","modules/youtubevideo.js","modules/dialogs.js","modules/data-layer.js","modules/nav.js","modules/testimonial.js","modules/carousel.js","modules/form.js","dynamic.js"],"sourcesContent":["// @ts-nocheck\n/**\n * Global helper functions to help maintain and enhance framework elements.\n * @module Helpers\n */\n/**\n * Add global classes used by the CSS and later JavaScript.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addBodyClasses = (body) => {\n body.classList.add(\"js-enabled\");\n if (navigator.userAgent.indexOf('MSIE') !== -1 || navigator.appVersion.indexOf('Trident/') > 0) {\n body.classList.add(\"ie\");\n }\n return null;\n};\n/**\n * Add global events.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addGlobalEvents = (body) => {\n const checkElements = function (hash) {\n const label = document.querySelector(`label[for=\"${hash.replace('#', '')}\"]`);\n const summary = document.querySelector(hash + ' summary');\n const dialog = document.querySelector(`dialog${hash}`);\n if (label instanceof HTMLElement)\n label.click();\n else if (summary instanceof HTMLElement)\n summary.click();\n else if (dialog instanceof HTMLElement)\n dialog.showModal();\n };\n if (location.hash)\n checkElements(location.hash);\n window.addEventListener('hashchange', function () { checkElements(location.hash); }, false);\n addEventListener(\"popstate\", (event) => {\n if (event && event.state.type && event.state.type == \"pagination\") {\n let form = document.querySelector(`#${event.state.form}`);\n let pageInput = document.querySelector(`#${event.state.form} [data-pagination]`);\n if (pageInput)\n pageInput.value = event.state.page;\n else\n form.innerHTML += `<input name=\"page\" type=\"hidden\" data-pagination=\"true\" value=\"${event.state.page}\" />`;\n form.dispatchEvent(new Event(\"submit\"));\n }\n });\n return null;\n};\nexport const isNumeric = function (str) {\n if (typeof str != \"string\")\n return false; // we only process strings! \n return !isNaN(str) && // use type coercion to parse the _entirety_ of the string (`parseFloat` alone does not do this)...\n !isNaN(parseFloat(str)); // ...and ensure strings of whitespace fail\n};\nexport const zeroPad = (num, places) => String(num).padStart(places, '0');\nexport const ucfirst = (str) => str.charAt(0).toUpperCase() + str.slice(1);\nexport const ucwords = (str) => str.split(' ').map(s => ucfirst(s)).join(' ');\nexport const unsnake = (str) => str.replace(/_/g, ' ');\nexport const snake = (str) => str.replace(/ /g, '_');\nexport const safeID = function (str) {\n str = str.toLowerCase();\n str = snake(str);\n str = str.replace(/\\W/g, '');\n return str;\n};\n","// @ts-nocheck\n/**\n * Integrate YouTube videos as a way of hosting videos without the overhead and worry surrounding hosting vides. i.e. file sizes, performance and accessibility.\n */\nclass youtubeVideo {\n /** @param {Element} embed dom element */\n constructor(embed) {\n // If the scripts is already loaded then lets just create the embed\n if (document.body.classList.contains('youtubeLoaded')) {\n embed.addEventListener('click', function (e) {\n // loop parent nodes from the target to the delegation node\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('a')) {\n e.preventDefault();\n createEmbed(target);\n break;\n }\n }\n }, false);\n }\n else {\n this.loadScripts(embed, this.createEmbed);\n }\n }\n /**\n * Load the YouTube scripts before trying to create the embed\n * @param {HTMLElement} embed dom element\n */\n loadScripts(embed) {\n return new Promise((resolve, reject) => {\n const image = new Image();\n image.onload = function () {\n // This code loads the IFrame Player API code asynchronously.\n var tag = document.createElement('script');\n tag.src = \"https://www.youtube.com/iframe_api\";\n var firstScriptTag = document.getElementsByTagName('script')[0];\n firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n document.body.classList.add('youtubeLoaded');\n resolve(true);\n // script has loaded, you can now use it safely\n tag.onload = () => {\n embed.addEventListener('click', function (event) {\n console.log('click');\n // loop parent nodes from the target to the delegation node\n if (event && event.target instanceof HTMLElement && event.target.closest('a')) {\n event.preventDefault();\n createEmbed(event.target.closest('a'));\n }\n }, false);\n };\n };\n image.onerror = function () {\n reject(false);\n };\n image.src = \"https://youtube.com/favicon.ico\";\n });\n }\n}\nexport const createEmbed = function (target) {\n // If there is more than one video lets make sure there is only one playing at a time.\n if (typeof window.player != \"undefined\" && typeof window.player.pauseVideo == \"function\")\n window.player.pauseVideo();\n var video_id = target.getAttribute('data-id');\n var link_id = target.getAttribute('id');\n // create an id to pass t the script if one isn't present\n if (typeof link_id == 'undefined' || link_id == null) {\n var randLetter = String.fromCharCode(65 + Math.floor(Math.random() * 26));\n link_id = randLetter + Date.now();\n target.setAttribute('id', link_id);\n }\n // This function creates an <iframe> (and YouTube player) after the API code downloads.\n function onYouTubeIframeAPIReady() {\n window.player = new YT.Player(link_id, {\n height: '100%',\n width: '100%',\n videoId: video_id,\n playerVars: {\n 'modestbranding': 1,\n 'playsinline': 1,\n 'rel': 0,\n 'showinfo': 0\n },\n events: {\n 'onReady': onPlayerReady,\n 'onStateChange': onPlayerStateChange\n }\n });\n }\n onYouTubeIframeAPIReady();\n // The API will call this function when the video player is ready.\n function onPlayerReady(event) {\n // Play the video straight away\n event.target.playVideo();\n }\n // The API calls this function when the player's state changes.\n // The function indicates that when playing a video (state=1)\n var done = false;\n function onPlayerStateChange(event) {\n if (event.data == YT.PlayerState.PLAYING && !done) {\n var link = document.getElementById(link_id);\n link.classList.add('player-ready');\n done = true;\n }\n }\n};\nexport default youtubeVideo;\n","// @ts-nocheck\nimport { createEmbed } from \"./youtubevideo.js\";\nconst extendDialogs = (body) => {\n // Dialogs/modals\n body.addEventListener('click', (event) => {\n // Modal\n if (event && event.target instanceof HTMLElement && event.target.closest('[data-modal]')) {\n const button = event.target.closest('[data-modal]');\n const modalID = button.hasAttribute('data-modal') ? button.getAttribute('data-modal') : button.getAttribute('data-filter');\n const dialog = document.querySelector(`dialog#${modalID}`);\n createDialog(dialog);\n // Prevent the user from escaping the model when transactional\n if (dialog.querySelector(':scope > .mh-lg > form:last-child > button:last-child, :scope > .mh-lg > button:last-child') && !dialog.classList.contains('dialog--multi')) {\n dialog.addEventListener(\"cancel\", (e) => {\n e.preventDefault();\n });\n }\n // Create the video embed\n let videoButton = dialog.querySelector('.youtube-embed a');\n if (videoButton) {\n createEmbed(videoButton);\n }\n // Open the modal!\n dialog.showModal();\n dialog.focus();\n console.log(dialog.querySelector('button'));\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"openModal\",\n \"id\": modalID\n });\n }\n ;\n // Close modal\n if (event && event.target instanceof HTMLElement && event.target.closest('button.dialog__close')) {\n const dialog = event.target.closest('dialog[open]');\n event.preventDefault();\n dialog.close();\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n // Track default close buttons\n if (event && event.target instanceof HTMLElement && event.target.closest('button[formmethod=\"dialog\"]')) {\n const dialog = event.target.closest('dialog[open]');\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n // Close the modal when clicked on the backdrop\n if (event && event.target instanceof HTMLElement && event.target.closest('dialog[open]')) {\n const dialog = event.target.closest('dialog[open]');\n // Dont allow the backdrop to be clicked when transactional\n if (!dialog.querySelector(':scope > .mh-lg > form:last-child > button:last-child, :scope > .mh-lg > button:last-child') || dialog.classList.contains('dialog--multi')) {\n const dialogDimensions = dialog.getBoundingClientRect();\n if (event.clientX < dialogDimensions.left || event.clientX > dialogDimensions.right || event.clientY < dialogDimensions.top || event.clientY > dialogDimensions.bottom) {\n dialog.close();\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n }\n }\n // Popover\n if (event && event.target instanceof HTMLElement && event.target.closest('.dialog__wrapper > button')) {\n // Close existing open popover\n let btn = event.target.closest('.dialog__wrapper > button');\n let parent = event.target.closest('.dialog__wrapper > button').parentNode;\n let dataEvent = \"openPopover\";\n let popover = parent.querySelector(':scope > dialog');\n if (document.querySelector('dialog[open]') && document.querySelector('dialog[open]') != popover)\n document.querySelector('dialog[open]').close();\n if (popover.hasAttribute('open')) {\n popover.close();\n dataEvent = \"closePopover\";\n popover.removeAttribute('style');\n btn.classList.remove('active');\n }\n else {\n popover.show();\n btn.classList.add('active');\n var position = btn.getBoundingClientRect();\n let topOffset = position.top;\n let leftOffset = position.left;\n if (btn.closest('iam-table')) {\n let container = btn.closest('iam-table').parentNode.getBoundingClientRect();\n topOffset -= container.top;\n leftOffset -= container.left;\n }\n if (popover.classList.contains('dialog--fix')) {\n popover.setAttribute('style', `position:fixed;top: ${topOffset}px; left: ${leftOffset}px; margin: 3rem 0 0 0;`);\n }\n }\n // When the dialog is fixed it could dip under the viewport\n // Lets check the dimensions and transform it to appear above\n let boundingRec = popover.getBoundingClientRect();\n let popoverBottom = boundingRec.bottom - window.scrollY;\n let windowPos = window.innerHeight - window.scrollY;\n if (popoverBottom > windowPos) {\n let currentStyle = popover.getAttribute('style');\n popover.setAttribute('style', currentStyle + `transform: translate(0, calc(-100% - 4rem))`);\n }\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": dataEvent,\n \"id\": btn.textContent\n });\n }\n ;\n });\n return null;\n};\nexport const createDialog = (dialog) => {\n // Multi dialog\n if (dialog.classList.contains('dialog--multi') && !dialog.querySelector(':scope > .steps')) {\n createMultiFormDialog(dialog);\n }\n if (!dialog.querySelector(':scope > .mh-lg') && !dialog.classList.contains('dialog--multi')) {\n dialog.innerHTML = `<div class=\"mh-lg\">${dialog.innerHTML}</div>`;\n let dialogContent = dialog.querySelector('.mh-lg');\n let titleElement = dialog.querySelector('.mh-lg :is(.h1,.h2,.h3,.h4,.h5,.h6)');\n if (titleElement) {\n let optionalElement = titleElement.previousSibling;\n dialogContent.before(titleElement);\n if (optionalElement)\n titleElement.before(optionalElement);\n }\n }\n // Create close button is needed\n if (!dialog.querySelector(':scope > button:first-child'))\n dialog.innerHTML = `<button class=\"dialog__close\">Close</button>${dialog.innerHTML}`;\n};\nconst createMultiFormDialog = (dialog) => {\n let buttons = \"\";\n let fieldsets = Array.from(dialog.querySelectorAll('fieldset[data-title]'));\n fieldsets.forEach((fieldset, index) => {\n buttons += `<button data-title=\"${fieldset.getAttribute('data-title')}\" type=\"button\" class=\"${index == 0 ? \"active\" : \"\"}\">${fieldset.getAttribute('data-title')}</button>`;\n const btnWrapper = document.createElement(\"div\");\n btnWrapper.classList.add('btn--wrapper');\n fieldset.appendChild(btnWrapper);\n if (index != 0)\n btnWrapper.innerHTML += `<button data-title=\"${fieldsets[index - 1].getAttribute('data-title')}\" class=\"btn btn-secondary mb-0\" type=\"button\">Previous</button>`;\n if (index != fieldsets.length - 1)\n btnWrapper.innerHTML += `<button data-title=\"${fieldsets[index + 1].getAttribute('data-title')}\" class=\"btn btn-primary mb-0\" type=\"button\">Next</button>`;\n if (index == fieldsets.length - 1)\n btnWrapper.innerHTML += `<button class=\"btn btn-primary mb-0\">Submit</button>`;\n });\n dialog.innerHTML = `<div class=\"steps bg-primary\">${buttons}</div>${dialog.innerHTML}`;\n dialog.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('button[data-title]')) {\n const button = event.target.closest('button[data-title]');\n const fieldset = dialog.querySelector(`fieldset[data-title=\"${button.getAttribute('data-title')}\"]`);\n const step = dialog.querySelector(`.steps button[data-title=\"${button.getAttribute('data-title')}\"]`);\n Array.from(dialog.querySelectorAll('button')).forEach((button, index) => {\n button.classList.remove('active');\n });\n Array.from(dialog.querySelectorAll('fieldset')).forEach((button, index) => {\n button.classList.remove('active');\n });\n step.classList.add('active');\n fieldset.classList.add('active');\n }\n ;\n return null;\n });\n};\nexport default extendDialogs;\n","function createDataLayer() {\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"Pageview\",\n \"pageTitle\": document.title\n });\n // Global events to track\n document.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('[open] summary')) {\n window.dataLayer.push({\n \"event\": \"closeDetails\",\n // @ts-ignore: Object is possibly 'null'.\n \"detailsTitle\": event.target.closest('summary').textContent\n });\n }\n else if (event && event.target instanceof HTMLElement && event.target.closest('summary')) {\n window.dataLayer.push({\n \"event\": \"openDetails\",\n // @ts-ignore: Object is possibly 'null'.\n \"detailsTitle\": event.target.closest('summary').textContent\n });\n }\n if (event && event.target instanceof HTMLElement && event.target.closest('a')) {\n window.dataLayer.push({\n \"event\": \"linkClicked\",\n // @ts-ignore: Object is possibly 'null'.\n \"linkText\": event.target.closest('a').hasAttribute('title') ? event.target.closest('a').getAttribute('title') : event.target.closest('a').textContent,\n // @ts-ignore: Object is possibly 'null'.\n \"class\": (event.target.closest('a').hasAttribute('class') ? event.target.closest('a').getAttribute('class') : ''),\n // @ts-ignore: Object is possibly 'null'.\n \"href\": event.target.closest('a').getAttribute('href')\n });\n }\n if (event && event.target instanceof HTMLElement && event.target.closest('button')) {\n window.dataLayer.push({\n \"event\": \"buttonClicked\",\n // @ts-ignore: Object is possibly 'null'.\n \"buttonText\": event.target.closest('button').textContent,\n // @ts-ignore: Object is possibly 'null'.\n \"class\": (event.target.closest('button').hasAttribute('class') ? event.target.closest('button').getAttribute('class') : '')\n });\n }\n });\n}\nexport default createDataLayer;\n","// @ts-nocheck\nconst navbar = (element) => {\n Array.from(element.querySelectorAll('details')).forEach((detail, index) => {\n detail.addEventListener('mouseenter', function (e) {\n if (window.matchMedia('(min-width: 62em)').matches)\n detail.setAttribute('open', 'true');\n }, false);\n detail.addEventListener('mouseleave', function (e) {\n if (window.matchMedia('(min-width: 62em)').matches)\n detail.removeAttribute('open');\n }, false);\n });\n if ('IntersectionObserver' in window) {\n const observer = new IntersectionObserver(([e]) => e.target.classList.toggle(\"is-stuck\", e.intersectionRatio < 1), { threshold: [1] });\n observer.observe(element);\n }\n};\nexport default navbar;\n","// @ts-nocheck\nfunction testimonial(testimonialElement) {\n var scrollTimeout;\n const imagesCarousel = testimonialElement.querySelector('.testimonial__images');\n const itemCount = imagesCarousel.querySelectorAll('img').length;\n // If we only have 1 item lets not bother doing anything else\n if (itemCount == 1) {\n return false;\n }\n testimonialElement.classList.add('testimonial--multi');\n // Set where the buttons go to\n const setButtons = function (scrollTo) {\n const nextButton = testimonialElement.querySelector('.btn-next');\n const prevButton = testimonialElement.querySelector('.btn-prev');\n nextButton.setAttribute('data-go', scrollTo + 1);\n prevButton.setAttribute('data-go', scrollTo - 1);\n nextButton.removeAttribute('disabled');\n prevButton.removeAttribute('disabled');\n if (scrollTo == 1)\n prevButton.setAttribute('disabled', true);\n else if (scrollTo == itemCount)\n nextButton.setAttribute('disabled', true);\n };\n // On scroll we need to make sure the buttons get corrected and the next testimonial is shown\n imagesCarousel.addEventListener('scroll', function (e) {\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(function () {\n let scrollWidth = imagesCarousel.scrollWidth;\n let scrollHeight = imagesCarousel.scrollHeight;\n let scrollLeft = imagesCarousel.scrollLeft;\n let scrollDown = imagesCarousel.scrollTop;\n let scrollTo = Math.round((scrollLeft / scrollWidth) * itemCount) + 1;\n // Change in scroll direction\n if (scrollLeft == 0 && scrollDown != 0)\n scrollTo = Math.round((scrollDown / scrollHeight) * itemCount) + 1;\n testimonialElement.setAttribute('data-show', scrollTo);\n setButtons(scrollTo);\n }, 300);\n }, false);\n // when the buttons are used we need to make sure the carousel scrolls to the correct place\n testimonialElement.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('[data-go]')) {\n let scrollTo = parseInt(target.getAttribute('data-go'));\n let scrollDown = 0;\n let scrollLeft = 0;\n let scrollWidth = imagesCarousel.scrollWidth;\n let scrollHeight = imagesCarousel.scrollHeight;\n if (scrollWidth > scrollHeight)\n scrollLeft = Math.floor(scrollWidth * ((scrollTo - 1) / itemCount));\n else\n scrollDown = Math.floor(scrollHeight * ((scrollTo - 1) / itemCount));\n // Trigger the scroll\n imagesCarousel.scroll({\n top: scrollDown,\n left: scrollLeft,\n behavior: 'smooth'\n });\n break;\n }\n }\n }, false);\n}\nexport default testimonial;\n","// @ts-nocheck\nfunction carousel(carouselElement) {\n var scrollTimeout;\n let carouselInner = carouselElement.querySelector('.carousel__inner');\n let itemCount = carouselElement.querySelectorAll('.carousel__item').length;\n let cols = carouselElement.getAttribute('data-cols');\n let smCols = carouselElement.getAttribute('data-sm-cols');\n let mdCols = carouselElement.getAttribute('data-md-cols');\n carouselElement.querySelector('.carousel__controls a').classList.add('active');\n // On scroll we need to make sure the buttons get corrected and the next testimonial is shown\n carouselInner.addEventListener('scroll', function (e) {\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(function () {\n let scrollArea = carouselInner.clientWidth;\n let scrollWidth = carouselInner.scrollWidth;\n let scrollLeft = carouselInner.scrollLeft;\n let targetSlide = Math.round((scrollLeft / scrollWidth) * itemCount) + 1;\n let lastItemOffset = carouselElement.querySelector('.carousel__item:last-child').offsetLeft;\n Array.from(carouselElement.querySelectorAll('.carousel__controls a')).forEach((link, index) => {\n link.classList.remove('active');\n });\n carouselElement.querySelector('.control-' + targetSlide).classList.add('active');\n // Disable the previous button\n if (targetSlide == 1)\n carouselElement.querySelector('.btn-prev').setAttribute('disabled', 'disabled');\n else\n carouselElement.querySelector('.btn-prev').removeAttribute('disabled');\n // Disable the next button if the last item is in view\n if (carouselInner.scrollLeft + scrollArea > lastItemOffset)\n carouselElement.querySelector('.btn-next').setAttribute('disabled', 'disabled');\n else\n carouselElement.querySelector('.btn-next').removeAttribute('disabled');\n }, 100);\n }, false);\n // when the buttons are used we need to make sure the carousel scrolls to the correct place\n carouselElement.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('.carousel__controls a')) {\n e.preventDefault();\n Array.from(carouselElement.querySelectorAll('.carousel__controls a')).forEach((link, index) => {\n link.classList.remove('active');\n });\n target.classList.add('active');\n const el = document.querySelector(target.getAttribute('href'));\n carouselInner.scroll({\n top: 0,\n left: el.offsetLeft,\n behavior: 'smooth'\n });\n break;\n }\n }\n }, false);\n carouselElement.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('.btn-next, .btn-prev')) {\n e.preventDefault();\n let scrollTo = target.classList.contains('btn-prev') ? carouselInner.scrollLeft - carouselInner.clientWidth : carouselInner.scrollLeft + carouselInner.clientWidth;\n carouselInner.scroll({\n top: 0,\n left: scrollTo,\n behavior: 'smooth'\n });\n break;\n }\n }\n }, false);\n // Add responsive hide button classes\n if (itemCount == 1)\n carouselElement.classList.add('hide-btns');\n if (smCols >= itemCount)\n carouselElement.classList.add('hide-sm-btns');\n if (mdCols >= itemCount)\n carouselElement.classList.add('hide-md-btns');\n}\nexport default carousel;\n","// @ts-nocheck\n// Create a link between two input/selects with one acting as setting a minimum value and the second a maximum\n// The link between the two will prevent the max input field form setting a lower value than the min and vice versa\nfunction inputRange(inputWrapper) {\n inputWrapper.addEventListener('change', function (e) {\n var min = parseInt(inputWrapper.querySelector('[data-min] select,[data-min] input').value);\n var max = parseInt(inputWrapper.querySelector('[data-max] select,[data-max] input').value);\n // Set attributes for input fields\n Array.from(inputWrapper.querySelectorAll('[data-min] input')).forEach((input, index) => {\n input.setAttribute('max', max);\n });\n Array.from(inputWrapper.querySelectorAll('[data-max] input')).forEach((input, index) => {\n input.setAttribute('min', min);\n });\n // Hide select options if they are higher or lower than the min and max values\n Array.from(inputWrapper.querySelectorAll('[data-min] select option')).forEach((option, index) => {\n if (parseInt(option.getAttribute('value')) > max)\n option.classList.add('d-none');\n else\n option.classList.remove('d-none');\n });\n Array.from(inputWrapper.querySelectorAll('[data-max] select option')).forEach((option, index) => {\n if (parseInt(option.getAttribute('value')) < min)\n option.classList.add('d-none');\n else\n option.classList.remove('d-none');\n });\n }, false);\n}\nfunction inputRedirect(inputWrapper) {\n inputWrapper.addEventListener('change', function (e) {\n if (inputWrapper.matches('[data-value-if]')) {\n const url = inputWrapper.getAttribute('data-redirect');\n const desiredValue = inputWrapper.getAttribute('data-value-if');\n if (inputWrapper.value == desiredValue)\n document.location.href = url;\n }\n else {\n if (typeof inputWrapper.value != \"undefined\")\n document.location.href = inputWrapper.value;\n }\n }, false);\n}\n//\nfunction multipleFileUploads(wrapper) {\n const fileTenplate = wrapper.querySelector('.row');\n const clone = fileTenplate.cloneNode(true);\n const addButton = wrapper.querySelector('[data-add]');\n wrapper.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('[data-add]')) { // Add a new row upload file input fields\n const tempClone = clone.cloneNode(true);\n wrapper.insertBefore(tempClone, target);\n if (addButton.matches('[data-maxfiles]') && Array.from(wrapper.querySelectorAll(':scope > .row')).length >= addButton.dataset.maxfiles)\n addButton.setAttribute('disabled', 'disabled');\n break;\n }\n if (target.matches('[data-delete]')) { // Delete the current row\n let row = target.closest('.row');\n row.remove();\n if (addButton.matches('[data-maxfiles]') && Array.from(wrapper.querySelectorAll(':scope > .row')).length < addButton.dataset.maxfiles)\n addButton.removeAttribute('disabled');\n break;\n }\n }\n }, false);\n}\n// Acts as an overall initialise function to trigger other functions.\nfunction form(formElement) {\n // Check for input range groups\n Array.from(formElement.querySelectorAll('[data-input-range]')).forEach((arrayElement, index) => {\n inputRange(arrayElement);\n });\n Array.from(formElement.querySelectorAll('[data-redirect]')).forEach((arrayElement, index) => {\n inputRedirect(arrayElement);\n });\n Array.from(formElement.querySelectorAll('.multiple-file-uploads')).forEach((arrayElement, index) => {\n multipleFileUploads(arrayElement);\n });\n // Check the file size of a file when uploaded in case it exceeds the max file size set\n formElement.addEventListener('change', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('[type=\"file\"][data-filesize]') && target.files && target.files[0]) {\n const maxAllowedSize = target.dataset.filesize;\n if (target.files[0].size > maxAllowedSize) {\n target.value = '';\n alert('File too large');\n }\n break;\n }\n }\n }, false);\n // When a form is updated we may want to update some of the existing input fields; setting active fields when some data is selected.\n formElement.addEventListener('change', function (e) {\n // Remove disabled attribute when a pre-selected input field equals a certain value\n Array.from(formElement.querySelectorAll('select[data-activeif][data-equals],input[data-activeif][data-equals]')).forEach((arrayElement, index) => {\n let group = arrayElement.closest('[data-group]') ? arrayElement.closest('[data-group]') : formElement;\n let selector = arrayElement.dataset.activeif;\n let value = arrayElement.dataset.equals;\n let testElement = group.querySelector(`select[data-id=\"${selector}\"],input[data-id=\"${selector}\"]`);\n if (testElement.value == value) {\n arrayElement.removeAttribute('disabled');\n }\n else {\n arrayElement.setAttribute('disabled', 'disabled');\n arrayElement.value = '';\n }\n });\n // Show this input wrapper when a pre-selected input field equals a certain value\n Array.from(formElement.querySelectorAll('.form-control__wrapper[data-displayif][data-equals]')).forEach((arrayElement, index) => {\n let group = arrayElement.closest('[data-group]') ? arrayElement.closest('[data-group]') : formElement;\n let selector = arrayElement.dataset.activeif;\n let value = arrayElement.dataset.equals;\n let testElement = group.querySelector(`select[data-id=\"${selector}\"],input[data-id=\"${selector}\"]`);\n if (testElement.value == value)\n arrayElement.classList.remove('d-none');\n else\n arrayElement.classList.add('d-none');\n });\n }, false);\n}\nexport default form;\n","// @ts-nocheck\n// Modules\nimport * as helpers from '../js/modules/helpers.js';\nimport extendDialogs from '../js/modules/dialogs.js';\nimport createDataLayer from '../js/modules/data-layer.js';\nimport nav from '../js/modules/nav.js';\n//import accordion from './modules/accordion.js'\nimport testimonial from '../js/modules/testimonial.js';\nimport carousel from '../js/modules/carousel.js';\nimport form from '../js/modules/form.js';\nimport youtubeVideo from '../js/modules/youtubevideo.js';\nconst components = ['accordion', 'header', 'tabs', 'table', 'card', 'pagination', 'filterlist', 'applied-filters'];\nconst prefix = \"iam\";\nconst options = {\n rootMargin: '50px',\n threshold: 0.1\n};\nconst componentExt = \".component.min.js\";\n// Load components - Each component will load once the first of its type has been loaded\ncomponents.forEach((component) => {\n console.log(component);\n if (document.getElementsByTagName(`${prefix}-${component}`).length === 0)\n return;\n let callback = (entries) => {\n entries.forEach((entry) => {\n if (entry.intersectionRatio > 0) {\n console.log(component);\n import(`./components/${component}/${component}${componentExt}`).then(module => {\n if (!window.customElements.get(`${prefix}-${component}`))\n window.customElements.define(`${prefix}-${component}`, module.default);\n }).catch((err) => {\n console.log(err.message);\n });\n intObserver.unobserve(entry.target);\n }\n });\n };\n const intObserver = new IntersectionObserver(callback, options);\n intObserver.observe(document.getElementsByTagName(`${prefix}-${component}`)[0]);\n});\n// Attach classes to dom elements\ndocument.addEventListener(\"DOMContentLoaded\", function () {\n createDataLayer();\n // Global stuff\n helpers.addBodyClasses(document.body);\n helpers.addGlobalEvents(document.body);\n //helpers.checkElements(document.body);\n extendDialogs(document.body);\n // ANav\n Array.from(document.querySelectorAll('.nav')).forEach((arrayElement) => {\n nav(arrayElement);\n });\n // Testimonial\n Array.from(document.querySelectorAll('.testimonial')).forEach((arrayElement) => {\n testimonial(arrayElement);\n });\n // Carousel\n Array.from(document.querySelectorAll('.carousel')).forEach((arrayElement) => {\n carousel(arrayElement);\n });\n // Form\n Array.from(document.querySelectorAll('form')).forEach((arrayElement) => {\n form(arrayElement);\n });\n // YouTube videos\n Array.from(document.querySelectorAll('.youtube-embed')).forEach((arrayElement) => {\n console.log(arrayElement);\n new youtubeVideo(arrayElement);\n });\n window.addEventListener('hashchange', function () {\n const hash = location.hash.replace('#', '');\n const label = document.querySelector(`label[for=\"${hash}\"]`);\n if (label instanceof HTMLElement)\n label.click();\n }, false);\n});\n"],"names":["addBodyClasses","body","addGlobalEvents","checkElements","hash","label","summary","dialog","event","form","pageInput","youtubeVideo","embed","target","createEmbed","resolve","reject","image","tag","firstScriptTag","video_id","link_id","randLetter","onYouTubeIframeAPIReady","onPlayerReady","onPlayerStateChange","done","link","extendDialogs","button","modalID","createDialog","e","videoButton","dialogDimensions","btn","parent","dataEvent","popover","position","topOffset","leftOffset","container","popoverBottom","windowPos","currentStyle","createMultiFormDialog","dialogContent","titleElement","optionalElement","buttons","fieldsets","fieldset","index","btnWrapper","step","createDataLayer","navbar","element","detail","testimonial","testimonialElement","scrollTimeout","imagesCarousel","itemCount","setButtons","scrollTo","nextButton","prevButton","scrollWidth","scrollHeight","scrollLeft","scrollDown","carousel","carouselElement","carouselInner","smCols","mdCols","scrollArea","targetSlide","lastItemOffset","el","inputRange","inputWrapper","min","max","input","option","inputRedirect","url","desiredValue","multipleFileUploads","wrapper","clone","addButton","tempClone","formElement","arrayElement","maxAllowedSize","group","selector","value","components","prefix","options","component","callback","entries","entry","module","err","intObserver","helpers.addBodyClasses","helpers.addGlobalEvents","nav"],"mappings":"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"}
1
+ {"version":3,"file":"dynamic.min.js","sources":["modules/helpers.js","modules/youtubevideo.js","modules/dialogs.js","modules/data-layer.js","modules/nav.js","modules/testimonial.js","modules/carousel.js","modules/form.js","dynamic.js"],"sourcesContent":["// @ts-nocheck\n/**\n * Global helper functions to help maintain and enhance framework elements.\n * @module Helpers\n */\n/**\n * Add global classes used by the CSS and later JavaScript.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addBodyClasses = (body) => {\n body.classList.add(\"js-enabled\");\n if (navigator.userAgent.indexOf('MSIE') !== -1 || navigator.appVersion.indexOf('Trident/') > 0) {\n body.classList.add(\"ie\");\n }\n return null;\n};\n/**\n * Add global events.\n * @param {HTMLElement} body Dom element, this doesn't have to be the body but it is recommended.\n */\nexport const addGlobalEvents = (body) => {\n const checkElements = function (hash) {\n const label = document.querySelector(`label[for=\"${hash.replace('#', '')}\"]`);\n const summary = document.querySelector(hash + ' summary');\n const dialog = document.querySelector(`dialog${hash}`);\n if (label instanceof HTMLElement)\n label.click();\n else if (summary instanceof HTMLElement)\n summary.click();\n else if (dialog instanceof HTMLElement)\n dialog.showModal();\n };\n if (location.hash)\n checkElements(location.hash);\n window.addEventListener('hashchange', function () { checkElements(location.hash); }, false);\n addEventListener(\"popstate\", (event) => {\n if (event && event.state.type && event.state.type == \"pagination\") {\n let form = document.querySelector(`#${event.state.form}`);\n let pageInput = document.querySelector(`#${event.state.form} [data-pagination]`);\n if (pageInput)\n pageInput.value = event.state.page;\n else\n form.innerHTML += `<input name=\"page\" type=\"hidden\" data-pagination=\"true\" value=\"${event.state.page}\" />`;\n form.dispatchEvent(new Event(\"submit\"));\n }\n });\n return null;\n};\nexport const isNumeric = function (str) {\n if (typeof str != \"string\")\n return false; // we only process strings! \n return !isNaN(str) && // use type coercion to parse the _entirety_ of the string (`parseFloat` alone does not do this)...\n !isNaN(parseFloat(str)); // ...and ensure strings of whitespace fail\n};\nexport const zeroPad = (num, places) => String(num).padStart(places, '0');\nexport const ucfirst = (str) => str.charAt(0).toUpperCase() + str.slice(1);\nexport const ucwords = (str) => str.split(' ').map(s => ucfirst(s)).join(' ');\nexport const unsnake = (str) => str.replace(/_/g, ' ');\nexport const snake = (str) => str.replace(/ /g, '_');\nexport const safeID = function (str) {\n str = str.toLowerCase();\n str = snake(str);\n str = str.replace(/\\W/g, '');\n return str;\n};\n","// @ts-nocheck\n/**\n * Integrate YouTube videos as a way of hosting videos without the overhead and worry surrounding hosting vides. i.e. file sizes, performance and accessibility.\n */\nclass youtubeVideo {\n /** @param {Element} embed dom element */\n constructor(embed) {\n // If the scripts is already loaded then lets just create the embed\n if (document.body.classList.contains('youtubeLoaded')) {\n embed.addEventListener('click', function (e) {\n // loop parent nodes from the target to the delegation node\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('a')) {\n e.preventDefault();\n createEmbed(target);\n break;\n }\n }\n }, false);\n }\n else {\n this.loadScripts(embed, this.createEmbed);\n }\n }\n /**\n * Load the YouTube scripts before trying to create the embed\n * @param {HTMLElement} embed dom element\n */\n loadScripts(embed) {\n return new Promise((resolve, reject) => {\n const image = new Image();\n image.onload = function () {\n // This code loads the IFrame Player API code asynchronously.\n var tag = document.createElement('script');\n tag.src = \"https://www.youtube.com/iframe_api\";\n var firstScriptTag = document.getElementsByTagName('script')[0];\n firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n document.body.classList.add('youtubeLoaded');\n resolve(true);\n // script has loaded, you can now use it safely\n tag.onload = () => {\n embed.addEventListener('click', function (event) {\n console.log('click');\n // loop parent nodes from the target to the delegation node\n if (event && event.target instanceof HTMLElement && event.target.closest('a')) {\n event.preventDefault();\n createEmbed(event.target.closest('a'));\n }\n }, false);\n };\n };\n image.onerror = function () {\n reject(false);\n };\n image.src = \"https://youtube.com/favicon.ico\";\n });\n }\n}\nexport const createEmbed = function (target) {\n // If there is more than one video lets make sure there is only one playing at a time.\n if (typeof window.player != \"undefined\" && typeof window.player.pauseVideo == \"function\")\n window.player.pauseVideo();\n var video_id = target.getAttribute('data-id');\n var link_id = target.getAttribute('id');\n // create an id to pass t the script if one isn't present\n if (typeof link_id == 'undefined' || link_id == null) {\n var randLetter = String.fromCharCode(65 + Math.floor(Math.random() * 26));\n link_id = randLetter + Date.now();\n target.setAttribute('id', link_id);\n }\n // This function creates an <iframe> (and YouTube player) after the API code downloads.\n function onYouTubeIframeAPIReady() {\n window.player = new YT.Player(link_id, {\n height: '100%',\n width: '100%',\n videoId: video_id,\n playerVars: {\n 'modestbranding': 1,\n 'playsinline': 1,\n 'rel': 0,\n 'showinfo': 0\n },\n events: {\n 'onReady': onPlayerReady,\n 'onStateChange': onPlayerStateChange\n }\n });\n }\n onYouTubeIframeAPIReady();\n // The API will call this function when the video player is ready.\n function onPlayerReady(event) {\n // Play the video straight away\n event.target.playVideo();\n }\n // The API calls this function when the player's state changes.\n // The function indicates that when playing a video (state=1)\n var done = false;\n function onPlayerStateChange(event) {\n if (event.data == YT.PlayerState.PLAYING && !done) {\n var link = document.getElementById(link_id);\n link.classList.add('player-ready');\n done = true;\n }\n }\n};\nexport default youtubeVideo;\n","// @ts-nocheck\nimport { createEmbed } from \"./youtubevideo.js\";\nconst extendDialogs = (body) => {\n // Dialogs/modals\n body.addEventListener('click', (event) => {\n // Modal\n if (event && event.target instanceof HTMLElement && event.target.closest('[data-modal]')) {\n const button = event.target.closest('[data-modal]');\n const modalID = button.hasAttribute('data-modal') ? button.getAttribute('data-modal') : button.getAttribute('data-filter');\n const dialog = document.querySelector(`dialog#${modalID}`);\n createDialog(dialog);\n // Prevent the user from escaping the model when transactional\n if (dialog.querySelector(':scope > .mh-lg > form:last-child > button:last-child, :scope > .mh-lg > button:last-child') && !dialog.classList.contains('dialog--multi')) {\n dialog.addEventListener(\"cancel\", (e) => {\n e.preventDefault();\n });\n }\n // Create the video embed\n let videoButton = dialog.querySelector('.youtube-embed a');\n if (videoButton) {\n createEmbed(videoButton);\n }\n // Open the modal!\n dialog.showModal();\n dialog.focus();\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"openModal\",\n \"id\": modalID\n });\n }\n ;\n // Close modal\n if (event && event.target instanceof HTMLElement && event.target.closest('button.dialog__close')) {\n const dialog = event.target.closest('dialog[open]');\n event.preventDefault();\n dialog.close();\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.classList.remove('active');\n });\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n // Track default close buttons\n if (event && event.target instanceof HTMLElement && event.target.closest('button[formmethod=\"dialog\"]')) {\n const dialog = event.target.closest('dialog[open]');\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.classList.remove('active');\n });\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n // Close the modal when clicked on the backdrop\n if (event && event.target instanceof HTMLElement && event.target.closest('dialog[open]')) {\n const dialog = event.target.closest('dialog[open]');\n // Dont allow the backdrop to be clicked when transactional\n if (!dialog.querySelector(':scope > .mh-lg > form:last-child > button:last-child, :scope > .mh-lg > button:last-child') || dialog.classList.contains('dialog--multi')) {\n const dialogDimensions = dialog.getBoundingClientRect();\n if (event.clientX < dialogDimensions.left || event.clientX > dialogDimensions.right || event.clientY < dialogDimensions.top || event.clientY > dialogDimensions.bottom) {\n dialog.close();\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"closeModal\",\n \"id\": dialog.getAttribute('id')\n });\n }\n }\n }\n // Popover\n if (event && event.target instanceof HTMLElement && event.target.closest('.dialog__wrapper > button')) {\n // Close existing open popover\n let btn = event.target.closest('.dialog__wrapper > button');\n let parent = event.target.closest('.dialog__wrapper > button').parentNode;\n let dataEvent = \"openPopover\";\n let popover = parent.querySelector(':scope > dialog');\n if (document.querySelector('dialog[open]') && document.querySelector('dialog[open]') != popover)\n document.querySelector('dialog[open]').close();\n // Remove active class from exiting active buttons\n Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {\n btnElement.classList.remove('active');\n });\n if (popover.hasAttribute('open')) {\n popover.close();\n dataEvent = \"closePopover\";\n popover.removeAttribute('style');\n btn.classList.remove('active');\n }\n else {\n popover.show();\n btn.classList.add('active');\n var position = btn.getBoundingClientRect();\n let topOffset = position.top;\n let leftOffset = position.left;\n if (btn.closest('iam-table')) {\n let container = btn.closest('iam-table').parentNode.getBoundingClientRect();\n topOffset -= container.top;\n leftOffset -= container.left;\n }\n if (popover.classList.contains('dialog--fix')) {\n popover.setAttribute('style', `position:fixed;top: ${topOffset}px; left: ${leftOffset}px; margin: 3rem 0 0 0;`);\n }\n }\n // When the dialog is fixed it could dip under the viewport\n // Lets check the dimensions and transform it to appear above\n let boundingRec = popover.getBoundingClientRect();\n let popoverBottom = boundingRec.bottom - window.scrollY;\n let windowPos = window.innerHeight - window.scrollY;\n if (popoverBottom > windowPos) {\n let currentStyle = popover.getAttribute('style');\n popover.setAttribute('style', currentStyle + `transform: translate(0, calc(-100% - 4rem))`);\n }\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": dataEvent,\n \"id\": btn.textContent\n });\n }\n ;\n });\n return null;\n};\nexport const createDialog = (dialog) => {\n // Multi dialog\n if (dialog.classList.contains('dialog--multi') && !dialog.querySelector(':scope > .steps')) {\n createMultiFormDialog(dialog);\n }\n if (!dialog.querySelector(':scope > .mh-lg') && !dialog.classList.contains('dialog--multi')) {\n dialog.innerHTML = `<div class=\"mh-lg\">${dialog.innerHTML}</div>`;\n let dialogContent = dialog.querySelector('.mh-lg');\n let titleElement = dialog.querySelector('.mh-lg :is(.h1,.h2,.h3,.h4,.h5,.h6)');\n if (titleElement) {\n let optionalElement = titleElement.previousSibling;\n dialogContent.before(titleElement);\n if (optionalElement)\n titleElement.before(optionalElement);\n }\n }\n // Create close button is needed\n if (!dialog.querySelector(':scope > button:first-child'))\n dialog.innerHTML = `<button class=\"dialog__close\">Close</button>${dialog.innerHTML}`;\n};\nconst createMultiFormDialog = (dialog) => {\n let buttons = \"\";\n let fieldsets = Array.from(dialog.querySelectorAll('fieldset[data-title]'));\n fieldsets.forEach((fieldset, index) => {\n buttons += `<button data-title=\"${fieldset.getAttribute('data-title')}\" type=\"button\" class=\"${index == 0 ? \"active\" : \"\"}\">${fieldset.getAttribute('data-title')}</button>`;\n const btnWrapper = document.createElement(\"div\");\n btnWrapper.classList.add('btn--wrapper');\n fieldset.appendChild(btnWrapper);\n if (index != 0)\n btnWrapper.innerHTML += `<button data-title=\"${fieldsets[index - 1].getAttribute('data-title')}\" class=\"btn btn-secondary mb-0\" type=\"button\">Previous</button>`;\n if (index != fieldsets.length - 1)\n btnWrapper.innerHTML += `<button data-title=\"${fieldsets[index + 1].getAttribute('data-title')}\" class=\"btn btn-primary mb-0\" type=\"button\">Next</button>`;\n if (index == fieldsets.length - 1)\n btnWrapper.innerHTML += `<button class=\"btn btn-primary mb-0\">Submit</button>`;\n });\n dialog.innerHTML = `<div class=\"steps bg-primary\">${buttons}</div>${dialog.innerHTML}`;\n dialog.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('button[data-title]')) {\n const button = event.target.closest('button[data-title]');\n const fieldset = dialog.querySelector(`fieldset[data-title=\"${button.getAttribute('data-title')}\"]`);\n const step = dialog.querySelector(`.steps button[data-title=\"${button.getAttribute('data-title')}\"]`);\n Array.from(dialog.querySelectorAll('button')).forEach((button, index) => {\n button.classList.remove('active');\n });\n Array.from(dialog.querySelectorAll('fieldset')).forEach((button, index) => {\n button.classList.remove('active');\n });\n step.classList.add('active');\n fieldset.classList.add('active');\n }\n ;\n return null;\n });\n};\nexport default extendDialogs;\n","function createDataLayer() {\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push({\n \"event\": \"Pageview\",\n \"pageTitle\": document.title\n });\n // Global events to track\n document.addEventListener('click', (event) => {\n if (event && event.target instanceof HTMLElement && event.target.closest('[open] summary')) {\n window.dataLayer.push({\n \"event\": \"closeDetails\",\n // @ts-ignore: Object is possibly 'null'.\n \"detailsTitle\": event.target.closest('summary').textContent\n });\n }\n else if (event && event.target instanceof HTMLElement && event.target.closest('summary')) {\n window.dataLayer.push({\n \"event\": \"openDetails\",\n // @ts-ignore: Object is possibly 'null'.\n \"detailsTitle\": event.target.closest('summary').textContent\n });\n }\n if (event && event.target instanceof HTMLElement && event.target.closest('a')) {\n window.dataLayer.push({\n \"event\": \"linkClicked\",\n // @ts-ignore: Object is possibly 'null'.\n \"linkText\": event.target.closest('a').hasAttribute('title') ? event.target.closest('a').getAttribute('title') : event.target.closest('a').textContent,\n // @ts-ignore: Object is possibly 'null'.\n \"class\": (event.target.closest('a').hasAttribute('class') ? event.target.closest('a').getAttribute('class') : ''),\n // @ts-ignore: Object is possibly 'null'.\n \"href\": event.target.closest('a').getAttribute('href')\n });\n }\n if (event && event.target instanceof HTMLElement && event.target.closest('button')) {\n window.dataLayer.push({\n \"event\": \"buttonClicked\",\n // @ts-ignore: Object is possibly 'null'.\n \"buttonText\": event.target.closest('button').textContent,\n // @ts-ignore: Object is possibly 'null'.\n \"class\": (event.target.closest('button').hasAttribute('class') ? event.target.closest('button').getAttribute('class') : '')\n });\n }\n });\n}\nexport default createDataLayer;\n","// @ts-nocheck\nconst navbar = (element) => {\n Array.from(element.querySelectorAll('details')).forEach((detail, index) => {\n detail.addEventListener('mouseenter', function (e) {\n if (window.matchMedia('(min-width: 62em)').matches)\n detail.setAttribute('open', 'true');\n }, false);\n detail.addEventListener('mouseleave', function (e) {\n if (window.matchMedia('(min-width: 62em)').matches)\n detail.removeAttribute('open');\n }, false);\n });\n if ('IntersectionObserver' in window) {\n const observer = new IntersectionObserver(([e]) => e.target.classList.toggle(\"is-stuck\", e.intersectionRatio < 1), { threshold: [1] });\n observer.observe(element);\n }\n};\nexport default navbar;\n","// @ts-nocheck\nfunction testimonial(testimonialElement) {\n var scrollTimeout;\n const imagesCarousel = testimonialElement.querySelector('.testimonial__images');\n const itemCount = imagesCarousel.querySelectorAll('img').length;\n // If we only have 1 item lets not bother doing anything else\n if (itemCount == 1) {\n return false;\n }\n testimonialElement.classList.add('testimonial--multi');\n // Set where the buttons go to\n const setButtons = function (scrollTo) {\n const nextButton = testimonialElement.querySelector('.btn-next');\n const prevButton = testimonialElement.querySelector('.btn-prev');\n nextButton.setAttribute('data-go', scrollTo + 1);\n prevButton.setAttribute('data-go', scrollTo - 1);\n nextButton.removeAttribute('disabled');\n prevButton.removeAttribute('disabled');\n if (scrollTo == 1)\n prevButton.setAttribute('disabled', true);\n else if (scrollTo == itemCount)\n nextButton.setAttribute('disabled', true);\n };\n // On scroll we need to make sure the buttons get corrected and the next testimonial is shown\n imagesCarousel.addEventListener('scroll', function (e) {\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(function () {\n let scrollWidth = imagesCarousel.scrollWidth;\n let scrollHeight = imagesCarousel.scrollHeight;\n let scrollLeft = imagesCarousel.scrollLeft;\n let scrollDown = imagesCarousel.scrollTop;\n let scrollTo = Math.round((scrollLeft / scrollWidth) * itemCount) + 1;\n // Change in scroll direction\n if (scrollLeft == 0 && scrollDown != 0)\n scrollTo = Math.round((scrollDown / scrollHeight) * itemCount) + 1;\n testimonialElement.setAttribute('data-show', scrollTo);\n setButtons(scrollTo);\n }, 300);\n }, false);\n // when the buttons are used we need to make sure the carousel scrolls to the correct place\n testimonialElement.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('[data-go]')) {\n let scrollTo = parseInt(target.getAttribute('data-go'));\n let scrollDown = 0;\n let scrollLeft = 0;\n let scrollWidth = imagesCarousel.scrollWidth;\n let scrollHeight = imagesCarousel.scrollHeight;\n if (scrollWidth > scrollHeight)\n scrollLeft = Math.floor(scrollWidth * ((scrollTo - 1) / itemCount));\n else\n scrollDown = Math.floor(scrollHeight * ((scrollTo - 1) / itemCount));\n // Trigger the scroll\n imagesCarousel.scroll({\n top: scrollDown,\n left: scrollLeft,\n behavior: 'smooth'\n });\n break;\n }\n }\n }, false);\n}\nexport default testimonial;\n","// @ts-nocheck\nfunction carousel(carouselElement) {\n var scrollTimeout;\n let carouselInner = carouselElement.querySelector('.carousel__inner');\n let itemCount = carouselElement.querySelectorAll('.carousel__item').length;\n let cols = carouselElement.getAttribute('data-cols');\n let smCols = carouselElement.getAttribute('data-sm-cols');\n let mdCols = carouselElement.getAttribute('data-md-cols');\n carouselElement.querySelector('.carousel__controls a').classList.add('active');\n // On scroll we need to make sure the buttons get corrected and the next testimonial is shown\n carouselInner.addEventListener('scroll', function (e) {\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(function () {\n let scrollArea = carouselInner.clientWidth;\n let scrollWidth = carouselInner.scrollWidth;\n let scrollLeft = carouselInner.scrollLeft;\n let targetSlide = Math.round((scrollLeft / scrollWidth) * itemCount) + 1;\n let lastItemOffset = carouselElement.querySelector('.carousel__item:last-child').offsetLeft;\n Array.from(carouselElement.querySelectorAll('.carousel__controls a')).forEach((link, index) => {\n link.classList.remove('active');\n });\n carouselElement.querySelector('.control-' + targetSlide).classList.add('active');\n // Disable the previous button\n if (targetSlide == 1)\n carouselElement.querySelector('.btn-prev').setAttribute('disabled', 'disabled');\n else\n carouselElement.querySelector('.btn-prev').removeAttribute('disabled');\n // Disable the next button if the last item is in view\n if (carouselInner.scrollLeft + scrollArea > lastItemOffset)\n carouselElement.querySelector('.btn-next').setAttribute('disabled', 'disabled');\n else\n carouselElement.querySelector('.btn-next').removeAttribute('disabled');\n }, 100);\n }, false);\n // when the buttons are used we need to make sure the carousel scrolls to the correct place\n carouselElement.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('.carousel__controls a')) {\n e.preventDefault();\n Array.from(carouselElement.querySelectorAll('.carousel__controls a')).forEach((link, index) => {\n link.classList.remove('active');\n });\n target.classList.add('active');\n const el = document.querySelector(target.getAttribute('href'));\n carouselInner.scroll({\n top: 0,\n left: el.offsetLeft,\n behavior: 'smooth'\n });\n break;\n }\n }\n }, false);\n carouselElement.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('.btn-next, .btn-prev')) {\n e.preventDefault();\n let scrollTo = target.classList.contains('btn-prev') ? carouselInner.scrollLeft - carouselInner.clientWidth : carouselInner.scrollLeft + carouselInner.clientWidth;\n carouselInner.scroll({\n top: 0,\n left: scrollTo,\n behavior: 'smooth'\n });\n break;\n }\n }\n }, false);\n // Add responsive hide button classes\n if (itemCount == 1)\n carouselElement.classList.add('hide-btns');\n if (smCols >= itemCount)\n carouselElement.classList.add('hide-sm-btns');\n if (mdCols >= itemCount)\n carouselElement.classList.add('hide-md-btns');\n}\nexport default carousel;\n","// @ts-nocheck\n// Create a link between two input/selects with one acting as setting a minimum value and the second a maximum\n// The link between the two will prevent the max input field form setting a lower value than the min and vice versa\nfunction inputRange(inputWrapper) {\n inputWrapper.addEventListener('change', function (e) {\n var min = parseInt(inputWrapper.querySelector('[data-min] select,[data-min] input').value);\n var max = parseInt(inputWrapper.querySelector('[data-max] select,[data-max] input').value);\n // Set attributes for input fields\n Array.from(inputWrapper.querySelectorAll('[data-min] input')).forEach((input, index) => {\n input.setAttribute('max', max);\n });\n Array.from(inputWrapper.querySelectorAll('[data-max] input')).forEach((input, index) => {\n input.setAttribute('min', min);\n });\n // Hide select options if they are higher or lower than the min and max values\n Array.from(inputWrapper.querySelectorAll('[data-min] select option')).forEach((option, index) => {\n if (parseInt(option.getAttribute('value')) > max)\n option.classList.add('d-none');\n else\n option.classList.remove('d-none');\n });\n Array.from(inputWrapper.querySelectorAll('[data-max] select option')).forEach((option, index) => {\n if (parseInt(option.getAttribute('value')) < min)\n option.classList.add('d-none');\n else\n option.classList.remove('d-none');\n });\n }, false);\n}\nfunction inputRedirect(inputWrapper) {\n inputWrapper.addEventListener('change', function (e) {\n if (inputWrapper.matches('[data-value-if]')) {\n const url = inputWrapper.getAttribute('data-redirect');\n const desiredValue = inputWrapper.getAttribute('data-value-if');\n if (inputWrapper.value == desiredValue)\n document.location.href = url;\n }\n else {\n if (typeof inputWrapper.value != \"undefined\")\n document.location.href = inputWrapper.value;\n }\n }, false);\n}\n//\nfunction multipleFileUploads(wrapper) {\n const fileTenplate = wrapper.querySelector('.row');\n const clone = fileTenplate.cloneNode(true);\n const addButton = wrapper.querySelector('[data-add]');\n wrapper.addEventListener('click', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('[data-add]')) { // Add a new row upload file input fields\n const tempClone = clone.cloneNode(true);\n wrapper.insertBefore(tempClone, target);\n if (addButton.matches('[data-maxfiles]') && Array.from(wrapper.querySelectorAll(':scope > .row')).length >= addButton.dataset.maxfiles)\n addButton.setAttribute('disabled', 'disabled');\n break;\n }\n if (target.matches('[data-delete]')) { // Delete the current row\n let row = target.closest('.row');\n row.remove();\n if (addButton.matches('[data-maxfiles]') && Array.from(wrapper.querySelectorAll(':scope > .row')).length < addButton.dataset.maxfiles)\n addButton.removeAttribute('disabled');\n break;\n }\n }\n }, false);\n}\n// Acts as an overall initialise function to trigger other functions.\nfunction form(formElement) {\n // Check for input range groups\n Array.from(formElement.querySelectorAll('[data-input-range]')).forEach((arrayElement, index) => {\n inputRange(arrayElement);\n });\n Array.from(formElement.querySelectorAll('[data-redirect]')).forEach((arrayElement, index) => {\n inputRedirect(arrayElement);\n });\n Array.from(formElement.querySelectorAll('.multiple-file-uploads')).forEach((arrayElement, index) => {\n multipleFileUploads(arrayElement);\n });\n // Check the file size of a file when uploaded in case it exceeds the max file size set\n formElement.addEventListener('change', function (e) {\n for (var target = e.target; target && target != this; target = target.parentNode) {\n if (target.matches('[type=\"file\"][data-filesize]') && target.files && target.files[0]) {\n const maxAllowedSize = target.dataset.filesize;\n if (target.files[0].size > maxAllowedSize) {\n target.value = '';\n alert('File too large');\n }\n break;\n }\n }\n }, false);\n // When a form is updated we may want to update some of the existing input fields; setting active fields when some data is selected.\n formElement.addEventListener('change', function (e) {\n // Remove disabled attribute when a pre-selected input field equals a certain value\n Array.from(formElement.querySelectorAll('select[data-activeif][data-equals],input[data-activeif][data-equals]')).forEach((arrayElement, index) => {\n let group = arrayElement.closest('[data-group]') ? arrayElement.closest('[data-group]') : formElement;\n let selector = arrayElement.dataset.activeif;\n let value = arrayElement.dataset.equals;\n let testElement = group.querySelector(`select[data-id=\"${selector}\"],input[data-id=\"${selector}\"]`);\n if (testElement.value == value) {\n arrayElement.removeAttribute('disabled');\n }\n else {\n arrayElement.setAttribute('disabled', 'disabled');\n arrayElement.value = '';\n }\n });\n // Show this input wrapper when a pre-selected input field equals a certain value\n Array.from(formElement.querySelectorAll('.form-control__wrapper[data-displayif][data-equals]')).forEach((arrayElement, index) => {\n let group = arrayElement.closest('[data-group]') ? arrayElement.closest('[data-group]') : formElement;\n let selector = arrayElement.dataset.activeif;\n let value = arrayElement.dataset.equals;\n let testElement = group.querySelector(`select[data-id=\"${selector}\"],input[data-id=\"${selector}\"]`);\n if (testElement.value == value)\n arrayElement.classList.remove('d-none');\n else\n arrayElement.classList.add('d-none');\n });\n }, false);\n}\nexport default form;\n","// @ts-nocheck\n// Modules\nimport * as helpers from '../js/modules/helpers.js';\nimport extendDialogs from '../js/modules/dialogs.js';\nimport createDataLayer from '../js/modules/data-layer.js';\nimport nav from '../js/modules/nav.js';\n//import accordion from './modules/accordion.js'\nimport testimonial from '../js/modules/testimonial.js';\nimport carousel from '../js/modules/carousel.js';\nimport form from '../js/modules/form.js';\nimport youtubeVideo from '../js/modules/youtubevideo.js';\nconst components = ['accordion', 'header', 'tabs', 'table', 'card', 'pagination', 'filterlist', 'applied-filters'];\nconst prefix = \"iam\";\nconst options = {\n rootMargin: '50px',\n threshold: 0.1\n};\nconst componentExt = \".component.min.js\";\n// Load components - Each component will load once the first of its type has been loaded\ncomponents.forEach((component) => {\n console.log(component);\n if (document.getElementsByTagName(`${prefix}-${component}`).length === 0)\n return;\n let callback = (entries) => {\n entries.forEach((entry) => {\n if (entry.intersectionRatio > 0) {\n console.log(component);\n import(`./components/${component}/${component}${componentExt}`).then(module => {\n if (!window.customElements.get(`${prefix}-${component}`))\n window.customElements.define(`${prefix}-${component}`, module.default);\n }).catch((err) => {\n console.log(err.message);\n });\n intObserver.unobserve(entry.target);\n }\n });\n };\n const intObserver = new IntersectionObserver(callback, options);\n intObserver.observe(document.getElementsByTagName(`${prefix}-${component}`)[0]);\n});\n// Attach classes to dom elements\ndocument.addEventListener(\"DOMContentLoaded\", function () {\n createDataLayer();\n // Global stuff\n helpers.addBodyClasses(document.body);\n helpers.addGlobalEvents(document.body);\n //helpers.checkElements(document.body);\n extendDialogs(document.body);\n // ANav\n Array.from(document.querySelectorAll('.nav')).forEach((arrayElement) => {\n nav(arrayElement);\n });\n // Testimonial\n Array.from(document.querySelectorAll('.testimonial')).forEach((arrayElement) => {\n testimonial(arrayElement);\n });\n // Carousel\n Array.from(document.querySelectorAll('.carousel')).forEach((arrayElement) => {\n carousel(arrayElement);\n });\n // Form\n Array.from(document.querySelectorAll('form')).forEach((arrayElement) => {\n form(arrayElement);\n });\n // YouTube videos\n Array.from(document.querySelectorAll('.youtube-embed')).forEach((arrayElement) => {\n console.log(arrayElement);\n new youtubeVideo(arrayElement);\n });\n window.addEventListener('hashchange', function () {\n const hash = location.hash.replace('#', '');\n const label = document.querySelector(`label[for=\"${hash}\"]`);\n if (label instanceof HTMLElement)\n label.click();\n }, false);\n});\n"],"names":["addBodyClasses","body","addGlobalEvents","checkElements","hash","label","summary","dialog","event","form","pageInput","youtubeVideo","embed","target","createEmbed","resolve","reject","image","tag","firstScriptTag","video_id","link_id","randLetter","onYouTubeIframeAPIReady","onPlayerReady","onPlayerStateChange","done","link","extendDialogs","button","modalID","createDialog","e","videoButton","btnElement","index","dialogDimensions","btn","parent","dataEvent","popover","position","topOffset","leftOffset","container","popoverBottom","windowPos","currentStyle","createMultiFormDialog","dialogContent","titleElement","optionalElement","buttons","fieldsets","fieldset","btnWrapper","step","createDataLayer","navbar","element","detail","testimonial","testimonialElement","scrollTimeout","imagesCarousel","itemCount","setButtons","scrollTo","nextButton","prevButton","scrollWidth","scrollHeight","scrollLeft","scrollDown","carousel","carouselElement","carouselInner","smCols","mdCols","scrollArea","targetSlide","lastItemOffset","el","inputRange","inputWrapper","min","max","input","option","inputRedirect","url","desiredValue","multipleFileUploads","wrapper","clone","addButton","tempClone","formElement","arrayElement","maxAllowedSize","group","selector","value","components","prefix","options","component","callback","entries","entry","module","err","intObserver","helpers.addBodyClasses","helpers.addGlobalEvents","nav"],"mappings":"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"}
@@ -83,7 +83,7 @@ function createAppliedFilters(container, filters) {
83
83
  if (name.match(/\[(.*)\]/)) {
84
84
  let newName = name.replace(/\[(.*)\]/, `[]`);
85
85
  let value = name.replace(/.*\[(.*)\]/, `$1`);
86
- selector = `[name="${newName}"][value="${value}"]`;
86
+ selector = `[value="${value}"]`;
87
87
  }
88
88
  let inputs = container.querySelectorAll(selector);
89
89
  for (var i = 0; i < inputs.length; i++) {
@@ -23,7 +23,6 @@ const extendDialogs = (body) => {
23
23
  // Open the modal!
24
24
  dialog.showModal();
25
25
  dialog.focus();
26
- console.log(dialog.querySelector('button'));
27
26
  window.dataLayer = window.dataLayer || [];
28
27
  window.dataLayer.push({
29
28
  "event": "openModal",
@@ -36,6 +35,10 @@ const extendDialogs = (body) => {
36
35
  const dialog = event.target.closest('dialog[open]');
37
36
  event.preventDefault();
38
37
  dialog.close();
38
+ // Remove active class from exiting active buttons
39
+ Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {
40
+ btnElement.classList.remove('active');
41
+ });
39
42
  window.dataLayer = window.dataLayer || [];
40
43
  window.dataLayer.push({
41
44
  "event": "closeModal",
@@ -45,6 +48,10 @@ const extendDialogs = (body) => {
45
48
  // Track default close buttons
46
49
  if (event && event.target instanceof HTMLElement && event.target.closest('button[formmethod="dialog"]')) {
47
50
  const dialog = event.target.closest('dialog[open]');
51
+ // Remove active class from exiting active buttons
52
+ Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {
53
+ btnElement.classList.remove('active');
54
+ });
48
55
  window.dataLayer = window.dataLayer || [];
49
56
  window.dataLayer.push({
50
57
  "event": "closeModal",
@@ -76,6 +83,10 @@ const extendDialogs = (body) => {
76
83
  let popover = parent.querySelector(':scope > dialog');
77
84
  if (document.querySelector('dialog[open]') && document.querySelector('dialog[open]') != popover)
78
85
  document.querySelector('dialog[open]').close();
86
+ // Remove active class from exiting active buttons
87
+ Array.from(document.querySelectorAll('.dialog__wrapper > button')).forEach((btnElement, index) => {
88
+ btnElement.classList.remove('active');
89
+ });
79
90
  if (popover.hasAttribute('open')) {
80
91
  popover.close();
81
92
  dataEvent = "closePopover";
@@ -7,7 +7,7 @@ export const addDataAttributes = (table) => {
7
7
  const colRows = Array.from(table.querySelectorAll('tbody tr'));
8
8
  colRows.forEach((row, index) => {
9
9
  const cells = Array.from(row.querySelectorAll('th, td'));
10
- const statuses = ['Low', 'Medium', 'High', 'N/A', 'Pending', 'Verified', 'Incomplete', 'Completed', 'Requires approval'];
10
+ const statuses = ['0', 'low', 'medium', 'high', 'unknown', 'n/a', 'pending', 'verified', 'incomplete', 'completed', 'requires approval'];
11
11
  cells.forEach((cell, cellIndex) => {
12
12
  const heading = colHeadings[cellIndex];
13
13
  if (typeof heading != "undefined") {
@@ -19,10 +19,10 @@ export const addDataAttributes = (table) => {
19
19
  cell.setAttribute('class', heading.getAttribute('data-td-class'));
20
20
  if (heading.hasAttribute('data-format')) {
21
21
  cell.setAttribute('data-format', heading.getAttribute('data-format'));
22
- cell.innerHTML = formatCell('date', cell.textContent.trim()); //Make sure date format is consistent
22
+ cell.innerHTML = formatCell(heading.getAttribute('data-format'), cell.textContent.trim()); //Make sure date format is consistent
23
23
  }
24
- if (statuses.includes(cell.textContent.trim())) {
25
- cell.setAttribute('data-content', cell.textContent.trim());
24
+ if (statuses.includes(cell.textContent.trim().toLowerCase())) {
25
+ cell.setAttribute('data-content', cell.textContent.trim().toLowerCase());
26
26
  }
27
27
  }
28
28
  });
@@ -100,9 +100,16 @@ export const createSearchDataList = (table, form) => {
100
100
  export const addFilterEventListeners = (table, form, pagination, wrapper, savedTableBody) => {
101
101
  var timer;
102
102
  // Check what conditions are set on the table to see what the form actions are
103
- let formSubmit = function () {
104
- if (form.hasAttribute('data-ajax'))
103
+ let formSubmit = function (paginate = false) {
104
+ if (form.hasAttribute('data-ajax')) {
105
+ // Default back to page 1
106
+ if (!paginate) {
107
+ let paginationInput = form.querySelector('[data-pagination]');
108
+ paginationInput.value = 1;
109
+ wrapper.setAttribute('data-page', 1);
110
+ }
105
111
  loadAjaxTable(table, form, pagination, wrapper);
112
+ }
106
113
  else if (form.hasAttribute('data-submit'))
107
114
  form.submit();
108
115
  else {
@@ -139,6 +146,9 @@ export const addFilterEventListeners = (table, form, pagination, wrapper, savedT
139
146
  if (event && event.target instanceof HTMLElement && event.target.closest('[data-show]')) {
140
147
  formSubmit();
141
148
  }
149
+ if (event && event.target instanceof HTMLElement && event.target.closest('[data-mimic]')) {
150
+ formSubmit();
151
+ }
142
152
  });
143
153
  form.addEventListener('click', (event) => {
144
154
  clearTimeout(timer);
@@ -168,6 +178,50 @@ export const addFilterEventListeners = (table, form, pagination, wrapper, savedT
168
178
  form.addEventListener('force', (event) => {
169
179
  formSubmit();
170
180
  });
181
+ form.addEventListener('paginate', (event) => {
182
+ formSubmit(true);
183
+ });
184
+ // Mmimic fields
185
+ let forms = [];
186
+ let fields = [];
187
+ // Collect the forms that we need to add an event listener for.
188
+ Array.from(form.querySelectorAll('[data-mimic]')).forEach((input, index) => {
189
+ let mimicField = input.getAttribute('data-mimic');
190
+ Array.from(document.querySelectorAll(`[name="${mimicField}"]`)).forEach((mimicInput, index) => {
191
+ let parentForm = mimicInput.closest('form');
192
+ if (!forms.includes(parentForm))
193
+ forms.push(parentForm);
194
+ if (!fields.includes(mimicInput))
195
+ fields.push(mimicInput);
196
+ });
197
+ });
198
+ // For each form add change listener
199
+ forms.forEach((parentForm, index) => {
200
+ const updateMimicInput = function () {
201
+ let mimickedAlready = [];
202
+ let formData = new FormData(parentForm);
203
+ let i = 1;
204
+ for (const [key, value] of formData) {
205
+ if (document.querySelector(`[data-mimic="${key}"]`) && !mimickedAlready.includes(key)) {
206
+ mimickedAlready.push(key);
207
+ document.querySelector(`[data-mimic="${key}"]`).value = value;
208
+ }
209
+ else if (document.querySelector(`[data-mimic="${key}"]`))
210
+ document.querySelector(`[data-mimic="${key}"]`).value += "," + value;
211
+ i++;
212
+ }
213
+ for (const value of mimickedAlready) {
214
+ const event = new Event("force");
215
+ form.dispatchEvent(event);
216
+ }
217
+ };
218
+ parentForm.addEventListener('force', (event) => {
219
+ updateMimicInput();
220
+ });
221
+ parentForm.addEventListener('change', (event) => {
222
+ updateMimicInput();
223
+ });
224
+ });
171
225
  };
172
226
  export const sortTable = (table, form, savedTableBody) => {
173
227
  if (form.getAttribute('data-ajax')) {
@@ -248,10 +302,11 @@ export const filterTable = (table, form, wrapper) => {
248
302
  filters[filterInput.getAttribute('data-filter')].push(value);
249
303
  }
250
304
  }
251
- else if (filterInput.value) {
252
- if (!filters[filterInput.getAttribute('data-filter')])
253
- filters[filterInput.getAttribute('data-filter')] = new Array();
254
- filters[filterInput.getAttribute('data-filter')].push(filterInput.value);
305
+ else if (filterInput && filterInput.value) {
306
+ let dataFilter = filterInput.getAttribute('data-filter');
307
+ if (!filters[dataFilter])
308
+ filters[dataFilter] = new Array();
309
+ filters[dataFilter].push(filterInput.value);
255
310
  }
256
311
  });
257
312
  // Add search columns too
@@ -364,13 +419,16 @@ export const filterTable = (table, form, wrapper) => {
364
419
  wrapper.setAttribute('data-show', showRows);
365
420
  }
366
421
  };
367
- export const populateDataQueries = (table, form) => {
422
+ export const populateDataQueries = (table, form, wrapper) => {
368
423
  const dataQueries = Array.from(form.querySelectorAll('[data-query]'));
369
424
  dataQueries.forEach((queryElement, index) => {
370
425
  let query = queryElement.getAttribute('data-query');
371
426
  let numberOfMatchedRows;
372
427
  if (query == 'total') {
373
- numberOfMatchedRows = table.classList.contains('table--filtered') ? table.querySelectorAll('tbody tr').length : table.querySelectorAll('tbody tr').length;
428
+ if (wrapper.hasAttribute('data-total'))
429
+ numberOfMatchedRows = wrapper.getAttribute('data-total');
430
+ else
431
+ numberOfMatchedRows = table.classList.contains('table--filtered') ? table.querySelectorAll('tbody tr').length : table.querySelectorAll('tbody tr').length;
374
432
  }
375
433
  else if (!query.includes(' == ') && query.includes(' & ')) {
376
434
  let queries = query.split(' & ');
@@ -416,7 +474,7 @@ export const addPaginationEventListeners = function (table, form, pagination, wr
416
474
  let newPage = event.target.closest('[data-page]').getAttribute('data-page');
417
475
  paginationInput.value = newPage;
418
476
  wrapper.setAttribute('data-page', newPage);
419
- form.dispatchEvent(new Event("submit"));
477
+ form.dispatchEvent(new Event("paginate"));
420
478
  if (table.hasAttribute('data-show-history')) {
421
479
  const url = new URL(location);
422
480
  url.searchParams.set("page", newPage);
@@ -477,9 +535,9 @@ export const exportAsCSV = function (table) {
477
535
  };
478
536
  // After table is loaded
479
537
  export const makeTableFunctional = function (table, form, pagination, wrapper) {
480
- createMobileButton(table);
481
538
  addDataAttributes(table);
482
- populateDataQueries(table, form);
539
+ createMobileButton(table);
540
+ populateDataQueries(table, form, wrapper);
483
541
  // Work out the largest width of the CTA's in the last column
484
542
  if (wrapper && wrapper.classList.contains('table--cta')) {
485
543
  const largestWidth = getLargestLastColWidth(table);
@@ -488,10 +546,12 @@ export const makeTableFunctional = function (table, form, pagination, wrapper) {
488
546
  };
489
547
  export const loadAjaxTable = function (table, form, pagination, wrapper) {
490
548
  const resolvePath = (object, path, defaultValue) => path.split(/[\.\[\]\'\"]/).filter(p => p).reduce((o, p) => o ? o[p] : defaultValue, object);
491
- let queryString = new URLSearchParams(new FormData(form)).toString();
549
+ let formData = new FormData(form);
550
+ let queryString = new URLSearchParams(formData).toString();
492
551
  let columns = table.querySelectorAll('thead tr th');
493
552
  let tbody = table.querySelector('tbody');
494
- fetch(form.getAttribute('data-ajax'), {
553
+ wrapper.classList.add('table--loading');
554
+ fetch(form.getAttribute('data-ajax') + '?' + queryString, {
495
555
  method: 'get',
496
556
  credentials: 'same-origin',
497
557
  headers: new Headers({
@@ -500,9 +560,15 @@ export const loadAjaxTable = function (table, form, pagination, wrapper) {
500
560
  'X-Requested-With': 'XMLHttpRequest'
501
561
  })
502
562
  }).then((response) => response.json()).then((response) => {
503
- if (response.data) {
563
+ let schema = form.hasAttribute('data-schema') ? form.getAttribute('data-schema') : 'data';
564
+ let totalNumberSchema = form.hasAttribute('data-schema-total') ? form.getAttribute('data-schema-total') : 'meta.total';
565
+ let currentPageSchema = form.hasAttribute('data-schema-page') ? form.getAttribute('data-schema-page') : 'meta.current_page';
566
+ let totalNumber = resolvePath(response, totalNumberSchema, 1);
567
+ let currentPage = resolvePath(response, currentPageSchema, 1);
568
+ let data = resolvePath(response, schema);
569
+ if (data) {
504
570
  tbody.innerHTML = '';
505
- response.data.forEach((row, index) => {
571
+ data.forEach((row, index) => {
506
572
  var table_row = document.createElement('tr');
507
573
  columns.forEach((col, index) => {
508
574
  let cellOutput = '';
@@ -514,8 +580,11 @@ export const loadAjaxTable = function (table, form, pagination, wrapper) {
514
580
  // Use a regex to replace {var} with actual values from the json data
515
581
  cellOutput = cellTemplate.replace(new RegExp(/{(.*?)}/, "gm"), function (matched) { return resolvePath(row, matched.replace('{', '').replace('}', '')); });
516
582
  }
517
- if (col.hasAttribute('data-format')) {
518
- cellOutput = formatCell(col.getAttribute('data-format'), cellOutput);
583
+ if (col.hasAttribute('data-transform')) {
584
+ const transforms = JSON.parse(col.getAttribute('data-transform'));
585
+ cellOutput = transforms[cellOutput];
586
+ if (!cellOutput && col.hasAttribute('data-default'))
587
+ cellOutput = col.getAttribute('data-default');
519
588
  }
520
589
  table_cell.innerHTML = cellOutput;
521
590
  table_row.appendChild(table_cell);
@@ -524,28 +593,33 @@ export const loadAjaxTable = function (table, form, pagination, wrapper) {
524
593
  });
525
594
  createSearchDataList(table, form);
526
595
  // Add data to the pagination
527
- makeTableFunctional(table, form, pagination, wrapper);
528
- wrapper.setAttribute('data-total', (response.meta.total ? response.meta.total : 1));
529
- wrapper.setAttribute('data-page', (response.meta.current_page ? response.meta.current_page : 1));
596
+ wrapper.setAttribute('data-total', parseInt(totalNumber));
597
+ wrapper.setAttribute('data-page', parseInt(currentPage));
530
598
  wrapper.setAttribute('data-pages', Math.ceil(wrapper.getAttribute('data-total') / wrapper.getAttribute('data-show')));
599
+ makeTableFunctional(table, form, pagination, wrapper);
531
600
  createPaginationButttons(wrapper, pagination);
532
601
  if (response.data.length == 0) {
533
602
  tbody.innerHTML = '<tr><td colspan="100%"><span class="h4 m-0">No results found</span></td></tr>';
534
603
  }
604
+ wrapper.classList.remove('table--loading');
535
605
  }
536
606
  else {
537
607
  tbody.innerHTML = '<tr><td colspan="100%"><span class="h6 m-0">Error loading table</span></td></tr>';
538
608
  }
539
609
  });
610
+ if (form.hasAttribute('data-ajax-post')) {
611
+ const http = new XMLHttpRequest();
612
+ http.open('GET', `${window.location.href}?ajax=true&${queryString}`);
613
+ http.send();
614
+ }
540
615
  };
541
616
  export const formatCell = (format, cellOutput) => {
542
617
  switch (format) {
618
+ case 'datetime':
619
+ return new Date(cellOutput).toLocaleDateString('en-gb', { weekday: 'short', year: "2-digit", month: "long", day: "numeric", }) + " " + new Date(cellOutput).toLocaleTimeString("en-gb", { hour: "2-digit", minute: "2-digit" });
543
620
  case 'date':
544
- cellOutput = new Date(cellOutput).toLocaleDateString('en-gb', { year: "2-digit", month: "long", day: "numeric" });
545
- break;
621
+ return new Date(cellOutput).toLocaleDateString('en-gb', { year: "2-digit", month: "long", day: "numeric" });
546
622
  case 'capitalise':
547
- cellOutput = ucfirst(cellOutput);
548
- break;
623
+ return cellOutput = ucfirst(cellOutput);
549
624
  }
550
- return cellOutput;
551
625
  };