@spectrum-web-components/overlay 0.30.0 → 0.30.1-overlay.30
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/package.json +50 -21
- package/sp-overlay.d.ts +6 -0
- package/sp-overlay.dev.js +5 -0
- package/{active-overlay.dev.js.map → sp-overlay.dev.js.map} +3 -3
- package/sp-overlay.js +2 -0
- package/{active-overlay.js.map → sp-overlay.js.map} +4 -4
- package/src/Overlay.d.ts +28 -0
- package/src/Overlay.dev.js +87 -0
- package/src/Overlay.dev.js.map +7 -0
- package/src/Overlay.js +2 -0
- package/src/Overlay.js.map +7 -0
- package/src/OverlayBase.d.ts +117 -0
- package/src/OverlayBase.dev.js +681 -0
- package/src/OverlayBase.dev.js.map +7 -0
- package/src/OverlayBase.js +17 -0
- package/src/OverlayBase.js.map +7 -0
- package/src/OverlayDialog.d.ts +8 -0
- package/src/OverlayDialog.dev.js +150 -0
- package/src/OverlayDialog.dev.js.map +7 -0
- package/src/OverlayDialog.js +2 -0
- package/src/OverlayDialog.js.map +7 -0
- package/src/OverlayNoPopover.d.ts +8 -0
- package/src/OverlayNoPopover.dev.js +120 -0
- package/src/OverlayNoPopover.dev.js.map +7 -0
- package/src/OverlayNoPopover.js +2 -0
- package/src/OverlayNoPopover.js.map +7 -0
- package/src/OverlayPopover.d.ts +8 -0
- package/src/OverlayPopover.dev.js +167 -0
- package/src/OverlayPopover.dev.js.map +7 -0
- package/src/OverlayPopover.js +2 -0
- package/src/OverlayPopover.js.map +7 -0
- package/src/OverlayStack.d.ts +24 -0
- package/src/OverlayStack.dev.js +125 -0
- package/src/OverlayStack.dev.js.map +7 -0
- package/src/OverlayStack.js +2 -0
- package/src/OverlayStack.js.map +7 -0
- package/src/OverlayTrigger.d.ts +19 -31
- package/src/OverlayTrigger.dev.js +116 -245
- package/src/OverlayTrigger.dev.js.map +3 -3
- package/src/OverlayTrigger.js +52 -22
- package/src/OverlayTrigger.js.map +3 -3
- package/src/PlacementController.d.ts +36 -0
- package/src/PlacementController.dev.js +193 -0
- package/src/PlacementController.dev.js.map +7 -0
- package/src/PlacementController.js +2 -0
- package/src/PlacementController.js.map +7 -0
- package/src/VirtualTrigger.dev.js +0 -2
- package/src/VirtualTrigger.dev.js.map +2 -2
- package/src/VirtualTrigger.js +1 -1
- package/src/VirtualTrigger.js.map +3 -3
- package/src/fullSizePlugin.d.ts +12 -0
- package/src/fullSizePlugin.dev.js +39 -0
- package/src/fullSizePlugin.dev.js.map +7 -0
- package/src/fullSizePlugin.js +2 -0
- package/src/fullSizePlugin.js.map +7 -0
- package/src/index.d.ts +2 -3
- package/src/index.dev.js +2 -3
- package/src/index.dev.js.map +2 -2
- package/src/index.js +1 -1
- package/src/index.js.map +2 -2
- package/src/loader.d.ts +2 -2
- package/src/loader.dev.js +2 -19
- package/src/loader.dev.js.map +2 -2
- package/src/loader.js +1 -1
- package/src/loader.js.map +3 -3
- package/src/overlay-base.css.dev.js +9 -0
- package/src/overlay-base.css.dev.js.map +7 -0
- package/src/overlay-base.css.js +6 -0
- package/src/overlay-base.css.js.map +7 -0
- package/src/overlay-trigger.css.dev.js +1 -1
- package/src/overlay-trigger.css.dev.js.map +1 -1
- package/src/overlay-trigger.css.js +1 -1
- package/src/overlay-trigger.css.js.map +1 -1
- package/src/overlay-types.d.ts +3 -3
- package/src/overlay-types.dev.js +1 -0
- package/src/overlay-types.dev.js.map +3 -3
- package/src/overlay-types.js +1 -1
- package/src/overlay-types.js.map +3 -3
- package/src/placement.d.ts +21 -0
- package/src/placement.dev.js +111 -0
- package/src/placement.dev.js.map +7 -0
- package/src/placement.js +2 -0
- package/src/placement.js.map +7 -0
- package/src/topLayerOverTransforms.d.ts +22 -0
- package/src/topLayerOverTransforms.dev.js +165 -0
- package/src/topLayerOverTransforms.dev.js.map +7 -0
- package/src/topLayerOverTransforms.js +2 -0
- package/src/topLayerOverTransforms.js.map +7 -0
- package/stories/overlay-element.stories.js +230 -0
- package/stories/overlay-element.stories.js.map +7 -0
- package/stories/overlay-story-components.js +9 -8
- package/stories/overlay-story-components.js.map +2 -2
- package/stories/overlay.stories.js +672 -646
- package/stories/overlay.stories.js.map +2 -2
- package/sync/overlay-trigger.d.ts +4 -0
- package/sync/overlay-trigger.dev.js +1 -4
- package/sync/overlay-trigger.dev.js.map +2 -2
- package/sync/overlay-trigger.js +1 -1
- package/sync/overlay-trigger.js.map +3 -3
- package/test/benchmark/basic-test.js +1 -1
- package/test/benchmark/basic-test.js.map +1 -1
- package/test/index.js +422 -375
- package/test/index.js.map +3 -3
- package/test/overlay-element.test-vrt.js +5 -0
- package/test/overlay-element.test-vrt.js.map +7 -0
- package/test/overlay-element.test.js +664 -0
- package/test/overlay-element.test.js.map +7 -0
- package/test/overlay-lifecycle.test.js +34 -106
- package/test/overlay-lifecycle.test.js.map +2 -2
- package/test/overlay-trigger-click.test.js +11 -5
- package/test/overlay-trigger-click.test.js.map +2 -2
- package/test/overlay-trigger-extended.test.js +1 -6
- package/test/overlay-trigger-extended.test.js.map +2 -2
- package/test/overlay-trigger-hover-click.test.js +22 -22
- package/test/overlay-trigger-hover-click.test.js.map +2 -2
- package/test/overlay-trigger-hover.test.js +40 -34
- package/test/overlay-trigger-hover.test.js.map +2 -2
- package/test/overlay-trigger-longpress.test.js +98 -80
- package/test/overlay-trigger-longpress.test.js.map +2 -2
- package/test/overlay-trigger-sync.test.js +1 -1
- package/test/overlay-trigger-sync.test.js.map +2 -2
- package/test/overlay-trigger.test.js +1 -1
- package/test/overlay-trigger.test.js.map +2 -2
- package/test/overlay-update.test.js +4 -4
- package/test/overlay-update.test.js.map +2 -2
- package/test/overlay.test.js +237 -235
- package/test/overlay.test.js.map +3 -3
- package/active-overlay.d.ts +0 -6
- package/active-overlay.dev.js +0 -5
- package/active-overlay.js +0 -2
- package/custom-elements.json +0 -1203
- package/src/ActiveOverlay.d.ts +0 -84
- package/src/ActiveOverlay.dev.js +0 -517
- package/src/ActiveOverlay.dev.js.map +0 -7
- package/src/ActiveOverlay.js +0 -16
- package/src/ActiveOverlay.js.map +0 -7
- package/src/active-overlay.css.dev.js +0 -13
- package/src/active-overlay.css.dev.js.map +0 -7
- package/src/active-overlay.css.js +0 -10
- package/src/active-overlay.css.js.map +0 -7
- package/src/overlay-stack.d.ts +0 -50
- package/src/overlay-stack.dev.js +0 -514
- package/src/overlay-stack.dev.js.map +0 -7
- package/src/overlay-stack.js +0 -33
- package/src/overlay-stack.js.map +0 -7
- package/src/overlay-utils.d.ts +0 -3
- package/src/overlay-utils.dev.js +0 -31
- package/src/overlay-utils.dev.js.map +0 -7
- package/src/overlay-utils.js +0 -2
- package/src/overlay-utils.js.map +0 -7
- package/src/overlay.d.ts +0 -59
- package/src/overlay.dev.js +0 -127
- package/src/overlay.dev.js.map +0 -7
- package/src/overlay.js +0 -2
- package/src/overlay.js.map +0 -7
- /package/src/{active-overlay.css.d.ts → overlay-base.css.d.ts} +0 -0
|
@@ -16,69 +16,125 @@ import {
|
|
|
16
16
|
} from "@spectrum-web-components/base";
|
|
17
17
|
import {
|
|
18
18
|
property,
|
|
19
|
+
query,
|
|
19
20
|
state
|
|
20
21
|
} from "@spectrum-web-components/base/src/decorators.js";
|
|
21
|
-
import { firstFocusableIn } from "@spectrum-web-components/shared/src/first-focusable-in.js";
|
|
22
22
|
import {
|
|
23
23
|
isAndroid,
|
|
24
24
|
isIOS
|
|
25
25
|
} from "@spectrum-web-components/shared/src/platform.js";
|
|
26
|
-
import { openOverlay } from "./loader.dev.js";
|
|
27
26
|
import overlayTriggerStyles from "./overlay-trigger.css.js";
|
|
27
|
+
import "../sp-overlay.dev.js";
|
|
28
28
|
export const LONGPRESS_INSTRUCTIONS = {
|
|
29
29
|
touch: "Double tap and long press for additional options",
|
|
30
30
|
keyboard: "Press Space or Alt+Down Arrow for additional options",
|
|
31
31
|
mouse: "Click and hold for additional options"
|
|
32
32
|
};
|
|
33
|
-
|
|
33
|
+
export class OverlayTrigger extends SpectrumElement {
|
|
34
34
|
constructor() {
|
|
35
35
|
super(...arguments);
|
|
36
|
-
this.placement = "bottom";
|
|
37
36
|
this.offset = 6;
|
|
38
37
|
this.disabled = false;
|
|
39
38
|
this.hasLongpressContent = false;
|
|
39
|
+
this.clickContent = [];
|
|
40
|
+
this.longpressContent = [];
|
|
41
|
+
this.hoverContent = [];
|
|
42
|
+
this.targetContent = [];
|
|
40
43
|
this._longpressId = `longpress-describedby-descriptor`;
|
|
41
|
-
this.abortOverlay = () => {
|
|
42
|
-
return;
|
|
43
|
-
};
|
|
44
|
-
this.openStatePromise = Promise.resolve();
|
|
45
44
|
}
|
|
46
45
|
static get styles() {
|
|
47
46
|
return [overlayTriggerStyles];
|
|
48
47
|
}
|
|
49
|
-
|
|
50
|
-
|
|
48
|
+
getAssignedElementsFromSlot(slot) {
|
|
49
|
+
return slot.assignedElements({ flatten: true });
|
|
50
|
+
}
|
|
51
|
+
handleTriggerContent(event) {
|
|
52
|
+
this.targetContent = this.getAssignedElementsFromSlot(event.target);
|
|
53
|
+
}
|
|
54
|
+
handleClickContent(event) {
|
|
55
|
+
this.clickContent = this.getAssignedElementsFromSlot(event.target);
|
|
56
|
+
}
|
|
57
|
+
handleLongpressContent(event) {
|
|
58
|
+
this.longpressContent = this.getAssignedElementsFromSlot(event.target);
|
|
59
|
+
}
|
|
60
|
+
handleHoverContent(event) {
|
|
61
|
+
this.hoverContent = this.getAssignedElementsFromSlot(event.target);
|
|
62
|
+
}
|
|
63
|
+
handleBeforetoggle(event) {
|
|
64
|
+
const target = event.composedPath()[0];
|
|
65
|
+
let type;
|
|
66
|
+
if (target === this.clickOverlayElement) {
|
|
67
|
+
type = "click";
|
|
68
|
+
} else if (target === this.longpressOverlayElement) {
|
|
69
|
+
type = "longpress";
|
|
70
|
+
} else if (target === this.hoverOverlayElement) {
|
|
71
|
+
type = "hover";
|
|
72
|
+
} else {
|
|
51
73
|
return;
|
|
52
74
|
}
|
|
53
|
-
|
|
75
|
+
if (event.newState === "open") {
|
|
76
|
+
this.open = type;
|
|
77
|
+
} else if (this.open === type) {
|
|
78
|
+
this.open = void 0;
|
|
79
|
+
}
|
|
54
80
|
}
|
|
55
81
|
render() {
|
|
56
82
|
return html`
|
|
57
83
|
<slot
|
|
58
84
|
id="trigger"
|
|
59
|
-
@click=${this.onTrigger}
|
|
60
|
-
@longpress=${this.onTrigger}
|
|
61
|
-
@mouseenter=${this.onTrigger}
|
|
62
|
-
@mouseleave=${this.onTrigger}
|
|
63
|
-
@focusin=${this.onTrigger}
|
|
64
|
-
@focusout=${this.onTrigger}
|
|
65
|
-
@sp-closed=${this.handleClose}
|
|
66
|
-
@slotchange=${this.onTargetSlotChange}
|
|
67
85
|
name="trigger"
|
|
86
|
+
@slotchange=${this.handleTriggerContent}
|
|
68
87
|
></slot>
|
|
69
88
|
<div id="overlay-content">
|
|
70
|
-
<
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
@
|
|
80
|
-
|
|
81
|
-
|
|
89
|
+
<sp-overlay
|
|
90
|
+
id="click-overlay"
|
|
91
|
+
?disabled=${this.disabled || !this.clickContent.length}
|
|
92
|
+
?open=${this.open === "click" && !!this.clickContent.length}
|
|
93
|
+
.offset=${this.offset}
|
|
94
|
+
.placement=${this.placement}
|
|
95
|
+
.triggerElement=${this.targetContent[0]}
|
|
96
|
+
.triggerInteraction=${"click"}
|
|
97
|
+
.type=${this.type !== "modal" ? "auto" : "modal"}
|
|
98
|
+
@beforetoggle=${this.handleBeforetoggle}
|
|
99
|
+
>
|
|
100
|
+
<slot
|
|
101
|
+
name="click-content"
|
|
102
|
+
@slotchange=${this.handleClickContent}
|
|
103
|
+
></slot>
|
|
104
|
+
</sp-overlay>
|
|
105
|
+
<sp-overlay
|
|
106
|
+
id="longpress-overlay"
|
|
107
|
+
?disabled=${this.disabled || !this.longpressContent.length}
|
|
108
|
+
?open=${this.open === "longpress" && !!this.longpressContent.length}
|
|
109
|
+
.offset=${this.offset}
|
|
110
|
+
.placement=${this.placement}
|
|
111
|
+
.triggerElement=${this.targetContent[0]}
|
|
112
|
+
.triggerInteraction=${"longpress"}
|
|
113
|
+
.type=${"auto"}
|
|
114
|
+
@beforetoggle=${this.handleBeforetoggle}
|
|
115
|
+
>
|
|
116
|
+
<slot
|
|
117
|
+
name="longpress-content"
|
|
118
|
+
@slotchange=${this.handleLongpressContent}
|
|
119
|
+
></slot>
|
|
120
|
+
<slot name="longpress-describedby-descriptor"></slot>
|
|
121
|
+
</sp-overlay>
|
|
122
|
+
<sp-overlay
|
|
123
|
+
id="hover-overlay"
|
|
124
|
+
?disabled=${this.disabled || !this.hoverContent.length}
|
|
125
|
+
?open=${this.open === "hover" && !!this.hoverContent.length}
|
|
126
|
+
.offset=${this.offset}
|
|
127
|
+
.placement=${this.placement}
|
|
128
|
+
.triggerElement=${this.targetContent[0]}
|
|
129
|
+
.triggerInteraction=${"hover"}
|
|
130
|
+
.type=${"hint"}
|
|
131
|
+
@beforetoggle=${this.handleBeforetoggle}
|
|
132
|
+
>
|
|
133
|
+
<slot
|
|
134
|
+
name="hover-content"
|
|
135
|
+
@slotchange=${this.handleHoverContent}
|
|
136
|
+
></slot>
|
|
137
|
+
</sp-overlay>
|
|
82
138
|
<slot name=${this._longpressId}></slot>
|
|
83
139
|
</div>
|
|
84
140
|
`;
|
|
@@ -86,13 +142,10 @@ const _OverlayTrigger = class extends SpectrumElement {
|
|
|
86
142
|
updated(changes) {
|
|
87
143
|
super.updated(changes);
|
|
88
144
|
if (this.disabled && changes.has("disabled")) {
|
|
89
|
-
this.
|
|
145
|
+
this.open = void 0;
|
|
90
146
|
return;
|
|
91
147
|
}
|
|
92
|
-
if (changes.has("
|
|
93
|
-
this.manageOpen();
|
|
94
|
-
}
|
|
95
|
-
if (changes.has("hasLongpressContent")) {
|
|
148
|
+
if (changes.has("hasLongpressContent") && typeof changes.get("hasLongpressContent") !== "undefined") {
|
|
96
149
|
this.manageLongpressDescriptor();
|
|
97
150
|
}
|
|
98
151
|
}
|
|
@@ -127,219 +180,16 @@ const _OverlayTrigger = class extends SpectrumElement {
|
|
|
127
180
|
trigger.removeAttribute("aria-describedby");
|
|
128
181
|
}
|
|
129
182
|
}
|
|
130
|
-
closeAllOverlays() {
|
|
131
|
-
if (this.abortOverlay)
|
|
132
|
-
this.abortOverlay(true);
|
|
133
|
-
[
|
|
134
|
-
"closeClickOverlay",
|
|
135
|
-
"closeHoverOverlay",
|
|
136
|
-
"closeLongpressOverlay"
|
|
137
|
-
].forEach(async (name) => {
|
|
138
|
-
const canClose = this[name];
|
|
139
|
-
if (canClose == null)
|
|
140
|
-
return;
|
|
141
|
-
delete this[name];
|
|
142
|
-
(await canClose)();
|
|
143
|
-
});
|
|
144
|
-
this.overlaidContent = void 0;
|
|
145
|
-
}
|
|
146
|
-
manageOpen() {
|
|
147
|
-
var _a;
|
|
148
|
-
const openHandlers = {
|
|
149
|
-
click: () => this.onTriggerClick(),
|
|
150
|
-
hover: () => this.onTriggerMouseEnter(),
|
|
151
|
-
longpress: () => this.onTriggerLongpress(),
|
|
152
|
-
none: () => this.closeAllOverlays()
|
|
153
|
-
};
|
|
154
|
-
openHandlers[(_a = this.open) != null ? _a : "none"]();
|
|
155
|
-
}
|
|
156
|
-
async openOverlay(target, interaction, content, options) {
|
|
157
|
-
this.openStatePromise = new Promise(
|
|
158
|
-
(res) => this.openStateResolver = res
|
|
159
|
-
);
|
|
160
|
-
this.addEventListener(
|
|
161
|
-
"sp-opened",
|
|
162
|
-
() => {
|
|
163
|
-
this.openStateResolver();
|
|
164
|
-
},
|
|
165
|
-
{ once: true }
|
|
166
|
-
);
|
|
167
|
-
this.overlaidContent = content;
|
|
168
|
-
return _OverlayTrigger.openOverlay(
|
|
169
|
-
target,
|
|
170
|
-
interaction,
|
|
171
|
-
content,
|
|
172
|
-
options
|
|
173
|
-
);
|
|
174
|
-
}
|
|
175
|
-
get overlayOptions() {
|
|
176
|
-
return {
|
|
177
|
-
offset: this.offset,
|
|
178
|
-
placement: this.placement,
|
|
179
|
-
receivesFocus: !this.type || this.type === "inline" || this.open === "hover" ? void 0 : "auto"
|
|
180
|
-
};
|
|
181
|
-
}
|
|
182
|
-
onTrigger(event) {
|
|
183
|
-
const mouseIsEnteringHoverContent = event.type === "mouseleave" && this.open === "hover" && event.relatedTarget === this.overlaidContent;
|
|
184
|
-
if (mouseIsEnteringHoverContent && this.overlaidContent) {
|
|
185
|
-
this.overlaidContent.addEventListener(
|
|
186
|
-
"mouseleave",
|
|
187
|
-
(event2) => {
|
|
188
|
-
const mouseIsEnteringTrigger = event2.relatedTarget === this.targetContent;
|
|
189
|
-
if (mouseIsEnteringTrigger) {
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
this.onTrigger(
|
|
193
|
-
event2
|
|
194
|
-
);
|
|
195
|
-
},
|
|
196
|
-
{ once: true }
|
|
197
|
-
);
|
|
198
|
-
return;
|
|
199
|
-
}
|
|
200
|
-
if (this.disabled)
|
|
201
|
-
return;
|
|
202
|
-
switch (event.type) {
|
|
203
|
-
case "mouseenter":
|
|
204
|
-
case "focusin":
|
|
205
|
-
if (!this.open && this.hoverContent) {
|
|
206
|
-
this.open = "hover";
|
|
207
|
-
}
|
|
208
|
-
return;
|
|
209
|
-
case "mouseleave":
|
|
210
|
-
case "focusout":
|
|
211
|
-
if (this.open === "hover") {
|
|
212
|
-
this.handleClose();
|
|
213
|
-
}
|
|
214
|
-
return;
|
|
215
|
-
case "click":
|
|
216
|
-
if (this.clickContent) {
|
|
217
|
-
this.open = event.type;
|
|
218
|
-
}
|
|
219
|
-
return;
|
|
220
|
-
case "longpress":
|
|
221
|
-
if (this.longpressContent) {
|
|
222
|
-
this._longpressEvent = event;
|
|
223
|
-
this.open = event.type;
|
|
224
|
-
}
|
|
225
|
-
return;
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
prepareToFocusOverlayContent(overlayContent) {
|
|
229
|
-
if (this.type !== "modal") {
|
|
230
|
-
return;
|
|
231
|
-
}
|
|
232
|
-
const firstFocusable = firstFocusableIn(overlayContent);
|
|
233
|
-
if (!firstFocusable) {
|
|
234
|
-
overlayContent.tabIndex = 0;
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
async onTriggerClick() {
|
|
238
|
-
if (!this.targetContent || !this.clickContent || this.closeClickOverlay) {
|
|
239
|
-
return;
|
|
240
|
-
}
|
|
241
|
-
const { targetContent, clickContent } = this;
|
|
242
|
-
this.closeAllOverlays();
|
|
243
|
-
this.prepareToFocusOverlayContent(clickContent);
|
|
244
|
-
if (true) {
|
|
245
|
-
window.__swc.ignoreWarningLevels.deprecation = true;
|
|
246
|
-
}
|
|
247
|
-
this.closeClickOverlay = this.openOverlay(
|
|
248
|
-
targetContent,
|
|
249
|
-
this.type ? this.type : "click",
|
|
250
|
-
clickContent,
|
|
251
|
-
this.overlayOptions
|
|
252
|
-
);
|
|
253
|
-
if (true) {
|
|
254
|
-
window.__swc.ignoreWarningLevels.deprecation = false;
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
async onTriggerLongpress() {
|
|
258
|
-
var _a, _b;
|
|
259
|
-
if (!this.targetContent || !this.longpressContent || this.closeLongpressOverlay) {
|
|
260
|
-
return;
|
|
261
|
-
}
|
|
262
|
-
const { targetContent, longpressContent } = this;
|
|
263
|
-
this.closeAllOverlays();
|
|
264
|
-
this.prepareToFocusOverlayContent(longpressContent);
|
|
265
|
-
const notImmediatelyClosable = ((_b = (_a = this._longpressEvent) == null ? void 0 : _a.detail) == null ? void 0 : _b.source) !== "keyboard";
|
|
266
|
-
if (true) {
|
|
267
|
-
window.__swc.ignoreWarningLevels.deprecation = true;
|
|
268
|
-
}
|
|
269
|
-
this.closeLongpressOverlay = this.openOverlay(
|
|
270
|
-
targetContent,
|
|
271
|
-
this.type ? this.type : "longpress",
|
|
272
|
-
longpressContent,
|
|
273
|
-
{
|
|
274
|
-
...this.overlayOptions,
|
|
275
|
-
receivesFocus: "auto",
|
|
276
|
-
notImmediatelyClosable
|
|
277
|
-
}
|
|
278
|
-
);
|
|
279
|
-
if (true) {
|
|
280
|
-
window.__swc.ignoreWarningLevels.deprecation = false;
|
|
281
|
-
}
|
|
282
|
-
this._longpressEvent = void 0;
|
|
283
|
-
}
|
|
284
|
-
async onTriggerMouseEnter() {
|
|
285
|
-
if (!this.targetContent || !this.hoverContent || this.closeHoverOverlay) {
|
|
286
|
-
return;
|
|
287
|
-
}
|
|
288
|
-
const abortPromise = new Promise((res) => {
|
|
289
|
-
this.abortOverlay = res;
|
|
290
|
-
});
|
|
291
|
-
const { targetContent, hoverContent } = this;
|
|
292
|
-
if (true) {
|
|
293
|
-
window.__swc.ignoreWarningLevels.deprecation = true;
|
|
294
|
-
}
|
|
295
|
-
this.closeHoverOverlay = this.openOverlay(
|
|
296
|
-
targetContent,
|
|
297
|
-
"hover",
|
|
298
|
-
hoverContent,
|
|
299
|
-
{
|
|
300
|
-
abortPromise,
|
|
301
|
-
...this.overlayOptions
|
|
302
|
-
}
|
|
303
|
-
);
|
|
304
|
-
if (true) {
|
|
305
|
-
window.__swc.ignoreWarningLevels.deprecation = false;
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
onClickSlotChange(event) {
|
|
309
|
-
this.clickContent = this.extractSlotContentFromEvent(event);
|
|
310
|
-
this.manageOpen();
|
|
311
|
-
}
|
|
312
|
-
onLongpressSlotChange(event) {
|
|
313
|
-
this.longpressContent = this.extractSlotContentFromEvent(event);
|
|
314
|
-
this.hasLongpressContent = !!this.longpressContent || !!this.closeLongpressOverlay;
|
|
315
|
-
this.manageOpen();
|
|
316
|
-
}
|
|
317
|
-
onHoverSlotChange(event) {
|
|
318
|
-
this.hoverContent = this.extractSlotContentFromEvent(event);
|
|
319
|
-
this.manageOpen();
|
|
320
|
-
}
|
|
321
|
-
onTargetSlotChange(event) {
|
|
322
|
-
this.targetContent = this.extractSlotContentFromEvent(event);
|
|
323
|
-
}
|
|
324
|
-
extractSlotContentFromEvent(event) {
|
|
325
|
-
const slot = event.target;
|
|
326
|
-
const nodes = slot.assignedNodes({ flatten: true });
|
|
327
|
-
return nodes.find((node) => node instanceof HTMLElement);
|
|
328
|
-
}
|
|
329
183
|
async getUpdateComplete() {
|
|
330
184
|
const complete = await super.getUpdateComplete();
|
|
331
|
-
await this.openStatePromise;
|
|
332
185
|
return complete;
|
|
333
186
|
}
|
|
334
|
-
|
|
335
|
-
this.
|
|
336
|
-
|
|
187
|
+
willUpdate() {
|
|
188
|
+
if (this.placement === "none") {
|
|
189
|
+
this.placement = void 0;
|
|
190
|
+
}
|
|
337
191
|
}
|
|
338
|
-
}
|
|
339
|
-
export let OverlayTrigger = _OverlayTrigger;
|
|
340
|
-
OverlayTrigger.openOverlay = async (target, interaction, content, options) => {
|
|
341
|
-
return openOverlay(target, interaction, content, options);
|
|
342
|
-
};
|
|
192
|
+
}
|
|
343
193
|
__decorateClass([
|
|
344
194
|
property({ reflect: true })
|
|
345
195
|
], OverlayTrigger.prototype, "placement", 2);
|
|
@@ -347,7 +197,7 @@ __decorateClass([
|
|
|
347
197
|
property()
|
|
348
198
|
], OverlayTrigger.prototype, "type", 2);
|
|
349
199
|
__decorateClass([
|
|
350
|
-
property({ type: Number
|
|
200
|
+
property({ type: Number })
|
|
351
201
|
], OverlayTrigger.prototype, "offset", 2);
|
|
352
202
|
__decorateClass([
|
|
353
203
|
property({ reflect: true })
|
|
@@ -358,4 +208,25 @@ __decorateClass([
|
|
|
358
208
|
__decorateClass([
|
|
359
209
|
state()
|
|
360
210
|
], OverlayTrigger.prototype, "hasLongpressContent", 2);
|
|
211
|
+
__decorateClass([
|
|
212
|
+
state()
|
|
213
|
+
], OverlayTrigger.prototype, "clickContent", 2);
|
|
214
|
+
__decorateClass([
|
|
215
|
+
state()
|
|
216
|
+
], OverlayTrigger.prototype, "longpressContent", 2);
|
|
217
|
+
__decorateClass([
|
|
218
|
+
state()
|
|
219
|
+
], OverlayTrigger.prototype, "hoverContent", 2);
|
|
220
|
+
__decorateClass([
|
|
221
|
+
state()
|
|
222
|
+
], OverlayTrigger.prototype, "targetContent", 2);
|
|
223
|
+
__decorateClass([
|
|
224
|
+
query("#click-overlay", true)
|
|
225
|
+
], OverlayTrigger.prototype, "clickOverlayElement", 2);
|
|
226
|
+
__decorateClass([
|
|
227
|
+
query("#longpress-overlay", true)
|
|
228
|
+
], OverlayTrigger.prototype, "longpressOverlayElement", 2);
|
|
229
|
+
__decorateClass([
|
|
230
|
+
query("#hover-overlay", true)
|
|
231
|
+
], OverlayTrigger.prototype, "hoverOverlayElement", 2);
|
|
361
232
|
//# sourceMappingURL=OverlayTrigger.dev.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["OverlayTrigger.ts"],
|
|
4
|
-
"sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n state,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport type { LongpressEvent } from '@spectrum-web-components/action-button';\nimport { firstFocusableIn } from '@spectrum-web-components/shared/src/first-focusable-in.js';\nimport {\n isAndroid,\n isIOS,\n} from '@spectrum-web-components/shared/src/platform.js';\n\nimport {\n OverlayOpenCloseDetail,\n OverlayOptions,\n OverlayTriggerInteractions,\n Placement,\n TriggerInteractions,\n} from './overlay-types';\nimport { openOverlay } from './loader.dev.js'\nimport overlayTriggerStyles from './overlay-trigger.css.js';\n\nexport type OverlayContentTypes = 'click' | 'hover' | 'longpress';\n\ntype closeOverlay =\n | 'closeClickOverlay'\n | 'closeHoverOverlay'\n | 'closeLongpressOverlay';\n\nexport const LONGPRESS_INSTRUCTIONS = {\n touch: 'Double tap and long press for additional options',\n keyboard: 'Press Space or Alt+Down Arrow for additional options',\n mouse: 'Click and hold for additional options',\n};\n\n/**\n * @element overlay-trigger\n *\n * @slot trigger - The content that will trigger the various overlays\n * @slot hover-content - The content that will be displayed on hover\n * @slot click-content - The content that will be displayed on click\n * @slot longpress-content - The content that will be displayed on click\n *\n * @fires sp-opened - Announces that the overlay has been opened\n * @fires sp-closed - Announces that the overlay has been closed\n */\nexport class OverlayTrigger extends SpectrumElement {\n private closeClickOverlay?: Promise<() => void>;\n private closeLongpressOverlay?: Promise<() => void>;\n private closeHoverOverlay?: Promise<() => void>;\n\n public static override get styles(): CSSResultArray {\n return [overlayTriggerStyles];\n }\n\n /**\n * @type {\"auto\" | \"auto-start\" | \"auto-end\" | \"top\" | \"bottom\" | \"right\" | \"left\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"right-start\" | \"right-end\" | \"left-start\" | \"left-end\" | \"none\"}\n * @attr\n */\n @property({ reflect: true })\n public placement: Placement = 'bottom';\n\n @property()\n public type?: OverlayTriggerInteractions;\n\n @property({ type: Number, reflect: true })\n public offset = 6;\n\n @property({ reflect: true })\n public open?: OverlayContentTypes;\n\n @property({ type: Boolean, reflect: true })\n public disabled = false;\n\n @state()\n public hasLongpressContent = false;\n\n private longpressDescriptor?: HTMLElement;\n private clickContent?: HTMLElement;\n private longpressContent?: HTMLElement;\n private hoverContent?: HTMLElement;\n private targetContent?: HTMLElement;\n private overlaidContent?: HTMLElement;\n\n private _longpressId = `longpress-describedby-descriptor`;\n\n private handleClose(event?: CustomEvent<OverlayOpenCloseDetail>): void {\n if (\n event &&\n event.detail.interaction !== this.open &&\n event.detail.interaction !== this.type\n ) {\n return;\n }\n this.removeAttribute('open');\n }\n\n protected override render(): TemplateResult {\n // Keyboard event availability documented in README.md\n /* eslint-disable lit-a11y/click-events-have-key-events */\n return html`\n <slot\n id=\"trigger\"\n @click=${this.onTrigger}\n @longpress=${this.onTrigger}\n @mouseenter=${this.onTrigger}\n @mouseleave=${this.onTrigger}\n @focusin=${this.onTrigger}\n @focusout=${this.onTrigger}\n @sp-closed=${this.handleClose}\n @slotchange=${this.onTargetSlotChange}\n name=\"trigger\"\n ></slot>\n <div id=\"overlay-content\">\n <slot\n @slotchange=${this.onClickSlotChange}\n name=\"click-content\"\n ></slot>\n <slot\n @slotchange=${this.onLongpressSlotChange}\n name=\"longpress-content\"\n ></slot>\n <slot\n @slotchange=${this.onHoverSlotChange}\n name=\"hover-content\"\n ></slot>\n <slot name=${this._longpressId}></slot>\n </div>\n `;\n /* eslint-enable lit-a11y/click-events-have-key-events */\n }\n\n protected override updated(changes: PropertyValues<this>): void {\n super.updated(changes);\n if (this.disabled && changes.has('disabled')) {\n this.closeAllOverlays();\n return;\n }\n if (changes.has('open')) {\n this.manageOpen();\n }\n if (changes.has('hasLongpressContent')) {\n this.manageLongpressDescriptor();\n }\n }\n\n protected manageLongpressDescriptor(): void {\n const trigger = this.querySelector(\n '[slot=\"trigger\"]'\n ) as SpectrumElement;\n const ariaDescribedby = trigger.getAttribute('aria-describedby');\n let descriptors = ariaDescribedby ? ariaDescribedby.split(/\\s+/) : [];\n\n if (this.hasLongpressContent) {\n if (!this.longpressDescriptor) {\n this.longpressDescriptor = document.createElement(\n 'div'\n ) as HTMLElement;\n\n this.longpressDescriptor.id = this._longpressId;\n this.longpressDescriptor.slot = this._longpressId;\n }\n const messageType = isIOS() || isAndroid() ? 'touch' : 'keyboard';\n this.longpressDescriptor.textContent =\n LONGPRESS_INSTRUCTIONS[messageType];\n this.appendChild(this.longpressDescriptor);\n descriptors.push(this._longpressId);\n } else {\n if (this.longpressDescriptor) this.longpressDescriptor.remove();\n descriptors = descriptors.filter(\n (descriptor) => descriptor !== this._longpressId\n );\n }\n if (descriptors.length) {\n trigger.setAttribute('aria-describedby', descriptors.join(' '));\n } else {\n trigger.removeAttribute('aria-describedby');\n }\n }\n\n private closeAllOverlays(): void {\n if (this.abortOverlay) this.abortOverlay(true);\n (\n [\n 'closeClickOverlay',\n 'closeHoverOverlay',\n 'closeLongpressOverlay',\n ] as closeOverlay[]\n ).forEach(async (name) => {\n const canClose = this[name] as Promise<() => void>;\n if (canClose == null) return;\n delete this[name];\n (await canClose)();\n });\n this.overlaidContent = undefined;\n }\n\n private manageOpen(): void {\n const openHandlers: Record<OverlayContentTypes | 'none', () => void> = {\n click: () => this.onTriggerClick(),\n hover: () => this.onTriggerMouseEnter(),\n longpress: () => this.onTriggerLongpress(),\n none: () => this.closeAllOverlays(),\n };\n openHandlers[this.open ?? 'none']();\n }\n\n private async openOverlay(\n target: HTMLElement,\n interaction: TriggerInteractions,\n content: HTMLElement,\n options: OverlayOptions\n ): Promise<() => void> {\n this.openStatePromise = new Promise(\n (res) => (this.openStateResolver = res)\n );\n this.addEventListener(\n 'sp-opened',\n () => {\n this.openStateResolver();\n },\n { once: true }\n );\n this.overlaidContent = content;\n return OverlayTrigger.openOverlay(\n target,\n interaction,\n content,\n options\n );\n }\n\n public static openOverlay = async (\n target: HTMLElement,\n interaction: TriggerInteractions,\n content: HTMLElement,\n options: OverlayOptions\n ): Promise<() => void> => {\n return openOverlay(target, interaction, content, options);\n };\n\n private get overlayOptions(): OverlayOptions {\n return {\n offset: this.offset,\n placement: this.placement,\n receivesFocus:\n !this.type || this.type === 'inline' || this.open === 'hover'\n ? undefined\n : 'auto',\n };\n }\n\n private onTrigger(event: CustomEvent<LongpressEvent>): void {\n const mouseIsEnteringHoverContent =\n event.type === 'mouseleave' &&\n this.open === 'hover' &&\n (event as unknown as MouseEvent).relatedTarget ===\n this.overlaidContent;\n if (mouseIsEnteringHoverContent && this.overlaidContent) {\n this.overlaidContent.addEventListener(\n 'mouseleave',\n (event: MouseEvent) => {\n const mouseIsEnteringTrigger =\n event.relatedTarget === this.targetContent;\n if (mouseIsEnteringTrigger) {\n return;\n }\n this.onTrigger(\n event as unknown as CustomEvent<LongpressEvent>\n );\n },\n { once: true }\n );\n return;\n }\n if (this.disabled) return;\n\n switch (event.type) {\n case 'mouseenter':\n case 'focusin':\n if (!this.open && this.hoverContent) {\n this.open = 'hover';\n }\n return;\n case 'mouseleave':\n case 'focusout':\n if (this.open === 'hover') {\n this.handleClose();\n }\n return;\n case 'click':\n if (this.clickContent) {\n this.open = event.type;\n }\n return;\n case 'longpress':\n if (this.longpressContent) {\n this._longpressEvent = event;\n this.open = event.type;\n }\n return;\n }\n }\n\n private prepareToFocusOverlayContent(overlayContent: HTMLElement): void {\n if (this.type !== 'modal') {\n return;\n }\n const firstFocusable = firstFocusableIn(overlayContent);\n if (!firstFocusable) {\n overlayContent.tabIndex = 0;\n }\n }\n\n public async onTriggerClick(): Promise<void> {\n if (\n !this.targetContent ||\n !this.clickContent ||\n this.closeClickOverlay\n ) {\n return;\n }\n const { targetContent, clickContent } = this;\n this.closeAllOverlays();\n this.prepareToFocusOverlayContent(clickContent);\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = true;\n }\n this.closeClickOverlay = this.openOverlay(\n targetContent,\n this.type ? this.type : 'click',\n clickContent,\n this.overlayOptions\n );\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = false;\n }\n }\n\n private _longpressEvent?: CustomEvent<LongpressEvent>;\n\n private async onTriggerLongpress(): Promise<void> {\n if (\n !this.targetContent ||\n !this.longpressContent ||\n this.closeLongpressOverlay\n ) {\n return;\n }\n const { targetContent, longpressContent } = this;\n this.closeAllOverlays();\n this.prepareToFocusOverlayContent(longpressContent);\n const notImmediatelyClosable =\n this._longpressEvent?.detail?.source !== 'keyboard';\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = true;\n }\n this.closeLongpressOverlay = this.openOverlay(\n targetContent,\n this.type ? this.type : 'longpress',\n longpressContent,\n {\n ...this.overlayOptions,\n receivesFocus: 'auto',\n notImmediatelyClosable,\n }\n );\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = false;\n }\n this._longpressEvent = undefined;\n }\n\n private abortOverlay: (cancelled: boolean) => void = () => {\n return;\n };\n\n public async onTriggerMouseEnter(): Promise<void> {\n if (\n !this.targetContent ||\n !this.hoverContent ||\n this.closeHoverOverlay\n ) {\n return;\n }\n const abortPromise: Promise<boolean> = new Promise((res) => {\n this.abortOverlay = res;\n });\n const { targetContent, hoverContent } = this;\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = true;\n }\n this.closeHoverOverlay = this.openOverlay(\n targetContent,\n 'hover',\n hoverContent,\n {\n abortPromise,\n ...this.overlayOptions,\n }\n );\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = false;\n }\n }\n\n private onClickSlotChange(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.clickContent = this.extractSlotContentFromEvent(event);\n this.manageOpen();\n }\n\n private onLongpressSlotChange(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.longpressContent = this.extractSlotContentFromEvent(event);\n this.hasLongpressContent =\n !!this.longpressContent || !!this.closeLongpressOverlay;\n this.manageOpen();\n }\n\n private onHoverSlotChange(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.hoverContent = this.extractSlotContentFromEvent(event);\n this.manageOpen();\n }\n\n private onTargetSlotChange(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.targetContent = this.extractSlotContentFromEvent(event);\n }\n\n private extractSlotContentFromEvent(event: Event): HTMLElement | undefined {\n const slot = event.target as HTMLSlotElement;\n const nodes = slot.assignedNodes({ flatten: true });\n return nodes.find((node) => node instanceof HTMLElement) as HTMLElement;\n }\n\n private openStatePromise = Promise.resolve();\n private openStateResolver!: () => void;\n\n protected override async getUpdateComplete(): Promise<boolean> {\n const complete = (await super.getUpdateComplete()) as boolean;\n await this.openStatePromise;\n return complete;\n }\n\n public override disconnectedCallback(): void {\n this.closeAllOverlays();\n super.disconnectedCallback();\n }\n}\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;AAYA;AAAA,EAEI;AAAA,EAEA;AAAA,OAEG;AACP;AAAA,EACI;AAAA,EACA;AAAA,
|
|
6
|
-
"names": [
|
|
4
|
+
"sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n state,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport {\n isAndroid,\n isIOS,\n} from '@spectrum-web-components/shared/src/platform.js';\n\nimport { OverlayTriggerInteractions } from './overlay-types';\nimport overlayTriggerStyles from './overlay-trigger.css.js';\nimport '../sp-overlay.dev.js'\nimport { Placement } from '@floating-ui/dom';\nimport { BeforetoggleOpenEvent, OverlayBase } from './OverlayBase.dev.js'\n\nexport type OverlayContentTypes = 'click' | 'hover' | 'longpress';\n\nexport const LONGPRESS_INSTRUCTIONS = {\n touch: 'Double tap and long press for additional options',\n keyboard: 'Press Space or Alt+Down Arrow for additional options',\n mouse: 'Click and hold for additional options',\n};\n\n/**\n * @element overlay-trigger\n *\n * @slot trigger - The content that will trigger the various overlays\n * @slot hover-content - The content that will be displayed on hover\n * @slot click-content - The content that will be displayed on click\n * @slot longpress-content - The content that will be displayed on click\n *\n * @fires sp-opened - Announces that the overlay has been opened\n * @fires sp-closed - Announces that the overlay has been closed\n */\nexport class OverlayTrigger extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [overlayTriggerStyles];\n }\n\n /**\n * @type {\"auto\" | \"auto-start\" | \"auto-end\" | \"top\" | \"bottom\" | \"right\" | \"left\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"right-start\" | \"right-end\" | \"left-start\" | \"left-end\" | \"none\"}\n * @attr\n */\n @property({ reflect: true })\n public placement?: Placement;\n\n @property()\n public type?: OverlayTriggerInteractions;\n\n @property({ type: Number })\n public offset = 6;\n\n @property({ reflect: true })\n public open?: OverlayContentTypes;\n\n @property({ type: Boolean, reflect: true })\n public disabled = false;\n\n @state()\n public hasLongpressContent = false;\n\n private longpressDescriptor?: HTMLElement;\n\n @state()\n private clickContent: HTMLElement[] = [];\n\n @state()\n private longpressContent: HTMLElement[] = [];\n\n @state()\n private hoverContent: HTMLElement[] = [];\n\n @state()\n private targetContent: HTMLElement[] = [];\n\n @query('#click-overlay', true)\n clickOverlayElement!: OverlayBase;\n\n @query('#longpress-overlay', true)\n longpressOverlayElement!: OverlayBase;\n\n @query('#hover-overlay', true)\n hoverOverlayElement!: OverlayBase;\n\n private _longpressId = `longpress-describedby-descriptor`;\n\n private getAssignedElementsFromSlot(slot: HTMLSlotElement): HTMLElement[] {\n return slot.assignedElements({ flatten: true }) as HTMLElement[];\n }\n\n private handleTriggerContent(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.targetContent = this.getAssignedElementsFromSlot(event.target);\n }\n\n private handleClickContent(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.clickContent = this.getAssignedElementsFromSlot(event.target);\n }\n\n private handleLongpressContent(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.longpressContent = this.getAssignedElementsFromSlot(event.target);\n }\n\n private handleHoverContent(\n event: Event & { target: HTMLSlotElement }\n ): void {\n this.hoverContent = this.getAssignedElementsFromSlot(event.target);\n }\n\n private handleBeforetoggle(event: BeforetoggleOpenEvent): void {\n const target = event.composedPath()[0];\n let type: OverlayContentTypes;\n if (target === this.clickOverlayElement) {\n type = 'click';\n } else if (target === this.longpressOverlayElement) {\n type = 'longpress';\n } else if (target === this.hoverOverlayElement) {\n type = 'hover';\n } else {\n return;\n }\n if (event.newState === 'open') {\n this.open = type;\n } else if (this.open === type) {\n this.open = undefined;\n }\n }\n\n protected override render(): TemplateResult {\n // Keyboard event availability documented in README.md\n /* eslint-disable lit-a11y/click-events-have-key-events */\n return html`\n <slot\n id=\"trigger\"\n name=\"trigger\"\n @slotchange=${this.handleTriggerContent}\n ></slot>\n <div id=\"overlay-content\">\n <sp-overlay\n id=\"click-overlay\"\n ?disabled=${this.disabled || !this.clickContent.length}\n ?open=${this.open === 'click' && !!this.clickContent.length}\n .offset=${this.offset}\n .placement=${this.placement}\n .triggerElement=${this.targetContent[0]}\n .triggerInteraction=${'click'}\n .type=${this.type !== 'modal' ? 'auto' : 'modal'}\n @beforetoggle=${this.handleBeforetoggle}\n >\n <slot\n name=\"click-content\"\n @slotchange=${this.handleClickContent}\n ></slot>\n </sp-overlay>\n <sp-overlay\n id=\"longpress-overlay\"\n ?disabled=${this.disabled || !this.longpressContent.length}\n ?open=${this.open === 'longpress' &&\n !!this.longpressContent.length}\n .offset=${this.offset}\n .placement=${this.placement}\n .triggerElement=${this.targetContent[0]}\n .triggerInteraction=${'longpress'}\n .type=${'auto'}\n @beforetoggle=${this.handleBeforetoggle}\n >\n <slot\n name=\"longpress-content\"\n @slotchange=${this.handleLongpressContent}\n ></slot>\n <slot name=\"longpress-describedby-descriptor\"></slot>\n </sp-overlay>\n <sp-overlay\n id=\"hover-overlay\"\n ?disabled=${this.disabled || !this.hoverContent.length}\n ?open=${this.open === 'hover' && !!this.hoverContent.length}\n .offset=${this.offset}\n .placement=${this.placement}\n .triggerElement=${this.targetContent[0]}\n .triggerInteraction=${'hover'}\n .type=${'hint'}\n @beforetoggle=${this.handleBeforetoggle}\n >\n <slot\n name=\"hover-content\"\n @slotchange=${this.handleHoverContent}\n ></slot>\n </sp-overlay>\n <slot name=${this._longpressId}></slot>\n </div>\n `;\n /* eslint-enable lit-a11y/click-events-have-key-events */\n }\n\n protected override updated(changes: PropertyValues<this>): void {\n super.updated(changes);\n if (this.disabled && changes.has('disabled')) {\n this.open = undefined;\n return;\n }\n if (\n changes.has('hasLongpressContent') &&\n typeof changes.get('hasLongpressContent') !== 'undefined'\n ) {\n this.manageLongpressDescriptor();\n }\n }\n\n protected manageLongpressDescriptor(): void {\n const trigger = this.querySelector(\n '[slot=\"trigger\"]'\n ) as SpectrumElement;\n const ariaDescribedby = trigger.getAttribute('aria-describedby');\n let descriptors = ariaDescribedby ? ariaDescribedby.split(/\\s+/) : [];\n\n if (this.hasLongpressContent) {\n if (!this.longpressDescriptor) {\n this.longpressDescriptor = document.createElement(\n 'div'\n ) as HTMLElement;\n\n this.longpressDescriptor.id = this._longpressId;\n this.longpressDescriptor.slot = this._longpressId;\n }\n const messageType = isIOS() || isAndroid() ? 'touch' : 'keyboard';\n this.longpressDescriptor.textContent =\n LONGPRESS_INSTRUCTIONS[messageType];\n this.appendChild(this.longpressDescriptor);\n descriptors.push(this._longpressId);\n } else {\n if (this.longpressDescriptor) this.longpressDescriptor.remove();\n descriptors = descriptors.filter(\n (descriptor) => descriptor !== this._longpressId\n );\n }\n if (descriptors.length) {\n trigger.setAttribute('aria-describedby', descriptors.join(' '));\n } else {\n trigger.removeAttribute('aria-describedby');\n }\n }\n\n protected override async getUpdateComplete(): Promise<boolean> {\n const complete = (await super.getUpdateComplete()) as boolean;\n return complete;\n }\n\n protected override willUpdate(): void {\n if ((this.placement as unknown as 'none') === 'none') {\n this.placement = undefined;\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
7
|
}
|
package/src/OverlayTrigger.js
CHANGED
|
@@ -1,30 +1,60 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var h=Object.defineProperty;var c=Object.getOwnPropertyDescriptor;var o=(a,r,e,s)=>{for(var t=s>1?void 0:s?c(r,e):r,n=a.length-1,p;n>=0;n--)(p=a[n])&&(t=(s?p(r,e,t):p(t))||t);return s&&t&&h(r,e,t),t};import{html as g,SpectrumElement as m}from"@spectrum-web-components/base";import{property as l,query as d,state as i}from"@spectrum-web-components/base/src/decorators.js";import{isAndroid as v,isIOS as f}from"@spectrum-web-components/shared/src/platform.js";import u from"./overlay-trigger.css.js";import"../sp-overlay.js";export const LONGPRESS_INSTRUCTIONS={touch:"Double tap and long press for additional options",keyboard:"Press Space or Alt+Down Arrow for additional options",mouse:"Click and hold for additional options"};export class OverlayTrigger extends m{constructor(){super(...arguments);this.offset=6;this.disabled=!1;this.hasLongpressContent=!1;this.clickContent=[];this.longpressContent=[];this.hoverContent=[];this.targetContent=[];this._longpressId="longpress-describedby-descriptor"}static get styles(){return[u]}getAssignedElementsFromSlot(e){return e.assignedElements({flatten:!0})}handleTriggerContent(e){this.targetContent=this.getAssignedElementsFromSlot(e.target)}handleClickContent(e){this.clickContent=this.getAssignedElementsFromSlot(e.target)}handleLongpressContent(e){this.longpressContent=this.getAssignedElementsFromSlot(e.target)}handleHoverContent(e){this.hoverContent=this.getAssignedElementsFromSlot(e.target)}handleBeforetoggle(e){const s=e.composedPath()[0];let t;if(s===this.clickOverlayElement)t="click";else if(s===this.longpressOverlayElement)t="longpress";else if(s===this.hoverOverlayElement)t="hover";else return;e.newState==="open"?this.open=t:this.open===t&&(this.open=void 0)}render(){return g`
|
|
2
2
|
<slot
|
|
3
3
|
id="trigger"
|
|
4
|
-
@click=${this.onTrigger}
|
|
5
|
-
@longpress=${this.onTrigger}
|
|
6
|
-
@mouseenter=${this.onTrigger}
|
|
7
|
-
@mouseleave=${this.onTrigger}
|
|
8
|
-
@focusin=${this.onTrigger}
|
|
9
|
-
@focusout=${this.onTrigger}
|
|
10
|
-
@sp-closed=${this.handleClose}
|
|
11
|
-
@slotchange=${this.onTargetSlotChange}
|
|
12
4
|
name="trigger"
|
|
5
|
+
@slotchange=${this.handleTriggerContent}
|
|
13
6
|
></slot>
|
|
14
7
|
<div id="overlay-content">
|
|
15
|
-
<
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
@
|
|
25
|
-
|
|
26
|
-
|
|
8
|
+
<sp-overlay
|
|
9
|
+
id="click-overlay"
|
|
10
|
+
?disabled=${this.disabled||!this.clickContent.length}
|
|
11
|
+
?open=${this.open==="click"&&!!this.clickContent.length}
|
|
12
|
+
.offset=${this.offset}
|
|
13
|
+
.placement=${this.placement}
|
|
14
|
+
.triggerElement=${this.targetContent[0]}
|
|
15
|
+
.triggerInteraction=${"click"}
|
|
16
|
+
.type=${this.type!=="modal"?"auto":"modal"}
|
|
17
|
+
@beforetoggle=${this.handleBeforetoggle}
|
|
18
|
+
>
|
|
19
|
+
<slot
|
|
20
|
+
name="click-content"
|
|
21
|
+
@slotchange=${this.handleClickContent}
|
|
22
|
+
></slot>
|
|
23
|
+
</sp-overlay>
|
|
24
|
+
<sp-overlay
|
|
25
|
+
id="longpress-overlay"
|
|
26
|
+
?disabled=${this.disabled||!this.longpressContent.length}
|
|
27
|
+
?open=${this.open==="longpress"&&!!this.longpressContent.length}
|
|
28
|
+
.offset=${this.offset}
|
|
29
|
+
.placement=${this.placement}
|
|
30
|
+
.triggerElement=${this.targetContent[0]}
|
|
31
|
+
.triggerInteraction=${"longpress"}
|
|
32
|
+
.type=${"auto"}
|
|
33
|
+
@beforetoggle=${this.handleBeforetoggle}
|
|
34
|
+
>
|
|
35
|
+
<slot
|
|
36
|
+
name="longpress-content"
|
|
37
|
+
@slotchange=${this.handleLongpressContent}
|
|
38
|
+
></slot>
|
|
39
|
+
<slot name="longpress-describedby-descriptor"></slot>
|
|
40
|
+
</sp-overlay>
|
|
41
|
+
<sp-overlay
|
|
42
|
+
id="hover-overlay"
|
|
43
|
+
?disabled=${this.disabled||!this.hoverContent.length}
|
|
44
|
+
?open=${this.open==="hover"&&!!this.hoverContent.length}
|
|
45
|
+
.offset=${this.offset}
|
|
46
|
+
.placement=${this.placement}
|
|
47
|
+
.triggerElement=${this.targetContent[0]}
|
|
48
|
+
.triggerInteraction=${"hover"}
|
|
49
|
+
.type=${"hint"}
|
|
50
|
+
@beforetoggle=${this.handleBeforetoggle}
|
|
51
|
+
>
|
|
52
|
+
<slot
|
|
53
|
+
name="hover-content"
|
|
54
|
+
@slotchange=${this.handleHoverContent}
|
|
55
|
+
></slot>
|
|
56
|
+
</sp-overlay>
|
|
27
57
|
<slot name=${this._longpressId}></slot>
|
|
28
58
|
</div>
|
|
29
|
-
`}updated(e){if(super.updated(e),this.disabled&&e.has("disabled")){this.
|
|
59
|
+
`}updated(e){if(super.updated(e),this.disabled&&e.has("disabled")){this.open=void 0;return}e.has("hasLongpressContent")&&typeof e.get("hasLongpressContent")!="undefined"&&this.manageLongpressDescriptor()}manageLongpressDescriptor(){const e=this.querySelector('[slot="trigger"]'),s=e.getAttribute("aria-describedby");let t=s?s.split(/\s+/):[];if(this.hasLongpressContent){this.longpressDescriptor||(this.longpressDescriptor=document.createElement("div"),this.longpressDescriptor.id=this._longpressId,this.longpressDescriptor.slot=this._longpressId);const n=f()||v()?"touch":"keyboard";this.longpressDescriptor.textContent=LONGPRESS_INSTRUCTIONS[n],this.appendChild(this.longpressDescriptor),t.push(this._longpressId)}else this.longpressDescriptor&&this.longpressDescriptor.remove(),t=t.filter(n=>n!==this._longpressId);t.length?e.setAttribute("aria-describedby",t.join(" ")):e.removeAttribute("aria-describedby")}async getUpdateComplete(){return await super.getUpdateComplete()}willUpdate(){this.placement==="none"&&(this.placement=void 0)}}o([l({reflect:!0})],OverlayTrigger.prototype,"placement",2),o([l()],OverlayTrigger.prototype,"type",2),o([l({type:Number})],OverlayTrigger.prototype,"offset",2),o([l({reflect:!0})],OverlayTrigger.prototype,"open",2),o([l({type:Boolean,reflect:!0})],OverlayTrigger.prototype,"disabled",2),o([i()],OverlayTrigger.prototype,"hasLongpressContent",2),o([i()],OverlayTrigger.prototype,"clickContent",2),o([i()],OverlayTrigger.prototype,"longpressContent",2),o([i()],OverlayTrigger.prototype,"hoverContent",2),o([i()],OverlayTrigger.prototype,"targetContent",2),o([d("#click-overlay",!0)],OverlayTrigger.prototype,"clickOverlayElement",2),o([d("#longpress-overlay",!0)],OverlayTrigger.prototype,"longpressOverlayElement",2),o([d("#hover-overlay",!0)],OverlayTrigger.prototype,"hoverOverlayElement",2);
|
|
30
60
|
//# sourceMappingURL=OverlayTrigger.js.map
|