Total Complexity | 1024 |
Complexity/F | 2.59 |
Lines of Code | 6322 |
Function Count | 396 |
Duplicated Lines | 6322 |
Ratio | 100 % |
Changes | 0 |
Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
Complex classes like public/js/notfound/bootstrap.bundle.js often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes.
Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.
1 | /*! |
||
6 | View Code Duplication | (function (global, factory) { |
|
|
|||
7 | typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('jquery')) : |
||
8 | typeof define === 'function' && define.amd ? define(['exports', 'jquery'], factory) : |
||
9 | (factory((global.bootstrap = {}),global.jQuery)); |
||
10 | }(this, (function (exports,$) { 'use strict'; |
||
11 | |||
12 | $ = $ && $.hasOwnProperty('default') ? $['default'] : $; |
||
13 | |||
14 | function _defineProperties(target, props) { |
||
15 | for (var i = 0; i < props.length; i++) { |
||
16 | var descriptor = props[i]; |
||
17 | descriptor.enumerable = descriptor.enumerable || false; |
||
18 | descriptor.configurable = true; |
||
19 | if ("value" in descriptor) descriptor.writable = true; |
||
20 | Object.defineProperty(target, descriptor.key, descriptor); |
||
21 | } |
||
22 | } |
||
23 | |||
24 | function _createClass(Constructor, protoProps, staticProps) { |
||
25 | if (protoProps) _defineProperties(Constructor.prototype, protoProps); |
||
26 | if (staticProps) _defineProperties(Constructor, staticProps); |
||
27 | return Constructor; |
||
28 | } |
||
29 | |||
30 | function _extends() { |
||
31 | _extends = Object.assign || function (target) { |
||
32 | for (var i = 1; i < arguments.length; i++) { |
||
33 | var source = arguments[i]; |
||
34 | |||
35 | for (var key in source) { |
||
36 | if (Object.prototype.hasOwnProperty.call(source, key)) { |
||
37 | target[key] = source[key]; |
||
38 | } |
||
39 | } |
||
40 | } |
||
41 | |||
42 | return target; |
||
43 | }; |
||
44 | |||
45 | return _extends.apply(this, arguments); |
||
46 | } |
||
47 | |||
48 | function _inheritsLoose(subClass, superClass) { |
||
49 | subClass.prototype = Object.create(superClass.prototype); |
||
50 | subClass.prototype.constructor = subClass; |
||
51 | subClass.__proto__ = superClass; |
||
52 | } |
||
53 | |||
54 | /** |
||
55 | * -------------------------------------------------------------------------- |
||
56 | * Bootstrap (v4.0.0): util.js |
||
57 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
58 | * -------------------------------------------------------------------------- |
||
59 | */ |
||
60 | |||
61 | var Util = function ($$$1) { |
||
62 | /** |
||
63 | * ------------------------------------------------------------------------ |
||
64 | * Private TransitionEnd Helpers |
||
65 | * ------------------------------------------------------------------------ |
||
66 | */ |
||
67 | var transition = false; |
||
68 | var MAX_UID = 1000000; // Shoutout AngusCroll (https://goo.gl/pxwQGp) |
||
69 | |||
70 | function toType(obj) { |
||
71 | return {}.toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase(); |
||
72 | } |
||
73 | |||
74 | function getSpecialTransitionEndEvent() { |
||
75 | return { |
||
76 | bindType: transition.end, |
||
77 | delegateType: transition.end, |
||
78 | handle: function handle(event) { |
||
79 | if ($$$1(event.target).is(this)) { |
||
80 | return event.handleObj.handler.apply(this, arguments); // eslint-disable-line prefer-rest-params |
||
81 | } |
||
82 | |||
83 | return undefined; // eslint-disable-line no-undefined |
||
84 | } |
||
85 | }; |
||
86 | } |
||
87 | |||
88 | function transitionEndTest() { |
||
89 | if (typeof window !== 'undefined' && window.QUnit) { |
||
90 | return false; |
||
91 | } |
||
92 | |||
93 | return { |
||
94 | end: 'transitionend' |
||
95 | }; |
||
96 | } |
||
97 | |||
98 | function transitionEndEmulator(duration) { |
||
99 | var _this = this; |
||
100 | |||
101 | var called = false; |
||
102 | $$$1(this).one(Util.TRANSITION_END, function () { |
||
103 | called = true; |
||
104 | }); |
||
105 | setTimeout(function () { |
||
106 | if (!called) { |
||
107 | Util.triggerTransitionEnd(_this); |
||
108 | } |
||
109 | }, duration); |
||
110 | return this; |
||
111 | } |
||
112 | |||
113 | function setTransitionEndSupport() { |
||
114 | transition = transitionEndTest(); |
||
115 | $$$1.fn.emulateTransitionEnd = transitionEndEmulator; |
||
116 | |||
117 | if (Util.supportsTransitionEnd()) { |
||
118 | $$$1.event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent(); |
||
119 | } |
||
120 | } |
||
121 | |||
122 | function escapeId(selector) { |
||
123 | // We escape IDs in case of special selectors (selector = '#myId:something') |
||
124 | // $.escapeSelector does not exist in jQuery < 3 |
||
125 | selector = typeof $$$1.escapeSelector === 'function' ? $$$1.escapeSelector(selector).substr(1) : selector.replace(/(:|\.|\[|\]|,|=|@)/g, '\\$1'); |
||
126 | return selector; |
||
127 | } |
||
128 | /** |
||
129 | * -------------------------------------------------------------------------- |
||
130 | * Public Util Api |
||
131 | * -------------------------------------------------------------------------- |
||
132 | */ |
||
133 | |||
134 | |||
135 | var Util = { |
||
136 | TRANSITION_END: 'bsTransitionEnd', |
||
137 | getUID: function getUID(prefix) { |
||
138 | do { |
||
139 | // eslint-disable-next-line no-bitwise |
||
140 | prefix += ~~(Math.random() * MAX_UID); // "~~" acts like a faster Math.floor() here |
||
141 | } while (document.getElementById(prefix)); |
||
142 | |||
143 | return prefix; |
||
144 | }, |
||
145 | getSelectorFromElement: function getSelectorFromElement(element) { |
||
146 | var selector = element.getAttribute('data-target'); |
||
147 | |||
148 | if (!selector || selector === '#') { |
||
149 | selector = element.getAttribute('href') || ''; |
||
150 | } // If it's an ID |
||
151 | |||
152 | |||
153 | if (selector.charAt(0) === '#') { |
||
154 | selector = escapeId(selector); |
||
155 | } |
||
156 | |||
157 | try { |
||
158 | var $selector = $$$1(document).find(selector); |
||
159 | return $selector.length > 0 ? selector : null; |
||
160 | } catch (err) { |
||
161 | return null; |
||
162 | } |
||
163 | }, |
||
164 | reflow: function reflow(element) { |
||
165 | return element.offsetHeight; |
||
166 | }, |
||
167 | triggerTransitionEnd: function triggerTransitionEnd(element) { |
||
168 | $$$1(element).trigger(transition.end); |
||
169 | }, |
||
170 | supportsTransitionEnd: function supportsTransitionEnd() { |
||
171 | return Boolean(transition); |
||
172 | }, |
||
173 | isElement: function isElement(obj) { |
||
174 | return (obj[0] || obj).nodeType; |
||
175 | }, |
||
176 | typeCheckConfig: function typeCheckConfig(componentName, config, configTypes) { |
||
177 | for (var property in configTypes) { |
||
178 | if (Object.prototype.hasOwnProperty.call(configTypes, property)) { |
||
179 | var expectedTypes = configTypes[property]; |
||
180 | var value = config[property]; |
||
181 | var valueType = value && Util.isElement(value) ? 'element' : toType(value); |
||
182 | |||
183 | if (!new RegExp(expectedTypes).test(valueType)) { |
||
184 | throw new Error(componentName.toUpperCase() + ": " + ("Option \"" + property + "\" provided type \"" + valueType + "\" ") + ("but expected type \"" + expectedTypes + "\".")); |
||
185 | } |
||
186 | } |
||
187 | } |
||
188 | } |
||
189 | }; |
||
190 | setTransitionEndSupport(); |
||
191 | return Util; |
||
192 | }($); |
||
193 | |||
194 | /** |
||
195 | * -------------------------------------------------------------------------- |
||
196 | * Bootstrap (v4.0.0): alert.js |
||
197 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
198 | * -------------------------------------------------------------------------- |
||
199 | */ |
||
200 | |||
201 | var Alert = function ($$$1) { |
||
202 | /** |
||
203 | * ------------------------------------------------------------------------ |
||
204 | * Constants |
||
205 | * ------------------------------------------------------------------------ |
||
206 | */ |
||
207 | var NAME = 'alert'; |
||
208 | var VERSION = '4.0.0'; |
||
209 | var DATA_KEY = 'bs.alert'; |
||
210 | var EVENT_KEY = "." + DATA_KEY; |
||
211 | var DATA_API_KEY = '.data-api'; |
||
212 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
213 | var TRANSITION_DURATION = 150; |
||
214 | var Selector = { |
||
215 | DISMISS: '[data-dismiss="alert"]' |
||
216 | }; |
||
217 | var Event = { |
||
218 | CLOSE: "close" + EVENT_KEY, |
||
219 | CLOSED: "closed" + EVENT_KEY, |
||
220 | CLICK_DATA_API: "click" + EVENT_KEY + DATA_API_KEY |
||
221 | }; |
||
222 | var ClassName = { |
||
223 | ALERT: 'alert', |
||
224 | FADE: 'fade', |
||
225 | SHOW: 'show' |
||
226 | /** |
||
227 | * ------------------------------------------------------------------------ |
||
228 | * Class Definition |
||
229 | * ------------------------------------------------------------------------ |
||
230 | */ |
||
231 | |||
232 | }; |
||
233 | |||
234 | var Alert = |
||
235 | /*#__PURE__*/ |
||
236 | function () { |
||
237 | function Alert(element) { |
||
238 | this._element = element; |
||
239 | } // Getters |
||
240 | |||
241 | |||
242 | var _proto = Alert.prototype; |
||
243 | |||
244 | // Public |
||
245 | _proto.close = function close(element) { |
||
246 | element = element || this._element; |
||
247 | |||
248 | var rootElement = this._getRootElement(element); |
||
249 | |||
250 | var customEvent = this._triggerCloseEvent(rootElement); |
||
251 | |||
252 | if (customEvent.isDefaultPrevented()) { |
||
253 | return; |
||
254 | } |
||
255 | |||
256 | this._removeElement(rootElement); |
||
257 | }; |
||
258 | |||
259 | _proto.dispose = function dispose() { |
||
260 | $$$1.removeData(this._element, DATA_KEY); |
||
261 | this._element = null; |
||
262 | }; // Private |
||
263 | |||
264 | |||
265 | _proto._getRootElement = function _getRootElement(element) { |
||
266 | var selector = Util.getSelectorFromElement(element); |
||
267 | var parent = false; |
||
268 | |||
269 | if (selector) { |
||
270 | parent = $$$1(selector)[0]; |
||
271 | } |
||
272 | |||
273 | if (!parent) { |
||
274 | parent = $$$1(element).closest("." + ClassName.ALERT)[0]; |
||
275 | } |
||
276 | |||
277 | return parent; |
||
278 | }; |
||
279 | |||
280 | _proto._triggerCloseEvent = function _triggerCloseEvent(element) { |
||
281 | var closeEvent = $$$1.Event(Event.CLOSE); |
||
282 | $$$1(element).trigger(closeEvent); |
||
283 | return closeEvent; |
||
284 | }; |
||
285 | |||
286 | _proto._removeElement = function _removeElement(element) { |
||
287 | var _this = this; |
||
288 | |||
289 | $$$1(element).removeClass(ClassName.SHOW); |
||
290 | |||
291 | if (!Util.supportsTransitionEnd() || !$$$1(element).hasClass(ClassName.FADE)) { |
||
292 | this._destroyElement(element); |
||
293 | |||
294 | return; |
||
295 | } |
||
296 | |||
297 | $$$1(element).one(Util.TRANSITION_END, function (event) { |
||
298 | return _this._destroyElement(element, event); |
||
299 | }).emulateTransitionEnd(TRANSITION_DURATION); |
||
300 | }; |
||
301 | |||
302 | _proto._destroyElement = function _destroyElement(element) { |
||
303 | $$$1(element).detach().trigger(Event.CLOSED).remove(); |
||
304 | }; // Static |
||
305 | |||
306 | |||
307 | Alert._jQueryInterface = function _jQueryInterface(config) { |
||
308 | return this.each(function () { |
||
309 | var $element = $$$1(this); |
||
310 | var data = $element.data(DATA_KEY); |
||
311 | |||
312 | if (!data) { |
||
313 | data = new Alert(this); |
||
314 | $element.data(DATA_KEY, data); |
||
315 | } |
||
316 | |||
317 | if (config === 'close') { |
||
318 | data[config](this); |
||
319 | } |
||
320 | }); |
||
321 | }; |
||
322 | |||
323 | Alert._handleDismiss = function _handleDismiss(alertInstance) { |
||
324 | return function (event) { |
||
325 | if (event) { |
||
326 | event.preventDefault(); |
||
327 | } |
||
328 | |||
329 | alertInstance.close(this); |
||
330 | }; |
||
331 | }; |
||
332 | |||
333 | _createClass(Alert, null, [{ |
||
334 | key: "VERSION", |
||
335 | get: function get() { |
||
336 | return VERSION; |
||
337 | } |
||
338 | }]); |
||
339 | return Alert; |
||
340 | }(); |
||
341 | /** |
||
342 | * ------------------------------------------------------------------------ |
||
343 | * Data Api implementation |
||
344 | * ------------------------------------------------------------------------ |
||
345 | */ |
||
346 | |||
347 | |||
348 | $$$1(document).on(Event.CLICK_DATA_API, Selector.DISMISS, Alert._handleDismiss(new Alert())); |
||
349 | /** |
||
350 | * ------------------------------------------------------------------------ |
||
351 | * jQuery |
||
352 | * ------------------------------------------------------------------------ |
||
353 | */ |
||
354 | |||
355 | $$$1.fn[NAME] = Alert._jQueryInterface; |
||
356 | $$$1.fn[NAME].Constructor = Alert; |
||
357 | |||
358 | $$$1.fn[NAME].noConflict = function () { |
||
359 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
360 | return Alert._jQueryInterface; |
||
361 | }; |
||
362 | |||
363 | return Alert; |
||
364 | }($); |
||
365 | |||
366 | /** |
||
367 | * -------------------------------------------------------------------------- |
||
368 | * Bootstrap (v4.0.0): button.js |
||
369 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
370 | * -------------------------------------------------------------------------- |
||
371 | */ |
||
372 | |||
373 | var Button = function ($$$1) { |
||
374 | /** |
||
375 | * ------------------------------------------------------------------------ |
||
376 | * Constants |
||
377 | * ------------------------------------------------------------------------ |
||
378 | */ |
||
379 | var NAME = 'button'; |
||
380 | var VERSION = '4.0.0'; |
||
381 | var DATA_KEY = 'bs.button'; |
||
382 | var EVENT_KEY = "." + DATA_KEY; |
||
383 | var DATA_API_KEY = '.data-api'; |
||
384 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
385 | var ClassName = { |
||
386 | ACTIVE: 'active', |
||
387 | BUTTON: 'btn', |
||
388 | FOCUS: 'focus' |
||
389 | }; |
||
390 | var Selector = { |
||
391 | DATA_TOGGLE_CARROT: '[data-toggle^="button"]', |
||
392 | DATA_TOGGLE: '[data-toggle="buttons"]', |
||
393 | INPUT: 'input', |
||
394 | ACTIVE: '.active', |
||
395 | BUTTON: '.btn' |
||
396 | }; |
||
397 | var Event = { |
||
398 | CLICK_DATA_API: "click" + EVENT_KEY + DATA_API_KEY, |
||
399 | FOCUS_BLUR_DATA_API: "focus" + EVENT_KEY + DATA_API_KEY + " " + ("blur" + EVENT_KEY + DATA_API_KEY) |
||
400 | /** |
||
401 | * ------------------------------------------------------------------------ |
||
402 | * Class Definition |
||
403 | * ------------------------------------------------------------------------ |
||
404 | */ |
||
405 | |||
406 | }; |
||
407 | |||
408 | var Button = |
||
409 | /*#__PURE__*/ |
||
410 | function () { |
||
411 | function Button(element) { |
||
412 | this._element = element; |
||
413 | } // Getters |
||
414 | |||
415 | |||
416 | var _proto = Button.prototype; |
||
417 | |||
418 | // Public |
||
419 | _proto.toggle = function toggle() { |
||
420 | var triggerChangeEvent = true; |
||
421 | var addAriaPressed = true; |
||
422 | var rootElement = $$$1(this._element).closest(Selector.DATA_TOGGLE)[0]; |
||
423 | |||
424 | if (rootElement) { |
||
425 | var input = $$$1(this._element).find(Selector.INPUT)[0]; |
||
426 | |||
427 | if (input) { |
||
428 | if (input.type === 'radio') { |
||
429 | if (input.checked && $$$1(this._element).hasClass(ClassName.ACTIVE)) { |
||
430 | triggerChangeEvent = false; |
||
431 | } else { |
||
432 | var activeElement = $$$1(rootElement).find(Selector.ACTIVE)[0]; |
||
433 | |||
434 | if (activeElement) { |
||
435 | $$$1(activeElement).removeClass(ClassName.ACTIVE); |
||
436 | } |
||
437 | } |
||
438 | } |
||
439 | |||
440 | if (triggerChangeEvent) { |
||
441 | if (input.hasAttribute('disabled') || rootElement.hasAttribute('disabled') || input.classList.contains('disabled') || rootElement.classList.contains('disabled')) { |
||
442 | return; |
||
443 | } |
||
444 | |||
445 | input.checked = !$$$1(this._element).hasClass(ClassName.ACTIVE); |
||
446 | $$$1(input).trigger('change'); |
||
447 | } |
||
448 | |||
449 | input.focus(); |
||
450 | addAriaPressed = false; |
||
451 | } |
||
452 | } |
||
453 | |||
454 | if (addAriaPressed) { |
||
455 | this._element.setAttribute('aria-pressed', !$$$1(this._element).hasClass(ClassName.ACTIVE)); |
||
456 | } |
||
457 | |||
458 | if (triggerChangeEvent) { |
||
459 | $$$1(this._element).toggleClass(ClassName.ACTIVE); |
||
460 | } |
||
461 | }; |
||
462 | |||
463 | _proto.dispose = function dispose() { |
||
464 | $$$1.removeData(this._element, DATA_KEY); |
||
465 | this._element = null; |
||
466 | }; // Static |
||
467 | |||
468 | |||
469 | Button._jQueryInterface = function _jQueryInterface(config) { |
||
470 | return this.each(function () { |
||
471 | var data = $$$1(this).data(DATA_KEY); |
||
472 | |||
473 | if (!data) { |
||
474 | data = new Button(this); |
||
475 | $$$1(this).data(DATA_KEY, data); |
||
476 | } |
||
477 | |||
478 | if (config === 'toggle') { |
||
479 | data[config](); |
||
480 | } |
||
481 | }); |
||
482 | }; |
||
483 | |||
484 | _createClass(Button, null, [{ |
||
485 | key: "VERSION", |
||
486 | get: function get() { |
||
487 | return VERSION; |
||
488 | } |
||
489 | }]); |
||
490 | return Button; |
||
491 | }(); |
||
492 | /** |
||
493 | * ------------------------------------------------------------------------ |
||
494 | * Data Api implementation |
||
495 | * ------------------------------------------------------------------------ |
||
496 | */ |
||
497 | |||
498 | |||
499 | $$$1(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) { |
||
500 | event.preventDefault(); |
||
501 | var button = event.target; |
||
502 | |||
503 | if (!$$$1(button).hasClass(ClassName.BUTTON)) { |
||
504 | button = $$$1(button).closest(Selector.BUTTON); |
||
505 | } |
||
506 | |||
507 | Button._jQueryInterface.call($$$1(button), 'toggle'); |
||
508 | }).on(Event.FOCUS_BLUR_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) { |
||
509 | var button = $$$1(event.target).closest(Selector.BUTTON)[0]; |
||
510 | $$$1(button).toggleClass(ClassName.FOCUS, /^focus(in)?$/.test(event.type)); |
||
511 | }); |
||
512 | /** |
||
513 | * ------------------------------------------------------------------------ |
||
514 | * jQuery |
||
515 | * ------------------------------------------------------------------------ |
||
516 | */ |
||
517 | |||
518 | $$$1.fn[NAME] = Button._jQueryInterface; |
||
519 | $$$1.fn[NAME].Constructor = Button; |
||
520 | |||
521 | $$$1.fn[NAME].noConflict = function () { |
||
522 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
523 | return Button._jQueryInterface; |
||
524 | }; |
||
525 | |||
526 | return Button; |
||
527 | }($); |
||
528 | |||
529 | /** |
||
530 | * -------------------------------------------------------------------------- |
||
531 | * Bootstrap (v4.0.0): carousel.js |
||
532 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
533 | * -------------------------------------------------------------------------- |
||
534 | */ |
||
535 | |||
536 | var Carousel = function ($$$1) { |
||
537 | /** |
||
538 | * ------------------------------------------------------------------------ |
||
539 | * Constants |
||
540 | * ------------------------------------------------------------------------ |
||
541 | */ |
||
542 | var NAME = 'carousel'; |
||
543 | var VERSION = '4.0.0'; |
||
544 | var DATA_KEY = 'bs.carousel'; |
||
545 | var EVENT_KEY = "." + DATA_KEY; |
||
546 | var DATA_API_KEY = '.data-api'; |
||
547 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
548 | var TRANSITION_DURATION = 600; |
||
549 | var ARROW_LEFT_KEYCODE = 37; // KeyboardEvent.which value for left arrow key |
||
550 | |||
551 | var ARROW_RIGHT_KEYCODE = 39; // KeyboardEvent.which value for right arrow key |
||
552 | |||
553 | var TOUCHEVENT_COMPAT_WAIT = 500; // Time for mouse compat events to fire after touch |
||
554 | |||
555 | var Default = { |
||
556 | interval: 5000, |
||
557 | keyboard: true, |
||
558 | slide: false, |
||
559 | pause: 'hover', |
||
560 | wrap: true |
||
561 | }; |
||
562 | var DefaultType = { |
||
563 | interval: '(number|boolean)', |
||
564 | keyboard: 'boolean', |
||
565 | slide: '(boolean|string)', |
||
566 | pause: '(string|boolean)', |
||
567 | wrap: 'boolean' |
||
568 | }; |
||
569 | var Direction = { |
||
570 | NEXT: 'next', |
||
571 | PREV: 'prev', |
||
572 | LEFT: 'left', |
||
573 | RIGHT: 'right' |
||
574 | }; |
||
575 | var Event = { |
||
576 | SLIDE: "slide" + EVENT_KEY, |
||
577 | SLID: "slid" + EVENT_KEY, |
||
578 | KEYDOWN: "keydown" + EVENT_KEY, |
||
579 | MOUSEENTER: "mouseenter" + EVENT_KEY, |
||
580 | MOUSELEAVE: "mouseleave" + EVENT_KEY, |
||
581 | TOUCHEND: "touchend" + EVENT_KEY, |
||
582 | LOAD_DATA_API: "load" + EVENT_KEY + DATA_API_KEY, |
||
583 | CLICK_DATA_API: "click" + EVENT_KEY + DATA_API_KEY |
||
584 | }; |
||
585 | var ClassName = { |
||
586 | CAROUSEL: 'carousel', |
||
587 | ACTIVE: 'active', |
||
588 | SLIDE: 'slide', |
||
589 | RIGHT: 'carousel-item-right', |
||
590 | LEFT: 'carousel-item-left', |
||
591 | NEXT: 'carousel-item-next', |
||
592 | PREV: 'carousel-item-prev', |
||
593 | ITEM: 'carousel-item' |
||
594 | }; |
||
595 | var Selector = { |
||
596 | ACTIVE: '.active', |
||
597 | ACTIVE_ITEM: '.active.carousel-item', |
||
598 | ITEM: '.carousel-item', |
||
599 | NEXT_PREV: '.carousel-item-next, .carousel-item-prev', |
||
600 | INDICATORS: '.carousel-indicators', |
||
601 | DATA_SLIDE: '[data-slide], [data-slide-to]', |
||
602 | DATA_RIDE: '[data-ride="carousel"]' |
||
603 | /** |
||
604 | * ------------------------------------------------------------------------ |
||
605 | * Class Definition |
||
606 | * ------------------------------------------------------------------------ |
||
607 | */ |
||
608 | |||
609 | }; |
||
610 | |||
611 | var Carousel = |
||
612 | /*#__PURE__*/ |
||
613 | function () { |
||
614 | function Carousel(element, config) { |
||
615 | this._items = null; |
||
616 | this._interval = null; |
||
617 | this._activeElement = null; |
||
618 | this._isPaused = false; |
||
619 | this._isSliding = false; |
||
620 | this.touchTimeout = null; |
||
621 | this._config = this._getConfig(config); |
||
622 | this._element = $$$1(element)[0]; |
||
623 | this._indicatorsElement = $$$1(this._element).find(Selector.INDICATORS)[0]; |
||
624 | |||
625 | this._addEventListeners(); |
||
626 | } // Getters |
||
627 | |||
628 | |||
629 | var _proto = Carousel.prototype; |
||
630 | |||
631 | // Public |
||
632 | _proto.next = function next() { |
||
633 | if (!this._isSliding) { |
||
634 | this._slide(Direction.NEXT); |
||
635 | } |
||
636 | }; |
||
637 | |||
638 | _proto.nextWhenVisible = function nextWhenVisible() { |
||
639 | // Don't call next when the page isn't visible |
||
640 | // or the carousel or its parent isn't visible |
||
641 | if (!document.hidden && $$$1(this._element).is(':visible') && $$$1(this._element).css('visibility') !== 'hidden') { |
||
642 | this.next(); |
||
643 | } |
||
644 | }; |
||
645 | |||
646 | _proto.prev = function prev() { |
||
647 | if (!this._isSliding) { |
||
648 | this._slide(Direction.PREV); |
||
649 | } |
||
650 | }; |
||
651 | |||
652 | _proto.pause = function pause(event) { |
||
653 | if (!event) { |
||
654 | this._isPaused = true; |
||
655 | } |
||
656 | |||
657 | if ($$$1(this._element).find(Selector.NEXT_PREV)[0] && Util.supportsTransitionEnd()) { |
||
658 | Util.triggerTransitionEnd(this._element); |
||
659 | this.cycle(true); |
||
660 | } |
||
661 | |||
662 | clearInterval(this._interval); |
||
663 | this._interval = null; |
||
664 | }; |
||
665 | |||
666 | _proto.cycle = function cycle(event) { |
||
667 | if (!event) { |
||
668 | this._isPaused = false; |
||
669 | } |
||
670 | |||
671 | if (this._interval) { |
||
672 | clearInterval(this._interval); |
||
673 | this._interval = null; |
||
674 | } |
||
675 | |||
676 | if (this._config.interval && !this._isPaused) { |
||
677 | this._interval = setInterval((document.visibilityState ? this.nextWhenVisible : this.next).bind(this), this._config.interval); |
||
678 | } |
||
679 | }; |
||
680 | |||
681 | _proto.to = function to(index) { |
||
682 | var _this = this; |
||
683 | |||
684 | this._activeElement = $$$1(this._element).find(Selector.ACTIVE_ITEM)[0]; |
||
685 | |||
686 | var activeIndex = this._getItemIndex(this._activeElement); |
||
687 | |||
688 | if (index > this._items.length - 1 || index < 0) { |
||
689 | return; |
||
690 | } |
||
691 | |||
692 | if (this._isSliding) { |
||
693 | $$$1(this._element).one(Event.SLID, function () { |
||
694 | return _this.to(index); |
||
695 | }); |
||
696 | return; |
||
697 | } |
||
698 | |||
699 | if (activeIndex === index) { |
||
700 | this.pause(); |
||
701 | this.cycle(); |
||
702 | return; |
||
703 | } |
||
704 | |||
705 | var direction = index > activeIndex ? Direction.NEXT : Direction.PREV; |
||
706 | |||
707 | this._slide(direction, this._items[index]); |
||
708 | }; |
||
709 | |||
710 | _proto.dispose = function dispose() { |
||
711 | $$$1(this._element).off(EVENT_KEY); |
||
712 | $$$1.removeData(this._element, DATA_KEY); |
||
713 | this._items = null; |
||
714 | this._config = null; |
||
715 | this._element = null; |
||
716 | this._interval = null; |
||
717 | this._isPaused = null; |
||
718 | this._isSliding = null; |
||
719 | this._activeElement = null; |
||
720 | this._indicatorsElement = null; |
||
721 | }; // Private |
||
722 | |||
723 | |||
724 | _proto._getConfig = function _getConfig(config) { |
||
725 | config = _extends({}, Default, config); |
||
726 | Util.typeCheckConfig(NAME, config, DefaultType); |
||
727 | return config; |
||
728 | }; |
||
729 | |||
730 | _proto._addEventListeners = function _addEventListeners() { |
||
731 | var _this2 = this; |
||
732 | |||
733 | if (this._config.keyboard) { |
||
734 | $$$1(this._element).on(Event.KEYDOWN, function (event) { |
||
735 | return _this2._keydown(event); |
||
736 | }); |
||
737 | } |
||
738 | |||
739 | if (this._config.pause === 'hover') { |
||
740 | $$$1(this._element).on(Event.MOUSEENTER, function (event) { |
||
741 | return _this2.pause(event); |
||
742 | }).on(Event.MOUSELEAVE, function (event) { |
||
743 | return _this2.cycle(event); |
||
744 | }); |
||
745 | |||
746 | if ('ontouchstart' in document.documentElement) { |
||
747 | // If it's a touch-enabled device, mouseenter/leave are fired as |
||
748 | // part of the mouse compatibility events on first tap - the carousel |
||
749 | // would stop cycling until user tapped out of it; |
||
750 | // here, we listen for touchend, explicitly pause the carousel |
||
751 | // (as if it's the second time we tap on it, mouseenter compat event |
||
752 | // is NOT fired) and after a timeout (to allow for mouse compatibility |
||
753 | // events to fire) we explicitly restart cycling |
||
754 | $$$1(this._element).on(Event.TOUCHEND, function () { |
||
755 | _this2.pause(); |
||
756 | |||
757 | if (_this2.touchTimeout) { |
||
758 | clearTimeout(_this2.touchTimeout); |
||
759 | } |
||
760 | |||
761 | _this2.touchTimeout = setTimeout(function (event) { |
||
762 | return _this2.cycle(event); |
||
763 | }, TOUCHEVENT_COMPAT_WAIT + _this2._config.interval); |
||
764 | }); |
||
765 | } |
||
766 | } |
||
767 | }; |
||
768 | |||
769 | _proto._keydown = function _keydown(event) { |
||
770 | if (/input|textarea/i.test(event.target.tagName)) { |
||
771 | return; |
||
772 | } |
||
773 | |||
774 | switch (event.which) { |
||
775 | case ARROW_LEFT_KEYCODE: |
||
776 | event.preventDefault(); |
||
777 | this.prev(); |
||
778 | break; |
||
779 | |||
780 | case ARROW_RIGHT_KEYCODE: |
||
781 | event.preventDefault(); |
||
782 | this.next(); |
||
783 | break; |
||
784 | |||
785 | default: |
||
786 | } |
||
787 | }; |
||
788 | |||
789 | _proto._getItemIndex = function _getItemIndex(element) { |
||
790 | this._items = $$$1.makeArray($$$1(element).parent().find(Selector.ITEM)); |
||
791 | return this._items.indexOf(element); |
||
792 | }; |
||
793 | |||
794 | _proto._getItemByDirection = function _getItemByDirection(direction, activeElement) { |
||
795 | var isNextDirection = direction === Direction.NEXT; |
||
796 | var isPrevDirection = direction === Direction.PREV; |
||
797 | |||
798 | var activeIndex = this._getItemIndex(activeElement); |
||
799 | |||
800 | var lastItemIndex = this._items.length - 1; |
||
801 | var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex; |
||
802 | |||
803 | if (isGoingToWrap && !this._config.wrap) { |
||
804 | return activeElement; |
||
805 | } |
||
806 | |||
807 | var delta = direction === Direction.PREV ? -1 : 1; |
||
808 | var itemIndex = (activeIndex + delta) % this._items.length; |
||
809 | return itemIndex === -1 ? this._items[this._items.length - 1] : this._items[itemIndex]; |
||
810 | }; |
||
811 | |||
812 | _proto._triggerSlideEvent = function _triggerSlideEvent(relatedTarget, eventDirectionName) { |
||
813 | var targetIndex = this._getItemIndex(relatedTarget); |
||
814 | |||
815 | var fromIndex = this._getItemIndex($$$1(this._element).find(Selector.ACTIVE_ITEM)[0]); |
||
816 | |||
817 | var slideEvent = $$$1.Event(Event.SLIDE, { |
||
818 | relatedTarget: relatedTarget, |
||
819 | direction: eventDirectionName, |
||
820 | from: fromIndex, |
||
821 | to: targetIndex |
||
822 | }); |
||
823 | $$$1(this._element).trigger(slideEvent); |
||
824 | return slideEvent; |
||
825 | }; |
||
826 | |||
827 | _proto._setActiveIndicatorElement = function _setActiveIndicatorElement(element) { |
||
828 | if (this._indicatorsElement) { |
||
829 | $$$1(this._indicatorsElement).find(Selector.ACTIVE).removeClass(ClassName.ACTIVE); |
||
830 | |||
831 | var nextIndicator = this._indicatorsElement.children[this._getItemIndex(element)]; |
||
832 | |||
833 | if (nextIndicator) { |
||
834 | $$$1(nextIndicator).addClass(ClassName.ACTIVE); |
||
835 | } |
||
836 | } |
||
837 | }; |
||
838 | |||
839 | _proto._slide = function _slide(direction, element) { |
||
840 | var _this3 = this; |
||
841 | |||
842 | var activeElement = $$$1(this._element).find(Selector.ACTIVE_ITEM)[0]; |
||
843 | |||
844 | var activeElementIndex = this._getItemIndex(activeElement); |
||
845 | |||
846 | var nextElement = element || activeElement && this._getItemByDirection(direction, activeElement); |
||
847 | |||
848 | var nextElementIndex = this._getItemIndex(nextElement); |
||
849 | |||
850 | var isCycling = Boolean(this._interval); |
||
851 | var directionalClassName; |
||
852 | var orderClassName; |
||
853 | var eventDirectionName; |
||
854 | |||
855 | if (direction === Direction.NEXT) { |
||
856 | directionalClassName = ClassName.LEFT; |
||
857 | orderClassName = ClassName.NEXT; |
||
858 | eventDirectionName = Direction.LEFT; |
||
859 | } else { |
||
860 | directionalClassName = ClassName.RIGHT; |
||
861 | orderClassName = ClassName.PREV; |
||
862 | eventDirectionName = Direction.RIGHT; |
||
863 | } |
||
864 | |||
865 | if (nextElement && $$$1(nextElement).hasClass(ClassName.ACTIVE)) { |
||
866 | this._isSliding = false; |
||
867 | return; |
||
868 | } |
||
869 | |||
870 | var slideEvent = this._triggerSlideEvent(nextElement, eventDirectionName); |
||
871 | |||
872 | if (slideEvent.isDefaultPrevented()) { |
||
873 | return; |
||
874 | } |
||
875 | |||
876 | if (!activeElement || !nextElement) { |
||
877 | // Some weirdness is happening, so we bail |
||
878 | return; |
||
879 | } |
||
880 | |||
881 | this._isSliding = true; |
||
882 | |||
883 | if (isCycling) { |
||
884 | this.pause(); |
||
885 | } |
||
886 | |||
887 | this._setActiveIndicatorElement(nextElement); |
||
888 | |||
889 | var slidEvent = $$$1.Event(Event.SLID, { |
||
890 | relatedTarget: nextElement, |
||
891 | direction: eventDirectionName, |
||
892 | from: activeElementIndex, |
||
893 | to: nextElementIndex |
||
894 | }); |
||
895 | |||
896 | if (Util.supportsTransitionEnd() && $$$1(this._element).hasClass(ClassName.SLIDE)) { |
||
897 | $$$1(nextElement).addClass(orderClassName); |
||
898 | Util.reflow(nextElement); |
||
899 | $$$1(activeElement).addClass(directionalClassName); |
||
900 | $$$1(nextElement).addClass(directionalClassName); |
||
901 | $$$1(activeElement).one(Util.TRANSITION_END, function () { |
||
902 | $$$1(nextElement).removeClass(directionalClassName + " " + orderClassName).addClass(ClassName.ACTIVE); |
||
903 | $$$1(activeElement).removeClass(ClassName.ACTIVE + " " + orderClassName + " " + directionalClassName); |
||
904 | _this3._isSliding = false; |
||
905 | setTimeout(function () { |
||
906 | return $$$1(_this3._element).trigger(slidEvent); |
||
907 | }, 0); |
||
908 | }).emulateTransitionEnd(TRANSITION_DURATION); |
||
909 | } else { |
||
910 | $$$1(activeElement).removeClass(ClassName.ACTIVE); |
||
911 | $$$1(nextElement).addClass(ClassName.ACTIVE); |
||
912 | this._isSliding = false; |
||
913 | $$$1(this._element).trigger(slidEvent); |
||
914 | } |
||
915 | |||
916 | if (isCycling) { |
||
917 | this.cycle(); |
||
918 | } |
||
919 | }; // Static |
||
920 | |||
921 | |||
922 | Carousel._jQueryInterface = function _jQueryInterface(config) { |
||
923 | return this.each(function () { |
||
924 | var data = $$$1(this).data(DATA_KEY); |
||
925 | |||
926 | var _config = _extends({}, Default, $$$1(this).data()); |
||
927 | |||
928 | if (typeof config === 'object') { |
||
929 | _config = _extends({}, _config, config); |
||
930 | } |
||
931 | |||
932 | var action = typeof config === 'string' ? config : _config.slide; |
||
933 | |||
934 | if (!data) { |
||
935 | data = new Carousel(this, _config); |
||
936 | $$$1(this).data(DATA_KEY, data); |
||
937 | } |
||
938 | |||
939 | if (typeof config === 'number') { |
||
940 | data.to(config); |
||
941 | } else if (typeof action === 'string') { |
||
942 | if (typeof data[action] === 'undefined') { |
||
943 | throw new TypeError("No method named \"" + action + "\""); |
||
944 | } |
||
945 | |||
946 | data[action](); |
||
947 | } else if (_config.interval) { |
||
948 | data.pause(); |
||
949 | data.cycle(); |
||
950 | } |
||
951 | }); |
||
952 | }; |
||
953 | |||
954 | Carousel._dataApiClickHandler = function _dataApiClickHandler(event) { |
||
955 | var selector = Util.getSelectorFromElement(this); |
||
956 | |||
957 | if (!selector) { |
||
958 | return; |
||
959 | } |
||
960 | |||
961 | var target = $$$1(selector)[0]; |
||
962 | |||
963 | if (!target || !$$$1(target).hasClass(ClassName.CAROUSEL)) { |
||
964 | return; |
||
965 | } |
||
966 | |||
967 | var config = _extends({}, $$$1(target).data(), $$$1(this).data()); |
||
968 | var slideIndex = this.getAttribute('data-slide-to'); |
||
969 | |||
970 | if (slideIndex) { |
||
971 | config.interval = false; |
||
972 | } |
||
973 | |||
974 | Carousel._jQueryInterface.call($$$1(target), config); |
||
975 | |||
976 | if (slideIndex) { |
||
977 | $$$1(target).data(DATA_KEY).to(slideIndex); |
||
978 | } |
||
979 | |||
980 | event.preventDefault(); |
||
981 | }; |
||
982 | |||
983 | _createClass(Carousel, null, [{ |
||
984 | key: "VERSION", |
||
985 | get: function get() { |
||
986 | return VERSION; |
||
987 | } |
||
988 | }, { |
||
989 | key: "Default", |
||
990 | get: function get() { |
||
991 | return Default; |
||
992 | } |
||
993 | }]); |
||
994 | return Carousel; |
||
995 | }(); |
||
996 | /** |
||
997 | * ------------------------------------------------------------------------ |
||
998 | * Data Api implementation |
||
999 | * ------------------------------------------------------------------------ |
||
1000 | */ |
||
1001 | |||
1002 | |||
1003 | $$$1(document).on(Event.CLICK_DATA_API, Selector.DATA_SLIDE, Carousel._dataApiClickHandler); |
||
1004 | $$$1(window).on(Event.LOAD_DATA_API, function () { |
||
1005 | $$$1(Selector.DATA_RIDE).each(function () { |
||
1006 | var $carousel = $$$1(this); |
||
1007 | |||
1008 | Carousel._jQueryInterface.call($carousel, $carousel.data()); |
||
1009 | }); |
||
1010 | }); |
||
1011 | /** |
||
1012 | * ------------------------------------------------------------------------ |
||
1013 | * jQuery |
||
1014 | * ------------------------------------------------------------------------ |
||
1015 | */ |
||
1016 | |||
1017 | $$$1.fn[NAME] = Carousel._jQueryInterface; |
||
1018 | $$$1.fn[NAME].Constructor = Carousel; |
||
1019 | |||
1020 | $$$1.fn[NAME].noConflict = function () { |
||
1021 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
1022 | return Carousel._jQueryInterface; |
||
1023 | }; |
||
1024 | |||
1025 | return Carousel; |
||
1026 | }($); |
||
1027 | |||
1028 | /** |
||
1029 | * -------------------------------------------------------------------------- |
||
1030 | * Bootstrap (v4.0.0): collapse.js |
||
1031 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
1032 | * -------------------------------------------------------------------------- |
||
1033 | */ |
||
1034 | |||
1035 | var Collapse = function ($$$1) { |
||
1036 | /** |
||
1037 | * ------------------------------------------------------------------------ |
||
1038 | * Constants |
||
1039 | * ------------------------------------------------------------------------ |
||
1040 | */ |
||
1041 | var NAME = 'collapse'; |
||
1042 | var VERSION = '4.0.0'; |
||
1043 | var DATA_KEY = 'bs.collapse'; |
||
1044 | var EVENT_KEY = "." + DATA_KEY; |
||
1045 | var DATA_API_KEY = '.data-api'; |
||
1046 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
1047 | var TRANSITION_DURATION = 600; |
||
1048 | var Default = { |
||
1049 | toggle: true, |
||
1050 | parent: '' |
||
1051 | }; |
||
1052 | var DefaultType = { |
||
1053 | toggle: 'boolean', |
||
1054 | parent: '(string|element)' |
||
1055 | }; |
||
1056 | var Event = { |
||
1057 | SHOW: "show" + EVENT_KEY, |
||
1058 | SHOWN: "shown" + EVENT_KEY, |
||
1059 | HIDE: "hide" + EVENT_KEY, |
||
1060 | HIDDEN: "hidden" + EVENT_KEY, |
||
1061 | CLICK_DATA_API: "click" + EVENT_KEY + DATA_API_KEY |
||
1062 | }; |
||
1063 | var ClassName = { |
||
1064 | SHOW: 'show', |
||
1065 | COLLAPSE: 'collapse', |
||
1066 | COLLAPSING: 'collapsing', |
||
1067 | COLLAPSED: 'collapsed' |
||
1068 | }; |
||
1069 | var Dimension = { |
||
1070 | WIDTH: 'width', |
||
1071 | HEIGHT: 'height' |
||
1072 | }; |
||
1073 | var Selector = { |
||
1074 | ACTIVES: '.show, .collapsing', |
||
1075 | DATA_TOGGLE: '[data-toggle="collapse"]' |
||
1076 | /** |
||
1077 | * ------------------------------------------------------------------------ |
||
1078 | * Class Definition |
||
1079 | * ------------------------------------------------------------------------ |
||
1080 | */ |
||
1081 | |||
1082 | }; |
||
1083 | |||
1084 | var Collapse = |
||
1085 | /*#__PURE__*/ |
||
1086 | function () { |
||
1087 | function Collapse(element, config) { |
||
1088 | this._isTransitioning = false; |
||
1089 | this._element = element; |
||
1090 | this._config = this._getConfig(config); |
||
1091 | this._triggerArray = $$$1.makeArray($$$1("[data-toggle=\"collapse\"][href=\"#" + element.id + "\"]," + ("[data-toggle=\"collapse\"][data-target=\"#" + element.id + "\"]"))); |
||
1092 | var tabToggles = $$$1(Selector.DATA_TOGGLE); |
||
1093 | |||
1094 | for (var i = 0; i < tabToggles.length; i++) { |
||
1095 | var elem = tabToggles[i]; |
||
1096 | var selector = Util.getSelectorFromElement(elem); |
||
1097 | |||
1098 | if (selector !== null && $$$1(selector).filter(element).length > 0) { |
||
1099 | this._selector = selector; |
||
1100 | |||
1101 | this._triggerArray.push(elem); |
||
1102 | } |
||
1103 | } |
||
1104 | |||
1105 | this._parent = this._config.parent ? this._getParent() : null; |
||
1106 | |||
1107 | if (!this._config.parent) { |
||
1108 | this._addAriaAndCollapsedClass(this._element, this._triggerArray); |
||
1109 | } |
||
1110 | |||
1111 | if (this._config.toggle) { |
||
1112 | this.toggle(); |
||
1113 | } |
||
1114 | } // Getters |
||
1115 | |||
1116 | |||
1117 | var _proto = Collapse.prototype; |
||
1118 | |||
1119 | // Public |
||
1120 | _proto.toggle = function toggle() { |
||
1121 | if ($$$1(this._element).hasClass(ClassName.SHOW)) { |
||
1122 | this.hide(); |
||
1123 | } else { |
||
1124 | this.show(); |
||
1125 | } |
||
1126 | }; |
||
1127 | |||
1128 | _proto.show = function show() { |
||
1129 | var _this = this; |
||
1130 | |||
1131 | if (this._isTransitioning || $$$1(this._element).hasClass(ClassName.SHOW)) { |
||
1132 | return; |
||
1133 | } |
||
1134 | |||
1135 | var actives; |
||
1136 | var activesData; |
||
1137 | |||
1138 | if (this._parent) { |
||
1139 | actives = $$$1.makeArray($$$1(this._parent).find(Selector.ACTIVES).filter("[data-parent=\"" + this._config.parent + "\"]")); |
||
1140 | |||
1141 | if (actives.length === 0) { |
||
1142 | actives = null; |
||
1143 | } |
||
1144 | } |
||
1145 | |||
1146 | if (actives) { |
||
1147 | activesData = $$$1(actives).not(this._selector).data(DATA_KEY); |
||
1148 | |||
1149 | if (activesData && activesData._isTransitioning) { |
||
1150 | return; |
||
1151 | } |
||
1152 | } |
||
1153 | |||
1154 | var startEvent = $$$1.Event(Event.SHOW); |
||
1155 | $$$1(this._element).trigger(startEvent); |
||
1156 | |||
1157 | if (startEvent.isDefaultPrevented()) { |
||
1158 | return; |
||
1159 | } |
||
1160 | |||
1161 | if (actives) { |
||
1162 | Collapse._jQueryInterface.call($$$1(actives).not(this._selector), 'hide'); |
||
1163 | |||
1164 | if (!activesData) { |
||
1165 | $$$1(actives).data(DATA_KEY, null); |
||
1166 | } |
||
1167 | } |
||
1168 | |||
1169 | var dimension = this._getDimension(); |
||
1170 | |||
1171 | $$$1(this._element).removeClass(ClassName.COLLAPSE).addClass(ClassName.COLLAPSING); |
||
1172 | this._element.style[dimension] = 0; |
||
1173 | |||
1174 | if (this._triggerArray.length > 0) { |
||
1175 | $$$1(this._triggerArray).removeClass(ClassName.COLLAPSED).attr('aria-expanded', true); |
||
1176 | } |
||
1177 | |||
1178 | this.setTransitioning(true); |
||
1179 | |||
1180 | var complete = function complete() { |
||
1181 | $$$1(_this._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).addClass(ClassName.SHOW); |
||
1182 | _this._element.style[dimension] = ''; |
||
1183 | |||
1184 | _this.setTransitioning(false); |
||
1185 | |||
1186 | $$$1(_this._element).trigger(Event.SHOWN); |
||
1187 | }; |
||
1188 | |||
1189 | if (!Util.supportsTransitionEnd()) { |
||
1190 | complete(); |
||
1191 | return; |
||
1192 | } |
||
1193 | |||
1194 | var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1); |
||
1195 | var scrollSize = "scroll" + capitalizedDimension; |
||
1196 | $$$1(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
||
1197 | this._element.style[dimension] = this._element[scrollSize] + "px"; |
||
1198 | }; |
||
1199 | |||
1200 | _proto.hide = function hide() { |
||
1201 | var _this2 = this; |
||
1202 | |||
1203 | if (this._isTransitioning || !$$$1(this._element).hasClass(ClassName.SHOW)) { |
||
1204 | return; |
||
1205 | } |
||
1206 | |||
1207 | var startEvent = $$$1.Event(Event.HIDE); |
||
1208 | $$$1(this._element).trigger(startEvent); |
||
1209 | |||
1210 | if (startEvent.isDefaultPrevented()) { |
||
1211 | return; |
||
1212 | } |
||
1213 | |||
1214 | var dimension = this._getDimension(); |
||
1215 | |||
1216 | this._element.style[dimension] = this._element.getBoundingClientRect()[dimension] + "px"; |
||
1217 | Util.reflow(this._element); |
||
1218 | $$$1(this._element).addClass(ClassName.COLLAPSING).removeClass(ClassName.COLLAPSE).removeClass(ClassName.SHOW); |
||
1219 | |||
1220 | if (this._triggerArray.length > 0) { |
||
1221 | for (var i = 0; i < this._triggerArray.length; i++) { |
||
1222 | var trigger = this._triggerArray[i]; |
||
1223 | var selector = Util.getSelectorFromElement(trigger); |
||
1224 | |||
1225 | if (selector !== null) { |
||
1226 | var $elem = $$$1(selector); |
||
1227 | |||
1228 | if (!$elem.hasClass(ClassName.SHOW)) { |
||
1229 | $$$1(trigger).addClass(ClassName.COLLAPSED).attr('aria-expanded', false); |
||
1230 | } |
||
1231 | } |
||
1232 | } |
||
1233 | } |
||
1234 | |||
1235 | this.setTransitioning(true); |
||
1236 | |||
1237 | var complete = function complete() { |
||
1238 | _this2.setTransitioning(false); |
||
1239 | |||
1240 | $$$1(_this2._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).trigger(Event.HIDDEN); |
||
1241 | }; |
||
1242 | |||
1243 | this._element.style[dimension] = ''; |
||
1244 | |||
1245 | if (!Util.supportsTransitionEnd()) { |
||
1246 | complete(); |
||
1247 | return; |
||
1248 | } |
||
1249 | |||
1250 | $$$1(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
||
1251 | }; |
||
1252 | |||
1253 | _proto.setTransitioning = function setTransitioning(isTransitioning) { |
||
1254 | this._isTransitioning = isTransitioning; |
||
1255 | }; |
||
1256 | |||
1257 | _proto.dispose = function dispose() { |
||
1258 | $$$1.removeData(this._element, DATA_KEY); |
||
1259 | this._config = null; |
||
1260 | this._parent = null; |
||
1261 | this._element = null; |
||
1262 | this._triggerArray = null; |
||
1263 | this._isTransitioning = null; |
||
1264 | }; // Private |
||
1265 | |||
1266 | |||
1267 | _proto._getConfig = function _getConfig(config) { |
||
1268 | config = _extends({}, Default, config); |
||
1269 | config.toggle = Boolean(config.toggle); // Coerce string values |
||
1270 | |||
1271 | Util.typeCheckConfig(NAME, config, DefaultType); |
||
1272 | return config; |
||
1273 | }; |
||
1274 | |||
1275 | _proto._getDimension = function _getDimension() { |
||
1276 | var hasWidth = $$$1(this._element).hasClass(Dimension.WIDTH); |
||
1277 | return hasWidth ? Dimension.WIDTH : Dimension.HEIGHT; |
||
1278 | }; |
||
1279 | |||
1280 | _proto._getParent = function _getParent() { |
||
1281 | var _this3 = this; |
||
1282 | |||
1283 | var parent = null; |
||
1284 | |||
1285 | if (Util.isElement(this._config.parent)) { |
||
1286 | parent = this._config.parent; // It's a jQuery object |
||
1287 | |||
1288 | if (typeof this._config.parent.jquery !== 'undefined') { |
||
1289 | parent = this._config.parent[0]; |
||
1290 | } |
||
1291 | } else { |
||
1292 | parent = $$$1(this._config.parent)[0]; |
||
1293 | } |
||
1294 | |||
1295 | var selector = "[data-toggle=\"collapse\"][data-parent=\"" + this._config.parent + "\"]"; |
||
1296 | $$$1(parent).find(selector).each(function (i, element) { |
||
1297 | _this3._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]); |
||
1298 | }); |
||
1299 | return parent; |
||
1300 | }; |
||
1301 | |||
1302 | _proto._addAriaAndCollapsedClass = function _addAriaAndCollapsedClass(element, triggerArray) { |
||
1303 | if (element) { |
||
1304 | var isOpen = $$$1(element).hasClass(ClassName.SHOW); |
||
1305 | |||
1306 | if (triggerArray.length > 0) { |
||
1307 | $$$1(triggerArray).toggleClass(ClassName.COLLAPSED, !isOpen).attr('aria-expanded', isOpen); |
||
1308 | } |
||
1309 | } |
||
1310 | }; // Static |
||
1311 | |||
1312 | |||
1313 | Collapse._getTargetFromElement = function _getTargetFromElement(element) { |
||
1314 | var selector = Util.getSelectorFromElement(element); |
||
1315 | return selector ? $$$1(selector)[0] : null; |
||
1316 | }; |
||
1317 | |||
1318 | Collapse._jQueryInterface = function _jQueryInterface(config) { |
||
1319 | return this.each(function () { |
||
1320 | var $this = $$$1(this); |
||
1321 | var data = $this.data(DATA_KEY); |
||
1322 | |||
1323 | var _config = _extends({}, Default, $this.data(), typeof config === 'object' && config); |
||
1324 | |||
1325 | if (!data && _config.toggle && /show|hide/.test(config)) { |
||
1326 | _config.toggle = false; |
||
1327 | } |
||
1328 | |||
1329 | if (!data) { |
||
1330 | data = new Collapse(this, _config); |
||
1331 | $this.data(DATA_KEY, data); |
||
1332 | } |
||
1333 | |||
1334 | if (typeof config === 'string') { |
||
1335 | if (typeof data[config] === 'undefined') { |
||
1336 | throw new TypeError("No method named \"" + config + "\""); |
||
1337 | } |
||
1338 | |||
1339 | data[config](); |
||
1340 | } |
||
1341 | }); |
||
1342 | }; |
||
1343 | |||
1344 | _createClass(Collapse, null, [{ |
||
1345 | key: "VERSION", |
||
1346 | get: function get() { |
||
1347 | return VERSION; |
||
1348 | } |
||
1349 | }, { |
||
1350 | key: "Default", |
||
1351 | get: function get() { |
||
1352 | return Default; |
||
1353 | } |
||
1354 | }]); |
||
1355 | return Collapse; |
||
1356 | }(); |
||
1357 | /** |
||
1358 | * ------------------------------------------------------------------------ |
||
1359 | * Data Api implementation |
||
1360 | * ------------------------------------------------------------------------ |
||
1361 | */ |
||
1362 | |||
1363 | |||
1364 | $$$1(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) { |
||
1365 | // preventDefault only for <a> elements (which change the URL) not inside the collapsible element |
||
1366 | if (event.currentTarget.tagName === 'A') { |
||
1367 | event.preventDefault(); |
||
1368 | } |
||
1369 | |||
1370 | var $trigger = $$$1(this); |
||
1371 | var selector = Util.getSelectorFromElement(this); |
||
1372 | $$$1(selector).each(function () { |
||
1373 | var $target = $$$1(this); |
||
1374 | var data = $target.data(DATA_KEY); |
||
1375 | var config = data ? 'toggle' : $trigger.data(); |
||
1376 | |||
1377 | Collapse._jQueryInterface.call($target, config); |
||
1378 | }); |
||
1379 | }); |
||
1380 | /** |
||
1381 | * ------------------------------------------------------------------------ |
||
1382 | * jQuery |
||
1383 | * ------------------------------------------------------------------------ |
||
1384 | */ |
||
1385 | |||
1386 | $$$1.fn[NAME] = Collapse._jQueryInterface; |
||
1387 | $$$1.fn[NAME].Constructor = Collapse; |
||
1388 | |||
1389 | $$$1.fn[NAME].noConflict = function () { |
||
1390 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
1391 | return Collapse._jQueryInterface; |
||
1392 | }; |
||
1393 | |||
1394 | return Collapse; |
||
1395 | }($); |
||
1396 | |||
1397 | /**! |
||
1398 | * @fileOverview Kickass library to create and place poppers near their reference elements. |
||
1399 | * @version 1.12.9 |
||
1400 | * @license |
||
1401 | * Copyright (c) 2016 Federico Zivolo and contributors |
||
1402 | * |
||
1403 | * Permission is hereby granted, free of charge, to any person obtaining a copy |
||
1404 | * of this software and associated documentation files (the "Software"), to deal |
||
1405 | * in the Software without restriction, including without limitation the rights |
||
1406 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
||
1407 | * copies of the Software, and to permit persons to whom the Software is |
||
1408 | * furnished to do so, subject to the following conditions: |
||
1409 | * |
||
1410 | * The above copyright notice and this permission notice shall be included in all |
||
1411 | * copies or substantial portions of the Software. |
||
1412 | * |
||
1413 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
||
1414 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
||
1415 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
||
1416 | * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
||
1417 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
||
1418 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
||
1419 | * SOFTWARE. |
||
1420 | */ |
||
1421 | var isBrowser = typeof window !== 'undefined' && typeof document !== 'undefined'; |
||
1422 | var longerTimeoutBrowsers = ['Edge', 'Trident', 'Firefox']; |
||
1423 | var timeoutDuration = 0; |
||
1424 | for (var i = 0; i < longerTimeoutBrowsers.length; i += 1) { |
||
1425 | if (isBrowser && navigator.userAgent.indexOf(longerTimeoutBrowsers[i]) >= 0) { |
||
1426 | timeoutDuration = 1; |
||
1427 | break; |
||
1428 | } |
||
1429 | } |
||
1430 | |||
1431 | function microtaskDebounce(fn) { |
||
1432 | var called = false; |
||
1433 | return function () { |
||
1434 | if (called) { |
||
1435 | return; |
||
1436 | } |
||
1437 | called = true; |
||
1438 | window.Promise.resolve().then(function () { |
||
1439 | called = false; |
||
1440 | fn(); |
||
1441 | }); |
||
1442 | }; |
||
1443 | } |
||
1444 | |||
1445 | function taskDebounce(fn) { |
||
1446 | var scheduled = false; |
||
1447 | return function () { |
||
1448 | if (!scheduled) { |
||
1449 | scheduled = true; |
||
1450 | setTimeout(function () { |
||
1451 | scheduled = false; |
||
1452 | fn(); |
||
1453 | }, timeoutDuration); |
||
1454 | } |
||
1455 | }; |
||
1456 | } |
||
1457 | |||
1458 | var supportsMicroTasks = isBrowser && window.Promise; |
||
1459 | |||
1460 | /** |
||
1461 | * Create a debounced version of a method, that's asynchronously deferred |
||
1462 | * but called in the minimum time possible. |
||
1463 | * |
||
1464 | * @method |
||
1465 | * @memberof Popper.Utils |
||
1466 | * @argument {Function} fn |
||
1467 | * @returns {Function} |
||
1468 | */ |
||
1469 | var debounce = supportsMicroTasks ? microtaskDebounce : taskDebounce; |
||
1470 | |||
1471 | /** |
||
1472 | * Check if the given variable is a function |
||
1473 | * @method |
||
1474 | * @memberof Popper.Utils |
||
1475 | * @argument {Any} functionToCheck - variable to check |
||
1476 | * @returns {Boolean} answer to: is a function? |
||
1477 | */ |
||
1478 | function isFunction(functionToCheck) { |
||
1479 | var getType = {}; |
||
1480 | return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]'; |
||
1481 | } |
||
1482 | |||
1483 | /** |
||
1484 | * Get CSS computed property of the given element |
||
1485 | * @method |
||
1486 | * @memberof Popper.Utils |
||
1487 | * @argument {Eement} element |
||
1488 | * @argument {String} property |
||
1489 | */ |
||
1490 | function getStyleComputedProperty(element, property) { |
||
1491 | if (element.nodeType !== 1) { |
||
1492 | return []; |
||
1493 | } |
||
1494 | // NOTE: 1 DOM access here |
||
1495 | var css = getComputedStyle(element, null); |
||
1496 | return property ? css[property] : css; |
||
1497 | } |
||
1498 | |||
1499 | /** |
||
1500 | * Returns the parentNode or the host of the element |
||
1501 | * @method |
||
1502 | * @memberof Popper.Utils |
||
1503 | * @argument {Element} element |
||
1504 | * @returns {Element} parent |
||
1505 | */ |
||
1506 | function getParentNode(element) { |
||
1507 | if (element.nodeName === 'HTML') { |
||
1508 | return element; |
||
1509 | } |
||
1510 | return element.parentNode || element.host; |
||
1511 | } |
||
1512 | |||
1513 | /** |
||
1514 | * Returns the scrolling parent of the given element |
||
1515 | * @method |
||
1516 | * @memberof Popper.Utils |
||
1517 | * @argument {Element} element |
||
1518 | * @returns {Element} scroll parent |
||
1519 | */ |
||
1520 | function getScrollParent(element) { |
||
1521 | // Return body, `getScroll` will take care to get the correct `scrollTop` from it |
||
1522 | if (!element) { |
||
1523 | return document.body; |
||
1524 | } |
||
1525 | |||
1526 | switch (element.nodeName) { |
||
1527 | case 'HTML': |
||
1528 | case 'BODY': |
||
1529 | return element.ownerDocument.body; |
||
1530 | case '#document': |
||
1531 | return element.body; |
||
1532 | } |
||
1533 | |||
1534 | // Firefox want us to check `-x` and `-y` variations as well |
||
1535 | |||
1536 | var _getStyleComputedProp = getStyleComputedProperty(element), |
||
1537 | overflow = _getStyleComputedProp.overflow, |
||
1538 | overflowX = _getStyleComputedProp.overflowX, |
||
1539 | overflowY = _getStyleComputedProp.overflowY; |
||
1540 | |||
1541 | if (/(auto|scroll)/.test(overflow + overflowY + overflowX)) { |
||
1542 | return element; |
||
1543 | } |
||
1544 | |||
1545 | return getScrollParent(getParentNode(element)); |
||
1546 | } |
||
1547 | |||
1548 | /** |
||
1549 | * Returns the offset parent of the given element |
||
1550 | * @method |
||
1551 | * @memberof Popper.Utils |
||
1552 | * @argument {Element} element |
||
1553 | * @returns {Element} offset parent |
||
1554 | */ |
||
1555 | function getOffsetParent(element) { |
||
1556 | // NOTE: 1 DOM access here |
||
1557 | var offsetParent = element && element.offsetParent; |
||
1558 | var nodeName = offsetParent && offsetParent.nodeName; |
||
1559 | |||
1560 | if (!nodeName || nodeName === 'BODY' || nodeName === 'HTML') { |
||
1561 | if (element) { |
||
1562 | return element.ownerDocument.documentElement; |
||
1563 | } |
||
1564 | |||
1565 | return document.documentElement; |
||
1566 | } |
||
1567 | |||
1568 | // .offsetParent will return the closest TD or TABLE in case |
||
1569 | // no offsetParent is present, I hate this job... |
||
1570 | if (['TD', 'TABLE'].indexOf(offsetParent.nodeName) !== -1 && getStyleComputedProperty(offsetParent, 'position') === 'static') { |
||
1571 | return getOffsetParent(offsetParent); |
||
1572 | } |
||
1573 | |||
1574 | return offsetParent; |
||
1575 | } |
||
1576 | |||
1577 | function isOffsetContainer(element) { |
||
1578 | var nodeName = element.nodeName; |
||
1579 | |||
1580 | if (nodeName === 'BODY') { |
||
1581 | return false; |
||
1582 | } |
||
1583 | return nodeName === 'HTML' || getOffsetParent(element.firstElementChild) === element; |
||
1584 | } |
||
1585 | |||
1586 | /** |
||
1587 | * Finds the root node (document, shadowDOM root) of the given element |
||
1588 | * @method |
||
1589 | * @memberof Popper.Utils |
||
1590 | * @argument {Element} node |
||
1591 | * @returns {Element} root node |
||
1592 | */ |
||
1593 | function getRoot(node) { |
||
1594 | if (node.parentNode !== null) { |
||
1595 | return getRoot(node.parentNode); |
||
1596 | } |
||
1597 | |||
1598 | return node; |
||
1599 | } |
||
1600 | |||
1601 | /** |
||
1602 | * Finds the offset parent common to the two provided nodes |
||
1603 | * @method |
||
1604 | * @memberof Popper.Utils |
||
1605 | * @argument {Element} element1 |
||
1606 | * @argument {Element} element2 |
||
1607 | * @returns {Element} common offset parent |
||
1608 | */ |
||
1609 | function findCommonOffsetParent(element1, element2) { |
||
1610 | // This check is needed to avoid errors in case one of the elements isn't defined for any reason |
||
1611 | if (!element1 || !element1.nodeType || !element2 || !element2.nodeType) { |
||
1612 | return document.documentElement; |
||
1613 | } |
||
1614 | |||
1615 | // Here we make sure to give as "start" the element that comes first in the DOM |
||
1616 | var order = element1.compareDocumentPosition(element2) & Node.DOCUMENT_POSITION_FOLLOWING; |
||
1617 | var start = order ? element1 : element2; |
||
1618 | var end = order ? element2 : element1; |
||
1619 | |||
1620 | // Get common ancestor container |
||
1621 | var range = document.createRange(); |
||
1622 | range.setStart(start, 0); |
||
1623 | range.setEnd(end, 0); |
||
1624 | var commonAncestorContainer = range.commonAncestorContainer; |
||
1625 | |||
1626 | // Both nodes are inside #document |
||
1627 | |||
1628 | if (element1 !== commonAncestorContainer && element2 !== commonAncestorContainer || start.contains(end)) { |
||
1629 | if (isOffsetContainer(commonAncestorContainer)) { |
||
1630 | return commonAncestorContainer; |
||
1631 | } |
||
1632 | |||
1633 | return getOffsetParent(commonAncestorContainer); |
||
1634 | } |
||
1635 | |||
1636 | // one of the nodes is inside shadowDOM, find which one |
||
1637 | var element1root = getRoot(element1); |
||
1638 | if (element1root.host) { |
||
1639 | return findCommonOffsetParent(element1root.host, element2); |
||
1640 | } else { |
||
1641 | return findCommonOffsetParent(element1, getRoot(element2).host); |
||
1642 | } |
||
1643 | } |
||
1644 | |||
1645 | /** |
||
1646 | * Gets the scroll value of the given element in the given side (top and left) |
||
1647 | * @method |
||
1648 | * @memberof Popper.Utils |
||
1649 | * @argument {Element} element |
||
1650 | * @argument {String} side `top` or `left` |
||
1651 | * @returns {number} amount of scrolled pixels |
||
1652 | */ |
||
1653 | function getScroll(element) { |
||
1654 | var side = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'top'; |
||
1655 | |||
1656 | var upperSide = side === 'top' ? 'scrollTop' : 'scrollLeft'; |
||
1657 | var nodeName = element.nodeName; |
||
1658 | |||
1659 | if (nodeName === 'BODY' || nodeName === 'HTML') { |
||
1660 | var html = element.ownerDocument.documentElement; |
||
1661 | var scrollingElement = element.ownerDocument.scrollingElement || html; |
||
1662 | return scrollingElement[upperSide]; |
||
1663 | } |
||
1664 | |||
1665 | return element[upperSide]; |
||
1666 | } |
||
1667 | |||
1668 | /* |
||
1669 | * Sum or subtract the element scroll values (left and top) from a given rect object |
||
1670 | * @method |
||
1671 | * @memberof Popper.Utils |
||
1672 | * @param {Object} rect - Rect object you want to change |
||
1673 | * @param {HTMLElement} element - The element from the function reads the scroll values |
||
1674 | * @param {Boolean} subtract - set to true if you want to subtract the scroll values |
||
1675 | * @return {Object} rect - The modifier rect object |
||
1676 | */ |
||
1677 | function includeScroll(rect, element) { |
||
1678 | var subtract = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; |
||
1679 | |||
1680 | var scrollTop = getScroll(element, 'top'); |
||
1681 | var scrollLeft = getScroll(element, 'left'); |
||
1682 | var modifier = subtract ? -1 : 1; |
||
1683 | rect.top += scrollTop * modifier; |
||
1684 | rect.bottom += scrollTop * modifier; |
||
1685 | rect.left += scrollLeft * modifier; |
||
1686 | rect.right += scrollLeft * modifier; |
||
1687 | return rect; |
||
1688 | } |
||
1689 | |||
1690 | /* |
||
1691 | * Helper to detect borders of a given element |
||
1692 | * @method |
||
1693 | * @memberof Popper.Utils |
||
1694 | * @param {CSSStyleDeclaration} styles |
||
1695 | * Result of `getStyleComputedProperty` on the given element |
||
1696 | * @param {String} axis - `x` or `y` |
||
1697 | * @return {number} borders - The borders size of the given axis |
||
1698 | */ |
||
1699 | |||
1700 | function getBordersSize(styles, axis) { |
||
1701 | var sideA = axis === 'x' ? 'Left' : 'Top'; |
||
1702 | var sideB = sideA === 'Left' ? 'Right' : 'Bottom'; |
||
1703 | |||
1704 | return parseFloat(styles['border' + sideA + 'Width'], 10) + parseFloat(styles['border' + sideB + 'Width'], 10); |
||
1705 | } |
||
1706 | |||
1707 | /** |
||
1708 | * Tells if you are running Internet Explorer 10 |
||
1709 | * @method |
||
1710 | * @memberof Popper.Utils |
||
1711 | * @returns {Boolean} isIE10 |
||
1712 | */ |
||
1713 | var isIE10 = undefined; |
||
1714 | |||
1715 | var isIE10$1 = function () { |
||
1716 | if (isIE10 === undefined) { |
||
1717 | isIE10 = navigator.appVersion.indexOf('MSIE 10') !== -1; |
||
1718 | } |
||
1719 | return isIE10; |
||
1720 | }; |
||
1721 | |||
1722 | function getSize(axis, body, html, computedStyle) { |
||
1723 | return Math.max(body['offset' + axis], body['scroll' + axis], html['client' + axis], html['offset' + axis], html['scroll' + axis], isIE10$1() ? html['offset' + axis] + computedStyle['margin' + (axis === 'Height' ? 'Top' : 'Left')] + computedStyle['margin' + (axis === 'Height' ? 'Bottom' : 'Right')] : 0); |
||
1724 | } |
||
1725 | |||
1726 | function getWindowSizes() { |
||
1727 | var body = document.body; |
||
1728 | var html = document.documentElement; |
||
1729 | var computedStyle = isIE10$1() && getComputedStyle(html); |
||
1730 | |||
1731 | return { |
||
1732 | height: getSize('Height', body, html, computedStyle), |
||
1733 | width: getSize('Width', body, html, computedStyle) |
||
1734 | }; |
||
1735 | } |
||
1736 | |||
1737 | var classCallCheck = function (instance, Constructor) { |
||
1738 | if (!(instance instanceof Constructor)) { |
||
1739 | throw new TypeError("Cannot call a class as a function"); |
||
1740 | } |
||
1741 | }; |
||
1742 | |||
1743 | var createClass = function () { |
||
1744 | function defineProperties(target, props) { |
||
1745 | for (var i = 0; i < props.length; i++) { |
||
1746 | var descriptor = props[i]; |
||
1747 | descriptor.enumerable = descriptor.enumerable || false; |
||
1748 | descriptor.configurable = true; |
||
1749 | if ("value" in descriptor) descriptor.writable = true; |
||
1750 | Object.defineProperty(target, descriptor.key, descriptor); |
||
1751 | } |
||
1752 | } |
||
1753 | |||
1754 | return function (Constructor, protoProps, staticProps) { |
||
1755 | if (protoProps) defineProperties(Constructor.prototype, protoProps); |
||
1756 | if (staticProps) defineProperties(Constructor, staticProps); |
||
1757 | return Constructor; |
||
1758 | }; |
||
1759 | }(); |
||
1760 | |||
1761 | |||
1762 | |||
1763 | |||
1764 | |||
1765 | var defineProperty = function (obj, key, value) { |
||
1766 | if (key in obj) { |
||
1767 | Object.defineProperty(obj, key, { |
||
1768 | value: value, |
||
1769 | enumerable: true, |
||
1770 | configurable: true, |
||
1771 | writable: true |
||
1772 | }); |
||
1773 | } else { |
||
1774 | obj[key] = value; |
||
1775 | } |
||
1776 | |||
1777 | return obj; |
||
1778 | }; |
||
1779 | |||
1780 | var _extends$1 = Object.assign || function (target) { |
||
1781 | for (var i = 1; i < arguments.length; i++) { |
||
1782 | var source = arguments[i]; |
||
1783 | |||
1784 | for (var key in source) { |
||
1785 | if (Object.prototype.hasOwnProperty.call(source, key)) { |
||
1786 | target[key] = source[key]; |
||
1787 | } |
||
1788 | } |
||
1789 | } |
||
1790 | |||
1791 | return target; |
||
1792 | }; |
||
1793 | |||
1794 | /** |
||
1795 | * Given element offsets, generate an output similar to getBoundingClientRect |
||
1796 | * @method |
||
1797 | * @memberof Popper.Utils |
||
1798 | * @argument {Object} offsets |
||
1799 | * @returns {Object} ClientRect like output |
||
1800 | */ |
||
1801 | function getClientRect(offsets) { |
||
1802 | return _extends$1({}, offsets, { |
||
1803 | right: offsets.left + offsets.width, |
||
1804 | bottom: offsets.top + offsets.height |
||
1805 | }); |
||
1806 | } |
||
1807 | |||
1808 | /** |
||
1809 | * Get bounding client rect of given element |
||
1810 | * @method |
||
1811 | * @memberof Popper.Utils |
||
1812 | * @param {HTMLElement} element |
||
1813 | * @return {Object} client rect |
||
1814 | */ |
||
1815 | function getBoundingClientRect(element) { |
||
1816 | var rect = {}; |
||
1817 | |||
1818 | // IE10 10 FIX: Please, don't ask, the element isn't |
||
1819 | // considered in DOM in some circumstances... |
||
1820 | // This isn't reproducible in IE10 compatibility mode of IE11 |
||
1821 | if (isIE10$1()) { |
||
1822 | try { |
||
1823 | rect = element.getBoundingClientRect(); |
||
1824 | var scrollTop = getScroll(element, 'top'); |
||
1825 | var scrollLeft = getScroll(element, 'left'); |
||
1826 | rect.top += scrollTop; |
||
1827 | rect.left += scrollLeft; |
||
1828 | rect.bottom += scrollTop; |
||
1829 | rect.right += scrollLeft; |
||
1830 | } catch (err) {} |
||
1831 | } else { |
||
1832 | rect = element.getBoundingClientRect(); |
||
1833 | } |
||
1834 | |||
1835 | var result = { |
||
1836 | left: rect.left, |
||
1837 | top: rect.top, |
||
1838 | width: rect.right - rect.left, |
||
1839 | height: rect.bottom - rect.top |
||
1840 | }; |
||
1841 | |||
1842 | // subtract scrollbar size from sizes |
||
1843 | var sizes = element.nodeName === 'HTML' ? getWindowSizes() : {}; |
||
1844 | var width = sizes.width || element.clientWidth || result.right - result.left; |
||
1845 | var height = sizes.height || element.clientHeight || result.bottom - result.top; |
||
1846 | |||
1847 | var horizScrollbar = element.offsetWidth - width; |
||
1848 | var vertScrollbar = element.offsetHeight - height; |
||
1849 | |||
1850 | // if an hypothetical scrollbar is detected, we must be sure it's not a `border` |
||
1851 | // we make this check conditional for performance reasons |
||
1852 | if (horizScrollbar || vertScrollbar) { |
||
1853 | var styles = getStyleComputedProperty(element); |
||
1854 | horizScrollbar -= getBordersSize(styles, 'x'); |
||
1855 | vertScrollbar -= getBordersSize(styles, 'y'); |
||
1856 | |||
1857 | result.width -= horizScrollbar; |
||
1858 | result.height -= vertScrollbar; |
||
1859 | } |
||
1860 | |||
1861 | return getClientRect(result); |
||
1862 | } |
||
1863 | |||
1864 | function getOffsetRectRelativeToArbitraryNode(children, parent) { |
||
1865 | var isIE10 = isIE10$1(); |
||
1866 | var isHTML = parent.nodeName === 'HTML'; |
||
1867 | var childrenRect = getBoundingClientRect(children); |
||
1868 | var parentRect = getBoundingClientRect(parent); |
||
1869 | var scrollParent = getScrollParent(children); |
||
1870 | |||
1871 | var styles = getStyleComputedProperty(parent); |
||
1872 | var borderTopWidth = parseFloat(styles.borderTopWidth, 10); |
||
1873 | var borderLeftWidth = parseFloat(styles.borderLeftWidth, 10); |
||
1874 | |||
1875 | var offsets = getClientRect({ |
||
1876 | top: childrenRect.top - parentRect.top - borderTopWidth, |
||
1877 | left: childrenRect.left - parentRect.left - borderLeftWidth, |
||
1878 | width: childrenRect.width, |
||
1879 | height: childrenRect.height |
||
1880 | }); |
||
1881 | offsets.marginTop = 0; |
||
1882 | offsets.marginLeft = 0; |
||
1883 | |||
1884 | // Subtract margins of documentElement in case it's being used as parent |
||
1885 | // we do this only on HTML because it's the only element that behaves |
||
1886 | // differently when margins are applied to it. The margins are included in |
||
1887 | // the box of the documentElement, in the other cases not. |
||
1888 | if (!isIE10 && isHTML) { |
||
1889 | var marginTop = parseFloat(styles.marginTop, 10); |
||
1890 | var marginLeft = parseFloat(styles.marginLeft, 10); |
||
1891 | |||
1892 | offsets.top -= borderTopWidth - marginTop; |
||
1893 | offsets.bottom -= borderTopWidth - marginTop; |
||
1894 | offsets.left -= borderLeftWidth - marginLeft; |
||
1895 | offsets.right -= borderLeftWidth - marginLeft; |
||
1896 | |||
1897 | // Attach marginTop and marginLeft because in some circumstances we may need them |
||
1898 | offsets.marginTop = marginTop; |
||
1899 | offsets.marginLeft = marginLeft; |
||
1900 | } |
||
1901 | |||
1902 | if (isIE10 ? parent.contains(scrollParent) : parent === scrollParent && scrollParent.nodeName !== 'BODY') { |
||
1903 | offsets = includeScroll(offsets, parent); |
||
1904 | } |
||
1905 | |||
1906 | return offsets; |
||
1907 | } |
||
1908 | |||
1909 | function getViewportOffsetRectRelativeToArtbitraryNode(element) { |
||
1910 | var html = element.ownerDocument.documentElement; |
||
1911 | var relativeOffset = getOffsetRectRelativeToArbitraryNode(element, html); |
||
1912 | var width = Math.max(html.clientWidth, window.innerWidth || 0); |
||
1913 | var height = Math.max(html.clientHeight, window.innerHeight || 0); |
||
1914 | |||
1915 | var scrollTop = getScroll(html); |
||
1916 | var scrollLeft = getScroll(html, 'left'); |
||
1917 | |||
1918 | var offset = { |
||
1919 | top: scrollTop - relativeOffset.top + relativeOffset.marginTop, |
||
1920 | left: scrollLeft - relativeOffset.left + relativeOffset.marginLeft, |
||
1921 | width: width, |
||
1922 | height: height |
||
1923 | }; |
||
1924 | |||
1925 | return getClientRect(offset); |
||
1926 | } |
||
1927 | |||
1928 | /** |
||
1929 | * Check if the given element is fixed or is inside a fixed parent |
||
1930 | * @method |
||
1931 | * @memberof Popper.Utils |
||
1932 | * @argument {Element} element |
||
1933 | * @argument {Element} customContainer |
||
1934 | * @returns {Boolean} answer to "isFixed?" |
||
1935 | */ |
||
1936 | function isFixed(element) { |
||
1937 | var nodeName = element.nodeName; |
||
1938 | if (nodeName === 'BODY' || nodeName === 'HTML') { |
||
1939 | return false; |
||
1940 | } |
||
1941 | if (getStyleComputedProperty(element, 'position') === 'fixed') { |
||
1942 | return true; |
||
1943 | } |
||
1944 | return isFixed(getParentNode(element)); |
||
1945 | } |
||
1946 | |||
1947 | /** |
||
1948 | * Computed the boundaries limits and return them |
||
1949 | * @method |
||
1950 | * @memberof Popper.Utils |
||
1951 | * @param {HTMLElement} popper |
||
1952 | * @param {HTMLElement} reference |
||
1953 | * @param {number} padding |
||
1954 | * @param {HTMLElement} boundariesElement - Element used to define the boundaries |
||
1955 | * @returns {Object} Coordinates of the boundaries |
||
1956 | */ |
||
1957 | function getBoundaries(popper, reference, padding, boundariesElement) { |
||
1958 | // NOTE: 1 DOM access here |
||
1959 | var boundaries = { top: 0, left: 0 }; |
||
1960 | var offsetParent = findCommonOffsetParent(popper, reference); |
||
1961 | |||
1962 | // Handle viewport case |
||
1963 | if (boundariesElement === 'viewport') { |
||
1964 | boundaries = getViewportOffsetRectRelativeToArtbitraryNode(offsetParent); |
||
1965 | } else { |
||
1966 | // Handle other cases based on DOM element used as boundaries |
||
1967 | var boundariesNode = void 0; |
||
1968 | if (boundariesElement === 'scrollParent') { |
||
1969 | boundariesNode = getScrollParent(getParentNode(reference)); |
||
1970 | if (boundariesNode.nodeName === 'BODY') { |
||
1971 | boundariesNode = popper.ownerDocument.documentElement; |
||
1972 | } |
||
1973 | } else if (boundariesElement === 'window') { |
||
1974 | boundariesNode = popper.ownerDocument.documentElement; |
||
1975 | } else { |
||
1976 | boundariesNode = boundariesElement; |
||
1977 | } |
||
1978 | |||
1979 | var offsets = getOffsetRectRelativeToArbitraryNode(boundariesNode, offsetParent); |
||
1980 | |||
1981 | // In case of HTML, we need a different computation |
||
1982 | if (boundariesNode.nodeName === 'HTML' && !isFixed(offsetParent)) { |
||
1983 | var _getWindowSizes = getWindowSizes(), |
||
1984 | height = _getWindowSizes.height, |
||
1985 | width = _getWindowSizes.width; |
||
1986 | |||
1987 | boundaries.top += offsets.top - offsets.marginTop; |
||
1988 | boundaries.bottom = height + offsets.top; |
||
1989 | boundaries.left += offsets.left - offsets.marginLeft; |
||
1990 | boundaries.right = width + offsets.left; |
||
1991 | } else { |
||
1992 | // for all the other DOM elements, this one is good |
||
1993 | boundaries = offsets; |
||
1994 | } |
||
1995 | } |
||
1996 | |||
1997 | // Add paddings |
||
1998 | boundaries.left += padding; |
||
1999 | boundaries.top += padding; |
||
2000 | boundaries.right -= padding; |
||
2001 | boundaries.bottom -= padding; |
||
2002 | |||
2003 | return boundaries; |
||
2004 | } |
||
2005 | |||
2006 | function getArea(_ref) { |
||
2007 | var width = _ref.width, |
||
2008 | height = _ref.height; |
||
2009 | |||
2010 | return width * height; |
||
2011 | } |
||
2012 | |||
2013 | /** |
||
2014 | * Utility used to transform the `auto` placement to the placement with more |
||
2015 | * available space. |
||
2016 | * @method |
||
2017 | * @memberof Popper.Utils |
||
2018 | * @argument {Object} data - The data object generated by update method |
||
2019 | * @argument {Object} options - Modifiers configuration and options |
||
2020 | * @returns {Object} The data object, properly modified |
||
2021 | */ |
||
2022 | function computeAutoPlacement(placement, refRect, popper, reference, boundariesElement) { |
||
2023 | var padding = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 0; |
||
2024 | |||
2025 | if (placement.indexOf('auto') === -1) { |
||
2026 | return placement; |
||
2027 | } |
||
2028 | |||
2029 | var boundaries = getBoundaries(popper, reference, padding, boundariesElement); |
||
2030 | |||
2031 | var rects = { |
||
2032 | top: { |
||
2033 | width: boundaries.width, |
||
2034 | height: refRect.top - boundaries.top |
||
2035 | }, |
||
2036 | right: { |
||
2037 | width: boundaries.right - refRect.right, |
||
2038 | height: boundaries.height |
||
2039 | }, |
||
2040 | bottom: { |
||
2041 | width: boundaries.width, |
||
2042 | height: boundaries.bottom - refRect.bottom |
||
2043 | }, |
||
2044 | left: { |
||
2045 | width: refRect.left - boundaries.left, |
||
2046 | height: boundaries.height |
||
2047 | } |
||
2048 | }; |
||
2049 | |||
2050 | var sortedAreas = Object.keys(rects).map(function (key) { |
||
2051 | return _extends$1({ |
||
2052 | key: key |
||
2053 | }, rects[key], { |
||
2054 | area: getArea(rects[key]) |
||
2055 | }); |
||
2056 | }).sort(function (a, b) { |
||
2057 | return b.area - a.area; |
||
2058 | }); |
||
2059 | |||
2060 | var filteredAreas = sortedAreas.filter(function (_ref2) { |
||
2061 | var width = _ref2.width, |
||
2062 | height = _ref2.height; |
||
2063 | return width >= popper.clientWidth && height >= popper.clientHeight; |
||
2064 | }); |
||
2065 | |||
2066 | var computedPlacement = filteredAreas.length > 0 ? filteredAreas[0].key : sortedAreas[0].key; |
||
2067 | |||
2068 | var variation = placement.split('-')[1]; |
||
2069 | |||
2070 | return computedPlacement + (variation ? '-' + variation : ''); |
||
2071 | } |
||
2072 | |||
2073 | /** |
||
2074 | * Get offsets to the reference element |
||
2075 | * @method |
||
2076 | * @memberof Popper.Utils |
||
2077 | * @param {Object} state |
||
2078 | * @param {Element} popper - the popper element |
||
2079 | * @param {Element} reference - the reference element (the popper will be relative to this) |
||
2080 | * @returns {Object} An object containing the offsets which will be applied to the popper |
||
2081 | */ |
||
2082 | function getReferenceOffsets(state, popper, reference) { |
||
2083 | var commonOffsetParent = findCommonOffsetParent(popper, reference); |
||
2084 | return getOffsetRectRelativeToArbitraryNode(reference, commonOffsetParent); |
||
2085 | } |
||
2086 | |||
2087 | /** |
||
2088 | * Get the outer sizes of the given element (offset size + margins) |
||
2089 | * @method |
||
2090 | * @memberof Popper.Utils |
||
2091 | * @argument {Element} element |
||
2092 | * @returns {Object} object containing width and height properties |
||
2093 | */ |
||
2094 | function getOuterSizes(element) { |
||
2095 | var styles = getComputedStyle(element); |
||
2096 | var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom); |
||
2097 | var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight); |
||
2098 | var result = { |
||
2099 | width: element.offsetWidth + y, |
||
2100 | height: element.offsetHeight + x |
||
2101 | }; |
||
2102 | return result; |
||
2103 | } |
||
2104 | |||
2105 | /** |
||
2106 | * Get the opposite placement of the given one |
||
2107 | * @method |
||
2108 | * @memberof Popper.Utils |
||
2109 | * @argument {String} placement |
||
2110 | * @returns {String} flipped placement |
||
2111 | */ |
||
2112 | function getOppositePlacement(placement) { |
||
2113 | var hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' }; |
||
2114 | return placement.replace(/left|right|bottom|top/g, function (matched) { |
||
2115 | return hash[matched]; |
||
2116 | }); |
||
2117 | } |
||
2118 | |||
2119 | /** |
||
2120 | * Get offsets to the popper |
||
2121 | * @method |
||
2122 | * @memberof Popper.Utils |
||
2123 | * @param {Object} position - CSS position the Popper will get applied |
||
2124 | * @param {HTMLElement} popper - the popper element |
||
2125 | * @param {Object} referenceOffsets - the reference offsets (the popper will be relative to this) |
||
2126 | * @param {String} placement - one of the valid placement options |
||
2127 | * @returns {Object} popperOffsets - An object containing the offsets which will be applied to the popper |
||
2128 | */ |
||
2129 | function getPopperOffsets(popper, referenceOffsets, placement) { |
||
2130 | placement = placement.split('-')[0]; |
||
2131 | |||
2132 | // Get popper node sizes |
||
2133 | var popperRect = getOuterSizes(popper); |
||
2134 | |||
2135 | // Add position, width and height to our offsets object |
||
2136 | var popperOffsets = { |
||
2137 | width: popperRect.width, |
||
2138 | height: popperRect.height |
||
2139 | }; |
||
2140 | |||
2141 | // depending by the popper placement we have to compute its offsets slightly differently |
||
2142 | var isHoriz = ['right', 'left'].indexOf(placement) !== -1; |
||
2143 | var mainSide = isHoriz ? 'top' : 'left'; |
||
2144 | var secondarySide = isHoriz ? 'left' : 'top'; |
||
2145 | var measurement = isHoriz ? 'height' : 'width'; |
||
2146 | var secondaryMeasurement = !isHoriz ? 'height' : 'width'; |
||
2147 | |||
2148 | popperOffsets[mainSide] = referenceOffsets[mainSide] + referenceOffsets[measurement] / 2 - popperRect[measurement] / 2; |
||
2149 | if (placement === secondarySide) { |
||
2150 | popperOffsets[secondarySide] = referenceOffsets[secondarySide] - popperRect[secondaryMeasurement]; |
||
2151 | } else { |
||
2152 | popperOffsets[secondarySide] = referenceOffsets[getOppositePlacement(secondarySide)]; |
||
2153 | } |
||
2154 | |||
2155 | return popperOffsets; |
||
2156 | } |
||
2157 | |||
2158 | /** |
||
2159 | * Mimics the `find` method of Array |
||
2160 | * @method |
||
2161 | * @memberof Popper.Utils |
||
2162 | * @argument {Array} arr |
||
2163 | * @argument prop |
||
2164 | * @argument value |
||
2165 | * @returns index or -1 |
||
2166 | */ |
||
2167 | function find(arr, check) { |
||
2168 | // use native find if supported |
||
2169 | if (Array.prototype.find) { |
||
2170 | return arr.find(check); |
||
2171 | } |
||
2172 | |||
2173 | // use `filter` to obtain the same behavior of `find` |
||
2174 | return arr.filter(check)[0]; |
||
2175 | } |
||
2176 | |||
2177 | /** |
||
2178 | * Return the index of the matching object |
||
2179 | * @method |
||
2180 | * @memberof Popper.Utils |
||
2181 | * @argument {Array} arr |
||
2182 | * @argument prop |
||
2183 | * @argument value |
||
2184 | * @returns index or -1 |
||
2185 | */ |
||
2186 | function findIndex(arr, prop, value) { |
||
2187 | // use native findIndex if supported |
||
2188 | if (Array.prototype.findIndex) { |
||
2189 | return arr.findIndex(function (cur) { |
||
2190 | return cur[prop] === value; |
||
2191 | }); |
||
2192 | } |
||
2193 | |||
2194 | // use `find` + `indexOf` if `findIndex` isn't supported |
||
2195 | var match = find(arr, function (obj) { |
||
2196 | return obj[prop] === value; |
||
2197 | }); |
||
2198 | return arr.indexOf(match); |
||
2199 | } |
||
2200 | |||
2201 | /** |
||
2202 | * Loop trough the list of modifiers and run them in order, |
||
2203 | * each of them will then edit the data object. |
||
2204 | * @method |
||
2205 | * @memberof Popper.Utils |
||
2206 | * @param {dataObject} data |
||
2207 | * @param {Array} modifiers |
||
2208 | * @param {String} ends - Optional modifier name used as stopper |
||
2209 | * @returns {dataObject} |
||
2210 | */ |
||
2211 | function runModifiers(modifiers, data, ends) { |
||
2212 | var modifiersToRun = ends === undefined ? modifiers : modifiers.slice(0, findIndex(modifiers, 'name', ends)); |
||
2213 | |||
2214 | modifiersToRun.forEach(function (modifier) { |
||
2215 | if (modifier['function']) { |
||
2216 | // eslint-disable-line dot-notation |
||
2217 | console.warn('`modifier.function` is deprecated, use `modifier.fn`!'); |
||
2218 | } |
||
2219 | var fn = modifier['function'] || modifier.fn; // eslint-disable-line dot-notation |
||
2220 | if (modifier.enabled && isFunction(fn)) { |
||
2221 | // Add properties to offsets to make them a complete clientRect object |
||
2222 | // we do this before each modifier to make sure the previous one doesn't |
||
2223 | // mess with these values |
||
2224 | data.offsets.popper = getClientRect(data.offsets.popper); |
||
2225 | data.offsets.reference = getClientRect(data.offsets.reference); |
||
2226 | |||
2227 | data = fn(data, modifier); |
||
2228 | } |
||
2229 | }); |
||
2230 | |||
2231 | return data; |
||
2232 | } |
||
2233 | |||
2234 | /** |
||
2235 | * Updates the position of the popper, computing the new offsets and applying |
||
2236 | * the new style.<br /> |
||
2237 | * Prefer `scheduleUpdate` over `update` because of performance reasons. |
||
2238 | * @method |
||
2239 | * @memberof Popper |
||
2240 | */ |
||
2241 | function update() { |
||
2242 | // if popper is destroyed, don't perform any further update |
||
2243 | if (this.state.isDestroyed) { |
||
2244 | return; |
||
2245 | } |
||
2246 | |||
2247 | var data = { |
||
2248 | instance: this, |
||
2249 | styles: {}, |
||
2250 | arrowStyles: {}, |
||
2251 | attributes: {}, |
||
2252 | flipped: false, |
||
2253 | offsets: {} |
||
2254 | }; |
||
2255 | |||
2256 | // compute reference element offsets |
||
2257 | data.offsets.reference = getReferenceOffsets(this.state, this.popper, this.reference); |
||
2258 | |||
2259 | // compute auto placement, store placement inside the data object, |
||
2260 | // modifiers will be able to edit `placement` if needed |
||
2261 | // and refer to originalPlacement to know the original value |
||
2262 | data.placement = computeAutoPlacement(this.options.placement, data.offsets.reference, this.popper, this.reference, this.options.modifiers.flip.boundariesElement, this.options.modifiers.flip.padding); |
||
2263 | |||
2264 | // store the computed placement inside `originalPlacement` |
||
2265 | data.originalPlacement = data.placement; |
||
2266 | |||
2267 | // compute the popper offsets |
||
2268 | data.offsets.popper = getPopperOffsets(this.popper, data.offsets.reference, data.placement); |
||
2269 | data.offsets.popper.position = 'absolute'; |
||
2270 | |||
2271 | // run the modifiers |
||
2272 | data = runModifiers(this.modifiers, data); |
||
2273 | |||
2274 | // the first `update` will call `onCreate` callback |
||
2275 | // the other ones will call `onUpdate` callback |
||
2276 | if (!this.state.isCreated) { |
||
2277 | this.state.isCreated = true; |
||
2278 | this.options.onCreate(data); |
||
2279 | } else { |
||
2280 | this.options.onUpdate(data); |
||
2281 | } |
||
2282 | } |
||
2283 | |||
2284 | /** |
||
2285 | * Helper used to know if the given modifier is enabled. |
||
2286 | * @method |
||
2287 | * @memberof Popper.Utils |
||
2288 | * @returns {Boolean} |
||
2289 | */ |
||
2290 | function isModifierEnabled(modifiers, modifierName) { |
||
2291 | return modifiers.some(function (_ref) { |
||
2292 | var name = _ref.name, |
||
2293 | enabled = _ref.enabled; |
||
2294 | return enabled && name === modifierName; |
||
2295 | }); |
||
2296 | } |
||
2297 | |||
2298 | /** |
||
2299 | * Get the prefixed supported property name |
||
2300 | * @method |
||
2301 | * @memberof Popper.Utils |
||
2302 | * @argument {String} property (camelCase) |
||
2303 | * @returns {String} prefixed property (camelCase or PascalCase, depending on the vendor prefix) |
||
2304 | */ |
||
2305 | function getSupportedPropertyName(property) { |
||
2306 | var prefixes = [false, 'ms', 'Webkit', 'Moz', 'O']; |
||
2307 | var upperProp = property.charAt(0).toUpperCase() + property.slice(1); |
||
2308 | |||
2309 | for (var i = 0; i < prefixes.length - 1; i++) { |
||
2310 | var prefix = prefixes[i]; |
||
2311 | var toCheck = prefix ? '' + prefix + upperProp : property; |
||
2312 | if (typeof document.body.style[toCheck] !== 'undefined') { |
||
2313 | return toCheck; |
||
2314 | } |
||
2315 | } |
||
2316 | return null; |
||
2317 | } |
||
2318 | |||
2319 | /** |
||
2320 | * Destroy the popper |
||
2321 | * @method |
||
2322 | * @memberof Popper |
||
2323 | */ |
||
2324 | function destroy() { |
||
2325 | this.state.isDestroyed = true; |
||
2326 | |||
2327 | // touch DOM only if `applyStyle` modifier is enabled |
||
2328 | if (isModifierEnabled(this.modifiers, 'applyStyle')) { |
||
2329 | this.popper.removeAttribute('x-placement'); |
||
2330 | this.popper.style.left = ''; |
||
2331 | this.popper.style.position = ''; |
||
2332 | this.popper.style.top = ''; |
||
2333 | this.popper.style[getSupportedPropertyName('transform')] = ''; |
||
2334 | } |
||
2335 | |||
2336 | this.disableEventListeners(); |
||
2337 | |||
2338 | // remove the popper if user explicity asked for the deletion on destroy |
||
2339 | // do not use `remove` because IE11 doesn't support it |
||
2340 | if (this.options.removeOnDestroy) { |
||
2341 | this.popper.parentNode.removeChild(this.popper); |
||
2342 | } |
||
2343 | return this; |
||
2344 | } |
||
2345 | |||
2346 | /** |
||
2347 | * Get the window associated with the element |
||
2348 | * @argument {Element} element |
||
2349 | * @returns {Window} |
||
2350 | */ |
||
2351 | function getWindow(element) { |
||
2352 | var ownerDocument = element.ownerDocument; |
||
2353 | return ownerDocument ? ownerDocument.defaultView : window; |
||
2354 | } |
||
2355 | |||
2356 | function attachToScrollParents(scrollParent, event, callback, scrollParents) { |
||
2357 | var isBody = scrollParent.nodeName === 'BODY'; |
||
2358 | var target = isBody ? scrollParent.ownerDocument.defaultView : scrollParent; |
||
2359 | target.addEventListener(event, callback, { passive: true }); |
||
2360 | |||
2361 | if (!isBody) { |
||
2362 | attachToScrollParents(getScrollParent(target.parentNode), event, callback, scrollParents); |
||
2363 | } |
||
2364 | scrollParents.push(target); |
||
2365 | } |
||
2366 | |||
2367 | /** |
||
2368 | * Setup needed event listeners used to update the popper position |
||
2369 | * @method |
||
2370 | * @memberof Popper.Utils |
||
2371 | * @private |
||
2372 | */ |
||
2373 | function setupEventListeners(reference, options, state, updateBound) { |
||
2374 | // Resize event listener on window |
||
2375 | state.updateBound = updateBound; |
||
2376 | getWindow(reference).addEventListener('resize', state.updateBound, { passive: true }); |
||
2377 | |||
2378 | // Scroll event listener on scroll parents |
||
2379 | var scrollElement = getScrollParent(reference); |
||
2380 | attachToScrollParents(scrollElement, 'scroll', state.updateBound, state.scrollParents); |
||
2381 | state.scrollElement = scrollElement; |
||
2382 | state.eventsEnabled = true; |
||
2383 | |||
2384 | return state; |
||
2385 | } |
||
2386 | |||
2387 | /** |
||
2388 | * It will add resize/scroll events and start recalculating |
||
2389 | * position of the popper element when they are triggered. |
||
2390 | * @method |
||
2391 | * @memberof Popper |
||
2392 | */ |
||
2393 | function enableEventListeners() { |
||
2394 | if (!this.state.eventsEnabled) { |
||
2395 | this.state = setupEventListeners(this.reference, this.options, this.state, this.scheduleUpdate); |
||
2396 | } |
||
2397 | } |
||
2398 | |||
2399 | /** |
||
2400 | * Remove event listeners used to update the popper position |
||
2401 | * @method |
||
2402 | * @memberof Popper.Utils |
||
2403 | * @private |
||
2404 | */ |
||
2405 | function removeEventListeners(reference, state) { |
||
2406 | // Remove resize event listener on window |
||
2407 | getWindow(reference).removeEventListener('resize', state.updateBound); |
||
2408 | |||
2409 | // Remove scroll event listener on scroll parents |
||
2410 | state.scrollParents.forEach(function (target) { |
||
2411 | target.removeEventListener('scroll', state.updateBound); |
||
2412 | }); |
||
2413 | |||
2414 | // Reset state |
||
2415 | state.updateBound = null; |
||
2416 | state.scrollParents = []; |
||
2417 | state.scrollElement = null; |
||
2418 | state.eventsEnabled = false; |
||
2419 | return state; |
||
2420 | } |
||
2421 | |||
2422 | /** |
||
2423 | * It will remove resize/scroll events and won't recalculate popper position |
||
2424 | * when they are triggered. It also won't trigger onUpdate callback anymore, |
||
2425 | * unless you call `update` method manually. |
||
2426 | * @method |
||
2427 | * @memberof Popper |
||
2428 | */ |
||
2429 | function disableEventListeners() { |
||
2430 | if (this.state.eventsEnabled) { |
||
2431 | cancelAnimationFrame(this.scheduleUpdate); |
||
2432 | this.state = removeEventListeners(this.reference, this.state); |
||
2433 | } |
||
2434 | } |
||
2435 | |||
2436 | /** |
||
2437 | * Tells if a given input is a number |
||
2438 | * @method |
||
2439 | * @memberof Popper.Utils |
||
2440 | * @param {*} input to check |
||
2441 | * @return {Boolean} |
||
2442 | */ |
||
2443 | function isNumeric(n) { |
||
2444 | return n !== '' && !isNaN(parseFloat(n)) && isFinite(n); |
||
2445 | } |
||
2446 | |||
2447 | /** |
||
2448 | * Set the style to the given popper |
||
2449 | * @method |
||
2450 | * @memberof Popper.Utils |
||
2451 | * @argument {Element} element - Element to apply the style to |
||
2452 | * @argument {Object} styles |
||
2453 | * Object with a list of properties and values which will be applied to the element |
||
2454 | */ |
||
2455 | function setStyles(element, styles) { |
||
2456 | Object.keys(styles).forEach(function (prop) { |
||
2457 | var unit = ''; |
||
2458 | // add unit if the value is numeric and is one of the following |
||
2459 | if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && isNumeric(styles[prop])) { |
||
2460 | unit = 'px'; |
||
2461 | } |
||
2462 | element.style[prop] = styles[prop] + unit; |
||
2463 | }); |
||
2464 | } |
||
2465 | |||
2466 | /** |
||
2467 | * Set the attributes to the given popper |
||
2468 | * @method |
||
2469 | * @memberof Popper.Utils |
||
2470 | * @argument {Element} element - Element to apply the attributes to |
||
2471 | * @argument {Object} styles |
||
2472 | * Object with a list of properties and values which will be applied to the element |
||
2473 | */ |
||
2474 | function setAttributes(element, attributes) { |
||
2475 | Object.keys(attributes).forEach(function (prop) { |
||
2476 | var value = attributes[prop]; |
||
2477 | if (value !== false) { |
||
2478 | element.setAttribute(prop, attributes[prop]); |
||
2479 | } else { |
||
2480 | element.removeAttribute(prop); |
||
2481 | } |
||
2482 | }); |
||
2483 | } |
||
2484 | |||
2485 | /** |
||
2486 | * @function |
||
2487 | * @memberof Modifiers |
||
2488 | * @argument {Object} data - The data object generated by `update` method |
||
2489 | * @argument {Object} data.styles - List of style properties - values to apply to popper element |
||
2490 | * @argument {Object} data.attributes - List of attribute properties - values to apply to popper element |
||
2491 | * @argument {Object} options - Modifiers configuration and options |
||
2492 | * @returns {Object} The same data object |
||
2493 | */ |
||
2494 | function applyStyle(data) { |
||
2495 | // any property present in `data.styles` will be applied to the popper, |
||
2496 | // in this way we can make the 3rd party modifiers add custom styles to it |
||
2497 | // Be aware, modifiers could override the properties defined in the previous |
||
2498 | // lines of this modifier! |
||
2499 | setStyles(data.instance.popper, data.styles); |
||
2500 | |||
2501 | // any property present in `data.attributes` will be applied to the popper, |
||
2502 | // they will be set as HTML attributes of the element |
||
2503 | setAttributes(data.instance.popper, data.attributes); |
||
2504 | |||
2505 | // if arrowElement is defined and arrowStyles has some properties |
||
2506 | if (data.arrowElement && Object.keys(data.arrowStyles).length) { |
||
2507 | setStyles(data.arrowElement, data.arrowStyles); |
||
2508 | } |
||
2509 | |||
2510 | return data; |
||
2511 | } |
||
2512 | |||
2513 | /** |
||
2514 | * Set the x-placement attribute before everything else because it could be used |
||
2515 | * to add margins to the popper margins needs to be calculated to get the |
||
2516 | * correct popper offsets. |
||
2517 | * @method |
||
2518 | * @memberof Popper.modifiers |
||
2519 | * @param {HTMLElement} reference - The reference element used to position the popper |
||
2520 | * @param {HTMLElement} popper - The HTML element used as popper. |
||
2521 | * @param {Object} options - Popper.js options |
||
2522 | */ |
||
2523 | function applyStyleOnLoad(reference, popper, options, modifierOptions, state) { |
||
2524 | // compute reference element offsets |
||
2525 | var referenceOffsets = getReferenceOffsets(state, popper, reference); |
||
2526 | |||
2527 | // compute auto placement, store placement inside the data object, |
||
2528 | // modifiers will be able to edit `placement` if needed |
||
2529 | // and refer to originalPlacement to know the original value |
||
2530 | var placement = computeAutoPlacement(options.placement, referenceOffsets, popper, reference, options.modifiers.flip.boundariesElement, options.modifiers.flip.padding); |
||
2531 | |||
2532 | popper.setAttribute('x-placement', placement); |
||
2533 | |||
2534 | // Apply `position` to popper before anything else because |
||
2535 | // without the position applied we can't guarantee correct computations |
||
2536 | setStyles(popper, { position: 'absolute' }); |
||
2537 | |||
2538 | return options; |
||
2539 | } |
||
2540 | |||
2541 | /** |
||
2542 | * @function |
||
2543 | * @memberof Modifiers |
||
2544 | * @argument {Object} data - The data object generated by `update` method |
||
2545 | * @argument {Object} options - Modifiers configuration and options |
||
2546 | * @returns {Object} The data object, properly modified |
||
2547 | */ |
||
2548 | function computeStyle(data, options) { |
||
2549 | var x = options.x, |
||
2550 | y = options.y; |
||
2551 | var popper = data.offsets.popper; |
||
2552 | |||
2553 | // Remove this legacy support in Popper.js v2 |
||
2554 | |||
2555 | var legacyGpuAccelerationOption = find(data.instance.modifiers, function (modifier) { |
||
2556 | return modifier.name === 'applyStyle'; |
||
2557 | }).gpuAcceleration; |
||
2558 | if (legacyGpuAccelerationOption !== undefined) { |
||
2559 | console.warn('WARNING: `gpuAcceleration` option moved to `computeStyle` modifier and will not be supported in future versions of Popper.js!'); |
||
2560 | } |
||
2561 | var gpuAcceleration = legacyGpuAccelerationOption !== undefined ? legacyGpuAccelerationOption : options.gpuAcceleration; |
||
2562 | |||
2563 | var offsetParent = getOffsetParent(data.instance.popper); |
||
2564 | var offsetParentRect = getBoundingClientRect(offsetParent); |
||
2565 | |||
2566 | // Styles |
||
2567 | var styles = { |
||
2568 | position: popper.position |
||
2569 | }; |
||
2570 | |||
2571 | // floor sides to avoid blurry text |
||
2572 | var offsets = { |
||
2573 | left: Math.floor(popper.left), |
||
2574 | top: Math.floor(popper.top), |
||
2575 | bottom: Math.floor(popper.bottom), |
||
2576 | right: Math.floor(popper.right) |
||
2577 | }; |
||
2578 | |||
2579 | var sideA = x === 'bottom' ? 'top' : 'bottom'; |
||
2580 | var sideB = y === 'right' ? 'left' : 'right'; |
||
2581 | |||
2582 | // if gpuAcceleration is set to `true` and transform is supported, |
||
2583 | // we use `translate3d` to apply the position to the popper we |
||
2584 | // automatically use the supported prefixed version if needed |
||
2585 | var prefixedProperty = getSupportedPropertyName('transform'); |
||
2586 | |||
2587 | // now, let's make a step back and look at this code closely (wtf?) |
||
2588 | // If the content of the popper grows once it's been positioned, it |
||
2589 | // may happen that the popper gets misplaced because of the new content |
||
2590 | // overflowing its reference element |
||
2591 | // To avoid this problem, we provide two options (x and y), which allow |
||
2592 | // the consumer to define the offset origin. |
||
2593 | // If we position a popper on top of a reference element, we can set |
||
2594 | // `x` to `top` to make the popper grow towards its top instead of |
||
2595 | // its bottom. |
||
2596 | var left = void 0, |
||
2597 | top = void 0; |
||
2598 | if (sideA === 'bottom') { |
||
2599 | top = -offsetParentRect.height + offsets.bottom; |
||
2600 | } else { |
||
2601 | top = offsets.top; |
||
2602 | } |
||
2603 | if (sideB === 'right') { |
||
2604 | left = -offsetParentRect.width + offsets.right; |
||
2605 | } else { |
||
2606 | left = offsets.left; |
||
2607 | } |
||
2608 | if (gpuAcceleration && prefixedProperty) { |
||
2609 | styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)'; |
||
2610 | styles[sideA] = 0; |
||
2611 | styles[sideB] = 0; |
||
2612 | styles.willChange = 'transform'; |
||
2613 | } else { |
||
2614 | // othwerise, we use the standard `top`, `left`, `bottom` and `right` properties |
||
2615 | var invertTop = sideA === 'bottom' ? -1 : 1; |
||
2616 | var invertLeft = sideB === 'right' ? -1 : 1; |
||
2617 | styles[sideA] = top * invertTop; |
||
2618 | styles[sideB] = left * invertLeft; |
||
2619 | styles.willChange = sideA + ', ' + sideB; |
||
2620 | } |
||
2621 | |||
2622 | // Attributes |
||
2623 | var attributes = { |
||
2624 | 'x-placement': data.placement |
||
2625 | }; |
||
2626 | |||
2627 | // Update `data` attributes, styles and arrowStyles |
||
2628 | data.attributes = _extends$1({}, attributes, data.attributes); |
||
2629 | data.styles = _extends$1({}, styles, data.styles); |
||
2630 | data.arrowStyles = _extends$1({}, data.offsets.arrow, data.arrowStyles); |
||
2631 | |||
2632 | return data; |
||
2633 | } |
||
2634 | |||
2635 | /** |
||
2636 | * Helper used to know if the given modifier depends from another one.<br /> |
||
2637 | * It checks if the needed modifier is listed and enabled. |
||
2638 | * @method |
||
2639 | * @memberof Popper.Utils |
||
2640 | * @param {Array} modifiers - list of modifiers |
||
2641 | * @param {String} requestingName - name of requesting modifier |
||
2642 | * @param {String} requestedName - name of requested modifier |
||
2643 | * @returns {Boolean} |
||
2644 | */ |
||
2645 | function isModifierRequired(modifiers, requestingName, requestedName) { |
||
2646 | var requesting = find(modifiers, function (_ref) { |
||
2647 | var name = _ref.name; |
||
2648 | return name === requestingName; |
||
2649 | }); |
||
2650 | |||
2651 | var isRequired = !!requesting && modifiers.some(function (modifier) { |
||
2652 | return modifier.name === requestedName && modifier.enabled && modifier.order < requesting.order; |
||
2653 | }); |
||
2654 | |||
2655 | if (!isRequired) { |
||
2656 | var _requesting = '`' + requestingName + '`'; |
||
2657 | var requested = '`' + requestedName + '`'; |
||
2658 | console.warn(requested + ' modifier is required by ' + _requesting + ' modifier in order to work, be sure to include it before ' + _requesting + '!'); |
||
2659 | } |
||
2660 | return isRequired; |
||
2661 | } |
||
2662 | |||
2663 | /** |
||
2664 | * @function |
||
2665 | * @memberof Modifiers |
||
2666 | * @argument {Object} data - The data object generated by update method |
||
2667 | * @argument {Object} options - Modifiers configuration and options |
||
2668 | * @returns {Object} The data object, properly modified |
||
2669 | */ |
||
2670 | function arrow(data, options) { |
||
2671 | var _data$offsets$arrow; |
||
2672 | |||
2673 | // arrow depends on keepTogether in order to work |
||
2674 | if (!isModifierRequired(data.instance.modifiers, 'arrow', 'keepTogether')) { |
||
2675 | return data; |
||
2676 | } |
||
2677 | |||
2678 | var arrowElement = options.element; |
||
2679 | |||
2680 | // if arrowElement is a string, suppose it's a CSS selector |
||
2681 | if (typeof arrowElement === 'string') { |
||
2682 | arrowElement = data.instance.popper.querySelector(arrowElement); |
||
2683 | |||
2684 | // if arrowElement is not found, don't run the modifier |
||
2685 | if (!arrowElement) { |
||
2686 | return data; |
||
2687 | } |
||
2688 | } else { |
||
2689 | // if the arrowElement isn't a query selector we must check that the |
||
2690 | // provided DOM node is child of its popper node |
||
2691 | if (!data.instance.popper.contains(arrowElement)) { |
||
2692 | console.warn('WARNING: `arrow.element` must be child of its popper element!'); |
||
2693 | return data; |
||
2694 | } |
||
2695 | } |
||
2696 | |||
2697 | var placement = data.placement.split('-')[0]; |
||
2698 | var _data$offsets = data.offsets, |
||
2699 | popper = _data$offsets.popper, |
||
2700 | reference = _data$offsets.reference; |
||
2701 | |||
2702 | var isVertical = ['left', 'right'].indexOf(placement) !== -1; |
||
2703 | |||
2704 | var len = isVertical ? 'height' : 'width'; |
||
2705 | var sideCapitalized = isVertical ? 'Top' : 'Left'; |
||
2706 | var side = sideCapitalized.toLowerCase(); |
||
2707 | var altSide = isVertical ? 'left' : 'top'; |
||
2708 | var opSide = isVertical ? 'bottom' : 'right'; |
||
2709 | var arrowElementSize = getOuterSizes(arrowElement)[len]; |
||
2710 | |||
2711 | // |
||
2712 | // extends keepTogether behavior making sure the popper and its |
||
2713 | // reference have enough pixels in conjuction |
||
2714 | // |
||
2715 | |||
2716 | // top/left side |
||
2717 | if (reference[opSide] - arrowElementSize < popper[side]) { |
||
2718 | data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowElementSize); |
||
2719 | } |
||
2720 | // bottom/right side |
||
2721 | if (reference[side] + arrowElementSize > popper[opSide]) { |
||
2722 | data.offsets.popper[side] += reference[side] + arrowElementSize - popper[opSide]; |
||
2723 | } |
||
2724 | data.offsets.popper = getClientRect(data.offsets.popper); |
||
2725 | |||
2726 | // compute center of the popper |
||
2727 | var center = reference[side] + reference[len] / 2 - arrowElementSize / 2; |
||
2728 | |||
2729 | // Compute the sideValue using the updated popper offsets |
||
2730 | // take popper margin in account because we don't have this info available |
||
2731 | var css = getStyleComputedProperty(data.instance.popper); |
||
2732 | var popperMarginSide = parseFloat(css['margin' + sideCapitalized], 10); |
||
2733 | var popperBorderSide = parseFloat(css['border' + sideCapitalized + 'Width'], 10); |
||
2734 | var sideValue = center - data.offsets.popper[side] - popperMarginSide - popperBorderSide; |
||
2735 | |||
2736 | // prevent arrowElement from being placed not contiguously to its popper |
||
2737 | sideValue = Math.max(Math.min(popper[len] - arrowElementSize, sideValue), 0); |
||
2738 | |||
2739 | data.arrowElement = arrowElement; |
||
2740 | data.offsets.arrow = (_data$offsets$arrow = {}, defineProperty(_data$offsets$arrow, side, Math.round(sideValue)), defineProperty(_data$offsets$arrow, altSide, ''), _data$offsets$arrow); |
||
2741 | |||
2742 | return data; |
||
2743 | } |
||
2744 | |||
2745 | /** |
||
2746 | * Get the opposite placement variation of the given one |
||
2747 | * @method |
||
2748 | * @memberof Popper.Utils |
||
2749 | * @argument {String} placement variation |
||
2750 | * @returns {String} flipped placement variation |
||
2751 | */ |
||
2752 | function getOppositeVariation(variation) { |
||
2753 | if (variation === 'end') { |
||
2754 | return 'start'; |
||
2755 | } else if (variation === 'start') { |
||
2756 | return 'end'; |
||
2757 | } |
||
2758 | return variation; |
||
2759 | } |
||
2760 | |||
2761 | /** |
||
2762 | * List of accepted placements to use as values of the `placement` option.<br /> |
||
2763 | * Valid placements are: |
||
2764 | * - `auto` |
||
2765 | * - `top` |
||
2766 | * - `right` |
||
2767 | * - `bottom` |
||
2768 | * - `left` |
||
2769 | * |
||
2770 | * Each placement can have a variation from this list: |
||
2771 | * - `-start` |
||
2772 | * - `-end` |
||
2773 | * |
||
2774 | * Variations are interpreted easily if you think of them as the left to right |
||
2775 | * written languages. Horizontally (`top` and `bottom`), `start` is left and `end` |
||
2776 | * is right.<br /> |
||
2777 | * Vertically (`left` and `right`), `start` is top and `end` is bottom. |
||
2778 | * |
||
2779 | * Some valid examples are: |
||
2780 | * - `top-end` (on top of reference, right aligned) |
||
2781 | * - `right-start` (on right of reference, top aligned) |
||
2782 | * - `bottom` (on bottom, centered) |
||
2783 | * - `auto-right` (on the side with more space available, alignment depends by placement) |
||
2784 | * |
||
2785 | * @static |
||
2786 | * @type {Array} |
||
2787 | * @enum {String} |
||
2788 | * @readonly |
||
2789 | * @method placements |
||
2790 | * @memberof Popper |
||
2791 | */ |
||
2792 | var placements = ['auto-start', 'auto', 'auto-end', 'top-start', 'top', 'top-end', 'right-start', 'right', 'right-end', 'bottom-end', 'bottom', 'bottom-start', 'left-end', 'left', 'left-start']; |
||
2793 | |||
2794 | // Get rid of `auto` `auto-start` and `auto-end` |
||
2795 | var validPlacements = placements.slice(3); |
||
2796 | |||
2797 | /** |
||
2798 | * Given an initial placement, returns all the subsequent placements |
||
2799 | * clockwise (or counter-clockwise). |
||
2800 | * |
||
2801 | * @method |
||
2802 | * @memberof Popper.Utils |
||
2803 | * @argument {String} placement - A valid placement (it accepts variations) |
||
2804 | * @argument {Boolean} counter - Set to true to walk the placements counterclockwise |
||
2805 | * @returns {Array} placements including their variations |
||
2806 | */ |
||
2807 | function clockwise(placement) { |
||
2808 | var counter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; |
||
2809 | |||
2810 | var index = validPlacements.indexOf(placement); |
||
2811 | var arr = validPlacements.slice(index + 1).concat(validPlacements.slice(0, index)); |
||
2812 | return counter ? arr.reverse() : arr; |
||
2813 | } |
||
2814 | |||
2815 | var BEHAVIORS = { |
||
2816 | FLIP: 'flip', |
||
2817 | CLOCKWISE: 'clockwise', |
||
2818 | COUNTERCLOCKWISE: 'counterclockwise' |
||
2819 | }; |
||
2820 | |||
2821 | /** |
||
2822 | * @function |
||
2823 | * @memberof Modifiers |
||
2824 | * @argument {Object} data - The data object generated by update method |
||
2825 | * @argument {Object} options - Modifiers configuration and options |
||
2826 | * @returns {Object} The data object, properly modified |
||
2827 | */ |
||
2828 | function flip(data, options) { |
||
2829 | // if `inner` modifier is enabled, we can't use the `flip` modifier |
||
2830 | if (isModifierEnabled(data.instance.modifiers, 'inner')) { |
||
2831 | return data; |
||
2832 | } |
||
2833 | |||
2834 | if (data.flipped && data.placement === data.originalPlacement) { |
||
2835 | // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides |
||
2836 | return data; |
||
2837 | } |
||
2838 | |||
2839 | var boundaries = getBoundaries(data.instance.popper, data.instance.reference, options.padding, options.boundariesElement); |
||
2840 | |||
2841 | var placement = data.placement.split('-')[0]; |
||
2842 | var placementOpposite = getOppositePlacement(placement); |
||
2843 | var variation = data.placement.split('-')[1] || ''; |
||
2844 | |||
2845 | var flipOrder = []; |
||
2846 | |||
2847 | switch (options.behavior) { |
||
2848 | case BEHAVIORS.FLIP: |
||
2849 | flipOrder = [placement, placementOpposite]; |
||
2850 | break; |
||
2851 | case BEHAVIORS.CLOCKWISE: |
||
2852 | flipOrder = clockwise(placement); |
||
2853 | break; |
||
2854 | case BEHAVIORS.COUNTERCLOCKWISE: |
||
2855 | flipOrder = clockwise(placement, true); |
||
2856 | break; |
||
2857 | default: |
||
2858 | flipOrder = options.behavior; |
||
2859 | } |
||
2860 | |||
2861 | flipOrder.forEach(function (step, index) { |
||
2862 | if (placement !== step || flipOrder.length === index + 1) { |
||
2863 | return data; |
||
2864 | } |
||
2865 | |||
2866 | placement = data.placement.split('-')[0]; |
||
2867 | placementOpposite = getOppositePlacement(placement); |
||
2868 | |||
2869 | var popperOffsets = data.offsets.popper; |
||
2870 | var refOffsets = data.offsets.reference; |
||
2871 | |||
2872 | // using floor because the reference offsets may contain decimals we are not going to consider here |
||
2873 | var floor = Math.floor; |
||
2874 | var overlapsRef = placement === 'left' && floor(popperOffsets.right) > floor(refOffsets.left) || placement === 'right' && floor(popperOffsets.left) < floor(refOffsets.right) || placement === 'top' && floor(popperOffsets.bottom) > floor(refOffsets.top) || placement === 'bottom' && floor(popperOffsets.top) < floor(refOffsets.bottom); |
||
2875 | |||
2876 | var overflowsLeft = floor(popperOffsets.left) < floor(boundaries.left); |
||
2877 | var overflowsRight = floor(popperOffsets.right) > floor(boundaries.right); |
||
2878 | var overflowsTop = floor(popperOffsets.top) < floor(boundaries.top); |
||
2879 | var overflowsBottom = floor(popperOffsets.bottom) > floor(boundaries.bottom); |
||
2880 | |||
2881 | var overflowsBoundaries = placement === 'left' && overflowsLeft || placement === 'right' && overflowsRight || placement === 'top' && overflowsTop || placement === 'bottom' && overflowsBottom; |
||
2882 | |||
2883 | // flip the variation if required |
||
2884 | var isVertical = ['top', 'bottom'].indexOf(placement) !== -1; |
||
2885 | var flippedVariation = !!options.flipVariations && (isVertical && variation === 'start' && overflowsLeft || isVertical && variation === 'end' && overflowsRight || !isVertical && variation === 'start' && overflowsTop || !isVertical && variation === 'end' && overflowsBottom); |
||
2886 | |||
2887 | if (overlapsRef || overflowsBoundaries || flippedVariation) { |
||
2888 | // this boolean to detect any flip loop |
||
2889 | data.flipped = true; |
||
2890 | |||
2891 | if (overlapsRef || overflowsBoundaries) { |
||
2892 | placement = flipOrder[index + 1]; |
||
2893 | } |
||
2894 | |||
2895 | if (flippedVariation) { |
||
2896 | variation = getOppositeVariation(variation); |
||
2897 | } |
||
2898 | |||
2899 | data.placement = placement + (variation ? '-' + variation : ''); |
||
2900 | |||
2901 | // this object contains `position`, we want to preserve it along with |
||
2902 | // any additional property we may add in the future |
||
2903 | data.offsets.popper = _extends$1({}, data.offsets.popper, getPopperOffsets(data.instance.popper, data.offsets.reference, data.placement)); |
||
2904 | |||
2905 | data = runModifiers(data.instance.modifiers, data, 'flip'); |
||
2906 | } |
||
2907 | }); |
||
2908 | return data; |
||
2909 | } |
||
2910 | |||
2911 | /** |
||
2912 | * @function |
||
2913 | * @memberof Modifiers |
||
2914 | * @argument {Object} data - The data object generated by update method |
||
2915 | * @argument {Object} options - Modifiers configuration and options |
||
2916 | * @returns {Object} The data object, properly modified |
||
2917 | */ |
||
2918 | function keepTogether(data) { |
||
2919 | var _data$offsets = data.offsets, |
||
2920 | popper = _data$offsets.popper, |
||
2921 | reference = _data$offsets.reference; |
||
2922 | |||
2923 | var placement = data.placement.split('-')[0]; |
||
2924 | var floor = Math.floor; |
||
2925 | var isVertical = ['top', 'bottom'].indexOf(placement) !== -1; |
||
2926 | var side = isVertical ? 'right' : 'bottom'; |
||
2927 | var opSide = isVertical ? 'left' : 'top'; |
||
2928 | var measurement = isVertical ? 'width' : 'height'; |
||
2929 | |||
2930 | if (popper[side] < floor(reference[opSide])) { |
||
2931 | data.offsets.popper[opSide] = floor(reference[opSide]) - popper[measurement]; |
||
2932 | } |
||
2933 | if (popper[opSide] > floor(reference[side])) { |
||
2934 | data.offsets.popper[opSide] = floor(reference[side]); |
||
2935 | } |
||
2936 | |||
2937 | return data; |
||
2938 | } |
||
2939 | |||
2940 | /** |
||
2941 | * Converts a string containing value + unit into a px value number |
||
2942 | * @function |
||
2943 | * @memberof {modifiers~offset} |
||
2944 | * @private |
||
2945 | * @argument {String} str - Value + unit string |
||
2946 | * @argument {String} measurement - `height` or `width` |
||
2947 | * @argument {Object} popperOffsets |
||
2948 | * @argument {Object} referenceOffsets |
||
2949 | * @returns {Number|String} |
||
2950 | * Value in pixels, or original string if no values were extracted |
||
2951 | */ |
||
2952 | function toValue(str, measurement, popperOffsets, referenceOffsets) { |
||
2953 | // separate value from unit |
||
2954 | var split = str.match(/((?:\-|\+)?\d*\.?\d*)(.*)/); |
||
2955 | var value = +split[1]; |
||
2956 | var unit = split[2]; |
||
2957 | |||
2958 | // If it's not a number it's an operator, I guess |
||
2959 | if (!value) { |
||
2960 | return str; |
||
2961 | } |
||
2962 | |||
2963 | if (unit.indexOf('%') === 0) { |
||
2964 | var element = void 0; |
||
2965 | switch (unit) { |
||
2966 | case '%p': |
||
2967 | element = popperOffsets; |
||
2968 | break; |
||
2969 | case '%': |
||
2970 | case '%r': |
||
2971 | default: |
||
2972 | element = referenceOffsets; |
||
2973 | } |
||
2974 | |||
2975 | var rect = getClientRect(element); |
||
2976 | return rect[measurement] / 100 * value; |
||
2977 | } else if (unit === 'vh' || unit === 'vw') { |
||
2978 | // if is a vh or vw, we calculate the size based on the viewport |
||
2979 | var size = void 0; |
||
2980 | if (unit === 'vh') { |
||
2981 | size = Math.max(document.documentElement.clientHeight, window.innerHeight || 0); |
||
2982 | } else { |
||
2983 | size = Math.max(document.documentElement.clientWidth, window.innerWidth || 0); |
||
2984 | } |
||
2985 | return size / 100 * value; |
||
2986 | } else { |
||
2987 | // if is an explicit pixel unit, we get rid of the unit and keep the value |
||
2988 | // if is an implicit unit, it's px, and we return just the value |
||
2989 | return value; |
||
2990 | } |
||
2991 | } |
||
2992 | |||
2993 | /** |
||
2994 | * Parse an `offset` string to extrapolate `x` and `y` numeric offsets. |
||
2995 | * @function |
||
2996 | * @memberof {modifiers~offset} |
||
2997 | * @private |
||
2998 | * @argument {String} offset |
||
2999 | * @argument {Object} popperOffsets |
||
3000 | * @argument {Object} referenceOffsets |
||
3001 | * @argument {String} basePlacement |
||
3002 | * @returns {Array} a two cells array with x and y offsets in numbers |
||
3003 | */ |
||
3004 | function parseOffset(offset, popperOffsets, referenceOffsets, basePlacement) { |
||
3005 | var offsets = [0, 0]; |
||
3006 | |||
3007 | // Use height if placement is left or right and index is 0 otherwise use width |
||
3008 | // in this way the first offset will use an axis and the second one |
||
3009 | // will use the other one |
||
3010 | var useHeight = ['right', 'left'].indexOf(basePlacement) !== -1; |
||
3011 | |||
3012 | // Split the offset string to obtain a list of values and operands |
||
3013 | // The regex addresses values with the plus or minus sign in front (+10, -20, etc) |
||
3014 | var fragments = offset.split(/(\+|\-)/).map(function (frag) { |
||
3015 | return frag.trim(); |
||
3016 | }); |
||
3017 | |||
3018 | // Detect if the offset string contains a pair of values or a single one |
||
3019 | // they could be separated by comma or space |
||
3020 | var divider = fragments.indexOf(find(fragments, function (frag) { |
||
3021 | return frag.search(/,|\s/) !== -1; |
||
3022 | })); |
||
3023 | |||
3024 | if (fragments[divider] && fragments[divider].indexOf(',') === -1) { |
||
3025 | console.warn('Offsets separated by white space(s) are deprecated, use a comma (,) instead.'); |
||
3026 | } |
||
3027 | |||
3028 | // If divider is found, we divide the list of values and operands to divide |
||
3029 | // them by ofset X and Y. |
||
3030 | var splitRegex = /\s*,\s*|\s+/; |
||
3031 | var ops = divider !== -1 ? [fragments.slice(0, divider).concat([fragments[divider].split(splitRegex)[0]]), [fragments[divider].split(splitRegex)[1]].concat(fragments.slice(divider + 1))] : [fragments]; |
||
3032 | |||
3033 | // Convert the values with units to absolute pixels to allow our computations |
||
3034 | ops = ops.map(function (op, index) { |
||
3035 | // Most of the units rely on the orientation of the popper |
||
3036 | var measurement = (index === 1 ? !useHeight : useHeight) ? 'height' : 'width'; |
||
3037 | var mergeWithPrevious = false; |
||
3038 | return op |
||
3039 | // This aggregates any `+` or `-` sign that aren't considered operators |
||
3040 | // e.g.: 10 + +5 => [10, +, +5] |
||
3041 | .reduce(function (a, b) { |
||
3042 | if (a[a.length - 1] === '' && ['+', '-'].indexOf(b) !== -1) { |
||
3043 | a[a.length - 1] = b; |
||
3044 | mergeWithPrevious = true; |
||
3045 | return a; |
||
3046 | } else if (mergeWithPrevious) { |
||
3047 | a[a.length - 1] += b; |
||
3048 | mergeWithPrevious = false; |
||
3049 | return a; |
||
3050 | } else { |
||
3051 | return a.concat(b); |
||
3052 | } |
||
3053 | }, []) |
||
3054 | // Here we convert the string values into number values (in px) |
||
3055 | .map(function (str) { |
||
3056 | return toValue(str, measurement, popperOffsets, referenceOffsets); |
||
3057 | }); |
||
3058 | }); |
||
3059 | |||
3060 | // Loop trough the offsets arrays and execute the operations |
||
3061 | ops.forEach(function (op, index) { |
||
3062 | op.forEach(function (frag, index2) { |
||
3063 | if (isNumeric(frag)) { |
||
3064 | offsets[index] += frag * (op[index2 - 1] === '-' ? -1 : 1); |
||
3065 | } |
||
3066 | }); |
||
3067 | }); |
||
3068 | return offsets; |
||
3069 | } |
||
3070 | |||
3071 | /** |
||
3072 | * @function |
||
3073 | * @memberof Modifiers |
||
3074 | * @argument {Object} data - The data object generated by update method |
||
3075 | * @argument {Object} options - Modifiers configuration and options |
||
3076 | * @argument {Number|String} options.offset=0 |
||
3077 | * The offset value as described in the modifier description |
||
3078 | * @returns {Object} The data object, properly modified |
||
3079 | */ |
||
3080 | function offset(data, _ref) { |
||
3081 | var offset = _ref.offset; |
||
3082 | var placement = data.placement, |
||
3083 | _data$offsets = data.offsets, |
||
3084 | popper = _data$offsets.popper, |
||
3085 | reference = _data$offsets.reference; |
||
3086 | |||
3087 | var basePlacement = placement.split('-')[0]; |
||
3088 | |||
3089 | var offsets = void 0; |
||
3090 | if (isNumeric(+offset)) { |
||
3091 | offsets = [+offset, 0]; |
||
3092 | } else { |
||
3093 | offsets = parseOffset(offset, popper, reference, basePlacement); |
||
3094 | } |
||
3095 | |||
3096 | if (basePlacement === 'left') { |
||
3097 | popper.top += offsets[0]; |
||
3098 | popper.left -= offsets[1]; |
||
3099 | } else if (basePlacement === 'right') { |
||
3100 | popper.top += offsets[0]; |
||
3101 | popper.left += offsets[1]; |
||
3102 | } else if (basePlacement === 'top') { |
||
3103 | popper.left += offsets[0]; |
||
3104 | popper.top -= offsets[1]; |
||
3105 | } else if (basePlacement === 'bottom') { |
||
3106 | popper.left += offsets[0]; |
||
3107 | popper.top += offsets[1]; |
||
3108 | } |
||
3109 | |||
3110 | data.popper = popper; |
||
3111 | return data; |
||
3112 | } |
||
3113 | |||
3114 | /** |
||
3115 | * @function |
||
3116 | * @memberof Modifiers |
||
3117 | * @argument {Object} data - The data object generated by `update` method |
||
3118 | * @argument {Object} options - Modifiers configuration and options |
||
3119 | * @returns {Object} The data object, properly modified |
||
3120 | */ |
||
3121 | function preventOverflow(data, options) { |
||
3122 | var boundariesElement = options.boundariesElement || getOffsetParent(data.instance.popper); |
||
3123 | |||
3124 | // If offsetParent is the reference element, we really want to |
||
3125 | // go one step up and use the next offsetParent as reference to |
||
3126 | // avoid to make this modifier completely useless and look like broken |
||
3127 | if (data.instance.reference === boundariesElement) { |
||
3128 | boundariesElement = getOffsetParent(boundariesElement); |
||
3129 | } |
||
3130 | |||
3131 | var boundaries = getBoundaries(data.instance.popper, data.instance.reference, options.padding, boundariesElement); |
||
3132 | options.boundaries = boundaries; |
||
3133 | |||
3134 | var order = options.priority; |
||
3135 | var popper = data.offsets.popper; |
||
3136 | |||
3137 | var check = { |
||
3138 | primary: function primary(placement) { |
||
3139 | var value = popper[placement]; |
||
3140 | if (popper[placement] < boundaries[placement] && !options.escapeWithReference) { |
||
3141 | value = Math.max(popper[placement], boundaries[placement]); |
||
3142 | } |
||
3143 | return defineProperty({}, placement, value); |
||
3144 | }, |
||
3145 | secondary: function secondary(placement) { |
||
3146 | var mainSide = placement === 'right' ? 'left' : 'top'; |
||
3147 | var value = popper[mainSide]; |
||
3148 | if (popper[placement] > boundaries[placement] && !options.escapeWithReference) { |
||
3149 | value = Math.min(popper[mainSide], boundaries[placement] - (placement === 'right' ? popper.width : popper.height)); |
||
3150 | } |
||
3151 | return defineProperty({}, mainSide, value); |
||
3152 | } |
||
3153 | }; |
||
3154 | |||
3155 | order.forEach(function (placement) { |
||
3156 | var side = ['left', 'top'].indexOf(placement) !== -1 ? 'primary' : 'secondary'; |
||
3157 | popper = _extends$1({}, popper, check[side](placement)); |
||
3158 | }); |
||
3159 | |||
3160 | data.offsets.popper = popper; |
||
3161 | |||
3162 | return data; |
||
3163 | } |
||
3164 | |||
3165 | /** |
||
3166 | * @function |
||
3167 | * @memberof Modifiers |
||
3168 | * @argument {Object} data - The data object generated by `update` method |
||
3169 | * @argument {Object} options - Modifiers configuration and options |
||
3170 | * @returns {Object} The data object, properly modified |
||
3171 | */ |
||
3172 | function shift(data) { |
||
3173 | var placement = data.placement; |
||
3174 | var basePlacement = placement.split('-')[0]; |
||
3175 | var shiftvariation = placement.split('-')[1]; |
||
3176 | |||
3177 | // if shift shiftvariation is specified, run the modifier |
||
3178 | if (shiftvariation) { |
||
3179 | var _data$offsets = data.offsets, |
||
3180 | reference = _data$offsets.reference, |
||
3181 | popper = _data$offsets.popper; |
||
3182 | |||
3183 | var isVertical = ['bottom', 'top'].indexOf(basePlacement) !== -1; |
||
3184 | var side = isVertical ? 'left' : 'top'; |
||
3185 | var measurement = isVertical ? 'width' : 'height'; |
||
3186 | |||
3187 | var shiftOffsets = { |
||
3188 | start: defineProperty({}, side, reference[side]), |
||
3189 | end: defineProperty({}, side, reference[side] + reference[measurement] - popper[measurement]) |
||
3190 | }; |
||
3191 | |||
3192 | data.offsets.popper = _extends$1({}, popper, shiftOffsets[shiftvariation]); |
||
3193 | } |
||
3194 | |||
3195 | return data; |
||
3196 | } |
||
3197 | |||
3198 | /** |
||
3199 | * @function |
||
3200 | * @memberof Modifiers |
||
3201 | * @argument {Object} data - The data object generated by update method |
||
3202 | * @argument {Object} options - Modifiers configuration and options |
||
3203 | * @returns {Object} The data object, properly modified |
||
3204 | */ |
||
3205 | function hide(data) { |
||
3206 | if (!isModifierRequired(data.instance.modifiers, 'hide', 'preventOverflow')) { |
||
3207 | return data; |
||
3208 | } |
||
3209 | |||
3210 | var refRect = data.offsets.reference; |
||
3211 | var bound = find(data.instance.modifiers, function (modifier) { |
||
3212 | return modifier.name === 'preventOverflow'; |
||
3213 | }).boundaries; |
||
3214 | |||
3215 | if (refRect.bottom < bound.top || refRect.left > bound.right || refRect.top > bound.bottom || refRect.right < bound.left) { |
||
3216 | // Avoid unnecessary DOM access if visibility hasn't changed |
||
3217 | if (data.hide === true) { |
||
3218 | return data; |
||
3219 | } |
||
3220 | |||
3221 | data.hide = true; |
||
3222 | data.attributes['x-out-of-boundaries'] = ''; |
||
3223 | } else { |
||
3224 | // Avoid unnecessary DOM access if visibility hasn't changed |
||
3225 | if (data.hide === false) { |
||
3226 | return data; |
||
3227 | } |
||
3228 | |||
3229 | data.hide = false; |
||
3230 | data.attributes['x-out-of-boundaries'] = false; |
||
3231 | } |
||
3232 | |||
3233 | return data; |
||
3234 | } |
||
3235 | |||
3236 | /** |
||
3237 | * @function |
||
3238 | * @memberof Modifiers |
||
3239 | * @argument {Object} data - The data object generated by `update` method |
||
3240 | * @argument {Object} options - Modifiers configuration and options |
||
3241 | * @returns {Object} The data object, properly modified |
||
3242 | */ |
||
3243 | function inner(data) { |
||
3244 | var placement = data.placement; |
||
3245 | var basePlacement = placement.split('-')[0]; |
||
3246 | var _data$offsets = data.offsets, |
||
3247 | popper = _data$offsets.popper, |
||
3248 | reference = _data$offsets.reference; |
||
3249 | |||
3250 | var isHoriz = ['left', 'right'].indexOf(basePlacement) !== -1; |
||
3251 | |||
3252 | var subtractLength = ['top', 'left'].indexOf(basePlacement) === -1; |
||
3253 | |||
3254 | popper[isHoriz ? 'left' : 'top'] = reference[basePlacement] - (subtractLength ? popper[isHoriz ? 'width' : 'height'] : 0); |
||
3255 | |||
3256 | data.placement = getOppositePlacement(placement); |
||
3257 | data.offsets.popper = getClientRect(popper); |
||
3258 | |||
3259 | return data; |
||
3260 | } |
||
3261 | |||
3262 | /** |
||
3263 | * Modifier function, each modifier can have a function of this type assigned |
||
3264 | * to its `fn` property.<br /> |
||
3265 | * These functions will be called on each update, this means that you must |
||
3266 | * make sure they are performant enough to avoid performance bottlenecks. |
||
3267 | * |
||
3268 | * @function ModifierFn |
||
3269 | * @argument {dataObject} data - The data object generated by `update` method |
||
3270 | * @argument {Object} options - Modifiers configuration and options |
||
3271 | * @returns {dataObject} The data object, properly modified |
||
3272 | */ |
||
3273 | |||
3274 | /** |
||
3275 | * Modifiers are plugins used to alter the behavior of your poppers.<br /> |
||
3276 | * Popper.js uses a set of 9 modifiers to provide all the basic functionalities |
||
3277 | * needed by the library. |
||
3278 | * |
||
3279 | * Usually you don't want to override the `order`, `fn` and `onLoad` props. |
||
3280 | * All the other properties are configurations that could be tweaked. |
||
3281 | * @namespace modifiers |
||
3282 | */ |
||
3283 | var modifiers = { |
||
3284 | /** |
||
3285 | * Modifier used to shift the popper on the start or end of its reference |
||
3286 | * element.<br /> |
||
3287 | * It will read the variation of the `placement` property.<br /> |
||
3288 | * It can be one either `-end` or `-start`. |
||
3289 | * @memberof modifiers |
||
3290 | * @inner |
||
3291 | */ |
||
3292 | shift: { |
||
3293 | /** @prop {number} order=100 - Index used to define the order of execution */ |
||
3294 | order: 100, |
||
3295 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3296 | enabled: true, |
||
3297 | /** @prop {ModifierFn} */ |
||
3298 | fn: shift |
||
3299 | }, |
||
3300 | |||
3301 | /** |
||
3302 | * The `offset` modifier can shift your popper on both its axis. |
||
3303 | * |
||
3304 | * It accepts the following units: |
||
3305 | * - `px` or unitless, interpreted as pixels |
||
3306 | * - `%` or `%r`, percentage relative to the length of the reference element |
||
3307 | * - `%p`, percentage relative to the length of the popper element |
||
3308 | * - `vw`, CSS viewport width unit |
||
3309 | * - `vh`, CSS viewport height unit |
||
3310 | * |
||
3311 | * For length is intended the main axis relative to the placement of the popper.<br /> |
||
3312 | * This means that if the placement is `top` or `bottom`, the length will be the |
||
3313 | * `width`. In case of `left` or `right`, it will be the height. |
||
3314 | * |
||
3315 | * You can provide a single value (as `Number` or `String`), or a pair of values |
||
3316 | * as `String` divided by a comma or one (or more) white spaces.<br /> |
||
3317 | * The latter is a deprecated method because it leads to confusion and will be |
||
3318 | * removed in v2.<br /> |
||
3319 | * Additionally, it accepts additions and subtractions between different units. |
||
3320 | * Note that multiplications and divisions aren't supported. |
||
3321 | * |
||
3322 | * Valid examples are: |
||
3323 | * ``` |
||
3324 | * 10 |
||
3325 | * '10%' |
||
3326 | * '10, 10' |
||
3327 | * '10%, 10' |
||
3328 | * '10 + 10%' |
||
3329 | * '10 - 5vh + 3%' |
||
3330 | * '-10px + 5vh, 5px - 6%' |
||
3331 | * ``` |
||
3332 | * > **NB**: If you desire to apply offsets to your poppers in a way that may make them overlap |
||
3333 | * > with their reference element, unfortunately, you will have to disable the `flip` modifier. |
||
3334 | * > More on this [reading this issue](https://github.com/FezVrasta/popper.js/issues/373) |
||
3335 | * |
||
3336 | * @memberof modifiers |
||
3337 | * @inner |
||
3338 | */ |
||
3339 | offset: { |
||
3340 | /** @prop {number} order=200 - Index used to define the order of execution */ |
||
3341 | order: 200, |
||
3342 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3343 | enabled: true, |
||
3344 | /** @prop {ModifierFn} */ |
||
3345 | fn: offset, |
||
3346 | /** @prop {Number|String} offset=0 |
||
3347 | * The offset value as described in the modifier description |
||
3348 | */ |
||
3349 | offset: 0 |
||
3350 | }, |
||
3351 | |||
3352 | /** |
||
3353 | * Modifier used to prevent the popper from being positioned outside the boundary. |
||
3354 | * |
||
3355 | * An scenario exists where the reference itself is not within the boundaries.<br /> |
||
3356 | * We can say it has "escaped the boundaries" — or just "escaped".<br /> |
||
3357 | * In this case we need to decide whether the popper should either: |
||
3358 | * |
||
3359 | * - detach from the reference and remain "trapped" in the boundaries, or |
||
3360 | * - if it should ignore the boundary and "escape with its reference" |
||
3361 | * |
||
3362 | * When `escapeWithReference` is set to`true` and reference is completely |
||
3363 | * outside its boundaries, the popper will overflow (or completely leave) |
||
3364 | * the boundaries in order to remain attached to the edge of the reference. |
||
3365 | * |
||
3366 | * @memberof modifiers |
||
3367 | * @inner |
||
3368 | */ |
||
3369 | preventOverflow: { |
||
3370 | /** @prop {number} order=300 - Index used to define the order of execution */ |
||
3371 | order: 300, |
||
3372 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3373 | enabled: true, |
||
3374 | /** @prop {ModifierFn} */ |
||
3375 | fn: preventOverflow, |
||
3376 | /** |
||
3377 | * @prop {Array} [priority=['left','right','top','bottom']] |
||
3378 | * Popper will try to prevent overflow following these priorities by default, |
||
3379 | * then, it could overflow on the left and on top of the `boundariesElement` |
||
3380 | */ |
||
3381 | priority: ['left', 'right', 'top', 'bottom'], |
||
3382 | /** |
||
3383 | * @prop {number} padding=5 |
||
3384 | * Amount of pixel used to define a minimum distance between the boundaries |
||
3385 | * and the popper this makes sure the popper has always a little padding |
||
3386 | * between the edges of its container |
||
3387 | */ |
||
3388 | padding: 5, |
||
3389 | /** |
||
3390 | * @prop {String|HTMLElement} boundariesElement='scrollParent' |
||
3391 | * Boundaries used by the modifier, can be `scrollParent`, `window`, |
||
3392 | * `viewport` or any DOM element. |
||
3393 | */ |
||
3394 | boundariesElement: 'scrollParent' |
||
3395 | }, |
||
3396 | |||
3397 | /** |
||
3398 | * Modifier used to make sure the reference and its popper stay near eachothers |
||
3399 | * without leaving any gap between the two. Expecially useful when the arrow is |
||
3400 | * enabled and you want to assure it to point to its reference element. |
||
3401 | * It cares only about the first axis, you can still have poppers with margin |
||
3402 | * between the popper and its reference element. |
||
3403 | * @memberof modifiers |
||
3404 | * @inner |
||
3405 | */ |
||
3406 | keepTogether: { |
||
3407 | /** @prop {number} order=400 - Index used to define the order of execution */ |
||
3408 | order: 400, |
||
3409 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3410 | enabled: true, |
||
3411 | /** @prop {ModifierFn} */ |
||
3412 | fn: keepTogether |
||
3413 | }, |
||
3414 | |||
3415 | /** |
||
3416 | * This modifier is used to move the `arrowElement` of the popper to make |
||
3417 | * sure it is positioned between the reference element and its popper element. |
||
3418 | * It will read the outer size of the `arrowElement` node to detect how many |
||
3419 | * pixels of conjuction are needed. |
||
3420 | * |
||
3421 | * It has no effect if no `arrowElement` is provided. |
||
3422 | * @memberof modifiers |
||
3423 | * @inner |
||
3424 | */ |
||
3425 | arrow: { |
||
3426 | /** @prop {number} order=500 - Index used to define the order of execution */ |
||
3427 | order: 500, |
||
3428 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3429 | enabled: true, |
||
3430 | /** @prop {ModifierFn} */ |
||
3431 | fn: arrow, |
||
3432 | /** @prop {String|HTMLElement} element='[x-arrow]' - Selector or node used as arrow */ |
||
3433 | element: '[x-arrow]' |
||
3434 | }, |
||
3435 | |||
3436 | /** |
||
3437 | * Modifier used to flip the popper's placement when it starts to overlap its |
||
3438 | * reference element. |
||
3439 | * |
||
3440 | * Requires the `preventOverflow` modifier before it in order to work. |
||
3441 | * |
||
3442 | * **NOTE:** this modifier will interrupt the current update cycle and will |
||
3443 | * restart it if it detects the need to flip the placement. |
||
3444 | * @memberof modifiers |
||
3445 | * @inner |
||
3446 | */ |
||
3447 | flip: { |
||
3448 | /** @prop {number} order=600 - Index used to define the order of execution */ |
||
3449 | order: 600, |
||
3450 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3451 | enabled: true, |
||
3452 | /** @prop {ModifierFn} */ |
||
3453 | fn: flip, |
||
3454 | /** |
||
3455 | * @prop {String|Array} behavior='flip' |
||
3456 | * The behavior used to change the popper's placement. It can be one of |
||
3457 | * `flip`, `clockwise`, `counterclockwise` or an array with a list of valid |
||
3458 | * placements (with optional variations). |
||
3459 | */ |
||
3460 | behavior: 'flip', |
||
3461 | /** |
||
3462 | * @prop {number} padding=5 |
||
3463 | * The popper will flip if it hits the edges of the `boundariesElement` |
||
3464 | */ |
||
3465 | padding: 5, |
||
3466 | /** |
||
3467 | * @prop {String|HTMLElement} boundariesElement='viewport' |
||
3468 | * The element which will define the boundaries of the popper position, |
||
3469 | * the popper will never be placed outside of the defined boundaries |
||
3470 | * (except if keepTogether is enabled) |
||
3471 | */ |
||
3472 | boundariesElement: 'viewport' |
||
3473 | }, |
||
3474 | |||
3475 | /** |
||
3476 | * Modifier used to make the popper flow toward the inner of the reference element. |
||
3477 | * By default, when this modifier is disabled, the popper will be placed outside |
||
3478 | * the reference element. |
||
3479 | * @memberof modifiers |
||
3480 | * @inner |
||
3481 | */ |
||
3482 | inner: { |
||
3483 | /** @prop {number} order=700 - Index used to define the order of execution */ |
||
3484 | order: 700, |
||
3485 | /** @prop {Boolean} enabled=false - Whether the modifier is enabled or not */ |
||
3486 | enabled: false, |
||
3487 | /** @prop {ModifierFn} */ |
||
3488 | fn: inner |
||
3489 | }, |
||
3490 | |||
3491 | /** |
||
3492 | * Modifier used to hide the popper when its reference element is outside of the |
||
3493 | * popper boundaries. It will set a `x-out-of-boundaries` attribute which can |
||
3494 | * be used to hide with a CSS selector the popper when its reference is |
||
3495 | * out of boundaries. |
||
3496 | * |
||
3497 | * Requires the `preventOverflow` modifier before it in order to work. |
||
3498 | * @memberof modifiers |
||
3499 | * @inner |
||
3500 | */ |
||
3501 | hide: { |
||
3502 | /** @prop {number} order=800 - Index used to define the order of execution */ |
||
3503 | order: 800, |
||
3504 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3505 | enabled: true, |
||
3506 | /** @prop {ModifierFn} */ |
||
3507 | fn: hide |
||
3508 | }, |
||
3509 | |||
3510 | /** |
||
3511 | * Computes the style that will be applied to the popper element to gets |
||
3512 | * properly positioned. |
||
3513 | * |
||
3514 | * Note that this modifier will not touch the DOM, it just prepares the styles |
||
3515 | * so that `applyStyle` modifier can apply it. This separation is useful |
||
3516 | * in case you need to replace `applyStyle` with a custom implementation. |
||
3517 | * |
||
3518 | * This modifier has `850` as `order` value to maintain backward compatibility |
||
3519 | * with previous versions of Popper.js. Expect the modifiers ordering method |
||
3520 | * to change in future major versions of the library. |
||
3521 | * |
||
3522 | * @memberof modifiers |
||
3523 | * @inner |
||
3524 | */ |
||
3525 | computeStyle: { |
||
3526 | /** @prop {number} order=850 - Index used to define the order of execution */ |
||
3527 | order: 850, |
||
3528 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3529 | enabled: true, |
||
3530 | /** @prop {ModifierFn} */ |
||
3531 | fn: computeStyle, |
||
3532 | /** |
||
3533 | * @prop {Boolean} gpuAcceleration=true |
||
3534 | * If true, it uses the CSS 3d transformation to position the popper. |
||
3535 | * Otherwise, it will use the `top` and `left` properties. |
||
3536 | */ |
||
3537 | gpuAcceleration: true, |
||
3538 | /** |
||
3539 | * @prop {string} [x='bottom'] |
||
3540 | * Where to anchor the X axis (`bottom` or `top`). AKA X offset origin. |
||
3541 | * Change this if your popper should grow in a direction different from `bottom` |
||
3542 | */ |
||
3543 | x: 'bottom', |
||
3544 | /** |
||
3545 | * @prop {string} [x='left'] |
||
3546 | * Where to anchor the Y axis (`left` or `right`). AKA Y offset origin. |
||
3547 | * Change this if your popper should grow in a direction different from `right` |
||
3548 | */ |
||
3549 | y: 'right' |
||
3550 | }, |
||
3551 | |||
3552 | /** |
||
3553 | * Applies the computed styles to the popper element. |
||
3554 | * |
||
3555 | * All the DOM manipulations are limited to this modifier. This is useful in case |
||
3556 | * you want to integrate Popper.js inside a framework or view library and you |
||
3557 | * want to delegate all the DOM manipulations to it. |
||
3558 | * |
||
3559 | * Note that if you disable this modifier, you must make sure the popper element |
||
3560 | * has its position set to `absolute` before Popper.js can do its work! |
||
3561 | * |
||
3562 | * Just disable this modifier and define you own to achieve the desired effect. |
||
3563 | * |
||
3564 | * @memberof modifiers |
||
3565 | * @inner |
||
3566 | */ |
||
3567 | applyStyle: { |
||
3568 | /** @prop {number} order=900 - Index used to define the order of execution */ |
||
3569 | order: 900, |
||
3570 | /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */ |
||
3571 | enabled: true, |
||
3572 | /** @prop {ModifierFn} */ |
||
3573 | fn: applyStyle, |
||
3574 | /** @prop {Function} */ |
||
3575 | onLoad: applyStyleOnLoad, |
||
3576 | /** |
||
3577 | * @deprecated since version 1.10.0, the property moved to `computeStyle` modifier |
||
3578 | * @prop {Boolean} gpuAcceleration=true |
||
3579 | * If true, it uses the CSS 3d transformation to position the popper. |
||
3580 | * Otherwise, it will use the `top` and `left` properties. |
||
3581 | */ |
||
3582 | gpuAcceleration: undefined |
||
3583 | } |
||
3584 | }; |
||
3585 | |||
3586 | /** |
||
3587 | * The `dataObject` is an object containing all the informations used by Popper.js |
||
3588 | * this object get passed to modifiers and to the `onCreate` and `onUpdate` callbacks. |
||
3589 | * @name dataObject |
||
3590 | * @property {Object} data.instance The Popper.js instance |
||
3591 | * @property {String} data.placement Placement applied to popper |
||
3592 | * @property {String} data.originalPlacement Placement originally defined on init |
||
3593 | * @property {Boolean} data.flipped True if popper has been flipped by flip modifier |
||
3594 | * @property {Boolean} data.hide True if the reference element is out of boundaries, useful to know when to hide the popper. |
||
3595 | * @property {HTMLElement} data.arrowElement Node used as arrow by arrow modifier |
||
3596 | * @property {Object} data.styles Any CSS property defined here will be applied to the popper, it expects the JavaScript nomenclature (eg. `marginBottom`) |
||
3597 | * @property {Object} data.arrowStyles Any CSS property defined here will be applied to the popper arrow, it expects the JavaScript nomenclature (eg. `marginBottom`) |
||
3598 | * @property {Object} data.boundaries Offsets of the popper boundaries |
||
3599 | * @property {Object} data.offsets The measurements of popper, reference and arrow elements. |
||
3600 | * @property {Object} data.offsets.popper `top`, `left`, `width`, `height` values |
||
3601 | * @property {Object} data.offsets.reference `top`, `left`, `width`, `height` values |
||
3602 | * @property {Object} data.offsets.arrow] `top` and `left` offsets, only one of them will be different from 0 |
||
3603 | */ |
||
3604 | |||
3605 | /** |
||
3606 | * Default options provided to Popper.js constructor.<br /> |
||
3607 | * These can be overriden using the `options` argument of Popper.js.<br /> |
||
3608 | * To override an option, simply pass as 3rd argument an object with the same |
||
3609 | * structure of this object, example: |
||
3610 | * ``` |
||
3611 | * new Popper(ref, pop, { |
||
3612 | * modifiers: { |
||
3613 | * preventOverflow: { enabled: false } |
||
3614 | * } |
||
3615 | * }) |
||
3616 | * ``` |
||
3617 | * @type {Object} |
||
3618 | * @static |
||
3619 | * @memberof Popper |
||
3620 | */ |
||
3621 | var Defaults = { |
||
3622 | /** |
||
3623 | * Popper's placement |
||
3624 | * @prop {Popper.placements} placement='bottom' |
||
3625 | */ |
||
3626 | placement: 'bottom', |
||
3627 | |||
3628 | /** |
||
3629 | * Whether events (resize, scroll) are initially enabled |
||
3630 | * @prop {Boolean} eventsEnabled=true |
||
3631 | */ |
||
3632 | eventsEnabled: true, |
||
3633 | |||
3634 | /** |
||
3635 | * Set to true if you want to automatically remove the popper when |
||
3636 | * you call the `destroy` method. |
||
3637 | * @prop {Boolean} removeOnDestroy=false |
||
3638 | */ |
||
3639 | removeOnDestroy: false, |
||
3640 | |||
3641 | /** |
||
3642 | * Callback called when the popper is created.<br /> |
||
3643 | * By default, is set to no-op.<br /> |
||
3644 | * Access Popper.js instance with `data.instance`. |
||
3645 | * @prop {onCreate} |
||
3646 | */ |
||
3647 | onCreate: function onCreate() {}, |
||
3648 | |||
3649 | /** |
||
3650 | * Callback called when the popper is updated, this callback is not called |
||
3651 | * on the initialization/creation of the popper, but only on subsequent |
||
3652 | * updates.<br /> |
||
3653 | * By default, is set to no-op.<br /> |
||
3654 | * Access Popper.js instance with `data.instance`. |
||
3655 | * @prop {onUpdate} |
||
3656 | */ |
||
3657 | onUpdate: function onUpdate() {}, |
||
3658 | |||
3659 | /** |
||
3660 | * List of modifiers used to modify the offsets before they are applied to the popper. |
||
3661 | * They provide most of the functionalities of Popper.js |
||
3662 | * @prop {modifiers} |
||
3663 | */ |
||
3664 | modifiers: modifiers |
||
3665 | }; |
||
3666 | |||
3667 | /** |
||
3668 | * @callback onCreate |
||
3669 | * @param {dataObject} data |
||
3670 | */ |
||
3671 | |||
3672 | /** |
||
3673 | * @callback onUpdate |
||
3674 | * @param {dataObject} data |
||
3675 | */ |
||
3676 | |||
3677 | // Utils |
||
3678 | // Methods |
||
3679 | var Popper = function () { |
||
3680 | /** |
||
3681 | * Create a new Popper.js instance |
||
3682 | * @class Popper |
||
3683 | * @param {HTMLElement|referenceObject} reference - The reference element used to position the popper |
||
3684 | * @param {HTMLElement} popper - The HTML element used as popper. |
||
3685 | * @param {Object} options - Your custom options to override the ones defined in [Defaults](#defaults) |
||
3686 | * @return {Object} instance - The generated Popper.js instance |
||
3687 | */ |
||
3688 | function Popper(reference, popper) { |
||
3689 | var _this = this; |
||
3690 | |||
3691 | var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; |
||
3692 | classCallCheck(this, Popper); |
||
3693 | |||
3694 | this.scheduleUpdate = function () { |
||
3695 | return requestAnimationFrame(_this.update); |
||
3696 | }; |
||
3697 | |||
3698 | // make update() debounced, so that it only runs at most once-per-tick |
||
3699 | this.update = debounce(this.update.bind(this)); |
||
3700 | |||
3701 | // with {} we create a new object with the options inside it |
||
3702 | this.options = _extends$1({}, Popper.Defaults, options); |
||
3703 | |||
3704 | // init state |
||
3705 | this.state = { |
||
3706 | isDestroyed: false, |
||
3707 | isCreated: false, |
||
3708 | scrollParents: [] |
||
3709 | }; |
||
3710 | |||
3711 | // get reference and popper elements (allow jQuery wrappers) |
||
3712 | this.reference = reference && reference.jquery ? reference[0] : reference; |
||
3713 | this.popper = popper && popper.jquery ? popper[0] : popper; |
||
3714 | |||
3715 | // Deep merge modifiers options |
||
3716 | this.options.modifiers = {}; |
||
3717 | Object.keys(_extends$1({}, Popper.Defaults.modifiers, options.modifiers)).forEach(function (name) { |
||
3718 | _this.options.modifiers[name] = _extends$1({}, Popper.Defaults.modifiers[name] || {}, options.modifiers ? options.modifiers[name] : {}); |
||
3719 | }); |
||
3720 | |||
3721 | // Refactoring modifiers' list (Object => Array) |
||
3722 | this.modifiers = Object.keys(this.options.modifiers).map(function (name) { |
||
3723 | return _extends$1({ |
||
3724 | name: name |
||
3725 | }, _this.options.modifiers[name]); |
||
3726 | }) |
||
3727 | // sort the modifiers by order |
||
3728 | .sort(function (a, b) { |
||
3729 | return a.order - b.order; |
||
3730 | }); |
||
3731 | |||
3732 | // modifiers have the ability to execute arbitrary code when Popper.js get inited |
||
3733 | // such code is executed in the same order of its modifier |
||
3734 | // they could add new properties to their options configuration |
||
3735 | // BE AWARE: don't add options to `options.modifiers.name` but to `modifierOptions`! |
||
3736 | this.modifiers.forEach(function (modifierOptions) { |
||
3737 | if (modifierOptions.enabled && isFunction(modifierOptions.onLoad)) { |
||
3738 | modifierOptions.onLoad(_this.reference, _this.popper, _this.options, modifierOptions, _this.state); |
||
3739 | } |
||
3740 | }); |
||
3741 | |||
3742 | // fire the first update to position the popper in the right place |
||
3743 | this.update(); |
||
3744 | |||
3745 | var eventsEnabled = this.options.eventsEnabled; |
||
3746 | if (eventsEnabled) { |
||
3747 | // setup event listeners, they will take care of update the position in specific situations |
||
3748 | this.enableEventListeners(); |
||
3749 | } |
||
3750 | |||
3751 | this.state.eventsEnabled = eventsEnabled; |
||
3752 | } |
||
3753 | |||
3754 | // We can't use class properties because they don't get listed in the |
||
3755 | // class prototype and break stuff like Sinon stubs |
||
3756 | |||
3757 | |||
3758 | createClass(Popper, [{ |
||
3759 | key: 'update', |
||
3760 | value: function update$$1() { |
||
3761 | return update.call(this); |
||
3762 | } |
||
3763 | }, { |
||
3764 | key: 'destroy', |
||
3765 | value: function destroy$$1() { |
||
3766 | return destroy.call(this); |
||
3767 | } |
||
3768 | }, { |
||
3769 | key: 'enableEventListeners', |
||
3770 | value: function enableEventListeners$$1() { |
||
3771 | return enableEventListeners.call(this); |
||
3772 | } |
||
3773 | }, { |
||
3774 | key: 'disableEventListeners', |
||
3775 | value: function disableEventListeners$$1() { |
||
3776 | return disableEventListeners.call(this); |
||
3777 | } |
||
3778 | |||
3779 | /** |
||
3780 | * Schedule an update, it will run on the next UI update available |
||
3781 | * @method scheduleUpdate |
||
3782 | * @memberof Popper |
||
3783 | */ |
||
3784 | |||
3785 | |||
3786 | /** |
||
3787 | * Collection of utilities useful when writing custom modifiers. |
||
3788 | * Starting from version 1.7, this method is available only if you |
||
3789 | * include `popper-utils.js` before `popper.js`. |
||
3790 | * |
||
3791 | * **DEPRECATION**: This way to access PopperUtils is deprecated |
||
3792 | * and will be removed in v2! Use the PopperUtils module directly instead. |
||
3793 | * Due to the high instability of the methods contained in Utils, we can't |
||
3794 | * guarantee them to follow semver. Use them at your own risk! |
||
3795 | * @static |
||
3796 | * @private |
||
3797 | * @type {Object} |
||
3798 | * @deprecated since version 1.8 |
||
3799 | * @member Utils |
||
3800 | * @memberof Popper |
||
3801 | */ |
||
3802 | |||
3803 | }]); |
||
3804 | return Popper; |
||
3805 | }(); |
||
3806 | |||
3807 | /** |
||
3808 | * The `referenceObject` is an object that provides an interface compatible with Popper.js |
||
3809 | * and lets you use it as replacement of a real DOM node.<br /> |
||
3810 | * You can use this method to position a popper relatively to a set of coordinates |
||
3811 | * in case you don't have a DOM node to use as reference. |
||
3812 | * |
||
3813 | * ``` |
||
3814 | * new Popper(referenceObject, popperNode); |
||
3815 | * ``` |
||
3816 | * |
||
3817 | * NB: This feature isn't supported in Internet Explorer 10 |
||
3818 | * @name referenceObject |
||
3819 | * @property {Function} data.getBoundingClientRect |
||
3820 | * A function that returns a set of coordinates compatible with the native `getBoundingClientRect` method. |
||
3821 | * @property {number} data.clientWidth |
||
3822 | * An ES6 getter that will return the width of the virtual reference element. |
||
3823 | * @property {number} data.clientHeight |
||
3824 | * An ES6 getter that will return the height of the virtual reference element. |
||
3825 | */ |
||
3826 | |||
3827 | |||
3828 | Popper.Utils = (typeof window !== 'undefined' ? window : global).PopperUtils; |
||
3829 | Popper.placements = placements; |
||
3830 | Popper.Defaults = Defaults; |
||
3831 | |||
3832 | /** |
||
3833 | * -------------------------------------------------------------------------- |
||
3834 | * Bootstrap (v4.0.0): dropdown.js |
||
3835 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
3836 | * -------------------------------------------------------------------------- |
||
3837 | */ |
||
3838 | |||
3839 | var Dropdown = function ($$$1) { |
||
3840 | /** |
||
3841 | * ------------------------------------------------------------------------ |
||
3842 | * Constants |
||
3843 | * ------------------------------------------------------------------------ |
||
3844 | */ |
||
3845 | var NAME = 'dropdown'; |
||
3846 | var VERSION = '4.0.0'; |
||
3847 | var DATA_KEY = 'bs.dropdown'; |
||
3848 | var EVENT_KEY = "." + DATA_KEY; |
||
3849 | var DATA_API_KEY = '.data-api'; |
||
3850 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
3851 | var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key |
||
3852 | |||
3853 | var SPACE_KEYCODE = 32; // KeyboardEvent.which value for space key |
||
3854 | |||
3855 | var TAB_KEYCODE = 9; // KeyboardEvent.which value for tab key |
||
3856 | |||
3857 | var ARROW_UP_KEYCODE = 38; // KeyboardEvent.which value for up arrow key |
||
3858 | |||
3859 | var ARROW_DOWN_KEYCODE = 40; // KeyboardEvent.which value for down arrow key |
||
3860 | |||
3861 | var RIGHT_MOUSE_BUTTON_WHICH = 3; // MouseEvent.which value for the right button (assuming a right-handed mouse) |
||
3862 | |||
3863 | var REGEXP_KEYDOWN = new RegExp(ARROW_UP_KEYCODE + "|" + ARROW_DOWN_KEYCODE + "|" + ESCAPE_KEYCODE); |
||
3864 | var Event = { |
||
3865 | HIDE: "hide" + EVENT_KEY, |
||
3866 | HIDDEN: "hidden" + EVENT_KEY, |
||
3867 | SHOW: "show" + EVENT_KEY, |
||
3868 | SHOWN: "shown" + EVENT_KEY, |
||
3869 | CLICK: "click" + EVENT_KEY, |
||
3870 | CLICK_DATA_API: "click" + EVENT_KEY + DATA_API_KEY, |
||
3871 | KEYDOWN_DATA_API: "keydown" + EVENT_KEY + DATA_API_KEY, |
||
3872 | KEYUP_DATA_API: "keyup" + EVENT_KEY + DATA_API_KEY |
||
3873 | }; |
||
3874 | var ClassName = { |
||
3875 | DISABLED: 'disabled', |
||
3876 | SHOW: 'show', |
||
3877 | DROPUP: 'dropup', |
||
3878 | DROPRIGHT: 'dropright', |
||
3879 | DROPLEFT: 'dropleft', |
||
3880 | MENURIGHT: 'dropdown-menu-right', |
||
3881 | MENULEFT: 'dropdown-menu-left', |
||
3882 | POSITION_STATIC: 'position-static' |
||
3883 | }; |
||
3884 | var Selector = { |
||
3885 | DATA_TOGGLE: '[data-toggle="dropdown"]', |
||
3886 | FORM_CHILD: '.dropdown form', |
||
3887 | MENU: '.dropdown-menu', |
||
3888 | NAVBAR_NAV: '.navbar-nav', |
||
3889 | VISIBLE_ITEMS: '.dropdown-menu .dropdown-item:not(.disabled)' |
||
3890 | }; |
||
3891 | var AttachmentMap = { |
||
3892 | TOP: 'top-start', |
||
3893 | TOPEND: 'top-end', |
||
3894 | BOTTOM: 'bottom-start', |
||
3895 | BOTTOMEND: 'bottom-end', |
||
3896 | RIGHT: 'right-start', |
||
3897 | RIGHTEND: 'right-end', |
||
3898 | LEFT: 'left-start', |
||
3899 | LEFTEND: 'left-end' |
||
3900 | }; |
||
3901 | var Default = { |
||
3902 | offset: 0, |
||
3903 | flip: true, |
||
3904 | boundary: 'scrollParent' |
||
3905 | }; |
||
3906 | var DefaultType = { |
||
3907 | offset: '(number|string|function)', |
||
3908 | flip: 'boolean', |
||
3909 | boundary: '(string|element)' |
||
3910 | /** |
||
3911 | * ------------------------------------------------------------------------ |
||
3912 | * Class Definition |
||
3913 | * ------------------------------------------------------------------------ |
||
3914 | */ |
||
3915 | |||
3916 | }; |
||
3917 | |||
3918 | var Dropdown = |
||
3919 | /*#__PURE__*/ |
||
3920 | function () { |
||
3921 | function Dropdown(element, config) { |
||
3922 | this._element = element; |
||
3923 | this._popper = null; |
||
3924 | this._config = this._getConfig(config); |
||
3925 | this._menu = this._getMenuElement(); |
||
3926 | this._inNavbar = this._detectNavbar(); |
||
3927 | |||
3928 | this._addEventListeners(); |
||
3929 | } // Getters |
||
3930 | |||
3931 | |||
3932 | var _proto = Dropdown.prototype; |
||
3933 | |||
3934 | // Public |
||
3935 | _proto.toggle = function toggle() { |
||
3936 | if (this._element.disabled || $$$1(this._element).hasClass(ClassName.DISABLED)) { |
||
3937 | return; |
||
3938 | } |
||
3939 | |||
3940 | var parent = Dropdown._getParentFromElement(this._element); |
||
3941 | |||
3942 | var isActive = $$$1(this._menu).hasClass(ClassName.SHOW); |
||
3943 | |||
3944 | Dropdown._clearMenus(); |
||
3945 | |||
3946 | if (isActive) { |
||
3947 | return; |
||
3948 | } |
||
3949 | |||
3950 | var relatedTarget = { |
||
3951 | relatedTarget: this._element |
||
3952 | }; |
||
3953 | var showEvent = $$$1.Event(Event.SHOW, relatedTarget); |
||
3954 | $$$1(parent).trigger(showEvent); |
||
3955 | |||
3956 | if (showEvent.isDefaultPrevented()) { |
||
3957 | return; |
||
3958 | } // Disable totally Popper.js for Dropdown in Navbar |
||
3959 | |||
3960 | |||
3961 | if (!this._inNavbar) { |
||
3962 | /** |
||
3963 | * Check for Popper dependency |
||
3964 | * Popper - https://popper.js.org |
||
3965 | */ |
||
3966 | if (typeof Popper === 'undefined') { |
||
3967 | throw new TypeError('Bootstrap dropdown require Popper.js (https://popper.js.org)'); |
||
3968 | } |
||
3969 | |||
3970 | var element = this._element; // For dropup with alignment we use the parent as popper container |
||
3971 | |||
3972 | if ($$$1(parent).hasClass(ClassName.DROPUP)) { |
||
3973 | if ($$$1(this._menu).hasClass(ClassName.MENULEFT) || $$$1(this._menu).hasClass(ClassName.MENURIGHT)) { |
||
3974 | element = parent; |
||
3975 | } |
||
3976 | } // If boundary is not `scrollParent`, then set position to `static` |
||
3977 | // to allow the menu to "escape" the scroll parent's boundaries |
||
3978 | // https://github.com/twbs/bootstrap/issues/24251 |
||
3979 | |||
3980 | |||
3981 | if (this._config.boundary !== 'scrollParent') { |
||
3982 | $$$1(parent).addClass(ClassName.POSITION_STATIC); |
||
3983 | } |
||
3984 | |||
3985 | this._popper = new Popper(element, this._menu, this._getPopperConfig()); |
||
3986 | } // If this is a touch-enabled device we add extra |
||
3987 | // empty mouseover listeners to the body's immediate children; |
||
3988 | // only needed because of broken event delegation on iOS |
||
3989 | // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html |
||
3990 | |||
3991 | |||
3992 | if ('ontouchstart' in document.documentElement && $$$1(parent).closest(Selector.NAVBAR_NAV).length === 0) { |
||
3993 | $$$1('body').children().on('mouseover', null, $$$1.noop); |
||
3994 | } |
||
3995 | |||
3996 | this._element.focus(); |
||
3997 | |||
3998 | this._element.setAttribute('aria-expanded', true); |
||
3999 | |||
4000 | $$$1(this._menu).toggleClass(ClassName.SHOW); |
||
4001 | $$$1(parent).toggleClass(ClassName.SHOW).trigger($$$1.Event(Event.SHOWN, relatedTarget)); |
||
4002 | }; |
||
4003 | |||
4004 | _proto.dispose = function dispose() { |
||
4005 | $$$1.removeData(this._element, DATA_KEY); |
||
4006 | $$$1(this._element).off(EVENT_KEY); |
||
4007 | this._element = null; |
||
4008 | this._menu = null; |
||
4009 | |||
4010 | if (this._popper !== null) { |
||
4011 | this._popper.destroy(); |
||
4012 | |||
4013 | this._popper = null; |
||
4014 | } |
||
4015 | }; |
||
4016 | |||
4017 | _proto.update = function update() { |
||
4018 | this._inNavbar = this._detectNavbar(); |
||
4019 | |||
4020 | if (this._popper !== null) { |
||
4021 | this._popper.scheduleUpdate(); |
||
4022 | } |
||
4023 | }; // Private |
||
4024 | |||
4025 | |||
4026 | _proto._addEventListeners = function _addEventListeners() { |
||
4027 | var _this = this; |
||
4028 | |||
4029 | $$$1(this._element).on(Event.CLICK, function (event) { |
||
4030 | event.preventDefault(); |
||
4031 | event.stopPropagation(); |
||
4032 | |||
4033 | _this.toggle(); |
||
4034 | }); |
||
4035 | }; |
||
4036 | |||
4037 | _proto._getConfig = function _getConfig(config) { |
||
4038 | config = _extends({}, this.constructor.Default, $$$1(this._element).data(), config); |
||
4039 | Util.typeCheckConfig(NAME, config, this.constructor.DefaultType); |
||
4040 | return config; |
||
4041 | }; |
||
4042 | |||
4043 | _proto._getMenuElement = function _getMenuElement() { |
||
4044 | if (!this._menu) { |
||
4045 | var parent = Dropdown._getParentFromElement(this._element); |
||
4046 | |||
4047 | this._menu = $$$1(parent).find(Selector.MENU)[0]; |
||
4048 | } |
||
4049 | |||
4050 | return this._menu; |
||
4051 | }; |
||
4052 | |||
4053 | _proto._getPlacement = function _getPlacement() { |
||
4054 | var $parentDropdown = $$$1(this._element).parent(); |
||
4055 | var placement = AttachmentMap.BOTTOM; // Handle dropup |
||
4056 | |||
4057 | if ($parentDropdown.hasClass(ClassName.DROPUP)) { |
||
4058 | placement = AttachmentMap.TOP; |
||
4059 | |||
4060 | if ($$$1(this._menu).hasClass(ClassName.MENURIGHT)) { |
||
4061 | placement = AttachmentMap.TOPEND; |
||
4062 | } |
||
4063 | } else if ($parentDropdown.hasClass(ClassName.DROPRIGHT)) { |
||
4064 | placement = AttachmentMap.RIGHT; |
||
4065 | } else if ($parentDropdown.hasClass(ClassName.DROPLEFT)) { |
||
4066 | placement = AttachmentMap.LEFT; |
||
4067 | } else if ($$$1(this._menu).hasClass(ClassName.MENURIGHT)) { |
||
4068 | placement = AttachmentMap.BOTTOMEND; |
||
4069 | } |
||
4070 | |||
4071 | return placement; |
||
4072 | }; |
||
4073 | |||
4074 | _proto._detectNavbar = function _detectNavbar() { |
||
4075 | return $$$1(this._element).closest('.navbar').length > 0; |
||
4076 | }; |
||
4077 | |||
4078 | _proto._getPopperConfig = function _getPopperConfig() { |
||
4079 | var _this2 = this; |
||
4080 | |||
4081 | var offsetConf = {}; |
||
4082 | |||
4083 | if (typeof this._config.offset === 'function') { |
||
4084 | offsetConf.fn = function (data) { |
||
4085 | data.offsets = _extends({}, data.offsets, _this2._config.offset(data.offsets) || {}); |
||
4086 | return data; |
||
4087 | }; |
||
4088 | } else { |
||
4089 | offsetConf.offset = this._config.offset; |
||
4090 | } |
||
4091 | |||
4092 | var popperConfig = { |
||
4093 | placement: this._getPlacement(), |
||
4094 | modifiers: { |
||
4095 | offset: offsetConf, |
||
4096 | flip: { |
||
4097 | enabled: this._config.flip |
||
4098 | }, |
||
4099 | preventOverflow: { |
||
4100 | boundariesElement: this._config.boundary |
||
4101 | } |
||
4102 | } |
||
4103 | }; |
||
4104 | return popperConfig; |
||
4105 | }; // Static |
||
4106 | |||
4107 | |||
4108 | Dropdown._jQueryInterface = function _jQueryInterface(config) { |
||
4109 | return this.each(function () { |
||
4110 | var data = $$$1(this).data(DATA_KEY); |
||
4111 | |||
4112 | var _config = typeof config === 'object' ? config : null; |
||
4113 | |||
4114 | if (!data) { |
||
4115 | data = new Dropdown(this, _config); |
||
4116 | $$$1(this).data(DATA_KEY, data); |
||
4117 | } |
||
4118 | |||
4119 | if (typeof config === 'string') { |
||
4120 | if (typeof data[config] === 'undefined') { |
||
4121 | throw new TypeError("No method named \"" + config + "\""); |
||
4122 | } |
||
4123 | |||
4124 | data[config](); |
||
4125 | } |
||
4126 | }); |
||
4127 | }; |
||
4128 | |||
4129 | Dropdown._clearMenus = function _clearMenus(event) { |
||
4130 | if (event && (event.which === RIGHT_MOUSE_BUTTON_WHICH || event.type === 'keyup' && event.which !== TAB_KEYCODE)) { |
||
4131 | return; |
||
4132 | } |
||
4133 | |||
4134 | var toggles = $$$1.makeArray($$$1(Selector.DATA_TOGGLE)); |
||
4135 | |||
4136 | for (var i = 0; i < toggles.length; i++) { |
||
4137 | var parent = Dropdown._getParentFromElement(toggles[i]); |
||
4138 | |||
4139 | var context = $$$1(toggles[i]).data(DATA_KEY); |
||
4140 | var relatedTarget = { |
||
4141 | relatedTarget: toggles[i] |
||
4142 | }; |
||
4143 | |||
4144 | if (!context) { |
||
4145 | continue; |
||
4146 | } |
||
4147 | |||
4148 | var dropdownMenu = context._menu; |
||
4149 | |||
4150 | if (!$$$1(parent).hasClass(ClassName.SHOW)) { |
||
4151 | continue; |
||
4152 | } |
||
4153 | |||
4154 | if (event && (event.type === 'click' && /input|textarea/i.test(event.target.tagName) || event.type === 'keyup' && event.which === TAB_KEYCODE) && $$$1.contains(parent, event.target)) { |
||
4155 | continue; |
||
4156 | } |
||
4157 | |||
4158 | var hideEvent = $$$1.Event(Event.HIDE, relatedTarget); |
||
4159 | $$$1(parent).trigger(hideEvent); |
||
4160 | |||
4161 | if (hideEvent.isDefaultPrevented()) { |
||
4162 | continue; |
||
4163 | } // If this is a touch-enabled device we remove the extra |
||
4164 | // empty mouseover listeners we added for iOS support |
||
4165 | |||
4166 | |||
4167 | if ('ontouchstart' in document.documentElement) { |
||
4168 | $$$1('body').children().off('mouseover', null, $$$1.noop); |
||
4169 | } |
||
4170 | |||
4171 | toggles[i].setAttribute('aria-expanded', 'false'); |
||
4172 | $$$1(dropdownMenu).removeClass(ClassName.SHOW); |
||
4173 | $$$1(parent).removeClass(ClassName.SHOW).trigger($$$1.Event(Event.HIDDEN, relatedTarget)); |
||
4174 | } |
||
4175 | }; |
||
4176 | |||
4177 | Dropdown._getParentFromElement = function _getParentFromElement(element) { |
||
4178 | var parent; |
||
4179 | var selector = Util.getSelectorFromElement(element); |
||
4180 | |||
4181 | if (selector) { |
||
4182 | parent = $$$1(selector)[0]; |
||
4183 | } |
||
4184 | |||
4185 | return parent || element.parentNode; |
||
4186 | }; // eslint-disable-next-line complexity |
||
4187 | |||
4188 | |||
4189 | Dropdown._dataApiKeydownHandler = function _dataApiKeydownHandler(event) { |
||
4190 | // If not input/textarea: |
||
4191 | // - And not a key in REGEXP_KEYDOWN => not a dropdown command |
||
4192 | // If input/textarea: |
||
4193 | // - If space key => not a dropdown command |
||
4194 | // - If key is other than escape |
||
4195 | // - If key is not up or down => not a dropdown command |
||
4196 | // - If trigger inside the menu => not a dropdown command |
||
4197 | 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 || $$$1(event.target).closest(Selector.MENU).length) : !REGEXP_KEYDOWN.test(event.which)) { |
||
4198 | return; |
||
4199 | } |
||
4200 | |||
4201 | event.preventDefault(); |
||
4202 | event.stopPropagation(); |
||
4203 | |||
4204 | if (this.disabled || $$$1(this).hasClass(ClassName.DISABLED)) { |
||
4205 | return; |
||
4206 | } |
||
4207 | |||
4208 | var parent = Dropdown._getParentFromElement(this); |
||
4209 | |||
4210 | var isActive = $$$1(parent).hasClass(ClassName.SHOW); |
||
4211 | |||
4212 | if (!isActive && (event.which !== ESCAPE_KEYCODE || event.which !== SPACE_KEYCODE) || isActive && (event.which === ESCAPE_KEYCODE || event.which === SPACE_KEYCODE)) { |
||
4213 | if (event.which === ESCAPE_KEYCODE) { |
||
4214 | var toggle = $$$1(parent).find(Selector.DATA_TOGGLE)[0]; |
||
4215 | $$$1(toggle).trigger('focus'); |
||
4216 | } |
||
4217 | |||
4218 | $$$1(this).trigger('click'); |
||
4219 | return; |
||
4220 | } |
||
4221 | |||
4222 | var items = $$$1(parent).find(Selector.VISIBLE_ITEMS).get(); |
||
4223 | |||
4224 | if (items.length === 0) { |
||
4225 | return; |
||
4226 | } |
||
4227 | |||
4228 | var index = items.indexOf(event.target); |
||
4229 | |||
4230 | if (event.which === ARROW_UP_KEYCODE && index > 0) { |
||
4231 | // Up |
||
4232 | index--; |
||
4233 | } |
||
4234 | |||
4235 | if (event.which === ARROW_DOWN_KEYCODE && index < items.length - 1) { |
||
4236 | // Down |
||
4237 | index++; |
||
4238 | } |
||
4239 | |||
4240 | if (index < 0) { |
||
4241 | index = 0; |
||
4242 | } |
||
4243 | |||
4244 | items[index].focus(); |
||
4245 | }; |
||
4246 | |||
4247 | _createClass(Dropdown, null, [{ |
||
4248 | key: "VERSION", |
||
4249 | get: function get() { |
||
4250 | return VERSION; |
||
4251 | } |
||
4252 | }, { |
||
4253 | key: "Default", |
||
4254 | get: function get() { |
||
4255 | return Default; |
||
4256 | } |
||
4257 | }, { |
||
4258 | key: "DefaultType", |
||
4259 | get: function get() { |
||
4260 | return DefaultType; |
||
4261 | } |
||
4262 | }]); |
||
4263 | return Dropdown; |
||
4264 | }(); |
||
4265 | /** |
||
4266 | * ------------------------------------------------------------------------ |
||
4267 | * Data Api implementation |
||
4268 | * ------------------------------------------------------------------------ |
||
4269 | */ |
||
4270 | |||
4271 | |||
4272 | $$$1(document).on(Event.KEYDOWN_DATA_API, Selector.DATA_TOGGLE, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.MENU, Dropdown._dataApiKeydownHandler).on(Event.CLICK_DATA_API + " " + Event.KEYUP_DATA_API, Dropdown._clearMenus).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) { |
||
4273 | event.preventDefault(); |
||
4274 | event.stopPropagation(); |
||
4275 | |||
4276 | Dropdown._jQueryInterface.call($$$1(this), 'toggle'); |
||
4277 | }).on(Event.CLICK_DATA_API, Selector.FORM_CHILD, function (e) { |
||
4278 | e.stopPropagation(); |
||
4279 | }); |
||
4280 | /** |
||
4281 | * ------------------------------------------------------------------------ |
||
4282 | * jQuery |
||
4283 | * ------------------------------------------------------------------------ |
||
4284 | */ |
||
4285 | |||
4286 | $$$1.fn[NAME] = Dropdown._jQueryInterface; |
||
4287 | $$$1.fn[NAME].Constructor = Dropdown; |
||
4288 | |||
4289 | $$$1.fn[NAME].noConflict = function () { |
||
4290 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
4291 | return Dropdown._jQueryInterface; |
||
4292 | }; |
||
4293 | |||
4294 | return Dropdown; |
||
4295 | }($, Popper); |
||
4296 | |||
4297 | /** |
||
4298 | * -------------------------------------------------------------------------- |
||
4299 | * Bootstrap (v4.0.0): modal.js |
||
4300 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
4301 | * -------------------------------------------------------------------------- |
||
4302 | */ |
||
4303 | |||
4304 | var Modal = function ($$$1) { |
||
4305 | /** |
||
4306 | * ------------------------------------------------------------------------ |
||
4307 | * Constants |
||
4308 | * ------------------------------------------------------------------------ |
||
4309 | */ |
||
4310 | var NAME = 'modal'; |
||
4311 | var VERSION = '4.0.0'; |
||
4312 | var DATA_KEY = 'bs.modal'; |
||
4313 | var EVENT_KEY = "." + DATA_KEY; |
||
4314 | var DATA_API_KEY = '.data-api'; |
||
4315 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
4316 | var TRANSITION_DURATION = 300; |
||
4317 | var BACKDROP_TRANSITION_DURATION = 150; |
||
4318 | var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key |
||
4319 | |||
4320 | var Default = { |
||
4321 | backdrop: true, |
||
4322 | keyboard: true, |
||
4323 | focus: true, |
||
4324 | show: true |
||
4325 | }; |
||
4326 | var DefaultType = { |
||
4327 | backdrop: '(boolean|string)', |
||
4328 | keyboard: 'boolean', |
||
4329 | focus: 'boolean', |
||
4330 | show: 'boolean' |
||
4331 | }; |
||
4332 | var Event = { |
||
4333 | HIDE: "hide" + EVENT_KEY, |
||
4334 | HIDDEN: "hidden" + EVENT_KEY, |
||
4335 | SHOW: "show" + EVENT_KEY, |
||
4336 | SHOWN: "shown" + EVENT_KEY, |
||
4337 | FOCUSIN: "focusin" + EVENT_KEY, |
||
4338 | RESIZE: "resize" + EVENT_KEY, |
||
4339 | CLICK_DISMISS: "click.dismiss" + EVENT_KEY, |
||
4340 | KEYDOWN_DISMISS: "keydown.dismiss" + EVENT_KEY, |
||
4341 | MOUSEUP_DISMISS: "mouseup.dismiss" + EVENT_KEY, |
||
4342 | MOUSEDOWN_DISMISS: "mousedown.dismiss" + EVENT_KEY, |
||
4343 | CLICK_DATA_API: "click" + EVENT_KEY + DATA_API_KEY |
||
4344 | }; |
||
4345 | var ClassName = { |
||
4346 | SCROLLBAR_MEASURER: 'modal-scrollbar-measure', |
||
4347 | BACKDROP: 'modal-backdrop', |
||
4348 | OPEN: 'modal-open', |
||
4349 | FADE: 'fade', |
||
4350 | SHOW: 'show' |
||
4351 | }; |
||
4352 | var Selector = { |
||
4353 | DIALOG: '.modal-dialog', |
||
4354 | DATA_TOGGLE: '[data-toggle="modal"]', |
||
4355 | DATA_DISMISS: '[data-dismiss="modal"]', |
||
4356 | FIXED_CONTENT: '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top', |
||
4357 | STICKY_CONTENT: '.sticky-top', |
||
4358 | NAVBAR_TOGGLER: '.navbar-toggler' |
||
4359 | /** |
||
4360 | * ------------------------------------------------------------------------ |
||
4361 | * Class Definition |
||
4362 | * ------------------------------------------------------------------------ |
||
4363 | */ |
||
4364 | |||
4365 | }; |
||
4366 | |||
4367 | var Modal = |
||
4368 | /*#__PURE__*/ |
||
4369 | function () { |
||
4370 | function Modal(element, config) { |
||
4371 | this._config = this._getConfig(config); |
||
4372 | this._element = element; |
||
4373 | this._dialog = $$$1(element).find(Selector.DIALOG)[0]; |
||
4374 | this._backdrop = null; |
||
4375 | this._isShown = false; |
||
4376 | this._isBodyOverflowing = false; |
||
4377 | this._ignoreBackdropClick = false; |
||
4378 | this._originalBodyPadding = 0; |
||
4379 | this._scrollbarWidth = 0; |
||
4380 | } // Getters |
||
4381 | |||
4382 | |||
4383 | var _proto = Modal.prototype; |
||
4384 | |||
4385 | // Public |
||
4386 | _proto.toggle = function toggle(relatedTarget) { |
||
4387 | return this._isShown ? this.hide() : this.show(relatedTarget); |
||
4388 | }; |
||
4389 | |||
4390 | _proto.show = function show(relatedTarget) { |
||
4391 | var _this = this; |
||
4392 | |||
4393 | if (this._isTransitioning || this._isShown) { |
||
4394 | return; |
||
4395 | } |
||
4396 | |||
4397 | if (Util.supportsTransitionEnd() && $$$1(this._element).hasClass(ClassName.FADE)) { |
||
4398 | this._isTransitioning = true; |
||
4399 | } |
||
4400 | |||
4401 | var showEvent = $$$1.Event(Event.SHOW, { |
||
4402 | relatedTarget: relatedTarget |
||
4403 | }); |
||
4404 | $$$1(this._element).trigger(showEvent); |
||
4405 | |||
4406 | if (this._isShown || showEvent.isDefaultPrevented()) { |
||
4407 | return; |
||
4408 | } |
||
4409 | |||
4410 | this._isShown = true; |
||
4411 | |||
4412 | this._checkScrollbar(); |
||
4413 | |||
4414 | this._setScrollbar(); |
||
4415 | |||
4416 | this._adjustDialog(); |
||
4417 | |||
4418 | $$$1(document.body).addClass(ClassName.OPEN); |
||
4419 | |||
4420 | this._setEscapeEvent(); |
||
4421 | |||
4422 | this._setResizeEvent(); |
||
4423 | |||
4424 | $$$1(this._element).on(Event.CLICK_DISMISS, Selector.DATA_DISMISS, function (event) { |
||
4425 | return _this.hide(event); |
||
4426 | }); |
||
4427 | $$$1(this._dialog).on(Event.MOUSEDOWN_DISMISS, function () { |
||
4428 | $$$1(_this._element).one(Event.MOUSEUP_DISMISS, function (event) { |
||
4429 | if ($$$1(event.target).is(_this._element)) { |
||
4430 | _this._ignoreBackdropClick = true; |
||
4431 | } |
||
4432 | }); |
||
4433 | }); |
||
4434 | |||
4435 | this._showBackdrop(function () { |
||
4436 | return _this._showElement(relatedTarget); |
||
4437 | }); |
||
4438 | }; |
||
4439 | |||
4440 | _proto.hide = function hide(event) { |
||
4441 | var _this2 = this; |
||
4442 | |||
4443 | if (event) { |
||
4444 | event.preventDefault(); |
||
4445 | } |
||
4446 | |||
4447 | if (this._isTransitioning || !this._isShown) { |
||
4448 | return; |
||
4449 | } |
||
4450 | |||
4451 | var hideEvent = $$$1.Event(Event.HIDE); |
||
4452 | $$$1(this._element).trigger(hideEvent); |
||
4453 | |||
4454 | if (!this._isShown || hideEvent.isDefaultPrevented()) { |
||
4455 | return; |
||
4456 | } |
||
4457 | |||
4458 | this._isShown = false; |
||
4459 | var transition = Util.supportsTransitionEnd() && $$$1(this._element).hasClass(ClassName.FADE); |
||
4460 | |||
4461 | if (transition) { |
||
4462 | this._isTransitioning = true; |
||
4463 | } |
||
4464 | |||
4465 | this._setEscapeEvent(); |
||
4466 | |||
4467 | this._setResizeEvent(); |
||
4468 | |||
4469 | $$$1(document).off(Event.FOCUSIN); |
||
4470 | $$$1(this._element).removeClass(ClassName.SHOW); |
||
4471 | $$$1(this._element).off(Event.CLICK_DISMISS); |
||
4472 | $$$1(this._dialog).off(Event.MOUSEDOWN_DISMISS); |
||
4473 | |||
4474 | if (transition) { |
||
4475 | $$$1(this._element).one(Util.TRANSITION_END, function (event) { |
||
4476 | return _this2._hideModal(event); |
||
4477 | }).emulateTransitionEnd(TRANSITION_DURATION); |
||
4478 | } else { |
||
4479 | this._hideModal(); |
||
4480 | } |
||
4481 | }; |
||
4482 | |||
4483 | _proto.dispose = function dispose() { |
||
4484 | $$$1.removeData(this._element, DATA_KEY); |
||
4485 | $$$1(window, document, this._element, this._backdrop).off(EVENT_KEY); |
||
4486 | this._config = null; |
||
4487 | this._element = null; |
||
4488 | this._dialog = null; |
||
4489 | this._backdrop = null; |
||
4490 | this._isShown = null; |
||
4491 | this._isBodyOverflowing = null; |
||
4492 | this._ignoreBackdropClick = null; |
||
4493 | this._scrollbarWidth = null; |
||
4494 | }; |
||
4495 | |||
4496 | _proto.handleUpdate = function handleUpdate() { |
||
4497 | this._adjustDialog(); |
||
4498 | }; // Private |
||
4499 | |||
4500 | |||
4501 | _proto._getConfig = function _getConfig(config) { |
||
4502 | config = _extends({}, Default, config); |
||
4503 | Util.typeCheckConfig(NAME, config, DefaultType); |
||
4504 | return config; |
||
4505 | }; |
||
4506 | |||
4507 | _proto._showElement = function _showElement(relatedTarget) { |
||
4508 | var _this3 = this; |
||
4509 | |||
4510 | var transition = Util.supportsTransitionEnd() && $$$1(this._element).hasClass(ClassName.FADE); |
||
4511 | |||
4512 | if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) { |
||
4513 | // Don't move modal's DOM position |
||
4514 | document.body.appendChild(this._element); |
||
4515 | } |
||
4516 | |||
4517 | this._element.style.display = 'block'; |
||
4518 | |||
4519 | this._element.removeAttribute('aria-hidden'); |
||
4520 | |||
4521 | this._element.scrollTop = 0; |
||
4522 | |||
4523 | if (transition) { |
||
4524 | Util.reflow(this._element); |
||
4525 | } |
||
4526 | |||
4527 | $$$1(this._element).addClass(ClassName.SHOW); |
||
4528 | |||
4529 | if (this._config.focus) { |
||
4530 | this._enforceFocus(); |
||
4531 | } |
||
4532 | |||
4533 | var shownEvent = $$$1.Event(Event.SHOWN, { |
||
4534 | relatedTarget: relatedTarget |
||
4535 | }); |
||
4536 | |||
4537 | var transitionComplete = function transitionComplete() { |
||
4538 | if (_this3._config.focus) { |
||
4539 | _this3._element.focus(); |
||
4540 | } |
||
4541 | |||
4542 | _this3._isTransitioning = false; |
||
4543 | $$$1(_this3._element).trigger(shownEvent); |
||
4544 | }; |
||
4545 | |||
4546 | if (transition) { |
||
4547 | $$$1(this._dialog).one(Util.TRANSITION_END, transitionComplete).emulateTransitionEnd(TRANSITION_DURATION); |
||
4548 | } else { |
||
4549 | transitionComplete(); |
||
4550 | } |
||
4551 | }; |
||
4552 | |||
4553 | _proto._enforceFocus = function _enforceFocus() { |
||
4554 | var _this4 = this; |
||
4555 | |||
4556 | $$$1(document).off(Event.FOCUSIN) // Guard against infinite focus loop |
||
4557 | .on(Event.FOCUSIN, function (event) { |
||
4558 | if (document !== event.target && _this4._element !== event.target && $$$1(_this4._element).has(event.target).length === 0) { |
||
4559 | _this4._element.focus(); |
||
4560 | } |
||
4561 | }); |
||
4562 | }; |
||
4563 | |||
4564 | _proto._setEscapeEvent = function _setEscapeEvent() { |
||
4565 | var _this5 = this; |
||
4566 | |||
4567 | if (this._isShown && this._config.keyboard) { |
||
4568 | $$$1(this._element).on(Event.KEYDOWN_DISMISS, function (event) { |
||
4569 | if (event.which === ESCAPE_KEYCODE) { |
||
4570 | event.preventDefault(); |
||
4571 | |||
4572 | _this5.hide(); |
||
4573 | } |
||
4574 | }); |
||
4575 | } else if (!this._isShown) { |
||
4576 | $$$1(this._element).off(Event.KEYDOWN_DISMISS); |
||
4577 | } |
||
4578 | }; |
||
4579 | |||
4580 | _proto._setResizeEvent = function _setResizeEvent() { |
||
4581 | var _this6 = this; |
||
4582 | |||
4583 | if (this._isShown) { |
||
4584 | $$$1(window).on(Event.RESIZE, function (event) { |
||
4585 | return _this6.handleUpdate(event); |
||
4586 | }); |
||
4587 | } else { |
||
4588 | $$$1(window).off(Event.RESIZE); |
||
4589 | } |
||
4590 | }; |
||
4591 | |||
4592 | _proto._hideModal = function _hideModal() { |
||
4593 | var _this7 = this; |
||
4594 | |||
4595 | this._element.style.display = 'none'; |
||
4596 | |||
4597 | this._element.setAttribute('aria-hidden', true); |
||
4598 | |||
4599 | this._isTransitioning = false; |
||
4600 | |||
4601 | this._showBackdrop(function () { |
||
4602 | $$$1(document.body).removeClass(ClassName.OPEN); |
||
4603 | |||
4604 | _this7._resetAdjustments(); |
||
4605 | |||
4606 | _this7._resetScrollbar(); |
||
4607 | |||
4608 | $$$1(_this7._element).trigger(Event.HIDDEN); |
||
4609 | }); |
||
4610 | }; |
||
4611 | |||
4612 | _proto._removeBackdrop = function _removeBackdrop() { |
||
4613 | if (this._backdrop) { |
||
4614 | $$$1(this._backdrop).remove(); |
||
4615 | this._backdrop = null; |
||
4616 | } |
||
4617 | }; |
||
4618 | |||
4619 | _proto._showBackdrop = function _showBackdrop(callback) { |
||
4620 | var _this8 = this; |
||
4621 | |||
4622 | var animate = $$$1(this._element).hasClass(ClassName.FADE) ? ClassName.FADE : ''; |
||
4623 | |||
4624 | if (this._isShown && this._config.backdrop) { |
||
4625 | var doAnimate = Util.supportsTransitionEnd() && animate; |
||
4626 | this._backdrop = document.createElement('div'); |
||
4627 | this._backdrop.className = ClassName.BACKDROP; |
||
4628 | |||
4629 | if (animate) { |
||
4630 | $$$1(this._backdrop).addClass(animate); |
||
4631 | } |
||
4632 | |||
4633 | $$$1(this._backdrop).appendTo(document.body); |
||
4634 | $$$1(this._element).on(Event.CLICK_DISMISS, function (event) { |
||
4635 | if (_this8._ignoreBackdropClick) { |
||
4636 | _this8._ignoreBackdropClick = false; |
||
4637 | return; |
||
4638 | } |
||
4639 | |||
4640 | if (event.target !== event.currentTarget) { |
||
4641 | return; |
||
4642 | } |
||
4643 | |||
4644 | if (_this8._config.backdrop === 'static') { |
||
4645 | _this8._element.focus(); |
||
4646 | } else { |
||
4647 | _this8.hide(); |
||
4648 | } |
||
4649 | }); |
||
4650 | |||
4651 | if (doAnimate) { |
||
4652 | Util.reflow(this._backdrop); |
||
4653 | } |
||
4654 | |||
4655 | $$$1(this._backdrop).addClass(ClassName.SHOW); |
||
4656 | |||
4657 | if (!callback) { |
||
4658 | return; |
||
4659 | } |
||
4660 | |||
4661 | if (!doAnimate) { |
||
4662 | callback(); |
||
4663 | return; |
||
4664 | } |
||
4665 | |||
4666 | $$$1(this._backdrop).one(Util.TRANSITION_END, callback).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION); |
||
4667 | } else if (!this._isShown && this._backdrop) { |
||
4668 | $$$1(this._backdrop).removeClass(ClassName.SHOW); |
||
4669 | |||
4670 | var callbackRemove = function callbackRemove() { |
||
4671 | _this8._removeBackdrop(); |
||
4672 | |||
4673 | if (callback) { |
||
4674 | callback(); |
||
4675 | } |
||
4676 | }; |
||
4677 | |||
4678 | if (Util.supportsTransitionEnd() && $$$1(this._element).hasClass(ClassName.FADE)) { |
||
4679 | $$$1(this._backdrop).one(Util.TRANSITION_END, callbackRemove).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION); |
||
4680 | } else { |
||
4681 | callbackRemove(); |
||
4682 | } |
||
4683 | } else if (callback) { |
||
4684 | callback(); |
||
4685 | } |
||
4686 | }; // ---------------------------------------------------------------------- |
||
4687 | // the following methods are used to handle overflowing modals |
||
4688 | // todo (fat): these should probably be refactored out of modal.js |
||
4689 | // ---------------------------------------------------------------------- |
||
4690 | |||
4691 | |||
4692 | _proto._adjustDialog = function _adjustDialog() { |
||
4693 | var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; |
||
4694 | |||
4695 | if (!this._isBodyOverflowing && isModalOverflowing) { |
||
4696 | this._element.style.paddingLeft = this._scrollbarWidth + "px"; |
||
4697 | } |
||
4698 | |||
4699 | if (this._isBodyOverflowing && !isModalOverflowing) { |
||
4700 | this._element.style.paddingRight = this._scrollbarWidth + "px"; |
||
4701 | } |
||
4702 | }; |
||
4703 | |||
4704 | _proto._resetAdjustments = function _resetAdjustments() { |
||
4705 | this._element.style.paddingLeft = ''; |
||
4706 | this._element.style.paddingRight = ''; |
||
4707 | }; |
||
4708 | |||
4709 | _proto._checkScrollbar = function _checkScrollbar() { |
||
4710 | var rect = document.body.getBoundingClientRect(); |
||
4711 | this._isBodyOverflowing = rect.left + rect.right < window.innerWidth; |
||
4712 | this._scrollbarWidth = this._getScrollbarWidth(); |
||
4713 | }; |
||
4714 | |||
4715 | _proto._setScrollbar = function _setScrollbar() { |
||
4716 | var _this9 = this; |
||
4717 | |||
4718 | if (this._isBodyOverflowing) { |
||
4719 | // Note: DOMNode.style.paddingRight returns the actual value or '' if not set |
||
4720 | // while $(DOMNode).css('padding-right') returns the calculated value or 0 if not set |
||
4721 | // Adjust fixed content padding |
||
4722 | $$$1(Selector.FIXED_CONTENT).each(function (index, element) { |
||
4723 | var actualPadding = $$$1(element)[0].style.paddingRight; |
||
4724 | var calculatedPadding = $$$1(element).css('padding-right'); |
||
4725 | $$$1(element).data('padding-right', actualPadding).css('padding-right', parseFloat(calculatedPadding) + _this9._scrollbarWidth + "px"); |
||
4726 | }); // Adjust sticky content margin |
||
4727 | |||
4728 | $$$1(Selector.STICKY_CONTENT).each(function (index, element) { |
||
4729 | var actualMargin = $$$1(element)[0].style.marginRight; |
||
4730 | var calculatedMargin = $$$1(element).css('margin-right'); |
||
4731 | $$$1(element).data('margin-right', actualMargin).css('margin-right', parseFloat(calculatedMargin) - _this9._scrollbarWidth + "px"); |
||
4732 | }); // Adjust navbar-toggler margin |
||
4733 | |||
4734 | $$$1(Selector.NAVBAR_TOGGLER).each(function (index, element) { |
||
4735 | var actualMargin = $$$1(element)[0].style.marginRight; |
||
4736 | var calculatedMargin = $$$1(element).css('margin-right'); |
||
4737 | $$$1(element).data('margin-right', actualMargin).css('margin-right', parseFloat(calculatedMargin) + _this9._scrollbarWidth + "px"); |
||
4738 | }); // Adjust body padding |
||
4739 | |||
4740 | var actualPadding = document.body.style.paddingRight; |
||
4741 | var calculatedPadding = $$$1('body').css('padding-right'); |
||
4742 | $$$1('body').data('padding-right', actualPadding).css('padding-right', parseFloat(calculatedPadding) + this._scrollbarWidth + "px"); |
||
4743 | } |
||
4744 | }; |
||
4745 | |||
4746 | _proto._resetScrollbar = function _resetScrollbar() { |
||
4747 | // Restore fixed content padding |
||
4748 | $$$1(Selector.FIXED_CONTENT).each(function (index, element) { |
||
4749 | var padding = $$$1(element).data('padding-right'); |
||
4750 | |||
4751 | if (typeof padding !== 'undefined') { |
||
4752 | $$$1(element).css('padding-right', padding).removeData('padding-right'); |
||
4753 | } |
||
4754 | }); // Restore sticky content and navbar-toggler margin |
||
4755 | |||
4756 | $$$1(Selector.STICKY_CONTENT + ", " + Selector.NAVBAR_TOGGLER).each(function (index, element) { |
||
4757 | var margin = $$$1(element).data('margin-right'); |
||
4758 | |||
4759 | if (typeof margin !== 'undefined') { |
||
4760 | $$$1(element).css('margin-right', margin).removeData('margin-right'); |
||
4761 | } |
||
4762 | }); // Restore body padding |
||
4763 | |||
4764 | var padding = $$$1('body').data('padding-right'); |
||
4765 | |||
4766 | if (typeof padding !== 'undefined') { |
||
4767 | $$$1('body').css('padding-right', padding).removeData('padding-right'); |
||
4768 | } |
||
4769 | }; |
||
4770 | |||
4771 | _proto._getScrollbarWidth = function _getScrollbarWidth() { |
||
4772 | // thx d.walsh |
||
4773 | var scrollDiv = document.createElement('div'); |
||
4774 | scrollDiv.className = ClassName.SCROLLBAR_MEASURER; |
||
4775 | document.body.appendChild(scrollDiv); |
||
4776 | var scrollbarWidth = scrollDiv.getBoundingClientRect().width - scrollDiv.clientWidth; |
||
4777 | document.body.removeChild(scrollDiv); |
||
4778 | return scrollbarWidth; |
||
4779 | }; // Static |
||
4780 | |||
4781 | |||
4782 | Modal._jQueryInterface = function _jQueryInterface(config, relatedTarget) { |
||
4783 | return this.each(function () { |
||
4784 | var data = $$$1(this).data(DATA_KEY); |
||
4785 | |||
4786 | var _config = _extends({}, Modal.Default, $$$1(this).data(), typeof config === 'object' && config); |
||
4787 | |||
4788 | if (!data) { |
||
4789 | data = new Modal(this, _config); |
||
4790 | $$$1(this).data(DATA_KEY, data); |
||
4791 | } |
||
4792 | |||
4793 | if (typeof config === 'string') { |
||
4794 | if (typeof data[config] === 'undefined') { |
||
4795 | throw new TypeError("No method named \"" + config + "\""); |
||
4796 | } |
||
4797 | |||
4798 | data[config](relatedTarget); |
||
4799 | } else if (_config.show) { |
||
4800 | data.show(relatedTarget); |
||
4801 | } |
||
4802 | }); |
||
4803 | }; |
||
4804 | |||
4805 | _createClass(Modal, null, [{ |
||
4806 | key: "VERSION", |
||
4807 | get: function get() { |
||
4808 | return VERSION; |
||
4809 | } |
||
4810 | }, { |
||
4811 | key: "Default", |
||
4812 | get: function get() { |
||
4813 | return Default; |
||
4814 | } |
||
4815 | }]); |
||
4816 | return Modal; |
||
4817 | }(); |
||
4818 | /** |
||
4819 | * ------------------------------------------------------------------------ |
||
4820 | * Data Api implementation |
||
4821 | * ------------------------------------------------------------------------ |
||
4822 | */ |
||
4823 | |||
4824 | |||
4825 | $$$1(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) { |
||
4826 | var _this10 = this; |
||
4827 | |||
4828 | var target; |
||
4829 | var selector = Util.getSelectorFromElement(this); |
||
4830 | |||
4831 | if (selector) { |
||
4832 | target = $$$1(selector)[0]; |
||
4833 | } |
||
4834 | |||
4835 | var config = $$$1(target).data(DATA_KEY) ? 'toggle' : _extends({}, $$$1(target).data(), $$$1(this).data()); |
||
4836 | |||
4837 | if (this.tagName === 'A' || this.tagName === 'AREA') { |
||
4838 | event.preventDefault(); |
||
4839 | } |
||
4840 | |||
4841 | var $target = $$$1(target).one(Event.SHOW, function (showEvent) { |
||
4842 | if (showEvent.isDefaultPrevented()) { |
||
4843 | // Only register focus restorer if modal will actually get shown |
||
4844 | return; |
||
4845 | } |
||
4846 | |||
4847 | $target.one(Event.HIDDEN, function () { |
||
4848 | if ($$$1(_this10).is(':visible')) { |
||
4849 | _this10.focus(); |
||
4850 | } |
||
4851 | }); |
||
4852 | }); |
||
4853 | |||
4854 | Modal._jQueryInterface.call($$$1(target), config, this); |
||
4855 | }); |
||
4856 | /** |
||
4857 | * ------------------------------------------------------------------------ |
||
4858 | * jQuery |
||
4859 | * ------------------------------------------------------------------------ |
||
4860 | */ |
||
4861 | |||
4862 | $$$1.fn[NAME] = Modal._jQueryInterface; |
||
4863 | $$$1.fn[NAME].Constructor = Modal; |
||
4864 | |||
4865 | $$$1.fn[NAME].noConflict = function () { |
||
4866 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
4867 | return Modal._jQueryInterface; |
||
4868 | }; |
||
4869 | |||
4870 | return Modal; |
||
4871 | }($); |
||
4872 | |||
4873 | /** |
||
4874 | * -------------------------------------------------------------------------- |
||
4875 | * Bootstrap (v4.0.0): tooltip.js |
||
4876 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
4877 | * -------------------------------------------------------------------------- |
||
4878 | */ |
||
4879 | |||
4880 | var Tooltip = function ($$$1) { |
||
4881 | /** |
||
4882 | * ------------------------------------------------------------------------ |
||
4883 | * Constants |
||
4884 | * ------------------------------------------------------------------------ |
||
4885 | */ |
||
4886 | var NAME = 'tooltip'; |
||
4887 | var VERSION = '4.0.0'; |
||
4888 | var DATA_KEY = 'bs.tooltip'; |
||
4889 | var EVENT_KEY = "." + DATA_KEY; |
||
4890 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
4891 | var TRANSITION_DURATION = 150; |
||
4892 | var CLASS_PREFIX = 'bs-tooltip'; |
||
4893 | var BSCLS_PREFIX_REGEX = new RegExp("(^|\\s)" + CLASS_PREFIX + "\\S+", 'g'); |
||
4894 | var DefaultType = { |
||
4895 | animation: 'boolean', |
||
4896 | template: 'string', |
||
4897 | title: '(string|element|function)', |
||
4898 | trigger: 'string', |
||
4899 | delay: '(number|object)', |
||
4900 | html: 'boolean', |
||
4901 | selector: '(string|boolean)', |
||
4902 | placement: '(string|function)', |
||
4903 | offset: '(number|string)', |
||
4904 | container: '(string|element|boolean)', |
||
4905 | fallbackPlacement: '(string|array)', |
||
4906 | boundary: '(string|element)' |
||
4907 | }; |
||
4908 | var AttachmentMap = { |
||
4909 | AUTO: 'auto', |
||
4910 | TOP: 'top', |
||
4911 | RIGHT: 'right', |
||
4912 | BOTTOM: 'bottom', |
||
4913 | LEFT: 'left' |
||
4914 | }; |
||
4915 | var Default = { |
||
4916 | animation: true, |
||
4917 | template: '<div class="tooltip" role="tooltip">' + '<div class="arrow"></div>' + '<div class="tooltip-inner"></div></div>', |
||
4918 | trigger: 'hover focus', |
||
4919 | title: '', |
||
4920 | delay: 0, |
||
4921 | html: false, |
||
4922 | selector: false, |
||
4923 | placement: 'top', |
||
4924 | offset: 0, |
||
4925 | container: false, |
||
4926 | fallbackPlacement: 'flip', |
||
4927 | boundary: 'scrollParent' |
||
4928 | }; |
||
4929 | var HoverState = { |
||
4930 | SHOW: 'show', |
||
4931 | OUT: 'out' |
||
4932 | }; |
||
4933 | var Event = { |
||
4934 | HIDE: "hide" + EVENT_KEY, |
||
4935 | HIDDEN: "hidden" + EVENT_KEY, |
||
4936 | SHOW: "show" + EVENT_KEY, |
||
4937 | SHOWN: "shown" + EVENT_KEY, |
||
4938 | INSERTED: "inserted" + EVENT_KEY, |
||
4939 | CLICK: "click" + EVENT_KEY, |
||
4940 | FOCUSIN: "focusin" + EVENT_KEY, |
||
4941 | FOCUSOUT: "focusout" + EVENT_KEY, |
||
4942 | MOUSEENTER: "mouseenter" + EVENT_KEY, |
||
4943 | MOUSELEAVE: "mouseleave" + EVENT_KEY |
||
4944 | }; |
||
4945 | var ClassName = { |
||
4946 | FADE: 'fade', |
||
4947 | SHOW: 'show' |
||
4948 | }; |
||
4949 | var Selector = { |
||
4950 | TOOLTIP: '.tooltip', |
||
4951 | TOOLTIP_INNER: '.tooltip-inner', |
||
4952 | ARROW: '.arrow' |
||
4953 | }; |
||
4954 | var Trigger = { |
||
4955 | HOVER: 'hover', |
||
4956 | FOCUS: 'focus', |
||
4957 | CLICK: 'click', |
||
4958 | MANUAL: 'manual' |
||
4959 | /** |
||
4960 | * ------------------------------------------------------------------------ |
||
4961 | * Class Definition |
||
4962 | * ------------------------------------------------------------------------ |
||
4963 | */ |
||
4964 | |||
4965 | }; |
||
4966 | |||
4967 | var Tooltip = |
||
4968 | /*#__PURE__*/ |
||
4969 | function () { |
||
4970 | function Tooltip(element, config) { |
||
4971 | /** |
||
4972 | * Check for Popper dependency |
||
4973 | * Popper - https://popper.js.org |
||
4974 | */ |
||
4975 | if (typeof Popper === 'undefined') { |
||
4976 | throw new TypeError('Bootstrap tooltips require Popper.js (https://popper.js.org)'); |
||
4977 | } // private |
||
4978 | |||
4979 | |||
4980 | this._isEnabled = true; |
||
4981 | this._timeout = 0; |
||
4982 | this._hoverState = ''; |
||
4983 | this._activeTrigger = {}; |
||
4984 | this._popper = null; // Protected |
||
4985 | |||
4986 | this.element = element; |
||
4987 | this.config = this._getConfig(config); |
||
4988 | this.tip = null; |
||
4989 | |||
4990 | this._setListeners(); |
||
4991 | } // Getters |
||
4992 | |||
4993 | |||
4994 | var _proto = Tooltip.prototype; |
||
4995 | |||
4996 | // Public |
||
4997 | _proto.enable = function enable() { |
||
4998 | this._isEnabled = true; |
||
4999 | }; |
||
5000 | |||
5001 | _proto.disable = function disable() { |
||
5002 | this._isEnabled = false; |
||
5003 | }; |
||
5004 | |||
5005 | _proto.toggleEnabled = function toggleEnabled() { |
||
5006 | this._isEnabled = !this._isEnabled; |
||
5007 | }; |
||
5008 | |||
5009 | _proto.toggle = function toggle(event) { |
||
5010 | if (!this._isEnabled) { |
||
5011 | return; |
||
5012 | } |
||
5013 | |||
5014 | if (event) { |
||
5015 | var dataKey = this.constructor.DATA_KEY; |
||
5016 | var context = $$$1(event.currentTarget).data(dataKey); |
||
5017 | |||
5018 | if (!context) { |
||
5019 | context = new this.constructor(event.currentTarget, this._getDelegateConfig()); |
||
5020 | $$$1(event.currentTarget).data(dataKey, context); |
||
5021 | } |
||
5022 | |||
5023 | context._activeTrigger.click = !context._activeTrigger.click; |
||
5024 | |||
5025 | if (context._isWithActiveTrigger()) { |
||
5026 | context._enter(null, context); |
||
5027 | } else { |
||
5028 | context._leave(null, context); |
||
5029 | } |
||
5030 | } else { |
||
5031 | if ($$$1(this.getTipElement()).hasClass(ClassName.SHOW)) { |
||
5032 | this._leave(null, this); |
||
5033 | |||
5034 | return; |
||
5035 | } |
||
5036 | |||
5037 | this._enter(null, this); |
||
5038 | } |
||
5039 | }; |
||
5040 | |||
5041 | _proto.dispose = function dispose() { |
||
5042 | clearTimeout(this._timeout); |
||
5043 | $$$1.removeData(this.element, this.constructor.DATA_KEY); |
||
5044 | $$$1(this.element).off(this.constructor.EVENT_KEY); |
||
5045 | $$$1(this.element).closest('.modal').off('hide.bs.modal'); |
||
5046 | |||
5047 | if (this.tip) { |
||
5048 | $$$1(this.tip).remove(); |
||
5049 | } |
||
5050 | |||
5051 | this._isEnabled = null; |
||
5052 | this._timeout = null; |
||
5053 | this._hoverState = null; |
||
5054 | this._activeTrigger = null; |
||
5055 | |||
5056 | if (this._popper !== null) { |
||
5057 | this._popper.destroy(); |
||
5058 | } |
||
5059 | |||
5060 | this._popper = null; |
||
5061 | this.element = null; |
||
5062 | this.config = null; |
||
5063 | this.tip = null; |
||
5064 | }; |
||
5065 | |||
5066 | _proto.show = function show() { |
||
5067 | var _this = this; |
||
5068 | |||
5069 | if ($$$1(this.element).css('display') === 'none') { |
||
5070 | throw new Error('Please use show on visible elements'); |
||
5071 | } |
||
5072 | |||
5073 | var showEvent = $$$1.Event(this.constructor.Event.SHOW); |
||
5074 | |||
5075 | if (this.isWithContent() && this._isEnabled) { |
||
5076 | $$$1(this.element).trigger(showEvent); |
||
5077 | var isInTheDom = $$$1.contains(this.element.ownerDocument.documentElement, this.element); |
||
5078 | |||
5079 | if (showEvent.isDefaultPrevented() || !isInTheDom) { |
||
5080 | return; |
||
5081 | } |
||
5082 | |||
5083 | var tip = this.getTipElement(); |
||
5084 | var tipId = Util.getUID(this.constructor.NAME); |
||
5085 | tip.setAttribute('id', tipId); |
||
5086 | this.element.setAttribute('aria-describedby', tipId); |
||
5087 | this.setContent(); |
||
5088 | |||
5089 | if (this.config.animation) { |
||
5090 | $$$1(tip).addClass(ClassName.FADE); |
||
5091 | } |
||
5092 | |||
5093 | var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement; |
||
5094 | |||
5095 | var attachment = this._getAttachment(placement); |
||
5096 | |||
5097 | this.addAttachmentClass(attachment); |
||
5098 | var container = this.config.container === false ? document.body : $$$1(this.config.container); |
||
5099 | $$$1(tip).data(this.constructor.DATA_KEY, this); |
||
5100 | |||
5101 | if (!$$$1.contains(this.element.ownerDocument.documentElement, this.tip)) { |
||
5102 | $$$1(tip).appendTo(container); |
||
5103 | } |
||
5104 | |||
5105 | $$$1(this.element).trigger(this.constructor.Event.INSERTED); |
||
5106 | this._popper = new Popper(this.element, tip, { |
||
5107 | placement: attachment, |
||
5108 | modifiers: { |
||
5109 | offset: { |
||
5110 | offset: this.config.offset |
||
5111 | }, |
||
5112 | flip: { |
||
5113 | behavior: this.config.fallbackPlacement |
||
5114 | }, |
||
5115 | arrow: { |
||
5116 | element: Selector.ARROW |
||
5117 | }, |
||
5118 | preventOverflow: { |
||
5119 | boundariesElement: this.config.boundary |
||
5120 | } |
||
5121 | }, |
||
5122 | onCreate: function onCreate(data) { |
||
5123 | if (data.originalPlacement !== data.placement) { |
||
5124 | _this._handlePopperPlacementChange(data); |
||
5125 | } |
||
5126 | }, |
||
5127 | onUpdate: function onUpdate(data) { |
||
5128 | _this._handlePopperPlacementChange(data); |
||
5129 | } |
||
5130 | }); |
||
5131 | $$$1(tip).addClass(ClassName.SHOW); // If this is a touch-enabled device we add extra |
||
5132 | // empty mouseover listeners to the body's immediate children; |
||
5133 | // only needed because of broken event delegation on iOS |
||
5134 | // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html |
||
5135 | |||
5136 | if ('ontouchstart' in document.documentElement) { |
||
5137 | $$$1('body').children().on('mouseover', null, $$$1.noop); |
||
5138 | } |
||
5139 | |||
5140 | var complete = function complete() { |
||
5141 | if (_this.config.animation) { |
||
5142 | _this._fixTransition(); |
||
5143 | } |
||
5144 | |||
5145 | var prevHoverState = _this._hoverState; |
||
5146 | _this._hoverState = null; |
||
5147 | $$$1(_this.element).trigger(_this.constructor.Event.SHOWN); |
||
5148 | |||
5149 | if (prevHoverState === HoverState.OUT) { |
||
5150 | _this._leave(null, _this); |
||
5151 | } |
||
5152 | }; |
||
5153 | |||
5154 | if (Util.supportsTransitionEnd() && $$$1(this.tip).hasClass(ClassName.FADE)) { |
||
5155 | $$$1(this.tip).one(Util.TRANSITION_END, complete).emulateTransitionEnd(Tooltip._TRANSITION_DURATION); |
||
5156 | } else { |
||
5157 | complete(); |
||
5158 | } |
||
5159 | } |
||
5160 | }; |
||
5161 | |||
5162 | _proto.hide = function hide(callback) { |
||
5163 | var _this2 = this; |
||
5164 | |||
5165 | var tip = this.getTipElement(); |
||
5166 | var hideEvent = $$$1.Event(this.constructor.Event.HIDE); |
||
5167 | |||
5168 | var complete = function complete() { |
||
5169 | if (_this2._hoverState !== HoverState.SHOW && tip.parentNode) { |
||
5170 | tip.parentNode.removeChild(tip); |
||
5171 | } |
||
5172 | |||
5173 | _this2._cleanTipClass(); |
||
5174 | |||
5175 | _this2.element.removeAttribute('aria-describedby'); |
||
5176 | |||
5177 | $$$1(_this2.element).trigger(_this2.constructor.Event.HIDDEN); |
||
5178 | |||
5179 | if (_this2._popper !== null) { |
||
5180 | _this2._popper.destroy(); |
||
5181 | } |
||
5182 | |||
5183 | if (callback) { |
||
5184 | callback(); |
||
5185 | } |
||
5186 | }; |
||
5187 | |||
5188 | $$$1(this.element).trigger(hideEvent); |
||
5189 | |||
5190 | if (hideEvent.isDefaultPrevented()) { |
||
5191 | return; |
||
5192 | } |
||
5193 | |||
5194 | $$$1(tip).removeClass(ClassName.SHOW); // If this is a touch-enabled device we remove the extra |
||
5195 | // empty mouseover listeners we added for iOS support |
||
5196 | |||
5197 | if ('ontouchstart' in document.documentElement) { |
||
5198 | $$$1('body').children().off('mouseover', null, $$$1.noop); |
||
5199 | } |
||
5200 | |||
5201 | this._activeTrigger[Trigger.CLICK] = false; |
||
5202 | this._activeTrigger[Trigger.FOCUS] = false; |
||
5203 | this._activeTrigger[Trigger.HOVER] = false; |
||
5204 | |||
5205 | if (Util.supportsTransitionEnd() && $$$1(this.tip).hasClass(ClassName.FADE)) { |
||
5206 | $$$1(tip).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
||
5207 | } else { |
||
5208 | complete(); |
||
5209 | } |
||
5210 | |||
5211 | this._hoverState = ''; |
||
5212 | }; |
||
5213 | |||
5214 | _proto.update = function update() { |
||
5215 | if (this._popper !== null) { |
||
5216 | this._popper.scheduleUpdate(); |
||
5217 | } |
||
5218 | }; // Protected |
||
5219 | |||
5220 | |||
5221 | _proto.isWithContent = function isWithContent() { |
||
5222 | return Boolean(this.getTitle()); |
||
5223 | }; |
||
5224 | |||
5225 | _proto.addAttachmentClass = function addAttachmentClass(attachment) { |
||
5226 | $$$1(this.getTipElement()).addClass(CLASS_PREFIX + "-" + attachment); |
||
5227 | }; |
||
5228 | |||
5229 | _proto.getTipElement = function getTipElement() { |
||
5230 | this.tip = this.tip || $$$1(this.config.template)[0]; |
||
5231 | return this.tip; |
||
5232 | }; |
||
5233 | |||
5234 | _proto.setContent = function setContent() { |
||
5235 | var $tip = $$$1(this.getTipElement()); |
||
5236 | this.setElementContent($tip.find(Selector.TOOLTIP_INNER), this.getTitle()); |
||
5237 | $tip.removeClass(ClassName.FADE + " " + ClassName.SHOW); |
||
5238 | }; |
||
5239 | |||
5240 | _proto.setElementContent = function setElementContent($element, content) { |
||
5241 | var html = this.config.html; |
||
5242 | |||
5243 | if (typeof content === 'object' && (content.nodeType || content.jquery)) { |
||
5244 | // Content is a DOM node or a jQuery |
||
5245 | if (html) { |
||
5246 | if (!$$$1(content).parent().is($element)) { |
||
5247 | $element.empty().append(content); |
||
5248 | } |
||
5249 | } else { |
||
5250 | $element.text($$$1(content).text()); |
||
5251 | } |
||
5252 | } else { |
||
5253 | $element[html ? 'html' : 'text'](content); |
||
5254 | } |
||
5255 | }; |
||
5256 | |||
5257 | _proto.getTitle = function getTitle() { |
||
5258 | var title = this.element.getAttribute('data-original-title'); |
||
5259 | |||
5260 | if (!title) { |
||
5261 | title = typeof this.config.title === 'function' ? this.config.title.call(this.element) : this.config.title; |
||
5262 | } |
||
5263 | |||
5264 | return title; |
||
5265 | }; // Private |
||
5266 | |||
5267 | |||
5268 | _proto._getAttachment = function _getAttachment(placement) { |
||
5269 | return AttachmentMap[placement.toUpperCase()]; |
||
5270 | }; |
||
5271 | |||
5272 | _proto._setListeners = function _setListeners() { |
||
5273 | var _this3 = this; |
||
5274 | |||
5275 | var triggers = this.config.trigger.split(' '); |
||
5276 | triggers.forEach(function (trigger) { |
||
5277 | if (trigger === 'click') { |
||
5278 | $$$1(_this3.element).on(_this3.constructor.Event.CLICK, _this3.config.selector, function (event) { |
||
5279 | return _this3.toggle(event); |
||
5280 | }); |
||
5281 | } else if (trigger !== Trigger.MANUAL) { |
||
5282 | var eventIn = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSEENTER : _this3.constructor.Event.FOCUSIN; |
||
5283 | var eventOut = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSELEAVE : _this3.constructor.Event.FOCUSOUT; |
||
5284 | $$$1(_this3.element).on(eventIn, _this3.config.selector, function (event) { |
||
5285 | return _this3._enter(event); |
||
5286 | }).on(eventOut, _this3.config.selector, function (event) { |
||
5287 | return _this3._leave(event); |
||
5288 | }); |
||
5289 | } |
||
5290 | |||
5291 | $$$1(_this3.element).closest('.modal').on('hide.bs.modal', function () { |
||
5292 | return _this3.hide(); |
||
5293 | }); |
||
5294 | }); |
||
5295 | |||
5296 | if (this.config.selector) { |
||
5297 | this.config = _extends({}, this.config, { |
||
5298 | trigger: 'manual', |
||
5299 | selector: '' |
||
5300 | }); |
||
5301 | } else { |
||
5302 | this._fixTitle(); |
||
5303 | } |
||
5304 | }; |
||
5305 | |||
5306 | _proto._fixTitle = function _fixTitle() { |
||
5307 | var titleType = typeof this.element.getAttribute('data-original-title'); |
||
5308 | |||
5309 | if (this.element.getAttribute('title') || titleType !== 'string') { |
||
5310 | this.element.setAttribute('data-original-title', this.element.getAttribute('title') || ''); |
||
5311 | this.element.setAttribute('title', ''); |
||
5312 | } |
||
5313 | }; |
||
5314 | |||
5315 | _proto._enter = function _enter(event, context) { |
||
5316 | var dataKey = this.constructor.DATA_KEY; |
||
5317 | context = context || $$$1(event.currentTarget).data(dataKey); |
||
5318 | |||
5319 | if (!context) { |
||
5320 | context = new this.constructor(event.currentTarget, this._getDelegateConfig()); |
||
5321 | $$$1(event.currentTarget).data(dataKey, context); |
||
5322 | } |
||
5323 | |||
5324 | if (event) { |
||
5325 | context._activeTrigger[event.type === 'focusin' ? Trigger.FOCUS : Trigger.HOVER] = true; |
||
5326 | } |
||
5327 | |||
5328 | if ($$$1(context.getTipElement()).hasClass(ClassName.SHOW) || context._hoverState === HoverState.SHOW) { |
||
5329 | context._hoverState = HoverState.SHOW; |
||
5330 | return; |
||
5331 | } |
||
5332 | |||
5333 | clearTimeout(context._timeout); |
||
5334 | context._hoverState = HoverState.SHOW; |
||
5335 | |||
5336 | if (!context.config.delay || !context.config.delay.show) { |
||
5337 | context.show(); |
||
5338 | return; |
||
5339 | } |
||
5340 | |||
5341 | context._timeout = setTimeout(function () { |
||
5342 | if (context._hoverState === HoverState.SHOW) { |
||
5343 | context.show(); |
||
5344 | } |
||
5345 | }, context.config.delay.show); |
||
5346 | }; |
||
5347 | |||
5348 | _proto._leave = function _leave(event, context) { |
||
5349 | var dataKey = this.constructor.DATA_KEY; |
||
5350 | context = context || $$$1(event.currentTarget).data(dataKey); |
||
5351 | |||
5352 | if (!context) { |
||
5353 | context = new this.constructor(event.currentTarget, this._getDelegateConfig()); |
||
5354 | $$$1(event.currentTarget).data(dataKey, context); |
||
5355 | } |
||
5356 | |||
5357 | if (event) { |
||
5358 | context._activeTrigger[event.type === 'focusout' ? Trigger.FOCUS : Trigger.HOVER] = false; |
||
5359 | } |
||
5360 | |||
5361 | if (context._isWithActiveTrigger()) { |
||
5362 | return; |
||
5363 | } |
||
5364 | |||
5365 | clearTimeout(context._timeout); |
||
5366 | context._hoverState = HoverState.OUT; |
||
5367 | |||
5368 | if (!context.config.delay || !context.config.delay.hide) { |
||
5369 | context.hide(); |
||
5370 | return; |
||
5371 | } |
||
5372 | |||
5373 | context._timeout = setTimeout(function () { |
||
5374 | if (context._hoverState === HoverState.OUT) { |
||
5375 | context.hide(); |
||
5376 | } |
||
5377 | }, context.config.delay.hide); |
||
5378 | }; |
||
5379 | |||
5380 | _proto._isWithActiveTrigger = function _isWithActiveTrigger() { |
||
5381 | for (var trigger in this._activeTrigger) { |
||
5382 | if (this._activeTrigger[trigger]) { |
||
5383 | return true; |
||
5384 | } |
||
5385 | } |
||
5386 | |||
5387 | return false; |
||
5388 | }; |
||
5389 | |||
5390 | _proto._getConfig = function _getConfig(config) { |
||
5391 | config = _extends({}, this.constructor.Default, $$$1(this.element).data(), config); |
||
5392 | |||
5393 | if (typeof config.delay === 'number') { |
||
5394 | config.delay = { |
||
5395 | show: config.delay, |
||
5396 | hide: config.delay |
||
5397 | }; |
||
5398 | } |
||
5399 | |||
5400 | if (typeof config.title === 'number') { |
||
5401 | config.title = config.title.toString(); |
||
5402 | } |
||
5403 | |||
5404 | if (typeof config.content === 'number') { |
||
5405 | config.content = config.content.toString(); |
||
5406 | } |
||
5407 | |||
5408 | Util.typeCheckConfig(NAME, config, this.constructor.DefaultType); |
||
5409 | return config; |
||
5410 | }; |
||
5411 | |||
5412 | _proto._getDelegateConfig = function _getDelegateConfig() { |
||
5413 | var config = {}; |
||
5414 | |||
5415 | if (this.config) { |
||
5416 | for (var key in this.config) { |
||
5417 | if (this.constructor.Default[key] !== this.config[key]) { |
||
5418 | config[key] = this.config[key]; |
||
5419 | } |
||
5420 | } |
||
5421 | } |
||
5422 | |||
5423 | return config; |
||
5424 | }; |
||
5425 | |||
5426 | _proto._cleanTipClass = function _cleanTipClass() { |
||
5427 | var $tip = $$$1(this.getTipElement()); |
||
5428 | var tabClass = $tip.attr('class').match(BSCLS_PREFIX_REGEX); |
||
5429 | |||
5430 | if (tabClass !== null && tabClass.length > 0) { |
||
5431 | $tip.removeClass(tabClass.join('')); |
||
5432 | } |
||
5433 | }; |
||
5434 | |||
5435 | _proto._handlePopperPlacementChange = function _handlePopperPlacementChange(data) { |
||
5436 | this._cleanTipClass(); |
||
5437 | |||
5438 | this.addAttachmentClass(this._getAttachment(data.placement)); |
||
5439 | }; |
||
5440 | |||
5441 | _proto._fixTransition = function _fixTransition() { |
||
5442 | var tip = this.getTipElement(); |
||
5443 | var initConfigAnimation = this.config.animation; |
||
5444 | |||
5445 | if (tip.getAttribute('x-placement') !== null) { |
||
5446 | return; |
||
5447 | } |
||
5448 | |||
5449 | $$$1(tip).removeClass(ClassName.FADE); |
||
5450 | this.config.animation = false; |
||
5451 | this.hide(); |
||
5452 | this.show(); |
||
5453 | this.config.animation = initConfigAnimation; |
||
5454 | }; // Static |
||
5455 | |||
5456 | |||
5457 | Tooltip._jQueryInterface = function _jQueryInterface(config) { |
||
5458 | return this.each(function () { |
||
5459 | var data = $$$1(this).data(DATA_KEY); |
||
5460 | |||
5461 | var _config = typeof config === 'object' && config; |
||
5462 | |||
5463 | if (!data && /dispose|hide/.test(config)) { |
||
5464 | return; |
||
5465 | } |
||
5466 | |||
5467 | if (!data) { |
||
5468 | data = new Tooltip(this, _config); |
||
5469 | $$$1(this).data(DATA_KEY, data); |
||
5470 | } |
||
5471 | |||
5472 | if (typeof config === 'string') { |
||
5473 | if (typeof data[config] === 'undefined') { |
||
5474 | throw new TypeError("No method named \"" + config + "\""); |
||
5475 | } |
||
5476 | |||
5477 | data[config](); |
||
5478 | } |
||
5479 | }); |
||
5480 | }; |
||
5481 | |||
5482 | _createClass(Tooltip, null, [{ |
||
5483 | key: "VERSION", |
||
5484 | get: function get() { |
||
5485 | return VERSION; |
||
5486 | } |
||
5487 | }, { |
||
5488 | key: "Default", |
||
5489 | get: function get() { |
||
5490 | return Default; |
||
5491 | } |
||
5492 | }, { |
||
5493 | key: "NAME", |
||
5494 | get: function get() { |
||
5495 | return NAME; |
||
5496 | } |
||
5497 | }, { |
||
5498 | key: "DATA_KEY", |
||
5499 | get: function get() { |
||
5500 | return DATA_KEY; |
||
5501 | } |
||
5502 | }, { |
||
5503 | key: "Event", |
||
5504 | get: function get() { |
||
5505 | return Event; |
||
5506 | } |
||
5507 | }, { |
||
5508 | key: "EVENT_KEY", |
||
5509 | get: function get() { |
||
5510 | return EVENT_KEY; |
||
5511 | } |
||
5512 | }, { |
||
5513 | key: "DefaultType", |
||
5514 | get: function get() { |
||
5515 | return DefaultType; |
||
5516 | } |
||
5517 | }]); |
||
5518 | return Tooltip; |
||
5519 | }(); |
||
5520 | /** |
||
5521 | * ------------------------------------------------------------------------ |
||
5522 | * jQuery |
||
5523 | * ------------------------------------------------------------------------ |
||
5524 | */ |
||
5525 | |||
5526 | |||
5527 | $$$1.fn[NAME] = Tooltip._jQueryInterface; |
||
5528 | $$$1.fn[NAME].Constructor = Tooltip; |
||
5529 | |||
5530 | $$$1.fn[NAME].noConflict = function () { |
||
5531 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
5532 | return Tooltip._jQueryInterface; |
||
5533 | }; |
||
5534 | |||
5535 | return Tooltip; |
||
5536 | }($, Popper); |
||
5537 | |||
5538 | /** |
||
5539 | * -------------------------------------------------------------------------- |
||
5540 | * Bootstrap (v4.0.0): popover.js |
||
5541 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
5542 | * -------------------------------------------------------------------------- |
||
5543 | */ |
||
5544 | |||
5545 | var Popover = function ($$$1) { |
||
5546 | /** |
||
5547 | * ------------------------------------------------------------------------ |
||
5548 | * Constants |
||
5549 | * ------------------------------------------------------------------------ |
||
5550 | */ |
||
5551 | var NAME = 'popover'; |
||
5552 | var VERSION = '4.0.0'; |
||
5553 | var DATA_KEY = 'bs.popover'; |
||
5554 | var EVENT_KEY = "." + DATA_KEY; |
||
5555 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
5556 | var CLASS_PREFIX = 'bs-popover'; |
||
5557 | var BSCLS_PREFIX_REGEX = new RegExp("(^|\\s)" + CLASS_PREFIX + "\\S+", 'g'); |
||
5558 | var Default = _extends({}, Tooltip.Default, { |
||
5559 | placement: 'right', |
||
5560 | trigger: 'click', |
||
5561 | content: '', |
||
5562 | template: '<div class="popover" role="tooltip">' + '<div class="arrow"></div>' + '<h3 class="popover-header"></h3>' + '<div class="popover-body"></div></div>' |
||
5563 | }); |
||
5564 | var DefaultType = _extends({}, Tooltip.DefaultType, { |
||
5565 | content: '(string|element|function)' |
||
5566 | }); |
||
5567 | var ClassName = { |
||
5568 | FADE: 'fade', |
||
5569 | SHOW: 'show' |
||
5570 | }; |
||
5571 | var Selector = { |
||
5572 | TITLE: '.popover-header', |
||
5573 | CONTENT: '.popover-body' |
||
5574 | }; |
||
5575 | var Event = { |
||
5576 | HIDE: "hide" + EVENT_KEY, |
||
5577 | HIDDEN: "hidden" + EVENT_KEY, |
||
5578 | SHOW: "show" + EVENT_KEY, |
||
5579 | SHOWN: "shown" + EVENT_KEY, |
||
5580 | INSERTED: "inserted" + EVENT_KEY, |
||
5581 | CLICK: "click" + EVENT_KEY, |
||
5582 | FOCUSIN: "focusin" + EVENT_KEY, |
||
5583 | FOCUSOUT: "focusout" + EVENT_KEY, |
||
5584 | MOUSEENTER: "mouseenter" + EVENT_KEY, |
||
5585 | MOUSELEAVE: "mouseleave" + EVENT_KEY |
||
5586 | /** |
||
5587 | * ------------------------------------------------------------------------ |
||
5588 | * Class Definition |
||
5589 | * ------------------------------------------------------------------------ |
||
5590 | */ |
||
5591 | |||
5592 | }; |
||
5593 | |||
5594 | var Popover = |
||
5595 | /*#__PURE__*/ |
||
5596 | function (_Tooltip) { |
||
5597 | _inheritsLoose(Popover, _Tooltip); |
||
5598 | |||
5599 | function Popover() { |
||
5600 | return _Tooltip.apply(this, arguments) || this; |
||
5601 | } |
||
5602 | |||
5603 | var _proto = Popover.prototype; |
||
5604 | |||
5605 | // Overrides |
||
5606 | _proto.isWithContent = function isWithContent() { |
||
5607 | return this.getTitle() || this._getContent(); |
||
5608 | }; |
||
5609 | |||
5610 | _proto.addAttachmentClass = function addAttachmentClass(attachment) { |
||
5611 | $$$1(this.getTipElement()).addClass(CLASS_PREFIX + "-" + attachment); |
||
5612 | }; |
||
5613 | |||
5614 | _proto.getTipElement = function getTipElement() { |
||
5615 | this.tip = this.tip || $$$1(this.config.template)[0]; |
||
5616 | return this.tip; |
||
5617 | }; |
||
5618 | |||
5619 | _proto.setContent = function setContent() { |
||
5620 | var $tip = $$$1(this.getTipElement()); // We use append for html objects to maintain js events |
||
5621 | |||
5622 | this.setElementContent($tip.find(Selector.TITLE), this.getTitle()); |
||
5623 | |||
5624 | var content = this._getContent(); |
||
5625 | |||
5626 | if (typeof content === 'function') { |
||
5627 | content = content.call(this.element); |
||
5628 | } |
||
5629 | |||
5630 | this.setElementContent($tip.find(Selector.CONTENT), content); |
||
5631 | $tip.removeClass(ClassName.FADE + " " + ClassName.SHOW); |
||
5632 | }; // Private |
||
5633 | |||
5634 | |||
5635 | _proto._getContent = function _getContent() { |
||
5636 | return this.element.getAttribute('data-content') || this.config.content; |
||
5637 | }; |
||
5638 | |||
5639 | _proto._cleanTipClass = function _cleanTipClass() { |
||
5640 | var $tip = $$$1(this.getTipElement()); |
||
5641 | var tabClass = $tip.attr('class').match(BSCLS_PREFIX_REGEX); |
||
5642 | |||
5643 | if (tabClass !== null && tabClass.length > 0) { |
||
5644 | $tip.removeClass(tabClass.join('')); |
||
5645 | } |
||
5646 | }; // Static |
||
5647 | |||
5648 | |||
5649 | Popover._jQueryInterface = function _jQueryInterface(config) { |
||
5650 | return this.each(function () { |
||
5651 | var data = $$$1(this).data(DATA_KEY); |
||
5652 | |||
5653 | var _config = typeof config === 'object' ? config : null; |
||
5654 | |||
5655 | if (!data && /destroy|hide/.test(config)) { |
||
5656 | return; |
||
5657 | } |
||
5658 | |||
5659 | if (!data) { |
||
5660 | data = new Popover(this, _config); |
||
5661 | $$$1(this).data(DATA_KEY, data); |
||
5662 | } |
||
5663 | |||
5664 | if (typeof config === 'string') { |
||
5665 | if (typeof data[config] === 'undefined') { |
||
5666 | throw new TypeError("No method named \"" + config + "\""); |
||
5667 | } |
||
5668 | |||
5669 | data[config](); |
||
5670 | } |
||
5671 | }); |
||
5672 | }; |
||
5673 | |||
5674 | _createClass(Popover, null, [{ |
||
5675 | key: "VERSION", |
||
5676 | // Getters |
||
5677 | get: function get() { |
||
5678 | return VERSION; |
||
5679 | } |
||
5680 | }, { |
||
5681 | key: "Default", |
||
5682 | get: function get() { |
||
5683 | return Default; |
||
5684 | } |
||
5685 | }, { |
||
5686 | key: "NAME", |
||
5687 | get: function get() { |
||
5688 | return NAME; |
||
5689 | } |
||
5690 | }, { |
||
5691 | key: "DATA_KEY", |
||
5692 | get: function get() { |
||
5693 | return DATA_KEY; |
||
5694 | } |
||
5695 | }, { |
||
5696 | key: "Event", |
||
5697 | get: function get() { |
||
5698 | return Event; |
||
5699 | } |
||
5700 | }, { |
||
5701 | key: "EVENT_KEY", |
||
5702 | get: function get() { |
||
5703 | return EVENT_KEY; |
||
5704 | } |
||
5705 | }, { |
||
5706 | key: "DefaultType", |
||
5707 | get: function get() { |
||
5708 | return DefaultType; |
||
5709 | } |
||
5710 | }]); |
||
5711 | return Popover; |
||
5712 | }(Tooltip); |
||
5713 | /** |
||
5714 | * ------------------------------------------------------------------------ |
||
5715 | * jQuery |
||
5716 | * ------------------------------------------------------------------------ |
||
5717 | */ |
||
5718 | |||
5719 | |||
5720 | $$$1.fn[NAME] = Popover._jQueryInterface; |
||
5721 | $$$1.fn[NAME].Constructor = Popover; |
||
5722 | |||
5723 | $$$1.fn[NAME].noConflict = function () { |
||
5724 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
5725 | return Popover._jQueryInterface; |
||
5726 | }; |
||
5727 | |||
5728 | return Popover; |
||
5729 | }($); |
||
5730 | |||
5731 | /** |
||
5732 | * -------------------------------------------------------------------------- |
||
5733 | * Bootstrap (v4.0.0): scrollspy.js |
||
5734 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
5735 | * -------------------------------------------------------------------------- |
||
5736 | */ |
||
5737 | |||
5738 | var ScrollSpy = function ($$$1) { |
||
5739 | /** |
||
5740 | * ------------------------------------------------------------------------ |
||
5741 | * Constants |
||
5742 | * ------------------------------------------------------------------------ |
||
5743 | */ |
||
5744 | var NAME = 'scrollspy'; |
||
5745 | var VERSION = '4.0.0'; |
||
5746 | var DATA_KEY = 'bs.scrollspy'; |
||
5747 | var EVENT_KEY = "." + DATA_KEY; |
||
5748 | var DATA_API_KEY = '.data-api'; |
||
5749 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
5750 | var Default = { |
||
5751 | offset: 10, |
||
5752 | method: 'auto', |
||
5753 | target: '' |
||
5754 | }; |
||
5755 | var DefaultType = { |
||
5756 | offset: 'number', |
||
5757 | method: 'string', |
||
5758 | target: '(string|element)' |
||
5759 | }; |
||
5760 | var Event = { |
||
5761 | ACTIVATE: "activate" + EVENT_KEY, |
||
5762 | SCROLL: "scroll" + EVENT_KEY, |
||
5763 | LOAD_DATA_API: "load" + EVENT_KEY + DATA_API_KEY |
||
5764 | }; |
||
5765 | var ClassName = { |
||
5766 | DROPDOWN_ITEM: 'dropdown-item', |
||
5767 | DROPDOWN_MENU: 'dropdown-menu', |
||
5768 | ACTIVE: 'active' |
||
5769 | }; |
||
5770 | var Selector = { |
||
5771 | DATA_SPY: '[data-spy="scroll"]', |
||
5772 | ACTIVE: '.active', |
||
5773 | NAV_LIST_GROUP: '.nav, .list-group', |
||
5774 | NAV_LINKS: '.nav-link', |
||
5775 | NAV_ITEMS: '.nav-item', |
||
5776 | LIST_ITEMS: '.list-group-item', |
||
5777 | DROPDOWN: '.dropdown', |
||
5778 | DROPDOWN_ITEMS: '.dropdown-item', |
||
5779 | DROPDOWN_TOGGLE: '.dropdown-toggle' |
||
5780 | }; |
||
5781 | var OffsetMethod = { |
||
5782 | OFFSET: 'offset', |
||
5783 | POSITION: 'position' |
||
5784 | /** |
||
5785 | * ------------------------------------------------------------------------ |
||
5786 | * Class Definition |
||
5787 | * ------------------------------------------------------------------------ |
||
5788 | */ |
||
5789 | |||
5790 | }; |
||
5791 | |||
5792 | var ScrollSpy = |
||
5793 | /*#__PURE__*/ |
||
5794 | function () { |
||
5795 | function ScrollSpy(element, config) { |
||
5796 | var _this = this; |
||
5797 | |||
5798 | this._element = element; |
||
5799 | this._scrollElement = element.tagName === 'BODY' ? window : element; |
||
5800 | this._config = this._getConfig(config); |
||
5801 | this._selector = this._config.target + " " + Selector.NAV_LINKS + "," + (this._config.target + " " + Selector.LIST_ITEMS + ",") + (this._config.target + " " + Selector.DROPDOWN_ITEMS); |
||
5802 | this._offsets = []; |
||
5803 | this._targets = []; |
||
5804 | this._activeTarget = null; |
||
5805 | this._scrollHeight = 0; |
||
5806 | $$$1(this._scrollElement).on(Event.SCROLL, function (event) { |
||
5807 | return _this._process(event); |
||
5808 | }); |
||
5809 | this.refresh(); |
||
5810 | |||
5811 | this._process(); |
||
5812 | } // Getters |
||
5813 | |||
5814 | |||
5815 | var _proto = ScrollSpy.prototype; |
||
5816 | |||
5817 | // Public |
||
5818 | _proto.refresh = function refresh() { |
||
5819 | var _this2 = this; |
||
5820 | |||
5821 | var autoMethod = this._scrollElement === this._scrollElement.window ? OffsetMethod.OFFSET : OffsetMethod.POSITION; |
||
5822 | var offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method; |
||
5823 | var offsetBase = offsetMethod === OffsetMethod.POSITION ? this._getScrollTop() : 0; |
||
5824 | this._offsets = []; |
||
5825 | this._targets = []; |
||
5826 | this._scrollHeight = this._getScrollHeight(); |
||
5827 | var targets = $$$1.makeArray($$$1(this._selector)); |
||
5828 | targets.map(function (element) { |
||
5829 | var target; |
||
5830 | var targetSelector = Util.getSelectorFromElement(element); |
||
5831 | |||
5832 | if (targetSelector) { |
||
5833 | target = $$$1(targetSelector)[0]; |
||
5834 | } |
||
5835 | |||
5836 | if (target) { |
||
5837 | var targetBCR = target.getBoundingClientRect(); |
||
5838 | |||
5839 | if (targetBCR.width || targetBCR.height) { |
||
5840 | // TODO (fat): remove sketch reliance on jQuery position/offset |
||
5841 | return [$$$1(target)[offsetMethod]().top + offsetBase, targetSelector]; |
||
5842 | } |
||
5843 | } |
||
5844 | |||
5845 | return null; |
||
5846 | }).filter(function (item) { |
||
5847 | return item; |
||
5848 | }).sort(function (a, b) { |
||
5849 | return a[0] - b[0]; |
||
5850 | }).forEach(function (item) { |
||
5851 | _this2._offsets.push(item[0]); |
||
5852 | |||
5853 | _this2._targets.push(item[1]); |
||
5854 | }); |
||
5855 | }; |
||
5856 | |||
5857 | _proto.dispose = function dispose() { |
||
5858 | $$$1.removeData(this._element, DATA_KEY); |
||
5859 | $$$1(this._scrollElement).off(EVENT_KEY); |
||
5860 | this._element = null; |
||
5861 | this._scrollElement = null; |
||
5862 | this._config = null; |
||
5863 | this._selector = null; |
||
5864 | this._offsets = null; |
||
5865 | this._targets = null; |
||
5866 | this._activeTarget = null; |
||
5867 | this._scrollHeight = null; |
||
5868 | }; // Private |
||
5869 | |||
5870 | |||
5871 | _proto._getConfig = function _getConfig(config) { |
||
5872 | config = _extends({}, Default, config); |
||
5873 | |||
5874 | if (typeof config.target !== 'string') { |
||
5875 | var id = $$$1(config.target).attr('id'); |
||
5876 | |||
5877 | if (!id) { |
||
5878 | id = Util.getUID(NAME); |
||
5879 | $$$1(config.target).attr('id', id); |
||
5880 | } |
||
5881 | |||
5882 | config.target = "#" + id; |
||
5883 | } |
||
5884 | |||
5885 | Util.typeCheckConfig(NAME, config, DefaultType); |
||
5886 | return config; |
||
5887 | }; |
||
5888 | |||
5889 | _proto._getScrollTop = function _getScrollTop() { |
||
5890 | return this._scrollElement === window ? this._scrollElement.pageYOffset : this._scrollElement.scrollTop; |
||
5891 | }; |
||
5892 | |||
5893 | _proto._getScrollHeight = function _getScrollHeight() { |
||
5894 | return this._scrollElement.scrollHeight || Math.max(document.body.scrollHeight, document.documentElement.scrollHeight); |
||
5895 | }; |
||
5896 | |||
5897 | _proto._getOffsetHeight = function _getOffsetHeight() { |
||
5898 | return this._scrollElement === window ? window.innerHeight : this._scrollElement.getBoundingClientRect().height; |
||
5899 | }; |
||
5900 | |||
5901 | _proto._process = function _process() { |
||
5902 | var scrollTop = this._getScrollTop() + this._config.offset; |
||
5903 | |||
5904 | var scrollHeight = this._getScrollHeight(); |
||
5905 | |||
5906 | var maxScroll = this._config.offset + scrollHeight - this._getOffsetHeight(); |
||
5907 | |||
5908 | if (this._scrollHeight !== scrollHeight) { |
||
5909 | this.refresh(); |
||
5910 | } |
||
5911 | |||
5912 | if (scrollTop >= maxScroll) { |
||
5913 | var target = this._targets[this._targets.length - 1]; |
||
5914 | |||
5915 | if (this._activeTarget !== target) { |
||
5916 | this._activate(target); |
||
5917 | } |
||
5918 | |||
5919 | return; |
||
5920 | } |
||
5921 | |||
5922 | if (this._activeTarget && scrollTop < this._offsets[0] && this._offsets[0] > 0) { |
||
5923 | this._activeTarget = null; |
||
5924 | |||
5925 | this._clear(); |
||
5926 | |||
5927 | return; |
||
5928 | } |
||
5929 | |||
5930 | for (var i = this._offsets.length; i--;) { |
||
5931 | var isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (typeof this._offsets[i + 1] === 'undefined' || scrollTop < this._offsets[i + 1]); |
||
5932 | |||
5933 | if (isActiveTarget) { |
||
5934 | this._activate(this._targets[i]); |
||
5935 | } |
||
5936 | } |
||
5937 | }; |
||
5938 | |||
5939 | _proto._activate = function _activate(target) { |
||
5940 | this._activeTarget = target; |
||
5941 | |||
5942 | this._clear(); |
||
5943 | |||
5944 | var queries = this._selector.split(','); // eslint-disable-next-line arrow-body-style |
||
5945 | |||
5946 | |||
5947 | queries = queries.map(function (selector) { |
||
5948 | return selector + "[data-target=\"" + target + "\"]," + (selector + "[href=\"" + target + "\"]"); |
||
5949 | }); |
||
5950 | var $link = $$$1(queries.join(',')); |
||
5951 | |||
5952 | if ($link.hasClass(ClassName.DROPDOWN_ITEM)) { |
||
5953 | $link.closest(Selector.DROPDOWN).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE); |
||
5954 | $link.addClass(ClassName.ACTIVE); |
||
5955 | } else { |
||
5956 | // Set triggered link as active |
||
5957 | $link.addClass(ClassName.ACTIVE); // Set triggered links parents as active |
||
5958 | // With both <ul> and <nav> markup a parent is the previous sibling of any nav ancestor |
||
5959 | |||
5960 | $link.parents(Selector.NAV_LIST_GROUP).prev(Selector.NAV_LINKS + ", " + Selector.LIST_ITEMS).addClass(ClassName.ACTIVE); // Handle special case when .nav-link is inside .nav-item |
||
5961 | |||
5962 | $link.parents(Selector.NAV_LIST_GROUP).prev(Selector.NAV_ITEMS).children(Selector.NAV_LINKS).addClass(ClassName.ACTIVE); |
||
5963 | } |
||
5964 | |||
5965 | $$$1(this._scrollElement).trigger(Event.ACTIVATE, { |
||
5966 | relatedTarget: target |
||
5967 | }); |
||
5968 | }; |
||
5969 | |||
5970 | _proto._clear = function _clear() { |
||
5971 | $$$1(this._selector).filter(Selector.ACTIVE).removeClass(ClassName.ACTIVE); |
||
5972 | }; // Static |
||
5973 | |||
5974 | |||
5975 | ScrollSpy._jQueryInterface = function _jQueryInterface(config) { |
||
5976 | return this.each(function () { |
||
5977 | var data = $$$1(this).data(DATA_KEY); |
||
5978 | |||
5979 | var _config = typeof config === 'object' && config; |
||
5980 | |||
5981 | if (!data) { |
||
5982 | data = new ScrollSpy(this, _config); |
||
5983 | $$$1(this).data(DATA_KEY, data); |
||
5984 | } |
||
5985 | |||
5986 | if (typeof config === 'string') { |
||
5987 | if (typeof data[config] === 'undefined') { |
||
5988 | throw new TypeError("No method named \"" + config + "\""); |
||
5989 | } |
||
5990 | |||
5991 | data[config](); |
||
5992 | } |
||
5993 | }); |
||
5994 | }; |
||
5995 | |||
5996 | _createClass(ScrollSpy, null, [{ |
||
5997 | key: "VERSION", |
||
5998 | get: function get() { |
||
5999 | return VERSION; |
||
6000 | } |
||
6001 | }, { |
||
6002 | key: "Default", |
||
6003 | get: function get() { |
||
6004 | return Default; |
||
6005 | } |
||
6006 | }]); |
||
6007 | return ScrollSpy; |
||
6008 | }(); |
||
6009 | /** |
||
6010 | * ------------------------------------------------------------------------ |
||
6011 | * Data Api implementation |
||
6012 | * ------------------------------------------------------------------------ |
||
6013 | */ |
||
6014 | |||
6015 | |||
6016 | $$$1(window).on(Event.LOAD_DATA_API, function () { |
||
6017 | var scrollSpys = $$$1.makeArray($$$1(Selector.DATA_SPY)); |
||
6018 | |||
6019 | for (var i = scrollSpys.length; i--;) { |
||
6020 | var $spy = $$$1(scrollSpys[i]); |
||
6021 | |||
6022 | ScrollSpy._jQueryInterface.call($spy, $spy.data()); |
||
6023 | } |
||
6024 | }); |
||
6025 | /** |
||
6026 | * ------------------------------------------------------------------------ |
||
6027 | * jQuery |
||
6028 | * ------------------------------------------------------------------------ |
||
6029 | */ |
||
6030 | |||
6031 | $$$1.fn[NAME] = ScrollSpy._jQueryInterface; |
||
6032 | $$$1.fn[NAME].Constructor = ScrollSpy; |
||
6033 | |||
6034 | $$$1.fn[NAME].noConflict = function () { |
||
6035 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
6036 | return ScrollSpy._jQueryInterface; |
||
6037 | }; |
||
6038 | |||
6039 | return ScrollSpy; |
||
6040 | }($); |
||
6041 | |||
6042 | /** |
||
6043 | * -------------------------------------------------------------------------- |
||
6044 | * Bootstrap (v4.0.0): tab.js |
||
6045 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
6046 | * -------------------------------------------------------------------------- |
||
6047 | */ |
||
6048 | |||
6049 | var Tab = function ($$$1) { |
||
6050 | /** |
||
6051 | * ------------------------------------------------------------------------ |
||
6052 | * Constants |
||
6053 | * ------------------------------------------------------------------------ |
||
6054 | */ |
||
6055 | var NAME = 'tab'; |
||
6056 | var VERSION = '4.0.0'; |
||
6057 | var DATA_KEY = 'bs.tab'; |
||
6058 | var EVENT_KEY = "." + DATA_KEY; |
||
6059 | var DATA_API_KEY = '.data-api'; |
||
6060 | var JQUERY_NO_CONFLICT = $$$1.fn[NAME]; |
||
6061 | var TRANSITION_DURATION = 150; |
||
6062 | var Event = { |
||
6063 | HIDE: "hide" + EVENT_KEY, |
||
6064 | HIDDEN: "hidden" + EVENT_KEY, |
||
6065 | SHOW: "show" + EVENT_KEY, |
||
6066 | SHOWN: "shown" + EVENT_KEY, |
||
6067 | CLICK_DATA_API: "click" + EVENT_KEY + DATA_API_KEY |
||
6068 | }; |
||
6069 | var ClassName = { |
||
6070 | DROPDOWN_MENU: 'dropdown-menu', |
||
6071 | ACTIVE: 'active', |
||
6072 | DISABLED: 'disabled', |
||
6073 | FADE: 'fade', |
||
6074 | SHOW: 'show' |
||
6075 | }; |
||
6076 | var Selector = { |
||
6077 | DROPDOWN: '.dropdown', |
||
6078 | NAV_LIST_GROUP: '.nav, .list-group', |
||
6079 | ACTIVE: '.active', |
||
6080 | ACTIVE_UL: '> li > .active', |
||
6081 | DATA_TOGGLE: '[data-toggle="tab"], [data-toggle="pill"], [data-toggle="list"]', |
||
6082 | DROPDOWN_TOGGLE: '.dropdown-toggle', |
||
6083 | DROPDOWN_ACTIVE_CHILD: '> .dropdown-menu .active' |
||
6084 | /** |
||
6085 | * ------------------------------------------------------------------------ |
||
6086 | * Class Definition |
||
6087 | * ------------------------------------------------------------------------ |
||
6088 | */ |
||
6089 | |||
6090 | }; |
||
6091 | |||
6092 | var Tab = |
||
6093 | /*#__PURE__*/ |
||
6094 | function () { |
||
6095 | function Tab(element) { |
||
6096 | this._element = element; |
||
6097 | } // Getters |
||
6098 | |||
6099 | |||
6100 | var _proto = Tab.prototype; |
||
6101 | |||
6102 | // Public |
||
6103 | _proto.show = function show() { |
||
6104 | var _this = this; |
||
6105 | |||
6106 | if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && $$$1(this._element).hasClass(ClassName.ACTIVE) || $$$1(this._element).hasClass(ClassName.DISABLED)) { |
||
6107 | return; |
||
6108 | } |
||
6109 | |||
6110 | var target; |
||
6111 | var previous; |
||
6112 | var listElement = $$$1(this._element).closest(Selector.NAV_LIST_GROUP)[0]; |
||
6113 | var selector = Util.getSelectorFromElement(this._element); |
||
6114 | |||
6115 | if (listElement) { |
||
6116 | var itemSelector = listElement.nodeName === 'UL' ? Selector.ACTIVE_UL : Selector.ACTIVE; |
||
6117 | previous = $$$1.makeArray($$$1(listElement).find(itemSelector)); |
||
6118 | previous = previous[previous.length - 1]; |
||
6119 | } |
||
6120 | |||
6121 | var hideEvent = $$$1.Event(Event.HIDE, { |
||
6122 | relatedTarget: this._element |
||
6123 | }); |
||
6124 | var showEvent = $$$1.Event(Event.SHOW, { |
||
6125 | relatedTarget: previous |
||
6126 | }); |
||
6127 | |||
6128 | if (previous) { |
||
6129 | $$$1(previous).trigger(hideEvent); |
||
6130 | } |
||
6131 | |||
6132 | $$$1(this._element).trigger(showEvent); |
||
6133 | |||
6134 | if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) { |
||
6135 | return; |
||
6136 | } |
||
6137 | |||
6138 | if (selector) { |
||
6139 | target = $$$1(selector)[0]; |
||
6140 | } |
||
6141 | |||
6142 | this._activate(this._element, listElement); |
||
6143 | |||
6144 | var complete = function complete() { |
||
6145 | var hiddenEvent = $$$1.Event(Event.HIDDEN, { |
||
6146 | relatedTarget: _this._element |
||
6147 | }); |
||
6148 | var shownEvent = $$$1.Event(Event.SHOWN, { |
||
6149 | relatedTarget: previous |
||
6150 | }); |
||
6151 | $$$1(previous).trigger(hiddenEvent); |
||
6152 | $$$1(_this._element).trigger(shownEvent); |
||
6153 | }; |
||
6154 | |||
6155 | if (target) { |
||
6156 | this._activate(target, target.parentNode, complete); |
||
6157 | } else { |
||
6158 | complete(); |
||
6159 | } |
||
6160 | }; |
||
6161 | |||
6162 | _proto.dispose = function dispose() { |
||
6163 | $$$1.removeData(this._element, DATA_KEY); |
||
6164 | this._element = null; |
||
6165 | }; // Private |
||
6166 | |||
6167 | |||
6168 | _proto._activate = function _activate(element, container, callback) { |
||
6169 | var _this2 = this; |
||
6170 | |||
6171 | var activeElements; |
||
6172 | |||
6173 | if (container.nodeName === 'UL') { |
||
6174 | activeElements = $$$1(container).find(Selector.ACTIVE_UL); |
||
6175 | } else { |
||
6176 | activeElements = $$$1(container).children(Selector.ACTIVE); |
||
6177 | } |
||
6178 | |||
6179 | var active = activeElements[0]; |
||
6180 | var isTransitioning = callback && Util.supportsTransitionEnd() && active && $$$1(active).hasClass(ClassName.FADE); |
||
6181 | |||
6182 | var complete = function complete() { |
||
6183 | return _this2._transitionComplete(element, active, callback); |
||
6184 | }; |
||
6185 | |||
6186 | if (active && isTransitioning) { |
||
6187 | $$$1(active).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
||
6188 | } else { |
||
6189 | complete(); |
||
6190 | } |
||
6191 | }; |
||
6192 | |||
6193 | _proto._transitionComplete = function _transitionComplete(element, active, callback) { |
||
6194 | if (active) { |
||
6195 | $$$1(active).removeClass(ClassName.SHOW + " " + ClassName.ACTIVE); |
||
6196 | var dropdownChild = $$$1(active.parentNode).find(Selector.DROPDOWN_ACTIVE_CHILD)[0]; |
||
6197 | |||
6198 | if (dropdownChild) { |
||
6199 | $$$1(dropdownChild).removeClass(ClassName.ACTIVE); |
||
6200 | } |
||
6201 | |||
6202 | if (active.getAttribute('role') === 'tab') { |
||
6203 | active.setAttribute('aria-selected', false); |
||
6204 | } |
||
6205 | } |
||
6206 | |||
6207 | $$$1(element).addClass(ClassName.ACTIVE); |
||
6208 | |||
6209 | if (element.getAttribute('role') === 'tab') { |
||
6210 | element.setAttribute('aria-selected', true); |
||
6211 | } |
||
6212 | |||
6213 | Util.reflow(element); |
||
6214 | $$$1(element).addClass(ClassName.SHOW); |
||
6215 | |||
6216 | if (element.parentNode && $$$1(element.parentNode).hasClass(ClassName.DROPDOWN_MENU)) { |
||
6217 | var dropdownElement = $$$1(element).closest(Selector.DROPDOWN)[0]; |
||
6218 | |||
6219 | if (dropdownElement) { |
||
6220 | $$$1(dropdownElement).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE); |
||
6221 | } |
||
6222 | |||
6223 | element.setAttribute('aria-expanded', true); |
||
6224 | } |
||
6225 | |||
6226 | if (callback) { |
||
6227 | callback(); |
||
6228 | } |
||
6229 | }; // Static |
||
6230 | |||
6231 | |||
6232 | Tab._jQueryInterface = function _jQueryInterface(config) { |
||
6233 | return this.each(function () { |
||
6234 | var $this = $$$1(this); |
||
6235 | var data = $this.data(DATA_KEY); |
||
6236 | |||
6237 | if (!data) { |
||
6238 | data = new Tab(this); |
||
6239 | $this.data(DATA_KEY, data); |
||
6240 | } |
||
6241 | |||
6242 | if (typeof config === 'string') { |
||
6243 | if (typeof data[config] === 'undefined') { |
||
6244 | throw new TypeError("No method named \"" + config + "\""); |
||
6245 | } |
||
6246 | |||
6247 | data[config](); |
||
6248 | } |
||
6249 | }); |
||
6250 | }; |
||
6251 | |||
6252 | _createClass(Tab, null, [{ |
||
6253 | key: "VERSION", |
||
6254 | get: function get() { |
||
6255 | return VERSION; |
||
6256 | } |
||
6257 | }]); |
||
6258 | return Tab; |
||
6259 | }(); |
||
6260 | /** |
||
6261 | * ------------------------------------------------------------------------ |
||
6262 | * Data Api implementation |
||
6263 | * ------------------------------------------------------------------------ |
||
6264 | */ |
||
6265 | |||
6266 | |||
6267 | $$$1(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) { |
||
6268 | event.preventDefault(); |
||
6269 | |||
6270 | Tab._jQueryInterface.call($$$1(this), 'show'); |
||
6271 | }); |
||
6272 | /** |
||
6273 | * ------------------------------------------------------------------------ |
||
6274 | * jQuery |
||
6275 | * ------------------------------------------------------------------------ |
||
6276 | */ |
||
6277 | |||
6278 | $$$1.fn[NAME] = Tab._jQueryInterface; |
||
6279 | $$$1.fn[NAME].Constructor = Tab; |
||
6280 | |||
6281 | $$$1.fn[NAME].noConflict = function () { |
||
6282 | $$$1.fn[NAME] = JQUERY_NO_CONFLICT; |
||
6283 | return Tab._jQueryInterface; |
||
6284 | }; |
||
6285 | |||
6286 | return Tab; |
||
6287 | }($); |
||
6288 | |||
6289 | /** |
||
6290 | * -------------------------------------------------------------------------- |
||
6291 | * Bootstrap (v4.0.0-alpha.6): index.js |
||
6292 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||
6293 | * -------------------------------------------------------------------------- |
||
6294 | */ |
||
6295 | |||
6296 | (function ($$$1) { |
||
6297 | if (typeof $$$1 === 'undefined') { |
||
6298 | throw new TypeError('Bootstrap\'s JavaScript requires jQuery. jQuery must be included before Bootstrap\'s JavaScript.'); |
||
6299 | } |
||
6300 | |||
6301 | var version = $$$1.fn.jquery.split(' ')[0].split('.'); |
||
6302 | var minMajor = 1; |
||
6303 | var ltMajor = 2; |
||
6304 | var minMinor = 9; |
||
6305 | var minPatch = 1; |
||
6306 | var maxMajor = 4; |
||
6307 | |||
6308 | if (version[0] < ltMajor && version[1] < minMinor || version[0] === minMajor && version[1] === minMinor && version[2] < minPatch || version[0] >= maxMajor) { |
||
6309 | throw new Error('Bootstrap\'s JavaScript requires at least jQuery v1.9.1 but less than v4.0.0'); |
||
6310 | } |
||
6311 | })($); |
||
6312 | |||
6313 | exports.Util = Util; |
||
6314 | exports.Alert = Alert; |
||
6315 | exports.Button = Button; |
||
6316 | exports.Carousel = Carousel; |
||
6317 | exports.Collapse = Collapse; |
||
6318 | exports.Dropdown = Dropdown; |
||
6319 | exports.Modal = Modal; |
||
6320 | exports.Popover = Popover; |
||
6321 | exports.Scrollspy = ScrollSpy; |
||
6322 | exports.Tab = Tab; |
||
6323 | exports.Tooltip = Tooltip; |
||
6324 | |||
6325 | Object.defineProperty(exports, '__esModule', { value: true }); |
||
6326 | |||
6327 | }))); |
||
6328 | //# sourceMappingURL=bootstrap.bundle.js.map |
||
6329 |