@genexus/genexus-ide-ui 1.1.5 → 1.1.7

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 (699) hide show
  1. package/dist/cjs/{code-render-0e9837c4.js → code-render-55d37767.js} +3 -3
  2. package/dist/cjs/code-render-55d37767.js.map +1 -0
  3. package/dist/cjs/{form-validation-ffe2b957.js → form-validation-178cf461.js} +3 -7
  4. package/dist/cjs/form-validation-178cf461.js.map +1 -0
  5. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  6. package/dist/cjs/gx-ide-about.cjs.entry.js +1 -1
  7. package/dist/cjs/gx-ide-ai-assistant.cjs.entry.js +15 -9
  8. package/dist/cjs/gx-ide-ai-assistant.cjs.entry.js.map +1 -1
  9. package/dist/cjs/gx-ide-ai-message.cjs.entry.js +2 -2
  10. package/dist/cjs/gx-ide-bpm-app-declaration.cjs.entry.js +4 -3
  11. package/dist/cjs/gx-ide-bpm-app-declaration.cjs.entry.js.map +1 -1
  12. package/dist/cjs/gx-ide-bpm-assign-roles.cjs.entry.js +1 -1
  13. package/dist/cjs/gx-ide-bpm-export-xpdl.cjs.entry.js +5 -3
  14. package/dist/cjs/gx-ide-bpm-export-xpdl.cjs.entry.js.map +1 -1
  15. package/dist/cjs/gx-ide-bpm-import-files.cjs.entry.js +3 -2
  16. package/dist/cjs/gx-ide-bpm-import-files.cjs.entry.js.map +1 -1
  17. package/dist/cjs/gx-ide-bpm-import-gxpm.cjs.entry.js +1 -1
  18. package/dist/cjs/gx-ide-bpm-objects-selector.cjs.entry.js +1 -1
  19. package/dist/cjs/gx-ide-bpm-sync-gam-roles.cjs.entry.js +3 -2
  20. package/dist/cjs/gx-ide-bpm-sync-gam-roles.cjs.entry.js.map +1 -1
  21. package/dist/cjs/gx-ide-bpm-task-documents.cjs.entry.js +11 -9
  22. package/dist/cjs/gx-ide-bpm-task-documents.cjs.entry.js.map +1 -1
  23. package/dist/cjs/gx-ide-bpm-timer-duration.cjs.entry.js +3 -2
  24. package/dist/cjs/gx-ide-bpm-timer-duration.cjs.entry.js.map +1 -1
  25. package/dist/cjs/gx-ide-card.cjs.entry.js +1 -1
  26. package/dist/cjs/gx-ide-chat-container_2.cjs.entry.js +1 -1
  27. package/dist/cjs/gx-ide-connect-gx-server.cjs.entry.js +23 -18
  28. package/dist/cjs/gx-ide-connect-gx-server.cjs.entry.js.map +1 -1
  29. package/dist/cjs/gx-ide-container_2.cjs.entry.js +2 -1
  30. package/dist/cjs/gx-ide-container_2.cjs.entry.js.map +1 -1
  31. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js +10 -6
  32. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js.map +1 -1
  33. package/dist/cjs/gx-ide-current-user-info.cjs.entry.js +4 -3
  34. package/dist/cjs/gx-ide-current-user-info.cjs.entry.js.map +1 -1
  35. package/dist/cjs/gx-ide-dashboard-home.cjs.entry.js +5 -4
  36. package/dist/cjs/gx-ide-dashboard-home.cjs.entry.js.map +1 -1
  37. package/dist/cjs/gx-ide-data-selector.cjs.entry.js +4 -3
  38. package/dist/cjs/gx-ide-data-selector.cjs.entry.js.map +1 -1
  39. package/dist/cjs/gx-ide-data-type-selector.cjs.entry.js +5 -4
  40. package/dist/cjs/gx-ide-data-type-selector.cjs.entry.js.map +1 -1
  41. package/dist/cjs/gx-ide-deployment-tool.cjs.entry.js +20 -16
  42. package/dist/cjs/gx-ide-deployment-tool.cjs.entry.js.map +1 -1
  43. package/dist/cjs/gx-ide-design-import.cjs.entry.js +29 -21
  44. package/dist/cjs/gx-ide-design-import.cjs.entry.js.map +1 -1
  45. package/dist/cjs/gx-ide-directory-selector.cjs.entry.js +2 -1
  46. package/dist/cjs/gx-ide-directory-selector.cjs.entry.js.map +1 -1
  47. package/dist/cjs/gx-ide-edit-module-server.cjs.entry.js +3 -2
  48. package/dist/cjs/gx-ide-edit-module-server.cjs.entry.js.map +1 -1
  49. package/dist/cjs/gx-ide-entity-selector.cjs.entry.js +5 -3
  50. package/dist/cjs/gx-ide-entity-selector.cjs.entry.js.map +1 -1
  51. package/dist/cjs/gx-ide-file-uploader.cjs.entry.js +45 -60
  52. package/dist/cjs/gx-ide-file-uploader.cjs.entry.js.map +1 -1
  53. package/dist/cjs/gx-ide-gam-installation-settings.cjs.entry.js +3 -2
  54. package/dist/cjs/gx-ide-gam-installation-settings.cjs.entry.js.map +1 -1
  55. package/dist/cjs/gx-ide-kb-manager-export.cjs.entry.js +1 -1
  56. package/dist/cjs/gx-ide-kb-manager-import.cjs.entry.js +8 -5
  57. package/dist/cjs/gx-ide-kb-manager-import.cjs.entry.js.map +1 -1
  58. package/dist/cjs/gx-ide-list-selector_2.cjs.entry.js +1 -1
  59. package/dist/cjs/gx-ide-list-selector_2.cjs.entry.js.map +1 -1
  60. package/dist/cjs/gx-ide-manage-module-references-v2.cjs.entry.js +5 -14
  61. package/dist/cjs/gx-ide-manage-module-references-v2.cjs.entry.js.map +1 -1
  62. package/dist/cjs/gx-ide-manage-module-references.cjs.entry.js +3 -3
  63. package/dist/cjs/gx-ide-manage-module-references.cjs.entry.js.map +1 -1
  64. package/dist/cjs/gx-ide-navigation-report.cjs.entry.js +7 -4
  65. package/dist/cjs/gx-ide-navigation-report.cjs.entry.js.map +1 -1
  66. package/dist/cjs/gx-ide-new-environment.cjs.entry.js +18 -13
  67. package/dist/cjs/gx-ide-new-environment.cjs.entry.js.map +1 -1
  68. package/dist/cjs/gx-ide-new-kb.cjs.entry.js +35 -31
  69. package/dist/cjs/gx-ide-new-kb.cjs.entry.js.map +1 -1
  70. package/dist/cjs/gx-ide-new-object.cjs.entry.js +9 -6
  71. package/dist/cjs/gx-ide-new-object.cjs.entry.js.map +1 -1
  72. package/dist/cjs/gx-ide-new-version.cjs.entry.js +61 -17
  73. package/dist/cjs/gx-ide-new-version.cjs.entry.js.map +1 -1
  74. package/dist/cjs/gx-ide-object-selector.cjs.entry.js +7 -6
  75. package/dist/cjs/gx-ide-object-selector.cjs.entry.js.map +1 -1
  76. package/dist/cjs/gx-ide-open-api-import.cjs.entry.js +9 -5
  77. package/dist/cjs/gx-ide-open-api-import.cjs.entry.js.map +1 -1
  78. package/dist/cjs/gx-ide-references.cjs.entry.js +23 -18
  79. package/dist/cjs/gx-ide-references.cjs.entry.js.map +1 -1
  80. package/dist/cjs/gx-ide-sc-chat-container.cjs.entry.js +1 -1
  81. package/dist/cjs/gx-ide-select-kb-items.cjs.entry.js +29 -16
  82. package/dist/cjs/gx-ide-select-kb-items.cjs.entry.js.map +1 -1
  83. package/dist/cjs/gx-ide-select-user-team.cjs.entry.js +4 -3
  84. package/dist/cjs/gx-ide-select-user-team.cjs.entry.js.map +1 -1
  85. package/dist/cjs/gx-ide-share-kb.cjs.entry.js +7 -4
  86. package/dist/cjs/gx-ide-share-kb.cjs.entry.js.map +1 -1
  87. package/dist/cjs/gx-ide-sign-in-team.cjs.entry.js +3 -2
  88. package/dist/cjs/gx-ide-sign-in-team.cjs.entry.js.map +1 -1
  89. package/dist/cjs/gx-ide-sign-in.cjs.entry.js +1 -1
  90. package/dist/cjs/gx-ide-splash.cjs.entry.js +4 -3
  91. package/dist/cjs/gx-ide-splash.cjs.entry.js.map +1 -1
  92. package/dist/cjs/gx-ide-start-page.cjs.entry.js +7 -4
  93. package/dist/cjs/gx-ide-start-page.cjs.entry.js.map +1 -1
  94. package/dist/cjs/gx-ide-status-buttons.cjs.entry.js +1 -1
  95. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js +4 -4
  96. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js.map +1 -1
  97. package/dist/cjs/gx-ide-team-dev-history.cjs.entry.js +270 -0
  98. package/dist/cjs/gx-ide-team-dev-history.cjs.entry.js.map +1 -0
  99. package/dist/cjs/gx-ide-team-dev-select-recent-comment.cjs.entry.js +1 -1
  100. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js +2 -2
  101. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js.map +1 -1
  102. package/dist/cjs/gx-ide-team-dev-update-to-revision.cjs.entry.js +1 -1
  103. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js +4 -3
  104. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js.map +1 -1
  105. package/dist/cjs/gx-ide-template.cjs.entry.js +1 -1
  106. package/dist/cjs/gx-ide-welcome-page.cjs.entry.js +8 -6
  107. package/dist/cjs/gx-ide-welcome-page.cjs.entry.js.map +1 -1
  108. package/dist/cjs/gx-ide-wf-settings.cjs.entry.js +1 -1
  109. package/dist/cjs/gx-ide-ww-attributes.cjs.entry.js +14 -8
  110. package/dist/cjs/gx-ide-ww-attributes.cjs.entry.js.map +1 -1
  111. package/dist/cjs/gx-ide-ww-files.cjs.entry.js +21 -18
  112. package/dist/cjs/gx-ide-ww-files.cjs.entry.js.map +1 -1
  113. package/dist/cjs/gx-ide-ww-images.cjs.entry.js +7 -18
  114. package/dist/cjs/gx-ide-ww-images.cjs.entry.js.map +1 -1
  115. package/dist/cjs/{helpers-e5a13fa5.js → helpers-30f109a4.js} +6 -6
  116. package/dist/cjs/helpers-30f109a4.js.map +1 -0
  117. package/dist/cjs/index.cjs.js +7 -1
  118. package/dist/cjs/index.cjs.js.map +1 -1
  119. package/dist/cjs/loader.cjs.js +1 -1
  120. package/dist/cjs/{locale-36b93b1b.js → locale-ff30a5f3.js} +4 -4
  121. package/dist/cjs/locale-ff30a5f3.js.map +1 -0
  122. package/dist/collection/collection-manifest.json +1 -0
  123. package/dist/collection/common/common.js +7 -4
  124. package/dist/collection/common/common.js.map +1 -1
  125. package/dist/collection/common/form-validation.js +4 -7
  126. package/dist/collection/common/form-validation.js.map +1 -1
  127. package/dist/collection/common/helpers.js +10 -9
  128. package/dist/collection/common/helpers.js.map +1 -1
  129. package/dist/collection/common/images/ai-avatar.svg +11 -0
  130. package/dist/collection/common/locale.js +3 -3
  131. package/dist/collection/common/locale.js.map +1 -1
  132. package/dist/collection/common/render-suggest.js +1 -1
  133. package/dist/collection/common/render-suggest.js.map +1 -1
  134. package/dist/collection/components/_helpers/container/container.js +2 -1
  135. package/dist/collection/components/_helpers/container/container.js.map +1 -1
  136. package/dist/collection/components/_helpers/directory-selector/directory-selector.js +2 -1
  137. package/dist/collection/components/_helpers/directory-selector/directory-selector.js.map +1 -1
  138. package/dist/collection/components/_helpers/entity-selector/entity-selector.js +4 -2
  139. package/dist/collection/components/_helpers/entity-selector/entity-selector.js.map +1 -1
  140. package/dist/collection/components/_helpers/list-selector/list-selector-item/list-selector-item.js +1 -1
  141. package/dist/collection/components/_helpers/list-selector/list-selector-item/list-selector-item.js.map +1 -1
  142. package/dist/collection/components/ai-assistant/ai-assistant.js +14 -8
  143. package/dist/collection/components/ai-assistant/ai-assistant.js.map +1 -1
  144. package/dist/collection/components/bpm/application-declaration/bpm-app-declaration.js +3 -2
  145. package/dist/collection/components/bpm/application-declaration/bpm-app-declaration.js.map +1 -1
  146. package/dist/collection/components/bpm/export-xpdl/bpm-export-xpdl.js +4 -2
  147. package/dist/collection/components/bpm/export-xpdl/bpm-export-xpdl.js.map +1 -1
  148. package/dist/collection/components/bpm/import-files/bpm-import-files.js +2 -1
  149. package/dist/collection/components/bpm/import-files/bpm-import-files.js.map +1 -1
  150. package/dist/collection/components/bpm/sync-gam-roles/bpm-sync-gam-roles.js +2 -1
  151. package/dist/collection/components/bpm/sync-gam-roles/bpm-sync-gam-roles.js.map +1 -1
  152. package/dist/collection/components/bpm/task-documents/helpers.js +1 -1
  153. package/dist/collection/components/bpm/task-documents/helpers.js.map +1 -1
  154. package/dist/collection/components/bpm/task-documents/task-documents.js +9 -7
  155. package/dist/collection/components/bpm/task-documents/task-documents.js.map +1 -1
  156. package/dist/collection/components/bpm/timer-duration/bpm-timer-duration.js +2 -1
  157. package/dist/collection/components/bpm/timer-duration/bpm-timer-duration.js.map +1 -1
  158. package/dist/collection/components/chat/code-render.js +2 -2
  159. package/dist/collection/components/chat/code-render.js.map +1 -1
  160. package/dist/collection/components/current-user-info/current-user-info.js +3 -2
  161. package/dist/collection/components/current-user-info/current-user-info.js.map +1 -1
  162. package/dist/collection/components/dashboard-home/dashboard-home.js +3 -2
  163. package/dist/collection/components/dashboard-home/dashboard-home.js.map +1 -1
  164. package/dist/collection/components/data-selector/data-selector.js +3 -2
  165. package/dist/collection/components/data-selector/data-selector.js.map +1 -1
  166. package/dist/collection/components/data-type-selector/data-type-selector.js +4 -3
  167. package/dist/collection/components/data-type-selector/data-type-selector.js.map +1 -1
  168. package/dist/collection/components/deployment-tool/deployment-tool.js +18 -11
  169. package/dist/collection/components/deployment-tool/deployment-tool.js.map +1 -1
  170. package/dist/collection/components/deployment-tool/helpers.js +1 -4
  171. package/dist/collection/components/deployment-tool/helpers.js.map +1 -1
  172. package/dist/collection/components/design-import/design-import.js +27 -19
  173. package/dist/collection/components/design-import/design-import.js.map +1 -1
  174. package/dist/collection/components/design-import/helpers.js +1 -1
  175. package/dist/collection/components/design-import/helpers.js.map +1 -1
  176. package/dist/collection/components/file-uploader/file-uploader.js +44 -59
  177. package/dist/collection/components/file-uploader/file-uploader.js.map +1 -1
  178. package/dist/collection/components/gam-installation-settings/gam-installation-settings.js +2 -1
  179. package/dist/collection/components/gam-installation-settings/gam-installation-settings.js.map +1 -1
  180. package/dist/collection/components/kb-manager-import/kb-manager-import.js +7 -4
  181. package/dist/collection/components/kb-manager-import/kb-manager-import.js.map +1 -1
  182. package/dist/collection/components/modules/edit-module-server/edit-module-server.js +2 -1
  183. package/dist/collection/components/modules/edit-module-server/edit-module-server.js.map +1 -1
  184. package/dist/collection/components/modules/manage-module-references/manage-module-references.js +2 -2
  185. package/dist/collection/components/modules/manage-module-references/manage-module-references.js.map +1 -1
  186. package/dist/collection/components/modules/manage-module-references-v2/manage-module-references-v2.js +4 -13
  187. package/dist/collection/components/modules/manage-module-references-v2/manage-module-references-v2.js.map +1 -1
  188. package/dist/collection/components/navigation-report/navigation-report.js +6 -3
  189. package/dist/collection/components/navigation-report/navigation-report.js.map +1 -1
  190. package/dist/collection/components/new-environment/new-environment.js +15 -10
  191. package/dist/collection/components/new-environment/new-environment.js.map +1 -1
  192. package/dist/collection/components/new-kb/new-kb.js +32 -28
  193. package/dist/collection/components/new-kb/new-kb.js.map +1 -1
  194. package/dist/collection/components/new-object/new-object.js +8 -5
  195. package/dist/collection/components/new-object/new-object.js.map +1 -1
  196. package/dist/collection/components/new-version/gx-ide-assets/new-version/langs/new-version.lang.en.json +3 -1
  197. package/dist/collection/components/new-version/gx-ide-assets/new-version/langs/new-version.lang.ja.json +3 -1
  198. package/dist/collection/components/new-version/gx-ide-assets/new-version/langs/new-version.lang.zh.json +3 -1
  199. package/dist/collection/components/new-version/new-version.css +4 -0
  200. package/dist/collection/components/new-version/new-version.js +126 -20
  201. package/dist/collection/components/new-version/new-version.js.map +1 -1
  202. package/dist/collection/components/object-selector/object-selector.js +5 -4
  203. package/dist/collection/components/object-selector/object-selector.js.map +1 -1
  204. package/dist/collection/components/open-api-import/open-api-import.js +8 -4
  205. package/dist/collection/components/open-api-import/open-api-import.js.map +1 -1
  206. package/dist/collection/components/references/helpers.js +13 -9
  207. package/dist/collection/components/references/helpers.js.map +1 -1
  208. package/dist/collection/components/references/references.js +11 -9
  209. package/dist/collection/components/references/references.js.map +1 -1
  210. package/dist/collection/components/select-kb-items/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.en.json +2 -1
  211. package/dist/collection/components/select-kb-items/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.ja.json +1 -0
  212. package/dist/collection/components/select-kb-items/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.zh.json +1 -0
  213. package/dist/collection/components/select-kb-items/helpers.js +10 -5
  214. package/dist/collection/components/select-kb-items/helpers.js.map +1 -1
  215. package/dist/collection/components/select-kb-items/select-kb-items.css +22 -27
  216. package/dist/collection/components/select-kb-items/select-kb-items.js +36 -9
  217. package/dist/collection/components/select-kb-items/select-kb-items.js.map +1 -1
  218. package/dist/collection/components/select-user-team/helpers.js +1 -1
  219. package/dist/collection/components/select-user-team/helpers.js.map +1 -1
  220. package/dist/collection/components/select-user-team/select-user-team.js +2 -1
  221. package/dist/collection/components/select-user-team/select-user-team.js.map +1 -1
  222. package/dist/collection/components/sign-in-team/sign-in-team.js +2 -1
  223. package/dist/collection/components/sign-in-team/sign-in-team.js.map +1 -1
  224. package/dist/collection/components/splash/splash.js +3 -2
  225. package/dist/collection/components/splash/splash.js.map +1 -1
  226. package/dist/collection/components/start-page/start-page.js +6 -3
  227. package/dist/collection/components/start-page/start-page.js.map +1 -1
  228. package/dist/collection/components/team-dev/commit/commit.js +2 -2
  229. package/dist/collection/components/team-dev/commit/commit.js.map +1 -1
  230. package/dist/collection/components/team-dev/connect-gx-server/connect-gx-server.js +21 -16
  231. package/dist/collection/components/team-dev/connect-gx-server/connect-gx-server.js.map +1 -1
  232. package/dist/collection/components/team-dev/create-kb-from-server/create-kb-from-server.js +8 -4
  233. package/dist/collection/components/team-dev/create-kb-from-server/create-kb-from-server.js.map +1 -1
  234. package/dist/collection/components/team-dev/history/gx-ide-assets/team-dev-history/langs/team-dev-history.lang.en.json +42 -0
  235. package/dist/collection/components/team-dev/history/gx-ide-assets/team-dev-history/langs/team-dev-history.lang.ja.json +42 -0
  236. package/dist/collection/components/team-dev/history/gx-ide-assets/team-dev-history/langs/team-dev-history.lang.zh.json +42 -0
  237. package/dist/collection/components/team-dev/history/helpers.js +22 -0
  238. package/dist/collection/components/team-dev/history/helpers.js.map +1 -0
  239. package/dist/collection/components/team-dev/history/history.css +124 -0
  240. package/dist/collection/components/team-dev/history/history.js +448 -0
  241. package/dist/collection/components/team-dev/history/history.js.map +1 -0
  242. package/dist/collection/components/team-dev/share-kb/share-kb.js +5 -2
  243. package/dist/collection/components/team-dev/share-kb/share-kb.js.map +1 -1
  244. package/dist/collection/components/team-dev/update/update.js +2 -1
  245. package/dist/collection/components/team-dev/update/update.js.map +1 -1
  246. package/dist/collection/components/team-dev/update-partial-selection/update-partial-selection.js +1 -1
  247. package/dist/collection/components/team-dev/update-partial-selection/update-partial-selection.js.map +1 -1
  248. package/dist/collection/components/welcome-page/welcome-page.js +7 -5
  249. package/dist/collection/components/welcome-page/welcome-page.js.map +1 -1
  250. package/dist/collection/components/ww-attributes/helpers.js +2 -1
  251. package/dist/collection/components/ww-attributes/helpers.js.map +1 -1
  252. package/dist/collection/components/ww-attributes/ww-attributes.js +11 -6
  253. package/dist/collection/components/ww-attributes/ww-attributes.js.map +1 -1
  254. package/dist/collection/components/ww-files/helpers.js +2 -1
  255. package/dist/collection/components/ww-files/helpers.js.map +1 -1
  256. package/dist/collection/components/ww-files/ww-files.js +18 -16
  257. package/dist/collection/components/ww-files/ww-files.js.map +1 -1
  258. package/dist/collection/components/ww-images/ww-images.js +5 -16
  259. package/dist/collection/components/ww-images/ww-images.js.map +1 -1
  260. package/dist/collection/index.js +4 -0
  261. package/dist/collection/index.js.map +1 -1
  262. package/dist/collection/testing/locale.e2e.js +4 -3
  263. package/dist/collection/testing/locale.e2e.js.map +1 -1
  264. package/dist/components/code-render.js +2 -2
  265. package/dist/components/code-render.js.map +1 -1
  266. package/dist/components/container.js +2 -1
  267. package/dist/components/container.js.map +1 -1
  268. package/dist/components/entity-selector.js +4 -2
  269. package/dist/components/entity-selector.js.map +1 -1
  270. package/dist/components/form-validation.js +2 -6
  271. package/dist/components/form-validation.js.map +1 -1
  272. package/dist/components/gx-ide-ai-assistant.js +14 -8
  273. package/dist/components/gx-ide-ai-assistant.js.map +1 -1
  274. package/dist/components/gx-ide-bpm-app-declaration.js +3 -2
  275. package/dist/components/gx-ide-bpm-app-declaration.js.map +1 -1
  276. package/dist/components/gx-ide-bpm-export-xpdl.js +4 -2
  277. package/dist/components/gx-ide-bpm-export-xpdl.js.map +1 -1
  278. package/dist/components/gx-ide-bpm-import-files.js +2 -1
  279. package/dist/components/gx-ide-bpm-import-files.js.map +1 -1
  280. package/dist/components/gx-ide-bpm-sync-gam-roles.js +2 -1
  281. package/dist/components/gx-ide-bpm-sync-gam-roles.js.map +1 -1
  282. package/dist/components/gx-ide-bpm-task-documents.js +10 -8
  283. package/dist/components/gx-ide-bpm-task-documents.js.map +1 -1
  284. package/dist/components/gx-ide-bpm-timer-duration.js +2 -1
  285. package/dist/components/gx-ide-bpm-timer-duration.js.map +1 -1
  286. package/dist/components/gx-ide-connect-gx-server.js +21 -16
  287. package/dist/components/gx-ide-connect-gx-server.js.map +1 -1
  288. package/dist/components/gx-ide-create-kb-from-server.js +8 -4
  289. package/dist/components/gx-ide-create-kb-from-server.js.map +1 -1
  290. package/dist/components/gx-ide-current-user-info.js +3 -2
  291. package/dist/components/gx-ide-current-user-info.js.map +1 -1
  292. package/dist/components/gx-ide-dashboard-home.js +3 -2
  293. package/dist/components/gx-ide-dashboard-home.js.map +1 -1
  294. package/dist/components/gx-ide-data-selector.js +3 -2
  295. package/dist/components/gx-ide-data-selector.js.map +1 -1
  296. package/dist/components/gx-ide-data-type-selector.js +4 -3
  297. package/dist/components/gx-ide-data-type-selector.js.map +1 -1
  298. package/dist/components/gx-ide-deployment-tool.js +19 -15
  299. package/dist/components/gx-ide-deployment-tool.js.map +1 -1
  300. package/dist/components/gx-ide-design-import.js +28 -20
  301. package/dist/components/gx-ide-design-import.js.map +1 -1
  302. package/dist/components/gx-ide-directory-selector.js +2 -1
  303. package/dist/components/gx-ide-directory-selector.js.map +1 -1
  304. package/dist/components/gx-ide-edit-module-server.js +2 -1
  305. package/dist/components/gx-ide-edit-module-server.js.map +1 -1
  306. package/dist/components/gx-ide-file-uploader.js +44 -59
  307. package/dist/components/gx-ide-file-uploader.js.map +1 -1
  308. package/dist/components/gx-ide-gam-installation-settings.js +2 -1
  309. package/dist/components/gx-ide-gam-installation-settings.js.map +1 -1
  310. package/dist/components/gx-ide-kb-manager-import.js +7 -4
  311. package/dist/components/gx-ide-kb-manager-import.js.map +1 -1
  312. package/dist/components/gx-ide-manage-module-references-v2.js +4 -13
  313. package/dist/components/gx-ide-manage-module-references-v2.js.map +1 -1
  314. package/dist/components/gx-ide-manage-module-references.js +2 -2
  315. package/dist/components/gx-ide-manage-module-references.js.map +1 -1
  316. package/dist/components/gx-ide-navigation-report.js +6 -3
  317. package/dist/components/gx-ide-navigation-report.js.map +1 -1
  318. package/dist/components/gx-ide-new-environment.js +15 -10
  319. package/dist/components/gx-ide-new-environment.js.map +1 -1
  320. package/dist/components/gx-ide-new-kb.js +32 -28
  321. package/dist/components/gx-ide-new-kb.js.map +1 -1
  322. package/dist/components/gx-ide-new-object.js +8 -5
  323. package/dist/components/gx-ide-new-object.js.map +1 -1
  324. package/dist/components/gx-ide-new-version.js +67 -17
  325. package/dist/components/gx-ide-new-version.js.map +1 -1
  326. package/dist/components/gx-ide-object-selector.js +5 -4
  327. package/dist/components/gx-ide-object-selector.js.map +1 -1
  328. package/dist/components/gx-ide-open-api-import.js +8 -4
  329. package/dist/components/gx-ide-open-api-import.js.map +1 -1
  330. package/dist/components/gx-ide-references.js +22 -17
  331. package/dist/components/gx-ide-references.js.map +1 -1
  332. package/dist/components/gx-ide-select-kb-items.js +1 -501
  333. package/dist/components/gx-ide-select-kb-items.js.map +1 -1
  334. package/dist/components/gx-ide-select-user-team.js +3 -2
  335. package/dist/components/gx-ide-select-user-team.js.map +1 -1
  336. package/dist/components/gx-ide-share-kb.js +5 -2
  337. package/dist/components/gx-ide-share-kb.js.map +1 -1
  338. package/dist/components/gx-ide-sign-in-team.js +2 -1
  339. package/dist/components/gx-ide-sign-in-team.js.map +1 -1
  340. package/dist/components/gx-ide-splash.js +3 -2
  341. package/dist/components/gx-ide-splash.js.map +1 -1
  342. package/dist/components/gx-ide-start-page.js +6 -3
  343. package/dist/components/gx-ide-start-page.js.map +1 -1
  344. package/dist/components/gx-ide-team-dev-commit.js +2 -2
  345. package/dist/components/gx-ide-team-dev-commit.js.map +1 -1
  346. package/dist/components/gx-ide-team-dev-history.d.ts +11 -0
  347. package/dist/components/gx-ide-team-dev-history.js +322 -0
  348. package/dist/components/gx-ide-team-dev-history.js.map +1 -0
  349. package/dist/components/gx-ide-team-dev-update-partial-selection.js +1 -1
  350. package/dist/components/gx-ide-team-dev-update-partial-selection.js.map +1 -1
  351. package/dist/components/gx-ide-team-dev-update.js +2 -1
  352. package/dist/components/gx-ide-team-dev-update.js.map +1 -1
  353. package/dist/components/gx-ide-welcome-page.js +7 -5
  354. package/dist/components/gx-ide-welcome-page.js.map +1 -1
  355. package/dist/components/gx-ide-ww-attributes.js +13 -7
  356. package/dist/components/gx-ide-ww-attributes.js.map +1 -1
  357. package/dist/components/gx-ide-ww-files.js +20 -17
  358. package/dist/components/gx-ide-ww-files.js.map +1 -1
  359. package/dist/components/gx-ide-ww-images.js +5 -16
  360. package/dist/components/gx-ide-ww-images.js.map +1 -1
  361. package/dist/components/helpers.js +5 -5
  362. package/dist/components/helpers.js.map +1 -1
  363. package/dist/components/index.js +6 -0
  364. package/dist/components/index.js.map +1 -1
  365. package/dist/components/list-selector-item.js +1 -1
  366. package/dist/components/list-selector-item.js.map +1 -1
  367. package/dist/components/locale.js +3 -3
  368. package/dist/components/locale.js.map +1 -1
  369. package/dist/components/select-kb-items.js +520 -0
  370. package/dist/components/select-kb-items.js.map +1 -0
  371. package/dist/esm/{code-render-f3afd300.js → code-render-53b3b0bd.js} +3 -3
  372. package/dist/esm/code-render-53b3b0bd.js.map +1 -0
  373. package/dist/esm/{form-validation-71dca8c6.js → form-validation-cd0215c6.js} +3 -7
  374. package/dist/{genexus-ide-ui/p-549b8f0c.js.map → esm/form-validation-cd0215c6.js.map} +1 -1
  375. package/dist/esm/genexus-ide-ui.js +1 -1
  376. package/dist/esm/gx-ide-about.entry.js +1 -1
  377. package/dist/esm/gx-ide-ai-assistant.entry.js +15 -9
  378. package/dist/esm/gx-ide-ai-assistant.entry.js.map +1 -1
  379. package/dist/esm/gx-ide-ai-message.entry.js +2 -2
  380. package/dist/esm/gx-ide-bpm-app-declaration.entry.js +4 -3
  381. package/dist/esm/gx-ide-bpm-app-declaration.entry.js.map +1 -1
  382. package/dist/esm/gx-ide-bpm-assign-roles.entry.js +1 -1
  383. package/dist/esm/gx-ide-bpm-export-xpdl.entry.js +5 -3
  384. package/dist/esm/gx-ide-bpm-export-xpdl.entry.js.map +1 -1
  385. package/dist/esm/gx-ide-bpm-import-files.entry.js +3 -2
  386. package/dist/esm/gx-ide-bpm-import-files.entry.js.map +1 -1
  387. package/dist/esm/gx-ide-bpm-import-gxpm.entry.js +1 -1
  388. package/dist/esm/gx-ide-bpm-objects-selector.entry.js +1 -1
  389. package/dist/esm/gx-ide-bpm-sync-gam-roles.entry.js +3 -2
  390. package/dist/esm/gx-ide-bpm-sync-gam-roles.entry.js.map +1 -1
  391. package/dist/esm/gx-ide-bpm-task-documents.entry.js +11 -9
  392. package/dist/esm/gx-ide-bpm-task-documents.entry.js.map +1 -1
  393. package/dist/esm/gx-ide-bpm-timer-duration.entry.js +3 -2
  394. package/dist/esm/gx-ide-bpm-timer-duration.entry.js.map +1 -1
  395. package/dist/esm/gx-ide-card.entry.js +1 -1
  396. package/dist/esm/gx-ide-chat-container_2.entry.js +1 -1
  397. package/dist/esm/gx-ide-connect-gx-server.entry.js +23 -18
  398. package/dist/esm/gx-ide-connect-gx-server.entry.js.map +1 -1
  399. package/dist/esm/gx-ide-container_2.entry.js +2 -1
  400. package/dist/esm/gx-ide-container_2.entry.js.map +1 -1
  401. package/dist/esm/gx-ide-create-kb-from-server.entry.js +10 -6
  402. package/dist/esm/gx-ide-create-kb-from-server.entry.js.map +1 -1
  403. package/dist/esm/gx-ide-current-user-info.entry.js +4 -3
  404. package/dist/esm/gx-ide-current-user-info.entry.js.map +1 -1
  405. package/dist/esm/gx-ide-dashboard-home.entry.js +5 -4
  406. package/dist/esm/gx-ide-dashboard-home.entry.js.map +1 -1
  407. package/dist/esm/gx-ide-data-selector.entry.js +4 -3
  408. package/dist/esm/gx-ide-data-selector.entry.js.map +1 -1
  409. package/dist/esm/gx-ide-data-type-selector.entry.js +5 -4
  410. package/dist/esm/gx-ide-data-type-selector.entry.js.map +1 -1
  411. package/dist/esm/gx-ide-deployment-tool.entry.js +20 -16
  412. package/dist/esm/gx-ide-deployment-tool.entry.js.map +1 -1
  413. package/dist/esm/gx-ide-design-import.entry.js +29 -21
  414. package/dist/esm/gx-ide-design-import.entry.js.map +1 -1
  415. package/dist/esm/gx-ide-directory-selector.entry.js +2 -1
  416. package/dist/esm/gx-ide-directory-selector.entry.js.map +1 -1
  417. package/dist/esm/gx-ide-edit-module-server.entry.js +3 -2
  418. package/dist/esm/gx-ide-edit-module-server.entry.js.map +1 -1
  419. package/dist/esm/gx-ide-entity-selector.entry.js +5 -3
  420. package/dist/esm/gx-ide-entity-selector.entry.js.map +1 -1
  421. package/dist/esm/gx-ide-file-uploader.entry.js +45 -60
  422. package/dist/esm/gx-ide-file-uploader.entry.js.map +1 -1
  423. package/dist/esm/gx-ide-gam-installation-settings.entry.js +3 -2
  424. package/dist/esm/gx-ide-gam-installation-settings.entry.js.map +1 -1
  425. package/dist/esm/gx-ide-kb-manager-export.entry.js +1 -1
  426. package/dist/esm/gx-ide-kb-manager-import.entry.js +8 -5
  427. package/dist/esm/gx-ide-kb-manager-import.entry.js.map +1 -1
  428. package/dist/esm/gx-ide-list-selector_2.entry.js +1 -1
  429. package/dist/esm/gx-ide-list-selector_2.entry.js.map +1 -1
  430. package/dist/esm/gx-ide-manage-module-references-v2.entry.js +5 -14
  431. package/dist/esm/gx-ide-manage-module-references-v2.entry.js.map +1 -1
  432. package/dist/esm/gx-ide-manage-module-references.entry.js +3 -3
  433. package/dist/esm/gx-ide-manage-module-references.entry.js.map +1 -1
  434. package/dist/esm/gx-ide-navigation-report.entry.js +7 -4
  435. package/dist/esm/gx-ide-navigation-report.entry.js.map +1 -1
  436. package/dist/esm/gx-ide-new-environment.entry.js +18 -13
  437. package/dist/esm/gx-ide-new-environment.entry.js.map +1 -1
  438. package/dist/esm/gx-ide-new-kb.entry.js +35 -31
  439. package/dist/esm/gx-ide-new-kb.entry.js.map +1 -1
  440. package/dist/esm/gx-ide-new-object.entry.js +9 -6
  441. package/dist/esm/gx-ide-new-object.entry.js.map +1 -1
  442. package/dist/esm/gx-ide-new-version.entry.js +61 -17
  443. package/dist/esm/gx-ide-new-version.entry.js.map +1 -1
  444. package/dist/esm/gx-ide-object-selector.entry.js +7 -6
  445. package/dist/esm/gx-ide-object-selector.entry.js.map +1 -1
  446. package/dist/esm/gx-ide-open-api-import.entry.js +9 -5
  447. package/dist/esm/gx-ide-open-api-import.entry.js.map +1 -1
  448. package/dist/esm/gx-ide-references.entry.js +23 -18
  449. package/dist/esm/gx-ide-references.entry.js.map +1 -1
  450. package/dist/esm/gx-ide-sc-chat-container.entry.js +1 -1
  451. package/dist/esm/gx-ide-select-kb-items.entry.js +29 -16
  452. package/dist/esm/gx-ide-select-kb-items.entry.js.map +1 -1
  453. package/dist/esm/gx-ide-select-user-team.entry.js +4 -3
  454. package/dist/esm/gx-ide-select-user-team.entry.js.map +1 -1
  455. package/dist/esm/gx-ide-share-kb.entry.js +7 -4
  456. package/dist/esm/gx-ide-share-kb.entry.js.map +1 -1
  457. package/dist/esm/gx-ide-sign-in-team.entry.js +3 -2
  458. package/dist/esm/gx-ide-sign-in-team.entry.js.map +1 -1
  459. package/dist/esm/gx-ide-sign-in.entry.js +1 -1
  460. package/dist/esm/gx-ide-splash.entry.js +4 -3
  461. package/dist/esm/gx-ide-splash.entry.js.map +1 -1
  462. package/dist/esm/gx-ide-start-page.entry.js +7 -4
  463. package/dist/esm/gx-ide-start-page.entry.js.map +1 -1
  464. package/dist/esm/gx-ide-status-buttons.entry.js +1 -1
  465. package/dist/esm/gx-ide-team-dev-commit.entry.js +4 -4
  466. package/dist/esm/gx-ide-team-dev-commit.entry.js.map +1 -1
  467. package/dist/esm/gx-ide-team-dev-history.entry.js +266 -0
  468. package/dist/esm/gx-ide-team-dev-history.entry.js.map +1 -0
  469. package/dist/esm/gx-ide-team-dev-select-recent-comment.entry.js +1 -1
  470. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js +2 -2
  471. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js.map +1 -1
  472. package/dist/esm/gx-ide-team-dev-update-to-revision.entry.js +1 -1
  473. package/dist/esm/gx-ide-team-dev-update.entry.js +4 -3
  474. package/dist/esm/gx-ide-team-dev-update.entry.js.map +1 -1
  475. package/dist/esm/gx-ide-template.entry.js +1 -1
  476. package/dist/esm/gx-ide-welcome-page.entry.js +8 -6
  477. package/dist/esm/gx-ide-welcome-page.entry.js.map +1 -1
  478. package/dist/esm/gx-ide-wf-settings.entry.js +1 -1
  479. package/dist/esm/gx-ide-ww-attributes.entry.js +14 -8
  480. package/dist/esm/gx-ide-ww-attributes.entry.js.map +1 -1
  481. package/dist/esm/gx-ide-ww-files.entry.js +21 -18
  482. package/dist/esm/gx-ide-ww-files.entry.js.map +1 -1
  483. package/dist/esm/gx-ide-ww-images.entry.js +7 -18
  484. package/dist/esm/gx-ide-ww-images.entry.js.map +1 -1
  485. package/dist/esm/{helpers-5f1c9a32.js → helpers-10479d69.js} +6 -6
  486. package/dist/esm/helpers-10479d69.js.map +1 -0
  487. package/dist/esm/index.js +7 -1
  488. package/dist/esm/index.js.map +1 -1
  489. package/dist/esm/loader.js +1 -1
  490. package/dist/esm/{locale-643afe17.js → locale-e5107fad.js} +4 -4
  491. package/dist/esm/locale-e5107fad.js.map +1 -0
  492. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  493. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
  494. package/dist/genexus-ide-ui/gx-ide-assets/new-version/langs/new-version.lang.en.json +3 -1
  495. package/dist/genexus-ide-ui/gx-ide-assets/new-version/langs/new-version.lang.ja.json +3 -1
  496. package/dist/genexus-ide-ui/gx-ide-assets/new-version/langs/new-version.lang.zh.json +3 -1
  497. package/dist/genexus-ide-ui/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.en.json +2 -1
  498. package/dist/genexus-ide-ui/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.ja.json +1 -0
  499. package/dist/genexus-ide-ui/gx-ide-assets/select-kb-items/langs/select-kb-items.lang.zh.json +1 -0
  500. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-history/langs/team-dev-history.lang.en.json +42 -0
  501. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-history/langs/team-dev-history.lang.ja.json +42 -0
  502. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-history/langs/team-dev-history.lang.zh.json +42 -0
  503. package/dist/genexus-ide-ui/index.esm.js +7 -1
  504. package/dist/genexus-ide-ui/index.esm.js.map +1 -1
  505. package/dist/genexus-ide-ui/{p-11dccb8f.entry.js → p-01d96378.entry.js} +16 -17
  506. package/dist/genexus-ide-ui/p-01d96378.entry.js.map +1 -0
  507. package/dist/genexus-ide-ui/{p-75e1aa31.entry.js → p-036d005d.entry.js} +5 -4
  508. package/dist/genexus-ide-ui/p-036d005d.entry.js.map +1 -0
  509. package/dist/genexus-ide-ui/{p-f5a48b33.entry.js → p-04205aa4.entry.js} +6 -5
  510. package/dist/genexus-ide-ui/p-04205aa4.entry.js.map +1 -0
  511. package/dist/genexus-ide-ui/{p-f6ceb01a.entry.js → p-04c6bd23.entry.js} +29 -28
  512. package/dist/genexus-ide-ui/p-04c6bd23.entry.js.map +1 -0
  513. package/dist/genexus-ide-ui/{p-f52bcdac.entry.js → p-0550fd5f.entry.js} +2 -2
  514. package/dist/genexus-ide-ui/{p-e1d75f00.entry.js → p-05b04291.entry.js} +2 -2
  515. package/dist/genexus-ide-ui/{p-e1d75f00.entry.js.map → p-05b04291.entry.js.map} +1 -1
  516. package/dist/genexus-ide-ui/{p-a6029d9a.entry.js → p-0acf517c.entry.js} +129 -117
  517. package/dist/genexus-ide-ui/p-0acf517c.entry.js.map +1 -0
  518. package/dist/genexus-ide-ui/{p-bfd9066c.entry.js → p-0bdf34f2.entry.js} +4 -6
  519. package/dist/genexus-ide-ui/p-0bdf34f2.entry.js.map +1 -0
  520. package/dist/genexus-ide-ui/{p-2be58a7a.entry.js → p-14165308.entry.js} +2 -2
  521. package/dist/genexus-ide-ui/{p-7cedb0f0.entry.js → p-1bc2613e.entry.js} +69 -66
  522. package/dist/genexus-ide-ui/p-1bc2613e.entry.js.map +1 -0
  523. package/dist/genexus-ide-ui/{p-c5cca204.entry.js → p-1c7ea1cb.entry.js} +11 -10
  524. package/dist/genexus-ide-ui/p-1c7ea1cb.entry.js.map +1 -0
  525. package/dist/genexus-ide-ui/{p-daa29451.entry.js → p-1dd7be84.entry.js} +17 -14
  526. package/dist/genexus-ide-ui/p-1dd7be84.entry.js.map +1 -0
  527. package/dist/genexus-ide-ui/{p-549b8f0c.js → p-289c3290.js} +15 -16
  528. package/dist/genexus-ide-ui/p-289c3290.js.map +1 -0
  529. package/dist/genexus-ide-ui/{p-032b4a81.entry.js → p-29c69938.entry.js} +22 -19
  530. package/dist/genexus-ide-ui/p-29c69938.entry.js.map +1 -0
  531. package/dist/genexus-ide-ui/{p-db4f756a.entry.js → p-3085add2.entry.js} +188 -176
  532. package/dist/genexus-ide-ui/p-3085add2.entry.js.map +1 -0
  533. package/dist/genexus-ide-ui/{p-857866f8.js → p-311eedf3.js} +9 -8
  534. package/dist/genexus-ide-ui/p-311eedf3.js.map +1 -0
  535. package/dist/genexus-ide-ui/{p-2e90a13a.entry.js → p-31beae9e.entry.js} +3 -2
  536. package/dist/genexus-ide-ui/p-31beae9e.entry.js.map +1 -0
  537. package/dist/genexus-ide-ui/{p-e37e95e7.entry.js → p-34fd4875.entry.js} +5 -20
  538. package/dist/genexus-ide-ui/p-34fd4875.entry.js.map +1 -0
  539. package/dist/genexus-ide-ui/{p-9a39e49c.entry.js → p-35f9ebbc.entry.js} +2 -2
  540. package/dist/genexus-ide-ui/{p-db4750ff.entry.js → p-385c9544.entry.js} +147 -138
  541. package/dist/genexus-ide-ui/p-385c9544.entry.js.map +1 -0
  542. package/dist/genexus-ide-ui/{p-8f1f4126.entry.js → p-3da8db15.entry.js} +9 -9
  543. package/dist/genexus-ide-ui/p-3da8db15.entry.js.map +1 -0
  544. package/dist/genexus-ide-ui/{p-b1833747.entry.js → p-4538dea5.entry.js} +31 -26
  545. package/dist/genexus-ide-ui/p-4538dea5.entry.js.map +1 -0
  546. package/dist/genexus-ide-ui/{p-6dc05a27.entry.js → p-45996535.entry.js} +4 -3
  547. package/dist/genexus-ide-ui/p-45996535.entry.js.map +1 -0
  548. package/dist/genexus-ide-ui/{p-4d929210.entry.js → p-4b38fffc.entry.js} +2 -2
  549. package/dist/genexus-ide-ui/{p-d1cc4724.entry.js → p-4d0ba4f6.entry.js} +8 -15
  550. package/dist/genexus-ide-ui/p-4d0ba4f6.entry.js.map +1 -0
  551. package/dist/genexus-ide-ui/{p-66d9269a.entry.js → p-4e943649.entry.js} +19 -16
  552. package/dist/genexus-ide-ui/p-4e943649.entry.js.map +1 -0
  553. package/dist/genexus-ide-ui/{p-ec01c70c.entry.js → p-67e0b419.entry.js} +7 -6
  554. package/dist/genexus-ide-ui/p-67e0b419.entry.js.map +1 -0
  555. package/dist/genexus-ide-ui/{p-45d2fa91.entry.js → p-68969051.entry.js} +12 -11
  556. package/dist/genexus-ide-ui/p-68969051.entry.js.map +1 -0
  557. package/dist/genexus-ide-ui/{p-9b238bf7.entry.js → p-690942cb.entry.js} +178 -173
  558. package/dist/genexus-ide-ui/p-690942cb.entry.js.map +1 -0
  559. package/dist/genexus-ide-ui/{p-b211bca8.entry.js → p-6b957e82.entry.js} +2 -2
  560. package/dist/genexus-ide-ui/{p-be794132.entry.js → p-6f898249.entry.js} +233 -228
  561. package/dist/genexus-ide-ui/p-6f898249.entry.js.map +1 -0
  562. package/dist/genexus-ide-ui/{p-29575656.entry.js → p-704499e5.entry.js} +116 -107
  563. package/dist/genexus-ide-ui/p-704499e5.entry.js.map +1 -0
  564. package/dist/genexus-ide-ui/p-74715731.entry.js +541 -0
  565. package/dist/genexus-ide-ui/p-74715731.entry.js.map +1 -0
  566. package/dist/genexus-ide-ui/{p-ac0438d6.entry.js → p-767e0f6d.entry.js} +12 -11
  567. package/dist/genexus-ide-ui/p-767e0f6d.entry.js.map +1 -0
  568. package/dist/genexus-ide-ui/{p-6168d48c.entry.js → p-7abe2214.entry.js} +167 -160
  569. package/dist/genexus-ide-ui/p-7abe2214.entry.js.map +1 -0
  570. package/dist/genexus-ide-ui/{p-50eaa96d.entry.js → p-7d8812b0.entry.js} +99 -89
  571. package/dist/genexus-ide-ui/p-7d8812b0.entry.js.map +1 -0
  572. package/dist/genexus-ide-ui/p-80c1ddc3.entry.js +218 -0
  573. package/dist/genexus-ide-ui/p-80c1ddc3.entry.js.map +1 -0
  574. package/dist/genexus-ide-ui/{p-9c690c36.entry.js → p-88c81f18.entry.js} +13 -12
  575. package/dist/genexus-ide-ui/p-88c81f18.entry.js.map +1 -0
  576. package/dist/genexus-ide-ui/{p-5e05f830.entry.js → p-8cb937b7.entry.js} +35 -31
  577. package/dist/genexus-ide-ui/p-8cb937b7.entry.js.map +1 -0
  578. package/dist/genexus-ide-ui/p-9ddea83b.js +146 -0
  579. package/dist/genexus-ide-ui/p-9ddea83b.js.map +1 -0
  580. package/dist/genexus-ide-ui/{p-0e53f1ef.entry.js → p-a1415a9c.entry.js} +161 -159
  581. package/dist/genexus-ide-ui/p-a1415a9c.entry.js.map +1 -0
  582. package/dist/genexus-ide-ui/{p-c30b2104.entry.js → p-a47d71eb.entry.js} +11 -9
  583. package/dist/genexus-ide-ui/p-a47d71eb.entry.js.map +1 -0
  584. package/dist/genexus-ide-ui/{p-2dbf722d.entry.js → p-a8d0b62e.entry.js} +192 -172
  585. package/dist/genexus-ide-ui/p-a8d0b62e.entry.js.map +1 -0
  586. package/dist/genexus-ide-ui/{p-f315c6e0.entry.js → p-aab809c4.entry.js} +2 -2
  587. package/dist/genexus-ide-ui/{p-f5879a41.entry.js → p-b1851e6b.entry.js} +3 -3
  588. package/dist/genexus-ide-ui/{p-f5879a41.entry.js.map → p-b1851e6b.entry.js.map} +1 -1
  589. package/dist/genexus-ide-ui/{p-95f831a8.entry.js → p-b2928645.entry.js} +2 -2
  590. package/dist/genexus-ide-ui/{p-39c527ff.entry.js → p-b58fb87b.entry.js} +2 -2
  591. package/dist/genexus-ide-ui/{p-a86a8692.entry.js → p-c38ce0bf.entry.js} +36 -32
  592. package/dist/genexus-ide-ui/p-c38ce0bf.entry.js.map +1 -0
  593. package/dist/genexus-ide-ui/{p-3edbf07d.js → p-c5178973.js} +3 -3
  594. package/dist/genexus-ide-ui/{p-3edbf07d.js.map → p-c5178973.js.map} +1 -1
  595. package/dist/genexus-ide-ui/{p-0d83a34d.entry.js → p-c7badbf1.entry.js} +66 -62
  596. package/dist/genexus-ide-ui/p-c7badbf1.entry.js.map +1 -0
  597. package/dist/genexus-ide-ui/{p-8b046b4b.entry.js → p-d095a37c.entry.js} +10 -9
  598. package/dist/genexus-ide-ui/p-d095a37c.entry.js.map +1 -0
  599. package/dist/genexus-ide-ui/{p-353810b8.entry.js → p-d3767a7d.entry.js} +104 -99
  600. package/dist/genexus-ide-ui/p-d3767a7d.entry.js.map +1 -0
  601. package/dist/genexus-ide-ui/{p-02fc47cd.entry.js → p-d8379699.entry.js} +2 -2
  602. package/dist/genexus-ide-ui/{p-cdf8b082.entry.js → p-da473001.entry.js} +2 -2
  603. package/dist/genexus-ide-ui/{p-501c7b1f.entry.js → p-de7f0c1f.entry.js} +22 -19
  604. package/dist/genexus-ide-ui/p-de7f0c1f.entry.js.map +1 -0
  605. package/dist/genexus-ide-ui/{p-5da3e999.entry.js → p-ded7444c.entry.js} +17 -16
  606. package/dist/genexus-ide-ui/p-ded7444c.entry.js.map +1 -0
  607. package/dist/genexus-ide-ui/{p-9a9ee1ee.entry.js → p-e24902a0.entry.js} +2 -2
  608. package/dist/genexus-ide-ui/{p-5a42428d.entry.js → p-e28e6bc4.entry.js} +15 -14
  609. package/dist/genexus-ide-ui/p-e28e6bc4.entry.js.map +1 -0
  610. package/dist/genexus-ide-ui/{p-7782e1b8.entry.js → p-e502c2fd.entry.js} +61 -56
  611. package/dist/genexus-ide-ui/p-e502c2fd.entry.js.map +1 -0
  612. package/dist/genexus-ide-ui/{p-f2bd9044.entry.js → p-e7fb3ee3.entry.js} +2 -2
  613. package/dist/genexus-ide-ui/{p-e5571f49.entry.js → p-eb9e760d.entry.js} +18 -18
  614. package/dist/genexus-ide-ui/p-eb9e760d.entry.js.map +1 -0
  615. package/dist/genexus-ide-ui/{p-eb51429c.entry.js → p-ec0809a7.entry.js} +2 -2
  616. package/dist/genexus-ide-ui/{p-460db3ff.entry.js → p-ecba870e.entry.js} +3 -3
  617. package/dist/genexus-ide-ui/{p-e26e05c7.entry.js → p-f49bb305.entry.js} +18 -12
  618. package/dist/genexus-ide-ui/p-f49bb305.entry.js.map +1 -0
  619. package/dist/genexus-ide-ui/{p-8636a0bd.entry.js → p-f722955f.entry.js} +2 -2
  620. package/dist/genexus-ide-ui/{p-a8cc41e4.entry.js → p-f7421997.entry.js} +61 -58
  621. package/dist/genexus-ide-ui/p-f7421997.entry.js.map +1 -0
  622. package/dist/types/components/new-version/new-version.d.ts +27 -1
  623. package/dist/types/components/select-kb-items/select-kb-items.d.ts +8 -0
  624. package/dist/types/components/team-dev/history/helpers.d.ts +7 -0
  625. package/dist/types/components/team-dev/history/history.d.ts +109 -0
  626. package/dist/types/components.d.ts +141 -18
  627. package/dist/types/index.d.ts +4 -0
  628. package/package.json +3 -3
  629. package/dist/cjs/code-render-0e9837c4.js.map +0 -1
  630. package/dist/cjs/form-validation-ffe2b957.js.map +0 -1
  631. package/dist/cjs/helpers-e5a13fa5.js.map +0 -1
  632. package/dist/cjs/locale-36b93b1b.js.map +0 -1
  633. package/dist/esm/code-render-f3afd300.js.map +0 -1
  634. package/dist/esm/form-validation-71dca8c6.js.map +0 -1
  635. package/dist/esm/helpers-5f1c9a32.js.map +0 -1
  636. package/dist/esm/locale-643afe17.js.map +0 -1
  637. package/dist/genexus-ide-ui/p-032b4a81.entry.js.map +0 -1
  638. package/dist/genexus-ide-ui/p-0d83a34d.entry.js.map +0 -1
  639. package/dist/genexus-ide-ui/p-0e53f1ef.entry.js.map +0 -1
  640. package/dist/genexus-ide-ui/p-11dccb8f.entry.js.map +0 -1
  641. package/dist/genexus-ide-ui/p-29575656.entry.js.map +0 -1
  642. package/dist/genexus-ide-ui/p-2dbf722d.entry.js.map +0 -1
  643. package/dist/genexus-ide-ui/p-2e90a13a.entry.js.map +0 -1
  644. package/dist/genexus-ide-ui/p-353810b8.entry.js.map +0 -1
  645. package/dist/genexus-ide-ui/p-45d2fa91.entry.js.map +0 -1
  646. package/dist/genexus-ide-ui/p-501c7b1f.entry.js.map +0 -1
  647. package/dist/genexus-ide-ui/p-50eaa96d.entry.js.map +0 -1
  648. package/dist/genexus-ide-ui/p-51601b85.js +0 -145
  649. package/dist/genexus-ide-ui/p-51601b85.js.map +0 -1
  650. package/dist/genexus-ide-ui/p-5a42428d.entry.js.map +0 -1
  651. package/dist/genexus-ide-ui/p-5da3e999.entry.js.map +0 -1
  652. package/dist/genexus-ide-ui/p-5e05f830.entry.js.map +0 -1
  653. package/dist/genexus-ide-ui/p-6168d48c.entry.js.map +0 -1
  654. package/dist/genexus-ide-ui/p-66d9269a.entry.js.map +0 -1
  655. package/dist/genexus-ide-ui/p-6dc05a27.entry.js.map +0 -1
  656. package/dist/genexus-ide-ui/p-75e1aa31.entry.js.map +0 -1
  657. package/dist/genexus-ide-ui/p-7782e1b8.entry.js.map +0 -1
  658. package/dist/genexus-ide-ui/p-7cedb0f0.entry.js.map +0 -1
  659. package/dist/genexus-ide-ui/p-857866f8.js.map +0 -1
  660. package/dist/genexus-ide-ui/p-8b046b4b.entry.js.map +0 -1
  661. package/dist/genexus-ide-ui/p-8f1f4126.entry.js.map +0 -1
  662. package/dist/genexus-ide-ui/p-970d16ca.entry.js +0 -149
  663. package/dist/genexus-ide-ui/p-970d16ca.entry.js.map +0 -1
  664. package/dist/genexus-ide-ui/p-9b238bf7.entry.js.map +0 -1
  665. package/dist/genexus-ide-ui/p-9c690c36.entry.js.map +0 -1
  666. package/dist/genexus-ide-ui/p-a6029d9a.entry.js.map +0 -1
  667. package/dist/genexus-ide-ui/p-a86a8692.entry.js.map +0 -1
  668. package/dist/genexus-ide-ui/p-a8cc41e4.entry.js.map +0 -1
  669. package/dist/genexus-ide-ui/p-ac0438d6.entry.js.map +0 -1
  670. package/dist/genexus-ide-ui/p-b1833747.entry.js.map +0 -1
  671. package/dist/genexus-ide-ui/p-be794132.entry.js.map +0 -1
  672. package/dist/genexus-ide-ui/p-bfd9066c.entry.js.map +0 -1
  673. package/dist/genexus-ide-ui/p-c30b2104.entry.js.map +0 -1
  674. package/dist/genexus-ide-ui/p-c5cca204.entry.js.map +0 -1
  675. package/dist/genexus-ide-ui/p-d1cc4724.entry.js.map +0 -1
  676. package/dist/genexus-ide-ui/p-daa29451.entry.js.map +0 -1
  677. package/dist/genexus-ide-ui/p-db4750ff.entry.js.map +0 -1
  678. package/dist/genexus-ide-ui/p-db4f756a.entry.js.map +0 -1
  679. package/dist/genexus-ide-ui/p-e26e05c7.entry.js.map +0 -1
  680. package/dist/genexus-ide-ui/p-e37e95e7.entry.js.map +0 -1
  681. package/dist/genexus-ide-ui/p-e5571f49.entry.js.map +0 -1
  682. package/dist/genexus-ide-ui/p-ec01c70c.entry.js.map +0 -1
  683. package/dist/genexus-ide-ui/p-f5a48b33.entry.js.map +0 -1
  684. package/dist/genexus-ide-ui/p-f6ceb01a.entry.js.map +0 -1
  685. /package/dist/genexus-ide-ui/{p-f52bcdac.entry.js.map → p-0550fd5f.entry.js.map} +0 -0
  686. /package/dist/genexus-ide-ui/{p-2be58a7a.entry.js.map → p-14165308.entry.js.map} +0 -0
  687. /package/dist/genexus-ide-ui/{p-9a39e49c.entry.js.map → p-35f9ebbc.entry.js.map} +0 -0
  688. /package/dist/genexus-ide-ui/{p-4d929210.entry.js.map → p-4b38fffc.entry.js.map} +0 -0
  689. /package/dist/genexus-ide-ui/{p-b211bca8.entry.js.map → p-6b957e82.entry.js.map} +0 -0
  690. /package/dist/genexus-ide-ui/{p-f315c6e0.entry.js.map → p-aab809c4.entry.js.map} +0 -0
  691. /package/dist/genexus-ide-ui/{p-95f831a8.entry.js.map → p-b2928645.entry.js.map} +0 -0
  692. /package/dist/genexus-ide-ui/{p-39c527ff.entry.js.map → p-b58fb87b.entry.js.map} +0 -0
  693. /package/dist/genexus-ide-ui/{p-02fc47cd.entry.js.map → p-d8379699.entry.js.map} +0 -0
  694. /package/dist/genexus-ide-ui/{p-cdf8b082.entry.js.map → p-da473001.entry.js.map} +0 -0
  695. /package/dist/genexus-ide-ui/{p-9a9ee1ee.entry.js.map → p-e24902a0.entry.js.map} +0 -0
  696. /package/dist/genexus-ide-ui/{p-f2bd9044.entry.js.map → p-e7fb3ee3.entry.js.map} +0 -0
  697. /package/dist/genexus-ide-ui/{p-eb51429c.entry.js.map → p-ec0809a7.entry.js.map} +0 -0
  698. /package/dist/genexus-ide-ui/{p-460db3ff.entry.js.map → p-ecba870e.entry.js.map} +0 -0
  699. /package/dist/genexus-ide-ui/{p-8636a0bd.entry.js.map → p-f722955f.entry.js.map} +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"names":["wwImagesCss","CSS_BUNDLES","GxIdeWWImages","this","renderedFirstTime","attachDetectClickOutsideFilter","document","addEventListener","detectClickOutsideFilter","removeDetectClickOutsideFilter","removeEventListener","e","clickedOutside","closeOnOutsideClickHandler","filterEl","filtersHidden","saveInitialFilterData","filterInitialData","name","filterNameEl","value","module","filterModuleEl","searchContents","filterSearchContentsEl","category","filterCategoryEl","allDescendants","filterAllDescendantsEl","checked","modified","filterModifiedEl","dateTime","filterModifiedDateEl","after","filterAfterTypeEl","user","filterUserEl","style","filterStyleEl","language","filterLanguageEl","density","filterDensityEl","layer","filterLayerEl","renderFilter","h","class","ref","el","label","_componentLocale","filter","part","defaultModule","defaultValue","selectEntityCallback","selectModuleCallback","onClick","resetFilterHandler","type","icon","toggleFiltersHandler","search","defaultCategory","disabled","categories","renderFormItems","labelPosition","center","hide","filterModified","filterAfterType","FILTER_AFTER","DATE_TIME","afterLabel","id","NONE","afterNone","IMPORT","LAST_BUILD","centerLabel","styles","languages","densities","layers","renderImagesData","contentBorderEnd","noContentPadding","titleType","containerTitle","secondaryFilter","imagesDataTitle","slot","placeholder","onInput","filterInputHandler","chGridEl","rowSelectionMode","columnName","columnNameHidden","settingable","size","config","tabularGrid","colSize","maxContent","tableHead","common","description","commonDouble","modifiedDate","lastUser","importDate","filteredImages","map","obj","rowid","src","hiChar","filterImagesInputValue","formatDate","renderImages","imagesTitle","titleHeightAsInput","imagesSelectedItems","item","url","alt","getImages","filters","parent","modifiedAfter","modifiedBy","loadCallback","then","items","images","selectedObjectsIds","deselectAll","filterImagesInformationHandler","newObjectCallbackHandler","newObjectCallback","openSelectionCallBackHandler","openSelectionCallback","deleteSelectionCallbackHandler","deleteSelectionCallback","selectAll","selectAllRows","listenChanges","detail","ev","loadImageItemsCallback","rowsId","selectionObjectChangedCallback","preventDefault","stopPropagation","contextMenuCallback","selection","selectedRowsId","clientX","clientY","filterValue","toLocaleLowerCase","image","nameMatch","includes","moduleMatch","descriptionMatch","modifiedDateMatch","toString","importDateMatch","filtersHiddenHandler","hidden","componentWillLoad","Locale","getComponentStrings","componentDidLoadEvent","emit","componentDidLoad","focus","componentDidRender","componentDidRenderFirstTime","componentName","keyDownHandler","eventInfo","activeElement","key","validate","isValid","reload","render","Host","model","noContentGap","displayTitle","slimmerFooter","gxIdeContainer","footer","btnSelectAll","btnNew","length","objCount","matching"],"sources":["src/components/ww-images/ww-images.scss?tag=gx-ide-ww-images&encapsulation=shadow","src/components/ww-images/ww-images.tsx"],"sourcesContent":["@import \"../../global/gx-ide-common.scss\";\n@import \"../../global/gx-ide-mixins.scss\";\n@import \"../../../node_modules/@genexus/mercury/dist/assets/scss/helpers.scss\";\n\n:host {\n display: block;\n}\n\n/*--- Filter ---*/\n.module-folder::part(wrapper) {\n padding-block: 1.5px;\n margin-block-start: var(--gxg-label-separation-vertical);\n}\n.filter--padding {\n padding: var(--gx-ide-container__padding);\n}\n.filter--gap {\n gap: var(--gx-ide-grid-row-gap);\n}\n.filter {\n display: flex;\n flex-direction: column;\n &__first-row {\n display: flex;\n gap: var(--gx-ide-grid-column-gap);\n .name,\n .module-folder {\n flex: 1;\n }\n .filter-btn {\n flex: none;\n }\n .second-column {\n display: flex;\n flex-direction: row;\n align-items: end;\n gap: var(--gx-ide-grid-column-gap);\n }\n > * {\n flex: 1;\n }\n }\n .checkboxes-label-wrapper {\n display: flex;\n flex-direction: column;\n gap: 0;\n }\n .checkboxes-wrapper {\n display: flex;\n gap: var(--gx-ide-grid-column-gap);\n border-radius: var(--border-radius-sm);\n height: var(--gxg-form-text-height);\n box-sizing: border-box;\n align-items: center;\n padding-inline-start: var(--mer-spacing--2xs);\n }\n .user {\n max-width: 100% !important;\n }\n}\n\n/*Filter*/\n.filters-outer-wrapper {\n display: grid;\n grid-template-rows: 1fr;\n transition: grid-template-rows 200ms;\n &--hidden {\n grid-template-rows: 0fr;\n }\n}\n.filters-inner-wrapper {\n padding-top: var(--gx-ide-container__padding);\n display: grid;\n overflow: hidden;\n grid-template-columns: repeat(12, 1fr);\n grid-template-rows: repeat(3, 1fr);\n\n .search-contents {\n grid-area: 1 / 1 / 2 / 5;\n }\n .category {\n grid-area: 1 / 5 / 2 / 9;\n }\n .options {\n grid-area: 1 / 9 / 2 / 13;\n }\n .date-time {\n grid-area: 2 / 1 / 3 / 5;\n }\n .after-date-time {\n grid-area: 2 / 5 / 3 / 9;\n }\n .user {\n grid-area: 2 / 9 / 3 / 13;\n }\n .style {\n grid-area: 3 / 1 / 4 / 4;\n }\n .language {\n grid-area: 3 / 4 / 4 / 7;\n }\n .density {\n grid-area: 3 / 7 / 4 / 10;\n }\n .layer {\n grid-area: 3 / 10 / 4 / 13;\n }\n}\n\ngxg-date-picker {\n position: absolute;\n inline-size: calc(33% - 16px);\n}\ngxg-date-picker::part(input) {\n block-size: 26px;\n}\n\n.master-wrapper {\n height: 100%;\n position: relative;\n display: grid;\n grid-template-rows: auto 1fr;\n}\n\n/*--- Grid/Images Container ---*/\n.grid-images-container {\n border-top: 1px solid var(--gx-ide-container-border-color);\n display: grid;\n grid-template-columns: 1fr 220px;\n grid-column-gap: 0;\n grid-row-gap: 0;\n overflow: auto;\n}\n.images-information {\n &__header {\n display: flex;\n align-items: center;\n gap: var(--gx-ide-grid-column-gap);\n &-title {\n flex: none;\n }\n }\n}\n\n/* Objects Table */\n.images-grid {\n grid-template-columns: repeat(2, 1fr);\n grid-column-gap: 0;\n > :nth-child(1) {\n grid-area: 1 / 1 / 1 / 3;\n }\n}\n.images-container {\n .image-item {\n display: inline-block;\n width: 50%;\n height: 110px; /*should be half the images container width (actually is 220px)*/\n &__container {\n padding: var(--gx-ide-container__padding);\n img {\n width: 100%;\n height: 100%;\n object-fit: scale-down;\n }\n }\n &__name {\n @include ellipsis;\n text-align: center;\n width: 100%;\n display: block;\n font-size: 10px;\n padding: 4px 8px;\n box-sizing: border-box;\n background-color: var(--gray-00);\n }\n &:nth-child(odd) {\n .image-item__name {\n border-inline-end: 1px solid var(--gray-02);\n }\n }\n }\n}\n.objects-count {\n grid-template-columns: repeat(2, 1fr);\n *:nth-child(2) {\n justify-content: flex-end;\n align-items: flex-start;\n }\n}\n\n@include hiChar;\n\n@include tabular-grid-cell-layout(\n $tabular-grid-selector: \".tabular-grid-ww-images\",\n $tabular-grid-cell-node-type: \"text\",\n $tabular-grid-cell-apply-ellipsis: true,\n $tabular-grid-affected-columns-nth-list: (\n 4\n )\n);\n","/* STENCIL IMPORTS */\nimport {\n Component,\n Host,\n h,\n Prop,\n Element,\n Event,\n EventEmitter,\n State,\n Method,\n Listen,\n Watch\n} from \"@stencil/core\";\n/* OTHER LIBRARIES IMPORTS */\nimport { ChGridRowContextMenuEvent } from \"@genexus/chameleon-controls-library\";\nimport { DatePickerDate } from \"@genexus/gemini/dist/types/components/date-picker/date-picker\";\nimport { MercuryBundles } from \"@genexus/mercury\";\n/* CUSTOM IMPORTS */\nimport { Locale } from \"../../common/locale\";\nimport { GxOption } from \"../../common/types\";\nimport { config } from \"../../common/config\";\nimport { renderFormItems } from \"../../common/common\";\nimport { EntityData, ContextMenuInfo } from \"../../common/types\";\nimport { FILTER_AFTER } from \"../../common/constants\";\nimport {\n formatDate,\n hiChar,\n closeOnOutsideClickHandler\n} from \"../../common/helpers\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n // \"utils/form\",\n // \"utils/layout\",\n // \"utils/typography\",\n // \"components/button\",\n // \"components/checkbox\",\n // \"components/edit\",\n \"components/tabular-grid\"\n];\n\n@Component({\n tag: \"gx-ide-ww-images\",\n styleUrl: \"ww-images.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/ww-images\"]\n})\nexport class GxIdeWWImages {\n // 1.OWN PROPERTIES //\n\n /**\n * The component hard-coded strings translations.\n */\n private _componentLocale: any;\n private renderedFirstTime = false;\n private filterInitialData: FilerInitialData;\n\n // 2. REFERENCE TO ELEMENTS //\n\n @Element() el: HTMLGxIdeWwImagesElement;\n\n private filterEl: HTMLDivElement;\n /* References needed to collect data */\n private filterNameEl!: HTMLGxgFormTextElement;\n private filterSearchContentsEl!: HTMLGxgFormTextElement;\n private filterCategoryEl!: HTMLGxgComboBoxElement;\n private filterModuleEl!: HTMLGxIdeEntitySelectorElement;\n private filterModifiedEl!: HTMLGxgFormCheckboxElement;\n private filterAllDescendantsEl!: HTMLGxgFormCheckboxElement;\n private filterAfterTypeEl!: HTMLGxgComboBoxElement;\n private filterUserEl!: HTMLGxgFormTextElement;\n private filterModifiedDateEl!: HTMLGxgDatePickerElement;\n private filterStyleEl!: HTMLGxgComboBoxElement;\n private filterLanguageEl!: HTMLGxgComboBoxElement;\n private filterDensityEl!: HTMLGxgComboBoxElement;\n private filterLayerEl!: HTMLGxgComboBoxElement;\n private chGridEl!: HTMLChGridElement;\n\n // 3.STATE() VARIABLES //\n\n @State() filtersHidden = true;\n @Watch(\"filtersHidden\")\n filtersHiddenHandler(hidden: boolean): void {\n if (hidden) {\n this.removeDetectClickOutsideFilter();\n } else {\n this.attachDetectClickOutsideFilter();\n }\n }\n\n /**\n * The after types render in the after selector\n */\n @State() filterAfterType = \"\";\n\n /**\n * For show or hide the filters relative to modifiers\n */\n @State() filterModified = false;\n\n /**\n * The images rendered in the table\n */\n @State() images: ImageData[] = [];\n\n /**\n * The images rendered in the table, after the filter\n */\n @State() filteredImages: ImageData[] = [];\n\n /**\n * The items of the image that is selected\n */\n @State() imagesSelectedItems: ImageItemData[] = [];\n\n /**\n * The selected images in the table of images\n */\n @State() selectedObjectsIds: string[] = [];\n\n /**\n * The images filter input text value\n */\n @State() filterImagesInputValue = \"\";\n\n // 4.PUBLIC PROPERTY API | WATCH'S //\n\n /**\n * If true it displays the component title on the header\n */\n @Prop() readonly displayTitle = false;\n\n /**\n * Displays a secondary filter, used to filter over the filtered images\n */\n @Prop() readonly secondaryFilter = false;\n\n /**\n * The categories render in the filter category selector\n */\n @Prop() readonly categories!: GxOption[];\n\n /**\n * The densities render in the filter density selector\n */\n @Prop() readonly densities!: GxOption[];\n\n /**\n * The default value for the 'categories' filter\n */\n @Prop() readonly defaultCategory: string;\n\n /**\n * The default value for the module/folder filter\n */\n @Prop() readonly defaultModule: EntityData;\n\n /**\n * The default value for the type filter\n */\n @Prop() readonly defaultType: string;\n\n /**\n * The modules/folders render in the module/folder selector\n */\n @Prop() readonly filterModules!: GxOption[];\n\n /**\n * The languages render in the filter language selector\n */\n @Prop() readonly languages!: GxOption[];\n\n /**\n * The layers render in the filter layer selector\n */\n @Prop() readonly layers!: GxOption[];\n\n /**\n * This is a function provided by the developer for expanded the data of images that is double-clicked or entered.\n */\n @Prop() readonly contextMenuCallback!: ContextMenuCallback;\n\n /**\n * This is a function provided by the developer for expanded the data of images that is double-clicked or entered.\n */\n @Prop() readonly deleteSelectionCallback!: DeleteSelectionCallback;\n\n /**\n * This is a function provided by the developer that return a list of images to populate the table of images.\n */\n @Prop() readonly loadCallback!: LoadCallback;\n\n /**\n * This is a function provided by the developer that return a list of items of the image selected.\n */\n @Prop() readonly loadImageItemsCallback!: LoadImageItemsCallback;\n\n /**\n * This is a function provided by the developer for expanded the data of images that is double-clicked or entered.\n */\n @Prop() readonly newObjectCallback!: NewObjectCallback;\n\n /**\n * This is a function provided by the developer for expanded the data of images that is double-clicked or entered.\n */\n @Prop() readonly openSelectionCallback!: OpenSelectionCallback;\n\n /**\n * Callback invoked when the action is executed on the Module/Folder filter (button '...'). It returns the information of the selected object (id and name) or 'undefined' if it was canceled.\n */\n @Prop() readonly selectModuleCallback!: SelectModuleCallback;\n\n /**\n * This is a function provided by the developer for expanded the data of images that is double-clicked or entered.\n */\n @Prop() readonly selectionObjectChangedCallback!: SelectionObjectCallback;\n\n /**\n * Applies a shadow all around\n */\n @Prop() readonly shadow = false;\n\n /**\n * The styles render in the filter style selector\n */\n @Prop() readonly styles!: GxOption[];\n\n /**\n * The types render in the filter type selector\n */\n @Prop() readonly types!: GxOption[];\n\n // 5.EVENTS (EMIT) //\n\n /**\n * This event is emitted once just after the component is fully loaded and the first render() occurs.\n */\n @Event() componentDidLoadEvent: EventEmitter<boolean>;\n\n /**\n * @description Gets fired when the component has rendered for the first time.\n */\n @Event() componentDidRenderFirstTime: EventEmitter<string>;\n\n // 6.COMPONENT LIFECYCLE EVENTS //\n\n async componentWillLoad() {\n this._componentLocale = await Locale.getComponentStrings(this.el);\n this.componentDidLoadEvent.emit(true);\n }\n\n componentDidLoad() {\n this.listenChanges();\n this.getImages();\n this.saveInitialFilterData();\n this.filterNameEl.focus();\n }\n\n componentDidRender() {\n if (!this.renderedFirstTime) {\n this.componentDidRenderFirstTime.emit(\n this._componentLocale.componentName\n );\n this.renderedFirstTime = true;\n }\n }\n\n // 7.LISTENERS //\n\n @Listen(\"keydown\", { passive: true })\n keyDownHandler(eventInfo: KeyboardEvent) {\n if (document.activeElement === this.el) {\n switch (eventInfo.key) {\n case \"Enter\":\n this.openSelectionCallBackHandler();\n break;\n case \"Delete\":\n this.deleteSelectionCallbackHandler();\n break;\n }\n }\n }\n\n // 8.PUBLIC METHODS API //\n\n /**\n * Validate necessary data input\n */\n @Method()\n async validate(): Promise<boolean> {\n const isValid = true;\n return isValid;\n }\n\n /**\n * This method reload the view, refreshing the filters and the table of images.\n */\n @Method()\n async reload(): Promise<void> {\n this.getImages();\n }\n\n // 9.LOCAL METHODS //\n\n private attachDetectClickOutsideFilter = () => {\n document.addEventListener(\"click\", this.detectClickOutsideFilter);\n };\n private removeDetectClickOutsideFilter = () => {\n document.removeEventListener(\"click\", this.detectClickOutsideFilter);\n };\n private detectClickOutsideFilter = (e: PointerEvent): void => {\n const clickedOutside = closeOnOutsideClickHandler(e, this.filterEl);\n if (clickedOutside) {\n this.filtersHidden = true;\n } else {\n this.filtersHidden = false;\n }\n };\n\n /**\n * @description This is needed for resetting the filter. When the user resets the filter, all the filter controls values have to be restored to the value they had on componentDidLoad.\n */\n private saveInitialFilterData = () => {\n this.filterInitialData = {\n name: this.filterNameEl.value,\n module: this.filterModuleEl.value,\n searchContents: this.filterSearchContentsEl.value,\n category: this.filterCategoryEl.value,\n allDescendants: this.filterAllDescendantsEl.checked,\n modified: this.filterModifiedEl.checked,\n dateTime: this.filterModifiedDateEl.value,\n after: this.filterAfterTypeEl.value,\n user: this.filterUserEl.value,\n style: this.filterStyleEl.value,\n language: this.filterLanguageEl.value,\n density: this.filterDensityEl.value,\n layer: this.filterLayerEl.value\n };\n };\n\n // 9.LOCAL METHODS -> Renders //\n\n private renderFilter = (): Element => {\n return (\n <div\n class=\"filter filter--padding\"\n ref={(el: HTMLDivElement) => (this.filterEl = el as HTMLDivElement)}\n >\n <div class=\"filter__first-row\">\n {/* name */}\n <gxg-form-text\n label-position=\"above\"\n label={this._componentLocale.filter.name}\n ref={(el: HTMLGxgFormTextElement) =>\n (this.filterNameEl = el as HTMLGxgFormTextElement)\n }\n part=\"filter-name\"\n class=\"name\"\n ></gxg-form-text>\n\n <div class=\"second-column\">\n {/* module/folder */}\n <gx-ide-entity-selector\n label-position=\"above\"\n value={this.defaultModule}\n defaultValue={this.defaultModule}\n selectEntityCallback={this.selectModuleCallback}\n ref={(el: HTMLGxIdeEntitySelectorElement) =>\n (this.filterModuleEl = el as HTMLGxIdeEntitySelectorElement)\n }\n class=\"module-folder\"\n part=\"filter-module-folder\"\n ></gx-ide-entity-selector>\n\n {/* reset filter button */}\n <gxg-button\n onClick={this.resetFilterHandler}\n part=\"gxg-button-reset-filter\"\n type=\"secondary-icon-only\"\n icon=\"gemini-tools/reset\"\n class=\"reset-filter-btn\"\n ></gxg-button>\n\n {/* filter button */}\n <gxg-button\n onClick={this.toggleFiltersHandler}\n part=\"gxg-button gxg-button--more-less\"\n type=\"secondary-icon-only\"\n icon={\n true ? \"window-tools/filter-conditions\" : \"window-tools/filter\"\n }\n class=\"filter-btn\"\n ></gxg-button>\n </div>\n </div>\n\n <div\n class={{\n \"filters-outer-wrapper\": true,\n \"filters-outer-wrapper--hidden\": this.filtersHidden\n }}\n >\n <div\n class={{\n \"filter\": true,\n \"filter--gap\": true,\n \"filters-inner-wrapper\": true\n }}\n >\n {/* search contents */}\n <gxg-form-text\n label-position=\"above\"\n label={this._componentLocale.filter.search}\n ref={(el: HTMLGxgFormTextElement) =>\n (this.filterSearchContentsEl = el as HTMLGxgFormTextElement)\n }\n class={{ \"search-contents\": true }}\n part=\"filter-search\"\n ></gxg-form-text>\n\n {/* category */}\n <gxg-combo-box\n disable-filter\n label={this._componentLocale.filter.category}\n value={this.defaultCategory}\n disabled={!this.categories}\n ref={(el: HTMLGxgComboBoxElement) =>\n (this.filterCategoryEl = el as HTMLGxgComboBoxElement)\n }\n class=\"category\"\n part=\"filter-category\"\n >\n {renderFormItems(\"gxg-combo-box-item\", this.categories ?? [])}\n </gxg-combo-box>\n\n <div class=\"options\">\n <gxg-label labelPosition=\"above\" center={false}>\n Options:\n </gxg-label>\n {/* all descendants*/}\n <div class=\"checkboxes-wrapper\">\n <gxg-form-checkbox\n label={this._componentLocale.filter.allDescendants}\n ref={(el: HTMLGxgFormCheckboxElement) =>\n (this.filterAllDescendantsEl =\n el as HTMLGxgFormCheckboxElement)\n }\n class=\"all-descendants\"\n part=\"filter-all-descendants\"\n ></gxg-form-checkbox>\n\n {/* modified */}\n <gxg-form-checkbox\n label={this._componentLocale.filter.modified}\n ref={(el: HTMLGxgFormCheckboxElement) =>\n (this.filterModifiedEl = el as HTMLGxgFormCheckboxElement)\n }\n class=\"modified\"\n part=\"filter-modified\"\n ></gxg-form-checkbox>\n </div>\n </div>\n\n {/* date/time*/}\n <div\n class={{\n \"hide\":\n !this.filterModified ||\n this.filterAfterType !== FILTER_AFTER.DATE_TIME,\n \"date-time\": true\n }}\n part=\"filter-datetime\"\n >\n <div class=\"date-time-wrapper\">\n <gxg-label label-position=\"above\">\n {this._componentLocale.filter.dateTime}\n </gxg-label>\n <gxg-date-picker\n class=\"date-picker\"\n disabled={!this.filterModified}\n ref={(el: HTMLGxgDatePickerElement) =>\n (this.filterModifiedDateEl = el as HTMLGxgDatePickerElement)\n }\n ></gxg-date-picker>\n </div>\n </div>\n\n {/* after date/time */}\n <gxg-combo-box\n class=\"after-date-time\"\n disabled={!this.filterModified}\n label={this._componentLocale.filter.afterLabel}\n disable-filter\n value={this.filterAfterType}\n ref={(el: HTMLGxgComboBoxElement) =>\n (this.filterAfterTypeEl = el as HTMLGxgComboBoxElement)\n }\n part=\"filter-after-type\"\n >\n {renderFormItems(\"gxg-combo-box-item\", [\n {\n id: FILTER_AFTER.NONE,\n label: this._componentLocale.filter.afterNone,\n value: FILTER_AFTER.NONE\n },\n {\n id: FILTER_AFTER.DATE_TIME,\n label: this._componentLocale.filter[FILTER_AFTER.DATE_TIME],\n value: FILTER_AFTER.DATE_TIME\n },\n {\n id: FILTER_AFTER.IMPORT,\n label: this._componentLocale.filter[FILTER_AFTER.IMPORT],\n value: FILTER_AFTER.IMPORT\n },\n {\n id: FILTER_AFTER.LAST_BUILD,\n label: this._componentLocale.filter[FILTER_AFTER.LAST_BUILD],\n value: FILTER_AFTER.LAST_BUILD\n }\n ])}\n </gxg-combo-box>\n\n {/* user */}\n <gxg-form-text\n disabled={!this.filterModified}\n labelPosition=\"above\"\n label={this._componentLocale.filter.user}\n ref={(el: HTMLGxgFormTextElement) =>\n (this.filterUserEl = el as HTMLGxgFormTextElement)\n }\n value=\"hey\"\n centerLabel={false}\n class=\"user\"\n part=\"filter-user\"\n ></gxg-form-text>\n\n {/* style*/}\n <gxg-combo-box\n disable-filter\n label={this._componentLocale.filter.style}\n disabled={!this.styles}\n ref={(el: HTMLGxgComboBoxElement) =>\n (this.filterStyleEl = el as HTMLGxgComboBoxElement)\n }\n class=\"style\"\n part=\"filter-style\"\n >\n {renderFormItems(\"gxg-combo-box-item\", this.styles ?? [])}\n </gxg-combo-box>\n\n {/* language*/}\n <gxg-combo-box\n disable-filter\n label={this._componentLocale.filter.language}\n disabled={!this.languages}\n ref={(el: HTMLGxgComboBoxElement) =>\n (this.filterLanguageEl = el as HTMLGxgComboBoxElement)\n }\n class=\"language\"\n part=\"filter-language\"\n >\n {renderFormItems(\"gxg-combo-box-item\", this.languages ?? [])}\n </gxg-combo-box>\n\n {/* density*/}\n <gxg-combo-box\n disable-filter\n label={this._componentLocale.filter.density}\n disabled={!this.densities}\n ref={(el: HTMLGxgComboBoxElement) =>\n (this.filterDensityEl = el as HTMLGxgComboBoxElement)\n }\n class=\"density\"\n part=\"filter-density\"\n >\n {renderFormItems(\"gxg-combo-box-item\", this.densities ?? [])}\n </gxg-combo-box>\n\n {/* layer*/}\n <gxg-combo-box\n disable-filter\n label={this._componentLocale.filter.layer}\n disabled={!this.layers}\n ref={(el: HTMLGxgComboBoxElement) =>\n (this.filterLayerEl = el as HTMLGxgComboBoxElement)\n }\n class=\"layer\"\n part=\"filter-layer\"\n >\n {renderFormItems(\"gxg-combo-box-item\", this.layers ?? [])}\n </gxg-combo-box>\n </div>\n </div>\n </div>\n );\n };\n\n private renderImagesData = (): Element => {\n return (\n /* images information*/\n <gx-ide-container\n contentBorderEnd\n noContentPadding\n titleType=\"secondary\"\n containerTitle={\n !this.secondaryFilter ? this._componentLocale.imagesDataTitle : null\n }\n class={{ \"images-information\": true, \"overflow-auto\": true }}\n part=\"grid-container\"\n >\n {this.secondaryFilter ? (\n <header class=\"images-information__header\" slot=\"header\">\n <gx-ide-title\n type=\"secondary\"\n class=\"images-information__header-title\"\n >\n {this._componentLocale.imagesDataTitle}\n </gx-ide-title>\n <gxg-form-text\n icon=\"gemini-tools/search\"\n icon-position=\"start\"\n placeholder=\"Search by any field\"\n onInput={this.filterInputHandler as any}\n ></gxg-form-text>\n </header>\n ) : null}\n\n <ch-tabular-grid\n ref={(el: HTMLChTabularGridElement) => (this.chGridEl = el)}\n part=\"ch-grid-images\"\n rowSelectionMode=\"single\"\n class=\"tabular-grid tabular-grid-ww-images\"\n >\n <ch-tabular-grid-columnset class=\"tabular-grid-column-set\">\n <ch-tabular-grid-column\n columnName=\"\"\n columnNameHidden={false}\n settingable={false}\n size={config.tabularGrid.colSize.maxContent}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.name}\n columnNameHidden={false}\n settingable={false}\n class=\"tabular-grid-column\"\n size={config.tabularGrid.colSize.common}\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.module}\n columnNameHidden={false}\n settingable={false}\n size={config.tabularGrid.colSize.common}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.description}\n columnNameHidden={false}\n settingable={false}\n size={config.tabularGrid.colSize.commonDouble}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.modifiedDate}\n columnNameHidden={false}\n settingable={false}\n size={config.tabularGrid.colSize.maxContent}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.lastUser}\n columnNameHidden={false}\n settingable={false}\n size={config.tabularGrid.colSize.maxContent}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.importDate}\n columnNameHidden={false}\n settingable={false}\n size={config.tabularGrid.colSize.maxContent}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n </ch-tabular-grid-columnset>\n {this.filteredImages.map((obj: ImageData) => (\n <ch-tabular-grid-row rowid={obj.id} class=\"tabular-grid-row\">\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n <ch-image src={obj.icon}></ch-image>\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {hiChar(obj.name, this.filterImagesInputValue)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {hiChar(obj.module, this.filterImagesInputValue)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {hiChar(obj.description, this.filterImagesInputValue)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {hiChar(\n `${formatDate(obj.modifiedDate)}`,\n this.filterImagesInputValue\n )}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {hiChar(obj.lastUser, this.filterImagesInputValue)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {hiChar(\n `${formatDate(obj.importDate)}`,\n this.filterImagesInputValue\n )}\n </ch-tabular-grid-cell>\n </ch-tabular-grid-row>\n ))}\n </ch-tabular-grid>\n </gx-ide-container>\n );\n };\n\n private renderImages = (): Element => {\n return (\n /* tiles */\n <gx-ide-container\n containerTitle={this._componentLocale.imagesTitle}\n noContentPadding\n titleType=\"secondary\"\n class=\"overflow-auto\"\n titleHeightAsInput={\n this.secondaryFilter ? this._componentLocale.imagesDataTitle : null\n }\n part=\"image-data-container\"\n >\n <div class=\"images-container\">\n {this.imagesSelectedItems.map(item => (\n <div class=\"image-item\">\n <div class=\"image-item__container\">\n <div class=\"img\">\n <img src={item.url} alt={item.id} />\n </div>\n </div>\n <span class=\"image-item__name\">{item.name}</span>\n </div>\n ))}\n </div>\n </gx-ide-container>\n );\n };\n\n // 9.LOCAL METHODS -> Other //\n\n private getImages = (): void => {\n let filters: ImageFiltersData = {\n name: this.filterNameEl.value,\n parent: this.filterModuleEl.value ? this.filterModuleEl.value.id : null\n };\n\n const modified = this.filterModifiedEl.checked;\n const modifiedAfter = this.filterAfterTypeEl.value;\n filters = {\n ...filters,\n searchContents: this.filterSearchContentsEl.value,\n category: this.filterCategoryEl.value,\n allDescendants: this.filterAllDescendantsEl.checked,\n modifiedAfter: modified ? modifiedAfter : null,\n modifiedBy: modified ? this.filterUserEl.value : null,\n modifiedDate:\n modified && modifiedAfter === FILTER_AFTER.DATE_TIME\n ? (this.filterModifiedDateEl.value as Date)\n : null,\n style: this.filterStyleEl.value,\n language: this.filterLanguageEl.value,\n density: this.filterDensityEl.value,\n layer: this.filterLayerEl.value\n };\n\n this.loadCallback(filters).then((items: ImageData[]) => {\n this.images = items;\n this.selectedObjectsIds = [];\n this.deselectAll();\n this.filterImagesInformationHandler();\n });\n };\n\n private newObjectCallbackHandler = (): void => {\n this.newObjectCallback();\n };\n\n private openSelectionCallBackHandler = (): void => {\n this.openSelectionCallback(this.selectedObjectsIds);\n };\n\n private deleteSelectionCallbackHandler = (): void => {\n this.deleteSelectionCallback(this.selectedObjectsIds);\n };\n\n private resetFilterHandler = () => {\n if (this.filterInitialData) {\n this.filterNameEl.value = this.filterInitialData.name;\n this.filterModuleEl.value = this.filterInitialData.module;\n this.filterSearchContentsEl.value = this.filterInitialData.searchContents;\n this.filterCategoryEl.value = this.filterInitialData.category;\n this.filterAllDescendantsEl.checked =\n this.filterInitialData.allDescendants;\n this.filterModifiedEl.checked = this.filterInitialData.modified;\n this.filterModifiedDateEl.value = this.filterInitialData.dateTime;\n this.filterAfterTypeEl.value = this.filterInitialData.after;\n this.filterUserEl.value = this.filterInitialData.user;\n this.filterStyleEl.value = this.filterInitialData.style;\n this.filterLanguageEl.value = this.filterInitialData.language;\n this.filterDensityEl.value = this.filterInitialData.density;\n this.filterLayerEl.value = this.filterInitialData.layer;\n }\n };\n\n private toggleFiltersHandler = () => {\n this.filtersHidden = !this.filtersHidden;\n };\n\n private selectAll = (): void => {\n (this.chGridEl as any).selectAllRows();\n };\n\n private deselectAll = (): void => {\n (this.chGridEl as any).selectAllRows(false);\n };\n\n private listenChanges = (): void => {\n /* name */\n this.filterNameEl.addEventListener(\"change\", () => {\n this.getImages();\n });\n /* module/folder */\n this.filterModuleEl.addEventListener(\"valueChanged\", () => {\n this.getImages();\n });\n /* search contents*/\n this.filterSearchContentsEl.addEventListener(\"change\", () => {\n this.getImages();\n });\n /* category */\n this.filterCategoryEl.addEventListener(\"valueChanged\", () => {\n this.getImages();\n });\n /* (options) -> all descendants */\n this.filterAllDescendantsEl.addEventListener(\"change\", () => {\n this.getImages();\n });\n /* (options) -> modified */\n this.filterModifiedEl.addEventListener(\"change\", (e: any) => {\n this.filterModified = e.detail.value;\n this.getImages();\n });\n /* date/time */\n this.filterModifiedDateEl.addEventListener(\"valueChanged\", () => {\n this.getImages();\n });\n /* after */\n this.filterAfterTypeEl.addEventListener(\"valueChanged\", () => {\n this.filterAfterType = this.filterAfterTypeEl.value;\n this.getImages();\n });\n /* user */\n this.filterUserEl.addEventListener(\"change\", () => {\n this.getImages();\n });\n /* style */\n this.filterStyleEl.addEventListener(\"valueChanged\", () => {\n this.getImages();\n });\n /* language */\n this.filterLanguageEl.addEventListener(\"valueChanged\", () => {\n this.getImages();\n });\n /* density */\n this.filterDensityEl.addEventListener(\"valueChanged\", () => {\n this.getImages();\n });\n /* layer */\n this.filterLayerEl.addEventListener(\"valueChanged\", () => {\n this.getImages();\n });\n\n // for grid selection\n this.chGridEl.addEventListener(\"selectionChanged\", (ev: any): void => {\n this.loadImageItemsCallback(ev.detail.rowsId[0]).then(\n (items: ImageItemData[]) => {\n this.imagesSelectedItems = items;\n }\n );\n });\n this.chGridEl.addEventListener(\"rowDoubleClicked\", (): void => {\n this.openSelectionCallBackHandler();\n });\n this.chGridEl.addEventListener(\"selectionChanged\", (ev: any): void => {\n this.selectedObjectsIds = ev.detail.rowsId;\n this.selectionObjectChangedCallback(this.selectedObjectsIds);\n });\n this.chGridEl.addEventListener(\n \"rowContextMenu\",\n (ev: CustomEvent<ChGridRowContextMenuEvent>): void => {\n ev.preventDefault();\n ev.stopPropagation();\n this.contextMenuCallback({\n selection: ev.detail.selectedRowsId,\n clientX: ev.detail.clientX,\n clientY: ev.detail.clientY\n });\n }\n );\n };\n\n private filterInputHandler = (e: CustomEvent<EventEmitter>) => {\n this.filterImagesInputValue = e.detail as unknown as string;\n this.filterImagesInformationHandler();\n };\n\n private filterImagesInformationHandler = () => {\n const filterValue = this.filterImagesInputValue.toLocaleLowerCase();\n this.filteredImages = this.images.filter(image => {\n const nameMatch = image.name.toLocaleLowerCase().includes(filterValue);\n const moduleMatch = image.module\n .toLocaleLowerCase()\n .includes(filterValue);\n const descriptionMatch = image.description\n .toLocaleLowerCase()\n .includes(filterValue);\n const modifiedDateMatch = image.modifiedDate\n .toString()\n .includes(filterValue);\n const lastUser = image.lastUser.toLocaleLowerCase().includes(filterValue);\n const importDateMatch =\n image.importDate && image.importDate.toString().includes(filterValue);\n\n return (\n nameMatch ||\n moduleMatch ||\n descriptionMatch ||\n modifiedDateMatch ||\n lastUser ||\n importDateMatch\n );\n });\n };\n\n // 10.RENDER() FUNCTION //\n\n render(): void {\n return (\n <Host class=\"gx-ide-component\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <div class=\"gx-ide-main-wrapper\">\n <gx-ide-container\n noContentPadding\n noContentGap\n containerTitle={\n this.displayTitle ? this._componentLocale.componentName : null\n }\n slimmerFooter={config.gxIdeContainer.slimmerFooter}\n >\n <div class=\"master-wrapper\">\n {this.renderFilter()}\n <div class=\"grid-images-container\">\n {this.renderImagesData()}\n {this.renderImages()}\n </div>\n </div>\n\n {/* select all button */}\n <gxg-button\n id=\"button-select-all\"\n type=\"outlined\"\n onClick={this.selectAll}\n part=\"gxg-button gxg-button--select-all\"\n slot=\"footer-end\"\n >\n {this._componentLocale.footer.btnSelectAll}\n </gxg-button>\n\n {/* new file button*/}\n <gxg-button\n id=\"button-new-file\"\n type=\"primary-text-icon\"\n icon=\"objects/image\"\n onClick={this.newObjectCallbackHandler}\n part=\"gxg-button gxg-button--new-file\"\n slot=\"footer-end\"\n >\n {this._componentLocale.footer.btnNew}\n </gxg-button>\n\n {/* matching objects */}\n <gxg-text\n class=\"align-end\"\n part=\"objects-matching\"\n slot=\"footer-start\"\n >\n {`${this.filteredImages.length} ${this._componentLocale.objCount.matching}`}\n </gxg-text>\n </gx-ide-container>\n </div>\n </Host>\n );\n }\n}\n\nexport type SelectionObjectCallback = (ids: string[]) => Promise<void>;\nexport type OpenSelectionCallback = (ids: string[]) => Promise<void>;\nexport type DeleteSelectionCallback = (ids: string[]) => Promise<void>;\nexport type SelectModuleCallback = () => Promise<EntityData | undefined>;\nexport type ContextMenuCallback = (\n contextMenuInfo: ContextMenuInfo\n) => Promise<void>;\nexport type NewObjectCallback = () => Promise<void>;\nexport type LoadCallback = (filters: ImageFiltersData) => Promise<ImageData[]>;\nexport type LoadImageItemsCallback = (id: string) => Promise<ImageItemData[]>;\n\nexport type ImageFiltersData = {\n name?: string;\n searchContents?: string;\n category?: string;\n parent?: string;\n allDescendants?: boolean;\n modifiedAfter?: string;\n modifiedBy?: string;\n modifiedDate?: Date;\n style?: string;\n language?: string;\n density?: string;\n layer?: string;\n};\n\nexport type ImageData = {\n id: string;\n icon: string;\n name: string;\n description: string;\n parent: string;\n module: string;\n modifiedDate?: Date;\n lastUser?: string;\n importDate?: Date;\n};\n\nexport type ImageItemData = {\n id: string;\n name: string;\n url: string;\n};\n\ntype FilerInitialData = {\n name: string;\n module: EntityData;\n searchContents: string;\n category: string;\n allDescendants: boolean;\n modified: boolean;\n dateTime: DatePickerDate;\n after: string;\n user: string;\n style: string;\n language: string;\n density: string;\n layer: string;\n};\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["bpmAppDeclarationCss","CSS_BUNDLES","ADD_ICON","getIconPath","category","name","colorType","FILTER_ICON","MORE_ICON","SUGGEST_OPTIONS","alreadyProcessed","autoExpand","hideMatchesAndShowNonMatches","highlightMatchedItems","matchCase","regularExpression","strict","renderActiveItemIconOnExpand","GxIdeBpmAppDeclaration","_GxIdeBpmAppDeclaration_componentLocale","set","this","_GxIdeBpmAppDeclaration_animateEmptyState","_GxIdeBpmAppDeclaration_shortcutsSrc","getAssetPath","_GxIdeBpmAppDeclaration_ACCESS_CAPTION_MAP","in","undefined","out","inout","_GxIdeBpmAppDeclaration_setAccessCaptions","__classPrivateFieldGet","dataMappings","access","_GxIdeBpmAppDeclaration_applicationInputChangedHandler","async","event","selectedApplicationName","detail","application","mappings","getDataMappingCallback","_GxIdeBpmAppDeclaration_cancelCallbackHandler","cancelCallback","_GxIdeBpmAppDeclaration_clearApplicationHandler","typeIcon","_GxIdeBpmAppDeclaration_confirmCallbackHandler","confirmCallback","_GxIdeBpmAppDeclaration_mapRelevantDataOptionsToComboBoxModel","relevantDataOptions","map","optionName","caption","value","_GxIdeBpmAppDeclaration_mapSuggestedApplicationsToComboBoxModel","suggestedApplicationsNames","applicationName","_GxIdeBpmAppDeclaration_relevantDataInputHandler","mappingIndex","inputValue","relevantData","_GxIdeBpmAppDeclaration_selectApplicationCallbackHandler","applicationDeclarationData","selectApplicationCallback","_GxIdeBpmAppDeclaration_setApplicationData","call","_GxIdeBpmAppDeclaration_selectMappingCallbackHandler","parameter","returnedRelevantData","selectMappingCallback","currentRelevantDataOptions","indexOfReturnedRelevantData","indexOf","push","_GxIdeBpmAppDeclaration_updateApplicationData","applicationData","applicationComboBoxModel","startImgSrc","_GxIdeBpmAppDeclaration_suggestInputHandler","suggestedApplicationNames","suggestApplicationsCallback","_GxIdeBpmAppDeclaration_renderDataMappingsGrid","applicationDataToDisplay","length","__classPrivateFieldSet","h","class","title","scrollable","part","columnName","firstColName","firstColNameParameter","settingable","size","config","tabularGrid","colSize","common","secondColName","sortable","auto","obj","index","rowId","key","model","onInput","onClick","buttons","selectMapping","src","isAnimated","stateIconSrc","stateTitle","emptyState","stateDescription","description","componentWillLoad","Locale","getComponentStrings","el","render","Host","slot","suggestDebounce","inputDebounce","suggest","suggestOptions","onChange","selectApplication","cancelButton","confirmButton"],"sources":["src/components/bpm/application-declaration/bpm-app-declaration.scss?tag=gx-ide-bpm-app-declaration&encapsulation=shadow","src/components/bpm/application-declaration/bpm-app-declaration.tsx"],"sourcesContent":["@import \"../../../global/gx-ide-common.scss\";\n@import \"../../../global/gx-ide-mixins.scss\";\n@import \"../../../../node_modules/@genexus/mercury/dist/assets/scss/helpers.scss\";\n\n:host {\n display: grid;\n block-size: 100%;\n grid-template-rows: max-content 1fr max-content;\n overflow: auto;\n}\n\n.section {\n display: contents;\n}\n\n.header {\n display: grid;\n grid-template-columns: 1fr max-content;\n}\n\n.data-mapping-grid-container,\n.data-mapping-grid-container .field {\n overflow: auto;\n block-size: 100%;\n}\n\n.tabular-grid-application-declaration {\n overflow: auto;\n}\nch-tabular-grid.empty-result::part(main) {\n // WA to avoid scrollbar flickering when displaying the empty-state message\n overflow: hidden;\n}\n\n.pill-tag {\n // base styles for this class defined on \"gx-ide-common.scss\"\n min-inline-size: 40px;\n margin-inline-end: 10px;\n}\n\n@include tabular-grid-cell-layout(\n $tabular-grid-selector: \".tabular-grid-application-declaration\",\n $tabular-grid-cell-node-type: \"element\",\n $tabular-grid-affected-columns-nth-list: (\n 2\n )\n);\n\n// WA\n.tabular-grid-cell:nth-child(2) {\n padding: 0 !important;\n display: grid;\n align-items: stretch;\n justify-content: stretch;\n --ds-focus-border-width: none;\n}\n.tabular-grid-cell:nth-child(3) {\n padding: 0 !important;\n align-items: center !important;\n justify-content: center !important;\n}\n.tabular-grid {\n overflow: auto;\n}\n","import {\n Component,\n Host,\n h,\n Prop,\n State,\n Element,\n Event,\n EventEmitter,\n getAssetPath\n} from \"@stencil/core\";\n\nimport { MercuryBundles, getIconPath } from \"@genexus/mercury\";\n\nimport { Locale } from \"../../../common/locale\";\nimport { config } from \"../../../common/config\";\nimport { ComboBoxModel } from \"@genexus/chameleon-controls-library\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/button\",\n \"components/combo-box\",\n \"components/icon\",\n \"components/tabular-grid\",\n \"utils/elevation\",\n \"utils/form\",\n \"utils/layout\",\n \"utils/spacing\"\n];\n\nconst ADD_ICON = getIconPath({\n category: \"system\",\n name: \"add\",\n colorType: \"neutral\"\n});\nconst FILTER_ICON = getIconPath({\n category: \"window-tools\",\n name: \"filter\",\n colorType: \"on-elevation\"\n});\nconst MORE_ICON = getIconPath({\n category: \"system\",\n name: \"more-horizontal\",\n colorType: \"primary\"\n});\n\nconst SUGGEST_OPTIONS = {\n alreadyProcessed: true,\n autoExpand: false,\n hideMatchesAndShowNonMatches: false,\n highlightMatchedItems: false,\n matchCase: false,\n regularExpression: false,\n strict: false,\n renderActiveItemIconOnExpand: true\n};\n\n@Component({\n tag: \"gx-ide-bpm-app-declaration\",\n styleUrl: \"bpm-app-declaration.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/bpm-app-declaration\"]\n})\nexport class GxIdeBpmAppDeclaration {\n /**\n * The component hard-coded strings translations.\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #componentLocale: any;\n #animateEmptyState = true;\n #shortcutsSrc = getAssetPath(\n `./gx-ide-assets/bpm-app-declaration/shortcuts.json`\n );\n\n #ACCESS_CAPTION_MAP: Record<DataMappingAccess, string> = {\n // To be defined on componentWillLoad\n in: undefined,\n out: undefined,\n inout: undefined\n };\n\n @Element() el: HTMLGxIdeBpmAppDeclarationElement;\n\n /**\n * The application ComoBoxModel. When the component renders for the first time, it is required\n * to display the application typeIcon. Later, it is required to display the suggested application\n * options with the combo suggest.\n */\n @State() applicationComboBoxModel: ComboBoxModel = [];\n\n /**\n * Current value of the application declaration. Keep in mind that this property will be used by\n * the host to initialize the component, meaning it will assign the current declaration value.\n */\n @Prop({ mutable: true }) application: ApplicationDeclarationData;\n\n /**\n * Callback invoked when user cancels application declaration\n */\n @Prop() readonly cancelCallback: CancelCallback;\n\n /**\n * Callback invoked when user confirms application declaration\n */\n @Prop() readonly confirmCallback: ConfirmCallback;\n\n /**\n * Callback invoked when user select one of the options provided by the suggest\n */\n @Prop() readonly getDataMappingCallback: GetDataMappingCallback;\n\n /**\n * Callback invoked to get access to selection application dialog\n */\n @Prop() readonly selectApplicationCallback: SelectApplicationCallback;\n\n /**\n * Callback invoked when user press mapping auto-def button\n */\n @Prop() readonly selectMappingCallback: SelectMappingCallback;\n\n /**\n * Callback invoked to get options for application input suggest\n */\n @Prop() readonly suggestApplicationsCallback: SuggestApplicationsCallback;\n\n /**\n * @description Gets fired when the component has rendered for the first time.\n */\n @Event() componentDidRenderFirstTime: EventEmitter<string>;\n\n async componentWillLoad() {\n this.#componentLocale = await Locale.getComponentStrings(this.el);\n this.#setApplicationData(this.application.application);\n if (this.application.mappings.length === 0) {\n this.#animateEmptyState = false;\n }\n this.#setAccessCaptions();\n }\n\n #setAccessCaptions = () => {\n this.#ACCESS_CAPTION_MAP.in = this.#componentLocale.dataMappings.access.in;\n this.#ACCESS_CAPTION_MAP.out =\n this.#componentLocale.dataMappings.access.out;\n this.#ACCESS_CAPTION_MAP.inout =\n this.#componentLocale.dataMappings.access.inout;\n };\n\n #applicationInputChangedHandler = async (\n event: CustomEvent<string> | InputEvent\n ) => {\n const selectedApplicationName = event.detail as string;\n this.application.mappings = await this.getDataMappingCallback(\n selectedApplicationName\n );\n };\n\n #cancelCallbackHandler = () => {\n this.cancelCallback();\n };\n\n #clearApplicationHandler = () => {\n this.application = {\n application: {\n name: \"\",\n typeIcon: \"\"\n },\n mappings: []\n };\n };\n\n #confirmCallbackHandler = () => {\n this.confirmCallback(this.application);\n };\n\n #mapRelevantDataOptionsToComboBoxModel = (\n relevantDataOptions: string[]\n ): ComboBoxModel => {\n return relevantDataOptions.map(optionName => {\n return {\n caption: optionName,\n value: optionName\n };\n });\n };\n\n #mapSuggestedApplicationsToComboBoxModel = (\n suggestedApplicationsNames: string[]\n ): ComboBoxModel => {\n return suggestedApplicationsNames.map(applicationName => {\n return {\n caption: applicationName,\n value: applicationName\n };\n });\n };\n\n #relevantDataInputHandler =\n (mappingIndex: number) =>\n async (event: CustomEvent<string> | InputEvent) => {\n const inputValue = event.detail as string;\n this.application.mappings[mappingIndex].relevantData = inputValue;\n };\n\n #selectApplicationCallbackHandler = async () => {\n const applicationDeclarationData = await this.selectApplicationCallback();\n if (applicationDeclarationData) {\n this.#setApplicationData(applicationDeclarationData.application);\n this.application.mappings = applicationDeclarationData.mappings;\n }\n };\n\n #selectMappingCallbackHandler =\n (parameter: string, mappingIndex: number) => async () => {\n const returnedRelevantData = await this.selectMappingCallback(parameter);\n if (returnedRelevantData) {\n const currentRelevantDataOptions =\n this.application.mappings[mappingIndex].relevantDataOptions;\n\n const indexOfReturnedRelevantData =\n currentRelevantDataOptions.indexOf(returnedRelevantData);\n\n if (indexOfReturnedRelevantData === -1) {\n // returnedRelevantData is a new option. Add to combo-box.\n currentRelevantDataOptions.push(returnedRelevantData);\n }\n // Set as selected\n this.application.mappings[mappingIndex].relevantData =\n returnedRelevantData;\n\n this.#updateApplicationData();\n }\n };\n\n #setApplicationData = (applicationData: ApplicationData) => {\n if (applicationData) {\n const applicationName = applicationData.name;\n this.application.application.name = applicationName;\n this.applicationComboBoxModel = [\n {\n caption: applicationName,\n value: applicationName,\n startImgSrc: applicationData.typeIcon\n }\n ];\n }\n };\n\n #suggestInputHandler = async (event: CustomEvent<string> | InputEvent) => {\n const inputValue = event.detail as string;\n this.application.application.name = inputValue;\n const suggestedApplicationNames: string[] =\n await this.suggestApplicationsCallback(inputValue);\n\n this.applicationComboBoxModel =\n this.#mapSuggestedApplicationsToComboBoxModel(suggestedApplicationNames);\n };\n\n #updateApplicationData = () => {\n this.application = { ...this.application };\n };\n\n // Renders\n\n #renderDataMappingsGrid = (): Element => {\n const applicationDataToDisplay = this.application.mappings.length;\n if (applicationDataToDisplay) {\n // Set as animated for the next time.\n this.#animateEmptyState = true;\n }\n return (\n <div class=\"field-group data-mapping-grid-container\">\n <div class=\"field field-block\">\n <label class=\"spacing-body-inline-start label\">\n {this.#componentLocale.dataMappings.title}\n </label>\n <ch-tabular-grid\n class={{\n \"tabular-grid\": true,\n \"tabular-grid-application-declaration\": true,\n \"scrollable\": true,\n \"empty-result\": !applicationDataToDisplay\n }}\n part=\"ch-grid-data-mappings\"\n >\n <ch-tabular-grid-columnset class=\"tabular-grid-column-set\">\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnName={\n this.application.application?.typeIcon ===\n \"objects/transaction\"\n ? this.#componentLocale.dataMappings.firstColName\n : this.#componentLocale.dataMappings.firstColNameParameter\n }\n settingable={false}\n size={config.tabularGrid.colSize.common}\n ></ch-tabular-grid-column>\n\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnName={this.#componentLocale.dataMappings.secondColName}\n settingable={false}\n sortable={false}\n size={config.tabularGrid.colSize.common}\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n settingable={false}\n sortable={false}\n size={config.tabularGrid.colSize.auto}\n ></ch-tabular-grid-column>\n </ch-tabular-grid-columnset>\n\n {this.application.mappings.length ? (\n <ch-tabular-grid-rowset class=\"tabular-grid-rowset\">\n {this.application.mappings.map(\n (obj: DataMappingData, index) => (\n <ch-tabular-grid-row\n class=\"tabular-grid-row\"\n rowId={`${index}-${obj.parameter}`}\n key={`${index}-${obj.parameter}-grid-row`}\n >\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n <span class=\"pill-tag elevation-3\">\n {\n this.#ACCESS_CAPTION_MAP[\n obj.access as DataMappingAccess\n ]\n }\n </span>\n {obj.parameter}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n <ch-combo-box-render\n class=\"combo-box\"\n model={this.#mapRelevantDataOptionsToComboBoxModel(\n obj.relevantDataOptions\n )}\n value={obj.relevantData}\n key={`${index}-${obj.parameter}-combo-box`}\n onInput={this.#relevantDataInputHandler(index)}\n ></ch-combo-box-render>\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n <button\n data-index={index}\n onClick={this.#selectMappingCallbackHandler(\n obj.parameter,\n index\n )}\n class=\"button-tertiary button-icon-only\"\n aria-label={\n this.#componentLocale.buttons.selectMapping\n }\n title={this.#componentLocale.buttons.selectMapping}\n >\n <ch-image class=\"icon-md\" src={ADD_ICON}></ch-image>\n </button>\n </ch-tabular-grid-cell>\n </ch-tabular-grid-row>\n )\n )}\n </ch-tabular-grid-rowset>\n ) : (\n <ch-tabular-grid-rowset class=\"tabular-grid-rowset\">\n <ch-tabular-grid-rowset-empty>\n <gx-ide-empty-state\n isAnimated={this.#animateEmptyState}\n stateIconSrc={FILTER_ICON}\n stateTitle={this.#componentLocale.emptyState.title}\n stateDescription={\n this.#componentLocale.emptyState.description\n }\n ></gx-ide-empty-state>\n </ch-tabular-grid-rowset-empty>\n </ch-tabular-grid-rowset>\n )}\n </ch-tabular-grid>\n </div>\n </div>\n );\n };\n\n render() {\n return (\n <Host class=\"widget\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <section class=\"section\">\n <header slot=\"header\" class=\"header spacing-body\">\n <ch-combo-box-render\n class=\"combo-box\"\n value={this.application.application.name}\n model={this.applicationComboBoxModel}\n suggestDebounce={config.inputDebounce}\n suggest\n suggestOptions={SUGGEST_OPTIONS}\n onInput={this.#suggestInputHandler}\n onChange={this.#applicationInputChangedHandler}\n ></ch-combo-box-render>\n\n <div class=\"buttons-spacer\">\n <button\n onClick={this.#selectApplicationCallbackHandler}\n class=\"button-tertiary button-icon-only\"\n aria-label={this.#componentLocale.buttons.selectApplication}\n title={this.#componentLocale.buttons.selectApplication}\n >\n <ch-image class=\"icon-md\" src={MORE_ICON}></ch-image>\n </button>\n <button\n onClick={this.#clearApplicationHandler}\n class=\"button-secondary\"\n >\n Clear\n </button>\n </div>\n </header>\n\n {this.#renderDataMappingsGrid()}\n\n <footer class=\"control-footer spacing-body-block-end spacing-body-inline\">\n <div class=\"buttons-spacer\">\n <button\n class=\"button-secondary\"\n onClick={this.#cancelCallbackHandler}\n >\n {this.#componentLocale.buttons.cancelButton}\n </button>\n <button\n class=\"button-primary\"\n onClick={this.#confirmCallbackHandler}\n >\n {this.#componentLocale.buttons.confirmButton}\n </button>\n </div>\n </footer>\n </section>\n <ch-shortcuts src={this.#shortcutsSrc}></ch-shortcuts>\n </Host>\n );\n }\n}\n\nexport type ApplicationDeclarationData = {\n application?: ApplicationData;\n mappings: DataMappingData[];\n};\nexport type ApplicationData = {\n name: string;\n typeIcon: string;\n};\n\ntype DataMappingAccess = \"in\" | \"out\" | \"inout\";\n\nexport type DataMappingData = {\n parameter: string;\n access: DataMappingAccess;\n relevantDataOptions: string[];\n relevantData?: string;\n};\n\nexport type SuggestApplicationsCallback = (\n prefix: string\n) => Promise<string[] | undefined>;\n\nexport type SelectApplicationCallback = () => Promise<\n ApplicationDeclarationData | undefined\n>;\n\nexport type SelectMappingCallback = (parameter: string) => Promise<string>;\n\nexport type ConfirmCallback = (\n data: ApplicationDeclarationData\n) => Promise<void>;\n\nexport type CancelCallback = () => Promise<void>;\n\nexport type GetDataMappingCallback = (\n applicationName: string\n) => Promise<DataMappingData[]>;\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["convertActionToTreeViewItem","operations","treeData","forEach","operation","importCategoryTreeItem","id","caption","name","expanded","leaf","checkbox","push","openApiImportCss","CSS_BUNDLES","FILE_ICON","getIconPath","category","colorType","MENU_DELETE","CHECKBOX_ALL_CHECKED_VALUE","CHECKBOX_ALL_UNCHECKED_VALUE","GxIdeOpenAPIImport","_GxIdeOpenAPIImport__componentLocale","set","this","_GxIdeOpenAPIImport_renderedFirstTime","_GxIdeOpenAPIImport_shortcutsSrc","getAssetPath","_GxIdeOpenAPIImport_chShortcutsEl","_GxIdeOpenAPIImport_fileInputHiddenEl","_GxIdeOpenAPIImport_parentEl","_GxIdeOpenAPIImport_objectsTreeEl","_GxIdeOpenAPIImport_cancelImportHandler","cancelCallback","_GxIdeOpenAPIImport_handleImport","async","importCallback","selectedOperations","_GxIdeOpenAPIImport_objectsTreeCheckedItemsChangedHandler","event","detail","size","allItems","checkedItems","values","filter","node","item","checked","map","length","selectAllCheckboxValue","selectAllCheckboxIndeterminate","_GxIdeOpenAPIImport_handleSelectAll","__classPrivateFieldGet","updateAllItemsProperties","op","_GxIdeOpenAPIImport_objectTreeClickedHandler","selectedOperationForDescription","description","_GxIdeOpenAPIImport_removeFileSelection","selectedFile","value","actionListItems","_GxIdeOpenAPIImport_selectFileInputChangedHandler","target","files","loadCallback","_GxIdeOpenAPIImport_selectFileInputHandler","click","_GxIdeOpenAPIImport_renderFooter","h","class","checkedValue","unCheckedValue","main","selectAll","indeterminate","onInput","disabled","importingIsInProcess","part","slot","onClick","footer","cancel","import","componentDidRender","componentDidRenderFirstTime","emit","componentName","__classPrivateFieldSet","componentWillLoad","Locale","getComponentStrings","el","suspendShortcuts","suspend","render","Host","model","src","ref","role","htmlFor","header","fileNameLabel","autoFocus","type","readonly","placeholder","fileNamePlaceholder","startImgSrc","hidden","accept","onChange","removeFileSelection","title","selectFileButton","moduleFolderLabel","defaultParent","defaultValue","selectEntityCallback","selectParentCallback","labelPosition","onCheckedItemsChange","onSelectedItemsChange","procedureDescription","call"],"sources":["src/components/open-api-import/helpers.ts","src/components/open-api-import/open-api-import.scss?tag=gx-ide-open-api-import&encapsulation=shadow","src/components/open-api-import/open-api-import.tsx"],"sourcesContent":["import { ApiOperationData } from \"./open-api-import\";\nimport { TreeViewItemModel } from \"@genexus/chameleon-controls-library\";\n\nexport const convertActionToTreeViewItem = (\n operations: ApiOperationData[]\n): TreeViewItemModel[] => {\n const treeData: TreeViewItemModel[] = [];\n if (!operations) {\n return treeData;\n }\n operations.forEach(operation => {\n const importCategoryTreeItem: TreeViewItemModel = {\n id: operation.id,\n caption: `${operation.name}`,\n expanded: true,\n leaf: true,\n checkbox: true\n };\n treeData.push(importCategoryTreeItem);\n });\n return treeData;\n};\n","section {\n display: grid;\n block-size: 100%;\n grid-template-rows: max-content 1fr max-content;\n}\n\n.main {\n position: relative;\n display: contents;\n}\n\n.input-file {\n display: flex;\n}\n\n.field {\n width: 100%;\n}\n\n.control-header__operations,\n.control-header__description {\n padding-block-start: var(--mer-spacing--md);\n}\n\n.header__field-group {\n grid-template:\n \"import-file-label import-file-name buttons-container\" max-content\n \"module-folder-label module-folder module-folder\" max-content\n / max-content 1fr max-content;\n}\n.module-folder-name {\n grid-area: module-folder;\n}\n.module-folder-label {\n grid-area: module-folder-label;\n}\n.import-file-label {\n grid-area: import-file-label;\n}\n\n.header__buttons-container {\n grid-area: buttons-container;\n}\n\n.section-grid {\n display: grid;\n grid-template:\n \"top-content-operations top-content-description\" max-content\n \"operations-area operations-description\" 1fr\n / 1fr 1fr;\n background-color: var(--items-container__bg-color);\n border-style: var(--items-container__border-style);\n border-width: var(--items-container__border-width);\n border-color: var(--items-container__border-color);\n border-block-start: 0;\n overflow-y: auto;\n}\n\n.list-wrapper {\n grid-area: operations-area;\n border-inline-end: var(--section-common-border);\n}\n.label {\n margin-top: 6px !important;\n}\n\n.tree-operations::part(item__header) {\n // WA Since this is a tree without parent node.\n // This componnent should ideally by an action-list,\n // but at the time of writting it doesn't support checkboxes.\n padding-inline-start: 0;\n}\n\n.procedure-description {\n grid-area: operations-description;\n overflow: auto;\n text-align: justify;\n}\n\n.control-header__operations {\n grid-area: top-content-operations;\n background-color: var(--items-container__bg-color);\n}\n\n.control-header__description {\n grid-area: top-content-description;\n background-color: var(--items-container__bg-color);\n}\n.text-align-center {\n text-align: center;\n}\n","/* STENCIL IMPORTS */\nimport {\n Component,\n Host,\n h,\n Prop,\n Element,\n Event,\n EventEmitter,\n State,\n getAssetPath,\n Method\n} from \"@stencil/core\";\n/* OTHER LIBRARIES IMPORTS */\n/* CUSTOM IMPORTS */\nimport { Locale } from \"../../common/locale\";\nimport { EntityData } from \"../../common/types\";\nimport { getIconPath, MercuryBundles } from \"@genexus/mercury\";\nimport {\n TreeViewItemModel,\n TreeViewItemModelExtended,\n ChCheckboxCustomEvent\n} from \"@genexus/chameleon-controls-library\";\nimport { convertActionToTreeViewItem } from \"./helpers\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/button\",\n \"components/checkbox\",\n \"components/edit\",\n \"components/icon\",\n \"components/tree-view\",\n \"components/list-box\",\n \"utils/form\",\n \"utils/layout\",\n \"utils/spacing\",\n \"utils/typography\"\n];\n\nconst FILE_ICON = getIconPath({\n category: \"gemini-tools\",\n name: \"file\",\n colorType: \"on-elevation\"\n});\n\nconst MENU_DELETE = getIconPath({\n category: \"menus\",\n name: \"delete\",\n colorType: \"primary\"\n});\n\nconst CHECKBOX_ALL_CHECKED_VALUE = \"allChecked\";\nconst CHECKBOX_ALL_UNCHECKED_VALUE = \"allUnchecked\";\n\n@Component({\n tag: \"gx-ide-open-api-import\",\n styleUrl: \"open-api-import.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/open-api-import\"]\n})\nexport class GxIdeOpenAPIImport {\n #_componentLocale: any;\n #renderedFirstTime = false;\n #shortcutsSrc = getAssetPath(`./gx-ide-assets/new-object/shortcuts.json`);\n\n @Element() el: HTMLGxIdeOpenApiImportElement;\n\n #chShortcutsEl: HTMLChShortcutsElement;\n #fileInputHiddenEl!: HTMLInputElement;\n #parentEl!: HTMLGxIdeEntitySelectorElement;\n\n @State() actionListItems: TreeViewItemModel[] = [];\n @State() importingIsInProcess = false;\n @State() operations: ApiOperationData[] = [];\n @State() selectedFile: File;\n @State() selectedOperationForDescription: string;\n @State() selectedOperations: string[] = [];\n @State() selectAllCheckboxValue: string;\n @State() selectAllCheckboxIndeterminate: boolean = false;\n\n /**\n * Default value for the Module/Folder field.\n */\n @Prop() readonly defaultParent: EntityData;\n\n /**\n * If true it displays the component title on the header\n */\n @Prop() readonly displayTitle = false;\n\n /**\n * Callback invoked when the user wants to cancel the export process.\n */\n @Prop() readonly cancelCallback: CancelCallback;\n\n /**\n * Callback invoked when the user wants to initiate the import process.\n */\n @Prop() readonly importCallback: ImportCallback;\n\n /**\n * Callback invoked must be loaded the content for an specification API\n */\n @Prop() readonly loadCallback: LoadCallback;\n\n /**\n * Callback invoked when action is executed on Module/Folder filter (button '...').\n */\n @Prop() readonly selectParentCallback: SelectParentCallback;\n\n /**\n * @description Gets fired when the component has rendered for the first time.\n */\n @Event() componentDidRenderFirstTime: EventEmitter<string>;\n\n #objectsTreeEl!: HTMLChTreeViewRenderElement;\n\n componentDidRender() {\n if (!this.#renderedFirstTime) {\n this.componentDidRenderFirstTime.emit(\n this.#_componentLocale.componentName\n );\n this.#renderedFirstTime = true;\n }\n }\n\n async componentWillLoad() {\n this.#_componentLocale = await Locale.getComponentStrings(this.el);\n }\n\n /**\n * Suspends or reactivates the shortcuts\n */\n @Method()\n async suspendShortcuts(suspendShortcuts: boolean) {\n if (suspendShortcuts) {\n this.#chShortcutsEl.suspend = true;\n } else {\n this.#chShortcutsEl.suspend = false;\n }\n }\n\n // 9.LOCAL METHODS //\n #cancelImportHandler = () => {\n if (this.cancelCallback) {\n this.cancelCallback();\n }\n };\n\n #handleImport = async () => {\n await this.importCallback(this.selectedOperations);\n };\n\n #objectsTreeCheckedItemsChangedHandler = (\n event: CustomEvent<Map<string, TreeViewItemModelExtended>>\n ) => {\n if (event.detail.size === 0) {\n return;\n }\n const allItems = event.detail;\n const checkedItems = [...allItems.values()].filter(\n node => node.item.checked\n );\n this.selectedOperations = checkedItems.map(item => item.item.id);\n\n // Evaluate \"Select All\" checkbox state (siguiendo el patrón de kb-manager-import)\n if (allItems.size === checkedItems.length) {\n this.selectAllCheckboxValue = CHECKBOX_ALL_CHECKED_VALUE;\n this.selectAllCheckboxIndeterminate = false;\n } else if (checkedItems.length === 0) {\n this.selectAllCheckboxValue = CHECKBOX_ALL_UNCHECKED_VALUE;\n this.selectAllCheckboxIndeterminate = false;\n } else {\n this.selectAllCheckboxIndeterminate = true;\n }\n };\n\n #handleSelectAll = (event: ChCheckboxCustomEvent<string> | InputEvent) => {\n if (\"detail\" in event && this.#objectsTreeEl) {\n const checked =\n (event as ChCheckboxCustomEvent<string>).detail ===\n CHECKBOX_ALL_CHECKED_VALUE;\n // Usar updateAllItemsProperties como en kb-manager-import\n this.#objectsTreeEl.updateAllItemsProperties({ checked: checked });\n this.selectedOperations = checked ? this.operations.map(op => op.id) : [];\n this.selectAllCheckboxValue = checked\n ? CHECKBOX_ALL_CHECKED_VALUE\n : CHECKBOX_ALL_UNCHECKED_VALUE;\n this.selectAllCheckboxIndeterminate = false;\n }\n };\n\n #objectTreeClickedHandler = (\n event: CustomEvent<TreeViewItemModelExtended[]>\n ) => {\n this.selectedOperationForDescription = this.operations.filter(\n op => op.id === event.detail[0]?.item.id\n )[0]?.description;\n };\n\n #removeFileSelection = () => {\n this.selectedFile = null;\n this.#fileInputHiddenEl.value = null;\n this.operations = [];\n this.actionListItems = [];\n this.selectedOperationForDescription = null;\n };\n\n #selectFileInputChangedHandler = async (event: InputEvent) => {\n const target = event.target as HTMLInputElement;\n if (target.files?.length > 0) {\n this.selectedFile = target.files[0];\n this.operations = await this.loadCallback(\n this.selectedFile,\n this.#parentEl.value.id\n );\n this.actionListItems = convertActionToTreeViewItem(this.operations);\n }\n };\n\n #selectFileInputHandler = () => {\n this.#fileInputHiddenEl.click();\n };\n\n #renderFooter = (): HTMLElement => {\n return (\n <footer class=\"control-footer control-footer-space-between spacing-body-block-end spacing-body-inline\">\n <div class=\"buttons-spacer\">\n <ch-checkbox\n id=\"select-all-checkbox\"\n class=\"checkbox\"\n checkedValue={CHECKBOX_ALL_CHECKED_VALUE}\n unCheckedValue={CHECKBOX_ALL_UNCHECKED_VALUE}\n caption={this.#_componentLocale.main.selectAll}\n value={this.selectAllCheckboxValue}\n indeterminate={this.selectAllCheckboxIndeterminate}\n onInput={this.#handleSelectAll}\n disabled={this.importingIsInProcess || !this.operations?.length}\n part=\"select-all-checkbox\"\n ></ch-checkbox>\n </div>\n <div class=\"buttons-spacer\">\n <button\n class=\"button-secondary\"\n slot=\"footer-end\"\n part=\"button-cancel\"\n onClick={this.#cancelImportHandler}\n >\n {this.#_componentLocale.footer.cancel}\n </button>\n\n <button\n class=\"button-primary\"\n slot=\"footer-end\"\n part=\"button-confirm\"\n onClick={this.#handleImport}\n >\n {this.#_componentLocale.footer.import}\n </button>\n </div>\n </footer>\n );\n };\n\n render() {\n return (\n <Host class=\"widget\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <ch-shortcuts\n src={this.#shortcutsSrc}\n ref={(el: HTMLChShortcutsElement) =>\n (this.#chShortcutsEl = el as HTMLChShortcutsElement)\n }\n ></ch-shortcuts>\n <section>\n <header\n class=\"header control-header-with-border space-body spacing-body-inline spacing-body-block-start\"\n role=\"banner\"\n >\n <div class=\"field-group header__field-group\">\n <div class=\"import-file-label\">\n <div class=\"field field-block\">\n <label class=\"label\" htmlFor=\"file-name\">\n {this.#_componentLocale.header.fileNameLabel}\n </label>\n </div>\n </div>\n <div class=\"input-file\">\n <div class=\"field input-file\">\n <ch-edit\n autoFocus\n id=\"file-name\"\n class=\"input file\"\n part=\"file-name\"\n type=\"text\"\n readonly\n value={this.selectedFile?.name}\n placeholder={\n this.#_componentLocale.header.fileNamePlaceholder\n }\n startImgSrc={FILE_ICON}\n ></ch-edit>\n <input\n hidden\n type=\"file\"\n accept=\".json, .yaml\"\n onChange={this.#selectFileInputChangedHandler}\n ref={(el: HTMLInputElement) =>\n (this.#fileInputHiddenEl = el as HTMLInputElement)\n }\n />\n </div>\n <div class=\"cancel-btn \">\n <button\n aria-label={\n this.#_componentLocale.header.removeFileSelection\n }\n title={this.#_componentLocale.header.removeFileSelection}\n id=\"reset-all-button\"\n class=\"button-tertiary button-icon-only\"\n part=\"reset-all-button\"\n onClick={this.#removeFileSelection}\n >\n <ch-image class=\"icon-md\" src={MENU_DELETE}></ch-image>\n </button>\n </div>\n </div>\n\n <div class=\"header__buttons-container\">\n <button\n id=\"select-file-load-button\"\n class=\"button-primary\"\n part=\"select-file-load-button\"\n onClick={this.#selectFileInputHandler}\n disabled={this.importingIsInProcess}\n >\n {this.#_componentLocale.header.selectFileButton}\n </button>\n </div>\n <div class=\"module-folder-label\">\n <div class=\"field field-block\">\n <label class=\"label\">\n {this.#_componentLocale.header.moduleFolderLabel}\n </label>\n </div>\n </div>\n <div class=\"field module-folder-name \">\n <gx-ide-entity-selector\n value={this.defaultParent}\n defaultValue={this.defaultParent}\n selectEntityCallback={this.selectParentCallback}\n labelPosition=\"none\"\n ref={(el: HTMLGxIdeEntitySelectorElement) =>\n (this.#parentEl = el as HTMLGxIdeEntitySelectorElement)\n }\n class=\"module-folder\"\n ></gx-ide-entity-selector>\n </div>\n </div>\n </header>\n\n <main class=\"main\">\n <div class=\"section-grid\">\n <h2\n id=\"operations-title\"\n class=\"control-header control-header-with-border control-header__operations subtitle-regular-xs text-align-center spacing-body-inline\"\n >\n {this.#_componentLocale.main.operations}\n </h2>\n\n <div\n class=\"list-wrapper field-group spacing-body-block-start spacing-body-inline scrollable\"\n role=\"region\"\n aria-labelledby=\"operations-title\"\n >\n <ch-tree-view-render\n class=\"tree-view tree-operations\"\n model={this.actionListItems}\n show-lines=\"last\"\n onCheckedItemsChange={\n this.#objectsTreeCheckedItemsChangedHandler\n }\n onSelectedItemsChange={this.#objectTreeClickedHandler}\n ref={el =>\n (this.#objectsTreeEl = el as HTMLChTreeViewRenderElement)\n }\n ></ch-tree-view-render>\n </div>\n\n <h2\n id=\"description-title\"\n class=\"control-header control-header-with-border control-header__description subtitle-regular-xs text-align-center spacing-body-inline\"\n >\n {this.#_componentLocale.main.procedureDescription}\n </h2>\n\n <div\n class=\"procedure-description field-group spacing-body-block-start spacing-body-inline scrollable\"\n role=\"region\"\n aria-labelledby=\"description-title\"\n >\n {this.selectedOperationForDescription}\n </div>\n </div>\n </main>\n {this.#renderFooter()}\n </section>\n </Host>\n );\n }\n}\n\nexport type ApiOperationData = {\n id: string;\n name: string;\n description: string;\n};\nexport type SelectionEventDetail = {\n itemId: string;\n itemValue: string;\n};\n\nexport type CancelCallback = () => Promise<void>;\nexport type ImportCallback = (operationIds: string[]) => Promise<boolean>;\nexport type SelectParentCallback = () => Promise<EntityData | undefined>;\nexport type LoadCallback = (\n source: string | File,\n parentId: string\n) => Promise<ApiOperationData[]>;\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["ACTIVE_ITEM_DEFAULT_ICON","getIconPath","category","name","colorType","convertItemsNodeListToFlattenedTreeViewModel","itemsList","checkboxType","itemsListFlattenedTreeViewModel","processNode","item","startImgSrc","active","iconStart","leaf","nodes","length","checkbox","metaData","JSON","stringify","versionType","type","push","caption","checked","endImgSrc","iconEnd","expanded","id","toString","items","metadata","parts","selected","forEach","childNode","convertItemsListToTreeViewModel","itemsListTreeViewModel","order","parseInt","findItemNode","itemNode","result","findItemInArray","itemsNodes","setAllLeafsCheckedFalse","uncheck","unselectAllNodes","unselect","checkItems","idsChecked","itemFind","expandItems","selectItems","idsSelected","searchInNode","node","parents","searchParentsItems","ids","rootItem","results","findFirstActiveNode","findActiveWithPath","nodeList","currentPath","nodePath","path","selectKbItemsCss","CSS_BUNDLES","SYSTEM_SEARCH_ICON","VIEW_AS_TREE_ID","VIEW_AS_LIST_ID","TOGGLE_CHECKBOXES_CHECKED_VALUE","GxIdeSelectKbItems","_GxIdeSelectKbItems__componentLocale","set","this","_GxIdeSelectKbItems_checkedNodesIds","_GxIdeSelectKbItems_chShortcutsEl","_GxIdeSelectKbItems_selectedNodesIds","_GxIdeSelectKbItems_shortcutsSrc","getAssetPath","_GxIdeSelectKbItems_updatedModelList","_GxIdeSelectKbItems_viewItemsAsModel","_GxIdeSelectKbItems_treeViewRenderEl","_GxIdeSelectKbItems_cancelHandler","cancelCallback","_GxIdeSelectKbItems_checkedItemsChangeHandler","async","e","checkedNodesIds","detail","__classPrivateFieldSet","__classPrivateFieldGet","checkedChanged","_GxIdeSelectKbItems_confirmHandler","confirmCallback","_GxIdeSelectKbItems_contextMenuHandler","itemContextMenuCallback","info","isSelected","find","updateItemsProperties","clientX","contextmenuEvent","clientY","selection","_GxIdeSelectKbItems_executeDialogAction","callback","_GxIdeSelectKbItems_patternSearchValueChangedHandler","event","searchPatternValue","_GxIdeSelectKbItems_renderActionButtons","h","dialogActions","map","action","class","part","onClick","call","disabled","loading","_GxIdeSelectKbItems_renderFooter","footer","cancel","select","_GxIdeSelectKbItems_selectedItemsChangeHandler","selectedNodesIds","selectionChanged","_GxIdeSelectKbItems_toggleAndSelectNodesInModelItems","selectedItemsIds","nodesToToggle","newItemsSelected","newItemsExpanded","_GxIdeSelectKbItems_updateViews","_GxIdeSelectKbItems_toggleCheckedNodesInModelItems","newItemsList","nodeVersionsListTreeModel","nodeListFlattenedTreeModel","_GxIdeSelectKbItems_viewItemsAsChangedHandler","selectedViewType","nodesVersionsViewType","_GxIdeSelectKbItems_toggleCheckboxesChangedHandler","toggleCheckboxes","_GxIdeSelectKbItems_scrollIntoActiveVersionNode","doScrollIntoView","activeItemNode","scrollIntoVisible","activeItemCallback","watchNodeListHandler","componentWillLoad","Locale","getComponentStrings","el","value","main","tree","suspendShortcuts","suspend","updateSelection","render","Host","model","src","ref","htmlFor","onChange","checkedValue","onInput","placeholder","header","searchPatternPlaceholder","containerRef","activeItem","loaderTitle","loader","title","show","expandableButton","onItemContextmenu","onCheckedItemsChange","onSelectedItemsChange","expandOnClick","multiSelection","filter","filterType"],"sources":["src/components/select-kb-items/helpers.tsx","src/components/select-kb-items/select-kb-items.scss?tag=gx-ide-select-kb-items&encapsulation=shadow","src/components/select-kb-items/select-kb-items.tsx"],"sourcesContent":["import { ItemNode, CheckboxType, ActiveNode } from \"./select-kb-items\";\nimport { TreeViewItemModel } from \"@genexus/chameleon-controls-library\";\nimport { getIconPath } from \"@genexus/mercury\";\n\nexport const ACTIVE_ITEM_DEFAULT_ICON = getIconPath({\n category: \"system\",\n name: \"check-circle\",\n colorType: \"primary\"\n});\n\nexport const convertItemsNodeListToFlattenedTreeViewModel = (\n itemsList: ItemNode[],\n checkboxType: CheckboxType\n): TreeViewItemModel[] => {\n const itemsListFlattenedTreeViewModel: TreeViewItemModel[] = [];\n\n const processNode = (item: ItemNode) => {\n const startImgSrc =\n item.active && !item.iconStart\n ? ACTIVE_ITEM_DEFAULT_ICON\n : item.iconStart;\n const leaf = !item.nodes?.length;\n const checkbox =\n checkboxType === \"all\" ||\n (checkboxType === \"custom\" && item.checkbox) ||\n (checkboxType === \"leaf\" && leaf);\n const metaData = JSON.stringify({\n versionType: item.type\n });\n itemsListFlattenedTreeViewModel.push({\n caption: item.name,\n checkbox: checkbox,\n checked: item.checked,\n startImgSrc: startImgSrc,\n endImgSrc: item.iconEnd,\n expanded: item.expanded,\n id: item.id.toString(),\n items: null,\n leaf: leaf,\n metadata: metaData,\n parts: item.parts,\n selected: item.selected\n });\n\n if (item.nodes) {\n item.nodes.forEach(childNode => processNode(childNode));\n }\n };\n\n itemsList.forEach(item => processNode(item));\n return itemsListFlattenedTreeViewModel;\n};\n\nexport const convertItemsListToTreeViewModel = (\n itemsList: ItemNode[],\n checkboxType: CheckboxType\n): TreeViewItemModel[] => {\n const itemsListTreeViewModel: TreeViewItemModel[] = [];\n itemsList.forEach(item => {\n const startImgSrc =\n item.active && !item.iconStart\n ? ACTIVE_ITEM_DEFAULT_ICON\n : item.iconStart;\n const leaf = !item.nodes?.length;\n const checkbox =\n checkboxType === \"all\" ||\n (checkboxType === \"custom\" && item.checkbox) ||\n (checkboxType === \"leaf\" && leaf);\n const expanded = item.expanded;\n const iconStart = startImgSrc;\n const iconEnd = item.iconEnd;\n const metaData = JSON.stringify({\n versionType: item.type\n });\n const order = parseInt(item.id);\n itemsListTreeViewModel.push({\n caption: item.name,\n checkbox: checkbox,\n checked: item.checked,\n startImgSrc: iconStart,\n endImgSrc: iconEnd,\n expanded: expanded,\n id: item.id.toString(),\n items: !leaf\n ? convertItemsListToTreeViewModel(item.nodes, checkboxType)\n : null,\n leaf: leaf,\n metadata: metaData,\n parts: item.parts,\n order: order,\n selected: item.selected\n });\n });\n\n return itemsListTreeViewModel;\n};\n\nconst findItemNode = (id: string, item: ItemNode): ItemNode | null => {\n if (item.id === id) {\n return item;\n }\n\n if (item.nodes) {\n for (const itemNode of item.nodes) {\n const result = findItemNode(id, itemNode);\n if (result) {\n return result;\n }\n }\n }\n return null;\n};\n\nfunction findItemInArray(itemsNodes: ItemNode[], id: string): ItemNode | null {\n for (const item of itemsNodes) {\n const result = findItemNode(id, item);\n if (result) {\n return result;\n }\n }\n return null;\n}\nconst setAllLeafsCheckedFalse = (itemsList: ItemNode[]): ItemNode[] => {\n const uncheck = (itemNode: ItemNode) => {\n itemNode.checked = false;\n if (itemNode.nodes?.length) {\n itemNode.nodes.forEach(childNode => uncheck(childNode));\n }\n };\n\n itemsList.forEach(item => uncheck(item));\n return itemsList;\n};\n\nexport const unselectAllNodes = (itemsList: ItemNode[]) => {\n const unselect = (itemNode: ItemNode) => {\n itemNode.selected = false;\n if (itemNode.nodes?.length) {\n itemNode.nodes.forEach(childNode => unselect(childNode));\n }\n };\n\n itemsList.forEach(item => unselect(item));\n};\n\nexport const checkItems = (\n itemsList: ItemNode[],\n idsChecked: string[]\n): ItemNode[] => {\n setAllLeafsCheckedFalse(itemsList);\n idsChecked.forEach(id => {\n const itemFind = findItemInArray(itemsList, id);\n if (itemFind) {\n itemFind.checked = true;\n }\n });\n\n return itemsList;\n};\n\nexport const expandItems = (\n itemsList: ItemNode[],\n idsChecked: string[]\n): ItemNode[] => {\n idsChecked.forEach(id => {\n const itemFind = findItemInArray(itemsList, id);\n if (itemFind) {\n itemFind.expanded = true;\n }\n });\n\n return itemsList;\n};\n\nexport const selectItems = (\n itemsList: ItemNode[],\n idsSelected: string[]\n): ItemNode[] => {\n idsSelected.forEach(id => {\n const itemFind = findItemInArray(itemsList, id);\n if (itemFind) {\n itemFind.selected = true;\n }\n });\n return itemsList;\n};\n\nfunction searchInNode(item: ItemNode, id: string): string[] | null {\n // If the current node is the searched node, we return an empty list (it has no parents in this branch)\n if (item.id === id) {\n return [];\n }\n\n // We traverse each child looking for the target node\n if (item.nodes?.length) {\n for (const node of item.nodes) {\n const parents = searchInNode(node, id);\n if (parents !== null) {\n // If we find it, we include the current node at the beginning of the path and return\n return [item.id, ...parents];\n }\n }\n }\n return null;\n}\n\nexport const searchParentsItems = (\n items: ItemNode[],\n ids: string[]\n): string[] | null => {\n const parents: string[] = [];\n for (const id of ids) {\n for (const rootItem of items) {\n const results = searchInNode(rootItem, id);\n if (results !== null) {\n results.forEach(result => {\n parents.push(result);\n });\n }\n }\n }\n return parents;\n};\n\n/**\n * Recursively searches for the first node with the active=true property\n * @param nodes Array of nodes to search through\n * @returns An object with caption, iconStart, and path to the first active node found, or null if none is found\n */\nexport const findFirstActiveNode = (nodes: ItemNode[]): ActiveNode | null => {\n // Helper function that keeps track of the path during recursion\n const findActiveWithPath = (\n nodeList: ItemNode[],\n currentPath: string[] = []\n ): ActiveNode | null => {\n // Base case: if nodes is undefined or empty\n if (!nodeList || nodeList.length === 0) {\n return null;\n }\n\n // Iterate through each node in the array\n for (const node of nodeList) {\n // Create a new path that includes the current node\n const nodePath = [...currentPath, node.id];\n\n // Check if the current node is active\n if (node.active === true) {\n return {\n caption: node.name,\n iconStart: node.iconStart,\n path: nodePath\n };\n }\n\n // If the node has children, search through them with the updated path\n if (node.nodes && node.nodes.length > 0) {\n const result = findActiveWithPath(node.nodes, nodePath);\n // If we find an active node in this subtree, return it immediately\n if (result !== null) {\n return result;\n }\n }\n }\n\n // No active node found in any of the nodes\n return null;\n };\n\n // Start the search with an empty path\n return findActiveWithPath(nodes);\n};\n",":host {\n display: grid;\n block-size: 100%;\n grid-template-rows: max-content 1fr max-content;\n}\n\n.header.has-active-item {\n grid-area: header;\n}\n\n.section {\n display: contents;\n}\n\n// header\n.header {\n grid-template-areas:\n \"view-mode view-mode\"\n \"pattern-filter active-item\";\n grid-template-columns: minmax(150px, 350px) max-content;\n --field-group__column-gap: var(\n --mer-spacing--md\n ); // WA: OVerriding this variable is not a good approeach to reduce the gap.TODO: Think about the right solution.\n}\n.view-mode__toggle-checkboxes {\n grid-area: view-mode;\n}\n.pattern-filter {\n grid-area: pattern-filter;\n max-inline-size: 350px;\n}\n\n.active-item {\n grid-area: active-item;\n background-color: var(--mer-surface__elevation--01);\n border-radius: var(--mer-border__radius--sm);\n padding: var(--mer-spacing--xs) var(--mer-spacing--sm);\n display: flex;\n align-items: center;\n gap: var(--mer-spacing--xs);\n}\n.active-item {\n &__icon-container {\n display: contents;\n }\n &__icon {\n pointer-events: none; // We do not want the icon to change the colors, since the clickable area is the caption only\n }\n &__link {\n text-decoration: underline;\n // TODO: There should be a class in Merucry to apply link styles\n color: var(--mer-text__primary);\n cursor: pointer;\n &:hover {\n color: var(--mer-text__primary--hover);\n }\n &:active {\n color: var(--mer-text__primary--active);\n }\n }\n}\n\n.view-mode__toggle-checkboxes {\n grid-template-columns: max-content max-content;\n}\n.field__items-view-type {\n align-items: center;\n .label {\n margin-block-start: 0 !important; // WA to center label with radio-group\n }\n}\n.field__toggle-checkboxes {\n .label {\n margin-block-start: 0 !important; // WA to center label with radio-group\n }\n}\n\n.trees {\n position: relative;\n}\n","import {\n Component,\n Element,\n getAssetPath,\n Host,\n h,\n Prop,\n State,\n Watch,\n Method\n} from \"@stencil/core\";\n\nimport {\n ChCheckboxCustomEvent,\n TreeViewItemModel,\n TreeViewItemModelExtended\n} from \"@genexus/chameleon-controls-library\";\n\nimport {\n checkItems,\n convertItemsListToTreeViewModel,\n convertItemsNodeListToFlattenedTreeViewModel,\n expandItems,\n searchParentsItems,\n selectItems,\n unselectAllNodes,\n findFirstActiveNode\n} from \"./helpers\";\nimport { getIconPath, MercuryBundles } from \"@genexus/mercury\";\nimport { Locale } from \"../../common/locale\";\nimport { ContextMenuInfo } from \"../../common/types\";\nimport { RadioGroupItemModel } from \"@genexus/chameleon-controls-library/dist/types/components/radio-group/types\";\n\nimport { ACTIVE_ITEM_DEFAULT_ICON } from \"./helpers\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"chameleon/scrollbar\",\n \"components/tooltip\",\n \"components/tree-view\",\n \"utils/form--full\",\n \"utils/layout\",\n \"utils/spacing\",\n \"utils/typography\"\n];\n\nconst SYSTEM_SEARCH_ICON = getIconPath({\n category: \"system\",\n name: \"search\",\n colorType: \"on-surface\"\n});\n\nconst VIEW_AS_TREE_ID: NodesVersionsViewType = \"tree\";\nconst VIEW_AS_LIST_ID: NodesVersionsViewType = \"list\";\n\nconst TOGGLE_CHECKBOXES_CHECKED_VALUE = \"on\";\n\n@Component({\n tag: \"gx-ide-select-kb-items\",\n styleUrl: \"select-kb-items.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/select-kb-items\"]\n})\nexport class GxIdeSelectKbItems {\n #_componentLocale: any;\n\n #checkedNodesIds: string[] = [];\n #chShortcutsEl: HTMLChShortcutsElement;\n #selectedNodesIds: string[] = [];\n #shortcutsSrc = getAssetPath(\n `./gx-ide-assets/select-kb-items/shortcuts.json`\n );\n #updatedModelList: ItemNode[] = [];\n\n #viewItemsAsModel: RadioGroupItemModel[];\n\n @Element() el: HTMLGxIdeSelectKbItemsElement;\n #treeViewRenderEl: HTMLChTreeViewRenderElement;\n\n /**\n * Represents the active version node caption and icon (if any)\n */\n @State() activeItemNode: ActiveNode;\n\n /**\n * Represents the nodes list model\n */\n @State() nodeListFlattenedTreeModel: TreeViewItemModel[] = [];\n\n /**\n * To show a loader when the component is loading\n */\n @State() loading: boolean = true;\n\n /**\n * View type for the nodes.\n */\n @State() nodesVersionsViewType: NodesVersionsViewType = \"tree\";\n\n /**\n * Represents the nodes tree model\n */\n @State() nodeVersionsListTreeModel: TreeViewItemModel[] = [];\n\n /**\n * \"Search Pattern\" input value, used to filter the nodes tree/list.\n */\n @State() searchPatternValue: string = null;\n\n /**\n * It maps to the ch-tree-view-render \"toggleCheckboxes\" property.\n */\n @State() toggleCheckboxes: boolean = true;\n\n /**\n * Callback emitted when the user clicks on the \"Active item\"\n */\n @Prop() readonly activeItemCallback?: () => Promise<void>;\n\n /**\n * Callback emitted when the 'cancel' button is pressed\n */\n @Prop() readonly cancelCallback?: () => Promise<void>;\n\n /**\n * Defines which nodes of the component have checkboxes.\n */\n @Prop() readonly checkboxType: CheckboxType;\n\n /**\n * Define if a item node is expanded on click interaction. If false item-node will only be expanded on double click.\n */\n @Prop() readonly expandOnClick: boolean = true;\n\n /**\n * Callback emitted when the items checked items change\n */\n @Prop() readonly checkedChanged?: (checkedItems: string[]) => Promise<void>;\n\n /**\n * Callback emitted when the 'select' button is pressed\n */\n @Prop() readonly confirmCallback?: (checkedItems: string[]) => Promise<void>;\n\n /**\n * Set of additional actions (callbacks) to those already provided by default by the selector (cancelCallback and selectCallback)\n */\n @Prop() readonly dialogActions: DialogAction[] = [];\n\n /**\n * Callback emitted when the user right click on an item\n */\n @Prop() readonly itemContextMenuCallback: (\n info: ContextMenuInfo\n ) => Promise<void>;\n\n /**\n * Represents the itemLis list model\n */\n @Prop() readonly itemsList: ItemNode[] = [];\n\n @Watch(\"itemsList\")\n watchNodeListHandler(newItemsList: ItemNode[]) {\n if (newItemsList.length > 0) {\n this.loading = false;\n }\n this.#updateViews(newItemsList);\n\n // Check and update activeItem\n this.activeItemNode = findFirstActiveNode(newItemsList);\n }\n\n /**\n * This define if the selection is unique or not\n */\n @Prop() readonly multiSelection?: boolean = false;\n\n /**\n * Callback emitted when the items selection change\n */\n @Prop() readonly selectionChanged?: (selectedItem: string[]) => Promise<void>;\n\n async componentWillLoad() {\n this.#_componentLocale = await Locale.getComponentStrings(this.el);\n this.#viewItemsAsModel = [\n { value: VIEW_AS_TREE_ID, caption: this.#_componentLocale.main.tree },\n { value: VIEW_AS_LIST_ID, caption: \"List\" }\n ];\n this.watchNodeListHandler(this.itemsList);\n }\n\n /**\n * Suspends or reactivates the shortcuts\n */\n @Method()\n async suspendShortcuts(suspendShortcuts: boolean) {\n if (suspendShortcuts) {\n this.#chShortcutsEl.suspend = true;\n } else {\n this.#chShortcutsEl.suspend = false;\n }\n }\n\n /**\n * Allow to update the selected items\n */\n @Method()\n async updateSelection(selectedItemsIds: string[]) {\n // first clear selected\n this.#treeViewRenderEl.updateItemsProperties(this.#selectedNodesIds, {\n selected: false\n });\n // then select\n this.#treeViewRenderEl.updateItemsProperties(selectedItemsIds, {\n selected: true\n });\n }\n\n #cancelHandler = () => {\n if (this.cancelCallback) {\n this.cancelCallback();\n }\n };\n\n #checkedItemsChangeHandler = async (\n e: CustomEvent<Map<string, TreeViewItemModelExtended>>\n ) => {\n const checkedNodesIds: string[] = [];\n e.detail.forEach(node => {\n node.item.checked && checkedNodesIds.push(node.item.id);\n });\n this.#checkedNodesIds = checkedNodesIds;\n this.#updatedModelList = checkItems(this.itemsList, this.#checkedNodesIds);\n\n if (this.checkedChanged) {\n this.checkedChanged(this.#checkedNodesIds);\n }\n };\n\n #confirmHandler = () => {\n if (this.confirmCallback) {\n this.confirmCallback(this.#checkedNodesIds);\n }\n };\n\n #contextMenuHandler = async (\n e: CustomEvent<{\n id: string;\n itemRef: HTMLChTreeViewItemElement;\n metadata: string;\n contextmenuEvent: PointerEvent;\n }>\n ) => {\n if (this.itemContextMenuCallback) {\n let info: ContextMenuInfo;\n const isSelected = this.#selectedNodesIds.find(id => id === e.detail.id);\n if (!this.#selectedNodesIds.length || !isSelected) {\n await this.#treeViewRenderEl.updateItemsProperties(\n this.#selectedNodesIds,\n { selected: false }\n );\n await this.#treeViewRenderEl.updateItemsProperties([e.detail.id], {\n selected: true\n });\n info = {\n clientX: e.detail.contextmenuEvent.clientX,\n clientY: e.detail.contextmenuEvent.clientY,\n selection: [e.detail.id]\n };\n } else {\n info = {\n clientX: e.detail.contextmenuEvent.clientX,\n clientY: e.detail.contextmenuEvent.clientY,\n selection: this.#selectedNodesIds\n };\n }\n this.itemContextMenuCallback(info);\n }\n };\n\n #executeDialogAction = (\n callback: (checkedNodesIds: string[], selectedNodesIds: string[]) => void\n ) => {\n return () => {\n callback(this.#checkedNodesIds, this.#selectedNodesIds);\n };\n };\n\n #patternSearchValueChangedHandler = (\n event: CustomEvent<string> | InputEvent\n ) => {\n this.searchPatternValue = event.detail.toString();\n };\n\n #renderActionButtons = (): HTMLElement[] => {\n return (\n <div>\n {this.dialogActions.map(action => {\n return (\n <button\n class={\"button-tertiary\"}\n part={`button button-${action.name}`}\n onClick={this.#executeDialogAction(action.callback)}\n disabled={this.loading}\n >\n {action.name}\n </button>\n );\n })}\n </div>\n );\n };\n\n #renderFooter = (): HTMLElement => {\n return (\n <footer class=\"footer control-footer-with-border spacing-body-inline spacing-body-block-end control-footer-space-between\">\n {this.#renderActionButtons()}\n <div class=\"buttons-spacer \">\n {this.cancelCallback && (\n <button\n class={\"button-secondary\"}\n part={\"cancel-button\"}\n onClick={this.#cancelHandler}\n >\n {this.#_componentLocale.footer.cancel}\n </button>\n )}\n {this.confirmCallback && (\n <button\n class={\"button-primary\"}\n part={\"confirm-button\"}\n onClick={this.#confirmHandler}\n disabled={this.loading}\n >\n {this.#_componentLocale.footer.select}\n </button>\n )}\n </div>\n </footer>\n );\n };\n\n #selectedItemsChangeHandler = (\n e: CustomEvent<TreeViewItemModelExtended[]>\n ) => {\n const selectedNodesIds: string[] = [];\n unselectAllNodes(this.itemsList);\n e.detail.forEach(node => {\n selectedNodesIds.push(node.item.id);\n });\n this.#selectedNodesIds = selectedNodesIds;\n if (this.selectionChanged) {\n this.selectionChanged(this.#selectedNodesIds);\n }\n\n this.#updatedModelList = selectItems(this.itemsList, selectedNodesIds);\n };\n\n #toggleAndSelectNodesInModelItems = async (selectedItemsIds: string[]) => {\n const nodesToToggle = searchParentsItems(this.itemsList, selectedItemsIds);\n const newItemsSelected = selectItems(this.itemsList, selectedItemsIds);\n const newItemsExpanded = expandItems(newItemsSelected, nodesToToggle);\n this.#updateViews(newItemsExpanded);\n };\n\n #toggleCheckedNodesInModelItems = async (selectedItemsIds: string[]) => {\n const nodesToToggle = searchParentsItems(this.itemsList, selectedItemsIds);\n const newItemsExpanded = expandItems(this.itemsList, nodesToToggle);\n this.#updateViews(newItemsExpanded);\n };\n\n #updateViews = (newItemsList: ItemNode[]) => {\n this.nodeVersionsListTreeModel = convertItemsListToTreeViewModel(\n newItemsList,\n this.checkboxType\n );\n\n this.nodeListFlattenedTreeModel =\n convertItemsNodeListToFlattenedTreeViewModel(\n newItemsList,\n this.checkboxType\n );\n };\n\n #viewItemsAsChangedHandler = async (event: CustomEvent<string>) => {\n const selectedViewType = event.detail as NodesVersionsViewType;\n this.nodesVersionsViewType = selectedViewType;\n if (this.nodesVersionsViewType === \"tree\") {\n await this.#toggleAndSelectNodesInModelItems(this.#selectedNodesIds);\n await this.#toggleCheckedNodesInModelItems(this.#checkedNodesIds);\n }\n this.#updateViews(this.#updatedModelList);\n };\n\n #toggleCheckboxesChangedHandler = (\n event: ChCheckboxCustomEvent<string> | InputEvent\n ) => {\n this.toggleCheckboxes = event.detail === TOGGLE_CHECKBOXES_CHECKED_VALUE;\n };\n\n #scrollIntoActiveVersionNode = () => {\n const doScrollIntoView =\n this.#treeViewRenderEl && this.activeItemNode?.path;\n if (doScrollIntoView) {\n this.#treeViewRenderEl.scrollIntoVisible(this.activeItemNode.path);\n }\n\n if (this.activeItemCallback) {\n this.activeItemCallback();\n }\n };\n\n render() {\n return (\n <Host class=\"widget\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <ch-shortcuts\n src={this.#shortcutsSrc}\n ref={(el: HTMLChShortcutsElement) =>\n (this.#chShortcutsEl = el as HTMLChShortcutsElement)\n }\n ></ch-shortcuts>\n <section class=\"section\">\n <header class=\"header control-header field-group spacing-body-block-start spacing-body-inline\">\n <div class=\"field-group view-mode__toggle-checkboxes\">\n <div class=\"field field-inline field__items-view-type\">\n <label class=\"label\" htmlFor=\"view-mode\">\n Select view mode:\n </label>\n <ch-radio-group-render\n class=\"radio-group\"\n id=\"view-mode\"\n model={this.#viewItemsAsModel}\n onChange={this.#viewItemsAsChangedHandler}\n value={this.#viewItemsAsModel[0].value}\n ></ch-radio-group-render>\n </div>\n\n {this.checkboxType !== \"none\" && (\n <div class=\"field field-inline field__toggle-checkboxes\">\n <label class=\"label\" htmlFor=\"toggle-checkboxes\">\n Toggle Checkboxes\n </label>\n <ch-checkbox\n class=\"checkbox\"\n id=\"toggle-checkboxes\"\n checkedValue={TOGGLE_CHECKBOXES_CHECKED_VALUE}\n value={TOGGLE_CHECKBOXES_CHECKED_VALUE}\n onInput={this.#toggleCheckboxesChangedHandler}\n ></ch-checkbox>\n </div>\n )}\n </div>\n\n <ch-edit\n class=\"input pattern-filter\"\n placeholder={\n this.#_componentLocale.header.searchPatternPlaceholder\n }\n startImgSrc={SYSTEM_SEARCH_ICON}\n onInput={this.#patternSearchValueChangedHandler}\n ></ch-edit>\n {this.activeItemNode && (\n <div class=\"active-item\">\n <span\n class=\"active-item__icon-container\"\n // make this span the icon container, to prevent icon state changes when\n // interacting with div.active-item\n >\n <ch-image\n class=\"icon-md active-item__icon\"\n src={\n this.activeItemNode.iconStart || ACTIVE_ITEM_DEFAULT_ICON\n }\n containerRef={null}\n ></ch-image>\n </span>\n {this.#_componentLocale.header.activeItem}\n <button\n class=\"active-item__link\"\n onClick={this.#scrollIntoActiveVersionNode}\n >\n {this.activeItemNode.caption}\n </button>\n </div>\n )}\n </header>\n\n <div class=\"spacing-body-inline-start trees\">\n {this.loading ? (\n <gx-ide-loader\n loaderTitle={this.#_componentLocale.loader.title}\n show\n ></gx-ide-loader>\n ) : (\n <ch-tree-view-render\n class=\"tree-view\"\n model={\n this.nodesVersionsViewType === \"tree\"\n ? this.nodeVersionsListTreeModel\n : this.nodeListFlattenedTreeModel\n }\n show-lines={\n this.nodesVersionsViewType === \"tree\" ? \"all\" : \"none\"\n }\n expandableButton={\n this.nodesVersionsViewType === \"tree\" ? \"decorative\" : \"no\"\n }\n onItemContextmenu={this.#contextMenuHandler}\n onCheckedItemsChange={this.#checkedItemsChangeHandler}\n onSelectedItemsChange={this.#selectedItemsChangeHandler}\n expandOnClick={this.expandOnClick}\n multiSelection={this.multiSelection}\n filter={this.searchPatternValue}\n filterType=\"caption\"\n toggleCheckboxes={this.toggleCheckboxes}\n ref={(el: HTMLChTreeViewRenderElement) => {\n this.#treeViewRenderEl = el as HTMLChTreeViewRenderElement;\n }}\n ></ch-tree-view-render>\n )}\n </div>\n {(this.dialogActions.length > 0 ||\n this.cancelCallback ||\n this.confirmCallback) &&\n this.#renderFooter()}\n </section>\n </Host>\n );\n }\n}\n\nexport type CheckboxType = \"none\" | \"all\" | \"leaf\" | \"custom\";\n\nexport type DialogAction = {\n name: string;\n callback: DialogActionCallback;\n};\n\nexport type DialogActionCallback = (...args: any[]) => void;\n\nexport type ItemCommon = {\n icon: string;\n expanded: boolean;\n};\n\nexport type ItemNode = {\n active?: boolean;\n checkbox?: boolean;\n checked?: boolean;\n expanded?: boolean;\n iconStart?: string;\n iconEnd?: string;\n id: string;\n name: string;\n nodes?: ItemNode[];\n parts?: string;\n selected?: boolean;\n type: ItemType;\n};\n\nexport type ActiveNode = {\n caption: string;\n iconStart?: string;\n path: string[]; // for using the scrollIntoVisible method of the tree-view-render\n};\n\nexport type ItemType = {\n id: string;\n name: string;\n};\n\ntype NodesVersionsViewType = \"tree\" | \"list\";\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["directorySelectorCss","GxIdeDirectorySelector","this","defaultIcon","evaluateLabelPosition","label","labelPosition","centerLabel","btnSelectClickHandler","selectDirectoryCallback","then","result","value","valueChangedHandler","e","detail","buttonSelectMouseEnterHandler","icon","buttonSelectMouseLeaveHandler","buttonSelectLabel","componentWillLoad","render","h","Host","center","class","part","onValueChanged","onClick","accessibilityLabels","type","disabled","onMouseEnter","onMouseLeave"],"sources":["src/components/_helpers/directory-selector/directory-selector.scss?tag=gx-ide-directory-selector&encapsulation=shadow","src/components/_helpers/directory-selector/directory-selector.tsx"],"sourcesContent":["@import \"../../../../node_modules/@genexus/gemini/dist/collection/globals/mixins.scss\";\n\n:host {\n display: flex;\n flex-direction: column;\n\n .container {\n display: flex;\n flex-direction: column;\n gap: 30px;\n }\n /*label*/\n label {\n font-size: 14px;\n }\n /*wrapper*/\n .wrapper {\n display: inline-flex;\n align-items: center;\n gap: var(--gx-ide-grid-column-gap);\n }\n}\n/*label position*/\n:host([label-position=\"start\"]) {\n flex-direction: row;\n .wrapper {\n flex: 1;\n }\n}\n","/* STENCIL IMPORTS */\nimport { Component, Host, h, Prop, State } from \"@stencil/core\";\n/* OTHER LIBRARIES IMPORTS */\n/* CUSTOM IMPORTS */\n\n@Component({\n tag: \"gx-ide-directory-selector\",\n styleUrl: \"directory-selector.scss\",\n shadow: true\n})\nexport class GxIdeDirectorySelector {\n /*\nINDEX:\n1.OWN PROPERTIES \n2.REFERENCE TO ELEMENTS\n3.STATE() VARIABLES\n4.PUBLIC PROPERTY API | WATCH'S\n5.EVENTS (EMIT)\n6.METHODS\n7.LISTENERS\n8.PUBLIC METHODS API\n9.LOCAL METHODS\n10.RENDER() FUNCTION\n*/\n\n // 1.OWN PROPERTIES | WATCH'S //\n\n private defaultIcon = \"objects/folder\";\n\n // 2. REFERENCE TO ELEMENTS //\n\n // 3.STATE() VARIABLES //\n\n @State() icon = this.defaultIcon;\n\n // 4.PUBLIC PROPERTY API | WATCH'S //\n\n /**\n * This property provides the user a way to define custom aria-label descriptions.\n */\n @Prop() readonly accessibilityLabels: DirectorySelectorLabels = {\n buttonSelectLabel: \"displays the directory selector\"\n };\n\n /**\n * The label associated with the input (optional)\n */\n @Prop() readonly label?: string;\n\n /**\n * The label position\n */\n @Prop({ reflect: true }) readonly labelPosition?: LabelPosition = \"start\";\n\n /**\n * Centers the label\n */\n @Prop({ mutable: true }) centerLabel = true;\n\n /**\n * The label width\n */\n @Prop() readonly labelWidth: string;\n\n /**\n * Callback that will be called when the user presses the action button. Returns the new value (directory path) assigned to the component.\n */\n @Prop() readonly selectDirectoryCallback: () => Promise<string>;\n\n /**\n * Value currently assigned.\n */\n @Prop({ mutable: true }) value: string;\n\n // 5.EVENTS (EMIT) //\n\n // 6.METHODS //\n\n componentWillLoad() {\n this.evaluateLabelPosition();\n }\n\n private evaluateLabelPosition = (): void => {\n if (this.label && this.labelPosition === \"above\") {\n this.centerLabel = false;\n }\n };\n\n // 7.LISTENERS //\n\n // 8.PUBLIC METHODS API //\n\n // 9.LOCAL METHODS //\n\n private btnSelectClickHandler = () => {\n this.selectDirectoryCallback &&\n this.selectDirectoryCallback().then(result => {\n if (result) {\n this.value = result;\n } else {\n // to be defined\n }\n });\n };\n\n private valueChangedHandler = (e: CustomEvent<string>) => {\n this.value = e.detail;\n };\n\n private buttonSelectMouseEnterHandler = (): void => {\n this.icon = \"objects/folder-open\";\n };\n\n private buttonSelectMouseLeaveHandler = (): void => {\n this.icon = this.defaultIcon;\n };\n\n // 10.RENDER() FUNCTION //\n\n render() {\n return (\n <Host>\n {this.label ? (\n <gxg-label\n labelPosition={this.labelPosition}\n center={this.centerLabel}\n >\n {this.label}\n </gxg-label>\n ) : null}\n <div class=\"wrapper\">\n <gxg-form-text\n part=\"input\"\n value={this.value}\n onValueChanged={this.valueChangedHandler}\n ></gxg-form-text>\n <gxg-button\n part=\"button-select\"\n onClick={this.btnSelectClickHandler}\n aria-label={this.accessibilityLabels?.buttonSelectLabel}\n type=\"secondary-icon-only\"\n icon={this.icon}\n disabled={!this.selectDirectoryCallback}\n onMouseEnter={this.buttonSelectMouseEnterHandler}\n onMouseLeave={this.buttonSelectMouseLeaveHandler}\n ></gxg-button>\n </div>\n </Host>\n );\n }\n}\n\nexport type DirectorySelectorLabels = {\n buttonSelectLabel: string;\n};\nexport type LabelPosition = \"start\" | \"above\";\n"],"mappings":";;AAAA,MAAMA,IAAuB;;MCUhBC,IAAsB;;;;;;;;;;;;;;;;;QAiBzBC,KAAAC,cAAc;IAuDdD,KAAAE,wBAAwB;MAC9B,IAAIF,KAAKG,SAASH,KAAKI,kBAAkB,SAAS;QAChDJ,KAAKK,cAAc;;;;;;QAUfL,KAAAM,wBAAwB;MAC9BN,KAAKO,2BACHP,KAAKO,0BAA0BC,MAAKC;QAClC,IAAIA,GAAQ;UACVT,KAAKU,QAAQD;;;AAIf;IAGET,KAAAW,sBAAuBC;MAC7BZ,KAAKU,QAAQE,EAAEC;AAAM;IAGfb,KAAAc,gCAAgC;MACtCd,KAAKe,OAAO;AAAqB;IAG3Bf,KAAAgB,gCAAgC;MACtChB,KAAKe,OAAOf,KAAKC;AAAW;gBAjFdD,KAAKC;+BAO2C;MAC9DgB,mBAAmB;;;yBAW6C;uBAK3B;;;;;;;EAqBvC,iBAAAC;IACElB,KAAKE;;;EAwCP,MAAAiB;IACE,OACEC,EAACC,GAAI,MACFrB,KAAKG,QACJiB,EAAA;MACEhB,eAAeJ,KAAKI;MACpBkB,QAAQtB,KAAKK;OAEZL,KAAKG,SAEN,MACJiB,EAAA;MAAKG,OAAM;OACTH,EAAA;MACEI,MAAK;MACLd,OAAOV,KAAKU;MACZe,gBAAgBzB,KAAKW;QAEvBS,EAAA;MACEI,MAAK;MACLE,SAAS1B,KAAKM;MAAqB,cACvBN,KAAK2B,qBAAqBV;MACtCW,MAAK;MACLb,MAAMf,KAAKe;MACXc,WAAW7B,KAAKO;MAChBuB,cAAc9B,KAAKc;MACnBiB,cAAc/B,KAAKgB"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["newEnvironmentCss","CSS_BUNDLES","MAIN_SECTION_CLASSES","BASIC_SECTION_PARENT_CLASSES","BASIC_TAB_SELECTOR","ADVANCED_TAB_SELECTOR","GxIdeNewEnvironment","_GxIdeNewEnvironment_advancedTabHasBeenRendered","set","this","_GxIdeNewEnvironment_chShortcutsEl","_GxIdeNewEnvironment_envNameModifiedByUser","_GxIdeNewEnvironment_frontEndsCheckedMap","Map","_GxIdeNewEnvironment_selectedDataStoreId","_GxIdeNewEnvironment_selectedLanguageId","_GxIdeNewEnvironment_selectedRuntimeEnvironmentId","_GxIdeNewEnvironment_shortcutsSrc","getAssetPath","_GxIdeNewEnvironment_newEnvironmentSectionsModel","_GxIdeNewEnvironment_componentLocale","_GxIdeNewEnvironment_dataStoreEl","_GxIdeNewEnvironment_environmentNameEl","_GxIdeNewEnvironment_languageEl","_GxIdeNewEnvironment_setAsCurrentEnvironmentEl","_GxIdeNewEnvironment_dataStoreValueChangedHandler","__classPrivateFieldSet","__classPrivateFieldGet","value","_GxIdeNewEnvironment_updateEnvironmentName","call","_GxIdeNewEnvironment_envNameInputHandler","e","newEnvName","detail","trim","environmentName","_GxIdeNewEnvironment_evaluateSelectedRuntimeEnvironmentId","runtimes","_GxIdeNewEnvironment_evaluateTooltipRender","controlReference","validatableControls","get","id","hasError","message","h","class","actionElement","blockAlign","config","tooltipSettings","inlineAlign","delay","_GxIdeNewEnvironment_initializeValidatableControlsBasicTab","forEach","validatableControl","reference","undefined","_GxIdeNewEnvironment_languageValueChangedHandler","async","event","_GxIdeNewEnvironment_updateDataSources","_GxIdeNewEnvironment_updateFrontEnds","_GxIdeNewEnvironment_renderAdvanced","name","_GxIdeNewEnvironment_renderBasic","length","runtime","onChange","_GxIdeNewEnvironment_runtimeEnvironmentChangedHandler","model","runtimesRadioGroupModel","caption","tabBasic","backEnd","backEndLabel","htmlFor","language","part","disabled","languages","languageComboBoxModel","onInput","ref","el","dataStores","dataStoresComboBoxModel","frontEnd","frontEndLabel","role","generators","renderChCheckboxItems","frontEnds","_GxIdeNewEnvironment_frontEndCheckboxInputHandler","_GxIdeNewEnvironment_createCallbackHandler","selectedFrontEndIds","createCallback","setAsCurrent","then","formSubmitResult","validateControls","_GxIdeNewEnvironment_tabSelectionChangedHandler","newSelectedId","advancedTabIsVisible","updatedDataSources","getDataSourcesCallback","getEnvironmentNameCallback","updatedFrontEnds","getFrontEndsCallback","checkedValue","target","checked","_GxIdeNewEnvironment_updateFrontEndsCheckedMap","checkboxId","currentState","push","checkboxIndex","findIndex","removeIndex","dataStoresChanged","newValue","mapOptionsToComboBoxItemModel","getSelectedItem","languagesChanged","runtimesChanged","connectedCallback","componentDidLoad","componentDidRender","componentWillLoad","Locale","getComponentStrings","tabLabel","tabAdvanced","suspendShortcuts","suspend","render","Host","src","header","isAdvanced","autoFocus","placeholder","environmentNamePlaceholder","tab","tabListPosition","selectedId","overflow","contain","onSelectedItemChange","slot","footer","setAsCurrentEnvironment","setAsTarget","onClick","cancelCallback","btnCancel","btnCreate"],"sources":["src/components/new-environment/new-environment.scss?tag=gx-ide-new-environment&encapsulation=shadow","src/components/new-environment/new-environment.tsx"],"sourcesContent":[":host {\n display: grid;\n block-size: 100%;\n grid-template-rows: max-content 1fr max-content;\n}\n\n.section {\n display: contents;\n}\n\n.basic,\n.advanced {\n padding-block-start: var(--mer-spacing--md);\n block-size: 100%;\n overflow: auto;\n}\n.advanced {\n padding-block-end: var(--content-block-spacing);\n}\n\n// basic\n.basic {\n display: grid;\n grid-template:\n \"runtime-environment runtime-environment\" max-content\n \"back-end front-end\" 1fr;\n grid-template-columns: 1fr 1fr;\n}\n.basic__runtime-environment {\n grid-area: runtime-environment;\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: var(--mer-spacing--xs);\n}\n.basic__runtime-environment.one-runtime-only {\n align-items: center;\n flex-direction: row;\n justify-content: center;\n}\n.control-header__back-end,\n.control-header__front-end {\n padding-block-start: var(--mer-spacing--md);\n}\n.basic__back-end {\n grid-area: back-end;\n}\n.basic__front-end {\n grid-area: front-end;\n}\n.basic__back-end,\n.basic__front-end {\n display: grid;\n grid-template-rows: max-content 1fr;\n grid-auto-rows: max-content;\n overflow: auto;\n}\n.main__back-end {\n border-inline-end: var(--section-common-border);\n}\n.main__back-end,\n.main__front-end {\n grid-auto-rows: max-content;\n padding-block: var(--content-block-spacing);\n overflow: auto;\n}\n\n// WA / TODO: Add a helper class in Mercury to justify text.\n.text-align-center {\n text-align: center; // should be resolved on mercury\n}\n\n.tab::part(page) {\n // WA / TODO: Remove this line when the ch-tab renders supports scrollbar\n // custom styling\n scrollbar-width: thin;\n}\n","/* STENCIL IMPORTS */\nimport {\n Component,\n Element,\n getAssetPath,\n Host,\n Method,\n Prop,\n State,\n h,\n Watch\n} from \"@stencil/core\";\n\nimport { MercuryBundles } from \"@genexus/mercury\";\n\nimport { config } from \"../../common/config\";\nimport { Locale } from \"../../common/locale\";\nimport {\n mapOptionsToComboBoxItemModel,\n renderChCheckboxItems\n} from \"../../common/helpers\";\nimport { getSelectedItem } from \"../../common/common\";\nimport { FormSubmitResult, GxOption } from \"../../common/types\";\nimport {\n ControlValidation,\n validateControls\n} from \"../../common/form-validation\";\nimport {\n ChRadioGroupRenderCustomEvent,\n TabModel,\n ComboBoxModel,\n ChEditCustomEvent,\n RadioGroupModel,\n ChCheckboxCustomEvent\n} from \"@genexus/chameleon-controls-library\";\nimport { removeIndex } from \"../../common/array\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n // TODO: review if \"utils/form--full\" is required.\n \"resets/box-sizing\",\n \"components/tab\",\n \"components/tooltip\",\n \"utils/form--full\",\n \"utils/layout\",\n \"utils/typography\",\n \"utils/spacing\",\n \"chameleon/scrollbar\"\n];\n\nconst MAIN_SECTION_CLASSES: string = \"main\";\nconst BASIC_SECTION_PARENT_CLASSES: string = \"basic\";\nconst BASIC_TAB_SELECTOR: string = \"basic\";\nconst ADVANCED_TAB_SELECTOR: string = \"advanced\";\n\n@Component({\n tag: \"gx-ide-new-environment\",\n styleUrl: \"new-environment.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/new-environment\"]\n})\nexport class GxIdeNewEnvironment {\n #advancedTabHasBeenRendered: boolean = false;\n #chShortcutsEl!: HTMLChShortcutsElement;\n #envNameModifiedByUser = false;\n /**\n * frontEndsState saves the id's of the front ends checkboxes that are checked\n */\n // TODO (Use a set instead of an array to improve performance)\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #frontEndsCheckedMap = new Map<string, string[]>();\n #selectedDataStoreId: string;\n #selectedLanguageId: string;\n #selectedRuntimeEnvironmentId: string;\n #shortcutsSrc = getAssetPath(\n `./gx-ide-assets/new-environment/shortcuts.json`\n );\n #newEnvironmentSectionsModel: TabModel = [];\n\n /**\n * The component hard-coded strings translations.\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #componentLocale: any;\n\n @Element() el: HTMLGxIdeNewEnvironmentElement;\n\n // References needed to collect data con \"createCallback\" button submit*/\n #dataStoreEl!: HTMLChComboBoxRenderElement;\n #environmentNameEl!: HTMLChEditElement;\n #languageEl!: HTMLChComboBoxRenderElement;\n #setAsCurrentEnvironmentEl!: HTMLChCheckboxElement;\n\n @State() advancedTabIsVisible: boolean = false;\n\n /**\n * Allows selecting multiple generators for the front end\n * TODO: Check if this property can be deleted, since we can call getFrontEndsCallback.\n */\n @State() frontEnds: GxOption[];\n\n @State() validatableControls = new Map<string, ControlValidation>();\n\n // representations of GxOption[] as ComboBoxModel or RadioGroupModel.\n @State() dataStoresComboBoxModel: ComboBoxModel = [];\n @State() languageComboBoxModel: ComboBoxModel = [];\n @State() runtimesRadioGroupModel: RadioGroupModel = [];\n\n /**\n * Callback invoked when user wants to cancel\n */\n @Prop() readonly cancelCallback: CancelCallback;\n\n /**\n * Callback invoked when user confirms the KB creation\n */\n @Prop() readonly createCallback!: CreateCallback;\n\n /**\n * Allows defining the DBMS to be used in the solution\n */\n @Prop({ mutable: true }) dataStores!: GxOption[];\n @Watch(\"dataStores\")\n dataStoresChanged(newValue: GxOption[]) {\n if (newValue?.length) {\n this.dataStoresComboBoxModel = mapOptionsToComboBoxItemModel(newValue);\n this.#selectedDataStoreId = getSelectedItem(newValue);\n }\n }\n\n /**\n * Name of the new environment\n */\n @Prop({ mutable: true }) environmentName: string;\n\n /**\n * Callback invoked when user changes the language or the runtime\n */\n @Prop() readonly getDataSourcesCallback!: GetDataSourcesCallback;\n\n /**\n * Callback invoked when user changes the language or data source\n */\n @Prop() readonly getEnvironmentNameCallback!: GetEnvironmentNameCallback;\n\n /**\n * Callback invoked when user changes the language\n */\n @Prop() readonly getFrontEndsCallback!: GetFrontEndsCallback;\n\n /**\n * Define if the Advanced tab should be displayed\n */\n @Prop() readonly isAdvanced: boolean = false;\n\n /**\n * Possible values for 'Language' combo\n */\n @Prop() readonly languages!: GxOption[];\n @Watch(\"languages\")\n languagesChanged(newValue: GxOption[]) {\n if (newValue?.length) {\n this.languageComboBoxModel = mapOptionsToComboBoxItemModel(newValue);\n this.#selectedLanguageId = getSelectedItem(newValue);\n this.#updateFrontEnds();\n }\n }\n\n /**\n * Possible values for 'Runtime Environment' radio button\n */\n @Prop() readonly runtimes!: GxOption[];\n @Watch(\"runtimes\")\n runtimesChanged(newValue: GxOption[]) {\n if (newValue?.length) {\n this.runtimesRadioGroupModel = mapOptionsToComboBoxItemModel(\n this.runtimes\n );\n }\n }\n\n /**\n * Belongs to checkbox 'Set as current environment' @default true\n *\n */\n @Prop() readonly setAsTarget?: boolean = true;\n\n connectedCallback() {\n this.dataStoresChanged(this.dataStores);\n this.languagesChanged(this.languages);\n this.runtimesChanged(this.runtimes);\n }\n\n componentDidLoad() {\n this.#initializeValidatableControlsBasicTab();\n }\n\n componentDidRender() {\n if (this.advancedTabIsVisible && !this.#advancedTabHasBeenRendered) {\n // just call this once.\n this.#advancedTabHasBeenRendered = true;\n }\n }\n\n async componentWillLoad() {\n this.#componentLocale = await Locale.getComponentStrings(this.el);\n this.#newEnvironmentSectionsModel = [\n {\n id: BASIC_TAB_SELECTOR,\n name: this.#componentLocale.tabBasic.tabLabel\n },\n {\n id: ADVANCED_TAB_SELECTOR,\n name: this.#componentLocale.tabAdvanced.tabLabel\n }\n ];\n this.#evaluateSelectedRuntimeEnvironmentId();\n }\n\n /**\n * Suspends or reactivates the shortcuts\n */\n @Method()\n async suspendShortcuts(suspendShortcuts: boolean) {\n if (suspendShortcuts) {\n this.#chShortcutsEl.suspend = true;\n } else {\n this.#chShortcutsEl.suspend = false;\n }\n }\n\n #dataStoreValueChangedHandler = () => {\n /* the data store item id is used for the value (they are equal)*/\n this.#selectedDataStoreId = this.#dataStoreEl.value;\n this.#updateEnvironmentName();\n };\n\n #envNameInputHandler = (e: ChEditCustomEvent<string> | InputEvent) => {\n const newEnvName = (e as ChEditCustomEvent<string>).detail.trim();\n this.#envNameModifiedByUser = newEnvName !== this.environmentName;\n };\n\n #evaluateSelectedRuntimeEnvironmentId = () => {\n this.#selectedRuntimeEnvironmentId = this.runtimes[0]?.value;\n };\n\n // TODO: We must avoid performing the get 3 times.\n // It is used on new-environment as well.\n #evaluateTooltipRender = (\n controlReference: HTMLElement\n ): HTMLChTooltipElement =>\n this.validatableControls?.get(controlReference?.id)?.hasError &&\n this.validatableControls.get(controlReference.id)?.message && (\n <ch-tooltip\n class=\"tooltip\"\n actionElement={controlReference as unknown as HTMLButtonElement}\n blockAlign={config.tooltipSettings.blockAlign}\n inlineAlign={config.tooltipSettings.inlineAlign}\n delay={config.tooltipSettings.delay}\n >\n {this.validatableControls.get(controlReference.id).message}\n </ch-tooltip>\n );\n\n #initializeValidatableControlsBasicTab = () => {\n // populate #controlsValidation with the controls that could have errors.\n const validatableControls: HTMLElement[] = [\n this.#dataStoreEl,\n this.#languageEl\n ];\n validatableControls.forEach(validatableControl => {\n if (validatableControl.id) {\n this.validatableControls.set(validatableControl.id, {\n reference: validatableControl,\n hasError: false,\n message: undefined\n });\n }\n });\n };\n\n #languageValueChangedHandler = async (\n event: CustomEvent<string> | InputEvent\n ) => {\n this.#selectedLanguageId = event.detail as string;\n await this.#updateDataSources();\n this.#updateFrontEnds();\n this.#updateEnvironmentName();\n };\n\n #renderAdvanced = (): Element => {\n return <slot name=\"property-grid\"></slot>;\n };\n\n #renderBasic = (): HTMLElement[] => {\n return [\n <div\n class={{\n \"basic__runtime-environment\": true,\n \"control-header-with-border\": true,\n \"one-runtime-only\": this.runtimes.length === 1\n }}\n >\n {this.runtimes.length > 1\n ? [\n <h2\n // Runtime Environment\n class=\"subtitle-regular-xs\t text-align-center\"\n >\n {this.#componentLocale.runtime}\n </h2>,\n <ch-radio-group-render\n class=\"radio-group\"\n onChange={this.#runtimeEnvironmentChangedHandler}\n model={this.runtimesRadioGroupModel}\n value={this.#selectedRuntimeEnvironmentId}\n ></ch-radio-group-render>\n ]\n : [\n <h2 class=\"subtitle-regular-xs\t text-align-center\">\n {this.#componentLocale.runtime}:\n </h2>,\n <p>{this.runtimesRadioGroupModel[0].caption}</p>\n ]}\n </div>,\n <section class=\"basic__back-end scrollable\">\n <h2\n // back end\n class=\"control-header control-header-with-border control-header__back-end subtitle-regular-xs\t text-align-center spacing-body-inline\"\n >\n {this.#componentLocale.tabBasic.backEnd.backEndLabel}\n </h2>\n\n <div class=\"field-group main__back-end spacing-body-inline scrollable\">\n <div\n // #language\n class=\"field field-block\"\n >\n <label class=\"label\" htmlFor=\"language\">\n {this.#componentLocale.tabBasic.backEnd.language}\n </label>\n <ch-combo-box-render\n id=\"language\"\n class=\"combo-box\"\n part=\"language\"\n value={this.#selectedLanguageId}\n disabled={this.languages.length === 0}\n model={this.languageComboBoxModel}\n onInput={this.#languageValueChangedHandler}\n ref={(el: HTMLChComboBoxRenderElement) =>\n (this.#languageEl = el as HTMLChComboBoxRenderElement)\n }\n // TODO: toolTip={config.tooltip}\n ></ch-combo-box-render>\n {this.#evaluateTooltipRender(this.#languageEl)}\n </div>\n\n <div\n // #data stores\n class=\"field field-block\"\n >\n <label class=\"label\" htmlFor=\"data-store\">\n {this.#componentLocale.tabBasic.backEnd.dataStores}\n </label>\n <ch-combo-box-render\n id=\"data-store\"\n class=\"combo-box\"\n part=\"data-store\"\n value={this.#selectedDataStoreId}\n model={this.dataStoresComboBoxModel}\n onInput={this.#dataStoreValueChangedHandler}\n ref={(el: HTMLChComboBoxRenderElement) =>\n (this.#dataStoreEl = el as HTMLChComboBoxRenderElement)\n }\n // TODO: toolTip={config.tooltip}\n ></ch-combo-box-render>\n {this.#evaluateTooltipRender(this.#dataStoreEl)}\n </div>\n </div>\n </section>,\n\n <section class=\"basic__front-end scrollable\">\n <h2\n // front end\n class=\"control-header control-header-with-border control-header__front-end subtitle-regular-xs\t text-align-center spacing-body-inline\"\n >\n {this.#componentLocale.tabBasic.frontEnd.frontEndLabel}\n </h2>\n <div\n class=\"field-group front-end__checkboxes spacing-body-inline main__front-end scrollable\"\n role=\"group\"\n aria-labelledby={this.#componentLocale.tabBasic.frontEnd.generators}\n >\n {renderChCheckboxItems(\n this.frontEnds,\n this.#frontEndCheckboxInputHandler,\n this.#frontEndsCheckedMap.get(this.#selectedLanguageId)\n )}\n </div>\n </section>\n ];\n };\n\n #runtimeEnvironmentChangedHandler = async (\n event: ChRadioGroupRenderCustomEvent<string>\n ): Promise<void> => {\n this.#selectedRuntimeEnvironmentId = event.detail;\n await this.#updateDataSources();\n this.#updateEnvironmentName();\n };\n\n #createCallbackHandler = async () => {\n const selectedFrontEndIds =\n this.#frontEndsCheckedMap.get(this.#selectedLanguageId) ?? [];\n\n this.createCallback({\n setAsCurrent: !!this.#setAsCurrentEnvironmentEl?.value,\n name: this.#environmentNameEl.value,\n runtime: this.#selectedRuntimeEnvironmentId,\n language: this.#languageEl.value,\n dataStores: this.#dataStoreEl.value,\n frontEnds: selectedFrontEndIds\n }).then((formSubmitResult: FormSubmitResult) => {\n this.validatableControls = validateControls(\n formSubmitResult,\n this.validatableControls\n );\n });\n };\n\n #tabSelectionChangedHandler = (\n event: CustomEvent<{\n lastSelectedIndex: number;\n newSelectedId: string;\n newSelectedIndex: number;\n }>\n ): void => {\n if (event.detail.newSelectedId === ADVANCED_TAB_SELECTOR) {\n this.advancedTabIsVisible = true;\n // Some logic for advanced tab is done on componentDidRender lifecycle,\n // since the reference to the elements is needed.\n }\n };\n\n #updateDataSources = async () => {\n const updatedDataSources = await this.getDataSourcesCallback(\n this.#selectedLanguageId,\n this.#selectedRuntimeEnvironmentId\n );\n if (updatedDataSources?.length > 0) {\n this.dataStores = updatedDataSources;\n }\n };\n\n #updateEnvironmentName = async () => {\n if (!this.#envNameModifiedByUser) {\n this.environmentName = await this.getEnvironmentNameCallback(\n this.#selectedLanguageId,\n this.#selectedDataStoreId,\n this.#selectedRuntimeEnvironmentId\n );\n }\n };\n\n #updateFrontEnds = async () => {\n const updatedFrontEnds = await this.getFrontEndsCallback(\n this.#selectedLanguageId\n );\n if (updatedFrontEnds?.length > 0) {\n this.frontEnds = updatedFrontEnds;\n }\n };\n\n #frontEndCheckboxInputHandler = (\n event: ChCheckboxCustomEvent<string> | InputEvent\n ) => {\n const checkedValue = (event.target as HTMLChCheckboxElement).checkedValue;\n const checked = event.detail === checkedValue;\n this.#updateFrontEndsCheckedMap(checkedValue, checked);\n };\n\n /**\n * This function updates frontEndsCheckedMap, that contains the checked\n * checkboxes for each language front ends.\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #updateFrontEndsCheckedMap = (checkboxId: string, checked: boolean) => {\n let currentState = this.#frontEndsCheckedMap.get(this.#selectedLanguageId);\n if (!currentState) {\n // first time\n currentState = [];\n this.#frontEndsCheckedMap.set(this.#selectedLanguageId, currentState);\n }\n if (checked) {\n // update by adding\n currentState.push(checkboxId);\n } else {\n // update by removing\n const checkboxIndex = currentState.findIndex(id => id === checkboxId);\n removeIndex(currentState, checkboxIndex);\n }\n };\n\n render() {\n return (\n <Host class=\"widget scrollable\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <ch-shortcuts\n src={this.#shortcutsSrc}\n ref={(el: HTMLChShortcutsElement) =>\n (this.#chShortcutsEl = el as HTMLChShortcutsElement)\n }\n ></ch-shortcuts>\n\n <section class=\"section\">\n <header\n class={{\n \"header\": true,\n \"spacing-body-inline\": true,\n \"spacing-body-block-start\": true,\n \"control-header\": this.isAdvanced,\n \"control-header-with-border\": !this.isAdvanced\n }}\n >\n <div\n // #environment name\n class=\"field field-inline\"\n >\n <label class=\"label\" htmlFor=\"environment-name\">\n {this.#componentLocale.name}\n </label>\n <ch-edit\n // environment name\n autoFocus\n id=\"environment-name\"\n class=\"input\"\n part=\"environment-name\"\n value={this.environmentName}\n placeholder={this.#componentLocale.environmentNamePlaceholder}\n // TODO: toolTip={config.tooltip}\n ref={(el: HTMLChEditElement) =>\n (this.#environmentNameEl = el as HTMLChEditElement)\n }\n onInput={this.#envNameInputHandler}\n ></ch-edit>\n </div>\n </header>\n\n {this.isAdvanced ? (\n <ch-tab-render\n // main section\n class={{\n tab: true,\n [MAIN_SECTION_CLASSES]: true\n }}\n tabListPosition=\"block-start\"\n model={this.#newEnvironmentSectionsModel}\n selectedId={BASIC_TAB_SELECTOR}\n overflow=\"auto\"\n contain=\"size\"\n onSelectedItemChange={\n !this.advancedTabIsVisible && this.#tabSelectionChangedHandler\n }\n >\n <div\n slot={BASIC_TAB_SELECTOR}\n class={BASIC_SECTION_PARENT_CLASSES}\n part=\"tab-button-basic\"\n >\n {this.#renderBasic()}\n </div>\n {this.advancedTabIsVisible && (\n <div\n slot={ADVANCED_TAB_SELECTOR}\n class=\"advanced spacing-body-inline\"\n part=\"tab-button-advanced\"\n >\n {this.#renderAdvanced()}\n </div>\n )}\n </ch-tab-render>\n ) : (\n <div\n // main section\n class={MAIN_SECTION_CLASSES}\n >\n <div class={BASIC_SECTION_PARENT_CLASSES}>\n {this.#renderBasic()}\n </div>\n </div>\n )}\n\n <footer\n class={{\n \"control-footer\": this.isAdvanced,\n \"control-footer-with-border\": !this.isAdvanced,\n \"control-footer-space-between\": true,\n \"spacing-body-block-end\": true,\n \"spacing-body-inline\": true\n }}\n >\n <ch-checkbox\n // #set as current environment\n class=\"checkbox\"\n caption={this.#componentLocale.footer.setAsCurrentEnvironment}\n ref={(el: HTMLChCheckboxElement) =>\n (this.#setAsCurrentEnvironmentEl = el as HTMLChCheckboxElement)\n }\n checkedValue=\"current-environment\"\n value={this.setAsTarget ? \"current-environment\" : \"\"}\n part=\"set-as-current-environment\"\n ></ch-checkbox>\n\n <div class=\"buttons-spacer\">\n <button\n // #cancel\n class=\"button-secondary\"\n onClick={this.cancelCallback}\n part=\"button button-cancel\"\n >\n {this.#componentLocale.footer.btnCancel}\n </button>\n\n <button\n // #create\n class=\"button-primary\"\n onClick={this.#createCallbackHandler}\n part=\"button button-create\"\n >\n {this.#componentLocale.footer.btnCreate}\n </button>\n </div>\n </footer>\n </section>\n </Host>\n );\n }\n}\n\nexport type CancelCallback = () => Promise<void>;\n\nexport type CreateCallback = (\n data: NewEnvironmentData\n) => Promise<FormSubmitResult>;\n\nexport type GetDataSourcesCallback = (\n selectedLanguageId: string,\n selectedRuntimeId: string\n) => Promise<GxOption[]>;\n\nexport type GetEnvironmentNameCallback = (\n selectedLanguageId: string,\n selectedDataSourceId: string,\n selectedRuntimeId: string\n) => Promise<string | undefined>;\n\nexport type GetFrontEndsCallback = (\n selectedLanguageId: string\n) => Promise<GxOption[]>;\n\nexport interface NewEnvironmentData {\n setAsCurrent: boolean;\n name: string;\n runtime: string;\n language: string;\n dataStores: string;\n frontEnds: string[];\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["mapTeamsToComboBoxItemModel","teams","map","team","value","id","caption","name","signInTeamCss","COPYRIGHTS_ILLUSTRATION","getAssetPath","ICON_NEXT","CSS_BUNDLES","CHECKED_VALUE","GxIdeSignInTeam","_GxIdeSignInTeam_componentLocale","set","this","_GxIdeSignInTeam_userTeamsModel","_GxIdeSignInTeam_chSelectTeamEl","_GxIdeSignInTeam_switchStepTransitionTime","_GxIdeSignInTeam_termsAndConditionsCheckboxEl","_GxIdeSignInTeam_privacyPolicyCheckboxEl","_GxIdeSignInTeam_authStepCallback","authStep","signInCallback","__classPrivateFieldGet","_GxIdeSignInTeam_continueHandler","call","async","continueCallback","_GxIdeSignInTeam_renderStepHeader","h","class","src","alt","authStepInternal","titlePart1","titlePart2","_GxIdeSignInTeam_renderStepFooter","signInDisabled","termsConfirmationRequired","termsAndConditionsAccepted","onClick","disabled","buttonCaption","_GxIdeSignInTeam_evaluateTermsConditionsAndPrivacyAccepted","privacyPolicyAccepted","_GxIdeSignInTeam_termsAndConditionsClickedHandler","event","preventDefault","termsCallback","_GxIdeSignInTeam_privacyPolicyClickedHandler","privacyCallback","_GxIdeSignInTeam_evaluateStepRender","signIn","description","checkedValue","ref","el","__classPrivateFieldSet","onInput","htmlFor","agreement","termsAndConditionsLabel","hyperlink","termsAndConditionsLink","privacyAndPolicyLabel","privacyAndPolicyLink","loaderTitle","loader","fetchingTeamsTitle","settingUpSessionTitle","loaderDescription","fetchingTeamsDescription","settingUpDescription","show","selectUserTeam","infoMessage","label","accessibleName","model","authStepChanged","newAuthStep","slideIsVisible","setTimeout","teamsChanged","newTeams","componentWillLoad","Locale","getComponentStrings","style","setProperty","toString","render","Host","slide__main"],"sources":["src/components/sign-in-team/helpers.ts","src/components/sign-in-team/sign-in-team.scss?tag=gx-ide-sign-in-team&encapsulation=shadow","src/components/sign-in-team/sign-in-team.tsx"],"sourcesContent":["import { ComboBoxItemModel } from \"@genexus/chameleon-controls-library/dist/types/components/combo-box/types\";\nimport { TeamData } from \"./sign-in-team\";\n\nexport const mapTeamsToComboBoxItemModel = (\n teams?: TeamData[]\n): ComboBoxItemModel[] | undefined => {\n if (!teams) {\n return [];\n }\n return teams.map(team => ({\n value: team.id,\n caption: team.name\n }));\n};\n",":host {\n display: grid;\n container-type: inline-size;\n container-name: host-container;\n block-size: 100%;\n inline-size: 100%;\n align-items: center;\n justify-content: center;\n padding: var(--mer-spacing--xl);\n}\n\n.slide {\n display: grid;\n grid-template-columns: 1fr 1fr;\n block-size: 100%;\n max-block-size: 700px;\n max-inline-size: 1100px;\n background-color: var(--mer-surface__elevation--01);\n border-radius: var(--mer-spacing--md);\n overflow: hidden;\n\n &__illustration {\n overflow: hidden;\n object-fit: cover;\n object-position: left;\n block-size: 100%;\n inline-size: 100%;\n }\n\n &__main {\n display: grid;\n block-size: 100%;\n inline-size: 100%;\n padding: var(--mer-spacing--3xl);\n transform: translateY(var(--mer-spacing--2xs));\n transition: var(--switch-step-transtion-time) all;\n opacity: 0;\n\n &--visible {\n transform: translateY(0);\n opacity: 1;\n }\n }\n\n &__main-container {\n display: grid;\n place-self: center;\n gap: var(--mer-spacing--lg);\n max-inline-size: 480px;\n }\n\n &__main-header {\n display: grid;\n gap: var(--mer-spacing--lg);\n }\n\n &__main-title {\n display: flex;\n flex-direction: column;\n font-size: var(--mer-font__size--xl);\n font-weight: var(--mer-font__weight--semi-bold);\n letter-spacing: 0.02em;\n color: var(--mer-text__on-surface);\n }\n\n &__main-description {\n display: grid;\n gap: var(--mer-spacing--2xl);\n font-size: var(--mer-font__size--sm);\n font-weight: var(--mer-font__weight--light);\n line-height: var(--mer-line-height--spaced);\n color: var(--mer-text__complementary);\n max-inline-size: 370px;\n }\n}\n\n.teams-list {\n inline-size: 100%;\n max-inline-size: 400px;\n}\n\n.main-btn {\n inline-size: 100%;\n max-inline-size: 124px;\n}\n\n@container host-container (max-width: 768px) {\n .slide {\n grid-template-columns: 1fr 2fr;\n }\n}\n\n@container host-container (max-width: 640px) {\n .slide {\n grid-template-columns: 1fr 5fr;\n }\n}\n\n// WA (this class should be defined on Mercury\n.hyperlink {\n text-decoration: underline;\n cursor: pointer;\n}\n// WA checkboxes labels should not include margin-block-start when\n// placed inside a field-inline.\n.field-inline > .label-agreement {\n margin-block-start: 0 !important;\n}\n","// Stencil\nimport {\n Component,\n Host,\n h,\n Prop,\n State,\n Watch,\n Element,\n getAssetPath\n} from \"@stencil/core\";\n// Other Libraries\nimport { MercuryBundles } from \"@genexus/mercury\";\nimport { ComboBoxItemModel } from \"@genexus/chameleon-controls-library/dist/types/components/combo-box/types\";\n// Custom Imports\nimport { Locale } from \"../../common/locale\";\nimport { mapTeamsToComboBoxItemModel } from \"./helpers\";\n\nconst COPYRIGHTS_ILLUSTRATION = getAssetPath(\n `./gx-ide-assets/welcome-page/images/copyrights-illustration.png`\n);\nconst ICON_NEXT = getAssetPath(\n `./gx-ide-assets/welcome-page/images/icon-next.svg`\n);\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"utils/typography\",\n \"components/button\",\n \"components/combo-box\",\n \"components/checkbox\",\n \"utils/form\"\n];\n\nconst CHECKED_VALUE = \"on\";\n\n@Component({\n tag: \"gx-ide-sign-in-team\",\n styleUrl: \"sign-in-team.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/sign-in-team\"]\n})\nexport class GxIdeSignInTeam {\n /**\n * The component hard-coded strings translations.\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #componentLocale: any;\n // Select User Team References :\n #userTeamsModel: ComboBoxItemModel[] = [];\n #chSelectTeamEl: HTMLChComboBoxRenderElement;\n #switchStepTransitionTime: number = 100;\n #termsAndConditionsCheckboxEl!: HTMLChCheckboxElement;\n #privacyPolicyCheckboxEl!: HTMLChCheckboxElement;\n\n @Element() el: HTMLGxIdeSignInTeamElement;\n\n /**\n * This is a handover from \"authStep\" that allows updating descriptions once\n * the slide is hidden. This enables a smooth transition between descriptions.\n */\n\n @State() authStepInternal: AuthStep;\n\n /**\n * Defines if the main slide is visible or not. Used for smooth transitions\n * between slides.\n */\n @State() slideIsVisible: boolean = true;\n\n /**\n * True if terms and conditions are accepted.\n */\n @State() termsAndConditionsAccepted: boolean = false;\n\n /**\n * The authentication step to display\n */\n @Prop() readonly authStep: AuthStep = \"signIn\";\n @Watch(\"authStep\")\n authStepChanged(newAuthStep: AuthStep) {\n this.slideIsVisible = false;\n // switch step\n setTimeout(() => {\n this.authStepInternal = newAuthStep;\n }, this.#switchStepTransitionTime);\n // show slide\n setTimeout(() => {\n this.slideIsVisible = true;\n }, this.#switchStepTransitionTime * 2);\n }\n\n /**\n * Callback executed when the user clicks the 'Continue' button\n */\n @Prop() readonly continueCallback!: (teamId: string) => Promise<void>;\n\n /**\n * Callback executed when the user click the \"Sign In\" button\n */\n @Prop() readonly signInCallback!: () => Promise<void>;\n\n /**\n * When true, it will diplay checkboxes for the user to confirm terms and conditions\n */\n @Prop() readonly termsConfirmationRequired: boolean = false;\n\n /**\n * Array that contains the user's teams\n */\n @Prop() readonly teams!: TeamData[];\n @Watch(\"teams\")\n teamsChanged(newTeams: TeamData[]) {\n this.#userTeamsModel = mapTeamsToComboBoxItemModel(newTeams);\n }\n\n /**\n * Callback executed when the user clicks on the \"term and conditions\" link\n */\n @Prop() readonly termsCallback: () => Promise<void>;\n\n /**\n * Callback executed when the user clicks on the \"privacy policy\" link\n */\n @Prop() readonly privacyCallback: () => Promise<void>;\n\n async componentWillLoad() {\n this.#componentLocale = await Locale.getComponentStrings(this.el);\n this.el.style.setProperty(\n \"--switch-step-transtion-time\",\n this.#switchStepTransitionTime.toString() + \"ms\"\n );\n // Initialize values\n this.authStepInternal = this.authStep;\n this.teamsChanged(this.teams);\n }\n\n #authStepCallback = () => {\n if (this.authStep === \"signIn\") {\n this.signInCallback();\n } else if (this.authStep === \"selectUserTeam\") {\n this.#continueHandler();\n }\n };\n\n #continueHandler = async () => {\n await this.continueCallback(this.#chSelectTeamEl.value);\n };\n\n #renderStepHeader = (): HTMLElement => {\n return (\n <header class=\"slide__main-header\">\n <img\n src={ICON_NEXT}\n alt=\"\" // decorative\n />\n <h2\n // Split the title into two spans for better styling\n class=\"slide__main-title\"\n >\n <span>{this.#componentLocale[this.authStepInternal].titlePart1}</span>\n <span>{this.#componentLocale[this.authStepInternal].titlePart2}</span>\n </h2>\n </header>\n );\n };\n\n #renderStepFooter = (): HTMLElement => {\n const signInDisabled =\n this.authStep === \"signIn\" &&\n this.termsConfirmationRequired &&\n !this.termsAndConditionsAccepted;\n return (\n <div>\n <button\n class=\"button-primary main-btn\"\n onClick={this.#authStepCallback}\n disabled={signInDisabled}\n >\n {this.#componentLocale[this.authStepInternal].buttonCaption}\n </button>\n </div>\n );\n };\n\n #evaluateTermsConditionsAndPrivacyAccepted = () => {\n const termsAndConditionsAccepted =\n this.#termsAndConditionsCheckboxEl.value === CHECKED_VALUE;\n const privacyPolicyAccepted =\n this.#privacyPolicyCheckboxEl.value === CHECKED_VALUE;\n this.termsAndConditionsAccepted =\n termsAndConditionsAccepted && privacyPolicyAccepted;\n };\n\n #termsAndConditionsClickedHandler = (event: MouseEvent) => {\n event.preventDefault();\n this.termsCallback();\n };\n\n #privacyPolicyClickedHandler = (event: MouseEvent) => {\n event.preventDefault();\n this.privacyCallback();\n };\n\n #evaluateStepRender = () => {\n if (this.authStepInternal === \"signIn\") {\n return [\n this.#renderStepHeader(),\n <p class=\"body-regular-l\">\n {this.#componentLocale.signIn.description}\n </p>,\n this.termsConfirmationRequired && (\n <div class=\"field-group\">\n <div\n // terms and conditions\n class=\"field field-inline\"\n >\n <ch-checkbox\n checkedValue={CHECKED_VALUE}\n id=\"terms-and-conditions\"\n class=\"checkbox\"\n ref={(el: HTMLChCheckboxElement) =>\n (this.#termsAndConditionsCheckboxEl =\n el as HTMLChCheckboxElement)\n }\n onInput={this.#evaluateTermsConditionsAndPrivacyAccepted}\n ></ch-checkbox>\n <label\n htmlFor=\"terms-and-conditions\"\n class=\"label label-agreement\"\n >\n {this.#componentLocale.agreement.termsAndConditionsLabel}\n <span\n class={{ hyperlink: !!this.termsCallback }}\n onClick={\n this.termsCallback && this.#termsAndConditionsClickedHandler\n }\n >\n {this.#componentLocale.agreement.termsAndConditionsLink}\n </span>\n </label>\n </div>\n <div\n // privacy policy\n class=\"field field-inline\"\n >\n <ch-checkbox\n checkedValue={CHECKED_VALUE}\n id=\"privacy-policy\"\n class=\"checkbox\"\n ref={(el: HTMLChCheckboxElement) =>\n (this.#privacyPolicyCheckboxEl = el as HTMLChCheckboxElement)\n }\n onInput={this.#evaluateTermsConditionsAndPrivacyAccepted}\n ></ch-checkbox>\n <label htmlFor=\"privacy-policy\" class=\"label label-agreement\">\n {this.#componentLocale.agreement.privacyAndPolicyLabel}\n <span\n class={{ hyperlink: !!this.privacyCallback }}\n onClick={\n this.privacyCallback && this.#privacyPolicyClickedHandler\n }\n >\n {this.#componentLocale.agreement.privacyAndPolicyLink}\n </span>\n </label>\n </div>\n </div>\n ),\n\n this.#renderStepFooter()\n ];\n } else if (\n this.authStepInternal === \"fetchUserTeams\" ||\n this.authStepInternal === \"settingUpSession\"\n ) {\n const loaderTitle =\n this.authStepInternal === \"fetchUserTeams\"\n ? this.#componentLocale.loader.fetchingTeamsTitle\n : this.#componentLocale.loader.settingUpSessionTitle;\n const loaderDescription =\n this.authStepInternal === \"fetchUserTeams\"\n ? this.#componentLocale.loader.fetchingTeamsDescription\n : this.#componentLocale.loader.settingUpDescription;\n return (\n <gx-ide-loader\n show\n loaderTitle={loaderTitle}\n description={loaderDescription}\n ></gx-ide-loader>\n );\n } else if (this.authStepInternal === \"selectUserTeam\") {\n return [\n this.#renderStepHeader(),\n <div class=\"slide__select-team-description\">\n <p class=\"body-semi-bold-l\">\n {this.#componentLocale.selectUserTeam.infoMessage}\n </p>\n </div>,\n <div class=\"field-group\">\n <div class=\"field field-block\">\n <label htmlFor=\"teams\">\n {this.#componentLocale.selectUserTeam.label}\n </label>\n <ch-combo-box-render\n id=\"teams\"\n accessibleName=\"Teams\"\n class=\"combo-box teams-list\"\n model={this.#userTeamsModel}\n value={this.#userTeamsModel[0]?.value}\n ref={(el: HTMLChComboBoxRenderElement) =>\n (this.#chSelectTeamEl = el as HTMLChComboBoxRenderElement)\n }\n ></ch-combo-box-render>\n </div>\n </div>,\n this.#renderStepFooter()\n ];\n }\n };\n\n render() {\n return (\n <Host>\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <section class=\"slide\">\n <img\n src={COPYRIGHTS_ILLUSTRATION}\n class=\"slide__illustration\"\n alt=\"\" // decorative\n />\n\n <div\n class={{\n \"slide__main\": true,\n \"slide__main--visible\": this.slideIsVisible\n }}\n >\n <div class=\"slide__main-container\">\n {this.#evaluateStepRender()}\n </div>\n </div>\n </section>\n </Host>\n );\n }\n}\n\nexport type AuthStep =\n | \"signIn\"\n | \"fetchUserTeams\"\n | \"selectUserTeam\"\n | \"settingUpSession\";\n\nexport type TeamData = {\n id: string;\n name: string;\n};\n"],"mappings":"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"}