@spectrum-web-components/menu 0.16.0-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.
- package/package.json +9 -9
- package/sp-menu-divider.js +1 -2
- package/sp-menu-divider.js.map +1 -1
- package/sp-menu-group.js +1 -2
- package/sp-menu-group.js.map +1 -1
- package/sp-menu-item.js +1 -2
- package/sp-menu-item.js.map +1 -1
- package/sp-menu.js +1 -2
- package/sp-menu.js.map +1 -1
- package/src/Menu.js +2 -493
- package/src/Menu.js.map +1 -1
- package/src/MenuDivider.js +1 -12
- package/src/MenuDivider.js.map +1 -1
- package/src/MenuGroup.js +2 -71
- package/src/MenuGroup.js.map +1 -1
- package/src/MenuItem.js +7 -406
- package/src/MenuItem.js.map +1 -1
- package/src/index.js +1 -4
- package/src/index.js.map +1 -1
- package/src/menu-divider.css.js +2 -4
- package/src/menu-divider.css.js.map +1 -1
- package/src/menu-group.css.js +2 -4
- package/src/menu-group.css.js.map +1 -1
- package/src/menu-item.css.js +2 -4
- package/src/menu-item.css.js.map +1 -1
- package/src/menu.css.js +2 -4
- package/src/menu.css.js.map +1 -1
- package/src/spectrum-checkmark.css.js +2 -4
- package/src/spectrum-checkmark.css.js.map +1 -1
- package/src/spectrum-chevron.css.js +2 -4
- package/src/spectrum-chevron.css.js.map +1 -1
- package/src/spectrum-itemLabel.css.js +2 -4
- package/src/spectrum-itemLabel.css.js.map +1 -1
- package/src/spectrum-menu-divider.css.js +2 -4
- package/src/spectrum-menu-divider.css.js.map +1 -1
- package/src/spectrum-menu-item.css.js +2 -4
- package/src/spectrum-menu-item.css.js.map +1 -1
- package/src/spectrum-menu-sectionHeading.css.js +2 -4
- package/src/spectrum-menu-sectionHeading.css.js.map +1 -1
- package/src/spectrum-menu.css.js +2 -4
- package/src/spectrum-menu.css.js.map +1 -1
- package/stories/menu-group.stories.js +9 -60
- package/stories/menu-group.stories.js.map +1 -1
- package/stories/menu-item.stories.js +4 -24
- package/stories/menu-item.stories.js.map +1 -1
- package/stories/menu.stories.js +8 -46
- package/stories/menu.stories.js.map +1 -1
- package/stories/submenu.stories.js +16 -153
- package/stories/submenu.stories.js.map +1 -1
- package/test/benchmark/test-basic.js +1 -7
- package/test/benchmark/test-basic.js.map +1 -1
- package/test/menu-group.test-vrt.js +1 -3
- package/test/menu-group.test-vrt.js.map +1 -1
- package/test/menu-group.test.js +6 -170
- package/test/menu-group.test.js.map +1 -1
- package/test/menu-item.test-vrt.js +1 -3
- package/test/menu-item.test-vrt.js.map +1 -1
- package/test/menu-item.test.js +8 -101
- package/test/menu-item.test.js.map +1 -1
- package/test/menu-selects.test.js +5 -504
- package/test/menu-selects.test.js.map +1 -1
- package/test/menu.test-vrt.js +1 -3
- package/test/menu.test-vrt.js.map +1 -1
- package/test/menu.test.js +17 -258
- package/test/menu.test.js.map +1 -1
- package/test/submenu.test-vrt.js +1 -3
- package/test/submenu.test-vrt.js.map +1 -1
- package/test/submenu.test.js +21 -482
- package/test/submenu.test.js.map +1 -1
package/test/submenu.test.js
CHANGED
|
@@ -1,45 +1,14 @@
|
|
|
1
|
-
import "@spectrum-web-components/menu/sp-menu.js";
|
|
2
|
-
|
|
3
|
-
|
|
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=${(
|
|
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=${(
|
|
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=${(
|
|
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=${(
|
|
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=${(
|
|
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=${(
|
|
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=${(
|
|
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
|
-
`,
|
|
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
|