프로젝트

일반

사용자정보

통계
| 브랜치(Branch): | 개정판:

markus / ConvertService / ServiceBase / UploadFonts / Scripts / bootstrap.js @ 38d69491

이력 | 보기 | 이력해설 | 다운로드 (142 KB)

1 950e6b84 taeseongkim
/*!
2 65674874 taeseongkim
  * Bootstrap v5.2.3 (https://getbootstrap.com/)
3
  * Copyright 2011-2022 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('@popperjs/core')) :
8
  typeof define === 'function' && define.amd ? define(['@popperjs/core'], factory) :
9
  (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.bootstrap = factory(global.Popper));
10
})(this, (function (Popper) { 'use strict';
11
12
  function _interopNamespace(e) {
13
    if (e && e.__esModule) return e;
14
    const n = Object.create(null, { [Symbol.toStringTag]: { value: 'Module' } });
15
    if (e) {
16
      for (const k in e) {
17
        if (k !== 'default') {
18
          const d = Object.getOwnPropertyDescriptor(e, k);
19
          Object.defineProperty(n, k, d.get ? d : {
20
            enumerable: true,
21
            get: () => e[k]
22
          });
23
        }
24
      }
25
    }
26
    n.default = e;
27
    return Object.freeze(n);
28 950e6b84 taeseongkim
  }
29
30 65674874 taeseongkim
  const Popper__namespace = /*#__PURE__*/_interopNamespace(Popper);
31 950e6b84 taeseongkim
32 65674874 taeseongkim
  /**
33
   * --------------------------------------------------------------------------
34
   * Bootstrap (v5.2.3): util/index.js
35
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
36
   * --------------------------------------------------------------------------
37
   */
38
  const MAX_UID = 1000000;
39
  const MILLISECONDS_MULTIPLIER = 1000;
40
  const TRANSITION_END = 'transitionend'; // Shout-out Angus Croll (https://goo.gl/pxwQGp)
41 950e6b84 taeseongkim
42 65674874 taeseongkim
  const toType = object => {
43
    if (object === null || object === undefined) {
44
      return `${object}`;
45
    }
46 950e6b84 taeseongkim
47 65674874 taeseongkim
    return Object.prototype.toString.call(object).match(/\s([a-z]+)/i)[1].toLowerCase();
48
  };
49
  /**
50
   * Public Util API
51
   */
52 950e6b84 taeseongkim
53
54 65674874 taeseongkim
  const getUID = prefix => {
55
    do {
56
      prefix += Math.floor(Math.random() * MAX_UID);
57
    } while (document.getElementById(prefix));
58 950e6b84 taeseongkim
59 65674874 taeseongkim
    return prefix;
60
  };
61 950e6b84 taeseongkim
62 65674874 taeseongkim
  const getSelector = element => {
63
    let selector = element.getAttribute('data-bs-target');
64 950e6b84 taeseongkim
65 65674874 taeseongkim
    if (!selector || selector === '#') {
66
      let hrefAttribute = element.getAttribute('href'); // The only valid content that could double as a selector are IDs or classes,
67
      // so everything starting with `#` or `.`. If a "real" URL is used as the selector,
68
      // `document.querySelector` will rightfully complain it is invalid.
69
      // See https://github.com/twbs/bootstrap/issues/32273
70 950e6b84 taeseongkim
71 65674874 taeseongkim
      if (!hrefAttribute || !hrefAttribute.includes('#') && !hrefAttribute.startsWith('.')) {
72
        return null;
73
      } // Just in case some CMS puts out a full URL with the anchor appended
74 950e6b84 taeseongkim
75
76 65674874 taeseongkim
      if (hrefAttribute.includes('#') && !hrefAttribute.startsWith('#')) {
77
        hrefAttribute = `#${hrefAttribute.split('#')[1]}`;
78 950e6b84 taeseongkim
      }
79 65674874 taeseongkim
80
      selector = hrefAttribute && hrefAttribute !== '#' ? hrefAttribute.trim() : null;
81 950e6b84 taeseongkim
    }
82
83 65674874 taeseongkim
    return selector;
84
  };
85 950e6b84 taeseongkim
86 65674874 taeseongkim
  const getSelectorFromElement = element => {
87
    const selector = getSelector(element);
88 950e6b84 taeseongkim
89 65674874 taeseongkim
    if (selector) {
90
      return document.querySelector(selector) ? selector : null;
91
    }
92 950e6b84 taeseongkim
93 65674874 taeseongkim
    return null;
94
  };
95 950e6b84 taeseongkim
96 65674874 taeseongkim
  const getElementFromSelector = element => {
97
    const selector = getSelector(element);
98
    return selector ? document.querySelector(selector) : null;
99
  };
100 950e6b84 taeseongkim
101 65674874 taeseongkim
  const getTransitionDurationFromElement = element => {
102
    if (!element) {
103
      return 0;
104
    } // Get transition-duration of the element
105 950e6b84 taeseongkim
106
107 65674874 taeseongkim
    let {
108
      transitionDuration,
109
      transitionDelay
110
    } = window.getComputedStyle(element);
111
    const floatTransitionDuration = Number.parseFloat(transitionDuration);
112
    const floatTransitionDelay = Number.parseFloat(transitionDelay); // Return 0 if element or transition duration is not found
113 950e6b84 taeseongkim
114 65674874 taeseongkim
    if (!floatTransitionDuration && !floatTransitionDelay) {
115
      return 0;
116
    } // If multiple durations are defined, take the first
117 950e6b84 taeseongkim
118
119 65674874 taeseongkim
    transitionDuration = transitionDuration.split(',')[0];
120
    transitionDelay = transitionDelay.split(',')[0];
121
    return (Number.parseFloat(transitionDuration) + Number.parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER;
122
  };
123 950e6b84 taeseongkim
124 65674874 taeseongkim
  const triggerTransitionEnd = element => {
125
    element.dispatchEvent(new Event(TRANSITION_END));
126
  };
127 950e6b84 taeseongkim
128 65674874 taeseongkim
  const isElement = object => {
129
    if (!object || typeof object !== 'object') {
130
      return false;
131 950e6b84 taeseongkim
    }
132
133 65674874 taeseongkim
    if (typeof object.jquery !== 'undefined') {
134
      object = object[0];
135
    }
136 950e6b84 taeseongkim
137 65674874 taeseongkim
    return typeof object.nodeType !== 'undefined';
138
  };
139 950e6b84 taeseongkim
140 65674874 taeseongkim
  const getElement = object => {
141
    // it's a jQuery object or a node element
142
    if (isElement(object)) {
143
      return object.jquery ? object[0] : object;
144
    }
145 950e6b84 taeseongkim
146 65674874 taeseongkim
    if (typeof object === 'string' && object.length > 0) {
147
      return document.querySelector(object);
148 950e6b84 taeseongkim
    }
149
150 65674874 taeseongkim
    return null;
151
  };
152 950e6b84 taeseongkim
153 65674874 taeseongkim
  const isVisible = element => {
154
    if (!isElement(element) || element.getClientRects().length === 0) {
155
      return false;
156
    }
157 950e6b84 taeseongkim
158 65674874 taeseongkim
    const elementIsVisible = getComputedStyle(element).getPropertyValue('visibility') === 'visible'; // Handle `details` element as its content may falsie appear visible when it is closed
159 950e6b84 taeseongkim
160 65674874 taeseongkim
    const closedDetails = element.closest('details:not([open])');
161 950e6b84 taeseongkim
162 65674874 taeseongkim
    if (!closedDetails) {
163
      return elementIsVisible;
164
    }
165 950e6b84 taeseongkim
166 65674874 taeseongkim
    if (closedDetails !== element) {
167
      const summary = element.closest('summary');
168 950e6b84 taeseongkim
169 65674874 taeseongkim
      if (summary && summary.parentNode !== closedDetails) {
170
        return false;
171
      }
172 950e6b84 taeseongkim
173 65674874 taeseongkim
      if (summary === null) {
174
        return false;
175
      }
176
    }
177 950e6b84 taeseongkim
178 65674874 taeseongkim
    return elementIsVisible;
179
  };
180 950e6b84 taeseongkim
181 65674874 taeseongkim
  const isDisabled = element => {
182
    if (!element || element.nodeType !== Node.ELEMENT_NODE) {
183
      return true;
184
    }
185
186
    if (element.classList.contains('disabled')) {
187
      return true;
188
    }
189 950e6b84 taeseongkim
190 65674874 taeseongkim
    if (typeof element.disabled !== 'undefined') {
191
      return element.disabled;
192
    }
193 950e6b84 taeseongkim
194 65674874 taeseongkim
    return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false';
195
  };
196 950e6b84 taeseongkim
197 65674874 taeseongkim
  const findShadowRoot = element => {
198
    if (!document.documentElement.attachShadow) {
199
      return null;
200
    } // Can find the shadow root otherwise it'll return the document
201 950e6b84 taeseongkim
202
203 65674874 taeseongkim
    if (typeof element.getRootNode === 'function') {
204
      const root = element.getRootNode();
205
      return root instanceof ShadowRoot ? root : null;
206
    }
207 950e6b84 taeseongkim
208 65674874 taeseongkim
    if (element instanceof ShadowRoot) {
209
      return element;
210
    } // when we don't find a shadow root
211 950e6b84 taeseongkim
212
213 65674874 taeseongkim
    if (!element.parentNode) {
214
      return null;
215
    }
216 950e6b84 taeseongkim
217 65674874 taeseongkim
    return findShadowRoot(element.parentNode);
218
  };
219 950e6b84 taeseongkim
220 65674874 taeseongkim
  const noop = () => {};
221
  /**
222
   * Trick to restart an element's animation
223
   *
224
   * @param {HTMLElement} element
225
   * @return void
226
   *
227
   * @see https://www.charistheo.io/blog/2021/02/restart-a-css-animation-with-javascript/#restarting-a-css-animation
228
   */
229 950e6b84 taeseongkim
230
231 65674874 taeseongkim
  const reflow = element => {
232
    element.offsetHeight; // eslint-disable-line no-unused-expressions
233
  };
234 950e6b84 taeseongkim
235 65674874 taeseongkim
  const getjQuery = () => {
236
    if (window.jQuery && !document.body.hasAttribute('data-bs-no-jquery')) {
237
      return window.jQuery;
238
    }
239 950e6b84 taeseongkim
240 65674874 taeseongkim
    return null;
241
  };
242 950e6b84 taeseongkim
243 65674874 taeseongkim
  const DOMContentLoadedCallbacks = [];
244 950e6b84 taeseongkim
245 65674874 taeseongkim
  const onDOMContentLoaded = callback => {
246
    if (document.readyState === 'loading') {
247
      // add listener on the first call when the document is in loading state
248
      if (!DOMContentLoadedCallbacks.length) {
249
        document.addEventListener('DOMContentLoaded', () => {
250
          for (const callback of DOMContentLoadedCallbacks) {
251
            callback();
252
          }
253
        });
254 950e6b84 taeseongkim
      }
255
256 65674874 taeseongkim
      DOMContentLoadedCallbacks.push(callback);
257 950e6b84 taeseongkim
    } else {
258 65674874 taeseongkim
      callback();
259 950e6b84 taeseongkim
    }
260 65674874 taeseongkim
  };
261 950e6b84 taeseongkim
262 65674874 taeseongkim
  const isRTL = () => document.documentElement.dir === 'rtl';
263 950e6b84 taeseongkim
264 65674874 taeseongkim
  const defineJQueryPlugin = plugin => {
265
    onDOMContentLoaded(() => {
266
      const $ = getjQuery();
267
      /* istanbul ignore if */
268 950e6b84 taeseongkim
269 65674874 taeseongkim
      if ($) {
270
        const name = plugin.NAME;
271
        const JQUERY_NO_CONFLICT = $.fn[name];
272
        $.fn[name] = plugin.jQueryInterface;
273
        $.fn[name].Constructor = plugin;
274 950e6b84 taeseongkim
275 65674874 taeseongkim
        $.fn[name].noConflict = () => {
276
          $.fn[name] = JQUERY_NO_CONFLICT;
277
          return plugin.jQueryInterface;
278
        };
279
      }
280
    });
281
  };
282 950e6b84 taeseongkim
283 65674874 taeseongkim
  const execute = callback => {
284
    if (typeof callback === 'function') {
285
      callback();
286
    }
287
  };
288 950e6b84 taeseongkim
289 65674874 taeseongkim
  const executeAfterTransition = (callback, transitionElement, waitForTransition = true) => {
290
    if (!waitForTransition) {
291
      execute(callback);
292
      return;
293
    }
294 950e6b84 taeseongkim
295 65674874 taeseongkim
    const durationPadding = 5;
296
    const emulatedDuration = getTransitionDurationFromElement(transitionElement) + durationPadding;
297
    let called = false;
298 950e6b84 taeseongkim
299 65674874 taeseongkim
    const handler = ({
300
      target
301
    }) => {
302
      if (target !== transitionElement) {
303
        return;
304
      }
305 950e6b84 taeseongkim
306 65674874 taeseongkim
      called = true;
307
      transitionElement.removeEventListener(TRANSITION_END, handler);
308
      execute(callback);
309
    };
310 950e6b84 taeseongkim
311 65674874 taeseongkim
    transitionElement.addEventListener(TRANSITION_END, handler);
312
    setTimeout(() => {
313
      if (!called) {
314
        triggerTransitionEnd(transitionElement);
315
      }
316
    }, emulatedDuration);
317
  };
318
  /**
319
   * Return the previous/next element of a list.
320
   *
321
   * @param {array} list    The list of elements
322
   * @param activeElement   The active element
323
   * @param shouldGetNext   Choose to get next or previous element
324
   * @param isCycleAllowed
325
   * @return {Element|elem} The proper element
326
   */
327 950e6b84 taeseongkim
328
329 65674874 taeseongkim
  const getNextActiveElement = (list, activeElement, shouldGetNext, isCycleAllowed) => {
330
    const listLength = list.length;
331
    let index = list.indexOf(activeElement); // if the element does not exist in the list return an element
332
    // depending on the direction and if cycle is allowed
333 950e6b84 taeseongkim
334 65674874 taeseongkim
    if (index === -1) {
335
      return !shouldGetNext && isCycleAllowed ? list[listLength - 1] : list[0];
336 950e6b84 taeseongkim
    }
337
338 65674874 taeseongkim
    index += shouldGetNext ? 1 : -1;
339 950e6b84 taeseongkim
340 65674874 taeseongkim
    if (isCycleAllowed) {
341
      index = (index + listLength) % listLength;
342
    }
343 950e6b84 taeseongkim
344 65674874 taeseongkim
    return list[Math.max(0, Math.min(index, listLength - 1))];
345
  };
346 950e6b84 taeseongkim
347 65674874 taeseongkim
  /**
348
   * --------------------------------------------------------------------------
349
   * Bootstrap (v5.2.3): dom/event-handler.js
350
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
351
   * --------------------------------------------------------------------------
352
   */
353
  /**
354
   * Constants
355
   */
356 950e6b84 taeseongkim
357 65674874 taeseongkim
  const namespaceRegex = /[^.]*(?=\..*)\.|.*/;
358
  const stripNameRegex = /\..*/;
359
  const stripUidRegex = /::\d+$/;
360
  const eventRegistry = {}; // Events storage
361
362
  let uidEvent = 1;
363
  const customEvents = {
364
    mouseenter: 'mouseover',
365
    mouseleave: 'mouseout'
366
  };
367
  const nativeEvents = new Set(['click', 'dblclick', 'mouseup', 'mousedown', 'contextmenu', 'mousewheel', 'DOMMouseScroll', 'mouseover', 'mouseout', 'mousemove', 'selectstart', 'selectend', 'keydown', 'keypress', 'keyup', 'orientationchange', 'touchstart', 'touchmove', 'touchend', 'touchcancel', 'pointerdown', 'pointermove', 'pointerup', 'pointerleave', 'pointercancel', 'gesturestart', 'gesturechange', 'gestureend', 'focus', 'blur', 'change', 'reset', 'select', 'submit', 'focusin', 'focusout', 'load', 'unload', 'beforeunload', 'resize', 'move', 'DOMContentLoaded', 'readystatechange', 'error', 'abort', 'scroll']);
368
  /**
369
   * Private methods
370
   */
371 950e6b84 taeseongkim
372 65674874 taeseongkim
  function makeEventUid(element, uid) {
373
    return uid && `${uid}::${uidEvent++}` || element.uidEvent || uidEvent++;
374 950e6b84 taeseongkim
  }
375
376 65674874 taeseongkim
  function getElementEvents(element) {
377
    const uid = makeEventUid(element);
378
    element.uidEvent = uid;
379
    eventRegistry[uid] = eventRegistry[uid] || {};
380
    return eventRegistry[uid];
381 950e6b84 taeseongkim
  }
382
383 65674874 taeseongkim
  function bootstrapHandler(element, fn) {
384
    return function handler(event) {
385
      hydrateObj(event, {
386
        delegateTarget: element
387
      });
388 950e6b84 taeseongkim
389 65674874 taeseongkim
      if (handler.oneOff) {
390
        EventHandler.off(element, event.type, fn);
391
      }
392 950e6b84 taeseongkim
393 65674874 taeseongkim
      return fn.apply(element, [event]);
394
    };
395 950e6b84 taeseongkim
  }
396
397 65674874 taeseongkim
  function bootstrapDelegationHandler(element, selector, fn) {
398
    return function handler(event) {
399
      const domElements = element.querySelectorAll(selector);
400 950e6b84 taeseongkim
401 65674874 taeseongkim
      for (let {
402
        target
403
      } = event; target && target !== this; target = target.parentNode) {
404
        for (const domElement of domElements) {
405
          if (domElement !== target) {
406
            continue;
407
          }
408
409
          hydrateObj(event, {
410
            delegateTarget: target
411
          });
412 950e6b84 taeseongkim
413 65674874 taeseongkim
          if (handler.oneOff) {
414
            EventHandler.off(element, event.type, selector, fn);
415
          }
416 950e6b84 taeseongkim
417 65674874 taeseongkim
          return fn.apply(target, [event]);
418
        }
419
      }
420
    };
421 950e6b84 taeseongkim
  }
422
423 65674874 taeseongkim
  function findHandler(events, callable, delegationSelector = null) {
424
    return Object.values(events).find(event => event.callable === callable && event.delegationSelector === delegationSelector);
425 950e6b84 taeseongkim
  }
426
427 65674874 taeseongkim
  function normalizeParameters(originalTypeEvent, handler, delegationFunction) {
428
    const isDelegated = typeof handler === 'string'; // todo: tooltip passes `false` instead of selector, so we need to check
429
430
    const callable = isDelegated ? delegationFunction : handler || delegationFunction;
431
    let typeEvent = getTypeEvent(originalTypeEvent);
432
433
    if (!nativeEvents.has(typeEvent)) {
434
      typeEvent = originalTypeEvent;
435
    }
436
437
    return [isDelegated, callable, typeEvent];
438 950e6b84 taeseongkim
  }
439
440 65674874 taeseongkim
  function addHandler(element, originalTypeEvent, handler, delegationFunction, oneOff) {
441
    if (typeof originalTypeEvent !== 'string' || !element) {
442
      return;
443 950e6b84 taeseongkim
    }
444
445 65674874 taeseongkim
    let [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction); // in case of mouseenter or mouseleave wrap the handler within a function that checks for its DOM position
446
    // this prevents the handler from being dispatched the same way as mouseover or mouseout does
447 950e6b84 taeseongkim
448 65674874 taeseongkim
    if (originalTypeEvent in customEvents) {
449
      const wrapFunction = fn => {
450
        return function (event) {
451
          if (!event.relatedTarget || event.relatedTarget !== event.delegateTarget && !event.delegateTarget.contains(event.relatedTarget)) {
452
            return fn.call(this, event);
453
          }
454
        };
455
      };
456 950e6b84 taeseongkim
457 65674874 taeseongkim
      callable = wrapFunction(callable);
458
    }
459 950e6b84 taeseongkim
460 65674874 taeseongkim
    const events = getElementEvents(element);
461
    const handlers = events[typeEvent] || (events[typeEvent] = {});
462
    const previousFunction = findHandler(handlers, callable, isDelegated ? handler : null);
463 950e6b84 taeseongkim
464 65674874 taeseongkim
    if (previousFunction) {
465
      previousFunction.oneOff = previousFunction.oneOff && oneOff;
466
      return;
467
    }
468 950e6b84 taeseongkim
469 65674874 taeseongkim
    const uid = makeEventUid(callable, originalTypeEvent.replace(namespaceRegex, ''));
470
    const fn = isDelegated ? bootstrapDelegationHandler(element, handler, callable) : bootstrapHandler(element, callable);
471
    fn.delegationSelector = isDelegated ? handler : null;
472
    fn.callable = callable;
473
    fn.oneOff = oneOff;
474
    fn.uidEvent = uid;
475
    handlers[uid] = fn;
476
    element.addEventListener(typeEvent, fn, isDelegated);
477 950e6b84 taeseongkim
  }
478
479 65674874 taeseongkim
  function removeHandler(element, events, typeEvent, handler, delegationSelector) {
480
    const fn = findHandler(events[typeEvent], handler, delegationSelector);
481 950e6b84 taeseongkim
482 65674874 taeseongkim
    if (!fn) {
483
      return;
484
    }
485 950e6b84 taeseongkim
486 65674874 taeseongkim
    element.removeEventListener(typeEvent, fn, Boolean(delegationSelector));
487
    delete events[typeEvent][fn.uidEvent];
488
  }
489 950e6b84 taeseongkim
490 65674874 taeseongkim
  function removeNamespacedHandlers(element, events, typeEvent, namespace) {
491
    const storeElementEvent = events[typeEvent] || {};
492 950e6b84 taeseongkim
493 65674874 taeseongkim
    for (const handlerKey of Object.keys(storeElementEvent)) {
494
      if (handlerKey.includes(namespace)) {
495
        const event = storeElementEvent[handlerKey];
496
        removeHandler(element, events, typeEvent, event.callable, event.delegationSelector);
497
      }
498
    }
499 950e6b84 taeseongkim
  }
500
501 65674874 taeseongkim
  function getTypeEvent(event) {
502
    // allow to get the native events from namespaced events ('click.bs.button' --> 'click')
503
    event = event.replace(stripNameRegex, '');
504
    return customEvents[event] || event;
505
  }
506 950e6b84 taeseongkim
507 65674874 taeseongkim
  const EventHandler = {
508
    on(element, event, handler, delegationFunction) {
509
      addHandler(element, event, handler, delegationFunction, false);
510
    },
511 950e6b84 taeseongkim
512 65674874 taeseongkim
    one(element, event, handler, delegationFunction) {
513
      addHandler(element, event, handler, delegationFunction, true);
514
    },
515 950e6b84 taeseongkim
516 65674874 taeseongkim
    off(element, originalTypeEvent, handler, delegationFunction) {
517
      if (typeof originalTypeEvent !== 'string' || !element) {
518
        return;
519
      }
520 950e6b84 taeseongkim
521 65674874 taeseongkim
      const [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction);
522
      const inNamespace = typeEvent !== originalTypeEvent;
523
      const events = getElementEvents(element);
524
      const storeElementEvent = events[typeEvent] || {};
525
      const isNamespace = originalTypeEvent.startsWith('.');
526 950e6b84 taeseongkim
527 65674874 taeseongkim
      if (typeof callable !== 'undefined') {
528
        // Simplest case: handler is passed, remove that listener ONLY.
529
        if (!Object.keys(storeElementEvent).length) {
530
          return;
531
        }
532 950e6b84 taeseongkim
533 65674874 taeseongkim
        removeHandler(element, events, typeEvent, callable, isDelegated ? handler : null);
534
        return;
535
      }
536 950e6b84 taeseongkim
537 65674874 taeseongkim
      if (isNamespace) {
538
        for (const elementEvent of Object.keys(events)) {
539
          removeNamespacedHandlers(element, events, elementEvent, originalTypeEvent.slice(1));
540
        }
541
      }
542 950e6b84 taeseongkim
543 65674874 taeseongkim
      for (const keyHandlers of Object.keys(storeElementEvent)) {
544
        const handlerKey = keyHandlers.replace(stripUidRegex, '');
545
546
        if (!inNamespace || originalTypeEvent.includes(handlerKey)) {
547
          const event = storeElementEvent[keyHandlers];
548
          removeHandler(element, events, typeEvent, event.callable, event.delegationSelector);
549
        }
550
      }
551
    },
552 950e6b84 taeseongkim
553 65674874 taeseongkim
    trigger(element, event, args) {
554
      if (typeof event !== 'string' || !element) {
555
        return null;
556
      }
557
558
      const $ = getjQuery();
559
      const typeEvent = getTypeEvent(event);
560
      const inNamespace = event !== typeEvent;
561
      let jQueryEvent = null;
562
      let bubbles = true;
563
      let nativeDispatch = true;
564
      let defaultPrevented = false;
565
566
      if (inNamespace && $) {
567
        jQueryEvent = $.Event(event, args);
568
        $(element).trigger(jQueryEvent);
569
        bubbles = !jQueryEvent.isPropagationStopped();
570
        nativeDispatch = !jQueryEvent.isImmediatePropagationStopped();
571
        defaultPrevented = jQueryEvent.isDefaultPrevented();
572
      }
573 950e6b84 taeseongkim
574 65674874 taeseongkim
      let evt = new Event(event, {
575
        bubbles,
576
        cancelable: true
577
      });
578
      evt = hydrateObj(evt, args);
579 950e6b84 taeseongkim
580 65674874 taeseongkim
      if (defaultPrevented) {
581
        evt.preventDefault();
582
      }
583 950e6b84 taeseongkim
584 65674874 taeseongkim
      if (nativeDispatch) {
585
        element.dispatchEvent(evt);
586
      }
587 950e6b84 taeseongkim
588 65674874 taeseongkim
      if (evt.defaultPrevented && jQueryEvent) {
589
        jQueryEvent.preventDefault();
590
      }
591 950e6b84 taeseongkim
592 65674874 taeseongkim
      return evt;
593
    }
594 950e6b84 taeseongkim
595 65674874 taeseongkim
  };
596 950e6b84 taeseongkim
597 65674874 taeseongkim
  function hydrateObj(obj, meta) {
598
    for (const [key, value] of Object.entries(meta || {})) {
599
      try {
600
        obj[key] = value;
601
      } catch (_unused) {
602
        Object.defineProperty(obj, key, {
603
          configurable: true,
604 950e6b84 taeseongkim
605 65674874 taeseongkim
          get() {
606
            return value;
607
          }
608
609
        });
610
      }
611 950e6b84 taeseongkim
    }
612
613 65674874 taeseongkim
    return obj;
614 950e6b84 taeseongkim
  }
615
616 65674874 taeseongkim
  /**
617
   * --------------------------------------------------------------------------
618
   * Bootstrap (v5.2.3): dom/data.js
619
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
620
   * --------------------------------------------------------------------------
621
   */
622 950e6b84 taeseongkim
623 65674874 taeseongkim
  /**
624
   * Constants
625
   */
626
  const elementMap = new Map();
627
  const Data = {
628
    set(element, key, instance) {
629
      if (!elementMap.has(element)) {
630
        elementMap.set(element, new Map());
631
      }
632 950e6b84 taeseongkim
633 65674874 taeseongkim
      const instanceMap = elementMap.get(element); // make it clear we only want one instance per element
634
      // can be removed later when multiple key/instances are fine to be used
635 950e6b84 taeseongkim
636 65674874 taeseongkim
      if (!instanceMap.has(key) && instanceMap.size !== 0) {
637
        // eslint-disable-next-line no-console
638
        console.error(`Bootstrap doesn't allow more than one instance per element. Bound instance: ${Array.from(instanceMap.keys())[0]}.`);
639
        return;
640
      }
641

642
      instanceMap.set(key, instance);
643
    },
644 950e6b84 taeseongkim

645 65674874 taeseongkim
    get(element, key) {
646
      if (elementMap.has(element)) {
647
        return elementMap.get(element).get(key) || null;
648
      }
649 950e6b84 taeseongkim

650 65674874 taeseongkim
      return null;
651
    },
652 950e6b84 taeseongkim

653 65674874 taeseongkim
    remove(element, key) {
654
      if (!elementMap.has(element)) {
655
        return;
656
      }
657 950e6b84 taeseongkim

658 65674874 taeseongkim
      const instanceMap = elementMap.get(element);
659
      instanceMap.delete(key); // free up element references if there are no instances left for an element
660 950e6b84 taeseongkim

661 65674874 taeseongkim
      if (instanceMap.size === 0) {
662
        elementMap.delete(element);
663
      }
664 950e6b84 taeseongkim
    }
665

666 65674874 taeseongkim
  };
667 950e6b84 taeseongkim

668 65674874 taeseongkim
  /**
669
   * --------------------------------------------------------------------------
670
   * Bootstrap (v5.2.3): dom/manipulator.js
671
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
672
   * --------------------------------------------------------------------------
673
   */
674
  function normalizeData(value) {
675
    if (value === 'true') {
676
      return true;
677
    }
678 950e6b84 taeseongkim

679 65674874 taeseongkim
    if (value === 'false') {
680
      return false;
681
    }
682 950e6b84 taeseongkim

683 65674874 taeseongkim
    if (value === Number(value).toString()) {
684
      return Number(value);
685 950e6b84 taeseongkim
    }
686

687 65674874 taeseongkim
    if (value === '' || value === 'null') {
688
      return null;
689
    }
690 950e6b84 taeseongkim

691 65674874 taeseongkim
    if (typeof value !== 'string') {
692
      return value;
693
    }
694 950e6b84 taeseongkim

695 65674874 taeseongkim
    try {
696
      return JSON.parse(decodeURIComponent(value));
697
    } catch (_unused) {
698
      return value;
699
    }
700 950e6b84 taeseongkim
  }
701

702 65674874 taeseongkim
  function normalizeDataKey(key) {
703
    return key.replace(/[A-Z]/g, chr => `-${chr.toLowerCase()}`);
704
  }
705 950e6b84 taeseongkim

706 65674874 taeseongkim
  const Manipulator = {
707
    setDataAttribute(element, key, value) {
708
      element.setAttribute(`data-bs-${normalizeDataKey(key)}`, value);
709
    },
710 950e6b84 taeseongkim

711 65674874 taeseongkim
    removeDataAttribute(element, key) {
712
      element.removeAttribute(`data-bs-${normalizeDataKey(key)}`);
713
    },
714 950e6b84 taeseongkim

715 65674874 taeseongkim
    getDataAttributes(element) {
716
      if (!element) {
717
        return {};
718
      }
719 950e6b84 taeseongkim

720 65674874 taeseongkim
      const attributes = {};
721
      const bsKeys = Object.keys(element.dataset).filter(key => key.startsWith('bs') && !key.startsWith('bsConfig'));
722 950e6b84 taeseongkim

723 65674874 taeseongkim
      for (const key of bsKeys) {
724
        let pureKey = key.replace(/^bs/, '');
725
        pureKey = pureKey.charAt(0).toLowerCase() + pureKey.slice(1, pureKey.length);
726
        attributes[pureKey] = normalizeData(element.dataset[key]);
727
      }
728 950e6b84 taeseongkim

729 65674874 taeseongkim
      return attributes;
730
    },
731 950e6b84 taeseongkim

732 65674874 taeseongkim
    getDataAttribute(element, key) {
733
      return normalizeData(element.getAttribute(`data-bs-${normalizeDataKey(key)}`));
734 950e6b84 taeseongkim
    }
735

736 65674874 taeseongkim
  };
737 950e6b84 taeseongkim

738 65674874 taeseongkim
  /**
739
   * --------------------------------------------------------------------------
740
   * Bootstrap (v5.2.3): util/config.js
741
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
742
   * --------------------------------------------------------------------------
743
   */
744
  /**
745
   * Class definition
746
   */
747 950e6b84 taeseongkim

748 65674874 taeseongkim
  class Config {
749
    // Getters
750
    static get Default() {
751
      return {};
752
    }
753 950e6b84 taeseongkim

754 65674874 taeseongkim
    static get DefaultType() {
755
      return {};
756
    }
757 950e6b84 taeseongkim

758 65674874 taeseongkim
    static get NAME() {
759
      throw new Error('You have to implement the static method "NAME", for each component!');
760
    }
761 950e6b84 taeseongkim

762 65674874 taeseongkim
    _getConfig(config) {
763
      config = this._mergeConfigObj(config);
764
      config = this._configAfterMerge(config);
765 950e6b84 taeseongkim

766 65674874 taeseongkim
      this._typeCheckConfig(config);
767 950e6b84 taeseongkim

768 65674874 taeseongkim
      return config;
769
    }
770 950e6b84 taeseongkim

771 65674874 taeseongkim
    _configAfterMerge(config) {
772
      return config;
773
    }
774 950e6b84 taeseongkim

775 65674874 taeseongkim
    _mergeConfigObj(config, element) {
776
      const jsonConfig = isElement(element) ? Manipulator.getDataAttribute(element, 'config') : {}; // try to parse
777 950e6b84 taeseongkim

778 65674874 taeseongkim
      return { ...this.constructor.Default,
779
        ...(typeof jsonConfig === 'object' ? jsonConfig : {}),
780
        ...(isElement(element) ? Manipulator.getDataAttributes(element) : {}),
781
        ...(typeof config === 'object' ? config : {})
782
      };
783
    }
784 950e6b84 taeseongkim

785 65674874 taeseongkim
    _typeCheckConfig(config, configTypes = this.constructor.DefaultType) {
786
      for (const property of Object.keys(configTypes)) {
787
        const expectedTypes = configTypes[property];
788
        const value = config[property];
789
        const valueType = isElement(value) ? 'element' : toType(value);
790 950e6b84 taeseongkim

791 65674874 taeseongkim
        if (!new RegExp(expectedTypes).test(valueType)) {
792
          throw new TypeError(`${this.constructor.NAME.toUpperCase()}: Option "${property}" provided type "${valueType}" but expected type "${expectedTypes}".`);
793
        }
794
      }
795
    }
796 950e6b84 taeseongkim

797 65674874 taeseongkim
  }
798 950e6b84 taeseongkim

799 65674874 taeseongkim
  /**
800
   * --------------------------------------------------------------------------
801
   * Bootstrap (v5.2.3): base-component.js
802
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
803
   * --------------------------------------------------------------------------
804
   */
805
  /**
806
   * Constants
807
   */
808 950e6b84 taeseongkim

809 65674874 taeseongkim
  const VERSION = '5.2.3';
810
  /**
811
   * Class definition
812
   */
813 950e6b84 taeseongkim

814 65674874 taeseongkim
  class BaseComponent extends Config {
815
    constructor(element, config) {
816
      super();
817
      element = getElement(element);
818 950e6b84 taeseongkim

819 65674874 taeseongkim
      if (!element) {
820
        return;
821
      }
822 950e6b84 taeseongkim

823 65674874 taeseongkim
      this._element = element;
824
      this._config = this._getConfig(config);
825
      Data.set(this._element, this.constructor.DATA_KEY, this);
826
    } // Public
827 950e6b84 taeseongkim

828

829 65674874 taeseongkim
    dispose() {
830
      Data.remove(this._element, this.constructor.DATA_KEY);
831
      EventHandler.off(this._element, this.constructor.EVENT_KEY);
832 950e6b84 taeseongkim

833 65674874 taeseongkim
      for (const propertyName of Object.getOwnPropertyNames(this)) {
834
        this[propertyName] = null;
835
      }
836
    }
837 950e6b84 taeseongkim

838 65674874 taeseongkim
    _queueCallback(callback, element, isAnimated = true) {
839
      executeAfterTransition(callback, element, isAnimated);
840
    }
841 950e6b84 taeseongkim

842 65674874 taeseongkim
    _getConfig(config) {
843
      config = this._mergeConfigObj(config, this._element);
844
      config = this._configAfterMerge(config);
845 950e6b84 taeseongkim

846 65674874 taeseongkim
      this._typeCheckConfig(config);
847 950e6b84 taeseongkim

848 65674874 taeseongkim
      return config;
849
    } // Static
850 950e6b84 taeseongkim

851

852 65674874 taeseongkim
    static getInstance(element) {
853
      return Data.get(getElement(element), this.DATA_KEY);
854
    }
855 950e6b84 taeseongkim

856 65674874 taeseongkim
    static getOrCreateInstance(element, config = {}) {
857
      return this.getInstance(element) || new this(element, typeof config === 'object' ? config : null);
858
    }
859 950e6b84 taeseongkim

860 65674874 taeseongkim
    static get VERSION() {
861
      return VERSION;
862
    }
863 950e6b84 taeseongkim

864 65674874 taeseongkim
    static get DATA_KEY() {
865
      return `bs.${this.NAME}`;
866
    }
867 950e6b84 taeseongkim

868 65674874 taeseongkim
    static get EVENT_KEY() {
869
      return `.${this.DATA_KEY}`;
870 950e6b84 taeseongkim
    }
871

872 65674874 taeseongkim
    static eventName(name) {
873
      return `${name}${this.EVENT_KEY}`;
874
    }
875 950e6b84 taeseongkim

876
  }
877

878 65674874 taeseongkim
  /**
879
   * --------------------------------------------------------------------------
880
   * Bootstrap (v5.2.3): util/component-functions.js
881
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
882
   * --------------------------------------------------------------------------
883
   */
884 950e6b84 taeseongkim

885 65674874 taeseongkim
  const enableDismissTrigger = (component, method = 'hide') => {
886
    const clickEvent = `click.dismiss${component.EVENT_KEY}`;
887
    const name = component.NAME;
888
    EventHandler.on(document, clickEvent, `[data-bs-dismiss="${name}"]`, function (event) {
889
      if (['A', 'AREA'].includes(this.tagName)) {
890
        event.preventDefault();
891
      }
892 950e6b84 taeseongkim

893 65674874 taeseongkim
      if (isDisabled(this)) {
894
        return;
895
      }
896 950e6b84 taeseongkim

897 65674874 taeseongkim
      const target = getElementFromSelector(this) || this.closest(`.${name}`);
898
      const instance = component.getOrCreateInstance(target); // Method argument is left, for Alert and only, as it doesn't implement the 'hide' method
899 950e6b84 taeseongkim
900 65674874 taeseongkim
      instance[method]();
901
    });
902
  };
903 950e6b84 taeseongkim
904 65674874 taeseongkim
  /**
905
   * --------------------------------------------------------------------------
906
   * Bootstrap (v5.2.3): alert.js
907
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
908
   * --------------------------------------------------------------------------
909
   */
910
  /**
911
   * Constants
912
   */
913 950e6b84 taeseongkim
914 65674874 taeseongkim
  const NAME$f = 'alert';
915
  const DATA_KEY$a = 'bs.alert';
916
  const EVENT_KEY$b = `.${DATA_KEY$a}`;
917
  const EVENT_CLOSE = `close${EVENT_KEY$b}`;
918
  const EVENT_CLOSED = `closed${EVENT_KEY$b}`;
919
  const CLASS_NAME_FADE$5 = 'fade';
920
  const CLASS_NAME_SHOW$8 = 'show';
921
  /**
922
   * Class definition
923
   */
924 950e6b84 taeseongkim
925 65674874 taeseongkim
  class Alert extends BaseComponent {
926
    // Getters
927
    static get NAME() {
928
      return NAME$f;
929
    } // Public
930 950e6b84 taeseongkim
931
932 65674874 taeseongkim
    close() {
933
      const closeEvent = EventHandler.trigger(this._element, EVENT_CLOSE);
934 950e6b84 taeseongkim
935 65674874 taeseongkim
      if (closeEvent.defaultPrevented) {
936
        return;
937 950e6b84 taeseongkim
      }
938
939 65674874 taeseongkim
      this._element.classList.remove(CLASS_NAME_SHOW$8);
940 950e6b84 taeseongkim
941 65674874 taeseongkim
      const isAnimated = this._element.classList.contains(CLASS_NAME_FADE$5);
942 950e6b84 taeseongkim
943 65674874 taeseongkim
      this._queueCallback(() => this._destroyElement(), this._element, isAnimated);
944
    } // Private
945 950e6b84 taeseongkim
946
947 65674874 taeseongkim
    _destroyElement() {
948
      this._element.remove();
949 950e6b84 taeseongkim
950 65674874 taeseongkim
      EventHandler.trigger(this._element, EVENT_CLOSED);
951
      this.dispose();
952
    } // Static
953 950e6b84 taeseongkim
954
955 65674874 taeseongkim
    static jQueryInterface(config) {
956
      return this.each(function () {
957
        const data = Alert.getOrCreateInstance(this);
958 950e6b84 taeseongkim
959 65674874 taeseongkim
        if (typeof config !== 'string') {
960
          return;
961
        }
962 950e6b84 taeseongkim
963 65674874 taeseongkim
        if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {
964
          throw new TypeError(`No method named "${config}"`);
965
        }
966 950e6b84 taeseongkim
967 65674874 taeseongkim
        data[config](this);
968
      });
969 950e6b84 taeseongkim
    }
970
971
  }
972 65674874 taeseongkim
  /**
973
   * Data API implementation
974
   */
975 950e6b84 taeseongkim
976
977 65674874 taeseongkim
  enableDismissTrigger(Alert, 'close');
978
  /**
979
   * jQuery
980
   */
981 950e6b84 taeseongkim
982 65674874 taeseongkim
  defineJQueryPlugin(Alert);
983 950e6b84 taeseongkim
984 65674874 taeseongkim
  /**
985
   * --------------------------------------------------------------------------
986
   * Bootstrap (v5.2.3): button.js
987
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
988
   * --------------------------------------------------------------------------
989
   */
990
  /**
991
   * Constants
992
   */
993 950e6b84 taeseongkim
994 65674874 taeseongkim
  const NAME$e = 'button';
995
  const DATA_KEY$9 = 'bs.button';
996
  const EVENT_KEY$a = `.${DATA_KEY$9}`;
997
  const DATA_API_KEY$6 = '.data-api';
998
  const CLASS_NAME_ACTIVE$3 = 'active';
999
  const SELECTOR_DATA_TOGGLE$5 = '[data-bs-toggle="button"]';
1000
  const EVENT_CLICK_DATA_API$6 = `click${EVENT_KEY$a}${DATA_API_KEY$6}`;
1001
  /**
1002
   * Class definition
1003
   */
1004 950e6b84 taeseongkim
1005 65674874 taeseongkim
  class Button extends BaseComponent {
1006
    // Getters
1007
    static get NAME() {
1008
      return NAME$e;
1009
    } // Public
1010 950e6b84 taeseongkim
1011
1012 65674874 taeseongkim
    toggle() {
1013
      // Toggle class and sync the `aria-pressed` attribute with the return value of the `.toggle()` method
1014
      this._element.setAttribute('aria-pressed', this._element.classList.toggle(CLASS_NAME_ACTIVE$3));
1015
    } // Static
1016 950e6b84 taeseongkim
1017
1018 65674874 taeseongkim
    static jQueryInterface(config) {
1019
      return this.each(function () {
1020
        const data = Button.getOrCreateInstance(this);
1021 950e6b84 taeseongkim
1022 65674874 taeseongkim
        if (config === 'toggle') {
1023
          data[config]();
1024
        }
1025
      });
1026 950e6b84 taeseongkim
    }
1027
1028 65674874 taeseongkim
  }
1029
  /**
1030
   * Data API implementation
1031
   */
1032 950e6b84 taeseongkim
1033
1034 65674874 taeseongkim
  EventHandler.on(document, EVENT_CLICK_DATA_API$6, SELECTOR_DATA_TOGGLE$5, event => {
1035
    event.preventDefault();
1036
    const button = event.target.closest(SELECTOR_DATA_TOGGLE$5);
1037
    const data = Button.getOrCreateInstance(button);
1038
    data.toggle();
1039
  });
1040
  /**
1041
   * jQuery
1042
   */
1043 950e6b84 taeseongkim
1044 65674874 taeseongkim
  defineJQueryPlugin(Button);
1045 950e6b84 taeseongkim
1046 65674874 taeseongkim
  /**
1047
   * --------------------------------------------------------------------------
1048
   * Bootstrap (v5.2.3): dom/selector-engine.js
1049
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
1050
   * --------------------------------------------------------------------------
1051
   */
1052
  /**
1053
   * Constants
1054
   */
1055 950e6b84 taeseongkim
1056 65674874 taeseongkim
  const SelectorEngine = {
1057
    find(selector, element = document.documentElement) {
1058
      return [].concat(...Element.prototype.querySelectorAll.call(element, selector));
1059
    },
1060 950e6b84 taeseongkim
1061 65674874 taeseongkim
    findOne(selector, element = document.documentElement) {
1062
      return Element.prototype.querySelector.call(element, selector);
1063
    },
1064 950e6b84 taeseongkim
1065 65674874 taeseongkim
    children(element, selector) {
1066
      return [].concat(...element.children).filter(child => child.matches(selector));
1067
    },
1068 950e6b84 taeseongkim
1069 65674874 taeseongkim
    parents(element, selector) {
1070
      const parents = [];
1071
      let ancestor = element.parentNode.closest(selector);
1072 950e6b84 taeseongkim
1073 65674874 taeseongkim
      while (ancestor) {
1074
        parents.push(ancestor);
1075
        ancestor = ancestor.parentNode.closest(selector);
1076
      }
1077 950e6b84 taeseongkim
1078 65674874 taeseongkim
      return parents;
1079
    },
1080 950e6b84 taeseongkim
1081 65674874 taeseongkim
    prev(element, selector) {
1082
      let previous = element.previousElementSibling;
1083 950e6b84 taeseongkim
1084 65674874 taeseongkim
      while (previous) {
1085
        if (previous.matches(selector)) {
1086
          return [previous];
1087
        }
1088 950e6b84 taeseongkim
1089 65674874 taeseongkim
        previous = previous.previousElementSibling;
1090 950e6b84 taeseongkim
      }
1091
1092 65674874 taeseongkim
      return [];
1093
    },
1094
1095
    // TODO: this is now unused; remove later along with prev()
1096
    next(element, selector) {
1097
      let next = element.nextElementSibling;
1098 950e6b84 taeseongkim
1099 65674874 taeseongkim
      while (next) {
1100
        if (next.matches(selector)) {
1101
          return [next];
1102
        }
1103 950e6b84 taeseongkim
1104 65674874 taeseongkim
        next = next.nextElementSibling;
1105 950e6b84 taeseongkim
      }
1106
1107 65674874 taeseongkim
      return [];
1108
    },
1109 950e6b84 taeseongkim
1110 65674874 taeseongkim
    focusableChildren(element) {
1111
      const focusables = ['a', 'button', 'input', 'textarea', 'select', 'details', '[tabindex]', '[contenteditable="true"]'].map(selector => `${selector}:not([tabindex^="-"])`).join(',');
1112
      return this.find(focusables, element).filter(el => !isDisabled(el) && isVisible(el));
1113
    }
1114 950e6b84 taeseongkim
1115 65674874 taeseongkim
  };
1116 950e6b84 taeseongkim
1117 65674874 taeseongkim
  /**
1118
   * --------------------------------------------------------------------------
1119
   * Bootstrap (v5.2.3): util/swipe.js
1120
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
1121
   * --------------------------------------------------------------------------
1122
   */
1123
  /**
1124
   * Constants
1125
   */
1126
1127
  const NAME$d = 'swipe';
1128
  const EVENT_KEY$9 = '.bs.swipe';
1129
  const EVENT_TOUCHSTART = `touchstart${EVENT_KEY$9}`;
1130
  const EVENT_TOUCHMOVE = `touchmove${EVENT_KEY$9}`;
1131
  const EVENT_TOUCHEND = `touchend${EVENT_KEY$9}`;
1132
  const EVENT_POINTERDOWN = `pointerdown${EVENT_KEY$9}`;
1133
  const EVENT_POINTERUP = `pointerup${EVENT_KEY$9}`;
1134
  const POINTER_TYPE_TOUCH = 'touch';
1135
  const POINTER_TYPE_PEN = 'pen';
1136
  const CLASS_NAME_POINTER_EVENT = 'pointer-event';
1137
  const SWIPE_THRESHOLD = 40;
1138
  const Default$c = {
1139
    endCallback: null,
1140
    leftCallback: null,
1141
    rightCallback: null
1142
  };
1143
  const DefaultType$c = {
1144
    endCallback: '(function|null)',
1145
    leftCallback: '(function|null)',
1146
    rightCallback: '(function|null)'
1147
  };
1148
  /**
1149
   * Class definition
1150
   */
1151 950e6b84 taeseongkim
1152 65674874 taeseongkim
  class Swipe extends Config {
1153
    constructor(element, config) {
1154
      super();
1155
      this._element = element;
1156
1157
      if (!element || !Swipe.isSupported()) {
1158
        return;
1159
      }
1160 950e6b84 taeseongkim
1161 65674874 taeseongkim
      this._config = this._getConfig(config);
1162
      this._deltaX = 0;
1163
      this._supportPointerEvents = Boolean(window.PointerEvent);
1164 950e6b84 taeseongkim
1165 65674874 taeseongkim
      this._initEvents();
1166
    } // Getters
1167 950e6b84 taeseongkim
1168
1169 65674874 taeseongkim
    static get Default() {
1170
      return Default$c;
1171
    }
1172 950e6b84 taeseongkim
1173 65674874 taeseongkim
    static get DefaultType() {
1174
      return DefaultType$c;
1175
    }
1176 950e6b84 taeseongkim
1177 65674874 taeseongkim
    static get NAME() {
1178
      return NAME$d;
1179
    } // Public
1180 950e6b84 taeseongkim
1181
1182 65674874 taeseongkim
    dispose() {
1183
      EventHandler.off(this._element, EVENT_KEY$9);
1184
    } // Private
1185 950e6b84 taeseongkim
1186
1187 65674874 taeseongkim
    _start(event) {
1188
      if (!this._supportPointerEvents) {
1189
        this._deltaX = event.touches[0].clientX;
1190
        return;
1191
      }
1192 950e6b84 taeseongkim
1193 65674874 taeseongkim
      if (this._eventIsPointerPenTouch(event)) {
1194
        this._deltaX = event.clientX;
1195
      }
1196 950e6b84 taeseongkim
    }
1197
1198 65674874 taeseongkim
    _end(event) {
1199
      if (this._eventIsPointerPenTouch(event)) {
1200
        this._deltaX = event.clientX - this._deltaX;
1201
      }
1202
1203
      this._handleSwipe();
1204
1205
      execute(this._config.endCallback);
1206
    }
1207
1208
    _move(event) {
1209
      this._deltaX = event.touches && event.touches.length > 1 ? 0 : event.touches[0].clientX - this._deltaX;
1210
    }
1211
1212
    _handleSwipe() {
1213
      const absDeltaX = Math.abs(this._deltaX);
1214
1215
      if (absDeltaX <= SWIPE_THRESHOLD) {
1216
        return;
1217
      }
1218
1219
      const direction = absDeltaX / this._deltaX;
1220
      this._deltaX = 0;
1221
1222
      if (!direction) {
1223
        return;
1224
      }
1225
1226
      execute(direction > 0 ? this._config.rightCallback : this._config.leftCallback);
1227
    }
1228
1229
    _initEvents() {
1230
      if (this._supportPointerEvents) {
1231
        EventHandler.on(this._element, EVENT_POINTERDOWN, event => this._start(event));
1232
        EventHandler.on(this._element, EVENT_POINTERUP, event => this._end(event));
1233
1234
        this._element.classList.add(CLASS_NAME_POINTER_EVENT);
1235
      } else {
1236
        EventHandler.on(this._element, EVENT_TOUCHSTART, event => this._start(event));
1237
        EventHandler.on(this._element, EVENT_TOUCHMOVE, event => this._move(event));
1238
        EventHandler.on(this._element, EVENT_TOUCHEND, event => this._end(event));
1239
      }
1240
    }
1241
1242
    _eventIsPointerPenTouch(event) {
1243
      return this._supportPointerEvents && (event.pointerType === POINTER_TYPE_PEN || event.pointerType === POINTER_TYPE_TOUCH);
1244
    } // Static
1245
1246
1247
    static isSupported() {
1248
      return 'ontouchstart' in document.documentElement || navigator.maxTouchPoints > 0;
1249
    }
1250
1251
  }
1252
1253
  /**
1254
   * --------------------------------------------------------------------------
1255
   * Bootstrap (v5.2.3): carousel.js
1256
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
1257
   * --------------------------------------------------------------------------
1258
   */
1259
  /**
1260
   * Constants
1261
   */
1262
1263
  const NAME$c = 'carousel';
1264
  const DATA_KEY$8 = 'bs.carousel';
1265
  const EVENT_KEY$8 = `.${DATA_KEY$8}`;
1266
  const DATA_API_KEY$5 = '.data-api';
1267
  const ARROW_LEFT_KEY$1 = 'ArrowLeft';
1268
  const ARROW_RIGHT_KEY$1 = 'ArrowRight';
1269
  const TOUCHEVENT_COMPAT_WAIT = 500; // Time for mouse compat events to fire after touch
1270
1271
  const ORDER_NEXT = 'next';
1272
  const ORDER_PREV = 'prev';
1273
  const DIRECTION_LEFT = 'left';
1274
  const DIRECTION_RIGHT = 'right';
1275
  const EVENT_SLIDE = `slide${EVENT_KEY$8}`;
1276
  const EVENT_SLID = `slid${EVENT_KEY$8}`;
1277
  const EVENT_KEYDOWN$1 = `keydown${EVENT_KEY$8}`;
1278
  const EVENT_MOUSEENTER$1 = `mouseenter${EVENT_KEY$8}`;
1279
  const EVENT_MOUSELEAVE$1 = `mouseleave${EVENT_KEY$8}`;
1280
  const EVENT_DRAG_START = `dragstart${EVENT_KEY$8}`;
1281
  const EVENT_LOAD_DATA_API$3 = `load${EVENT_KEY$8}${DATA_API_KEY$5}`;
1282
  const EVENT_CLICK_DATA_API$5 = `click${EVENT_KEY$8}${DATA_API_KEY$5}`;
1283
  const CLASS_NAME_CAROUSEL = 'carousel';
1284
  const CLASS_NAME_ACTIVE$2 = 'active';
1285
  const CLASS_NAME_SLIDE = 'slide';
1286
  const CLASS_NAME_END = 'carousel-item-end';
1287
  const CLASS_NAME_START = 'carousel-item-start';
1288
  const CLASS_NAME_NEXT = 'carousel-item-next';
1289
  const CLASS_NAME_PREV = 'carousel-item-prev';
1290
  const SELECTOR_ACTIVE = '.active';
1291
  const SELECTOR_ITEM = '.carousel-item';
1292
  const SELECTOR_ACTIVE_ITEM = SELECTOR_ACTIVE + SELECTOR_ITEM;
1293
  const SELECTOR_ITEM_IMG = '.carousel-item img';
1294
  const SELECTOR_INDICATORS = '.carousel-indicators';
1295
  const SELECTOR_DATA_SLIDE = '[data-bs-slide], [data-bs-slide-to]';
1296
  const SELECTOR_DATA_RIDE = '[data-bs-ride="carousel"]';
1297
  const KEY_TO_DIRECTION = {
1298
    [ARROW_LEFT_KEY$1]: DIRECTION_RIGHT,
1299
    [ARROW_RIGHT_KEY$1]: DIRECTION_LEFT
1300
  };
1301
  const Default$b = {
1302
    interval: 5000,
1303
    keyboard: true,
1304
    pause: 'hover',
1305
    ride: false,
1306
    touch: true,
1307
    wrap: true
1308
  };
1309
  const DefaultType$b = {
1310
    interval: '(number|boolean)',
1311
    // TODO:v6 remove boolean support
1312
    keyboard: 'boolean',
1313
    pause: '(string|boolean)',
1314
    ride: '(boolean|string)',
1315
    touch: 'boolean',
1316
    wrap: 'boolean'
1317
  };
1318
  /**
1319
   * Class definition
1320
   */
1321
1322
  class Carousel extends BaseComponent {
1323
    constructor(element, config) {
1324
      super(element, config);
1325
      this._interval = null;
1326
      this._activeElement = null;
1327
      this._isSliding = false;
1328
      this.touchTimeout = null;
1329
      this._swipeHelper = null;
1330
      this._indicatorsElement = SelectorEngine.findOne(SELECTOR_INDICATORS, this._element);
1331
1332
      this._addEventListeners();
1333
1334
      if (this._config.ride === CLASS_NAME_CAROUSEL) {
1335
        this.cycle();
1336
      }
1337
    } // Getters
1338
1339
1340
    static get Default() {
1341
      return Default$b;
1342
    }
1343
1344
    static get DefaultType() {
1345
      return DefaultType$b;
1346
    }
1347
1348
    static get NAME() {
1349
      return NAME$c;
1350
    } // Public
1351
1352
1353
    next() {
1354
      this._slide(ORDER_NEXT);
1355
    }
1356
1357
    nextWhenVisible() {
1358
      // FIXME TODO use `document.visibilityState`
1359
      // Don't call next when the page isn't visible
1360
      // or the carousel or its parent isn't visible
1361
      if (!document.hidden && isVisible(this._element)) {
1362
        this.next();
1363
      }
1364
    }
1365
1366
    prev() {
1367
      this._slide(ORDER_PREV);
1368
    }
1369
1370
    pause() {
1371
      if (this._isSliding) {
1372
        triggerTransitionEnd(this._element);
1373
      }
1374
1375
      this._clearInterval();
1376
    }
1377
1378
    cycle() {
1379
      this._clearInterval();
1380
1381
      this._updateInterval();
1382
1383
      this._interval = setInterval(() => this.nextWhenVisible(), this._config.interval);
1384
    }
1385
1386
    _maybeEnableCycle() {
1387
      if (!this._config.ride) {
1388
        return;
1389
      }
1390
1391
      if (this._isSliding) {
1392
        EventHandler.one(this._element, EVENT_SLID, () => this.cycle());
1393
        return;
1394
      }
1395
1396
      this.cycle();
1397
    }
1398
1399
    to(index) {
1400
      const items = this._getItems();
1401
1402
      if (index > items.length - 1 || index < 0) {
1403
        return;
1404
      }
1405
1406
      if (this._isSliding) {
1407
        EventHandler.one(this._element, EVENT_SLID, () => this.to(index));
1408
        return;
1409
      }
1410
1411
      const activeIndex = this._getItemIndex(this._getActive());
1412
1413
      if (activeIndex === index) {
1414
        return;
1415
      }
1416
1417
      const order = index > activeIndex ? ORDER_NEXT : ORDER_PREV;
1418
1419
      this._slide(order, items[index]);
1420
    }
1421
1422
    dispose() {
1423
      if (this._swipeHelper) {
1424
        this._swipeHelper.dispose();
1425
      }
1426
1427
      super.dispose();
1428
    } // Private
1429
1430
1431
    _configAfterMerge(config) {
1432
      config.defaultInterval = config.interval;
1433
      return config;
1434
    }
1435
1436
    _addEventListeners() {
1437
      if (this._config.keyboard) {
1438
        EventHandler.on(this._element, EVENT_KEYDOWN$1, event => this._keydown(event));
1439
      }
1440
1441
      if (this._config.pause === 'hover') {
1442
        EventHandler.on(this._element, EVENT_MOUSEENTER$1, () => this.pause());
1443
        EventHandler.on(this._element, EVENT_MOUSELEAVE$1, () => this._maybeEnableCycle());
1444
      }
1445
1446
      if (this._config.touch && Swipe.isSupported()) {
1447
        this._addTouchEventListeners();
1448
      }
1449
    }
1450
1451
    _addTouchEventListeners() {
1452
      for (const img of SelectorEngine.find(SELECTOR_ITEM_IMG, this._element)) {
1453
        EventHandler.on(img, EVENT_DRAG_START, event => event.preventDefault());
1454
      }
1455
1456
      const endCallBack = () => {
1457
        if (this._config.pause !== 'hover') {
1458
          return;
1459
        } // If it's a touch-enabled device, mouseenter/leave are fired as
1460
        // part of the mouse compatibility events on first tap - the carousel
1461
        // would stop cycling until user tapped out of it;
1462
        // here, we listen for touchend, explicitly pause the carousel
1463
        // (as if it's the second time we tap on it, mouseenter compat event
1464
        // is NOT fired) and after a timeout (to allow for mouse compatibility
1465
        // events to fire) we explicitly restart cycling
1466
1467
1468
        this.pause();
1469
1470
        if (this.touchTimeout) {
1471
          clearTimeout(this.touchTimeout);
1472
        }
1473
1474
        this.touchTimeout = setTimeout(() => this._maybeEnableCycle(), TOUCHEVENT_COMPAT_WAIT + this._config.interval);
1475
      };
1476
1477
      const swipeConfig = {
1478
        leftCallback: () => this._slide(this._directionToOrder(DIRECTION_LEFT)),
1479
        rightCallback: () => this._slide(this._directionToOrder(DIRECTION_RIGHT)),
1480
        endCallback: endCallBack
1481
      };
1482
      this._swipeHelper = new Swipe(this._element, swipeConfig);
1483
    }
1484
1485
    _keydown(event) {
1486
      if (/input|textarea/i.test(event.target.tagName)) {
1487
        return;
1488
      }
1489
1490
      const direction = KEY_TO_DIRECTION[event.key];
1491
1492
      if (direction) {
1493
        event.preventDefault();
1494
1495
        this._slide(this._directionToOrder(direction));
1496
      }
1497
    }
1498
1499
    _getItemIndex(element) {
1500
      return this._getItems().indexOf(element);
1501
    }
1502
1503
    _setActiveIndicatorElement(index) {
1504
      if (!this._indicatorsElement) {
1505
        return;
1506
      }
1507
1508
      const activeIndicator = SelectorEngine.findOne(SELECTOR_ACTIVE, this._indicatorsElement);
1509
      activeIndicator.classList.remove(CLASS_NAME_ACTIVE$2);
1510
      activeIndicator.removeAttribute('aria-current');
1511
      const newActiveIndicator = SelectorEngine.findOne(`[data-bs-slide-to="${index}"]`, this._indicatorsElement);
1512
1513
      if (newActiveIndicator) {
1514
        newActiveIndicator.classList.add(CLASS_NAME_ACTIVE$2);
1515
        newActiveIndicator.setAttribute('aria-current', 'true');
1516
      }
1517
    }
1518
1519
    _updateInterval() {
1520
      const element = this._activeElement || this._getActive();
1521
1522
      if (!element) {
1523
        return;
1524
      }
1525
1526
      const elementInterval = Number.parseInt(element.getAttribute('data-bs-interval'), 10);
1527
      this._config.interval = elementInterval || this._config.defaultInterval;
1528
    }
1529
1530
    _slide(order, element = null) {
1531
      if (this._isSliding) {
1532
        return;
1533
      }
1534
1535
      const activeElement = this._getActive();
1536
1537
      const isNext = order === ORDER_NEXT;
1538
      const nextElement = element || getNextActiveElement(this._getItems(), activeElement, isNext, this._config.wrap);
1539
1540
      if (nextElement === activeElement) {
1541
        return;
1542
      }
1543
1544
      const nextElementIndex = this._getItemIndex(nextElement);
1545
1546
      const triggerEvent = eventName => {
1547
        return EventHandler.trigger(this._element, eventName, {
1548
          relatedTarget: nextElement,
1549
          direction: this._orderToDirection(order),
1550
          from: this._getItemIndex(activeElement),
1551
          to: nextElementIndex
1552
        });
1553
      };
1554
1555
      const slideEvent = triggerEvent(EVENT_SLIDE);
1556
1557
      if (slideEvent.defaultPrevented) {
1558
        return;
1559
      }
1560
1561
      if (!activeElement || !nextElement) {
1562
        // Some weirdness is happening, so we bail
1563
        // todo: change tests that use empty divs to avoid this check
1564
        return;
1565
      }
1566
1567
      const isCycling = Boolean(this._interval);
1568
      this.pause();
1569
      this._isSliding = true;
1570
1571
      this._setActiveIndicatorElement(nextElementIndex);
1572
1573
      this._activeElement = nextElement;
1574
      const directionalClassName = isNext ? CLASS_NAME_START : CLASS_NAME_END;
1575
      const orderClassName = isNext ? CLASS_NAME_NEXT : CLASS_NAME_PREV;
1576
      nextElement.classList.add(orderClassName);
1577
      reflow(nextElement);
1578
      activeElement.classList.add(directionalClassName);
1579
      nextElement.classList.add(directionalClassName);
1580
1581
      const completeCallBack = () => {
1582
        nextElement.classList.remove(directionalClassName, orderClassName);
1583
        nextElement.classList.add(CLASS_NAME_ACTIVE$2);
1584
        activeElement.classList.remove(CLASS_NAME_ACTIVE$2, orderClassName, directionalClassName);
1585
        this._isSliding = false;
1586
        triggerEvent(EVENT_SLID);
1587
      };
1588
1589
      this._queueCallback(completeCallBack, activeElement, this._isAnimated());
1590
1591
      if (isCycling) {
1592
        this.cycle();
1593
      }
1594
    }
1595
1596
    _isAnimated() {
1597
      return this._element.classList.contains(CLASS_NAME_SLIDE);
1598
    }
1599
1600
    _getActive() {
1601
      return SelectorEngine.findOne(SELECTOR_ACTIVE_ITEM, this._element);
1602
    }
1603
1604
    _getItems() {
1605
      return SelectorEngine.find(SELECTOR_ITEM, this._element);
1606
    }
1607
1608
    _clearInterval() {
1609
      if (this._interval) {
1610
        clearInterval(this._interval);
1611
        this._interval = null;
1612
      }
1613
    }
1614
1615
    _directionToOrder(direction) {
1616
      if (isRTL()) {
1617
        return direction === DIRECTION_LEFT ? ORDER_PREV : ORDER_NEXT;
1618
      }
1619
1620
      return direction === DIRECTION_LEFT ? ORDER_NEXT : ORDER_PREV;
1621
    }
1622
1623
    _orderToDirection(order) {
1624
      if (isRTL()) {
1625
        return order === ORDER_PREV ? DIRECTION_LEFT : DIRECTION_RIGHT;
1626
      }
1627
1628
      return order === ORDER_PREV ? DIRECTION_RIGHT : DIRECTION_LEFT;
1629
    } // Static
1630
1631
1632
    static jQueryInterface(config) {
1633
      return this.each(function () {
1634
        const data = Carousel.getOrCreateInstance(this, config);
1635
1636
        if (typeof config === 'number') {
1637
          data.to(config);
1638
          return;
1639
        }
1640
1641
        if (typeof config === 'string') {
1642
          if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {
1643
            throw new TypeError(`No method named "${config}"`);
1644
          }
1645
1646
          data[config]();
1647
        }
1648
      });
1649
    }
1650
1651
  }
1652
  /**
1653
   * Data API implementation
1654
   */
1655
1656
1657
  EventHandler.on(document, EVENT_CLICK_DATA_API$5, SELECTOR_DATA_SLIDE, function (event) {
1658
    const target = getElementFromSelector(this);
1659
1660
    if (!target || !target.classList.contains(CLASS_NAME_CAROUSEL)) {
1661
      return;
1662
    }
1663
1664
    event.preventDefault();
1665
    const carousel = Carousel.getOrCreateInstance(target);
1666
    const slideIndex = this.getAttribute('data-bs-slide-to');
1667
1668
    if (slideIndex) {
1669
      carousel.to(slideIndex);
1670
1671
      carousel._maybeEnableCycle();
1672
1673
      return;
1674
    }
1675
1676
    if (Manipulator.getDataAttribute(this, 'slide') === 'next') {
1677
      carousel.next();
1678
1679
      carousel._maybeEnableCycle();
1680
1681
      return;
1682
    }
1683
1684
    carousel.prev();
1685
1686
    carousel._maybeEnableCycle();
1687
  });
1688
  EventHandler.on(window, EVENT_LOAD_DATA_API$3, () => {
1689
    const carousels = SelectorEngine.find(SELECTOR_DATA_RIDE);
1690
1691
    for (const carousel of carousels) {
1692
      Carousel.getOrCreateInstance(carousel);
1693
    }
1694
  });
1695
  /**
1696
   * jQuery
1697
   */
1698
1699
  defineJQueryPlugin(Carousel);
1700
1701
  /**
1702
   * --------------------------------------------------------------------------
1703
   * Bootstrap (v5.2.3): collapse.js
1704
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
1705
   * --------------------------------------------------------------------------
1706
   */
1707
  /**
1708
   * Constants
1709
   */
1710
1711
  const NAME$b = 'collapse';
1712
  const DATA_KEY$7 = 'bs.collapse';
1713
  const EVENT_KEY$7 = `.${DATA_KEY$7}`;
1714
  const DATA_API_KEY$4 = '.data-api';
1715
  const EVENT_SHOW$6 = `show${EVENT_KEY$7}`;
1716
  const EVENT_SHOWN$6 = `shown${EVENT_KEY$7}`;
1717
  const EVENT_HIDE$6 = `hide${EVENT_KEY$7}`;
1718
  const EVENT_HIDDEN$6 = `hidden${EVENT_KEY$7}`;
1719
  const EVENT_CLICK_DATA_API$4 = `click${EVENT_KEY$7}${DATA_API_KEY$4}`;
1720
  const CLASS_NAME_SHOW$7 = 'show';
1721
  const CLASS_NAME_COLLAPSE = 'collapse';
1722
  const CLASS_NAME_COLLAPSING = 'collapsing';
1723
  const CLASS_NAME_COLLAPSED = 'collapsed';
1724
  const CLASS_NAME_DEEPER_CHILDREN = `:scope .${CLASS_NAME_COLLAPSE} .${CLASS_NAME_COLLAPSE}`;
1725
  const CLASS_NAME_HORIZONTAL = 'collapse-horizontal';
1726
  const WIDTH = 'width';
1727
  const HEIGHT = 'height';
1728
  const SELECTOR_ACTIVES = '.collapse.show, .collapse.collapsing';
1729
  const SELECTOR_DATA_TOGGLE$4 = '[data-bs-toggle="collapse"]';
1730
  const Default$a = {
1731
    parent: null,
1732
    toggle: true
1733
  };
1734
  const DefaultType$a = {
1735
    parent: '(null|element)',
1736
    toggle: 'boolean'
1737
  };
1738
  /**
1739
   * Class definition
1740
   */
1741
1742
  class Collapse extends BaseComponent {
1743
    constructor(element, config) {
1744
      super(element, config);
1745
      this._isTransitioning = false;
1746
      this._triggerArray = [];
1747
      const toggleList = SelectorEngine.find(SELECTOR_DATA_TOGGLE$4);
1748
1749
      for (const elem of toggleList) {
1750
        const selector = getSelectorFromElement(elem);
1751
        const filterElement = SelectorEngine.find(selector).filter(foundElement => foundElement === this._element);
1752
1753
        if (selector !== null && filterElement.length) {
1754
          this._triggerArray.push(elem);
1755
        }
1756
      }
1757
1758
      this._initializeChildren();
1759
1760
      if (!this._config.parent) {
1761
        this._addAriaAndCollapsedClass(this._triggerArray, this._isShown());
1762
      }
1763
1764
      if (this._config.toggle) {
1765
        this.toggle();
1766
      }
1767
    } // Getters
1768
1769
1770
    static get Default() {
1771
      return Default$a;
1772
    }
1773
1774
    static get DefaultType() {
1775
      return DefaultType$a;
1776
    }
1777
1778
    static get NAME() {
1779
      return NAME$b;
1780
    } // Public
1781
1782
1783
    toggle() {
1784
      if (this._isShown()) {
1785
        this.hide();
1786
      } else {
1787
        this.show();
1788
      }
1789
    }
1790
1791
    show() {
1792
      if (this._isTransitioning || this._isShown()) {
1793
        return;
1794
      }
1795
1796
      let activeChildren = []; // find active children
1797
1798
      if (this._config.parent) {
1799
        activeChildren = this._getFirstLevelChildren(SELECTOR_ACTIVES).filter(element => element !== this._element).map(element => Collapse.getOrCreateInstance(element, {
1800
          toggle: false
1801
        }));
1802
      }
1803
1804
      if (activeChildren.length && activeChildren[0]._isTransitioning) {
1805
        return;
1806
      }
1807
1808
      const startEvent = EventHandler.trigger(this._element, EVENT_SHOW$6);
1809
1810
      if (startEvent.defaultPrevented) {
1811
        return;
1812
      }
1813
1814
      for (const activeInstance of activeChildren) {
1815
        activeInstance.hide();
1816
      }
1817
1818
      const dimension = this._getDimension();
1819
1820
      this._element.classList.remove(CLASS_NAME_COLLAPSE);
1821
1822
      this._element.classList.add(CLASS_NAME_COLLAPSING);
1823
1824
      this._element.style[dimension] = 0;
1825
1826
      this._addAriaAndCollapsedClass(this._triggerArray, true);
1827
1828
      this._isTransitioning = true;
1829
1830
      const complete = () => {
1831
        this._isTransitioning = false;
1832
1833
        this._element.classList.remove(CLASS_NAME_COLLAPSING);
1834
1835
        this._element.classList.add(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW$7);
1836
1837
        this._element.style[dimension] = '';
1838
        EventHandler.trigger(this._element, EVENT_SHOWN$6);
1839
      };
1840
1841
      const capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1);
1842
      const scrollSize = `scroll${capitalizedDimension}`;
1843
1844
      this._queueCallback(complete, this._element, true);
1845
1846
      this._element.style[dimension] = `${this._element[scrollSize]}px`;
1847
    }
1848
1849
    hide() {
1850
      if (this._isTransitioning || !this._isShown()) {
1851
        return;
1852
      }
1853
1854
      const startEvent = EventHandler.trigger(this._element, EVENT_HIDE$6);
1855
1856
      if (startEvent.defaultPrevented) {
1857
        return;
1858
      }
1859
1860
      const dimension = this._getDimension();
1861
1862
      this._element.style[dimension] = `${this._element.getBoundingClientRect()[dimension]}px`;
1863
      reflow(this._element);
1864
1865
      this._element.classList.add(CLASS_NAME_COLLAPSING);
1866
1867
      this._element.classList.remove(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW$7);
1868
1869
      for (const trigger of this._triggerArray) {
1870
        const element = getElementFromSelector(trigger);
1871
1872
        if (element && !this._isShown(element)) {
1873
          this._addAriaAndCollapsedClass([trigger], false);
1874
        }
1875
      }
1876
1877
      this._isTransitioning = true;
1878
1879
      const complete = () => {
1880
        this._isTransitioning = false;
1881
1882
        this._element.classList.remove(CLASS_NAME_COLLAPSING);
1883
1884
        this._element.classList.add(CLASS_NAME_COLLAPSE);
1885
1886
        EventHandler.trigger(this._element, EVENT_HIDDEN$6);
1887
      };
1888
1889
      this._element.style[dimension] = '';
1890
1891
      this._queueCallback(complete, this._element, true);
1892
    }
1893
1894
    _isShown(element = this._element) {
1895
      return element.classList.contains(CLASS_NAME_SHOW$7);
1896
    } // Private
1897
1898
1899
    _configAfterMerge(config) {
1900
      config.toggle = Boolean(config.toggle); // Coerce string values
1901
1902
      config.parent = getElement(config.parent);
1903
      return config;
1904
    }
1905
1906
    _getDimension() {
1907
      return this._element.classList.contains(CLASS_NAME_HORIZONTAL) ? WIDTH : HEIGHT;
1908
    }
1909
1910
    _initializeChildren() {
1911
      if (!this._config.parent) {
1912
        return;
1913
      }
1914
1915
      const children = this._getFirstLevelChildren(SELECTOR_DATA_TOGGLE$4);
1916
1917
      for (const element of children) {
1918
        const selected = getElementFromSelector(element);
1919
1920
        if (selected) {
1921
          this._addAriaAndCollapsedClass([element], this._isShown(selected));
1922
        }
1923
      }
1924
    }
1925
1926
    _getFirstLevelChildren(selector) {
1927
      const children = SelectorEngine.find(CLASS_NAME_DEEPER_CHILDREN, this._config.parent); // remove children if greater depth
1928
1929
      return SelectorEngine.find(selector, this._config.parent).filter(element => !children.includes(element));
1930
    }
1931
1932
    _addAriaAndCollapsedClass(triggerArray, isOpen) {
1933
      if (!triggerArray.length) {
1934
        return;
1935
      }
1936
1937
      for (const element of triggerArray) {
1938
        element.classList.toggle(CLASS_NAME_COLLAPSED, !isOpen);
1939
        element.setAttribute('aria-expanded', isOpen);
1940
      }
1941
    } // Static
1942
1943
1944
    static jQueryInterface(config) {
1945
      const _config = {};
1946
1947
      if (typeof config === 'string' && /show|hide/.test(config)) {
1948
        _config.toggle = false;
1949
      }
1950
1951
      return this.each(function () {
1952
        const data = Collapse.getOrCreateInstance(this, _config);
1953
1954
        if (typeof config === 'string') {
1955
          if (typeof data[config] === 'undefined') {
1956
            throw new TypeError(`No method named "${config}"`);
1957
          }
1958
1959
          data[config]();
1960
        }
1961
      });
1962
    }
1963
1964
  }
1965
  /**
1966
   * Data API implementation
1967
   */
1968
1969
1970
  EventHandler.on(document, EVENT_CLICK_DATA_API$4, SELECTOR_DATA_TOGGLE$4, function (event) {
1971
    // preventDefault only for <a> elements (which change the URL) not inside the collapsible element
1972
    if (event.target.tagName === 'A' || event.delegateTarget && event.delegateTarget.tagName === 'A') {
1973
      event.preventDefault();
1974
    }
1975
1976
    const selector = getSelectorFromElement(this);
1977
    const selectorElements = SelectorEngine.find(selector);
1978
1979
    for (const element of selectorElements) {
1980
      Collapse.getOrCreateInstance(element, {
1981
        toggle: false
1982
      }).toggle();
1983
    }
1984
  });
1985
  /**
1986
   * jQuery
1987
   */
1988
1989
  defineJQueryPlugin(Collapse);
1990
1991
  /**
1992
   * --------------------------------------------------------------------------
1993
   * Bootstrap (v5.2.3): dropdown.js
1994
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
1995
   * --------------------------------------------------------------------------
1996
   */
1997
  /**
1998
   * Constants
1999
   */
2000
2001
  const NAME$a = 'dropdown';
2002
  const DATA_KEY$6 = 'bs.dropdown';
2003
  const EVENT_KEY$6 = `.${DATA_KEY$6}`;
2004
  const DATA_API_KEY$3 = '.data-api';
2005
  const ESCAPE_KEY$2 = 'Escape';
2006
  const TAB_KEY$1 = 'Tab';
2007
  const ARROW_UP_KEY$1 = 'ArrowUp';
2008
  const ARROW_DOWN_KEY$1 = 'ArrowDown';
2009
  const RIGHT_MOUSE_BUTTON = 2; // MouseEvent.button value for the secondary button, usually the right button
2010
2011
  const EVENT_HIDE$5 = `hide${EVENT_KEY$6}`;
2012
  const EVENT_HIDDEN$5 = `hidden${EVENT_KEY$6}`;
2013
  const EVENT_SHOW$5 = `show${EVENT_KEY$6}`;
2014
  const EVENT_SHOWN$5 = `shown${EVENT_KEY$6}`;
2015
  const EVENT_CLICK_DATA_API$3 = `click${EVENT_KEY$6}${DATA_API_KEY$3}`;
2016
  const EVENT_KEYDOWN_DATA_API = `keydown${EVENT_KEY$6}${DATA_API_KEY$3}`;
2017
  const EVENT_KEYUP_DATA_API = `keyup${EVENT_KEY$6}${DATA_API_KEY$3}`;
2018
  const CLASS_NAME_SHOW$6 = 'show';
2019
  const CLASS_NAME_DROPUP = 'dropup';
2020
  const CLASS_NAME_DROPEND = 'dropend';
2021
  const CLASS_NAME_DROPSTART = 'dropstart';
2022
  const CLASS_NAME_DROPUP_CENTER = 'dropup-center';
2023
  const CLASS_NAME_DROPDOWN_CENTER = 'dropdown-center';
2024
  const SELECTOR_DATA_TOGGLE$3 = '[data-bs-toggle="dropdown"]:not(.disabled):not(:disabled)';
2025
  const SELECTOR_DATA_TOGGLE_SHOWN = `${SELECTOR_DATA_TOGGLE$3}.${CLASS_NAME_SHOW$6}`;
2026
  const SELECTOR_MENU = '.dropdown-menu';
2027
  const SELECTOR_NAVBAR = '.navbar';
2028
  const SELECTOR_NAVBAR_NAV = '.navbar-nav';
2029
  const SELECTOR_VISIBLE_ITEMS = '.dropdown-menu .dropdown-item:not(.disabled):not(:disabled)';
2030
  const PLACEMENT_TOP = isRTL() ? 'top-end' : 'top-start';
2031
  const PLACEMENT_TOPEND = isRTL() ? 'top-start' : 'top-end';
2032
  const PLACEMENT_BOTTOM = isRTL() ? 'bottom-end' : 'bottom-start';
2033
  const PLACEMENT_BOTTOMEND = isRTL() ? 'bottom-start' : 'bottom-end';
2034
  const PLACEMENT_RIGHT = isRTL() ? 'left-start' : 'right-start';
2035
  const PLACEMENT_LEFT = isRTL() ? 'right-start' : 'left-start';
2036
  const PLACEMENT_TOPCENTER = 'top';
2037
  const PLACEMENT_BOTTOMCENTER = 'bottom';
2038
  const Default$9 = {
2039
    autoClose: true,
2040
    boundary: 'clippingParents',
2041
    display: 'dynamic',
2042
    offset: [0, 2],
2043
    popperConfig: null,
2044
    reference: 'toggle'
2045
  };
2046
  const DefaultType$9 = {
2047
    autoClose: '(boolean|string)',
2048
    boundary: '(string|element)',
2049
    display: 'string',
2050
    offset: '(array|string|function)',
2051
    popperConfig: '(null|object|function)',
2052
    reference: '(string|element|object)'
2053
  };
2054
  /**
2055
   * Class definition
2056
   */
2057
2058
  class Dropdown extends BaseComponent {
2059
    constructor(element, config) {
2060
      super(element, config);
2061
      this._popper = null;
2062
      this._parent = this._element.parentNode; // dropdown wrapper
2063
      // todo: v6 revert #37011 & change markup https://getbootstrap.com/docs/5.2/forms/input-group/
2064
2065
      this._menu = SelectorEngine.next(this._element, SELECTOR_MENU)[0] || SelectorEngine.prev(this._element, SELECTOR_MENU)[0] || SelectorEngine.findOne(SELECTOR_MENU, this._parent);
2066
      this._inNavbar = this._detectNavbar();
2067
    } // Getters
2068
2069
2070
    static get Default() {
2071
      return Default$9;
2072
    }
2073
2074
    static get DefaultType() {
2075
      return DefaultType$9;
2076
    }
2077
2078
    static get NAME() {
2079
      return NAME$a;
2080
    } // Public
2081
2082
2083
    toggle() {
2084
      return this._isShown() ? this.hide() : this.show();
2085
    }
2086
2087
    show() {
2088
      if (isDisabled(this._element) || this._isShown()) {
2089
        return;
2090
      }
2091
2092
      const relatedTarget = {
2093
        relatedTarget: this._element
2094
      };
2095
      const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$5, relatedTarget);
2096
2097
      if (showEvent.defaultPrevented) {
2098
        return;
2099
      }
2100
2101
      this._createPopper(); // If this is a touch-enabled device we add extra
2102
      // empty mouseover listeners to the body's immediate children;
2103
      // only needed because of broken event delegation on iOS
2104
      // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html
2105
2106
2107
      if ('ontouchstart' in document.documentElement && !this._parent.closest(SELECTOR_NAVBAR_NAV)) {
2108
        for (const element of [].concat(...document.body.children)) {
2109
          EventHandler.on(element, 'mouseover', noop);
2110
        }
2111
      }
2112
2113
      this._element.focus();
2114
2115
      this._element.setAttribute('aria-expanded', true);
2116
2117
      this._menu.classList.add(CLASS_NAME_SHOW$6);
2118
2119
      this._element.classList.add(CLASS_NAME_SHOW$6);
2120
2121
      EventHandler.trigger(this._element, EVENT_SHOWN$5, relatedTarget);
2122
    }
2123
2124
    hide() {
2125
      if (isDisabled(this._element) || !this._isShown()) {
2126
        return;
2127
      }
2128
2129
      const relatedTarget = {
2130
        relatedTarget: this._element
2131
      };
2132
2133
      this._completeHide(relatedTarget);
2134
    }
2135
2136
    dispose() {
2137
      if (this._popper) {
2138
        this._popper.destroy();
2139
      }
2140
2141
      super.dispose();
2142
    }
2143
2144
    update() {
2145
      this._inNavbar = this._detectNavbar();
2146
2147
      if (this._popper) {
2148
        this._popper.update();
2149
      }
2150
    } // Private
2151
2152
2153
    _completeHide(relatedTarget) {
2154
      const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$5, relatedTarget);
2155
2156
      if (hideEvent.defaultPrevented) {
2157
        return;
2158
      } // If this is a touch-enabled device we remove the extra
2159
      // empty mouseover listeners we added for iOS support
2160
2161
2162
      if ('ontouchstart' in document.documentElement) {
2163
        for (const element of [].concat(...document.body.children)) {
2164
          EventHandler.off(element, 'mouseover', noop);
2165
        }
2166
      }
2167
2168
      if (this._popper) {
2169
        this._popper.destroy();
2170
      }
2171
2172
      this._menu.classList.remove(CLASS_NAME_SHOW$6);
2173
2174
      this._element.classList.remove(CLASS_NAME_SHOW$6);
2175
2176
      this._element.setAttribute('aria-expanded', 'false');
2177
2178
      Manipulator.removeDataAttribute(this._menu, 'popper');
2179
      EventHandler.trigger(this._element, EVENT_HIDDEN$5, relatedTarget);
2180
    }
2181
2182
    _getConfig(config) {
2183
      config = super._getConfig(config);
2184
2185
      if (typeof config.reference === 'object' && !isElement(config.reference) && typeof config.reference.getBoundingClientRect !== 'function') {
2186
        // Popper virtual elements require a getBoundingClientRect method
2187
        throw new TypeError(`${NAME$a.toUpperCase()}: Option "reference" provided type "object" without a required "getBoundingClientRect" method.`);
2188
      }
2189
2190
      return config;
2191
    }
2192
2193
    _createPopper() {
2194
      if (typeof Popper__namespace === 'undefined') {
2195
        throw new TypeError('Bootstrap\'s dropdowns require Popper (https://popper.js.org)');
2196
      }
2197
2198
      let referenceElement = this._element;
2199
2200
      if (this._config.reference === 'parent') {
2201
        referenceElement = this._parent;
2202
      } else if (isElement(this._config.reference)) {
2203
        referenceElement = getElement(this._config.reference);
2204
      } else if (typeof this._config.reference === 'object') {
2205
        referenceElement = this._config.reference;
2206
      }
2207
2208
      const popperConfig = this._getPopperConfig();
2209
2210
      this._popper = Popper__namespace.createPopper(referenceElement, this._menu, popperConfig);
2211
    }
2212
2213
    _isShown() {
2214
      return this._menu.classList.contains(CLASS_NAME_SHOW$6);
2215
    }
2216
2217
    _getPlacement() {
2218
      const parentDropdown = this._parent;
2219
2220
      if (parentDropdown.classList.contains(CLASS_NAME_DROPEND)) {
2221
        return PLACEMENT_RIGHT;
2222
      }
2223
2224
      if (parentDropdown.classList.contains(CLASS_NAME_DROPSTART)) {
2225
        return PLACEMENT_LEFT;
2226
      }
2227
2228
      if (parentDropdown.classList.contains(CLASS_NAME_DROPUP_CENTER)) {
2229
        return PLACEMENT_TOPCENTER;
2230
      }
2231
2232
      if (parentDropdown.classList.contains(CLASS_NAME_DROPDOWN_CENTER)) {
2233
        return PLACEMENT_BOTTOMCENTER;
2234
      } // We need to trim the value because custom properties can also include spaces
2235
2236
2237
      const isEnd = getComputedStyle(this._menu).getPropertyValue('--bs-position').trim() === 'end';
2238
2239
      if (parentDropdown.classList.contains(CLASS_NAME_DROPUP)) {
2240
        return isEnd ? PLACEMENT_TOPEND : PLACEMENT_TOP;
2241
      }
2242
2243
      return isEnd ? PLACEMENT_BOTTOMEND : PLACEMENT_BOTTOM;
2244
    }
2245
2246
    _detectNavbar() {
2247
      return this._element.closest(SELECTOR_NAVBAR) !== null;
2248
    }
2249
2250
    _getOffset() {
2251
      const {
2252
        offset
2253
      } = this._config;
2254
2255
      if (typeof offset === 'string') {
2256
        return offset.split(',').map(value => Number.parseInt(value, 10));
2257
      }
2258
2259
      if (typeof offset === 'function') {
2260
        return popperData => offset(popperData, this._element);
2261
      }
2262
2263
      return offset;
2264
    }
2265
2266
    _getPopperConfig() {
2267
      const defaultBsPopperConfig = {
2268
        placement: this._getPlacement(),
2269
        modifiers: [{
2270
          name: 'preventOverflow',
2271
          options: {
2272
            boundary: this._config.boundary
2273
          }
2274
        }, {
2275
          name: 'offset',
2276
          options: {
2277
            offset: this._getOffset()
2278
          }
2279
        }]
2280
      }; // Disable Popper if we have a static display or Dropdown is in Navbar
2281
2282
      if (this._inNavbar || this._config.display === 'static') {
2283
        Manipulator.setDataAttribute(this._menu, 'popper', 'static'); // todo:v6 remove
2284
2285
        defaultBsPopperConfig.modifiers = [{
2286
          name: 'applyStyles',
2287
          enabled: false
2288
        }];
2289
      }
2290
2291
      return { ...defaultBsPopperConfig,
2292
        ...(typeof this._config.popperConfig === 'function' ? this._config.popperConfig(defaultBsPopperConfig) : this._config.popperConfig)
2293
      };
2294
    }
2295
2296
    _selectMenuItem({
2297
      key,
2298
      target
2299
    }) {
2300
      const items = SelectorEngine.find(SELECTOR_VISIBLE_ITEMS, this._menu).filter(element => isVisible(element));
2301
2302
      if (!items.length) {
2303
        return;
2304
      } // if target isn't included in items (e.g. when expanding the dropdown)
2305
      // allow cycling to get the last item in case key equals ARROW_UP_KEY
2306
2307
2308
      getNextActiveElement(items, target, key === ARROW_DOWN_KEY$1, !items.includes(target)).focus();
2309
    } // Static
2310
2311
2312
    static jQueryInterface(config) {
2313
      return this.each(function () {
2314
        const data = Dropdown.getOrCreateInstance(this, config);
2315
2316
        if (typeof config !== 'string') {
2317
          return;
2318
        }
2319
2320
        if (typeof data[config] === 'undefined') {
2321
          throw new TypeError(`No method named "${config}"`);
2322
        }
2323
2324
        data[config]();
2325
      });
2326
    }
2327
2328
    static clearMenus(event) {
2329
      if (event.button === RIGHT_MOUSE_BUTTON || event.type === 'keyup' && event.key !== TAB_KEY$1) {
2330
        return;
2331
      }
2332
2333
      const openToggles = SelectorEngine.find(SELECTOR_DATA_TOGGLE_SHOWN);
2334
2335
      for (const toggle of openToggles) {
2336
        const context = Dropdown.getInstance(toggle);
2337
2338
        if (!context || context._config.autoClose === false) {
2339
          continue;
2340
        }
2341
2342
        const composedPath = event.composedPath();
2343
        const isMenuTarget = composedPath.includes(context._menu);
2344
2345
        if (composedPath.includes(context._element) || context._config.autoClose === 'inside' && !isMenuTarget || context._config.autoClose === 'outside' && isMenuTarget) {
2346
          continue;
2347
        } // Tab navigation through the dropdown menu or events from contained inputs shouldn't close the menu
2348
2349
2350
        if (context._menu.contains(event.target) && (event.type === 'keyup' && event.key === TAB_KEY$1 || /input|select|option|textarea|form/i.test(event.target.tagName))) {
2351
          continue;
2352
        }
2353
2354
        const relatedTarget = {
2355
          relatedTarget: context._element
2356
        };
2357
2358
        if (event.type === 'click') {
2359
          relatedTarget.clickEvent = event;
2360
        }
2361
2362
        context._completeHide(relatedTarget);
2363
      }
2364
    }
2365
2366
    static dataApiKeydownHandler(event) {
2367
      // If not an UP | DOWN | ESCAPE key => not a dropdown command
2368
      // If input/textarea && if key is other than ESCAPE => not a dropdown command
2369
      const isInput = /input|textarea/i.test(event.target.tagName);
2370
      const isEscapeEvent = event.key === ESCAPE_KEY$2;
2371
      const isUpOrDownEvent = [ARROW_UP_KEY$1, ARROW_DOWN_KEY$1].includes(event.key);
2372
2373
      if (!isUpOrDownEvent && !isEscapeEvent) {
2374
        return;
2375
      }
2376
2377
      if (isInput && !isEscapeEvent) {
2378
        return;
2379
      }
2380
2381
      event.preventDefault(); // todo: v6 revert #37011 & change markup https://getbootstrap.com/docs/5.2/forms/input-group/
2382
2383
      const getToggleButton = this.matches(SELECTOR_DATA_TOGGLE$3) ? this : SelectorEngine.prev(this, SELECTOR_DATA_TOGGLE$3)[0] || SelectorEngine.next(this, SELECTOR_DATA_TOGGLE$3)[0] || SelectorEngine.findOne(SELECTOR_DATA_TOGGLE$3, event.delegateTarget.parentNode);
2384
      const instance = Dropdown.getOrCreateInstance(getToggleButton);
2385
2386
      if (isUpOrDownEvent) {
2387
        event.stopPropagation();
2388
        instance.show();
2389
2390
        instance._selectMenuItem(event);
2391
2392
        return;
2393
      }
2394
2395
      if (instance._isShown()) {
2396
        // else is escape and we check if it is shown
2397
        event.stopPropagation();
2398
        instance.hide();
2399
        getToggleButton.focus();
2400
      }
2401
    }
2402
2403
  }
2404
  /**
2405
   * Data API implementation
2406
   */
2407
2408
2409
  EventHandler.on(document, EVENT_KEYDOWN_DATA_API, SELECTOR_DATA_TOGGLE$3, Dropdown.dataApiKeydownHandler);
2410
  EventHandler.on(document, EVENT_KEYDOWN_DATA_API, SELECTOR_MENU, Dropdown.dataApiKeydownHandler);
2411
  EventHandler.on(document, EVENT_CLICK_DATA_API$3, Dropdown.clearMenus);
2412
  EventHandler.on(document, EVENT_KEYUP_DATA_API, Dropdown.clearMenus);
2413
  EventHandler.on(document, EVENT_CLICK_DATA_API$3, SELECTOR_DATA_TOGGLE$3, function (event) {
2414
    event.preventDefault();
2415
    Dropdown.getOrCreateInstance(this).toggle();
2416
  });
2417
  /**
2418
   * jQuery
2419
   */
2420
2421
  defineJQueryPlugin(Dropdown);
2422
2423
  /**
2424
   * --------------------------------------------------------------------------
2425
   * Bootstrap (v5.2.3): util/scrollBar.js
2426
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
2427
   * --------------------------------------------------------------------------
2428
   */
2429
  /**
2430
   * Constants
2431
   */
2432
2433
  const SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top';
2434
  const SELECTOR_STICKY_CONTENT = '.sticky-top';
2435
  const PROPERTY_PADDING = 'padding-right';
2436
  const PROPERTY_MARGIN = 'margin-right';
2437
  /**
2438
   * Class definition
2439
   */
2440
2441
  class ScrollBarHelper {
2442
    constructor() {
2443
      this._element = document.body;
2444
    } // Public
2445
2446
2447
    getWidth() {
2448
      // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes
2449
      const documentWidth = document.documentElement.clientWidth;
2450
      return Math.abs(window.innerWidth - documentWidth);
2451
    }
2452
2453
    hide() {
2454
      const width = this.getWidth();
2455
2456
      this._disableOverFlow(); // give padding to element to balance the hidden scrollbar width
2457
2458
2459
      this._setElementAttributes(this._element, PROPERTY_PADDING, calculatedValue => calculatedValue + width); // trick: We adjust positive paddingRight and negative marginRight to sticky-top elements to keep showing fullwidth
2460
2461
2462
      this._setElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING, calculatedValue => calculatedValue + width);
2463
2464
      this._setElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN, calculatedValue => calculatedValue - width);
2465
    }
2466
2467
    reset() {
2468
      this._resetElementAttributes(this._element, 'overflow');
2469
2470
      this._resetElementAttributes(this._element, PROPERTY_PADDING);
2471
2472
      this._resetElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING);
2473
2474
      this._resetElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN);
2475
    }
2476
2477
    isOverflowing() {
2478
      return this.getWidth() > 0;
2479
    } // Private
2480
2481
2482
    _disableOverFlow() {
2483
      this._saveInitialAttribute(this._element, 'overflow');
2484
2485
      this._element.style.overflow = 'hidden';
2486
    }
2487
2488
    _setElementAttributes(selector, styleProperty, callback) {
2489
      const scrollbarWidth = this.getWidth();
2490
2491
      const manipulationCallBack = element => {
2492
        if (element !== this._element && window.innerWidth > element.clientWidth + scrollbarWidth) {
2493
          return;
2494
        }
2495
2496
        this._saveInitialAttribute(element, styleProperty);
2497
2498
        const calculatedValue = window.getComputedStyle(element).getPropertyValue(styleProperty);
2499
        element.style.setProperty(styleProperty, `${callback(Number.parseFloat(calculatedValue))}px`);
2500
      };
2501
2502
      this._applyManipulationCallback(selector, manipulationCallBack);
2503
    }
2504
2505
    _saveInitialAttribute(element, styleProperty) {
2506
      const actualValue = element.style.getPropertyValue(styleProperty);
2507
2508
      if (actualValue) {
2509
        Manipulator.setDataAttribute(element, styleProperty, actualValue);
2510
      }
2511
    }
2512
2513
    _resetElementAttributes(selector, styleProperty) {
2514
      const manipulationCallBack = element => {
2515
        const value = Manipulator.getDataAttribute(element, styleProperty); // We only want to remove the property if the value is `null`; the value can also be zero
2516
2517
        if (value === null) {
2518
          element.style.removeProperty(styleProperty);
2519
          return;
2520
        }
2521
2522
        Manipulator.removeDataAttribute(element, styleProperty);
2523
        element.style.setProperty(styleProperty, value);
2524
      };
2525
2526
      this._applyManipulationCallback(selector, manipulationCallBack);
2527
    }
2528
2529
    _applyManipulationCallback(selector, callBack) {
2530
      if (isElement(selector)) {
2531
        callBack(selector);
2532
        return;
2533
      }
2534
2535
      for (const sel of SelectorEngine.find(selector, this._element)) {
2536
        callBack(sel);
2537
      }
2538
    }
2539
2540
  }
2541
2542
  /**
2543
   * --------------------------------------------------------------------------
2544
   * Bootstrap (v5.2.3): util/backdrop.js
2545
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
2546
   * --------------------------------------------------------------------------
2547
   */
2548
  /**
2549
   * Constants
2550
   */
2551
2552
  const NAME$9 = 'backdrop';
2553
  const CLASS_NAME_FADE$4 = 'fade';
2554
  const CLASS_NAME_SHOW$5 = 'show';
2555
  const EVENT_MOUSEDOWN = `mousedown.bs.${NAME$9}`;
2556
  const Default$8 = {
2557
    className: 'modal-backdrop',
2558
    clickCallback: null,
2559
    isAnimated: false,
2560
    isVisible: true,
2561
    // if false, we use the backdrop helper without adding any element to the dom
2562
    rootElement: 'body' // give the choice to place backdrop under different elements
2563
2564
  };
2565
  const DefaultType$8 = {
2566
    className: 'string',
2567
    clickCallback: '(function|null)',
2568
    isAnimated: 'boolean',
2569
    isVisible: 'boolean',
2570
    rootElement: '(element|string)'
2571
  };
2572
  /**
2573
   * Class definition
2574
   */
2575
2576
  class Backdrop extends Config {
2577
    constructor(config) {
2578
      super();
2579
      this._config = this._getConfig(config);
2580
      this._isAppended = false;
2581
      this._element = null;
2582
    } // Getters
2583
2584
2585
    static get Default() {
2586
      return Default$8;
2587
    }
2588
2589
    static get DefaultType() {
2590
      return DefaultType$8;
2591
    }
2592
2593
    static get NAME() {
2594
      return NAME$9;
2595
    } // Public
2596
2597
2598
    show(callback) {
2599
      if (!this._config.isVisible) {
2600
        execute(callback);
2601
        return;
2602
      }
2603
2604
      this._append();
2605
2606
      const element = this._getElement();
2607
2608
      if (this._config.isAnimated) {
2609
        reflow(element);
2610
      }
2611
2612
      element.classList.add(CLASS_NAME_SHOW$5);
2613
2614
      this._emulateAnimation(() => {
2615
        execute(callback);
2616
      });
2617
    }
2618
2619
    hide(callback) {
2620
      if (!this._config.isVisible) {
2621
        execute(callback);
2622
        return;
2623
      }
2624
2625
      this._getElement().classList.remove(CLASS_NAME_SHOW$5);
2626
2627
      this._emulateAnimation(() => {
2628
        this.dispose();
2629
        execute(callback);
2630
      });
2631
    }
2632
2633
    dispose() {
2634
      if (!this._isAppended) {
2635
        return;
2636
      }
2637
2638
      EventHandler.off(this._element, EVENT_MOUSEDOWN);
2639
2640
      this._element.remove();
2641
2642
      this._isAppended = false;
2643
    } // Private
2644
2645
2646
    _getElement() {
2647
      if (!this._element) {
2648
        const backdrop = document.createElement('div');
2649
        backdrop.className = this._config.className;
2650
2651
        if (this._config.isAnimated) {
2652
          backdrop.classList.add(CLASS_NAME_FADE$4);
2653
        }
2654
2655
        this._element = backdrop;
2656
      }
2657
2658
      return this._element;
2659
    }
2660
2661
    _configAfterMerge(config) {
2662
      // use getElement() with the default "body" to get a fresh Element on each instantiation
2663
      config.rootElement = getElement(config.rootElement);
2664
      return config;
2665
    }
2666
2667
    _append() {
2668
      if (this._isAppended) {
2669
        return;
2670
      }
2671
2672
      const element = this._getElement();
2673
2674
      this._config.rootElement.append(element);
2675
2676
      EventHandler.on(element, EVENT_MOUSEDOWN, () => {
2677
        execute(this._config.clickCallback);
2678
      });
2679
      this._isAppended = true;
2680
    }
2681
2682
    _emulateAnimation(callback) {
2683
      executeAfterTransition(callback, this._getElement(), this._config.isAnimated);
2684
    }
2685
2686
  }
2687
2688
  /**
2689
   * --------------------------------------------------------------------------
2690
   * Bootstrap (v5.2.3): util/focustrap.js
2691
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
2692
   * --------------------------------------------------------------------------
2693
   */
2694
  /**
2695
   * Constants
2696
   */
2697
2698
  const NAME$8 = 'focustrap';
2699
  const DATA_KEY$5 = 'bs.focustrap';
2700
  const EVENT_KEY$5 = `.${DATA_KEY$5}`;
2701
  const EVENT_FOCUSIN$2 = `focusin${EVENT_KEY$5}`;
2702
  const EVENT_KEYDOWN_TAB = `keydown.tab${EVENT_KEY$5}`;
2703
  const TAB_KEY = 'Tab';
2704
  const TAB_NAV_FORWARD = 'forward';
2705
  const TAB_NAV_BACKWARD = 'backward';
2706
  const Default$7 = {
2707
    autofocus: true,
2708
    trapElement: null // The element to trap focus inside of
2709
2710
  };
2711
  const DefaultType$7 = {
2712
    autofocus: 'boolean',
2713
    trapElement: 'element'
2714
  };
2715
  /**
2716
   * Class definition
2717
   */
2718
2719
  class FocusTrap extends Config {
2720
    constructor(config) {
2721
      super();
2722
      this._config = this._getConfig(config);
2723
      this._isActive = false;
2724
      this._lastTabNavDirection = null;
2725
    } // Getters
2726
2727
2728
    static get Default() {
2729
      return Default$7;
2730
    }
2731
2732
    static get DefaultType() {
2733
      return DefaultType$7;
2734
    }
2735
2736
    static get NAME() {
2737
      return NAME$8;
2738
    } // Public
2739
2740
2741
    activate() {
2742
      if (this._isActive) {
2743
        return;
2744
      }
2745
2746
      if (this._config.autofocus) {
2747
        this._config.trapElement.focus();
2748
      }
2749
2750
      EventHandler.off(document, EVENT_KEY$5); // guard against infinite focus loop
2751
2752
      EventHandler.on(document, EVENT_FOCUSIN$2, event => this._handleFocusin(event));
2753
      EventHandler.on(document, EVENT_KEYDOWN_TAB, event => this._handleKeydown(event));
2754
      this._isActive = true;
2755
    }
2756
2757
    deactivate() {
2758
      if (!this._isActive) {
2759
        return;
2760
      }
2761
2762
      this._isActive = false;
2763
      EventHandler.off(document, EVENT_KEY$5);
2764
    } // Private
2765
2766
2767
    _handleFocusin(event) {
2768
      const {
2769
        trapElement
2770
      } = this._config;
2771
2772
      if (event.target === document || event.target === trapElement || trapElement.contains(event.target)) {
2773
        return;
2774
      }
2775
2776
      const elements = SelectorEngine.focusableChildren(trapElement);
2777
2778
      if (elements.length === 0) {
2779
        trapElement.focus();
2780
      } else if (this._lastTabNavDirection === TAB_NAV_BACKWARD) {
2781
        elements[elements.length - 1].focus();
2782
      } else {
2783
        elements[0].focus();
2784
      }
2785
    }
2786
2787
    _handleKeydown(event) {
2788
      if (event.key !== TAB_KEY) {
2789
        return;
2790
      }
2791
2792
      this._lastTabNavDirection = event.shiftKey ? TAB_NAV_BACKWARD : TAB_NAV_FORWARD;
2793
    }
2794
2795
  }
2796
2797
  /**
2798
   * --------------------------------------------------------------------------
2799
   * Bootstrap (v5.2.3): modal.js
2800
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
2801
   * --------------------------------------------------------------------------
2802
   */
2803
  /**
2804
   * Constants
2805
   */
2806
2807
  const NAME$7 = 'modal';
2808
  const DATA_KEY$4 = 'bs.modal';
2809
  const EVENT_KEY$4 = `.${DATA_KEY$4}`;
2810
  const DATA_API_KEY$2 = '.data-api';
2811
  const ESCAPE_KEY$1 = 'Escape';
2812
  const EVENT_HIDE$4 = `hide${EVENT_KEY$4}`;
2813
  const EVENT_HIDE_PREVENTED$1 = `hidePrevented${EVENT_KEY$4}`;
2814
  const EVENT_HIDDEN$4 = `hidden${EVENT_KEY$4}`;
2815
  const EVENT_SHOW$4 = `show${EVENT_KEY$4}`;
2816
  const EVENT_SHOWN$4 = `shown${EVENT_KEY$4}`;
2817
  const EVENT_RESIZE$1 = `resize${EVENT_KEY$4}`;
2818
  const EVENT_CLICK_DISMISS = `click.dismiss${EVENT_KEY$4}`;
2819
  const EVENT_MOUSEDOWN_DISMISS = `mousedown.dismiss${EVENT_KEY$4}`;
2820
  const EVENT_KEYDOWN_DISMISS$1 = `keydown.dismiss${EVENT_KEY$4}`;
2821
  const EVENT_CLICK_DATA_API$2 = `click${EVENT_KEY$4}${DATA_API_KEY$2}`;
2822
  const CLASS_NAME_OPEN = 'modal-open';
2823
  const CLASS_NAME_FADE$3 = 'fade';
2824
  const CLASS_NAME_SHOW$4 = 'show';
2825
  const CLASS_NAME_STATIC = 'modal-static';
2826
  const OPEN_SELECTOR$1 = '.modal.show';
2827
  const SELECTOR_DIALOG = '.modal-dialog';
2828
  const SELECTOR_MODAL_BODY = '.modal-body';
2829
  const SELECTOR_DATA_TOGGLE$2 = '[data-bs-toggle="modal"]';
2830
  const Default$6 = {
2831
    backdrop: true,
2832
    focus: true,
2833
    keyboard: true
2834
  };
2835
  const DefaultType$6 = {
2836
    backdrop: '(boolean|string)',
2837
    focus: 'boolean',
2838
    keyboard: 'boolean'
2839
  };
2840
  /**
2841
   * Class definition
2842
   */
2843
2844
  class Modal extends BaseComponent {
2845
    constructor(element, config) {
2846
      super(element, config);
2847
      this._dialog = SelectorEngine.findOne(SELECTOR_DIALOG, this._element);
2848
      this._backdrop = this._initializeBackDrop();
2849
      this._focustrap = this._initializeFocusTrap();
2850
      this._isShown = false;
2851
      this._isTransitioning = false;
2852
      this._scrollBar = new ScrollBarHelper();
2853
2854
      this._addEventListeners();
2855
    } // Getters
2856
2857
2858
    static get Default() {
2859
      return Default$6;
2860
    }
2861
2862
    static get DefaultType() {
2863
      return DefaultType$6;
2864
    }
2865
2866
    static get NAME() {
2867
      return NAME$7;
2868
    } // Public
2869
2870
2871
    toggle(relatedTarget) {
2872
      return this._isShown ? this.hide() : this.show(relatedTarget);
2873
    }
2874
2875
    show(relatedTarget) {
2876
      if (this._isShown || this._isTransitioning) {
2877
        return;
2878
      }
2879
2880
      const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$4, {
2881
        relatedTarget
2882
      });
2883
2884
      if (showEvent.defaultPrevented) {
2885
        return;
2886
      }
2887
2888
      this._isShown = true;
2889
      this._isTransitioning = true;
2890
2891
      this._scrollBar.hide();
2892
2893
      document.body.classList.add(CLASS_NAME_OPEN);
2894
2895
      this._adjustDialog();
2896
2897
      this._backdrop.show(() => this._showElement(relatedTarget));
2898
    }
2899
2900
    hide() {
2901
      if (!this._isShown || this._isTransitioning) {
2902
        return;
2903
      }
2904
2905
      const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$4);
2906
2907
      if (hideEvent.defaultPrevented) {
2908
        return;
2909
      }
2910
2911
      this._isShown = false;
2912
      this._isTransitioning = true;
2913
2914
      this._focustrap.deactivate();
2915
2916
      this._element.classList.remove(CLASS_NAME_SHOW$4);
2917
2918
      this._queueCallback(() => this._hideModal(), this._element, this._isAnimated());
2919
    }
2920
2921
    dispose() {
2922
      for (const htmlElement of [window, this._dialog]) {
2923
        EventHandler.off(htmlElement, EVENT_KEY$4);
2924
      }
2925
2926
      this._backdrop.dispose();
2927
2928
      this._focustrap.deactivate();
2929
2930
      super.dispose();
2931
    }
2932
2933
    handleUpdate() {
2934
      this._adjustDialog();
2935
    } // Private
2936
2937
2938
    _initializeBackDrop() {
2939
      return new Backdrop({
2940
        isVisible: Boolean(this._config.backdrop),
2941
        // 'static' option will be translated to true, and booleans will keep their value,
2942
        isAnimated: this._isAnimated()
2943
      });
2944
    }
2945
2946
    _initializeFocusTrap() {
2947
      return new FocusTrap({
2948
        trapElement: this._element
2949
      });
2950
    }
2951
2952
    _showElement(relatedTarget) {
2953
      // try to append dynamic modal
2954
      if (!document.body.contains(this._element)) {
2955
        document.body.append(this._element);
2956
      }
2957
2958
      this._element.style.display = 'block';
2959
2960
      this._element.removeAttribute('aria-hidden');
2961
2962
      this._element.setAttribute('aria-modal', true);
2963
2964
      this._element.setAttribute('role', 'dialog');
2965
2966
      this._element.scrollTop = 0;
2967
      const modalBody = SelectorEngine.findOne(SELECTOR_MODAL_BODY, this._dialog);
2968
2969
      if (modalBody) {
2970
        modalBody.scrollTop = 0;
2971
      }
2972
2973
      reflow(this._element);
2974
2975
      this._element.classList.add(CLASS_NAME_SHOW$4);
2976
2977
      const transitionComplete = () => {
2978
        if (this._config.focus) {
2979
          this._focustrap.activate();
2980
        }
2981
2982
        this._isTransitioning = false;
2983
        EventHandler.trigger(this._element, EVENT_SHOWN$4, {
2984
          relatedTarget
2985
        });
2986
      };
2987
2988
      this._queueCallback(transitionComplete, this._dialog, this._isAnimated());
2989
    }
2990
2991
    _addEventListeners() {
2992
      EventHandler.on(this._element, EVENT_KEYDOWN_DISMISS$1, event => {
2993
        if (event.key !== ESCAPE_KEY$1) {
2994
          return;
2995
        }
2996
2997
        if (this._config.keyboard) {
2998
          event.preventDefault();
2999
          this.hide();
3000
          return;
3001
        }
3002
3003
        this._triggerBackdropTransition();
3004
      });
3005
      EventHandler.on(window, EVENT_RESIZE$1, () => {
3006
        if (this._isShown && !this._isTransitioning) {
3007
          this._adjustDialog();
3008
        }
3009
      });
3010
      EventHandler.on(this._element, EVENT_MOUSEDOWN_DISMISS, event => {
3011
        // a bad trick to segregate clicks that may start inside dialog but end outside, and avoid listen to scrollbar clicks
3012
        EventHandler.one(this._element, EVENT_CLICK_DISMISS, event2 => {
3013
          if (this._element !== event.target || this._element !== event2.target) {
3014
            return;
3015
          }
3016
3017
          if (this._config.backdrop === 'static') {
3018
            this._triggerBackdropTransition();
3019
3020
            return;
3021
          }
3022
3023
          if (this._config.backdrop) {
3024
            this.hide();
3025
          }
3026
        });
3027
      });
3028
    }
3029
3030
    _hideModal() {
3031
      this._element.style.display = 'none';
3032
3033
      this._element.setAttribute('aria-hidden', true);
3034
3035
      this._element.removeAttribute('aria-modal');
3036
3037
      this._element.removeAttribute('role');
3038
3039
      this._isTransitioning = false;
3040
3041
      this._backdrop.hide(() => {
3042
        document.body.classList.remove(CLASS_NAME_OPEN);
3043
3044
        this._resetAdjustments();
3045
3046
        this._scrollBar.reset();
3047
3048
        EventHandler.trigger(this._element, EVENT_HIDDEN$4);
3049
      });
3050
    }
3051
3052
    _isAnimated() {
3053
      return this._element.classList.contains(CLASS_NAME_FADE$3);
3054
    }
3055
3056
    _triggerBackdropTransition() {
3057
      const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED$1);
3058
3059
      if (hideEvent.defaultPrevented) {
3060
        return;
3061
      }
3062
3063
      const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;
3064
      const initialOverflowY = this._element.style.overflowY; // return if the following background transition hasn't yet completed
3065
3066
      if (initialOverflowY === 'hidden' || this._element.classList.contains(CLASS_NAME_STATIC)) {
3067
        return;
3068
      }
3069
3070
      if (!isModalOverflowing) {
3071
        this._element.style.overflowY = 'hidden';
3072
      }
3073
3074
      this._element.classList.add(CLASS_NAME_STATIC);
3075
3076
      this._queueCallback(() => {
3077
        this._element.classList.remove(CLASS_NAME_STATIC);
3078
3079
        this._queueCallback(() => {
3080
          this._element.style.overflowY = initialOverflowY;
3081
        }, this._dialog);
3082
      }, this._dialog);
3083
3084
      this._element.focus();
3085
    }
3086
    /**
3087
     * The following methods are used to handle overflowing modals
3088
     */
3089
3090
3091
    _adjustDialog() {
3092
      const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;
3093
3094
      const scrollbarWidth = this._scrollBar.getWidth();
3095
3096
      const isBodyOverflowing = scrollbarWidth > 0;
3097
3098
      if (isBodyOverflowing && !isModalOverflowing) {
3099
        const property = isRTL() ? 'paddingLeft' : 'paddingRight';
3100
        this._element.style[property] = `${scrollbarWidth}px`;
3101
      }
3102
3103
      if (!isBodyOverflowing && isModalOverflowing) {
3104
        const property = isRTL() ? 'paddingRight' : 'paddingLeft';
3105
        this._element.style[property] = `${scrollbarWidth}px`;
3106
      }
3107
    }
3108
3109
    _resetAdjustments() {
3110
      this._element.style.paddingLeft = '';
3111
      this._element.style.paddingRight = '';
3112
    } // Static
3113
3114
3115
    static jQueryInterface(config, relatedTarget) {
3116
      return this.each(function () {
3117
        const data = Modal.getOrCreateInstance(this, config);
3118
3119
        if (typeof config !== 'string') {
3120
          return;
3121
        }
3122
3123
        if (typeof data[config] === 'undefined') {
3124
          throw new TypeError(`No method named "${config}"`);
3125
        }
3126
3127
        data[config](relatedTarget);
3128
      });
3129
    }
3130
3131
  }
3132
  /**
3133
   * Data API implementation
3134
   */
3135
3136
3137
  EventHandler.on(document, EVENT_CLICK_DATA_API$2, SELECTOR_DATA_TOGGLE$2, function (event) {
3138
    const target = getElementFromSelector(this);
3139
3140
    if (['A', 'AREA'].includes(this.tagName)) {
3141
      event.preventDefault();
3142
    }
3143
3144
    EventHandler.one(target, EVENT_SHOW$4, showEvent => {
3145
      if (showEvent.defaultPrevented) {
3146
        // only register focus restorer if modal will actually get shown
3147
        return;
3148
      }
3149
3150
      EventHandler.one(target, EVENT_HIDDEN$4, () => {
3151
        if (isVisible(this)) {
3152
          this.focus();
3153
        }
3154
      });
3155
    }); // avoid conflict when clicking modal toggler while another one is open
3156
3157
    const alreadyOpen = SelectorEngine.findOne(OPEN_SELECTOR$1);
3158
3159
    if (alreadyOpen) {
3160
      Modal.getInstance(alreadyOpen).hide();
3161 950e6b84 taeseongkim
    }
3162
3163 65674874 taeseongkim
    const data = Modal.getOrCreateInstance(target);
3164
    data.toggle(this);
3165
  });
3166
  enableDismissTrigger(Modal);
3167
  /**
3168
   * jQuery
3169
   */
3170 950e6b84 taeseongkim
3171 65674874 taeseongkim
  defineJQueryPlugin(Modal);
3172
3173
  /**
3174
   * --------------------------------------------------------------------------
3175
   * Bootstrap (v5.2.3): offcanvas.js
3176
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
3177
   * --------------------------------------------------------------------------
3178
   */
3179
  /**
3180
   * Constants
3181
   */
3182
3183
  const NAME$6 = 'offcanvas';
3184
  const DATA_KEY$3 = 'bs.offcanvas';
3185
  const EVENT_KEY$3 = `.${DATA_KEY$3}`;
3186
  const DATA_API_KEY$1 = '.data-api';
3187
  const EVENT_LOAD_DATA_API$2 = `load${EVENT_KEY$3}${DATA_API_KEY$1}`;
3188
  const ESCAPE_KEY = 'Escape';
3189
  const CLASS_NAME_SHOW$3 = 'show';
3190
  const CLASS_NAME_SHOWING$1 = 'showing';
3191
  const CLASS_NAME_HIDING = 'hiding';
3192
  const CLASS_NAME_BACKDROP = 'offcanvas-backdrop';
3193
  const OPEN_SELECTOR = '.offcanvas.show';
3194
  const EVENT_SHOW$3 = `show${EVENT_KEY$3}`;
3195
  const EVENT_SHOWN$3 = `shown${EVENT_KEY$3}`;
3196
  const EVENT_HIDE$3 = `hide${EVENT_KEY$3}`;
3197
  const EVENT_HIDE_PREVENTED = `hidePrevented${EVENT_KEY$3}`;
3198
  const EVENT_HIDDEN$3 = `hidden${EVENT_KEY$3}`;
3199
  const EVENT_RESIZE = `resize${EVENT_KEY$3}`;
3200
  const EVENT_CLICK_DATA_API$1 = `click${EVENT_KEY$3}${DATA_API_KEY$1}`;
3201
  const EVENT_KEYDOWN_DISMISS = `keydown.dismiss${EVENT_KEY$3}`;
3202
  const SELECTOR_DATA_TOGGLE$1 = '[data-bs-toggle="offcanvas"]';
3203
  const Default$5 = {
3204
    backdrop: true,
3205
    keyboard: true,
3206
    scroll: false
3207
  };
3208
  const DefaultType$5 = {
3209
    backdrop: '(boolean|string)',
3210
    keyboard: 'boolean',
3211
    scroll: 'boolean'
3212
  };
3213
  /**
3214
   * Class definition
3215
   */
3216
3217
  class Offcanvas extends BaseComponent {
3218
    constructor(element, config) {
3219
      super(element, config);
3220
      this._isShown = false;
3221
      this._backdrop = this._initializeBackDrop();
3222
      this._focustrap = this._initializeFocusTrap();
3223
3224
      this._addEventListeners();
3225
    } // Getters
3226
3227
3228
    static get Default() {
3229
      return Default$5;
3230
    }
3231
3232
    static get DefaultType() {
3233
      return DefaultType$5;
3234
    }
3235
3236
    static get NAME() {
3237
      return NAME$6;
3238
    } // Public
3239
3240
3241
    toggle(relatedTarget) {
3242
      return this._isShown ? this.hide() : this.show(relatedTarget);
3243
    }
3244
3245
    show(relatedTarget) {
3246
      if (this._isShown) {
3247
        return;
3248
      }
3249 950e6b84 taeseongkim
3250 65674874 taeseongkim
      const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$3, {
3251
        relatedTarget
3252
      });
3253 950e6b84 taeseongkim
3254 65674874 taeseongkim
      if (showEvent.defaultPrevented) {
3255
        return;
3256
      }
3257
3258
      this._isShown = true;
3259
3260
      this._backdrop.show();
3261
3262
      if (!this._config.scroll) {
3263
        new ScrollBarHelper().hide();
3264
      }
3265
3266
      this._element.setAttribute('aria-modal', true);
3267 950e6b84 taeseongkim
3268 65674874 taeseongkim
      this._element.setAttribute('role', 'dialog');
3269 950e6b84 taeseongkim
3270 65674874 taeseongkim
      this._element.classList.add(CLASS_NAME_SHOWING$1);
3271
3272
      const completeCallBack = () => {
3273
        if (!this._config.scroll || this._config.backdrop) {
3274
          this._focustrap.activate();
3275 950e6b84 taeseongkim
        }
3276
3277 65674874 taeseongkim
        this._element.classList.add(CLASS_NAME_SHOW$3);
3278
3279
        this._element.classList.remove(CLASS_NAME_SHOWING$1);
3280 950e6b84 taeseongkim
3281 65674874 taeseongkim
        EventHandler.trigger(this._element, EVENT_SHOWN$3, {
3282
          relatedTarget
3283
        });
3284
      };
3285 950e6b84 taeseongkim
3286 65674874 taeseongkim
      this._queueCallback(completeCallBack, this._element, true);
3287
    }
3288 950e6b84 taeseongkim
3289 65674874 taeseongkim
    hide() {
3290
      if (!this._isShown) {
3291
        return;
3292
      }
3293 950e6b84 taeseongkim
3294 65674874 taeseongkim
      const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$3);
3295 950e6b84 taeseongkim
3296 65674874 taeseongkim
      if (hideEvent.defaultPrevented) {
3297
        return;
3298 950e6b84 taeseongkim
      }
3299
3300 65674874 taeseongkim
      this._focustrap.deactivate();
3301
3302
      this._element.blur();
3303
3304
      this._isShown = false;
3305
3306
      this._element.classList.add(CLASS_NAME_HIDING);
3307
3308
      this._backdrop.hide();
3309
3310
      const completeCallback = () => {
3311
        this._element.classList.remove(CLASS_NAME_SHOW$3, CLASS_NAME_HIDING);
3312
3313
        this._element.removeAttribute('aria-modal');
3314
3315
        this._element.removeAttribute('role');
3316
3317
        if (!this._config.scroll) {
3318
          new ScrollBarHelper().reset();
3319
        }
3320
3321
        EventHandler.trigger(this._element, EVENT_HIDDEN$3);
3322
      };
3323
3324
      this._queueCallback(completeCallback, this._element, true);
3325 950e6b84 taeseongkim
    }
3326
3327 65674874 taeseongkim
    dispose() {
3328
      this._backdrop.dispose();
3329 950e6b84 taeseongkim
3330 65674874 taeseongkim
      this._focustrap.deactivate();
3331 950e6b84 taeseongkim
3332 65674874 taeseongkim
      super.dispose();
3333
    } // Private
3334 950e6b84 taeseongkim
3335
3336 65674874 taeseongkim
    _initializeBackDrop() {
3337
      const clickCallback = () => {
3338
        if (this._config.backdrop === 'static') {
3339
          EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED);
3340
          return;
3341
        }
3342
3343
        this.hide();
3344
      }; // 'static' option will be translated to true, and booleans will keep their value
3345
3346 950e6b84 taeseongkim
3347 65674874 taeseongkim
      const isVisible = Boolean(this._config.backdrop);
3348
      return new Backdrop({
3349
        className: CLASS_NAME_BACKDROP,
3350
        isVisible,
3351
        isAnimated: true,
3352
        rootElement: this._element.parentNode,
3353
        clickCallback: isVisible ? clickCallback : null
3354
      });
3355 950e6b84 taeseongkim
    }
3356
3357 65674874 taeseongkim
    _initializeFocusTrap() {
3358
      return new FocusTrap({
3359
        trapElement: this._element
3360
      });
3361 950e6b84 taeseongkim
    }
3362
3363 65674874 taeseongkim
    _addEventListeners() {
3364
      EventHandler.on(this._element, EVENT_KEYDOWN_DISMISS, event => {
3365
        if (event.key !== ESCAPE_KEY) {
3366
          return;
3367
        }
3368
3369
        if (!this._config.keyboard) {
3370
          EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED);
3371
          return;
3372
        }
3373
3374
        this.hide();
3375
      });
3376
    } // Static
3377 950e6b84 taeseongkim
3378
3379 65674874 taeseongkim
    static jQueryInterface(config) {
3380
      return this.each(function () {
3381
        const data = Offcanvas.getOrCreateInstance(this, config);
3382 950e6b84 taeseongkim
3383 65674874 taeseongkim
        if (typeof config !== 'string') {
3384
          return;
3385
        }
3386
3387
        if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {
3388
          throw new TypeError(`No method named "${config}"`);
3389
        }
3390 950e6b84 taeseongkim
3391 65674874 taeseongkim
        data[config](this);
3392
      });
3393
    }
3394 950e6b84 taeseongkim
3395
  }
3396 65674874 taeseongkim
  /**
3397
   * Data API implementation
3398
   */
3399 950e6b84 taeseongkim
3400
3401 65674874 taeseongkim
  EventHandler.on(document, EVENT_CLICK_DATA_API$1, SELECTOR_DATA_TOGGLE$1, function (event) {
3402
    const target = getElementFromSelector(this);
3403 950e6b84 taeseongkim
3404 65674874 taeseongkim
    if (['A', 'AREA'].includes(this.tagName)) {
3405
      event.preventDefault();
3406
    }
3407 950e6b84 taeseongkim
3408 65674874 taeseongkim
    if (isDisabled(this)) {
3409
      return;
3410
    }
3411 950e6b84 taeseongkim
3412 65674874 taeseongkim
    EventHandler.one(target, EVENT_HIDDEN$3, () => {
3413
      // focus on trigger when it is closed
3414
      if (isVisible(this)) {
3415
        this.focus();
3416
      }
3417
    }); // avoid conflict when clicking a toggler of an offcanvas, while another is open
3418 950e6b84 taeseongkim
3419 65674874 taeseongkim
    const alreadyOpen = SelectorEngine.findOne(OPEN_SELECTOR);
3420 950e6b84 taeseongkim
3421 65674874 taeseongkim
    if (alreadyOpen && alreadyOpen !== target) {
3422
      Offcanvas.getInstance(alreadyOpen).hide();
3423
    }
3424 950e6b84 taeseongkim
3425 65674874 taeseongkim
    const data = Offcanvas.getOrCreateInstance(target);
3426
    data.toggle(this);
3427
  });
3428
  EventHandler.on(window, EVENT_LOAD_DATA_API$2, () => {
3429
    for (const selector of SelectorEngine.find(OPEN_SELECTOR)) {
3430
      Offcanvas.getOrCreateInstance(selector).show();
3431
    }
3432
  });
3433
  EventHandler.on(window, EVENT_RESIZE, () => {
3434
    for (const element of SelectorEngine.find('[aria-modal][class*=show][class*=offcanvas-]')) {
3435
      if (getComputedStyle(element).position !== 'fixed') {
3436
        Offcanvas.getOrCreateInstance(element).hide();
3437
      }
3438
    }
3439
  });
3440
  enableDismissTrigger(Offcanvas);
3441
  /**
3442
   * jQuery
3443
   */
3444 950e6b84 taeseongkim
3445 65674874 taeseongkim
  defineJQueryPlugin(Offcanvas);
3446 950e6b84 taeseongkim
3447 65674874 taeseongkim
  /**
3448
   * --------------------------------------------------------------------------
3449
   * Bootstrap (v5.2.3): util/sanitizer.js
3450
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
3451
   * --------------------------------------------------------------------------
3452
   */
3453
  const uriAttributes = new Set(['background', 'cite', 'href', 'itemtype', 'longdesc', 'poster', 'src', 'xlink:href']);
3454
  const ARIA_ATTRIBUTE_PATTERN = /^aria-[\w-]*$/i;
3455
  /**
3456
   * A pattern that recognizes a commonly useful subset of URLs that are safe.
3457
   *
3458
   * Shout-out to Angular https://github.com/angular/angular/blob/12.2.x/packages/core/src/sanitization/url_sanitizer.ts
3459
   */
3460 950e6b84 taeseongkim
3461 65674874 taeseongkim
  const SAFE_URL_PATTERN = /^(?:(?:https?|mailto|ftp|tel|file|sms):|[^#&/:?]*(?:[#/?]|$))/i;
3462
  /**
3463
   * A pattern that matches safe data URLs. Only matches image, video and audio types.
3464
   *
3465
   * Shout-out to Angular https://github.com/angular/angular/blob/12.2.x/packages/core/src/sanitization/url_sanitizer.ts
3466
   */
3467 950e6b84 taeseongkim
3468 65674874 taeseongkim
  const DATA_URL_PATTERN = /^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[\d+/a-z]+=*$/i;
3469 950e6b84 taeseongkim
3470 65674874 taeseongkim
  const allowedAttribute = (attribute, allowedAttributeList) => {
3471
    const attributeName = attribute.nodeName.toLowerCase();
3472 950e6b84 taeseongkim
3473 65674874 taeseongkim
    if (allowedAttributeList.includes(attributeName)) {
3474
      if (uriAttributes.has(attributeName)) {
3475
        return Boolean(SAFE_URL_PATTERN.test(attribute.nodeValue) || DATA_URL_PATTERN.test(attribute.nodeValue));
3476
      }
3477 950e6b84 taeseongkim
3478 65674874 taeseongkim
      return true;
3479
    } // Check if a regular expression validates the attribute.
3480 950e6b84 taeseongkim
3481
3482 65674874 taeseongkim
    return allowedAttributeList.filter(attributeRegex => attributeRegex instanceof RegExp).some(regex => regex.test(attributeName));
3483
  };
3484 950e6b84 taeseongkim
3485 65674874 taeseongkim
  const DefaultAllowlist = {
3486 950e6b84 taeseongkim
    // Global attributes allowed on any supplied element below.
3487
    '*': ['class', 'dir', 'id', 'lang', 'role', ARIA_ATTRIBUTE_PATTERN],
3488
    a: ['target', 'href', 'title', 'rel'],
3489
    area: [],
3490
    b: [],
3491
    br: [],
3492
    col: [],
3493
    code: [],
3494
    div: [],
3495
    em: [],
3496
    hr: [],
3497
    h1: [],
3498
    h2: [],
3499
    h3: [],
3500
    h4: [],
3501
    h5: [],
3502
    h6: [],
3503
    i: [],
3504 65674874 taeseongkim
    img: ['src', 'srcset', 'alt', 'title', 'width', 'height'],
3505 950e6b84 taeseongkim
    li: [],
3506
    ol: [],
3507
    p: [],
3508
    pre: [],
3509
    s: [],
3510
    small: [],
3511
    span: [],
3512
    sub: [],
3513
    sup: [],
3514
    strong: [],
3515
    u: [],
3516
    ul: []
3517 65674874 taeseongkim
  };
3518
  function sanitizeHtml(unsafeHtml, allowList, sanitizeFunction) {
3519
    if (!unsafeHtml.length) {
3520
      return unsafeHtml;
3521
    }
3522
3523
    if (sanitizeFunction && typeof sanitizeFunction === 'function') {
3524
      return sanitizeFunction(unsafeHtml);
3525
    }
3526
3527
    const domParser = new window.DOMParser();
3528
    const createdDocument = domParser.parseFromString(unsafeHtml, 'text/html');
3529
    const elements = [].concat(...createdDocument.body.querySelectorAll('*'));
3530
3531
    for (const element of elements) {
3532
      const elementName = element.nodeName.toLowerCase();
3533
3534
      if (!Object.keys(allowList).includes(elementName)) {
3535
        element.remove();
3536
        continue;
3537
      }
3538
3539
      const attributeList = [].concat(...element.attributes);
3540
      const allowedAttributes = [].concat(allowList['*'] || [], allowList[elementName] || []);
3541
3542
      for (const attribute of attributeList) {
3543
        if (!allowedAttribute(attribute, allowedAttributes)) {
3544
          element.removeAttribute(attribute.nodeName);
3545
        }
3546
      }
3547
    }
3548
3549
    return createdDocument.body.innerHTML;
3550 950e6b84 taeseongkim
  }
3551
3552
  /**
3553 65674874 taeseongkim
   * --------------------------------------------------------------------------
3554
   * Bootstrap (v5.2.3): util/template-factory.js
3555
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
3556
   * --------------------------------------------------------------------------
3557
   */
3558
  /**
3559
   * Constants
3560 950e6b84 taeseongkim
   */
3561
3562 65674874 taeseongkim
  const NAME$5 = 'TemplateFactory';
3563
  const Default$4 = {
3564
    allowList: DefaultAllowlist,
3565
    content: {},
3566
    // { selector : text ,  selector2 : text2 , }
3567
    extraClass: '',
3568
    html: false,
3569
    sanitize: true,
3570
    sanitizeFn: null,
3571
    template: '<div></div>'
3572
  };
3573
  const DefaultType$4 = {
3574
    allowList: 'object',
3575
    content: 'object',
3576
    extraClass: '(string|function)',
3577
    html: 'boolean',
3578
    sanitize: 'boolean',
3579
    sanitizeFn: '(null|function)',
3580
    template: 'string'
3581
  };
3582
  const DefaultContentType = {
3583
    entry: '(string|element|function|null)',
3584
    selector: '(string|element)'
3585
  };
3586 950e6b84 taeseongkim
  /**
3587 65674874 taeseongkim
   * Class definition
3588 950e6b84 taeseongkim
   */
3589
3590 65674874 taeseongkim
  class TemplateFactory extends Config {
3591
    constructor(config) {
3592
      super();
3593
      this._config = this._getConfig(config);
3594
    } // Getters
3595
3596
3597
    static get Default() {
3598
      return Default$4;
3599
    }
3600
3601
    static get DefaultType() {
3602
      return DefaultType$4;
3603
    }
3604
3605
    static get NAME() {
3606
      return NAME$5;
3607
    } // Public
3608
3609
3610
    getContent() {
3611
      return Object.values(this._config.content).map(config => this._resolvePossibleFunction(config)).filter(Boolean);
3612
    }
3613
3614
    hasContent() {
3615
      return this.getContent().length > 0;
3616
    }
3617
3618
    changeContent(content) {
3619
      this._checkContent(content);
3620
3621
      this._config.content = { ...this._config.content,
3622
        ...content
3623
      };
3624
      return this;
3625
    }
3626
3627
    toHtml() {
3628
      const templateWrapper = document.createElement('div');
3629
      templateWrapper.innerHTML = this._maybeSanitize(this._config.template);
3630
3631
      for (const [selector, text] of Object.entries(this._config.content)) {
3632
        this._setContent(templateWrapper, text, selector);
3633
      }
3634
3635
      const template = templateWrapper.children[0];
3636
3637
      const extraClass = this._resolvePossibleFunction(this._config.extraClass);
3638
3639
      if (extraClass) {
3640
        template.classList.add(...extraClass.split(' '));
3641
      }
3642
3643
      return template;
3644
    } // Private
3645
3646
3647
    _typeCheckConfig(config) {
3648
      super._typeCheckConfig(config);
3649
3650
      this._checkContent(config.content);
3651
    }
3652
3653
    _checkContent(arg) {
3654
      for (const [selector, content] of Object.entries(arg)) {
3655
        super._typeCheckConfig({
3656
          selector,
3657
          entry: content
3658
        }, DefaultContentType);
3659
      }
3660
    }
3661 950e6b84 taeseongkim
3662 65674874 taeseongkim
    _setContent(template, content, selector) {
3663
      const templateElement = SelectorEngine.findOne(selector, template);
3664
3665
      if (!templateElement) {
3666
        return;
3667
      }
3668
3669
      content = this._resolvePossibleFunction(content);
3670
3671
      if (!content) {
3672
        templateElement.remove();
3673
        return;
3674
      }
3675
3676
      if (isElement(content)) {
3677
        this._putElementInTemplate(getElement(content), templateElement);
3678
3679
        return;
3680
      }
3681
3682
      if (this._config.html) {
3683
        templateElement.innerHTML = this._maybeSanitize(content);
3684
        return;
3685 950e6b84 taeseongkim
      }
3686
3687 65674874 taeseongkim
      templateElement.textContent = content;
3688
    }
3689
3690
    _maybeSanitize(arg) {
3691
      return this._config.sanitize ? sanitizeHtml(arg, this._config.allowList, this._config.sanitizeFn) : arg;
3692 950e6b84 taeseongkim
    }
3693
3694 65674874 taeseongkim
    _resolvePossibleFunction(arg) {
3695
      return typeof arg === 'function' ? arg(this) : arg;
3696
    }
3697 950e6b84 taeseongkim
3698 65674874 taeseongkim
    _putElementInTemplate(element, templateElement) {
3699
      if (this._config.html) {
3700
        templateElement.innerHTML = '';
3701
        templateElement.append(element);
3702
        return;
3703 950e6b84 taeseongkim
      }
3704 65674874 taeseongkim
3705
      templateElement.textContent = element.textContent;
3706 950e6b84 taeseongkim
    }
3707
3708
  }
3709
3710 65674874 taeseongkim
  /**
3711
   * --------------------------------------------------------------------------
3712
   * Bootstrap (v5.2.3): tooltip.js
3713
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
3714
   * --------------------------------------------------------------------------
3715
   */
3716
  /**
3717
   * Constants
3718
   */
3719
3720
  const NAME$4 = 'tooltip';
3721
  const DISALLOWED_ATTRIBUTES = new Set(['sanitize', 'allowList', 'sanitizeFn']);
3722
  const CLASS_NAME_FADE$2 = 'fade';
3723
  const CLASS_NAME_MODAL = 'modal';
3724
  const CLASS_NAME_SHOW$2 = 'show';
3725
  const SELECTOR_TOOLTIP_INNER = '.tooltip-inner';
3726
  const SELECTOR_MODAL = `.${CLASS_NAME_MODAL}`;
3727
  const EVENT_MODAL_HIDE = 'hide.bs.modal';
3728
  const TRIGGER_HOVER = 'hover';
3729
  const TRIGGER_FOCUS = 'focus';
3730
  const TRIGGER_CLICK = 'click';
3731
  const TRIGGER_MANUAL = 'manual';
3732
  const EVENT_HIDE$2 = 'hide';
3733
  const EVENT_HIDDEN$2 = 'hidden';
3734
  const EVENT_SHOW$2 = 'show';
3735
  const EVENT_SHOWN$2 = 'shown';
3736
  const EVENT_INSERTED = 'inserted';
3737
  const EVENT_CLICK$1 = 'click';
3738
  const EVENT_FOCUSIN$1 = 'focusin';
3739
  const EVENT_FOCUSOUT$1 = 'focusout';
3740
  const EVENT_MOUSEENTER = 'mouseenter';
3741
  const EVENT_MOUSELEAVE = 'mouseleave';
3742
  const AttachmentMap = {
3743
    AUTO: 'auto',
3744
    TOP: 'top',
3745
    RIGHT: isRTL() ? 'left' : 'right',
3746
    BOTTOM: 'bottom',
3747
    LEFT: isRTL() ? 'right' : 'left'
3748
  };
3749
  const Default$3 = {
3750
    allowList: DefaultAllowlist,
3751
    animation: true,
3752
    boundary: 'clippingParents',
3753
    container: false,
3754
    customClass: '',
3755
    delay: 0,
3756
    fallbackPlacements: ['top', 'right', 'bottom', 'left'],
3757
    html: false,
3758
    offset: [0, 0],
3759
    placement: 'top',
3760
    popperConfig: null,
3761
    sanitize: true,
3762
    sanitizeFn: null,
3763
    selector: false,
3764
    template: '<div class="tooltip" role="tooltip">' + '<div class="tooltip-arrow"></div>' + '<div class="tooltip-inner"></div>' + '</div>',
3765
    title: '',
3766
    trigger: 'hover focus'
3767
  };
3768
  const DefaultType$3 = {
3769
    allowList: 'object',
3770
    animation: 'boolean',
3771
    boundary: '(string|element)',
3772
    container: '(string|element|boolean)',
3773
    customClass: '(string|function)',
3774
    delay: '(number|object)',
3775
    fallbackPlacements: 'array',
3776
    html: 'boolean',
3777
    offset: '(array|string|function)',
3778
    placement: '(string|function)',
3779
    popperConfig: '(null|object|function)',
3780
    sanitize: 'boolean',
3781
    sanitizeFn: '(null|function)',
3782
    selector: '(string|boolean)',
3783
    template: 'string',
3784
    title: '(string|element|function)',
3785
    trigger: 'string'
3786
  };
3787
  /**
3788
   * Class definition
3789
   */
3790
3791
  class Tooltip extends BaseComponent {
3792
    constructor(element, config) {
3793
      if (typeof Popper__namespace === 'undefined') {
3794
        throw new TypeError('Bootstrap\'s tooltips require Popper (https://popper.js.org)');
3795
      }
3796
3797
      super(element, config); // Private
3798
3799
      this._isEnabled = true;
3800
      this._timeout = 0;
3801
      this._isHovered = null;
3802
      this._activeTrigger = {};
3803
      this._popper = null;
3804
      this._templateFactory = null;
3805
      this._newContent = null; // Protected
3806
3807
      this.tip = null;
3808
3809
      this._setListeners();
3810
3811
      if (!this._config.selector) {
3812
        this._fixTitle();
3813
      }
3814
    } // Getters
3815
3816
3817
    static get Default() {
3818
      return Default$3;
3819
    }
3820
3821
    static get DefaultType() {
3822
      return DefaultType$3;
3823
    }
3824
3825
    static get NAME() {
3826
      return NAME$4;
3827
    } // Public
3828
3829
3830
    enable() {
3831
      this._isEnabled = true;
3832
    }
3833
3834
    disable() {
3835
      this._isEnabled = false;
3836
    }
3837
3838
    toggleEnabled() {
3839
      this._isEnabled = !this._isEnabled;
3840 950e6b84 taeseongkim
    }
3841
3842 65674874 taeseongkim
    toggle() {
3843
      if (!this._isEnabled) {
3844
        return;
3845
      }
3846
3847
      this._activeTrigger.click = !this._activeTrigger.click;
3848
3849
      if (this._isShown()) {
3850
        this._leave();
3851
3852
        return;
3853
      }
3854
3855
      this._enter();
3856 950e6b84 taeseongkim
    }
3857
3858 65674874 taeseongkim
    dispose() {
3859
      clearTimeout(this._timeout);
3860
      EventHandler.off(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler);
3861
3862
      if (this._element.getAttribute('data-bs-original-title')) {
3863
        this._element.setAttribute('title', this._element.getAttribute('data-bs-original-title'));
3864
      }
3865
3866
      this._disposePopper();
3867
3868
      super.dispose();
3869 950e6b84 taeseongkim
    }
3870
3871 65674874 taeseongkim
    show() {
3872
      if (this._element.style.display === 'none') {
3873
        throw new Error('Please use show on visible elements');
3874
      }
3875
3876
      if (!(this._isWithContent() && this._isEnabled)) {
3877
        return;
3878
      }
3879
3880
      const showEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOW$2));
3881
      const shadowRoot = findShadowRoot(this._element);
3882
3883
      const isInTheDom = (shadowRoot || this._element.ownerDocument.documentElement).contains(this._element);
3884
3885
      if (showEvent.defaultPrevented || !isInTheDom) {
3886
        return;
3887
      } // todo v6 remove this OR make it optional
3888
3889 950e6b84 taeseongkim
3890 65674874 taeseongkim
      this._disposePopper();
3891 950e6b84 taeseongkim
3892 65674874 taeseongkim
      const tip = this._getTipElement();
3893 950e6b84 taeseongkim
3894 65674874 taeseongkim
      this._element.setAttribute('aria-describedby', tip.getAttribute('id'));
3895 950e6b84 taeseongkim
3896 65674874 taeseongkim
      const {
3897
        container
3898
      } = this._config;
3899
3900
      if (!this._element.ownerDocument.documentElement.contains(this.tip)) {
3901
        container.append(tip);
3902
        EventHandler.trigger(this._element, this.constructor.eventName(EVENT_INSERTED));
3903 950e6b84 taeseongkim
      }
3904
3905 65674874 taeseongkim
      this._popper = this._createPopper(tip);
3906
      tip.classList.add(CLASS_NAME_SHOW$2); // If this is a touch-enabled device we add extra
3907
      // empty mouseover listeners to the body's immediate children;
3908
      // only needed because of broken event delegation on iOS
3909
      // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html
3910 950e6b84 taeseongkim
3911 65674874 taeseongkim
      if ('ontouchstart' in document.documentElement) {
3912
        for (const element of [].concat(...document.body.children)) {
3913
          EventHandler.on(element, 'mouseover', noop);
3914 950e6b84 taeseongkim
        }
3915
      }
3916 65674874 taeseongkim
3917
      const complete = () => {
3918
        EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOWN$2));
3919
3920
        if (this._isHovered === false) {
3921
          this._leave();
3922
        }
3923
3924
        this._isHovered = false;
3925
      };
3926
3927
      this._queueCallback(complete, this.tip, this._isAnimated());
3928 950e6b84 taeseongkim
    }
3929
3930 65674874 taeseongkim
    hide() {
3931
      if (!this._isShown()) {
3932
        return;
3933
      }
3934 950e6b84 taeseongkim
3935 65674874 taeseongkim
      const hideEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDE$2));
3936 950e6b84 taeseongkim
3937 65674874 taeseongkim
      if (hideEvent.defaultPrevented) {
3938
        return;
3939
      }
3940 950e6b84 taeseongkim
3941 65674874 taeseongkim
      const tip = this._getTipElement();
3942 950e6b84 taeseongkim
3943 65674874 taeseongkim
      tip.classList.remove(CLASS_NAME_SHOW$2); // If this is a touch-enabled device we remove the extra
3944
      // empty mouseover listeners we added for iOS support
3945 950e6b84 taeseongkim
3946 65674874 taeseongkim
      if ('ontouchstart' in document.documentElement) {
3947
        for (const element of [].concat(...document.body.children)) {
3948
          EventHandler.off(element, 'mouseover', noop);
3949
        }
3950
      }
3951 950e6b84 taeseongkim
3952 65674874 taeseongkim
      this._activeTrigger[TRIGGER_CLICK] = false;
3953
      this._activeTrigger[TRIGGER_FOCUS] = false;
3954
      this._activeTrigger[TRIGGER_HOVER] = false;
3955
      this._isHovered = null; // it is a trick to support manual triggering
3956
3957
      const complete = () => {
3958
        if (this._isWithActiveTrigger()) {
3959
          return;
3960
        }
3961
3962
        if (!this._isHovered) {
3963
          this._disposePopper();
3964
        }
3965
3966
        this._element.removeAttribute('aria-describedby');
3967 950e6b84 taeseongkim
3968 65674874 taeseongkim
        EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDDEN$2));
3969
      };
3970 950e6b84 taeseongkim
3971 65674874 taeseongkim
      this._queueCallback(complete, this.tip, this._isAnimated());
3972 950e6b84 taeseongkim
    }
3973
3974 65674874 taeseongkim
    update() {
3975
      if (this._popper) {
3976
        this._popper.update();
3977
      }
3978
    } // Protected
3979 950e6b84 taeseongkim
3980
3981 65674874 taeseongkim
    _isWithContent() {
3982
      return Boolean(this._getTitle());
3983
    }
3984 950e6b84 taeseongkim
3985 65674874 taeseongkim
    _getTipElement() {
3986
      if (!this.tip) {
3987
        this.tip = this._createTipElement(this._newContent || this._getContentForTemplate());
3988 950e6b84 taeseongkim
      }
3989 65674874 taeseongkim
3990
      return this.tip;
3991 950e6b84 taeseongkim
    }
3992
3993 65674874 taeseongkim
    _createTipElement(content) {
3994
      const tip = this._getTemplateFactory(content).toHtml(); // todo: remove this check on v6
3995 950e6b84 taeseongkim
3996
3997 65674874 taeseongkim
      if (!tip) {
3998
        return null;
3999
      }
4000
4001
      tip.classList.remove(CLASS_NAME_FADE$2, CLASS_NAME_SHOW$2); // todo: on v6 the following can be achieved with CSS only
4002
4003
      tip.classList.add(`bs-${this.constructor.NAME}-auto`);
4004
      const tipId = getUID(this.constructor.NAME).toString();
4005
      tip.setAttribute('id', tipId);
4006
4007
      if (this._isAnimated()) {
4008
        tip.classList.add(CLASS_NAME_FADE$2);
4009
      }
4010
4011
      return tip;
4012
    }
4013
4014
    setContent(content) {
4015
      this._newContent = content;
4016
4017
      if (this._isShown()) {
4018
        this._disposePopper();
4019
4020
        this.show();
4021
      }
4022
    }
4023
4024
    _getTemplateFactory(content) {
4025
      if (this._templateFactory) {
4026
        this._templateFactory.changeContent(content);
4027
      } else {
4028
        this._templateFactory = new TemplateFactory({ ...this._config,
4029
          // the `content` var has to be after `this._config`
4030
          // to override config.content in case of popover
4031
          content,
4032
          extraClass: this._resolvePossibleFunction(this._config.customClass)
4033
        });
4034
      }
4035
4036
      return this._templateFactory;
4037
    }
4038 950e6b84 taeseongkim
4039 65674874 taeseongkim
    _getContentForTemplate() {
4040
      return {
4041
        [SELECTOR_TOOLTIP_INNER]: this._getTitle()
4042
      };
4043 950e6b84 taeseongkim
    }
4044
4045 65674874 taeseongkim
    _getTitle() {
4046
      return this._resolvePossibleFunction(this._config.title) || this._element.getAttribute('data-bs-original-title');
4047
    } // Private
4048 950e6b84 taeseongkim
4049 65674874 taeseongkim
4050
    _initializeOnDelegatedTarget(event) {
4051
      return this.constructor.getOrCreateInstance(event.delegateTarget, this._getDelegateConfig());
4052 950e6b84 taeseongkim
    }
4053
4054 65674874 taeseongkim
    _isAnimated() {
4055
      return this._config.animation || this.tip && this.tip.classList.contains(CLASS_NAME_FADE$2);
4056 950e6b84 taeseongkim
    }
4057
4058 65674874 taeseongkim
    _isShown() {
4059
      return this.tip && this.tip.classList.contains(CLASS_NAME_SHOW$2);
4060
    }
4061 950e6b84 taeseongkim
4062 65674874 taeseongkim
    _createPopper(tip) {
4063
      const placement = typeof this._config.placement === 'function' ? this._config.placement.call(this, tip, this._element) : this._config.placement;
4064
      const attachment = AttachmentMap[placement.toUpperCase()];
4065
      return Popper__namespace.createPopper(this._element, tip, this._getPopperConfig(attachment));
4066
    }
4067 950e6b84 taeseongkim
4068 65674874 taeseongkim
    _getOffset() {
4069
      const {
4070
        offset
4071
      } = this._config;
4072 950e6b84 taeseongkim
4073 65674874 taeseongkim
      if (typeof offset === 'string') {
4074
        return offset.split(',').map(value => Number.parseInt(value, 10));
4075
      }
4076 950e6b84 taeseongkim
4077 65674874 taeseongkim
      if (typeof offset === 'function') {
4078
        return popperData => offset(popperData, this._element);
4079
      }
4080 950e6b84 taeseongkim
4081 65674874 taeseongkim
      return offset;
4082 950e6b84 taeseongkim
    }
4083
4084 65674874 taeseongkim
    _resolvePossibleFunction(arg) {
4085
      return typeof arg === 'function' ? arg.call(this._element) : arg;
4086 950e6b84 taeseongkim
    }
4087
4088 65674874 taeseongkim
    _getPopperConfig(attachment) {
4089
      const defaultBsPopperConfig = {
4090
        placement: attachment,
4091
        modifiers: [{
4092
          name: 'flip',
4093
          options: {
4094
            fallbackPlacements: this._config.fallbackPlacements
4095
          }
4096
        }, {
4097
          name: 'offset',
4098
          options: {
4099
            offset: this._getOffset()
4100
          }
4101
        }, {
4102
          name: 'preventOverflow',
4103
          options: {
4104
            boundary: this._config.boundary
4105
          }
4106
        }, {
4107
          name: 'arrow',
4108
          options: {
4109
            element: `.${this.constructor.NAME}-arrow`
4110
          }
4111
        }, {
4112
          name: 'preSetPlacement',
4113
          enabled: true,
4114
          phase: 'beforeMain',
4115
          fn: data => {
4116
            // Pre-set Popper's placement attribute in order to read the arrow sizes properly.
4117
            // Otherwise, Popper mixes up the width and height dimensions since the initial arrow style is for top placement
4118
            this._getTipElement().setAttribute('data-popper-placement', data.state.placement);
4119
          }
4120
        }]
4121
      };
4122
      return { ...defaultBsPopperConfig,
4123
        ...(typeof this._config.popperConfig === 'function' ? this._config.popperConfig(defaultBsPopperConfig) : this._config.popperConfig)
4124
      };
4125 950e6b84 taeseongkim
    }
4126
4127 65674874 taeseongkim
    _setListeners() {
4128
      const triggers = this._config.trigger.split(' ');
4129 950e6b84 taeseongkim
4130 65674874 taeseongkim
      for (const trigger of triggers) {
4131
        if (trigger === 'click') {
4132
          EventHandler.on(this._element, this.constructor.eventName(EVENT_CLICK$1), this._config.selector, event => {
4133
            const context = this._initializeOnDelegatedTarget(event);
4134 950e6b84 taeseongkim
4135 65674874 taeseongkim
            context.toggle();
4136
          });
4137
        } else if (trigger !== TRIGGER_MANUAL) {
4138
          const eventIn = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSEENTER) : this.constructor.eventName(EVENT_FOCUSIN$1);
4139
          const eventOut = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSELEAVE) : this.constructor.eventName(EVENT_FOCUSOUT$1);
4140
          EventHandler.on(this._element, eventIn, this._config.selector, event => {
4141
            const context = this._initializeOnDelegatedTarget(event);
4142 950e6b84 taeseongkim
4143 65674874 taeseongkim
            context._activeTrigger[event.type === 'focusin' ? TRIGGER_FOCUS : TRIGGER_HOVER] = true;
4144 950e6b84 taeseongkim
4145 65674874 taeseongkim
            context._enter();
4146
          });
4147
          EventHandler.on(this._element, eventOut, this._config.selector, event => {
4148
            const context = this._initializeOnDelegatedTarget(event);
4149 950e6b84 taeseongkim
4150 65674874 taeseongkim
            context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] = context._element.contains(event.relatedTarget);
4151 950e6b84 taeseongkim
4152 65674874 taeseongkim
            context._leave();
4153
          });
4154
        }
4155
      }
4156 950e6b84 taeseongkim
4157 65674874 taeseongkim
      this._hideModalHandler = () => {
4158
        if (this._element) {
4159
          this.hide();
4160
        }
4161
      };
4162 950e6b84 taeseongkim
4163 65674874 taeseongkim
      EventHandler.on(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler);
4164 950e6b84 taeseongkim
    }
4165
4166 65674874 taeseongkim
    _fixTitle() {
4167
      const title = this._element.getAttribute('title');
4168 950e6b84 taeseongkim
4169 65674874 taeseongkim
      if (!title) {
4170
        return;
4171
      }
4172 950e6b84 taeseongkim
4173 65674874 taeseongkim
      if (!this._element.getAttribute('aria-label') && !this._element.textContent.trim()) {
4174
        this._element.setAttribute('aria-label', title);
4175
      }
4176 950e6b84 taeseongkim
4177 65674874 taeseongkim
      this._element.setAttribute('data-bs-original-title', title); // DO NOT USE IT. Is only for backwards compatibility
4178 950e6b84 taeseongkim
4179
4180 65674874 taeseongkim
      this._element.removeAttribute('title');
4181
    }
4182 950e6b84 taeseongkim
4183 65674874 taeseongkim
    _enter() {
4184
      if (this._isShown() || this._isHovered) {
4185
        this._isHovered = true;
4186
        return;
4187
      }
4188 950e6b84 taeseongkim
4189 65674874 taeseongkim
      this._isHovered = true;
4190 950e6b84 taeseongkim
4191 65674874 taeseongkim
      this._setTimeout(() => {
4192
        if (this._isHovered) {
4193
          this.show();
4194
        }
4195
      }, this._config.delay.show);
4196
    }
4197 950e6b84 taeseongkim
4198 65674874 taeseongkim
    _leave() {
4199
      if (this._isWithActiveTrigger()) {
4200
        return;
4201
      }
4202 950e6b84 taeseongkim
4203 65674874 taeseongkim
      this._isHovered = false;
4204 950e6b84 taeseongkim
4205 65674874 taeseongkim
      this._setTimeout(() => {
4206
        if (!this._isHovered) {
4207
          this.hide();
4208
        }
4209
      }, this._config.delay.hide);
4210
    }
4211 950e6b84 taeseongkim
4212 65674874 taeseongkim
    _setTimeout(handler, timeout) {
4213
      clearTimeout(this._timeout);
4214
      this._timeout = setTimeout(handler, timeout);
4215
    }
4216 950e6b84 taeseongkim
4217 65674874 taeseongkim
    _isWithActiveTrigger() {
4218
      return Object.values(this._activeTrigger).includes(true);
4219
    }
4220 950e6b84 taeseongkim
4221 65674874 taeseongkim
    _getConfig(config) {
4222
      const dataAttributes = Manipulator.getDataAttributes(this._element);
4223 950e6b84 taeseongkim
4224 65674874 taeseongkim
      for (const dataAttribute of Object.keys(dataAttributes)) {
4225
        if (DISALLOWED_ATTRIBUTES.has(dataAttribute)) {
4226
          delete dataAttributes[dataAttribute];
4227
        }
4228
      }
4229 950e6b84 taeseongkim
4230 65674874 taeseongkim
      config = { ...dataAttributes,
4231
        ...(typeof config === 'object' && config ? config : {})
4232
      };
4233
      config = this._mergeConfigObj(config);
4234
      config = this._configAfterMerge(config);
4235 950e6b84 taeseongkim
4236 65674874 taeseongkim
      this._typeCheckConfig(config);
4237 950e6b84 taeseongkim
4238 65674874 taeseongkim
      return config;
4239
    }
4240 950e6b84 taeseongkim
4241 65674874 taeseongkim
    _configAfterMerge(config) {
4242
      config.container = config.container === false ? document.body : getElement(config.container);
4243 950e6b84 taeseongkim
4244 65674874 taeseongkim
      if (typeof config.delay === 'number') {
4245
        config.delay = {
4246
          show: config.delay,
4247
          hide: config.delay
4248
        };
4249
      }
4250 950e6b84 taeseongkim
4251 65674874 taeseongkim
      if (typeof config.title === 'number') {
4252
        config.title = config.title.toString();
4253
      }
4254 950e6b84 taeseongkim
4255 65674874 taeseongkim
      if (typeof config.content === 'number') {
4256
        config.content = config.content.toString();
4257 950e6b84 taeseongkim
      }
4258
4259 65674874 taeseongkim
      return config;
4260 950e6b84 taeseongkim
    }
4261
4262 65674874 taeseongkim
    _getDelegateConfig() {
4263
      const config = {};
4264 950e6b84 taeseongkim
4265 65674874 taeseongkim
      for (const key in this._config) {
4266
        if (this.constructor.Default[key] !== this._config[key]) {
4267
          config[key] = this._config[key];
4268
        }
4269
      }
4270 950e6b84 taeseongkim
4271 65674874 taeseongkim
      config.selector = false;
4272
      config.trigger = 'manual'; // In the future can be replaced with:
4273
      // const keysWithDifferentValues = Object.entries(this._config).filter(entry => this.constructor.Default[entry[0]] !== this._config[entry[0]])
4274
      // `Object.fromEntries(keysWithDifferentValues)`
4275
4276
      return config;
4277
    }
4278 950e6b84 taeseongkim
4279 65674874 taeseongkim
    _disposePopper() {
4280
      if (this._popper) {
4281
        this._popper.destroy();
4282 950e6b84 taeseongkim
4283 65674874 taeseongkim
        this._popper = null;
4284 950e6b84 taeseongkim
      }
4285
4286 65674874 taeseongkim
      if (this.tip) {
4287
        this.tip.remove();
4288
        this.tip = null;
4289
      }
4290
    } // Static
4291 950e6b84 taeseongkim
4292
4293 65674874 taeseongkim
    static jQueryInterface(config) {
4294
      return this.each(function () {
4295
        const data = Tooltip.getOrCreateInstance(this, config);
4296 950e6b84 taeseongkim
4297 65674874 taeseongkim
        if (typeof config !== 'string') {
4298
          return;
4299
        }
4300 950e6b84 taeseongkim
4301 65674874 taeseongkim
        if (typeof data[config] === 'undefined') {
4302
          throw new TypeError(`No method named "${config}"`);
4303
        }
4304 950e6b84 taeseongkim
4305 65674874 taeseongkim
        data[config]();
4306
      });
4307
    }
4308 950e6b84 taeseongkim
4309
  }
4310 65674874 taeseongkim
  /**
4311
   * jQuery
4312
   */
4313 950e6b84 taeseongkim
4314
4315 65674874 taeseongkim
  defineJQueryPlugin(Tooltip);
4316 950e6b84 taeseongkim
4317 65674874 taeseongkim
  /**
4318
   * --------------------------------------------------------------------------
4319
   * Bootstrap (v5.2.3): popover.js
4320
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
4321
   * --------------------------------------------------------------------------
4322
   */
4323
  /**
4324
   * Constants
4325
   */
4326 950e6b84 taeseongkim
4327 65674874 taeseongkim
  const NAME$3 = 'popover';
4328
  const SELECTOR_TITLE = '.popover-header';
4329
  const SELECTOR_CONTENT = '.popover-body';
4330
  const Default$2 = { ...Tooltip.Default,
4331
    content: '',
4332
    offset: [0, 8],
4333
    placement: 'right',
4334
    template: '<div class="popover" role="tooltip">' + '<div class="popover-arrow"></div>' + '<h3 class="popover-header"></h3>' + '<div class="popover-body"></div>' + '</div>',
4335
    trigger: 'click'
4336
  };
4337
  const DefaultType$2 = { ...Tooltip.DefaultType,
4338
    content: '(null|string|element|function)'
4339
  };
4340
  /**
4341
   * Class definition
4342
   */
4343
4344
  class Popover extends Tooltip {
4345
    // Getters
4346
    static get Default() {
4347
      return Default$2;
4348 950e6b84 taeseongkim
    }
4349
4350 65674874 taeseongkim
    static get DefaultType() {
4351
      return DefaultType$2;
4352
    }
4353 950e6b84 taeseongkim
4354 65674874 taeseongkim
    static get NAME() {
4355
      return NAME$3;
4356
    } // Overrides
4357 950e6b84 taeseongkim
4358
4359 65674874 taeseongkim
    _isWithContent() {
4360
      return this._getTitle() || this._getContent();
4361
    } // Private
4362
4363 950e6b84 taeseongkim
4364 65674874 taeseongkim
    _getContentForTemplate() {
4365
      return {
4366
        [SELECTOR_TITLE]: this._getTitle(),
4367
        [SELECTOR_CONTENT]: this._getContent()
4368
      };
4369
    }
4370 950e6b84 taeseongkim
4371 65674874 taeseongkim
    _getContent() {
4372
      return this._resolvePossibleFunction(this._config.content);
4373
    } // Static
4374 950e6b84 taeseongkim
4375
4376 65674874 taeseongkim
    static jQueryInterface(config) {
4377
      return this.each(function () {
4378
        const data = Popover.getOrCreateInstance(this, config);
4379 950e6b84 taeseongkim
4380 65674874 taeseongkim
        if (typeof config !== 'string') {
4381
          return;
4382
        }
4383
4384
        if (typeof data[config] === 'undefined') {
4385
          throw new TypeError(`No method named "${config}"`);
4386
        }
4387 950e6b84 taeseongkim
4388 65674874 taeseongkim
        data[config]();
4389
      });
4390 950e6b84 taeseongkim
    }
4391
4392
  }
4393 65674874 taeseongkim
  /**
4394
   * jQuery
4395
   */
4396 950e6b84 taeseongkim
4397
4398 65674874 taeseongkim
  defineJQueryPlugin(Popover);
4399
4400
  /**
4401
   * --------------------------------------------------------------------------
4402
   * Bootstrap (v5.2.3): scrollspy.js
4403
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
4404
   * --------------------------------------------------------------------------
4405
   */
4406
  /**
4407
   * Constants
4408
   */
4409
4410
  const NAME$2 = 'scrollspy';
4411
  const DATA_KEY$2 = 'bs.scrollspy';
4412
  const EVENT_KEY$2 = `.${DATA_KEY$2}`;
4413
  const DATA_API_KEY = '.data-api';
4414
  const EVENT_ACTIVATE = `activate${EVENT_KEY$2}`;
4415
  const EVENT_CLICK = `click${EVENT_KEY$2}`;
4416
  const EVENT_LOAD_DATA_API$1 = `load${EVENT_KEY$2}${DATA_API_KEY}`;
4417
  const CLASS_NAME_DROPDOWN_ITEM = 'dropdown-item';
4418
  const CLASS_NAME_ACTIVE$1 = 'active';
4419
  const SELECTOR_DATA_SPY = '[data-bs-spy="scroll"]';
4420
  const SELECTOR_TARGET_LINKS = '[href]';
4421
  const SELECTOR_NAV_LIST_GROUP = '.nav, .list-group';
4422
  const SELECTOR_NAV_LINKS = '.nav-link';
4423
  const SELECTOR_NAV_ITEMS = '.nav-item';
4424
  const SELECTOR_LIST_ITEMS = '.list-group-item';
4425
  const SELECTOR_LINK_ITEMS = `${SELECTOR_NAV_LINKS}, ${SELECTOR_NAV_ITEMS} > ${SELECTOR_NAV_LINKS}, ${SELECTOR_LIST_ITEMS}`;
4426
  const SELECTOR_DROPDOWN = '.dropdown';
4427
  const SELECTOR_DROPDOWN_TOGGLE$1 = '.dropdown-toggle';
4428
  const Default$1 = {
4429
    offset: null,
4430
    // TODO: v6 @deprecated, keep it for backwards compatibility reasons
4431
    rootMargin: '0px 0px -25%',
4432
    smoothScroll: false,
4433
    target: null,
4434
    threshold: [0.1, 0.5, 1]
4435
  };
4436
  const DefaultType$1 = {
4437
    offset: '(number|null)',
4438
    // TODO v6 @deprecated, keep it for backwards compatibility reasons
4439
    rootMargin: 'string',
4440
    smoothScroll: 'boolean',
4441
    target: 'element',
4442
    threshold: 'array'
4443
  };
4444
  /**
4445
   * Class definition
4446
   */
4447 950e6b84 taeseongkim
4448 65674874 taeseongkim
  class ScrollSpy extends BaseComponent {
4449
    constructor(element, config) {
4450
      super(element, config); // this._element is the observablesContainer and config.target the menu links wrapper
4451
4452
      this._targetLinks = new Map();
4453
      this._observableSections = new Map();
4454
      this._rootElement = getComputedStyle(this._element).overflowY === 'visible' ? null : this._element;
4455
      this._activeTarget = null;
4456
      this._observer = null;
4457
      this._previousScrollData = {
4458
        visibleEntryTop: 0,
4459
        parentScrollTop: 0
4460
      };
4461
      this.refresh(); // initialize
4462
    } // Getters
4463
4464
4465
    static get Default() {
4466
      return Default$1;
4467 950e6b84 taeseongkim
    }
4468
4469 65674874 taeseongkim
    static get DefaultType() {
4470
      return DefaultType$1;
4471
    }
4472 950e6b84 taeseongkim
4473 65674874 taeseongkim
    static get NAME() {
4474
      return NAME$2;
4475
    } // Public
4476 950e6b84 taeseongkim
4477
4478 65674874 taeseongkim
    refresh() {
4479
      this._initializeTargetsAndObservables();
4480 950e6b84 taeseongkim
4481 65674874 taeseongkim
      this._maybeEnableSmoothScroll();
4482 950e6b84 taeseongkim
4483 65674874 taeseongkim
      if (this._observer) {
4484
        this._observer.disconnect();
4485
      } else {
4486
        this._observer = this._getNewObserver();
4487 950e6b84 taeseongkim
      }
4488 65674874 taeseongkim
4489
      for (const section of this._observableSections.values()) {
4490
        this._observer.observe(section);
4491 950e6b84 taeseongkim
      }
4492
    }
4493
4494 65674874 taeseongkim
    dispose() {
4495
      this._observer.disconnect();
4496 950e6b84 taeseongkim
4497 65674874 taeseongkim
      super.dispose();
4498
    } // Private
4499 950e6b84 taeseongkim
4500
4501 65674874 taeseongkim
    _configAfterMerge(config) {
4502
      // TODO: on v6 target should be given explicitly & remove the {target: 'ss-target'} case
4503
      config.target = getElement(config.target) || document.body; // TODO: v6 Only for backwards compatibility reasons. Use rootMargin only
4504 950e6b84 taeseongkim
4505 65674874 taeseongkim
      config.rootMargin = config.offset ? `${config.offset}px 0px -30%` : config.rootMargin;
4506 950e6b84 taeseongkim
4507 65674874 taeseongkim
      if (typeof config.threshold === 'string') {
4508
        config.threshold = config.threshold.split(',').map(value => Number.parseFloat(value));
4509 950e6b84 taeseongkim
      }
4510 65674874 taeseongkim
4511
      return config;
4512 950e6b84 taeseongkim
    }
4513
4514 65674874 taeseongkim
    _maybeEnableSmoothScroll() {
4515
      if (!this._config.smoothScroll) {
4516
        return;
4517
      } // unregister any previous listeners
4518 950e6b84 taeseongkim
4519
4520 65674874 taeseongkim
      EventHandler.off(this._config.target, EVENT_CLICK);
4521
      EventHandler.on(this._config.target, EVENT_CLICK, SELECTOR_TARGET_LINKS, event => {
4522
        const observableSection = this._observableSections.get(event.target.hash);
4523 950e6b84 taeseongkim
4524 65674874 taeseongkim
        if (observableSection) {
4525
          event.preventDefault();
4526
          const root = this._rootElement || window;
4527
          const height = observableSection.offsetTop - this._element.offsetTop;
4528 950e6b84 taeseongkim
4529 65674874 taeseongkim
          if (root.scrollTo) {
4530
            root.scrollTo({
4531
              top: height,
4532
              behavior: 'smooth'
4533
            });
4534
            return;
4535
          } // Chrome 60 doesn't support `scrollTo`
4536 950e6b84 taeseongkim
4537
4538 65674874 taeseongkim
          root.scrollTop = height;
4539
        }
4540
      });
4541
    }
4542 950e6b84 taeseongkim
4543 65674874 taeseongkim
    _getNewObserver() {
4544
      const options = {
4545
        root: this._rootElement,
4546
        threshold: this._config.threshold,
4547
        rootMargin: this._config.rootMargin
4548
      };
4549
      return new IntersectionObserver(entries => this._observerCallback(entries), options);
4550
    } // The logic of selection
4551 950e6b84 taeseongkim
4552
4553 65674874 taeseongkim
    _observerCallback(entries) {
4554
      const targetElement = entry => this._targetLinks.get(`#${entry.target.id}`);
4555 950e6b84 taeseongkim
4556 65674874 taeseongkim
      const activate = entry => {
4557
        this._previousScrollData.visibleEntryTop = entry.target.offsetTop;
4558 950e6b84 taeseongkim
4559 65674874 taeseongkim
        this._process(targetElement(entry));
4560
      };
4561 950e6b84 taeseongkim
4562 65674874 taeseongkim
      const parentScrollTop = (this._rootElement || document.documentElement).scrollTop;
4563
      const userScrollsDown = parentScrollTop >= this._previousScrollData.parentScrollTop;
4564
      this._previousScrollData.parentScrollTop = parentScrollTop;
4565 950e6b84 taeseongkim
4566 65674874 taeseongkim
      for (const entry of entries) {
4567
        if (!entry.isIntersecting) {
4568
          this._activeTarget = null;
4569 950e6b84 taeseongkim
4570 65674874 taeseongkim
          this._clearActiveClass(targetElement(entry));
4571 950e6b84 taeseongkim
4572 65674874 taeseongkim
          continue;
4573
        }
4574 950e6b84 taeseongkim
4575 65674874 taeseongkim
        const entryIsLowerThanPrevious = entry.target.offsetTop >= this._previousScrollData.visibleEntryTop; // if we are scrolling down, pick the bigger offsetTop
4576 950e6b84 taeseongkim
4577 65674874 taeseongkim
        if (userScrollsDown && entryIsLowerThanPrevious) {
4578
          activate(entry); // if parent isn't scrolled, let's keep the first visible item, breaking the iteration
4579 950e6b84 taeseongkim
4580 65674874 taeseongkim
          if (!parentScrollTop) {
4581
            return;
4582
          }
4583 950e6b84 taeseongkim
4584 65674874 taeseongkim
          continue;
4585
        } // if we are scrolling up, pick the smallest offsetTop
4586 950e6b84 taeseongkim
4587
4588 65674874 taeseongkim
        if (!userScrollsDown && !entryIsLowerThanPrevious) {
4589
          activate(entry);
4590
        }
4591
      }
4592
    }
4593 950e6b84 taeseongkim
4594 65674874 taeseongkim
    _initializeTargetsAndObservables() {
4595
      this._targetLinks = new Map();
4596
      this._observableSections = new Map();
4597
      const targetLinks = SelectorEngine.find(SELECTOR_TARGET_LINKS, this._config.target);
4598 950e6b84 taeseongkim
4599 65674874 taeseongkim
      for (const anchor of targetLinks) {
4600
        // ensure that the anchor has an id and is not disabled
4601
        if (!anchor.hash || isDisabled(anchor)) {
4602
          continue;
4603
        }
4604 950e6b84 taeseongkim
4605 65674874 taeseongkim
        const observableSection = SelectorEngine.findOne(anchor.hash, this._element); // ensure that the observableSection exists & is visible
4606 950e6b84 taeseongkim
4607 65674874 taeseongkim
        if (isVisible(observableSection)) {
4608
          this._targetLinks.set(anchor.hash, anchor);
4609 950e6b84 taeseongkim
4610 65674874 taeseongkim
          this._observableSections.set(anchor.hash, observableSection);
4611
        }
4612
      }
4613
    }
4614 950e6b84 taeseongkim
4615 65674874 taeseongkim
    _process(target) {
4616
      if (this._activeTarget === target) {
4617
        return;
4618
      }
4619 950e6b84 taeseongkim
4620 65674874 taeseongkim
      this._clearActiveClass(this._config.target);
4621 950e6b84 taeseongkim
4622 65674874 taeseongkim
      this._activeTarget = target;
4623
      target.classList.add(CLASS_NAME_ACTIVE$1);
4624 950e6b84 taeseongkim
4625 65674874 taeseongkim
      this._activateParents(target);
4626 950e6b84 taeseongkim
4627 65674874 taeseongkim
      EventHandler.trigger(this._element, EVENT_ACTIVATE, {
4628
        relatedTarget: target
4629
      });
4630
    }
4631 950e6b84 taeseongkim
4632 65674874 taeseongkim
    _activateParents(target) {
4633
      // Activate dropdown parents
4634
      if (target.classList.contains(CLASS_NAME_DROPDOWN_ITEM)) {
4635
        SelectorEngine.findOne(SELECTOR_DROPDOWN_TOGGLE$1, target.closest(SELECTOR_DROPDOWN)).classList.add(CLASS_NAME_ACTIVE$1);
4636
        return;
4637
      }
4638 950e6b84 taeseongkim
4639 65674874 taeseongkim
      for (const listGroup of SelectorEngine.parents(target, SELECTOR_NAV_LIST_GROUP)) {
4640
        // Set triggered links parents as active
4641
        // With both <ul> and <nav> markup a parent is the previous sibling of any nav ancestor
4642
        for (const item of SelectorEngine.prev(listGroup, SELECTOR_LINK_ITEMS)) {
4643
          item.classList.add(CLASS_NAME_ACTIVE$1);
4644 950e6b84 taeseongkim
        }
4645
      }
4646
    }
4647
4648 65674874 taeseongkim
    _clearActiveClass(parent) {
4649
      parent.classList.remove(CLASS_NAME_ACTIVE$1);
4650
      const activeNodes = SelectorEngine.find(`${SELECTOR_TARGET_LINKS}.${CLASS_NAME_ACTIVE$1}`, parent);
4651 950e6b84 taeseongkim
4652 65674874 taeseongkim
      for (const node of activeNodes) {
4653
        node.classList.remove(CLASS_NAME_ACTIVE$1);
4654
      }
4655
    } // Static
4656 950e6b84 taeseongkim
4657
4658 65674874 taeseongkim
    static jQueryInterface(config) {
4659
      return this.each(function () {
4660
        const data = ScrollSpy.getOrCreateInstance(this, config);
4661 950e6b84 taeseongkim
4662 65674874 taeseongkim
        if (typeof config !== 'string') {
4663
          return;
4664
        }
4665
4666
        if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {
4667
          throw new TypeError(`No method named "${config}"`);
4668
        }
4669
4670
        data[config]();
4671
      });
4672
    }
4673 950e6b84 taeseongkim
4674
  }
4675 65674874 taeseongkim
  /**
4676
   * Data API implementation
4677
   */
4678 950e6b84 taeseongkim
4679
4680 65674874 taeseongkim
  EventHandler.on(window, EVENT_LOAD_DATA_API$1, () => {
4681
    for (const spy of SelectorEngine.find(SELECTOR_DATA_SPY)) {
4682
      ScrollSpy.getOrCreateInstance(spy);
4683
    }
4684
  });
4685
  /**
4686
   * jQuery
4687
   */
4688 950e6b84 taeseongkim
4689 65674874 taeseongkim
  defineJQueryPlugin(ScrollSpy);
4690 950e6b84 taeseongkim
4691 65674874 taeseongkim
  /**
4692
   * --------------------------------------------------------------------------
4693
   * Bootstrap (v5.2.3): tab.js
4694
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
4695
   * --------------------------------------------------------------------------
4696
   */
4697
  /**
4698
   * Constants
4699
   */
4700 950e6b84 taeseongkim
4701 65674874 taeseongkim
  const NAME$1 = 'tab';
4702
  const DATA_KEY$1 = 'bs.tab';
4703
  const EVENT_KEY$1 = `.${DATA_KEY$1}`;
4704
  const EVENT_HIDE$1 = `hide${EVENT_KEY$1}`;
4705
  const EVENT_HIDDEN$1 = `hidden${EVENT_KEY$1}`;
4706
  const EVENT_SHOW$1 = `show${EVENT_KEY$1}`;
4707
  const EVENT_SHOWN$1 = `shown${EVENT_KEY$1}`;
4708
  const EVENT_CLICK_DATA_API = `click${EVENT_KEY$1}`;
4709
  const EVENT_KEYDOWN = `keydown${EVENT_KEY$1}`;
4710
  const EVENT_LOAD_DATA_API = `load${EVENT_KEY$1}`;
4711
  const ARROW_LEFT_KEY = 'ArrowLeft';
4712
  const ARROW_RIGHT_KEY = 'ArrowRight';
4713
  const ARROW_UP_KEY = 'ArrowUp';
4714
  const ARROW_DOWN_KEY = 'ArrowDown';
4715
  const CLASS_NAME_ACTIVE = 'active';
4716
  const CLASS_NAME_FADE$1 = 'fade';
4717
  const CLASS_NAME_SHOW$1 = 'show';
4718
  const CLASS_DROPDOWN = 'dropdown';
4719
  const SELECTOR_DROPDOWN_TOGGLE = '.dropdown-toggle';
4720
  const SELECTOR_DROPDOWN_MENU = '.dropdown-menu';
4721
  const NOT_SELECTOR_DROPDOWN_TOGGLE = ':not(.dropdown-toggle)';
4722
  const SELECTOR_TAB_PANEL = '.list-group, .nav, [role="tablist"]';
4723
  const SELECTOR_OUTER = '.nav-item, .list-group-item';
4724
  const SELECTOR_INNER = `.nav-link${NOT_SELECTOR_DROPDOWN_TOGGLE}, .list-group-item${NOT_SELECTOR_DROPDOWN_TOGGLE}, [role="tab"]${NOT_SELECTOR_DROPDOWN_TOGGLE}`;
4725
  const SELECTOR_DATA_TOGGLE = '[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]'; // todo:v6: could be only `tab`
4726
4727
  const SELECTOR_INNER_ELEM = `${SELECTOR_INNER}, ${SELECTOR_DATA_TOGGLE}`;
4728
  const SELECTOR_DATA_TOGGLE_ACTIVE = `.${CLASS_NAME_ACTIVE}[data-bs-toggle="tab"], .${CLASS_NAME_ACTIVE}[data-bs-toggle="pill"], .${CLASS_NAME_ACTIVE}[data-bs-toggle="list"]`;
4729
  /**
4730
   * Class definition
4731
   */
4732 950e6b84 taeseongkim
4733 65674874 taeseongkim
  class Tab extends BaseComponent {
4734
    constructor(element) {
4735
      super(element);
4736
      this._parent = this._element.closest(SELECTOR_TAB_PANEL);
4737 950e6b84 taeseongkim
4738 65674874 taeseongkim
      if (!this._parent) {
4739
        return; // todo: should Throw exception on v6
4740
        // throw new TypeError(`${element.outerHTML} has not a valid parent ${SELECTOR_INNER_ELEM}`)
4741
      } // Set up initial aria attributes
4742 950e6b84 taeseongkim
4743
4744 65674874 taeseongkim
      this._setInitialAttributes(this._parent, this._getChildren());
4745 950e6b84 taeseongkim
4746 65674874 taeseongkim
      EventHandler.on(this._element, EVENT_KEYDOWN, event => this._keydown(event));
4747
    } // Getters
4748 950e6b84 taeseongkim
4749
4750 65674874 taeseongkim
    static get NAME() {
4751
      return NAME$1;
4752
    } // Public
4753 950e6b84 taeseongkim
4754
4755 65674874 taeseongkim
    show() {
4756
      // Shows this elem and deactivate the active sibling if exists
4757
      const innerElem = this._element;
4758 950e6b84 taeseongkim
4759 65674874 taeseongkim
      if (this._elemIsActive(innerElem)) {
4760
        return;
4761
      } // Search for active tab on same parent to deactivate it
4762 950e6b84 taeseongkim
4763
4764 65674874 taeseongkim
      const active = this._getActiveElem();
4765 950e6b84 taeseongkim
4766 65674874 taeseongkim
      const hideEvent = active ? EventHandler.trigger(active, EVENT_HIDE$1, {
4767
        relatedTarget: innerElem
4768
      }) : null;
4769
      const showEvent = EventHandler.trigger(innerElem, EVENT_SHOW$1, {
4770
        relatedTarget: active
4771
      });
4772 950e6b84 taeseongkim
4773 65674874 taeseongkim
      if (showEvent.defaultPrevented || hideEvent && hideEvent.defaultPrevented) {
4774
        return;
4775
      }
4776 950e6b84 taeseongkim
4777 65674874 taeseongkim
      this._deactivate(active, innerElem);
4778 950e6b84 taeseongkim
4779 65674874 taeseongkim
      this._activate(innerElem, active);
4780
    } // Private
4781 950e6b84 taeseongkim
4782
4783 65674874 taeseongkim
    _activate(element, relatedElem) {
4784
      if (!element) {
4785
        return;
4786
      }
4787 950e6b84 taeseongkim
4788 65674874 taeseongkim
      element.classList.add(CLASS_NAME_ACTIVE);
4789 950e6b84 taeseongkim
4790 65674874 taeseongkim
      this._activate(getElementFromSelector(element)); // Search and activate/show the proper section
4791 950e6b84 taeseongkim
4792
4793 65674874 taeseongkim
      const complete = () => {
4794
        if (element.getAttribute('role') !== 'tab') {
4795
          element.classList.add(CLASS_NAME_SHOW$1);
4796
          return;
4797
        }
4798 950e6b84 taeseongkim
4799 65674874 taeseongkim
        element.removeAttribute('tabindex');
4800
        element.setAttribute('aria-selected', true);
4801 950e6b84 taeseongkim
4802 65674874 taeseongkim
        this._toggleDropDown(element, true);
4803 950e6b84 taeseongkim
4804 65674874 taeseongkim
        EventHandler.trigger(element, EVENT_SHOWN$1, {
4805
          relatedTarget: relatedElem
4806
        });
4807
      };
4808 950e6b84 taeseongkim
4809 65674874 taeseongkim
      this._queueCallback(complete, element, element.classList.contains(CLASS_NAME_FADE$1));
4810
    }
4811 950e6b84 taeseongkim
4812 65674874 taeseongkim
    _deactivate(element, relatedElem) {
4813
      if (!element) {
4814
        return;
4815
      }
4816 950e6b84 taeseongkim
4817 65674874 taeseongkim
      element.classList.remove(CLASS_NAME_ACTIVE);
4818
      element.blur();
4819 950e6b84 taeseongkim
4820 65674874 taeseongkim
      this._deactivate(getElementFromSelector(element)); // Search and deactivate the shown section too
4821 950e6b84 taeseongkim
4822
4823 65674874 taeseongkim
      const complete = () => {
4824
        if (element.getAttribute('role') !== 'tab') {
4825
          element.classList.remove(CLASS_NAME_SHOW$1);
4826
          return;
4827
        }
4828 950e6b84 taeseongkim
4829 65674874 taeseongkim
        element.setAttribute('aria-selected', false);
4830
        element.setAttribute('tabindex', '-1');
4831 950e6b84 taeseongkim
4832 65674874 taeseongkim
        this._toggleDropDown(element, false);
4833 950e6b84 taeseongkim
4834 65674874 taeseongkim
        EventHandler.trigger(element, EVENT_HIDDEN$1, {
4835
          relatedTarget: relatedElem
4836
        });
4837
      };
4838 950e6b84 taeseongkim
4839 65674874 taeseongkim
      this._queueCallback(complete, element, element.classList.contains(CLASS_NAME_FADE$1));
4840
    }
4841 950e6b84 taeseongkim
4842 65674874 taeseongkim
    _keydown(event) {
4843
      if (![ARROW_LEFT_KEY, ARROW_RIGHT_KEY, ARROW_UP_KEY, ARROW_DOWN_KEY].includes(event.key)) {
4844
        return;
4845
      }
4846 950e6b84 taeseongkim
4847 65674874 taeseongkim
      event.stopPropagation(); // stopPropagation/preventDefault both added to support up/down keys without scrolling the page
4848 950e6b84 taeseongkim
4849 65674874 taeseongkim
      event.preventDefault();
4850
      const isNext = [ARROW_RIGHT_KEY, ARROW_DOWN_KEY].includes(event.key);
4851
      const nextActiveElement = getNextActiveElement(this._getChildren().filter(element => !isDisabled(element)), event.target, isNext, true);
4852 950e6b84 taeseongkim
4853 65674874 taeseongkim
      if (nextActiveElement) {
4854
        nextActiveElement.focus({
4855
          preventScroll: true
4856
        });
4857
        Tab.getOrCreateInstance(nextActiveElement).show();
4858
      }
4859
    }
4860 950e6b84 taeseongkim
4861 65674874 taeseongkim
    _getChildren() {
4862
      // collection of inner elements
4863
      return SelectorEngine.find(SELECTOR_INNER_ELEM, this._parent);
4864
    }
4865 950e6b84 taeseongkim
4866 65674874 taeseongkim
    _getActiveElem() {
4867
      return this._getChildren().find(child => this._elemIsActive(child)) || null;
4868
    }
4869 950e6b84 taeseongkim
4870 65674874 taeseongkim
    _setInitialAttributes(parent, children) {
4871
      this._setAttributeIfNotExists(parent, 'role', 'tablist');
4872 950e6b84 taeseongkim
4873 65674874 taeseongkim
      for (const child of children) {
4874
        this._setInitialAttributesOnChild(child);
4875
      }
4876
    }
4877 950e6b84 taeseongkim
4878 65674874 taeseongkim
    _setInitialAttributesOnChild(child) {
4879
      child = this._getInnerElement(child);
4880 950e6b84 taeseongkim
4881 65674874 taeseongkim
      const isActive = this._elemIsActive(child);
4882 950e6b84 taeseongkim
4883 65674874 taeseongkim
      const outerElem = this._getOuterElement(child);
4884 950e6b84 taeseongkim
4885 65674874 taeseongkim
      child.setAttribute('aria-selected', isActive);
4886 950e6b84 taeseongkim
4887 65674874 taeseongkim
      if (outerElem !== child) {
4888
        this._setAttributeIfNotExists(outerElem, 'role', 'presentation');
4889
      }
4890 950e6b84 taeseongkim
4891 65674874 taeseongkim
      if (!isActive) {
4892
        child.setAttribute('tabindex', '-1');
4893
      }
4894 950e6b84 taeseongkim
4895 65674874 taeseongkim
      this._setAttributeIfNotExists(child, 'role', 'tab'); // set attributes to the related panel too
4896 950e6b84 taeseongkim
4897
4898 65674874 taeseongkim
      this._setInitialAttributesOnTargetPanel(child);
4899
    }
4900 950e6b84 taeseongkim
4901 65674874 taeseongkim
    _setInitialAttributesOnTargetPanel(child) {
4902
      const target = getElementFromSelector(child);
4903 950e6b84 taeseongkim
4904 65674874 taeseongkim
      if (!target) {
4905
        return;
4906
      }
4907 950e6b84 taeseongkim
4908 65674874 taeseongkim
      this._setAttributeIfNotExists(target, 'role', 'tabpanel');
4909 950e6b84 taeseongkim
4910 65674874 taeseongkim
      if (child.id) {
4911
        this._setAttributeIfNotExists(target, 'aria-labelledby', `#${child.id}`);
4912 950e6b84 taeseongkim
      }
4913 65674874 taeseongkim
    }
4914 950e6b84 taeseongkim
4915 65674874 taeseongkim
    _toggleDropDown(element, open) {
4916
      const outerElem = this._getOuterElement(element);
4917
4918
      if (!outerElem.classList.contains(CLASS_DROPDOWN)) {
4919
        return;
4920 950e6b84 taeseongkim
      }
4921
4922 65674874 taeseongkim
      const toggle = (selector, className) => {
4923
        const element = SelectorEngine.findOne(selector, outerElem);
4924
4925
        if (element) {
4926
          element.classList.toggle(className, open);
4927
        }
4928
      };
4929
4930
      toggle(SELECTOR_DROPDOWN_TOGGLE, CLASS_NAME_ACTIVE);
4931
      toggle(SELECTOR_DROPDOWN_MENU, CLASS_NAME_SHOW$1);
4932
      outerElem.setAttribute('aria-expanded', open);
4933 950e6b84 taeseongkim
    }
4934
4935 65674874 taeseongkim
    _setAttributeIfNotExists(element, attribute, value) {
4936
      if (!element.hasAttribute(attribute)) {
4937
        element.setAttribute(attribute, value);
4938
      }
4939
    }
4940 950e6b84 taeseongkim
4941 65674874 taeseongkim
    _elemIsActive(elem) {
4942
      return elem.classList.contains(CLASS_NAME_ACTIVE);
4943
    } // Try to get the inner element (usually the .nav-link)
4944 950e6b84 taeseongkim
4945
4946 65674874 taeseongkim
    _getInnerElement(elem) {
4947
      return elem.matches(SELECTOR_INNER_ELEM) ? elem : SelectorEngine.findOne(SELECTOR_INNER_ELEM, elem);
4948
    } // Try to get the outer element (usually the .nav-item)
4949 950e6b84 taeseongkim
4950
4951 65674874 taeseongkim
    _getOuterElement(elem) {
4952
      return elem.closest(SELECTOR_OUTER) || elem;
4953
    } // Static
4954 950e6b84 taeseongkim
4955
4956 65674874 taeseongkim
    static jQueryInterface(config) {
4957
      return this.each(function () {
4958
        const data = Tab.getOrCreateInstance(this);
4959 950e6b84 taeseongkim
4960 65674874 taeseongkim
        if (typeof config !== 'string') {
4961
          return;
4962
        }
4963
4964
        if (data[config] === undefined || config.startsWith('_') || config === 'constructor') {
4965
          throw new TypeError(`No method named "${config}"`);
4966
        }
4967 950e6b84 taeseongkim
4968 65674874 taeseongkim
        data[config]();
4969
      });
4970
    }
4971 950e6b84 taeseongkim
4972
  }
4973 65674874 taeseongkim
  /**
4974
   * Data API implementation
4975
   */
4976 950e6b84 taeseongkim
4977
4978 65674874 taeseongkim
  EventHandler.on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
4979
    if (['A', 'AREA'].includes(this.tagName)) {
4980
      event.preventDefault();
4981
    }
4982 950e6b84 taeseongkim
4983 65674874 taeseongkim
    if (isDisabled(this)) {
4984
      return;
4985
    }
4986
4987
    Tab.getOrCreateInstance(this).show();
4988
  });
4989
  /**
4990
   * Initialize on focus
4991
   */
4992 950e6b84 taeseongkim
4993 65674874 taeseongkim
  EventHandler.on(window, EVENT_LOAD_DATA_API, () => {
4994
    for (const element of SelectorEngine.find(SELECTOR_DATA_TOGGLE_ACTIVE)) {
4995
      Tab.getOrCreateInstance(element);
4996
    }
4997
  });
4998
  /**
4999
   * jQuery
5000
   */
5001 950e6b84 taeseongkim
5002 65674874 taeseongkim
  defineJQueryPlugin(Tab);
5003 950e6b84 taeseongkim
5004 65674874 taeseongkim
  /**
5005
   * --------------------------------------------------------------------------
5006
   * Bootstrap (v5.2.3): toast.js
5007
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
5008
   * --------------------------------------------------------------------------
5009
   */
5010
  /**
5011
   * Constants
5012
   */
5013 950e6b84 taeseongkim
5014 65674874 taeseongkim
  const NAME = 'toast';
5015
  const DATA_KEY = 'bs.toast';
5016
  const EVENT_KEY = `.${DATA_KEY}`;
5017
  const EVENT_MOUSEOVER = `mouseover${EVENT_KEY}`;
5018
  const EVENT_MOUSEOUT = `mouseout${EVENT_KEY}`;
5019
  const EVENT_FOCUSIN = `focusin${EVENT_KEY}`;
5020
  const EVENT_FOCUSOUT = `focusout${EVENT_KEY}`;
5021
  const EVENT_HIDE = `hide${EVENT_KEY}`;
5022
  const EVENT_HIDDEN = `hidden${EVENT_KEY}`;
5023
  const EVENT_SHOW = `show${EVENT_KEY}`;
5024
  const EVENT_SHOWN = `shown${EVENT_KEY}`;
5025
  const CLASS_NAME_FADE = 'fade';
5026
  const CLASS_NAME_HIDE = 'hide'; // @deprecated - kept here only for backwards compatibility
5027
5028
  const CLASS_NAME_SHOW = 'show';
5029
  const CLASS_NAME_SHOWING = 'showing';
5030
  const DefaultType = {
5031
    animation: 'boolean',
5032
    autohide: 'boolean',
5033
    delay: 'number'
5034
  };
5035
  const Default = {
5036
    animation: true,
5037
    autohide: true,
5038
    delay: 5000
5039
  };
5040
  /**
5041
   * Class definition
5042
   */
5043 950e6b84 taeseongkim
5044 65674874 taeseongkim
  class Toast extends BaseComponent {
5045
    constructor(element, config) {
5046
      super(element, config);
5047
      this._timeout = null;
5048
      this._hasMouseInteraction = false;
5049
      this._hasKeyboardInteraction = false;
5050 950e6b84 taeseongkim
5051 65674874 taeseongkim
      this._setListeners();
5052
    } // Getters
5053 950e6b84 taeseongkim
5054
5055 65674874 taeseongkim
    static get Default() {
5056
      return Default;
5057
    }
5058 950e6b84 taeseongkim
5059 65674874 taeseongkim
    static get DefaultType() {
5060
      return DefaultType;
5061
    }
5062 950e6b84 taeseongkim
5063 65674874 taeseongkim
    static get NAME() {
5064
      return NAME;
5065
    } // Public
5066 950e6b84 taeseongkim
5067
5068 65674874 taeseongkim
    show() {
5069
      const showEvent = EventHandler.trigger(this._element, EVENT_SHOW);
5070 950e6b84 taeseongkim
5071 65674874 taeseongkim
      if (showEvent.defaultPrevented) {
5072
        return;
5073
      }
5074 950e6b84 taeseongkim
5075 65674874 taeseongkim
      this._clearTimeout();
5076 950e6b84 taeseongkim
5077 65674874 taeseongkim
      if (this._config.animation) {
5078
        this._element.classList.add(CLASS_NAME_FADE);
5079
      }
5080 950e6b84 taeseongkim
5081 65674874 taeseongkim
      const complete = () => {
5082
        this._element.classList.remove(CLASS_NAME_SHOWING);
5083 950e6b84 taeseongkim
5084 65674874 taeseongkim
        EventHandler.trigger(this._element, EVENT_SHOWN);
5085 950e6b84 taeseongkim
5086 65674874 taeseongkim
        this._maybeScheduleHide();
5087
      };
5088 950e6b84 taeseongkim
5089 65674874 taeseongkim
      this._element.classList.remove(CLASS_NAME_HIDE); // @deprecated
5090 950e6b84 taeseongkim
5091
5092 65674874 taeseongkim
      reflow(this._element);
5093 950e6b84 taeseongkim
5094 65674874 taeseongkim
      this._element.classList.add(CLASS_NAME_SHOW, CLASS_NAME_SHOWING);
5095 950e6b84 taeseongkim
5096 65674874 taeseongkim
      this._queueCallback(complete, this._element, this._config.animation);
5097
    }
5098 950e6b84 taeseongkim
5099 65674874 taeseongkim
    hide() {
5100
      if (!this.isShown()) {
5101
        return;
5102
      }
5103 950e6b84 taeseongkim
5104 65674874 taeseongkim
      const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE);
5105 950e6b84 taeseongkim
5106 65674874 taeseongkim
      if (hideEvent.defaultPrevented) {
5107
        return;
5108
      }
5109 950e6b84 taeseongkim
5110 65674874 taeseongkim
      const complete = () => {
5111
        this._element.classList.add(CLASS_NAME_HIDE); // @deprecated
5112 950e6b84 taeseongkim
5113
5114 65674874 taeseongkim
        this._element.classList.remove(CLASS_NAME_SHOWING, CLASS_NAME_SHOW);
5115 950e6b84 taeseongkim
5116 65674874 taeseongkim
        EventHandler.trigger(this._element, EVENT_HIDDEN);
5117
      };
5118 950e6b84 taeseongkim
5119 65674874 taeseongkim
      this._element.classList.add(CLASS_NAME_SHOWING);
5120 950e6b84 taeseongkim
5121 65674874 taeseongkim
      this._queueCallback(complete, this._element, this._config.animation);
5122 950e6b84 taeseongkim
    }
5123
5124 65674874 taeseongkim
    dispose() {
5125
      this._clearTimeout();
5126
5127
      if (this.isShown()) {
5128
        this._element.classList.remove(CLASS_NAME_SHOW);
5129
      }
5130
5131
      super.dispose();
5132 950e6b84 taeseongkim
    }
5133 65674874 taeseongkim
5134
    isShown() {
5135
      return this._element.classList.contains(CLASS_NAME_SHOW);
5136
    } // Private
5137 950e6b84 taeseongkim
5138
5139 65674874 taeseongkim
    _maybeScheduleHide() {
5140
      if (!this._config.autohide) {
5141
        return;
5142
      }
5143 950e6b84 taeseongkim
5144 65674874 taeseongkim
      if (this._hasMouseInteraction || this._hasKeyboardInteraction) {
5145
        return;
5146
      }
5147 950e6b84 taeseongkim
5148 65674874 taeseongkim
      this._timeout = setTimeout(() => {
5149
        this.hide();
5150
      }, this._config.delay);
5151
    }
5152 950e6b84 taeseongkim
5153 65674874 taeseongkim
    _onInteraction(event, isInteracting) {
5154
      switch (event.type) {
5155
        case 'mouseover':
5156
        case 'mouseout':
5157
          {
5158
            this._hasMouseInteraction = isInteracting;
5159
            break;
5160
          }
5161
5162
        case 'focusin':
5163
        case 'focusout':
5164
          {
5165
            this._hasKeyboardInteraction = isInteracting;
5166
            break;
5167
          }
5168
      }
5169 950e6b84 taeseongkim
5170 65674874 taeseongkim
      if (isInteracting) {
5171
        this._clearTimeout();
5172 950e6b84 taeseongkim
5173 65674874 taeseongkim
        return;
5174
      }
5175 950e6b84 taeseongkim
5176 65674874 taeseongkim
      const nextElement = event.relatedTarget;
5177 950e6b84 taeseongkim
5178 65674874 taeseongkim
      if (this._element === nextElement || this._element.contains(nextElement)) {
5179
        return;
5180
      }
5181 950e6b84 taeseongkim
5182 65674874 taeseongkim
      this._maybeScheduleHide();
5183
    }
5184
5185
    _setListeners() {
5186
      EventHandler.on(this._element, EVENT_MOUSEOVER, event => this._onInteraction(event, true));
5187
      EventHandler.on(this._element, EVENT_MOUSEOUT, event => this._onInteraction(event, false));
5188
      EventHandler.on(this._element, EVENT_FOCUSIN, event => this._onInteraction(event, true));
5189
      EventHandler.on(this._element, EVENT_FOCUSOUT, event => this._onInteraction(event, false));
5190
    }
5191
5192
    _clearTimeout() {
5193
      clearTimeout(this._timeout);
5194
      this._timeout = null;
5195
    } // Static
5196 950e6b84 taeseongkim
5197
5198 65674874 taeseongkim
    static jQueryInterface(config) {
5199
      return this.each(function () {
5200
        const data = Toast.getOrCreateInstance(this, config);
5201
5202
        if (typeof config === 'string') {
5203
          if (typeof data[config] === 'undefined') {
5204
            throw new TypeError(`No method named "${config}"`);
5205
          }
5206
5207
          data[config](this);
5208
        }
5209
      });
5210
    }
5211
5212
  }
5213
  /**
5214
   * Data API implementation
5215
   */
5216 950e6b84 taeseongkim
5217
5218 65674874 taeseongkim
  enableDismissTrigger(Toast);
5219
  /**
5220
   * jQuery
5221
   */
5222 950e6b84 taeseongkim
5223 65674874 taeseongkim
  defineJQueryPlugin(Toast);
5224 950e6b84 taeseongkim
5225 65674874 taeseongkim
  /**
5226
   * --------------------------------------------------------------------------
5227
   * Bootstrap (v5.2.3): index.umd.js
5228
   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
5229
   * --------------------------------------------------------------------------
5230
   */
5231
  const index_umd = {
5232
    Alert,
5233
    Button,
5234
    Carousel,
5235
    Collapse,
5236
    Dropdown,
5237
    Modal,
5238
    Offcanvas,
5239
    Popover,
5240
    ScrollSpy,
5241
    Tab,
5242
    Toast,
5243
    Tooltip
5244
  };
5245
5246
  return index_umd;
5247
5248
}));
5249
//# sourceMappingURL=bootstrap.js.map
클립보드 이미지 추가 (최대 크기: 500 MB)