@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
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@spectrum-web-components/overlay",
|
|
3
|
-
"version": "0.30.
|
|
3
|
+
"version": "0.30.1-overlay.30+1df211c75",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -25,19 +25,46 @@
|
|
|
25
25
|
"default": "./src/index.js"
|
|
26
26
|
},
|
|
27
27
|
"./package.json": "./package.json",
|
|
28
|
-
"./src/
|
|
29
|
-
"development": "./src/
|
|
30
|
-
"default": "./src/
|
|
28
|
+
"./src/Overlay.js": {
|
|
29
|
+
"development": "./src/Overlay.dev.js",
|
|
30
|
+
"default": "./src/Overlay.js"
|
|
31
|
+
},
|
|
32
|
+
"./src/OverlayBase.js": {
|
|
33
|
+
"development": "./src/OverlayBase.dev.js",
|
|
34
|
+
"default": "./src/OverlayBase.js"
|
|
35
|
+
},
|
|
36
|
+
"./src/OverlayDialog.js": {
|
|
37
|
+
"development": "./src/OverlayDialog.dev.js",
|
|
38
|
+
"default": "./src/OverlayDialog.js"
|
|
39
|
+
},
|
|
40
|
+
"./src/OverlayNoPopover.js": {
|
|
41
|
+
"development": "./src/OverlayNoPopover.dev.js",
|
|
42
|
+
"default": "./src/OverlayNoPopover.js"
|
|
43
|
+
},
|
|
44
|
+
"./src/OverlayPopover.js": {
|
|
45
|
+
"development": "./src/OverlayPopover.dev.js",
|
|
46
|
+
"default": "./src/OverlayPopover.js"
|
|
47
|
+
},
|
|
48
|
+
"./src/OverlayStack.js": {
|
|
49
|
+
"development": "./src/OverlayStack.dev.js",
|
|
50
|
+
"default": "./src/OverlayStack.js"
|
|
31
51
|
},
|
|
32
52
|
"./src/OverlayTrigger.js": {
|
|
33
53
|
"development": "./src/OverlayTrigger.dev.js",
|
|
34
54
|
"default": "./src/OverlayTrigger.js"
|
|
35
55
|
},
|
|
56
|
+
"./src/PlacementController.js": {
|
|
57
|
+
"development": "./src/PlacementController.dev.js",
|
|
58
|
+
"default": "./src/PlacementController.js"
|
|
59
|
+
},
|
|
36
60
|
"./src/VirtualTrigger.js": {
|
|
37
61
|
"development": "./src/VirtualTrigger.dev.js",
|
|
38
62
|
"default": "./src/VirtualTrigger.js"
|
|
39
63
|
},
|
|
40
|
-
"./src/
|
|
64
|
+
"./src/fullSizePlugin.js": {
|
|
65
|
+
"development": "./src/fullSizePlugin.dev.js",
|
|
66
|
+
"default": "./src/fullSizePlugin.js"
|
|
67
|
+
},
|
|
41
68
|
"./src/index.js": {
|
|
42
69
|
"development": "./src/index.dev.js",
|
|
43
70
|
"default": "./src/index.js"
|
|
@@ -46,14 +73,11 @@
|
|
|
46
73
|
"development": "./src/loader.dev.js",
|
|
47
74
|
"default": "./src/loader.js"
|
|
48
75
|
},
|
|
76
|
+
"./src/overlay-base.css.js": "./src/overlay-base.css.js",
|
|
49
77
|
"./src/overlay-events.js": {
|
|
50
78
|
"development": "./src/overlay-events.dev.js",
|
|
51
79
|
"default": "./src/overlay-events.js"
|
|
52
80
|
},
|
|
53
|
-
"./src/overlay-stack.js": {
|
|
54
|
-
"development": "./src/overlay-stack.dev.js",
|
|
55
|
-
"default": "./src/overlay-stack.js"
|
|
56
|
-
},
|
|
57
81
|
"./src/overlay-timer.js": {
|
|
58
82
|
"development": "./src/overlay-timer.dev.js",
|
|
59
83
|
"default": "./src/overlay-timer.js"
|
|
@@ -63,13 +87,13 @@
|
|
|
63
87
|
"development": "./src/overlay-types.dev.js",
|
|
64
88
|
"default": "./src/overlay-types.js"
|
|
65
89
|
},
|
|
66
|
-
"./src/
|
|
67
|
-
"development": "./src/
|
|
68
|
-
"default": "./src/
|
|
90
|
+
"./src/placement.js": {
|
|
91
|
+
"development": "./src/placement.dev.js",
|
|
92
|
+
"default": "./src/placement.js"
|
|
69
93
|
},
|
|
70
|
-
"./src/
|
|
71
|
-
"development": "./src/
|
|
72
|
-
"default": "./src/
|
|
94
|
+
"./src/topLayerOverTransforms.js": {
|
|
95
|
+
"development": "./src/topLayerOverTransforms.dev.js",
|
|
96
|
+
"default": "./src/topLayerOverTransforms.js"
|
|
73
97
|
},
|
|
74
98
|
"./active-overlay.js": {
|
|
75
99
|
"development": "./active-overlay.dev.js",
|
|
@@ -82,6 +106,10 @@
|
|
|
82
106
|
"./sync/overlay-trigger.js": {
|
|
83
107
|
"development": "./sync/overlay-trigger.dev.js",
|
|
84
108
|
"default": "./sync/overlay-trigger.js"
|
|
109
|
+
},
|
|
110
|
+
"./sp-overlay.js": {
|
|
111
|
+
"development": "./sp-overlay.dev.js",
|
|
112
|
+
"default": "./sp-overlay.js"
|
|
85
113
|
}
|
|
86
114
|
},
|
|
87
115
|
"scripts": {
|
|
@@ -102,20 +130,21 @@
|
|
|
102
130
|
"lit-html"
|
|
103
131
|
],
|
|
104
132
|
"dependencies": {
|
|
105
|
-
"@floating-ui/dom": "^1.2.
|
|
106
|
-
"@spectrum-web-components/action-button": "^0.30.
|
|
107
|
-
"@spectrum-web-components/base": "^0.30.
|
|
108
|
-
"@spectrum-web-components/shared": "^0.30.
|
|
109
|
-
"@spectrum-web-components/theme": "^0.30.
|
|
133
|
+
"@floating-ui/dom": "^1.2.7",
|
|
134
|
+
"@spectrum-web-components/action-button": "^0.30.1-overlay.30+1df211c75",
|
|
135
|
+
"@spectrum-web-components/base": "^0.30.1-overlay.30+1df211c75",
|
|
136
|
+
"@spectrum-web-components/shared": "^0.30.1-overlay.30+1df211c75",
|
|
137
|
+
"@spectrum-web-components/theme": "^0.30.1-overlay.30+1df211c75"
|
|
110
138
|
},
|
|
111
139
|
"types": "./src/index.d.ts",
|
|
112
140
|
"customElements": "custom-elements.json",
|
|
113
141
|
"sideEffects": [
|
|
114
142
|
"./active-overlay.js",
|
|
115
143
|
"./overlay-trigger.js",
|
|
144
|
+
"./sp-overlay.js",
|
|
116
145
|
"./sync/overlay-trigger.js",
|
|
117
146
|
"./stories/overlay-story-components.js",
|
|
118
147
|
"./**/*.dev.js"
|
|
119
148
|
],
|
|
120
|
-
"gitHead": "
|
|
149
|
+
"gitHead": "1df211c7581b6fd6ec624cf2b09bc81aeec29c26"
|
|
121
150
|
}
|
package/sp-overlay.d.ts
ADDED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["
|
|
4
|
-
"sourcesContent": ["/*\nCopyright
|
|
5
|
-
"mappings": ";AAWA,SAAS,qBAAqB;AAC9B,SAAS,
|
|
3
|
+
"sources": ["sp-overlay.ts"],
|
|
4
|
+
"sourcesContent": ["/*\nCopyright 2023 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*/\nimport { defineElement } from '@spectrum-web-components/base/src/define-element.js';\nimport { Overlay } from './src/Overlay.dev.js'\n\ndefineElement('sp-overlay', Overlay);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'sp-overlay': Overlay;\n }\n}\n"],
|
|
5
|
+
"mappings": ";AAWA,SAAS,qBAAqB;AAC9B,SAAS,eAAe;AAExB,cAAc,cAAc,OAAO;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/sp-overlay.js
ADDED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["
|
|
4
|
-
"sourcesContent": ["/*\nCopyright
|
|
5
|
-
"mappings": "aAWA,OAAS,iBAAAA,MAAqB,sDAC9B,OAAS,
|
|
6
|
-
"names": ["defineElement", "
|
|
3
|
+
"sources": ["sp-overlay.ts"],
|
|
4
|
+
"sourcesContent": ["/*\nCopyright 2023 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*/\nimport { defineElement } from '@spectrum-web-components/base/src/define-element.js';\nimport { Overlay } from './src/Overlay.js';\n\ndefineElement('sp-overlay', Overlay);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'sp-overlay': Overlay;\n }\n}\n"],
|
|
5
|
+
"mappings": "aAWA,OAAS,iBAAAA,MAAqB,sDAC9B,OAAS,WAAAC,MAAe,mBAExBD,EAAc,aAAcC,CAAO",
|
|
6
|
+
"names": ["defineElement", "Overlay"]
|
|
7
7
|
}
|
package/src/Overlay.d.ts
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { OverlayBase } from './OverlayBase.js';
|
|
2
|
+
import type { OverlayOptions, TriggerInteractions } from './overlay-types.js';
|
|
3
|
+
import { Placement } from '@floating-ui/dom/src/types.js';
|
|
4
|
+
import { VirtualTrigger } from './VirtualTrigger.js';
|
|
5
|
+
declare let OverlayFeatures: typeof OverlayBase & {
|
|
6
|
+
new (...args: any[]): import("lit").ReactiveElement;
|
|
7
|
+
prototype: import("lit").ReactiveElement;
|
|
8
|
+
};
|
|
9
|
+
declare type OverlayOptionsV2 = {
|
|
10
|
+
delayed?: boolean;
|
|
11
|
+
offset?: number | [number, number];
|
|
12
|
+
placement?: Placement;
|
|
13
|
+
receivesFocus: 'auto' | 'true' | 'false';
|
|
14
|
+
trigger?: HTMLElement | VirtualTrigger;
|
|
15
|
+
type?: 'modal' | 'page' | 'hint' | 'auto' | 'manual';
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* @element sp-overlay
|
|
19
|
+
*
|
|
20
|
+
* @fires sp-opened - announces that an overlay has completed any entry animations
|
|
21
|
+
* @fires sp-closed - announce that an overlay has compelted any exit animations
|
|
22
|
+
*/
|
|
23
|
+
export declare class Overlay extends OverlayFeatures {
|
|
24
|
+
static update(): void;
|
|
25
|
+
static open(target: HTMLElement, interaction: TriggerInteractions, content: HTMLElement, options: OverlayOptions): Promise<() => void>;
|
|
26
|
+
static open(content: HTMLElement, options: OverlayOptionsV2): Promise<Overlay>;
|
|
27
|
+
}
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { noop, OverlayBase } from "./OverlayBase.dev.js";
|
|
3
|
+
import { OverlayDialog } from "./OverlayDialog.dev.js";
|
|
4
|
+
import { OverlayPopover } from "./OverlayPopover.dev.js";
|
|
5
|
+
import { OverlayNoPopover } from "./OverlayNoPopover.dev.js";
|
|
6
|
+
import { reparentChildren } from "@spectrum-web-components/shared";
|
|
7
|
+
const supportsPopover = "showPopover" in document.createElement("div");
|
|
8
|
+
let OverlayFeatures = OverlayDialog(OverlayBase);
|
|
9
|
+
if (supportsPopover) {
|
|
10
|
+
OverlayFeatures = OverlayPopover(OverlayFeatures);
|
|
11
|
+
} else {
|
|
12
|
+
OverlayFeatures = OverlayNoPopover(OverlayFeatures);
|
|
13
|
+
}
|
|
14
|
+
export class Overlay extends OverlayFeatures {
|
|
15
|
+
static update() {
|
|
16
|
+
const overlayUpdateEvent = new CustomEvent("sp-update-overlays", {
|
|
17
|
+
bubbles: true,
|
|
18
|
+
composed: true,
|
|
19
|
+
cancelable: true
|
|
20
|
+
});
|
|
21
|
+
document.dispatchEvent(overlayUpdateEvent);
|
|
22
|
+
}
|
|
23
|
+
static async open(targetOrContent, interactionOrOptions, content, options) {
|
|
24
|
+
var _a, _b;
|
|
25
|
+
const v2 = arguments.length === 2;
|
|
26
|
+
const overlay = new Overlay();
|
|
27
|
+
if (v2) {
|
|
28
|
+
const content2 = targetOrContent;
|
|
29
|
+
const options2 = interactionOrOptions;
|
|
30
|
+
overlay.append(content2);
|
|
31
|
+
overlay.triggerElement = options2.trigger || null;
|
|
32
|
+
overlay.type = options2.type || "modal";
|
|
33
|
+
overlay.offset = options2.offset || 6;
|
|
34
|
+
overlay.placement = options2.placement;
|
|
35
|
+
await new Promise(
|
|
36
|
+
(res) => requestAnimationFrame(() => res())
|
|
37
|
+
);
|
|
38
|
+
overlay.open = true;
|
|
39
|
+
return overlay;
|
|
40
|
+
} else if (content && options) {
|
|
41
|
+
const target = targetOrContent;
|
|
42
|
+
const interaction = interactionOrOptions;
|
|
43
|
+
let restored = false;
|
|
44
|
+
const restoreContent = reparentChildren([content], overlay, {
|
|
45
|
+
position: "beforeend",
|
|
46
|
+
prepareCallback: (el) => {
|
|
47
|
+
const slot = el.slot;
|
|
48
|
+
return () => {
|
|
49
|
+
el.slot = slot;
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
overlay.receivesFocus = (_a = options.receivesFocus) != null ? _a : "auto";
|
|
54
|
+
overlay.triggerElement = options.virtualTrigger || target;
|
|
55
|
+
overlay.type = interaction === "modal" ? "modal" : interaction === "hover" ? "hint" : "auto";
|
|
56
|
+
overlay.offset = (_b = options.offset) != null ? _b : 6;
|
|
57
|
+
overlay.placement = options.placement;
|
|
58
|
+
overlay.willPreventClose = !!options.notImmediatelyClosable;
|
|
59
|
+
const parent = target.getRootNode();
|
|
60
|
+
if (parent === document) {
|
|
61
|
+
target.insertAdjacentElement("afterend", overlay);
|
|
62
|
+
} else {
|
|
63
|
+
parent.append(overlay);
|
|
64
|
+
}
|
|
65
|
+
await new Promise(
|
|
66
|
+
(res) => requestAnimationFrame(() => requestAnimationFrame(() => res()))
|
|
67
|
+
);
|
|
68
|
+
overlay.open = true;
|
|
69
|
+
overlay.dispose = () => {
|
|
70
|
+
overlay.addEventListener("sp-closed", () => {
|
|
71
|
+
if (!restored) {
|
|
72
|
+
restoreContent();
|
|
73
|
+
restored = true;
|
|
74
|
+
}
|
|
75
|
+
requestAnimationFrame(() => {
|
|
76
|
+
overlay.remove();
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
overlay.open = false;
|
|
80
|
+
overlay.dispose = noop;
|
|
81
|
+
};
|
|
82
|
+
return overlay.dispose;
|
|
83
|
+
}
|
|
84
|
+
return overlay;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=Overlay.dev.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["Overlay.ts"],
|
|
4
|
+
"sourcesContent": ["/*\nCopyright 2023 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*/\nimport { noop, OverlayBase } from './OverlayBase.dev.js'\nimport { OverlayDialog } from './OverlayDialog.dev.js'\nimport { OverlayPopover } from './OverlayPopover.dev.js'\nimport { OverlayNoPopover } from './OverlayNoPopover.dev.js'\nimport type { OverlayOptions, TriggerInteractions } from './overlay-types.dev.js'\nimport { Placement } from '@floating-ui/dom/src/types.js';\nimport { VirtualTrigger } from './VirtualTrigger.dev.js'\nimport { reparentChildren } from '@spectrum-web-components/shared';\n\nconst supportsPopover = 'showPopover' in document.createElement('div');\n\nlet OverlayFeatures = OverlayDialog(OverlayBase);\nif (supportsPopover) {\n OverlayFeatures = OverlayPopover(OverlayFeatures);\n} else {\n OverlayFeatures = OverlayNoPopover(OverlayFeatures);\n}\n\ntype OverlayOptionsV2 = {\n delayed?: boolean;\n offset?: number | [number, number]; // supporting multi-axis\n placement?: Placement;\n receivesFocus: 'auto' | 'true' | 'false';\n trigger?: HTMLElement | VirtualTrigger;\n type?: 'modal' | 'page' | 'hint' | 'auto' | 'manual';\n};\n\n/**\n * @element sp-overlay\n *\n * @fires sp-opened - announces that an overlay has completed any entry animations\n * @fires sp-closed - announce that an overlay has compelted any exit animations\n */\nexport class Overlay extends OverlayFeatures {\n public static update(): void {\n const overlayUpdateEvent = new CustomEvent('sp-update-overlays', {\n bubbles: true,\n composed: true,\n cancelable: true,\n });\n document.dispatchEvent(overlayUpdateEvent);\n }\n\n public static async open(\n target: HTMLElement,\n interaction: TriggerInteractions,\n content: HTMLElement,\n options: OverlayOptions\n ): Promise<() => void>;\n public static async open(\n content: HTMLElement,\n options: OverlayOptionsV2\n ): Promise<Overlay>;\n public static async open(\n targetOrContent: HTMLElement,\n interactionOrOptions: TriggerInteractions | OverlayOptionsV2,\n content?: HTMLElement,\n options?: OverlayOptions\n ): Promise<Overlay | (() => void)> {\n const v2 = arguments.length === 2;\n const overlay = new Overlay();\n if (v2) {\n const content = targetOrContent;\n const options = interactionOrOptions as OverlayOptionsV2;\n overlay.append(content);\n overlay.triggerElement = options.trigger || null;\n overlay.type = options.type || 'modal';\n overlay.offset = options.offset || 6;\n overlay.placement = options.placement;\n await new Promise<void>((res) =>\n requestAnimationFrame(() => res())\n );\n // Do we want to \"open\" this path, or leave that to the consumer?\n overlay.open = true;\n return overlay;\n } else if (content && options) {\n const target = targetOrContent;\n const interaction = interactionOrOptions;\n let restored = false;\n const restoreContent = reparentChildren([content], overlay, {\n position: 'beforeend',\n prepareCallback: (el) => {\n const slot = el.slot;\n return () => {\n el.slot = slot;\n };\n },\n });\n overlay.receivesFocus = options.receivesFocus ?? 'auto';\n overlay.triggerElement = options.virtualTrigger || target;\n overlay.type =\n interaction === 'modal'\n ? 'modal'\n : interaction === 'hover'\n ? 'hint'\n : 'auto';\n overlay.offset = options.offset ?? 6;\n overlay.placement = options.placement;\n overlay.willPreventClose = !!options.notImmediatelyClosable;\n // This is super dirty...find a better way.\n // Maybe imperative open should go _at the end_ of everything?\n // Having an option is likely useful.\n // Make imperative overlays less useful?\n // Delete the imperative approach to an overlay?\n // Possibly the giving all of the responsiblities to the user is the best path.\n const parent = target.getRootNode() as Document;\n if (parent === document) {\n target.insertAdjacentElement('afterend', overlay);\n } else {\n parent.append(overlay);\n }\n await new Promise<void>((res) =>\n requestAnimationFrame(() => requestAnimationFrame(() => res()))\n );\n overlay.open = true;\n overlay.dispose = () => {\n overlay.addEventListener('sp-closed', () => {\n if (!restored) {\n restoreContent();\n restored = true;\n }\n requestAnimationFrame(() => {\n overlay.remove();\n });\n });\n overlay.open = false;\n overlay.dispose = noop;\n };\n return overlay.dispose;\n }\n /* c8 ignore next 1 */\n return overlay;\n }\n}\n"],
|
|
5
|
+
"mappings": ";AAWA,SAAS,MAAM,mBAAmB;AAClC,SAAS,qBAAqB;AAC9B,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAIjC,SAAS,wBAAwB;AAEjC,MAAM,kBAAkB,iBAAiB,SAAS,cAAc,KAAK;AAErE,IAAI,kBAAkB,cAAc,WAAW;AAC/C,IAAI,iBAAiB;AACjB,oBAAkB,eAAe,eAAe;AACpD,OAAO;AACH,oBAAkB,iBAAiB,eAAe;AACtD;AAiBO,aAAM,gBAAgB,gBAAgB;AAAA,EACzC,OAAc,SAAe;AACzB,UAAM,qBAAqB,IAAI,YAAY,sBAAsB;AAAA,MAC7D,SAAS;AAAA,MACT,UAAU;AAAA,MACV,YAAY;AAAA,IAChB,CAAC;AACD,aAAS,cAAc,kBAAkB;AAAA,EAC7C;AAAA,EAYA,aAAoB,KAChB,iBACA,sBACA,SACA,SAC+B;AArEvC;AAsEQ,UAAM,KAAK,UAAU,WAAW;AAChC,UAAM,UAAU,IAAI,QAAQ;AAC5B,QAAI,IAAI;AACJ,YAAMA,WAAU;AAChB,YAAMC,WAAU;AAChB,cAAQ,OAAOD,QAAO;AACtB,cAAQ,iBAAiBC,SAAQ,WAAW;AAC5C,cAAQ,OAAOA,SAAQ,QAAQ;AAC/B,cAAQ,SAASA,SAAQ,UAAU;AACnC,cAAQ,YAAYA,SAAQ;AAC5B,YAAM,IAAI;AAAA,QAAc,CAAC,QACrB,sBAAsB,MAAM,IAAI,CAAC;AAAA,MACrC;AAEA,cAAQ,OAAO;AACf,aAAO;AAAA,IACX,WAAW,WAAW,SAAS;AAC3B,YAAM,SAAS;AACf,YAAM,cAAc;AACpB,UAAI,WAAW;AACf,YAAM,iBAAiB,iBAAiB,CAAC,OAAO,GAAG,SAAS;AAAA,QACxD,UAAU;AAAA,QACV,iBAAiB,CAAC,OAAO;AACrB,gBAAM,OAAO,GAAG;AAChB,iBAAO,MAAM;AACT,eAAG,OAAO;AAAA,UACd;AAAA,QACJ;AAAA,MACJ,CAAC;AACD,cAAQ,iBAAgB,aAAQ,kBAAR,YAAyB;AACjD,cAAQ,iBAAiB,QAAQ,kBAAkB;AACnD,cAAQ,OACJ,gBAAgB,UACV,UACA,gBAAgB,UAChB,SACA;AACV,cAAQ,UAAS,aAAQ,WAAR,YAAkB;AACnC,cAAQ,YAAY,QAAQ;AAC5B,cAAQ,mBAAmB,CAAC,CAAC,QAAQ;AAOrC,YAAM,SAAS,OAAO,YAAY;AAClC,UAAI,WAAW,UAAU;AACrB,eAAO,sBAAsB,YAAY,OAAO;AAAA,MACpD,OAAO;AACH,eAAO,OAAO,OAAO;AAAA,MACzB;AACA,YAAM,IAAI;AAAA,QAAc,CAAC,QACrB,sBAAsB,MAAM,sBAAsB,MAAM,IAAI,CAAC,CAAC;AAAA,MAClE;AACA,cAAQ,OAAO;AACf,cAAQ,UAAU,MAAM;AACpB,gBAAQ,iBAAiB,aAAa,MAAM;AACxC,cAAI,CAAC,UAAU;AACX,2BAAe;AACf,uBAAW;AAAA,UACf;AACA,gCAAsB,MAAM;AACxB,oBAAQ,OAAO;AAAA,UACnB,CAAC;AAAA,QACL,CAAC;AACD,gBAAQ,OAAO;AACf,gBAAQ,UAAU;AAAA,MACtB;AACA,aAAO,QAAQ;AAAA,IACnB;AAEA,WAAO;AAAA,EACX;AACJ;",
|
|
6
|
+
"names": ["content", "options"]
|
|
7
|
+
}
|
package/src/Overlay.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";import{noop as f,OverlayBase as g}from"./OverlayBase.js";import{OverlayDialog as O}from"./OverlayDialog.js";import{OverlayPopover as b}from"./OverlayPopover.js";import{OverlayNoPopover as E}from"./OverlayNoPopover.js";import{reparentChildren as P}from"@spectrum-web-components/shared";const T="showPopover"in document.createElement("div");let n=O(g);T?n=b(n):n=E(n);export class Overlay extends n{static update(){const a=new CustomEvent("sp-update-overlays",{bubbles:!0,composed:!0,cancelable:!0});document.dispatchEvent(a)}static async open(a,l,m,r){var p,c;const v=arguments.length===2,e=new Overlay;if(v){const o=a,t=l;return e.append(o),e.triggerElement=t.trigger||null,e.type=t.type||"modal",e.offset=t.offset||6,e.placement=t.placement,await new Promise(s=>requestAnimationFrame(()=>s())),e.open=!0,e}else if(m&&r){const o=a,t=l;let s=!1;const d=P([m],e,{position:"beforeend",prepareCallback:i=>{const y=i.slot;return()=>{i.slot=y}}});e.receivesFocus=(p=r.receivesFocus)!=null?p:"auto",e.triggerElement=r.virtualTrigger||o,e.type=t==="modal"?"modal":t==="hover"?"hint":"auto",e.offset=(c=r.offset)!=null?c:6,e.placement=r.placement,e.willPreventClose=!!r.notImmediatelyClosable;const u=o.getRootNode();return u===document?o.insertAdjacentElement("afterend",e):u.append(e),await new Promise(i=>requestAnimationFrame(()=>requestAnimationFrame(()=>i()))),e.open=!0,e.dispose=()=>{e.addEventListener("sp-closed",()=>{s||(d(),s=!0),requestAnimationFrame(()=>{e.remove()})}),e.open=!1,e.dispose=f},e.dispose}return e}}
|
|
2
|
+
//# sourceMappingURL=Overlay.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["Overlay.ts"],
|
|
4
|
+
"sourcesContent": ["/*\nCopyright 2023 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*/\nimport { noop, OverlayBase } from './OverlayBase.js';\nimport { OverlayDialog } from './OverlayDialog.js';\nimport { OverlayPopover } from './OverlayPopover.js';\nimport { OverlayNoPopover } from './OverlayNoPopover.js';\nimport type { OverlayOptions, TriggerInteractions } from './overlay-types.js';\nimport { Placement } from '@floating-ui/dom/src/types.js';\nimport { VirtualTrigger } from './VirtualTrigger.js';\nimport { reparentChildren } from '@spectrum-web-components/shared';\n\nconst supportsPopover = 'showPopover' in document.createElement('div');\n\nlet OverlayFeatures = OverlayDialog(OverlayBase);\nif (supportsPopover) {\n OverlayFeatures = OverlayPopover(OverlayFeatures);\n} else {\n OverlayFeatures = OverlayNoPopover(OverlayFeatures);\n}\n\ntype OverlayOptionsV2 = {\n delayed?: boolean;\n offset?: number | [number, number]; // supporting multi-axis\n placement?: Placement;\n receivesFocus: 'auto' | 'true' | 'false';\n trigger?: HTMLElement | VirtualTrigger;\n type?: 'modal' | 'page' | 'hint' | 'auto' | 'manual';\n};\n\n/**\n * @element sp-overlay\n *\n * @fires sp-opened - announces that an overlay has completed any entry animations\n * @fires sp-closed - announce that an overlay has compelted any exit animations\n */\nexport class Overlay extends OverlayFeatures {\n public static update(): void {\n const overlayUpdateEvent = new CustomEvent('sp-update-overlays', {\n bubbles: true,\n composed: true,\n cancelable: true,\n });\n document.dispatchEvent(overlayUpdateEvent);\n }\n\n public static async open(\n target: HTMLElement,\n interaction: TriggerInteractions,\n content: HTMLElement,\n options: OverlayOptions\n ): Promise<() => void>;\n public static async open(\n content: HTMLElement,\n options: OverlayOptionsV2\n ): Promise<Overlay>;\n public static async open(\n targetOrContent: HTMLElement,\n interactionOrOptions: TriggerInteractions | OverlayOptionsV2,\n content?: HTMLElement,\n options?: OverlayOptions\n ): Promise<Overlay | (() => void)> {\n const v2 = arguments.length === 2;\n const overlay = new Overlay();\n if (v2) {\n const content = targetOrContent;\n const options = interactionOrOptions as OverlayOptionsV2;\n overlay.append(content);\n overlay.triggerElement = options.trigger || null;\n overlay.type = options.type || 'modal';\n overlay.offset = options.offset || 6;\n overlay.placement = options.placement;\n await new Promise<void>((res) =>\n requestAnimationFrame(() => res())\n );\n // Do we want to \"open\" this path, or leave that to the consumer?\n overlay.open = true;\n return overlay;\n } else if (content && options) {\n const target = targetOrContent;\n const interaction = interactionOrOptions;\n let restored = false;\n const restoreContent = reparentChildren([content], overlay, {\n position: 'beforeend',\n prepareCallback: (el) => {\n const slot = el.slot;\n return () => {\n el.slot = slot;\n };\n },\n });\n overlay.receivesFocus = options.receivesFocus ?? 'auto';\n overlay.triggerElement = options.virtualTrigger || target;\n overlay.type =\n interaction === 'modal'\n ? 'modal'\n : interaction === 'hover'\n ? 'hint'\n : 'auto';\n overlay.offset = options.offset ?? 6;\n overlay.placement = options.placement;\n overlay.willPreventClose = !!options.notImmediatelyClosable;\n // This is super dirty...find a better way.\n // Maybe imperative open should go _at the end_ of everything?\n // Having an option is likely useful.\n // Make imperative overlays less useful?\n // Delete the imperative approach to an overlay?\n // Possibly the giving all of the responsiblities to the user is the best path.\n const parent = target.getRootNode() as Document;\n if (parent === document) {\n target.insertAdjacentElement('afterend', overlay);\n } else {\n parent.append(overlay);\n }\n await new Promise<void>((res) =>\n requestAnimationFrame(() => requestAnimationFrame(() => res()))\n );\n overlay.open = true;\n overlay.dispose = () => {\n overlay.addEventListener('sp-closed', () => {\n if (!restored) {\n restoreContent();\n restored = true;\n }\n requestAnimationFrame(() => {\n overlay.remove();\n });\n });\n overlay.open = false;\n overlay.dispose = noop;\n };\n return overlay.dispose;\n }\n /* c8 ignore next 1 */\n return overlay;\n }\n}\n"],
|
|
5
|
+
"mappings": "aAWA,OAAS,QAAAA,EAAM,eAAAC,MAAmB,mBAClC,OAAS,iBAAAC,MAAqB,qBAC9B,OAAS,kBAAAC,MAAsB,sBAC/B,OAAS,oBAAAC,MAAwB,wBAIjC,OAAS,oBAAAC,MAAwB,kCAEjC,MAAMC,EAAkB,gBAAiB,SAAS,cAAc,KAAK,EAErE,IAAIC,EAAkBL,EAAcD,CAAW,EAC3CK,EACAC,EAAkBJ,EAAeI,CAAe,EAEhDA,EAAkBH,EAAiBG,CAAe,EAkB/C,aAAM,gBAAgBA,CAAgB,CACzC,OAAc,QAAe,CACzB,MAAMC,EAAqB,IAAI,YAAY,qBAAsB,CAC7D,QAAS,GACT,SAAU,GACV,WAAY,EAChB,CAAC,EACD,SAAS,cAAcA,CAAkB,CAC7C,CAYA,aAAoB,KAChBC,EACAC,EACAC,EACAC,EAC+B,CArEvC,IAAAC,EAAAC,EAsEQ,MAAMC,EAAK,UAAU,SAAW,EAC1BC,EAAU,IAAI,QACpB,GAAID,EAAI,CACJ,MAAMJ,EAAUF,EACVG,EAAUF,EAChB,OAAAM,EAAQ,OAAOL,CAAO,EACtBK,EAAQ,eAAiBJ,EAAQ,SAAW,KAC5CI,EAAQ,KAAOJ,EAAQ,MAAQ,QAC/BI,EAAQ,OAASJ,EAAQ,QAAU,EACnCI,EAAQ,UAAYJ,EAAQ,UAC5B,MAAM,IAAI,QAAeK,GACrB,sBAAsB,IAAMA,EAAI,CAAC,CACrC,EAEAD,EAAQ,KAAO,GACRA,UACAL,GAAWC,EAAS,CAC3B,MAAMM,EAAST,EACTU,EAAcT,EACpB,IAAIU,EAAW,GACf,MAAMC,EAAiBhB,EAAiB,CAACM,CAAO,EAAGK,EAAS,CACxD,SAAU,YACV,gBAAkBM,GAAO,CACrB,MAAMC,EAAOD,EAAG,KAChB,MAAO,IAAM,CACTA,EAAG,KAAOC,CACd,CACJ,CACJ,CAAC,EACDP,EAAQ,eAAgBH,EAAAD,EAAQ,gBAAR,KAAAC,EAAyB,OACjDG,EAAQ,eAAiBJ,EAAQ,gBAAkBM,EACnDF,EAAQ,KACJG,IAAgB,QACV,QACAA,IAAgB,QAChB,OACA,OACVH,EAAQ,QAASF,EAAAF,EAAQ,SAAR,KAAAE,EAAkB,EACnCE,EAAQ,UAAYJ,EAAQ,UAC5BI,EAAQ,iBAAmB,CAAC,CAACJ,EAAQ,uBAOrC,MAAMY,EAASN,EAAO,YAAY,EAClC,OAAIM,IAAW,SACXN,EAAO,sBAAsB,WAAYF,CAAO,EAEhDQ,EAAO,OAAOR,CAAO,EAEzB,MAAM,IAAI,QAAeC,GACrB,sBAAsB,IAAM,sBAAsB,IAAMA,EAAI,CAAC,CAAC,CAClE,EACAD,EAAQ,KAAO,GACfA,EAAQ,QAAU,IAAM,CACpBA,EAAQ,iBAAiB,YAAa,IAAM,CACnCI,IACDC,EAAe,EACfD,EAAW,IAEf,sBAAsB,IAAM,CACxBJ,EAAQ,OAAO,CACnB,CAAC,CACL,CAAC,EACDA,EAAQ,KAAO,GACfA,EAAQ,QAAUhB,CACtB,EACOgB,EAAQ,QAGnB,OAAOA,CACX,CACJ",
|
|
6
|
+
"names": ["noop", "OverlayBase", "OverlayDialog", "OverlayPopover", "OverlayNoPopover", "reparentChildren", "supportsPopover", "OverlayFeatures", "overlayUpdateEvent", "targetOrContent", "interactionOrOptions", "content", "options", "_a", "_b", "v2", "overlay", "res", "target", "interaction", "restored", "restoreContent", "el", "slot", "parent"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import type { Placement } from '@floating-ui/dom';
|
|
2
|
+
import { PropertyValues, SpectrumElement, TemplateResult } from '@spectrum-web-components/base';
|
|
3
|
+
import { VirtualTrigger } from './VirtualTrigger.js';
|
|
4
|
+
import { PlacementController } from './PlacementController.js';
|
|
5
|
+
export declare type OpenableElement = HTMLElement & {
|
|
6
|
+
open: boolean;
|
|
7
|
+
tipElement?: HTMLElement;
|
|
8
|
+
updateComplete?: Promise<void>;
|
|
9
|
+
};
|
|
10
|
+
export declare type OverlayTypes = 'auto' | 'hint' | 'manual' | 'modal' | 'page';
|
|
11
|
+
export declare type LongpressEvent = {
|
|
12
|
+
source: 'pointer' | 'keyboard';
|
|
13
|
+
};
|
|
14
|
+
export declare const LONGPRESS_INSTRUCTIONS: {
|
|
15
|
+
touch: string;
|
|
16
|
+
keyboard: string;
|
|
17
|
+
mouse: string;
|
|
18
|
+
};
|
|
19
|
+
export declare class BeforetoggleClosedEvent extends Event {
|
|
20
|
+
currentState: string;
|
|
21
|
+
newState: string;
|
|
22
|
+
constructor();
|
|
23
|
+
}
|
|
24
|
+
export declare class BeforetoggleOpenEvent extends Event {
|
|
25
|
+
currentState: string;
|
|
26
|
+
newState: string;
|
|
27
|
+
constructor();
|
|
28
|
+
}
|
|
29
|
+
export declare const noop: () => void;
|
|
30
|
+
/**
|
|
31
|
+
* Apply a "transitionend" listener to an element that may not transition but
|
|
32
|
+
* guarantee the callback will be fired either way.
|
|
33
|
+
*
|
|
34
|
+
* @param el {HTMLElement} - Target of the "transition" listeners.
|
|
35
|
+
* @param action {Function} - Method to trigger the "transition".
|
|
36
|
+
* @param cb {Function} - Callback to trigger when the "transition" has ended.
|
|
37
|
+
*/
|
|
38
|
+
export declare const guaranteedTransitionend: (el: HTMLElement, action: () => void, cb: () => void) => void;
|
|
39
|
+
export declare class OverlayBase extends SpectrumElement {
|
|
40
|
+
static styles: import("@spectrum-web-components/base").CSSResult[];
|
|
41
|
+
dialogEl: HTMLDialogElement & {
|
|
42
|
+
showPopover(): void;
|
|
43
|
+
hidePopover(): void;
|
|
44
|
+
};
|
|
45
|
+
get disabled(): boolean;
|
|
46
|
+
set disabled(disabled: boolean);
|
|
47
|
+
private _disabled;
|
|
48
|
+
protected dispose: () => void;
|
|
49
|
+
elements: OpenableElement[];
|
|
50
|
+
parentOverlayToForceClose?: OverlayBase;
|
|
51
|
+
private get hasNonVirtualTrigger();
|
|
52
|
+
protected longpressed: boolean;
|
|
53
|
+
private longressTimeout;
|
|
54
|
+
offset: number | [number, number];
|
|
55
|
+
placementController: PlacementController;
|
|
56
|
+
get open(): boolean;
|
|
57
|
+
set open(open: boolean);
|
|
58
|
+
private _open;
|
|
59
|
+
static openCount: number;
|
|
60
|
+
placement?: Placement;
|
|
61
|
+
receivesFocus: 'true' | 'false' | 'auto';
|
|
62
|
+
private releaseAriaDescribedby;
|
|
63
|
+
private releaseLongpressDescribedby;
|
|
64
|
+
slotEl: HTMLSlotElement;
|
|
65
|
+
trigger?: string;
|
|
66
|
+
triggerElement: HTMLElement | VirtualTrigger | null;
|
|
67
|
+
triggerInteraction?: 'click' | 'longpress' | 'hover';
|
|
68
|
+
type: OverlayTypes;
|
|
69
|
+
protected wasOpen: boolean;
|
|
70
|
+
private elementResolver;
|
|
71
|
+
private get usesDialog();
|
|
72
|
+
private get popoverValue();
|
|
73
|
+
protected manageDialogOpen(): Promise<void>;
|
|
74
|
+
protected managePopoverOpen(): Promise<void>;
|
|
75
|
+
protected get requiresPosition(): boolean;
|
|
76
|
+
protected managePosition(): void;
|
|
77
|
+
protected manageOpen(oldOpen: boolean): Promise<void>;
|
|
78
|
+
protected unbindEvents(triggerElement: HTMLElement): void;
|
|
79
|
+
protected bindEvents(): void;
|
|
80
|
+
protected bundClickEvents(triggerElement: HTMLElement): void;
|
|
81
|
+
protected bindLongpressEvents(triggerElement: HTMLElement): void;
|
|
82
|
+
protected bindHoverEvents(triggerElement: HTMLElement): void;
|
|
83
|
+
protected manageTriggerElement(triggerElement: HTMLElement | null): void;
|
|
84
|
+
private elementIds;
|
|
85
|
+
private prepareLongpressDescription;
|
|
86
|
+
private prepareAriaDescribedby;
|
|
87
|
+
private handlePointerdown;
|
|
88
|
+
private handlePointerup;
|
|
89
|
+
/**
|
|
90
|
+
* @private
|
|
91
|
+
*/
|
|
92
|
+
protected handleKeydown: (event: KeyboardEvent) => void;
|
|
93
|
+
protected handleKeyup: (event: KeyboardEvent) => void;
|
|
94
|
+
protected handleClick: () => void;
|
|
95
|
+
private focusedin;
|
|
96
|
+
protected handleFocusin: () => void;
|
|
97
|
+
protected handleFocusout: () => void;
|
|
98
|
+
private pointerentered;
|
|
99
|
+
protected handlePointerenter: () => void;
|
|
100
|
+
protected handlePointerleave: (event: PointerEvent) => void;
|
|
101
|
+
protected handleOverlayPointerleave: (event: PointerEvent) => void;
|
|
102
|
+
protected doPointerleave(): void;
|
|
103
|
+
protected handleLongpress: () => void;
|
|
104
|
+
protected handleBeforetoggle(event: Event & {
|
|
105
|
+
newState: string;
|
|
106
|
+
}): void;
|
|
107
|
+
protected handlePopoverhide(): void;
|
|
108
|
+
protected handlePopovershow(): void;
|
|
109
|
+
protected handleSlotchange(): void;
|
|
110
|
+
willPreventClose: boolean;
|
|
111
|
+
shouldPreventClose(): boolean;
|
|
112
|
+
willUpdate(changes: PropertyValues): void;
|
|
113
|
+
protected updated(changes: PropertyValues): void;
|
|
114
|
+
render(): TemplateResult;
|
|
115
|
+
connectedCallback(): void;
|
|
116
|
+
disconnectedCallback(): void;
|
|
117
|
+
}
|