vgapp 0.2.2 → 0.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/CHANGELOG.md +7 -1
  2. package/app/modules/vgalert/js/vgalert.js +119 -0
  3. package/app/modules/vgalert/scss/_variables.scss +32 -0
  4. package/app/modules/vgalert/scss/vgalert.css +83 -0
  5. package/app/modules/vgalert/scss/vgalert.css.map +1 -0
  6. package/app/modules/vgalert/scss/vgalert.scss +79 -0
  7. package/app/modules/vgdropdown/js/vgdropdown.js +9 -8
  8. package/app/modules/vgdropdown/scss/vgdropdown.css +47 -47
  9. package/app/modules/vgformsender/scss/vgformsender.css +13 -13
  10. package/app/modules/vglawcookie/scss/vglawcookie.css +87 -87
  11. package/app/modules/vgmodal/js/vgmodal.js +32 -4
  12. package/app/modules/vgmodal/scss/vgmodal.css +3824 -3824
  13. package/app/modules/vgnav/scss/vgnav.css +312 -312
  14. package/app/modules/vgrollup/scss/vgrollup.css +41 -41
  15. package/app/modules/vgselect/scss/vgselect.css +256 -256
  16. package/app/modules/vgsidebar/js/vgsidebar.js +32 -2
  17. package/app/modules/vgsidebar/scss/vgsidebar.css +86 -86
  18. package/app/modules/vgtoast/js/vgtoast.js +378 -0
  19. package/app/modules/vgtoast/scss/_variables.scss +26 -0
  20. package/app/modules/vgtoast/scss/vgtoast.css +113 -0
  21. package/app/modules/vgtoast/scss/vgtoast.css.map +1 -0
  22. package/app/modules/vgtoast/scss/vgtoast.scss +125 -0
  23. package/app/utils/js/dom/event.js +1 -0
  24. package/app/utils/scss/default.css +198 -275
  25. package/app/utils/scss/default.css.map +1 -1
  26. package/app/utils/scss/default.scss +0 -70
  27. package/app/utils/scss/functions.scss +19 -0
  28. package/app/utils/scss/variables.scss +58 -35
  29. package/build/vgapp.css +3 -1
  30. package/build/vgapp.css.map +1 -1
  31. package/build/vgapp.js +1 -1
  32. package/build/vgapp.js.map +1 -1
  33. package/index.js +9 -1
  34. package/package.json +1 -1
  35. package/app/modules/vgnotify/js/vgnotify.js +0 -0
  36. package/app/modules/vgnotify/scss/vgnotify.css +0 -3
  37. package/app/modules/vgnotify/scss/vgnotify.css.map +0 -1
  38. package/app/modules/vgnotify/scss/vgnotify.scss +0 -0
@@ -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 = `click.dismiss${NAME_KEY}`
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: true,
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;