@genexus/genexus-ide-ui 0.0.43 → 0.0.45

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 +70 -8
  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 +3 -3
  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 +110 -10
  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 +2 -2
  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 +74 -10
  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 +3 -3
  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 +70 -8
  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 +3 -3
  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-597a1d43.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/new-kb/new-kb.d.ts +20 -2
  134. package/dist/types/components/object-selector/object-selector.d.ts +10 -6
  135. package/dist/types/components/team-dev-commit/team-dev-commit.d.ts +4 -0
  136. package/dist/types/components/team-dev-update/team-dev-update.d.ts +4 -0
  137. package/dist/types/components.d.ts +49 -21
  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-7a83018d.entry.js +0 -1
  156. package/dist/genexus-ide-ui/p-7a90def4.entry.js +0 -1
  157. package/dist/genexus-ide-ui/p-7c38776f.entry.js +0 -1
  158. package/dist/genexus-ide-ui/p-82228c39.entry.js +0 -1
  159. package/dist/genexus-ide-ui/p-8afbdbc9.entry.js +0 -1
  160. package/dist/genexus-ide-ui/p-a89c699c.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,111 @@
1
+ import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
2
+ import { c as commonClassesNames } from './classesNames.js';
3
+ import { K as KeyboardKeys } from './types.js';
4
+ import { d as defineCustomElement$3 } from './icon.js';
5
+ import { d as defineCustomElement$2 } from './icon2.js';
6
+
7
+ const itemCss = "/*! 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(.gxg--disabled) .form-element,:host(.gxg--disabled.form-element){pointer-events:none;background-color:var(--color-background-disabled) !important;color:var(--color-on-background--disabled) !important;border-color:var(--gxg-border-color--disabled) !important;cursor:default !important}:host .menu-item{position:relative}:host .menu-item:before{content:\"\";display:block;height:100%;width:2px;background-color:transparent;position:absolute}:host .menu-item--ellipsis .menu-item__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}:host .menu-item__button{all:unset;color:var(--color-on-background);padding:0 var(--spacing-comp-01);min-height:var(--gxg-list-item-height);width:100%;box-sizing:border-box;cursor:pointer;display:flex;align-items:center;gap:var(--spacing-comp-02);border-radius:var(--border-width-md);overflow:hidden}:host .menu-item__button:hover{background-color:var(--gxg-background-color-item-hover)}:host .menu-item__button:focus{outline-style:solid;outline-color:var(--color-primary-active);outline-width:var(--border-width-md);outline-offset:-2px}:host :menu-item--tab{font-weight:var(--font-weight-semibold)}:host([active]) .menu-item__button{color:var(--gxg-color-selected);background-color:var(--gxg-background-color-item-selected)}";
8
+
9
+ const GxgMenuSlimItem$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
10
+ constructor() {
11
+ super();
12
+ this.__registerHost();
13
+ this.__attachShadow();
14
+ this.keyboardNavigation = createEvent(this, "keyboardNavigation", 7);
15
+ this.itemSelected = createEvent(this, "itemSelected", 7);
16
+ /**
17
+ * Sets the item as active or not
18
+ */
19
+ this.active = false;
20
+ /**
21
+ * Prevents the the text from wrapping into more than one line, adding an ellipsis at the end. This property is set and inherited one the menu.
22
+ */
23
+ this.ellipsis = false;
24
+ /**
25
+ * Disables the item
26
+ */
27
+ this.disabled = false;
28
+ this.iconTypeColor = () => {
29
+ if (this.disabled) {
30
+ return "ondisabled";
31
+ }
32
+ else if (this.active) {
33
+ return "negative";
34
+ }
35
+ else {
36
+ return "disabled";
37
+ }
38
+ };
39
+ this.buttonClickedHandler = () => {
40
+ this.active = true;
41
+ this.itemSelected.emit({
42
+ id: this.itemId,
43
+ ref: this.el,
44
+ label: this.label,
45
+ iconType: this.iconType,
46
+ });
47
+ };
48
+ this.buttonKeyDownHandler = (e) => {
49
+ if (e.key === KeyboardKeys.ARROW_DOWN || e.key === KeyboardKeys.ARROW_UP) {
50
+ this.keyboardNavigation.emit({
51
+ ref: this.el,
52
+ key: e.key,
53
+ });
54
+ }
55
+ };
56
+ }
57
+ // 6.METHODS //
58
+ // 7.LISTENERS //
59
+ // 8.PUBLIC METHODS API //
60
+ // 9.LOCAL METHODS //
61
+ // 10.RENDER() FUNCTION //
62
+ renderIcon() {
63
+ return this.iconType ? (h("gxg-icon", { slot: "iconType", type: this.iconType, size: "small", color: this.iconTypeColor(), part: "icon" })) : null;
64
+ }
65
+ render() {
66
+ return (h(Host, { class: { [commonClassesNames["DISABLED_CLASS"]]: this.disabled } }, h("li", { class: {
67
+ "menu-item": true,
68
+ "menu-item--shorter": this.iconType !== undefined,
69
+ "menu-item--ellipsis": this.ellipsis,
70
+ [commonClassesNames["DISABLED_CLASS"]]: this.disabled,
71
+ }, ref: (el) => (this.listItem = el), part: "item" }, h("button", { class: "menu-item__button form-element", onClick: this.buttonClickedHandler, onKeyDown: this.buttonKeyDownHandler, part: "button" }, this.renderIcon(), h("span", { class: "menu-item__label", part: "label" }, this.label)))));
72
+ }
73
+ static get delegatesFocus() { return true; }
74
+ get el() { return this; }
75
+ static get style() { return itemCss; }
76
+ }, [17, "gxg-menu-slim-item", {
77
+ "label": [1],
78
+ "iconType": [1, "icon-type"],
79
+ "active": [516],
80
+ "itemId": [1, "item-id"],
81
+ "ellipsis": [4],
82
+ "disabled": [4]
83
+ }]);
84
+ function defineCustomElement$1() {
85
+ if (typeof customElements === "undefined") {
86
+ return;
87
+ }
88
+ const components = ["gxg-menu-slim-item", "ch-icon", "gxg-icon"];
89
+ components.forEach(tagName => { switch (tagName) {
90
+ case "gxg-menu-slim-item":
91
+ if (!customElements.get(tagName)) {
92
+ customElements.define(tagName, GxgMenuSlimItem$1);
93
+ }
94
+ break;
95
+ case "ch-icon":
96
+ if (!customElements.get(tagName)) {
97
+ defineCustomElement$3();
98
+ }
99
+ break;
100
+ case "gxg-icon":
101
+ if (!customElements.get(tagName)) {
102
+ defineCustomElement$2();
103
+ }
104
+ break;
105
+ } });
106
+ }
107
+
108
+ const GxgMenuSlimItem = GxgMenuSlimItem$1;
109
+ const defineCustomElement = defineCustomElement$1;
110
+
111
+ export { GxgMenuSlimItem, defineCustomElement };
@@ -0,0 +1,50 @@
1
+ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
+ import { d as defineCustomElement$2 } from './title.js';
3
+
4
+ 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}";
5
+
6
+ const GxgMenuSlimList$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
7
+ constructor() {
8
+ super();
9
+ this.__registerHost();
10
+ this.__attachShadow();
11
+ }
12
+ // 2. REFERENCE TO ELEMENTS //
13
+ // 3.STATE() VARIABLES //
14
+ // 4.PUBLIC PROPERTY API | WATCH'S //
15
+ // 5.EVENTS (EMIT) //
16
+ // 6.METHODS //
17
+ // 7.LISTENERS //
18
+ // 8.PUBLIC METHODS API //
19
+ // 9.LOCAL METHODS //
20
+ // 10.RENDER() FUNCTION //
21
+ render() {
22
+ 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)))));
23
+ }
24
+ static get style() { return listCss; }
25
+ }, [1, "gxg-menu-slim-list", {
26
+ "listTitle": [1, "list-title"]
27
+ }]);
28
+ function defineCustomElement$1() {
29
+ if (typeof customElements === "undefined") {
30
+ return;
31
+ }
32
+ const components = ["gxg-menu-slim-list", "gxg-title"];
33
+ components.forEach(tagName => { switch (tagName) {
34
+ case "gxg-menu-slim-list":
35
+ if (!customElements.get(tagName)) {
36
+ customElements.define(tagName, GxgMenuSlimList$1);
37
+ }
38
+ break;
39
+ case "gxg-title":
40
+ if (!customElements.get(tagName)) {
41
+ defineCustomElement$2();
42
+ }
43
+ break;
44
+ } });
45
+ }
46
+
47
+ const GxgMenuSlimList = GxgMenuSlimList$1;
48
+ const defineCustomElement = defineCustomElement$1;
49
+
50
+ export { GxgMenuSlimList, defineCustomElement };
@@ -0,0 +1,271 @@
1
+ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
+ import { K as KeyboardKeys } from './types.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$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
29
+ constructor() {
30
+ super();
31
+ this.__registerHost();
32
+ this.__attachShadow();
33
+ /*
34
+ INDEX:
35
+ 1.OWN PROPERTIES
36
+ 2.REFERENCE TO ELEMENTS
37
+ 3.STATE() VARIABLES
38
+ 4.PUBLIC PROPERTY API | WATCH'S
39
+ 5.EVENTS (EMIT)
40
+ 6.COMPONENT LIFECYCLE EVENTS
41
+ 7.LISTENERS
42
+ 8.PUBLIC METHODS API
43
+ 9.LOCAL METHODS
44
+ 10.RENDER() FUNCTION
45
+ */
46
+ // 1.OWN PROPERTIES //
47
+ this._menuHeight = "0px";
48
+ /**
49
+ * The delay in milliseconds that the menu will remain visible after mouseout event fires.
50
+ */
51
+ this._mouseOutDelay = 1000;
52
+ /**
53
+ * The menu height transition timing.
54
+ */
55
+ this._transitionDuration = 200;
56
+ /**
57
+ * The enabled (not disabled) menu items
58
+ */
59
+ this._enabledItems = [];
60
+ /**
61
+ * Hides or show the menu with an animation
62
+ */
63
+ this.hidden = true;
64
+ /**
65
+ * Hides the menu when an item is selected.
66
+ */
67
+ this.hideOnSelect = true;
68
+ /**
69
+ * Prevents the menu-item's text from wrapping into more than one line, adding an ellipsis at the end.
70
+ */
71
+ this.ellipsis = true;
72
+ // 8.PUBLIC METHODS API //
73
+ // 9.LOCAL METHODS //
74
+ this.setFocusFirstItem = () => {
75
+ const firstItem = this.el.querySelector("gxg-menu-slim-item");
76
+ firstItem.focus();
77
+ };
78
+ this.assignEllipsis = () => {
79
+ if (this.ellipsis) {
80
+ const items = this.el.querySelectorAll("gxg-menu-slim-item");
81
+ items &&
82
+ items.forEach((item) => {
83
+ item.ellipsis = true;
84
+ });
85
+ }
86
+ };
87
+ /*Mouse out handlers*/
88
+ this.attachMouseOut = () => {
89
+ this.el.addEventListener("mouseout", this.detectMouseOut);
90
+ };
91
+ this.removeMouseOut = () => {
92
+ this.el.removeEventListener("mouseout", this.detectMouseOut);
93
+ };
94
+ this.detectMouseOut = (e) => {
95
+ const nodeName = e.relatedTarget.nodeName;
96
+ if (nodeName !== "GXG-MENU" &&
97
+ nodeName !== "GXG-MENU-LIST" &&
98
+ nodeName !== "GXG-MENU-slim-ITEM") {
99
+ //Mouse out
100
+ this.startMouseOutTimeout();
101
+ }
102
+ };
103
+ /*Mouse enter handlers*/
104
+ this.attachMouseEnter = () => {
105
+ this.el.addEventListener("mouseenter", this.detectMouseEnter);
106
+ };
107
+ this.removeMouseEnter = () => {
108
+ this.el.removeEventListener("mouseenter", this.detectMouseEnter);
109
+ };
110
+ this.detectMouseEnter = () => {
111
+ //Mouse enter
112
+ this.clearMouseOutTimeout();
113
+ };
114
+ /*Detect click outside*/
115
+ this.attachDetectClickOutside = () => {
116
+ document.addEventListener("click", this.detectClickOutside);
117
+ };
118
+ this.removeDetectClickOutside = () => {
119
+ document.removeEventListener("click", this.detectClickOutside);
120
+ };
121
+ /*Detect click outside*/
122
+ this.detectClickOutside = (e) => {
123
+ const clickedOutside = detectClickOutside(e, this.el);
124
+ if (clickedOutside) {
125
+ this.hidden = true;
126
+ }
127
+ else {
128
+ this.hidden = false;
129
+ }
130
+ };
131
+ this.getEnabledItems = () => {
132
+ const enabledItems = this.el.querySelectorAll("gxg-menu-slim-item");
133
+ enabledItems.forEach((menuItem) => {
134
+ if (!menuItem.disabled) {
135
+ this._enabledItems.push(menuItem);
136
+ }
137
+ });
138
+ };
139
+ }
140
+ hiddenHandler(hidden) {
141
+ if (hidden) {
142
+ this._menuHeight = "0px";
143
+ this.el.setAttribute("tabindex", "-1");
144
+ this.removeDetectClickOutside();
145
+ this.removeMouseOut();
146
+ this.removeMouseEnter();
147
+ }
148
+ else {
149
+ this._menuHeight = this.innerWrapper.offsetHeight + "px";
150
+ this.el.removeAttribute("tabindex");
151
+ setTimeout(() => {
152
+ this.setFocusFirstItem();
153
+ this.attachDetectClickOutside();
154
+ this.attachMouseOut();
155
+ this.attachMouseEnter();
156
+ }, this._transitionDuration);
157
+ }
158
+ }
159
+ // 5.EVENTS (EMIT) //
160
+ // 6.COMPONENT LIFECYCLE EVENTS //
161
+ componentWillLoad() {
162
+ this.assignEllipsis();
163
+ /*Prevent this.mouseOutTimeout firing on page load*/
164
+ clearTimeout(this.mouseOutTimeout);
165
+ this.getEnabledItems();
166
+ }
167
+ componentDidUnload() {
168
+ this.removeDetectClickOutside();
169
+ this.removeMouseOut();
170
+ this.removeMouseEnter();
171
+ }
172
+ // 7.LISTENERS //
173
+ itemSelectedHandler(itemSelected) {
174
+ /*Remove 'active' from every item, except from the clicked one*/
175
+ const menuItems = Array.from(this.el.querySelectorAll("gxg-menu-slim-item"));
176
+ menuItems.forEach((menuItem) => {
177
+ if (itemSelected.detail.ref !== menuItem) {
178
+ menuItem.active = false;
179
+ }
180
+ });
181
+ /*Hide menu*/
182
+ if (this.hideOnSelect) {
183
+ this.hidden = true;
184
+ }
185
+ }
186
+ keyboardNavigationHandler(triggeredItem) {
187
+ const triggeringItem = triggeredItem.detail.ref;
188
+ const triggeringItemIndex = this._enabledItems.findIndex((item) => {
189
+ return item === triggeringItem;
190
+ });
191
+ let newFocusedItem;
192
+ if (triggeringItemIndex !== -1 &&
193
+ triggeredItem.detail.key === KeyboardKeys.ARROW_UP) {
194
+ const prevItem = this._enabledItems[triggeringItemIndex - 1];
195
+ if ((prevItem === null || prevItem === void 0 ? void 0 : prevItem.active) && prevItem.previousElementSibling) {
196
+ newFocusedItem = prevItem.previousElementSibling;
197
+ }
198
+ else if (prevItem) {
199
+ newFocusedItem = prevItem;
200
+ }
201
+ }
202
+ else if (triggeringItemIndex !== -1 &&
203
+ triggeredItem.detail.key === KeyboardKeys.ARROW_DOWN) {
204
+ const nextItem = this._enabledItems[triggeringItemIndex + 1];
205
+ if ((nextItem === null || nextItem === void 0 ? void 0 : nextItem.active) && nextItem.nextElementSibling) {
206
+ newFocusedItem = nextItem.nextElementSibling;
207
+ }
208
+ else if (nextItem) {
209
+ newFocusedItem = nextItem;
210
+ }
211
+ }
212
+ if (newFocusedItem) {
213
+ newFocusedItem.focus();
214
+ }
215
+ }
216
+ /**
217
+ * @description
218
+ */
219
+ startMouseOutTimeout() {
220
+ this.mouseOutTimeout = setTimeout(() => {
221
+ this.hidden = true;
222
+ }, this._mouseOutDelay);
223
+ }
224
+ clearMouseOutTimeout() {
225
+ clearTimeout(this.mouseOutTimeout);
226
+ }
227
+ /**
228
+ * @description It renders the menu title, which is optional.
229
+ */
230
+ renderTitle() {
231
+ return this.menuTitle ? (h("header", { class: "menu__header", part: "header" }, h("h1", { class: "menu__header__title", part: "title" }, this.menuTitle))) : null;
232
+ }
233
+ // 10.RENDER() FUNCTION //
234
+ render() {
235
+ return (h(Host, { tabindex: "-1" }, h("div", { class: {
236
+ "outer-wrapper": true,
237
+ }, style: {
238
+ height: this._menuHeight,
239
+ transitionDuration: `${this._transitionDuration}ms`,
240
+ }, 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))))));
241
+ }
242
+ get el() { return this; }
243
+ static get watchers() { return {
244
+ "hidden": ["hiddenHandler"]
245
+ }; }
246
+ static get style() { return menuCss; }
247
+ }, [1, "gxg-menu-slim", {
248
+ "menuTitle": [1, "menu-title"],
249
+ "tabs": [516],
250
+ "hidden": [4],
251
+ "hideOnSelect": [4, "hide-on-select"],
252
+ "ellipsis": [4]
253
+ }, [[0, "itemSelected", "itemSelectedHandler"], [0, "keyboardNavigation", "keyboardNavigationHandler"]]]);
254
+ function defineCustomElement$1() {
255
+ if (typeof customElements === "undefined") {
256
+ return;
257
+ }
258
+ const components = ["gxg-menu-slim"];
259
+ components.forEach(tagName => { switch (tagName) {
260
+ case "gxg-menu-slim":
261
+ if (!customElements.get(tagName)) {
262
+ customElements.define(tagName, GxgMenuSlim$1);
263
+ }
264
+ break;
265
+ } });
266
+ }
267
+
268
+ const GxgMenuSlim = GxgMenuSlim$1;
269
+ const defineCustomElement = defineCustomElement$1;
270
+
271
+ export { GxgMenuSlim, defineCustomElement };