Comparing version 5.0.0-beta2 to 5.0.0-beta3
/*! | ||
* Bootstrap v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
*/ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(require("@popperjs/core")):"function"==typeof define&&define.amd?define(["@popperjs/core"],e):(t="undefined"!=typeof globalThis?globalThis:t||self).bootstrap=e(t.Popper)}(this,(function(t){"use strict";function e(t){if(t&&t.__esModule)return t;var e=Object.create(null);return t&&Object.keys(t).forEach((function(n){if("default"!==n){var i=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,i.get?i:{enumerable:!0,get:function(){return t[n]}})}})),e.default=t,Object.freeze(e)}var n=e(t);function i(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function o(t,e,n){return e&&i(t.prototype,e),n&&i(t,n),t}function s(){return(s=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var i in n)Object.prototype.hasOwnProperty.call(n,i)&&(t[i]=n[i])}return t}).apply(this,arguments)}function r(t,e){var n,i;t.prototype=Object.create(e.prototype),t.prototype.constructor=t,n=t,i=e,(Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(n,i)}var a,l,c=function(t){do{t+=Math.floor(1e6*Math.random())}while(document.getElementById(t));return t},u=function(t){var e=t.getAttribute("data-bs-target");if(!e||"#"===e){var n=t.getAttribute("href");if(!n||!n.includes("#")&&!n.startsWith("."))return null;n.includes("#")&&!n.startsWith("#")&&(n="#"+n.split("#")[1]),e=n&&"#"!==n?n.trim():null}return e},h=function(t){var e=u(t);return e&&document.querySelector(e)?e:null},d=function(t){var e=u(t);return e?document.querySelector(e):null},f=function(t){if(!t)return 0;var e=window.getComputedStyle(t),n=e.transitionDuration,i=e.transitionDelay,o=Number.parseFloat(n),s=Number.parseFloat(i);return o||s?(n=n.split(",")[0],i=i.split(",")[0],1e3*(Number.parseFloat(n)+Number.parseFloat(i))):0},p=function(t){t.dispatchEvent(new Event("transitionend"))},g=function(t){return(t[0]||t).nodeType},m=function(t,e){var n=!1,i=e+5;t.addEventListener("transitionend",(function e(){n=!0,t.removeEventListener("transitionend",e)})),setTimeout((function(){n||p(t)}),i)},_=function(t,e,n){Object.keys(n).forEach((function(i){var o,s=n[i],r=e[i],a=r&&g(r)?"element":null==(o=r)?""+o:{}.toString.call(o).match(/\s([a-z]+)/i)[1].toLowerCase();if(!new RegExp(s).test(a))throw new TypeError(t.toUpperCase()+': Option "'+i+'" provided type "'+a+'" but expected type "'+s+'".')}))},v=function(t){if(!t)return!1;if(t.style&&t.parentNode&&t.parentNode.style){var e=getComputedStyle(t),n=getComputedStyle(t.parentNode);return"none"!==e.display&&"none"!==n.display&&"hidden"!==e.visibility}return!1},b=function(){return function(){}},y=function(t){return t.offsetHeight},w=function(){var t=window.jQuery;return t&&!document.body.hasAttribute("data-bs-no-jquery")?t:null},E="rtl"===document.documentElement.dir,T=function(t,e){var n;n=function(){var n=w();if(n){var i=n.fn[t];n.fn[t]=e.jQueryInterface,n.fn[t].Constructor=e,n.fn[t].noConflict=function(){return n.fn[t]=i,e.jQueryInterface}}},"loading"===document.readyState?document.addEventListener("DOMContentLoaded",n):n()},A=(a={},l=1,{set:function(t,e,n){void 0===t.bsKey&&(t.bsKey={key:e,id:l},l++),a[t.bsKey.id]=n},get:function(t,e){if(!t||void 0===t.bsKey)return null;var n=t.bsKey;return n.key===e?a[n.id]:null},delete:function(t,e){if(void 0!==t.bsKey){var n=t.bsKey;n.key===e&&(delete a[n.id],delete t.bsKey)}}}),k=function(t,e,n){A.set(t,e,n)},L=function(t,e){return A.get(t,e)},C=/[^.]*(?=\..*)\.|.*/,D=/\..*/,S=/::\d+$/,N={},O=1,I={mouseenter:"mouseover",mouseleave:"mouseout"},j=new Set(["click","dblclick","mouseup","mousedown","contextmenu","mousewheel","DOMMouseScroll","mouseover","mouseout","mousemove","selectstart","selectend","keydown","keypress","keyup","orientationchange","touchstart","touchmove","touchend","touchcancel","pointerdown","pointermove","pointerup","pointerleave","pointercancel","gesturestart","gesturechange","gestureend","focus","blur","change","reset","select","submit","focusin","focusout","load","unload","beforeunload","resize","move","DOMContentLoaded","readystatechange","error","abort","scroll"]);function P(t,e){return e&&e+"::"+O++||t.uidEvent||O++}function x(t){var e=P(t);return t.uidEvent=e,N[e]=N[e]||{},N[e]}function H(t,e,n){void 0===n&&(n=null);for(var i=Object.keys(t),o=0,s=i.length;o<s;o++){var r=t[i[o]];if(r.originalHandler===e&&r.delegationSelector===n)return r}return null}function B(t,e,n){var i="string"==typeof e,o=i?n:e,s=t.replace(D,""),r=I[s];return r&&(s=r),j.has(s)||(s=t),[i,o,s]}function M(t,e,n,i,o){if("string"==typeof e&&t){n||(n=i,i=null);var s=B(e,n,i),r=s[0],a=s[1],l=s[2],c=x(t),u=c[l]||(c[l]={}),h=H(u,a,r?n:null);if(h)h.oneOff=h.oneOff&&o;else{var d=P(a,e.replace(C,"")),f=r?function(t,e,n){return function i(o){for(var s=t.querySelectorAll(e),r=o.target;r&&r!==this;r=r.parentNode)for(var a=s.length;a--;)if(s[a]===r)return o.delegateTarget=r,i.oneOff&&K.off(t,o.type,n),n.apply(r,[o]);return null}}(t,n,i):function(t,e){return function n(i){return i.delegateTarget=t,n.oneOff&&K.off(t,i.type,e),e.apply(t,[i])}}(t,n);f.delegationSelector=r?n:null,f.originalHandler=a,f.oneOff=o,f.uidEvent=d,u[d]=f,t.addEventListener(l,f,r)}}}function R(t,e,n,i,o){var s=H(e[n],i,o);s&&(t.removeEventListener(n,s,Boolean(o)),delete e[n][s.uidEvent])}var K={on:function(t,e,n,i){M(t,e,n,i,!1)},one:function(t,e,n,i){M(t,e,n,i,!0)},off:function(t,e,n,i){if("string"==typeof e&&t){var o=B(e,n,i),s=o[0],r=o[1],a=o[2],l=a!==e,c=x(t),u=e.startsWith(".");if(void 0===r){u&&Object.keys(c).forEach((function(n){!function(t,e,n,i){var o=e[n]||{};Object.keys(o).forEach((function(s){if(s.includes(i)){var r=o[s];R(t,e,n,r.originalHandler,r.delegationSelector)}}))}(t,c,n,e.slice(1))}));var h=c[a]||{};Object.keys(h).forEach((function(n){var i=n.replace(S,"");if(!l||e.includes(i)){var o=h[n];R(t,c,a,o.originalHandler,o.delegationSelector)}}))}else{if(!c||!c[a])return;R(t,c,a,r,s?n:null)}}},trigger:function(t,e,n){if("string"!=typeof e||!t)return null;var i,o=w(),s=e.replace(D,""),r=e!==s,a=j.has(s),l=!0,c=!0,u=!1,h=null;return r&&o&&(i=o.Event(e,n),o(t).trigger(i),l=!i.isPropagationStopped(),c=!i.isImmediatePropagationStopped(),u=i.isDefaultPrevented()),a?(h=document.createEvent("HTMLEvents")).initEvent(s,l,!0):h=new CustomEvent(e,{bubbles:l,cancelable:!0}),void 0!==n&&Object.keys(n).forEach((function(t){Object.defineProperty(h,t,{get:function(){return n[t]}})})),u&&h.preventDefault(),c&&t.dispatchEvent(h),h.defaultPrevented&&void 0!==i&&i.preventDefault(),h}},W=function(){function t(t){t&&(this._element=t,k(t,this.constructor.DATA_KEY,this))}return t.prototype.dispose=function(){var t,e;t=this._element,e=this.constructor.DATA_KEY,A.delete(t,e),this._element=null},t.getInstance=function(t){return L(t,this.DATA_KEY)},o(t,null,[{key:"VERSION",get:function(){return"5.0.0-beta2"}}]),t}(),U=function(t){function e(){return t.apply(this,arguments)||this}r(e,t);var n=e.prototype;return n.close=function(t){var e=t?this._getRootElement(t):this._element,n=this._triggerCloseEvent(e);null===n||n.defaultPrevented||this._removeElement(e)},n._getRootElement=function(t){return d(t)||t.closest(".alert")},n._triggerCloseEvent=function(t){return K.trigger(t,"close.bs.alert")},n._removeElement=function(t){var e=this;if(t.classList.remove("show"),t.classList.contains("fade")){var n=f(t);K.one(t,"transitionend",(function(){return e._destroyElement(t)})),m(t,n)}else this._destroyElement(t)},n._destroyElement=function(t){t.parentNode&&t.parentNode.removeChild(t),K.trigger(t,"closed.bs.alert")},e.jQueryInterface=function(t){return this.each((function(){var n=L(this,"bs.alert");n||(n=new e(this)),"close"===t&&n[t](this)}))},e.handleDismiss=function(t){return function(e){e&&e.preventDefault(),t.close(this)}},o(e,null,[{key:"DATA_KEY",get:function(){return"bs.alert"}}]),e}(W);K.on(document,"click.bs.alert.data-api",'[data-bs-dismiss="alert"]',U.handleDismiss(new U)),T("alert",U);var F=function(t){function e(){return t.apply(this,arguments)||this}return r(e,t),e.prototype.toggle=function(){this._element.setAttribute("aria-pressed",this._element.classList.toggle("active"))},e.jQueryInterface=function(t){return this.each((function(){var n=L(this,"bs.button");n||(n=new e(this)),"toggle"===t&&n[t]()}))},o(e,null,[{key:"DATA_KEY",get:function(){return"bs.button"}}]),e}(W);function z(t){return"true"===t||"false"!==t&&(t===Number(t).toString()?Number(t):""===t||"null"===t?null:t)}function Y(t){return t.replace(/[A-Z]/g,(function(t){return"-"+t.toLowerCase()}))}K.on(document,"click.bs.button.data-api",'[data-bs-toggle="button"]',(function(t){t.preventDefault();var e=t.target.closest('[data-bs-toggle="button"]'),n=L(e,"bs.button");n||(n=new F(e)),n.toggle()})),T("button",F);var X={setDataAttribute:function(t,e,n){t.setAttribute("data-bs-"+Y(e),n)},removeDataAttribute:function(t,e){t.removeAttribute("data-bs-"+Y(e))},getDataAttributes:function(t){if(!t)return{};var e={};return Object.keys(t.dataset).filter((function(t){return t.startsWith("bs")})).forEach((function(n){var i=n.replace(/^bs/,"");i=i.charAt(0).toLowerCase()+i.slice(1,i.length),e[i]=z(t.dataset[n])})),e},getDataAttribute:function(t,e){return z(t.getAttribute("data-bs-"+Y(e)))},offset:function(t){var e=t.getBoundingClientRect();return{top:e.top+document.body.scrollTop,left:e.left+document.body.scrollLeft}},position:function(t){return{top:t.offsetTop,left:t.offsetLeft}}},q=function(t,e){var n;return void 0===e&&(e=document.documentElement),(n=[]).concat.apply(n,Element.prototype.querySelectorAll.call(e,t))},Q=function(t,e){return void 0===e&&(e=document.documentElement),Element.prototype.querySelector.call(e,t)},V=function(t,e){var n;return(n=[]).concat.apply(n,t.children).filter((function(t){return t.matches(e)}))},$=function(t,e){for(var n=t.previousElementSibling;n;){if(n.matches(e))return[n];n=n.previousElementSibling}return[]},G={interval:5e3,keyboard:!0,slide:!1,pause:"hover",wrap:!0,touch:!0},Z={interval:"(number|boolean)",keyboard:"boolean",slide:"(boolean|string)",pause:"(string|boolean)",wrap:"boolean",touch:"boolean"},J=function(t){function e(e,n){var i;return(i=t.call(this,e)||this)._items=null,i._interval=null,i._activeElement=null,i._isPaused=!1,i._isSliding=!1,i.touchTimeout=null,i.touchStartX=0,i.touchDeltaX=0,i._config=i._getConfig(n),i._indicatorsElement=Q(".carousel-indicators",i._element),i._touchSupported="ontouchstart"in document.documentElement||navigator.maxTouchPoints>0,i._pointerEvent=Boolean(window.PointerEvent),i._addEventListeners(),i}r(e,t);var n=e.prototype;return n.next=function(){this._isSliding||this._slide("next")},n.nextWhenVisible=function(){!document.hidden&&v(this._element)&&this.next()},n.prev=function(){this._isSliding||this._slide("prev")},n.pause=function(t){t||(this._isPaused=!0),Q(".carousel-item-next, .carousel-item-prev",this._element)&&(p(this._element),this.cycle(!0)),clearInterval(this._interval),this._interval=null},n.cycle=function(t){t||(this._isPaused=!1),this._interval&&(clearInterval(this._interval),this._interval=null),this._config&&this._config.interval&&!this._isPaused&&(this._updateInterval(),this._interval=setInterval((document.visibilityState?this.nextWhenVisible:this.next).bind(this),this._config.interval))},n.to=function(t){var e=this;this._activeElement=Q(".active.carousel-item",this._element);var n=this._getItemIndex(this._activeElement);if(!(t>this._items.length-1||t<0))if(this._isSliding)K.one(this._element,"slid.bs.carousel",(function(){return e.to(t)}));else{if(n===t)return this.pause(),void this.cycle();var i=t>n?"next":"prev";this._slide(i,this._items[t])}},n.dispose=function(){t.prototype.dispose.call(this),K.off(this._element,".bs.carousel"),this._items=null,this._config=null,this._interval=null,this._isPaused=null,this._isSliding=null,this._activeElement=null,this._indicatorsElement=null},n._getConfig=function(t){return t=s({},G,t),_("carousel",t,Z),t},n._handleSwipe=function(){var t=Math.abs(this.touchDeltaX);if(!(t<=40)){var e=t/this.touchDeltaX;this.touchDeltaX=0,e>0&&(E?this.next():this.prev()),e<0&&(E?this.prev():this.next())}},n._addEventListeners=function(){var t=this;this._config.keyboard&&K.on(this._element,"keydown.bs.carousel",(function(e){return t._keydown(e)})),"hover"===this._config.pause&&(K.on(this._element,"mouseenter.bs.carousel",(function(e){return t.pause(e)})),K.on(this._element,"mouseleave.bs.carousel",(function(e){return t.cycle(e)}))),this._config.touch&&this._touchSupported&&this._addTouchEventListeners()},n._addTouchEventListeners=function(){var t=this,e=function(e){!t._pointerEvent||"pen"!==e.pointerType&&"touch"!==e.pointerType?t._pointerEvent||(t.touchStartX=e.touches[0].clientX):t.touchStartX=e.clientX},n=function(e){!t._pointerEvent||"pen"!==e.pointerType&&"touch"!==e.pointerType||(t.touchDeltaX=e.clientX-t.touchStartX),t._handleSwipe(),"hover"===t._config.pause&&(t.pause(),t.touchTimeout&&clearTimeout(t.touchTimeout),t.touchTimeout=setTimeout((function(e){return t.cycle(e)}),500+t._config.interval))};q(".carousel-item img",this._element).forEach((function(t){K.on(t,"dragstart.bs.carousel",(function(t){return t.preventDefault()}))})),this._pointerEvent?(K.on(this._element,"pointerdown.bs.carousel",(function(t){return e(t)})),K.on(this._element,"pointerup.bs.carousel",(function(t){return n(t)})),this._element.classList.add("pointer-event")):(K.on(this._element,"touchstart.bs.carousel",(function(t){return e(t)})),K.on(this._element,"touchmove.bs.carousel",(function(e){return function(e){e.touches&&e.touches.length>1?t.touchDeltaX=0:t.touchDeltaX=e.touches[0].clientX-t.touchStartX}(e)})),K.on(this._element,"touchend.bs.carousel",(function(t){return n(t)})))},n._keydown=function(t){/input|textarea/i.test(t.target.tagName)||("ArrowLeft"===t.key?(t.preventDefault(),E?this.next():this.prev()):"ArrowRight"===t.key&&(t.preventDefault(),E?this.prev():this.next()))},n._getItemIndex=function(t){return this._items=t&&t.parentNode?q(".carousel-item",t.parentNode):[],this._items.indexOf(t)},n._getItemByDirection=function(t,e){var n="next"===t,i="prev"===t,o=this._getItemIndex(e),s=this._items.length-1;if((i&&0===o||n&&o===s)&&!this._config.wrap)return e;var r=(o+("prev"===t?-1:1))%this._items.length;return-1===r?this._items[this._items.length-1]:this._items[r]},n._triggerSlideEvent=function(t,e){var n=this._getItemIndex(t),i=this._getItemIndex(Q(".active.carousel-item",this._element));return K.trigger(this._element,"slide.bs.carousel",{relatedTarget:t,direction:e,from:i,to:n})},n._setActiveIndicatorElement=function(t){if(this._indicatorsElement){var e=Q(".active",this._indicatorsElement);e.classList.remove("active"),e.removeAttribute("aria-current");for(var n=q("[data-bs-target]",this._indicatorsElement),i=0;i<n.length;i++)if(Number.parseInt(n[i].getAttribute("data-bs-slide-to"),10)===this._getItemIndex(t)){n[i].classList.add("active"),n[i].setAttribute("aria-current","true");break}}},n._updateInterval=function(){var t=this._activeElement||Q(".active.carousel-item",this._element);if(t){var e=Number.parseInt(t.getAttribute("data-bs-interval"),10);e?(this._config.defaultInterval=this._config.defaultInterval||this._config.interval,this._config.interval=e):this._config.interval=this._config.defaultInterval||this._config.interval}},n._slide=function(t,e){var n=this,i=Q(".active.carousel-item",this._element),o=this._getItemIndex(i),s=e||i&&this._getItemByDirection(t,i),r=this._getItemIndex(s),a=Boolean(this._interval),l="next"===t?"carousel-item-start":"carousel-item-end",c="next"===t?"carousel-item-next":"carousel-item-prev",u="next"===t?"left":"right";if(s&&s.classList.contains("active"))this._isSliding=!1;else if(!this._triggerSlideEvent(s,u).defaultPrevented&&i&&s){if(this._isSliding=!0,a&&this.pause(),this._setActiveIndicatorElement(s),this._activeElement=s,this._element.classList.contains("slide")){s.classList.add(c),y(s),i.classList.add(l),s.classList.add(l);var h=f(i);K.one(i,"transitionend",(function(){s.classList.remove(l,c),s.classList.add("active"),i.classList.remove("active",c,l),n._isSliding=!1,setTimeout((function(){K.trigger(n._element,"slid.bs.carousel",{relatedTarget:s,direction:u,from:o,to:r})}),0)})),m(i,h)}else i.classList.remove("active"),s.classList.add("active"),this._isSliding=!1,K.trigger(this._element,"slid.bs.carousel",{relatedTarget:s,direction:u,from:o,to:r});a&&this.cycle()}},e.carouselInterface=function(t,n){var i=L(t,"bs.carousel"),o=s({},G,X.getDataAttributes(t));"object"==typeof n&&(o=s({},o,n));var r="string"==typeof n?n:o.slide;if(i||(i=new e(t,o)),"number"==typeof n)i.to(n);else if("string"==typeof r){if(void 0===i[r])throw new TypeError('No method named "'+r+'"');i[r]()}else o.interval&&o.ride&&(i.pause(),i.cycle())},e.jQueryInterface=function(t){return this.each((function(){e.carouselInterface(this,t)}))},e.dataApiClickHandler=function(t){var n=d(this);if(n&&n.classList.contains("carousel")){var i=s({},X.getDataAttributes(n),X.getDataAttributes(this)),o=this.getAttribute("data-bs-slide-to");o&&(i.interval=!1),e.carouselInterface(n,i),o&&L(n,"bs.carousel").to(o),t.preventDefault()}},o(e,null,[{key:"Default",get:function(){return G}},{key:"DATA_KEY",get:function(){return"bs.carousel"}}]),e}(W);K.on(document,"click.bs.carousel.data-api","[data-bs-slide], [data-bs-slide-to]",J.dataApiClickHandler),K.on(window,"load.bs.carousel.data-api",(function(){for(var t=q('[data-bs-ride="carousel"]'),e=0,n=t.length;e<n;e++)J.carouselInterface(t[e],L(t[e],"bs.carousel"))})),T("carousel",J);var tt={toggle:!0,parent:""},et={toggle:"boolean",parent:"(string|element)"},nt=function(t){function e(e,n){var i;(i=t.call(this,e)||this)._isTransitioning=!1,i._config=i._getConfig(n),i._triggerArray=q('[data-bs-toggle="collapse"][href="#'+e.id+'"],[data-bs-toggle="collapse"][data-bs-target="#'+e.id+'"]');for(var o=q('[data-bs-toggle="collapse"]'),s=0,r=o.length;s<r;s++){var a=o[s],l=h(a),c=q(l).filter((function(t){return t===e}));null!==l&&c.length&&(i._selector=l,i._triggerArray.push(a))}return i._parent=i._config.parent?i._getParent():null,i._config.parent||i._addAriaAndCollapsedClass(i._element,i._triggerArray),i._config.toggle&&i.toggle(),i}r(e,t);var n=e.prototype;return n.toggle=function(){this._element.classList.contains("show")?this.hide():this.show()},n.show=function(){var t=this;if(!this._isTransitioning&&!this._element.classList.contains("show")){var n,i;this._parent&&0===(n=q(".show, .collapsing",this._parent).filter((function(e){return"string"==typeof t._config.parent?e.getAttribute("data-bs-parent")===t._config.parent:e.classList.contains("collapse")}))).length&&(n=null);var o=Q(this._selector);if(n){var s=n.find((function(t){return o!==t}));if((i=s?L(s,"bs.collapse"):null)&&i._isTransitioning)return}if(!K.trigger(this._element,"show.bs.collapse").defaultPrevented){n&&n.forEach((function(t){o!==t&&e.collapseInterface(t,"hide"),i||k(t,"bs.collapse",null)}));var r=this._getDimension();this._element.classList.remove("collapse"),this._element.classList.add("collapsing"),this._element.style[r]=0,this._triggerArray.length&&this._triggerArray.forEach((function(t){t.classList.remove("collapsed"),t.setAttribute("aria-expanded",!0)})),this.setTransitioning(!0);var a="scroll"+(r[0].toUpperCase()+r.slice(1)),l=f(this._element);K.one(this._element,"transitionend",(function(){t._element.classList.remove("collapsing"),t._element.classList.add("collapse","show"),t._element.style[r]="",t.setTransitioning(!1),K.trigger(t._element,"shown.bs.collapse")})),m(this._element,l),this._element.style[r]=this._element[a]+"px"}}},n.hide=function(){var t=this;if(!this._isTransitioning&&this._element.classList.contains("show")&&!K.trigger(this._element,"hide.bs.collapse").defaultPrevented){var e=this._getDimension();this._element.style[e]=this._element.getBoundingClientRect()[e]+"px",y(this._element),this._element.classList.add("collapsing"),this._element.classList.remove("collapse","show");var n=this._triggerArray.length;if(n>0)for(var i=0;i<n;i++){var o=this._triggerArray[i],s=d(o);s&&!s.classList.contains("show")&&(o.classList.add("collapsed"),o.setAttribute("aria-expanded",!1))}this.setTransitioning(!0),this._element.style[e]="";var r=f(this._element);K.one(this._element,"transitionend",(function(){t.setTransitioning(!1),t._element.classList.remove("collapsing"),t._element.classList.add("collapse"),K.trigger(t._element,"hidden.bs.collapse")})),m(this._element,r)}},n.setTransitioning=function(t){this._isTransitioning=t},n.dispose=function(){t.prototype.dispose.call(this),this._config=null,this._parent=null,this._triggerArray=null,this._isTransitioning=null},n._getConfig=function(t){return(t=s({},tt,t)).toggle=Boolean(t.toggle),_("collapse",t,et),t},n._getDimension=function(){return this._element.classList.contains("width")?"width":"height"},n._getParent=function(){var t=this,e=this._config.parent;return g(e)?void 0===e.jquery&&void 0===e[0]||(e=e[0]):e=Q(e),q('[data-bs-toggle="collapse"][data-bs-parent="'+e+'"]',e).forEach((function(e){var n=d(e);t._addAriaAndCollapsedClass(n,[e])})),e},n._addAriaAndCollapsedClass=function(t,e){if(t&&e.length){var n=t.classList.contains("show");e.forEach((function(t){n?t.classList.remove("collapsed"):t.classList.add("collapsed"),t.setAttribute("aria-expanded",n)}))}},e.collapseInterface=function(t,n){var i=L(t,"bs.collapse"),o=s({},tt,X.getDataAttributes(t),"object"==typeof n&&n?n:{});if(!i&&o.toggle&&"string"==typeof n&&/show|hide/.test(n)&&(o.toggle=!1),i||(i=new e(t,o)),"string"==typeof n){if(void 0===i[n])throw new TypeError('No method named "'+n+'"');i[n]()}},e.jQueryInterface=function(t){return this.each((function(){e.collapseInterface(this,t)}))},o(e,null,[{key:"Default",get:function(){return tt}},{key:"DATA_KEY",get:function(){return"bs.collapse"}}]),e}(W);K.on(document,"click.bs.collapse.data-api",'[data-bs-toggle="collapse"]',(function(t){("A"===t.target.tagName||t.delegateTarget&&"A"===t.delegateTarget.tagName)&&t.preventDefault();var e=X.getDataAttributes(this),n=h(this);q(n).forEach((function(t){var n,i=L(t,"bs.collapse");i?(null===i._parent&&"string"==typeof e.parent&&(i._config.parent=e.parent,i._parent=i._getParent()),n="toggle"):n=e,nt.collapseInterface(t,n)}))})),T("collapse",nt);var it=new RegExp("ArrowUp|ArrowDown|Escape"),ot=E?"top-end":"top-start",st=E?"top-start":"top-end",rt=E?"bottom-end":"bottom-start",at=E?"bottom-start":"bottom-end",lt=E?"left-start":"right-start",ct=E?"right-start":"left-start",ut={offset:[0,2],flip:!0,boundary:"clippingParents",reference:"toggle",display:"dynamic",popperConfig:null},ht={offset:"(array|string|function)",flip:"boolean",boundary:"(string|element)",reference:"(string|element|object)",display:"string",popperConfig:"(null|object|function)"},dt=function(e){function i(t,n){var i;return(i=e.call(this,t)||this)._popper=null,i._config=i._getConfig(n),i._menu=i._getMenuElement(),i._inNavbar=i._detectNavbar(),i._addEventListeners(),i}r(i,e);var a=i.prototype;return a.toggle=function(){if(!this._element.disabled&&!this._element.classList.contains("disabled")){var t=this._element.classList.contains("show");i.clearMenus(),t||this.show()}},a.show=function(){if(!(this._element.disabled||this._element.classList.contains("disabled")||this._menu.classList.contains("show"))){var e=i.getParentFromElement(this._element),o={relatedTarget:this._element};if(!K.trigger(this._element,"show.bs.dropdown",o).defaultPrevented){if(this._inNavbar)X.setDataAttribute(this._menu,"popper","none");else{if(void 0===n)throw new TypeError("Bootstrap's dropdowns require Popper (https://popper.js.org)");var s=this._element;"parent"===this._config.reference?s=e:g(this._config.reference)?(s=this._config.reference,void 0!==this._config.reference.jquery&&(s=this._config.reference[0])):"object"==typeof this._config.reference&&(s=this._config.reference);var r=this._getPopperConfig(),a=r.modifiers.find((function(t){return"applyStyles"===t.name&&!1===t.enabled}));this._popper=t.createPopper(s,this._menu,r),a&&X.setDataAttribute(this._menu,"popper","static")}var l;"ontouchstart"in document.documentElement&&!e.closest(".navbar-nav")&&(l=[]).concat.apply(l,document.body.children).forEach((function(t){return K.on(t,"mouseover",null,(function(){}))})),this._element.focus(),this._element.setAttribute("aria-expanded",!0),this._menu.classList.toggle("show"),this._element.classList.toggle("show"),K.trigger(this._element,"shown.bs.dropdown",o)}}},a.hide=function(){if(!this._element.disabled&&!this._element.classList.contains("disabled")&&this._menu.classList.contains("show")){var t={relatedTarget:this._element};K.trigger(this._element,"hide.bs.dropdown",t).defaultPrevented||(this._popper&&this._popper.destroy(),this._menu.classList.toggle("show"),this._element.classList.toggle("show"),X.removeDataAttribute(this._menu,"popper"),K.trigger(this._element,"hidden.bs.dropdown",t))}},a.dispose=function(){e.prototype.dispose.call(this),K.off(this._element,".bs.dropdown"),this._menu=null,this._popper&&(this._popper.destroy(),this._popper=null)},a.update=function(){this._inNavbar=this._detectNavbar(),this._popper&&this._popper.update()},a._addEventListeners=function(){var t=this;K.on(this._element,"click.bs.dropdown",(function(e){e.preventDefault(),e.stopPropagation(),t.toggle()}))},a._getConfig=function(t){if(t=s({},this.constructor.Default,X.getDataAttributes(this._element),t),_("dropdown",t,this.constructor.DefaultType),"object"==typeof t.reference&&!g(t.reference)&&"function"!=typeof t.reference.getBoundingClientRect)throw new TypeError("dropdown".toUpperCase()+': Option "reference" provided type "object" without a required "getBoundingClientRect" method.');return t},a._getMenuElement=function(){return function(t,e){for(var n=t.nextElementSibling;n;){if(n.matches(e))return[n];n=n.nextElementSibling}return[]}(this._element,".dropdown-menu")[0]},a._getPlacement=function(){var t=this._element.parentNode;if(t.classList.contains("dropend"))return lt;if(t.classList.contains("dropstart"))return ct;var e="end"===getComputedStyle(this._menu).getPropertyValue("--bs-position").trim();return t.classList.contains("dropup")?e?st:ot:e?at:rt},a._detectNavbar=function(){return null!==this._element.closest(".navbar")},a._getOffset=function(){var t=this,e=this._config.offset;return"string"==typeof e?e.split(",").map((function(t){return Number.parseInt(t,10)})):"function"==typeof e?function(n){return e(n,t._element)}:e},a._getPopperConfig=function(){var t={placement:this._getPlacement(),modifiers:[{name:"preventOverflow",options:{altBoundary:this._config.flip,boundary:this._config.boundary}},{name:"offset",options:{offset:this._getOffset()}}]};return"static"===this._config.display&&(t.modifiers=[{name:"applyStyles",enabled:!1}]),s({},t,"function"==typeof this._config.popperConfig?this._config.popperConfig(t):this._config.popperConfig)},i.dropdownInterface=function(t,e){var n=L(t,"bs.dropdown");if(n||(n=new i(t,"object"==typeof e?e:null)),"string"==typeof e){if(void 0===n[e])throw new TypeError('No method named "'+e+'"');n[e]()}},i.jQueryInterface=function(t){return this.each((function(){i.dropdownInterface(this,t)}))},i.clearMenus=function(t){if(!t||2!==t.button&&("keyup"!==t.type||"Tab"===t.key))for(var e=q('[data-bs-toggle="dropdown"]'),n=0,i=e.length;n<i;n++){var o=L(e[n],"bs.dropdown"),s={relatedTarget:e[n]};if(t&&"click"===t.type&&(s.clickEvent=t),o){var r,a=o._menu;if(e[n].classList.contains("show")&&!(t&&("click"===t.type&&/input|textarea/i.test(t.target.tagName)||"keyup"===t.type&&"Tab"===t.key)&&a.contains(t.target)||K.trigger(e[n],"hide.bs.dropdown",s).defaultPrevented))"ontouchstart"in document.documentElement&&(r=[]).concat.apply(r,document.body.children).forEach((function(t){return K.off(t,"mouseover",null,(function(){}))})),e[n].setAttribute("aria-expanded","false"),o._popper&&o._popper.destroy(),a.classList.remove("show"),e[n].classList.remove("show"),X.removeDataAttribute(a,"popper"),K.trigger(e[n],"hidden.bs.dropdown",s)}}},i.getParentFromElement=function(t){return d(t)||t.parentNode},i.dataApiKeydownHandler=function(t){if(!(/input|textarea/i.test(t.target.tagName)?"Space"===t.key||"Escape"!==t.key&&("ArrowDown"!==t.key&&"ArrowUp"!==t.key||t.target.closest(".dropdown-menu")):!it.test(t.key))&&(t.preventDefault(),t.stopPropagation(),!this.disabled&&!this.classList.contains("disabled"))){var e=i.getParentFromElement(this),n=this.classList.contains("show");if("Escape"===t.key)return(this.matches('[data-bs-toggle="dropdown"]')?this:$(this,'[data-bs-toggle="dropdown"]')[0]).focus(),void i.clearMenus();if(n||"ArrowUp"!==t.key&&"ArrowDown"!==t.key)if(n&&"Space"!==t.key){var o=q(".dropdown-menu .dropdown-item:not(.disabled):not(:disabled)",e).filter(v);if(o.length){var s=o.indexOf(t.target);"ArrowUp"===t.key&&s>0&&s--,"ArrowDown"===t.key&&s<o.length-1&&s++,o[s=-1===s?0:s].focus()}}else i.clearMenus();else(this.matches('[data-bs-toggle="dropdown"]')?this:$(this,'[data-bs-toggle="dropdown"]')[0]).click()}},o(i,null,[{key:"Default",get:function(){return ut}},{key:"DefaultType",get:function(){return ht}},{key:"DATA_KEY",get:function(){return"bs.dropdown"}}]),i}(W);K.on(document,"keydown.bs.dropdown.data-api",'[data-bs-toggle="dropdown"]',dt.dataApiKeydownHandler),K.on(document,"keydown.bs.dropdown.data-api",".dropdown-menu",dt.dataApiKeydownHandler),K.on(document,"click.bs.dropdown.data-api",dt.clearMenus),K.on(document,"keyup.bs.dropdown.data-api",dt.clearMenus),K.on(document,"click.bs.dropdown.data-api",'[data-bs-toggle="dropdown"]',(function(t){t.preventDefault(),t.stopPropagation(),dt.dropdownInterface(this,"toggle")})),K.on(document,"click.bs.dropdown.data-api",".dropdown form",(function(t){return t.stopPropagation()})),T("dropdown",dt);var ft={backdrop:!0,keyboard:!0,focus:!0},pt={backdrop:"(boolean|string)",keyboard:"boolean",focus:"boolean"},gt=function(t){function e(e,n){var i;return(i=t.call(this,e)||this)._config=i._getConfig(n),i._dialog=Q(".modal-dialog",e),i._backdrop=null,i._isShown=!1,i._isBodyOverflowing=!1,i._ignoreBackdropClick=!1,i._isTransitioning=!1,i._scrollbarWidth=0,i}r(e,t);var n=e.prototype;return n.toggle=function(t){return this._isShown?this.hide():this.show(t)},n.show=function(t){var e=this;if(!this._isShown&&!this._isTransitioning){this._element.classList.contains("fade")&&(this._isTransitioning=!0);var n=K.trigger(this._element,"show.bs.modal",{relatedTarget:t});this._isShown||n.defaultPrevented||(this._isShown=!0,this._checkScrollbar(),this._setScrollbar(),this._adjustDialog(),this._setEscapeEvent(),this._setResizeEvent(),K.on(this._element,"click.dismiss.bs.modal",'[data-bs-dismiss="modal"]',(function(t){return e.hide(t)})),K.on(this._dialog,"mousedown.dismiss.bs.modal",(function(){K.one(e._element,"mouseup.dismiss.bs.modal",(function(t){t.target===e._element&&(e._ignoreBackdropClick=!0)}))})),this._showBackdrop((function(){return e._showElement(t)})))}},n.hide=function(t){var e=this;if(t&&t.preventDefault(),this._isShown&&!this._isTransitioning&&!K.trigger(this._element,"hide.bs.modal").defaultPrevented){this._isShown=!1;var n=this._element.classList.contains("fade");if(n&&(this._isTransitioning=!0),this._setEscapeEvent(),this._setResizeEvent(),K.off(document,"focusin.bs.modal"),this._element.classList.remove("show"),K.off(this._element,"click.dismiss.bs.modal"),K.off(this._dialog,"mousedown.dismiss.bs.modal"),n){var i=f(this._element);K.one(this._element,"transitionend",(function(t){return e._hideModal(t)})),m(this._element,i)}else this._hideModal()}},n.dispose=function(){[window,this._element,this._dialog].forEach((function(t){return K.off(t,".bs.modal")})),t.prototype.dispose.call(this),K.off(document,"focusin.bs.modal"),this._config=null,this._dialog=null,this._backdrop=null,this._isShown=null,this._isBodyOverflowing=null,this._ignoreBackdropClick=null,this._isTransitioning=null,this._scrollbarWidth=null},n.handleUpdate=function(){this._adjustDialog()},n._getConfig=function(t){return t=s({},ft,t),_("modal",t,pt),t},n._showElement=function(t){var e=this,n=this._element.classList.contains("fade"),i=Q(".modal-body",this._dialog);this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE||document.body.appendChild(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.scrollTop=0,i&&(i.scrollTop=0),n&&y(this._element),this._element.classList.add("show"),this._config.focus&&this._enforceFocus();var o=function(){e._config.focus&&e._element.focus(),e._isTransitioning=!1,K.trigger(e._element,"shown.bs.modal",{relatedTarget:t})};if(n){var s=f(this._dialog);K.one(this._dialog,"transitionend",o),m(this._dialog,s)}else o()},n._enforceFocus=function(){var t=this;K.off(document,"focusin.bs.modal"),K.on(document,"focusin.bs.modal",(function(e){document===e.target||t._element===e.target||t._element.contains(e.target)||t._element.focus()}))},n._setEscapeEvent=function(){var t=this;this._isShown?K.on(this._element,"keydown.dismiss.bs.modal",(function(e){t._config.keyboard&&"Escape"===e.key?(e.preventDefault(),t.hide()):t._config.keyboard||"Escape"!==e.key||t._triggerBackdropTransition()})):K.off(this._element,"keydown.dismiss.bs.modal")},n._setResizeEvent=function(){var t=this;this._isShown?K.on(window,"resize.bs.modal",(function(){return t._adjustDialog()})):K.off(window,"resize.bs.modal")},n._hideModal=function(){var t=this;this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._isTransitioning=!1,this._showBackdrop((function(){document.body.classList.remove("modal-open"),t._resetAdjustments(),t._resetScrollbar(),K.trigger(t._element,"hidden.bs.modal")}))},n._removeBackdrop=function(){this._backdrop.parentNode.removeChild(this._backdrop),this._backdrop=null},n._showBackdrop=function(t){var e=this,n=this._element.classList.contains("fade")?"fade":"";if(this._isShown&&this._config.backdrop){if(this._backdrop=document.createElement("div"),this._backdrop.className="modal-backdrop",n&&this._backdrop.classList.add(n),document.body.appendChild(this._backdrop),K.on(this._element,"click.dismiss.bs.modal",(function(t){e._ignoreBackdropClick?e._ignoreBackdropClick=!1:t.target===t.currentTarget&&("static"===e._config.backdrop?e._triggerBackdropTransition():e.hide())})),n&&y(this._backdrop),this._backdrop.classList.add("show"),!n)return void t();var i=f(this._backdrop);K.one(this._backdrop,"transitionend",t),m(this._backdrop,i)}else if(!this._isShown&&this._backdrop){this._backdrop.classList.remove("show");var o=function(){e._removeBackdrop(),t()};if(this._element.classList.contains("fade")){var s=f(this._backdrop);K.one(this._backdrop,"transitionend",o),m(this._backdrop,s)}else o()}else t()},n._triggerBackdropTransition=function(){var t=this;if(!K.trigger(this._element,"hidePrevented.bs.modal").defaultPrevented){var e=this._element.scrollHeight>document.documentElement.clientHeight;e||(this._element.style.overflowY="hidden"),this._element.classList.add("modal-static");var n=f(this._dialog);K.off(this._element,"transitionend"),K.one(this._element,"transitionend",(function(){t._element.classList.remove("modal-static"),e||(K.one(t._element,"transitionend",(function(){t._element.style.overflowY=""})),m(t._element,n))})),m(this._element,n),this._element.focus()}},n._adjustDialog=function(){var t=this._element.scrollHeight>document.documentElement.clientHeight;(!this._isBodyOverflowing&&t&&!E||this._isBodyOverflowing&&!t&&E)&&(this._element.style.paddingLeft=this._scrollbarWidth+"px"),(this._isBodyOverflowing&&!t&&!E||!this._isBodyOverflowing&&t&&E)&&(this._element.style.paddingRight=this._scrollbarWidth+"px")},n._resetAdjustments=function(){this._element.style.paddingLeft="",this._element.style.paddingRight=""},n._checkScrollbar=function(){var t=document.body.getBoundingClientRect();this._isBodyOverflowing=Math.round(t.left+t.right)<window.innerWidth,this._scrollbarWidth=this._getScrollbarWidth()},n._setScrollbar=function(){var t=this;this._isBodyOverflowing&&(this._setElementAttributes(".fixed-top, .fixed-bottom, .is-fixed, .sticky-top","paddingRight",(function(e){return e+t._scrollbarWidth})),this._setElementAttributes(".sticky-top","marginRight",(function(e){return e-t._scrollbarWidth})),this._setElementAttributes("body","paddingRight",(function(e){return e+t._scrollbarWidth}))),document.body.classList.add("modal-open")},n._setElementAttributes=function(t,e,n){q(t).forEach((function(t){var i=t.style[e],o=window.getComputedStyle(t)[e];X.setDataAttribute(t,e,i),t.style[e]=n(Number.parseFloat(o))+"px"}))},n._resetScrollbar=function(){this._resetElementAttributes(".fixed-top, .fixed-bottom, .is-fixed, .sticky-top","paddingRight"),this._resetElementAttributes(".sticky-top","marginRight"),this._resetElementAttributes("body","paddingRight")},n._resetElementAttributes=function(t,e){q(t).forEach((function(t){var n=X.getDataAttribute(t,e);void 0===n&&t===document.body?t.style[e]="":(X.removeDataAttribute(t,e),t.style[e]=n)}))},n._getScrollbarWidth=function(){var t=document.createElement("div");t.className="modal-scrollbar-measure",document.body.appendChild(t);var e=t.getBoundingClientRect().width-t.clientWidth;return document.body.removeChild(t),e},e.jQueryInterface=function(t,n){return this.each((function(){var i=L(this,"bs.modal"),o=s({},ft,X.getDataAttributes(this),"object"==typeof t&&t?t:{});if(i||(i=new e(this,o)),"string"==typeof t){if(void 0===i[t])throw new TypeError('No method named "'+t+'"');i[t](n)}}))},o(e,null,[{key:"Default",get:function(){return ft}},{key:"DATA_KEY",get:function(){return"bs.modal"}}]),e}(W);K.on(document,"click.bs.modal.data-api",'[data-bs-toggle="modal"]',(function(t){var e=this,n=d(this);"A"!==this.tagName&&"AREA"!==this.tagName||t.preventDefault(),K.one(n,"show.bs.modal",(function(t){t.defaultPrevented||K.one(n,"hidden.bs.modal",(function(){v(e)&&e.focus()}))}));var i=L(n,"bs.modal");if(!i){var o=s({},X.getDataAttributes(n),X.getDataAttributes(this));i=new gt(n,o)}i.toggle(this)})),T("modal",gt);var mt=new Set(["background","cite","href","itemtype","longdesc","poster","src","xlink:href"]),_t=/^(?:(?:https?|mailto|ftp|tel|file):|[^#&/:?]*(?:[#/?]|$))/gi,vt=/^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[\d+/a-z]+=*$/i;function bt(t,e,n){var i;if(!t.length)return t;if(n&&"function"==typeof n)return n(t);for(var o=(new window.DOMParser).parseFromString(t,"text/html"),s=Object.keys(e),r=(i=[]).concat.apply(i,o.body.querySelectorAll("*")),a=function(t,n){var i,o=r[t],a=o.nodeName.toLowerCase();if(!s.includes(a))return o.parentNode.removeChild(o),"continue";var l=(i=[]).concat.apply(i,o.attributes),c=[].concat(e["*"]||[],e[a]||[]);l.forEach((function(t){(function(t,e){var n=t.nodeName.toLowerCase();if(e.includes(n))return!mt.has(n)||Boolean(_t.test(t.nodeValue)||vt.test(t.nodeValue));for(var i=e.filter((function(t){return t instanceof RegExp})),o=0,s=i.length;o<s;o++)if(i[o].test(n))return!0;return!1})(t,c)||o.removeAttribute(t.nodeName)}))},l=0,c=r.length;l<c;l++)a(l);return o.body.innerHTML}var yt=new RegExp("(^|\\s)bs-tooltip\\S+","g"),wt=new Set(["sanitize","allowList","sanitizeFn"]),Et={animation:"boolean",template:"string",title:"(string|element|function)",trigger:"string",delay:"(number|object)",html:"boolean",selector:"(string|boolean)",placement:"(string|function)",offset:"(array|string|function)",container:"(string|element|boolean)",fallbackPlacements:"array",boundary:"(string|element)",customClass:"(string|function)",sanitize:"boolean",sanitizeFn:"(null|function)",allowList:"object",popperConfig:"(null|object|function)"},Tt={AUTO:"auto",TOP:"top",RIGHT:E?"left":"right",BOTTOM:"bottom",LEFT:E?"right":"left"},At={animation:!0,template:'<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,selector:!1,placement:"top",offset:[0,0],container:!1,fallbackPlacements:["top","right","bottom","left"],boundary:"clippingParents",customClass:"",sanitize:!0,sanitizeFn:null,allowList:{"*":["class","dir","id","lang","role",/^aria-[\w-]*$/i],a:["target","href","title","rel"],area:[],b:[],br:[],col:[],code:[],div:[],em:[],hr:[],h1:[],h2:[],h3:[],h4:[],h5:[],h6:[],i:[],img:["src","srcset","alt","title","width","height"],li:[],ol:[],p:[],pre:[],s:[],small:[],span:[],sub:[],sup:[],strong:[],u:[],ul:[]},popperConfig:null},kt={HIDE:"hide.bs.tooltip",HIDDEN:"hidden.bs.tooltip",SHOW:"show.bs.tooltip",SHOWN:"shown.bs.tooltip",INSERTED:"inserted.bs.tooltip",CLICK:"click.bs.tooltip",FOCUSIN:"focusin.bs.tooltip",FOCUSOUT:"focusout.bs.tooltip",MOUSEENTER:"mouseenter.bs.tooltip",MOUSELEAVE:"mouseleave.bs.tooltip"},Lt=function(e){function i(t,i){var o;if(void 0===n)throw new TypeError("Bootstrap's tooltips require Popper (https://popper.js.org)");return(o=e.call(this,t)||this)._isEnabled=!0,o._timeout=0,o._hoverState="",o._activeTrigger={},o._popper=null,o.config=o._getConfig(i),o.tip=null,o._setListeners(),o}r(i,e);var a=i.prototype;return a.enable=function(){this._isEnabled=!0},a.disable=function(){this._isEnabled=!1},a.toggleEnabled=function(){this._isEnabled=!this._isEnabled},a.toggle=function(t){if(this._isEnabled)if(t){var e=this._initializeOnDelegatedTarget(t);e._activeTrigger.click=!e._activeTrigger.click,e._isWithActiveTrigger()?e._enter(null,e):e._leave(null,e)}else{if(this.getTipElement().classList.contains("show"))return void this._leave(null,this);this._enter(null,this)}},a.dispose=function(){clearTimeout(this._timeout),K.off(this._element,this.constructor.EVENT_KEY),K.off(this._element.closest(".modal"),"hide.bs.modal",this._hideModalHandler),this.tip&&this.tip.parentNode&&this.tip.parentNode.removeChild(this.tip),this._isEnabled=null,this._timeout=null,this._hoverState=null,this._activeTrigger=null,this._popper&&this._popper.destroy(),this._popper=null,this.config=null,this.tip=null,e.prototype.dispose.call(this)},a.show=function(){var e=this;if("none"===this._element.style.display)throw new Error("Please use show on visible elements");if(this.isWithContent()&&this._isEnabled){var n=K.trigger(this._element,this.constructor.Event.SHOW),i=function t(e){if(!document.documentElement.attachShadow)return null;if("function"==typeof e.getRootNode){var n=e.getRootNode();return n instanceof ShadowRoot?n:null}return e instanceof ShadowRoot?e:e.parentNode?t(e.parentNode):null}(this._element),o=null===i?this._element.ownerDocument.documentElement.contains(this._element):i.contains(this._element);if(!n.defaultPrevented&&o){var s=this.getTipElement(),r=c(this.constructor.NAME);s.setAttribute("id",r),this._element.setAttribute("aria-describedby",r),this.setContent(),this.config.animation&&s.classList.add("fade");var a="function"==typeof this.config.placement?this.config.placement.call(this,s,this._element):this.config.placement,l=this._getAttachment(a);this._addAttachmentClass(l);var u=this._getContainer();k(s,this.constructor.DATA_KEY,this),this._element.ownerDocument.documentElement.contains(this.tip)||u.appendChild(s),K.trigger(this._element,this.constructor.Event.INSERTED),this._popper=t.createPopper(this._element,s,this._getPopperConfig(l)),s.classList.add("show");var h,d,p="function"==typeof this.config.customClass?this.config.customClass():this.config.customClass;p&&(h=s.classList).add.apply(h,p.split(" ")),"ontouchstart"in document.documentElement&&(d=[]).concat.apply(d,document.body.children).forEach((function(t){K.on(t,"mouseover",(function(){}))}));var g=function(){var t=e._hoverState;e._hoverState=null,K.trigger(e._element,e.constructor.Event.SHOWN),"out"===t&&e._leave(null,e)};if(this.tip.classList.contains("fade")){var _=f(this.tip);K.one(this.tip,"transitionend",g),m(this.tip,_)}else g()}}},a.hide=function(){var t=this;if(this._popper){var e=this.getTipElement(),n=function(){"show"!==t._hoverState&&e.parentNode&&e.parentNode.removeChild(e),t._cleanTipClass(),t._element.removeAttribute("aria-describedby"),K.trigger(t._element,t.constructor.Event.HIDDEN),t._popper&&(t._popper.destroy(),t._popper=null)};if(!K.trigger(this._element,this.constructor.Event.HIDE).defaultPrevented){var i;if(e.classList.remove("show"),"ontouchstart"in document.documentElement&&(i=[]).concat.apply(i,document.body.children).forEach((function(t){return K.off(t,"mouseover",b)})),this._activeTrigger.click=!1,this._activeTrigger.focus=!1,this._activeTrigger.hover=!1,this.tip.classList.contains("fade")){var o=f(e);K.one(e,"transitionend",n),m(e,o)}else n();this._hoverState=""}}},a.update=function(){null!==this._popper&&this._popper.update()},a.isWithContent=function(){return Boolean(this.getTitle())},a.getTipElement=function(){if(this.tip)return this.tip;var t=document.createElement("div");return t.innerHTML=this.config.template,this.tip=t.children[0],this.tip},a.setContent=function(){var t=this.getTipElement();this.setElementContent(Q(".tooltip-inner",t),this.getTitle()),t.classList.remove("fade","show")},a.setElementContent=function(t,e){if(null!==t)return"object"==typeof e&&g(e)?(e.jquery&&(e=e[0]),void(this.config.html?e.parentNode!==t&&(t.innerHTML="",t.appendChild(e)):t.textContent=e.textContent)):void(this.config.html?(this.config.sanitize&&(e=bt(e,this.config.allowList,this.config.sanitizeFn)),t.innerHTML=e):t.textContent=e)},a.getTitle=function(){var t=this._element.getAttribute("data-bs-original-title");return t||(t="function"==typeof this.config.title?this.config.title.call(this._element):this.config.title),t},a.updateAttachment=function(t){return"right"===t?"end":"left"===t?"start":t},a._initializeOnDelegatedTarget=function(t,e){var n=this.constructor.DATA_KEY;return(e=e||L(t.delegateTarget,n))||(e=new this.constructor(t.delegateTarget,this._getDelegateConfig()),k(t.delegateTarget,n,e)),e},a._getOffset=function(){var t=this,e=this.config.offset;return"string"==typeof e?e.split(",").map((function(t){return Number.parseInt(t,10)})):"function"==typeof e?function(n){return e(n,t._element)}:e},a._getPopperConfig=function(t){var e=this,n={placement:t,modifiers:[{name:"flip",options:{altBoundary:!0,fallbackPlacements:this.config.fallbackPlacements}},{name:"offset",options:{offset:this._getOffset()}},{name:"preventOverflow",options:{boundary:this.config.boundary}},{name:"arrow",options:{element:"."+this.constructor.NAME+"-arrow"}},{name:"onChange",enabled:!0,phase:"afterWrite",fn:function(t){return e._handlePopperPlacementChange(t)}}],onFirstUpdate:function(t){t.options.placement!==t.placement&&e._handlePopperPlacementChange(t)}};return s({},n,"function"==typeof this.config.popperConfig?this.config.popperConfig(n):this.config.popperConfig)},a._addAttachmentClass=function(t){this.getTipElement().classList.add("bs-tooltip-"+this.updateAttachment(t))},a._getContainer=function(){return!1===this.config.container?document.body:g(this.config.container)?this.config.container:Q(this.config.container)},a._getAttachment=function(t){return Tt[t.toUpperCase()]},a._setListeners=function(){var t=this;this.config.trigger.split(" ").forEach((function(e){if("click"===e)K.on(t._element,t.constructor.Event.CLICK,t.config.selector,(function(e){return t.toggle(e)}));else if("manual"!==e){var n="hover"===e?t.constructor.Event.MOUSEENTER:t.constructor.Event.FOCUSIN,i="hover"===e?t.constructor.Event.MOUSELEAVE:t.constructor.Event.FOCUSOUT;K.on(t._element,n,t.config.selector,(function(e){return t._enter(e)})),K.on(t._element,i,t.config.selector,(function(e){return t._leave(e)}))}})),this._hideModalHandler=function(){t._element&&t.hide()},K.on(this._element.closest(".modal"),"hide.bs.modal",this._hideModalHandler),this.config.selector?this.config=s({},this.config,{trigger:"manual",selector:""}):this._fixTitle()},a._fixTitle=function(){var t=this._element.getAttribute("title"),e=typeof this._element.getAttribute("data-bs-original-title");(t||"string"!==e)&&(this._element.setAttribute("data-bs-original-title",t||""),!t||this._element.getAttribute("aria-label")||this._element.textContent||this._element.setAttribute("aria-label",t),this._element.setAttribute("title",""))},a._enter=function(t,e){e=this._initializeOnDelegatedTarget(t,e),t&&(e._activeTrigger["focusin"===t.type?"focus":"hover"]=!0),e.getTipElement().classList.contains("show")||"show"===e._hoverState?e._hoverState="show":(clearTimeout(e._timeout),e._hoverState="show",e.config.delay&&e.config.delay.show?e._timeout=setTimeout((function(){"show"===e._hoverState&&e.show()}),e.config.delay.show):e.show())},a._leave=function(t,e){e=this._initializeOnDelegatedTarget(t,e),t&&(e._activeTrigger["focusout"===t.type?"focus":"hover"]=!1),e._isWithActiveTrigger()||(clearTimeout(e._timeout),e._hoverState="out",e.config.delay&&e.config.delay.hide?e._timeout=setTimeout((function(){"out"===e._hoverState&&e.hide()}),e.config.delay.hide):e.hide())},a._isWithActiveTrigger=function(){for(var t in this._activeTrigger)if(this._activeTrigger[t])return!0;return!1},a._getConfig=function(t){var e=X.getDataAttributes(this._element);return Object.keys(e).forEach((function(t){wt.has(t)&&delete e[t]})),t&&"object"==typeof t.container&&t.container.jquery&&(t.container=t.container[0]),"number"==typeof(t=s({},this.constructor.Default,e,"object"==typeof t&&t?t:{})).delay&&(t.delay={show:t.delay,hide:t.delay}),"number"==typeof t.title&&(t.title=t.title.toString()),"number"==typeof t.content&&(t.content=t.content.toString()),_("tooltip",t,this.constructor.DefaultType),t.sanitize&&(t.template=bt(t.template,t.allowList,t.sanitizeFn)),t},a._getDelegateConfig=function(){var t={};if(this.config)for(var e in this.config)this.constructor.Default[e]!==this.config[e]&&(t[e]=this.config[e]);return t},a._cleanTipClass=function(){var t=this.getTipElement(),e=t.getAttribute("class").match(yt);null!==e&&e.length>0&&e.map((function(t){return t.trim()})).forEach((function(e){return t.classList.remove(e)}))},a._handlePopperPlacementChange=function(t){var e=t.state;e&&(this.tip=e.elements.popper,this._cleanTipClass(),this._addAttachmentClass(this._getAttachment(e.placement)))},i.jQueryInterface=function(t){return this.each((function(){var e=L(this,"bs.tooltip"),n="object"==typeof t&&t;if((e||!/dispose|hide/.test(t))&&(e||(e=new i(this,n)),"string"==typeof t)){if(void 0===e[t])throw new TypeError('No method named "'+t+'"');e[t]()}}))},o(i,null,[{key:"Default",get:function(){return At}},{key:"NAME",get:function(){return"tooltip"}},{key:"DATA_KEY",get:function(){return"bs.tooltip"}},{key:"Event",get:function(){return kt}},{key:"EVENT_KEY",get:function(){return".bs.tooltip"}},{key:"DefaultType",get:function(){return Et}}]),i}(W);T("tooltip",Lt);var Ct=new RegExp("(^|\\s)bs-popover\\S+","g"),Dt=s({},Lt.Default,{placement:"right",offset:[0,8],trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="popover-arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>'}),St=s({},Lt.DefaultType,{content:"(string|element|function)"}),Nt={HIDE:"hide.bs.popover",HIDDEN:"hidden.bs.popover",SHOW:"show.bs.popover",SHOWN:"shown.bs.popover",INSERTED:"inserted.bs.popover",CLICK:"click.bs.popover",FOCUSIN:"focusin.bs.popover",FOCUSOUT:"focusout.bs.popover",MOUSEENTER:"mouseenter.bs.popover",MOUSELEAVE:"mouseleave.bs.popover"},Ot=function(t){function e(){return t.apply(this,arguments)||this}r(e,t);var n=e.prototype;return n.isWithContent=function(){return this.getTitle()||this._getContent()},n.setContent=function(){var t=this.getTipElement();this.setElementContent(Q(".popover-header",t),this.getTitle());var e=this._getContent();"function"==typeof e&&(e=e.call(this._element)),this.setElementContent(Q(".popover-body",t),e),t.classList.remove("fade","show")},n._addAttachmentClass=function(t){this.getTipElement().classList.add("bs-popover-"+this.updateAttachment(t))},n._getContent=function(){return this._element.getAttribute("data-bs-content")||this.config.content},n._cleanTipClass=function(){var t=this.getTipElement(),e=t.getAttribute("class").match(Ct);null!==e&&e.length>0&&e.map((function(t){return t.trim()})).forEach((function(e){return t.classList.remove(e)}))},e.jQueryInterface=function(t){return this.each((function(){var n=L(this,"bs.popover"),i="object"==typeof t?t:null;if((n||!/dispose|hide/.test(t))&&(n||(n=new e(this,i),k(this,"bs.popover",n)),"string"==typeof t)){if(void 0===n[t])throw new TypeError('No method named "'+t+'"');n[t]()}}))},o(e,null,[{key:"Default",get:function(){return Dt}},{key:"NAME",get:function(){return"popover"}},{key:"DATA_KEY",get:function(){return"bs.popover"}},{key:"Event",get:function(){return Nt}},{key:"EVENT_KEY",get:function(){return".bs.popover"}},{key:"DefaultType",get:function(){return St}}]),e}(Lt);T("popover",Ot);var It={offset:10,method:"auto",target:""},jt={offset:"number",method:"string",target:"(string|element)"},Pt=function(t){function e(e,n){var i;return(i=t.call(this,e)||this)._scrollElement="BODY"===e.tagName?window:e,i._config=i._getConfig(n),i._selector=i._config.target+" .nav-link, "+i._config.target+" .list-group-item, "+i._config.target+" .dropdown-item",i._offsets=[],i._targets=[],i._activeTarget=null,i._scrollHeight=0,K.on(i._scrollElement,"scroll.bs.scrollspy",(function(){return i._process()})),i.refresh(),i._process(),i}r(e,t);var n=e.prototype;return n.refresh=function(){var t=this,e=this._scrollElement===this._scrollElement.window?"offset":"position",n="auto"===this._config.method?e:this._config.method,i="position"===n?this._getScrollTop():0;this._offsets=[],this._targets=[],this._scrollHeight=this._getScrollHeight(),q(this._selector).map((function(t){var e=h(t),o=e?Q(e):null;if(o){var s=o.getBoundingClientRect();if(s.width||s.height)return[X[n](o).top+i,e]}return null})).filter((function(t){return t})).sort((function(t,e){return t[0]-e[0]})).forEach((function(e){t._offsets.push(e[0]),t._targets.push(e[1])}))},n.dispose=function(){t.prototype.dispose.call(this),K.off(this._scrollElement,".bs.scrollspy"),this._scrollElement=null,this._config=null,this._selector=null,this._offsets=null,this._targets=null,this._activeTarget=null,this._scrollHeight=null},n._getConfig=function(t){if("string"!=typeof(t=s({},It,"object"==typeof t&&t?t:{})).target&&g(t.target)){var e=t.target.id;e||(e=c("scrollspy"),t.target.id=e),t.target="#"+e}return _("scrollspy",t,jt),t},n._getScrollTop=function(){return this._scrollElement===window?this._scrollElement.pageYOffset:this._scrollElement.scrollTop},n._getScrollHeight=function(){return this._scrollElement.scrollHeight||Math.max(document.body.scrollHeight,document.documentElement.scrollHeight)},n._getOffsetHeight=function(){return this._scrollElement===window?window.innerHeight:this._scrollElement.getBoundingClientRect().height},n._process=function(){var t=this._getScrollTop()+this._config.offset,e=this._getScrollHeight(),n=this._config.offset+e-this._getOffsetHeight();if(this._scrollHeight!==e&&this.refresh(),t>=n){var i=this._targets[this._targets.length-1];this._activeTarget!==i&&this._activate(i)}else{if(this._activeTarget&&t<this._offsets[0]&&this._offsets[0]>0)return this._activeTarget=null,void this._clear();for(var o=this._offsets.length;o--;)this._activeTarget!==this._targets[o]&&t>=this._offsets[o]&&(void 0===this._offsets[o+1]||t<this._offsets[o+1])&&this._activate(this._targets[o])}},n._activate=function(t){this._activeTarget=t,this._clear();var e=this._selector.split(",").map((function(e){return e+'[data-bs-target="'+t+'"],'+e+'[href="'+t+'"]'})),n=Q(e.join(","));n.classList.contains("dropdown-item")?(Q(".dropdown-toggle",n.closest(".dropdown")).classList.add("active"),n.classList.add("active")):(n.classList.add("active"),function(t,e){for(var n=[],i=t.parentNode;i&&i.nodeType===Node.ELEMENT_NODE&&3!==i.nodeType;)i.matches(e)&&n.push(i),i=i.parentNode;return n}(n,".nav, .list-group").forEach((function(t){$(t,".nav-link, .list-group-item").forEach((function(t){return t.classList.add("active")})),$(t,".nav-item").forEach((function(t){V(t,".nav-link").forEach((function(t){return t.classList.add("active")}))}))}))),K.trigger(this._scrollElement,"activate.bs.scrollspy",{relatedTarget:t})},n._clear=function(){q(this._selector).filter((function(t){return t.classList.contains("active")})).forEach((function(t){return t.classList.remove("active")}))},e.jQueryInterface=function(t){return this.each((function(){var n=L(this,"bs.scrollspy");if(n||(n=new e(this,"object"==typeof t&&t)),"string"==typeof t){if(void 0===n[t])throw new TypeError('No method named "'+t+'"');n[t]()}}))},o(e,null,[{key:"Default",get:function(){return It}},{key:"DATA_KEY",get:function(){return"bs.scrollspy"}}]),e}(W);K.on(window,"load.bs.scrollspy.data-api",(function(){q('[data-bs-spy="scroll"]').forEach((function(t){return new Pt(t,X.getDataAttributes(t))}))})),T("scrollspy",Pt);var xt=function(t){function e(){return t.apply(this,arguments)||this}r(e,t);var n=e.prototype;return n.show=function(){var t=this;if(!(this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE&&this._element.classList.contains("active")||this._element.classList.contains("disabled"))){var e,n=d(this._element),i=this._element.closest(".nav, .list-group");if(i){var o="UL"===i.nodeName||"OL"===i.nodeName?":scope > li > .active":".active";e=(e=q(o,i))[e.length-1]}var s=e?K.trigger(e,"hide.bs.tab",{relatedTarget:this._element}):null;if(!(K.trigger(this._element,"show.bs.tab",{relatedTarget:e}).defaultPrevented||null!==s&&s.defaultPrevented)){this._activate(this._element,i);var r=function(){K.trigger(e,"hidden.bs.tab",{relatedTarget:t._element}),K.trigger(t._element,"shown.bs.tab",{relatedTarget:e})};n?this._activate(n,n.parentNode,r):r()}}},n._activate=function(t,e,n){var i=this,o=(!e||"UL"!==e.nodeName&&"OL"!==e.nodeName?V(e,".active"):q(":scope > li > .active",e))[0],s=n&&o&&o.classList.contains("fade"),r=function(){return i._transitionComplete(t,o,n)};if(o&&s){var a=f(o);o.classList.remove("show"),K.one(o,"transitionend",r),m(o,a)}else r()},n._transitionComplete=function(t,e,n){if(e){e.classList.remove("active");var i=Q(":scope > .dropdown-menu .active",e.parentNode);i&&i.classList.remove("active"),"tab"===e.getAttribute("role")&&e.setAttribute("aria-selected",!1)}t.classList.add("active"),"tab"===t.getAttribute("role")&&t.setAttribute("aria-selected",!0),y(t),t.classList.contains("fade")&&t.classList.add("show"),t.parentNode&&t.parentNode.classList.contains("dropdown-menu")&&(t.closest(".dropdown")&&q(".dropdown-toggle").forEach((function(t){return t.classList.add("active")})),t.setAttribute("aria-expanded",!0)),n&&n()},e.jQueryInterface=function(t){return this.each((function(){var n=L(this,"bs.tab")||new e(this);if("string"==typeof t){if(void 0===n[t])throw new TypeError('No method named "'+t+'"');n[t]()}}))},o(e,null,[{key:"DATA_KEY",get:function(){return"bs.tab"}}]),e}(W);K.on(document,"click.bs.tab.data-api",'[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]',(function(t){t.preventDefault(),(L(this,"bs.tab")||new xt(this)).show()})),T("tab",xt);var Ht={animation:"boolean",autohide:"boolean",delay:"number"},Bt={animation:!0,autohide:!0,delay:5e3},Mt=function(t){function e(e,n){var i;return(i=t.call(this,e)||this)._config=i._getConfig(n),i._timeout=null,i._setListeners(),i}r(e,t);var n=e.prototype;return n.show=function(){var t=this;if(!K.trigger(this._element,"show.bs.toast").defaultPrevented){this._clearTimeout(),this._config.animation&&this._element.classList.add("fade");var e=function(){t._element.classList.remove("showing"),t._element.classList.add("show"),K.trigger(t._element,"shown.bs.toast"),t._config.autohide&&(t._timeout=setTimeout((function(){t.hide()}),t._config.delay))};if(this._element.classList.remove("hide"),y(this._element),this._element.classList.add("showing"),this._config.animation){var n=f(this._element);K.one(this._element,"transitionend",e),m(this._element,n)}else e()}},n.hide=function(){var t=this;if(this._element.classList.contains("show")&&!K.trigger(this._element,"hide.bs.toast").defaultPrevented){var e=function(){t._element.classList.add("hide"),K.trigger(t._element,"hidden.bs.toast")};if(this._element.classList.remove("show"),this._config.animation){var n=f(this._element);K.one(this._element,"transitionend",e),m(this._element,n)}else e()}},n.dispose=function(){this._clearTimeout(),this._element.classList.contains("show")&&this._element.classList.remove("show"),K.off(this._element,"click.dismiss.bs.toast"),t.prototype.dispose.call(this),this._config=null},n._getConfig=function(t){return t=s({},Bt,X.getDataAttributes(this._element),"object"==typeof t&&t?t:{}),_("toast",t,this.constructor.DefaultType),t},n._setListeners=function(){var t=this;K.on(this._element,"click.dismiss.bs.toast",'[data-bs-dismiss="toast"]',(function(){return t.hide()}))},n._clearTimeout=function(){clearTimeout(this._timeout),this._timeout=null},e.jQueryInterface=function(t){return this.each((function(){var n=L(this,"bs.toast");if(n||(n=new e(this,"object"==typeof t&&t)),"string"==typeof t){if(void 0===n[t])throw new TypeError('No method named "'+t+'"');n[t](this)}}))},o(e,null,[{key:"DefaultType",get:function(){return Ht}},{key:"Default",get:function(){return Bt}},{key:"DATA_KEY",get:function(){return"bs.toast"}}]),e}(W);return T("toast",Mt),{Alert:U,Button:F,Carousel:J,Collapse:nt,Dropdown:dt,Modal:gt,Popover:Ot,ScrollSpy:Pt,Tab:xt,Toast:Mt,Tooltip:Lt}})); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(require("@popperjs/core")):"function"==typeof define&&define.amd?define(["@popperjs/core"],e):(t="undefined"!=typeof globalThis?globalThis:t||self).bootstrap=e(t.Popper)}(this,(function(t){"use strict";function e(t){if(t&&t.__esModule)return t;var e=Object.create(null);return t&&Object.keys(t).forEach((function(s){if("default"!==s){var i=Object.getOwnPropertyDescriptor(t,s);Object.defineProperty(e,s,i.get?i:{enumerable:!0,get:function(){return t[s]}})}})),e.default=t,Object.freeze(e)}var s=e(t);const i=t=>{do{t+=Math.floor(1e6*Math.random())}while(document.getElementById(t));return t},n=t=>{let e=t.getAttribute("data-bs-target");if(!e||"#"===e){let s=t.getAttribute("href");if(!s||!s.includes("#")&&!s.startsWith("."))return null;s.includes("#")&&!s.startsWith("#")&&(s="#"+s.split("#")[1]),e=s&&"#"!==s?s.trim():null}return e},o=t=>{const e=n(t);return e&&document.querySelector(e)?e:null},r=t=>{const e=n(t);return e?document.querySelector(e):null},a=t=>{if(!t)return 0;let{transitionDuration:e,transitionDelay:s}=window.getComputedStyle(t);const i=Number.parseFloat(e),n=Number.parseFloat(s);return i||n?(e=e.split(",")[0],s=s.split(",")[0],1e3*(Number.parseFloat(e)+Number.parseFloat(s))):0},l=t=>{t.dispatchEvent(new Event("transitionend"))},c=t=>(t[0]||t).nodeType,h=(t,e)=>{let s=!1;const i=e+5;t.addEventListener("transitionend",(function e(){s=!0,t.removeEventListener("transitionend",e)})),setTimeout(()=>{s||l(t)},i)},d=(t,e,s)=>{Object.keys(s).forEach(i=>{const n=s[i],o=e[i],r=o&&c(o)?"element":null==(a=o)?""+a:{}.toString.call(a).match(/\s([a-z]+)/i)[1].toLowerCase();var a;if(!new RegExp(n).test(r))throw new TypeError(t.toUpperCase()+": "+`Option "${i}" provided type "${r}" `+`but expected type "${n}".`)})},u=t=>{if(!t)return!1;if(t.style&&t.parentNode&&t.parentNode.style){const e=getComputedStyle(t),s=getComputedStyle(t.parentNode);return"none"!==e.display&&"none"!==s.display&&"hidden"!==e.visibility}return!1},g=t=>!t||t.nodeType!==Node.ELEMENT_NODE||!!t.classList.contains("disabled")||(void 0!==t.disabled?t.disabled:t.hasAttribute("disabled")&&"false"!==t.getAttribute("disabled")),f=t=>{if(!document.documentElement.attachShadow)return null;if("function"==typeof t.getRootNode){const e=t.getRootNode();return e instanceof ShadowRoot?e:null}return t instanceof ShadowRoot?t:t.parentNode?f(t.parentNode):null},p=()=>function(){},m=t=>t.offsetHeight,_=()=>{const{jQuery:t}=window;return t&&!document.body.hasAttribute("data-bs-no-jquery")?t:null},b=()=>"rtl"===document.documentElement.dir,v=(t,e)=>{var s;s=()=>{const s=_();if(s){const i=s.fn[t];s.fn[t]=e.jQueryInterface,s.fn[t].Constructor=e,s.fn[t].noConflict=()=>(s.fn[t]=i,e.jQueryInterface)}},"loading"===document.readyState?document.addEventListener("DOMContentLoaded",s):s()},y=new Map;var w={set(t,e,s){y.has(t)||y.set(t,new Map);const i=y.get(t);i.has(e)||0===i.size?i.set(e,s):console.error(`Bootstrap doesn't allow more than one instance per element. Bound instance: ${Array.from(i.keys())[0]}.`)},get:(t,e)=>y.has(t)&&y.get(t).get(e)||null,remove(t,e){if(!y.has(t))return;const s=y.get(t);s.delete(e),0===s.size&&y.delete(t)}};const E=/[^.]*(?=\..*)\.|.*/,T=/\..*/,A=/::\d+$/,L={};let k=1;const C={mouseenter:"mouseover",mouseleave:"mouseout"},D=new Set(["click","dblclick","mouseup","mousedown","contextmenu","mousewheel","DOMMouseScroll","mouseover","mouseout","mousemove","selectstart","selectend","keydown","keypress","keyup","orientationchange","touchstart","touchmove","touchend","touchcancel","pointerdown","pointermove","pointerup","pointerleave","pointercancel","gesturestart","gesturechange","gestureend","focus","blur","change","reset","select","submit","focusin","focusout","load","unload","beforeunload","resize","move","DOMContentLoaded","readystatechange","error","abort","scroll"]);function S(t,e){return e&&`${e}::${k++}`||t.uidEvent||k++}function N(t){const e=S(t);return t.uidEvent=e,L[e]=L[e]||{},L[e]}function O(t,e,s=null){const i=Object.keys(t);for(let n=0,o=i.length;n<o;n++){const o=t[i[n]];if(o.originalHandler===e&&o.delegationSelector===s)return o}return null}function x(t,e,s){const i="string"==typeof e,n=i?s:e;let o=t.replace(T,"");const r=C[o];return r&&(o=r),D.has(o)||(o=t),[i,n,o]}function I(t,e,s,i,n){if("string"!=typeof e||!t)return;s||(s=i,i=null);const[o,r,a]=x(e,s,i),l=N(t),c=l[a]||(l[a]={}),h=O(c,r,o?s:null);if(h)return void(h.oneOff=h.oneOff&&n);const d=S(r,e.replace(E,"")),u=o?function(t,e,s){return function i(n){const o=t.querySelectorAll(e);for(let{target:e}=n;e&&e!==this;e=e.parentNode)for(let r=o.length;r--;)if(o[r]===e)return n.delegateTarget=e,i.oneOff&&P.off(t,n.type,s),s.apply(e,[n]);return null}}(t,s,i):function(t,e){return function s(i){return i.delegateTarget=t,s.oneOff&&P.off(t,i.type,e),e.apply(t,[i])}}(t,s);u.delegationSelector=o?s:null,u.originalHandler=r,u.oneOff=n,u.uidEvent=d,c[d]=u,t.addEventListener(a,u,o)}function j(t,e,s,i,n){const o=O(e[s],i,n);o&&(t.removeEventListener(s,o,Boolean(n)),delete e[s][o.uidEvent])}const P={on(t,e,s,i){I(t,e,s,i,!1)},one(t,e,s,i){I(t,e,s,i,!0)},off(t,e,s,i){if("string"!=typeof e||!t)return;const[n,o,r]=x(e,s,i),a=r!==e,l=N(t),c=e.startsWith(".");if(void 0!==o){if(!l||!l[r])return;return void j(t,l,r,o,n?s:null)}c&&Object.keys(l).forEach(s=>{!function(t,e,s,i){const n=e[s]||{};Object.keys(n).forEach(o=>{if(o.includes(i)){const i=n[o];j(t,e,s,i.originalHandler,i.delegationSelector)}})}(t,l,s,e.slice(1))});const h=l[r]||{};Object.keys(h).forEach(s=>{const i=s.replace(A,"");if(!a||e.includes(i)){const e=h[s];j(t,l,r,e.originalHandler,e.delegationSelector)}})},trigger(t,e,s){if("string"!=typeof e||!t)return null;const i=_(),n=e.replace(T,""),o=e!==n,r=D.has(n);let a,l=!0,c=!0,h=!1,d=null;return o&&i&&(a=i.Event(e,s),i(t).trigger(a),l=!a.isPropagationStopped(),c=!a.isImmediatePropagationStopped(),h=a.isDefaultPrevented()),r?(d=document.createEvent("HTMLEvents"),d.initEvent(n,l,!0)):d=new CustomEvent(e,{bubbles:l,cancelable:!0}),void 0!==s&&Object.keys(s).forEach(t=>{Object.defineProperty(d,t,{get:()=>s[t]})}),h&&d.preventDefault(),c&&t.dispatchEvent(d),d.defaultPrevented&&void 0!==a&&a.preventDefault(),d}};class M{constructor(t){(t="string"==typeof t?document.querySelector(t):t)&&(this._element=t,w.set(this._element,this.constructor.DATA_KEY,this))}dispose(){w.remove(this._element,this.constructor.DATA_KEY),this._element=null}static getInstance(t){return w.get(t,this.DATA_KEY)}static get VERSION(){return"5.0.0-beta3"}}class H extends M{static get DATA_KEY(){return"bs.alert"}close(t){const e=t?this._getRootElement(t):this._element,s=this._triggerCloseEvent(e);null===s||s.defaultPrevented||this._removeElement(e)}_getRootElement(t){return r(t)||t.closest(".alert")}_triggerCloseEvent(t){return P.trigger(t,"close.bs.alert")}_removeElement(t){if(t.classList.remove("show"),!t.classList.contains("fade"))return void this._destroyElement(t);const e=a(t);P.one(t,"transitionend",()=>this._destroyElement(t)),h(t,e)}_destroyElement(t){t.parentNode&&t.parentNode.removeChild(t),P.trigger(t,"closed.bs.alert")}static jQueryInterface(t){return this.each((function(){let e=w.get(this,"bs.alert");e||(e=new H(this)),"close"===t&&e[t](this)}))}static handleDismiss(t){return function(e){e&&e.preventDefault(),t.close(this)}}}P.on(document,"click.bs.alert.data-api",'[data-bs-dismiss="alert"]',H.handleDismiss(new H)),v("alert",H);class R extends M{static get DATA_KEY(){return"bs.button"}toggle(){this._element.setAttribute("aria-pressed",this._element.classList.toggle("active"))}static jQueryInterface(t){return this.each((function(){let e=w.get(this,"bs.button");e||(e=new R(this)),"toggle"===t&&e[t]()}))}}function B(t){return"true"===t||"false"!==t&&(t===Number(t).toString()?Number(t):""===t||"null"===t?null:t)}function W(t){return t.replace(/[A-Z]/g,t=>"-"+t.toLowerCase())}P.on(document,"click.bs.button.data-api",'[data-bs-toggle="button"]',t=>{t.preventDefault();const e=t.target.closest('[data-bs-toggle="button"]');let s=w.get(e,"bs.button");s||(s=new R(e)),s.toggle()}),v("button",R);const $={setDataAttribute(t,e,s){t.setAttribute("data-bs-"+W(e),s)},removeDataAttribute(t,e){t.removeAttribute("data-bs-"+W(e))},getDataAttributes(t){if(!t)return{};const e={};return Object.keys(t.dataset).filter(t=>t.startsWith("bs")).forEach(s=>{let i=s.replace(/^bs/,"");i=i.charAt(0).toLowerCase()+i.slice(1,i.length),e[i]=B(t.dataset[s])}),e},getDataAttribute:(t,e)=>B(t.getAttribute("data-bs-"+W(e))),offset(t){const e=t.getBoundingClientRect();return{top:e.top+document.body.scrollTop,left:e.left+document.body.scrollLeft}},position:t=>({top:t.offsetTop,left:t.offsetLeft})},U={find:(t,e=document.documentElement)=>[].concat(...Element.prototype.querySelectorAll.call(e,t)),findOne:(t,e=document.documentElement)=>Element.prototype.querySelector.call(e,t),children:(t,e)=>[].concat(...t.children).filter(t=>t.matches(e)),parents(t,e){const s=[];let i=t.parentNode;for(;i&&i.nodeType===Node.ELEMENT_NODE&&3!==i.nodeType;)i.matches(e)&&s.push(i),i=i.parentNode;return s},prev(t,e){let s=t.previousElementSibling;for(;s;){if(s.matches(e))return[s];s=s.previousElementSibling}return[]},next(t,e){let s=t.nextElementSibling;for(;s;){if(s.matches(e))return[s];s=s.nextElementSibling}return[]}},F={interval:5e3,keyboard:!0,slide:!1,pause:"hover",wrap:!0,touch:!0},K={interval:"(number|boolean)",keyboard:"boolean",slide:"(boolean|string)",pause:"(string|boolean)",wrap:"boolean",touch:"boolean"},z="next",Y="prev",q="left",Q="right";class X extends M{constructor(t,e){super(t),this._items=null,this._interval=null,this._activeElement=null,this._isPaused=!1,this._isSliding=!1,this.touchTimeout=null,this.touchStartX=0,this.touchDeltaX=0,this._config=this._getConfig(e),this._indicatorsElement=U.findOne(".carousel-indicators",this._element),this._touchSupported="ontouchstart"in document.documentElement||navigator.maxTouchPoints>0,this._pointerEvent=Boolean(window.PointerEvent),this._addEventListeners()}static get Default(){return F}static get DATA_KEY(){return"bs.carousel"}next(){this._isSliding||this._slide(z)}nextWhenVisible(){!document.hidden&&u(this._element)&&this.next()}prev(){this._isSliding||this._slide(Y)}pause(t){t||(this._isPaused=!0),U.findOne(".carousel-item-next, .carousel-item-prev",this._element)&&(l(this._element),this.cycle(!0)),clearInterval(this._interval),this._interval=null}cycle(t){t||(this._isPaused=!1),this._interval&&(clearInterval(this._interval),this._interval=null),this._config&&this._config.interval&&!this._isPaused&&(this._updateInterval(),this._interval=setInterval((document.visibilityState?this.nextWhenVisible:this.next).bind(this),this._config.interval))}to(t){this._activeElement=U.findOne(".active.carousel-item",this._element);const e=this._getItemIndex(this._activeElement);if(t>this._items.length-1||t<0)return;if(this._isSliding)return void P.one(this._element,"slid.bs.carousel",()=>this.to(t));if(e===t)return this.pause(),void this.cycle();const s=t>e?z:Y;this._slide(s,this._items[t])}dispose(){P.off(this._element,".bs.carousel"),this._items=null,this._config=null,this._interval=null,this._isPaused=null,this._isSliding=null,this._activeElement=null,this._indicatorsElement=null,super.dispose()}_getConfig(t){return t={...F,...t},d("carousel",t,K),t}_handleSwipe(){const t=Math.abs(this.touchDeltaX);if(t<=40)return;const e=t/this.touchDeltaX;this.touchDeltaX=0,e&&this._slide(e>0?Q:q)}_addEventListeners(){this._config.keyboard&&P.on(this._element,"keydown.bs.carousel",t=>this._keydown(t)),"hover"===this._config.pause&&(P.on(this._element,"mouseenter.bs.carousel",t=>this.pause(t)),P.on(this._element,"mouseleave.bs.carousel",t=>this.cycle(t))),this._config.touch&&this._touchSupported&&this._addTouchEventListeners()}_addTouchEventListeners(){const t=t=>{!this._pointerEvent||"pen"!==t.pointerType&&"touch"!==t.pointerType?this._pointerEvent||(this.touchStartX=t.touches[0].clientX):this.touchStartX=t.clientX},e=t=>{this.touchDeltaX=t.touches&&t.touches.length>1?0:t.touches[0].clientX-this.touchStartX},s=t=>{!this._pointerEvent||"pen"!==t.pointerType&&"touch"!==t.pointerType||(this.touchDeltaX=t.clientX-this.touchStartX),this._handleSwipe(),"hover"===this._config.pause&&(this.pause(),this.touchTimeout&&clearTimeout(this.touchTimeout),this.touchTimeout=setTimeout(t=>this.cycle(t),500+this._config.interval))};U.find(".carousel-item img",this._element).forEach(t=>{P.on(t,"dragstart.bs.carousel",t=>t.preventDefault())}),this._pointerEvent?(P.on(this._element,"pointerdown.bs.carousel",e=>t(e)),P.on(this._element,"pointerup.bs.carousel",t=>s(t)),this._element.classList.add("pointer-event")):(P.on(this._element,"touchstart.bs.carousel",e=>t(e)),P.on(this._element,"touchmove.bs.carousel",t=>e(t)),P.on(this._element,"touchend.bs.carousel",t=>s(t)))}_keydown(t){/input|textarea/i.test(t.target.tagName)||("ArrowLeft"===t.key?(t.preventDefault(),this._slide(q)):"ArrowRight"===t.key&&(t.preventDefault(),this._slide(Q)))}_getItemIndex(t){return this._items=t&&t.parentNode?U.find(".carousel-item",t.parentNode):[],this._items.indexOf(t)}_getItemByOrder(t,e){const s=t===z,i=t===Y,n=this._getItemIndex(e),o=this._items.length-1;if((i&&0===n||s&&n===o)&&!this._config.wrap)return e;const r=(n+(i?-1:1))%this._items.length;return-1===r?this._items[this._items.length-1]:this._items[r]}_triggerSlideEvent(t,e){const s=this._getItemIndex(t),i=this._getItemIndex(U.findOne(".active.carousel-item",this._element));return P.trigger(this._element,"slide.bs.carousel",{relatedTarget:t,direction:e,from:i,to:s})}_setActiveIndicatorElement(t){if(this._indicatorsElement){const e=U.findOne(".active",this._indicatorsElement);e.classList.remove("active"),e.removeAttribute("aria-current");const s=U.find("[data-bs-target]",this._indicatorsElement);for(let e=0;e<s.length;e++)if(Number.parseInt(s[e].getAttribute("data-bs-slide-to"),10)===this._getItemIndex(t)){s[e].classList.add("active"),s[e].setAttribute("aria-current","true");break}}}_updateInterval(){const t=this._activeElement||U.findOne(".active.carousel-item",this._element);if(!t)return;const e=Number.parseInt(t.getAttribute("data-bs-interval"),10);e?(this._config.defaultInterval=this._config.defaultInterval||this._config.interval,this._config.interval=e):this._config.interval=this._config.defaultInterval||this._config.interval}_slide(t,e){const s=this._directionToOrder(t),i=U.findOne(".active.carousel-item",this._element),n=this._getItemIndex(i),o=e||this._getItemByOrder(s,i),r=this._getItemIndex(o),l=Boolean(this._interval),c=s===z,d=c?"carousel-item-start":"carousel-item-end",u=c?"carousel-item-next":"carousel-item-prev",g=this._orderToDirection(s);if(o&&o.classList.contains("active"))this._isSliding=!1;else if(!this._triggerSlideEvent(o,g).defaultPrevented&&i&&o){if(this._isSliding=!0,l&&this.pause(),this._setActiveIndicatorElement(o),this._activeElement=o,this._element.classList.contains("slide")){o.classList.add(u),m(o),i.classList.add(d),o.classList.add(d);const t=a(i);P.one(i,"transitionend",()=>{o.classList.remove(d,u),o.classList.add("active"),i.classList.remove("active",u,d),this._isSliding=!1,setTimeout(()=>{P.trigger(this._element,"slid.bs.carousel",{relatedTarget:o,direction:g,from:n,to:r})},0)}),h(i,t)}else i.classList.remove("active"),o.classList.add("active"),this._isSliding=!1,P.trigger(this._element,"slid.bs.carousel",{relatedTarget:o,direction:g,from:n,to:r});l&&this.cycle()}}_directionToOrder(t){return[Q,q].includes(t)?b()?t===Q?Y:z:t===Q?z:Y:t}_orderToDirection(t){return[z,Y].includes(t)?b()?t===z?q:Q:t===z?Q:q:t}static carouselInterface(t,e){let s=w.get(t,"bs.carousel"),i={...F,...$.getDataAttributes(t)};"object"==typeof e&&(i={...i,...e});const n="string"==typeof e?e:i.slide;if(s||(s=new X(t,i)),"number"==typeof e)s.to(e);else if("string"==typeof n){if(void 0===s[n])throw new TypeError(`No method named "${n}"`);s[n]()}else i.interval&&i.ride&&(s.pause(),s.cycle())}static jQueryInterface(t){return this.each((function(){X.carouselInterface(this,t)}))}static dataApiClickHandler(t){const e=r(this);if(!e||!e.classList.contains("carousel"))return;const s={...$.getDataAttributes(e),...$.getDataAttributes(this)},i=this.getAttribute("data-bs-slide-to");i&&(s.interval=!1),X.carouselInterface(e,s),i&&w.get(e,"bs.carousel").to(i),t.preventDefault()}}P.on(document,"click.bs.carousel.data-api","[data-bs-slide], [data-bs-slide-to]",X.dataApiClickHandler),P.on(window,"load.bs.carousel.data-api",()=>{const t=U.find('[data-bs-ride="carousel"]');for(let e=0,s=t.length;e<s;e++)X.carouselInterface(t[e],w.get(t[e],"bs.carousel"))}),v("carousel",X);const V={toggle:!0,parent:""},G={toggle:"boolean",parent:"(string|element)"};class Z extends M{constructor(t,e){super(t),this._isTransitioning=!1,this._config=this._getConfig(e),this._triggerArray=U.find(`[data-bs-toggle="collapse"][href="#${this._element.id}"],[data-bs-toggle="collapse"][data-bs-target="#${this._element.id}"]`);const s=U.find('[data-bs-toggle="collapse"]');for(let t=0,e=s.length;t<e;t++){const e=s[t],i=o(e),n=U.find(i).filter(t=>t===this._element);null!==i&&n.length&&(this._selector=i,this._triggerArray.push(e))}this._parent=this._config.parent?this._getParent():null,this._config.parent||this._addAriaAndCollapsedClass(this._element,this._triggerArray),this._config.toggle&&this.toggle()}static get Default(){return V}static get DATA_KEY(){return"bs.collapse"}toggle(){this._element.classList.contains("show")?this.hide():this.show()}show(){if(this._isTransitioning||this._element.classList.contains("show"))return;let t,e;this._parent&&(t=U.find(".show, .collapsing",this._parent).filter(t=>"string"==typeof this._config.parent?t.getAttribute("data-bs-parent")===this._config.parent:t.classList.contains("collapse")),0===t.length&&(t=null));const s=U.findOne(this._selector);if(t){const i=t.find(t=>s!==t);if(e=i?w.get(i,"bs.collapse"):null,e&&e._isTransitioning)return}if(P.trigger(this._element,"show.bs.collapse").defaultPrevented)return;t&&t.forEach(t=>{s!==t&&Z.collapseInterface(t,"hide"),e||w.set(t,"bs.collapse",null)});const i=this._getDimension();this._element.classList.remove("collapse"),this._element.classList.add("collapsing"),this._element.style[i]=0,this._triggerArray.length&&this._triggerArray.forEach(t=>{t.classList.remove("collapsed"),t.setAttribute("aria-expanded",!0)}),this.setTransitioning(!0);const n="scroll"+(i[0].toUpperCase()+i.slice(1)),o=a(this._element);P.one(this._element,"transitionend",()=>{this._element.classList.remove("collapsing"),this._element.classList.add("collapse","show"),this._element.style[i]="",this.setTransitioning(!1),P.trigger(this._element,"shown.bs.collapse")}),h(this._element,o),this._element.style[i]=this._element[n]+"px"}hide(){if(this._isTransitioning||!this._element.classList.contains("show"))return;if(P.trigger(this._element,"hide.bs.collapse").defaultPrevented)return;const t=this._getDimension();this._element.style[t]=this._element.getBoundingClientRect()[t]+"px",m(this._element),this._element.classList.add("collapsing"),this._element.classList.remove("collapse","show");const e=this._triggerArray.length;if(e>0)for(let t=0;t<e;t++){const e=this._triggerArray[t],s=r(e);s&&!s.classList.contains("show")&&(e.classList.add("collapsed"),e.setAttribute("aria-expanded",!1))}this.setTransitioning(!0),this._element.style[t]="";const s=a(this._element);P.one(this._element,"transitionend",()=>{this.setTransitioning(!1),this._element.classList.remove("collapsing"),this._element.classList.add("collapse"),P.trigger(this._element,"hidden.bs.collapse")}),h(this._element,s)}setTransitioning(t){this._isTransitioning=t}dispose(){super.dispose(),this._config=null,this._parent=null,this._triggerArray=null,this._isTransitioning=null}_getConfig(t){return(t={...V,...t}).toggle=Boolean(t.toggle),d("collapse",t,G),t}_getDimension(){return this._element.classList.contains("width")?"width":"height"}_getParent(){let{parent:t}=this._config;c(t)?void 0===t.jquery&&void 0===t[0]||(t=t[0]):t=U.findOne(t);const e=`[data-bs-toggle="collapse"][data-bs-parent="${t}"]`;return U.find(e,t).forEach(t=>{const e=r(t);this._addAriaAndCollapsedClass(e,[t])}),t}_addAriaAndCollapsedClass(t,e){if(!t||!e.length)return;const s=t.classList.contains("show");e.forEach(t=>{s?t.classList.remove("collapsed"):t.classList.add("collapsed"),t.setAttribute("aria-expanded",s)})}static collapseInterface(t,e){let s=w.get(t,"bs.collapse");const i={...V,...$.getDataAttributes(t),..."object"==typeof e&&e?e:{}};if(!s&&i.toggle&&"string"==typeof e&&/show|hide/.test(e)&&(i.toggle=!1),s||(s=new Z(t,i)),"string"==typeof e){if(void 0===s[e])throw new TypeError(`No method named "${e}"`);s[e]()}}static jQueryInterface(t){return this.each((function(){Z.collapseInterface(this,t)}))}}P.on(document,"click.bs.collapse.data-api",'[data-bs-toggle="collapse"]',(function(t){("A"===t.target.tagName||t.delegateTarget&&"A"===t.delegateTarget.tagName)&&t.preventDefault();const e=$.getDataAttributes(this),s=o(this);U.find(s).forEach(t=>{const s=w.get(t,"bs.collapse");let i;s?(null===s._parent&&"string"==typeof e.parent&&(s._config.parent=e.parent,s._parent=s._getParent()),i="toggle"):i=e,Z.collapseInterface(t,i)})})),v("collapse",Z);const J=new RegExp("ArrowUp|ArrowDown|Escape"),tt=b()?"top-end":"top-start",et=b()?"top-start":"top-end",st=b()?"bottom-end":"bottom-start",it=b()?"bottom-start":"bottom-end",nt=b()?"left-start":"right-start",ot=b()?"right-start":"left-start",rt={offset:[0,2],boundary:"clippingParents",reference:"toggle",display:"dynamic",popperConfig:null},at={offset:"(array|string|function)",boundary:"(string|element)",reference:"(string|element|object)",display:"string",popperConfig:"(null|object|function)"};class lt extends M{constructor(t,e){super(t),this._popper=null,this._config=this._getConfig(e),this._menu=this._getMenuElement(),this._inNavbar=this._detectNavbar(),this._addEventListeners()}static get Default(){return rt}static get DefaultType(){return at}static get DATA_KEY(){return"bs.dropdown"}toggle(){if(this._element.disabled||this._element.classList.contains("disabled"))return;const t=this._element.classList.contains("show");lt.clearMenus(),t||this.show()}show(){if(this._element.disabled||this._element.classList.contains("disabled")||this._menu.classList.contains("show"))return;const t=lt.getParentFromElement(this._element),e={relatedTarget:this._element};if(!P.trigger(this._element,"show.bs.dropdown",e).defaultPrevented){if(this._inNavbar)$.setDataAttribute(this._menu,"popper","none");else{if(void 0===s)throw new TypeError("Bootstrap's dropdowns require Popper (https://popper.js.org)");let e=this._element;"parent"===this._config.reference?e=t:c(this._config.reference)?(e=this._config.reference,void 0!==this._config.reference.jquery&&(e=this._config.reference[0])):"object"==typeof this._config.reference&&(e=this._config.reference);const i=this._getPopperConfig(),n=i.modifiers.find(t=>"applyStyles"===t.name&&!1===t.enabled);this._popper=s.createPopper(e,this._menu,i),n&&$.setDataAttribute(this._menu,"popper","static")}"ontouchstart"in document.documentElement&&!t.closest(".navbar-nav")&&[].concat(...document.body.children).forEach(t=>P.on(t,"mouseover",null,(function(){}))),this._element.focus(),this._element.setAttribute("aria-expanded",!0),this._menu.classList.toggle("show"),this._element.classList.toggle("show"),P.trigger(this._element,"shown.bs.dropdown",e)}}hide(){if(this._element.disabled||this._element.classList.contains("disabled")||!this._menu.classList.contains("show"))return;const t={relatedTarget:this._element};P.trigger(this._element,"hide.bs.dropdown",t).defaultPrevented||(this._popper&&this._popper.destroy(),this._menu.classList.toggle("show"),this._element.classList.toggle("show"),$.removeDataAttribute(this._menu,"popper"),P.trigger(this._element,"hidden.bs.dropdown",t))}dispose(){P.off(this._element,".bs.dropdown"),this._menu=null,this._popper&&(this._popper.destroy(),this._popper=null),super.dispose()}update(){this._inNavbar=this._detectNavbar(),this._popper&&this._popper.update()}_addEventListeners(){P.on(this._element,"click.bs.dropdown",t=>{t.preventDefault(),this.toggle()})}_getConfig(t){if(t={...this.constructor.Default,...$.getDataAttributes(this._element),...t},d("dropdown",t,this.constructor.DefaultType),"object"==typeof t.reference&&!c(t.reference)&&"function"!=typeof t.reference.getBoundingClientRect)throw new TypeError("dropdown".toUpperCase()+': Option "reference" provided type "object" without a required "getBoundingClientRect" method.');return t}_getMenuElement(){return U.next(this._element,".dropdown-menu")[0]}_getPlacement(){const t=this._element.parentNode;if(t.classList.contains("dropend"))return nt;if(t.classList.contains("dropstart"))return ot;const e="end"===getComputedStyle(this._menu).getPropertyValue("--bs-position").trim();return t.classList.contains("dropup")?e?et:tt:e?it:st}_detectNavbar(){return null!==this._element.closest(".navbar")}_getOffset(){const{offset:t}=this._config;return"string"==typeof t?t.split(",").map(t=>Number.parseInt(t,10)):"function"==typeof t?e=>t(e,this._element):t}_getPopperConfig(){const t={placement:this._getPlacement(),modifiers:[{name:"preventOverflow",options:{boundary:this._config.boundary}},{name:"offset",options:{offset:this._getOffset()}}]};return"static"===this._config.display&&(t.modifiers=[{name:"applyStyles",enabled:!1}]),{...t,..."function"==typeof this._config.popperConfig?this._config.popperConfig(t):this._config.popperConfig}}static dropdownInterface(t,e){let s=w.get(t,"bs.dropdown");if(s||(s=new lt(t,"object"==typeof e?e:null)),"string"==typeof e){if(void 0===s[e])throw new TypeError(`No method named "${e}"`);s[e]()}}static jQueryInterface(t){return this.each((function(){lt.dropdownInterface(this,t)}))}static clearMenus(t){if(t){if(2===t.button||"keyup"===t.type&&"Tab"!==t.key)return;if(/input|select|textarea|form/i.test(t.target.tagName))return}const e=U.find('[data-bs-toggle="dropdown"]');for(let s=0,i=e.length;s<i;s++){const i=w.get(e[s],"bs.dropdown"),n={relatedTarget:e[s]};if(t&&"click"===t.type&&(n.clickEvent=t),!i)continue;const o=i._menu;if(e[s].classList.contains("show")){if(t){if([i._element].some(e=>t.composedPath().includes(e)))continue;if("keyup"===t.type&&"Tab"===t.key&&o.contains(t.target))continue}P.trigger(e[s],"hide.bs.dropdown",n).defaultPrevented||("ontouchstart"in document.documentElement&&[].concat(...document.body.children).forEach(t=>P.off(t,"mouseover",null,(function(){}))),e[s].setAttribute("aria-expanded","false"),i._popper&&i._popper.destroy(),o.classList.remove("show"),e[s].classList.remove("show"),$.removeDataAttribute(o,"popper"),P.trigger(e[s],"hidden.bs.dropdown",n))}}}static getParentFromElement(t){return r(t)||t.parentNode}static dataApiKeydownHandler(t){if(/input|textarea/i.test(t.target.tagName)?"Space"===t.key||"Escape"!==t.key&&("ArrowDown"!==t.key&&"ArrowUp"!==t.key||t.target.closest(".dropdown-menu")):!J.test(t.key))return;if(t.preventDefault(),t.stopPropagation(),this.disabled||this.classList.contains("disabled"))return;const e=lt.getParentFromElement(this),s=this.classList.contains("show");if("Escape"===t.key)return(this.matches('[data-bs-toggle="dropdown"]')?this:U.prev(this,'[data-bs-toggle="dropdown"]')[0]).focus(),void lt.clearMenus();if(!s&&("ArrowUp"===t.key||"ArrowDown"===t.key))return void(this.matches('[data-bs-toggle="dropdown"]')?this:U.prev(this,'[data-bs-toggle="dropdown"]')[0]).click();if(!s||"Space"===t.key)return void lt.clearMenus();const i=U.find(".dropdown-menu .dropdown-item:not(.disabled):not(:disabled)",e).filter(u);if(!i.length)return;let n=i.indexOf(t.target);"ArrowUp"===t.key&&n>0&&n--,"ArrowDown"===t.key&&n<i.length-1&&n++,n=-1===n?0:n,i[n].focus()}}P.on(document,"keydown.bs.dropdown.data-api",'[data-bs-toggle="dropdown"]',lt.dataApiKeydownHandler),P.on(document,"keydown.bs.dropdown.data-api",".dropdown-menu",lt.dataApiKeydownHandler),P.on(document,"click.bs.dropdown.data-api",lt.clearMenus),P.on(document,"keyup.bs.dropdown.data-api",lt.clearMenus),P.on(document,"click.bs.dropdown.data-api",'[data-bs-toggle="dropdown"]',(function(t){t.preventDefault(),lt.dropdownInterface(this)})),v("dropdown",lt);const ct={backdrop:!0,keyboard:!0,focus:!0},ht={backdrop:"(boolean|string)",keyboard:"boolean",focus:"boolean"};class dt extends M{constructor(t,e){super(t),this._config=this._getConfig(e),this._dialog=U.findOne(".modal-dialog",this._element),this._backdrop=null,this._isShown=!1,this._isBodyOverflowing=!1,this._ignoreBackdropClick=!1,this._isTransitioning=!1,this._scrollbarWidth=0}static get Default(){return ct}static get DATA_KEY(){return"bs.modal"}toggle(t){return this._isShown?this.hide():this.show(t)}show(t){if(this._isShown||this._isTransitioning)return;this._isAnimated()&&(this._isTransitioning=!0);const e=P.trigger(this._element,"show.bs.modal",{relatedTarget:t});this._isShown||e.defaultPrevented||(this._isShown=!0,this._checkScrollbar(),this._setScrollbar(),this._adjustDialog(),this._setEscapeEvent(),this._setResizeEvent(),P.on(this._element,"click.dismiss.bs.modal",'[data-bs-dismiss="modal"]',t=>this.hide(t)),P.on(this._dialog,"mousedown.dismiss.bs.modal",()=>{P.one(this._element,"mouseup.dismiss.bs.modal",t=>{t.target===this._element&&(this._ignoreBackdropClick=!0)})}),this._showBackdrop(()=>this._showElement(t)))}hide(t){if(t&&t.preventDefault(),!this._isShown||this._isTransitioning)return;if(P.trigger(this._element,"hide.bs.modal").defaultPrevented)return;this._isShown=!1;const e=this._isAnimated();if(e&&(this._isTransitioning=!0),this._setEscapeEvent(),this._setResizeEvent(),P.off(document,"focusin.bs.modal"),this._element.classList.remove("show"),P.off(this._element,"click.dismiss.bs.modal"),P.off(this._dialog,"mousedown.dismiss.bs.modal"),e){const t=a(this._element);P.one(this._element,"transitionend",t=>this._hideModal(t)),h(this._element,t)}else this._hideModal()}dispose(){[window,this._element,this._dialog].forEach(t=>P.off(t,".bs.modal")),super.dispose(),P.off(document,"focusin.bs.modal"),this._config=null,this._dialog=null,this._backdrop=null,this._isShown=null,this._isBodyOverflowing=null,this._ignoreBackdropClick=null,this._isTransitioning=null,this._scrollbarWidth=null}handleUpdate(){this._adjustDialog()}_getConfig(t){return t={...ct,...t},d("modal",t,ht),t}_showElement(t){const e=this._isAnimated(),s=U.findOne(".modal-body",this._dialog);this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE||document.body.appendChild(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.scrollTop=0,s&&(s.scrollTop=0),e&&m(this._element),this._element.classList.add("show"),this._config.focus&&this._enforceFocus();const i=()=>{this._config.focus&&this._element.focus(),this._isTransitioning=!1,P.trigger(this._element,"shown.bs.modal",{relatedTarget:t})};if(e){const t=a(this._dialog);P.one(this._dialog,"transitionend",i),h(this._dialog,t)}else i()}_enforceFocus(){P.off(document,"focusin.bs.modal"),P.on(document,"focusin.bs.modal",t=>{document===t.target||this._element===t.target||this._element.contains(t.target)||this._element.focus()})}_setEscapeEvent(){this._isShown?P.on(this._element,"keydown.dismiss.bs.modal",t=>{this._config.keyboard&&"Escape"===t.key?(t.preventDefault(),this.hide()):this._config.keyboard||"Escape"!==t.key||this._triggerBackdropTransition()}):P.off(this._element,"keydown.dismiss.bs.modal")}_setResizeEvent(){this._isShown?P.on(window,"resize.bs.modal",()=>this._adjustDialog()):P.off(window,"resize.bs.modal")}_hideModal(){this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._isTransitioning=!1,this._showBackdrop(()=>{document.body.classList.remove("modal-open"),this._resetAdjustments(),this._resetScrollbar(),P.trigger(this._element,"hidden.bs.modal")})}_removeBackdrop(){this._backdrop.parentNode.removeChild(this._backdrop),this._backdrop=null}_showBackdrop(t){const e=this._isAnimated();if(this._isShown&&this._config.backdrop){if(this._backdrop=document.createElement("div"),this._backdrop.className="modal-backdrop",e&&this._backdrop.classList.add("fade"),document.body.appendChild(this._backdrop),P.on(this._element,"click.dismiss.bs.modal",t=>{this._ignoreBackdropClick?this._ignoreBackdropClick=!1:t.target===t.currentTarget&&("static"===this._config.backdrop?this._triggerBackdropTransition():this.hide())}),e&&m(this._backdrop),this._backdrop.classList.add("show"),!e)return void t();const s=a(this._backdrop);P.one(this._backdrop,"transitionend",t),h(this._backdrop,s)}else if(!this._isShown&&this._backdrop){this._backdrop.classList.remove("show");const s=()=>{this._removeBackdrop(),t()};if(e){const t=a(this._backdrop);P.one(this._backdrop,"transitionend",s),h(this._backdrop,t)}else s()}else t()}_isAnimated(){return this._element.classList.contains("fade")}_triggerBackdropTransition(){if(P.trigger(this._element,"hidePrevented.bs.modal").defaultPrevented)return;const t=this._element.scrollHeight>document.documentElement.clientHeight;t||(this._element.style.overflowY="hidden"),this._element.classList.add("modal-static");const e=a(this._dialog);P.off(this._element,"transitionend"),P.one(this._element,"transitionend",()=>{this._element.classList.remove("modal-static"),t||(P.one(this._element,"transitionend",()=>{this._element.style.overflowY=""}),h(this._element,e))}),h(this._element,e),this._element.focus()}_adjustDialog(){const t=this._element.scrollHeight>document.documentElement.clientHeight;(!this._isBodyOverflowing&&t&&!b()||this._isBodyOverflowing&&!t&&b())&&(this._element.style.paddingLeft=this._scrollbarWidth+"px"),(this._isBodyOverflowing&&!t&&!b()||!this._isBodyOverflowing&&t&&b())&&(this._element.style.paddingRight=this._scrollbarWidth+"px")}_resetAdjustments(){this._element.style.paddingLeft="",this._element.style.paddingRight=""}_checkScrollbar(){const t=document.body.getBoundingClientRect();this._isBodyOverflowing=Math.round(t.left+t.right)<window.innerWidth,this._scrollbarWidth=this._getScrollbarWidth()}_setScrollbar(){this._isBodyOverflowing&&(this._setElementAttributes(".fixed-top, .fixed-bottom, .is-fixed, .sticky-top","paddingRight",t=>t+this._scrollbarWidth),this._setElementAttributes(".sticky-top","marginRight",t=>t-this._scrollbarWidth),this._setElementAttributes("body","paddingRight",t=>t+this._scrollbarWidth)),document.body.classList.add("modal-open")}_setElementAttributes(t,e,s){U.find(t).forEach(t=>{if(t!==document.body&&window.innerWidth>t.clientWidth+this._scrollbarWidth)return;const i=t.style[e],n=window.getComputedStyle(t)[e];$.setDataAttribute(t,e,i),t.style[e]=s(Number.parseFloat(n))+"px"})}_resetScrollbar(){this._resetElementAttributes(".fixed-top, .fixed-bottom, .is-fixed, .sticky-top","paddingRight"),this._resetElementAttributes(".sticky-top","marginRight"),this._resetElementAttributes("body","paddingRight")}_resetElementAttributes(t,e){U.find(t).forEach(t=>{const s=$.getDataAttribute(t,e);void 0===s&&t===document.body?t.style[e]="":($.removeDataAttribute(t,e),t.style[e]=s)})}_getScrollbarWidth(){const t=document.createElement("div");t.className="modal-scrollbar-measure",document.body.appendChild(t);const e=t.getBoundingClientRect().width-t.clientWidth;return document.body.removeChild(t),e}static jQueryInterface(t,e){return this.each((function(){let s=w.get(this,"bs.modal");const i={...ct,...$.getDataAttributes(this),..."object"==typeof t&&t?t:{}};if(s||(s=new dt(this,i)),"string"==typeof t){if(void 0===s[t])throw new TypeError(`No method named "${t}"`);s[t](e)}}))}}P.on(document,"click.bs.modal.data-api",'[data-bs-toggle="modal"]',(function(t){const e=r(this);"A"!==this.tagName&&"AREA"!==this.tagName||t.preventDefault(),P.one(e,"show.bs.modal",t=>{t.defaultPrevented||P.one(e,"hidden.bs.modal",()=>{u(this)&&this.focus()})});let s=w.get(e,"bs.modal");if(!s){const t={...$.getDataAttributes(e),...$.getDataAttributes(this)};s=new dt(e,t)}s.toggle(this)})),v("modal",dt);const ut=()=>{const t=document.documentElement.clientWidth;return Math.abs(window.innerWidth-t)},gt=(t,e,s)=>{const i=ut();U.find(t).forEach(t=>{if(t!==document.body&&window.innerWidth>t.clientWidth+i)return;const n=t.style[e],o=window.getComputedStyle(t)[e];$.setDataAttribute(t,e,n),t.style[e]=s(Number.parseFloat(o))+"px"})},ft=(t,e)=>{U.find(t).forEach(t=>{const s=$.getDataAttribute(t,e);void 0===s&&t===document.body?t.style.removeProperty(e):($.removeDataAttribute(t,e),t.style[e]=s)})},pt={backdrop:!0,keyboard:!0,scroll:!1},mt={backdrop:"boolean",keyboard:"boolean",scroll:"boolean"};class _t extends M{constructor(t,e){super(t),this._config=this._getConfig(e),this._isShown=!1,this._addEventListeners()}static get Default(){return pt}static get DATA_KEY(){return"bs.offcanvas"}toggle(t){return this._isShown?this.hide():this.show(t)}show(t){this._isShown||P.trigger(this._element,"show.bs.offcanvas",{relatedTarget:t}).defaultPrevented||(this._isShown=!0,this._element.style.visibility="visible",this._config.backdrop&&document.body.classList.add("offcanvas-backdrop"),this._config.scroll||((t=ut())=>{document.body.style.overflow="hidden",gt(".fixed-top, .fixed-bottom, .is-fixed","paddingRight",e=>e+t),gt(".sticky-top","marginRight",e=>e-t),gt("body","paddingRight",e=>e+t)})(),this._element.classList.add("offcanvas-toggling"),this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.classList.add("show"),setTimeout(()=>{this._element.classList.remove("offcanvas-toggling"),P.trigger(this._element,"shown.bs.offcanvas",{relatedTarget:t}),this._enforceFocusOnElement(this._element)},a(this._element)))}hide(){this._isShown&&(P.trigger(this._element,"hide.bs.offcanvas").defaultPrevented||(this._element.classList.add("offcanvas-toggling"),P.off(document,"focusin.bs.offcanvas"),this._element.blur(),this._isShown=!1,this._element.classList.remove("show"),setTimeout(()=>{this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._element.style.visibility="hidden",this._config.backdrop&&document.body.classList.remove("offcanvas-backdrop"),this._config.scroll||(document.body.style.overflow="auto",ft(".fixed-top, .fixed-bottom, .is-fixed","paddingRight"),ft(".sticky-top","marginRight"),ft("body","paddingRight")),P.trigger(this._element,"hidden.bs.offcanvas"),this._element.classList.remove("offcanvas-toggling")},a(this._element))))}_getConfig(t){return t={...pt,...$.getDataAttributes(this._element),..."object"==typeof t?t:{}},d("offcanvas",t,mt),t}_enforceFocusOnElement(t){P.off(document,"focusin.bs.offcanvas"),P.on(document,"focusin.bs.offcanvas",e=>{document===e.target||t===e.target||t.contains(e.target)||t.focus()}),t.focus()}_addEventListeners(){P.on(this._element,"click.dismiss.bs.offcanvas",'[data-bs-dismiss="offcanvas"]',()=>this.hide()),P.on(document,"keydown",t=>{this._config.keyboard&&"Escape"===t.key&&this.hide()}),P.on(document,"click.bs.offcanvas.data-api",t=>{const e=U.findOne(o(t.target));this._element.contains(t.target)||e===this._element||this.hide()})}static jQueryInterface(t){return this.each((function(){const e=w.get(this,"bs.offcanvas")||new _t(this,"object"==typeof t?t:{});if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}P.on(document,"click.bs.offcanvas.data-api",'[data-bs-toggle="offcanvas"]',(function(t){const e=r(this);if(["A","AREA"].includes(this.tagName)&&t.preventDefault(),g(this))return;P.one(e,"hidden.bs.offcanvas",()=>{u(this)&&this.focus()});const s=U.findOne(".offcanvas.show, .offcanvas-toggling");s&&s!==e||(w.get(e,"bs.offcanvas")||new _t(e)).toggle(this)})),P.on(window,"load.bs.offcanvas.data-api",()=>{U.find(".offcanvas.show").forEach(t=>(w.get(t,"bs.offcanvas")||new _t(t)).show())}),v("offcanvas",_t);const bt=new Set(["background","cite","href","itemtype","longdesc","poster","src","xlink:href"]),vt=/^(?:(?:https?|mailto|ftp|tel|file):|[^#&/:?]*(?:[#/?]|$))/i,yt=/^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[\d+/a-z]+=*$/i,wt=(t,e)=>{const s=t.nodeName.toLowerCase();if(e.includes(s))return!bt.has(s)||Boolean(vt.test(t.nodeValue)||yt.test(t.nodeValue));const i=e.filter(t=>t instanceof RegExp);for(let t=0,e=i.length;t<e;t++)if(i[t].test(s))return!0;return!1};function Et(t,e,s){if(!t.length)return t;if(s&&"function"==typeof s)return s(t);const i=(new window.DOMParser).parseFromString(t,"text/html"),n=Object.keys(e),o=[].concat(...i.body.querySelectorAll("*"));for(let t=0,s=o.length;t<s;t++){const s=o[t],i=s.nodeName.toLowerCase();if(!n.includes(i)){s.parentNode.removeChild(s);continue}const r=[].concat(...s.attributes),a=[].concat(e["*"]||[],e[i]||[]);r.forEach(t=>{wt(t,a)||s.removeAttribute(t.nodeName)})}return i.body.innerHTML}const Tt=new RegExp("(^|\\s)bs-tooltip\\S+","g"),At=new Set(["sanitize","allowList","sanitizeFn"]),Lt={animation:"boolean",template:"string",title:"(string|element|function)",trigger:"string",delay:"(number|object)",html:"boolean",selector:"(string|boolean)",placement:"(string|function)",offset:"(array|string|function)",container:"(string|element|boolean)",fallbackPlacements:"array",boundary:"(string|element)",customClass:"(string|function)",sanitize:"boolean",sanitizeFn:"(null|function)",allowList:"object",popperConfig:"(null|object|function)"},kt={AUTO:"auto",TOP:"top",RIGHT:b()?"left":"right",BOTTOM:"bottom",LEFT:b()?"right":"left"},Ct={animation:!0,template:'<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,selector:!1,placement:"top",offset:[0,0],container:!1,fallbackPlacements:["top","right","bottom","left"],boundary:"clippingParents",customClass:"",sanitize:!0,sanitizeFn:null,allowList:{"*":["class","dir","id","lang","role",/^aria-[\w-]*$/i],a:["target","href","title","rel"],area:[],b:[],br:[],col:[],code:[],div:[],em:[],hr:[],h1:[],h2:[],h3:[],h4:[],h5:[],h6:[],i:[],img:["src","srcset","alt","title","width","height"],li:[],ol:[],p:[],pre:[],s:[],small:[],span:[],sub:[],sup:[],strong:[],u:[],ul:[]},popperConfig:null},Dt={HIDE:"hide.bs.tooltip",HIDDEN:"hidden.bs.tooltip",SHOW:"show.bs.tooltip",SHOWN:"shown.bs.tooltip",INSERTED:"inserted.bs.tooltip",CLICK:"click.bs.tooltip",FOCUSIN:"focusin.bs.tooltip",FOCUSOUT:"focusout.bs.tooltip",MOUSEENTER:"mouseenter.bs.tooltip",MOUSELEAVE:"mouseleave.bs.tooltip"};class St extends M{constructor(t,e){if(void 0===s)throw new TypeError("Bootstrap's tooltips require Popper (https://popper.js.org)");super(t),this._isEnabled=!0,this._timeout=0,this._hoverState="",this._activeTrigger={},this._popper=null,this.config=this._getConfig(e),this.tip=null,this._setListeners()}static get Default(){return Ct}static get NAME(){return"tooltip"}static get DATA_KEY(){return"bs.tooltip"}static get Event(){return Dt}static get EVENT_KEY(){return".bs.tooltip"}static get DefaultType(){return Lt}enable(){this._isEnabled=!0}disable(){this._isEnabled=!1}toggleEnabled(){this._isEnabled=!this._isEnabled}toggle(t){if(this._isEnabled)if(t){const e=this._initializeOnDelegatedTarget(t);e._activeTrigger.click=!e._activeTrigger.click,e._isWithActiveTrigger()?e._enter(null,e):e._leave(null,e)}else{if(this.getTipElement().classList.contains("show"))return void this._leave(null,this);this._enter(null,this)}}dispose(){clearTimeout(this._timeout),P.off(this._element,this.constructor.EVENT_KEY),P.off(this._element.closest(".modal"),"hide.bs.modal",this._hideModalHandler),this.tip&&this.tip.parentNode&&this.tip.parentNode.removeChild(this.tip),this._isEnabled=null,this._timeout=null,this._hoverState=null,this._activeTrigger=null,this._popper&&this._popper.destroy(),this._popper=null,this.config=null,this.tip=null,super.dispose()}show(){if("none"===this._element.style.display)throw new Error("Please use show on visible elements");if(!this.isWithContent()||!this._isEnabled)return;const t=P.trigger(this._element,this.constructor.Event.SHOW),e=f(this._element),n=null===e?this._element.ownerDocument.documentElement.contains(this._element):e.contains(this._element);if(t.defaultPrevented||!n)return;const o=this.getTipElement(),r=i(this.constructor.NAME);o.setAttribute("id",r),this._element.setAttribute("aria-describedby",r),this.setContent(),this.config.animation&&o.classList.add("fade");const l="function"==typeof this.config.placement?this.config.placement.call(this,o,this._element):this.config.placement,c=this._getAttachment(l);this._addAttachmentClass(c);const d=this._getContainer();w.set(o,this.constructor.DATA_KEY,this),this._element.ownerDocument.documentElement.contains(this.tip)||(d.appendChild(o),P.trigger(this._element,this.constructor.Event.INSERTED)),this._popper?this._popper.update():this._popper=s.createPopper(this._element,o,this._getPopperConfig(c)),o.classList.add("show");const u="function"==typeof this.config.customClass?this.config.customClass():this.config.customClass;u&&o.classList.add(...u.split(" ")),"ontouchstart"in document.documentElement&&[].concat(...document.body.children).forEach(t=>{P.on(t,"mouseover",(function(){}))});const g=()=>{const t=this._hoverState;this._hoverState=null,P.trigger(this._element,this.constructor.Event.SHOWN),"out"===t&&this._leave(null,this)};if(this.tip.classList.contains("fade")){const t=a(this.tip);P.one(this.tip,"transitionend",g),h(this.tip,t)}else g()}hide(){if(!this._popper)return;const t=this.getTipElement(),e=()=>{this._isWithActiveTrigger()||("show"!==this._hoverState&&t.parentNode&&t.parentNode.removeChild(t),this._cleanTipClass(),this._element.removeAttribute("aria-describedby"),P.trigger(this._element,this.constructor.Event.HIDDEN),this._popper&&(this._popper.destroy(),this._popper=null))};if(!P.trigger(this._element,this.constructor.Event.HIDE).defaultPrevented){if(t.classList.remove("show"),"ontouchstart"in document.documentElement&&[].concat(...document.body.children).forEach(t=>P.off(t,"mouseover",p)),this._activeTrigger.click=!1,this._activeTrigger.focus=!1,this._activeTrigger.hover=!1,this.tip.classList.contains("fade")){const s=a(t);P.one(t,"transitionend",e),h(t,s)}else e();this._hoverState=""}}update(){null!==this._popper&&this._popper.update()}isWithContent(){return Boolean(this.getTitle())}getTipElement(){if(this.tip)return this.tip;const t=document.createElement("div");return t.innerHTML=this.config.template,this.tip=t.children[0],this.tip}setContent(){const t=this.getTipElement();this.setElementContent(U.findOne(".tooltip-inner",t),this.getTitle()),t.classList.remove("fade","show")}setElementContent(t,e){if(null!==t)return"object"==typeof e&&c(e)?(e.jquery&&(e=e[0]),void(this.config.html?e.parentNode!==t&&(t.innerHTML="",t.appendChild(e)):t.textContent=e.textContent)):void(this.config.html?(this.config.sanitize&&(e=Et(e,this.config.allowList,this.config.sanitizeFn)),t.innerHTML=e):t.textContent=e)}getTitle(){let t=this._element.getAttribute("data-bs-original-title");return t||(t="function"==typeof this.config.title?this.config.title.call(this._element):this.config.title),t}updateAttachment(t){return"right"===t?"end":"left"===t?"start":t}_initializeOnDelegatedTarget(t,e){const s=this.constructor.DATA_KEY;return(e=e||w.get(t.delegateTarget,s))||(e=new this.constructor(t.delegateTarget,this._getDelegateConfig()),w.set(t.delegateTarget,s,e)),e}_getOffset(){const{offset:t}=this.config;return"string"==typeof t?t.split(",").map(t=>Number.parseInt(t,10)):"function"==typeof t?e=>t(e,this._element):t}_getPopperConfig(t){const e={placement:t,modifiers:[{name:"flip",options:{altBoundary:!0,fallbackPlacements:this.config.fallbackPlacements}},{name:"offset",options:{offset:this._getOffset()}},{name:"preventOverflow",options:{boundary:this.config.boundary}},{name:"arrow",options:{element:`.${this.constructor.NAME}-arrow`}},{name:"onChange",enabled:!0,phase:"afterWrite",fn:t=>this._handlePopperPlacementChange(t)}],onFirstUpdate:t=>{t.options.placement!==t.placement&&this._handlePopperPlacementChange(t)}};return{...e,..."function"==typeof this.config.popperConfig?this.config.popperConfig(e):this.config.popperConfig}}_addAttachmentClass(t){this.getTipElement().classList.add("bs-tooltip-"+this.updateAttachment(t))}_getContainer(){return!1===this.config.container?document.body:c(this.config.container)?this.config.container:U.findOne(this.config.container)}_getAttachment(t){return kt[t.toUpperCase()]}_setListeners(){this.config.trigger.split(" ").forEach(t=>{if("click"===t)P.on(this._element,this.constructor.Event.CLICK,this.config.selector,t=>this.toggle(t));else if("manual"!==t){const e="hover"===t?this.constructor.Event.MOUSEENTER:this.constructor.Event.FOCUSIN,s="hover"===t?this.constructor.Event.MOUSELEAVE:this.constructor.Event.FOCUSOUT;P.on(this._element,e,this.config.selector,t=>this._enter(t)),P.on(this._element,s,this.config.selector,t=>this._leave(t))}}),this._hideModalHandler=()=>{this._element&&this.hide()},P.on(this._element.closest(".modal"),"hide.bs.modal",this._hideModalHandler),this.config.selector?this.config={...this.config,trigger:"manual",selector:""}:this._fixTitle()}_fixTitle(){const t=this._element.getAttribute("title"),e=typeof this._element.getAttribute("data-bs-original-title");(t||"string"!==e)&&(this._element.setAttribute("data-bs-original-title",t||""),!t||this._element.getAttribute("aria-label")||this._element.textContent||this._element.setAttribute("aria-label",t),this._element.setAttribute("title",""))}_enter(t,e){e=this._initializeOnDelegatedTarget(t,e),t&&(e._activeTrigger["focusin"===t.type?"focus":"hover"]=!0),e.getTipElement().classList.contains("show")||"show"===e._hoverState?e._hoverState="show":(clearTimeout(e._timeout),e._hoverState="show",e.config.delay&&e.config.delay.show?e._timeout=setTimeout(()=>{"show"===e._hoverState&&e.show()},e.config.delay.show):e.show())}_leave(t,e){e=this._initializeOnDelegatedTarget(t,e),t&&(e._activeTrigger["focusout"===t.type?"focus":"hover"]=e._element.contains(t.relatedTarget)),e._isWithActiveTrigger()||(clearTimeout(e._timeout),e._hoverState="out",e.config.delay&&e.config.delay.hide?e._timeout=setTimeout(()=>{"out"===e._hoverState&&e.hide()},e.config.delay.hide):e.hide())}_isWithActiveTrigger(){for(const t in this._activeTrigger)if(this._activeTrigger[t])return!0;return!1}_getConfig(t){const e=$.getDataAttributes(this._element);return Object.keys(e).forEach(t=>{At.has(t)&&delete e[t]}),t&&"object"==typeof t.container&&t.container.jquery&&(t.container=t.container[0]),"number"==typeof(t={...this.constructor.Default,...e,..."object"==typeof t&&t?t:{}}).delay&&(t.delay={show:t.delay,hide:t.delay}),"number"==typeof t.title&&(t.title=t.title.toString()),"number"==typeof t.content&&(t.content=t.content.toString()),d("tooltip",t,this.constructor.DefaultType),t.sanitize&&(t.template=Et(t.template,t.allowList,t.sanitizeFn)),t}_getDelegateConfig(){const t={};if(this.config)for(const e in this.config)this.constructor.Default[e]!==this.config[e]&&(t[e]=this.config[e]);return t}_cleanTipClass(){const t=this.getTipElement(),e=t.getAttribute("class").match(Tt);null!==e&&e.length>0&&e.map(t=>t.trim()).forEach(e=>t.classList.remove(e))}_handlePopperPlacementChange(t){const{state:e}=t;e&&(this.tip=e.elements.popper,this._cleanTipClass(),this._addAttachmentClass(this._getAttachment(e.placement)))}static jQueryInterface(t){return this.each((function(){let e=w.get(this,"bs.tooltip");const s="object"==typeof t&&t;if((e||!/dispose|hide/.test(t))&&(e||(e=new St(this,s)),"string"==typeof t)){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}v("tooltip",St);const Nt=new RegExp("(^|\\s)bs-popover\\S+","g"),Ot={...St.Default,placement:"right",offset:[0,8],trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="popover-arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>'},xt={...St.DefaultType,content:"(string|element|function)"},It={HIDE:"hide.bs.popover",HIDDEN:"hidden.bs.popover",SHOW:"show.bs.popover",SHOWN:"shown.bs.popover",INSERTED:"inserted.bs.popover",CLICK:"click.bs.popover",FOCUSIN:"focusin.bs.popover",FOCUSOUT:"focusout.bs.popover",MOUSEENTER:"mouseenter.bs.popover",MOUSELEAVE:"mouseleave.bs.popover"};class jt extends St{static get Default(){return Ot}static get NAME(){return"popover"}static get DATA_KEY(){return"bs.popover"}static get Event(){return It}static get EVENT_KEY(){return".bs.popover"}static get DefaultType(){return xt}isWithContent(){return this.getTitle()||this._getContent()}setContent(){const t=this.getTipElement();this.setElementContent(U.findOne(".popover-header",t),this.getTitle());let e=this._getContent();"function"==typeof e&&(e=e.call(this._element)),this.setElementContent(U.findOne(".popover-body",t),e),t.classList.remove("fade","show")}_addAttachmentClass(t){this.getTipElement().classList.add("bs-popover-"+this.updateAttachment(t))}_getContent(){return this._element.getAttribute("data-bs-content")||this.config.content}_cleanTipClass(){const t=this.getTipElement(),e=t.getAttribute("class").match(Nt);null!==e&&e.length>0&&e.map(t=>t.trim()).forEach(e=>t.classList.remove(e))}static jQueryInterface(t){return this.each((function(){let e=w.get(this,"bs.popover");const s="object"==typeof t?t:null;if((e||!/dispose|hide/.test(t))&&(e||(e=new jt(this,s),w.set(this,"bs.popover",e)),"string"==typeof t)){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}v("popover",jt);const Pt={offset:10,method:"auto",target:""},Mt={offset:"number",method:"string",target:"(string|element)"};class Ht extends M{constructor(t,e){super(t),this._scrollElement="BODY"===this._element.tagName?window:this._element,this._config=this._getConfig(e),this._selector=`${this._config.target} .nav-link, ${this._config.target} .list-group-item, ${this._config.target} .dropdown-item`,this._offsets=[],this._targets=[],this._activeTarget=null,this._scrollHeight=0,P.on(this._scrollElement,"scroll.bs.scrollspy",()=>this._process()),this.refresh(),this._process()}static get Default(){return Pt}static get DATA_KEY(){return"bs.scrollspy"}refresh(){const t=this._scrollElement===this._scrollElement.window?"offset":"position",e="auto"===this._config.method?t:this._config.method,s="position"===e?this._getScrollTop():0;this._offsets=[],this._targets=[],this._scrollHeight=this._getScrollHeight(),U.find(this._selector).map(t=>{const i=o(t),n=i?U.findOne(i):null;if(n){const t=n.getBoundingClientRect();if(t.width||t.height)return[$[e](n).top+s,i]}return null}).filter(t=>t).sort((t,e)=>t[0]-e[0]).forEach(t=>{this._offsets.push(t[0]),this._targets.push(t[1])})}dispose(){super.dispose(),P.off(this._scrollElement,".bs.scrollspy"),this._scrollElement=null,this._config=null,this._selector=null,this._offsets=null,this._targets=null,this._activeTarget=null,this._scrollHeight=null}_getConfig(t){if("string"!=typeof(t={...Pt,..."object"==typeof t&&t?t:{}}).target&&c(t.target)){let{id:e}=t.target;e||(e=i("scrollspy"),t.target.id=e),t.target="#"+e}return d("scrollspy",t,Mt),t}_getScrollTop(){return this._scrollElement===window?this._scrollElement.pageYOffset:this._scrollElement.scrollTop}_getScrollHeight(){return this._scrollElement.scrollHeight||Math.max(document.body.scrollHeight,document.documentElement.scrollHeight)}_getOffsetHeight(){return this._scrollElement===window?window.innerHeight:this._scrollElement.getBoundingClientRect().height}_process(){const t=this._getScrollTop()+this._config.offset,e=this._getScrollHeight(),s=this._config.offset+e-this._getOffsetHeight();if(this._scrollHeight!==e&&this.refresh(),t>=s){const t=this._targets[this._targets.length-1];this._activeTarget!==t&&this._activate(t)}else{if(this._activeTarget&&t<this._offsets[0]&&this._offsets[0]>0)return this._activeTarget=null,void this._clear();for(let e=this._offsets.length;e--;)this._activeTarget!==this._targets[e]&&t>=this._offsets[e]&&(void 0===this._offsets[e+1]||t<this._offsets[e+1])&&this._activate(this._targets[e])}}_activate(t){this._activeTarget=t,this._clear();const e=this._selector.split(",").map(e=>`${e}[data-bs-target="${t}"],${e}[href="${t}"]`),s=U.findOne(e.join(","));s.classList.contains("dropdown-item")?(U.findOne(".dropdown-toggle",s.closest(".dropdown")).classList.add("active"),s.classList.add("active")):(s.classList.add("active"),U.parents(s,".nav, .list-group").forEach(t=>{U.prev(t,".nav-link, .list-group-item").forEach(t=>t.classList.add("active")),U.prev(t,".nav-item").forEach(t=>{U.children(t,".nav-link").forEach(t=>t.classList.add("active"))})})),P.trigger(this._scrollElement,"activate.bs.scrollspy",{relatedTarget:t})}_clear(){U.find(this._selector).filter(t=>t.classList.contains("active")).forEach(t=>t.classList.remove("active"))}static jQueryInterface(t){return this.each((function(){let e=w.get(this,"bs.scrollspy");if(e||(e=new Ht(this,"object"==typeof t&&t)),"string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}P.on(window,"load.bs.scrollspy.data-api",()=>{U.find('[data-bs-spy="scroll"]').forEach(t=>new Ht(t,$.getDataAttributes(t)))}),v("scrollspy",Ht);class Rt extends M{static get DATA_KEY(){return"bs.tab"}show(){if(this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE&&this._element.classList.contains("active")||g(this._element))return;let t;const e=r(this._element),s=this._element.closest(".nav, .list-group");if(s){const e="UL"===s.nodeName||"OL"===s.nodeName?":scope > li > .active":".active";t=U.find(e,s),t=t[t.length-1]}const i=t?P.trigger(t,"hide.bs.tab",{relatedTarget:this._element}):null;if(P.trigger(this._element,"show.bs.tab",{relatedTarget:t}).defaultPrevented||null!==i&&i.defaultPrevented)return;this._activate(this._element,s);const n=()=>{P.trigger(t,"hidden.bs.tab",{relatedTarget:this._element}),P.trigger(this._element,"shown.bs.tab",{relatedTarget:t})};e?this._activate(e,e.parentNode,n):n()}_activate(t,e,s){const i=(!e||"UL"!==e.nodeName&&"OL"!==e.nodeName?U.children(e,".active"):U.find(":scope > li > .active",e))[0],n=s&&i&&i.classList.contains("fade"),o=()=>this._transitionComplete(t,i,s);if(i&&n){const t=a(i);i.classList.remove("show"),P.one(i,"transitionend",o),h(i,t)}else o()}_transitionComplete(t,e,s){if(e){e.classList.remove("active");const t=U.findOne(":scope > .dropdown-menu .active",e.parentNode);t&&t.classList.remove("active"),"tab"===e.getAttribute("role")&&e.setAttribute("aria-selected",!1)}t.classList.add("active"),"tab"===t.getAttribute("role")&&t.setAttribute("aria-selected",!0),m(t),t.classList.contains("fade")&&t.classList.add("show"),t.parentNode&&t.parentNode.classList.contains("dropdown-menu")&&(t.closest(".dropdown")&&U.find(".dropdown-toggle").forEach(t=>t.classList.add("active")),t.setAttribute("aria-expanded",!0)),s&&s()}static jQueryInterface(t){return this.each((function(){const e=w.get(this,"bs.tab")||new Rt(this);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}P.on(document,"click.bs.tab.data-api",'[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]',(function(t){t.preventDefault(),(w.get(this,"bs.tab")||new Rt(this)).show()})),v("tab",Rt);const Bt={animation:"boolean",autohide:"boolean",delay:"number"},Wt={animation:!0,autohide:!0,delay:5e3};class $t extends M{constructor(t,e){super(t),this._config=this._getConfig(e),this._timeout=null,this._setListeners()}static get DefaultType(){return Bt}static get Default(){return Wt}static get DATA_KEY(){return"bs.toast"}show(){if(P.trigger(this._element,"show.bs.toast").defaultPrevented)return;this._clearTimeout(),this._config.animation&&this._element.classList.add("fade");const t=()=>{this._element.classList.remove("showing"),this._element.classList.add("show"),P.trigger(this._element,"shown.bs.toast"),this._config.autohide&&(this._timeout=setTimeout(()=>{this.hide()},this._config.delay))};if(this._element.classList.remove("hide"),m(this._element),this._element.classList.add("showing"),this._config.animation){const e=a(this._element);P.one(this._element,"transitionend",t),h(this._element,e)}else t()}hide(){if(!this._element.classList.contains("show"))return;if(P.trigger(this._element,"hide.bs.toast").defaultPrevented)return;const t=()=>{this._element.classList.add("hide"),P.trigger(this._element,"hidden.bs.toast")};if(this._element.classList.remove("show"),this._config.animation){const e=a(this._element);P.one(this._element,"transitionend",t),h(this._element,e)}else t()}dispose(){this._clearTimeout(),this._element.classList.contains("show")&&this._element.classList.remove("show"),P.off(this._element,"click.dismiss.bs.toast"),super.dispose(),this._config=null}_getConfig(t){return t={...Wt,...$.getDataAttributes(this._element),..."object"==typeof t&&t?t:{}},d("toast",t,this.constructor.DefaultType),t}_setListeners(){P.on(this._element,"click.dismiss.bs.toast",'[data-bs-dismiss="toast"]',()=>this.hide())}_clearTimeout(){clearTimeout(this._timeout),this._timeout=null}static jQueryInterface(t){return this.each((function(){let e=w.get(this,"bs.toast");if(e||(e=new $t(this,"object"==typeof t&&t)),"string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}return v("toast",$t),{Alert:H,Button:R,Carousel:X,Collapse:Z,Dropdown:lt,Modal:dt,Offcanvas:_t,Popover:jt,ScrollSpy:Ht,Tab:Rt,Toast:$t,Tooltip:St}})); | ||
//# sourceMappingURL=bootstrap.min.js.map |
/*! | ||
* Bootstrap alert.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap alert.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -18,48 +18,16 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MILLISECONDS_MULTIPLIER = 1000; | ||
var TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
const MILLISECONDS_MULTIPLIER = 1000; | ||
const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
var getSelector = function getSelector(element) { | ||
var selector = element.getAttribute('data-bs-target'); | ||
const getSelector = element => { | ||
let selector = element.getAttribute('data-bs-target'); | ||
if (!selector || selector === '#') { | ||
var hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
// so everything starting with `#` or `.`. If a "real" URL is used as the selector, | ||
@@ -84,8 +52,8 @@ // `document.querySelector` will rightfully complain it is invalid. | ||
var getElementFromSelector = function getElementFromSelector(element) { | ||
var selector = getSelector(element); | ||
const getElementFromSelector = element => { | ||
const selector = getSelector(element); | ||
return selector ? document.querySelector(selector) : null; | ||
}; | ||
var getTransitionDurationFromElement = function getTransitionDurationFromElement(element) { | ||
const getTransitionDurationFromElement = element => { | ||
if (!element) { | ||
@@ -96,9 +64,9 @@ return 0; | ||
var _window$getComputedSt = window.getComputedStyle(element), | ||
transitionDuration = _window$getComputedSt.transitionDuration, | ||
transitionDelay = _window$getComputedSt.transitionDelay; | ||
let { | ||
transitionDuration, | ||
transitionDelay | ||
} = window.getComputedStyle(element); | ||
const floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
var floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
var floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
if (!floatTransitionDuration && !floatTransitionDelay) { | ||
@@ -114,10 +82,10 @@ return 0; | ||
var triggerTransitionEnd = function triggerTransitionEnd(element) { | ||
const triggerTransitionEnd = element => { | ||
element.dispatchEvent(new Event(TRANSITION_END)); | ||
}; | ||
var emulateTransitionEnd = function emulateTransitionEnd(element, duration) { | ||
var called = false; | ||
var durationPadding = 5; | ||
var emulatedDuration = duration + durationPadding; | ||
const emulateTransitionEnd = (element, duration) => { | ||
let called = false; | ||
const durationPadding = 5; | ||
const emulatedDuration = duration + durationPadding; | ||
@@ -130,3 +98,3 @@ function listener() { | ||
element.addEventListener(TRANSITION_END, listener); | ||
setTimeout(function () { | ||
setTimeout(() => { | ||
if (!called) { | ||
@@ -138,5 +106,6 @@ triggerTransitionEnd(element); | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -150,3 +119,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -159,15 +128,13 @@ document.addEventListener('DOMContentLoaded', callback); | ||
document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -181,2 +148,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): alert.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -187,13 +160,13 @@ * Constants | ||
var NAME = 'alert'; | ||
var DATA_KEY = 'bs.alert'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var SELECTOR_DISMISS = '[data-bs-dismiss="alert"]'; | ||
var EVENT_CLOSE = "close" + EVENT_KEY; | ||
var EVENT_CLOSED = "closed" + EVENT_KEY; | ||
var EVENT_CLICK_DATA_API = "click" + EVENT_KEY + DATA_API_KEY; | ||
var CLASS_NAME_ALERT = 'alert'; | ||
var CLASS_NAME_FADE = 'fade'; | ||
var CLASS_NAME_SHOW = 'show'; | ||
const NAME = 'alert'; | ||
const DATA_KEY = 'bs.alert'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const SELECTOR_DISMISS = '[data-bs-dismiss="alert"]'; | ||
const EVENT_CLOSE = `close${EVENT_KEY}`; | ||
const EVENT_CLOSED = `closed${EVENT_KEY}`; | ||
const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`; | ||
const CLASS_NAME_ALERT = 'alert'; | ||
const CLASS_NAME_FADE = 'fade'; | ||
const CLASS_NAME_SHOW = 'show'; | ||
/** | ||
@@ -205,17 +178,14 @@ * ------------------------------------------------------------------------ | ||
var Alert = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Alert, _BaseComponent); | ||
class Alert extends BaseComponent__default['default'] { | ||
// Getters | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
function Alert() { | ||
return _BaseComponent.apply(this, arguments) || this; | ||
} | ||
var _proto = Alert.prototype; | ||
close(element) { | ||
const rootElement = element ? this._getRootElement(element) : this._element; | ||
// Public | ||
_proto.close = function close(element) { | ||
var rootElement = element ? this._getRootElement(element) : this._element; | ||
const customEvent = this._triggerCloseEvent(rootElement); | ||
var customEvent = this._triggerCloseEvent(rootElement); | ||
if (customEvent === null || customEvent.defaultPrevented) { | ||
@@ -227,15 +197,13 @@ return; | ||
} // Private | ||
; | ||
_proto._getRootElement = function _getRootElement(element) { | ||
return getElementFromSelector(element) || element.closest("." + CLASS_NAME_ALERT); | ||
}; | ||
_proto._triggerCloseEvent = function _triggerCloseEvent(element) { | ||
_getRootElement(element) { | ||
return getElementFromSelector(element) || element.closest(`.${CLASS_NAME_ALERT}`); | ||
} | ||
_triggerCloseEvent(element) { | ||
return EventHandler__default['default'].trigger(element, EVENT_CLOSE); | ||
}; | ||
} | ||
_proto._removeElement = function _removeElement(element) { | ||
var _this = this; | ||
_removeElement(element) { | ||
element.classList.remove(CLASS_NAME_SHOW); | ||
@@ -249,10 +217,8 @@ | ||
var transitionDuration = getTransitionDurationFromElement(element); | ||
EventHandler__default['default'].one(element, 'transitionend', function () { | ||
return _this._destroyElement(element); | ||
}); | ||
const transitionDuration = getTransitionDurationFromElement(element); | ||
EventHandler__default['default'].one(element, 'transitionend', () => this._destroyElement(element)); | ||
emulateTransitionEnd(element, transitionDuration); | ||
}; | ||
} | ||
_proto._destroyElement = function _destroyElement(element) { | ||
_destroyElement(element) { | ||
if (element.parentNode) { | ||
@@ -264,7 +230,7 @@ element.parentNode.removeChild(element); | ||
} // Static | ||
; | ||
Alert.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY); | ||
let data = Data__default['default'].get(this, DATA_KEY); | ||
@@ -279,5 +245,5 @@ if (!data) { | ||
}); | ||
}; | ||
} | ||
Alert.handleDismiss = function handleDismiss(alertInstance) { | ||
static handleDismiss(alertInstance) { | ||
return function (event) { | ||
@@ -290,14 +256,5 @@ if (event) { | ||
}; | ||
}; | ||
} | ||
_createClass(Alert, null, [{ | ||
key: "DATA_KEY", | ||
get: // Getters | ||
function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Alert; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -304,0 +261,0 @@ * ------------------------------------------------------------------------ |
/*! | ||
* Bootstrap base-component.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap base-component.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -16,19 +16,9 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): base-component.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -39,6 +29,8 @@ * Constants | ||
var VERSION = '5.0.0-beta2'; | ||
const VERSION = '5.0.0-beta3'; | ||
var BaseComponent = /*#__PURE__*/function () { | ||
function BaseComponent(element) { | ||
class BaseComponent { | ||
constructor(element) { | ||
element = typeof element === 'string' ? document.querySelector(element) : element; | ||
if (!element) { | ||
@@ -49,28 +41,22 @@ return; | ||
this._element = element; | ||
Data__default['default'].setData(element, this.constructor.DATA_KEY, this); | ||
Data__default['default'].set(this._element, this.constructor.DATA_KEY, this); | ||
} | ||
var _proto = BaseComponent.prototype; | ||
_proto.dispose = function dispose() { | ||
Data__default['default'].removeData(this._element, this.constructor.DATA_KEY); | ||
dispose() { | ||
Data__default['default'].remove(this._element, this.constructor.DATA_KEY); | ||
this._element = null; | ||
} | ||
/** Static */ | ||
; | ||
BaseComponent.getInstance = function getInstance(element) { | ||
return Data__default['default'].getData(element, this.DATA_KEY); | ||
}; | ||
_createClass(BaseComponent, null, [{ | ||
key: "VERSION", | ||
get: function get() { | ||
return VERSION; | ||
} | ||
}]); | ||
static getInstance(element) { | ||
return Data__default['default'].get(element, this.DATA_KEY); | ||
} | ||
return BaseComponent; | ||
}(); | ||
static get VERSION() { | ||
return VERSION; | ||
} | ||
} | ||
return BaseComponent; | ||
@@ -77,0 +63,0 @@ |
/*! | ||
* Bootstrap button.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap button.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -18,37 +18,5 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -58,5 +26,6 @@ * -------------------------------------------------------------------------- | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -70,3 +39,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -79,15 +48,13 @@ document.addEventListener('DOMContentLoaded', callback); | ||
document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -101,2 +68,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): button.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -107,9 +80,9 @@ * Constants | ||
var NAME = 'button'; | ||
var DATA_KEY = 'bs.button'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var CLASS_NAME_ACTIVE = 'active'; | ||
var SELECTOR_DATA_TOGGLE = '[data-bs-toggle="button"]'; | ||
var EVENT_CLICK_DATA_API = "click" + EVENT_KEY + DATA_API_KEY; | ||
const NAME = 'button'; | ||
const DATA_KEY = 'bs.button'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const CLASS_NAME_ACTIVE = 'active'; | ||
const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="button"]'; | ||
const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`; | ||
/** | ||
@@ -121,21 +94,18 @@ * ------------------------------------------------------------------------ | ||
var Button = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Button, _BaseComponent); | ||
class Button extends BaseComponent__default['default'] { | ||
// Getters | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
function Button() { | ||
return _BaseComponent.apply(this, arguments) || this; | ||
} | ||
var _proto = Button.prototype; | ||
// Public | ||
_proto.toggle = function toggle() { | ||
toggle() { | ||
// Toggle class and sync the `aria-pressed` attribute with the return value of the `.toggle()` method | ||
this._element.setAttribute('aria-pressed', this._element.classList.toggle(CLASS_NAME_ACTIVE)); | ||
} // Static | ||
; | ||
Button.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY); | ||
let data = Data__default['default'].get(this, DATA_KEY); | ||
@@ -150,14 +120,5 @@ if (!data) { | ||
}); | ||
}; | ||
} | ||
_createClass(Button, null, [{ | ||
key: "DATA_KEY", | ||
get: // Getters | ||
function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Button; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -170,6 +131,6 @@ * ------------------------------------------------------------------------ | ||
EventHandler__default['default'].on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) { | ||
EventHandler__default['default'].on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, event => { | ||
event.preventDefault(); | ||
var button = event.target.closest(SELECTOR_DATA_TOGGLE); | ||
var data = Data__default['default'].getData(button, DATA_KEY); | ||
const button = event.target.closest(SELECTOR_DATA_TOGGLE); | ||
let data = Data__default['default'].get(button, DATA_KEY); | ||
@@ -176,0 +137,0 @@ if (!data) { |
/*! | ||
* Bootstrap carousel.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap carousel.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -20,64 +20,14 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MILLISECONDS_MULTIPLIER = 1000; | ||
var TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
const MILLISECONDS_MULTIPLIER = 1000; | ||
const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
var toType = function toType(obj) { | ||
const toType = obj => { | ||
if (obj === null || obj === undefined) { | ||
return "" + obj; | ||
return `${obj}`; | ||
} | ||
@@ -88,7 +38,7 @@ | ||
var getSelector = function getSelector(element) { | ||
var selector = element.getAttribute('data-bs-target'); | ||
const getSelector = element => { | ||
let selector = element.getAttribute('data-bs-target'); | ||
if (!selector || selector === '#') { | ||
var hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
// so everything starting with `#` or `.`. If a "real" URL is used as the selector, | ||
@@ -113,8 +63,8 @@ // `document.querySelector` will rightfully complain it is invalid. | ||
var getElementFromSelector = function getElementFromSelector(element) { | ||
var selector = getSelector(element); | ||
const getElementFromSelector = element => { | ||
const selector = getSelector(element); | ||
return selector ? document.querySelector(selector) : null; | ||
}; | ||
var getTransitionDurationFromElement = function getTransitionDurationFromElement(element) { | ||
const getTransitionDurationFromElement = element => { | ||
if (!element) { | ||
@@ -125,9 +75,9 @@ return 0; | ||
var _window$getComputedSt = window.getComputedStyle(element), | ||
transitionDuration = _window$getComputedSt.transitionDuration, | ||
transitionDelay = _window$getComputedSt.transitionDelay; | ||
let { | ||
transitionDuration, | ||
transitionDelay | ||
} = window.getComputedStyle(element); | ||
const floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
var floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
var floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
if (!floatTransitionDuration && !floatTransitionDelay) { | ||
@@ -143,14 +93,12 @@ return 0; | ||
var triggerTransitionEnd = function triggerTransitionEnd(element) { | ||
const triggerTransitionEnd = element => { | ||
element.dispatchEvent(new Event(TRANSITION_END)); | ||
}; | ||
var isElement = function isElement(obj) { | ||
return (obj[0] || obj).nodeType; | ||
}; | ||
const isElement = obj => (obj[0] || obj).nodeType; | ||
var emulateTransitionEnd = function emulateTransitionEnd(element, duration) { | ||
var called = false; | ||
var durationPadding = 5; | ||
var emulatedDuration = duration + durationPadding; | ||
const emulateTransitionEnd = (element, duration) => { | ||
let called = false; | ||
const durationPadding = 5; | ||
const emulatedDuration = duration + durationPadding; | ||
@@ -163,3 +111,3 @@ function listener() { | ||
element.addEventListener(TRANSITION_END, listener); | ||
setTimeout(function () { | ||
setTimeout(() => { | ||
if (!called) { | ||
@@ -171,10 +119,10 @@ triggerTransitionEnd(element); | ||
var typeCheckConfig = function typeCheckConfig(componentName, config, configTypes) { | ||
Object.keys(configTypes).forEach(function (property) { | ||
var expectedTypes = configTypes[property]; | ||
var value = config[property]; | ||
var valueType = value && isElement(value) ? 'element' : toType(value); | ||
const typeCheckConfig = (componentName, config, configTypes) => { | ||
Object.keys(configTypes).forEach(property => { | ||
const expectedTypes = configTypes[property]; | ||
const value = config[property]; | ||
const valueType = value && isElement(value) ? 'element' : toType(value); | ||
if (!new RegExp(expectedTypes).test(valueType)) { | ||
throw new TypeError(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); | ||
throw new TypeError(`${componentName.toUpperCase()}: ` + `Option "${property}" provided type "${valueType}" ` + `but expected type "${expectedTypes}".`); | ||
} | ||
@@ -184,3 +132,3 @@ }); | ||
var isVisible = function isVisible(element) { | ||
const isVisible = element => { | ||
if (!element) { | ||
@@ -191,4 +139,4 @@ return false; | ||
if (element.style && element.parentNode && element.parentNode.style) { | ||
var elementStyle = getComputedStyle(element); | ||
var parentNodeStyle = getComputedStyle(element.parentNode); | ||
const elementStyle = getComputedStyle(element); | ||
const parentNodeStyle = getComputedStyle(element.parentNode); | ||
return elementStyle.display !== 'none' && parentNodeStyle.display !== 'none' && elementStyle.visibility !== 'hidden'; | ||
@@ -200,9 +148,8 @@ } | ||
var reflow = function reflow(element) { | ||
return element.offsetHeight; | ||
}; | ||
const reflow = element => element.offsetHeight; | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -216,3 +163,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -225,15 +172,15 @@ document.addEventListener('DOMContentLoaded', callback); | ||
var isRTL = document.documentElement.dir === 'rtl'; | ||
const isRTL = () => document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -247,2 +194,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): carousel.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -253,12 +206,12 @@ * Constants | ||
var NAME = 'carousel'; | ||
var DATA_KEY = 'bs.carousel'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var ARROW_LEFT_KEY = 'ArrowLeft'; | ||
var ARROW_RIGHT_KEY = 'ArrowRight'; | ||
var TOUCHEVENT_COMPAT_WAIT = 500; // Time for mouse compat events to fire after touch | ||
const NAME = 'carousel'; | ||
const DATA_KEY = 'bs.carousel'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const ARROW_LEFT_KEY = 'ArrowLeft'; | ||
const ARROW_RIGHT_KEY = 'ArrowRight'; | ||
const TOUCHEVENT_COMPAT_WAIT = 500; // Time for mouse compat events to fire after touch | ||
var SWIPE_THRESHOLD = 40; | ||
var Default = { | ||
const SWIPE_THRESHOLD = 40; | ||
const Default = { | ||
interval: 5000, | ||
@@ -271,3 +224,3 @@ keyboard: true, | ||
}; | ||
var DefaultType = { | ||
const DefaultType = { | ||
interval: '(number|boolean)', | ||
@@ -280,38 +233,38 @@ keyboard: 'boolean', | ||
}; | ||
var DIRECTION_NEXT = 'next'; | ||
var DIRECTION_PREV = 'prev'; | ||
var DIRECTION_LEFT = 'left'; | ||
var DIRECTION_RIGHT = 'right'; | ||
var EVENT_SLIDE = "slide" + EVENT_KEY; | ||
var EVENT_SLID = "slid" + EVENT_KEY; | ||
var EVENT_KEYDOWN = "keydown" + EVENT_KEY; | ||
var EVENT_MOUSEENTER = "mouseenter" + EVENT_KEY; | ||
var EVENT_MOUSELEAVE = "mouseleave" + EVENT_KEY; | ||
var EVENT_TOUCHSTART = "touchstart" + EVENT_KEY; | ||
var EVENT_TOUCHMOVE = "touchmove" + EVENT_KEY; | ||
var EVENT_TOUCHEND = "touchend" + EVENT_KEY; | ||
var EVENT_POINTERDOWN = "pointerdown" + EVENT_KEY; | ||
var EVENT_POINTERUP = "pointerup" + EVENT_KEY; | ||
var EVENT_DRAG_START = "dragstart" + EVENT_KEY; | ||
var EVENT_LOAD_DATA_API = "load" + EVENT_KEY + DATA_API_KEY; | ||
var EVENT_CLICK_DATA_API = "click" + EVENT_KEY + DATA_API_KEY; | ||
var CLASS_NAME_CAROUSEL = 'carousel'; | ||
var CLASS_NAME_ACTIVE = 'active'; | ||
var CLASS_NAME_SLIDE = 'slide'; | ||
var CLASS_NAME_END = 'carousel-item-end'; | ||
var CLASS_NAME_START = 'carousel-item-start'; | ||
var CLASS_NAME_NEXT = 'carousel-item-next'; | ||
var CLASS_NAME_PREV = 'carousel-item-prev'; | ||
var CLASS_NAME_POINTER_EVENT = 'pointer-event'; | ||
var SELECTOR_ACTIVE = '.active'; | ||
var SELECTOR_ACTIVE_ITEM = '.active.carousel-item'; | ||
var SELECTOR_ITEM = '.carousel-item'; | ||
var SELECTOR_ITEM_IMG = '.carousel-item img'; | ||
var SELECTOR_NEXT_PREV = '.carousel-item-next, .carousel-item-prev'; | ||
var SELECTOR_INDICATORS = '.carousel-indicators'; | ||
var SELECTOR_INDICATOR = '[data-bs-target]'; | ||
var SELECTOR_DATA_SLIDE = '[data-bs-slide], [data-bs-slide-to]'; | ||
var SELECTOR_DATA_RIDE = '[data-bs-ride="carousel"]'; | ||
var POINTER_TYPE_TOUCH = 'touch'; | ||
var POINTER_TYPE_PEN = 'pen'; | ||
const ORDER_NEXT = 'next'; | ||
const ORDER_PREV = 'prev'; | ||
const DIRECTION_LEFT = 'left'; | ||
const DIRECTION_RIGHT = 'right'; | ||
const EVENT_SLIDE = `slide${EVENT_KEY}`; | ||
const EVENT_SLID = `slid${EVENT_KEY}`; | ||
const EVENT_KEYDOWN = `keydown${EVENT_KEY}`; | ||
const EVENT_MOUSEENTER = `mouseenter${EVENT_KEY}`; | ||
const EVENT_MOUSELEAVE = `mouseleave${EVENT_KEY}`; | ||
const EVENT_TOUCHSTART = `touchstart${EVENT_KEY}`; | ||
const EVENT_TOUCHMOVE = `touchmove${EVENT_KEY}`; | ||
const EVENT_TOUCHEND = `touchend${EVENT_KEY}`; | ||
const EVENT_POINTERDOWN = `pointerdown${EVENT_KEY}`; | ||
const EVENT_POINTERUP = `pointerup${EVENT_KEY}`; | ||
const EVENT_DRAG_START = `dragstart${EVENT_KEY}`; | ||
const EVENT_LOAD_DATA_API = `load${EVENT_KEY}${DATA_API_KEY}`; | ||
const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`; | ||
const CLASS_NAME_CAROUSEL = 'carousel'; | ||
const CLASS_NAME_ACTIVE = 'active'; | ||
const CLASS_NAME_SLIDE = 'slide'; | ||
const CLASS_NAME_END = 'carousel-item-end'; | ||
const CLASS_NAME_START = 'carousel-item-start'; | ||
const CLASS_NAME_NEXT = 'carousel-item-next'; | ||
const CLASS_NAME_PREV = 'carousel-item-prev'; | ||
const CLASS_NAME_POINTER_EVENT = 'pointer-event'; | ||
const SELECTOR_ACTIVE = '.active'; | ||
const SELECTOR_ACTIVE_ITEM = '.active.carousel-item'; | ||
const SELECTOR_ITEM = '.carousel-item'; | ||
const SELECTOR_ITEM_IMG = '.carousel-item img'; | ||
const SELECTOR_NEXT_PREV = '.carousel-item-next, .carousel-item-prev'; | ||
const SELECTOR_INDICATORS = '.carousel-indicators'; | ||
const SELECTOR_INDICATOR = '[data-bs-target]'; | ||
const SELECTOR_DATA_SLIDE = '[data-bs-slide], [data-bs-slide-to]'; | ||
const SELECTOR_DATA_RIDE = '[data-bs-ride="carousel"]'; | ||
const POINTER_TYPE_TOUCH = 'touch'; | ||
const POINTER_TYPE_PEN = 'pen'; | ||
/** | ||
@@ -323,38 +276,38 @@ * ------------------------------------------------------------------------ | ||
var Carousel = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Carousel, _BaseComponent); | ||
class Carousel extends BaseComponent__default['default'] { | ||
constructor(element, config) { | ||
super(element); | ||
this._items = null; | ||
this._interval = null; | ||
this._activeElement = null; | ||
this._isPaused = false; | ||
this._isSliding = false; | ||
this.touchTimeout = null; | ||
this.touchStartX = 0; | ||
this.touchDeltaX = 0; | ||
this._config = this._getConfig(config); | ||
this._indicatorsElement = SelectorEngine__default['default'].findOne(SELECTOR_INDICATORS, this._element); | ||
this._touchSupported = 'ontouchstart' in document.documentElement || navigator.maxTouchPoints > 0; | ||
this._pointerEvent = Boolean(window.PointerEvent); | ||
function Carousel(element, config) { | ||
var _this; | ||
this._addEventListeners(); | ||
} // Getters | ||
_this = _BaseComponent.call(this, element) || this; | ||
_this._items = null; | ||
_this._interval = null; | ||
_this._activeElement = null; | ||
_this._isPaused = false; | ||
_this._isSliding = false; | ||
_this.touchTimeout = null; | ||
_this.touchStartX = 0; | ||
_this.touchDeltaX = 0; | ||
_this._config = _this._getConfig(config); | ||
_this._indicatorsElement = SelectorEngine__default['default'].findOne(SELECTOR_INDICATORS, _this._element); | ||
_this._touchSupported = 'ontouchstart' in document.documentElement || navigator.maxTouchPoints > 0; | ||
_this._pointerEvent = Boolean(window.PointerEvent); | ||
_this._addEventListeners(); | ||
static get Default() { | ||
return Default; | ||
} | ||
return _this; | ||
} // Getters | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
var _proto = Carousel.prototype; | ||
// Public | ||
_proto.next = function next() { | ||
next() { | ||
if (!this._isSliding) { | ||
this._slide(DIRECTION_NEXT); | ||
this._slide(ORDER_NEXT); | ||
} | ||
}; | ||
} | ||
_proto.nextWhenVisible = function nextWhenVisible() { | ||
nextWhenVisible() { | ||
// Don't call next when the page isn't visible | ||
@@ -365,11 +318,11 @@ // or the carousel or its parent isn't visible | ||
} | ||
}; | ||
} | ||
_proto.prev = function prev() { | ||
prev() { | ||
if (!this._isSliding) { | ||
this._slide(DIRECTION_PREV); | ||
this._slide(ORDER_PREV); | ||
} | ||
}; | ||
} | ||
_proto.pause = function pause(event) { | ||
pause(event) { | ||
if (!event) { | ||
@@ -386,5 +339,5 @@ this._isPaused = true; | ||
this._interval = null; | ||
}; | ||
} | ||
_proto.cycle = function cycle(event) { | ||
cycle(event) { | ||
if (!event) { | ||
@@ -404,10 +357,8 @@ this._isPaused = false; | ||
} | ||
}; | ||
} | ||
_proto.to = function to(index) { | ||
var _this2 = this; | ||
to(index) { | ||
this._activeElement = SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE_ITEM, this._element); | ||
var activeIndex = this._getItemIndex(this._activeElement); | ||
const activeIndex = this._getItemIndex(this._activeElement); | ||
@@ -419,5 +370,3 @@ if (index > this._items.length - 1 || index < 0) { | ||
if (this._isSliding) { | ||
EventHandler__default['default'].one(this._element, EVENT_SLID, function () { | ||
return _this2.to(index); | ||
}); | ||
EventHandler__default['default'].one(this._element, EVENT_SLID, () => this.to(index)); | ||
return; | ||
@@ -432,10 +381,8 @@ } | ||
var direction = index > activeIndex ? DIRECTION_NEXT : DIRECTION_PREV; | ||
const order = index > activeIndex ? ORDER_NEXT : ORDER_PREV; | ||
this._slide(direction, this._items[index]); | ||
}; | ||
this._slide(order, this._items[index]); | ||
} | ||
_proto.dispose = function dispose() { | ||
_BaseComponent.prototype.dispose.call(this); | ||
dispose() { | ||
EventHandler__default['default'].off(this._element, EVENT_KEY); | ||
@@ -449,13 +396,16 @@ this._items = null; | ||
this._indicatorsElement = null; | ||
super.dispose(); | ||
} // Private | ||
; | ||
_proto._getConfig = function _getConfig(config) { | ||
config = _extends({}, Default, config); | ||
_getConfig(config) { | ||
config = { ...Default, | ||
...config | ||
}; | ||
typeCheckConfig(NAME, config, DefaultType); | ||
return config; | ||
}; | ||
} | ||
_proto._handleSwipe = function _handleSwipe() { | ||
var absDeltax = Math.abs(this.touchDeltaX); | ||
_handleSwipe() { | ||
const absDeltax = Math.abs(this.touchDeltaX); | ||
@@ -466,39 +416,20 @@ if (absDeltax <= SWIPE_THRESHOLD) { | ||
var direction = absDeltax / this.touchDeltaX; | ||
this.touchDeltaX = 0; // swipe left | ||
const direction = absDeltax / this.touchDeltaX; | ||
this.touchDeltaX = 0; | ||
if (direction > 0) { | ||
if (isRTL) { | ||
this.next(); | ||
} else { | ||
this.prev(); | ||
} | ||
} // swipe right | ||
if (direction < 0) { | ||
if (isRTL) { | ||
this.prev(); | ||
} else { | ||
this.next(); | ||
} | ||
if (!direction) { | ||
return; | ||
} | ||
}; | ||
_proto._addEventListeners = function _addEventListeners() { | ||
var _this3 = this; | ||
this._slide(direction > 0 ? DIRECTION_RIGHT : DIRECTION_LEFT); | ||
} | ||
_addEventListeners() { | ||
if (this._config.keyboard) { | ||
EventHandler__default['default'].on(this._element, EVENT_KEYDOWN, function (event) { | ||
return _this3._keydown(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_KEYDOWN, event => this._keydown(event)); | ||
} | ||
if (this._config.pause === 'hover') { | ||
EventHandler__default['default'].on(this._element, EVENT_MOUSEENTER, function (event) { | ||
return _this3.pause(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_MOUSELEAVE, function (event) { | ||
return _this3.cycle(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_MOUSEENTER, event => this.pause(event)); | ||
EventHandler__default['default'].on(this._element, EVENT_MOUSELEAVE, event => this.cycle(event)); | ||
} | ||
@@ -509,32 +440,26 @@ | ||
} | ||
}; | ||
} | ||
_proto._addTouchEventListeners = function _addTouchEventListeners() { | ||
var _this4 = this; | ||
var start = function start(event) { | ||
if (_this4._pointerEvent && (event.pointerType === POINTER_TYPE_PEN || event.pointerType === POINTER_TYPE_TOUCH)) { | ||
_this4.touchStartX = event.clientX; | ||
} else if (!_this4._pointerEvent) { | ||
_this4.touchStartX = event.touches[0].clientX; | ||
_addTouchEventListeners() { | ||
const start = event => { | ||
if (this._pointerEvent && (event.pointerType === POINTER_TYPE_PEN || event.pointerType === POINTER_TYPE_TOUCH)) { | ||
this.touchStartX = event.clientX; | ||
} else if (!this._pointerEvent) { | ||
this.touchStartX = event.touches[0].clientX; | ||
} | ||
}; | ||
var move = function move(event) { | ||
const move = event => { | ||
// ensure swiping with one touch and not pinching | ||
if (event.touches && event.touches.length > 1) { | ||
_this4.touchDeltaX = 0; | ||
} else { | ||
_this4.touchDeltaX = event.touches[0].clientX - _this4.touchStartX; | ||
} | ||
this.touchDeltaX = event.touches && event.touches.length > 1 ? 0 : event.touches[0].clientX - this.touchStartX; | ||
}; | ||
var end = function end(event) { | ||
if (_this4._pointerEvent && (event.pointerType === POINTER_TYPE_PEN || event.pointerType === POINTER_TYPE_TOUCH)) { | ||
_this4.touchDeltaX = event.clientX - _this4.touchStartX; | ||
const end = event => { | ||
if (this._pointerEvent && (event.pointerType === POINTER_TYPE_PEN || event.pointerType === POINTER_TYPE_TOUCH)) { | ||
this.touchDeltaX = event.clientX - this.touchStartX; | ||
} | ||
_this4._handleSwipe(); | ||
this._handleSwipe(); | ||
if (_this4._config.pause === 'hover') { | ||
if (this._config.pause === 'hover') { | ||
// If it's a touch-enabled device, mouseenter/leave are fired as | ||
@@ -547,43 +472,29 @@ // part of the mouse compatibility events on first tap - the carousel | ||
// events to fire) we explicitly restart cycling | ||
_this4.pause(); | ||
this.pause(); | ||
if (_this4.touchTimeout) { | ||
clearTimeout(_this4.touchTimeout); | ||
if (this.touchTimeout) { | ||
clearTimeout(this.touchTimeout); | ||
} | ||
_this4.touchTimeout = setTimeout(function (event) { | ||
return _this4.cycle(event); | ||
}, TOUCHEVENT_COMPAT_WAIT + _this4._config.interval); | ||
this.touchTimeout = setTimeout(event => this.cycle(event), TOUCHEVENT_COMPAT_WAIT + this._config.interval); | ||
} | ||
}; | ||
SelectorEngine__default['default'].find(SELECTOR_ITEM_IMG, this._element).forEach(function (itemImg) { | ||
EventHandler__default['default'].on(itemImg, EVENT_DRAG_START, function (e) { | ||
return e.preventDefault(); | ||
}); | ||
SelectorEngine__default['default'].find(SELECTOR_ITEM_IMG, this._element).forEach(itemImg => { | ||
EventHandler__default['default'].on(itemImg, EVENT_DRAG_START, e => e.preventDefault()); | ||
}); | ||
if (this._pointerEvent) { | ||
EventHandler__default['default'].on(this._element, EVENT_POINTERDOWN, function (event) { | ||
return start(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_POINTERUP, function (event) { | ||
return end(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_POINTERDOWN, event => start(event)); | ||
EventHandler__default['default'].on(this._element, EVENT_POINTERUP, event => end(event)); | ||
this._element.classList.add(CLASS_NAME_POINTER_EVENT); | ||
} else { | ||
EventHandler__default['default'].on(this._element, EVENT_TOUCHSTART, function (event) { | ||
return start(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_TOUCHMOVE, function (event) { | ||
return move(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_TOUCHEND, function (event) { | ||
return end(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, EVENT_TOUCHSTART, event => start(event)); | ||
EventHandler__default['default'].on(this._element, EVENT_TOUCHMOVE, event => move(event)); | ||
EventHandler__default['default'].on(this._element, EVENT_TOUCHEND, event => end(event)); | ||
} | ||
}; | ||
} | ||
_proto._keydown = function _keydown(event) { | ||
_keydown(event) { | ||
if (/input|textarea/i.test(event.target.tagName)) { | ||
@@ -596,31 +507,23 @@ return; | ||
if (isRTL) { | ||
this.next(); | ||
} else { | ||
this.prev(); | ||
} | ||
this._slide(DIRECTION_LEFT); | ||
} else if (event.key === ARROW_RIGHT_KEY) { | ||
event.preventDefault(); | ||
if (isRTL) { | ||
this.prev(); | ||
} else { | ||
this.next(); | ||
} | ||
this._slide(DIRECTION_RIGHT); | ||
} | ||
}; | ||
} | ||
_proto._getItemIndex = function _getItemIndex(element) { | ||
_getItemIndex(element) { | ||
this._items = element && element.parentNode ? SelectorEngine__default['default'].find(SELECTOR_ITEM, element.parentNode) : []; | ||
return this._items.indexOf(element); | ||
}; | ||
} | ||
_proto._getItemByDirection = function _getItemByDirection(direction, activeElement) { | ||
var isNextDirection = direction === DIRECTION_NEXT; | ||
var isPrevDirection = direction === DIRECTION_PREV; | ||
_getItemByOrder(order, activeElement) { | ||
const isNext = order === ORDER_NEXT; | ||
const isPrev = order === ORDER_PREV; | ||
var activeIndex = this._getItemIndex(activeElement); | ||
const activeIndex = this._getItemIndex(activeElement); | ||
var lastItemIndex = this._items.length - 1; | ||
var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex; | ||
const lastItemIndex = this._items.length - 1; | ||
const isGoingToWrap = isPrev && activeIndex === 0 || isNext && activeIndex === lastItemIndex; | ||
@@ -631,14 +534,14 @@ if (isGoingToWrap && !this._config.wrap) { | ||
var delta = direction === DIRECTION_PREV ? -1 : 1; | ||
var itemIndex = (activeIndex + delta) % this._items.length; | ||
const delta = isPrev ? -1 : 1; | ||
const itemIndex = (activeIndex + delta) % this._items.length; | ||
return itemIndex === -1 ? this._items[this._items.length - 1] : this._items[itemIndex]; | ||
}; | ||
} | ||
_proto._triggerSlideEvent = function _triggerSlideEvent(relatedTarget, eventDirectionName) { | ||
var targetIndex = this._getItemIndex(relatedTarget); | ||
_triggerSlideEvent(relatedTarget, eventDirectionName) { | ||
const targetIndex = this._getItemIndex(relatedTarget); | ||
var fromIndex = this._getItemIndex(SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE_ITEM, this._element)); | ||
const fromIndex = this._getItemIndex(SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE_ITEM, this._element)); | ||
return EventHandler__default['default'].trigger(this._element, EVENT_SLIDE, { | ||
relatedTarget: relatedTarget, | ||
relatedTarget, | ||
direction: eventDirectionName, | ||
@@ -648,12 +551,12 @@ from: fromIndex, | ||
}); | ||
}; | ||
} | ||
_proto._setActiveIndicatorElement = function _setActiveIndicatorElement(element) { | ||
_setActiveIndicatorElement(element) { | ||
if (this._indicatorsElement) { | ||
var activeIndicator = SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE, this._indicatorsElement); | ||
const activeIndicator = SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE, this._indicatorsElement); | ||
activeIndicator.classList.remove(CLASS_NAME_ACTIVE); | ||
activeIndicator.removeAttribute('aria-current'); | ||
var indicators = SelectorEngine__default['default'].find(SELECTOR_INDICATOR, this._indicatorsElement); | ||
const indicators = SelectorEngine__default['default'].find(SELECTOR_INDICATOR, this._indicatorsElement); | ||
for (var i = 0; i < indicators.length; i++) { | ||
for (let i = 0; i < indicators.length; i++) { | ||
if (Number.parseInt(indicators[i].getAttribute('data-bs-slide-to'), 10) === this._getItemIndex(element)) { | ||
@@ -666,6 +569,6 @@ indicators[i].classList.add(CLASS_NAME_ACTIVE); | ||
} | ||
}; | ||
} | ||
_proto._updateInterval = function _updateInterval() { | ||
var element = this._activeElement || SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE_ITEM, this._element); | ||
_updateInterval() { | ||
const element = this._activeElement || SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE_ITEM, this._element); | ||
@@ -676,3 +579,3 @@ if (!element) { | ||
var elementInterval = Number.parseInt(element.getAttribute('data-bs-interval'), 10); | ||
const elementInterval = Number.parseInt(element.getAttribute('data-bs-interval'), 10); | ||
@@ -685,20 +588,22 @@ if (elementInterval) { | ||
} | ||
}; | ||
} | ||
_proto._slide = function _slide(direction, element) { | ||
var _this5 = this; | ||
_slide(directionOrOrder, element) { | ||
const order = this._directionToOrder(directionOrOrder); | ||
var activeElement = SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE_ITEM, this._element); | ||
const activeElement = SelectorEngine__default['default'].findOne(SELECTOR_ACTIVE_ITEM, this._element); | ||
var activeElementIndex = this._getItemIndex(activeElement); | ||
const activeElementIndex = this._getItemIndex(activeElement); | ||
var nextElement = element || activeElement && this._getItemByDirection(direction, activeElement); | ||
const nextElement = element || this._getItemByOrder(order, activeElement); | ||
var nextElementIndex = this._getItemIndex(nextElement); | ||
const nextElementIndex = this._getItemIndex(nextElement); | ||
var isCycling = Boolean(this._interval); | ||
var directionalClassName = direction === DIRECTION_NEXT ? CLASS_NAME_START : CLASS_NAME_END; | ||
var orderClassName = direction === DIRECTION_NEXT ? CLASS_NAME_NEXT : CLASS_NAME_PREV; | ||
var eventDirectionName = direction === DIRECTION_NEXT ? DIRECTION_LEFT : DIRECTION_RIGHT; | ||
const isCycling = Boolean(this._interval); | ||
const isNext = order === ORDER_NEXT; | ||
const directionalClassName = isNext ? CLASS_NAME_START : CLASS_NAME_END; | ||
const orderClassName = isNext ? CLASS_NAME_NEXT : CLASS_NAME_PREV; | ||
const eventDirectionName = this._orderToDirection(order); | ||
if (nextElement && nextElement.classList.contains(CLASS_NAME_ACTIVE)) { | ||
@@ -709,3 +614,3 @@ this._isSliding = false; | ||
var slideEvent = this._triggerSlideEvent(nextElement, eventDirectionName); | ||
const slideEvent = this._triggerSlideEvent(nextElement, eventDirectionName); | ||
@@ -736,10 +641,10 @@ if (slideEvent.defaultPrevented) { | ||
nextElement.classList.add(directionalClassName); | ||
var transitionDuration = getTransitionDurationFromElement(activeElement); | ||
EventHandler__default['default'].one(activeElement, 'transitionend', function () { | ||
const transitionDuration = getTransitionDurationFromElement(activeElement); | ||
EventHandler__default['default'].one(activeElement, 'transitionend', () => { | ||
nextElement.classList.remove(directionalClassName, orderClassName); | ||
nextElement.classList.add(CLASS_NAME_ACTIVE); | ||
activeElement.classList.remove(CLASS_NAME_ACTIVE, orderClassName, directionalClassName); | ||
_this5._isSliding = false; | ||
setTimeout(function () { | ||
EventHandler__default['default'].trigger(_this5._element, EVENT_SLID, { | ||
this._isSliding = false; | ||
setTimeout(() => { | ||
EventHandler__default['default'].trigger(this._element, EVENT_SLID, { | ||
relatedTarget: nextElement, | ||
@@ -768,15 +673,42 @@ direction: eventDirectionName, | ||
} | ||
} | ||
_directionToOrder(direction) { | ||
if (![DIRECTION_RIGHT, DIRECTION_LEFT].includes(direction)) { | ||
return direction; | ||
} | ||
if (isRTL()) { | ||
return direction === DIRECTION_RIGHT ? ORDER_PREV : ORDER_NEXT; | ||
} | ||
return direction === DIRECTION_RIGHT ? ORDER_NEXT : ORDER_PREV; | ||
} | ||
_orderToDirection(order) { | ||
if (![ORDER_NEXT, ORDER_PREV].includes(order)) { | ||
return order; | ||
} | ||
if (isRTL()) { | ||
return order === ORDER_NEXT ? DIRECTION_LEFT : DIRECTION_RIGHT; | ||
} | ||
return order === ORDER_NEXT ? DIRECTION_RIGHT : DIRECTION_LEFT; | ||
} // Static | ||
; | ||
Carousel.carouselInterface = function carouselInterface(element, config) { | ||
var data = Data__default['default'].getData(element, DATA_KEY); | ||
var _config = _extends({}, Default, Manipulator__default['default'].getDataAttributes(element)); | ||
static carouselInterface(element, config) { | ||
let data = Data__default['default'].get(element, DATA_KEY); | ||
let _config = { ...Default, | ||
...Manipulator__default['default'].getDataAttributes(element) | ||
}; | ||
if (typeof config === 'object') { | ||
_config = _extends({}, _config, config); | ||
_config = { ..._config, | ||
...config | ||
}; | ||
} | ||
var action = typeof config === 'string' ? config : _config.slide; | ||
const action = typeof config === 'string' ? config : _config.slide; | ||
@@ -791,3 +723,3 @@ if (!data) { | ||
if (typeof data[action] === 'undefined') { | ||
throw new TypeError("No method named \"" + action + "\""); | ||
throw new TypeError(`No method named "${action}"`); | ||
} | ||
@@ -800,12 +732,12 @@ | ||
} | ||
}; | ||
} | ||
Carousel.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
Carousel.carouselInterface(this, config); | ||
}); | ||
}; | ||
} | ||
Carousel.dataApiClickHandler = function dataApiClickHandler(event) { | ||
var target = getElementFromSelector(this); | ||
static dataApiClickHandler(event) { | ||
const target = getElementFromSelector(this); | ||
@@ -816,6 +748,7 @@ if (!target || !target.classList.contains(CLASS_NAME_CAROUSEL)) { | ||
var config = _extends({}, Manipulator__default['default'].getDataAttributes(target), Manipulator__default['default'].getDataAttributes(this)); | ||
const config = { ...Manipulator__default['default'].getDataAttributes(target), | ||
...Manipulator__default['default'].getDataAttributes(this) | ||
}; | ||
const slideIndex = this.getAttribute('data-bs-slide-to'); | ||
var slideIndex = this.getAttribute('data-bs-slide-to'); | ||
if (slideIndex) { | ||
@@ -828,22 +761,9 @@ config.interval = false; | ||
if (slideIndex) { | ||
Data__default['default'].getData(target, DATA_KEY).to(slideIndex); | ||
Data__default['default'].get(target, DATA_KEY).to(slideIndex); | ||
} | ||
event.preventDefault(); | ||
}; | ||
} | ||
_createClass(Carousel, null, [{ | ||
key: "Default", | ||
get: function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Carousel; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -857,7 +777,7 @@ * ------------------------------------------------------------------------ | ||
EventHandler__default['default'].on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_SLIDE, Carousel.dataApiClickHandler); | ||
EventHandler__default['default'].on(window, EVENT_LOAD_DATA_API, function () { | ||
var carousels = SelectorEngine__default['default'].find(SELECTOR_DATA_RIDE); | ||
EventHandler__default['default'].on(window, EVENT_LOAD_DATA_API, () => { | ||
const carousels = SelectorEngine__default['default'].find(SELECTOR_DATA_RIDE); | ||
for (var i = 0, len = carousels.length; i < len; i++) { | ||
Carousel.carouselInterface(carousels[i], Data__default['default'].getData(carousels[i], DATA_KEY)); | ||
for (let i = 0, len = carousels.length; i < len; i++) { | ||
Carousel.carouselInterface(carousels[i], Data__default['default'].get(carousels[i], DATA_KEY)); | ||
} | ||
@@ -864,0 +784,0 @@ }); |
/*! | ||
* Bootstrap collapse.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap collapse.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -20,64 +20,14 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MILLISECONDS_MULTIPLIER = 1000; | ||
var TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
const MILLISECONDS_MULTIPLIER = 1000; | ||
const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
var toType = function toType(obj) { | ||
const toType = obj => { | ||
if (obj === null || obj === undefined) { | ||
return "" + obj; | ||
return `${obj}`; | ||
} | ||
@@ -88,7 +38,7 @@ | ||
var getSelector = function getSelector(element) { | ||
var selector = element.getAttribute('data-bs-target'); | ||
const getSelector = element => { | ||
let selector = element.getAttribute('data-bs-target'); | ||
if (!selector || selector === '#') { | ||
var hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
// so everything starting with `#` or `.`. If a "real" URL is used as the selector, | ||
@@ -113,4 +63,4 @@ // `document.querySelector` will rightfully complain it is invalid. | ||
var getSelectorFromElement = function getSelectorFromElement(element) { | ||
var selector = getSelector(element); | ||
const getSelectorFromElement = element => { | ||
const selector = getSelector(element); | ||
@@ -124,8 +74,8 @@ if (selector) { | ||
var getElementFromSelector = function getElementFromSelector(element) { | ||
var selector = getSelector(element); | ||
const getElementFromSelector = element => { | ||
const selector = getSelector(element); | ||
return selector ? document.querySelector(selector) : null; | ||
}; | ||
var getTransitionDurationFromElement = function getTransitionDurationFromElement(element) { | ||
const getTransitionDurationFromElement = element => { | ||
if (!element) { | ||
@@ -136,9 +86,9 @@ return 0; | ||
var _window$getComputedSt = window.getComputedStyle(element), | ||
transitionDuration = _window$getComputedSt.transitionDuration, | ||
transitionDelay = _window$getComputedSt.transitionDelay; | ||
let { | ||
transitionDuration, | ||
transitionDelay | ||
} = window.getComputedStyle(element); | ||
const floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
var floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
var floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
if (!floatTransitionDuration && !floatTransitionDelay) { | ||
@@ -154,14 +104,12 @@ return 0; | ||
var triggerTransitionEnd = function triggerTransitionEnd(element) { | ||
const triggerTransitionEnd = element => { | ||
element.dispatchEvent(new Event(TRANSITION_END)); | ||
}; | ||
var isElement = function isElement(obj) { | ||
return (obj[0] || obj).nodeType; | ||
}; | ||
const isElement = obj => (obj[0] || obj).nodeType; | ||
var emulateTransitionEnd = function emulateTransitionEnd(element, duration) { | ||
var called = false; | ||
var durationPadding = 5; | ||
var emulatedDuration = duration + durationPadding; | ||
const emulateTransitionEnd = (element, duration) => { | ||
let called = false; | ||
const durationPadding = 5; | ||
const emulatedDuration = duration + durationPadding; | ||
@@ -174,3 +122,3 @@ function listener() { | ||
element.addEventListener(TRANSITION_END, listener); | ||
setTimeout(function () { | ||
setTimeout(() => { | ||
if (!called) { | ||
@@ -182,10 +130,10 @@ triggerTransitionEnd(element); | ||
var typeCheckConfig = function typeCheckConfig(componentName, config, configTypes) { | ||
Object.keys(configTypes).forEach(function (property) { | ||
var expectedTypes = configTypes[property]; | ||
var value = config[property]; | ||
var valueType = value && isElement(value) ? 'element' : toType(value); | ||
const typeCheckConfig = (componentName, config, configTypes) => { | ||
Object.keys(configTypes).forEach(property => { | ||
const expectedTypes = configTypes[property]; | ||
const value = config[property]; | ||
const valueType = value && isElement(value) ? 'element' : toType(value); | ||
if (!new RegExp(expectedTypes).test(valueType)) { | ||
throw new TypeError(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); | ||
throw new TypeError(`${componentName.toUpperCase()}: ` + `Option "${property}" provided type "${valueType}" ` + `but expected type "${expectedTypes}".`); | ||
} | ||
@@ -195,9 +143,8 @@ }); | ||
var reflow = function reflow(element) { | ||
return element.offsetHeight; | ||
}; | ||
const reflow = element => element.offsetHeight; | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -211,3 +158,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -220,15 +167,13 @@ document.addEventListener('DOMContentLoaded', callback); | ||
document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -242,2 +187,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): collapse.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -248,27 +199,27 @@ * Constants | ||
var NAME = 'collapse'; | ||
var DATA_KEY = 'bs.collapse'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var Default = { | ||
const NAME = 'collapse'; | ||
const DATA_KEY = 'bs.collapse'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const Default = { | ||
toggle: true, | ||
parent: '' | ||
}; | ||
var DefaultType = { | ||
const DefaultType = { | ||
toggle: 'boolean', | ||
parent: '(string|element)' | ||
}; | ||
var EVENT_SHOW = "show" + EVENT_KEY; | ||
var EVENT_SHOWN = "shown" + EVENT_KEY; | ||
var EVENT_HIDE = "hide" + EVENT_KEY; | ||
var EVENT_HIDDEN = "hidden" + EVENT_KEY; | ||
var EVENT_CLICK_DATA_API = "click" + EVENT_KEY + DATA_API_KEY; | ||
var CLASS_NAME_SHOW = 'show'; | ||
var CLASS_NAME_COLLAPSE = 'collapse'; | ||
var CLASS_NAME_COLLAPSING = 'collapsing'; | ||
var CLASS_NAME_COLLAPSED = 'collapsed'; | ||
var WIDTH = 'width'; | ||
var HEIGHT = 'height'; | ||
var SELECTOR_ACTIVES = '.show, .collapsing'; | ||
var SELECTOR_DATA_TOGGLE = '[data-bs-toggle="collapse"]'; | ||
const EVENT_SHOW = `show${EVENT_KEY}`; | ||
const EVENT_SHOWN = `shown${EVENT_KEY}`; | ||
const EVENT_HIDE = `hide${EVENT_KEY}`; | ||
const EVENT_HIDDEN = `hidden${EVENT_KEY}`; | ||
const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`; | ||
const CLASS_NAME_SHOW = 'show'; | ||
const CLASS_NAME_COLLAPSE = 'collapse'; | ||
const CLASS_NAME_COLLAPSING = 'collapsing'; | ||
const CLASS_NAME_COLLAPSED = 'collapsed'; | ||
const WIDTH = 'width'; | ||
const HEIGHT = 'height'; | ||
const SELECTOR_ACTIVES = '.show, .collapsing'; | ||
const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="collapse"]'; | ||
/** | ||
@@ -280,46 +231,44 @@ * ------------------------------------------------------------------------ | ||
var Collapse = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Collapse, _BaseComponent); | ||
class Collapse extends BaseComponent__default['default'] { | ||
constructor(element, config) { | ||
super(element); | ||
this._isTransitioning = false; | ||
this._config = this._getConfig(config); | ||
this._triggerArray = SelectorEngine__default['default'].find(`${SELECTOR_DATA_TOGGLE}[href="#${this._element.id}"],` + `${SELECTOR_DATA_TOGGLE}[data-bs-target="#${this._element.id}"]`); | ||
const toggleList = SelectorEngine__default['default'].find(SELECTOR_DATA_TOGGLE); | ||
function Collapse(element, config) { | ||
var _this; | ||
for (let i = 0, len = toggleList.length; i < len; i++) { | ||
const elem = toggleList[i]; | ||
const selector = getSelectorFromElement(elem); | ||
const filterElement = SelectorEngine__default['default'].find(selector).filter(foundElem => foundElem === this._element); | ||
_this = _BaseComponent.call(this, element) || this; | ||
_this._isTransitioning = false; | ||
_this._config = _this._getConfig(config); | ||
_this._triggerArray = SelectorEngine__default['default'].find(SELECTOR_DATA_TOGGLE + "[href=\"#" + element.id + "\"]," + (SELECTOR_DATA_TOGGLE + "[data-bs-target=\"#" + element.id + "\"]")); | ||
var toggleList = SelectorEngine__default['default'].find(SELECTOR_DATA_TOGGLE); | ||
for (var i = 0, len = toggleList.length; i < len; i++) { | ||
var elem = toggleList[i]; | ||
var selector = getSelectorFromElement(elem); | ||
var filterElement = SelectorEngine__default['default'].find(selector).filter(function (foundElem) { | ||
return foundElem === element; | ||
}); | ||
if (selector !== null && filterElement.length) { | ||
_this._selector = selector; | ||
this._selector = selector; | ||
_this._triggerArray.push(elem); | ||
this._triggerArray.push(elem); | ||
} | ||
} | ||
_this._parent = _this._config.parent ? _this._getParent() : null; | ||
this._parent = this._config.parent ? this._getParent() : null; | ||
if (!_this._config.parent) { | ||
_this._addAriaAndCollapsedClass(_this._element, _this._triggerArray); | ||
if (!this._config.parent) { | ||
this._addAriaAndCollapsedClass(this._element, this._triggerArray); | ||
} | ||
if (_this._config.toggle) { | ||
_this.toggle(); | ||
if (this._config.toggle) { | ||
this.toggle(); | ||
} | ||
return _this; | ||
} // Getters | ||
var _proto = Collapse.prototype; | ||
static get Default() { | ||
return Default; | ||
} | ||
// Public | ||
_proto.toggle = function toggle() { | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
toggle() { | ||
if (this._element.classList.contains(CLASS_NAME_SHOW)) { | ||
@@ -330,7 +279,5 @@ this.hide(); | ||
} | ||
}; | ||
} | ||
_proto.show = function show() { | ||
var _this2 = this; | ||
show() { | ||
if (this._isTransitioning || this._element.classList.contains(CLASS_NAME_SHOW)) { | ||
@@ -340,9 +287,9 @@ return; | ||
var actives; | ||
var activesData; | ||
let actives; | ||
let activesData; | ||
if (this._parent) { | ||
actives = SelectorEngine__default['default'].find(SELECTOR_ACTIVES, this._parent).filter(function (elem) { | ||
if (typeof _this2._config.parent === 'string') { | ||
return elem.getAttribute('data-bs-parent') === _this2._config.parent; | ||
actives = SelectorEngine__default['default'].find(SELECTOR_ACTIVES, this._parent).filter(elem => { | ||
if (typeof this._config.parent === 'string') { | ||
return elem.getAttribute('data-bs-parent') === this._config.parent; | ||
} | ||
@@ -358,9 +305,7 @@ | ||
var container = SelectorEngine__default['default'].findOne(this._selector); | ||
const container = SelectorEngine__default['default'].findOne(this._selector); | ||
if (actives) { | ||
var tempActiveData = actives.find(function (elem) { | ||
return container !== elem; | ||
}); | ||
activesData = tempActiveData ? Data__default['default'].getData(tempActiveData, DATA_KEY) : null; | ||
const tempActiveData = actives.find(elem => container !== elem); | ||
activesData = tempActiveData ? Data__default['default'].get(tempActiveData, DATA_KEY) : null; | ||
@@ -372,3 +317,3 @@ if (activesData && activesData._isTransitioning) { | ||
var startEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW); | ||
const startEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW); | ||
@@ -380,3 +325,3 @@ if (startEvent.defaultPrevented) { | ||
if (actives) { | ||
actives.forEach(function (elemActive) { | ||
actives.forEach(elemActive => { | ||
if (container !== elemActive) { | ||
@@ -387,3 +332,3 @@ Collapse.collapseInterface(elemActive, 'hide'); | ||
if (!activesData) { | ||
Data__default['default'].setData(elemActive, DATA_KEY, null); | ||
Data__default['default'].set(elemActive, DATA_KEY, null); | ||
} | ||
@@ -393,3 +338,3 @@ }); | ||
var dimension = this._getDimension(); | ||
const dimension = this._getDimension(); | ||
@@ -403,3 +348,3 @@ this._element.classList.remove(CLASS_NAME_COLLAPSE); | ||
if (this._triggerArray.length) { | ||
this._triggerArray.forEach(function (element) { | ||
this._triggerArray.forEach(element => { | ||
element.classList.remove(CLASS_NAME_COLLAPSED); | ||
@@ -412,25 +357,21 @@ element.setAttribute('aria-expanded', true); | ||
var complete = function complete() { | ||
_this2._element.classList.remove(CLASS_NAME_COLLAPSING); | ||
const complete = () => { | ||
this._element.classList.remove(CLASS_NAME_COLLAPSING); | ||
_this2._element.classList.add(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW); | ||
this._element.classList.add(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW); | ||
_this2._element.style[dimension] = ''; | ||
_this2.setTransitioning(false); | ||
EventHandler__default['default'].trigger(_this2._element, EVENT_SHOWN); | ||
this._element.style[dimension] = ''; | ||
this.setTransitioning(false); | ||
EventHandler__default['default'].trigger(this._element, EVENT_SHOWN); | ||
}; | ||
var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1); | ||
var scrollSize = "scroll" + capitalizedDimension; | ||
var transitionDuration = getTransitionDurationFromElement(this._element); | ||
const capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1); | ||
const scrollSize = `scroll${capitalizedDimension}`; | ||
const transitionDuration = getTransitionDurationFromElement(this._element); | ||
EventHandler__default['default'].one(this._element, 'transitionend', complete); | ||
emulateTransitionEnd(this._element, transitionDuration); | ||
this._element.style[dimension] = this._element[scrollSize] + "px"; | ||
}; | ||
this._element.style[dimension] = `${this._element[scrollSize]}px`; | ||
} | ||
_proto.hide = function hide() { | ||
var _this3 = this; | ||
hide() { | ||
if (this._isTransitioning || !this._element.classList.contains(CLASS_NAME_SHOW)) { | ||
@@ -440,3 +381,3 @@ return; | ||
var startEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE); | ||
const startEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE); | ||
@@ -447,5 +388,5 @@ if (startEvent.defaultPrevented) { | ||
var dimension = this._getDimension(); | ||
const dimension = this._getDimension(); | ||
this._element.style[dimension] = this._element.getBoundingClientRect()[dimension] + "px"; | ||
this._element.style[dimension] = `${this._element.getBoundingClientRect()[dimension]}px`; | ||
reflow(this._element); | ||
@@ -457,8 +398,8 @@ | ||
var triggerArrayLength = this._triggerArray.length; | ||
const triggerArrayLength = this._triggerArray.length; | ||
if (triggerArrayLength > 0) { | ||
for (var i = 0; i < triggerArrayLength; i++) { | ||
var trigger = this._triggerArray[i]; | ||
var elem = getElementFromSelector(trigger); | ||
for (let i = 0; i < triggerArrayLength; i++) { | ||
const trigger = this._triggerArray[i]; | ||
const elem = getElementFromSelector(trigger); | ||
@@ -474,25 +415,24 @@ if (elem && !elem.classList.contains(CLASS_NAME_SHOW)) { | ||
var complete = function complete() { | ||
_this3.setTransitioning(false); | ||
const complete = () => { | ||
this.setTransitioning(false); | ||
_this3._element.classList.remove(CLASS_NAME_COLLAPSING); | ||
this._element.classList.remove(CLASS_NAME_COLLAPSING); | ||
_this3._element.classList.add(CLASS_NAME_COLLAPSE); | ||
this._element.classList.add(CLASS_NAME_COLLAPSE); | ||
EventHandler__default['default'].trigger(_this3._element, EVENT_HIDDEN); | ||
EventHandler__default['default'].trigger(this._element, EVENT_HIDDEN); | ||
}; | ||
this._element.style[dimension] = ''; | ||
var transitionDuration = getTransitionDurationFromElement(this._element); | ||
const transitionDuration = getTransitionDurationFromElement(this._element); | ||
EventHandler__default['default'].one(this._element, 'transitionend', complete); | ||
emulateTransitionEnd(this._element, transitionDuration); | ||
}; | ||
} | ||
_proto.setTransitioning = function setTransitioning(isTransitioning) { | ||
setTransitioning(isTransitioning) { | ||
this._isTransitioning = isTransitioning; | ||
}; | ||
} | ||
_proto.dispose = function dispose() { | ||
_BaseComponent.prototype.dispose.call(this); | ||
dispose() { | ||
super.dispose(); | ||
this._config = null; | ||
@@ -503,6 +443,8 @@ this._parent = null; | ||
} // Private | ||
; | ||
_proto._getConfig = function _getConfig(config) { | ||
config = _extends({}, Default, config); | ||
_getConfig(config) { | ||
config = { ...Default, | ||
...config | ||
}; | ||
config.toggle = Boolean(config.toggle); // Coerce string values | ||
@@ -512,13 +454,13 @@ | ||
return config; | ||
}; | ||
} | ||
_proto._getDimension = function _getDimension() { | ||
_getDimension() { | ||
return this._element.classList.contains(WIDTH) ? WIDTH : HEIGHT; | ||
}; | ||
} | ||
_proto._getParent = function _getParent() { | ||
var _this4 = this; | ||
_getParent() { | ||
let { | ||
parent | ||
} = this._config; | ||
var parent = this._config.parent; | ||
if (isElement(parent)) { | ||
@@ -533,12 +475,12 @@ // it's a jQuery object | ||
var selector = SELECTOR_DATA_TOGGLE + "[data-bs-parent=\"" + parent + "\"]"; | ||
SelectorEngine__default['default'].find(selector, parent).forEach(function (element) { | ||
var selected = getElementFromSelector(element); | ||
const selector = `${SELECTOR_DATA_TOGGLE}[data-bs-parent="${parent}"]`; | ||
SelectorEngine__default['default'].find(selector, parent).forEach(element => { | ||
const selected = getElementFromSelector(element); | ||
_this4._addAriaAndCollapsedClass(selected, [element]); | ||
this._addAriaAndCollapsedClass(selected, [element]); | ||
}); | ||
return parent; | ||
}; | ||
} | ||
_proto._addAriaAndCollapsedClass = function _addAriaAndCollapsedClass(element, triggerArray) { | ||
_addAriaAndCollapsedClass(element, triggerArray) { | ||
if (!element || !triggerArray.length) { | ||
@@ -548,4 +490,4 @@ return; | ||
var isOpen = element.classList.contains(CLASS_NAME_SHOW); | ||
triggerArray.forEach(function (elem) { | ||
const isOpen = element.classList.contains(CLASS_NAME_SHOW); | ||
triggerArray.forEach(elem => { | ||
if (isOpen) { | ||
@@ -560,8 +502,10 @@ elem.classList.remove(CLASS_NAME_COLLAPSED); | ||
} // Static | ||
; | ||
Collapse.collapseInterface = function collapseInterface(element, config) { | ||
var data = Data__default['default'].getData(element, DATA_KEY); | ||
var _config = _extends({}, Default, Manipulator__default['default'].getDataAttributes(element), typeof config === 'object' && config ? config : {}); | ||
static collapseInterface(element, config) { | ||
let data = Data__default['default'].get(element, DATA_KEY); | ||
const _config = { ...Default, | ||
...Manipulator__default['default'].getDataAttributes(element), | ||
...(typeof config === 'object' && config ? config : {}) | ||
}; | ||
@@ -578,3 +522,3 @@ if (!data && _config.toggle && typeof config === 'string' && /show|hide/.test(config)) { | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -584,24 +528,11 @@ | ||
} | ||
}; | ||
} | ||
Collapse.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
Collapse.collapseInterface(this, config); | ||
}); | ||
}; | ||
} | ||
_createClass(Collapse, null, [{ | ||
key: "Default", | ||
get: function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Collapse; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -620,8 +551,8 @@ * ------------------------------------------------------------------------ | ||
var triggerData = Manipulator__default['default'].getDataAttributes(this); | ||
var selector = getSelectorFromElement(this); | ||
var selectorElements = SelectorEngine__default['default'].find(selector); | ||
selectorElements.forEach(function (element) { | ||
var data = Data__default['default'].getData(element, DATA_KEY); | ||
var config; | ||
const triggerData = Manipulator__default['default'].getDataAttributes(this); | ||
const selector = getSelectorFromElement(this); | ||
const selectorElements = SelectorEngine__default['default'].find(selector); | ||
selectorElements.forEach(element => { | ||
const data = Data__default['default'].get(element, DATA_KEY); | ||
let config; | ||
@@ -628,0 +559,0 @@ if (data) { |
/*! | ||
* Bootstrap data.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap data.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -14,3 +14,3 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/data.js | ||
* Bootstrap (v5.0.0-beta3): dom/data.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -25,60 +25,47 @@ * -------------------------------------------------------------------------- | ||
*/ | ||
var mapData = function () { | ||
var storeData = {}; | ||
var id = 1; | ||
return { | ||
set: function set(element, key, data) { | ||
if (typeof element.bsKey === 'undefined') { | ||
element.bsKey = { | ||
key: key, | ||
id: id | ||
}; | ||
id++; | ||
} | ||
const elementMap = new Map(); | ||
var data = { | ||
set(element, key, instance) { | ||
if (!elementMap.has(element)) { | ||
elementMap.set(element, new Map()); | ||
} | ||
storeData[element.bsKey.id] = data; | ||
}, | ||
get: function get(element, key) { | ||
if (!element || typeof element.bsKey === 'undefined') { | ||
return null; | ||
} | ||
const instanceMap = elementMap.get(element); // make it clear we only want one instance per element | ||
// can be removed later when multiple key/instances are fine to be used | ||
var keyProperties = element.bsKey; | ||
if (!instanceMap.has(key) && instanceMap.size !== 0) { | ||
// eslint-disable-next-line no-console | ||
console.error(`Bootstrap doesn't allow more than one instance per element. Bound instance: ${Array.from(instanceMap.keys())[0]}.`); | ||
return; | ||
} | ||
if (keyProperties.key === key) { | ||
return storeData[keyProperties.id]; | ||
} | ||
instanceMap.set(key, instance); | ||
}, | ||
return null; | ||
}, | ||
delete: function _delete(element, key) { | ||
if (typeof element.bsKey === 'undefined') { | ||
return; | ||
} | ||
get(element, key) { | ||
if (elementMap.has(element)) { | ||
return elementMap.get(element).get(key) || null; | ||
} | ||
var keyProperties = element.bsKey; | ||
return null; | ||
}, | ||
if (keyProperties.key === key) { | ||
delete storeData[keyProperties.id]; | ||
delete element.bsKey; | ||
} | ||
remove(element, key) { | ||
if (!elementMap.has(element)) { | ||
return; | ||
} | ||
}; | ||
}(); | ||
var Data = { | ||
setData: function setData(instance, key, data) { | ||
mapData.set(instance, key, data); | ||
}, | ||
getData: function getData(instance, key) { | ||
return mapData.get(instance, key); | ||
}, | ||
removeData: function removeData(instance, key) { | ||
mapData.delete(instance, key); | ||
const instanceMap = elementMap.get(element); | ||
instanceMap.delete(key); // free up element references if there are no instances left for an element | ||
if (instanceMap.size === 0) { | ||
elementMap.delete(element); | ||
} | ||
} | ||
}; | ||
return Data; | ||
return data; | ||
}))); | ||
//# sourceMappingURL=data.js.map |
/*! | ||
* Bootstrap event-handler.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap event-handler.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -14,3 +14,3 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -20,5 +20,6 @@ * -------------------------------------------------------------------------- | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -32,7 +33,5 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
document.documentElement.dir === 'rtl'; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/event-handler.js | ||
* Bootstrap (v5.0.0-beta3): dom/event-handler.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -47,13 +46,13 @@ * -------------------------------------------------------------------------- | ||
var namespaceRegex = /[^.]*(?=\..*)\.|.*/; | ||
var stripNameRegex = /\..*/; | ||
var stripUidRegex = /::\d+$/; | ||
var eventRegistry = {}; // Events storage | ||
const namespaceRegex = /[^.]*(?=\..*)\.|.*/; | ||
const stripNameRegex = /\..*/; | ||
const stripUidRegex = /::\d+$/; | ||
const eventRegistry = {}; // Events storage | ||
var uidEvent = 1; | ||
var customEvents = { | ||
let uidEvent = 1; | ||
const customEvents = { | ||
mouseenter: 'mouseover', | ||
mouseleave: 'mouseout' | ||
}; | ||
var nativeEvents = new Set(['click', 'dblclick', 'mouseup', 'mousedown', 'contextmenu', 'mousewheel', 'DOMMouseScroll', 'mouseover', 'mouseout', 'mousemove', 'selectstart', 'selectend', 'keydown', 'keypress', 'keyup', 'orientationchange', 'touchstart', 'touchmove', 'touchend', 'touchcancel', 'pointerdown', 'pointermove', 'pointerup', 'pointerleave', 'pointercancel', 'gesturestart', 'gesturechange', 'gestureend', 'focus', 'blur', 'change', 'reset', 'select', 'submit', 'focusin', 'focusout', 'load', 'unload', 'beforeunload', 'resize', 'move', 'DOMContentLoaded', 'readystatechange', 'error', 'abort', 'scroll']); | ||
const nativeEvents = new Set(['click', 'dblclick', 'mouseup', 'mousedown', 'contextmenu', 'mousewheel', 'DOMMouseScroll', 'mouseover', 'mouseout', 'mousemove', 'selectstart', 'selectend', 'keydown', 'keypress', 'keyup', 'orientationchange', 'touchstart', 'touchmove', 'touchend', 'touchcancel', 'pointerdown', 'pointermove', 'pointerup', 'pointerleave', 'pointercancel', 'gesturestart', 'gesturechange', 'gestureend', 'focus', 'blur', 'change', 'reset', 'select', 'submit', 'focusin', 'focusout', 'load', 'unload', 'beforeunload', 'resize', 'move', 'DOMContentLoaded', 'readystatechange', 'error', 'abort', 'scroll']); | ||
/** | ||
@@ -66,7 +65,7 @@ * ------------------------------------------------------------------------ | ||
function getUidEvent(element, uid) { | ||
return uid && uid + "::" + uidEvent++ || element.uidEvent || uidEvent++; | ||
return uid && `${uid}::${uidEvent++}` || element.uidEvent || uidEvent++; | ||
} | ||
function getEvent(element) { | ||
var uid = getUidEvent(element); | ||
const uid = getUidEvent(element); | ||
element.uidEvent = uid; | ||
@@ -91,6 +90,8 @@ eventRegistry[uid] = eventRegistry[uid] || {}; | ||
return function handler(event) { | ||
var domElements = element.querySelectorAll(selector); | ||
const domElements = element.querySelectorAll(selector); | ||
for (var target = event.target; target && target !== this; target = target.parentNode) { | ||
for (var i = domElements.length; i--;) { | ||
for (let { | ||
target | ||
} = event; target && target !== this; target = target.parentNode) { | ||
for (let i = domElements.length; i--;) { | ||
if (domElements[i] === target) { | ||
@@ -114,12 +115,8 @@ event.delegateTarget = target; | ||
function findHandler(events, handler, delegationSelector) { | ||
if (delegationSelector === void 0) { | ||
delegationSelector = null; | ||
} | ||
function findHandler(events, handler, delegationSelector = null) { | ||
const uidEventList = Object.keys(events); | ||
var uidEventList = Object.keys(events); | ||
for (let i = 0, len = uidEventList.length; i < len; i++) { | ||
const event = events[uidEventList[i]]; | ||
for (var i = 0, len = uidEventList.length; i < len; i++) { | ||
var event = events[uidEventList[i]]; | ||
if (event.originalHandler === handler && event.delegationSelector === delegationSelector) { | ||
@@ -134,7 +131,7 @@ return event; | ||
function normalizeParams(originalTypeEvent, handler, delegationFn) { | ||
var delegation = typeof handler === 'string'; | ||
var originalHandler = delegation ? delegationFn : handler; // allow to get the native events from namespaced events ('click.bs.button' --> 'click') | ||
const delegation = typeof handler === 'string'; | ||
const originalHandler = delegation ? delegationFn : handler; // allow to get the native events from namespaced events ('click.bs.button' --> 'click') | ||
var typeEvent = originalTypeEvent.replace(stripNameRegex, ''); | ||
var custom = customEvents[typeEvent]; | ||
let typeEvent = originalTypeEvent.replace(stripNameRegex, ''); | ||
const custom = customEvents[typeEvent]; | ||
@@ -145,3 +142,3 @@ if (custom) { | ||
var isNative = nativeEvents.has(typeEvent); | ||
const isNative = nativeEvents.has(typeEvent); | ||
@@ -165,11 +162,7 @@ if (!isNative) { | ||
var _normalizeParams = normalizeParams(originalTypeEvent, handler, delegationFn), | ||
delegation = _normalizeParams[0], | ||
originalHandler = _normalizeParams[1], | ||
typeEvent = _normalizeParams[2]; | ||
const [delegation, originalHandler, typeEvent] = normalizeParams(originalTypeEvent, handler, delegationFn); | ||
const events = getEvent(element); | ||
const handlers = events[typeEvent] || (events[typeEvent] = {}); | ||
const previousFn = findHandler(handlers, originalHandler, delegation ? handler : null); | ||
var events = getEvent(element); | ||
var handlers = events[typeEvent] || (events[typeEvent] = {}); | ||
var previousFn = findHandler(handlers, originalHandler, delegation ? handler : null); | ||
if (previousFn) { | ||
@@ -180,4 +173,4 @@ previousFn.oneOff = previousFn.oneOff && oneOff; | ||
var uid = getUidEvent(originalHandler, originalTypeEvent.replace(namespaceRegex, '')); | ||
var fn = delegation ? bootstrapDelegationHandler(element, handler, delegationFn) : bootstrapHandler(element, handler); | ||
const uid = getUidEvent(originalHandler, originalTypeEvent.replace(namespaceRegex, '')); | ||
const fn = delegation ? bootstrapDelegationHandler(element, handler, delegationFn) : bootstrapHandler(element, handler); | ||
fn.delegationSelector = delegation ? handler : null; | ||
@@ -192,3 +185,3 @@ fn.originalHandler = originalHandler; | ||
function removeHandler(element, events, typeEvent, handler, delegationSelector) { | ||
var fn = findHandler(events[typeEvent], handler, delegationSelector); | ||
const fn = findHandler(events[typeEvent], handler, delegationSelector); | ||
@@ -204,6 +197,6 @@ if (!fn) { | ||
function removeNamespacedHandlers(element, events, typeEvent, namespace) { | ||
var storeElementEvent = events[typeEvent] || {}; | ||
Object.keys(storeElementEvent).forEach(function (handlerKey) { | ||
const storeElementEvent = events[typeEvent] || {}; | ||
Object.keys(storeElementEvent).forEach(handlerKey => { | ||
if (handlerKey.includes(namespace)) { | ||
var event = storeElementEvent[handlerKey]; | ||
const event = storeElementEvent[handlerKey]; | ||
removeHandler(element, events, typeEvent, event.originalHandler, event.delegationSelector); | ||
@@ -214,10 +207,12 @@ } | ||
var EventHandler = { | ||
on: function on(element, event, handler, delegationFn) { | ||
const EventHandler = { | ||
on(element, event, handler, delegationFn) { | ||
addHandler(element, event, handler, delegationFn, false); | ||
}, | ||
one: function one(element, event, handler, delegationFn) { | ||
one(element, event, handler, delegationFn) { | ||
addHandler(element, event, handler, delegationFn, true); | ||
}, | ||
off: function off(element, originalTypeEvent, handler, delegationFn) { | ||
off(element, originalTypeEvent, handler, delegationFn) { | ||
if (typeof originalTypeEvent !== 'string' || !element) { | ||
@@ -227,11 +222,7 @@ return; | ||
var _normalizeParams2 = normalizeParams(originalTypeEvent, handler, delegationFn), | ||
delegation = _normalizeParams2[0], | ||
originalHandler = _normalizeParams2[1], | ||
typeEvent = _normalizeParams2[2]; | ||
const [delegation, originalHandler, typeEvent] = normalizeParams(originalTypeEvent, handler, delegationFn); | ||
const inNamespace = typeEvent !== originalTypeEvent; | ||
const events = getEvent(element); | ||
const isNamespace = originalTypeEvent.startsWith('.'); | ||
var inNamespace = typeEvent !== originalTypeEvent; | ||
var events = getEvent(element); | ||
var isNamespace = originalTypeEvent.startsWith('.'); | ||
if (typeof originalHandler !== 'undefined') { | ||
@@ -248,3 +239,3 @@ // Simplest case: handler is passed, remove that listener ONLY. | ||
if (isNamespace) { | ||
Object.keys(events).forEach(function (elementEvent) { | ||
Object.keys(events).forEach(elementEvent => { | ||
removeNamespacedHandlers(element, events, elementEvent, originalTypeEvent.slice(1)); | ||
@@ -254,8 +245,8 @@ }); | ||
var storeElementEvent = events[typeEvent] || {}; | ||
Object.keys(storeElementEvent).forEach(function (keyHandlers) { | ||
var handlerKey = keyHandlers.replace(stripUidRegex, ''); | ||
const storeElementEvent = events[typeEvent] || {}; | ||
Object.keys(storeElementEvent).forEach(keyHandlers => { | ||
const handlerKey = keyHandlers.replace(stripUidRegex, ''); | ||
if (!inNamespace || originalTypeEvent.includes(handlerKey)) { | ||
var event = storeElementEvent[keyHandlers]; | ||
const event = storeElementEvent[keyHandlers]; | ||
removeHandler(element, events, typeEvent, event.originalHandler, event.delegationSelector); | ||
@@ -265,3 +256,4 @@ } | ||
}, | ||
trigger: function trigger(element, event, args) { | ||
trigger(element, event, args) { | ||
if (typeof event !== 'string' || !element) { | ||
@@ -271,11 +263,11 @@ return null; | ||
var $ = getjQuery(); | ||
var typeEvent = event.replace(stripNameRegex, ''); | ||
var inNamespace = event !== typeEvent; | ||
var isNative = nativeEvents.has(typeEvent); | ||
var jQueryEvent; | ||
var bubbles = true; | ||
var nativeDispatch = true; | ||
var defaultPrevented = false; | ||
var evt = null; | ||
const $ = getjQuery(); | ||
const typeEvent = event.replace(stripNameRegex, ''); | ||
const inNamespace = event !== typeEvent; | ||
const isNative = nativeEvents.has(typeEvent); | ||
let jQueryEvent; | ||
let bubbles = true; | ||
let nativeDispatch = true; | ||
let defaultPrevented = false; | ||
let evt = null; | ||
@@ -295,3 +287,3 @@ if (inNamespace && $) { | ||
evt = new CustomEvent(event, { | ||
bubbles: bubbles, | ||
bubbles, | ||
cancelable: true | ||
@@ -303,7 +295,8 @@ }); | ||
if (typeof args !== 'undefined') { | ||
Object.keys(args).forEach(function (key) { | ||
Object.keys(args).forEach(key => { | ||
Object.defineProperty(evt, key, { | ||
get: function get() { | ||
get() { | ||
return args[key]; | ||
} | ||
}); | ||
@@ -327,2 +320,3 @@ }); | ||
} | ||
}; | ||
@@ -329,0 +323,0 @@ |
/*! | ||
* Bootstrap manipulator.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap manipulator.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -14,3 +14,3 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/manipulator.js | ||
* Bootstrap (v5.0.0-beta3): dom/manipulator.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -40,15 +40,15 @@ * -------------------------------------------------------------------------- | ||
function normalizeDataKey(key) { | ||
return key.replace(/[A-Z]/g, function (chr) { | ||
return "-" + chr.toLowerCase(); | ||
}); | ||
return key.replace(/[A-Z]/g, chr => `-${chr.toLowerCase()}`); | ||
} | ||
var Manipulator = { | ||
setDataAttribute: function setDataAttribute(element, key, value) { | ||
element.setAttribute("data-bs-" + normalizeDataKey(key), value); | ||
const Manipulator = { | ||
setDataAttribute(element, key, value) { | ||
element.setAttribute(`data-bs-${normalizeDataKey(key)}`, value); | ||
}, | ||
removeDataAttribute: function removeDataAttribute(element, key) { | ||
element.removeAttribute("data-bs-" + normalizeDataKey(key)); | ||
removeDataAttribute(element, key) { | ||
element.removeAttribute(`data-bs-${normalizeDataKey(key)}`); | ||
}, | ||
getDataAttributes: function getDataAttributes(element) { | ||
getDataAttributes(element) { | ||
if (!element) { | ||
@@ -58,7 +58,5 @@ return {}; | ||
var attributes = {}; | ||
Object.keys(element.dataset).filter(function (key) { | ||
return key.startsWith('bs'); | ||
}).forEach(function (key) { | ||
var pureKey = key.replace(/^bs/, ''); | ||
const attributes = {}; | ||
Object.keys(element.dataset).filter(key => key.startsWith('bs')).forEach(key => { | ||
let pureKey = key.replace(/^bs/, ''); | ||
pureKey = pureKey.charAt(0).toLowerCase() + pureKey.slice(1, pureKey.length); | ||
@@ -69,7 +67,9 @@ attributes[pureKey] = normalizeData(element.dataset[key]); | ||
}, | ||
getDataAttribute: function getDataAttribute(element, key) { | ||
return normalizeData(element.getAttribute("data-bs-" + normalizeDataKey(key))); | ||
getDataAttribute(element, key) { | ||
return normalizeData(element.getAttribute(`data-bs-${normalizeDataKey(key)}`)); | ||
}, | ||
offset: function offset(element) { | ||
var rect = element.getBoundingClientRect(); | ||
offset(element) { | ||
const rect = element.getBoundingClientRect(); | ||
return { | ||
@@ -80,3 +80,4 @@ top: rect.top + document.body.scrollTop, | ||
}, | ||
position: function position(element) { | ||
position(element) { | ||
return { | ||
@@ -87,2 +88,3 @@ top: element.offsetTop, | ||
} | ||
}; | ||
@@ -89,0 +91,0 @@ |
/*! | ||
* Bootstrap selector-engine.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap selector-engine.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -14,3 +14,3 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/selector-engine.js | ||
* Bootstrap (v5.0.0-beta3): dom/selector-engine.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -25,31 +25,20 @@ * -------------------------------------------------------------------------- | ||
*/ | ||
var NODE_TEXT = 3; | ||
var SelectorEngine = { | ||
find: function find(selector, element) { | ||
var _ref; | ||
if (element === void 0) { | ||
element = document.documentElement; | ||
} | ||
return (_ref = []).concat.apply(_ref, Element.prototype.querySelectorAll.call(element, selector)); | ||
const NODE_TEXT = 3; | ||
const SelectorEngine = { | ||
find(selector, element = document.documentElement) { | ||
return [].concat(...Element.prototype.querySelectorAll.call(element, selector)); | ||
}, | ||
findOne: function findOne(selector, element) { | ||
if (element === void 0) { | ||
element = document.documentElement; | ||
} | ||
findOne(selector, element = document.documentElement) { | ||
return Element.prototype.querySelector.call(element, selector); | ||
}, | ||
children: function children(element, selector) { | ||
var _ref2; | ||
return (_ref2 = []).concat.apply(_ref2, element.children).filter(function (child) { | ||
return child.matches(selector); | ||
}); | ||
children(element, selector) { | ||
return [].concat(...element.children).filter(child => child.matches(selector)); | ||
}, | ||
parents: function parents(element, selector) { | ||
var parents = []; | ||
var ancestor = element.parentNode; | ||
parents(element, selector) { | ||
const parents = []; | ||
let ancestor = element.parentNode; | ||
while (ancestor && ancestor.nodeType === Node.ELEMENT_NODE && ancestor.nodeType !== NODE_TEXT) { | ||
@@ -65,5 +54,6 @@ if (ancestor.matches(selector)) { | ||
}, | ||
prev: function prev(element, selector) { | ||
var previous = element.previousElementSibling; | ||
prev(element, selector) { | ||
let previous = element.previousElementSibling; | ||
while (previous) { | ||
@@ -79,5 +69,6 @@ if (previous.matches(selector)) { | ||
}, | ||
next: function next(element, selector) { | ||
var next = element.nextElementSibling; | ||
next(element, selector) { | ||
let next = element.nextElementSibling; | ||
while (next) { | ||
@@ -93,2 +84,3 @@ if (next.matches(selector)) { | ||
} | ||
}; | ||
@@ -95,0 +87,0 @@ |
/*! | ||
* Bootstrap dropdown.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap dropdown.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -41,55 +41,5 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -99,5 +49,5 @@ * -------------------------------------------------------------------------- | ||
var toType = function toType(obj) { | ||
const toType = obj => { | ||
if (obj === null || obj === undefined) { | ||
return "" + obj; | ||
return `${obj}`; | ||
} | ||
@@ -108,7 +58,7 @@ | ||
var getSelector = function getSelector(element) { | ||
var selector = element.getAttribute('data-bs-target'); | ||
const getSelector = element => { | ||
let selector = element.getAttribute('data-bs-target'); | ||
if (!selector || selector === '#') { | ||
var hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
// so everything starting with `#` or `.`. If a "real" URL is used as the selector, | ||
@@ -133,19 +83,17 @@ // `document.querySelector` will rightfully complain it is invalid. | ||
var getElementFromSelector = function getElementFromSelector(element) { | ||
var selector = getSelector(element); | ||
const getElementFromSelector = element => { | ||
const selector = getSelector(element); | ||
return selector ? document.querySelector(selector) : null; | ||
}; | ||
var isElement = function isElement(obj) { | ||
return (obj[0] || obj).nodeType; | ||
}; | ||
const isElement = obj => (obj[0] || obj).nodeType; | ||
var typeCheckConfig = function typeCheckConfig(componentName, config, configTypes) { | ||
Object.keys(configTypes).forEach(function (property) { | ||
var expectedTypes = configTypes[property]; | ||
var value = config[property]; | ||
var valueType = value && isElement(value) ? 'element' : toType(value); | ||
const typeCheckConfig = (componentName, config, configTypes) => { | ||
Object.keys(configTypes).forEach(property => { | ||
const expectedTypes = configTypes[property]; | ||
const value = config[property]; | ||
const valueType = value && isElement(value) ? 'element' : toType(value); | ||
if (!new RegExp(expectedTypes).test(valueType)) { | ||
throw new TypeError(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); | ||
throw new TypeError(`${componentName.toUpperCase()}: ` + `Option "${property}" provided type "${valueType}" ` + `but expected type "${expectedTypes}".`); | ||
} | ||
@@ -155,3 +103,3 @@ }); | ||
var isVisible = function isVisible(element) { | ||
const isVisible = element => { | ||
if (!element) { | ||
@@ -162,4 +110,4 @@ return false; | ||
if (element.style && element.parentNode && element.parentNode.style) { | ||
var elementStyle = getComputedStyle(element); | ||
var parentNodeStyle = getComputedStyle(element.parentNode); | ||
const elementStyle = getComputedStyle(element); | ||
const parentNodeStyle = getComputedStyle(element.parentNode); | ||
return elementStyle.display !== 'none' && parentNodeStyle.display !== 'none' && elementStyle.visibility !== 'hidden'; | ||
@@ -171,9 +119,8 @@ } | ||
var noop = function noop() { | ||
return function () {}; | ||
}; | ||
const noop = () => function () {}; | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -187,3 +134,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -196,15 +143,15 @@ document.addEventListener('DOMContentLoaded', callback); | ||
var isRTL = document.documentElement.dir === 'rtl'; | ||
const isRTL = () => document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -218,2 +165,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): dropdown.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -224,42 +177,40 @@ * Constants | ||
var NAME = 'dropdown'; | ||
var DATA_KEY = 'bs.dropdown'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var ESCAPE_KEY = 'Escape'; | ||
var SPACE_KEY = 'Space'; | ||
var TAB_KEY = 'Tab'; | ||
var ARROW_UP_KEY = 'ArrowUp'; | ||
var ARROW_DOWN_KEY = 'ArrowDown'; | ||
var RIGHT_MOUSE_BUTTON = 2; // MouseEvent.button value for the secondary button, usually the right button | ||
const NAME = 'dropdown'; | ||
const DATA_KEY = 'bs.dropdown'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const ESCAPE_KEY = 'Escape'; | ||
const SPACE_KEY = 'Space'; | ||
const TAB_KEY = 'Tab'; | ||
const ARROW_UP_KEY = 'ArrowUp'; | ||
const ARROW_DOWN_KEY = 'ArrowDown'; | ||
const RIGHT_MOUSE_BUTTON = 2; // MouseEvent.button value for the secondary button, usually the right button | ||
var REGEXP_KEYDOWN = new RegExp(ARROW_UP_KEY + "|" + ARROW_DOWN_KEY + "|" + ESCAPE_KEY); | ||
var EVENT_HIDE = "hide" + EVENT_KEY; | ||
var EVENT_HIDDEN = "hidden" + EVENT_KEY; | ||
var EVENT_SHOW = "show" + EVENT_KEY; | ||
var EVENT_SHOWN = "shown" + EVENT_KEY; | ||
var EVENT_CLICK = "click" + EVENT_KEY; | ||
var EVENT_CLICK_DATA_API = "click" + EVENT_KEY + DATA_API_KEY; | ||
var EVENT_KEYDOWN_DATA_API = "keydown" + EVENT_KEY + DATA_API_KEY; | ||
var EVENT_KEYUP_DATA_API = "keyup" + EVENT_KEY + DATA_API_KEY; | ||
var CLASS_NAME_DISABLED = 'disabled'; | ||
var CLASS_NAME_SHOW = 'show'; | ||
var CLASS_NAME_DROPUP = 'dropup'; | ||
var CLASS_NAME_DROPEND = 'dropend'; | ||
var CLASS_NAME_DROPSTART = 'dropstart'; | ||
var CLASS_NAME_NAVBAR = 'navbar'; | ||
var SELECTOR_DATA_TOGGLE = '[data-bs-toggle="dropdown"]'; | ||
var SELECTOR_FORM_CHILD = '.dropdown form'; | ||
var SELECTOR_MENU = '.dropdown-menu'; | ||
var SELECTOR_NAVBAR_NAV = '.navbar-nav'; | ||
var SELECTOR_VISIBLE_ITEMS = '.dropdown-menu .dropdown-item:not(.disabled):not(:disabled)'; | ||
var PLACEMENT_TOP = isRTL ? 'top-end' : 'top-start'; | ||
var PLACEMENT_TOPEND = isRTL ? 'top-start' : 'top-end'; | ||
var PLACEMENT_BOTTOM = isRTL ? 'bottom-end' : 'bottom-start'; | ||
var PLACEMENT_BOTTOMEND = isRTL ? 'bottom-start' : 'bottom-end'; | ||
var PLACEMENT_RIGHT = isRTL ? 'left-start' : 'right-start'; | ||
var PLACEMENT_LEFT = isRTL ? 'right-start' : 'left-start'; | ||
var Default = { | ||
const REGEXP_KEYDOWN = new RegExp(`${ARROW_UP_KEY}|${ARROW_DOWN_KEY}|${ESCAPE_KEY}`); | ||
const EVENT_HIDE = `hide${EVENT_KEY}`; | ||
const EVENT_HIDDEN = `hidden${EVENT_KEY}`; | ||
const EVENT_SHOW = `show${EVENT_KEY}`; | ||
const EVENT_SHOWN = `shown${EVENT_KEY}`; | ||
const EVENT_CLICK = `click${EVENT_KEY}`; | ||
const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`; | ||
const EVENT_KEYDOWN_DATA_API = `keydown${EVENT_KEY}${DATA_API_KEY}`; | ||
const EVENT_KEYUP_DATA_API = `keyup${EVENT_KEY}${DATA_API_KEY}`; | ||
const CLASS_NAME_DISABLED = 'disabled'; | ||
const CLASS_NAME_SHOW = 'show'; | ||
const CLASS_NAME_DROPUP = 'dropup'; | ||
const CLASS_NAME_DROPEND = 'dropend'; | ||
const CLASS_NAME_DROPSTART = 'dropstart'; | ||
const CLASS_NAME_NAVBAR = 'navbar'; | ||
const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="dropdown"]'; | ||
const SELECTOR_MENU = '.dropdown-menu'; | ||
const SELECTOR_NAVBAR_NAV = '.navbar-nav'; | ||
const SELECTOR_VISIBLE_ITEMS = '.dropdown-menu .dropdown-item:not(.disabled):not(:disabled)'; | ||
const PLACEMENT_TOP = isRTL() ? 'top-end' : 'top-start'; | ||
const PLACEMENT_TOPEND = isRTL() ? 'top-start' : 'top-end'; | ||
const PLACEMENT_BOTTOM = isRTL() ? 'bottom-end' : 'bottom-start'; | ||
const PLACEMENT_BOTTOMEND = isRTL() ? 'bottom-start' : 'bottom-end'; | ||
const PLACEMENT_RIGHT = isRTL() ? 'left-start' : 'right-start'; | ||
const PLACEMENT_LEFT = isRTL() ? 'right-start' : 'left-start'; | ||
const Default = { | ||
offset: [0, 2], | ||
flip: true, | ||
boundary: 'clippingParents', | ||
@@ -270,5 +221,4 @@ reference: 'toggle', | ||
}; | ||
var DefaultType = { | ||
const DefaultType = { | ||
offset: '(array|string|function)', | ||
flip: 'boolean', | ||
boundary: '(string|element)', | ||
@@ -285,24 +235,28 @@ reference: '(string|element|object)', | ||
var Dropdown = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Dropdown, _BaseComponent); | ||
class Dropdown extends BaseComponent__default['default'] { | ||
constructor(element, config) { | ||
super(element); | ||
this._popper = null; | ||
this._config = this._getConfig(config); | ||
this._menu = this._getMenuElement(); | ||
this._inNavbar = this._detectNavbar(); | ||
function Dropdown(element, config) { | ||
var _this; | ||
this._addEventListeners(); | ||
} // Getters | ||
_this = _BaseComponent.call(this, element) || this; | ||
_this._popper = null; | ||
_this._config = _this._getConfig(config); | ||
_this._menu = _this._getMenuElement(); | ||
_this._inNavbar = _this._detectNavbar(); | ||
_this._addEventListeners(); | ||
static get Default() { | ||
return Default; | ||
} | ||
return _this; | ||
} // Getters | ||
static get DefaultType() { | ||
return DefaultType; | ||
} | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
var _proto = Dropdown.prototype; | ||
// Public | ||
_proto.toggle = function toggle() { | ||
toggle() { | ||
if (this._element.disabled || this._element.classList.contains(CLASS_NAME_DISABLED)) { | ||
@@ -312,3 +266,3 @@ return; | ||
var isActive = this._element.classList.contains(CLASS_NAME_SHOW); | ||
const isActive = this._element.classList.contains(CLASS_NAME_SHOW); | ||
@@ -322,5 +276,5 @@ Dropdown.clearMenus(); | ||
this.show(); | ||
}; | ||
} | ||
_proto.show = function show() { | ||
show() { | ||
if (this._element.disabled || this._element.classList.contains(CLASS_NAME_DISABLED) || this._menu.classList.contains(CLASS_NAME_SHOW)) { | ||
@@ -330,7 +284,7 @@ return; | ||
var parent = Dropdown.getParentFromElement(this._element); | ||
var relatedTarget = { | ||
const parent = Dropdown.getParentFromElement(this._element); | ||
const relatedTarget = { | ||
relatedTarget: this._element | ||
}; | ||
var showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW, relatedTarget); | ||
const showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW, relatedTarget); | ||
@@ -349,3 +303,3 @@ if (showEvent.defaultPrevented) { | ||
var referenceElement = this._element; | ||
let referenceElement = this._element; | ||
@@ -364,8 +318,6 @@ if (this._config.reference === 'parent') { | ||
var popperConfig = this._getPopperConfig(); | ||
const popperConfig = this._getPopperConfig(); | ||
var isDisplayStatic = popperConfig.modifiers.find(function (modifier) { | ||
return modifier.name === 'applyStyles' && modifier.enabled === false; | ||
}); | ||
this._popper = Popper.createPopper(referenceElement, this._menu, popperConfig); | ||
const isDisplayStatic = popperConfig.modifiers.find(modifier => modifier.name === 'applyStyles' && modifier.enabled === false); | ||
this._popper = Popper__namespace.createPopper(referenceElement, this._menu, popperConfig); | ||
@@ -382,7 +334,3 @@ if (isDisplayStatic) { | ||
if ('ontouchstart' in document.documentElement && !parent.closest(SELECTOR_NAVBAR_NAV)) { | ||
var _ref; | ||
(_ref = []).concat.apply(_ref, document.body.children).forEach(function (elem) { | ||
return EventHandler__default['default'].on(elem, 'mouseover', null, noop()); | ||
}); | ||
[].concat(...document.body.children).forEach(elem => EventHandler__default['default'].on(elem, 'mouseover', null, noop())); | ||
} | ||
@@ -399,5 +347,5 @@ | ||
EventHandler__default['default'].trigger(this._element, EVENT_SHOWN, relatedTarget); | ||
}; | ||
} | ||
_proto.hide = function hide() { | ||
hide() { | ||
if (this._element.disabled || this._element.classList.contains(CLASS_NAME_DISABLED) || !this._menu.classList.contains(CLASS_NAME_SHOW)) { | ||
@@ -407,6 +355,6 @@ return; | ||
var relatedTarget = { | ||
const relatedTarget = { | ||
relatedTarget: this._element | ||
}; | ||
var hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE, relatedTarget); | ||
const hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE, relatedTarget); | ||
@@ -427,7 +375,5 @@ if (hideEvent.defaultPrevented) { | ||
EventHandler__default['default'].trigger(this._element, EVENT_HIDDEN, relatedTarget); | ||
}; | ||
} | ||
_proto.dispose = function dispose() { | ||
_BaseComponent.prototype.dispose.call(this); | ||
dispose() { | ||
EventHandler__default['default'].off(this._element, EVENT_KEY); | ||
@@ -441,5 +387,7 @@ this._menu = null; | ||
} | ||
}; | ||
_proto.update = function update() { | ||
super.dispose(); | ||
} | ||
update() { | ||
this._inNavbar = this._detectNavbar(); | ||
@@ -451,17 +399,16 @@ | ||
} // Private | ||
; | ||
_proto._addEventListeners = function _addEventListeners() { | ||
var _this2 = this; | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK, function (event) { | ||
_addEventListeners() { | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK, event => { | ||
event.preventDefault(); | ||
event.stopPropagation(); | ||
_this2.toggle(); | ||
this.toggle(); | ||
}); | ||
}; | ||
} | ||
_proto._getConfig = function _getConfig(config) { | ||
config = _extends({}, this.constructor.Default, Manipulator__default['default'].getDataAttributes(this._element), config); | ||
_getConfig(config) { | ||
config = { ...this.constructor.Default, | ||
...Manipulator__default['default'].getDataAttributes(this._element), | ||
...config | ||
}; | ||
typeCheckConfig(NAME, config, this.constructor.DefaultType); | ||
@@ -471,14 +418,14 @@ | ||
// Popper virtual elements require a getBoundingClientRect method | ||
throw new TypeError(NAME.toUpperCase() + ": Option \"reference\" provided type \"object\" without a required \"getBoundingClientRect\" method."); | ||
throw new TypeError(`${NAME.toUpperCase()}: Option "reference" provided type "object" without a required "getBoundingClientRect" method.`); | ||
} | ||
return config; | ||
}; | ||
} | ||
_proto._getMenuElement = function _getMenuElement() { | ||
_getMenuElement() { | ||
return SelectorEngine__default['default'].next(this._element, SELECTOR_MENU)[0]; | ||
}; | ||
} | ||
_proto._getPlacement = function _getPlacement() { | ||
var parentDropdown = this._element.parentNode; | ||
_getPlacement() { | ||
const parentDropdown = this._element.parentNode; | ||
@@ -494,3 +441,3 @@ if (parentDropdown.classList.contains(CLASS_NAME_DROPEND)) { | ||
var isEnd = getComputedStyle(this._menu).getPropertyValue('--bs-position').trim() === 'end'; | ||
const isEnd = getComputedStyle(this._menu).getPropertyValue('--bs-position').trim() === 'end'; | ||
@@ -502,30 +449,26 @@ if (parentDropdown.classList.contains(CLASS_NAME_DROPUP)) { | ||
return isEnd ? PLACEMENT_BOTTOMEND : PLACEMENT_BOTTOM; | ||
}; | ||
} | ||
_proto._detectNavbar = function _detectNavbar() { | ||
return this._element.closest("." + CLASS_NAME_NAVBAR) !== null; | ||
}; | ||
_detectNavbar() { | ||
return this._element.closest(`.${CLASS_NAME_NAVBAR}`) !== null; | ||
} | ||
_proto._getOffset = function _getOffset() { | ||
var _this3 = this; | ||
_getOffset() { | ||
const { | ||
offset | ||
} = this._config; | ||
var offset = this._config.offset; | ||
if (typeof offset === 'string') { | ||
return offset.split(',').map(function (val) { | ||
return Number.parseInt(val, 10); | ||
}); | ||
return offset.split(',').map(val => Number.parseInt(val, 10)); | ||
} | ||
if (typeof offset === 'function') { | ||
return function (popperData) { | ||
return offset(popperData, _this3._element); | ||
}; | ||
return popperData => offset(popperData, this._element); | ||
} | ||
return offset; | ||
}; | ||
} | ||
_proto._getPopperConfig = function _getPopperConfig() { | ||
var defaultBsPopperConfig = { | ||
_getPopperConfig() { | ||
const defaultBsPopperConfig = { | ||
placement: this._getPlacement(), | ||
@@ -535,3 +478,2 @@ modifiers: [{ | ||
options: { | ||
altBoundary: this._config.flip, | ||
boundary: this._config.boundary | ||
@@ -554,11 +496,13 @@ } | ||
return _extends({}, defaultBsPopperConfig, typeof this._config.popperConfig === 'function' ? this._config.popperConfig(defaultBsPopperConfig) : this._config.popperConfig); | ||
return { ...defaultBsPopperConfig, | ||
...(typeof this._config.popperConfig === 'function' ? this._config.popperConfig(defaultBsPopperConfig) : this._config.popperConfig) | ||
}; | ||
} // Static | ||
; | ||
Dropdown.dropdownInterface = function dropdownInterface(element, config) { | ||
var data = Data__default['default'].getData(element, DATA_KEY); | ||
var _config = typeof config === 'object' ? config : null; | ||
static dropdownInterface(element, config) { | ||
let data = Data__default['default'].get(element, DATA_KEY); | ||
const _config = typeof config === 'object' ? config : null; | ||
if (!data) { | ||
@@ -570,3 +514,3 @@ data = new Dropdown(element, _config); | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -576,20 +520,26 @@ | ||
} | ||
}; | ||
} | ||
Dropdown.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
Dropdown.dropdownInterface(this, config); | ||
}); | ||
}; | ||
} | ||
Dropdown.clearMenus = function clearMenus(event) { | ||
if (event && (event.button === RIGHT_MOUSE_BUTTON || event.type === 'keyup' && event.key !== TAB_KEY)) { | ||
return; | ||
static clearMenus(event) { | ||
if (event) { | ||
if (event.button === RIGHT_MOUSE_BUTTON || event.type === 'keyup' && event.key !== TAB_KEY) { | ||
return; | ||
} | ||
if (/input|select|textarea|form/i.test(event.target.tagName)) { | ||
return; | ||
} | ||
} | ||
var toggles = SelectorEngine__default['default'].find(SELECTOR_DATA_TOGGLE); | ||
const toggles = SelectorEngine__default['default'].find(SELECTOR_DATA_TOGGLE); | ||
for (var i = 0, len = toggles.length; i < len; i++) { | ||
var context = Data__default['default'].getData(toggles[i], DATA_KEY); | ||
var relatedTarget = { | ||
for (let i = 0, len = toggles.length; i < len; i++) { | ||
const context = Data__default['default'].get(toggles[i], DATA_KEY); | ||
const relatedTarget = { | ||
relatedTarget: toggles[i] | ||
@@ -606,3 +556,3 @@ }; | ||
var dropdownMenu = context._menu; | ||
const dropdownMenu = context._menu; | ||
@@ -613,7 +563,15 @@ if (!toggles[i].classList.contains(CLASS_NAME_SHOW)) { | ||
if (event && (event.type === 'click' && /input|textarea/i.test(event.target.tagName) || event.type === 'keyup' && event.key === TAB_KEY) && dropdownMenu.contains(event.target)) { | ||
continue; | ||
if (event) { | ||
// Don't close the menu if the clicked element or one of its parents is the dropdown button | ||
if ([context._element].some(element => event.composedPath().includes(element))) { | ||
continue; | ||
} // Tab navigation through the dropdown menu shouldn't close the menu | ||
if (event.type === 'keyup' && event.key === TAB_KEY && dropdownMenu.contains(event.target)) { | ||
continue; | ||
} | ||
} | ||
var hideEvent = EventHandler__default['default'].trigger(toggles[i], EVENT_HIDE, relatedTarget); | ||
const hideEvent = EventHandler__default['default'].trigger(toggles[i], EVENT_HIDE, relatedTarget); | ||
@@ -627,7 +585,3 @@ if (hideEvent.defaultPrevented) { | ||
if ('ontouchstart' in document.documentElement) { | ||
var _ref2; | ||
(_ref2 = []).concat.apply(_ref2, document.body.children).forEach(function (elem) { | ||
return EventHandler__default['default'].off(elem, 'mouseover', null, noop()); | ||
}); | ||
[].concat(...document.body.children).forEach(elem => EventHandler__default['default'].off(elem, 'mouseover', null, noop())); | ||
} | ||
@@ -646,9 +600,9 @@ | ||
} | ||
}; | ||
} | ||
Dropdown.getParentFromElement = function getParentFromElement(element) { | ||
static getParentFromElement(element) { | ||
return getElementFromSelector(element) || element.parentNode; | ||
}; | ||
} | ||
Dropdown.dataApiKeydownHandler = function dataApiKeydownHandler(event) { | ||
static dataApiKeydownHandler(event) { | ||
// If not input/textarea: | ||
@@ -672,7 +626,7 @@ // - And not a key in REGEXP_KEYDOWN => not a dropdown command | ||
var parent = Dropdown.getParentFromElement(this); | ||
var isActive = this.classList.contains(CLASS_NAME_SHOW); | ||
const parent = Dropdown.getParentFromElement(this); | ||
const isActive = this.classList.contains(CLASS_NAME_SHOW); | ||
if (event.key === ESCAPE_KEY) { | ||
var button = this.matches(SELECTOR_DATA_TOGGLE) ? this : SelectorEngine__default['default'].prev(this, SELECTOR_DATA_TOGGLE)[0]; | ||
const button = this.matches(SELECTOR_DATA_TOGGLE) ? this : SelectorEngine__default['default'].prev(this, SELECTOR_DATA_TOGGLE)[0]; | ||
button.focus(); | ||
@@ -684,6 +638,4 @@ Dropdown.clearMenus(); | ||
if (!isActive && (event.key === ARROW_UP_KEY || event.key === ARROW_DOWN_KEY)) { | ||
var _button = this.matches(SELECTOR_DATA_TOGGLE) ? this : SelectorEngine__default['default'].prev(this, SELECTOR_DATA_TOGGLE)[0]; | ||
_button.click(); | ||
const button = this.matches(SELECTOR_DATA_TOGGLE) ? this : SelectorEngine__default['default'].prev(this, SELECTOR_DATA_TOGGLE)[0]; | ||
button.click(); | ||
return; | ||
@@ -697,3 +649,3 @@ } | ||
var items = SelectorEngine__default['default'].find(SELECTOR_VISIBLE_ITEMS, parent).filter(isVisible); | ||
const items = SelectorEngine__default['default'].find(SELECTOR_VISIBLE_ITEMS, parent).filter(isVisible); | ||
@@ -704,3 +656,3 @@ if (!items.length) { | ||
var index = items.indexOf(event.target); // Up | ||
let index = items.indexOf(event.target); // Up | ||
@@ -719,23 +671,5 @@ if (event.key === ARROW_UP_KEY && index > 0) { | ||
items[index].focus(); | ||
}; | ||
} | ||
_createClass(Dropdown, null, [{ | ||
key: "Default", | ||
get: function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "DefaultType", | ||
get: function get() { | ||
return DefaultType; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Dropdown; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -754,8 +688,4 @@ * ------------------------------------------------------------------------ | ||
event.preventDefault(); | ||
event.stopPropagation(); | ||
Dropdown.dropdownInterface(this, 'toggle'); | ||
Dropdown.dropdownInterface(this); | ||
}); | ||
EventHandler__default['default'].on(document, EVENT_CLICK_DATA_API, SELECTOR_FORM_CHILD, function (e) { | ||
return e.stopPropagation(); | ||
}); | ||
/** | ||
@@ -762,0 +692,0 @@ * ------------------------------------------------------------------------ |
/*! | ||
* Bootstrap modal.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap modal.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -20,64 +20,14 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MILLISECONDS_MULTIPLIER = 1000; | ||
var TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
const MILLISECONDS_MULTIPLIER = 1000; | ||
const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
var toType = function toType(obj) { | ||
const toType = obj => { | ||
if (obj === null || obj === undefined) { | ||
return "" + obj; | ||
return `${obj}`; | ||
} | ||
@@ -88,7 +38,7 @@ | ||
var getSelector = function getSelector(element) { | ||
var selector = element.getAttribute('data-bs-target'); | ||
const getSelector = element => { | ||
let selector = element.getAttribute('data-bs-target'); | ||
if (!selector || selector === '#') { | ||
var hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
// so everything starting with `#` or `.`. If a "real" URL is used as the selector, | ||
@@ -113,8 +63,8 @@ // `document.querySelector` will rightfully complain it is invalid. | ||
var getElementFromSelector = function getElementFromSelector(element) { | ||
var selector = getSelector(element); | ||
const getElementFromSelector = element => { | ||
const selector = getSelector(element); | ||
return selector ? document.querySelector(selector) : null; | ||
}; | ||
var getTransitionDurationFromElement = function getTransitionDurationFromElement(element) { | ||
const getTransitionDurationFromElement = element => { | ||
if (!element) { | ||
@@ -125,9 +75,9 @@ return 0; | ||
var _window$getComputedSt = window.getComputedStyle(element), | ||
transitionDuration = _window$getComputedSt.transitionDuration, | ||
transitionDelay = _window$getComputedSt.transitionDelay; | ||
let { | ||
transitionDuration, | ||
transitionDelay | ||
} = window.getComputedStyle(element); | ||
const floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
var floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
var floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
if (!floatTransitionDuration && !floatTransitionDelay) { | ||
@@ -143,14 +93,12 @@ return 0; | ||
var triggerTransitionEnd = function triggerTransitionEnd(element) { | ||
const triggerTransitionEnd = element => { | ||
element.dispatchEvent(new Event(TRANSITION_END)); | ||
}; | ||
var isElement = function isElement(obj) { | ||
return (obj[0] || obj).nodeType; | ||
}; | ||
const isElement = obj => (obj[0] || obj).nodeType; | ||
var emulateTransitionEnd = function emulateTransitionEnd(element, duration) { | ||
var called = false; | ||
var durationPadding = 5; | ||
var emulatedDuration = duration + durationPadding; | ||
const emulateTransitionEnd = (element, duration) => { | ||
let called = false; | ||
const durationPadding = 5; | ||
const emulatedDuration = duration + durationPadding; | ||
@@ -163,3 +111,3 @@ function listener() { | ||
element.addEventListener(TRANSITION_END, listener); | ||
setTimeout(function () { | ||
setTimeout(() => { | ||
if (!called) { | ||
@@ -171,10 +119,10 @@ triggerTransitionEnd(element); | ||
var typeCheckConfig = function typeCheckConfig(componentName, config, configTypes) { | ||
Object.keys(configTypes).forEach(function (property) { | ||
var expectedTypes = configTypes[property]; | ||
var value = config[property]; | ||
var valueType = value && isElement(value) ? 'element' : toType(value); | ||
const typeCheckConfig = (componentName, config, configTypes) => { | ||
Object.keys(configTypes).forEach(property => { | ||
const expectedTypes = configTypes[property]; | ||
const value = config[property]; | ||
const valueType = value && isElement(value) ? 'element' : toType(value); | ||
if (!new RegExp(expectedTypes).test(valueType)) { | ||
throw new TypeError(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); | ||
throw new TypeError(`${componentName.toUpperCase()}: ` + `Option "${property}" provided type "${valueType}" ` + `but expected type "${expectedTypes}".`); | ||
} | ||
@@ -184,3 +132,3 @@ }); | ||
var isVisible = function isVisible(element) { | ||
const isVisible = element => { | ||
if (!element) { | ||
@@ -191,4 +139,4 @@ return false; | ||
if (element.style && element.parentNode && element.parentNode.style) { | ||
var elementStyle = getComputedStyle(element); | ||
var parentNodeStyle = getComputedStyle(element.parentNode); | ||
const elementStyle = getComputedStyle(element); | ||
const parentNodeStyle = getComputedStyle(element.parentNode); | ||
return elementStyle.display !== 'none' && parentNodeStyle.display !== 'none' && elementStyle.visibility !== 'hidden'; | ||
@@ -200,9 +148,8 @@ } | ||
var reflow = function reflow(element) { | ||
return element.offsetHeight; | ||
}; | ||
const reflow = element => element.offsetHeight; | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -216,3 +163,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -225,15 +172,15 @@ document.addEventListener('DOMContentLoaded', callback); | ||
var isRTL = document.documentElement.dir === 'rtl'; | ||
const isRTL = () => document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -247,2 +194,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): modal.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -253,8 +206,8 @@ * Constants | ||
var NAME = 'modal'; | ||
var DATA_KEY = 'bs.modal'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var ESCAPE_KEY = 'Escape'; | ||
var Default = { | ||
const NAME = 'modal'; | ||
const DATA_KEY = 'bs.modal'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const ESCAPE_KEY = 'Escape'; | ||
const Default = { | ||
backdrop: true, | ||
@@ -264,3 +217,3 @@ keyboard: true, | ||
}; | ||
var DefaultType = { | ||
const DefaultType = { | ||
backdrop: '(boolean|string)', | ||
@@ -270,26 +223,26 @@ keyboard: 'boolean', | ||
}; | ||
var EVENT_HIDE = "hide" + EVENT_KEY; | ||
var EVENT_HIDE_PREVENTED = "hidePrevented" + EVENT_KEY; | ||
var EVENT_HIDDEN = "hidden" + EVENT_KEY; | ||
var EVENT_SHOW = "show" + EVENT_KEY; | ||
var EVENT_SHOWN = "shown" + EVENT_KEY; | ||
var EVENT_FOCUSIN = "focusin" + EVENT_KEY; | ||
var EVENT_RESIZE = "resize" + EVENT_KEY; | ||
var EVENT_CLICK_DISMISS = "click.dismiss" + EVENT_KEY; | ||
var EVENT_KEYDOWN_DISMISS = "keydown.dismiss" + EVENT_KEY; | ||
var EVENT_MOUSEUP_DISMISS = "mouseup.dismiss" + EVENT_KEY; | ||
var EVENT_MOUSEDOWN_DISMISS = "mousedown.dismiss" + EVENT_KEY; | ||
var EVENT_CLICK_DATA_API = "click" + EVENT_KEY + DATA_API_KEY; | ||
var CLASS_NAME_SCROLLBAR_MEASURER = 'modal-scrollbar-measure'; | ||
var CLASS_NAME_BACKDROP = 'modal-backdrop'; | ||
var CLASS_NAME_OPEN = 'modal-open'; | ||
var CLASS_NAME_FADE = 'fade'; | ||
var CLASS_NAME_SHOW = 'show'; | ||
var CLASS_NAME_STATIC = 'modal-static'; | ||
var SELECTOR_DIALOG = '.modal-dialog'; | ||
var SELECTOR_MODAL_BODY = '.modal-body'; | ||
var SELECTOR_DATA_TOGGLE = '[data-bs-toggle="modal"]'; | ||
var SELECTOR_DATA_DISMISS = '[data-bs-dismiss="modal"]'; | ||
var SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top'; | ||
var SELECTOR_STICKY_CONTENT = '.sticky-top'; | ||
const EVENT_HIDE = `hide${EVENT_KEY}`; | ||
const EVENT_HIDE_PREVENTED = `hidePrevented${EVENT_KEY}`; | ||
const EVENT_HIDDEN = `hidden${EVENT_KEY}`; | ||
const EVENT_SHOW = `show${EVENT_KEY}`; | ||
const EVENT_SHOWN = `shown${EVENT_KEY}`; | ||
const EVENT_FOCUSIN = `focusin${EVENT_KEY}`; | ||
const EVENT_RESIZE = `resize${EVENT_KEY}`; | ||
const EVENT_CLICK_DISMISS = `click.dismiss${EVENT_KEY}`; | ||
const EVENT_KEYDOWN_DISMISS = `keydown.dismiss${EVENT_KEY}`; | ||
const EVENT_MOUSEUP_DISMISS = `mouseup.dismiss${EVENT_KEY}`; | ||
const EVENT_MOUSEDOWN_DISMISS = `mousedown.dismiss${EVENT_KEY}`; | ||
const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`; | ||
const CLASS_NAME_SCROLLBAR_MEASURER = 'modal-scrollbar-measure'; | ||
const CLASS_NAME_BACKDROP = 'modal-backdrop'; | ||
const CLASS_NAME_OPEN = 'modal-open'; | ||
const CLASS_NAME_FADE = 'fade'; | ||
const CLASS_NAME_SHOW = 'show'; | ||
const CLASS_NAME_STATIC = 'modal-static'; | ||
const SELECTOR_DIALOG = '.modal-dialog'; | ||
const SELECTOR_MODAL_BODY = '.modal-body'; | ||
const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="modal"]'; | ||
const SELECTOR_DATA_DISMISS = '[data-bs-dismiss="modal"]'; | ||
const SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top'; | ||
const SELECTOR_STICKY_CONTENT = '.sticky-top'; | ||
/** | ||
@@ -301,31 +254,30 @@ * ------------------------------------------------------------------------ | ||
var Modal = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Modal, _BaseComponent); | ||
class Modal extends BaseComponent__default['default'] { | ||
constructor(element, config) { | ||
super(element); | ||
this._config = this._getConfig(config); | ||
this._dialog = SelectorEngine__default['default'].findOne(SELECTOR_DIALOG, this._element); | ||
this._backdrop = null; | ||
this._isShown = false; | ||
this._isBodyOverflowing = false; | ||
this._ignoreBackdropClick = false; | ||
this._isTransitioning = false; | ||
this._scrollbarWidth = 0; | ||
} // Getters | ||
function Modal(element, config) { | ||
var _this; | ||
_this = _BaseComponent.call(this, element) || this; | ||
_this._config = _this._getConfig(config); | ||
_this._dialog = SelectorEngine__default['default'].findOne(SELECTOR_DIALOG, element); | ||
_this._backdrop = null; | ||
_this._isShown = false; | ||
_this._isBodyOverflowing = false; | ||
_this._ignoreBackdropClick = false; | ||
_this._isTransitioning = false; | ||
_this._scrollbarWidth = 0; | ||
return _this; | ||
} // Getters | ||
static get Default() { | ||
return Default; | ||
} | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
var _proto = Modal.prototype; | ||
// Public | ||
_proto.toggle = function toggle(relatedTarget) { | ||
toggle(relatedTarget) { | ||
return this._isShown ? this.hide() : this.show(relatedTarget); | ||
}; | ||
} | ||
_proto.show = function show(relatedTarget) { | ||
var _this2 = this; | ||
show(relatedTarget) { | ||
if (this._isShown || this._isTransitioning) { | ||
@@ -335,8 +287,8 @@ return; | ||
if (this._element.classList.contains(CLASS_NAME_FADE)) { | ||
if (this._isAnimated()) { | ||
this._isTransitioning = true; | ||
} | ||
var showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW, { | ||
relatedTarget: relatedTarget | ||
const showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW, { | ||
relatedTarget | ||
}); | ||
@@ -360,9 +312,7 @@ | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK_DISMISS, SELECTOR_DATA_DISMISS, function (event) { | ||
return _this2.hide(event); | ||
}); | ||
EventHandler__default['default'].on(this._dialog, EVENT_MOUSEDOWN_DISMISS, function () { | ||
EventHandler__default['default'].one(_this2._element, EVENT_MOUSEUP_DISMISS, function (event) { | ||
if (event.target === _this2._element) { | ||
_this2._ignoreBackdropClick = true; | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK_DISMISS, SELECTOR_DATA_DISMISS, event => this.hide(event)); | ||
EventHandler__default['default'].on(this._dialog, EVENT_MOUSEDOWN_DISMISS, () => { | ||
EventHandler__default['default'].one(this._element, EVENT_MOUSEUP_DISMISS, event => { | ||
if (event.target === this._element) { | ||
this._ignoreBackdropClick = true; | ||
} | ||
@@ -372,10 +322,6 @@ }); | ||
this._showBackdrop(function () { | ||
return _this2._showElement(relatedTarget); | ||
}); | ||
}; | ||
this._showBackdrop(() => this._showElement(relatedTarget)); | ||
} | ||
_proto.hide = function hide(event) { | ||
var _this3 = this; | ||
hide(event) { | ||
if (event) { | ||
@@ -389,3 +335,3 @@ event.preventDefault(); | ||
var hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE); | ||
const hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE); | ||
@@ -398,5 +344,5 @@ if (hideEvent.defaultPrevented) { | ||
var transition = this._element.classList.contains(CLASS_NAME_FADE); | ||
const isAnimated = this._isAnimated(); | ||
if (transition) { | ||
if (isAnimated) { | ||
this._isTransitioning = true; | ||
@@ -416,7 +362,5 @@ } | ||
if (transition) { | ||
var transitionDuration = getTransitionDurationFromElement(this._element); | ||
EventHandler__default['default'].one(this._element, 'transitionend', function (event) { | ||
return _this3._hideModal(event); | ||
}); | ||
if (isAnimated) { | ||
const transitionDuration = getTransitionDurationFromElement(this._element); | ||
EventHandler__default['default'].one(this._element, 'transitionend', event => this._hideModal(event)); | ||
emulateTransitionEnd(this._element, transitionDuration); | ||
@@ -426,10 +370,7 @@ } else { | ||
} | ||
}; | ||
} | ||
_proto.dispose = function dispose() { | ||
[window, this._element, this._dialog].forEach(function (htmlElement) { | ||
return EventHandler__default['default'].off(htmlElement, EVENT_KEY); | ||
}); | ||
_BaseComponent.prototype.dispose.call(this); | ||
dispose() { | ||
[window, this._element, this._dialog].forEach(htmlElement => EventHandler__default['default'].off(htmlElement, EVENT_KEY)); | ||
super.dispose(); | ||
/** | ||
@@ -441,3 +382,2 @@ * `document` has 2 events `EVENT_FOCUSIN` and `EVENT_CLICK_DATA_API` | ||
EventHandler__default['default'].off(document, EVENT_FOCUSIN); | ||
@@ -452,22 +392,22 @@ this._config = null; | ||
this._scrollbarWidth = null; | ||
}; | ||
} | ||
_proto.handleUpdate = function handleUpdate() { | ||
handleUpdate() { | ||
this._adjustDialog(); | ||
} // Private | ||
; | ||
_proto._getConfig = function _getConfig(config) { | ||
config = _extends({}, Default, config); | ||
_getConfig(config) { | ||
config = { ...Default, | ||
...config | ||
}; | ||
typeCheckConfig(NAME, config, DefaultType); | ||
return config; | ||
}; | ||
} | ||
_proto._showElement = function _showElement(relatedTarget) { | ||
var _this4 = this; | ||
_showElement(relatedTarget) { | ||
const isAnimated = this._isAnimated(); | ||
var transition = this._element.classList.contains(CLASS_NAME_FADE); | ||
const modalBody = SelectorEngine__default['default'].findOne(SELECTOR_MODAL_BODY, this._dialog); | ||
var modalBody = SelectorEngine__default['default'].findOne(SELECTOR_MODAL_BODY, this._dialog); | ||
if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) { | ||
@@ -492,3 +432,3 @@ // Don't move modal's DOM position | ||
if (transition) { | ||
if (isAnimated) { | ||
reflow(this._element); | ||
@@ -503,15 +443,15 @@ } | ||
var transitionComplete = function transitionComplete() { | ||
if (_this4._config.focus) { | ||
_this4._element.focus(); | ||
const transitionComplete = () => { | ||
if (this._config.focus) { | ||
this._element.focus(); | ||
} | ||
_this4._isTransitioning = false; | ||
EventHandler__default['default'].trigger(_this4._element, EVENT_SHOWN, { | ||
relatedTarget: relatedTarget | ||
this._isTransitioning = false; | ||
EventHandler__default['default'].trigger(this._element, EVENT_SHOWN, { | ||
relatedTarget | ||
}); | ||
}; | ||
if (transition) { | ||
var transitionDuration = getTransitionDurationFromElement(this._dialog); | ||
if (isAnimated) { | ||
const transitionDuration = getTransitionDurationFromElement(this._dialog); | ||
EventHandler__default['default'].one(this._dialog, 'transitionend', transitionComplete); | ||
@@ -522,27 +462,22 @@ emulateTransitionEnd(this._dialog, transitionDuration); | ||
} | ||
}; | ||
} | ||
_proto._enforceFocus = function _enforceFocus() { | ||
var _this5 = this; | ||
_enforceFocus() { | ||
EventHandler__default['default'].off(document, EVENT_FOCUSIN); // guard against infinite focus loop | ||
EventHandler__default['default'].on(document, EVENT_FOCUSIN, function (event) { | ||
if (document !== event.target && _this5._element !== event.target && !_this5._element.contains(event.target)) { | ||
_this5._element.focus(); | ||
EventHandler__default['default'].on(document, EVENT_FOCUSIN, event => { | ||
if (document !== event.target && this._element !== event.target && !this._element.contains(event.target)) { | ||
this._element.focus(); | ||
} | ||
}); | ||
}; | ||
} | ||
_proto._setEscapeEvent = function _setEscapeEvent() { | ||
var _this6 = this; | ||
_setEscapeEvent() { | ||
if (this._isShown) { | ||
EventHandler__default['default'].on(this._element, EVENT_KEYDOWN_DISMISS, function (event) { | ||
if (_this6._config.keyboard && event.key === ESCAPE_KEY) { | ||
EventHandler__default['default'].on(this._element, EVENT_KEYDOWN_DISMISS, event => { | ||
if (this._config.keyboard && event.key === ESCAPE_KEY) { | ||
event.preventDefault(); | ||
_this6.hide(); | ||
} else if (!_this6._config.keyboard && event.key === ESCAPE_KEY) { | ||
_this6._triggerBackdropTransition(); | ||
this.hide(); | ||
} else if (!this._config.keyboard && event.key === ESCAPE_KEY) { | ||
this._triggerBackdropTransition(); | ||
} | ||
@@ -553,19 +488,13 @@ }); | ||
} | ||
}; | ||
} | ||
_proto._setResizeEvent = function _setResizeEvent() { | ||
var _this7 = this; | ||
_setResizeEvent() { | ||
if (this._isShown) { | ||
EventHandler__default['default'].on(window, EVENT_RESIZE, function () { | ||
return _this7._adjustDialog(); | ||
}); | ||
EventHandler__default['default'].on(window, EVENT_RESIZE, () => this._adjustDialog()); | ||
} else { | ||
EventHandler__default['default'].off(window, EVENT_RESIZE); | ||
} | ||
}; | ||
} | ||
_proto._hideModal = function _hideModal() { | ||
var _this8 = this; | ||
_hideModal() { | ||
this._element.style.display = 'none'; | ||
@@ -581,24 +510,22 @@ | ||
this._showBackdrop(function () { | ||
this._showBackdrop(() => { | ||
document.body.classList.remove(CLASS_NAME_OPEN); | ||
_this8._resetAdjustments(); | ||
this._resetAdjustments(); | ||
_this8._resetScrollbar(); | ||
this._resetScrollbar(); | ||
EventHandler__default['default'].trigger(_this8._element, EVENT_HIDDEN); | ||
EventHandler__default['default'].trigger(this._element, EVENT_HIDDEN); | ||
}); | ||
}; | ||
} | ||
_proto._removeBackdrop = function _removeBackdrop() { | ||
_removeBackdrop() { | ||
this._backdrop.parentNode.removeChild(this._backdrop); | ||
this._backdrop = null; | ||
}; | ||
} | ||
_proto._showBackdrop = function _showBackdrop(callback) { | ||
var _this9 = this; | ||
_showBackdrop(callback) { | ||
const isAnimated = this._isAnimated(); | ||
var animate = this._element.classList.contains(CLASS_NAME_FADE) ? CLASS_NAME_FADE : ''; | ||
if (this._isShown && this._config.backdrop) { | ||
@@ -608,10 +535,10 @@ this._backdrop = document.createElement('div'); | ||
if (animate) { | ||
this._backdrop.classList.add(animate); | ||
if (isAnimated) { | ||
this._backdrop.classList.add(CLASS_NAME_FADE); | ||
} | ||
document.body.appendChild(this._backdrop); | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK_DISMISS, function (event) { | ||
if (_this9._ignoreBackdropClick) { | ||
_this9._ignoreBackdropClick = false; | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK_DISMISS, event => { | ||
if (this._ignoreBackdropClick) { | ||
this._ignoreBackdropClick = false; | ||
return; | ||
@@ -624,10 +551,10 @@ } | ||
if (_this9._config.backdrop === 'static') { | ||
_this9._triggerBackdropTransition(); | ||
if (this._config.backdrop === 'static') { | ||
this._triggerBackdropTransition(); | ||
} else { | ||
_this9.hide(); | ||
this.hide(); | ||
} | ||
}); | ||
if (animate) { | ||
if (isAnimated) { | ||
reflow(this._backdrop); | ||
@@ -638,3 +565,3 @@ } | ||
if (!animate) { | ||
if (!isAnimated) { | ||
callback(); | ||
@@ -644,3 +571,3 @@ return; | ||
var backdropTransitionDuration = getTransitionDurationFromElement(this._backdrop); | ||
const backdropTransitionDuration = getTransitionDurationFromElement(this._backdrop); | ||
EventHandler__default['default'].one(this._backdrop, 'transitionend', callback); | ||
@@ -651,4 +578,4 @@ emulateTransitionEnd(this._backdrop, backdropTransitionDuration); | ||
var callbackRemove = function callbackRemove() { | ||
_this9._removeBackdrop(); | ||
const callbackRemove = () => { | ||
this._removeBackdrop(); | ||
@@ -658,7 +585,6 @@ callback(); | ||
if (this._element.classList.contains(CLASS_NAME_FADE)) { | ||
var _backdropTransitionDuration = getTransitionDurationFromElement(this._backdrop); | ||
if (isAnimated) { | ||
const backdropTransitionDuration = getTransitionDurationFromElement(this._backdrop); | ||
EventHandler__default['default'].one(this._backdrop, 'transitionend', callbackRemove); | ||
emulateTransitionEnd(this._backdrop, _backdropTransitionDuration); | ||
emulateTransitionEnd(this._backdrop, backdropTransitionDuration); | ||
} else { | ||
@@ -670,8 +596,10 @@ callbackRemove(); | ||
} | ||
}; | ||
} | ||
_proto._triggerBackdropTransition = function _triggerBackdropTransition() { | ||
var _this10 = this; | ||
_isAnimated() { | ||
return this._element.classList.contains(CLASS_NAME_FADE); | ||
} | ||
var hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE_PREVENTED); | ||
_triggerBackdropTransition() { | ||
const hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE_PREVENTED); | ||
@@ -682,3 +610,3 @@ if (hideEvent.defaultPrevented) { | ||
var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; | ||
const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; | ||
@@ -691,12 +619,12 @@ if (!isModalOverflowing) { | ||
var modalTransitionDuration = getTransitionDurationFromElement(this._dialog); | ||
const modalTransitionDuration = getTransitionDurationFromElement(this._dialog); | ||
EventHandler__default['default'].off(this._element, 'transitionend'); | ||
EventHandler__default['default'].one(this._element, 'transitionend', function () { | ||
_this10._element.classList.remove(CLASS_NAME_STATIC); | ||
EventHandler__default['default'].one(this._element, 'transitionend', () => { | ||
this._element.classList.remove(CLASS_NAME_STATIC); | ||
if (!isModalOverflowing) { | ||
EventHandler__default['default'].one(_this10._element, 'transitionend', function () { | ||
_this10._element.style.overflowY = ''; | ||
EventHandler__default['default'].one(this._element, 'transitionend', () => { | ||
this._element.style.overflowY = ''; | ||
}); | ||
emulateTransitionEnd(_this10._element, modalTransitionDuration); | ||
emulateTransitionEnd(this._element, modalTransitionDuration); | ||
} | ||
@@ -710,57 +638,53 @@ }); | ||
// ---------------------------------------------------------------------- | ||
; | ||
_proto._adjustDialog = function _adjustDialog() { | ||
var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; | ||
if (!this._isBodyOverflowing && isModalOverflowing && !isRTL || this._isBodyOverflowing && !isModalOverflowing && isRTL) { | ||
this._element.style.paddingLeft = this._scrollbarWidth + "px"; | ||
_adjustDialog() { | ||
const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; | ||
if (!this._isBodyOverflowing && isModalOverflowing && !isRTL() || this._isBodyOverflowing && !isModalOverflowing && isRTL()) { | ||
this._element.style.paddingLeft = `${this._scrollbarWidth}px`; | ||
} | ||
if (this._isBodyOverflowing && !isModalOverflowing && !isRTL || !this._isBodyOverflowing && isModalOverflowing && isRTL) { | ||
this._element.style.paddingRight = this._scrollbarWidth + "px"; | ||
if (this._isBodyOverflowing && !isModalOverflowing && !isRTL() || !this._isBodyOverflowing && isModalOverflowing && isRTL()) { | ||
this._element.style.paddingRight = `${this._scrollbarWidth}px`; | ||
} | ||
}; | ||
} | ||
_proto._resetAdjustments = function _resetAdjustments() { | ||
_resetAdjustments() { | ||
this._element.style.paddingLeft = ''; | ||
this._element.style.paddingRight = ''; | ||
}; | ||
} | ||
_proto._checkScrollbar = function _checkScrollbar() { | ||
var rect = document.body.getBoundingClientRect(); | ||
_checkScrollbar() { | ||
const rect = document.body.getBoundingClientRect(); | ||
this._isBodyOverflowing = Math.round(rect.left + rect.right) < window.innerWidth; | ||
this._scrollbarWidth = this._getScrollbarWidth(); | ||
}; | ||
} | ||
_proto._setScrollbar = function _setScrollbar() { | ||
var _this11 = this; | ||
_setScrollbar() { | ||
if (this._isBodyOverflowing) { | ||
this._setElementAttributes(SELECTOR_FIXED_CONTENT, 'paddingRight', function (calculatedValue) { | ||
return calculatedValue + _this11._scrollbarWidth; | ||
}); | ||
this._setElementAttributes(SELECTOR_FIXED_CONTENT, 'paddingRight', calculatedValue => calculatedValue + this._scrollbarWidth); | ||
this._setElementAttributes(SELECTOR_STICKY_CONTENT, 'marginRight', function (calculatedValue) { | ||
return calculatedValue - _this11._scrollbarWidth; | ||
}); | ||
this._setElementAttributes(SELECTOR_STICKY_CONTENT, 'marginRight', calculatedValue => calculatedValue - this._scrollbarWidth); | ||
this._setElementAttributes('body', 'paddingRight', function (calculatedValue) { | ||
return calculatedValue + _this11._scrollbarWidth; | ||
}); | ||
this._setElementAttributes('body', 'paddingRight', calculatedValue => calculatedValue + this._scrollbarWidth); | ||
} | ||
document.body.classList.add(CLASS_NAME_OPEN); | ||
}; | ||
} | ||
_proto._setElementAttributes = function _setElementAttributes(selector, styleProp, callback) { | ||
SelectorEngine__default['default'].find(selector).forEach(function (element) { | ||
var actualValue = element.style[styleProp]; | ||
var calculatedValue = window.getComputedStyle(element)[styleProp]; | ||
_setElementAttributes(selector, styleProp, callback) { | ||
SelectorEngine__default['default'].find(selector).forEach(element => { | ||
if (element !== document.body && window.innerWidth > element.clientWidth + this._scrollbarWidth) { | ||
return; | ||
} | ||
const actualValue = element.style[styleProp]; | ||
const calculatedValue = window.getComputedStyle(element)[styleProp]; | ||
Manipulator__default['default'].setDataAttribute(element, styleProp, actualValue); | ||
element.style[styleProp] = callback(Number.parseFloat(calculatedValue)) + 'px'; | ||
}); | ||
}; | ||
} | ||
_proto._resetScrollbar = function _resetScrollbar() { | ||
_resetScrollbar() { | ||
this._resetElementAttributes(SELECTOR_FIXED_CONTENT, 'paddingRight'); | ||
@@ -771,7 +695,7 @@ | ||
this._resetElementAttributes('body', 'paddingRight'); | ||
}; | ||
} | ||
_proto._resetElementAttributes = function _resetElementAttributes(selector, styleProp) { | ||
SelectorEngine__default['default'].find(selector).forEach(function (element) { | ||
var value = Manipulator__default['default'].getDataAttribute(element, styleProp); | ||
_resetElementAttributes(selector, styleProp) { | ||
SelectorEngine__default['default'].find(selector).forEach(element => { | ||
const value = Manipulator__default['default'].getDataAttribute(element, styleProp); | ||
@@ -785,21 +709,23 @@ if (typeof value === 'undefined' && element === document.body) { | ||
}); | ||
}; | ||
} | ||
_proto._getScrollbarWidth = function _getScrollbarWidth() { | ||
_getScrollbarWidth() { | ||
// thx d.walsh | ||
var scrollDiv = document.createElement('div'); | ||
const scrollDiv = document.createElement('div'); | ||
scrollDiv.className = CLASS_NAME_SCROLLBAR_MEASURER; | ||
document.body.appendChild(scrollDiv); | ||
var scrollbarWidth = scrollDiv.getBoundingClientRect().width - scrollDiv.clientWidth; | ||
const scrollbarWidth = scrollDiv.getBoundingClientRect().width - scrollDiv.clientWidth; | ||
document.body.removeChild(scrollDiv); | ||
return scrollbarWidth; | ||
} // Static | ||
; | ||
Modal.jQueryInterface = function jQueryInterface(config, relatedTarget) { | ||
static jQueryInterface(config, relatedTarget) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY); | ||
let data = Data__default['default'].get(this, DATA_KEY); | ||
const _config = { ...Default, | ||
...Manipulator__default['default'].getDataAttributes(this), | ||
...(typeof config === 'object' && config ? config : {}) | ||
}; | ||
var _config = _extends({}, Default, Manipulator__default['default'].getDataAttributes(this), typeof config === 'object' && config ? config : {}); | ||
if (!data) { | ||
@@ -811,3 +737,3 @@ data = new Modal(this, _config); | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -818,18 +744,5 @@ | ||
}); | ||
}; | ||
} | ||
_createClass(Modal, null, [{ | ||
key: "Default", | ||
get: function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Modal; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -843,6 +756,4 @@ * ------------------------------------------------------------------------ | ||
EventHandler__default['default'].on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) { | ||
var _this12 = this; | ||
const target = getElementFromSelector(this); | ||
var target = getElementFromSelector(this); | ||
if (this.tagName === 'A' || this.tagName === 'AREA') { | ||
@@ -852,3 +763,3 @@ event.preventDefault(); | ||
EventHandler__default['default'].one(target, EVENT_SHOW, function (showEvent) { | ||
EventHandler__default['default'].one(target, EVENT_SHOW, showEvent => { | ||
if (showEvent.defaultPrevented) { | ||
@@ -859,13 +770,14 @@ // only register focus restorer if modal will actually get shown | ||
EventHandler__default['default'].one(target, EVENT_HIDDEN, function () { | ||
if (isVisible(_this12)) { | ||
_this12.focus(); | ||
EventHandler__default['default'].one(target, EVENT_HIDDEN, () => { | ||
if (isVisible(this)) { | ||
this.focus(); | ||
} | ||
}); | ||
}); | ||
var data = Data__default['default'].getData(target, DATA_KEY); | ||
let data = Data__default['default'].get(target, DATA_KEY); | ||
if (!data) { | ||
var config = _extends({}, Manipulator__default['default'].getDataAttributes(target), Manipulator__default['default'].getDataAttributes(this)); | ||
const config = { ...Manipulator__default['default'].getDataAttributes(target), | ||
...Manipulator__default['default'].getDataAttributes(this) | ||
}; | ||
data = new Modal(target, config); | ||
@@ -872,0 +784,0 @@ } |
/*! | ||
* Bootstrap popover.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap popover.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -18,55 +18,5 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -76,5 +26,6 @@ * -------------------------------------------------------------------------- | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -88,3 +39,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -97,15 +48,13 @@ document.addEventListener('DOMContentLoaded', callback); | ||
document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -119,2 +68,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): popover.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -125,9 +80,8 @@ * Constants | ||
var NAME = 'popover'; | ||
var DATA_KEY = 'bs.popover'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var CLASS_PREFIX = 'bs-popover'; | ||
var BSCLS_PREFIX_REGEX = new RegExp("(^|\\s)" + CLASS_PREFIX + "\\S+", 'g'); | ||
var Default = _extends({}, Tooltip__default['default'].Default, { | ||
const NAME = 'popover'; | ||
const DATA_KEY = 'bs.popover'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const CLASS_PREFIX = 'bs-popover'; | ||
const BSCLS_PREFIX_REGEX = new RegExp(`(^|\\s)${CLASS_PREFIX}\\S+`, 'g'); | ||
const Default = { ...Tooltip__default['default'].Default, | ||
placement: 'right', | ||
@@ -138,24 +92,22 @@ offset: [0, 8], | ||
template: '<div class="popover" role="tooltip">' + '<div class="popover-arrow"></div>' + '<h3 class="popover-header"></h3>' + '<div class="popover-body"></div>' + '</div>' | ||
}); | ||
var DefaultType = _extends({}, Tooltip__default['default'].DefaultType, { | ||
}; | ||
const DefaultType = { ...Tooltip__default['default'].DefaultType, | ||
content: '(string|element|function)' | ||
}); | ||
var Event = { | ||
HIDE: "hide" + EVENT_KEY, | ||
HIDDEN: "hidden" + EVENT_KEY, | ||
SHOW: "show" + EVENT_KEY, | ||
SHOWN: "shown" + EVENT_KEY, | ||
INSERTED: "inserted" + EVENT_KEY, | ||
CLICK: "click" + EVENT_KEY, | ||
FOCUSIN: "focusin" + EVENT_KEY, | ||
FOCUSOUT: "focusout" + EVENT_KEY, | ||
MOUSEENTER: "mouseenter" + EVENT_KEY, | ||
MOUSELEAVE: "mouseleave" + EVENT_KEY | ||
}; | ||
var CLASS_NAME_FADE = 'fade'; | ||
var CLASS_NAME_SHOW = 'show'; | ||
var SELECTOR_TITLE = '.popover-header'; | ||
var SELECTOR_CONTENT = '.popover-body'; | ||
const Event = { | ||
HIDE: `hide${EVENT_KEY}`, | ||
HIDDEN: `hidden${EVENT_KEY}`, | ||
SHOW: `show${EVENT_KEY}`, | ||
SHOWN: `shown${EVENT_KEY}`, | ||
INSERTED: `inserted${EVENT_KEY}`, | ||
CLICK: `click${EVENT_KEY}`, | ||
FOCUSIN: `focusin${EVENT_KEY}`, | ||
FOCUSOUT: `focusout${EVENT_KEY}`, | ||
MOUSEENTER: `mouseenter${EVENT_KEY}`, | ||
MOUSELEAVE: `mouseleave${EVENT_KEY}` | ||
}; | ||
const CLASS_NAME_FADE = 'fade'; | ||
const CLASS_NAME_SHOW = 'show'; | ||
const SELECTOR_TITLE = '.popover-header'; | ||
const SELECTOR_CONTENT = '.popover-body'; | ||
/** | ||
@@ -167,22 +119,39 @@ * ------------------------------------------------------------------------ | ||
var Popover = /*#__PURE__*/function (_Tooltip) { | ||
_inheritsLoose(Popover, _Tooltip); | ||
class Popover extends Tooltip__default['default'] { | ||
// Getters | ||
static get Default() { | ||
return Default; | ||
} | ||
function Popover() { | ||
return _Tooltip.apply(this, arguments) || this; | ||
static get NAME() { | ||
return NAME; | ||
} | ||
var _proto = Popover.prototype; | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} | ||
// Overrides | ||
_proto.isWithContent = function isWithContent() { | ||
static get Event() { | ||
return Event; | ||
} | ||
static get EVENT_KEY() { | ||
return EVENT_KEY; | ||
} | ||
static get DefaultType() { | ||
return DefaultType; | ||
} // Overrides | ||
isWithContent() { | ||
return this.getTitle() || this._getContent(); | ||
}; | ||
} | ||
_proto.setContent = function setContent() { | ||
var tip = this.getTipElement(); // we use append for html objects to maintain js events | ||
setContent() { | ||
const tip = this.getTipElement(); // we use append for html objects to maintain js events | ||
this.setElementContent(SelectorEngine__default['default'].findOne(SELECTOR_TITLE, tip), this.getTitle()); | ||
var content = this._getContent(); | ||
let content = this._getContent(); | ||
@@ -196,31 +165,27 @@ if (typeof content === 'function') { | ||
} // Private | ||
; | ||
_proto._addAttachmentClass = function _addAttachmentClass(attachment) { | ||
this.getTipElement().classList.add(CLASS_PREFIX + "-" + this.updateAttachment(attachment)); | ||
}; | ||
_proto._getContent = function _getContent() { | ||
_addAttachmentClass(attachment) { | ||
this.getTipElement().classList.add(`${CLASS_PREFIX}-${this.updateAttachment(attachment)}`); | ||
} | ||
_getContent() { | ||
return this._element.getAttribute('data-bs-content') || this.config.content; | ||
}; | ||
} | ||
_proto._cleanTipClass = function _cleanTipClass() { | ||
var tip = this.getTipElement(); | ||
var tabClass = tip.getAttribute('class').match(BSCLS_PREFIX_REGEX); | ||
_cleanTipClass() { | ||
const tip = this.getTipElement(); | ||
const tabClass = tip.getAttribute('class').match(BSCLS_PREFIX_REGEX); | ||
if (tabClass !== null && tabClass.length > 0) { | ||
tabClass.map(function (token) { | ||
return token.trim(); | ||
}).forEach(function (tClass) { | ||
return tip.classList.remove(tClass); | ||
}); | ||
tabClass.map(token => token.trim()).forEach(tClass => tip.classList.remove(tClass)); | ||
} | ||
} // Static | ||
; | ||
Popover.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY); | ||
let data = Data__default['default'].get(this, DATA_KEY); | ||
var _config = typeof config === 'object' ? config : null; | ||
const _config = typeof config === 'object' ? config : null; | ||
@@ -233,3 +198,3 @@ if (!data && /dispose|hide/.test(config)) { | ||
data = new Popover(this, _config); | ||
Data__default['default'].setData(this, DATA_KEY, data); | ||
Data__default['default'].set(this, DATA_KEY, data); | ||
} | ||
@@ -239,3 +204,3 @@ | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -246,39 +211,5 @@ | ||
}); | ||
}; | ||
} | ||
_createClass(Popover, null, [{ | ||
key: "Default", | ||
get: // Getters | ||
function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "NAME", | ||
get: function get() { | ||
return NAME; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}, { | ||
key: "Event", | ||
get: function get() { | ||
return Event; | ||
} | ||
}, { | ||
key: "EVENT_KEY", | ||
get: function get() { | ||
return EVENT_KEY; | ||
} | ||
}, { | ||
key: "DefaultType", | ||
get: function get() { | ||
return DefaultType; | ||
} | ||
}]); | ||
return Popover; | ||
}(Tooltip__default['default']); | ||
} | ||
/** | ||
@@ -285,0 +216,0 @@ * ------------------------------------------------------------------------ |
/*! | ||
* Bootstrap scrollspy.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap scrollspy.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -20,63 +20,13 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MAX_UID = 1000000; | ||
const MAX_UID = 1000000; | ||
var toType = function toType(obj) { | ||
const toType = obj => { | ||
if (obj === null || obj === undefined) { | ||
return "" + obj; | ||
return `${obj}`; | ||
} | ||
@@ -93,3 +43,3 @@ | ||
var getUID = function getUID(prefix) { | ||
const getUID = prefix => { | ||
do { | ||
@@ -102,7 +52,7 @@ prefix += Math.floor(Math.random() * MAX_UID); | ||
var getSelector = function getSelector(element) { | ||
var selector = element.getAttribute('data-bs-target'); | ||
const getSelector = element => { | ||
let selector = element.getAttribute('data-bs-target'); | ||
if (!selector || selector === '#') { | ||
var hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
// so everything starting with `#` or `.`. If a "real" URL is used as the selector, | ||
@@ -127,4 +77,4 @@ // `document.querySelector` will rightfully complain it is invalid. | ||
var getSelectorFromElement = function getSelectorFromElement(element) { | ||
var selector = getSelector(element); | ||
const getSelectorFromElement = element => { | ||
const selector = getSelector(element); | ||
@@ -138,14 +88,12 @@ if (selector) { | ||
var isElement = function isElement(obj) { | ||
return (obj[0] || obj).nodeType; | ||
}; | ||
const isElement = obj => (obj[0] || obj).nodeType; | ||
var typeCheckConfig = function typeCheckConfig(componentName, config, configTypes) { | ||
Object.keys(configTypes).forEach(function (property) { | ||
var expectedTypes = configTypes[property]; | ||
var value = config[property]; | ||
var valueType = value && isElement(value) ? 'element' : toType(value); | ||
const typeCheckConfig = (componentName, config, configTypes) => { | ||
Object.keys(configTypes).forEach(property => { | ||
const expectedTypes = configTypes[property]; | ||
const value = config[property]; | ||
const valueType = value && isElement(value) ? 'element' : toType(value); | ||
if (!new RegExp(expectedTypes).test(valueType)) { | ||
throw new TypeError(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); | ||
throw new TypeError(`${componentName.toUpperCase()}: ` + `Option "${property}" provided type "${valueType}" ` + `but expected type "${expectedTypes}".`); | ||
} | ||
@@ -155,5 +103,6 @@ }); | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -167,3 +116,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -176,15 +125,13 @@ document.addEventListener('DOMContentLoaded', callback); | ||
document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -198,2 +145,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): scrollspy.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -204,7 +157,7 @@ * Constants | ||
var NAME = 'scrollspy'; | ||
var DATA_KEY = 'bs.scrollspy'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var Default = { | ||
const NAME = 'scrollspy'; | ||
const DATA_KEY = 'bs.scrollspy'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const Default = { | ||
offset: 10, | ||
@@ -214,3 +167,3 @@ method: 'auto', | ||
}; | ||
var DefaultType = { | ||
const DefaultType = { | ||
offset: 'number', | ||
@@ -220,16 +173,16 @@ method: 'string', | ||
}; | ||
var EVENT_ACTIVATE = "activate" + EVENT_KEY; | ||
var EVENT_SCROLL = "scroll" + EVENT_KEY; | ||
var EVENT_LOAD_DATA_API = "load" + EVENT_KEY + DATA_API_KEY; | ||
var CLASS_NAME_DROPDOWN_ITEM = 'dropdown-item'; | ||
var CLASS_NAME_ACTIVE = 'active'; | ||
var SELECTOR_DATA_SPY = '[data-bs-spy="scroll"]'; | ||
var SELECTOR_NAV_LIST_GROUP = '.nav, .list-group'; | ||
var SELECTOR_NAV_LINKS = '.nav-link'; | ||
var SELECTOR_NAV_ITEMS = '.nav-item'; | ||
var SELECTOR_LIST_ITEMS = '.list-group-item'; | ||
var SELECTOR_DROPDOWN = '.dropdown'; | ||
var SELECTOR_DROPDOWN_TOGGLE = '.dropdown-toggle'; | ||
var METHOD_OFFSET = 'offset'; | ||
var METHOD_POSITION = 'position'; | ||
const EVENT_ACTIVATE = `activate${EVENT_KEY}`; | ||
const EVENT_SCROLL = `scroll${EVENT_KEY}`; | ||
const EVENT_LOAD_DATA_API = `load${EVENT_KEY}${DATA_API_KEY}`; | ||
const CLASS_NAME_DROPDOWN_ITEM = 'dropdown-item'; | ||
const CLASS_NAME_ACTIVE = 'active'; | ||
const SELECTOR_DATA_SPY = '[data-bs-spy="scroll"]'; | ||
const SELECTOR_NAV_LIST_GROUP = '.nav, .list-group'; | ||
const SELECTOR_NAV_LINKS = '.nav-link'; | ||
const SELECTOR_NAV_ITEMS = '.nav-item'; | ||
const SELECTOR_LIST_ITEMS = '.list-group-item'; | ||
const SELECTOR_DROPDOWN = '.dropdown'; | ||
const SELECTOR_DROPDOWN_TOGGLE = '.dropdown-toggle'; | ||
const METHOD_OFFSET = 'offset'; | ||
const METHOD_POSITION = 'position'; | ||
/** | ||
@@ -241,47 +194,42 @@ * ------------------------------------------------------------------------ | ||
var ScrollSpy = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(ScrollSpy, _BaseComponent); | ||
class ScrollSpy extends BaseComponent__default['default'] { | ||
constructor(element, config) { | ||
super(element); | ||
this._scrollElement = this._element.tagName === 'BODY' ? window : this._element; | ||
this._config = this._getConfig(config); | ||
this._selector = `${this._config.target} ${SELECTOR_NAV_LINKS}, ${this._config.target} ${SELECTOR_LIST_ITEMS}, ${this._config.target} .${CLASS_NAME_DROPDOWN_ITEM}`; | ||
this._offsets = []; | ||
this._targets = []; | ||
this._activeTarget = null; | ||
this._scrollHeight = 0; | ||
EventHandler__default['default'].on(this._scrollElement, EVENT_SCROLL, () => this._process()); | ||
this.refresh(); | ||
function ScrollSpy(element, config) { | ||
var _this; | ||
this._process(); | ||
} // Getters | ||
_this = _BaseComponent.call(this, element) || this; | ||
_this._scrollElement = element.tagName === 'BODY' ? window : element; | ||
_this._config = _this._getConfig(config); | ||
_this._selector = _this._config.target + " " + SELECTOR_NAV_LINKS + ", " + _this._config.target + " " + SELECTOR_LIST_ITEMS + ", " + _this._config.target + " ." + CLASS_NAME_DROPDOWN_ITEM; | ||
_this._offsets = []; | ||
_this._targets = []; | ||
_this._activeTarget = null; | ||
_this._scrollHeight = 0; | ||
EventHandler__default['default'].on(_this._scrollElement, EVENT_SCROLL, function () { | ||
return _this._process(); | ||
}); | ||
_this.refresh(); | ||
static get Default() { | ||
return Default; | ||
} | ||
_this._process(); | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
return _this; | ||
} // Getters | ||
var _proto = ScrollSpy.prototype; | ||
// Public | ||
_proto.refresh = function refresh() { | ||
var _this2 = this; | ||
var autoMethod = this._scrollElement === this._scrollElement.window ? METHOD_OFFSET : METHOD_POSITION; | ||
var offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method; | ||
var offsetBase = offsetMethod === METHOD_POSITION ? this._getScrollTop() : 0; | ||
refresh() { | ||
const autoMethod = this._scrollElement === this._scrollElement.window ? METHOD_OFFSET : METHOD_POSITION; | ||
const offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method; | ||
const offsetBase = offsetMethod === METHOD_POSITION ? this._getScrollTop() : 0; | ||
this._offsets = []; | ||
this._targets = []; | ||
this._scrollHeight = this._getScrollHeight(); | ||
var targets = SelectorEngine__default['default'].find(this._selector); | ||
targets.map(function (element) { | ||
var targetSelector = getSelectorFromElement(element); | ||
var target = targetSelector ? SelectorEngine__default['default'].findOne(targetSelector) : null; | ||
const targets = SelectorEngine__default['default'].find(this._selector); | ||
targets.map(element => { | ||
const targetSelector = getSelectorFromElement(element); | ||
const target = targetSelector ? SelectorEngine__default['default'].findOne(targetSelector) : null; | ||
if (target) { | ||
var targetBCR = target.getBoundingClientRect(); | ||
const targetBCR = target.getBoundingClientRect(); | ||
@@ -294,16 +242,11 @@ if (targetBCR.width || targetBCR.height) { | ||
return null; | ||
}).filter(function (item) { | ||
return item; | ||
}).sort(function (a, b) { | ||
return a[0] - b[0]; | ||
}).forEach(function (item) { | ||
_this2._offsets.push(item[0]); | ||
}).filter(item => item).sort((a, b) => a[0] - b[0]).forEach(item => { | ||
this._offsets.push(item[0]); | ||
_this2._targets.push(item[1]); | ||
this._targets.push(item[1]); | ||
}); | ||
}; | ||
} | ||
_proto.dispose = function dispose() { | ||
_BaseComponent.prototype.dispose.call(this); | ||
dispose() { | ||
super.dispose(); | ||
EventHandler__default['default'].off(this._scrollElement, EVENT_KEY); | ||
@@ -318,9 +261,13 @@ this._scrollElement = null; | ||
} // Private | ||
; | ||
_proto._getConfig = function _getConfig(config) { | ||
config = _extends({}, Default, typeof config === 'object' && config ? config : {}); | ||
_getConfig(config) { | ||
config = { ...Default, | ||
...(typeof config === 'object' && config ? config : {}) | ||
}; | ||
if (typeof config.target !== 'string' && isElement(config.target)) { | ||
var id = config.target.id; | ||
let { | ||
id | ||
} = config.target; | ||
@@ -332,3 +279,3 @@ if (!id) { | ||
config.target = "#" + id; | ||
config.target = `#${id}`; | ||
} | ||
@@ -338,22 +285,22 @@ | ||
return config; | ||
}; | ||
} | ||
_proto._getScrollTop = function _getScrollTop() { | ||
_getScrollTop() { | ||
return this._scrollElement === window ? this._scrollElement.pageYOffset : this._scrollElement.scrollTop; | ||
}; | ||
} | ||
_proto._getScrollHeight = function _getScrollHeight() { | ||
_getScrollHeight() { | ||
return this._scrollElement.scrollHeight || Math.max(document.body.scrollHeight, document.documentElement.scrollHeight); | ||
}; | ||
} | ||
_proto._getOffsetHeight = function _getOffsetHeight() { | ||
_getOffsetHeight() { | ||
return this._scrollElement === window ? window.innerHeight : this._scrollElement.getBoundingClientRect().height; | ||
}; | ||
} | ||
_proto._process = function _process() { | ||
var scrollTop = this._getScrollTop() + this._config.offset; | ||
_process() { | ||
const scrollTop = this._getScrollTop() + this._config.offset; | ||
var scrollHeight = this._getScrollHeight(); | ||
const scrollHeight = this._getScrollHeight(); | ||
var maxScroll = this._config.offset + scrollHeight - this._getOffsetHeight(); | ||
const maxScroll = this._config.offset + scrollHeight - this._getOffsetHeight(); | ||
@@ -365,3 +312,3 @@ if (this._scrollHeight !== scrollHeight) { | ||
if (scrollTop >= maxScroll) { | ||
var target = this._targets[this._targets.length - 1]; | ||
const target = this._targets[this._targets.length - 1]; | ||
@@ -383,4 +330,4 @@ if (this._activeTarget !== target) { | ||
for (var i = this._offsets.length; i--;) { | ||
var isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (typeof this._offsets[i + 1] === 'undefined' || scrollTop < this._offsets[i + 1]); | ||
for (let i = this._offsets.length; i--;) { | ||
const isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (typeof this._offsets[i + 1] === 'undefined' || scrollTop < this._offsets[i + 1]); | ||
@@ -391,5 +338,5 @@ if (isActiveTarget) { | ||
} | ||
}; | ||
} | ||
_proto._activate = function _activate(target) { | ||
_activate(target) { | ||
this._activeTarget = target; | ||
@@ -399,7 +346,5 @@ | ||
var queries = this._selector.split(',').map(function (selector) { | ||
return selector + "[data-bs-target=\"" + target + "\"]," + selector + "[href=\"" + target + "\"]"; | ||
}); | ||
const queries = this._selector.split(',').map(selector => `${selector}[data-bs-target="${target}"],${selector}[href="${target}"]`); | ||
var link = SelectorEngine__default['default'].findOne(queries.join(',')); | ||
const link = SelectorEngine__default['default'].findOne(queries.join(',')); | ||
@@ -412,13 +357,9 @@ if (link.classList.contains(CLASS_NAME_DROPDOWN_ITEM)) { | ||
link.classList.add(CLASS_NAME_ACTIVE); | ||
SelectorEngine__default['default'].parents(link, SELECTOR_NAV_LIST_GROUP).forEach(function (listGroup) { | ||
SelectorEngine__default['default'].parents(link, SELECTOR_NAV_LIST_GROUP).forEach(listGroup => { | ||
// Set triggered links parents as active | ||
// With both <ul> and <nav> markup a parent is the previous sibling of any nav ancestor | ||
SelectorEngine__default['default'].prev(listGroup, SELECTOR_NAV_LINKS + ", " + SELECTOR_LIST_ITEMS).forEach(function (item) { | ||
return item.classList.add(CLASS_NAME_ACTIVE); | ||
}); // Handle special case when .nav-link is inside .nav-item | ||
SelectorEngine__default['default'].prev(listGroup, `${SELECTOR_NAV_LINKS}, ${SELECTOR_LIST_ITEMS}`).forEach(item => item.classList.add(CLASS_NAME_ACTIVE)); // Handle special case when .nav-link is inside .nav-item | ||
SelectorEngine__default['default'].prev(listGroup, SELECTOR_NAV_ITEMS).forEach(function (navItem) { | ||
SelectorEngine__default['default'].children(navItem, SELECTOR_NAV_LINKS).forEach(function (item) { | ||
return item.classList.add(CLASS_NAME_ACTIVE); | ||
}); | ||
SelectorEngine__default['default'].prev(listGroup, SELECTOR_NAV_ITEMS).forEach(navItem => { | ||
SelectorEngine__default['default'].children(navItem, SELECTOR_NAV_LINKS).forEach(item => item.classList.add(CLASS_NAME_ACTIVE)); | ||
}); | ||
@@ -431,18 +372,14 @@ }); | ||
}); | ||
}; | ||
} | ||
_proto._clear = function _clear() { | ||
SelectorEngine__default['default'].find(this._selector).filter(function (node) { | ||
return node.classList.contains(CLASS_NAME_ACTIVE); | ||
}).forEach(function (node) { | ||
return node.classList.remove(CLASS_NAME_ACTIVE); | ||
}); | ||
_clear() { | ||
SelectorEngine__default['default'].find(this._selector).filter(node => node.classList.contains(CLASS_NAME_ACTIVE)).forEach(node => node.classList.remove(CLASS_NAME_ACTIVE)); | ||
} // Static | ||
; | ||
ScrollSpy.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY); | ||
let data = Data__default['default'].get(this, DATA_KEY); | ||
var _config = typeof config === 'object' && config; | ||
const _config = typeof config === 'object' && config; | ||
@@ -455,3 +392,3 @@ if (!data) { | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -462,18 +399,5 @@ | ||
}); | ||
}; | ||
} | ||
_createClass(ScrollSpy, null, [{ | ||
key: "Default", | ||
get: function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return ScrollSpy; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -486,6 +410,4 @@ * ------------------------------------------------------------------------ | ||
EventHandler__default['default'].on(window, EVENT_LOAD_DATA_API, function () { | ||
SelectorEngine__default['default'].find(SELECTOR_DATA_SPY).forEach(function (spy) { | ||
return new ScrollSpy(spy, Manipulator__default['default'].getDataAttributes(spy)); | ||
}); | ||
EventHandler__default['default'].on(window, EVENT_LOAD_DATA_API, () => { | ||
SelectorEngine__default['default'].find(SELECTOR_DATA_SPY).forEach(spy => new ScrollSpy(spy, Manipulator__default['default'].getDataAttributes(spy))); | ||
}); | ||
@@ -492,0 +414,0 @@ /** |
/*! | ||
* Bootstrap tab.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap tab.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -19,48 +19,16 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MILLISECONDS_MULTIPLIER = 1000; | ||
var TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
const MILLISECONDS_MULTIPLIER = 1000; | ||
const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
var getSelector = function getSelector(element) { | ||
var selector = element.getAttribute('data-bs-target'); | ||
const getSelector = element => { | ||
let selector = element.getAttribute('data-bs-target'); | ||
if (!selector || selector === '#') { | ||
var hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes, | ||
// so everything starting with `#` or `.`. If a "real" URL is used as the selector, | ||
@@ -85,8 +53,8 @@ // `document.querySelector` will rightfully complain it is invalid. | ||
var getElementFromSelector = function getElementFromSelector(element) { | ||
var selector = getSelector(element); | ||
const getElementFromSelector = element => { | ||
const selector = getSelector(element); | ||
return selector ? document.querySelector(selector) : null; | ||
}; | ||
var getTransitionDurationFromElement = function getTransitionDurationFromElement(element) { | ||
const getTransitionDurationFromElement = element => { | ||
if (!element) { | ||
@@ -97,9 +65,9 @@ return 0; | ||
var _window$getComputedSt = window.getComputedStyle(element), | ||
transitionDuration = _window$getComputedSt.transitionDuration, | ||
transitionDelay = _window$getComputedSt.transitionDelay; | ||
let { | ||
transitionDuration, | ||
transitionDelay | ||
} = window.getComputedStyle(element); | ||
const floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
var floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
var floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
if (!floatTransitionDuration && !floatTransitionDelay) { | ||
@@ -115,10 +83,10 @@ return 0; | ||
var triggerTransitionEnd = function triggerTransitionEnd(element) { | ||
const triggerTransitionEnd = element => { | ||
element.dispatchEvent(new Event(TRANSITION_END)); | ||
}; | ||
var emulateTransitionEnd = function emulateTransitionEnd(element, duration) { | ||
var called = false; | ||
var durationPadding = 5; | ||
var emulatedDuration = duration + durationPadding; | ||
const emulateTransitionEnd = (element, duration) => { | ||
let called = false; | ||
const durationPadding = 5; | ||
const emulatedDuration = duration + durationPadding; | ||
@@ -131,3 +99,3 @@ function listener() { | ||
element.addEventListener(TRANSITION_END, listener); | ||
setTimeout(function () { | ||
setTimeout(() => { | ||
if (!called) { | ||
@@ -139,10 +107,25 @@ triggerTransitionEnd(element); | ||
var reflow = function reflow(element) { | ||
return element.offsetHeight; | ||
const isDisabled = element => { | ||
if (!element || element.nodeType !== Node.ELEMENT_NODE) { | ||
return true; | ||
} | ||
if (element.classList.contains('disabled')) { | ||
return true; | ||
} | ||
if (typeof element.disabled !== 'undefined') { | ||
return element.disabled; | ||
} | ||
return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false'; | ||
}; | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const reflow = element => element.offsetHeight; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
@@ -155,3 +138,3 @@ return jQuery; | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -164,15 +147,13 @@ document.addEventListener('DOMContentLoaded', callback); | ||
document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -186,2 +167,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): tab.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -192,23 +179,22 @@ * Constants | ||
var NAME = 'tab'; | ||
var DATA_KEY = 'bs.tab'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var DATA_API_KEY = '.data-api'; | ||
var EVENT_HIDE = "hide" + EVENT_KEY; | ||
var EVENT_HIDDEN = "hidden" + EVENT_KEY; | ||
var EVENT_SHOW = "show" + EVENT_KEY; | ||
var EVENT_SHOWN = "shown" + EVENT_KEY; | ||
var EVENT_CLICK_DATA_API = "click" + EVENT_KEY + DATA_API_KEY; | ||
var CLASS_NAME_DROPDOWN_MENU = 'dropdown-menu'; | ||
var CLASS_NAME_ACTIVE = 'active'; | ||
var CLASS_NAME_DISABLED = 'disabled'; | ||
var CLASS_NAME_FADE = 'fade'; | ||
var CLASS_NAME_SHOW = 'show'; | ||
var SELECTOR_DROPDOWN = '.dropdown'; | ||
var SELECTOR_NAV_LIST_GROUP = '.nav, .list-group'; | ||
var SELECTOR_ACTIVE = '.active'; | ||
var SELECTOR_ACTIVE_UL = ':scope > li > .active'; | ||
var SELECTOR_DATA_TOGGLE = '[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]'; | ||
var SELECTOR_DROPDOWN_TOGGLE = '.dropdown-toggle'; | ||
var SELECTOR_DROPDOWN_ACTIVE_CHILD = ':scope > .dropdown-menu .active'; | ||
const NAME = 'tab'; | ||
const DATA_KEY = 'bs.tab'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const DATA_API_KEY = '.data-api'; | ||
const EVENT_HIDE = `hide${EVENT_KEY}`; | ||
const EVENT_HIDDEN = `hidden${EVENT_KEY}`; | ||
const EVENT_SHOW = `show${EVENT_KEY}`; | ||
const EVENT_SHOWN = `shown${EVENT_KEY}`; | ||
const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`; | ||
const CLASS_NAME_DROPDOWN_MENU = 'dropdown-menu'; | ||
const CLASS_NAME_ACTIVE = 'active'; | ||
const CLASS_NAME_FADE = 'fade'; | ||
const CLASS_NAME_SHOW = 'show'; | ||
const SELECTOR_DROPDOWN = '.dropdown'; | ||
const SELECTOR_NAV_LIST_GROUP = '.nav, .list-group'; | ||
const SELECTOR_ACTIVE = '.active'; | ||
const SELECTOR_ACTIVE_UL = ':scope > li > .active'; | ||
const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]'; | ||
const SELECTOR_DROPDOWN_TOGGLE = '.dropdown-toggle'; | ||
const SELECTOR_DROPDOWN_ACTIVE_CHILD = ':scope > .dropdown-menu .active'; | ||
/** | ||
@@ -220,26 +206,21 @@ * ------------------------------------------------------------------------ | ||
var Tab = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Tab, _BaseComponent); | ||
class Tab extends BaseComponent__default['default'] { | ||
// Getters | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
function Tab() { | ||
return _BaseComponent.apply(this, arguments) || this; | ||
} | ||
var _proto = Tab.prototype; | ||
// Public | ||
_proto.show = function show() { | ||
var _this = this; | ||
if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && this._element.classList.contains(CLASS_NAME_ACTIVE) || this._element.classList.contains(CLASS_NAME_DISABLED)) { | ||
show() { | ||
if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && this._element.classList.contains(CLASS_NAME_ACTIVE) || isDisabled(this._element)) { | ||
return; | ||
} | ||
var previous; | ||
var target = getElementFromSelector(this._element); | ||
let previous; | ||
const target = getElementFromSelector(this._element); | ||
var listElement = this._element.closest(SELECTOR_NAV_LIST_GROUP); | ||
const listElement = this._element.closest(SELECTOR_NAV_LIST_GROUP); | ||
if (listElement) { | ||
var itemSelector = listElement.nodeName === 'UL' || listElement.nodeName === 'OL' ? SELECTOR_ACTIVE_UL : SELECTOR_ACTIVE; | ||
const itemSelector = listElement.nodeName === 'UL' || listElement.nodeName === 'OL' ? SELECTOR_ACTIVE_UL : SELECTOR_ACTIVE; | ||
previous = SelectorEngine__default['default'].find(itemSelector, listElement); | ||
@@ -249,6 +230,6 @@ previous = previous[previous.length - 1]; | ||
var hideEvent = previous ? EventHandler__default['default'].trigger(previous, EVENT_HIDE, { | ||
const hideEvent = previous ? EventHandler__default['default'].trigger(previous, EVENT_HIDE, { | ||
relatedTarget: this._element | ||
}) : null; | ||
var showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW, { | ||
const showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW, { | ||
relatedTarget: previous | ||
@@ -263,7 +244,7 @@ }); | ||
var complete = function complete() { | ||
const complete = () => { | ||
EventHandler__default['default'].trigger(previous, EVENT_HIDDEN, { | ||
relatedTarget: _this._element | ||
relatedTarget: this._element | ||
}); | ||
EventHandler__default['default'].trigger(_this._element, EVENT_SHOWN, { | ||
EventHandler__default['default'].trigger(this._element, EVENT_SHOWN, { | ||
relatedTarget: previous | ||
@@ -279,17 +260,13 @@ }); | ||
} // Private | ||
; | ||
_proto._activate = function _activate(element, container, callback) { | ||
var _this2 = this; | ||
var activeElements = container && (container.nodeName === 'UL' || container.nodeName === 'OL') ? SelectorEngine__default['default'].find(SELECTOR_ACTIVE_UL, container) : SelectorEngine__default['default'].children(container, SELECTOR_ACTIVE); | ||
var active = activeElements[0]; | ||
var isTransitioning = callback && active && active.classList.contains(CLASS_NAME_FADE); | ||
_activate(element, container, callback) { | ||
const activeElements = container && (container.nodeName === 'UL' || container.nodeName === 'OL') ? SelectorEngine__default['default'].find(SELECTOR_ACTIVE_UL, container) : SelectorEngine__default['default'].children(container, SELECTOR_ACTIVE); | ||
const active = activeElements[0]; | ||
const isTransitioning = callback && active && active.classList.contains(CLASS_NAME_FADE); | ||
var complete = function complete() { | ||
return _this2._transitionComplete(element, active, callback); | ||
}; | ||
const complete = () => this._transitionComplete(element, active, callback); | ||
if (active && isTransitioning) { | ||
var transitionDuration = getTransitionDurationFromElement(active); | ||
const transitionDuration = getTransitionDurationFromElement(active); | ||
active.classList.remove(CLASS_NAME_SHOW); | ||
@@ -301,8 +278,8 @@ EventHandler__default['default'].one(active, 'transitionend', complete); | ||
} | ||
}; | ||
} | ||
_proto._transitionComplete = function _transitionComplete(element, active, callback) { | ||
_transitionComplete(element, active, callback) { | ||
if (active) { | ||
active.classList.remove(CLASS_NAME_ACTIVE); | ||
var dropdownChild = SelectorEngine__default['default'].findOne(SELECTOR_DROPDOWN_ACTIVE_CHILD, active.parentNode); | ||
const dropdownChild = SelectorEngine__default['default'].findOne(SELECTOR_DROPDOWN_ACTIVE_CHILD, active.parentNode); | ||
@@ -331,8 +308,6 @@ if (dropdownChild) { | ||
if (element.parentNode && element.parentNode.classList.contains(CLASS_NAME_DROPDOWN_MENU)) { | ||
var dropdownElement = element.closest(SELECTOR_DROPDOWN); | ||
const dropdownElement = element.closest(SELECTOR_DROPDOWN); | ||
if (dropdownElement) { | ||
SelectorEngine__default['default'].find(SELECTOR_DROPDOWN_TOGGLE).forEach(function (dropdown) { | ||
return dropdown.classList.add(CLASS_NAME_ACTIVE); | ||
}); | ||
SelectorEngine__default['default'].find(SELECTOR_DROPDOWN_TOGGLE).forEach(dropdown => dropdown.classList.add(CLASS_NAME_ACTIVE)); | ||
} | ||
@@ -347,11 +322,11 @@ | ||
} // Static | ||
; | ||
Tab.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY) || new Tab(this); | ||
const data = Data__default['default'].get(this, DATA_KEY) || new Tab(this); | ||
if (typeof config === 'string') { | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -362,14 +337,5 @@ | ||
}); | ||
}; | ||
} | ||
_createClass(Tab, null, [{ | ||
key: "DATA_KEY", | ||
get: // Getters | ||
function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Tab; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -384,3 +350,3 @@ * ------------------------------------------------------------------------ | ||
event.preventDefault(); | ||
var data = Data__default['default'].getData(this, DATA_KEY) || new Tab(this); | ||
const data = Data__default['default'].get(this, DATA_KEY) || new Tab(this); | ||
data.show(); | ||
@@ -387,0 +353,0 @@ }); |
/*! | ||
* Bootstrap toast.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap toast.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -19,64 +19,14 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MILLISECONDS_MULTIPLIER = 1000; | ||
var TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
const MILLISECONDS_MULTIPLIER = 1000; | ||
const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
var toType = function toType(obj) { | ||
const toType = obj => { | ||
if (obj === null || obj === undefined) { | ||
return "" + obj; | ||
return `${obj}`; | ||
} | ||
@@ -87,3 +37,3 @@ | ||
var getTransitionDurationFromElement = function getTransitionDurationFromElement(element) { | ||
const getTransitionDurationFromElement = element => { | ||
if (!element) { | ||
@@ -94,9 +44,9 @@ return 0; | ||
var _window$getComputedSt = window.getComputedStyle(element), | ||
transitionDuration = _window$getComputedSt.transitionDuration, | ||
transitionDelay = _window$getComputedSt.transitionDelay; | ||
let { | ||
transitionDuration, | ||
transitionDelay | ||
} = window.getComputedStyle(element); | ||
const floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
var floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
var floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
if (!floatTransitionDuration && !floatTransitionDelay) { | ||
@@ -112,14 +62,12 @@ return 0; | ||
var triggerTransitionEnd = function triggerTransitionEnd(element) { | ||
const triggerTransitionEnd = element => { | ||
element.dispatchEvent(new Event(TRANSITION_END)); | ||
}; | ||
var isElement = function isElement(obj) { | ||
return (obj[0] || obj).nodeType; | ||
}; | ||
const isElement = obj => (obj[0] || obj).nodeType; | ||
var emulateTransitionEnd = function emulateTransitionEnd(element, duration) { | ||
var called = false; | ||
var durationPadding = 5; | ||
var emulatedDuration = duration + durationPadding; | ||
const emulateTransitionEnd = (element, duration) => { | ||
let called = false; | ||
const durationPadding = 5; | ||
const emulatedDuration = duration + durationPadding; | ||
@@ -132,3 +80,3 @@ function listener() { | ||
element.addEventListener(TRANSITION_END, listener); | ||
setTimeout(function () { | ||
setTimeout(() => { | ||
if (!called) { | ||
@@ -140,10 +88,10 @@ triggerTransitionEnd(element); | ||
var typeCheckConfig = function typeCheckConfig(componentName, config, configTypes) { | ||
Object.keys(configTypes).forEach(function (property) { | ||
var expectedTypes = configTypes[property]; | ||
var value = config[property]; | ||
var valueType = value && isElement(value) ? 'element' : toType(value); | ||
const typeCheckConfig = (componentName, config, configTypes) => { | ||
Object.keys(configTypes).forEach(property => { | ||
const expectedTypes = configTypes[property]; | ||
const value = config[property]; | ||
const valueType = value && isElement(value) ? 'element' : toType(value); | ||
if (!new RegExp(expectedTypes).test(valueType)) { | ||
throw new TypeError(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); | ||
throw new TypeError(`${componentName.toUpperCase()}: ` + `Option "${property}" provided type "${valueType}" ` + `but expected type "${expectedTypes}".`); | ||
} | ||
@@ -153,9 +101,8 @@ }); | ||
var reflow = function reflow(element) { | ||
return element.offsetHeight; | ||
}; | ||
const reflow = element => element.offsetHeight; | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -169,3 +116,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -178,15 +125,13 @@ document.addEventListener('DOMContentLoaded', callback); | ||
document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -200,2 +145,8 @@ return plugin.jQueryInterface; | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): toast.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -206,15 +157,15 @@ * Constants | ||
var NAME = 'toast'; | ||
var DATA_KEY = 'bs.toast'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var EVENT_CLICK_DISMISS = "click.dismiss" + EVENT_KEY; | ||
var EVENT_HIDE = "hide" + EVENT_KEY; | ||
var EVENT_HIDDEN = "hidden" + EVENT_KEY; | ||
var EVENT_SHOW = "show" + EVENT_KEY; | ||
var EVENT_SHOWN = "shown" + EVENT_KEY; | ||
var CLASS_NAME_FADE = 'fade'; | ||
var CLASS_NAME_HIDE = 'hide'; | ||
var CLASS_NAME_SHOW = 'show'; | ||
var CLASS_NAME_SHOWING = 'showing'; | ||
var DefaultType = { | ||
const NAME = 'toast'; | ||
const DATA_KEY = 'bs.toast'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const EVENT_CLICK_DISMISS = `click.dismiss${EVENT_KEY}`; | ||
const EVENT_HIDE = `hide${EVENT_KEY}`; | ||
const EVENT_HIDDEN = `hidden${EVENT_KEY}`; | ||
const EVENT_SHOW = `show${EVENT_KEY}`; | ||
const EVENT_SHOWN = `shown${EVENT_KEY}`; | ||
const CLASS_NAME_FADE = 'fade'; | ||
const CLASS_NAME_HIDE = 'hide'; | ||
const CLASS_NAME_SHOW = 'show'; | ||
const CLASS_NAME_SHOWING = 'showing'; | ||
const DefaultType = { | ||
animation: 'boolean', | ||
@@ -224,3 +175,3 @@ autohide: 'boolean', | ||
}; | ||
var Default = { | ||
const Default = { | ||
animation: true, | ||
@@ -230,3 +181,3 @@ autohide: true, | ||
}; | ||
var SELECTOR_DATA_DISMISS = '[data-bs-dismiss="toast"]'; | ||
const SELECTOR_DATA_DISMISS = '[data-bs-dismiss="toast"]'; | ||
/** | ||
@@ -238,26 +189,28 @@ * ------------------------------------------------------------------------ | ||
var Toast = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Toast, _BaseComponent); | ||
class Toast extends BaseComponent__default['default'] { | ||
constructor(element, config) { | ||
super(element); | ||
this._config = this._getConfig(config); | ||
this._timeout = null; | ||
function Toast(element, config) { | ||
var _this; | ||
this._setListeners(); | ||
} // Getters | ||
_this = _BaseComponent.call(this, element) || this; | ||
_this._config = _this._getConfig(config); | ||
_this._timeout = null; | ||
_this._setListeners(); | ||
static get DefaultType() { | ||
return DefaultType; | ||
} | ||
return _this; | ||
} // Getters | ||
static get Default() { | ||
return Default; | ||
} | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} // Public | ||
var _proto = Toast.prototype; | ||
// Public | ||
_proto.show = function show() { | ||
var _this2 = this; | ||
show() { | ||
const showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW); | ||
var showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW); | ||
if (showEvent.defaultPrevented) { | ||
@@ -273,13 +226,13 @@ return; | ||
var complete = function complete() { | ||
_this2._element.classList.remove(CLASS_NAME_SHOWING); | ||
const complete = () => { | ||
this._element.classList.remove(CLASS_NAME_SHOWING); | ||
_this2._element.classList.add(CLASS_NAME_SHOW); | ||
this._element.classList.add(CLASS_NAME_SHOW); | ||
EventHandler__default['default'].trigger(_this2._element, EVENT_SHOWN); | ||
EventHandler__default['default'].trigger(this._element, EVENT_SHOWN); | ||
if (_this2._config.autohide) { | ||
_this2._timeout = setTimeout(function () { | ||
_this2.hide(); | ||
}, _this2._config.delay); | ||
if (this._config.autohide) { | ||
this._timeout = setTimeout(() => { | ||
this.hide(); | ||
}, this._config.delay); | ||
} | ||
@@ -295,3 +248,3 @@ }; | ||
if (this._config.animation) { | ||
var transitionDuration = getTransitionDurationFromElement(this._element); | ||
const transitionDuration = getTransitionDurationFromElement(this._element); | ||
EventHandler__default['default'].one(this._element, 'transitionend', complete); | ||
@@ -302,7 +255,5 @@ emulateTransitionEnd(this._element, transitionDuration); | ||
} | ||
}; | ||
} | ||
_proto.hide = function hide() { | ||
var _this3 = this; | ||
hide() { | ||
if (!this._element.classList.contains(CLASS_NAME_SHOW)) { | ||
@@ -312,3 +263,3 @@ return; | ||
var hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE); | ||
const hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE); | ||
@@ -319,6 +270,6 @@ if (hideEvent.defaultPrevented) { | ||
var complete = function complete() { | ||
_this3._element.classList.add(CLASS_NAME_HIDE); | ||
const complete = () => { | ||
this._element.classList.add(CLASS_NAME_HIDE); | ||
EventHandler__default['default'].trigger(_this3._element, EVENT_HIDDEN); | ||
EventHandler__default['default'].trigger(this._element, EVENT_HIDDEN); | ||
}; | ||
@@ -329,3 +280,3 @@ | ||
if (this._config.animation) { | ||
var transitionDuration = getTransitionDurationFromElement(this._element); | ||
const transitionDuration = getTransitionDurationFromElement(this._element); | ||
EventHandler__default['default'].one(this._element, 'transitionend', complete); | ||
@@ -336,5 +287,5 @@ emulateTransitionEnd(this._element, transitionDuration); | ||
} | ||
}; | ||
} | ||
_proto.dispose = function dispose() { | ||
dispose() { | ||
this._clearTimeout(); | ||
@@ -347,34 +298,31 @@ | ||
EventHandler__default['default'].off(this._element, EVENT_CLICK_DISMISS); | ||
_BaseComponent.prototype.dispose.call(this); | ||
super.dispose(); | ||
this._config = null; | ||
} // Private | ||
; | ||
_proto._getConfig = function _getConfig(config) { | ||
config = _extends({}, Default, Manipulator__default['default'].getDataAttributes(this._element), typeof config === 'object' && config ? config : {}); | ||
_getConfig(config) { | ||
config = { ...Default, | ||
...Manipulator__default['default'].getDataAttributes(this._element), | ||
...(typeof config === 'object' && config ? config : {}) | ||
}; | ||
typeCheckConfig(NAME, config, this.constructor.DefaultType); | ||
return config; | ||
}; | ||
} | ||
_proto._setListeners = function _setListeners() { | ||
var _this4 = this; | ||
_setListeners() { | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK_DISMISS, SELECTOR_DATA_DISMISS, () => this.hide()); | ||
} | ||
EventHandler__default['default'].on(this._element, EVENT_CLICK_DISMISS, SELECTOR_DATA_DISMISS, function () { | ||
return _this4.hide(); | ||
}); | ||
}; | ||
_proto._clearTimeout = function _clearTimeout() { | ||
_clearTimeout() { | ||
clearTimeout(this._timeout); | ||
this._timeout = null; | ||
} // Static | ||
; | ||
Toast.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY); | ||
let data = Data__default['default'].get(this, DATA_KEY); | ||
var _config = typeof config === 'object' && config; | ||
const _config = typeof config === 'object' && config; | ||
@@ -387,3 +335,3 @@ if (!data) { | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -394,23 +342,5 @@ | ||
}); | ||
}; | ||
} | ||
_createClass(Toast, null, [{ | ||
key: "DefaultType", | ||
get: function get() { | ||
return DefaultType; | ||
} | ||
}, { | ||
key: "Default", | ||
get: function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}]); | ||
return Toast; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -417,0 +347,0 @@ * ------------------------------------------------------------------------ |
/*! | ||
* Bootstrap tooltip.js v5.0.0-beta2 (https://getbootstrap.com/) | ||
* Bootstrap tooltip.js v5.0.0-beta3 (https://getbootstrap.com/) | ||
* Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) | ||
@@ -41,65 +41,15 @@ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
function _defineProperties(target, props) { | ||
for (var i = 0; i < props.length; i++) { | ||
var descriptor = props[i]; | ||
descriptor.enumerable = descriptor.enumerable || false; | ||
descriptor.configurable = true; | ||
if ("value" in descriptor) descriptor.writable = true; | ||
Object.defineProperty(target, descriptor.key, descriptor); | ||
} | ||
} | ||
function _createClass(Constructor, protoProps, staticProps) { | ||
if (protoProps) _defineProperties(Constructor.prototype, protoProps); | ||
if (staticProps) _defineProperties(Constructor, staticProps); | ||
return Constructor; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
function _inheritsLoose(subClass, superClass) { | ||
subClass.prototype = Object.create(superClass.prototype); | ||
subClass.prototype.constructor = subClass; | ||
_setPrototypeOf(subClass, superClass); | ||
} | ||
function _setPrototypeOf(o, p) { | ||
_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { | ||
o.__proto__ = p; | ||
return o; | ||
}; | ||
return _setPrototypeOf(o, p); | ||
} | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var MAX_UID = 1000000; | ||
var MILLISECONDS_MULTIPLIER = 1000; | ||
var TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
const MAX_UID = 1000000; | ||
const MILLISECONDS_MULTIPLIER = 1000; | ||
const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp) | ||
var toType = function toType(obj) { | ||
const toType = obj => { | ||
if (obj === null || obj === undefined) { | ||
return "" + obj; | ||
return `${obj}`; | ||
} | ||
@@ -116,3 +66,3 @@ | ||
var getUID = function getUID(prefix) { | ||
const getUID = prefix => { | ||
do { | ||
@@ -125,3 +75,3 @@ prefix += Math.floor(Math.random() * MAX_UID); | ||
var getTransitionDurationFromElement = function getTransitionDurationFromElement(element) { | ||
const getTransitionDurationFromElement = element => { | ||
if (!element) { | ||
@@ -132,9 +82,9 @@ return 0; | ||
var _window$getComputedSt = window.getComputedStyle(element), | ||
transitionDuration = _window$getComputedSt.transitionDuration, | ||
transitionDelay = _window$getComputedSt.transitionDelay; | ||
let { | ||
transitionDuration, | ||
transitionDelay | ||
} = window.getComputedStyle(element); | ||
const floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
var floatTransitionDuration = Number.parseFloat(transitionDuration); | ||
var floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found | ||
if (!floatTransitionDuration && !floatTransitionDelay) { | ||
@@ -150,14 +100,12 @@ return 0; | ||
var triggerTransitionEnd = function triggerTransitionEnd(element) { | ||
const triggerTransitionEnd = element => { | ||
element.dispatchEvent(new Event(TRANSITION_END)); | ||
}; | ||
var isElement = function isElement(obj) { | ||
return (obj[0] || obj).nodeType; | ||
}; | ||
const isElement = obj => (obj[0] || obj).nodeType; | ||
var emulateTransitionEnd = function emulateTransitionEnd(element, duration) { | ||
var called = false; | ||
var durationPadding = 5; | ||
var emulatedDuration = duration + durationPadding; | ||
const emulateTransitionEnd = (element, duration) => { | ||
let called = false; | ||
const durationPadding = 5; | ||
const emulatedDuration = duration + durationPadding; | ||
@@ -170,3 +118,3 @@ function listener() { | ||
element.addEventListener(TRANSITION_END, listener); | ||
setTimeout(function () { | ||
setTimeout(() => { | ||
if (!called) { | ||
@@ -178,10 +126,10 @@ triggerTransitionEnd(element); | ||
var typeCheckConfig = function typeCheckConfig(componentName, config, configTypes) { | ||
Object.keys(configTypes).forEach(function (property) { | ||
var expectedTypes = configTypes[property]; | ||
var value = config[property]; | ||
var valueType = value && isElement(value) ? 'element' : toType(value); | ||
const typeCheckConfig = (componentName, config, configTypes) => { | ||
Object.keys(configTypes).forEach(property => { | ||
const expectedTypes = configTypes[property]; | ||
const value = config[property]; | ||
const valueType = value && isElement(value) ? 'element' : toType(value); | ||
if (!new RegExp(expectedTypes).test(valueType)) { | ||
throw new TypeError(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); | ||
throw new TypeError(`${componentName.toUpperCase()}: ` + `Option "${property}" provided type "${valueType}" ` + `but expected type "${expectedTypes}".`); | ||
} | ||
@@ -191,3 +139,3 @@ }); | ||
var findShadowRoot = function findShadowRoot(element) { | ||
const findShadowRoot = element => { | ||
if (!document.documentElement.attachShadow) { | ||
@@ -199,3 +147,3 @@ return null; | ||
if (typeof element.getRootNode === 'function') { | ||
var root = element.getRootNode(); | ||
const root = element.getRootNode(); | ||
return root instanceof ShadowRoot ? root : null; | ||
@@ -216,9 +164,8 @@ } | ||
var noop = function noop() { | ||
return function () {}; | ||
}; | ||
const noop = () => function () {}; | ||
var getjQuery = function getjQuery() { | ||
var _window = window, | ||
jQuery = _window.jQuery; | ||
const getjQuery = () => { | ||
const { | ||
jQuery | ||
} = window; | ||
@@ -232,3 +179,3 @@ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { | ||
var onDOMContentLoaded = function onDOMContentLoaded(callback) { | ||
const onDOMContentLoaded = callback => { | ||
if (document.readyState === 'loading') { | ||
@@ -241,15 +188,15 @@ document.addEventListener('DOMContentLoaded', callback); | ||
var isRTL = document.documentElement.dir === 'rtl'; | ||
const isRTL = () => document.documentElement.dir === 'rtl'; | ||
var defineJQueryPlugin = function defineJQueryPlugin(name, plugin) { | ||
onDOMContentLoaded(function () { | ||
var $ = getjQuery(); | ||
const defineJQueryPlugin = (name, plugin) => { | ||
onDOMContentLoaded(() => { | ||
const $ = getjQuery(); | ||
/* istanbul ignore if */ | ||
if ($) { | ||
var JQUERY_NO_CONFLICT = $.fn[name]; | ||
const JQUERY_NO_CONFLICT = $.fn[name]; | ||
$.fn[name] = plugin.jQueryInterface; | ||
$.fn[name].Constructor = plugin; | ||
$.fn[name].noConflict = function () { | ||
$.fn[name].noConflict = () => { | ||
$.fn[name] = JQUERY_NO_CONFLICT; | ||
@@ -264,8 +211,8 @@ return plugin.jQueryInterface; | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/sanitizer.js | ||
* Bootstrap (v5.0.0-beta3): util/sanitizer.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
var uriAttrs = new Set(['background', 'cite', 'href', 'itemtype', 'longdesc', 'poster', 'src', 'xlink:href']); | ||
var ARIA_ATTRIBUTE_PATTERN = /^aria-[\w-]*$/i; | ||
const uriAttrs = new Set(['background', 'cite', 'href', 'itemtype', 'longdesc', 'poster', 'src', 'xlink:href']); | ||
const ARIA_ATTRIBUTE_PATTERN = /^aria-[\w-]*$/i; | ||
/** | ||
@@ -277,3 +224,3 @@ * A pattern that recognizes a commonly useful subset of URLs that are safe. | ||
var SAFE_URL_PATTERN = /^(?:(?:https?|mailto|ftp|tel|file):|[^#&/:?]*(?:[#/?]|$))/gi; | ||
const SAFE_URL_PATTERN = /^(?:(?:https?|mailto|ftp|tel|file):|[^#&/:?]*(?:[#/?]|$))/i; | ||
/** | ||
@@ -285,6 +232,6 @@ * A pattern that matches safe data URLs. Only matches image, video and audio types. | ||
var DATA_URL_PATTERN = /^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[\d+/a-z]+=*$/i; | ||
const DATA_URL_PATTERN = /^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[\d+/a-z]+=*$/i; | ||
var allowedAttribute = function allowedAttribute(attr, allowedAttributeList) { | ||
var attrName = attr.nodeName.toLowerCase(); | ||
const allowedAttribute = (attr, allowedAttributeList) => { | ||
const attrName = attr.nodeName.toLowerCase(); | ||
@@ -299,7 +246,5 @@ if (allowedAttributeList.includes(attrName)) { | ||
var regExp = allowedAttributeList.filter(function (attrRegex) { | ||
return attrRegex instanceof RegExp; | ||
}); // Check if a regular expression validates the attribute. | ||
const regExp = allowedAttributeList.filter(attrRegex => attrRegex instanceof RegExp); // Check if a regular expression validates the attribute. | ||
for (var i = 0, len = regExp.length; i < len; i++) { | ||
for (let i = 0, len = regExp.length; i < len; i++) { | ||
if (regExp[i].test(attrName)) { | ||
@@ -313,3 +258,3 @@ return true; | ||
var DefaultAllowlist = { | ||
const DefaultAllowlist = { | ||
// Global attributes allowed on any supplied element below. | ||
@@ -348,4 +293,2 @@ '*': ['class', 'dir', 'id', 'lang', 'role', ARIA_ATTRIBUTE_PATTERN], | ||
function sanitizeHtml(unsafeHtml, allowList, sanitizeFn) { | ||
var _ref; | ||
if (!unsafeHtml.length) { | ||
@@ -359,23 +302,19 @@ return unsafeHtml; | ||
var domParser = new window.DOMParser(); | ||
var createdDocument = domParser.parseFromString(unsafeHtml, 'text/html'); | ||
var allowlistKeys = Object.keys(allowList); | ||
const domParser = new window.DOMParser(); | ||
const createdDocument = domParser.parseFromString(unsafeHtml, 'text/html'); | ||
const allowlistKeys = Object.keys(allowList); | ||
const elements = [].concat(...createdDocument.body.querySelectorAll('*')); | ||
var elements = (_ref = []).concat.apply(_ref, createdDocument.body.querySelectorAll('*')); | ||
for (let i = 0, len = elements.length; i < len; i++) { | ||
const el = elements[i]; | ||
const elName = el.nodeName.toLowerCase(); | ||
var _loop = function _loop(i, len) { | ||
var _ref2; | ||
var el = elements[i]; | ||
var elName = el.nodeName.toLowerCase(); | ||
if (!allowlistKeys.includes(elName)) { | ||
el.parentNode.removeChild(el); | ||
return "continue"; | ||
continue; | ||
} | ||
var attributeList = (_ref2 = []).concat.apply(_ref2, el.attributes); | ||
var allowedAttributes = [].concat(allowList['*'] || [], allowList[elName] || []); | ||
attributeList.forEach(function (attr) { | ||
const attributeList = [].concat(...el.attributes); | ||
const allowedAttributes = [].concat(allowList['*'] || [], allowList[elName] || []); | ||
attributeList.forEach(attr => { | ||
if (!allowedAttribute(attr, allowedAttributes)) { | ||
@@ -385,8 +324,2 @@ el.removeAttribute(attr.nodeName); | ||
}); | ||
}; | ||
for (var i = 0, len = elements.length; i < len; i++) { | ||
var _ret = _loop(i); | ||
if (_ret === "continue") continue; | ||
} | ||
@@ -398,2 +331,8 @@ | ||
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta3): tooltip.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
* -------------------------------------------------------------------------- | ||
*/ | ||
/** | ||
* ------------------------------------------------------------------------ | ||
@@ -404,9 +343,9 @@ * Constants | ||
var NAME = 'tooltip'; | ||
var DATA_KEY = 'bs.tooltip'; | ||
var EVENT_KEY = "." + DATA_KEY; | ||
var CLASS_PREFIX = 'bs-tooltip'; | ||
var BSCLS_PREFIX_REGEX = new RegExp("(^|\\s)" + CLASS_PREFIX + "\\S+", 'g'); | ||
var DISALLOWED_ATTRIBUTES = new Set(['sanitize', 'allowList', 'sanitizeFn']); | ||
var DefaultType = { | ||
const NAME = 'tooltip'; | ||
const DATA_KEY = 'bs.tooltip'; | ||
const EVENT_KEY = `.${DATA_KEY}`; | ||
const CLASS_PREFIX = 'bs-tooltip'; | ||
const BSCLS_PREFIX_REGEX = new RegExp(`(^|\\s)${CLASS_PREFIX}\\S+`, 'g'); | ||
const DISALLOWED_ATTRIBUTES = new Set(['sanitize', 'allowList', 'sanitizeFn']); | ||
const DefaultType = { | ||
animation: 'boolean', | ||
@@ -430,10 +369,10 @@ template: 'string', | ||
}; | ||
var AttachmentMap = { | ||
const AttachmentMap = { | ||
AUTO: 'auto', | ||
TOP: 'top', | ||
RIGHT: isRTL ? 'left' : 'right', | ||
RIGHT: isRTL() ? 'left' : 'right', | ||
BOTTOM: 'bottom', | ||
LEFT: isRTL ? 'right' : 'left' | ||
LEFT: isRTL() ? 'right' : 'left' | ||
}; | ||
var Default = { | ||
const Default = { | ||
animation: true, | ||
@@ -457,24 +396,24 @@ template: '<div class="tooltip" role="tooltip">' + '<div class="tooltip-arrow"></div>' + '<div class="tooltip-inner"></div>' + '</div>', | ||
}; | ||
var Event$1 = { | ||
HIDE: "hide" + EVENT_KEY, | ||
HIDDEN: "hidden" + EVENT_KEY, | ||
SHOW: "show" + EVENT_KEY, | ||
SHOWN: "shown" + EVENT_KEY, | ||
INSERTED: "inserted" + EVENT_KEY, | ||
CLICK: "click" + EVENT_KEY, | ||
FOCUSIN: "focusin" + EVENT_KEY, | ||
FOCUSOUT: "focusout" + EVENT_KEY, | ||
MOUSEENTER: "mouseenter" + EVENT_KEY, | ||
MOUSELEAVE: "mouseleave" + EVENT_KEY | ||
const Event$1 = { | ||
HIDE: `hide${EVENT_KEY}`, | ||
HIDDEN: `hidden${EVENT_KEY}`, | ||
SHOW: `show${EVENT_KEY}`, | ||
SHOWN: `shown${EVENT_KEY}`, | ||
INSERTED: `inserted${EVENT_KEY}`, | ||
CLICK: `click${EVENT_KEY}`, | ||
FOCUSIN: `focusin${EVENT_KEY}`, | ||
FOCUSOUT: `focusout${EVENT_KEY}`, | ||
MOUSEENTER: `mouseenter${EVENT_KEY}`, | ||
MOUSELEAVE: `mouseleave${EVENT_KEY}` | ||
}; | ||
var CLASS_NAME_FADE = 'fade'; | ||
var CLASS_NAME_MODAL = 'modal'; | ||
var CLASS_NAME_SHOW = 'show'; | ||
var HOVER_STATE_SHOW = 'show'; | ||
var HOVER_STATE_OUT = 'out'; | ||
var SELECTOR_TOOLTIP_INNER = '.tooltip-inner'; | ||
var TRIGGER_HOVER = 'hover'; | ||
var TRIGGER_FOCUS = 'focus'; | ||
var TRIGGER_CLICK = 'click'; | ||
var TRIGGER_MANUAL = 'manual'; | ||
const CLASS_NAME_FADE = 'fade'; | ||
const CLASS_NAME_MODAL = 'modal'; | ||
const CLASS_NAME_SHOW = 'show'; | ||
const HOVER_STATE_SHOW = 'show'; | ||
const HOVER_STATE_OUT = 'out'; | ||
const SELECTOR_TOOLTIP_INNER = '.tooltip-inner'; | ||
const TRIGGER_HOVER = 'hover'; | ||
const TRIGGER_FOCUS = 'focus'; | ||
const TRIGGER_CLICK = 'click'; | ||
const TRIGGER_MANUAL = 'manual'; | ||
/** | ||
@@ -486,8 +425,4 @@ * ------------------------------------------------------------------------ | ||
var Tooltip = /*#__PURE__*/function (_BaseComponent) { | ||
_inheritsLoose(Tooltip, _BaseComponent); | ||
function Tooltip(element, config) { | ||
var _this; | ||
class Tooltip extends BaseComponent__default['default'] { | ||
constructor(element, config) { | ||
if (typeof Popper__namespace === 'undefined') { | ||
@@ -497,35 +432,55 @@ throw new TypeError('Bootstrap\'s tooltips require Popper (https://popper.js.org)'); | ||
_this = _BaseComponent.call(this, element) || this; // private | ||
super(element); // private | ||
_this._isEnabled = true; | ||
_this._timeout = 0; | ||
_this._hoverState = ''; | ||
_this._activeTrigger = {}; | ||
_this._popper = null; // Protected | ||
this._isEnabled = true; | ||
this._timeout = 0; | ||
this._hoverState = ''; | ||
this._activeTrigger = {}; | ||
this._popper = null; // Protected | ||
_this.config = _this._getConfig(config); | ||
_this.tip = null; | ||
this.config = this._getConfig(config); | ||
this.tip = null; | ||
_this._setListeners(); | ||
return _this; | ||
this._setListeners(); | ||
} // Getters | ||
var _proto = Tooltip.prototype; | ||
static get Default() { | ||
return Default; | ||
} | ||
// Public | ||
_proto.enable = function enable() { | ||
static get NAME() { | ||
return NAME; | ||
} | ||
static get DATA_KEY() { | ||
return DATA_KEY; | ||
} | ||
static get Event() { | ||
return Event$1; | ||
} | ||
static get EVENT_KEY() { | ||
return EVENT_KEY; | ||
} | ||
static get DefaultType() { | ||
return DefaultType; | ||
} // Public | ||
enable() { | ||
this._isEnabled = true; | ||
}; | ||
} | ||
_proto.disable = function disable() { | ||
disable() { | ||
this._isEnabled = false; | ||
}; | ||
} | ||
_proto.toggleEnabled = function toggleEnabled() { | ||
toggleEnabled() { | ||
this._isEnabled = !this._isEnabled; | ||
}; | ||
} | ||
_proto.toggle = function toggle(event) { | ||
toggle(event) { | ||
if (!this._isEnabled) { | ||
@@ -536,3 +491,3 @@ return; | ||
if (event) { | ||
var context = this._initializeOnDelegatedTarget(event); | ||
const context = this._initializeOnDelegatedTarget(event); | ||
@@ -555,8 +510,8 @@ context._activeTrigger.click = !context._activeTrigger.click; | ||
} | ||
}; | ||
} | ||
_proto.dispose = function dispose() { | ||
dispose() { | ||
clearTimeout(this._timeout); | ||
EventHandler__default['default'].off(this._element, this.constructor.EVENT_KEY); | ||
EventHandler__default['default'].off(this._element.closest("." + CLASS_NAME_MODAL), 'hide.bs.modal', this._hideModalHandler); | ||
EventHandler__default['default'].off(this._element.closest(`.${CLASS_NAME_MODAL}`), 'hide.bs.modal', this._hideModalHandler); | ||
@@ -579,9 +534,6 @@ if (this.tip && this.tip.parentNode) { | ||
this.tip = null; | ||
super.dispose(); | ||
} | ||
_BaseComponent.prototype.dispose.call(this); | ||
}; | ||
_proto.show = function show() { | ||
var _this2 = this; | ||
show() { | ||
if (this._element.style.display === 'none') { | ||
@@ -595,5 +547,5 @@ throw new Error('Please use show on visible elements'); | ||
var showEvent = EventHandler__default['default'].trigger(this._element, this.constructor.Event.SHOW); | ||
var shadowRoot = findShadowRoot(this._element); | ||
var isInTheDom = shadowRoot === null ? this._element.ownerDocument.documentElement.contains(this._element) : shadowRoot.contains(this._element); | ||
const showEvent = EventHandler__default['default'].trigger(this._element, this.constructor.Event.SHOW); | ||
const shadowRoot = findShadowRoot(this._element); | ||
const isInTheDom = shadowRoot === null ? this._element.ownerDocument.documentElement.contains(this._element) : shadowRoot.contains(this._element); | ||
@@ -604,4 +556,4 @@ if (showEvent.defaultPrevented || !isInTheDom) { | ||
var tip = this.getTipElement(); | ||
var tipId = getUID(this.constructor.NAME); | ||
const tip = this.getTipElement(); | ||
const tipId = getUID(this.constructor.NAME); | ||
tip.setAttribute('id', tipId); | ||
@@ -617,25 +569,28 @@ | ||
var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this._element) : this.config.placement; | ||
const placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this._element) : this.config.placement; | ||
var attachment = this._getAttachment(placement); | ||
const attachment = this._getAttachment(placement); | ||
this._addAttachmentClass(attachment); | ||
var container = this._getContainer(); | ||
const container = this._getContainer(); | ||
Data__default['default'].setData(tip, this.constructor.DATA_KEY, this); | ||
Data__default['default'].set(tip, this.constructor.DATA_KEY, this); | ||
if (!this._element.ownerDocument.documentElement.contains(this.tip)) { | ||
container.appendChild(tip); | ||
EventHandler__default['default'].trigger(this._element, this.constructor.Event.INSERTED); | ||
} | ||
EventHandler__default['default'].trigger(this._element, this.constructor.Event.INSERTED); | ||
this._popper = Popper.createPopper(this._element, tip, this._getPopperConfig(attachment)); | ||
if (this._popper) { | ||
this._popper.update(); | ||
} else { | ||
this._popper = Popper__namespace.createPopper(this._element, tip, this._getPopperConfig(attachment)); | ||
} | ||
tip.classList.add(CLASS_NAME_SHOW); | ||
var customClass = typeof this.config.customClass === 'function' ? this.config.customClass() : this.config.customClass; | ||
const customClass = typeof this.config.customClass === 'function' ? this.config.customClass() : this.config.customClass; | ||
if (customClass) { | ||
var _tip$classList; | ||
(_tip$classList = tip.classList).add.apply(_tip$classList, customClass.split(' ')); | ||
tip.classList.add(...customClass.split(' ')); | ||
} // If this is a touch-enabled device we add extra | ||
@@ -648,5 +603,3 @@ // empty mouseover listeners to the body's immediate children; | ||
if ('ontouchstart' in document.documentElement) { | ||
var _ref; | ||
(_ref = []).concat.apply(_ref, document.body.children).forEach(function (element) { | ||
[].concat(...document.body.children).forEach(element => { | ||
EventHandler__default['default'].on(element, 'mouseover', noop()); | ||
@@ -656,9 +609,9 @@ }); | ||
var complete = function complete() { | ||
var prevHoverState = _this2._hoverState; | ||
_this2._hoverState = null; | ||
EventHandler__default['default'].trigger(_this2._element, _this2.constructor.Event.SHOWN); | ||
const complete = () => { | ||
const prevHoverState = this._hoverState; | ||
this._hoverState = null; | ||
EventHandler__default['default'].trigger(this._element, this.constructor.Event.SHOWN); | ||
if (prevHoverState === HOVER_STATE_OUT) { | ||
_this2._leave(null, _this2); | ||
this._leave(null, this); | ||
} | ||
@@ -668,3 +621,3 @@ }; | ||
if (this.tip.classList.contains(CLASS_NAME_FADE)) { | ||
var transitionDuration = getTransitionDurationFromElement(this.tip); | ||
const transitionDuration = getTransitionDurationFromElement(this.tip); | ||
EventHandler__default['default'].one(this.tip, 'transitionend', complete); | ||
@@ -675,7 +628,5 @@ emulateTransitionEnd(this.tip, transitionDuration); | ||
} | ||
}; | ||
} | ||
_proto.hide = function hide() { | ||
var _this3 = this; | ||
hide() { | ||
if (!this._popper) { | ||
@@ -685,23 +636,27 @@ return; | ||
var tip = this.getTipElement(); | ||
const tip = this.getTipElement(); | ||
var complete = function complete() { | ||
if (_this3._hoverState !== HOVER_STATE_SHOW && tip.parentNode) { | ||
const complete = () => { | ||
if (this._isWithActiveTrigger()) { | ||
return; | ||
} | ||
if (this._hoverState !== HOVER_STATE_SHOW && tip.parentNode) { | ||
tip.parentNode.removeChild(tip); | ||
} | ||
_this3._cleanTipClass(); | ||
this._cleanTipClass(); | ||
_this3._element.removeAttribute('aria-describedby'); | ||
this._element.removeAttribute('aria-describedby'); | ||
EventHandler__default['default'].trigger(_this3._element, _this3.constructor.Event.HIDDEN); | ||
EventHandler__default['default'].trigger(this._element, this.constructor.Event.HIDDEN); | ||
if (_this3._popper) { | ||
_this3._popper.destroy(); | ||
if (this._popper) { | ||
this._popper.destroy(); | ||
_this3._popper = null; | ||
this._popper = null; | ||
} | ||
}; | ||
var hideEvent = EventHandler__default['default'].trigger(this._element, this.constructor.Event.HIDE); | ||
const hideEvent = EventHandler__default['default'].trigger(this._element, this.constructor.Event.HIDE); | ||
@@ -716,7 +671,3 @@ if (hideEvent.defaultPrevented) { | ||
if ('ontouchstart' in document.documentElement) { | ||
var _ref2; | ||
(_ref2 = []).concat.apply(_ref2, document.body.children).forEach(function (element) { | ||
return EventHandler__default['default'].off(element, 'mouseover', noop); | ||
}); | ||
[].concat(...document.body.children).forEach(element => EventHandler__default['default'].off(element, 'mouseover', noop)); | ||
} | ||
@@ -729,3 +680,3 @@ | ||
if (this.tip.classList.contains(CLASS_NAME_FADE)) { | ||
var transitionDuration = getTransitionDurationFromElement(tip); | ||
const transitionDuration = getTransitionDurationFromElement(tip); | ||
EventHandler__default['default'].one(tip, 'transitionend', complete); | ||
@@ -738,5 +689,5 @@ emulateTransitionEnd(tip, transitionDuration); | ||
this._hoverState = ''; | ||
}; | ||
} | ||
_proto.update = function update() { | ||
update() { | ||
if (this._popper !== null) { | ||
@@ -746,9 +697,9 @@ this._popper.update(); | ||
} // Protected | ||
; | ||
_proto.isWithContent = function isWithContent() { | ||
isWithContent() { | ||
return Boolean(this.getTitle()); | ||
}; | ||
} | ||
_proto.getTipElement = function getTipElement() { | ||
getTipElement() { | ||
if (this.tip) { | ||
@@ -758,15 +709,15 @@ return this.tip; | ||
var element = document.createElement('div'); | ||
const element = document.createElement('div'); | ||
element.innerHTML = this.config.template; | ||
this.tip = element.children[0]; | ||
return this.tip; | ||
}; | ||
} | ||
_proto.setContent = function setContent() { | ||
var tip = this.getTipElement(); | ||
setContent() { | ||
const tip = this.getTipElement(); | ||
this.setElementContent(SelectorEngine__default['default'].findOne(SELECTOR_TOOLTIP_INNER, tip), this.getTitle()); | ||
tip.classList.remove(CLASS_NAME_FADE, CLASS_NAME_SHOW); | ||
}; | ||
} | ||
_proto.setElementContent = function setElementContent(element, content) { | ||
setElementContent(element, content) { | ||
if (element === null) { | ||
@@ -803,6 +754,6 @@ return; | ||
} | ||
}; | ||
} | ||
_proto.getTitle = function getTitle() { | ||
var title = this._element.getAttribute('data-bs-original-title'); | ||
getTitle() { | ||
let title = this._element.getAttribute('data-bs-original-title'); | ||
@@ -814,5 +765,5 @@ if (!title) { | ||
return title; | ||
}; | ||
} | ||
_proto.updateAttachment = function updateAttachment(attachment) { | ||
updateAttachment(attachment) { | ||
if (attachment === 'right') { | ||
@@ -828,40 +779,34 @@ return 'end'; | ||
} // Private | ||
; | ||
_proto._initializeOnDelegatedTarget = function _initializeOnDelegatedTarget(event, context) { | ||
var dataKey = this.constructor.DATA_KEY; | ||
context = context || Data__default['default'].getData(event.delegateTarget, dataKey); | ||
_initializeOnDelegatedTarget(event, context) { | ||
const dataKey = this.constructor.DATA_KEY; | ||
context = context || Data__default['default'].get(event.delegateTarget, dataKey); | ||
if (!context) { | ||
context = new this.constructor(event.delegateTarget, this._getDelegateConfig()); | ||
Data__default['default'].setData(event.delegateTarget, dataKey, context); | ||
Data__default['default'].set(event.delegateTarget, dataKey, context); | ||
} | ||
return context; | ||
}; | ||
} | ||
_proto._getOffset = function _getOffset() { | ||
var _this4 = this; | ||
_getOffset() { | ||
const { | ||
offset | ||
} = this.config; | ||
var offset = this.config.offset; | ||
if (typeof offset === 'string') { | ||
return offset.split(',').map(function (val) { | ||
return Number.parseInt(val, 10); | ||
}); | ||
return offset.split(',').map(val => Number.parseInt(val, 10)); | ||
} | ||
if (typeof offset === 'function') { | ||
return function (popperData) { | ||
return offset(popperData, _this4._element); | ||
}; | ||
return popperData => offset(popperData, this._element); | ||
} | ||
return offset; | ||
}; | ||
} | ||
_proto._getPopperConfig = function _getPopperConfig(attachment) { | ||
var _this5 = this; | ||
var defaultBsPopperConfig = { | ||
_getPopperConfig(attachment) { | ||
const defaultBsPopperConfig = { | ||
placement: attachment, | ||
@@ -887,3 +832,3 @@ modifiers: [{ | ||
options: { | ||
element: "." + this.constructor.NAME + "-arrow" | ||
element: `.${this.constructor.NAME}-arrow` | ||
} | ||
@@ -894,20 +839,20 @@ }, { | ||
phase: 'afterWrite', | ||
fn: function fn(data) { | ||
return _this5._handlePopperPlacementChange(data); | ||
} | ||
fn: data => this._handlePopperPlacementChange(data) | ||
}], | ||
onFirstUpdate: function onFirstUpdate(data) { | ||
onFirstUpdate: data => { | ||
if (data.options.placement !== data.placement) { | ||
_this5._handlePopperPlacementChange(data); | ||
this._handlePopperPlacementChange(data); | ||
} | ||
} | ||
}; | ||
return _extends({}, defaultBsPopperConfig, typeof this.config.popperConfig === 'function' ? this.config.popperConfig(defaultBsPopperConfig) : this.config.popperConfig); | ||
}; | ||
return { ...defaultBsPopperConfig, | ||
...(typeof this.config.popperConfig === 'function' ? this.config.popperConfig(defaultBsPopperConfig) : this.config.popperConfig) | ||
}; | ||
} | ||
_proto._addAttachmentClass = function _addAttachmentClass(attachment) { | ||
this.getTipElement().classList.add(CLASS_PREFIX + "-" + this.updateAttachment(attachment)); | ||
}; | ||
_addAttachmentClass(attachment) { | ||
this.getTipElement().classList.add(`${CLASS_PREFIX}-${this.updateAttachment(attachment)}`); | ||
} | ||
_proto._getContainer = function _getContainer() { | ||
_getContainer() { | ||
if (this.config.container === false) { | ||
@@ -922,51 +867,43 @@ return document.body; | ||
return SelectorEngine__default['default'].findOne(this.config.container); | ||
}; | ||
} | ||
_proto._getAttachment = function _getAttachment(placement) { | ||
_getAttachment(placement) { | ||
return AttachmentMap[placement.toUpperCase()]; | ||
}; | ||
} | ||
_proto._setListeners = function _setListeners() { | ||
var _this6 = this; | ||
var triggers = this.config.trigger.split(' '); | ||
triggers.forEach(function (trigger) { | ||
_setListeners() { | ||
const triggers = this.config.trigger.split(' '); | ||
triggers.forEach(trigger => { | ||
if (trigger === 'click') { | ||
EventHandler__default['default'].on(_this6._element, _this6.constructor.Event.CLICK, _this6.config.selector, function (event) { | ||
return _this6.toggle(event); | ||
}); | ||
EventHandler__default['default'].on(this._element, this.constructor.Event.CLICK, this.config.selector, event => this.toggle(event)); | ||
} else if (trigger !== TRIGGER_MANUAL) { | ||
var eventIn = trigger === TRIGGER_HOVER ? _this6.constructor.Event.MOUSEENTER : _this6.constructor.Event.FOCUSIN; | ||
var eventOut = trigger === TRIGGER_HOVER ? _this6.constructor.Event.MOUSELEAVE : _this6.constructor.Event.FOCUSOUT; | ||
EventHandler__default['default'].on(_this6._element, eventIn, _this6.config.selector, function (event) { | ||
return _this6._enter(event); | ||
}); | ||
EventHandler__default['default'].on(_this6._element, eventOut, _this6.config.selector, function (event) { | ||
return _this6._leave(event); | ||
}); | ||
const eventIn = trigger === TRIGGER_HOVER ? this.constructor.Event.MOUSEENTER : this.constructor.Event.FOCUSIN; | ||
const eventOut = trigger === TRIGGER_HOVER ? this.constructor.Event.MOUSELEAVE : this.constructor.Event.FOCUSOUT; | ||
EventHandler__default['default'].on(this._element, eventIn, this.config.selector, event => this._enter(event)); | ||
EventHandler__default['default'].on(this._element, eventOut, this.config.selector, event => this._leave(event)); | ||
} | ||
}); | ||
this._hideModalHandler = function () { | ||
if (_this6._element) { | ||
_this6.hide(); | ||
this._hideModalHandler = () => { | ||
if (this._element) { | ||
this.hide(); | ||
} | ||
}; | ||
EventHandler__default['default'].on(this._element.closest("." + CLASS_NAME_MODAL), 'hide.bs.modal', this._hideModalHandler); | ||
EventHandler__default['default'].on(this._element.closest(`.${CLASS_NAME_MODAL}`), 'hide.bs.modal', this._hideModalHandler); | ||
if (this.config.selector) { | ||
this.config = _extends({}, this.config, { | ||
this.config = { ...this.config, | ||
trigger: 'manual', | ||
selector: '' | ||
}); | ||
}; | ||
} else { | ||
this._fixTitle(); | ||
} | ||
}; | ||
} | ||
_proto._fixTitle = function _fixTitle() { | ||
var title = this._element.getAttribute('title'); | ||
_fixTitle() { | ||
const title = this._element.getAttribute('title'); | ||
var originalTitleType = typeof this._element.getAttribute('data-bs-original-title'); | ||
const originalTitleType = typeof this._element.getAttribute('data-bs-original-title'); | ||
@@ -982,5 +919,5 @@ if (title || originalTitleType !== 'string') { | ||
} | ||
}; | ||
} | ||
_proto._enter = function _enter(event, context) { | ||
_enter(event, context) { | ||
context = this._initializeOnDelegatedTarget(event, context); | ||
@@ -1005,3 +942,3 @@ | ||
context._timeout = setTimeout(function () { | ||
context._timeout = setTimeout(() => { | ||
if (context._hoverState === HOVER_STATE_SHOW) { | ||
@@ -1011,9 +948,9 @@ context.show(); | ||
}, context.config.delay.show); | ||
}; | ||
} | ||
_proto._leave = function _leave(event, context) { | ||
_leave(event, context) { | ||
context = this._initializeOnDelegatedTarget(event, context); | ||
if (event) { | ||
context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] = false; | ||
context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] = context._element.contains(event.relatedTarget); | ||
} | ||
@@ -1033,3 +970,3 @@ | ||
context._timeout = setTimeout(function () { | ||
context._timeout = setTimeout(() => { | ||
if (context._hoverState === HOVER_STATE_OUT) { | ||
@@ -1039,6 +976,6 @@ context.hide(); | ||
}, context.config.delay.hide); | ||
}; | ||
} | ||
_proto._isWithActiveTrigger = function _isWithActiveTrigger() { | ||
for (var trigger in this._activeTrigger) { | ||
_isWithActiveTrigger() { | ||
for (const trigger in this._activeTrigger) { | ||
if (this._activeTrigger[trigger]) { | ||
@@ -1050,7 +987,7 @@ return true; | ||
return false; | ||
}; | ||
} | ||
_proto._getConfig = function _getConfig(config) { | ||
var dataAttributes = Manipulator__default['default'].getDataAttributes(this._element); | ||
Object.keys(dataAttributes).forEach(function (dataAttr) { | ||
_getConfig(config) { | ||
const dataAttributes = Manipulator__default['default'].getDataAttributes(this._element); | ||
Object.keys(dataAttributes).forEach(dataAttr => { | ||
if (DISALLOWED_ATTRIBUTES.has(dataAttr)) { | ||
@@ -1065,3 +1002,6 @@ delete dataAttributes[dataAttr]; | ||
config = _extends({}, this.constructor.Default, dataAttributes, typeof config === 'object' && config ? config : {}); | ||
config = { ...this.constructor.Default, | ||
...dataAttributes, | ||
...(typeof config === 'object' && config ? config : {}) | ||
}; | ||
@@ -1090,9 +1030,9 @@ if (typeof config.delay === 'number') { | ||
return config; | ||
}; | ||
} | ||
_proto._getDelegateConfig = function _getDelegateConfig() { | ||
var config = {}; | ||
_getDelegateConfig() { | ||
const config = {}; | ||
if (this.config) { | ||
for (var key in this.config) { | ||
for (const key in this.config) { | ||
if (this.constructor.Default[key] !== this.config[key]) { | ||
@@ -1105,19 +1045,17 @@ config[key] = this.config[key]; | ||
return config; | ||
}; | ||
} | ||
_proto._cleanTipClass = function _cleanTipClass() { | ||
var tip = this.getTipElement(); | ||
var tabClass = tip.getAttribute('class').match(BSCLS_PREFIX_REGEX); | ||
_cleanTipClass() { | ||
const tip = this.getTipElement(); | ||
const tabClass = tip.getAttribute('class').match(BSCLS_PREFIX_REGEX); | ||
if (tabClass !== null && tabClass.length > 0) { | ||
tabClass.map(function (token) { | ||
return token.trim(); | ||
}).forEach(function (tClass) { | ||
return tip.classList.remove(tClass); | ||
}); | ||
tabClass.map(token => token.trim()).forEach(tClass => tip.classList.remove(tClass)); | ||
} | ||
}; | ||
} | ||
_proto._handlePopperPlacementChange = function _handlePopperPlacementChange(popperData) { | ||
var state = popperData.state; | ||
_handlePopperPlacementChange(popperData) { | ||
const { | ||
state | ||
} = popperData; | ||
@@ -1134,9 +1072,9 @@ if (!state) { | ||
} // Static | ||
; | ||
Tooltip.jQueryInterface = function jQueryInterface(config) { | ||
static jQueryInterface(config) { | ||
return this.each(function () { | ||
var data = Data__default['default'].getData(this, DATA_KEY); | ||
let data = Data__default['default'].get(this, DATA_KEY); | ||
var _config = typeof config === 'object' && config; | ||
const _config = typeof config === 'object' && config; | ||
@@ -1153,3 +1091,3 @@ if (!data && /dispose|hide/.test(config)) { | ||
if (typeof data[config] === 'undefined') { | ||
throw new TypeError("No method named \"" + config + "\""); | ||
throw new TypeError(`No method named "${config}"`); | ||
} | ||
@@ -1160,38 +1098,5 @@ | ||
}); | ||
}; | ||
} | ||
_createClass(Tooltip, null, [{ | ||
key: "Default", | ||
get: function get() { | ||
return Default; | ||
} | ||
}, { | ||
key: "NAME", | ||
get: function get() { | ||
return NAME; | ||
} | ||
}, { | ||
key: "DATA_KEY", | ||
get: function get() { | ||
return DATA_KEY; | ||
} | ||
}, { | ||
key: "Event", | ||
get: function get() { | ||
return Event$1; | ||
} | ||
}, { | ||
key: "EVENT_KEY", | ||
get: function get() { | ||
return EVENT_KEY; | ||
} | ||
}, { | ||
key: "DefaultType", | ||
get: function get() { | ||
return DefaultType; | ||
} | ||
}]); | ||
return Tooltip; | ||
}(BaseComponent__default['default']); | ||
} | ||
/** | ||
@@ -1198,0 +1103,0 @@ * ------------------------------------------------------------------------ |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): alert.js | ||
* Bootstrap (v5.0.0-beta3): alert.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -101,3 +101,3 @@ * -------------------------------------------------------------------------- | ||
return this.each(function () { | ||
let data = Data.getData(this, DATA_KEY) | ||
let data = Data.get(this, DATA_KEY) | ||
@@ -130,2 +130,3 @@ if (!data) { | ||
*/ | ||
EventHandler.on(document, EVENT_CLICK_DATA_API, SELECTOR_DISMISS, Alert.handleDismiss(new Alert())) | ||
@@ -132,0 +133,0 @@ |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): base-component.js | ||
* Bootstrap (v5.0.0-beta3): base-component.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -16,6 +16,8 @@ * -------------------------------------------------------------------------- | ||
const VERSION = '5.0.0-beta2' | ||
const VERSION = '5.0.0-beta3' | ||
class BaseComponent { | ||
constructor(element) { | ||
element = typeof element === 'string' ? document.querySelector(element) : element | ||
if (!element) { | ||
@@ -26,7 +28,7 @@ return | ||
this._element = element | ||
Data.setData(element, this.constructor.DATA_KEY, this) | ||
Data.set(this._element, this.constructor.DATA_KEY, this) | ||
} | ||
dispose() { | ||
Data.removeData(this._element, this.constructor.DATA_KEY) | ||
Data.remove(this._element, this.constructor.DATA_KEY) | ||
this._element = null | ||
@@ -38,3 +40,3 @@ } | ||
static getInstance(element) { | ||
return Data.getData(element, this.DATA_KEY) | ||
return Data.get(element, this.DATA_KEY) | ||
} | ||
@@ -41,0 +43,0 @@ |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): button.js | ||
* Bootstrap (v5.0.0-beta3): button.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -54,3 +54,3 @@ * -------------------------------------------------------------------------- | ||
return this.each(function () { | ||
let data = Data.getData(this, DATA_KEY) | ||
let data = Data.get(this, DATA_KEY) | ||
@@ -79,3 +79,3 @@ if (!data) { | ||
let data = Data.getData(button, DATA_KEY) | ||
let data = Data.get(button, DATA_KEY) | ||
if (!data) { | ||
@@ -82,0 +82,0 @@ data = new Button(button) |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): carousel.js | ||
* Bootstrap (v5.0.0-beta3): carousel.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -13,4 +13,4 @@ * -------------------------------------------------------------------------- | ||
getTransitionDurationFromElement, | ||
isRTL, | ||
isVisible, | ||
isRTL, | ||
reflow, | ||
@@ -60,4 +60,4 @@ triggerTransitionEnd, | ||
const DIRECTION_NEXT = 'next' | ||
const DIRECTION_PREV = 'prev' | ||
const ORDER_NEXT = 'next' | ||
const ORDER_PREV = 'prev' | ||
const DIRECTION_LEFT = 'left' | ||
@@ -142,3 +142,3 @@ const DIRECTION_RIGHT = 'right' | ||
if (!this._isSliding) { | ||
this._slide(DIRECTION_NEXT) | ||
this._slide(ORDER_NEXT) | ||
} | ||
@@ -157,3 +157,3 @@ } | ||
if (!this._isSliding) { | ||
this._slide(DIRECTION_PREV) | ||
this._slide(ORDER_PREV) | ||
} | ||
@@ -215,11 +215,10 @@ } | ||
const direction = index > activeIndex ? | ||
DIRECTION_NEXT : | ||
DIRECTION_PREV | ||
const order = index > activeIndex ? | ||
ORDER_NEXT : | ||
ORDER_PREV | ||
this._slide(direction, this._items[index]) | ||
this._slide(order, this._items[index]) | ||
} | ||
dispose() { | ||
super.dispose() | ||
EventHandler.off(this._element, EVENT_KEY) | ||
@@ -234,2 +233,4 @@ | ||
this._indicatorsElement = null | ||
super.dispose() | ||
} | ||
@@ -259,19 +260,7 @@ | ||
// swipe left | ||
if (direction > 0) { | ||
if (isRTL) { | ||
this.next() | ||
} else { | ||
this.prev() | ||
} | ||
if (!direction) { | ||
return | ||
} | ||
// swipe right | ||
if (direction < 0) { | ||
if (isRTL) { | ||
this.prev() | ||
} else { | ||
this.next() | ||
} | ||
} | ||
this._slide(direction > 0 ? DIRECTION_RIGHT : DIRECTION_LEFT) | ||
} | ||
@@ -305,7 +294,5 @@ | ||
// ensure swiping with one touch and not pinching | ||
if (event.touches && event.touches.length > 1) { | ||
this.touchDeltaX = 0 | ||
} else { | ||
this.touchDeltaX = event.touches[0].clientX - this.touchStartX | ||
} | ||
this.touchDeltaX = event.touches && event.touches.length > 1 ? | ||
0 : | ||
event.touches[0].clientX - this.touchStartX | ||
} | ||
@@ -360,14 +347,6 @@ | ||
event.preventDefault() | ||
if (isRTL) { | ||
this.next() | ||
} else { | ||
this.prev() | ||
} | ||
this._slide(DIRECTION_LEFT) | ||
} else if (event.key === ARROW_RIGHT_KEY) { | ||
event.preventDefault() | ||
if (isRTL) { | ||
this.prev() | ||
} else { | ||
this.next() | ||
} | ||
this._slide(DIRECTION_RIGHT) | ||
} | ||
@@ -384,9 +363,8 @@ } | ||
_getItemByDirection(direction, activeElement) { | ||
const isNextDirection = direction === DIRECTION_NEXT | ||
const isPrevDirection = direction === DIRECTION_PREV | ||
_getItemByOrder(order, activeElement) { | ||
const isNext = order === ORDER_NEXT | ||
const isPrev = order === ORDER_PREV | ||
const activeIndex = this._getItemIndex(activeElement) | ||
const lastItemIndex = this._items.length - 1 | ||
const isGoingToWrap = (isPrevDirection && activeIndex === 0) || | ||
(isNextDirection && activeIndex === lastItemIndex) | ||
const isGoingToWrap = (isPrev && activeIndex === 0) || (isNext && activeIndex === lastItemIndex) | ||
@@ -397,3 +375,3 @@ if (isGoingToWrap && !this._config.wrap) { | ||
const delta = direction === DIRECTION_PREV ? -1 : 1 | ||
const delta = isPrev ? -1 : 1 | ||
const itemIndex = (activeIndex + delta) % this._items.length | ||
@@ -454,6 +432,7 @@ | ||
_slide(direction, element) { | ||
_slide(directionOrOrder, element) { | ||
const order = this._directionToOrder(directionOrOrder) | ||
const activeElement = SelectorEngine.findOne(SELECTOR_ACTIVE_ITEM, this._element) | ||
const activeElementIndex = this._getItemIndex(activeElement) | ||
const nextElement = element || (activeElement && this._getItemByDirection(direction, activeElement)) | ||
const nextElement = element || this._getItemByOrder(order, activeElement) | ||
@@ -463,5 +442,6 @@ const nextElementIndex = this._getItemIndex(nextElement) | ||
const directionalClassName = direction === DIRECTION_NEXT ? CLASS_NAME_START : CLASS_NAME_END | ||
const orderClassName = direction === DIRECTION_NEXT ? CLASS_NAME_NEXT : CLASS_NAME_PREV | ||
const eventDirectionName = direction === DIRECTION_NEXT ? DIRECTION_LEFT : DIRECTION_RIGHT | ||
const isNext = order === ORDER_NEXT | ||
const directionalClassName = isNext ? CLASS_NAME_START : CLASS_NAME_END | ||
const orderClassName = isNext ? CLASS_NAME_NEXT : CLASS_NAME_PREV | ||
const eventDirectionName = this._orderToDirection(order) | ||
@@ -539,6 +519,30 @@ if (nextElement && nextElement.classList.contains(CLASS_NAME_ACTIVE)) { | ||
_directionToOrder(direction) { | ||
if (![DIRECTION_RIGHT, DIRECTION_LEFT].includes(direction)) { | ||
return direction | ||
} | ||
if (isRTL()) { | ||
return direction === DIRECTION_RIGHT ? ORDER_PREV : ORDER_NEXT | ||
} | ||
return direction === DIRECTION_RIGHT ? ORDER_NEXT : ORDER_PREV | ||
} | ||
_orderToDirection(order) { | ||
if (![ORDER_NEXT, ORDER_PREV].includes(order)) { | ||
return order | ||
} | ||
if (isRTL()) { | ||
return order === ORDER_NEXT ? DIRECTION_LEFT : DIRECTION_RIGHT | ||
} | ||
return order === ORDER_NEXT ? DIRECTION_RIGHT : DIRECTION_LEFT | ||
} | ||
// Static | ||
static carouselInterface(element, config) { | ||
let data = Data.getData(element, DATA_KEY) | ||
let data = Data.get(element, DATA_KEY) | ||
let _config = { | ||
@@ -602,3 +606,3 @@ ...Default, | ||
if (slideIndex) { | ||
Data.getData(target, DATA_KEY).to(slideIndex) | ||
Data.get(target, DATA_KEY).to(slideIndex) | ||
} | ||
@@ -622,3 +626,3 @@ | ||
for (let i = 0, len = carousels.length; i < len; i++) { | ||
Carousel.carouselInterface(carousels[i], Data.getData(carousels[i], DATA_KEY)) | ||
Carousel.carouselInterface(carousels[i], Data.get(carousels[i], DATA_KEY)) | ||
} | ||
@@ -625,0 +629,0 @@ }) |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): collapse.js | ||
* Bootstrap (v5.0.0-beta3): collapse.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -75,4 +75,4 @@ * -------------------------------------------------------------------------- | ||
this._triggerArray = SelectorEngine.find( | ||
`${SELECTOR_DATA_TOGGLE}[href="#${element.id}"],` + | ||
`${SELECTOR_DATA_TOGGLE}[data-bs-target="#${element.id}"]` | ||
`${SELECTOR_DATA_TOGGLE}[href="#${this._element.id}"],` + | ||
`${SELECTOR_DATA_TOGGLE}[data-bs-target="#${this._element.id}"]` | ||
) | ||
@@ -86,3 +86,3 @@ | ||
const filterElement = SelectorEngine.find(selector) | ||
.filter(foundElem => foundElem === element) | ||
.filter(foundElem => foundElem === this._element) | ||
@@ -152,3 +152,3 @@ if (selector !== null && filterElement.length) { | ||
const tempActiveData = actives.find(elem => container !== elem) | ||
activesData = tempActiveData ? Data.getData(tempActiveData, DATA_KEY) : null | ||
activesData = tempActiveData ? Data.get(tempActiveData, DATA_KEY) : null | ||
@@ -172,3 +172,3 @@ if (activesData && activesData._isTransitioning) { | ||
if (!activesData) { | ||
Data.setData(elemActive, DATA_KEY, null) | ||
Data.set(elemActive, DATA_KEY, null) | ||
} | ||
@@ -339,3 +339,3 @@ }) | ||
static collapseInterface(element, config) { | ||
let data = Data.getData(element, DATA_KEY) | ||
let data = Data.get(element, DATA_KEY) | ||
const _config = { | ||
@@ -388,3 +388,3 @@ ...Default, | ||
selectorElements.forEach(element => { | ||
const data = Data.getData(element, DATA_KEY) | ||
const data = Data.get(element, DATA_KEY) | ||
let config | ||
@@ -391,0 +391,0 @@ if (data) { |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/data.js | ||
* Bootstrap (v5.0.0-beta3): dom/data.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -14,55 +14,45 @@ * -------------------------------------------------------------------------- | ||
const mapData = (() => { | ||
const storeData = {} | ||
let id = 1 | ||
return { | ||
set(element, key, data) { | ||
if (typeof element.bsKey === 'undefined') { | ||
element.bsKey = { | ||
key, | ||
id | ||
} | ||
id++ | ||
} | ||
const elementMap = new Map() | ||
storeData[element.bsKey.id] = data | ||
}, | ||
get(element, key) { | ||
if (!element || typeof element.bsKey === 'undefined') { | ||
return null | ||
} | ||
export default { | ||
set(element, key, instance) { | ||
if (!elementMap.has(element)) { | ||
elementMap.set(element, new Map()) | ||
} | ||
const keyProperties = element.bsKey | ||
if (keyProperties.key === key) { | ||
return storeData[keyProperties.id] | ||
} | ||
const instanceMap = elementMap.get(element) | ||
return null | ||
}, | ||
delete(element, key) { | ||
if (typeof element.bsKey === 'undefined') { | ||
return | ||
} | ||
// make it clear we only want one instance per element | ||
// can be removed later when multiple key/instances are fine to be used | ||
if (!instanceMap.has(key) && instanceMap.size !== 0) { | ||
// eslint-disable-next-line no-console | ||
console.error(`Bootstrap doesn't allow more than one instance per element. Bound instance: ${Array.from(instanceMap.keys())[0]}.`) | ||
return | ||
} | ||
const keyProperties = element.bsKey | ||
if (keyProperties.key === key) { | ||
delete storeData[keyProperties.id] | ||
delete element.bsKey | ||
} | ||
instanceMap.set(key, instance) | ||
}, | ||
get(element, key) { | ||
if (elementMap.has(element)) { | ||
return elementMap.get(element).get(key) || null | ||
} | ||
} | ||
})() | ||
const Data = { | ||
setData(instance, key, data) { | ||
mapData.set(instance, key, data) | ||
return null | ||
}, | ||
getData(instance, key) { | ||
return mapData.get(instance, key) | ||
}, | ||
removeData(instance, key) { | ||
mapData.delete(instance, key) | ||
remove(element, key) { | ||
if (!elementMap.has(element)) { | ||
return | ||
} | ||
const instanceMap = elementMap.get(element) | ||
instanceMap.delete(key) | ||
// free up element references if there are no instances left for an element | ||
if (instanceMap.size === 0) { | ||
elementMap.delete(element) | ||
} | ||
} | ||
} | ||
export default Data |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/event-handler.js | ||
* Bootstrap (v5.0.0-beta3): dom/event-handler.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -5,0 +5,0 @@ * -------------------------------------------------------------------------- |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/manipulator.js | ||
* Bootstrap (v5.0.0-beta3): dom/manipulator.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -5,0 +5,0 @@ * -------------------------------------------------------------------------- |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dom/selector-engine.js | ||
* Bootstrap (v5.0.0-beta3): dom/selector-engine.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -5,0 +5,0 @@ * -------------------------------------------------------------------------- |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): dropdown.js | ||
* Bootstrap (v5.0.0-beta3): dropdown.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -62,3 +62,2 @@ * -------------------------------------------------------------------------- | ||
const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="dropdown"]' | ||
const SELECTOR_FORM_CHILD = '.dropdown form' | ||
const SELECTOR_MENU = '.dropdown-menu' | ||
@@ -68,12 +67,11 @@ const SELECTOR_NAVBAR_NAV = '.navbar-nav' | ||
const PLACEMENT_TOP = isRTL ? 'top-end' : 'top-start' | ||
const PLACEMENT_TOPEND = isRTL ? 'top-start' : 'top-end' | ||
const PLACEMENT_BOTTOM = isRTL ? 'bottom-end' : 'bottom-start' | ||
const PLACEMENT_BOTTOMEND = isRTL ? 'bottom-start' : 'bottom-end' | ||
const PLACEMENT_RIGHT = isRTL ? 'left-start' : 'right-start' | ||
const PLACEMENT_LEFT = isRTL ? 'right-start' : 'left-start' | ||
const PLACEMENT_TOP = isRTL() ? 'top-end' : 'top-start' | ||
const PLACEMENT_TOPEND = isRTL() ? 'top-start' : 'top-end' | ||
const PLACEMENT_BOTTOM = isRTL() ? 'bottom-end' : 'bottom-start' | ||
const PLACEMENT_BOTTOMEND = isRTL() ? 'bottom-start' : 'bottom-end' | ||
const PLACEMENT_RIGHT = isRTL() ? 'left-start' : 'right-start' | ||
const PLACEMENT_LEFT = isRTL() ? 'right-start' : 'left-start' | ||
const Default = { | ||
offset: [0, 2], | ||
flip: true, | ||
boundary: 'clippingParents', | ||
@@ -87,3 +85,2 @@ reference: 'toggle', | ||
offset: '(array|string|function)', | ||
flip: 'boolean', | ||
boundary: '(string|element)', | ||
@@ -238,3 +235,2 @@ reference: '(string|element|object)', | ||
dispose() { | ||
super.dispose() | ||
EventHandler.off(this._element, EVENT_KEY) | ||
@@ -247,2 +243,4 @@ this._menu = null | ||
} | ||
super.dispose() | ||
} | ||
@@ -262,3 +260,2 @@ | ||
event.preventDefault() | ||
event.stopPropagation() | ||
this.toggle() | ||
@@ -336,3 +333,2 @@ }) | ||
options: { | ||
altBoundary: this._config.flip, | ||
boundary: this._config.boundary | ||
@@ -366,3 +362,3 @@ } | ||
static dropdownInterface(element, config) { | ||
let data = Data.getData(element, DATA_KEY) | ||
let data = Data.get(element, DATA_KEY) | ||
const _config = typeof config === 'object' ? config : null | ||
@@ -390,4 +386,10 @@ | ||
static clearMenus(event) { | ||
if (event && (event.button === RIGHT_MOUSE_BUTTON || (event.type === 'keyup' && event.key !== TAB_KEY))) { | ||
return | ||
if (event) { | ||
if (event.button === RIGHT_MOUSE_BUTTON || (event.type === 'keyup' && event.key !== TAB_KEY)) { | ||
return | ||
} | ||
if (/input|select|textarea|form/i.test(event.target.tagName)) { | ||
return | ||
} | ||
} | ||
@@ -398,3 +400,3 @@ | ||
for (let i = 0, len = toggles.length; i < len; i++) { | ||
const context = Data.getData(toggles[i], DATA_KEY) | ||
const context = Data.get(toggles[i], DATA_KEY) | ||
const relatedTarget = { | ||
@@ -417,7 +419,12 @@ relatedTarget: toggles[i] | ||
if (event && ((event.type === 'click' && | ||
/input|textarea/i.test(event.target.tagName)) || | ||
(event.type === 'keyup' && event.key === TAB_KEY)) && | ||
dropdownMenu.contains(event.target)) { | ||
continue | ||
if (event) { | ||
// Don't close the menu if the clicked element or one of its parents is the dropdown button | ||
if ([context._element].some(element => event.composedPath().includes(element))) { | ||
continue | ||
} | ||
// Tab navigation through the dropdown menu shouldn't close the menu | ||
if (event.type === 'keyup' && event.key === TAB_KEY && dropdownMenu.contains(event.target)) { | ||
continue | ||
} | ||
} | ||
@@ -535,6 +542,4 @@ | ||
event.preventDefault() | ||
event.stopPropagation() | ||
Dropdown.dropdownInterface(this, 'toggle') | ||
Dropdown.dropdownInterface(this) | ||
}) | ||
EventHandler.on(document, EVENT_CLICK_DATA_API, SELECTOR_FORM_CHILD, e => e.stopPropagation()) | ||
@@ -541,0 +546,0 @@ /** |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): modal.js | ||
* Bootstrap (v5.0.0-beta3): modal.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -86,3 +86,3 @@ * -------------------------------------------------------------------------- | ||
this._config = this._getConfig(config) | ||
this._dialog = SelectorEngine.findOne(SELECTOR_DIALOG, element) | ||
this._dialog = SelectorEngine.findOne(SELECTOR_DIALOG, this._element) | ||
this._backdrop = null | ||
@@ -117,3 +117,3 @@ this._isShown = false | ||
if (this._element.classList.contains(CLASS_NAME_FADE)) { | ||
if (this._isAnimated()) { | ||
this._isTransitioning = true | ||
@@ -169,5 +169,5 @@ } | ||
this._isShown = false | ||
const transition = this._element.classList.contains(CLASS_NAME_FADE) | ||
const isAnimated = this._isAnimated() | ||
if (transition) { | ||
if (isAnimated) { | ||
this._isTransitioning = true | ||
@@ -186,3 +186,3 @@ } | ||
if (transition) { | ||
if (isAnimated) { | ||
const transitionDuration = getTransitionDurationFromElement(this._element) | ||
@@ -236,3 +236,3 @@ | ||
_showElement(relatedTarget) { | ||
const transition = this._element.classList.contains(CLASS_NAME_FADE) | ||
const isAnimated = this._isAnimated() | ||
const modalBody = SelectorEngine.findOne(SELECTOR_MODAL_BODY, this._dialog) | ||
@@ -255,3 +255,3 @@ | ||
if (transition) { | ||
if (isAnimated) { | ||
reflow(this._element) | ||
@@ -277,3 +277,3 @@ } | ||
if (transition) { | ||
if (isAnimated) { | ||
const transitionDuration = getTransitionDurationFromElement(this._dialog) | ||
@@ -342,6 +342,3 @@ | ||
_showBackdrop(callback) { | ||
const animate = this._element.classList.contains(CLASS_NAME_FADE) ? | ||
CLASS_NAME_FADE : | ||
'' | ||
const isAnimated = this._isAnimated() | ||
if (this._isShown && this._config.backdrop) { | ||
@@ -351,4 +348,4 @@ this._backdrop = document.createElement('div') | ||
if (animate) { | ||
this._backdrop.classList.add(animate) | ||
if (isAnimated) { | ||
this._backdrop.classList.add(CLASS_NAME_FADE) | ||
} | ||
@@ -375,3 +372,3 @@ | ||
if (animate) { | ||
if (isAnimated) { | ||
reflow(this._backdrop) | ||
@@ -382,3 +379,3 @@ } | ||
if (!animate) { | ||
if (!isAnimated) { | ||
callback() | ||
@@ -400,3 +397,3 @@ return | ||
if (this._element.classList.contains(CLASS_NAME_FADE)) { | ||
if (isAnimated) { | ||
const backdropTransitionDuration = getTransitionDurationFromElement(this._backdrop) | ||
@@ -413,2 +410,6 @@ EventHandler.one(this._backdrop, 'transitionend', callbackRemove) | ||
_isAnimated() { | ||
return this._element.classList.contains(CLASS_NAME_FADE) | ||
} | ||
_triggerBackdropTransition() { | ||
@@ -447,10 +448,9 @@ const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED) | ||
_adjustDialog() { | ||
const isModalOverflowing = | ||
this._element.scrollHeight > document.documentElement.clientHeight | ||
const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight | ||
if ((!this._isBodyOverflowing && isModalOverflowing && !isRTL) || (this._isBodyOverflowing && !isModalOverflowing && isRTL)) { | ||
if ((!this._isBodyOverflowing && isModalOverflowing && !isRTL()) || (this._isBodyOverflowing && !isModalOverflowing && isRTL())) { | ||
this._element.style.paddingLeft = `${this._scrollbarWidth}px` | ||
} | ||
if ((this._isBodyOverflowing && !isModalOverflowing && !isRTL) || (!this._isBodyOverflowing && isModalOverflowing && isRTL)) { | ||
if ((this._isBodyOverflowing && !isModalOverflowing && !isRTL()) || (!this._isBodyOverflowing && isModalOverflowing && isRTL())) { | ||
this._element.style.paddingRight = `${this._scrollbarWidth}px` | ||
@@ -484,2 +484,6 @@ } | ||
.forEach(element => { | ||
if (element !== document.body && window.innerWidth > element.clientWidth + this._scrollbarWidth) { | ||
return | ||
} | ||
const actualValue = element.style[styleProp] | ||
@@ -523,3 +527,3 @@ const calculatedValue = window.getComputedStyle(element)[styleProp] | ||
return this.each(function () { | ||
let data = Data.getData(this, DATA_KEY) | ||
let data = Data.get(this, DATA_KEY) | ||
const _config = { | ||
@@ -572,3 +576,3 @@ ...Default, | ||
let data = Data.getData(target, DATA_KEY) | ||
let data = Data.get(target, DATA_KEY) | ||
if (!data) { | ||
@@ -575,0 +579,0 @@ const config = { |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): popover.js | ||
* Bootstrap (v5.0.0-beta3): popover.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -139,3 +139,3 @@ * -------------------------------------------------------------------------- | ||
return this.each(function () { | ||
let data = Data.getData(this, DATA_KEY) | ||
let data = Data.get(this, DATA_KEY) | ||
const _config = typeof config === 'object' ? config : null | ||
@@ -149,3 +149,3 @@ | ||
data = new Popover(this, _config) | ||
Data.setData(this, DATA_KEY, data) | ||
Data.set(this, DATA_KEY, data) | ||
} | ||
@@ -152,0 +152,0 @@ |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): scrollspy.js | ||
* Bootstrap (v5.0.0-beta3): scrollspy.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -71,3 +71,3 @@ * -------------------------------------------------------------------------- | ||
super(element) | ||
this._scrollElement = element.tagName === 'BODY' ? window : element | ||
this._scrollElement = this._element.tagName === 'BODY' ? window : this._element | ||
this._config = this._getConfig(config) | ||
@@ -282,3 +282,3 @@ this._selector = `${this._config.target} ${SELECTOR_NAV_LINKS}, ${this._config.target} ${SELECTOR_LIST_ITEMS}, ${this._config.target} .${CLASS_NAME_DROPDOWN_ITEM}` | ||
return this.each(function () { | ||
let data = Data.getData(this, DATA_KEY) | ||
let data = Data.get(this, DATA_KEY) | ||
const _config = typeof config === 'object' && config | ||
@@ -285,0 +285,0 @@ |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): tab.js | ||
* Bootstrap (v5.0.0-beta3): tab.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -13,2 +13,3 @@ * -------------------------------------------------------------------------- | ||
getTransitionDurationFromElement, | ||
isDisabled, | ||
reflow | ||
@@ -40,3 +41,2 @@ } from './util/index' | ||
const CLASS_NAME_ACTIVE = 'active' | ||
const CLASS_NAME_DISABLED = 'disabled' | ||
const CLASS_NAME_FADE = 'fade' | ||
@@ -72,3 +72,3 @@ const CLASS_NAME_SHOW = 'show' | ||
this._element.classList.contains(CLASS_NAME_ACTIVE)) || | ||
this._element.classList.contains(CLASS_NAME_DISABLED)) { | ||
isDisabled(this._element)) { | ||
return | ||
@@ -188,3 +188,3 @@ } | ||
return this.each(function () { | ||
const data = Data.getData(this, DATA_KEY) || new Tab(this) | ||
const data = Data.get(this, DATA_KEY) || new Tab(this) | ||
@@ -211,3 +211,3 @@ if (typeof config === 'string') { | ||
const data = Data.getData(this, DATA_KEY) || new Tab(this) | ||
const data = Data.get(this, DATA_KEY) || new Tab(this) | ||
data.show() | ||
@@ -214,0 +214,0 @@ }) |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): toast.js | ||
* Bootstrap (v5.0.0-beta3): toast.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -192,3 +192,3 @@ * -------------------------------------------------------------------------- | ||
return this.each(function () { | ||
let data = Data.getData(this, DATA_KEY) | ||
let data = Data.get(this, DATA_KEY) | ||
const _config = typeof config === 'object' && config | ||
@@ -195,0 +195,0 @@ |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): tooltip.js | ||
* Bootstrap (v5.0.0-beta3): tooltip.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -67,5 +67,5 @@ * -------------------------------------------------------------------------- | ||
TOP: 'top', | ||
RIGHT: isRTL ? 'left' : 'right', | ||
RIGHT: isRTL() ? 'left' : 'right', | ||
BOTTOM: 'bottom', | ||
LEFT: isRTL ? 'right' : 'left' | ||
LEFT: isRTL() ? 'right' : 'left' | ||
} | ||
@@ -279,12 +279,15 @@ | ||
const container = this._getContainer() | ||
Data.setData(tip, this.constructor.DATA_KEY, this) | ||
Data.set(tip, this.constructor.DATA_KEY, this) | ||
if (!this._element.ownerDocument.documentElement.contains(this.tip)) { | ||
container.appendChild(tip) | ||
EventHandler.trigger(this._element, this.constructor.Event.INSERTED) | ||
} | ||
EventHandler.trigger(this._element, this.constructor.Event.INSERTED) | ||
if (this._popper) { | ||
this._popper.update() | ||
} else { | ||
this._popper = Popper.createPopper(this._element, tip, this._getPopperConfig(attachment)) | ||
} | ||
this._popper = Popper.createPopper(this._element, tip, this._getPopperConfig(attachment)) | ||
tip.classList.add(CLASS_NAME_SHOW) | ||
@@ -334,2 +337,6 @@ | ||
const complete = () => { | ||
if (this._isWithActiveTrigger()) { | ||
return | ||
} | ||
if (this._hoverState !== HOVER_STATE_SHOW && tip.parentNode) { | ||
@@ -471,7 +478,7 @@ tip.parentNode.removeChild(tip) | ||
const dataKey = this.constructor.DATA_KEY | ||
context = context || Data.getData(event.delegateTarget, dataKey) | ||
context = context || Data.get(event.delegateTarget, dataKey) | ||
if (!context) { | ||
context = new this.constructor(event.delegateTarget, this._getDelegateConfig()) | ||
Data.setData(event.delegateTarget, dataKey, context) | ||
Data.set(event.delegateTarget, dataKey, context) | ||
} | ||
@@ -570,4 +577,3 @@ | ||
if (trigger === 'click') { | ||
EventHandler.on(this._element, this.constructor.Event.CLICK, this.config.selector, event => this.toggle(event) | ||
) | ||
EventHandler.on(this._element, this.constructor.Event.CLICK, this.config.selector, event => this.toggle(event)) | ||
} else if (trigger !== TRIGGER_MANUAL) { | ||
@@ -655,3 +661,3 @@ const eventIn = trigger === TRIGGER_HOVER ? | ||
event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER | ||
] = false | ||
] = context._element.contains(event.relatedTarget) | ||
} | ||
@@ -771,3 +777,3 @@ | ||
return this.each(function () { | ||
let data = Data.getData(this, DATA_KEY) | ||
let data = Data.get(this, DATA_KEY) | ||
const _config = typeof config === 'object' && config | ||
@@ -774,0 +780,0 @@ |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/index.js | ||
* Bootstrap (v5.0.0-beta3): util/index.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -156,2 +156,18 @@ * -------------------------------------------------------------------------- | ||
const isDisabled = element => { | ||
if (!element || element.nodeType !== Node.ELEMENT_NODE) { | ||
return true | ||
} | ||
if (element.classList.contains('disabled')) { | ||
return true | ||
} | ||
if (typeof element.disabled !== 'undefined') { | ||
return element.disabled | ||
} | ||
return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false' | ||
} | ||
const findShadowRoot = element => { | ||
@@ -202,3 +218,3 @@ if (!document.documentElement.attachShadow) { | ||
const isRTL = document.documentElement.dir === 'rtl' | ||
const isRTL = () => document.documentElement.dir === 'rtl' | ||
@@ -231,2 +247,3 @@ const defineJQueryPlugin = (name, plugin) => { | ||
isVisible, | ||
isDisabled, | ||
findShadowRoot, | ||
@@ -233,0 +250,0 @@ noop, |
/** | ||
* -------------------------------------------------------------------------- | ||
* Bootstrap (v5.0.0-beta2): util/sanitizer.js | ||
* Bootstrap (v5.0.0-beta3): util/sanitizer.js | ||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) | ||
@@ -26,3 +26,3 @@ * -------------------------------------------------------------------------- | ||
*/ | ||
const SAFE_URL_PATTERN = /^(?:(?:https?|mailto|ftp|tel|file):|[^#&/:?]*(?:[#/?]|$))/gi | ||
const SAFE_URL_PATTERN = /^(?:(?:https?|mailto|ftp|tel|file):|[^#&/:?]*(?:[#/?]|$))/i | ||
@@ -29,0 +29,0 @@ /** |
{ | ||
"name": "bootstrap", | ||
"description": "The most popular front-end framework for developing responsive, mobile first projects on the web.", | ||
"version": "5.0.0-beta2", | ||
"version": "5.0.0-beta3", | ||
"config": { | ||
@@ -32,4 +32,4 @@ "version_short": "5.0" | ||
"css-minify": "npm-run-all --parallel css-minify-*", | ||
"css-minify-main": "cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap.min.css dist/css/bootstrap.css && cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap-grid.min.css dist/css/bootstrap-grid.css && cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap-utilities.min.css dist/css/bootstrap-utilities.css && cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap-reboot.min.css dist/css/bootstrap-reboot.css", | ||
"css-minify-rtl": "cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap.rtl.min.css dist/css/bootstrap.rtl.css && cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap-grid.rtl.min.css dist/css/bootstrap-grid.rtl.css && cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap-utilities.rtl.min.css dist/css/bootstrap-utilities.rtl.css && cleancss -O1 --format breakWith=lf --source-map --source-map-inline-sources --output dist/css/bootstrap-reboot.rtl.min.css dist/css/bootstrap-reboot.rtl.css", | ||
"css-minify-main": "cleancss -O1 --format breakWith=lf --with-rebase --source-map --source-map-inline-sources --output dist/css/ --batch --batch-suffix \".min\" \"dist/css/*.css\" \"!dist/css/*.min.css\" \"!dist/css/*rtl*.css\"", | ||
"css-minify-rtl": "cleancss -O1 --format breakWith=lf --with-rebase --source-map --source-map-inline-sources --output dist/css/ --batch --batch-suffix \".min\" \"dist/css/*rtl.css\" \"!dist/css/*.min.css\"", | ||
"css-prefix": "npm-run-all --parallel css-prefix-*", | ||
@@ -61,7 +61,7 @@ "css-prefix-main": "postcss --config build/postcss.config.js --replace \"dist/css/*.css\" \"!dist/css/*.rtl*.css\" \"!dist/css/*.min.css\"", | ||
"docs-compile": "npm run docs-build", | ||
"docs-linkinator": "linkinator _gh_pages --recurse --silent --skip \"^(?!http://localhost)\"", | ||
"docs-linkinator": "linkinator _site --recurse --skip \"^(?!http://localhost)\" --verbosity error", | ||
"docs-vnu": "node build/vnu-jar.js", | ||
"docs-lint": "npm-run-all --parallel docs-vnu docs-linkinator", | ||
"docs-serve": "hugo server --port 9001 --disableFastRender", | ||
"docs-serve-only": "npx sirv-cli _gh_pages --port 9001", | ||
"docs-serve-only": "npx sirv-cli _site --port 9001", | ||
"lockfile-lint": "lockfile-lint --allowed-hosts npm --allowed-schemes https: --empty-hostname false --type npm --path package-lock.json", | ||
@@ -102,28 +102,29 @@ "update-deps": "ncu -u -x karma-browserstack-launcher,terser && npm update && echo Manually update site/assets/js/vendor", | ||
"peerDependencies": { | ||
"@popperjs/core": "^2.6.0" | ||
"@popperjs/core": "^2.9.1" | ||
}, | ||
"devDependencies": { | ||
"@babel/cli": "^7.12.13", | ||
"@babel/core": "^7.12.13", | ||
"@babel/preset-env": "^7.12.13", | ||
"@popperjs/core": "^2.6.0", | ||
"@rollup/plugin-babel": "^5.2.3", | ||
"@babel/cli": "^7.13.10", | ||
"@babel/core": "^7.13.10", | ||
"@babel/preset-env": "^7.13.12", | ||
"@popperjs/core": "^2.9.1", | ||
"@rollup/plugin-babel": "^5.3.0", | ||
"@rollup/plugin-commonjs": "^17.1.0", | ||
"@rollup/plugin-node-resolve": "^11.1.1", | ||
"@rollup/plugin-replace": "^2.3.4", | ||
"autoprefixer": "^10.2.4", | ||
"@rollup/plugin-node-resolve": "^11.2.0", | ||
"@rollup/plugin-replace": "^2.4.1", | ||
"autoprefixer": "^10.2.5", | ||
"bundlewatch": "^0.3.2", | ||
"clean-css-cli": "^4.3.0", | ||
"clean-css-cli": "^5.2.2", | ||
"cross-env": "^7.0.3", | ||
"eslint": "^7.19.0", | ||
"eslint-config-xo": "^0.34.0", | ||
"eslint": "^7.22.0", | ||
"eslint-config-xo": "^0.35.0", | ||
"eslint-plugin-import": "^2.22.1", | ||
"eslint-plugin-unicorn": "^27.0.0", | ||
"eslint-plugin-unicorn": "^29.0.0", | ||
"find-unused-sass-variables": "^3.1.0", | ||
"glob": "^7.1.6", | ||
"globby": "^11.0.3", | ||
"hammer-simulator": "0.0.1", | ||
"hugo-bin": "^0.68.0", | ||
"hugo-bin": "^0.70.0", | ||
"ip": "^1.1.5", | ||
"jquery": "^3.5.1", | ||
"karma": "^6.0.4", | ||
"jquery": "^3.6.0", | ||
"karma": "^6.2.0", | ||
"karma-browserstack-launcher": "1.4.0", | ||
@@ -136,15 +137,15 @@ "karma-chrome-launcher": "^3.1.0", | ||
"karma-jasmine-html-reporter": "^1.5.4", | ||
"karma-rollup-preprocessor": "^7.0.5", | ||
"linkinator": "^2.13.4", | ||
"lockfile-lint": "^4.3.7", | ||
"karma-rollup-preprocessor": "^7.0.7", | ||
"linkinator": "^2.13.6", | ||
"lockfile-lint": "^4.6.2", | ||
"nodemon": "^2.0.7", | ||
"npm-run-all": "^4.1.5", | ||
"postcss": "^8.2.5", | ||
"postcss": "^8.2.8", | ||
"postcss-cli": "^8.3.1", | ||
"rollup": "^2.38.5", | ||
"rollup": "^2.42.3", | ||
"rollup-plugin-istanbul": "^3.0.0", | ||
"rtlcss": "^3.1.2", | ||
"sass": "^1.32.6", | ||
"sass": "^1.32.8", | ||
"shelljs": "^0.8.4", | ||
"stylelint": "^13.9.0", | ||
"stylelint": "^13.12.0", | ||
"stylelint-config-twbs-bootstrap": "^2.1.0", | ||
@@ -177,5 +178,5 @@ "terser": "5.1.0", | ||
"peerDependencies": { | ||
"@popperjs/core": "^2.6.0" | ||
"@popperjs/core": "^2.9.1" | ||
} | ||
} | ||
} |
@@ -49,7 +49,7 @@ <p align="center"> | ||
- [Download the latest release](https://github.com/twbs/bootstrap/archive/v5.0.0-beta2.zip) | ||
- [Download the latest release](https://github.com/twbs/bootstrap/archive/v5.0.0-beta3.zip) | ||
- Clone the repo: `git clone https://github.com/twbs/bootstrap.git` | ||
- Install with [npm](https://www.npmjs.com/): `npm install bootstrap@next` | ||
- Install with [yarn](https://yarnpkg.com/): `yarn add bootstrap@next` | ||
- Install with [Composer](https://getcomposer.org/): `composer require twbs/bootstrap:5.0.0-beta2` | ||
- Install with [Composer](https://getcomposer.org/): `composer require twbs/bootstrap:5.0.0-beta3` | ||
- Install with [NuGet](https://www.nuget.org/): CSS: `Install-Package bootstrap` Sass: `Install-Package bootstrap.sass` | ||
@@ -63,3 +63,3 @@ | ||
[![Slack](https://bootstrap-slack.herokuapp.com/badge.svg)](https://bootstrap-slack.herokuapp.com/) | ||
[![Build Status](https://github.com/twbs/bootstrap/workflows/JS%20Tests/badge.svg?branch=main)](https://github.com/twbs/bootstrap/actions?query=workflow%3AJS+Tests+branch%3Amain) | ||
[![Build Status](https://img.shields.io/github/workflow/status/twbs/bootstrap/JS%20Tests/main?label=JS%20Tests&logo=github)](https://github.com/twbs/bootstrap/actions?query=workflow%3AJS+Tests+branch%3Amain) | ||
[![npm version](https://img.shields.io/npm/v/bootstrap)](https://www.npmjs.com/package/bootstrap) | ||
@@ -66,0 +66,0 @@ [![Gem version](https://img.shields.io/gem/v/bootstrap)](https://rubygems.org/gems/bootstrap) |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
8318294
181
59701
47