bootstrap 4.1.3 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +17 -2
  3. data/CHANGELOG.md +2 -14
  4. data/README.md +7 -4
  5. data/Rakefile +2 -2
  6. data/assets/javascripts/bootstrap/alert.js +226 -166
  7. data/assets/javascripts/bootstrap/base-component.js +63 -0
  8. data/assets/javascripts/bootstrap/button.js +119 -165
  9. data/assets/javascripts/bootstrap/carousel.js +634 -445
  10. data/assets/javascripts/bootstrap/collapse.js +447 -327
  11. data/assets/javascripts/bootstrap/dom/data.js +68 -0
  12. data/assets/javascripts/bootstrap/dom/event-handler.js +322 -0
  13. data/assets/javascripts/bootstrap/dom/manipulator.js +88 -0
  14. data/assets/javascripts/bootstrap/dom/selector-engine.js +85 -0
  15. data/assets/javascripts/bootstrap/dropdown.js +550 -425
  16. data/assets/javascripts/bootstrap/modal.js +695 -492
  17. data/assets/javascripts/bootstrap/offcanvas.js +671 -0
  18. data/assets/javascripts/bootstrap/popover.js +167 -217
  19. data/assets/javascripts/bootstrap/scrollspy.js +319 -302
  20. data/assets/javascripts/bootstrap/tab.js +303 -221
  21. data/assets/javascripts/bootstrap/toast.js +333 -0
  22. data/assets/javascripts/bootstrap/tooltip.js +896 -577
  23. data/assets/javascripts/bootstrap-global-this-define.js +6 -0
  24. data/assets/javascripts/bootstrap-global-this-undefine.js +2 -0
  25. data/assets/javascripts/bootstrap-sprockets.js +15 -7
  26. data/assets/javascripts/bootstrap.js +4262 -3163
  27. data/assets/javascripts/bootstrap.min.js +4 -4
  28. data/assets/stylesheets/_bootstrap-grid.scss +54 -21
  29. data/assets/stylesheets/_bootstrap-reboot.scss +7 -4
  30. data/assets/stylesheets/_bootstrap.scss +21 -11
  31. data/assets/stylesheets/bootstrap/_accordion.scss +118 -0
  32. data/assets/stylesheets/bootstrap/_alert.scss +15 -9
  33. data/assets/stylesheets/bootstrap/_badge.scss +3 -21
  34. data/assets/stylesheets/bootstrap/_breadcrumb.scss +5 -18
  35. data/assets/stylesheets/bootstrap/_button-group.scss +29 -62
  36. data/assets/stylesheets/bootstrap/_buttons.scss +33 -65
  37. data/assets/stylesheets/bootstrap/_card.scss +55 -141
  38. data/assets/stylesheets/bootstrap/_carousel.scss +94 -101
  39. data/assets/stylesheets/bootstrap/_close.scss +33 -28
  40. data/assets/stylesheets/bootstrap/_containers.scss +41 -0
  41. data/assets/stylesheets/bootstrap/_dropdown.scss +114 -40
  42. data/assets/stylesheets/bootstrap/_forms.scss +9 -333
  43. data/assets/stylesheets/bootstrap/_functions.scss +148 -29
  44. data/assets/stylesheets/bootstrap/_grid.scss +4 -34
  45. data/assets/stylesheets/bootstrap/_helpers.scss +7 -0
  46. data/assets/stylesheets/bootstrap/_images.scss +4 -4
  47. data/assets/stylesheets/bootstrap/_list-group.scss +86 -27
  48. data/assets/stylesheets/bootstrap/_mixins.scss +17 -16
  49. data/assets/stylesheets/bootstrap/_modal.scss +90 -42
  50. data/assets/stylesheets/bootstrap/_nav.scss +31 -10
  51. data/assets/stylesheets/bootstrap/_navbar.scss +68 -61
  52. data/assets/stylesheets/bootstrap/_offcanvas.scss +77 -0
  53. data/assets/stylesheets/bootstrap/_pagination.scss +13 -27
  54. data/assets/stylesheets/bootstrap/_popover.scss +63 -88
  55. data/assets/stylesheets/bootstrap/_progress.scss +20 -6
  56. data/assets/stylesheets/bootstrap/_reboot.scss +349 -211
  57. data/assets/stylesheets/bootstrap/_root.scss +5 -8
  58. data/assets/stylesheets/bootstrap/_spinners.scss +69 -0
  59. data/assets/stylesheets/bootstrap/_tables.scss +79 -116
  60. data/assets/stylesheets/bootstrap/_toasts.scss +51 -0
  61. data/assets/stylesheets/bootstrap/_tooltip.scss +18 -18
  62. data/assets/stylesheets/bootstrap/_transitions.scss +2 -3
  63. data/assets/stylesheets/bootstrap/_type.scss +42 -63
  64. data/assets/stylesheets/bootstrap/_utilities.scss +594 -15
  65. data/assets/stylesheets/bootstrap/_variables.scss +952 -440
  66. data/assets/stylesheets/bootstrap/bootstrap-utilities.scss +18 -0
  67. data/assets/stylesheets/bootstrap/forms/_floating-labels.scss +61 -0
  68. data/assets/stylesheets/bootstrap/forms/_form-check.scss +152 -0
  69. data/assets/stylesheets/bootstrap/forms/_form-control.scss +219 -0
  70. data/assets/stylesheets/bootstrap/forms/_form-range.scss +91 -0
  71. data/assets/stylesheets/bootstrap/forms/_form-select.scss +67 -0
  72. data/assets/stylesheets/bootstrap/forms/_form-text.scss +11 -0
  73. data/assets/stylesheets/bootstrap/forms/_input-group.scss +121 -0
  74. data/assets/stylesheets/bootstrap/forms/_labels.scss +36 -0
  75. data/assets/stylesheets/bootstrap/forms/_validation.scss +12 -0
  76. data/assets/stylesheets/bootstrap/helpers/_colored-links.scss +12 -0
  77. data/assets/stylesheets/bootstrap/helpers/_position.scss +30 -0
  78. data/assets/stylesheets/bootstrap/helpers/_ratio.scss +26 -0
  79. data/assets/stylesheets/bootstrap/helpers/_stretched-link.scss +15 -0
  80. data/assets/stylesheets/bootstrap/helpers/_text-truncation.scss +7 -0
  81. data/assets/stylesheets/bootstrap/helpers/_visually-hidden.scss +8 -0
  82. data/assets/stylesheets/bootstrap/mixins/_alert.scss +3 -5
  83. data/assets/stylesheets/bootstrap/mixins/_border-radius.scss +57 -14
  84. data/assets/stylesheets/bootstrap/mixins/_box-shadow.scss +14 -1
  85. data/assets/stylesheets/bootstrap/mixins/_breakpoints.scss +13 -9
  86. data/assets/stylesheets/bootstrap/mixins/_buttons.scss +77 -53
  87. data/assets/stylesheets/bootstrap/mixins/_caret.scss +14 -16
  88. data/assets/stylesheets/bootstrap/mixins/_clearfix.scss +2 -0
  89. data/assets/stylesheets/bootstrap/mixins/_color-scheme.scss +7 -0
  90. data/assets/stylesheets/bootstrap/mixins/_container.scss +9 -0
  91. data/assets/stylesheets/bootstrap/mixins/_deprecate.scss +10 -0
  92. data/assets/stylesheets/bootstrap/mixins/_forms.scss +87 -97
  93. data/assets/stylesheets/bootstrap/mixins/_gradients.scss +13 -11
  94. data/assets/stylesheets/bootstrap/mixins/_grid.scss +106 -33
  95. data/assets/stylesheets/bootstrap/mixins/_image.scss +0 -20
  96. data/assets/stylesheets/bootstrap/mixins/_list-group.scss +5 -2
  97. data/assets/stylesheets/bootstrap/mixins/_pagination.scss +18 -9
  98. data/assets/stylesheets/bootstrap/mixins/_reset-text.scss +2 -2
  99. data/assets/stylesheets/bootstrap/mixins/_table-variants.scss +21 -0
  100. data/assets/stylesheets/bootstrap/mixins/_transition.scss +19 -6
  101. data/assets/stylesheets/bootstrap/mixins/_utilities.scss +68 -0
  102. data/assets/stylesheets/bootstrap/mixins/_visually-hidden.scss +29 -0
  103. data/assets/stylesheets/bootstrap/utilities/_api.scss +47 -0
  104. data/assets/stylesheets/bootstrap/vendor/_rfs.scss +312 -0
  105. data/bootstrap.gemspec +7 -6
  106. data/lib/bootstrap/engine.rb +3 -0
  107. data/lib/bootstrap/version.rb +4 -2
  108. data/lib/bootstrap.rb +10 -7
  109. data/tasks/updater/js.rb +20 -5
  110. data/tasks/updater/network.rb +8 -2
  111. data/test/dummy_rails/app/assets/config/manifest.js +3 -0
  112. data/test/dummy_rails/app/assets/javascripts/application.js +4 -3
  113. data/test/dummy_rails/app/assets/stylesheets/.browserslistrc +1 -0
  114. data/test/dummy_rails/app/views/layouts/application.html.erb +3 -1
  115. data/test/dummy_rails/app/views/pages/root.html +89 -0
  116. data/test/dummy_rails/config/application.rb +0 -3
  117. data/test/gemfiles/rails_6_0.gemfile +7 -0
  118. data/test/gemfiles/rails_6_1.gemfile +7 -0
  119. data/test/support/dummy_rails_integration.rb +3 -1
  120. data/test/test_helper.rb +18 -13
  121. metadata +64 -79
  122. data/assets/javascripts/bootstrap/util.js +0 -143
  123. data/assets/stylesheets/bootstrap/_code.scss +0 -48
  124. data/assets/stylesheets/bootstrap/_custom-forms.scss +0 -433
  125. data/assets/stylesheets/bootstrap/_input-group.scss +0 -173
  126. data/assets/stylesheets/bootstrap/_jumbotron.scss +0 -16
  127. data/assets/stylesheets/bootstrap/_media.scss +0 -8
  128. data/assets/stylesheets/bootstrap/_print.scss +0 -141
  129. data/assets/stylesheets/bootstrap/mixins/_background-variant.scss +0 -21
  130. data/assets/stylesheets/bootstrap/mixins/_badge.scss +0 -12
  131. data/assets/stylesheets/bootstrap/mixins/_float.scss +0 -11
  132. data/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +0 -67
  133. data/assets/stylesheets/bootstrap/mixins/_hover.scss +0 -37
  134. data/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +0 -10
  135. data/assets/stylesheets/bootstrap/mixins/_screen-reader.scss +0 -33
  136. data/assets/stylesheets/bootstrap/mixins/_size.scss +0 -6
  137. data/assets/stylesheets/bootstrap/mixins/_table-row.scss +0 -30
  138. data/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +0 -14
  139. data/assets/stylesheets/bootstrap/mixins/_text-hide.scss +0 -13
  140. data/assets/stylesheets/bootstrap/mixins/_visibility.scss +0 -7
  141. data/assets/stylesheets/bootstrap/utilities/_align.scss +0 -8
  142. data/assets/stylesheets/bootstrap/utilities/_background.scss +0 -19
  143. data/assets/stylesheets/bootstrap/utilities/_borders.scss +0 -59
  144. data/assets/stylesheets/bootstrap/utilities/_display.scss +0 -38
  145. data/assets/stylesheets/bootstrap/utilities/_embed.scss +0 -52
  146. data/assets/stylesheets/bootstrap/utilities/_flex.scss +0 -51
  147. data/assets/stylesheets/bootstrap/utilities/_float.scss +0 -9
  148. data/assets/stylesheets/bootstrap/utilities/_position.scss +0 -37
  149. data/assets/stylesheets/bootstrap/utilities/_screenreaders.scss +0 -11
  150. data/assets/stylesheets/bootstrap/utilities/_shadows.scss +0 -6
  151. data/assets/stylesheets/bootstrap/utilities/_sizing.scss +0 -12
  152. data/assets/stylesheets/bootstrap/utilities/_spacing.scss +0 -51
  153. data/assets/stylesheets/bootstrap/utilities/_text.scss +0 -58
  154. data/assets/stylesheets/bootstrap/utilities/_visibility.scss +0 -11
  155. data/test/dummy_rails/app/views/pages/root.html.slim +0 -58
  156. /data/assets/stylesheets/bootstrap/{utilities → helpers}/_clearfix.scss +0 -0
@@ -0,0 +1,671 @@
1
+ /*!
2
+ * Bootstrap offcanvas.js v5.0.0 (https://getbootstrap.com/)
3
+ * Copyright 2011-2021 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
4
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
5
+ */
6
+ (function (global, factory) {
7
+ typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('./dom/selector-engine.js'), require('./dom/manipulator.js'), require('./dom/data.js'), require('./dom/event-handler.js'), require('./base-component.js')) :
8
+ typeof define === 'function' && define.amd ? define(['./dom/selector-engine', './dom/manipulator', './dom/data', './dom/event-handler', './base-component'], factory) :
9
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Offcanvas = factory(global.SelectorEngine, global.Manipulator, global.Data, global.EventHandler, global.Base));
10
+ }(this, (function (SelectorEngine, Manipulator, Data, EventHandler, BaseComponent) { 'use strict';
11
+
12
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
13
+
14
+ var SelectorEngine__default = /*#__PURE__*/_interopDefaultLegacy(SelectorEngine);
15
+ var Manipulator__default = /*#__PURE__*/_interopDefaultLegacy(Manipulator);
16
+ var Data__default = /*#__PURE__*/_interopDefaultLegacy(Data);
17
+ var EventHandler__default = /*#__PURE__*/_interopDefaultLegacy(EventHandler);
18
+ var BaseComponent__default = /*#__PURE__*/_interopDefaultLegacy(BaseComponent);
19
+
20
+ /**
21
+ * --------------------------------------------------------------------------
22
+ * Bootstrap (v5.0.0): util/index.js
23
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
24
+ * --------------------------------------------------------------------------
25
+ */
26
+ const MILLISECONDS_MULTIPLIER = 1000;
27
+ const TRANSITION_END = 'transitionend'; // Shoutout AngusCroll (https://goo.gl/pxwQGp)
28
+
29
+ const toType = obj => {
30
+ if (obj === null || obj === undefined) {
31
+ return `${obj}`;
32
+ }
33
+
34
+ return {}.toString.call(obj).match(/\s([a-z]+)/i)[1].toLowerCase();
35
+ };
36
+
37
+ const getSelector = element => {
38
+ let selector = element.getAttribute('data-bs-target');
39
+
40
+ if (!selector || selector === '#') {
41
+ let hrefAttr = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes,
42
+ // so everything starting with `#` or `.`. If a "real" URL is used as the selector,
43
+ // `document.querySelector` will rightfully complain it is invalid.
44
+ // See https://github.com/twbs/bootstrap/issues/32273
45
+
46
+ if (!hrefAttr || !hrefAttr.includes('#') && !hrefAttr.startsWith('.')) {
47
+ return null;
48
+ } // Just in case some CMS puts out a full URL with the anchor appended
49
+
50
+
51
+ if (hrefAttr.includes('#') && !hrefAttr.startsWith('#')) {
52
+ hrefAttr = `#${hrefAttr.split('#')[1]}`;
53
+ }
54
+
55
+ selector = hrefAttr && hrefAttr !== '#' ? hrefAttr.trim() : null;
56
+ }
57
+
58
+ return selector;
59
+ };
60
+
61
+ const getElementFromSelector = element => {
62
+ const selector = getSelector(element);
63
+ return selector ? document.querySelector(selector) : null;
64
+ };
65
+
66
+ const getTransitionDurationFromElement = element => {
67
+ if (!element) {
68
+ return 0;
69
+ } // Get transition-duration of the element
70
+
71
+
72
+ let {
73
+ transitionDuration,
74
+ transitionDelay
75
+ } = window.getComputedStyle(element);
76
+ const floatTransitionDuration = Number.parseFloat(transitionDuration);
77
+ const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found
78
+
79
+ if (!floatTransitionDuration && !floatTransitionDelay) {
80
+ return 0;
81
+ } // If multiple durations are defined, take the first
82
+
83
+
84
+ transitionDuration = transitionDuration.split(',')[0];
85
+ transitionDelay = transitionDelay.split(',')[0];
86
+ return (Number.parseFloat(transitionDuration) + Number.parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER;
87
+ };
88
+
89
+ const triggerTransitionEnd = element => {
90
+ element.dispatchEvent(new Event(TRANSITION_END));
91
+ };
92
+
93
+ const isElement = obj => (obj[0] || obj).nodeType;
94
+
95
+ const emulateTransitionEnd = (element, duration) => {
96
+ let called = false;
97
+ const durationPadding = 5;
98
+ const emulatedDuration = duration + durationPadding;
99
+
100
+ function listener() {
101
+ called = true;
102
+ element.removeEventListener(TRANSITION_END, listener);
103
+ }
104
+
105
+ element.addEventListener(TRANSITION_END, listener);
106
+ setTimeout(() => {
107
+ if (!called) {
108
+ triggerTransitionEnd(element);
109
+ }
110
+ }, emulatedDuration);
111
+ };
112
+
113
+ const typeCheckConfig = (componentName, config, configTypes) => {
114
+ Object.keys(configTypes).forEach(property => {
115
+ const expectedTypes = configTypes[property];
116
+ const value = config[property];
117
+ const valueType = value && isElement(value) ? 'element' : toType(value);
118
+
119
+ if (!new RegExp(expectedTypes).test(valueType)) {
120
+ throw new TypeError(`${componentName.toUpperCase()}: Option "${property}" provided type "${valueType}" but expected type "${expectedTypes}".`);
121
+ }
122
+ });
123
+ };
124
+
125
+ const isVisible = element => {
126
+ if (!element) {
127
+ return false;
128
+ }
129
+
130
+ if (element.style && element.parentNode && element.parentNode.style) {
131
+ const elementStyle = getComputedStyle(element);
132
+ const parentNodeStyle = getComputedStyle(element.parentNode);
133
+ return elementStyle.display !== 'none' && parentNodeStyle.display !== 'none' && elementStyle.visibility !== 'hidden';
134
+ }
135
+
136
+ return false;
137
+ };
138
+
139
+ const isDisabled = element => {
140
+ if (!element || element.nodeType !== Node.ELEMENT_NODE) {
141
+ return true;
142
+ }
143
+
144
+ if (element.classList.contains('disabled')) {
145
+ return true;
146
+ }
147
+
148
+ if (typeof element.disabled !== 'undefined') {
149
+ return element.disabled;
150
+ }
151
+
152
+ return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false';
153
+ };
154
+
155
+ const reflow = element => element.offsetHeight;
156
+
157
+ const getjQuery = () => {
158
+ const {
159
+ jQuery
160
+ } = window;
161
+
162
+ if (jQuery && !document.body.hasAttribute('data-bs-no-jquery')) {
163
+ return jQuery;
164
+ }
165
+
166
+ return null;
167
+ };
168
+
169
+ const onDOMContentLoaded = callback => {
170
+ if (document.readyState === 'loading') {
171
+ document.addEventListener('DOMContentLoaded', callback);
172
+ } else {
173
+ callback();
174
+ }
175
+ };
176
+
177
+ const defineJQueryPlugin = (name, plugin) => {
178
+ onDOMContentLoaded(() => {
179
+ const $ = getjQuery();
180
+ /* istanbul ignore if */
181
+
182
+ if ($) {
183
+ const JQUERY_NO_CONFLICT = $.fn[name];
184
+ $.fn[name] = plugin.jQueryInterface;
185
+ $.fn[name].Constructor = plugin;
186
+
187
+ $.fn[name].noConflict = () => {
188
+ $.fn[name] = JQUERY_NO_CONFLICT;
189
+ return plugin.jQueryInterface;
190
+ };
191
+ }
192
+ });
193
+ };
194
+
195
+ const execute = callback => {
196
+ if (typeof callback === 'function') {
197
+ callback();
198
+ }
199
+ };
200
+
201
+ /**
202
+ * --------------------------------------------------------------------------
203
+ * Bootstrap (v5.0.0): util/scrollBar.js
204
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
205
+ * --------------------------------------------------------------------------
206
+ */
207
+ const SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top';
208
+ const SELECTOR_STICKY_CONTENT = '.sticky-top';
209
+
210
+ const getWidth = () => {
211
+ // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes
212
+ const documentWidth = document.documentElement.clientWidth;
213
+ return Math.abs(window.innerWidth - documentWidth);
214
+ };
215
+
216
+ const hide = (width = getWidth()) => {
217
+ _disableOverFlow(); // give padding to element to balances the hidden scrollbar width
218
+
219
+
220
+ _setElementAttributes('body', 'paddingRight', calculatedValue => calculatedValue + width); // trick: We adjust positive paddingRight and negative marginRight to sticky-top elements, to keep shown fullwidth
221
+
222
+
223
+ _setElementAttributes(SELECTOR_FIXED_CONTENT, 'paddingRight', calculatedValue => calculatedValue + width);
224
+
225
+ _setElementAttributes(SELECTOR_STICKY_CONTENT, 'marginRight', calculatedValue => calculatedValue - width);
226
+ };
227
+
228
+ const _disableOverFlow = () => {
229
+ const actualValue = document.body.style.overflow;
230
+
231
+ if (actualValue) {
232
+ Manipulator__default['default'].setDataAttribute(document.body, 'overflow', actualValue);
233
+ }
234
+
235
+ document.body.style.overflow = 'hidden';
236
+ };
237
+
238
+ const _setElementAttributes = (selector, styleProp, callback) => {
239
+ const scrollbarWidth = getWidth();
240
+ SelectorEngine__default['default'].find(selector).forEach(element => {
241
+ if (element !== document.body && window.innerWidth > element.clientWidth + scrollbarWidth) {
242
+ return;
243
+ }
244
+
245
+ const actualValue = element.style[styleProp];
246
+ const calculatedValue = window.getComputedStyle(element)[styleProp];
247
+ Manipulator__default['default'].setDataAttribute(element, styleProp, actualValue);
248
+ element.style[styleProp] = `${callback(Number.parseFloat(calculatedValue))}px`;
249
+ });
250
+ };
251
+
252
+ const reset = () => {
253
+ _resetElementAttributes('body', 'overflow');
254
+
255
+ _resetElementAttributes('body', 'paddingRight');
256
+
257
+ _resetElementAttributes(SELECTOR_FIXED_CONTENT, 'paddingRight');
258
+
259
+ _resetElementAttributes(SELECTOR_STICKY_CONTENT, 'marginRight');
260
+ };
261
+
262
+ const _resetElementAttributes = (selector, styleProp) => {
263
+ SelectorEngine__default['default'].find(selector).forEach(element => {
264
+ const value = Manipulator__default['default'].getDataAttribute(element, styleProp);
265
+
266
+ if (typeof value === 'undefined') {
267
+ element.style.removeProperty(styleProp);
268
+ } else {
269
+ Manipulator__default['default'].removeDataAttribute(element, styleProp);
270
+ element.style[styleProp] = value;
271
+ }
272
+ });
273
+ };
274
+
275
+ /**
276
+ * --------------------------------------------------------------------------
277
+ * Bootstrap (v5.0.0): util/backdrop.js
278
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
279
+ * --------------------------------------------------------------------------
280
+ */
281
+ const Default$1 = {
282
+ isVisible: true,
283
+ // if false, we use the backdrop helper without adding any element to the dom
284
+ isAnimated: false,
285
+ rootElement: document.body,
286
+ // give the choice to place backdrop under different elements
287
+ clickCallback: null
288
+ };
289
+ const DefaultType$1 = {
290
+ isVisible: 'boolean',
291
+ isAnimated: 'boolean',
292
+ rootElement: 'element',
293
+ clickCallback: '(function|null)'
294
+ };
295
+ const NAME$1 = 'backdrop';
296
+ const CLASS_NAME_BACKDROP = 'modal-backdrop';
297
+ const CLASS_NAME_FADE = 'fade';
298
+ const CLASS_NAME_SHOW$1 = 'show';
299
+ const EVENT_MOUSEDOWN = `mousedown.bs.${NAME$1}`;
300
+
301
+ class Backdrop {
302
+ constructor(config) {
303
+ this._config = this._getConfig(config);
304
+ this._isAppended = false;
305
+ this._element = null;
306
+ }
307
+
308
+ show(callback) {
309
+ if (!this._config.isVisible) {
310
+ execute(callback);
311
+ return;
312
+ }
313
+
314
+ this._append();
315
+
316
+ if (this._config.isAnimated) {
317
+ reflow(this._getElement());
318
+ }
319
+
320
+ this._getElement().classList.add(CLASS_NAME_SHOW$1);
321
+
322
+ this._emulateAnimation(() => {
323
+ execute(callback);
324
+ });
325
+ }
326
+
327
+ hide(callback) {
328
+ if (!this._config.isVisible) {
329
+ execute(callback);
330
+ return;
331
+ }
332
+
333
+ this._getElement().classList.remove(CLASS_NAME_SHOW$1);
334
+
335
+ this._emulateAnimation(() => {
336
+ this.dispose();
337
+ execute(callback);
338
+ });
339
+ } // Private
340
+
341
+
342
+ _getElement() {
343
+ if (!this._element) {
344
+ const backdrop = document.createElement('div');
345
+ backdrop.className = CLASS_NAME_BACKDROP;
346
+
347
+ if (this._config.isAnimated) {
348
+ backdrop.classList.add(CLASS_NAME_FADE);
349
+ }
350
+
351
+ this._element = backdrop;
352
+ }
353
+
354
+ return this._element;
355
+ }
356
+
357
+ _getConfig(config) {
358
+ config = { ...Default$1,
359
+ ...(typeof config === 'object' ? config : {})
360
+ };
361
+ typeCheckConfig(NAME$1, config, DefaultType$1);
362
+ return config;
363
+ }
364
+
365
+ _append() {
366
+ if (this._isAppended) {
367
+ return;
368
+ }
369
+
370
+ this._config.rootElement.appendChild(this._getElement());
371
+
372
+ EventHandler__default['default'].on(this._getElement(), EVENT_MOUSEDOWN, () => {
373
+ execute(this._config.clickCallback);
374
+ });
375
+ this._isAppended = true;
376
+ }
377
+
378
+ dispose() {
379
+ if (!this._isAppended) {
380
+ return;
381
+ }
382
+
383
+ EventHandler__default['default'].off(this._element, EVENT_MOUSEDOWN);
384
+
385
+ this._getElement().parentNode.removeChild(this._element);
386
+
387
+ this._isAppended = false;
388
+ }
389
+
390
+ _emulateAnimation(callback) {
391
+ if (!this._config.isAnimated) {
392
+ execute(callback);
393
+ return;
394
+ }
395
+
396
+ const backdropTransitionDuration = getTransitionDurationFromElement(this._getElement());
397
+ EventHandler__default['default'].one(this._getElement(), 'transitionend', () => execute(callback));
398
+ emulateTransitionEnd(this._getElement(), backdropTransitionDuration);
399
+ }
400
+
401
+ }
402
+
403
+ /**
404
+ * --------------------------------------------------------------------------
405
+ * Bootstrap (v5.0.0): offcanvas.js
406
+ * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
407
+ * --------------------------------------------------------------------------
408
+ */
409
+ /**
410
+ * ------------------------------------------------------------------------
411
+ * Constants
412
+ * ------------------------------------------------------------------------
413
+ */
414
+
415
+ const NAME = 'offcanvas';
416
+ const DATA_KEY = 'bs.offcanvas';
417
+ const EVENT_KEY = `.${DATA_KEY}`;
418
+ const DATA_API_KEY = '.data-api';
419
+ const EVENT_LOAD_DATA_API = `load${EVENT_KEY}${DATA_API_KEY}`;
420
+ const ESCAPE_KEY = 'Escape';
421
+ const Default = {
422
+ backdrop: true,
423
+ keyboard: true,
424
+ scroll: false
425
+ };
426
+ const DefaultType = {
427
+ backdrop: 'boolean',
428
+ keyboard: 'boolean',
429
+ scroll: 'boolean'
430
+ };
431
+ const CLASS_NAME_SHOW = 'show';
432
+ const OPEN_SELECTOR = '.offcanvas.show';
433
+ const EVENT_SHOW = `show${EVENT_KEY}`;
434
+ const EVENT_SHOWN = `shown${EVENT_KEY}`;
435
+ const EVENT_HIDE = `hide${EVENT_KEY}`;
436
+ const EVENT_HIDDEN = `hidden${EVENT_KEY}`;
437
+ const EVENT_FOCUSIN = `focusin${EVENT_KEY}`;
438
+ const EVENT_CLICK_DATA_API = `click${EVENT_KEY}${DATA_API_KEY}`;
439
+ const EVENT_CLICK_DISMISS = `click.dismiss${EVENT_KEY}`;
440
+ const EVENT_KEYDOWN_DISMISS = `keydown.dismiss${EVENT_KEY}`;
441
+ const SELECTOR_DATA_DISMISS = '[data-bs-dismiss="offcanvas"]';
442
+ const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="offcanvas"]';
443
+ /**
444
+ * ------------------------------------------------------------------------
445
+ * Class Definition
446
+ * ------------------------------------------------------------------------
447
+ */
448
+
449
+ class Offcanvas extends BaseComponent__default['default'] {
450
+ constructor(element, config) {
451
+ super(element);
452
+ this._config = this._getConfig(config);
453
+ this._isShown = false;
454
+ this._backdrop = this._initializeBackDrop();
455
+
456
+ this._addEventListeners();
457
+ } // Getters
458
+
459
+
460
+ static get Default() {
461
+ return Default;
462
+ }
463
+
464
+ static get DATA_KEY() {
465
+ return DATA_KEY;
466
+ } // Public
467
+
468
+
469
+ toggle(relatedTarget) {
470
+ return this._isShown ? this.hide() : this.show(relatedTarget);
471
+ }
472
+
473
+ show(relatedTarget) {
474
+ if (this._isShown) {
475
+ return;
476
+ }
477
+
478
+ const showEvent = EventHandler__default['default'].trigger(this._element, EVENT_SHOW, {
479
+ relatedTarget
480
+ });
481
+
482
+ if (showEvent.defaultPrevented) {
483
+ return;
484
+ }
485
+
486
+ this._isShown = true;
487
+ this._element.style.visibility = 'visible';
488
+
489
+ this._backdrop.show();
490
+
491
+ if (!this._config.scroll) {
492
+ hide();
493
+
494
+ this._enforceFocusOnElement(this._element);
495
+ }
496
+
497
+ this._element.removeAttribute('aria-hidden');
498
+
499
+ this._element.setAttribute('aria-modal', true);
500
+
501
+ this._element.setAttribute('role', 'dialog');
502
+
503
+ this._element.classList.add(CLASS_NAME_SHOW);
504
+
505
+ const completeCallBack = () => {
506
+ EventHandler__default['default'].trigger(this._element, EVENT_SHOWN, {
507
+ relatedTarget
508
+ });
509
+ };
510
+
511
+ const transitionDuration = getTransitionDurationFromElement(this._element);
512
+ EventHandler__default['default'].one(this._element, 'transitionend', completeCallBack);
513
+ emulateTransitionEnd(this._element, transitionDuration);
514
+ }
515
+
516
+ hide() {
517
+ if (!this._isShown) {
518
+ return;
519
+ }
520
+
521
+ const hideEvent = EventHandler__default['default'].trigger(this._element, EVENT_HIDE);
522
+
523
+ if (hideEvent.defaultPrevented) {
524
+ return;
525
+ }
526
+
527
+ EventHandler__default['default'].off(document, EVENT_FOCUSIN);
528
+
529
+ this._element.blur();
530
+
531
+ this._isShown = false;
532
+
533
+ this._element.classList.remove(CLASS_NAME_SHOW);
534
+
535
+ this._backdrop.hide();
536
+
537
+ const completeCallback = () => {
538
+ this._element.setAttribute('aria-hidden', true);
539
+
540
+ this._element.removeAttribute('aria-modal');
541
+
542
+ this._element.removeAttribute('role');
543
+
544
+ this._element.style.visibility = 'hidden';
545
+
546
+ if (!this._config.scroll) {
547
+ reset();
548
+ }
549
+
550
+ EventHandler__default['default'].trigger(this._element, EVENT_HIDDEN);
551
+ };
552
+
553
+ const transitionDuration = getTransitionDurationFromElement(this._element);
554
+ EventHandler__default['default'].one(this._element, 'transitionend', completeCallback);
555
+ emulateTransitionEnd(this._element, transitionDuration);
556
+ }
557
+
558
+ dispose() {
559
+ this._backdrop.dispose();
560
+
561
+ super.dispose();
562
+ EventHandler__default['default'].off(document, EVENT_FOCUSIN);
563
+ this._config = null;
564
+ this._backdrop = null;
565
+ } // Private
566
+
567
+
568
+ _getConfig(config) {
569
+ config = { ...Default,
570
+ ...Manipulator__default['default'].getDataAttributes(this._element),
571
+ ...(typeof config === 'object' ? config : {})
572
+ };
573
+ typeCheckConfig(NAME, config, DefaultType);
574
+ return config;
575
+ }
576
+
577
+ _initializeBackDrop() {
578
+ return new Backdrop({
579
+ isVisible: this._config.backdrop,
580
+ isAnimated: true,
581
+ rootElement: this._element.parentNode,
582
+ clickCallback: () => this.hide()
583
+ });
584
+ }
585
+
586
+ _enforceFocusOnElement(element) {
587
+ EventHandler__default['default'].off(document, EVENT_FOCUSIN); // guard against infinite focus loop
588
+
589
+ EventHandler__default['default'].on(document, EVENT_FOCUSIN, event => {
590
+ if (document !== event.target && element !== event.target && !element.contains(event.target)) {
591
+ element.focus();
592
+ }
593
+ });
594
+ element.focus();
595
+ }
596
+
597
+ _addEventListeners() {
598
+ EventHandler__default['default'].on(this._element, EVENT_CLICK_DISMISS, SELECTOR_DATA_DISMISS, () => this.hide());
599
+ EventHandler__default['default'].on(this._element, EVENT_KEYDOWN_DISMISS, event => {
600
+ if (this._config.keyboard && event.key === ESCAPE_KEY) {
601
+ this.hide();
602
+ }
603
+ });
604
+ } // Static
605
+
606
+
607
+ static jQueryInterface(config) {
608
+ return this.each(function () {
609
+ const data = Data__default['default'].get(this, DATA_KEY) || new Offcanvas(this, typeof config === 'object' ? config : {});
610
+
611
+ if (typeof config !== 'string') {
612
+ return;
613
+ }
614
+
615
+ if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {
616
+ throw new TypeError(`No method named "${config}"`);
617
+ }
618
+
619
+ data[config](this);
620
+ });
621
+ }
622
+
623
+ }
624
+ /**
625
+ * ------------------------------------------------------------------------
626
+ * Data Api implementation
627
+ * ------------------------------------------------------------------------
628
+ */
629
+
630
+
631
+ EventHandler__default['default'].on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
632
+ const target = getElementFromSelector(this);
633
+
634
+ if (['A', 'AREA'].includes(this.tagName)) {
635
+ event.preventDefault();
636
+ }
637
+
638
+ if (isDisabled(this)) {
639
+ return;
640
+ }
641
+
642
+ EventHandler__default['default'].one(target, EVENT_HIDDEN, () => {
643
+ // focus on trigger when it is closed
644
+ if (isVisible(this)) {
645
+ this.focus();
646
+ }
647
+ }); // avoid conflict when clicking a toggler of an offcanvas, while another is open
648
+
649
+ const allReadyOpen = SelectorEngine__default['default'].findOne(OPEN_SELECTOR);
650
+
651
+ if (allReadyOpen && allReadyOpen !== target) {
652
+ Offcanvas.getInstance(allReadyOpen).hide();
653
+ }
654
+
655
+ const data = Data__default['default'].get(target, DATA_KEY) || new Offcanvas(target);
656
+ data.toggle(this);
657
+ });
658
+ EventHandler__default['default'].on(window, EVENT_LOAD_DATA_API, () => {
659
+ SelectorEngine__default['default'].find(OPEN_SELECTOR).forEach(el => (Data__default['default'].get(el, DATA_KEY) || new Offcanvas(el)).show());
660
+ });
661
+ /**
662
+ * ------------------------------------------------------------------------
663
+ * jQuery
664
+ * ------------------------------------------------------------------------
665
+ */
666
+
667
+ defineJQueryPlugin(NAME, Offcanvas);
668
+
669
+ return Offcanvas;
670
+
671
+ })));