@spectrum-web-components/menu 0.16.12-react.50 → 0.16.12

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.
@@ -4,7 +4,7 @@
4
4
  "modules": [
5
5
  {
6
6
  "kind": "javascript-module",
7
- "path": "sp-menu-divider.ts",
7
+ "path": "sp-menu-divider.js",
8
8
  "declarations": [],
9
9
  "exports": [
10
10
  {
@@ -19,7 +19,7 @@
19
19
  },
20
20
  {
21
21
  "kind": "javascript-module",
22
- "path": "sp-menu-group.ts",
22
+ "path": "sp-menu-group.js",
23
23
  "declarations": [],
24
24
  "exports": [
25
25
  {
@@ -34,7 +34,7 @@
34
34
  },
35
35
  {
36
36
  "kind": "javascript-module",
37
- "path": "sp-menu-item.ts",
37
+ "path": "sp-menu-item.js",
38
38
  "declarations": [],
39
39
  "exports": [
40
40
  {
@@ -49,7 +49,7 @@
49
49
  },
50
50
  {
51
51
  "kind": "javascript-module",
52
- "path": "sp-menu.ts",
52
+ "path": "sp-menu.js",
53
53
  "declarations": [],
54
54
  "exports": [
55
55
  {
@@ -64,7 +64,7 @@
64
64
  },
65
65
  {
66
66
  "kind": "javascript-module",
67
- "path": "src/Menu.ts",
67
+ "path": "src/Menu.js",
68
68
  "declarations": [
69
69
  {
70
70
  "kind": "class",
@@ -666,14 +666,14 @@
666
666
  "name": "Menu",
667
667
  "declaration": {
668
668
  "name": "Menu",
669
- "module": "src/Menu.ts"
669
+ "module": "src/Menu.js"
670
670
  }
671
671
  }
672
672
  ]
673
673
  },
674
674
  {
675
675
  "kind": "javascript-module",
676
- "path": "src/MenuDivider.ts",
676
+ "path": "src/MenuDivider.js",
677
677
  "declarations": [
678
678
  {
679
679
  "kind": "class",
@@ -694,14 +694,14 @@
694
694
  "name": "MenuDivider",
695
695
  "declaration": {
696
696
  "name": "MenuDivider",
697
- "module": "src/MenuDivider.ts"
697
+ "module": "src/MenuDivider.js"
698
698
  }
699
699
  }
700
700
  ]
701
701
  },
702
702
  {
703
703
  "kind": "javascript-module",
704
- "path": "src/MenuGroup.ts",
704
+ "path": "src/MenuGroup.js",
705
705
  "declarations": [
706
706
  {
707
707
  "kind": "class",
@@ -762,7 +762,7 @@
762
762
  "privacy": "protected",
763
763
  "inheritedFrom": {
764
764
  "name": "Menu",
765
- "module": "src/Menu.ts"
765
+ "module": "src/Menu.js"
766
766
  }
767
767
  },
768
768
  {
@@ -785,7 +785,7 @@
785
785
  "default": "false",
786
786
  "inheritedFrom": {
787
787
  "name": "Menu",
788
- "module": "src/Menu.ts"
788
+ "module": "src/Menu.js"
789
789
  }
790
790
  },
791
791
  {
@@ -800,7 +800,7 @@
800
800
  "reflects": true,
801
801
  "inheritedFrom": {
802
802
  "name": "Menu",
803
- "module": "src/Menu.ts"
803
+ "module": "src/Menu.js"
804
804
  }
805
805
  },
806
806
  {
@@ -814,7 +814,7 @@
814
814
  "reflects": true,
815
815
  "inheritedFrom": {
816
816
  "name": "Menu",
817
- "module": "src/Menu.ts"
817
+ "module": "src/Menu.js"
818
818
  }
819
819
  },
820
820
  {
@@ -828,7 +828,7 @@
828
828
  "attribute": "value",
829
829
  "inheritedFrom": {
830
830
  "name": "Menu",
831
- "module": "src/Menu.ts"
831
+ "module": "src/Menu.js"
832
832
  }
833
833
  },
834
834
  {
@@ -842,7 +842,7 @@
842
842
  "attribute": "value-separator",
843
843
  "inheritedFrom": {
844
844
  "name": "Menu",
845
- "module": "src/Menu.ts"
845
+ "module": "src/Menu.js"
846
846
  }
847
847
  },
848
848
  {
@@ -852,7 +852,7 @@
852
852
  "default": "[]",
853
853
  "inheritedFrom": {
854
854
  "name": "Menu",
855
- "module": "src/Menu.ts"
855
+ "module": "src/Menu.js"
856
856
  }
857
857
  },
858
858
  {
@@ -862,7 +862,7 @@
862
862
  "default": "[]",
863
863
  "inheritedFrom": {
864
864
  "name": "Menu",
865
- "module": "src/Menu.ts"
865
+ "module": "src/Menu.js"
866
866
  }
867
867
  },
868
868
  {
@@ -874,7 +874,7 @@
874
874
  "privacy": "public",
875
875
  "inheritedFrom": {
876
876
  "name": "Menu",
877
- "module": "src/Menu.ts"
877
+ "module": "src/Menu.js"
878
878
  }
879
879
  },
880
880
  {
@@ -884,7 +884,7 @@
884
884
  "default": "new Set<MenuItem>()",
885
885
  "inheritedFrom": {
886
886
  "name": "Menu",
887
- "module": "src/Menu.ts"
887
+ "module": "src/Menu.js"
888
888
  }
889
889
  },
890
890
  {
@@ -897,7 +897,7 @@
897
897
  "default": "0",
898
898
  "inheritedFrom": {
899
899
  "name": "Menu",
900
- "module": "src/Menu.ts"
900
+ "module": "src/Menu.js"
901
901
  }
902
902
  },
903
903
  {
@@ -910,7 +910,7 @@
910
910
  "default": "0",
911
911
  "inheritedFrom": {
912
912
  "name": "Menu",
913
- "module": "src/Menu.ts"
913
+ "module": "src/Menu.js"
914
914
  }
915
915
  },
916
916
  {
@@ -920,7 +920,7 @@
920
920
  "default": "new Map()",
921
921
  "inheritedFrom": {
922
922
  "name": "Menu",
923
- "module": "src/Menu.ts"
923
+ "module": "src/Menu.js"
924
924
  }
925
925
  },
926
926
  {
@@ -932,7 +932,7 @@
932
932
  "privacy": "public",
933
933
  "inheritedFrom": {
934
934
  "name": "Menu",
935
- "module": "src/Menu.ts"
935
+ "module": "src/Menu.js"
936
936
  }
937
937
  },
938
938
  {
@@ -944,7 +944,7 @@
944
944
  "privacy": "private",
945
945
  "inheritedFrom": {
946
946
  "name": "Menu",
947
- "module": "src/Menu.ts"
947
+ "module": "src/Menu.js"
948
948
  }
949
949
  },
950
950
  {
@@ -958,7 +958,7 @@
958
958
  },
959
959
  "inheritedFrom": {
960
960
  "name": "Menu",
961
- "module": "src/Menu.ts"
961
+ "module": "src/Menu.js"
962
962
  }
963
963
  },
964
964
  {
@@ -971,7 +971,7 @@
971
971
  "description": "Hide this getter from web-component-analyzer until\nhttps://github.com/runem/web-component-analyzer/issues/131\nhas been addressed.",
972
972
  "inheritedFrom": {
973
973
  "name": "Menu",
974
- "module": "src/Menu.ts"
974
+ "module": "src/Menu.js"
975
975
  }
976
976
  },
977
977
  {
@@ -983,7 +983,7 @@
983
983
  "privacy": "private",
984
984
  "inheritedFrom": {
985
985
  "name": "Menu",
986
- "module": "src/Menu.ts"
986
+ "module": "src/Menu.js"
987
987
  }
988
988
  },
989
989
  {
@@ -995,7 +995,7 @@
995
995
  "privacy": "private",
996
996
  "inheritedFrom": {
997
997
  "name": "Menu",
998
- "module": "src/Menu.ts"
998
+ "module": "src/Menu.js"
999
999
  }
1000
1000
  },
1001
1001
  {
@@ -1018,7 +1018,7 @@
1018
1018
  "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.",
1019
1019
  "inheritedFrom": {
1020
1020
  "name": "Menu",
1021
- "module": "src/Menu.ts"
1021
+ "module": "src/Menu.js"
1022
1022
  }
1023
1023
  },
1024
1024
  {
@@ -1041,7 +1041,7 @@
1041
1041
  "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.",
1042
1042
  "inheritedFrom": {
1043
1043
  "name": "Menu",
1044
- "module": "src/Menu.ts"
1044
+ "module": "src/Menu.js"
1045
1045
  }
1046
1046
  },
1047
1047
  {
@@ -1063,7 +1063,7 @@
1063
1063
  ],
1064
1064
  "inheritedFrom": {
1065
1065
  "name": "Menu",
1066
- "module": "src/Menu.ts"
1066
+ "module": "src/Menu.js"
1067
1067
  }
1068
1068
  },
1069
1069
  {
@@ -1085,7 +1085,7 @@
1085
1085
  ],
1086
1086
  "inheritedFrom": {
1087
1087
  "name": "Menu",
1088
- "module": "src/Menu.ts"
1088
+ "module": "src/Menu.js"
1089
1089
  }
1090
1090
  },
1091
1091
  {
@@ -1108,7 +1108,7 @@
1108
1108
  ],
1109
1109
  "inheritedFrom": {
1110
1110
  "name": "Menu",
1111
- "module": "src/Menu.ts"
1111
+ "module": "src/Menu.js"
1112
1112
  }
1113
1113
  },
1114
1114
  {
@@ -1130,7 +1130,7 @@
1130
1130
  ],
1131
1131
  "inheritedFrom": {
1132
1132
  "name": "Menu",
1133
- "module": "src/Menu.ts"
1133
+ "module": "src/Menu.js"
1134
1134
  }
1135
1135
  },
1136
1136
  {
@@ -1152,7 +1152,7 @@
1152
1152
  ],
1153
1153
  "inheritedFrom": {
1154
1154
  "name": "Menu",
1155
- "module": "src/Menu.ts"
1155
+ "module": "src/Menu.js"
1156
1156
  }
1157
1157
  },
1158
1158
  {
@@ -1166,7 +1166,7 @@
1166
1166
  },
1167
1167
  "inheritedFrom": {
1168
1168
  "name": "Menu",
1169
- "module": "src/Menu.ts"
1169
+ "module": "src/Menu.js"
1170
1170
  }
1171
1171
  },
1172
1172
  {
@@ -1188,7 +1188,7 @@
1188
1188
  ],
1189
1189
  "inheritedFrom": {
1190
1190
  "name": "Menu",
1191
- "module": "src/Menu.ts"
1191
+ "module": "src/Menu.js"
1192
1192
  }
1193
1193
  },
1194
1194
  {
@@ -1202,7 +1202,7 @@
1202
1202
  },
1203
1203
  "inheritedFrom": {
1204
1204
  "name": "Menu",
1205
- "module": "src/Menu.ts"
1205
+ "module": "src/Menu.js"
1206
1206
  }
1207
1207
  },
1208
1208
  {
@@ -1224,7 +1224,7 @@
1224
1224
  ],
1225
1225
  "inheritedFrom": {
1226
1226
  "name": "Menu",
1227
- "module": "src/Menu.ts"
1227
+ "module": "src/Menu.js"
1228
1228
  }
1229
1229
  },
1230
1230
  {
@@ -1246,7 +1246,7 @@
1246
1246
  ],
1247
1247
  "inheritedFrom": {
1248
1248
  "name": "Menu",
1249
- "module": "src/Menu.ts"
1249
+ "module": "src/Menu.js"
1250
1250
  }
1251
1251
  },
1252
1252
  {
@@ -1268,7 +1268,7 @@
1268
1268
  ],
1269
1269
  "inheritedFrom": {
1270
1270
  "name": "Menu",
1271
- "module": "src/Menu.ts"
1271
+ "module": "src/Menu.js"
1272
1272
  }
1273
1273
  },
1274
1274
  {
@@ -1290,7 +1290,7 @@
1290
1290
  ],
1291
1291
  "inheritedFrom": {
1292
1292
  "name": "Menu",
1293
- "module": "src/Menu.ts"
1293
+ "module": "src/Menu.js"
1294
1294
  }
1295
1295
  },
1296
1296
  {
@@ -1312,7 +1312,7 @@
1312
1312
  ],
1313
1313
  "inheritedFrom": {
1314
1314
  "name": "Menu",
1315
- "module": "src/Menu.ts"
1315
+ "module": "src/Menu.js"
1316
1316
  }
1317
1317
  },
1318
1318
  {
@@ -1326,7 +1326,7 @@
1326
1326
  },
1327
1327
  "inheritedFrom": {
1328
1328
  "name": "Menu",
1329
- "module": "src/Menu.ts"
1329
+ "module": "src/Menu.js"
1330
1330
  }
1331
1331
  },
1332
1332
  {
@@ -1340,7 +1340,7 @@
1340
1340
  },
1341
1341
  "inheritedFrom": {
1342
1342
  "name": "Menu",
1343
- "module": "src/Menu.ts"
1343
+ "module": "src/Menu.js"
1344
1344
  }
1345
1345
  },
1346
1346
  {
@@ -1353,7 +1353,7 @@
1353
1353
  "default": "false",
1354
1354
  "inheritedFrom": {
1355
1355
  "name": "Menu",
1356
- "module": "src/Menu.ts"
1356
+ "module": "src/Menu.js"
1357
1357
  }
1358
1358
  },
1359
1359
  {
@@ -1367,7 +1367,7 @@
1367
1367
  },
1368
1368
  "inheritedFrom": {
1369
1369
  "name": "Menu",
1370
- "module": "src/Menu.ts"
1370
+ "module": "src/Menu.js"
1371
1371
  }
1372
1372
  },
1373
1373
  {
@@ -1381,7 +1381,7 @@
1381
1381
  },
1382
1382
  "inheritedFrom": {
1383
1383
  "name": "Menu",
1384
- "module": "src/Menu.ts"
1384
+ "module": "src/Menu.js"
1385
1385
  }
1386
1386
  },
1387
1387
  {
@@ -1403,7 +1403,7 @@
1403
1403
  ],
1404
1404
  "inheritedFrom": {
1405
1405
  "name": "Menu",
1406
- "module": "src/Menu.ts"
1406
+ "module": "src/Menu.js"
1407
1407
  }
1408
1408
  },
1409
1409
  {
@@ -1416,7 +1416,7 @@
1416
1416
  "default": "false",
1417
1417
  "inheritedFrom": {
1418
1418
  "name": "Menu",
1419
- "module": "src/Menu.ts"
1419
+ "module": "src/Menu.js"
1420
1420
  }
1421
1421
  },
1422
1422
  {
@@ -1430,7 +1430,7 @@
1430
1430
  },
1431
1431
  "inheritedFrom": {
1432
1432
  "name": "Menu",
1433
- "module": "src/Menu.ts"
1433
+ "module": "src/Menu.js"
1434
1434
  }
1435
1435
  },
1436
1436
  {
@@ -1442,7 +1442,7 @@
1442
1442
  "privacy": "protected",
1443
1443
  "inheritedFrom": {
1444
1444
  "name": "Menu",
1445
- "module": "src/Menu.ts"
1445
+ "module": "src/Menu.js"
1446
1446
  }
1447
1447
  },
1448
1448
  {
@@ -1451,7 +1451,7 @@
1451
1451
  "privacy": "protected",
1452
1452
  "inheritedFrom": {
1453
1453
  "name": "Menu",
1454
- "module": "src/Menu.ts"
1454
+ "module": "src/Menu.js"
1455
1455
  }
1456
1456
  },
1457
1457
  {
@@ -1465,7 +1465,7 @@
1465
1465
  },
1466
1466
  "inheritedFrom": {
1467
1467
  "name": "Menu",
1468
- "module": "src/Menu.ts"
1468
+ "module": "src/Menu.js"
1469
1469
  }
1470
1470
  }
1471
1471
  ],
@@ -1556,14 +1556,14 @@
1556
1556
  "name": "MenuGroup",
1557
1557
  "declaration": {
1558
1558
  "name": "MenuGroup",
1559
- "module": "src/MenuGroup.ts"
1559
+ "module": "src/MenuGroup.js"
1560
1560
  }
1561
1561
  }
1562
1562
  ]
1563
1563
  },
1564
1564
  {
1565
1565
  "kind": "javascript-module",
1566
- "path": "src/MenuItem.ts",
1566
+ "path": "src/MenuItem.js",
1567
1567
  "declarations": [
1568
1568
  {
1569
1569
  "kind": "class",
@@ -2160,7 +2160,7 @@
2160
2160
  "name": "MenuItemRemovedEvent",
2161
2161
  "declaration": {
2162
2162
  "name": "MenuItemRemovedEvent",
2163
- "module": "src/MenuItem.ts"
2163
+ "module": "src/MenuItem.js"
2164
2164
  }
2165
2165
  },
2166
2166
  {
@@ -2168,7 +2168,7 @@
2168
2168
  "name": "MenuItemAddedOrUpdatedEvent",
2169
2169
  "declaration": {
2170
2170
  "name": "MenuItemAddedOrUpdatedEvent",
2171
- "module": "src/MenuItem.ts"
2171
+ "module": "src/MenuItem.js"
2172
2172
  }
2173
2173
  },
2174
2174
  {
@@ -2176,7 +2176,7 @@
2176
2176
  "name": "MenuItem",
2177
2177
  "declaration": {
2178
2178
  "name": "MenuItem",
2179
- "module": "src/MenuItem.ts"
2179
+ "module": "src/MenuItem.js"
2180
2180
  }
2181
2181
  }
2182
2182
  ]
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@spectrum-web-components/menu",
3
- "version": "0.16.12-react.50+474992be7",
3
+ "version": "0.16.12",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -85,16 +85,16 @@
85
85
  ],
86
86
  "dependencies": {
87
87
  "@lit-labs/observers": "^1.0.1",
88
- "@spectrum-web-components/action-button": "^0.10.11-react.50+474992be7",
89
- "@spectrum-web-components/base": "^0.7.5-react.50+474992be7",
90
- "@spectrum-web-components/divider": "^0.6.6-react.50+474992be7",
91
- "@spectrum-web-components/icon": "^0.12.8-react.50+474992be7",
92
- "@spectrum-web-components/icons-ui": "^0.9.8-react.50+474992be7",
93
- "@spectrum-web-components/overlay": "^0.18.12-react.50+474992be7",
94
- "@spectrum-web-components/shared": "^0.15.6-react.50+474992be7"
88
+ "@spectrum-web-components/action-button": "^0.10.11",
89
+ "@spectrum-web-components/base": "^0.7.4",
90
+ "@spectrum-web-components/divider": "^0.6.6",
91
+ "@spectrum-web-components/icon": "^0.12.8",
92
+ "@spectrum-web-components/icons-ui": "^0.9.8",
93
+ "@spectrum-web-components/overlay": "^0.19.0",
94
+ "@spectrum-web-components/shared": "^0.15.5"
95
95
  },
96
96
  "devDependencies": {
97
- "@spectrum-css/menu": "^4.0.8"
97
+ "@spectrum-css/menu": "^4.0.11"
98
98
  },
99
99
  "types": "./src/index.d.ts",
100
100
  "customElements": "custom-elements.json",
@@ -102,5 +102,5 @@
102
102
  "./sp-*.js",
103
103
  "./**/*.dev.js"
104
104
  ],
105
- "gitHead": "474992be7513cad160eeeec0b522600243babc70"
105
+ "gitHead": "007a762c0257af4cd74e3781d877a8a8343acfd0"
106
106
  }
@@ -154,10 +154,11 @@ const _MenuItem = class extends LikeAnchor(Focusable) {
154
154
  return this;
155
155
  }
156
156
  get itemChildren() {
157
+ var _a, _b;
157
158
  if (this._itemChildren) {
158
159
  return this._itemChildren;
159
160
  }
160
- const iconSlot = this.shadowRoot.querySelector(
161
+ const iconSlot = (_a = this.shadowRoot) == null ? void 0 : _a.querySelector(
161
162
  'slot[name="icon"]'
162
163
  );
163
164
  const icon = !iconSlot ? [] : iconSlot.assignedElements().map((element) => {
@@ -166,7 +167,7 @@ const _MenuItem = class extends LikeAnchor(Focusable) {
166
167
  newElement.classList.toggle("icon");
167
168
  return newElement;
168
169
  });
169
- const contentSlot = this.shadowRoot.querySelector(
170
+ const contentSlot = (_b = this.shadowRoot) == null ? void 0 : _b.querySelector(
170
171
  "slot:not([name])"
171
172
  );
172
173
  const content = !contentSlot ? [] : contentSlot.assignedNodes().map((node) => node.cloneNode(true));
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["MenuItem.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\n\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js';\nimport { LikeAnchor } from '@spectrum-web-components/shared/src/like-anchor.js';\nimport { Focusable } from '@spectrum-web-components/shared/src/focusable.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport { openOverlay } from '@spectrum-web-components/overlay/src/loader.js';\nimport { OverlayCloseEvent } from '@spectrum-web-components/overlay/src/overlay-events.js';\n\nimport menuItemStyles from './menu-item.css.js';\nimport checkmarkStyles from '@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js';\nimport type { Menu } from './Menu.dev.js'\nimport type { OverlayOpenCloseDetail } from '@spectrum-web-components/overlay';\nimport { reparentChildren } from '@spectrum-web-components/shared/src/reparent-children.js';\nimport { MutationController } from '@lit-labs/observers/mutation_controller.js';\n\n/**\n * Duration during which a pointing device can leave an `<sp-menu-item>` element\n * and return to it or to the submenu opened from it before closing that submenu.\n **/\nconst POINTERLEAVE_TIMEOUT = 100;\n\nexport class MenuItemRemovedEvent extends Event {\n constructor() {\n super('sp-menu-item-removed', {\n bubbles: true,\n composed: true,\n });\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n focused = false;\n reset(item: MenuItem): void {\n this._item = item;\n }\n}\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor() {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n }\n set focusRoot(root: Menu | undefined) {\n this.item.menuData.focusRoot = this.item.menuData.focusRoot || root;\n }\n set selectionRoot(root: Menu) {\n this.item.menuData.selectionRoot =\n this.item.menuData.selectionRoot || root;\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n set currentAncestorWithSelects(ancestor: Menu | undefined) {\n this._currentAncestorWithSelects = ancestor;\n }\n get currentAncestorWithSelects(): Menu | undefined {\n return this._currentAncestorWithSelects;\n }\n _currentAncestorWithSelects?: Menu;\n reset(item: MenuItem): void {\n this._item = item;\n this._currentAncestorWithSelects = undefined;\n item.menuData = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n }\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\nconst addOrUpdateEvent = new MenuItemAddedOrUpdatedEvent();\nconst removeEvent = new MenuItemRemovedEvent();\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot icon - icon element to be placed at the start of the Menu Item\n * @slot value - content placed at the end of the Menu Item like values, keyboard shortcuts, etc.\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n * @fires sp-menu-item-removed - announces when removed from the DOM so the parent menu can remove ownership and update selected state\n */\nexport class MenuItem extends LikeAnchor(Focusable) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n static instanceCount = 0;\n\n private isInSubmenu = false;\n\n @property({ type: Boolean, reflect: true })\n public active = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: Boolean, reflect: true })\n public selected = false;\n\n @property({ type: String })\n public get value(): string {\n return this._value || this.itemText;\n }\n\n public set value(value: string) {\n if (value === this._value) {\n return;\n }\n this._value = value || '';\n if (this._value) {\n this.setAttribute('value', this._value);\n } else {\n this.removeAttribute('value');\n }\n }\n\n private _value = '';\n\n /**\n * @private\n */\n public get itemText(): string {\n return this.itemChildren.content.reduce(\n (acc, node) => acc + (node.textContent || '').trim(),\n ''\n );\n }\n\n @property({ type: Boolean })\n public hasSubmenu = false;\n\n @property({\n type: Boolean,\n reflect: true,\n attribute: 'no-wrap',\n hasChanged() {\n return false;\n },\n })\n public noWrap = false;\n\n @query('.anchor')\n private anchorElement!: HTMLAnchorElement;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (this._itemChildren) {\n return this._itemChildren;\n }\n\n const iconSlot = this.shadowRoot.querySelector(\n 'slot[name=\"icon\"]'\n ) as HTMLSlotElement;\n const icon = !iconSlot\n ? []\n : iconSlot.assignedElements().map((element) => {\n const newElement = element.cloneNode(true) as HTMLElement;\n newElement.removeAttribute('slot');\n newElement.classList.toggle('icon');\n return newElement;\n });\n const contentSlot = this.shadowRoot.querySelector(\n 'slot:not([name])'\n ) as HTMLSlotElement;\n const content = !contentSlot\n ? []\n : contentSlot.assignedNodes().map((node) => node.cloneNode(true));\n this._itemChildren = { icon, content };\n\n return this._itemChildren;\n }\n\n private _itemChildren?: MenuItemChildren;\n\n constructor() {\n super();\n this.proxyFocus = this.proxyFocus.bind(this);\n\n this.addEventListener('click', this.handleClickCapture, {\n capture: true,\n });\n\n new MutationController(this, {\n config: {\n characterData: true,\n childList: true,\n subtree: true,\n },\n callback: () => {\n this.breakItemChildrenCache();\n },\n });\n }\n\n @property({ type: Boolean })\n public open = false;\n\n public override click(): void {\n if (this.disabled) {\n return;\n }\n\n if (this.shouldProxyClick()) {\n return;\n }\n\n super.click();\n }\n\n private handleClickCapture(event: Event): void | boolean {\n if (this.disabled) {\n event.preventDefault();\n event.stopImmediatePropagation();\n event.stopPropagation();\n return false;\n }\n }\n\n private proxyFocus(): void {\n this.focus();\n }\n\n private shouldProxyClick(): boolean {\n let handled = false;\n if (this.anchorElement) {\n this.anchorElement.click();\n handled = true;\n }\n return handled;\n }\n\n protected breakItemChildrenCache(): void {\n this._itemChildren = undefined;\n this.triggerUpdate();\n }\n\n protected override render(): TemplateResult {\n return html`\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"value\"></slot>\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 icon checkmark\"\n ></sp-icon-checkmark100>\n `\n : html``}\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : html``}\n <slot\n hidden\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n ></slot>\n ${this.hasSubmenu\n ? html`\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `\n : html``}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = this.open || !!assignedElements.length;\n }\n\n private handleRemoveActive(event: Event): void {\n if (\n (event.type === 'pointerleave' && this.hasSubmenu) ||\n this.hasSubmenu ||\n this.open\n ) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(): void {\n this.active = true;\n }\n\n protected override firstUpdated(changes: PropertyValues): void {\n super.firstUpdated(changes);\n this.setAttribute('tabindex', '-1');\n this.addEventListener('pointerdown', this.handlePointerdown);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${MenuItem.instanceCount++}`;\n }\n this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n const overalyCloseEvent = new OverlayCloseEvent({\n root: this.menuData.focusRoot,\n });\n this.dispatchEvent(overalyCloseEvent);\n }\n\n public closeOverlay?: () => Promise<void>;\n\n protected handleSubmenuClick(): void {\n this.openOverlay();\n }\n\n protected handlePointerenter(): void {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n return;\n }\n this.openOverlay();\n }\n\n protected leaveTimeout?: ReturnType<typeof setTimeout>;\n\n protected handlePointerleave(): void {\n if (this.hasSubmenu && this.open) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n if (this.closeOverlay) this.closeOverlay();\n }, POINTERLEAVE_TIMEOUT);\n }\n }\n\n /**\n * When there is a `change` event in the submenu for this item\n * then we \"click\" this item to cascade the selection up the\n * menu tree allowing all submenus between the initial selection\n * and the root of the tree to have their selection changes and\n * be closed.\n */\n protected handleSubmenuChange = (): void => {\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n };\n\n protected handleSubmenuPointerenter = (): void => {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n }\n };\n\n public async openOverlay(): Promise<void> {\n if (!this.hasSubmenu || this.open || this.disabled) {\n return;\n }\n this.open = true;\n this.active = true;\n const submenu = (\n this.shadowRoot.querySelector(\n 'slot[name=\"submenu\"]'\n ) as HTMLSlotElement\n ).assignedElements()[0] as Menu;\n submenu.addEventListener(\n 'pointerenter',\n this.handleSubmenuPointerenter\n );\n submenu.addEventListener('change', this.handleSubmenuChange);\n const popover = document.createElement('sp-popover');\n const returnSubmenu = reparentChildren([submenu], popover, {\n position: 'beforeend',\n prepareCallback: (el) => {\n const slotName = el.slot;\n el.tabIndex = 0;\n el.removeAttribute('slot');\n el.isSubmenu = true;\n return (el) => {\n el.tabIndex = -1;\n el.slot = slotName;\n el.isSubmenu = false;\n };\n },\n });\n const closeOverlay = openOverlay(this, 'click', popover, {\n placement: this.isLTR ? 'right-start' : 'left-start',\n receivesFocus: 'auto',\n root: this.menuData.focusRoot,\n });\n const closeSubmenu = async (): Promise<void> => {\n delete this.closeOverlay;\n (await closeOverlay)();\n };\n this.closeOverlay = closeSubmenu;\n const cleanup = (event: CustomEvent<OverlayOpenCloseDetail>): void => {\n event.stopPropagation();\n delete this.closeOverlay;\n returnSubmenu();\n this.open = false;\n this.active = false;\n };\n this.addEventListener('sp-closed', cleanup as EventListener, {\n once: true,\n });\n popover.addEventListener('change', closeSubmenu);\n }\n\n updateAriaSelected(): void {\n const role = this.getAttribute('role');\n if (role === 'option') {\n this.setAttribute(\n 'aria-selected',\n this.selected ? 'true' : 'false'\n );\n } else if (role === 'menuitemcheckbox' || role === 'menuitemradio') {\n this.setAttribute('aria-checked', this.selected ? 'true' : 'false');\n }\n }\n\n public setRole(role: string): void {\n this.setAttribute('role', role);\n this.updateAriaSelected();\n }\n\n protected override updated(changes: PropertyValues<this>): void {\n super.updated(changes);\n if (changes.has('label')) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (changes.has('active')) {\n if (this.active) {\n this.addEventListener('pointerup', this.handleRemoveActive);\n this.addEventListener('pointerleave', this.handleRemoveActive);\n this.addEventListener('pointercancel', this.handleRemoveActive);\n } else {\n this.removeEventListener('pointerup', this.handleRemoveActive);\n this.removeEventListener(\n 'pointerleave',\n this.handleRemoveActive\n );\n this.removeEventListener(\n 'pointercancel',\n this.handleRemoveActive\n );\n }\n }\n if (this.anchorElement) {\n this.anchorElement.addEventListener('focus', this.proxyFocus);\n this.anchorElement.tabIndex = -1;\n }\n if (changes.has('selected')) {\n this.updateAriaSelected();\n }\n if (changes.has('hasSubmenu')) {\n if (this.hasSubmenu) {\n this.addEventListener('click', this.handleSubmenuClick);\n this.addEventListener('pointerenter', this.handlePointerenter);\n this.addEventListener('pointerleave', this.handlePointerleave);\n } else if (!this.closeOverlay) {\n this.removeEventListener('click', this.handleSubmenuClick);\n this.removeEventListener(\n 'pointerenter',\n this.handlePointerenter\n );\n this.removeEventListener(\n 'pointerleave',\n this.handlePointerleave\n );\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.isInSubmenu = !!this.closest('[slot=\"submenu\"]');\n if (this.isInSubmenu) {\n return;\n }\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n this._parentElement = this.parentElement as HTMLElement;\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n removeEvent.reset(this);\n if (!this.isInSubmenu) {\n this._parentElement?.dispatchEvent(removeEvent);\n }\n this.isInSubmenu = false;\n super.disconnectedCallback();\n }\n\n public async triggerUpdate(): Promise<void> {\n if (this.isInSubmenu) {\n return;\n }\n await new Promise((ready) => requestAnimationFrame(ready));\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n }\n\n public menuData: {\n focusRoot?: Menu;\n selectionRoot?: Menu;\n } = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\n 'sp-menu-item-removed': MenuItemRemovedEvent;\n }\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\n\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js';\nimport { LikeAnchor } from '@spectrum-web-components/shared/src/like-anchor.js';\nimport { Focusable } from '@spectrum-web-components/shared/src/focusable.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport { openOverlay } from '@spectrum-web-components/overlay/src/loader.js';\nimport { OverlayCloseEvent } from '@spectrum-web-components/overlay/src/overlay-events.js';\n\nimport menuItemStyles from './menu-item.css.js';\nimport checkmarkStyles from '@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js';\nimport type { Menu } from './Menu.dev.js'\nimport type { OverlayOpenCloseDetail } from '@spectrum-web-components/overlay';\nimport { reparentChildren } from '@spectrum-web-components/shared/src/reparent-children.js';\nimport { MutationController } from '@lit-labs/observers/mutation_controller.js';\n\n/**\n * Duration during which a pointing device can leave an `<sp-menu-item>` element\n * and return to it or to the submenu opened from it before closing that submenu.\n **/\nconst POINTERLEAVE_TIMEOUT = 100;\n\nexport class MenuItemRemovedEvent extends Event {\n constructor() {\n super('sp-menu-item-removed', {\n bubbles: true,\n composed: true,\n });\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n focused = false;\n reset(item: MenuItem): void {\n this._item = item;\n }\n}\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor() {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n }\n set focusRoot(root: Menu | undefined) {\n this.item.menuData.focusRoot = this.item.menuData.focusRoot || root;\n }\n set selectionRoot(root: Menu) {\n this.item.menuData.selectionRoot =\n this.item.menuData.selectionRoot || root;\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n set currentAncestorWithSelects(ancestor: Menu | undefined) {\n this._currentAncestorWithSelects = ancestor;\n }\n get currentAncestorWithSelects(): Menu | undefined {\n return this._currentAncestorWithSelects;\n }\n _currentAncestorWithSelects?: Menu;\n reset(item: MenuItem): void {\n this._item = item;\n this._currentAncestorWithSelects = undefined;\n item.menuData = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n }\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\nconst addOrUpdateEvent = new MenuItemAddedOrUpdatedEvent();\nconst removeEvent = new MenuItemRemovedEvent();\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot icon - icon element to be placed at the start of the Menu Item\n * @slot value - content placed at the end of the Menu Item like values, keyboard shortcuts, etc.\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n * @fires sp-menu-item-removed - announces when removed from the DOM so the parent menu can remove ownership and update selected state\n */\nexport class MenuItem extends LikeAnchor(Focusable) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n static instanceCount = 0;\n\n private isInSubmenu = false;\n\n @property({ type: Boolean, reflect: true })\n public active = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: Boolean, reflect: true })\n public selected = false;\n\n @property({ type: String })\n public get value(): string {\n return this._value || this.itemText;\n }\n\n public set value(value: string) {\n if (value === this._value) {\n return;\n }\n this._value = value || '';\n if (this._value) {\n this.setAttribute('value', this._value);\n } else {\n this.removeAttribute('value');\n }\n }\n\n private _value = '';\n\n /**\n * @private\n */\n public get itemText(): string {\n return this.itemChildren.content.reduce(\n (acc, node) => acc + (node.textContent || '').trim(),\n ''\n );\n }\n\n @property({ type: Boolean })\n public hasSubmenu = false;\n\n @property({\n type: Boolean,\n reflect: true,\n attribute: 'no-wrap',\n hasChanged() {\n return false;\n },\n })\n public noWrap = false;\n\n @query('.anchor')\n private anchorElement!: HTMLAnchorElement;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (this._itemChildren) {\n return this._itemChildren;\n }\n\n const iconSlot = this.shadowRoot?.querySelector(\n 'slot[name=\"icon\"]'\n ) as HTMLSlotElement;\n const icon = !iconSlot\n ? []\n : iconSlot.assignedElements().map((element) => {\n const newElement = element.cloneNode(true) as HTMLElement;\n newElement.removeAttribute('slot');\n newElement.classList.toggle('icon');\n return newElement;\n });\n const contentSlot = this.shadowRoot?.querySelector(\n 'slot:not([name])'\n ) as HTMLSlotElement;\n const content = !contentSlot\n ? []\n : contentSlot.assignedNodes().map((node) => node.cloneNode(true));\n this._itemChildren = { icon, content };\n\n return this._itemChildren;\n }\n\n private _itemChildren?: MenuItemChildren;\n\n constructor() {\n super();\n this.proxyFocus = this.proxyFocus.bind(this);\n\n this.addEventListener('click', this.handleClickCapture, {\n capture: true,\n });\n\n new MutationController(this, {\n config: {\n characterData: true,\n childList: true,\n subtree: true,\n },\n callback: () => {\n this.breakItemChildrenCache();\n },\n });\n }\n\n @property({ type: Boolean })\n public open = false;\n\n public override click(): void {\n if (this.disabled) {\n return;\n }\n\n if (this.shouldProxyClick()) {\n return;\n }\n\n super.click();\n }\n\n private handleClickCapture(event: Event): void | boolean {\n if (this.disabled) {\n event.preventDefault();\n event.stopImmediatePropagation();\n event.stopPropagation();\n return false;\n }\n }\n\n private proxyFocus(): void {\n this.focus();\n }\n\n private shouldProxyClick(): boolean {\n let handled = false;\n if (this.anchorElement) {\n this.anchorElement.click();\n handled = true;\n }\n return handled;\n }\n\n protected breakItemChildrenCache(): void {\n this._itemChildren = undefined;\n this.triggerUpdate();\n }\n\n protected override render(): TemplateResult {\n return html`\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"value\"></slot>\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 icon checkmark\"\n ></sp-icon-checkmark100>\n `\n : html``}\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : html``}\n <slot\n hidden\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n ></slot>\n ${this.hasSubmenu\n ? html`\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `\n : html``}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = this.open || !!assignedElements.length;\n }\n\n private handleRemoveActive(event: Event): void {\n if (\n (event.type === 'pointerleave' && this.hasSubmenu) ||\n this.hasSubmenu ||\n this.open\n ) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(): void {\n this.active = true;\n }\n\n protected override firstUpdated(changes: PropertyValues): void {\n super.firstUpdated(changes);\n this.setAttribute('tabindex', '-1');\n this.addEventListener('pointerdown', this.handlePointerdown);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${MenuItem.instanceCount++}`;\n }\n this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n const overalyCloseEvent = new OverlayCloseEvent({\n root: this.menuData.focusRoot,\n });\n this.dispatchEvent(overalyCloseEvent);\n }\n\n public closeOverlay?: () => Promise<void>;\n\n protected handleSubmenuClick(): void {\n this.openOverlay();\n }\n\n protected handlePointerenter(): void {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n return;\n }\n this.openOverlay();\n }\n\n protected leaveTimeout?: ReturnType<typeof setTimeout>;\n\n protected handlePointerleave(): void {\n if (this.hasSubmenu && this.open) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n if (this.closeOverlay) this.closeOverlay();\n }, POINTERLEAVE_TIMEOUT);\n }\n }\n\n /**\n * When there is a `change` event in the submenu for this item\n * then we \"click\" this item to cascade the selection up the\n * menu tree allowing all submenus between the initial selection\n * and the root of the tree to have their selection changes and\n * be closed.\n */\n protected handleSubmenuChange = (): void => {\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n };\n\n protected handleSubmenuPointerenter = (): void => {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n }\n };\n\n public async openOverlay(): Promise<void> {\n if (!this.hasSubmenu || this.open || this.disabled) {\n return;\n }\n this.open = true;\n this.active = true;\n const submenu = (\n this.shadowRoot.querySelector(\n 'slot[name=\"submenu\"]'\n ) as HTMLSlotElement\n ).assignedElements()[0] as Menu;\n submenu.addEventListener(\n 'pointerenter',\n this.handleSubmenuPointerenter\n );\n submenu.addEventListener('change', this.handleSubmenuChange);\n const popover = document.createElement('sp-popover');\n const returnSubmenu = reparentChildren([submenu], popover, {\n position: 'beforeend',\n prepareCallback: (el) => {\n const slotName = el.slot;\n el.tabIndex = 0;\n el.removeAttribute('slot');\n el.isSubmenu = true;\n return (el) => {\n el.tabIndex = -1;\n el.slot = slotName;\n el.isSubmenu = false;\n };\n },\n });\n const closeOverlay = openOverlay(this, 'click', popover, {\n placement: this.isLTR ? 'right-start' : 'left-start',\n receivesFocus: 'auto',\n root: this.menuData.focusRoot,\n });\n const closeSubmenu = async (): Promise<void> => {\n delete this.closeOverlay;\n (await closeOverlay)();\n };\n this.closeOverlay = closeSubmenu;\n const cleanup = (event: CustomEvent<OverlayOpenCloseDetail>): void => {\n event.stopPropagation();\n delete this.closeOverlay;\n returnSubmenu();\n this.open = false;\n this.active = false;\n };\n this.addEventListener('sp-closed', cleanup as EventListener, {\n once: true,\n });\n popover.addEventListener('change', closeSubmenu);\n }\n\n updateAriaSelected(): void {\n const role = this.getAttribute('role');\n if (role === 'option') {\n this.setAttribute(\n 'aria-selected',\n this.selected ? 'true' : 'false'\n );\n } else if (role === 'menuitemcheckbox' || role === 'menuitemradio') {\n this.setAttribute('aria-checked', this.selected ? 'true' : 'false');\n }\n }\n\n public setRole(role: string): void {\n this.setAttribute('role', role);\n this.updateAriaSelected();\n }\n\n protected override updated(changes: PropertyValues<this>): void {\n super.updated(changes);\n if (changes.has('label')) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (changes.has('active')) {\n if (this.active) {\n this.addEventListener('pointerup', this.handleRemoveActive);\n this.addEventListener('pointerleave', this.handleRemoveActive);\n this.addEventListener('pointercancel', this.handleRemoveActive);\n } else {\n this.removeEventListener('pointerup', this.handleRemoveActive);\n this.removeEventListener(\n 'pointerleave',\n this.handleRemoveActive\n );\n this.removeEventListener(\n 'pointercancel',\n this.handleRemoveActive\n );\n }\n }\n if (this.anchorElement) {\n this.anchorElement.addEventListener('focus', this.proxyFocus);\n this.anchorElement.tabIndex = -1;\n }\n if (changes.has('selected')) {\n this.updateAriaSelected();\n }\n if (changes.has('hasSubmenu')) {\n if (this.hasSubmenu) {\n this.addEventListener('click', this.handleSubmenuClick);\n this.addEventListener('pointerenter', this.handlePointerenter);\n this.addEventListener('pointerleave', this.handlePointerleave);\n } else if (!this.closeOverlay) {\n this.removeEventListener('click', this.handleSubmenuClick);\n this.removeEventListener(\n 'pointerenter',\n this.handlePointerenter\n );\n this.removeEventListener(\n 'pointerleave',\n this.handlePointerleave\n );\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.isInSubmenu = !!this.closest('[slot=\"submenu\"]');\n if (this.isInSubmenu) {\n return;\n }\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n this._parentElement = this.parentElement as HTMLElement;\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n removeEvent.reset(this);\n if (!this.isInSubmenu) {\n this._parentElement?.dispatchEvent(removeEvent);\n }\n this.isInSubmenu = false;\n super.disconnectedCallback();\n }\n\n public async triggerUpdate(): Promise<void> {\n if (this.isInSubmenu) {\n return;\n }\n await new Promise((ready) => requestAnimationFrame(ready));\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n }\n\n public menuData: {\n focusRoot?: Menu;\n selectionRoot?: Menu;\n } = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\n 'sp-menu-item-removed': MenuItemRemovedEvent;\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": ["el"]
7
7
  }
package/src/MenuItem.js CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var f=Object.defineProperty;var E=Object.getOwnPropertyDescriptor;var s=(h,o,e,t)=>{for(var i=t>1?void 0:t?E(o,e):o,r=h.length-1,n;r>=0;r--)(n=h[r])&&(i=(t?n(o,e,i):n(i))||i);return t&&i&&f(o,e,i),i};import{html as u}from"@spectrum-web-components/base";import{property as a,query as y}from"@spectrum-web-components/base/src/decorators.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js";import{LikeAnchor as S}from"@spectrum-web-components/shared/src/like-anchor.js";import{Focusable as C}from"@spectrum-web-components/shared/src/focusable.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js";import g from"@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js";import{openOverlay as R}from"@spectrum-web-components/overlay/src/loader.js";import{OverlayCloseEvent as A}from"@spectrum-web-components/overlay/src/overlay-events.js";import k from"./menu-item.css.js";import L from"@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js";import{reparentChildren as T}from"@spectrum-web-components/shared/src/reparent-children.js";import{MutationController as M}from"@lit-labs/observers/mutation_controller.js";const O=100;export class MenuItemRemovedEvent extends Event{constructor(){super("sp-menu-item-removed",{bubbles:!0,composed:!0});this.focused=!1}get item(){return this._item}reset(e){this._item=e}}export class MenuItemAddedOrUpdatedEvent extends Event{constructor(){super("sp-menu-item-added-or-updated",{bubbles:!0,composed:!0})}set focusRoot(e){this.item.menuData.focusRoot=this.item.menuData.focusRoot||e}set selectionRoot(e){this.item.menuData.selectionRoot=this.item.menuData.selectionRoot||e}get item(){return this._item}set currentAncestorWithSelects(e){this._currentAncestorWithSelects=e}get currentAncestorWithSelects(){return this._currentAncestorWithSelects}reset(e){this._item=e,this._currentAncestorWithSelects=void 0,e.menuData={focusRoot:void 0,selectionRoot:void 0}}}const d=new MenuItemAddedOrUpdatedEvent,v=new MenuItemRemovedEvent,p=class extends S(C){constructor(){super();this.isInSubmenu=!1;this.active=!1;this.focused=!1;this.selected=!1;this._value="";this.hasSubmenu=!1;this.noWrap=!1;this.open=!1;this.handleSubmenuChange=()=>{var e;(e=this.menuData.selectionRoot)==null||e.selectOrToggleItem(this)};this.handleSubmenuPointerenter=()=>{this.leaveTimeout&&(clearTimeout(this.leaveTimeout),delete this.leaveTimeout)};this.menuData={focusRoot:void 0,selectionRoot:void 0};this.proxyFocus=this.proxyFocus.bind(this),this.addEventListener("click",this.handleClickCapture,{capture:!0}),new M(this,{config:{characterData:!0,childList:!0,subtree:!0},callback:()=>{this.breakItemChildrenCache()}})}static get styles(){return[k,L,g]}get value(){return this._value||this.itemText}set value(e){e!==this._value&&(this._value=e||"",this._value?this.setAttribute("value",this._value):this.removeAttribute("value"))}get itemText(){return this.itemChildren.content.reduce((e,t)=>e+(t.textContent||"").trim(),"")}get focusElement(){return this}get itemChildren(){if(this._itemChildren)return this._itemChildren;const e=this.shadowRoot.querySelector('slot[name="icon"]'),t=e?e.assignedElements().map(n=>{const c=n.cloneNode(!0);return c.removeAttribute("slot"),c.classList.toggle("icon"),c}):[],i=this.shadowRoot.querySelector("slot:not([name])"),r=i?i.assignedNodes().map(n=>n.cloneNode(!0)):[];return this._itemChildren={icon:t,content:r},this._itemChildren}click(){this.disabled||this.shouldProxyClick()||super.click()}handleClickCapture(e){if(this.disabled)return e.preventDefault(),e.stopImmediatePropagation(),e.stopPropagation(),!1}proxyFocus(){this.focus()}shouldProxyClick(){let e=!1;return this.anchorElement&&(this.anchorElement.click(),e=!0),e}breakItemChildrenCache(){this._itemChildren=void 0,this.triggerUpdate()}render(){return u`
1
+ "use strict";var f=Object.defineProperty;var E=Object.getOwnPropertyDescriptor;var o=(h,r,e,t)=>{for(var i=t>1?void 0:t?E(r,e):r,a=h.length-1,s;a>=0;a--)(s=h[a])&&(i=(t?s(r,e,i):s(i))||i);return t&&i&&f(r,e,i),i};import{html as u}from"@spectrum-web-components/base";import{property as l,query as y}from"@spectrum-web-components/base/src/decorators.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js";import{LikeAnchor as S}from"@spectrum-web-components/shared/src/like-anchor.js";import{Focusable as C}from"@spectrum-web-components/shared/src/focusable.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js";import g from"@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js";import{openOverlay as R}from"@spectrum-web-components/overlay/src/loader.js";import{OverlayCloseEvent as A}from"@spectrum-web-components/overlay/src/overlay-events.js";import k from"./menu-item.css.js";import L from"@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js";import{reparentChildren as T}from"@spectrum-web-components/shared/src/reparent-children.js";import{MutationController as M}from"@lit-labs/observers/mutation_controller.js";const O=100;export class MenuItemRemovedEvent extends Event{constructor(){super("sp-menu-item-removed",{bubbles:!0,composed:!0});this.focused=!1}get item(){return this._item}reset(e){this._item=e}}export class MenuItemAddedOrUpdatedEvent extends Event{constructor(){super("sp-menu-item-added-or-updated",{bubbles:!0,composed:!0})}set focusRoot(e){this.item.menuData.focusRoot=this.item.menuData.focusRoot||e}set selectionRoot(e){this.item.menuData.selectionRoot=this.item.menuData.selectionRoot||e}get item(){return this._item}set currentAncestorWithSelects(e){this._currentAncestorWithSelects=e}get currentAncestorWithSelects(){return this._currentAncestorWithSelects}reset(e){this._item=e,this._currentAncestorWithSelects=void 0,e.menuData={focusRoot:void 0,selectionRoot:void 0}}}const m=new MenuItemAddedOrUpdatedEvent,b=new MenuItemRemovedEvent,v=class extends S(C){constructor(){super();this.isInSubmenu=!1;this.active=!1;this.focused=!1;this.selected=!1;this._value="";this.hasSubmenu=!1;this.noWrap=!1;this.open=!1;this.handleSubmenuChange=()=>{var e;(e=this.menuData.selectionRoot)==null||e.selectOrToggleItem(this)};this.handleSubmenuPointerenter=()=>{this.leaveTimeout&&(clearTimeout(this.leaveTimeout),delete this.leaveTimeout)};this.menuData={focusRoot:void 0,selectionRoot:void 0};this.proxyFocus=this.proxyFocus.bind(this),this.addEventListener("click",this.handleClickCapture,{capture:!0}),new M(this,{config:{characterData:!0,childList:!0,subtree:!0},callback:()=>{this.breakItemChildrenCache()}})}static get styles(){return[k,L,g]}get value(){return this._value||this.itemText}set value(e){e!==this._value&&(this._value=e||"",this._value?this.setAttribute("value",this._value):this.removeAttribute("value"))}get itemText(){return this.itemChildren.content.reduce((e,t)=>e+(t.textContent||"").trim(),"")}get focusElement(){return this}get itemChildren(){var s,d;if(this._itemChildren)return this._itemChildren;const e=(s=this.shadowRoot)==null?void 0:s.querySelector('slot[name="icon"]'),t=e?e.assignedElements().map(n=>{const c=n.cloneNode(!0);return c.removeAttribute("slot"),c.classList.toggle("icon"),c}):[],i=(d=this.shadowRoot)==null?void 0:d.querySelector("slot:not([name])"),a=i?i.assignedNodes().map(n=>n.cloneNode(!0)):[];return this._itemChildren={icon:t,content:a},this._itemChildren}click(){this.disabled||this.shouldProxyClick()||super.click()}handleClickCapture(e){if(this.disabled)return e.preventDefault(),e.stopImmediatePropagation(),e.stopPropagation(),!1}proxyFocus(){this.focus()}shouldProxyClick(){let e=!1;return this.anchorElement&&(this.anchorElement.click(),e=!0),e}breakItemChildrenCache(){this._itemChildren=void 0,this.triggerUpdate()}render(){return u`
2
2
  <slot name="icon"></slot>
3
3
  <div id="label">
4
4
  <slot id="slot"></slot>
@@ -21,5 +21,5 @@
21
21
  class="spectrum-UIIcon-ChevronRight100 chevron icon"
22
22
  ></sp-icon-chevron100>
23
23
  `:u``}
24
- `}manageSubmenu(e){const t=e.target.assignedElements({flatten:!0});this.hasSubmenu=this.open||!!t.length}handleRemoveActive(e){e.type==="pointerleave"&&this.hasSubmenu||this.hasSubmenu||this.open||(this.active=!1)}handlePointerdown(){this.active=!0}firstUpdated(e){super.firstUpdated(e),this.setAttribute("tabindex","-1"),this.addEventListener("pointerdown",this.handlePointerdown),this.hasAttribute("id")||(this.id=`sp-menu-item-${p.instanceCount++}`),this.addEventListener("pointerenter",this.closeOverlaysForRoot)}closeOverlaysForRoot(){if(this.open)return;const e=new A({root:this.menuData.focusRoot});this.dispatchEvent(e)}handleSubmenuClick(){this.openOverlay()}handlePointerenter(){if(this.leaveTimeout){clearTimeout(this.leaveTimeout),delete this.leaveTimeout;return}this.openOverlay()}handlePointerleave(){this.hasSubmenu&&this.open&&(this.leaveTimeout=setTimeout(()=>{delete this.leaveTimeout,this.closeOverlay&&this.closeOverlay()},O))}async openOverlay(){if(!this.hasSubmenu||this.open||this.disabled)return;this.open=!0,this.active=!0;const e=this.shadowRoot.querySelector('slot[name="submenu"]').assignedElements()[0];e.addEventListener("pointerenter",this.handleSubmenuPointerenter),e.addEventListener("change",this.handleSubmenuChange);const t=document.createElement("sp-popover"),i=T([e],t,{position:"beforeend",prepareCallback:l=>{const b=l.slot;return l.tabIndex=0,l.removeAttribute("slot"),l.isSubmenu=!0,m=>{m.tabIndex=-1,m.slot=b,m.isSubmenu=!1}}}),r=R(this,"click",t,{placement:this.isLTR?"right-start":"left-start",receivesFocus:"auto",root:this.menuData.focusRoot}),n=async()=>{delete this.closeOverlay,(await r)()};this.closeOverlay=n;const c=l=>{l.stopPropagation(),delete this.closeOverlay,i(),this.open=!1,this.active=!1};this.addEventListener("sp-closed",c,{once:!0}),t.addEventListener("change",n)}updateAriaSelected(){const e=this.getAttribute("role");e==="option"?this.setAttribute("aria-selected",this.selected?"true":"false"):(e==="menuitemcheckbox"||e==="menuitemradio")&&this.setAttribute("aria-checked",this.selected?"true":"false")}setRole(e){this.setAttribute("role",e),this.updateAriaSelected()}updated(e){super.updated(e),e.has("label")&&this.setAttribute("aria-label",this.label||""),e.has("active")&&(this.active?(this.addEventListener("pointerup",this.handleRemoveActive),this.addEventListener("pointerleave",this.handleRemoveActive),this.addEventListener("pointercancel",this.handleRemoveActive)):(this.removeEventListener("pointerup",this.handleRemoveActive),this.removeEventListener("pointerleave",this.handleRemoveActive),this.removeEventListener("pointercancel",this.handleRemoveActive))),this.anchorElement&&(this.anchorElement.addEventListener("focus",this.proxyFocus),this.anchorElement.tabIndex=-1),e.has("selected")&&this.updateAriaSelected(),e.has("hasSubmenu")&&(this.hasSubmenu?(this.addEventListener("click",this.handleSubmenuClick),this.addEventListener("pointerenter",this.handlePointerenter),this.addEventListener("pointerleave",this.handlePointerleave)):this.closeOverlay||(this.removeEventListener("click",this.handleSubmenuClick),this.removeEventListener("pointerenter",this.handlePointerenter),this.removeEventListener("pointerleave",this.handlePointerleave)))}connectedCallback(){super.connectedCallback(),this.isInSubmenu=!!this.closest('[slot="submenu"]'),!this.isInSubmenu&&(d.reset(this),this.dispatchEvent(d),this._parentElement=this.parentElement)}disconnectedCallback(){var e;v.reset(this),this.isInSubmenu||(e=this._parentElement)==null||e.dispatchEvent(v),this.isInSubmenu=!1,super.disconnectedCallback()}async triggerUpdate(){this.isInSubmenu||(await new Promise(e=>requestAnimationFrame(e)),d.reset(this),this.dispatchEvent(d))}};export let MenuItem=p;MenuItem.instanceCount=0,s([a({type:Boolean,reflect:!0})],MenuItem.prototype,"active",2),s([a({type:Boolean,reflect:!0})],MenuItem.prototype,"focused",2),s([a({type:Boolean,reflect:!0})],MenuItem.prototype,"selected",2),s([a({type:String})],MenuItem.prototype,"value",1),s([a({type:Boolean})],MenuItem.prototype,"hasSubmenu",2),s([a({type:Boolean,reflect:!0,attribute:"no-wrap",hasChanged(){return!1}})],MenuItem.prototype,"noWrap",2),s([y(".anchor")],MenuItem.prototype,"anchorElement",2),s([a({type:Boolean})],MenuItem.prototype,"open",2);
24
+ `}manageSubmenu(e){const t=e.target.assignedElements({flatten:!0});this.hasSubmenu=this.open||!!t.length}handleRemoveActive(e){e.type==="pointerleave"&&this.hasSubmenu||this.hasSubmenu||this.open||(this.active=!1)}handlePointerdown(){this.active=!0}firstUpdated(e){super.firstUpdated(e),this.setAttribute("tabindex","-1"),this.addEventListener("pointerdown",this.handlePointerdown),this.hasAttribute("id")||(this.id=`sp-menu-item-${v.instanceCount++}`),this.addEventListener("pointerenter",this.closeOverlaysForRoot)}closeOverlaysForRoot(){if(this.open)return;const e=new A({root:this.menuData.focusRoot});this.dispatchEvent(e)}handleSubmenuClick(){this.openOverlay()}handlePointerenter(){if(this.leaveTimeout){clearTimeout(this.leaveTimeout),delete this.leaveTimeout;return}this.openOverlay()}handlePointerleave(){this.hasSubmenu&&this.open&&(this.leaveTimeout=setTimeout(()=>{delete this.leaveTimeout,this.closeOverlay&&this.closeOverlay()},O))}async openOverlay(){if(!this.hasSubmenu||this.open||this.disabled)return;this.open=!0,this.active=!0;const e=this.shadowRoot.querySelector('slot[name="submenu"]').assignedElements()[0];e.addEventListener("pointerenter",this.handleSubmenuPointerenter),e.addEventListener("change",this.handleSubmenuChange);const t=document.createElement("sp-popover"),i=T([e],t,{position:"beforeend",prepareCallback:n=>{const c=n.slot;return n.tabIndex=0,n.removeAttribute("slot"),n.isSubmenu=!0,p=>{p.tabIndex=-1,p.slot=c,p.isSubmenu=!1}}}),a=R(this,"click",t,{placement:this.isLTR?"right-start":"left-start",receivesFocus:"auto",root:this.menuData.focusRoot}),s=async()=>{delete this.closeOverlay,(await a)()};this.closeOverlay=s;const d=n=>{n.stopPropagation(),delete this.closeOverlay,i(),this.open=!1,this.active=!1};this.addEventListener("sp-closed",d,{once:!0}),t.addEventListener("change",s)}updateAriaSelected(){const e=this.getAttribute("role");e==="option"?this.setAttribute("aria-selected",this.selected?"true":"false"):(e==="menuitemcheckbox"||e==="menuitemradio")&&this.setAttribute("aria-checked",this.selected?"true":"false")}setRole(e){this.setAttribute("role",e),this.updateAriaSelected()}updated(e){super.updated(e),e.has("label")&&this.setAttribute("aria-label",this.label||""),e.has("active")&&(this.active?(this.addEventListener("pointerup",this.handleRemoveActive),this.addEventListener("pointerleave",this.handleRemoveActive),this.addEventListener("pointercancel",this.handleRemoveActive)):(this.removeEventListener("pointerup",this.handleRemoveActive),this.removeEventListener("pointerleave",this.handleRemoveActive),this.removeEventListener("pointercancel",this.handleRemoveActive))),this.anchorElement&&(this.anchorElement.addEventListener("focus",this.proxyFocus),this.anchorElement.tabIndex=-1),e.has("selected")&&this.updateAriaSelected(),e.has("hasSubmenu")&&(this.hasSubmenu?(this.addEventListener("click",this.handleSubmenuClick),this.addEventListener("pointerenter",this.handlePointerenter),this.addEventListener("pointerleave",this.handlePointerleave)):this.closeOverlay||(this.removeEventListener("click",this.handleSubmenuClick),this.removeEventListener("pointerenter",this.handlePointerenter),this.removeEventListener("pointerleave",this.handlePointerleave)))}connectedCallback(){super.connectedCallback(),this.isInSubmenu=!!this.closest('[slot="submenu"]'),!this.isInSubmenu&&(m.reset(this),this.dispatchEvent(m),this._parentElement=this.parentElement)}disconnectedCallback(){var e;b.reset(this),this.isInSubmenu||(e=this._parentElement)==null||e.dispatchEvent(b),this.isInSubmenu=!1,super.disconnectedCallback()}async triggerUpdate(){this.isInSubmenu||(await new Promise(e=>requestAnimationFrame(e)),m.reset(this),this.dispatchEvent(m))}};export let MenuItem=v;MenuItem.instanceCount=0,o([l({type:Boolean,reflect:!0})],MenuItem.prototype,"active",2),o([l({type:Boolean,reflect:!0})],MenuItem.prototype,"focused",2),o([l({type:Boolean,reflect:!0})],MenuItem.prototype,"selected",2),o([l({type:String})],MenuItem.prototype,"value",1),o([l({type:Boolean})],MenuItem.prototype,"hasSubmenu",2),o([l({type:Boolean,reflect:!0,attribute:"no-wrap",hasChanged(){return!1}})],MenuItem.prototype,"noWrap",2),o([y(".anchor")],MenuItem.prototype,"anchorElement",2),o([l({type:Boolean})],MenuItem.prototype,"open",2);
25
25
  //# sourceMappingURL=MenuItem.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["MenuItem.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\n\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js';\nimport { LikeAnchor } from '@spectrum-web-components/shared/src/like-anchor.js';\nimport { Focusable } from '@spectrum-web-components/shared/src/focusable.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport { openOverlay } from '@spectrum-web-components/overlay/src/loader.js';\nimport { OverlayCloseEvent } from '@spectrum-web-components/overlay/src/overlay-events.js';\n\nimport menuItemStyles from './menu-item.css.js';\nimport checkmarkStyles from '@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js';\nimport type { Menu } from './Menu.js';\nimport type { OverlayOpenCloseDetail } from '@spectrum-web-components/overlay';\nimport { reparentChildren } from '@spectrum-web-components/shared/src/reparent-children.js';\nimport { MutationController } from '@lit-labs/observers/mutation_controller.js';\n\n/**\n * Duration during which a pointing device can leave an `<sp-menu-item>` element\n * and return to it or to the submenu opened from it before closing that submenu.\n **/\nconst POINTERLEAVE_TIMEOUT = 100;\n\nexport class MenuItemRemovedEvent extends Event {\n constructor() {\n super('sp-menu-item-removed', {\n bubbles: true,\n composed: true,\n });\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n focused = false;\n reset(item: MenuItem): void {\n this._item = item;\n }\n}\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor() {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n }\n set focusRoot(root: Menu | undefined) {\n this.item.menuData.focusRoot = this.item.menuData.focusRoot || root;\n }\n set selectionRoot(root: Menu) {\n this.item.menuData.selectionRoot =\n this.item.menuData.selectionRoot || root;\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n set currentAncestorWithSelects(ancestor: Menu | undefined) {\n this._currentAncestorWithSelects = ancestor;\n }\n get currentAncestorWithSelects(): Menu | undefined {\n return this._currentAncestorWithSelects;\n }\n _currentAncestorWithSelects?: Menu;\n reset(item: MenuItem): void {\n this._item = item;\n this._currentAncestorWithSelects = undefined;\n item.menuData = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n }\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\nconst addOrUpdateEvent = new MenuItemAddedOrUpdatedEvent();\nconst removeEvent = new MenuItemRemovedEvent();\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot icon - icon element to be placed at the start of the Menu Item\n * @slot value - content placed at the end of the Menu Item like values, keyboard shortcuts, etc.\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n * @fires sp-menu-item-removed - announces when removed from the DOM so the parent menu can remove ownership and update selected state\n */\nexport class MenuItem extends LikeAnchor(Focusable) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n static instanceCount = 0;\n\n private isInSubmenu = false;\n\n @property({ type: Boolean, reflect: true })\n public active = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: Boolean, reflect: true })\n public selected = false;\n\n @property({ type: String })\n public get value(): string {\n return this._value || this.itemText;\n }\n\n public set value(value: string) {\n if (value === this._value) {\n return;\n }\n this._value = value || '';\n if (this._value) {\n this.setAttribute('value', this._value);\n } else {\n this.removeAttribute('value');\n }\n }\n\n private _value = '';\n\n /**\n * @private\n */\n public get itemText(): string {\n return this.itemChildren.content.reduce(\n (acc, node) => acc + (node.textContent || '').trim(),\n ''\n );\n }\n\n @property({ type: Boolean })\n public hasSubmenu = false;\n\n @property({\n type: Boolean,\n reflect: true,\n attribute: 'no-wrap',\n hasChanged() {\n return false;\n },\n })\n public noWrap = false;\n\n @query('.anchor')\n private anchorElement!: HTMLAnchorElement;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (this._itemChildren) {\n return this._itemChildren;\n }\n\n const iconSlot = this.shadowRoot.querySelector(\n 'slot[name=\"icon\"]'\n ) as HTMLSlotElement;\n const icon = !iconSlot\n ? []\n : iconSlot.assignedElements().map((element) => {\n const newElement = element.cloneNode(true) as HTMLElement;\n newElement.removeAttribute('slot');\n newElement.classList.toggle('icon');\n return newElement;\n });\n const contentSlot = this.shadowRoot.querySelector(\n 'slot:not([name])'\n ) as HTMLSlotElement;\n const content = !contentSlot\n ? []\n : contentSlot.assignedNodes().map((node) => node.cloneNode(true));\n this._itemChildren = { icon, content };\n\n return this._itemChildren;\n }\n\n private _itemChildren?: MenuItemChildren;\n\n constructor() {\n super();\n this.proxyFocus = this.proxyFocus.bind(this);\n\n this.addEventListener('click', this.handleClickCapture, {\n capture: true,\n });\n\n new MutationController(this, {\n config: {\n characterData: true,\n childList: true,\n subtree: true,\n },\n callback: () => {\n this.breakItemChildrenCache();\n },\n });\n }\n\n @property({ type: Boolean })\n public open = false;\n\n public override click(): void {\n if (this.disabled) {\n return;\n }\n\n if (this.shouldProxyClick()) {\n return;\n }\n\n super.click();\n }\n\n private handleClickCapture(event: Event): void | boolean {\n if (this.disabled) {\n event.preventDefault();\n event.stopImmediatePropagation();\n event.stopPropagation();\n return false;\n }\n }\n\n private proxyFocus(): void {\n this.focus();\n }\n\n private shouldProxyClick(): boolean {\n let handled = false;\n if (this.anchorElement) {\n this.anchorElement.click();\n handled = true;\n }\n return handled;\n }\n\n protected breakItemChildrenCache(): void {\n this._itemChildren = undefined;\n this.triggerUpdate();\n }\n\n protected override render(): TemplateResult {\n return html`\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"value\"></slot>\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 icon checkmark\"\n ></sp-icon-checkmark100>\n `\n : html``}\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : html``}\n <slot\n hidden\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n ></slot>\n ${this.hasSubmenu\n ? html`\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `\n : html``}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = this.open || !!assignedElements.length;\n }\n\n private handleRemoveActive(event: Event): void {\n if (\n (event.type === 'pointerleave' && this.hasSubmenu) ||\n this.hasSubmenu ||\n this.open\n ) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(): void {\n this.active = true;\n }\n\n protected override firstUpdated(changes: PropertyValues): void {\n super.firstUpdated(changes);\n this.setAttribute('tabindex', '-1');\n this.addEventListener('pointerdown', this.handlePointerdown);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${MenuItem.instanceCount++}`;\n }\n this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n const overalyCloseEvent = new OverlayCloseEvent({\n root: this.menuData.focusRoot,\n });\n this.dispatchEvent(overalyCloseEvent);\n }\n\n public closeOverlay?: () => Promise<void>;\n\n protected handleSubmenuClick(): void {\n this.openOverlay();\n }\n\n protected handlePointerenter(): void {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n return;\n }\n this.openOverlay();\n }\n\n protected leaveTimeout?: ReturnType<typeof setTimeout>;\n\n protected handlePointerleave(): void {\n if (this.hasSubmenu && this.open) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n if (this.closeOverlay) this.closeOverlay();\n }, POINTERLEAVE_TIMEOUT);\n }\n }\n\n /**\n * When there is a `change` event in the submenu for this item\n * then we \"click\" this item to cascade the selection up the\n * menu tree allowing all submenus between the initial selection\n * and the root of the tree to have their selection changes and\n * be closed.\n */\n protected handleSubmenuChange = (): void => {\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n };\n\n protected handleSubmenuPointerenter = (): void => {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n }\n };\n\n public async openOverlay(): Promise<void> {\n if (!this.hasSubmenu || this.open || this.disabled) {\n return;\n }\n this.open = true;\n this.active = true;\n const submenu = (\n this.shadowRoot.querySelector(\n 'slot[name=\"submenu\"]'\n ) as HTMLSlotElement\n ).assignedElements()[0] as Menu;\n submenu.addEventListener(\n 'pointerenter',\n this.handleSubmenuPointerenter\n );\n submenu.addEventListener('change', this.handleSubmenuChange);\n const popover = document.createElement('sp-popover');\n const returnSubmenu = reparentChildren([submenu], popover, {\n position: 'beforeend',\n prepareCallback: (el) => {\n const slotName = el.slot;\n el.tabIndex = 0;\n el.removeAttribute('slot');\n el.isSubmenu = true;\n return (el) => {\n el.tabIndex = -1;\n el.slot = slotName;\n el.isSubmenu = false;\n };\n },\n });\n const closeOverlay = openOverlay(this, 'click', popover, {\n placement: this.isLTR ? 'right-start' : 'left-start',\n receivesFocus: 'auto',\n root: this.menuData.focusRoot,\n });\n const closeSubmenu = async (): Promise<void> => {\n delete this.closeOverlay;\n (await closeOverlay)();\n };\n this.closeOverlay = closeSubmenu;\n const cleanup = (event: CustomEvent<OverlayOpenCloseDetail>): void => {\n event.stopPropagation();\n delete this.closeOverlay;\n returnSubmenu();\n this.open = false;\n this.active = false;\n };\n this.addEventListener('sp-closed', cleanup as EventListener, {\n once: true,\n });\n popover.addEventListener('change', closeSubmenu);\n }\n\n updateAriaSelected(): void {\n const role = this.getAttribute('role');\n if (role === 'option') {\n this.setAttribute(\n 'aria-selected',\n this.selected ? 'true' : 'false'\n );\n } else if (role === 'menuitemcheckbox' || role === 'menuitemradio') {\n this.setAttribute('aria-checked', this.selected ? 'true' : 'false');\n }\n }\n\n public setRole(role: string): void {\n this.setAttribute('role', role);\n this.updateAriaSelected();\n }\n\n protected override updated(changes: PropertyValues<this>): void {\n super.updated(changes);\n if (changes.has('label')) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (changes.has('active')) {\n if (this.active) {\n this.addEventListener('pointerup', this.handleRemoveActive);\n this.addEventListener('pointerleave', this.handleRemoveActive);\n this.addEventListener('pointercancel', this.handleRemoveActive);\n } else {\n this.removeEventListener('pointerup', this.handleRemoveActive);\n this.removeEventListener(\n 'pointerleave',\n this.handleRemoveActive\n );\n this.removeEventListener(\n 'pointercancel',\n this.handleRemoveActive\n );\n }\n }\n if (this.anchorElement) {\n this.anchorElement.addEventListener('focus', this.proxyFocus);\n this.anchorElement.tabIndex = -1;\n }\n if (changes.has('selected')) {\n this.updateAriaSelected();\n }\n if (changes.has('hasSubmenu')) {\n if (this.hasSubmenu) {\n this.addEventListener('click', this.handleSubmenuClick);\n this.addEventListener('pointerenter', this.handlePointerenter);\n this.addEventListener('pointerleave', this.handlePointerleave);\n } else if (!this.closeOverlay) {\n this.removeEventListener('click', this.handleSubmenuClick);\n this.removeEventListener(\n 'pointerenter',\n this.handlePointerenter\n );\n this.removeEventListener(\n 'pointerleave',\n this.handlePointerleave\n );\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.isInSubmenu = !!this.closest('[slot=\"submenu\"]');\n if (this.isInSubmenu) {\n return;\n }\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n this._parentElement = this.parentElement as HTMLElement;\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n removeEvent.reset(this);\n if (!this.isInSubmenu) {\n this._parentElement?.dispatchEvent(removeEvent);\n }\n this.isInSubmenu = false;\n super.disconnectedCallback();\n }\n\n public async triggerUpdate(): Promise<void> {\n if (this.isInSubmenu) {\n return;\n }\n await new Promise((ready) => requestAnimationFrame(ready));\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n }\n\n public menuData: {\n focusRoot?: Menu;\n selectionRoot?: Menu;\n } = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\n 'sp-menu-item-removed': MenuItemRemovedEvent;\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["html", "property", "query", "LikeAnchor", "Focusable", "chevronStyles", "openOverlay", "OverlayCloseEvent", "menuItemStyles", "checkmarkStyles", "reparentChildren", "MutationController", "POINTERLEAVE_TIMEOUT", "item", "root", "ancestor", "addOrUpdateEvent", "removeEvent", "_MenuItem", "_a", "value", "acc", "node", "iconSlot", "icon", "element", "newElement", "contentSlot", "content", "event", "handled", "assignedElements", "changes", "overalyCloseEvent", "submenu", "popover", "returnSubmenu", "el", "slotName", "closeOverlay", "closeSubmenu", "cleanup", "role", "ready", "__decorateClass"]
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\n\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js';\nimport { LikeAnchor } from '@spectrum-web-components/shared/src/like-anchor.js';\nimport { Focusable } from '@spectrum-web-components/shared/src/focusable.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport { openOverlay } from '@spectrum-web-components/overlay/src/loader.js';\nimport { OverlayCloseEvent } from '@spectrum-web-components/overlay/src/overlay-events.js';\n\nimport menuItemStyles from './menu-item.css.js';\nimport checkmarkStyles from '@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js';\nimport type { Menu } from './Menu.js';\nimport type { OverlayOpenCloseDetail } from '@spectrum-web-components/overlay';\nimport { reparentChildren } from '@spectrum-web-components/shared/src/reparent-children.js';\nimport { MutationController } from '@lit-labs/observers/mutation_controller.js';\n\n/**\n * Duration during which a pointing device can leave an `<sp-menu-item>` element\n * and return to it or to the submenu opened from it before closing that submenu.\n **/\nconst POINTERLEAVE_TIMEOUT = 100;\n\nexport class MenuItemRemovedEvent extends Event {\n constructor() {\n super('sp-menu-item-removed', {\n bubbles: true,\n composed: true,\n });\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n focused = false;\n reset(item: MenuItem): void {\n this._item = item;\n }\n}\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor() {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n }\n set focusRoot(root: Menu | undefined) {\n this.item.menuData.focusRoot = this.item.menuData.focusRoot || root;\n }\n set selectionRoot(root: Menu) {\n this.item.menuData.selectionRoot =\n this.item.menuData.selectionRoot || root;\n }\n get item(): MenuItem {\n return this._item;\n }\n _item!: MenuItem;\n set currentAncestorWithSelects(ancestor: Menu | undefined) {\n this._currentAncestorWithSelects = ancestor;\n }\n get currentAncestorWithSelects(): Menu | undefined {\n return this._currentAncestorWithSelects;\n }\n _currentAncestorWithSelects?: Menu;\n reset(item: MenuItem): void {\n this._item = item;\n this._currentAncestorWithSelects = undefined;\n item.menuData = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n }\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\nconst addOrUpdateEvent = new MenuItemAddedOrUpdatedEvent();\nconst removeEvent = new MenuItemRemovedEvent();\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot icon - icon element to be placed at the start of the Menu Item\n * @slot value - content placed at the end of the Menu Item like values, keyboard shortcuts, etc.\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n * @fires sp-menu-item-removed - announces when removed from the DOM so the parent menu can remove ownership and update selected state\n */\nexport class MenuItem extends LikeAnchor(Focusable) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n static instanceCount = 0;\n\n private isInSubmenu = false;\n\n @property({ type: Boolean, reflect: true })\n public active = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: Boolean, reflect: true })\n public selected = false;\n\n @property({ type: String })\n public get value(): string {\n return this._value || this.itemText;\n }\n\n public set value(value: string) {\n if (value === this._value) {\n return;\n }\n this._value = value || '';\n if (this._value) {\n this.setAttribute('value', this._value);\n } else {\n this.removeAttribute('value');\n }\n }\n\n private _value = '';\n\n /**\n * @private\n */\n public get itemText(): string {\n return this.itemChildren.content.reduce(\n (acc, node) => acc + (node.textContent || '').trim(),\n ''\n );\n }\n\n @property({ type: Boolean })\n public hasSubmenu = false;\n\n @property({\n type: Boolean,\n reflect: true,\n attribute: 'no-wrap',\n hasChanged() {\n return false;\n },\n })\n public noWrap = false;\n\n @query('.anchor')\n private anchorElement!: HTMLAnchorElement;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (this._itemChildren) {\n return this._itemChildren;\n }\n\n const iconSlot = this.shadowRoot?.querySelector(\n 'slot[name=\"icon\"]'\n ) as HTMLSlotElement;\n const icon = !iconSlot\n ? []\n : iconSlot.assignedElements().map((element) => {\n const newElement = element.cloneNode(true) as HTMLElement;\n newElement.removeAttribute('slot');\n newElement.classList.toggle('icon');\n return newElement;\n });\n const contentSlot = this.shadowRoot?.querySelector(\n 'slot:not([name])'\n ) as HTMLSlotElement;\n const content = !contentSlot\n ? []\n : contentSlot.assignedNodes().map((node) => node.cloneNode(true));\n this._itemChildren = { icon, content };\n\n return this._itemChildren;\n }\n\n private _itemChildren?: MenuItemChildren;\n\n constructor() {\n super();\n this.proxyFocus = this.proxyFocus.bind(this);\n\n this.addEventListener('click', this.handleClickCapture, {\n capture: true,\n });\n\n new MutationController(this, {\n config: {\n characterData: true,\n childList: true,\n subtree: true,\n },\n callback: () => {\n this.breakItemChildrenCache();\n },\n });\n }\n\n @property({ type: Boolean })\n public open = false;\n\n public override click(): void {\n if (this.disabled) {\n return;\n }\n\n if (this.shouldProxyClick()) {\n return;\n }\n\n super.click();\n }\n\n private handleClickCapture(event: Event): void | boolean {\n if (this.disabled) {\n event.preventDefault();\n event.stopImmediatePropagation();\n event.stopPropagation();\n return false;\n }\n }\n\n private proxyFocus(): void {\n this.focus();\n }\n\n private shouldProxyClick(): boolean {\n let handled = false;\n if (this.anchorElement) {\n this.anchorElement.click();\n handled = true;\n }\n return handled;\n }\n\n protected breakItemChildrenCache(): void {\n this._itemChildren = undefined;\n this.triggerUpdate();\n }\n\n protected override render(): TemplateResult {\n return html`\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"value\"></slot>\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 icon checkmark\"\n ></sp-icon-checkmark100>\n `\n : html``}\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : html``}\n <slot\n hidden\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n ></slot>\n ${this.hasSubmenu\n ? html`\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `\n : html``}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = this.open || !!assignedElements.length;\n }\n\n private handleRemoveActive(event: Event): void {\n if (\n (event.type === 'pointerleave' && this.hasSubmenu) ||\n this.hasSubmenu ||\n this.open\n ) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(): void {\n this.active = true;\n }\n\n protected override firstUpdated(changes: PropertyValues): void {\n super.firstUpdated(changes);\n this.setAttribute('tabindex', '-1');\n this.addEventListener('pointerdown', this.handlePointerdown);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${MenuItem.instanceCount++}`;\n }\n this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n const overalyCloseEvent = new OverlayCloseEvent({\n root: this.menuData.focusRoot,\n });\n this.dispatchEvent(overalyCloseEvent);\n }\n\n public closeOverlay?: () => Promise<void>;\n\n protected handleSubmenuClick(): void {\n this.openOverlay();\n }\n\n protected handlePointerenter(): void {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n return;\n }\n this.openOverlay();\n }\n\n protected leaveTimeout?: ReturnType<typeof setTimeout>;\n\n protected handlePointerleave(): void {\n if (this.hasSubmenu && this.open) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n if (this.closeOverlay) this.closeOverlay();\n }, POINTERLEAVE_TIMEOUT);\n }\n }\n\n /**\n * When there is a `change` event in the submenu for this item\n * then we \"click\" this item to cascade the selection up the\n * menu tree allowing all submenus between the initial selection\n * and the root of the tree to have their selection changes and\n * be closed.\n */\n protected handleSubmenuChange = (): void => {\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n };\n\n protected handleSubmenuPointerenter = (): void => {\n if (this.leaveTimeout) {\n clearTimeout(this.leaveTimeout);\n delete this.leaveTimeout;\n }\n };\n\n public async openOverlay(): Promise<void> {\n if (!this.hasSubmenu || this.open || this.disabled) {\n return;\n }\n this.open = true;\n this.active = true;\n const submenu = (\n this.shadowRoot.querySelector(\n 'slot[name=\"submenu\"]'\n ) as HTMLSlotElement\n ).assignedElements()[0] as Menu;\n submenu.addEventListener(\n 'pointerenter',\n this.handleSubmenuPointerenter\n );\n submenu.addEventListener('change', this.handleSubmenuChange);\n const popover = document.createElement('sp-popover');\n const returnSubmenu = reparentChildren([submenu], popover, {\n position: 'beforeend',\n prepareCallback: (el) => {\n const slotName = el.slot;\n el.tabIndex = 0;\n el.removeAttribute('slot');\n el.isSubmenu = true;\n return (el) => {\n el.tabIndex = -1;\n el.slot = slotName;\n el.isSubmenu = false;\n };\n },\n });\n const closeOverlay = openOverlay(this, 'click', popover, {\n placement: this.isLTR ? 'right-start' : 'left-start',\n receivesFocus: 'auto',\n root: this.menuData.focusRoot,\n });\n const closeSubmenu = async (): Promise<void> => {\n delete this.closeOverlay;\n (await closeOverlay)();\n };\n this.closeOverlay = closeSubmenu;\n const cleanup = (event: CustomEvent<OverlayOpenCloseDetail>): void => {\n event.stopPropagation();\n delete this.closeOverlay;\n returnSubmenu();\n this.open = false;\n this.active = false;\n };\n this.addEventListener('sp-closed', cleanup as EventListener, {\n once: true,\n });\n popover.addEventListener('change', closeSubmenu);\n }\n\n updateAriaSelected(): void {\n const role = this.getAttribute('role');\n if (role === 'option') {\n this.setAttribute(\n 'aria-selected',\n this.selected ? 'true' : 'false'\n );\n } else if (role === 'menuitemcheckbox' || role === 'menuitemradio') {\n this.setAttribute('aria-checked', this.selected ? 'true' : 'false');\n }\n }\n\n public setRole(role: string): void {\n this.setAttribute('role', role);\n this.updateAriaSelected();\n }\n\n protected override updated(changes: PropertyValues<this>): void {\n super.updated(changes);\n if (changes.has('label')) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (changes.has('active')) {\n if (this.active) {\n this.addEventListener('pointerup', this.handleRemoveActive);\n this.addEventListener('pointerleave', this.handleRemoveActive);\n this.addEventListener('pointercancel', this.handleRemoveActive);\n } else {\n this.removeEventListener('pointerup', this.handleRemoveActive);\n this.removeEventListener(\n 'pointerleave',\n this.handleRemoveActive\n );\n this.removeEventListener(\n 'pointercancel',\n this.handleRemoveActive\n );\n }\n }\n if (this.anchorElement) {\n this.anchorElement.addEventListener('focus', this.proxyFocus);\n this.anchorElement.tabIndex = -1;\n }\n if (changes.has('selected')) {\n this.updateAriaSelected();\n }\n if (changes.has('hasSubmenu')) {\n if (this.hasSubmenu) {\n this.addEventListener('click', this.handleSubmenuClick);\n this.addEventListener('pointerenter', this.handlePointerenter);\n this.addEventListener('pointerleave', this.handlePointerleave);\n } else if (!this.closeOverlay) {\n this.removeEventListener('click', this.handleSubmenuClick);\n this.removeEventListener(\n 'pointerenter',\n this.handlePointerenter\n );\n this.removeEventListener(\n 'pointerleave',\n this.handlePointerleave\n );\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.isInSubmenu = !!this.closest('[slot=\"submenu\"]');\n if (this.isInSubmenu) {\n return;\n }\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n this._parentElement = this.parentElement as HTMLElement;\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n removeEvent.reset(this);\n if (!this.isInSubmenu) {\n this._parentElement?.dispatchEvent(removeEvent);\n }\n this.isInSubmenu = false;\n super.disconnectedCallback();\n }\n\n public async triggerUpdate(): Promise<void> {\n if (this.isInSubmenu) {\n return;\n }\n await new Promise((ready) => requestAnimationFrame(ready));\n addOrUpdateEvent.reset(this);\n this.dispatchEvent(addOrUpdateEvent);\n }\n\n public menuData: {\n focusRoot?: Menu;\n selectionRoot?: Menu;\n } = {\n focusRoot: undefined,\n selectionRoot: undefined,\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\n 'sp-menu-item-removed': MenuItemRemovedEvent;\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["html", "property", "query", "LikeAnchor", "Focusable", "chevronStyles", "openOverlay", "OverlayCloseEvent", "menuItemStyles", "checkmarkStyles", "reparentChildren", "MutationController", "POINTERLEAVE_TIMEOUT", "item", "root", "ancestor", "addOrUpdateEvent", "removeEvent", "_MenuItem", "_a", "value", "acc", "node", "_b", "iconSlot", "icon", "element", "newElement", "contentSlot", "content", "event", "handled", "assignedElements", "changes", "overalyCloseEvent", "submenu", "popover", "returnSubmenu", "el", "slotName", "closeOverlay", "closeSubmenu", "cleanup", "role", "ready", "__decorateClass"]
7
7
  }
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __decorateClass = (decorators, target, key, kind) => {
5
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
6
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
7
+ if (decorator = decorators[i])
8
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
9
+ if (kind && result)
10
+ __defProp(target, key, result);
11
+ return result;
12
+ };
13
+ import { html, LitElement } from "lit";
14
+ import { property, state } from "lit/decorators.js";
15
+ import { repeat } from "lit/directives/repeat.js";
16
+ import { when } from "lit/directives/when.js";
17
+ import "@spectrum-web-components/picker/sp-picker.js";
18
+ import "@spectrum-web-components/button/sp-button.js";
19
+ import { SpectrumMixin } from "@spectrum-web-components/base";
20
+ var BlendModeValue = /* @__PURE__ */ ((BlendModeValue2) => {
21
+ BlendModeValue2[BlendModeValue2["normal"] = 2] = "normal";
22
+ BlendModeValue2[BlendModeValue2["multiply"] = 3] = "multiply";
23
+ BlendModeValue2[BlendModeValue2["screen"] = 7] = "screen";
24
+ return BlendModeValue2;
25
+ })(BlendModeValue || {});
26
+ const XElement = SpectrumMixin(LitElement);
27
+ class MyContainer extends XElement {
28
+ constructor() {
29
+ super(...arguments);
30
+ this._counter = 0;
31
+ }
32
+ _handleClick() {
33
+ this._counter += 1;
34
+ }
35
+ render() {
36
+ return html`
37
+ <div>
38
+ ${when(
39
+ this._counter % 2 === 0,
40
+ () => html`
41
+ <my-view1></my-view1>
42
+ `,
43
+ () => html`
44
+ <my-view2></my-view2>
45
+ `
46
+ )}
47
+ <sp-button
48
+ variant="primary"
49
+ size="m"
50
+ @click=${this._handleClick}
51
+ >
52
+ Switch views
53
+ </sp-button>
54
+ </div>
55
+ `;
56
+ }
57
+ }
58
+ __decorateClass([
59
+ state()
60
+ ], MyContainer.prototype, "_counter", 2);
61
+ customElements.define("my-container", MyContainer);
62
+ class MyView1 extends XElement {
63
+ render() {
64
+ const blendModeOptions = [
65
+ {
66
+ value: 2 /* normal */,
67
+ title: "Normal 1",
68
+ subtitle: "No effect applied"
69
+ },
70
+ {
71
+ value: 3 /* multiply */,
72
+ title: "Multiply",
73
+ subtitle: "Darken shadows with contrast and details"
74
+ },
75
+ {
76
+ value: 7 /* screen */,
77
+ title: "Screen",
78
+ subtitle: "Brighten highlights with contrast and details"
79
+ }
80
+ ];
81
+ return html`
82
+ View 1
83
+ <my-picker
84
+ .blendMode=${2 /* normal */}
85
+ .blendModeOptions=${blendModeOptions}
86
+ dir="ltr"
87
+ ></my-picker>
88
+ `;
89
+ }
90
+ }
91
+ customElements.define("my-view1", MyView1);
92
+ class MyView2 extends XElement {
93
+ render() {
94
+ const blendModeOptions = [
95
+ {
96
+ value: 2 /* normal */,
97
+ title: "Normal 2",
98
+ subtitle: "No effect applied"
99
+ },
100
+ {
101
+ value: 3 /* multiply */,
102
+ title: "Multiply",
103
+ subtitle: "Darken shadows with contrast and details"
104
+ },
105
+ {
106
+ value: 7 /* screen */,
107
+ title: "Screen",
108
+ subtitle: "Brighten highlights with contrast and details"
109
+ }
110
+ ];
111
+ return html`
112
+ View 2
113
+ <my-picker
114
+ .blendMode=${2 /* normal */}
115
+ .blendModeOptions=${blendModeOptions}
116
+ ></my-picker>
117
+ `;
118
+ }
119
+ }
120
+ customElements.define("my-view2", MyView2);
121
+ class MyPicker extends XElement {
122
+ constructor() {
123
+ super(...arguments);
124
+ this.blendModeOptions = [];
125
+ this.blendMode = 2 /* normal */;
126
+ }
127
+ _renderBlendOptions() {
128
+ return html`
129
+ ${repeat(
130
+ this.blendModeOptions,
131
+ // This is intentional so that repeat directive will add instead of
132
+ // update existing DOM which will then trigger error in
133
+ // MenuItem.childrenItem
134
+ // Using .value for the key will workaround the issue
135
+ (blendModeOption) => blendModeOption,
136
+ (blendModeOption) => html`
137
+ <sp-menu-item value=${blendModeOption.value}>
138
+ ${blendModeOption.title}
139
+ <span slot="value">
140
+ ${blendModeOption.subtitle}
141
+ </span>
142
+ </sp-menu-item>
143
+ `
144
+ )}
145
+ `;
146
+ }
147
+ render() {
148
+ return html`
149
+ <sp-picker
150
+ id="blendMode"
151
+ size="l"
152
+ label="Blend"
153
+ value=${this.blendMode}
154
+ >
155
+ ${this._renderBlendOptions()}
156
+ </sp-picker>
157
+ `;
158
+ }
159
+ }
160
+ __decorateClass([
161
+ property({ type: Array })
162
+ ], MyPicker.prototype, "blendModeOptions", 2);
163
+ __decorateClass([
164
+ property()
165
+ ], MyPicker.prototype, "blendMode", 2);
166
+ customElements.define("my-picker", MyPicker);
167
+ export default {
168
+ component: "sp-menu-item",
169
+ title: "Menu Item/Disconnected"
170
+ };
171
+ export const disconnectedChildItems = () => html`
172
+ <my-container></my-container>
173
+ `;
174
+ disconnectedChildItems.swc_vrt = {
175
+ skip: true
176
+ };
177
+ //# sourceMappingURL=menu-item.disconnected.stories.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["menu-item.disconnected.stories.ts"],
4
+ "sourcesContent": ["/*\nCopyright 2023 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport { html, LitElement, TemplateResult } from 'lit';\nimport { property, state } from 'lit/decorators.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport { when } from 'lit/directives/when.js';\n\nimport '@spectrum-web-components/picker/sp-picker.js';\nimport '@spectrum-web-components/button/sp-button.js';\nimport { SpectrumMixin } from '@spectrum-web-components/base';\n\nenum BlendModeValue {\n normal = 2,\n multiply = 3,\n screen = 7,\n}\n\ninterface BlendModeOption {\n value: BlendModeValue;\n title: string;\n subtitle: string;\n thumbnail: string;\n}\n\nconst XElement = SpectrumMixin(LitElement);\n\nclass MyContainer extends XElement {\n @state()\n private _counter = 0;\n\n private _handleClick(): void {\n this._counter += 1;\n }\n\n protected override render(): TemplateResult {\n return html`\n <div>\n ${when(\n this._counter % 2 === 0,\n () => html`\n <my-view1></my-view1>\n `,\n () => html`\n <my-view2></my-view2>\n `\n )}\n <sp-button\n variant=\"primary\"\n size=\"m\"\n @click=${this._handleClick}\n >\n Switch views\n </sp-button>\n </div>\n `;\n }\n}\n\ncustomElements.define('my-container', MyContainer);\n\nclass MyView1 extends XElement {\n protected override render(): TemplateResult {\n const blendModeOptions = [\n {\n value: BlendModeValue.normal,\n title: 'Normal 1',\n subtitle: 'No effect applied',\n },\n {\n value: BlendModeValue.multiply,\n title: 'Multiply',\n subtitle: 'Darken shadows with contrast and details',\n },\n {\n value: BlendModeValue.screen,\n title: 'Screen',\n subtitle: 'Brighten highlights with contrast and details',\n },\n ];\n return html`\n View 1\n <my-picker\n .blendMode=${BlendModeValue.normal}\n .blendModeOptions=${blendModeOptions}\n dir=\"ltr\"\n ></my-picker>\n `;\n }\n}\n\ncustomElements.define('my-view1', MyView1);\n\nclass MyView2 extends XElement {\n protected override render(): TemplateResult {\n const blendModeOptions = [\n {\n value: BlendModeValue.normal,\n title: 'Normal 2',\n subtitle: 'No effect applied',\n },\n {\n value: BlendModeValue.multiply,\n title: 'Multiply',\n subtitle: 'Darken shadows with contrast and details',\n },\n {\n value: BlendModeValue.screen,\n title: 'Screen',\n subtitle: 'Brighten highlights with contrast and details',\n },\n ];\n return html`\n View 2\n <my-picker\n .blendMode=${BlendModeValue.normal}\n .blendModeOptions=${blendModeOptions}\n ></my-picker>\n `;\n }\n}\n\ncustomElements.define('my-view2', MyView2);\n\nclass MyPicker extends XElement {\n @property({ type: Array })\n public blendModeOptions: BlendModeOption[] = [];\n\n @property()\n public blendMode: number = BlendModeValue.normal;\n\n private _renderBlendOptions(): TemplateResult {\n return html`\n ${repeat(\n this.blendModeOptions,\n // This is intentional so that repeat directive will add instead of\n // update existing DOM which will then trigger error in\n // MenuItem.childrenItem\n // Using .value for the key will workaround the issue\n (blendModeOption) => blendModeOption,\n (blendModeOption: BlendModeOption) =>\n html`\n <sp-menu-item value=${blendModeOption.value}>\n ${blendModeOption.title}\n <span slot=\"value\">\n ${blendModeOption.subtitle}\n </span>\n </sp-menu-item>\n `\n )}\n `;\n }\n protected override render(): TemplateResult {\n return html`\n <sp-picker\n id=\"blendMode\"\n size=\"l\"\n label=\"Blend\"\n value=${this.blendMode}\n >\n ${this._renderBlendOptions()}\n </sp-picker>\n `;\n }\n}\n\ncustomElements.define('my-picker', MyPicker);\n\nexport default {\n component: 'sp-menu-item',\n title: 'Menu Item/Disconnected',\n};\n\nexport const disconnectedChildItems = (): TemplateResult => html`\n <my-container></my-container>\n`;\n\ndisconnectedChildItems.swc_vrt = {\n skip: true,\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["BlendModeValue"]
7
+ }
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ import * as stories from "../stories/menu-item.disconnected.stories.js";
3
+ import { regressVisuals } from "../../../test/visual/test.js";
4
+ regressVisuals("MenuItem.disconnectedStories", stories);
5
+ //# sourceMappingURL=menu-item.disconnected.test-vrt.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["menu-item.disconnected.test-vrt.ts"],
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport * as stories from '../stories/menu-item.disconnected.stories.js';\nimport { regressVisuals } from '../../../test/visual/test.js';\nimport type { TestsType } from '../../../test/visual/test.js';\n\nregressVisuals('MenuItem.disconnectedStories', stories as unknown as TestsType);\n"],
5
+ "mappings": ";AAYA,YAAY,aAAa;AACzB,SAAS,sBAAsB;AAG/B,eAAe,gCAAgC,OAA+B;",
6
+ "names": []
7
+ }