@genexus/genexus-ide-ui 1.1.4 → 1.1.5

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 (777) hide show
  1. package/dist/cjs/MERCURY_ASSETS-972bf7f4.js +9 -0
  2. package/dist/cjs/MERCURY_ASSETS-972bf7f4.js.map +1 -0
  3. package/dist/cjs/code-render-0e9837c4.js +86 -0
  4. package/dist/cjs/code-render-0e9837c4.js.map +1 -0
  5. package/dist/cjs/{common-72f91a78.js → common-090e6d3a.js} +28 -12
  6. package/dist/cjs/common-090e6d3a.js.map +1 -0
  7. package/dist/cjs/{form-validation-178cf461.js → form-validation-ffe2b957.js} +7 -3
  8. package/dist/cjs/form-validation-ffe2b957.js.map +1 -0
  9. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  10. package/dist/cjs/gx-ide-about.cjs.entry.js +1 -1
  11. package/dist/cjs/gx-ide-ai-assistant.cjs.entry.js +9 -15
  12. package/dist/cjs/gx-ide-ai-assistant.cjs.entry.js.map +1 -1
  13. package/dist/cjs/gx-ide-ai-message.cjs.entry.js +4 -5
  14. package/dist/cjs/gx-ide-ai-message.cjs.entry.js.map +1 -1
  15. package/dist/cjs/gx-ide-bpm-app-declaration.cjs.entry.js +8 -10
  16. package/dist/cjs/gx-ide-bpm-app-declaration.cjs.entry.js.map +1 -1
  17. package/dist/cjs/gx-ide-bpm-assign-roles.cjs.entry.js +1 -1
  18. package/dist/cjs/gx-ide-bpm-export-xpdl.cjs.entry.js +3 -5
  19. package/dist/cjs/gx-ide-bpm-export-xpdl.cjs.entry.js.map +1 -1
  20. package/dist/cjs/gx-ide-bpm-import-files.cjs.entry.js +2 -3
  21. package/dist/cjs/gx-ide-bpm-import-files.cjs.entry.js.map +1 -1
  22. package/dist/cjs/gx-ide-bpm-import-gxpm.cjs.entry.js +1 -1
  23. package/dist/cjs/gx-ide-bpm-objects-selector.cjs.entry.js +1 -1
  24. package/dist/cjs/gx-ide-bpm-sync-gam-roles.cjs.entry.js +2 -3
  25. package/dist/cjs/gx-ide-bpm-sync-gam-roles.cjs.entry.js.map +1 -1
  26. package/dist/cjs/gx-ide-bpm-task-documents.cjs.entry.js +13 -16
  27. package/dist/cjs/gx-ide-bpm-task-documents.cjs.entry.js.map +1 -1
  28. package/dist/cjs/gx-ide-bpm-timer-duration.cjs.entry.js +2 -3
  29. package/dist/cjs/gx-ide-bpm-timer-duration.cjs.entry.js.map +1 -1
  30. package/dist/cjs/gx-ide-card.cjs.entry.js +1 -1
  31. package/dist/cjs/gx-ide-chat-container_2.cjs.entry.js +239 -0
  32. package/dist/cjs/gx-ide-chat-container_2.cjs.entry.js.map +1 -0
  33. package/dist/cjs/gx-ide-connect-gx-server.cjs.entry.js +18 -23
  34. package/dist/cjs/gx-ide-connect-gx-server.cjs.entry.js.map +1 -1
  35. package/dist/cjs/gx-ide-container_2.cjs.entry.js +1 -2
  36. package/dist/cjs/gx-ide-container_2.cjs.entry.js.map +1 -1
  37. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js +9 -14
  38. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js.map +1 -1
  39. package/dist/cjs/gx-ide-current-user-info.cjs.entry.js +5 -7
  40. package/dist/cjs/gx-ide-current-user-info.cjs.entry.js.map +1 -1
  41. package/dist/cjs/gx-ide-dashboard-home.cjs.entry.js +6 -8
  42. package/dist/cjs/gx-ide-dashboard-home.cjs.entry.js.map +1 -1
  43. package/dist/cjs/gx-ide-data-selector.cjs.entry.js +6 -8
  44. package/dist/cjs/gx-ide-data-selector.cjs.entry.js.map +1 -1
  45. package/dist/cjs/gx-ide-data-type-selector.cjs.entry.js +6 -8
  46. package/dist/cjs/gx-ide-data-type-selector.cjs.entry.js.map +1 -1
  47. package/dist/cjs/gx-ide-deployment-tool.cjs.entry.js +16 -20
  48. package/dist/cjs/gx-ide-deployment-tool.cjs.entry.js.map +1 -1
  49. package/dist/cjs/gx-ide-design-import.cjs.entry.js +27 -36
  50. package/dist/cjs/gx-ide-design-import.cjs.entry.js.map +1 -1
  51. package/dist/cjs/gx-ide-directory-selector.cjs.entry.js +1 -2
  52. package/dist/cjs/gx-ide-directory-selector.cjs.entry.js.map +1 -1
  53. package/dist/cjs/gx-ide-edit-module-server.cjs.entry.js +2 -3
  54. package/dist/cjs/gx-ide-edit-module-server.cjs.entry.js.map +1 -1
  55. package/dist/cjs/gx-ide-entity-selector.cjs.entry.js +6 -9
  56. package/dist/cjs/gx-ide-entity-selector.cjs.entry.js.map +1 -1
  57. package/dist/cjs/gx-ide-file-item.cjs.entry.js +5 -6
  58. package/dist/cjs/gx-ide-file-item.cjs.entry.js.map +1 -1
  59. package/dist/cjs/gx-ide-file-uploader.cjs.entry.js +62 -48
  60. package/dist/cjs/gx-ide-file-uploader.cjs.entry.js.map +1 -1
  61. package/dist/cjs/gx-ide-gam-installation-settings.cjs.entry.js +2 -3
  62. package/dist/cjs/gx-ide-gam-installation-settings.cjs.entry.js.map +1 -1
  63. package/dist/cjs/gx-ide-kb-manager-export.cjs.entry.js +7 -8
  64. package/dist/cjs/gx-ide-kb-manager-export.cjs.entry.js.map +1 -1
  65. package/dist/cjs/gx-ide-kb-manager-import.cjs.entry.js +10 -14
  66. package/dist/cjs/gx-ide-kb-manager-import.cjs.entry.js.map +1 -1
  67. package/dist/cjs/gx-ide-list-selector_2.cjs.entry.js +1 -1
  68. package/dist/cjs/gx-ide-list-selector_2.cjs.entry.js.map +1 -1
  69. package/dist/cjs/gx-ide-manage-module-references-v2.cjs.entry.js +18 -10
  70. package/dist/cjs/gx-ide-manage-module-references-v2.cjs.entry.js.map +1 -1
  71. package/dist/cjs/gx-ide-manage-module-references.cjs.entry.js +7 -8
  72. package/dist/cjs/gx-ide-manage-module-references.cjs.entry.js.map +1 -1
  73. package/dist/cjs/gx-ide-navigation-report.cjs.entry.js +4 -7
  74. package/dist/cjs/gx-ide-navigation-report.cjs.entry.js.map +1 -1
  75. package/dist/cjs/gx-ide-new-environment.cjs.entry.js +14 -19
  76. package/dist/cjs/gx-ide-new-environment.cjs.entry.js.map +1 -1
  77. package/dist/cjs/gx-ide-new-kb.cjs.entry.js +34 -39
  78. package/dist/cjs/gx-ide-new-kb.cjs.entry.js.map +1 -1
  79. package/dist/cjs/gx-ide-new-object.cjs.entry.js +6 -9
  80. package/dist/cjs/gx-ide-new-object.cjs.entry.js.map +1 -1
  81. package/dist/cjs/gx-ide-new-version.cjs.entry.js +3 -3
  82. package/dist/cjs/gx-ide-new-version.cjs.entry.js.map +1 -1
  83. package/dist/cjs/gx-ide-object-selector.cjs.entry.js +10 -12
  84. package/dist/cjs/gx-ide-object-selector.cjs.entry.js.map +1 -1
  85. package/dist/cjs/gx-ide-open-api-import.cjs.entry.js +8 -13
  86. package/dist/cjs/gx-ide-open-api-import.cjs.entry.js.map +1 -1
  87. package/dist/cjs/gx-ide-references.cjs.entry.js +21 -27
  88. package/dist/cjs/gx-ide-references.cjs.entry.js.map +1 -1
  89. package/dist/cjs/gx-ide-sc-chat-container.cjs.entry.js +202 -98
  90. package/dist/cjs/gx-ide-sc-chat-container.cjs.entry.js.map +1 -1
  91. package/dist/cjs/gx-ide-select-kb-items.cjs.entry.js +10 -17
  92. package/dist/cjs/gx-ide-select-kb-items.cjs.entry.js.map +1 -1
  93. package/dist/cjs/gx-ide-select-user-team.cjs.entry.js +3 -4
  94. package/dist/cjs/gx-ide-select-user-team.cjs.entry.js.map +1 -1
  95. package/dist/cjs/gx-ide-share-kb.cjs.entry.js +6 -10
  96. package/dist/cjs/gx-ide-share-kb.cjs.entry.js.map +1 -1
  97. package/dist/cjs/gx-ide-sign-in-team.cjs.entry.js +2 -3
  98. package/dist/cjs/gx-ide-sign-in-team.cjs.entry.js.map +1 -1
  99. package/dist/cjs/gx-ide-sign-in.cjs.entry.js +1 -1
  100. package/dist/cjs/gx-ide-splash.cjs.entry.js +6 -8
  101. package/dist/cjs/gx-ide-splash.cjs.entry.js.map +1 -1
  102. package/dist/cjs/gx-ide-start-page.cjs.entry.js +9 -13
  103. package/dist/cjs/gx-ide-start-page.cjs.entry.js.map +1 -1
  104. package/dist/cjs/gx-ide-status-buttons.cjs.entry.js +1 -1
  105. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js +3 -3
  106. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js.map +1 -1
  107. package/dist/cjs/gx-ide-team-dev-select-recent-comment.cjs.entry.js +1 -1
  108. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js +2 -2
  109. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js.map +1 -1
  110. package/dist/cjs/gx-ide-team-dev-update-to-revision.cjs.entry.js +1 -1
  111. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js +4 -5
  112. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js.map +1 -1
  113. package/dist/cjs/gx-ide-template.cjs.entry.js +1 -1
  114. package/dist/cjs/gx-ide-welcome-page.cjs.entry.js +8 -11
  115. package/dist/cjs/gx-ide-welcome-page.cjs.entry.js.map +1 -1
  116. package/dist/cjs/gx-ide-wf-settings.cjs.entry.js +1 -1
  117. package/dist/cjs/gx-ide-ww-attributes.cjs.entry.js +11 -18
  118. package/dist/cjs/gx-ide-ww-attributes.cjs.entry.js.map +1 -1
  119. package/dist/cjs/gx-ide-ww-files.cjs.entry.js +19 -22
  120. package/dist/cjs/gx-ide-ww-files.cjs.entry.js.map +1 -1
  121. package/dist/cjs/gx-ide-ww-images.cjs.entry.js +20 -9
  122. package/dist/cjs/gx-ide-ww-images.cjs.entry.js.map +1 -1
  123. package/dist/cjs/{helpers-30f109a4.js → helpers-e5a13fa5.js} +6 -6
  124. package/dist/cjs/helpers-e5a13fa5.js.map +1 -0
  125. package/dist/cjs/index.cjs.js +2 -2
  126. package/dist/cjs/index.cjs.js.map +1 -1
  127. package/dist/cjs/loader.cjs.js +1 -1
  128. package/dist/cjs/{locale-ff30a5f3.js → locale-36b93b1b.js} +4 -4
  129. package/dist/cjs/locale-36b93b1b.js.map +1 -0
  130. package/dist/collection/collection-manifest.json +2 -1
  131. package/dist/collection/common/common.js +23 -13
  132. package/dist/collection/common/common.js.map +1 -1
  133. package/dist/collection/common/form-validation.js +7 -4
  134. package/dist/collection/common/form-validation.js.map +1 -1
  135. package/dist/collection/common/helpers.js +9 -10
  136. package/dist/collection/common/helpers.js.map +1 -1
  137. package/dist/collection/common/locale.js +3 -3
  138. package/dist/collection/common/locale.js.map +1 -1
  139. package/dist/collection/common/render-suggest.js +1 -1
  140. package/dist/collection/common/render-suggest.js.map +1 -1
  141. package/dist/collection/components/_helpers/container/container.js +1 -2
  142. package/dist/collection/components/_helpers/container/container.js.map +1 -1
  143. package/dist/collection/components/_helpers/directory-selector/directory-selector.js +1 -2
  144. package/dist/collection/components/_helpers/directory-selector/directory-selector.js.map +1 -1
  145. package/dist/collection/components/_helpers/entity-selector/entity-selector.js +2 -4
  146. package/dist/collection/components/_helpers/entity-selector/entity-selector.js.map +1 -1
  147. package/dist/collection/components/_helpers/list-selector/list-selector-item/list-selector-item.js +1 -1
  148. package/dist/collection/components/_helpers/list-selector/list-selector-item/list-selector-item.js.map +1 -1
  149. package/dist/collection/components/ai-assistant/ai-assistant.js +8 -14
  150. package/dist/collection/components/ai-assistant/ai-assistant.js.map +1 -1
  151. package/dist/collection/components/bpm/application-declaration/bpm-app-declaration.css +1 -0
  152. package/dist/collection/components/bpm/application-declaration/bpm-app-declaration.js +2 -3
  153. package/dist/collection/components/bpm/application-declaration/bpm-app-declaration.js.map +1 -1
  154. package/dist/collection/components/bpm/export-xpdl/bpm-export-xpdl.js +2 -4
  155. package/dist/collection/components/bpm/export-xpdl/bpm-export-xpdl.js.map +1 -1
  156. package/dist/collection/components/bpm/import-files/bpm-import-files.js +1 -2
  157. package/dist/collection/components/bpm/import-files/bpm-import-files.js.map +1 -1
  158. package/dist/collection/components/bpm/sync-gam-roles/bpm-sync-gam-roles.js +1 -2
  159. package/dist/collection/components/bpm/sync-gam-roles/bpm-sync-gam-roles.js.map +1 -1
  160. package/dist/collection/components/bpm/task-documents/helpers.js +1 -1
  161. package/dist/collection/components/bpm/task-documents/helpers.js.map +1 -1
  162. package/dist/collection/components/bpm/task-documents/task-documents.js +7 -9
  163. package/dist/collection/components/bpm/task-documents/task-documents.js.map +1 -1
  164. package/dist/collection/components/bpm/timer-duration/bpm-timer-duration.js +1 -2
  165. package/dist/collection/components/bpm/timer-duration/bpm-timer-duration.js.map +1 -1
  166. package/dist/collection/components/chat/chat-container/chat-container.css +118 -0
  167. package/dist/collection/components/chat/chat-container/chat-container.js +218 -0
  168. package/dist/collection/components/chat/chat-container/chat-container.js.map +1 -0
  169. package/dist/collection/components/chat/chat-container/gx-ide-assets/chat-container/langs/chat-container.lang.en.json +9 -0
  170. package/dist/collection/components/chat/chat-container/gx-ide-assets/chat-container/langs/chat-container.lang.ja.json +9 -0
  171. package/dist/collection/components/chat/chat-container/gx-ide-assets/chat-container/langs/chat-container.lang.zh.json +9 -0
  172. package/dist/collection/components/chat/chat-welcome/chat-welcome.css +109 -0
  173. package/dist/collection/components/chat/chat-welcome/chat-welcome.js +228 -0
  174. package/dist/collection/components/chat/chat-welcome/chat-welcome.js.map +1 -0
  175. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/helpers.js +3 -0
  176. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/helpers.js.map +1 -0
  177. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/helpers.tsx +31 -0
  178. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/images/ai-avatar-welcome.svg +21 -0
  179. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/images/ai-avatar.svg +11 -0
  180. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/images/header-illustration.svg +24 -0
  181. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/langs/chat-welcome.lang.en.json +10 -0
  182. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/langs/chat-welcome.lang.ja.json +10 -0
  183. package/dist/collection/components/chat/chat-welcome/gx-ide-assets/chat-welcome/langs/chat-welcome.lang.zh.json +10 -0
  184. package/dist/collection/components/chat/code-render.js +65 -0
  185. package/dist/collection/components/chat/code-render.js.map +1 -0
  186. package/dist/collection/components/current-user-info/current-user-info.js +2 -3
  187. package/dist/collection/components/current-user-info/current-user-info.js.map +1 -1
  188. package/dist/collection/components/dashboard-home/dashboard-home.js +2 -3
  189. package/dist/collection/components/dashboard-home/dashboard-home.js.map +1 -1
  190. package/dist/collection/components/data-selector/data-selector.css +1 -0
  191. package/dist/collection/components/data-selector/data-selector.js +2 -3
  192. package/dist/collection/components/data-selector/data-selector.js.map +1 -1
  193. package/dist/collection/components/data-type-selector/data-type-selector.js +3 -4
  194. package/dist/collection/components/data-type-selector/data-type-selector.js.map +1 -1
  195. package/dist/collection/components/deployment-tool/deployment-tool.js +11 -18
  196. package/dist/collection/components/deployment-tool/deployment-tool.js.map +1 -1
  197. package/dist/collection/components/deployment-tool/helpers.js +4 -1
  198. package/dist/collection/components/deployment-tool/helpers.js.map +1 -1
  199. package/dist/collection/components/design-import/design-import.js +18 -26
  200. package/dist/collection/components/design-import/design-import.js.map +1 -1
  201. package/dist/collection/components/design-import/helpers.js +1 -1
  202. package/dist/collection/components/design-import/helpers.js.map +1 -1
  203. package/dist/collection/components/file-uploader/file-uploader.js +59 -44
  204. package/dist/collection/components/file-uploader/file-uploader.js.map +1 -1
  205. package/dist/collection/components/gam-installation-settings/gam-installation-settings.js +1 -2
  206. package/dist/collection/components/gam-installation-settings/gam-installation-settings.js.map +1 -1
  207. package/dist/collection/components/kb-manager-import/kb-manager-import.js +4 -7
  208. package/dist/collection/components/kb-manager-import/kb-manager-import.js.map +1 -1
  209. package/dist/collection/components/modules/edit-module-server/edit-module-server.js +1 -2
  210. package/dist/collection/components/modules/edit-module-server/edit-module-server.js.map +1 -1
  211. package/dist/collection/components/modules/manage-module-references/manage-module-references.js +2 -2
  212. package/dist/collection/components/modules/manage-module-references/manage-module-references.js.map +1 -1
  213. package/dist/collection/components/modules/manage-module-references-v2/manage-module-references-v2.js +13 -4
  214. package/dist/collection/components/modules/manage-module-references-v2/manage-module-references-v2.js.map +1 -1
  215. package/dist/collection/components/navigation-report/navigation-report.js +3 -6
  216. package/dist/collection/components/navigation-report/navigation-report.js.map +1 -1
  217. package/dist/collection/components/new-environment/new-environment.js +10 -15
  218. package/dist/collection/components/new-environment/new-environment.js.map +1 -1
  219. package/dist/collection/components/new-kb/new-kb.js +28 -32
  220. package/dist/collection/components/new-kb/new-kb.js.map +1 -1
  221. package/dist/collection/components/new-object/new-object.js +5 -8
  222. package/dist/collection/components/new-object/new-object.js.map +1 -1
  223. package/dist/collection/components/new-version/new-version.js +2 -2
  224. package/dist/collection/components/new-version/new-version.js.map +1 -1
  225. package/dist/collection/components/object-selector/object-selector.css +1 -0
  226. package/dist/collection/components/object-selector/object-selector.js +4 -5
  227. package/dist/collection/components/object-selector/object-selector.js.map +1 -1
  228. package/dist/collection/components/open-api-import/open-api-import.js +4 -8
  229. package/dist/collection/components/open-api-import/open-api-import.js.map +1 -1
  230. package/dist/collection/components/references/helpers.js +9 -13
  231. package/dist/collection/components/references/helpers.js.map +1 -1
  232. package/dist/collection/components/references/references.js +9 -11
  233. package/dist/collection/components/references/references.js.map +1 -1
  234. package/dist/collection/components/select-kb-items/helpers.js +5 -10
  235. package/dist/collection/components/select-kb-items/helpers.js.map +1 -1
  236. package/dist/collection/components/select-kb-items/select-kb-items.js +1 -2
  237. package/dist/collection/components/select-kb-items/select-kb-items.js.map +1 -1
  238. package/dist/collection/components/select-user-team/helpers.js +1 -1
  239. package/dist/collection/components/select-user-team/helpers.js.map +1 -1
  240. package/dist/collection/components/select-user-team/select-user-team.js +1 -2
  241. package/dist/collection/components/select-user-team/select-user-team.js.map +1 -1
  242. package/dist/collection/components/sign-in-team/sign-in-team.js +1 -2
  243. package/dist/collection/components/sign-in-team/sign-in-team.js.map +1 -1
  244. package/dist/collection/components/splash/splash.js +2 -3
  245. package/dist/collection/components/splash/splash.js.map +1 -1
  246. package/dist/collection/components/start-page/start-page.js +3 -6
  247. package/dist/collection/components/start-page/start-page.js.map +1 -1
  248. package/dist/collection/components/team-dev/commit/commit.css +1 -0
  249. package/dist/collection/components/team-dev/connect-gx-server/connect-gx-server.js +16 -21
  250. package/dist/collection/components/team-dev/connect-gx-server/connect-gx-server.js.map +1 -1
  251. package/dist/collection/components/team-dev/create-kb-from-server/create-kb-from-server.js +4 -8
  252. package/dist/collection/components/team-dev/create-kb-from-server/create-kb-from-server.js.map +1 -1
  253. package/dist/collection/components/team-dev/share-kb/share-kb.js +2 -5
  254. package/dist/collection/components/team-dev/share-kb/share-kb.js.map +1 -1
  255. package/dist/collection/components/team-dev/update/update.css +2 -0
  256. package/dist/collection/components/team-dev/update/update.js +1 -2
  257. package/dist/collection/components/team-dev/update/update.js.map +1 -1
  258. package/dist/collection/components/team-dev/update-partial-selection/update-partial-selection.js +1 -1
  259. package/dist/collection/components/team-dev/update-partial-selection/update-partial-selection.js.map +1 -1
  260. package/dist/collection/components/welcome-page/welcome-page.js +5 -7
  261. package/dist/collection/components/welcome-page/welcome-page.js.map +1 -1
  262. package/dist/collection/components/ww-attributes/helpers.js +1 -2
  263. package/dist/collection/components/ww-attributes/helpers.js.map +1 -1
  264. package/dist/collection/components/ww-attributes/ww-attributes.css +1 -0
  265. package/dist/collection/components/ww-attributes/ww-attributes.js +6 -11
  266. package/dist/collection/components/ww-attributes/ww-attributes.js.map +1 -1
  267. package/dist/collection/components/ww-files/helpers.js +1 -2
  268. package/dist/collection/components/ww-files/helpers.js.map +1 -1
  269. package/dist/collection/components/ww-files/ww-files.css +1 -0
  270. package/dist/collection/components/ww-files/ww-files.js +16 -18
  271. package/dist/collection/components/ww-files/ww-files.js.map +1 -1
  272. package/dist/collection/components/ww-images/ww-images.css +1 -0
  273. package/dist/collection/components/ww-images/ww-images.js +16 -5
  274. package/dist/collection/components/ww-images/ww-images.js.map +1 -1
  275. package/dist/collection/index.js +1 -1
  276. package/dist/collection/index.js.map +1 -1
  277. package/dist/collection/showcase/chat-container/callbacks.js +105 -90
  278. package/dist/collection/showcase/chat-container/callbacks.js.map +1 -1
  279. package/dist/collection/showcase/chat-container/chat.showcase.js +145 -10
  280. package/dist/collection/showcase/chat-container/chat.showcase.js.map +1 -1
  281. package/dist/collection/testing/locale.e2e.js +4 -3
  282. package/dist/collection/testing/locale.e2e.js.map +1 -1
  283. package/dist/components/MERCURY_ASSETS.js +5 -1
  284. package/dist/components/MERCURY_ASSETS.js.map +1 -1
  285. package/dist/components/ai-message.js +1 -2
  286. package/dist/components/ai-message.js.map +1 -1
  287. package/dist/components/chat-container.js +70 -7
  288. package/dist/components/chat-container.js.map +1 -1
  289. package/dist/components/chat-welcome.js +146 -0
  290. package/dist/components/chat-welcome.js.map +1 -0
  291. package/dist/components/code-render.js +68 -41
  292. package/dist/components/code-render.js.map +1 -1
  293. package/dist/components/common.js +27 -11
  294. package/dist/components/common.js.map +1 -1
  295. package/dist/components/container.js +1 -2
  296. package/dist/components/container.js.map +1 -1
  297. package/dist/components/entity-selector.js +3 -6
  298. package/dist/components/entity-selector.js.map +1 -1
  299. package/dist/components/file-item.js +1 -2
  300. package/dist/components/file-item.js.map +1 -1
  301. package/dist/components/form-validation.js +6 -2
  302. package/dist/components/form-validation.js.map +1 -1
  303. package/dist/components/gx-ide-ai-assistant.js +8 -14
  304. package/dist/components/gx-ide-ai-assistant.js.map +1 -1
  305. package/dist/components/gx-ide-bpm-app-declaration.js +4 -6
  306. package/dist/components/gx-ide-bpm-app-declaration.js.map +1 -1
  307. package/dist/components/gx-ide-bpm-export-xpdl.js +2 -4
  308. package/dist/components/gx-ide-bpm-export-xpdl.js.map +1 -1
  309. package/dist/components/gx-ide-bpm-import-files.js +1 -2
  310. package/dist/components/gx-ide-bpm-import-files.js.map +1 -1
  311. package/dist/components/gx-ide-bpm-sync-gam-roles.js +1 -2
  312. package/dist/components/gx-ide-bpm-sync-gam-roles.js.map +1 -1
  313. package/dist/components/gx-ide-bpm-task-documents.js +9 -12
  314. package/dist/components/gx-ide-bpm-task-documents.js.map +1 -1
  315. package/dist/components/gx-ide-bpm-timer-duration.js +1 -2
  316. package/dist/components/gx-ide-bpm-timer-duration.js.map +1 -1
  317. package/dist/components/gx-ide-chat-welcome.d.ts +11 -0
  318. package/dist/components/gx-ide-chat-welcome.js +8 -0
  319. package/dist/components/gx-ide-chat-welcome.js.map +1 -0
  320. package/dist/components/gx-ide-connect-gx-server.js +16 -21
  321. package/dist/components/gx-ide-connect-gx-server.js.map +1 -1
  322. package/dist/components/gx-ide-create-kb-from-server.js +5 -10
  323. package/dist/components/gx-ide-create-kb-from-server.js.map +1 -1
  324. package/dist/components/gx-ide-current-user-info.js +3 -5
  325. package/dist/components/gx-ide-current-user-info.js.map +1 -1
  326. package/dist/components/gx-ide-dashboard-home.js +3 -5
  327. package/dist/components/gx-ide-dashboard-home.js.map +1 -1
  328. package/dist/components/gx-ide-data-selector.js +4 -6
  329. package/dist/components/gx-ide-data-selector.js.map +1 -1
  330. package/dist/components/gx-ide-data-type-selector.js +4 -6
  331. package/dist/components/gx-ide-data-type-selector.js.map +1 -1
  332. package/dist/components/gx-ide-deployment-tool.js +15 -19
  333. package/dist/components/gx-ide-deployment-tool.js.map +1 -1
  334. package/dist/components/gx-ide-design-import.js +20 -29
  335. package/dist/components/gx-ide-design-import.js.map +1 -1
  336. package/dist/components/gx-ide-directory-selector.js +1 -2
  337. package/dist/components/gx-ide-directory-selector.js.map +1 -1
  338. package/dist/components/gx-ide-edit-module-server.js +1 -2
  339. package/dist/components/gx-ide-edit-module-server.js.map +1 -1
  340. package/dist/components/gx-ide-file-uploader.js +60 -46
  341. package/dist/components/gx-ide-file-uploader.js.map +1 -1
  342. package/dist/components/gx-ide-gam-installation-settings.js +1 -2
  343. package/dist/components/gx-ide-gam-installation-settings.js.map +1 -1
  344. package/dist/components/gx-ide-kb-manager-export.js +1 -2
  345. package/dist/components/gx-ide-kb-manager-export.js.map +1 -1
  346. package/dist/components/gx-ide-kb-manager-import.js +5 -9
  347. package/dist/components/gx-ide-kb-manager-import.js.map +1 -1
  348. package/dist/components/gx-ide-manage-module-references-v2.js +14 -6
  349. package/dist/components/gx-ide-manage-module-references-v2.js.map +1 -1
  350. package/dist/components/gx-ide-manage-module-references.js +3 -4
  351. package/dist/components/gx-ide-manage-module-references.js.map +1 -1
  352. package/dist/components/gx-ide-navigation-report.js +3 -6
  353. package/dist/components/gx-ide-navigation-report.js.map +1 -1
  354. package/dist/components/gx-ide-new-environment.js +10 -15
  355. package/dist/components/gx-ide-new-environment.js.map +1 -1
  356. package/dist/components/gx-ide-new-kb.js +29 -34
  357. package/dist/components/gx-ide-new-kb.js.map +1 -1
  358. package/dist/components/gx-ide-new-object.js +5 -8
  359. package/dist/components/gx-ide-new-object.js.map +1 -1
  360. package/dist/components/gx-ide-new-version.js +2 -2
  361. package/dist/components/gx-ide-new-version.js.map +1 -1
  362. package/dist/components/gx-ide-object-selector.js +6 -8
  363. package/dist/components/gx-ide-object-selector.js.map +1 -1
  364. package/dist/components/gx-ide-open-api-import.js +5 -10
  365. package/dist/components/gx-ide-open-api-import.js.map +1 -1
  366. package/dist/components/gx-ide-references.js +18 -24
  367. package/dist/components/gx-ide-references.js.map +1 -1
  368. package/dist/components/gx-ide-sc-chat-container.js +215 -100
  369. package/dist/components/gx-ide-sc-chat-container.js.map +1 -1
  370. package/dist/components/gx-ide-select-kb-items.js +7 -14
  371. package/dist/components/gx-ide-select-kb-items.js.map +1 -1
  372. package/dist/components/gx-ide-select-user-team.js +2 -3
  373. package/dist/components/gx-ide-select-user-team.js.map +1 -1
  374. package/dist/components/gx-ide-share-kb.js +3 -7
  375. package/dist/components/gx-ide-share-kb.js.map +1 -1
  376. package/dist/components/gx-ide-sign-in-team.js +1 -2
  377. package/dist/components/gx-ide-sign-in-team.js.map +1 -1
  378. package/dist/components/gx-ide-splash.js +3 -5
  379. package/dist/components/gx-ide-splash.js.map +1 -1
  380. package/dist/components/gx-ide-start-page.js +4 -8
  381. package/dist/components/gx-ide-start-page.js.map +1 -1
  382. package/dist/components/gx-ide-team-dev-commit.js +1 -1
  383. package/dist/components/gx-ide-team-dev-commit.js.map +1 -1
  384. package/dist/components/gx-ide-team-dev-update-partial-selection.js +1 -1
  385. package/dist/components/gx-ide-team-dev-update-partial-selection.js.map +1 -1
  386. package/dist/components/gx-ide-team-dev-update.js +2 -3
  387. package/dist/components/gx-ide-team-dev-update.js.map +1 -1
  388. package/dist/components/gx-ide-welcome-page.js +6 -9
  389. package/dist/components/gx-ide-welcome-page.js.map +1 -1
  390. package/dist/components/gx-ide-ww-attributes.js +9 -16
  391. package/dist/components/gx-ide-ww-attributes.js.map +1 -1
  392. package/dist/components/gx-ide-ww-files.js +18 -21
  393. package/dist/components/gx-ide-ww-files.js.map +1 -1
  394. package/dist/components/gx-ide-ww-images.js +17 -6
  395. package/dist/components/gx-ide-ww-images.js.map +1 -1
  396. package/dist/components/helpers.js +5 -5
  397. package/dist/components/helpers.js.map +1 -1
  398. package/dist/components/index.js.map +1 -1
  399. package/dist/components/list-selector-item.js +1 -1
  400. package/dist/components/list-selector-item.js.map +1 -1
  401. package/dist/components/locale.js +3 -3
  402. package/dist/components/locale.js.map +1 -1
  403. package/dist/esm/MERCURY_ASSETS-039222dd.js +7 -0
  404. package/dist/esm/MERCURY_ASSETS-039222dd.js.map +1 -0
  405. package/dist/esm/code-render-f3afd300.js +83 -0
  406. package/dist/esm/code-render-f3afd300.js.map +1 -0
  407. package/dist/esm/{common-ccb4504a.js → common-719c4daf.js} +28 -12
  408. package/dist/esm/common-719c4daf.js.map +1 -0
  409. package/dist/esm/{form-validation-cd0215c6.js → form-validation-71dca8c6.js} +7 -3
  410. package/dist/esm/form-validation-71dca8c6.js.map +1 -0
  411. package/dist/esm/genexus-ide-ui.js +1 -1
  412. package/dist/esm/gx-ide-about.entry.js +1 -1
  413. package/dist/esm/gx-ide-ai-assistant.entry.js +9 -15
  414. package/dist/esm/gx-ide-ai-assistant.entry.js.map +1 -1
  415. package/dist/esm/gx-ide-ai-message.entry.js +3 -4
  416. package/dist/esm/gx-ide-ai-message.entry.js.map +1 -1
  417. package/dist/esm/gx-ide-bpm-app-declaration.entry.js +5 -7
  418. package/dist/esm/gx-ide-bpm-app-declaration.entry.js.map +1 -1
  419. package/dist/esm/gx-ide-bpm-assign-roles.entry.js +1 -1
  420. package/dist/esm/gx-ide-bpm-export-xpdl.entry.js +3 -5
  421. package/dist/esm/gx-ide-bpm-export-xpdl.entry.js.map +1 -1
  422. package/dist/esm/gx-ide-bpm-import-files.entry.js +2 -3
  423. package/dist/esm/gx-ide-bpm-import-files.entry.js.map +1 -1
  424. package/dist/esm/gx-ide-bpm-import-gxpm.entry.js +1 -1
  425. package/dist/esm/gx-ide-bpm-objects-selector.entry.js +1 -1
  426. package/dist/esm/gx-ide-bpm-sync-gam-roles.entry.js +2 -3
  427. package/dist/esm/gx-ide-bpm-sync-gam-roles.entry.js.map +1 -1
  428. package/dist/esm/gx-ide-bpm-task-documents.entry.js +10 -13
  429. package/dist/esm/gx-ide-bpm-task-documents.entry.js.map +1 -1
  430. package/dist/esm/gx-ide-bpm-timer-duration.entry.js +2 -3
  431. package/dist/esm/gx-ide-bpm-timer-duration.entry.js.map +1 -1
  432. package/dist/esm/gx-ide-card.entry.js +1 -1
  433. package/dist/esm/gx-ide-chat-container_2.entry.js +234 -0
  434. package/dist/esm/gx-ide-chat-container_2.entry.js.map +1 -0
  435. package/dist/esm/gx-ide-connect-gx-server.entry.js +18 -23
  436. package/dist/esm/gx-ide-connect-gx-server.entry.js.map +1 -1
  437. package/dist/esm/gx-ide-container_2.entry.js +1 -2
  438. package/dist/esm/gx-ide-container_2.entry.js.map +1 -1
  439. package/dist/esm/gx-ide-create-kb-from-server.entry.js +7 -12
  440. package/dist/esm/gx-ide-create-kb-from-server.entry.js.map +1 -1
  441. package/dist/esm/gx-ide-current-user-info.entry.js +4 -6
  442. package/dist/esm/gx-ide-current-user-info.entry.js.map +1 -1
  443. package/dist/esm/gx-ide-dashboard-home.entry.js +5 -7
  444. package/dist/esm/gx-ide-dashboard-home.entry.js.map +1 -1
  445. package/dist/esm/gx-ide-data-selector.entry.js +5 -7
  446. package/dist/esm/gx-ide-data-selector.entry.js.map +1 -1
  447. package/dist/esm/gx-ide-data-type-selector.entry.js +5 -7
  448. package/dist/esm/gx-ide-data-type-selector.entry.js.map +1 -1
  449. package/dist/esm/gx-ide-deployment-tool.entry.js +16 -20
  450. package/dist/esm/gx-ide-deployment-tool.entry.js.map +1 -1
  451. package/dist/esm/gx-ide-design-import.entry.js +21 -30
  452. package/dist/esm/gx-ide-design-import.entry.js.map +1 -1
  453. package/dist/esm/gx-ide-directory-selector.entry.js +1 -2
  454. package/dist/esm/gx-ide-directory-selector.entry.js.map +1 -1
  455. package/dist/esm/gx-ide-edit-module-server.entry.js +2 -3
  456. package/dist/esm/gx-ide-edit-module-server.entry.js.map +1 -1
  457. package/dist/esm/gx-ide-entity-selector.entry.js +4 -7
  458. package/dist/esm/gx-ide-entity-selector.entry.js.map +1 -1
  459. package/dist/esm/gx-ide-file-item.entry.js +1 -2
  460. package/dist/esm/gx-ide-file-item.entry.js.map +1 -1
  461. package/dist/esm/gx-ide-file-uploader.entry.js +61 -47
  462. package/dist/esm/gx-ide-file-uploader.entry.js.map +1 -1
  463. package/dist/esm/gx-ide-gam-installation-settings.entry.js +2 -3
  464. package/dist/esm/gx-ide-gam-installation-settings.entry.js.map +1 -1
  465. package/dist/esm/gx-ide-kb-manager-export.entry.js +2 -3
  466. package/dist/esm/gx-ide-kb-manager-export.entry.js.map +1 -1
  467. package/dist/esm/gx-ide-kb-manager-import.entry.js +6 -10
  468. package/dist/esm/gx-ide-kb-manager-import.entry.js.map +1 -1
  469. package/dist/esm/gx-ide-list-selector_2.entry.js +1 -1
  470. package/dist/esm/gx-ide-list-selector_2.entry.js.map +1 -1
  471. package/dist/esm/gx-ide-manage-module-references-v2.entry.js +16 -8
  472. package/dist/esm/gx-ide-manage-module-references-v2.entry.js.map +1 -1
  473. package/dist/esm/gx-ide-manage-module-references.entry.js +5 -6
  474. package/dist/esm/gx-ide-manage-module-references.entry.js.map +1 -1
  475. package/dist/esm/gx-ide-navigation-report.entry.js +4 -7
  476. package/dist/esm/gx-ide-navigation-report.entry.js.map +1 -1
  477. package/dist/esm/gx-ide-new-environment.entry.js +14 -19
  478. package/dist/esm/gx-ide-new-environment.entry.js.map +1 -1
  479. package/dist/esm/gx-ide-new-kb.entry.js +33 -38
  480. package/dist/esm/gx-ide-new-kb.entry.js.map +1 -1
  481. package/dist/esm/gx-ide-new-object.entry.js +6 -9
  482. package/dist/esm/gx-ide-new-object.entry.js.map +1 -1
  483. package/dist/esm/gx-ide-new-version.entry.js +3 -3
  484. package/dist/esm/gx-ide-new-version.entry.js.map +1 -1
  485. package/dist/esm/gx-ide-object-selector.entry.js +8 -10
  486. package/dist/esm/gx-ide-object-selector.entry.js.map +1 -1
  487. package/dist/esm/gx-ide-open-api-import.entry.js +6 -11
  488. package/dist/esm/gx-ide-open-api-import.entry.js.map +1 -1
  489. package/dist/esm/gx-ide-references.entry.js +19 -25
  490. package/dist/esm/gx-ide-references.entry.js.map +1 -1
  491. package/dist/esm/gx-ide-sc-chat-container.entry.js +203 -99
  492. package/dist/esm/gx-ide-sc-chat-container.entry.js.map +1 -1
  493. package/dist/esm/gx-ide-select-kb-items.entry.js +8 -15
  494. package/dist/esm/gx-ide-select-kb-items.entry.js.map +1 -1
  495. package/dist/esm/gx-ide-select-user-team.entry.js +3 -4
  496. package/dist/esm/gx-ide-select-user-team.entry.js.map +1 -1
  497. package/dist/esm/gx-ide-share-kb.entry.js +5 -9
  498. package/dist/esm/gx-ide-share-kb.entry.js.map +1 -1
  499. package/dist/esm/gx-ide-sign-in-team.entry.js +2 -3
  500. package/dist/esm/gx-ide-sign-in-team.entry.js.map +1 -1
  501. package/dist/esm/gx-ide-sign-in.entry.js +1 -1
  502. package/dist/esm/gx-ide-splash.entry.js +5 -7
  503. package/dist/esm/gx-ide-splash.entry.js.map +1 -1
  504. package/dist/esm/gx-ide-start-page.entry.js +5 -9
  505. package/dist/esm/gx-ide-start-page.entry.js.map +1 -1
  506. package/dist/esm/gx-ide-status-buttons.entry.js +1 -1
  507. package/dist/esm/gx-ide-team-dev-commit.entry.js +3 -3
  508. package/dist/esm/gx-ide-team-dev-commit.entry.js.map +1 -1
  509. package/dist/esm/gx-ide-team-dev-select-recent-comment.entry.js +1 -1
  510. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js +2 -2
  511. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js.map +1 -1
  512. package/dist/esm/gx-ide-team-dev-update-to-revision.entry.js +1 -1
  513. package/dist/esm/gx-ide-team-dev-update.entry.js +4 -5
  514. package/dist/esm/gx-ide-team-dev-update.entry.js.map +1 -1
  515. package/dist/esm/gx-ide-template.entry.js +1 -1
  516. package/dist/esm/gx-ide-welcome-page.entry.js +7 -10
  517. package/dist/esm/gx-ide-welcome-page.entry.js.map +1 -1
  518. package/dist/esm/gx-ide-wf-settings.entry.js +1 -1
  519. package/dist/esm/gx-ide-ww-attributes.entry.js +10 -17
  520. package/dist/esm/gx-ide-ww-attributes.entry.js.map +1 -1
  521. package/dist/esm/gx-ide-ww-files.entry.js +19 -22
  522. package/dist/esm/gx-ide-ww-files.entry.js.map +1 -1
  523. package/dist/esm/gx-ide-ww-images.entry.js +20 -9
  524. package/dist/esm/gx-ide-ww-images.entry.js.map +1 -1
  525. package/dist/esm/{helpers-10479d69.js → helpers-5f1c9a32.js} +6 -6
  526. package/dist/esm/helpers-5f1c9a32.js.map +1 -0
  527. package/dist/esm/index.js +2 -2
  528. package/dist/esm/index.js.map +1 -1
  529. package/dist/esm/loader.js +1 -1
  530. package/dist/esm/{locale-e5107fad.js → locale-643afe17.js} +4 -4
  531. package/dist/esm/locale-643afe17.js.map +1 -0
  532. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  533. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
  534. package/dist/genexus-ide-ui/gx-ide-assets/chat-container/langs/chat-container.lang.en.json +9 -0
  535. package/dist/genexus-ide-ui/gx-ide-assets/chat-container/langs/chat-container.lang.ja.json +9 -0
  536. package/dist/genexus-ide-ui/gx-ide-assets/chat-container/langs/chat-container.lang.zh.json +9 -0
  537. package/dist/genexus-ide-ui/gx-ide-assets/chat-welcome/helpers.tsx +31 -0
  538. package/dist/genexus-ide-ui/gx-ide-assets/chat-welcome/images/ai-avatar-welcome.svg +21 -0
  539. package/dist/genexus-ide-ui/gx-ide-assets/chat-welcome/images/ai-avatar.svg +11 -0
  540. package/dist/genexus-ide-ui/gx-ide-assets/chat-welcome/images/header-illustration.svg +24 -0
  541. package/dist/genexus-ide-ui/gx-ide-assets/chat-welcome/langs/chat-welcome.lang.en.json +10 -0
  542. package/dist/genexus-ide-ui/gx-ide-assets/chat-welcome/langs/chat-welcome.lang.ja.json +10 -0
  543. package/dist/genexus-ide-ui/gx-ide-assets/chat-welcome/langs/chat-welcome.lang.zh.json +10 -0
  544. package/dist/genexus-ide-ui/index.esm.js +2 -2
  545. package/dist/genexus-ide-ui/index.esm.js.map +1 -1
  546. package/dist/genexus-ide-ui/{p-d8379699.entry.js → p-02fc47cd.entry.js} +2 -2
  547. package/dist/genexus-ide-ui/{p-530c32aa.entry.js → p-032b4a81.entry.js} +25 -30
  548. package/dist/genexus-ide-ui/p-032b4a81.entry.js.map +1 -0
  549. package/dist/genexus-ide-ui/{p-eea944d4.entry.js → p-0d83a34d.entry.js} +63 -69
  550. package/dist/genexus-ide-ui/p-0d83a34d.entry.js.map +1 -0
  551. package/dist/genexus-ide-ui/{p-fcecdafa.entry.js → p-0e53f1ef.entry.js} +161 -163
  552. package/dist/genexus-ide-ui/p-0e53f1ef.entry.js.map +1 -0
  553. package/dist/genexus-ide-ui/{p-a1d73ca3.entry.js → p-11dccb8f.entry.js} +19 -20
  554. package/dist/genexus-ide-ui/p-11dccb8f.entry.js.map +1 -0
  555. package/dist/genexus-ide-ui/{p-fecc50e4.entry.js → p-29575656.entry.js} +85 -96
  556. package/dist/genexus-ide-ui/p-29575656.entry.js.map +1 -0
  557. package/dist/genexus-ide-ui/{p-14165308.entry.js → p-2be58a7a.entry.js} +2 -2
  558. package/dist/genexus-ide-ui/{p-fdf41406.entry.js → p-2dbf722d.entry.js} +77 -85
  559. package/dist/genexus-ide-ui/p-2dbf722d.entry.js.map +1 -0
  560. package/dist/genexus-ide-ui/{p-31beae9e.entry.js → p-2e90a13a.entry.js} +2 -3
  561. package/dist/genexus-ide-ui/p-2e90a13a.entry.js.map +1 -0
  562. package/dist/genexus-ide-ui/{p-ba7d1472.entry.js → p-353810b8.entry.js} +99 -104
  563. package/dist/genexus-ide-ui/p-353810b8.entry.js.map +1 -0
  564. package/dist/genexus-ide-ui/{p-b58fb87b.entry.js → p-39c527ff.entry.js} +2 -2
  565. package/dist/genexus-ide-ui/p-3edbf07d.js +109 -0
  566. package/dist/genexus-ide-ui/p-3edbf07d.js.map +1 -0
  567. package/dist/genexus-ide-ui/{p-ef5dfd35.entry.js → p-41a4364d.entry.js} +2 -4
  568. package/dist/genexus-ide-ui/{p-ef5dfd35.entry.js.map → p-41a4364d.entry.js.map} +1 -1
  569. package/dist/genexus-ide-ui/{p-68969051.entry.js → p-45d2fa91.entry.js} +11 -12
  570. package/dist/genexus-ide-ui/p-45d2fa91.entry.js.map +1 -0
  571. package/dist/genexus-ide-ui/{p-5687fdb7.entry.js → p-460db3ff.entry.js} +11 -13
  572. package/dist/genexus-ide-ui/{p-5687fdb7.entry.js.map → p-460db3ff.entry.js.map} +1 -1
  573. package/dist/genexus-ide-ui/{p-9a609b51.js → p-48f5911b.js} +50 -33
  574. package/dist/genexus-ide-ui/p-48f5911b.js.map +1 -0
  575. package/dist/genexus-ide-ui/{p-4b38fffc.entry.js → p-4d929210.entry.js} +2 -2
  576. package/dist/genexus-ide-ui/{p-de7f0c1f.entry.js → p-501c7b1f.entry.js} +19 -22
  577. package/dist/genexus-ide-ui/p-501c7b1f.entry.js.map +1 -0
  578. package/dist/genexus-ide-ui/{p-c747afac.entry.js → p-50eaa96d.entry.js} +99 -111
  579. package/dist/genexus-ide-ui/p-50eaa96d.entry.js.map +1 -0
  580. package/dist/genexus-ide-ui/p-51601b85.js +145 -0
  581. package/dist/genexus-ide-ui/p-51601b85.js.map +1 -0
  582. package/dist/genexus-ide-ui/{p-289c3290.js → p-549b8f0c.js} +16 -15
  583. package/dist/{esm/form-validation-cd0215c6.js.map → genexus-ide-ui/p-549b8f0c.js.map} +1 -1
  584. package/dist/genexus-ide-ui/{p-007173ef.entry.js → p-5a42428d.entry.js} +16 -19
  585. package/dist/genexus-ide-ui/p-5a42428d.entry.js.map +1 -0
  586. package/dist/genexus-ide-ui/{p-ded7444c.entry.js → p-5da3e999.entry.js} +16 -17
  587. package/dist/genexus-ide-ui/p-5da3e999.entry.js.map +1 -0
  588. package/dist/genexus-ide-ui/{p-1072bf33.entry.js → p-5e05f830.entry.js} +32 -38
  589. package/dist/genexus-ide-ui/p-5e05f830.entry.js.map +1 -0
  590. package/dist/genexus-ide-ui/{p-fe490103.entry.js → p-6168d48c.entry.js} +165 -174
  591. package/dist/genexus-ide-ui/p-6168d48c.entry.js.map +1 -0
  592. package/dist/genexus-ide-ui/{p-76c3fc51.entry.js → p-66d9269a.entry.js} +17 -22
  593. package/dist/genexus-ide-ui/p-66d9269a.entry.js.map +1 -0
  594. package/dist/genexus-ide-ui/{p-45996535.entry.js → p-6dc05a27.entry.js} +3 -4
  595. package/dist/genexus-ide-ui/p-6dc05a27.entry.js.map +1 -0
  596. package/dist/genexus-ide-ui/{p-f51adb3d.entry.js → p-75e1aa31.entry.js} +5 -6
  597. package/dist/genexus-ide-ui/p-75e1aa31.entry.js.map +1 -0
  598. package/dist/genexus-ide-ui/{p-e502c2fd.entry.js → p-7782e1b8.entry.js} +56 -61
  599. package/dist/genexus-ide-ui/p-7782e1b8.entry.js.map +1 -0
  600. package/dist/genexus-ide-ui/{p-1bc2613e.entry.js → p-7cedb0f0.entry.js} +66 -69
  601. package/dist/genexus-ide-ui/p-7cedb0f0.entry.js.map +1 -0
  602. package/dist/genexus-ide-ui/{p-311eedf3.js → p-857866f8.js} +8 -9
  603. package/dist/genexus-ide-ui/p-857866f8.js.map +1 -0
  604. package/dist/genexus-ide-ui/{p-f722955f.entry.js → p-8636a0bd.entry.js} +2 -2
  605. package/dist/genexus-ide-ui/{p-d095a37c.entry.js → p-8b046b4b.entry.js} +9 -10
  606. package/dist/genexus-ide-ui/p-8b046b4b.entry.js.map +1 -0
  607. package/dist/genexus-ide-ui/{p-4b79c3ab.entry.js → p-8f1f4126.entry.js} +10 -12
  608. package/dist/genexus-ide-ui/p-8f1f4126.entry.js.map +1 -0
  609. package/dist/genexus-ide-ui/{p-b2928645.entry.js → p-95f831a8.entry.js} +2 -2
  610. package/dist/genexus-ide-ui/{p-c91af626.entry.js → p-970d16ca.entry.js} +15 -15
  611. package/dist/genexus-ide-ui/{p-c91af626.entry.js.map → p-970d16ca.entry.js.map} +1 -1
  612. package/dist/genexus-ide-ui/{p-35f9ebbc.entry.js → p-9a39e49c.entry.js} +2 -2
  613. package/dist/genexus-ide-ui/{p-e24902a0.entry.js → p-9a9ee1ee.entry.js} +2 -2
  614. package/dist/genexus-ide-ui/{p-bbf88f43.entry.js → p-9b238bf7.entry.js} +173 -180
  615. package/dist/genexus-ide-ui/p-9b238bf7.entry.js.map +1 -0
  616. package/dist/genexus-ide-ui/{p-edf889d2.entry.js → p-9c690c36.entry.js} +13 -16
  617. package/dist/genexus-ide-ui/p-9c690c36.entry.js.map +1 -0
  618. package/dist/genexus-ide-ui/{p-4c717aa7.entry.js → p-a6029d9a.entry.js} +117 -131
  619. package/dist/genexus-ide-ui/p-a6029d9a.entry.js.map +1 -0
  620. package/dist/genexus-ide-ui/{p-833c3585.entry.js → p-a86a8692.entry.js} +33 -39
  621. package/dist/genexus-ide-ui/p-a86a8692.entry.js.map +1 -0
  622. package/dist/genexus-ide-ui/{p-f7421997.entry.js → p-a8cc41e4.entry.js} +58 -61
  623. package/dist/genexus-ide-ui/p-a8cc41e4.entry.js.map +1 -0
  624. package/dist/genexus-ide-ui/{p-767e0f6d.entry.js → p-ac0438d6.entry.js} +11 -12
  625. package/dist/genexus-ide-ui/p-ac0438d6.entry.js.map +1 -0
  626. package/dist/genexus-ide-ui/{p-56331289.entry.js → p-b1833747.entry.js} +38 -45
  627. package/dist/genexus-ide-ui/p-b1833747.entry.js.map +1 -0
  628. package/dist/genexus-ide-ui/{p-6b957e82.entry.js → p-b211bca8.entry.js} +2 -2
  629. package/dist/genexus-ide-ui/{p-84618917.entry.js → p-be794132.entry.js} +229 -236
  630. package/dist/genexus-ide-ui/p-be794132.entry.js.map +1 -0
  631. package/dist/genexus-ide-ui/{p-961bb2cc.entry.js → p-bfd9066c.entry.js} +8 -8
  632. package/dist/genexus-ide-ui/p-bfd9066c.entry.js.map +1 -0
  633. package/dist/genexus-ide-ui/{p-a47d71eb.entry.js → p-c30b2104.entry.js} +9 -11
  634. package/dist/genexus-ide-ui/p-c30b2104.entry.js.map +1 -0
  635. package/dist/genexus-ide-ui/{p-fa18a70c.entry.js → p-c5cca204.entry.js} +17 -20
  636. package/dist/genexus-ide-ui/p-c5cca204.entry.js.map +1 -0
  637. package/dist/genexus-ide-ui/p-cdf8b082.entry.js +338 -0
  638. package/dist/genexus-ide-ui/p-cdf8b082.entry.js.map +1 -0
  639. package/dist/genexus-ide-ui/{p-6d2174ed.entry.js → p-d1cc4724.entry.js} +17 -12
  640. package/dist/genexus-ide-ui/p-d1cc4724.entry.js.map +1 -0
  641. package/dist/genexus-ide-ui/{p-1dd7be84.entry.js → p-daa29451.entry.js} +14 -17
  642. package/dist/genexus-ide-ui/p-daa29451.entry.js.map +1 -0
  643. package/dist/genexus-ide-ui/{p-67762237.entry.js → p-db4750ff.entry.js} +139 -148
  644. package/dist/genexus-ide-ui/p-db4750ff.entry.js.map +1 -0
  645. package/dist/genexus-ide-ui/{p-3085add2.entry.js → p-db4f756a.entry.js} +176 -188
  646. package/dist/genexus-ide-ui/p-db4f756a.entry.js.map +1 -0
  647. package/dist/genexus-ide-ui/{p-05b04291.entry.js → p-e1d75f00.entry.js} +2 -2
  648. package/dist/genexus-ide-ui/{p-05b04291.entry.js.map → p-e1d75f00.entry.js.map} +1 -1
  649. package/dist/genexus-ide-ui/{p-f49bb305.entry.js → p-e26e05c7.entry.js} +12 -18
  650. package/dist/genexus-ide-ui/p-e26e05c7.entry.js.map +1 -0
  651. package/dist/genexus-ide-ui/{p-2b3938b4.entry.js → p-e37e95e7.entry.js} +4 -4
  652. package/dist/genexus-ide-ui/{p-4cbc8a8b.entry.js → p-e5571f49.entry.js} +26 -28
  653. package/dist/genexus-ide-ui/p-e5571f49.entry.js.map +1 -0
  654. package/dist/genexus-ide-ui/p-eb51429c.entry.js +317 -0
  655. package/dist/genexus-ide-ui/p-eb51429c.entry.js.map +1 -0
  656. package/dist/genexus-ide-ui/{p-29a026bb.entry.js → p-ec01c70c.entry.js} +15 -18
  657. package/dist/genexus-ide-ui/p-ec01c70c.entry.js.map +1 -0
  658. package/dist/genexus-ide-ui/{p-5ac47c69.js → p-ede7bd20.js} +6885 -6346
  659. package/dist/genexus-ide-ui/p-ede7bd20.js.map +1 -0
  660. package/dist/genexus-ide-ui/{p-e7fb3ee3.entry.js → p-f2bd9044.entry.js} +2 -2
  661. package/dist/genexus-ide-ui/{p-50f304fe.entry.js → p-f315c6e0.entry.js} +12 -14
  662. package/dist/genexus-ide-ui/{p-50f304fe.entry.js.map → p-f315c6e0.entry.js.map} +1 -1
  663. package/dist/genexus-ide-ui/{p-0550fd5f.entry.js → p-f52bcdac.entry.js} +2 -2
  664. package/dist/genexus-ide-ui/{p-b1851e6b.entry.js → p-f5879a41.entry.js} +3 -3
  665. package/dist/genexus-ide-ui/{p-b1851e6b.entry.js.map → p-f5879a41.entry.js.map} +1 -1
  666. package/dist/genexus-ide-ui/{p-f3f35e5c.entry.js → p-f5a48b33.entry.js} +6 -9
  667. package/dist/genexus-ide-ui/p-f5a48b33.entry.js.map +1 -0
  668. package/dist/genexus-ide-ui/{p-04c6bd23.entry.js → p-f6ceb01a.entry.js} +28 -29
  669. package/dist/genexus-ide-ui/p-f6ceb01a.entry.js.map +1 -0
  670. package/dist/types/common/common.d.ts +1 -1
  671. package/dist/types/components/{_helpers → chat}/chat-container/chat-container.d.ts +13 -2
  672. package/dist/types/components/chat/chat-welcome/chat-welcome.d.ts +39 -0
  673. package/dist/types/components/chat/chat-welcome/gx-ide-assets/chat-welcome/helpers.d.ts +1 -0
  674. package/dist/types/components/{_helpers/chat-container → chat}/code-render.d.ts +1 -1
  675. package/dist/types/components.d.ts +73 -0
  676. package/dist/types/index.d.ts +1 -1
  677. package/dist/types/showcase/chat-container/callbacks.d.ts +1 -1
  678. package/dist/types/showcase/chat-container/chat.showcase.d.ts +15 -0
  679. package/package.json +5 -5
  680. package/dist/cjs/MERCURY_ASSETS-6bbcc011.js +0 -5
  681. package/dist/cjs/MERCURY_ASSETS-6bbcc011.js.map +0 -1
  682. package/dist/cjs/assets-manager-7227a74b.js +0 -7
  683. package/dist/cjs/assets-manager-7227a74b.js.map +0 -1
  684. package/dist/cjs/code-render-db7cb770.js +0 -59
  685. package/dist/cjs/code-render-db7cb770.js.map +0 -1
  686. package/dist/cjs/common-72f91a78.js.map +0 -1
  687. package/dist/cjs/form-validation-178cf461.js.map +0 -1
  688. package/dist/cjs/gx-ide-chat-container.cjs.entry.js +0 -62
  689. package/dist/cjs/gx-ide-chat-container.cjs.entry.js.map +0 -1
  690. package/dist/cjs/helpers-30f109a4.js.map +0 -1
  691. package/dist/cjs/locale-ff30a5f3.js.map +0 -1
  692. package/dist/collection/components/_helpers/chat-container/chat-container.css +0 -204
  693. package/dist/collection/components/_helpers/chat-container/chat-container.js +0 -137
  694. package/dist/collection/components/_helpers/chat-container/chat-container.js.map +0 -1
  695. package/dist/collection/components/_helpers/chat-container/code-render.js +0 -46
  696. package/dist/collection/components/_helpers/chat-container/code-render.js.map +0 -1
  697. package/dist/components/assets-manager.js +0 -5
  698. package/dist/components/assets-manager.js.map +0 -1
  699. package/dist/esm/MERCURY_ASSETS-bbdf7018.js +0 -3
  700. package/dist/esm/MERCURY_ASSETS-bbdf7018.js.map +0 -1
  701. package/dist/esm/assets-manager-0d129105.js +0 -5
  702. package/dist/esm/assets-manager-0d129105.js.map +0 -1
  703. package/dist/esm/code-render-6cbb0e63.js +0 -56
  704. package/dist/esm/code-render-6cbb0e63.js.map +0 -1
  705. package/dist/esm/common-ccb4504a.js.map +0 -1
  706. package/dist/esm/gx-ide-chat-container.entry.js +0 -58
  707. package/dist/esm/gx-ide-chat-container.entry.js.map +0 -1
  708. package/dist/esm/helpers-10479d69.js.map +0 -1
  709. package/dist/esm/locale-e5107fad.js.map +0 -1
  710. package/dist/genexus-ide-ui/p-007173ef.entry.js.map +0 -1
  711. package/dist/genexus-ide-ui/p-04c6bd23.entry.js.map +0 -1
  712. package/dist/genexus-ide-ui/p-1072bf33.entry.js.map +0 -1
  713. package/dist/genexus-ide-ui/p-1a74d49a.entry.js +0 -231
  714. package/dist/genexus-ide-ui/p-1a74d49a.entry.js.map +0 -1
  715. package/dist/genexus-ide-ui/p-1bc2613e.entry.js.map +0 -1
  716. package/dist/genexus-ide-ui/p-1dd7be84.entry.js.map +0 -1
  717. package/dist/genexus-ide-ui/p-289c3290.js.map +0 -1
  718. package/dist/genexus-ide-ui/p-29a026bb.entry.js.map +0 -1
  719. package/dist/genexus-ide-ui/p-3085add2.entry.js.map +0 -1
  720. package/dist/genexus-ide-ui/p-311eedf3.js.map +0 -1
  721. package/dist/genexus-ide-ui/p-31beae9e.entry.js.map +0 -1
  722. package/dist/genexus-ide-ui/p-45996535.entry.js.map +0 -1
  723. package/dist/genexus-ide-ui/p-4b79c3ab.entry.js.map +0 -1
  724. package/dist/genexus-ide-ui/p-4c717aa7.entry.js.map +0 -1
  725. package/dist/genexus-ide-ui/p-4cbc8a8b.entry.js.map +0 -1
  726. package/dist/genexus-ide-ui/p-530c32aa.entry.js.map +0 -1
  727. package/dist/genexus-ide-ui/p-56331289.entry.js.map +0 -1
  728. package/dist/genexus-ide-ui/p-5ac47c69.js.map +0 -1
  729. package/dist/genexus-ide-ui/p-67762237.entry.js.map +0 -1
  730. package/dist/genexus-ide-ui/p-68969051.entry.js.map +0 -1
  731. package/dist/genexus-ide-ui/p-6d2174ed.entry.js.map +0 -1
  732. package/dist/genexus-ide-ui/p-6e4208d8.js +0 -9
  733. package/dist/genexus-ide-ui/p-6e4208d8.js.map +0 -1
  734. package/dist/genexus-ide-ui/p-767e0f6d.entry.js.map +0 -1
  735. package/dist/genexus-ide-ui/p-76c3fc51.entry.js.map +0 -1
  736. package/dist/genexus-ide-ui/p-833c3585.entry.js.map +0 -1
  737. package/dist/genexus-ide-ui/p-84618917.entry.js.map +0 -1
  738. package/dist/genexus-ide-ui/p-961bb2cc.entry.js.map +0 -1
  739. package/dist/genexus-ide-ui/p-9a609b51.js.map +0 -1
  740. package/dist/genexus-ide-ui/p-9ddea83b.js +0 -146
  741. package/dist/genexus-ide-ui/p-9ddea83b.js.map +0 -1
  742. package/dist/genexus-ide-ui/p-a1d73ca3.entry.js.map +0 -1
  743. package/dist/genexus-ide-ui/p-a47d71eb.entry.js.map +0 -1
  744. package/dist/genexus-ide-ui/p-ba7d1472.entry.js.map +0 -1
  745. package/dist/genexus-ide-ui/p-bbf88f43.entry.js.map +0 -1
  746. package/dist/genexus-ide-ui/p-be8a59fd.js +0 -107
  747. package/dist/genexus-ide-ui/p-be8a59fd.js.map +0 -1
  748. package/dist/genexus-ide-ui/p-c747afac.entry.js.map +0 -1
  749. package/dist/genexus-ide-ui/p-d095a37c.entry.js.map +0 -1
  750. package/dist/genexus-ide-ui/p-db9c3b37.entry.js +0 -85
  751. package/dist/genexus-ide-ui/p-db9c3b37.entry.js.map +0 -1
  752. package/dist/genexus-ide-ui/p-de7f0c1f.entry.js.map +0 -1
  753. package/dist/genexus-ide-ui/p-ded7444c.entry.js.map +0 -1
  754. package/dist/genexus-ide-ui/p-e502c2fd.entry.js.map +0 -1
  755. package/dist/genexus-ide-ui/p-edf889d2.entry.js.map +0 -1
  756. package/dist/genexus-ide-ui/p-eea944d4.entry.js.map +0 -1
  757. package/dist/genexus-ide-ui/p-f3f35e5c.entry.js.map +0 -1
  758. package/dist/genexus-ide-ui/p-f49bb305.entry.js.map +0 -1
  759. package/dist/genexus-ide-ui/p-f51adb3d.entry.js.map +0 -1
  760. package/dist/genexus-ide-ui/p-f7421997.entry.js.map +0 -1
  761. package/dist/genexus-ide-ui/p-fa18a70c.entry.js.map +0 -1
  762. package/dist/genexus-ide-ui/p-fcecdafa.entry.js.map +0 -1
  763. package/dist/genexus-ide-ui/p-fdf41406.entry.js.map +0 -1
  764. package/dist/genexus-ide-ui/p-fe490103.entry.js.map +0 -1
  765. package/dist/genexus-ide-ui/p-fecc50e4.entry.js.map +0 -1
  766. /package/dist/genexus-ide-ui/{p-d8379699.entry.js.map → p-02fc47cd.entry.js.map} +0 -0
  767. /package/dist/genexus-ide-ui/{p-14165308.entry.js.map → p-2be58a7a.entry.js.map} +0 -0
  768. /package/dist/genexus-ide-ui/{p-b58fb87b.entry.js.map → p-39c527ff.entry.js.map} +0 -0
  769. /package/dist/genexus-ide-ui/{p-4b38fffc.entry.js.map → p-4d929210.entry.js.map} +0 -0
  770. /package/dist/genexus-ide-ui/{p-f722955f.entry.js.map → p-8636a0bd.entry.js.map} +0 -0
  771. /package/dist/genexus-ide-ui/{p-b2928645.entry.js.map → p-95f831a8.entry.js.map} +0 -0
  772. /package/dist/genexus-ide-ui/{p-35f9ebbc.entry.js.map → p-9a39e49c.entry.js.map} +0 -0
  773. /package/dist/genexus-ide-ui/{p-e24902a0.entry.js.map → p-9a9ee1ee.entry.js.map} +0 -0
  774. /package/dist/genexus-ide-ui/{p-6b957e82.entry.js.map → p-b211bca8.entry.js.map} +0 -0
  775. /package/dist/genexus-ide-ui/{p-2b3938b4.entry.js.map → p-e37e95e7.entry.js.map} +0 -0
  776. /package/dist/genexus-ide-ui/{p-e7fb3ee3.entry.js.map → p-f2bd9044.entry.js.map} +0 -0
  777. /package/dist/genexus-ide-ui/{p-0550fd5f.entry.js.map → p-f52bcdac.entry.js.map} +0 -0
@@ -1,6 +1,6 @@
1
1
  import { r as e, c as t, h as r, H as o, a } from "./p-25a9f1d7.js";
2
2
 
3
- import { L as s } from "./p-311eedf3.js";
3
+ import { L as s } from "./p-857866f8.js";
4
4
 
5
5
  const i = ":root{--ui-animaton-speed:0.2s}.gxg-title-01{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-01-font-weight);font-size:var(--ds-title-01-font-size);letter-spacing:var(--ds-base-font-letter-spacing--comfortable);color:var(--ds-base-font-color);text-align:start;line-height:var(--ds-base-font-line-height--comfortable)}.gxg-title-01--negative{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-01-font-weight);font-size:var(--ds-title-01-font-size);letter-spacing:var(--ds-base-font-letter-spacing--comfortable);color:var(--ds-base-font-color);text-align:start;line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--negative)}.gxg-title-02{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-02-font-weight);font-size:var(--ds-title-02-font-size);letter-spacing:var(--ds-base-font-letter-spacing--regular);color:var(--ds-base-font-color);text-align:start;text-transform:uppercase;line-height:var(--ds-base-font-line-height--comfortable)}.gxg-title-02--negative{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-02-font-weight);font-size:var(--ds-title-02-font-size);letter-spacing:var(--ds-base-font-letter-spacing--regular);color:var(--ds-base-font-color);text-align:start;text-transform:uppercase;line-height:var(--ds-base-font-line-height--comfortable);color:var(--color-on-primary)}.gxg-title-03{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-03-font-weight);font-size:var(--ds-title-03-font-size);letter-spacing:var(--ds-base-font-letter-spacing--regular);color:var(--ds-base-font-color);text-align:start;text-transform:uppercase;line-height:var(--ds-base-font-line-height--comfortable)}.gxg-title-03--negative{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-03-font-weight);font-size:var(--ds-title-03-font-size);letter-spacing:var(--ds-base-font-letter-spacing--regular);color:var(--ds-base-font-color);text-align:start;text-transform:uppercase;line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--negative)}.gxg-title-04{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-04-font-weight);font-size:var(--ds-title-04-font-size);letter-spacing:var(--ds-base-font-letter-spacing--comfortable);color:var(--ds-base-font-color);text-align:start;line-height:var(--ds-base-font-line-height--comfortable)}.gxg-title-04--negative{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-04-font-weight);font-size:var(--ds-title-04-font-size);letter-spacing:var(--ds-base-font-letter-spacing--comfortable);color:var(--ds-base-font-color);text-align:start;line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--negative)}.gxg-title-05{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-05-font-weight);font-size:var(--ds-title-05-font-size);letter-spacing:var(--ds-base-font-letter-spacing--regular);color:var(--ds-base-font-color);text-align:start;line-height:var(--ds-base-font-line-height--comfortable)}.gxg-title-05--negative{font-family:var(--ds-base-font-family-primary);font-weight:var(--ds-title-05-font-weight);font-size:var(--ds-title-05-font-size);letter-spacing:var(--ds-base-font-letter-spacing--regular);color:var(--ds-base-font-color);text-align:start;line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--negative)}.gxg-text{font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable)}.gxg-text--negative{font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--negative)}.gxg-text--gray{font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--dimmed)}.gxg-quote{font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);font-style:italic}.gxg-quote--negative{color:var(--ds-base-font-color--negative)}.gxg-link{line-height:unset;font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--link);text-decoration:underline;cursor:pointer;display:inline-block}.gxg-link:hover{color:var(--ds-base-font-color--link-hover)}.gxg-link:active{color:var(--ds-base-font-color--link-active)}.gxg-link-gray{line-height:unset;font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--link);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--ds-base-font-color--dimmed)}.gxg-link-gray:hover{line-height:unset;font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--link);text-decoration:underline;cursor:pointer;display:inline-block;color:var(--ds-base-font-color--dimmed);filter:brightness(1.4)}.gxg-alert-error{font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--error);display:inline-block}.gxg-alert-warning{font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--warning);display:inline-block}.gxg-alert-success{font-family:var(--ds-base-font-family-primary);font-size:var(--ds-base-font-size);color:var(--ds-base-font-size-color);font-weight:var(--ds-base-font-size-weight);line-height:var(--ds-base-font-line-height--comfortable);color:var(--ds-base-font-color--success);display:inline-block}.gxg-tab--disabled{color:var(--color-primary-disabled);pointer-events:none}.gxg-tab--disabled[disabled]{color:var(--color-primary-disabled);pointer-events:none}.gxg-label{font-family:var(--ds-base-font-family-primary);font-weight:var(--gxg-label-font-weight);font-size:var(--gxg-label-font-size);color:var(--gxg-label-color);text-align:center;line-height:1.455em;display:flex;align-items:center}.gxg-label:hover{color:var(--color-primary-hover)}.gxg-label:focus{color:var(--color-primary-active)}.gxg-label:active{color:var(--color-primary-active)}.gxg-label[disabled]{color:var(--color-primary-disabled)}.gxg-label--negative{color:var(--color-on-primary)}.gxg-label--negative[disabled]{color:var(--color-on-disabled)}.gxg-scrollbar{}.gxg-scrollbar::-webkit-scrollbar{width:var(--gxg-scrollbar-width);height:var(--gxg-scrollbar-width)}.gxg-scrollbar::-webkit-scrollbar-track{background-color:var(--gxg-scrollbar-track-background);border-radius:var(--gxg-scrollbar-track-border-radius)}.gxg-scrollbar::-webkit-scrollbar-thumb{background-color:var(--gxg-scrollbar-track-thumb-background);border-radius:var(--gxg-scrollbar-track-thumb-radius)}.gxg-scrollbar::-webkit-scrollbar-thumb:hover{background-color:var(--gxg-scrollbar-track-thumb-hover-background)}.gxg-scrollbar::-webkit-scrollbar-corner{background:rgba(0, 0, 0, 0)}:host{display:block;border-radius:var(--ds-form-control-border-radius);--status-buttons-label-color:var(--mer-text__on-surface)}gx-ide-list-selector::part(list){display:flex;flex-direction:row;padding:var(--mer-spacing--2xs)}gx-ide-list-selector-item{flex:1;text-align:center;}gx-ide-list-selector-item .label{display:grid;inline-size:fit-content}gx-ide-list-selector-item .label__wrapper{grid-template-columns:max-content}gx-ide-list-selector-item .label__description{color:var(--status-buttons-label-color);text-transform:capitalize}gx-ide-list-selector-item .pseudo-checkbox{position:relative;inline-size:var(--gxg-checkbox-size);height:var(--gxg-checkbox-size);border:1px solid var(--gxg-checkbox-border-color);border-radius:var(--gxg-checkbox-border-radius)}gx-ide-list-selector-item input:after{display:none}gx-ide-list-selector-item input+.label .label__wrapper{display:inline-grid;grid-auto-flow:column;grid-auto-columns:max-content;align-items:center;justify-content:center}gx-ide-list-selector-item input:checked+.label{--status-buttons-label-color:var(--mer-text__on-surface);background-color:inherit}gx-ide-list-selector-item input:checked+.label .pseudo-checkbox{background:var(--icon__system_check_on-elevation--enabled) center center/80% no-repeat}gx-ide-list-selector-item:hover input:checked+.label{background-color:var(--ds-item-background-color--hover) !important}:host([compact]) gx-ide-list-selector-item{font-size:var(--mer-font__size--2xs)}:host([compact]) .label__wrapper{padding:var(--mer-spacing--3xs) var(--mer-spacing--xs) var(--mer-spacing--3xs) var(--mer-spacing--2xs)}:host([compact]) .label__wrapper:before{top:10px}:host([compact]) .label__universal-slot{margin-inline-end:var(--mer-spacing--3xs)}:host([no-inner-borders]) gx-ide-list-selector-item{border-inline-end:none}";
6
6
 
@@ -142,4 +142,4 @@ c = new WeakMap;
142
142
  f.style = i;
143
143
 
144
144
  export { f as gx_ide_status_buttons };
145
- //# sourceMappingURL=p-e7fb3ee3.entry.js.map
145
+ //# sourceMappingURL=p-f2bd9044.entry.js.map
@@ -1,10 +1,8 @@
1
1
  import { r as t, h as e, H as s, a as i } from "./p-25a9f1d7.js";
2
2
 
3
- import { L as n } from "./p-311eedf3.js";
3
+ import { L as n } from "./p-857866f8.js";
4
4
 
5
- import { g as a } from "./p-6e4208d8.js";
6
-
7
- import "./p-5ac47c69.js";
5
+ import { g as a } from "./p-ede7bd20.js";
8
6
 
9
7
  const o = "property";
10
8
 
@@ -136,7 +134,7 @@ var d = undefined && undefined.__classPrivateFieldSet || function(t, e, s, i, n)
136
134
  return i === "a" ? n.call(t, s) : n ? n.value = s : e.set(t, s), s;
137
135
  };
138
136
 
139
- var l, f, p, u, b, m, w, k, y, g, x, v, M, W, T, j, C, _, I, S, E, z, V, L;
137
+ var l, f, p, u, b, m, w, k, y, g, x, v, M, W, T, C, _, j, I, S, E, z, V, L;
140
138
 
141
139
  const A = a({
142
140
  category: "gemini-tools",
@@ -257,7 +255,7 @@ const q = class {
257
255
  checked: true,
258
256
  dragDisabled: true,
259
257
  dropDisabled: true,
260
- filter: h(this, C, "f").call(this),
258
+ filter: h(this, _, "f").call(this),
261
259
  filterType: this.addKbPropertiesIsChecked && !this.exportAllIsChecked ? "none" : "metadata",
262
260
  model: this.objectsTreeViewModel,
263
261
  showLines: "last",
@@ -266,10 +264,10 @@ const q = class {
266
264
  onCheckedItemsChange: h(this, E, "f")
267
265
  });
268
266
  }));
269
- j.set(this, (() => {
267
+ C.set(this, (() => {
270
268
  this.hasObjects = this.objectsTreeViewModel && this.objectsTreeViewModel.length > 0;
271
269
  }));
272
- C.set(this, (() => {
270
+ _.set(this, (() => {
273
271
  if (this.addKbPropertiesIsChecked && this.exportAllIsChecked) {
274
272
  return o;
275
273
  // only show properties
@@ -280,7 +278,7 @@ const q = class {
280
278
  }
281
279
  return "none";
282
280
  }));
283
- _.set(this, (t => {
281
+ j.set(this, (t => {
284
282
  this.exportAllIsChecked = h(this, b, "f").value === H;
285
283
  }));
286
284
  I.set(this, (async () => {
@@ -391,7 +389,7 @@ const q = class {
391
389
  }
392
390
  async componentWillLoad() {
393
391
  d(this, p, await n.getComponentStrings(this.el), "f");
394
- h(this, j, "f").call(this);
392
+ h(this, C, "f").call(this);
395
393
  h(this, l, "m", S).call(this, this.objectTypes);
396
394
  }
397
395
  render() {
@@ -455,7 +453,7 @@ const q = class {
455
453
  part: "export-all-checkbox",
456
454
  checkedValue: H,
457
455
  caption: h(this, p, "f").main.exportAll,
458
- onInput: h(this, _, "f"),
456
+ onInput: h(this, j, "f"),
459
457
  ref: t => d(this, b, t, "f")
460
458
  })))), e("div", {
461
459
  class: "main spacing-body-inline"
@@ -483,8 +481,8 @@ const q = class {
483
481
 
484
482
  f = new WeakMap, p = new WeakMap, u = new WeakMap, b = new WeakMap, m = new WeakMap,
485
483
  w = new WeakMap, k = new WeakMap, y = new WeakMap, g = new WeakMap, x = new WeakMap,
486
- v = new WeakMap, M = new WeakMap, W = new WeakMap, T = new WeakMap, j = new WeakMap,
487
- C = new WeakMap, _ = new WeakMap, I = new WeakMap, E = new WeakMap, z = new WeakMap,
484
+ v = new WeakMap, M = new WeakMap, W = new WeakMap, T = new WeakMap, C = new WeakMap,
485
+ _ = new WeakMap, j = new WeakMap, I = new WeakMap, E = new WeakMap, z = new WeakMap,
488
486
  V = new WeakMap, L = new WeakMap, l = new WeakSet, S = function _GxIdeKbManagerExport_objectsTypesArrayToMap(t) {
489
487
  t.forEach((t => {
490
488
  h(this, k, "f").set(t.id, t);
@@ -494,4 +492,4 @@ V = new WeakMap, L = new WeakMap, l = new WeakSet, S = function _GxIdeKbManagerE
494
492
  q.style = c;
495
493
 
496
494
  export { q as gx_ide_kb_manager_export };
497
- //# sourceMappingURL=p-50f304fe.entry.js.map
495
+ //# sourceMappingURL=p-f315c6e0.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["KB_PROPERTY","KB_OBJECT","getPropertyIcon","typeId","kbPropertiesTypes","find","propertyType","id","icon","convertObjectTypeToTreeItem","objectType","caption","name","startImgSrc","leaf","parts","expanded","items","convertObjectToTreeItem","object","objectTypes","get","metadata","convertPropertyToTreeItem","property","updateObjectsTreeModel","objects","objectTypesMap","objectsSet","actualTreeState","updatedTreeData","forEach","has","objectTreeItem","objectTypeTreeItemIndex","findIndex","treeItem","objectTypeTreeItem","push","add","convertKbPropertiesDataToTreeItemData","properties","propertyAlreadyExists","node","undefined","propertyTreeItem","unshift","clearKbPropertiesFromTree","filter","item","kbManagerExportCss","FILE_ICON","getIconPath","category","colorType","SETTINGS_ICON","GENERAL_REFERENCES_ICON","MENUS_NEW_OBJECT_ICON","TREE_VIEW_ICON","CHECKBOX_CHECKED_VALUE","CSS_BUNDLES","GxIdeKbManagerExport","_GxIdeKbManagerExport_addKbDescriptionEl","set","this","_GxIdeKbManagerExport_componentLocale","_GxIdeKbManagerExport_animateEmptyState","_GxIdeKbManagerExport_exportAllEl","_GxIdeKbManagerExport_fileNameEl","_GxIdeKbManagerExport_kBPropertiesData","_GxIdeKbManagerExport_objectTypesMap","Map","_GxIdeKbManagerExport_objectsSet","Set","_GxIdeKbManagerExport_addKBPropertiesCallbackHandler","async","_e","addKbPropertiesIsChecked","__classPrivateFieldGet","value","__classPrivateFieldSet","addKBPropertiesCallback","length","objectsTreeViewModel","_GxIdeKbManagerExport_addObjectsCallbackHandler","exportAllIsChecked","addedObjects","addObjectsCallback","_GxIdeKbManagerExport_updateObjects","call","_GxIdeKbManagerExport_addReferencesCallbackHandler","addReferencesCallback","checkedObjectsIds","_GxIdeKbManagerExport_cancelCallbackHandler","cancelled","cancelCallback","exportingIsInProcess","_GxIdeKbManagerExport_clearButtonHandler","clear","_GxIdeKbManagerExport_evaluateContentToDisplay","hasObjects","h","isAnimated","stateTitle","main","noObjectsToDisplay","key","class","onClick","beginByADdingSomeObjects","stateIconSrc","exportAllMessage","checkbox","checked","dragDisabled","dropDisabled","_GxIdeKbManagerExport_evaluateTreeViewFilters","filterType","model","showLines","toggleCheckboxes","sortItemsCallback","_GxIdeKbManagerExport_sortTreeItems","onCheckedItemsChange","_GxIdeKbManagerExport_objectsTreeCheckedItemsChangedHandler","_GxIdeKbManagerExport_evaluateObjects","_GxIdeKbManagerExport_exportAllChangedHandler","_event","_GxIdeKbManagerExport_exportCallbackHandler","fileName","checkedKbPropertiesIds","checkedPropertiesIds","checkedObjectIds","exportCallback","then","event","allItemsWithCheckbox","detail","values","atLeastOnePropertyItemIsChecked","atLeastOneObjectItemIsChecked","subModel","sort","a","b","localeCompare","_GxIdeKbManagerExport_renderFooter","referencesButtonEnabled","clearButtonEnabled","disabled","part","footer","clearButton","src","addReferencesButton","addButton","objectsDataArray","newObjectsTreeModel","objectsTreeViewModelChanged","newObjectsTreeViewModel","objectTypesChanged","newObjectTypesArray","_GxIdeKbManagerExport_instances","_GxIdeKbManagerExport_objectsTypesArrayToMap","componentWillLoad","Locale","getComponentStrings","el","render","exportButtonEnabled","cancelButtonEnabled","Host","htmlFor","header","exportFileName","autoFocus","ref","exportButton","cancelButton","optionsButton","title","optionsCallback","addKnowledgeBaseDescription","checkedValue","onInput","exportAll","loader","cancelLabel","loaderTitle","show","objectTypesArray"],"sources":["src/components/kb-manager-export/helpers.ts","src/components/kb-manager-export/kb-manager-export.scss?tag=gx-ide-kb-manager-export&encapsulation=shadow","src/components/kb-manager-export/kb-manager-export.tsx"],"sourcesContent":["// /* Tree View */\nimport {\n TreeViewItemModel,\n TreeViewModel\n} from \"@genexus/chameleon-controls-library\";\nimport { ObjectData, KBPropertyData, KBPropertyType } from \"./types\";\nimport { ObjectType } from \"../../common/types\";\nexport const KB_PROPERTY = \"property\";\nexport const KB_OBJECT = \"object\";\n\nconst getPropertyIcon = (\n typeId: string,\n kbPropertiesTypes: KBPropertyType[]\n): string =>\n // The object icon has to be retrieved from the ObjectTypes array, by\n // matching the ObjectData typeId with the ObjectType id\n kbPropertiesTypes.find(propertyType => propertyType.id === typeId).icon;\n\nconst convertObjectTypeToTreeItem = (\n objectType: ObjectType\n): TreeViewItemModel => ({\n caption: objectType.name,\n id: objectType.id,\n startImgSrc: objectType.icon,\n leaf: false,\n parts: \"object-type tree-view-item\",\n expanded: true,\n items: []\n});\n\nconst convertObjectToTreeItem = (\n object: ObjectData,\n objectTypes: Map<string, ObjectType>\n): TreeViewItemModel => ({\n caption: object.name,\n id: object.id,\n startImgSrc: objectTypes.get(object.typeId).icon,\n parts: \"object tree-view-item\",\n metadata: KB_OBJECT,\n leaf: true\n});\n\nconst convertPropertyToTreeItem = (\n property: KBPropertyData,\n kbPropertiesTypes: KBPropertyType[]\n): TreeViewItemModel => ({\n caption: property.name,\n id: property.id,\n startImgSrc: getPropertyIcon(property.typeId, kbPropertiesTypes),\n parts: \"property tree-view-item\",\n metadata: KB_PROPERTY,\n leaf: true\n});\n\n/**\n * Updates the tree model with the provided objects.\n * Objects may already exist and are placed under their parent node.\n * If the parent node doesn't exist (identified by typeId on ObjectTypes),\n * it is created and added at the bottom.\n *\n * @param {ObjectData[] | undefined} objects - The array of objects to update.\n * @param {Map<string, ObjectType>} objectTypesMap - A map of object types by ID.\n * @param {Set<string>} objectsSet - A set of existing object IDs.\n * @param {TreeViewModel} actualTreeState - The current tree state to be updated.\n * @returns {TreeViewModel} - The updated tree view model.\n */\nexport const updateObjectsTreeModel = (\n objects: ObjectData[] | undefined,\n objectTypesMap: Map<string, ObjectType>,\n objectsSet: Set<string>,\n actualTreeState: TreeViewModel\n): TreeViewModel => {\n if (!objects) {\n return [...actualTreeState];\n }\n\n const updatedTreeData: TreeViewModel = [...actualTreeState];\n objects.forEach(object => {\n // objects that already exists in the actual actualTreeState should not be added.\n\n if (objectsSet.has(object.id)) {\n // object already exists\n return;\n }\n\n const objectTreeItem = convertObjectToTreeItem(object, objectTypesMap);\n\n // TODO: Improve the algorithm efficiency. This check visits potentially all nodes\n // from the TreeViewModel on each iteration. Using a Map to pre-store the TreeView\n // nodes would improve efficiency.\n const objectTypeTreeItemIndex = updatedTreeData.findIndex(\n treeItem => treeItem.id === object.typeId\n );\n\n if (objectTypeTreeItemIndex === -1) {\n // Create and add new object type tree item\n const objectType = objectTypesMap.get(object.typeId);\n if (objectType) {\n const objectTypeTreeItem = convertObjectTypeToTreeItem(objectType);\n objectTypeTreeItem.items.push(objectTreeItem);\n updatedTreeData.push(objectTypeTreeItem);\n }\n } else {\n // objectType exists already. insert object as children of the object type tree item.\n updatedTreeData[objectTypeTreeItemIndex].items.push(objectTreeItem);\n }\n\n objectsSet.add(object.id);\n });\n\n return updatedTreeData;\n};\n\n/**\n * Converts an array of KB properties data into tree item data for a tree view.\n *\n * @param {KBPropertyData[]} properties - The array of KB property data.\n * @param {KBPropertyType[]} kbPropertiesTypes - The array of KB property types.\n * @param {TreeViewModel} actualTreeState - The current state of the tree.\n * @returns {TreeViewModel} - The updated tree view item models.\n */\nexport const convertKbPropertiesDataToTreeItemData = (\n properties: KBPropertyData[],\n kbPropertiesTypes: KBPropertyType[],\n actualTreeState: TreeViewModel\n): TreeViewModel => {\n if (!properties) {\n return [...actualTreeState];\n }\n\n const updatedTreeData: TreeViewModel = [...actualTreeState];\n properties.forEach(property => {\n // properties have no parent node, and they should be added at the beginning of the tree\n const propertyAlreadyExists =\n updatedTreeData.find(node => node.id === property.id) !== undefined;\n if (propertyAlreadyExists) {\n return;\n }\n const propertyTreeItem = convertPropertyToTreeItem(\n property,\n kbPropertiesTypes\n );\n updatedTreeData.unshift(propertyTreeItem);\n });\n return updatedTreeData;\n};\n\n/**\n * Removes properties from the tree model.\n *\n * @param {TreeViewModel} actualTreeState - The current state of the tree,\n * containing various tree view items.\n * @returns {TreeViewModel} - A new array of tree view items that excludes\n * any items with metadata of type `KB_PROPERTY`.\n */\nexport const clearKbPropertiesFromTree = (\n actualTreeState: TreeViewModel\n): TreeViewModel =>\n actualTreeState.filter(item => item.metadata !== KB_PROPERTY);\n","section {\n display: grid;\n block-size: 100%;\n grid-template-rows: max-content 1fr max-content;\n}\n\n.header__field-group {\n grid-template:\n \"export-file-name buttons-container\" max-content\n \"checkboxes checkboxes\" max-content\n / 1fr max-content;\n}\n.export-file-name {\n grid-area: export-file-name;\n}\n.header__buttons-container {\n grid-area: buttons-container;\n}\n.header__checkboxes {\n grid-area: checkboxes;\n grid-template-columns: max-content 1fr;\n}\n\n.main {\n position: relative;\n padding-block: var(--content-block-spacing);\n}\n","import { Component, Host, h, Prop, Element, State, Watch } from \"@stencil/core\";\n\nimport { ChCheckboxCustomEvent } from \"@genexus/chameleon-controls-library\";\nimport {\n TreeViewItemModelExtended,\n TreeViewModel\n} from \"@genexus/chameleon-controls-library\";\nimport { MercuryBundles } from \"@genexus/mercury\";\n\nimport { Locale } from \"../../common/locale\";\nimport {\n updateObjectsTreeModel,\n convertKbPropertiesDataToTreeItemData,\n clearKbPropertiesFromTree\n} from \"./helpers\";\nimport { ObjectType } from \"../../common/types\";\n\nimport { KB_PROPERTY, KB_OBJECT } from \"./helpers\";\nimport {\n KBPropertiesCallback,\n KBPropertyData,\n KBPropertyType,\n ObjectData,\n ExportFileDirectoryCallback,\n OptionsCallback,\n AddObjectsCallback,\n ExportCallback,\n AddReferencesCallback,\n CancelCallback\n} from \"./types\";\n\nimport { getIconPath } from \"@genexus/mercury\";\n\nconst FILE_ICON = getIconPath({\n category: \"gemini-tools\",\n name: \"file\",\n colorType: \"on-elevation\"\n});\nconst SETTINGS_ICON = getIconPath({\n category: \"gemini-tools\",\n name: \"settings\",\n colorType: \"primary\"\n});\nconst GENERAL_REFERENCES_ICON = getIconPath({\n category: \"window-tools\",\n name: \"references\",\n colorType: \"neutral\"\n});\nconst MENUS_NEW_OBJECT_ICON = getIconPath({\n category: \"menus\",\n name: \"new-object\",\n colorType: \"on-primary\"\n});\nconst TREE_VIEW_ICON = getIconPath({\n category: \"controls\",\n name: \"treeview\"\n});\nconst CHECKBOX_CHECKED_VALUE = \"true\";\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 \"utils/form\",\n \"utils/layout\",\n \"utils/spacing\",\n \"utils/typography\"\n];\n@Component({\n tag: \"gx-ide-kb-manager-export\",\n styleUrl: \"kb-manager-export.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/kb-manager-export\"]\n})\nexport class GxIdeKbManagerExport {\n #addKbDescriptionEl!: HTMLChCheckboxElement;\n #componentLocale: any;\n #animateEmptyState: boolean = false;\n #exportAllEl!: HTMLChCheckboxElement;\n #fileNameEl!: HTMLChEditElement;\n #kBPropertiesData!: KBPropertyData[];\n /**\n * Stores the object types information (name, and icon)\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #objectTypesMap: Map<string, ObjectType> = new Map();\n /**\n * Stores the object's id that have been added.\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #objectsSet: Set<string> = new Set();\n\n @Element() el: HTMLGxIdeKbManagerExportElement;\n\n @State() addKbPropertiesIsChecked = false;\n @State() atLeastOnePropertyItemIsChecked = false;\n @State() atLeastOneObjectItemIsChecked = false;\n @State() checkedObjectsIds: string[] = [];\n @State() checkedPropertiesIds: string[] = [];\n @State() exportAllIsChecked = false;\n @State() exportingIsInProcess = false;\n @State() hasObjects: boolean;\n @State() objectsTreeViewModel: TreeViewModel = [];\n @Watch(\"objectsTreeViewModel\")\n objectsTreeViewModelChanged(newObjectsTreeViewModel: TreeViewModel) {\n this.hasObjects =\n newObjectsTreeViewModel && newObjectsTreeViewModel.length > 0;\n if (!this.hasObjects) {\n this.atLeastOnePropertyItemIsChecked = false;\n this.atLeastOneObjectItemIsChecked = false;\n }\n }\n\n /**\n * Callback invoked when the user wants to include KB properties.\n */\n @Prop() readonly addKBPropertiesCallback!: KBPropertiesCallback;\n\n /**\n * Callback invoked when the user wants to add objects.\n */\n @Prop() readonly addObjectsCallback!: AddObjectsCallback;\n\n /**\n *Callback invoked when the user wants to add all the references for the selected objects.\n *@param itemIds:string[] The selected item ids\n *@returns : Returns an object with the items and its references\n */\n @Prop() readonly addReferencesCallback!: AddReferencesCallback;\n\n /**\n * Callback invoked when the user wants to cancel the export process.\n * @returns It returns a boolean indicating whether the process could be canceled or not.\n */\n @Prop() readonly cancelCallback!: CancelCallback;\n\n /**\n *Callback invoked when the user wants to initiate the export process.\n *@param fileName:string\n *@param itemIds:string[] The selected item ids\n *@returns : It returns a boolean indicating whether the process was successful\n */\n @Prop() readonly exportCallback!: ExportCallback;\n\n /**\n * Callback invoked when the user wants to access the export options.\n */\n @Prop() readonly exportFileDirectoryCallback!: ExportFileDirectoryCallback;\n\n /**\n * It allows defining the default Export File Name\n */\n @Prop() readonly fileName: string;\n\n /**\n * Array with the possible types of KB properties\n */\n @Prop() readonly kbPropertiesTypes: KBPropertyType[];\n\n /**\n * If true, it will display a loader when needed.\n */\n @Prop() readonly loader = false;\n\n /**\n * Array of possible object types\n */\n @Prop() readonly objectTypes: ObjectType[];\n @Watch(\"objectTypes\")\n objectTypesChanged(newObjectTypesArray: ObjectType[]) {\n this.#objectsTypesArrayToMap(newObjectTypesArray);\n }\n\n /**\n * Callback invoked when the user wants to access the export options.\n */\n @Prop() readonly optionsCallback: OptionsCallback;\n\n async componentWillLoad() {\n this.#componentLocale = await Locale.getComponentStrings(this.el);\n this.#evaluateObjects();\n this.#objectsTypesArrayToMap(this.objectTypes);\n }\n\n #addKBPropertiesCallbackHandler = async (\n _e: ChCheckboxCustomEvent<any> | InputEvent\n ) => {\n this.addKbPropertiesIsChecked =\n this.#addKbDescriptionEl.value === CHECKBOX_CHECKED_VALUE;\n if (this.addKbPropertiesIsChecked) {\n this.#kBPropertiesData = await this.addKBPropertiesCallback();\n if (this.#kBPropertiesData.length) {\n this.objectsTreeViewModel = convertKbPropertiesDataToTreeItemData(\n this.#kBPropertiesData,\n this.kbPropertiesTypes,\n this.objectsTreeViewModel\n );\n }\n } else {\n // previous properties (if any) should be removed\n this.objectsTreeViewModel = clearKbPropertiesFromTree(\n this.objectsTreeViewModel\n );\n }\n };\n\n #addObjectsCallbackHandler = async () => {\n this.#exportAllEl.value = undefined;\n this.exportAllIsChecked = false;\n const addedObjects = await this.addObjectsCallback();\n this.#updateObjects(addedObjects);\n };\n\n #addReferencesCallbackHandler = async () => {\n const objects: ObjectData[] = await this.addReferencesCallback(\n this.checkedObjectsIds\n );\n this.#updateObjects(objects);\n };\n\n #cancelCallbackHandler = async () => {\n const cancelled = await this.cancelCallback();\n if (cancelled) {\n this.exportingIsInProcess = false;\n }\n };\n\n #clearButtonHandler = () => {\n this.objectsTreeViewModel = [];\n this.#objectsSet.clear();\n this.#addKbDescriptionEl.value = undefined;\n this.#exportAllEl.value = undefined;\n };\n\n #evaluateContentToDisplay = () => {\n // Nothing to display on the tree-view\n if (!this.hasObjects && !this.exportAllIsChecked) {\n return (\n <gx-ide-empty-state\n isAnimated={this.#animateEmptyState}\n stateTitle={this.#componentLocale.main.noObjectsToDisplay}\n key=\"no-objects-empty-state\"\n >\n <button\n class=\"button-primary\"\n onClick={this.#addObjectsCallbackHandler}\n >\n {this.#componentLocale.main.beginByADdingSomeObjects}\n </button>\n </gx-ide-empty-state>\n );\n } else {\n this.#animateEmptyState = true; // improve performance if is first render\n }\n\n if (this.exportAllIsChecked) {\n return (\n <gx-ide-empty-state\n isAnimated={this.#animateEmptyState}\n stateIconSrc={TREE_VIEW_ICON}\n stateTitle={this.#componentLocale.main.exportAllMessage}\n key=\"exporting-all-empty-state\"\n ></gx-ide-empty-state>\n );\n } else {\n this.#animateEmptyState = true; // improve performance if is first render\n }\n\n return (\n <ch-tree-view-render\n class=\"tree-view\"\n checkbox\n checked\n dragDisabled\n dropDisabled\n filter={this.#evaluateTreeViewFilters()}\n filterType={\n this.addKbPropertiesIsChecked && !this.exportAllIsChecked\n ? \"none\"\n : \"metadata\"\n }\n model={this.objectsTreeViewModel}\n showLines=\"last\"\n toggleCheckboxes\n sortItemsCallback={this.#sortTreeItems}\n onCheckedItemsChange={this.#objectsTreeCheckedItemsChangedHandler}\n ></ch-tree-view-render>\n );\n };\n\n #evaluateObjects = () => {\n this.hasObjects =\n this.objectsTreeViewModel && this.objectsTreeViewModel.length > 0;\n };\n\n #evaluateTreeViewFilters = (): string => {\n if (this.addKbPropertiesIsChecked && this.exportAllIsChecked) {\n return KB_PROPERTY; // only show properties\n }\n if (!this.addKbPropertiesIsChecked && !this.exportAllIsChecked) {\n return KB_OBJECT; // only show objects\n }\n return \"none\";\n };\n\n #exportAllChangedHandler = (\n _event: ChCheckboxCustomEvent<any> | InputEvent\n ) => {\n this.exportAllIsChecked =\n this.#exportAllEl.value === CHECKBOX_CHECKED_VALUE;\n };\n\n #exportCallbackHandler = async () => {\n this.exportingIsInProcess = true;\n const fileName: string = this.#fileNameEl.value;\n const checkedKbPropertiesIds = this.addKbPropertiesIsChecked\n ? this.checkedPropertiesIds\n : [];\n const checkedObjectIds = this.exportAllIsChecked\n ? undefined\n : this.checkedObjectsIds;\n this.exportCallback(\n fileName,\n checkedKbPropertiesIds,\n checkedObjectIds\n ).then(() => {\n this.exportingIsInProcess = false;\n });\n // returns Promise<boolean> but no procedure was detailed on the spec.\n };\n\n #objectsTypesArrayToMap(objectTypesArray: ObjectType[]) {\n objectTypesArray.forEach(objectType => {\n this.#objectTypesMap.set(objectType.id, objectType);\n });\n }\n\n #objectsTreeCheckedItemsChangedHandler = (\n event: CustomEvent<Map<string, TreeViewItemModelExtended>>\n ) => {\n // filter 'checked objects' and 'checked properties' ids\n const checkedObjectsIds: string[] = [];\n const checkedPropertiesIds: string[] = [];\n const allItemsWithCheckbox = [...event.detail.values()];\n allItemsWithCheckbox.forEach(node => {\n if (node.item.checked && node.item.metadata === KB_OBJECT) {\n checkedObjectsIds.push(node.item.id);\n } else if (node.item.checked && node.item.metadata === KB_PROPERTY) {\n checkedPropertiesIds.push(node.item.id);\n }\n });\n this.checkedObjectsIds = checkedObjectsIds;\n this.checkedPropertiesIds = checkedPropertiesIds;\n\n this.atLeastOnePropertyItemIsChecked = this.checkedPropertiesIds.length > 0;\n this.atLeastOneObjectItemIsChecked = this.checkedObjectsIds.length > 0;\n };\n\n #sortTreeItems = (subModel: TreeViewModel) => {\n // \"property\" items should be added on top.\n // else sort alphabetically by \"caption\" value.\n return subModel.sort((a, b) => {\n if (a.metadata === \"property\" && b.metadata !== \"property\") {\n return -1;\n }\n if (b.metadata === \"property\" && a.metadata !== \"property\") {\n return 1;\n }\n\n return a.caption.localeCompare(b.caption);\n });\n };\n\n #renderFooter = (): HTMLElement => {\n const referencesButtonEnabled = this.atLeastOneObjectItemIsChecked;\n const clearButtonEnabled = this.objectsTreeViewModel.length > 0;\n return (\n <footer class=\"footer control-footer-with-border control-footer-space-between space-body spacing-body-inline spacing-body-block-end\">\n <button\n class=\"button-tertiary clear-btn\"\n disabled={!clearButtonEnabled}\n part=\"clear-button\"\n onClick={clearButtonEnabled && this.#clearButtonHandler}\n >\n {this.#componentLocale.footer.clearButton}\n </button>\n\n <div class=\"buttons-spacer\">\n <button\n class=\"button-secondary button-icon-and-text\"\n part=\"references-button\"\n disabled={!referencesButtonEnabled}\n onClick={\n referencesButtonEnabled && this.#addReferencesCallbackHandler\n }\n >\n <ch-image\n class=\"icon-sm\"\n disabled={!referencesButtonEnabled}\n src={GENERAL_REFERENCES_ICON}\n ></ch-image>\n {this.#componentLocale.footer.addReferencesButton}\n </button>\n\n <button\n // Add button\n class=\"button-primary button-icon-and-text\"\n disabled={this.exportAllIsChecked}\n part=\"add-button\"\n onClick={\n !this.exportAllIsChecked && this.#addObjectsCallbackHandler\n }\n >\n <ch-image\n class=\"icon-sm\"\n disabled={this.exportAllIsChecked}\n src={MENUS_NEW_OBJECT_ICON}\n ></ch-image>\n {this.#componentLocale.footer.addButton}\n </button>\n </div>\n </footer>\n );\n };\n\n #updateObjects = (objectsDataArray: ObjectData[]) => {\n if (objectsDataArray.length) {\n const newObjectsTreeModel = updateObjectsTreeModel(\n objectsDataArray,\n this.#objectTypesMap,\n this.#objectsSet,\n this.objectsTreeViewModel\n );\n this.objectsTreeViewModel = newObjectsTreeModel;\n }\n };\n\n render(): void {\n const exportButtonEnabled =\n this.atLeastOnePropertyItemIsChecked ||\n this.atLeastOneObjectItemIsChecked ||\n this.exportAllIsChecked;\n\n const cancelButtonEnabled = this.exportingIsInProcess;\n\n return (\n <Host class=\"widget\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n\n <section>\n <header class=\"header control-header-with-border space-body spacing-body-inline spacing-body-block-start\">\n <div class=\"field-group header__field-group\">\n <div class=\"field field-inline export-file-name\">\n <label class=\"label\" htmlFor=\"xpz-file\">\n {this.#componentLocale.header.exportFileName}\n </label>\n <ch-edit\n autoFocus\n id=\"xpz-file\"\n class=\"input\"\n part=\"xpz-file\"\n value={this.fileName}\n startImgSrc={FILE_ICON}\n ref={(el: HTMLChEditElement) =>\n (this.#fileNameEl = el as HTMLChEditElement)\n }\n ></ch-edit>\n </div>\n\n <div class=\"header__buttons-container buttons-spacer\">\n <button\n id=\"export-kb-btn\"\n class=\"button-primary export-btn\"\n part=\"export-btn\"\n disabled={!exportButtonEnabled}\n onClick={exportButtonEnabled && this.#exportCallbackHandler}\n >\n {this.#componentLocale.header.exportButton}\n </button>\n <button\n id=\"cancel-kb-export-btn\"\n class=\"button-secondary cancel-btn\"\n part=\"cancel-button\"\n disabled={!cancelButtonEnabled}\n onClick={cancelButtonEnabled && this.#cancelCallbackHandler}\n >\n {this.#componentLocale.header.cancelButton}\n </button>\n\n <button\n aria-label={this.#componentLocale.header.optionsButton}\n title={this.#componentLocale.header.optionsButton}\n class=\"button-tertiary button-icon-only options-btn\"\n part=\"select-kb-btn\"\n onClick={this.optionsCallback}\n >\n <ch-image class=\"icon-md\" src={SETTINGS_ICON}></ch-image>\n </button>\n </div>\n\n <div class=\"header__checkboxes field-group\">\n <ch-checkbox\n class=\"checkbox add-kb-description\"\n part=\"add-kb-description\"\n caption={\n this.#componentLocale.main.addKnowledgeBaseDescription\n }\n checkedValue={CHECKBOX_CHECKED_VALUE}\n onInput={this.#addKBPropertiesCallbackHandler}\n ref={(el: HTMLChCheckboxElement) =>\n (this.#addKbDescriptionEl = el as HTMLChCheckboxElement)\n }\n ></ch-checkbox>\n\n <ch-checkbox\n class=\"checkbox export-all\"\n part=\"export-all-checkbox\"\n checkedValue={CHECKBOX_CHECKED_VALUE}\n caption={this.#componentLocale.main.exportAll}\n onInput={this.#exportAllChangedHandler}\n ref={(el: HTMLChCheckboxElement) =>\n (this.#exportAllEl = el as HTMLChCheckboxElement)\n }\n ></ch-checkbox>\n </div>\n </div>\n </header>\n\n <div class=\"main spacing-body-inline\">\n {this.#evaluateContentToDisplay()}\n {this.loader && this.exportingIsInProcess && (\n <gx-ide-loader\n cancelLabel={this.#componentLocale.loader.cancelLabel}\n loaderTitle={this.#componentLocale.loader.title}\n cancelCallback={this.#cancelCallbackHandler}\n show\n class=\"loader\"\n ></gx-ide-loader>\n )}\n </div>\n\n {this.#renderFooter()}\n </section>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["KB_PROPERTY","KB_OBJECT","getPropertyIcon","typeId","kbPropertiesTypes","find","propertyType","id","icon","convertObjectTypeToTreeItem","objectType","caption","name","startImgSrc","leaf","parts","expanded","items","convertObjectToTreeItem","object","objectTypes","get","metadata","convertPropertyToTreeItem","property","updateObjectsTreeModel","objects","objectTypesMap","objectsSet","actualTreeState","updatedTreeData","forEach","has","objectTreeItem","objectTypeTreeItemIndex","findIndex","treeItem","objectTypeTreeItem","push","add","convertKbPropertiesDataToTreeItemData","properties","propertyAlreadyExists","node","undefined","propertyTreeItem","unshift","clearKbPropertiesFromTree","filter","item","kbManagerExportCss","FILE_ICON","getIconPath","category","colorType","SETTINGS_ICON","GENERAL_REFERENCES_ICON","MENUS_NEW_OBJECT_ICON","TREE_VIEW_ICON","CHECKBOX_CHECKED_VALUE","CSS_BUNDLES","GxIdeKbManagerExport","_GxIdeKbManagerExport_addKbDescriptionEl","set","this","_GxIdeKbManagerExport_componentLocale","_GxIdeKbManagerExport_animateEmptyState","_GxIdeKbManagerExport_exportAllEl","_GxIdeKbManagerExport_fileNameEl","_GxIdeKbManagerExport_kBPropertiesData","_GxIdeKbManagerExport_objectTypesMap","Map","_GxIdeKbManagerExport_objectsSet","Set","_GxIdeKbManagerExport_addKBPropertiesCallbackHandler","async","_e","addKbPropertiesIsChecked","__classPrivateFieldGet","value","__classPrivateFieldSet","addKBPropertiesCallback","length","objectsTreeViewModel","_GxIdeKbManagerExport_addObjectsCallbackHandler","exportAllIsChecked","addedObjects","addObjectsCallback","_GxIdeKbManagerExport_updateObjects","call","_GxIdeKbManagerExport_addReferencesCallbackHandler","addReferencesCallback","checkedObjectsIds","_GxIdeKbManagerExport_cancelCallbackHandler","cancelled","cancelCallback","exportingIsInProcess","_GxIdeKbManagerExport_clearButtonHandler","clear","_GxIdeKbManagerExport_evaluateContentToDisplay","hasObjects","h","isAnimated","stateTitle","main","noObjectsToDisplay","key","class","onClick","beginByADdingSomeObjects","stateIconSrc","exportAllMessage","checkbox","checked","dragDisabled","dropDisabled","_GxIdeKbManagerExport_evaluateTreeViewFilters","filterType","model","showLines","toggleCheckboxes","sortItemsCallback","_GxIdeKbManagerExport_sortTreeItems","onCheckedItemsChange","_GxIdeKbManagerExport_objectsTreeCheckedItemsChangedHandler","_GxIdeKbManagerExport_evaluateObjects","_GxIdeKbManagerExport_exportAllChangedHandler","_event","_GxIdeKbManagerExport_exportCallbackHandler","fileName","checkedKbPropertiesIds","checkedPropertiesIds","checkedObjectIds","exportCallback","then","event","allItemsWithCheckbox","detail","values","atLeastOnePropertyItemIsChecked","atLeastOneObjectItemIsChecked","subModel","sort","a","b","localeCompare","_GxIdeKbManagerExport_renderFooter","referencesButtonEnabled","clearButtonEnabled","disabled","part","footer","clearButton","src","addReferencesButton","addButton","objectsDataArray","newObjectsTreeModel","objectsTreeViewModelChanged","newObjectsTreeViewModel","objectTypesChanged","newObjectTypesArray","_GxIdeKbManagerExport_instances","_GxIdeKbManagerExport_objectsTypesArrayToMap","componentWillLoad","Locale","getComponentStrings","el","render","exportButtonEnabled","cancelButtonEnabled","Host","htmlFor","header","exportFileName","autoFocus","ref","exportButton","cancelButton","optionsButton","title","optionsCallback","addKnowledgeBaseDescription","checkedValue","onInput","exportAll","loader","cancelLabel","loaderTitle","show","objectTypesArray"],"sources":["src/components/kb-manager-export/helpers.ts","src/components/kb-manager-export/kb-manager-export.scss?tag=gx-ide-kb-manager-export&encapsulation=shadow","src/components/kb-manager-export/kb-manager-export.tsx"],"sourcesContent":["// /* Tree View */\nimport {\n TreeViewItemModel,\n TreeViewModel\n} from \"@genexus/chameleon-controls-library\";\nimport { ObjectData, KBPropertyData, KBPropertyType } from \"./types\";\nimport { ObjectType } from \"../../common/types\";\nexport const KB_PROPERTY = \"property\";\nexport const KB_OBJECT = \"object\";\n\nconst getPropertyIcon = (\n typeId: string,\n kbPropertiesTypes: KBPropertyType[]\n): string =>\n // The object icon has to be retrieved from the ObjectTypes array, by\n // matching the ObjectData typeId with the ObjectType id\n kbPropertiesTypes.find(propertyType => propertyType.id === typeId).icon;\n\nconst convertObjectTypeToTreeItem = (\n objectType: ObjectType\n): TreeViewItemModel => ({\n caption: objectType.name,\n id: objectType.id,\n startImgSrc: objectType.icon,\n leaf: false,\n parts: \"object-type tree-view-item\",\n expanded: true,\n items: []\n});\n\nconst convertObjectToTreeItem = (\n object: ObjectData,\n objectTypes: Map<string, ObjectType>\n): TreeViewItemModel => ({\n caption: object.name,\n id: object.id,\n startImgSrc: objectTypes.get(object.typeId).icon,\n parts: \"object tree-view-item\",\n metadata: KB_OBJECT,\n leaf: true\n});\n\nconst convertPropertyToTreeItem = (\n property: KBPropertyData,\n kbPropertiesTypes: KBPropertyType[]\n): TreeViewItemModel => ({\n caption: property.name,\n id: property.id,\n startImgSrc: getPropertyIcon(property.typeId, kbPropertiesTypes),\n parts: \"property tree-view-item\",\n metadata: KB_PROPERTY,\n leaf: true\n});\n\n/**\n * Updates the tree model with the provided objects.\n * Objects may already exist and are placed under their parent node.\n * If the parent node doesn't exist (identified by typeId on ObjectTypes),\n * it is created and added at the bottom.\n *\n * @param {ObjectData[] | undefined} objects - The array of objects to update.\n * @param {Map<string, ObjectType>} objectTypesMap - A map of object types by ID.\n * @param {Set<string>} objectsSet - A set of existing object IDs.\n * @param {TreeViewModel} actualTreeState - The current tree state to be updated.\n * @returns {TreeViewModel} - The updated tree view model.\n */\nexport const updateObjectsTreeModel = (\n objects: ObjectData[] | undefined,\n objectTypesMap: Map<string, ObjectType>,\n objectsSet: Set<string>,\n actualTreeState: TreeViewModel\n): TreeViewModel => {\n if (!objects) {\n return [...actualTreeState];\n }\n\n const updatedTreeData: TreeViewModel = [...actualTreeState];\n objects.forEach(object => {\n // objects that already exists in the actual actualTreeState should not be added.\n\n if (objectsSet.has(object.id)) {\n // object already exists\n return;\n }\n\n const objectTreeItem = convertObjectToTreeItem(object, objectTypesMap);\n\n // TODO: Improve the algorithm efficiency. This check visits potentially all nodes\n // from the TreeViewModel on each iteration. Using a Map to pre-store the TreeView\n // nodes would improve efficiency.\n const objectTypeTreeItemIndex = updatedTreeData.findIndex(\n treeItem => treeItem.id === object.typeId\n );\n\n if (objectTypeTreeItemIndex === -1) {\n // Create and add new object type tree item\n const objectType = objectTypesMap.get(object.typeId);\n if (objectType) {\n const objectTypeTreeItem = convertObjectTypeToTreeItem(objectType);\n objectTypeTreeItem.items.push(objectTreeItem);\n updatedTreeData.push(objectTypeTreeItem);\n }\n } else {\n // objectType exists already. insert object as children of the object type tree item.\n updatedTreeData[objectTypeTreeItemIndex].items.push(objectTreeItem);\n }\n\n objectsSet.add(object.id);\n });\n\n return updatedTreeData;\n};\n\n/**\n * Converts an array of KB properties data into tree item data for a tree view.\n *\n * @param {KBPropertyData[]} properties - The array of KB property data.\n * @param {KBPropertyType[]} kbPropertiesTypes - The array of KB property types.\n * @param {TreeViewModel} actualTreeState - The current state of the tree.\n * @returns {TreeViewModel} - The updated tree view item models.\n */\nexport const convertKbPropertiesDataToTreeItemData = (\n properties: KBPropertyData[],\n kbPropertiesTypes: KBPropertyType[],\n actualTreeState: TreeViewModel\n): TreeViewModel => {\n if (!properties) {\n return [...actualTreeState];\n }\n\n const updatedTreeData: TreeViewModel = [...actualTreeState];\n properties.forEach(property => {\n // properties have no parent node, and they should be added at the beginning of the tree\n const propertyAlreadyExists =\n updatedTreeData.find(node => node.id === property.id) !== undefined;\n if (propertyAlreadyExists) {\n return;\n }\n const propertyTreeItem = convertPropertyToTreeItem(\n property,\n kbPropertiesTypes\n );\n updatedTreeData.unshift(propertyTreeItem);\n });\n return updatedTreeData;\n};\n\n/**\n * Removes properties from the tree model.\n *\n * @param {TreeViewModel} actualTreeState - The current state of the tree,\n * containing various tree view items.\n * @returns {TreeViewModel} - A new array of tree view items that excludes\n * any items with metadata of type `KB_PROPERTY`.\n */\nexport const clearKbPropertiesFromTree = (\n actualTreeState: TreeViewModel\n): TreeViewModel =>\n actualTreeState.filter(item => item.metadata !== KB_PROPERTY);\n","section {\n display: grid;\n block-size: 100%;\n grid-template-rows: max-content 1fr max-content;\n}\n\n.header__field-group {\n grid-template:\n \"export-file-name buttons-container\" max-content\n \"checkboxes checkboxes\" max-content\n / 1fr max-content;\n}\n.export-file-name {\n grid-area: export-file-name;\n}\n.header__buttons-container {\n grid-area: buttons-container;\n}\n.header__checkboxes {\n grid-area: checkboxes;\n grid-template-columns: max-content 1fr;\n}\n\n.main {\n position: relative;\n padding-block: var(--content-block-spacing);\n}\n","import { Component, Host, h, Prop, Element, State, Watch } from \"@stencil/core\";\n\nimport { ChCheckboxCustomEvent } from \"@genexus/chameleon-controls-library\";\nimport {\n TreeViewItemModelExtended,\n TreeViewModel\n} from \"@genexus/chameleon-controls-library\";\nimport { MercuryBundles } from \"@genexus/mercury\";\n\nimport { Locale } from \"../../common/locale\";\nimport {\n updateObjectsTreeModel,\n convertKbPropertiesDataToTreeItemData,\n clearKbPropertiesFromTree\n} from \"./helpers\";\nimport { ObjectType } from \"../../common/types\";\n\nimport { KB_PROPERTY, KB_OBJECT } from \"./helpers\";\nimport {\n KBPropertiesCallback,\n KBPropertyData,\n KBPropertyType,\n ObjectData,\n ExportFileDirectoryCallback,\n OptionsCallback,\n AddObjectsCallback,\n ExportCallback,\n AddReferencesCallback,\n CancelCallback\n} from \"./types\";\n\nimport { getIconPath } from \"@genexus/mercury\";\n\nconst FILE_ICON = getIconPath({\n category: \"gemini-tools\",\n name: \"file\",\n colorType: \"on-elevation\"\n});\nconst SETTINGS_ICON = getIconPath({\n category: \"gemini-tools\",\n name: \"settings\",\n colorType: \"primary\"\n});\nconst GENERAL_REFERENCES_ICON = getIconPath({\n category: \"window-tools\",\n name: \"references\",\n colorType: \"neutral\"\n});\nconst MENUS_NEW_OBJECT_ICON = getIconPath({\n category: \"menus\",\n name: \"new-object\",\n colorType: \"on-primary\"\n});\nconst TREE_VIEW_ICON = getIconPath({\n category: \"controls\",\n name: \"treeview\"\n});\nconst CHECKBOX_CHECKED_VALUE = \"true\";\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 \"utils/form\",\n \"utils/layout\",\n \"utils/spacing\",\n \"utils/typography\"\n];\n@Component({\n tag: \"gx-ide-kb-manager-export\",\n styleUrl: \"kb-manager-export.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/kb-manager-export\"]\n})\nexport class GxIdeKbManagerExport {\n #addKbDescriptionEl!: HTMLChCheckboxElement;\n #componentLocale: any;\n #animateEmptyState: boolean = false;\n #exportAllEl!: HTMLChCheckboxElement;\n #fileNameEl!: HTMLChEditElement;\n #kBPropertiesData!: KBPropertyData[];\n /**\n * Stores the object types information (name, and icon)\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #objectTypesMap: Map<string, ObjectType> = new Map();\n /**\n * Stores the object's id that have been added.\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #objectsSet: Set<string> = new Set();\n\n @Element() el: HTMLGxIdeKbManagerExportElement;\n\n @State() addKbPropertiesIsChecked = false;\n @State() atLeastOnePropertyItemIsChecked = false;\n @State() atLeastOneObjectItemIsChecked = false;\n @State() checkedObjectsIds: string[] = [];\n @State() checkedPropertiesIds: string[] = [];\n @State() exportAllIsChecked = false;\n @State() exportingIsInProcess = false;\n @State() hasObjects: boolean;\n @State() objectsTreeViewModel: TreeViewModel = [];\n @Watch(\"objectsTreeViewModel\")\n objectsTreeViewModelChanged(newObjectsTreeViewModel: TreeViewModel) {\n this.hasObjects =\n newObjectsTreeViewModel && newObjectsTreeViewModel.length > 0;\n if (!this.hasObjects) {\n this.atLeastOnePropertyItemIsChecked = false;\n this.atLeastOneObjectItemIsChecked = false;\n }\n }\n\n /**\n * Callback invoked when the user wants to include KB properties.\n */\n @Prop() readonly addKBPropertiesCallback!: KBPropertiesCallback;\n\n /**\n * Callback invoked when the user wants to add objects.\n */\n @Prop() readonly addObjectsCallback!: AddObjectsCallback;\n\n /**\n *Callback invoked when the user wants to add all the references for the selected objects.\n *@param itemIds:string[] The selected item ids\n *@returns : Returns an object with the items and its references\n */\n @Prop() readonly addReferencesCallback!: AddReferencesCallback;\n\n /**\n * Callback invoked when the user wants to cancel the export process.\n * @returns It returns a boolean indicating whether the process could be canceled or not.\n */\n @Prop() readonly cancelCallback!: CancelCallback;\n\n /**\n *Callback invoked when the user wants to initiate the export process.\n *@param fileName:string\n *@param itemIds:string[] The selected item ids\n *@returns : It returns a boolean indicating whether the process was successful\n */\n @Prop() readonly exportCallback!: ExportCallback;\n\n /**\n * Callback invoked when the user wants to access the export options.\n */\n @Prop() readonly exportFileDirectoryCallback!: ExportFileDirectoryCallback;\n\n /**\n * It allows defining the default Export File Name\n */\n @Prop() readonly fileName: string;\n\n /**\n * Array with the possible types of KB properties\n */\n @Prop() readonly kbPropertiesTypes: KBPropertyType[];\n\n /**\n * If true, it will display a loader when needed.\n */\n @Prop() readonly loader = false;\n\n /**\n * Array of possible object types\n */\n @Prop() readonly objectTypes: ObjectType[];\n @Watch(\"objectTypes\")\n objectTypesChanged(newObjectTypesArray: ObjectType[]) {\n this.#objectsTypesArrayToMap(newObjectTypesArray);\n }\n\n /**\n * Callback invoked when the user wants to access the export options.\n */\n @Prop() readonly optionsCallback: OptionsCallback;\n\n async componentWillLoad() {\n this.#componentLocale = await Locale.getComponentStrings(this.el);\n this.#evaluateObjects();\n this.#objectsTypesArrayToMap(this.objectTypes);\n }\n\n #addKBPropertiesCallbackHandler = async (\n _e: ChCheckboxCustomEvent<any> | InputEvent\n ) => {\n this.addKbPropertiesIsChecked =\n this.#addKbDescriptionEl.value === CHECKBOX_CHECKED_VALUE;\n if (this.addKbPropertiesIsChecked) {\n this.#kBPropertiesData = await this.addKBPropertiesCallback();\n if (this.#kBPropertiesData.length) {\n this.objectsTreeViewModel = convertKbPropertiesDataToTreeItemData(\n this.#kBPropertiesData,\n this.kbPropertiesTypes,\n this.objectsTreeViewModel\n );\n }\n } else {\n // previous properties (if any) should be removed\n this.objectsTreeViewModel = clearKbPropertiesFromTree(\n this.objectsTreeViewModel\n );\n }\n };\n\n #addObjectsCallbackHandler = async () => {\n this.#exportAllEl.value = undefined;\n this.exportAllIsChecked = false;\n const addedObjects = await this.addObjectsCallback();\n this.#updateObjects(addedObjects);\n };\n\n #addReferencesCallbackHandler = async () => {\n const objects: ObjectData[] = await this.addReferencesCallback(\n this.checkedObjectsIds\n );\n this.#updateObjects(objects);\n };\n\n #cancelCallbackHandler = async () => {\n const cancelled = await this.cancelCallback();\n if (cancelled) {\n this.exportingIsInProcess = false;\n }\n };\n\n #clearButtonHandler = () => {\n this.objectsTreeViewModel = [];\n this.#objectsSet.clear();\n this.#addKbDescriptionEl.value = undefined;\n this.#exportAllEl.value = undefined;\n };\n\n #evaluateContentToDisplay = () => {\n // Nothing to display on the tree-view\n if (!this.hasObjects && !this.exportAllIsChecked) {\n return (\n <gx-ide-empty-state\n isAnimated={this.#animateEmptyState}\n stateTitle={this.#componentLocale.main.noObjectsToDisplay}\n key=\"no-objects-empty-state\"\n >\n <button\n class=\"button-primary\"\n onClick={this.#addObjectsCallbackHandler}\n >\n {this.#componentLocale.main.beginByADdingSomeObjects}\n </button>\n </gx-ide-empty-state>\n );\n } else {\n this.#animateEmptyState = true; // improve performance if is first render\n }\n\n if (this.exportAllIsChecked) {\n return (\n <gx-ide-empty-state\n isAnimated={this.#animateEmptyState}\n stateIconSrc={TREE_VIEW_ICON}\n stateTitle={this.#componentLocale.main.exportAllMessage}\n key=\"exporting-all-empty-state\"\n ></gx-ide-empty-state>\n );\n } else {\n this.#animateEmptyState = true; // improve performance if is first render\n }\n\n return (\n <ch-tree-view-render\n class=\"tree-view\"\n checkbox\n checked\n dragDisabled\n dropDisabled\n filter={this.#evaluateTreeViewFilters()}\n filterType={\n this.addKbPropertiesIsChecked && !this.exportAllIsChecked\n ? \"none\"\n : \"metadata\"\n }\n model={this.objectsTreeViewModel}\n showLines=\"last\"\n toggleCheckboxes\n sortItemsCallback={this.#sortTreeItems}\n onCheckedItemsChange={this.#objectsTreeCheckedItemsChangedHandler}\n ></ch-tree-view-render>\n );\n };\n\n #evaluateObjects = () => {\n this.hasObjects =\n this.objectsTreeViewModel && this.objectsTreeViewModel.length > 0;\n };\n\n #evaluateTreeViewFilters = (): string => {\n if (this.addKbPropertiesIsChecked && this.exportAllIsChecked) {\n return KB_PROPERTY; // only show properties\n }\n if (!this.addKbPropertiesIsChecked && !this.exportAllIsChecked) {\n return KB_OBJECT; // only show objects\n }\n return \"none\";\n };\n\n #exportAllChangedHandler = (\n _event: ChCheckboxCustomEvent<any> | InputEvent\n ) => {\n this.exportAllIsChecked =\n this.#exportAllEl.value === CHECKBOX_CHECKED_VALUE;\n };\n\n #exportCallbackHandler = async () => {\n this.exportingIsInProcess = true;\n const fileName: string = this.#fileNameEl.value;\n const checkedKbPropertiesIds = this.addKbPropertiesIsChecked\n ? this.checkedPropertiesIds\n : [];\n const checkedObjectIds = this.exportAllIsChecked\n ? undefined\n : this.checkedObjectsIds;\n this.exportCallback(\n fileName,\n checkedKbPropertiesIds,\n checkedObjectIds\n ).then(() => {\n this.exportingIsInProcess = false;\n });\n // returns Promise<boolean> but no procedure was detailed on the spec.\n };\n\n #objectsTypesArrayToMap(objectTypesArray: ObjectType[]) {\n objectTypesArray.forEach(objectType => {\n this.#objectTypesMap.set(objectType.id, objectType);\n });\n }\n\n #objectsTreeCheckedItemsChangedHandler = (\n event: CustomEvent<Map<string, TreeViewItemModelExtended>>\n ) => {\n // filter 'checked objects' and 'checked properties' ids\n const checkedObjectsIds: string[] = [];\n const checkedPropertiesIds: string[] = [];\n const allItemsWithCheckbox = [...event.detail.values()];\n allItemsWithCheckbox.forEach(node => {\n if (node.item.checked && node.item.metadata === KB_OBJECT) {\n checkedObjectsIds.push(node.item.id);\n } else if (node.item.checked && node.item.metadata === KB_PROPERTY) {\n checkedPropertiesIds.push(node.item.id);\n }\n });\n this.checkedObjectsIds = checkedObjectsIds;\n this.checkedPropertiesIds = checkedPropertiesIds;\n\n this.atLeastOnePropertyItemIsChecked = this.checkedPropertiesIds.length > 0;\n this.atLeastOneObjectItemIsChecked = this.checkedObjectsIds.length > 0;\n };\n\n #sortTreeItems = (subModel: TreeViewModel) => {\n // \"property\" items should be added on top.\n // else sort alphabetically by \"caption\" value.\n return subModel.sort((a, b) => {\n if (a.metadata === \"property\" && b.metadata !== \"property\") {\n return -1;\n }\n if (b.metadata === \"property\" && a.metadata !== \"property\") {\n return 1;\n }\n\n return a.caption.localeCompare(b.caption);\n });\n };\n\n #renderFooter = (): HTMLElement => {\n const referencesButtonEnabled = this.atLeastOneObjectItemIsChecked;\n const clearButtonEnabled = this.objectsTreeViewModel.length > 0;\n return (\n <footer class=\"footer control-footer-with-border control-footer-space-between space-body spacing-body-inline spacing-body-block-end\">\n <button\n class=\"button-tertiary clear-btn\"\n disabled={!clearButtonEnabled}\n part=\"clear-button\"\n onClick={clearButtonEnabled && this.#clearButtonHandler}\n >\n {this.#componentLocale.footer.clearButton}\n </button>\n\n <div class=\"buttons-spacer\">\n <button\n class=\"button-secondary button-icon-and-text\"\n part=\"references-button\"\n disabled={!referencesButtonEnabled}\n onClick={\n referencesButtonEnabled && this.#addReferencesCallbackHandler\n }\n >\n <ch-image\n class=\"icon-sm\"\n disabled={!referencesButtonEnabled}\n src={GENERAL_REFERENCES_ICON}\n ></ch-image>\n {this.#componentLocale.footer.addReferencesButton}\n </button>\n\n <button\n // Add button\n class=\"button-primary button-icon-and-text\"\n disabled={this.exportAllIsChecked}\n part=\"add-button\"\n onClick={\n !this.exportAllIsChecked && this.#addObjectsCallbackHandler\n }\n >\n <ch-image\n class=\"icon-sm\"\n disabled={this.exportAllIsChecked}\n src={MENUS_NEW_OBJECT_ICON}\n ></ch-image>\n {this.#componentLocale.footer.addButton}\n </button>\n </div>\n </footer>\n );\n };\n\n #updateObjects = (objectsDataArray: ObjectData[]) => {\n if (objectsDataArray.length) {\n const newObjectsTreeModel = updateObjectsTreeModel(\n objectsDataArray,\n this.#objectTypesMap,\n this.#objectsSet,\n this.objectsTreeViewModel\n );\n this.objectsTreeViewModel = newObjectsTreeModel;\n }\n };\n\n render(): void {\n const exportButtonEnabled =\n this.atLeastOnePropertyItemIsChecked ||\n this.atLeastOneObjectItemIsChecked ||\n this.exportAllIsChecked;\n\n const cancelButtonEnabled = this.exportingIsInProcess;\n\n return (\n <Host class=\"widget\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n\n <section>\n <header class=\"header control-header-with-border space-body spacing-body-inline spacing-body-block-start\">\n <div class=\"field-group header__field-group\">\n <div class=\"field field-inline export-file-name\">\n <label class=\"label\" htmlFor=\"xpz-file\">\n {this.#componentLocale.header.exportFileName}\n </label>\n <ch-edit\n autoFocus\n id=\"xpz-file\"\n class=\"input\"\n part=\"xpz-file\"\n value={this.fileName}\n startImgSrc={FILE_ICON}\n ref={(el: HTMLChEditElement) =>\n (this.#fileNameEl = el as HTMLChEditElement)\n }\n ></ch-edit>\n </div>\n\n <div class=\"header__buttons-container buttons-spacer\">\n <button\n id=\"export-kb-btn\"\n class=\"button-primary export-btn\"\n part=\"export-btn\"\n disabled={!exportButtonEnabled}\n onClick={exportButtonEnabled && this.#exportCallbackHandler}\n >\n {this.#componentLocale.header.exportButton}\n </button>\n <button\n id=\"cancel-kb-export-btn\"\n class=\"button-secondary cancel-btn\"\n part=\"cancel-button\"\n disabled={!cancelButtonEnabled}\n onClick={cancelButtonEnabled && this.#cancelCallbackHandler}\n >\n {this.#componentLocale.header.cancelButton}\n </button>\n\n <button\n aria-label={this.#componentLocale.header.optionsButton}\n title={this.#componentLocale.header.optionsButton}\n class=\"button-tertiary button-icon-only options-btn\"\n part=\"select-kb-btn\"\n onClick={this.optionsCallback}\n >\n <ch-image class=\"icon-md\" src={SETTINGS_ICON}></ch-image>\n </button>\n </div>\n\n <div class=\"header__checkboxes field-group\">\n <ch-checkbox\n class=\"checkbox add-kb-description\"\n part=\"add-kb-description\"\n caption={\n this.#componentLocale.main.addKnowledgeBaseDescription\n }\n checkedValue={CHECKBOX_CHECKED_VALUE}\n onInput={this.#addKBPropertiesCallbackHandler}\n ref={(el: HTMLChCheckboxElement) =>\n (this.#addKbDescriptionEl = el as HTMLChCheckboxElement)\n }\n ></ch-checkbox>\n\n <ch-checkbox\n class=\"checkbox export-all\"\n part=\"export-all-checkbox\"\n checkedValue={CHECKBOX_CHECKED_VALUE}\n caption={this.#componentLocale.main.exportAll}\n onInput={this.#exportAllChangedHandler}\n ref={(el: HTMLChCheckboxElement) =>\n (this.#exportAllEl = el as HTMLChCheckboxElement)\n }\n ></ch-checkbox>\n </div>\n </div>\n </header>\n\n <div class=\"main spacing-body-inline\">\n {this.#evaluateContentToDisplay()}\n {this.loader && this.exportingIsInProcess && (\n <gx-ide-loader\n cancelLabel={this.#componentLocale.loader.cancelLabel}\n loaderTitle={this.#componentLocale.loader.title}\n cancelCallback={this.#cancelCallbackHandler}\n show\n class=\"loader\"\n ></gx-ide-loader>\n )}\n </div>\n\n {this.#renderFooter()}\n </section>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { r as e, g as t, h as i, H as n, a as s } from "./p-25a9f1d7.js";
2
2
 
3
- import { L as o } from "./p-311eedf3.js";
3
+ import { L as o } from "./p-857866f8.js";
4
4
 
5
5
  const r = ":host{--spacing-body-block-start:var(--mer-spacing--lg);--spacing-body-block-end:var(--mer-spacing--lg);--spacing-body-inline-start:var(--mer-spacing--md);--spacing-body-inline-end:var(--mer-spacing--md);display:grid;block-size:100%;overflow:auto;grid-template-rows:1fr max-content;background-color:var(--elevation-background-color, var(--mer-surface));color:var(--mer-text__on-elevation);text-align:center}.section{display:contents}.main{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px}.version__container{display:flex;justify-content:center;flex-direction:column;gap:var(--mer-spacing--xs)}.logo__container{display:flex;flex-direction:column;gap:var(--mer-spacing--sm);align-items:center;margin:unset}.logo__img{inline-size:28px;block-size:28px}.link-underlined{text-decoration:underline;color:var(--mer-text__on-elevation)}.link-underlined:hover{color:var(--mer-text__highlighted)}.link-underlined:active{color:var(--mer-text__elevation)}.links-container{display:flex;gap:var(--mer-spacing--xs)}.copyrights{color:var(--mer-text__complementary)}";
6
6
 
@@ -93,4 +93,4 @@ l = new WeakMap, d = new WeakMap;
93
93
  h.style = r;
94
94
 
95
95
  export { h as gx_ide_about };
96
- //# sourceMappingURL=p-0550fd5f.entry.js.map
96
+ //# sourceMappingURL=p-f52bcdac.entry.js.map
@@ -1,6 +1,6 @@
1
1
  import { r as t, c as e, g as r, h as a, H as o, a as i } from "./p-25a9f1d7.js";
2
2
 
3
- import { L as s } from "./p-311eedf3.js";
3
+ import { L as s } from "./p-857866f8.js";
4
4
 
5
5
  import { c as l } from "./p-13738332.js";
6
6
 
@@ -76,7 +76,7 @@ const g = class {
76
76
  }, `${t.modifiedOn.toISOString().slice(0, 10)}`)))));
77
77
  this.getObjectsHandler = () => {
78
78
  this.addCallback().then((t => {
79
- if ((t === null || t === void 0 ? void 0 : t.length) > 0) {
79
+ if (t?.length > 0) {
80
80
  this.selection = [ ...this.selection, ...t ];
81
81
  this.selectedObjectsIds = [];
82
82
  }
@@ -198,4 +198,4 @@ const g = class {
198
198
  g.style = n;
199
199
 
200
200
  export { g as gx_ide_team_dev_update_partial_selection };
201
- //# sourceMappingURL=p-b1851e6b.entry.js.map
201
+ //# sourceMappingURL=p-f5879a41.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["updatePartialSelectionCss","CSS_BUNDLES","GxIdeTeamDevUpdatePartialSelection","this","renderedFirstTime","shortcutsSrc","getAssetPath","renderObjects","h","class","ref","el","chGridEl","part","columnName","settingable","sortable","size","config","tabularGrid","colSize","minContent","_componentLocale","tableHead","name","auto","type","description","modifiedOn","selection","map","obj","rowid","id","key","src","typeIcon","toISOString","slice","getObjectsHandler","addCallback","then","items","length","selectedObjectsIds","removeSelectedObjectsHandler","filter","item","includes","confirmHandler","confirmCallback","allRowsIds","forEach","row","push","cancelHandler","cancelCallback","removeAllHandler","listenChanges","addEventListener","ev","detail","rowsId","componentWillLoad","Locale","getComponentStrings","componentDidLoadEvent","emit","componentDidLoad","componentDidRender","componentDidRenderFirstTime","componentName","validate","isValid","render","Host","model","noContentPadding","noContentGap","containerTitle","displayTitle","slimmerFooter","gxIdeContainer","icon","onClick","btnAddObject","disabled","btnRemoveSelectedObjects","slot","footer","btnRemoveAll","btnCancel","btnConfirm"],"sources":["src/components/team-dev/update-partial-selection/update-partial-selection.scss?tag=gx-ide-team-dev-update-partial-selection&encapsulation=shadow","src/components/team-dev/update-partial-selection/update-partial-selection.tsx"],"sourcesContent":["@import \"../../../global/gx-ide-common.scss\";\n@import \"../../../global/gx-ide-mixins.scss\";\n\n:host {\n display: block;\n}\n.top-actions {\n display: flex;\n gap: var(--gx-ide-grid-column-gap);\n padding: var(--mer-spacing--xs) var(--gx-ide-container__padding);\n flex-direction: row-reverse;\n border-bottom: 1px solid var(--gx-ide-container-border-color);\n}\n\n.tabular-grid {\n block-size: 100%;\n}\n","/* STENCIL IMPORTS */\nimport {\n Component,\n Host,\n h,\n Prop,\n Element,\n Event,\n EventEmitter,\n State,\n Method,\n getAssetPath\n} from \"@stencil/core\";\n/* OTHER LIBRARIES IMPORTS */\nimport { MercuryBundles } from \"@genexus/mercury\";\n/* CUSTOM IMPORTS */\nimport { Locale } from \"../../../common/locale\";\nimport { config } from \"../../../common/config\";\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@Component({\n tag: \"gx-ide-team-dev-update-partial-selection\",\n styleUrl: \"update-partial-selection.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/team-dev-update-partial-selection\"]\n})\nexport class GxIdeTeamDevUpdatePartialSelection {\n // 1.OWN PROPERTIES //\n\n /**\n * The component hard-coded strings translations.\n */\n private _componentLocale: any;\n private renderedFirstTime = false;\n private shortcutsSrc = getAssetPath(\n `./gx-ide-assets/team-dev-update-partial-selection/shortcuts.json`\n );\n\n // 2. REFERENCE TO ELEMENTS //\n\n @Element() el: HTMLGxIdeTeamDevUpdatePartialSelectionElement;\n\n /* References needed to collect data */\n private chGridEl!: HTMLElement;\n\n // 3.STATE() VARIABLES //\n\n /**\n * The selected objects in the table of objects\n */\n @State() selectedObjectsIds: string[] = [];\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 * This is a function provided by the developer that return a list of new objects to populate the table of objects.\n */\n @Prop() readonly addCallback!: AddCallback;\n\n /**\n * This is a function provided by the developer for execute when cancel button is pressed.\n */\n @Prop() readonly cancelCallback!: CancelCallback;\n\n /**\n * This is a function provided by the developer and is invoked when the action confirm is executed passing the selected objects of the grid\n */\n @Prop() readonly confirmCallback!: ConfirmCallback;\n\n /**\n * The categories render in the filter category selector\n */\n @Prop({ mutable: true }) selection: ObjectData[] = [];\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 }\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 // 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 // 9.LOCAL METHODS //\n\n private renderObjects = (): Element => {\n return (\n <ch-tabular-grid\n class=\"tabular-grid\"\n row-selection-mode=\"multiple\"\n ref={(el: HTMLElement) => (this.chGridEl = el)}\n part=\"ch-grid-objects\"\n >\n <ch-tabular-grid-columnset class=\"tabular-grid-column-set\">\n <ch-tabular-grid-column\n columnName=\"\"\n settingable={false}\n sortable={false}\n size={config.tabularGrid.colSize.minContent}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.name}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.type}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.description}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.modifiedOn}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n </ch-tabular-grid-columnset>\n {this.selection.map((obj: ObjectData) => (\n <ch-tabular-grid-row\n rowid={obj.id}\n key={obj.id}\n class=\"tabular-grid-row\"\n >\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n <ch-image src={obj.typeIcon} class=\"icon-md\"></ch-image>\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {obj.name}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {obj.type}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {obj.description}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {`${obj.modifiedOn.toISOString().slice(0, 10)}`}\n </ch-tabular-grid-cell>\n </ch-tabular-grid-row>\n ))}\n </ch-tabular-grid>\n );\n };\n\n private getObjectsHandler = (): void => {\n this.addCallback().then((items: ObjectData[]) => {\n if (items?.length > 0) {\n this.selection = [...this.selection, ...items];\n this.selectedObjectsIds = [];\n }\n });\n };\n\n private removeSelectedObjectsHandler = (): void => {\n this.selection = this.selection.filter(\n item => !this.selectedObjectsIds.includes(item.id)\n );\n this.selectedObjectsIds = [];\n };\n\n private confirmHandler = (): void => {\n if (this.confirmCallback) {\n const allRowsIds: string[] = [];\n this.selection.forEach(row => {\n allRowsIds.push(row.id);\n });\n this.confirmCallback(allRowsIds);\n }\n };\n\n private cancelHandler = (): void => {\n this.cancelCallback();\n };\n\n private removeAllHandler = (): void => {\n this.selection = [];\n };\n\n private listenChanges = (): void => {\n // for grid selection\n this.chGridEl.addEventListener(\"selectionChanged\", (ev: any): void => {\n this.selectedObjectsIds = ev.detail.rowsId;\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=\"top-actions\">\n {/* add button*/}\n <gxg-button\n id=\"button-add\"\n type=\"outlined\"\n icon=\"gemini-tools/add\"\n onClick={this.getObjectsHandler}\n part=\"add\"\n >\n {this._componentLocale.btnAddObject}\n </gxg-button>\n\n {/* remove button*/}\n <gxg-button\n id=\"button-remove\"\n type=\"secondary-text-only\"\n onClick={this.removeSelectedObjectsHandler}\n part=\"remove\"\n disabled={!(this.selectedObjectsIds.length > 0)}\n >\n {this._componentLocale.btnRemoveSelectedObjects}\n </gxg-button>\n </div>\n\n {this.renderObjects()}\n\n {/* remove all button*/}\n <gxg-button\n id=\"button-clear\"\n onClick={this.removeAllHandler}\n disabled={!(this.selection.length > 0)}\n part=\"clear\"\n slot=\"footer-start\"\n type=\"secondary-text-only\"\n >\n {this._componentLocale.footer.btnRemoveAll}\n </gxg-button>\n\n {/* cancel button*/}\n <gxg-button\n id=\"button-cancel\"\n type=\"outlined\"\n onClick={this.cancelHandler}\n part=\"cancel\"\n slot=\"footer-end\"\n >\n {this._componentLocale.footer.btnCancel}\n </gxg-button>\n\n {/* confirm button*/}\n <gxg-button\n id=\"button-ok\"\n type=\"primary-text-only\"\n onClick={this.confirmHandler}\n part=\"confirm\"\n slot=\"footer-end\"\n >\n {this._componentLocale.footer.btnConfirm}\n </gxg-button>\n </gx-ide-container>\n </div>\n <gxg-shortcuts src={this.shortcutsSrc}></gxg-shortcuts>\n </Host>\n );\n }\n}\n\nexport type AddCallback = () => Promise<ObjectData[]>;\nexport type CancelCallback = () => Promise<void>;\nexport type ConfirmCallback = (ids: string[]) => Promise<void>;\n\nexport interface ObjectData {\n id: string;\n typeIcon: string;\n name: string;\n type: string;\n description: string;\n modifiedOn: Date;\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["updatePartialSelectionCss","CSS_BUNDLES","GxIdeTeamDevUpdatePartialSelection","this","renderedFirstTime","shortcutsSrc","getAssetPath","renderObjects","h","class","ref","el","chGridEl","part","columnName","settingable","sortable","size","config","tabularGrid","colSize","minContent","_componentLocale","tableHead","name","auto","type","description","modifiedOn","selection","map","obj","rowid","id","key","src","typeIcon","toISOString","slice","getObjectsHandler","addCallback","then","items","length","selectedObjectsIds","removeSelectedObjectsHandler","filter","item","includes","confirmHandler","confirmCallback","allRowsIds","forEach","row","push","cancelHandler","cancelCallback","removeAllHandler","listenChanges","addEventListener","ev","detail","rowsId","componentWillLoad","Locale","getComponentStrings","componentDidLoadEvent","emit","componentDidLoad","componentDidRender","componentDidRenderFirstTime","componentName","validate","isValid","render","Host","model","noContentPadding","noContentGap","containerTitle","displayTitle","slimmerFooter","gxIdeContainer","icon","onClick","btnAddObject","disabled","btnRemoveSelectedObjects","slot","footer","btnRemoveAll","btnCancel","btnConfirm"],"sources":["src/components/team-dev/update-partial-selection/update-partial-selection.scss?tag=gx-ide-team-dev-update-partial-selection&encapsulation=shadow","src/components/team-dev/update-partial-selection/update-partial-selection.tsx"],"sourcesContent":["@import \"../../../global/gx-ide-common.scss\";\n@import \"../../../global/gx-ide-mixins.scss\";\n\n:host {\n display: block;\n}\n.top-actions {\n display: flex;\n gap: var(--gx-ide-grid-column-gap);\n padding: var(--mer-spacing--xs) var(--gx-ide-container__padding);\n flex-direction: row-reverse;\n border-bottom: 1px solid var(--gx-ide-container-border-color);\n}\n\n.tabular-grid {\n block-size: 100%;\n}\n","/* STENCIL IMPORTS */\nimport {\n Component,\n Host,\n h,\n Prop,\n Element,\n Event,\n EventEmitter,\n State,\n Method,\n getAssetPath\n} from \"@stencil/core\";\n/* OTHER LIBRARIES IMPORTS */\nimport { MercuryBundles } from \"@genexus/mercury\";\n/* CUSTOM IMPORTS */\nimport { Locale } from \"../../../common/locale\";\nimport { config } from \"../../../common/config\";\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@Component({\n tag: \"gx-ide-team-dev-update-partial-selection\",\n styleUrl: \"update-partial-selection.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/team-dev-update-partial-selection\"]\n})\nexport class GxIdeTeamDevUpdatePartialSelection {\n // 1.OWN PROPERTIES //\n\n /**\n * The component hard-coded strings translations.\n */\n private _componentLocale: any;\n private renderedFirstTime = false;\n private shortcutsSrc = getAssetPath(\n `./gx-ide-assets/team-dev-update-partial-selection/shortcuts.json`\n );\n\n // 2. REFERENCE TO ELEMENTS //\n\n @Element() el: HTMLGxIdeTeamDevUpdatePartialSelectionElement;\n\n /* References needed to collect data */\n private chGridEl!: HTMLElement;\n\n // 3.STATE() VARIABLES //\n\n /**\n * The selected objects in the table of objects\n */\n @State() selectedObjectsIds: string[] = [];\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 * This is a function provided by the developer that return a list of new objects to populate the table of objects.\n */\n @Prop() readonly addCallback!: AddCallback;\n\n /**\n * This is a function provided by the developer for execute when cancel button is pressed.\n */\n @Prop() readonly cancelCallback!: CancelCallback;\n\n /**\n * This is a function provided by the developer and is invoked when the action confirm is executed passing the selected objects of the grid\n */\n @Prop() readonly confirmCallback!: ConfirmCallback;\n\n /**\n * The categories render in the filter category selector\n */\n @Prop({ mutable: true }) selection: ObjectData[] = [];\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 }\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 // 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 // 9.LOCAL METHODS //\n\n private renderObjects = (): Element => {\n return (\n <ch-tabular-grid\n class=\"tabular-grid\"\n row-selection-mode=\"multiple\"\n ref={(el: HTMLElement) => (this.chGridEl = el)}\n part=\"ch-grid-objects\"\n >\n <ch-tabular-grid-columnset class=\"tabular-grid-column-set\">\n <ch-tabular-grid-column\n columnName=\"\"\n settingable={false}\n sortable={false}\n size={config.tabularGrid.colSize.minContent}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.name}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.type}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.description}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n <ch-tabular-grid-column\n columnName={this._componentLocale.tableHead.modifiedOn}\n settingable={false}\n size={config.tabularGrid.colSize.auto}\n class=\"tabular-grid-column\"\n ></ch-tabular-grid-column>\n </ch-tabular-grid-columnset>\n {this.selection.map((obj: ObjectData) => (\n <ch-tabular-grid-row\n rowid={obj.id}\n key={obj.id}\n class=\"tabular-grid-row\"\n >\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n <ch-image src={obj.typeIcon} class=\"icon-md\"></ch-image>\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {obj.name}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {obj.type}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {obj.description}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {`${obj.modifiedOn.toISOString().slice(0, 10)}`}\n </ch-tabular-grid-cell>\n </ch-tabular-grid-row>\n ))}\n </ch-tabular-grid>\n );\n };\n\n private getObjectsHandler = (): void => {\n this.addCallback().then((items: ObjectData[]) => {\n if (items?.length > 0) {\n this.selection = [...this.selection, ...items];\n this.selectedObjectsIds = [];\n }\n });\n };\n\n private removeSelectedObjectsHandler = (): void => {\n this.selection = this.selection.filter(\n item => !this.selectedObjectsIds.includes(item.id)\n );\n this.selectedObjectsIds = [];\n };\n\n private confirmHandler = (): void => {\n if (this.confirmCallback) {\n const allRowsIds: string[] = [];\n this.selection.forEach(row => {\n allRowsIds.push(row.id);\n });\n this.confirmCallback(allRowsIds);\n }\n };\n\n private cancelHandler = (): void => {\n this.cancelCallback();\n };\n\n private removeAllHandler = (): void => {\n this.selection = [];\n };\n\n private listenChanges = (): void => {\n // for grid selection\n this.chGridEl.addEventListener(\"selectionChanged\", (ev: any): void => {\n this.selectedObjectsIds = ev.detail.rowsId;\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=\"top-actions\">\n {/* add button*/}\n <gxg-button\n id=\"button-add\"\n type=\"outlined\"\n icon=\"gemini-tools/add\"\n onClick={this.getObjectsHandler}\n part=\"add\"\n >\n {this._componentLocale.btnAddObject}\n </gxg-button>\n\n {/* remove button*/}\n <gxg-button\n id=\"button-remove\"\n type=\"secondary-text-only\"\n onClick={this.removeSelectedObjectsHandler}\n part=\"remove\"\n disabled={!(this.selectedObjectsIds.length > 0)}\n >\n {this._componentLocale.btnRemoveSelectedObjects}\n </gxg-button>\n </div>\n\n {this.renderObjects()}\n\n {/* remove all button*/}\n <gxg-button\n id=\"button-clear\"\n onClick={this.removeAllHandler}\n disabled={!(this.selection.length > 0)}\n part=\"clear\"\n slot=\"footer-start\"\n type=\"secondary-text-only\"\n >\n {this._componentLocale.footer.btnRemoveAll}\n </gxg-button>\n\n {/* cancel button*/}\n <gxg-button\n id=\"button-cancel\"\n type=\"outlined\"\n onClick={this.cancelHandler}\n part=\"cancel\"\n slot=\"footer-end\"\n >\n {this._componentLocale.footer.btnCancel}\n </gxg-button>\n\n {/* confirm button*/}\n <gxg-button\n id=\"button-ok\"\n type=\"primary-text-only\"\n onClick={this.confirmHandler}\n part=\"confirm\"\n slot=\"footer-end\"\n >\n {this._componentLocale.footer.btnConfirm}\n </gxg-button>\n </gx-ide-container>\n </div>\n <gxg-shortcuts src={this.shortcutsSrc}></gxg-shortcuts>\n </Host>\n );\n }\n}\n\nexport type AddCallback = () => Promise<ObjectData[]>;\nexport type CancelCallback = () => Promise<void>;\nexport type ConfirmCallback = (ids: string[]) => Promise<void>;\n\nexport interface ObjectData {\n id: string;\n typeIcon: string;\n name: string;\n type: string;\n description: string;\n modifiedOn: Date;\n}\n"],"mappings":"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"}
@@ -1,10 +1,8 @@
1
1
  import { g as e, r as i, h as t, H as s, a } from "./p-25a9f1d7.js";
2
2
 
3
- import { g as r } from "./p-6e4208d8.js";
3
+ import { g as r } from "./p-ede7bd20.js";
4
4
 
5
- import "./p-5ac47c69.js";
6
-
7
- import { L as o } from "./p-311eedf3.js";
5
+ import { L as o } from "./p-857866f8.js";
8
6
 
9
7
  const n = ':host{--slide-header-block-padding:34px;--slide-footer-block:var(--mer-spacing--md) var(--mer-spacing--4xl);--slide-footer-block-last-slide:var(--mer-spacing--md) 42px;--slide-footer-navigation-hide-transition:var(--mer-timing--fast);display:grid;block-size:100%;inline-size:100%;overflow:auto;padding:var(--mer-spacing--lg);box-sizing:border-box;padding:var(--mer-spacing--xl)}.main{display:grid;place-self:center;inline-size:100%;max-inline-size:1100px;background-color:var(--mer-surface__elevation--01);border-radius:17px;overflow:hidden;border:var(--mer-border__width--sm) solid var(--mer-surface__elevation--01);inset-block-start:0;transition:opacity var(--slide-fade-duration);opacity:0;pointer-events:none}.main--border-glow{animation:borderColorCycle 2s infinite}.main--visible{pointer-events:visible;opacity:1}.slide{display:grid;block-size:100%;grid-template-areas:"header header" "slide-wrapper slide-wrapper" "footer footer";grid-template-rows:max-content 1fr max-content}.slide__header{padding-inline:18px;padding-block:24px 27px;display:flex;flex-direction:row-reverse;grid-area:header}.slide__container{display:contents}.slide__wrapper{display:grid;column-gap:var(--mer-spacing--3xl);grid-template-areas:"header header" "illustration copy" "footer footer";grid-template-rows:max-content 1fr max-content;grid-template-columns:1fr 1fr;grid-area:slide-wrapper;transition:var(--slide-fade-duration) opacity;transition:opacity 200ms;padding-inline:48px;opacity:1;z-index:1}.slide__wrapper:not(.active){opacity:0;z-index:0;pointer-events:none}.slide__illustration{position:relative;overflow:hidden;display:grid;grid-area:illustration;place-items:center;inline-size:100%}.slide__illustration-img{object-fit:contain;block-size:100%;inline-size:100%}.slide__copy{grid-area:copy;place-self:center;justify-self:flex-start}.slide__copy-container{display:grid;gap:var(--mer-spacing--md);max-inline-size:524px}.slide__copy-header{display:grid;gap:var(--mer-spacing--md)}.slide__copy-title{font-size:var(--mer-font__size--xl);color:var(--mer-text__on-surface);letter-spacing:0.02em;font-weight:var(--mer-font__weight--semi-bold)}.slide__copy-description{display:grid;gap:var(--mer-spacing--md);font-size:var(--mer-font__size--sm);font-weight:var(--mer-font__weight--light);line-height:var(--mer-line-height--spaced)}.slide__list{display:grid;gap:var(--mer-spacing--md);list-style:none;padding:0;margin:0}.slide__list-item-title{font-weight:var(--mer-font__weight--medium)}.slide__word{transition:var(--mer-timing--regular) opacity;opacity:0}.slide__word--visible{opacity:1}.slide__footer{grid-area:footer;display:grid;padding-block:var(--slide-footer-block);opacity:1}.slide__footer-last-slide{opacity:0;transition:calc(var(--mer-timing--fast) + 200ms) opacity;pointer-events:none;animation:footerPaddingBlockLastSlide var(--mer-timing--regular) ease-out forwards calc(var(--mer-timing--fast) + 200ms)}.slide__footer-wrapper{display:grid;grid-auto-flow:column;grid-auto-columns:max-content;gap:var(--mer-spacing--md);align-items:center;justify-content:center;transition:var(--mer-timing--regular) opacity;opacity:1}.slide__footer-wrapper-hidden{opacity:0}.slide__dots{display:grid;gap:var(--mer-spacing--2xs);list-style:none;padding:0;margin:0;grid-auto-flow:column;grid-auto-columns:max-content;justify-content:center}.slide__dots-inactive{pointer-events:none}.slide__dot{display:grid;padding:var(--mer-spacing--xs);cursor:pointer}.slide__dot::before{content:"";place-self:center;inline-size:var(--mer-spacing--sm);block-size:var(--mer-spacing--sm);border-radius:calc(var(--mer-spacing--sm) / 2);background-color:var(--mer-color__neutral-gray--500)}.slide__dot:hover::before{background-color:var(--mer-icon__on-primary--hover)}.slide__dot.active{cursor:auto}.slide__dot.active::before{background-color:var(--mer-accent__primary);cursor:auto}.slide__dot-inactive{pointer-events:none}.close-icon{transition:all var(--mer-timing--fast)}.close-icon:hover{filter:brightness(1.5)}.start-button{justify-self:start;margin-block-start:25px}@keyframes ellipseFadeInOut{0%{opacity:0.3}100%{opacity:0.7}}@keyframes ellipseRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}@keyframes polygonRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}@keyframes borderColorCycle{0%{border-color:var(--mer-surface__elevation--01)}50%{border-color:var(--mer-color__primary--400)}100%{border-color:var(--mer-surface__elevation--01)}}@keyframes footerPaddingBlockLastSlide{0%{padding-block:var(--slide-footer-block)}100%{padding-block:var(--slide-footer-block-last-slide)}}.fade-out{animation:fadeOut 0.5s forwards 0.3s}';
10
8
 
@@ -148,8 +146,7 @@ const I = class {
148
146
  }));
149
147
  z.set(this, (() => {
150
148
  d(this, h, this.slides.map(((e, i) => {
151
- var s, a;
152
- const r = i === this.slides.length - 1;
149
+ const s = i === this.slides.length - 1;
153
150
  return t("section", {
154
151
  class: "slide__wrapper",
155
152
  ref: e => l(this, f, "f")[i] = e
@@ -174,13 +171,13 @@ const I = class {
174
171
  class: "slide__copy-title"
175
172
  }, e.title)), t("div", {
176
173
  class: "slide__copy-description"
177
- }, (s = e.description) === null || s === void 0 ? void 0 : s.map((i => t("p", null, e.descriptionAsChunks ? l(this, M, "f").call(this, i) : i))), ((a = e.listItems) === null || a === void 0 ? void 0 : a.length) && t("ul", {
174
+ }, e.description?.map((i => t("p", null, e.descriptionAsChunks ? l(this, M, "f").call(this, i) : i))), e.listItems?.length && t("ul", {
178
175
  class: "slide__list"
179
176
  }, e.listItems.map((e => t("li", {
180
177
  class: "slide__list-item"
181
178
  }, t("strong", {
182
179
  class: "slide__list-item-title"
183
- }, e.title), " ", e.description))))), r && t("button", {
180
+ }, e.title), " ", e.description))))), s && t("button", {
184
181
  class: "button-primary start-button",
185
182
  onClick: l(this, g, "f")
186
183
  }, l(this, c, "f").startButtonCaption))));
@@ -308,4 +305,4 @@ M = new WeakMap, W = new WeakMap;
308
305
  I.style = n;
309
306
 
310
307
  export { I as gx_ide_welcome_page };
311
- //# sourceMappingURL=p-f3f35e5c.entry.js.map
308
+ //# sourceMappingURL=p-f5a48b33.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["welcomePageCss","ACTIVE_SLIDE_SELECTOR","ARROW_LEFT_KEY","ARROW_RIGHT_KEY","ESCAPE_KEY","SLIDE_FADE_DURATION","SLIDE_WORD_SELECTOR","SLIDE_WORD_SELECTOR_TIMEOUT","SLIDE_WORD_SELECTOR_VISIBLE","ICON_NEXT","getAssetPath","CLOSE_ICON","getIconPath","category","name","colorType","CSS_BUNDLES","GxIdeWelcomePage","_GxIdeWelcomePage_componentLocale","set","this","_GxIdeWelcomePage_slidesDescriptionAsChunksAlreadyDisplayed","Map","_GxIdeWelcomePage_slidesElements","_GxIdeWelcomePage_slidesElementsRef","_GxIdeWelcomePage_slideTimeOutId","_GxIdeWelcomePage_closeSlider","sliderVisible","setTimeout","el","remove","closeCallback","document","removeEventListener","__classPrivateFieldGet","_GxIdeWelcomePage_keyboardEventHandler","_GxIdeWelcomePage_initiateSlidesTransition","_GxIdeWelcomePage_slideTimeOut","call","addEventListener","_GxIdeWelcomePage_displayWords","wordsNodeList","forEach","word","index","classList","add","_GxIdeWelcomePage_dotClickedHandler","event","userHasChangedSlide","itemClicked","currentTarget","parseInt","getAttribute","_GxIdeWelcomePage_updateActiveSlide","goToPrevSlide","key","slideTransitioning","lastSlideReached","activeSlideIndex","goToNextSlide","closeSlider","_GxIdeWelcomePage_nextSlideHandler","_GxIdeWelcomePage_prevSlideHandler","newIndex","clearTimeout","autoChangeSlide","transitionType","itemsWordsCount","slides","listItems","itemsWords","map","item","title","description","length","mergedItemsWords","join","split","mergedDescription","words","timeBeforeNextSlide","_GxIdeWelcomePage_secondsToRead","__classPrivateFieldSet","wordsCount","wordsPerMinute","minutes","milliseconds","_GxIdeWelcomePage_renderSlides","slide","isLastSlide","h","class","ref","role","copyright","illustrationAriaLabel","src","illustration","url","alt","paragraph","descriptionAsChunks","_GxIdeWelcomePage_splitWords","onClick","startButtonCaption","newSlideIndex","activeSlide","nextSlideReference","displayDescriptionAsChunks","descriptionAsChunksDisplayedAlready","get","slideTimeOut","querySelectorAll","componentWillLoad","Locale","getComponentStrings","componentDidLoad","render","Host","model","main","style","slide__footer","_","slide__dot"],"sources":["src/components/welcome-page/welcome-page.scss?tag=gx-ide-welcome-page&encapsulation=shadow","src/components/welcome-page/welcome-page.tsx"],"sourcesContent":[":host {\n --slide-header-block-padding: 34px;\n --slide-footer-block: var(--mer-spacing--md) var(--mer-spacing--4xl);\n --slide-footer-block-last-slide: var(--mer-spacing--md) 42px;\n --slide-footer-navigation-hide-transition: var(--mer-timing--fast);\n display: grid;\n block-size: 100%;\n inline-size: 100%;\n overflow: auto;\n padding: var(--mer-spacing--lg);\n box-sizing: border-box;\n padding: var(--mer-spacing--xl);\n}\n\n.main {\n display: grid;\n place-self: center;\n inline-size: 100%;\n max-inline-size: 1100px;\n background-color: var(--mer-surface__elevation--01);\n border-radius: 17px;\n overflow: hidden;\n border: var(--mer-border__width--sm) solid var(--mer-surface__elevation--01);\n inset-block-start: 0;\n transition: opacity var(--slide-fade-duration);\n opacity: 0;\n pointer-events: none;\n\n &--border-glow {\n animation: borderColorCycle 2s infinite;\n }\n &--visible {\n pointer-events: visible;\n opacity: 1;\n }\n}\n\n// - - - - - - - - - - - - -\n// Slide\n// - - - - - - - - - - - - -\n\n.slide {\n display: grid;\n block-size: 100%;\n grid-template-areas:\n \"header header\"\n \"slide-wrapper slide-wrapper\"\n \"footer footer\";\n grid-template-rows: max-content 1fr max-content;\n\n // - - - - - Header\n\n &__header {\n padding-inline: 18px;\n padding-block: 24px 27px;\n display: flex;\n flex-direction: row-reverse;\n grid-area: header;\n }\n\n // - - - - - Container\n\n &__container {\n display: contents;\n }\n\n &__wrapper {\n display: grid;\n column-gap: var(--mer-spacing--3xl);\n grid-template-areas:\n \"header header\"\n \"illustration copy\"\n \"footer footer\";\n grid-template-rows: max-content 1fr max-content;\n // grid-template-columns: 411px 1fr;\n grid-template-columns: 1fr 1fr;\n grid-area: slide-wrapper;\n transition: var(--slide-fade-duration) opacity;\n transition: opacity 200ms;\n padding-inline: 48px;\n opacity: 1;\n z-index: 1;\n }\n &__wrapper:not(.active) {\n opacity: 0;\n z-index: 0;\n pointer-events: none;\n }\n\n &__illustration {\n position: relative;\n overflow: hidden;\n display: grid;\n grid-area: illustration;\n place-items: center;\n inline-size: 100%;\n\n &-img {\n object-fit: contain;\n block-size: 100%;\n inline-size: 100%;\n }\n }\n\n &__copy {\n grid-area: copy;\n place-self: center;\n justify-self: flex-start;\n }\n\n &__copy-container {\n display: grid;\n gap: var(--mer-spacing--md);\n max-inline-size: 524px;\n }\n\n &__copy-header {\n display: grid;\n gap: var(--mer-spacing--md);\n }\n\n &__copy-title {\n font-size: var(--mer-font__size--xl);\n color: var(--mer-text__on-surface);\n letter-spacing: 0.02em;\n font-weight: var(--mer-font__weight--semi-bold);\n }\n\n &__copy-description {\n display: grid;\n gap: var(--mer-spacing--md);\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 }\n\n &__list {\n display: grid;\n gap: var(--mer-spacing--md);\n list-style: none;\n padding: 0;\n margin: 0;\n\n &-item {\n &-title {\n font-weight: var(--mer-font__weight--medium);\n }\n }\n }\n\n // words (if 'showTextInChunks' is true)\n &__word {\n transition: var(--mer-timing--regular) opacity;\n opacity: 0;\n\n &--visible {\n opacity: 1;\n }\n }\n\n // - - - - - Footer\n\n &__footer {\n $hideDotsDuration: calc(var(--mer-timing--fast) + 200ms);\n grid-area: footer;\n display: grid;\n padding-block: var(--slide-footer-block);\n opacity: 1;\n\n &-last-slide {\n opacity: 0;\n transition: $hideDotsDuration opacity;\n pointer-events: none;\n animation: footerPaddingBlockLastSlide var(--mer-timing--regular) ease-out\n forwards $hideDotsDuration;\n }\n }\n\n &__footer-wrapper {\n display: grid;\n grid-auto-flow: column;\n grid-auto-columns: max-content;\n gap: var(--mer-spacing--md);\n align-items: center;\n justify-content: center;\n transition: var(--mer-timing--regular) opacity;\n opacity: 1;\n\n &-hidden {\n opacity: 0;\n }\n }\n &__dots {\n display: grid;\n gap: var(--mer-spacing--2xs);\n list-style: none;\n padding: 0;\n margin: 0;\n grid-auto-flow: column;\n grid-auto-columns: max-content;\n justify-content: center;\n\n &-inactive {\n pointer-events: none;\n }\n }\n &__dot {\n display: grid;\n padding: var(--mer-spacing--xs);\n cursor: pointer;\n\n &::before {\n content: \"\";\n place-self: center;\n inline-size: var(--mer-spacing--sm);\n block-size: var(--mer-spacing--sm);\n border-radius: calc(var(--mer-spacing--sm) / 2);\n background-color: var(--mer-color__neutral-gray--500);\n }\n &:hover::before {\n background-color: var(--mer-icon__on-primary--hover);\n }\n\n &.active {\n cursor: auto;\n &::before {\n background-color: var(--mer-accent__primary);\n cursor: auto;\n }\n }\n\n &-inactive {\n pointer-events: none;\n }\n }\n}\n\n.close-icon {\n transition: all var(--mer-timing--fast);\n &:hover {\n filter: brightness(1.5);\n }\n}\n\n.start-button {\n justify-self: start;\n margin-block-start: 25px;\n}\n\n// - - - - - - - - - - - - - -\n// Animations\n// - - - - - - - - - - - - - -\n\n@keyframes ellipseFadeInOut {\n 0% {\n opacity: 0.3;\n }\n 100% {\n opacity: 0.7;\n }\n}\n@keyframes ellipseRotate {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n@keyframes polygonRotate {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n\n@keyframes borderColorCycle {\n 0% {\n border-color: var(--mer-surface__elevation--01);\n }\n 50% {\n border-color: var(--mer-color__primary--400);\n }\n 100% {\n border-color: var(--mer-surface__elevation--01);\n }\n}\n\n@keyframes footerPaddingBlockLastSlide {\n 0% {\n padding-block: var(--slide-footer-block);\n }\n 100% {\n padding-block: var(--slide-footer-block-last-slide);\n }\n}\n\n.fade-out {\n animation: fadeOut 0.5s forwards 0.3s;\n}\n","// Stencil\nimport {\n Component,\n Host,\n h,\n Prop,\n Element,\n State,\n getAssetPath\n} from \"@stencil/core\";\n// Other Libraries\nimport { MercuryBundles, getIconPath } from \"@genexus/mercury\";\n\n// Custom Imports\nimport { Locale } from \"../../common/locale\";\n\nconst ACTIVE_SLIDE_SELECTOR = \"active\";\nconst ARROW_LEFT_KEY = \"ArrowLeft\";\nconst ARROW_RIGHT_KEY = \"ArrowRight\";\nconst ESCAPE_KEY = \"Escape\";\nconst SLIDE_FADE_DURATION = 300;\nconst SLIDE_WORD_SELECTOR = \".slide__word\";\nconst SLIDE_WORD_SELECTOR_TIMEOUT = 70;\nconst SLIDE_WORD_SELECTOR_VISIBLE = \"slide__word--visible\";\n\n// icons\nconst ICON_NEXT = getAssetPath(\n `./gx-ide-assets/welcome-page/images/icon-next.svg`\n);\nconst CLOSE_ICON = getIconPath({\n category: \"system\",\n name: \"close\",\n colorType: \"on-elevation\"\n});\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"utils/typography\",\n \"components/icon\",\n \"components/button\"\n];\n\n@Component({\n tag: \"gx-ide-welcome-page\",\n styleUrl: \"welcome-page.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/welcome-page\"]\n})\nexport class GxIdeWelcomePage {\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 #slidesDescriptionAsChunksAlreadyDisplayed: Map<number, boolean> = new Map();\n #slidesElements: HTMLElement[] = [];\n #slidesElementsRef: HTMLElement[] = [];\n // #slidesDescriptionAsChunksAlreadyDisplayed is used to know if the description of a slide\n // that is set to be displayed as chunks, has already been displayed. Used to not display\n // as chunks after the first time.\n #slideTimeOutId: NodeJS.Timeout;\n\n @Element() el: HTMLGxIdeWelcomePageElement;\n\n /**\n * The current active slide index from 'slides' Prop. It does not considers the very first slide \"Copyright\".\n */\n @State() activeSlideIndex: number = 0;\n\n /**\n * When true the slider will be visible. Used to display and hide the slide with a smooth transition.\n */\n @State() displaySlider: boolean = false;\n\n /**\n * True if the very first slide is visible (The copyright slide)\n */\n @State() copyrightsVisible: boolean = true;\n\n /**\n * True if the user has reached the last slide. Used to hide/disable the navigation.\n */\n @State() lastSlideReached: boolean = false;\n\n /**\n * When true the slider will be visible. Used to display and hide the slider with a smooth transition.\n */\n @State() sliderVisible: boolean = false;\n\n /**\n * True if a slide is transitioning, false otherwise. Used to disable the navigation arrows while transitioning.\n */\n @State() slideTransitioning: boolean = false;\n\n /**\n * True if the user has changed slides by clicking on the navigation dots, or by using the keyboard arrows. This is used to know evaluate the slide transition setTimeOut. If the user has navigated, automatic slide transition should be turned off.\n */\n @State() userHasChangedSlide: boolean = false;\n\n /**\n * The transition type between the slides. \"static\" requires the user to navigate by clicking the navigation dots. \"auto\" will transition automatically after a calculated amount of time.\n */\n @Prop() readonly transitionType: TransitionType = \"auto\";\n\n /**\n * The estimated amount of words per minute that the user requires to read a slide. This value is used to return the time each slide is freezed before transitioning to the next one. Only evaluated when transitionType is set to \"auto\".\n */\n @Prop() readonly wordsPerMinute: number = 250;\n\n /**\n * Callback invoked when the user closes the slider by pressing the close button.\n */\n @Prop() readonly closeCallback!: CloseCallback;\n\n /**\n * An array of slides, with the information that each slide requires. This slides appear after the first slide (Copyrights) that is defined inside the component.\n */\n @Prop() readonly slides: SlideInfo[] = [];\n\n async componentWillLoad() {\n this.#componentLocale = await Locale.getComponentStrings(this.el);\n this.#renderSlides();\n }\n\n componentDidLoad() {\n this.#slidesElementsRef[this.activeSlideIndex].classList.add(\n ACTIVE_SLIDE_SELECTOR\n );\n this.sliderVisible = true;\n this.#initiateSlidesTransition();\n }\n\n #closeSlider = () => {\n this.sliderVisible = false;\n setTimeout(() => {\n // wait until the slide disappears, then remove.\n this.el.remove();\n this.closeCallback();\n document.removeEventListener(\"keydown\", this.#keyboardEventHandler);\n }, SLIDE_FADE_DURATION);\n };\n\n #initiateSlidesTransition = () => {\n this.#slideTimeOut();\n // listen to keydown events to navigate the slides with the arrows\n document.addEventListener(\"keydown\", this.#keyboardEventHandler);\n };\n\n #displayWords = (wordsNodeList: NodeListOf<HTMLElement>) => {\n wordsNodeList.forEach((word, index) => {\n setTimeout(() => {\n word.classList.add(SLIDE_WORD_SELECTOR_VISIBLE);\n }, index * SLIDE_WORD_SELECTOR_TIMEOUT);\n });\n };\n\n #dotClickedHandler = (event: MouseEvent) => {\n this.userHasChangedSlide = true;\n const itemClicked = event.currentTarget as HTMLElement;\n const index = parseInt(itemClicked.getAttribute(\"data-index\"), 10);\n this.#updateActiveSlide(index);\n };\n\n #keyboardEventHandler = (event: KeyboardEvent) => {\n this.userHasChangedSlide = true;\n const goToPrevSlide =\n event.key === ARROW_LEFT_KEY &&\n !this.slideTransitioning &&\n !this.lastSlideReached &&\n this.activeSlideIndex !== 0;\n\n const goToNextSlide =\n event.key === ARROW_RIGHT_KEY &&\n !this.slideTransitioning &&\n !this.lastSlideReached;\n\n const closeSlider =\n event.key === ESCAPE_KEY ||\n (event.key === ARROW_RIGHT_KEY &&\n !this.slideTransitioning &&\n this.lastSlideReached);\n\n if (goToNextSlide) {\n this.#nextSlideHandler();\n } else if (goToPrevSlide) {\n this.#prevSlideHandler();\n } else if (closeSlider) {\n this.#closeSlider();\n }\n };\n\n #nextSlideHandler = () => {\n const newIndex = this.activeSlideIndex + 1;\n this.#updateActiveSlide(newIndex);\n };\n\n #prevSlideHandler = () => {\n const newIndex = this.activeSlideIndex - 1;\n this.#updateActiveSlide(newIndex);\n };\n\n #slideTimeOut = () => {\n // Clear any existing timeout\n if (this.#slideTimeOutId) {\n clearTimeout(this.#slideTimeOutId);\n }\n\n const autoChangeSlide =\n this.transitionType === \"auto\" &&\n !this.lastSlideReached &&\n !this.userHasChangedSlide;\n\n if (!autoChangeSlide) {\n return;\n }\n\n let itemsWordsCount = 0;\n if (this.slides[this.activeSlideIndex].listItems) {\n const itemsWords = this.slides[this.activeSlideIndex].listItems.map(\n item => {\n return item.title + item.description;\n }\n );\n if (itemsWords.length) {\n const mergedItemsWords = itemsWords.join(\"\");\n itemsWordsCount = mergedItemsWords.split(\" \").length;\n }\n }\n\n const mergedDescription =\n this.slides[this.activeSlideIndex].description.join(\"\");\n const words = mergedDescription.split(\" \").length;\n const timeBeforeNextSlide: number = this.#secondsToRead(\n words + itemsWordsCount\n );\n\n // Set a fresh timeout\n if (timeBeforeNextSlide) {\n this.#slideTimeOutId = setTimeout(() => {\n this.#nextSlideHandler();\n }, timeBeforeNextSlide);\n }\n };\n\n #secondsToRead = (\n wordsCount: number,\n wordsPerMinute = this.wordsPerMinute\n ): number => {\n const minutes = wordsCount / wordsPerMinute;\n const milliseconds = minutes * 60000; // Convert minutes to milliseconds\n return milliseconds;\n };\n\n #renderSlides = () => {\n this.#slidesElements = this.slides.map((slide, index) => {\n const isLastSlide = index === this.slides.length - 1;\n return (\n <section\n class=\"slide__wrapper\"\n ref={(el: HTMLElement) =>\n (this.#slidesElementsRef[index] = el as HTMLElement)\n }\n >\n <div\n class=\"slide__illustration\"\n role=\"img\"\n aria-label={this.#componentLocale.copyright.illustrationAriaLabel}\n >\n <img\n class=\"slide__illustration-img\"\n src={slide.illustration.url}\n alt={slide.illustration.alt}\n />\n </div>\n <section class=\"slide__copy\">\n <div class=\"slide__copy-container\">\n <header class=\"slide__copy-header\">\n <img src={ICON_NEXT} alt=\"GeneXus Next isologotype\" />\n <h2 class=\"slide__copy-title\">{slide.title}</h2>\n </header>\n <div class=\"slide__copy-description\">\n {slide.description?.map(paragraph => {\n return (\n <p>\n {slide.descriptionAsChunks\n ? this.#splitWords(paragraph)\n : paragraph}\n </p>\n );\n })}\n {slide.listItems?.length && (\n <ul class=\"slide__list\">\n {slide.listItems.map(item => {\n return (\n <li class=\"slide__list-item\">\n <strong class=\"slide__list-item-title\">\n {item.title}\n </strong>{\" \"}\n {item.description}\n </li>\n );\n })}\n </ul>\n )}\n </div>\n {isLastSlide && (\n <button\n class=\"button-primary start-button\"\n onClick={this.#closeSlider}\n >\n {this.#componentLocale.startButtonCaption}\n </button>\n )}\n </div>\n </section>\n </section>\n );\n });\n };\n\n #splitWords = (paragraph: string): HTMLSpanElement[] => {\n return paragraph.split(\" \").map(word => {\n // keep the space after {word} !\n return <span class=\"slide__word\">{word} </span>;\n });\n };\n\n #updateActiveSlide = (newSlideIndex: number) => {\n this.slideTransitioning = true;\n\n // unset current active slide\n const activeSlide = this.#slidesElementsRef[this.activeSlideIndex];\n activeSlide.classList.remove(ACTIVE_SLIDE_SELECTOR);\n\n const nextSlideReference = this.#slidesElementsRef[newSlideIndex];\n const displayDescriptionAsChunks =\n this.slides[newSlideIndex].descriptionAsChunks;\n const descriptionAsChunksDisplayedAlready =\n this.#slidesDescriptionAsChunksAlreadyDisplayed.get(newSlideIndex);\n let wordsCount;\n let wordsNodeList: NodeListOf<HTMLElement>;\n let slideTimeOut = 0;\n if (displayDescriptionAsChunks) {\n wordsNodeList = nextSlideReference.querySelectorAll(SLIDE_WORD_SELECTOR);\n wordsCount = wordsNodeList.length;\n slideTimeOut = wordsCount * SLIDE_WORD_SELECTOR_TIMEOUT;\n }\n\n this.lastSlideReached = newSlideIndex === this.slides.length - 1;\n\n // set new slide as active after fade out\n setTimeout(() => {\n nextSlideReference.classList.add(ACTIVE_SLIDE_SELECTOR);\n\n if (displayDescriptionAsChunks && !descriptionAsChunksDisplayedAlready) {\n this.#slidesDescriptionAsChunksAlreadyDisplayed.set(\n newSlideIndex,\n true\n );\n this.#displayWords(wordsNodeList);\n setTimeout(() => {\n this.slideTransitioning = false;\n }, slideTimeOut);\n } else {\n this.slideTransitioning = false;\n }\n }, SLIDE_FADE_DURATION);\n\n // update active slide index\n this.activeSlideIndex = newSlideIndex;\n this.#slideTimeOut(); // this has to be after this.#updateActiveSlide.\n };\n\n render() {\n return (\n <Host>\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <div\n class={{\n \"main\": true,\n \"main--visible\": this.sliderVisible,\n \"main--border-glow\": this.lastSlideReached\n }}\n style={{ \"--slide-fade-duration\": `${SLIDE_FADE_DURATION}ms` }}\n >\n <section class=\"slide\">\n <header class=\"slide__header\">\n <button\n class=\"button-tertiary button-icon-only close-icon\"\n aria-label=\"close presentation\"\n onClick={this.#closeSlider}\n >\n <ch-image class=\"icon-md\" src={CLOSE_ICON}></ch-image>\n </button>\n </header>\n <div class=\"slide__container\">{this.#slidesElements}</div>\n <footer\n // slide common footer\n class={{\n slide__footer: true\n }}\n >\n <div\n class={{\n \"slide__footer-wrapper\": true\n }}\n >\n <ul class=\"slide__dots\" aria-label=\"Slide indicators\">\n {this.slides.map((_, index) => {\n return (\n <li\n class={{\n \"slide__dot\": true,\n \"slide__dot-inactive\": this.slideTransitioning,\n [ACTIVE_SLIDE_SELECTOR]:\n index === this.activeSlideIndex\n }}\n data-index={index}\n onClick={\n !this.slideTransitioning && this.#dotClickedHandler\n }\n ></li>\n );\n })}\n </ul>\n </div>\n </footer>\n </section>\n </div>\n </Host>\n );\n }\n}\n\nexport type SlideInfo = {\n illustration: {\n url: string;\n alt: string;\n };\n title: string;\n description?: string[];\n descriptionAsChunks?: boolean;\n listItems?: Array<{\n title: string;\n description: string;\n }>;\n};\n\nexport type CloseCallback = () => Promise<void>;\nexport type TransitionType = \"static\" | \"auto\";\n"],"mappings":"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"}