2018-11-13 07:41:12 +01:00
/ * !
2021-02-10 17:14:51 +01:00
* Bootstrap carousel . js v5 . 0.0 - beta2 ( https : //getbootstrap.com/)
* Copyright 2011 - 2021 The Bootstrap Authors ( https : //github.com/twbs/bootstrap/graphs/contributors)
2020-06-16 20:50:01 +02:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/main/LICENSE)
2018-11-13 07:41:12 +01:00
* /
2018-07-24 02:51:14 +02:00
( function ( global , factory ) {
2021-02-10 17:14:51 +01:00
typeof exports === 'object' && typeof module !== 'undefined' ? module . exports = factory ( require ( './dom/data.js' ) , require ( './dom/event-handler.js' ) , require ( './dom/manipulator.js' ) , require ( './dom/selector-engine.js' ) , require ( './base-component.js' ) ) :
typeof define === 'function' && define . amd ? define ( [ './dom/data' , './dom/event-handler' , './dom/manipulator' , './dom/selector-engine' , './base-component' ] , factory ) :
( global = typeof globalThis !== 'undefined' ? globalThis : global || self , global . Carousel = factory ( global . Data , global . EventHandler , global . Manipulator , global . SelectorEngine , global . Base ) ) ;
} ( this , ( function ( Data , EventHandler , Manipulator , SelectorEngine , BaseComponent ) { 'use strict' ;
2018-07-24 02:51:14 +02:00
2020-09-14 17:12:06 +02:00
function _interopDefaultLegacy ( e ) { return e && typeof e === 'object' && 'default' in e ? e : { 'default' : e } ; }
var Data _ _default = /*#__PURE__*/ _interopDefaultLegacy ( Data ) ;
var EventHandler _ _default = /*#__PURE__*/ _interopDefaultLegacy ( EventHandler ) ;
var Manipulator _ _default = /*#__PURE__*/ _interopDefaultLegacy ( Manipulator ) ;
var SelectorEngine _ _default = /*#__PURE__*/ _interopDefaultLegacy ( SelectorEngine ) ;
2021-02-10 17:14:51 +01:00
var BaseComponent _ _default = /*#__PURE__*/ _interopDefaultLegacy ( BaseComponent ) ;
function _defineProperties ( target , props ) {
for ( var i = 0 ; i < props . length ; i ++ ) {
var descriptor = props [ i ] ;
descriptor . enumerable = descriptor . enumerable || false ;
descriptor . configurable = true ;
if ( "value" in descriptor ) descriptor . writable = true ;
Object . defineProperty ( target , descriptor . key , descriptor ) ;
}
}
function _createClass ( Constructor , protoProps , staticProps ) {
if ( protoProps ) _defineProperties ( Constructor . prototype , protoProps ) ;
if ( staticProps ) _defineProperties ( Constructor , staticProps ) ;
return Constructor ;
}
function _extends ( ) {
_extends = Object . assign || function ( target ) {
for ( var i = 1 ; i < arguments . length ; i ++ ) {
var source = arguments [ i ] ;
for ( var key in source ) {
if ( Object . prototype . hasOwnProperty . call ( source , key ) ) {
target [ key ] = source [ key ] ;
}
}
}
return target ;
} ;
return _extends . apply ( this , arguments ) ;
}
function _inheritsLoose ( subClass , superClass ) {
subClass . prototype = Object . create ( superClass . prototype ) ;
subClass . prototype . constructor = subClass ;
2021-02-11 16:22:18 +01:00
_setPrototypeOf ( subClass , superClass ) ;
}
function _setPrototypeOf ( o , p ) {
_setPrototypeOf = Object . setPrototypeOf || function _setPrototypeOf ( o , p ) {
o . _ _proto _ _ = p ;
return o ;
} ;
return _setPrototypeOf ( o , p ) ;
2021-02-10 17:14:51 +01:00
}
2018-07-24 02:51:14 +02:00
2019-03-01 17:31:34 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2021-02-10 17:14:51 +01:00
* Bootstrap ( v5 . 0.0 - beta2 ) : util / index . js
2020-06-16 20:50:01 +02:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/main/LICENSE)
2019-03-01 17:31:34 +01:00
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
var MILLISECONDS _MULTIPLIER = 1000 ;
2019-08-27 15:03:21 +02:00
var TRANSITION _END = 'transitionend' ; // Shoutout AngusCroll (https://goo.gl/pxwQGp)
2019-03-01 17:31:34 +01:00
var toType = function toType ( obj ) {
2020-03-28 11:29:08 +01:00
if ( obj === null || obj === undefined ) {
return "" + obj ;
}
2019-03-01 17:31:34 +01:00
return { } . toString . call ( obj ) . match ( /\s([a-z]+)/i ) [ 1 ] . toLowerCase ( ) ;
} ;
2019-08-27 15:03:21 +02:00
var getSelector = function getSelector ( element ) {
2020-11-23 14:17:16 +01:00
var selector = element . getAttribute ( 'data-bs-target' ) ;
2019-03-01 17:31:34 +01:00
if ( ! selector || selector === '#' ) {
2021-02-10 17:14:51 +01:00
var hrefAttr = element . getAttribute ( 'href' ) ; // The only valid content that could double as a selector are IDs or classes,
// so everything starting with `#` or `.`. If a "real" URL is used as the selector,
// `document.querySelector` will rightfully complain it is invalid.
// See https://github.com/twbs/bootstrap/issues/32273
if ( ! hrefAttr || ! hrefAttr . includes ( '#' ) && ! hrefAttr . startsWith ( '.' ) ) {
return null ;
} // Just in case some CMS puts out a full URL with the anchor appended
if ( hrefAttr . includes ( '#' ) && ! hrefAttr . startsWith ( '#' ) ) {
hrefAttr = '#' + hrefAttr . split ( '#' ) [ 1 ] ;
}
2019-08-27 15:03:21 +02:00
selector = hrefAttr && hrefAttr !== '#' ? hrefAttr . trim ( ) : null ;
2019-03-01 17:31:34 +01:00
}
2019-08-27 15:03:21 +02:00
return selector ;
} ;
var getElementFromSelector = function getElementFromSelector ( element ) {
var selector = getSelector ( element ) ;
return selector ? document . querySelector ( selector ) : null ;
2019-03-01 17:31:34 +01:00
} ;
var getTransitionDurationFromElement = function getTransitionDurationFromElement ( element ) {
if ( ! element ) {
return 0 ;
} // Get transition-duration of the element
var _window$getComputedSt = window . getComputedStyle ( element ) ,
transitionDuration = _window$getComputedSt . transitionDuration ,
transitionDelay = _window$getComputedSt . transitionDelay ;
2020-11-23 14:17:16 +01:00
var floatTransitionDuration = Number . parseFloat ( transitionDuration ) ;
var floatTransitionDelay = Number . parseFloat ( transitionDelay ) ; // Return 0 if element or transition duration is not found
2019-03-01 17:31:34 +01:00
if ( ! floatTransitionDuration && ! floatTransitionDelay ) {
return 0 ;
} // If multiple durations are defined, take the first
transitionDuration = transitionDuration . split ( ',' ) [ 0 ] ;
transitionDelay = transitionDelay . split ( ',' ) [ 0 ] ;
2020-11-23 14:17:16 +01:00
return ( Number . parseFloat ( transitionDuration ) + Number . parseFloat ( transitionDelay ) ) * MILLISECONDS _MULTIPLIER ;
2019-03-01 17:31:34 +01:00
} ;
var triggerTransitionEnd = function triggerTransitionEnd ( element ) {
2020-03-28 11:29:08 +01:00
element . dispatchEvent ( new Event ( TRANSITION _END ) ) ;
2019-03-01 17:31:34 +01:00
} ;
var isElement = function isElement ( obj ) {
return ( obj [ 0 ] || obj ) . nodeType ;
} ;
var emulateTransitionEnd = function emulateTransitionEnd ( element , duration ) {
var called = false ;
var durationPadding = 5 ;
var emulatedDuration = duration + durationPadding ;
function listener ( ) {
called = true ;
element . removeEventListener ( TRANSITION _END , listener ) ;
}
element . addEventListener ( TRANSITION _END , listener ) ;
setTimeout ( function ( ) {
if ( ! called ) {
triggerTransitionEnd ( element ) ;
}
} , emulatedDuration ) ;
} ;
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 ) ;
if ( ! new RegExp ( expectedTypes ) . test ( valueType ) ) {
2021-02-10 17:14:51 +01:00
throw new TypeError ( componentName . toUpperCase ( ) + ": " + ( "Option \"" + property + "\" provided type \"" + valueType + "\" " ) + ( "but expected type \"" + expectedTypes + "\"." ) ) ;
2019-03-01 17:31:34 +01:00
}
} ) ;
} ;
var isVisible = function isVisible ( element ) {
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-01 17:31:34 +01:00
}
return false ;
} ;
var reflow = function reflow ( element ) {
return element . offsetHeight ;
} ;
2019-08-27 15:03:21 +02:00
var getjQuery = function getjQuery ( ) {
var _window = window ,
jQuery = _window . jQuery ;
2020-11-23 14:17:16 +01:00
if ( jQuery && ! document . body . hasAttribute ( 'data-bs-no-jquery' ) ) {
2019-08-27 15:03:21 +02:00
return jQuery ;
}
return null ;
} ;
2020-11-11 18:07:37 +01:00
var onDOMContentLoaded = function onDOMContentLoaded ( callback ) {
if ( document . readyState === 'loading' ) {
document . addEventListener ( 'DOMContentLoaded' , callback ) ;
} else {
callback ( ) ;
}
} ;
2020-12-03 14:08:31 +01:00
var isRTL = document . documentElement . dir === 'rtl' ;
2021-02-10 17:14:51 +01:00
var defineJQueryPlugin = function defineJQueryPlugin ( name , plugin ) {
onDOMContentLoaded ( function ( ) {
var $ = getjQuery ( ) ;
/* istanbul ignore if */
2020-12-03 15:18:59 +01:00
2021-02-10 17:14:51 +01:00
if ( $ ) {
var JQUERY _NO _CONFLICT = $ . fn [ name ] ;
$ . fn [ name ] = plugin . jQueryInterface ;
$ . fn [ name ] . Constructor = plugin ;
2020-12-03 15:18:59 +01:00
2021-02-10 17:14:51 +01:00
$ . fn [ name ] . noConflict = function ( ) {
$ . fn [ name ] = JQUERY _NO _CONFLICT ;
return plugin . jQueryInterface ;
} ;
2020-12-03 15:18:59 +01:00
}
2021-02-10 17:14:51 +01:00
} ) ;
} ;
2020-12-03 15:18:59 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
var NAME = 'carousel' ;
2018-11-13 07:41:12 +01:00
var DATA _KEY = 'bs.carousel' ;
var EVENT _KEY = "." + DATA _KEY ;
var DATA _API _KEY = '.data-api' ;
2020-05-13 20:53:43 +02:00
var ARROW _LEFT _KEY = 'ArrowLeft' ;
var ARROW _RIGHT _KEY = 'ArrowRight' ;
2018-11-13 07:41:12 +01:00
var TOUCHEVENT _COMPAT _WAIT = 500 ; // Time for mouse compat events to fire after touch
var SWIPE _THRESHOLD = 40 ;
var Default = {
interval : 5000 ,
keyboard : true ,
slide : false ,
pause : 'hover' ,
wrap : true ,
touch : true
} ;
var DefaultType = {
interval : '(number|boolean)' ,
keyboard : 'boolean' ,
slide : '(boolean|string)' ,
pause : '(string|boolean)' ,
wrap : 'boolean' ,
touch : 'boolean'
} ;
2020-03-28 11:29:08 +01:00
var DIRECTION _NEXT = 'next' ;
var DIRECTION _PREV = 'prev' ;
var DIRECTION _LEFT = 'left' ;
var DIRECTION _RIGHT = 'right' ;
var EVENT _SLIDE = "slide" + EVENT _KEY ;
var EVENT _SLID = "slid" + EVENT _KEY ;
var EVENT _KEYDOWN = "keydown" + EVENT _KEY ;
var EVENT _MOUSEENTER = "mouseenter" + EVENT _KEY ;
var EVENT _MOUSELEAVE = "mouseleave" + EVENT _KEY ;
var EVENT _TOUCHSTART = "touchstart" + EVENT _KEY ;
var EVENT _TOUCHMOVE = "touchmove" + EVENT _KEY ;
var EVENT _TOUCHEND = "touchend" + EVENT _KEY ;
var EVENT _POINTERDOWN = "pointerdown" + EVENT _KEY ;
var EVENT _POINTERUP = "pointerup" + EVENT _KEY ;
var EVENT _DRAG _START = "dragstart" + EVENT _KEY ;
var EVENT _LOAD _DATA _API = "load" + EVENT _KEY + DATA _API _KEY ;
var EVENT _CLICK _DATA _API = "click" + EVENT _KEY + DATA _API _KEY ;
var CLASS _NAME _CAROUSEL = 'carousel' ;
var CLASS _NAME _ACTIVE = 'active' ;
var CLASS _NAME _SLIDE = 'slide' ;
2020-12-03 14:08:31 +01:00
var CLASS _NAME _END = 'carousel-item-end' ;
var CLASS _NAME _START = 'carousel-item-start' ;
2020-03-28 11:29:08 +01:00
var CLASS _NAME _NEXT = 'carousel-item-next' ;
var CLASS _NAME _PREV = 'carousel-item-prev' ;
var CLASS _NAME _POINTER _EVENT = 'pointer-event' ;
var SELECTOR _ACTIVE = '.active' ;
var SELECTOR _ACTIVE _ITEM = '.active.carousel-item' ;
var SELECTOR _ITEM = '.carousel-item' ;
var SELECTOR _ITEM _IMG = '.carousel-item img' ;
var SELECTOR _NEXT _PREV = '.carousel-item-next, .carousel-item-prev' ;
var SELECTOR _INDICATORS = '.carousel-indicators' ;
2021-02-10 17:14:51 +01:00
var SELECTOR _INDICATOR = '[data-bs-target]' ;
2020-11-23 14:17:16 +01:00
var SELECTOR _DATA _SLIDE = '[data-bs-slide], [data-bs-slide-to]' ;
var SELECTOR _DATA _RIDE = '[data-bs-ride="carousel"]' ;
2021-02-10 17:14:51 +01:00
var POINTER _TYPE _TOUCH = 'touch' ;
var POINTER _TYPE _PEN = 'pen' ;
2019-10-08 08:39:10 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2018-11-13 07:41:12 +01:00
2020-12-03 15:18:59 +01:00
var Carousel = /*#__PURE__*/ function ( _BaseComponent ) {
_inheritsLoose ( Carousel , _BaseComponent ) ;
2019-03-01 17:31:34 +01:00
2020-12-03 15:18:59 +01:00
function Carousel ( element , config ) {
var _this ;
_this = _BaseComponent . call ( this , element ) || this ;
_this . _items = null ;
_this . _interval = null ;
_this . _activeElement = null ;
_this . _isPaused = false ;
_this . _isSliding = false ;
_this . touchTimeout = null ;
_this . touchStartX = 0 ;
_this . touchDeltaX = 0 ;
_this . _config = _this . _getConfig ( config ) ;
_this . _indicatorsElement = SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _INDICATORS , _this . _element ) ;
_this . _touchSupported = 'ontouchstart' in document . documentElement || navigator . maxTouchPoints > 0 ;
_this . _pointerEvent = Boolean ( window . PointerEvent ) ;
_this . _addEventListeners ( ) ;
return _this ;
2018-11-13 07:41:12 +01:00
} // Getters
var _proto = Carousel . prototype ;
// Public
_proto . next = function next ( ) {
if ( ! this . _isSliding ) {
2020-03-28 11:29:08 +01:00
this . _slide ( DIRECTION _NEXT ) ;
2018-11-13 07:41:12 +01:00
}
2018-07-24 02:51:14 +02:00
} ;
2018-11-13 07:41:12 +01:00
_proto . nextWhenVisible = function nextWhenVisible ( ) {
// Don't call next when the page isn't visible
// or the carousel or its parent isn't visible
2019-03-01 17:31:34 +01:00
if ( ! document . hidden && isVisible ( this . _element ) ) {
2018-11-13 07:41:12 +01:00
this . next ( ) ;
}
2018-07-24 02:51:14 +02:00
} ;
2018-11-13 07:41:12 +01:00
_proto . prev = function prev ( ) {
if ( ! this . _isSliding ) {
2020-03-28 11:29:08 +01:00
this . _slide ( DIRECTION _PREV ) ;
2018-11-13 07:41:12 +01:00
}
2018-07-24 02:51:14 +02:00
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . pause = function pause ( event ) {
if ( ! event ) {
this . _isPaused = true ;
}
2020-09-14 17:12:06 +02:00
if ( SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _NEXT _PREV , this . _element ) ) {
2019-03-01 17:31:34 +01:00
triggerTransitionEnd ( this . _element ) ;
2018-11-13 07:41:12 +01:00
this . cycle ( true ) ;
}
clearInterval ( this . _interval ) ;
this . _interval = null ;
2018-07-24 02:51:14 +02:00
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . cycle = function cycle ( event ) {
if ( ! event ) {
2018-07-24 02:51:14 +02:00
this . _isPaused = false ;
2018-11-13 07:41:12 +01:00
}
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
if ( this . _interval ) {
clearInterval ( this . _interval ) ;
this . _interval = null ;
}
2015-05-08 07:26:40 +02:00
2019-03-01 17:31:34 +01:00
if ( this . _config && this . _config . interval && ! this . _isPaused ) {
2020-11-11 18:07:37 +01:00
this . _updateInterval ( ) ;
2018-11-13 07:41:12 +01:00
this . _interval = setInterval ( ( document . visibilityState ? this . nextWhenVisible : this . next ) . bind ( this ) , this . _config . interval ) ;
}
} ;
2016-10-10 02:26:51 +02:00
2018-11-13 07:41:12 +01:00
_proto . to = function to ( index ) {
2020-12-03 15:18:59 +01:00
var _this2 = this ;
2017-09-30 23:28:03 +02:00
2020-09-14 17:12:06 +02:00
this . _activeElement = SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _ACTIVE _ITEM , this . _element ) ;
2017-09-30 23:28:03 +02:00
2018-11-13 07:41:12 +01:00
var activeIndex = this . _getItemIndex ( this . _activeElement ) ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
if ( index > this . _items . length - 1 || index < 0 ) {
return ;
}
2017-09-30 23:28:03 +02:00
2018-11-13 07:41:12 +01:00
if ( this . _isSliding ) {
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . one ( this . _element , EVENT _SLID , function ( ) {
2020-12-03 15:18:59 +01:00
return _this2 . to ( index ) ;
2018-11-13 07:41:12 +01:00
} ) ;
return ;
}
2016-10-10 02:26:51 +02:00
2018-11-13 07:41:12 +01:00
if ( activeIndex === index ) {
this . pause ( ) ;
this . cycle ( ) ;
return ;
}
2015-05-08 07:26:40 +02:00
2020-03-28 11:29:08 +01:00
var direction = index > activeIndex ? DIRECTION _NEXT : DIRECTION _PREV ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
this . _slide ( direction , this . _items [ index ] ) ;
} ;
2017-09-30 23:28:03 +02:00
2018-11-13 07:41:12 +01:00
_proto . dispose = function dispose ( ) {
2020-12-03 15:18:59 +01:00
_BaseComponent . prototype . dispose . call ( this ) ;
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . off ( this . _element , EVENT _KEY ) ;
2018-11-13 07:41:12 +01:00
this . _items = null ;
this . _config = null ;
this . _interval = null ;
this . _isPaused = null ;
this . _isSliding = null ;
this . _activeElement = null ;
this . _indicatorsElement = null ;
2019-01-04 17:29:45 +01:00
} // Private
;
2018-11-13 07:41:12 +01:00
_proto . _getConfig = function _getConfig ( config ) {
2020-09-14 17:12:06 +02:00
config = _extends ( { } , Default , config ) ;
2019-03-01 17:31:34 +01:00
typeCheckConfig ( NAME , config , DefaultType ) ;
2018-11-13 07:41:12 +01:00
return config ;
} ;
2017-09-30 23:28:03 +02:00
2018-11-13 07:41:12 +01:00
_proto . _handleSwipe = function _handleSwipe ( ) {
var absDeltax = Math . abs ( this . touchDeltaX ) ;
2017-09-30 23:28:03 +02:00
2018-11-13 07:41:12 +01:00
if ( absDeltax <= SWIPE _THRESHOLD ) {
return ;
}
2015-05-08 07:26:40 +02:00
2019-04-18 13:47:52 +02:00
var direction = absDeltax / this . touchDeltaX ;
this . touchDeltaX = 0 ; // swipe left
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
if ( direction > 0 ) {
2021-02-10 17:14:51 +01:00
if ( isRTL ) {
this . next ( ) ;
} else {
this . prev ( ) ;
}
2018-11-13 07:41:12 +01:00
} // swipe right
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
if ( direction < 0 ) {
2021-02-10 17:14:51 +01:00
if ( isRTL ) {
this . prev ( ) ;
} else {
this . next ( ) ;
}
2018-11-13 07:41:12 +01:00
}
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . _addEventListeners = function _addEventListeners ( ) {
2020-12-03 15:18:59 +01:00
var _this3 = this ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
if ( this . _config . keyboard ) {
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _KEYDOWN , function ( event ) {
2020-12-03 15:18:59 +01:00
return _this3 . _keydown ( event ) ;
2018-11-13 07:41:12 +01:00
} ) ;
}
2016-11-01 05:14:23 +01:00
2018-11-13 07:41:12 +01:00
if ( this . _config . pause === 'hover' ) {
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _MOUSEENTER , function ( event ) {
2020-12-03 15:18:59 +01:00
return _this3 . pause ( event ) ;
2019-03-01 17:31:34 +01:00
} ) ;
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _MOUSELEAVE , function ( event ) {
2020-12-03 15:18:59 +01:00
return _this3 . cycle ( event ) ;
2018-11-13 07:41:12 +01:00
} ) ;
}
2015-05-08 07:26:40 +02:00
2019-07-24 08:13:50 +02:00
if ( this . _config . touch && this . _touchSupported ) {
2019-02-11 20:15:34 +01:00
this . _addTouchEventListeners ( ) ;
}
2018-11-13 07:41:12 +01:00
} ;
2017-09-30 23:28:03 +02:00
2018-11-13 07:41:12 +01:00
_proto . _addTouchEventListeners = function _addTouchEventListeners ( ) {
2020-12-03 15:18:59 +01:00
var _this4 = this ;
2018-07-24 02:51:14 +02:00
2018-11-13 07:41:12 +01:00
var start = function start ( event ) {
2021-02-10 17:14:51 +01:00
if ( _this4 . _pointerEvent && ( event . pointerType === POINTER _TYPE _PEN || event . pointerType === POINTER _TYPE _TOUCH ) ) {
2020-12-03 15:18:59 +01:00
_this4 . touchStartX = event . clientX ;
} else if ( ! _this4 . _pointerEvent ) {
_this4 . touchStartX = event . touches [ 0 ] . clientX ;
2017-09-06 06:05:12 +02:00
}
2018-11-13 07:41:12 +01:00
} ;
2017-09-06 06:05:12 +02:00
2018-11-13 07:41:12 +01:00
var move = function move ( event ) {
// ensure swiping with one touch and not pinching
2019-03-01 17:31:34 +01:00
if ( event . touches && event . touches . length > 1 ) {
2020-12-03 15:18:59 +01:00
_this4 . touchDeltaX = 0 ;
2018-11-13 07:41:12 +01:00
} else {
2020-12-03 15:18:59 +01:00
_this4 . touchDeltaX = event . touches [ 0 ] . clientX - _this4 . touchStartX ;
2018-07-24 02:51:14 +02:00
}
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
var end = function end ( event ) {
2021-02-10 17:14:51 +01:00
if ( _this4 . _pointerEvent && ( event . pointerType === POINTER _TYPE _PEN || event . pointerType === POINTER _TYPE _TOUCH ) ) {
2020-12-03 15:18:59 +01:00
_this4 . touchDeltaX = event . clientX - _this4 . touchStartX ;
2018-07-24 02:51:14 +02:00
}
2017-09-30 23:28:03 +02:00
2020-12-03 15:18:59 +01:00
_this4 . _handleSwipe ( ) ;
2018-11-13 07:41:12 +01:00
2020-12-03 15:18:59 +01:00
if ( _this4 . _config . pause === 'hover' ) {
2018-11-13 07:41:12 +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
2020-12-03 15:18:59 +01:00
_this4 . pause ( ) ;
2015-05-08 07:26:40 +02:00
2020-12-03 15:18:59 +01:00
if ( _this4 . touchTimeout ) {
clearTimeout ( _this4 . touchTimeout ) ;
2018-11-13 07:41:12 +01:00
}
2015-05-08 07:26:40 +02:00
2020-12-03 15:18:59 +01:00
_this4 . touchTimeout = setTimeout ( function ( event ) {
return _this4 . cycle ( event ) ;
} , TOUCHEVENT _COMPAT _WAIT + _this4 . _config . interval ) ;
2018-07-24 02:51:14 +02:00
}
} ;
2016-10-10 02:26:51 +02:00
2020-09-14 17:12:06 +02:00
SelectorEngine _ _default [ 'default' ] . find ( SELECTOR _ITEM _IMG , this . _element ) . forEach ( function ( itemImg ) {
EventHandler _ _default [ 'default' ] . on ( itemImg , EVENT _DRAG _START , function ( e ) {
2019-03-01 17:31:34 +01:00
return e . preventDefault ( ) ;
} ) ;
2018-11-13 07:41:12 +01:00
} ) ;
2016-10-10 02:26:51 +02:00
2018-11-13 07:41:12 +01:00
if ( this . _pointerEvent ) {
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _POINTERDOWN , function ( event ) {
2018-11-13 07:41:12 +01:00
return start ( event ) ;
} ) ;
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _POINTERUP , function ( event ) {
2018-11-13 07:41:12 +01:00
return end ( event ) ;
} ) ;
2017-09-30 23:28:03 +02:00
2020-03-28 11:29:08 +01:00
this . _element . classList . add ( CLASS _NAME _POINTER _EVENT ) ;
2018-11-13 07:41:12 +01:00
} else {
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _TOUCHSTART , function ( event ) {
2018-11-13 07:41:12 +01:00
return start ( event ) ;
} ) ;
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _TOUCHMOVE , function ( event ) {
2018-11-13 07:41:12 +01:00
return move ( event ) ;
} ) ;
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _TOUCHEND , function ( event ) {
2018-11-13 07:41:12 +01:00
return end ( event ) ;
} ) ;
}
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . _keydown = function _keydown ( event ) {
if ( /input|textarea/i . test ( event . target . tagName ) ) {
return ;
}
2015-05-08 07:26:40 +02:00
2021-02-10 17:14:51 +01:00
if ( event . key === ARROW _LEFT _KEY ) {
event . preventDefault ( ) ;
if ( isRTL ) {
this . next ( ) ;
} else {
2018-11-13 07:41:12 +01:00
this . prev ( ) ;
2021-02-10 17:14:51 +01:00
}
} else if ( event . key === ARROW _RIGHT _KEY ) {
event . preventDefault ( ) ;
2015-05-08 07:26:40 +02:00
2021-02-10 17:14:51 +01:00
if ( isRTL ) {
this . prev ( ) ;
} else {
2018-11-13 07:41:12 +01:00
this . next ( ) ;
2021-02-10 17:14:51 +01:00
}
2018-11-13 07:41:12 +01:00
}
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . _getItemIndex = function _getItemIndex ( element ) {
2020-09-14 17:12:06 +02:00
this . _items = element && element . parentNode ? SelectorEngine _ _default [ 'default' ] . find ( SELECTOR _ITEM , element . parentNode ) : [ ] ;
2018-11-13 07:41:12 +01:00
return this . _items . indexOf ( element ) ;
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . _getItemByDirection = function _getItemByDirection ( direction , activeElement ) {
2020-03-28 11:29:08 +01:00
var isNextDirection = direction === DIRECTION _NEXT ;
var isPrevDirection = direction === DIRECTION _PREV ;
2018-07-24 02:51:14 +02:00
2018-11-13 07:41:12 +01:00
var activeIndex = this . _getItemIndex ( activeElement ) ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
var lastItemIndex = this . _items . length - 1 ;
var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex ;
2018-07-24 02:51:14 +02:00
2018-11-13 07:41:12 +01:00
if ( isGoingToWrap && ! this . _config . wrap ) {
return activeElement ;
}
2015-05-08 07:26:40 +02:00
2020-03-28 11:29:08 +01:00
var delta = direction === DIRECTION _PREV ? - 1 : 1 ;
2018-11-13 07:41:12 +01:00
var itemIndex = ( activeIndex + delta ) % this . _items . length ;
return itemIndex === - 1 ? this . _items [ this . _items . length - 1 ] : this . _items [ itemIndex ] ;
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . _triggerSlideEvent = function _triggerSlideEvent ( relatedTarget , eventDirectionName ) {
var targetIndex = this . _getItemIndex ( relatedTarget ) ;
2015-05-08 07:26:40 +02:00
2020-09-14 17:12:06 +02:00
var fromIndex = this . _getItemIndex ( SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _ACTIVE _ITEM , this . _element ) ) ;
2015-05-08 07:26:40 +02:00
2020-09-14 17:12:06 +02:00
return EventHandler _ _default [ 'default' ] . trigger ( this . _element , EVENT _SLIDE , {
2018-11-13 07:41:12 +01:00
relatedTarget : relatedTarget ,
direction : eventDirectionName ,
from : fromIndex ,
to : targetIndex
} ) ;
} ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
_proto . _setActiveIndicatorElement = function _setActiveIndicatorElement ( element ) {
if ( this . _indicatorsElement ) {
2021-02-10 17:14:51 +01:00
var activeIndicator = SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _ACTIVE , this . _indicatorsElement ) ;
activeIndicator . classList . remove ( CLASS _NAME _ACTIVE ) ;
activeIndicator . removeAttribute ( 'aria-current' ) ;
var indicators = SelectorEngine _ _default [ 'default' ] . find ( SELECTOR _INDICATOR , this . _indicatorsElement ) ;
2019-03-01 17:31:34 +01:00
for ( var i = 0 ; i < indicators . length ; i ++ ) {
2021-02-10 17:14:51 +01:00
if ( Number . parseInt ( indicators [ i ] . getAttribute ( 'data-bs-slide-to' ) , 10 ) === this . _getItemIndex ( element ) ) {
indicators [ i ] . classList . add ( CLASS _NAME _ACTIVE ) ;
indicators [ i ] . setAttribute ( 'aria-current' , 'true' ) ;
break ;
}
2018-07-24 02:51:14 +02:00
}
2018-11-13 07:41:12 +01:00
}
} ;
2015-05-08 07:26:40 +02:00
2020-11-11 18:07:37 +01:00
_proto . _updateInterval = function _updateInterval ( ) {
var element = this . _activeElement || SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _ACTIVE _ITEM , this . _element ) ;
if ( ! element ) {
return ;
}
2020-11-23 14:17:16 +01:00
var elementInterval = Number . parseInt ( element . getAttribute ( 'data-bs-interval' ) , 10 ) ;
2020-11-11 18:07:37 +01:00
if ( elementInterval ) {
this . _config . defaultInterval = this . _config . defaultInterval || this . _config . interval ;
this . _config . interval = elementInterval ;
} else {
this . _config . interval = this . _config . defaultInterval || this . _config . interval ;
}
} ;
2018-11-13 07:41:12 +01:00
_proto . _slide = function _slide ( direction , element ) {
2020-12-03 15:18:59 +01:00
var _this5 = this ;
2015-05-08 07:26:40 +02:00
2020-09-14 17:12:06 +02:00
var activeElement = SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _ACTIVE _ITEM , this . _element ) ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
var activeElementIndex = this . _getItemIndex ( activeElement ) ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
var nextElement = element || activeElement && this . _getItemByDirection ( direction , activeElement ) ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
var nextElementIndex = this . _getItemIndex ( nextElement ) ;
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
var isCycling = Boolean ( this . _interval ) ;
2021-02-10 17:14:51 +01:00
var directionalClassName = direction === DIRECTION _NEXT ? CLASS _NAME _START : CLASS _NAME _END ;
var orderClassName = direction === DIRECTION _NEXT ? CLASS _NAME _NEXT : CLASS _NAME _PREV ;
var eventDirectionName = direction === DIRECTION _NEXT ? DIRECTION _LEFT : DIRECTION _RIGHT ;
2017-09-30 23:28:03 +02:00
2020-03-28 11:29:08 +01:00
if ( nextElement && nextElement . classList . contains ( CLASS _NAME _ACTIVE ) ) {
2018-11-13 07:41:12 +01:00
this . _isSliding = false ;
return ;
}
2017-09-30 23:28:03 +02:00
2018-11-13 07:41:12 +01:00
var slideEvent = this . _triggerSlideEvent ( nextElement , eventDirectionName ) ;
2018-09-19 06:35:40 +02:00
2019-03-01 17:31:34 +01:00
if ( slideEvent . defaultPrevented ) {
2018-11-13 07:41:12 +01:00
return ;
}
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
if ( ! activeElement || ! nextElement ) {
// Some weirdness is happening, so we bail
return ;
}
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
this . _isSliding = true ;
2015-08-19 05:28:28 +02:00
2018-11-13 07:41:12 +01:00
if ( isCycling ) {
this . pause ( ) ;
}
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
this . _setActiveIndicatorElement ( nextElement ) ;
2017-09-30 23:28:03 +02:00
2020-11-11 18:07:37 +01:00
this . _activeElement = nextElement ;
2020-03-28 11:29:08 +01:00
if ( this . _element . classList . contains ( CLASS _NAME _SLIDE ) ) {
2019-03-01 17:31:34 +01:00
nextElement . classList . add ( orderClassName ) ;
reflow ( nextElement ) ;
activeElement . classList . add ( directionalClassName ) ;
nextElement . classList . add ( directionalClassName ) ;
var transitionDuration = getTransitionDurationFromElement ( activeElement ) ;
2021-02-10 17:14:51 +01:00
EventHandler _ _default [ 'default' ] . one ( activeElement , 'transitionend' , function ( ) {
2020-05-13 20:53:43 +02:00
nextElement . classList . remove ( directionalClassName , orderClassName ) ;
2020-03-28 11:29:08 +01:00
nextElement . classList . add ( CLASS _NAME _ACTIVE ) ;
2020-05-13 20:53:43 +02:00
activeElement . classList . remove ( CLASS _NAME _ACTIVE , orderClassName , directionalClassName ) ;
2020-12-03 15:18:59 +01:00
_this5 . _isSliding = false ;
2018-11-13 07:41:12 +01:00
setTimeout ( function ( ) {
2020-12-03 15:18:59 +01:00
EventHandler _ _default [ 'default' ] . trigger ( _this5 . _element , EVENT _SLID , {
2019-03-01 17:31:34 +01:00
relatedTarget : nextElement ,
direction : eventDirectionName ,
from : activeElementIndex ,
to : nextElementIndex
} ) ;
2018-11-13 07:41:12 +01:00
} , 0 ) ;
2019-03-01 17:31:34 +01:00
} ) ;
emulateTransitionEnd ( activeElement , transitionDuration ) ;
2018-11-13 07:41:12 +01:00
} else {
2020-03-28 11:29:08 +01:00
activeElement . classList . remove ( CLASS _NAME _ACTIVE ) ;
nextElement . classList . add ( CLASS _NAME _ACTIVE ) ;
2018-11-13 07:41:12 +01:00
this . _isSliding = false ;
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . trigger ( this . _element , EVENT _SLID , {
2019-03-01 17:31:34 +01:00
relatedTarget : nextElement ,
direction : eventDirectionName ,
from : activeElementIndex ,
to : nextElementIndex
} ) ;
2018-11-13 07:41:12 +01:00
}
2018-07-24 02:51:14 +02:00
2018-11-13 07:41:12 +01:00
if ( isCycling ) {
this . cycle ( ) ;
}
2019-01-04 17:29:45 +01:00
} // Static
;
2016-10-10 02:26:51 +02:00
2019-08-27 15:03:21 +02:00
Carousel . carouselInterface = function carouselInterface ( element , config ) {
2020-09-14 17:12:06 +02:00
var data = Data _ _default [ 'default' ] . getData ( element , DATA _KEY ) ;
2017-09-30 23:28:03 +02:00
2020-09-14 17:12:06 +02:00
var _config = _extends ( { } , Default , Manipulator _ _default [ 'default' ] . getDataAttributes ( element ) ) ;
2017-09-30 23:28:03 +02:00
2019-03-01 17:31:34 +01:00
if ( typeof config === 'object' ) {
2020-09-14 17:12:06 +02:00
_config = _extends ( { } , _config , config ) ;
2019-03-01 17:31:34 +01:00
}
2017-09-30 23:28:03 +02:00
2019-03-01 17:31:34 +01:00
var action = typeof config === 'string' ? config : _config . slide ;
2017-12-23 01:21:54 +01:00
2019-03-01 17:31:34 +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-03-11 16:13:30 +01:00
throw new TypeError ( "No method named \"" + action + "\"" ) ;
2018-07-24 02:51:14 +02:00
}
2017-09-30 23:28:03 +02:00
2019-03-01 17:31:34 +01:00
data [ action ] ( ) ;
} else if ( _config . interval && _config . ride ) {
data . pause ( ) ;
data . cycle ( ) ;
}
} ;
2017-09-30 23:28:03 +02:00
2019-08-27 15:03:21 +02:00
Carousel . jQueryInterface = function jQueryInterface ( config ) {
2019-03-01 17:31:34 +01:00
return this . each ( function ( ) {
2019-08-27 15:03:21 +02:00
Carousel . carouselInterface ( this , config ) ;
2018-11-13 07:41:12 +01:00
} ) ;
} ;
2017-09-30 23:28:03 +02:00
2019-08-27 15:03:21 +02:00
Carousel . dataApiClickHandler = function dataApiClickHandler ( event ) {
var target = getElementFromSelector ( this ) ;
2015-05-08 07:26:40 +02:00
2020-03-28 11:29:08 +01:00
if ( ! target || ! target . classList . contains ( CLASS _NAME _CAROUSEL ) ) {
2018-11-13 07:41:12 +01:00
return ;
}
2015-05-08 07:26:40 +02:00
2020-09-14 17:12:06 +02:00
var config = _extends ( { } , Manipulator _ _default [ 'default' ] . getDataAttributes ( target ) , Manipulator _ _default [ 'default' ] . getDataAttributes ( this ) ) ;
2015-05-08 07:26:40 +02:00
2020-11-23 14:17:16 +01:00
var slideIndex = this . getAttribute ( 'data-bs-slide-to' ) ;
2018-06-22 07:55:23 +02:00
2018-11-13 07:41:12 +01:00
if ( slideIndex ) {
config . interval = false ;
2018-07-24 02:51:14 +02:00
}
2017-09-30 23:28:03 +02:00
2019-08-27 15:03:21 +02:00
Carousel . carouselInterface ( target , config ) ;
2018-11-13 07:41:12 +01:00
if ( slideIndex ) {
2020-09-14 17:12:06 +02:00
Data _ _default [ 'default' ] . getData ( target , DATA _KEY ) . to ( slideIndex ) ;
2018-11-13 07:41:12 +01:00
}
2015-05-08 07:26:40 +02:00
2018-11-13 07:41:12 +01:00
event . preventDefault ( ) ;
2018-07-24 02:51:14 +02:00
} ;
2017-09-30 23:28:03 +02:00
2021-02-10 17:14:51 +01:00
_createClass ( Carousel , null , [ {
2020-12-03 15:18:59 +01:00
key : "Default" ,
2018-11-13 07:41:12 +01:00
get : function get ( ) {
2020-12-03 15:18:59 +01:00
return Default ;
2018-11-13 07:41:12 +01:00
}
} , {
2020-12-03 15:18:59 +01:00
key : "DATA_KEY" ,
2018-11-13 07:41:12 +01:00
get : function get ( ) {
2020-12-03 15:18:59 +01:00
return DATA _KEY ;
2018-11-13 07:41:12 +01:00
}
} ] ) ;
2018-07-24 02:51:14 +02:00
return Carousel ;
2021-02-10 17:14:51 +01:00
} ( BaseComponent _ _default [ 'default' ] ) ;
2018-11-13 07:41:12 +01:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2020-09-14 17:12:06 +02:00
EventHandler _ _default [ 'default' ] . on ( document , EVENT _CLICK _DATA _API , SELECTOR _DATA _SLIDE , Carousel . dataApiClickHandler ) ;
EventHandler _ _default [ 'default' ] . on ( window , EVENT _LOAD _DATA _API , function ( ) {
var carousels = SelectorEngine _ _default [ 'default' ] . find ( SELECTOR _DATA _RIDE ) ;
2018-11-13 07:41:12 +01:00
for ( var i = 0 , len = carousels . length ; i < len ; i ++ ) {
2020-09-14 17:12:06 +02:00
Carousel . carouselInterface ( carousels [ i ] , Data _ _default [ 'default' ] . getData ( carousels [ i ] , DATA _KEY ) ) ;
2018-11-13 07:41:12 +01:00
}
} ) ;
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2020-11-11 18:07:37 +01:00
* add . Carousel to jQuery only if jQuery is present
2018-11-13 07:41:12 +01:00
* /
2021-02-10 17:14:51 +01:00
defineJQueryPlugin ( NAME , Carousel ) ;
2015-05-08 07:26:40 +02:00
return Carousel ;
2018-07-24 02:51:14 +02:00
2019-11-08 09:11:23 +01:00
} ) ) ) ;
2018-07-24 02:51:14 +02:00
//# sourceMappingURL=carousel.js.map