2018-11-13 08:41:12 +02:00
/ * !
2021-02-10 18:14:51 +02:00
* Bootstrap toast . js v5 . 0.0 - beta2 ( https : //getbootstrap.com/)
* Copyright 2011 - 2021 The Bootstrap Authors ( https : //github.com/twbs/bootstrap/graphs/contributors)
2020-06-16 21:50:01 +03:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/main/LICENSE)
2018-11-13 08:41:12 +02:00
* /
( function ( global , factory ) {
2021-02-10 18:14:51 +02:00
typeof exports === 'object' && typeof module !== 'undefined' ? module . exports = factory ( require ( './dom/data.js' ) , require ( './dom/event-handler.js' ) , require ( './dom/manipulator.js' ) , require ( './base-component.js' ) ) :
typeof define === 'function' && define . amd ? define ( [ './dom/data' , './dom/event-handler' , './dom/manipulator' , './base-component' ] , factory ) :
( global = typeof globalThis !== 'undefined' ? globalThis : global || self , global . Toast = factory ( global . Data , global . EventHandler , global . Manipulator , global . Base ) ) ;
} ( this , ( function ( Data , EventHandler , Manipulator , BaseComponent ) { 'use strict' ;
2018-11-13 08:41:12 +02:00
2020-09-14 18:12:06 +03: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 ) ;
2021-02-10 18:14:51 +02: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 ;
_setPrototypeOf ( subClass , superClass ) ;
}
function _setPrototypeOf ( o , p ) {
_setPrototypeOf = Object . setPrototypeOf || function _setPrototypeOf ( o , p ) {
o . _ _proto _ _ = p ;
return o ;
} ;
return _setPrototypeOf ( o , p ) ;
}
2018-11-13 08:41:12 +02:00
2019-03-01 18:31:34 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2021-02-10 18:14:51 +02:00
* Bootstrap ( v5 . 0.0 - beta2 ) : util / index . js
2020-06-16 21:50:01 +03:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/main/LICENSE)
2019-03-01 18:31:34 +02:00
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
var MILLISECONDS _MULTIPLIER = 1000 ;
2019-08-27 16:03:21 +03:00
var TRANSITION _END = 'transitionend' ; // Shoutout AngusCroll (https://goo.gl/pxwQGp)
2019-03-01 18:31:34 +02:00
var toType = function toType ( obj ) {
2020-03-28 12:29:08 +02:00
if ( obj === null || obj === undefined ) {
return "" + obj ;
}
2019-03-01 18:31:34 +02:00
return { } . toString . call ( obj ) . match ( /\s([a-z]+)/i ) [ 1 ] . toLowerCase ( ) ;
} ;
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 15:17:16 +02:00
var floatTransitionDuration = Number . parseFloat ( transitionDuration ) ;
var floatTransitionDelay = Number . parseFloat ( transitionDelay ) ; // Return 0 if element or transition duration is not found
2019-03-01 18:31:34 +02: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 15:17:16 +02:00
return ( Number . parseFloat ( transitionDuration ) + Number . parseFloat ( transitionDelay ) ) * MILLISECONDS _MULTIPLIER ;
2019-03-01 18:31:34 +02:00
} ;
var triggerTransitionEnd = function triggerTransitionEnd ( element ) {
2020-03-28 12:29:08 +02:00
element . dispatchEvent ( new Event ( TRANSITION _END ) ) ;
2019-03-01 18:31:34 +02: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 18:14:51 +02:00
throw new TypeError ( componentName . toUpperCase ( ) + ": " + ( "Option \"" + property + "\" provided type \"" + valueType + "\" " ) + ( "but expected type \"" + expectedTypes + "\"." ) ) ;
2019-03-01 18:31:34 +02:00
}
} ) ;
} ;
2019-07-23 23:13:50 -07:00
var reflow = function reflow ( element ) {
return element . offsetHeight ;
} ;
2019-08-27 16:03:21 +03:00
var getjQuery = function getjQuery ( ) {
var _window = window ,
jQuery = _window . jQuery ;
2020-11-23 15:17:16 +02:00
if ( jQuery && ! document . body . hasAttribute ( 'data-bs-no-jquery' ) ) {
2019-08-27 16:03:21 +03:00
return jQuery ;
}
return null ;
} ;
2020-11-11 19:07:37 +02:00
var onDOMContentLoaded = function onDOMContentLoaded ( callback ) {
if ( document . readyState === 'loading' ) {
document . addEventListener ( 'DOMContentLoaded' , callback ) ;
} else {
callback ( ) ;
}
} ;
2021-02-10 18:14:51 +02:00
document . documentElement . dir === 'rtl' ;
2020-12-03 16:18:59 +02:00
2021-02-10 18:14:51 +02:00
var defineJQueryPlugin = function defineJQueryPlugin ( name , plugin ) {
onDOMContentLoaded ( function ( ) {
var $ = getjQuery ( ) ;
/* istanbul ignore if */
2020-12-03 16:18:59 +02:00
2021-02-10 18:14:51 +02:00
if ( $ ) {
var JQUERY _NO _CONFLICT = $ . fn [ name ] ;
$ . fn [ name ] = plugin . jQueryInterface ;
$ . fn [ name ] . Constructor = plugin ;
2020-12-03 16:18:59 +02:00
2021-02-10 18:14:51 +02:00
$ . fn [ name ] . noConflict = function ( ) {
$ . fn [ name ] = JQUERY _NO _CONFLICT ;
return plugin . jQueryInterface ;
} ;
2020-12-03 16:18:59 +02:00
}
2021-02-10 18:14:51 +02:00
} ) ;
} ;
2020-12-03 16:18:59 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
var NAME = 'toast' ;
2018-11-24 18:22:59 +02:00
var DATA _KEY = 'bs.toast' ;
var EVENT _KEY = "." + DATA _KEY ;
2020-03-28 12:29:08 +02:00
var EVENT _CLICK _DISMISS = "click.dismiss" + EVENT _KEY ;
var EVENT _HIDE = "hide" + EVENT _KEY ;
var EVENT _HIDDEN = "hidden" + EVENT _KEY ;
var EVENT _SHOW = "show" + EVENT _KEY ;
var EVENT _SHOWN = "shown" + EVENT _KEY ;
var CLASS _NAME _FADE = 'fade' ;
var CLASS _NAME _HIDE = 'hide' ;
var CLASS _NAME _SHOW = 'show' ;
var CLASS _NAME _SHOWING = 'showing' ;
2018-11-24 18:22:59 +02:00
var DefaultType = {
animation : 'boolean' ,
autohide : 'boolean' ,
delay : 'number'
} ;
var Default = {
animation : true ,
autohide : true ,
2020-09-14 18:12:06 +03:00
delay : 5000
2018-11-24 18:22:59 +02:00
} ;
2020-11-23 15:17:16 +02:00
var SELECTOR _DATA _DISMISS = '[data-bs-dismiss="toast"]' ;
2019-10-08 09:39:10 +03:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2018-11-13 08:41:12 +02:00
2020-12-03 16:18:59 +02:00
var Toast = /*#__PURE__*/ function ( _BaseComponent ) {
_inheritsLoose ( Toast , _BaseComponent ) ;
2018-11-24 18:22:59 +02:00
function Toast ( element , config ) {
2020-12-03 16:18:59 +02:00
var _this ;
2018-11-13 08:41:12 +02:00
2020-12-03 16:18:59 +02:00
_this = _BaseComponent . call ( this , element ) || this ;
_this . _config = _this . _getConfig ( config ) ;
_this . _timeout = null ;
2019-03-01 18:31:34 +02:00
2020-12-03 16:18:59 +02:00
_this . _setListeners ( ) ;
return _this ;
2018-11-24 18:22:59 +02:00
} // Getters
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
var _proto = Toast . prototype ;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
// Public
_proto . show = function show ( ) {
2020-12-03 16:18:59 +02:00
var _this2 = this ;
2018-11-13 08:41:12 +02:00
2020-09-14 18:12:06 +03:00
var showEvent = EventHandler _ _default [ 'default' ] . trigger ( this . _element , EVENT _SHOW ) ;
2019-07-12 16:56:26 -05:00
if ( showEvent . defaultPrevented ) {
return ;
}
2018-11-13 08:41:12 +02:00
2020-09-14 18:12:06 +03:00
this . _clearTimeout ( ) ;
2018-11-24 18:22:59 +02:00
if ( this . _config . animation ) {
2020-03-28 12:29:08 +02:00
this . _element . classList . add ( CLASS _NAME _FADE ) ;
2018-11-24 18:22:59 +02:00
}
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
var complete = function complete ( ) {
2020-12-03 16:18:59 +02:00
_this2 . _element . classList . remove ( CLASS _NAME _SHOWING ) ;
2018-12-15 15:13:22 -08:00
2020-12-03 16:18:59 +02:00
_this2 . _element . classList . add ( CLASS _NAME _SHOW ) ;
2018-12-15 15:13:22 -08:00
2020-12-03 16:18:59 +02:00
EventHandler _ _default [ 'default' ] . trigger ( _this2 . _element , EVENT _SHOWN ) ;
2018-11-13 08:41:12 +02:00
2020-12-03 16:18:59 +02:00
if ( _this2 . _config . autohide ) {
_this2 . _timeout = setTimeout ( function ( ) {
_this2 . hide ( ) ;
} , _this2 . _config . delay ) ;
2018-11-13 08:41:12 +02:00
}
} ;
2020-03-28 12:29:08 +02:00
this . _element . classList . remove ( CLASS _NAME _HIDE ) ;
2018-12-15 15:13:22 -08:00
2019-07-23 23:13:50 -07:00
reflow ( this . _element ) ;
2020-03-28 12:29:08 +02:00
this . _element . classList . add ( CLASS _NAME _SHOWING ) ;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
if ( this . _config . animation ) {
2019-03-01 18:31:34 +02:00
var transitionDuration = getTransitionDurationFromElement ( this . _element ) ;
2021-02-10 18:14:51 +02:00
EventHandler _ _default [ 'default' ] . one ( this . _element , 'transitionend' , complete ) ;
2019-03-01 18:31:34 +02:00
emulateTransitionEnd ( this . _element , transitionDuration ) ;
2018-11-24 18:22:59 +02:00
} else {
complete ( ) ;
}
} ;
2018-11-13 08:41:12 +02:00
2019-04-18 14:47:52 +03:00
_proto . hide = function hide ( ) {
2020-12-03 16:18:59 +02:00
var _this3 = this ;
2018-11-13 08:41:12 +02:00
2020-03-28 12:29:08 +02:00
if ( ! this . _element . classList . contains ( CLASS _NAME _SHOW ) ) {
2018-11-24 18:22:59 +02:00
return ;
}
2018-11-13 08:41:12 +02:00
2020-09-14 18:12:06 +03:00
var hideEvent = EventHandler _ _default [ 'default' ] . trigger ( this . _element , EVENT _HIDE ) ;
2019-07-12 16:56:26 -05:00
if ( hideEvent . defaultPrevented ) {
return ;
}
2018-11-13 08:41:12 +02:00
2019-04-18 14:47:52 +03:00
var complete = function complete ( ) {
2020-12-03 16:18:59 +02:00
_this3 . _element . classList . add ( CLASS _NAME _HIDE ) ;
2019-04-18 14:47:52 +03:00
2020-12-03 16:18:59 +02:00
EventHandler _ _default [ 'default' ] . trigger ( _this3 . _element , EVENT _HIDDEN ) ;
2019-04-18 14:47:52 +03:00
} ;
2020-03-28 12:29:08 +02:00
this . _element . classList . remove ( CLASS _NAME _SHOW ) ;
2019-04-18 14:47:52 +03:00
if ( this . _config . animation ) {
var transitionDuration = getTransitionDurationFromElement ( this . _element ) ;
2021-02-10 18:14:51 +02:00
EventHandler _ _default [ 'default' ] . one ( this . _element , 'transitionend' , complete ) ;
2019-04-18 14:47:52 +03:00
emulateTransitionEnd ( this . _element , transitionDuration ) ;
2018-11-24 18:22:59 +02:00
} else {
2019-04-18 14:47:52 +03:00
complete ( ) ;
2018-11-24 18:22:59 +02:00
}
} ;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
_proto . dispose = function dispose ( ) {
2020-09-14 18:12:06 +03:00
this . _clearTimeout ( ) ;
2018-11-13 08:41:12 +02:00
2020-03-28 12:29:08 +02:00
if ( this . _element . classList . contains ( CLASS _NAME _SHOW ) ) {
this . _element . classList . remove ( CLASS _NAME _SHOW ) ;
2018-11-24 18:22:59 +02:00
}
2018-11-13 08:41:12 +02:00
2020-09-14 18:12:06 +03:00
EventHandler _ _default [ 'default' ] . off ( this . _element , EVENT _CLICK _DISMISS ) ;
2020-12-03 16:18:59 +02:00
_BaseComponent . prototype . dispose . call ( this ) ;
2018-11-24 18:22:59 +02:00
this . _config = null ;
2019-01-04 08:29:45 -08:00
} // Private
;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
_proto . _getConfig = function _getConfig ( config ) {
2020-09-14 18:12:06 +03:00
config = _extends ( { } , Default , Manipulator _ _default [ 'default' ] . getDataAttributes ( this . _element ) , typeof config === 'object' && config ? config : { } ) ;
2019-03-01 18:31:34 +02:00
typeCheckConfig ( NAME , config , this . constructor . DefaultType ) ;
2018-11-24 18:22:59 +02:00
return config ;
} ;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
_proto . _setListeners = function _setListeners ( ) {
2020-12-03 16:18:59 +02:00
var _this4 = this ;
2018-11-13 08:41:12 +02:00
2020-09-14 18:12:06 +03:00
EventHandler _ _default [ 'default' ] . on ( this . _element , EVENT _CLICK _DISMISS , SELECTOR _DATA _DISMISS , function ( ) {
2020-12-03 16:18:59 +02:00
return _this4 . hide ( ) ;
2018-11-24 18:22:59 +02:00
} ) ;
2020-09-14 18:12:06 +03:00
} ;
_proto . _clearTimeout = function _clearTimeout ( ) {
clearTimeout ( this . _timeout ) ;
this . _timeout = null ;
2019-01-04 08:29:45 -08:00
} // Static
;
2018-11-13 08:41:12 +02:00
2019-08-27 16:03:21 +03:00
Toast . jQueryInterface = function jQueryInterface ( config ) {
2018-11-24 18:22:59 +02:00
return this . each ( function ( ) {
2020-09-14 18:12:06 +03:00
var data = Data _ _default [ 'default' ] . getData ( this , DATA _KEY ) ;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
var _config = typeof config === 'object' && config ;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
if ( ! data ) {
data = new Toast ( this , _config ) ;
}
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
if ( typeof config === 'string' ) {
if ( typeof data [ config ] === 'undefined' ) {
throw new TypeError ( "No method named \"" + config + "\"" ) ;
2018-11-13 08:41:12 +02:00
}
2018-11-24 18:22:59 +02:00
data [ config ] ( this ) ;
2018-11-13 08:41:12 +02:00
}
2018-11-24 18:22:59 +02:00
} ) ;
} ;
2018-11-13 08:41:12 +02:00
2021-02-10 18:14:51 +02:00
_createClass ( Toast , null , [ {
2018-11-24 18:22:59 +02:00
key : "DefaultType" ,
get : function get ( ) {
return DefaultType ;
}
2019-02-11 11:15:34 -08:00
} , {
key : "Default" ,
get : function get ( ) {
return Default ;
}
2020-12-03 16:18:59 +02:00
} , {
key : "DATA_KEY" ,
get : function get ( ) {
return DATA _KEY ;
}
2018-11-24 18:22:59 +02:00
} ] ) ;
2018-11-13 08:41:12 +02:00
2018-11-24 18:22:59 +02:00
return Toast ;
2021-02-10 18:14:51 +02:00
} ( BaseComponent _ _default [ 'default' ] ) ;
2018-11-24 18:22:59 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2020-11-11 19:07:37 +02:00
* add . Toast to jQuery only if jQuery is present
2018-11-24 18:22:59 +02:00
* /
2018-11-13 08:41:12 +02:00
2019-07-23 23:13:50 -07:00
2021-02-10 18:14:51 +02:00
defineJQueryPlugin ( NAME , Toast ) ;
2018-11-13 08:41:12 +02:00
return Toast ;
2019-11-08 10:11:23 +02:00
} ) ) ) ;
2018-11-13 08:41:12 +02:00
//# sourceMappingURL=toast.js.map