2019-03-11 16:13:30 +01:00
/ * !
* Bootstrap v4 . 3.1 ( https : //getbootstrap.com/)
* Copyright 2011 - 2019 The Bootstrap Authors ( https : //github.com/twbs/bootstrap/graphs/contributors)
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* /
import Popper from 'popper.js' ;
2019-04-18 13:47:52 +02:00
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 _defineProperty ( obj , key , value ) {
if ( key in obj ) {
Object . defineProperty ( obj , key , {
value : value ,
enumerable : true ,
configurable : true ,
writable : true
} ) ;
} else {
obj [ key ] = value ;
}
return obj ;
}
2019-07-24 08:13:50 +02:00
function ownKeys ( object , enumerableOnly ) {
var keys = Object . keys ( object ) ;
if ( Object . getOwnPropertySymbols ) {
var symbols = Object . getOwnPropertySymbols ( object ) ;
if ( enumerableOnly ) symbols = symbols . filter ( function ( sym ) {
return Object . getOwnPropertyDescriptor ( object , sym ) . enumerable ;
} ) ;
keys . push . apply ( keys , symbols ) ;
}
return keys ;
}
function _objectSpread2 ( target ) {
2019-04-18 13:47:52 +02:00
for ( var i = 1 ; i < arguments . length ; i ++ ) {
var source = arguments [ i ] != null ? arguments [ i ] : { } ;
2019-07-24 08:13:50 +02:00
if ( i % 2 ) {
ownKeys ( source , true ) . forEach ( function ( key ) {
_defineProperty ( target , key , source [ key ] ) ;
} ) ;
} else if ( Object . getOwnPropertyDescriptors ) {
Object . defineProperties ( target , Object . getOwnPropertyDescriptors ( source ) ) ;
} else {
ownKeys ( source ) . forEach ( function ( key ) {
Object . defineProperty ( target , key , Object . getOwnPropertyDescriptor ( source , key ) ) ;
} ) ;
2019-04-18 13:47:52 +02:00
}
}
return target ;
}
function _inheritsLoose ( subClass , superClass ) {
subClass . prototype = Object . create ( superClass . prototype ) ;
subClass . prototype . constructor = subClass ;
subClass . _ _proto _ _ = superClass ;
}
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Bootstrap ( v4 . 3.1 ) : util / index . js
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var MAX _UID = 1000000 ;
var MILLISECONDS _MULTIPLIER = 1000 ;
2019-08-27 15:03:21 +02:00
var TRANSITION _END = 'transitionend' ; // Shoutout AngusCroll (https://goo.gl/pxwQGp)
2019-04-18 13:47:52 +02:00
var toType = function toType ( obj ) {
return { } . toString . call ( obj ) . match ( /\s([a-z]+)/i ) [ 1 ] . toLowerCase ( ) ;
} ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Public Util Api
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var getUID = function getUID ( prefix ) {
2019-03-11 16:13:30 +01:00
do {
prefix += ~ ~ ( Math . random ( ) * MAX _UID ) ; // "~~" acts like a faster Math.floor() here
} while ( document . getElementById ( prefix ) ) ;
return prefix ;
} ;
2019-08-27 15:03:21 +02:00
var getSelector = function getSelector ( element ) {
2019-04-18 13:47:52 +02:00
var selector = element . getAttribute ( 'data-target' ) ;
2019-03-11 16:13:30 +01:00
if ( ! selector || selector === '#' ) {
2019-04-18 13:47:52 +02:00
var hrefAttr = element . getAttribute ( 'href' ) ;
2019-08-27 15:03:21 +02:00
selector = hrefAttr && hrefAttr !== '#' ? hrefAttr . trim ( ) : null ;
2019-03-11 16:13:30 +01:00
}
2019-08-27 15:03:21 +02:00
return selector ;
} ;
var getSelectorFromElement = function getSelectorFromElement ( element ) {
var selector = getSelector ( element ) ;
if ( selector ) {
2019-03-11 16:13:30 +01:00
return document . querySelector ( selector ) ? selector : null ;
}
2019-08-27 15:03:21 +02:00
return null ;
} ;
var getElementFromSelector = function getElementFromSelector ( element ) {
var selector = getSelector ( element ) ;
return selector ? document . querySelector ( selector ) : null ;
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var getTransitionDurationFromElement = function getTransitionDurationFromElement ( element ) {
2019-03-11 16:13:30 +01:00
if ( ! element ) {
return 0 ;
} // Get transition-duration of the element
2019-04-18 13:47:52 +02:00
var _window$getComputedSt = window . getComputedStyle ( element ) ,
2019-03-11 16:13:30 +01:00
transitionDuration = _window$getComputedSt . transitionDuration ,
transitionDelay = _window$getComputedSt . transitionDelay ;
2019-04-18 13:47:52 +02:00
var floatTransitionDuration = parseFloat ( transitionDuration ) ;
var floatTransitionDelay = parseFloat ( transitionDelay ) ; // Return 0 if element or transition duration is not found
2019-03-11 16:13:30 +01:00
if ( ! floatTransitionDuration && ! floatTransitionDelay ) {
return 0 ;
} // If multiple durations are defined, take the first
transitionDuration = transitionDuration . split ( ',' ) [ 0 ] ;
transitionDelay = transitionDelay . split ( ',' ) [ 0 ] ;
return ( parseFloat ( transitionDuration ) + parseFloat ( transitionDelay ) ) * MILLISECONDS _MULTIPLIER ;
} ;
2019-04-18 13:47:52 +02:00
var triggerTransitionEnd = function triggerTransitionEnd ( element ) {
var evt = document . createEvent ( 'HTMLEvents' ) ;
evt . initEvent ( TRANSITION _END , true , true ) ;
element . dispatchEvent ( evt ) ;
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var isElement = function isElement ( obj ) {
return ( obj [ 0 ] || obj ) . nodeType ;
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var emulateTransitionEnd = function emulateTransitionEnd ( element , duration ) {
var called = false ;
var durationPadding = 5 ;
var emulatedDuration = duration + durationPadding ;
2019-03-11 16:13:30 +01:00
function listener ( ) {
called = true ;
element . removeEventListener ( TRANSITION _END , listener ) ;
}
element . addEventListener ( TRANSITION _END , listener ) ;
2019-04-18 13:47:52 +02:00
setTimeout ( function ( ) {
2019-03-11 16:13:30 +01:00
if ( ! called ) {
triggerTransitionEnd ( element ) ;
}
} , emulatedDuration ) ;
} ;
2019-04-18 13:47:52 +02:00
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 ) ;
2019-03-11 16:13:30 +01:00
if ( ! new RegExp ( expectedTypes ) . test ( valueType ) ) {
2019-04-18 13:47:52 +02:00
throw new Error ( componentName . toUpperCase ( ) + ": " + ( "Option \"" + property + "\" provided type \"" + valueType + "\" " ) + ( "but expected type \"" + expectedTypes + "\"." ) ) ;
2019-03-11 16:13:30 +01:00
}
} ) ;
} ;
2019-04-18 13:47:52 +02:00
var makeArray = function makeArray ( nodeList ) {
2019-03-11 16:13:30 +01:00
if ( ! nodeList ) {
return [ ] ;
}
return [ ] . slice . call ( nodeList ) ;
} ;
2019-04-18 13:47:52 +02:00
var isVisible = function isVisible ( element ) {
2019-03-11 16:13:30 +01:00
if ( ! element ) {
return false ;
}
if ( element . style && element . parentNode && element . parentNode . style ) {
2019-11-08 09:11:23 +01:00
var elementStyle = getComputedStyle ( element ) ;
var parentNodeStyle = getComputedStyle ( element . parentNode ) ;
return elementStyle . display !== 'none' && parentNodeStyle . display !== 'none' && elementStyle . visibility !== 'hidden' ;
2019-03-11 16:13:30 +01:00
}
return false ;
} ;
2019-04-18 13:47:52 +02:00
var findShadowRoot = function findShadowRoot ( element ) {
2019-03-11 16:13:30 +01:00
if ( ! document . documentElement . attachShadow ) {
return null ;
} // Can find the shadow root otherwise it'll return the document
if ( typeof element . getRootNode === 'function' ) {
2019-04-18 13:47:52 +02:00
var root = element . getRootNode ( ) ;
2019-03-11 16:13:30 +01:00
return root instanceof ShadowRoot ? root : null ;
}
if ( element instanceof ShadowRoot ) {
return element ;
} // when we don't find a shadow root
if ( ! element . parentNode ) {
return null ;
}
return findShadowRoot ( element . parentNode ) ;
2019-10-08 08:39:10 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var noop = function noop ( ) {
return function ( ) { } ;
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var reflow = function reflow ( element ) {
return element . offsetHeight ;
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
var getjQuery = function getjQuery ( ) {
var _window = window ,
jQuery = _window . jQuery ;
if ( jQuery && ! document . body . hasAttribute ( 'data-no-jquery' ) ) {
return jQuery ;
}
return null ;
} ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Bootstrap ( v4 . 3.1 ) : dom / data . js
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var mapData = function ( ) {
var storeData = { } ;
var id = 1 ;
2019-03-11 16:13:30 +01:00
return {
2019-04-18 13:47:52 +02:00
set : function set ( element , key , data ) {
2019-03-11 16:13:30 +01:00
if ( typeof element . key === 'undefined' ) {
element . key = {
2019-04-18 13:47:52 +02:00
key : key ,
id : id
2019-03-11 16:13:30 +01:00
} ;
id ++ ;
}
storeData [ element . key . id ] = data ;
} ,
2019-04-18 13:47:52 +02:00
get : function get ( element , key ) {
2019-03-11 16:13:30 +01:00
if ( ! element || typeof element . key === 'undefined' ) {
return null ;
}
2019-04-18 13:47:52 +02:00
var keyProperties = element . key ;
2019-03-11 16:13:30 +01:00
if ( keyProperties . key === key ) {
return storeData [ keyProperties . id ] ;
}
return null ;
} ,
2019-04-18 13:47:52 +02:00
delete : function _delete ( element , key ) {
2019-03-11 16:13:30 +01:00
if ( typeof element . key === 'undefined' ) {
return ;
}
2019-04-18 13:47:52 +02:00
var keyProperties = element . key ;
2019-03-11 16:13:30 +01:00
if ( keyProperties . key === key ) {
delete storeData [ keyProperties . id ] ;
delete element . key ;
}
}
} ;
2019-04-18 13:47:52 +02:00
} ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Data = {
setData : function setData ( instance , key , data ) {
2019-03-11 16:13:30 +01:00
mapData . set ( instance , key , data ) ;
} ,
2019-04-18 13:47:52 +02:00
getData : function getData ( instance , key ) {
2019-03-11 16:13:30 +01:00
return mapData . get ( instance , key ) ;
} ,
2019-04-18 13:47:52 +02:00
removeData : function removeData ( instance , key ) {
2019-03-11 16:13:30 +01:00
mapData . delete ( instance , key ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
/* istanbul ignore file */
var _Element$prototype = Element . prototype ,
matches = _Element$prototype . matches ,
closest = _Element$prototype . closest ;
var find = Element . prototype . querySelectorAll ;
var findOne = Element . prototype . querySelector ;
var createCustomEvent = function createCustomEvent ( eventName , params ) {
var cEvent = new CustomEvent ( eventName , params ) ;
return cEvent ;
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
if ( typeof window . CustomEvent !== 'function' ) {
createCustomEvent = function createCustomEvent ( eventName , params ) {
params = params || {
bubbles : false ,
cancelable : false ,
detail : null
} ;
var evt = document . createEvent ( 'CustomEvent' ) ;
evt . initCustomEvent ( eventName , params . bubbles , params . cancelable , params . detail ) ;
return evt ;
} ;
}
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var workingDefaultPrevented = function ( ) {
var e = document . createEvent ( 'CustomEvent' ) ;
e . initEvent ( 'Bootstrap' , true , true ) ;
e . preventDefault ( ) ;
return e . defaultPrevented ;
} ( ) ;
if ( ! workingDefaultPrevented ) {
var origPreventDefault = Event . prototype . preventDefault ;
Event . prototype . preventDefault = function ( ) {
if ( ! this . cancelable ) {
return ;
}
origPreventDefault . call ( this ) ;
Object . defineProperty ( this , 'defaultPrevented' , {
get : function get ( ) {
return true ;
} ,
configurable : true
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
} ;
} // MSEdge resets defaultPrevented flag upon dispatchEvent call if at least one listener is attached
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var defaultPreventedPreservedOnDispatch = function ( ) {
var e = createCustomEvent ( 'Bootstrap' , {
cancelable : true
} ) ;
var element = document . createElement ( 'div' ) ;
element . addEventListener ( 'Bootstrap' , function ( ) {
return null ;
} ) ;
e . preventDefault ( ) ;
element . dispatchEvent ( e ) ;
return e . defaultPrevented ;
} ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
if ( ! matches ) {
matches = Element . prototype . msMatchesSelector || Element . prototype . webkitMatchesSelector ;
}
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
if ( ! closest ) {
closest = function closest ( selector ) {
var element = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
do {
if ( matches . call ( element , selector ) ) {
return element ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
element = element . parentElement || element . parentNode ;
} while ( element !== null && element . nodeType === 1 ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
return null ;
} ;
}
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var scopeSelectorRegex = /:scope\b/ ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var supportScopeQuery = function ( ) {
var element = document . createElement ( 'div' ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
try {
element . querySelectorAll ( ':scope *' ) ;
2019-10-08 08:39:10 +02:00
} catch ( _ ) {
2019-04-18 13:47:52 +02:00
return false ;
}
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
return true ;
} ( ) ;
if ( ! supportScopeQuery ) {
find = function find ( selector ) {
if ( ! scopeSelectorRegex . test ( selector ) ) {
return this . querySelectorAll ( selector ) ;
}
var hasId = Boolean ( this . id ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
if ( ! hasId ) {
this . id = getUID ( 'scope' ) ;
}
var nodeList = null ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
try {
selector = selector . replace ( scopeSelectorRegex , "#" + this . id ) ;
nodeList = this . querySelectorAll ( selector ) ;
} finally {
if ( ! hasId ) {
this . removeAttribute ( 'id' ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
}
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
return nodeList ;
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
findOne = function findOne ( selector ) {
if ( ! scopeSelectorRegex . test ( selector ) ) {
return this . querySelector ( selector ) ;
}
var matches = find . call ( this , selector ) ;
if ( typeof matches [ 0 ] !== 'undefined' ) {
return matches [ 0 ] ;
}
return null ;
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
}
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2019-05-08 15:11:24 +02:00
* Bootstrap ( v4 . 3.1 ) : dom / event - handler . js
2019-03-11 16:13:30 +01:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-08-27 15:03:21 +02:00
var $ = getjQuery ( ) ;
2019-04-18 13:47:52 +02:00
var namespaceRegex = /[^.]*(?=\..*)\.|.*/ ;
var stripNameRegex = /\..*/ ;
var keyEventRegex = /^key/ ;
var stripUidRegex = /::\d+$/ ;
var eventRegistry = { } ; // Events storage
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var uidEvent = 1 ;
var customEvents = {
2019-03-11 16:13:30 +01:00
mouseenter : 'mouseover' ,
mouseleave : 'mouseout'
} ;
2019-04-18 13:47:52 +02:00
var nativeEvents = [ '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' ] ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Private methods
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
function getUidEvent ( element , uid ) {
2019-04-18 13:47:52 +02:00
return uid && uid + "::" + uidEvent ++ || element . uidEvent || uidEvent ++ ;
2019-03-11 16:13:30 +01:00
}
function getEvent ( element ) {
2019-04-18 13:47:52 +02:00
var uid = getUidEvent ( element ) ;
2019-03-11 16:13:30 +01:00
element . uidEvent = uid ;
eventRegistry [ uid ] = eventRegistry [ uid ] || { } ;
return eventRegistry [ uid ] ;
}
function fixEvent ( event , element ) {
// Add which for key events
if ( event . which === null && keyEventRegex . test ( event . type ) ) {
event . which = event . charCode === null ? event . keyCode : event . charCode ;
}
event . delegateTarget = element ;
}
function bootstrapHandler ( element , fn ) {
return function handler ( event ) {
fixEvent ( event , element ) ;
if ( handler . oneOff ) {
EventHandler . off ( element , event . type , fn ) ;
}
return fn . apply ( element , [ event ] ) ;
} ;
}
function bootstrapDelegationHandler ( element , selector , fn ) {
return function handler ( event ) {
2019-04-18 13:47:52 +02:00
var domElements = element . querySelectorAll ( selector ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
for ( var target = event . target ; target && target !== this ; target = target . parentNode ) {
for ( var i = domElements . length ; i -- ; ) {
2019-03-11 16:13:30 +01:00
if ( domElements [ i ] === target ) {
fixEvent ( event , target ) ;
if ( handler . oneOff ) {
EventHandler . off ( element , event . type , fn ) ;
}
return fn . apply ( target , [ event ] ) ;
}
}
} // To please ESLint
return null ;
} ;
}
function findHandler ( events , handler , delegationSelector ) {
if ( delegationSelector === void 0 ) {
delegationSelector = null ;
}
2019-07-12 23:56:26 +02:00
var uidEventList = Object . keys ( events ) ;
for ( var i = 0 , len = uidEventList . length ; i < len ; i ++ ) {
var event = events [ uidEventList [ i ] ] ;
2019-03-11 16:13:30 +01:00
if ( event . originalHandler === handler && event . delegationSelector === delegationSelector ) {
2019-07-12 23:56:26 +02:00
return event ;
2019-03-11 16:13:30 +01:00
}
}
return null ;
}
function normalizeParams ( originalTypeEvent , handler , delegationFn ) {
2019-04-18 13:47:52 +02:00
var delegation = typeof handler === 'string' ;
var originalHandler = delegation ? delegationFn : handler ; // allow to get the native events from namespaced events ('click.bs.button' --> 'click')
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var typeEvent = originalTypeEvent . replace ( stripNameRegex , '' ) ;
var custom = customEvents [ typeEvent ] ;
2019-03-11 16:13:30 +01:00
if ( custom ) {
typeEvent = custom ;
}
2019-04-18 13:47:52 +02:00
var isNative = nativeEvents . indexOf ( typeEvent ) > - 1 ;
2019-03-11 16:13:30 +01:00
if ( ! isNative ) {
typeEvent = originalTypeEvent ;
}
return [ delegation , originalHandler , typeEvent ] ;
}
function addHandler ( element , originalTypeEvent , handler , delegationFn , oneOff ) {
if ( typeof originalTypeEvent !== 'string' || ! element ) {
return ;
}
if ( ! handler ) {
handler = delegationFn ;
delegationFn = null ;
}
2019-04-18 13:47:52 +02:00
var _normalizeParams = normalizeParams ( originalTypeEvent , handler , delegationFn ) ,
delegation = _normalizeParams [ 0 ] ,
originalHandler = _normalizeParams [ 1 ] ,
typeEvent = _normalizeParams [ 2 ] ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var events = getEvent ( element ) ;
var handlers = events [ typeEvent ] || ( events [ typeEvent ] = { } ) ;
var previousFn = findHandler ( handlers , originalHandler , delegation ? handler : null ) ;
2019-03-11 16:13:30 +01:00
if ( previousFn ) {
previousFn . oneOff = previousFn . oneOff && oneOff ;
return ;
}
2019-04-18 13:47:52 +02:00
var uid = getUidEvent ( originalHandler , originalTypeEvent . replace ( namespaceRegex , '' ) ) ;
var fn = delegation ? bootstrapDelegationHandler ( element , handler , delegationFn ) : bootstrapHandler ( element , handler ) ;
2019-03-11 16:13:30 +01:00
fn . delegationSelector = delegation ? handler : null ;
fn . originalHandler = originalHandler ;
fn . oneOff = oneOff ;
fn . uidEvent = uid ;
handlers [ uid ] = fn ;
element . addEventListener ( typeEvent , fn , delegation ) ;
}
function removeHandler ( element , events , typeEvent , handler , delegationSelector ) {
2019-04-18 13:47:52 +02:00
var fn = findHandler ( events [ typeEvent ] , handler , delegationSelector ) ;
2019-03-11 16:13:30 +01:00
2019-07-12 23:56:26 +02:00
if ( ! fn ) {
2019-03-11 16:13:30 +01:00
return ;
}
element . removeEventListener ( typeEvent , fn , Boolean ( delegationSelector ) ) ;
delete events [ typeEvent ] [ fn . uidEvent ] ;
}
function removeNamespacedHandlers ( element , events , typeEvent , namespace ) {
2019-04-18 13:47:52 +02:00
var storeElementEvent = events [ typeEvent ] || { } ;
Object . keys ( storeElementEvent ) . forEach ( function ( handlerKey ) {
2019-03-11 16:13:30 +01:00
if ( handlerKey . indexOf ( namespace ) > - 1 ) {
2019-04-18 13:47:52 +02:00
var event = storeElementEvent [ handlerKey ] ;
2019-03-11 16:13:30 +01:00
removeHandler ( element , events , typeEvent , event . originalHandler , event . delegationSelector ) ;
}
} ) ;
}
2019-04-18 13:47:52 +02:00
var EventHandler = {
on : function on ( element , event , handler , delegationFn ) {
2019-03-11 16:13:30 +01:00
addHandler ( element , event , handler , delegationFn , false ) ;
} ,
2019-04-18 13:47:52 +02:00
one : function one ( element , event , handler , delegationFn ) {
2019-03-11 16:13:30 +01:00
addHandler ( element , event , handler , delegationFn , true ) ;
} ,
2019-04-18 13:47:52 +02:00
off : function off ( element , originalTypeEvent , handler , delegationFn ) {
2019-03-11 16:13:30 +01:00
if ( typeof originalTypeEvent !== 'string' || ! element ) {
return ;
}
2019-04-18 13:47:52 +02:00
var _normalizeParams2 = normalizeParams ( originalTypeEvent , handler , delegationFn ) ,
delegation = _normalizeParams2 [ 0 ] ,
originalHandler = _normalizeParams2 [ 1 ] ,
typeEvent = _normalizeParams2 [ 2 ] ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var inNamespace = typeEvent !== originalTypeEvent ;
var events = getEvent ( element ) ;
var isNamespace = originalTypeEvent . charAt ( 0 ) === '.' ;
2019-03-11 16:13:30 +01:00
if ( typeof originalHandler !== 'undefined' ) {
// Simplest case: handler is passed, remove that listener ONLY.
if ( ! events || ! events [ typeEvent ] ) {
return ;
}
removeHandler ( element , events , typeEvent , originalHandler , delegation ? handler : null ) ;
return ;
}
if ( isNamespace ) {
2019-04-18 13:47:52 +02:00
Object . keys ( events ) . forEach ( function ( elementEvent ) {
2019-10-08 08:39:10 +02:00
removeNamespacedHandlers ( element , events , elementEvent , originalTypeEvent . slice ( 1 ) ) ;
2019-03-11 16:13:30 +01:00
} ) ;
}
2019-04-18 13:47:52 +02:00
var storeElementEvent = events [ typeEvent ] || { } ;
Object . keys ( storeElementEvent ) . forEach ( function ( keyHandlers ) {
var handlerKey = keyHandlers . replace ( stripUidRegex , '' ) ;
2019-03-11 16:13:30 +01:00
if ( ! inNamespace || originalTypeEvent . indexOf ( handlerKey ) > - 1 ) {
2019-04-18 13:47:52 +02:00
var event = storeElementEvent [ keyHandlers ] ;
2019-03-11 16:13:30 +01:00
removeHandler ( element , events , typeEvent , event . originalHandler , event . delegationSelector ) ;
}
} ) ;
} ,
2019-04-18 13:47:52 +02:00
trigger : function trigger ( element , event , args ) {
2019-03-11 16:13:30 +01:00
if ( typeof event !== 'string' || ! element ) {
return null ;
}
2019-04-18 13:47:52 +02:00
var typeEvent = event . replace ( stripNameRegex , '' ) ;
var inNamespace = event !== typeEvent ;
var isNative = nativeEvents . indexOf ( typeEvent ) > - 1 ;
var jQueryEvent ;
var bubbles = true ;
var nativeDispatch = true ;
var defaultPrevented = false ;
var evt = null ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
if ( inNamespace && $ ) {
jQueryEvent = $ . Event ( event , args ) ;
$ ( element ) . trigger ( jQueryEvent ) ;
2019-03-11 16:13:30 +01:00
bubbles = ! jQueryEvent . isPropagationStopped ( ) ;
nativeDispatch = ! jQueryEvent . isImmediatePropagationStopped ( ) ;
defaultPrevented = jQueryEvent . isDefaultPrevented ( ) ;
}
if ( isNative ) {
evt = document . createEvent ( 'HTMLEvents' ) ;
evt . initEvent ( typeEvent , bubbles , true ) ;
} else {
2019-04-18 13:47:52 +02:00
evt = createCustomEvent ( event , {
bubbles : bubbles ,
2019-03-11 16:13:30 +01:00
cancelable : true
} ) ;
} // merge custom informations in our event
if ( typeof args !== 'undefined' ) {
2019-04-18 13:47:52 +02:00
Object . keys ( args ) . forEach ( function ( key ) {
2019-03-11 16:13:30 +01:00
Object . defineProperty ( evt , key , {
2019-04-18 13:47:52 +02:00
get : function get ( ) {
2019-03-11 16:13:30 +01:00
return args [ key ] ;
}
} ) ;
} ) ;
}
if ( defaultPrevented ) {
evt . preventDefault ( ) ;
2019-04-18 13:47:52 +02:00
if ( ! defaultPreventedPreservedOnDispatch ) {
2019-03-11 16:13:30 +01:00
Object . defineProperty ( evt , 'defaultPrevented' , {
2019-04-18 13:47:52 +02:00
get : function get ( ) {
return true ;
}
2019-03-11 16:13:30 +01:00
} ) ;
}
}
if ( nativeDispatch ) {
element . dispatchEvent ( evt ) ;
}
if ( evt . defaultPrevented && typeof jQueryEvent !== 'undefined' ) {
jQueryEvent . preventDefault ( ) ;
}
return evt ;
}
} ;
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2019-05-08 15:11:24 +02:00
* Bootstrap ( v4 . 3.1 ) : dom / selector - engine . js
2019-03-11 16:13:30 +01:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NODE _TEXT = 3 ;
var SelectorEngine = {
matches : function matches$1 ( element , selector ) {
return matches . call ( element , selector ) ;
2019-03-11 16:13:30 +01:00
} ,
2019-04-18 13:47:52 +02:00
find : function find$1 ( selector , element ) {
2019-03-11 16:13:30 +01:00
if ( element === void 0 ) {
element = document . documentElement ;
}
2019-04-18 13:47:52 +02:00
return find . call ( element , selector ) ;
2019-03-11 16:13:30 +01:00
} ,
2019-04-18 13:47:52 +02:00
findOne : function findOne$1 ( selector , element ) {
2019-03-11 16:13:30 +01:00
if ( element === void 0 ) {
element = document . documentElement ;
}
return findOne . call ( element , selector ) ;
} ,
2019-04-18 13:47:52 +02:00
children : function children ( element , selector ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var children = makeArray ( element . children ) ;
return children . filter ( function ( child ) {
return _this . matches ( child , selector ) ;
} ) ;
2019-03-11 16:13:30 +01:00
} ,
2019-04-18 13:47:52 +02:00
parents : function parents ( element , selector ) {
var parents = [ ] ;
var ancestor = element . parentNode ;
2019-03-11 16:13:30 +01:00
while ( ancestor && ancestor . nodeType === Node . ELEMENT _NODE && ancestor . nodeType !== NODE _TEXT ) {
if ( this . matches ( ancestor , selector ) ) {
parents . push ( ancestor ) ;
}
ancestor = ancestor . parentNode ;
}
return parents ;
} ,
2019-04-18 13:47:52 +02:00
closest : function closest$1 ( element , selector ) {
return closest . call ( element , selector ) ;
2019-03-11 16:13:30 +01:00
} ,
2019-04-18 13:47:52 +02:00
prev : function prev ( element , selector ) {
var siblings = [ ] ;
var previous = element . previousSibling ;
2019-03-11 16:13:30 +01:00
while ( previous && previous . nodeType === Node . ELEMENT _NODE && previous . nodeType !== NODE _TEXT ) {
if ( this . matches ( previous , selector ) ) {
siblings . push ( previous ) ;
}
previous = previous . previousSibling ;
}
return siblings ;
}
} ;
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME = 'alert' ;
var VERSION = '4.3.1' ;
var DATA _KEY = 'bs.alert' ;
var EVENT _KEY = "." + DATA _KEY ;
var DATA _API _KEY = '.data-api' ;
var Selector = {
2019-03-11 16:13:30 +01:00
DISMISS : '[data-dismiss="alert"]'
} ;
2019-04-18 13:47:52 +02:00
var Event$1 = {
CLOSE : "close" + EVENT _KEY ,
CLOSED : "closed" + EVENT _KEY ,
CLICK _DATA _API : "click" + EVENT _KEY + DATA _API _KEY
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName = {
2019-03-11 16:13:30 +01:00
ALERT : 'alert' ,
FADE : 'fade' ,
SHOW : 'show'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Alert =
/*#__PURE__*/
function ( ) {
function Alert ( element ) {
2019-03-11 16:13:30 +01:00
this . _element = element ;
if ( this . _element ) {
Data . setData ( element , DATA _KEY , this ) ;
}
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Alert . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . close = function close ( element ) {
var rootElement = this . _element ;
2019-03-11 16:13:30 +01:00
if ( element ) {
rootElement = this . _getRootElement ( element ) ;
}
2019-04-18 13:47:52 +02:00
var customEvent = this . _triggerCloseEvent ( rootElement ) ;
2019-03-11 16:13:30 +01:00
if ( customEvent === null || customEvent . defaultPrevented ) {
return ;
}
this . _removeElement ( rootElement ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
Data . removeData ( this . _element , DATA _KEY ) ;
this . _element = null ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getRootElement = function _getRootElement ( element ) {
2019-08-27 15:03:21 +02:00
var parent = getElementFromSelector ( element ) ;
2019-03-11 16:13:30 +01:00
if ( ! parent ) {
2019-04-18 13:47:52 +02:00
parent = SelectorEngine . closest ( element , "." + ClassName . ALERT ) ;
2019-03-11 16:13:30 +01:00
}
return parent ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _triggerCloseEvent = function _triggerCloseEvent ( element ) {
2019-03-11 16:13:30 +01:00
return EventHandler . trigger ( element , Event$1 . CLOSE ) ;
2019-04-18 13:47:52 +02:00
} ;
_proto . _removeElement = function _removeElement ( element ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
element . classList . remove ( ClassName . SHOW ) ;
if ( ! element . classList . contains ( ClassName . FADE ) ) {
this . _destroyElement ( element ) ;
return ;
}
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( element ) ;
2019-07-24 08:13:50 +02:00
EventHandler . one ( element , TRANSITION _END , function ( ) {
return _this . _destroyElement ( element ) ;
2019-04-18 13:47:52 +02:00
} ) ;
2019-03-11 16:13:30 +01:00
emulateTransitionEnd ( element , transitionDuration ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _destroyElement = function _destroyElement ( element ) {
2019-03-11 16:13:30 +01:00
if ( element . parentNode ) {
element . parentNode . removeChild ( element ) ;
}
EventHandler . trigger ( element , Event$1 . CLOSED ) ;
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Alert . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY ) ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new Alert ( this ) ;
}
if ( config === 'close' ) {
data [ config ] ( this ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Alert . handleDismiss = function handleDismiss ( alertInstance ) {
2019-03-11 16:13:30 +01:00
return function ( event ) {
if ( event ) {
event . preventDefault ( ) ;
}
alertInstance . close ( this ) ;
} ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Alert . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Alert , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION ;
}
} ] ) ;
return Alert ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-08-27 15:03:21 +02:00
EventHandler . on ( document , Event$1 . CLICK _DATA _API , Selector . DISMISS , Alert . handleDismiss ( new Alert ( ) ) ) ;
var $$1 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . alert to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$1 ) {
var JQUERY _NO _CONFLICT = $$1 . fn [ NAME ] ;
$$1 . fn [ NAME ] = Alert . jQueryInterface ;
$$1 . fn [ NAME ] . Constructor = Alert ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$1 . fn [ NAME ] . noConflict = function ( ) {
$$1 . fn [ NAME ] = JQUERY _NO _CONFLICT ;
return Alert . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$1 = 'button' ;
var VERSION$1 = '4.3.1' ;
var DATA _KEY$1 = 'bs.button' ;
var EVENT _KEY$1 = "." + DATA _KEY$1 ;
var DATA _API _KEY$1 = '.data-api' ;
var ClassName$1 = {
2019-03-11 16:13:30 +01:00
ACTIVE : 'active' ,
BUTTON : 'btn' ,
FOCUS : 'focus'
} ;
2019-04-18 13:47:52 +02:00
var Selector$1 = {
2019-03-11 16:13:30 +01:00
DATA _TOGGLE _CARROT : '[data-toggle^="button"]' ,
DATA _TOGGLE : '[data-toggle="buttons"]' ,
INPUT : 'input:not([type="hidden"])' ,
ACTIVE : '.active' ,
BUTTON : '.btn'
} ;
2019-04-18 13:47:52 +02:00
var Event$2 = {
CLICK _DATA _API : "click" + EVENT _KEY$1 + DATA _API _KEY$1 ,
FOCUS _DATA _API : "focus" + EVENT _KEY$1 + DATA _API _KEY$1 ,
BLUR _DATA _API : "blur" + EVENT _KEY$1 + DATA _API _KEY$1
2019-03-11 16:13:30 +01:00
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Button =
/*#__PURE__*/
function ( ) {
function Button ( element ) {
2019-03-11 16:13:30 +01:00
this . _element = element ;
Data . setData ( element , DATA _KEY$1 , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Button . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . toggle = function toggle ( ) {
var triggerChangeEvent = true ;
var addAriaPressed = true ;
var rootElement = SelectorEngine . closest ( this . _element , Selector$1 . DATA _TOGGLE ) ;
2019-03-11 16:13:30 +01:00
if ( rootElement ) {
2019-04-18 13:47:52 +02:00
var input = SelectorEngine . findOne ( Selector$1 . INPUT , this . _element ) ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
if ( input && input . type === 'radio' ) {
if ( input . checked && this . _element . classList . contains ( ClassName$1 . ACTIVE ) ) {
triggerChangeEvent = false ;
} else {
var activeElement = SelectorEngine . findOne ( Selector$1 . ACTIVE , rootElement ) ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
if ( activeElement ) {
activeElement . classList . remove ( ClassName$1 . ACTIVE ) ;
2019-03-11 16:13:30 +01:00
}
}
if ( triggerChangeEvent ) {
if ( input . hasAttribute ( 'disabled' ) || rootElement . hasAttribute ( 'disabled' ) || input . classList . contains ( 'disabled' ) || rootElement . classList . contains ( 'disabled' ) ) {
return ;
}
input . checked = ! this . _element . classList . contains ( ClassName$1 . ACTIVE ) ;
EventHandler . trigger ( input , 'change' ) ;
}
input . focus ( ) ;
addAriaPressed = false ;
}
}
if ( addAriaPressed ) {
this . _element . setAttribute ( 'aria-pressed' , ! this . _element . classList . contains ( ClassName$1 . ACTIVE ) ) ;
}
if ( triggerChangeEvent ) {
this . _element . classList . toggle ( ClassName$1 . ACTIVE ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
Data . removeData ( this . _element , DATA _KEY$1 ) ;
this . _element = null ;
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Button . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$1 ) ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new Button ( this ) ;
}
if ( config === 'toggle' ) {
data [ config ] ( ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Button . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$1 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Button , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$1 ;
}
} ] ) ;
return Button ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
EventHandler . on ( document , Event$2 . CLICK _DATA _API , Selector$1 . DATA _TOGGLE _CARROT , function ( event ) {
2019-03-11 16:13:30 +01:00
event . preventDefault ( ) ;
2019-04-18 13:47:52 +02:00
var button = event . target ;
2019-03-11 16:13:30 +01:00
if ( ! button . classList . contains ( ClassName$1 . BUTTON ) ) {
button = SelectorEngine . closest ( button , Selector$1 . BUTTON ) ;
}
2019-04-18 13:47:52 +02:00
var data = Data . getData ( button , DATA _KEY$1 ) ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new Button ( button ) ;
}
data . toggle ( ) ;
} ) ;
2019-04-18 13:47:52 +02:00
EventHandler . on ( document , Event$2 . FOCUS _DATA _API , Selector$1 . DATA _TOGGLE _CARROT , function ( event ) {
var button = SelectorEngine . closest ( event . target , Selector$1 . BUTTON ) ;
if ( button ) {
button . classList . add ( ClassName$1 . FOCUS ) ;
}
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
EventHandler . on ( document , Event$2 . BLUR _DATA _API , Selector$1 . DATA _TOGGLE _CARROT , function ( event ) {
var button = SelectorEngine . closest ( event . target , Selector$1 . BUTTON ) ;
if ( button ) {
button . classList . remove ( ClassName$1 . FOCUS ) ;
}
2019-03-11 16:13:30 +01:00
} ) ;
2019-08-27 15:03:21 +02:00
var $$2 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . button to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$2 ) {
var JQUERY _NO _CONFLICT$1 = $$2 . fn [ NAME$1 ] ;
$$2 . fn [ NAME$1 ] = Button . jQueryInterface ;
$$2 . fn [ NAME$1 ] . Constructor = Button ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$2 . fn [ NAME$1 ] . noConflict = function ( ) {
$$2 . fn [ NAME$1 ] = JQUERY _NO _CONFLICT$1 ;
return Button . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Bootstrap ( v4 . 3.1 ) : dom / manipulator . js
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
function normalizeData ( val ) {
if ( val === 'true' ) {
return true ;
}
if ( val === 'false' ) {
return false ;
}
if ( val === Number ( val ) . toString ( ) ) {
return Number ( val ) ;
}
if ( val === '' || val === 'null' ) {
return null ;
}
return val ;
}
function normalizeDataKey ( key ) {
2019-04-18 13:47:52 +02:00
return key . replace ( /[A-Z]/g , function ( chr ) {
2019-11-08 09:11:23 +01:00
return "-" + chr . toLowerCase ( ) ;
2019-04-18 13:47:52 +02:00
} ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
var Manipulator = {
setDataAttribute : function setDataAttribute ( element , key , value ) {
element . setAttribute ( "data-" + normalizeDataKey ( key ) , value ) ;
2019-03-11 16:13:30 +01:00
} ,
2019-04-18 13:47:52 +02:00
removeDataAttribute : function removeDataAttribute ( element , key ) {
element . removeAttribute ( "data-" + normalizeDataKey ( key ) ) ;
2019-03-11 16:13:30 +01:00
} ,
2019-04-18 13:47:52 +02:00
getDataAttributes : function getDataAttributes ( element ) {
2019-03-11 16:13:30 +01:00
if ( ! element ) {
return { } ;
}
2019-07-24 08:13:50 +02:00
var attributes = _objectSpread2 ( { } , element . dataset ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
Object . keys ( attributes ) . forEach ( function ( key ) {
2019-03-11 16:13:30 +01:00
attributes [ key ] = normalizeData ( attributes [ key ] ) ;
} ) ;
return attributes ;
} ,
2019-04-18 13:47:52 +02:00
getDataAttribute : function getDataAttribute ( element , key ) {
return normalizeData ( element . getAttribute ( "data-" + normalizeDataKey ( key ) ) ) ;
2019-03-11 16:13:30 +01:00
} ,
2019-04-18 13:47:52 +02:00
offset : function offset ( element ) {
var rect = element . getBoundingClientRect ( ) ;
2019-03-11 16:13:30 +01:00
return {
top : rect . top + document . body . scrollTop ,
left : rect . left + document . body . scrollLeft
} ;
} ,
2019-04-18 13:47:52 +02:00
position : function position ( element ) {
2019-03-11 16:13:30 +01:00
return {
top : element . offsetTop ,
left : element . offsetLeft
} ;
} ,
2019-04-18 13:47:52 +02:00
toggleClass : function toggleClass ( element , className ) {
2019-03-11 16:13:30 +01:00
if ( ! element ) {
return ;
}
if ( element . classList . contains ( className ) ) {
element . classList . remove ( className ) ;
} else {
element . classList . add ( className ) ;
}
}
} ;
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$2 = 'carousel' ;
var VERSION$2 = '4.3.1' ;
var DATA _KEY$2 = 'bs.carousel' ;
var EVENT _KEY$2 = "." + DATA _KEY$2 ;
var DATA _API _KEY$2 = '.data-api' ;
var ARROW _LEFT _KEYCODE = 37 ; // KeyboardEvent.which value for left arrow key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var ARROW _RIGHT _KEYCODE = 39 ; // KeyboardEvent.which value for right arrow key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var TOUCHEVENT _COMPAT _WAIT = 500 ; // Time for mouse compat events to fire after touch
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var SWIPE _THRESHOLD = 40 ;
var Default = {
2019-03-11 16:13:30 +01:00
interval : 5000 ,
keyboard : true ,
slide : false ,
pause : 'hover' ,
wrap : true ,
touch : true
} ;
2019-04-18 13:47:52 +02:00
var DefaultType = {
2019-03-11 16:13:30 +01:00
interval : '(number|boolean)' ,
keyboard : 'boolean' ,
slide : '(boolean|string)' ,
pause : '(string|boolean)' ,
wrap : 'boolean' ,
touch : 'boolean'
} ;
2019-04-18 13:47:52 +02:00
var Direction = {
2019-03-11 16:13:30 +01:00
NEXT : 'next' ,
PREV : 'prev' ,
LEFT : 'left' ,
RIGHT : 'right'
} ;
2019-04-18 13:47:52 +02:00
var Event$3 = {
SLIDE : "slide" + EVENT _KEY$2 ,
SLID : "slid" + EVENT _KEY$2 ,
KEYDOWN : "keydown" + EVENT _KEY$2 ,
MOUSEENTER : "mouseenter" + EVENT _KEY$2 ,
MOUSELEAVE : "mouseleave" + EVENT _KEY$2 ,
TOUCHSTART : "touchstart" + EVENT _KEY$2 ,
TOUCHMOVE : "touchmove" + EVENT _KEY$2 ,
TOUCHEND : "touchend" + EVENT _KEY$2 ,
POINTERDOWN : "pointerdown" + EVENT _KEY$2 ,
POINTERUP : "pointerup" + EVENT _KEY$2 ,
DRAG _START : "dragstart" + EVENT _KEY$2 ,
LOAD _DATA _API : "load" + EVENT _KEY$2 + DATA _API _KEY$2 ,
CLICK _DATA _API : "click" + EVENT _KEY$2 + DATA _API _KEY$2
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$2 = {
2019-03-11 16:13:30 +01:00
CAROUSEL : 'carousel' ,
ACTIVE : 'active' ,
SLIDE : 'slide' ,
RIGHT : 'carousel-item-right' ,
LEFT : 'carousel-item-left' ,
NEXT : 'carousel-item-next' ,
PREV : 'carousel-item-prev' ,
ITEM : 'carousel-item' ,
POINTER _EVENT : 'pointer-event'
} ;
2019-04-18 13:47:52 +02:00
var Selector$2 = {
2019-03-11 16:13:30 +01:00
ACTIVE : '.active' ,
ACTIVE _ITEM : '.active.carousel-item' ,
ITEM : '.carousel-item' ,
ITEM _IMG : '.carousel-item img' ,
NEXT _PREV : '.carousel-item-next, .carousel-item-prev' ,
INDICATORS : '.carousel-indicators' ,
DATA _SLIDE : '[data-slide], [data-slide-to]' ,
DATA _RIDE : '[data-ride="carousel"]'
} ;
2019-04-18 13:47:52 +02:00
var PointerType = {
2019-03-11 16:13:30 +01:00
TOUCH : 'touch' ,
PEN : 'pen'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Carousel =
/*#__PURE__*/
function ( ) {
function Carousel ( element , config ) {
2019-03-11 16:13:30 +01:00
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 . _element = element ;
this . _indicatorsElement = SelectorEngine . findOne ( Selector$2 . INDICATORS , this . _element ) ;
this . _touchSupported = 'ontouchstart' in document . documentElement || navigator . maxTouchPoints > 0 ;
this . _pointerEvent = Boolean ( window . PointerEvent || window . MSPointerEvent ) ;
this . _addEventListeners ( ) ;
Data . setData ( element , DATA _KEY$2 , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Carousel . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . next = function next ( ) {
2019-03-11 16:13:30 +01:00
if ( ! this . _isSliding ) {
this . _slide ( Direction . NEXT ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . nextWhenVisible = function nextWhenVisible ( ) {
2019-03-11 16:13:30 +01:00
// Don't call next when the page isn't visible
// or the carousel or its parent isn't visible
if ( ! document . hidden && isVisible ( this . _element ) ) {
this . next ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . prev = function prev ( ) {
2019-03-11 16:13:30 +01:00
if ( ! this . _isSliding ) {
this . _slide ( Direction . PREV ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . pause = function pause ( event ) {
2019-03-11 16:13:30 +01:00
if ( ! event ) {
this . _isPaused = true ;
}
if ( SelectorEngine . findOne ( Selector$2 . NEXT _PREV , this . _element ) ) {
triggerTransitionEnd ( this . _element ) ;
this . cycle ( true ) ;
}
clearInterval ( this . _interval ) ;
this . _interval = null ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . cycle = function cycle ( event ) {
2019-03-11 16:13:30 +01:00
if ( ! event ) {
this . _isPaused = false ;
}
if ( this . _interval ) {
clearInterval ( this . _interval ) ;
this . _interval = null ;
}
if ( this . _config && this . _config . interval && ! this . _isPaused ) {
this . _interval = setInterval ( ( document . visibilityState ? this . nextWhenVisible : this . next ) . bind ( this ) , this . _config . interval ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . to = function to ( index ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
this . _activeElement = SelectorEngine . findOne ( Selector$2 . ACTIVE _ITEM , this . _element ) ;
2019-04-18 13:47:52 +02:00
var activeIndex = this . _getItemIndex ( this . _activeElement ) ;
2019-03-11 16:13:30 +01:00
if ( index > this . _items . length - 1 || index < 0 ) {
return ;
}
if ( this . _isSliding ) {
2019-04-18 13:47:52 +02:00
EventHandler . one ( this . _element , Event$3 . SLID , function ( ) {
return _this . to ( index ) ;
} ) ;
2019-03-11 16:13:30 +01:00
return ;
}
if ( activeIndex === index ) {
this . pause ( ) ;
this . cycle ( ) ;
return ;
}
2019-04-18 13:47:52 +02:00
var direction = index > activeIndex ? Direction . NEXT : Direction . PREV ;
2019-03-11 16:13:30 +01:00
this . _slide ( direction , this . _items [ index ] ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
EventHandler . off ( this . _element , EVENT _KEY$2 ) ;
Data . removeData ( this . _element , DATA _KEY$2 ) ;
this . _items = null ;
this . _config = null ;
this . _element = null ;
this . _interval = null ;
this . _isPaused = null ;
this . _isSliding = null ;
this . _activeElement = null ;
this . _indicatorsElement = null ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getConfig = function _getConfig ( config ) {
2019-07-24 08:13:50 +02:00
config = _objectSpread2 ( { } , Default , { } , config ) ;
2019-03-11 16:13:30 +01:00
typeCheckConfig ( NAME$2 , config , DefaultType ) ;
return config ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _handleSwipe = function _handleSwipe ( ) {
var absDeltax = Math . abs ( this . touchDeltaX ) ;
2019-03-11 16:13:30 +01:00
if ( absDeltax <= SWIPE _THRESHOLD ) {
return ;
}
2019-04-18 13:47:52 +02:00
var direction = absDeltax / this . touchDeltaX ;
this . touchDeltaX = 0 ; // swipe left
2019-03-11 16:13:30 +01:00
if ( direction > 0 ) {
this . prev ( ) ;
} // swipe right
if ( direction < 0 ) {
this . next ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . _addEventListeners = function _addEventListeners ( ) {
var _this2 = this ;
2019-03-11 16:13:30 +01:00
if ( this . _config . keyboard ) {
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$3 . KEYDOWN , function ( event ) {
return _this2 . _keydown ( event ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
if ( this . _config . pause === 'hover' ) {
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$3 . MOUSEENTER , function ( event ) {
return _this2 . pause ( event ) ;
} ) ;
EventHandler . on ( this . _element , Event$3 . MOUSELEAVE , function ( event ) {
return _this2 . cycle ( event ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
2019-07-24 08:13:50 +02:00
if ( this . _config . touch && this . _touchSupported ) {
2019-03-11 16:13:30 +01:00
this . _addTouchEventListeners ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . _addTouchEventListeners = function _addTouchEventListeners ( ) {
var _this3 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var start = function start ( event ) {
if ( _this3 . _pointerEvent && PointerType [ event . pointerType . toUpperCase ( ) ] ) {
_this3 . touchStartX = event . clientX ;
} else if ( ! _this3 . _pointerEvent ) {
_this3 . touchStartX = event . touches [ 0 ] . clientX ;
2019-03-11 16:13:30 +01:00
}
} ;
2019-04-18 13:47:52 +02:00
var move = function move ( event ) {
2019-03-11 16:13:30 +01:00
// ensure swiping with one touch and not pinching
if ( event . touches && event . touches . length > 1 ) {
2019-04-18 13:47:52 +02:00
_this3 . touchDeltaX = 0 ;
2019-03-11 16:13:30 +01:00
} else {
2019-04-18 13:47:52 +02:00
_this3 . touchDeltaX = event . touches [ 0 ] . clientX - _this3 . touchStartX ;
2019-03-11 16:13:30 +01:00
}
} ;
2019-04-18 13:47:52 +02:00
var end = function end ( event ) {
if ( _this3 . _pointerEvent && PointerType [ event . pointerType . toUpperCase ( ) ] ) {
_this3 . touchDeltaX = event . clientX - _this3 . touchStartX ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
_this3 . _handleSwipe ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
if ( _this3 . _config . pause === 'hover' ) {
2019-03-11 16:13:30 +01:00
// If it's a touch-enabled device, mouseenter/leave are fired as
// part of the mouse compatibility events on first tap - the carousel
// would stop cycling until user tapped out of it;
// here, we listen for touchend, explicitly pause the carousel
// (as if it's the second time we tap on it, mouseenter compat event
// is NOT fired) and after a timeout (to allow for mouse compatibility
// events to fire) we explicitly restart cycling
2019-04-18 13:47:52 +02:00
_this3 . pause ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
if ( _this3 . touchTimeout ) {
clearTimeout ( _this3 . touchTimeout ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
_this3 . touchTimeout = setTimeout ( function ( event ) {
return _this3 . cycle ( event ) ;
} , TOUCHEVENT _COMPAT _WAIT + _this3 . _config . interval ) ;
2019-03-11 16:13:30 +01:00
}
} ;
2019-04-18 13:47:52 +02:00
makeArray ( SelectorEngine . find ( Selector$2 . ITEM _IMG , this . _element ) ) . forEach ( function ( itemImg ) {
EventHandler . on ( itemImg , Event$3 . DRAG _START , function ( e ) {
return e . preventDefault ( ) ;
} ) ;
2019-03-11 16:13:30 +01:00
} ) ;
if ( this . _pointerEvent ) {
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$3 . POINTERDOWN , function ( event ) {
return start ( event ) ;
} ) ;
EventHandler . on ( this . _element , Event$3 . POINTERUP , function ( event ) {
return end ( event ) ;
} ) ;
2019-03-11 16:13:30 +01:00
this . _element . classList . add ( ClassName$2 . POINTER _EVENT ) ;
} else {
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$3 . TOUCHSTART , function ( event ) {
return start ( event ) ;
} ) ;
EventHandler . on ( this . _element , Event$3 . TOUCHMOVE , function ( event ) {
return move ( event ) ;
} ) ;
EventHandler . on ( this . _element , Event$3 . TOUCHEND , function ( event ) {
return end ( event ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _keydown = function _keydown ( event ) {
2019-03-11 16:13:30 +01:00
if ( /input|textarea/i . test ( event . target . tagName ) ) {
return ;
}
switch ( event . which ) {
case ARROW _LEFT _KEYCODE :
event . preventDefault ( ) ;
this . prev ( ) ;
break ;
case ARROW _RIGHT _KEYCODE :
event . preventDefault ( ) ;
this . next ( ) ;
break ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getItemIndex = function _getItemIndex ( element ) {
2019-03-11 16:13:30 +01:00
this . _items = element && element . parentNode ? makeArray ( SelectorEngine . find ( Selector$2 . ITEM , element . parentNode ) ) : [ ] ;
return this . _items . indexOf ( element ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getItemByDirection = function _getItemByDirection ( direction , activeElement ) {
var isNextDirection = direction === Direction . NEXT ;
var isPrevDirection = direction === Direction . PREV ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var activeIndex = this . _getItemIndex ( activeElement ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var lastItemIndex = this . _items . length - 1 ;
var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex ;
2019-03-11 16:13:30 +01:00
if ( isGoingToWrap && ! this . _config . wrap ) {
return activeElement ;
}
2019-04-18 13:47:52 +02:00
var delta = direction === Direction . PREV ? - 1 : 1 ;
var itemIndex = ( activeIndex + delta ) % this . _items . length ;
2019-03-11 16:13:30 +01:00
return itemIndex === - 1 ? this . _items [ this . _items . length - 1 ] : this . _items [ itemIndex ] ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _triggerSlideEvent = function _triggerSlideEvent ( relatedTarget , eventDirectionName ) {
var targetIndex = this . _getItemIndex ( relatedTarget ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var fromIndex = this . _getItemIndex ( SelectorEngine . findOne ( Selector$2 . ACTIVE _ITEM , this . _element ) ) ;
2019-03-11 16:13:30 +01:00
return EventHandler . trigger ( this . _element , Event$3 . SLIDE , {
2019-04-18 13:47:52 +02:00
relatedTarget : relatedTarget ,
2019-03-11 16:13:30 +01:00
direction : eventDirectionName ,
from : fromIndex ,
to : targetIndex
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _setActiveIndicatorElement = function _setActiveIndicatorElement ( element ) {
2019-03-11 16:13:30 +01:00
if ( this . _indicatorsElement ) {
2019-04-18 13:47:52 +02:00
var indicators = SelectorEngine . find ( Selector$2 . ACTIVE , this . _indicatorsElement ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
for ( var i = 0 ; i < indicators . length ; i ++ ) {
2019-03-11 16:13:30 +01:00
indicators [ i ] . classList . remove ( ClassName$2 . ACTIVE ) ;
}
2019-04-18 13:47:52 +02:00
var nextIndicator = this . _indicatorsElement . children [ this . _getItemIndex ( element ) ] ;
2019-03-11 16:13:30 +01:00
if ( nextIndicator ) {
nextIndicator . classList . add ( ClassName$2 . ACTIVE ) ;
}
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _slide = function _slide ( direction , element ) {
var _this4 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var activeElement = SelectorEngine . findOne ( Selector$2 . ACTIVE _ITEM , this . _element ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var activeElementIndex = this . _getItemIndex ( activeElement ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var nextElement = element || activeElement && this . _getItemByDirection ( direction , activeElement ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var nextElementIndex = this . _getItemIndex ( nextElement ) ;
var isCycling = Boolean ( this . _interval ) ;
var directionalClassName ;
var orderClassName ;
var eventDirectionName ;
2019-03-11 16:13:30 +01:00
if ( direction === Direction . NEXT ) {
directionalClassName = ClassName$2 . LEFT ;
orderClassName = ClassName$2 . NEXT ;
eventDirectionName = Direction . LEFT ;
} else {
directionalClassName = ClassName$2 . RIGHT ;
orderClassName = ClassName$2 . PREV ;
eventDirectionName = Direction . RIGHT ;
}
if ( nextElement && nextElement . classList . contains ( ClassName$2 . ACTIVE ) ) {
this . _isSliding = false ;
return ;
}
2019-04-18 13:47:52 +02:00
var slideEvent = this . _triggerSlideEvent ( nextElement , eventDirectionName ) ;
2019-03-11 16:13:30 +01:00
if ( slideEvent . defaultPrevented ) {
return ;
}
if ( ! activeElement || ! nextElement ) {
// Some weirdness is happening, so we bail
return ;
}
this . _isSliding = true ;
if ( isCycling ) {
this . pause ( ) ;
}
this . _setActiveIndicatorElement ( nextElement ) ;
if ( this . _element . classList . contains ( ClassName$2 . SLIDE ) ) {
nextElement . classList . add ( orderClassName ) ;
reflow ( nextElement ) ;
activeElement . classList . add ( directionalClassName ) ;
nextElement . classList . add ( directionalClassName ) ;
2019-04-18 13:47:52 +02:00
var nextElementInterval = parseInt ( nextElement . getAttribute ( 'data-interval' ) , 10 ) ;
2019-03-11 16:13:30 +01:00
if ( nextElementInterval ) {
this . _config . defaultInterval = this . _config . defaultInterval || this . _config . interval ;
this . _config . interval = nextElementInterval ;
} else {
this . _config . interval = this . _config . defaultInterval || this . _config . interval ;
}
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( activeElement ) ;
EventHandler . one ( activeElement , TRANSITION _END , function ( ) {
2019-03-11 16:13:30 +01:00
nextElement . classList . remove ( directionalClassName ) ;
nextElement . classList . remove ( orderClassName ) ;
nextElement . classList . add ( ClassName$2 . ACTIVE ) ;
activeElement . classList . remove ( ClassName$2 . ACTIVE ) ;
activeElement . classList . remove ( orderClassName ) ;
activeElement . classList . remove ( directionalClassName ) ;
2019-04-18 13:47:52 +02:00
_this4 . _isSliding = false ;
setTimeout ( function ( ) {
EventHandler . trigger ( _this4 . _element , Event$3 . SLID , {
2019-03-11 16:13:30 +01:00
relatedTarget : nextElement ,
direction : eventDirectionName ,
from : activeElementIndex ,
to : nextElementIndex
} ) ;
} , 0 ) ;
} ) ;
emulateTransitionEnd ( activeElement , transitionDuration ) ;
} else {
activeElement . classList . remove ( ClassName$2 . ACTIVE ) ;
nextElement . classList . add ( ClassName$2 . ACTIVE ) ;
this . _isSliding = false ;
EventHandler . trigger ( this . _element , Event$3 . SLID , {
relatedTarget : nextElement ,
direction : eventDirectionName ,
from : activeElementIndex ,
to : nextElementIndex
} ) ;
}
if ( isCycling ) {
this . cycle ( ) ;
}
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Carousel . carouselInterface = function carouselInterface ( element , config ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( element , DATA _KEY$2 ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
var _config = _objectSpread2 ( { } , Default , { } , Manipulator . getDataAttributes ( element ) ) ;
2019-03-11 16:13:30 +01:00
if ( typeof config === 'object' ) {
2019-07-24 08:13:50 +02:00
_config = _objectSpread2 ( { } , _config , { } , config ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
var action = typeof config === 'string' ? config : _config . slide ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new Carousel ( element , _config ) ;
}
if ( typeof config === 'number' ) {
data . to ( config ) ;
} else if ( typeof action === 'string' ) {
if ( typeof data [ action ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + action + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ action ] ( ) ;
} else if ( _config . interval && _config . ride ) {
data . pause ( ) ;
data . cycle ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Carousel . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-08-27 15:03:21 +02:00
Carousel . carouselInterface ( this , config ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Carousel . dataApiClickHandler = function dataApiClickHandler ( event ) {
var target = getElementFromSelector ( this ) ;
2019-03-11 16:13:30 +01:00
if ( ! target || ! target . classList . contains ( ClassName$2 . CAROUSEL ) ) {
return ;
}
2019-07-24 08:13:50 +02:00
var config = _objectSpread2 ( { } , Manipulator . getDataAttributes ( target ) , { } , Manipulator . getDataAttributes ( this ) ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var slideIndex = this . getAttribute ( 'data-slide-to' ) ;
2019-03-11 16:13:30 +01:00
if ( slideIndex ) {
config . interval = false ;
}
2019-08-27 15:03:21 +02:00
Carousel . carouselInterface ( target , config ) ;
2019-03-11 16:13:30 +01:00
if ( slideIndex ) {
Data . getData ( target , DATA _KEY$2 ) . to ( slideIndex ) ;
}
event . preventDefault ( ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Carousel . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$2 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Carousel , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$2 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default ;
}
} ] ) ;
return Carousel ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-08-27 15:03:21 +02:00
EventHandler . on ( document , Event$3 . CLICK _DATA _API , Selector$2 . DATA _SLIDE , Carousel . dataApiClickHandler ) ;
2019-04-18 13:47:52 +02:00
EventHandler . on ( window , Event$3 . LOAD _DATA _API , function ( ) {
var carousels = makeArray ( SelectorEngine . find ( Selector$2 . DATA _RIDE ) ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
for ( var i = 0 , len = carousels . length ; i < len ; i ++ ) {
2019-08-27 15:03:21 +02:00
Carousel . carouselInterface ( carousels [ i ] , Data . getData ( carousels [ i ] , DATA _KEY$2 ) ) ;
2019-03-11 16:13:30 +01:00
}
} ) ;
2019-08-27 15:03:21 +02:00
var $$3 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . carousel to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$3 ) {
var JQUERY _NO _CONFLICT$2 = $$3 . fn [ NAME$2 ] ;
$$3 . fn [ NAME$2 ] = Carousel . jQueryInterface ;
$$3 . fn [ NAME$2 ] . Constructor = Carousel ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$3 . fn [ NAME$2 ] . noConflict = function ( ) {
$$3 . fn [ NAME$2 ] = JQUERY _NO _CONFLICT$2 ;
return Carousel . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$3 = 'collapse' ;
var VERSION$3 = '4.3.1' ;
var DATA _KEY$3 = 'bs.collapse' ;
var EVENT _KEY$3 = "." + DATA _KEY$3 ;
var DATA _API _KEY$3 = '.data-api' ;
var Default$1 = {
2019-03-11 16:13:30 +01:00
toggle : true ,
parent : ''
} ;
2019-04-18 13:47:52 +02:00
var DefaultType$1 = {
2019-03-11 16:13:30 +01:00
toggle : 'boolean' ,
parent : '(string|element)'
} ;
2019-04-18 13:47:52 +02:00
var Event$4 = {
SHOW : "show" + EVENT _KEY$3 ,
SHOWN : "shown" + EVENT _KEY$3 ,
HIDE : "hide" + EVENT _KEY$3 ,
HIDDEN : "hidden" + EVENT _KEY$3 ,
CLICK _DATA _API : "click" + EVENT _KEY$3 + DATA _API _KEY$3
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$3 = {
2019-03-11 16:13:30 +01:00
SHOW : 'show' ,
COLLAPSE : 'collapse' ,
COLLAPSING : 'collapsing' ,
COLLAPSED : 'collapsed'
} ;
2019-04-18 13:47:52 +02:00
var Dimension = {
2019-03-11 16:13:30 +01:00
WIDTH : 'width' ,
HEIGHT : 'height'
} ;
2019-04-18 13:47:52 +02:00
var Selector$3 = {
2019-03-11 16:13:30 +01:00
ACTIVES : '.show, .collapsing' ,
DATA _TOGGLE : '[data-toggle="collapse"]'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Collapse =
/*#__PURE__*/
function ( ) {
function Collapse ( element , config ) {
2019-03-11 16:13:30 +01:00
this . _isTransitioning = false ;
this . _element = element ;
this . _config = this . _getConfig ( config ) ;
2019-04-18 13:47:52 +02:00
this . _triggerArray = makeArray ( SelectorEngine . find ( "[data-toggle=\"collapse\"][href=\"#" + element . id + "\"]," + ( "[data-toggle=\"collapse\"][data-target=\"#" + element . id + "\"]" ) ) ) ;
var toggleList = makeArray ( SelectorEngine . find ( Selector$3 . DATA _TOGGLE ) ) ;
for ( var i = 0 , len = toggleList . length ; i < len ; i ++ ) {
var elem = toggleList [ i ] ;
var selector = getSelectorFromElement ( elem ) ;
var filterElement = makeArray ( SelectorEngine . find ( selector ) ) . filter ( function ( foundElem ) {
return foundElem === element ;
} ) ;
2019-03-11 16:13:30 +01:00
if ( selector !== null && filterElement . length ) {
this . _selector = selector ;
this . _triggerArray . push ( elem ) ;
}
}
this . _parent = this . _config . parent ? this . _getParent ( ) : null ;
if ( ! this . _config . parent ) {
this . _addAriaAndCollapsedClass ( this . _element , this . _triggerArray ) ;
}
if ( this . _config . toggle ) {
this . toggle ( ) ;
}
Data . setData ( element , DATA _KEY$3 , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Collapse . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . toggle = function toggle ( ) {
2019-03-11 16:13:30 +01:00
if ( this . _element . classList . contains ( ClassName$3 . SHOW ) ) {
this . hide ( ) ;
} else {
this . show ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . show = function show ( ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
if ( this . _isTransitioning || this . _element . classList . contains ( ClassName$3 . SHOW ) ) {
return ;
}
2019-04-18 13:47:52 +02:00
var actives ;
var activesData ;
2019-03-11 16:13:30 +01:00
if ( this . _parent ) {
2019-04-18 13:47:52 +02:00
actives = makeArray ( SelectorEngine . find ( Selector$3 . ACTIVES , this . _parent ) ) . filter ( function ( elem ) {
if ( typeof _this . _config . parent === 'string' ) {
return elem . getAttribute ( 'data-parent' ) === _this . _config . parent ;
2019-03-11 16:13:30 +01:00
}
return elem . classList . contains ( ClassName$3 . COLLAPSE ) ;
} ) ;
if ( actives . length === 0 ) {
actives = null ;
}
}
2019-04-18 13:47:52 +02:00
var container = SelectorEngine . findOne ( this . _selector ) ;
2019-03-11 16:13:30 +01:00
if ( actives ) {
2019-04-18 13:47:52 +02:00
var tempActiveData = actives . filter ( function ( elem ) {
return container !== elem ;
} ) ;
2019-03-11 16:13:30 +01:00
activesData = tempActiveData [ 0 ] ? Data . getData ( tempActiveData [ 0 ] , DATA _KEY$3 ) : null ;
if ( activesData && activesData . _isTransitioning ) {
return ;
}
}
2019-04-18 13:47:52 +02:00
var startEvent = EventHandler . trigger ( this . _element , Event$4 . SHOW ) ;
2019-03-11 16:13:30 +01:00
if ( startEvent . defaultPrevented ) {
return ;
}
if ( actives ) {
2019-04-18 13:47:52 +02:00
actives . forEach ( function ( elemActive ) {
2019-03-11 16:13:30 +01:00
if ( container !== elemActive ) {
2019-08-27 15:03:21 +02:00
Collapse . collapseInterface ( elemActive , 'hide' ) ;
2019-03-11 16:13:30 +01:00
}
if ( ! activesData ) {
Data . setData ( elemActive , DATA _KEY$3 , null ) ;
}
} ) ;
}
2019-04-18 13:47:52 +02:00
var dimension = this . _getDimension ( ) ;
2019-03-11 16:13:30 +01:00
this . _element . classList . remove ( ClassName$3 . COLLAPSE ) ;
this . _element . classList . add ( ClassName$3 . COLLAPSING ) ;
this . _element . style [ dimension ] = 0 ;
if ( this . _triggerArray . length ) {
2019-04-18 13:47:52 +02:00
this . _triggerArray . forEach ( function ( element ) {
2019-03-11 16:13:30 +01:00
element . classList . remove ( ClassName$3 . COLLAPSED ) ;
element . setAttribute ( 'aria-expanded' , true ) ;
} ) ;
}
this . setTransitioning ( true ) ;
2019-04-18 13:47:52 +02:00
var complete = function complete ( ) {
_this . _element . classList . remove ( ClassName$3 . COLLAPSING ) ;
_this . _element . classList . add ( ClassName$3 . COLLAPSE ) ;
_this . _element . classList . add ( ClassName$3 . SHOW ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_this . _element . style [ dimension ] = '' ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_this . setTransitioning ( false ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
EventHandler . trigger ( _this . _element , Event$4 . SHOWN ) ;
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var capitalizedDimension = dimension [ 0 ] . toUpperCase ( ) + dimension . slice ( 1 ) ;
var scrollSize = "scroll" + capitalizedDimension ;
var transitionDuration = getTransitionDurationFromElement ( this . _element ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( this . _element , TRANSITION _END , complete ) ;
emulateTransitionEnd ( this . _element , transitionDuration ) ;
2019-04-18 13:47:52 +02:00
this . _element . style [ dimension ] = this . _element [ scrollSize ] + "px" ;
} ;
_proto . hide = function hide ( ) {
var _this2 = this ;
2019-03-11 16:13:30 +01:00
if ( this . _isTransitioning || ! this . _element . classList . contains ( ClassName$3 . SHOW ) ) {
return ;
}
2019-04-18 13:47:52 +02:00
var startEvent = EventHandler . trigger ( this . _element , Event$4 . HIDE ) ;
2019-03-11 16:13:30 +01:00
if ( startEvent . defaultPrevented ) {
return ;
}
2019-04-18 13:47:52 +02:00
var dimension = this . _getDimension ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
this . _element . style [ dimension ] = this . _element . getBoundingClientRect ( ) [ dimension ] + "px" ;
2019-03-11 16:13:30 +01:00
reflow ( this . _element ) ;
this . _element . classList . add ( ClassName$3 . COLLAPSING ) ;
this . _element . classList . remove ( ClassName$3 . COLLAPSE ) ;
this . _element . classList . remove ( ClassName$3 . SHOW ) ;
2019-04-18 13:47:52 +02:00
var triggerArrayLength = this . _triggerArray . length ;
2019-03-11 16:13:30 +01:00
if ( triggerArrayLength > 0 ) {
2019-04-18 13:47:52 +02:00
for ( var i = 0 ; i < triggerArrayLength ; i ++ ) {
var trigger = this . _triggerArray [ i ] ;
2019-08-27 15:03:21 +02:00
var elem = getElementFromSelector ( trigger ) ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
if ( elem && ! elem . classList . contains ( ClassName$3 . SHOW ) ) {
trigger . classList . add ( ClassName$3 . COLLAPSED ) ;
trigger . setAttribute ( 'aria-expanded' , false ) ;
2019-03-11 16:13:30 +01:00
}
}
}
this . setTransitioning ( true ) ;
2019-04-18 13:47:52 +02:00
var complete = function complete ( ) {
_this2 . setTransitioning ( false ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_this2 . _element . classList . remove ( ClassName$3 . COLLAPSING ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_this2 . _element . classList . add ( ClassName$3 . COLLAPSE ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
EventHandler . trigger ( _this2 . _element , Event$4 . HIDDEN ) ;
2019-03-11 16:13:30 +01:00
} ;
this . _element . style [ dimension ] = '' ;
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( this . _element ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( this . _element , TRANSITION _END , complete ) ;
emulateTransitionEnd ( this . _element , transitionDuration ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . setTransitioning = function setTransitioning ( isTransitioning ) {
2019-03-11 16:13:30 +01:00
this . _isTransitioning = isTransitioning ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
Data . removeData ( this . _element , DATA _KEY$3 ) ;
this . _config = null ;
this . _parent = null ;
this . _element = null ;
this . _triggerArray = null ;
this . _isTransitioning = null ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getConfig = function _getConfig ( config ) {
2019-07-24 08:13:50 +02:00
config = _objectSpread2 ( { } , Default$1 , { } , config ) ;
2019-03-11 16:13:30 +01:00
config . toggle = Boolean ( config . toggle ) ; // Coerce string values
typeCheckConfig ( NAME$3 , config , DefaultType$1 ) ;
return config ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getDimension = function _getDimension ( ) {
var hasWidth = this . _element . classList . contains ( Dimension . WIDTH ) ;
2019-03-11 16:13:30 +01:00
return hasWidth ? Dimension . WIDTH : Dimension . HEIGHT ;
2019-04-18 13:47:52 +02:00
} ;
_proto . _getParent = function _getParent ( ) {
var _this3 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var parent = this . _config . parent ;
2019-03-11 16:13:30 +01:00
if ( isElement ( parent ) ) {
// it's a jQuery object
if ( typeof parent . jquery !== 'undefined' || typeof parent [ 0 ] !== 'undefined' ) {
parent = parent [ 0 ] ;
}
} else {
parent = SelectorEngine . findOne ( parent ) ;
}
2019-04-18 13:47:52 +02:00
var selector = "[data-toggle=\"collapse\"][data-parent=\"" + parent + "\"]" ;
makeArray ( SelectorEngine . find ( selector , parent ) ) . forEach ( function ( element ) {
2019-08-27 15:03:21 +02:00
var selected = getElementFromSelector ( element ) ;
2019-07-24 08:13:50 +02:00
_this3 . _addAriaAndCollapsedClass ( selected , [ element ] ) ;
2019-03-11 16:13:30 +01:00
} ) ;
return parent ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _addAriaAndCollapsedClass = function _addAriaAndCollapsedClass ( element , triggerArray ) {
2019-03-11 16:13:30 +01:00
if ( element ) {
2019-04-18 13:47:52 +02:00
var isOpen = element . classList . contains ( ClassName$3 . SHOW ) ;
2019-03-11 16:13:30 +01:00
if ( triggerArray . length ) {
2019-04-18 13:47:52 +02:00
triggerArray . forEach ( function ( elem ) {
2019-03-11 16:13:30 +01:00
if ( isOpen ) {
elem . classList . remove ( ClassName$3 . COLLAPSED ) ;
} else {
elem . classList . add ( ClassName$3 . COLLAPSED ) ;
}
elem . setAttribute ( 'aria-expanded' , isOpen ) ;
} ) ;
}
}
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Collapse . collapseInterface = function collapseInterface ( element , config ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( element , DATA _KEY$3 ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
var _config = _objectSpread2 ( { } , Default$1 , { } , Manipulator . getDataAttributes ( element ) , { } , typeof config === 'object' && config ? config : { } ) ;
2019-03-11 16:13:30 +01:00
if ( ! data && _config . toggle && /show|hide/ . test ( config ) ) {
_config . toggle = false ;
}
if ( ! data ) {
data = new Collapse ( element , _config ) ;
}
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Collapse . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-08-27 15:03:21 +02:00
Collapse . collapseInterface ( this , config ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Collapse . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$3 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Collapse , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$3 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default$1 ;
}
} ] ) ;
return Collapse ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
EventHandler . on ( document , Event$4 . CLICK _DATA _API , Selector$3 . DATA _TOGGLE , function ( event ) {
// preventDefault only for <a> elements (which change the URL) not inside the collapsible element
if ( event . target . tagName === 'A' ) {
event . preventDefault ( ) ;
}
2019-04-18 13:47:52 +02:00
var triggerData = Manipulator . getDataAttributes ( this ) ;
var selector = getSelectorFromElement ( this ) ;
var selectorElements = makeArray ( SelectorEngine . find ( selector ) ) ;
selectorElements . forEach ( function ( element ) {
var data = Data . getData ( element , DATA _KEY$3 ) ;
var config ;
2019-03-11 16:13:30 +01:00
if ( data ) {
// update parent attribute
if ( data . _parent === null && typeof triggerData . parent === 'string' ) {
data . _config . parent = triggerData . parent ;
data . _parent = data . _getParent ( ) ;
}
config = 'toggle' ;
} else {
config = triggerData ;
}
2019-08-27 15:03:21 +02:00
Collapse . collapseInterface ( element , config ) ;
2019-03-11 16:13:30 +01:00
} ) ;
} ) ;
2019-08-27 15:03:21 +02:00
var $$4 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . collapse to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$4 ) {
var JQUERY _NO _CONFLICT$3 = $$4 . fn [ NAME$3 ] ;
$$4 . fn [ NAME$3 ] = Collapse . jQueryInterface ;
$$4 . fn [ NAME$3 ] . Constructor = Collapse ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$4 . fn [ NAME$3 ] . noConflict = function ( ) {
$$4 . fn [ NAME$3 ] = JQUERY _NO _CONFLICT$3 ;
return Collapse . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$4 = 'dropdown' ;
var VERSION$4 = '4.3.1' ;
var DATA _KEY$4 = 'bs.dropdown' ;
var EVENT _KEY$4 = "." + DATA _KEY$4 ;
var DATA _API _KEY$4 = '.data-api' ;
var ESCAPE _KEYCODE = 27 ; // KeyboardEvent.which value for Escape (Esc) key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var SPACE _KEYCODE = 32 ; // KeyboardEvent.which value for space key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var TAB _KEYCODE = 9 ; // KeyboardEvent.which value for tab key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var ARROW _UP _KEYCODE = 38 ; // KeyboardEvent.which value for up arrow key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var ARROW _DOWN _KEYCODE = 40 ; // KeyboardEvent.which value for down arrow key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var RIGHT _MOUSE _BUTTON _WHICH = 3 ; // MouseEvent.which value for the right button (assuming a right-handed mouse)
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var REGEXP _KEYDOWN = new RegExp ( ARROW _UP _KEYCODE + "|" + ARROW _DOWN _KEYCODE + "|" + ESCAPE _KEYCODE ) ;
var Event$5 = {
HIDE : "hide" + EVENT _KEY$4 ,
HIDDEN : "hidden" + EVENT _KEY$4 ,
SHOW : "show" + EVENT _KEY$4 ,
SHOWN : "shown" + EVENT _KEY$4 ,
CLICK : "click" + EVENT _KEY$4 ,
CLICK _DATA _API : "click" + EVENT _KEY$4 + DATA _API _KEY$4 ,
KEYDOWN _DATA _API : "keydown" + EVENT _KEY$4 + DATA _API _KEY$4 ,
KEYUP _DATA _API : "keyup" + EVENT _KEY$4 + DATA _API _KEY$4
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$4 = {
2019-03-11 16:13:30 +01:00
DISABLED : 'disabled' ,
SHOW : 'show' ,
DROPUP : 'dropup' ,
DROPRIGHT : 'dropright' ,
DROPLEFT : 'dropleft' ,
MENURIGHT : 'dropdown-menu-right' ,
POSITION _STATIC : 'position-static'
} ;
2019-04-18 13:47:52 +02:00
var Selector$4 = {
2019-03-11 16:13:30 +01:00
DATA _TOGGLE : '[data-toggle="dropdown"]' ,
FORM _CHILD : '.dropdown form' ,
MENU : '.dropdown-menu' ,
NAVBAR _NAV : '.navbar-nav' ,
VISIBLE _ITEMS : '.dropdown-menu .dropdown-item:not(.disabled):not(:disabled)'
} ;
2019-04-18 13:47:52 +02:00
var AttachmentMap = {
2019-03-11 16:13:30 +01:00
TOP : 'top-start' ,
TOPEND : 'top-end' ,
BOTTOM : 'bottom-start' ,
BOTTOMEND : 'bottom-end' ,
RIGHT : 'right-start' ,
RIGHTEND : 'right-end' ,
LEFT : 'left-start' ,
LEFTEND : 'left-end'
} ;
2019-04-18 13:47:52 +02:00
var Default$2 = {
2019-03-11 16:13:30 +01:00
offset : 0 ,
flip : true ,
boundary : 'scrollParent' ,
reference : 'toggle' ,
2019-08-27 15:03:21 +02:00
display : 'dynamic' ,
popperConfig : null
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var DefaultType$2 = {
2019-03-11 16:13:30 +01:00
offset : '(number|string|function)' ,
flip : 'boolean' ,
boundary : '(string|element)' ,
reference : '(string|element)' ,
2019-08-27 15:03:21 +02:00
display : 'string' ,
popperConfig : '(null|object)'
2019-03-11 16:13:30 +01:00
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Dropdown =
/*#__PURE__*/
function ( ) {
function Dropdown ( element , config ) {
2019-03-11 16:13:30 +01:00
this . _element = element ;
this . _popper = null ;
this . _config = this . _getConfig ( config ) ;
this . _menu = this . _getMenuElement ( ) ;
this . _inNavbar = this . _detectNavbar ( ) ;
this . _addEventListeners ( ) ;
Data . setData ( element , DATA _KEY$4 , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Dropdown . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . toggle = function toggle ( ) {
2019-03-11 16:13:30 +01:00
if ( this . _element . disabled || this . _element . classList . contains ( ClassName$4 . DISABLED ) ) {
return ;
}
2019-04-18 13:47:52 +02:00
var isActive = this . _menu . classList . contains ( ClassName$4 . SHOW ) ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Dropdown . clearMenus ( ) ;
2019-03-11 16:13:30 +01:00
if ( isActive ) {
return ;
}
2019-08-27 15:03:21 +02:00
this . show ( ) ;
} ;
_proto . show = function show ( ) {
if ( this . _element . disabled || this . _element . classList . contains ( ClassName$4 . DISABLED ) || this . _menu . classList . contains ( ClassName$4 . SHOW ) ) {
return ;
}
var parent = Dropdown . getParentFromElement ( this . _element ) ;
2019-04-18 13:47:52 +02:00
var relatedTarget = {
2019-03-11 16:13:30 +01:00
relatedTarget : this . _element
} ;
2019-04-18 13:47:52 +02:00
var showEvent = EventHandler . trigger ( parent , Event$5 . SHOW , relatedTarget ) ;
2019-03-11 16:13:30 +01:00
if ( showEvent . defaultPrevented ) {
return ;
} // Disable totally Popper.js for Dropdown in Navbar
if ( ! this . _inNavbar ) {
if ( typeof Popper === 'undefined' ) {
throw new TypeError ( 'Bootstrap\'s dropdowns require Popper.js (https://popper.js.org)' ) ;
}
2019-04-18 13:47:52 +02:00
var referenceElement = this . _element ;
2019-03-11 16:13:30 +01:00
if ( this . _config . reference === 'parent' ) {
referenceElement = parent ;
} else if ( isElement ( this . _config . reference ) ) {
referenceElement = this . _config . reference ; // Check if it's jQuery element
if ( typeof this . _config . reference . jquery !== 'undefined' ) {
referenceElement = this . _config . reference [ 0 ] ;
}
} // If boundary is not `scrollParent`, then set position to `static`
// to allow the menu to "escape" the scroll parent's boundaries
// https://github.com/twbs/bootstrap/issues/24251
if ( this . _config . boundary !== 'scrollParent' ) {
parent . classList . add ( ClassName$4 . POSITION _STATIC ) ;
}
this . _popper = new Popper ( referenceElement , this . _menu , this . _getPopperConfig ( ) ) ;
} // If this is a touch-enabled device we add extra
// empty mouseover listeners to the body's immediate children;
// only needed because of broken event delegation on iOS
// https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html
if ( 'ontouchstart' in document . documentElement && ! makeArray ( SelectorEngine . closest ( parent , Selector$4 . NAVBAR _NAV ) ) . length ) {
2019-04-18 13:47:52 +02:00
makeArray ( document . body . children ) . forEach ( function ( elem ) {
return EventHandler . on ( elem , 'mouseover' , null , noop ( ) ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
this . _element . focus ( ) ;
this . _element . setAttribute ( 'aria-expanded' , true ) ;
Manipulator . toggleClass ( this . _menu , ClassName$4 . SHOW ) ;
Manipulator . toggleClass ( parent , ClassName$4 . SHOW ) ;
EventHandler . trigger ( parent , Event$5 . SHOWN , relatedTarget ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . hide = function hide ( ) {
2019-03-11 16:13:30 +01:00
if ( this . _element . disabled || this . _element . classList . contains ( ClassName$4 . DISABLED ) || ! this . _menu . classList . contains ( ClassName$4 . SHOW ) ) {
return ;
}
2019-08-27 15:03:21 +02:00
var parent = Dropdown . getParentFromElement ( this . _element ) ;
2019-04-18 13:47:52 +02:00
var relatedTarget = {
2019-03-11 16:13:30 +01:00
relatedTarget : this . _element
} ;
2019-04-18 13:47:52 +02:00
var hideEvent = EventHandler . trigger ( parent , Event$5 . HIDE , relatedTarget ) ;
2019-03-11 16:13:30 +01:00
if ( hideEvent . defaultPrevented ) {
return ;
}
2019-08-27 15:03:21 +02:00
if ( this . _popper ) {
this . _popper . destroy ( ) ;
}
2019-03-11 16:13:30 +01:00
Manipulator . toggleClass ( this . _menu , ClassName$4 . SHOW ) ;
Manipulator . toggleClass ( parent , ClassName$4 . SHOW ) ;
EventHandler . trigger ( parent , Event$5 . HIDDEN , relatedTarget ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
Data . removeData ( this . _element , DATA _KEY$4 ) ;
EventHandler . off ( this . _element , EVENT _KEY$4 ) ;
this . _element = null ;
this . _menu = null ;
2019-08-27 15:03:21 +02:00
if ( this . _popper ) {
2019-03-11 16:13:30 +01:00
this . _popper . destroy ( ) ;
this . _popper = null ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . update = function update ( ) {
2019-03-11 16:13:30 +01:00
this . _inNavbar = this . _detectNavbar ( ) ;
2019-08-27 15:03:21 +02:00
if ( this . _popper ) {
2019-03-11 16:13:30 +01:00
this . _popper . scheduleUpdate ( ) ;
}
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _addEventListeners = function _addEventListeners ( ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$5 . CLICK , function ( event ) {
2019-03-11 16:13:30 +01:00
event . preventDefault ( ) ;
event . stopPropagation ( ) ;
2019-04-18 13:47:52 +02:00
_this . toggle ( ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getConfig = function _getConfig ( config ) {
2019-07-24 08:13:50 +02:00
config = _objectSpread2 ( { } , this . constructor . Default , { } , Manipulator . getDataAttributes ( this . _element ) , { } , config ) ;
2019-03-11 16:13:30 +01:00
typeCheckConfig ( NAME$4 , config , this . constructor . DefaultType ) ;
return config ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getMenuElement = function _getMenuElement ( ) {
2019-08-27 15:03:21 +02:00
var parent = Dropdown . getParentFromElement ( this . _element ) ;
2019-07-24 08:13:50 +02:00
return SelectorEngine . findOne ( Selector$4 . MENU , parent ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getPlacement = function _getPlacement ( ) {
var parentDropdown = this . _element . parentNode ;
var placement = AttachmentMap . BOTTOM ; // Handle dropup
2019-03-11 16:13:30 +01:00
if ( parentDropdown . classList . contains ( ClassName$4 . DROPUP ) ) {
placement = AttachmentMap . TOP ;
if ( this . _menu . classList . contains ( ClassName$4 . MENURIGHT ) ) {
placement = AttachmentMap . TOPEND ;
}
} else if ( parentDropdown . classList . contains ( ClassName$4 . DROPRIGHT ) ) {
placement = AttachmentMap . RIGHT ;
} else if ( parentDropdown . classList . contains ( ClassName$4 . DROPLEFT ) ) {
placement = AttachmentMap . LEFT ;
} else if ( this . _menu . classList . contains ( ClassName$4 . MENURIGHT ) ) {
placement = AttachmentMap . BOTTOMEND ;
}
return placement ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _detectNavbar = function _detectNavbar ( ) {
2019-03-11 16:13:30 +01:00
return Boolean ( SelectorEngine . closest ( this . _element , '.navbar' ) ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getOffset = function _getOffset ( ) {
var _this2 = this ;
var offset = { } ;
2019-03-11 16:13:30 +01:00
if ( typeof this . _config . offset === 'function' ) {
2019-04-18 13:47:52 +02:00
offset . fn = function ( data ) {
2019-07-24 08:13:50 +02:00
data . offsets = _objectSpread2 ( { } , data . offsets , { } , _this2 . _config . offset ( data . offsets , _this2 . _element ) || { } ) ;
2019-03-11 16:13:30 +01:00
return data ;
} ;
} else {
offset . offset = this . _config . offset ;
}
return offset ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getPopperConfig = function _getPopperConfig ( ) {
var popperConfig = {
2019-03-11 16:13:30 +01:00
placement : this . _getPlacement ( ) ,
modifiers : {
offset : this . _getOffset ( ) ,
flip : {
enabled : this . _config . flip
} ,
preventOverflow : {
boundariesElement : this . _config . boundary
}
2019-10-08 08:39:10 +02:00
}
} ; // Disable Popper.js if we have a static display
2019-03-11 16:13:30 +01:00
if ( this . _config . display === 'static' ) {
popperConfig . modifiers . applyStyle = {
enabled : false
} ;
}
2019-08-27 15:03:21 +02:00
return _objectSpread2 ( { } , popperConfig , { } , this . _config . popperConfig ) ;
2019-03-11 16:13:30 +01:00
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Dropdown . dropdownInterface = function dropdownInterface ( element , config ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( element , DATA _KEY$4 ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var _config = typeof config === 'object' ? config : null ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new Dropdown ( element , _config ) ;
}
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Dropdown . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-08-27 15:03:21 +02:00
Dropdown . dropdownInterface ( this , config ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Dropdown . clearMenus = function clearMenus ( event ) {
2019-03-11 16:13:30 +01:00
if ( event && ( event . which === RIGHT _MOUSE _BUTTON _WHICH || event . type === 'keyup' && event . which !== TAB _KEYCODE ) ) {
return ;
}
2019-04-18 13:47:52 +02:00
var toggles = makeArray ( SelectorEngine . find ( Selector$4 . DATA _TOGGLE ) ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
for ( var i = 0 , len = toggles . length ; i < len ; i ++ ) {
2019-08-27 15:03:21 +02:00
var parent = Dropdown . getParentFromElement ( toggles [ i ] ) ;
2019-04-18 13:47:52 +02:00
var context = Data . getData ( toggles [ i ] , DATA _KEY$4 ) ;
var relatedTarget = {
2019-03-11 16:13:30 +01:00
relatedTarget : toggles [ i ]
} ;
if ( event && event . type === 'click' ) {
relatedTarget . clickEvent = event ;
}
if ( ! context ) {
continue ;
}
2019-04-18 13:47:52 +02:00
var dropdownMenu = context . _menu ;
2019-03-11 16:13:30 +01:00
if ( ! parent . classList . contains ( ClassName$4 . SHOW ) ) {
continue ;
}
if ( event && ( event . type === 'click' && /input|textarea/i . test ( event . target . tagName ) || event . type === 'keyup' && event . which === TAB _KEYCODE ) && parent . contains ( event . target ) ) {
continue ;
}
2019-04-18 13:47:52 +02:00
var hideEvent = EventHandler . trigger ( parent , Event$5 . HIDE , relatedTarget ) ;
2019-03-11 16:13:30 +01:00
if ( hideEvent . defaultPrevented ) {
continue ;
} // If this is a touch-enabled device we remove the extra
// empty mouseover listeners we added for iOS support
if ( 'ontouchstart' in document . documentElement ) {
2019-04-18 13:47:52 +02:00
makeArray ( document . body . children ) . forEach ( function ( elem ) {
return EventHandler . off ( elem , 'mouseover' , null , noop ( ) ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
toggles [ i ] . setAttribute ( 'aria-expanded' , 'false' ) ;
2019-08-27 15:03:21 +02:00
if ( context . _popper ) {
context . _popper . destroy ( ) ;
}
2019-03-11 16:13:30 +01:00
dropdownMenu . classList . remove ( ClassName$4 . SHOW ) ;
parent . classList . remove ( ClassName$4 . SHOW ) ;
EventHandler . trigger ( parent , Event$5 . HIDDEN , relatedTarget ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Dropdown . getParentFromElement = function getParentFromElement ( element ) {
return getElementFromSelector ( element ) || element . parentNode ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Dropdown . dataApiKeydownHandler = function dataApiKeydownHandler ( event ) {
2019-03-11 16:13:30 +01:00
// If not input/textarea:
// - And not a key in REGEXP_KEYDOWN => not a dropdown command
// If input/textarea:
// - If space key => not a dropdown command
// - If key is other than escape
// - If key is not up or down => not a dropdown command
// - If trigger inside the menu => not a dropdown command
if ( /input|textarea/i . test ( event . target . tagName ) ? event . which === SPACE _KEYCODE || event . which !== ESCAPE _KEYCODE && ( event . which !== ARROW _DOWN _KEYCODE && event . which !== ARROW _UP _KEYCODE || SelectorEngine . closest ( event . target , Selector$4 . MENU ) ) : ! REGEXP _KEYDOWN . test ( event . which ) ) {
return ;
}
event . preventDefault ( ) ;
event . stopPropagation ( ) ;
if ( this . disabled || this . classList . contains ( ClassName$4 . DISABLED ) ) {
return ;
}
2019-08-27 15:03:21 +02:00
var parent = Dropdown . getParentFromElement ( this ) ;
2019-04-18 13:47:52 +02:00
var isActive = parent . classList . contains ( ClassName$4 . SHOW ) ;
2019-03-11 16:13:30 +01:00
if ( ! isActive || isActive && ( event . which === ESCAPE _KEYCODE || event . which === SPACE _KEYCODE ) ) {
if ( event . which === ESCAPE _KEYCODE ) {
2019-07-12 23:56:26 +02:00
SelectorEngine . findOne ( Selector$4 . DATA _TOGGLE , parent ) . focus ( ) ;
2019-03-11 16:13:30 +01:00
}
2019-08-27 15:03:21 +02:00
Dropdown . clearMenus ( ) ;
2019-03-11 16:13:30 +01:00
return ;
}
2019-11-08 09:11:23 +01:00
var items = makeArray ( SelectorEngine . find ( Selector$4 . VISIBLE _ITEMS , parent ) ) . filter ( isVisible ) ;
2019-03-11 16:13:30 +01:00
if ( ! items . length ) {
return ;
}
2019-04-18 13:47:52 +02:00
var index = items . indexOf ( event . target ) ;
2019-03-11 16:13:30 +01:00
if ( event . which === ARROW _UP _KEYCODE && index > 0 ) {
// Up
index -- ;
}
if ( event . which === ARROW _DOWN _KEYCODE && index < items . length - 1 ) {
// Down
index ++ ;
}
if ( index < 0 ) {
index = 0 ;
}
items [ index ] . focus ( ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Dropdown . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$4 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Dropdown , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$4 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default$2 ;
}
} , {
key : "DefaultType" ,
get : function get ( ) {
return DefaultType$2 ;
}
} ] ) ;
return Dropdown ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-08-27 15:03:21 +02:00
EventHandler . on ( document , Event$5 . KEYDOWN _DATA _API , Selector$4 . DATA _TOGGLE , Dropdown . dataApiKeydownHandler ) ;
EventHandler . on ( document , Event$5 . KEYDOWN _DATA _API , Selector$4 . MENU , Dropdown . dataApiKeydownHandler ) ;
EventHandler . on ( document , Event$5 . CLICK _DATA _API , Dropdown . clearMenus ) ;
EventHandler . on ( document , Event$5 . KEYUP _DATA _API , Dropdown . clearMenus ) ;
2019-03-11 16:13:30 +01:00
EventHandler . on ( document , Event$5 . CLICK _DATA _API , Selector$4 . DATA _TOGGLE , function ( event ) {
event . preventDefault ( ) ;
event . stopPropagation ( ) ;
2019-08-27 15:03:21 +02:00
Dropdown . dropdownInterface ( this , 'toggle' ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
EventHandler . on ( document , Event$5 . CLICK _DATA _API , Selector$4 . FORM _CHILD , function ( e ) {
return e . stopPropagation ( ) ;
} ) ;
2019-08-27 15:03:21 +02:00
var $$5 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . dropdown to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$5 ) {
var JQUERY _NO _CONFLICT$4 = $$5 . fn [ NAME$4 ] ;
$$5 . fn [ NAME$4 ] = Dropdown . jQueryInterface ;
$$5 . fn [ NAME$4 ] . Constructor = Dropdown ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$5 . fn [ NAME$4 ] . noConflict = function ( ) {
$$5 . fn [ NAME$4 ] = JQUERY _NO _CONFLICT$4 ;
return Dropdown . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$5 = 'modal' ;
var VERSION$5 = '4.3.1' ;
var DATA _KEY$5 = 'bs.modal' ;
var EVENT _KEY$5 = "." + DATA _KEY$5 ;
var DATA _API _KEY$5 = '.data-api' ;
var ESCAPE _KEYCODE$1 = 27 ; // KeyboardEvent.which value for Escape (Esc) key
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Default$3 = {
2019-03-11 16:13:30 +01:00
backdrop : true ,
keyboard : true ,
focus : true ,
show : true
} ;
2019-04-18 13:47:52 +02:00
var DefaultType$3 = {
2019-03-11 16:13:30 +01:00
backdrop : '(boolean|string)' ,
keyboard : 'boolean' ,
focus : 'boolean' ,
show : 'boolean'
} ;
2019-04-18 13:47:52 +02:00
var Event$6 = {
HIDE : "hide" + EVENT _KEY$5 ,
2019-11-08 09:11:23 +01:00
HIDE _PREVENTED : "hidePrevented" + EVENT _KEY$5 ,
2019-04-18 13:47:52 +02:00
HIDDEN : "hidden" + EVENT _KEY$5 ,
SHOW : "show" + EVENT _KEY$5 ,
SHOWN : "shown" + EVENT _KEY$5 ,
FOCUSIN : "focusin" + EVENT _KEY$5 ,
RESIZE : "resize" + EVENT _KEY$5 ,
CLICK _DISMISS : "click.dismiss" + EVENT _KEY$5 ,
KEYDOWN _DISMISS : "keydown.dismiss" + EVENT _KEY$5 ,
MOUSEUP _DISMISS : "mouseup.dismiss" + EVENT _KEY$5 ,
MOUSEDOWN _DISMISS : "mousedown.dismiss" + EVENT _KEY$5 ,
CLICK _DATA _API : "click" + EVENT _KEY$5 + DATA _API _KEY$5
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$5 = {
2019-03-11 16:13:30 +01:00
SCROLLABLE : 'modal-dialog-scrollable' ,
SCROLLBAR _MEASURER : 'modal-scrollbar-measure' ,
BACKDROP : 'modal-backdrop' ,
OPEN : 'modal-open' ,
FADE : 'fade' ,
2019-11-08 09:11:23 +01:00
SHOW : 'show' ,
STATIC : 'modal-static'
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var Selector$5 = {
2019-03-11 16:13:30 +01:00
DIALOG : '.modal-dialog' ,
MODAL _BODY : '.modal-body' ,
DATA _TOGGLE : '[data-toggle="modal"]' ,
DATA _DISMISS : '[data-dismiss="modal"]' ,
FIXED _CONTENT : '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top' ,
STICKY _CONTENT : '.sticky-top'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Modal =
/*#__PURE__*/
function ( ) {
function Modal ( element , config ) {
2019-03-11 16:13:30 +01:00
this . _config = this . _getConfig ( config ) ;
this . _element = element ;
this . _dialog = SelectorEngine . findOne ( Selector$5 . DIALOG , element ) ;
this . _backdrop = null ;
this . _isShown = false ;
this . _isBodyOverflowing = false ;
this . _ignoreBackdropClick = false ;
this . _isTransitioning = false ;
this . _scrollbarWidth = 0 ;
Data . setData ( element , DATA _KEY$5 , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Modal . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . toggle = function toggle ( relatedTarget ) {
2019-03-11 16:13:30 +01:00
return this . _isShown ? this . hide ( ) : this . show ( relatedTarget ) ;
2019-04-18 13:47:52 +02:00
} ;
_proto . show = function show ( relatedTarget ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
if ( this . _isShown || this . _isTransitioning ) {
return ;
}
if ( this . _element . classList . contains ( ClassName$5 . FADE ) ) {
this . _isTransitioning = true ;
}
2019-04-18 13:47:52 +02:00
var showEvent = EventHandler . trigger ( this . _element , Event$6 . SHOW , {
relatedTarget : relatedTarget
2019-03-11 16:13:30 +01:00
} ) ;
if ( this . _isShown || showEvent . defaultPrevented ) {
return ;
}
this . _isShown = true ;
this . _checkScrollbar ( ) ;
this . _setScrollbar ( ) ;
this . _adjustDialog ( ) ;
this . _setEscapeEvent ( ) ;
this . _setResizeEvent ( ) ;
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$6 . CLICK _DISMISS , Selector$5 . DATA _DISMISS , function ( event ) {
return _this . hide ( event ) ;
} ) ;
EventHandler . on ( this . _dialog , Event$6 . MOUSEDOWN _DISMISS , function ( ) {
EventHandler . one ( _this . _element , Event$6 . MOUSEUP _DISMISS , function ( event ) {
if ( event . target === _this . _element ) {
_this . _ignoreBackdropClick = true ;
2019-03-11 16:13:30 +01:00
}
} ) ;
} ) ;
2019-04-18 13:47:52 +02:00
this . _showBackdrop ( function ( ) {
return _this . _showElement ( relatedTarget ) ;
} ) ;
} ;
_proto . hide = function hide ( event ) {
var _this2 = this ;
2019-03-11 16:13:30 +01:00
if ( event ) {
event . preventDefault ( ) ;
}
if ( ! this . _isShown || this . _isTransitioning ) {
return ;
}
2019-04-18 13:47:52 +02:00
var hideEvent = EventHandler . trigger ( this . _element , Event$6 . HIDE ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
if ( hideEvent . defaultPrevented ) {
2019-03-11 16:13:30 +01:00
return ;
}
this . _isShown = false ;
2019-04-18 13:47:52 +02:00
var transition = this . _element . classList . contains ( ClassName$5 . FADE ) ;
2019-03-11 16:13:30 +01:00
if ( transition ) {
this . _isTransitioning = true ;
}
this . _setEscapeEvent ( ) ;
this . _setResizeEvent ( ) ;
EventHandler . off ( document , Event$6 . FOCUSIN ) ;
this . _element . classList . remove ( ClassName$5 . SHOW ) ;
EventHandler . off ( this . _element , Event$6 . CLICK _DISMISS ) ;
EventHandler . off ( this . _dialog , Event$6 . MOUSEDOWN _DISMISS ) ;
if ( transition ) {
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( this . _element ) ;
EventHandler . one ( this . _element , TRANSITION _END , function ( event ) {
return _this2 . _hideModal ( event ) ;
} ) ;
2019-03-11 16:13:30 +01:00
emulateTransitionEnd ( this . _element , transitionDuration ) ;
} else {
this . _hideModal ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
[ window , this . _element , this . _dialog ] . forEach ( function ( htmlElement ) {
return EventHandler . off ( htmlElement , EVENT _KEY$5 ) ;
} ) ;
2019-03-11 16:13:30 +01:00
/ * *
* ` document ` has 2 events ` Event.FOCUSIN ` and ` Event.CLICK_DATA_API `
* Do not move ` document ` in ` htmlElements ` array
* It will remove ` Event.CLICK_DATA_API ` event that should remain
* /
EventHandler . off ( document , Event$6 . FOCUSIN ) ;
Data . removeData ( this . _element , DATA _KEY$5 ) ;
this . _config = null ;
this . _element = null ;
this . _dialog = null ;
this . _backdrop = null ;
this . _isShown = null ;
this . _isBodyOverflowing = null ;
this . _ignoreBackdropClick = null ;
this . _isTransitioning = null ;
this . _scrollbarWidth = null ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . handleUpdate = function handleUpdate ( ) {
2019-03-11 16:13:30 +01:00
this . _adjustDialog ( ) ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getConfig = function _getConfig ( config ) {
2019-07-24 08:13:50 +02:00
config = _objectSpread2 ( { } , Default$3 , { } , config ) ;
2019-03-11 16:13:30 +01:00
typeCheckConfig ( NAME$5 , config , DefaultType$3 ) ;
return config ;
2019-04-18 13:47:52 +02:00
} ;
_proto . _showElement = function _showElement ( relatedTarget ) {
var _this3 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var transition = this . _element . classList . contains ( ClassName$5 . FADE ) ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
var modalBody = SelectorEngine . findOne ( Selector$5 . MODAL _BODY , this . _dialog ) ;
2019-03-11 16:13:30 +01:00
if ( ! this . _element . parentNode || this . _element . parentNode . nodeType !== Node . ELEMENT _NODE ) {
// Don't move modal's DOM position
document . body . appendChild ( this . _element ) ;
}
this . _element . style . display = 'block' ;
this . _element . removeAttribute ( 'aria-hidden' ) ;
this . _element . setAttribute ( 'aria-modal' , true ) ;
2019-08-27 15:03:21 +02:00
if ( this . _dialog . classList . contains ( ClassName$5 . SCROLLABLE ) && modalBody ) {
modalBody . scrollTop = 0 ;
2019-03-11 16:13:30 +01:00
} else {
this . _element . scrollTop = 0 ;
}
if ( transition ) {
reflow ( this . _element ) ;
}
this . _element . classList . add ( ClassName$5 . SHOW ) ;
if ( this . _config . focus ) {
this . _enforceFocus ( ) ;
}
2019-04-18 13:47:52 +02:00
var transitionComplete = function transitionComplete ( ) {
if ( _this3 . _config . focus ) {
_this3 . _element . focus ( ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
_this3 . _isTransitioning = false ;
EventHandler . trigger ( _this3 . _element , Event$6 . SHOWN , {
relatedTarget : relatedTarget
2019-03-11 16:13:30 +01:00
} ) ;
} ;
if ( transition ) {
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( this . _dialog ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( this . _dialog , TRANSITION _END , transitionComplete ) ;
emulateTransitionEnd ( this . _dialog , transitionDuration ) ;
} else {
transitionComplete ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . _enforceFocus = function _enforceFocus ( ) {
var _this4 = this ;
2019-03-11 16:13:30 +01:00
EventHandler . off ( document , Event$6 . FOCUSIN ) ; // guard against infinite focus loop
2019-04-18 13:47:52 +02:00
EventHandler . on ( document , Event$6 . FOCUSIN , function ( event ) {
if ( document !== event . target && _this4 . _element !== event . target && ! _this4 . _element . contains ( event . target ) ) {
_this4 . _element . focus ( ) ;
2019-03-11 16:13:30 +01:00
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
_proto . _setEscapeEvent = function _setEscapeEvent ( ) {
var _this5 = this ;
2019-03-11 16:13:30 +01:00
if ( this . _isShown && this . _config . keyboard ) {
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$6 . KEYDOWN _DISMISS , function ( event ) {
2019-03-11 16:13:30 +01:00
if ( event . which === ESCAPE _KEYCODE$1 ) {
2019-11-08 09:11:23 +01:00
_this5 . _triggerBackdropTransition ( ) ;
2019-03-11 16:13:30 +01:00
}
} ) ;
2019-07-24 08:13:50 +02:00
} else {
2019-03-11 16:13:30 +01:00
EventHandler . off ( this . _element , Event$6 . KEYDOWN _DISMISS ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . _setResizeEvent = function _setResizeEvent ( ) {
var _this6 = this ;
2019-03-11 16:13:30 +01:00
if ( this . _isShown ) {
2019-07-24 08:13:50 +02:00
EventHandler . on ( window , Event$6 . RESIZE , function ( ) {
return _this6 . _adjustDialog ( ) ;
2019-04-18 13:47:52 +02:00
} ) ;
2019-03-11 16:13:30 +01:00
} else {
EventHandler . off ( window , Event$6 . RESIZE ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . _hideModal = function _hideModal ( ) {
var _this7 = this ;
2019-03-11 16:13:30 +01:00
this . _element . style . display = 'none' ;
this . _element . setAttribute ( 'aria-hidden' , true ) ;
this . _element . removeAttribute ( 'aria-modal' ) ;
this . _isTransitioning = false ;
2019-04-18 13:47:52 +02:00
this . _showBackdrop ( function ( ) {
2019-03-11 16:13:30 +01:00
document . body . classList . remove ( ClassName$5 . OPEN ) ;
2019-04-18 13:47:52 +02:00
_this7 . _resetAdjustments ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_this7 . _resetScrollbar ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
EventHandler . trigger ( _this7 . _element , Event$6 . HIDDEN ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _removeBackdrop = function _removeBackdrop ( ) {
2019-07-24 08:13:50 +02:00
this . _backdrop . parentNode . removeChild ( this . _backdrop ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
this . _backdrop = null ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _showBackdrop = function _showBackdrop ( callback ) {
var _this8 = this ;
var animate = this . _element . classList . contains ( ClassName$5 . FADE ) ? ClassName$5 . FADE : '' ;
2019-03-11 16:13:30 +01:00
if ( this . _isShown && this . _config . backdrop ) {
this . _backdrop = document . createElement ( 'div' ) ;
this . _backdrop . className = ClassName$5 . BACKDROP ;
if ( animate ) {
this . _backdrop . classList . add ( animate ) ;
}
document . body . appendChild ( this . _backdrop ) ;
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$6 . CLICK _DISMISS , function ( event ) {
if ( _this8 . _ignoreBackdropClick ) {
_this8 . _ignoreBackdropClick = false ;
2019-03-11 16:13:30 +01:00
return ;
}
if ( event . target !== event . currentTarget ) {
return ;
}
2019-11-08 09:11:23 +01:00
_this8 . _triggerBackdropTransition ( ) ;
2019-03-11 16:13:30 +01:00
} ) ;
if ( animate ) {
reflow ( this . _backdrop ) ;
}
this . _backdrop . classList . add ( ClassName$5 . SHOW ) ;
if ( ! animate ) {
callback ( ) ;
return ;
}
2019-04-18 13:47:52 +02:00
var backdropTransitionDuration = getTransitionDurationFromElement ( this . _backdrop ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( this . _backdrop , TRANSITION _END , callback ) ;
emulateTransitionEnd ( this . _backdrop , backdropTransitionDuration ) ;
} else if ( ! this . _isShown && this . _backdrop ) {
this . _backdrop . classList . remove ( ClassName$5 . SHOW ) ;
2019-04-18 13:47:52 +02:00
var callbackRemove = function callbackRemove ( ) {
_this8 . _removeBackdrop ( ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
callback ( ) ;
2019-03-11 16:13:30 +01:00
} ;
if ( this . _element . classList . contains ( ClassName$5 . FADE ) ) {
2019-04-18 13:47:52 +02:00
var _backdropTransitionDuration = getTransitionDurationFromElement ( this . _backdrop ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( this . _backdrop , TRANSITION _END , callbackRemove ) ;
2019-04-18 13:47:52 +02:00
emulateTransitionEnd ( this . _backdrop , _backdropTransitionDuration ) ;
2019-03-11 16:13:30 +01:00
} else {
callbackRemove ( ) ;
}
2019-07-24 08:13:50 +02:00
} else {
2019-03-11 16:13:30 +01:00
callback ( ) ;
}
2019-11-08 09:11:23 +01:00
} ;
_proto . _triggerBackdropTransition = function _triggerBackdropTransition ( ) {
var _this9 = this ;
if ( this . _config . backdrop === 'static' ) {
var hideEvent = EventHandler . trigger ( this . _element , Event$6 . HIDE _PREVENTED ) ;
if ( hideEvent . defaultPrevented ) {
return ;
}
this . _element . classList . add ( ClassName$5 . STATIC ) ;
var modalTransitionDuration = getTransitionDurationFromElement ( this . _element ) ;
EventHandler . one ( this . _element , TRANSITION _END , function ( ) {
_this9 . _element . classList . remove ( ClassName$5 . STATIC ) ;
} ) ;
emulateTransitionEnd ( this . _element , modalTransitionDuration ) ;
this . _element . focus ( ) ;
} else {
this . hide ( ) ;
}
2019-03-11 16:13:30 +01:00
} // ----------------------------------------------------------------------
// the following methods are used to handle overflowing modals
// ----------------------------------------------------------------------
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _adjustDialog = function _adjustDialog ( ) {
var isModalOverflowing = this . _element . scrollHeight > document . documentElement . clientHeight ;
2019-03-11 16:13:30 +01:00
if ( ! this . _isBodyOverflowing && isModalOverflowing ) {
2019-04-18 13:47:52 +02:00
this . _element . style . paddingLeft = this . _scrollbarWidth + "px" ;
2019-03-11 16:13:30 +01:00
}
if ( this . _isBodyOverflowing && ! isModalOverflowing ) {
2019-04-18 13:47:52 +02:00
this . _element . style . paddingRight = this . _scrollbarWidth + "px" ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _resetAdjustments = function _resetAdjustments ( ) {
2019-03-11 16:13:30 +01:00
this . _element . style . paddingLeft = '' ;
this . _element . style . paddingRight = '' ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _checkScrollbar = function _checkScrollbar ( ) {
var rect = document . body . getBoundingClientRect ( ) ;
2019-03-11 16:13:30 +01:00
this . _isBodyOverflowing = rect . left + rect . right < window . innerWidth ;
this . _scrollbarWidth = this . _getScrollbarWidth ( ) ;
2019-04-18 13:47:52 +02:00
} ;
_proto . _setScrollbar = function _setScrollbar ( ) {
2019-11-08 09:11:23 +01:00
var _this10 = this ;
2019-03-11 16:13:30 +01:00
if ( this . _isBodyOverflowing ) {
// Note: DOMNode.style.paddingRight returns the actual value or '' if not set
// while $(DOMNode).css('padding-right') returns the calculated value or 0 if not set
// Adjust fixed content padding
2019-04-18 13:47:52 +02:00
makeArray ( SelectorEngine . find ( Selector$5 . FIXED _CONTENT ) ) . forEach ( function ( element ) {
var actualPadding = element . style . paddingRight ;
var calculatedPadding = window . getComputedStyle ( element ) [ 'padding-right' ] ;
2019-03-11 16:13:30 +01:00
Manipulator . setDataAttribute ( element , 'padding-right' , actualPadding ) ;
2019-11-08 09:11:23 +01:00
element . style . paddingRight = parseFloat ( calculatedPadding ) + _this10 . _scrollbarWidth + "px" ;
2019-03-11 16:13:30 +01:00
} ) ; // Adjust sticky content margin
2019-04-18 13:47:52 +02:00
makeArray ( SelectorEngine . find ( Selector$5 . STICKY _CONTENT ) ) . forEach ( function ( element ) {
var actualMargin = element . style . marginRight ;
var calculatedMargin = window . getComputedStyle ( element ) [ 'margin-right' ] ;
2019-03-11 16:13:30 +01:00
Manipulator . setDataAttribute ( element , 'margin-right' , actualMargin ) ;
2019-11-08 09:11:23 +01:00
element . style . marginRight = parseFloat ( calculatedMargin ) - _this10 . _scrollbarWidth + "px" ;
2019-03-11 16:13:30 +01:00
} ) ; // Adjust body padding
2019-04-18 13:47:52 +02:00
var actualPadding = document . body . style . paddingRight ;
var calculatedPadding = window . getComputedStyle ( document . body ) [ 'padding-right' ] ;
2019-03-11 16:13:30 +01:00
Manipulator . setDataAttribute ( document . body , 'padding-right' , actualPadding ) ;
2019-04-18 13:47:52 +02:00
document . body . style . paddingRight = parseFloat ( calculatedPadding ) + this . _scrollbarWidth + "px" ;
2019-03-11 16:13:30 +01:00
}
document . body . classList . add ( ClassName$5 . OPEN ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _resetScrollbar = function _resetScrollbar ( ) {
2019-03-11 16:13:30 +01:00
// Restore fixed content padding
2019-04-18 13:47:52 +02:00
makeArray ( SelectorEngine . find ( Selector$5 . FIXED _CONTENT ) ) . forEach ( function ( element ) {
var padding = Manipulator . getDataAttribute ( element , 'padding-right' ) ;
2019-03-11 16:13:30 +01:00
if ( typeof padding !== 'undefined' ) {
Manipulator . removeDataAttribute ( element , 'padding-right' ) ;
element . style . paddingRight = padding ;
}
} ) ; // Restore sticky content and navbar-toggler margin
2019-04-18 13:47:52 +02:00
makeArray ( SelectorEngine . find ( "" + Selector$5 . STICKY _CONTENT ) ) . forEach ( function ( element ) {
var margin = Manipulator . getDataAttribute ( element , 'margin-right' ) ;
2019-03-11 16:13:30 +01:00
if ( typeof margin !== 'undefined' ) {
Manipulator . removeDataAttribute ( element , 'margin-right' ) ;
element . style . marginRight = margin ;
}
} ) ; // Restore body padding
2019-04-18 13:47:52 +02:00
var padding = Manipulator . getDataAttribute ( document . body , 'padding-right' ) ;
2019-03-11 16:13:30 +01:00
if ( typeof padding === 'undefined' ) {
document . body . style . paddingRight = '' ;
} else {
Manipulator . removeDataAttribute ( document . body , 'padding-right' ) ;
document . body . style . paddingRight = padding ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getScrollbarWidth = function _getScrollbarWidth ( ) {
2019-03-11 16:13:30 +01:00
// thx d.walsh
2019-04-18 13:47:52 +02:00
var scrollDiv = document . createElement ( 'div' ) ;
2019-03-11 16:13:30 +01:00
scrollDiv . className = ClassName$5 . SCROLLBAR _MEASURER ;
document . body . appendChild ( scrollDiv ) ;
2019-04-18 13:47:52 +02:00
var scrollbarWidth = scrollDiv . getBoundingClientRect ( ) . width - scrollDiv . clientWidth ;
2019-03-11 16:13:30 +01:00
document . body . removeChild ( scrollDiv ) ;
return scrollbarWidth ;
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Modal . jQueryInterface = function jQueryInterface ( config , relatedTarget ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$5 ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
var _config = _objectSpread2 ( { } , Default$3 , { } , Manipulator . getDataAttributes ( this ) , { } , typeof config === 'object' && config ? config : { } ) ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new Modal ( this , _config ) ;
}
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( relatedTarget ) ;
} else if ( _config . show ) {
data . show ( relatedTarget ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Modal . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$5 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Modal , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$5 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default$3 ;
}
} ] ) ;
return Modal ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
EventHandler . on ( document , Event$6 . CLICK _DATA _API , Selector$5 . DATA _TOGGLE , function ( event ) {
2019-11-08 09:11:23 +01:00
var _this11 = this ;
2019-04-18 13:47:52 +02:00
2019-08-27 15:03:21 +02:00
var target = getElementFromSelector ( this ) ;
2019-03-11 16:13:30 +01:00
if ( this . tagName === 'A' || this . tagName === 'AREA' ) {
event . preventDefault ( ) ;
}
2019-04-18 13:47:52 +02:00
EventHandler . one ( target , Event$6 . SHOW , function ( showEvent ) {
2019-03-11 16:13:30 +01:00
if ( showEvent . defaultPrevented ) {
// only register focus restorer if modal will actually get shown
return ;
}
2019-04-18 13:47:52 +02:00
EventHandler . one ( target , Event$6 . HIDDEN , function ( ) {
2019-11-08 09:11:23 +01:00
if ( isVisible ( _this11 ) ) {
_this11 . focus ( ) ;
2019-03-11 16:13:30 +01:00
}
} ) ;
} ) ;
2019-04-18 13:47:52 +02:00
var data = Data . getData ( target , DATA _KEY$5 ) ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
2019-07-24 08:13:50 +02:00
var config = _objectSpread2 ( { } , Manipulator . getDataAttributes ( target ) , { } , Manipulator . getDataAttributes ( this ) ) ;
2019-03-11 16:13:30 +01:00
data = new Modal ( target , config ) ;
}
data . show ( this ) ;
} ) ;
2019-08-27 15:03:21 +02:00
var $$6 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2019-07-24 08:13:50 +02:00
* add . modal to jQuery only if jQuery is present
2019-03-11 16:13:30 +01:00
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$6 ) {
var JQUERY _NO _CONFLICT$5 = $$6 . fn [ NAME$5 ] ;
$$6 . fn [ NAME$5 ] = Modal . jQueryInterface ;
$$6 . fn [ NAME$5 ] . Constructor = Modal ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$6 . fn [ NAME$5 ] . noConflict = function ( ) {
$$6 . fn [ NAME$5 ] = JQUERY _NO _CONFLICT$5 ;
return Modal . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Bootstrap ( v4 . 3.1 ) : util / sanitizer . js
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var uriAttrs = [ 'background' , 'cite' , 'href' , 'itemtype' , 'longdesc' , 'poster' , 'src' , 'xlink:href' ] ;
var ARIA _ATTRIBUTE _PATTERN = /^aria-[\w-]*$/i ;
2019-03-11 16:13:30 +01:00
/ * *
* A pattern that recognizes a commonly useful subset of URLs that are safe .
*
* Shoutout to Angular 7 https : //github.com/angular/angular/blob/7.2.4/packages/core/src/sanitization/url_sanitizer.ts
* /
2019-04-18 13:47:52 +02:00
var SAFE _URL _PATTERN = /^(?:(?:https?|mailto|ftp|tel|file):|[^&:/?#]*(?:[/?#]|$))/gi ;
2019-03-11 16:13:30 +01:00
/ * *
* A pattern that matches safe data URLs . Only matches image , video and audio types .
*
* Shoutout to Angular 7 https : //github.com/angular/angular/blob/7.2.4/packages/core/src/sanitization/url_sanitizer.ts
* /
2019-04-18 13:47:52 +02:00
var DATA _URL _PATTERN = /^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[a-z0-9+/]+=*$/i ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var allowedAttribute = function allowedAttribute ( attr , allowedAttributeList ) {
var attrName = attr . nodeName . toLowerCase ( ) ;
2019-03-11 16:13:30 +01:00
if ( allowedAttributeList . indexOf ( attrName ) !== - 1 ) {
if ( uriAttrs . indexOf ( attrName ) !== - 1 ) {
return Boolean ( attr . nodeValue . match ( SAFE _URL _PATTERN ) || attr . nodeValue . match ( DATA _URL _PATTERN ) ) ;
}
return true ;
}
2019-04-18 13:47:52 +02:00
var regExp = allowedAttributeList . filter ( function ( attrRegex ) {
return attrRegex instanceof RegExp ;
} ) ; // Check if a regular expression validates the attribute.
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
for ( var i = 0 , l = regExp . length ; i < l ; i ++ ) {
2019-03-11 16:13:30 +01:00
if ( attrName . match ( regExp [ i ] ) ) {
return true ;
}
}
return false ;
} ;
2019-04-18 13:47:52 +02:00
var DefaultWhitelist = {
2019-03-11 16:13:30 +01:00
// Global attributes allowed on any supplied element below.
'*' : [ 'class' , 'dir' , 'id' , 'lang' , 'role' , ARIA _ATTRIBUTE _PATTERN ] ,
a : [ 'target' , 'href' , 'title' , 'rel' ] ,
area : [ ] ,
b : [ ] ,
br : [ ] ,
col : [ ] ,
code : [ ] ,
div : [ ] ,
em : [ ] ,
hr : [ ] ,
h1 : [ ] ,
h2 : [ ] ,
h3 : [ ] ,
h4 : [ ] ,
h5 : [ ] ,
h6 : [ ] ,
i : [ ] ,
img : [ 'src' , 'alt' , 'title' , 'width' , 'height' ] ,
li : [ ] ,
ol : [ ] ,
p : [ ] ,
pre : [ ] ,
s : [ ] ,
small : [ ] ,
span : [ ] ,
sub : [ ] ,
sup : [ ] ,
strong : [ ] ,
u : [ ] ,
ul : [ ]
} ;
function sanitizeHtml ( unsafeHtml , whiteList , sanitizeFn ) {
if ( ! unsafeHtml . length ) {
return unsafeHtml ;
}
if ( sanitizeFn && typeof sanitizeFn === 'function' ) {
return sanitizeFn ( unsafeHtml ) ;
}
2019-04-18 13:47:52 +02:00
var domParser = new window . DOMParser ( ) ;
var createdDocument = domParser . parseFromString ( unsafeHtml , 'text/html' ) ;
var whitelistKeys = Object . keys ( whiteList ) ;
var elements = makeArray ( createdDocument . body . querySelectorAll ( '*' ) ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var _loop = function _loop ( i , len ) {
var el = elements [ i ] ;
var elName = el . nodeName . toLowerCase ( ) ;
2019-03-11 16:13:30 +01:00
if ( whitelistKeys . indexOf ( elName ) === - 1 ) {
el . parentNode . removeChild ( el ) ;
2019-04-18 13:47:52 +02:00
return "continue" ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
var attributeList = makeArray ( el . attributes ) ;
var whitelistedAttributes = [ ] . concat ( whiteList [ '*' ] || [ ] , whiteList [ elName ] || [ ] ) ;
attributeList . forEach ( function ( attr ) {
2019-03-11 16:13:30 +01:00
if ( ! allowedAttribute ( attr , whitelistedAttributes ) ) {
el . removeAttribute ( attr . nodeName ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
for ( var i = 0 , len = elements . length ; i < len ; i ++ ) {
2019-07-24 08:13:50 +02:00
var _ret = _loop ( i ) ;
2019-04-18 13:47:52 +02:00
if ( _ret === "continue" ) continue ;
2019-03-11 16:13:30 +01:00
}
return createdDocument . body . innerHTML ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$6 = 'tooltip' ;
var VERSION$6 = '4.3.1' ;
var DATA _KEY$6 = 'bs.tooltip' ;
var EVENT _KEY$6 = "." + DATA _KEY$6 ;
var CLASS _PREFIX = 'bs-tooltip' ;
var BSCLS _PREFIX _REGEX = new RegExp ( "(^|\\s)" + CLASS _PREFIX + "\\S+" , 'g' ) ;
var DISALLOWED _ATTRIBUTES = [ 'sanitize' , 'whiteList' , 'sanitizeFn' ] ;
var DefaultType$4 = {
2019-03-11 16:13:30 +01:00
animation : 'boolean' ,
template : 'string' ,
title : '(string|element|function)' ,
trigger : 'string' ,
delay : '(number|object)' ,
html : 'boolean' ,
selector : '(string|boolean)' ,
placement : '(string|function)' ,
offset : '(number|string|function)' ,
container : '(string|element|boolean)' ,
fallbackPlacement : '(string|array)' ,
boundary : '(string|element)' ,
sanitize : 'boolean' ,
sanitizeFn : '(null|function)' ,
2019-08-27 15:03:21 +02:00
whiteList : 'object' ,
popperConfig : '(null|object)'
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var AttachmentMap$1 = {
2019-03-11 16:13:30 +01:00
AUTO : 'auto' ,
TOP : 'top' ,
RIGHT : 'right' ,
BOTTOM : 'bottom' ,
LEFT : 'left'
} ;
2019-04-18 13:47:52 +02:00
var Default$4 = {
2019-03-11 16:13:30 +01:00
animation : true ,
template : '<div class="tooltip" role="tooltip">' + '<div class="tooltip-arrow"></div>' + '<div class="tooltip-inner"></div></div>' ,
trigger : 'hover focus' ,
title : '' ,
delay : 0 ,
html : false ,
selector : false ,
placement : 'top' ,
offset : 0 ,
container : false ,
fallbackPlacement : 'flip' ,
boundary : 'scrollParent' ,
sanitize : true ,
sanitizeFn : null ,
2019-08-27 15:03:21 +02:00
whiteList : DefaultWhitelist ,
popperConfig : null
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var HoverState = {
2019-03-11 16:13:30 +01:00
SHOW : 'show' ,
OUT : 'out'
} ;
2019-04-18 13:47:52 +02:00
var Event$7 = {
HIDE : "hide" + EVENT _KEY$6 ,
HIDDEN : "hidden" + EVENT _KEY$6 ,
SHOW : "show" + EVENT _KEY$6 ,
SHOWN : "shown" + EVENT _KEY$6 ,
INSERTED : "inserted" + EVENT _KEY$6 ,
CLICK : "click" + EVENT _KEY$6 ,
FOCUSIN : "focusin" + EVENT _KEY$6 ,
FOCUSOUT : "focusout" + EVENT _KEY$6 ,
MOUSEENTER : "mouseenter" + EVENT _KEY$6 ,
MOUSELEAVE : "mouseleave" + EVENT _KEY$6
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$6 = {
2019-03-11 16:13:30 +01:00
FADE : 'fade' ,
SHOW : 'show'
} ;
2019-04-18 13:47:52 +02:00
var Selector$6 = {
2019-07-12 23:56:26 +02:00
TOOLTIP _INNER : '.tooltip-inner'
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var Trigger = {
2019-03-11 16:13:30 +01:00
HOVER : 'hover' ,
FOCUS : 'focus' ,
CLICK : 'click' ,
MANUAL : 'manual'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Tooltip =
/*#__PURE__*/
function ( ) {
function Tooltip ( element , config ) {
2019-03-11 16:13:30 +01:00
if ( typeof Popper === 'undefined' ) {
throw new TypeError ( 'Bootstrap\'s tooltips require Popper.js (https://popper.js.org)' ) ;
} // private
this . _isEnabled = true ;
this . _timeout = 0 ;
this . _hoverState = '' ;
this . _activeTrigger = { } ;
this . _popper = null ; // Protected
this . element = element ;
this . config = this . _getConfig ( config ) ;
this . tip = null ;
this . _setListeners ( ) ;
Data . setData ( element , this . constructor . DATA _KEY , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Tooltip . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . enable = function enable ( ) {
2019-03-11 16:13:30 +01:00
this . _isEnabled = true ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . disable = function disable ( ) {
2019-03-11 16:13:30 +01:00
this . _isEnabled = false ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . toggleEnabled = function toggleEnabled ( ) {
2019-03-11 16:13:30 +01:00
this . _isEnabled = ! this . _isEnabled ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . toggle = function toggle ( event ) {
2019-03-11 16:13:30 +01:00
if ( ! this . _isEnabled ) {
return ;
}
if ( event ) {
2019-04-18 13:47:52 +02:00
var dataKey = this . constructor . DATA _KEY ;
var context = Data . getData ( event . delegateTarget , dataKey ) ;
2019-03-11 16:13:30 +01:00
if ( ! context ) {
context = new this . constructor ( event . delegateTarget , this . _getDelegateConfig ( ) ) ;
Data . setData ( event . delegateTarget , dataKey , context ) ;
}
context . _activeTrigger . click = ! context . _activeTrigger . click ;
if ( context . _isWithActiveTrigger ( ) ) {
context . _enter ( null , context ) ;
} else {
context . _leave ( null , context ) ;
}
} else {
if ( this . getTipElement ( ) . classList . contains ( ClassName$6 . SHOW ) ) {
this . _leave ( null , this ) ;
return ;
}
this . _enter ( null , this ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
clearTimeout ( this . _timeout ) ;
Data . removeData ( this . element , this . constructor . DATA _KEY ) ;
EventHandler . off ( this . element , this . constructor . EVENT _KEY ) ;
2019-07-12 23:56:26 +02:00
EventHandler . off ( SelectorEngine . closest ( this . element , '.modal' ) , 'hide.bs.modal' , this . _hideModalHandler ) ;
2019-03-11 16:13:30 +01:00
if ( this . tip ) {
this . tip . parentNode . removeChild ( this . tip ) ;
}
this . _isEnabled = null ;
this . _timeout = null ;
this . _hoverState = null ;
this . _activeTrigger = null ;
2019-08-27 15:03:21 +02:00
if ( this . _popper ) {
2019-03-11 16:13:30 +01:00
this . _popper . destroy ( ) ;
}
this . _popper = null ;
this . element = null ;
this . config = null ;
this . tip = null ;
2019-04-18 13:47:52 +02:00
} ;
_proto . show = function show ( ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
if ( this . element . style . display === 'none' ) {
throw new Error ( 'Please use show on visible elements' ) ;
}
if ( this . isWithContent ( ) && this . _isEnabled ) {
2019-04-18 13:47:52 +02:00
var showEvent = EventHandler . 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 ) ;
2019-03-11 16:13:30 +01:00
if ( showEvent . defaultPrevented || ! isInTheDom ) {
return ;
}
2019-04-18 13:47:52 +02:00
var tip = this . getTipElement ( ) ;
var tipId = getUID ( this . constructor . NAME ) ;
2019-03-11 16:13:30 +01:00
tip . setAttribute ( 'id' , tipId ) ;
this . element . setAttribute ( 'aria-describedby' , tipId ) ;
this . setContent ( ) ;
if ( this . config . animation ) {
tip . classList . add ( ClassName$6 . FADE ) ;
}
2019-04-18 13:47:52 +02:00
var placement = typeof this . config . placement === 'function' ? this . config . placement . call ( this , tip , this . element ) : this . config . placement ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var attachment = this . _getAttachment ( placement ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
this . _addAttachmentClass ( attachment ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var container = this . _getContainer ( ) ;
2019-03-11 16:13:30 +01:00
Data . setData ( 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 ) ;
2019-08-27 15:03:21 +02:00
this . _popper = new Popper ( this . element , tip , this . _getPopperConfig ( attachment ) ) ;
2019-03-11 16:13:30 +01:00
tip . classList . add ( ClassName$6 . SHOW ) ; // If this is a touch-enabled device we add extra
// empty mouseover listeners to the body's immediate children;
// only needed because of broken event delegation on iOS
// https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html
if ( 'ontouchstart' in document . documentElement ) {
2019-04-18 13:47:52 +02:00
makeArray ( document . body . children ) . forEach ( function ( element ) {
2019-03-11 16:13:30 +01:00
EventHandler . on ( element , 'mouseover' , noop ( ) ) ;
} ) ;
}
2019-04-18 13:47:52 +02:00
var complete = function complete ( ) {
if ( _this . config . animation ) {
_this . _fixTransition ( ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
var prevHoverState = _this . _hoverState ;
_this . _hoverState = null ;
EventHandler . trigger ( _this . element , _this . constructor . Event . SHOWN ) ;
2019-03-11 16:13:30 +01:00
if ( prevHoverState === HoverState . OUT ) {
2019-04-18 13:47:52 +02:00
_this . _leave ( null , _this ) ;
2019-03-11 16:13:30 +01:00
}
} ;
if ( this . tip . classList . contains ( ClassName$6 . FADE ) ) {
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( this . tip ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( this . tip , TRANSITION _END , complete ) ;
emulateTransitionEnd ( this . tip , transitionDuration ) ;
} else {
complete ( ) ;
}
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
_proto . hide = function hide ( ) {
2019-04-18 13:47:52 +02:00
var _this2 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var tip = this . getTipElement ( ) ;
var complete = function complete ( ) {
if ( _this2 . _hoverState !== HoverState . SHOW && tip . parentNode ) {
2019-03-11 16:13:30 +01:00
tip . parentNode . removeChild ( tip ) ;
}
2019-04-18 13:47:52 +02:00
_this2 . _cleanTipClass ( ) ;
_this2 . element . removeAttribute ( 'aria-describedby' ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
EventHandler . trigger ( _this2 . element , _this2 . constructor . Event . HIDDEN ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
_this2 . _popper . destroy ( ) ;
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var hideEvent = EventHandler . trigger ( this . element , this . constructor . Event . HIDE ) ;
2019-03-11 16:13:30 +01:00
if ( hideEvent . defaultPrevented ) {
return ;
}
tip . classList . remove ( ClassName$6 . SHOW ) ; // If this is a touch-enabled device we remove the extra
// empty mouseover listeners we added for iOS support
if ( 'ontouchstart' in document . documentElement ) {
2019-04-18 13:47:52 +02:00
makeArray ( document . body . children ) . forEach ( function ( element ) {
return EventHandler . off ( element , 'mouseover' , noop ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
this . _activeTrigger [ Trigger . CLICK ] = false ;
this . _activeTrigger [ Trigger . FOCUS ] = false ;
this . _activeTrigger [ Trigger . HOVER ] = false ;
if ( this . tip . classList . contains ( ClassName$6 . FADE ) ) {
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( tip ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( tip , TRANSITION _END , complete ) ;
emulateTransitionEnd ( tip , transitionDuration ) ;
} else {
complete ( ) ;
}
this . _hoverState = '' ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . update = function update ( ) {
2019-03-11 16:13:30 +01:00
if ( this . _popper !== null ) {
this . _popper . scheduleUpdate ( ) ;
}
} // Protected
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . isWithContent = function isWithContent ( ) {
2019-03-11 16:13:30 +01:00
return Boolean ( this . getTitle ( ) ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . getTipElement = function getTipElement ( ) {
2019-03-11 16:13:30 +01:00
if ( this . tip ) {
return this . tip ;
}
2019-04-18 13:47:52 +02:00
var element = document . createElement ( 'div' ) ;
2019-03-11 16:13:30 +01:00
element . innerHTML = this . config . template ;
this . tip = element . children [ 0 ] ;
return this . tip ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . setContent = function setContent ( ) {
var tip = this . getTipElement ( ) ;
2019-03-11 16:13:30 +01:00
this . setElementContent ( SelectorEngine . findOne ( Selector$6 . TOOLTIP _INNER , tip ) , this . getTitle ( ) ) ;
tip . classList . remove ( ClassName$6 . FADE ) ;
tip . classList . remove ( ClassName$6 . SHOW ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . setElementContent = function setElementContent ( element , content ) {
2019-03-11 16:13:30 +01:00
if ( element === null ) {
return ;
}
2019-07-24 08:13:50 +02:00
if ( typeof content === 'object' && isElement ( content ) ) {
2019-03-11 16:13:30 +01:00
if ( content . jquery ) {
content = content [ 0 ] ;
} // content is a DOM node or a jQuery
if ( this . config . html ) {
if ( content . parentNode !== element ) {
element . innerHTML = '' ;
element . appendChild ( content ) ;
}
} else {
element . innerText = content . textContent ;
}
return ;
}
if ( this . config . html ) {
if ( this . config . sanitize ) {
content = sanitizeHtml ( content , this . config . whiteList , this . config . sanitizeFn ) ;
}
element . innerHTML = content ;
} else {
element . innerText = content ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . getTitle = function getTitle ( ) {
var title = this . element . getAttribute ( 'data-original-title' ) ;
2019-03-11 16:13:30 +01:00
if ( ! title ) {
title = typeof this . config . title === 'function' ? this . config . title . call ( this . element ) : this . config . title ;
}
return title ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
_proto . _getPopperConfig = function _getPopperConfig ( attachment ) {
var _this3 = this ;
var defaultBsConfig = {
placement : attachment ,
modifiers : {
offset : this . _getOffset ( ) ,
flip : {
behavior : this . config . fallbackPlacement
} ,
arrow : {
element : "." + this . constructor . NAME + "-arrow"
} ,
preventOverflow : {
boundariesElement : this . config . boundary
}
} ,
onCreate : function onCreate ( data ) {
if ( data . originalPlacement !== data . placement ) {
_this3 . _handlePopperPlacementChange ( data ) ;
}
} ,
onUpdate : function onUpdate ( data ) {
return _this3 . _handlePopperPlacementChange ( data ) ;
}
} ;
return _objectSpread2 ( { } , defaultBsConfig , { } , this . config . popperConfig ) ;
} ;
2019-07-24 08:13:50 +02:00
_proto . _addAttachmentClass = function _addAttachmentClass ( attachment ) {
this . getTipElement ( ) . classList . add ( CLASS _PREFIX + "-" + attachment ) ;
} ;
2019-04-18 13:47:52 +02:00
_proto . _getOffset = function _getOffset ( ) {
2019-08-27 15:03:21 +02:00
var _this4 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var offset = { } ;
2019-03-11 16:13:30 +01:00
if ( typeof this . config . offset === 'function' ) {
2019-04-18 13:47:52 +02:00
offset . fn = function ( data ) {
2019-08-27 15:03:21 +02:00
data . offsets = _objectSpread2 ( { } , data . offsets , { } , _this4 . config . offset ( data . offsets , _this4 . element ) || { } ) ;
2019-03-11 16:13:30 +01:00
return data ;
} ;
} else {
offset . offset = this . config . offset ;
}
return offset ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getContainer = function _getContainer ( ) {
2019-03-11 16:13:30 +01:00
if ( this . config . container === false ) {
return document . body ;
}
if ( isElement ( this . config . container ) ) {
return this . config . container ;
}
return SelectorEngine . findOne ( this . config . container ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getAttachment = function _getAttachment ( placement ) {
2019-03-11 16:13:30 +01:00
return AttachmentMap$1 [ placement . toUpperCase ( ) ] ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _setListeners = function _setListeners ( ) {
2019-08-27 15:03:21 +02:00
var _this5 = this ;
2019-04-18 13:47:52 +02:00
var triggers = this . config . trigger . split ( ' ' ) ;
triggers . forEach ( function ( trigger ) {
2019-03-11 16:13:30 +01:00
if ( trigger === 'click' ) {
2019-08-27 15:03:21 +02:00
EventHandler . on ( _this5 . element , _this5 . constructor . Event . CLICK , _this5 . config . selector , function ( event ) {
return _this5 . toggle ( event ) ;
2019-04-18 13:47:52 +02:00
} ) ;
2019-03-11 16:13:30 +01:00
} else if ( trigger !== Trigger . MANUAL ) {
2019-08-27 15:03:21 +02:00
var eventIn = trigger === Trigger . HOVER ? _this5 . constructor . Event . MOUSEENTER : _this5 . constructor . Event . FOCUSIN ;
var eventOut = trigger === Trigger . HOVER ? _this5 . constructor . Event . MOUSELEAVE : _this5 . constructor . Event . FOCUSOUT ;
EventHandler . on ( _this5 . element , eventIn , _this5 . config . selector , function ( event ) {
return _this5 . _enter ( event ) ;
2019-04-18 13:47:52 +02:00
} ) ;
2019-08-27 15:03:21 +02:00
EventHandler . on ( _this5 . element , eventOut , _this5 . config . selector , function ( event ) {
return _this5 . _leave ( event ) ;
2019-04-18 13:47:52 +02:00
} ) ;
2019-03-11 16:13:30 +01:00
}
} ) ;
2019-07-12 23:56:26 +02:00
this . _hideModalHandler = function ( ) {
2019-08-27 15:03:21 +02:00
if ( _this5 . element ) {
_this5 . hide ( ) ;
2019-03-11 16:13:30 +01:00
}
2019-07-12 23:56:26 +02:00
} ;
EventHandler . on ( SelectorEngine . closest ( this . element , '.modal' ) , 'hide.bs.modal' , this . _hideModalHandler ) ;
2019-03-11 16:13:30 +01:00
if ( this . config . selector ) {
2019-07-24 08:13:50 +02:00
this . config = _objectSpread2 ( { } , this . config , {
2019-03-11 16:13:30 +01:00
trigger : 'manual' ,
selector : ''
} ) ;
} else {
this . _fixTitle ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _fixTitle = function _fixTitle ( ) {
var titleType = typeof this . element . getAttribute ( 'data-original-title' ) ;
2019-03-11 16:13:30 +01:00
if ( this . element . getAttribute ( 'title' ) || titleType !== 'string' ) {
this . element . setAttribute ( 'data-original-title' , this . element . getAttribute ( 'title' ) || '' ) ;
this . element . setAttribute ( 'title' , '' ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _enter = function _enter ( event , context ) {
var dataKey = this . constructor . DATA _KEY ;
2019-03-11 16:13:30 +01:00
context = context || Data . getData ( event . delegateTarget , dataKey ) ;
if ( ! context ) {
context = new this . constructor ( event . delegateTarget , this . _getDelegateConfig ( ) ) ;
Data . setData ( event . delegateTarget , dataKey , context ) ;
}
if ( event ) {
context . _activeTrigger [ event . type === 'focusin' ? Trigger . FOCUS : Trigger . HOVER ] = true ;
}
if ( context . getTipElement ( ) . classList . contains ( ClassName$6 . SHOW ) || context . _hoverState === HoverState . SHOW ) {
context . _hoverState = HoverState . SHOW ;
return ;
}
clearTimeout ( context . _timeout ) ;
context . _hoverState = HoverState . SHOW ;
if ( ! context . config . delay || ! context . config . delay . show ) {
context . show ( ) ;
return ;
}
2019-04-18 13:47:52 +02:00
context . _timeout = setTimeout ( function ( ) {
2019-03-11 16:13:30 +01:00
if ( context . _hoverState === HoverState . SHOW ) {
context . show ( ) ;
}
} , context . config . delay . show ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _leave = function _leave ( event , context ) {
var dataKey = this . constructor . DATA _KEY ;
2019-03-11 16:13:30 +01:00
context = context || Data . getData ( event . delegateTarget , dataKey ) ;
if ( ! context ) {
context = new this . constructor ( event . delegateTarget , this . _getDelegateConfig ( ) ) ;
Data . setData ( event . delegateTarget , dataKey , context ) ;
}
if ( event ) {
context . _activeTrigger [ event . type === 'focusout' ? Trigger . FOCUS : Trigger . HOVER ] = false ;
}
if ( context . _isWithActiveTrigger ( ) ) {
return ;
}
clearTimeout ( context . _timeout ) ;
context . _hoverState = HoverState . OUT ;
if ( ! context . config . delay || ! context . config . delay . hide ) {
context . hide ( ) ;
return ;
}
2019-04-18 13:47:52 +02:00
context . _timeout = setTimeout ( function ( ) {
2019-03-11 16:13:30 +01:00
if ( context . _hoverState === HoverState . OUT ) {
context . hide ( ) ;
}
} , context . config . delay . hide ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _isWithActiveTrigger = function _isWithActiveTrigger ( ) {
for ( var trigger in this . _activeTrigger ) {
2019-03-11 16:13:30 +01:00
if ( this . _activeTrigger [ trigger ] ) {
return true ;
}
}
return false ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getConfig = function _getConfig ( config ) {
var dataAttributes = Manipulator . getDataAttributes ( this . element ) ;
Object . keys ( dataAttributes ) . forEach ( function ( dataAttr ) {
2019-03-11 16:13:30 +01:00
if ( DISALLOWED _ATTRIBUTES . indexOf ( dataAttr ) !== - 1 ) {
delete dataAttributes [ dataAttr ] ;
}
} ) ;
if ( config && typeof config . container === 'object' && config . container . jquery ) {
config . container = config . container [ 0 ] ;
}
2019-07-24 08:13:50 +02:00
config = _objectSpread2 ( { } , this . constructor . Default , { } , dataAttributes , { } , typeof config === 'object' && config ? config : { } ) ;
2019-03-11 16:13:30 +01:00
if ( typeof config . delay === 'number' ) {
config . delay = {
show : config . delay ,
hide : config . delay
} ;
}
if ( typeof config . title === 'number' ) {
config . title = config . title . toString ( ) ;
}
if ( typeof config . content === 'number' ) {
config . content = config . content . toString ( ) ;
}
typeCheckConfig ( NAME$6 , config , this . constructor . DefaultType ) ;
if ( config . sanitize ) {
config . template = sanitizeHtml ( config . template , config . whiteList , config . sanitizeFn ) ;
}
return config ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getDelegateConfig = function _getDelegateConfig ( ) {
var config = { } ;
2019-03-11 16:13:30 +01:00
if ( this . config ) {
2019-04-18 13:47:52 +02:00
for ( var key in this . config ) {
2019-03-11 16:13:30 +01:00
if ( this . constructor . Default [ key ] !== this . config [ key ] ) {
config [ key ] = this . config [ key ] ;
}
}
}
return config ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _cleanTipClass = function _cleanTipClass ( ) {
var tip = this . getTipElement ( ) ;
var tabClass = tip . getAttribute ( 'class' ) . match ( BSCLS _PREFIX _REGEX ) ;
2019-03-11 16:13:30 +01:00
if ( tabClass !== null && tabClass . length ) {
2019-04-18 13:47:52 +02:00
tabClass . map ( function ( token ) {
return token . trim ( ) ;
} ) . forEach ( function ( tClass ) {
return tip . classList . remove ( tClass ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _handlePopperPlacementChange = function _handlePopperPlacementChange ( popperData ) {
var popperInstance = popperData . instance ;
2019-03-11 16:13:30 +01:00
this . tip = popperInstance . popper ;
this . _cleanTipClass ( ) ;
2019-07-24 08:13:50 +02:00
this . _addAttachmentClass ( this . _getAttachment ( popperData . placement ) ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _fixTransition = function _fixTransition ( ) {
var tip = this . getTipElement ( ) ;
var initConfigAnimation = this . config . animation ;
2019-03-11 16:13:30 +01:00
if ( tip . getAttribute ( 'x-placement' ) !== null ) {
return ;
}
tip . classList . remove ( ClassName$6 . FADE ) ;
this . config . animation = false ;
this . hide ( ) ;
this . show ( ) ;
this . config . animation = initConfigAnimation ;
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Tooltip . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$6 ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var _config = typeof config === 'object' && config ;
2019-03-11 16:13:30 +01:00
if ( ! data && /dispose|hide/ . test ( config ) ) {
return ;
}
if ( ! data ) {
data = new Tooltip ( this , _config ) ;
}
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Tooltip . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$6 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Tooltip , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$6 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default$4 ;
}
} , {
key : "NAME" ,
get : function get ( ) {
return NAME$6 ;
}
} , {
key : "DATA_KEY" ,
get : function get ( ) {
return DATA _KEY$6 ;
}
} , {
key : "Event" ,
get : function get ( ) {
return Event$7 ;
}
} , {
key : "EVENT_KEY" ,
get : function get ( ) {
return EVENT _KEY$6 ;
}
} , {
key : "DefaultType" ,
get : function get ( ) {
return DefaultType$4 ;
}
} ] ) ;
return Tooltip ;
} ( ) ;
2019-08-27 15:03:21 +02:00
var $$7 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . tooltip to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$7 ) {
var JQUERY _NO _CONFLICT$6 = $$7 . fn [ NAME$6 ] ;
$$7 . fn [ NAME$6 ] = Tooltip . jQueryInterface ;
$$7 . fn [ NAME$6 ] . Constructor = Tooltip ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$7 . fn [ NAME$6 ] . noConflict = function ( ) {
$$7 . fn [ NAME$6 ] = JQUERY _NO _CONFLICT$6 ;
return Tooltip . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$7 = 'popover' ;
var VERSION$7 = '4.3.1' ;
var DATA _KEY$7 = 'bs.popover' ;
var EVENT _KEY$7 = "." + DATA _KEY$7 ;
var CLASS _PREFIX$1 = 'bs-popover' ;
var BSCLS _PREFIX _REGEX$1 = new RegExp ( "(^|\\s)" + CLASS _PREFIX$1 + "\\S+" , 'g' ) ;
2019-03-11 16:13:30 +01:00
2019-07-24 08:13:50 +02:00
var Default$5 = _objectSpread2 ( { } , Tooltip . Default , {
2019-03-11 16:13:30 +01:00
placement : 'right' ,
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>'
} ) ;
2019-07-24 08:13:50 +02:00
var DefaultType$5 = _objectSpread2 ( { } , Tooltip . DefaultType , {
2019-03-11 16:13:30 +01:00
content : '(string|element|function)'
} ) ;
2019-04-18 13:47:52 +02:00
var ClassName$7 = {
2019-03-11 16:13:30 +01:00
FADE : 'fade' ,
SHOW : 'show'
} ;
2019-04-18 13:47:52 +02:00
var Selector$7 = {
2019-03-11 16:13:30 +01:00
TITLE : '.popover-header' ,
CONTENT : '.popover-body'
} ;
2019-04-18 13:47:52 +02:00
var Event$8 = {
HIDE : "hide" + EVENT _KEY$7 ,
HIDDEN : "hidden" + EVENT _KEY$7 ,
SHOW : "show" + EVENT _KEY$7 ,
SHOWN : "shown" + EVENT _KEY$7 ,
INSERTED : "inserted" + EVENT _KEY$7 ,
CLICK : "click" + EVENT _KEY$7 ,
FOCUSIN : "focusin" + EVENT _KEY$7 ,
FOCUSOUT : "focusout" + EVENT _KEY$7 ,
MOUSEENTER : "mouseenter" + EVENT _KEY$7 ,
MOUSELEAVE : "mouseleave" + EVENT _KEY$7
2019-03-11 16:13:30 +01:00
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Popover =
/*#__PURE__*/
function ( _Tooltip ) {
_inheritsLoose ( Popover , _Tooltip ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
function Popover ( ) {
return _Tooltip . apply ( this , arguments ) || this ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
var _proto = Popover . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Overrides
_proto . isWithContent = function isWithContent ( ) {
2019-03-11 16:13:30 +01:00
return this . getTitle ( ) || this . _getContent ( ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . setContent = function setContent ( ) {
var tip = this . getTipElement ( ) ; // we use append for html objects to maintain js events
2019-03-11 16:13:30 +01:00
this . setElementContent ( SelectorEngine . findOne ( Selector$7 . TITLE , tip ) , this . getTitle ( ) ) ;
2019-04-18 13:47:52 +02:00
var content = this . _getContent ( ) ;
2019-03-11 16:13:30 +01:00
if ( typeof content === 'function' ) {
content = content . call ( this . element ) ;
}
this . setElementContent ( SelectorEngine . findOne ( Selector$7 . CONTENT , tip ) , content ) ;
tip . classList . remove ( ClassName$7 . FADE ) ;
tip . classList . remove ( ClassName$7 . SHOW ) ;
2019-08-27 15:03:21 +02:00
} ;
_proto . _addAttachmentClass = function _addAttachmentClass ( attachment ) {
this . getTipElement ( ) . classList . add ( CLASS _PREFIX$1 + "-" + attachment ) ;
2019-03-11 16:13:30 +01:00
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getContent = function _getContent ( ) {
2019-03-11 16:13:30 +01:00
return this . element . getAttribute ( 'data-content' ) || this . config . content ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _cleanTipClass = function _cleanTipClass ( ) {
var tip = this . getTipElement ( ) ;
var tabClass = tip . getAttribute ( 'class' ) . match ( BSCLS _PREFIX _REGEX$1 ) ;
2019-03-11 16:13:30 +01:00
if ( tabClass !== null && tabClass . length > 0 ) {
2019-04-18 13:47:52 +02:00
tabClass . map ( function ( token ) {
return token . trim ( ) ;
} ) . forEach ( function ( tClass ) {
return tip . classList . remove ( tClass ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Popover . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$7 ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var _config = typeof config === 'object' ? config : null ;
2019-03-11 16:13:30 +01:00
if ( ! data && /dispose|hide/ . test ( config ) ) {
return ;
}
if ( ! data ) {
data = new Popover ( this , _config ) ;
Data . setData ( this , DATA _KEY$7 , data ) ;
}
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Popover . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$7 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Popover , null , [ {
key : "VERSION" ,
// Getters
get : function get ( ) {
return VERSION$7 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default$5 ;
}
} , {
key : "NAME" ,
get : function get ( ) {
return NAME$7 ;
}
} , {
key : "DATA_KEY" ,
get : function get ( ) {
return DATA _KEY$7 ;
}
} , {
key : "Event" ,
get : function get ( ) {
return Event$8 ;
}
} , {
key : "EVENT_KEY" ,
get : function get ( ) {
return EVENT _KEY$7 ;
}
} , {
key : "DefaultType" ,
get : function get ( ) {
return DefaultType$5 ;
}
} ] ) ;
return Popover ;
} ( Tooltip ) ;
2019-08-27 15:03:21 +02:00
var $$8 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$8 ) {
var JQUERY _NO _CONFLICT$7 = $$8 . fn [ NAME$7 ] ;
$$8 . fn [ NAME$7 ] = Popover . jQueryInterface ;
$$8 . fn [ NAME$7 ] . Constructor = Popover ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$8 . fn [ NAME$7 ] . noConflict = function ( ) {
$$8 . fn [ NAME$7 ] = JQUERY _NO _CONFLICT$7 ;
return Popover . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$8 = 'scrollspy' ;
var VERSION$8 = '4.3.1' ;
var DATA _KEY$8 = 'bs.scrollspy' ;
var EVENT _KEY$8 = "." + DATA _KEY$8 ;
var DATA _API _KEY$6 = '.data-api' ;
var Default$6 = {
2019-03-11 16:13:30 +01:00
offset : 10 ,
method : 'auto' ,
target : ''
} ;
2019-04-18 13:47:52 +02:00
var DefaultType$6 = {
2019-03-11 16:13:30 +01:00
offset : 'number' ,
method : 'string' ,
target : '(string|element)'
} ;
2019-04-18 13:47:52 +02:00
var Event$9 = {
ACTIVATE : "activate" + EVENT _KEY$8 ,
SCROLL : "scroll" + EVENT _KEY$8 ,
LOAD _DATA _API : "load" + EVENT _KEY$8 + DATA _API _KEY$6
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$8 = {
2019-03-11 16:13:30 +01:00
DROPDOWN _ITEM : 'dropdown-item' ,
ACTIVE : 'active'
} ;
2019-04-18 13:47:52 +02:00
var Selector$8 = {
2019-03-11 16:13:30 +01:00
DATA _SPY : '[data-spy="scroll"]' ,
NAV _LIST _GROUP : '.nav, .list-group' ,
NAV _LINKS : '.nav-link' ,
NAV _ITEMS : '.nav-item' ,
LIST _ITEMS : '.list-group-item' ,
DROPDOWN : '.dropdown' ,
DROPDOWN _TOGGLE : '.dropdown-toggle'
} ;
2019-04-18 13:47:52 +02:00
var OffsetMethod = {
2019-03-11 16:13:30 +01:00
OFFSET : 'offset' ,
POSITION : 'position'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var ScrollSpy =
/*#__PURE__*/
function ( ) {
function ScrollSpy ( element , config ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
this . _element = element ;
this . _scrollElement = element . tagName === 'BODY' ? window : element ;
this . _config = this . _getConfig ( config ) ;
2019-04-18 13:47:52 +02:00
this . _selector = this . _config . target + " " + Selector$8 . NAV _LINKS + "," + ( this . _config . target + " " + Selector$8 . LIST _ITEMS + "," ) + ( this . _config . target + " ." + ClassName$8 . DROPDOWN _ITEM ) ;
2019-03-11 16:13:30 +01:00
this . _offsets = [ ] ;
this . _targets = [ ] ;
this . _activeTarget = null ;
this . _scrollHeight = 0 ;
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _scrollElement , Event$9 . SCROLL , function ( event ) {
return _this . _process ( event ) ;
} ) ;
2019-03-11 16:13:30 +01:00
this . refresh ( ) ;
this . _process ( ) ;
Data . setData ( element , DATA _KEY$8 , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = ScrollSpy . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . refresh = function refresh ( ) {
var _this2 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var autoMethod = this . _scrollElement === this . _scrollElement . window ? OffsetMethod . OFFSET : OffsetMethod . POSITION ;
var offsetMethod = this . _config . method === 'auto' ? autoMethod : this . _config . method ;
var offsetBase = offsetMethod === OffsetMethod . POSITION ? this . _getScrollTop ( ) : 0 ;
2019-03-11 16:13:30 +01:00
this . _offsets = [ ] ;
this . _targets = [ ] ;
this . _scrollHeight = this . _getScrollHeight ( ) ;
2019-04-18 13:47:52 +02:00
var targets = makeArray ( SelectorEngine . find ( this . _selector ) ) ;
targets . map ( function ( element ) {
var target ;
var targetSelector = getSelectorFromElement ( element ) ;
2019-03-11 16:13:30 +01:00
if ( targetSelector ) {
target = SelectorEngine . findOne ( targetSelector ) ;
}
if ( target ) {
2019-04-18 13:47:52 +02:00
var targetBCR = target . getBoundingClientRect ( ) ;
2019-03-11 16:13:30 +01:00
if ( targetBCR . width || targetBCR . height ) {
return [ Manipulator [ offsetMethod ] ( target ) . top + offsetBase , targetSelector ] ;
}
}
return null ;
2019-04-18 13:47:52 +02:00
} ) . filter ( function ( item ) {
return item ;
} ) . sort ( function ( a , b ) {
return a [ 0 ] - b [ 0 ] ;
} ) . forEach ( function ( item ) {
_this2 . _offsets . push ( item [ 0 ] ) ;
_this2 . _targets . push ( item [ 1 ] ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
Data . removeData ( this . _element , DATA _KEY$8 ) ;
EventHandler . off ( this . _scrollElement , EVENT _KEY$8 ) ;
this . _element = null ;
this . _scrollElement = null ;
this . _config = null ;
this . _selector = null ;
this . _offsets = null ;
this . _targets = null ;
this . _activeTarget = null ;
this . _scrollHeight = null ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getConfig = function _getConfig ( config ) {
2019-07-24 08:13:50 +02:00
config = _objectSpread2 ( { } , Default$6 , { } , typeof config === 'object' && config ? config : { } ) ;
2019-03-11 16:13:30 +01:00
if ( typeof config . target !== 'string' ) {
2019-04-18 13:47:52 +02:00
var id = config . target . id ;
2019-03-11 16:13:30 +01:00
if ( ! id ) {
id = getUID ( NAME$8 ) ;
config . target . id = id ;
}
2019-04-18 13:47:52 +02:00
config . target = "#" + id ;
2019-03-11 16:13:30 +01:00
}
typeCheckConfig ( NAME$8 , config , DefaultType$6 ) ;
return config ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getScrollTop = function _getScrollTop ( ) {
2019-03-11 16:13:30 +01:00
return this . _scrollElement === window ? this . _scrollElement . pageYOffset : this . _scrollElement . scrollTop ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getScrollHeight = function _getScrollHeight ( ) {
2019-03-11 16:13:30 +01:00
return this . _scrollElement . scrollHeight || Math . max ( document . body . scrollHeight , document . documentElement . scrollHeight ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getOffsetHeight = function _getOffsetHeight ( ) {
2019-03-11 16:13:30 +01:00
return this . _scrollElement === window ? window . innerHeight : this . _scrollElement . getBoundingClientRect ( ) . height ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _process = function _process ( ) {
var scrollTop = this . _getScrollTop ( ) + this . _config . offset ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var scrollHeight = this . _getScrollHeight ( ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var maxScroll = this . _config . offset + scrollHeight - this . _getOffsetHeight ( ) ;
2019-03-11 16:13:30 +01:00
if ( this . _scrollHeight !== scrollHeight ) {
this . refresh ( ) ;
}
if ( scrollTop >= maxScroll ) {
2019-04-18 13:47:52 +02:00
var target = this . _targets [ this . _targets . length - 1 ] ;
2019-03-11 16:13:30 +01:00
if ( this . _activeTarget !== target ) {
this . _activate ( target ) ;
}
return ;
}
if ( this . _activeTarget && scrollTop < this . _offsets [ 0 ] && this . _offsets [ 0 ] > 0 ) {
this . _activeTarget = null ;
this . _clear ( ) ;
return ;
}
2019-04-18 13:47:52 +02:00
var offsetLength = this . _offsets . length ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
for ( var i = offsetLength ; i -- ; ) {
var isActiveTarget = this . _activeTarget !== this . _targets [ i ] && scrollTop >= this . _offsets [ i ] && ( typeof this . _offsets [ i + 1 ] === 'undefined' || scrollTop < this . _offsets [ i + 1 ] ) ;
2019-03-11 16:13:30 +01:00
if ( isActiveTarget ) {
this . _activate ( this . _targets [ i ] ) ;
}
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _activate = function _activate ( target ) {
2019-03-11 16:13:30 +01:00
this . _activeTarget = target ;
this . _clear ( ) ;
2019-04-18 13:47:52 +02:00
var queries = this . _selector . split ( ',' ) . map ( function ( selector ) {
return selector + "[data-target=\"" + target + "\"]," + selector + "[href=\"" + target + "\"]" ;
} ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var link = SelectorEngine . findOne ( queries . join ( ',' ) ) ;
2019-03-11 16:13:30 +01:00
if ( link . classList . contains ( ClassName$8 . DROPDOWN _ITEM ) ) {
SelectorEngine . findOne ( Selector$8 . DROPDOWN _TOGGLE , SelectorEngine . closest ( link , Selector$8 . DROPDOWN ) ) . classList . add ( ClassName$8 . ACTIVE ) ;
link . classList . add ( ClassName$8 . ACTIVE ) ;
} else {
// Set triggered link as active
link . classList . add ( ClassName$8 . ACTIVE ) ;
2019-04-18 13:47:52 +02:00
SelectorEngine . parents ( link , Selector$8 . NAV _LIST _GROUP ) . forEach ( function ( listGroup ) {
2019-03-11 16:13:30 +01:00
// Set triggered links parents as active
// With both <ul> and <nav> markup a parent is the previous sibling of any nav ancestor
2019-04-18 13:47:52 +02:00
SelectorEngine . prev ( listGroup , Selector$8 . NAV _LINKS + ", " + Selector$8 . LIST _ITEMS ) . forEach ( function ( item ) {
return item . classList . add ( ClassName$8 . ACTIVE ) ;
} ) ; // Handle special case when .nav-link is inside .nav-item
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
SelectorEngine . prev ( listGroup , Selector$8 . NAV _ITEMS ) . forEach ( function ( navItem ) {
SelectorEngine . children ( navItem , Selector$8 . NAV _LINKS ) . forEach ( function ( item ) {
return item . classList . add ( ClassName$8 . ACTIVE ) ;
} ) ;
2019-03-11 16:13:30 +01:00
} ) ;
} ) ;
}
EventHandler . trigger ( this . _scrollElement , Event$9 . ACTIVATE , {
relatedTarget : target
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _clear = function _clear ( ) {
makeArray ( SelectorEngine . find ( this . _selector ) ) . filter ( function ( node ) {
return node . classList . contains ( ClassName$8 . ACTIVE ) ;
} ) . forEach ( function ( node ) {
return node . classList . remove ( ClassName$8 . ACTIVE ) ;
} ) ;
2019-03-11 16:13:30 +01:00
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
ScrollSpy . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$8 ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var _config = typeof config === 'object' && config ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new ScrollSpy ( this , _config ) ;
}
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
ScrollSpy . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$8 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( ScrollSpy , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$8 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default$6 ;
}
} ] ) ;
return ScrollSpy ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
EventHandler . on ( window , Event$9 . LOAD _DATA _API , function ( ) {
makeArray ( SelectorEngine . find ( Selector$8 . DATA _SPY ) ) . forEach ( function ( spy ) {
return new ScrollSpy ( spy , Manipulator . getDataAttributes ( spy ) ) ;
} ) ;
2019-03-11 16:13:30 +01:00
} ) ;
2019-08-27 15:03:21 +02:00
var $$9 = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$9 ) {
var JQUERY _NO _CONFLICT$8 = $$9 . fn [ NAME$8 ] ;
$$9 . fn [ NAME$8 ] = ScrollSpy . jQueryInterface ;
$$9 . fn [ NAME$8 ] . Constructor = ScrollSpy ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$9 . fn [ NAME$8 ] . noConflict = function ( ) {
$$9 . fn [ NAME$8 ] = JQUERY _NO _CONFLICT$8 ;
return ScrollSpy . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$9 = 'tab' ;
var VERSION$9 = '4.3.1' ;
var DATA _KEY$9 = 'bs.tab' ;
var EVENT _KEY$9 = "." + DATA _KEY$9 ;
var DATA _API _KEY$7 = '.data-api' ;
var Event$a = {
HIDE : "hide" + EVENT _KEY$9 ,
HIDDEN : "hidden" + EVENT _KEY$9 ,
SHOW : "show" + EVENT _KEY$9 ,
SHOWN : "shown" + EVENT _KEY$9 ,
CLICK _DATA _API : "click" + EVENT _KEY$9 + DATA _API _KEY$7
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$9 = {
2019-03-11 16:13:30 +01:00
DROPDOWN _MENU : 'dropdown-menu' ,
ACTIVE : 'active' ,
DISABLED : 'disabled' ,
FADE : 'fade' ,
SHOW : 'show'
} ;
2019-04-18 13:47:52 +02:00
var Selector$9 = {
2019-03-11 16:13:30 +01:00
DROPDOWN : '.dropdown' ,
NAV _LIST _GROUP : '.nav, .list-group' ,
ACTIVE : '.active' ,
ACTIVE _UL : ':scope > li > .active' ,
DATA _TOGGLE : '[data-toggle="tab"], [data-toggle="pill"], [data-toggle="list"]' ,
DROPDOWN _TOGGLE : '.dropdown-toggle' ,
DROPDOWN _ACTIVE _CHILD : ':scope > .dropdown-menu .active'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Tab =
/*#__PURE__*/
function ( ) {
function Tab ( element ) {
2019-03-11 16:13:30 +01:00
this . _element = element ;
Data . setData ( this . _element , DATA _KEY$9 , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Tab . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . show = function show ( ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
if ( this . _element . parentNode && this . _element . parentNode . nodeType === Node . ELEMENT _NODE && this . _element . classList . contains ( ClassName$9 . ACTIVE ) || this . _element . classList . contains ( ClassName$9 . DISABLED ) ) {
return ;
}
2019-04-18 13:47:52 +02:00
var previous ;
2019-08-27 15:03:21 +02:00
var target = getElementFromSelector ( this . _element ) ;
2019-04-18 13:47:52 +02:00
var listElement = SelectorEngine . closest ( this . _element , Selector$9 . NAV _LIST _GROUP ) ;
2019-03-11 16:13:30 +01:00
if ( listElement ) {
2019-04-18 13:47:52 +02:00
var itemSelector = listElement . nodeName === 'UL' || listElement . nodeName === 'OL' ? Selector$9 . ACTIVE _UL : Selector$9 . ACTIVE ;
2019-03-11 16:13:30 +01:00
previous = makeArray ( SelectorEngine . find ( itemSelector , listElement ) ) ;
previous = previous [ previous . length - 1 ] ;
}
2019-04-18 13:47:52 +02:00
var hideEvent = null ;
2019-03-11 16:13:30 +01:00
if ( previous ) {
hideEvent = EventHandler . trigger ( previous , Event$a . HIDE , {
relatedTarget : this . _element
} ) ;
}
2019-04-18 13:47:52 +02:00
var showEvent = EventHandler . trigger ( this . _element , Event$a . SHOW , {
2019-03-11 16:13:30 +01:00
relatedTarget : previous
} ) ;
if ( showEvent . defaultPrevented || hideEvent !== null && hideEvent . defaultPrevented ) {
return ;
}
this . _activate ( this . _element , listElement ) ;
2019-04-18 13:47:52 +02:00
var complete = function complete ( ) {
2019-03-11 16:13:30 +01:00
EventHandler . trigger ( previous , Event$a . HIDDEN , {
2019-04-18 13:47:52 +02:00
relatedTarget : _this . _element
2019-03-11 16:13:30 +01:00
} ) ;
2019-04-18 13:47:52 +02:00
EventHandler . trigger ( _this . _element , Event$a . SHOWN , {
2019-03-11 16:13:30 +01:00
relatedTarget : previous
} ) ;
} ;
if ( target ) {
this . _activate ( target , target . parentNode , complete ) ;
} else {
complete ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
Data . removeData ( this . _element , DATA _KEY$9 ) ;
this . _element = null ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _activate = function _activate ( element , container , callback ) {
var _this2 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var activeElements = container && ( container . nodeName === 'UL' || container . nodeName === 'OL' ) ? SelectorEngine . find ( Selector$9 . ACTIVE _UL , container ) : SelectorEngine . children ( container , Selector$9 . ACTIVE ) ;
var active = activeElements [ 0 ] ;
var isTransitioning = callback && active && active . classList . contains ( ClassName$9 . FADE ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var complete = function complete ( ) {
return _this2 . _transitionComplete ( element , active , callback ) ;
} ;
2019-03-11 16:13:30 +01:00
if ( active && isTransitioning ) {
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( active ) ;
2019-03-11 16:13:30 +01:00
active . classList . remove ( ClassName$9 . SHOW ) ;
EventHandler . one ( active , TRANSITION _END , complete ) ;
emulateTransitionEnd ( active , transitionDuration ) ;
} else {
complete ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _transitionComplete = function _transitionComplete ( element , active , callback ) {
2019-03-11 16:13:30 +01:00
if ( active ) {
active . classList . remove ( ClassName$9 . ACTIVE ) ;
2019-04-18 13:47:52 +02:00
var dropdownChild = SelectorEngine . findOne ( Selector$9 . DROPDOWN _ACTIVE _CHILD , active . parentNode ) ;
2019-03-11 16:13:30 +01:00
if ( dropdownChild ) {
dropdownChild . classList . remove ( ClassName$9 . ACTIVE ) ;
}
if ( active . getAttribute ( 'role' ) === 'tab' ) {
active . setAttribute ( 'aria-selected' , false ) ;
}
}
element . classList . add ( ClassName$9 . ACTIVE ) ;
if ( element . getAttribute ( 'role' ) === 'tab' ) {
element . setAttribute ( 'aria-selected' , true ) ;
}
reflow ( element ) ;
if ( element . classList . contains ( ClassName$9 . FADE ) ) {
element . classList . add ( ClassName$9 . SHOW ) ;
}
if ( element . parentNode && element . parentNode . classList . contains ( ClassName$9 . DROPDOWN _MENU ) ) {
2019-04-18 13:47:52 +02:00
var dropdownElement = SelectorEngine . closest ( element , Selector$9 . DROPDOWN ) ;
2019-03-11 16:13:30 +01:00
if ( dropdownElement ) {
2019-04-18 13:47:52 +02:00
makeArray ( SelectorEngine . find ( Selector$9 . DROPDOWN _TOGGLE ) ) . forEach ( function ( dropdown ) {
return dropdown . classList . add ( ClassName$9 . ACTIVE ) ;
} ) ;
2019-03-11 16:13:30 +01:00
}
element . setAttribute ( 'aria-expanded' , true ) ;
}
if ( callback ) {
callback ( ) ;
}
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Tab . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$9 ) || new Tab ( this ) ;
2019-03-11 16:13:30 +01:00
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Tab . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$9 ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Tab , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$9 ;
}
} ] ) ;
return Tab ;
} ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
EventHandler . on ( document , Event$a . CLICK _DATA _API , Selector$9 . DATA _TOGGLE , function ( event ) {
event . preventDefault ( ) ;
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$9 ) || new Tab ( this ) ;
2019-03-11 16:13:30 +01:00
data . show ( ) ;
} ) ;
2019-08-27 15:03:21 +02:00
var $$a = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . tab to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$a ) {
var JQUERY _NO _CONFLICT$9 = $$a . fn [ NAME$9 ] ;
$$a . fn [ NAME$9 ] = Tab . jQueryInterface ;
$$a . fn [ NAME$9 ] . Constructor = Tab ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$a . fn [ NAME$9 ] . noConflict = function ( ) {
$$a . fn [ NAME$9 ] = JQUERY _NO _CONFLICT$9 ;
return Tab . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-04-18 13:47:52 +02:00
var NAME$a = 'toast' ;
var VERSION$a = '4.3.1' ;
var DATA _KEY$a = 'bs.toast' ;
var EVENT _KEY$a = "." + DATA _KEY$a ;
var Event$b = {
CLICK _DISMISS : "click.dismiss" + EVENT _KEY$a ,
HIDE : "hide" + EVENT _KEY$a ,
HIDDEN : "hidden" + EVENT _KEY$a ,
SHOW : "show" + EVENT _KEY$a ,
SHOWN : "shown" + EVENT _KEY$a
2019-03-11 16:13:30 +01:00
} ;
2019-04-18 13:47:52 +02:00
var ClassName$a = {
2019-03-11 16:13:30 +01:00
FADE : 'fade' ,
HIDE : 'hide' ,
SHOW : 'show' ,
SHOWING : 'showing'
} ;
2019-04-18 13:47:52 +02:00
var DefaultType$7 = {
2019-03-11 16:13:30 +01:00
animation : 'boolean' ,
autohide : 'boolean' ,
delay : 'number'
} ;
2019-04-18 13:47:52 +02:00
var Default$7 = {
2019-03-11 16:13:30 +01:00
animation : true ,
autohide : true ,
delay : 500
} ;
2019-04-18 13:47:52 +02:00
var Selector$a = {
2019-03-11 16:13:30 +01:00
DATA _DISMISS : '[data-dismiss="toast"]'
} ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var Toast =
/*#__PURE__*/
function ( ) {
function Toast ( element , config ) {
2019-03-11 16:13:30 +01:00
this . _element = element ;
this . _config = this . _getConfig ( config ) ;
this . _timeout = null ;
this . _setListeners ( ) ;
Data . setData ( element , DATA _KEY$a , this ) ;
} // Getters
2019-04-18 13:47:52 +02:00
var _proto = Toast . prototype ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
// Public
_proto . show = function show ( ) {
var _this = this ;
2019-03-11 16:13:30 +01:00
2019-07-12 23:56:26 +02:00
var showEvent = EventHandler . trigger ( this . _element , Event$b . SHOW ) ;
if ( showEvent . defaultPrevented ) {
return ;
}
2019-03-11 16:13:30 +01:00
if ( this . _config . animation ) {
this . _element . classList . add ( ClassName$a . FADE ) ;
}
2019-04-18 13:47:52 +02:00
var complete = function complete ( ) {
_this . _element . classList . remove ( ClassName$a . SHOWING ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_this . _element . classList . add ( ClassName$a . SHOW ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
EventHandler . trigger ( _this . _element , Event$b . SHOWN ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
if ( _this . _config . autohide ) {
_this . _timeout = setTimeout ( function ( ) {
_this . hide ( ) ;
} , _this . _config . delay ) ;
2019-03-11 16:13:30 +01:00
}
} ;
this . _element . classList . remove ( ClassName$a . HIDE ) ;
2019-07-24 08:13:50 +02:00
reflow ( this . _element ) ;
2019-03-11 16:13:30 +01:00
this . _element . classList . add ( ClassName$a . SHOWING ) ;
if ( this . _config . animation ) {
2019-04-18 13:47:52 +02:00
var transitionDuration = getTransitionDurationFromElement ( this . _element ) ;
2019-03-11 16:13:30 +01:00
EventHandler . one ( this . _element , TRANSITION _END , complete ) ;
emulateTransitionEnd ( this . _element , transitionDuration ) ;
} else {
complete ( ) ;
}
2019-04-18 13:47:52 +02:00
} ;
_proto . hide = function hide ( ) {
var _this2 = this ;
2019-03-11 16:13:30 +01:00
if ( ! this . _element . classList . contains ( ClassName$a . SHOW ) ) {
return ;
}
2019-07-12 23:56:26 +02:00
var hideEvent = EventHandler . trigger ( this . _element , Event$b . HIDE ) ;
if ( hideEvent . defaultPrevented ) {
return ;
}
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var complete = function complete ( ) {
_this2 . _element . classList . add ( ClassName$a . HIDE ) ;
EventHandler . trigger ( _this2 . _element , Event$b . HIDDEN ) ;
} ;
this . _element . classList . remove ( ClassName$a . SHOW ) ;
if ( this . _config . animation ) {
var transitionDuration = getTransitionDurationFromElement ( this . _element ) ;
EventHandler . one ( this . _element , TRANSITION _END , complete ) ;
emulateTransitionEnd ( this . _element , transitionDuration ) ;
2019-03-11 16:13:30 +01:00
} else {
2019-04-18 13:47:52 +02:00
complete ( ) ;
2019-03-11 16:13:30 +01:00
}
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . dispose = function dispose ( ) {
2019-03-11 16:13:30 +01:00
clearTimeout ( this . _timeout ) ;
this . _timeout = null ;
if ( this . _element . classList . contains ( ClassName$a . SHOW ) ) {
this . _element . classList . remove ( ClassName$a . SHOW ) ;
}
EventHandler . off ( this . _element , Event$b . CLICK _DISMISS ) ;
Data . removeData ( this . _element , DATA _KEY$a ) ;
this . _element = null ;
this . _config = null ;
} // Private
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _getConfig = function _getConfig ( config ) {
2019-07-24 08:13:50 +02:00
config = _objectSpread2 ( { } , Default$7 , { } , Manipulator . getDataAttributes ( this . _element ) , { } , typeof config === 'object' && config ? config : { } ) ;
2019-03-11 16:13:30 +01:00
typeCheckConfig ( NAME$a , config , this . constructor . DefaultType ) ;
return config ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_proto . _setListeners = function _setListeners ( ) {
var _this3 = this ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
EventHandler . on ( this . _element , Event$b . CLICK _DISMISS , Selector$a . DATA _DISMISS , function ( ) {
return _this3 . hide ( ) ;
} ) ;
2019-03-11 16:13:30 +01:00
} // Static
2019-04-18 13:47:52 +02:00
;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Toast . jQueryInterface = function jQueryInterface ( config ) {
2019-03-11 16:13:30 +01:00
return this . each ( function ( ) {
2019-04-18 13:47:52 +02:00
var data = Data . getData ( this , DATA _KEY$a ) ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
var _config = typeof config === 'object' && config ;
2019-03-11 16:13:30 +01:00
if ( ! data ) {
data = new Toast ( this , _config ) ;
}
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
2019-04-18 13:47:52 +02:00
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2019-03-11 16:13:30 +01:00
}
data [ config ] ( this ) ;
}
} ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
Toast . getInstance = function getInstance ( element ) {
2019-03-11 16:13:30 +01:00
return Data . getData ( element , DATA _KEY$a ) ;
2019-04-18 13:47:52 +02:00
} ;
2019-03-11 16:13:30 +01:00
2019-04-18 13:47:52 +02:00
_createClass ( Toast , null , [ {
key : "VERSION" ,
get : function get ( ) {
return VERSION$a ;
}
} , {
key : "DefaultType" ,
get : function get ( ) {
return DefaultType$7 ;
}
} , {
key : "Default" ,
get : function get ( ) {
return Default$7 ;
}
} ] ) ;
return Toast ;
} ( ) ;
2019-08-27 15:03:21 +02:00
var $$b = getjQuery ( ) ;
2019-03-11 16:13:30 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* add . toast to jQuery only if jQuery is present
* /
2019-07-24 08:13:50 +02:00
/* istanbul ignore if */
2019-08-27 15:03:21 +02:00
if ( $$b ) {
var JQUERY _NO _CONFLICT$a = $$b . fn [ NAME$a ] ;
$$b . fn [ NAME$a ] = Toast . jQueryInterface ;
$$b . fn [ NAME$a ] . Constructor = Toast ;
2019-03-11 16:13:30 +01:00
2019-08-27 15:03:21 +02:00
$$b . fn [ NAME$a ] . noConflict = function ( ) {
$$b . fn [ NAME$a ] = JQUERY _NO _CONFLICT$a ;
return Toast . jQueryInterface ;
2019-03-11 16:13:30 +01:00
} ;
}
export { Alert , Button , Carousel , Collapse , Dropdown , Modal , Popover , ScrollSpy , Tab , Toast , Tooltip } ;
//# sourceMappingURL=bootstrap.esm.js.map