@spectrum-web-components/overlay 0.15.0 → 0.15.2

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 (48) hide show
  1. package/active-overlay.d.ts +6 -0
  2. package/active-overlay.js +14 -0
  3. package/active-overlay.js.map +1 -0
  4. package/custom-elements.json +6 -6
  5. package/overlay-trigger.d.ts +6 -0
  6. package/overlay-trigger.js +14 -0
  7. package/overlay-trigger.js.map +1 -0
  8. package/package.json +6 -6
  9. package/src/ActiveOverlay.d.ts +77 -0
  10. package/src/ActiveOverlay.js +436 -0
  11. package/src/ActiveOverlay.js.map +1 -0
  12. package/src/OverlayTrigger.d.ts +66 -0
  13. package/src/OverlayTrigger.js +310 -0
  14. package/src/OverlayTrigger.js.map +1 -0
  15. package/src/VirtualTrigger.d.ts +7 -0
  16. package/src/VirtualTrigger.js +40 -0
  17. package/src/VirtualTrigger.js.map +1 -0
  18. package/src/active-overlay.css.d.ts +2 -0
  19. package/src/active-overlay.css.js +21 -0
  20. package/src/active-overlay.css.js.map +1 -0
  21. package/src/index.d.ts +6 -0
  22. package/src/index.js +18 -0
  23. package/src/index.js.map +1 -0
  24. package/src/loader.d.ts +2 -0
  25. package/src/loader.js +16 -0
  26. package/src/loader.js.map +1 -0
  27. package/src/overlay-stack.d.ts +46 -0
  28. package/src/overlay-stack.js +449 -0
  29. package/src/overlay-stack.js.map +1 -0
  30. package/src/overlay-timer.d.ts +22 -0
  31. package/src/overlay-timer.js +89 -0
  32. package/src/overlay-timer.js.map +1 -0
  33. package/src/overlay-trigger.css.d.ts +2 -0
  34. package/src/overlay-trigger.css.js +17 -0
  35. package/src/overlay-trigger.css.js.map +1 -0
  36. package/src/overlay-types.d.ts +52 -0
  37. package/src/overlay-types.js +13 -0
  38. package/src/overlay-types.js.map +1 -0
  39. package/src/overlay.d.ts +59 -0
  40. package/src/overlay.js +119 -0
  41. package/src/overlay.js.map +1 -0
  42. package/stories/overlay-story-components.js +292 -0
  43. package/stories/overlay-story-components.js.map +1 -0
  44. package/stories/overlay.stories.js +805 -0
  45. package/stories/overlay.stories.js.map +1 -0
  46. package/sync/overlay-trigger.d.ts +1 -0
  47. package/sync/overlay-trigger.js +18 -0
  48. package/sync/overlay-trigger.js.map +1 -0
@@ -0,0 +1,805 @@
1
+ /*
2
+ Copyright 2020 Adobe. All rights reserved.
3
+ This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
+ you may not use this file except in compliance with the License. You may obtain a copy
5
+ of the License at http://www.apache.org/licenses/LICENSE-2.0
6
+ Unless required by applicable law or agreed to in writing, software distributed under
7
+ the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
8
+ OF ANY KIND, either express or implied. See the License for the specific language
9
+ governing permissions and limitations under the License.
10
+ */
11
+ import { html } from '@spectrum-web-components/base';
12
+ import { ifDefined } from '@spectrum-web-components/base/src/directives.js';
13
+ import { openOverlay, Overlay, VirtualTrigger, } from '../';
14
+ import '@spectrum-web-components/action-button/sp-action-button.js';
15
+ import '@spectrum-web-components/action-group/sp-action-group.js';
16
+ import '@spectrum-web-components/button/sp-button.js';
17
+ import '@spectrum-web-components/dialog/sp-dialog-wrapper.js';
18
+ import '@spectrum-web-components/field-label/sp-field-label.js';
19
+ import '@spectrum-web-components/icons-workflow/icons/sp-icon-magnify.js';
20
+ import '@spectrum-web-components/icons-workflow/icons/sp-icon-open-in.js';
21
+ import '@spectrum-web-components/overlay/overlay-trigger.js';
22
+ import '@spectrum-web-components/picker/sp-picker.js';
23
+ import '@spectrum-web-components/menu/sp-menu.js';
24
+ import '@spectrum-web-components/menu/sp-menu-item.js';
25
+ import '@spectrum-web-components/menu/sp-menu-divider.js';
26
+ import '@spectrum-web-components/popover/sp-popover.js';
27
+ import '@spectrum-web-components/slider/sp-slider.js';
28
+ import '@spectrum-web-components/radio/sp-radio.js';
29
+ import '@spectrum-web-components/radio/sp-radio-group.js';
30
+ import '@spectrum-web-components/tooltip/sp-tooltip.js';
31
+ import '@spectrum-web-components/theme/sp-theme.js';
32
+ import '@spectrum-web-components/theme/src/themes.js';
33
+ import '../../../projects/story-decorator/src/types.js';
34
+ import './overlay-story-components.js';
35
+ import { render } from 'lit-html';
36
+ const storyStyles = html `
37
+ <style>
38
+ html,
39
+ body,
40
+ #root,
41
+ #root-inner,
42
+ sp-story-decorator {
43
+ height: 100%;
44
+ margin: 0;
45
+ }
46
+
47
+ sp-story-decorator::part(container) {
48
+ display: flex;
49
+ flex-direction: column;
50
+ width: 100%;
51
+ height: 100%;
52
+ align-items: center;
53
+ justify-content: center;
54
+ }
55
+
56
+ overlay-trigger {
57
+ flex: none;
58
+ }
59
+
60
+ #styled-div {
61
+ background-color: var(--styled-div-background-color, blue);
62
+ color: white;
63
+ padding: 4px 10px;
64
+ margin-bottom: 10px;
65
+ }
66
+
67
+ #inner-trigger {
68
+ display: inline-block;
69
+ }
70
+ </style>
71
+ `;
72
+ export default {
73
+ title: 'Overlay',
74
+ argTypes: {
75
+ offset: { control: 'number' },
76
+ placement: {
77
+ control: {
78
+ type: 'inline-radio',
79
+ options: [
80
+ 'top',
81
+ 'top-start',
82
+ 'top-end',
83
+ 'bottom',
84
+ 'bottom-start',
85
+ 'bottom-end',
86
+ 'left',
87
+ 'left-start',
88
+ 'left-end',
89
+ 'right',
90
+ 'right-start',
91
+ 'right-end',
92
+ 'auto',
93
+ 'auto-start',
94
+ 'auto-end',
95
+ 'none',
96
+ ],
97
+ },
98
+ },
99
+ colorStop: {
100
+ control: {
101
+ type: 'inline-radio',
102
+ options: ['light', 'dark'],
103
+ },
104
+ },
105
+ },
106
+ args: {
107
+ placement: 'bottom',
108
+ offset: 0,
109
+ colorStop: 'light',
110
+ },
111
+ };
112
+ const template = ({ placement, offset, open }) => {
113
+ return html `
114
+ ${storyStyles}
115
+ <overlay-trigger
116
+ id="trigger"
117
+ placement="${placement}"
118
+ offset="${offset}"
119
+ open=${ifDefined(open)}
120
+ >
121
+ <sp-button variant="primary" slot="trigger">Show Popover</sp-button>
122
+ <sp-popover
123
+ dialog
124
+ slot="click-content"
125
+ placement="${placement}"
126
+ tip
127
+ >
128
+ <div class="options-popover-content">
129
+ <sp-slider
130
+ value="5"
131
+ step="0.5"
132
+ min="0"
133
+ max="20"
134
+ label="Awesomeness"
135
+ ></sp-slider>
136
+ <div id="styled-div">
137
+ The background of this div should be blue
138
+ </div>
139
+ <overlay-trigger id="inner-trigger" placement="bottom">
140
+ <sp-button slot="trigger">Press Me</sp-button>
141
+ <sp-popover
142
+ dialog
143
+ slot="click-content"
144
+ placement="bottom"
145
+ tip
146
+ open
147
+ >
148
+ <div class="options-popover-content">
149
+ Another Popover
150
+ </div>
151
+ </sp-popover>
152
+
153
+ <sp-tooltip slot="hover-content" delayed tip="bottom">
154
+ Click to open another popover.
155
+ </sp-tooltip>
156
+ </overlay-trigger>
157
+ </div>
158
+ </sp-popover>
159
+ <sp-tooltip
160
+ slot="hover-content"
161
+ ?delayed=${open !== 'hover'}
162
+ tip="bottom"
163
+ >
164
+ Click to open a popover.
165
+ </sp-tooltip>
166
+ </overlay-trigger>
167
+ `;
168
+ };
169
+ export const Default = (args) => template(args);
170
+ export const openHoverContent = (args) => template(Object.assign(Object.assign({}, args), { open: 'hover' }));
171
+ export const openClickContent = (args) => template(Object.assign(Object.assign({}, args), { open: 'click' }));
172
+ export const customizedClickContent = (args) => html `
173
+ <style>
174
+ active-overlay::part(theme) {
175
+ --styled-div-background-color: var(--spectrum-semantic-cta-background-color-default);
176
+ --spectrum-button-m-cta-texticon-background-color: rebeccapurple;
177
+ }
178
+ </style>
179
+ </style>
180
+ ${template(Object.assign(Object.assign({}, args), { open: 'click' }))}
181
+ `;
182
+ const extraText = html `
183
+ <p>This is some text.</p>
184
+ <p>This is some text.</p>
185
+ <p>
186
+ This is a
187
+ <a href="#anchor">link</a>
188
+ .
189
+ </p>
190
+ `;
191
+ export const inline = () => {
192
+ const closeEvent = new Event('close', { bubbles: true, composed: true });
193
+ return html `
194
+ <overlay-trigger type="inline">
195
+ <sp-button slot="trigger">Open</sp-button>
196
+ <sp-overlay slot="click-content">
197
+ <sp-button
198
+ @click=${(event) => {
199
+ event.target.dispatchEvent(closeEvent);
200
+ }}
201
+ >
202
+ Close
203
+ </sp-button>
204
+ </sp-overlay>
205
+ </overlay-trigger>
206
+ ${extraText}
207
+ `;
208
+ };
209
+ export const replace = () => {
210
+ const closeEvent = new Event('close', { bubbles: true, composed: true });
211
+ return html `
212
+ <overlay-trigger type="replace">
213
+ <sp-button slot="trigger">Open</sp-button>
214
+ <sp-overlay slot="click-content">
215
+ <sp-button
216
+ @click=${(event) => {
217
+ event.target.dispatchEvent(closeEvent);
218
+ }}
219
+ >
220
+ Close
221
+ </sp-button>
222
+ </sp-overlay>
223
+ </overlay-trigger>
224
+ ${extraText}
225
+ `;
226
+ };
227
+ export const modalLoose = () => {
228
+ const closeEvent = new Event('close', { bubbles: true, composed: true });
229
+ return html `
230
+ <overlay-trigger type="modal" placement="none">
231
+ <sp-button slot="trigger">Open</sp-button>
232
+ <sp-dialog
233
+ size="s"
234
+ dismissable
235
+ slot="click-content"
236
+ @closed=${(event) => event.target.dispatchEvent(closeEvent)}
237
+ >
238
+ <h2 slot="heading">Loose Dialog</h2>
239
+ <p>
240
+ The
241
+ <code>sp-dialog</code>
242
+ element is not "meant" to be a modal alone. In that way it
243
+ does not manage its own
244
+ <code>open</code>
245
+ attribute or outline when it should have
246
+ <code>pointer-events: auto</code>
247
+ . It's a part of this test suite to prove that content in
248
+ this way can be used in an
249
+ <code>overlay-trigger</code>
250
+ element.
251
+ </p>
252
+ </sp-dialog>
253
+ </overlay-trigger>
254
+ ${extraText}
255
+ `;
256
+ };
257
+ export const modalManaged = () => {
258
+ const closeEvent = new Event('close', { bubbles: true, composed: true });
259
+ return html `
260
+ <overlay-trigger type="modal" placement="none">
261
+ <sp-button slot="trigger">Open</sp-button>
262
+ <sp-dialog-wrapper
263
+ underlay
264
+ slot="click-content"
265
+ headline="Wrapped Dialog w/ Hero Image"
266
+ confirm-label="Keep Both"
267
+ secondary-label="Replace"
268
+ cancel-label="Cancel"
269
+ footer="Content for footer"
270
+ @confirm=${(event) => {
271
+ event.target.dispatchEvent(closeEvent);
272
+ }}
273
+ @secondary=${(event) => {
274
+ event.target.dispatchEvent(closeEvent);
275
+ }}
276
+ @cancel=${(event) => {
277
+ event.target.dispatchEvent(closeEvent);
278
+ }}
279
+ >
280
+ <p>
281
+ The
282
+ <code>sp-dialog-wrapper</code>
283
+ element has been prepared for use in an
284
+ <code>overlay-trigger</code>
285
+ element by it's combination of modal, underlay, etc. styles
286
+ and features.
287
+ </p>
288
+ </sp-dialog-wrapper>
289
+ </overlay-trigger>
290
+ ${extraText}
291
+ `;
292
+ };
293
+ export const deepNesting = () => {
294
+ const color = window.__swc_hack_knobs__.defaultColor;
295
+ const outter = color === 'light' ? 'dark' : 'light';
296
+ return html `
297
+ ${storyStyles}
298
+ <sp-theme
299
+ color=${outter}
300
+ scale=${window.__swc_hack_knobs__.defaultScale}
301
+ dir=${window.__swc_hack_knobs__.defaultDirection}
302
+ >
303
+ <sp-theme
304
+ color=${color}
305
+ scale=${window.__swc_hack_knobs__.defaultScale}
306
+ dir=${window.__swc_hack_knobs__.defaultDirection}
307
+ >
308
+ <recursive-popover
309
+ tabindex=""
310
+ style="
311
+ background-color: var(--spectrum-global-color-gray-100);
312
+ color: var(--spectrum-global-color-gray-800);
313
+ padding: var(--spectrum-global-dimension-size-225);
314
+ "
315
+ ></recursive-popover>
316
+ </sp-theme>
317
+ </sp-theme>
318
+ `;
319
+ };
320
+ export const edges = () => {
321
+ return html `
322
+ <style>
323
+ .demo {
324
+ position: absolute;
325
+ }
326
+ .top-left {
327
+ top: 0;
328
+ left: 0;
329
+ }
330
+ .top-right {
331
+ top: 0;
332
+ right: 0;
333
+ }
334
+ .bottom-right {
335
+ bottom: 0;
336
+ right: 0;
337
+ }
338
+ .bottom-left {
339
+ bottom: 0;
340
+ left: 0;
341
+ }
342
+ </style>
343
+ <overlay-trigger class="demo top-left" placement="bottom">
344
+ <sp-button slot="trigger">
345
+ Top/
346
+ <br />
347
+ Left
348
+ </sp-button>
349
+ <sp-tooltip slot="hover-content" delayed open tip="bottom">
350
+ Triskaidekaphobia and More
351
+ </sp-tooltip>
352
+ </overlay-trigger>
353
+ <overlay-trigger class="demo top-right" placement="bottom">
354
+ <sp-button slot="trigger">
355
+ Top/
356
+ <br />
357
+ Right
358
+ </sp-button>
359
+ <sp-tooltip slot="hover-content" delayed open tip="bottom">
360
+ Triskaidekaphobia and More
361
+ </sp-tooltip>
362
+ </overlay-trigger>
363
+ <overlay-trigger class="demo bottom-left" placement="top">
364
+ <sp-button slot="trigger">
365
+ Bottom/
366
+ <br />
367
+ Left
368
+ </sp-button>
369
+ <sp-tooltip slot="hover-content" delayed open tip="top">
370
+ Triskaidekaphobia and More
371
+ </sp-tooltip>
372
+ </overlay-trigger>
373
+ <overlay-trigger placement="top" class="demo bottom-right">
374
+ <sp-button slot="trigger">
375
+ Bottom/
376
+ <br />
377
+ Right
378
+ </sp-button>
379
+ <sp-tooltip slot="hover-content" delayed open tip="top">
380
+ Triskaidekaphobia and More
381
+ </sp-tooltip>
382
+ </overlay-trigger>
383
+ `;
384
+ };
385
+ export const updated = () => {
386
+ return html `
387
+ ${storyStyles}
388
+ <style>
389
+ sp-tooltip {
390
+ transition: none;
391
+ }
392
+ </style>
393
+ <overlay-drag>
394
+ <overlay-trigger class="demo top-left" placement="bottom">
395
+ <overlay-target-icon
396
+ slot="trigger"
397
+ style="translate(400px, 300px)"
398
+ ></overlay-target-icon>
399
+ <sp-tooltip slot="hover-content" delayed tip="bottom">
400
+ Click to open popover
401
+ </sp-tooltip>
402
+ <sp-popover
403
+ dialog
404
+ slot="click-content"
405
+ position="bottom"
406
+ tip
407
+ open
408
+ >
409
+ <div class="options-popover-content">
410
+ <sp-slider
411
+ value="5"
412
+ step="0.5"
413
+ min="0"
414
+ max="20"
415
+ label="Awesomeness"
416
+ ></sp-slider>
417
+ <div id="styled-div">
418
+ The background of this div should be blue
419
+ </div>
420
+ <overlay-trigger id="inner-trigger" placement="bottom">
421
+ <sp-button slot="trigger">Press Me</sp-button>
422
+ <sp-popover
423
+ dialog
424
+ slot="click-content"
425
+ placement="bottom"
426
+ tip
427
+ open
428
+ >
429
+ <div class="options-popover-content">
430
+ Another Popover
431
+ </div>
432
+ </sp-popover>
433
+
434
+ <sp-tooltip
435
+ slot="hover-content"
436
+ delayed
437
+ tip="bottom"
438
+ >
439
+ Click to open another popover.
440
+ </sp-tooltip>
441
+ </overlay-trigger>
442
+ </div>
443
+ </sp-popover>
444
+ </overlay-trigger>
445
+ </overlay-drag>
446
+ `;
447
+ };
448
+ export const sideHoverDraggable = () => {
449
+ return html `
450
+ ${storyStyles}
451
+ <style>
452
+ sp-tooltip {
453
+ transition: none;
454
+ }
455
+ </style>
456
+ <overlay-drag>
457
+ <overlay-trigger placement="right">
458
+ <overlay-target-icon slot="trigger"></overlay-target-icon>
459
+ <sp-tooltip slot="hover-content" delayed tip="right">
460
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit.
461
+ Vivamus egestas sed enim sed condimentum. Nunc facilisis
462
+ scelerisque massa sed luctus. Orci varius natoque penatibus
463
+ et magnis dis parturient montes, nascetur ridiculus mus.
464
+ Suspendisse sagittis sodales purus vitae ultricies. Integer
465
+ at dui sem. Sed quam tortor, ornare in nisi et, rhoncus
466
+ lacinia mauris. Sed vel rutrum mauris, ac pellentesque nibh.
467
+ Sed feugiat semper libero, sit amet vehicula orci fermentum
468
+ id. Vivamus imperdiet egestas luctus. Mauris tincidunt
469
+ malesuada ante, faucibus viverra nunc blandit a. Fusce et
470
+ nisl nisi. Aenean dictum quam id mollis faucibus. Nulla a
471
+ ultricies dui. In hac habitasse platea dictumst. Curabitur
472
+ gravida lobortis vestibulum.
473
+ </sp-tooltip>
474
+ </overlay-trigger>
475
+ </overlay-drag>
476
+ `;
477
+ };
478
+ export const longpress = () => {
479
+ return html `
480
+ <overlay-trigger placement="right-start">
481
+ <sp-action-button slot="trigger" hold-affordance>
482
+ <sp-icon-magnify slot="icon"></sp-icon-magnify>
483
+ </sp-action-button>
484
+ <sp-tooltip slot="hover-content">Search real hard...</sp-tooltip>
485
+ <sp-popover slot="longpress-content" tip>
486
+ <sp-action-group
487
+ @change=${(event) => event.target.dispatchEvent(new Event('close', { bubbles: true }))}
488
+ selects="single"
489
+ vertical
490
+ style="margin: calc(var(--spectrum-actiongroup-button-gap-y,var(--spectrum-global-dimension-size-100)) / 2);"
491
+ >
492
+ <sp-action-button>
493
+ <sp-icon-magnify slot="icon"></sp-icon-magnify>
494
+ </sp-action-button>
495
+ <sp-action-button>
496
+ <sp-icon-magnify slot="icon"></sp-icon-magnify>
497
+ </sp-action-button>
498
+ <sp-action-button>
499
+ <sp-icon-magnify slot="icon"></sp-icon-magnify>
500
+ </sp-action-button>
501
+ </sp-action-group>
502
+ </sp-popover>
503
+ </overlay-trigger>
504
+ `;
505
+ };
506
+ function nextFrame() {
507
+ return new Promise((res) => requestAnimationFrame(() => res()));
508
+ }
509
+ class ComplexModalReady extends HTMLElement {
510
+ constructor() {
511
+ super();
512
+ this.handleTriggerOpened = async () => {
513
+ await nextFrame();
514
+ const picker = document.querySelector('#test-picker');
515
+ picker.addEventListener('sp-opened', this.handlePickerOpen);
516
+ picker.open = true;
517
+ };
518
+ this.handlePickerOpen = async () => {
519
+ const picker = document.querySelector('#test-picker');
520
+ const actions = [nextFrame, picker.updateComplete];
521
+ await Promise.all(actions);
522
+ this.ready(true);
523
+ };
524
+ this.readyPromise = Promise.resolve(false);
525
+ this.readyPromise = new Promise((res) => {
526
+ this.ready = res;
527
+ this.setup();
528
+ });
529
+ }
530
+ async setup() {
531
+ await nextFrame();
532
+ const overlay = document.querySelector(`overlay-trigger`);
533
+ overlay.addEventListener('sp-opened', this.handleTriggerOpened);
534
+ }
535
+ get updateComplete() {
536
+ return this.readyPromise;
537
+ }
538
+ }
539
+ customElements.define('complex-modal-ready', ComplexModalReady);
540
+ const complexModalDecorator = (story) => {
541
+ return html `
542
+ ${story()}
543
+ <complex-modal-ready></complex-modal-ready>
544
+ `;
545
+ };
546
+ export const complexModal = () => {
547
+ return html `
548
+ <style>
549
+ body {
550
+ --swc-margin-test: 10px;
551
+ margin: var(--swc-margin-test);
552
+ }
553
+ sp-story-decorator::part(container) {
554
+ min-height: calc(100vh - (2 * var(--swc-margin-test)));
555
+ padding: 0;
556
+ display: grid;
557
+ place-content: center;
558
+ }
559
+ active-overlay > * {
560
+ --spectrum-global-animation-duration-100: 0ms;
561
+ --spectrum-global-animation-duration-200: 0ms;
562
+ --spectrum-global-animation-duration-300: 0ms;
563
+ --spectrum-global-animation-duration-400: 0ms;
564
+ --spectrum-global-animation-duration-500: 0ms;
565
+ --spectrum-global-animation-duration-600: 0ms;
566
+ --spectrum-global-animation-duration-700: 0ms;
567
+ --spectrum-global-animation-duration-800: 0ms;
568
+ --spectrum-global-animation-duration-900: 0ms;
569
+ --spectrum-global-animation-duration-1000: 0ms;
570
+ --spectrum-global-animation-duration-2000: 0ms;
571
+ --spectrum-global-animation-duration-4000: 0ms;
572
+ --spectrum-coachmark-animation-indicator-ring-duration: 0ms;
573
+ --swc-test-duration: 1ms;
574
+ }
575
+ </style>
576
+ <overlay-trigger type="modal" placement="none" open="click">
577
+ <sp-dialog-wrapper
578
+ slot="click-content"
579
+ headline="Dialog title"
580
+ dismissable
581
+ underlay
582
+ footer="Content for footer"
583
+ >
584
+ <sp-field-label for="test-picker">
585
+ Selection type:
586
+ </sp-field-label>
587
+ <sp-picker id="test-picker">
588
+ <sp-menu-item>Deselect</sp-menu-item>
589
+ <sp-menu-item>Select inverse</sp-menu-item>
590
+ <sp-menu-item>Feather...</sp-menu-item>
591
+ <sp-menu-item>Select and mask...</sp-menu-item>
592
+ <sp-menu-divider></sp-menu-divider>
593
+ <sp-menu-item>Save selection</sp-menu-item>
594
+ <sp-menu-item disabled>Make work path</sp-menu-item>
595
+ </sp-picker>
596
+ </sp-dialog-wrapper>
597
+ <sp-button slot="trigger" variant="primary">
598
+ Toggle Dialog
599
+ </sp-button>
600
+ </overlay-trigger>
601
+ `;
602
+ };
603
+ complexModal.decorators = [complexModalDecorator];
604
+ export const superComplexModal = () => {
605
+ return html `
606
+ <overlay-trigger type="modal" placement="none">
607
+ <sp-button slot="trigger" variant="accent">Toggle Dialog</sp-button>
608
+ <sp-popover dialog slot="click-content">
609
+ <overlay-trigger>
610
+ <sp-button slot="trigger" variant="primary">
611
+ Toggle Dialog
612
+ </sp-button>
613
+ <sp-popover dialog slot="click-content">
614
+ <overlay-trigger type="modal">
615
+ <sp-button slot="trigger" variant="secondary">
616
+ Toggle Dialog
617
+ </sp-button>
618
+ <sp-popover dialog slot="click-content">
619
+ <p>
620
+ When you get this deep, this ActiveOverlay
621
+ should be the only one in [slot="open"].
622
+ </p>
623
+ <p>
624
+ All of the rest of the ActiveOverlay
625
+ elements should have had their [slot]
626
+ attribute removed.
627
+ </p>
628
+ <p>
629
+ Closing this ActiveOverlay should replace
630
+ them...
631
+ </p>
632
+ </sp-popover>
633
+ </overlay-trigger>
634
+ </sp-popover>
635
+ </overlay-trigger>
636
+ </sp-popover>
637
+ </overlay-trigger>
638
+ `;
639
+ };
640
+ class StartEndContextmenu extends HTMLElement {
641
+ constructor() {
642
+ super();
643
+ this.attachShadow({ mode: 'open' });
644
+ this.shadowRoot.innerHTML = `
645
+ <style>
646
+ :host {
647
+ display: flex;
648
+ align-items: stretch;
649
+ }
650
+ div {
651
+ width: 50%;
652
+ height: 100%;
653
+ }
654
+ </style>
655
+ <div id="start"></div>
656
+ <div id="end"></div>
657
+ `;
658
+ }
659
+ }
660
+ customElements.define('start-end-contextmenu', StartEndContextmenu);
661
+ export const virtualElement = (args) => {
662
+ const contextMenuTemplate = (kind = '') => html `
663
+ <sp-popover
664
+ style="max-width: 33vw;"
665
+ @click=${(event) => {
666
+ var _a;
667
+ return (_a = event.target) === null || _a === void 0 ? void 0 : _a.dispatchEvent(new Event('close', { bubbles: true }));
668
+ }}
669
+ >
670
+ <sp-menu>
671
+ <sp-menu-group>
672
+ <span slot="header">Menu source: ${kind}</span>
673
+ <sp-menu-item>Deselect</sp-menu-item>
674
+ <sp-menu-item>Select inverse</sp-menu-item>
675
+ <sp-menu-item>Feather...</sp-menu-item>
676
+ <sp-menu-item>Select and mask...</sp-menu-item>
677
+ <sp-menu-divider></sp-menu-divider>
678
+ <sp-menu-item>Save selection</sp-menu-item>
679
+ <sp-menu-item disabled>Make work path</sp-menu-item>
680
+ </sp-menu-group>
681
+ </sp-menu>
682
+ </sp-popover>
683
+ `;
684
+ const pointerenter = async (event) => {
685
+ event.preventDefault();
686
+ const source = event.composedPath()[0];
687
+ const { id } = source;
688
+ const trigger = event.target;
689
+ const virtualTrigger = new VirtualTrigger(event.clientX, event.clientY);
690
+ const fragment = document.createDocumentFragment();
691
+ render(contextMenuTemplate(id), fragment);
692
+ const popover = fragment.querySelector('sp-popover');
693
+ openOverlay(trigger, 'modal', popover, {
694
+ placement: args.placement,
695
+ receivesFocus: 'auto',
696
+ virtualTrigger,
697
+ });
698
+ };
699
+ return html `
700
+ <style>
701
+ .app-root {
702
+ position: absolute;
703
+ inset: 0;
704
+ }
705
+ </style>
706
+ <start-end-contextmenu
707
+ class="app-root"
708
+ @contextmenu=${pointerenter}
709
+ ></start-end-contextmenu>
710
+ `;
711
+ };
712
+ virtualElement.args = {
713
+ placement: 'right-start',
714
+ };
715
+ export const detachedElement = () => {
716
+ let closeOverlay;
717
+ const openDetachedOverlayContent = async ({ target, }) => {
718
+ if (closeOverlay) {
719
+ closeOverlay();
720
+ closeOverlay = undefined;
721
+ return;
722
+ }
723
+ const div = document.createElement('div');
724
+ div.textContent = 'This div is overlaid';
725
+ div.setAttribute('style', `
726
+ background-color: var(--spectrum-global-color-gray-50);
727
+ color: var(--spectrum-global-color-gray-800);
728
+ border: 1px solid;
729
+ padding: 2em;
730
+ `);
731
+ closeOverlay = await Overlay.open(target, 'click', div, {
732
+ offset: 0,
733
+ placement: 'bottom',
734
+ });
735
+ };
736
+ requestAnimationFrame(() => {
737
+ openDetachedOverlayContent({
738
+ target: document.querySelector('#detached-content-trigger'),
739
+ });
740
+ });
741
+ return html `
742
+ <sp-action-button
743
+ id="detached-content-trigger"
744
+ @click=${openDetachedOverlayContent}
745
+ @sp-closed=${() => (closeOverlay = undefined)}
746
+ >
747
+ <sp-icon-open-in
748
+ slot="icon"
749
+ label="Open in overlay"
750
+ ></sp-icon-open-in>
751
+ </sp-action-button>
752
+ `;
753
+ };
754
+ class DefinedOverlayReady extends HTMLElement {
755
+ constructor() {
756
+ super();
757
+ this.handleTriggerOpened = async () => {
758
+ await nextFrame();
759
+ const popover = document.querySelector('popover-content');
760
+ if (!popover) {
761
+ return;
762
+ }
763
+ popover.addEventListener('sp-opened', this.handlePopoverOpen);
764
+ popover.button.click();
765
+ };
766
+ this.handlePopoverOpen = async () => {
767
+ await nextFrame();
768
+ this.ready(true);
769
+ };
770
+ this.readyPromise = Promise.resolve(false);
771
+ this.readyPromise = new Promise((res) => {
772
+ this.ready = res;
773
+ this.setup();
774
+ });
775
+ }
776
+ async setup() {
777
+ await nextFrame();
778
+ const overlay = document.querySelector(`overlay-trigger`);
779
+ const button = document.querySelector(`[slot="trigger"]`);
780
+ overlay.addEventListener('sp-opened', this.handleTriggerOpened);
781
+ button.click();
782
+ }
783
+ get updateComplete() {
784
+ return this.readyPromise;
785
+ }
786
+ }
787
+ customElements.define('defined-overlay-ready', DefinedOverlayReady);
788
+ const definedOverlayDecorator = (story) => {
789
+ return html `
790
+ ${story()}
791
+ <defined-overlay-ready></defined-overlay-ready>
792
+ `;
793
+ };
794
+ export const definedOverlayElement = () => {
795
+ return html `
796
+ <overlay-trigger placement="bottom" type="modal">
797
+ <sp-button variant="primary" slot="trigger">Open popover</sp-button>
798
+ <sp-popover slot="click-content" direction="bottom" dialog>
799
+ <popover-content></popover-content>
800
+ </sp-popover>
801
+ </overlay-trigger>
802
+ `;
803
+ };
804
+ definedOverlayElement.decorators = [definedOverlayDecorator];
805
+ //# sourceMappingURL=overlay.stories.js.map