vgapp 0.2.3 → 0.2.5
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/CHANGELOG.md +10 -0
- package/app/modules/vgalert/js/vgalert.js +135 -0
- package/app/modules/vgalert/scss/_variables.scss +32 -0
- package/app/modules/vgalert/scss/vgalert.css +83 -0
- package/app/modules/vgalert/scss/vgalert.css.map +1 -0
- package/app/modules/vgalert/scss/vgalert.scss +79 -0
- package/app/modules/vgdropdown/js/vgdropdown.js +2 -1
- package/app/modules/vgmodal/js/vgmodal.js +32 -4
- package/app/modules/vgrollup/js/vgrollup.js +207 -16
- package/app/modules/vgrollup/scss/vgrollup.css +3 -0
- package/app/modules/vgrollup/scss/vgrollup.css.map +1 -1
- package/app/modules/vgrollup/scss/vgrollup.scss +6 -0
- package/app/modules/vgsidebar/js/vgsidebar.js +32 -2
- package/app/modules/vgtoast/js/vgtoast.js +378 -0
- package/app/modules/vgtoast/scss/_variables.scss +26 -0
- package/app/modules/vgtoast/scss/vgtoast.css +133 -0
- package/app/modules/vgtoast/scss/vgtoast.css.map +1 -0
- package/app/modules/vgtoast/scss/vgtoast.scss +125 -0
- package/app/utils/js/dom/event.js +1 -0
- package/app/utils/scss/default.css +0 -77
- package/app/utils/scss/default.css.map +1 -1
- package/app/utils/scss/default.scss +0 -70
- package/app/utils/scss/functions.scss +19 -0
- package/app/utils/scss/variables.scss +58 -35
- package/build/vgapp.css +13 -4946
- package/build/vgapp.css.map +1 -1
- package/build/vgapp.js +3 -4277
- package/build/vgapp.js.map +1 -1
- package/index.js +9 -1
- package/package.json +1 -1
- package/app/modules/vgnotify/js/vgnotify.js +0 -0
- package/app/modules/vgnotify/scss/vgnotify.css +0 -3
- package/app/modules/vgnotify/scss/vgnotify.css.map +0 -1
- package/app/modules/vgnotify/scss/vgnotify.scss +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
# VEGAS-APP 0.2.5 (Апрель, 12, 2025)
|
|
2
|
+
* Исправлены ошибки в разных модулях
|
|
3
|
+
## Новый модуль VGRollup
|
|
4
|
+
|
|
5
|
+
# VEGAS-APP 0.2.4 (Апрель, 8, 2025)
|
|
6
|
+
## Модуль VGSidebar & VGModal
|
|
7
|
+
* Добавлен параметр hash
|
|
8
|
+
|
|
9
|
+
## Новый модуль VGToast
|
|
10
|
+
|
|
1
11
|
# VEGAS-APP 0.2.2 - 0.2.3 (Апрель, 4, 2025)
|
|
2
12
|
## Модуль VGDROPDOWN
|
|
3
13
|
* Добавлен параметр overflow и backdrop
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import BaseModule from "../../base-module";
|
|
2
|
+
import EventHandler from "../../../utils/js/dom/event";
|
|
3
|
+
import {dismissTrigger} from "../../module-fn";
|
|
4
|
+
import {execute, mergeDeepObject} from "../../../utils/js/functions";
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Constants
|
|
8
|
+
*/
|
|
9
|
+
const NAME = 'alert';
|
|
10
|
+
const NAME_KEY = 'vg.alert';
|
|
11
|
+
const SELECTOR_DATA_TOGGLE= '[data-vg-toggle="alert"]';
|
|
12
|
+
|
|
13
|
+
const CLASS_NAME_SHOW = 'show';
|
|
14
|
+
const CLASS_NAME_OPEN = 'vg-alert-open';
|
|
15
|
+
|
|
16
|
+
const EVENT_KEY_HIDE = `${NAME_KEY}.hide`;
|
|
17
|
+
const EVENT_KEY_HIDDEN = `${NAME_KEY}.hidden`;
|
|
18
|
+
const EVENT_KEY_SHOW = `${NAME_KEY}.show`;
|
|
19
|
+
const EVENT_KEY_SHOWN = `${NAME_KEY}.shown`;
|
|
20
|
+
const EVENT_KEY_LOADED = `${NAME_KEY}.loaded`;
|
|
21
|
+
const EVENT_KEY_CONFIRM = `${NAME_KEY}.confirm`;
|
|
22
|
+
const EVENT_KEY_CANCEL = `${NAME_KEY}.cancel`;
|
|
23
|
+
|
|
24
|
+
const EVENT_KEY_KEYDOWN_DISMISS = `keydown.dismiss.${NAME_KEY}`;
|
|
25
|
+
const EVENT_KEY_HIDE_PREVENTED = `hidePrevented.${NAME_KEY}`;
|
|
26
|
+
const EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
|
|
27
|
+
|
|
28
|
+
class VGAlert extends BaseModule {
|
|
29
|
+
constructor(element, params = {}) {
|
|
30
|
+
super(element, params);
|
|
31
|
+
|
|
32
|
+
this._params = this._getParams(element, mergeDeepObject({
|
|
33
|
+
backdrop: true,
|
|
34
|
+
overflow: true,
|
|
35
|
+
keyboard: true,
|
|
36
|
+
confirm: true,
|
|
37
|
+
showInside: true,
|
|
38
|
+
theme: 'default',
|
|
39
|
+
elements: [
|
|
40
|
+
{
|
|
41
|
+
'title': 'Вы уверены?',
|
|
42
|
+
'element': 'button',
|
|
43
|
+
'type': 'confirm',
|
|
44
|
+
'classes': ['btn', 'btn-primary']
|
|
45
|
+
}
|
|
46
|
+
],
|
|
47
|
+
animation: {
|
|
48
|
+
enable: false,
|
|
49
|
+
in: 'animate__rollIn',
|
|
50
|
+
out: 'animate__rollOut',
|
|
51
|
+
delay: 800,
|
|
52
|
+
},
|
|
53
|
+
ajax: {
|
|
54
|
+
route: '',
|
|
55
|
+
target: '',
|
|
56
|
+
method: 'get',
|
|
57
|
+
loader: false,
|
|
58
|
+
}
|
|
59
|
+
}, params));
|
|
60
|
+
|
|
61
|
+
this._addEventListeners();
|
|
62
|
+
this._dismissElement();
|
|
63
|
+
|
|
64
|
+
this._params.animation.delay = !this._params.animation.enable ? 0 : this._params.animation.delay;
|
|
65
|
+
this._animation(this._element, VGAlert.NAME_KEY, this._params.animation);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
static get NAME() {
|
|
69
|
+
return NAME;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
static get NAME_KEY() {
|
|
73
|
+
return NAME_KEY
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
static run(text, params = {}, callback) {
|
|
77
|
+
return VGAlert.build(text, params, callback);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
static build(text, params, callback) {
|
|
81
|
+
params = mergeDeepObject({
|
|
82
|
+
theme: 'default',
|
|
83
|
+
}, params);
|
|
84
|
+
|
|
85
|
+
let target;
|
|
86
|
+
|
|
87
|
+
let instance = VGAlert.getOrCreateInstance(target, params);
|
|
88
|
+
execute(callback, [instance]);
|
|
89
|
+
instance.show();
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
toggle(relatedTarget) {
|
|
93
|
+
return !this._isShown() ? this.show(relatedTarget) : this.hide();
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
show(relatedTarget) {
|
|
97
|
+
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
hide() {
|
|
101
|
+
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
dispose() {
|
|
105
|
+
super.dispose();
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
_isShown() {
|
|
109
|
+
return this._element.classList.contains(CLASS_NAME_SHOW);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
_addEventListeners() {
|
|
113
|
+
EventHandler.on(document, EVENT_KEY_KEYDOWN_DISMISS, event => {
|
|
114
|
+
if (event.key !== 'Escape') return;
|
|
115
|
+
|
|
116
|
+
if (this._params.keyboard) {
|
|
117
|
+
this.hide();
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
EventHandler.trigger(this._element, EVENT_KEY_HIDE_PREVENTED)
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
dismissTrigger(VGAlert);
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* Data API implementation
|
|
130
|
+
*/
|
|
131
|
+
EventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
|
|
132
|
+
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
export default VGAlert;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
$alert-map: (
|
|
2
|
+
padding: 2rem,
|
|
3
|
+
margin: 0 0 2rem,
|
|
4
|
+
border-width: $border-width,
|
|
5
|
+
border-style: $border-style,
|
|
6
|
+
border-color: transparent,
|
|
7
|
+
border-radius: $border-radius,
|
|
8
|
+
gap: 1.5rem,
|
|
9
|
+
icon-width: 80px,
|
|
10
|
+
icon-height: 80px,
|
|
11
|
+
content-width: 100%,
|
|
12
|
+
content-align: center,
|
|
13
|
+
content-justify: flex-start
|
|
14
|
+
);
|
|
15
|
+
$alert-success-map: (
|
|
16
|
+
color: darken(#A5DC86, 10%),
|
|
17
|
+
border-color: #A5DC86,
|
|
18
|
+
background-color: rgba(lighten(#A5DC86, 10%), .15),
|
|
19
|
+
stroke: rgba(117, 183, 152, 0.4)
|
|
20
|
+
);
|
|
21
|
+
|
|
22
|
+
$alert-error-map: (
|
|
23
|
+
color: darken(#F74444, 10%),
|
|
24
|
+
border-color: #F74444,
|
|
25
|
+
background-color: rgba(lighten(#F74444, 25%), .075)
|
|
26
|
+
);
|
|
27
|
+
|
|
28
|
+
$alert-waiting-map: (
|
|
29
|
+
color: darken(#ffda6a, 10%),
|
|
30
|
+
border-color: #ffda6a,
|
|
31
|
+
background-color: rgba(lighten(#ffda6a, 15%), .1)
|
|
32
|
+
);
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
@charset "UTF-8";
|
|
2
|
+
/**
|
|
3
|
+
*--------------------------------------------------------------------------
|
|
4
|
+
* Модуль: VGAlert
|
|
5
|
+
* Автор: Vegas DEV
|
|
6
|
+
* Лицензия: смотри LICENSE
|
|
7
|
+
*--------------------------------------------------------------------------
|
|
8
|
+
**/
|
|
9
|
+
.vg-alert {
|
|
10
|
+
--vg-alert-padding: 2rem ;
|
|
11
|
+
--vg-alert-margin: 0 0 2rem ;
|
|
12
|
+
--vg-alert-border-width: 1px ;
|
|
13
|
+
--vg-alert-border-style: solid ;
|
|
14
|
+
--vg-alert-border-color: transparent ;
|
|
15
|
+
--vg-alert-border-radius: 0.375rem ;
|
|
16
|
+
--vg-alert-gap: 1.5rem ;
|
|
17
|
+
--vg-alert-icon-width: 80px ;
|
|
18
|
+
--vg-alert-icon-height: 80px ;
|
|
19
|
+
--vg-alert-content-width: 100% ;
|
|
20
|
+
--vg-alert-content-align: center ;
|
|
21
|
+
--vg-alert-content-justify: flex-start ;
|
|
22
|
+
--vg-alert-success-color: #88d15e ;
|
|
23
|
+
--vg-alert-success-border-color: #A5DC86 ;
|
|
24
|
+
--vg-alert-success-background-color: rgba(194, 231, 174, 0.15) ;
|
|
25
|
+
--vg-alert-success-stroke: rgba(117, 183, 152, 0.4) ;
|
|
26
|
+
--vg-alert-error-color: #f51313 ;
|
|
27
|
+
--vg-alert-error-border-color: #F74444 ;
|
|
28
|
+
--vg-alert-error-background-color: rgba(252, 190, 190, 0.075) ;
|
|
29
|
+
--vg-alert-waiting-color: #ffcd37 ;
|
|
30
|
+
--vg-alert-waiting-border-color: #ffda6a ;
|
|
31
|
+
--vg-alert-waiting-background-color: rgba(255, 237, 183, 0.1) ;
|
|
32
|
+
padding: var(--vg-alert-padding);
|
|
33
|
+
margin: var(--vg-alert-margin);
|
|
34
|
+
border: var(--vg-alert-border-width) var(--vg-alert-border-style) var(--vg-alert-border-color);
|
|
35
|
+
border-radius: var(--vg-alert-border-radius);
|
|
36
|
+
display: flex;
|
|
37
|
+
align-items: center;
|
|
38
|
+
justify-content: center;
|
|
39
|
+
}
|
|
40
|
+
.vg-alert-success {
|
|
41
|
+
color: var(--vg-alert-success-color);
|
|
42
|
+
border-color: var(--vg-alert-success-border-color);
|
|
43
|
+
background-color: var(--vg-alert-success-background-color);
|
|
44
|
+
}
|
|
45
|
+
.vg-alert-error {
|
|
46
|
+
color: var(--vg-alert-error-color);
|
|
47
|
+
border-color: var(--vg-alert-error-border-color);
|
|
48
|
+
background-color: var(--vg-alert-error-background-color);
|
|
49
|
+
}
|
|
50
|
+
.vg-alert-content {
|
|
51
|
+
display: flex;
|
|
52
|
+
align-items: var(--vg-alert-content-align);
|
|
53
|
+
justify-content: var(--vg-alert-content-justify);
|
|
54
|
+
gap: var(--vg-alert-gap);
|
|
55
|
+
width: var(--vg-alert-content-width);
|
|
56
|
+
}
|
|
57
|
+
.vg-alert-content--icon {
|
|
58
|
+
width: var(--vg-alert-icon-width);
|
|
59
|
+
height: var(--vg-alert-icon-height);
|
|
60
|
+
}
|
|
61
|
+
.vg-alert-content--icon svg {
|
|
62
|
+
width: 100%;
|
|
63
|
+
height: 100%;
|
|
64
|
+
}
|
|
65
|
+
.vg-alert-content--icon .ui-success-circle {
|
|
66
|
+
stroke: var(--vg-alert-success-stroke);
|
|
67
|
+
}
|
|
68
|
+
.vg-alert-content--icon .ui-success-path {
|
|
69
|
+
stroke: var(--vg-alert-success-color);
|
|
70
|
+
}
|
|
71
|
+
.vg-alert-modal {
|
|
72
|
+
--vg-alert-icon-width: 150px;
|
|
73
|
+
--vg-alert-icon-height: 150px;
|
|
74
|
+
--vg-alert-padding: 5rem 2rem;
|
|
75
|
+
--vg-alert-border-width: 0;
|
|
76
|
+
margin: 0;
|
|
77
|
+
}
|
|
78
|
+
.vg-alert-modal .vg-alert-content {
|
|
79
|
+
flex-direction: column;
|
|
80
|
+
text-align: center;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/*# sourceMappingURL=vgalert.css.map */
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sourceRoot":"","sources":["vgalert.scss","../../../utils/scss/mixin.scss"],"names":[],"mappings":";AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAaA;ECNG;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EAAA;EDWF;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;;AAGD;EACC;EACA;EACA;;AAGD;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;;AAEA;EACC;EACA;;AAIA;EACC;;AAGD;EACC;;AAMJ;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA","file":"vgalert.css"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
/**
|
|
2
|
+
*--------------------------------------------------------------------------
|
|
3
|
+
* Модуль: VGAlert
|
|
4
|
+
* Автор: Vegas DEV
|
|
5
|
+
* Лицензия: смотри LICENSE
|
|
6
|
+
*--------------------------------------------------------------------------
|
|
7
|
+
**/
|
|
8
|
+
|
|
9
|
+
@import "../../../utils/scss/functions";
|
|
10
|
+
@import "../../../utils/scss/mixin";
|
|
11
|
+
@import "../../../utils/scss/variables";
|
|
12
|
+
@import "variables";
|
|
13
|
+
|
|
14
|
+
.vg-alert {
|
|
15
|
+
@include mix-vars('alert', $alert-map);
|
|
16
|
+
@include mix-vars('alert-success', $alert-success-map);
|
|
17
|
+
@include mix-vars('alert-error', $alert-error-map);
|
|
18
|
+
@include mix-vars('alert-waiting', $alert-waiting-map);
|
|
19
|
+
padding: var(--vg-alert-padding);
|
|
20
|
+
margin: var(--vg-alert-margin);
|
|
21
|
+
border: var(--vg-alert-border-width) var(--vg-alert-border-style) var(--vg-alert-border-color);
|
|
22
|
+
border-radius: var(--vg-alert-border-radius);
|
|
23
|
+
display: flex;
|
|
24
|
+
align-items: center;
|
|
25
|
+
justify-content: center;
|
|
26
|
+
|
|
27
|
+
&-success {
|
|
28
|
+
color: var(--vg-alert-success-color);
|
|
29
|
+
border-color: var(--vg-alert-success-border-color);
|
|
30
|
+
background-color: var(--vg-alert-success-background-color);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
&-error {
|
|
34
|
+
color: var(--vg-alert-error-color);
|
|
35
|
+
border-color: var(--vg-alert-error-border-color);
|
|
36
|
+
background-color: var(--vg-alert-error-background-color);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
&-content {
|
|
40
|
+
display: flex;
|
|
41
|
+
align-items: var(--vg-alert-content-align);
|
|
42
|
+
justify-content: var(--vg-alert-content-justify);
|
|
43
|
+
gap: var(--vg-alert-gap);
|
|
44
|
+
width: var(--vg-alert-content-width);
|
|
45
|
+
|
|
46
|
+
&--icon {
|
|
47
|
+
width: var(--vg-alert-icon-width);
|
|
48
|
+
height: var(--vg-alert-icon-height);
|
|
49
|
+
|
|
50
|
+
svg {
|
|
51
|
+
width: 100%;
|
|
52
|
+
height: 100%;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.ui-success {
|
|
56
|
+
&-circle {
|
|
57
|
+
stroke: var(--vg-alert-success-stroke);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
&-path {
|
|
61
|
+
stroke: var(--vg-alert-success-color);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
&-modal {
|
|
68
|
+
--vg-alert-icon-width: 150px;
|
|
69
|
+
--vg-alert-icon-height: 150px;
|
|
70
|
+
--vg-alert-padding: 5rem 2rem;
|
|
71
|
+
--vg-alert-border-width: 0;
|
|
72
|
+
margin: 0;
|
|
73
|
+
|
|
74
|
+
.vg-alert-content {
|
|
75
|
+
flex-direction: column;
|
|
76
|
+
text-align: center;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
@@ -6,7 +6,6 @@ import EventHandler from "../../../utils/js/dom/event";
|
|
|
6
6
|
import {Manipulator} from "../../../utils/js/dom/manipulator";
|
|
7
7
|
import {execute, isDisabled, isRTL, mergeDeepObject, reflow} from "../../../utils/js/functions";
|
|
8
8
|
import {dismissTrigger} from "../../module-fn";
|
|
9
|
-
import Params from "../../../utils/js/components/params";
|
|
10
9
|
|
|
11
10
|
/**
|
|
12
11
|
* Constants
|
|
@@ -36,8 +35,10 @@ const EVENT_KEY_LOADED = `${NAME_KEY}.loaded`;
|
|
|
36
35
|
const EVENT_KEY_KEYDOWN_DISMISS = `keydown.dismiss.${NAME_KEY}`;
|
|
37
36
|
const EVENT_KEY_HIDE_PREVENTED = `hidePrevented.${NAME_KEY}`;
|
|
38
37
|
const EVENT_KEY_CLICK_DATA_API = `click.${NAME_KEY}.data.api`;
|
|
39
|
-
const EVENT_KEY_MOUSEDOWN_DISMISS = `mousedown.dismiss${NAME_KEY}
|
|
40
|
-
const EVENT_KEY_CLICK_DISMISS
|
|
38
|
+
const EVENT_KEY_MOUSEDOWN_DISMISS = `mousedown.dismiss${NAME_KEY}`;
|
|
39
|
+
const EVENT_KEY_CLICK_DISMISS = `click.dismiss${NAME_KEY}`;
|
|
40
|
+
const EVENT_KEY_DOM_LOADED_DATA_API = `DOMContentLoaded.${NAME_KEY}.data.api`;
|
|
41
|
+
const EVENT_KEY_POPSTATE_DATA_API = `popstate.${NAME_KEY}.data.api`;
|
|
41
42
|
|
|
42
43
|
class VGModal extends BaseModule {
|
|
43
44
|
constructor(element, params = {}) {
|
|
@@ -48,6 +49,7 @@ class VGModal extends BaseModule {
|
|
|
48
49
|
focus: true,
|
|
49
50
|
keyboard: true,
|
|
50
51
|
fields: [],
|
|
52
|
+
hash: false,
|
|
51
53
|
ajax: {
|
|
52
54
|
route: '',
|
|
53
55
|
target: '',
|
|
@@ -149,6 +151,14 @@ class VGModal extends BaseModule {
|
|
|
149
151
|
this._isShown = true;
|
|
150
152
|
this._isTransitioning = true;
|
|
151
153
|
|
|
154
|
+
if (this._params.hash) {
|
|
155
|
+
window.history.pushState(null, "vg-sidebar-open", "#" + this._element.id);
|
|
156
|
+
|
|
157
|
+
EventHandler.on(window, EVENT_KEY_POPSTATE_DATA_API, () => {
|
|
158
|
+
this.hide();
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
|
|
152
162
|
this._scrollBar.hide();
|
|
153
163
|
|
|
154
164
|
document.body.classList.add(CLASS_NAME_OPEN);
|
|
@@ -183,6 +193,10 @@ class VGModal extends BaseModule {
|
|
|
183
193
|
|
|
184
194
|
if (openedModals.length) return;
|
|
185
195
|
|
|
196
|
+
if (this._params.hash) {
|
|
197
|
+
history.pushState("", document.title, window.location.pathname + window.location.search);
|
|
198
|
+
}
|
|
199
|
+
|
|
186
200
|
Backdrop.hide(() => {
|
|
187
201
|
document.body.classList.remove(CLASS_NAME_OPEN);
|
|
188
202
|
this._resetAdjustments();
|
|
@@ -327,7 +341,6 @@ dismissTrigger(VGModal);
|
|
|
327
341
|
/**
|
|
328
342
|
* Data API implementation
|
|
329
343
|
*/
|
|
330
|
-
|
|
331
344
|
EventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, function (event) {
|
|
332
345
|
const target = Selectors.getElementFromSelector(this);
|
|
333
346
|
|
|
@@ -342,6 +355,21 @@ EventHandler.on(document, EVENT_KEY_CLICK_DATA_API, SELECTOR_DATA_TOGGLE, functi
|
|
|
342
355
|
|
|
343
356
|
const data = VGModal.getOrCreateInstance(target);
|
|
344
357
|
data.toggle(this);
|
|
358
|
+
});
|
|
359
|
+
|
|
360
|
+
EventHandler.on(document, EVENT_KEY_DOM_LOADED_DATA_API, function () {
|
|
361
|
+
let targetHash = window.location.hash.slice(1);
|
|
362
|
+
if (targetHash) {
|
|
363
|
+
let target = Selectors.find('#' + targetHash);
|
|
364
|
+
if (target && target.classList.contains('vg-modal')) {
|
|
365
|
+
if (isDisabled(target)) {
|
|
366
|
+
return;
|
|
367
|
+
}
|
|
368
|
+
|
|
369
|
+
const data = VGModal.getOrCreateInstance(target)
|
|
370
|
+
data.toggle();
|
|
371
|
+
}
|
|
372
|
+
}
|
|
345
373
|
})
|
|
346
374
|
|
|
347
375
|
export default VGModal;
|