@spectrum-web-components/overlay 0.19.2 → 0.19.4-overlay.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. package/package.json +50 -21
  2. package/sp-overlay.d.ts +6 -0
  3. package/sp-overlay.dev.js +4 -0
  4. package/{active-overlay.js.map → sp-overlay.dev.js.map} +4 -4
  5. package/sp-overlay.js +2 -0
  6. package/sp-overlay.js.map +7 -0
  7. package/src/Overlay.d.ts +22 -0
  8. package/src/Overlay.dev.js +68 -0
  9. package/src/Overlay.dev.js.map +7 -0
  10. package/src/Overlay.js +2 -0
  11. package/src/Overlay.js.map +7 -0
  12. package/src/OverlayBase.d.ts +97 -0
  13. package/src/OverlayBase.dev.js +572 -0
  14. package/src/OverlayBase.dev.js.map +7 -0
  15. package/src/OverlayBase.js +18 -0
  16. package/src/OverlayBase.js.map +7 -0
  17. package/src/OverlayDialog.d.ts +8 -0
  18. package/src/OverlayDialog.dev.js +43 -0
  19. package/src/OverlayDialog.dev.js.map +7 -0
  20. package/src/OverlayDialog.js +2 -0
  21. package/src/OverlayDialog.js.map +7 -0
  22. package/src/OverlayNoPopover.d.ts +8 -0
  23. package/src/OverlayNoPopover.dev.js +62 -0
  24. package/src/OverlayNoPopover.dev.js.map +7 -0
  25. package/src/OverlayNoPopover.js +2 -0
  26. package/src/OverlayNoPopover.js.map +7 -0
  27. package/src/OverlayPopover.d.ts +8 -0
  28. package/src/OverlayPopover.dev.js +81 -0
  29. package/src/OverlayPopover.dev.js.map +7 -0
  30. package/src/OverlayPopover.js +2 -0
  31. package/src/OverlayPopover.js.map +7 -0
  32. package/src/OverlayStack.d.ts +24 -0
  33. package/src/OverlayStack.dev.js +115 -0
  34. package/src/OverlayStack.dev.js.map +7 -0
  35. package/src/OverlayStack.js +2 -0
  36. package/src/OverlayStack.js.map +7 -0
  37. package/src/OverlayTrigger.d.ts +18 -31
  38. package/src/OverlayTrigger.dev.js +138 -246
  39. package/src/OverlayTrigger.dev.js.map +3 -3
  40. package/src/OverlayTrigger.js +54 -22
  41. package/src/OverlayTrigger.js.map +3 -3
  42. package/src/PlacementController.d.ts +35 -0
  43. package/src/PlacementController.dev.js +172 -0
  44. package/src/PlacementController.dev.js.map +7 -0
  45. package/src/PlacementController.js +2 -0
  46. package/src/PlacementController.js.map +7 -0
  47. package/src/VirtualTrigger.dev.js +0 -2
  48. package/src/VirtualTrigger.dev.js.map +2 -2
  49. package/src/VirtualTrigger.js +1 -1
  50. package/src/VirtualTrigger.js.map +3 -3
  51. package/src/fullSizePlugin.d.ts +12 -0
  52. package/src/fullSizePlugin.dev.js +39 -0
  53. package/src/fullSizePlugin.dev.js.map +7 -0
  54. package/src/fullSizePlugin.js +2 -0
  55. package/src/fullSizePlugin.js.map +7 -0
  56. package/src/index.d.ts +2 -3
  57. package/src/index.dev.js +2 -3
  58. package/src/index.dev.js.map +2 -2
  59. package/src/index.js +1 -1
  60. package/src/index.js.map +2 -2
  61. package/src/loader.d.ts +2 -2
  62. package/src/loader.dev.js +2 -19
  63. package/src/loader.dev.js.map +2 -2
  64. package/src/loader.js +1 -1
  65. package/src/loader.js.map +3 -3
  66. package/src/overlay-base.css.dev.js +9 -0
  67. package/src/overlay-base.css.dev.js.map +7 -0
  68. package/src/overlay-base.css.js +6 -0
  69. package/src/overlay-base.css.js.map +7 -0
  70. package/src/overlay-trigger.css.dev.js +1 -1
  71. package/src/overlay-trigger.css.dev.js.map +1 -1
  72. package/src/overlay-trigger.css.js +1 -1
  73. package/src/overlay-trigger.css.js.map +1 -1
  74. package/src/overlay-types.d.ts +3 -3
  75. package/src/overlay-types.dev.js +1 -0
  76. package/src/overlay-types.dev.js.map +3 -3
  77. package/src/overlay-types.js +1 -1
  78. package/src/overlay-types.js.map +3 -3
  79. package/src/placement.d.ts +21 -0
  80. package/src/placement.dev.js +111 -0
  81. package/src/placement.dev.js.map +7 -0
  82. package/src/placement.js +2 -0
  83. package/src/placement.js.map +7 -0
  84. package/src/topLayerOverTransforms.d.ts +22 -0
  85. package/src/topLayerOverTransforms.dev.js +161 -0
  86. package/src/topLayerOverTransforms.dev.js.map +7 -0
  87. package/src/topLayerOverTransforms.js +2 -0
  88. package/src/topLayerOverTransforms.js.map +7 -0
  89. package/stories/overlay-element.stories.js +229 -0
  90. package/stories/overlay-element.stories.js.map +7 -0
  91. package/stories/overlay-story-components.js +1 -6
  92. package/stories/overlay-story-components.js.map +2 -2
  93. package/stories/overlay.stories.js +683 -644
  94. package/stories/overlay.stories.js.map +2 -2
  95. package/sync/overlay-trigger.d.ts +4 -0
  96. package/sync/overlay-trigger.dev.js +1 -4
  97. package/sync/overlay-trigger.dev.js.map +2 -2
  98. package/sync/overlay-trigger.js +1 -1
  99. package/sync/overlay-trigger.js.map +3 -3
  100. package/test/benchmark/basic-test.js +1 -1
  101. package/test/benchmark/basic-test.js.map +1 -1
  102. package/test/index.js +3 -9
  103. package/test/index.js.map +2 -2
  104. package/test/overlay-element.test-vrt.js +5 -0
  105. package/{active-overlay.dev.js.map → test/overlay-element.test-vrt.js.map} +3 -3
  106. package/test/overlay-element.test.js +759 -0
  107. package/test/overlay-element.test.js.map +7 -0
  108. package/test/overlay-lifecycle.test.js +34 -74
  109. package/test/overlay-lifecycle.test.js.map +2 -2
  110. package/test/overlay-trigger-click.test.js +3 -2
  111. package/test/overlay-trigger-click.test.js.map +2 -2
  112. package/test/overlay-trigger-extended.test.js +1 -6
  113. package/test/overlay-trigger-extended.test.js.map +2 -2
  114. package/test/overlay-trigger-hover-click.test.js +1 -1
  115. package/test/overlay-trigger-hover-click.test.js.map +2 -2
  116. package/test/overlay-trigger-hover.test.js +2 -2
  117. package/test/overlay-trigger-hover.test.js.map +2 -2
  118. package/test/overlay-trigger-longpress.test.js +1 -377
  119. package/test/overlay-trigger-longpress.test.js.map +2 -2
  120. package/test/overlay-trigger-sync.test.js +1 -3
  121. package/test/overlay-trigger-sync.test.js.map +2 -2
  122. package/test/overlay-trigger.test.js +1 -3
  123. package/test/overlay-trigger.test.js.map +2 -2
  124. package/test/overlay-update.test.js +4 -4
  125. package/test/overlay-update.test.js.map +2 -2
  126. package/test/overlay.test.js +98 -146
  127. package/test/overlay.test.js.map +2 -2
  128. package/active-overlay.d.ts +0 -6
  129. package/active-overlay.dev.js +0 -4
  130. package/active-overlay.js +0 -2
  131. package/custom-elements.json +0 -1212
  132. package/src/ActiveOverlay.d.ts +0 -84
  133. package/src/ActiveOverlay.dev.js +0 -517
  134. package/src/ActiveOverlay.dev.js.map +0 -7
  135. package/src/ActiveOverlay.js +0 -16
  136. package/src/ActiveOverlay.js.map +0 -7
  137. package/src/active-overlay.css.dev.js +0 -13
  138. package/src/active-overlay.css.dev.js.map +0 -7
  139. package/src/active-overlay.css.js +0 -10
  140. package/src/active-overlay.css.js.map +0 -7
  141. package/src/overlay-stack.d.ts +0 -50
  142. package/src/overlay-stack.dev.js +0 -514
  143. package/src/overlay-stack.dev.js.map +0 -7
  144. package/src/overlay-stack.js +0 -33
  145. package/src/overlay-stack.js.map +0 -7
  146. package/src/overlay-utils.d.ts +0 -3
  147. package/src/overlay-utils.dev.js +0 -31
  148. package/src/overlay-utils.dev.js.map +0 -7
  149. package/src/overlay-utils.js +0 -2
  150. package/src/overlay-utils.js.map +0 -7
  151. package/src/overlay.d.ts +0 -59
  152. package/src/overlay.dev.js +0 -127
  153. package/src/overlay.dev.js.map +0 -7
  154. package/src/overlay.js +0 -2
  155. package/src/overlay.js.map +0 -7
  156. /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.19.2",
3
+ "version": "0.19.4-overlay.22+e296a22f1",
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/ActiveOverlay.js": {
29
- "development": "./src/ActiveOverlay.dev.js",
30
- "default": "./src/ActiveOverlay.js"
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/active-overlay.css.js": "./src/active-overlay.css.js",
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/overlay-utils.js": {
67
- "development": "./src/overlay-utils.dev.js",
68
- "default": "./src/overlay-utils.js"
90
+ "./src/placement.js": {
91
+ "development": "./src/placement.dev.js",
92
+ "default": "./src/placement.js"
69
93
  },
70
- "./src/overlay.js": {
71
- "development": "./src/overlay.dev.js",
72
- "default": "./src/overlay.js"
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.0",
106
- "@spectrum-web-components/action-button": "^0.10.13",
107
- "@spectrum-web-components/base": "^0.7.4",
108
- "@spectrum-web-components/shared": "^0.15.5",
109
- "@spectrum-web-components/theme": "^0.14.12"
133
+ "@floating-ui/dom": "^1.2.5",
134
+ "@spectrum-web-components/action-button": "^0.10.15-overlay.22+e296a22f1",
135
+ "@spectrum-web-components/base": "^0.7.5-overlay.250+e296a22f1",
136
+ "@spectrum-web-components/shared": "^0.15.6-overlay.250+e296a22f1",
137
+ "@spectrum-web-components/theme": "^0.14.14-overlay.22+e296a22f1"
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": "5e11d828243bb3ff572c25b33a8d58844a89f524"
149
+ "gitHead": "e296a22f1eeff7d62753caf21d2bae4ba406cbbd"
121
150
  }
@@ -0,0 +1,6 @@
1
+ import { Overlay } from './src/Overlay.js';
2
+ declare global {
3
+ interface HTMLElementTagNameMap {
4
+ 'sp-overlay': typeof Overlay;
5
+ }
6
+ }
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ import { Overlay } from "./src/Overlay.dev.js";
3
+ customElements.define("sp-overlay", Overlay);
4
+ //# sourceMappingURL=sp-overlay.dev.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["active-overlay.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*/\nimport { ActiveOverlay } from './src/ActiveOverlay.js';\n\ncustomElements.define('active-overlay', ActiveOverlay);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'active-overlay': ActiveOverlay;\n }\n}\n"],
5
- "mappings": "aAWA,OAAS,iBAAAA,MAAqB,yBAE9B,eAAe,OAAO,iBAAkBA,CAAa",
6
- "names": ["ActiveOverlay"]
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 { Overlay } from './src/Overlay.dev.js'\n\ncustomElements.define('sp-overlay', Overlay);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'sp-overlay': typeof Overlay;\n }\n}\n"],
5
+ "mappings": ";AAWA,SAAS,eAAe;AAExB,eAAe,OAAO,cAAc,OAAO;",
6
+ "names": []
7
7
  }
package/sp-overlay.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";import{Overlay as e}from"./src/Overlay.js";customElements.define("sp-overlay",e);
2
+ //# sourceMappingURL=sp-overlay.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
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 { Overlay } from './src/Overlay.js';\n\ncustomElements.define('sp-overlay', Overlay);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'sp-overlay': typeof Overlay;\n }\n}\n"],
5
+ "mappings": "aAWA,OAAS,WAAAA,MAAe,mBAExB,eAAe,OAAO,aAAcA,CAAO",
6
+ "names": ["Overlay"]
7
+ }
@@ -0,0 +1,22 @@
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
+ export declare class Overlay extends OverlayFeatures {
18
+ static update(): void;
19
+ static open(target: HTMLElement, interaction: TriggerInteractions, content: HTMLElement, options: OverlayOptions): Promise<() => void>;
20
+ static open(content: HTMLElement, options: OverlayOptionsV2): Promise<Overlay>;
21
+ }
22
+ export {};
@@ -0,0 +1,68 @@
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
+ const supportsPopover = "showPopover" in document.createElement("div");
7
+ let OverlayFeatures = OverlayDialog(OverlayBase);
8
+ if (supportsPopover) {
9
+ OverlayFeatures = OverlayPopover(OverlayFeatures);
10
+ } else {
11
+ OverlayFeatures = OverlayNoPopover(OverlayFeatures);
12
+ }
13
+ export class Overlay extends OverlayFeatures {
14
+ static update() {
15
+ return;
16
+ }
17
+ static async open(targetOrContent, interactionOrOptions, content, options) {
18
+ var _a, _b;
19
+ const v2 = arguments.length === 2;
20
+ const overlay = new Overlay();
21
+ if (v2) {
22
+ const content2 = targetOrContent;
23
+ const options2 = interactionOrOptions;
24
+ overlay.append(content2);
25
+ overlay.triggerElement = options2.trigger || null;
26
+ overlay.type = options2.type || "modal";
27
+ overlay.offset = options2.offset || 6;
28
+ overlay.placement = options2.placement;
29
+ await new Promise(
30
+ (res) => requestAnimationFrame(() => res())
31
+ );
32
+ overlay.open = true;
33
+ return overlay;
34
+ } else if (content && options) {
35
+ const target = targetOrContent;
36
+ const interaction = interactionOrOptions;
37
+ overlay.append(content);
38
+ overlay.receivesFocus = (_a = options.receivesFocus) != null ? _a : "auto";
39
+ overlay.triggerElement = options.virtualTrigger || target;
40
+ overlay.type = interaction === "modal" ? "modal" : interaction === "hover" ? "hint" : "auto";
41
+ overlay.offset = (_b = options.offset) != null ? _b : 6;
42
+ overlay.placement = options.placement;
43
+ overlay.willPreventClose = !!options.notImmediatelyClosable;
44
+ const parent = target.getRootNode();
45
+ if (parent === document) {
46
+ target.insertAdjacentElement("afterend", overlay);
47
+ } else {
48
+ parent.append(overlay);
49
+ }
50
+ await new Promise(
51
+ (res) => requestAnimationFrame(() => requestAnimationFrame(() => res()))
52
+ );
53
+ overlay.open = true;
54
+ overlay.dispose = () => {
55
+ overlay.addEventListener("sp-closed", () => {
56
+ requestAnimationFrame(() => {
57
+ overlay.remove();
58
+ });
59
+ });
60
+ overlay.open = false;
61
+ overlay.dispose = noop;
62
+ };
63
+ return overlay.dispose;
64
+ }
65
+ return overlay;
66
+ }
67
+ }
68
+ //# 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'\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\nexport class Overlay extends OverlayFeatures {\n public static update(): void {\n return;\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 overlay.append(content);\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 // document.body.append(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 requestAnimationFrame(() => {\n overlay.remove();\n });\n });\n overlay.open = false;\n overlay.dispose = noop;\n };\n return overlay.dispose;\n }\n return overlay;\n }\n}\n"],
5
+ "mappings": ";AAWA,SAAS,MAAM,mBAAmB;AAClC,SAAS,qBAAqB;AAC9B,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAKjC,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;AAWO,aAAM,gBAAgB,gBAAgB;AAAA,EACzC,OAAc,SAAe;AACzB;AAAA,EACJ;AAAA,EAYA,aAAoB,KAChB,iBACA,sBACA,SACA,SAC+B;AAzDvC;AA0DQ,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,cAAQ,OAAO,OAAO;AACtB,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,MAEpD,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,gCAAsB,MAAM;AACxB,oBAAQ,OAAO;AAAA,UACnB,CAAC;AAAA,QACL,CAAC;AACD,gBAAQ,OAAO;AACf,gBAAQ,UAAU;AAAA,MACtB;AACA,aAAO,QAAQ;AAAA,IACnB;AACA,WAAO;AAAA,EACX;AACJ;",
6
+ "names": ["content", "options"]
7
+ }
package/src/Overlay.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";import{noop as v,OverlayBase as d}from"./OverlayBase.js";import{OverlayDialog as y}from"./OverlayDialog.js";import{OverlayPopover as g}from"./OverlayPopover.js";import{OverlayNoPopover as f}from"./OverlayNoPopover.js";const O="showPopover"in document.createElement("div");let n=y(d);O?n=g(n):n=f(n);export class Overlay extends n{static update(){}static async open(i,s,l,r){var m,p;const c=arguments.length===2,e=new Overlay;if(c){const o=i,t=s;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(a=>requestAnimationFrame(()=>a())),e.open=!0,e}else if(l&&r){const o=i,t=s;e.append(l),e.receivesFocus=(m=r.receivesFocus)!=null?m:"auto",e.triggerElement=r.virtualTrigger||o,e.type=t==="modal"?"modal":t==="hover"?"hint":"auto",e.offset=(p=r.offset)!=null?p:6,e.placement=r.placement,e.willPreventClose=!!r.notImmediatelyClosable;const a=o.getRootNode();return a===document?o.insertAdjacentElement("afterend",e):a.append(e),await new Promise(u=>requestAnimationFrame(()=>requestAnimationFrame(()=>u()))),e.open=!0,e.dispose=()=>{e.addEventListener("sp-closed",()=>{requestAnimationFrame(()=>{e.remove()})}),e.open=!1,e.dispose=v},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';\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\nexport class Overlay extends OverlayFeatures {\n public static update(): void {\n return;\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 overlay.append(content);\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 // document.body.append(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 requestAnimationFrame(() => {\n overlay.remove();\n });\n });\n overlay.open = false;\n overlay.dispose = noop;\n };\n return overlay.dispose;\n }\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,wBAKjC,MAAMC,EAAkB,gBAAiB,SAAS,cAAc,KAAK,EAErE,IAAIC,EAAkBJ,EAAcD,CAAW,EAC3CI,EACAC,EAAkBH,EAAeG,CAAe,EAEhDA,EAAkBF,EAAiBE,CAAe,EAY/C,aAAM,gBAAgBA,CAAgB,CACzC,OAAc,QAAe,CAE7B,CAYA,aAAoB,KAChBC,EACAC,EACAC,EACAC,EAC+B,CAzDvC,IAAAC,EAAAC,EA0DQ,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,CACX,SAAWL,GAAWC,EAAS,CAC3B,MAAMM,EAAST,EACTU,EAAcT,EACpBM,EAAQ,OAAOL,CAAO,EACtBK,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,MAAMQ,EAASF,EAAO,YAAY,EAClC,OAAIE,IAAW,SACXF,EAAO,sBAAsB,WAAYF,CAAO,EAGhDI,EAAO,OAAOJ,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,CACxC,sBAAsB,IAAM,CACxBA,EAAQ,OAAO,CACnB,CAAC,CACL,CAAC,EACDA,EAAQ,KAAO,GACfA,EAAQ,QAAUd,CACtB,EACOc,EAAQ,OACnB,CACA,OAAOA,CACX,CACJ",
6
+ "names": ["noop", "OverlayBase", "OverlayDialog", "OverlayPopover", "OverlayNoPopover", "supportsPopover", "OverlayFeatures", "targetOrContent", "interactionOrOptions", "content", "options", "_a", "_b", "v2", "overlay", "res", "target", "interaction", "parent"]
7
+ }
@@ -0,0 +1,97 @@
1
+ import type { Placement } from '@floating-ui/dom';
2
+ import { PropertyValues, SpectrumElement, TemplateResult } from '@spectrum-web-components/base';
3
+ import type { 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
+ export declare class OverlayBase extends SpectrumElement {
31
+ static styles: import("@spectrum-web-components/base").CSSResult[];
32
+ dialogEl: HTMLDialogElement & {
33
+ showPopover(): void;
34
+ hidePopover(): void;
35
+ };
36
+ get disabled(): boolean;
37
+ set disabled(disabled: boolean);
38
+ private _disabled;
39
+ protected dispose: () => void;
40
+ elements: OpenableElement[];
41
+ parentOverlayToForceClose?: OverlayBase;
42
+ protected longpressed: boolean;
43
+ private longressTimeout;
44
+ offset: number | [number, number];
45
+ placementController: PlacementController;
46
+ get open(): boolean;
47
+ set open(open: boolean);
48
+ private _open;
49
+ static openCount: number;
50
+ placement?: Placement;
51
+ receivesFocus: 'true' | 'false' | 'auto';
52
+ private releaseAriaDescribedby;
53
+ slotEl: HTMLSlotElement;
54
+ trigger?: string;
55
+ triggerElement: HTMLElement | VirtualTrigger | null;
56
+ triggerInteraction?: 'click' | 'longpress' | 'hover';
57
+ type: OverlayTypes;
58
+ protected wasOpen: boolean;
59
+ private elementResolver;
60
+ private get usesDialog();
61
+ private get popoverValue();
62
+ protected manageChildren(open: boolean): void;
63
+ protected manageDialogOpen(): Promise<void>;
64
+ protected managePopoverOpen(): Promise<void>;
65
+ protected get requiresPosition(): boolean;
66
+ protected managePosition(): void;
67
+ protected manageOpen(): Promise<void>;
68
+ protected manageTriggerElement(triggerElement: HTMLElement | null): void;
69
+ private elementIds;
70
+ private prepareAriaDescribedby;
71
+ private handlePointerdown;
72
+ private handlePointerup;
73
+ /**
74
+ * @private
75
+ */
76
+ protected handleKeydown: (event: KeyboardEvent) => void;
77
+ protected handleKeyup: (event: KeyboardEvent) => void;
78
+ protected handleClick: () => void;
79
+ private focusedin;
80
+ protected handleFocusin: () => void;
81
+ protected handleFocusout: () => void;
82
+ private pointerentered;
83
+ protected handlePointerenter: () => void;
84
+ protected handlePointerleave: () => void;
85
+ protected handleLongpress: () => void;
86
+ protected handleBeforetoggle({ newState: open, }: Event & {
87
+ newState: string;
88
+ }): void;
89
+ protected handlePopoverhide(): void;
90
+ protected handlePopovershow(): void;
91
+ willPreventClose: boolean;
92
+ shouldPreventClose(): boolean;
93
+ willUpdate(changes: PropertyValues): void;
94
+ protected updated(changes: PropertyValues): void;
95
+ render(): TemplateResult;
96
+ connectedCallback(): void;
97
+ }