internet-programming/lab2/node_modules/bootstrap/js/dist/util/backdrop.js

141 lines
4.0 KiB
JavaScript
Raw Normal View History

2023-10-23 13:48:44 +04:00
/*!
2023-11-02 21:33:55 +04:00
* Bootstrap backdrop.js v5.3.2 (https://getbootstrap.com/)
* Copyright 2011-2023 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
2023-10-23 13:48:44 +04:00
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
*/
(function (global, factory) {
2023-11-02 21:33:55 +04:00
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('../dom/event-handler.js'), require('./config.js'), require('./index.js')) :
typeof define === 'function' && define.amd ? define(['../dom/event-handler', './config', './index'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Backdrop = factory(global.EventHandler, global.Config, global.Index));
})(this, (function (EventHandler, Config, index_js) { 'use strict';
2023-10-23 13:48:44 +04:00
/**
* --------------------------------------------------------------------------
2023-11-02 21:33:55 +04:00
* Bootstrap util/backdrop.js
2023-10-23 13:48:44 +04:00
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
* --------------------------------------------------------------------------
*/
2023-11-02 21:33:55 +04:00
2023-10-23 13:48:44 +04:00
/**
* Constants
*/
const NAME = 'backdrop';
const CLASS_NAME_FADE = 'fade';
const CLASS_NAME_SHOW = 'show';
const EVENT_MOUSEDOWN = `mousedown.bs.${NAME}`;
const Default = {
className: 'modal-backdrop',
clickCallback: null,
isAnimated: false,
isVisible: true,
// if false, we use the backdrop helper without adding any element to the dom
rootElement: 'body' // give the choice to place backdrop under different elements
};
2023-11-02 21:33:55 +04:00
2023-10-23 13:48:44 +04:00
const DefaultType = {
className: 'string',
clickCallback: '(function|null)',
isAnimated: 'boolean',
isVisible: 'boolean',
rootElement: '(element|string)'
};
2023-11-02 21:33:55 +04:00
2023-10-23 13:48:44 +04:00
/**
* Class definition
*/
2023-11-02 21:33:55 +04:00
class Backdrop extends Config {
2023-10-23 13:48:44 +04:00
constructor(config) {
super();
this._config = this._getConfig(config);
this._isAppended = false;
this._element = null;
2023-11-02 21:33:55 +04:00
}
2023-10-23 13:48:44 +04:00
2023-11-02 21:33:55 +04:00
// Getters
2023-10-23 13:48:44 +04:00
static get Default() {
return Default;
}
static get DefaultType() {
return DefaultType;
}
static get NAME() {
return NAME;
2023-11-02 21:33:55 +04:00
}
2023-10-23 13:48:44 +04:00
2023-11-02 21:33:55 +04:00
// Public
2023-10-23 13:48:44 +04:00
show(callback) {
if (!this._config.isVisible) {
2023-11-02 21:33:55 +04:00
index_js.execute(callback);
2023-10-23 13:48:44 +04:00
return;
}
this._append();
const element = this._getElement();
if (this._config.isAnimated) {
2023-11-02 21:33:55 +04:00
index_js.reflow(element);
2023-10-23 13:48:44 +04:00
}
element.classList.add(CLASS_NAME_SHOW);
this._emulateAnimation(() => {
2023-11-02 21:33:55 +04:00
index_js.execute(callback);
2023-10-23 13:48:44 +04:00
});
}
hide(callback) {
if (!this._config.isVisible) {
2023-11-02 21:33:55 +04:00
index_js.execute(callback);
2023-10-23 13:48:44 +04:00
return;
}
this._getElement().classList.remove(CLASS_NAME_SHOW);
this._emulateAnimation(() => {
this.dispose();
2023-11-02 21:33:55 +04:00
index_js.execute(callback);
2023-10-23 13:48:44 +04:00
});
}
dispose() {
if (!this._isAppended) {
return;
}
2023-11-02 21:33:55 +04:00
EventHandler.off(this._element, EVENT_MOUSEDOWN);
2023-10-23 13:48:44 +04:00
this._element.remove();
this._isAppended = false;
2023-11-02 21:33:55 +04:00
}
2023-10-23 13:48:44 +04:00
2023-11-02 21:33:55 +04:00
// Private
2023-10-23 13:48:44 +04:00
_getElement() {
if (!this._element) {
const backdrop = document.createElement('div');
backdrop.className = this._config.className;
if (this._config.isAnimated) {
backdrop.classList.add(CLASS_NAME_FADE);
}
this._element = backdrop;
}
return this._element;
}
_configAfterMerge(config) {
// use getElement() with the default "body" to get a fresh Element on each instantiation
2023-11-02 21:33:55 +04:00
config.rootElement = index_js.getElement(config.rootElement);
2023-10-23 13:48:44 +04:00
return config;
}
_append() {
if (this._isAppended) {
return;
}
const element = this._getElement();
this._config.rootElement.append(element);
2023-11-02 21:33:55 +04:00
EventHandler.on(element, EVENT_MOUSEDOWN, () => {
index_js.execute(this._config.clickCallback);
2023-10-23 13:48:44 +04:00
});
this._isAppended = true;
}
_emulateAnimation(callback) {
2023-11-02 21:33:55 +04:00
index_js.executeAfterTransition(callback, this._getElement(), this._config.isAnimated);
2023-10-23 13:48:44 +04:00
}
}
return Backdrop;
}));
//# sourceMappingURL=backdrop.js.map