vgapp 0.1.4 → 0.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/vgapp.js CHANGED
@@ -1,4155 +1,3 @@
1
- var vg;
2
- /******/ (() => { // webpackBootstrap
3
- /******/ "use strict";
4
- /******/ var __webpack_modules__ = ({
5
-
6
- /***/ "./app/modules/base-module.js":
7
- /*!************************************!*\
8
- !*** ./app/modules/base-module.js ***!
9
- \************************************/
10
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
11
-
12
- __webpack_require__.r(__webpack_exports__);
13
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
14
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
15
- /* harmony export */ });
16
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/js/functions */ "./app/utils/js/functions.js");
17
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
18
- /* harmony import */ var _utils_js_dom_data__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/js/dom/data */ "./app/utils/js/dom/data.js");
19
- /* harmony import */ var _utils_js_components_params__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/js/components/params */ "./app/utils/js/components/params.js");
20
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/js/dom/event */ "./app/utils/js/dom/event.js");
21
- /* harmony import */ var _module_fn__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./module-fn */ "./app/modules/module-fn.js");
22
- /* harmony import */ var _utils_js_components_animation__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils/js/components/animation */ "./app/utils/js/components/animation.js");
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
- class BaseModule {
31
- constructor(element) {
32
- if (!element) return;
33
- this._element = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find(element);
34
- if (!this._element) {
35
- throw new Error('Товарищ! Первый параметр не должен быть пустым!');
36
- }
37
- this._params = {};
38
- _utils_js_dom_data__WEBPACK_IMPORTED_MODULE_2__["default"].set(this._element, this.constructor.NAME_KEY, this);
39
- }
40
- _getParams(element, params) {
41
- return new _utils_js_components_params__WEBPACK_IMPORTED_MODULE_3__["default"](params, element).get();
42
- }
43
- dispose() {
44
- _utils_js_dom_data__WEBPACK_IMPORTED_MODULE_2__["default"].remove(this._element, this.constructor.NAME_KEY);
45
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].off(this._element, this.constructor.EVENT_KEY);
46
- for (const propertyName of Object.getOwnPropertyNames(this)) {
47
- this[propertyName] = null;
48
- }
49
- }
50
- _route(callback) {
51
- const _this = this;
52
- let $content = null;
53
- const setData = data => {
54
- if ($content) $content.innerHTML = data;
55
- };
56
- if (!_this._params.hasOwnProperty('ajax')) {
57
- return;
58
- }
59
- if (!_this._params.ajax.route) {
60
- return;
61
- }
62
- if (!'method' in _this._params.ajax) {
63
- _this._params.ajax.method = 'get';
64
- }
65
- if ('target' in _this._params.ajax && _this._params.ajax.target) {
66
- $content = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find(_this._params.ajax.target);
67
- }
68
- if ('loader' in _this._params.ajax && _this._params.ajax.loader) {
69
- setData('<div class="vg-loader"></div>');
70
- }
71
- _module_fn__WEBPACK_IMPORTED_MODULE_5__.Ajax[_this._params.ajax.method](_this._params.ajax.route, _this._params.ajax.data || {}, function (status, data) {
72
- setData(data.response);
73
- (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_0__.execute)(callback, [status, data]);
74
- });
75
- }
76
- _dismissElement() {
77
- let cross = (0,_module_fn__WEBPACK_IMPORTED_MODULE_5__.getSVG)('cross'),
78
- button = this._element.querySelector('.vg-btn-close');
79
- if (button) {
80
- let svg = button.querySelector('svg');
81
- if (!svg) button.insertAdjacentHTML('beforeend', cross);
82
- }
83
- }
84
- _queueCallback(callback, element, isAnimated = true, timeOutMs) {
85
- (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_0__.executeAfterTransition)(callback, element, isAnimated, timeOutMs);
86
- }
87
- _animation(element, key, params = {}) {
88
- new _utils_js_components_animation__WEBPACK_IMPORTED_MODULE_6__["default"](element, key, params);
89
- }
90
- static getInstance(element) {
91
- return _utils_js_dom_data__WEBPACK_IMPORTED_MODULE_2__["default"].get(_utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find(element), this.NAME_KEY);
92
- }
93
- static getOrCreateInstance(element, params = {}) {
94
- return this.getInstance(element) || new this(element, !(0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_0__.isEmptyObj)(params) ? params : {});
95
- }
96
- static get DATA_KEY() {
97
- return `vg.${this.NAME}`;
98
- }
99
- static get EVENT_KEY() {
100
- return `.${this.DATA_KEY}`;
101
- }
102
- }
103
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (BaseModule);
104
-
105
- /***/ }),
106
-
107
- /***/ "./app/modules/module-fn.js":
108
- /*!**********************************!*\
109
- !*** ./app/modules/module-fn.js ***!
110
- \**********************************/
111
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
112
-
113
- __webpack_require__.r(__webpack_exports__);
114
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
115
- /* harmony export */ Ajax: () => (/* binding */ Ajax),
116
- /* harmony export */ dismissTrigger: () => (/* binding */ dismissTrigger),
117
- /* harmony export */ getSVG: () => (/* binding */ getSVG)
118
- /* harmony export */ });
119
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/js/dom/event */ "./app/utils/js/dom/event.js");
120
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/js/functions */ "./app/utils/js/functions.js");
121
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
122
-
123
-
124
-
125
-
126
- /**
127
- * Тут собраны вспомогательные скрипты для работы модулей
128
- */
129
-
130
- /**
131
- * Набор svg элементов
132
- * @param name
133
- * @returns {*|{}}
134
- */
135
- const getSVG = name => {
136
- const svg = {
137
- error: '<svg viewBox="0 0 87 87" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="ui-success" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="Group-2" transform="translate(2.000000, 2.000000)"><circle id="Oval-2" stroke="rgba(252, 191, 191, .5)" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><circle class="ui-error-circle" stroke="#F74444" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><path class="ui-error-line1" d="M22.244224,22 L60.4279902,60.1837662" id="Line" stroke="#F74444" stroke-width="3" stroke-linecap="square"></path><path class="ui-error-line2" d="M60.755776,21 L23.244224,59.8443492" id="Line" stroke="#F74444" stroke-width="3" stroke-linecap="square"></path></g></g></svg>',
138
- success: '<svg viewBox="0 0 87 87" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="ui-error" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="Group-3" transform="translate(2.000000, 2.000000)"><circle id="Oval-2" stroke="rgba(117, 183, 152, 0.4)" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><circle class="ui-success-circle" id="Oval-2" stroke="#A5DC86" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><polyline class="ui-success-path" id="Path-2" stroke="#A5DC86" stroke-width="4" points="19 38.8036813 31.1020744 54.8046875 63.299221 28"></polyline></g></g></svg>',
139
- waiting: '<svg viewBox="0 0 87 87" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="ui-waiting" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="Group-3" transform="translate(2.000000, 2.000000)"><circle id="Oval-2" stroke="rgba(255, 218, 106, 0.4)" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><circle class="ui-waiting-circle" id="Oval-2" stroke="#ffda6a" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><path class="ui-waiting-line1" d="M43 63C54.598 63 64 53.598 64 42C64 30.402 54.598 21 43 21C31.402 21 22 30.402 22 42C22 53.598 31.402 63 43 63Z" stroke-width="3" stroke="#ffda6a" stroke-linecap="round" stroke-linejoin="round"/><path class="ui-waiting-line2" d="M40.6667 32.6641V44.3307H52.3334" stroke="#ffda6a" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"/></g></g></svg>',
140
- dots: '<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-three-dots-vertical" viewBox="0 0 16 16"><path d="M9.5 13a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z"/></svg>',
141
- cross: '<svg version="1.1" id="Capa_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 224.512 224.512" xml:space="preserve"><g><polygon points="224.507,6.997 217.521,0 112.256,105.258 6.998,0 0.005,6.997 105.263,112.254 0.005,217.512 6.998,224.512 112.256,119.24 217.521,224.512 224.507,217.512 119.249,112.254 "/></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g></svg>'
142
- };
143
- return svg[name] ?? {};
144
- };
145
-
146
- /**
147
- * Вешаем событие "Закрыть" на все модалки, сайдбары и т.п.
148
- * @param module
149
- * @param method
150
- */
151
- const dismissTrigger = (module, method = 'hide') => {
152
- const clickEvent = `click.dismiss.${module.EVENT_KEY}`;
153
- const name = module.NAME;
154
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_0__["default"].on(document, clickEvent, `[data-vg-dismiss="${name}"]`, function (event) {
155
- if (['A', 'AREA'].includes(this.tagName)) {
156
- event.preventDefault();
157
- }
158
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(this)) return;
159
- const target = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_2__["default"].getSelectorFromElement(this) || this.closest(`.vg-${name}`);
160
- const instance = module.getOrCreateInstance(target);
161
- instance[method]();
162
- });
163
- };
164
-
165
- /**
166
- * AJAX REQUEST
167
- * @type {{post: ajax.post, get: ajax.get, x: ((function(): (XMLHttpRequest))|*), send: ajax.send}}
168
- */
169
- const Ajax = {
170
- x: function () {
171
- if (typeof XMLHttpRequest !== 'undefined') {
172
- return new XMLHttpRequest();
173
- }
174
- let versions = ["MSXML2.XmlHttp.6.0", "MSXML2.XmlHttp.5.0", "MSXML2.XmlHttp.4.0", "MSXML2.XmlHttp.3.0", "MSXML2.XmlHttp.2.0", "Microsoft.XmlHttp"];
175
- let xhr;
176
- for (let i = 0; i < versions.length; i++) {
177
- try {
178
- xhr = new ActiveXObject(versions[i]);
179
- break;
180
- } catch (e) {}
181
- }
182
- return xhr;
183
- },
184
- send: function (url, callback, method, data, async) {
185
- if (async === undefined) {
186
- async = true;
187
- }
188
- let x = Ajax.x();
189
- x.open(method, url, async);
190
- x.setRequestHeader("X-Requested-With", "XMLHttpRequest");
191
- x.onreadystatechange = function () {
192
- if (x.readyState === 4) {
193
- switch (x.status) {
194
- case 200:
195
- callback('success', {
196
- text: x.statusText,
197
- response: x.responseText,
198
- code: x.status
199
- });
200
- break;
201
- default:
202
- callback('error', {
203
- text: x.statusText,
204
- response: x.responseText,
205
- code: x.status
206
- });
207
- break;
208
- }
209
- }
210
- };
211
- x.send(data);
212
- },
213
- get: function (url, data, callback, async) {
214
- let query = [];
215
- if (!(0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isEmptyObj)(data)) {
216
- for (let key of data) {
217
- query.push(encodeURIComponent(key[0]) + '=' + encodeURIComponent(key[1]));
218
- }
219
- }
220
- Ajax.send(url + (query.length ? '?' + query.join('&') : ''), callback, 'GET', null, async);
221
- },
222
- post: function (url, data, callback, async) {
223
- Ajax.send(url, callback, 'POST', data, async);
224
- }
225
- };
226
-
227
-
228
- /***/ }),
229
-
230
- /***/ "./app/modules/vgcollapse/js/vgcollapse.js":
231
- /*!*************************************************!*\
232
- !*** ./app/modules/vgcollapse/js/vgcollapse.js ***!
233
- \*************************************************/
234
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
235
-
236
- __webpack_require__.r(__webpack_exports__);
237
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
238
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
239
- /* harmony export */ });
240
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
241
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
242
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
243
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
244
- /* harmony import */ var _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/dom/manipulator */ "./app/utils/js/dom/manipulator.js");
245
-
246
-
247
-
248
-
249
-
250
-
251
- /**
252
- * Constants
253
- */
254
- const NAME = 'collapse';
255
- const NAME_KEY = 'vg.collapse';
256
- const CLASS_NAME_SHOW = 'show';
257
- const CLASS_NAME_COLLAPSE = 'vg-collapse';
258
- const CLASS_NAME_COLLAPSING = 'vg-collapsing';
259
- const CLASS_NAME_COLLAPSED = 'vg-collapsed';
260
- const CLASS_NAME_DEEPER_CHILDREN = `:scope .${CLASS_NAME_COLLAPSE} .${CLASS_NAME_COLLAPSE}`;
261
- const SELECTOR_DATA_TOGGLE = '[data-vg-toggle="collapse"]';
262
- const SELECTOR_ACTIVES = '.collapse.show, .collapse.collapsing';
263
- const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
264
- const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
265
- const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
266
- const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
267
- const EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
268
- class VGCollapse extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
269
- constructor(element, params = {}) {
270
- super(element, params);
271
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.mergeDeepObject)({
272
- toggle: true,
273
- parent: null,
274
- ajax: {
275
- route: '',
276
- target: '',
277
- method: 'get'
278
- }
279
- }, params));
280
- this._isTransitioning = false;
281
- this._triggerArray = [];
282
- const toggleList = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].findAll(SELECTOR_DATA_TOGGLE);
283
- for (const elem of toggleList) {
284
- const selector = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].getSelectorFromElement(elem);
285
- const filterElement = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].findAll(selector).filter(foundElement => foundElement === this._element);
286
- if (selector !== null && filterElement.length) {
287
- this._triggerArray.push(elem);
288
- }
289
- }
290
- this._initializeChildren();
291
- if (!this._params.parent) {
292
- this._addAriaAndCollapsedClass(this._triggerArray, this._isShown());
293
- }
294
- if (this._params.toggle) {
295
- this.toggle();
296
- }
297
- }
298
- static get NAME() {
299
- return NAME;
300
- }
301
- static get NAME_KEY() {
302
- return NAME_KEY;
303
- }
304
- toggle(relatedTarget) {
305
- return !this._isShown() ? this.show(relatedTarget) : this.hide();
306
- }
307
- show() {
308
- const _this = this;
309
- if (_this._isTransitioning || _this._isShown()) return;
310
- let activeChildren = [];
311
- if (_this._params.parent) {
312
- activeChildren = this._getFirstLevelChildren(SELECTOR_ACTIVES).filter(element => element !== this._element).map(element => VGCollapse.getOrCreateInstance(element, {
313
- toggle: false
314
- }));
315
- }
316
- if (activeChildren.length && activeChildren[0]._isTransitioning) return;
317
- const startEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_SHOW);
318
- if (startEvent.defaultPrevented) return;
319
- for (const activeInstance of activeChildren) {
320
- activeInstance.hide();
321
- }
322
- _this._element.classList.remove(CLASS_NAME_COLLAPSE);
323
- _this._element.classList.add(CLASS_NAME_COLLAPSING);
324
- _this._element.style.height = 0;
325
- _this._addAriaAndCollapsedClass(_this._triggerArray, true);
326
- _this._isTransitioning = true;
327
- _this._route();
328
- const complete = () => {
329
- _this._isTransitioning = false;
330
- _this._element.classList.remove(CLASS_NAME_COLLAPSING);
331
- _this._element.classList.add(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW);
332
- _this._element.style.height = '';
333
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_SHOWN);
334
- };
335
- _this._queueCallback(complete, _this._element, true);
336
- const scrollSize = `scrollHeight`;
337
- _this._element.style.height = `${_this._element[scrollSize]}px`;
338
- }
339
- hide() {
340
- const _this = this;
341
- if (_this._isTransitioning || !_this._isShown()) return;
342
- const startEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_HIDE);
343
- if (startEvent.defaultPrevented) return;
344
- _this._element.style.height = `${this._element.getBoundingClientRect().height}px`;
345
- (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.reflow)(_this._element);
346
- _this._element.classList.add(CLASS_NAME_COLLAPSING);
347
- _this._element.classList.remove(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW);
348
- for (const trigger of _this._triggerArray) {
349
- const element = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].getElementFromSelector(trigger);
350
- if (element && !_this._isShown(element)) {
351
- _this._addAriaAndCollapsedClass([trigger], false);
352
- }
353
- }
354
- _this._isTransitioning = true;
355
- const complete = () => {
356
- _this._isTransitioning = false;
357
- _this._element.classList.remove(CLASS_NAME_COLLAPSING);
358
- _this._element.classList.add(CLASS_NAME_COLLAPSE);
359
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_HIDDEN);
360
- };
361
- _this._element.style.height = '';
362
- _this._queueCallback(complete, _this._element, true);
363
- }
364
- dispose() {
365
- super.dispose();
366
- }
367
- _isShown(element = this._element) {
368
- return element.classList.contains(CLASS_NAME_SHOW);
369
- }
370
- _addAriaAndCollapsedClass(triggerArray, isOpen) {
371
- if (!triggerArray.length) {
372
- return;
373
- }
374
- for (const element of triggerArray) {
375
- this._changeStateButton(element, isOpen);
376
- }
377
- }
378
- _initializeChildren() {
379
- if (!this._params.parent) return;
380
- const children = this._getFirstLevelChildren(SELECTOR_DATA_TOGGLE);
381
- for (const element of children) {
382
- const selected = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].getElementFromSelector(element);
383
- if (selected) {
384
- this._addAriaAndCollapsedClass([element], this._isShown(selected));
385
- }
386
- }
387
- }
388
- _getFirstLevelChildren(selector) {
389
- const children = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].find(CLASS_NAME_DEEPER_CHILDREN, this._params.parent);
390
- return _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].find(selector, this._params.parent).filter(element => !children.includes(element));
391
- }
392
- _changeStateButton(element, isOpen) {
393
- element.classList.toggle(CLASS_NAME_COLLAPSED, !isOpen);
394
- element.setAttribute('aria-expanded', isOpen);
395
- element.innerHTML = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_4__.Manipulator.get(element, `data-${isOpen ? 'hide' : 'show'}-text`) || element.innerHTML;
396
- }
397
- }
398
-
399
- /**
400
- * Data API implementation
401
- */
402
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
403
- if (event.target.tagName === 'A' || event.delegateTarget && event.delegateTarget.tagName === 'A') {
404
- event.preventDefault();
405
- }
406
- _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].getMultipleElementsFromSelector(this).forEach(function (element) {
407
- VGCollapse.getOrCreateInstance(element, {
408
- toggle: false
409
- }).toggle();
410
- });
411
- });
412
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGCollapse);
413
-
414
- /***/ }),
415
-
416
- /***/ "./app/modules/vgdropdown/js/vgdropdown.js":
417
- /*!*************************************************!*\
418
- !*** ./app/modules/vgdropdown/js/vgdropdown.js ***!
419
- \*************************************************/
420
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
421
-
422
- __webpack_require__.r(__webpack_exports__);
423
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
424
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
425
- /* harmony export */ });
426
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
427
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
428
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
429
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
430
- /* harmony import */ var _utils_js_components_placement__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/components/placement */ "./app/utils/js/components/placement.js");
431
-
432
-
433
-
434
-
435
-
436
- const NAME = 'dropdown';
437
- const NAME_KEY = 'vg.dropdown';
438
- const CLASS_NAME_SHOW = 'show';
439
- const CLASS_NAME_FADE = 'fade';
440
- const TARGET_CONTAINER = 'vg-dropdown-content';
441
- const PARENT_CONTAINER = 'vg-dropdown';
442
- const SELECTOR_DATA_TOGGLE = '[data-vg-toggle="dropdown"]';
443
- const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
444
- const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
445
- const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
446
- const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
447
- const EVENT_KEYUP_DATA_API = `keyup.${NAME_KEY}.data.api`;
448
- const EVENT_KEYDOWN_DATA_API = `keydown.${NAME_KEY}.data.api`;
449
- const EVENT_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
450
- const EVENT_MOUSEOVER_DATA_API = `mouseover.${NAME_KEY}.data.api`;
451
- const EVENT_MOUSEOUT_DATA_API = `mouseout.${NAME_KEY}.data.api`;
452
- class VGDropdown extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
453
- constructor(element, params) {
454
- super(element, params);
455
- let defaultParams = {
456
- offset: [0, 2],
457
- over: false,
458
- backdrop: true,
459
- overflow: true,
460
- keyboard: true,
461
- placement: 'bottom',
462
- timeoutAnimation: 350,
463
- hover: false,
464
- ajax: {
465
- route: '',
466
- target: '',
467
- method: 'get'
468
- },
469
- animation: {
470
- enable: false,
471
- in: 'animate__flipInY',
472
- out: 'animate__flipOutY',
473
- delay: 800
474
- }
475
- };
476
- if ('offset' in params && Array.isArray(params.offset)) {
477
- defaultParams.offset = params.offset;
478
- }
479
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_3__.mergeDeepObject)(defaultParams, params));
480
- this._parent = this._element.parentNode;
481
- this._drop = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_2__["default"].find('.' + TARGET_CONTAINER, this._parent);
482
- this._isPlacement = false;
483
- this._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;
484
- this._animation(this._drop, VGDropdown.NAME_KEY, this._params.animation);
485
- }
486
- static get NAME() {
487
- return NAME;
488
- }
489
- static get NAME_KEY() {
490
- return NAME_KEY;
491
- }
492
- toggle() {
493
- return this._isShown() ? this.hide() : this.show();
494
- }
495
- show() {
496
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_3__.isDisabled)(this._element) || this._isShown()) return;
497
- const relatedTarget = {
498
- relatedTarget: this._element
499
- };
500
- const showEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].trigger(this._element, EVENT_KEY_SHOW, relatedTarget);
501
- if (showEvent.defaultPrevented) return;
502
- if ('ontouchstart' in document.documentElement) {
503
- for (const element of [].concat(...document.body.children)) {
504
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(element, 'mouseover', _utils_js_functions__WEBPACK_IMPORTED_MODULE_3__.noop);
505
- }
506
- }
507
- this._route();
508
- this._element.setAttribute('aria-expanded', true);
509
- this._element.classList.add(CLASS_NAME_SHOW);
510
- this._drop.classList.add(CLASS_NAME_SHOW);
511
- this._setPlacement();
512
- const completeCallBack = () => {
513
- this._drop.classList.add(CLASS_NAME_FADE);
514
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].trigger(this._element, EVENT_KEY_SHOWN, relatedTarget);
515
- };
516
- this._queueCallback(completeCallBack, this._drop, true, 50);
517
- }
518
- hide() {
519
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_3__.isDisabled)(this._element) || !this._isShown()) {
520
- return;
521
- }
522
- const relatedTarget = {
523
- relatedTarget: this._element
524
- };
525
- this._completeHide(relatedTarget);
526
- }
527
- dispose() {
528
- return super.dispose();
529
- }
530
- _isShown() {
531
- return this._element.classList.contains(CLASS_NAME_SHOW);
532
- }
533
- _completeHide(relatedTarget) {
534
- const hideEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].trigger(this._element, EVENT_KEY_HIDE, relatedTarget);
535
- if (hideEvent.defaultPrevented) {
536
- return;
537
- }
538
- if ('ontouchstart' in document.documentElement) {
539
- for (const element of [].concat(...document.body.children)) {
540
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].off(element, 'mouseover', _utils_js_functions__WEBPACK_IMPORTED_MODULE_3__.noop);
541
- }
542
- }
543
- this._drop.classList.remove(CLASS_NAME_FADE);
544
- this._element.classList.remove(CLASS_NAME_SHOW);
545
- this._element.setAttribute('aria-expanded', 'false');
546
- setTimeout(() => {
547
- const completeCallback = () => {
548
- this._drop.classList.remove(CLASS_NAME_SHOW);
549
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].trigger(this._element, EVENT_KEY_HIDDEN, relatedTarget);
550
- };
551
- this._queueCallback(completeCallback, this._parent, true, 10);
552
- }, this._params.animation.delay);
553
- }
554
-
555
- // TODO class Placement isn't done
556
- _setPlacement() {
557
- const _this = this;
558
- if (!_this._isPlacement) {
559
- let placement = new _utils_js_components_placement__WEBPACK_IMPORTED_MODULE_4__["default"]({
560
- element: this._parent,
561
- drop: this._drop
562
- })._getPlacement();
563
- if (placement.isFixed) {
564
- _this._drop.style.position = 'fixed';
565
- _this._drop.style.transform = 'translateY(-20%)'; // todo this is костыль поfixить
566
- }
567
- _this._drop.style.left = placement.left + 'px';
568
- _this._drop.style.top = placement.top + 'px';
569
- }
570
- if (_this._params.offset) {
571
- _this._drop.style.paddingTop = _this._params.offset[1] + 'px';
572
- _this._drop.style.paddingRight = _this._params.offset[0] + 'px';
573
- }
574
- _this._isPlacement = true;
575
- }
576
- static init(element, params = {}) {
577
- const instance = VGDropdown.getOrCreateInstance(element, params);
578
- if (instance._params.hover) {
579
- let currentElem = null;
580
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(instance._parent, EVENT_MOUSEOVER_DATA_API, function (event) {
581
- if (currentElem) return;
582
- VGDropdown.hideOpenToggles(event);
583
- let target = event.target.closest('.' + PARENT_CONTAINER);
584
- if (!target) return;
585
- if (!instance._parent.contains(target)) return;
586
- currentElem = target;
587
- instance.show();
588
- });
589
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(instance._parent, EVENT_MOUSEOUT_DATA_API, function (event) {
590
- if (!currentElem) return;
591
- let relatedTarget = event.relatedTarget;
592
- while (relatedTarget) {
593
- if (relatedTarget === currentElem) return;
594
- relatedTarget = relatedTarget.parentNode;
595
- }
596
- currentElem = null;
597
- instance._completeHide({
598
- relatedTarget: instance._element
599
- });
600
- });
601
- } else {
602
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(document, EVENT_KEYUP_DATA_API, SELECTOR_DATA_TOGGLE, VGDropdown.keydownHandler);
603
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(document, EVENT_KEYDOWN_DATA_API, '.' + TARGET_CONTAINER, VGDropdown.keydownHandler);
604
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(document, EVENT_KEYUP_DATA_API, VGDropdown.clearDrops);
605
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(document, EVENT_CLICK_DATA_API, VGDropdown.clearDrops);
606
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(element, EVENT_CLICK_DATA_API, function (event) {
607
- event.preventDefault();
608
- instance.toggle();
609
- });
610
- }
611
- }
612
- static hideOpenToggles(event) {
613
- const openToggles = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_2__["default"].findAll('[data-vg-toggle="dropdown"]:not(.disabled):not(:disabled).show');
614
- for (const toggle of openToggles) {
615
- const context = VGDropdown.getInstance(toggle);
616
- if (!context) {
617
- continue;
618
- }
619
- if (event.target.closest('.' + TARGET_CONTAINER) === context._drop) {
620
- return;
621
- }
622
- const composedPath = event.composedPath();
623
- if (composedPath.includes(context._element)) {
624
- continue;
625
- }
626
- const relatedTarget = {
627
- relatedTarget: context._element
628
- };
629
- if (event.type === 'click') {
630
- relatedTarget.clickEvent = event;
631
- }
632
- context._completeHide(relatedTarget);
633
- }
634
- }
635
- static keydownHandler(event) {
636
- const isInput = /input|textarea/i.test(event.target.tagName);
637
- const isEscapeEvent = event.key === 'Escape';
638
- const isUpOrDownEvent = ['ArrowUp', 'ArrowDown'].includes(event.key);
639
- if (!isUpOrDownEvent && !isEscapeEvent) {
640
- return;
641
- }
642
- if (isInput && !isEscapeEvent) {
643
- return;
644
- }
645
- event.preventDefault();
646
- const getToggleButton = this.matches(SELECTOR_DATA_TOGGLE) ? this : _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_2__["default"].find(SELECTOR_DATA_TOGGLE, event.delegateTarget.parentNode);
647
- const instance = VGDropdown.getOrCreateInstance(getToggleButton);
648
- if (isUpOrDownEvent) {
649
- event.stopPropagation();
650
- instance.show();
651
- return;
652
- }
653
- if (instance._isShown()) {
654
- event.stopPropagation();
655
- instance.hide();
656
- getToggleButton.focus();
657
- }
658
- }
659
- static clearDrops(event) {
660
- if (event.button === 2 || event.type === 'keyup' && event.key !== 'Tab') {
661
- return;
662
- }
663
- VGDropdown.hideOpenToggles(event);
664
- }
665
- }
666
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGDropdown);
667
-
668
- /***/ }),
669
-
670
- /***/ "./app/modules/vgformsender/js/vgformsender.js":
671
- /*!*****************************************************!*\
672
- !*** ./app/modules/vgformsender/js/vgformsender.js ***!
673
- \*****************************************************/
674
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
675
-
676
- __webpack_require__.r(__webpack_exports__);
677
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
678
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
679
- /* harmony export */ });
680
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
681
- /* harmony import */ var _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/dom/manipulator */ "./app/utils/js/dom/manipulator.js");
682
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
683
- /* harmony import */ var _vgmodal_js_vgmodal__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../vgmodal/js/vgmodal */ "./app/modules/vgmodal/js/vgmodal.js");
684
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
685
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
686
- /* harmony import */ var _vgcollapse_js_vgcollapse__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../vgcollapse/js/vgcollapse */ "./app/modules/vgcollapse/js/vgcollapse.js");
687
- /* harmony import */ var _module_fn__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../module-fn */ "./app/modules/module-fn.js");
688
- /* harmony import */ var _utils_js_components_backdrop__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../../../utils/js/components/backdrop */ "./app/utils/js/components/backdrop.js");
689
-
690
-
691
-
692
-
693
-
694
-
695
-
696
-
697
-
698
-
699
- /**
700
- * Constants
701
- */
702
- const NAME = 'form-sender';
703
- const NAME_KEY = 'vg.fs';
704
-
705
- /**
706
- * Constants Events
707
- */
708
- const EVENT_KEY_SUCCESS = 'vg.fs.success';
709
- const EVENT_KEY_ERROR = 'vg.fs.error';
710
- const EVENT_KEY_BEFORE = 'vg.fs.before';
711
- const EVENT_SUBMIT_DATA_API = `submit.${NAME_KEY}.data.api`;
712
- class VGFormSender extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
713
- constructor(element, params = {}) {
714
- super(element, params);
715
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.mergeDeepObject)({
716
- redirect: '',
717
- validate: false,
718
- submit: false,
719
- fields: [],
720
- alert: {
721
- enabled: true,
722
- type: 'modal'
723
- },
724
- ajax: {
725
- route: '',
726
- target: '',
727
- method: 'get'
728
- },
729
- classes: {
730
- general: 'vg-form-sender',
731
- alertCollapse: 'vg-form-sender-collapse',
732
- alertModal: 'vg-form-sender-modal',
733
- validation: 'needs-validation',
734
- wasValidate: 'was-validated'
735
- }
736
- }, params));
737
- this._params.ajax.route = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(this._element, 'action').toLowerCase();
738
- this._params.ajax.method = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(this._element, 'method').toLowerCase();
739
- this._button = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__["default"].find('[type="submit"]', this._element) || _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__["default"].find('[form="' + this._element.id + '"]') || null;
740
- this._params.isBtnText = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(this._element, 'data-btn-text') !== 'false';
741
- this._params.isJsonParse = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(this._element, 'data-json-parse') !== 'false';
742
- this._params.isShowPass = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(this._element, 'data-show-pass') === 'true';
743
- }
744
- static get NAME() {
745
- return NAME;
746
- }
747
- static get NAME_KEY() {
748
- return NAME_KEY;
749
- }
750
- build() {
751
- this._element.classList.add(this._params.classes.general);
752
- if (this._params.validate) {
753
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.set(this._element, 'novalidate', '');
754
- this._element.classList.add(this._params.classes.validation);
755
- }
756
-
757
- // TODO сделать добавление глаза если есть ввод пароля
758
-
759
- return this;
760
- }
761
- request(data, event) {
762
- const _this = this;
763
- _this._alertBefore();
764
- _this._params.ajax.data = data;
765
- _this._route(function (status, data) {
766
- _this._element.classList.remove('was-validated');
767
- if (_this._params.alert.enabled) {
768
- if (typeof status === 'string' && status === 'error') {
769
- _this._alertError(event, data);
770
- } else if (typeof status === 'string' && status === 'success') {
771
- _this._alertSuccess(event, data);
772
- }
773
- }
774
- if (_this._params.redirect) {
775
- window.location.href = _this._params.redirect;
776
- }
777
- });
778
- }
779
- _alertBefore() {
780
- const _this = this;
781
- if (_this._params.alert.type === 'collapse') {
782
- [...document.getElementsByClassName(_this._params.classes.alertCollapse)].forEach(function (element) {
783
- if (element && element.classList.contains('show')) {
784
- _vgcollapse_js_vgcollapse__WEBPACK_IMPORTED_MODULE_6__["default"].getOrCreateInstance(element, {
785
- toggle: false
786
- }).hide();
787
- }
788
- });
789
- }
790
- _this._statusButton('before');
791
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_BEFORE, _this);
792
- }
793
- _alertError(event, data) {
794
- const _this = this;
795
- _this._statusButton('after');
796
- _this._jsonParse(data, 'error');
797
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_ERROR, [event, _this, data]);
798
- }
799
- _alertSuccess(event, data) {
800
- const _this = this;
801
- _this._statusButton('after');
802
- _this._jsonParse(data, 'success');
803
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_SUCCESS, [event, _this, data]);
804
- }
805
- _statusButton(status) {
806
- const _this = this;
807
- if (!_this._button) return;
808
- let btnSubmitText = _this._button,
809
- btnText = {
810
- send: 'Отправляем...',
811
- text: 'Отправить'
812
- };
813
- if (_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.has(_this._button, 'data-spinner') && status === 'before') {
814
- _this._button.insertAdjacentHTML('afterbegin', '<span class="spinner-border spinner-border-sm me-2"></span>');
815
- }
816
- if (_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.has(_this._button, 'data-text')) {
817
- btnText.text = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(_this._button, 'data-text');
818
- } else {
819
- let $btnText = _this._button.querySelector('[data-text]');
820
- if ($btnText) {
821
- btnText.text = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get($btnText, 'data-text');
822
- btnSubmitText = $btnText;
823
- }
824
- }
825
- if (_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.has(_this._button, 'data-text-send')) {
826
- btnText.send = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(_this._button, 'data-text-send');
827
- } else {
828
- let $btnTextSend = _this._button.querySelector('[data-text-send]');
829
- if ($btnTextSend) {
830
- btnText.send = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get($btnTextSend, 'data-text-send');
831
- btnSubmitText = $btnTextSend;
832
- }
833
- }
834
- if (status === 'before') {
835
- if (_this._params.isBtnText) {
836
- btnSubmitText.innerHTML = btnText.send;
837
- }
838
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.set(_this._button, 'disabled', 'disabled');
839
- }
840
- if (status === 'after') {
841
- if (_this._params.isBtnText) {
842
- btnSubmitText.innerHTML = btnText.text;
843
- }
844
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.remove(_this._button, 'disabled');
845
- let spinner = _this._button.querySelector('.spinner-border');
846
- if (spinner) spinner.remove();
847
- }
848
- }
849
- _jsonParse(data, status) {
850
- const _this = this;
851
- if (_this._params.isJsonParse && typeof data === 'string') {
852
- let parserData = {};
853
- try {
854
- parserData = JSON.parse(data);
855
- _this.alert(parserData, status);
856
- } catch (e) {
857
- _this.alert(data, status);
858
- }
859
- } else {
860
- _this.alert(data, status);
861
- }
862
- }
863
- alert(data, status) {
864
- const _this = this;
865
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.isObject)(data)) {
866
- if ('code' in data && data.code && data.code === 200) {
867
- if ('response' in data && data.response) {
868
- let response = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.normalizeData)(data.response);
869
- if (typeof response === 'string') {
870
- if (response.indexOf("Parse error") !== -1 || response.indexOf("syntax error") !== -1) {
871
- status = 'error';
872
- data = {
873
- response: {
874
- title: 'Error',
875
- message: 'Something went wrong, please repeat later'
876
- },
877
- text: 'Something went wrong, please repeat later'
878
- };
879
- }
880
- } else {
881
- if ('errors' in response && (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.normalizeData)(response.errors)) {
882
- status = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.normalizeData)(response.errors) ? 'error' : 'success';
883
- }
884
- }
885
- }
886
- }
887
- }
888
- if (!_this._params.alert.enabled) {
889
- return;
890
- }
891
- if (_this._params.alert.type === 'modal') {
892
- _this._alertModal(data, status);
893
- }
894
- if (_this._params.alert.type === 'collapse') {
895
- _this._alertCollapse(data, status);
896
- }
897
- }
898
- _alertModal(data, status) {
899
- const _this = this;
900
-
901
- // Есть ли открытые модалки, закрываем
902
- [...document.getElementsByClassName('modal')].forEach(function (element) {
903
- if (element && element.classList.contains('show')) {
904
- let mBS = bootstrap.Modal.getOrCreateInstance(element);
905
- mBS.hide();
906
- }
907
- });
908
- [...document.getElementsByClassName('vg-modal')].forEach(function (element) {
909
- if (element && element.classList.contains('show')) {
910
- const mVG = _vgmodal_js_vgmodal__WEBPACK_IMPORTED_MODULE_3__["default"].getOrCreateInstance(element);
911
- mVG.hide();
912
- }
913
- });
914
- let id = _this._params.classes.general + '-' + (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.makeRandomString)();
915
- let $modal = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__["default"].find('.' + _this._params.classes.alertModal);
916
- if ($modal) $modal.remove();
917
- setTimeout(() => {
918
- _vgmodal_js_vgmodal__WEBPACK_IMPORTED_MODULE_3__["default"].init(id, {
919
- classes: {
920
- alert: _this._params.classes.alertModal
921
- }
922
- }, function (self) {
923
- let element = self._element;
924
- element.classList.add(_this._params.classes.alertModal);
925
- let $body = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__["default"].find('.vg-modal-body', element);
926
- if ($body) $body.append(_this.setDataRelationStatus(element, status, data, 'modal'));
927
- self.toggle();
928
- });
929
- }, 800);
930
- }
931
- _alertCollapse(data, status) {
932
- const _this = this;
933
- let $collapse = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__["default"].find('.' + _this._params.classes.alertCollapse);
934
- if (!$collapse) {
935
- $collapse = document.createElement('div');
936
- $collapse.classList.add(_this._params.classes.alertCollapse);
937
- $collapse.classList.add('vg-collapse');
938
- $collapse.id = _this._params.classes.general + '-' + (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.makeRandomString)();
939
- $collapse.append(_this.setDataRelationStatus($collapse, status, data, 'collapse'));
940
- _this._element.prepend($collapse);
941
- }
942
- _vgcollapse_js_vgcollapse__WEBPACK_IMPORTED_MODULE_6__["default"].getOrCreateInstance($collapse, {
943
- toggle: false
944
- }).toggle();
945
- }
946
- setDataRelationStatus($element, status, data, type) {
947
- let $alert = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__["default"].find('.vg-alert-' + status, $element);
948
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.isObject)(data)) {
949
- if (status === 'error') {
950
- if ('code' in data && data.code !== 200) {
951
- if ('text' in data && !data.text) {
952
- data.text = 'Something went wrong, please repeat later';
953
- switch (data.code) {
954
- case 400:
955
- data.text = 'Bad Request';
956
- break;
957
- case 401:
958
- data.text = 'Unauthorized';
959
- break;
960
- case 403:
961
- data.text = 'Unauthorized';
962
- break;
963
- case 413:
964
- data.text = 'Forbidden';
965
- break;
966
- case 404:
967
- data.text = 'Not Found';
968
- break;
969
- case 422:
970
- data.text = 'Unprocessable Entity';
971
- break;
972
- case 500:
973
- data.text = 'Internal Server Error';
974
- break;
975
- case 504:
976
- data.text = 'Gateway Timeout';
977
- break;
978
- }
979
- }
980
- }
981
- }
982
- if ('response' in data) {
983
- let response = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.normalizeData)(data.response),
984
- title = '',
985
- txt = '',
986
- code = '';
987
- if (typeof response !== 'string') {
988
- if (!('view' in response)) {
989
- if ('title' in response) title = response.title;
990
- if (status === 'error' && data.code !== 200) {
991
- code = ' ' + data.text + ' (' + data.code + ')';
992
- }
993
- txt += '<h4 class="vg-alert-content--title">' + title + code + '</h4>';
994
- if ('message' in response) {
995
- txt += '<div class="vg-alert-content--message">' + response.message + '</div>';
996
- }
997
- if ('errors' in response) {
998
- let errors = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.normalizeData)(response.errors) || null;
999
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.isObject)(errors)) {
1000
- for (const error in errors) {
1001
- if (Array.isArray(errors[error])) {
1002
- errors[error].forEach(function (t) {
1003
- txt += '<div>' + t + '</div>';
1004
- });
1005
- } else {
1006
- txt = '<div>' + errors[error] + '</div>';
1007
- }
1008
- }
1009
- }
1010
- }
1011
- data = {
1012
- view: txt
1013
- };
1014
- }
1015
- } else {
1016
- data.view = response;
1017
- }
1018
- }
1019
- }
1020
- if (!$alert) {
1021
- $alert = document.createElement('div');
1022
- $alert.classList.add('vg-alert', 'vg-alert-' + status, 'vg-alert-' + type);
1023
- let content = document.createElement('div');
1024
- content.classList.add('vg-alert-content');
1025
- let icon = document.createElement('div');
1026
- icon.classList.add('vg-alert-content--icon');
1027
- let i = document.createElement('i');
1028
- i.innerHTML = (0,_module_fn__WEBPACK_IMPORTED_MODULE_7__.getSVG)(status);
1029
- icon.append(i);
1030
- content.append(icon);
1031
- let text = document.createElement('div');
1032
- text.classList.add('vg-alert-content--text');
1033
- text.innerHTML = data.view;
1034
- content.append(text);
1035
- $alert.append(content);
1036
- } else {
1037
- let text = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_5__["default"].find('.vg-alert-content--text', $alert);
1038
- text.innerHTML = data.view;
1039
- }
1040
- return $alert;
1041
- }
1042
-
1043
- /**
1044
- * Инициализация
1045
- * @param element
1046
- * @param params
1047
- */
1048
- static init(element, params = {}) {
1049
- const instance = VGFormSender.getOrCreateInstance(element, params);
1050
- instance.build();
1051
- }
1052
- }
1053
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(document, EVENT_SUBMIT_DATA_API, function (event) {
1054
- if (!_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.has(event.target, 'data-vgformsender')) {
1055
- return;
1056
- }
1057
- const instance = VGFormSender.getOrCreateInstance(event.target, {});
1058
- if (!instance) {
1059
- return;
1060
- }
1061
- if (instance._params.validate) {
1062
- if (!instance._element.checkValidity()) {
1063
- event.preventDefault();
1064
- event.stopPropagation();
1065
- instance._element.classList.add(instance._params.classes.wasValidate);
1066
- return false;
1067
- }
1068
- }
1069
- const collectData = function (data, fields) {
1070
- for (let name in fields) {
1071
- if (typeof fields[name] === 'object') {
1072
- for (let key in fields[name]) {
1073
- let arr = Object.keys(fields[name][key]).map(function (i) {
1074
- return fields[name][key][i];
1075
- });
1076
- data.append(name, arr);
1077
- }
1078
- } else {
1079
- data.append(name, fields[name]);
1080
- }
1081
- }
1082
- return data;
1083
- };
1084
- if (!instance._params.submit) {
1085
- event.preventDefault();
1086
- let data = new FormData(instance._element);
1087
-
1088
- // TODO доделать
1089
- /*if (Array.isArray(instance._params.ajax.fields) && instance._params.ajax.fields.length) {
1090
- data = collectData(data, instance._params.ajax.fields);
1091
- }*/
1092
-
1093
- return instance.request(data, event);
1094
- }
1095
- });
1096
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGFormSender);
1097
-
1098
- /***/ }),
1099
-
1100
- /***/ "./app/modules/vglawcookie/js/vglawcookie.js":
1101
- /*!***************************************************!*\
1102
- !*** ./app/modules/vglawcookie/js/vglawcookie.js ***!
1103
- \***************************************************/
1104
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1105
-
1106
- __webpack_require__.r(__webpack_exports__);
1107
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1108
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
1109
- /* harmony export */ });
1110
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
1111
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
1112
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
1113
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
1114
- /* harmony import */ var _utils_js_dom_cookie__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/dom/cookie */ "./app/utils/js/dom/cookie.js");
1115
- /* harmony import */ var _module_fn__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../module-fn */ "./app/modules/module-fn.js");
1116
-
1117
-
1118
-
1119
-
1120
-
1121
-
1122
-
1123
- /**
1124
- * Constants
1125
- */
1126
- const NAME = 'lawcookie';
1127
- const NAME_KEY = 'vg.lawcookie';
1128
- const CLASS_NAME_SHOW = 'show';
1129
- const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
1130
- const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
1131
- const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
1132
- const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
1133
- const SELECTOR_DATA_TOGGLE = '[data-vg-toggle="lawcookie"]';
1134
- const SELECTOR_DATA_TOGGLE_CLEAR = '[data-vg-toggle="lawcookie-clear"]';
1135
- const EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
1136
- class VGLawCookie extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
1137
- static sParams = {};
1138
- constructor(element, params = {}) {
1139
- super(element, params);
1140
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.mergeDeepObject)({
1141
- storage: 'local',
1142
- // cookie or local
1143
- delay: 500,
1144
- cookie: {
1145
- name: 'lawCookie',
1146
- value: 'yes',
1147
- attributes: {}
1148
- },
1149
- animation: {
1150
- enable: true,
1151
- in: 'animate__fadeInUp',
1152
- out: 'animate__fadeOutDown',
1153
- delay: 800
1154
- },
1155
- ajax: {
1156
- route: '',
1157
- target: '',
1158
- method: 'get'
1159
- }
1160
- }, params));
1161
- VGLawCookie.sParams = this._params;
1162
- this._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;
1163
- this._animation(this._element, VGLawCookie.NAME_KEY, this._params.animation);
1164
- }
1165
- static get NAME() {
1166
- return NAME;
1167
- }
1168
- static get NAME_KEY() {
1169
- return NAME_KEY;
1170
- }
1171
- toggle() {
1172
- return !this._isShown() ? this.show() : this.hide();
1173
- }
1174
- _isShown() {
1175
- return this.storage().get();
1176
- }
1177
- show() {
1178
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(this._element)) return;
1179
- const showEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(this._element, EVENT_KEY_SHOW, {});
1180
- if (showEvent.defaultPrevented) return;
1181
- this._element.classList.add(CLASS_NAME_SHOW);
1182
- const completeCallBack = () => {
1183
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(this._element, EVENT_KEY_SHOWN, {});
1184
- };
1185
- this._queueCallback(completeCallBack, this._element, true, this._params.delay);
1186
- }
1187
- hide() {
1188
- const hideEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(this._element, EVENT_KEY_HIDE);
1189
- if (hideEvent.defaultPrevented) return;
1190
- setTimeout(() => {
1191
- this._element.classList.remove(CLASS_NAME_SHOW);
1192
- const completeCallback = () => _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(this._element, EVENT_KEY_HIDDEN);
1193
- this._queueCallback(completeCallback, this._element, true);
1194
- }, this._params.animation.delay);
1195
- }
1196
- storage() {
1197
- this._storage = {
1198
- isCookie: this._params.storage === 'cookie',
1199
- storage: this._params.storage === 'cookie' ? _utils_js_dom_cookie__WEBPACK_IMPORTED_MODULE_4__["default"] : localStorage,
1200
- name: this._params.cookie.name,
1201
- value: this._params.cookie.value,
1202
- attributes: this._params.cookie.attributes
1203
- };
1204
- return this;
1205
- }
1206
- get() {
1207
- if (this._storage.isCookie) {
1208
- return this._storage.storage.get(this._storage.name);
1209
- } else {
1210
- return this._storage.storage.getItem(this._storage.name);
1211
- }
1212
- }
1213
- set() {
1214
- if (this._storage.isCookie) {
1215
- this._storage.storage.set(this._storage.name, this._storage.value, this._storage.attributes);
1216
- } else {
1217
- this._storage.storage.setItem(this._storage.name, this._storage.value);
1218
- }
1219
- }
1220
- dispose() {
1221
- super.dispose();
1222
- }
1223
- static reset() {
1224
- _utils_js_dom_cookie__WEBPACK_IMPORTED_MODULE_4__["default"].remove(VGLawCookie.sParams.cookie.name);
1225
- localStorage.clear();
1226
- location.reload();
1227
- }
1228
-
1229
- /**
1230
- * Инициализация
1231
- * @param element
1232
- * @param params
1233
- */
1234
- static init(element, params = {}) {
1235
- const instance = VGLawCookie.getOrCreateInstance(element, params);
1236
- instance.toggle();
1237
- }
1238
- }
1239
- (0,_module_fn__WEBPACK_IMPORTED_MODULE_5__.dismissTrigger)(VGLawCookie);
1240
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
1241
- if (['A', 'AREA'].includes(this.tagName)) {
1242
- event.preventDefault();
1243
- }
1244
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(this)) return;
1245
- const element = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].find('#vg-lawcookie');
1246
- if (!element) return;
1247
- const instance = VGLawCookie.getOrCreateInstance(element);
1248
- instance.storage().set();
1249
- instance.hide();
1250
- });
1251
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE_CLEAR, function (event) {
1252
- if (['A', 'AREA'].includes(this.tagName)) {
1253
- event.preventDefault();
1254
- }
1255
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(this)) return;
1256
- const element = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].find('#vg-lawcookie');
1257
- if (!element) return;
1258
- const instance = VGLawCookie.getOrCreateInstance(element);
1259
- instance.dispose();
1260
- location.reload();
1261
- });
1262
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGLawCookie);
1263
-
1264
- /***/ }),
1265
-
1266
- /***/ "./app/modules/vgmodal/js/vgmodal.js":
1267
- /*!*******************************************!*\
1268
- !*** ./app/modules/vgmodal/js/vgmodal.js ***!
1269
- \*******************************************/
1270
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1271
-
1272
- __webpack_require__.r(__webpack_exports__);
1273
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1274
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
1275
- /* harmony export */ });
1276
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
1277
- /* harmony import */ var _utils_js_components_scrollbar__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/components/scrollbar */ "./app/utils/js/components/scrollbar.js");
1278
- /* harmony import */ var _utils_js_components_backdrop__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/components/backdrop */ "./app/utils/js/components/backdrop.js");
1279
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
1280
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
1281
- /* harmony import */ var _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../../utils/js/dom/manipulator */ "./app/utils/js/dom/manipulator.js");
1282
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
1283
- /* harmony import */ var _module_fn__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../module-fn */ "./app/modules/module-fn.js");
1284
- /* harmony import */ var _utils_js_components_params__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../../../utils/js/components/params */ "./app/utils/js/components/params.js");
1285
-
1286
-
1287
-
1288
-
1289
-
1290
-
1291
-
1292
-
1293
-
1294
-
1295
- /**
1296
- * Constants
1297
- */
1298
- const NAME = 'modal';
1299
- const NAME_KEY = 'vg.modal';
1300
- const ESCAPE_KEY = 'Escape';
1301
- const OPEN_SELECTOR = '.vg-modal.show';
1302
- const SELECTOR_DIALOG = '.vg-modal-dialog';
1303
- const SELECTOR_MODAL_BODY = '.vg-modal-body';
1304
- const SELECTOR_DATA_TOGGLE = '[data-vg-toggle="modal"]';
1305
- const CLASS_NAME_OPEN = 'vg-modal-open';
1306
- const CLASS_NAME_SHOW = 'show';
1307
- const CLASS_NAME_FADE = 'fade';
1308
- const CLASS_NAME_STATIC = 'vg-modal-static';
1309
- const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
1310
- const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
1311
- const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
1312
- const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
1313
- const EVENT_KEY_RESIZE = `${NAME_KEY}.resize`;
1314
- const EVENT_KEY_KEYDOWN_DISMISS = `keydown.dismiss.${NAME_KEY}`;
1315
- const EVENT_KEY_HIDE_PREVENTED = `hidePrevented.${NAME_KEY}`;
1316
- const EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
1317
- const EVENT_KEY_MOUSEDOWN_DISMISS = `mousedown.dismiss${NAME_KEY}`;
1318
- const EVENT_KEY_CLICK_DISMISS = `click.dismiss${NAME_KEY}`;
1319
- class VGModal extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
1320
- constructor(element, params = {}) {
1321
- super(element, params);
1322
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_6__.mergeDeepObject)({
1323
- backdrop: true,
1324
- focus: true,
1325
- keyboard: true,
1326
- fields: [],
1327
- ajax: {
1328
- route: '',
1329
- target: '',
1330
- method: 'get',
1331
- loader: false
1332
- },
1333
- animation: {
1334
- enable: false,
1335
- in: 'animate__rollIn',
1336
- out: 'animate__rollOut',
1337
- delay: 800
1338
- },
1339
- classes: {
1340
- general: 'vg-modal',
1341
- dialog: 'vg-modal-dialog',
1342
- content: 'vg-modal-content',
1343
- header: 'vg-modal-header',
1344
- title: 'vg-modal-title',
1345
- body: 'vg-modal-body',
1346
- footer: 'vg-modal-footer'
1347
- }
1348
- }, params));
1349
- this._button = null;
1350
- this._dialog = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].find(SELECTOR_DIALOG, this._element);
1351
- this._isShown = false;
1352
- this._isTransitioning = false;
1353
- this._scrollBar = new _utils_js_components_scrollbar__WEBPACK_IMPORTED_MODULE_1__["default"]();
1354
- this._addEventListeners();
1355
- this._dismissElement();
1356
- this._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;
1357
- this._animation(this._element, VGModal.NAME_KEY, this._params.animation);
1358
- }
1359
- static get NAME() {
1360
- return NAME;
1361
- }
1362
- static get NAME_KEY() {
1363
- return NAME_KEY;
1364
- }
1365
- static init(element, params, callback) {
1366
- VGModal.build(element, params, callback);
1367
- }
1368
- static build(id, params, callback) {
1369
- if (typeof id !== "string") return;
1370
- let _element = document.createElement('div');
1371
- _element.classList.add('vg-modal', 'fade');
1372
- _element.id = id;
1373
- let dialog = document.createElement('div');
1374
- dialog.classList.add('vg-modal-dialog');
1375
- let content = document.createElement('div');
1376
- content.classList.add('vg-modal-content');
1377
- let btnClose = document.createElement('button');
1378
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_5__.Manipulator.set(btnClose, 'type', 'button');
1379
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_5__.Manipulator.set(btnClose, 'data-vg-dismiss', 'modal');
1380
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_5__.Manipulator.set(btnClose, 'data-vg-target', '#' + id);
1381
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_5__.Manipulator.set(btnClose, 'aria-label', 'close');
1382
- btnClose.classList.add('vg-btn-close');
1383
- content.append(btnClose);
1384
- let body = document.createElement('div');
1385
- body.classList.add('vg-modal-body');
1386
- content.append(body);
1387
- dialog.append(content);
1388
- _element.append(dialog);
1389
- document.body.append(_element);
1390
- const modal = VGModal.getOrCreateInstance(_element, params);
1391
- (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_6__.execute)(callback, [modal]);
1392
- }
1393
- toggle(relatedTarget) {
1394
- return !this._isShown ? this.show(relatedTarget) : this.hide();
1395
- }
1396
- show(relatedTarget) {
1397
- const _this = this;
1398
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_6__.isDisabled)(_this._element)) return;
1399
- this._params = this._getParams(relatedTarget, this._params);
1400
- this._route();
1401
- const showEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].trigger(this._element, EVENT_KEY_SHOW, {
1402
- relatedTarget
1403
- });
1404
- if (showEvent.defaultPrevented) return;
1405
- this._isShown = true;
1406
- this._isTransitioning = true;
1407
- this._scrollBar.hide();
1408
- document.body.classList.add(CLASS_NAME_OPEN);
1409
- this._addFieldsInModal(relatedTarget);
1410
- this._adjustDialog();
1411
- _utils_js_components_backdrop__WEBPACK_IMPORTED_MODULE_2__["default"].show(() => this._showElement(relatedTarget));
1412
- }
1413
- hide() {
1414
- if (!this._isShown || this._isTransitioning) return;
1415
- const hideEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].trigger(this._element, EVENT_KEY_HIDE);
1416
- if (hideEvent.defaultPrevented) return;
1417
- this._isShown = false;
1418
- this._isTransitioning = true;
1419
- setTimeout(() => {
1420
- this._element.classList.remove(CLASS_NAME_SHOW);
1421
- this._queueCallback(() => this._hideModal(), this._element, this._isAnimatedFade());
1422
- }, this._params.animation.delay);
1423
- }
1424
- _hideModal() {
1425
- this._element.style.display = 'none';
1426
- this._element.setAttribute('aria-hidden', true);
1427
- this._element.removeAttribute('aria-modal');
1428
- this._element.removeAttribute('role');
1429
- this._isTransitioning = false;
1430
- _utils_js_components_backdrop__WEBPACK_IMPORTED_MODULE_2__["default"].hide(() => {
1431
- document.body.classList.remove(CLASS_NAME_OPEN);
1432
- this._resetAdjustments();
1433
- this._scrollBar.reset();
1434
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].trigger(this._element, EVENT_KEY_HIDDEN);
1435
- });
1436
- }
1437
- _showElement(relatedTarget) {
1438
- if (!document.body.contains(this._element)) {
1439
- document.body.append(this._element);
1440
- }
1441
- this._element.style.display = 'block';
1442
- this._element.removeAttribute('aria-hidden');
1443
- this._element.setAttribute('aria-modal', true);
1444
- this._element.setAttribute('role', 'dialog');
1445
- this._element.scrollTop = 0;
1446
- const modalBody = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].find(SELECTOR_MODAL_BODY, this._dialog);
1447
- if (modalBody) {
1448
- modalBody.scrollTop = 0;
1449
- }
1450
- (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_6__.reflow)(this._element);
1451
- this._element.classList.add(CLASS_NAME_SHOW);
1452
- const transitionComplete = () => {
1453
- this._isTransitioning = false;
1454
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].trigger(this._element, EVENT_KEY_SHOWN, {
1455
- relatedTarget
1456
- });
1457
- };
1458
- this._queueCallback(transitionComplete, this._dialog, this._isAnimatedFade());
1459
- }
1460
- _isAnimatedFade() {
1461
- return this._element.classList.contains(CLASS_NAME_FADE);
1462
- }
1463
- _adjustDialog() {
1464
- const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;
1465
- const scrollbarWidth = this._scrollBar.getWidth();
1466
- const isBodyOverflowing = scrollbarWidth > 0;
1467
- if (isBodyOverflowing && !isModalOverflowing) {
1468
- const property = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_6__.isRTL)() ? 'paddingLeft' : 'paddingRight';
1469
- this._element.style[property] = `${scrollbarWidth}px`;
1470
- }
1471
- if (!isBodyOverflowing && isModalOverflowing) {
1472
- const property = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_6__.isRTL)() ? 'paddingRight' : 'paddingLeft';
1473
- this._element.style[property] = `${scrollbarWidth}px`;
1474
- }
1475
- }
1476
- _resetAdjustments() {
1477
- this._element.style.paddingLeft = '';
1478
- this._element.style.paddingRight = '';
1479
- }
1480
- _addEventListeners() {
1481
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].on(this._element, EVENT_KEY_KEYDOWN_DISMISS, event => {
1482
- if (event.key !== ESCAPE_KEY) return;
1483
- if (this._params.keyboard) {
1484
- this.hide();
1485
- return;
1486
- }
1487
- this._triggerBackdropTransition();
1488
- });
1489
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].on(window, EVENT_KEY_RESIZE, () => {
1490
- if (this._isShown && !this._isTransitioning) this._adjustDialog();
1491
- });
1492
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].on(this._element, EVENT_KEY_MOUSEDOWN_DISMISS, event => {
1493
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].one(this._element, EVENT_KEY_CLICK_DISMISS, event2 => {
1494
- if (this._element !== event.target || this._element !== event2.target) return;
1495
- if (this._params.backdrop === 'static') {
1496
- this._triggerBackdropTransition();
1497
- return;
1498
- }
1499
- if (this._params.backdrop) {
1500
- this.hide();
1501
- }
1502
- });
1503
- });
1504
- }
1505
- _triggerBackdropTransition() {
1506
- const hideEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].trigger(this._element, EVENT_KEY_HIDE_PREVENTED);
1507
- if (hideEvent.defaultPrevented) return;
1508
- const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;
1509
- const initialOverflowY = this._element.style.overflowY;
1510
- if (initialOverflowY === 'hidden' || this._element.classList.contains(CLASS_NAME_STATIC)) return;
1511
- if (!isModalOverflowing) this._element.style.overflowY = 'hidden';
1512
- this._element.classList.add(CLASS_NAME_STATIC);
1513
- this._queueCallback(() => {
1514
- this._element.classList.remove(CLASS_NAME_STATIC);
1515
- this._queueCallback(() => {
1516
- this._element.style.overflowY = initialOverflowY;
1517
- }, this._dialog);
1518
- }, this._dialog);
1519
- }
1520
- _addFieldsInModal(relatedTarget) {
1521
- this._params = this._getParams(relatedTarget, this._params);
1522
- if (!this._params.fields.length) return;
1523
- this._params.fields.forEach(function (item) {
1524
- if (!'name' in item && !'value' in item) return;
1525
- let elements = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].findAll('[data-' + item.name + ']');
1526
- if (!elements.length) return;
1527
- for (const elm of elements) {
1528
- switch (elm.tagName) {
1529
- case 'INPUT':
1530
- elm.value = item.value;
1531
- break;
1532
- case 'IMG':
1533
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_5__.Manipulator.set(elm, 'src', item.value);
1534
- break;
1535
- default:
1536
- elm.innerHTML = item.value;
1537
- }
1538
- }
1539
- });
1540
- }
1541
- }
1542
- (0,_module_fn__WEBPACK_IMPORTED_MODULE_7__.dismissTrigger)(VGModal);
1543
-
1544
- /**
1545
- * Data API implementation
1546
- */
1547
-
1548
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
1549
- const target = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].getElementFromSelector(this);
1550
- if (['A', 'AREA'].includes(this.tagName)) event.preventDefault();
1551
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_4__["default"].one(target, EVENT_KEY_SHOW, showEvent => {
1552
- if (showEvent.defaultPrevented) return;
1553
- });
1554
- const alreadyOpen = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].find(OPEN_SELECTOR);
1555
- if (alreadyOpen) VGModal.getInstance(alreadyOpen).hide();
1556
- const data = VGModal.getOrCreateInstance(target);
1557
- data.toggle(this);
1558
- });
1559
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGModal);
1560
-
1561
- /***/ }),
1562
-
1563
- /***/ "./app/modules/vgnav/js/vgnav.js":
1564
- /*!***************************************!*\
1565
- !*** ./app/modules/vgnav/js/vgnav.js ***!
1566
- \***************************************/
1567
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1568
-
1569
- __webpack_require__.r(__webpack_exports__);
1570
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1571
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
1572
- /* harmony export */ });
1573
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
1574
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
1575
- /* harmony import */ var _utils_js_components_responsive__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/components/responsive */ "./app/utils/js/components/responsive.js");
1576
- /* harmony import */ var _module_fn__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../module-fn */ "./app/modules/module-fn.js");
1577
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
1578
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
1579
- /* harmony import */ var _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../../utils/js/dom/manipulator */ "./app/utils/js/dom/manipulator.js");
1580
-
1581
-
1582
-
1583
-
1584
-
1585
-
1586
-
1587
-
1588
- /**
1589
- * Constants
1590
- */
1591
- const NAME = 'nav';
1592
- const NAME_KEY = 'vg.nav';
1593
-
1594
- /**
1595
- * Constants Classes
1596
- */
1597
- const CLASS_NAME_SHOW = 'show';
1598
- const CLASS_NAME_FADE = 'fade';
1599
- const CLASS_NAME_ACTIVE = 'active';
1600
- const SELECTOR_DATA_TOGGLE = '.vg-nav a';
1601
-
1602
- /**
1603
- * Constants Events
1604
- */
1605
- const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
1606
- const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
1607
- const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
1608
- const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
1609
- const EVENT_MOUSEOVER_DATA_API = `mouseover.${NAME_KEY}.data.api`;
1610
- const EVENT_MOUSEOUT_DATA_API = `mouseout.${NAME_KEY}.data.api`;
1611
- const EVENT_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
1612
- const EVENT_KEYUP_DATA_API = `keyup.${NAME_KEY}.data.api`;
1613
- const EVENT_RESIZE_DATA_API = `resize.${NAME_KEY}.data.api`;
1614
- class VGNav extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
1615
- constructor(element, params = {}) {
1616
- super(element);
1617
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.mergeDeepObject)({
1618
- breakpoint: false,
1619
- placement: 'horizontal',
1620
- classes: {
1621
- hamburgerActive: 'vg-nav-hamburger-active',
1622
- hamburgerAlways: 'vg-nav-hamburger-always',
1623
- hamburger: 'vg-nav-hamburger',
1624
- container: 'vg-nav-container',
1625
- wrapper: 'vg-nav-wrapper',
1626
- active: 'vg-nav-active',
1627
- expand: 'vg-nav-expand',
1628
- cloned: 'vg-nav-cloned',
1629
- hover: 'vg-nav-hover',
1630
- flip: 'vg-nav-flip',
1631
- XXXL: 'vg-nav-xxxl',
1632
- XXL: 'vg-nav-xxl',
1633
- XL: 'vg-nav-xl',
1634
- LG: 'vg-nav-lg',
1635
- MD: 'vg-nav-md',
1636
- SM: 'vg-nav-sm',
1637
- XS: 'vg-nav-xs'
1638
- },
1639
- expand: true,
1640
- hover: false,
1641
- position: true,
1642
- collapse: true,
1643
- toggle: '<span class="default"></span>',
1644
- hamburger: {
1645
- enable: true,
1646
- always: false,
1647
- title: '',
1648
- body: null
1649
- },
1650
- callback: _utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.noop,
1651
- animation: true,
1652
- timeoutAnimation: 300,
1653
- ajax: {
1654
- route: '',
1655
- target: '',
1656
- method: 'get'
1657
- }
1658
- }, params));
1659
- this._navigation = null;
1660
- this.navigation = '.' + this._params.classes.wrapper;
1661
- this.movedLinks = [];
1662
- this.$links = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].findAll('.' + this._params.classes.wrapper + ' > li', this.navigation);
1663
- if (this._params.animation === false) {
1664
- this._params.timeoutAnimation = 10;
1665
- }
1666
- }
1667
- static get NAME() {
1668
- return NAME;
1669
- }
1670
- static get NAME_KEY() {
1671
- return NAME_KEY;
1672
- }
1673
- get navigation() {
1674
- return this._navigation;
1675
- }
1676
- set navigation(el) {
1677
- let elm = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find(el, this._element);
1678
- if (!elm) return;
1679
- this._navigation = elm;
1680
- }
1681
- build() {
1682
- if (!this.navigation) return;
1683
- let params = this._params;
1684
-
1685
- // Вешаем основные классы
1686
- this._element.classList.add(params.classes.container);
1687
- this._element.classList.add('vg-nav-' + params.placement);
1688
-
1689
- // Если нужно оставить список меню или установить медиа точку
1690
- if (!params.breakpoint) {
1691
- params.expand = false;
1692
- }
1693
- if (!params.hamburger.always) {
1694
- if (!params.breakpoint || !params.expand) {
1695
- this._element.classList.add(params.classes.expand);
1696
- } else if (params.breakpoint !== false) {
1697
- this._element.classList.add('vg-nav-' + params.breakpoint);
1698
- }
1699
- } else {
1700
- this._element.classList.add(params.classes.hamburgerAlways);
1701
- }
1702
-
1703
- // Меню срабатывает при наведении, если это не мобильное устройство
1704
- if (params.hover) {
1705
- this._element.classList.add(params.classes.hover);
1706
- if (_utils_js_components_responsive__WEBPACK_IMPORTED_MODULE_2__["default"].checkMobileOrTablet()) {
1707
- this._element.classList.remove(params.classes.hover);
1708
- }
1709
- }
1710
-
1711
- // Устанавливаем гамбургер, если его нет в разметке
1712
- if (params.expand && !params.hamburger.body) {
1713
- let isHamburger = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find('.' + params.classes.hamburger, this._element);
1714
- if (isHamburger === null) {
1715
- let mTitle = '',
1716
- hamburger = '<span class="' + params.classes.hamburger + '--lines"><span></span><span></span><span></span></span>';
1717
- if (params.hamburger.title) {
1718
- mTitle = '<span class="' + params.classes.hamburger + '--title">' + params.hamburger.title + '</span>';
1719
- }
1720
- if (params.hamburger.body !== null) {
1721
- hamburger = params.hamburger.body;
1722
- }
1723
- this._element.insertAdjacentHTML('afterbegin', '<a href="#sidebar-nav" class="' + params.classes.hamburger + '" data-vg-toggle="sidebar">' + mTitle + hamburger + '</a>');
1724
- }
1725
- }
1726
-
1727
- // Устанавливаем указатель переключателя
1728
- if (params.toggle) {
1729
- let $dropdown_a = [..._utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].findAll('.dropdown-mega > a, .dropdown > a', this._element)],
1730
- toggle = '<span class="toggle">' + params.toggle + '</span>';
1731
- if ($dropdown_a.length) {
1732
- $dropdown_a.forEach(function (elem) {
1733
- if (!elem.querySelector('.toggle') && !elem.closest('.dots')) {
1734
- elem.setAttribute('aria-expanded', 'false');
1735
- elem.insertAdjacentHTML('beforeend', toggle);
1736
- }
1737
- });
1738
- }
1739
- }
1740
- if (params.collapse && _utils_js_components_responsive__WEBPACK_IMPORTED_MODULE_2__["default"].check(this) && params.placement !== 'vertical') {
1741
- setCollapse(this);
1742
- }
1743
- if ('afterInit' in this._params.callback) {
1744
- (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.execute)(this._params.callback.afterInit, [this]);
1745
- }
1746
-
1747
- /**
1748
- * Функция сворачивания
1749
- * TODO Придумать что то с мега меню, которое уходит в подменю
1750
- * TODO Так же есть косяки при ресайзе
1751
- */
1752
- function setCollapse(_this) {
1753
- let width_navigation_responsive = _this.navigation.clientWidth,
1754
- width_all_links_responsive = 0,
1755
- $dots = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find('.dots', _this.navigation),
1756
- _dots = (0,_module_fn__WEBPACK_IMPORTED_MODULE_3__.getSVG)('dots');
1757
- if (_this.$links.length) {
1758
- if ($dots) {
1759
- width_all_links_responsive = $dots.clientWidth;
1760
- } else {
1761
- let $a = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find('a', _this.$links[0]),
1762
- $linkStyle = getComputedStyle($a),
1763
- paddingLeft = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.normalizeData)($linkStyle.paddingLeft.slice(0, -2)),
1764
- paddingRight = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.normalizeData)($linkStyle.paddingRight.slice(0, -2)),
1765
- padding = paddingLeft + paddingRight;
1766
-
1767
- // TODO не совсем верно, но мы точно знаем ширину точек в svg - 16px
1768
- width_all_links_responsive = padding + 16;
1769
- }
1770
- for (let $link of _this.$links) {
1771
- let width = $link.getBoundingClientRect().width;
1772
- width_all_links_responsive = width_all_links_responsive + width;
1773
- if (width_navigation_responsive < width_all_links_responsive) {
1774
- _this.movedLinks.push($link);
1775
- $link.remove();
1776
- } else {
1777
- if (_this.movedLinks.length) {
1778
- if ($dots) {
1779
- _this.navigation.insertBefore(_this.movedLinks[0], $dots);
1780
- } else {
1781
- _this.navigation.appendChild(_this.movedLinks[0]);
1782
- }
1783
- _this.movedLinks.splice(0, 1);
1784
- }
1785
- }
1786
- }
1787
- if (_this.movedLinks.length) {
1788
- if (!$dots) {
1789
- _this.navigation.insertAdjacentHTML('beforeend', '<li class="dropdown dots">' + '<a href="#" aria-expanded="false">' + _dots + '</a></li>');
1790
- }
1791
- } else {
1792
- if ($dots) {
1793
- $dots.remove();
1794
- }
1795
- }
1796
- let $d = _this.navigation.querySelector('.dots');
1797
- if ($d && _this.movedLinks.length) {
1798
- let $dropdown = $d.querySelector('ul');
1799
- if ($dropdown) {
1800
- for (let link of _this.movedLinks) {
1801
- $dropdown.prepend(link);
1802
- }
1803
- } else {
1804
- let $dropdown = document.createElement('ul');
1805
- $dropdown.classList.add('dropdown-content');
1806
- $dropdown.classList.add('right');
1807
- for (let link of _this.movedLinks) {
1808
- $dropdown.prepend(link);
1809
- }
1810
- $d.appendChild($dropdown);
1811
- }
1812
- }
1813
- }
1814
- }
1815
- }
1816
- show(relatedTarget) {
1817
- let target = relatedTarget.relatedTarget;
1818
- if (!target || (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.isDisabled)(target)) {
1819
- return;
1820
- }
1821
- if (!target.closest('.dropdown-content')) {
1822
- target.classList.add('first');
1823
- }
1824
- const showEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].trigger(target, EVENT_KEY_SHOW, {
1825
- relatedTarget
1826
- });
1827
- if (showEvent.defaultPrevented) return;
1828
- let drop = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find('.dropdown-content', target),
1829
- link = target.firstElementChild;
1830
- if (link) link.setAttribute('aria-expanded', 'true');
1831
- drop.classList.add(CLASS_NAME_SHOW);
1832
- target.classList.add(CLASS_NAME_ACTIVE);
1833
- setDropPosition(drop);
1834
- const completeCallBack = () => {
1835
- drop.classList.add(CLASS_NAME_FADE);
1836
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].trigger(target, EVENT_KEY_SHOWN, relatedTarget);
1837
- };
1838
- this._queueCallback(completeCallBack, drop, true, 50);
1839
-
1840
- /**
1841
- *
1842
- * @param $drop
1843
- */
1844
- function setDropPosition($drop) {
1845
- let {
1846
- width,
1847
- right
1848
- } = $drop.getBoundingClientRect(),
1849
- window_width = window.innerWidth;
1850
- let N_right = window_width - right - width;
1851
- $drop.classList.remove('right');
1852
- $drop.classList.remove('left');
1853
- let $parent = $drop.closest('li'),
1854
- $ul = $parent.querySelectorAll('ul');
1855
- if (N_right > width) {
1856
- for (const $el of $ul) {
1857
- $el.classList.add('left');
1858
- }
1859
- } else {
1860
- for (const $el of $ul) {
1861
- $el.classList.add('right');
1862
- }
1863
- }
1864
- }
1865
- }
1866
- hide(relatedTarget) {
1867
- const _this = this;
1868
- if ('ontouchstart' in document.documentElement) {
1869
- for (const element of [].concat(...document.body.children)) {
1870
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].off(element, 'mouseover', _utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.noop);
1871
- }
1872
- }
1873
- let element = relatedTarget.relatedTarget;
1874
- if ('elm' in relatedTarget && relatedTarget.elm) {
1875
- element = relatedTarget.elm;
1876
- }
1877
- if (element) {
1878
- const hideEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].trigger(element, EVENT_KEY_HIDE);
1879
- if (hideEvent.defaultPrevented) return;
1880
- element.classList.remove(CLASS_NAME_ACTIVE);
1881
- if (element.classList.contains('first')) {
1882
- element.classList.remove('first');
1883
- }
1884
- [..._utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].findAll('.' + CLASS_NAME_SHOW, element)].forEach(function (el, index) {
1885
- el.classList.remove(CLASS_NAME_FADE);
1886
- let parent = el.closest('.dropdown');
1887
- if (parent.classList.contains(CLASS_NAME_ACTIVE)) {
1888
- parent.classList.remove(CLASS_NAME_ACTIVE);
1889
- }
1890
- let link = el.previousElementSibling;
1891
- if (link) link.setAttribute('aria-expanded', 'false');
1892
- if (index === 0) {
1893
- const completeCallback = () => {
1894
- el.classList.remove(CLASS_NAME_SHOW);
1895
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].trigger(el, EVENT_KEY_HIDDEN, relatedTarget);
1896
- };
1897
- _this._queueCallback(completeCallback, el, true, 500);
1898
- }
1899
- });
1900
- }
1901
- }
1902
-
1903
- /**
1904
- * TODO если на странице несколько навигаций, то есть косяки
1905
- * @param element
1906
- * @param params
1907
- */
1908
- static init(element, params = {}) {
1909
- const instance = VGNav.getOrCreateInstance(element, params);
1910
- instance.build();
1911
- let drops = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].findAll('.dropdown', instance._navigation);
1912
- if (instance._params.hover) {
1913
- [...drops].forEach(function (el) {
1914
- let currentElem = null;
1915
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].on(el, EVENT_MOUSEOVER_DATA_API, function (event) {
1916
- if (currentElem) return;
1917
- VGNav.hideOpenDrops(event);
1918
- let target = event.target.closest('.dropdown');
1919
- if (!target) return;
1920
- if (!instance.navigation.contains(target)) return;
1921
- currentElem = target;
1922
- let relatedTarget = {
1923
- relatedTarget: target
1924
- };
1925
- instance.show(relatedTarget);
1926
- });
1927
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].on(el, EVENT_MOUSEOUT_DATA_API, function (event) {
1928
- if (!currentElem) return;
1929
- let relatedTarget = event.relatedTarget.closest('.dropdown'),
1930
- elm = currentElem;
1931
- while (relatedTarget) {
1932
- if (relatedTarget === currentElem) return;
1933
- relatedTarget = relatedTarget.parentNode;
1934
- }
1935
- currentElem = null;
1936
- instance.hide({
1937
- relatedTarget: relatedTarget,
1938
- elm: elm
1939
- });
1940
- });
1941
- });
1942
- } else {
1943
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].on(document, EVENT_KEYUP_DATA_API, VGNav.clearDrops);
1944
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].on(document, EVENT_CLICK_DATA_API, VGNav.clearDrops);
1945
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
1946
- if (!_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_6__.Manipulator.has(this, 'aria-expanded')) {
1947
- return;
1948
- }
1949
- if ('click' in instance._params.callback) {
1950
- (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.execute)(instance._params.callback.click, [this]);
1951
- }
1952
- event.preventDefault();
1953
- let self = this.closest('.vg-nav'),
1954
- isFirst = self.querySelector('.first');
1955
- let target = this.closest('.dropdown');
1956
- if (!target) return;
1957
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.isDisabled)(target) && !(0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_4__.isVisible)(target)) {
1958
- return;
1959
- }
1960
- if (isFirst && this.closest('.first')) {
1961
- if (target.classList.contains('active')) {
1962
- instance.hide({
1963
- relatedTarget: target
1964
- });
1965
- return;
1966
- }
1967
- } else {
1968
- [..._utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].findAll('.active', self)].forEach(function (el) {
1969
- if (el && el !== target) {
1970
- instance.hide({
1971
- relatedTarget: el
1972
- });
1973
- }
1974
- });
1975
- }
1976
- instance.show({
1977
- relatedTarget: target
1978
- });
1979
- });
1980
- }
1981
- const vgNavSidebar = document.getElementById('sidebar-nav');
1982
- let hamburger = instance._element.querySelector('.' + instance._params.classes.hamburger);
1983
- if (vgNavSidebar && hamburger) {
1984
- vgNavSidebar.addEventListener('vg.sidebar.show', function () {
1985
- hamburger.classList.add(instance._params.classes.hamburgerActive);
1986
- });
1987
- vgNavSidebar.addEventListener('vg.sidebar.hide', function () {
1988
- hamburger.classList.remove(instance._params.classes.hamburgerActive);
1989
- });
1990
- }
1991
- }
1992
- static clearDrops(event) {
1993
- if (event.button === 2 || event.type === 'keyup' && event.key !== 'Tab') {
1994
- return;
1995
- }
1996
- VGNav.hideOpenDrops(event);
1997
- }
1998
- static hideOpenDrops(event) {
1999
- const openToggles = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].findAll('.dropdown:not(.disabled):not(:disabled).active');
2000
- for (const toggle of openToggles) {
2001
- const context = VGNav.getInstance(toggle.closest('.vg-nav'));
2002
- if (!context) continue;
2003
- if (event.target.closest('.first')) {
2004
- return;
2005
- }
2006
- const relatedTarget = {
2007
- relatedTarget: toggle
2008
- };
2009
- if (event.type === 'click') {
2010
- relatedTarget.clickEvent = event;
2011
- }
2012
- context.hide(relatedTarget);
2013
- }
2014
- }
2015
- }
2016
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_5__["default"].on(window, EVENT_RESIZE_DATA_API, function (event) {
2017
- const instance = VGNav.getOrCreateInstance('.vg-nav', {});
2018
- instance.build();
2019
- });
2020
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGNav);
2021
-
2022
- /***/ }),
2023
-
2024
- /***/ "./app/modules/vgrollup/js/vgrollup.js":
2025
- /*!*********************************************!*\
2026
- !*** ./app/modules/vgrollup/js/vgrollup.js ***!
2027
- \*********************************************/
2028
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2029
-
2030
- __webpack_require__.r(__webpack_exports__);
2031
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2032
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2033
- /* harmony export */ });
2034
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
2035
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
2036
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
2037
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
2038
- /* harmony import */ var _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/dom/manipulator */ "./app/utils/js/dom/manipulator.js");
2039
-
2040
-
2041
-
2042
-
2043
-
2044
-
2045
- /**
2046
- * Constants
2047
- */
2048
- const NAME = 'rollup';
2049
- const NAME_KEY = 'vg.rollup';
2050
- const CLASS_NAME_SHOW = 'show';
2051
- const CLASS_NAME_HIDE = 'd-none';
2052
- const SELECTOR_DATA_TOGGLE = '[data-vg-toggle="rollup"]';
2053
- const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
2054
- const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
2055
- const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
2056
- const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
2057
- const EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
2058
- class VGRollup extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
2059
- constructor(element, params = {}) {
2060
- super(element, params);
2061
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.mergeDeepObject)({}, params));
2062
- }
2063
- static get NAME() {
2064
- return NAME;
2065
- }
2066
- static get NAME_KEY() {
2067
- return NAME_KEY;
2068
- }
2069
- build() {}
2070
- toggle(relatedTarget) {
2071
- return !this._isShown() ? this.show(relatedTarget) : this.hide();
2072
- }
2073
- show(relatedTarget) {}
2074
- _isShown() {
2075
- return this._element.classList.contains(CLASS_NAME_SHOW);
2076
- }
2077
-
2078
- /**
2079
- * Инициализация
2080
- * @param element
2081
- * @param params
2082
- */
2083
- static init(element, params = {}) {
2084
- const instance = VGRollup.getOrCreateInstance(element, params);
2085
- instance.toggle();
2086
- }
2087
- }
2088
-
2089
- /**
2090
- * Data API implementation
2091
- */
2092
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
2093
- const target = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_3__["default"].getElementFromSelector(this);
2094
- if (!target) return;
2095
- if (['A', 'AREA'].includes(this.tagName)) {
2096
- event.preventDefault();
2097
- }
2098
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(this)) {
2099
- return;
2100
- }
2101
- this.setAttribute('aria-expanded', true);
2102
- const data = VGRollup.getOrCreateInstance(target);
2103
- data.toggle(this);
2104
- });
2105
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGRollup);
2106
-
2107
- /***/ }),
2108
-
2109
- /***/ "./app/modules/vgselect/js/vgselect.js":
2110
- /*!*********************************************!*\
2111
- !*** ./app/modules/vgselect/js/vgselect.js ***!
2112
- \*********************************************/
2113
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2114
-
2115
- __webpack_require__.r(__webpack_exports__);
2116
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2117
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2118
- /* harmony export */ });
2119
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
2120
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
2121
- /* harmony import */ var _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/dom/manipulator */ "./app/utils/js/dom/manipulator.js");
2122
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
2123
-
2124
-
2125
-
2126
-
2127
-
2128
- /**
2129
- * Constants
2130
- */
2131
- const NAME = 'select';
2132
- const NAME_KEY = 'vg.select';
2133
- const CLASS_NAME_CONTAINER = 'vg-select';
2134
- const CLASS_NAME_DROPDOWN = 'vg-select-dropdown';
2135
- const CLASS_NAME_LIST = 'vg-select-list';
2136
- const CLASS_NAME_OPTION = 'vg-select-list--option';
2137
- const CLASS_NAME_OPTGROUP = 'vg-select-list--optgroup';
2138
- const CLASS_NAME_OPTGROUP_TITLE = 'vg-select-list--optgroup-title';
2139
- const CLASS_NAME_CURRENT = 'vg-select-current';
2140
- const CLASS_NAME_SEARCH = 'vg-select-search';
2141
- const CLASS_NAME_SELECTED = 'selected';
2142
- const EVENT_KEY_CHANGE = `${NAME_KEY}.change`;
2143
- let observerTimout;
2144
- class VGSelect extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
2145
- constructor(element, params = {}) {
2146
- super(element, params);
2147
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.mergeDeepObject)({
2148
- search: false
2149
- }, params));
2150
- }
2151
- static get NAME() {
2152
- return NAME;
2153
- }
2154
- static get NAME_KEY() {
2155
- return NAME_KEY;
2156
- }
2157
- build(isRebuild, elm = null) {
2158
- const _this = this;
2159
- let element = this._element;
2160
- if (elm) element = elm;
2161
- if (element.dataset?.inited === 'true' && !isRebuild) {
2162
- return;
2163
- } else if (isRebuild) {
2164
- _this.destroy(element);
2165
- }
2166
- element.parentElement.style.position = 'relative';
2167
- let option_selected = element.options[element.selectedIndex].innerText,
2168
- options = element.options;
2169
-
2170
- // Создаем основной элемент с классами селекта
2171
- let classes = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.get(element, 'class'),
2172
- select = document.createElement('div');
2173
- classes = classes.split(' ');
2174
- for (const _class of classes) {
2175
- select.classList.add(_class);
2176
- }
2177
- if (_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.has(element, 'disabled')) select.classList.add('disabled');
2178
- let elData = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.get(element);
2179
- if (!(0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isEmptyObj)(elData)) {
2180
- for (const key of Object.keys(elData)) {
2181
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.set(select, 'data-' + key, elData[key]);
2182
- }
2183
- }
2184
-
2185
- // Создаем элемент с отображением выбранного варианта
2186
- let current = document.createElement('div');
2187
- current.classList.add(CLASS_NAME_CURRENT);
2188
- current.innerText = option_selected.trim();
2189
- select.append(current);
2190
-
2191
- // Создаем элемент выпадающего списка
2192
- let dropdown = document.createElement('div');
2193
- dropdown.classList.add(CLASS_NAME_DROPDOWN);
2194
- select.append(dropdown);
2195
-
2196
- // Создаем список и варианты селекта
2197
- let list = document.createElement('ul');
2198
- list.classList.add(CLASS_NAME_LIST);
2199
- let optGroup = element.querySelectorAll('optgroup');
2200
- if (optGroup.length) {
2201
- let isSelected = false;
2202
- [...optGroup].forEach(function (el) {
2203
- let olOptGroup = document.createElement('ol');
2204
- olOptGroup.classList.add(CLASS_NAME_OPTGROUP);
2205
- let liLabel = document.createElement('li');
2206
- liLabel.innerHTML = el.label.trim();
2207
- liLabel.classList.add(CLASS_NAME_OPTGROUP_TITLE);
2208
- olOptGroup.prepend(liLabel);
2209
- let optGroupOptions = el.querySelectorAll('option');
2210
- createLi(optGroupOptions, olOptGroup, isSelected);
2211
- list.append(olOptGroup);
2212
- isSelected = true;
2213
- });
2214
- } else {
2215
- let isSelected = false;
2216
- createLi(options, list, isSelected);
2217
- }
2218
- function createLi(options, list, isSelected) {
2219
- let i = 0;
2220
- for (const option of options) {
2221
- let li = document.createElement('li');
2222
- li.innerHTML = option.innerHTML.trim().replace(/<\/[^>]+(>|$)/g, "");
2223
- li.dataset.value = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.get(option, 'value');
2224
- li.classList.add(CLASS_NAME_OPTION);
2225
- let liData = _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.get(option);
2226
- if (!(0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isEmptyObj)(liData)) {
2227
- for (const key of Object.keys(liData)) {
2228
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.set(li, 'data-' + key, liData[key]);
2229
- }
2230
- }
2231
- if (i === element.selectedIndex && !isSelected) {
2232
- li.classList.add('selected');
2233
- }
2234
- if (_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.has(option, 'disabled')) li.classList.add('disabled');
2235
- if (_utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.has(option, 'hidden')) li.classList.add('hidden');
2236
- list.append(li);
2237
- i++;
2238
- }
2239
- }
2240
- dropdown.append(list);
2241
-
2242
- // Добавляем все созданный контейнер после селекта
2243
- element.insertAdjacentElement('afterend', select);
2244
-
2245
- // помечаем элемент инициализированным
2246
- element.dataset.inited = 'true';
2247
- if (_this._params.search) {
2248
- this.search(select);
2249
- }
2250
- this._addEventListeners(select);
2251
- }
2252
- destroy(select) {
2253
- let element = select.nextElementSibling;
2254
- if (element) {
2255
- if (element.classList.contains(CLASS_NAME_CONTAINER)) {
2256
- element.remove();
2257
- select.selectedIndex = 0;
2258
- [...select.querySelectorAll('option')].forEach(function (el, index) {
2259
- if (el.hasAttribute('selected')) {
2260
- select.selectedIndex = index;
2261
- }
2262
- });
2263
- }
2264
- }
2265
- }
2266
- refresh(select) {
2267
- const _this = this;
2268
- let observer = new MutationObserver(() => {
2269
- clearTimeout(observerTimout);
2270
- observerTimout = setTimeout(() => {
2271
- _this.build(true, select);
2272
- }, 100);
2273
- });
2274
- observer.observe(select, {
2275
- attributeFilter: ['disabled', 'required', 'style', 'hidden'],
2276
- childList: true,
2277
- subtree: true,
2278
- characterDataOldValue: true
2279
- });
2280
- }
2281
- search(select) {
2282
- const _this = this;
2283
- let dropdown = select.querySelector('.' + CLASS_NAME_DROPDOWN);
2284
- let search_container = document.createElement('div');
2285
- search_container.classList.add(CLASS_NAME_SEARCH);
2286
- let input = document.createElement('input');
2287
- input.setAttribute('name', 'vg-select-search');
2288
- input.setAttribute('type', 'text');
2289
- input.setAttribute('placeholder', 'Поиск...');
2290
- search_container.append(input);
2291
- dropdown.prepend(search_container);
2292
- search_container.querySelector('[name=vg-select-search]').addEventListener('keyup', e => {
2293
- e.preventDefault();
2294
- let el = e.target;
2295
- let selectList = el?.closest('.' + CLASS_NAME_DROPDOWN).querySelector('.' + CLASS_NAME_LIST);
2296
- if (selectList) {
2297
- let options = [...selectList.querySelectorAll('.' + CLASS_NAME_OPTION)],
2298
- optionsGroup = [...selectList.querySelectorAll('.' + CLASS_NAME_OPTGROUP)],
2299
- value = el?.value;
2300
- options = options.concat(optionsGroup);
2301
- for (const option of options) {
2302
- _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.show(option);
2303
- }
2304
- if (value.length) {
2305
- value = value.trim();
2306
- value = value.toLowerCase();
2307
- value = (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.transliterate)(value, true);
2308
- for (const option of options) {
2309
- let text = option.innerText.toLowerCase();
2310
- if (text.indexOf(value) === -1) _utils_js_dom_manipulator__WEBPACK_IMPORTED_MODULE_2__.Manipulator.hide(option);
2311
- }
2312
- }
2313
- }
2314
- });
2315
- }
2316
- dispose() {
2317
- super.dispose();
2318
- }
2319
- _addEventListeners(select) {
2320
- const _this = this;
2321
- select.querySelector('.' + CLASS_NAME_CURRENT).onclick = function (e) {
2322
- let el = e.target,
2323
- container = el.closest('.' + CLASS_NAME_CONTAINER);
2324
- let selects = document.querySelectorAll('.' + CLASS_NAME_CONTAINER);
2325
- if (selects.length) {
2326
- for (const els of selects) {
2327
- if (els !== container) {
2328
- els?.classList.remove('show');
2329
- }
2330
- }
2331
- }
2332
- if (container.classList.contains('show')) {
2333
- container.classList.remove('show');
2334
- } else {
2335
- container.classList.add('show');
2336
- if (_this._params.search) {
2337
- let input = container.querySelector('input');
2338
- if (input) input.focus();
2339
- }
2340
- }
2341
- return false;
2342
- };
2343
- select.querySelectorAll('.' + CLASS_NAME_OPTION).forEach(option => {
2344
- option.addEventListener('click', e => {
2345
- e.preventDefault();
2346
- let el = e.target;
2347
- if (!el.classList.contains('disabled')) {
2348
- let container = el.closest('.' + CLASS_NAME_CONTAINER),
2349
- options = container.querySelectorAll('.' + CLASS_NAME_OPTION);
2350
- if (options.length) {
2351
- for (const option of options) {
2352
- option.classList.remove('selected');
2353
- }
2354
- }
2355
- el.classList.add('selected');
2356
- container.querySelector('.' + CLASS_NAME_CURRENT).innerText = el.innerText;
2357
- container.classList.remove('show');
2358
- let select = container.previousSibling;
2359
- select.value = el.dataset.value;
2360
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_3__["default"].trigger(select, EVENT_KEY_CHANGE);
2361
- }
2362
- });
2363
- });
2364
- window.addEventListener('click', function (e) {
2365
- if (!e?.target.closest('.' + CLASS_NAME_CONTAINER)) {
2366
- let selects = document.querySelectorAll('.' + CLASS_NAME_CONTAINER);
2367
- if (selects.length) {
2368
- for (const el of selects) {
2369
- el?.classList.remove('show');
2370
- }
2371
- }
2372
- }
2373
- });
2374
- [...document.querySelectorAll('form')].forEach(function (form) {
2375
- form.addEventListener("reset", function () {
2376
- form.querySelectorAll('select.vg-select').forEach(function (select) {
2377
- VGSelect.init(select, {}, true);
2378
- });
2379
- });
2380
- });
2381
- }
2382
-
2383
- /**
2384
- * Инициализация
2385
- * @param element
2386
- * @param params
2387
- * @param isRebuild
2388
- */
2389
- static init(element, params = {}, isRebuild = false) {
2390
- const instance = VGSelect.getOrCreateInstance(element, params);
2391
- instance.build(isRebuild);
2392
- }
2393
- }
2394
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGSelect);
2395
-
2396
- /***/ }),
2397
-
2398
- /***/ "./app/modules/vgsidebar/js/vgsidebar.js":
2399
- /*!***********************************************!*\
2400
- !*** ./app/modules/vgsidebar/js/vgsidebar.js ***!
2401
- \***********************************************/
2402
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2403
-
2404
- __webpack_require__.r(__webpack_exports__);
2405
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2406
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2407
- /* harmony export */ });
2408
- /* harmony import */ var _base_module__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../base-module */ "./app/modules/base-module.js");
2409
- /* harmony import */ var _utils_js_functions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../utils/js/functions */ "./app/utils/js/functions.js");
2410
- /* harmony import */ var _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../utils/js/dom/event */ "./app/utils/js/dom/event.js");
2411
- /* harmony import */ var _module_fn__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../module-fn */ "./app/modules/module-fn.js");
2412
- /* harmony import */ var _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../../utils/js/dom/selectors */ "./app/utils/js/dom/selectors.js");
2413
- /* harmony import */ var _utils_js_components_backdrop__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../../utils/js/components/backdrop */ "./app/utils/js/components/backdrop.js");
2414
- /* harmony import */ var _utils_js_components_overflow__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../../utils/js/components/overflow */ "./app/utils/js/components/overflow.js");
2415
-
2416
-
2417
-
2418
-
2419
-
2420
-
2421
-
2422
-
2423
- /**
2424
- * Constants
2425
- */
2426
- const NAME = 'sidebar';
2427
- const NAME_KEY = 'vg.sidebar';
2428
- const SELECTOR_DATA_TOGGLE = '[data-vg-toggle="sidebar"]';
2429
- const CLASS_NAME_SHOW = 'show';
2430
- const CLASS_NAME_OPEN = 'vg-sidebar-open';
2431
- const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
2432
- const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
2433
- const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
2434
- const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
2435
- const EVENT_KEY_KEYDOWN_DISMISS = `keydown.dismiss.${NAME_KEY}`;
2436
- const EVENT_KEY_HIDE_PREVENTED = `hidePrevented.${NAME_KEY}`;
2437
- const EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
2438
- class VGSidebar extends _base_module__WEBPACK_IMPORTED_MODULE_0__["default"] {
2439
- constructor(element, params = {}) {
2440
- super(element, params);
2441
- this._params = this._getParams(element, (0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.mergeDeepObject)({
2442
- backdrop: true,
2443
- overflow: true,
2444
- keyboard: true,
2445
- animation: {
2446
- enable: false,
2447
- in: 'animate__rollIn',
2448
- out: 'animate__rollOut',
2449
- delay: 800
2450
- },
2451
- ajax: {
2452
- route: '',
2453
- target: '',
2454
- method: 'get'
2455
- }
2456
- }, params));
2457
- this._addEventListeners();
2458
- this._dismissElement();
2459
- this._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;
2460
- this._animation(this._element, VGSidebar.NAME_KEY, this._params.animation);
2461
- }
2462
- static get NAME() {
2463
- return NAME;
2464
- }
2465
- static get NAME_KEY() {
2466
- return NAME_KEY;
2467
- }
2468
- toggle(relatedTarget) {
2469
- return !this._isShown() ? this.show(relatedTarget) : this.hide();
2470
- }
2471
- show(relatedTarget) {
2472
- const _this = this;
2473
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(_this._element)) return;
2474
- _this._params = _this._getParams(relatedTarget, _this._params);
2475
- _this._route();
2476
- const showEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_SHOW, {
2477
- relatedTarget
2478
- });
2479
- if (showEvent.defaultPrevented) return;
2480
- if (_this._params.backdrop) {
2481
- _utils_js_components_backdrop__WEBPACK_IMPORTED_MODULE_5__["default"].show();
2482
- }
2483
- if (_this._params.overflow) {
2484
- _utils_js_components_overflow__WEBPACK_IMPORTED_MODULE_6__["default"].append();
2485
- }
2486
- _this._element.classList.add(CLASS_NAME_SHOW);
2487
- document.body.classList.add(CLASS_NAME_OPEN);
2488
- const completeCallBack = () => {
2489
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(_utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_4__["default"].find('.vg-backdrop'), 'mousedown.vg.backdrop', function () {
2490
- _this.hide();
2491
- });
2492
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(_this._element, EVENT_KEY_SHOWN, {
2493
- relatedTarget
2494
- });
2495
- };
2496
- _this._queueCallback(completeCallBack, _this._element, true, 50);
2497
- }
2498
- hide() {
2499
- const _this = this;
2500
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(_this._element)) return;
2501
- const hideEvent = _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(this._element, EVENT_KEY_HIDE);
2502
- if (hideEvent.defaultPrevented) return;
2503
- if (_this._params.backdrop) {
2504
- _utils_js_components_backdrop__WEBPACK_IMPORTED_MODULE_5__["default"].hide(function () {
2505
- if (_this._params.overflow) {
2506
- _utils_js_components_overflow__WEBPACK_IMPORTED_MODULE_6__["default"].destroy();
2507
- }
2508
- });
2509
- }
2510
- if (_this._params.overflow) {
2511
- _utils_js_components_overflow__WEBPACK_IMPORTED_MODULE_6__["default"].destroy();
2512
- }
2513
- setTimeout(() => {
2514
- _this._element.setAttribute('aria-expanded', false);
2515
- _this._element.classList.remove(CLASS_NAME_SHOW);
2516
- const completeCallback = () => {
2517
- document.body.classList.remove(CLASS_NAME_OPEN);
2518
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(this._element, EVENT_KEY_HIDDEN);
2519
- };
2520
- this._queueCallback(completeCallback, this._element, true);
2521
- }, this._params.animation.delay);
2522
- }
2523
- dispose() {
2524
- super.dispose();
2525
- }
2526
- _isShown() {
2527
- return this._element.classList.contains(CLASS_NAME_SHOW);
2528
- }
2529
- _addEventListeners() {
2530
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(document, EVENT_KEY_KEYDOWN_DISMISS, event => {
2531
- if (event.key !== 'Escape') return;
2532
- if (this._params.keyboard) {
2533
- this.hide();
2534
- return;
2535
- }
2536
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].trigger(this._element, EVENT_KEY_HIDE_PREVENTED);
2537
- });
2538
- }
2539
- }
2540
- (0,_module_fn__WEBPACK_IMPORTED_MODULE_3__.dismissTrigger)(VGSidebar);
2541
-
2542
- /**
2543
- * Data API implementation
2544
- */
2545
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
2546
- const target = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_4__["default"].getElementFromSelector(this);
2547
- if (['A', 'AREA'].includes(this.tagName)) {
2548
- event.preventDefault();
2549
- }
2550
- if ((0,_utils_js_functions__WEBPACK_IMPORTED_MODULE_1__.isDisabled)(this)) {
2551
- return;
2552
- }
2553
- this.setAttribute('aria-expanded', true);
2554
- _utils_js_dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].one(target, EVENT_KEY_HIDDEN, () => {
2555
- //if (isVisible(this)) this.focus();
2556
- this.setAttribute('aria-expanded', false);
2557
- });
2558
- const alreadyOpen = _utils_js_dom_selectors__WEBPACK_IMPORTED_MODULE_4__["default"].find('.vg-sidebar.show');
2559
- if (alreadyOpen && alreadyOpen !== target) {
2560
- VGSidebar.getInstance(alreadyOpen).hide();
2561
- }
2562
- const data = VGSidebar.getOrCreateInstance(target);
2563
- data.toggle(this);
2564
- });
2565
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VGSidebar);
2566
-
2567
- /***/ }),
2568
-
2569
- /***/ "./app/utils/js/components/animation.js":
2570
- /*!**********************************************!*\
2571
- !*** ./app/utils/js/components/animation.js ***!
2572
- \**********************************************/
2573
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2574
-
2575
- __webpack_require__.r(__webpack_exports__);
2576
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2577
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2578
- /* harmony export */ });
2579
- /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../functions */ "./app/utils/js/functions.js");
2580
- /* harmony import */ var _dom_event__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../dom/event */ "./app/utils/js/dom/event.js");
2581
-
2582
-
2583
-
2584
- /**
2585
- * Классы для анимаций смотрим здесь
2586
- * https://animate.style/
2587
- *
2588
- * Работает с модулями у которых есть события show, hide, hidden
2589
- */
2590
- class Animation {
2591
- constructor(element, key, params = {}) {
2592
- this._params = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.mergeDeepObject)({
2593
- enable: false,
2594
- in: 'animate__backInUp',
2595
- out: 'animate__backOutUp',
2596
- delay: 0
2597
- }, params);
2598
- this.classes = {
2599
- animated: 'animate__animated'
2600
- };
2601
- if (!this._params.enable) return;
2602
- if (!(0,_functions__WEBPACK_IMPORTED_MODULE_0__.isElement)(element)) return;
2603
- this._element = element;
2604
- this._name_key = key;
2605
- if (!this._element.classList.contains(this.classes.animated)) {
2606
- this._element.classList.add(this.classes.animated);
2607
- }
2608
- this._triggers();
2609
- }
2610
- _triggers() {
2611
- _dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(this._element, this._name_key + '.show', () => {
2612
- this._element.classList.remove(this._params.out);
2613
- this._element.classList.add(this._params.in);
2614
- });
2615
- _dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(this._element, this._name_key + '.hide', () => {
2616
- this._element.classList.remove(this._params.in);
2617
- this._element.classList.add(this._params.out);
2618
- });
2619
- _dom_event__WEBPACK_IMPORTED_MODULE_1__["default"].on(this._element, this._name_key + '.hidden', () => {
2620
- this._element.classList.remove(this._params.out);
2621
- });
2622
- }
2623
- }
2624
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Animation);
2625
-
2626
- /***/ }),
2627
-
2628
- /***/ "./app/utils/js/components/backdrop.js":
2629
- /*!*********************************************!*\
2630
- !*** ./app/utils/js/components/backdrop.js ***!
2631
- \*********************************************/
2632
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2633
-
2634
- __webpack_require__.r(__webpack_exports__);
2635
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2636
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2637
- /* harmony export */ });
2638
- /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../functions */ "./app/utils/js/functions.js");
2639
- /* harmony import */ var _dom_selectors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../dom/selectors */ "./app/utils/js/dom/selectors.js");
2640
- /* harmony import */ var _dom_event__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../dom/event */ "./app/utils/js/dom/event.js");
2641
- /* harmony import */ var _overflow__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./overflow */ "./app/utils/js/components/overflow.js");
2642
-
2643
-
2644
-
2645
-
2646
- const NAME = 'backdrop';
2647
- const CLASS_NAME = 'vg-backdrop';
2648
- const CLASS_NAME_FADE = 'fade';
2649
- const EVENT_MOUSEDOWN = `mousedown.vg.${NAME}`;
2650
- let backdrop_delay = 500;
2651
- class Backdrop {
2652
- static show(callback) {
2653
- Backdrop._append();
2654
- (0,_functions__WEBPACK_IMPORTED_MODULE_0__.execute)(callback);
2655
- }
2656
- static hide(callback) {
2657
- Backdrop._destroy();
2658
- (0,_functions__WEBPACK_IMPORTED_MODULE_0__.execute)(callback);
2659
- }
2660
- static _append() {
2661
- if (_dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find('.' + CLASS_NAME)) {
2662
- return false;
2663
- }
2664
- let backdrop = document.createElement('div');
2665
- backdrop.classList.add(CLASS_NAME);
2666
- document.body.append(backdrop);
2667
- setTimeout(() => {
2668
- backdrop.classList.add(CLASS_NAME_FADE);
2669
- }, 50);
2670
- _dom_event__WEBPACK_IMPORTED_MODULE_2__["default"].on(backdrop, EVENT_MOUSEDOWN, () => {
2671
- Backdrop.hide();
2672
- _overflow__WEBPACK_IMPORTED_MODULE_3__["default"].destroy();
2673
- });
2674
- }
2675
- static _destroy() {
2676
- let element = _dom_selectors__WEBPACK_IMPORTED_MODULE_1__["default"].find('.' + CLASS_NAME);
2677
- if (!element) return;
2678
- element.classList.remove(CLASS_NAME_FADE);
2679
- setTimeout(() => {
2680
- element.remove();
2681
- }, backdrop_delay);
2682
- }
2683
- }
2684
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Backdrop);
2685
-
2686
- /***/ }),
2687
-
2688
- /***/ "./app/utils/js/components/overflow.js":
2689
- /*!*********************************************!*\
2690
- !*** ./app/utils/js/components/overflow.js ***!
2691
- \*********************************************/
2692
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2693
-
2694
- __webpack_require__.r(__webpack_exports__);
2695
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2696
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2697
- /* harmony export */ });
2698
- /* harmony import */ var _dom_manipulator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../dom/manipulator */ "./app/utils/js/dom/manipulator.js");
2699
-
2700
-
2701
- /**
2702
- * Класс Overflow
2703
- * Запрещает скроллинг и убирает его, компенсируя отступом
2704
- */
2705
-
2706
- class Overflow {
2707
- static append() {
2708
- document.body.style.paddingRight = getWidth() + 'px';
2709
- document.body.style.overflow = 'hidden';
2710
- function getWidth() {
2711
- const documentWidth = document.documentElement.clientWidth;
2712
- return Math.abs(window.innerWidth - documentWidth);
2713
- }
2714
- }
2715
- static destroy() {
2716
- document.body.style.overflow = '';
2717
- document.body.style.paddingRight = '';
2718
- let styles = _dom_manipulator__WEBPACK_IMPORTED_MODULE_0__.Manipulator.get(document.body, 'style');
2719
- if (!styles) _dom_manipulator__WEBPACK_IMPORTED_MODULE_0__.Manipulator.remove(document.body, 'style');
2720
- }
2721
- }
2722
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Overflow);
2723
-
2724
- /***/ }),
2725
-
2726
- /***/ "./app/utils/js/components/params.js":
2727
- /*!*******************************************!*\
2728
- !*** ./app/utils/js/components/params.js ***!
2729
- \*******************************************/
2730
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2731
-
2732
- __webpack_require__.r(__webpack_exports__);
2733
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2734
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2735
- /* harmony export */ });
2736
- /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../functions */ "./app/utils/js/functions.js");
2737
- /* harmony import */ var _dom_manipulator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../dom/manipulator */ "./app/utils/js/dom/manipulator.js");
2738
-
2739
-
2740
- class Params {
2741
- constructor(params, element = null) {
2742
- this._params = this.merge(params, element);
2743
- }
2744
- get() {
2745
- return this._params;
2746
- }
2747
- fromElement(element) {
2748
- return (0,_functions__WEBPACK_IMPORTED_MODULE_0__.isElement)(element) ? _dom_manipulator__WEBPACK_IMPORTED_MODULE_1__.Manipulator.get(element) : {};
2749
- }
2750
- merge(params, element) {
2751
- let mParams = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.mergeDeepObject)(params, this.fromElement(element));
2752
- for (let key in mParams) {
2753
- if (key.indexOf('-') !== -1) {
2754
- let keys = key.split('-'),
2755
- value = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.normalizeData)(mParams[key]);
2756
- if (keys[0] in mParams) {
2757
- if (keys[1] in mParams[keys[0]]) {
2758
- mParams[keys[0]][keys[1]] = value;
2759
- }
2760
- }
2761
- delete mParams[key];
2762
- }
2763
- }
2764
- if ('params' in mParams) {
2765
- mParams = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.mergeDeepObject)(mParams, mParams.params);
2766
- delete mParams.params;
2767
- }
2768
- return mParams;
2769
- }
2770
- }
2771
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Params);
2772
-
2773
- /***/ }),
2774
-
2775
- /***/ "./app/utils/js/components/placement.js":
2776
- /*!**********************************************!*\
2777
- !*** ./app/utils/js/components/placement.js ***!
2778
- \**********************************************/
2779
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2780
-
2781
- __webpack_require__.r(__webpack_exports__);
2782
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2783
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2784
- /* harmony export */ });
2785
- /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../functions */ "./app/utils/js/functions.js");
2786
-
2787
-
2788
- /**
2789
- * Класс Placement, определяет и устанавливает местоположение элемента на странице.
2790
- * TODO класс не дописан
2791
- */
2792
-
2793
- class Placement {
2794
- constructor(arg = {}) {
2795
- this.params = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.mergeDeepObject)({
2796
- element: null,
2797
- drop: null
2798
- }, arg);
2799
- }
2800
- _getPlacement() {
2801
- const _this = this;
2802
- const _parent = self => {
2803
- let parent = self.parentNode,
2804
- overflow = getComputedStyle(parent).overflow;
2805
- if (parent.tagName !== 'BODY') {
2806
- if (overflow === 'visible') {
2807
- _parent(parent);
2808
- } else {
2809
- return parent;
2810
- }
2811
- } else {
2812
- return null;
2813
- }
2814
- };
2815
- let isFixed = false,
2816
- top,
2817
- left,
2818
- bounds = _this.params.drop.getBoundingClientRect(),
2819
- parent = _this.params.element.getBoundingClientRect();
2820
- if (_parent(_this.params.element)) {
2821
- isFixed = true;
2822
- top = bounds.top;
2823
- left = bounds.left;
2824
- } else {
2825
- let styles = getComputedStyle(_this.params.drop);
2826
- top = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.normalizeData)(styles.top.slice(0, -2));
2827
- left = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.normalizeData)(styles.left.slice(0, -2));
2828
- }
2829
- if (bounds.left + bounds.width > window.innerWidth) {
2830
- left = parent.width - bounds.width;
2831
- }
2832
- return {
2833
- isFixed: isFixed,
2834
- top: top,
2835
- left: left
2836
- };
2837
- }
2838
- }
2839
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Placement);
2840
-
2841
- /***/ }),
2842
-
2843
- /***/ "./app/utils/js/components/responsive.js":
2844
- /*!***********************************************!*\
2845
- !*** ./app/utils/js/components/responsive.js ***!
2846
- \***********************************************/
2847
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2848
-
2849
- __webpack_require__.r(__webpack_exports__);
2850
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2851
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2852
- /* harmony export */ });
2853
- /**
2854
- * Класс Responsive, работает по таким же медиа точкам, что и bootstrap
2855
- * и определяет на тач устройства.
2856
- */
2857
-
2858
- class Responsive {
2859
- constructor() {
2860
- this.breakpoints = {
2861
- xs: 0,
2862
- sm: 576,
2863
- md: 768,
2864
- lg: 992,
2865
- xl: 1200,
2866
- xxl: 1400,
2867
- xxxl: 1600
2868
- };
2869
- }
2870
-
2871
- /**
2872
- * Если наша ширина экрана совпадает с диапазоном который указан в модуле выдаем true, иначе false
2873
- * @param module
2874
- * @returns {boolean}
2875
- */
2876
- static check(module) {
2877
- let instance = new this();
2878
- return instance.define(module);
2879
- }
2880
-
2881
- /**
2882
- * Проверяет на тач устройства. TODO не совсем правильно, надо сделать по-другому
2883
- * @returns {boolean}
2884
- */
2885
- static checkMobileOrTablet() {
2886
- let check = false;
2887
- (function (a) {
2888
- if (/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(a) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.slice(0, 4))) {
2889
- check = true;
2890
- }
2891
- })(navigator.userAgent || navigator.vendor || window.opera);
2892
- return check;
2893
- }
2894
- define(module) {
2895
- let windowWidth = window.innerWidth,
2896
- responsive_size = this._checkResponsiveClass(module),
2897
- breakpoints = this.breakpoints,
2898
- point = Object.keys(breakpoints).find(key => breakpoints[key] === responsive_size);
2899
- let keys = Object.keys(breakpoints),
2900
- loc = keys.indexOf(point);
2901
- return windowWidth >= breakpoints[keys[loc + 1]];
2902
- }
2903
- _checkResponsiveClass(module) {
2904
- let element = module._element,
2905
- params = module._params,
2906
- current_responsive_size = 0;
2907
- if (element.classList.contains(params.classes.XXXL)) {
2908
- current_responsive_size = this.breakpoints.xxxl;
2909
- } else if (element.classList.contains(params.classes.XXL)) {
2910
- current_responsive_size = this.breakpoints.xxl;
2911
- } else if (element.classList.contains(params.classes.XL)) {
2912
- current_responsive_size = this.breakpoints.xl;
2913
- } else if (element.classList.contains(params.classes.LG)) {
2914
- current_responsive_size = this.breakpoints.lg;
2915
- } else if (element.classList.contains(params.classes.MD)) {
2916
- current_responsive_size = this.breakpoints.md;
2917
- } else if (element.classList.contains(params.classes.SM)) {
2918
- current_responsive_size = this.breakpoints.sm;
2919
- } else if (element.classList.contains(params.classes.XS)) {
2920
- current_responsive_size = this.breakpoints.xs;
2921
- } else {
2922
- current_responsive_size = this.breakpoints.xs;
2923
- }
2924
- return current_responsive_size;
2925
- }
2926
- }
2927
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Responsive);
2928
-
2929
- /***/ }),
2930
-
2931
- /***/ "./app/utils/js/components/scrollbar.js":
2932
- /*!**********************************************!*\
2933
- !*** ./app/utils/js/components/scrollbar.js ***!
2934
- \**********************************************/
2935
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2936
-
2937
- __webpack_require__.r(__webpack_exports__);
2938
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2939
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
2940
- /* harmony export */ });
2941
- /* harmony import */ var _dom_manipulator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../dom/manipulator */ "./app/utils/js/dom/manipulator.js");
2942
- /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../functions */ "./app/utils/js/functions.js");
2943
- /* harmony import */ var _dom_selectors__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../dom/selectors */ "./app/utils/js/dom/selectors.js");
2944
- /**
2945
- * --------------------------------------------------------------------------
2946
- * Bootstrap util/scrollBar.js
2947
- * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
2948
- * --------------------------------------------------------------------------
2949
- */
2950
-
2951
-
2952
-
2953
-
2954
-
2955
- /**
2956
- * Constants
2957
- */
2958
-
2959
- const SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top';
2960
- const SELECTOR_STICKY_CONTENT = '.sticky-top';
2961
- const PROPERTY_PADDING = 'padding-right';
2962
- const PROPERTY_MARGIN = 'margin-right';
2963
-
2964
- /**
2965
- * Class definition
2966
- */
2967
-
2968
- class ScrollBarHelper {
2969
- constructor() {
2970
- this._element = document.body;
2971
- }
2972
-
2973
- // Public
2974
- getWidth() {
2975
- // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes
2976
- const documentWidth = document.documentElement.clientWidth;
2977
- return Math.abs(window.innerWidth - documentWidth);
2978
- }
2979
- hide() {
2980
- const width = this.getWidth();
2981
- this._disableOverFlow();
2982
- // give padding to element to balance the hidden scrollbar width
2983
- this._setElementAttributes(this._element, PROPERTY_PADDING, calculatedValue => calculatedValue + width);
2984
- // trick: We adjust positive paddingRight and negative marginRight to sticky-top elements to keep showing fullwidth
2985
- this._setElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING, calculatedValue => calculatedValue + width);
2986
- this._setElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN, calculatedValue => calculatedValue - width);
2987
- }
2988
- reset() {
2989
- this._resetElementAttributes(this._element, 'overflow');
2990
- this._resetElementAttributes(this._element, PROPERTY_PADDING);
2991
- this._resetElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING);
2992
- this._resetElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN);
2993
- }
2994
- isOverflowing() {
2995
- return this.getWidth() > 0;
2996
- }
2997
-
2998
- // Private
2999
- _disableOverFlow() {
3000
- this._saveInitialAttribute(this._element, 'overflow');
3001
- this._element.style.overflow = 'hidden';
3002
- }
3003
- _setElementAttributes(selector, styleProperty, callback) {
3004
- const scrollbarWidth = this.getWidth();
3005
- const manipulationCallBack = element => {
3006
- if (element !== this._element && window.innerWidth > element.clientWidth + scrollbarWidth) {
3007
- return;
3008
- }
3009
- this._saveInitialAttribute(element, styleProperty);
3010
- const calculatedValue = window.getComputedStyle(element).getPropertyValue(styleProperty);
3011
- element.style.setProperty(styleProperty, `${callback(Number.parseFloat(calculatedValue))}px`);
3012
- };
3013
- this._applyManipulationCallback(selector, manipulationCallBack);
3014
- }
3015
- _saveInitialAttribute(element, styleProperty) {
3016
- const actualValue = element.style.getPropertyValue(styleProperty);
3017
- if (actualValue) {
3018
- _dom_manipulator__WEBPACK_IMPORTED_MODULE_0__.Manipulator.get(element, styleProperty, actualValue);
3019
- }
3020
- }
3021
- _resetElementAttributes(selector, styleProperty) {
3022
- const manipulationCallBack = element => {
3023
- const value = _dom_manipulator__WEBPACK_IMPORTED_MODULE_0__.Manipulator.get(element, styleProperty);
3024
- // We only want to remove the property if the value is `null`; the value can also be zero
3025
- if (value === null) {
3026
- element.style.removeProperty(styleProperty);
3027
- return;
3028
- }
3029
- _dom_manipulator__WEBPACK_IMPORTED_MODULE_0__.Manipulator.remove(element, styleProperty);
3030
- element.style.setProperty(styleProperty, value);
3031
- };
3032
- this._applyManipulationCallback(selector, manipulationCallBack);
3033
- }
3034
- _applyManipulationCallback(selector, callBack) {
3035
- if ((0,_functions__WEBPACK_IMPORTED_MODULE_1__.isElement)(selector)) {
3036
- callBack(selector);
3037
- return;
3038
- }
3039
- for (const sel of _dom_selectors__WEBPACK_IMPORTED_MODULE_2__["default"].findAll(selector, this._element)) {
3040
- callBack(sel);
3041
- }
3042
- }
3043
- }
3044
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ScrollBarHelper);
3045
-
3046
- /***/ }),
3047
-
3048
- /***/ "./app/utils/js/dom/cookie.js":
3049
- /*!************************************!*\
3050
- !*** ./app/utils/js/dom/cookie.js ***!
3051
- \************************************/
3052
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3053
-
3054
- __webpack_require__.r(__webpack_exports__);
3055
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3056
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
3057
- /* harmony export */ });
3058
- /*! js-cookie v3.0.1 | MIT */
3059
-
3060
- function assign(target) {
3061
- for (let i = 1; i < arguments.length; i++) {
3062
- let source = arguments[i];
3063
- for (let key in source) {
3064
- target[key] = source[key];
3065
- }
3066
- }
3067
- return target;
3068
- }
3069
- let defaultConverter = {
3070
- read: function (value) {
3071
- if (value[0] === '"') {
3072
- value = value.slice(1, -1);
3073
- }
3074
- return value.replace(/(%[\dA-F]{2})+/gi, decodeURIComponent);
3075
- },
3076
- write: function (value) {
3077
- return encodeURIComponent(value).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g, decodeURIComponent);
3078
- }
3079
- };
3080
- function init(converter, defaultAttributes) {
3081
- function set(key, value, attributes) {
3082
- if (typeof document === 'undefined') {
3083
- return;
3084
- }
3085
- attributes = assign({}, defaultAttributes, attributes);
3086
- if (typeof attributes.expires === 'number') {
3087
- attributes.expires = new Date(Date.now() + attributes.expires * 864e5);
3088
- }
3089
- if (attributes.expires) {
3090
- attributes.expires = attributes.expires.toUTCString();
3091
- }
3092
- key = encodeURIComponent(key).replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent).replace(/[()]/g, escape);
3093
- let stringifiedAttributes = '';
3094
- for (let attributeName in attributes) {
3095
- if (!attributes[attributeName]) {
3096
- continue;
3097
- }
3098
- stringifiedAttributes += '; ' + attributeName;
3099
- if (attributes[attributeName] === true) {
3100
- continue;
3101
- }
3102
-
3103
- // Considers RFC 6265 section 5.2:
3104
- // ...
3105
- // 3. If the remaining unparsed-attributes contains a %x3B (";")
3106
- // character:
3107
- // Consume the characters of the unparsed-attributes up to,
3108
- // not including, the first %x3B (";") character.
3109
- // ...
3110
- stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];
3111
- }
3112
- return document.cookie = key + '=' + converter.write(value, key) + stringifiedAttributes;
3113
- }
3114
- function get(key) {
3115
- if (typeof document === 'undefined' || arguments.length && !key) {
3116
- return;
3117
- }
3118
-
3119
- // To prevent the for loop in the first place assign an empty array
3120
- // in case there are no cookies at all.
3121
- let cookies = document.cookie ? document.cookie.split('; ') : [];
3122
- let jar = {};
3123
- for (let i = 0; i < cookies.length; i++) {
3124
- let parts = cookies[i].split('=');
3125
- let value = parts.slice(1).join('=');
3126
- try {
3127
- let foundKey = decodeURIComponent(parts[0]);
3128
- jar[foundKey] = converter.read(value, foundKey);
3129
- if (key === foundKey) {
3130
- break;
3131
- }
3132
- } catch (e) {}
3133
- }
3134
- return key ? jar[key] : jar;
3135
- }
3136
- return Object.create({
3137
- set: set,
3138
- get: get,
3139
- remove: function (key, attributes) {
3140
- set(key, '', assign({}, attributes, {
3141
- expires: -1
3142
- }));
3143
- },
3144
- withAttributes: function (attributes) {
3145
- return init(this.converter, assign({}, this.attributes, attributes));
3146
- },
3147
- withConverter: function (converter) {
3148
- return init(assign({}, this.converter, converter), this.attributes);
3149
- }
3150
- }, {
3151
- attributes: {
3152
- value: Object.freeze(defaultAttributes)
3153
- },
3154
- converter: {
3155
- value: Object.freeze(converter)
3156
- }
3157
- });
3158
- }
3159
- let api = init(defaultConverter, {
3160
- path: '/'
3161
- });
3162
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (api);
3163
-
3164
- /***/ }),
3165
-
3166
- /***/ "./app/utils/js/dom/data.js":
3167
- /*!**********************************!*\
3168
- !*** ./app/utils/js/dom/data.js ***!
3169
- \**********************************/
3170
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3171
-
3172
- __webpack_require__.r(__webpack_exports__);
3173
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3174
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
3175
- /* harmony export */ });
3176
- /**
3177
- * --------------------------------------------------------------------------
3178
- * Bootstrap data.js
3179
- * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
3180
- * --------------------------------------------------------------------------
3181
- * Скрипт работает с коллекцией модулей. Подробнее тут https://learn.javascript.ru/map-set
3182
- */
3183
-
3184
- /**
3185
- * Константы
3186
- */
3187
-
3188
- const elementMap = new Map();
3189
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({
3190
- set(element, key, instance) {
3191
- if (!elementMap.has(element)) {
3192
- elementMap.set(element, new Map());
3193
- }
3194
- const instanceMap = elementMap.get(element);
3195
- if (!instanceMap.has(key) && instanceMap.size !== 0) {
3196
- console.error(`VGApp не допускает более одного экземпляра для каждого элемента. Связанный экземпляр: ${Array.from(instanceMap.keys())[0]}.`);
3197
- return;
3198
- }
3199
- instanceMap.set(key, instance);
3200
- },
3201
- get(element, key) {
3202
- if (elementMap.has(element)) {
3203
- return elementMap.get(element).get(key) || null;
3204
- }
3205
- return null;
3206
- },
3207
- remove(element, key) {
3208
- if (!elementMap.has(element)) {
3209
- return;
3210
- }
3211
- const instanceMap = elementMap.get(element);
3212
- instanceMap.delete(key);
3213
- if (instanceMap.size === 0) {
3214
- elementMap.delete(element);
3215
- }
3216
- }
3217
- });
3218
-
3219
- /***/ }),
3220
-
3221
- /***/ "./app/utils/js/dom/event.js":
3222
- /*!***********************************!*\
3223
- !*** ./app/utils/js/dom/event.js ***!
3224
- \***********************************/
3225
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3226
-
3227
- __webpack_require__.r(__webpack_exports__);
3228
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3229
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
3230
- /* harmony export */ });
3231
- /**
3232
- * --------------------------------------------------------------------------
3233
- * Bootstrap event.js
3234
- * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
3235
- * --------------------------------------------------------------------------
3236
- * Скрипт для прослушивания события
3237
- */
3238
-
3239
- /**
3240
- * Константы
3241
- */
3242
-
3243
- const namespaceRegex = /[^.]*(?=\..*)\.|.*/;
3244
- const stripNameRegex = /\..*/;
3245
- const stripUidRegex = /::\d+$/;
3246
- const eventRegistry = {}; // Events storage
3247
- let uidEvent = 1;
3248
- const customEvents = {
3249
- mouseenter: 'mouseover',
3250
- mouseleave: 'mouseout'
3251
- };
3252
- const nativeEvents = new Set(['click', 'dblclick', 'mouseup', 'mousedown', 'contextmenu', 'mousewheel', 'DOMMouseScroll', 'mouseover', 'mouseout', 'mousemove', 'selectstart', 'selectend', 'submit', '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']);
3253
-
3254
- /**
3255
- * Приватные методы
3256
- */
3257
-
3258
- function makeEventUid(element, uid) {
3259
- return uid && `${uid}::${uidEvent++}` || element.uidEvent || uidEvent++;
3260
- }
3261
- function getElementEvents(element) {
3262
- const uid = makeEventUid(element);
3263
- element.uidEvent = uid;
3264
- eventRegistry[uid] = eventRegistry[uid] || {};
3265
- return eventRegistry[uid];
3266
- }
3267
- function bootstrapHandler(element, fn) {
3268
- return function handler(event) {
3269
- hydrateObj(event, {
3270
- delegateTarget: element
3271
- });
3272
- if (handler.oneOff) {
3273
- EventHandler.off(element, event.type, fn);
3274
- }
3275
- return fn.apply(element, [event]);
3276
- };
3277
- }
3278
- function bootstrapDelegationHandler(element, selector, fn) {
3279
- return function handler(event) {
3280
- const domElements = element.querySelectorAll(selector);
3281
- for (let {
3282
- target
3283
- } = event; target && target !== this; target = target.parentNode) {
3284
- for (const domElement of domElements) {
3285
- if (domElement !== target) {
3286
- continue;
3287
- }
3288
- hydrateObj(event, {
3289
- delegateTarget: target
3290
- });
3291
- if (handler.oneOff) {
3292
- EventHandler.off(element, event.type, selector, fn);
3293
- }
3294
- return fn.apply(target, [event]);
3295
- }
3296
- }
3297
- };
3298
- }
3299
- function findHandler(events, callable, delegationSelector = null) {
3300
- return Object.values(events).find(event => event.callable === callable && event.delegationSelector === delegationSelector);
3301
- }
3302
- function normalizeParameters(originalTypeEvent, handler, delegationFunction) {
3303
- const isDelegated = typeof handler === 'string';
3304
- // TODO: выдает "false" вместо селектора, поэтому нужно проверить. boot
3305
- const callable = isDelegated ? delegationFunction : handler || delegationFunction;
3306
- let typeEvent = getTypeEvent(originalTypeEvent);
3307
- if (!nativeEvents.has(typeEvent)) {
3308
- typeEvent = originalTypeEvent;
3309
- }
3310
- return [isDelegated, callable, typeEvent];
3311
- }
3312
- function addHandler(element, originalTypeEvent, handler, delegationFunction, oneOff) {
3313
- if (typeof originalTypeEvent !== 'string' || !element) {
3314
- return;
3315
- }
3316
- let [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction);
3317
-
3318
- // in case of mouseenter or mouseleave wrap the handler within a function that checks for its DOM position
3319
- // this prevents the handler from being dispatched the same way as mouseover or mouseout does
3320
- if (originalTypeEvent in customEvents) {
3321
- const wrapFunction = fn => {
3322
- return function (event) {
3323
- if (!event.relatedTarget || event.relatedTarget !== event.delegateTarget && !event.delegateTarget.contains(event.relatedTarget)) {
3324
- return fn.call(this, event);
3325
- }
3326
- };
3327
- };
3328
- callable = wrapFunction(callable);
3329
- }
3330
- const events = getElementEvents(element);
3331
- const handlers = events[typeEvent] || (events[typeEvent] = {});
3332
- const previousFunction = findHandler(handlers, callable, isDelegated ? handler : null);
3333
- if (previousFunction) {
3334
- previousFunction.oneOff = previousFunction.oneOff && oneOff;
3335
- return;
3336
- }
3337
- const uid = makeEventUid(callable, originalTypeEvent.replace(namespaceRegex, ''));
3338
- const fn = isDelegated ? bootstrapDelegationHandler(element, handler, callable) : bootstrapHandler(element, callable);
3339
- fn.delegationSelector = isDelegated ? handler : null;
3340
- fn.callable = callable;
3341
- fn.oneOff = oneOff;
3342
- fn.uidEvent = uid;
3343
- handlers[uid] = fn;
3344
- element.addEventListener(typeEvent, fn, isDelegated);
3345
- }
3346
- function removeHandler(element, events, typeEvent, handler, delegationSelector) {
3347
- const fn = findHandler(events[typeEvent], handler, delegationSelector);
3348
- if (!fn) {
3349
- return;
3350
- }
3351
- element.removeEventListener(typeEvent, fn, Boolean(delegationSelector));
3352
- delete events[typeEvent][fn.uidEvent];
3353
- }
3354
- function removeNamespacedHandlers(element, events, typeEvent, namespace) {
3355
- const storeElementEvent = events[typeEvent] || {};
3356
- for (const [handlerKey, event] of Object.entries(storeElementEvent)) {
3357
- if (handlerKey.includes(namespace)) {
3358
- removeHandler(element, events, typeEvent, event.callable, event.delegationSelector);
3359
- }
3360
- }
3361
- }
3362
- function getTypeEvent(event) {
3363
- // allow to get the native events from namespaced events ('click.bs.button' --> 'click')
3364
- event = event.replace(stripNameRegex, '');
3365
- return customEvents[event] || event;
3366
- }
3367
- function hydrateObj(obj, meta = {}) {
3368
- for (const [key, value] of Object.entries(meta)) {
3369
- try {
3370
- obj[key] = value;
3371
- } catch {
3372
- Object.defineProperty(obj, key, {
3373
- configurable: true,
3374
- get() {
3375
- return value;
3376
- }
3377
- });
3378
- }
3379
- }
3380
- return obj;
3381
- }
3382
-
3383
- /**
3384
- * События
3385
- * @type {{one(*, *, *, *): void, trigger(*, *, *): (null|*), off(*, *, *, *): void, on(*, *, *, *): void}}
3386
- */
3387
- const EventHandler = {
3388
- /**
3389
- * Прослушиватель событий (элемент, событие (полный список смотри в константе nativeEvents, источник события или хендлер, функция обратного вызова))
3390
- * @param element
3391
- * @param event
3392
- * @param handler
3393
- * @param delegationFunction
3394
- */
3395
- on(element, event, handler, delegationFunction) {
3396
- addHandler(element, event, handler, delegationFunction, false);
3397
- },
3398
- /**
3399
- * Прослушиватель событий, но замыкается и больше не повторяется на элементе
3400
- * @param element
3401
- * @param event
3402
- * @param handler
3403
- * @param delegationFunction
3404
- */
3405
- one(element, event, handler, delegationFunction) {
3406
- addHandler(element, event, handler, delegationFunction, true);
3407
- },
3408
- /**
3409
- * Удаление обработчика
3410
- * @param element
3411
- * @param originalTypeEvent
3412
- * @param handler
3413
- * @param delegationFunction
3414
- */
3415
- off(element, originalTypeEvent, handler, delegationFunction) {
3416
- if (typeof originalTypeEvent !== 'string' || !element) {
3417
- return;
3418
- }
3419
- const [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction);
3420
- const inNamespace = typeEvent !== originalTypeEvent;
3421
- const events = getElementEvents(element);
3422
- const storeElementEvent = events[typeEvent] || {};
3423
- const isNamespace = originalTypeEvent.startsWith('.');
3424
- if (typeof callable !== 'undefined') {
3425
- // Simplest case: handler is passed, remove that listener ONLY.
3426
- if (!Object.keys(storeElementEvent).length) {
3427
- return;
3428
- }
3429
- removeHandler(element, events, typeEvent, callable, isDelegated ? handler : null);
3430
- return;
3431
- }
3432
- if (isNamespace) {
3433
- for (const elementEvent of Object.keys(events)) {
3434
- removeNamespacedHandlers(element, events, elementEvent, originalTypeEvent.slice(1));
3435
- }
3436
- }
3437
- for (const [keyHandlers, event] of Object.entries(storeElementEvent)) {
3438
- const handlerKey = keyHandlers.replace(stripUidRegex, '');
3439
- if (!inNamespace || originalTypeEvent.includes(handlerKey)) {
3440
- removeHandler(element, events, typeEvent, event.callable, event.delegationSelector);
3441
- }
3442
- }
3443
- },
3444
- /**
3445
- * Пользовательские события. Подробнее тут https://learn.javascript.ru/dispatch-events
3446
- * @param element
3447
- * @param event
3448
- * @param args
3449
- * @returns {*|null}
3450
- */
3451
- trigger(element, event, args) {
3452
- if (typeof event !== 'string' || !element) {
3453
- return null;
3454
- }
3455
- let bubbles = true;
3456
- let nativeDispatch = true;
3457
- let defaultPrevented = false;
3458
- const evt = hydrateObj(new Event(event, {
3459
- bubbles,
3460
- cancelable: true
3461
- }), args);
3462
- if (defaultPrevented) {
3463
- evt.preventDefault();
3464
- }
3465
- if (nativeDispatch) {
3466
- element.dispatchEvent(evt);
3467
- }
3468
- return evt;
3469
- }
3470
- };
3471
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (EventHandler);
3472
-
3473
- /***/ }),
3474
-
3475
- /***/ "./app/utils/js/dom/manipulator.js":
3476
- /*!*****************************************!*\
3477
- !*** ./app/utils/js/dom/manipulator.js ***!
3478
- \*****************************************/
3479
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3480
-
3481
- __webpack_require__.r(__webpack_exports__);
3482
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3483
- /* harmony export */ Manipulator: () => (/* binding */ Manipulator)
3484
- /* harmony export */ });
3485
- /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../functions */ "./app/utils/js/functions.js");
3486
-
3487
-
3488
- /**
3489
- * Манипуляции с атрибутами у элемента:
3490
- * get (элемент, имя, флаг - вырезать data-) - метод выбирает значение атрибута по его имени, если в поле имени передать 'data' -> будут выбраны только дата атрибуты, если 'all' -> метод вернет значение всех атрибутов
3491
- * has (элемент, имя) - есть ли атрибут у элемента
3492
- * set (элемент, имя, значение) - установка у элемента атрибута или его изменение
3493
- * remove (элемент, имя) - удаляет атрибут у элемента
3494
- */
3495
- const Manipulator = {
3496
- get(element, nameAttribute = 'data', isRemoveDataName = true) {
3497
- if (!element) {
3498
- return {};
3499
- }
3500
- if (nameAttribute === 'data') {
3501
- let elmBase = ['data-vg-toggle', 'data-vg-target', 'data-vg-dismiss'],
3502
- attributes = {};
3503
- let arr = [].filter.call(element.attributes, function (at) {
3504
- return /^data-/.test(at.name);
3505
- });
3506
- if (arr.length) {
3507
- arr.forEach(function (v) {
3508
- let name = v.name;
3509
- if (!elmBase.includes(name)) {
3510
- if (isRemoveDataName) name = name.slice(5);
3511
- attributes[name] = (0,_functions__WEBPACK_IMPORTED_MODULE_0__.normalizeData)(v.value);
3512
- }
3513
- });
3514
- }
3515
- return attributes;
3516
- } else if (nameAttribute === 'all') {
3517
- return element.getAttributeNames().reduce((acc, name) => {
3518
- return {
3519
- ...acc,
3520
- [name]: element.getAttribute(name)
3521
- };
3522
- }, {});
3523
- } else {
3524
- return element.getAttribute(nameAttribute);
3525
- }
3526
- },
3527
- has(element, nameAttribute) {
3528
- return element.hasAttribute(nameAttribute);
3529
- },
3530
- set(element, name, value) {
3531
- if ((0,_functions__WEBPACK_IMPORTED_MODULE_0__.isElement)(element) && name) {
3532
- element.setAttribute(name, value);
3533
- }
3534
- },
3535
- remove(element, nameAttribute) {
3536
- if ((0,_functions__WEBPACK_IMPORTED_MODULE_0__.isElement)(element) && nameAttribute) {
3537
- element.removeAttribute(nameAttribute);
3538
- }
3539
- },
3540
- hide(el) {
3541
- el.style.display = 'none';
3542
- },
3543
- show(el, state = 'block') {
3544
- el.style.display = state;
3545
- }
3546
- };
3547
-
3548
-
3549
- /***/ }),
3550
-
3551
- /***/ "./app/utils/js/dom/selectors.js":
3552
- /*!***************************************!*\
3553
- !*** ./app/utils/js/dom/selectors.js ***!
3554
- \***************************************/
3555
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3556
-
3557
- __webpack_require__.r(__webpack_exports__);
3558
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3559
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
3560
- /* harmony export */ });
3561
- /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../functions */ "./app/utils/js/functions.js");
3562
- /**
3563
- * Работа с DOM
3564
- * @param selector
3565
- * @returns {*}
3566
- */
3567
-
3568
- const parseSelector = selector => {
3569
- if (selector && window.CSS && window.CSS.escape) {
3570
- selector = selector.replace(/#([^\s"#']+)/g, (match, id) => `#${CSS.escape(id)}`);
3571
- }
3572
- return selector;
3573
- };
3574
- const getSelector = element => {
3575
- let selector = element.getAttribute('data-vg-target');
3576
- if (!selector || selector === '#') {
3577
- let hrefAttribute = element.getAttribute('href');
3578
- if (!hrefAttribute || !hrefAttribute.includes('#') && !hrefAttribute.startsWith('.')) {
3579
- return null;
3580
- }
3581
- if (hrefAttribute.includes('#') && !hrefAttribute.startsWith('#')) {
3582
- hrefAttribute = `#${hrefAttribute.split('#')[1]}`;
3583
- }
3584
- selector = hrefAttribute && hrefAttribute !== '#' ? hrefAttribute.trim() : null;
3585
- }
3586
- return selector ? selector.split(',').map(sel => parseSelector(sel)).join(',') : null;
3587
- };
3588
- const Selectors = {
3589
- find(selector, element = document.documentElement) {
3590
- if ((0,_functions__WEBPACK_IMPORTED_MODULE_0__.isElement)(selector)) {
3591
- return selector;
3592
- } else {
3593
- return Element.prototype.querySelector.call(element, selector);
3594
- }
3595
- },
3596
- findAll(selector, container = document.documentElement) {
3597
- return [].concat(...Element.prototype.querySelectorAll.call(container, selector));
3598
- },
3599
- getSelectorFromElement(element) {
3600
- const selector = getSelector(element);
3601
- if (selector) return Selectors.find(selector) ? selector : null;
3602
- return null;
3603
- },
3604
- getElementFromSelector(element) {
3605
- const selector = getSelector(element);
3606
- return selector ? Selectors.find(selector) : null;
3607
- },
3608
- getMultipleElementsFromSelector(element) {
3609
- const selector = getSelector(element);
3610
- return selector ? Selectors.findAll(selector) : [];
3611
- }
3612
- };
3613
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Selectors);
3614
-
3615
- /***/ }),
3616
-
3617
- /***/ "./app/utils/js/functions.js":
3618
- /*!***********************************!*\
3619
- !*** ./app/utils/js/functions.js ***!
3620
- \***********************************/
3621
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3622
-
3623
- __webpack_require__.r(__webpack_exports__);
3624
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
3625
- /* harmony export */ execute: () => (/* binding */ execute),
3626
- /* harmony export */ executeAfterTransition: () => (/* binding */ executeAfterTransition),
3627
- /* harmony export */ isDisabled: () => (/* binding */ isDisabled),
3628
- /* harmony export */ isElement: () => (/* binding */ isElement),
3629
- /* harmony export */ isEmptyObj: () => (/* binding */ isEmptyObj),
3630
- /* harmony export */ isObject: () => (/* binding */ isObject),
3631
- /* harmony export */ isRTL: () => (/* binding */ isRTL),
3632
- /* harmony export */ isVisible: () => (/* binding */ isVisible),
3633
- /* harmony export */ makeRandomString: () => (/* binding */ makeRandomString),
3634
- /* harmony export */ mergeDeepObject: () => (/* binding */ mergeDeepObject),
3635
- /* harmony export */ noop: () => (/* binding */ noop),
3636
- /* harmony export */ normalizeData: () => (/* binding */ normalizeData),
3637
- /* harmony export */ reflow: () => (/* binding */ reflow),
3638
- /* harmony export */ removeElementArray: () => (/* binding */ removeElementArray),
3639
- /* harmony export */ transliterate: () => (/* binding */ transliterate)
3640
- /* harmony export */ });
3641
- /**
3642
- * Набор скриптов для широкого применения
3643
- */
3644
-
3645
- /**
3646
- * Если что-нибудь в объекте
3647
- * @param obj
3648
- * @returns {boolean}
3649
- */
3650
- function isEmptyObj(obj) {
3651
- for (let prop in obj) {
3652
- if (Object.prototype.hasOwnProperty.call(obj, prop)) {
3653
- return false;
3654
- }
3655
- }
3656
- return true;
3657
- }
3658
-
3659
- /**
3660
- * isElement
3661
- * @param object
3662
- * @returns {boolean}
3663
- */
3664
- const isElement = object => {
3665
- if (!isObject(object)) {
3666
- return false;
3667
- }
3668
- return typeof object.nodeType !== 'undefined';
3669
- };
3670
-
3671
- /**
3672
- * isDisabled
3673
- * @param element
3674
- * @returns {boolean}
3675
- */
3676
- const isDisabled = element => {
3677
- if (!element || element.nodeType !== Node.ELEMENT_NODE) {
3678
- return true;
3679
- }
3680
- if (element.classList.contains('disabled')) {
3681
- return true;
3682
- }
3683
- if (typeof element.disabled !== 'undefined') {
3684
- return element.disabled;
3685
- }
3686
- return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false';
3687
- };
3688
-
3689
- /**
3690
- * isVisible
3691
- * @param element
3692
- * @returns {boolean}
3693
- */
3694
- function isVisible(element) {
3695
- if (!isElement(element) || element.getClientRects().length === 0) {
3696
- return false;
3697
- }
3698
- const elementIsVisible = getComputedStyle(element).getPropertyValue('visibility') === 'visible';
3699
- const closedDetails = element.closest('details:not([open])');
3700
- if (!closedDetails) {
3701
- return elementIsVisible;
3702
- }
3703
- if (closedDetails !== element) {
3704
- const summary = element.closest('summary');
3705
- if (summary && summary.parentNode !== closedDetails) {
3706
- return false;
3707
- }
3708
- if (summary === null) {
3709
- return false;
3710
- }
3711
- }
3712
- return elementIsVisible;
3713
- }
3714
-
3715
- /**
3716
- * isObject
3717
- * @param obj
3718
- * @returns {boolean}
3719
- */
3720
- function isObject(obj) {
3721
- return obj && typeof obj === 'object';
3722
- }
3723
-
3724
- /**
3725
- * Приводим в порядок типы данных
3726
- * @param value
3727
- * @returns {any}
3728
- */
3729
- function normalizeData(value) {
3730
- if (value === 'true') {
3731
- return true;
3732
- }
3733
- if (value === 'false') {
3734
- return false;
3735
- }
3736
- if (value === Number(value).toString()) {
3737
- return Number(value);
3738
- }
3739
- if (value === '' || value === 'null') {
3740
- return null;
3741
- }
3742
- if (typeof value !== 'string') {
3743
- return value;
3744
- }
3745
- try {
3746
- return JSON.parse(decodeURIComponent(value));
3747
- } catch {
3748
- return value;
3749
- }
3750
- }
3751
-
3752
- /**
3753
- * Удаляем элементы с массива
3754
- * @param arr
3755
- * @param el
3756
- */
3757
- function removeElementArray(arr, el) {
3758
- return arr.filter(item => !el.includes(item));
3759
- }
3760
-
3761
- /**
3762
- * Глубокое объединение объектов
3763
- * @param objects
3764
- * @returns {*}
3765
- */
3766
- function mergeDeepObject(...objects) {
3767
- const isObject = obj => obj && typeof obj === 'object';
3768
- return objects.reduce((prev, obj) => {
3769
- Object.keys(obj).forEach(key => {
3770
- const pVal = prev[key];
3771
- const oVal = obj[key];
3772
- if (Array.isArray(pVal) && Array.isArray(oVal)) {
3773
- prev[key] = pVal.concat(...oVal);
3774
- } else if (isObject(pVal) && isObject(oVal)) {
3775
- prev[key] = mergeDeepObject(pVal, oVal);
3776
- } else {
3777
- prev[key] = oVal;
3778
- }
3779
- });
3780
- return prev;
3781
- }, {});
3782
- }
3783
-
3784
- /**
3785
- * Callback
3786
- * @param possibleCallback
3787
- * @param args
3788
- * @param defaultValue
3789
- * @returns {*}
3790
- */
3791
- function execute(possibleCallback, args = [], defaultValue = possibleCallback) {
3792
- return typeof possibleCallback === 'function' ? possibleCallback(...args) : defaultValue;
3793
- }
3794
-
3795
- /**
3796
- * Transition
3797
- * @param callback
3798
- * @param transitionElement
3799
- * @param waitForTransition
3800
- */
3801
- const TRANSITION_END = 'transitionend';
3802
- const MILLISECONDS_MULTIPLIER = 1000;
3803
- function executeAfterTransition(callback, transitionElement, waitForTransition = true, timeOutMs) {
3804
- if (!waitForTransition) {
3805
- execute(callback);
3806
- return;
3807
- }
3808
- const durationPadding = 5;
3809
- const emulatedDuration = timeOutMs ? timeOutMs : getTransitionDurationFromElement(transitionElement) + durationPadding;
3810
- let called = false;
3811
- const handler = ({
3812
- target
3813
- }) => {
3814
- if (target !== transitionElement) {
3815
- return;
3816
- }
3817
- called = true;
3818
- transitionElement.removeEventListener(TRANSITION_END, handler);
3819
- execute(callback);
3820
- };
3821
- transitionElement.addEventListener(TRANSITION_END, handler);
3822
- setTimeout(() => {
3823
- if (!called) {
3824
- triggerTransitionEnd(transitionElement);
3825
- }
3826
- }, emulatedDuration);
3827
- }
3828
- const getTransitionDurationFromElement = element => {
3829
- if (!element) {
3830
- return 0;
3831
- }
3832
-
3833
- // Get transition-duration of the element
3834
- let {
3835
- transitionDuration,
3836
- transitionDelay
3837
- } = window.getComputedStyle(element);
3838
- const floatTransitionDuration = Number.parseFloat(transitionDuration);
3839
- const floatTransitionDelay = Number.parseFloat(transitionDelay);
3840
-
3841
- // Return 0 if element or transition duration is not found
3842
- if (!floatTransitionDuration && !floatTransitionDelay) {
3843
- return 0;
3844
- }
3845
-
3846
- // If multiple durations are defined, take the first
3847
- transitionDuration = transitionDuration.split(',')[0];
3848
- transitionDelay = transitionDelay.split(',')[0];
3849
- return (Number.parseFloat(transitionDuration) + Number.parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER;
3850
- };
3851
- const triggerTransitionEnd = element => {
3852
- element.dispatchEvent(new Event(TRANSITION_END));
3853
- };
3854
-
3855
- /**
3856
- * Трюк для перезапуска анимации элемента
3857
- *
3858
- * @param {HTMLElement} element
3859
- * @return void
3860
- *
3861
- * @смотри https://www.charistheo.io/blog/2021/02/restart-a-css-animation-with-javascript/#restarting-a-css-animation
3862
- */
3863
- const reflow = element => {
3864
- element.offsetHeight; // eslint-disable-line no-unused-expressions
3865
- };
3866
-
3867
- /**
3868
- * Noop
3869
- */
3870
- const noop = () => {};
3871
-
3872
- /**
3873
- * Генерация случайной строки
3874
- */
3875
- function makeRandomString(length = 7) {
3876
- let result = '';
3877
- const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
3878
- const charactersLength = characters.length;
3879
- let counter = 0;
3880
- while (counter < length) {
3881
- result += characters.charAt(Math.floor(Math.random() * charactersLength));
3882
- counter += 1;
3883
- }
3884
- return result;
3885
- }
3886
-
3887
- /**
3888
- * Транслитерация символов с латиницы на кириллицу и обратно
3889
- * @param text
3890
- * @param enToRu
3891
- * @returns {*}
3892
- */
3893
- function transliterate(text, enToRu) {
3894
- let ru = "й ц у к е н г ш щ з х ъ ф ы в а п р о л д ж э я ч с м и т ь б ю".split(/ +/g);
3895
- let en = "q w e r t y u i o p [ ] a s d f g h j k l ; ' z x c v b n m , .".split(/ +/g);
3896
- let x;
3897
- for (x = 0; x < ru.length; x++) {
3898
- text = text.split(enToRu ? en[x] : ru[x]).join(enToRu ? ru[x] : en[x]);
3899
- text = text.split(enToRu ? en[x].toUpperCase() : ru[x].toUpperCase()).join(enToRu ? ru[x].toUpperCase() : en[x].toUpperCase());
3900
- }
3901
- return text;
3902
- }
3903
-
3904
- /**
3905
- *
3906
- */
3907
- const isRTL = () => document.documentElement.dir === 'rtl';
3908
-
3909
-
3910
- /***/ }),
3911
-
3912
- /***/ "./app/modules/vgdropdown/scss/vgdropdown.scss":
3913
- /*!*****************************************************!*\
3914
- !*** ./app/modules/vgdropdown/scss/vgdropdown.scss ***!
3915
- \*****************************************************/
3916
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3917
-
3918
- __webpack_require__.r(__webpack_exports__);
3919
- // extracted by mini-css-extract-plugin
3920
-
3921
-
3922
- /***/ }),
3923
-
3924
- /***/ "./app/modules/vgformsender/scss/vgformsender.scss":
3925
- /*!*********************************************************!*\
3926
- !*** ./app/modules/vgformsender/scss/vgformsender.scss ***!
3927
- \*********************************************************/
3928
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3929
-
3930
- __webpack_require__.r(__webpack_exports__);
3931
- // extracted by mini-css-extract-plugin
3932
-
3933
-
3934
- /***/ }),
3935
-
3936
- /***/ "./app/modules/vglawcookie/scss/vglawcookie.scss":
3937
- /*!*******************************************************!*\
3938
- !*** ./app/modules/vglawcookie/scss/vglawcookie.scss ***!
3939
- \*******************************************************/
3940
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3941
-
3942
- __webpack_require__.r(__webpack_exports__);
3943
- // extracted by mini-css-extract-plugin
3944
-
3945
-
3946
- /***/ }),
3947
-
3948
- /***/ "./app/modules/vgmodal/scss/vgmodal.scss":
3949
- /*!***********************************************!*\
3950
- !*** ./app/modules/vgmodal/scss/vgmodal.scss ***!
3951
- \***********************************************/
3952
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3953
-
3954
- __webpack_require__.r(__webpack_exports__);
3955
- // extracted by mini-css-extract-plugin
3956
-
3957
-
3958
- /***/ }),
3959
-
3960
- /***/ "./app/modules/vgnav/scss/vgnav.scss":
3961
- /*!*******************************************!*\
3962
- !*** ./app/modules/vgnav/scss/vgnav.scss ***!
3963
- \*******************************************/
3964
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3965
-
3966
- __webpack_require__.r(__webpack_exports__);
3967
- // extracted by mini-css-extract-plugin
3968
-
3969
-
3970
- /***/ }),
3971
-
3972
- /***/ "./app/modules/vgrollup/scss/vgrollup.scss":
3973
- /*!*************************************************!*\
3974
- !*** ./app/modules/vgrollup/scss/vgrollup.scss ***!
3975
- \*************************************************/
3976
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3977
-
3978
- __webpack_require__.r(__webpack_exports__);
3979
- // extracted by mini-css-extract-plugin
3980
-
3981
-
3982
- /***/ }),
3983
-
3984
- /***/ "./app/modules/vgselect/scss/vgselect.scss":
3985
- /*!*************************************************!*\
3986
- !*** ./app/modules/vgselect/scss/vgselect.scss ***!
3987
- \*************************************************/
3988
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
3989
-
3990
- __webpack_require__.r(__webpack_exports__);
3991
- // extracted by mini-css-extract-plugin
3992
-
3993
-
3994
- /***/ }),
3995
-
3996
- /***/ "./app/modules/vgsidebar/scss/vgsidebar.scss":
3997
- /*!***************************************************!*\
3998
- !*** ./app/modules/vgsidebar/scss/vgsidebar.scss ***!
3999
- \***************************************************/
4000
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
4001
-
4002
- __webpack_require__.r(__webpack_exports__);
4003
- // extracted by mini-css-extract-plugin
4004
-
4005
-
4006
- /***/ }),
4007
-
4008
- /***/ "./app/utils/scss/default.scss":
4009
- /*!*************************************!*\
4010
- !*** ./app/utils/scss/default.scss ***!
4011
- \*************************************/
4012
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
4013
-
4014
- __webpack_require__.r(__webpack_exports__);
4015
- // extracted by mini-css-extract-plugin
4016
-
4017
-
4018
- /***/ })
4019
-
4020
- /******/ });
4021
- /************************************************************************/
4022
- /******/ // The module cache
4023
- /******/ var __webpack_module_cache__ = {};
4024
- /******/
4025
- /******/ // The require function
4026
- /******/ function __webpack_require__(moduleId) {
4027
- /******/ // Check if module is in cache
4028
- /******/ var cachedModule = __webpack_module_cache__[moduleId];
4029
- /******/ if (cachedModule !== undefined) {
4030
- /******/ return cachedModule.exports;
4031
- /******/ }
4032
- /******/ // Create a new module (and put it into the cache)
4033
- /******/ var module = __webpack_module_cache__[moduleId] = {
4034
- /******/ // no module.id needed
4035
- /******/ // no module.loaded needed
4036
- /******/ exports: {}
4037
- /******/ };
4038
- /******/
4039
- /******/ // Execute the module function
4040
- /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
4041
- /******/
4042
- /******/ // Return the exports of the module
4043
- /******/ return module.exports;
4044
- /******/ }
4045
- /******/
4046
- /************************************************************************/
4047
- /******/ /* webpack/runtime/define property getters */
4048
- /******/ (() => {
4049
- /******/ // define getter functions for harmony exports
4050
- /******/ __webpack_require__.d = (exports, definition) => {
4051
- /******/ for(var key in definition) {
4052
- /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
4053
- /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
4054
- /******/ }
4055
- /******/ }
4056
- /******/ };
4057
- /******/ })();
4058
- /******/
4059
- /******/ /* webpack/runtime/hasOwnProperty shorthand */
4060
- /******/ (() => {
4061
- /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
4062
- /******/ })();
4063
- /******/
4064
- /******/ /* webpack/runtime/make namespace object */
4065
- /******/ (() => {
4066
- /******/ // define __esModule on exports
4067
- /******/ __webpack_require__.r = (exports) => {
4068
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
4069
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4070
- /******/ }
4071
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
4072
- /******/ };
4073
- /******/ })();
4074
- /******/
4075
- /************************************************************************/
4076
- var __webpack_exports__ = {};
4077
- // This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk.
4078
- (() => {
4079
- /*!******************!*\
4080
- !*** ./index.js ***!
4081
- \******************/
4082
- __webpack_require__.r(__webpack_exports__);
4083
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
4084
- /* harmony export */ VGCollapse: () => (/* reexport safe */ _app_modules_vgcollapse_js_vgcollapse__WEBPACK_IMPORTED_MODULE_3__["default"]),
4085
- /* harmony export */ VGDropdown: () => (/* reexport safe */ _app_modules_vgdropdown_js_vgdropdown__WEBPACK_IMPORTED_MODULE_7__["default"]),
4086
- /* harmony export */ VGFormSender: () => (/* reexport safe */ _app_modules_vgformsender_js_vgformsender__WEBPACK_IMPORTED_MODULE_11__["default"]),
4087
- /* harmony export */ VGLawCookie: () => (/* reexport safe */ _app_modules_vglawcookie_js_vglawcookie__WEBPACK_IMPORTED_MODULE_15__["default"]),
4088
- /* harmony export */ VGModal: () => (/* reexport safe */ _app_modules_vgmodal_js_vgmodal__WEBPACK_IMPORTED_MODULE_9__["default"]),
4089
- /* harmony export */ VGNav: () => (/* reexport safe */ _app_modules_vgnav_js_vgnav__WEBPACK_IMPORTED_MODULE_5__["default"]),
4090
- /* harmony export */ VGRollup: () => (/* reexport safe */ _app_modules_vgrollup_js_vgrollup__WEBPACK_IMPORTED_MODULE_13__["default"]),
4091
- /* harmony export */ VGSelect: () => (/* reexport safe */ _app_modules_vgselect_js_vgselect__WEBPACK_IMPORTED_MODULE_17__["default"]),
4092
- /* harmony export */ VGSidebar: () => (/* reexport safe */ _app_modules_vgsidebar_js_vgsidebar__WEBPACK_IMPORTED_MODULE_2__["default"])
4093
- /* harmony export */ });
4094
- /* harmony import */ var _app_utils_scss_default_scss__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./app/utils/scss/default.scss */ "./app/utils/scss/default.scss");
4095
- /* harmony import */ var _app_modules_vgsidebar_scss_vgsidebar_scss__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./app/modules/vgsidebar/scss/vgsidebar.scss */ "./app/modules/vgsidebar/scss/vgsidebar.scss");
4096
- /* harmony import */ var _app_modules_vgsidebar_js_vgsidebar__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./app/modules/vgsidebar/js/vgsidebar */ "./app/modules/vgsidebar/js/vgsidebar.js");
4097
- /* harmony import */ var _app_modules_vgcollapse_js_vgcollapse__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./app/modules/vgcollapse/js/vgcollapse */ "./app/modules/vgcollapse/js/vgcollapse.js");
4098
- /* harmony import */ var _app_modules_vgnav_scss_vgnav_scss__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./app/modules/vgnav/scss/vgnav.scss */ "./app/modules/vgnav/scss/vgnav.scss");
4099
- /* harmony import */ var _app_modules_vgnav_js_vgnav__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./app/modules/vgnav/js/vgnav */ "./app/modules/vgnav/js/vgnav.js");
4100
- /* harmony import */ var _app_modules_vgdropdown_scss_vgdropdown_scss__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./app/modules/vgdropdown/scss/vgdropdown.scss */ "./app/modules/vgdropdown/scss/vgdropdown.scss");
4101
- /* harmony import */ var _app_modules_vgdropdown_js_vgdropdown__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./app/modules/vgdropdown/js/vgdropdown */ "./app/modules/vgdropdown/js/vgdropdown.js");
4102
- /* harmony import */ var _app_modules_vgmodal_scss_vgmodal_scss__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./app/modules/vgmodal/scss/vgmodal.scss */ "./app/modules/vgmodal/scss/vgmodal.scss");
4103
- /* harmony import */ var _app_modules_vgmodal_js_vgmodal__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./app/modules/vgmodal/js/vgmodal */ "./app/modules/vgmodal/js/vgmodal.js");
4104
- /* harmony import */ var _app_modules_vgformsender_scss_vgformsender_scss__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./app/modules/vgformsender/scss/vgformsender.scss */ "./app/modules/vgformsender/scss/vgformsender.scss");
4105
- /* harmony import */ var _app_modules_vgformsender_js_vgformsender__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./app/modules/vgformsender/js/vgformsender */ "./app/modules/vgformsender/js/vgformsender.js");
4106
- /* harmony import */ var _app_modules_vgrollup_scss_vgrollup_scss__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./app/modules/vgrollup/scss/vgrollup.scss */ "./app/modules/vgrollup/scss/vgrollup.scss");
4107
- /* harmony import */ var _app_modules_vgrollup_js_vgrollup__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./app/modules/vgrollup/js/vgrollup */ "./app/modules/vgrollup/js/vgrollup.js");
4108
- /* harmony import */ var _app_modules_vglawcookie_scss_vglawcookie_scss__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./app/modules/vglawcookie/scss/vglawcookie.scss */ "./app/modules/vglawcookie/scss/vglawcookie.scss");
4109
- /* harmony import */ var _app_modules_vglawcookie_js_vglawcookie__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./app/modules/vglawcookie/js/vglawcookie */ "./app/modules/vglawcookie/js/vglawcookie.js");
4110
- /* harmony import */ var _app_modules_vgselect_scss_vgselect_scss__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ./app/modules/vgselect/scss/vgselect.scss */ "./app/modules/vgselect/scss/vgselect.scss");
4111
- /* harmony import */ var _app_modules_vgselect_js_vgselect__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ./app/modules/vgselect/js/vgselect */ "./app/modules/vgselect/js/vgselect.js");
4112
- // css классы по умолчанию
4113
-
4114
-
4115
- // sidebar
4116
-
4117
-
4118
-
4119
- // collapse
4120
-
4121
-
4122
- // nav
4123
-
4124
-
4125
-
4126
- // dropdown
4127
-
4128
-
4129
-
4130
- // modal
4131
-
4132
-
4133
-
4134
- // form sender
4135
-
4136
-
4137
-
4138
- // rollup
4139
-
4140
-
4141
-
4142
- // law cookie
4143
-
4144
-
4145
-
4146
- // select
4147
-
4148
-
4149
-
4150
- })();
4151
-
4152
- vg = __webpack_exports__;
4153
- /******/ })()
4154
- ;
4155
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"vgapp.js","mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;ACvGA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;ACjHA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AAAA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;AC1NA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AAGA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;;;;;AClSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;;AC5dA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;;;;;;;;;;;;;;;;;;;;;;;ACrLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAGA;AACA;AACA;;AAEA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;;;ACrVA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AAAA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;ACxfA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AAKA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAIA;AACA;AACA;AAEA;AAIA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAGA;;;;;;;;;;;;;;;;;;AC1FA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AAEA;;AAEA;AACA;;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;;;ACpVA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;ACtLA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;ACpDA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;ACvDA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;AC3BA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;;;;;;;;;;;;;AC3CA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;AC1DA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;AClFA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;ACjHA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAIA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAEA;AAEA;AAAA;AAAA;AAEA;;;;;;;;;;;;;;AC9HA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;AClDA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAkDA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AAIA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;;;;;;;;;;;;;AC1UA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACnEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AChEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;AAEA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;;;;;;;;;;;;ACrSA;;;;;;;;;;;;ACAA;;;;;;;;;;;;ACAA;;;;;;;;;;;;ACAA;;;;;;;;;;;;ACAA;;;;;;;;;;;;ACAA;;;;;;;;;;;;ACAA;;;;;;;;;;;;ACAA;;;;;;;;;;;;ACAA;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACPA;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACNA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA","sources":["webpack://vg/./app/modules/base-module.js","webpack://vg/./app/modules/module-fn.js","webpack://vg/./app/modules/vgcollapse/js/vgcollapse.js","webpack://vg/./app/modules/vgdropdown/js/vgdropdown.js","webpack://vg/./app/modules/vgformsender/js/vgformsender.js","webpack://vg/./app/modules/vglawcookie/js/vglawcookie.js","webpack://vg/./app/modules/vgmodal/js/vgmodal.js","webpack://vg/./app/modules/vgnav/js/vgnav.js","webpack://vg/./app/modules/vgrollup/js/vgrollup.js","webpack://vg/./app/modules/vgselect/js/vgselect.js","webpack://vg/./app/modules/vgsidebar/js/vgsidebar.js","webpack://vg/./app/utils/js/components/animation.js","webpack://vg/./app/utils/js/components/backdrop.js","webpack://vg/./app/utils/js/components/overflow.js","webpack://vg/./app/utils/js/components/params.js","webpack://vg/./app/utils/js/components/placement.js","webpack://vg/./app/utils/js/components/responsive.js","webpack://vg/./app/utils/js/components/scrollbar.js","webpack://vg/./app/utils/js/dom/cookie.js","webpack://vg/./app/utils/js/dom/data.js","webpack://vg/./app/utils/js/dom/event.js","webpack://vg/./app/utils/js/dom/manipulator.js","webpack://vg/./app/utils/js/dom/selectors.js","webpack://vg/./app/utils/js/functions.js","webpack://vg/./app/modules/vgdropdown/scss/vgdropdown.scss?e825","webpack://vg/./app/modules/vgformsender/scss/vgformsender.scss?6912","webpack://vg/./app/modules/vglawcookie/scss/vglawcookie.scss?dd45","webpack://vg/./app/modules/vgmodal/scss/vgmodal.scss?1289","webpack://vg/./app/modules/vgnav/scss/vgnav.scss?19bc","webpack://vg/./app/modules/vgrollup/scss/vgrollup.scss?3526","webpack://vg/./app/modules/vgselect/scss/vgselect.scss?0fbe","webpack://vg/./app/modules/vgsidebar/scss/vgsidebar.scss?5acd","webpack://vg/./app/utils/scss/default.scss?c634","webpack://vg/webpack/bootstrap","webpack://vg/webpack/runtime/define property getters","webpack://vg/webpack/runtime/hasOwnProperty shorthand","webpack://vg/webpack/runtime/make namespace object","webpack://vg/./index.js"],"sourcesContent":["import {execute, executeAfterTransition, isEmptyObj} from \"../utils/js/functions\";\r\nimport Selectors from \"../utils/js/dom/selectors\";\r\nimport Data from \"../utils/js/dom/data\";\r\nimport Params from \"../utils/js/components/params\";\r\nimport EventHandler from \"../utils/js/dom/event\";\r\nimport {Ajax, getSVG} from \"./module-fn\";\r\nimport Animation from \"../utils/js/components/animation\";\r\n\r\nclass BaseModule {\r\n\tconstructor(element) {\r\n\t\tif (!element) return\r\n\r\n\t\tthis._element = Selectors.find(element);\r\n\t\tif (!this._element){\r\n\t\t\tthrow new Error('Товарищ! Первый параметр не должен быть пустым!');\r\n\t\t}\r\n\r\n\t\tthis._params = {};\r\n\t\tData.set(this._element, this.constructor.NAME_KEY, this);\r\n\t}\r\n\r\n\t_getParams(element, params) {\r\n\t\treturn new Params(params, element).get();\r\n\t}\r\n\r\n\tdispose() {\r\n\t\tData.remove(this._element, this.constructor.NAME_KEY);\r\n\t\tEventHandler.off(this._element, this.constructor.EVENT_KEY)\r\n\r\n\t\tfor (const propertyName of Object.getOwnPropertyNames(this)) {\r\n\t\t\tthis[propertyName] = null\r\n\t\t}\r\n\t}\r\n\r\n\t_route(callback) {\r\n\t\tconst _this = this;\r\n\t\tlet $content = null;\r\n\r\n\t\tconst setData = (data) => {\r\n\t\t\tif ($content) $content.innerHTML = data;\r\n\t\t};\r\n\r\n\t\tif (!_this._params.hasOwnProperty('ajax')) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (!_this._params.ajax.route) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (!'method' in _this._params.ajax) {\r\n\t\t\t_this._params.ajax.method = 'get';\r\n\t\t}\r\n\r\n\t\tif ('target' in _this._params.ajax && _this._params.ajax.target) {\r\n\t\t\t$content = Selectors.find(_this._params.ajax.target);\r\n\t\t}\r\n\r\n\t\tif ('loader' in _this._params.ajax && _this._params.ajax.loader) {\r\n\t\t\tsetData('<div class=\"vg-loader\"></div>');\r\n\t\t}\r\n\r\n\t\tAjax[_this._params.ajax.method](_this._params.ajax.route, _this._params.ajax.data || {}, function (status, data) {\r\n\t\t\tsetData(data.response);\r\n\t\t\texecute(callback, [status, data]);\r\n\t\t});\r\n\t}\r\n\r\n\t_dismissElement() {\r\n\t\tlet cross = getSVG('cross'),\r\n\t\t\tbutton = this._element.querySelector('.vg-btn-close');\r\n\r\n\t\tif (button) {\r\n\t\t\tlet svg = button.querySelector('svg');\r\n\t\t\tif (!svg) button.insertAdjacentHTML('beforeend', cross);\r\n\t\t}\r\n\t}\r\n\r\n\t_queueCallback(callback, element, isAnimated = true, timeOutMs) {\r\n\t\texecuteAfterTransition(callback, element, isAnimated, timeOutMs);\r\n\t}\r\n\r\n\t_animation(element, key, params = {}) {\r\n\t\tnew Animation(element, key, params);\r\n\t}\r\n\r\n\tstatic getInstance(element) {\r\n\t\treturn Data.get(Selectors.find(element), this.NAME_KEY)\r\n\t}\r\n\r\n\tstatic getOrCreateInstance(element, params = {}) {\r\n\t\treturn this.getInstance(element) || new this(element, !isEmptyObj(params) ? params : {})\r\n\t}\r\n\r\n\tstatic get DATA_KEY() {\r\n\t\treturn `vg.${this.NAME}`\r\n\t}\r\n\r\n\tstatic get EVENT_KEY() {\r\n\t\treturn `.${this.DATA_KEY}`\r\n\t}\r\n}\r\n\r\nexport default BaseModule;","import EventHandler from \"../utils/js/dom/event\";\r\nimport {isDisabled, isEmptyObj} from \"../utils/js/functions\";\r\nimport Selectors from \"../utils/js/dom/selectors\";\r\n\r\n/**\r\n * Тут собраны вспомогательные скрипты для работы модулей\r\n */\r\n\r\n/**\r\n * Набор svg элементов\r\n * @param name\r\n * @returns {*|{}}\r\n */\r\nconst getSVG = (name) => {\r\n\tconst svg =  {\r\n\t\terror: '<svg  viewBox=\"0 0 87 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><g id=\"ui-success\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\"><g id=\"Group-2\" transform=\"translate(2.000000, 2.000000)\"><circle id=\"Oval-2\" stroke=\"rgba(252, 191, 191, .5)\" stroke-width=\"4\" cx=\"41.5\" cy=\"41.5\" r=\"41.5\"></circle><circle class=\"ui-error-circle\" stroke=\"#F74444\" stroke-width=\"4\" cx=\"41.5\" cy=\"41.5\" r=\"41.5\"></circle><path class=\"ui-error-line1\" d=\"M22.244224,22 L60.4279902,60.1837662\" id=\"Line\" stroke=\"#F74444\" stroke-width=\"3\" stroke-linecap=\"square\"></path><path class=\"ui-error-line2\" d=\"M60.755776,21 L23.244224,59.8443492\" id=\"Line\" stroke=\"#F74444\" stroke-width=\"3\" stroke-linecap=\"square\"></path></g></g></svg>',\r\n\t\tsuccess: '<svg viewBox=\"0 0 87 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><g id=\"ui-error\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\"><g id=\"Group-3\" transform=\"translate(2.000000, 2.000000)\"><circle id=\"Oval-2\" stroke=\"rgba(117, 183, 152, 0.4)\" stroke-width=\"4\" cx=\"41.5\" cy=\"41.5\" r=\"41.5\"></circle><circle  class=\"ui-success-circle\" id=\"Oval-2\" stroke=\"#A5DC86\" stroke-width=\"4\" cx=\"41.5\" cy=\"41.5\" r=\"41.5\"></circle><polyline class=\"ui-success-path\" id=\"Path-2\" stroke=\"#A5DC86\" stroke-width=\"4\" points=\"19 38.8036813 31.1020744 54.8046875 63.299221 28\"></polyline></g></g></svg>',\r\n\t\twaiting: '<svg viewBox=\"0 0 87 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><g id=\"ui-waiting\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\"><g id=\"Group-3\" transform=\"translate(2.000000, 2.000000)\"><circle id=\"Oval-2\" stroke=\"rgba(255, 218, 106, 0.4)\" stroke-width=\"4\" cx=\"41.5\" cy=\"41.5\" r=\"41.5\"></circle><circle class=\"ui-waiting-circle\" id=\"Oval-2\" stroke=\"#ffda6a\" stroke-width=\"4\" cx=\"41.5\" cy=\"41.5\" r=\"41.5\"></circle><path class=\"ui-waiting-line1\" d=\"M43 63C54.598 63 64 53.598 64 42C64 30.402 54.598 21 43 21C31.402 21 22 30.402 22 42C22 53.598 31.402 63 43 63Z\" stroke-width=\"3\" stroke=\"#ffda6a\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path class=\"ui-waiting-line2\" d=\"M40.6667 32.6641V44.3307H52.3334\" stroke=\"#ffda6a\" stroke-width=\"3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></g></g></svg>',\r\n\t\tdots: '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" class=\"bi bi-three-dots-vertical\" viewBox=\"0 0 16 16\"><path d=\"M9.5 13a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z\"/></svg>',\r\n\t\tcross: '<svg version=\"1.1\" id=\"Capa_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\" viewBox=\"0 0 224.512 224.512\" xml:space=\"preserve\"><g><polygon points=\"224.507,6.997 217.521,0 112.256,105.258 6.998,0 0.005,6.997 105.263,112.254 0.005,217.512 6.998,224.512 112.256,119.24 217.521,224.512 224.507,217.512 119.249,112.254 \"/></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g></svg>'\r\n\t};\r\n\r\n\treturn svg[name] ?? {};\r\n}\r\n\r\n/**\r\n * Вешаем событие \"Закрыть\" на все модалки, сайдбары и т.п.\r\n * @param module\r\n * @param method\r\n */\r\nconst dismissTrigger = (module, method = 'hide') => {\r\n\tconst clickEvent = `click.dismiss.${module.EVENT_KEY}`\r\n\tconst name = module.NAME;\r\n\r\n\tEventHandler.on(document, clickEvent, `[data-vg-dismiss=\"${name}\"]`, function (event) {\r\n\t\tif (['A', 'AREA'].includes(this.tagName)) {\r\n\t\t\tevent.preventDefault();\r\n\t\t}\r\n\r\n\t\tif (isDisabled(this)) return;\r\n\r\n\t\tconst target = Selectors.getSelectorFromElement(this) || this.closest(`.vg-${name}`);\r\n\t\tconst instance = module.getOrCreateInstance(target);\r\n\r\n\t\tinstance[method]();\r\n\t})\r\n}\r\n\r\n/**\r\n * AJAX REQUEST\r\n * @type {{post: ajax.post, get: ajax.get, x: ((function(): (XMLHttpRequest))|*), send: ajax.send}}\r\n */\r\nconst Ajax = {\r\n\tx: function () {\r\n\t\tif (typeof XMLHttpRequest !== 'undefined') {\r\n\t\t\treturn new XMLHttpRequest();\r\n\t\t}\r\n\t\tlet versions = [\r\n\t\t\t\"MSXML2.XmlHttp.6.0\",\r\n\t\t\t\"MSXML2.XmlHttp.5.0\",\r\n\t\t\t\"MSXML2.XmlHttp.4.0\",\r\n\t\t\t\"MSXML2.XmlHttp.3.0\",\r\n\t\t\t\"MSXML2.XmlHttp.2.0\",\r\n\t\t\t\"Microsoft.XmlHttp\"\r\n\t\t];\r\n\r\n\t\tlet xhr;\r\n\t\tfor (let i = 0; i < versions.length; i++) {\r\n\t\t\ttry {\r\n\t\t\t\txhr = new ActiveXObject(versions[i]);\r\n\t\t\t\tbreak;\r\n\t\t\t} catch (e) {}\r\n\t\t}\r\n\r\n\t\treturn xhr;\r\n\t},\r\n\r\n\tsend: function (url, callback, method, data, async) {\r\n\t\tif (async === undefined) {\r\n\t\t\tasync = true;\r\n\t\t}\r\n\t\tlet x = Ajax.x();\r\n\t\tx.open(method, url, async);\r\n\t\tx.setRequestHeader(\"X-Requested-With\", \"XMLHttpRequest\");\r\n\t\tx.onreadystatechange = function () {\r\n\t\t\tif (x.readyState === 4) {\r\n\t\t\t\tswitch (x.status) {\r\n\t\t\t\t\tcase 200:\r\n\t\t\t\t\t\tcallback('success', {text: x.statusText, response: x.responseText, code: x.status})\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tdefault:\r\n\t\t\t\t\t\tcallback('error', {text: x.statusText, response: x.responseText, code: x.status})\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t};\r\n\t\tx.send(data)\r\n\t},\r\n\r\n\tget: function (url, data, callback, async) {\r\n\t\tlet query = [];\r\n\r\n\t\tif (!isEmptyObj(data)) {\r\n\t\t\tfor (let key of data) {\r\n\t\t\t\tquery.push(encodeURIComponent(key[0]) + '=' + encodeURIComponent(key[1]));\r\n\t\t\t}\r\n\t\t}\r\n\t\tAjax.send(url + (query.length ? '?' + query.join('&') : ''), callback, 'GET', null, async)\r\n\t},\r\n\r\n\tpost: function (url, data, callback, async) {\r\n\t\tAjax.send(url, callback, 'POST', data, async)\r\n\t}\r\n};\r\n\r\nexport {\r\n\tdismissTrigger, Ajax, getSVG\r\n}","import BaseModule from \"../../base-module\";\r\nimport {mergeDeepObject, reflow} from \"../../../utils/js/functions\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport {Manipulator} from \"../../../utils/js/dom/manipulator\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME = 'collapse';\r\nconst NAME_KEY = 'vg.collapse';\r\nconst CLASS_NAME_SHOW = 'show';\r\nconst CLASS_NAME_COLLAPSE = 'vg-collapse';\r\nconst CLASS_NAME_COLLAPSING = 'vg-collapsing';\r\nconst CLASS_NAME_COLLAPSED = 'vg-collapsed';\r\nconst CLASS_NAME_DEEPER_CHILDREN = `:scope .${CLASS_NAME_COLLAPSE} .${CLASS_NAME_COLLAPSE}`;\r\n\r\nconst SELECTOR_DATA_TOGGLE= '[data-vg-toggle=\"collapse\"]';\r\nconst SELECTOR_ACTIVES = '.collapse.show, .collapse.collapsing';\r\n\r\nconst EVENT_KEY_HIDE   = `${NAME_KEY}.hide`;\r\nconst EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;\r\nconst EVENT_KEY_SHOW   = `${NAME_KEY}.show`;\r\nconst EVENT_KEY_SHOWN  = `${NAME_KEY}.shown`;\r\n\r\nconst EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;\r\n\r\nclass VGCollapse extends BaseModule {\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\t\t\ttoggle: true,\r\n\t\t\tparent: null,\r\n\t\t\tajax: {\r\n\t\t\t\troute: '',\r\n\t\t\t\ttarget: '',\r\n\t\t\t\tmethod: 'get'\r\n\t\t\t}\r\n\t\t}, params));\r\n\r\n\t\tthis._isTransitioning = false\r\n\t\tthis._triggerArray = []\r\n\r\n\t\tconst toggleList = Selectors.findAll(SELECTOR_DATA_TOGGLE);\r\n\r\n\t\tfor (const elem of toggleList) {\r\n\t\t\tconst selector = Selectors.getSelectorFromElement(elem);\r\n\t\t\tconst filterElement = Selectors.findAll(selector).filter(foundElement => foundElement === this._element);\r\n\r\n\t\t\tif (selector !== null && filterElement.length) {\r\n\t\t\t\tthis._triggerArray.push(elem)\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis._initializeChildren();\r\n\r\n\t\tif (!this._params.parent) {\r\n\t\t\tthis._addAriaAndCollapsedClass(this._triggerArray, this._isShown());\r\n\t\t}\r\n\r\n\t\tif (this._params.toggle) {\r\n\t\t\tthis.toggle();\r\n\t\t}\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY\r\n\t}\r\n\r\n\ttoggle(relatedTarget) {\r\n\t\treturn !this._isShown() ? this.show(relatedTarget) : this.hide();\r\n\t}\r\n\r\n\tshow() {\r\n\t\tconst _this = this;\r\n\r\n\t\tif (_this._isTransitioning || _this._isShown()) return;\r\n\r\n\t\tlet activeChildren = [];\r\n\r\n\t\tif (_this._params.parent) {\r\n\t\t\tactiveChildren = this._getFirstLevelChildren(SELECTOR_ACTIVES)\r\n\t\t\t\t.filter(element => element !== this._element)\r\n\t\t\t\t.map(element => VGCollapse.getOrCreateInstance(element, { toggle: false }));\r\n\t\t}\r\n\r\n\t\tif (activeChildren.length && activeChildren[0]._isTransitioning) return;\r\n\r\n\t\tconst startEvent = EventHandler.trigger(_this._element, EVENT_KEY_SHOW);\r\n\t\tif (startEvent.defaultPrevented) return;\r\n\r\n\t\tfor (const activeInstance of activeChildren) {\r\n\t\t\tactiveInstance.hide();\r\n\t\t}\r\n\r\n\t\t_this._element.classList.remove(CLASS_NAME_COLLAPSE)\r\n\t\t_this._element.classList.add(CLASS_NAME_COLLAPSING)\r\n\r\n\t\t_this._element.style.height = 0;\r\n\r\n\t\t_this._addAriaAndCollapsedClass(_this._triggerArray, true);\r\n\t\t_this._isTransitioning = true;\r\n\r\n\t\t_this._route();\r\n\r\n\t\tconst complete = () => {\r\n\t\t\t_this._isTransitioning = false;\r\n\r\n\t\t\t_this._element.classList.remove(CLASS_NAME_COLLAPSING);\r\n\t\t\t_this._element.classList.add(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW);\r\n\r\n\t\t\t_this._element.style.height = '';\r\n\t\t\tEventHandler.trigger(_this._element, EVENT_KEY_SHOWN);\r\n\t\t}\r\n\r\n\t\t_this._queueCallback(complete, _this._element, true);\r\n\r\n\t\tconst scrollSize = `scrollHeight`;\r\n\t\t_this._element.style.height = `${_this._element[scrollSize]}px`;\r\n\t}\r\n\r\n\thide() {\r\n\t\tconst _this = this;\r\n\r\n\t\tif (_this._isTransitioning || !_this._isShown()) return;\r\n\r\n\t\tconst startEvent = EventHandler.trigger(_this._element, EVENT_KEY_HIDE)\r\n\t\tif (startEvent.defaultPrevented) return;\r\n\r\n\t\t_this._element.style.height = `${this._element.getBoundingClientRect().height}px`;\r\n\t\treflow(_this._element);\r\n\r\n\t\t_this._element.classList.add(CLASS_NAME_COLLAPSING);\r\n\t\t_this._element.classList.remove(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW);\r\n\r\n\t\tfor (const trigger of _this._triggerArray) {\r\n\t\t\tconst element = Selectors.getElementFromSelector(trigger);\r\n\r\n\t\t\tif (element && !_this._isShown(element)) {\r\n\t\t\t\t_this._addAriaAndCollapsedClass([trigger], false);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t_this._isTransitioning = true\r\n\r\n\t\tconst complete = () => {\r\n\t\t\t_this._isTransitioning = false;\r\n\t\t\t_this._element.classList.remove(CLASS_NAME_COLLAPSING);\r\n\t\t\t_this._element.classList.add(CLASS_NAME_COLLAPSE);\r\n\t\t\tEventHandler.trigger(_this._element, EVENT_KEY_HIDDEN);\r\n\t\t}\r\n\r\n\t\t_this._element.style.height = '';\r\n\t\t_this._queueCallback(complete, _this._element, true);\r\n\t}\r\n\r\n\tdispose() {\r\n\t\tsuper.dispose();\r\n\t}\r\n\r\n\t_isShown(element = this._element) {\r\n\t\treturn element.classList.contains(CLASS_NAME_SHOW);\r\n\t}\r\n\r\n\t_addAriaAndCollapsedClass(triggerArray, isOpen) {\r\n\t\tif (!triggerArray.length) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tfor (const element of triggerArray) {\r\n\t\t\tthis._changeStateButton(element, isOpen);\r\n\t\t}\r\n\t}\r\n\r\n\t_initializeChildren() {\r\n\t\tif (!this._params.parent) return;\r\n\r\n\t\tconst children = this._getFirstLevelChildren(SELECTOR_DATA_TOGGLE);\r\n\r\n\t\tfor (const element of children) {\r\n\t\t\tconst selected = Selectors.getElementFromSelector(element)\r\n\r\n\t\t\tif (selected) {\r\n\t\t\t\tthis._addAriaAndCollapsedClass([element], this._isShown(selected))\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t_getFirstLevelChildren(selector) {\r\n\t\tconst children = Selectors.find(CLASS_NAME_DEEPER_CHILDREN, this._params.parent);\r\n\t\treturn Selectors.find(selector, this._params.parent).filter(element => !children.includes(element));\r\n\t}\r\n\r\n\t_changeStateButton(element, isOpen) {\r\n\t\telement.classList.toggle(CLASS_NAME_COLLAPSED, !isOpen);\r\n\t\telement.setAttribute('aria-expanded', isOpen);\r\n\t\telement.innerHTML = Manipulator.get(element, `data-${isOpen ? 'hide' : 'show'}-text`) || element.innerHTML;\r\n\t}\r\n}\r\n\r\n/**\r\n * Data API implementation\r\n */\r\nEventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {\r\n\tif (event.target.tagName === 'A' || (event.delegateTarget && event.delegateTarget.tagName === 'A')) {\r\n\t\tevent.preventDefault()\r\n\t}\r\n\r\n\tSelectors.getMultipleElementsFromSelector(this).forEach(function (element) {\r\n\t\tVGCollapse.getOrCreateInstance(element, {toggle: false}).toggle();\r\n\t});\r\n})\r\n\r\nexport default VGCollapse;","import BaseModule from \"../../base-module\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport {isDisabled, mergeDeepObject, noop} from \"../../../utils/js/functions\";\r\nimport Placement from \"../../../utils/js/components/placement\";\r\n\r\nconst NAME             = 'dropdown';\r\nconst NAME_KEY         = 'vg.dropdown';\r\nconst CLASS_NAME_SHOW  = 'show';\r\nconst CLASS_NAME_FADE  = 'fade';\r\nconst TARGET_CONTAINER = 'vg-dropdown-content';\r\nconst PARENT_CONTAINER = 'vg-dropdown';\r\nconst SELECTOR_DATA_TOGGLE = '[data-vg-toggle=\"dropdown\"]';\r\n\r\nconst EVENT_KEY_HIDE   = `${NAME_KEY}.hide`;\r\nconst EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;\r\nconst EVENT_KEY_SHOW   = `${NAME_KEY}.show`;\r\nconst EVENT_KEY_SHOWN  = `${NAME_KEY}.shown`;\r\n\r\nconst EVENT_KEYUP_DATA_API =     `keyup.${NAME_KEY}.data.api`;\r\nconst EVENT_KEYDOWN_DATA_API =   `keydown.${NAME_KEY}.data.api`;\r\nconst EVENT_CLICK_DATA_API =     `click.${NAME_KEY}.data.api`;\r\nconst EVENT_MOUSEOVER_DATA_API = `mouseover.${NAME_KEY}.data.api`;\r\nconst EVENT_MOUSEOUT_DATA_API =  `mouseout.${NAME_KEY}.data.api`;\r\n\r\nclass VGDropdown extends BaseModule {\r\n\tconstructor(element, params) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tlet defaultParams = {\r\n\t\t\toffset: [0, 2],\r\n\t\t\tover: false,\r\n\t\t\tbackdrop: true,\r\n\t\t\toverflow: true,\r\n\t\t\tkeyboard: true,\r\n\t\t\tplacement: 'bottom',\r\n\t\t\ttimeoutAnimation: 350,\r\n\t\t\thover: false,\r\n\t\t\tajax: {\r\n\t\t\t\troute: '',\r\n\t\t\t\ttarget: '',\r\n\t\t\t\tmethod: 'get'\r\n\t\t\t},\r\n\t\t\tanimation: {\r\n\t\t\t\tenable: false,\r\n\t\t\t\tin: 'animate__flipInY',\r\n\t\t\t\tout: 'animate__flipOutY',\r\n\t\t\t\tdelay: 800,\r\n\t\t\t},\r\n\t\t}\r\n\r\n\t\tif ('offset' in params && Array.isArray(params.offset)) {\r\n\t\t\tdefaultParams.offset = params.offset;\r\n\t\t}\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject(defaultParams, params));\r\n\r\n\t\tthis._parent = this._element.parentNode;\r\n\t\tthis._drop = Selectors.find('.' + TARGET_CONTAINER, this._parent);\r\n\t\tthis._isPlacement = false;\r\n\r\n\t\tthis._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;\r\n\t\tthis._animation(this._drop, VGDropdown.NAME_KEY, this._params.animation);\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY;\r\n\t}\r\n\r\n\ttoggle() {\r\n\t\treturn this._isShown() ? this.hide() : this.show();\r\n\t}\r\n\r\n\tshow() {\r\n\t\tif (isDisabled(this._element) || this._isShown()) return;\r\n\r\n\t\tconst relatedTarget = {\r\n\t\t\trelatedTarget: this._element\r\n\t\t}\r\n\r\n\t\tconst showEvent = EventHandler.trigger(this._element, EVENT_KEY_SHOW, relatedTarget)\r\n\t\tif (showEvent.defaultPrevented) return;\r\n\r\n\t\tif ('ontouchstart' in document.documentElement) {\r\n\t\t\tfor (const element of [].concat(...document.body.children)) {\r\n\t\t\t\tEventHandler.on(element, 'mouseover', noop);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis._route();\r\n\r\n\t\tthis._element.setAttribute('aria-expanded', true);\r\n\t\tthis._element.classList.add(CLASS_NAME_SHOW);\r\n\t\tthis._drop.classList.add(CLASS_NAME_SHOW);\r\n\t\tthis._setPlacement();\r\n\r\n\t\tconst completeCallBack = () => {\r\n\t\t\tthis._drop.classList.add(CLASS_NAME_FADE);\r\n\t\t\tEventHandler.trigger(this._element, EVENT_KEY_SHOWN, relatedTarget)\r\n\t\t}\r\n\t\tthis._queueCallback(completeCallBack, this._drop, true, 50);\r\n\t}\r\n\r\n\thide() {\r\n\t\tif (isDisabled(this._element) || !this._isShown()) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst relatedTarget = {\r\n\t\t\trelatedTarget: this._element\r\n\t\t}\r\n\r\n\t\tthis._completeHide(relatedTarget);\r\n\t}\r\n\r\n\tdispose() {\r\n\t\treturn super.dispose();\r\n\t}\r\n\r\n\t_isShown() {\r\n\t\treturn this._element.classList.contains(CLASS_NAME_SHOW);\r\n\t}\r\n\r\n\t_completeHide(relatedTarget) {\r\n\t\tconst hideEvent = EventHandler.trigger(this._element, EVENT_KEY_HIDE, relatedTarget)\r\n\t\tif (hideEvent.defaultPrevented) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif ('ontouchstart' in document.documentElement) {\r\n\t\t\tfor (const element of [].concat(...document.body.children)) {\r\n\t\t\t\tEventHandler.off(element, 'mouseover', noop);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis._drop.classList.remove(CLASS_NAME_FADE);\r\n\t\tthis._element.classList.remove(CLASS_NAME_SHOW);\r\n\t\tthis._element.setAttribute('aria-expanded', 'false');\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tconst completeCallback = () => {\r\n\t\t\t\tthis._drop.classList.remove(CLASS_NAME_SHOW);\r\n\t\t\t\tEventHandler.trigger(this._element, EVENT_KEY_HIDDEN, relatedTarget);\r\n\t\t\t}\r\n\t\t\tthis._queueCallback(completeCallback, this._parent, true, 10);\r\n\t\t}, this._params.animation.delay);\r\n\t}\r\n\r\n\t// TODO class Placement isn't done\r\n\t_setPlacement() {\r\n\t\tconst _this = this;\r\n\r\n\t\tif (!_this._isPlacement) {\r\n\t\t\tlet placement = new Placement({\r\n\t\t\t\telement: this._parent,\r\n\t\t\t\tdrop: this._drop\r\n\t\t\t})._getPlacement();\r\n\r\n\t\t\tif (placement.isFixed) {\r\n\t\t\t\t_this._drop.style.position = 'fixed';\r\n\t\t\t\t_this._drop.style.transform = 'translateY(-20%)'; // todo this is костыль поfixить\r\n\t\t\t}\r\n\r\n\t\t\t_this._drop.style.left = placement.left + 'px';\r\n\t\t\t_this._drop.style.top =  placement.top + 'px';\r\n\t\t}\r\n\r\n\t\tif (_this._params.offset) {\r\n\t\t\t_this._drop.style.paddingTop = _this._params.offset[1] + 'px';\r\n\t\t\t_this._drop.style.paddingRight = _this._params.offset[0] + 'px';\r\n\t\t}\r\n\r\n\t\t_this._isPlacement = true;\r\n\t}\r\n\r\n\tstatic init(element, params = {}) {\r\n\t\tconst instance = VGDropdown.getOrCreateInstance(element, params);\r\n\r\n\t\tif (instance._params.hover) {\r\n\t\t\tlet currentElem = null;\r\n\t\t\tEventHandler.on(instance._parent, EVENT_MOUSEOVER_DATA_API, function (event) {\r\n\t\t\t\tif (currentElem) return;\r\n\t\t\t\tVGDropdown.hideOpenToggles(event);\r\n\r\n\t\t\t\tlet target = event.target.closest('.' + PARENT_CONTAINER);\r\n\t\t\t\tif (!target) return;\r\n\r\n\t\t\t\tif (!instance._parent.contains(target)) return;\r\n\t\t\t\tcurrentElem = target;\r\n\t\t\t\tinstance.show();\r\n\t\t\t});\r\n\r\n\t\t\tEventHandler.on(instance._parent, EVENT_MOUSEOUT_DATA_API, function (event) {\r\n\t\t\t\tif (!currentElem) return;\r\n\r\n\t\t\t\tlet relatedTarget = event.relatedTarget;\r\n\r\n\t\t\t\twhile (relatedTarget) {\r\n\t\t\t\t\tif (relatedTarget === currentElem) return;\r\n\t\t\t\t\trelatedTarget = relatedTarget.parentNode;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tcurrentElem = null;\r\n\t\t\t\tinstance._completeHide({relatedTarget: instance._element});\r\n\t\t\t})\r\n\t\t} else {\r\n\t\t\tEventHandler.on(document, EVENT_KEYUP_DATA_API, SELECTOR_DATA_TOGGLE, VGDropdown.keydownHandler);\r\n\t\t\tEventHandler.on(document, EVENT_KEYDOWN_DATA_API, '.' + TARGET_CONTAINER, VGDropdown.keydownHandler);\r\n\t\t\tEventHandler.on(document, EVENT_KEYUP_DATA_API, VGDropdown.clearDrops);\r\n\t\t\tEventHandler.on(document, EVENT_CLICK_DATA_API, VGDropdown.clearDrops);\r\n\t\t\tEventHandler.on(element, EVENT_CLICK_DATA_API, function (event) {\r\n\t\t\t\tevent.preventDefault();\r\n\t\t\t\tinstance.toggle();\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tstatic hideOpenToggles(event) {\r\n\t\tconst openToggles = Selectors.findAll('[data-vg-toggle=\"dropdown\"]:not(.disabled):not(:disabled).show');\r\n\t\tfor (const toggle of openToggles) {\r\n\t\t\tconst context = VGDropdown.getInstance(toggle);\r\n\t\t\tif (!context) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\r\n\t\t\tif (event.target.closest('.' + TARGET_CONTAINER) === context._drop) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst composedPath = event.composedPath();\r\n\t\t\tif (composedPath.includes(context._element)) {\r\n\t\t\t\tcontinue\r\n\t\t\t}\r\n\r\n\t\t\tconst relatedTarget = { relatedTarget: context._element }\r\n\r\n\t\t\tif (event.type === 'click') {\r\n\t\t\t\trelatedTarget.clickEvent = event\r\n\t\t\t}\r\n\r\n\t\t\tcontext._completeHide(relatedTarget)\r\n\t\t}\r\n\t}\r\n\r\n\tstatic keydownHandler(event) {\r\n\t\tconst isInput = /input|textarea/i.test(event.target.tagName)\r\n\t\tconst isEscapeEvent = event.key === 'Escape'\r\n\t\tconst isUpOrDownEvent = ['ArrowUp', 'ArrowDown'].includes(event.key)\r\n\r\n\t\tif (!isUpOrDownEvent && !isEscapeEvent) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tif (isInput && !isEscapeEvent) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tevent.preventDefault()\r\n\r\n\t\tconst getToggleButton = this.matches(SELECTOR_DATA_TOGGLE) ?\r\n\t\t\tthis : (Selectors.find(SELECTOR_DATA_TOGGLE, event.delegateTarget.parentNode))\r\n\r\n\t\tconst instance = VGDropdown.getOrCreateInstance(getToggleButton)\r\n\r\n\t\tif (isUpOrDownEvent) {\r\n\t\t\tevent.stopPropagation()\r\n\t\t\tinstance.show()\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tif (instance._isShown()) {\r\n\t\t\tevent.stopPropagation()\r\n\t\t\tinstance.hide()\r\n\t\t\tgetToggleButton.focus()\r\n\t\t}\r\n\t}\r\n\r\n\tstatic clearDrops(event) {\r\n\t\tif (event.button === 2 || (event.type === 'keyup' && event.key !== 'Tab')) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tVGDropdown.hideOpenToggles(event)\r\n\t}\r\n}\r\n\r\nexport default VGDropdown;","import BaseModule from \"../../base-module\";\r\nimport {Manipulator} from \"../../../utils/js/dom/manipulator\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport VGModal from \"../../vgmodal/js/vgmodal\";\r\nimport {isObject, makeRandomString, mergeDeepObject, normalizeData} from \"../../../utils/js/functions\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport VGCollapse from \"../../vgcollapse/js/vgcollapse\";\r\nimport {getSVG} from \"../../module-fn\";\r\nimport Backdrop from \"../../../utils/js/components/backdrop\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME = 'form-sender';\r\nconst NAME_KEY = 'vg.fs';\r\n\r\n/**\r\n * Constants Events\r\n */\r\nconst EVENT_KEY_SUCCESS = 'vg.fs.success';\r\nconst EVENT_KEY_ERROR   = 'vg.fs.error';\r\nconst EVENT_KEY_BEFORE  = 'vg.fs.before';\r\n\r\nconst EVENT_SUBMIT_DATA_API = `submit.${NAME_KEY}.data.api`;\r\n\r\nclass VGFormSender extends BaseModule {\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\t\t\tredirect: '',\r\n\t\t\tvalidate: false,\r\n\t\t\tsubmit: false,\r\n\t\t\tfields: [],\r\n\t\t\talert: {\r\n\t\t\t\tenabled: true,\r\n\t\t\t\ttype: 'modal'\r\n\t\t\t},\r\n\t\t\tajax: {\r\n\t\t\t\troute: '',\r\n\t\t\t\ttarget: '',\r\n\t\t\t\tmethod: 'get',\r\n\t\t\t},\r\n\t\t\tclasses: {\r\n\t\t\t\tgeneral: 'vg-form-sender',\r\n\t\t\t\talertCollapse: 'vg-form-sender-collapse',\r\n\t\t\t\talertModal: 'vg-form-sender-modal',\r\n\t\t\t\tvalidation: 'needs-validation',\r\n\t\t\t\twasValidate: 'was-validated'\r\n\t\t\t}\r\n\t\t}, params));\r\n\r\n\t\tthis._params.ajax.route = Manipulator.get(this._element, 'action').toLowerCase();\r\n\t\tthis._params.ajax.method = Manipulator.get(this._element, 'method').toLowerCase();\r\n\t\tthis._button = Selectors.find('[type=\"submit\"]', this._element) || Selectors.find('[form=\"' + this._element.id + '\"]') || null;\r\n\r\n\t\tthis._params.isBtnText   = Manipulator.get(this._element, 'data-btn-text') !== 'false';\r\n\t\tthis._params.isJsonParse = Manipulator.get(this._element, 'data-json-parse') !== 'false';\r\n\t\tthis._params.isShowPass  = Manipulator.get(this._element, 'data-show-pass') === 'true';\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY;\r\n\t}\r\n\r\n\tbuild() {\r\n\t\tthis._element.classList.add(this._params.classes.general);\r\n\r\n\t\tif (this._params.validate) {\r\n\t\t\tManipulator.set(this._element, 'novalidate', '');\r\n\t\t\tthis._element.classList.add(this._params.classes.validation);\r\n\t\t}\r\n\r\n\t\t// TODO сделать добавление глаза если есть ввод пароля\r\n\r\n\t\treturn this\r\n\t}\r\n\r\n\trequest(data, event) {\r\n\t\tconst _this = this;\r\n\r\n\t\t_this._alertBefore();\r\n\r\n\t\t_this._params.ajax.data = data;\r\n\r\n\t\t_this._route(function (status, data) {\r\n\t\t\t_this._element.classList.remove('was-validated');\r\n\r\n\t\t\tif (_this._params.alert.enabled) {\r\n\t\t\t\tif (typeof status === 'string' && status === 'error') {\r\n\t\t\t\t\t_this._alertError(event, data);\r\n\t\t\t\t} else if (typeof status === 'string' && status === 'success') {\r\n\t\t\t\t\t_this._alertSuccess(event, data);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tif (_this._params.redirect) {\r\n\t\t\t\twindow.location.href = _this._params.redirect;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t_alertBefore() {\r\n\t\tconst _this = this;\r\n\r\n\t\tif (_this._params.alert.type === 'collapse') {\r\n\t\t\t[...document.getElementsByClassName(_this._params.classes.alertCollapse)].forEach(function (element) {\r\n\t\t\t\tif (element && element.classList.contains('show')) {\r\n\t\t\t\t\tVGCollapse.getOrCreateInstance(element, {toggle: false}).hide();\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t_this._statusButton('before');\r\n\t\tEventHandler.trigger(_this._element, EVENT_KEY_BEFORE, _this);\r\n\t}\r\n\r\n\t_alertError(event, data) {\r\n\t\tconst _this = this;\r\n\r\n\t\t_this._statusButton('after');\r\n\t\t_this._jsonParse(data, 'error');\r\n\t\tEventHandler.trigger(_this._element, EVENT_KEY_ERROR, [event, _this, data]);\r\n\t}\r\n\r\n\t_alertSuccess(event, data) {\r\n\t\tconst _this = this;\r\n\r\n\t\t_this._statusButton('after');\r\n\t\t_this._jsonParse(data, 'success');\r\n\t\tEventHandler.trigger(_this._element, EVENT_KEY_SUCCESS, [event, _this, data]);\r\n\t}\r\n\r\n\t_statusButton(status) {\r\n\t\tconst _this = this;\r\n\r\n\t\tif (!_this._button) return;\r\n\r\n\t\tlet btnSubmitText = _this._button,\r\n\t\t\tbtnText = {\r\n\t\t\tsend: 'Отправляем...',\r\n\t\t\ttext: 'Отправить'\r\n\t\t};\r\n\r\n\t\tif (Manipulator.has(_this._button, 'data-spinner') && status === 'before') {\r\n\t\t\t_this._button.insertAdjacentHTML('afterbegin', '<span class=\"spinner-border spinner-border-sm me-2\"></span>');\r\n\t\t}\r\n\r\n\t\tif (Manipulator.has(_this._button, 'data-text')) {\r\n\t\t\tbtnText.text = Manipulator.get(_this._button, 'data-text');\r\n\t\t} else {\r\n\t\t\tlet $btnText = _this._button.querySelector('[data-text]');\r\n\t\t\tif ($btnText) {\r\n\t\t\t\tbtnText.text = Manipulator.get($btnText, 'data-text');\r\n\t\t\t\tbtnSubmitText = $btnText;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (Manipulator.has(_this._button, 'data-text-send')) {\r\n\t\t\tbtnText.send = Manipulator.get(_this._button, 'data-text-send');\r\n\t\t} else {\r\n\t\t\tlet $btnTextSend = _this._button.querySelector('[data-text-send]');\r\n\t\t\tif ($btnTextSend) {\r\n\t\t\t\tbtnText.send = Manipulator.get($btnTextSend, 'data-text-send');\r\n\t\t\t\tbtnSubmitText = $btnTextSend;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (status === 'before') {\r\n\t\t\tif (_this._params.isBtnText) {\r\n\t\t\t\tbtnSubmitText.innerHTML = btnText.send;\r\n\t\t\t}\r\n\t\t\tManipulator.set(_this._button,'disabled', 'disabled');\r\n\t\t}\r\n\r\n\t\tif (status === 'after') {\r\n\t\t\tif (_this._params.isBtnText) {\r\n\t\t\t\tbtnSubmitText.innerHTML = btnText.text;\r\n\t\t\t}\r\n\t\t\tManipulator.remove(_this._button,'disabled');\r\n\r\n\t\t\tlet spinner = _this._button.querySelector('.spinner-border');\r\n\t\t\tif (spinner) spinner.remove();\r\n\t\t}\r\n\t}\r\n\r\n\t_jsonParse(data, status) {\r\n\t\tconst _this = this;\r\n\r\n\t\tif (_this._params.isJsonParse && typeof data === 'string') {\r\n\t\t\tlet parserData = {};\r\n\r\n\t\t\ttry {\r\n\t\t\t\tparserData = JSON.parse(data);\r\n\t\t\t\t_this.alert(parserData, status);\r\n\t\t\t} catch (e) {\r\n\t\t\t\t_this.alert(data, status);\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t_this.alert(data, status);\r\n\t\t}\r\n\t}\r\n\r\n\talert(data, status) {\r\n\t\tconst _this = this;\r\n\r\n\t\tif (isObject(data)) {\r\n\t\t\tif (('code' in data) && data.code && data.code === 200) {\r\n\t\t\t\tif ('response' in data && data.response) {\r\n\t\t\t\t\tlet response = normalizeData(data.response);\r\n\t\t\t\t\tif (typeof response === 'string') {\r\n\t\t\t\t\t\tif (response.indexOf(\"Parse error\") !== -1 || response.indexOf(\"syntax error\") !== -1) {\r\n\t\t\t\t\t\t\tstatus = 'error';\r\n\t\t\t\t\t\t\tdata = {\r\n\t\t\t\t\t\t\t\tresponse: {\r\n\t\t\t\t\t\t\t\t\ttitle: 'Error',\r\n\t\t\t\t\t\t\t\t\tmessage: 'Something went wrong, please repeat later'\r\n\t\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t\ttext: 'Something went wrong, please repeat later'\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tif ('errors' in response && normalizeData(response.errors)) {\r\n\t\t\t\t\t\t\tstatus = normalizeData(response.errors) ? 'error' : 'success';\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (!_this._params.alert.enabled) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (_this._params.alert.type === 'modal') {\r\n\t\t\t_this._alertModal(data, status)\r\n\t\t}\r\n\r\n\t\tif (_this._params.alert.type === 'collapse') {\r\n\t\t\t_this._alertCollapse(data, status)\r\n\t\t}\r\n\t}\r\n\r\n\t_alertModal(data, status) {\r\n\t\tconst _this = this;\r\n\r\n\t\t// Есть ли открытые модалки, закрываем\r\n\t\t[...document.getElementsByClassName('modal')].forEach(function (element) {\r\n\t\t\tif (element && element.classList.contains('show')) {\r\n\t\t\t\tlet mBS = bootstrap.Modal.getOrCreateInstance(element);\r\n\t\t\t\tmBS.hide();\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\t[...document.getElementsByClassName('vg-modal')].forEach(function (element) {\r\n\t\t\tif (element && element.classList.contains('show')) {\r\n\t\t\t\tconst mVG = VGModal.getOrCreateInstance(element);\r\n\t\t\t\tmVG.hide();\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tlet id = _this._params.classes.general + '-' + makeRandomString();\r\n\r\n\t\tlet $modal = Selectors.find('.' + _this._params.classes.alertModal);\r\n\t\tif ($modal) $modal.remove();\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tVGModal.init(id, {\r\n\t\t\t\tclasses: {\r\n\t\t\t\t\talert: _this._params.classes.alertModal\r\n\t\t\t\t}\r\n\t\t\t}, function (self) {\r\n\t\t\t\tlet element = self._element;\r\n\t\t\t\telement.classList.add(_this._params.classes.alertModal);\r\n\r\n\t\t\t\tlet $body = Selectors.find('.vg-modal-body', element);\r\n\t\t\t\tif ($body) $body.append(_this.setDataRelationStatus(element, status, data, 'modal'));\r\n\r\n\t\t\t\tself.toggle();\r\n\t\t\t});\r\n\t\t}, 800);\r\n\t}\r\n\r\n\t_alertCollapse(data, status) {\r\n\t\tconst _this = this;\r\n\r\n\t\tlet $collapse = Selectors.find('.' + _this._params.classes.alertCollapse);\r\n\t\tif (!$collapse) {\r\n\t\t\t$collapse = document.createElement('div');\r\n\t\t\t$collapse.classList.add(_this._params.classes.alertCollapse);\r\n\t\t\t$collapse.classList.add('vg-collapse');\r\n\t\t\t$collapse.id = _this._params.classes.general + '-' + makeRandomString();\r\n\t\t\t$collapse.append(_this.setDataRelationStatus($collapse, status, data, 'collapse'));\r\n\r\n\t\t\t_this._element.prepend($collapse);\r\n\t\t}\r\n\r\n\t\tVGCollapse.getOrCreateInstance($collapse, {toggle: false}).toggle();\r\n\t}\r\n\r\n\tsetDataRelationStatus($element, status, data, type) {\r\n\t\tlet $alert = Selectors.find('.vg-alert-' + status, $element);\r\n\r\n\t\tif (isObject(data)) {\r\n\t\t\tif (status === 'error') {\r\n\t\t\t\tif ('code' in data && data.code !== 200) {\r\n\t\t\t\t\tif ('text' in data && !data.text) {\r\n\t\t\t\t\t\tdata.text = 'Something went wrong, please repeat later';\r\n\r\n\t\t\t\t\t\tswitch (data.code) {\r\n\t\t\t\t\t\t\tcase 400:\r\n\t\t\t\t\t\t\t\tdata.text = 'Bad Request'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\tcase 401:\r\n\t\t\t\t\t\t\t\tdata.text = 'Unauthorized'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\tcase 403:\r\n\t\t\t\t\t\t\t\tdata.text = 'Unauthorized'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\tcase 413:\r\n\t\t\t\t\t\t\t\tdata.text = 'Forbidden'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\tcase 404:\r\n\t\t\t\t\t\t\t\tdata.text = 'Not Found'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\tcase 422:\r\n\t\t\t\t\t\t\t\tdata.text = 'Unprocessable Entity'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\tcase 500:\r\n\t\t\t\t\t\t\t\tdata.text = 'Internal Server Error'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t\tcase 504:\r\n\t\t\t\t\t\t\t\tdata.text = 'Gateway Timeout'\r\n\t\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tif ('response' in data) {\r\n\t\t\t\tlet response = normalizeData(data.response), title = '', txt = '', code = '';\r\n\t\t\t\tif (typeof response !== 'string') {\r\n\t\t\t\t\tif (!('view' in response)) {\r\n\t\t\t\t\t\tif ('title' in response) title = response.title;\r\n\t\t\t\t\t\tif (status === 'error' && data.code !== 200) {\r\n\t\t\t\t\t\t\tcode = ' ' + data.text + ' (' + data.code + ')';\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\ttxt += '<h4 class=\"vg-alert-content--title\">' + title + code + '</h4>';\r\n\r\n\t\t\t\t\t\tif ('message' in response) {\r\n\t\t\t\t\t\t\ttxt += '<div class=\"vg-alert-content--message\">' + response.message + '</div>'\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tif ('errors' in response) {\r\n\t\t\t\t\t\t\tlet errors = normalizeData(response.errors) || null;\r\n\t\t\t\t\t\t\tif (isObject(errors)) {\r\n\t\t\t\t\t\t\t\tfor (const error in errors) {\r\n\t\t\t\t\t\t\t\t\tif (Array.isArray(errors[error])) {\r\n\t\t\t\t\t\t\t\t\t\terrors[error].forEach(function (t) {\r\n\t\t\t\t\t\t\t\t\t\t\ttxt += '<div>'+ t +'</div>';\r\n\t\t\t\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t\t\ttxt = '<div>'+ errors[error] +'</div>';\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tdata = {\r\n\t\t\t\t\t\t\tview: txt\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\tdata.view = response;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (!$alert) {\r\n\t\t\t$alert = document.createElement('div');\r\n\t\t\t$alert.classList.add('vg-alert', 'vg-alert-' + status, 'vg-alert-' + type);\r\n\r\n\t\t\tlet content = document.createElement('div');\r\n\t\t\tcontent.classList.add('vg-alert-content');\r\n\r\n\t\t\tlet icon = document.createElement('div');\r\n\t\t\ticon.classList.add('vg-alert-content--icon');\r\n\r\n\t\t\tlet i = document.createElement('i');\r\n\t\t\ti.innerHTML = getSVG(status);\r\n\r\n\t\t\ticon.append(i);\r\n\t\t\tcontent.append(icon);\r\n\r\n\t\t\tlet text = document.createElement('div');\r\n\t\t\ttext.classList.add('vg-alert-content--text');\r\n\t\t\ttext.innerHTML = data.view;\r\n\r\n\t\t\tcontent.append(text);\r\n\t\t\t$alert.append(content);\r\n\t\t} else {\r\n\t\t\tlet text = Selectors.find('.vg-alert-content--text', $alert);\r\n\t\t\ttext.innerHTML = data.view;\r\n\t\t}\r\n\r\n\t\treturn $alert;\r\n\t}\r\n\r\n\t/**\r\n\t * Инициализация\r\n\t * @param element\r\n\t * @param params\r\n\t */\r\n\tstatic init(element, params = {}) {\r\n\t\tconst instance = VGFormSender.getOrCreateInstance(element, params);\r\n\t\tinstance.build();\r\n\t}\r\n}\r\n\r\nEventHandler.on(document, EVENT_SUBMIT_DATA_API, function (event) {\r\n\tif (!Manipulator.has(event.target, 'data-vgformsender')) {\r\n\t\treturn;\r\n\t}\r\n\r\n\tconst instance = VGFormSender.getOrCreateInstance(event.target, {});\r\n\tif (!instance) {\r\n\t\treturn;\r\n\t}\r\n\r\n\tif (instance._params.validate) {\r\n\t\tif (!instance._element.checkValidity()) {\r\n\t\t\tevent.preventDefault();\r\n\t\t\tevent.stopPropagation();\r\n\r\n\t\t\tinstance._element.classList.add(instance._params.classes.wasValidate);\r\n\r\n\t\t\treturn false;\r\n\t\t}\r\n\t}\r\n\r\n\tconst collectData = function(data, fields) {\r\n\t\tfor (let name in fields) {\r\n\t\t\tif (typeof fields[name] === 'object') {\r\n\t\t\t\tfor (let key in fields[name]) {\r\n\t\t\t\t\tlet arr = Object.keys(fields[name][key]).map(function (i) {\r\n\t\t\t\t\t\treturn fields[name][key][i];\r\n\t\t\t\t\t});\r\n\t\t\t\t\tdata.append(name, arr);\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tdata.append(name, fields[name]);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn data;\r\n\t}\r\n\r\n\tif (!instance._params.submit) {\r\n\t\tevent.preventDefault();\r\n\r\n\t\tlet data = new FormData(instance._element);\r\n\r\n\t\t// TODO доделать\r\n\t\t/*if (Array.isArray(instance._params.ajax.fields) && instance._params.ajax.fields.length) {\r\n\t\t\tdata = collectData(data, instance._params.ajax.fields);\r\n\t\t}*/\r\n\r\n\t\treturn instance.request(data, event);\r\n\t}\r\n})\r\n\r\nexport default VGFormSender;","import BaseModule from \"../../base-module\";\r\nimport {isDisabled, mergeDeepObject} from \"../../../utils/js/functions\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport Cookies from \"../../../utils/js/dom/cookie\";\r\nimport {dismissTrigger} from \"../../module-fn\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME     = 'lawcookie';\r\nconst NAME_KEY = 'vg.lawcookie';\r\n\r\nconst CLASS_NAME_SHOW = 'show';\r\n\r\nconst EVENT_KEY_HIDE   = `${NAME_KEY}.hide`;\r\nconst EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;\r\nconst EVENT_KEY_SHOW   = `${NAME_KEY}.show`;\r\nconst EVENT_KEY_SHOWN  = `${NAME_KEY}.shown`;\r\n\r\nconst SELECTOR_DATA_TOGGLE       = '[data-vg-toggle=\"lawcookie\"]';\r\nconst SELECTOR_DATA_TOGGLE_CLEAR = '[data-vg-toggle=\"lawcookie-clear\"]';\r\nconst EVENT_KEY_CLICK_DATA_API   = `click.${NAME_KEY}.data.api`;\r\n\r\nclass VGLawCookie extends BaseModule {\r\n\tstatic sParams = {};\r\n\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\t\t\tstorage: 'local', // cookie or local\r\n\t\t\tdelay: 500,\r\n\t\t\tcookie: {\r\n\t\t\t\tname: 'lawCookie',\r\n\t\t\t\tvalue: 'yes',\r\n\t\t\t\tattributes: {}\r\n\t\t\t},\r\n\t\t\tanimation: {\r\n\t\t\t\tenable: true,\r\n\t\t\t\tin: 'animate__fadeInUp',\r\n\t\t\t\tout: 'animate__fadeOutDown',\r\n\t\t\t\tdelay: 800,\r\n\t\t\t},\r\n\t\t\tajax: {\r\n\t\t\t\troute: '',\r\n\t\t\t\ttarget: '',\r\n\t\t\t\tmethod: 'get'\r\n\t\t\t}\r\n\t\t}, params));\r\n\r\n\t\tVGLawCookie.sParams = this._params;\r\n\r\n\t\tthis._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;\r\n\t\tthis._animation(this._element, VGLawCookie.NAME_KEY, this._params.animation);\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY;\r\n\t}\r\n\r\n\ttoggle() {\r\n\t\treturn !this._isShown() ? this.show() : this.hide();\r\n\t}\r\n\r\n\t_isShown() {\r\n\t\treturn this.storage().get();\r\n\t}\r\n\r\n\tshow() {\r\n\t\tif (isDisabled(this._element)) return;\r\n\r\n\t\tconst showEvent = EventHandler.trigger(this._element, EVENT_KEY_SHOW, {})\r\n\t\tif (showEvent.defaultPrevented) return;\r\n\r\n\t\tthis._element.classList.add(CLASS_NAME_SHOW);\r\n\r\n\t\tconst completeCallBack = () => {\r\n\t\t\tEventHandler.trigger(this._element, EVENT_KEY_SHOWN, {});\r\n\t\t}\r\n\t\tthis._queueCallback(completeCallBack, this._element, true, this._params.delay)\r\n\t}\r\n\r\n\thide() {\r\n\t\tconst hideEvent = EventHandler.trigger(this._element, EVENT_KEY_HIDE);\r\n\t\tif (hideEvent.defaultPrevented) return;\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis._element.classList.remove(CLASS_NAME_SHOW);\r\n\r\n\t\t\tconst completeCallback = () => EventHandler.trigger(this._element, EVENT_KEY_HIDDEN);\r\n\t\t\tthis._queueCallback(completeCallback, this._element, true);\r\n\t\t}, this._params.animation.delay);\r\n\t}\r\n\r\n\tstorage() {\r\n\t\tthis._storage = {\r\n\t\t\tisCookie: this._params.storage === 'cookie',\r\n\t\t\tstorage: this._params.storage === 'cookie' ? Cookies : localStorage,\r\n\t\t\tname: this._params.cookie.name,\r\n\t\t\tvalue: this._params.cookie.value,\r\n\t\t\tattributes: this._params.cookie.attributes,\r\n\t\t}\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tget() {\r\n\t\tif (this._storage.isCookie) {\r\n\t\t\treturn this._storage.storage.get(this._storage.name);\r\n\t\t} else {\r\n\t\t\treturn this._storage.storage.getItem(this._storage.name);\r\n\t\t}\r\n\t}\r\n\r\n\tset() {\r\n\t\tif (this._storage.isCookie) {\r\n\t\t\tthis._storage.storage.set(this._storage.name, this._storage.value, this._storage.attributes);\r\n\t\t} else {\r\n\t\t\tthis._storage.storage.setItem(this._storage.name, this._storage.value);\r\n\t\t}\r\n\t}\r\n\r\n\tdispose() {\r\n\t\tsuper.dispose();\r\n\t}\r\n\r\n\tstatic reset() {\r\n\t\tCookies.remove(VGLawCookie.sParams.cookie.name);\r\n\t\tlocalStorage.clear();\r\n\t\tlocation.reload();\r\n\t}\r\n\r\n\t/**\r\n\t * Инициализация\r\n\t * @param element\r\n\t * @param params\r\n\t */\r\n\tstatic init(element, params = {}) {\r\n\t\tconst instance = VGLawCookie.getOrCreateInstance(element, params);\r\n\t\tinstance.toggle();\r\n\t}\r\n}\r\n\r\ndismissTrigger(VGLawCookie);\r\n\r\nEventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {\r\n\tif (['A', 'AREA'].includes(this.tagName)) {\r\n\t\tevent.preventDefault()\r\n\t}\r\n\r\n\tif (isDisabled(this)) return;\r\n\r\n\tconst element = Selectors.find('#vg-lawcookie');\r\n\tif (!element) return;\r\n\r\n\tconst instance = VGLawCookie.getOrCreateInstance(element);\r\n\tinstance.storage().set();\r\n\tinstance.hide();\r\n});\r\n\r\nEventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE_CLEAR, function (event) {\r\n\tif (['A', 'AREA'].includes(this.tagName)) {\r\n\t\tevent.preventDefault()\r\n\t}\r\n\r\n\tif (isDisabled(this)) return;\r\n\r\n\tconst element = Selectors.find('#vg-lawcookie');\r\n\tif (!element) return;\r\n\r\n\tconst instance = VGLawCookie.getOrCreateInstance(element);\r\n\tinstance.dispose();\r\n\r\n\tlocation.reload();\r\n});\r\n\r\nexport default VGLawCookie;","import BaseModule from \"../../base-module\";\r\nimport ScrollBarHelper from \"../../../utils/js/components/scrollbar\";\r\nimport Backdrop from \"../../../utils/js/components/backdrop\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport {Manipulator} from \"../../../utils/js/dom/manipulator\";\r\nimport {execute, isDisabled, isRTL, mergeDeepObject, reflow} from \"../../../utils/js/functions\";\r\nimport {dismissTrigger} from \"../../module-fn\";\r\nimport Params from \"../../../utils/js/components/params\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME = 'modal';\r\nconst NAME_KEY = 'vg.modal';\r\n\r\nconst ESCAPE_KEY = 'Escape';\r\n\r\nconst OPEN_SELECTOR = '.vg-modal.show';\r\nconst SELECTOR_DIALOG = '.vg-modal-dialog';\r\nconst SELECTOR_MODAL_BODY = '.vg-modal-body';\r\nconst SELECTOR_DATA_TOGGLE = '[data-vg-toggle=\"modal\"]';\r\n\r\nconst CLASS_NAME_OPEN = 'vg-modal-open';\r\nconst CLASS_NAME_SHOW = 'show';\r\nconst CLASS_NAME_FADE = 'fade';\r\nconst CLASS_NAME_STATIC = 'vg-modal-static'\r\n\r\nconst EVENT_KEY_HIDE   = `${NAME_KEY}.hide`;\r\nconst EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;\r\nconst EVENT_KEY_SHOW   = `${NAME_KEY}.show`;\r\nconst EVENT_KEY_SHOWN  = `${NAME_KEY}.shown`;\r\nconst EVENT_KEY_RESIZE = `${NAME_KEY}.resize`\r\n\r\nconst EVENT_KEY_KEYDOWN_DISMISS     = `keydown.dismiss.${NAME_KEY}`;\r\nconst EVENT_KEY_HIDE_PREVENTED      = `hidePrevented.${NAME_KEY}`;\r\nconst EVENT_KEY_CLICK_DATA_API      = `click.${NAME_KEY}.data.api`;\r\nconst EVENT_KEY_MOUSEDOWN_DISMISS   = `mousedown.dismiss${NAME_KEY}`\r\nconst EVENT_KEY_CLICK_DISMISS           = `click.dismiss${NAME_KEY}`\r\n\r\nclass VGModal extends BaseModule {\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\t\t\tbackdrop: true,\r\n\t\t\tfocus: true,\r\n\t\t\tkeyboard: true,\r\n\t\t\tfields: [],\r\n\t\t\tajax: {\r\n\t\t\t\troute: '',\r\n\t\t\t\ttarget: '',\r\n\t\t\t\tmethod: 'get',\r\n\t\t\t\tloader: false\r\n\t\t\t},\r\n\t\t\tanimation: {\r\n\t\t\t\tenable: false,\r\n\t\t\t\tin: 'animate__rollIn',\r\n\t\t\t\tout: 'animate__rollOut',\r\n\t\t\t\tdelay: 800,\r\n\t\t\t},\r\n\t\t\tclasses: {\r\n\t\t\t\tgeneral: 'vg-modal',\r\n\t\t\t\tdialog: 'vg-modal-dialog',\r\n\t\t\t\tcontent: 'vg-modal-content',\r\n\t\t\t\theader: 'vg-modal-header',\r\n\t\t\t\ttitle: 'vg-modal-title',\r\n\t\t\t\tbody: 'vg-modal-body',\r\n\t\t\t\tfooter: 'vg-modal-footer',\r\n\t\t\t}\r\n\t\t}, params));\r\n\r\n\t\tthis._button = null;\r\n\t\tthis._dialog = Selectors.find(SELECTOR_DIALOG, this._element);\r\n\t\tthis._isShown = false;\r\n\t\tthis._isTransitioning = false;\r\n\t\tthis._scrollBar = new ScrollBarHelper();\r\n\r\n\t\tthis._addEventListeners();\r\n\t\tthis._dismissElement();\r\n\r\n\t\tthis._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;\r\n\t\tthis._animation(this._element, VGModal.NAME_KEY, this._params.animation);\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY;\r\n\t}\r\n\r\n\tstatic init(element, params, callback) {\r\n\t\tVGModal.build(element, params, callback);\r\n\t}\r\n\r\n\tstatic build(id, params, callback) {\r\n\t\tif (typeof id !== \"string\") return;\r\n\r\n\t\tlet _element = document.createElement('div');\r\n\t\t_element.classList.add('vg-modal', 'fade');\r\n\t\t_element.id = id;let dialog = document.createElement('div');\r\n\t\tdialog.classList.add('vg-modal-dialog');\r\n\r\n\t\tlet content = document.createElement('div');\r\n\t\tcontent.classList.add('vg-modal-content');\r\n\r\n\t\tlet btnClose = document.createElement('button');\r\n\t\tManipulator.set(btnClose, 'type', 'button');\r\n\t\tManipulator.set(btnClose, 'data-vg-dismiss', 'modal');\r\n\t\tManipulator.set(btnClose, 'data-vg-target', '#' + id);\r\n\t\tManipulator.set(btnClose, 'aria-label', 'close');\r\n\t\tbtnClose.classList.add('vg-btn-close');\r\n\r\n\t\tcontent.append(btnClose);\r\n\r\n\t\tlet body = document.createElement('div');\r\n\t\tbody.classList.add('vg-modal-body');\r\n\r\n\t\tcontent.append(body);\r\n\t\tdialog.append(content);\r\n\t\t_element.append(dialog);\r\n\r\n\t\tdocument.body.append(_element);\r\n\r\n\t\tconst modal = VGModal.getOrCreateInstance(_element, params);\r\n\r\n\t\texecute(callback, [modal]);\r\n\t}\r\n\r\n\ttoggle(relatedTarget) {\r\n\t\treturn !this._isShown ? this.show(relatedTarget) : this.hide();\r\n\t}\r\n\r\n\tshow(relatedTarget) {\r\n\t\tconst _this = this;\r\n\t\tif (isDisabled(_this._element)) return;\r\n\r\n\t\tthis._params = this._getParams(relatedTarget, this._params);\r\n\t\tthis._route();\r\n\r\n\t\tconst showEvent = EventHandler.trigger(this._element, EVENT_KEY_SHOW, { relatedTarget })\r\n\t\tif (showEvent.defaultPrevented) return;\r\n\r\n\t\tthis._isShown = true;\r\n\t\tthis._isTransitioning = true;\r\n\r\n\t\tthis._scrollBar.hide();\r\n\r\n\t\tdocument.body.classList.add(CLASS_NAME_OPEN);\r\n\r\n\t\tthis._addFieldsInModal(relatedTarget);\r\n\t\tthis._adjustDialog();\r\n\r\n\t\tBackdrop.show(() => this._showElement(relatedTarget));\r\n\t}\r\n\r\n\thide() {\r\n\t\tif (!this._isShown || this._isTransitioning) return;\r\n\r\n\t\tconst hideEvent = EventHandler.trigger(this._element, EVENT_KEY_HIDE);\r\n\t\tif (hideEvent.defaultPrevented) return;\r\n\r\n\t\tthis._isShown = false;\r\n\t\tthis._isTransitioning = true;\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis._element.classList.remove(CLASS_NAME_SHOW);\r\n\t\t\tthis._queueCallback(() => this._hideModal(), this._element, this._isAnimatedFade());\r\n\t\t}, this._params.animation.delay);\r\n\t}\r\n\r\n\t_hideModal() {\r\n\t\tthis._element.style.display = 'none';\r\n\t\tthis._element.setAttribute('aria-hidden', true);\r\n\t\tthis._element.removeAttribute('aria-modal');\r\n\t\tthis._element.removeAttribute('role');\r\n\t\tthis._isTransitioning = false;\r\n\r\n\t\tBackdrop.hide(() => {\r\n\t\t\tdocument.body.classList.remove(CLASS_NAME_OPEN);\r\n\t\t\tthis._resetAdjustments();\r\n\t\t\tthis._scrollBar.reset();\r\n\r\n\t\t\tEventHandler.trigger(this._element, EVENT_KEY_HIDDEN);\r\n\t\t})\r\n\t}\r\n\r\n\t_showElement(relatedTarget) {\r\n\t\tif (!document.body.contains(this._element)) {\r\n\t\t\tdocument.body.append(this._element);\r\n\t\t}\r\n\r\n\t\tthis._element.style.display = 'block';\r\n\t\tthis._element.removeAttribute('aria-hidden');\r\n\t\tthis._element.setAttribute('aria-modal', true);\r\n\t\tthis._element.setAttribute('role', 'dialog');\r\n\t\tthis._element.scrollTop = 0;\r\n\r\n\t\tconst modalBody = Selectors.find(SELECTOR_MODAL_BODY, this._dialog);\r\n\t\tif (modalBody) {\r\n\t\t\tmodalBody.scrollTop = 0;\r\n\t\t}\r\n\r\n\t\treflow(this._element);\r\n\r\n\t\tthis._element.classList.add(CLASS_NAME_SHOW)\r\n\r\n\t\tconst transitionComplete = () => {\r\n\t\t\tthis._isTransitioning = false;\r\n\t\t\tEventHandler.trigger(this._element, EVENT_KEY_SHOWN, {\r\n\t\t\t\trelatedTarget\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\tthis._queueCallback(transitionComplete, this._dialog, this._isAnimatedFade())\r\n\t}\r\n\r\n\t_isAnimatedFade() {\r\n\t\treturn this._element.classList.contains(CLASS_NAME_FADE)\r\n\t}\r\n\r\n\t_adjustDialog() {\r\n\t\tconst isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight\r\n\t\tconst scrollbarWidth = this._scrollBar.getWidth()\r\n\t\tconst isBodyOverflowing = scrollbarWidth > 0\r\n\r\n\t\tif (isBodyOverflowing && !isModalOverflowing) {\r\n\t\t\tconst property = isRTL() ? 'paddingLeft' : 'paddingRight'\r\n\t\t\tthis._element.style[property] = `${scrollbarWidth}px`\r\n\t\t}\r\n\r\n\t\tif (!isBodyOverflowing && isModalOverflowing) {\r\n\t\t\tconst property = isRTL() ? 'paddingRight' : 'paddingLeft'\r\n\t\t\tthis._element.style[property] = `${scrollbarWidth}px`\r\n\t\t}\r\n\t}\r\n\r\n\t_resetAdjustments() {\r\n\t\tthis._element.style.paddingLeft = ''\r\n\t\tthis._element.style.paddingRight = ''\r\n\t}\r\n\r\n\t_addEventListeners() {\r\n\t\tEventHandler.on(this._element, EVENT_KEY_KEYDOWN_DISMISS, event => {\r\n\t\t\tif (event.key !== ESCAPE_KEY) return;\r\n\r\n\t\t\tif (this._params.keyboard) {\r\n\t\t\t\tthis.hide();\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tthis._triggerBackdropTransition();\r\n\t\t});\r\n\r\n\t\tEventHandler.on(window, EVENT_KEY_RESIZE, () => {\r\n\t\t\tif (this._isShown && !this._isTransitioning) this._adjustDialog();\r\n\t\t});\r\n\r\n\t\tEventHandler.on(this._element, EVENT_KEY_MOUSEDOWN_DISMISS, event => {\r\n\t\t\tEventHandler.one(this._element, EVENT_KEY_CLICK_DISMISS, event2 => {\r\n\t\t\t\tif (this._element !== event.target || this._element !== event2.target) return;\r\n\r\n\t\t\t\tif (this._params.backdrop === 'static') {\r\n\t\t\t\t\tthis._triggerBackdropTransition();\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this._params.backdrop) {\r\n\t\t\t\t\tthis.hide();\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t});\r\n\t}\r\n\r\n\t_triggerBackdropTransition() {\r\n\t\tconst hideEvent = EventHandler.trigger(this._element, EVENT_KEY_HIDE_PREVENTED);\r\n\t\tif (hideEvent.defaultPrevented) return;\r\n\r\n\t\tconst isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;\r\n\t\tconst initialOverflowY = this._element.style.overflowY;\r\n\r\n\t\tif (initialOverflowY === 'hidden' || this._element.classList.contains(CLASS_NAME_STATIC)) return;\r\n\t\tif (!isModalOverflowing) this._element.style.overflowY = 'hidden';\r\n\r\n\t\tthis._element.classList.add(CLASS_NAME_STATIC);\r\n\r\n\t\tthis._queueCallback(() => {\r\n\t\t\tthis._element.classList.remove(CLASS_NAME_STATIC);\r\n\t\t\tthis._queueCallback(() => {\r\n\t\t\t\tthis._element.style.overflowY = initialOverflowY;\r\n\t\t\t}, this._dialog);\r\n\t\t}, this._dialog);\r\n\t}\r\n\r\n\t_addFieldsInModal(relatedTarget) {\r\n\t\tthis._params = this._getParams(relatedTarget, this._params);\r\n\r\n\t\tif (!this._params.fields.length) return;\r\n\r\n\t\tthis._params.fields.forEach(function (item) {\r\n\t\t\tif (!'name' in item && !'value' in item) return;\r\n\r\n\t\t\tlet elements = Selectors.findAll('[data-' + item.name + ']');\r\n\t\t\tif (!elements.length) return;\r\n\r\n\t\t\tfor (const elm of elements) {\r\n\t\t\t\tswitch (elm.tagName) {\r\n\t\t\t\t\tcase 'INPUT': elm.value = item.value; break;\r\n\t\t\t\t\tcase 'IMG': Manipulator.set(elm, 'src', item.value); break;\r\n\t\t\t\t\tdefault: elm.innerHTML = item.value;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n\r\ndismissTrigger(VGModal);\r\n\r\n\r\n/**\r\n * Data API implementation\r\n */\r\n\r\nEventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {\r\n\tconst target = Selectors.getElementFromSelector(this);\r\n\r\n\tif (['A', 'AREA'].includes(this.tagName)) event.preventDefault();\r\n\r\n\tEventHandler.one(target, EVENT_KEY_SHOW, showEvent => {\r\n\t\tif (showEvent.defaultPrevented) return;\r\n\t});\r\n\r\n\tconst alreadyOpen = Selectors.find(OPEN_SELECTOR);\r\n\tif (alreadyOpen) VGModal.getInstance(alreadyOpen).hide();\r\n\r\n\tconst data = VGModal.getOrCreateInstance(target);\r\n\tdata.toggle(this);\r\n})\r\n\r\nexport default VGModal;","import BaseModule from \"../../base-module\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport Responsive from \"../../../utils/js/components/responsive\";\r\nimport {getSVG} from \"../../module-fn\";\r\nimport {execute, isDisabled, isVisible, mergeDeepObject, noop, normalizeData} from \"../../../utils/js/functions\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport {Manipulator} from \"../../../utils/js/dom/manipulator\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME = 'nav';\r\nconst NAME_KEY = 'vg.nav';\r\n\r\n/**\r\n * Constants Classes\r\n */\r\nconst CLASS_NAME_SHOW   = 'show';\r\nconst CLASS_NAME_FADE   = 'fade';\r\nconst CLASS_NAME_ACTIVE = 'active';\r\nconst SELECTOR_DATA_TOGGLE = '.vg-nav a';\r\n\r\n/**\r\n * Constants Events\r\n */\r\nconst EVENT_KEY_HIDE   = `${NAME_KEY}.hide`;\r\nconst EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;\r\nconst EVENT_KEY_SHOW   = `${NAME_KEY}.show`;\r\nconst EVENT_KEY_SHOWN  = `${NAME_KEY}.shown`;\r\n\r\nconst EVENT_MOUSEOVER_DATA_API = `mouseover.${NAME_KEY}.data.api`;\r\nconst EVENT_MOUSEOUT_DATA_API  = `mouseout.${NAME_KEY}.data.api`;\r\nconst EVENT_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;\r\nconst EVENT_KEYUP_DATA_API = `keyup.${NAME_KEY}.data.api`;\r\nconst EVENT_RESIZE_DATA_API = `resize.${NAME_KEY}.data.api`;\r\n\r\nclass VGNav extends BaseModule {\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\t\t\tbreakpoint: false,\r\n\t\t\tplacement: 'horizontal',\r\n\t\t\tclasses: {\r\n\t\t\t\thamburgerActive: 'vg-nav-hamburger-active',\r\n\t\t\t\thamburgerAlways: 'vg-nav-hamburger-always',\r\n\t\t\t\thamburger: 'vg-nav-hamburger',\r\n\t\t\t\tcontainer: 'vg-nav-container',\r\n\t\t\t\twrapper: 'vg-nav-wrapper',\r\n\t\t\t\tactive: 'vg-nav-active',\r\n\t\t\t\texpand: 'vg-nav-expand',\r\n\t\t\t\tcloned: 'vg-nav-cloned',\r\n\t\t\t\thover: 'vg-nav-hover',\r\n\t\t\t\tflip: 'vg-nav-flip',\r\n\t\t\t\tXXXL: 'vg-nav-xxxl',\r\n\t\t\t\tXXL: 'vg-nav-xxl',\r\n\t\t\t\tXL: 'vg-nav-xl',\r\n\t\t\t\tLG: 'vg-nav-lg',\r\n\t\t\t\tMD: 'vg-nav-md',\r\n\t\t\t\tSM: 'vg-nav-sm',\r\n\t\t\t\tXS: 'vg-nav-xs'\r\n\t\t\t},\r\n\t\t\texpand: true,\r\n\t\t\thover: false,\r\n\t\t\tposition: true,\r\n\t\t\tcollapse: true,\r\n\t\t\ttoggle: '<span class=\"default\"></span>',\r\n\t\t\thamburger: {\r\n\t\t\t\tenable: true,\r\n\t\t\t\talways: false,\r\n\t\t\t\ttitle: '',\r\n\t\t\t\tbody: null\r\n\t\t\t},\r\n\t\t\tcallback: noop,\r\n\t\t\tanimation: true,\r\n\t\t\ttimeoutAnimation: 300,\r\n\t\t\tajax: {\r\n\t\t\t\troute: '',\r\n\t\t\t\ttarget: '',\r\n\t\t\t\tmethod: 'get'\r\n\t\t\t}\r\n\t\t}, params));\r\n\r\n\t\tthis._navigation = null;\r\n\t\tthis.navigation = '.' + this._params.classes.wrapper;\r\n\r\n\t\tthis.movedLinks = [];\r\n\t\tthis.$links = Selectors.findAll('.' + this._params.classes.wrapper + ' > li', this.navigation)\r\n\r\n\t\tif (this._params.animation === false) {\r\n\t\t\tthis._params.timeoutAnimation = 10\r\n\t\t}\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY;\r\n\t}\r\n\r\n\tget navigation() {\r\n\t\treturn this._navigation;\r\n\t}\r\n\r\n\tset navigation(el) {\r\n\t\tlet elm = Selectors.find(el, this._element);\r\n\t\tif (!elm) return;\r\n\t\tthis._navigation = elm;\r\n\t}\r\n\r\n\tbuild() {\r\n\t\tif (!this.navigation) return;\r\n\r\n\t\tlet params = this._params;\r\n\r\n\t\t// Вешаем основные классы\r\n\t\tthis._element.classList.add(params.classes.container);\r\n\t\tthis._element.classList.add('vg-nav-' + params.placement);\r\n\r\n\t\t// Если нужно оставить список меню или установить медиа точку\r\n\t\tif (!params.breakpoint) {\r\n\t\t\tparams.expand = false;\r\n\t\t}\r\n\r\n\t\tif (!params.hamburger.always) {\r\n\t\t\tif (!params.breakpoint || !params.expand) {\r\n\t\t\t\tthis._element.classList.add(params.classes.expand);\r\n\t\t\t} else if (params.breakpoint !== false) {\r\n\t\t\t\tthis._element.classList.add('vg-nav-' + params.breakpoint);\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthis._element.classList.add(params.classes.hamburgerAlways);\r\n\t\t}\r\n\r\n\t\t// Меню срабатывает при наведении, если это не мобильное устройство\r\n\t\tif (params.hover) {\r\n\t\t\tthis._element.classList.add(params.classes.hover);\r\n\r\n\t\t\tif (Responsive.checkMobileOrTablet()) {\r\n\t\t\t\tthis._element.classList.remove(params.classes.hover);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Устанавливаем гамбургер, если его нет в разметке\r\n\t\tif (params.expand && !params.hamburger.body) {\r\n\t\t\tlet isHamburger = Selectors.find('.' + params.classes.hamburger, this._element);\r\n\r\n\t\t\tif (isHamburger === null) {\r\n\t\t\t\tlet mTitle = '',\r\n\t\t\t\t\thamburger = '<span class=\"' + params.classes.hamburger + '--lines\"><span></span><span></span><span></span></span>';\r\n\r\n\t\t\t\tif (params.hamburger.title) {\r\n\t\t\t\t\tmTitle = '<span class=\"' + params.classes.hamburger + '--title\">'+ params.hamburger.title +'</span>';\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (params.hamburger.body !== null) {\r\n\t\t\t\t\thamburger = params.hamburger.body;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tthis._element.insertAdjacentHTML('afterbegin','<a href=\"#sidebar-nav\" class=\"' + params.classes.hamburger + '\" data-vg-toggle=\"sidebar\">' + mTitle + hamburger +'</a>');\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Устанавливаем указатель переключателя\r\n\t\tif (params.toggle) {\r\n\t\t\tlet $dropdown_a = [...Selectors.findAll('.dropdown-mega > a, .dropdown > a', this._element)],\r\n\t\t\t\ttoggle = '<span class=\"toggle\">' + params.toggle + '</span>';\r\n\r\n\t\t\tif ($dropdown_a.length) {\r\n\t\t\t\t$dropdown_a.forEach(function (elem) {\r\n\t\t\t\t\tif (!elem.querySelector('.toggle') && !elem.closest('.dots')) {\r\n\t\t\t\t\t\telem.setAttribute('aria-expanded', 'false')\r\n\t\t\t\t\t\telem.insertAdjacentHTML('beforeend', toggle)\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (params.collapse && Responsive.check(this) && params.placement !== 'vertical') {\r\n\t\t\tsetCollapse(this);\r\n\t\t}\r\n\r\n\t\tif ('afterInit' in this._params.callback) {\r\n\t\t\texecute(this._params.callback.afterInit, [this]);\r\n\t\t}\r\n\r\n\t\t/**\r\n\t\t * Функция сворачивания\r\n\t\t * TODO Придумать что то с мега меню, которое уходит в подменю\r\n\t\t * TODO Так же есть косяки при ресайзе\r\n\t\t */\r\n\t\tfunction setCollapse(_this) {\r\n\t\t\tlet width_navigation_responsive = _this.navigation.clientWidth,\r\n\t\t\t\twidth_all_links_responsive = 0,\r\n\t\t\t\t$dots = Selectors.find('.dots', _this.navigation),\r\n\t\t\t\t_dots = getSVG('dots');\r\n\r\n\t\t\tif (_this.$links.length) {\r\n\t\t\t\tif ($dots) {\r\n\t\t\t\t\twidth_all_links_responsive = $dots.clientWidth\r\n\t\t\t\t} else {\r\n\t\t\t\t\tlet $a = Selectors.find('a', _this.$links[0]),\r\n\t\t\t\t\t\t$linkStyle = getComputedStyle($a),\r\n\t\t\t\t\t\tpaddingLeft = normalizeData($linkStyle.paddingLeft.slice(0, -2)),\r\n\t\t\t\t\t\tpaddingRight =  normalizeData($linkStyle.paddingRight.slice(0, -2)),\r\n\t\t\t\t\t\tpadding = paddingLeft + paddingRight;\r\n\r\n\t\t\t\t\t// TODO не совсем верно, но мы точно знаем ширину точек в svg - 16px\r\n\t\t\t\t\twidth_all_links_responsive = padding + 16;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tfor (let $link of _this.$links) {\r\n\t\t\t\t\tlet width = $link.getBoundingClientRect().width;\r\n\t\t\t\t\twidth_all_links_responsive = width_all_links_responsive + width;\r\n\r\n\t\t\t\t\tif ((width_navigation_responsive) < width_all_links_responsive) {\r\n\t\t\t\t\t\t_this.movedLinks.push($link);\r\n\t\t\t\t\t\t$link.remove();\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tif (_this.movedLinks.length) {\r\n\t\t\t\t\t\t\tif ($dots) {\r\n\t\t\t\t\t\t\t\t_this.navigation.insertBefore(_this.movedLinks[0], $dots)\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\t_this.navigation.appendChild(_this.movedLinks[0])\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t_this.movedLinks.splice(0, 1);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (_this.movedLinks.length) {\r\n\t\t\t\t\tif (!$dots) {\r\n\t\t\t\t\t\t_this.navigation.insertAdjacentHTML('beforeend','<li class=\"dropdown dots\">' + '<a href=\"#\" aria-expanded=\"false\">'+ _dots +'</a></li>');\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\tif ($dots) {\r\n\t\t\t\t\t\t$dots.remove();\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tlet $d = _this.navigation.querySelector('.dots');\r\n\t\t\t\tif ($d && _this.movedLinks.length) {\r\n\t\t\t\t\tlet $dropdown = $d.querySelector('ul');\r\n\t\t\t\t\tif ($dropdown) {\r\n\t\t\t\t\t\tfor (let link of _this.movedLinks) {\r\n\t\t\t\t\t\t\t$dropdown.prepend(link);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tlet $dropdown = document.createElement('ul');\r\n\t\t\t\t\t\t$dropdown.classList.add('dropdown-content');\r\n\t\t\t\t\t\t$dropdown.classList.add('right');\r\n\r\n\t\t\t\t\t\tfor (let link of _this.movedLinks) {\r\n\t\t\t\t\t\t\t$dropdown.prepend(link);\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\t$d.appendChild($dropdown);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tshow(relatedTarget) {\r\n\t\tlet target = relatedTarget.relatedTarget;\r\n\r\n\t\tif (!target || isDisabled(target)) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (!target.closest('.dropdown-content')) {\r\n\t\t\ttarget.classList.add('first');\r\n\t\t}\r\n\r\n\t\tconst showEvent = EventHandler.trigger(target, EVENT_KEY_SHOW, { relatedTarget });\r\n\t\tif (showEvent.defaultPrevented) return;\r\n\r\n\t\tlet drop = Selectors.find('.dropdown-content', target),\r\n\t\t\tlink = target.firstElementChild;\r\n\r\n\t\tif (link) link.setAttribute('aria-expanded', 'true');\r\n\t\tdrop.classList.add(CLASS_NAME_SHOW);\r\n\t\ttarget.classList.add(CLASS_NAME_ACTIVE);\r\n\r\n\t\tsetDropPosition(drop)\r\n\r\n\t\tconst completeCallBack = () => {\r\n\t\t\tdrop.classList.add(CLASS_NAME_FADE);\r\n\t\t\tEventHandler.trigger(target, EVENT_KEY_SHOWN, relatedTarget)\r\n\t\t}\r\n\t\tthis._queueCallback(completeCallBack, drop, true, 50);\r\n\r\n\t\t/**\r\n\t\t *\r\n\t\t * @param $drop\r\n\t\t */\r\n\t\tfunction setDropPosition($drop) {\r\n\t\t\tlet {width, right} = $drop.getBoundingClientRect(),\r\n\t\t\t\twindow_width = window.innerWidth;\r\n\r\n\t\t\tlet N_right = window_width - right - width;\r\n\r\n\t\t\t$drop.classList.remove('right');\r\n\t\t\t$drop.classList.remove('left');\r\n\r\n\t\t\tlet $parent = $drop.closest('li'),\r\n\t\t\t\t$ul = $parent.querySelectorAll('ul');\r\n\r\n\t\t\tif (N_right > width) {\r\n\t\t\t\tfor (const $el of $ul) {\r\n\t\t\t\t\t$el.classList.add('left');\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tfor (const $el of $ul) {\r\n\t\t\t\t\t$el.classList.add('right');\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\thide(relatedTarget) {\r\n\t\tconst _this = this;\r\n\t\tif ('ontouchstart' in document.documentElement) {\r\n\t\t\tfor (const element of [].concat(...document.body.children)) {\r\n\t\t\t\tEventHandler.off(element, 'mouseover', noop);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tlet element = relatedTarget.relatedTarget;\r\n\r\n\t\tif ('elm' in relatedTarget && relatedTarget.elm) {\r\n\t\t\telement = relatedTarget.elm\r\n\t\t}\r\n\r\n\t\tif (element) {\r\n\t\t\tconst hideEvent = EventHandler.trigger(element, EVENT_KEY_HIDE);\r\n\t\t\tif (hideEvent.defaultPrevented) return;\r\n\r\n\t\t\telement.classList.remove(CLASS_NAME_ACTIVE);\r\n\r\n\t\t\tif (element.classList.contains('first')) {\r\n\t\t\t\telement.classList.remove('first');\r\n\t\t\t}\r\n\r\n\t\t\t[...Selectors.findAll('.' + CLASS_NAME_SHOW, element)].forEach(function (el, index) {\r\n\t\t\t\tel.classList.remove(CLASS_NAME_FADE);\r\n\r\n\t\t\t\tlet parent = el.closest('.dropdown');\r\n\t\t\t\tif (parent.classList.contains(CLASS_NAME_ACTIVE)) {\r\n\t\t\t\t\tparent.classList.remove(CLASS_NAME_ACTIVE);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tlet link = el.previousElementSibling;\r\n\t\t\t\tif (link) link.setAttribute('aria-expanded', 'false');\r\n\r\n\t\t\t\tif (index === 0) {\r\n\t\t\t\t\tconst completeCallback = () => {\r\n\t\t\t\t\t\tel.classList.remove(CLASS_NAME_SHOW);\r\n\t\t\t\t\t\tEventHandler.trigger(el, EVENT_KEY_HIDDEN, relatedTarget)\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\t_this._queueCallback(completeCallback, el, true, 500);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * TODO если на странице несколько навигаций, то есть косяки\r\n\t * @param element\r\n\t * @param params\r\n\t */\r\n\tstatic init(element, params = {}) {\r\n\t\tconst instance = VGNav.getOrCreateInstance(element, params);\r\n\t\tinstance.build();\r\n\r\n\t\tlet drops = Selectors.findAll('.dropdown', instance._navigation)\r\n\r\n\t\tif (instance._params.hover) {\r\n\t\t\t[...drops].forEach(function (el) {\r\n\t\t\t\tlet currentElem = null;\r\n\t\t\t\tEventHandler.on(el, EVENT_MOUSEOVER_DATA_API, function (event) {\r\n\t\t\t\t\tif (currentElem) return;\r\n\t\t\t\t\tVGNav.hideOpenDrops(event);\r\n\r\n\t\t\t\t\tlet target = event.target.closest('.dropdown');\r\n\t\t\t\t\tif (!target) return;\r\n\r\n\t\t\t\t\tif (!instance.navigation.contains(target)) return;\r\n\t\t\t\t\tcurrentElem = target;\r\n\r\n\t\t\t\t\tlet relatedTarget = {\r\n\t\t\t\t\t\trelatedTarget: target\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tinstance.show(relatedTarget);\r\n\t\t\t\t});\r\n\t\t\t\tEventHandler.on(el, EVENT_MOUSEOUT_DATA_API, function (event) {\r\n\t\t\t\t\tif (!currentElem) return;\r\n\r\n\t\t\t\t\tlet relatedTarget = event.relatedTarget.closest('.dropdown'),\r\n\t\t\t\t\t\telm = currentElem;\r\n\r\n\t\t\t\t\twhile (relatedTarget) {\r\n\t\t\t\t\t\tif (relatedTarget === currentElem) return;\r\n\t\t\t\t\t\trelatedTarget = relatedTarget.parentNode;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tcurrentElem = null;\r\n\t\t\t\t\tinstance.hide({relatedTarget: relatedTarget, elm: elm});\r\n\t\t\t\t})\r\n\t\t\t})\r\n\t\t} else {\r\n\t\t\tEventHandler.on(document, EVENT_KEYUP_DATA_API, VGNav.clearDrops);\r\n\t\t\tEventHandler.on(document, EVENT_CLICK_DATA_API, VGNav.clearDrops);\r\n\t\t\tEventHandler.on(document, EVENT_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {\r\n\t\t\t\tif (!Manipulator.has(this, 'aria-expanded')) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif ('click' in instance._params.callback) {\r\n\t\t\t\t\texecute(instance._params.callback.click, [this]);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tevent.preventDefault();\r\n\r\n\t\t\t\tlet self = this.closest('.vg-nav'),\r\n\t\t\t\t\tisFirst = self.querySelector('.first');\r\n\r\n\t\t\t\tlet target = this.closest('.dropdown');\r\n\t\t\t\tif (!target) return;\r\n\r\n\t\t\t\tif (isDisabled(target) && !isVisible(target)) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (isFirst && this.closest('.first')) {\r\n\t\t\t\t\tif (target.classList.contains('active')) {\r\n\t\t\t\t\t\tinstance.hide({relatedTarget: target});\r\n\t\t\t\t\t\treturn;\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\t[...Selectors.findAll('.active', self)].forEach(function (el) {\r\n\t\t\t\t\t\tif (el && el !== target) {\r\n\t\t\t\t\t\t\tinstance.hide({relatedTarget: el})\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\r\n\t\t\t\tinstance.show({relatedTarget: target});\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\tconst vgNavSidebar = document.getElementById('sidebar-nav');\r\n\t\tlet hamburger = instance._element.querySelector('.' + instance._params.classes.hamburger);\r\n\r\n\t\tif (vgNavSidebar && hamburger) {\r\n\t\t\tvgNavSidebar.addEventListener('vg.sidebar.show', function () {\r\n\t\t\t\thamburger.classList.add(instance._params.classes.hamburgerActive);\r\n\t\t\t});\r\n\r\n\t\t\tvgNavSidebar.addEventListener('vg.sidebar.hide', function () {\r\n\t\t\t\thamburger.classList.remove(instance._params.classes.hamburgerActive);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tstatic clearDrops(event) {\r\n\t\tif (event.button === 2 || (event.type === 'keyup' && event.key !== 'Tab')) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tVGNav.hideOpenDrops(event)\r\n\t}\r\n\r\n\tstatic hideOpenDrops(event) {\r\n\t\tconst openToggles = Selectors.findAll('.dropdown:not(.disabled):not(:disabled).active');\r\n\r\n\t\tfor (const toggle of openToggles) {\r\n\t\t\tconst context = VGNav.getInstance(toggle.closest('.vg-nav'));\r\n\t\t\tif (!context) continue;\r\n\r\n\t\t\tif (event.target.closest('.first')) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tconst relatedTarget = { relatedTarget: toggle }\r\n\r\n\t\t\tif (event.type === 'click') {\r\n\t\t\t\trelatedTarget.clickEvent = event\r\n\t\t\t}\r\n\r\n\t\t\tcontext.hide(relatedTarget)\r\n\t\t}\r\n\t}\r\n}\r\n\r\nEventHandler.on(window, EVENT_RESIZE_DATA_API, function (event) {\r\n\tconst instance = VGNav.getOrCreateInstance('.vg-nav', {});\r\n\tinstance.build();\r\n})\r\n\r\nexport default VGNav;","import BaseModule from \"../../base-module\";\r\nimport {execute, isDisabled, isVisible, mergeDeepObject, noop} from \"../../../utils/js/functions\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport {Manipulator} from \"../../../utils/js/dom/manipulator\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME = 'rollup';\r\nconst NAME_KEY = 'vg.rollup';\r\nconst CLASS_NAME_SHOW = 'show';\r\nconst CLASS_NAME_HIDE = 'd-none';\r\nconst SELECTOR_DATA_TOGGLE= '[data-vg-toggle=\"rollup\"]'\r\n\r\nconst EVENT_KEY_HIDE   = `${NAME_KEY}.hide`;\r\nconst EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;\r\nconst EVENT_KEY_SHOW   = `${NAME_KEY}.show`;\r\nconst EVENT_KEY_SHOWN  = `${NAME_KEY}.shown`;\r\n\r\nconst EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;\r\n\r\nclass VGRollup  extends BaseModule {\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\r\n\t\t}, params));\r\n\r\n\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY\r\n\t}\r\n\r\n\tbuild() {\r\n\r\n\t}\r\n\r\n\ttoggle(relatedTarget) {\r\n\t\treturn !this._isShown() ? this.show(relatedTarget) : this.hide();\r\n\t}\r\n\r\n\tshow(relatedTarget) {\r\n\r\n\t}\r\n\r\n\t_isShown() {\r\n\t\treturn this._element.classList.contains(CLASS_NAME_SHOW);\r\n\t}\r\n\r\n\t/**\r\n\t * Инициализация\r\n\t * @param element\r\n\t * @param params\r\n\t */\r\n\tstatic init(element, params = {}) {\r\n\t\tconst instance = VGRollup.getOrCreateInstance(element, params);\r\n\t\tinstance.toggle();\r\n\t}\r\n}\r\n\r\n/**\r\n * Data API implementation\r\n */\r\nEventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {\r\n\tconst target = Selectors.getElementFromSelector(this);\r\n\tif (!target) return;\r\n\r\n\tif (['A', 'AREA'].includes(this.tagName)) {\r\n\t\tevent.preventDefault()\r\n\t}\r\n\r\n\tif (isDisabled(this)) {\r\n\t\treturn\r\n\t}\r\n\r\n\tthis.setAttribute('aria-expanded', true);\r\n\r\n\tconst data = VGRollup.getOrCreateInstance(target)\r\n\tdata.toggle(this);\r\n});\r\n\r\n\r\nexport default VGRollup;","import BaseModule from \"../../base-module\";\r\nimport {isEmptyObj, mergeDeepObject, transliterate} from \"../../../utils/js/functions\";\r\nimport {Manipulator} from \"../../../utils/js/dom/manipulator\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME = 'select';\r\nconst NAME_KEY = 'vg.select';\r\n\r\nconst CLASS_NAME_CONTAINER      = 'vg-select';\r\nconst CLASS_NAME_DROPDOWN       = 'vg-select-dropdown';\r\nconst CLASS_NAME_LIST           = 'vg-select-list';\r\nconst CLASS_NAME_OPTION         = 'vg-select-list--option';\r\nconst CLASS_NAME_OPTGROUP       = 'vg-select-list--optgroup';\r\nconst CLASS_NAME_OPTGROUP_TITLE = 'vg-select-list--optgroup-title';\r\nconst CLASS_NAME_CURRENT        = 'vg-select-current';\r\nconst CLASS_NAME_SEARCH         = 'vg-select-search';\r\nconst CLASS_NAME_SELECTED       = 'selected';\r\n\r\nconst EVENT_KEY_CHANGE          = `${NAME_KEY}.change`;\r\n\r\nlet observerTimout;\r\n\r\nclass VGSelect extends BaseModule {\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\t\t\tsearch: false\r\n\t\t}, params));\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY;\r\n\t}\r\n\r\n\tbuild(isRebuild, elm = null) {\r\n\t\tconst _this = this;\r\n\t\tlet element = this._element;\r\n\r\n\t\tif (elm) element = elm;\r\n\r\n\t\tif (element.dataset?.inited === 'true' && !isRebuild) {\r\n\t\t\treturn;\r\n\t\t} else if (isRebuild) {\r\n\t\t\t_this.destroy(element);\r\n\t\t}\r\n\r\n\t\telement.parentElement.style.position = 'relative';\r\n\r\n\t\tlet option_selected = element.options[element.selectedIndex].innerText,\r\n\t\t\toptions = element.options;\r\n\r\n\t\t// Создаем основной элемент с классами селекта\r\n\t\tlet classes = Manipulator.get(element,'class'),\r\n\t\t\tselect = document.createElement('div');\r\n\r\n\t\tclasses = classes.split(' ');\r\n\r\n\t\tfor (const _class of classes) {\r\n\t\t\tselect.classList.add(_class)\r\n\t\t}\r\n\r\n\t\tif (Manipulator.has(element, 'disabled')) select.classList.add('disabled')\r\n\r\n\t\tlet elData = Manipulator.get(element);\r\n\t\tif (!isEmptyObj(elData)) {\r\n\t\t\tfor (const key of Object.keys(elData)) {\r\n\t\t\t\tManipulator.set(select,'data-' + key, elData[key]);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Создаем элемент с отображением выбранного варианта\r\n\t\tlet current = document.createElement('div');\r\n\t\tcurrent.classList.add(CLASS_NAME_CURRENT);\r\n\t\tcurrent.innerText = option_selected.trim();\r\n\t\tselect.append(current);\r\n\r\n\t\t// Создаем элемент выпадающего списка\r\n\t\tlet dropdown = document.createElement('div');\r\n\t\tdropdown.classList.add(CLASS_NAME_DROPDOWN);\r\n\t\tselect.append(dropdown);\r\n\r\n\t\t// Создаем список и варианты селекта\r\n\t\tlet list = document.createElement('ul');\r\n\t\tlist.classList.add(CLASS_NAME_LIST);\r\n\r\n\t\tlet optGroup = element.querySelectorAll('optgroup');\r\n\r\n\t\tif (optGroup.length) {\r\n\t\t\tlet isSelected = false;\r\n\t\t\t[...optGroup].forEach(function (el) {\r\n\t\t\t\tlet olOptGroup = document.createElement('ol');\r\n\t\t\t\tolOptGroup.classList.add(CLASS_NAME_OPTGROUP);\r\n\r\n\t\t\t\tlet liLabel = document.createElement('li');\r\n\t\t\t\tliLabel.innerHTML = el.label.trim();\r\n\t\t\t\tliLabel.classList.add(CLASS_NAME_OPTGROUP_TITLE)\r\n\r\n\t\t\t\tolOptGroup.prepend(liLabel)\r\n\r\n\t\t\t\tlet optGroupOptions = el.querySelectorAll('option');\r\n\r\n\t\t\t\tcreateLi(optGroupOptions, olOptGroup, isSelected);\r\n\r\n\t\t\t\tlist.append(olOptGroup);\r\n\t\t\t\tisSelected = true;\r\n\t\t\t});\r\n\t\t} else {\r\n\t\t\tlet isSelected = false;\r\n\t\t\tcreateLi(options, list, isSelected);\r\n\t\t}\r\n\r\n\t\tfunction createLi(options, list, isSelected) {\r\n\t\t\tlet i = 0;\r\n\t\t\tfor (const option of options) {\r\n\t\t\t\tlet li = document.createElement('li');\r\n\r\n\t\t\t\tli.innerHTML = option.innerHTML.trim().replace(/<\\/[^>]+(>|$)/g, \"\")\r\n\t\t\t\tli.dataset.value = Manipulator.get(option, 'value');\r\n\t\t\t\tli.classList.add(CLASS_NAME_OPTION);\r\n\r\n\t\t\t\tlet liData = Manipulator.get(option);\r\n\t\t\t\tif (!isEmptyObj(liData)) {\r\n\t\t\t\t\tfor (const key of Object.keys(liData)) {\r\n\t\t\t\t\t\tManipulator.set(li, 'data-' + key, liData[key]);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (i === element.selectedIndex && !isSelected) {\r\n\t\t\t\t\tli.classList.add('selected');\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (Manipulator.has(option, 'disabled')) li.classList.add('disabled');\r\n\t\t\t\tif (Manipulator.has(option, 'hidden')) li.classList.add('hidden');\r\n\r\n\t\t\t\tlist.append(li);\r\n\r\n\t\t\t\ti++;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tdropdown.append(list);\r\n\r\n\t\t// Добавляем все созданный контейнер после селекта\r\n\t\telement.insertAdjacentElement('afterend', select);\r\n\r\n\t\t// помечаем элемент инициализированным\r\n\t\telement.dataset.inited = 'true';\r\n\r\n\t\tif (_this._params.search) {\r\n\t\t\tthis.search(select);\r\n\t\t}\r\n\r\n\t\tthis._addEventListeners(select);\r\n\t}\r\n\r\n\tdestroy(select) {\r\n\t\tlet element = select.nextElementSibling;\r\n\r\n\t\tif (element) {\r\n\t\t\tif (element.classList.contains(CLASS_NAME_CONTAINER)) {\r\n\t\t\t\telement.remove();\r\n\r\n\t\t\t\tselect.selectedIndex = 0;\r\n\t\t\t\t[...select.querySelectorAll('option')].forEach(function (el, index) {\r\n\t\t\t\t\tif (el.hasAttribute('selected')) {\r\n\t\t\t\t\t\tselect.selectedIndex = index;\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\trefresh(select) {\r\n\t\tconst _this = this;\r\n\r\n\t\tlet observer = new MutationObserver(() => {\r\n\t\t\tclearTimeout(observerTimout);\r\n\t\t\tobserverTimout = setTimeout(() => {\r\n\t\t\t\t_this.build(true, select);\r\n\t\t\t}, 100);\r\n\t\t});\r\n\r\n\t\tobserver.observe(select, {\r\n\t\t\tattributeFilter: ['disabled', 'required', 'style', 'hidden'],\r\n\t\t\tchildList: true,\r\n\t\t\tsubtree: true,\r\n\t\t\tcharacterDataOldValue: true,\r\n\t\t});\r\n\t}\r\n\r\n\tsearch(select) {\r\n\t\tconst _this = this;\r\n\r\n\t\tlet dropdown = select.querySelector('.' + CLASS_NAME_DROPDOWN);\r\n\r\n\t\tlet search_container = document.createElement('div');\r\n\t\tsearch_container.classList.add(CLASS_NAME_SEARCH);\r\n\r\n\t\tlet input = document.createElement('input');\r\n\t\tinput.setAttribute('name', 'vg-select-search');\r\n\t\tinput.setAttribute('type', 'text');\r\n\t\tinput.setAttribute('placeholder', 'Поиск...');\r\n\r\n\t\tsearch_container.append(input);\r\n\t\tdropdown.prepend(search_container);\r\n\r\n\t\tsearch_container.querySelector('[name=vg-select-search]').addEventListener('keyup', (e) => {\r\n\t\t\te.preventDefault();\r\n\r\n\t\t\tlet el = e.target;\r\n\r\n\t\t\tlet selectList = el?.closest('.' + CLASS_NAME_DROPDOWN).querySelector('.' + CLASS_NAME_LIST);\r\n\t\t\tif (selectList) {\r\n\t\t\t\tlet options = [...selectList.querySelectorAll('.' + CLASS_NAME_OPTION)],\r\n\t\t\t\t\toptionsGroup = [...selectList.querySelectorAll('.' + CLASS_NAME_OPTGROUP)],\r\n\t\t\t\t\tvalue = el?.value;\r\n\r\n\t\t\t\toptions = options.concat(optionsGroup);\r\n\r\n\t\t\t\tfor (const option of options) {\r\n\t\t\t\t\tManipulator.show(option);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (value.length) {\r\n\t\t\t\t\tvalue = value.trim();\r\n\t\t\t\t\tvalue = value.toLowerCase();\r\n\t\t\t\t\tvalue = transliterate(value, true);\r\n\r\n\t\t\t\t\tfor (const option of options) {\r\n\t\t\t\t\t\tlet text = option.innerText.toLowerCase();\r\n\r\n\t\t\t\t\t\tif (text.indexOf(value) === -1) Manipulator.hide(option);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tdispose() {\r\n\t\tsuper.dispose();\r\n\t}\r\n\r\n\t_addEventListeners(select) {\r\n\t\tconst _this = this;\r\n\r\n\t\tselect.querySelector('.' + CLASS_NAME_CURRENT).onclick = function (e) {\r\n\t\t\tlet el = e.target,\r\n\t\t\t\tcontainer = el.closest('.' + CLASS_NAME_CONTAINER);\r\n\r\n\t\t\tlet selects = document.querySelectorAll('.' + CLASS_NAME_CONTAINER);\r\n\t\t\tif (selects.length) {\r\n\t\t\t\tfor (const els of selects) {\r\n\t\t\t\t\tif (els !== container) {\r\n\t\t\t\t\t\tels?.classList.remove('show');\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tif (container.classList.contains('show')) {\r\n\t\t\t\tcontainer.classList.remove('show');\r\n\t\t\t} else {\r\n\t\t\t\tcontainer.classList.add('show');\r\n\r\n\t\t\t\tif (_this._params.search) {\r\n\t\t\t\t\tlet input = container.querySelector('input');\r\n\t\t\t\t\tif (input) input.focus();\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\tselect.querySelectorAll('.' + CLASS_NAME_OPTION).forEach((option) => {\r\n\t\t\toption.addEventListener('click', (e) => {\r\n\t\t\t\te.preventDefault();\r\n\r\n\t\t\t\tlet el = e.target;\r\n\r\n\t\t\t\tif (!el.classList.contains('disabled')) {\r\n\t\t\t\t\tlet container = el.closest('.' + CLASS_NAME_CONTAINER),\r\n\t\t\t\t\t\toptions = container.querySelectorAll('.' + CLASS_NAME_OPTION);\r\n\r\n\t\t\t\t\tif (options.length) {\r\n\t\t\t\t\t\tfor (const option of options) {\r\n\t\t\t\t\t\t\toption.classList.remove('selected');\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tel.classList.add('selected');\r\n\r\n\t\t\t\t\tcontainer.querySelector('.' + CLASS_NAME_CURRENT).innerText = el.innerText;\r\n\t\t\t\t\tcontainer.classList.remove('show');\r\n\r\n\t\t\t\t\tlet select = container.previousSibling;\r\n\t\t\t\t\tselect.value = el.dataset.value;\r\n\t\t\t\t\tEventHandler.trigger(select, EVENT_KEY_CHANGE)\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\r\n\t\twindow.addEventListener('click', function (e) {\r\n\t\t\tif (!e?.target.closest('.' + CLASS_NAME_CONTAINER)) {\r\n\t\t\t\tlet selects = document.querySelectorAll('.' + CLASS_NAME_CONTAINER);\r\n\t\t\t\tif (selects.length) {\r\n\t\t\t\t\tfor (const el of selects) {\r\n\t\t\t\t\t\tel?.classList.remove('show');\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\t[...document.querySelectorAll('form')].forEach(function (form) {\r\n\t\t\tform.addEventListener(\"reset\", function () {\r\n\t\t\t\tform.querySelectorAll('select.vg-select').forEach(function (select) {\r\n\t\t\t\t\tVGSelect.init(select, {}, true)\r\n\t\t\t\t})\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * Инициализация\r\n\t * @param element\r\n\t * @param params\r\n\t * @param isRebuild\r\n\t */\r\n\tstatic init(element, params = {}, isRebuild = false) {\r\n\t\tconst instance = VGSelect.getOrCreateInstance(element, params);\r\n\t\tinstance.build(isRebuild);\r\n\t}\r\n}\r\n\r\nexport default VGSelect;","import BaseModule from \"../../base-module\";\r\nimport {isDisabled, isVisible, mergeDeepObject} from \"../../../utils/js/functions\";\r\nimport EventHandler from \"../../../utils/js/dom/event\";\r\nimport {dismissTrigger} from \"../../module-fn\";\r\nimport Selectors from \"../../../utils/js/dom/selectors\";\r\nimport Backdrop from \"../../../utils/js/components/backdrop\";\r\nimport Overflow from \"../../../utils/js/components/overflow\";\r\n\r\n/**\r\n * Constants\r\n */\r\nconst NAME = 'sidebar';\r\nconst NAME_KEY = 'vg.sidebar';\r\nconst SELECTOR_DATA_TOGGLE= '[data-vg-toggle=\"sidebar\"]';\r\n\r\nconst CLASS_NAME_SHOW = 'show';\r\nconst CLASS_NAME_OPEN = 'vg-sidebar-open';\r\n\r\nconst EVENT_KEY_HIDE   = `${NAME_KEY}.hide`;\r\nconst EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;\r\nconst EVENT_KEY_SHOW   = `${NAME_KEY}.show`;\r\nconst EVENT_KEY_SHOWN  = `${NAME_KEY}.shown`;\r\n\r\nconst EVENT_KEY_KEYDOWN_DISMISS = `keydown.dismiss.${NAME_KEY}`;\r\nconst EVENT_KEY_HIDE_PREVENTED = `hidePrevented.${NAME_KEY}`;\r\nconst EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;\r\n\r\nclass VGSidebar extends BaseModule {\r\n\tconstructor(element, params = {}) {\r\n\t\tsuper(element, params);\r\n\r\n\t\tthis._params = this._getParams(element, mergeDeepObject({\r\n\t\t\tbackdrop: true,\r\n\t\t\toverflow: true,\r\n\t\t\tkeyboard: true,\r\n\t\t\tanimation: {\r\n\t\t\t\tenable: false,\r\n\t\t\t\tin: 'animate__rollIn',\r\n\t\t\t\tout: 'animate__rollOut',\r\n\t\t\t\tdelay: 800,\r\n\t\t\t},\r\n\t\t\tajax: {\r\n\t\t\t\troute: '',\r\n\t\t\t\ttarget: '',\r\n\t\t\t\tmethod: 'get'\r\n\t\t\t}\r\n\t\t}, params));\r\n\r\n\t\tthis._addEventListeners();\r\n\t\tthis._dismissElement();\r\n\r\n\t\tthis._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;\r\n\t\tthis._animation(this._element, VGSidebar.NAME_KEY, this._params.animation);\r\n\t}\r\n\r\n\tstatic get NAME() {\r\n\t\treturn NAME;\r\n\t}\r\n\r\n\tstatic get NAME_KEY() {\r\n\t\treturn NAME_KEY\r\n\t}\r\n\r\n\ttoggle(relatedTarget) {\r\n\t\treturn !this._isShown() ? this.show(relatedTarget) : this.hide();\r\n\t}\r\n\r\n\tshow(relatedTarget) {\r\n\t\tconst _this = this;\r\n\t\tif (isDisabled(_this._element)) return;\r\n\r\n\t\t_this._params = _this._getParams(relatedTarget, _this._params);\r\n\t\t_this._route();\r\n\r\n\t\tconst showEvent = EventHandler.trigger(_this._element, EVENT_KEY_SHOW, { relatedTarget })\r\n\t\tif (showEvent.defaultPrevented) return;\r\n\r\n\t\tif (_this._params.backdrop) {\r\n\t\t\tBackdrop.show();\r\n\t\t}\r\n\r\n\t\tif (_this._params.overflow) {\r\n\t\t\tOverflow.append();\r\n\t\t}\r\n\r\n\t\t_this._element.classList.add(CLASS_NAME_SHOW);\r\n\t\tdocument.body.classList.add(CLASS_NAME_OPEN);\r\n\r\n\t\tconst completeCallBack = () => {\r\n\t\t\tEventHandler.on(Selectors.find('.vg-backdrop'), 'mousedown.vg.backdrop', function () {\r\n\t\t\t\t_this.hide();\r\n\t\t\t});\r\n\r\n\t\t\tEventHandler.trigger(_this._element, EVENT_KEY_SHOWN, { relatedTarget });\r\n\t\t}\r\n\t\t_this._queueCallback(completeCallBack, _this._element, true, 50)\r\n\t}\r\n\r\n\thide() {\r\n\t\tconst _this = this;\r\n\t\tif (isDisabled(_this._element)) return;\r\n\r\n\t\tconst hideEvent = EventHandler.trigger(this._element, EVENT_KEY_HIDE);\r\n\t\tif (hideEvent.defaultPrevented) return;\r\n\r\n\t\tif (_this._params.backdrop) {\r\n\t\t\tBackdrop.hide(function () {\r\n\t\t\t\tif (_this._params.overflow) {\r\n\t\t\t\t\tOverflow.destroy();\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\tif (_this._params.overflow) {\r\n\t\t\tOverflow.destroy();\r\n\t\t}\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\t_this._element.setAttribute('aria-expanded', false);\r\n\t\t\t_this._element.classList.remove(CLASS_NAME_SHOW);\r\n\r\n\t\t\tconst completeCallback = () => {\r\n\t\t\t\tdocument.body.classList.remove(CLASS_NAME_OPEN);\r\n\t\t\t\tEventHandler.trigger(this._element, EVENT_KEY_HIDDEN);\r\n\t\t\t}\r\n\t\t\tthis._queueCallback(completeCallback, this._element, true);\r\n\t\t}, this._params.animation.delay);\r\n\t}\r\n\r\n\tdispose() {\r\n\t\tsuper.dispose();\r\n\t}\r\n\r\n\t_isShown() {\r\n\t\treturn this._element.classList.contains(CLASS_NAME_SHOW);\r\n\t}\r\n\r\n\t_addEventListeners() {\r\n\t\tEventHandler.on(document, EVENT_KEY_KEYDOWN_DISMISS, event => {\r\n\t\t\tif (event.key !== 'Escape') return;\r\n\r\n\t\t\tif (this._params.keyboard) {\r\n\t\t\t\tthis.hide();\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\tEventHandler.trigger(this._element, EVENT_KEY_HIDE_PREVENTED)\r\n\t\t});\r\n\t}\r\n}\r\n\r\ndismissTrigger(VGSidebar);\r\n\r\n/**\r\n * Data API implementation\r\n */\r\nEventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {\r\n\tconst target = Selectors.getElementFromSelector(this);\r\n\r\n\tif (['A', 'AREA'].includes(this.tagName)) {\r\n\t\tevent.preventDefault()\r\n\t}\r\n\r\n\tif (isDisabled(this)) {\r\n\t\treturn\r\n\t}\r\n\r\n\tthis.setAttribute('aria-expanded', true);\r\n\tEventHandler.one(target, EVENT_KEY_HIDDEN, () => {\r\n\t\t//if (isVisible(this)) this.focus();\r\n\t\tthis.setAttribute('aria-expanded', false);\r\n\t})\r\n\r\n\tconst alreadyOpen = Selectors.find('.vg-sidebar.show')\r\n\tif (alreadyOpen && alreadyOpen !== target) {\r\n\t\tVGSidebar.getInstance(alreadyOpen).hide()\r\n\t}\r\n\r\n\tconst data = VGSidebar.getOrCreateInstance(target)\r\n\tdata.toggle(this);\r\n});\r\n\r\nexport default VGSidebar;\r\n","import {isElement, mergeDeepObject} from \"../functions\";\r\nimport EventHandler from \"../dom/event\";\r\n\r\n/**\r\n * Классы для анимаций смотрим здесь\r\n * https://animate.style/\r\n *\r\n * Работает с модулями у которых есть события show, hide, hidden\r\n */\r\nclass Animation {\r\n\tconstructor(element, key, params = {}) {\r\n\t\tthis._params = mergeDeepObject({\r\n\t\t\tenable: false,\r\n\t\t\tin: 'animate__backInUp',\r\n\t\t\tout: 'animate__backOutUp',\r\n\t\t\tdelay: 0,\r\n\t\t}, params);\r\n\r\n\t\tthis.classes = {\r\n\t\t\tanimated: 'animate__animated'\r\n\t\t}\r\n\r\n\t\tif (!this._params.enable) return;\r\n\t\tif (!isElement(element)) return;\r\n\r\n\t\tthis._element = element;\r\n\t\tthis._name_key = key;\r\n\r\n\t\tif (!this._element.classList.contains(this.classes.animated)) {\r\n\t\t\tthis._element.classList.add(this.classes.animated);\r\n\t\t}\r\n\r\n\t\tthis._triggers();\r\n\t}\r\n\r\n\t_triggers() {\r\n\t\tEventHandler.on(this._element, this._name_key + '.show', () => {\r\n\t\t\tthis._element.classList.remove(this._params.out);\r\n\t\t\tthis._element.classList.add(this._params.in);\r\n\t\t});\r\n\r\n\t\tEventHandler.on(this._element, this._name_key + '.hide', () => {\r\n\t\t\tthis._element.classList.remove(this._params.in);\r\n\t\t\tthis._element.classList.add(this._params.out);\r\n\t\t});\r\n\r\n\t\tEventHandler.on(this._element, this._name_key + '.hidden', () => {\r\n\t\t\tthis._element.classList.remove(this._params.out);\r\n\t\t});\r\n\t}\r\n}\r\n\r\nexport default Animation;","import {execute} from \"../functions\";\r\nimport Selectors from \"../dom/selectors\";\r\nimport EventHandler from \"../dom/event\";\r\nimport Overflow from \"./overflow\";\r\n\r\nconst NAME = 'backdrop';\r\nconst CLASS_NAME = 'vg-backdrop';\r\nconst CLASS_NAME_FADE = 'fade';\r\nconst EVENT_MOUSEDOWN = `mousedown.vg.${NAME}`;\r\n\r\nlet backdrop_delay = 500;\r\n\r\nclass Backdrop {\r\n\tstatic show(callback) {\r\n\t\tBackdrop._append()\r\n\t\texecute(callback);\r\n\t}\r\n\r\n\tstatic hide(callback) {\r\n\t\tBackdrop._destroy();\r\n\t\texecute(callback);\r\n\t}\r\n\r\n\tstatic _append() {\r\n\t\tif (Selectors.find('.' + CLASS_NAME)) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\tlet backdrop = document.createElement('div');\r\n\t\tbackdrop.classList.add(CLASS_NAME);\r\n\r\n\t\tdocument.body.append(backdrop);\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tbackdrop.classList.add(CLASS_NAME_FADE)\r\n\t\t}, 50);\r\n\r\n\t\tEventHandler.on(backdrop, EVENT_MOUSEDOWN, () => {\r\n\t\t\tBackdrop.hide()\r\n\t\t\tOverflow.destroy();\r\n\t\t});\r\n\t}\r\n\r\n\tstatic _destroy() {\r\n\t\tlet element = Selectors.find('.' + CLASS_NAME);\r\n\t\tif (!element) return;\r\n\r\n\t\telement.classList.remove(CLASS_NAME_FADE);\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\telement.remove();\r\n\t\t}, backdrop_delay);\r\n\t}\r\n}\r\n\r\nexport default Backdrop;","import {Manipulator} from \"../dom/manipulator\";\r\n\r\n/**\r\n * Класс Overflow\r\n * Запрещает скроллинг и убирает его, компенсируя отступом\r\n */\r\n\r\nclass Overflow {\r\n\tstatic append() {\r\n\t\tdocument.body.style.paddingRight = getWidth() + 'px';\r\n\t\tdocument.body.style.overflow = 'hidden';\r\n\r\n\t\tfunction getWidth() {\r\n\t\t\tconst documentWidth = document.documentElement.clientWidth\r\n\t\t\treturn Math.abs(window.innerWidth - documentWidth)\r\n\t\t}\r\n\t}\r\n\r\n\tstatic destroy() {\r\n\t\tdocument.body.style.overflow = '';\r\n\t\tdocument.body.style.paddingRight = '';\r\n\r\n\t\tlet styles = Manipulator.get(document.body, 'style');\r\n\t\tif (!styles) Manipulator.remove(document.body, 'style');\r\n\t}\r\n}\r\n\r\nexport default Overflow;","import {isElement, mergeDeepObject, normalizeData} from \"../functions\";\r\nimport {Manipulator} from \"../dom/manipulator\";\r\n\r\nclass Params {\r\n\tconstructor(params, element = null) {\r\n\t\tthis._params = this.merge(params, element);\r\n\t}\r\n\r\n\tget() {\r\n\t\treturn this._params;\r\n\t}\r\n\r\n\tfromElement(element) {\r\n\t\treturn isElement(element) ? Manipulator.get(element) : {};\r\n\t}\r\n\r\n\tmerge(params, element) {\r\n\t\tlet mParams = mergeDeepObject(params, this.fromElement(element));\r\n\r\n\t\tfor (let key in mParams) {\r\n\t\t\tif (key.indexOf('-') !== -1) {\r\n\t\t\t\tlet keys = key.split('-'),\r\n\t\t\t\t\tvalue = normalizeData(mParams[key]);\r\n\r\n\t\t\t\tif (keys[0] in mParams) {\r\n\t\t\t\t\tif (keys[1] in mParams[keys[0]]) {\r\n\t\t\t\t\t\tmParams[keys[0]][keys[1]] = value;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tdelete mParams[key];\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif ('params' in mParams) {\r\n\t\t\tmParams = mergeDeepObject(mParams, mParams.params);\r\n\t\t\tdelete mParams.params;\r\n\t\t}\r\n\r\n\t\treturn mParams;\r\n\t}\r\n}\r\n\r\nexport default Params;","import {mergeDeepObject, normalizeData} from \"../functions\";\r\n\r\n/**\r\n * Класс Placement, определяет и устанавливает местоположение элемента на странице.\r\n * TODO класс не дописан\r\n */\r\n\r\nclass Placement {\r\n\tconstructor(arg = {}) {\r\n\t\tthis.params = mergeDeepObject({\r\n\t\t\telement: null,\r\n\t\t\tdrop: null\r\n\t\t}, arg);\r\n\t}\r\n\r\n\t_getPlacement() {\r\n\t\tconst _this = this;\r\n\t\tconst _parent = (self) => {\r\n\t\t\tlet parent = self.parentNode,\r\n\t\t\t\toverflow = getComputedStyle(parent).overflow;\r\n\r\n\t\t\tif (parent.tagName !== 'BODY') {\r\n\t\t\t\tif (overflow === 'visible') {\r\n\t\t\t\t\t_parent(parent)\r\n\t\t\t\t} else {\r\n\t\t\t\t\treturn parent;\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\treturn null;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tlet isFixed = false, top, left,\r\n\t\t\tbounds = _this.params.drop.getBoundingClientRect(),\r\n\t\t\tparent = _this.params.element.getBoundingClientRect();\r\n\r\n\t\tif (_parent(_this.params.element)) {\r\n\t\t\tisFixed = true;\r\n\t\t\ttop = bounds.top;\r\n\t\t\tleft = bounds.left;\r\n\t\t} else {\r\n\t\t\tlet styles = getComputedStyle(_this.params.drop);\r\n\t\t\ttop = normalizeData(styles.top.slice(0, -2));\r\n\t\t\tleft = normalizeData(styles.left.slice(0, -2));\r\n\t\t}\r\n\r\n\t\tif ((bounds.left + bounds.width) > window.innerWidth) {\r\n\t\t\tleft = parent.width - bounds.width;\r\n\t\t}\r\n\r\n\t\treturn {\r\n\t\t\tisFixed: isFixed,\r\n\t\t\ttop: top,\r\n\t\t\tleft: left\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport default Placement;","/**\r\n * Класс Responsive, работает по таким же медиа точкам, что и bootstrap\r\n * и определяет на тач устройства.\r\n */\r\n\r\nclass Responsive {\r\n\tconstructor() {\r\n\t\tthis.breakpoints = {\r\n\t\t\txs: 0,\r\n\t\t\tsm: 576,\r\n\t\t\tmd: 768,\r\n\t\t\tlg: 992,\r\n\t\t\txl: 1200,\r\n\t\t\txxl: 1400,\r\n\t\t\txxxl: 1600,\r\n\t\t};\r\n\t}\r\n\r\n\t/**\r\n\t * Если наша ширина экрана совпадает с диапазоном который указан в модуле выдаем true, иначе false\r\n\t * @param module\r\n\t * @returns {boolean}\r\n\t */\r\n\tstatic check(module) {\r\n\t\tlet instance = new this ;\r\n\t\treturn instance.define(module);\r\n\t}\r\n\r\n\t/**\r\n\t * Проверяет на тач устройства. TODO не совсем правильно, надо сделать по-другому\r\n\t * @returns {boolean}\r\n\t */\r\n\tstatic checkMobileOrTablet() {\r\n\t\tlet check = false;\r\n\t\t(function(a) {\r\n\t\t\tif (/(android|bb\\d+|meego).+mobile|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(a)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\\-(n|u)|c55\\/|capi|ccwa|cdm\\-|cell|chtm|cldc|cmd\\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\\-s|devi|dica|dmob|do(c|p)o|ds(12|\\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\\-|_)|g1 u|g560|gene|gf\\-5|g\\-mo|go(\\.w|od)|gr(ad|un)|haie|hcit|hd\\-(m|p|t)|hei\\-|hi(pt|ta)|hp( i|ip)|hs\\-c|ht(c(\\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\\-(20|go|ma)|i230|iac( |\\-|\\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\\/)|klon|kpt |kwc\\-|kyo(c|k)|le(no|xi)|lg( g|\\/(k|l|u)|50|54|\\-[a-w])|libw|lynx|m1\\-w|m3ga|m50\\/|ma(te|ui|xo)|mc(01|21|ca)|m\\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\\-2|po(ck|rt|se)|prox|psio|pt\\-g|qa\\-a|qc(07|12|21|32|60|\\-[2-7]|i\\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\\-|oo|p\\-)|sdk\\/|se(c(\\-|0|1)|47|mc|nd|ri)|sgh\\-|shar|sie(\\-|m)|sk\\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\\-|v\\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\\-|tdg\\-|tel(i|m)|tim\\-|t\\-mo|to(pl|sh)|ts(70|m\\-|m3|m5)|tx\\-9|up(\\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\\-|your|zeto|zte\\-/i.test(a.slice(0,4))){\r\n\t\t\t\tcheck = true;\r\n\t\t\t}\r\n\t\t})(navigator.userAgent||navigator.vendor||window.opera);\r\n\r\n\t\treturn check;\r\n\t}\r\n\r\n\tdefine(module) {\r\n\t\tlet windowWidth = window.innerWidth,\r\n\t\t\tresponsive_size = this._checkResponsiveClass(module),\r\n\t\t\tbreakpoints = this.breakpoints,\r\n\t\t\tpoint = Object.keys(breakpoints).find(key => breakpoints[key] === responsive_size);\r\n\r\n\t\tlet keys = Object.keys(breakpoints),\r\n\t\t\tloc = keys.indexOf(point);\r\n\r\n\t\treturn windowWidth >= breakpoints[keys[loc + 1]];\r\n\t}\r\n\r\n\t_checkResponsiveClass(module) {\r\n\t\tlet element = module._element,\r\n\t\t\tparams = module._params,\r\n\t\t\tcurrent_responsive_size = 0;\r\n\r\n\t\tif (element.classList.contains(params.classes.XXXL)) {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.xxxl;\r\n\t\t} else if (element.classList.contains(params.classes.XXL)) {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.xxl;\r\n\t\t} else if (element.classList.contains(params.classes.XL)) {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.xl;\r\n\t\t} else if (element.classList.contains(params.classes.LG)) {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.lg;\r\n\t\t} else if (element.classList.contains(params.classes.MD)) {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.md;\r\n\t\t} else if (element.classList.contains(params.classes.SM)) {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.sm;\r\n\t\t} else if (element.classList.contains(params.classes.XS)) {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.xs;\r\n\t\t} else {\r\n\t\t\tcurrent_responsive_size = this.breakpoints.xs;\r\n\t\t}\r\n\r\n\t\treturn current_responsive_size\r\n\t}\r\n}\r\n\r\nexport default Responsive;","/**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap util/scrollBar.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n */\r\n\r\nimport {Manipulator} from \"../dom/manipulator\";\r\nimport {isElement} from \"../functions\";\r\nimport Selectors from \"../dom/selectors\";\r\n\r\n/**\r\n * Constants\r\n */\r\n\r\nconst SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top'\r\nconst SELECTOR_STICKY_CONTENT = '.sticky-top'\r\nconst PROPERTY_PADDING = 'padding-right'\r\nconst PROPERTY_MARGIN = 'margin-right'\r\n\r\n/**\r\n * Class definition\r\n */\r\n\r\nclass ScrollBarHelper {\r\n\tconstructor() {\r\n\t\tthis._element = document.body\r\n\t}\r\n\r\n\t// Public\r\n\tgetWidth() {\r\n\t\t// https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes\r\n\t\tconst documentWidth = document.documentElement.clientWidth\r\n\t\treturn Math.abs(window.innerWidth - documentWidth)\r\n\t}\r\n\r\n\thide() {\r\n\t\tconst width = this.getWidth()\r\n\t\tthis._disableOverFlow()\r\n\t\t// give padding to element to balance the hidden scrollbar width\r\n\t\tthis._setElementAttributes(this._element, PROPERTY_PADDING, calculatedValue => calculatedValue + width)\r\n\t\t// trick: We adjust positive paddingRight and negative marginRight to sticky-top elements to keep showing fullwidth\r\n\t\tthis._setElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING, calculatedValue => calculatedValue + width)\r\n\t\tthis._setElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN, calculatedValue => calculatedValue - width)\r\n\t}\r\n\r\n\treset() {\r\n\t\tthis._resetElementAttributes(this._element, 'overflow')\r\n\t\tthis._resetElementAttributes(this._element, PROPERTY_PADDING)\r\n\t\tthis._resetElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING)\r\n\t\tthis._resetElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN)\r\n\t}\r\n\r\n\tisOverflowing() {\r\n\t\treturn this.getWidth() > 0\r\n\t}\r\n\r\n\t// Private\r\n\t_disableOverFlow() {\r\n\t\tthis._saveInitialAttribute(this._element, 'overflow')\r\n\t\tthis._element.style.overflow = 'hidden'\r\n\t}\r\n\r\n\t_setElementAttributes(selector, styleProperty, callback) {\r\n\t\tconst scrollbarWidth = this.getWidth()\r\n\t\tconst manipulationCallBack = element => {\r\n\t\t\tif (element !== this._element && window.innerWidth > element.clientWidth + scrollbarWidth) {\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\r\n\t\t\tthis._saveInitialAttribute(element, styleProperty)\r\n\t\t\tconst calculatedValue = window.getComputedStyle(element).getPropertyValue(styleProperty)\r\n\t\t\telement.style.setProperty(styleProperty, `${callback(Number.parseFloat(calculatedValue))}px`)\r\n\t\t}\r\n\r\n\t\tthis._applyManipulationCallback(selector, manipulationCallBack)\r\n\t}\r\n\r\n\t_saveInitialAttribute(element, styleProperty) {\r\n\t\tconst actualValue = element.style.getPropertyValue(styleProperty)\r\n\t\tif (actualValue) {\r\n\t\t\tManipulator.get(element, styleProperty, actualValue)\r\n\t\t}\r\n\t}\r\n\r\n\t_resetElementAttributes(selector, styleProperty) {\r\n\t\tconst manipulationCallBack = element => {\r\n\t\t\tconst value = Manipulator.get(element, styleProperty)\r\n\t\t\t// We only want to remove the property if the value is `null`; the value can also be zero\r\n\t\t\tif (value === null) {\r\n\t\t\t\telement.style.removeProperty(styleProperty)\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\r\n\t\t\tManipulator.remove(element, styleProperty)\r\n\t\t\telement.style.setProperty(styleProperty, value)\r\n\t\t}\r\n\r\n\t\tthis._applyManipulationCallback(selector, manipulationCallBack)\r\n\t}\r\n\r\n\t_applyManipulationCallback(selector, callBack) {\r\n\t\tif (isElement(selector)) {\r\n\t\t\tcallBack(selector)\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tfor (const sel of Selectors.findAll(selector, this._element)) {\r\n\t\t\tcallBack(sel)\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport default ScrollBarHelper","/*! js-cookie v3.0.1 | MIT */\r\n\r\nfunction assign (target) {\r\n\tfor (let i = 1; i < arguments.length; i++) {\r\n\t\tlet source = arguments[i];\r\n\t\tfor (let key in source) {\r\n\t\t\ttarget[key] = source[key];\r\n\t\t}\r\n\t}\r\n\treturn target\r\n}\r\n\r\nlet defaultConverter = {\r\n\tread: function (value) {\r\n\t\tif (value[0] === '\"') {\r\n\t\t\tvalue = value.slice(1, -1);\r\n\t\t}\r\n\t\treturn value.replace(/(%[\\dA-F]{2})+/gi, decodeURIComponent)\r\n\t},\r\n\twrite: function (value) {\r\n\t\treturn encodeURIComponent(value).replace(\r\n\t\t\t/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,\r\n\t\t\tdecodeURIComponent\r\n\t\t)\r\n\t}\r\n};\r\n\r\nfunction init (converter, defaultAttributes) {\r\n\tfunction set (key, value, attributes) {\r\n\t\tif (typeof document === 'undefined') {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tattributes = assign({}, defaultAttributes, attributes);\r\n\r\n\t\tif (typeof attributes.expires === 'number') {\r\n\t\t\tattributes.expires = new Date(Date.now() + attributes.expires * 864e5);\r\n\t\t}\r\n\t\tif (attributes.expires) {\r\n\t\t\tattributes.expires = attributes.expires.toUTCString();\r\n\t\t}\r\n\r\n\t\tkey = encodeURIComponent(key)\r\n\t\t\t.replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\r\n\t\t\t.replace(/[()]/g, escape);\r\n\r\n\t\tlet stringifiedAttributes = '';\r\n\t\tfor (let attributeName in attributes) {\r\n\t\t\tif (!attributes[attributeName]) {\r\n\t\t\t\tcontinue\r\n\t\t\t}\r\n\r\n\t\t\tstringifiedAttributes += '; ' + attributeName;\r\n\r\n\t\t\tif (attributes[attributeName] === true) {\r\n\t\t\t\tcontinue\r\n\t\t\t}\r\n\r\n\t\t\t// Considers RFC 6265 section 5.2:\r\n\t\t\t// ...\r\n\t\t\t// 3.  If the remaining unparsed-attributes contains a %x3B (\";\")\r\n\t\t\t//     character:\r\n\t\t\t// Consume the characters of the unparsed-attributes up to,\r\n\t\t\t// not including, the first %x3B (\";\") character.\r\n\t\t\t// ...\r\n\t\t\tstringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\r\n\t\t}\r\n\r\n\t\treturn (document.cookie =\r\n\t\t\tkey + '=' + converter.write(value, key) + stringifiedAttributes)\r\n\t}\r\n\r\n\tfunction get (key) {\r\n\t\tif (typeof document === 'undefined' || (arguments.length && !key)) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\t// To prevent the for loop in the first place assign an empty array\r\n\t\t// in case there are no cookies at all.\r\n\t\tlet cookies = document.cookie ? document.cookie.split('; ') : [];\r\n\t\tlet jar = {};\r\n\t\tfor (let i = 0; i < cookies.length; i++) {\r\n\t\t\tlet parts = cookies[i].split('=');\r\n\t\t\tlet value = parts.slice(1).join('=');\r\n\r\n\t\t\ttry {\r\n\t\t\t\tlet foundKey = decodeURIComponent(parts[0]);\r\n\t\t\t\tjar[foundKey] = converter.read(value, foundKey);\r\n\r\n\t\t\t\tif (key === foundKey) {\r\n\t\t\t\t\tbreak\r\n\t\t\t\t}\r\n\t\t\t} catch (e) {}\r\n\t\t}\r\n\r\n\t\treturn key ? jar[key] : jar\r\n\t}\r\n\r\n\treturn Object.create({\r\n\t\t\tset: set,\r\n\t\t\tget: get,\r\n\t\t\tremove: function (key, attributes) {\r\n\t\t\t\tset(\r\n\t\t\t\t\tkey,\r\n\t\t\t\t\t'',\r\n\t\t\t\t\tassign({}, attributes, {\r\n\t\t\t\t\t\texpires: -1\r\n\t\t\t\t\t})\r\n\t\t\t\t);\r\n\t\t\t},\r\n\t\t\twithAttributes: function (attributes) {\r\n\t\t\t\treturn init(this.converter, assign({}, this.attributes, attributes))\r\n\t\t\t},\r\n\t\t\twithConverter: function (converter) {\r\n\t\t\t\treturn init(assign({}, this.converter, converter), this.attributes)\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\tattributes: { value: Object.freeze(defaultAttributes) },\r\n\t\t\tconverter: { value: Object.freeze(converter) }\r\n\t\t}\r\n\t)\r\n}\r\n\r\nlet api = init(defaultConverter, { path: '/' });\r\n\r\nexport default api;","/**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap data.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n * Скрипт работает с коллекцией модулей. Подробнее тут https://learn.javascript.ru/map-set\r\n */\r\n\r\n/**\r\n * Константы\r\n */\r\n\r\nconst elementMap = new Map()\r\n\r\nexport default {\r\n\tset(element, key, instance) {\r\n\t\tif (!elementMap.has(element)) {\r\n\t\t\telementMap.set(element, new Map())\r\n\t\t}\r\n\r\n\t\tconst instanceMap = elementMap.get(element)\r\n\t\tif (!instanceMap.has(key) && instanceMap.size !== 0) {\r\n\t\t\tconsole.error(`VGApp не допускает более одного экземпляра для каждого элемента. Связанный экземпляр: ${Array.from(instanceMap.keys())[0]}.`)\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tinstanceMap.set(key, instance);\r\n\t},\r\n\r\n\tget(element, key) {\r\n\t\tif (elementMap.has(element)) {\r\n\t\t\treturn elementMap.get(element).get(key) || null\r\n\t\t}\r\n\r\n\t\treturn null\r\n\t},\r\n\r\n\tremove(element, key) {\r\n\t\tif (!elementMap.has(element)) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tconst instanceMap = elementMap.get(element)\r\n\r\n\t\tinstanceMap.delete(key);\r\n\r\n\t\tif (instanceMap.size === 0) {\r\n\t\t\telementMap.delete(element)\r\n\t\t}\r\n\t}\r\n}\r\n","/**\r\n * --------------------------------------------------------------------------\r\n * Bootstrap event.js\r\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\r\n * --------------------------------------------------------------------------\r\n * Скрипт для прослушивания события\r\n */\r\n\r\n/**\r\n * Константы\r\n */\r\n\r\nconst namespaceRegex = /[^.]*(?=\\..*)\\.|.*/\r\nconst stripNameRegex = /\\..*/\r\nconst stripUidRegex = /::\\d+$/\r\nconst eventRegistry = {} // Events storage\r\nlet uidEvent = 1\r\nconst customEvents = {\r\n\tmouseenter: 'mouseover',\r\n\tmouseleave: 'mouseout'\r\n}\r\n\r\nconst nativeEvents = new Set([\r\n\t'click',\r\n\t'dblclick',\r\n\t'mouseup',\r\n\t'mousedown',\r\n\t'contextmenu',\r\n\t'mousewheel',\r\n\t'DOMMouseScroll',\r\n\t'mouseover',\r\n\t'mouseout',\r\n\t'mousemove',\r\n\t'selectstart',\r\n\t'selectend',\r\n\t'submit',\r\n\t'keydown',\r\n\t'keypress',\r\n\t'keyup',\r\n\t'orientationchange',\r\n\t'touchstart',\r\n\t'touchmove',\r\n\t'touchend',\r\n\t'touchcancel',\r\n\t'pointerdown',\r\n\t'pointermove',\r\n\t'pointerup',\r\n\t'pointerleave',\r\n\t'pointercancel',\r\n\t'gesturestart',\r\n\t'gesturechange',\r\n\t'gestureend',\r\n\t'focus',\r\n\t'blur',\r\n\t'change',\r\n\t'reset',\r\n\t'select',\r\n\t'submit',\r\n\t'focusin',\r\n\t'focusout',\r\n\t'load',\r\n\t'unload',\r\n\t'beforeunload',\r\n\t'resize',\r\n\t'move',\r\n\t'DOMContentLoaded',\r\n\t'readystatechange',\r\n\t'error',\r\n\t'abort',\r\n\t'scroll'\r\n])\r\n\r\n/**\r\n * Приватные методы\r\n */\r\n\r\nfunction makeEventUid(element, uid) {\r\n\treturn (uid && `${uid}::${uidEvent++}`) || element.uidEvent || uidEvent++\r\n}\r\n\r\nfunction getElementEvents(element) {\r\n\tconst uid = makeEventUid(element)\r\n\r\n\telement.uidEvent = uid\r\n\teventRegistry[uid] = eventRegistry[uid] || {}\r\n\r\n\treturn eventRegistry[uid]\r\n}\r\n\r\nfunction bootstrapHandler(element, fn) {\r\n\treturn function handler(event) {\r\n\t\thydrateObj(event, { delegateTarget: element })\r\n\r\n\t\tif (handler.oneOff) {\r\n\t\t\tEventHandler.off(element, event.type, fn)\r\n\t\t}\r\n\r\n\t\treturn fn.apply(element, [event])\r\n\t}\r\n}\r\n\r\nfunction bootstrapDelegationHandler(element, selector, fn) {\r\n\treturn function handler(event) {\r\n\t\tconst domElements = element.querySelectorAll(selector)\r\n\r\n\t\tfor (let { target } = event; target && target !== this; target = target.parentNode) {\r\n\t\t\tfor (const domElement of domElements) {\r\n\t\t\t\tif (domElement !== target) {\r\n\t\t\t\t\tcontinue\r\n\t\t\t\t}\r\n\r\n\t\t\t\thydrateObj(event, { delegateTarget: target })\r\n\r\n\t\t\t\tif (handler.oneOff) {\r\n\t\t\t\t\tEventHandler.off(element, event.type, selector, fn)\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn fn.apply(target, [event])\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\nfunction findHandler(events, callable, delegationSelector = null) {\r\n\treturn Object.values(events)\r\n\t\t.find(event => event.callable === callable && event.delegationSelector === delegationSelector)\r\n}\r\n\r\nfunction normalizeParameters(originalTypeEvent, handler, delegationFunction) {\r\n\tconst isDelegated = typeof handler === 'string'\r\n\t// TODO: выдает \"false\" вместо селектора, поэтому нужно проверить. boot\r\n\tconst callable = isDelegated ? delegationFunction : (handler || delegationFunction)\r\n\tlet typeEvent = getTypeEvent(originalTypeEvent)\r\n\r\n\tif (!nativeEvents.has(typeEvent)) {\r\n\t\ttypeEvent = originalTypeEvent\r\n\t}\r\n\r\n\treturn [isDelegated, callable, typeEvent]\r\n}\r\n\r\nfunction addHandler(element, originalTypeEvent, handler, delegationFunction, oneOff) {\r\n\tif (typeof originalTypeEvent !== 'string' || !element) {\r\n\t\treturn\r\n\t}\r\n\r\n\tlet [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction)\r\n\r\n\t// in case of mouseenter or mouseleave wrap the handler within a function that checks for its DOM position\r\n\t// this prevents the handler from being dispatched the same way as mouseover or mouseout does\r\n\tif (originalTypeEvent in customEvents) {\r\n\t\tconst wrapFunction = fn => {\r\n\t\t\treturn function (event) {\r\n\t\t\t\tif (!event.relatedTarget || (event.relatedTarget !== event.delegateTarget && !event.delegateTarget.contains(event.relatedTarget))) {\r\n\t\t\t\t\treturn fn.call(this, event)\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tcallable = wrapFunction(callable)\r\n\t}\r\n\r\n\tconst events = getElementEvents(element)\r\n\tconst handlers = events[typeEvent] || (events[typeEvent] = {})\r\n\tconst previousFunction = findHandler(handlers, callable, isDelegated ? handler : null)\r\n\r\n\tif (previousFunction) {\r\n\t\tpreviousFunction.oneOff = previousFunction.oneOff && oneOff\r\n\r\n\t\treturn\r\n\t}\r\n\r\n\tconst uid = makeEventUid(callable, originalTypeEvent.replace(namespaceRegex, ''))\r\n\tconst fn = isDelegated ?\r\n\t\tbootstrapDelegationHandler(element, handler, callable) :\r\n\t\tbootstrapHandler(element, callable)\r\n\r\n\tfn.delegationSelector = isDelegated ? handler : null\r\n\tfn.callable = callable\r\n\tfn.oneOff = oneOff\r\n\tfn.uidEvent = uid\r\n\thandlers[uid] = fn\r\n\r\n\telement.addEventListener(typeEvent, fn, isDelegated)\r\n}\r\n\r\nfunction removeHandler(element, events, typeEvent, handler, delegationSelector) {\r\n\tconst fn = findHandler(events[typeEvent], handler, delegationSelector)\r\n\r\n\tif (!fn) {\r\n\t\treturn\r\n\t}\r\n\r\n\telement.removeEventListener(typeEvent, fn, Boolean(delegationSelector))\r\n\tdelete events[typeEvent][fn.uidEvent]\r\n}\r\n\r\nfunction removeNamespacedHandlers(element, events, typeEvent, namespace) {\r\n\tconst storeElementEvent = events[typeEvent] || {}\r\n\r\n\tfor (const [handlerKey, event] of Object.entries(storeElementEvent)) {\r\n\t\tif (handlerKey.includes(namespace)) {\r\n\t\t\tremoveHandler(element, events, typeEvent, event.callable, event.delegationSelector)\r\n\t\t}\r\n\t}\r\n}\r\n\r\nfunction getTypeEvent(event) {\r\n\t// allow to get the native events from namespaced events ('click.bs.button' --> 'click')\r\n\tevent = event.replace(stripNameRegex, '')\r\n\treturn customEvents[event] || event\r\n}\r\n\r\nfunction hydrateObj(obj, meta = {}) {\r\n\tfor (const [key, value] of Object.entries(meta)) {\r\n\t\ttry {\r\n\t\t\tobj[key] = value\r\n\t\t} catch {\r\n\t\t\tObject.defineProperty(obj, key, {\r\n\t\t\t\tconfigurable: true,\r\n\t\t\t\tget() {\r\n\t\t\t\t\treturn value\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t}\r\n\t}\r\n\r\n\treturn obj\r\n}\r\n\r\n/**\r\n * События\r\n * @type {{one(*, *, *, *): void, trigger(*, *, *): (null|*), off(*, *, *, *): void, on(*, *, *, *): void}}\r\n */\r\nconst EventHandler = {\r\n\t/**\r\n\t * Прослушиватель событий (элемент, событие (полный список смотри в константе nativeEvents, источник события или хендлер, функция обратного вызова))\r\n\t * @param element\r\n\t * @param event\r\n\t * @param handler\r\n\t * @param delegationFunction\r\n\t */\r\n\ton(element, event, handler, delegationFunction) {\r\n\t\taddHandler(element, event, handler, delegationFunction, false)\r\n\t},\r\n\r\n\t/**\r\n\t * Прослушиватель событий, но замыкается и больше не повторяется на элементе\r\n\t * @param element\r\n\t * @param event\r\n\t * @param handler\r\n\t * @param delegationFunction\r\n\t */\r\n\tone(element, event, handler, delegationFunction) {\r\n\t\taddHandler(element, event, handler, delegationFunction, true)\r\n\t},\r\n\r\n\t/**\r\n\t * Удаление обработчика\r\n\t * @param element\r\n\t * @param originalTypeEvent\r\n\t * @param handler\r\n\t * @param delegationFunction\r\n\t */\r\n\toff(element, originalTypeEvent, handler, delegationFunction) {\r\n\t\tif (typeof originalTypeEvent !== 'string' || !element) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tconst [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction)\r\n\t\tconst inNamespace = typeEvent !== originalTypeEvent\r\n\t\tconst events = getElementEvents(element)\r\n\t\tconst storeElementEvent = events[typeEvent] || {}\r\n\t\tconst isNamespace = originalTypeEvent.startsWith('.')\r\n\r\n\t\tif (typeof callable !== 'undefined') {\r\n\t\t\t// Simplest case: handler is passed, remove that listener ONLY.\r\n\t\t\tif (!Object.keys(storeElementEvent).length) {\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\r\n\t\t\tremoveHandler(element, events, typeEvent, callable, isDelegated ? handler : null)\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tif (isNamespace) {\r\n\t\t\tfor (const elementEvent of Object.keys(events)) {\r\n\t\t\t\tremoveNamespacedHandlers(element, events, elementEvent, originalTypeEvent.slice(1))\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tfor (const [keyHandlers, event] of Object.entries(storeElementEvent)) {\r\n\t\t\tconst handlerKey = keyHandlers.replace(stripUidRegex, '')\r\n\r\n\t\t\tif (!inNamespace || originalTypeEvent.includes(handlerKey)) {\r\n\t\t\t\tremoveHandler(element, events, typeEvent, event.callable, event.delegationSelector)\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n\r\n\t/**\r\n\t * Пользовательские события. Подробнее тут https://learn.javascript.ru/dispatch-events\r\n\t * @param element\r\n\t * @param event\r\n\t * @param args\r\n\t * @returns {*|null}\r\n\t */\r\n\ttrigger(element, event, args) {\r\n\t\tif (typeof event !== 'string' || !element) {\r\n\t\t\treturn null\r\n\t\t}\r\n\r\n\t\tlet bubbles = true;\r\n\t\tlet nativeDispatch = true;\r\n\t\tlet defaultPrevented = false;\r\n\r\n\t\tconst evt = hydrateObj(new Event(event, { bubbles, cancelable: true }), args)\r\n\r\n\t\tif (defaultPrevented) {\r\n\t\t\tevt.preventDefault()\r\n\t\t}\r\n\r\n\t\tif (nativeDispatch) {\r\n\t\t\telement.dispatchEvent(evt)\r\n\t\t}\r\n\r\n\t\treturn evt\r\n\t}\r\n}\r\n\r\nexport default EventHandler\r\n","import {isElement, normalizeData} from \"../functions\";\r\n\r\n/**\r\n * Манипуляции с атрибутами у элемента:\r\n * get (элемент, имя, флаг - вырезать data-) - метод выбирает значение атрибута по его имени, если в поле имени передать 'data' -> будут выбраны только дата атрибуты, если 'all' -> метод вернет значение всех атрибутов\r\n * has (элемент, имя) - есть ли атрибут у элемента\r\n * set (элемент, имя, значение) - установка у элемента атрибута или его изменение\r\n * remove (элемент, имя) - удаляет атрибут у элемента\r\n */\r\nconst Manipulator = {\r\n\tget(element, nameAttribute = 'data', isRemoveDataName = true) {\r\n\t\tif (!element) {\r\n\t\t\treturn {}\r\n\t\t}\r\n\r\n\t\tif (nameAttribute === 'data') {\r\n\t\t\tlet elmBase = ['data-vg-toggle', 'data-vg-target', 'data-vg-dismiss'],\r\n\t\t\t\tattributes = {};\r\n\r\n\t\t\tlet arr = [].filter.call(element.attributes, function (at) {\r\n\t\t\t\treturn /^data-/.test(at.name);\r\n\t\t\t});\r\n\r\n\t\t\tif (arr.length) {\r\n\t\t\t\tarr.forEach(function (v) {\r\n\t\t\t\t\tlet name = v.name;\r\n\r\n\t\t\t\t\tif (!elmBase.includes(name)) {\r\n\t\t\t\t\t\tif (isRemoveDataName) name = name.slice(5);\r\n\t\t\t\t\t\tattributes[name] = normalizeData(v.value)\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t}\r\n\r\n\t\t\treturn attributes;\r\n\t\t} else if (nameAttribute === 'all') {\r\n\t\t\treturn element.getAttributeNames().reduce((acc, name) => {\r\n\t\t\t\treturn {...acc, [name]: element.getAttribute(name)};\r\n\t\t\t}, {});\r\n\t\t} else {\r\n\t\t\treturn element.getAttribute(nameAttribute);\r\n\t\t}\r\n\t},\r\n\r\n\thas(element, nameAttribute) {\r\n\t\treturn element.hasAttribute(nameAttribute);\r\n\t},\r\n\r\n\tset(element, name, value) {\r\n\t\tif (isElement(element) && name) {\r\n\t\t\telement.setAttribute(name, value);\r\n\t\t}\r\n\t},\r\n\r\n\tremove(element, nameAttribute) {\r\n\t\tif (isElement(element) && nameAttribute) {\r\n\t\t\telement.removeAttribute(nameAttribute);\r\n\t\t}\r\n\t},\r\n\r\n\thide(el) {\r\n\t\tel.style.display = 'none';\r\n\t},\r\n\r\n\tshow(el, state = 'block') {\r\n\t\tel.style.display = state;\r\n\t},\r\n}\r\n\r\nexport {Manipulator}\r\n","/**\r\n * Работа с DOM\r\n * @param selector\r\n * @returns {*}\r\n */\r\nimport {isElement} from \"../functions\";\r\n\r\nconst parseSelector = selector => {\r\n\tif (selector && window.CSS && window.CSS.escape) {\r\n\t\tselector = selector.replace(/#([^\\s\"#']+)/g, (match, id) => `#${CSS.escape(id)}`)\r\n\t}\r\n\r\n\treturn selector\r\n}\r\n\r\nconst getSelector = element => {\r\n\tlet selector = element.getAttribute('data-vg-target');\r\n\r\n\tif (!selector || selector === '#') {\r\n\t\tlet hrefAttribute = element.getAttribute('href');\r\n\t\tif (!hrefAttribute || (!hrefAttribute.includes('#') && !hrefAttribute.startsWith('.'))) {\r\n\t\t\treturn null;\r\n\t\t}\r\n\r\n\t\tif (hrefAttribute.includes('#') && !hrefAttribute.startsWith('#')) {\r\n\t\t\threfAttribute = `#${hrefAttribute.split('#')[1]}`;\r\n\t\t}\r\n\r\n\t\tselector = hrefAttribute && hrefAttribute !== '#' ? hrefAttribute.trim() : null;\r\n\t}\r\n\r\n\treturn selector ? selector.split(',').map(sel => parseSelector(sel)).join(',') : null;\r\n}\r\n\r\nconst Selectors = {\r\n\tfind(selector, element = document.documentElement) {\r\n\t\tif (isElement(selector)) {\r\n\t\t\treturn selector;\r\n\t\t} else {\r\n\t\t\treturn Element.prototype.querySelector.call(element, selector);\r\n\t\t}\r\n\t},\r\n\r\n\tfindAll(selector, container = document.documentElement) {\r\n\t\treturn [].concat(...Element.prototype.querySelectorAll.call(container, selector));\r\n\t},\r\n\r\n\tgetSelectorFromElement(element) {\r\n\t\tconst selector = getSelector(element);\r\n\t\tif (selector) return Selectors.find(selector) ? selector : null\r\n\t\treturn null\r\n\t},\r\n\r\n\tgetElementFromSelector(element) {\r\n\t\tconst selector = getSelector(element);\r\n\t\treturn selector ? Selectors.find(selector) : null\r\n\t},\r\n\r\n\tgetMultipleElementsFromSelector(element) {\r\n\t\tconst selector = getSelector(element);\r\n\t\treturn selector ? Selectors.findAll(selector) : []\r\n\t}\r\n}\r\n\r\nexport default Selectors;","/**\r\n * Набор скриптов для широкого применения\r\n */\r\n\r\n/**\r\n * Если что-нибудь в объекте\r\n * @param obj\r\n * @returns {boolean}\r\n */\r\nfunction isEmptyObj(obj) {\r\n\tfor (let prop in obj) {\r\n\t\tif (Object.prototype.hasOwnProperty.call(obj, prop)) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\t}\r\n\r\n\treturn true\r\n}\r\n\r\n/**\r\n * isElement\r\n * @param object\r\n * @returns {boolean}\r\n */\r\nconst isElement = object => {\r\n\tif (!isObject(object)) {\r\n\t\treturn false\r\n\t}\r\n\r\n\treturn typeof object.nodeType !== 'undefined'\r\n}\r\n\r\n/**\r\n * isDisabled\r\n * @param element\r\n * @returns {boolean}\r\n */\r\nconst isDisabled = element => {\r\n\tif (!element || element.nodeType !== Node.ELEMENT_NODE) {\r\n\t\treturn true\r\n\t}\r\n\r\n\tif (element.classList.contains('disabled')) {\r\n\t\treturn true\r\n\t}\r\n\r\n\tif (typeof element.disabled !== 'undefined') {\r\n\t\treturn element.disabled\r\n\t}\r\n\r\n\treturn element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false'\r\n}\r\n\r\n/**\r\n * isVisible\r\n * @param element\r\n * @returns {boolean}\r\n */\r\nfunction isVisible (element) {\r\n\tif (!isElement(element) || element.getClientRects().length === 0) {\r\n\t\treturn false\r\n\t}\r\n\r\n\tconst elementIsVisible = getComputedStyle(element).getPropertyValue('visibility') === 'visible'\r\n\tconst closedDetails = element.closest('details:not([open])')\r\n\r\n\tif (!closedDetails) {\r\n\t\treturn elementIsVisible\r\n\t}\r\n\r\n\tif (closedDetails !== element) {\r\n\t\tconst summary = element.closest('summary')\r\n\t\tif (summary && summary.parentNode !== closedDetails) {\r\n\t\t\treturn false\r\n\t\t}\r\n\r\n\t\tif (summary === null) {\r\n\t\t\treturn false\r\n\t\t}\r\n\t}\r\n\r\n\treturn elementIsVisible\r\n}\r\n\r\n/**\r\n * isObject\r\n * @param obj\r\n * @returns {boolean}\r\n */\r\nfunction isObject(obj) {\r\n\treturn obj && typeof obj === 'object'\r\n}\r\n\r\n/**\r\n * Приводим в порядок типы данных\r\n * @param value\r\n * @returns {any}\r\n */\r\nfunction normalizeData(value)  {\r\n\tif (value === 'true') {\r\n\t\treturn true\r\n\t}\r\n\r\n\tif (value === 'false') {\r\n\t\treturn false\r\n\t}\r\n\r\n\tif (value === Number(value).toString()) {\r\n\t\treturn Number(value)\r\n\t}\r\n\r\n\tif (value === '' || value === 'null') {\r\n\t\treturn null\r\n\t}\r\n\r\n\tif (typeof value !== 'string') {\r\n\t\treturn value\r\n\t}\r\n\r\n\ttry {\r\n\t\treturn JSON.parse(decodeURIComponent(value))\r\n\t} catch {\r\n\t\treturn value\r\n\t}\r\n}\r\n\r\n/**\r\n * Удаляем элементы с массива\r\n * @param arr\r\n * @param el\r\n */\r\nfunction removeElementArray(arr, el) {\r\n\treturn arr.filter((item) => !el.includes(item));\r\n}\r\n\r\n/**\r\n * Глубокое объединение объектов\r\n * @param objects\r\n * @returns {*}\r\n */\r\nfunction mergeDeepObject(...objects) {\r\n\tconst isObject = obj => obj && typeof obj === 'object';\r\n\r\n\treturn objects.reduce((prev, obj) => {\r\n\t\tObject.keys(obj).forEach(key => {\r\n\t\t\tconst pVal = prev[key];\r\n\t\t\tconst oVal = obj[key];\r\n\r\n\t\t\tif (Array.isArray(pVal) && Array.isArray(oVal)) {\r\n\t\t\t\tprev[key] = pVal.concat(...oVal);\r\n\t\t\t}\r\n\t\t\telse if (isObject(pVal) && isObject(oVal)) {\r\n\t\t\t\tprev[key] = mergeDeepObject(pVal, oVal);\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\tprev[key] = oVal;\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\treturn prev;\r\n\t}, {});\r\n}\r\n\r\n/**\r\n * Callback\r\n * @param possibleCallback\r\n * @param args\r\n * @param defaultValue\r\n * @returns {*}\r\n */\r\nfunction execute(possibleCallback, args = [], defaultValue = possibleCallback) {\r\n\treturn typeof possibleCallback === 'function' ? possibleCallback(...args) : defaultValue\r\n}\r\n\r\n/**\r\n * Transition\r\n * @param callback\r\n * @param transitionElement\r\n * @param waitForTransition\r\n */\r\nconst TRANSITION_END = 'transitionend';\r\nconst MILLISECONDS_MULTIPLIER = 1000;\r\n\r\nfunction executeAfterTransition (callback, transitionElement, waitForTransition = true, timeOutMs) {\r\n\tif (!waitForTransition) {\r\n\t\texecute(callback)\r\n\t\treturn\r\n\t}\r\n\r\n\tconst durationPadding = 5\r\n\tconst emulatedDuration = timeOutMs ? timeOutMs : getTransitionDurationFromElement(transitionElement) + durationPadding;\r\n\r\n\tlet called = false\r\n\r\n\tconst handler = ({ target }) => {\r\n\t\tif (target !== transitionElement) {\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\tcalled = true\r\n\t\ttransitionElement.removeEventListener(TRANSITION_END, handler)\r\n\t\texecute(callback)\r\n\t}\r\n\r\n\ttransitionElement.addEventListener(TRANSITION_END, handler)\r\n\tsetTimeout(() => {\r\n\t\tif (!called) {\r\n\t\t\ttriggerTransitionEnd(transitionElement)\r\n\t\t}\r\n\t}, emulatedDuration)\r\n}\r\n\r\nconst getTransitionDurationFromElement = element => {\r\n\tif (!element) {\r\n\t\treturn 0\r\n\t}\r\n\r\n\t// Get transition-duration of the element\r\n\tlet { transitionDuration, transitionDelay } = window.getComputedStyle(element)\r\n\r\n\tconst floatTransitionDuration = Number.parseFloat(transitionDuration)\r\n\tconst floatTransitionDelay = Number.parseFloat(transitionDelay)\r\n\r\n\t// Return 0 if element or transition duration is not found\r\n\tif (!floatTransitionDuration && !floatTransitionDelay) {\r\n\t\treturn 0\r\n\t}\r\n\r\n\t// If multiple durations are defined, take the first\r\n\ttransitionDuration = transitionDuration.split(',')[0]\r\n\ttransitionDelay = transitionDelay.split(',')[0]\r\n\r\n\treturn (Number.parseFloat(transitionDuration) + Number.parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER\r\n}\r\n\r\nconst triggerTransitionEnd = element => {\r\n\telement.dispatchEvent(new Event(TRANSITION_END))\r\n}\r\n\r\n/**\r\n * Трюк для перезапуска анимации элемента\r\n *\r\n * @param {HTMLElement} element\r\n * @return void\r\n *\r\n * @смотри https://www.charistheo.io/blog/2021/02/restart-a-css-animation-with-javascript/#restarting-a-css-animation\r\n */\r\nconst reflow = element => {\r\n\telement.offsetHeight // eslint-disable-line no-unused-expressions\r\n}\r\n\r\n/**\r\n * Noop\r\n */\r\nconst noop = () => {};\r\n\r\n/**\r\n * Генерация случайной строки\r\n */\r\nfunction makeRandomString(length = 7) {\r\n\tlet result = '';\r\n\tconst characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\r\n\tconst charactersLength = characters.length;\r\n\tlet counter = 0;\r\n\twhile (counter < length) {\r\n\t\tresult += characters.charAt(Math.floor(Math.random() * charactersLength));\r\n\t\tcounter += 1;\r\n\t}\r\n\treturn result;\r\n}\r\n\r\n/**\r\n * Транслитерация символов с латиницы на кириллицу и обратно\r\n * @param text\r\n * @param enToRu\r\n * @returns {*}\r\n */\r\nfunction transliterate(text, enToRu) {\r\n\tlet ru = \"й ц у к е н г ш щ з х ъ ф ы в а п р о л д ж э я ч с м и т ь б ю\".split(/ +/g);\r\n\tlet en = \"q w e r t y u i o p [ ] a s d f g h j k l ; ' z x c v b n m , .\".split(/ +/g);\r\n\tlet x;\r\n\r\n\tfor (x = 0; x < ru.length; x++) {\r\n\t\ttext = text.split(enToRu ? en[x] : ru[x]).join(enToRu ? ru[x] : en[x]);\r\n\t\ttext = text.split(enToRu ? en[x].toUpperCase() : ru[x].toUpperCase()).join(enToRu ? ru[x].toUpperCase() : en[x].toUpperCase());\r\n\t}\r\n\r\n\treturn text;\r\n}\r\n\r\n/**\r\n *\r\n */\r\nconst isRTL = () => document.documentElement.dir === 'rtl'\r\n\r\nexport {isElement, isVisible, isDisabled, isObject, isEmptyObj, mergeDeepObject, removeElementArray, normalizeData, execute, executeAfterTransition, reflow, noop, makeRandomString, isRTL, transliterate}","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// extracted by mini-css-extract-plugin\nexport {};","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// css классы по умолчанию\r\nimport \"./app/utils/scss/default.scss\";\r\n\r\n// sidebar\r\nimport \"./app/modules/vgsidebar/scss/vgsidebar.scss\";\r\nimport VGSidebar from \"./app/modules/vgsidebar/js/vgsidebar\";\r\n\r\n// collapse\r\nimport VGCollapse from \"./app/modules/vgcollapse/js/vgcollapse\";\r\n\r\n// nav\r\nimport \"./app/modules/vgnav/scss/vgnav.scss\";\r\nimport VGNav from \"./app/modules/vgnav/js/vgnav\";\r\n\r\n// dropdown\r\nimport \"./app/modules/vgdropdown/scss/vgdropdown.scss\";\r\nimport VGDropdown from \"./app/modules/vgdropdown/js/vgdropdown\";\r\n\r\n// modal\r\nimport \"./app/modules/vgmodal/scss/vgmodal.scss\";\r\nimport VGModal from \"./app/modules/vgmodal/js/vgmodal\";\r\n\r\n// form sender\r\nimport \"./app/modules/vgformsender/scss/vgformsender.scss\";\r\nimport VGFormSender from \"./app/modules/vgformsender/js/vgformsender\";\r\n\r\n// rollup\r\nimport \"./app/modules/vgrollup/scss/vgrollup.scss\";\r\nimport VGRollup from \"./app/modules/vgrollup/js/vgrollup\";\r\n\r\n// law cookie\r\nimport \"./app/modules/vglawcookie/scss/vglawcookie.scss\";\r\nimport VGLawCookie from \"./app/modules/vglawcookie/js/vglawcookie\";\r\n\r\n// select\r\nimport \"./app/modules/vgselect/scss/vgselect.scss\";\r\nimport VGSelect from \"./app/modules/vgselect/js/vgselect\";\r\n\r\nexport {\r\n\tVGSidebar, VGCollapse, VGNav, VGDropdown, VGModal, VGFormSender, VGRollup, VGLawCookie, VGSelect\r\n}\r\n"],"names":[],"sourceRoot":""}
1
+ /*! For license information please see vgapp.js.LICENSE.txt */
2
+ var vg;(()=>{"use strict";var e={d:(t,s)=>{for(var a in s)e.o(s,a)&&!e.o(t,a)&&Object.defineProperty(t,a,{enumerable:!0,get:s[a]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r:e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}},t={};function s(e){for(let t in e)if(Object.prototype.hasOwnProperty.call(e,t))return!1;return!0}e.r(t),e.d(t,{VGCollapse:()=>be,VGDropdown:()=>Ze,VGFormSender:()=>Lt,VGLawCookie:()=>Ht,VGModal:()=>wt,VGNav:()=>Ne,VGRollup:()=>St,VGSelect:()=>ns,VGSidebar:()=>re});const a=e=>!!n(e)&&void 0!==e.nodeType,i=e=>!e||e.nodeType!==Node.ELEMENT_NODE||!!e.classList.contains("disabled")||(void 0!==e.disabled?e.disabled:e.hasAttribute("disabled")&&"false"!==e.getAttribute("disabled"));function n(e){return e&&"object"==typeof e}function r(e){if("true"===e)return!0;if("false"===e)return!1;if(e===Number(e).toString())return Number(e);if(""===e||"null"===e)return null;if("string"!=typeof e)return e;try{return JSON.parse(decodeURIComponent(e))}catch{return e}}function o(...e){const t=e=>e&&"object"==typeof e;return e.reduce(((e,s)=>(Object.keys(s).forEach((a=>{const i=e[a],n=s[a];Array.isArray(i)&&Array.isArray(n)?e[a]=i.concat(...n):t(i)&&t(n)?e[a]=o(i,n):e[a]=n})),e)),{})}function l(e,t=[],s=e){return"function"==typeof e?e(...t):s}const d="transitionend",c=e=>{e.offsetHeight},m=()=>{};function h(e=7){let t="";let s=0;for(;s<e;)t+="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789".charAt(Math.floor(62*Math.random())),s+=1;return t}const u=()=>"rtl"===document.documentElement.dir,g=e=>{let t=e.getAttribute("data-vg-target");if(!t||"#"===t){let s=e.getAttribute("href");if(!s||!s.includes("#")&&!s.startsWith("."))return null;s.includes("#")&&!s.startsWith("#")&&(s=`#${s.split("#")[1]}`),t=s&&"#"!==s?s.trim():null}return t?t.split(",").map((e=>(e=>(e&&window.CSS&&window.CSS.escape&&(e=e.replace(/#([^\s"#']+)/g,((e,t)=>`#${CSS.escape(t)}`))),e))(e))).join(","):null},p={find:(e,t=document.documentElement)=>a(e)?e:Element.prototype.querySelector.call(t,e),findAll:(e,t=document.documentElement)=>[].concat(...Element.prototype.querySelectorAll.call(t,e)),getSelectorFromElement(e){const t=g(e);return t&&p.find(t)?t:null},getElementFromSelector(e){const t=g(e);return t?p.find(t):null},getMultipleElementsFromSelector(e){const t=g(e);return t?p.findAll(t):[]}},_=p,f=new Map,v={set(e,t,s){f.has(e)||f.set(e,new Map);const a=f.get(e);a.has(t)||0===a.size?a.set(t,s):console.error(`VGApp не допускает более одного экземпляра для каждого элемента. Связанный экземпляр: ${Array.from(a.keys())[0]}.`)},get:(e,t)=>f.has(e)&&f.get(e).get(t)||null,remove(e,t){if(!f.has(e))return;const s=f.get(e);s.delete(t),0===s.size&&f.delete(e)}},b={get(e,t="data",s=!0){if(!e)return{};if("data"===t){let t=["data-vg-toggle","data-vg-target","data-vg-dismiss"],a={},i=[].filter.call(e.attributes,(function(e){return/^data-/.test(e.name)}));return i.length&&i.forEach((function(e){let i=e.name;t.includes(i)||(s&&(i=i.slice(5)),a[i]=r(e.value))})),a}return"all"===t?e.getAttributeNames().reduce(((t,s)=>({...t,[s]:e.getAttribute(s)})),{}):e.getAttribute(t)},has:(e,t)=>e.hasAttribute(t),set(e,t,s){a(e)&&t&&e.setAttribute(t,s)},remove(e,t){a(e)&&t&&e.removeAttribute(t)},hide(e){e.style.display="none"},show(e,t="block"){e.style.display=t}},w=class{constructor(e,t=null){this._params=this.merge(e,t)}get(){return this._params}fromElement(e){return a(e)?b.get(e):{}}merge(e,t){let s=o(e,this.fromElement(t));for(let e in s)if(-1!==e.indexOf("-")){let t=e.split("-"),a=r(s[e]);t[0]in s&&t[1]in s[t[0]]&&(s[t[0]][t[1]]=a),delete s[e]}return"params"in s&&(s=o(s,s.params),delete s.params),s}},y=/[^.]*(?=\..*)\.|.*/,k=/\..*/,x=/::\d+$/,L={};let E=1;const A={mouseenter:"mouseover",mouseleave:"mouseout"},C=new Set(["click","dblclick","mouseup","mousedown","contextmenu","mousewheel","DOMMouseScroll","mouseover","mouseout","mousemove","selectstart","selectend","submit","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"]);function S(e,t){return t&&`${t}::${E++}`||e.uidEvent||E++}function T(e){const t=S(e);return e.uidEvent=t,L[t]=L[t]||{},L[t]}function M(e,t,s=null){return Object.values(e).find((e=>e.callable===t&&e.delegationSelector===s))}function O(e,t,s){const a="string"==typeof t,i=a?s:t||s;let n=(r=(r=e).replace(k,""),A[r]||r);var r;return C.has(n)||(n=e),[a,i,n]}function $(e,t,s,a,i){if("string"!=typeof t||!e)return;let[n,r,o]=O(t,s,a);if(t in A){const e=e=>function(t){if(!t.relatedTarget||t.relatedTarget!==t.delegateTarget&&!t.delegateTarget.contains(t.relatedTarget))return e.call(this,t)};r=e(r)}const l=T(e),d=l[o]||(l[o]={}),c=M(d,r,n?s:null);if(c)return void(c.oneOff=c.oneOff&&i);const m=S(r,t.replace(y,"")),h=n?function(e,t,s){return function a(i){const n=e.querySelectorAll(t);for(let{target:r}=i;r&&r!==this;r=r.parentNode)for(const o of n)if(o===r)return N(i,{delegateTarget:r}),a.oneOff&&I.off(e,i.type,t,s),s.apply(r,[i])}}(e,s,r):function(e,t){return function s(a){return N(a,{delegateTarget:e}),s.oneOff&&I.off(e,a.type,t),t.apply(e,[a])}}(e,r);h.delegationSelector=n?s:null,h.callable=r,h.oneOff=i,h.uidEvent=m,d[m]=h,e.addEventListener(o,h,n)}function j(e,t,s,a,i){const n=M(t[s],a,i);n&&(e.removeEventListener(s,n,Boolean(i)),delete t[s][n.uidEvent])}function P(e,t,s,a){const i=t[s]||{};for(const[n,r]of Object.entries(i))n.includes(a)&&j(e,t,s,r.callable,r.delegationSelector)}function N(e,t={}){for(const[s,a]of Object.entries(t))try{e[s]=a}catch{Object.defineProperty(e,s,{configurable:!0,get:()=>a})}return e}const I={on(e,t,s,a){$(e,t,s,a,!1)},one(e,t,s,a){$(e,t,s,a,!0)},off(e,t,s,a){if("string"!=typeof t||!e)return;const[i,n,r]=O(t,s,a),o=r!==t,l=T(e),d=l[r]||{},c=t.startsWith(".");if(void 0===n){if(c)for(const s of Object.keys(l))P(e,l,s,t.slice(1));for(const[s,a]of Object.entries(d)){const i=s.replace(x,"");o&&!t.includes(i)||j(e,l,r,a.callable,a.delegationSelector)}}else{if(!Object.keys(d).length)return;j(e,l,r,n,i?s:null)}},trigger(e,t,s){if("string"!=typeof t||!e)return null;const a=N(new Event(t,{bubbles:!0,cancelable:!0}),s);return e.dispatchEvent(a),a}},q=I,D=e=>({error:'<svg viewBox="0 0 87 87" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="ui-success" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="Group-2" transform="translate(2.000000, 2.000000)"><circle id="Oval-2" stroke="rgba(252, 191, 191, .5)" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><circle class="ui-error-circle" stroke="#F74444" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><path class="ui-error-line1" d="M22.244224,22 L60.4279902,60.1837662" id="Line" stroke="#F74444" stroke-width="3" stroke-linecap="square"></path><path class="ui-error-line2" d="M60.755776,21 L23.244224,59.8443492" id="Line" stroke="#F74444" stroke-width="3" stroke-linecap="square"></path></g></g></svg>',success:'<svg viewBox="0 0 87 87" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="ui-error" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="Group-3" transform="translate(2.000000, 2.000000)"><circle id="Oval-2" stroke="rgba(117, 183, 152, 0.4)" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><circle class="ui-success-circle" id="Oval-2" stroke="#A5DC86" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><polyline class="ui-success-path" id="Path-2" stroke="#A5DC86" stroke-width="4" points="19 38.8036813 31.1020744 54.8046875 63.299221 28"></polyline></g></g></svg>',waiting:'<svg viewBox="0 0 87 87" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="ui-waiting" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="Group-3" transform="translate(2.000000, 2.000000)"><circle id="Oval-2" stroke="rgba(255, 218, 106, 0.4)" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><circle class="ui-waiting-circle" id="Oval-2" stroke="#ffda6a" stroke-width="4" cx="41.5" cy="41.5" r="41.5"></circle><path class="ui-waiting-line1" d="M43 63C54.598 63 64 53.598 64 42C64 30.402 54.598 21 43 21C31.402 21 22 30.402 22 42C22 53.598 31.402 63 43 63Z" stroke-width="3" stroke="#ffda6a" stroke-linecap="round" stroke-linejoin="round"/><path class="ui-waiting-line2" d="M40.6667 32.6641V44.3307H52.3334" stroke="#ffda6a" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"/></g></g></svg>',dots:'<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-three-dots-vertical" viewBox="0 0 16 16"><path d="M9.5 13a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0zm0-5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0z"/></svg>',cross:'<svg version="1.1" id="Capa_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 224.512 224.512" xml:space="preserve"><g><polygon points="224.507,6.997 217.521,0 112.256,105.258 6.998,0 0.005,6.997 105.263,112.254 0.005,217.512 6.998,224.512 112.256,119.24 217.521,224.512 224.507,217.512 119.249,112.254 "/></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g></svg>'}[e]??{}),H=(e,t="hide")=>{const s=`click.dismiss.${e.EVENT_KEY}`,a=e.NAME;q.on(document,s,`[data-vg-dismiss="${a}"]`,(function(s){if(["A","AREA"].includes(this.tagName)&&s.preventDefault(),i(this))return;const n=_.getSelectorFromElement(this)||this.closest(`.vg-${a}`);e.getOrCreateInstance(n)[t]()}))},B={x:function(){if("undefined"!=typeof XMLHttpRequest)return new XMLHttpRequest;let e,t=["MSXML2.XmlHttp.6.0","MSXML2.XmlHttp.5.0","MSXML2.XmlHttp.4.0","MSXML2.XmlHttp.3.0","MSXML2.XmlHttp.2.0","Microsoft.XmlHttp"];for(let s=0;s<t.length;s++)try{e=new ActiveXObject(t[s]);break}catch(e){}return e},send:function(e,t,s,a,i){void 0===i&&(i=!0);let n=B.x();n.open(s,e,i),n.setRequestHeader("X-Requested-With","XMLHttpRequest"),n.onreadystatechange=function(){4===n.readyState&&(200===n.status?t("success",{text:n.statusText,response:n.responseText,code:n.status}):t("error",{text:n.statusText,response:n.responseText,code:n.status}))},n.send(a)},get:function(e,t,a,i){let n=[];if(!s(t))for(let e of t)n.push(encodeURIComponent(e[0])+"="+encodeURIComponent(e[1]));B.send(e+(n.length?"?"+n.join("&"):""),a,"GET",null,i)},post:function(e,t,s,a){B.send(e,s,"POST",t,a)}},R=class{constructor(e,t,s={}){this._params=o({enable:!1,in:"animate__backInUp",out:"animate__backOutUp",delay:0},s),this.classes={animated:"animate__animated"},this._params.enable&&a(e)&&(this._element=e,this._name_key=t,this._element.classList.contains(this.classes.animated)||this._element.classList.add(this.classes.animated),this._triggers())}_triggers(){q.on(this._element,this._name_key+".show",(()=>{this._element.classList.remove(this._params.out),this._element.classList.add(this._params.in)})),q.on(this._element,this._name_key+".hide",(()=>{this._element.classList.remove(this._params.in),this._element.classList.add(this._params.out)})),q.on(this._element,this._name_key+".hidden",(()=>{this._element.classList.remove(this._params.out)}))}},F=class{constructor(e){if(e){if(this._element=_.find(e),!this._element)throw new Error("Товарищ! Первый параметр не должен быть пустым!");this._params={},v.set(this._element,this.constructor.NAME_KEY,this)}}_getParams(e,t){return new w(t,e).get()}dispose(){v.remove(this._element,this.constructor.NAME_KEY),q.off(this._element,this.constructor.EVENT_KEY);for(const e of Object.getOwnPropertyNames(this))this[e]=null}_route(e){const t=this;let s=null;const a=e=>{s&&(s.innerHTML=e)};t._params.hasOwnProperty("ajax")&&t._params.ajax.route&&(!1 in t._params.ajax&&(t._params.ajax.method="get"),"target"in t._params.ajax&&t._params.ajax.target&&(s=_.find(t._params.ajax.target)),"loader"in t._params.ajax&&t._params.ajax.loader&&a('<div class="vg-loader"></div>'),B[t._params.ajax.method](t._params.ajax.route,t._params.ajax.data||{},(function(t,s){a(s.response),l(e,[t,s])})))}_dismissElement(){let e=D("cross"),t=this._element.querySelector(".vg-btn-close");t&&(t.querySelector("svg")||t.insertAdjacentHTML("beforeend",e))}_queueCallback(e,t,s=!0,a){!function(e,t,s=!0,a){if(!s)return void l(e);const i=a||(e=>{if(!e)return 0;let{transitionDuration:t,transitionDelay:s}=window.getComputedStyle(e);const a=Number.parseFloat(t),i=Number.parseFloat(s);return a||i?(t=t.split(",")[0],s=s.split(",")[0],1e3*(Number.parseFloat(t)+Number.parseFloat(s))):0})(t)+5;let n=!1;const r=({target:s})=>{s===t&&(n=!0,t.removeEventListener(d,r),l(e))};t.addEventListener(d,r),setTimeout((()=>{n||(e=>{e.dispatchEvent(new Event(d))})(t)}),i)}(e,t,s,a)}_animation(e,t,s={}){new R(e,t,s)}static getInstance(e){return v.get(_.find(e),this.NAME_KEY)}static getOrCreateInstance(e,t={}){return this.getInstance(e)||new this(e,s(t)?{}:t)}static get DATA_KEY(){return`vg.${this.NAME}`}static get EVENT_KEY(){return`.${this.DATA_KEY}`}},X=class{static append(){document.body.style.paddingRight=function(){const e=document.documentElement.clientWidth;return Math.abs(window.innerWidth-e)}()+"px",document.body.style.overflow="hidden"}static destroy(){document.body.style.overflow="",document.body.style.paddingRight="",b.get(document.body,"style")||b.remove(document.body,"style")}},Y="vg-backdrop",z="fade";class K{static show(e){K._append(),l(e)}static hide(e){K._destroy(),l(e)}static _append(){if(_.find("."+Y))return!1;let e=document.createElement("div");e.classList.add(Y),document.body.append(e),setTimeout((()=>{e.classList.add(z)}),50),q.on(e,"mousedown.vg.backdrop",(()=>{K.hide(),X.destroy()}))}static _destroy(){let e=_.find("."+Y);e&&(e.classList.remove(z),setTimeout((()=>{e.remove()}),500))}}const V=K,W="vg.sidebar",U="show",G="vg-sidebar-open",J=`${W}.hide`,Z=`${W}.hidden`,Q=`${W}.show`,ee=`${W}.shown`,te=`${W}.loaded`,se=`keydown.dismiss.${W}`,ae=`hidePrevented.${W}`,ie=`click.${W}.data.api`;class ne extends F{constructor(e,t={}){super(e,t),this._params=this._getParams(e,o({backdrop:!0,overflow:!0,keyboard:!0,animation:{enable:!1,in:"animate__rollIn",out:"animate__rollOut",delay:800},ajax:{route:"",target:"",method:"get",loader:!1}},t)),this._addEventListeners(),this._dismissElement(),this._params.animation.delay=this._params.animation.enable?this._params.animation.delay:0,this._animation(this._element,ne.NAME_KEY,this._params.animation)}static get NAME(){return"sidebar"}static get NAME_KEY(){return W}toggle(e){return this._isShown()?this.hide():this.show(e)}show(e){const t=this;i(t._element)||(t._params=t._getParams(e,t._params),t._route((function(e,s){q.trigger(t._element,te,{stats:e,data:s})})),q.trigger(t._element,Q,{relatedTarget:e}).defaultPrevented||(t._params.backdrop&&V.show(),t._params.overflow&&X.append(),t._element.classList.add(U),document.body.classList.add(G),t._queueCallback((()=>{q.on(_.find(".vg-backdrop"),"mousedown.vg.backdrop",(function(){t.hide()})),q.trigger(t._element,ee,{relatedTarget:e})}),t._element,!0,50)))}hide(){const e=this;i(e._element)||q.trigger(this._element,J).defaultPrevented||setTimeout((()=>{e._element.setAttribute("aria-expanded",!1),e._element.classList.remove(U),this._queueCallback((()=>{e._params.backdrop&&V.hide((function(){e._params.overflow&&X.destroy()})),e._params.overflow&&X.destroy(),document.body.classList.remove(G),q.trigger(this._element,Z)}),this._element,!0)}),this._params.animation.delay)}dispose(){super.dispose()}_isShown(){return this._element.classList.contains(U)}_addEventListeners(){q.on(document,se,(e=>{"Escape"===e.key&&(this._params.keyboard?this.hide():q.trigger(this._element,ae))}))}}H(ne),q.on(document,ie,'[data-vg-toggle="sidebar"]',(function(e){const t=_.getElementFromSelector(this);if(["A","AREA"].includes(this.tagName)&&e.preventDefault(),i(this))return;this.setAttribute("aria-expanded",!0),q.one(t,Z,(()=>{this.setAttribute("aria-expanded",!1)}));const s=_.find(".vg-sidebar.show");s&&s!==t&&ne.getInstance(s).hide(),ne.getOrCreateInstance(t).toggle(this)}));const re=ne,oe="vg.collapse",le="show",de="vg-collapse",ce="vg-collapsing",me=`:scope .${de} .${de}`,he='[data-vg-toggle="collapse"]',ue=`${oe}.hide`,ge=`${oe}.hidden`,pe=`${oe}.show`,_e=`${oe}.shown`,fe=`click.${oe}.data.api`;class ve extends F{constructor(e,t={}){super(e,t),this._params=this._getParams(e,o({toggle:!0,parent:null,ajax:{route:"",target:"",method:"get",loader:!1}},t)),this._isTransitioning=!1,this._triggerArray=[];const s=_.findAll(he);for(const e of s){const t=_.getSelectorFromElement(e),s=_.findAll(t).filter((e=>e===this._element));null!==t&&s.length&&this._triggerArray.push(e)}this._initializeChildren(),this._params.parent||this._addAriaAndCollapsedClass(this._triggerArray,this._isShown()),this._params.toggle&&this.toggle()}static get NAME(){return"collapse"}static get NAME_KEY(){return oe}toggle(e){return this._isShown()?this.hide():this.show(e)}show(){const e=this;if(e._isTransitioning||e._isShown())return;let t=[];if(!(e._params.parent&&(t=this._getFirstLevelChildren(".collapse.show, .collapse.collapsing").filter((e=>e!==this._element)).map((e=>ve.getOrCreateInstance(e,{toggle:!1})))),t.length&&t[0]._isTransitioning||q.trigger(e._element,pe).defaultPrevented)){for(const e of t)e.hide();e._element.classList.remove(de),e._element.classList.add(ce),e._element.style.height=0,e._addAriaAndCollapsedClass(e._triggerArray,!0),e._isTransitioning=!0,e._route(),e._queueCallback((()=>{e._isTransitioning=!1,e._element.classList.remove(ce),e._element.classList.add(de,le),e._element.style.height="",q.trigger(e._element,_e)}),e._element,!0),e._element.style.height=`${e._element.scrollHeight}px`}}hide(){const e=this;if(!e._isTransitioning&&e._isShown()&&!q.trigger(e._element,ue).defaultPrevented){e._element.style.height=`${this._element.getBoundingClientRect().height}px`,c(e._element),e._element.classList.add(ce),e._element.classList.remove(de,le);for(const t of e._triggerArray){const s=_.getElementFromSelector(t);s&&!e._isShown(s)&&e._addAriaAndCollapsedClass([t],!1)}e._isTransitioning=!0,e._element.style.height="",e._queueCallback((()=>{e._isTransitioning=!1,e._element.classList.remove(ce),e._element.classList.add(de),q.trigger(e._element,ge)}),e._element,!0)}}dispose(){super.dispose()}_isShown(e=this._element){return e.classList.contains(le)}_addAriaAndCollapsedClass(e,t){if(e.length)for(const s of e)this._changeStateButton(s,t)}_initializeChildren(){if(!this._params.parent)return;const e=this._getFirstLevelChildren(he);for(const t of e){const e=_.getElementFromSelector(t);e&&this._addAriaAndCollapsedClass([t],this._isShown(e))}}_getFirstLevelChildren(e){const t=_.find(me,this._params.parent);return _.find(e,this._params.parent).filter((e=>!t.includes(e)))}_changeStateButton(e,t){e.classList.toggle("vg-collapsed",!t),e.setAttribute("aria-expanded",t),e.innerHTML=b.get(e,`data-${t?"hide":"show"}-text`)||e.innerHTML}}q.on(document,fe,he,(function(e){("A"===e.target.tagName||e.delegateTarget&&"A"===e.delegateTarget.tagName)&&e.preventDefault(),_.getMultipleElementsFromSelector(this).forEach((function(e){ve.getOrCreateInstance(e,{toggle:!1}).toggle()}))}));const be=ve,we=class{constructor(){this.breakpoints={xs:0,sm:576,md:768,lg:992,xl:1200,xxl:1400,xxxl:1600}}static check(e){return(new this).define(e)}static checkMobileOrTablet(){let e=!1;var t;return t=navigator.userAgent||navigator.vendor||window.opera,(/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(t)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(t.slice(0,4)))&&(e=!0),e}define(e){let t=window.innerWidth,s=this._checkResponsiveClass(e),a=this.breakpoints,i=Object.keys(a).find((e=>a[e]===s)),n=Object.keys(a),r=n.indexOf(i);return t>=a[n[r+1]]}_checkResponsiveClass(e){let t=e._element,s=e._params,a=0;return a=t.classList.contains(s.classes.XXXL)?this.breakpoints.xxxl:t.classList.contains(s.classes.XXL)?this.breakpoints.xxl:t.classList.contains(s.classes.XL)?this.breakpoints.xl:t.classList.contains(s.classes.LG)?this.breakpoints.lg:t.classList.contains(s.classes.MD)?this.breakpoints.md:t.classList.contains(s.classes.SM)?this.breakpoints.sm:(t.classList.contains(s.classes.XS),this.breakpoints.xs),a}},ye="vg.nav",ke="show",xe="fade",Le="active",Ee=`${ye}.hide`,Ae=`${ye}.hidden`,Ce=`${ye}.show`,Se=`${ye}.shown`,Te=`mouseover.${ye}.data.api`,Me=`mouseout.${ye}.data.api`,Oe=`click.${ye}.data.api`,$e=`keyup.${ye}.data.api`,je=`resize.${ye}.data.api`;class Pe extends F{constructor(e,t={}){super(e),this._params=this._getParams(e,o({breakpoint:!1,placement:"horizontal",classes:{hamburgerActive:"vg-nav-hamburger-active",hamburgerAlways:"vg-nav-hamburger-always",hamburger:"vg-nav-hamburger",container:"vg-nav-container",wrapper:"vg-nav-wrapper",active:"vg-nav-active",expand:"vg-nav-expand",cloned:"vg-nav-cloned",hover:"vg-nav-hover",flip:"vg-nav-flip",XXXL:"vg-nav-xxxl",XXL:"vg-nav-xxl",XL:"vg-nav-xl",LG:"vg-nav-lg",MD:"vg-nav-md",SM:"vg-nav-sm",XS:"vg-nav-xs"},expand:!0,hover:!1,position:!0,collapse:!0,toggle:'<span class="default"></span>',hamburger:{enable:!0,always:!1,title:"",body:null},callback:m,animation:!0,timeoutAnimation:300,ajax:{route:"",target:"",method:"get"}},t)),this._navigation=null,this.navigation="."+this._params.classes.wrapper,this.movedLinks=[],this.$links=_.findAll("."+this._params.classes.wrapper+" > li",this.navigation),!1===this._params.animation&&(this._params.timeoutAnimation=10)}static get NAME(){return"nav"}static get NAME_KEY(){return ye}get navigation(){return this._navigation}set navigation(e){let t=_.find(e,this._element);t&&(this._navigation=t)}build(){if(!this.navigation)return;let e=this._params;if(this._element.classList.add(e.classes.container),this._element.classList.add("vg-nav-"+e.placement),e.breakpoint||(e.expand=!1),e.hamburger.always?this._element.classList.add(e.classes.hamburgerAlways):e.breakpoint&&e.expand?!1!==e.breakpoint&&this._element.classList.add("vg-nav-"+e.breakpoint):this._element.classList.add(e.classes.expand),e.hover&&(this._element.classList.add(e.classes.hover),we.checkMobileOrTablet()&&this._element.classList.remove(e.classes.hover)),e.expand&&!e.hamburger.body&&null===_.find("."+e.classes.hamburger,this._element)){let t="",s='<span class="'+e.classes.hamburger+'--lines"><span></span><span></span><span></span></span>';e.hamburger.title&&(t='<span class="'+e.classes.hamburger+'--title">'+e.hamburger.title+"</span>"),null!==e.hamburger.body&&(s=e.hamburger.body),this._element.insertAdjacentHTML("afterbegin",'<a href="#sidebar-nav" class="'+e.classes.hamburger+'" data-vg-toggle="sidebar">'+t+s+"</a>")}if(e.toggle){let t=[..._.findAll(".dropdown-mega > a, .dropdown > a",this._element)],s='<span class="toggle">'+e.toggle+"</span>";t.length&&t.forEach((function(e){e.querySelector(".toggle")||e.closest(".dots")||(e.setAttribute("aria-expanded","false"),e.insertAdjacentHTML("beforeend",s))}))}e.collapse&&we.check(this)&&"vertical"!==e.placement&&function(e){let t=e.navigation.clientWidth,s=0,a=_.find(".dots",e.navigation),i=D("dots");if(e.$links.length){if(a)s=a.clientWidth;else{let t=_.find("a",e.$links[0]),a=getComputedStyle(t);s=r(a.paddingLeft.slice(0,-2))+r(a.paddingRight.slice(0,-2))+16}for(let i of e.$links)s+=i.getBoundingClientRect().width,t<s?(e.movedLinks.push(i),i.remove()):e.movedLinks.length&&(a?e.navigation.insertBefore(e.movedLinks[0],a):e.navigation.appendChild(e.movedLinks[0]),e.movedLinks.splice(0,1));e.movedLinks.length?a||e.navigation.insertAdjacentHTML("beforeend",'<li class="dropdown dots"><a href="#" aria-expanded="false">'+i+"</a></li>"):a&&a.remove();let n=e.navigation.querySelector(".dots");if(n&&e.movedLinks.length){let t=n.querySelector("ul");if(t)for(let s of e.movedLinks)t.prepend(s);else{let t=document.createElement("ul");t.classList.add("dropdown-content"),t.classList.add("right");for(let s of e.movedLinks)t.prepend(s);n.appendChild(t)}}}}(this),"afterInit"in this._params.callback&&l(this._params.callback.afterInit,[this])}show(e){let t=e.relatedTarget;if(!t||i(t))return;if(t.closest(".dropdown-content")||t.classList.add("first"),q.trigger(t,Ce,{relatedTarget:e}).defaultPrevented)return;let s=_.find(".dropdown-content",t),a=t.firstElementChild;a&&a.setAttribute("aria-expanded","true"),s.classList.add(ke),t.classList.add(Le),function(e){let{width:t,right:s}=e.getBoundingClientRect(),a=window.innerWidth-s-t;e.classList.remove("right"),e.classList.remove("left");let i=e.closest("li").querySelectorAll("ul");if(a>t)for(const e of i)e.classList.add("left");else for(const e of i)e.classList.add("right")}(s),this._queueCallback((()=>{s.classList.add(xe),q.trigger(t,Se,e)}),s,!0,50)}hide(e){const t=this;if("ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))q.off(e,"mouseover",m);let s=e.relatedTarget;if("elm"in e&&e.elm&&(s=e.elm),s){if(q.trigger(s,Ee).defaultPrevented)return;s.classList.remove(Le),s.classList.contains("first")&&s.classList.remove("first"),[..._.findAll("."+ke,s)].forEach((function(s,a){s.classList.remove(xe);let i=s.closest(".dropdown");i.classList.contains(Le)&&i.classList.remove(Le);let n=s.previousElementSibling;if(n&&n.setAttribute("aria-expanded","false"),0===a){const a=()=>{s.classList.remove(ke),q.trigger(s,Ae,e)};t._queueCallback(a,s,!0,500)}}))}}static init(e,t={}){const s=Pe.getOrCreateInstance(e,t);s.build();let n=_.findAll(".dropdown",s._navigation);s._params.hover?[...n].forEach((function(e){let t=null;q.on(e,Te,(function(e){if(t)return;Pe.hideOpenDrops(e);let a=e.target.closest(".dropdown");if(!a)return;if(!s.navigation.contains(a))return;t=a;let i={relatedTarget:a};s.show(i)})),q.on(e,Me,(function(e){if(!t)return;let a=e.relatedTarget.closest(".dropdown"),i=t;for(;a;){if(a===t)return;a=a.parentNode}t=null,s.hide({relatedTarget:a,elm:i})}))})):(q.on(document,$e,Pe.clearDrops),q.on(document,Oe,Pe.clearDrops),q.on(document,Oe,".vg-nav a",(function(e){if(!b.has(this,"aria-expanded"))return;"click"in s._params.callback&&l(s._params.callback.click,[this]),e.preventDefault();let t=this.closest(".vg-nav"),n=t.querySelector(".first"),r=this.closest(".dropdown");if(r&&(!i(r)||function(e){if(!a(e)||0===e.getClientRects().length)return!1;const t="visible"===getComputedStyle(e).getPropertyValue("visibility"),s=e.closest("details:not([open])");if(!s)return t;if(s!==e){const t=e.closest("summary");if(t&&t.parentNode!==s)return!1;if(null===t)return!1}return t}(r))){if(n&&this.closest(".first")){if(r.classList.contains("active"))return void s.hide({relatedTarget:r})}else[..._.findAll(".active",t)].forEach((function(e){e&&e!==r&&s.hide({relatedTarget:e})}));s.show({relatedTarget:r})}})));const r=document.getElementById("sidebar-nav");let o=s._element.querySelector("."+s._params.classes.hamburger);r&&o&&(r.addEventListener("vg.sidebar.show",(function(){o.classList.add(s._params.classes.hamburgerActive)})),r.addEventListener("vg.sidebar.hide",(function(){o.classList.remove(s._params.classes.hamburgerActive)})))}static clearDrops(e){2===e.button||"keyup"===e.type&&"Tab"!==e.key||Pe.hideOpenDrops(e)}static hideOpenDrops(e){const t=_.findAll(".dropdown:not(.disabled):not(:disabled).active");for(const s of t){const t=Pe.getInstance(s.closest(".vg-nav"));if(!t)continue;if(e.target.closest(".first"))return;const a={relatedTarget:s};"click"===e.type&&(a.clickEvent=e),t.hide(a)}}}q.on(window,je,(function(e){Pe.getOrCreateInstance(".vg-nav",{}).build()}));const Ne=Pe,Ie=class{constructor(e={}){this.params=o({element:null,drop:null},e)}_getPlacement(){const e=this,t=e=>{let s=e.parentNode,a=getComputedStyle(s).overflow;return"BODY"===s.tagName?null:"visible"!==a?s:void t(s)};let s,a,i=!1,n=e.params.drop.getBoundingClientRect(),o=e.params.element.getBoundingClientRect();if(t(e.params.element))i=!0,s=n.top,a=n.left;else{let t=getComputedStyle(e.params.drop);s=r(t.top.slice(0,-2)),a=r(t.left.slice(0,-2))}return n.left+n.width>window.innerWidth&&(a=o.width-n.width),{isFixed:i,top:s,left:a}}},qe="vg.dropdown",De="show",He="fade",Be="vg-dropdown-content",Re='[data-vg-toggle="dropdown"]',Fe=`${qe}.hide`,Xe=`${qe}.hidden`,Ye=`${qe}.show`,ze=`${qe}.shown`,Ke=`keyup.${qe}.data.api`,Ve=`keydown.${qe}.data.api`,We=`click.${qe}.data.api`,Ue=`mouseover.${qe}.data.api`,Ge=`mouseout.${qe}.data.api`;class Je extends F{constructor(e,t){super(e,t);let s={offset:[0,2],over:!1,backdrop:!0,overflow:!0,keyboard:!0,placement:"bottom",timeoutAnimation:350,hover:!1,ajax:{route:"",target:"",method:"get"},animation:{enable:!1,in:"animate__flipInY",out:"animate__flipOutY",delay:800}};"offset"in t&&Array.isArray(t.offset)&&(s.offset=t.offset),this._params=this._getParams(e,o(s,t)),this._parent=this._element.parentNode,this._drop=_.find("."+Be,this._parent),this._isPlacement=!1,this._params.animation.delay=this._params.animation.enable?this._params.animation.delay:0,this._animation(this._drop,Je.NAME_KEY,this._params.animation)}static get NAME(){return"dropdown"}static get NAME_KEY(){return qe}toggle(){return this._isShown()?this.hide():this.show()}show(){if(i(this._element)||this._isShown())return;const e={relatedTarget:this._element};if(!q.trigger(this._element,Ye,e).defaultPrevented){if("ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))q.on(e,"mouseover",m);this._route(),this._element.setAttribute("aria-expanded",!0),this._element.classList.add(De),this._drop.classList.add(De),this._setPlacement(),this._queueCallback((()=>{this._drop.classList.add(He),q.trigger(this._element,ze,e)}),this._drop,!0,50)}}hide(){if(i(this._element)||!this._isShown())return;const e={relatedTarget:this._element};this._completeHide(e)}dispose(){return super.dispose()}_isShown(){return this._element.classList.contains(De)}_completeHide(e){if(!q.trigger(this._element,Fe,e).defaultPrevented){if("ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))q.off(e,"mouseover",m);this._drop.classList.remove(He),this._element.classList.remove(De),this._element.setAttribute("aria-expanded","false"),setTimeout((()=>{this._queueCallback((()=>{this._drop.classList.remove(De),q.trigger(this._element,Xe,e)}),this._parent,!0,10)}),this._params.animation.delay)}}_setPlacement(){const e=this;if(!e._isPlacement){let t=new Ie({element:this._parent,drop:this._drop})._getPlacement();t.isFixed&&(e._drop.style.position="fixed",e._drop.style.transform="translateY(-20%)"),e._drop.style.left=t.left+"px",e._drop.style.top=t.top+"px"}e._params.offset&&(e._drop.style.paddingTop=e._params.offset[1]+"px",e._drop.style.paddingRight=e._params.offset[0]+"px"),e._isPlacement=!0}static init(e,t={}){const s=Je.getOrCreateInstance(e,t);if(s._params.hover){let e=null;q.on(s._parent,Ue,(function(t){if(e)return;Je.hideOpenToggles(t);let a=t.target.closest(".vg-dropdown");a&&s._parent.contains(a)&&(e=a,s.show())})),q.on(s._parent,Ge,(function(t){if(!e)return;let a=t.relatedTarget;for(;a;){if(a===e)return;a=a.parentNode}e=null,s._completeHide({relatedTarget:s._element})}))}else q.on(document,Ke,Re,Je.keydownHandler),q.on(document,Ve,"."+Be,Je.keydownHandler),q.on(document,Ke,Je.clearDrops),q.on(document,We,Je.clearDrops),q.on(e,We,(function(e){e.preventDefault(),s.toggle()}))}static hideOpenToggles(e){const t=_.findAll('[data-vg-toggle="dropdown"]:not(.disabled):not(:disabled).show');for(const s of t){const t=Je.getInstance(s);if(!t)continue;if(e.target.closest("."+Be)===t._drop)return;if(e.composedPath().includes(t._element))continue;const a={relatedTarget:t._element};"click"===e.type&&(a.clickEvent=e),t._completeHide(a)}}static keydownHandler(e){const t=/input|textarea/i.test(e.target.tagName),s="Escape"===e.key,a=["ArrowUp","ArrowDown"].includes(e.key);if(!a&&!s)return;if(t&&!s)return;e.preventDefault();const i=this.matches(Re)?this:_.find(Re,e.delegateTarget.parentNode),n=Je.getOrCreateInstance(i);if(a)return e.stopPropagation(),void n.show();n._isShown()&&(e.stopPropagation(),n.hide(),i.focus())}static clearDrops(e){2===e.button||"keyup"===e.type&&"Tab"!==e.key||Je.hideOpenToggles(e)}}const Ze=Je,Qe=".fixed-top, .fixed-bottom, .is-fixed, .sticky-top",et=".sticky-top",tt="padding-right",st="margin-right",at=class{constructor(){this._element=document.body}getWidth(){const e=document.documentElement.clientWidth;return Math.abs(window.innerWidth-e)}hide(){const e=this.getWidth();this._disableOverFlow(),this._setElementAttributes(this._element,tt,(t=>t+e)),this._setElementAttributes(Qe,tt,(t=>t+e)),this._setElementAttributes(et,st,(t=>t-e))}reset(){this._resetElementAttributes(this._element,"overflow"),this._resetElementAttributes(this._element,tt),this._resetElementAttributes(Qe,tt),this._resetElementAttributes(et,st)}isOverflowing(){return this.getWidth()>0}_disableOverFlow(){this._saveInitialAttribute(this._element,"overflow"),this._element.style.overflow="hidden"}_setElementAttributes(e,t,s){const a=this.getWidth();this._applyManipulationCallback(e,(e=>{if(e!==this._element&&window.innerWidth>e.clientWidth+a)return;this._saveInitialAttribute(e,t);const i=window.getComputedStyle(e).getPropertyValue(t);e.style.setProperty(t,`${s(Number.parseFloat(i))}px`)}))}_saveInitialAttribute(e,t){const s=e.style.getPropertyValue(t);s&&b.get(e,t,s)}_resetElementAttributes(e,t){this._applyManipulationCallback(e,(e=>{const s=b.get(e,t);null!==s?(b.remove(e,t),e.style.setProperty(t,s)):e.style.removeProperty(t)}))}_applyManipulationCallback(e,t){if(a(e))t(e);else for(const s of _.findAll(e,this._element))t(s)}},it="vg.modal",nt="vg-modal-open",rt="show",ot="vg-modal-static",lt=`${it}.hide`,dt=`${it}.hidden`,ct=`${it}.show`,mt=`${it}.shown`,ht=`${it}.resize`,ut=`${it}.loaded`,gt=`keydown.dismiss.${it}`,pt=`hidePrevented.${it}`,_t=`click.${it}.data.api`,ft=`mousedown.dismiss${it}`,vt=`click.dismiss${it}`;class bt extends F{constructor(e,t={}){super(e,t),this._params=this._getParams(e,o({backdrop:!0,focus:!0,keyboard:!0,fields:[],ajax:{route:"",target:"",method:"get",loader:!1},animation:{enable:!1,in:"animate__rollIn",out:"animate__rollOut",delay:800},classes:{general:"vg-modal",dialog:"vg-modal-dialog",content:"vg-modal-content",header:"vg-modal-header",title:"vg-modal-title",body:"vg-modal-body",footer:"vg-modal-footer"}},t)),this._button=null,this._dialog=_.find(".vg-modal-dialog",this._element),this._isShown=!1,this._isTransitioning=!1,this._scrollBar=new at,this._addEventListeners(),this._dismissElement(),this._params.animation.delay=this._params.animation.enable?this._params.animation.delay:0,this._animation(this._element,bt.NAME_KEY,this._params.animation)}static get NAME(){return"modal"}static get NAME_KEY(){return it}static init(e,t,s){bt.build(e,t,s)}static build(e,t,s){if("string"!=typeof e)return;let a=document.createElement("div");a.classList.add("vg-modal","fade"),a.id=e;let i=document.createElement("div");i.classList.add("vg-modal-dialog");let n=document.createElement("div");n.classList.add("vg-modal-content");let r=document.createElement("button");b.set(r,"type","button"),b.set(r,"data-vg-dismiss","modal"),b.set(r,"data-vg-target","#"+e),b.set(r,"aria-label","close"),r.classList.add("vg-btn-close"),n.append(r);let o=document.createElement("div");o.classList.add("vg-modal-body"),n.append(o),i.append(n),a.append(i),document.body.append(a),l(s,[bt.getOrCreateInstance(a,t)])}toggle(e){return this._isShown?this.hide():this.show(e)}show(e){const t=this;i(t._element)||(this._params=this._getParams(e,this._params),t._route((function(e,s){q.trigger(t._element,ut,{stats:e,data:s})})),q.trigger(this._element,ct,{relatedTarget:e}).defaultPrevented||(this._isShown=!0,this._isTransitioning=!0,this._scrollBar.hide(),document.body.classList.add(nt),this._addFieldsInModal(e),this._adjustDialog(),V.show((()=>this._showElement(e)))))}hide(){this._isShown&&!this._isTransitioning&&(q.trigger(this._element,lt).defaultPrevented||(this._isShown=!1,this._isTransitioning=!0,setTimeout((()=>{this._element.classList.remove(rt),this._queueCallback((()=>this._hideModal()),this._element,this._isAnimatedFade())}),this._params.animation.delay)))}_hideModal(){this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._isTransitioning=!1,V.hide((()=>{document.body.classList.remove(nt),this._resetAdjustments(),this._scrollBar.reset(),q.trigger(this._element,dt)}))}_showElement(e){document.body.contains(this._element)||document.body.append(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.scrollTop=0;const t=_.find(".vg-modal-body",this._dialog);t&&(t.scrollTop=0),c(this._element),this._element.classList.add(rt),this._queueCallback((()=>{this._isTransitioning=!1,q.trigger(this._element,mt,{relatedTarget:e})}),this._dialog,this._isAnimatedFade())}_isAnimatedFade(){return this._element.classList.contains("fade")}_adjustDialog(){const e=this._element.scrollHeight>document.documentElement.clientHeight,t=this._scrollBar.getWidth(),s=t>0;if(s&&!e){const e=u()?"paddingLeft":"paddingRight";this._element.style[e]=`${t}px`}if(!s&&e){const e=u()?"paddingRight":"paddingLeft";this._element.style[e]=`${t}px`}}_resetAdjustments(){this._element.style.paddingLeft="",this._element.style.paddingRight=""}_addEventListeners(){q.on(this._element,gt,(e=>{"Escape"===e.key&&(this._params.keyboard?this.hide():this._triggerBackdropTransition())})),q.on(window,ht,(()=>{this._isShown&&!this._isTransitioning&&this._adjustDialog()})),q.on(this._element,ft,(e=>{q.one(this._element,vt,(t=>{this._element===e.target&&this._element===t.target&&("static"!==this._params.backdrop?this._params.backdrop&&this.hide():this._triggerBackdropTransition())}))}))}_triggerBackdropTransition(){if(q.trigger(this._element,pt).defaultPrevented)return;const e=this._element.scrollHeight>document.documentElement.clientHeight,t=this._element.style.overflowY;"hidden"===t||this._element.classList.contains(ot)||(e||(this._element.style.overflowY="hidden"),this._element.classList.add(ot),this._queueCallback((()=>{this._element.classList.remove(ot),this._queueCallback((()=>{this._element.style.overflowY=t}),this._dialog)}),this._dialog))}_addFieldsInModal(e){this._params=this._getParams(e,this._params),this._params.fields.length&&this._params.fields.forEach((function(e){if(!1 in e&&!1 in e)return;let t=_.findAll("[data-"+e.name+"]");if(t.length)for(const s of t)switch(s.tagName){case"INPUT":s.value=e.value;break;case"IMG":b.set(s,"src",e.value);break;default:s.innerHTML=e.value}}))}}H(bt),q.on(document,_t,'[data-vg-toggle="modal"]',(function(e){const t=_.getElementFromSelector(this);["A","AREA"].includes(this.tagName)&&e.preventDefault(),q.one(t,ct,(e=>{e.defaultPrevented}));const s=_.find(".vg-modal.show");s&&bt.getInstance(s).hide(),bt.getOrCreateInstance(t).toggle(this)}));const wt=bt,yt="vg.fs",kt=`submit.${yt}.data.api`;class xt extends F{constructor(e,t={}){super(e,t),this._params=this._getParams(e,o({redirect:"",validate:!1,submit:!1,fields:[],alert:{enabled:!0,type:"modal"},ajax:{route:"",target:"",method:"get"},classes:{general:"vg-form-sender",alertCollapse:"vg-form-sender-collapse",alertModal:"vg-form-sender-modal",validation:"needs-validation",wasValidate:"was-validated"}},t)),this._params.ajax.route=b.get(this._element,"action").toLowerCase(),this._params.ajax.method=b.get(this._element,"method").toLowerCase(),this._button=_.find('[type="submit"]',this._element)||_.find('[form="'+this._element.id+'"]')||null,this._params.isBtnText="false"!==b.get(this._element,"data-btn-text"),this._params.isJsonParse="false"!==b.get(this._element,"data-json-parse"),this._params.isShowPass="true"===b.get(this._element,"data-show-pass")}static get NAME(){return"form-sender"}static get NAME_KEY(){return yt}build(){return this._element.classList.add(this._params.classes.general),this._params.validate&&(b.set(this._element,"novalidate",""),this._element.classList.add(this._params.classes.validation)),this}request(e,t){const s=this;s._alertBefore(),s._params.ajax.data=e,s._route((function(e,a){s._element.classList.remove("was-validated"),s._params.alert.enabled&&("string"==typeof e&&"error"===e?s._alertError(t,a):"string"==typeof e&&"success"===e&&s._alertSuccess(t,a)),s._params.redirect&&(window.location.href=s._params.redirect)}))}_alertBefore(){const e=this;"collapse"===e._params.alert.type&&[...document.getElementsByClassName(e._params.classes.alertCollapse)].forEach((function(e){e&&e.classList.contains("show")&&be.getOrCreateInstance(e,{toggle:!1}).hide()})),e._statusButton("before"),q.trigger(e._element,"vg.fs.before",e)}_alertError(e,t){const s=this;s._statusButton("after"),s._jsonParse(t,"error"),q.trigger(s._element,"vg.fs.error",[e,s,t])}_alertSuccess(e,t){const s=this;s._statusButton("after"),s._jsonParse(t,"success"),q.trigger(s._element,"vg.fs.success",[e,s,t])}_statusButton(e){const t=this;if(!t._button)return;let s=t._button,a={send:"Отправляем...",text:"Отправить"};if(b.has(t._button,"data-spinner")&&"before"===e&&t._button.insertAdjacentHTML("afterbegin",'<span class="spinner-border spinner-border-sm me-2"></span>'),b.has(t._button,"data-text"))a.text=b.get(t._button,"data-text");else{let e=t._button.querySelector("[data-text]");e&&(a.text=b.get(e,"data-text"),s=e)}if(b.has(t._button,"data-text-send"))a.send=b.get(t._button,"data-text-send");else{let e=t._button.querySelector("[data-text-send]");e&&(a.send=b.get(e,"data-text-send"),s=e)}if("before"===e&&(t._params.isBtnText&&(s.innerHTML=a.send),b.set(t._button,"disabled","disabled")),"after"===e){t._params.isBtnText&&(s.innerHTML=a.text),b.remove(t._button,"disabled");let e=t._button.querySelector(".spinner-border");e&&e.remove()}}_jsonParse(e,t){const s=this;if(s._params.isJsonParse&&"string"==typeof e){let a={};try{a=JSON.parse(e),s.alert(a,t)}catch(a){s.alert(e,t)}}else s.alert(e,t)}alert(e,t){const s=this;if(n(e)&&"code"in e&&e.code&&200===e.code&&"response"in e&&e.response){let s=r(e.response);"string"==typeof s?-1===s.indexOf("Parse error")&&-1===s.indexOf("syntax error")||(t="error",e={response:{title:"Error",message:"Something went wrong, please repeat later"},text:"Something went wrong, please repeat later"}):"errors"in s&&r(s.errors)&&(t=r(s.errors)?"error":"success")}s._params.alert.enabled&&("modal"===s._params.alert.type&&s._alertModal(e,t),"collapse"===s._params.alert.type&&s._alertCollapse(e,t))}_alertModal(e,t){const s=this;[...document.getElementsByClassName("modal")].forEach((function(e){e&&e.classList.contains("show")&&bootstrap.Modal.getOrCreateInstance(e).hide()})),[...document.getElementsByClassName("vg-modal")].forEach((function(e){e&&e.classList.contains("show")&&wt.getOrCreateInstance(e).hide()}));let a=s._params.classes.general+"-"+h(),i=_.find("."+s._params.classes.alertModal);i&&i.remove(),setTimeout((()=>{wt.init(a,{classes:{alert:s._params.classes.alertModal}},(function(a){let i=a._element;i.classList.add(s._params.classes.alertModal);let n=_.find(".vg-modal-body",i);n&&n.append(s.setDataRelationStatus(i,t,e,"modal")),a.toggle()}))}),800)}_alertCollapse(e,t){const s=this;let a=_.find("."+s._params.classes.alertCollapse);a||(a=document.createElement("div"),a.classList.add(s._params.classes.alertCollapse),a.classList.add("vg-collapse"),a.id=s._params.classes.general+"-"+h(),a.append(s.setDataRelationStatus(a,t,e,"collapse")),s._element.prepend(a)),be.getOrCreateInstance(a,{toggle:!1}).toggle()}setDataRelationStatus(e,t,s,a){let i=_.find(".vg-alert-"+t,e);if(n(s)){if("error"===t&&"code"in s&&200!==s.code&&"text"in s&&!s.text)switch(s.text="Something went wrong, please repeat later",s.code){case 400:s.text="Bad Request";break;case 401:case 403:s.text="Unauthorized";break;case 413:s.text="Forbidden";break;case 404:s.text="Not Found";break;case 422:s.text="Unprocessable Entity";break;case 500:s.text="Internal Server Error";break;case 504:s.text="Gateway Timeout"}if("response"in s){let e=r(s.response),a="",i="",o="";if("string"!=typeof e){if(!("view"in e)){if("title"in e&&(a=e.title),"error"===t&&200!==s.code&&(o=" "+s.text+" ("+s.code+")"),i+='<h4 class="vg-alert-content--title">'+a+o+"</h4>","message"in e&&(i+='<div class="vg-alert-content--message">'+e.message+"</div>"),"errors"in e){let t=r(e.errors)||null;if(n(t))for(const e in t)Array.isArray(t[e])?t[e].forEach((function(e){i+="<div>"+e+"</div>"})):i="<div>"+t[e]+"</div>"}s={view:i}}}else s.view=e}}if(i)_.find(".vg-alert-content--text",i).innerHTML=s.view;else{i=document.createElement("div"),i.classList.add("vg-alert","vg-alert-"+t,"vg-alert-"+a);let e=document.createElement("div");e.classList.add("vg-alert-content");let n=document.createElement("div");n.classList.add("vg-alert-content--icon");let r=document.createElement("i");r.innerHTML=D(t),n.append(r),e.append(n);let o=document.createElement("div");o.classList.add("vg-alert-content--text"),o.innerHTML=s.view,e.append(o),i.append(e)}return i}static init(e,t={}){xt.getOrCreateInstance(e,t).build()}}q.on(document,kt,(function(e){if(!b.has(e.target,"data-vgformsender"))return;const t=xt.getOrCreateInstance(e.target,{});if(t){if(t._params.validate&&!t._element.checkValidity())return e.preventDefault(),e.stopPropagation(),t._element.classList.add(t._params.classes.wasValidate),!1;if(!t._params.submit){e.preventDefault();let s=new FormData(t._element);return t.request(s,e)}}}));const Lt=xt,Et="vg.rollup",At=`click.${Et}.data.api`;class Ct extends F{constructor(e,t={}){super(e,t),this._params=this._getParams(e,o({},t))}static get NAME(){return"rollup"}static get NAME_KEY(){return Et}build(){}toggle(e){return this._isShown()?this.hide():this.show(e)}show(e){}_isShown(){return this._element.classList.contains("show")}static init(e,t={}){Ct.getOrCreateInstance(e,t).toggle()}}q.on(document,At,'[data-vg-toggle="rollup"]',(function(e){const t=_.getElementFromSelector(this);t&&(["A","AREA"].includes(this.tagName)&&e.preventDefault(),i(this)||(this.setAttribute("aria-expanded",!0),Ct.getOrCreateInstance(t).toggle(this)))}));const St=Ct;function Tt(e){for(let t=1;t<arguments.length;t++){let s=arguments[t];for(let t in s)e[t]=s[t]}return e}const Mt=function e(t,s){function a(e,a,i){if("undefined"==typeof document)return;"number"==typeof(i=Tt({},s,i)).expires&&(i.expires=new Date(Date.now()+864e5*i.expires)),i.expires&&(i.expires=i.expires.toUTCString()),e=encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);let n="";for(let e in i)i[e]&&(n+="; "+e,!0!==i[e]&&(n+="="+i[e].split(";")[0]));return document.cookie=e+"="+t.write(a,e)+n}return Object.create({set:a,get:function(e){if("undefined"==typeof document||arguments.length&&!e)return;let s=document.cookie?document.cookie.split("; "):[],a={};for(let i=0;i<s.length;i++){let n=s[i].split("="),r=n.slice(1).join("=");try{let s=decodeURIComponent(n[0]);if(a[s]=t.read(r,s),e===s)break}catch(e){}}return e?a[e]:a},remove:function(e,t){a(e,"",Tt({},t,{expires:-1}))},withAttributes:function(t){return e(this.converter,Tt({},this.attributes,t))},withConverter:function(t){return e(Tt({},this.converter,t),this.attributes)}},{attributes:{value:Object.freeze(s)},converter:{value:Object.freeze(t)}})}({read:function(e){return'"'===e[0]&&(e=e.slice(1,-1)),e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(e){return encodeURIComponent(e).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}},{path:"/"}),Ot="vg.lawcookie",$t="show",jt=`${Ot}.hide`,Pt=`${Ot}.hidden`,Nt=`${Ot}.show`,It=`${Ot}.shown`,qt=`click.${Ot}.data.api`;class Dt extends F{static sParams={};constructor(e,t={}){super(e,t),this._params=this._getParams(e,o({storage:"local",delay:500,cookie:{name:"lawCookie",value:"yes",attributes:{}},animation:{enable:!0,in:"animate__fadeInUp",out:"animate__fadeOutDown",delay:800},ajax:{route:"",target:"",method:"get"}},t)),Dt.sParams=this._params,this._params.animation.delay=this._params.animation.enable?this._params.animation.delay:0,this._animation(this._element,Dt.NAME_KEY,this._params.animation)}static get NAME(){return"lawcookie"}static get NAME_KEY(){return Ot}toggle(){return this._isShown()?this.hide():this.show()}_isShown(){return this.storage().get()}show(){i(this._element)||q.trigger(this._element,Nt,{}).defaultPrevented||(this._element.classList.add($t),this._queueCallback((()=>{q.trigger(this._element,It,{})}),this._element,!0,this._params.delay))}hide(){q.trigger(this._element,jt).defaultPrevented||setTimeout((()=>{this._element.classList.remove($t),this._queueCallback((()=>q.trigger(this._element,Pt)),this._element,!0)}),this._params.animation.delay)}storage(){return this._storage={isCookie:"cookie"===this._params.storage,storage:"cookie"===this._params.storage?Mt:localStorage,name:this._params.cookie.name,value:this._params.cookie.value,attributes:this._params.cookie.attributes},this}get(){return this._storage.isCookie?this._storage.storage.get(this._storage.name):this._storage.storage.getItem(this._storage.name)}set(){this._storage.isCookie?this._storage.storage.set(this._storage.name,this._storage.value,this._storage.attributes):this._storage.storage.setItem(this._storage.name,this._storage.value)}dispose(){super.dispose()}static reset(){Mt.remove(Dt.sParams.cookie.name),localStorage.clear(),location.reload()}static init(e,t={}){Dt.getOrCreateInstance(e,t).toggle()}}H(Dt),q.on(document,qt,'[data-vg-toggle="lawcookie"]',(function(e){if(["A","AREA"].includes(this.tagName)&&e.preventDefault(),i(this))return;const t=_.find("#vg-lawcookie");if(!t)return;const s=Dt.getOrCreateInstance(t);s.storage().set(),s.hide()})),q.on(document,qt,'[data-vg-toggle="lawcookie-clear"]',(function(e){if(["A","AREA"].includes(this.tagName)&&e.preventDefault(),i(this))return;const t=_.find("#vg-lawcookie");t&&(Dt.getOrCreateInstance(t).dispose(),location.reload())}));const Ht=Dt,Bt="vg.select",Rt="show",Ft="active",Xt="vg-select",Yt="vg-select-dropdown",zt="vg-select-list",Kt="vg-select-list--option",Vt="vg-select-list--optgroup",Wt="vg-select-current",Ut=`click.${Bt}.data.api`,Gt=`keyup.${Bt}.data.api`,Jt=`${Bt}.change`,Zt=`${Bt}.hide`,Qt=`${Bt}.hidden`,es=`${Bt}.show`,ts=`${Bt}.shown`,ss='[data-vg-toggle="select"]';let as;class is extends F{constructor(e,t={}){super(e,t),this._params=this._getParams(e,o({search:!1,placeholder:"",ajax:{route:"",target:"",method:"get",loader:!1},render:{option:m,item:m}},t)),this._drop=_.find("."+Yt,this._element)}static get NAME(){return"select"}static get NAME_KEY(){return Bt}static buildListOptions(e,t){let a=e.options,i=document.createElement("ul");i.classList.add(zt);let n=e.querySelectorAll("optgroup");if(n.length){let e=!1;[...n].forEach((function(t){let s=document.createElement("ol");s.classList.add(Vt);let a=document.createElement("li");a.innerHTML=t.label.trim(),a.classList.add("vg-select-list--optgroup-title"),s.prepend(a),r(_.findAll("option",t),s,e),i.append(s),e=!0}))}else r(a,i,!1);return t.append(i),i;function r(t,a,i){let n=0;for(const r of t){let t=document.createElement("li");t.innerHTML=r.innerHTML.trim().replace(/<\/[^>]+(>|$)/g,""),t.dataset.value=b.get(r,"value"),t.classList.add(Kt),b.set(t,"data-vg-toggle","select-option");let o=b.get(r);if(!s(o))for(const e of Object.keys(o))b.set(t,"data-"+e,o[e]);n!==e.selectedIndex||i||t.classList.add("selected"),b.has(r,"disabled")&&t.classList.add("disabled"),b.has(r,"hidden")&&t.classList.add("hidden"),a.append(t),n++}}}static build(e){let t,a=e.dataset.placeholder||"",i=e.dataset.search||!1;e.parentElement.style.position="relative",t=a&&0===e.selectedIndex?'<span class="vg-select-current--placeholder">'+a+"<span>":e.options[e.selectedIndex].innerText;let n=b.get(e,"class"),r=document.createElement("div");n=n.split(" ");for(const e of n)r.classList.add(e);b.has(e,"disabled")&&r.classList.add("disabled");let o=b.get(e);if(!s(o))for(const e of Object.keys(o))b.set(r,"data-"+e,o[e]);let l=document.createElement("div");l.classList.add(Wt),b.set(l,"data-vg-toggle","select"),b.set(l,"aria-expanded","false"),l.innerHTML=t.trim(),r.append(l);let d=document.createElement("div");if(d.classList.add(Yt),r.append(d),is.buildListOptions(e,d),e.insertAdjacentElement("afterend",r),e.dataset.inited="true",i){let e=document.createElement("div");e.classList.add("vg-select-search");let t=document.createElement("input");b.set(t,"name","vg-select-search"),b.set(t,"type","text"),b.set(t,"placeholder","Поиск..."),e.append(t),d.prepend(e)}return r}render(e,t){let s=_.find("."+zt,this._drop);s&&s.remove(),is.buildListOptions(e,this._drop)}toggle(e){return this._isShown()?this.hide():this.show(e)}show(e){if(!i(this._element)&&!q.trigger(this._element,es,{relatedTarget:e}).defaultPrevented){if("ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))q.on(e,"mouseover",m);if(this._element.classList.add(Rt),this._params.search){let e=_.find("input",this._element);e&&e.focus()}this._queueCallback((()=>{this._element.classList.add(Ft),q.trigger(this._element,ts,{relatedTarget:e})}),this._drop,!0,50)}}hide(){!i(this._element)&&this._isShown()&&this._completeHide()}_completeHide(){if(q.trigger(this._element,Zt,{}).defaultPrevented)return;this._element.classList.remove(Ft);let e=_.find(ss,this._element);if(b.set(e,"aria-expanded","false"),"ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))q.off(e,"mouseover",m);this._queueCallback((()=>{this._element.classList.remove(Rt),q.trigger(this._element,Qt,{})}),this._element,!0,10)}_isShown(){return this._element.classList.contains(Rt)}destroy(e){let t=e.nextElementSibling;t&&t.classList.contains(Xt)&&(t.remove(),e.selectedIndex=0,[...e.querySelectorAll("option")].forEach((function(t,s){t.hasAttribute("selected")&&(e.selectedIndex=s)})))}refresh(e){const t=this;new MutationObserver((()=>{clearTimeout(as),as=setTimeout((()=>{t.build(!0,e)}),100)})).observe(e,{attributeFilter:["disabled","required","style","hidden"],childList:!0,subtree:!0,characterDataOldValue:!0})}search(e){}dispose(){super.dispose()}static hideOpenToggles(e){const t=_.findAll(".vg-select:not(.disabled):not(:disabled).show");for(const s of t){const t=is.getInstance(s);if(!t)continue;if(e.target.closest("."+Xt)===t._element)return;if(e.composedPath().includes(t._element))continue;const a={relatedTarget:t._element};"click"===e.type&&(a.clickEvent=e),t._completeHide(a)}}static clearDrops(e){2===e.button||"keyup"===e.type&&"Tab"!==e.key||is.hideOpenToggles(e)}static init(e,t={},s=!1){let a=is.build(e);is.getOrCreateInstance(a,t)}}q.on(document,Ut,is.clearDrops),q.on(document,Ut,ss,(function(){const e=this.closest("."+Xt);b.set(this,"aria-expanded",!0);const t=_.find(".vg-select.show");t&&t!==e&&is.getInstance(t).hide(),is.getOrCreateInstance(e).toggle(this)})),q.on(document,Ut,'[data-vg-toggle="select-option"]',(function(e){let t=e.target;if(!t.classList.contains("disabled")){let e=t.closest("."+Xt),s=e.querySelectorAll("."+Kt);if(s.length)for(const e of s)e.classList.remove("selected");t.classList.add("selected"),e.querySelector("."+Wt).innerText=t.innerText,e.classList.remove("show");let a=e.previousSibling;a.value=t.dataset.value,q.trigger(a,Jt,{value:t.dataset.value})}})),q.on(document,Gt,"[name=vg-select-search]",(function(e){let t=this,s=t?.closest("."+Yt).querySelector("."+zt);if(s){let e=[...s.querySelectorAll("."+Kt)],a=[...s.querySelectorAll("."+Vt)],i=t?.value;e=e.concat(a);for(const t of e)b.show(t);if(i.length){i=i.trim(),i=i.toLowerCase(),i=function(e){let t,s="й ц у к е н г ш щ з х ъ ф ы в а п р о л д ж э я ч с м и т ь б ю".split(/ +/g),a="q w e r t y u i o p [ ] a s d f g h j k l ; ' z x c v b n m , .".split(/ +/g);for(t=0;t<s.length;t++)e=(e=e.split(a[t]).join(s[t])).split(a[t].toUpperCase()).join(s[t].toUpperCase());return e}(i);for(const t of e)-1===t.innerText.toLowerCase().indexOf(i)&&b.hide(t)}}}));const ns=is;vg=t})();
3
+ //# sourceMappingURL=vgapp.js.map