@genexus/genexus-ide-ui 0.0.42 → 0.0.44

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 (165) hide show
  1. package/dist/cjs/ch-grid_8.cjs.entry.js +2 -1
  2. package/dist/cjs/ch-icon_2.cjs.entry.js +177 -0
  3. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  4. package/dist/cjs/grid-be8c3413.js +11 -0
  5. package/dist/cjs/{gxg-tab_4.cjs.entry.js → gx-ide-container_5.cjs.entry.js} +136 -2
  6. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js +1 -1
  7. package/dist/cjs/gx-ide-new-environment.cjs.entry.js +4 -5
  8. package/dist/cjs/gx-ide-new-kb.cjs.entry.js +6 -6
  9. package/dist/cjs/gx-ide-new-object.cjs.entry.js +3 -3
  10. package/dist/cjs/gx-ide-object-selector.cjs.entry.js +9 -12
  11. package/dist/cjs/gx-ide-references.cjs.entry.js +4 -4
  12. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js +8 -5
  13. package/dist/cjs/gx-ide-team-dev-select-recent-comment.cjs.entry.js +1 -1
  14. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js +1 -1
  15. package/dist/cjs/gx-ide-team-dev-update-to-revision.cjs.entry.js +1 -1
  16. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js +11 -9
  17. package/dist/cjs/gx-ide-template.cjs.entry.js +1 -1
  18. package/dist/cjs/gx-ide-ww-images.cjs.entry.js +19 -18
  19. package/dist/cjs/{gxg-button_2.cjs.entry.js → gxg-button.cjs.entry.js} +0 -61
  20. package/dist/cjs/gxg-menu-item.cjs.entry.js +11 -59
  21. package/dist/cjs/gxg-menu-slim-item.cjs.entry.js +78 -0
  22. package/dist/cjs/gxg-menu-slim-list.cjs.entry.js +28 -0
  23. package/dist/cjs/gxg-menu-slim.cjs.entry.js +251 -0
  24. package/dist/cjs/gxg-menu.cjs.entry.js +12 -228
  25. package/dist/cjs/loader.cjs.js +1 -1
  26. package/dist/collection/collection-manifest.json +3 -1
  27. package/dist/collection/components/_template/template.css +24 -0
  28. package/dist/collection/components/container/container.css +7 -11
  29. package/dist/collection/components/container/container.js +45 -40
  30. package/dist/collection/components/create-kb-from-server/create-kb-from-server.css +24 -0
  31. package/dist/collection/components/new-environment/new-environment.css +25 -0
  32. package/dist/collection/components/new-environment/new-environment.js +3 -22
  33. package/dist/collection/components/new-kb/new-kb.css +24 -0
  34. package/dist/collection/components/new-kb/new-kb.js +5 -5
  35. package/dist/collection/components/new-object/new-object.css +24 -0
  36. package/dist/collection/components/new-object/new-object.js +2 -2
  37. package/dist/collection/components/object-selector/object-selector.css +24 -0
  38. package/dist/collection/components/object-selector/object-selector.js +21 -3
  39. package/dist/collection/components/references/references.css +24 -0
  40. package/dist/collection/components/references/references.js +3 -3
  41. package/dist/collection/components/team-dev-commit/team-dev-commit.css +33 -10
  42. package/dist/collection/components/team-dev-commit/team-dev-commit.js +21 -4
  43. package/dist/collection/components/team-dev-select-recent-comment/team-dev-select-recent-comment.css +24 -0
  44. package/dist/collection/components/team-dev-update/team-dev-update.css +24 -0
  45. package/dist/collection/components/team-dev-update/team-dev-update.js +24 -8
  46. package/dist/collection/components/team-dev-update-partial-selection/team-dev-update-partial-selection.css +24 -0
  47. package/dist/collection/components/team-dev-update-to-revision/team-dev-update-to-revision.css +24 -0
  48. package/dist/collection/components/ww-images/ww-images.css +24 -0
  49. package/dist/collection/components/ww-images/ww-images.js +22 -22
  50. package/dist/collection/pages/assets/common.js +21 -21
  51. package/dist/components/container.js +12 -24
  52. package/dist/components/grid.js +9 -0
  53. package/dist/components/gx-ide-create-kb-from-server.js +1 -1
  54. package/dist/components/gx-ide-new-environment.js +8 -16
  55. package/dist/components/gx-ide-new-kb.js +6 -6
  56. package/dist/components/gx-ide-new-object.js +3 -3
  57. package/dist/components/gx-ide-object-selector.js +9 -12
  58. package/dist/components/gx-ide-references.js +4 -4
  59. package/dist/components/gx-ide-team-dev-commit.js +17 -14
  60. package/dist/components/gx-ide-team-dev-select-recent-comment.js +1 -1
  61. package/dist/components/gx-ide-team-dev-update-partial-selection.js +1 -1
  62. package/dist/components/gx-ide-team-dev-update-to-revision.js +1 -1
  63. package/dist/components/gx-ide-team-dev-update.js +20 -18
  64. package/dist/components/gx-ide-template.js +1 -1
  65. package/dist/components/gx-ide-top-bar.js +72 -1
  66. package/dist/components/gx-ide-ww-images.js +20 -19
  67. package/dist/components/gxg-grid2.js +4 -2
  68. package/dist/components/gxg-menu-item.js +14 -65
  69. package/dist/components/gxg-menu-slim-item.js +111 -0
  70. package/dist/components/gxg-menu-slim-list.js +50 -0
  71. package/dist/components/gxg-menu-slim.js +271 -0
  72. package/dist/components/gxg-menu.js +14 -233
  73. package/dist/components/index.js +3 -1
  74. package/dist/components/tab-bar.js +7 -1
  75. package/dist/components/tab.js +13 -1
  76. package/dist/components/tabs.js +2 -0
  77. package/dist/esm/ch-grid_8.entry.js +2 -1
  78. package/dist/esm/ch-icon_2.entry.js +172 -0
  79. package/dist/esm/genexus-ide-ui.js +1 -1
  80. package/dist/esm/grid-1354bf8f.js +9 -0
  81. package/dist/esm/{gxg-tab_4.entry.js → gx-ide-container_5.entry.js} +136 -3
  82. package/dist/esm/gx-ide-create-kb-from-server.entry.js +1 -1
  83. package/dist/esm/gx-ide-new-environment.entry.js +4 -5
  84. package/dist/esm/gx-ide-new-kb.entry.js +6 -6
  85. package/dist/esm/gx-ide-new-object.entry.js +3 -3
  86. package/dist/esm/gx-ide-object-selector.entry.js +9 -12
  87. package/dist/esm/gx-ide-references.entry.js +4 -4
  88. package/dist/esm/gx-ide-team-dev-commit.entry.js +8 -5
  89. package/dist/esm/gx-ide-team-dev-select-recent-comment.entry.js +1 -1
  90. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js +1 -1
  91. package/dist/esm/gx-ide-team-dev-update-to-revision.entry.js +1 -1
  92. package/dist/esm/gx-ide-team-dev-update.entry.js +11 -9
  93. package/dist/esm/gx-ide-template.entry.js +1 -1
  94. package/dist/esm/gx-ide-ww-images.entry.js +19 -18
  95. package/dist/esm/{gxg-button_2.entry.js → gxg-button.entry.js} +2 -62
  96. package/dist/esm/gxg-menu-item.entry.js +12 -60
  97. package/dist/esm/gxg-menu-slim-item.entry.js +74 -0
  98. package/dist/esm/gxg-menu-slim-list.entry.js +24 -0
  99. package/dist/esm/gxg-menu-slim.entry.js +247 -0
  100. package/dist/esm/gxg-menu.entry.js +12 -228
  101. package/dist/esm/loader.js +1 -1
  102. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  103. package/dist/genexus-ide-ui/p-04f69ecc.entry.js +1 -0
  104. package/dist/genexus-ide-ui/p-098a1397.entry.js +1 -0
  105. package/dist/genexus-ide-ui/p-0f85cf00.entry.js +1 -0
  106. package/dist/genexus-ide-ui/{p-38fa6211.entry.js → p-19d9c08c.entry.js} +1 -1
  107. package/dist/genexus-ide-ui/p-1bcabe1c.entry.js +1 -0
  108. package/dist/genexus-ide-ui/{p-fcdcb919.entry.js → p-1ccf523f.entry.js} +1 -1
  109. package/dist/genexus-ide-ui/p-2bd01c9e.entry.js +1 -0
  110. package/dist/genexus-ide-ui/p-42901fd7.entry.js +1 -0
  111. package/dist/genexus-ide-ui/p-4b65669b.entry.js +1 -0
  112. package/dist/genexus-ide-ui/p-6afc6187.entry.js +1 -0
  113. package/dist/genexus-ide-ui/p-73f61127.entry.js +1 -0
  114. package/dist/genexus-ide-ui/p-9014609e.entry.js +1 -0
  115. package/dist/genexus-ide-ui/{p-508cf8b0.entry.js → p-917c5696.entry.js} +1 -1
  116. package/dist/genexus-ide-ui/p-a708db45.entry.js +1 -0
  117. package/dist/genexus-ide-ui/p-b456483d.entry.js +1 -0
  118. package/dist/genexus-ide-ui/p-b74dd891.entry.js +1 -0
  119. package/dist/genexus-ide-ui/p-c38c6957.entry.js +1 -0
  120. package/dist/genexus-ide-ui/p-c61bf417.entry.js +1 -0
  121. package/dist/genexus-ide-ui/p-c6a7b93c.js +1 -0
  122. package/dist/genexus-ide-ui/p-e1cd9135.entry.js +1 -0
  123. package/dist/genexus-ide-ui/{p-22e142e8.entry.js → p-e4eb3828.entry.js} +1 -1
  124. package/dist/genexus-ide-ui/p-e5a3e3b9.entry.js +1 -0
  125. package/dist/genexus-ide-ui/{p-6073c264.entry.js → p-f1116ac5.entry.js} +1 -1
  126. package/dist/node_modules/@genexus/gemini/dist/collection/components/grid/gxg-grid.css +1 -5
  127. package/dist/node_modules/@genexus/gemini/dist/collection/components/menu/menu/menu.css +724 -0
  128. package/dist/node_modules/@genexus/gemini/dist/collection/components/menu/menu-item/menu-item.css +711 -0
  129. package/dist/node_modules/@genexus/gemini/dist/collection/components/tab/tab.css +8 -0
  130. package/dist/node_modules/@genexus/gemini/dist/collection/components/tab-bar/tab-bar.css +3 -0
  131. package/dist/types/components/container/container.d.ts +8 -5
  132. package/dist/types/components/new-environment/new-environment.d.ts +0 -4
  133. package/dist/types/components/object-selector/object-selector.d.ts +10 -6
  134. package/dist/types/components/team-dev-commit/team-dev-commit.d.ts +4 -0
  135. package/dist/types/components/team-dev-update/team-dev-update.d.ts +4 -0
  136. package/dist/types/components/ww-images/ww-images.d.ts +13 -14
  137. package/dist/types/components.d.ts +27 -15
  138. package/package.json +3 -3
  139. package/dist/cjs/ch-icon.cjs.entry.js +0 -116
  140. package/dist/cjs/gx-ide-container.cjs.entry.js +0 -137
  141. package/dist/cjs/gxg-menu-list.cjs.entry.js +0 -28
  142. package/dist/components/gxg-menu-list.js +0 -50
  143. package/dist/components/top-bar.js +0 -74
  144. package/dist/esm/ch-icon.entry.js +0 -112
  145. package/dist/esm/gx-ide-container.entry.js +0 -133
  146. package/dist/esm/gxg-menu-list.entry.js +0 -24
  147. package/dist/genexus-ide-ui/p-07e89cdd.entry.js +0 -1
  148. package/dist/genexus-ide-ui/p-1770fa36.entry.js +0 -1
  149. package/dist/genexus-ide-ui/p-179713ef.entry.js +0 -1
  150. package/dist/genexus-ide-ui/p-181ee8a8.entry.js +0 -1
  151. package/dist/genexus-ide-ui/p-35fc1102.entry.js +0 -1
  152. package/dist/genexus-ide-ui/p-4d39c34a.entry.js +0 -1
  153. package/dist/genexus-ide-ui/p-55d98662.entry.js +0 -1
  154. package/dist/genexus-ide-ui/p-5ad757f4.entry.js +0 -1
  155. package/dist/genexus-ide-ui/p-764ab316.entry.js +0 -1
  156. package/dist/genexus-ide-ui/p-7a83018d.entry.js +0 -1
  157. package/dist/genexus-ide-ui/p-7a90def4.entry.js +0 -1
  158. package/dist/genexus-ide-ui/p-7c38776f.entry.js +0 -1
  159. package/dist/genexus-ide-ui/p-82228c39.entry.js +0 -1
  160. package/dist/genexus-ide-ui/p-8afbdbc9.entry.js +0 -1
  161. package/dist/genexus-ide-ui/p-cab184a7.entry.js +0 -1
  162. package/dist/genexus-ide-ui/p-d376dada.entry.js +0 -1
  163. /package/dist/node_modules/@genexus/gemini/dist/collection/components/{menu-item/menu-item.css → menu-slim/item/item.css} +0 -0
  164. /package/dist/node_modules/@genexus/gemini/dist/collection/components/{menu-list/menu-list.css → menu-slim/list/list.css} +0 -0
  165. /package/dist/node_modules/@genexus/gemini/dist/collection/components/{menu → menu-slim/menu}/menu.css +0 -0
@@ -0,0 +1,24 @@
1
+ import { r as registerInstance, h, H as Host } from './index-0da01575.js';
2
+
3
+ const listCss = ":root{--ui-animaton-speed:0.2s}.gxg-title-01{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-01--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-02{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-02--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-03{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-03--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-04{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-04--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-05{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em}.gxg-title-05--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em;color:var(--color-on-primary)}.gxg-text{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-text--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-text--gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--gray-05)}.gxg-quote{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;font-style:italic}.gxg-quote--negative{color:var(--color-on-primary)}.gxg-link{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block}.gxg-link:hover{color:var(--color-primary-hover)}.gxg-link:active{color:var(--color-primary-active)}.gxg-link-gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04)}.gxg-link-gray:hover{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04);color:var(--gray-06)}.gxg-alert-error{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-error-dark);display:inline-block}.gxg-alert-warning{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-warning-dark);display:inline-block}.gxg-alert-success{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-success-dark);display:inline-block}.gxg-tab--disabled{color:var(--color-primary-disabled);pointer-events:none}.gxg-tab--disabled[disabled]{color:var(--color-primary-disabled);pointer-events:none}.gxg-label{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-label:hover{color:var(--color-primary-hover)}.gxg-label:focus{color:var(--color-primary-active)}.gxg-label:active{color:var(--color-primary-active)}.gxg-label[disabled]{color:var(--color-primary-disabled)}.gxg-label--negative{color:var(--color-on-primary)}.gxg-label--negative[disabled]{color:var(--color-on-disabled)}.gxg-button-styles{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-scrollbar{}.gxg-scrollbar::-webkit-scrollbar{width:6px;height:6px}.gxg-scrollbar::-webkit-scrollbar-track{background-color:var(--gray-02);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb{background:var(--gray-05);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--gray-04);cursor:pointer}:host{display:block}.title-wrapper{display:block;padding:var(--spacing-comp-01) var(--spacing-comp-02);box-sizing:border-box}ul{padding-left:0;list-style-type:none;display:block;box-sizing:border-box;margin:0;font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em}";
4
+
5
+ const GxgMenuSlimList = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ }
9
+ // 2. REFERENCE TO ELEMENTS //
10
+ // 3.STATE() VARIABLES //
11
+ // 4.PUBLIC PROPERTY API | WATCH'S //
12
+ // 5.EVENTS (EMIT) //
13
+ // 6.METHODS //
14
+ // 7.LISTENERS //
15
+ // 8.PUBLIC METHODS API //
16
+ // 9.LOCAL METHODS //
17
+ // 10.RENDER() FUNCTION //
18
+ render() {
19
+ return (h(Host, null, h("div", { class: "wrapper", part: "wrapper" }, this.listTitle ? (h("span", { class: "title-wrapper", part: "title-wrapper" }, h("gxg-title", { type: "title-05", part: "title" }, this.listTitle))) : null, h("ul", { part: "list" }, h("slot", null)))));
20
+ }
21
+ };
22
+ GxgMenuSlimList.style = listCss;
23
+
24
+ export { GxgMenuSlimList as gxg_menu_slim_list };
@@ -0,0 +1,247 @@
1
+ import { r as registerInstance, h, H as Host, g as getElement } from './index-0da01575.js';
2
+ import { K as KeyboardKeys } from './types-02481dff.js';
3
+
4
+ const detectClickOutside = (event, element) => {
5
+ const x = event.x;
6
+ const y = event.y;
7
+ //Contextual menu coordinates
8
+ const elementBoundingClientRect = element.getBoundingClientRect();
9
+ if ((x > elementBoundingClientRect.left &&
10
+ x < elementBoundingClientRect.right &&
11
+ y > elementBoundingClientRect.top &&
12
+ y < elementBoundingClientRect.bottom) ||
13
+ (event.screenX === 0 &&
14
+ event.screenY === 0 &&
15
+ event.clientX === 0 &&
16
+ event.clientY === 0)) {
17
+ //Click happened inside the element
18
+ return false;
19
+ }
20
+ else {
21
+ //Click happened outside the element
22
+ return true;
23
+ }
24
+ };
25
+
26
+ const menuCss = "/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0;}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px;}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}:root{--ui-animaton-speed:0.2s}.gxg-title-01{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-01--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-02{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-02--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-03{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-03--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-04{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-04--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-05{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em}.gxg-title-05--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em;color:var(--color-on-primary)}.gxg-text{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-text--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-text--gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--gray-05)}.gxg-quote{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;font-style:italic}.gxg-quote--negative{color:var(--color-on-primary)}.gxg-link{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block}.gxg-link:hover{color:var(--color-primary-hover)}.gxg-link:active{color:var(--color-primary-active)}.gxg-link-gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04)}.gxg-link-gray:hover{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04);color:var(--gray-06)}.gxg-alert-error{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-error-dark);display:inline-block}.gxg-alert-warning{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-warning-dark);display:inline-block}.gxg-alert-success{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-success-dark);display:inline-block}.gxg-tab--disabled{color:var(--color-primary-disabled);pointer-events:none}.gxg-tab--disabled[disabled]{color:var(--color-primary-disabled);pointer-events:none}.gxg-label{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-label:hover{color:var(--color-primary-hover)}.gxg-label:focus{color:var(--color-primary-active)}.gxg-label:active{color:var(--color-primary-active)}.gxg-label[disabled]{color:var(--color-primary-disabled)}.gxg-label--negative{color:var(--color-on-primary)}.gxg-label--negative[disabled]{color:var(--color-on-disabled)}.gxg-button-styles{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-scrollbar{}.gxg-scrollbar::-webkit-scrollbar{width:6px;height:6px}.gxg-scrollbar::-webkit-scrollbar-track{background-color:var(--gray-02);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb{background:var(--gray-05);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--gray-04);cursor:pointer}:host{display:inline-block;position:absolute}.outer-wrapper{color:var(--color-on-background);font-family:var(--font-family-primary);overflow:hidden;box-shadow:var(--box-shadow-01);background:var(--color-background);transition-property:height}.inner-wrapper{border-radius:var(--border-width-md);box-sizing:border-box}.menu__header{border-bottom-style:var(--border-style-regular);border-bottom-width:var(--border-width-sm);border-bottom-color:var(--gray-03)}.menu__header__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);text-transform:uppercase;margin-top:0;margin-bottom:0;padding:var(--spacing-comp-01) var(--spacing-comp-03)}:host([full-width]){width:100% !important}:host([tabs]) .menu-list{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}:host([tabs]) .menu-list ::slotted(gxg-menu-item){text-transform:uppercase}:host ::slotted(gxg-menu-list){border-bottom-style:var(--border-style-regular);border-bottom-width:var(--border-width-sm);border-bottom-color:var(--gray-03)}:host ::slotted(gxg-menu-list){border-bottom:none}";
27
+
28
+ const GxgMenuSlim = class {
29
+ constructor(hostRef) {
30
+ registerInstance(this, hostRef);
31
+ /*
32
+ INDEX:
33
+ 1.OWN PROPERTIES
34
+ 2.REFERENCE TO ELEMENTS
35
+ 3.STATE() VARIABLES
36
+ 4.PUBLIC PROPERTY API | WATCH'S
37
+ 5.EVENTS (EMIT)
38
+ 6.COMPONENT LIFECYCLE EVENTS
39
+ 7.LISTENERS
40
+ 8.PUBLIC METHODS API
41
+ 9.LOCAL METHODS
42
+ 10.RENDER() FUNCTION
43
+ */
44
+ // 1.OWN PROPERTIES //
45
+ this._menuHeight = "0px";
46
+ /**
47
+ * The delay in milliseconds that the menu will remain visible after mouseout event fires.
48
+ */
49
+ this._mouseOutDelay = 1000;
50
+ /**
51
+ * The menu height transition timing.
52
+ */
53
+ this._transitionDuration = 200;
54
+ /**
55
+ * The enabled (not disabled) menu items
56
+ */
57
+ this._enabledItems = [];
58
+ /**
59
+ * Hides or show the menu with an animation
60
+ */
61
+ this.hidden = true;
62
+ /**
63
+ * Hides the menu when an item is selected.
64
+ */
65
+ this.hideOnSelect = true;
66
+ /**
67
+ * Prevents the menu-item's text from wrapping into more than one line, adding an ellipsis at the end.
68
+ */
69
+ this.ellipsis = true;
70
+ // 8.PUBLIC METHODS API //
71
+ // 9.LOCAL METHODS //
72
+ this.setFocusFirstItem = () => {
73
+ const firstItem = this.el.querySelector("gxg-menu-slim-item");
74
+ firstItem.focus();
75
+ };
76
+ this.assignEllipsis = () => {
77
+ if (this.ellipsis) {
78
+ const items = this.el.querySelectorAll("gxg-menu-slim-item");
79
+ items &&
80
+ items.forEach((item) => {
81
+ item.ellipsis = true;
82
+ });
83
+ }
84
+ };
85
+ /*Mouse out handlers*/
86
+ this.attachMouseOut = () => {
87
+ this.el.addEventListener("mouseout", this.detectMouseOut);
88
+ };
89
+ this.removeMouseOut = () => {
90
+ this.el.removeEventListener("mouseout", this.detectMouseOut);
91
+ };
92
+ this.detectMouseOut = (e) => {
93
+ const nodeName = e.relatedTarget.nodeName;
94
+ if (nodeName !== "GXG-MENU" &&
95
+ nodeName !== "GXG-MENU-LIST" &&
96
+ nodeName !== "GXG-MENU-slim-ITEM") {
97
+ //Mouse out
98
+ this.startMouseOutTimeout();
99
+ }
100
+ };
101
+ /*Mouse enter handlers*/
102
+ this.attachMouseEnter = () => {
103
+ this.el.addEventListener("mouseenter", this.detectMouseEnter);
104
+ };
105
+ this.removeMouseEnter = () => {
106
+ this.el.removeEventListener("mouseenter", this.detectMouseEnter);
107
+ };
108
+ this.detectMouseEnter = () => {
109
+ //Mouse enter
110
+ this.clearMouseOutTimeout();
111
+ };
112
+ /*Detect click outside*/
113
+ this.attachDetectClickOutside = () => {
114
+ document.addEventListener("click", this.detectClickOutside);
115
+ };
116
+ this.removeDetectClickOutside = () => {
117
+ document.removeEventListener("click", this.detectClickOutside);
118
+ };
119
+ /*Detect click outside*/
120
+ this.detectClickOutside = (e) => {
121
+ const clickedOutside = detectClickOutside(e, this.el);
122
+ if (clickedOutside) {
123
+ this.hidden = true;
124
+ }
125
+ else {
126
+ this.hidden = false;
127
+ }
128
+ };
129
+ this.getEnabledItems = () => {
130
+ const enabledItems = this.el.querySelectorAll("gxg-menu-slim-item");
131
+ enabledItems.forEach((menuItem) => {
132
+ if (!menuItem.disabled) {
133
+ this._enabledItems.push(menuItem);
134
+ }
135
+ });
136
+ };
137
+ }
138
+ hiddenHandler(hidden) {
139
+ if (hidden) {
140
+ this._menuHeight = "0px";
141
+ this.el.setAttribute("tabindex", "-1");
142
+ this.removeDetectClickOutside();
143
+ this.removeMouseOut();
144
+ this.removeMouseEnter();
145
+ }
146
+ else {
147
+ this._menuHeight = this.innerWrapper.offsetHeight + "px";
148
+ this.el.removeAttribute("tabindex");
149
+ setTimeout(() => {
150
+ this.setFocusFirstItem();
151
+ this.attachDetectClickOutside();
152
+ this.attachMouseOut();
153
+ this.attachMouseEnter();
154
+ }, this._transitionDuration);
155
+ }
156
+ }
157
+ // 5.EVENTS (EMIT) //
158
+ // 6.COMPONENT LIFECYCLE EVENTS //
159
+ componentWillLoad() {
160
+ this.assignEllipsis();
161
+ /*Prevent this.mouseOutTimeout firing on page load*/
162
+ clearTimeout(this.mouseOutTimeout);
163
+ this.getEnabledItems();
164
+ }
165
+ componentDidUnload() {
166
+ this.removeDetectClickOutside();
167
+ this.removeMouseOut();
168
+ this.removeMouseEnter();
169
+ }
170
+ // 7.LISTENERS //
171
+ itemSelectedHandler(itemSelected) {
172
+ /*Remove 'active' from every item, except from the clicked one*/
173
+ const menuItems = Array.from(this.el.querySelectorAll("gxg-menu-slim-item"));
174
+ menuItems.forEach((menuItem) => {
175
+ if (itemSelected.detail.ref !== menuItem) {
176
+ menuItem.active = false;
177
+ }
178
+ });
179
+ /*Hide menu*/
180
+ if (this.hideOnSelect) {
181
+ this.hidden = true;
182
+ }
183
+ }
184
+ keyboardNavigationHandler(triggeredItem) {
185
+ const triggeringItem = triggeredItem.detail.ref;
186
+ const triggeringItemIndex = this._enabledItems.findIndex((item) => {
187
+ return item === triggeringItem;
188
+ });
189
+ let newFocusedItem;
190
+ if (triggeringItemIndex !== -1 &&
191
+ triggeredItem.detail.key === KeyboardKeys.ARROW_UP) {
192
+ const prevItem = this._enabledItems[triggeringItemIndex - 1];
193
+ if ((prevItem === null || prevItem === void 0 ? void 0 : prevItem.active) && prevItem.previousElementSibling) {
194
+ newFocusedItem = prevItem.previousElementSibling;
195
+ }
196
+ else if (prevItem) {
197
+ newFocusedItem = prevItem;
198
+ }
199
+ }
200
+ else if (triggeringItemIndex !== -1 &&
201
+ triggeredItem.detail.key === KeyboardKeys.ARROW_DOWN) {
202
+ const nextItem = this._enabledItems[triggeringItemIndex + 1];
203
+ if ((nextItem === null || nextItem === void 0 ? void 0 : nextItem.active) && nextItem.nextElementSibling) {
204
+ newFocusedItem = nextItem.nextElementSibling;
205
+ }
206
+ else if (nextItem) {
207
+ newFocusedItem = nextItem;
208
+ }
209
+ }
210
+ if (newFocusedItem) {
211
+ newFocusedItem.focus();
212
+ }
213
+ }
214
+ /**
215
+ * @description
216
+ */
217
+ startMouseOutTimeout() {
218
+ this.mouseOutTimeout = setTimeout(() => {
219
+ this.hidden = true;
220
+ }, this._mouseOutDelay);
221
+ }
222
+ clearMouseOutTimeout() {
223
+ clearTimeout(this.mouseOutTimeout);
224
+ }
225
+ /**
226
+ * @description It renders the menu title, which is optional.
227
+ */
228
+ renderTitle() {
229
+ return this.menuTitle ? (h("header", { class: "menu__header", part: "header" }, h("h1", { class: "menu__header__title", part: "title" }, this.menuTitle))) : null;
230
+ }
231
+ // 10.RENDER() FUNCTION //
232
+ render() {
233
+ return (h(Host, { tabindex: "-1" }, h("div", { class: {
234
+ "outer-wrapper": true,
235
+ }, style: {
236
+ height: this._menuHeight,
237
+ transitionDuration: `${this._transitionDuration}ms`,
238
+ }, part: "outer-wrapper" }, h("div", { class: "inner-wrapper", ref: (el) => (this.innerWrapper = el), part: "inner-wrapper" }, this.renderTitle(), h("div", { class: "lists-wrapper", part: "lists-wrapper" }, h("slot", null))))));
239
+ }
240
+ get el() { return getElement(this); }
241
+ static get watchers() { return {
242
+ "hidden": ["hiddenHandler"]
243
+ }; }
244
+ };
245
+ GxgMenuSlim.style = menuCss;
246
+
247
+ export { GxgMenuSlim as gxg_menu_slim };
@@ -1,246 +1,30 @@
1
1
  import { r as registerInstance, h, H as Host, g as getElement } from './index-0da01575.js';
2
- import { K as KeyboardKeys } from './types-02481dff.js';
3
2
 
4
- const detectClickOutside = (event, element) => {
5
- const x = event.x;
6
- const y = event.y;
7
- //Contextual menu coordinates
8
- const elementBoundingClientRect = element.getBoundingClientRect();
9
- if ((x > elementBoundingClientRect.left &&
10
- x < elementBoundingClientRect.right &&
11
- y > elementBoundingClientRect.top &&
12
- y < elementBoundingClientRect.bottom) ||
13
- (event.screenX === 0 &&
14
- event.screenY === 0 &&
15
- event.clientX === 0 &&
16
- event.clientY === 0)) {
17
- //Click happened inside the element
18
- return false;
19
- }
20
- else {
21
- //Click happened outside the element
22
- return true;
23
- }
24
- };
25
-
26
- const menuCss = "/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0;}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px;}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}:root{--ui-animaton-speed:0.2s}.gxg-title-01{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-01--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-02{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-02--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-03{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-03--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-04{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-04--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-05{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em}.gxg-title-05--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em;color:var(--color-on-primary)}.gxg-text{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-text--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-text--gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--gray-05)}.gxg-quote{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;font-style:italic}.gxg-quote--negative{color:var(--color-on-primary)}.gxg-link{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block}.gxg-link:hover{color:var(--color-primary-hover)}.gxg-link:active{color:var(--color-primary-active)}.gxg-link-gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04)}.gxg-link-gray:hover{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04);color:var(--gray-06)}.gxg-alert-error{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-error-dark);display:inline-block}.gxg-alert-warning{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-warning-dark);display:inline-block}.gxg-alert-success{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-success-dark);display:inline-block}.gxg-tab--disabled{color:var(--color-primary-disabled);pointer-events:none}.gxg-tab--disabled[disabled]{color:var(--color-primary-disabled);pointer-events:none}.gxg-label{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-label:hover{color:var(--color-primary-hover)}.gxg-label:focus{color:var(--color-primary-active)}.gxg-label:active{color:var(--color-primary-active)}.gxg-label[disabled]{color:var(--color-primary-disabled)}.gxg-label--negative{color:var(--color-on-primary)}.gxg-label--negative[disabled]{color:var(--color-on-disabled)}.gxg-button-styles{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-scrollbar{}.gxg-scrollbar::-webkit-scrollbar{width:6px;height:6px}.gxg-scrollbar::-webkit-scrollbar-track{background-color:var(--gray-02);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb{background:var(--gray-05);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--gray-04);cursor:pointer}:host{display:inline-block;position:absolute}.outer-wrapper{color:var(--color-on-background);font-family:var(--font-family-primary);overflow:hidden;box-shadow:var(--box-shadow-01);background:var(--color-background);transition-property:height}.inner-wrapper{border-radius:var(--border-width-md);box-sizing:border-box}.menu__header{border-bottom-style:var(--border-style-regular);border-bottom-width:var(--border-width-sm);border-bottom-color:var(--gray-03)}.menu__header__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);text-transform:uppercase;margin-top:0;margin-bottom:0;padding:var(--spacing-comp-01) var(--spacing-comp-03)}:host([full-width]){width:100% !important}:host([tabs]) .menu-list{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}:host([tabs]) .menu-list ::slotted(gxg-menu-item){text-transform:uppercase}:host ::slotted(gxg-menu-list){border-bottom-style:var(--border-style-regular);border-bottom-width:var(--border-width-sm);border-bottom-color:var(--gray-03)}:host ::slotted(gxg-menu-list){border-bottom:none}";
3
+ const menuCss = "/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%;}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible;}pre{font-family:monospace, monospace;font-size:1em;}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em;}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0;}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal;}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0;}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px;}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit;}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}:root{--ui-animaton-speed:0.2s}.gxg-title-01{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-01--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-02{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-02--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-03{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em}.gxg-title-03--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;text-transform:uppercase;line-height:1.556em;color:var(--color-on-primary)}.gxg-title-04{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-title-04--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);letter-spacing:var(--letter-spacing-md);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-title-05{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em}.gxg-title-05--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-sm);color:var(--color-on-background);text-align:start;line-height:1.556em;color:var(--color-on-primary)}.gxg-text{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em}.gxg-text--negative{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-on-primary)}.gxg-text--gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--gray-05)}.gxg-quote{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;font-style:italic}.gxg-quote--negative{color:var(--color-on-primary)}.gxg-link{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block}.gxg-link:hover{color:var(--color-primary-hover)}.gxg-link:active{color:var(--color-primary-active)}.gxg-link-gray{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04)}.gxg-link-gray:hover{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-primary);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--gray-04);color:var(--gray-06)}.gxg-alert-error{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-error-dark);display:inline-block}.gxg-alert-warning{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-warning-dark);display:inline-block}.gxg-alert-success{font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em;color:var(--color-success-dark);display:inline-block}.gxg-tab--disabled{color:var(--color-primary-disabled);pointer-events:none}.gxg-tab--disabled[disabled]{color:var(--color-primary-disabled);pointer-events:none}.gxg-label{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-label:hover{color:var(--color-primary-hover)}.gxg-label:focus{color:var(--color-primary-active)}.gxg-label:active{color:var(--color-primary-active)}.gxg-label[disabled]{color:var(--color-primary-disabled)}.gxg-label--negative{color:var(--color-on-primary)}.gxg-label--negative[disabled]{color:var(--color-on-disabled)}.gxg-button-styles{font-family:var(--font-family-primary) !important;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm) !important;letter-spacing:var(--letter-spacing-xs);color:var(--color-primary-enabled);text-align:center;line-height:1.455em}.gxg-scrollbar{}.gxg-scrollbar::-webkit-scrollbar{width:6px;height:6px}.gxg-scrollbar::-webkit-scrollbar-track{background-color:var(--gray-02);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb{background:var(--gray-05);border-radius:10px}.gxg-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--gray-04);cursor:pointer}:host{display:inline-block;background:var(--color-background);border-radius:var(--border-width-md);box-shadow:var(--box-shadow-01)}:host .menu__header{border-bottom-style:var(--border-style-regular);border-bottom-width:var(--border-width-sm);border-bottom-color:var(--gray-04)}:host .menu__header__title{color:var(--color-on-background);font-family:var(--font-family-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;margin-top:0;margin-bottom:0;padding:var(--spacing-comp-03) var(--spacing-comp-05) var(--spacing-comp-03) var(--spacing-comp-05)}:host .menuList{list-style-type:none;display:block;padding-left:0;margin:0;font-family:var(--font-family-primary);font-weight:var(--font-weight-regular);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-xs);color:var(--color-on-background);text-align:start;line-height:1.455em}:host([full-width]){width:100% !important}:host([tabs]) .menuList{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}:host([tabs]) .menuList ::slotted(gxg-menu-item){text-transform:uppercase}";
27
4
 
28
5
  const GxgMenu = class {
29
6
  constructor(hostRef) {
30
7
  registerInstance(this, hostRef);
31
- /*
32
- INDEX:
33
- 1.OWN PROPERTIES
34
- 2.REFERENCE TO ELEMENTS
35
- 3.STATE() VARIABLES
36
- 4.PUBLIC PROPERTY API | WATCH'S
37
- 5.EVENTS (EMIT)
38
- 6.COMPONENT LIFECYCLE EVENTS
39
- 7.LISTENERS
40
- 8.PUBLIC METHODS API
41
- 9.LOCAL METHODS
42
- 10.RENDER() FUNCTION
43
- */
44
- // 1.OWN PROPERTIES //
45
- this._menuHeight = "0px";
46
- /**
47
- * The delay in milliseconds that the menu will remain visible after mouseout event fires.
48
- */
49
- this._mouseOutDelay = 1000;
50
- /**
51
- * The menu height transition timing.
52
- */
53
- this._transitionDuration = 200;
54
- /**
55
- * The enabled (not disabled) menu items
56
- */
57
- this._enabledItems = [];
58
- /**
59
- * Hides or show the menu with an animation
60
- */
61
- this.hidden = true;
62
- /**
63
- * Hides the menu when an item is selected.
64
- */
65
- this.hideOnSelect = true;
66
- /**
67
- * Prevents the menu-item's text from wrapping into more than one line, adding an ellipsis at the end.
68
- */
69
- this.ellipsis = true;
70
- // 8.PUBLIC METHODS API //
71
- // 9.LOCAL METHODS //
72
- this.setFocusFirstItem = () => {
73
- const firstItem = this.el.querySelector("gxg-menu-item");
74
- firstItem.focus();
75
- };
76
- this.assignEllipsis = () => {
77
- if (this.ellipsis) {
78
- const items = this.el.querySelectorAll("gxg-menu-item");
79
- items &&
80
- items.forEach((item) => {
81
- item.ellipsis = true;
82
- });
83
- }
84
- };
85
- /*Mouse out handlers*/
86
- this.attachMouseOut = () => {
87
- this.el.addEventListener("mouseout", this.detectMouseOut);
88
- };
89
- this.removeMouseOut = () => {
90
- this.el.removeEventListener("mouseout", this.detectMouseOut);
91
- };
92
- this.detectMouseOut = (e) => {
93
- const nodeName = e.relatedTarget.nodeName;
94
- if (nodeName !== "GXG-MENU" &&
95
- nodeName !== "GXG-MENU-LIST" &&
96
- nodeName !== "GXG-MENU-ITEM") {
97
- //Mouse out
98
- this.startMouseOutTimeout();
99
- }
100
- };
101
- /*Mouse enter handlers*/
102
- this.attachMouseEnter = () => {
103
- this.el.addEventListener("mouseenter", this.detectMouseEnter);
104
- };
105
- this.removeMouseEnter = () => {
106
- this.el.removeEventListener("mouseenter", this.detectMouseEnter);
107
- };
108
- this.detectMouseEnter = () => {
109
- //Mouse enter
110
- this.clearMouseOutTimeout();
111
- };
112
- /*Detect click outside*/
113
- this.attachDetectClickOutside = () => {
114
- document.addEventListener("click", this.detectClickOutside);
115
- };
116
- this.removeDetectClickOutside = () => {
117
- document.removeEventListener("click", this.detectClickOutside);
118
- };
119
- /*Detect click outside*/
120
- this.detectClickOutside = (e) => {
121
- const clickedOutside = detectClickOutside(e, this.el);
122
- if (clickedOutside) {
123
- this.hidden = true;
124
- }
125
- else {
126
- this.hidden = false;
127
- }
128
- };
129
- this.getEnabledItems = () => {
130
- const enabledItems = this.el.querySelectorAll("gxg-menu-item");
131
- enabledItems.forEach((menuItem) => {
132
- if (!menuItem.disabled) {
133
- this._enabledItems.push(menuItem);
134
- }
135
- });
136
- };
137
- }
138
- hiddenHandler(hidden) {
139
- if (hidden) {
140
- this._menuHeight = "0px";
141
- this.el.setAttribute("tabindex", "-1");
142
- this.removeDetectClickOutside();
143
- this.removeMouseOut();
144
- this.removeMouseEnter();
145
- }
146
- else {
147
- this._menuHeight = this.innerWrapper.offsetHeight + "px";
148
- this.el.removeAttribute("tabindex");
149
- setTimeout(() => {
150
- this.setFocusFirstItem();
151
- this.attachDetectClickOutside();
152
- this.attachMouseOut();
153
- this.attachMouseEnter();
154
- }, this._transitionDuration);
155
- }
156
- }
157
- // 5.EVENTS (EMIT) //
158
- // 6.COMPONENT LIFECYCLE EVENTS //
159
- componentWillLoad() {
160
- this.assignEllipsis();
161
- /*Prevent this.mouseOutTimeout firing on page load*/
162
- clearTimeout(this.mouseOutTimeout);
163
- this.getEnabledItems();
164
8
  }
165
- componentDidUnload() {
166
- this.removeDetectClickOutside();
167
- this.removeMouseOut();
168
- this.removeMouseEnter();
169
- }
170
- // 7.LISTENERS //
171
- itemSelectedHandler(itemSelected) {
172
- /*Remove 'active' from every item, except from the clicked one*/
173
- const menuItems = Array.from(this.el.querySelectorAll("gxg-menu-item"));
174
- menuItems.forEach((menuItem) => {
175
- if (itemSelected.detail.ref !== menuItem) {
176
- menuItem.active = false;
9
+ menuItemActiveHandler(event) {
10
+ const children = Array.from(this.el.querySelectorAll("gxg-menu-item"));
11
+ children.forEach((element) => {
12
+ element.removeAttribute("active");
13
+ if (event.detail === element.getAttribute("label")) {
14
+ element.setAttribute("active", "active");
177
15
  }
178
16
  });
179
- /*Hide menu*/
180
- if (this.hideOnSelect) {
181
- this.hidden = true;
182
- }
183
17
  }
184
- keyboardNavigationHandler(triggeredItem) {
185
- const triggeringItem = triggeredItem.detail.ref;
186
- const triggeringItemIndex = this._enabledItems.findIndex((item) => {
187
- return item === triggeringItem;
188
- });
189
- let newFocusedItem;
190
- if (triggeringItemIndex !== -1 &&
191
- triggeredItem.detail.key === KeyboardKeys.ARROW_UP) {
192
- const prevItem = this._enabledItems[triggeringItemIndex - 1];
193
- if ((prevItem === null || prevItem === void 0 ? void 0 : prevItem.active) && prevItem.previousElementSibling) {
194
- newFocusedItem = prevItem.previousElementSibling;
195
- }
196
- else if (prevItem) {
197
- newFocusedItem = prevItem;
198
- }
199
- }
200
- else if (triggeringItemIndex !== -1 &&
201
- triggeredItem.detail.key === KeyboardKeys.ARROW_DOWN) {
202
- const nextItem = this._enabledItems[triggeringItemIndex + 1];
203
- if ((nextItem === null || nextItem === void 0 ? void 0 : nextItem.active) && nextItem.nextElementSibling) {
204
- newFocusedItem = nextItem.nextElementSibling;
205
- }
206
- else if (nextItem) {
207
- newFocusedItem = nextItem;
208
- }
209
- }
210
- if (newFocusedItem) {
211
- newFocusedItem.focus();
18
+ printTitle() {
19
+ if (this.menuTitle !== "undefined" &&
20
+ this.menuTitle.replace(/\s/g, "") !== "") {
21
+ return (h("header", { class: "menu__header" }, h("h1", { class: "menu__header__title" }, this.menuTitle)));
212
22
  }
213
23
  }
214
- /**
215
- * @description
216
- */
217
- startMouseOutTimeout() {
218
- this.mouseOutTimeout = setTimeout(() => {
219
- this.hidden = true;
220
- }, this._mouseOutDelay);
221
- }
222
- clearMouseOutTimeout() {
223
- clearTimeout(this.mouseOutTimeout);
224
- }
225
- /**
226
- * @description It renders the menu title, which is optional.
227
- */
228
- renderTitle() {
229
- return this.menuTitle ? (h("header", { class: "menu__header", part: "header" }, h("h1", { class: "menu__header__title", part: "title" }, this.menuTitle))) : null;
230
- }
231
- // 10.RENDER() FUNCTION //
232
24
  render() {
233
- return (h(Host, { tabindex: "-1" }, h("div", { class: {
234
- "outer-wrapper": true,
235
- }, style: {
236
- height: this._menuHeight,
237
- transitionDuration: `${this._transitionDuration}ms`,
238
- }, part: "outer-wrapper" }, h("div", { class: "inner-wrapper", ref: (el) => (this.innerWrapper = el), part: "inner-wrapper" }, this.renderTitle(), h("div", { class: "lists-wrapper", part: "lists-wrapper" }, h("slot", null))))));
25
+ return (h(Host, null, this.printTitle(), h("ul", { class: "menuList" }, h("slot", null))));
239
26
  }
240
27
  get el() { return getElement(this); }
241
- static get watchers() { return {
242
- "hidden": ["hiddenHandler"]
243
- }; }
244
28
  };
245
29
  GxgMenu.style = menuCss;
246
30