@spectrum-web-components/menu 0.15.1-devmode.0 → 0.16.0

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 (69) hide show
  1. package/package.json +9 -9
  2. package/sp-menu-divider.js +1 -2
  3. package/sp-menu-divider.js.map +1 -1
  4. package/sp-menu-group.js +1 -2
  5. package/sp-menu-group.js.map +1 -1
  6. package/sp-menu-item.js +1 -2
  7. package/sp-menu-item.js.map +1 -1
  8. package/sp-menu.js +1 -2
  9. package/sp-menu.js.map +1 -1
  10. package/src/Menu.js +2 -493
  11. package/src/Menu.js.map +1 -1
  12. package/src/MenuDivider.js +1 -12
  13. package/src/MenuDivider.js.map +1 -1
  14. package/src/MenuGroup.js +2 -71
  15. package/src/MenuGroup.js.map +1 -1
  16. package/src/MenuItem.js +7 -406
  17. package/src/MenuItem.js.map +1 -1
  18. package/src/index.js +1 -4
  19. package/src/index.js.map +1 -1
  20. package/src/menu-divider.css.js +2 -4
  21. package/src/menu-divider.css.js.map +1 -1
  22. package/src/menu-group.css.js +2 -4
  23. package/src/menu-group.css.js.map +1 -1
  24. package/src/menu-item.css.js +2 -4
  25. package/src/menu-item.css.js.map +1 -1
  26. package/src/menu.css.js +2 -4
  27. package/src/menu.css.js.map +1 -1
  28. package/src/spectrum-checkmark.css.js +2 -4
  29. package/src/spectrum-checkmark.css.js.map +1 -1
  30. package/src/spectrum-chevron.css.js +2 -4
  31. package/src/spectrum-chevron.css.js.map +1 -1
  32. package/src/spectrum-itemLabel.css.js +2 -4
  33. package/src/spectrum-itemLabel.css.js.map +1 -1
  34. package/src/spectrum-menu-divider.css.js +2 -4
  35. package/src/spectrum-menu-divider.css.js.map +1 -1
  36. package/src/spectrum-menu-item.css.js +2 -4
  37. package/src/spectrum-menu-item.css.js.map +1 -1
  38. package/src/spectrum-menu-sectionHeading.css.js +2 -4
  39. package/src/spectrum-menu-sectionHeading.css.js.map +1 -1
  40. package/src/spectrum-menu.css.js +2 -4
  41. package/src/spectrum-menu.css.js.map +1 -1
  42. package/stories/menu-group.stories.js +9 -60
  43. package/stories/menu-group.stories.js.map +1 -1
  44. package/stories/menu-item.stories.js +4 -24
  45. package/stories/menu-item.stories.js.map +1 -1
  46. package/stories/menu.stories.js +8 -46
  47. package/stories/menu.stories.js.map +1 -1
  48. package/stories/submenu.stories.js +16 -153
  49. package/stories/submenu.stories.js.map +1 -1
  50. package/test/benchmark/test-basic.js +1 -7
  51. package/test/benchmark/test-basic.js.map +1 -1
  52. package/test/menu-group.test-vrt.js +1 -3
  53. package/test/menu-group.test-vrt.js.map +1 -1
  54. package/test/menu-group.test.js +6 -170
  55. package/test/menu-group.test.js.map +1 -1
  56. package/test/menu-item.test-vrt.js +1 -3
  57. package/test/menu-item.test-vrt.js.map +1 -1
  58. package/test/menu-item.test.js +8 -101
  59. package/test/menu-item.test.js.map +1 -1
  60. package/test/menu-selects.test.js +5 -504
  61. package/test/menu-selects.test.js.map +1 -1
  62. package/test/menu.test-vrt.js +1 -3
  63. package/test/menu.test-vrt.js.map +1 -1
  64. package/test/menu.test.js +17 -258
  65. package/test/menu.test.js.map +1 -1
  66. package/test/submenu.test-vrt.js +1 -3
  67. package/test/submenu.test-vrt.js.map +1 -1
  68. package/test/submenu.test.js +21 -482
  69. package/test/submenu.test.js.map +1 -1
@@ -1,45 +1,14 @@
1
- import "@spectrum-web-components/menu/sp-menu.js";
2
- import "@spectrum-web-components/menu/sp-menu-item.js";
3
- import {
4
- elementUpdated,
5
- expect,
6
- fixture,
7
- html,
8
- nextFrame,
9
- oneEvent
10
- } from "@open-wc/testing";
11
- import "@spectrum-web-components/theme/sp-theme.js";
12
- import "@spectrum-web-components/theme/src/themes.js";
13
- import { sendMouse } from "../../../test/plugins/browser.js";
14
- import { spy } from "sinon";
15
- import { sendKeys } from "@web/test-runner-commands";
16
- import "@spectrum-web-components/action-menu/sp-action-menu.js";
17
- import "@spectrum-web-components/menu/sp-menu-group.js";
18
- import "@spectrum-web-components/icons-workflow/icons/sp-icon-show-menu.js";
19
- async function styledFixture(story, dir = "ltr") {
20
- const test = await fixture(html`
21
- <sp-theme dir=${dir} scale="medium" color="dark">${story}</sp-theme>
22
- `);
23
- document.documentElement.dir = dir;
24
- return test.children[0];
25
- }
26
- describe("Submenu", () => {
27
- it("selects - pointer", async () => {
28
- const rootChanged = spy();
29
- const submenuChanged = spy();
30
- const el = await styledFixture(html`
1
+ import"@spectrum-web-components/menu/sp-menu.js";import"@spectrum-web-components/menu/sp-menu-item.js";import{elementUpdated as d,expect as m,fixture as M,html as l,nextFrame as S,oneEvent as o}from"@open-wc/testing";import"@spectrum-web-components/theme/sp-theme.js";import"@spectrum-web-components/theme/src/themes.js";import{sendMouse as p}from"../../../test/plugins/browser.js";import{spy as h}from"sinon";import{sendKeys as y}from"@web/test-runner-commands";import"@spectrum-web-components/action-menu/sp-action-menu.js";import"@spectrum-web-components/menu/sp-menu-group.js";import"@spectrum-web-components/icons-workflow/icons/sp-icon-show-menu.js";async function r(t,n="ltr"){const e=await M(l`
2
+ <sp-theme dir=${n} scale="medium" color="dark">${t}</sp-theme>
3
+ `);return document.documentElement.dir=n,e.children[0]}describe("Submenu",()=>{it("selects - pointer",async()=>{const t=h(),n=h(),e=await r(l`
31
4
  <sp-menu
32
- @change=${(event) => {
33
- rootChanged(event.target.value);
34
- }}
5
+ @change=${b=>{t(b.target.value)}}
35
6
  >
36
7
  <sp-menu-item class="root">
37
8
  Has submenu
38
9
  <sp-menu
39
10
  slot="submenu"
40
- @change=${(event) => {
41
- submenuChanged(event.target.value);
42
- }}
11
+ @change=${b=>{n(b.target.value)}}
43
12
  >
44
13
  <sp-menu-item class="submenu-item-1">
45
14
  One
@@ -53,61 +22,15 @@ describe("Submenu", () => {
53
22
  </sp-menu>
54
23
  </sp-menu-item>
55
24
  </sp-menu>
56
- `);
57
- await elementUpdated(el);
58
- const rootItem = el.querySelector(".root");
59
- const rootItemBoundingRect = rootItem.getBoundingClientRect();
60
- expect(rootItem.open).to.be.false;
61
- const opened = oneEvent(rootItem, "sp-opened");
62
- sendMouse({
63
- steps: [
64
- {
65
- type: "move",
66
- position: [
67
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
68
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
69
- ]
70
- }
71
- ]
72
- });
73
- await opened;
74
- expect(rootItem.open).to.be.true;
75
- const item2 = document.querySelector(".submenu-item-2");
76
- const item2BoundingRect = item2.getBoundingClientRect();
77
- const closed = oneEvent(rootItem, "sp-closed");
78
- sendMouse({
79
- steps: [
80
- {
81
- type: "click",
82
- position: [
83
- item2BoundingRect.left + item2BoundingRect.width / 2,
84
- item2BoundingRect.top + item2BoundingRect.height / 2
85
- ]
86
- }
87
- ]
88
- });
89
- await closed;
90
- await nextFrame();
91
- expect(rootChanged.calledWith("Has submenu"), "root changed").to.be.true;
92
- expect(submenuChanged.calledWith("Two"), "submenu changed").to.be.true;
93
- });
94
- it("closes deep tree on selection", async () => {
95
- const rootChanged = spy();
96
- const submenuChanged = spy();
97
- const subSubmenuChanged = spy();
98
- const el = await styledFixture(html`
25
+ `);await d(e);const u=e.querySelector(".root"),s=u.getBoundingClientRect();m(u.open).to.be.false;const i=o(u,"sp-opened");p({steps:[{type:"move",position:[s.left+s.width/2,s.top+s.height/2]}]}),await i,m(u.open).to.be.true;const a=document.querySelector(".submenu-item-2").getBoundingClientRect(),w=o(u,"sp-closed");p({steps:[{type:"click",position:[a.left+a.width/2,a.top+a.height/2]}]}),await w,await S(),m(t.calledWith("Has submenu"),"root changed").to.be.true,m(n.calledWith("Two"),"submenu changed").to.be.true}),it("closes deep tree on selection",async()=>{const t=h(),n=h(),e=h(),u=await r(l`
99
26
  <sp-menu
100
- @change=${(event) => {
101
- rootChanged(event.target.value);
102
- }}
27
+ @change=${g=>{t(g.target.value)}}
103
28
  >
104
29
  <sp-menu-item class="root">
105
30
  Has submenu
106
31
  <sp-menu
107
32
  slot="submenu"
108
- @change=${(event) => {
109
- submenuChanged(event.target.value);
110
- }}
33
+ @change=${g=>{n(g.target.value)}}
111
34
  >
112
35
  <sp-menu-item class="submenu-item-1">
113
36
  One
@@ -116,9 +39,7 @@ describe("Submenu", () => {
116
39
  Two
117
40
  <sp-menu
118
41
  slot="submenu"
119
- @change=${(event) => {
120
- subSubmenuChanged(event.target.value);
121
- }}
42
+ @change=${g=>{e(g.target.value)}}
122
43
  >
123
44
  <sp-menu-item class="sub-submenu-item-1">
124
45
  A
@@ -137,90 +58,15 @@ describe("Submenu", () => {
137
58
  </sp-menu>
138
59
  </sp-menu-item>
139
60
  </sp-menu>
140
- `);
141
- await elementUpdated(el);
142
- const rootItem = el.querySelector(".root");
143
- const rootItemBoundingRect = rootItem.getBoundingClientRect();
144
- expect(rootItem.open).to.be.false;
145
- const opened = oneEvent(rootItem, "sp-opened");
146
- sendMouse({
147
- steps: [
148
- {
149
- type: "move",
150
- position: [
151
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
152
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
153
- ]
154
- }
155
- ]
156
- });
157
- await opened;
158
- expect(rootItem.open).to.be.true;
159
- const item2 = document.querySelector(".submenu-item-2");
160
- const item2BoundingRect = item2.getBoundingClientRect();
161
- let closed = oneEvent(item2, "sp-opened");
162
- sendMouse({
163
- steps: [
164
- {
165
- type: "click",
166
- position: [
167
- item2BoundingRect.left + item2BoundingRect.width / 2,
168
- item2BoundingRect.top + item2BoundingRect.height / 2
169
- ]
170
- }
171
- ]
172
- });
173
- await closed;
174
- await nextFrame();
175
- expect(item2.open).to.be.true;
176
- const itemC = document.querySelector(".sub-submenu-item-3");
177
- const itemCBoundingRect = itemC.getBoundingClientRect();
178
- closed = oneEvent(rootItem, "sp-closed");
179
- sendMouse({
180
- steps: [
181
- {
182
- type: "click",
183
- position: [
184
- itemCBoundingRect.left + itemCBoundingRect.width / 2,
185
- itemCBoundingRect.top + itemCBoundingRect.height / 2
186
- ]
187
- }
188
- ]
189
- });
190
- await closed;
191
- await nextFrame();
192
- expect(rootChanged.calledWith("Has submenu"), "root changed").to.be.true;
193
- expect(submenuChanged.calledWith("Two"), "submenu changed").to.be.true;
194
- expect(subSubmenuChanged.calledWith("C"), "sub submenu changed").to.be.true;
195
- });
196
- [
197
- {
198
- dir: "ltr",
199
- openKey: "ArrowRight",
200
- closeKey: "ArrowLeft"
201
- },
202
- {
203
- dir: "rtl",
204
- openKey: "ArrowLeft",
205
- closeKey: "ArrowRight"
206
- }
207
- ].map((testData) => {
208
- it(`selects - keyboard: ${testData.dir}`, async () => {
209
- const rootChanged = spy();
210
- const submenuChanged = spy();
211
- const el = await styledFixture(html`
61
+ `);await d(u);const s=u.querySelector(".root"),i=s.getBoundingClientRect();m(s.open).to.be.false;const c=o(s,"sp-opened");p({steps:[{type:"move",position:[i.left+i.width/2,i.top+i.height/2]}]}),await c,m(s.open).to.be.true;const a=document.querySelector(".submenu-item-2"),w=a.getBoundingClientRect();let b=o(a,"sp-opened");p({steps:[{type:"click",position:[w.left+w.width/2,w.top+w.height/2]}]}),await b,await S(),m(a.open).to.be.true;const v=document.querySelector(".sub-submenu-item-3").getBoundingClientRect();b=o(s,"sp-closed"),p({steps:[{type:"click",position:[v.left+v.width/2,v.top+v.height/2]}]}),await b,await S(),m(t.calledWith("Has submenu"),"root changed").to.be.true,m(n.calledWith("Two"),"submenu changed").to.be.true,m(e.calledWith("C"),"sub submenu changed").to.be.true}),[{dir:"ltr",openKey:"ArrowRight",closeKey:"ArrowLeft"},{dir:"rtl",openKey:"ArrowLeft",closeKey:"ArrowRight"}].map(t=>{it(`selects - keyboard: ${t.dir}`,async()=>{const n=h(),e=h(),u=await r(l`
212
62
  <sp-menu
213
- @change=${(event) => {
214
- rootChanged(event.target.value);
215
- }}
63
+ @change=${a=>{n(a.target.value)}}
216
64
  >
217
65
  <sp-menu-item class="root">
218
66
  Has submenu
219
67
  <sp-menu
220
68
  slot="submenu"
221
- @change=${(event) => {
222
- submenuChanged(event.target.value);
223
- }}
69
+ @change=${a=>{e(a.target.value)}}
224
70
  >
225
71
  <sp-menu-item class="submenu-item-1">
226
72
  One
@@ -234,44 +80,7 @@ describe("Submenu", () => {
234
80
  </sp-menu>
235
81
  </sp-menu-item>
236
82
  </sp-menu>
237
- `, testData.dir);
238
- await elementUpdated(el);
239
- const rootItem = el.querySelector(".root");
240
- expect(rootItem.open).to.be.false;
241
- el.focus();
242
- await elementUpdated(el);
243
- let opened = oneEvent(rootItem, "sp-opened");
244
- sendKeys({
245
- press: testData.openKey
246
- });
247
- await opened;
248
- expect(rootItem.open).to.be.true;
249
- let closed = oneEvent(rootItem, "sp-closed");
250
- sendKeys({
251
- press: testData.closeKey
252
- });
253
- await closed;
254
- expect(rootItem.open).to.be.false;
255
- opened = oneEvent(rootItem, "sp-opened");
256
- sendKeys({
257
- press: testData.openKey
258
- });
259
- await opened;
260
- expect(rootItem.open).to.be.true;
261
- await sendKeys({
262
- press: "ArrowDown"
263
- });
264
- closed = oneEvent(rootItem, "sp-closed");
265
- sendKeys({
266
- press: "Enter"
267
- });
268
- await closed;
269
- expect(rootChanged.calledWith("Has submenu"), "root changed").to.be.true;
270
- expect(submenuChanged.calledWith("Two"), "submenu changed").to.be.true;
271
- });
272
- });
273
- it("closes on `pointerleave`", async () => {
274
- const el = await styledFixture(html`
83
+ `,t.dir);await d(u);const s=u.querySelector(".root");m(s.open).to.be.false,u.focus(),await d(u);let i=o(s,"sp-opened");y({press:t.openKey}),await i,m(s.open).to.be.true;let c=o(s,"sp-closed");y({press:t.closeKey}),await c,m(s.open).to.be.false,i=o(s,"sp-opened"),y({press:t.openKey}),await i,m(s.open).to.be.true,await y({press:"ArrowDown"}),c=o(s,"sp-closed"),y({press:"Enter"}),await c,m(n.calledWith("Has submenu"),"root changed").to.be.true,m(e.calledWith("Two"),"submenu changed").to.be.true})}),it("closes on `pointerleave`",async()=>{const t=await r(l`
275
84
  <sp-menu>
276
85
  <sp-menu-item class="root">
277
86
  Has submenu
@@ -288,42 +97,7 @@ describe("Submenu", () => {
288
97
  </sp-menu>
289
98
  </sp-menu-item>
290
99
  </sp-menu>
291
- `);
292
- await elementUpdated(el);
293
- const rootItem = el.querySelector(".root");
294
- const rootItemBoundingRect = rootItem.getBoundingClientRect();
295
- expect(rootItem.open).to.be.false;
296
- const opened = oneEvent(rootItem, "sp-opened");
297
- sendMouse({
298
- steps: [
299
- {
300
- type: "move",
301
- position: [
302
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
303
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
304
- ]
305
- }
306
- ]
307
- });
308
- await opened;
309
- expect(rootItem.open).to.be.true;
310
- const closed = oneEvent(rootItem, "sp-closed");
311
- sendMouse({
312
- steps: [
313
- {
314
- type: "move",
315
- position: [
316
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
317
- rootItemBoundingRect.top + rootItemBoundingRect.height * 2
318
- ]
319
- }
320
- ]
321
- });
322
- await closed;
323
- expect(rootItem.open).to.be.false;
324
- });
325
- it("stays open when mousing off menu item and back again", async () => {
326
- const el = await styledFixture(html`
100
+ `);await d(t);const n=t.querySelector(".root"),e=n.getBoundingClientRect();m(n.open).to.be.false;const u=o(n,"sp-opened");p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height/2]}]}),await u,m(n.open).to.be.true;const s=o(n,"sp-closed");p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height*2]}]}),await s,m(n.open).to.be.false}),it("stays open when mousing off menu item and back again",async()=>{const t=await r(l`
327
101
  <sp-menu>
328
102
  <sp-menu-item class="root">
329
103
  Has submenu
@@ -340,63 +114,7 @@ describe("Submenu", () => {
340
114
  </sp-menu>
341
115
  </sp-menu-item>
342
116
  </sp-menu>
343
- `);
344
- await elementUpdated(el);
345
- const rootItem = el.querySelector(".root");
346
- const rootItemBoundingRect = rootItem.getBoundingClientRect();
347
- expect(rootItem.open).to.be.false;
348
- const opened = oneEvent(rootItem, "sp-opened");
349
- await sendMouse({
350
- steps: [
351
- {
352
- type: "move",
353
- position: [
354
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
355
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
356
- ]
357
- }
358
- ]
359
- });
360
- await sendMouse({
361
- steps: [
362
- {
363
- type: "move",
364
- position: [
365
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
366
- rootItemBoundingRect.top + rootItemBoundingRect.height * 2
367
- ]
368
- }
369
- ]
370
- });
371
- await sendMouse({
372
- steps: [
373
- {
374
- type: "move",
375
- position: [
376
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
377
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
378
- ]
379
- }
380
- ]
381
- });
382
- await opened;
383
- expect(rootItem.open).to.be.true;
384
- const closed = oneEvent(rootItem, "sp-closed");
385
- sendMouse({
386
- steps: [
387
- {
388
- type: "move",
389
- position: [
390
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
391
- rootItemBoundingRect.top + rootItemBoundingRect.height * 2
392
- ]
393
- }
394
- ]
395
- });
396
- await closed;
397
- });
398
- it("stays open when mousing between menu item and submenu", async () => {
399
- const el = await styledFixture(html`
117
+ `);await d(t);const n=t.querySelector(".root"),e=n.getBoundingClientRect();m(n.open).to.be.false;const u=o(n,"sp-opened");await p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height/2]}]}),await p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height*2]}]}),await p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height/2]}]}),await u,m(n.open).to.be.true;const s=o(n,"sp-closed");p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height*2]}]}),await s}),it("stays open when mousing between menu item and submenu",async()=>{const t=await r(l`
400
118
  <sp-menu>
401
119
  <sp-menu-item class="root">
402
120
  Has submenu
@@ -413,50 +131,7 @@ describe("Submenu", () => {
413
131
  </sp-menu>
414
132
  </sp-menu-item>
415
133
  </sp-menu>
416
- `);
417
- await elementUpdated(el);
418
- const rootItem = el.querySelector(".root");
419
- const rootItemBoundingRect = rootItem.getBoundingClientRect();
420
- expect(rootItem.open).to.be.false;
421
- const opened = oneEvent(rootItem, "sp-opened");
422
- await sendMouse({
423
- steps: [
424
- {
425
- type: "move",
426
- position: [
427
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
428
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
429
- ]
430
- }
431
- ]
432
- });
433
- await sendMouse({
434
- steps: [
435
- {
436
- type: "move",
437
- position: [
438
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
439
- rootItemBoundingRect.top + rootItemBoundingRect.height * 2
440
- ]
441
- }
442
- ]
443
- });
444
- await sendMouse({
445
- steps: [
446
- {
447
- type: "move",
448
- position: [
449
- rootItemBoundingRect.left + rootItemBoundingRect.width * 1.5,
450
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
451
- ]
452
- }
453
- ]
454
- });
455
- await opened;
456
- expect(rootItem.open).to.be.true;
457
- });
458
- it("not opens if disabled", async () => {
459
- const el = await styledFixture(html`
134
+ `);await d(t);const n=t.querySelector(".root"),e=n.getBoundingClientRect();m(n.open).to.be.false;const u=o(n,"sp-opened");await p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height/2]}]}),await p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height*2]}]}),await p({steps:[{type:"move",position:[e.left+e.width*1.5,e.top+e.height/2]}]}),await u,m(n.open).to.be.true}),it("not opens if disabled",async()=>{const t=await r(l`
460
135
  <sp-menu>
461
136
  <sp-menu-item disabled class="root">
462
137
  Has submenu
@@ -473,27 +148,7 @@ describe("Submenu", () => {
473
148
  </sp-menu>
474
149
  </sp-menu-item>
475
150
  </sp-menu>
476
- `);
477
- await elementUpdated(el);
478
- const rootItem = el.querySelector(".root");
479
- const rootItemBoundingRect = rootItem.getBoundingClientRect();
480
- expect(rootItem.open).to.be.false;
481
- sendMouse({
482
- steps: [
483
- {
484
- type: "move",
485
- position: [
486
- rootItemBoundingRect.left + rootItemBoundingRect.width / 2,
487
- rootItemBoundingRect.top + rootItemBoundingRect.height / 2
488
- ]
489
- }
490
- ]
491
- });
492
- await new Promise((r) => setTimeout(r, 200));
493
- expect(rootItem.open).to.be.false;
494
- });
495
- it("closes all decendent submenus when closing a ancestor menu", async () => {
496
- const el = await styledFixture(html`
151
+ `);await d(t);const n=t.querySelector(".root"),e=n.getBoundingClientRect();m(n.open).to.be.false,p({steps:[{type:"move",position:[e.left+e.width/2,e.top+e.height/2]}]}),await new Promise(u=>setTimeout(u,200)),m(n.open).to.be.false}),it("closes all decendent submenus when closing a ancestor menu",async()=>{const t=await r(l`
497
152
  <sp-action-menu>
498
153
  <sp-icon-show-menu slot="icon"></sp-icon-show-menu>
499
154
  <sp-menu-group role="none">
@@ -531,39 +186,7 @@ describe("Submenu", () => {
531
186
  </sp-menu-item>
532
187
  </sp-menu-group>
533
188
  </sp-action-menu>
534
- `);
535
- const rootMenu1 = el.querySelector("#submenu-item-1");
536
- const rootMenu2 = el.querySelector("#submenu-item-3");
537
- const childMenu2 = el.querySelector("#submenu-item-2");
538
- expect(el.open).to.be.false;
539
- let opened = oneEvent(el, "sp-opened");
540
- el.click();
541
- await opened;
542
- expect(el.open).to.be.true;
543
- let activeOverlays = document.querySelectorAll("active-overlay");
544
- expect(activeOverlays.length).to.equal(1);
545
- opened = oneEvent(rootMenu1, "sp-opened");
546
- rootMenu1.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
547
- await opened;
548
- activeOverlays = document.querySelectorAll("active-overlay");
549
- expect(activeOverlays.length).to.equal(2);
550
- opened = oneEvent(childMenu2, "sp-opened");
551
- childMenu2.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
552
- await opened;
553
- activeOverlays = document.querySelectorAll("active-overlay");
554
- expect(activeOverlays.length).to.equal(3);
555
- const overlaysManaged = Promise.all([
556
- oneEvent(childMenu2, "sp-closed"),
557
- oneEvent(rootMenu1, "sp-closed"),
558
- oneEvent(rootMenu2, "sp-opened")
559
- ]);
560
- rootMenu2.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
561
- await overlaysManaged;
562
- activeOverlays = document.querySelectorAll("active-overlay");
563
- expect(activeOverlays.length).to.equal(2);
564
- });
565
- it("closes back to the first overlay without a `root` when clicking away", async () => {
566
- const el = await styledFixture(html`
189
+ `),n=t.querySelector("#submenu-item-1"),e=t.querySelector("#submenu-item-3"),u=t.querySelector("#submenu-item-2");m(t.open).to.be.false;let s=o(t,"sp-opened");t.click(),await s,m(t.open).to.be.true;let i=document.querySelectorAll("active-overlay");m(i.length).to.equal(1),s=o(n,"sp-opened"),n.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await s,i=document.querySelectorAll("active-overlay"),m(i.length).to.equal(2),s=o(u,"sp-opened"),u.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await s,i=document.querySelectorAll("active-overlay"),m(i.length).to.equal(3);const c=Promise.all([o(u,"sp-closed"),o(n,"sp-closed"),o(e,"sp-opened")]);e.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await c,i=document.querySelectorAll("active-overlay"),m(i.length).to.equal(2)}),it("closes back to the first overlay without a `root` when clicking away",async()=>{const t=await r(l`
567
190
  <sp-action-menu>
568
191
  <sp-icon-show-menu slot="icon"></sp-icon-show-menu>
569
192
  <sp-menu-group role="none">
@@ -601,38 +224,7 @@ describe("Submenu", () => {
601
224
  </sp-menu-item>
602
225
  </sp-menu-group>
603
226
  </sp-action-menu>
604
- `);
605
- const rootMenu1 = el.querySelector("#submenu-item-1");
606
- const childMenu2 = el.querySelector("#submenu-item-2");
607
- expect(el.open).to.be.false;
608
- let opened = oneEvent(el, "sp-opened");
609
- el.click();
610
- await opened;
611
- expect(el.open).to.be.true;
612
- let activeOverlays = document.querySelectorAll("active-overlay");
613
- expect(activeOverlays.length).to.equal(1);
614
- opened = oneEvent(rootMenu1, "sp-opened");
615
- rootMenu1.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
616
- await opened;
617
- activeOverlays = document.querySelectorAll("active-overlay");
618
- expect(activeOverlays.length).to.equal(2);
619
- opened = oneEvent(childMenu2, "sp-opened");
620
- childMenu2.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
621
- await opened;
622
- activeOverlays = document.querySelectorAll("active-overlay");
623
- expect(activeOverlays.length).to.equal(3);
624
- const closed = Promise.all([
625
- oneEvent(childMenu2, "sp-closed"),
626
- oneEvent(rootMenu1, "sp-closed"),
627
- oneEvent(el, "sp-closed")
628
- ]);
629
- document.body.click();
630
- await closed;
631
- activeOverlays = document.querySelectorAll("active-overlay");
632
- expect(activeOverlays.length).to.equal(0);
633
- });
634
- it("closes decendent menus when Menu Item in ancestor without a submenu is pointerentered", async () => {
635
- const el = await styledFixture(html`
227
+ `),n=t.querySelector("#submenu-item-1"),e=t.querySelector("#submenu-item-2");m(t.open).to.be.false;let u=o(t,"sp-opened");t.click(),await u,m(t.open).to.be.true;let s=document.querySelectorAll("active-overlay");m(s.length).to.equal(1),u=o(n,"sp-opened"),n.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await u,s=document.querySelectorAll("active-overlay"),m(s.length).to.equal(2),u=o(e,"sp-opened"),e.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await u,s=document.querySelectorAll("active-overlay"),m(s.length).to.equal(3);const i=Promise.all([o(e,"sp-closed"),o(n,"sp-closed"),o(t,"sp-closed")]);document.body.click(),await i,s=document.querySelectorAll("active-overlay"),m(s.length).to.equal(0)}),it("closes decendent menus when Menu Item in ancestor without a submenu is pointerentered",async()=>{const t=await r(l`
636
228
  <sp-action-menu>
637
229
  <sp-icon-show-menu slot="icon"></sp-icon-show-menu>
638
230
  <sp-menu-group role="none">
@@ -660,29 +252,7 @@ describe("Submenu", () => {
660
252
  </sp-menu-item>
661
253
  </sp-menu-group>
662
254
  </sp-action-menu>
663
- `);
664
- const rootMenu = el.querySelector("#submenu-item-1");
665
- const noSubmenu = el.querySelector("#no-submenu");
666
- expect(el.open).to.be.false;
667
- let opened = oneEvent(el, "sp-opened");
668
- el.click();
669
- await opened;
670
- expect(el.open).to.be.true;
671
- let activeOverlays = document.querySelectorAll("active-overlay");
672
- expect(activeOverlays.length).to.equal(1);
673
- opened = oneEvent(rootMenu, "sp-opened");
674
- rootMenu.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
675
- await opened;
676
- activeOverlays = document.querySelectorAll("active-overlay");
677
- expect(activeOverlays.length).to.equal(2);
678
- const closed = oneEvent(rootMenu, "sp-closed");
679
- noSubmenu.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
680
- await closed;
681
- activeOverlays = document.querySelectorAll("active-overlay");
682
- expect(activeOverlays.length).to.equal(1);
683
- });
684
- it("closes decendent menus when Menu Item in ancestor is clicked", async () => {
685
- const el = await styledFixture(html`
255
+ `),n=t.querySelector("#submenu-item-1"),e=t.querySelector("#no-submenu");m(t.open).to.be.false;let u=o(t,"sp-opened");t.click(),await u,m(t.open).to.be.true;let s=document.querySelectorAll("active-overlay");m(s.length).to.equal(1),u=o(n,"sp-opened"),n.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await u,s=document.querySelectorAll("active-overlay"),m(s.length).to.equal(2);const i=o(n,"sp-closed");e.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await i,s=document.querySelectorAll("active-overlay"),m(s.length).to.equal(1)}),it("closes decendent menus when Menu Item in ancestor is clicked",async()=>{const t=await r(l`
686
256
  <sp-action-menu>
687
257
  <sp-icon-show-menu slot="icon"></sp-icon-show-menu>
688
258
  <sp-menu-group role="none">
@@ -722,36 +292,5 @@ describe("Submenu", () => {
722
292
  </sp-menu-item>
723
293
  </sp-menu-group>
724
294
  </sp-action-menu>
725
- `);
726
- const rootMenu1 = el.querySelector("#submenu-item-1");
727
- const childMenu2 = el.querySelector("#submenu-item-2");
728
- const ancestorItem = el.querySelector("#ancestor-item");
729
- expect(el.open).to.be.false;
730
- let opened = oneEvent(el, "sp-opened");
731
- el.click();
732
- await opened;
733
- expect(el.open).to.be.true;
734
- let activeOverlays = document.querySelectorAll("active-overlay");
735
- expect(activeOverlays.length).to.equal(1);
736
- opened = oneEvent(rootMenu1, "sp-opened");
737
- rootMenu1.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
738
- await opened;
739
- activeOverlays = document.querySelectorAll("active-overlay");
740
- expect(activeOverlays.length).to.equal(2);
741
- opened = oneEvent(childMenu2, "sp-opened");
742
- childMenu2.dispatchEvent(new PointerEvent("pointerenter", { bubbles: true }));
743
- await opened;
744
- activeOverlays = document.querySelectorAll("active-overlay");
745
- expect(activeOverlays.length).to.equal(3);
746
- const closed = Promise.all([
747
- oneEvent(childMenu2, "sp-closed"),
748
- oneEvent(rootMenu1, "sp-closed"),
749
- oneEvent(el, "sp-closed")
750
- ]);
751
- ancestorItem.click();
752
- await closed;
753
- activeOverlays = document.querySelectorAll("active-overlay");
754
- expect(activeOverlays.length).to.equal(0);
755
- });
756
- });
295
+ `),n=t.querySelector("#submenu-item-1"),e=t.querySelector("#submenu-item-2"),u=t.querySelector("#ancestor-item");m(t.open).to.be.false;let s=o(t,"sp-opened");t.click(),await s,m(t.open).to.be.true;let i=document.querySelectorAll("active-overlay");m(i.length).to.equal(1),s=o(n,"sp-opened"),n.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await s,i=document.querySelectorAll("active-overlay"),m(i.length).to.equal(2),s=o(e,"sp-opened"),e.dispatchEvent(new PointerEvent("pointerenter",{bubbles:!0})),await s,i=document.querySelectorAll("active-overlay"),m(i.length).to.equal(3);const c=Promise.all([o(e,"sp-closed"),o(n,"sp-closed"),o(t,"sp-closed")]);u.click(),await c,i=document.querySelectorAll("active-overlay"),m(i.length).to.equal(0)})});
757
296
  //# sourceMappingURL=submenu.test.js.map