{"version":3,"file":"js/9009.d83ceac1.js","mappings":"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","sources":["webpack://ellevio-styleguide-web/./src/stories/web/structure/LinkIcon.vue","webpack://ellevio-styleguide-web/./src/stories/web/structure/LinkIcon.vue?e4d3","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/Alert.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/Alert.vue?5cf4","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/Header.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNav.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNavHead.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNavHead.vue?9bad","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileLoginWideArea.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileLoginWideArea.vue?784c","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileSearchWideArea.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/HeaderSearchInput.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/HeaderSearchInput.vue?ef55","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileSearchWideArea.vue?11ef","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNavTree.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNavTree.vue?afe2","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNavFooter.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNavFooter.vue?78d2","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/MobileNav.vue?8e9b","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/RunOnload.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/RunOnload.vue?f194","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNav.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavLower.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavLowerMegaMenuItem.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavLowerNavIcon.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavLowerNavIcon.vue?9223","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavLowerMegaMenuItem.vue?1639","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavLower.vue?d7e3","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavUpper.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNavUpper.vue?53f4","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/DesktopNav.vue?9d6f","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/Header.vue?99c7","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/LogOutButton.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/LogOutButton.vue?81a4","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/SearchInputErrorMessage.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/SearchInputErrorMessage.vue?4dc3","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/TooltipWrapper.vue","webpack://ellevio-styleguide-web/./src/stories/web/vue-components/TooltipWrapper.vue?c0ae","webpack://ellevio-styleguide-web/./src/directives/clickOutside.js","webpack://ellevio-styleguide-web/./src/helpers/cookies.js","webpack://ellevio-styleguide-web/./src/helpers/focusTrap.js"],"sourcesContent":["<template>\r\n <svg v-if=\"!mirror\" xmlns=\"http://www.w3.org/2000/svg\" class=\"inline-block ml-2 -mt-0.5\" :style=\"color ? `fill:${color}` : ''\" viewBox=\"0 0 18.87 11.92\" width=\"18.87\" height=\"11.92\">\r\n <g class=\"transition-transform duration-200 transform -translate-x-3 group-hover:transform group-hover:translate-x-0\"><path d=\"M13.26.736l5.614 5.615-1.386 1.386-5.614-5.615zM11.872 10.54l3.302-3.301 1.386 1.385-3.303 3.303z\" /></g>\r\n <path class=\"transition-transform duration-200 transform scale-x-0 group-hover:transform group-hover:scale-x-100\" d=\"M12.98 7.52H5.04V5.56h7.94l1 .98-1 .98z\" />\r\n </svg>\r\n <svg v-else xmlns=\"http://www.w3.org/2000/svg\" class=\"inline-block mr-2 -mt-1\" :style=\"color ? `fill:${color}` : ''\" viewBox=\"0 0 18.87 11.92\" width=\"18.87\" height=\"11.92\">\r\n <g class=\"transition-transform duration-200 transform -translate-x-0.5 group-hover:transform group-hover:translate-x-0\"><path d=\"M13.26.736l5.614 5.615-1.386 1.386-5.614-5.615zM11.872 10.54l3.302-3.301 1.386 1.385-3.303 3.303z\" /></g>\r\n <path class=\"transition-transform duration-200 origin-center transform scale-x-0 group-hover:transform group-hover:scale-x-100\" d=\"M12.98 7.52H5.04V5.56h7.94l1 .98-1 .98z\" />\r\n </svg>\r\n</template>\r\n\r\n<script>\r\nexport default {\r\n name: 'EllevioWebLinkIcon',\r\n props: {\r\n color: {\r\n type: String,\r\n default: ''\r\n },\r\n mirror: {\r\n type: Boolean,\r\n default: false\r\n }\r\n }\r\n}\r\n</script>\r\n","import { render } from \"./LinkIcon.vue?vue&type=template&id=78ac8ff3\"\nimport script from \"./LinkIcon.vue?vue&type=script&lang=js\"\nexport * from \"./LinkIcon.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","<template>\r\n <div v-if=\"open\" class=\"relative w-full max-h-auto alert-box\" :class=\"[errorType(), zOrderClass]\" role=\"alert\" ref=\"alertContainerRef\">\r\n <div class=\"flex py-4 container-large\">\r\n <div class=\"flex justify-between w-full items-top\">\r\n <div>\r\n <div class=\"flex items-center\">\r\n <!-- Icons -->\r\n <svg v-if=\"outlineIcon\" class=\"alert-icon-outline\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M12 8H12.01M12 11V16M21 12C21 16.9706 16.9706 21 12 21C7.02944 21 3 16.9706 3 12C3 7.02944 7.02944 3 12 3C16.9706 3 21 7.02944 21 12Z\" stroke=\"#2C2827\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n <svg v-else class=\"alert-icon\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n fill-rule=\"evenodd\"\r\n clip-rule=\"evenodd\"\r\n d=\"M12 22C17.5228 22 22 17.5228 22 12C22 6.47715 17.5228 2 12 2C6.47715 2 2 6.47715 2 12C2 17.5228 6.47715 22 12 22ZM13 7.55556C13 7.00327 12.5523 6.55556 12 6.55556C11.4477 6.55556 11 7.00327 11 7.55556V13.1111C11 13.6634 11.4477 14.1111 12 14.1111C12.5523 14.1111 13 13.6634 13 13.1111V7.55556ZM12 15.4444C11.4477 15.4444 11 15.8922 11 16.4444C11 16.9967 11.4477 17.4444 12 17.4444H12.0111C12.5634 17.4444 13.0111 16.9967 13.0111 16.4444C13.0111 15.8922 12.5634 15.4444 12.0111 15.4444H12Z\"\r\n fill=\"#2C2827\" />\r\n </svg>\r\n\r\n <!-- Heading -->\r\n <h2 class=\"alert-heading\">{{ title }}</h2>\r\n </div>\r\n <!-- Text -->\r\n <p class=\"alert-text\" :class=\"setTextFullWidth ? '' : 'max-w-2xl'\">\r\n {{ text }} <a v-if=\"showLink\" :href=\"linkUrl\" :target=\"linkTarget\" class=\"alert-link arrow-link-forward\" :class=\"[{ 'arrow-link-forward--white': type === 'critical' }]\">{{ linkText }}</a>\r\n </p>\r\n </div>\r\n\r\n <!-- Close button -->\r\n <button v-if=\"showClose === true || showClose === 'true'\" @click.prevent=\"close\" class=\"alert-close-button\">\r\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M10 8.182L18.182 0 20 1.818 1.818 20 0 18.182 8.182 10 0 1.818 1.818 0 10 8.182zM18.182 20l-6.73-6.73 1.819-1.817L20 18.182 18.182 20z\" fill=\"#2C2827\" />\r\n </svg>\r\n <span>{{ closeText }}</span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport cookieHelper from '../../../helpers/cookies'\r\n\r\nexport default {\r\n name: 'ellevio-web-alert',\r\n props: {\r\n outlineIcon: {\r\n type: Boolean,\r\n default: false\r\n },\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n text: {\r\n type: String,\r\n default: ''\r\n },\r\n setTextFullWidth: {\r\n type: Boolean,\r\n default: false\r\n },\r\n iconSrc: {\r\n type: String,\r\n default: ''\r\n },\r\n type: {\r\n type: String,\r\n default: 'information',\r\n validator(value) {\r\n // The value must match one of these strings\r\n return ['information', 'softWarning', 'warning', 'critical'].includes(value)\r\n }\r\n },\r\n cookieId: {\r\n type: String,\r\n default: 'default'\r\n },\r\n showClose: {\r\n type: Boolean,\r\n default: false\r\n },\r\n closeText: {\r\n type: String,\r\n default: 'Stäng'\r\n },\r\n linkUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n linkTarget: {\r\n type: String,\r\n default: '_self',\r\n validator(value) {\r\n // The value must match one of these strings\r\n return ['_self', '_blank'].includes(value)\r\n }\r\n },\r\n linkText: {\r\n type: String,\r\n default: ''\r\n },\r\n scrollbarWidth: {\r\n type: Number,\r\n default: 0\r\n },\r\n desktopMenuIsOpen: {\r\n type: Boolean,\r\n default: false\r\n },\r\n zOrderSmaller: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n data() {\r\n return {\r\n closed: false\r\n }\r\n },\r\n mounted() {\r\n const doc = document.documentElement\r\n if (this.open) {\r\n const resizeObserver = new ResizeObserver((entries) => {\r\n for (const entry of entries) {\r\n if (entry.contentBoxSize) {\r\n const contentBoxSize = entry.contentBoxSize[0]\r\n doc.style.setProperty('--alert-height', contentBoxSize.blockSize + 'px')\r\n }\r\n }\r\n })\r\n\r\n const alertBox = document.querySelector('.alert-box')\r\n resizeObserver.observe(alertBox)\r\n }\r\n },\r\n computed: {\r\n open() {\r\n return !cookieHelper.getCookie(this.renderedCookieName) && !this.closed\r\n },\r\n showLink() {\r\n return this.linkUrl\r\n },\r\n renderedCookieName() {\r\n return `EllevioAlertMessage_${this.cookieId}`\r\n },\r\n zOrderClass() {\r\n return this.zOrderSmaller ? 'z-auto' : 'z-50'\r\n }\r\n },\r\n methods: {\r\n close() {\r\n const doc = document.documentElement\r\n doc.style.setProperty('--alert-height', '0px')\r\n\r\n this.closed = true\r\n cookieHelper.setCookie(this.renderedCookieName, 'closed for 1 day', 1)\r\n },\r\n errorType() {\r\n return `alert-${this.type}` || 'alert-information'\r\n }\r\n },\r\n watch: {\r\n desktopMenuIsOpen(isOpen) {\r\n // Prevent alert from jumping when mega menu is open\r\n if (isOpen) {\r\n this.$refs.alertContainerRef.style.paddingRight = `${this.scrollbarWidth}px`\r\n } else {\r\n this.$refs.alertContainerRef.style.paddingRight = `0`\r\n }\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.alert-icon {\r\n @apply relative w-6 h-6 mt-0 mr-2 inline shrink-0;\r\n}\r\n.alert-icon-outline {\r\n @apply relative mt-0 mr-2 inline shrink-0;\r\n}\r\n.alert-heading {\r\n @apply text-base lg-rem:text-lg leading-6 font-futuraEfDemiBold max-w-2xl;\r\n}\r\n.alert-text {\r\n @apply mt-1 text-base lg-rem:text-lg leading-6 inline-block ml-8;\r\n}\r\n.alert-link {\r\n @apply text-base lg-rem:text-lg leading-6 focus:outline-offset-2;\r\n}\r\n.alert-close-button {\r\n @apply flex self-start gap-2 text-base mt-1 lg-rem:mt-0 lg-rem:text-lg items-center ml-6 lg-rem:mb-2 focus:outline-dotted focus:outline-newColors-gray-content focus:outline-offset-4 focus:outline-2 rounded-sm;\r\n}\r\n.alert-close-button svg {\r\n @apply w-4 h-4;\r\n}\r\n.alert-close-button span {\r\n /* Hide button text on mobile, but show it for screen readers. */\r\n @apply sr-only lg-rem:not-sr-only;\r\n}\r\n\r\n/*--- CRITICAL ---*/\r\n/* Background color */\r\n.alert-critical {\r\n @apply bg-newColors-red-negative;\r\n}\r\n\r\n/* Text color */\r\n.alert-critical,\r\n.alert-critical .alert-heading,\r\n.alert-critical .alert-link {\r\n @apply text-newColors-gray-base;\r\n}\r\n\r\n/* Focus outline color */\r\n.alert-critical .alert-link,\r\n.alert-critical .alert-close-button {\r\n @apply focus:outline-newColors-gray-base;\r\n}\r\n.alert-critical .alert-close-button {\r\n @apply focus:outline-newColors-gray-base;\r\n}\r\n\r\n/* Icon color */\r\n.alert-critical svg path,\r\n.alert-critical .alert-close-button svg {\r\n @apply fill-newColors-gray-base;\r\n}\r\n/*--- end CRITICAL---*/\r\n\r\n/*--- WARNING ---*/\r\n/* Background color */\r\n.alert-warning {\r\n @apply bg-newColors-red-negativeB;\r\n}\r\n\r\n/* Heading color */\r\n.alert-heading {\r\n @apply text-newColors-red-negative;\r\n}\r\n\r\n/* Icon color */\r\n.alert-warning .alert-icon path {\r\n @apply fill-newColors-red-negative;\r\n}\r\n/*--- end WARNING---*/\r\n\r\n/*--- SOFT WARNING ---*/\r\n/* Background color */\r\n.alert-softWarning {\r\n @apply bg-newColors-orange-signatureB;\r\n}\r\n\r\n/* Heading color */\r\n.alert-heading {\r\n @apply text-newColors-gray-content;\r\n}\r\n\r\n/* Icon color */\r\n.alert-softWarning .alert-icon path {\r\n @apply fill-newColors-orange-signatureA;\r\n}\r\n/*--- end SOFT WARNING---*/\r\n\r\n/*--- INFORMATION ---*/\r\n/* Background color */\r\n.alert-information {\r\n @apply bg-newColors-green-primaryB;\r\n}\r\n\r\n/* Heading color */\r\n.alert-information .alert-heading {\r\n @apply text-newColors-green-primaryA;\r\n}\r\n\r\n/* Icon color */\r\n.alert-information .alert-icon path {\r\n @apply fill-newColors-green-primaryA;\r\n}\r\n/*--- end INFORMATION---*/\r\n</style>\r\n","import { render } from \"./Alert.vue?vue&type=template&id=d693e45a&scoped=true\"\nimport script from \"./Alert.vue?vue&type=script&lang=js\"\nexport * from \"./Alert.vue?vue&type=script&lang=js\"\n\nimport \"./Alert.vue?vue&type=style&index=0&id=d693e45a&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-d693e45a\"]])\n\nexport default __exports__","<template>\r\n <div>\r\n <header :class=\"{ 'fixed top-0': desktopMenuIsOpen && !isMobile }\" class=\"w-full z-[99999] bg-white text-newColors-gray-content ellevio-header\" ref=\"headerHeightRef\">\r\n <ellevio-web-run-onload />\r\n <ellevio-web-alert v-if=\"alert\" v-bind=\"alertMenu\" :scrollbarWidth=\"scrollbarWidth\" :desktopMenuIsOpen=\"desktopMenuIsOpen\" />\r\n <ellevio-web-desktop-nav\r\n v-if=\"!isMobile\"\r\n @toggleMegaMenu=\"handleToggleMegaMenu\"\r\n :searchNoHitsContent=\"searchNoHitsContent\"\r\n :headerHeight=\"headerHeight\"\r\n :show=\"!isMobile\"\r\n :searchApiUrl=\"searchApiUrl\"\r\n :searchPageUrl=\"searchPageUrl\"\r\n :navigationData=\"desktopNavigationData\"\r\n :logoLink=\"logoLink\"\r\n :scrollbarWidth=\"scrollbarWidth\" />\r\n <ellevio-web-mobile-nav\r\n v-if=\"isMobile\"\r\n :on-map-page=\"onMapPage\"\r\n apiUrl=\"//localhost:8082/api/autocompleteItems/\"\r\n :searchApiUrl=\"searchApiUrl\"\r\n :searchPageUrl=\"searchPageUrl\"\r\n :searchNoHitsContent=\"searchNoHitsContent\"\r\n :showAutocompleteList=\"true\"\r\n :logoLink=\"logoLink\"\r\n :footerLinks=\"secondaryMenu\"\r\n v-bind=\"{ ...mobileNavigationData, alert }\" />\r\n </header>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebMobileNav from './MobileNav.vue'\r\nimport EllevioWebAlert from './Alert.vue'\r\nimport EllevioWebRunOnload from './RunOnload.vue'\r\nimport EllevioWebDesktopNav from './DesktopNav.vue'\r\n\r\nexport default {\r\n name: 'ellevio-web-header',\r\n components: {\r\n EllevioWebDesktopNav,\r\n EllevioWebMobileNav,\r\n EllevioWebAlert,\r\n EllevioWebRunOnload\r\n },\r\n props: {\r\n translations: {\r\n type: Object,\r\n default: () => {\r\n return {\r\n search: {},\r\n ariaLabels: {},\r\n skipLinks: {}\r\n }\r\n }\r\n },\r\n searchNoHitsContent: {\r\n type: String,\r\n default: 'Sökningen gav tyvärr inga träffar. Prova gärna med andra ord eller använd vår navigation för att hitta det du söker.'\r\n },\r\n alert: {\r\n type: Boolean,\r\n default: false\r\n },\r\n logoLink: {\r\n type: String,\r\n default: '/'\r\n },\r\n searchApiUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n searchPageUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n megaMenu: {\r\n type: Array,\r\n default: () => []\r\n },\r\n secondaryMenu: {\r\n type: Array,\r\n default: () => []\r\n },\r\n loginMenu: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n alertMenu: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n otherLanguage: {\r\n type: Object,\r\n default: () => {}\r\n }\r\n },\r\n data() {\r\n return {\r\n isMobile: true,\r\n breakpoint: '64rem',\r\n desktopItemsPerRow: 4,\r\n mobileNavigationData: { menuItems: this.megaMenu, loginMenu: this.loginMenu, otherLanguage: this.otherLanguage, translations: this.translations },\r\n desktopNavigationData: {\r\n menuItems: this.megaMenu,\r\n secondaryMenu: this.secondaryMenu,\r\n loginMenu: this.loginMenu,\r\n translations: this.translations,\r\n otherLanguage: this.otherLanguage\r\n },\r\n headerHeight: 0,\r\n desktopMenuIsOpen: false,\r\n resizeObserver: null,\r\n scrollbarWidth: 0\r\n }\r\n },\r\n computed: {\r\n matchMediaQuery() {\r\n return window.matchMedia(` (min-width: ${this.breakpoint}) `)\r\n },\r\n onMapPage() {\r\n return window.location.href.indexOf('projectmap') > -1\r\n }\r\n },\r\n methods: {\r\n resize: function () {\r\n const isMobile = this.matchMediaQuery ? !this.matchMediaQuery.matches : true\r\n\r\n this.isMobile = isMobile\r\n\r\n // On mobile, remove any classes that handle the open mega menu on desktop\r\n if (isMobile && this.desktopMenuIsOpen) {\r\n this.handleToggleMegaMenu(false)\r\n }\r\n },\r\n handleToggleMegaMenu(isOpen) {\r\n const htmlClassNames = ['overflow-hidden']\r\n const bodyClassNames = ['overflow-y-scroll', 'w-full']\r\n\r\n this.desktopMenuIsOpen = isOpen\r\n\r\n if (this.desktopMenuIsOpen) {\r\n // Disable background scroll when menu is open\r\n document.body.classList.add(...bodyClassNames)\r\n document.documentElement.classList.add(...htmlClassNames)\r\n\r\n // Prevent background content from jumping up when header gets position fixed when open\r\n document.body.style.paddingTop = `${this.headerHeight}px`\r\n } else {\r\n document.body.classList.remove(...bodyClassNames)\r\n document.documentElement.classList.remove(...htmlClassNames)\r\n\r\n document.body.style.paddingTop = ''\r\n }\r\n },\r\n onHeaderHeightResize() {\r\n this.headerHeight = this.$refs.headerHeightRef.clientHeight\r\n },\r\n measureScrollbarWidth() {\r\n const outer = document.createElement('div')\r\n outer.style.visibility = 'hidden'\r\n outer.style.overflow = 'scroll' // This creates a scrollbar\r\n outer.style.width = '50px'\r\n outer.style.height = '50px'\r\n\r\n document.body.appendChild(outer)\r\n\r\n const inner = document.createElement('div')\r\n inner.style.width = '100%'\r\n inner.style.height = '100%'\r\n\r\n outer.appendChild(inner)\r\n\r\n this.scrollbarWidth = outer.offsetWidth - inner.offsetWidth\r\n\r\n document.body.removeChild(outer)\r\n }\r\n },\r\n mounted() {\r\n this.measureScrollbarWidth()\r\n\r\n this.isMobile = this.matchMediaQuery ? !this.matchMediaQuery.matches : true\r\n this._boundedResize = this.resize.bind(this)\r\n window.addEventListener('resize', this._boundedResize)\r\n\r\n /* Listen to changes in header height. E.g. when alert banner is closed\r\n The header height is used to push down the mega menu to the correct position. */\r\n this.resizeObserver = new ResizeObserver(this.onHeaderHeightResize)\r\n this.resizeObserver.observe(this.$refs.headerHeightRef)\r\n this.onHeaderHeightResize()\r\n },\r\n unmounted() {\r\n window.removeEventListener('resize', this._boundedResize)\r\n\r\n if (this.$refs.headerHeightRef instanceof Element) {\r\n this.resizeObserver.unobserve(this.$refs.headerHeightRef)\r\n }\r\n }\r\n}\r\n</script>\r\n","<template>\r\n <section class=\"w-full bg-transparent\" :class=\"[alert ? '' : loginMenuOpen || showSearchField ? 'absolute top-0 left-0 right-0 bottom-0 z-40' : 'relative', onMapPage ? 'hidden md:block' : 'block'].join(' ')\">\r\n <div>\r\n <ellevio-web-mobile-nav-head\r\n :api-url=\"apiUrl\"\r\n :top-names=\"topNames && Object.keys(topNames).length ? topNames : undefined\"\r\n :logo-link=\"logoLink\"\r\n :menu-open=\"false\"\r\n :tree-open=\"false\"\r\n :tree-heading=\"treeHeading\"\r\n :tree-heading-link=\"treeHeadingLink\"\r\n :show-search-field=\"showSearchField\"\r\n :search=\"search\"\r\n :my-pages=\"myPages\"\r\n :show-login=\"showLogin\"\r\n :login-menu=\"loginMenu\"\r\n :user-logged-in=\"userLoggedIn\"\r\n :translations=\"translations\"\r\n :show-autocomplete-list=\"showAutocompleteList\"\r\n @show-search-field=\"handleShowSearchField\"\r\n @close-search-field=\"handleCloseSearchField\"\r\n @toggle-login-menu=\"handleToggleLoginMenu\"\r\n @toggle-menu=\"handleToggleMenu\"\r\n @close-menu=\"handleCloseMenu\"\r\n @show-main-menu=\"handleShowMainMenu\" />\r\n <ellevio-web-mobile-login-wide-area v-show=\"loginMenuOpen\" :my-pages=\"myPages\" :translations=\"translations\" :login=\"loginMenu\" :user-logged-in=\"userLoggedIn\" @close-login-menu=\"closeLoginMenu\" />\r\n <ellevio-web-mobile-search-wide-area\r\n v-show=\"showSearchField\"\r\n :my-pages=\"myPages\"\r\n :translations=\"translations\"\r\n :searchApiUrl=\"searchApiUrl\"\r\n :searchPageUrl=\"searchPageUrl\"\r\n :searchNoHitsContent=\"searchNoHitsContent\"\r\n @close-search-field=\"handleCloseSearchField\"\r\n @close-search-menu=\"handleCloseSearchField\" />\r\n </div>\r\n </section>\r\n <section v-show=\"menuOpen\" class=\"absolute top-0 left-0 right-0 z-[2000] block w-full min-h-screen back lg:hidden bg-[rgba(44,40,39,0.4)] mobile-area\" @click=\"closeMenuFromSide\">\r\n <div class=\"absolute top-0 right-0 z-50 block w-full min-h-screen bg-white lg:hidden mobile-main\">\r\n <div class=\"relative overflow-y-scroll h-[100dvh]\">\r\n <div class=\"flex flex-col items-end py-2.5 pl-2 pr-0 bg-white lg:p-2 border-b-gray-ultralight border-b-1\" tabindex=\"0\">\r\n <button class=\"flex flex-col items-center justify-center pt-1 mr-2.5\" type=\"button\" @click=\"handleToggleMenu\" @keyup.enter=\"handleToggleMenu\" @keydown.esc=\"closeMenu\" data-testid=\"mobileMenuCloseButton\">\r\n <img v-show=\"menuOpen\" width=\"18\" height=\"18\" class=\"inline top-mobile-icons\" src=\"../../../assets/images/cross-black.svg\" alt=\"close menu\" />\r\n <span class=\"whitespace-nowrap mt-0.5 leading-4 uppercase font-futuraEfDemiBold text-[0.6875rem] text-newColors-gray-content\">{{ translations?.topMenuMobile.closeMenu }}</span>\r\n </button>\r\n </div>\r\n <ellevio-web-mobile-nav-tree :menuItems=\"menuItems\" :menuOpen=\"menuOpen\" />\r\n <ellevio-web-mobile-nav-footer :footerLinks=\"footerLinks\" :footer-language=\"otherLanguage\" :translations=\"translations\" />\r\n </div>\r\n </div>\r\n </section>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebMobileNavHead from './MobileNavHead.vue'\r\nimport EllevioWebMobileLoginWideArea from './MobileLoginWideArea.vue'\r\nimport EllevioWebMobileSearchWideArea from './MobileSearchWideArea.vue'\r\nimport EllevioWebMobileNavTree from './MobileNavTree.vue'\r\nimport EllevioWebMobileNavFooter from './MobileNavFooter.vue'\r\n\r\nimport apiUrl from '../../../helpers/apiUrl'\r\nimport axios from 'axios'\r\nimport store from '../../../store/index'\r\n\r\nexport default {\r\n name: 'EllevioWebMobileNav',\r\n components: {\r\n EllevioWebMobileNavHead,\r\n EllevioWebMobileLoginWideArea,\r\n EllevioWebMobileSearchWideArea,\r\n EllevioWebMobileNavTree,\r\n EllevioWebMobileNavFooter\r\n },\r\n props: {\r\n mobileNavigationData: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n translations: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n loginMenu: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n onMapPage: {\r\n type: Boolean,\r\n default: false\r\n },\r\n lang: {\r\n type: String,\r\n default: 'sv'\r\n },\r\n alert: {\r\n type: Boolean,\r\n default: false\r\n },\r\n topNames: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n logoLink: {\r\n type: String,\r\n default: '/'\r\n },\r\n myPages: {\r\n type: Boolean,\r\n default: false\r\n },\r\n tree: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n menuItems: {\r\n type: Array,\r\n default: () => []\r\n },\r\n topLinks: {\r\n type: Array\r\n },\r\n breakpoint: {\r\n type: String,\r\n default: '64rem'\r\n },\r\n //\"startsidans\" länklista\r\n initialLinks: {\r\n type: Array\r\n },\r\n search: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n footerLinks: {\r\n type: Array\r\n },\r\n otherLanguage: {\r\n type: Object\r\n },\r\n apiUrl: {\r\n type: String,\r\n required: true\r\n },\r\n showAutocompleteList: {\r\n type: Boolean,\r\n default: false\r\n },\r\n userLoggedIn: {\r\n type: Boolean,\r\n default: false\r\n },\r\n searchApiUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n searchPageUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n searchNoHitsContent: {\r\n type: String,\r\n default: ''\r\n }\r\n },\r\n data() {\r\n return {\r\n menuOpen: false,\r\n loginMenuOpen: false,\r\n showNavigationTree: false,\r\n showSearchField: false,\r\n fetchedData: [],\r\n treeData: {},\r\n treeHeading: '',\r\n treeHeadingLink: '',\r\n isMobile: true\r\n }\r\n },\r\n computed: {\r\n matchMediaQuery() {\r\n return window.matchMedia(` (min-width: ${this.breakpoint}) `)\r\n },\r\n showLogin() {\r\n return this.loginMenu !== undefined && this.loginMenu !== null && Object.keys(this.loginMenu).length > 0\r\n }\r\n },\r\n mounted() {\r\n this.isMobile = this.matchMediaQuery ? !this.matchMediaQuery.matches : true\r\n this._boundedResize = this.resize.bind(this)\r\n window.addEventListener('resize', this._boundedResize)\r\n\r\n if (this.tree && Object.keys(this.tree).length > 0) {\r\n this.treeData = this.tree\r\n this.treeHeading = this.treeData.text\r\n this.treeHeadingLink = this.treeData.url\r\n this.showNavigationTree = true\r\n }\r\n },\r\n unmounted() {\r\n window.removeEventListener('resize', this._boundedResize)\r\n },\r\n methods: {\r\n resize: function () {\r\n this.isMobile = this.matchMediaQuery ? !this.matchMediaQuery.matches : true\r\n\r\n if (!this.isMobile && this.menuOpen) {\r\n this.handleToggleMenu()\r\n }\r\n },\r\n handleFixedScrollState(toggle) {\r\n const bodyClassNames = ['fixed', 'overflow-y-scroll', 'w-full']\r\n if (!toggle && document.body.classList.contains(bodyClassNames[0])) {\r\n document.body.classList.remove(...bodyClassNames)\r\n } else {\r\n document.body.classList.add(...bodyClassNames)\r\n }\r\n },\r\n handleToggleMenu() {\r\n this.menuOpen = !this.menuOpen\r\n\r\n this.handleFixedScrollState(this.menuOpen)\r\n\r\n //also close login menu\r\n this.loginMenuOpen = false\r\n\r\n //also close facility selector from MyPages\r\n this.closeDeliverySiteSelectorMobile()\r\n },\r\n closeMenuFromSide(e) {\r\n if (this.menuOpen && typeof e.target.className === 'string' && e.target.className.indexOf('mobile-area') !== -1) {\r\n this.menuOpen = !this.menuOpen\r\n this.handleFixedScrollState(this.menuOpen)\r\n }\r\n },\r\n handleToggleLoginMenu() {\r\n this.loginMenuOpen = !this.loginMenuOpen\r\n\r\n this.handleFixedScrollState(this.loginMenuOpen)\r\n\r\n //also close deliverySite selector from MyPages\r\n this.closeDeliverySiteSelectorMobile()\r\n },\r\n closeLoginMenu() {\r\n this.loginMenuOpen = false\r\n const bodyClassNames = ['fixed', 'overflow-y-scroll', 'w-full']\r\n if (document.body.classList.contains(bodyClassNames[0])) {\r\n document.body.classList.remove(...bodyClassNames)\r\n }\r\n },\r\n handleShowSearchField() {\r\n this.showSearchField = true\r\n\r\n const bodyClassNames = ['fixed', 'overflow-y-scroll', 'w-full']\r\n if (!document.body.classList.contains(bodyClassNames[0])) {\r\n document.body.classList.add(...bodyClassNames)\r\n }\r\n },\r\n handleCloseSearchField() {\r\n this.showSearchField = false\r\n const bodyClassNames = ['fixed', 'overflow-y-scroll', 'w-full']\r\n if (document.body.classList.contains(bodyClassNames[0])) {\r\n document.body.classList.remove(...bodyClassNames)\r\n }\r\n },\r\n handleCloseMenu() {\r\n if (this.menuOpen) {\r\n this.menuOpen = !this.menuOpen\r\n }\r\n },\r\n handleShowMainMenu() {\r\n this.treeData = {}\r\n this.showNavigationTree = false\r\n },\r\n handleShowNavigationTree: async function (parentId) {\r\n if (!this.showNavigationTree) {\r\n this.treeData = await this.fetchChildren(parentId)\r\n\r\n this.treeHeading = this.treeData.text\r\n this.treeHeadingLink = this.treeData.url\r\n this.showNavigationTree = !this.showNavigationTree\r\n } else {\r\n this.showNavigationTree = !this.showNavigationTree\r\n }\r\n },\r\n fetchChildren: async function (parentId) {\r\n if (!this.fetchedData[parentId]) {\r\n const response = await axios.get(`${apiUrl.getMenuChildrenByParentId}${parentId}`, { headers: { 'Accept-Language': this.lang } })\r\n const responseData = response.data.data\r\n this.fetchedData[parentId] = responseData\r\n\r\n return responseData\r\n }\r\n\r\n return this.fetchedData[parentId]\r\n },\r\n closeDeliverySiteSelectorMobile() {\r\n store.dispatch('SET_closeDeliverySiteSelectorMobile')\r\n }\r\n }\r\n}\r\n</script>\r\n","<template>\r\n <header\r\n class=\"flex pl-2 pr-3 bg-white\"\r\n style=\"padding-top: 0.375rem; padding-bottom: 0.375rem\"\r\n :class=\"[menuOpen ? 'bg-white' : '', treeOpen && menuOpen ? 'items-start' : 'items-center', !showSearchField && !menuOpen ? 'justify-between' : 'justify-end'].join(' ')\"\r\n data-testid=\"mobile-nav-head\">\r\n <a v-if=\"!showSearchField && !menuOpen\" v-show=\"!(treeOpen && menuOpen)\" :aria-label=\"translations?.ariaLabels?.goToStartPage\" :href=\"logoLink\" class=\"flex items-center pt-0 pl-1 lg:pl-4\" data-testid=\"mobileMenuLogoLink\">\r\n <img class=\"inline\" width=\"111\" height=\"23\" src=\"../../../assets/images/logo-orange.svg\" alt=\"Ellevio logo\" data-testid=\"mobileMenuLogoImage\" />\r\n </a>\r\n <div v-if=\"treeOpen && menuOpen\">\r\n <button class=\"flex items-center px-2 pt-3 pb-2\" @click=\"showMainMenu\" @keyup.enter=\"showMainMenu\">\r\n <svg class=\"transform rotate-180\" width=\"8\" height=\"13\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M1.585 0L.001 1.584l6.414 6.415L8 6.414 1.585 0zM0 11.204l1.585 1.585L5.36 9.015 3.775 7.429 0 11.204z\" fill=\"#000\" />\r\n </svg>\r\n <!-- TODO: lang: Huvudmeny-->\r\n <span class=\"ml-2\">Huvudmeny</span>\r\n </button>\r\n <h3 v-if=\"treeHeadingLink\" class=\"mt-1 mb-2 ml-2\" style=\"font-size: 32px\">\r\n <a :href=\"treeHeadingLink\" class=\"group\">{{ treeHeading }}<ellevio-web-link-icon class=\"relative w-8 h-8 -top-0.5\" /></a>\r\n </h3>\r\n <h3 v-if=\"!treeHeadingLink\" class=\"mt-1 mb-2 ml-2\" style=\"font-size: 32px\">\r\n {{ treeHeading }}\r\n </h3>\r\n </div>\r\n\r\n <ul v-if=\"!showSearchField\" class=\"flex\">\r\n <li v-if=\"!myPages\" tabindex=\"0\" class=\"flex flex-col items-center p-2 pb-1 cursor-pointer\" @keyup.enter=\"toggleSearchField\" @click=\"toggleSearchField\" data-testid=\"mobileMenuSearchOption\">\r\n <img v-show=\"!menuOpen\" class=\"inline top-mobile-icons\" width=\"22\" height=\"22\" src=\"../../../assets/images/search-black.svg\" alt=\"search\" />\r\n <span v-show=\"!menuOpen\" class=\"whitespace-nowrap mt-0.5 uppercase font-futuraEfDemiBold text-[0.6875rem]\" :class=\"!menuOpen && dark ? 'text-white' : 'text-black'\">{{ translations?.search?.menuLabel }}</span>\r\n </li>\r\n <li v-if=\"showLogin\" tabindex=\"0\" class=\"flex flex-col items-center p-2 pb-1 cursor-pointer\" @keyup.enter=\"toggleLoginMenu\" @click=\"toggleLoginMenu\" data-testid=\"mobileMenuLoginOption\">\r\n <img v-show=\"!menuOpen\" class=\"inline top-mobile-icons\" width=\"22\" height=\"22\" src=\"../../../assets/images/login-black.svg\" alt=\"log in\" />\r\n <span v-show=\"!menuOpen\" class=\"whitespace-nowrap mt-0.5 uppercase font-futuraEfDemiBold w-14 text-center text-[0.6875rem] text-newColors-gray-content\" :class=\"{ 'text-ellipsis overflow-hidden': userLoggedIn }\">{{ profileButtonText }}</span>\r\n </li>\r\n <li class=\"flex flex-col items-center pt-2 pb-1 pl-2 pr-0 cursor-pointer lg:p-2\" tabindex=\"0\" @click=\"toggleMenu\" @keyup.enter=\"toggleMenu\" @keydown.esc=\"closeMenu\" data-testid=\"mobileMenuMenuOption\">\r\n <img v-show=\"menuOpen\" width=\"18\" height=\"18\" class=\"inline top-mobile-icons\" src=\"../../../assets/images/cross-black.svg\" alt=\"close menu\" />\r\n <img v-show=\"!menuOpen\" width=\"22\" height=\"22\" class=\"inline top-mobile-icons\" src=\"../../../assets/images/menu-black.svg\" alt=\"open menu\" />\r\n <span class=\"whitespace-nowrap mt-0.5 uppercase font-futuraEfDemiBold text-[0.6875rem]\" :class=\"!menuOpen && dark ? 'text-white' : 'text-black'\">{{ translations?.topMenuMobile.menuLabel }}</span>\r\n </li>\r\n </ul>\r\n </header>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebLinkIcon from '../structure/LinkIcon.vue'\r\n//import EllevioWebSearchInput from '../vue-components/SearchInput.vue'\r\n\r\nexport default {\r\n name: 'EllevioWebMobileNavHead',\r\n components: {\r\n EllevioWebLinkIcon\r\n //EllevioWebSearchInput\r\n },\r\n props: {\r\n loginMenu: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n translations: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n logoLink: {\r\n type: String,\r\n default: '/'\r\n },\r\n menuOpen: {\r\n type: Boolean,\r\n default: false\r\n },\r\n treeOpen: {\r\n type: Boolean,\r\n default: false\r\n },\r\n treeHeading: {\r\n type: String,\r\n default: ''\r\n },\r\n treeHeadingLink: {\r\n type: String,\r\n default: ''\r\n },\r\n dark: {\r\n type: Boolean,\r\n default: false\r\n },\r\n showSearchField: {\r\n type: Boolean,\r\n default: false\r\n },\r\n tagsForSmallerInput: {\r\n type: Boolean,\r\n default: false\r\n },\r\n myPages: {\r\n type: Boolean,\r\n default: false\r\n },\r\n showLogin: {\r\n type: Boolean,\r\n default: true\r\n },\r\n userLoggedIn: {\r\n type: Boolean,\r\n default: false\r\n },\r\n apiUrl: {\r\n type: String,\r\n required: true\r\n },\r\n showAutocompleteList: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n data() {\r\n return {\r\n emptySearchField: false\r\n }\r\n },\r\n computed: {\r\n profileButtonText: function () {\r\n if (this.loginMenu?.userName?.length > 0) {\r\n const userNameSplit = this.loginMenu.userName.split(' ')\r\n const potentialFirstName = userNameSplit[0]\r\n\r\n return potentialFirstName.length > 10 ? potentialFirstName.substring(0, 10) + '...' : potentialFirstName\r\n } else return this.loginMenu.heading\r\n }\r\n },\r\n methods: {\r\n objectEmpty(obj) {\r\n return typeof obj === 'undefined' || (Object.keys(obj).length === 0 && obj.constructor === Object)\r\n },\r\n toggleMenu() {\r\n this.$emit('toggle-menu')\r\n },\r\n closeMenu() {\r\n this.$emit('close-menu')\r\n },\r\n showMainMenu() {\r\n this.$emit('show-main-menu')\r\n },\r\n toggleLoginMenu() {\r\n this.$emit('toggle-login-menu')\r\n },\r\n toggleSearchField() {\r\n this.$emit('show-search-field')\r\n },\r\n closeSearchField() {\r\n this.emptySearchField = true\r\n this.$emit('close-search-field')\r\n }\r\n }\r\n}\r\n</script>\r\n","import { render } from \"./MobileNavHead.vue?vue&type=template&id=b5c03162\"\nimport script from \"./MobileNavHead.vue?vue&type=script&lang=js\"\nexport * from \"./MobileNavHead.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","<template>\r\n <div class=\"fixed top-0 bottom-0 left-0 right-0 z-[2000] px-3 py-2 bg-white overflow-y-scroll\">\r\n <div class=\"flex items-center justify-end mb-4\">\r\n <button class=\"flex flex-col items-center justify-center pt-2\" type=\"button\" @click=\"closeLoginMenu\" @keydown.esc=\"closeMenu\" data-testid=\"mobileMenuCloseLoginMenuButton\">\r\n <img width=\"18\" height=\"18\" class=\"inline top-mobile-icons\" src=\"../../../assets/images/cross-black.svg\" alt=\"close menu\" />\r\n <span class=\"whitespace-nowrap text-black leading-4 mt-0.5 uppercase font-futuraEfDemiBold text-[0.6875rem]\">{{ translations?.topMenuMobile.closeMenu }}</span>\r\n </button>\r\n <!--\r\n <button class=\"p-2 focus:outline-black-alt-tight\" @click=\"closeLoginMenu\">\r\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" class=\"inline-block\" width=\"26px\" height=\"26px\" viewBox=\"0 0 20 20\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M10 8.182L18.182 0 20 1.818 1.818 20 0 18.182 8.182 10 0 1.818 1.818 0 10 8.182zM18.182 20l-6.73-6.73 1.819-1.817L20 18.182 18.182 20z\" fill=\"#000\" />\r\n </svg>\r\n </button>\r\n -->\r\n </div>\r\n <div class=\"flex flex-col items-center mb-7\">\r\n <div class=\"flex items-center justify-center w-[5.5rem] h-[5.5rem] rounded-full bg-green-dark mb-2\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"45\" height=\"45\" fill=\"none\" viewBox=\"0 0 16 16\" class=\"absolute w-[2.8rem] h-[2.8rem]\" data-testid=\"mobileMenuLoginIcon\">\r\n <path fill=\"#FFF\" d=\"M1.57 15.2c.897-1.872 3.44-3.168 6.43-3.168 2.99 0 5.533 1.368 6.43 3.168H16c-.897-2.664-4.112-4.608-8-4.608S.897 12.536 0 15.2h1.57Z\" />\r\n <path\r\n fill=\"#FFF\"\r\n d=\"M7.776.8C4.86.8 2.542 3.032 2.542 5.84c0 2.232 1.57 4.176 3.664 4.824l.448-1.368c-1.495-.432-2.617-1.8-2.617-3.456 0-2.016 1.645-3.6 3.739-3.6 2.093 0 3.738 1.584 3.738 3.6 0 1.584-1.047 2.88-2.467 3.384l.523 1.368c2.019-.72 3.44-2.592 3.44-4.752C13.01 3.032 10.616.8 7.775.8Z\" />\r\n </svg>\r\n </div>\r\n <h3 class=\"inline-block mb-2 text-4xl\" data-testid=\"mobileMenuLoginHeading\">\r\n {{ login?.heading }}\r\n </h3>\r\n <p class=\"text-lg leading-6 text-center\" data-testid=\"mobileMenuLoginParagraph\">{{ login?.description }}</p>\r\n <div v-if=\"login?.areas?.length > 0\" class=\"w-full mt-6 mobile-maxwidth\">\r\n <div v-for=\"(area, index) in login?.areas\" :key=\"area.id\" class=\"w-full mobile-maxwidth\">\r\n <h4 class=\"text-xl normal-case\" :data-testid=\"`mobileMenuLoginSubHeading-${index}`\">\r\n {{ area.heading }}\r\n </h4>\r\n <ul v-if=\"area.links?.length > 0\" class=\"mb-5\">\r\n <li v-for=\"(link, subindex) in area.links\" :key=\"`${index}-${subindex}`\" class=\"mt-1\">\r\n <a :href=\"link.url\" class=\"arrow-link-forward\" :data-testid=\"`mobileMenuLoginSubLink-${index}-${subindex}`\">{{ link.text }}</a>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n <!-- Logout button -->\r\n <a v-if=\"login?.userName\" :href=\"login?.logOutButton?.url\" class=\"w-full mt-8 btn-secondary btn-icon-user mobile-maxwidth\">{{ login?.logOutButton?.text }}</a>\r\n </div>\r\n\r\n <ellevio-web-log-out-button :login=\"login\" :my-pages=\"myPages\" :user-logged-in=\"userLoggedIn\" />\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebLogOutButton from './LogOutButton.vue'\r\nexport default {\r\n name: 'EllevioWebMobileLoginArea',\r\n components: {\r\n EllevioWebLogOutButton\r\n },\r\n props: {\r\n login: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n myPages: {\r\n type: Boolean,\r\n default: false\r\n },\r\n userLoggedIn: {\r\n type: Boolean,\r\n default: false\r\n },\r\n translations: {\r\n type: Object,\r\n default: () => {}\r\n }\r\n },\r\n methods: {\r\n closeLoginMenu() {\r\n this.$emit('close-login-menu')\r\n }\r\n }\r\n}\r\n</script>\r\n<style>\r\n.mobile-maxwidth {\r\n max-width: 400px;\r\n}\r\n</style>\r\n","import { render } from \"./MobileLoginWideArea.vue?vue&type=template&id=df3cdbc2\"\nimport script from \"./MobileLoginWideArea.vue?vue&type=script&lang=js\"\nexport * from \"./MobileLoginWideArea.vue?vue&type=script&lang=js\"\n\nimport \"./MobileLoginWideArea.vue?vue&type=style&index=0&id=df3cdbc2&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","<template>\r\n <div class=\"absolute top-0 bottom-0 left-0 right-0 z-[2000] px-3 py-2 bg-white\">\r\n <div class=\"flex items-center justify-end w-full mb-4\">\r\n <button class=\"flex flex-col items-center justify-center pt-2\" type=\"button\" @click=\"closeSearchMenu\" @keydown.esc=\"closeSearchMenu\" data-testid=\"mobileMenuCloseSearchMenuButton\">\r\n <img width=\"18\" height=\"18\" class=\"inline top-mobile-icons\" src=\"../../../assets/images/cross-black.svg\" alt=\"close menu\" />\r\n <span class=\"whitespace-nowrap text-black mt-0.5 leading-4 uppercase font-futuraEfDemiBold text-[0.6875rem]\">{{ translations?.topMenuMobile.closeMenu }}</span>\r\n </button>\r\n </div>\r\n <form name=\"searchform\" :action=\"searchPageUrl\" data-testid=\"mobileMenuSearcForm\">\r\n <ellevio-web-header-search-input\r\n :apiUrl=\"searchApiUrl\"\r\n :searchNoHitsContent=\"searchNoHitsContent\"\r\n :label=\"translations?.search?.inputLabel\"\r\n :placeholder=\"translations?.search?.inputPlaceholder\"\r\n buttonText=\"Sök\"\r\n :itemIsOpen=\"true\"\r\n :clearSearchFieldLabel=\"translations?.search?.clearSearchField\" />\r\n </form>\r\n <div class=\"flex flex-col items-center mb-7\"></div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebHeaderSearchInput from '../vue-components/HeaderSearchInput.vue'\r\nexport default {\r\n name: 'EllevioWebMobileSearchWideArea',\r\n components: {\r\n EllevioWebHeaderSearchInput\r\n },\r\n props: {\r\n login: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n myPages: {\r\n type: Boolean,\r\n default: false\r\n },\r\n userLoggedIn: {\r\n type: Boolean,\r\n default: false\r\n },\r\n searchApiUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n searchPageUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n searchNoHitsContent: {\r\n type: String,\r\n default: ''\r\n },\r\n translations: {\r\n type: Object,\r\n default: () => {}\r\n }\r\n },\r\n methods: {\r\n closeSearchMenu() {\r\n this.$emit('close-search-menu')\r\n },\r\n objectEmpty(obj) {\r\n return typeof obj === 'undefined' || (Object.keys(obj).length === 0 && obj.constructor === Object)\r\n }\r\n }\r\n}\r\n</script>\r\n","<template>\r\n <div role=\"search\" class=\"h-[18.3rem]\">\r\n <label for=\"query\" class=\"hidden pb-3 text-2xl font-futuraEfDemiBold lg-rem:block\" data-testid=\"desktopAndMobileMenuSearchLabel\">{{ label }}</label>\r\n <div class=\"flex items-start gap-2 pointer-events-auto\">\r\n <div class=\"relative flex flex-col flex-1\">\r\n <div class=\"relative flex mb-2 header-search-input\">\r\n <input\r\n id=\"query\"\r\n ref=\"query\"\r\n v-model=\"inputText\"\r\n type=\"search\"\r\n style=\"width: calc(100% - 50px)\"\r\n class=\"p-3 pl-4 text-lg bg-white bg-no-repeat border-r-0 rounded-l-lg rounded-r-none placeholder:italic h-11 lg:h-10 pr-11 border-1 border-newColors-gray-contentD font-futuraEfBook bg-line-height bg-center-left\"\r\n name=\"query\"\r\n autocomplete=\"off\"\r\n :placeholder=\"placeholder\"\r\n @keyup=\"keyUpEvents($event)\"\r\n data-testid=\"desktopAndMobileMenuSearchInput\" />\r\n <button v-if=\"deleteTextCrossVisible\" @click=\"clearSearchField\" type=\"button\" class=\"mr-4 -ml-8 rounded-sm ellevio-clear-search-field\" :aria-label=\"clearSearchFieldLabel\" data-testid=\"desktopAndMobileMenuSearchInputDeleteCross\">\r\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 20 20\" class=\"\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M10 8.182L18.182 0 20 1.818 1.818 20 0 18.182 8.182 10 0 1.818 1.818 0 10 8.182zM18.182 20l-6.73-6.73 1.819-1.817L20 18.182 18.182 20z\" fill=\"#2C2827\" />\r\n </svg>\r\n </button>\r\n <!-- desktop (with wrapper) -->\r\n <ellevio-web-tooltip-wrapper :content=\"searchTooltipLabel\" :active=\"true\" placement=\"bottom\" class=\"hidden lg:flex\" :aria-label=\"label\">\r\n <button class=\"items-center justify-center hidden custom-search-button lg:flex\" type=\"submit\" :aria-label=\"label\" @click=\"submitForm\" :data-testid=\"`desktopMenuSearchButton`\">\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n fill-rule=\"evenodd\"\r\n clip-rule=\"evenodd\"\r\n d=\"M10.8554 9.524C9.97207 10.548 8.66793 11.2 7.21229 11.2C4.55993 11.2 2.40293 9.0464 2.40293 6.4C2.40293 3.7528 4.55993 1.6 7.21229 1.6C9.86386 1.6 12.0209 3.7528 12.0209 6.4C12.0209 7.132 11.8509 7.8232 11.5568 8.444L13.0052 9.1264C13.3995 8.2984 13.624 7.376 13.624 6.4C13.624 2.8712 10.7472 0 7.21229 0C3.67581 0 0.799805 2.8712 0.799805 6.4C0.799805 9.9288 3.67581 12.8 7.21229 12.8C8.40982 12.8 9.528 12.4648 10.4875 11.8912L14.6043 16L15.9998 14.6072L10.8554 9.524Z\"\r\n fill=\"#0B8454\" />\r\n </svg>\r\n </button>\r\n </ellevio-web-tooltip-wrapper>\r\n <!-- mobile -->\r\n <button class=\"block pl-3.5 custom-search-button lg:hidden\" :aria-label=\"label\" :data-testid=\"`mobileMenuSearchButton`\">\r\n <svg width=\"19\" height=\"20\" viewBox=\"0 0 19 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <mask id=\"mask0_3375_3177\" style=\"mask-type: luminance\" maskUnits=\"userSpaceOnUse\" x=\"0\" y=\"0\" width=\"19\" height=\"20\"><path d=\"M0 0H18.963V20H0V0Z\" fill=\"white\" /></mask>\r\n <g mask=\"url(#mask0_3375_3177)\">\r\n <path\r\n fill-rule=\"evenodd\"\r\n clip-rule=\"evenodd\"\r\n d=\"M12.545 11.905C11.9835 12.5615 11.2865 13.0886 10.5019 13.4503C9.7174 13.8119 8.86388 13.9994 8 14C4.691 14 2 11.308 2 8C2 4.691 4.691 2 8 2C9.59064 2.00185 11.1156 2.63462 12.2402 3.75947C13.3649 4.88431 13.9974 6.40936 13.999 8C13.999 8.915 13.787 9.779 13.42 10.555L15.227 11.408C15.7351 10.3437 15.9989 9.17934 15.999 8C15.999 3.589 12.41 0 8 0C3.588 0 0 3.589 0 8C0 12.411 3.588 16 8 16C9.43991 15.9996 10.8525 15.6068 12.086 14.864L17.222 20L18.963 18.259L12.545 11.905Z\"\r\n fill=\"#0B8454\" />\r\n </g>\r\n </svg>\r\n </button>\r\n </div>\r\n <ul v-if=\"showAutoComplete === true && matches && matches.length > 0 && showAutocompleteList\" v-click-outside=\"closeAutoComplete\" class=\"w-full\" @keyup.esc=\"handleEsc\">\r\n <li v-for=\"(item, index) in matches\" :key=\"index\" class=\"relative flex items-center px-4 py-2 cursor-pointer ellevio-header-search-result-remove-focus group\">\r\n <a tabindex=\"0\" :href=\"item.url\" class=\"text-lg rounded-sm ellevio-header-search-hit-hightlight\" @keyup.enter=\"autocompleteClick($event)\" @click=\"autocompleteClick($event)\" v-html=\"item.title\" />\r\n </li>\r\n </ul>\r\n <ellevio-search-input-error-message v-if=\"inputText.length > 2 && matches && matches.length === 0 && showAutoComplete && showAutocompleteList\" :errorMessage=\"searchNoHitsContent\" />\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport axios from 'axios'\r\nimport { clickOutside } from '../../../directives/clickOutside'\r\nimport EllevioWebTooltipWrapper from '../../web/vue-components/TooltipWrapper.vue'\r\nimport EllevioSearchInputErrorMessage from '../../web/vue-components/SearchInputErrorMessage.vue'\r\nimport { getBaseUrl } from '../../../helpers/utils'\r\n\r\nexport default {\r\n name: 'EllevioWebSearchInput',\r\n components: {\r\n EllevioWebTooltipWrapper,\r\n EllevioSearchInputErrorMessage\r\n },\r\n directives: {\r\n 'click-outside': clickOutside\r\n },\r\n props: {\r\n itemIsOpen: {\r\n type: Boolean,\r\n default: false\r\n },\r\n sizeSmall: {\r\n type: Boolean,\r\n default: true\r\n },\r\n sizeSearch: {\r\n type: Boolean,\r\n default: false\r\n },\r\n backgroundBox: {\r\n type: Boolean,\r\n default: false\r\n },\r\n placeholderText: {\r\n type: String,\r\n default: ''\r\n },\r\n buttonText: {\r\n type: String,\r\n default: ''\r\n },\r\n value: {\r\n type: String,\r\n default: ''\r\n },\r\n useInHeader: {\r\n type: Boolean,\r\n default: false\r\n },\r\n dark: {\r\n type: Boolean,\r\n default: false\r\n },\r\n showSearchField: {\r\n type: Boolean,\r\n default: false\r\n },\r\n numberOfItems: {\r\n type: Number,\r\n default: 5\r\n },\r\n showAutocompleteList: {\r\n type: Boolean,\r\n default: true\r\n },\r\n apiUrl: {\r\n type: String,\r\n required: true\r\n },\r\n label: {\r\n type: String,\r\n default: ''\r\n },\r\n searchTooltipLabel: {\r\n type: String,\r\n default: ''\r\n },\r\n searchNoHitsContent: {\r\n type: String,\r\n default: ''\r\n },\r\n placeholder: {\r\n type: String,\r\n default: ''\r\n },\r\n clearSearchFieldLabel: {\r\n type: String,\r\n default: ''\r\n }\r\n },\r\n data() {\r\n return {\r\n showAutoComplete: false,\r\n hover: [],\r\n inputText: this.value,\r\n timer: null,\r\n getAutocompleteItems: [],\r\n deleteTextCrossVisible: false\r\n }\r\n },\r\n computed: {\r\n baseUrl() {\r\n return getBaseUrl()\r\n },\r\n matches() {\r\n if (this.inputText == '') {\r\n return []\r\n }\r\n let env = {}\r\n try {\r\n env = import.meta.env\r\n if (typeof env !== 'object') env = {}\r\n } catch (_) {\r\n env = {}\r\n }\r\n\r\n if (env.MODE === 'development') {\r\n return this.getAutocompleteItems.filter((item) => item.title?.toLowerCase().includes(this.inputText.toLowerCase())).slice(0, this.numberOfItems)\r\n } else {\r\n return this.getAutocompleteItems.slice(0, this.numberOfItems)\r\n }\r\n }\r\n },\r\n watch: {\r\n showSearchField: function (newVal) {\r\n if (newVal) {\r\n this.$nextTick(async function () {\r\n this.$refs.query.focus()\r\n })\r\n }\r\n },\r\n itemIsOpen: function () {\r\n this.itemIsOpen ? this.focusSearchField() : this.emptySearchField()\r\n }\r\n },\r\n methods: {\r\n submitForm() {\r\n document.forms.searchform.submit()\r\n },\r\n emptySearchField() {\r\n this.inputText = ''\r\n },\r\n clearSearchField() {\r\n this.inputText = ''\r\n this.deleteTextCrossVisible = false\r\n this.$refs.query.focus()\r\n },\r\n closeAutoComplete() {\r\n this.showAutoComplete = false\r\n },\r\n getData: async function (inputText) {\r\n const response = await axios.get(`${this.baseUrl}${this.apiUrl}?query=${inputText}&hits=${this.numberOfItems}`)\r\n const responseData = response.data.data\r\n\r\n return Object.keys(responseData).length === 0 ? [] : responseData\r\n },\r\n handleEsc() {\r\n this.showAutoComplete = false\r\n },\r\n keyUpEvents: async function ($event) {\r\n if (!this.showAutocompleteList) return\r\n clearTimeout(this.timer)\r\n this.inputText = $event.target.value\r\n this.deleteTextCrossVisible = this.inputText.length > 0\r\n if (this.inputText.length > 2) {\r\n this.timer = setTimeout(\r\n async function () {\r\n this.getAutocompleteItems = await this.getData(this.inputText)\r\n this.showAutoComplete = true\r\n }.bind(this),\r\n 150\r\n )\r\n } else {\r\n this.showAutoComplete = false\r\n }\r\n },\r\n autocompleteClick: function () {\r\n //this.inputText = $event.target.innerText\r\n this.showAutoComplete = false\r\n },\r\n focusSearchField: function () {\r\n this.$nextTick(async function () {\r\n this.$refs.query.focus()\r\n })\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.custom-search-button {\r\n width: 3.125rem;\r\n @apply border-1 border-l-0 relative border-newColors-gray-contentD rounded-r-lg font-futuraEfBook text-lg;\r\n}\r\n\r\n.ellevio-clear-search-field svg {\r\n height: 1rem;\r\n width: 1rem;\r\n}\r\n\r\n.custom-search-button::before {\r\n @apply content-[''] bg-newColors-gray-contentD absolute left-0 top-1 bottom-1 w-[1px];\r\n}\r\n\r\n.custom-search-button svg {\r\n height: 1.25rem;\r\n width: 1.1875rem;\r\n}\r\n\r\n.ellevio-header-search-hit-hightlight :deep(span) {\r\n @apply font-futuraEfDemiBold;\r\n}\r\n\r\ninput[type='search'][autocomplete]:focus {\r\n @apply border-1 border-r-0 border-newColors-gray-contentD !important;\r\n}\r\n\r\n.header-search-input:hover {\r\n box-shadow: 0px 4px 12px 0px rgba(0, 0, 0, 0.05);\r\n}\r\n</style>\r\n","import { render } from \"./HeaderSearchInput.vue?vue&type=template&id=7b8fe811&scoped=true\"\nimport script from \"./HeaderSearchInput.vue?vue&type=script&lang=js\"\nexport * from \"./HeaderSearchInput.vue?vue&type=script&lang=js\"\n\nimport \"./HeaderSearchInput.vue?vue&type=style&index=0&id=7b8fe811&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-7b8fe811\"]])\n\nexport default __exports__","import { render } from \"./MobileSearchWideArea.vue?vue&type=template&id=349e0ea6\"\nimport script from \"./MobileSearchWideArea.vue?vue&type=script&lang=js\"\nexport * from \"./MobileSearchWideArea.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","<template>\r\n <div class=\"pb-2 bg-white nav-mobile-render\">\r\n <ul>\r\n <li v-for=\"(item, index) in menuItems\" :key=\"index\" class=\"flex flex-col items-center justify-between border-b-gray-ultralight border-b-1\">\r\n <div class=\"flex items-center justify-between w-full nav-mobile-render-linkrow\">\r\n <button class=\"flex items-stretch justify-between w-full pl-4 text-xl\" @click=\"toggleMenuItem($event, anyChildrenActive(item.nodes ?? []))\" :data-testid=\"`mobileMenuNavTreeToggleButtonLvl1-${index}`\">\r\n <span class=\"flex items-center py-2 text-xl\" :class=\"item.isSelected ? 'page-active' : ''\" :data-testid=\"`mobileMenuNavTreeItemLvl1-${index}`\">{{ item.heading }}</span>\r\n <div class=\"px-3 py-3 nav-mobile-render-wrap-icons\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"36\" height=\"36\" fill=\"none\" viewBox=\"0 0 36 36\" :class=\"anyChildrenActive(item.nodes ?? []) ? 'hidden' : ''\" :data-testid=\"`mobileMenuNavTreeToggleButtonPlusIconLvl1-${index}`\">\r\n <rect width=\"36\" height=\"36\" fill=\"transparent\" rx=\"18\" />\r\n <path fill=\"#2C2827\" fill-rule=\"evenodd\" d=\"M16.847 16.851V9.028h2.306V26.97h-2.306v-7.813l-7.818-.003v-2.303h7.818Zm10.124 2.303h-5.975v-2.306h5.975v2.306Z\" clip-rule=\"evenodd\" />\r\n </svg>\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"36\" height=\"36\" fill=\"none\" viewBox=\"0 0 36 36\" :class=\"anyChildrenActive(item.nodes ?? []) ? '' : 'hidden'\" :data-testid=\"`mobileMenuNavTreeToggleButtonMinusIconLvl1-${index}`\">\r\n <rect width=\"36\" height=\"36\" fill=\"transparent\" rx=\"18\" />\r\n <path fill=\"#2C2827\" d=\"M25.973 19.025H10.025v-2.05h15.948v2.05Z\" />\r\n </svg>\r\n </div>\r\n </button>\r\n </div>\r\n <ul class=\"level-wrapper\">\r\n <li v-for=\"(itemlvl2, index2) in item.nodes\" :key=\"index2\">\r\n <div class=\"flex items-stretch justify-between w-full border-white border-t-1 nav-mobile-render-linkrow\">\r\n <a\r\n :href=\"itemlvl2.url\"\r\n :target=\"itemlvl2.target === '' ? '_self' : itemlvl2.target\"\r\n class=\"pl-[26px] text-lg flex items-center w-full\"\r\n :class=\"itemlvl2.isSelected ? 'page-active' : ''\"\r\n :data-testid=\"`mobileMenuNavTreeItemLinkLvl2-${index}-${index2}`\"\r\n >{{ itemlvl2.text }}</a\r\n >\r\n <button\r\n class=\"px-3 py-2 border-white border-l-1 lvl2Button\"\r\n @click=\"\r\n toggleMenuItem(\r\n $event,\r\n itemlvl2.items.find((x) => x.isSelected === true)\r\n )\r\n \"\r\n :data-testid=\"`mobileMenuNavTreeToggleButtonLvl2-${index}-${index2}`\">\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n width=\"36\"\r\n height=\"36\"\r\n fill=\"none\"\r\n viewBox=\"0 0 36 36\"\r\n :class=\"itemlvl2.items.find((x) => x.isSelected === true) ? 'hidden' : ''\"\r\n :data-testid=\"`mobileMenuNavTreeToggleButtonPlusIconLvl2-${index}-${index2}`\">\r\n <rect width=\"36\" height=\"36\" fill=\"#E5E3E1\" rx=\"18\" />\r\n <path fill=\"#2C2827\" fill-rule=\"evenodd\" d=\"M16.847 16.851V9.028h2.306V26.97h-2.306v-7.813l-7.818-.003v-2.303h7.818Zm10.124 2.303h-5.975v-2.306h5.975v2.306Z\" clip-rule=\"evenodd\" />\r\n </svg>\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n width=\"36\"\r\n height=\"36\"\r\n fill=\"none\"\r\n viewBox=\"0 0 36 36\"\r\n :class=\"itemlvl2.items.find((x) => x.isSelected === true) ? '' : 'hidden'\"\r\n :data-testid=\"`mobileMenuNavTreeToggleButtonMinusIconLvl2-${index}-${index2}`\">\r\n <rect width=\"36\" height=\"36\" fill=\"#E5E3E1\" rx=\"18\" />\r\n <path fill=\"#2C2827\" d=\"M25.973 19.025H10.025v-2.05h15.948v2.05Z\" />\r\n </svg>\r\n </button>\r\n </div>\r\n <ul class=\"py-2 level-wrapper\">\r\n <li v-for=\"(itemlvl3, index3) in itemlvl2.items\" :key=\"index3\" class=\"\">\r\n <a\r\n :href=\"itemlvl3.url\"\r\n :target=\"itemlvl3.target === '' ? '_self' : itemlvl3.target\"\r\n class=\"text-lg pl-[40px] py-1.5 inline-block w-full\"\r\n :class=\"itemlvl3.isSelected ? 'page-active' : ''\"\r\n :data-testid=\"`mobileMenuNavTreeItemLinkLvl3-${index}-${index2}-${index3}`\"\r\n >{{ itemlvl3.text }}</a\r\n >\r\n </li>\r\n </ul>\r\n </li>\r\n </ul>\r\n </li>\r\n </ul>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nexport default {\r\n name: 'EllevioWebMobileNavTree',\r\n components: {},\r\n props: {\r\n menuItems: {\r\n type: Array,\r\n default: () => []\r\n },\r\n menuOpen: {\r\n type: Boolean,\r\n default: false\r\n },\r\n indentWidth: {\r\n type: Number,\r\n default: 15\r\n }\r\n },\r\n watch: {\r\n menuOpen(val) {\r\n if (val === true) {\r\n this.$nextTick(() => {\r\n const children = document.querySelectorAll('.nav-mobile-render-linkrow + ul')\r\n for (let i = 0; i < children.length; i++) {\r\n if (children[i].checkVisibility()) {\r\n children[i].previousSibling.querySelector('.nav-mobile-render-wrap-icons')?.classList.add('bgGray')\r\n children[i].parentNode.querySelector('.lvl2Button')?.classList.add('bgGray')\r\n }\r\n }\r\n })\r\n }\r\n }\r\n },\r\n methods: {\r\n anyChildrenActive(items) {\r\n return items.find((child) => child.isSelected === true) || items.find((child) => child.items.find((grandChild) => grandChild.isSelected === true))\r\n },\r\n toggleMenuItem($event, activeItem) {\r\n const el = $event.target.closest('.nav-mobile-render-linkrow')\r\n const plusSvg = el.querySelector('svg:first-of-type')\r\n const minusSvg = el.querySelector('svg:last-of-type')\r\n const lvl1Wrapper = el.querySelector('.nav-mobile-render-wrap-icons')\r\n const lvl2Button = el.querySelector('.lvl2Button')\r\n const nextEl = el.nextElementSibling\r\n if (nextEl) {\r\n if (nextEl.classList.contains('!block')) {\r\n nextEl.classList.remove('!block')\r\n nextEl.classList.add('!hidden')\r\n } else if (nextEl.classList.contains('!hidden')) {\r\n nextEl.classList.remove('!hidden')\r\n nextEl.classList.add('!block')\r\n } else {\r\n if (activeItem) {\r\n nextEl.classList.remove('!block')\r\n nextEl.classList.add('!hidden')\r\n } else {\r\n nextEl.classList.remove('!hidden')\r\n nextEl.classList.add('!block')\r\n }\r\n }\r\n }\r\n if (plusSvg) {\r\n plusSvg.classList.toggle('hidden')\r\n }\r\n if (minusSvg) {\r\n minusSvg.classList.toggle('hidden')\r\n }\r\n if (lvl1Wrapper) {\r\n lvl1Wrapper.classList.toggle('bgGray')\r\n }\r\n if (lvl2Button) {\r\n lvl2Button.classList.toggle('bgGray')\r\n }\r\n }\r\n }\r\n}\r\n</script>\r\n<style scoped>\r\n/*\r\n.nav-mobile-render .nav-mobile-render-linkrow + ul {\r\n display: none;\r\n}\r\n*/\r\n\r\n.nav-mobile-render ul,\r\n.nav-mobile-render li {\r\n width: 100%;\r\n}\r\n\r\n.nav-mobile-render ul ul {\r\n background-color: #f8f8f8; /* #f2f1f0;*/\r\n}\r\n.nav-mobile-render ul ul ul {\r\n background-color: #f1f1f1; /* #e5e3e1; */\r\n}\r\n.nav-mobile-render-wrap-icons.bgGray {\r\n background-color: #f8f8f8; /* #f2f1f0; */\r\n}\r\n.lvl2Button.bgGray {\r\n background-color: #f1f1f1; /* #e5e3e1; */\r\n}\r\n.level-wrapper {\r\n display: none;\r\n}\r\n.level-wrapper:has(.page-active) {\r\n display: block;\r\n}\r\n.page-active {\r\n @apply font-futuraEfDemiBold;\r\n}\r\n</style>\r\n","import { render } from \"./MobileNavTree.vue?vue&type=template&id=1b276b00&scoped=true\"\nimport script from \"./MobileNavTree.vue?vue&type=script&lang=js\"\nexport * from \"./MobileNavTree.vue?vue&type=script&lang=js\"\n\nimport \"./MobileNavTree.vue?vue&type=style&index=0&id=1b276b00&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-1b276b00\"]])\n\nexport default __exports__","<template>\r\n <footer class=\"py-5\">\r\n <ul class=\"px-5 mt-2\" role=\"menu\">\r\n <li v-for=\"(link, index) in footerLinks\" :key=\"index\" class=\"mb-3\">\r\n <a :href=\"link.url\" :target=\"link.target\" class=\"text-base group font-futuraEfBook\" :class=\"[{ underline: link.isSelected }]\" role=\"menuitem\" :data-testid=\"`mobileMenuFooterLink-${index}`\">{{ link.text }}</a>\r\n </li>\r\n <li v-if=\"footerLanguage && footerLanguage.url && footerLanguage.label\" class=\"pt-1 text-white border-solid\">\r\n <a :href=\"footerLanguage.url\" class=\"inline-flex items-center ellevio-lang-switch\" role=\"menuitem\" :aria-label=\"translations?.ariaLabels?.changeLanguage\" data-testid=\"mobileMenuFooterLangSwitch\">\r\n <span class=\"pl-1 text-xs text-newColors-gray-content font-futuraEfDemiBold\" data-testid=\"mobileMenuFooterLangSwitchText\">{{ footerLanguage.label }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </footer>\r\n</template>\r\n\r\n<script>\r\n//import EllevioWebLinkIcon from '../structure/LinkIcon.vue'\r\n\r\nexport default {\r\n name: 'EllevioWebMobileNavFooter',\r\n //components: {\r\n //EllevioWebLinkIcon\r\n //},\r\n props: {\r\n footerLinks: {\r\n type: Array\r\n },\r\n footerLanguage: {\r\n type: Object\r\n },\r\n translations: {\r\n type: Object,\r\n default: () => {}\r\n }\r\n }\r\n}\r\n</script>\r\n","import { render } from \"./MobileNavFooter.vue?vue&type=template&id=4d158338\"\nimport script from \"./MobileNavFooter.vue?vue&type=script&lang=js\"\nexport * from \"./MobileNavFooter.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","import { render } from \"./MobileNav.vue?vue&type=template&id=0ca78a48\"\nimport script from \"./MobileNav.vue?vue&type=script&lang=js\"\nexport * from \"./MobileNav.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","<script>\r\nexport default {\r\n\tname: \"EllevioWebRunOnload\",\r\n\tmounted: function() {\r\n\t\tfunction appHeight() {\r\n\t\t\tconst doc = document.documentElement\r\n\t\t\tdoc.style.setProperty('--vh', (window.innerHeight*.01) + 'px');\r\n\t\t}\r\n\t\twindow.addEventListener('resize', appHeight);\r\n\t\tappHeight();\r\n\t},\r\n\trender() {\r\n\t\treturn null;\r\n\t}\r\n}\r\n</script>\r\n","import script from \"./RunOnload.vue?vue&type=script&lang=js\"\nexport * from \"./RunOnload.vue?vue&type=script&lang=js\"\n\nconst __exports__ = script;\n\nexport default __exports__","<template>\r\n <div ref=\"desktopNavRef\">\r\n <div class=\"sr-only ellevio-skip-links flex gap-6 text-newColors-gray-base bg-newColors-green-primaryA focus-within:not-sr-only z-[999991]\" role=\"menu\">\r\n <a href=\"#main-menu\" class=\"flex items-center text-lg rounded-sm focus:outline-white-alt\" role=\"menuitem\">{{ navigationData.translations?.skipLinks?.toMenu }}</a>\r\n <a href=\"#main-content\" class=\"text-lg rounded-sm focus:outline-white-alt\" role=\"menuitem\">{{ navigationData.translations?.skipLinks?.toContent }}</a>\r\n </div>\r\n\r\n <div class=\"flex flex-wrap ellevio-desktop-nav container-large\">\r\n <div class=\"flex w-full\">\r\n <!--<ellevio-web-desktop-nav-upper :navigationData=\"navigationData.secondaryMenu\" :ariaLabelUpperNav=\"navigationData.ariaLabels.upperNav\" />-->\r\n <ellevio-web-desktop-nav-upper :navigationData=\"navigationData\" :otherLanguage=\"navigationData.otherLanguage\" :logoLink=\"logoLink\" :megaMenuOpen=\"megaMenuOpen\" />\r\n </div>\r\n <div class=\"flex w-full\">\r\n <!--<ellevio-web-desktop-nav-lower @toggleMegaMenu=\"handleToggleMegaMenu\" :headerHeight=\"headerHeight\" :navigationData=\"navigationData\" :activeMenuItem=\"activeMenuItem\" :ariaLabelLowerNav=\"navigationData.ariaLabels.lowerNav\" />-->\r\n <ellevio-web-desktop-nav-lower\r\n @toggleMegaMenu=\"handleToggleMegaMenu\"\r\n :searchApiUrl=\"searchApiUrl\"\r\n :searchPageUrl=\"searchPageUrl\"\r\n :headerHeight=\"headerHeight\"\r\n :navigationData=\"navigationData\"\r\n :translations=\"navigationData.translations\"\r\n :searchNoHitsContent=\"searchNoHitsContent\"\r\n @megaMenuIsOpen=\"setPropsForMegaMenuOpen\"\r\n :activeMenuItem=\"activeMenuItem\"\r\n :scrollbarWidth=\"scrollbarWidth\" />\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebDesktopNavLower from './DesktopNavLower.vue'\r\nimport EllevioWebDesktopNavUpper from './DesktopNavUpper.vue'\r\n\r\nexport default {\r\n name: 'ellevio-web-desktop-nav',\r\n components: {\r\n EllevioWebDesktopNavLower,\r\n EllevioWebDesktopNavUpper\r\n },\r\n emits: ['toggleMegaMenu'],\r\n props: {\r\n searchNoHitsContent: {\r\n type: String,\r\n default: ''\r\n },\r\n headerHeight: {\r\n type: Number,\r\n default: 0\r\n },\r\n logoLink: {\r\n type: String,\r\n default: '/'\r\n },\r\n navigationData: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n otherLanguage: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n searchApiUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n searchPageUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n scrollbarWidth: {\r\n type: Number,\r\n default: 0\r\n }\r\n },\r\n data() {\r\n return {\r\n activeMenuItem: '',\r\n megaMenuOpen: false\r\n }\r\n },\r\n computed: {},\r\n methods: {\r\n setPropsForMegaMenuOpen(isOpen) {\r\n this.megaMenuOpen = isOpen\r\n },\r\n handleToggleMegaMenu(itemId) {\r\n this.activeMenuItem = itemId\r\n this.$emit('toggleMegaMenu', itemId.length > 0)\r\n this.toggleMegaMenuMargin()\r\n },\r\n toggleMegaMenuMargin() {\r\n if (this.$refs.desktopNavRef) {\r\n if (this.activeMenuItem === '') {\r\n this.$refs.desktopNavRef.style.marginRight = `0`\r\n } else {\r\n this.$refs.desktopNavRef.style.marginRight = `${this.scrollbarWidth}px`\r\n }\r\n }\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.ellevio-desktop-nav :deep(a:focus),\r\n.ellevio-desktop-nav :deep(button:focus) {\r\n outline: 2px dotted #2c2827;\r\n outline-offset: 4px;\r\n}\r\n\r\n/* Menu buttons that open megamenu. With orange border hover effect */\r\n.ellevio-desktop-nav :deep(.ellevio-mega-menu-item-button:not(.ellevio-mega-menu-login-link)::before) {\r\n content: '';\r\n position: absolute;\r\n left: 0;\r\n width: 100%;\r\n height: 0.25rem;\r\n @apply bg-newColors-orange-signatureA;\r\n transform: scaleX(0);\r\n transition: transform 250ms;\r\n}\r\n.ellevio-desktop-nav :deep(.ellevio-mega-menu-item-button:not(.ellevio-mega-menu-login-link):hover::before) {\r\n transform: scaleX(1);\r\n}\r\n.ellevio-desktop-nav :deep(.ellevio-mega-menu-item-button:not(.ellevio-mega-menu-login-link):active::before) {\r\n transform: scaleX(1);\r\n}\r\n\r\n/* Menu links with orange border hover effect */\r\n.ellevio-desktop-nav:deep(.animated-menu-link) {\r\n position: relative;\r\n}\r\n.ellevio-desktop-nav:deep(.animated-menu-link:before) {\r\n content: '';\r\n position: absolute;\r\n left: 0;\r\n width: 100%;\r\n height: 0.25rem;\r\n @apply bg-newColors-orange-signatureA;\r\n transform: scaleX(0);\r\n transition: transform 250ms;\r\n}\r\n.ellevio-desktop-nav:deep(.animated-menu-link:hover::before) {\r\n @apply bg-orange-light;\r\n}\r\n.ellevio-desktop-nav:deep(.animated-menu-link:hover::before) {\r\n transform: scaleX(1);\r\n}\r\n.ellevio-desktop-nav:deep(.animated-menu-link.active::before) {\r\n transform: scaleX(1);\r\n @apply border-b-[0.125rem] border-solid border-newColors-orange-signatureA;\r\n}\r\n\r\n.ellevio-skip-links {\r\n position: absolute;\r\n transform: translateY(-100%) translateX(-50%);\r\n top: 0.25rem;\r\n left: 50%;\r\n transition: transform 0.3s;\r\n box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);\r\n}\r\n.ellevio-skip-links:focus-within {\r\n transform: translateY(0%) translateX(-50%);\r\n outline: none !important;\r\n padding: 1rem 3rem !important;\r\n}\r\n</style>\r\n","<template>\r\n <nav :aria-label=\"ariaLabelLowerNav\" class=\"flex justify-between w-full gap-8 ellevio-desktop-nav-lower mt-[1px] z-10\">\r\n <!-- Main nav -->\r\n <ul class=\"flex items-center gap-8\" role=\"menu\" id=\"main-menu\">\r\n <li v-for=\"(item, index) in navigationData.menuItems\" :key=\"`menuItem-${index}`\" role=\"none\" class=\"relative pt-4 pb-3\">\r\n <ellevio-web-desktop-nav-lower-mega-menu-item\r\n :label=\"item.heading\"\r\n :itemId=\"`menuItem-${index}`\"\r\n :itemIcon=\"item.icon\"\r\n :itemIsOpen=\"activeMenuItem === `menuItem-${index}`\"\r\n :showActiveUnderline=\"showActiveUnderline(activeMenuItem === `menuItem-${index}`, item)\"\r\n :headerHeight=\"headerHeight\"\r\n :scrollbarWidth=\"scrollbarWidth\"\r\n @toggleMegaMenu=\"handleToggleMegaMenu\"\r\n :ariaLabels=\"translations?.ariaLabels\">\r\n <!-- Heading link -->\r\n <div class=\"flex items-center gap-5 mb-8\" :data-testid=\"`desktopMegaMenuHeadingWrapper-${index}`\">\r\n <ellevio-web-desktop-nav-lower-nav-icon :typeOfIcon=\"item.icon\" :large=\"true\" />\r\n <div>\r\n <h2 class=\"text-3xl font-futuraEfDemiBold\" :data-testid=\"`desktopMegaMenuHeading-${index}`\">{{ item.heading }}</h2>\r\n <p v-if=\"item.description\" class=\"mt-1 text-lg font-futuraEfBook text-newColors-gray-contentA\" :data-testid=\"`desktopMegaMenuParagraph-${index}`\">{{ item.description }}</p>\r\n </div>\r\n </div>\r\n\r\n <!-- Sub menu items -->\r\n <ul class=\"grid grid-cols-12 auto-rows-auto gap-y-14 gap-x-8\">\r\n <li class=\"col-span-3 grid-item\" v-for=\"(subitem, subIndex) in item.nodes\" :key=\"`subMenuItem-${subIndex}`\">\r\n <h3 class=\"mb-2 text-xl font-futuraEfDemiBold\" :data-testid=\"`desktopMegaMenuSubHeading-${index}`\">\r\n <a v-if=\"subitem.url\" :href=\"subitem.url\" class=\"text-xl font-futuraEfDemiBold\" :data-testid=\"`desktopMegaMenuSubHeadingLink-${index}`\" :class=\"[{ underline: subitem.isSelected }]\">{{ subitem.text }}</a>\r\n {{ !subitem.url ? subitem.text : '' }}\r\n </h3>\r\n <ul class=\"flex flex-col gap-2 text-newColors-gray-contentA ellevio-mega-menu-submenu\" role=\"menu\">\r\n <li v-for=\"(subsubitem, subsubindex) in subitem.items\" :key=\"`subSubMenuItem-${subsubindex}`\" role=\"none\">\r\n <a\r\n :href=\"subsubitem.url\"\r\n :target=\"subsubitem.target === '' ? '_self' : subsubitem.target\"\r\n role=\"menuitem\"\r\n class=\"rounded-sm\"\r\n :class=\"[{ underline: subsubitem.isSelected }]\"\r\n :data-testid=\"`desktopMegaMenuSubMenuLink-${index}-${subIndex}-${subsubindex}`\"\r\n >{{ subsubitem.text }}</a\r\n >\r\n </li>\r\n </ul>\r\n </li>\r\n </ul>\r\n </ellevio-web-desktop-nav-lower-mega-menu-item>\r\n </li>\r\n </ul>\r\n\r\n <div class=\"flex items-center gap-5\">\r\n <!-- Search -->\r\n <div class=\"pt-4 pb-3\">\r\n <ellevio-web-desktop-nav-lower-mega-menu-item\r\n :label=\"translations?.search?.menuLabel\"\r\n :searchLink=\"true\"\r\n :itemId=\"'headerSearch'\"\r\n :showActiveUnderline=\"showActiveUnderline(activeMenuItem === 'headerSearch')\"\r\n :itemIsOpen=\"activeMenuItem === 'headerSearch'\"\r\n @toggleMegaMenu=\"handleToggleMegaMenu\"\r\n :headerHeight=\"headerHeight\"\r\n :aria-labels=\"translations?.ariaLabels\">\r\n <form name=\"searchform\" :action=\"searchPageUrl\">\r\n <ellevio-web-header-search-input\r\n :searchNoHitsContent=\"searchNoHitsContent\"\r\n :apiUrl=\"searchApiUrl\"\r\n :clearSearchFieldLabel=\"translations?.search?.clearSearchField\"\r\n :label=\"translations?.search?.inputLabel\"\r\n :searchTooltipLabel=\"translations?.search?.inputLabel\"\r\n :buttonText=\"translations?.search?.buttonText\"\r\n :itemIsOpen=\"activeMenuItem === 'headerSearch'\"\r\n :placeholder=\"translations?.search?.inputPlaceholder\" />\r\n </form>\r\n </ellevio-web-desktop-nav-lower-mega-menu-item>\r\n </div>\r\n\r\n <!-- Login -->\r\n <div v-if=\"navigationData?.loginMenu\">\r\n <ellevio-web-desktop-nav-lower-mega-menu-item\r\n :label=\"navigationData?.loginMenu?.userName || navigationData?.loginMenu?.heading\"\r\n :loginLink=\"!navigationData?.loginMenu?.userName\"\r\n :logoutLink=\"navigationData?.loginMenu?.userName\"\r\n :itemId=\"'headerLogin'\"\r\n :itemIsOpen=\"activeMenuItem === 'headerLogin'\"\r\n @toggleMegaMenu=\"handleToggleMegaMenu\"\r\n :headerHeight=\"headerHeight\">\r\n <div class=\"flex items-center gap-5 mb-8\" data-testid=\"desktopMegaMenuHeadingWrapper-login\">\r\n <ellevio-web-desktop-nav-lower-nav-icon typeOfIcon=\"user\" />\r\n <div>\r\n <h2 class=\"text-3xl font-futuraEfDemiBold\" data-testid=\"desktopMegaMenuHeading-login\">{{ navigationData?.loginMenu?.heading }}</h2>\r\n <p class=\"text-lg font-futuraEfBook\" data-testid=\"desktopMegaMenuParagraph-login\">{{ navigationData?.loginMenu?.description }}</p>\r\n </div>\r\n </div>\r\n <ul class=\"flex items-start gap-44\" role=\"menu\">\r\n <li v-for=\"(area, index) in navigationData?.loginMenu?.areas\" :key=\"`area-${index}`\" role=\"menuitem\">\r\n <h3 v-if=\"area?.heading\" class=\"mb-1 text-xl font-futuraEfDemiBold\" :data-testid=\"`desktopMegaMenuLoginSubHeading-${index}`\">{{ area?.heading }}</h3>\r\n <ul class=\"flex flex-col gap-2\" role=\"menu\">\r\n <li v-for=\"(link, index2) in area?.links\" :key=\"`area-link-${index2}`\" role=\"menuitem\">\r\n <a :href=\"link.url\" :target=\"link.target === '' ? '_self' : link.target\" class=\"rounded-sm arrow-link-forward\" :data-testid=\"`desktopMegaMenuLoginSubMenuLink-${index}-${index2}`\">{{ link.text }}</a>\r\n </li>\r\n </ul>\r\n </li>\r\n <!-- Logout button -->\r\n <li v-if=\"navigationData?.loginMenu?.userName\" role=\"menuitem\">\r\n <ul class=\"flex flex-col gap-2\" role=\"menu\">\r\n <li role=\"menuitem\">\r\n <a :href=\"navigationData?.loginMenu?.logOutButton?.url\" class=\"btn-secondary btn-small btn-icon-user mt-7\">{{ navigationData?.loginMenu?.logOutButton?.text }}</a>\r\n </li>\r\n </ul>\r\n </li>\r\n </ul>\r\n </ellevio-web-desktop-nav-lower-mega-menu-item>\r\n </div>\r\n </div>\r\n </nav>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebDesktopNavLowerMegaMenuItem from './DesktopNavLowerMegaMenuItem.vue'\r\nimport EllevioWebDesktopNavLowerNavIcon from './DesktopNavLowerNavIcon.vue'\r\nimport EllevioWebHeaderSearchInput from './HeaderSearchInput.vue'\r\n\r\nexport default {\r\n name: 'ellevio-web-desktop-nav-lower',\r\n components: {\r\n EllevioWebDesktopNavLowerMegaMenuItem,\r\n EllevioWebDesktopNavLowerNavIcon,\r\n EllevioWebHeaderSearchInput\r\n },\r\n emits: ['toggleMegaMenu', 'megaMenuIsOpen'],\r\n props: {\r\n searchNoHitsContent: {\r\n type: String,\r\n default: ''\r\n },\r\n headerHeight: {\r\n type: Number,\r\n default: 0\r\n },\r\n scrollbarWidth: {\r\n type: Number,\r\n default: 0\r\n },\r\n navigationData: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n translations: {\r\n type: Object,\r\n default: () => {\r\n return {\r\n search: {}\r\n }\r\n }\r\n },\r\n activeMenuItem: {\r\n type: String,\r\n default: ''\r\n },\r\n ariaLabelLowerNav: {\r\n type: String,\r\n default: 'Huvudmeny'\r\n },\r\n searchApiUrl: {\r\n type: String,\r\n default: ''\r\n },\r\n searchPageUrl: {\r\n type: String,\r\n default: ''\r\n }\r\n },\r\n data() {\r\n return {}\r\n },\r\n watch: {\r\n activeMenuItem: function (newVal, oldVal) {\r\n if (newVal !== oldVal) {\r\n this.$emit('megaMenuIsOpen', newVal !== '')\r\n }\r\n }\r\n },\r\n methods: {\r\n handleToggleMegaMenu(itemId) {\r\n this.$emit('toggleMegaMenu', itemId)\r\n },\r\n anyChildrenActive(items) {\r\n return items.some((child) => child.isSelected === true) || items.some((child) => child.items.some((grandchild) => grandchild.isSelected === true))\r\n },\r\n showActiveUnderline(itemIsOpen, item) {\r\n const menuIsClosedAndItemHasChild = item ? this.activeMenuItem === '' && this.anyChildrenActive(item.nodes ?? []) : false\r\n const menuIsOpen = itemIsOpen\r\n\r\n return menuIsOpen || menuIsClosedAndItemHasChild\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.ellevio-desktop-nav-lower:deep(.animated-menu-link::before) {\r\n bottom: -0.75rem;\r\n}\r\n</style>\r\n","<template>\r\n <div>\r\n <button\r\n @click=\"toggleMenu(itemId)\"\r\n :aria-controls=\"`submenu-${itemId}`\"\r\n aria-haspopup=\"true\"\r\n :class=\"[\r\n { 'before:border-orange-light active': showActiveUnderline && !loginLink && !logoutLink },\r\n { 'btn-primary btn-small btn-icon-user text-base leading-3 ellevio-mega-menu-login-link max-w-36 overflow-hidden whitespace-nowrap text-ellipsis': loginLink },\r\n { 'btn-primary btn-small text-base leading-3 ellevio-mega-menu-login-link max-w-[9rem] w-[100%] overflow-hidden whitespace-nowrap text-ellipsis inline-block': logoutLink },\r\n { 'animated-menu-link text-lg font-futuraEfBook items-start gap-2 rounded-sm text-left leading-6 flex': !loginLink && !logoutLink },\r\n { 'items-center': searchLink }\r\n ]\"\r\n class=\"z-[999991] relative cursor-pointer sm:hide whitespace-nowrap ellevio-mega-menu-item-button\"\r\n :aria-label=\"itemIsOpen ? `${ariaLabels?.closeMegaMenu} ${label}` : null\"\r\n :aria-expanded=\"itemIsOpen\"\r\n :id=\"itemId\"\r\n :data-testid=\"loginLink || logoutLink ? 'nav-login-logout-button' : `desktopMenuButton-${itemId}`\"\r\n role=\"menuitem\"\r\n ref=\"menuButton\">\r\n <span v-if=\"!loginLink && !logoutLink && !searchLink\" class=\"hidden lg-large-rem:block\">\r\n <ellevio-web-desktop-nav-lower-nav-icon v-if=\"!searchLink && itemIcon\" :typeOfIcon=\"itemIcon\" />\r\n </span>\r\n <ellevio-web-desktop-nav-lower-nav-icon v-if=\"searchLink\" typeOfIcon=\"search\" :data-testid=\"`desktopMegaMenuIconSmall-${itemId}`\" />\r\n {{ label }}\r\n </button>\r\n <div v-show=\"itemIsOpen\" @keydown.esc=\"closeAndSetButtonFocus()\" class=\"fixed z-[99999] inset-0 flex flex-col w-full overflow-auto gray-gradient\" :id=\"`submenu-${itemId}`\" :aria-labelledby=\"itemId\" :style=\"{ top: `${headerHeight}px` }\">\r\n <div class=\"absolute top-0 left-0 right-0 gray-gradient h-14 md:h28\" />\r\n <div class=\"bg-white\">\r\n <nav :id=\"`trapping-box-${itemId}`\" class=\"relative max-w-6xl pt-12 pb-16 m-auto px-desktop-gutter\" ref=\"megaMenuRef\">\r\n <div class=\"ellevio-mega-menu-sublinks\">\r\n <Transition name=\"fade-slide\">\r\n <div v-show=\"itemIsOpen\">\r\n <slot></slot>\r\n </div>\r\n </Transition>\r\n </div>\r\n\r\n <button\r\n class=\"absolute flex items-center p-2 text-lg rounded-sm font-futuraEfBook hover:underline right-4 top-12 z-50]\"\r\n :aria-label=\"`${ariaLabels.closeMegaMenu} ${label}`\"\r\n @click=\"closeAndSetButtonFocus(itemId)\"\r\n ref=\"closeBtnRef\"\r\n :data-testid=\"`desktopMegaMenuCloseButton-${itemId}`\">\r\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" class=\"relative w-[0.875rem] h-[0.875rem] mr-2\" :data-testid=\"`desktopMegaMenuCloseButtonIcon-${itemId}`\">\r\n <path\r\n fill-rule=\"evenodd\"\r\n clip-rule=\"evenodd\"\r\n d=\"M5.72736 6.99994L0.000112799 1.27272L1.27284 0L7.00008 5.72722L12.7273 7.75299e-05L14 1.2728L1.27273 14L0 12.7273L5.72736 6.99994ZM12.7275 13.9993L8.01704 9.28883L9.28977 8.01611L14.0003 12.7266L12.7275 13.9993Z\"\r\n fill=\"#2C2827\" />\r\n </svg>\r\n <span class=\"inline-block\">{{ ariaLabels?.closeMegaMenu }}</span>\r\n </button>\r\n </nav>\r\n </div>\r\n <div @click=\"toggleMenu(itemId)\" class=\"ellevio-cursor-cross backdrop-blur bg-[rgba(44,40,39,0.4)] flex-1\" :data-testid=\"`desktopMegaMenuBlurredBackdrop-${itemId}`\"></div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport EllevioWebDesktopNavLowerNavIcon from './DesktopNavLowerNavIcon.vue'\r\nimport { TrapFocus } from '../../../helpers/focusTrap.js'\r\n\r\nexport default {\r\n name: 'ellevio-web-desktop-nav-mega-menu-item',\r\n components: {\r\n EllevioWebDesktopNavLowerNavIcon\r\n },\r\n emits: ['toggleMegaMenu'],\r\n data() {\r\n return {}\r\n },\r\n props: {\r\n label: {\r\n type: String,\r\n default: ''\r\n },\r\n itemId: {\r\n type: String,\r\n default: ''\r\n },\r\n itemIcon: {\r\n type: String,\r\n default: ''\r\n },\r\n searchLink: {\r\n type: Boolean,\r\n default: false\r\n },\r\n loginLink: {\r\n type: Boolean,\r\n default: false\r\n },\r\n logoutLink: {\r\n type: Boolean,\r\n default: false\r\n },\r\n itemIsOpen: {\r\n type: Boolean,\r\n default: false\r\n },\r\n showActiveUnderline: {\r\n type: Boolean,\r\n default: false\r\n },\r\n headerHeight: {\r\n type: Number,\r\n default: 0\r\n },\r\n scrollBarWidth: {\r\n type: Number,\r\n default: 0\r\n },\r\n ariaLabels: {\r\n type: Object,\r\n default: () => {\r\n return {\r\n closeMegaMenu: 'Stäng'\r\n }\r\n }\r\n }\r\n },\r\n mounted() {\r\n this.setMegaMenuPadding()\r\n },\r\n methods: {\r\n toggleMenu(itemId) {\r\n this.$emit('toggleMegaMenu', this.itemIsOpen ? '' : itemId)\r\n },\r\n closeAndSetButtonFocus() {\r\n this.toggleMenu('')\r\n this.$refs.menuButton.focus()\r\n },\r\n setMegaMenuPadding() {\r\n const megaMenuRef = this.$refs.megaMenuRef\r\n const closeBtnRef = this.$refs.closeBtnRef\r\n const megaMenuStyle = window.getComputedStyle(megaMenuRef)\r\n const closeBtnStyle = window.getComputedStyle(closeBtnRef)\r\n const megaMenuPaddingRight = parseInt(megaMenuStyle.paddingRight)\r\n const closeBtnRight = parseInt(closeBtnStyle.right)\r\n\r\n // Add scrollbar width to megamenu to position content correctly\r\n megaMenuRef.style.paddingRight = megaMenuPaddingRight + this.scrollBarWidth + 'px'\r\n closeBtnRef.style.right = closeBtnRight + this.scrollBarWidth + 'px'\r\n }\r\n },\r\n watch: {\r\n itemIsOpen() {\r\n this.$nextTick(() => {\r\n this.$nextTick(() => {\r\n if (this.itemIsOpen) {\r\n setTimeout(() => {\r\n document.querySelector('.vue-header').classList.add('!h-auto')\r\n }, 0)\r\n new TrapFocus(document.getElementById(`trapping-box-${this.itemId}`))\r\n } else {\r\n document.querySelector('.vue-header').classList.remove('!h-auto')\r\n }\r\n })\r\n })\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n/* Antimation */\r\n.fade-slide-enter-from {\r\n opacity: 0;\r\n transform: translateY(-1rem);\r\n}\r\n.fade-slide-enter-to {\r\n opacity: 1;\r\n\r\n transition: opacity 0.4s, transform 0.4s;\r\n transform: translateY(0);\r\n}\r\n\r\n/* All sublinks */\r\n.ellevio-mega-menu-sublinks :deep(.ellevio-mega-menu-submenu a:not(.arrow-link-forward)) {\r\n @apply text-lg;\r\n}\r\n\r\n/* All links */\r\n.ellevio-mega-menu-sublinks :deep(a:not(.arrow-link-forward)) {\r\n @apply hover:underline;\r\n}\r\n\r\n.ellevio-cursor-cross {\r\n cursor: url(../../../assets/images/cross-black-cursor.svg) 16 0, auto;\r\n}\r\n</style>\r\n","<template>\r\n <!-- Plug icon -->\r\n <svg v-if=\"props.typeOfIcon === 'power-plug' && !large\" class=\"icon-small\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <path\r\n id=\"plug-circle-small_black\"\r\n stroke=\"#363433\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n stroke-width=\"2\"\r\n d=\"M10 8v3m4-3v3m-2 10v-5m0 5a9 9 0 1 0 0-18 9 9 0 0 0 0 18ZM8 11h8v1.8c0 1.12 0 1.68-.218 2.108a2 2 0 0 1-.874.874C14.48 16 13.92 16 12.8 16h-1.6c-1.12 0-1.68 0-2.108-.218a2 2 0 0 1-.874-.874C8 14.48 8 13.92 8 12.8V11Z\" />\r\n </svg>\r\n\r\n <svg v-if=\"props.typeOfIcon === 'power-plug' && large\" class=\"icon-large\" xmlns=\"http://www.w3.org/2000/svg\" width=\"60\" height=\"60\" viewBox=\"0 0 60 60\" fill=\"none\">\r\n <path\r\n id=\"plug-circle-large_black\"\r\n stroke=\"#363433\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n stroke-width=\"4\"\r\n d=\"M25 20v7.5M35 20v7.5m-5 25V40m0 12.5c12.426 0 22.5-10.074 22.5-22.5S42.426 7.5 30 7.5 7.5 17.574 7.5 30 17.574 52.5 30 52.5Zm-10-25h20V32c0 2.8 0 4.2-.545 5.27a5 5 0 0 1-2.185 2.185C36.2 40 34.8 40 32 40h-4c-2.8 0-4.2 0-5.27-.545a5 5 0 0 1-2.185-2.185C20 36.2 20 34.8 20 32v-4.5Z\" />\r\n </svg>\r\n\r\n <!-- File icon -->\r\n <svg v-if=\"props.typeOfIcon === 'document' && !large\" class=\"icon-small\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n id=\"file-small_black\"\r\n d=\"M9 17H15M9 13H15M9 9H10M13 3H8.2C7.0799 3 6.51984 3 6.09202 3.21799C5.71569 3.40973 5.40973 3.71569 5.21799 4.09202C5 4.51984 5 5.0799 5 6.2V17.8C5 18.9201 5 19.4802 5.21799 19.908C5.40973 20.2843 5.71569 20.5903 6.09202 20.782C6.51984 21 7.0799 21 8.2 21H15.8C16.9201 21 17.4802 21 17.908 20.782C18.2843 20.5903 18.5903 20.2843 18.782 19.908C19 19.4802 19 18.9201 19 17.8V9M13 3L19 9M13 3V7.4C13 7.96005 13 8.24008 13.109 8.45399C13.2049 8.64215 13.3578 8.79513 13.546 8.89101C13.7599 9 14.0399 9 14.6 9H19\"\r\n stroke=\"#363433\"\r\n stroke-width=\"2\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n <svg v-if=\"props.typeOfIcon === 'document' && large\" class=\"icon-large\" width=\"60\" height=\"60\" viewBox=\"0 0 60 60\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n id=\"file-large_black\"\r\n d=\"M22.5 42.5H37.5M22.5 32.5H37.5M22.5 22.5H25M32.5 7.5H20.5C17.6997 7.5 16.2996 7.5 15.23 8.04497C14.2892 8.52433 13.5243 9.28924 13.045 10.23C12.5 11.2996 12.5 12.6997 12.5 15.5V44.5C12.5 47.3003 12.5 48.7004 13.045 49.77C13.5243 50.7108 14.2892 51.4757 15.23 51.955C16.2996 52.5 17.6997 52.5 20.5 52.5H39.5C42.3003 52.5 43.7004 52.5 44.77 51.955C45.7108 51.4757 46.4757 50.7108 46.955 49.77C47.5 48.7004 47.5 47.3003 47.5 44.5V22.5M32.5 7.5L47.5 22.5M32.5 7.5V18.5C32.5 19.9001 32.5 20.6002 32.7725 21.135C33.0122 21.6054 33.3946 21.9878 33.865 22.2275C34.3998 22.5 35.0999 22.5 36.5 22.5H47.5\"\r\n stroke=\"#363433\"\r\n stroke-width=\"4\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n <!-- Battery icon -->\r\n <svg v-if=\"props.typeOfIcon === 'battery' && !large\" class=\"icon-small\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <g id=\"battery-small_black\">\r\n <path\r\n d=\"M21 13V11M6.2 18H16.8C17.9201 18 18.4802 18 18.908 17.782C19.2843 17.5903 19.5903 17.2843 19.782 16.908C20 16.4802 20 15.9201 20 14.8V9.2C20 8.0799 20 7.51984 19.782 7.09202C19.5903 6.71569 19.2843 6.40973 18.908 6.21799C18.4802 6 17.9201 6 16.8 6H6.2C5.0799 6 4.51984 6 4.09202 6.21799C3.71569 6.40973 3.40973 6.71569 3.21799 7.09202C3 7.51984 3 8.07989 3 9.2V14.8C3 15.9201 3 16.4802 3.21799 16.908C3.40973 17.2843 3.71569 17.5903 4.09202 17.782C4.51984 18 5.07989 18 6.2 18Z\"\r\n stroke=\"#363433\"\r\n stroke-width=\"2\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path d=\"M15.8261 10V13.6522M14 11.8261H17.6522\" stroke=\"#363433\" stroke-width=\"1.21739\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path d=\"M5.5 12H9.15217\" stroke=\"#363433\" stroke-width=\"1.21739\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n </svg>\r\n\r\n <svg v-if=\"props.typeOfIcon === 'battery' && large\" class=\"icon-large\" width=\"60\" height=\"60\" viewBox=\"0 0 60 60\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <g id=\"battery-large_black\">\r\n <path\r\n d=\"M52.5 32.5V27.5M15.5 45H42C44.8003 45 46.2004 45 47.27 44.455C48.2108 43.9757 48.9757 43.2108 49.455 42.27C50 41.2004 50 39.8003 50 37V23C50 20.1997 50 18.7996 49.455 17.73C48.9757 16.7892 48.2108 16.0243 47.27 15.545C46.2004 15 44.8003 15 42 15H15.5C12.6997 15 11.2996 15 10.23 15.545C9.28924 16.0243 8.52433 16.7892 8.04497 17.73C7.5 18.7996 7.5 20.1997 7.5 23V37C7.5 39.8003 7.5 41.2004 8.04497 42.27C8.52433 43.2108 9.28924 43.9757 10.23 44.455C11.2996 45 12.6997 45 15.5 45Z\"\r\n stroke=\"#363433\"\r\n stroke-width=\"4\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path d=\"M39.5652 25V34.1304M35 29.5652H44.1304\" stroke=\"#363433\" stroke-width=\"3.04348\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path d=\"M13.75 30H22.8804\" stroke=\"#363433\" stroke-width=\"3.04348\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n </svg>\r\n\r\n <!-- Tool icon -->\r\n <svg v-if=\"props.typeOfIcon === 'monkey-wrench' && !large\" class=\"icon-small\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M11.2148 12.7852L16.939 18.5094C17.4104 18.9809 17.6462 19.2166 17.8905 19.3324C18.1053 19.4343 18.3243 19.473 18.5158 19.4428C18.7336 19.4085 18.8987 19.2435 19.2287 18.9135L19.7001 18.4421C20.0301 18.1121 20.1951 17.9471 20.2294 17.7293C20.2596 17.5377 20.2209 17.3188 20.119 17.1039C20.0032 16.8596 19.7675 16.6238 19.296 16.1524L13.5718 10.4282\"\r\n stroke=\"#363433\"\r\n stroke-width=\"1.66667\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M7.44357 2.41421C7.44357 2.41421 10.6256 2.76777 12.0987 4.24091C14.1611 6.3033 14.5648 9.4351 12.3933 11.6066C10.2218 13.7782 7.18565 13.47 4.9687 11.253C3.49556 9.77991 3.20093 6.65685 3.20093 6.65685\"\r\n stroke=\"#363433\"\r\n stroke-width=\"2\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M7.44342 2.41431C7.44342 2.41431 8.36889 3.33953 8.86876 3.83965C9.78449 4.75583 10.1757 7.03271 8.95431 8.2541C7.81868 9.38973 5.67565 9.13182 4.62616 8.08225C3.57667 7.03268 3.20095 6.65712 3.20095 6.65712\"\r\n stroke=\"#363433\"\r\n stroke-width=\"2\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <rect width=\"1.66667\" height=\"4.33\" transform=\"matrix(-0.707107 0.707107 0.707107 0.707107 11.2146 9.24976)\" fill=\"white\" />\r\n </svg>\r\n\r\n <svg v-if=\"props.typeOfIcon === 'monkey-wrench' && large\" class=\"icon-large\" width=\"60\" height=\"60\" viewBox=\"0 0 60 60\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M26.9016 32.5784L41.2121 46.8889C42.3907 48.0675 42.98 48.6568 43.5907 48.9465C44.128 49.2012 44.6753 49.2978 45.1542 49.2224C45.6987 49.1366 46.1112 48.7241 46.9363 47.8991L48.1148 46.7205C48.9398 45.8955 49.3523 45.483 49.4381 44.9385C49.5135 44.4595 49.4169 43.9122 49.1622 43.375C48.8726 42.7643 48.2832 42.175 47.1046 40.9963L32.7941 26.6859\"\r\n stroke=\"#363433\"\r\n stroke-width=\"4\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M17.3261 6.79808C17.3261 6.79808 25.4283 7.53465 29.1112 11.2175C34.2672 16.3735 35.2765 24.203 29.8477 29.6318C24.4189 35.0606 17.3261 36.2609 10.6969 29.6317C7.01409 25.9489 6.27752 17.8466 6.27752 17.8466\"\r\n stroke=\"#363433\"\r\n stroke-width=\"4\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M17.3251 6.7992C17.3251 6.7992 21.0087 9.0081 23.2169 12.6924C25.1477 15.9139 25.4282 19.32 22.3748 22.3735C19.5357 25.2125 16.3636 26.5352 12.1687 23.7407C7.97384 20.9461 6.27617 17.8481 6.27617 17.8481\"\r\n stroke=\"#363433\"\r\n stroke-width=\"4\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <rect width=\"4.32758\" height=\"10.825\" transform=\"matrix(-0.707107 0.707107 0.707107 0.707107 26.959 23.6816)\" fill=\"white\" />\r\n </svg>\r\n\r\n <!-- Search icon -->\r\n <svg v-if=\"props.typeOfIcon === 'search'\" class=\"icon-search\" v-bind=\"$attrs\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n fill-rule=\"evenodd\"\r\n clip-rule=\"evenodd\"\r\n d=\"M10.8554 9.524C9.97207 10.548 8.66793 11.2 7.21229 11.2C4.55993 11.2 2.40293 9.0464 2.40293 6.4C2.40293 3.7528 4.55993 1.6 7.21229 1.6C9.86386 1.6 12.0209 3.7528 12.0209 6.4C12.0209 7.132 11.8509 7.8232 11.5568 8.444L13.0052 9.1264C13.3995 8.2984 13.624 7.376 13.624 6.4C13.624 2.8712 10.7472 0 7.21229 0C3.67581 0 0.799805 2.8712 0.799805 6.4C0.799805 9.9288 3.67581 12.8 7.21229 12.8C8.40982 12.8 9.528 12.4648 10.4875 11.8912L14.6043 16L15.9998 14.6072L10.8554 9.524Z\"\r\n fill=\"#2C2827\" />\r\n </svg>\r\n\r\n <!-- Login icon -->\r\n <svg v-if=\"props.typeOfIcon === 'login'\" class=\"icon-login\" v-bind=\"$attrs\" xmlns=\"http://www.w3.org/2000/svg\" width=\"56\" height=\"56\" fill=\"none\" viewBox=\"0 0 56 56\">\r\n <path fill=\"#363433\" d=\"M5.495 53.2C8.635 46.648 17.533 42.112 28 42.112c10.467 0 19.364 4.788 22.505 11.088H56c-3.14-9.324-14.392-16.128-28-16.128-13.607 0-24.86 6.804-28 16.128h5.495Z\" />\r\n <path\r\n fill=\"#363433\"\r\n d=\"M27.215 2.8C17.01 2.8 8.897 10.612 8.897 20.44c0 7.812 5.496 14.616 12.823 16.884l1.57-4.788c-5.234-1.512-9.159-6.3-9.159-12.096 0-7.056 5.757-12.6 13.084-12.6S40.3 13.384 40.3 20.44c0 5.544-3.663 10.08-8.635 11.844l1.832 4.788C40.56 34.552 45.533 28 45.533 20.44c0-9.828-8.374-17.64-18.318-17.64Z\" />\r\n </svg>\r\n\r\n <!-- User icon -->\r\n <svg v-if=\"props.typeOfIcon === 'user'\" class=\"icon-user\" width=\"56\" height=\"56\" viewBox=\"0 0 56 56\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5.49533 53.2002C8.63551 46.6482 17.5327 42.1123 28 42.1123C38.4673 42.1123 47.3645 46.9002 50.5047 53.2002H56C52.8598 43.8762 41.6075 37.0723 28 37.0723C14.3925 37.0723 3.14019 43.8762 0 53.2002H5.49533Z\" fill=\"#363433\" />\r\n <path\r\n d=\"M27.2152 2.80005C17.0096 2.80005 8.89746 10.612 8.89746 20.44C8.89746 28.252 14.3928 35.056 21.7199 37.324L23.29 32.536C18.0563 31.024 14.1311 26.236 14.1311 20.44C14.1311 13.384 19.8881 7.84004 27.2152 7.84004C34.5423 7.84004 40.2993 13.384 40.2993 20.44C40.2993 25.984 36.6358 30.52 31.6638 32.284L33.4956 37.072C40.561 34.552 45.533 28 45.533 20.44C45.533 10.612 37.1591 2.80005 27.2152 2.80005Z\"\r\n fill=\"#363433\" />\r\n </svg>\r\n</template>\r\n\r\n<script setup>\r\nimport { defineProps } from 'vue'\r\n\r\nconst props = defineProps({\r\n typeOfIcon: {\r\n type: String,\r\n default: () => '',\r\n validator: function (value) {\r\n const allowedValues = ['power-plug', 'document', 'battery', 'monkey-wrench', 'search', 'login', 'user']\r\n return allowedValues.includes(value)\r\n }\r\n },\r\n large: {\r\n type: Boolean,\r\n default: false\r\n }\r\n})\r\n</script>\r\n\r\n<style scoped>\r\n.icon-small {\r\n width: 1.5rem;\r\n height: 1.5rem;\r\n}\r\n.icon-large {\r\n width: 6rem;\r\n height: 6rem;\r\n}\r\n\r\n.icon-search {\r\n width: 1rem;\r\n height: 1rem;\r\n}\r\n\r\n.icon-login {\r\n width: 3.5rem;\r\n height: 3.5rem;\r\n}\r\n\r\n.icon-user {\r\n width: 3.5rem;\r\n height: 3.5rem;\r\n}\r\n</style>\r\n","import script from \"./DesktopNavLowerNavIcon.vue?vue&type=script&setup=true&lang=js\"\nexport * from \"./DesktopNavLowerNavIcon.vue?vue&type=script&setup=true&lang=js\"\n\nimport \"./DesktopNavLowerNavIcon.vue?vue&type=style&index=0&id=173cddf0&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['__scopeId',\"data-v-173cddf0\"]])\n\nexport default __exports__","import { render } from \"./DesktopNavLowerMegaMenuItem.vue?vue&type=template&id=0fd41ea0&scoped=true\"\nimport script from \"./DesktopNavLowerMegaMenuItem.vue?vue&type=script&lang=js\"\nexport * from \"./DesktopNavLowerMegaMenuItem.vue?vue&type=script&lang=js\"\n\nimport \"./DesktopNavLowerMegaMenuItem.vue?vue&type=style&index=0&id=0fd41ea0&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-0fd41ea0\"]])\n\nexport default __exports__","import { render } from \"./DesktopNavLower.vue?vue&type=template&id=158df654&scoped=true\"\nimport script from \"./DesktopNavLower.vue?vue&type=script&lang=js\"\nexport * from \"./DesktopNavLower.vue?vue&type=script&lang=js\"\n\nimport \"./DesktopNavLower.vue?vue&type=style&index=0&id=158df654&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-158df654\"]])\n\nexport default __exports__","<template>\r\n <div class=\"flex items-center justify-between w-full ellevio-desktop-nav-upper\">\r\n <a :href=\"logoLink\" class=\"flex items-center my-3 rounded-sm\" data-testid=\"desktopMenuLogoLink\">\r\n <img class=\"inline ellevio-logo\" :src=\"`${isDevelopment ? '' : '/gui-web'}/img/logo-orange.svg`\" :alt=\"navigationData.translations?.altTexts?.logotypeAltText\" data-testid=\"desktopMenuLogoImage\" />\r\n </a>\r\n <div class=\"flex items-center\">\r\n <nav :aria-label=\"navigationData.translations?.ariaLabels?.upperNav\">\r\n <ul class=\"flex gap-5\" role=\"menu\">\r\n <li v-for=\"(item, index) in navigationData.secondaryMenu\" :key=\"`desktopNavUpper-${index}`\">\r\n <a :href=\"item.url\" :target=\"item.target === '' ? '_self' : item.target\" class=\"text-lg rounded-sm animated-menu-link\" :class=\"item.isSelected && !megaMenuOpen ? 'active' : ''\" role=\"menuitem\" :data-testid=\"`desktopMenuUpperNavLink-${index}`\">{{\r\n item.text\r\n }}</a>\r\n </li>\r\n <li v-if=\"otherLanguage?.url\" class=\"flex items-center\">\r\n <a :href=\"otherLanguage?.url\" class=\"flex items-center rounded-sm ellevio-lang-switch\" :aria-label=\"navigationData.translations?.ariaLabels?.changeLanguage\" role=\"menuitem\" data-testid=\"desktopMenuUpperNavLangSwitch\">\r\n <span class=\"pl-1 mt-[3px] text-xs text-newColors-gray-content font-futuraEfDemiBold\">{{ otherLanguage?.label }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </nav>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nexport default {\r\n name: 'ellevio-web-desktop-nav-upper',\r\n props: {\r\n navigationData: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n otherLanguage: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n logoLink: {\r\n type: String,\r\n default: '/'\r\n },\r\n megaMenuOpen: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n computed: {\r\n isDevelopment() {\r\n let env = {}\r\n try {\r\n env = import.meta.env\r\n if (typeof env !== 'object') env = {}\r\n } catch (_) {\r\n env = {}\r\n }\r\n return env.MODE === 'development'\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.ellevio-desktop-nav-upper {\r\n position: relative;\r\n}\r\n/* Gray divider */\r\n.ellevio-desktop-nav-upper::after {\r\n @apply content-[''] bg-newColors-gray-baseB h-[1px] absolute left-0 bottom-[-1px];\r\n width: 100%;\r\n}\r\n\r\n.ellevio-logo {\r\n width: 7.5rem;\r\n}\r\n\r\n.ellevio-desktop-nav-upper:deep(a:focus) {\r\n outline: 2px dotted black;\r\n outline-offset: 4px;\r\n}\r\n\r\n.ellevio-desktop-nav-upper:deep(a.animated-menu-link:before) {\r\n bottom: -0.9rem;\r\n z-index: 1;\r\n}\r\n</style>\r\n","import { render } from \"./DesktopNavUpper.vue?vue&type=template&id=062142a6&scoped=true\"\nimport script from \"./DesktopNavUpper.vue?vue&type=script&lang=js\"\nexport * from \"./DesktopNavUpper.vue?vue&type=script&lang=js\"\n\nimport \"./DesktopNavUpper.vue?vue&type=style&index=0&id=062142a6&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-062142a6\"]])\n\nexport default __exports__","import { render } from \"./DesktopNav.vue?vue&type=template&id=bad1fbf2&scoped=true\"\nimport script from \"./DesktopNav.vue?vue&type=script&lang=js\"\nexport * from \"./DesktopNav.vue?vue&type=script&lang=js\"\n\nimport \"./DesktopNav.vue?vue&type=style&index=0&id=bad1fbf2&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-bad1fbf2\"]])\n\nexport default __exports__","import { render } from \"./Header.vue?vue&type=template&id=74b680d3\"\nimport script from \"./Header.vue?vue&type=script&lang=js\"\nexport * from \"./Header.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","<template>\r\n <button v-if=\"myPages || userLoggedIn\" class=\"flex items-center justify-between w-full\">\r\n <a :href=\"login.logOutButton.url\" class=\"flex w-full p-2 cursor-pointer group button-std\" @click.prevent=\"logOut\">\r\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" class=\"inline-block ml-2\" width=\"16px\" height=\"16px\" viewBox=\"0 0 16 16\">\r\n <path\r\n class=\"group-hover:fill-black fill-white\"\r\n d=\"m12.444 4.444-1.253 1.254 1.405 1.413H5.333V8.89h7.263l-1.405 1.404 1.253 1.263L16 8l-3.556-3.556ZM1.778 1.778H8V0H1.778C.8 0 0 .8 0 1.778v12.444C0 15.2.8 16 1.778 16H8v-1.778H1.778V1.778Z\"\r\n fill=\"#fff\" />\r\n </svg>\r\n <span class=\"ml-2\">{{ login.logOutButton.text }}</span>\r\n </a>\r\n </button>\r\n</template>\r\n\r\n<script>\r\nexport default {\r\n name: 'EllevioWebLogOutButton',\r\n props: {\r\n login: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n myPages: {\r\n type: Boolean,\r\n default: false\r\n },\r\n userLoggedIn: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n methods: {\r\n logOut() {\r\n //sessionStorage.clear();\r\n sessionStorage.removeItem('vuex')\r\n window.location.href = this.login.logOutButton.url\r\n },\r\n closeLoginMenu() {\r\n this.$emit('close-login-menu')\r\n }\r\n }\r\n}\r\n</script>\r\n","import { render } from \"./LogOutButton.vue?vue&type=template&id=d25968aa\"\nimport script from \"./LogOutButton.vue?vue&type=script&lang=js\"\nexport * from \"./LogOutButton.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","<template>\r\n <div class=\"flex items-start justify-start\">\r\n <span class=\"info-icon\"></span>\r\n <p v-html=\"errorMessage\" class=\"flex-1 max-w-[52rem] text-base leading-5 error-message font-futuraEfBook\" data-testid=\"searchInputErrorMessage\"></p>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nexport default {\r\n name: 'SearchInputErrorMessage',\r\n props: {\r\n errorMessage: {\r\n type: String,\r\n required: true\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.error-message :deep(a) {\r\n @apply !text-base underline hover:!no-underline;\r\n}\r\n.info-icon {\r\n @apply not-sr-only;\r\n}\r\n.info-icon::before {\r\n @apply content-[''] block w-6 h-6 bg-newColors-orange-signature -mt-[2px] mr-2;\r\n mask: url('/src/assets/images/brand2024/icon-info.svg') no-repeat center / contain;\r\n -webkit-mask: url('/src/assets/images/brand2024/icon-info.svg') no-repeat center / contain;\r\n}\r\n</style>\r\n","import { render } from \"./SearchInputErrorMessage.vue?vue&type=template&id=295f3fd6&scoped=true\"\nimport script from \"./SearchInputErrorMessage.vue?vue&type=script&lang=js\"\nexport * from \"./SearchInputErrorMessage.vue?vue&type=script&lang=js\"\n\nimport \"./SearchInputErrorMessage.vue?vue&type=style&index=0&id=295f3fd6&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-295f3fd6\"]])\n\nexport default __exports__","<template>\r\n <div :id=\"`tooltip-${tooltipId}`\" @click.prevent=\"tooltipClicked\" aria-label=\"Tooltip\" data-testid=\"tooltip\">\r\n <slot />\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport tippy from 'tippy.js'\r\nimport 'tippy.js/dist/tippy.css'\r\nimport 'tippy.js/dist/backdrop.css'\r\nimport 'tippy.js/dist/border.css'\r\nimport 'tippy.js/dist/svg-arrow.css'\r\nimport 'tippy.js/themes/light.css'\r\nexport default {\r\n name: 'ellevio-web-tooltip',\r\n props: {\r\n title: {\r\n type: String,\r\n default: ''\r\n },\r\n content: {\r\n type: String,\r\n default: ''\r\n },\r\n identifier: {\r\n type: String,\r\n default: ''\r\n },\r\n active: {\r\n type: Boolean,\r\n default: true\r\n },\r\n placement: {\r\n type: String,\r\n default: 'top'\r\n }\r\n },\r\n data() {\r\n return {\r\n tippyInstance: null,\r\n isMobile: true\r\n }\r\n },\r\n computed: {\r\n matchMediaMobileQuery() {\r\n return window.matchMedia(' (min-width: 900px) ')\r\n },\r\n tooltipId() {\r\n return this.identifier || Math.floor(Math.random() * 1000 + 1)\r\n }\r\n },\r\n methods: {\r\n tooltipClicked() {\r\n if (this.active) {\r\n if (this.isMobile && this.tippyInstance && this.tippyInstance[0]) {\r\n if (this.tippyInstance[0].state.isShown) {\r\n this.tippyInstance[0].hide(200)\r\n } else {\r\n this.tippyInstance[0].show(200)\r\n }\r\n }\r\n }\r\n },\r\n resize: function () {\r\n this.isMobile = this.matchMediaMobileQuery ? !this.matchMediaMobileQuery.matches : true\r\n }\r\n },\r\n mounted() {\r\n if (this.active) {\r\n this.isMobile = this.matchMediaMobileQuery ? !this.matchMediaMobileQuery.matches : true\r\n this._boundedResize = this.resize.bind(this)\r\n window.addEventListener('resize', this._boundedResize)\r\n\r\n this.$nextTick(() => {\r\n this.tippyInstance = tippy(`#tooltip-${this.tooltipId}`, {\r\n theme: 'light',\r\n zIndex: 100000,\r\n placement: this.placement,\r\n allowHTML: true,\r\n hideOnClick: false,\r\n content: `<div class=\"tooltip-inner\">${this.title.length > 0 ? `<strong>${this.title}</strong><br/>` : ''}${this.content}</div>`\r\n })\r\n })\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n[id^='tooltip-'] {\r\n min-width: 20px;\r\n width: auto;\r\n height: auto;\r\n font-size: 1.9rem;\r\n /*font-size: 18px !important;*/\r\n}\r\n.tippy-box[data-theme~='light'] {\r\n /* override theme box shadow (tailwind shadow-md + small adjustment) */\r\n box-shadow: 0 4px 6px 1px rgb(0 0 0 / 0.1), 0 2px 4px 0 rgb(0 0 0 / 0.1);\r\n}\r\n.tooltip-inner {\r\n font-size: 18px !important;\r\n line-height: 24px;\r\n padding: 6px;\r\n}\r\n</style>\r\n","import { render } from \"./TooltipWrapper.vue?vue&type=template&id=8db02790&scoped=true\"\nimport script from \"./TooltipWrapper.vue?vue&type=script&lang=js\"\nexport * from \"./TooltipWrapper.vue?vue&type=script&lang=js\"\n\nimport \"./TooltipWrapper.vue?vue&type=style&index=0&id=8db02790&scoped=true&lang=css\"\n\nimport exportComponent from \"../../../../node_modules/@vue/cli-service/node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-8db02790\"]])\n\nexport default __exports__","export const clickOutside = {\r\n bind: function(el, binding, vnode) {\r\n el.event = function(event) {\r\n if (!(el == event.target || el.contains(event.target))) {\r\n vnode.context[binding.expression](event)\r\n }\r\n }\r\n document.body.addEventListener('click', el.event)\r\n document.body.addEventListener('focusin', el.event)\r\n },\r\n unbind: function(el) {\r\n document.body.removeEventListener('click', el.event)\r\n document.body.removeEventListener('focusin', el.event)\r\n }\r\n}\r\n","export default {\r\n setCookie(cname, cvalue, exdays) {\r\n const d = new Date()\r\n d.setTime(d.getTime() + exdays * 24 * 60 * 60 * 1000)\r\n let expires = 'expires=' + d.toUTCString()\r\n document.cookie = cname + '=' + cvalue + ';' + expires + ';path=/'\r\n },\r\n getCookie(cname) {\r\n let name = cname + '='\r\n let decodedCookie = decodeURIComponent(document.cookie)\r\n let ca = decodedCookie.split(';')\r\n for (let i = 0; i < ca.length; i++) {\r\n let c = ca[i]\r\n while (c.charAt(0) == ' ') {\r\n c = c.substring(1)\r\n }\r\n if (c.indexOf(name) == 0) {\r\n return c.substring(name.length, c.length)\r\n }\r\n }\r\n return ''\r\n }\r\n}\r\n","/**\r\n * Simple focus trap utility class (mainly for use in megamenu in the header-navigation)\r\n * Use it like this: new TrapFocus(document.getElementById('id of the container'))\r\n * More info here - https://codepen.io/massimo-baffoni/pen/mdjXXeg\r\n */\r\nexport class TrapFocus {\r\n constructor(element) {\r\n this.container = element\r\n this.focusableEls = []\r\n this.FOCUSABLES = 'a[href]:not([disabled]), area[href]:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, [tabindex=\"0\"], [contenteditable]'\r\n this.setFocusables()\r\n this.setEventListeners()\r\n }\r\n\r\n setFocusables() {\r\n this.focusableEls = this.container.querySelectorAll(this.FOCUSABLES)\r\n }\r\n\r\n setEventListeners() {\r\n this.container.addEventListener('keydown', this.keyboardHandler)\r\n this.container.setAttribute('tabindex', '-1')\r\n //commenting out this row since it stops selecting text in the megamenu. We do not need focusRebounce at this stage.\r\n //this.container.addEventListener('focus', this.focusRebounce)\r\n }\r\n\r\n /* Listener relative to keypress, to let focus cycle inside container elements andnot outside */\r\n keyboardHandler = (e) => {\r\n if (e.key === 'Tab' || e.keyCode === 9) {\r\n if (e.shiftKey && e.target === this.focusableEls[0]) {\r\n e.preventDefault()\r\n this.focusableEls[this.focusableEls.length - 1].focus()\r\n } else if (!e.shiftKey && e.target === this.focusableEls[this.focusableEls.length - 1]) {\r\n e.preventDefault()\r\n this.focusableEls[0].focus()\r\n }\r\n }\r\n }\r\n\r\n /* Utility listener, not needed for theoverall logics but potentially useful for automatically targeting the first focusable element from outside container. This is a requested behaviour for modals and dropdowns */\r\n focusRebounce = () => {\r\n this.focusableEls[0].focus()\r\n }\r\n}\r\n"],"names":["mirror","xmlns","class","style","color","viewBox","width","height","d","name","props","type","String","default","Boolean","__exports__","render","fill","errorType","zOrderClass","role","ref","stroke","title","setTextFullWidth","text","href","linkUrl","target","linkTarget","linkText","showClose","close","closeText","outlineIcon","iconSrc","validator","value","includes","cookieId","scrollbarWidth","Number","desktopMenuIsOpen","zOrderSmaller","data","closed","mounted","doc","document","documentElement","this","open","resizeObserver","ResizeObserver","entries","entry","contentBoxSize","setProperty","blockSize","alertBox","querySelector","observe","computed","getCookie","renderedCookieName","showLink","methods","setCookie","watch","isOpen","$refs","alertContainerRef","paddingRight","isMobile","alertMenu","handleToggleMegaMenu","searchNoHitsContent","headerHeight","show","searchApiUrl","searchPageUrl","navigationData","desktopNavigationData","logoLink","onMapPage","apiUrl","showAutocompleteList","footerLinks","secondaryMenu","mobileNavigationData","alert","tabindex","src","alt","loginMenuOpen","showSearchField","join","topNames","Object","keys","length","undefined","treeHeading","treeHeadingLink","search","myPages","showLogin","loginMenu","userLoggedIn","translations","handleShowSearchField","handleCloseSearchField","handleToggleLoginMenu","handleToggleMenu","handleCloseMenu","handleShowMainMenu","login","closeLoginMenu","closeMenuFromSide","closeMenu","menuOpen","topMenuMobile","menuItems","otherLanguage","treeOpen","ariaLabels","goToStartPage","showMainMenu","toggleSearchField","dark","menuLabel","toggleLoginMenu","profileButtonText","toggleMenu","components","EllevioWebLinkIcon","tagsForSmallerInput","required","emptySearchField","userName","userNameSplit","split","potentialFirstName","substring","heading","objectEmpty","obj","constructor","$emit","closeSearchField","description","areas","area","index","key","id","links","link","subindex","url","logOutButton","EllevioWebLogOutButton","closeSearchMenu","action","label","inputLabel","placeholder","inputPlaceholder","buttonText","itemIsOpen","clearSearchFieldLabel","clearSearchField","for","autocomplete","keyUpEvents","$event","inputText","content","searchTooltipLabel","active","placement","submitForm","showAutoComplete","matches","handleEsc","item","autocompleteClick","closeAutoComplete","errorMessage","EllevioWebTooltipWrapper","EllevioSearchInputErrorMessage","directives","clickOutside","sizeSmall","sizeSearch","backgroundBox","placeholderText","useInHeader","numberOfItems","hover","timer","getAutocompleteItems","deleteTextCrossVisible","baseUrl","env","_","MODE","filter","toLowerCase","slice","newVal","$nextTick","async","query","focus","focusSearchField","forms","searchform","submit","getData","response","axios","get","responseData","clearTimeout","setTimeout","bind","EllevioWebHeaderSearchInput","toggleMenuItem","anyChildrenActive","nodes","isSelected","rx","itemlvl2","index2","items","find","x","itemlvl3","index3","Array","indentWidth","val","children","querySelectorAll","i","checkVisibility","previousSibling","classList","add","parentNode","child","grandChild","activeItem","el","closest","plusSvg","minusSvg","lvl1Wrapper","lvl2Button","nextEl","nextElementSibling","contains","remove","toggle","footerLanguage","changeLanguage","EllevioWebMobileNavHead","EllevioWebMobileLoginWideArea","EllevioWebMobileSearchWideArea","EllevioWebMobileNavTree","EllevioWebMobileNavFooter","lang","tree","topLinks","breakpoint","initialLinks","showNavigationTree","fetchedData","treeData","matchMediaQuery","window","matchMedia","_boundedResize","resize","addEventListener","unmounted","removeEventListener","handleFixedScrollState","bodyClassNames","body","closeDeliverySiteSelectorMobile","e","className","indexOf","handleShowNavigationTree","parentId","fetchChildren","getMenuChildrenByParentId","headers","store","dispatch","appHeight","innerHeight","skipLinks","toMenu","toContent","megaMenuOpen","setPropsForMegaMenuOpen","activeMenuItem","ariaLabelLowerNav","itemId","itemIcon","icon","showActiveUnderline","typeOfIcon","large","subitem","subIndex","subsubitem","subsubindex","searchLink","loginLink","logoutLink","closeMegaMenu","closeAndSetButtonFocus","EllevioWebDesktopNavLowerNavIcon","emits","scrollBarWidth","setMegaMenuPadding","menuButton","megaMenuRef","closeBtnRef","megaMenuStyle","getComputedStyle","closeBtnStyle","megaMenuPaddingRight","parseInt","closeBtnRight","right","getElementById","EllevioWebDesktopNavLowerMegaMenuItem","oldVal","some","grandchild","menuIsClosedAndItemHasChild","menuIsOpen","isDevelopment","altTexts","logotypeAltText","upperNav","EllevioWebDesktopNavLower","EllevioWebDesktopNavUpper","toggleMegaMenuMargin","desktopNavRef","marginRight","EllevioWebDesktopNav","EllevioWebMobileNav","EllevioWebAlert","EllevioWebRunOnload","megaMenu","desktopItemsPerRow","location","htmlClassNames","paddingTop","onHeaderHeightResize","headerHeightRef","clientHeight","measureScrollbarWidth","outer","createElement","visibility","overflow","appendChild","inner","offsetWidth","removeChild","Element","unobserve","logOut","sessionStorage","removeItem","tooltipId","tooltipClicked","identifier","tippyInstance","matchMediaMobileQuery","Math","floor","random","state","isShown","hide","theme","zIndex","allowHTML","hideOnClick","binding","vnode","event","context","expression","unbind","cname","cvalue","exdays","Date","setTime","getTime","expires","toUTCString","cookie","decodedCookie","decodeURIComponent","ca","c","charAt","TrapFocus","element","container","focusableEls","FOCUSABLES","setFocusables","setEventListeners","keyboardHandler","setAttribute","keyCode","shiftKey","preventDefault","focusRebounce"],"sourceRoot":""}