2015-05-07 12:48:22 -07:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Bootstrap ( v4 . 0.0 ) : util . js
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/master/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
'use strict' ;
2015-05-07 17:07:38 -07:00
var Util = ( function ( $ ) {
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Private TransitionEnd Helpers
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
var transition = false ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
var TransitionEndEvent = {
WebkitTransition : 'webkitTransitionEnd' ,
MozTransition : 'transitionend' ,
OTransition : 'oTransitionEnd otransitionend' ,
transition : 'transitionend'
} ;
2015-05-13 14:46:50 -07:00
// shoutout AngusCroll (https://goo.gl/pxwQGp)
function toType ( obj ) {
return ( { } ) . toString . call ( obj ) . match ( /\s([a-zA-Z]+)/ ) [ 1 ] . toLowerCase ( ) ;
}
function isElement ( obj ) {
return ( obj [ 0 ] || obj ) . nodeType ;
}
2015-05-07 16:34:28 -07:00
function getSpecialTransitionEndEvent ( ) {
return {
bindType : transition . end ,
delegateType : transition . end ,
handle : function handle ( event ) {
if ( $ ( event . target ) . is ( this ) ) {
return event . handleObj . handler . apply ( this , arguments ) ;
}
}
} ;
}
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
function transitionEndTest ( ) {
if ( window . QUnit ) {
return false ;
2015-05-07 12:48:22 -07:00
}
2015-05-07 16:34:28 -07:00
var el = document . createElement ( 'bootstrap' ) ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
for ( var name in TransitionEndEvent ) {
if ( el . style [ name ] !== undefined ) {
return { end : TransitionEndEvent [ name ] } ;
}
}
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
return false ;
2015-05-07 12:48:22 -07:00
}
2015-05-07 16:34:28 -07:00
function transitionEndEmulator ( duration ) {
var _this = this ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
var called = false ;
$ ( this ) . one ( Util . TRANSITION _END , function ( ) {
called = true ;
} ) ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
setTimeout ( function ( ) {
if ( ! called ) {
2015-05-07 22:26:40 -07:00
Util . triggerTransitionEnd ( _this ) ;
2015-05-07 12:48:22 -07:00
}
2015-05-07 16:34:28 -07:00
} , duration ) ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
return this ;
2015-05-07 12:48:22 -07:00
}
2015-05-07 16:34:28 -07:00
function setTransitionEndSupport ( ) {
transition = transitionEndTest ( ) ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
$ . fn . emulateTransitionEnd = transitionEndEmulator ;
if ( Util . supportsTransitionEnd ( ) ) {
$ . event . special [ Util . TRANSITION _END ] = getSpecialTransitionEndEvent ( ) ;
2015-05-07 12:48:22 -07:00
}
}
2015-05-07 16:34:28 -07:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Public Util Api
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
var Util = {
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
TRANSITION _END : 'bsTransitionEnd' ,
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
getUID : function getUID ( prefix ) {
do prefix += ~ ~ ( Math . random ( ) * 1000000 ) ; while ( document . getElementById ( prefix ) ) ;
return prefix ;
} ,
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
getSelectorFromElement : function getSelectorFromElement ( element ) {
var selector = element . getAttribute ( 'data-target' ) ;
if ( ! selector ) {
selector = element . getAttribute ( 'href' ) || '' ;
selector = /^#[a-z]/i . test ( selector ) ? selector : null ;
}
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
return selector ;
} ,
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
reflow : function reflow ( element ) {
new Function ( 'bs' , 'return bs' ) ( element . offsetHeight ) ;
} ,
2015-05-07 12:48:22 -07:00
2015-05-07 22:26:40 -07:00
triggerTransitionEnd : function triggerTransitionEnd ( element ) {
$ ( element ) . trigger ( transition . end ) ;
} ,
2015-05-07 16:34:28 -07:00
supportsTransitionEnd : function supportsTransitionEnd ( ) {
return ! ! transition ;
2015-05-13 14:46:50 -07:00
} ,
typeCheckConfig : function typeCheckConfig ( componentName , config , configTypes ) {
for ( var property in configTypes ) {
var expectedTypes = configTypes [ property ] ;
var value = config [ property ] ;
var valueType = undefined ;
if ( value && isElement ( value ) ) valueType = 'element' ; else valueType = toType ( value ) ;
if ( ! new RegExp ( expectedTypes ) . test ( valueType ) ) {
throw new Error ( '' + componentName . toUpperCase ( ) + ': ' + ( 'Option "' + property + '" provided type "' + valueType + '" ' ) + ( 'but expected type "' + expectedTypes + '".' ) ) ;
}
}
2015-05-07 16:34:28 -07:00
}
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
} ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
setTransitionEndSupport ( ) ;
2015-05-07 12:48:22 -07:00
2015-05-07 16:34:28 -07:00
return Util ;
2015-05-07 17:07:38 -07:00
} ) ( jQuery ) ;
2015-05-07 12:48:22 -07:00
//# sourceMappingURL=util.js.map