0
0
mirror of https://github.com/twbs/bootstrap.git synced 2025-01-26 18:52:18 +01:00
Bootstrap/js/dist/util.js

194 lines
6.7 KiB
JavaScript
Raw Permalink Normal View History

2018-11-13 08:41:12 +02:00
/*!
2020-10-13 18:38:30 +03:00
* Bootstrap util.js v4.5.3 (https://getbootstrap.com/)
2020-05-12 19:53:07 +03:00
* Copyright 2011-2020 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
2020-08-04 19:24:33 +03:00
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
2018-11-13 08:41:12 +02:00
*/
2018-07-23 17:51:14 -07:00
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('jquery')) :
typeof define === 'function' && define.amd ? define(['jquery'], factory) :
2020-08-04 19:24:33 +03:00
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Util = factory(global.jQuery));
2019-11-26 19:12:00 +02:00
}(this, (function ($) { 'use strict';
2018-07-23 17:51:14 -07:00
2020-10-13 18:38:30 +03:00
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var $__default = /*#__PURE__*/_interopDefaultLegacy($);
2017-09-30 14:28:03 -07:00
/**
* --------------------------------------------------------------------------
2020-10-13 18:38:30 +03:00
* Bootstrap (v4.5.3): util.js
2020-08-04 19:24:33 +03:00
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
* --------------------------------------------------------------------------
*/
2018-11-13 08:41:12 +02:00
/**
* ------------------------------------------------------------------------
* Private TransitionEnd Helpers
* ------------------------------------------------------------------------
*/
2017-09-30 14:28:03 -07:00
2018-11-13 08:41:12 +02:00
var TRANSITION_END = 'transitionend';
var MAX_UID = 1000000;
var MILLISECONDS_MULTIPLIER = 1000; // Shoutout AngusCroll (https://goo.gl/pxwQGp)
function toType(obj) {
2020-05-12 19:53:07 +03:00
if (obj === null || typeof obj === 'undefined') {
return "" + obj;
}
2018-11-13 08:41:12 +02:00
return {}.toString.call(obj).match(/\s([a-z]+)/i)[1].toLowerCase();
}
function getSpecialTransitionEndEvent() {
return {
bindType: TRANSITION_END,
delegateType: TRANSITION_END,
handle: function handle(event) {
2020-10-13 18:38:30 +03:00
if ($__default['default'](event.target).is(this)) {
2018-11-13 08:41:12 +02:00
return event.handleObj.handler.apply(this, arguments); // eslint-disable-line prefer-rest-params
2018-07-23 17:51:14 -07:00
}
2017-09-30 14:28:03 -07:00
2020-05-12 19:53:07 +03:00
return undefined;
2018-11-13 08:41:12 +02:00
}
};
}
function transitionEndEmulator(duration) {
var _this = this;
var called = false;
2020-10-13 18:38:30 +03:00
$__default['default'](this).one(Util.TRANSITION_END, function () {
2018-11-13 08:41:12 +02:00
called = true;
});
setTimeout(function () {
if (!called) {
Util.triggerTransitionEnd(_this);
}
}, duration);
return this;
}
function setTransitionEndSupport() {
2020-10-13 18:38:30 +03:00
$__default['default'].fn.emulateTransitionEnd = transitionEndEmulator;
$__default['default'].event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent();
2018-11-13 08:41:12 +02:00
}
/**
* --------------------------------------------------------------------------
* Public Util Api
* --------------------------------------------------------------------------
*/
2015-05-07 12:48:22 -07:00
2018-11-13 08:41:12 +02:00
var Util = {
TRANSITION_END: 'bsTransitionEnd',
getUID: function getUID(prefix) {
do {
prefix += ~~(Math.random() * MAX_UID); // "~~" acts like a faster Math.floor() here
} while (document.getElementById(prefix));
2018-07-23 17:51:14 -07:00
2018-11-13 08:41:12 +02:00
return prefix;
},
getSelectorFromElement: function getSelectorFromElement(element) {
var selector = element.getAttribute('data-target');
if (!selector || selector === '#') {
var hrefAttr = element.getAttribute('href');
selector = hrefAttr && hrefAttr !== '#' ? hrefAttr.trim() : '';
}
2018-08-18 20:22:08 -07:00
2019-01-04 08:29:45 -08:00
try {
return document.querySelector(selector) ? selector : null;
2020-10-13 18:38:30 +03:00
} catch (_) {
2019-01-04 08:29:45 -08:00
return null;
}
2018-11-13 08:41:12 +02:00
},
getTransitionDurationFromElement: function getTransitionDurationFromElement(element) {
if (!element) {
return 0;
} // Get transition-duration of the element
2020-10-13 18:38:30 +03:00
var transitionDuration = $__default['default'](element).css('transition-duration');
var transitionDelay = $__default['default'](element).css('transition-delay');
2018-11-13 08:41:12 +02:00
var floatTransitionDuration = parseFloat(transitionDuration);
var floatTransitionDelay = parseFloat(transitionDelay); // Return 0 if element or transition duration is not found
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;
},
reflow: function reflow(element) {
return element.offsetHeight;
},
triggerTransitionEnd: function triggerTransitionEnd(element) {
2020-10-13 18:38:30 +03:00
$__default['default'](element).trigger(TRANSITION_END);
2018-11-13 08:41:12 +02:00
},
supportsTransitionEnd: function supportsTransitionEnd() {
return Boolean(TRANSITION_END);
},
isElement: function isElement(obj) {
return (obj[0] || obj).nodeType;
},
typeCheckConfig: function typeCheckConfig(componentName, config, configTypes) {
for (var property in configTypes) {
if (Object.prototype.hasOwnProperty.call(configTypes, property)) {
var expectedTypes = configTypes[property];
var value = config[property];
var valueType = value && Util.isElement(value) ? 'element' : toType(value);
if (!new RegExp(expectedTypes).test(valueType)) {
throw new Error(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\"."));
2015-08-18 20:28:28 -07:00
}
2015-05-13 14:46:50 -07:00
}
}
2018-12-15 15:13:22 -08:00
},
findShadowRoot: function findShadowRoot(element) {
if (!document.documentElement.attachShadow) {
return null;
} // Can find the shadow root otherwise it'll return the document
if (typeof element.getRootNode === 'function') {
var root = element.getRootNode();
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 Util.findShadowRoot(element.parentNode);
2019-11-26 19:12:00 +02:00
},
jQueryDetection: function jQueryDetection() {
2020-10-13 18:38:30 +03:00
if (typeof $__default['default'] === 'undefined') {
2019-11-26 19:12:00 +02:00
throw new TypeError('Bootstrap\'s JavaScript requires jQuery. jQuery must be included before Bootstrap\'s JavaScript.');
}
2020-10-13 18:38:30 +03:00
var version = $__default['default'].fn.jquery.split(' ')[0].split('.');
2019-11-26 19:12:00 +02:00
var minMajor = 1;
var ltMajor = 2;
var minMinor = 9;
var minPatch = 1;
var maxMajor = 4;
if (version[0] < ltMajor && version[1] < minMinor || version[0] === minMajor && version[1] === minMinor && version[2] < minPatch || version[0] >= maxMajor) {
throw new Error('Bootstrap\'s JavaScript requires at least jQuery v1.9.1 but less than v4.0.0');
}
2018-11-13 08:41:12 +02:00
}
};
2019-11-26 19:12:00 +02:00
Util.jQueryDetection();
2018-11-13 08:41:12 +02:00
setTransitionEndSupport();
2018-07-23 17:51:14 -07:00
return Util;
2018-07-23 17:51:14 -07:00
2019-11-26 19:12:00 +02:00
})));
2018-07-23 17:51:14 -07:00
//# sourceMappingURL=util.js.map