@spectrum-web-components/menu 0.40.5 → 0.41.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/package.json +10 -10
  2. package/src/MenuGroup.dev.js +2 -1
  3. package/src/MenuGroup.dev.js.map +2 -2
  4. package/src/MenuGroup.js +1 -1
  5. package/src/MenuGroup.js.map +3 -3
  6. package/src/MenuItem.dev.js +3 -2
  7. package/src/MenuItem.dev.js.map +2 -2
  8. package/src/MenuItem.js +2 -2
  9. package/src/MenuItem.js.map +3 -3
  10. package/src/menu-divider.css.dev.js +5 -5
  11. package/src/menu-divider.css.dev.js.map +1 -1
  12. package/src/menu-divider.css.js +5 -5
  13. package/src/menu-divider.css.js.map +1 -1
  14. package/src/menu-group.css.dev.js +5 -5
  15. package/src/menu-group.css.dev.js.map +1 -1
  16. package/src/menu-group.css.js +5 -5
  17. package/src/menu-group.css.js.map +1 -1
  18. package/src/menu-item.css.dev.js +8 -8
  19. package/src/menu-item.css.dev.js.map +1 -1
  20. package/src/menu-item.css.js +8 -8
  21. package/src/menu-item.css.js.map +1 -1
  22. package/src/menu.css.dev.js +5 -5
  23. package/src/menu.css.dev.js.map +1 -1
  24. package/src/menu.css.js +5 -5
  25. package/src/menu.css.js.map +1 -1
  26. package/src/spectrum-checkmark.css.dev.js +8 -8
  27. package/src/spectrum-checkmark.css.dev.js.map +1 -1
  28. package/src/spectrum-checkmark.css.js +8 -8
  29. package/src/spectrum-checkmark.css.js.map +1 -1
  30. package/src/spectrum-chevron.css.dev.js +5 -5
  31. package/src/spectrum-chevron.css.dev.js.map +1 -1
  32. package/src/spectrum-chevron.css.js +5 -5
  33. package/src/spectrum-chevron.css.js.map +1 -1
  34. package/src/spectrum-menu-divider.css.dev.js +5 -5
  35. package/src/spectrum-menu-divider.css.dev.js.map +1 -1
  36. package/src/spectrum-menu-divider.css.js +5 -5
  37. package/src/spectrum-menu-divider.css.js.map +1 -1
  38. package/src/spectrum-menu-item.css.dev.js +8 -8
  39. package/src/spectrum-menu-item.css.dev.js.map +1 -1
  40. package/src/spectrum-menu-item.css.js +8 -8
  41. package/src/spectrum-menu-item.css.js.map +1 -1
  42. package/src/spectrum-menu-sectionHeading.css.dev.js +5 -5
  43. package/src/spectrum-menu-sectionHeading.css.dev.js.map +1 -1
  44. package/src/spectrum-menu-sectionHeading.css.js +5 -5
  45. package/src/spectrum-menu-sectionHeading.css.js.map +1 -1
  46. package/src/spectrum-menu.css.dev.js +5 -5
  47. package/src/spectrum-menu.css.dev.js.map +1 -1
  48. package/src/spectrum-menu.css.js +5 -5
  49. package/src/spectrum-menu.css.js.map +1 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@spectrum-web-components/menu",
3
- "version": "0.40.5",
3
+ "version": "0.41.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -85,14 +85,14 @@
85
85
  ],
86
86
  "dependencies": {
87
87
  "@lit-labs/observers": "^2.0.0",
88
- "@spectrum-web-components/action-button": "^0.40.5",
89
- "@spectrum-web-components/base": "^0.40.5",
90
- "@spectrum-web-components/divider": "^0.40.5",
91
- "@spectrum-web-components/icon": "^0.40.5",
92
- "@spectrum-web-components/icons-ui": "^0.40.5",
93
- "@spectrum-web-components/overlay": "^0.40.5",
94
- "@spectrum-web-components/popover": "^0.40.5",
95
- "@spectrum-web-components/shared": "^0.40.5"
88
+ "@spectrum-web-components/action-button": "^0.41.0",
89
+ "@spectrum-web-components/base": "^0.41.0",
90
+ "@spectrum-web-components/divider": "^0.41.0",
91
+ "@spectrum-web-components/icon": "^0.41.0",
92
+ "@spectrum-web-components/icons-ui": "^0.41.0",
93
+ "@spectrum-web-components/overlay": "^0.41.0",
94
+ "@spectrum-web-components/popover": "^0.41.0",
95
+ "@spectrum-web-components/shared": "^0.41.0"
96
96
  },
97
97
  "devDependencies": {
98
98
  "@spectrum-css/menu": "^6.1.0"
@@ -103,5 +103,5 @@
103
103
  "./sp-*.js",
104
104
  "./**/*.dev.js"
105
105
  ],
106
- "gitHead": "2e0006478841b07af63c19a0167a136bf724d064"
106
+ "gitHead": "0bf38fd427adc39804b228a4c61de623e5ebb82e"
107
107
  }
@@ -17,6 +17,7 @@ import {
17
17
  queryAssignedNodes,
18
18
  state
19
19
  } from "@spectrum-web-components/base/src/decorators.js";
20
+ import { randomID } from "@spectrum-web-components/shared/src/random-id.js";
20
21
  import { Menu } from "./Menu.dev.js";
21
22
  import "@spectrum-web-components/menu/sp-menu.js";
22
23
  import menuGroupStyles from "./menu-group.css.js";
@@ -45,7 +46,7 @@ export class MenuGroup extends Menu {
45
46
  this.headerElement.removeAttribute("id");
46
47
  }
47
48
  if (headerElement) {
48
- this.headerId = this.headerId || `sp-menu-group-label-${crypto.randomUUID().slice(0, 8)}`;
49
+ this.headerId = this.headerId || `sp-menu-group-label-${randomID()}`;
49
50
  const headerId = headerElement.id || this.headerId;
50
51
  if (!headerElement.id) {
51
52
  headerElement.id = headerId;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["MenuGroup.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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n queryAssignedNodes,\n state,\n} from '@spectrum-web-components/base/src/decorators.js';\n\nimport { Menu } from './Menu.dev.js'\n// Leveraged in build systems that use aliasing to prevent multiple registrations: https://github.com/adobe/spectrum-web-components/pull/3225\nimport '@spectrum-web-components/menu/sp-menu.js';\nimport menuGroupStyles from './menu-group.css.js';\n\n/**\n * @element sp-menu-group\n *\n * @slot header - headline of the menu group\n * @slot - menu items to be listed in the group\n */\nexport class MenuGroup extends Menu {\n public static override get styles(): CSSResultArray {\n return [...super.styles, menuGroupStyles];\n }\n\n private headerId = '';\n\n @queryAssignedNodes({\n slot: 'header',\n flatten: true,\n })\n private headerElements!: NodeListOf<HTMLElement>;\n\n @state()\n private headerElement?: HTMLElement;\n\n protected override get ownRole(): string {\n switch (this.selects) {\n case 'multiple':\n case 'single':\n case 'inherit':\n return 'group';\n default:\n return 'menu';\n }\n }\n\n protected updateLabel(): void {\n const headerElement = this.headerElements.length\n ? this.headerElements[0]\n : undefined;\n if (headerElement !== this.headerElement) {\n if (this.headerElement && this.headerElement.id === this.headerId) {\n this.headerElement.removeAttribute('id');\n }\n if (headerElement) {\n this.headerId =\n this.headerId ||\n `sp-menu-group-label-${crypto.randomUUID().slice(0, 8)}`;\n const headerId = headerElement.id || this.headerId;\n if (!headerElement.id) {\n headerElement.id = headerId;\n }\n this.setAttribute('aria-labelledby', headerId);\n } else {\n this.removeAttribute('aria-labelledby');\n }\n }\n this.headerElement = headerElement;\n }\n\n public override render(): TemplateResult {\n return html`\n <span class=\"header\" ?hidden=${!this.headerElement}>\n <slot name=\"header\" @slotchange=${this.updateLabel}></slot>\n </span>\n <sp-menu ignore>${this.renderMenuItemSlot()}</sp-menu>\n `;\n }\n}\n"],
5
- "mappings": ";;;;;;;;;;;;AAYA;AAAA,EAEI;AAAA,OAEG;AACP;AAAA,EACI;AAAA,EACA;AAAA,OACG;AAEP,SAAS,YAAY;AAErB,OAAO;AACP,OAAO,qBAAqB;AAQrB,aAAM,kBAAkB,KAAK;AAAA,EAA7B;AAAA;AAKH,SAAQ,WAAW;AAAA;AAAA,EAJnB,WAA2B,SAAyB;AAChD,WAAO,CAAC,GAAG,MAAM,QAAQ,eAAe;AAAA,EAC5C;AAAA,EAaA,IAAuB,UAAkB;AACrC,YAAQ,KAAK,SAAS;AAAA,MAClB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACD,eAAO;AAAA,MACX;AACI,eAAO;AAAA,IACf;AAAA,EACJ;AAAA,EAEU,cAAoB;AAC1B,UAAM,gBAAgB,KAAK,eAAe,SACpC,KAAK,eAAe,CAAC,IACrB;AACN,QAAI,kBAAkB,KAAK,eAAe;AACtC,UAAI,KAAK,iBAAiB,KAAK,cAAc,OAAO,KAAK,UAAU;AAC/D,aAAK,cAAc,gBAAgB,IAAI;AAAA,MAC3C;AACA,UAAI,eAAe;AACf,aAAK,WACD,KAAK,YACL,uBAAuB,OAAO,WAAW,EAAE,MAAM,GAAG,CAAC,CAAC;AAC1D,cAAM,WAAW,cAAc,MAAM,KAAK;AAC1C,YAAI,CAAC,cAAc,IAAI;AACnB,wBAAc,KAAK;AAAA,QACvB;AACA,aAAK,aAAa,mBAAmB,QAAQ;AAAA,MACjD,OAAO;AACH,aAAK,gBAAgB,iBAAiB;AAAA,MAC1C;AAAA,IACJ;AACA,SAAK,gBAAgB;AAAA,EACzB;AAAA,EAEgB,SAAyB;AACrC,WAAO;AAAA,2CAC4B,CAAC,KAAK,aAAa;AAAA,kDACZ,KAAK,WAAW;AAAA;AAAA,8BAEpC,KAAK,mBAAmB,CAAC;AAAA;AAAA,EAEnD;AACJ;AAhDY;AAAA,EAJP,mBAAmB;AAAA,IAChB,MAAM;AAAA,IACN,SAAS;AAAA,EACb,CAAC;AAAA,GAVQ,UAWD;AAGA;AAAA,EADP,MAAM;AAAA,GAbE,UAcD;",
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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n queryAssignedNodes,\n state,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { randomID } from '@spectrum-web-components/shared/src/random-id.js';\n\nimport { Menu } from './Menu.dev.js'\n// Leveraged in build systems that use aliasing to prevent multiple registrations: https://github.com/adobe/spectrum-web-components/pull/3225\nimport '@spectrum-web-components/menu/sp-menu.js';\nimport menuGroupStyles from './menu-group.css.js';\n\n/**\n * @element sp-menu-group\n *\n * @slot header - headline of the menu group\n * @slot - menu items to be listed in the group\n */\nexport class MenuGroup extends Menu {\n public static override get styles(): CSSResultArray {\n return [...super.styles, menuGroupStyles];\n }\n\n private headerId = '';\n\n @queryAssignedNodes({\n slot: 'header',\n flatten: true,\n })\n private headerElements!: NodeListOf<HTMLElement>;\n\n @state()\n private headerElement?: HTMLElement;\n\n protected override get ownRole(): string {\n switch (this.selects) {\n case 'multiple':\n case 'single':\n case 'inherit':\n return 'group';\n default:\n return 'menu';\n }\n }\n\n protected updateLabel(): void {\n const headerElement = this.headerElements.length\n ? this.headerElements[0]\n : undefined;\n if (headerElement !== this.headerElement) {\n if (this.headerElement && this.headerElement.id === this.headerId) {\n this.headerElement.removeAttribute('id');\n }\n if (headerElement) {\n this.headerId =\n this.headerId || `sp-menu-group-label-${randomID()}`;\n const headerId = headerElement.id || this.headerId;\n if (!headerElement.id) {\n headerElement.id = headerId;\n }\n this.setAttribute('aria-labelledby', headerId);\n } else {\n this.removeAttribute('aria-labelledby');\n }\n }\n this.headerElement = headerElement;\n }\n\n public override render(): TemplateResult {\n return html`\n <span class=\"header\" ?hidden=${!this.headerElement}>\n <slot name=\"header\" @slotchange=${this.updateLabel}></slot>\n </span>\n <sp-menu ignore>${this.renderMenuItemSlot()}</sp-menu>\n `;\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;AAYA;AAAA,EAEI;AAAA,OAEG;AACP;AAAA,EACI;AAAA,EACA;AAAA,OACG;AACP,SAAS,gBAAgB;AAEzB,SAAS,YAAY;AAErB,OAAO;AACP,OAAO,qBAAqB;AAQrB,aAAM,kBAAkB,KAAK;AAAA,EAA7B;AAAA;AAKH,SAAQ,WAAW;AAAA;AAAA,EAJnB,WAA2B,SAAyB;AAChD,WAAO,CAAC,GAAG,MAAM,QAAQ,eAAe;AAAA,EAC5C;AAAA,EAaA,IAAuB,UAAkB;AACrC,YAAQ,KAAK,SAAS;AAAA,MAClB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACD,eAAO;AAAA,MACX;AACI,eAAO;AAAA,IACf;AAAA,EACJ;AAAA,EAEU,cAAoB;AAC1B,UAAM,gBAAgB,KAAK,eAAe,SACpC,KAAK,eAAe,CAAC,IACrB;AACN,QAAI,kBAAkB,KAAK,eAAe;AACtC,UAAI,KAAK,iBAAiB,KAAK,cAAc,OAAO,KAAK,UAAU;AAC/D,aAAK,cAAc,gBAAgB,IAAI;AAAA,MAC3C;AACA,UAAI,eAAe;AACf,aAAK,WACD,KAAK,YAAY,uBAAuB,SAAS,CAAC;AACtD,cAAM,WAAW,cAAc,MAAM,KAAK;AAC1C,YAAI,CAAC,cAAc,IAAI;AACnB,wBAAc,KAAK;AAAA,QACvB;AACA,aAAK,aAAa,mBAAmB,QAAQ;AAAA,MACjD,OAAO;AACH,aAAK,gBAAgB,iBAAiB;AAAA,MAC1C;AAAA,IACJ;AACA,SAAK,gBAAgB;AAAA,EACzB;AAAA,EAEgB,SAAyB;AACrC,WAAO;AAAA,2CAC4B,CAAC,KAAK,aAAa;AAAA,kDACZ,KAAK,WAAW;AAAA;AAAA,8BAEpC,KAAK,mBAAmB,CAAC;AAAA;AAAA,EAEnD;AACJ;AA/CY;AAAA,EAJP,mBAAmB;AAAA,IAChB,MAAM;AAAA,IACN,SAAS;AAAA,EACb,CAAC;AAAA,GAVQ,UAWD;AAGA;AAAA,EADP,MAAM;AAAA,GAbE,UAcD;",
6
6
  "names": []
7
7
  }
package/src/MenuGroup.js CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var n=Object.defineProperty;var h=Object.getOwnPropertyDescriptor;var l=(i,s,e,t)=>{for(var r=t>1?void 0:t?h(s,e):s,d=i.length-1,a;d>=0;d--)(a=i[d])&&(r=(t?a(s,e,r):a(r))||r);return t&&r&&n(s,e,r),r};import{html as m}from"@spectrum-web-components/base";import{queryAssignedNodes as o,state as u}from"@spectrum-web-components/base/src/decorators.js";import{Menu as p}from"./Menu.js";import"@spectrum-web-components/menu/sp-menu.js";import c from"./menu-group.css.js";export class MenuGroup extends p{constructor(){super(...arguments);this.headerId=""}static get styles(){return[...super.styles,c]}get ownRole(){switch(this.selects){case"multiple":case"single":case"inherit":return"group";default:return"menu"}}updateLabel(){const e=this.headerElements.length?this.headerElements[0]:void 0;if(e!==this.headerElement)if(this.headerElement&&this.headerElement.id===this.headerId&&this.headerElement.removeAttribute("id"),e){this.headerId=this.headerId||`sp-menu-group-label-${crypto.randomUUID().slice(0,8)}`;const t=e.id||this.headerId;e.id||(e.id=t),this.setAttribute("aria-labelledby",t)}else this.removeAttribute("aria-labelledby");this.headerElement=e}render(){return m`
1
+ "use strict";var n=Object.defineProperty;var h=Object.getOwnPropertyDescriptor;var l=(i,s,e,t)=>{for(var r=t>1?void 0:t?h(s,e):s,d=i.length-1,a;d>=0;d--)(a=i[d])&&(r=(t?a(s,e,r):a(r))||r);return t&&r&&n(s,e,r),r};import{html as m}from"@spectrum-web-components/base";import{queryAssignedNodes as o,state as u}from"@spectrum-web-components/base/src/decorators.js";import{randomID as p}from"@spectrum-web-components/shared/src/random-id.js";import{Menu as c}from"./Menu.js";import"@spectrum-web-components/menu/sp-menu.js";import f from"./menu-group.css.js";export class MenuGroup extends c{constructor(){super(...arguments);this.headerId=""}static get styles(){return[...super.styles,f]}get ownRole(){switch(this.selects){case"multiple":case"single":case"inherit":return"group";default:return"menu"}}updateLabel(){const e=this.headerElements.length?this.headerElements[0]:void 0;if(e!==this.headerElement)if(this.headerElement&&this.headerElement.id===this.headerId&&this.headerElement.removeAttribute("id"),e){this.headerId=this.headerId||`sp-menu-group-label-${p()}`;const t=e.id||this.headerId;e.id||(e.id=t),this.setAttribute("aria-labelledby",t)}else this.removeAttribute("aria-labelledby");this.headerElement=e}render(){return m`
2
2
  <span class="header" ?hidden=${!this.headerElement}>
3
3
  <slot name="header" @slotchange=${this.updateLabel}></slot>
4
4
  </span>
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["MenuGroup.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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n queryAssignedNodes,\n state,\n} from '@spectrum-web-components/base/src/decorators.js';\n\nimport { Menu } from './Menu.js';\n// Leveraged in build systems that use aliasing to prevent multiple registrations: https://github.com/adobe/spectrum-web-components/pull/3225\nimport '@spectrum-web-components/menu/sp-menu.js';\nimport menuGroupStyles from './menu-group.css.js';\n\n/**\n * @element sp-menu-group\n *\n * @slot header - headline of the menu group\n * @slot - menu items to be listed in the group\n */\nexport class MenuGroup extends Menu {\n public static override get styles(): CSSResultArray {\n return [...super.styles, menuGroupStyles];\n }\n\n private headerId = '';\n\n @queryAssignedNodes({\n slot: 'header',\n flatten: true,\n })\n private headerElements!: NodeListOf<HTMLElement>;\n\n @state()\n private headerElement?: HTMLElement;\n\n protected override get ownRole(): string {\n switch (this.selects) {\n case 'multiple':\n case 'single':\n case 'inherit':\n return 'group';\n default:\n return 'menu';\n }\n }\n\n protected updateLabel(): void {\n const headerElement = this.headerElements.length\n ? this.headerElements[0]\n : undefined;\n if (headerElement !== this.headerElement) {\n if (this.headerElement && this.headerElement.id === this.headerId) {\n this.headerElement.removeAttribute('id');\n }\n if (headerElement) {\n this.headerId =\n this.headerId ||\n `sp-menu-group-label-${crypto.randomUUID().slice(0, 8)}`;\n const headerId = headerElement.id || this.headerId;\n if (!headerElement.id) {\n headerElement.id = headerId;\n }\n this.setAttribute('aria-labelledby', headerId);\n } else {\n this.removeAttribute('aria-labelledby');\n }\n }\n this.headerElement = headerElement;\n }\n\n public override render(): TemplateResult {\n return html`\n <span class=\"header\" ?hidden=${!this.headerElement}>\n <slot name=\"header\" @slotchange=${this.updateLabel}></slot>\n </span>\n <sp-menu ignore>${this.renderMenuItemSlot()}</sp-menu>\n `;\n }\n}\n"],
5
- "mappings": "qNAYA,OAEI,QAAAA,MAEG,gCACP,OACI,sBAAAC,EACA,SAAAC,MACG,kDAEP,OAAS,QAAAC,MAAY,YAErB,MAAO,2CACP,OAAOC,MAAqB,sBAQrB,aAAM,kBAAkBD,CAAK,CAA7B,kCAKH,KAAQ,SAAW,GAJnB,WAA2B,QAAyB,CAChD,MAAO,CAAC,GAAG,MAAM,OAAQC,CAAe,CAC5C,CAaA,IAAuB,SAAkB,CACrC,OAAQ,KAAK,QAAS,CAClB,IAAK,WACL,IAAK,SACL,IAAK,UACD,MAAO,QACX,QACI,MAAO,MACf,CACJ,CAEU,aAAoB,CAC1B,MAAMC,EAAgB,KAAK,eAAe,OACpC,KAAK,eAAe,CAAC,EACrB,OACN,GAAIA,IAAkB,KAAK,cAIvB,GAHI,KAAK,eAAiB,KAAK,cAAc,KAAO,KAAK,UACrD,KAAK,cAAc,gBAAgB,IAAI,EAEvCA,EAAe,CACf,KAAK,SACD,KAAK,UACL,uBAAuB,OAAO,WAAW,EAAE,MAAM,EAAG,CAAC,CAAC,GAC1D,MAAMC,EAAWD,EAAc,IAAM,KAAK,SACrCA,EAAc,KACfA,EAAc,GAAKC,GAEvB,KAAK,aAAa,kBAAmBA,CAAQ,CACjD,MACI,KAAK,gBAAgB,iBAAiB,EAG9C,KAAK,cAAgBD,CACzB,CAEgB,QAAyB,CACrC,OAAOL;AAAA,2CAC4B,CAAC,KAAK,aAAa;AAAA,kDACZ,KAAK,WAAW;AAAA;AAAA,8BAEpC,KAAK,mBAAmB,CAAC;AAAA,SAEnD,CACJ,CAhDYO,EAAA,CAJPN,EAAmB,CAChB,KAAM,SACN,QAAS,EACb,CAAC,GAVQ,UAWD,8BAGAM,EAAA,CADPL,EAAM,GAbE,UAcD",
6
- "names": ["html", "queryAssignedNodes", "state", "Menu", "menuGroupStyles", "headerElement", "headerId", "__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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n queryAssignedNodes,\n state,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { randomID } from '@spectrum-web-components/shared/src/random-id.js';\n\nimport { Menu } from './Menu.js';\n// Leveraged in build systems that use aliasing to prevent multiple registrations: https://github.com/adobe/spectrum-web-components/pull/3225\nimport '@spectrum-web-components/menu/sp-menu.js';\nimport menuGroupStyles from './menu-group.css.js';\n\n/**\n * @element sp-menu-group\n *\n * @slot header - headline of the menu group\n * @slot - menu items to be listed in the group\n */\nexport class MenuGroup extends Menu {\n public static override get styles(): CSSResultArray {\n return [...super.styles, menuGroupStyles];\n }\n\n private headerId = '';\n\n @queryAssignedNodes({\n slot: 'header',\n flatten: true,\n })\n private headerElements!: NodeListOf<HTMLElement>;\n\n @state()\n private headerElement?: HTMLElement;\n\n protected override get ownRole(): string {\n switch (this.selects) {\n case 'multiple':\n case 'single':\n case 'inherit':\n return 'group';\n default:\n return 'menu';\n }\n }\n\n protected updateLabel(): void {\n const headerElement = this.headerElements.length\n ? this.headerElements[0]\n : undefined;\n if (headerElement !== this.headerElement) {\n if (this.headerElement && this.headerElement.id === this.headerId) {\n this.headerElement.removeAttribute('id');\n }\n if (headerElement) {\n this.headerId =\n this.headerId || `sp-menu-group-label-${randomID()}`;\n const headerId = headerElement.id || this.headerId;\n if (!headerElement.id) {\n headerElement.id = headerId;\n }\n this.setAttribute('aria-labelledby', headerId);\n } else {\n this.removeAttribute('aria-labelledby');\n }\n }\n this.headerElement = headerElement;\n }\n\n public override render(): TemplateResult {\n return html`\n <span class=\"header\" ?hidden=${!this.headerElement}>\n <slot name=\"header\" @slotchange=${this.updateLabel}></slot>\n </span>\n <sp-menu ignore>${this.renderMenuItemSlot()}</sp-menu>\n `;\n }\n}\n"],
5
+ "mappings": "qNAYA,OAEI,QAAAA,MAEG,gCACP,OACI,sBAAAC,EACA,SAAAC,MACG,kDACP,OAAS,YAAAC,MAAgB,mDAEzB,OAAS,QAAAC,MAAY,YAErB,MAAO,2CACP,OAAOC,MAAqB,sBAQrB,aAAM,kBAAkBD,CAAK,CAA7B,kCAKH,KAAQ,SAAW,GAJnB,WAA2B,QAAyB,CAChD,MAAO,CAAC,GAAG,MAAM,OAAQC,CAAe,CAC5C,CAaA,IAAuB,SAAkB,CACrC,OAAQ,KAAK,QAAS,CAClB,IAAK,WACL,IAAK,SACL,IAAK,UACD,MAAO,QACX,QACI,MAAO,MACf,CACJ,CAEU,aAAoB,CAC1B,MAAMC,EAAgB,KAAK,eAAe,OACpC,KAAK,eAAe,CAAC,EACrB,OACN,GAAIA,IAAkB,KAAK,cAIvB,GAHI,KAAK,eAAiB,KAAK,cAAc,KAAO,KAAK,UACrD,KAAK,cAAc,gBAAgB,IAAI,EAEvCA,EAAe,CACf,KAAK,SACD,KAAK,UAAY,uBAAuBH,EAAS,CAAC,GACtD,MAAMI,EAAWD,EAAc,IAAM,KAAK,SACrCA,EAAc,KACfA,EAAc,GAAKC,GAEvB,KAAK,aAAa,kBAAmBA,CAAQ,CACjD,MACI,KAAK,gBAAgB,iBAAiB,EAG9C,KAAK,cAAgBD,CACzB,CAEgB,QAAyB,CACrC,OAAON;AAAA,2CAC4B,CAAC,KAAK,aAAa;AAAA,kDACZ,KAAK,WAAW;AAAA;AAAA,8BAEpC,KAAK,mBAAmB,CAAC;AAAA,SAEnD,CACJ,CA/CYQ,EAAA,CAJPP,EAAmB,CAChB,KAAM,SACN,QAAS,EACb,CAAC,GAVQ,UAWD,8BAGAO,EAAA,CADPN,EAAM,GAbE,UAcD",
6
+ "names": ["html", "queryAssignedNodes", "state", "randomID", "Menu", "menuGroupStyles", "headerElement", "headerId", "__decorateClass"]
7
7
  }
@@ -16,7 +16,8 @@ import {
16
16
  } from "@spectrum-web-components/base";
17
17
  import {
18
18
  ObserveSlotPresence,
19
- ObserveSlotText
19
+ ObserveSlotText,
20
+ randomID
20
21
  } from "@spectrum-web-components/shared";
21
22
  import {
22
23
  property,
@@ -287,7 +288,7 @@ export class MenuItem extends LikeAnchor(
287
288
  this.addEventListener("pointerdown", this.handlePointerdown);
288
289
  this.addEventListener("pointerenter", this.closeOverlaysForRoot);
289
290
  if (!this.hasAttribute("id")) {
290
- this.id = `sp-menu-item-${crypto.randomUUID().slice(0, 8)}`;
291
+ this.id = `sp-menu-item-${randomID()}`;
291
292
  }
292
293
  }
293
294
  closeOverlaysForRoot() {
@@ -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 nothing,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ObserveSlotPresence,\n ObserveSlotText,\n} from '@spectrum-web-components/shared';\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';\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 { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport type { Overlay } from '@spectrum-web-components/overlay';\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\ntype MenuCascadeItem = {\n hadFocusRoot: boolean;\n ancestorWithSelects?: HTMLElement;\n};\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor(item: MenuItem) {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n this.clear(item);\n }\n clear(item: MenuItem): void {\n this._item = item;\n this.currentAncestorWithSelects = undefined;\n item.menuData = {\n cleanupSteps: [],\n focusRoot: undefined,\n selectionRoot: undefined,\n parentMenu: undefined,\n };\n this.menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n }\n menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n get item(): MenuItem {\n return this._item;\n }\n private _item!: MenuItem;\n currentAncestorWithSelects?: Menu;\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot description - description to be placed below the label of 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 * @slot submenu - content placed in a submenu\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n */\nexport class MenuItem extends LikeAnchor(\n ObserveSlotText(ObserveSlotPresence(Focusable, '[slot=\"icon\"]'))\n) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n abortControllerPointer!: AbortController;\n\n abortControllerSubmenu!: AbortController;\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, reflect: true, attribute: 'has-submenu' })\n public hasSubmenu = false;\n\n @query('slot:not([name])')\n contentSlot!: HTMLSlotElement;\n\n @query('slot[name=\"icon\"]')\n iconSlot!: HTMLSlotElement;\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 @query('sp-overlay')\n public overlayElement!: Overlay;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n protected get hasIcon(): boolean {\n return this.slotContentIsPresent;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (!this.iconSlot || !this.contentSlot) {\n return {\n icon: [],\n content: [],\n };\n }\n if (this._itemChildren) {\n return this._itemChildren;\n }\n const icon = this.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 content = this.contentSlot\n .assignedNodes()\n .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.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, reflect: true })\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 renderSubmenu(): TemplateResult {\n const slot = html`\n <slot\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n @sp-menu-item-added-or-updated=${{\n handleEvent: (event: MenuItemAddedOrUpdatedEvent) => {\n event.clear(event.item);\n },\n capture: true,\n }}\n @focusin=${(event: Event) => event.stopPropagation()}\n ></slot>\n `;\n if (!this.hasSubmenu) {\n return slot;\n }\n import('@spectrum-web-components/overlay/sp-overlay.js');\n import('@spectrum-web-components/popover/sp-popover.js');\n return html`\n <sp-overlay\n .triggerElement=${this as HTMLElement}\n ?disabled=${!this.hasSubmenu}\n ?open=${this.hasSubmenu && this.open}\n .placement=${this.isLTR ? 'right-start' : 'left-start'}\n .offset=${[-10, -4] as [number, number]}\n .type=${'auto'}\n @close=${(event: Event) => event.stopPropagation()}\n >\n <sp-popover\n @change=${(event: Event) => {\n this.handleSubmenuChange(event);\n this.open = false;\n }}\n @pointerenter=${this.handleSubmenuPointerenter}\n @pointerleave=${this.handleSubmenuPointerleave}\n @sp-menu-item-added-or-updated=${(event: Event) =>\n event.stopPropagation()}\n >\n ${slot}\n </sp-popover>\n </sp-overlay>\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `;\n }\n\n protected override render(): TemplateResult {\n return html`\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 \n icon \n checkmark\n ${this.hasIcon\n ? 'checkmark--withAdjacentIcon'\n : ''}\"\n ></sp-icon-checkmark100>\n `\n : nothing}\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"description\"></slot>\n <slot name=\"value\"></slot>\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : nothing}\n ${this.renderSubmenu()}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = !!assignedElements.length;\n if (this.hasSubmenu) {\n this.setAttribute('aria-haspopup', 'true');\n }\n }\n\n private handleRemoveActive(): void {\n if (this.open) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(event: PointerEvent): void {\n this.active = true;\n if (event.target === this && this.hasSubmenu && this.open) {\n this.addEventListener('focus', this.handleSubmenuFocus, {\n once: true,\n });\n this.overlayElement.addEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${crypto.randomUUID().slice(0, 8)}`;\n }\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n this.menuData.parentMenu?.closeDescendentOverlays();\n }\n\n protected handleSubmenuClick(event: Event): void {\n if (event.composedPath().includes(this.overlayElement)) {\n return;\n }\n this.openOverlay();\n }\n\n protected handleSubmenuFocus(): void {\n requestAnimationFrame(() => {\n // Wait till after `closeDescendentOverlays` has happened in Menu\n // to reopen (keey open) the direct descendent of this Menu Item\n this.overlayElement.open = this.open;\n });\n }\n\n protected handleBeforetoggle = (event: Event): void => {\n if ((event as Event & { newState: string }).newState === 'closed') {\n this.open = true;\n this.overlayElement.manuallyKeepOpen();\n this.overlayElement.removeEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 protected recentlyLeftChild = false;\n\n protected handlePointerleave(): void {\n if (this.open && !this.recentlyLeftChild) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n this.open = false;\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(event: Event): void {\n event.stopPropagation();\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n }\n\n protected handleSubmenuPointerenter(): void {\n this.recentlyLeftChild = true;\n }\n\n protected async handleSubmenuPointerleave(): Promise<void> {\n requestAnimationFrame(() => {\n this.recentlyLeftChild = false;\n });\n }\n\n protected handleSubmenuOpen(event: Event): void {\n this.focused = false;\n const parentOverlay = event.composedPath().find((el) => {\n return (\n el !== this.overlayElement &&\n (el as HTMLElement).localName === 'sp-overlay'\n );\n }) as Overlay;\n this.overlayElement.parentOverlayToForceClose = parentOverlay;\n }\n\n protected cleanup(): void {\n this.open = false;\n this.active = false;\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 this.setAttribute('aria-expanded', 'true');\n this.addEventListener('sp-closed', this.cleanup, {\n once: true,\n });\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 (\n changes.has('label') &&\n (this.label || typeof changes.get('label') !== 'undefined')\n ) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (\n changes.has('active') &&\n (this.active || typeof changes.get('active') !== 'undefined')\n ) {\n if (this.active) {\n this.menuData.selectionRoot?.closeDescendentOverlays();\n this.abortControllerPointer = new AbortController();\n const options = { signal: this.abortControllerPointer.signal };\n this.addEventListener(\n 'pointerup',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointercancel',\n this.handleRemoveActive,\n options\n );\n } else {\n this.abortControllerPointer?.abort();\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 (\n changes.has('hasSubmenu') &&\n (this.hasSubmenu ||\n typeof changes.get('hasSubmenu') !== 'undefined')\n ) {\n if (this.hasSubmenu) {\n this.abortControllerSubmenu = new AbortController();\n const options = { signal: this.abortControllerSubmenu.signal };\n this.addEventListener(\n 'click',\n this.handleSubmenuClick,\n options\n );\n this.addEventListener(\n 'pointerenter',\n this.handlePointerenter,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handlePointerleave,\n options\n );\n this.addEventListener(\n 'sp-opened',\n this.handleSubmenuOpen,\n options\n );\n } else {\n this.abortControllerSubmenu?.abort();\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.triggerUpdate();\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n this.menuData.cleanupSteps.forEach((removal) => removal(this));\n super.disconnectedCallback();\n }\n\n private willDispatchUpdate = false;\n\n public async triggerUpdate(): Promise<void> {\n if (this.willDispatchUpdate) {\n return;\n }\n this.willDispatchUpdate = true;\n await new Promise((ready) => requestAnimationFrame(ready));\n this.dispatchUpdate();\n }\n\n public dispatchUpdate(): void {\n this.dispatchEvent(new MenuItemAddedOrUpdatedEvent(this));\n this.willDispatchUpdate = false;\n }\n\n public menuData: {\n focusRoot?: Menu;\n parentMenu?: Menu;\n selectionRoot?: Menu;\n cleanupSteps: ((item: MenuItem) => void)[];\n } = {\n focusRoot: undefined,\n parentMenu: undefined,\n selectionRoot: undefined,\n cleanupSteps: [],\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\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 nothing,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ObserveSlotPresence,\n ObserveSlotText,\n randomID,\n} from '@spectrum-web-components/shared';\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';\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 { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport type { Overlay } from '@spectrum-web-components/overlay';\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\ntype MenuCascadeItem = {\n hadFocusRoot: boolean;\n ancestorWithSelects?: HTMLElement;\n};\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor(item: MenuItem) {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n this.clear(item);\n }\n clear(item: MenuItem): void {\n this._item = item;\n this.currentAncestorWithSelects = undefined;\n item.menuData = {\n cleanupSteps: [],\n focusRoot: undefined,\n selectionRoot: undefined,\n parentMenu: undefined,\n };\n this.menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n }\n menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n get item(): MenuItem {\n return this._item;\n }\n private _item!: MenuItem;\n currentAncestorWithSelects?: Menu;\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot description - description to be placed below the label of 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 * @slot submenu - content placed in a submenu\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n */\nexport class MenuItem extends LikeAnchor(\n ObserveSlotText(ObserveSlotPresence(Focusable, '[slot=\"icon\"]'))\n) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n abortControllerPointer!: AbortController;\n\n abortControllerSubmenu!: AbortController;\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, reflect: true, attribute: 'has-submenu' })\n public hasSubmenu = false;\n\n @query('slot:not([name])')\n contentSlot!: HTMLSlotElement;\n\n @query('slot[name=\"icon\"]')\n iconSlot!: HTMLSlotElement;\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 @query('sp-overlay')\n public overlayElement!: Overlay;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n protected get hasIcon(): boolean {\n return this.slotContentIsPresent;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (!this.iconSlot || !this.contentSlot) {\n return {\n icon: [],\n content: [],\n };\n }\n if (this._itemChildren) {\n return this._itemChildren;\n }\n const icon = this.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 content = this.contentSlot\n .assignedNodes()\n .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.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, reflect: true })\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 renderSubmenu(): TemplateResult {\n const slot = html`\n <slot\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n @sp-menu-item-added-or-updated=${{\n handleEvent: (event: MenuItemAddedOrUpdatedEvent) => {\n event.clear(event.item);\n },\n capture: true,\n }}\n @focusin=${(event: Event) => event.stopPropagation()}\n ></slot>\n `;\n if (!this.hasSubmenu) {\n return slot;\n }\n import('@spectrum-web-components/overlay/sp-overlay.js');\n import('@spectrum-web-components/popover/sp-popover.js');\n return html`\n <sp-overlay\n .triggerElement=${this as HTMLElement}\n ?disabled=${!this.hasSubmenu}\n ?open=${this.hasSubmenu && this.open}\n .placement=${this.isLTR ? 'right-start' : 'left-start'}\n .offset=${[-10, -4] as [number, number]}\n .type=${'auto'}\n @close=${(event: Event) => event.stopPropagation()}\n >\n <sp-popover\n @change=${(event: Event) => {\n this.handleSubmenuChange(event);\n this.open = false;\n }}\n @pointerenter=${this.handleSubmenuPointerenter}\n @pointerleave=${this.handleSubmenuPointerleave}\n @sp-menu-item-added-or-updated=${(event: Event) =>\n event.stopPropagation()}\n >\n ${slot}\n </sp-popover>\n </sp-overlay>\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `;\n }\n\n protected override render(): TemplateResult {\n return html`\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 \n icon \n checkmark\n ${this.hasIcon\n ? 'checkmark--withAdjacentIcon'\n : ''}\"\n ></sp-icon-checkmark100>\n `\n : nothing}\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"description\"></slot>\n <slot name=\"value\"></slot>\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : nothing}\n ${this.renderSubmenu()}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = !!assignedElements.length;\n if (this.hasSubmenu) {\n this.setAttribute('aria-haspopup', 'true');\n }\n }\n\n private handleRemoveActive(): void {\n if (this.open) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(event: PointerEvent): void {\n this.active = true;\n if (event.target === this && this.hasSubmenu && this.open) {\n this.addEventListener('focus', this.handleSubmenuFocus, {\n once: true,\n });\n this.overlayElement.addEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${randomID()}`;\n }\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n this.menuData.parentMenu?.closeDescendentOverlays();\n }\n\n protected handleSubmenuClick(event: Event): void {\n if (event.composedPath().includes(this.overlayElement)) {\n return;\n }\n this.openOverlay();\n }\n\n protected handleSubmenuFocus(): void {\n requestAnimationFrame(() => {\n // Wait till after `closeDescendentOverlays` has happened in Menu\n // to reopen (keey open) the direct descendent of this Menu Item\n this.overlayElement.open = this.open;\n });\n }\n\n protected handleBeforetoggle = (event: Event): void => {\n if ((event as Event & { newState: string }).newState === 'closed') {\n this.open = true;\n this.overlayElement.manuallyKeepOpen();\n this.overlayElement.removeEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 protected recentlyLeftChild = false;\n\n protected handlePointerleave(): void {\n if (this.open && !this.recentlyLeftChild) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n this.open = false;\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(event: Event): void {\n event.stopPropagation();\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n }\n\n protected handleSubmenuPointerenter(): void {\n this.recentlyLeftChild = true;\n }\n\n protected async handleSubmenuPointerleave(): Promise<void> {\n requestAnimationFrame(() => {\n this.recentlyLeftChild = false;\n });\n }\n\n protected handleSubmenuOpen(event: Event): void {\n this.focused = false;\n const parentOverlay = event.composedPath().find((el) => {\n return (\n el !== this.overlayElement &&\n (el as HTMLElement).localName === 'sp-overlay'\n );\n }) as Overlay;\n this.overlayElement.parentOverlayToForceClose = parentOverlay;\n }\n\n protected cleanup(): void {\n this.open = false;\n this.active = false;\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 this.setAttribute('aria-expanded', 'true');\n this.addEventListener('sp-closed', this.cleanup, {\n once: true,\n });\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 (\n changes.has('label') &&\n (this.label || typeof changes.get('label') !== 'undefined')\n ) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (\n changes.has('active') &&\n (this.active || typeof changes.get('active') !== 'undefined')\n ) {\n if (this.active) {\n this.menuData.selectionRoot?.closeDescendentOverlays();\n this.abortControllerPointer = new AbortController();\n const options = { signal: this.abortControllerPointer.signal };\n this.addEventListener(\n 'pointerup',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointercancel',\n this.handleRemoveActive,\n options\n );\n } else {\n this.abortControllerPointer?.abort();\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 (\n changes.has('hasSubmenu') &&\n (this.hasSubmenu ||\n typeof changes.get('hasSubmenu') !== 'undefined')\n ) {\n if (this.hasSubmenu) {\n this.abortControllerSubmenu = new AbortController();\n const options = { signal: this.abortControllerSubmenu.signal };\n this.addEventListener(\n 'click',\n this.handleSubmenuClick,\n options\n );\n this.addEventListener(\n 'pointerenter',\n this.handlePointerenter,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handlePointerleave,\n options\n );\n this.addEventListener(\n 'sp-opened',\n this.handleSubmenuOpen,\n options\n );\n } else {\n this.abortControllerSubmenu?.abort();\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.triggerUpdate();\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n this.menuData.cleanupSteps.forEach((removal) => removal(this));\n super.disconnectedCallback();\n }\n\n private willDispatchUpdate = false;\n\n public async triggerUpdate(): Promise<void> {\n if (this.willDispatchUpdate) {\n return;\n }\n this.willDispatchUpdate = true;\n await new Promise((ready) => requestAnimationFrame(ready));\n this.dispatchUpdate();\n }\n\n public dispatchUpdate(): void {\n this.dispatchEvent(new MenuItemAddedOrUpdatedEvent(this));\n this.willDispatchUpdate = false;\n }\n\n public menuData: {\n focusRoot?: Menu;\n parentMenu?: Menu;\n selectionRoot?: Menu;\n cleanupSteps: ((item: MenuItem) => void)[];\n } = {\n focusRoot: undefined,\n parentMenu: undefined,\n selectionRoot: undefined,\n cleanupSteps: [],\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
package/src/MenuItem.js CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var c=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var r=(l,a,e,t)=>{for(var i=t>1?void 0:t?p(a,e):a,o=l.length-1,n;o>=0;o--)(n=l[o])&&(i=(t?n(a,e,i):n(i))||i);return t&&i&&c(a,e,i),i};import{html as d,nothing as h}from"@spectrum-web-components/base";import{ObserveSlotPresence as m,ObserveSlotText as v}from"@spectrum-web-components/shared";import{property as s,query as u}from"@spectrum-web-components/base/src/decorators.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js";import{LikeAnchor as b}from"@spectrum-web-components/shared/src/like-anchor.js";import{Focusable as f}from"@spectrum-web-components/shared/src/focusable.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js";import E from"@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js";import y from"./menu-item.css.js";import g from"@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js";import{MutationController as S}from"@lit-labs/observers/mutation-controller.js";const C=100;export class MenuItemAddedOrUpdatedEvent extends Event{constructor(e){super("sp-menu-item-added-or-updated",{bubbles:!0,composed:!0});this.menuCascade=new WeakMap;this.clear(e)}clear(e){this._item=e,this.currentAncestorWithSelects=void 0,e.menuData={cleanupSteps:[],focusRoot:void 0,selectionRoot:void 0,parentMenu:void 0},this.menuCascade=new WeakMap}get item(){return this._item}}export class MenuItem extends b(v(m(f,'[slot="icon"]'))){constructor(){super();this.active=!1;this.focused=!1;this.selected=!1;this._value="";this.hasSubmenu=!1;this.noWrap=!1;this.open=!1;this.proxyFocus=()=>{this.focus()};this.handleBeforetoggle=e=>{e.newState==="closed"&&(this.open=!0,this.overlayElement.manuallyKeepOpen(),this.overlayElement.removeEventListener("beforetoggle",this.handleBeforetoggle))};this.recentlyLeftChild=!1;this.willDispatchUpdate=!1;this.menuData={focusRoot:void 0,parentMenu:void 0,selectionRoot:void 0,cleanupSteps:[]};this.addEventListener("click",this.handleClickCapture,{capture:!0}),new S(this,{config:{characterData:!0,childList:!0,subtree:!0},callback:()=>{this.breakItemChildrenCache()}})}static get styles(){return[y,g,E]}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 hasIcon(){return this.slotContentIsPresent}get itemChildren(){if(!this.iconSlot||!this.contentSlot)return{icon:[],content:[]};if(this._itemChildren)return this._itemChildren;const e=this.iconSlot.assignedElements().map(i=>{const o=i.cloneNode(!0);return o.removeAttribute("slot"),o.classList.toggle("icon"),o}),t=this.contentSlot.assignedNodes().map(i=>i.cloneNode(!0));return this._itemChildren={icon:e,content:t},this._itemChildren}click(){this.disabled||this.shouldProxyClick()||super.click()}handleClickCapture(e){if(this.disabled)return e.preventDefault(),e.stopImmediatePropagation(),e.stopPropagation(),!1}shouldProxyClick(){let e=!1;return this.anchorElement&&(this.anchorElement.click(),e=!0),e}breakItemChildrenCache(){this._itemChildren=void 0,this.triggerUpdate()}renderSubmenu(){const e=d`
1
+ "use strict";var c=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var r=(l,a,e,t)=>{for(var i=t>1?void 0:t?p(a,e):a,o=l.length-1,n;o>=0;o--)(n=l[o])&&(i=(t?n(a,e,i):n(i))||i);return t&&i&&c(a,e,i),i};import{html as d,nothing as h}from"@spectrum-web-components/base";import{ObserveSlotPresence as m,ObserveSlotText as v,randomID as b}from"@spectrum-web-components/shared";import{property as s,query as u}from"@spectrum-web-components/base/src/decorators.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-checkmark100.js";import{LikeAnchor as f}from"@spectrum-web-components/shared/src/like-anchor.js";import{Focusable as E}from"@spectrum-web-components/shared/src/focusable.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js";import y from"@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js";import g from"./menu-item.css.js";import S from"@spectrum-web-components/icon/src/spectrum-icon-checkmark.css.js";import{MutationController as C}from"@lit-labs/observers/mutation-controller.js";const A=100;export class MenuItemAddedOrUpdatedEvent extends Event{constructor(e){super("sp-menu-item-added-or-updated",{bubbles:!0,composed:!0});this.menuCascade=new WeakMap;this.clear(e)}clear(e){this._item=e,this.currentAncestorWithSelects=void 0,e.menuData={cleanupSteps:[],focusRoot:void 0,selectionRoot:void 0,parentMenu:void 0},this.menuCascade=new WeakMap}get item(){return this._item}}export class MenuItem extends f(v(m(E,'[slot="icon"]'))){constructor(){super();this.active=!1;this.focused=!1;this.selected=!1;this._value="";this.hasSubmenu=!1;this.noWrap=!1;this.open=!1;this.proxyFocus=()=>{this.focus()};this.handleBeforetoggle=e=>{e.newState==="closed"&&(this.open=!0,this.overlayElement.manuallyKeepOpen(),this.overlayElement.removeEventListener("beforetoggle",this.handleBeforetoggle))};this.recentlyLeftChild=!1;this.willDispatchUpdate=!1;this.menuData={focusRoot:void 0,parentMenu:void 0,selectionRoot:void 0,cleanupSteps:[]};this.addEventListener("click",this.handleClickCapture,{capture:!0}),new C(this,{config:{characterData:!0,childList:!0,subtree:!0},callback:()=>{this.breakItemChildrenCache()}})}static get styles(){return[g,S,y]}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 hasIcon(){return this.slotContentIsPresent}get itemChildren(){if(!this.iconSlot||!this.contentSlot)return{icon:[],content:[]};if(this._itemChildren)return this._itemChildren;const e=this.iconSlot.assignedElements().map(i=>{const o=i.cloneNode(!0);return o.removeAttribute("slot"),o.classList.toggle("icon"),o}),t=this.contentSlot.assignedNodes().map(i=>i.cloneNode(!0));return this._itemChildren={icon:e,content:t},this._itemChildren}click(){this.disabled||this.shouldProxyClick()||super.click()}handleClickCapture(e){if(this.disabled)return e.preventDefault(),e.stopImmediatePropagation(),e.stopPropagation(),!1}shouldProxyClick(){let e=!1;return this.anchorElement&&(this.anchorElement.click(),e=!0),e}breakItemChildrenCache(){this._itemChildren=void 0,this.triggerUpdate()}renderSubmenu(){const e=d`
2
2
  <slot
3
3
  name="submenu"
4
4
  @slotchange=${this.manageSubmenu}
@@ -45,5 +45,5 @@
45
45
  <slot name="value"></slot>
46
46
  ${this.href&&this.href.length>0?super.renderAnchor({id:"button",ariaHidden:!0,className:"button anchor hidden"}):h}
47
47
  ${this.renderSubmenu()}
48
- `}manageSubmenu(e){const t=e.target.assignedElements({flatten:!0});this.hasSubmenu=!!t.length,this.hasSubmenu&&this.setAttribute("aria-haspopup","true")}handleRemoveActive(){this.open||(this.active=!1)}handlePointerdown(e){this.active=!0,e.target===this&&this.hasSubmenu&&this.open&&(this.addEventListener("focus",this.handleSubmenuFocus,{once:!0}),this.overlayElement.addEventListener("beforetoggle",this.handleBeforetoggle))}firstUpdated(e){super.firstUpdated(e),this.setAttribute("tabindex","-1"),this.addEventListener("pointerdown",this.handlePointerdown),this.addEventListener("pointerenter",this.closeOverlaysForRoot),this.hasAttribute("id")||(this.id=`sp-menu-item-${crypto.randomUUID().slice(0,8)}`)}closeOverlaysForRoot(){var e;this.open||(e=this.menuData.parentMenu)==null||e.closeDescendentOverlays()}handleSubmenuClick(e){e.composedPath().includes(this.overlayElement)||this.openOverlay()}handleSubmenuFocus(){requestAnimationFrame(()=>{this.overlayElement.open=this.open})}handlePointerenter(){if(this.leaveTimeout){clearTimeout(this.leaveTimeout),delete this.leaveTimeout;return}this.openOverlay()}handlePointerleave(){this.open&&!this.recentlyLeftChild&&(this.leaveTimeout=setTimeout(()=>{delete this.leaveTimeout,this.open=!1},C))}handleSubmenuChange(e){var t;e.stopPropagation(),(t=this.menuData.selectionRoot)==null||t.selectOrToggleItem(this)}handleSubmenuPointerenter(){this.recentlyLeftChild=!0}async handleSubmenuPointerleave(){requestAnimationFrame(()=>{this.recentlyLeftChild=!1})}handleSubmenuOpen(e){this.focused=!1;const t=e.composedPath().find(i=>i!==this.overlayElement&&i.localName==="sp-overlay");this.overlayElement.parentOverlayToForceClose=t}cleanup(){this.open=!1,this.active=!1}async openOverlay(){!this.hasSubmenu||this.open||this.disabled||(this.open=!0,this.active=!0,this.setAttribute("aria-expanded","true"),this.addEventListener("sp-closed",this.cleanup,{once:!0}))}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){var t,i,o;if(super.updated(e),e.has("label")&&(this.label||typeof e.get("label")!="undefined")&&this.setAttribute("aria-label",this.label||""),e.has("active")&&(this.active||typeof e.get("active")!="undefined"))if(this.active){(t=this.menuData.selectionRoot)==null||t.closeDescendentOverlays(),this.abortControllerPointer=new AbortController;const n={signal:this.abortControllerPointer.signal};this.addEventListener("pointerup",this.handleRemoveActive,n),this.addEventListener("pointerleave",this.handleRemoveActive,n),this.addEventListener("pointercancel",this.handleRemoveActive,n)}else(i=this.abortControllerPointer)==null||i.abort();if(this.anchorElement&&(this.anchorElement.addEventListener("focus",this.proxyFocus),this.anchorElement.tabIndex=-1),e.has("selected")&&this.updateAriaSelected(),e.has("hasSubmenu")&&(this.hasSubmenu||typeof e.get("hasSubmenu")!="undefined"))if(this.hasSubmenu){this.abortControllerSubmenu=new AbortController;const n={signal:this.abortControllerSubmenu.signal};this.addEventListener("click",this.handleSubmenuClick,n),this.addEventListener("pointerenter",this.handlePointerenter,n),this.addEventListener("pointerleave",this.handlePointerleave,n),this.addEventListener("sp-opened",this.handleSubmenuOpen,n)}else(o=this.abortControllerSubmenu)==null||o.abort()}connectedCallback(){super.connectedCallback(),this.triggerUpdate()}disconnectedCallback(){this.menuData.cleanupSteps.forEach(e=>e(this)),super.disconnectedCallback()}async triggerUpdate(){this.willDispatchUpdate||(this.willDispatchUpdate=!0,await new Promise(e=>requestAnimationFrame(e)),this.dispatchUpdate())}dispatchUpdate(){this.dispatchEvent(new MenuItemAddedOrUpdatedEvent(this)),this.willDispatchUpdate=!1}}r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"active",2),r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"focused",2),r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"selected",2),r([s({type:String})],MenuItem.prototype,"value",1),r([s({type:Boolean,reflect:!0,attribute:"has-submenu"})],MenuItem.prototype,"hasSubmenu",2),r([u("slot:not([name])")],MenuItem.prototype,"contentSlot",2),r([u('slot[name="icon"]')],MenuItem.prototype,"iconSlot",2),r([s({type:Boolean,reflect:!0,attribute:"no-wrap",hasChanged(){return!1}})],MenuItem.prototype,"noWrap",2),r([u(".anchor")],MenuItem.prototype,"anchorElement",2),r([u("sp-overlay")],MenuItem.prototype,"overlayElement",2),r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"open",2);
48
+ `}manageSubmenu(e){const t=e.target.assignedElements({flatten:!0});this.hasSubmenu=!!t.length,this.hasSubmenu&&this.setAttribute("aria-haspopup","true")}handleRemoveActive(){this.open||(this.active=!1)}handlePointerdown(e){this.active=!0,e.target===this&&this.hasSubmenu&&this.open&&(this.addEventListener("focus",this.handleSubmenuFocus,{once:!0}),this.overlayElement.addEventListener("beforetoggle",this.handleBeforetoggle))}firstUpdated(e){super.firstUpdated(e),this.setAttribute("tabindex","-1"),this.addEventListener("pointerdown",this.handlePointerdown),this.addEventListener("pointerenter",this.closeOverlaysForRoot),this.hasAttribute("id")||(this.id=`sp-menu-item-${b()}`)}closeOverlaysForRoot(){var e;this.open||(e=this.menuData.parentMenu)==null||e.closeDescendentOverlays()}handleSubmenuClick(e){e.composedPath().includes(this.overlayElement)||this.openOverlay()}handleSubmenuFocus(){requestAnimationFrame(()=>{this.overlayElement.open=this.open})}handlePointerenter(){if(this.leaveTimeout){clearTimeout(this.leaveTimeout),delete this.leaveTimeout;return}this.openOverlay()}handlePointerleave(){this.open&&!this.recentlyLeftChild&&(this.leaveTimeout=setTimeout(()=>{delete this.leaveTimeout,this.open=!1},A))}handleSubmenuChange(e){var t;e.stopPropagation(),(t=this.menuData.selectionRoot)==null||t.selectOrToggleItem(this)}handleSubmenuPointerenter(){this.recentlyLeftChild=!0}async handleSubmenuPointerleave(){requestAnimationFrame(()=>{this.recentlyLeftChild=!1})}handleSubmenuOpen(e){this.focused=!1;const t=e.composedPath().find(i=>i!==this.overlayElement&&i.localName==="sp-overlay");this.overlayElement.parentOverlayToForceClose=t}cleanup(){this.open=!1,this.active=!1}async openOverlay(){!this.hasSubmenu||this.open||this.disabled||(this.open=!0,this.active=!0,this.setAttribute("aria-expanded","true"),this.addEventListener("sp-closed",this.cleanup,{once:!0}))}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){var t,i,o;if(super.updated(e),e.has("label")&&(this.label||typeof e.get("label")!="undefined")&&this.setAttribute("aria-label",this.label||""),e.has("active")&&(this.active||typeof e.get("active")!="undefined"))if(this.active){(t=this.menuData.selectionRoot)==null||t.closeDescendentOverlays(),this.abortControllerPointer=new AbortController;const n={signal:this.abortControllerPointer.signal};this.addEventListener("pointerup",this.handleRemoveActive,n),this.addEventListener("pointerleave",this.handleRemoveActive,n),this.addEventListener("pointercancel",this.handleRemoveActive,n)}else(i=this.abortControllerPointer)==null||i.abort();if(this.anchorElement&&(this.anchorElement.addEventListener("focus",this.proxyFocus),this.anchorElement.tabIndex=-1),e.has("selected")&&this.updateAriaSelected(),e.has("hasSubmenu")&&(this.hasSubmenu||typeof e.get("hasSubmenu")!="undefined"))if(this.hasSubmenu){this.abortControllerSubmenu=new AbortController;const n={signal:this.abortControllerSubmenu.signal};this.addEventListener("click",this.handleSubmenuClick,n),this.addEventListener("pointerenter",this.handlePointerenter,n),this.addEventListener("pointerleave",this.handlePointerleave,n),this.addEventListener("sp-opened",this.handleSubmenuOpen,n)}else(o=this.abortControllerSubmenu)==null||o.abort()}connectedCallback(){super.connectedCallback(),this.triggerUpdate()}disconnectedCallback(){this.menuData.cleanupSteps.forEach(e=>e(this)),super.disconnectedCallback()}async triggerUpdate(){this.willDispatchUpdate||(this.willDispatchUpdate=!0,await new Promise(e=>requestAnimationFrame(e)),this.dispatchUpdate())}dispatchUpdate(){this.dispatchEvent(new MenuItemAddedOrUpdatedEvent(this)),this.willDispatchUpdate=!1}}r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"active",2),r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"focused",2),r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"selected",2),r([s({type:String})],MenuItem.prototype,"value",1),r([s({type:Boolean,reflect:!0,attribute:"has-submenu"})],MenuItem.prototype,"hasSubmenu",2),r([u("slot:not([name])")],MenuItem.prototype,"contentSlot",2),r([u('slot[name="icon"]')],MenuItem.prototype,"iconSlot",2),r([s({type:Boolean,reflect:!0,attribute:"no-wrap",hasChanged(){return!1}})],MenuItem.prototype,"noWrap",2),r([u(".anchor")],MenuItem.prototype,"anchorElement",2),r([u("sp-overlay")],MenuItem.prototype,"overlayElement",2),r([s({type:Boolean,reflect:!0})],MenuItem.prototype,"open",2);
49
49
  //# 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 nothing,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ObserveSlotPresence,\n ObserveSlotText,\n} from '@spectrum-web-components/shared';\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';\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 { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport type { Overlay } from '@spectrum-web-components/overlay';\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\ntype MenuCascadeItem = {\n hadFocusRoot: boolean;\n ancestorWithSelects?: HTMLElement;\n};\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor(item: MenuItem) {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n this.clear(item);\n }\n clear(item: MenuItem): void {\n this._item = item;\n this.currentAncestorWithSelects = undefined;\n item.menuData = {\n cleanupSteps: [],\n focusRoot: undefined,\n selectionRoot: undefined,\n parentMenu: undefined,\n };\n this.menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n }\n menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n get item(): MenuItem {\n return this._item;\n }\n private _item!: MenuItem;\n currentAncestorWithSelects?: Menu;\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot description - description to be placed below the label of 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 * @slot submenu - content placed in a submenu\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n */\nexport class MenuItem extends LikeAnchor(\n ObserveSlotText(ObserveSlotPresence(Focusable, '[slot=\"icon\"]'))\n) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n abortControllerPointer!: AbortController;\n\n abortControllerSubmenu!: AbortController;\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, reflect: true, attribute: 'has-submenu' })\n public hasSubmenu = false;\n\n @query('slot:not([name])')\n contentSlot!: HTMLSlotElement;\n\n @query('slot[name=\"icon\"]')\n iconSlot!: HTMLSlotElement;\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 @query('sp-overlay')\n public overlayElement!: Overlay;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n protected get hasIcon(): boolean {\n return this.slotContentIsPresent;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (!this.iconSlot || !this.contentSlot) {\n return {\n icon: [],\n content: [],\n };\n }\n if (this._itemChildren) {\n return this._itemChildren;\n }\n const icon = this.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 content = this.contentSlot\n .assignedNodes()\n .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.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, reflect: true })\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 renderSubmenu(): TemplateResult {\n const slot = html`\n <slot\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n @sp-menu-item-added-or-updated=${{\n handleEvent: (event: MenuItemAddedOrUpdatedEvent) => {\n event.clear(event.item);\n },\n capture: true,\n }}\n @focusin=${(event: Event) => event.stopPropagation()}\n ></slot>\n `;\n if (!this.hasSubmenu) {\n return slot;\n }\n import('@spectrum-web-components/overlay/sp-overlay.js');\n import('@spectrum-web-components/popover/sp-popover.js');\n return html`\n <sp-overlay\n .triggerElement=${this as HTMLElement}\n ?disabled=${!this.hasSubmenu}\n ?open=${this.hasSubmenu && this.open}\n .placement=${this.isLTR ? 'right-start' : 'left-start'}\n .offset=${[-10, -4] as [number, number]}\n .type=${'auto'}\n @close=${(event: Event) => event.stopPropagation()}\n >\n <sp-popover\n @change=${(event: Event) => {\n this.handleSubmenuChange(event);\n this.open = false;\n }}\n @pointerenter=${this.handleSubmenuPointerenter}\n @pointerleave=${this.handleSubmenuPointerleave}\n @sp-menu-item-added-or-updated=${(event: Event) =>\n event.stopPropagation()}\n >\n ${slot}\n </sp-popover>\n </sp-overlay>\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `;\n }\n\n protected override render(): TemplateResult {\n return html`\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 \n icon \n checkmark\n ${this.hasIcon\n ? 'checkmark--withAdjacentIcon'\n : ''}\"\n ></sp-icon-checkmark100>\n `\n : nothing}\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"description\"></slot>\n <slot name=\"value\"></slot>\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : nothing}\n ${this.renderSubmenu()}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = !!assignedElements.length;\n if (this.hasSubmenu) {\n this.setAttribute('aria-haspopup', 'true');\n }\n }\n\n private handleRemoveActive(): void {\n if (this.open) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(event: PointerEvent): void {\n this.active = true;\n if (event.target === this && this.hasSubmenu && this.open) {\n this.addEventListener('focus', this.handleSubmenuFocus, {\n once: true,\n });\n this.overlayElement.addEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${crypto.randomUUID().slice(0, 8)}`;\n }\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n this.menuData.parentMenu?.closeDescendentOverlays();\n }\n\n protected handleSubmenuClick(event: Event): void {\n if (event.composedPath().includes(this.overlayElement)) {\n return;\n }\n this.openOverlay();\n }\n\n protected handleSubmenuFocus(): void {\n requestAnimationFrame(() => {\n // Wait till after `closeDescendentOverlays` has happened in Menu\n // to reopen (keey open) the direct descendent of this Menu Item\n this.overlayElement.open = this.open;\n });\n }\n\n protected handleBeforetoggle = (event: Event): void => {\n if ((event as Event & { newState: string }).newState === 'closed') {\n this.open = true;\n this.overlayElement.manuallyKeepOpen();\n this.overlayElement.removeEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 protected recentlyLeftChild = false;\n\n protected handlePointerleave(): void {\n if (this.open && !this.recentlyLeftChild) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n this.open = false;\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(event: Event): void {\n event.stopPropagation();\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n }\n\n protected handleSubmenuPointerenter(): void {\n this.recentlyLeftChild = true;\n }\n\n protected async handleSubmenuPointerleave(): Promise<void> {\n requestAnimationFrame(() => {\n this.recentlyLeftChild = false;\n });\n }\n\n protected handleSubmenuOpen(event: Event): void {\n this.focused = false;\n const parentOverlay = event.composedPath().find((el) => {\n return (\n el !== this.overlayElement &&\n (el as HTMLElement).localName === 'sp-overlay'\n );\n }) as Overlay;\n this.overlayElement.parentOverlayToForceClose = parentOverlay;\n }\n\n protected cleanup(): void {\n this.open = false;\n this.active = false;\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 this.setAttribute('aria-expanded', 'true');\n this.addEventListener('sp-closed', this.cleanup, {\n once: true,\n });\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 (\n changes.has('label') &&\n (this.label || typeof changes.get('label') !== 'undefined')\n ) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (\n changes.has('active') &&\n (this.active || typeof changes.get('active') !== 'undefined')\n ) {\n if (this.active) {\n this.menuData.selectionRoot?.closeDescendentOverlays();\n this.abortControllerPointer = new AbortController();\n const options = { signal: this.abortControllerPointer.signal };\n this.addEventListener(\n 'pointerup',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointercancel',\n this.handleRemoveActive,\n options\n );\n } else {\n this.abortControllerPointer?.abort();\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 (\n changes.has('hasSubmenu') &&\n (this.hasSubmenu ||\n typeof changes.get('hasSubmenu') !== 'undefined')\n ) {\n if (this.hasSubmenu) {\n this.abortControllerSubmenu = new AbortController();\n const options = { signal: this.abortControllerSubmenu.signal };\n this.addEventListener(\n 'click',\n this.handleSubmenuClick,\n options\n );\n this.addEventListener(\n 'pointerenter',\n this.handlePointerenter,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handlePointerleave,\n options\n );\n this.addEventListener(\n 'sp-opened',\n this.handleSubmenuOpen,\n options\n );\n } else {\n this.abortControllerSubmenu?.abort();\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.triggerUpdate();\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n this.menuData.cleanupSteps.forEach((removal) => removal(this));\n super.disconnectedCallback();\n }\n\n private willDispatchUpdate = false;\n\n public async triggerUpdate(): Promise<void> {\n if (this.willDispatchUpdate) {\n return;\n }\n this.willDispatchUpdate = true;\n await new Promise((ready) => requestAnimationFrame(ready));\n this.dispatchUpdate();\n }\n\n public dispatchUpdate(): void {\n this.dispatchEvent(new MenuItemAddedOrUpdatedEvent(this));\n this.willDispatchUpdate = false;\n }\n\n public menuData: {\n focusRoot?: Menu;\n parentMenu?: Menu;\n selectionRoot?: Menu;\n cleanupSteps: ((item: MenuItem) => void)[];\n } = {\n focusRoot: undefined,\n parentMenu: undefined,\n selectionRoot: undefined,\n cleanupSteps: [],\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["html", "nothing", "ObserveSlotPresence", "ObserveSlotText", "property", "query", "LikeAnchor", "Focusable", "chevronStyles", "menuItemStyles", "checkmarkStyles", "MutationController", "POINTERLEAVE_TIMEOUT", "item", "event", "value", "acc", "node", "icon", "element", "newElement", "content", "handled", "slot", "assignedElements", "changes", "_a", "parentOverlay", "el", "role", "_b", "_c", "options", "removal", "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 nothing,\n PropertyValues,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ObserveSlotPresence,\n ObserveSlotText,\n randomID,\n} from '@spectrum-web-components/shared';\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';\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 { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport type { Overlay } from '@spectrum-web-components/overlay';\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\ntype MenuCascadeItem = {\n hadFocusRoot: boolean;\n ancestorWithSelects?: HTMLElement;\n};\n\nexport class MenuItemAddedOrUpdatedEvent extends Event {\n constructor(item: MenuItem) {\n super('sp-menu-item-added-or-updated', {\n bubbles: true,\n composed: true,\n });\n this.clear(item);\n }\n clear(item: MenuItem): void {\n this._item = item;\n this.currentAncestorWithSelects = undefined;\n item.menuData = {\n cleanupSteps: [],\n focusRoot: undefined,\n selectionRoot: undefined,\n parentMenu: undefined,\n };\n this.menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n }\n menuCascade = new WeakMap<HTMLElement, MenuCascadeItem>();\n get item(): MenuItem {\n return this._item;\n }\n private _item!: MenuItem;\n currentAncestorWithSelects?: Menu;\n}\n\nexport type MenuItemChildren = { icon: Element[]; content: Node[] };\n\n/**\n * @element sp-menu-item\n *\n * @slot - text content to display within the Menu Item\n * @slot description - description to be placed below the label of 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 * @slot submenu - content placed in a submenu\n * @fires sp-menu-item-added - announces the item has been added so a parent menu can take ownerships\n */\nexport class MenuItem extends LikeAnchor(\n ObserveSlotText(ObserveSlotPresence(Focusable, '[slot=\"icon\"]'))\n) {\n public static override get styles(): CSSResultArray {\n return [menuItemStyles, checkmarkStyles, chevronStyles];\n }\n\n abortControllerPointer!: AbortController;\n\n abortControllerSubmenu!: AbortController;\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, reflect: true, attribute: 'has-submenu' })\n public hasSubmenu = false;\n\n @query('slot:not([name])')\n contentSlot!: HTMLSlotElement;\n\n @query('slot[name=\"icon\"]')\n iconSlot!: HTMLSlotElement;\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 @query('sp-overlay')\n public overlayElement!: Overlay;\n\n public override get focusElement(): HTMLElement {\n return this;\n }\n\n protected get hasIcon(): boolean {\n return this.slotContentIsPresent;\n }\n\n public get itemChildren(): MenuItemChildren {\n if (!this.iconSlot || !this.contentSlot) {\n return {\n icon: [],\n content: [],\n };\n }\n if (this._itemChildren) {\n return this._itemChildren;\n }\n const icon = this.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 content = this.contentSlot\n .assignedNodes()\n .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.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, reflect: true })\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 renderSubmenu(): TemplateResult {\n const slot = html`\n <slot\n name=\"submenu\"\n @slotchange=${this.manageSubmenu}\n @sp-menu-item-added-or-updated=${{\n handleEvent: (event: MenuItemAddedOrUpdatedEvent) => {\n event.clear(event.item);\n },\n capture: true,\n }}\n @focusin=${(event: Event) => event.stopPropagation()}\n ></slot>\n `;\n if (!this.hasSubmenu) {\n return slot;\n }\n import('@spectrum-web-components/overlay/sp-overlay.js');\n import('@spectrum-web-components/popover/sp-popover.js');\n return html`\n <sp-overlay\n .triggerElement=${this as HTMLElement}\n ?disabled=${!this.hasSubmenu}\n ?open=${this.hasSubmenu && this.open}\n .placement=${this.isLTR ? 'right-start' : 'left-start'}\n .offset=${[-10, -4] as [number, number]}\n .type=${'auto'}\n @close=${(event: Event) => event.stopPropagation()}\n >\n <sp-popover\n @change=${(event: Event) => {\n this.handleSubmenuChange(event);\n this.open = false;\n }}\n @pointerenter=${this.handleSubmenuPointerenter}\n @pointerleave=${this.handleSubmenuPointerleave}\n @sp-menu-item-added-or-updated=${(event: Event) =>\n event.stopPropagation()}\n >\n ${slot}\n </sp-popover>\n </sp-overlay>\n <sp-icon-chevron100\n class=\"spectrum-UIIcon-ChevronRight100 chevron icon\"\n ></sp-icon-chevron100>\n `;\n }\n\n protected override render(): TemplateResult {\n return html`\n ${this.selected\n ? html`\n <sp-icon-checkmark100\n id=\"selected\"\n class=\"spectrum-UIIcon-Checkmark100 \n icon \n checkmark\n ${this.hasIcon\n ? 'checkmark--withAdjacentIcon'\n : ''}\"\n ></sp-icon-checkmark100>\n `\n : nothing}\n <slot name=\"icon\"></slot>\n <div id=\"label\">\n <slot id=\"slot\"></slot>\n </div>\n <slot name=\"description\"></slot>\n <slot name=\"value\"></slot>\n ${this.href && this.href.length > 0\n ? super.renderAnchor({\n id: 'button',\n ariaHidden: true,\n className: 'button anchor hidden',\n })\n : nothing}\n ${this.renderSubmenu()}\n `;\n }\n\n protected manageSubmenu(event: Event & { target: HTMLSlotElement }): void {\n const assignedElements = event.target.assignedElements({\n flatten: true,\n });\n this.hasSubmenu = !!assignedElements.length;\n if (this.hasSubmenu) {\n this.setAttribute('aria-haspopup', 'true');\n }\n }\n\n private handleRemoveActive(): void {\n if (this.open) {\n return;\n }\n this.active = false;\n }\n\n private handlePointerdown(event: PointerEvent): void {\n this.active = true;\n if (event.target === this && this.hasSubmenu && this.open) {\n this.addEventListener('focus', this.handleSubmenuFocus, {\n once: true,\n });\n this.overlayElement.addEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 this.addEventListener('pointerenter', this.closeOverlaysForRoot);\n if (!this.hasAttribute('id')) {\n this.id = `sp-menu-item-${randomID()}`;\n }\n }\n\n protected closeOverlaysForRoot(): void {\n if (this.open) return;\n this.menuData.parentMenu?.closeDescendentOverlays();\n }\n\n protected handleSubmenuClick(event: Event): void {\n if (event.composedPath().includes(this.overlayElement)) {\n return;\n }\n this.openOverlay();\n }\n\n protected handleSubmenuFocus(): void {\n requestAnimationFrame(() => {\n // Wait till after `closeDescendentOverlays` has happened in Menu\n // to reopen (keey open) the direct descendent of this Menu Item\n this.overlayElement.open = this.open;\n });\n }\n\n protected handleBeforetoggle = (event: Event): void => {\n if ((event as Event & { newState: string }).newState === 'closed') {\n this.open = true;\n this.overlayElement.manuallyKeepOpen();\n this.overlayElement.removeEventListener(\n 'beforetoggle',\n this.handleBeforetoggle\n );\n }\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 protected recentlyLeftChild = false;\n\n protected handlePointerleave(): void {\n if (this.open && !this.recentlyLeftChild) {\n this.leaveTimeout = setTimeout(() => {\n delete this.leaveTimeout;\n this.open = false;\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(event: Event): void {\n event.stopPropagation();\n this.menuData.selectionRoot?.selectOrToggleItem(this);\n }\n\n protected handleSubmenuPointerenter(): void {\n this.recentlyLeftChild = true;\n }\n\n protected async handleSubmenuPointerleave(): Promise<void> {\n requestAnimationFrame(() => {\n this.recentlyLeftChild = false;\n });\n }\n\n protected handleSubmenuOpen(event: Event): void {\n this.focused = false;\n const parentOverlay = event.composedPath().find((el) => {\n return (\n el !== this.overlayElement &&\n (el as HTMLElement).localName === 'sp-overlay'\n );\n }) as Overlay;\n this.overlayElement.parentOverlayToForceClose = parentOverlay;\n }\n\n protected cleanup(): void {\n this.open = false;\n this.active = false;\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 this.setAttribute('aria-expanded', 'true');\n this.addEventListener('sp-closed', this.cleanup, {\n once: true,\n });\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 (\n changes.has('label') &&\n (this.label || typeof changes.get('label') !== 'undefined')\n ) {\n this.setAttribute('aria-label', this.label || '');\n }\n if (\n changes.has('active') &&\n (this.active || typeof changes.get('active') !== 'undefined')\n ) {\n if (this.active) {\n this.menuData.selectionRoot?.closeDescendentOverlays();\n this.abortControllerPointer = new AbortController();\n const options = { signal: this.abortControllerPointer.signal };\n this.addEventListener(\n 'pointerup',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handleRemoveActive,\n options\n );\n this.addEventListener(\n 'pointercancel',\n this.handleRemoveActive,\n options\n );\n } else {\n this.abortControllerPointer?.abort();\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 (\n changes.has('hasSubmenu') &&\n (this.hasSubmenu ||\n typeof changes.get('hasSubmenu') !== 'undefined')\n ) {\n if (this.hasSubmenu) {\n this.abortControllerSubmenu = new AbortController();\n const options = { signal: this.abortControllerSubmenu.signal };\n this.addEventListener(\n 'click',\n this.handleSubmenuClick,\n options\n );\n this.addEventListener(\n 'pointerenter',\n this.handlePointerenter,\n options\n );\n this.addEventListener(\n 'pointerleave',\n this.handlePointerleave,\n options\n );\n this.addEventListener(\n 'sp-opened',\n this.handleSubmenuOpen,\n options\n );\n } else {\n this.abortControllerSubmenu?.abort();\n }\n }\n }\n\n public override connectedCallback(): void {\n super.connectedCallback();\n this.triggerUpdate();\n }\n\n _parentElement!: HTMLElement;\n\n public override disconnectedCallback(): void {\n this.menuData.cleanupSteps.forEach((removal) => removal(this));\n super.disconnectedCallback();\n }\n\n private willDispatchUpdate = false;\n\n public async triggerUpdate(): Promise<void> {\n if (this.willDispatchUpdate) {\n return;\n }\n this.willDispatchUpdate = true;\n await new Promise((ready) => requestAnimationFrame(ready));\n this.dispatchUpdate();\n }\n\n public dispatchUpdate(): void {\n this.dispatchEvent(new MenuItemAddedOrUpdatedEvent(this));\n this.willDispatchUpdate = false;\n }\n\n public menuData: {\n focusRoot?: Menu;\n parentMenu?: Menu;\n selectionRoot?: Menu;\n cleanupSteps: ((item: MenuItem) => void)[];\n } = {\n focusRoot: undefined,\n parentMenu: undefined,\n selectionRoot: undefined,\n cleanupSteps: [],\n };\n}\n\ndeclare global {\n interface GlobalEventHandlersEventMap {\n 'sp-menu-item-added-or-updated': MenuItemAddedOrUpdatedEvent;\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["html", "nothing", "ObserveSlotPresence", "ObserveSlotText", "randomID", "property", "query", "LikeAnchor", "Focusable", "chevronStyles", "menuItemStyles", "checkmarkStyles", "MutationController", "POINTERLEAVE_TIMEOUT", "item", "event", "value", "acc", "node", "icon", "element", "newElement", "content", "handled", "slot", "assignedElements", "changes", "_a", "parentOverlay", "el", "role", "_b", "_c", "options", "removal", "ready", "__decorateClass"]
7
7
  }
@@ -31,14 +31,14 @@ var(--spectrum-menu-item-focus-indicator-width)
31
31
  --mod-menu-section-header-font-weight,var(--spectrum-menu-section-header-font-weight)
32
32
  );line-height:var(
33
33
  --mod-menu-section-header-line-height,var(--spectrum-menu-section-header-line-height)
34
- )}.spectrum-Menu-backIcon{fill:var(
35
- --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
36
- );color:var(
37
- --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
38
- );margin-block:var(
34
+ )}.spectrum-Menu-backIcon{margin-block:var(
39
35
  --mod-menu-back-icon-margin-block,var(--spectrum-menu-back-icon-margin)
40
36
  );margin-inline:var(
41
37
  --mod-menu-back-icon-margin-inline,var(--spectrum-menu-back-icon-margin)
38
+ );fill:var(
39
+ --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
40
+ );color:var(
41
+ --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
42
42
  )}:host{display:block;flex-shrink:0}
43
43
  `;
44
44
  export default styles;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["menu-divider.css.ts"],
4
- "sourcesContent": ["/*\nCopyright 2024 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*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{--spectrum-menu-divider-thickness:var(--spectrum-divider-thickness-medium)}:host{inline-size:auto;margin-block:var(\n--mod-menu-section-divider-margin-block,max(0px,(var(--spectrum-menu-item-section-divider-height) - var(--spectrum-menu-divider-thickness))/2)\n);margin-inline:var(\n--mod-menu-item-label-inline-edge-to-content,var(--spectrum-menu-item-label-inline-edge-to-content)\n);overflow:visible}.spectrum-Menu-back.focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back:focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back{align-items:center;display:flex;flex-flow:wrap;padding-block:var(--mod-menu-back-padding-block-start,0) var(--mod-menu-back-padding-block-end,0);padding-inline:var(--mod-menu-back-padding-inline-start,0) var(\n--mod-menu-back-padding-inline-end,var(--spectrum-menu-item-label-inline-edge-to-content)\n)}.spectrum-Menu-backButton{background:none;border:0;cursor:pointer;display:inline-flex;margin:0;padding:0}.spectrum-Menu-backButton.focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backButton:focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backHeading{color:var(\n--highcontrast-menu-item-color-default,var(\n--mod-menu-back-heading-color,var(--spectrum-menu-section-header-color)\n)\n);display:block;font-size:var(\n--mod-menu-section-header-font-size,var(--spectrum-menu-section-header-font-size)\n);font-weight:var(\n--mod-menu-section-header-font-weight,var(--spectrum-menu-section-header-font-weight)\n);line-height:var(\n--mod-menu-section-header-line-height,var(--spectrum-menu-section-header-line-height)\n)}.spectrum-Menu-backIcon{fill:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n);color:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n);margin-block:var(\n--mod-menu-back-icon-margin-block,var(--spectrum-menu-back-icon-margin)\n);margin-inline:var(\n--mod-menu-back-icon-margin-inline,var(--spectrum-menu-back-icon-margin)\n)}:host{display:block;flex-shrink:0}\n`;\nexport default styles;"],
4
+ "sourcesContent": ["/*\nCopyright 2024 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*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{--spectrum-menu-divider-thickness:var(--spectrum-divider-thickness-medium)}:host{inline-size:auto;margin-block:var(\n--mod-menu-section-divider-margin-block,max(0px,(var(--spectrum-menu-item-section-divider-height) - var(--spectrum-menu-divider-thickness))/2)\n);margin-inline:var(\n--mod-menu-item-label-inline-edge-to-content,var(--spectrum-menu-item-label-inline-edge-to-content)\n);overflow:visible}.spectrum-Menu-back.focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back:focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back{align-items:center;display:flex;flex-flow:wrap;padding-block:var(--mod-menu-back-padding-block-start,0) var(--mod-menu-back-padding-block-end,0);padding-inline:var(--mod-menu-back-padding-inline-start,0) var(\n--mod-menu-back-padding-inline-end,var(--spectrum-menu-item-label-inline-edge-to-content)\n)}.spectrum-Menu-backButton{background:none;border:0;cursor:pointer;display:inline-flex;margin:0;padding:0}.spectrum-Menu-backButton.focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backButton:focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backHeading{color:var(\n--highcontrast-menu-item-color-default,var(\n--mod-menu-back-heading-color,var(--spectrum-menu-section-header-color)\n)\n);display:block;font-size:var(\n--mod-menu-section-header-font-size,var(--spectrum-menu-section-header-font-size)\n);font-weight:var(\n--mod-menu-section-header-font-weight,var(--spectrum-menu-section-header-font-weight)\n);line-height:var(\n--mod-menu-section-header-line-height,var(--spectrum-menu-section-header-line-height)\n)}.spectrum-Menu-backIcon{margin-block:var(\n--mod-menu-back-icon-margin-block,var(--spectrum-menu-back-icon-margin)\n);margin-inline:var(\n--mod-menu-back-icon-margin-inline,var(--spectrum-menu-back-icon-margin)\n);fill:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n);color:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n)}:host{display:block;flex-shrink:0}\n`;\nexport default styles;"],
5
5
  "mappings": ";AAWA,SAAS,WAAW;AACpB,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAyCf,eAAe;",
6
6
  "names": []
7
7
  }
@@ -29,14 +29,14 @@ var(--spectrum-menu-item-focus-indicator-width)
29
29
  --mod-menu-section-header-font-weight,var(--spectrum-menu-section-header-font-weight)
30
30
  );line-height:var(
31
31
  --mod-menu-section-header-line-height,var(--spectrum-menu-section-header-line-height)
32
- )}.spectrum-Menu-backIcon{fill:var(
33
- --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
34
- );color:var(
35
- --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
36
- );margin-block:var(
32
+ )}.spectrum-Menu-backIcon{margin-block:var(
37
33
  --mod-menu-back-icon-margin-block,var(--spectrum-menu-back-icon-margin)
38
34
  );margin-inline:var(
39
35
  --mod-menu-back-icon-margin-inline,var(--spectrum-menu-back-icon-margin)
36
+ );fill:var(
37
+ --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
38
+ );color:var(
39
+ --highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)
40
40
  )}:host{display:block;flex-shrink:0}
41
41
  `;export default i;
42
42
  //# sourceMappingURL=menu-divider.css.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["menu-divider.css.ts"],
4
- "sourcesContent": ["/*\nCopyright 2024 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*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{--spectrum-menu-divider-thickness:var(--spectrum-divider-thickness-medium)}:host{inline-size:auto;margin-block:var(\n--mod-menu-section-divider-margin-block,max(0px,(var(--spectrum-menu-item-section-divider-height) - var(--spectrum-menu-divider-thickness))/2)\n);margin-inline:var(\n--mod-menu-item-label-inline-edge-to-content,var(--spectrum-menu-item-label-inline-edge-to-content)\n);overflow:visible}.spectrum-Menu-back.focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back:focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back{align-items:center;display:flex;flex-flow:wrap;padding-block:var(--mod-menu-back-padding-block-start,0) var(--mod-menu-back-padding-block-end,0);padding-inline:var(--mod-menu-back-padding-inline-start,0) var(\n--mod-menu-back-padding-inline-end,var(--spectrum-menu-item-label-inline-edge-to-content)\n)}.spectrum-Menu-backButton{background:none;border:0;cursor:pointer;display:inline-flex;margin:0;padding:0}.spectrum-Menu-backButton.focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backButton:focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backHeading{color:var(\n--highcontrast-menu-item-color-default,var(\n--mod-menu-back-heading-color,var(--spectrum-menu-section-header-color)\n)\n);display:block;font-size:var(\n--mod-menu-section-header-font-size,var(--spectrum-menu-section-header-font-size)\n);font-weight:var(\n--mod-menu-section-header-font-weight,var(--spectrum-menu-section-header-font-weight)\n);line-height:var(\n--mod-menu-section-header-line-height,var(--spectrum-menu-section-header-line-height)\n)}.spectrum-Menu-backIcon{fill:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n);color:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n);margin-block:var(\n--mod-menu-back-icon-margin-block,var(--spectrum-menu-back-icon-margin)\n);margin-inline:var(\n--mod-menu-back-icon-margin-inline,var(--spectrum-menu-back-icon-margin)\n)}:host{display:block;flex-shrink:0}\n`;\nexport default styles;"],
4
+ "sourcesContent": ["/*\nCopyright 2024 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*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{--spectrum-menu-divider-thickness:var(--spectrum-divider-thickness-medium)}:host{inline-size:auto;margin-block:var(\n--mod-menu-section-divider-margin-block,max(0px,(var(--spectrum-menu-item-section-divider-height) - var(--spectrum-menu-divider-thickness))/2)\n);margin-inline:var(\n--mod-menu-item-label-inline-edge-to-content,var(--spectrum-menu-item-label-inline-edge-to-content)\n);overflow:visible}.spectrum-Menu-back.focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back:focus-visible{box-shadow:inset calc(var(\n--mod-menu-item-focus-indicator-width,\nvar(--spectrum-menu-item-focus-indicator-width)\n)*var(--spectrum-menu-item-focus-indicator-direction-scalar, 1)) 0 0 0 var(\n--highcontrast-menu-item-focus-indicator-color,var(\n--mod-menu-item-focus-indicator-color,var(--spectrum-menu-item-focus-indicator-color)\n)\n)}.spectrum-Menu-back{align-items:center;display:flex;flex-flow:wrap;padding-block:var(--mod-menu-back-padding-block-start,0) var(--mod-menu-back-padding-block-end,0);padding-inline:var(--mod-menu-back-padding-inline-start,0) var(\n--mod-menu-back-padding-inline-end,var(--spectrum-menu-item-label-inline-edge-to-content)\n)}.spectrum-Menu-backButton{background:none;border:0;cursor:pointer;display:inline-flex;margin:0;padding:0}.spectrum-Menu-backButton.focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backButton:focus-visible{outline:var(--spectrum-focus-indicator-thickness) solid var(--spectrum-focus-indicator-color);outline-offset:calc((var(--spectrum-focus-indicator-thickness) + 1px)*-1)}.spectrum-Menu-backHeading{color:var(\n--highcontrast-menu-item-color-default,var(\n--mod-menu-back-heading-color,var(--spectrum-menu-section-header-color)\n)\n);display:block;font-size:var(\n--mod-menu-section-header-font-size,var(--spectrum-menu-section-header-font-size)\n);font-weight:var(\n--mod-menu-section-header-font-weight,var(--spectrum-menu-section-header-font-weight)\n);line-height:var(\n--mod-menu-section-header-line-height,var(--spectrum-menu-section-header-line-height)\n)}.spectrum-Menu-backIcon{margin-block:var(\n--mod-menu-back-icon-margin-block,var(--spectrum-menu-back-icon-margin)\n);margin-inline:var(\n--mod-menu-back-icon-margin-inline,var(--spectrum-menu-back-icon-margin)\n);fill:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n);color:var(\n--highcontrast-menu-item-color-default,var(--mod-menu-back-icon-color-default)\n)}:host{display:block;flex-shrink:0}\n`;\nexport default styles;"],
5
5
  "mappings": "aAWA,OAAS,OAAAA,MAAW,gCACpB,MAAMC,EAASD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAyCf,eAAeC",
6
6
  "names": ["css", "styles"]
7
7
  }