@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.
- package/active-overlay.d.ts +6 -0
- package/active-overlay.js +14 -0
- package/active-overlay.js.map +1 -0
- package/custom-elements.json +6 -6
- package/overlay-trigger.d.ts +6 -0
- package/overlay-trigger.js +14 -0
- package/overlay-trigger.js.map +1 -0
- package/package.json +6 -6
- package/src/ActiveOverlay.d.ts +77 -0
- package/src/ActiveOverlay.js +436 -0
- package/src/ActiveOverlay.js.map +1 -0
- package/src/OverlayTrigger.d.ts +66 -0
- package/src/OverlayTrigger.js +310 -0
- package/src/OverlayTrigger.js.map +1 -0
- package/src/VirtualTrigger.d.ts +7 -0
- package/src/VirtualTrigger.js +40 -0
- package/src/VirtualTrigger.js.map +1 -0
- package/src/active-overlay.css.d.ts +2 -0
- package/src/active-overlay.css.js +21 -0
- package/src/active-overlay.css.js.map +1 -0
- package/src/index.d.ts +6 -0
- package/src/index.js +18 -0
- package/src/index.js.map +1 -0
- package/src/loader.d.ts +2 -0
- package/src/loader.js +16 -0
- package/src/loader.js.map +1 -0
- package/src/overlay-stack.d.ts +46 -0
- package/src/overlay-stack.js +449 -0
- package/src/overlay-stack.js.map +1 -0
- package/src/overlay-timer.d.ts +22 -0
- package/src/overlay-timer.js +89 -0
- package/src/overlay-timer.js.map +1 -0
- package/src/overlay-trigger.css.d.ts +2 -0
- package/src/overlay-trigger.css.js +17 -0
- package/src/overlay-trigger.css.js.map +1 -0
- package/src/overlay-types.d.ts +52 -0
- package/src/overlay-types.js +13 -0
- package/src/overlay-types.js.map +1 -0
- package/src/overlay.d.ts +59 -0
- package/src/overlay.js +119 -0
- package/src/overlay.js.map +1 -0
- package/stories/overlay-story-components.js +292 -0
- package/stories/overlay-story-components.js.map +1 -0
- package/stories/overlay.stories.js +805 -0
- package/stories/overlay.stories.js.map +1 -0
- package/sync/overlay-trigger.d.ts +1 -0
- package/sync/overlay-trigger.js +18 -0
- 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
|