@spectrum-web-components/menu 0.35.1-rc.43 → 0.36.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 (78) hide show
  1. package/custom-elements.json +2276 -0
  2. package/package.json +10 -10
  3. package/src/Menu.d.ts +12 -17
  4. package/src/Menu.dev.js +64 -164
  5. package/src/Menu.dev.js.map +2 -2
  6. package/src/Menu.js +3 -7
  7. package/src/Menu.js.map +3 -3
  8. package/src/MenuGroup.d.ts +2 -0
  9. package/src/MenuGroup.dev.js +12 -8
  10. package/src/MenuGroup.dev.js.map +2 -2
  11. package/src/MenuGroup.js +5 -3
  12. package/src/MenuGroup.js.map +3 -3
  13. package/src/MenuItem.d.ts +32 -31
  14. package/src/MenuItem.dev.js +232 -197
  15. package/src/MenuItem.dev.js.map +3 -3
  16. package/src/MenuItem.js +25 -39
  17. package/src/MenuItem.js.map +3 -3
  18. package/src/menu-divider.css.dev.js +5 -1
  19. package/src/menu-divider.css.dev.js.map +2 -2
  20. package/src/menu-divider.css.js +7 -3
  21. package/src/menu-divider.css.js.map +2 -2
  22. package/src/menu-group.css.dev.js +23 -1
  23. package/src/menu-group.css.dev.js.map +2 -2
  24. package/src/menu-group.css.js +25 -3
  25. package/src/menu-group.css.js.map +2 -2
  26. package/src/menu-item.css.dev.js +302 -60
  27. package/src/menu-item.css.dev.js.map +2 -2
  28. package/src/menu-item.css.js +304 -62
  29. package/src/menu-item.css.js.map +2 -2
  30. package/src/menu.css.dev.js +181 -48
  31. package/src/menu.css.dev.js.map +2 -2
  32. package/src/menu.css.js +183 -50
  33. package/src/menu.css.js.map +2 -2
  34. package/src/spectrum-checkmark.css.dev.js +23 -1
  35. package/src/spectrum-checkmark.css.dev.js.map +2 -2
  36. package/src/spectrum-checkmark.css.js +25 -3
  37. package/src/spectrum-checkmark.css.js.map +2 -2
  38. package/src/spectrum-chevron.css.dev.js +3 -1
  39. package/src/spectrum-chevron.css.dev.js.map +2 -2
  40. package/src/spectrum-chevron.css.js +5 -3
  41. package/src/spectrum-chevron.css.js.map +2 -2
  42. package/src/spectrum-config.js +258 -79
  43. package/src/spectrum-menu-divider.css.dev.js +5 -1
  44. package/src/spectrum-menu-divider.css.dev.js.map +2 -2
  45. package/src/spectrum-menu-divider.css.js +7 -3
  46. package/src/spectrum-menu-divider.css.js.map +2 -2
  47. package/src/spectrum-menu-item.css.dev.js +302 -60
  48. package/src/spectrum-menu-item.css.dev.js.map +2 -2
  49. package/src/spectrum-menu-item.css.js +304 -62
  50. package/src/spectrum-menu-item.css.js.map +2 -2
  51. package/src/spectrum-menu-sectionHeading.css.dev.js +23 -1
  52. package/src/spectrum-menu-sectionHeading.css.dev.js.map +2 -2
  53. package/src/spectrum-menu-sectionHeading.css.js +25 -3
  54. package/src/spectrum-menu-sectionHeading.css.js.map +2 -2
  55. package/src/spectrum-menu.css.dev.js +180 -47
  56. package/src/spectrum-menu.css.dev.js.map +2 -2
  57. package/src/spectrum-menu.css.js +182 -49
  58. package/src/spectrum-menu.css.js.map +2 -2
  59. package/stories/index.js +30 -0
  60. package/stories/index.js.map +7 -0
  61. package/stories/menu-sizes.stories.js +11 -0
  62. package/stories/menu-sizes.stories.js.map +7 -0
  63. package/stories/menu.stories.js +24 -1
  64. package/stories/menu.stories.js.map +2 -2
  65. package/stories/submenu.stories.js +104 -117
  66. package/stories/submenu.stories.js.map +3 -3
  67. package/test/menu-group.test.js +1 -14
  68. package/test/menu-group.test.js.map +2 -2
  69. package/test/menu-item.test.js +0 -22
  70. package/test/menu-item.test.js.map +2 -2
  71. package/test/menu-selects.test.js +1 -3
  72. package/test/menu-selects.test.js.map +2 -2
  73. package/test/menu-sizes.test-vrt.js +5 -0
  74. package/test/menu-sizes.test-vrt.js.map +7 -0
  75. package/test/menu.test.js +0 -7
  76. package/test/menu.test.js.map +2 -2
  77. package/test/submenu.test.js +84 -206
  78. package/test/submenu.test.js.map +2 -2
@@ -0,0 +1,2276 @@
1
+ {
2
+ "schemaVersion": "1.0.0",
3
+ "readme": "",
4
+ "modules": [
5
+ {
6
+ "kind": "javascript-module",
7
+ "path": "sp-menu-divider.js",
8
+ "declarations": [],
9
+ "exports": [
10
+ {
11
+ "kind": "custom-element-definition",
12
+ "name": "sp-menu-divider",
13
+ "declaration": {
14
+ "name": "MenuDivider",
15
+ "module": "/src/MenuDivider.js"
16
+ }
17
+ }
18
+ ]
19
+ },
20
+ {
21
+ "kind": "javascript-module",
22
+ "path": "sp-menu-group.js",
23
+ "declarations": [],
24
+ "exports": [
25
+ {
26
+ "kind": "custom-element-definition",
27
+ "name": "sp-menu-group",
28
+ "declaration": {
29
+ "name": "MenuGroup",
30
+ "module": "/src/MenuGroup.js"
31
+ }
32
+ }
33
+ ]
34
+ },
35
+ {
36
+ "kind": "javascript-module",
37
+ "path": "sp-menu-item.js",
38
+ "declarations": [],
39
+ "exports": [
40
+ {
41
+ "kind": "custom-element-definition",
42
+ "name": "sp-menu-item",
43
+ "declaration": {
44
+ "name": "MenuItem",
45
+ "module": "/src/MenuItem.js"
46
+ }
47
+ }
48
+ ]
49
+ },
50
+ {
51
+ "kind": "javascript-module",
52
+ "path": "sp-menu.js",
53
+ "declarations": [],
54
+ "exports": [
55
+ {
56
+ "kind": "custom-element-definition",
57
+ "name": "sp-menu",
58
+ "declaration": {
59
+ "name": "Menu",
60
+ "module": "/src/Menu.js"
61
+ }
62
+ }
63
+ ]
64
+ },
65
+ {
66
+ "kind": "javascript-module",
67
+ "path": "src/Menu.js",
68
+ "declarations": [
69
+ {
70
+ "kind": "class",
71
+ "description": "Spectrum Menu Component",
72
+ "name": "Menu",
73
+ "slots": [
74
+ {
75
+ "description": "menu items to be listed in the menu",
76
+ "name": ""
77
+ }
78
+ ],
79
+ "members": [
80
+ {
81
+ "kind": "field",
82
+ "name": "isSubmenu",
83
+ "type": {
84
+ "text": "boolean"
85
+ },
86
+ "privacy": "public",
87
+ "default": "false"
88
+ },
89
+ {
90
+ "kind": "field",
91
+ "name": "label",
92
+ "type": {
93
+ "text": "string"
94
+ },
95
+ "privacy": "public",
96
+ "default": "''",
97
+ "attribute": "label",
98
+ "reflects": true
99
+ },
100
+ {
101
+ "kind": "field",
102
+ "name": "ignore",
103
+ "type": {
104
+ "text": "boolean"
105
+ },
106
+ "privacy": "public",
107
+ "default": "false",
108
+ "attribute": "ignore",
109
+ "reflects": true
110
+ },
111
+ {
112
+ "kind": "field",
113
+ "name": "selects",
114
+ "type": {
115
+ "text": "undefined | 'inherit' | 'single' | 'multiple'"
116
+ },
117
+ "privacy": "public",
118
+ "attribute": "selects",
119
+ "reflects": true
120
+ },
121
+ {
122
+ "kind": "field",
123
+ "name": "value",
124
+ "type": {
125
+ "text": "string"
126
+ },
127
+ "privacy": "public",
128
+ "default": "''",
129
+ "attribute": "value"
130
+ },
131
+ {
132
+ "kind": "field",
133
+ "name": "valueSeparator",
134
+ "type": {
135
+ "text": "string"
136
+ },
137
+ "privacy": "public",
138
+ "default": "','",
139
+ "attribute": "value-separator"
140
+ },
141
+ {
142
+ "kind": "field",
143
+ "name": "selected",
144
+ "privacy": "public",
145
+ "default": "[]"
146
+ },
147
+ {
148
+ "kind": "field",
149
+ "name": "selectedItems",
150
+ "privacy": "public",
151
+ "default": "[]"
152
+ },
153
+ {
154
+ "kind": "field",
155
+ "name": "menuSlot",
156
+ "type": {
157
+ "text": "HTMLSlotElement"
158
+ },
159
+ "privacy": "public"
160
+ },
161
+ {
162
+ "kind": "field",
163
+ "name": "childItemSet",
164
+ "privacy": "private",
165
+ "default": "new Set<MenuItem>()"
166
+ },
167
+ {
168
+ "kind": "field",
169
+ "name": "focusedItemIndex",
170
+ "type": {
171
+ "text": "number"
172
+ },
173
+ "privacy": "public",
174
+ "default": "0"
175
+ },
176
+ {
177
+ "kind": "field",
178
+ "name": "focusInItemIndex",
179
+ "type": {
180
+ "text": "number"
181
+ },
182
+ "privacy": "public",
183
+ "default": "0"
184
+ },
185
+ {
186
+ "kind": "field",
187
+ "name": "selectedItemsMap",
188
+ "privacy": "private",
189
+ "default": "new Map()"
190
+ },
191
+ {
192
+ "kind": "field",
193
+ "name": "childItems",
194
+ "type": {
195
+ "text": "MenuItem[]"
196
+ },
197
+ "privacy": "public",
198
+ "readonly": true
199
+ },
200
+ {
201
+ "kind": "field",
202
+ "name": "cachedChildItems",
203
+ "type": {
204
+ "text": "MenuItem[] | undefined"
205
+ },
206
+ "privacy": "private"
207
+ },
208
+ {
209
+ "kind": "method",
210
+ "name": "updateCachedMenuItems",
211
+ "privacy": "private",
212
+ "return": {
213
+ "type": {
214
+ "text": "MenuItem[]"
215
+ }
216
+ }
217
+ },
218
+ {
219
+ "kind": "field",
220
+ "name": "childRole",
221
+ "type": {
222
+ "text": "string"
223
+ },
224
+ "privacy": "private",
225
+ "description": "Hide this getter from web-component-analyzer until\nhttps://github.com/runem/web-component-analyzer/issues/131\nhas been addressed.",
226
+ "readonly": true
227
+ },
228
+ {
229
+ "kind": "field",
230
+ "name": "ownRole",
231
+ "type": {
232
+ "text": "string"
233
+ },
234
+ "privacy": "protected",
235
+ "readonly": true
236
+ },
237
+ {
238
+ "kind": "field",
239
+ "name": "resolvedSelects",
240
+ "type": {
241
+ "text": "SelectsType | undefined"
242
+ },
243
+ "privacy": "private"
244
+ },
245
+ {
246
+ "kind": "field",
247
+ "name": "resolvedRole",
248
+ "type": {
249
+ "text": "RoleType | undefined"
250
+ },
251
+ "privacy": "private"
252
+ },
253
+ {
254
+ "kind": "method",
255
+ "name": "onFocusableItemAddedOrUpdated",
256
+ "privacy": "private",
257
+ "return": {
258
+ "type": {
259
+ "text": "void"
260
+ }
261
+ },
262
+ "parameters": [
263
+ {
264
+ "name": "event",
265
+ "type": {
266
+ "text": "MenuItemAddedOrUpdatedEvent"
267
+ }
268
+ }
269
+ ],
270
+ "description": "When a descendant `<sp-menu-item>` element is added or updated it will dispatch\nthis event to announce its presence in the DOM. During the capture phase the first\nMenu based element that the event encounters will manage the focus state of the\ndispatching `<sp-menu-item>` element."
271
+ },
272
+ {
273
+ "kind": "method",
274
+ "name": "onSelectableItemAddedOrUpdated",
275
+ "privacy": "private",
276
+ "return": {
277
+ "type": {
278
+ "text": "void"
279
+ }
280
+ },
281
+ "parameters": [
282
+ {
283
+ "name": "event",
284
+ "type": {
285
+ "text": "MenuItemAddedOrUpdatedEvent"
286
+ }
287
+ }
288
+ ],
289
+ "description": "When a descendant `<sp-menu-item>` element is added or updated it will dispatch\nthis event to announce its presence in the DOM. During the bubble phase the first\nMenu based element that the event encounters that does not inherit selection will\nmanage the selection state of the dispatching `<sp-menu-item>` element."
290
+ },
291
+ {
292
+ "kind": "method",
293
+ "name": "addChildItem",
294
+ "privacy": "private",
295
+ "return": {
296
+ "type": {
297
+ "text": "void"
298
+ }
299
+ },
300
+ "parameters": [
301
+ {
302
+ "name": "item",
303
+ "type": {
304
+ "text": "MenuItem"
305
+ }
306
+ }
307
+ ]
308
+ },
309
+ {
310
+ "kind": "method",
311
+ "name": "removeChildItem",
312
+ "privacy": "private",
313
+ "return": {
314
+ "type": {
315
+ "text": "Promise<void>"
316
+ }
317
+ },
318
+ "parameters": [
319
+ {
320
+ "name": "event",
321
+ "type": {
322
+ "text": "MenuItemRemovedEvent"
323
+ }
324
+ }
325
+ ]
326
+ },
327
+ {
328
+ "kind": "method",
329
+ "name": "focus",
330
+ "privacy": "public",
331
+ "return": {
332
+ "type": {
333
+ "text": "void"
334
+ }
335
+ },
336
+ "parameters": [
337
+ {
338
+ "name": "{ preventScroll }",
339
+ "default": "{}",
340
+ "type": {
341
+ "text": "FocusOptions"
342
+ }
343
+ }
344
+ ]
345
+ },
346
+ {
347
+ "kind": "method",
348
+ "name": "onClick",
349
+ "privacy": "private",
350
+ "return": {
351
+ "type": {
352
+ "text": "void"
353
+ }
354
+ },
355
+ "parameters": [
356
+ {
357
+ "name": "event",
358
+ "type": {
359
+ "text": "Event"
360
+ }
361
+ }
362
+ ]
363
+ },
364
+ {
365
+ "kind": "method",
366
+ "name": "handleFocusin",
367
+ "privacy": "public",
368
+ "return": {
369
+ "type": {
370
+ "text": "void"
371
+ }
372
+ },
373
+ "parameters": [
374
+ {
375
+ "name": "event",
376
+ "type": {
377
+ "text": "FocusEvent"
378
+ }
379
+ }
380
+ ]
381
+ },
382
+ {
383
+ "kind": "method",
384
+ "name": "startListeningToKeyboard",
385
+ "privacy": "public",
386
+ "return": {
387
+ "type": {
388
+ "text": "void"
389
+ }
390
+ }
391
+ },
392
+ {
393
+ "kind": "method",
394
+ "name": "handleFocusout",
395
+ "privacy": "public",
396
+ "return": {
397
+ "type": {
398
+ "text": "void"
399
+ }
400
+ },
401
+ "parameters": [
402
+ {
403
+ "name": "event",
404
+ "type": {
405
+ "text": "FocusEvent"
406
+ }
407
+ }
408
+ ]
409
+ },
410
+ {
411
+ "kind": "method",
412
+ "name": "stopListeningToKeyboard",
413
+ "privacy": "public",
414
+ "return": {
415
+ "type": {
416
+ "text": "void"
417
+ }
418
+ }
419
+ },
420
+ {
421
+ "kind": "method",
422
+ "name": "selectOrToggleItem",
423
+ "privacy": "public",
424
+ "return": {
425
+ "type": {
426
+ "text": "Promise<void>"
427
+ }
428
+ },
429
+ "parameters": [
430
+ {
431
+ "name": "targetItem",
432
+ "type": {
433
+ "text": "MenuItem"
434
+ }
435
+ }
436
+ ]
437
+ },
438
+ {
439
+ "kind": "method",
440
+ "name": "navigateWithinMenu",
441
+ "privacy": "protected",
442
+ "return": {
443
+ "type": {
444
+ "text": "void"
445
+ }
446
+ },
447
+ "parameters": [
448
+ {
449
+ "name": "event",
450
+ "type": {
451
+ "text": "KeyboardEvent"
452
+ }
453
+ }
454
+ ]
455
+ },
456
+ {
457
+ "kind": "method",
458
+ "name": "navigateBetweenRelatedMenus",
459
+ "privacy": "protected",
460
+ "return": {
461
+ "type": {
462
+ "text": "void"
463
+ }
464
+ },
465
+ "parameters": [
466
+ {
467
+ "name": "code",
468
+ "type": {
469
+ "text": "string"
470
+ }
471
+ }
472
+ ]
473
+ },
474
+ {
475
+ "kind": "method",
476
+ "name": "handleKeydown",
477
+ "privacy": "public",
478
+ "return": {
479
+ "type": {
480
+ "text": "void"
481
+ }
482
+ },
483
+ "parameters": [
484
+ {
485
+ "name": "event",
486
+ "type": {
487
+ "text": "KeyboardEvent"
488
+ }
489
+ }
490
+ ]
491
+ },
492
+ {
493
+ "kind": "method",
494
+ "name": "focusMenuItemByOffset",
495
+ "privacy": "public",
496
+ "return": {
497
+ "type": {
498
+ "text": "MenuItem"
499
+ }
500
+ },
501
+ "parameters": [
502
+ {
503
+ "name": "offset",
504
+ "type": {
505
+ "text": "number"
506
+ }
507
+ }
508
+ ]
509
+ },
510
+ {
511
+ "kind": "method",
512
+ "name": "prepareToCleanUp",
513
+ "privacy": "private",
514
+ "return": {
515
+ "type": {
516
+ "text": "void"
517
+ }
518
+ }
519
+ },
520
+ {
521
+ "kind": "method",
522
+ "name": "updateSelectedItemIndex",
523
+ "privacy": "public",
524
+ "return": {
525
+ "type": {
526
+ "text": "void"
527
+ }
528
+ }
529
+ },
530
+ {
531
+ "kind": "field",
532
+ "name": "_willUpdateItems",
533
+ "type": {
534
+ "text": "boolean"
535
+ },
536
+ "privacy": "private",
537
+ "default": "false"
538
+ },
539
+ {
540
+ "kind": "method",
541
+ "name": "handleItemsChanged",
542
+ "privacy": "private",
543
+ "return": {
544
+ "type": {
545
+ "text": "void"
546
+ }
547
+ }
548
+ },
549
+ {
550
+ "kind": "method",
551
+ "name": "updateItemFocus",
552
+ "privacy": "private",
553
+ "return": {
554
+ "type": {
555
+ "text": "void"
556
+ }
557
+ }
558
+ },
559
+ {
560
+ "kind": "method",
561
+ "name": "forwardFocusVisibleToItem",
562
+ "privacy": "private",
563
+ "return": {
564
+ "type": {
565
+ "text": "void"
566
+ }
567
+ },
568
+ "parameters": [
569
+ {
570
+ "name": "item",
571
+ "type": {
572
+ "text": "MenuItem"
573
+ }
574
+ }
575
+ ]
576
+ },
577
+ {
578
+ "kind": "field",
579
+ "name": "_notFirstUpdated",
580
+ "type": {
581
+ "text": "boolean"
582
+ },
583
+ "privacy": "private",
584
+ "default": "false"
585
+ },
586
+ {
587
+ "kind": "method",
588
+ "name": "selectsChanged",
589
+ "privacy": "protected",
590
+ "return": {
591
+ "type": {
592
+ "text": "void"
593
+ }
594
+ }
595
+ },
596
+ {
597
+ "kind": "field",
598
+ "name": "childItemsUpdated",
599
+ "type": {
600
+ "text": "Promise<unknown[]>"
601
+ },
602
+ "privacy": "protected"
603
+ },
604
+ {
605
+ "kind": "field",
606
+ "name": "cacheUpdated",
607
+ "privacy": "protected"
608
+ },
609
+ {
610
+ "kind": "method",
611
+ "name": "getUpdateComplete",
612
+ "privacy": "protected",
613
+ "return": {
614
+ "type": {
615
+ "text": "Promise<boolean>"
616
+ }
617
+ }
618
+ }
619
+ ],
620
+ "events": [
621
+ {
622
+ "name": "change",
623
+ "type": {
624
+ "text": "Event"
625
+ },
626
+ "description": "Announces that the `value` of the element has changed"
627
+ },
628
+ {
629
+ "name": "close",
630
+ "type": {
631
+ "text": "Event"
632
+ }
633
+ }
634
+ ],
635
+ "attributes": [
636
+ {
637
+ "description": "whether the element has a specific selection algorithm that it applies to its item descendants. `single` allows only one descendent to be selected at a time. `multiple` allows many descendants to be selected. `inherit` will be applied dynamically when an ancestor of this element is actively managing the selection of its descendents. When the `selects` attribute is not present a `value` will not be maintained and the Menu Item children of this Menu will not have their `selected` state managed.",
638
+ "name": "selects",
639
+ "type": {
640
+ "text": "undefined | 'inherit' | 'single' | 'multiple'"
641
+ },
642
+ "fieldName": "selects"
643
+ },
644
+ {
645
+ "name": "label",
646
+ "type": {
647
+ "text": "string"
648
+ },
649
+ "default": "''",
650
+ "fieldName": "label"
651
+ },
652
+ {
653
+ "name": "ignore",
654
+ "type": {
655
+ "text": "boolean"
656
+ },
657
+ "default": "false",
658
+ "fieldName": "ignore"
659
+ },
660
+ {
661
+ "name": "value",
662
+ "type": {
663
+ "text": "string"
664
+ },
665
+ "default": "''",
666
+ "fieldName": "value"
667
+ },
668
+ {
669
+ "name": "value-separator",
670
+ "type": {
671
+ "text": "string"
672
+ },
673
+ "default": "','",
674
+ "fieldName": "valueSeparator"
675
+ }
676
+ ],
677
+ "mixins": [
678
+ {
679
+ "name": "SizedMixin",
680
+ "package": "@spectrum-web-components/base"
681
+ }
682
+ ],
683
+ "superclass": {
684
+ "name": "SpectrumElement",
685
+ "package": "@spectrum-web-components/base"
686
+ },
687
+ "tagName": "sp-menu",
688
+ "customElement": true
689
+ }
690
+ ],
691
+ "exports": [
692
+ {
693
+ "kind": "js",
694
+ "name": "Menu",
695
+ "declaration": {
696
+ "name": "Menu",
697
+ "module": "src/Menu.js"
698
+ }
699
+ }
700
+ ]
701
+ },
702
+ {
703
+ "kind": "javascript-module",
704
+ "path": "src/MenuDivider.js",
705
+ "declarations": [
706
+ {
707
+ "kind": "class",
708
+ "description": "",
709
+ "name": "MenuDivider",
710
+ "members": [],
711
+ "mixins": [
712
+ {
713
+ "name": "SizedMixin",
714
+ "package": "@spectrum-web-components/base"
715
+ }
716
+ ],
717
+ "superclass": {
718
+ "name": "SpectrumElement",
719
+ "package": "@spectrum-web-components/base"
720
+ },
721
+ "tagName": "sp-menu-divider",
722
+ "customElement": true
723
+ }
724
+ ],
725
+ "exports": [
726
+ {
727
+ "kind": "js",
728
+ "name": "MenuDivider",
729
+ "declaration": {
730
+ "name": "MenuDivider",
731
+ "module": "src/MenuDivider.js"
732
+ }
733
+ }
734
+ ]
735
+ },
736
+ {
737
+ "kind": "javascript-module",
738
+ "path": "src/MenuGroup.js",
739
+ "declarations": [
740
+ {
741
+ "kind": "class",
742
+ "description": "",
743
+ "name": "MenuGroup",
744
+ "slots": [
745
+ {
746
+ "description": "headline of the menu group",
747
+ "name": "header"
748
+ },
749
+ {
750
+ "description": "menu items to be listed in the group",
751
+ "name": ""
752
+ }
753
+ ],
754
+ "members": [
755
+ {
756
+ "kind": "field",
757
+ "name": "instances",
758
+ "type": {
759
+ "text": "number"
760
+ },
761
+ "privacy": "private",
762
+ "static": true,
763
+ "default": "1"
764
+ },
765
+ {
766
+ "kind": "field",
767
+ "name": "headerId",
768
+ "type": {
769
+ "text": "string"
770
+ },
771
+ "privacy": "private",
772
+ "default": "`sp-menu-group-label-${MenuGroup.instances}`"
773
+ },
774
+ {
775
+ "kind": "field",
776
+ "name": "headerElements",
777
+ "type": {
778
+ "text": "NodeListOf<HTMLElement>"
779
+ },
780
+ "privacy": "private"
781
+ },
782
+ {
783
+ "kind": "field",
784
+ "name": "headerElement",
785
+ "type": {
786
+ "text": "HTMLElement | undefined"
787
+ },
788
+ "privacy": "private"
789
+ },
790
+ {
791
+ "kind": "field",
792
+ "name": "ownRole",
793
+ "type": {
794
+ "text": "string"
795
+ },
796
+ "privacy": "protected",
797
+ "readonly": true,
798
+ "inheritedFrom": {
799
+ "name": "Menu",
800
+ "module": "src/Menu.js"
801
+ }
802
+ },
803
+ {
804
+ "kind": "method",
805
+ "name": "updateLabel",
806
+ "privacy": "protected",
807
+ "return": {
808
+ "type": {
809
+ "text": "void"
810
+ }
811
+ }
812
+ },
813
+ {
814
+ "kind": "field",
815
+ "name": "isSubmenu",
816
+ "type": {
817
+ "text": "boolean"
818
+ },
819
+ "privacy": "public",
820
+ "default": "false",
821
+ "inheritedFrom": {
822
+ "name": "Menu",
823
+ "module": "src/Menu.js"
824
+ }
825
+ },
826
+ {
827
+ "kind": "field",
828
+ "name": "label",
829
+ "type": {
830
+ "text": "string"
831
+ },
832
+ "privacy": "public",
833
+ "default": "''",
834
+ "attribute": "label",
835
+ "reflects": true,
836
+ "inheritedFrom": {
837
+ "name": "Menu",
838
+ "module": "src/Menu.js"
839
+ }
840
+ },
841
+ {
842
+ "kind": "field",
843
+ "name": "ignore",
844
+ "type": {
845
+ "text": "boolean"
846
+ },
847
+ "privacy": "public",
848
+ "default": "false",
849
+ "attribute": "ignore",
850
+ "reflects": true,
851
+ "inheritedFrom": {
852
+ "name": "Menu",
853
+ "module": "src/Menu.js"
854
+ }
855
+ },
856
+ {
857
+ "kind": "field",
858
+ "name": "selects",
859
+ "type": {
860
+ "text": "undefined | 'inherit' | 'single' | 'multiple'"
861
+ },
862
+ "privacy": "public",
863
+ "attribute": "selects",
864
+ "reflects": true,
865
+ "inheritedFrom": {
866
+ "name": "Menu",
867
+ "module": "src/Menu.js"
868
+ }
869
+ },
870
+ {
871
+ "kind": "field",
872
+ "name": "value",
873
+ "type": {
874
+ "text": "string"
875
+ },
876
+ "privacy": "public",
877
+ "default": "''",
878
+ "attribute": "value",
879
+ "inheritedFrom": {
880
+ "name": "Menu",
881
+ "module": "src/Menu.js"
882
+ }
883
+ },
884
+ {
885
+ "kind": "field",
886
+ "name": "valueSeparator",
887
+ "type": {
888
+ "text": "string"
889
+ },
890
+ "privacy": "public",
891
+ "default": "','",
892
+ "attribute": "value-separator",
893
+ "inheritedFrom": {
894
+ "name": "Menu",
895
+ "module": "src/Menu.js"
896
+ }
897
+ },
898
+ {
899
+ "kind": "field",
900
+ "name": "selected",
901
+ "privacy": "public",
902
+ "default": "[]",
903
+ "inheritedFrom": {
904
+ "name": "Menu",
905
+ "module": "src/Menu.js"
906
+ }
907
+ },
908
+ {
909
+ "kind": "field",
910
+ "name": "selectedItems",
911
+ "privacy": "public",
912
+ "default": "[]",
913
+ "inheritedFrom": {
914
+ "name": "Menu",
915
+ "module": "src/Menu.js"
916
+ }
917
+ },
918
+ {
919
+ "kind": "field",
920
+ "name": "menuSlot",
921
+ "type": {
922
+ "text": "HTMLSlotElement"
923
+ },
924
+ "privacy": "public",
925
+ "inheritedFrom": {
926
+ "name": "Menu",
927
+ "module": "src/Menu.js"
928
+ }
929
+ },
930
+ {
931
+ "kind": "field",
932
+ "name": "childItemSet",
933
+ "privacy": "private",
934
+ "default": "new Set<MenuItem>()",
935
+ "inheritedFrom": {
936
+ "name": "Menu",
937
+ "module": "src/Menu.js"
938
+ }
939
+ },
940
+ {
941
+ "kind": "field",
942
+ "name": "focusedItemIndex",
943
+ "type": {
944
+ "text": "number"
945
+ },
946
+ "privacy": "public",
947
+ "default": "0",
948
+ "inheritedFrom": {
949
+ "name": "Menu",
950
+ "module": "src/Menu.js"
951
+ }
952
+ },
953
+ {
954
+ "kind": "field",
955
+ "name": "focusInItemIndex",
956
+ "type": {
957
+ "text": "number"
958
+ },
959
+ "privacy": "public",
960
+ "default": "0",
961
+ "inheritedFrom": {
962
+ "name": "Menu",
963
+ "module": "src/Menu.js"
964
+ }
965
+ },
966
+ {
967
+ "kind": "field",
968
+ "name": "selectedItemsMap",
969
+ "privacy": "private",
970
+ "default": "new Map()",
971
+ "inheritedFrom": {
972
+ "name": "Menu",
973
+ "module": "src/Menu.js"
974
+ }
975
+ },
976
+ {
977
+ "kind": "field",
978
+ "name": "childItems",
979
+ "type": {
980
+ "text": "MenuItem[]"
981
+ },
982
+ "privacy": "public",
983
+ "readonly": true,
984
+ "inheritedFrom": {
985
+ "name": "Menu",
986
+ "module": "src/Menu.js"
987
+ }
988
+ },
989
+ {
990
+ "kind": "field",
991
+ "name": "cachedChildItems",
992
+ "type": {
993
+ "text": "MenuItem[] | undefined"
994
+ },
995
+ "privacy": "private",
996
+ "inheritedFrom": {
997
+ "name": "Menu",
998
+ "module": "src/Menu.js"
999
+ }
1000
+ },
1001
+ {
1002
+ "kind": "method",
1003
+ "name": "updateCachedMenuItems",
1004
+ "privacy": "private",
1005
+ "return": {
1006
+ "type": {
1007
+ "text": "MenuItem[]"
1008
+ }
1009
+ },
1010
+ "inheritedFrom": {
1011
+ "name": "Menu",
1012
+ "module": "src/Menu.js"
1013
+ }
1014
+ },
1015
+ {
1016
+ "kind": "field",
1017
+ "name": "childRole",
1018
+ "type": {
1019
+ "text": "string"
1020
+ },
1021
+ "privacy": "private",
1022
+ "description": "Hide this getter from web-component-analyzer until\nhttps://github.com/runem/web-component-analyzer/issues/131\nhas been addressed.",
1023
+ "readonly": true,
1024
+ "inheritedFrom": {
1025
+ "name": "Menu",
1026
+ "module": "src/Menu.js"
1027
+ }
1028
+ },
1029
+ {
1030
+ "kind": "field",
1031
+ "name": "resolvedSelects",
1032
+ "type": {
1033
+ "text": "SelectsType | undefined"
1034
+ },
1035
+ "privacy": "private",
1036
+ "inheritedFrom": {
1037
+ "name": "Menu",
1038
+ "module": "src/Menu.js"
1039
+ }
1040
+ },
1041
+ {
1042
+ "kind": "field",
1043
+ "name": "resolvedRole",
1044
+ "type": {
1045
+ "text": "RoleType | undefined"
1046
+ },
1047
+ "privacy": "private",
1048
+ "inheritedFrom": {
1049
+ "name": "Menu",
1050
+ "module": "src/Menu.js"
1051
+ }
1052
+ },
1053
+ {
1054
+ "kind": "method",
1055
+ "name": "onFocusableItemAddedOrUpdated",
1056
+ "privacy": "private",
1057
+ "return": {
1058
+ "type": {
1059
+ "text": "void"
1060
+ }
1061
+ },
1062
+ "parameters": [
1063
+ {
1064
+ "name": "event",
1065
+ "type": {
1066
+ "text": "MenuItemAddedOrUpdatedEvent"
1067
+ }
1068
+ }
1069
+ ],
1070
+ "description": "When a descendant `<sp-menu-item>` element is added or updated it will dispatch\nthis event to announce its presence in the DOM. During the capture phase the first\nMenu based element that the event encounters will manage the focus state of the\ndispatching `<sp-menu-item>` element.",
1071
+ "inheritedFrom": {
1072
+ "name": "Menu",
1073
+ "module": "src/Menu.js"
1074
+ }
1075
+ },
1076
+ {
1077
+ "kind": "method",
1078
+ "name": "onSelectableItemAddedOrUpdated",
1079
+ "privacy": "private",
1080
+ "return": {
1081
+ "type": {
1082
+ "text": "void"
1083
+ }
1084
+ },
1085
+ "parameters": [
1086
+ {
1087
+ "name": "event",
1088
+ "type": {
1089
+ "text": "MenuItemAddedOrUpdatedEvent"
1090
+ }
1091
+ }
1092
+ ],
1093
+ "description": "When a descendant `<sp-menu-item>` element is added or updated it will dispatch\nthis event to announce its presence in the DOM. During the bubble phase the first\nMenu based element that the event encounters that does not inherit selection will\nmanage the selection state of the dispatching `<sp-menu-item>` element.",
1094
+ "inheritedFrom": {
1095
+ "name": "Menu",
1096
+ "module": "src/Menu.js"
1097
+ }
1098
+ },
1099
+ {
1100
+ "kind": "method",
1101
+ "name": "addChildItem",
1102
+ "privacy": "private",
1103
+ "return": {
1104
+ "type": {
1105
+ "text": "void"
1106
+ }
1107
+ },
1108
+ "parameters": [
1109
+ {
1110
+ "name": "item",
1111
+ "type": {
1112
+ "text": "MenuItem"
1113
+ }
1114
+ }
1115
+ ],
1116
+ "inheritedFrom": {
1117
+ "name": "Menu",
1118
+ "module": "src/Menu.js"
1119
+ }
1120
+ },
1121
+ {
1122
+ "kind": "method",
1123
+ "name": "removeChildItem",
1124
+ "privacy": "private",
1125
+ "return": {
1126
+ "type": {
1127
+ "text": "Promise<void>"
1128
+ }
1129
+ },
1130
+ "parameters": [
1131
+ {
1132
+ "name": "event",
1133
+ "type": {
1134
+ "text": "MenuItemRemovedEvent"
1135
+ }
1136
+ }
1137
+ ],
1138
+ "inheritedFrom": {
1139
+ "name": "Menu",
1140
+ "module": "src/Menu.js"
1141
+ }
1142
+ },
1143
+ {
1144
+ "kind": "method",
1145
+ "name": "focus",
1146
+ "privacy": "public",
1147
+ "return": {
1148
+ "type": {
1149
+ "text": "void"
1150
+ }
1151
+ },
1152
+ "parameters": [
1153
+ {
1154
+ "name": "{ preventScroll }",
1155
+ "default": "{}",
1156
+ "type": {
1157
+ "text": "FocusOptions"
1158
+ }
1159
+ }
1160
+ ],
1161
+ "inheritedFrom": {
1162
+ "name": "Menu",
1163
+ "module": "src/Menu.js"
1164
+ }
1165
+ },
1166
+ {
1167
+ "kind": "method",
1168
+ "name": "onClick",
1169
+ "privacy": "private",
1170
+ "return": {
1171
+ "type": {
1172
+ "text": "void"
1173
+ }
1174
+ },
1175
+ "parameters": [
1176
+ {
1177
+ "name": "event",
1178
+ "type": {
1179
+ "text": "Event"
1180
+ }
1181
+ }
1182
+ ],
1183
+ "inheritedFrom": {
1184
+ "name": "Menu",
1185
+ "module": "src/Menu.js"
1186
+ }
1187
+ },
1188
+ {
1189
+ "kind": "method",
1190
+ "name": "handleFocusin",
1191
+ "privacy": "public",
1192
+ "return": {
1193
+ "type": {
1194
+ "text": "void"
1195
+ }
1196
+ },
1197
+ "parameters": [
1198
+ {
1199
+ "name": "event",
1200
+ "type": {
1201
+ "text": "FocusEvent"
1202
+ }
1203
+ }
1204
+ ],
1205
+ "inheritedFrom": {
1206
+ "name": "Menu",
1207
+ "module": "src/Menu.js"
1208
+ }
1209
+ },
1210
+ {
1211
+ "kind": "method",
1212
+ "name": "startListeningToKeyboard",
1213
+ "privacy": "public",
1214
+ "return": {
1215
+ "type": {
1216
+ "text": "void"
1217
+ }
1218
+ },
1219
+ "inheritedFrom": {
1220
+ "name": "Menu",
1221
+ "module": "src/Menu.js"
1222
+ }
1223
+ },
1224
+ {
1225
+ "kind": "method",
1226
+ "name": "handleFocusout",
1227
+ "privacy": "public",
1228
+ "return": {
1229
+ "type": {
1230
+ "text": "void"
1231
+ }
1232
+ },
1233
+ "parameters": [
1234
+ {
1235
+ "name": "event",
1236
+ "type": {
1237
+ "text": "FocusEvent"
1238
+ }
1239
+ }
1240
+ ],
1241
+ "inheritedFrom": {
1242
+ "name": "Menu",
1243
+ "module": "src/Menu.js"
1244
+ }
1245
+ },
1246
+ {
1247
+ "kind": "method",
1248
+ "name": "stopListeningToKeyboard",
1249
+ "privacy": "public",
1250
+ "return": {
1251
+ "type": {
1252
+ "text": "void"
1253
+ }
1254
+ },
1255
+ "inheritedFrom": {
1256
+ "name": "Menu",
1257
+ "module": "src/Menu.js"
1258
+ }
1259
+ },
1260
+ {
1261
+ "kind": "method",
1262
+ "name": "selectOrToggleItem",
1263
+ "privacy": "public",
1264
+ "return": {
1265
+ "type": {
1266
+ "text": "Promise<void>"
1267
+ }
1268
+ },
1269
+ "parameters": [
1270
+ {
1271
+ "name": "targetItem",
1272
+ "type": {
1273
+ "text": "MenuItem"
1274
+ }
1275
+ }
1276
+ ],
1277
+ "inheritedFrom": {
1278
+ "name": "Menu",
1279
+ "module": "src/Menu.js"
1280
+ }
1281
+ },
1282
+ {
1283
+ "kind": "method",
1284
+ "name": "navigateWithinMenu",
1285
+ "privacy": "protected",
1286
+ "return": {
1287
+ "type": {
1288
+ "text": "void"
1289
+ }
1290
+ },
1291
+ "parameters": [
1292
+ {
1293
+ "name": "event",
1294
+ "type": {
1295
+ "text": "KeyboardEvent"
1296
+ }
1297
+ }
1298
+ ],
1299
+ "inheritedFrom": {
1300
+ "name": "Menu",
1301
+ "module": "src/Menu.js"
1302
+ }
1303
+ },
1304
+ {
1305
+ "kind": "method",
1306
+ "name": "navigateBetweenRelatedMenus",
1307
+ "privacy": "protected",
1308
+ "return": {
1309
+ "type": {
1310
+ "text": "void"
1311
+ }
1312
+ },
1313
+ "parameters": [
1314
+ {
1315
+ "name": "code",
1316
+ "type": {
1317
+ "text": "string"
1318
+ }
1319
+ }
1320
+ ],
1321
+ "inheritedFrom": {
1322
+ "name": "Menu",
1323
+ "module": "src/Menu.js"
1324
+ }
1325
+ },
1326
+ {
1327
+ "kind": "method",
1328
+ "name": "handleKeydown",
1329
+ "privacy": "public",
1330
+ "return": {
1331
+ "type": {
1332
+ "text": "void"
1333
+ }
1334
+ },
1335
+ "parameters": [
1336
+ {
1337
+ "name": "event",
1338
+ "type": {
1339
+ "text": "KeyboardEvent"
1340
+ }
1341
+ }
1342
+ ],
1343
+ "inheritedFrom": {
1344
+ "name": "Menu",
1345
+ "module": "src/Menu.js"
1346
+ }
1347
+ },
1348
+ {
1349
+ "kind": "method",
1350
+ "name": "focusMenuItemByOffset",
1351
+ "privacy": "public",
1352
+ "return": {
1353
+ "type": {
1354
+ "text": "MenuItem"
1355
+ }
1356
+ },
1357
+ "parameters": [
1358
+ {
1359
+ "name": "offset",
1360
+ "type": {
1361
+ "text": "number"
1362
+ }
1363
+ }
1364
+ ],
1365
+ "inheritedFrom": {
1366
+ "name": "Menu",
1367
+ "module": "src/Menu.js"
1368
+ }
1369
+ },
1370
+ {
1371
+ "kind": "method",
1372
+ "name": "prepareToCleanUp",
1373
+ "privacy": "private",
1374
+ "return": {
1375
+ "type": {
1376
+ "text": "void"
1377
+ }
1378
+ },
1379
+ "inheritedFrom": {
1380
+ "name": "Menu",
1381
+ "module": "src/Menu.js"
1382
+ }
1383
+ },
1384
+ {
1385
+ "kind": "method",
1386
+ "name": "updateSelectedItemIndex",
1387
+ "privacy": "public",
1388
+ "return": {
1389
+ "type": {
1390
+ "text": "void"
1391
+ }
1392
+ },
1393
+ "inheritedFrom": {
1394
+ "name": "Menu",
1395
+ "module": "src/Menu.js"
1396
+ }
1397
+ },
1398
+ {
1399
+ "kind": "field",
1400
+ "name": "_willUpdateItems",
1401
+ "type": {
1402
+ "text": "boolean"
1403
+ },
1404
+ "privacy": "private",
1405
+ "default": "false",
1406
+ "inheritedFrom": {
1407
+ "name": "Menu",
1408
+ "module": "src/Menu.js"
1409
+ }
1410
+ },
1411
+ {
1412
+ "kind": "method",
1413
+ "name": "handleItemsChanged",
1414
+ "privacy": "private",
1415
+ "return": {
1416
+ "type": {
1417
+ "text": "void"
1418
+ }
1419
+ },
1420
+ "inheritedFrom": {
1421
+ "name": "Menu",
1422
+ "module": "src/Menu.js"
1423
+ }
1424
+ },
1425
+ {
1426
+ "kind": "method",
1427
+ "name": "updateItemFocus",
1428
+ "privacy": "private",
1429
+ "return": {
1430
+ "type": {
1431
+ "text": "void"
1432
+ }
1433
+ },
1434
+ "inheritedFrom": {
1435
+ "name": "Menu",
1436
+ "module": "src/Menu.js"
1437
+ }
1438
+ },
1439
+ {
1440
+ "kind": "method",
1441
+ "name": "forwardFocusVisibleToItem",
1442
+ "privacy": "private",
1443
+ "return": {
1444
+ "type": {
1445
+ "text": "void"
1446
+ }
1447
+ },
1448
+ "parameters": [
1449
+ {
1450
+ "name": "item",
1451
+ "type": {
1452
+ "text": "MenuItem"
1453
+ }
1454
+ }
1455
+ ],
1456
+ "inheritedFrom": {
1457
+ "name": "Menu",
1458
+ "module": "src/Menu.js"
1459
+ }
1460
+ },
1461
+ {
1462
+ "kind": "field",
1463
+ "name": "_notFirstUpdated",
1464
+ "type": {
1465
+ "text": "boolean"
1466
+ },
1467
+ "privacy": "private",
1468
+ "default": "false",
1469
+ "inheritedFrom": {
1470
+ "name": "Menu",
1471
+ "module": "src/Menu.js"
1472
+ }
1473
+ },
1474
+ {
1475
+ "kind": "method",
1476
+ "name": "selectsChanged",
1477
+ "privacy": "protected",
1478
+ "return": {
1479
+ "type": {
1480
+ "text": "void"
1481
+ }
1482
+ },
1483
+ "inheritedFrom": {
1484
+ "name": "Menu",
1485
+ "module": "src/Menu.js"
1486
+ }
1487
+ },
1488
+ {
1489
+ "kind": "field",
1490
+ "name": "childItemsUpdated",
1491
+ "type": {
1492
+ "text": "Promise<unknown[]>"
1493
+ },
1494
+ "privacy": "protected",
1495
+ "inheritedFrom": {
1496
+ "name": "Menu",
1497
+ "module": "src/Menu.js"
1498
+ }
1499
+ },
1500
+ {
1501
+ "kind": "field",
1502
+ "name": "cacheUpdated",
1503
+ "privacy": "protected",
1504
+ "inheritedFrom": {
1505
+ "name": "Menu",
1506
+ "module": "src/Menu.js"
1507
+ }
1508
+ },
1509
+ {
1510
+ "kind": "method",
1511
+ "name": "getUpdateComplete",
1512
+ "privacy": "protected",
1513
+ "return": {
1514
+ "type": {
1515
+ "text": "Promise<boolean>"
1516
+ }
1517
+ },
1518
+ "inheritedFrom": {
1519
+ "name": "Menu",
1520
+ "module": "src/Menu.js"
1521
+ }
1522
+ }
1523
+ ],
1524
+ "superclass": {
1525
+ "name": "Menu",
1526
+ "module": "/src/Menu.js"
1527
+ },
1528
+ "tagName": "sp-menu-group",
1529
+ "customElement": true,
1530
+ "attributes": [
1531
+ {
1532
+ "description": "whether the element has a specific selection algorithm that it applies to its item descendants. `single` allows only one descendent to be selected at a time. `multiple` allows many descendants to be selected. `inherit` will be applied dynamically when an ancestor of this element is actively managing the selection of its descendents. When the `selects` attribute is not present a `value` will not be maintained and the Menu Item children of this Menu will not have their `selected` state managed.",
1533
+ "name": "selects",
1534
+ "type": {
1535
+ "text": "undefined | 'inherit' | 'single' | 'multiple'"
1536
+ },
1537
+ "fieldName": "selects",
1538
+ "inheritedFrom": {
1539
+ "name": "Menu",
1540
+ "module": "src/Menu.ts"
1541
+ }
1542
+ },
1543
+ {
1544
+ "name": "label",
1545
+ "type": {
1546
+ "text": "string"
1547
+ },
1548
+ "default": "''",
1549
+ "fieldName": "label",
1550
+ "inheritedFrom": {
1551
+ "name": "Menu",
1552
+ "module": "src/Menu.ts"
1553
+ }
1554
+ },
1555
+ {
1556
+ "name": "ignore",
1557
+ "type": {
1558
+ "text": "boolean"
1559
+ },
1560
+ "default": "false",
1561
+ "fieldName": "ignore",
1562
+ "inheritedFrom": {
1563
+ "name": "Menu",
1564
+ "module": "src/Menu.ts"
1565
+ }
1566
+ },
1567
+ {
1568
+ "name": "value",
1569
+ "type": {
1570
+ "text": "string"
1571
+ },
1572
+ "default": "''",
1573
+ "fieldName": "value",
1574
+ "inheritedFrom": {
1575
+ "name": "Menu",
1576
+ "module": "src/Menu.ts"
1577
+ }
1578
+ },
1579
+ {
1580
+ "name": "value-separator",
1581
+ "type": {
1582
+ "text": "string"
1583
+ },
1584
+ "default": "','",
1585
+ "fieldName": "valueSeparator",
1586
+ "inheritedFrom": {
1587
+ "name": "Menu",
1588
+ "module": "src/Menu.ts"
1589
+ }
1590
+ }
1591
+ ],
1592
+ "events": [
1593
+ {
1594
+ "name": "change",
1595
+ "type": {
1596
+ "text": "Event"
1597
+ },
1598
+ "description": "Announces that the `value` of the element has changed",
1599
+ "inheritedFrom": {
1600
+ "name": "Menu",
1601
+ "module": "src/Menu.ts"
1602
+ }
1603
+ },
1604
+ {
1605
+ "name": "close",
1606
+ "type": {
1607
+ "text": "Event"
1608
+ },
1609
+ "inheritedFrom": {
1610
+ "name": "Menu",
1611
+ "module": "src/Menu.ts"
1612
+ }
1613
+ }
1614
+ ]
1615
+ }
1616
+ ],
1617
+ "exports": [
1618
+ {
1619
+ "kind": "js",
1620
+ "name": "MenuGroup",
1621
+ "declaration": {
1622
+ "name": "MenuGroup",
1623
+ "module": "src/MenuGroup.js"
1624
+ }
1625
+ }
1626
+ ]
1627
+ },
1628
+ {
1629
+ "kind": "javascript-module",
1630
+ "path": "src/MenuItem.js",
1631
+ "declarations": [
1632
+ {
1633
+ "kind": "class",
1634
+ "description": "",
1635
+ "name": "MenuItemRemovedEvent",
1636
+ "members": [
1637
+ {
1638
+ "kind": "field",
1639
+ "name": "item",
1640
+ "type": {
1641
+ "text": "MenuItem"
1642
+ },
1643
+ "readonly": true
1644
+ },
1645
+ {
1646
+ "kind": "field",
1647
+ "name": "_item",
1648
+ "type": {
1649
+ "text": "MenuItem"
1650
+ }
1651
+ },
1652
+ {
1653
+ "kind": "field",
1654
+ "name": "focused",
1655
+ "type": {
1656
+ "text": "boolean"
1657
+ },
1658
+ "default": "false"
1659
+ },
1660
+ {
1661
+ "kind": "method",
1662
+ "name": "reset",
1663
+ "return": {
1664
+ "type": {
1665
+ "text": "void"
1666
+ }
1667
+ },
1668
+ "parameters": [
1669
+ {
1670
+ "name": "item",
1671
+ "type": {
1672
+ "text": "MenuItem"
1673
+ }
1674
+ }
1675
+ ]
1676
+ }
1677
+ ],
1678
+ "superclass": {
1679
+ "name": "Event",
1680
+ "module": "src/MenuItem.ts"
1681
+ }
1682
+ },
1683
+ {
1684
+ "kind": "class",
1685
+ "description": "",
1686
+ "name": "MenuItemAddedOrUpdatedEvent",
1687
+ "members": [
1688
+ {
1689
+ "kind": "field",
1690
+ "name": "focusRoot"
1691
+ },
1692
+ {
1693
+ "kind": "field",
1694
+ "name": "selectionRoot"
1695
+ },
1696
+ {
1697
+ "kind": "field",
1698
+ "name": "item",
1699
+ "type": {
1700
+ "text": "MenuItem"
1701
+ },
1702
+ "readonly": true
1703
+ },
1704
+ {
1705
+ "kind": "field",
1706
+ "name": "_item",
1707
+ "type": {
1708
+ "text": "MenuItem"
1709
+ }
1710
+ },
1711
+ {
1712
+ "kind": "field",
1713
+ "name": "currentAncestorWithSelects",
1714
+ "type": {
1715
+ "text": "Menu | undefined"
1716
+ }
1717
+ },
1718
+ {
1719
+ "kind": "field",
1720
+ "name": "_currentAncestorWithSelects",
1721
+ "type": {
1722
+ "text": "Menu | undefined"
1723
+ }
1724
+ },
1725
+ {
1726
+ "kind": "method",
1727
+ "name": "reset",
1728
+ "return": {
1729
+ "type": {
1730
+ "text": "void"
1731
+ }
1732
+ },
1733
+ "parameters": [
1734
+ {
1735
+ "name": "item",
1736
+ "type": {
1737
+ "text": "MenuItem"
1738
+ }
1739
+ }
1740
+ ]
1741
+ }
1742
+ ],
1743
+ "superclass": {
1744
+ "name": "Event",
1745
+ "module": "src/MenuItem.ts"
1746
+ }
1747
+ },
1748
+ {
1749
+ "kind": "class",
1750
+ "description": "",
1751
+ "name": "MenuItem",
1752
+ "slots": [
1753
+ {
1754
+ "description": "text content to display within the Menu Item",
1755
+ "name": ""
1756
+ },
1757
+ {
1758
+ "description": "icon element to be placed at the start of the Menu Item",
1759
+ "name": "icon"
1760
+ },
1761
+ {
1762
+ "description": "content placed at the end of the Menu Item like values, keyboard shortcuts, etc.",
1763
+ "name": "value"
1764
+ },
1765
+ {
1766
+ "description": "content placed in a submenu",
1767
+ "name": "submenu"
1768
+ }
1769
+ ],
1770
+ "members": [
1771
+ {
1772
+ "kind": "field",
1773
+ "name": "instanceCount",
1774
+ "type": {
1775
+ "text": "number"
1776
+ },
1777
+ "static": true,
1778
+ "default": "0"
1779
+ },
1780
+ {
1781
+ "kind": "field",
1782
+ "name": "isInSubmenu",
1783
+ "type": {
1784
+ "text": "boolean"
1785
+ },
1786
+ "privacy": "private",
1787
+ "default": "false"
1788
+ },
1789
+ {
1790
+ "kind": "field",
1791
+ "name": "active",
1792
+ "type": {
1793
+ "text": "boolean"
1794
+ },
1795
+ "privacy": "public",
1796
+ "default": "false",
1797
+ "attribute": "active",
1798
+ "reflects": true
1799
+ },
1800
+ {
1801
+ "kind": "field",
1802
+ "name": "focused",
1803
+ "type": {
1804
+ "text": "boolean"
1805
+ },
1806
+ "privacy": "public",
1807
+ "default": "false",
1808
+ "attribute": "focused",
1809
+ "reflects": true
1810
+ },
1811
+ {
1812
+ "kind": "field",
1813
+ "name": "selected",
1814
+ "type": {
1815
+ "text": "boolean"
1816
+ },
1817
+ "privacy": "public",
1818
+ "default": "false",
1819
+ "attribute": "selected",
1820
+ "reflects": true
1821
+ },
1822
+ {
1823
+ "kind": "field",
1824
+ "name": "value",
1825
+ "type": {
1826
+ "text": "string"
1827
+ },
1828
+ "privacy": "public",
1829
+ "attribute": "value"
1830
+ },
1831
+ {
1832
+ "kind": "field",
1833
+ "name": "_value",
1834
+ "type": {
1835
+ "text": "string"
1836
+ },
1837
+ "privacy": "private",
1838
+ "default": "''"
1839
+ },
1840
+ {
1841
+ "kind": "field",
1842
+ "name": "itemText",
1843
+ "type": {
1844
+ "text": "string"
1845
+ },
1846
+ "privacy": "private",
1847
+ "readonly": true
1848
+ },
1849
+ {
1850
+ "kind": "field",
1851
+ "name": "hasSubmenu",
1852
+ "type": {
1853
+ "text": "boolean"
1854
+ },
1855
+ "privacy": "public",
1856
+ "default": "false",
1857
+ "attribute": "has-submenu",
1858
+ "reflects": true
1859
+ },
1860
+ {
1861
+ "kind": "field",
1862
+ "name": "noWrap",
1863
+ "type": {
1864
+ "text": "boolean"
1865
+ },
1866
+ "privacy": "public",
1867
+ "default": "false",
1868
+ "attribute": "no-wrap",
1869
+ "reflects": true
1870
+ },
1871
+ {
1872
+ "kind": "field",
1873
+ "name": "anchorElement",
1874
+ "type": {
1875
+ "text": "HTMLAnchorElement"
1876
+ },
1877
+ "privacy": "private"
1878
+ },
1879
+ {
1880
+ "kind": "field",
1881
+ "name": "focusElement",
1882
+ "type": {
1883
+ "text": "HTMLElement"
1884
+ },
1885
+ "privacy": "public",
1886
+ "readonly": true
1887
+ },
1888
+ {
1889
+ "kind": "field",
1890
+ "name": "hasIcon",
1891
+ "type": {
1892
+ "text": "boolean"
1893
+ },
1894
+ "privacy": "protected",
1895
+ "readonly": true
1896
+ },
1897
+ {
1898
+ "kind": "field",
1899
+ "name": "itemChildren",
1900
+ "type": {
1901
+ "text": "MenuItemChildren"
1902
+ },
1903
+ "privacy": "public",
1904
+ "readonly": true
1905
+ },
1906
+ {
1907
+ "kind": "field",
1908
+ "name": "_itemChildren",
1909
+ "type": {
1910
+ "text": "MenuItemChildren | undefined"
1911
+ },
1912
+ "privacy": "private"
1913
+ },
1914
+ {
1915
+ "kind": "field",
1916
+ "name": "open",
1917
+ "type": {
1918
+ "text": "boolean"
1919
+ },
1920
+ "privacy": "public",
1921
+ "default": "false",
1922
+ "attribute": "open"
1923
+ },
1924
+ {
1925
+ "kind": "method",
1926
+ "name": "click",
1927
+ "privacy": "public",
1928
+ "return": {
1929
+ "type": {
1930
+ "text": "void"
1931
+ }
1932
+ }
1933
+ },
1934
+ {
1935
+ "kind": "method",
1936
+ "name": "handleClickCapture",
1937
+ "privacy": "private",
1938
+ "return": {
1939
+ "type": {
1940
+ "text": "void | boolean"
1941
+ }
1942
+ },
1943
+ "parameters": [
1944
+ {
1945
+ "name": "event",
1946
+ "type": {
1947
+ "text": "Event"
1948
+ }
1949
+ }
1950
+ ]
1951
+ },
1952
+ {
1953
+ "kind": "method",
1954
+ "name": "proxyFocus",
1955
+ "privacy": "private",
1956
+ "return": {
1957
+ "type": {
1958
+ "text": "void"
1959
+ }
1960
+ }
1961
+ },
1962
+ {
1963
+ "kind": "method",
1964
+ "name": "shouldProxyClick",
1965
+ "privacy": "private",
1966
+ "return": {
1967
+ "type": {
1968
+ "text": "boolean"
1969
+ }
1970
+ }
1971
+ },
1972
+ {
1973
+ "kind": "method",
1974
+ "name": "breakItemChildrenCache",
1975
+ "privacy": "protected",
1976
+ "return": {
1977
+ "type": {
1978
+ "text": "void"
1979
+ }
1980
+ }
1981
+ },
1982
+ {
1983
+ "kind": "method",
1984
+ "name": "manageSubmenu",
1985
+ "privacy": "protected",
1986
+ "return": {
1987
+ "type": {
1988
+ "text": "void"
1989
+ }
1990
+ },
1991
+ "parameters": [
1992
+ {
1993
+ "name": "event",
1994
+ "type": {
1995
+ "text": "Event & { target: HTMLSlotElement }"
1996
+ }
1997
+ }
1998
+ ]
1999
+ },
2000
+ {
2001
+ "kind": "method",
2002
+ "name": "handleRemoveActive",
2003
+ "privacy": "private",
2004
+ "return": {
2005
+ "type": {
2006
+ "text": "void"
2007
+ }
2008
+ },
2009
+ "parameters": [
2010
+ {
2011
+ "name": "event",
2012
+ "type": {
2013
+ "text": "Event"
2014
+ }
2015
+ }
2016
+ ]
2017
+ },
2018
+ {
2019
+ "kind": "method",
2020
+ "name": "handlePointerdown",
2021
+ "privacy": "private",
2022
+ "return": {
2023
+ "type": {
2024
+ "text": "void"
2025
+ }
2026
+ }
2027
+ },
2028
+ {
2029
+ "kind": "method",
2030
+ "name": "closeOverlaysForRoot",
2031
+ "privacy": "protected",
2032
+ "return": {
2033
+ "type": {
2034
+ "text": "void"
2035
+ }
2036
+ }
2037
+ },
2038
+ {
2039
+ "kind": "field",
2040
+ "name": "closeOverlay",
2041
+ "type": {
2042
+ "text": "() => Promise<void> | undefined"
2043
+ },
2044
+ "privacy": "public"
2045
+ },
2046
+ {
2047
+ "kind": "method",
2048
+ "name": "handleSubmenuClick",
2049
+ "privacy": "protected",
2050
+ "return": {
2051
+ "type": {
2052
+ "text": "void"
2053
+ }
2054
+ }
2055
+ },
2056
+ {
2057
+ "kind": "method",
2058
+ "name": "handlePointerenter",
2059
+ "privacy": "protected",
2060
+ "return": {
2061
+ "type": {
2062
+ "text": "void"
2063
+ }
2064
+ }
2065
+ },
2066
+ {
2067
+ "kind": "field",
2068
+ "name": "leaveTimeout",
2069
+ "type": {
2070
+ "text": "ReturnType<typeof setTimeout> | undefined"
2071
+ },
2072
+ "privacy": "protected"
2073
+ },
2074
+ {
2075
+ "kind": "method",
2076
+ "name": "handlePointerleave",
2077
+ "privacy": "protected",
2078
+ "return": {
2079
+ "type": {
2080
+ "text": "void"
2081
+ }
2082
+ }
2083
+ },
2084
+ {
2085
+ "kind": "field",
2086
+ "name": "handleSubmenuChange",
2087
+ "privacy": "protected",
2088
+ "description": "When there is a `change` event in the submenu for this item\nthen we \"click\" this item to cascade the selection up the\nmenu tree allowing all submenus between the initial selection\nand the root of the tree to have their selection changes and\nbe closed."
2089
+ },
2090
+ {
2091
+ "kind": "field",
2092
+ "name": "handleSubmenuPointerenter",
2093
+ "privacy": "protected"
2094
+ },
2095
+ {
2096
+ "kind": "method",
2097
+ "name": "openOverlay",
2098
+ "privacy": "public",
2099
+ "return": {
2100
+ "type": {
2101
+ "text": "Promise<void>"
2102
+ }
2103
+ }
2104
+ },
2105
+ {
2106
+ "kind": "method",
2107
+ "name": "updateAriaSelected",
2108
+ "return": {
2109
+ "type": {
2110
+ "text": "void"
2111
+ }
2112
+ }
2113
+ },
2114
+ {
2115
+ "kind": "method",
2116
+ "name": "setRole",
2117
+ "privacy": "public",
2118
+ "return": {
2119
+ "type": {
2120
+ "text": "void"
2121
+ }
2122
+ },
2123
+ "parameters": [
2124
+ {
2125
+ "name": "role",
2126
+ "type": {
2127
+ "text": "string"
2128
+ }
2129
+ }
2130
+ ]
2131
+ },
2132
+ {
2133
+ "kind": "field",
2134
+ "name": "_parentElement",
2135
+ "type": {
2136
+ "text": "HTMLElement"
2137
+ }
2138
+ },
2139
+ {
2140
+ "kind": "method",
2141
+ "name": "triggerUpdate",
2142
+ "privacy": "public",
2143
+ "return": {
2144
+ "type": {
2145
+ "text": "Promise<void>"
2146
+ }
2147
+ }
2148
+ },
2149
+ {
2150
+ "kind": "field",
2151
+ "name": "menuData",
2152
+ "type": {
2153
+ "text": "{\n focusRoot?: Menu;\n selectionRoot?: Menu;\n }"
2154
+ },
2155
+ "privacy": "public",
2156
+ "default": "{\n focusRoot: undefined,\n selectionRoot: undefined,\n }"
2157
+ }
2158
+ ],
2159
+ "events": [
2160
+ {
2161
+ "description": "announces the item has been added so a parent menu can take ownerships",
2162
+ "name": "sp-menu-item-added"
2163
+ },
2164
+ {
2165
+ "description": "announces when removed from the DOM so the parent menu can remove ownership and update selected state",
2166
+ "name": "sp-menu-item-removed"
2167
+ }
2168
+ ],
2169
+ "attributes": [
2170
+ {
2171
+ "name": "active",
2172
+ "type": {
2173
+ "text": "boolean"
2174
+ },
2175
+ "default": "false",
2176
+ "fieldName": "active"
2177
+ },
2178
+ {
2179
+ "name": "focused",
2180
+ "type": {
2181
+ "text": "boolean"
2182
+ },
2183
+ "default": "false",
2184
+ "fieldName": "focused"
2185
+ },
2186
+ {
2187
+ "name": "selected",
2188
+ "type": {
2189
+ "text": "boolean"
2190
+ },
2191
+ "default": "false",
2192
+ "fieldName": "selected"
2193
+ },
2194
+ {
2195
+ "name": "value",
2196
+ "type": {
2197
+ "text": "string"
2198
+ },
2199
+ "fieldName": "value"
2200
+ },
2201
+ {
2202
+ "name": "has-submenu",
2203
+ "type": {
2204
+ "text": "boolean"
2205
+ },
2206
+ "default": "false",
2207
+ "fieldName": "hasSubmenu"
2208
+ },
2209
+ {
2210
+ "name": "no-wrap",
2211
+ "type": {
2212
+ "text": "boolean"
2213
+ },
2214
+ "default": "false",
2215
+ "fieldName": "noWrap"
2216
+ },
2217
+ {
2218
+ "name": "open",
2219
+ "type": {
2220
+ "text": "boolean"
2221
+ },
2222
+ "default": "false",
2223
+ "fieldName": "open"
2224
+ }
2225
+ ],
2226
+ "mixins": [
2227
+ {
2228
+ "name": "LikeAnchor",
2229
+ "package": "@spectrum-web-components/shared/src/like-anchor.js"
2230
+ },
2231
+ {
2232
+ "name": "ObserveSlotText",
2233
+ "package": "@spectrum-web-components/shared"
2234
+ },
2235
+ {
2236
+ "name": "ObserveSlotPresence",
2237
+ "package": "@spectrum-web-components/shared"
2238
+ }
2239
+ ],
2240
+ "superclass": {
2241
+ "name": "Focusable",
2242
+ "package": "@spectrum-web-components/shared/src/focusable.js"
2243
+ },
2244
+ "tagName": "sp-menu-item",
2245
+ "customElement": true
2246
+ }
2247
+ ],
2248
+ "exports": [
2249
+ {
2250
+ "kind": "js",
2251
+ "name": "MenuItemRemovedEvent",
2252
+ "declaration": {
2253
+ "name": "MenuItemRemovedEvent",
2254
+ "module": "src/MenuItem.js"
2255
+ }
2256
+ },
2257
+ {
2258
+ "kind": "js",
2259
+ "name": "MenuItemAddedOrUpdatedEvent",
2260
+ "declaration": {
2261
+ "name": "MenuItemAddedOrUpdatedEvent",
2262
+ "module": "src/MenuItem.js"
2263
+ }
2264
+ },
2265
+ {
2266
+ "kind": "js",
2267
+ "name": "MenuItem",
2268
+ "declaration": {
2269
+ "name": "MenuItem",
2270
+ "module": "src/MenuItem.js"
2271
+ }
2272
+ }
2273
+ ]
2274
+ }
2275
+ ]
2276
+ }