1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 | import { Xt } from './xt.mjs'
|
8 | import './toggle.mjs'
|
9 | import JSON5 from 'json5'
|
10 | Xt.JSON5 = JSON5
|
11 |
|
12 |
|
13 |
|
14 |
|
15 | class Overlay extends Xt.Toggle {
|
16 | |
17 |
|
18 |
|
19 |
|
20 |
|
21 |
|
22 | constructor(object, optionsCustom = {}) {
|
23 | super(object, optionsCustom)
|
24 | }
|
25 | }
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 | Overlay.componentName = 'xt-overlay'
|
32 | Overlay.optionsDefault = {
|
33 |
|
34 | elements: '[data-xt-overlay-element]',
|
35 | targets: '[data-xt-overlay-target]',
|
36 |
|
37 | min: 0,
|
38 | max: 1,
|
39 |
|
40 | on: 'click',
|
41 | off: 'click',
|
42 | mouseParent: false,
|
43 | eventLimit: '.xt-event-limit, .xt-overlay',
|
44 | closeauto: true,
|
45 | openauto: true,
|
46 | closeDeep: '.xt-dismiss',
|
47 | closeInside: '.xt-backdrop, .xt-overlay-container',
|
48 | closeOutside: false,
|
49 |
|
50 | queue: {
|
51 | elements: false,
|
52 | targets: true,
|
53 | elementsInner: false,
|
54 | targetsInner: true,
|
55 | },
|
56 |
|
57 | disableDeactivate: true,
|
58 | appendTo: 'body',
|
59 | classBody: 'xt-scrollbar-overlay',
|
60 | focusLimit: true,
|
61 | zIndex: {
|
62 | targets: {
|
63 | start: 5000,
|
64 | factor: 0,
|
65 | },
|
66 | },
|
67 | a11y: {
|
68 | role: 'dialog',
|
69 | labelElements: false,
|
70 | labelTargets: false,
|
71 | controls: true,
|
72 | selected: false,
|
73 | expanded: true,
|
74 | live: true,
|
75 | disabled: true,
|
76 | keyboard: true,
|
77 | vertical: false,
|
78 | items: false,
|
79 | },
|
80 | }
|
81 |
|
82 |
|
83 |
|
84 |
|
85 |
|
86 | Xt.Overlay = Overlay
|
87 |
|
88 |
|
89 |
|
90 |
|
91 |
|
92 | if (typeof window !== 'undefined') {
|
93 | Xt.mount({
|
94 | matches: `[data-${Xt.Overlay.componentName}]`,
|
95 | mount: ({ ref }) => {
|
96 |
|
97 |
|
98 | const optionsMarkup = ref.getAttribute(`data-${Xt.Overlay.componentName}`)
|
99 | const options = optionsMarkup ? JSON5.parse(optionsMarkup) : {}
|
100 |
|
101 |
|
102 |
|
103 | let self = new Xt.Overlay(ref, options)
|
104 |
|
105 |
|
106 |
|
107 | return () => {
|
108 | self.destroy()
|
109 | self = null
|
110 | }
|
111 | },
|
112 | })
|
113 | }
|