@genexus/genexus-ide-ui 0.0.43 → 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 (164) 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 +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 +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 +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 +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 +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 +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 +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-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.d.ts +24 -12
  137. package/package.json +3 -3
  138. package/dist/cjs/ch-icon.cjs.entry.js +0 -116
  139. package/dist/cjs/gx-ide-container.cjs.entry.js +0 -137
  140. package/dist/cjs/gxg-menu-list.cjs.entry.js +0 -28
  141. package/dist/components/gxg-menu-list.js +0 -50
  142. package/dist/components/top-bar.js +0 -74
  143. package/dist/esm/ch-icon.entry.js +0 -112
  144. package/dist/esm/gx-ide-container.entry.js +0 -133
  145. package/dist/esm/gxg-menu-list.entry.js +0 -24
  146. package/dist/genexus-ide-ui/p-07e89cdd.entry.js +0 -1
  147. package/dist/genexus-ide-ui/p-1770fa36.entry.js +0 -1
  148. package/dist/genexus-ide-ui/p-179713ef.entry.js +0 -1
  149. package/dist/genexus-ide-ui/p-181ee8a8.entry.js +0 -1
  150. package/dist/genexus-ide-ui/p-35fc1102.entry.js +0 -1
  151. package/dist/genexus-ide-ui/p-4d39c34a.entry.js +0 -1
  152. package/dist/genexus-ide-ui/p-55d98662.entry.js +0 -1
  153. package/dist/genexus-ide-ui/p-5ad757f4.entry.js +0 -1
  154. package/dist/genexus-ide-ui/p-7a83018d.entry.js +0 -1
  155. package/dist/genexus-ide-ui/p-7a90def4.entry.js +0 -1
  156. package/dist/genexus-ide-ui/p-7c38776f.entry.js +0 -1
  157. package/dist/genexus-ide-ui/p-82228c39.entry.js +0 -1
  158. package/dist/genexus-ide-ui/p-8afbdbc9.entry.js +0 -1
  159. package/dist/genexus-ide-ui/p-a89c699c.entry.js +0 -1
  160. package/dist/genexus-ide-ui/p-cab184a7.entry.js +0 -1
  161. package/dist/genexus-ide-ui/p-d376dada.entry.js +0 -1
  162. /package/dist/node_modules/@genexus/gemini/dist/collection/components/{menu-item/menu-item.css → menu-slim/item/item.css} +0 -0
  163. /package/dist/node_modules/@genexus/gemini/dist/collection/components/{menu-list/menu-list.css → menu-slim/list/list.css} +0 -0
  164. /package/dist/node_modules/@genexus/gemini/dist/collection/components/{menu → menu-slim/menu}/menu.css +0 -0
@@ -3,75 +3,27 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  const index = require('./index-5a32426a.js');
6
- const classesNames = require('./classesNames-5b7c6ad4.js');
7
- const types = require('./types-e04c9098.js');
8
6
 
9
- const menuItemCss = "/*! 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)}";
7
+ const menuItemCss = "/*! 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 .menu-item{color:var(--color-on-background);position:relative}:host .menu-item:before{content:\"\";display:block;height:100%;width:2px;background-color:transparent;position:absolute}:host .menu-item__container{height:var(--spacing-comp-06);background-color:transparent;cursor:pointer;padding:0 var(--spacing-comp-05) 0 var(--spacing-comp-05);display:flex;align-items:center}:host .menu-item__container:hover{background-color:var(--gray-02)}:host .menu-item gxg-icon{margin-right:var(--spacing-comp-01)}:host :menu-item--tab{font-weight:var(--font-weight-semibold)}:host([active]) .menu-item:before{background-color:var(--gray-03)}";
10
8
 
11
9
  const GxgMenuItem = class {
12
10
  constructor(hostRef) {
13
11
  index.registerInstance(this, hostRef);
14
- this.keyboardNavigation = index.createEvent(this, "keyboardNavigation", 7);
15
- this.itemSelected = index.createEvent(this, "itemSelected", 7);
16
- /**
17
- * Sets the item as active or not
18
- */
12
+ this.menuItemActive = index.createEvent(this, "menuItemActive", 7);
13
+ this.icon = null;
19
14
  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 === types.KeyboardKeys.ARROW_DOWN || e.key === types.KeyboardKeys.ARROW_UP) {
50
- this.keyboardNavigation.emit({
51
- ref: this.el,
52
- key: e.key,
53
- });
54
- }
55
- };
56
15
  }
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 ? (index.h("gxg-icon", { slot: "iconType", type: this.iconType, size: "small", color: this.iconTypeColor(), part: "icon" })) : null;
16
+ includeIcon() {
17
+ if (this.icon !== null) {
18
+ return index.h("gxg-icon", { slot: "icon", type: this.icon, size: "small" });
19
+ }
20
+ }
21
+ setActive() {
22
+ this.menuItemActive.emit(this.label);
64
23
  }
65
24
  render() {
66
- return (index.h(index.Host, { class: { [classesNames.commonClassesNames["DISABLED_CLASS"]]: this.disabled } }, index.h("li", { class: {
67
- "menu-item": true,
68
- "menu-item--shorter": this.iconType !== undefined,
69
- "menu-item--ellipsis": this.ellipsis,
70
- [classesNames.commonClassesNames["DISABLED_CLASS"]]: this.disabled,
71
- }, ref: (el) => (this.listItem = el), part: "item" }, index.h("button", { class: "menu-item__button form-element", onClick: this.buttonClickedHandler, onKeyDown: this.buttonKeyDownHandler, part: "button" }, this.renderIcon(), index.h("span", { class: "menu-item__label", part: "label" }, this.label)))));
25
+ return (index.h(index.Host, { onClick: this.setActive.bind(this) }, index.h("li", { class: "menu-item", ref: (el) => (this.listItem = el) }, index.h("div", { class: "menu-item__container" }, this.includeIcon(), this.label))));
72
26
  }
73
- static get delegatesFocus() { return true; }
74
- get el() { return index.getElement(this); }
75
27
  };
76
28
  GxgMenuItem.style = menuItemCss;
77
29
 
@@ -0,0 +1,78 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-5a32426a.js');
6
+ const classesNames = require('./classesNames-5b7c6ad4.js');
7
+ const types = require('./types-e04c9098.js');
8
+
9
+ 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)}";
10
+
11
+ const GxgMenuSlimItem = class {
12
+ constructor(hostRef) {
13
+ index.registerInstance(this, hostRef);
14
+ this.keyboardNavigation = index.createEvent(this, "keyboardNavigation", 7);
15
+ this.itemSelected = index.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 === types.KeyboardKeys.ARROW_DOWN || e.key === types.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 ? (index.h("gxg-icon", { slot: "iconType", type: this.iconType, size: "small", color: this.iconTypeColor(), part: "icon" })) : null;
64
+ }
65
+ render() {
66
+ return (index.h(index.Host, { class: { [classesNames.commonClassesNames["DISABLED_CLASS"]]: this.disabled } }, index.h("li", { class: {
67
+ "menu-item": true,
68
+ "menu-item--shorter": this.iconType !== undefined,
69
+ "menu-item--ellipsis": this.ellipsis,
70
+ [classesNames.commonClassesNames["DISABLED_CLASS"]]: this.disabled,
71
+ }, ref: (el) => (this.listItem = el), part: "item" }, index.h("button", { class: "menu-item__button form-element", onClick: this.buttonClickedHandler, onKeyDown: this.buttonKeyDownHandler, part: "button" }, this.renderIcon(), index.h("span", { class: "menu-item__label", part: "label" }, this.label)))));
72
+ }
73
+ static get delegatesFocus() { return true; }
74
+ get el() { return index.getElement(this); }
75
+ };
76
+ GxgMenuSlimItem.style = itemCss;
77
+
78
+ exports.gxg_menu_slim_item = GxgMenuSlimItem;
@@ -0,0 +1,28 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-5a32426a.js');
6
+
7
+ 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}";
8
+
9
+ const GxgMenuSlimList = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ }
13
+ // 2. REFERENCE TO ELEMENTS //
14
+ // 3.STATE() VARIABLES //
15
+ // 4.PUBLIC PROPERTY API | WATCH'S //
16
+ // 5.EVENTS (EMIT) //
17
+ // 6.METHODS //
18
+ // 7.LISTENERS //
19
+ // 8.PUBLIC METHODS API //
20
+ // 9.LOCAL METHODS //
21
+ // 10.RENDER() FUNCTION //
22
+ render() {
23
+ return (index.h(index.Host, null, index.h("div", { class: "wrapper", part: "wrapper" }, this.listTitle ? (index.h("span", { class: "title-wrapper", part: "title-wrapper" }, index.h("gxg-title", { type: "title-05", part: "title" }, this.listTitle))) : null, index.h("ul", { part: "list" }, index.h("slot", null)))));
24
+ }
25
+ };
26
+ GxgMenuSlimList.style = listCss;
27
+
28
+ exports.gxg_menu_slim_list = GxgMenuSlimList;
@@ -0,0 +1,251 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-5a32426a.js');
6
+ const types = require('./types-e04c9098.js');
7
+
8
+ const detectClickOutside = (event, element) => {
9
+ const x = event.x;
10
+ const y = event.y;
11
+ //Contextual menu coordinates
12
+ const elementBoundingClientRect = element.getBoundingClientRect();
13
+ if ((x > elementBoundingClientRect.left &&
14
+ x < elementBoundingClientRect.right &&
15
+ y > elementBoundingClientRect.top &&
16
+ y < elementBoundingClientRect.bottom) ||
17
+ (event.screenX === 0 &&
18
+ event.screenY === 0 &&
19
+ event.clientX === 0 &&
20
+ event.clientY === 0)) {
21
+ //Click happened inside the element
22
+ return false;
23
+ }
24
+ else {
25
+ //Click happened outside the element
26
+ return true;
27
+ }
28
+ };
29
+
30
+ 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}";
31
+
32
+ const GxgMenuSlim = class {
33
+ constructor(hostRef) {
34
+ index.registerInstance(this, hostRef);
35
+ /*
36
+ INDEX:
37
+ 1.OWN PROPERTIES
38
+ 2.REFERENCE TO ELEMENTS
39
+ 3.STATE() VARIABLES
40
+ 4.PUBLIC PROPERTY API | WATCH'S
41
+ 5.EVENTS (EMIT)
42
+ 6.COMPONENT LIFECYCLE EVENTS
43
+ 7.LISTENERS
44
+ 8.PUBLIC METHODS API
45
+ 9.LOCAL METHODS
46
+ 10.RENDER() FUNCTION
47
+ */
48
+ // 1.OWN PROPERTIES //
49
+ this._menuHeight = "0px";
50
+ /**
51
+ * The delay in milliseconds that the menu will remain visible after mouseout event fires.
52
+ */
53
+ this._mouseOutDelay = 1000;
54
+ /**
55
+ * The menu height transition timing.
56
+ */
57
+ this._transitionDuration = 200;
58
+ /**
59
+ * The enabled (not disabled) menu items
60
+ */
61
+ this._enabledItems = [];
62
+ /**
63
+ * Hides or show the menu with an animation
64
+ */
65
+ this.hidden = true;
66
+ /**
67
+ * Hides the menu when an item is selected.
68
+ */
69
+ this.hideOnSelect = true;
70
+ /**
71
+ * Prevents the menu-item's text from wrapping into more than one line, adding an ellipsis at the end.
72
+ */
73
+ this.ellipsis = true;
74
+ // 8.PUBLIC METHODS API //
75
+ // 9.LOCAL METHODS //
76
+ this.setFocusFirstItem = () => {
77
+ const firstItem = this.el.querySelector("gxg-menu-slim-item");
78
+ firstItem.focus();
79
+ };
80
+ this.assignEllipsis = () => {
81
+ if (this.ellipsis) {
82
+ const items = this.el.querySelectorAll("gxg-menu-slim-item");
83
+ items &&
84
+ items.forEach((item) => {
85
+ item.ellipsis = true;
86
+ });
87
+ }
88
+ };
89
+ /*Mouse out handlers*/
90
+ this.attachMouseOut = () => {
91
+ this.el.addEventListener("mouseout", this.detectMouseOut);
92
+ };
93
+ this.removeMouseOut = () => {
94
+ this.el.removeEventListener("mouseout", this.detectMouseOut);
95
+ };
96
+ this.detectMouseOut = (e) => {
97
+ const nodeName = e.relatedTarget.nodeName;
98
+ if (nodeName !== "GXG-MENU" &&
99
+ nodeName !== "GXG-MENU-LIST" &&
100
+ nodeName !== "GXG-MENU-slim-ITEM") {
101
+ //Mouse out
102
+ this.startMouseOutTimeout();
103
+ }
104
+ };
105
+ /*Mouse enter handlers*/
106
+ this.attachMouseEnter = () => {
107
+ this.el.addEventListener("mouseenter", this.detectMouseEnter);
108
+ };
109
+ this.removeMouseEnter = () => {
110
+ this.el.removeEventListener("mouseenter", this.detectMouseEnter);
111
+ };
112
+ this.detectMouseEnter = () => {
113
+ //Mouse enter
114
+ this.clearMouseOutTimeout();
115
+ };
116
+ /*Detect click outside*/
117
+ this.attachDetectClickOutside = () => {
118
+ document.addEventListener("click", this.detectClickOutside);
119
+ };
120
+ this.removeDetectClickOutside = () => {
121
+ document.removeEventListener("click", this.detectClickOutside);
122
+ };
123
+ /*Detect click outside*/
124
+ this.detectClickOutside = (e) => {
125
+ const clickedOutside = detectClickOutside(e, this.el);
126
+ if (clickedOutside) {
127
+ this.hidden = true;
128
+ }
129
+ else {
130
+ this.hidden = false;
131
+ }
132
+ };
133
+ this.getEnabledItems = () => {
134
+ const enabledItems = this.el.querySelectorAll("gxg-menu-slim-item");
135
+ enabledItems.forEach((menuItem) => {
136
+ if (!menuItem.disabled) {
137
+ this._enabledItems.push(menuItem);
138
+ }
139
+ });
140
+ };
141
+ }
142
+ hiddenHandler(hidden) {
143
+ if (hidden) {
144
+ this._menuHeight = "0px";
145
+ this.el.setAttribute("tabindex", "-1");
146
+ this.removeDetectClickOutside();
147
+ this.removeMouseOut();
148
+ this.removeMouseEnter();
149
+ }
150
+ else {
151
+ this._menuHeight = this.innerWrapper.offsetHeight + "px";
152
+ this.el.removeAttribute("tabindex");
153
+ setTimeout(() => {
154
+ this.setFocusFirstItem();
155
+ this.attachDetectClickOutside();
156
+ this.attachMouseOut();
157
+ this.attachMouseEnter();
158
+ }, this._transitionDuration);
159
+ }
160
+ }
161
+ // 5.EVENTS (EMIT) //
162
+ // 6.COMPONENT LIFECYCLE EVENTS //
163
+ componentWillLoad() {
164
+ this.assignEllipsis();
165
+ /*Prevent this.mouseOutTimeout firing on page load*/
166
+ clearTimeout(this.mouseOutTimeout);
167
+ this.getEnabledItems();
168
+ }
169
+ componentDidUnload() {
170
+ this.removeDetectClickOutside();
171
+ this.removeMouseOut();
172
+ this.removeMouseEnter();
173
+ }
174
+ // 7.LISTENERS //
175
+ itemSelectedHandler(itemSelected) {
176
+ /*Remove 'active' from every item, except from the clicked one*/
177
+ const menuItems = Array.from(this.el.querySelectorAll("gxg-menu-slim-item"));
178
+ menuItems.forEach((menuItem) => {
179
+ if (itemSelected.detail.ref !== menuItem) {
180
+ menuItem.active = false;
181
+ }
182
+ });
183
+ /*Hide menu*/
184
+ if (this.hideOnSelect) {
185
+ this.hidden = true;
186
+ }
187
+ }
188
+ keyboardNavigationHandler(triggeredItem) {
189
+ const triggeringItem = triggeredItem.detail.ref;
190
+ const triggeringItemIndex = this._enabledItems.findIndex((item) => {
191
+ return item === triggeringItem;
192
+ });
193
+ let newFocusedItem;
194
+ if (triggeringItemIndex !== -1 &&
195
+ triggeredItem.detail.key === types.KeyboardKeys.ARROW_UP) {
196
+ const prevItem = this._enabledItems[triggeringItemIndex - 1];
197
+ if ((prevItem === null || prevItem === void 0 ? void 0 : prevItem.active) && prevItem.previousElementSibling) {
198
+ newFocusedItem = prevItem.previousElementSibling;
199
+ }
200
+ else if (prevItem) {
201
+ newFocusedItem = prevItem;
202
+ }
203
+ }
204
+ else if (triggeringItemIndex !== -1 &&
205
+ triggeredItem.detail.key === types.KeyboardKeys.ARROW_DOWN) {
206
+ const nextItem = this._enabledItems[triggeringItemIndex + 1];
207
+ if ((nextItem === null || nextItem === void 0 ? void 0 : nextItem.active) && nextItem.nextElementSibling) {
208
+ newFocusedItem = nextItem.nextElementSibling;
209
+ }
210
+ else if (nextItem) {
211
+ newFocusedItem = nextItem;
212
+ }
213
+ }
214
+ if (newFocusedItem) {
215
+ newFocusedItem.focus();
216
+ }
217
+ }
218
+ /**
219
+ * @description
220
+ */
221
+ startMouseOutTimeout() {
222
+ this.mouseOutTimeout = setTimeout(() => {
223
+ this.hidden = true;
224
+ }, this._mouseOutDelay);
225
+ }
226
+ clearMouseOutTimeout() {
227
+ clearTimeout(this.mouseOutTimeout);
228
+ }
229
+ /**
230
+ * @description It renders the menu title, which is optional.
231
+ */
232
+ renderTitle() {
233
+ return this.menuTitle ? (index.h("header", { class: "menu__header", part: "header" }, index.h("h1", { class: "menu__header__title", part: "title" }, this.menuTitle))) : null;
234
+ }
235
+ // 10.RENDER() FUNCTION //
236
+ render() {
237
+ return (index.h(index.Host, { tabindex: "-1" }, index.h("div", { class: {
238
+ "outer-wrapper": true,
239
+ }, style: {
240
+ height: this._menuHeight,
241
+ transitionDuration: `${this._transitionDuration}ms`,
242
+ }, part: "outer-wrapper" }, index.h("div", { class: "inner-wrapper", ref: (el) => (this.innerWrapper = el), part: "inner-wrapper" }, this.renderTitle(), index.h("div", { class: "lists-wrapper", part: "lists-wrapper" }, index.h("slot", null))))));
243
+ }
244
+ get el() { return index.getElement(this); }
245
+ static get watchers() { return {
246
+ "hidden": ["hiddenHandler"]
247
+ }; }
248
+ };
249
+ GxgMenuSlim.style = menuCss;
250
+
251
+ exports.gxg_menu_slim = GxgMenuSlim;