{"version":3,"file":"main.js","names":["_ImageLoader","MILLISECONDS_MULTIPLIER","TRANSITION_END","toType","obj","undefined","concat","toString","call","match","toLowerCase","getSelector","element","selector","getAttribute","hrefAttr","includes","startsWith","split","trim","getElementFromSelector","document","querySelector","getTransitionDurationFromElement","_window$getComputedSt","window","getComputedStyle","transitionDuration","transitionDelay","floatTransitionDuration","Number","parseFloat","floatTransitionDelay","triggerTransitionEnd","dispatchEvent","Event","isElement","_typeof","jquery","nodeType","getElement","length","typeCheckConfig","componentName","config","configTypes","Object","keys","forEach","property","expectedTypes","value","valueType","RegExp","test","TypeError","toUpperCase","isVisible","getClientRects","getPropertyValue","isDisabled","Node","ELEMENT_NODE","classList","contains","disabled","hasAttribute","reflow","offsetHeight","getjQuery","_window","jQuery","body","DOMContentLoadedCallbacks","onDOMContentLoaded","callback","readyState","addEventListener","push","isRTL","documentElement","dir","defineJQueryPlugin","plugin","$","name","NAME","JQUERY_NO_CONFLICT","fn","jQueryInterface","Constructor","noConflict","execute","executeAfterTransition","transitionElement","waitForTransition","arguments","durationPadding","emulatedDuration","called","handler","_ref","target","removeEventListener","setTimeout","namespaceRegex","stripNameRegex","stripUidRegex","eventRegistry","uidEvent","customEvents","mouseenter","mouseleave","customEventsRegex","nativeEvents","Set","getUidEvent","uid","getEvent","bootstrapHandler","event","delegateTarget","oneOff","EventHandler","off","type","apply","bootstrapDelegationHandler","domElements","querySelectorAll","parentNode","i","findHandler","events","delegationSelector","uidEventList","len","originalHandler","normalizeParams","originalTypeEvent","delegationFn","delegation","typeEvent","getTypeEvent","isNative","has","addHandler","wrapFn","relatedTarget","_normalizeParams","_normalizeParams2","_slicedToArray","handlers","previousFn","replace","removeHandler","Boolean","removeNamespacedHandlers","namespace","storeElementEvent","handlerKey","on","one","_normalizeParams3","_normalizeParams4","inNamespace","isNamespace","elementEvent","slice","keyHandlers","trigger","args","jQueryEvent","bubbles","nativeDispatch","defaultPrevented","evt","isPropagationStopped","isImmediatePropagationStopped","isDefaultPrevented","createEvent","initEvent","CustomEvent","cancelable","key","defineProperty","get","preventDefault","normalizeData","val","normalizeDataKey","chr","Manipulator","setDataAttribute","setAttribute","removeDataAttribute","removeAttribute","getDataAttributes","attributes","dataset","filter","pureKey","charAt","getDataAttribute","offset","rect","getBoundingClientRect","top","pageYOffset","left","pageXOffset","position","offsetTop","offsetLeft","NODE_TEXT","SelectorEngine","find","_ref2","_toConsumableArray","Element","prototype","findOne","children","_ref3","child","matches","parents","ancestor","prev","previous","previousElementSibling","next","nextElementSibling","focusableChildren","focusables","map","join","el","SELECTOR_FIXED_CONTENT","SELECTOR_STICKY_CONTENT","ScrollBarHelper","_classCallCheck","_element","_createClass","getWidth","documentWidth","clientWidth","Math","abs","innerWidth","hide","width","_disableOverFlow","_setElementAttributes","calculatedValue","_saveInitialAttribute","style","overflow","styleProp","_this","scrollbarWidth","manipulationCallBack","_applyManipulationCallback","reset","_resetElementAttributes","actualValue","removeProperty","callBack","isOverflowing","elementMap","Map","Data","set","instance","instanceMap","size","console","error","Array","from","remove","VERSION","BaseComponent","constructor","DATA_KEY","dispose","_this2","EVENT_KEY","getOwnPropertyNames","propertyName","_queueCallback","isAnimated","getInstance","getOrCreateInstance","Error","Default$2","className","rootElement","clickCallback","DefaultType$2","NAME$3","CLASS_NAME_FADE$2","CLASS_NAME_SHOW$2","EVENT_MOUSEDOWN","Backdrop","_config","_getConfig","_isAppended","show","_append","_getElement","add","_emulateAnimation","_this3","backdrop","createElement","_objectSpread","_this4","append","Default$1","trapElement","autofocus","DefaultType$1","NAME$2","DATA_KEY$2","EVENT_KEY$2","EVENT_FOCUSIN","EVENT_KEYDOWN_TAB","TAB_KEY","TAB_NAV_FORWARD","TAB_NAV_BACKWARD","FocusTrap","_isActive","_lastTabNavDirection","activate","_this5","_this$_config","focus","_handleFocusin","_handleKeydown","deactivate","elements","shiftKey","enableDismissTrigger","component","method","clickEvent","tagName","closest","NAME$1","DATA_KEY$1","EVENT_KEY$1","DATA_API_KEY$1","ESCAPE_KEY","Default","keyboard","DefaultType","EVENT_HIDE$1","EVENT_HIDE_PREVENTED","EVENT_HIDDEN$1","EVENT_SHOW$1","EVENT_SHOWN$1","EVENT_RESIZE","EVENT_CLICK_DISMISS","EVENT_KEYDOWN_DISMISS","EVENT_MOUSEUP_DISMISS","EVENT_MOUSEDOWN_DISMISS","EVENT_CLICK_DATA_API$1","CLASS_NAME_OPEN","CLASS_NAME_FADE$1","CLASS_NAME_SHOW$1","CLASS_NAME_STATIC","OPEN_SELECTOR","SELECTOR_DIALOG","SELECTOR_MODAL_BODY","SELECTOR_DATA_TOGGLE$1","Modal","_BaseComponent","_inherits","_super","_createSuper","_this6","_dialog","_backdrop","_initializeBackDrop","_focustrap","_initializeFocusTrap","_isShown","_ignoreBackdropClick","_isTransitioning","_scrollBar","toggle","_this7","showEvent","_isAnimated","_adjustDialog","_setEscapeEvent","_setResizeEvent","_showBackdrop","_showElement","_this8","hideEvent","_hideModal","htmlElement","_get","_getPrototypeOf","handleUpdate","_this9","modalBody","display","scrollTop","transitionComplete","_resetAndDisplayIframe","iframe","originalSrc","src","_this10","_triggerBackdropTransition","_this11","_this12","_resetAdjustments","_hideVideoOnModalClose","_this13","currentTarget","_this14","_this$_element","scrollHeight","isModalOverflowing","clientHeight","overflowY","isBodyOverflowing","paddingLeft","paddingRight","each","data","_this15","allReadyOpen","DATA_API_KEY","EVENT_HIDE","EVENT_HIDDEN","EVENT_SHOW","EVENT_SHOWN","EVENT_CLICK_DATA_API","CLASS_NAME_DROPDOWN_MENU","CLASS_NAME_ACTIVE","CLASS_NAME_FADE","CLASS_NAME_SHOW","SELECTOR_DROPDOWN","SELECTOR_NAV_LIST_GROUP","SELECTOR_ACTIVE","SELECTOR_ACTIVE_UL","SELECTOR_DATA_TOGGLE","SELECTOR_DROPDOWN_TOGGLE","SELECTOR_DROPDOWN_ACTIVE_CHILD","Tab","_BaseComponent2","_super2","_this16","listElement","itemSelector","nodeName","_activate","complete","container","_this17","activeElements","active","isTransitioning","_transitionComplete","dropdownChild","parent","dropdownElement","dropdown","Accordion","main","bodyClass","isGov","accordions","init","accordion","toggleAccordion","e","accordionItem","toggleIcon","iconHref","blur","Alerts","alertCloseBtns","shouldRender","closeBtn","closeAlert","alerts","alert","alertId","sessionStorage","getItem","setItem","getElementById","AnimatedStat","counters","options","rootMargin","threshold","observer","IntersectionObserver","entries","entry","isIntersecting","animateCounter","unobserve","counter","observe","counterHTML","start","end","step","current","timer","setInterval","innerHTML","clearInterval","BlogCards","years","categories","categories2","categories3","activeCategory","activeCategory2","activeCategory3","activeYear","activeSort","searchTerm","currentPage","index","firstIndex","lastIndex","cardLinks","initCards","filtered","setCategories","card","cardEl","categoriesArr","JSON","parse","category","categorySelect","categoryOption","innerText","appendChild","setCategories2","setCategories3","setYears","_cardEl$querySelector","cardContent","textContent","yearsSelect","year","yearOption","handlePages","list","insertAdjacentHTML","pagination","pageAmount","ceil","renderPage","slicedBlogs","blog","sortingAndFiltering","hasFilters","keyWordSearch","filterBlog","selectedIndex","sortBlog","changePage","pages","nextButton","prevButton","page","parseInt","handlePagingStatus","pageControl","pagingStatus","cardLink","setHover","removeHover","cardImage","filteredCards","cardsReplica","sort","a","b","_a$querySelector","_a$querySelector2","_b$querySelector","_b$querySelector2","_a$querySelector3","_a$querySelector4","_b$querySelector3","_b$querySelector4","_a$querySelector5","_a$querySelector6","_b$querySelector5","_b$querySelector6","yearA","Date","yearB","authorA","authorB","titleA","titleB","cards","cardCategories","filteredCards2","filteredCards3","filteredCards4","_cardEl$querySelector2","filteredCards5","NewsCards","_cardEl$querySelector3","slicedNews","news","filterNews","_document$querySelect","_document$querySelect2","_document$querySelect3","_document$querySelect4","_document$querySelect5","localStorage","sortNews","pageToNav","click","_a$querySelector7","_a$querySelector8","_b$querySelector7","_b$querySelector8","_a$querySelector9","_a$querySelector10","_b$querySelector9","_b$querySelector10","_a$querySelector11","_a$querySelector12","_b$querySelector11","_b$querySelector12","_cardEl$querySelector4","ImageLoader","queue","backgroundQueue","lazyImageObserver","lazyBgObserver","initialize","_this18","getImagesToLazyLoad","abort","onContentLoaded","setGenericPlaceholder","lazyImage","lazyBg","_this19","genericImagePlaceholder","img","genericBgPlaceholder","bg","backgroundColor","_this20","srcset","freeze","_BREAKPOINTS_","Proxy","Symbol","iterator","URLSearchParams","location","search","url","URL","searchParams","history","replaceState","deleteProperty","Carousel","id","carouselType","bulletsWrapper","totalSlides","perSlide","perSlideTablet","perSlideMobile","centerFocus","centerFocusMobile","autoPlay","autoPlayDuration","animationTimingFunc","hoverPause","peek","peekTablet","peekMobile","gap","gapTablet","gapMobile","leftArrowIcon","leftArrowIconMobile","rightArrowIcon","rightArrowIconMobile","cardsSlider","adjustableHeightOnMobile","carouselIsMobileOnly","carousels","resizeHandler","carouselItem","random","checkCarouselIsMobileOnly","setup","carousel","_this21","glideSlides","slides","sm","hideOrShowArrows","setFullBackground","setCarouselButtonPosition","perView","perSwipe","focusAt","autoplay","hoverpause","rewind","dragThreshold","breakpoints","track","parentElement","unscrolled","scrollLeft","slide","slideIndex","indexOf","slider","go","setCountText","isMobile","destroy","Glide","mount","md","slideHeight","root","glideTrack","newHeight","height","scrollIntoView","behavior","block","isFullCarousel","_carousel$parentEleme","_carousel$parentEleme2","_carousel$parentEleme3","_carousel$parentEleme4","fullCarousel","backColor","backImage","showDots","dots","prevNext","showPrevNext","backgroundImage","isGalleryCarousel","gallerySlideContainer","_gallerySlideContaine","photoHeight","_carousel$getAttribut","_carouselItem$getAttr","Datatables","tables","table","_table$getAttribute","_table$getAttribute2","paging","info","searching","isResponsive","horizontalScrollbar","orderCol","orderDir","orderArray","DataTable","targets","orderable","responsive","drawCallback","settings","api","Footer","currentYear","getCurrentYear","getFullYear","yearHTML","FeaturedImageVideoCallout","calculateHeaderHeights","cardLayouts","cardLayout","cardHeadlines","maxHeight","headline","heroBanner","pausePlayBtn","pausePlayVideo","video","paused","play","pause","IconCard","iconCards","ImageCard","imageCards","href","urlExtension","getUrlExtension","fileExtensions","endUrl","pop","LeftNavMenu","seriius","gov","leftNav","shareBarCol9","toggleLeftNavBtns","browserWidth","moveShareBar","toggleLeftNavBtn","toggleLeftNav","leftnav","moveLeftNav","bindMobile","leftNavMobileWrapper","leftNavDesktopWrapper","parentNodes","node","shareDiv","mobileNavToggle","parentToggles","toggleMobileMenu","parentToggle","openMobileSubmenu","closeAllMobileSubmenus","openNodes","keyCode","leftNavMenu","LinkUpdates","links","link","removeTitleAttribute","changeUrl","fileTypes","fileExtension","some","currentUrl","newHref","LogosWidget","backgroundImg","useImg","setBG","desktopImg","mobileImg","MainMenu","parentLinks","bodyClasses","timeId","clearTimeout","executeAfterResize","setBindings","moveSearch","userLinksMobile","checkStacked","siteMenu","abortControl","noMenu","checkIfOutsideOfMenu","hideShowSearchheader2","hideShowSearchheader1","hideShowSearchheader3","reformatRequired","_abortControl","AbortController","desktop","matchMedia","bindDesktop","navStyle","parentLink","openSubmenu","signal","childToggles","childToggle","header3SearchWrappers","header3SearchWrapper","searchToggle","header2SearchWrappers","header2SearchWrapper","header3","mobileSearchSpacer","header1SearchWrappers","headerOneSearch","header1SearchWrapper","header","dropdownList","userLinks","menuWrapper","windowWidth","isheader2","grayBackground","_document$querySelect6","_document$querySelect7","_document$querySelect8","titleWidth","offsetWidth","menuWidth","menuHeight","activeElement","openNode","closeAllSubmenus","searchToggleBtn","mobileSearch","searchMenuWrap","conatains","openChildNodes","currentNode","headerSearchCol","bannerTitleCol","mainMenu","lg","after","prepend","forms","form","labels","label","labelText","mobileToggleBtn","NotificationBanner","notifications","hasLeftNav","notification","closeNotification","subForm","marginBottom","titleBar","ParallaxHero","heros","hero","currentImg","ParallaxImageTextOverlay","fullWidthCtas","banner","fadeOut","opacity","fade","requestAnimationFrame","fadeIn","ScrollToTop","btn","isShown","scrollY","onclick","scrollTo","SoftwareTools","dropdownToggles","ossdTable","toggleDropdown","clickedOutside","OSSDDT","initDatatable","getDatatable","draw","not","stopPropagation","va","order","text","dropdownMenu","withinDropdown","dt","methods","dtid","dom","columns","rows","contents","html","invalidate","pageLength","dataTable","ext","dataIndex","fv","is","rv","row","t","inArray","TeamMembers","teamMemberSections","teamMembers","loadMoreBtn","searchBtn","expandModule","teamSearchRedirect","elementScrollHeight","ToggleSearch","toggleSearchBtns","srcSubSearch","externalSubSearchBtn","externalSubSearchBox","externalSearchBtns","_loop","x","redirectToExternalSearch","childNodes","toggleSearch","pageTitle","redirectToExternalSubSearch","header3ToggleSearchBtn","headerTwoToggleSearchBtn","headerOneToggleSearchBtn","pageWrapper","searchButton","marginTop","_e$target$parentNode$","_e$target$parentNode$2","externalTarget","_e$target$parentNode$3","_e$target$parentNode$4","_e$target$parentNode$5","_e$target$parentNode$6","encodeURIComponent","videoPopup","videos","openModalBtn","generateModal","openModalLink","modalAlt","iframeHref","videoTitle","setAttributes","prop","modalDiv","role","modalContent","fixTabbing","bindModal","closeModal","modal","log","videoModal","clickedVideo","VideoHero","heroVideo","pauseBtn","playBtn","pauseVideo","playVideo","TabbedContent","tabbedContent","targetList","listItems","tab","li","bsToggle","bsTarget","heading","replaceChildren","MailChimpForm","setItemWithDate","newDate","date","stringify","getItemWithDate","subscribeForm","validate","isPopup","seconds","isNaN","formCode","result","visitNo","originalDate","diffDays","GovNews","newsListing","searchInput","yearFilter","sortBy","newsType","newsTopic","clearButton","setEvents","setData","DoSearch","ClearSearch","urlParams","selectedYear","selectedSort","searchText","selectedType","selectedTopic","yearsList","jsonYears","selected","topic","_urlParams$get","_urlParams$get2","_urlParams$get3","_urlParams$get4","_urlParams$get5","searchString","selectedSearch","_searchInput$value","_sortBy$value","_newsType$value","_newsTopic$value","_yearFilter$value","path","segments","isNumeric","searchPath","substring","n","isFinite","ShareThisThreads","updateThreadsLink","currentTitle","title","encodedTitle","encodedUrl","updatedUrl","screenWidth","screen","screenHeight","windowHeight","windowFeatures","open","threads","svg4everybody"],"sources":["main.js"],"sourcesContent":["(function () {\n 'use strict';\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): util/index.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n const MILLISECONDS_MULTIPLIER = 1000;\r\n const TRANSITION_END = 'transitionend';\r\n\r\n // Shoutout AngusCroll (https://goo.gl/pxwQGp)\r\n const toType = obj => {\r\n if (obj === null || obj === undefined) {\r\n return `${obj}`\r\n }\r\n\r\n return {}.toString.call(obj).match(/\\s([a-z]+)/i)[1].toLowerCase()\r\n };\r\n\r\n const getSelector = element => {\r\n let selector = element.getAttribute('data-bs-target');\r\n\r\n if (!selector || selector === '#') {\r\n let hrefAttr = element.getAttribute('href');\r\n\r\n // The only valid content that could double as a selector are IDs or classes,\r\n // so everything starting with `#` or `.`. If a \"real\" URL is used as the selector,\r\n // `document.querySelector` will rightfully complain it is invalid.\r\n // See https://github.com/twbs/bootstrap/issues/32273\r\n if (!hrefAttr || (!hrefAttr.includes('#') && !hrefAttr.startsWith('.'))) {\r\n return null\r\n }\r\n\r\n // Just in case some CMS puts out a full URL with the anchor appended\r\n if (hrefAttr.includes('#') && !hrefAttr.startsWith('#')) {\r\n hrefAttr = `#${hrefAttr.split('#')[1]}`;\r\n }\r\n\r\n selector = hrefAttr && hrefAttr !== '#' ? hrefAttr.trim() : null;\r\n }\r\n\r\n return selector\r\n };\r\n\r\n const getElementFromSelector = element => {\r\n const selector = getSelector(element);\r\n\r\n return selector ? document.querySelector(selector) : null\r\n };\r\n\r\n const getTransitionDurationFromElement = element => {\r\n if (!element) {\r\n return 0\r\n }\r\n\r\n // Get transition-duration of the element\r\n let { transitionDuration, transitionDelay } = window.getComputedStyle(element);\r\n\r\n const floatTransitionDuration = Number.parseFloat(transitionDuration);\r\n const floatTransitionDelay = Number.parseFloat(transitionDelay);\r\n\r\n // Return 0 if element or transition duration is not found\r\n if (!floatTransitionDuration && !floatTransitionDelay) {\r\n return 0\r\n }\r\n\r\n // If multiple durations are defined, take the first\r\n transitionDuration = transitionDuration.split(',')[0];\r\n transitionDelay = transitionDelay.split(',')[0];\r\n\r\n return (Number.parseFloat(transitionDuration) + Number.parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER\r\n };\r\n\r\n const triggerTransitionEnd = element => {\r\n element.dispatchEvent(new Event(TRANSITION_END));\r\n };\r\n\r\n const isElement = obj => {\r\n if (!obj || typeof obj !== 'object') {\r\n return false\r\n }\r\n\r\n if (typeof obj.jquery !== 'undefined') {\r\n obj = obj[0];\r\n }\r\n\r\n return typeof obj.nodeType !== 'undefined'\r\n };\r\n\r\n const getElement = obj => {\r\n if (isElement(obj)) { // it's a jQuery object or a node element\r\n return obj.jquery ? obj[0] : obj\r\n }\r\n\r\n if (typeof obj === 'string' && obj.length > 0) {\r\n return document.querySelector(obj)\r\n }\r\n\r\n return null\r\n };\r\n\r\n const typeCheckConfig = (componentName, config, configTypes) => {\r\n Object.keys(configTypes).forEach(property => {\r\n const expectedTypes = configTypes[property];\r\n const value = config[property];\r\n const valueType = value && isElement(value) ? 'element' : toType(value);\r\n\r\n if (!new RegExp(expectedTypes).test(valueType)) {\r\n throw new TypeError(\r\n `${componentName.toUpperCase()}: Option \"${property}\" provided type \"${valueType}\" but expected type \"${expectedTypes}\".`\r\n )\r\n }\r\n });\r\n };\r\n\r\n const isVisible = element => {\r\n if (!isElement(element) || element.getClientRects().length === 0) {\r\n return false\r\n }\r\n\r\n return getComputedStyle(element).getPropertyValue('visibility') === 'visible'\r\n };\r\n\r\n const isDisabled = element => {\r\n if (!element || element.nodeType !== Node.ELEMENT_NODE) {\r\n return true\r\n }\r\n\r\n if (element.classList.contains('disabled')) {\r\n return true\r\n }\r\n\r\n if (typeof element.disabled !== 'undefined') {\r\n return element.disabled\r\n }\r\n\r\n return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false'\r\n };\r\n\r\n /**\r\n * Trick to restart an element's animation\r\n *\r\n * @param {HTMLElement} element\r\n * @return void\r\n *\r\n * @see https://www.charistheo.io/blog/2021/02/restart-a-css-animation-with-javascript/#restarting-a-css-animation\r\n */\r\n const reflow = element => {\r\n // eslint-disable-next-line no-unused-expressions\r\n element.offsetHeight;\r\n };\r\n\r\n const getjQuery = () => {\r\n const { jQuery } = window;\r\n\r\n if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) {\r\n return jQuery\r\n }\r\n\r\n return null\r\n };\r\n\r\n const DOMContentLoadedCallbacks = [];\r\n\r\n const onDOMContentLoaded = callback => {\r\n if (document.readyState === 'loading') {\r\n // add listener on the first call when the document is in loading state\r\n if (!DOMContentLoadedCallbacks.length) {\r\n document.addEventListener('DOMContentLoaded', () => {\r\n DOMContentLoadedCallbacks.forEach(callback => callback());\r\n });\r\n }\r\n\r\n DOMContentLoadedCallbacks.push(callback);\r\n } else {\r\n callback();\r\n }\r\n };\r\n\r\n const isRTL = () => document.documentElement.dir === 'rtl';\r\n\r\n const defineJQueryPlugin = plugin => {\r\n onDOMContentLoaded(() => {\r\n const $ = getjQuery();\r\n /* istanbul ignore if */\r\n if ($) {\r\n const name = plugin.NAME;\r\n const JQUERY_NO_CONFLICT = $.fn[name];\r\n $.fn[name] = plugin.jQueryInterface;\r\n $.fn[name].Constructor = plugin;\r\n $.fn[name].noConflict = () => {\r\n $.fn[name] = JQUERY_NO_CONFLICT;\r\n return plugin.jQueryInterface\r\n };\r\n }\r\n });\r\n };\r\n\r\n const execute = callback => {\r\n if (typeof callback === 'function') {\r\n callback();\r\n }\r\n };\r\n\r\n const executeAfterTransition = (callback, transitionElement, waitForTransition = true) => {\r\n if (!waitForTransition) {\r\n execute(callback);\r\n return\r\n }\r\n\r\n const durationPadding = 5;\r\n const emulatedDuration = getTransitionDurationFromElement(transitionElement) + durationPadding;\r\n\r\n let called = false;\r\n\r\n const handler = ({ target }) => {\r\n if (target !== transitionElement) {\r\n return\r\n }\r\n\r\n called = true;\r\n transitionElement.removeEventListener(TRANSITION_END, handler);\r\n execute(callback);\r\n };\r\n\r\n transitionElement.addEventListener(TRANSITION_END, handler);\r\n setTimeout(() => {\r\n if (!called) {\r\n triggerTransitionEnd(transitionElement);\r\n }\r\n }, emulatedDuration);\r\n };\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): dom/event-handler.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Constants\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n const namespaceRegex = /[^.]*(?=\\..*)\\.|.*/;\r\n const stripNameRegex = /\\..*/;\r\n const stripUidRegex = /::\\d+$/;\r\n const eventRegistry = {}; // Events storage\r\n let uidEvent = 1;\r\n const customEvents = {\r\n mouseenter: 'mouseover',\r\n mouseleave: 'mouseout'\r\n };\r\n const customEventsRegex = /^(mouseenter|mouseleave)/i;\r\n const nativeEvents = new Set([\r\n 'click',\r\n 'dblclick',\r\n 'mouseup',\r\n 'mousedown',\r\n 'contextmenu',\r\n 'mousewheel',\r\n 'DOMMouseScroll',\r\n 'mouseover',\r\n 'mouseout',\r\n 'mousemove',\r\n 'selectstart',\r\n 'selectend',\r\n 'keydown',\r\n 'keypress',\r\n 'keyup',\r\n 'orientationchange',\r\n 'touchstart',\r\n 'touchmove',\r\n 'touchend',\r\n 'touchcancel',\r\n 'pointerdown',\r\n 'pointermove',\r\n 'pointerup',\r\n 'pointerleave',\r\n 'pointercancel',\r\n 'gesturestart',\r\n 'gesturechange',\r\n 'gestureend',\r\n 'focus',\r\n 'blur',\r\n 'change',\r\n 'reset',\r\n 'select',\r\n 'submit',\r\n 'focusin',\r\n 'focusout',\r\n 'load',\r\n 'unload',\r\n 'beforeunload',\r\n 'resize',\r\n 'move',\r\n 'DOMContentLoaded',\r\n 'readystatechange',\r\n 'error',\r\n 'abort',\r\n 'scroll'\r\n ]);\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Private methods\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n function getUidEvent(element, uid) {\r\n return (uid && `${uid}::${uidEvent++}`) || element.uidEvent || uidEvent++\r\n }\r\n\r\n function getEvent(element) {\r\n const uid = getUidEvent(element);\r\n\r\n element.uidEvent = uid;\r\n eventRegistry[uid] = eventRegistry[uid] || {};\r\n\r\n return eventRegistry[uid]\r\n }\r\n\r\n function bootstrapHandler(element, fn) {\r\n return function handler(event) {\r\n event.delegateTarget = element;\r\n\r\n if (handler.oneOff) {\r\n EventHandler.off(element, event.type, fn);\r\n }\r\n\r\n return fn.apply(element, [event])\r\n }\r\n }\r\n\r\n function bootstrapDelegationHandler(element, selector, fn) {\r\n return function handler(event) {\r\n const domElements = element.querySelectorAll(selector);\r\n\r\n for (let { target } = event; target && target !== this; target = target.parentNode) {\r\n for (let i = domElements.length; i--;) {\r\n if (domElements[i] === target) {\r\n event.delegateTarget = target;\r\n\r\n if (handler.oneOff) {\r\n EventHandler.off(element, event.type, selector, fn);\r\n }\r\n\r\n return fn.apply(target, [event])\r\n }\r\n }\r\n }\r\n\r\n // To please ESLint\r\n return null\r\n }\r\n }\r\n\r\n function findHandler(events, handler, delegationSelector = null) {\r\n const uidEventList = Object.keys(events);\r\n\r\n for (let i = 0, len = uidEventList.length; i < len; i++) {\r\n const event = events[uidEventList[i]];\r\n\r\n if (event.originalHandler === handler && event.delegationSelector === delegationSelector) {\r\n return event\r\n }\r\n }\r\n\r\n return null\r\n }\r\n\r\n function normalizeParams(originalTypeEvent, handler, delegationFn) {\r\n const delegation = typeof handler === 'string';\r\n const originalHandler = delegation ? delegationFn : handler;\r\n\r\n let typeEvent = getTypeEvent(originalTypeEvent);\r\n const isNative = nativeEvents.has(typeEvent);\r\n\r\n if (!isNative) {\r\n typeEvent = originalTypeEvent;\r\n }\r\n\r\n return [delegation, originalHandler, typeEvent]\r\n }\r\n\r\n function addHandler(element, originalTypeEvent, handler, delegationFn, oneOff) {\r\n if (typeof originalTypeEvent !== 'string' || !element) {\r\n return\r\n }\r\n\r\n if (!handler) {\r\n handler = delegationFn;\r\n delegationFn = null;\r\n }\r\n\r\n // in case of mouseenter or mouseleave wrap the handler within a function that checks for its DOM position\r\n // this prevents the handler from being dispatched the same way as mouseover or mouseout does\r\n if (customEventsRegex.test(originalTypeEvent)) {\r\n const wrapFn = fn => {\r\n return function (event) {\r\n if (!event.relatedTarget || (event.relatedTarget !== event.delegateTarget && !event.delegateTarget.contains(event.relatedTarget))) {\r\n return fn.call(this, event)\r\n }\r\n }\r\n };\r\n\r\n if (delegationFn) {\r\n delegationFn = wrapFn(delegationFn);\r\n } else {\r\n handler = wrapFn(handler);\r\n }\r\n }\r\n\r\n const [delegation, originalHandler, typeEvent] = normalizeParams(originalTypeEvent, handler, delegationFn);\r\n const events = getEvent(element);\r\n const handlers = events[typeEvent] || (events[typeEvent] = {});\r\n const previousFn = findHandler(handlers, originalHandler, delegation ? handler : null);\r\n\r\n if (previousFn) {\r\n previousFn.oneOff = previousFn.oneOff && oneOff;\r\n\r\n return\r\n }\r\n\r\n const uid = getUidEvent(originalHandler, originalTypeEvent.replace(namespaceRegex, ''));\r\n const fn = delegation ?\r\n bootstrapDelegationHandler(element, handler, delegationFn) :\r\n bootstrapHandler(element, handler);\r\n\r\n fn.delegationSelector = delegation ? handler : null;\r\n fn.originalHandler = originalHandler;\r\n fn.oneOff = oneOff;\r\n fn.uidEvent = uid;\r\n handlers[uid] = fn;\r\n\r\n element.addEventListener(typeEvent, fn, delegation);\r\n }\r\n\r\n function removeHandler(element, events, typeEvent, handler, delegationSelector) {\r\n const fn = findHandler(events[typeEvent], handler, delegationSelector);\r\n\r\n if (!fn) {\r\n return\r\n }\r\n\r\n element.removeEventListener(typeEvent, fn, Boolean(delegationSelector));\r\n delete events[typeEvent][fn.uidEvent];\r\n }\r\n\r\n function removeNamespacedHandlers(element, events, typeEvent, namespace) {\r\n const storeElementEvent = events[typeEvent] || {};\r\n\r\n Object.keys(storeElementEvent).forEach(handlerKey => {\r\n if (handlerKey.includes(namespace)) {\r\n const event = storeElementEvent[handlerKey];\r\n\r\n removeHandler(element, events, typeEvent, event.originalHandler, event.delegationSelector);\r\n }\r\n });\r\n }\r\n\r\n function getTypeEvent(event) {\r\n // allow to get the native events from namespaced events ('click.bs.button' --> 'click')\r\n event = event.replace(stripNameRegex, '');\r\n return customEvents[event] || event\r\n }\r\n\r\n const EventHandler = {\r\n on(element, event, handler, delegationFn) {\r\n addHandler(element, event, handler, delegationFn, false);\r\n },\r\n\r\n one(element, event, handler, delegationFn) {\r\n addHandler(element, event, handler, delegationFn, true);\r\n },\r\n\r\n off(element, originalTypeEvent, handler, delegationFn) {\r\n if (typeof originalTypeEvent !== 'string' || !element) {\r\n return\r\n }\r\n\r\n const [delegation, originalHandler, typeEvent] = normalizeParams(originalTypeEvent, handler, delegationFn);\r\n const inNamespace = typeEvent !== originalTypeEvent;\r\n const events = getEvent(element);\r\n const isNamespace = originalTypeEvent.startsWith('.');\r\n\r\n if (typeof originalHandler !== 'undefined') {\r\n // Simplest case: handler is passed, remove that listener ONLY.\r\n if (!events || !events[typeEvent]) {\r\n return\r\n }\r\n\r\n removeHandler(element, events, typeEvent, originalHandler, delegation ? handler : null);\r\n return\r\n }\r\n\r\n if (isNamespace) {\r\n Object.keys(events).forEach(elementEvent => {\r\n removeNamespacedHandlers(element, events, elementEvent, originalTypeEvent.slice(1));\r\n });\r\n }\r\n\r\n const storeElementEvent = events[typeEvent] || {};\r\n Object.keys(storeElementEvent).forEach(keyHandlers => {\r\n const handlerKey = keyHandlers.replace(stripUidRegex, '');\r\n\r\n if (!inNamespace || originalTypeEvent.includes(handlerKey)) {\r\n const event = storeElementEvent[keyHandlers];\r\n\r\n removeHandler(element, events, typeEvent, event.originalHandler, event.delegationSelector);\r\n }\r\n });\r\n },\r\n\r\n trigger(element, event, args) {\r\n if (typeof event !== 'string' || !element) {\r\n return null\r\n }\r\n\r\n const $ = getjQuery();\r\n const typeEvent = getTypeEvent(event);\r\n const inNamespace = event !== typeEvent;\r\n const isNative = nativeEvents.has(typeEvent);\r\n\r\n let jQueryEvent;\r\n let bubbles = true;\r\n let nativeDispatch = true;\r\n let defaultPrevented = false;\r\n let evt = null;\r\n\r\n if (inNamespace && $) {\r\n jQueryEvent = $.Event(event, args);\r\n\r\n $(element).trigger(jQueryEvent);\r\n bubbles = !jQueryEvent.isPropagationStopped();\r\n nativeDispatch = !jQueryEvent.isImmediatePropagationStopped();\r\n defaultPrevented = jQueryEvent.isDefaultPrevented();\r\n }\r\n\r\n if (isNative) {\r\n evt = document.createEvent('HTMLEvents');\r\n evt.initEvent(typeEvent, bubbles, true);\r\n } else {\r\n evt = new CustomEvent(event, {\r\n bubbles,\r\n cancelable: true\r\n });\r\n }\r\n\r\n // merge custom information in our event\r\n if (typeof args !== 'undefined') {\r\n Object.keys(args).forEach(key => {\r\n Object.defineProperty(evt, key, {\r\n get() {\r\n return args[key]\r\n }\r\n });\r\n });\r\n }\r\n\r\n if (defaultPrevented) {\r\n evt.preventDefault();\r\n }\r\n\r\n if (nativeDispatch) {\r\n element.dispatchEvent(evt);\r\n }\r\n\r\n if (evt.defaultPrevented && typeof jQueryEvent !== 'undefined') {\r\n jQueryEvent.preventDefault();\r\n }\r\n\r\n return evt\r\n }\r\n };\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): dom/manipulator.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n function normalizeData(val) {\r\n if (val === 'true') {\r\n return true\r\n }\r\n\r\n if (val === 'false') {\r\n return false\r\n }\r\n\r\n if (val === Number(val).toString()) {\r\n return Number(val)\r\n }\r\n\r\n if (val === '' || val === 'null') {\r\n return null\r\n }\r\n\r\n return val\r\n }\r\n\r\n function normalizeDataKey(key) {\r\n return key.replace(/[A-Z]/g, chr => `-${chr.toLowerCase()}`)\r\n }\r\n\r\n const Manipulator = {\r\n setDataAttribute(element, key, value) {\r\n element.setAttribute(`data-bs-${normalizeDataKey(key)}`, value);\r\n },\r\n\r\n removeDataAttribute(element, key) {\r\n element.removeAttribute(`data-bs-${normalizeDataKey(key)}`);\r\n },\r\n\r\n getDataAttributes(element) {\r\n if (!element) {\r\n return {}\r\n }\r\n\r\n const attributes = {};\r\n\r\n Object.keys(element.dataset)\r\n .filter(key => key.startsWith('bs'))\r\n .forEach(key => {\r\n let pureKey = key.replace(/^bs/, '');\r\n pureKey = pureKey.charAt(0).toLowerCase() + pureKey.slice(1, pureKey.length);\r\n attributes[pureKey] = normalizeData(element.dataset[key]);\r\n });\r\n\r\n return attributes\r\n },\r\n\r\n getDataAttribute(element, key) {\r\n return normalizeData(element.getAttribute(`data-bs-${normalizeDataKey(key)}`))\r\n },\r\n\r\n offset(element) {\r\n const rect = element.getBoundingClientRect();\r\n\r\n return {\r\n top: rect.top + window.pageYOffset,\r\n left: rect.left + window.pageXOffset\r\n }\r\n },\r\n\r\n position(element) {\r\n return {\r\n top: element.offsetTop,\r\n left: element.offsetLeft\r\n }\r\n }\r\n };\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): dom/selector-engine.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n const NODE_TEXT = 3;\r\n\r\n const SelectorEngine = {\r\n find(selector, element = document.documentElement) {\r\n return [].concat(...Element.prototype.querySelectorAll.call(element, selector))\r\n },\r\n\r\n findOne(selector, element = document.documentElement) {\r\n return Element.prototype.querySelector.call(element, selector)\r\n },\r\n\r\n children(element, selector) {\r\n return [].concat(...element.children)\r\n .filter(child => child.matches(selector))\r\n },\r\n\r\n parents(element, selector) {\r\n const parents = [];\r\n\r\n let ancestor = element.parentNode;\r\n\r\n while (ancestor && ancestor.nodeType === Node.ELEMENT_NODE && ancestor.nodeType !== NODE_TEXT) {\r\n if (ancestor.matches(selector)) {\r\n parents.push(ancestor);\r\n }\r\n\r\n ancestor = ancestor.parentNode;\r\n }\r\n\r\n return parents\r\n },\r\n\r\n prev(element, selector) {\r\n let previous = element.previousElementSibling;\r\n\r\n while (previous) {\r\n if (previous.matches(selector)) {\r\n return [previous]\r\n }\r\n\r\n previous = previous.previousElementSibling;\r\n }\r\n\r\n return []\r\n },\r\n\r\n next(element, selector) {\r\n let next = element.nextElementSibling;\r\n\r\n while (next) {\r\n if (next.matches(selector)) {\r\n return [next]\r\n }\r\n\r\n next = next.nextElementSibling;\r\n }\r\n\r\n return []\r\n },\r\n\r\n focusableChildren(element) {\r\n const focusables = [\r\n 'a',\r\n 'button',\r\n 'input',\r\n 'textarea',\r\n 'select',\r\n 'details',\r\n '[tabindex]',\r\n '[contenteditable=\"true\"]'\r\n ].map(selector => `${selector}:not([tabindex^=\"-\"])`).join(', ');\r\n\r\n return this.find(focusables, element).filter(el => !isDisabled(el) && isVisible(el))\r\n }\r\n };\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): util/scrollBar.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n const SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top';\r\n const SELECTOR_STICKY_CONTENT = '.sticky-top';\r\n\r\n class ScrollBarHelper {\r\n constructor() {\r\n this._element = document.body;\r\n }\r\n\r\n getWidth() {\r\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes\r\n const documentWidth = document.documentElement.clientWidth;\r\n return Math.abs(window.innerWidth - documentWidth)\r\n }\r\n\r\n hide() {\r\n const width = this.getWidth();\r\n this._disableOverFlow();\r\n // give padding to element to balance the hidden scrollbar width\r\n this._setElementAttributes(this._element, 'paddingRight', calculatedValue => calculatedValue + width);\r\n // trick: We adjust positive paddingRight and negative marginRight to sticky-top elements to keep showing fullwidth\r\n this._setElementAttributes(SELECTOR_FIXED_CONTENT, 'paddingRight', calculatedValue => calculatedValue + width);\r\n this._setElementAttributes(SELECTOR_STICKY_CONTENT, 'marginRight', calculatedValue => calculatedValue - width);\r\n }\r\n\r\n _disableOverFlow() {\r\n this._saveInitialAttribute(this._element, 'overflow');\r\n this._element.style.overflow = 'hidden';\r\n }\r\n\r\n _setElementAttributes(selector, styleProp, callback) {\r\n const scrollbarWidth = this.getWidth();\r\n const manipulationCallBack = element => {\r\n if (element !== this._element && window.innerWidth > element.clientWidth + scrollbarWidth) {\r\n return\r\n }\r\n\r\n this._saveInitialAttribute(element, styleProp);\r\n const calculatedValue = window.getComputedStyle(element)[styleProp];\r\n element.style[styleProp] = `${callback(Number.parseFloat(calculatedValue))}px`;\r\n };\r\n\r\n this._applyManipulationCallback(selector, manipulationCallBack);\r\n }\r\n\r\n reset() {\r\n this._resetElementAttributes(this._element, 'overflow');\r\n this._resetElementAttributes(this._element, 'paddingRight');\r\n this._resetElementAttributes(SELECTOR_FIXED_CONTENT, 'paddingRight');\r\n this._resetElementAttributes(SELECTOR_STICKY_CONTENT, 'marginRight');\r\n }\r\n\r\n _saveInitialAttribute(element, styleProp) {\r\n const actualValue = element.style[styleProp];\r\n if (actualValue) {\r\n Manipulator.setDataAttribute(element, styleProp, actualValue);\r\n }\r\n }\r\n\r\n _resetElementAttributes(selector, styleProp) {\r\n const manipulationCallBack = element => {\r\n const value = Manipulator.getDataAttribute(element, styleProp);\r\n if (typeof value === 'undefined') {\r\n element.style.removeProperty(styleProp);\r\n } else {\r\n Manipulator.removeDataAttribute(element, styleProp);\r\n element.style[styleProp] = value;\r\n }\r\n };\r\n\r\n this._applyManipulationCallback(selector, manipulationCallBack);\r\n }\r\n\r\n _applyManipulationCallback(selector, callBack) {\r\n if (isElement(selector)) {\r\n callBack(selector);\r\n } else {\r\n SelectorEngine.find(selector, this._element).forEach(callBack);\r\n }\r\n }\r\n\r\n isOverflowing() {\r\n return this.getWidth() > 0\r\n }\r\n }\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): dom/data.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Constants\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n const elementMap = new Map();\r\n\r\n var Data = {\r\n set(element, key, instance) {\r\n if (!elementMap.has(element)) {\r\n elementMap.set(element, new Map());\r\n }\r\n\r\n const instanceMap = elementMap.get(element);\r\n\r\n // make it clear we only want one instance per element\r\n // can be removed later when multiple key/instances are fine to be used\r\n if (!instanceMap.has(key) && instanceMap.size !== 0) {\r\n // eslint-disable-next-line no-console\r\n console.error(`Bootstrap doesn't allow more than one instance per element. Bound instance: ${Array.from(instanceMap.keys())[0]}.`);\r\n return\r\n }\r\n\r\n instanceMap.set(key, instance);\r\n },\r\n\r\n get(element, key) {\r\n if (elementMap.has(element)) {\r\n return elementMap.get(element).get(key) || null\r\n }\r\n\r\n return null\r\n },\r\n\r\n remove(element, key) {\r\n if (!elementMap.has(element)) {\r\n return\r\n }\r\n\r\n const instanceMap = elementMap.get(element);\r\n\r\n instanceMap.delete(key);\r\n\r\n // free up element references if there are no instances left for an element\r\n if (instanceMap.size === 0) {\r\n elementMap.delete(element);\r\n }\r\n }\r\n };\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): base-component.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Constants\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n const VERSION = '5.1.3';\r\n\r\n class BaseComponent {\r\n constructor(element) {\r\n element = getElement(element);\r\n\r\n if (!element) {\r\n return\r\n }\r\n\r\n this._element = element;\r\n Data.set(this._element, this.constructor.DATA_KEY, this);\r\n }\r\n\r\n dispose() {\r\n Data.remove(this._element, this.constructor.DATA_KEY);\r\n EventHandler.off(this._element, this.constructor.EVENT_KEY);\r\n\r\n Object.getOwnPropertyNames(this).forEach(propertyName => {\r\n this[propertyName] = null;\r\n });\r\n }\r\n\r\n _queueCallback(callback, element, isAnimated = true) {\r\n executeAfterTransition(callback, element, isAnimated);\r\n }\r\n\r\n /** Static */\r\n\r\n static getInstance(element) {\r\n return Data.get(getElement(element), this.DATA_KEY)\r\n }\r\n\r\n static getOrCreateInstance(element, config = {}) {\r\n return this.getInstance(element) || new this(element, typeof config === 'object' ? config : null)\r\n }\r\n\r\n static get VERSION() {\r\n return VERSION\r\n }\r\n\r\n static get NAME() {\r\n throw new Error('You have to implement the static method \"NAME\", for each component!')\r\n }\r\n\r\n static get DATA_KEY() {\r\n return `bs.${this.NAME}`\r\n }\r\n\r\n static get EVENT_KEY() {\r\n return `.${this.DATA_KEY}`\r\n }\r\n }\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): util/backdrop.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n const Default$2 = {\r\n className: 'modal-backdrop',\r\n isVisible: true, // if false, we use the backdrop helper without adding any element to the dom\r\n isAnimated: false,\r\n rootElement: 'body', // give the choice to place backdrop under different elements\r\n clickCallback: null\r\n };\r\n\r\n const DefaultType$2 = {\r\n className: 'string',\r\n isVisible: 'boolean',\r\n isAnimated: 'boolean',\r\n rootElement: '(element|string)',\r\n clickCallback: '(function|null)'\r\n };\r\n const NAME$3 = 'backdrop';\r\n const CLASS_NAME_FADE$2 = 'fade';\r\n const CLASS_NAME_SHOW$2 = 'show';\r\n\r\n const EVENT_MOUSEDOWN = `mousedown.bs.${NAME$3}`;\r\n\r\n class Backdrop {\r\n constructor(config) {\r\n this._config = this._getConfig(config);\r\n this._isAppended = false;\r\n this._element = null;\r\n }\r\n\r\n show(callback) {\r\n if (!this._config.isVisible) {\r\n execute(callback);\r\n return\r\n }\r\n\r\n this._append();\r\n\r\n if (this._config.isAnimated) {\r\n reflow(this._getElement());\r\n }\r\n\r\n this._getElement().classList.add(CLASS_NAME_SHOW$2);\r\n\r\n this._emulateAnimation(() => {\r\n execute(callback);\r\n });\r\n }\r\n\r\n hide(callback) {\r\n if (!this._config.isVisible) {\r\n execute(callback);\r\n return\r\n }\r\n\r\n this._getElement().classList.remove(CLASS_NAME_SHOW$2);\r\n\r\n this._emulateAnimation(() => {\r\n this.dispose();\r\n execute(callback);\r\n });\r\n }\r\n\r\n // Private\r\n\r\n _getElement() {\r\n if (!this._element) {\r\n const backdrop = document.createElement('div');\r\n backdrop.className = this._config.className;\r\n if (this._config.isAnimated) {\r\n backdrop.classList.add(CLASS_NAME_FADE$2);\r\n }\r\n\r\n this._element = backdrop;\r\n }\r\n\r\n return this._element\r\n }\r\n\r\n _getConfig(config) {\r\n config = {\r\n ...Default$2,\r\n ...(typeof config === 'object' ? config : {})\r\n };\r\n\r\n // use getElement() with the default \"body\" to get a fresh Element on each instantiation\r\n config.rootElement = getElement(config.rootElement);\r\n typeCheckConfig(NAME$3, config, DefaultType$2);\r\n return config\r\n }\r\n\r\n _append() {\r\n if (this._isAppended) {\r\n return\r\n }\r\n\r\n this._config.rootElement.append(this._getElement());\r\n\r\n EventHandler.on(this._getElement(), EVENT_MOUSEDOWN, () => {\r\n execute(this._config.clickCallback);\r\n });\r\n\r\n this._isAppended = true;\r\n }\r\n\r\n dispose() {\r\n if (!this._isAppended) {\r\n return\r\n }\r\n\r\n EventHandler.off(this._element, EVENT_MOUSEDOWN);\r\n\r\n this._element.remove();\r\n this._isAppended = false;\r\n }\r\n\r\n _emulateAnimation(callback) {\r\n executeAfterTransition(callback, this._getElement(), this._config.isAnimated);\r\n }\r\n }\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): util/focustrap.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n const Default$1 = {\r\n trapElement: null, // The element to trap focus inside of\r\n autofocus: true\r\n };\r\n\r\n const DefaultType$1 = {\r\n trapElement: 'element',\r\n autofocus: 'boolean'\r\n };\r\n\r\n const NAME$2 = 'focustrap';\r\n const DATA_KEY$2 = 'bs.focustrap';\r\n const EVENT_KEY$2 = `.${DATA_KEY$2}`;\r\n const EVENT_FOCUSIN = `focusin${EVENT_KEY$2}`;\r\n const EVENT_KEYDOWN_TAB = `keydown.tab${EVENT_KEY$2}`;\r\n\r\n const TAB_KEY = 'Tab';\r\n const TAB_NAV_FORWARD = 'forward';\r\n const TAB_NAV_BACKWARD = 'backward';\r\n\r\n class FocusTrap {\r\n constructor(config) {\r\n this._config = this._getConfig(config);\r\n this._isActive = false;\r\n this._lastTabNavDirection = null;\r\n }\r\n\r\n activate() {\r\n const { trapElement, autofocus } = this._config;\r\n\r\n if (this._isActive) {\r\n return\r\n }\r\n\r\n if (autofocus) {\r\n trapElement.focus();\r\n }\r\n\r\n EventHandler.off(document, EVENT_KEY$2); // guard against infinite focus loop\r\n EventHandler.on(document, EVENT_FOCUSIN, event => this._handleFocusin(event));\r\n EventHandler.on(document, EVENT_KEYDOWN_TAB, event => this._handleKeydown(event));\r\n\r\n this._isActive = true;\r\n }\r\n\r\n deactivate() {\r\n if (!this._isActive) {\r\n return\r\n }\r\n\r\n this._isActive = false;\r\n EventHandler.off(document, EVENT_KEY$2);\r\n }\r\n\r\n // Private\r\n\r\n _handleFocusin(event) {\r\n const { target } = event;\r\n const { trapElement } = this._config;\r\n\r\n if (target === document || target === trapElement || trapElement.contains(target)) {\r\n return\r\n }\r\n\r\n const elements = SelectorEngine.focusableChildren(trapElement);\r\n\r\n if (elements.length === 0) {\r\n trapElement.focus();\r\n } else if (this._lastTabNavDirection === TAB_NAV_BACKWARD) {\r\n elements[elements.length - 1].focus();\r\n } else {\r\n elements[0].focus();\r\n }\r\n }\r\n\r\n _handleKeydown(event) {\r\n if (event.key !== TAB_KEY) {\r\n return\r\n }\r\n\r\n this._lastTabNavDirection = event.shiftKey ? TAB_NAV_BACKWARD : TAB_NAV_FORWARD;\r\n }\r\n\r\n _getConfig(config) {\r\n config = {\r\n ...Default$1,\r\n ...(typeof config === 'object' ? config : {})\r\n };\r\n typeCheckConfig(NAME$2, config, DefaultType$1);\r\n return config\r\n }\r\n }\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): util/component-functions.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n const enableDismissTrigger = (component, method = 'hide') => {\r\n const clickEvent = `click.dismiss${component.EVENT_KEY}`;\r\n const name = component.NAME;\r\n\r\n EventHandler.on(document, clickEvent, `[data-bs-dismiss=\"${name}\"]`, function (event) {\r\n if (['A', 'AREA'].includes(this.tagName)) {\r\n event.preventDefault();\r\n }\r\n\r\n if (isDisabled(this)) {\r\n return\r\n }\r\n\r\n const target = getElementFromSelector(this) || this.closest(`.${name}`);\r\n const instance = component.getOrCreateInstance(target);\r\n\r\n // Method argument is left, for Alert and only, as it doesn't implement the 'hide' method\r\n instance[method]();\r\n });\r\n };\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): modal.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Constants\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n const NAME$1 = 'modal';\r\n const DATA_KEY$1 = 'bs.modal';\r\n const EVENT_KEY$1 = `.${DATA_KEY$1}`;\r\n const DATA_API_KEY$1 = '.data-api';\r\n const ESCAPE_KEY = 'Escape';\r\n\r\n const Default = {\r\n backdrop: true,\r\n keyboard: true,\r\n focus: true\r\n };\r\n\r\n const DefaultType = {\r\n backdrop: '(boolean|string)',\r\n keyboard: 'boolean',\r\n focus: 'boolean'\r\n };\r\n\r\n const EVENT_HIDE$1 = `hide${EVENT_KEY$1}`;\r\n const EVENT_HIDE_PREVENTED = `hidePrevented${EVENT_KEY$1}`;\r\n const EVENT_HIDDEN$1 = `hidden${EVENT_KEY$1}`;\r\n const EVENT_SHOW$1 = `show${EVENT_KEY$1}`;\r\n const EVENT_SHOWN$1 = `shown${EVENT_KEY$1}`;\r\n const EVENT_RESIZE = `resize${EVENT_KEY$1}`;\r\n const EVENT_CLICK_DISMISS = `click.dismiss${EVENT_KEY$1}`;\r\n const EVENT_KEYDOWN_DISMISS = `keydown.dismiss${EVENT_KEY$1}`;\r\n const EVENT_MOUSEUP_DISMISS = `mouseup.dismiss${EVENT_KEY$1}`;\r\n const EVENT_MOUSEDOWN_DISMISS = `mousedown.dismiss${EVENT_KEY$1}`;\r\n const EVENT_CLICK_DATA_API$1 = `click${EVENT_KEY$1}${DATA_API_KEY$1}`;\r\n\r\n const CLASS_NAME_OPEN = 'modal-open';\r\n const CLASS_NAME_FADE$1 = 'fade';\r\n const CLASS_NAME_SHOW$1 = 'show';\r\n const CLASS_NAME_STATIC = 'modal-static';\r\n\r\n const OPEN_SELECTOR = '.modal.show';\r\n const SELECTOR_DIALOG = '.modal-dialog';\r\n const SELECTOR_MODAL_BODY = '.modal-body';\r\n const SELECTOR_DATA_TOGGLE$1 = '[data-bs-toggle=\"modal\"]';\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Class Definition\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n class Modal extends BaseComponent {\r\n constructor(element, config) {\r\n super(element);\r\n\r\n this._config = this._getConfig(config);\r\n this._dialog = SelectorEngine.findOne(SELECTOR_DIALOG, this._element);\r\n this._backdrop = this._initializeBackDrop();\r\n this._focustrap = this._initializeFocusTrap();\r\n this._isShown = false;\r\n this._ignoreBackdropClick = false;\r\n this._isTransitioning = false;\r\n this._scrollBar = new ScrollBarHelper();\r\n }\r\n\r\n // Getters\r\n\r\n static get Default() {\r\n return Default\r\n }\r\n\r\n static get NAME() {\r\n return NAME$1\r\n }\r\n\r\n // Public\r\n\r\n toggle(relatedTarget) {\r\n return this._isShown ? this.hide() : this.show(relatedTarget)\r\n }\r\n\r\n show(relatedTarget) {\r\n if (this._isShown || this._isTransitioning) {\r\n return\r\n }\r\n\r\n const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$1, {\r\n relatedTarget\r\n });\r\n\r\n if (showEvent.defaultPrevented) {\r\n return\r\n }\r\n\r\n this._isShown = true;\r\n\r\n if (this._isAnimated()) {\r\n this._isTransitioning = true;\r\n }\r\n\r\n this._scrollBar.hide();\r\n\r\n document.body.classList.add(CLASS_NAME_OPEN);\r\n\r\n this._adjustDialog();\r\n\r\n this._setEscapeEvent();\r\n this._setResizeEvent();\r\n\r\n EventHandler.on(this._dialog, EVENT_MOUSEDOWN_DISMISS, () => {\r\n EventHandler.one(this._element, EVENT_MOUSEUP_DISMISS, event => {\r\n if (event.target === this._element) {\r\n this._ignoreBackdropClick = true;\r\n }\r\n });\r\n });\r\n\r\n this._showBackdrop(() => this._showElement(relatedTarget));\r\n }\r\n\r\n hide() {\r\n if (!this._isShown || this._isTransitioning) {\r\n return\r\n }\r\n\r\n const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$1);\r\n\r\n if (hideEvent.defaultPrevented) {\r\n return\r\n }\r\n\r\n this._isShown = false;\r\n const isAnimated = this._isAnimated();\r\n\r\n if (isAnimated) {\r\n this._isTransitioning = true;\r\n }\r\n\r\n this._setEscapeEvent();\r\n this._setResizeEvent();\r\n\r\n this._focustrap.deactivate();\r\n\r\n this._element.classList.remove(CLASS_NAME_SHOW$1);\r\n\r\n EventHandler.off(this._element, EVENT_CLICK_DISMISS);\r\n EventHandler.off(this._dialog, EVENT_MOUSEDOWN_DISMISS);\r\n\r\n this._queueCallback(() => this._hideModal(), this._element, isAnimated);\r\n }\r\n\r\n dispose() {\r\n [window, this._dialog]\r\n .forEach(htmlElement => EventHandler.off(htmlElement, EVENT_KEY$1));\r\n\r\n this._backdrop.dispose();\r\n this._focustrap.deactivate();\r\n super.dispose();\r\n }\r\n\r\n handleUpdate() {\r\n this._adjustDialog();\r\n }\r\n\r\n // Private\r\n\r\n _initializeBackDrop() {\r\n return new Backdrop({\r\n isVisible: Boolean(this._config.backdrop), // 'static' option will be translated to true, and booleans will keep their value\r\n isAnimated: this._isAnimated()\r\n })\r\n }\r\n\r\n _initializeFocusTrap() {\r\n return new FocusTrap({\r\n trapElement: this._element\r\n })\r\n }\r\n\r\n _getConfig(config) {\r\n config = {\r\n ...Default,\r\n ...Manipulator.getDataAttributes(this._element),\r\n ...(typeof config === 'object' ? config : {})\r\n };\r\n typeCheckConfig(NAME$1, config, DefaultType);\r\n return config\r\n }\r\n\r\n _showElement(relatedTarget) {\r\n const isAnimated = this._isAnimated();\r\n const modalBody = SelectorEngine.findOne(SELECTOR_MODAL_BODY, this._dialog);\r\n\r\n if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) {\r\n // Don't move modal's DOM position\r\n document.body.append(this._element);\r\n }\r\n\r\n this._element.style.display = 'block';\r\n this._element.removeAttribute('aria-hidden');\r\n this._element.setAttribute('aria-modal', true);\r\n this._element.setAttribute('role', 'dialog');\r\n this._element.scrollTop = 0;\r\n\r\n if (modalBody) {\r\n modalBody.scrollTop = 0;\r\n }\r\n\r\n if (isAnimated) {\r\n reflow(this._element);\r\n }\r\n\r\n this._element.classList.add(CLASS_NAME_SHOW$1);\r\n\r\n const transitionComplete = () => {\r\n if (this._config.focus) {\r\n this._focustrap.activate();\r\n }\r\n\r\n this._isTransitioning = false;\r\n EventHandler.trigger(this._element, EVENT_SHOWN$1, {\r\n relatedTarget\r\n });\r\n this._resetAndDisplayIframe(); \r\n };\r\n this._queueCallback(transitionComplete, this._dialog, isAnimated);\r\n }\r\n\r\n _resetAndDisplayIframe() {\r\n const iframe = this._element.querySelector('iframe');\r\n \r\n if (iframe && iframe.dataset.originalSrc) {\r\n iframe.src = iframe.dataset.originalSrc;\r\n }\r\n }\r\n _setEscapeEvent() {\r\n if (this._isShown) {\r\n EventHandler.on(this._element, EVENT_KEYDOWN_DISMISS, event => {\r\n if (this._config.keyboard && event.key === ESCAPE_KEY) {\r\n event.preventDefault();\r\n this.hide();\r\n } else if (!this._config.keyboard && event.key === ESCAPE_KEY) {\r\n this._triggerBackdropTransition();\r\n }\r\n });\r\n } else {\r\n EventHandler.off(this._element, EVENT_KEYDOWN_DISMISS);\r\n }\r\n }\r\n\r\n _setResizeEvent() {\r\n if (this._isShown) {\r\n EventHandler.on(window, EVENT_RESIZE, () => this._adjustDialog());\r\n } else {\r\n EventHandler.off(window, EVENT_RESIZE);\r\n }\r\n }\r\n\r\n _hideModal() {\r\n this._element.style.display = 'none';\r\n this._element.setAttribute('aria-hidden', true);\r\n this._element.removeAttribute('aria-modal');\r\n this._element.removeAttribute('role');\r\n this._isTransitioning = false;\r\n this._backdrop.hide(() => {\r\n document.body.classList.remove(CLASS_NAME_OPEN);\r\n this._resetAdjustments();\r\n this._scrollBar.reset();\r\n EventHandler.trigger(this._element, EVENT_HIDDEN$1);\r\n });\r\n this._hideVideoOnModalClose(); \r\n }\r\n\r\n _hideVideoOnModalClose() {\r\n const iframe = this._element.querySelector('iframe');\r\n \r\n if(iframe) {\r\n iframe.dataset.originalSrc = iframe.src;\r\n iframe.removeAttribute('src');\r\n }\r\n }\r\n\r\n _showBackdrop(callback) {\r\n EventHandler.on(this._element, EVENT_CLICK_DISMISS, event => {\r\n if (this._ignoreBackdropClick) {\r\n this._ignoreBackdropClick = false;\r\n return\r\n }\r\n\r\n if (event.target !== event.currentTarget) {\r\n return\r\n }\r\n\r\n if (this._config.backdrop === true) {\r\n this.hide();\r\n } else if (this._config.backdrop === 'static') {\r\n this._triggerBackdropTransition();\r\n }\r\n });\r\n\r\n this._backdrop.show(callback);\r\n }\r\n\r\n _isAnimated() {\r\n return this._element.classList.contains(CLASS_NAME_FADE$1)\r\n }\r\n\r\n _triggerBackdropTransition() {\r\n const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED);\r\n if (hideEvent.defaultPrevented) {\r\n return\r\n }\r\n\r\n const { classList, scrollHeight, style } = this._element;\r\n const isModalOverflowing = scrollHeight > document.documentElement.clientHeight;\r\n\r\n // return if the following background transition hasn't yet completed\r\n if ((!isModalOverflowing && style.overflowY === 'hidden') || classList.contains(CLASS_NAME_STATIC)) {\r\n return\r\n }\r\n\r\n if (!isModalOverflowing) {\r\n style.overflowY = 'hidden';\r\n }\r\n\r\n classList.add(CLASS_NAME_STATIC);\r\n this._queueCallback(() => {\r\n classList.remove(CLASS_NAME_STATIC);\r\n if (!isModalOverflowing) {\r\n this._queueCallback(() => {\r\n style.overflowY = '';\r\n }, this._dialog);\r\n }\r\n }, this._dialog);\r\n\r\n this._element.focus();\r\n }\r\n\r\n // ----------------------------------------------------------------------\r\n // the following methods are used to handle overflowing modals\r\n // ----------------------------------------------------------------------\r\n\r\n _adjustDialog() {\r\n const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;\r\n const scrollbarWidth = this._scrollBar.getWidth();\r\n const isBodyOverflowing = scrollbarWidth > 0;\r\n\r\n if ((!isBodyOverflowing && isModalOverflowing && !isRTL()) || (isBodyOverflowing && !isModalOverflowing && isRTL())) {\r\n this._element.style.paddingLeft = `${scrollbarWidth}px`;\r\n }\r\n\r\n if ((isBodyOverflowing && !isModalOverflowing && !isRTL()) || (!isBodyOverflowing && isModalOverflowing && isRTL())) {\r\n this._element.style.paddingRight = `${scrollbarWidth}px`;\r\n }\r\n }\r\n\r\n _resetAdjustments() {\r\n this._element.style.paddingLeft = '';\r\n this._element.style.paddingRight = '';\r\n }\r\n\r\n // Static\r\n\r\n static jQueryInterface(config, relatedTarget) {\r\n return this.each(function () {\r\n const data = Modal.getOrCreateInstance(this, config);\r\n\r\n if (typeof config !== 'string') {\r\n return\r\n }\r\n\r\n if (typeof data[config] === 'undefined') {\r\n throw new TypeError(`No method named \"${config}\"`)\r\n }\r\n\r\n data[config](relatedTarget);\r\n })\r\n }\r\n }\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Data Api implementation\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n EventHandler.on(document, EVENT_CLICK_DATA_API$1, SELECTOR_DATA_TOGGLE$1, function (event) {\r\n const target = getElementFromSelector(this);\r\n\r\n if (['A', 'AREA'].includes(this.tagName)) {\r\n event.preventDefault();\r\n }\r\n\r\n EventHandler.one(target, EVENT_SHOW$1, showEvent => {\r\n if (showEvent.defaultPrevented) {\r\n // only register focus restorer if modal will actually get shown\r\n return\r\n }\r\n\r\n EventHandler.one(target, EVENT_HIDDEN$1, () => {\r\n if (isVisible(this)) {\r\n this.focus();\r\n }\r\n });\r\n });\r\n\r\n // avoid conflict when clicking modal toggler while another one is open\r\n const allReadyOpen = SelectorEngine.findOne(OPEN_SELECTOR);\r\n if (allReadyOpen) {\r\n Modal.getInstance(allReadyOpen).hide();\r\n }\r\n\r\n const data = Modal.getOrCreateInstance(target);\r\n\r\n data.toggle(this);\r\n });\r\n\r\n enableDismissTrigger(Modal);\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * jQuery\r\n * ------------------------------------------------------------------------\r\n * add .Modal to jQuery only if jQuery is present\r\n */\r\n\r\n defineJQueryPlugin(Modal);\n\n /**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap (v5.1.3): tab.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Constants\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n const NAME = 'tab';\r\n const DATA_KEY = 'bs.tab';\r\n const EVENT_KEY = `.${DATA_KEY}`;\r\n const DATA_API_KEY = '.data-api';\r\n\r\n const EVENT_HIDE = `hide${EVENT_KEY}`;\r\n const EVENT_HIDDEN = `hidden${EVENT_KEY}`;\r\n const EVENT_SHOW = `show${EVENT_KEY}`;\r\n const EVENT_SHOWN = `shown${EVENT_KEY}`;\r\n const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`;\r\n\r\n const CLASS_NAME_DROPDOWN_MENU = 'dropdown-menu';\r\n const CLASS_NAME_ACTIVE = 'active';\r\n const CLASS_NAME_FADE = 'fade';\r\n const CLASS_NAME_SHOW = 'show';\r\n\r\n const SELECTOR_DROPDOWN = '.dropdown';\r\n const SELECTOR_NAV_LIST_GROUP = '.nav, .list-group';\r\n const SELECTOR_ACTIVE = '.active';\r\n const SELECTOR_ACTIVE_UL = ':scope > li > .active';\r\n const SELECTOR_DATA_TOGGLE = '[data-bs-toggle=\"tab\"], [data-bs-toggle=\"pill\"], [data-bs-toggle=\"list\"]';\r\n const SELECTOR_DROPDOWN_TOGGLE = '.dropdown-toggle';\r\n const SELECTOR_DROPDOWN_ACTIVE_CHILD = ':scope > .dropdown-menu .active';\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Class Definition\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n class Tab extends BaseComponent {\r\n // Getters\r\n\r\n static get NAME() {\r\n return NAME\r\n }\r\n\r\n // Public\r\n\r\n show() {\r\n if ((this._element.parentNode &&\r\n this._element.parentNode.nodeType === Node.ELEMENT_NODE &&\r\n this._element.classList.contains(CLASS_NAME_ACTIVE))) {\r\n return\r\n }\r\n\r\n let previous;\r\n const target = getElementFromSelector(this._element);\r\n const listElement = this._element.closest(SELECTOR_NAV_LIST_GROUP);\r\n\r\n if (listElement) {\r\n const itemSelector = listElement.nodeName === 'UL' || listElement.nodeName === 'OL' ? SELECTOR_ACTIVE_UL : SELECTOR_ACTIVE;\r\n previous = SelectorEngine.find(itemSelector, listElement);\r\n previous = previous[previous.length - 1];\r\n }\r\n\r\n const hideEvent = previous ?\r\n EventHandler.trigger(previous, EVENT_HIDE, {\r\n relatedTarget: this._element\r\n }) :\r\n null;\r\n\r\n const showEvent = EventHandler.trigger(this._element, EVENT_SHOW, {\r\n relatedTarget: previous\r\n });\r\n\r\n if (showEvent.defaultPrevented || (hideEvent !== null && hideEvent.defaultPrevented)) {\r\n return\r\n }\r\n\r\n this._activate(this._element, listElement);\r\n\r\n const complete = () => {\r\n EventHandler.trigger(previous, EVENT_HIDDEN, {\r\n relatedTarget: this._element\r\n });\r\n EventHandler.trigger(this._element, EVENT_SHOWN, {\r\n relatedTarget: previous\r\n });\r\n };\r\n\r\n if (target) {\r\n this._activate(target, target.parentNode, complete);\r\n } else {\r\n complete();\r\n }\r\n }\r\n\r\n // Private\r\n\r\n _activate(element, container, callback) {\r\n const activeElements = container && (container.nodeName === 'UL' || container.nodeName === 'OL') ?\r\n SelectorEngine.find(SELECTOR_ACTIVE_UL, container) :\r\n SelectorEngine.children(container, SELECTOR_ACTIVE);\r\n\r\n const active = activeElements[0];\r\n const isTransitioning = callback && (active && active.classList.contains(CLASS_NAME_FADE));\r\n\r\n const complete = () => this._transitionComplete(element, active, callback);\r\n\r\n if (active && isTransitioning) {\r\n active.classList.remove(CLASS_NAME_SHOW);\r\n this._queueCallback(complete, element, true);\r\n } else {\r\n complete();\r\n }\r\n }\r\n\r\n _transitionComplete(element, active, callback) {\r\n if (active) {\r\n active.classList.remove(CLASS_NAME_ACTIVE);\r\n\r\n const dropdownChild = SelectorEngine.findOne(SELECTOR_DROPDOWN_ACTIVE_CHILD, active.parentNode);\r\n\r\n if (dropdownChild) {\r\n dropdownChild.classList.remove(CLASS_NAME_ACTIVE);\r\n }\r\n\r\n if (active.getAttribute('role') === 'tab') {\r\n active.setAttribute('aria-selected', false);\r\n }\r\n }\r\n\r\n element.classList.add(CLASS_NAME_ACTIVE);\r\n if (element.getAttribute('role') === 'tab') {\r\n element.setAttribute('aria-selected', true);\r\n }\r\n\r\n reflow(element);\r\n\r\n if (element.classList.contains(CLASS_NAME_FADE)) {\r\n element.classList.add(CLASS_NAME_SHOW);\r\n }\r\n\r\n let parent = element.parentNode;\r\n if (parent && parent.nodeName === 'LI') {\r\n parent = parent.parentNode;\r\n }\r\n\r\n if (parent && parent.classList.contains(CLASS_NAME_DROPDOWN_MENU)) {\r\n const dropdownElement = element.closest(SELECTOR_DROPDOWN);\r\n\r\n if (dropdownElement) {\r\n SelectorEngine.find(SELECTOR_DROPDOWN_TOGGLE, dropdownElement)\r\n .forEach(dropdown => dropdown.classList.add(CLASS_NAME_ACTIVE));\r\n }\r\n\r\n element.setAttribute('aria-expanded', true);\r\n }\r\n\r\n if (callback) {\r\n callback();\r\n }\r\n }\r\n\r\n // Static\r\n\r\n static jQueryInterface(config) {\r\n return this.each(function () {\r\n const data = Tab.getOrCreateInstance(this);\r\n\r\n if (typeof config === 'string') {\r\n if (typeof data[config] === 'undefined') {\r\n throw new TypeError(`No method named \"${config}\"`)\r\n }\r\n\r\n data[config]();\r\n }\r\n })\r\n }\r\n }\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * Data Api implementation\r\n * ------------------------------------------------------------------------\r\n */\r\n\r\n EventHandler.on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {\r\n if (['A', 'AREA'].includes(this.tagName)) {\r\n event.preventDefault();\r\n }\r\n\r\n if (isDisabled(this)) {\r\n return\r\n }\r\n\r\n const data = Tab.getOrCreateInstance(this);\r\n data.show();\r\n });\r\n\r\n /**\r\n * ------------------------------------------------------------------------\r\n * jQuery\r\n * ------------------------------------------------------------------------\r\n * add .Tab to jQuery only if jQuery is present\r\n */\r\n\r\n defineJQueryPlugin(Tab);\n\n class Accordion {\r\n static main() {\r\n const bodyClass = document.querySelector('body').classList;\r\n const isGov = bodyClass.contains('gov') ? true : false;\r\n\r\n const accordions = document.querySelectorAll('.accordion-trigger');\r\n if (accordions) {\r\n init();\r\n }\r\n\r\n function init() {\r\n accordions.forEach((accordion) => {\r\n accordion.addEventListener('click', toggleAccordion); \r\n }); \r\n }\r\n\r\n function toggleAccordion(e) {\r\n e.preventDefault();\r\n const accordionItem = e.target.closest('.accordion'); \r\n const toggle = e.currentTarget; \r\n\r\n if (!accordionItem.classList.contains('open')) {\r\n accordionItem.classList.add('open');\r\n toggle.setAttribute('aria-expanded', true);\r\n\r\n // Gov uses + and - icons, not chevrons like Microsites\r\n if (isGov) {\r\n const toggleIcon = e.currentTarget.querySelector('.accordion-icon svg use');\r\n if (toggleIcon) {\r\n let iconHref = toggleIcon.getAttribute('href').replace(/\\#.*/, '#accordion-minus');\r\n toggleIcon.setAttribute('href', iconHref);\r\n }\r\n }\r\n }\r\n else {\r\n accordionItem.classList.remove('open');\r\n toggle.setAttribute('aria-expanded', false); \r\n toggle.blur();\r\n\r\n // Gov uses + and - circles, not chevrons like Microsites\r\n if (isGov) {\r\n const toggleIcon = e.currentTarget.querySelector('.accordion-icon svg use');\r\n if (toggleIcon) {\r\n let iconHref = toggleIcon.getAttribute('href').replace(/\\#.*/, '#accordion-plus');\r\n toggleIcon.setAttribute('href', iconHref);\r\n }\r\n }\r\n }\r\n }\r\n\r\n // function updateAccordionScrollbar() {\r\n // accordions.forEach((accordion) => {\r\n // const content = accordion.querySelector('.accordion-content');\r\n // if (content.scrollHeight > accordion.clientHeight) {\r\n // accordion.style.overflowY = 'scroll';\r\n // } else {\r\n // accordion.style.overflowY = 'hidden';\r\n // }\r\n // });\r\n // }\r\n }\r\n }\n\n class Alerts {\r\n static main() {\r\n\r\n init();\r\n\r\n function init() { \r\n const alertCloseBtns = document.querySelectorAll('.alert .js-close-alert');\r\n \r\n if (alertCloseBtns) {\r\n shouldRender();\r\n\r\n alertCloseBtns.forEach((closeBtn) => {\r\n closeBtn.addEventListener('click', closeAlert);\r\n });\r\n }\r\n }\r\n\r\n // check sessionStorage if alert has been closed or not already\r\n function shouldRender() {{\r\n const alerts = document.querySelectorAll('.alert');\r\n\r\n alerts.forEach((alert) => {\r\n const alertId = alert.getAttribute('id');\r\n const shouldRender = sessionStorage.getItem('alert-'+alertId) !== \"dismissed\";\r\n\r\n if (shouldRender) {\r\n alert.classList.add('show');\r\n }\r\n });\r\n }}\r\n\r\n function closeAlert(e) {\r\n e.preventDefault();\r\n const alertId = e.target.closest('.alert').getAttribute('id');\r\n \r\n sessionStorage.setItem('alert-' + alertId, \"dismissed\");\r\n document.getElementById(alertId).classList.remove('show');\r\n }\r\n }\r\n }\n\n /*\r\n We start by selecting all elements with the class counter and setting up an IntersectionObserver to watch for when they become visible in the viewport.\r\n\r\n When a counter element becomes visible, we call the animateCounter function to start animating the counter from the start value to the end value in increments of the step value.\r\n\r\n The animateCounter function uses a setInterval timer to increment the current value of the counter and update its text content every 5 milliseconds. Once the current value reaches the end value, the timer is cleared and the counter text content is set to the final value.\r\n\r\n */\r\n class AnimatedStat {\r\n static main() {\r\n const counters = document.querySelectorAll('.animated-stat');\r\n const options = {\r\n rootMargin: '0px',\r\n threshold: 0.5\r\n };\r\n\r\n const observer = new IntersectionObserver(function(entries, observer) {\r\n entries.forEach(entry => {\r\n if (entry.isIntersecting) {\r\n animateCounter(entry.target);\r\n observer.unobserve(entry.target);\r\n }\r\n });\r\n }, options);\r\n\r\n counters.forEach(counter => {\r\n observer.observe(counter);\r\n });\r\n\r\n function animateCounter(counter) {\r\n const counterHTML = counter.querySelector('.counter-num');\r\n const start = Number(counter.getAttribute('data-start'));\r\n const end = Number(counter.getAttribute('data-end'));\r\n const step = Number(counter.getAttribute('data-step'));\r\n let current = start;\r\n\r\n const timer = setInterval(() => {\r\n current += step;\r\n counterHTML.innerHTML = current;\r\n if (current >= end) {\r\n counterHTML.innerHTML = end;\r\n clearInterval(timer);\r\n }\r\n }, 5);\r\n }\r\n }\r\n }\n\n class BlogCards {\r\n static main() {\r\n let years = new Set();\r\n let categories = new Set();\r\n let categories2 = new Set();\r\n let categories3 = new Set();\r\n\r\n let activeCategory = \"all\";\r\n let activeCategory2 = \"all\";\r\n let activeCategory3 = \"all\";\r\n let activeYear = \"all\";\r\n let activeSort = \"all\";\r\n let searchTerm = null;\r\n let currentPage = 1;\r\n let index = {\r\n firstIndex: 0,\r\n lastIndex: 9\r\n };\r\n \r\n const cardLinks = document.querySelectorAll('.blog-widget .kdx-card a, .event-widget .kdx-card a, .blog-listing .kdx-card a, .event-listing .kdx-card a');\r\n const initCards = [...document.querySelectorAll('.blog-listing .listing.row > *')];\r\n \r\n let filtered = initCards;\r\n\r\n if (cardLinks.length) {\r\n init();\r\n }\r\n\r\n function setCategories(){\r\n initCards.forEach((card) => {\r\n const cardEl = card.querySelector(\".kdx-card\");\r\n const categoriesArr = JSON.parse(cardEl.getAttribute(\"data-categories\"));\r\n for(const category in categoriesArr){\r\n categories.add(categoriesArr[category]);\r\n }\r\n });\r\n const categorySelect = document.querySelector(\"#filter-by-category\");\r\n categories.forEach(category => {\r\n const categoryOption = document.createElement(\"option\");\r\n categoryOption.setAttribute(\"value\", category);\r\n categoryOption.innerText = category;\r\n categorySelect.appendChild(categoryOption);\r\n });\r\n }\r\n\r\n function setCategories2(){\r\n initCards.forEach((card) => {\r\n const cardEl = card.querySelector(\".kdx-card\");\r\n const categoriesArr = JSON.parse(cardEl.getAttribute(\"data-categories-2\"));\r\n for(const category in categoriesArr){\r\n categories2.add(categoriesArr[category]);\r\n }\r\n });\r\n const categorySelect = document.querySelector(\"#filter-by-category-2\");\r\n categories2.forEach(category => {\r\n const categoryOption = document.createElement(\"option\");\r\n categoryOption.setAttribute(\"value\", category);\r\n categoryOption.innerText = category;\r\n categorySelect.appendChild(categoryOption);\r\n });\r\n }\r\n\r\n function setCategories3(){\r\n initCards.forEach((card) => {\r\n const cardEl = card.querySelector(\".kdx-card\");\r\n const categoriesArr = JSON.parse(cardEl.getAttribute(\"data-categories-3\"));\r\n for(const category in categoriesArr){\r\n categories3.add(categoriesArr[category]);\r\n }\r\n });\r\n const categorySelect = document.querySelector(\"#filter-by-category-3\");\r\n categories3.forEach(category => {\r\n const categoryOption = document.createElement(\"option\");\r\n categoryOption.setAttribute(\"value\", category);\r\n categoryOption.innerText = category;\r\n categorySelect.appendChild(categoryOption);\r\n });\r\n }\r\n\r\n function setYears(){\r\n initCards.forEach((card) => {\r\n const cardEl = card.querySelector(\".kdx-card\");\r\n const cardContent = cardEl.querySelector(\".date\")?.textContent;\r\n cardContent !== null && cardContent !== undefined && years.add(cardContent.slice(-4));\r\n });\r\n const yearsSelect = document.querySelector(\"#filter-by-year\");\r\n years.forEach((year) => {\r\n const yearOption = document.createElement(\"option\");\r\n yearOption.setAttribute(\"value\", year);\r\n yearOption.innerText = year;\r\n yearsSelect.appendChild(yearOption);\r\n });\r\n }\r\n\r\n function handlePages(){\r\n //clear pages\r\n const list = document.querySelector(\".blog-listing .pagination ul\");\r\n if (list==null)\r\n {\r\n return;\r\n }\r\n\r\n Array.from(list.children).forEach((child) => {\r\n child.remove();\r\n });\r\n\r\n //Add prev and next buttons manually\r\n list.insertAdjacentHTML(\"afterbegin\", `