@genexus/genexus-ide-ui 1.1.34 → 1.1.35

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 (262) hide show
  1. package/dist/cjs/{config-140f58fe.js → config-df6ba4e9.js} +2 -2
  2. package/dist/cjs/config-df6ba4e9.js.map +1 -0
  3. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  4. package/dist/cjs/gx-ide-bpm-app-declaration.cjs.entry.js +1 -1
  5. package/dist/cjs/gx-ide-bpm-assign-roles.cjs.entry.js +1 -1
  6. package/dist/cjs/gx-ide-bpm-export-xpdl.cjs.entry.js +1 -1
  7. package/dist/cjs/gx-ide-bpm-import-files.cjs.entry.js +1 -1
  8. package/dist/cjs/gx-ide-bpm-import-gxpm.cjs.entry.js +1 -1
  9. package/dist/cjs/gx-ide-bpm-objects-selector.cjs.entry.js +1 -1
  10. package/dist/cjs/gx-ide-bpm-timer-duration.cjs.entry.js +1 -1
  11. package/dist/cjs/gx-ide-connect-gx-server.cjs.entry.js +2 -2
  12. package/dist/cjs/gx-ide-connect-gx-server.cjs.entry.js.map +1 -1
  13. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js +1 -1
  14. package/dist/cjs/gx-ide-curl-inspector.cjs.entry.js +1 -1
  15. package/dist/cjs/gx-ide-data-selector.cjs.entry.js +1 -1
  16. package/dist/cjs/gx-ide-design-import.cjs.entry.js +1 -1
  17. package/dist/cjs/gx-ide-json-import.cjs.entry.js +1 -1
  18. package/dist/cjs/gx-ide-new-environment.cjs.entry.js +1 -1
  19. package/dist/cjs/gx-ide-new-kb.cjs.entry.js +1 -1
  20. package/dist/cjs/gx-ide-new-object.cjs.entry.js +1 -1
  21. package/dist/cjs/gx-ide-new-version.cjs.entry.js +1 -1
  22. package/dist/cjs/gx-ide-object-selector.cjs.entry.js +1 -1
  23. package/dist/cjs/gx-ide-plugin-explorer.cjs.entry.js +1 -1
  24. package/dist/cjs/gx-ide-server-selector.cjs.entry.js +5 -3
  25. package/dist/cjs/gx-ide-server-selector.cjs.entry.js.map +1 -1
  26. package/dist/cjs/gx-ide-share-kb.cjs.entry.js +1 -1
  27. package/dist/cjs/gx-ide-team-dev-bring-changes.cjs.entry.js +18 -29
  28. package/dist/cjs/gx-ide-team-dev-bring-changes.cjs.entry.js.map +1 -1
  29. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js +6 -15
  30. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js.map +1 -1
  31. package/dist/cjs/gx-ide-team-dev-history.cjs.entry.js +1 -1
  32. package/dist/cjs/gx-ide-team-dev-select-recent-comment.cjs.entry.js +1 -1
  33. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js +92 -53
  34. package/dist/cjs/gx-ide-team-dev-update-partial-selection.cjs.entry.js.map +1 -1
  35. package/dist/cjs/gx-ide-team-dev-update-to-revision.cjs.entry.js +111 -36
  36. package/dist/cjs/gx-ide-team-dev-update-to-revision.cjs.entry.js.map +1 -1
  37. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js +497 -234
  38. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js.map +1 -1
  39. package/dist/cjs/gx-ide-wf-settings.cjs.entry.js +1 -1
  40. package/dist/cjs/gx-ide-ww-attributes.cjs.entry.js +1 -1
  41. package/dist/cjs/gx-ide-ww-files.cjs.entry.js +1 -1
  42. package/dist/cjs/gx-ide-ww-images.cjs.entry.js +1 -1
  43. package/dist/cjs/helpers-456ecc75.js +16 -0
  44. package/dist/cjs/helpers-456ecc75.js.map +1 -0
  45. package/dist/cjs/loader.cjs.js +1 -1
  46. package/dist/collection/common/config.js +1 -1
  47. package/dist/collection/common/config.js.map +1 -1
  48. package/dist/collection/components/data-type-selector/gx-ide-assets/data-type-selector/langs/data-type-selector.lang.en.json +1 -1
  49. package/dist/collection/components/plugin-explorer/gx-ide-assets/plugin-explorer/langs/plugin-explorer.lang.en.json +1 -1
  50. package/dist/collection/components/plugin-explorer/gx-ide-assets/plugin-explorer/langs/plugin-explorer.lang.zh.json +1 -1
  51. package/dist/collection/components/start-page/gx-ide-assets/start-page/langs/start-page.lang.en.json +1 -1
  52. package/dist/collection/components/start-page/gx-ide-assets/start-page/langs/start-page.lang.zh.json +1 -1
  53. package/dist/collection/components/team-dev/bring-changes/bring-changes.css +3 -3
  54. package/dist/collection/components/team-dev/bring-changes/bring-changes.js +43 -49
  55. package/dist/collection/components/team-dev/bring-changes/bring-changes.js.map +1 -1
  56. package/dist/collection/components/team-dev/bring-changes/gx-ide-assets/team-dev-bring-changes/langs/team-dev-bring-changes.lang.en.json +1 -1
  57. package/dist/collection/components/team-dev/bring-changes/gx-ide-assets/team-dev-bring-changes/langs/team-dev-bring-changes.lang.zh.json +1 -1
  58. package/dist/collection/components/team-dev/commit/gx-ide-assets/team-dev-commit/langs/team-dev-commit.lang.en.json +2 -2
  59. package/dist/collection/components/team-dev/commit/gx-ide-assets/team-dev-commit/langs/team-dev-commit.lang.ja.json +1 -1
  60. package/dist/collection/components/team-dev/commit/gx-ide-assets/team-dev-commit/langs/team-dev-commit.lang.zh.json +2 -2
  61. package/dist/collection/components/team-dev/connect-gx-server/connect-gx-server.js +1 -1
  62. package/dist/collection/components/team-dev/connect-gx-server/connect-gx-server.js.map +1 -1
  63. package/dist/collection/components/team-dev/connect-gx-server/gx-ide-assets/connect-gx-server/langs/connect-gx-server.lang.en.json +1 -1
  64. package/dist/collection/components/team-dev/connect-gx-server/gx-ide-assets/connect-gx-server/langs/connect-gx-server.lang.ja.json +1 -1
  65. package/dist/collection/components/team-dev/connect-gx-server/gx-ide-assets/connect-gx-server/langs/connect-gx-server.lang.zh.json +1 -1
  66. package/dist/collection/components/team-dev/server-selector/server-selector.js +4 -2
  67. package/dist/collection/components/team-dev/server-selector/server-selector.js.map +1 -1
  68. package/dist/collection/components/team-dev/update/gx-ide-assets/team-dev-update/langs/team-dev-update.lang.en.json +49 -28
  69. package/dist/collection/components/team-dev/update/gx-ide-assets/team-dev-update/langs/team-dev-update.lang.ja.json +58 -37
  70. package/dist/collection/components/team-dev/update/gx-ide-assets/team-dev-update/langs/team-dev-update.lang.zh.json +49 -28
  71. package/dist/collection/components/team-dev/update/types.js +2 -0
  72. package/dist/collection/components/team-dev/update/types.js.map +1 -0
  73. package/dist/collection/components/team-dev/update/update.css +268 -606
  74. package/dist/collection/components/team-dev/update/update.js +566 -411
  75. package/dist/collection/components/team-dev/update/update.js.map +1 -1
  76. package/dist/collection/components/team-dev/update/utilities/actions-combo-box-model.js +2 -0
  77. package/dist/collection/components/team-dev/update/utilities/actions-combo-box-model.js.map +1 -0
  78. package/dist/collection/components/team-dev/update-partial-selection/gx-ide-assets/team-dev-update-partial-selection/langs/team-dev-update-partial-selection.lang.zh.json +11 -11
  79. package/dist/collection/components/team-dev/update-partial-selection/update-partial-selection.css +16 -590
  80. package/dist/collection/components/team-dev/update-partial-selection/update-partial-selection.js +100 -78
  81. package/dist/collection/components/team-dev/update-partial-selection/update-partial-selection.js.map +1 -1
  82. package/dist/collection/components/team-dev/update-to-revision/gx-ide-assets/team-dev-update-to-revision/langs/team-dev-update-to-revision.lang.zh.json +5 -5
  83. package/dist/collection/components/team-dev/update-to-revision/gx-ide-assets/team-dev-update-to-revision/shortcuts.json +3 -3
  84. package/dist/collection/components/team-dev/update-to-revision/helpers.js +6 -0
  85. package/dist/collection/components/team-dev/update-to-revision/helpers.js.map +1 -0
  86. package/dist/collection/components/team-dev/update-to-revision/update-to-revision.css +11 -596
  87. package/dist/collection/components/team-dev/update-to-revision/update-to-revision.js +133 -56
  88. package/dist/collection/components/team-dev/update-to-revision/update-to-revision.js.map +1 -1
  89. package/dist/components/config.js +1 -1
  90. package/dist/components/config.js.map +1 -1
  91. package/dist/components/gx-ide-connect-gx-server.js +1 -1
  92. package/dist/components/gx-ide-connect-gx-server.js.map +1 -1
  93. package/dist/components/gx-ide-server-selector.js +4 -2
  94. package/dist/components/gx-ide-server-selector.js.map +1 -1
  95. package/dist/components/gx-ide-team-dev-bring-changes.js +20 -32
  96. package/dist/components/gx-ide-team-dev-bring-changes.js.map +1 -1
  97. package/dist/components/gx-ide-team-dev-commit.js +1 -10
  98. package/dist/components/gx-ide-team-dev-commit.js.map +1 -1
  99. package/dist/components/gx-ide-team-dev-update-partial-selection.js +93 -67
  100. package/dist/components/gx-ide-team-dev-update-partial-selection.js.map +1 -1
  101. package/dist/components/gx-ide-team-dev-update-to-revision.js +115 -51
  102. package/dist/components/gx-ide-team-dev-update-to-revision.js.map +1 -1
  103. package/dist/components/gx-ide-team-dev-update.js +528 -267
  104. package/dist/components/gx-ide-team-dev-update.js.map +1 -1
  105. package/dist/components/helpers2.js +13 -0
  106. package/dist/components/helpers2.js.map +1 -0
  107. package/dist/esm/{config-73a57a22.js → config-9eaeb14b.js} +2 -2
  108. package/dist/esm/config-9eaeb14b.js.map +1 -0
  109. package/dist/esm/genexus-ide-ui.js +1 -1
  110. package/dist/esm/gx-ide-bpm-app-declaration.entry.js +1 -1
  111. package/dist/esm/gx-ide-bpm-assign-roles.entry.js +1 -1
  112. package/dist/esm/gx-ide-bpm-export-xpdl.entry.js +1 -1
  113. package/dist/esm/gx-ide-bpm-import-files.entry.js +1 -1
  114. package/dist/esm/gx-ide-bpm-import-gxpm.entry.js +1 -1
  115. package/dist/esm/gx-ide-bpm-objects-selector.entry.js +1 -1
  116. package/dist/esm/gx-ide-bpm-timer-duration.entry.js +1 -1
  117. package/dist/esm/gx-ide-connect-gx-server.entry.js +2 -2
  118. package/dist/esm/gx-ide-connect-gx-server.entry.js.map +1 -1
  119. package/dist/esm/gx-ide-create-kb-from-server.entry.js +1 -1
  120. package/dist/esm/gx-ide-curl-inspector.entry.js +1 -1
  121. package/dist/esm/gx-ide-data-selector.entry.js +1 -1
  122. package/dist/esm/gx-ide-design-import.entry.js +1 -1
  123. package/dist/esm/gx-ide-json-import.entry.js +1 -1
  124. package/dist/esm/gx-ide-new-environment.entry.js +1 -1
  125. package/dist/esm/gx-ide-new-kb.entry.js +1 -1
  126. package/dist/esm/gx-ide-new-object.entry.js +1 -1
  127. package/dist/esm/gx-ide-new-version.entry.js +1 -1
  128. package/dist/esm/gx-ide-object-selector.entry.js +1 -1
  129. package/dist/esm/gx-ide-plugin-explorer.entry.js +1 -1
  130. package/dist/esm/gx-ide-server-selector.entry.js +5 -3
  131. package/dist/esm/gx-ide-server-selector.entry.js.map +1 -1
  132. package/dist/esm/gx-ide-share-kb.entry.js +1 -1
  133. package/dist/esm/gx-ide-team-dev-bring-changes.entry.js +18 -29
  134. package/dist/esm/gx-ide-team-dev-bring-changes.entry.js.map +1 -1
  135. package/dist/esm/gx-ide-team-dev-commit.entry.js +2 -11
  136. package/dist/esm/gx-ide-team-dev-commit.entry.js.map +1 -1
  137. package/dist/esm/gx-ide-team-dev-history.entry.js +1 -1
  138. package/dist/esm/gx-ide-team-dev-select-recent-comment.entry.js +1 -1
  139. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js +92 -53
  140. package/dist/esm/gx-ide-team-dev-update-partial-selection.entry.js.map +1 -1
  141. package/dist/esm/gx-ide-team-dev-update-to-revision.entry.js +111 -36
  142. package/dist/esm/gx-ide-team-dev-update-to-revision.entry.js.map +1 -1
  143. package/dist/esm/gx-ide-team-dev-update.entry.js +498 -235
  144. package/dist/esm/gx-ide-team-dev-update.entry.js.map +1 -1
  145. package/dist/esm/gx-ide-wf-settings.entry.js +1 -1
  146. package/dist/esm/gx-ide-ww-attributes.entry.js +1 -1
  147. package/dist/esm/gx-ide-ww-files.entry.js +1 -1
  148. package/dist/esm/gx-ide-ww-images.entry.js +1 -1
  149. package/dist/esm/helpers-e1db579e.js +13 -0
  150. package/dist/esm/helpers-e1db579e.js.map +1 -0
  151. package/dist/esm/loader.js +1 -1
  152. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  153. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
  154. package/dist/genexus-ide-ui/gx-ide-assets/connect-gx-server/langs/connect-gx-server.lang.en.json +1 -1
  155. package/dist/genexus-ide-ui/gx-ide-assets/connect-gx-server/langs/connect-gx-server.lang.ja.json +1 -1
  156. package/dist/genexus-ide-ui/gx-ide-assets/connect-gx-server/langs/connect-gx-server.lang.zh.json +1 -1
  157. package/dist/genexus-ide-ui/gx-ide-assets/data-type-selector/langs/data-type-selector.lang.en.json +1 -1
  158. package/dist/genexus-ide-ui/gx-ide-assets/plugin-explorer/langs/plugin-explorer.lang.en.json +1 -1
  159. package/dist/genexus-ide-ui/gx-ide-assets/plugin-explorer/langs/plugin-explorer.lang.zh.json +1 -1
  160. package/dist/genexus-ide-ui/gx-ide-assets/start-page/langs/start-page.lang.en.json +1 -1
  161. package/dist/genexus-ide-ui/gx-ide-assets/start-page/langs/start-page.lang.zh.json +1 -1
  162. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-bring-changes/langs/team-dev-bring-changes.lang.en.json +1 -1
  163. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-bring-changes/langs/team-dev-bring-changes.lang.zh.json +1 -1
  164. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-commit/langs/team-dev-commit.lang.en.json +2 -2
  165. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-commit/langs/team-dev-commit.lang.ja.json +1 -1
  166. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-commit/langs/team-dev-commit.lang.zh.json +2 -2
  167. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-update/langs/team-dev-update.lang.en.json +49 -28
  168. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-update/langs/team-dev-update.lang.ja.json +58 -37
  169. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-update/langs/team-dev-update.lang.zh.json +49 -28
  170. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-update-partial-selection/langs/team-dev-update-partial-selection.lang.zh.json +11 -11
  171. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-update-to-revision/langs/team-dev-update-to-revision.lang.zh.json +5 -5
  172. package/dist/genexus-ide-ui/gx-ide-assets/team-dev-update-to-revision/shortcuts.json +3 -3
  173. package/dist/genexus-ide-ui/p-08d90282.entry.js +178 -0
  174. package/dist/genexus-ide-ui/p-08d90282.entry.js.map +1 -0
  175. package/dist/genexus-ide-ui/{p-dc1a9bd5.entry.js → p-09a634fc.entry.js} +3 -3
  176. package/dist/genexus-ide-ui/p-09a634fc.entry.js.map +1 -0
  177. package/dist/genexus-ide-ui/{p-8c125495.entry.js → p-0ae0616f.entry.js} +2 -2
  178. package/dist/genexus-ide-ui/{p-00e51225.entry.js → p-1056dfe7.entry.js} +2 -2
  179. package/dist/genexus-ide-ui/{p-bf176329.entry.js → p-12b563fe.entry.js} +2 -2
  180. package/dist/genexus-ide-ui/{p-a5b30dc7.entry.js → p-13f4b647.entry.js} +2 -2
  181. package/dist/genexus-ide-ui/{p-54946b5e.entry.js → p-159164d6.entry.js} +2 -2
  182. package/dist/genexus-ide-ui/{p-6945a7ad.entry.js → p-16a88fc3.entry.js} +6 -6
  183. package/dist/genexus-ide-ui/{p-2c6ab8f4.entry.js → p-1d044bf5.entry.js} +2 -2
  184. package/dist/genexus-ide-ui/p-1f7ef8ba.entry.js +603 -0
  185. package/dist/genexus-ide-ui/p-1f7ef8ba.entry.js.map +1 -0
  186. package/dist/genexus-ide-ui/{p-e1d947d7.entry.js → p-2ce60f4c.entry.js} +2 -2
  187. package/dist/genexus-ide-ui/{p-38f135a5.entry.js → p-3b955964.entry.js} +2 -2
  188. package/dist/genexus-ide-ui/{p-4da77239.entry.js → p-3dc5d62e.entry.js} +2 -2
  189. package/dist/genexus-ide-ui/{p-56308ae7.entry.js → p-443fc479.entry.js} +2 -2
  190. package/dist/genexus-ide-ui/{p-952d84f8.entry.js → p-49f765ef.entry.js} +163 -172
  191. package/dist/genexus-ide-ui/p-49f765ef.entry.js.map +1 -0
  192. package/dist/genexus-ide-ui/{p-68ff4ac9.entry.js → p-4ef96726.entry.js} +2 -2
  193. package/dist/genexus-ide-ui/{p-e06cfa27.entry.js → p-59908901.entry.js} +2 -2
  194. package/dist/genexus-ide-ui/{p-57b8dd3d.entry.js → p-5a328be1.entry.js} +2 -2
  195. package/dist/genexus-ide-ui/{p-3817c664.entry.js → p-646ddf49.entry.js} +2 -2
  196. package/dist/genexus-ide-ui/{p-3d7ed559.entry.js → p-730f0cd3.entry.js} +2 -2
  197. package/dist/genexus-ide-ui/{p-4c37ff28.entry.js → p-7836028c.entry.js} +2 -2
  198. package/dist/genexus-ide-ui/{p-f94cb936.entry.js → p-7adb9d1f.entry.js} +2 -2
  199. package/dist/genexus-ide-ui/p-7f091892.entry.js +222 -0
  200. package/dist/genexus-ide-ui/p-7f091892.entry.js.map +1 -0
  201. package/dist/genexus-ide-ui/p-821431b4.js +13 -0
  202. package/dist/genexus-ide-ui/p-821431b4.js.map +1 -0
  203. package/dist/genexus-ide-ui/{p-44e5e972.js → p-9a03ac9f.js} +2 -2
  204. package/dist/genexus-ide-ui/{p-44e5e972.js.map → p-9a03ac9f.js.map} +1 -1
  205. package/dist/genexus-ide-ui/{p-9b1550be.entry.js → p-9ad85231.entry.js} +2 -2
  206. package/dist/genexus-ide-ui/{p-bb0cdfe6.entry.js → p-b5d8589f.entry.js} +2 -2
  207. package/dist/genexus-ide-ui/{p-7fe4387b.entry.js → p-be84e15b.entry.js} +2 -2
  208. package/dist/genexus-ide-ui/{p-923744e7.entry.js → p-bee71b20.entry.js} +25 -23
  209. package/dist/genexus-ide-ui/p-bee71b20.entry.js.map +1 -0
  210. package/dist/genexus-ide-ui/{p-4dd3af73.entry.js → p-d01bbc7a.entry.js} +2 -2
  211. package/dist/genexus-ide-ui/p-d1374a00.entry.js +728 -0
  212. package/dist/genexus-ide-ui/p-d1374a00.entry.js.map +1 -0
  213. package/dist/genexus-ide-ui/{p-833ae3bf.entry.js → p-da7df3dc.entry.js} +2 -2
  214. package/dist/genexus-ide-ui/{p-9d1316d4.entry.js → p-e7738191.entry.js} +2 -2
  215. package/dist/genexus-ide-ui/{p-212ca306.entry.js → p-f242ae04.entry.js} +2 -2
  216. package/dist/types/components/team-dev/bring-changes/bring-changes.d.ts +6 -9
  217. package/dist/types/components/team-dev/update/types.d.ts +1 -0
  218. package/dist/types/components/team-dev/update/update.d.ts +98 -110
  219. package/dist/types/components/team-dev/update/utilities/actions-combo-box-model.d.ts +0 -0
  220. package/dist/types/components/team-dev/update-partial-selection/update-partial-selection.d.ts +8 -25
  221. package/dist/types/components/team-dev/update-to-revision/helpers.d.ts +1 -0
  222. package/dist/types/components/team-dev/update-to-revision/update-to-revision.d.ts +8 -25
  223. package/dist/types/components.d.ts +68 -144
  224. package/package.json +1 -1
  225. package/dist/cjs/config-140f58fe.js.map +0 -1
  226. package/dist/esm/config-73a57a22.js.map +0 -1
  227. package/dist/genexus-ide-ui/p-0391a478.entry.js +0 -119
  228. package/dist/genexus-ide-ui/p-0391a478.entry.js.map +0 -1
  229. package/dist/genexus-ide-ui/p-69da0cd9.entry.js +0 -201
  230. package/dist/genexus-ide-ui/p-69da0cd9.entry.js.map +0 -1
  231. package/dist/genexus-ide-ui/p-8c1ee4d9.entry.js +0 -643
  232. package/dist/genexus-ide-ui/p-8c1ee4d9.entry.js.map +0 -1
  233. package/dist/genexus-ide-ui/p-923744e7.entry.js.map +0 -1
  234. package/dist/genexus-ide-ui/p-952d84f8.entry.js.map +0 -1
  235. package/dist/genexus-ide-ui/p-b2854730.entry.js +0 -641
  236. package/dist/genexus-ide-ui/p-b2854730.entry.js.map +0 -1
  237. package/dist/genexus-ide-ui/p-dc1a9bd5.entry.js.map +0 -1
  238. /package/dist/genexus-ide-ui/{p-8c125495.entry.js.map → p-0ae0616f.entry.js.map} +0 -0
  239. /package/dist/genexus-ide-ui/{p-00e51225.entry.js.map → p-1056dfe7.entry.js.map} +0 -0
  240. /package/dist/genexus-ide-ui/{p-bf176329.entry.js.map → p-12b563fe.entry.js.map} +0 -0
  241. /package/dist/genexus-ide-ui/{p-a5b30dc7.entry.js.map → p-13f4b647.entry.js.map} +0 -0
  242. /package/dist/genexus-ide-ui/{p-54946b5e.entry.js.map → p-159164d6.entry.js.map} +0 -0
  243. /package/dist/genexus-ide-ui/{p-6945a7ad.entry.js.map → p-16a88fc3.entry.js.map} +0 -0
  244. /package/dist/genexus-ide-ui/{p-2c6ab8f4.entry.js.map → p-1d044bf5.entry.js.map} +0 -0
  245. /package/dist/genexus-ide-ui/{p-e1d947d7.entry.js.map → p-2ce60f4c.entry.js.map} +0 -0
  246. /package/dist/genexus-ide-ui/{p-38f135a5.entry.js.map → p-3b955964.entry.js.map} +0 -0
  247. /package/dist/genexus-ide-ui/{p-4da77239.entry.js.map → p-3dc5d62e.entry.js.map} +0 -0
  248. /package/dist/genexus-ide-ui/{p-56308ae7.entry.js.map → p-443fc479.entry.js.map} +0 -0
  249. /package/dist/genexus-ide-ui/{p-68ff4ac9.entry.js.map → p-4ef96726.entry.js.map} +0 -0
  250. /package/dist/genexus-ide-ui/{p-e06cfa27.entry.js.map → p-59908901.entry.js.map} +0 -0
  251. /package/dist/genexus-ide-ui/{p-57b8dd3d.entry.js.map → p-5a328be1.entry.js.map} +0 -0
  252. /package/dist/genexus-ide-ui/{p-3817c664.entry.js.map → p-646ddf49.entry.js.map} +0 -0
  253. /package/dist/genexus-ide-ui/{p-3d7ed559.entry.js.map → p-730f0cd3.entry.js.map} +0 -0
  254. /package/dist/genexus-ide-ui/{p-4c37ff28.entry.js.map → p-7836028c.entry.js.map} +0 -0
  255. /package/dist/genexus-ide-ui/{p-f94cb936.entry.js.map → p-7adb9d1f.entry.js.map} +0 -0
  256. /package/dist/genexus-ide-ui/{p-9b1550be.entry.js.map → p-9ad85231.entry.js.map} +0 -0
  257. /package/dist/genexus-ide-ui/{p-bb0cdfe6.entry.js.map → p-b5d8589f.entry.js.map} +0 -0
  258. /package/dist/genexus-ide-ui/{p-7fe4387b.entry.js.map → p-be84e15b.entry.js.map} +0 -0
  259. /package/dist/genexus-ide-ui/{p-4dd3af73.entry.js.map → p-d01bbc7a.entry.js.map} +0 -0
  260. /package/dist/genexus-ide-ui/{p-833ae3bf.entry.js.map → p-da7df3dc.entry.js.map} +0 -0
  261. /package/dist/genexus-ide-ui/{p-9d1316d4.entry.js.map → p-e7738191.entry.js.map} +0 -0
  262. /package/dist/genexus-ide-ui/{p-212ca306.entry.js.map → p-f242ae04.entry.js.map} +0 -0
@@ -1,355 +1,616 @@
1
- import { h, proxyCustomElement, HTMLElement, createEvent, Host } from '@stencil/core/internal/client';
1
+ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
+ import { g as getIconPath } from './MERCURY_ASSETS.js';
2
3
  import { L as Locale } from './locale.js';
3
- import { c as config } from './config.js';
4
+ import { r as renderObjectTypeWithIcon } from './utilities.js';
4
5
  import { f as formatDate } from './helpers.js';
5
- import { d as defineCustomElement$5 } from './container.js';
6
- import { d as defineCustomElement$4 } from './list-selector.js';
7
- import { d as defineCustomElement$3 } from './list-selector-item.js';
8
- import { d as defineCustomElement$2 } from './title.js';
9
-
10
- /* STENCIL IMPORTS */
11
- const renderComboItems = (gxOptions) => {
12
- const comboItemsArray = [];
13
- gxOptions.forEach((gxOption) => {
14
- const iconName = gxOption.iconName || gxOption.icon;
15
- const value = gxOption.value || gxOption.id;
16
- comboItemsArray.push(h("gxg-combo-box-item", { value: value, icon: iconName }, gxOption.label || gxOption.name || gxOption.value || gxOption.id));
17
- });
18
- return comboItemsArray;
19
- };
6
+ import { c as config } from './config.js';
7
+ import { a as mapObjectTypeToComboBoxItemModel } from './helpers2.js';
8
+ import { d as defineCustomElement$3 } from './gx-ide-empty-state2.js';
9
+ import { d as defineCustomElement$2 } from './ide-loader.js';
20
10
 
21
- const updateCss = ":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:grid;block-size:100%}.card-regular{background-color:var(--mer-surface__elevation--01);border:var(--mer-border__width--sm) solid var(--mer-border-color__on-elevation--01);border-radius:var(--mer-border__radius--md);padding:var(--mer-spacing--md) var(--mer-spacing--md);display:grid}.card-small{background-color:var(--mer-surface__elevation--02);border-radius:var(--mer-border__radius--sm);padding:var(--mer-spacing--sm) var(--mer-spacing--sm)}.card-small--actionable:hover{background-color:var(--mer-color__neutral-gray--600)}.card-small--actionable:active{background-color:var(--mer-color__neutral-gray--650)}.card-small:focus-visible{outline:var(--focus__outline-width) var(--focus__outline-style) var(--focus__outline-color);outline-offset:var(--focus__outline-offset)}.empty-state{block-size:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--mer-spacing--sm);text-align:center}.empty-state__title,.empty-state__button,.empty-state__link{max-inline-size:300px}.opacity-0{opacity:0}.opacity-1{opacity:1}.display-contents{display:contents}.pill-tag{padding:1px 4px;border-radius:2px;min-inline-size:40px;text-align:center;margin-inline-end:10px;font-size:11px}.gxi-hidden{display:none !important}.gxi-full-height{height:100%}.gxi-overflow-auto{overflow:auto}.gxi-display-flex{display:flex}.align-start{display:flex;align-items:start}.align-center{display:flex;align-items:center}.align-end{display:flex;align-items:end}.overflow-auto{overflow:auto}.justify-start{display:flex;justify-content:start}.justify-center{display:flex;justify-content:center}.justify-end{display:flex;justify-content:end}.grid{display:grid;grid-row-gap:var(--gx-ide-grid-row-gap);grid-column-gap:var(--gx-ide-grid-column-gap);grid-template-rows:auto}ch-grid-cell{display:flex}ch-grid{overflow:auto;height:100%}ch-grid-column{z-index:99;border-bottom:1px solid var(--mer-color__neutral-gray--800)}ch-grid-column:first-child{padding-inline-start:var(--gx-ide-container__padding) !important}ch-grid-column:last-child{padding-inline-end:var(--gx-ide-container__padding) !important}ch-grid-cell{--mer-spacing--xs:var(--gx-ide-container__padding)}.layout{display:grid;gap:var(--mer-spacing--lg);box-sizing:border-box}.layout--two-cols{grid-template-columns:1fr 1fr}.layout--space-above{padding-block-start:var(--mer-spacing--lg)}gxg-tabs{box-shadow:none}:host(.gx-ide-component){height:100% !important;display:flex !important;flex-direction:column !important}:host(:focus-within) gx-ide-top-bar::part(wrapper){background-color:var(--color-secondary-enabled)}.gx-ide-main-wrapper{color:var(--gx-ide-component-text-color);font-weight:var(--mer-font__weight--regular);font-size:var(--mer-font__size--xs);font-family:var(--mer-font-family--primary);height:100%;background-color:var(--gx-ide-component-background-color);display:flex;flex-direction:column;flex-grow:1;box-sizing:border-box}.gx-ide-main{flex-grow:1;overflow-y:auto;}.gx-ide-main::-webkit-scrollbar{width:var(--gxg-scrollbar-width);height:var(--gxg-scrollbar-width)}.gx-ide-main::-webkit-scrollbar-track{background-color:var(--gxg-scrollbar-track-background);border-radius:var(--gxg-scrollbar-track-border-radius)}.gx-ide-main::-webkit-scrollbar-thumb{background-color:var(--gxg-scrollbar-track-thumb-background);border-radius:var(--gxg-scrollbar-track-thumb-radius)}.gx-ide-main::-webkit-scrollbar-thumb:hover{background-color:var(--gxg-scrollbar-track-thumb-hover-background)}.gx-ide-main::-webkit-scrollbar-corner{background:rgba(0, 0, 0, 0)}.gx-ide-overflow{overflow-y:auto;}.gx-ide-overflow::-webkit-scrollbar{width:var(--gxg-scrollbar-width);height:var(--gxg-scrollbar-width)}.gx-ide-overflow::-webkit-scrollbar-track{background-color:var(--gxg-scrollbar-track-background);border-radius:var(--gxg-scrollbar-track-border-radius)}.gx-ide-overflow::-webkit-scrollbar-thumb{background-color:var(--gxg-scrollbar-track-thumb-background);border-radius:var(--gxg-scrollbar-track-thumb-radius)}.gx-ide-overflow::-webkit-scrollbar-thumb:hover{background-color:var(--gxg-scrollbar-track-thumb-hover-background)}.gx-ide-overflow::-webkit-scrollbar-corner{background:rgba(0, 0, 0, 0)}.tree-view-primary{font-size:var(--mer-font__size--2xs)}p{margin:0;font-size:var(--mer-font__size--xxs)}.buttons-container{display:flex;gap:var(--mer-spacing--xs)}:host{display:block}.options-wrapper{display:grid;grid-template-columns:2fr 1fr;grid-column-gap:0;grid-row-gap:0;border-bottom:1px solid var(--gx-ide-container-border-color)}.options-wrapper .genexus-server{cursor:pointer}.options-wrapper .genexus-server:hover{background-color:var(--ds-item-background-color--hover)}.options-wrapper .scope{font-family:inherit;display:flex;flex-direction:column;gap:var(--mer-spacing--2xs)}.options-wrapper .scope .row{display:flex;flex-direction:row;align-items:center;gap:var(--mer-spacing--xs)}.options-wrapper .scope .row .value{font-style:italic}.filter-row{padding:0 var(--gx-ide-container__padding) 0 var(--gx-ide-container__padding);display:flex;flex-direction:row;gap:var(--gx-ide-grid-row-gap)}.filter-row .combo{flex:1}.data-grid{grid-template-columns:repeat(3, 1fr)}.data-grid>:nth-child(1){grid-area:1/1/2/2}.data-grid>:nth-child(2){grid-area:1/2/2/4}.data-panel-grid{grid-template-columns:repeat(2, 1fr)}.data-preview img{max-width:100%}.data-max-height{max-height:300px;overflow-y:auto}.actions{justify-content:flex-end}.no-border{border:0}.bold{font-weight:bold}ch-grid-rowset-empty{padding:var(--mer-spacing--2xs) var(--mer-spacing--xs)}gxg-tab::part(container){line-height:unset}.tabular-grid{block-size:100%}gx-ide-container::part(content){overflow:hidden}.tabular-grid-pending-update ch-tabular-grid-cell:is(:nth-child(6)){padding-block:var(--grid-cell__padding-block);padding-inline:var(--grid-cell__padding-inline);align-items:start;justify-content:start;display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-inline-size:0}.tabular-grid-results ch-tabular-grid-cell:is(:nth-child(6)){padding-block:var(--grid-cell__padding-block);padding-inline:var(--grid-cell__padding-inline);align-items:start;justify-content:start;display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-inline-size:0}";
11
+ const updateCss = ".custom-icon-text-wrapper {\n display: flex;\n align-items: center;\n gap: 10px;\n}\n\n/*Gx Ide*/\n/*@container queries*/\n/* hiChar styles\nFound on /common/helpers.tsx hiChar function is used to add a span/class to every character that matches a search value. It is used to help the user see why the filter results are filtered. The span/class on the characters are useless without proper styling.\n*/\n:host {\n --pill-border-radius: 12px;\n --pill-padding-inline: 8px;\n --pill-padding-block: 2px;\n --pill-font-size: var(--font-size-body-s);\n display: grid;\n block-size: 100%;\n overflow: auto;\n grid-template-rows: max-content max-content 1fr;\n}\n\n.detail__version, .detail__knowledge-base {\n padding-inline: 24px;\n border-inline-end: 1px solid var(--mer-border-color__on-elevation--01);\n}\n\n.detail__genexus-server {\n padding-inline-end: 24px;\n border-inline-end: 1px solid var(--mer-border-color__on-elevation--01);\n}\n\n.detail__last-full-update {\n padding-inline-start: 24px;\n}\n\n.section {\n display: contents;\n}\n\n.header {\n display: grid;\n grid-template-columns: 1fr max-content;\n}\n\n.header__detail {\n display: grid;\n row-gap: var(--mer-spacing--md);\n grid-auto-columns: max-content;\n grid-auto-rows: max-content;\n grid-template-areas: \"detail-heading-gx . . .\" \"detail-genexus-server detail-knowledge-base detail-version detail-last-full-update\";\n}\n\n.detail__label {\n color: var(--mer-color__neutral-gray--400);\n}\n\n.detail__heading-genexus-server {\n grid-area: detail-heading-gx;\n}\n\n.detail__genexus-server {\n grid-area: detail-genexus-server;\n}\n.detail__genexus-server > a {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n display: inline-block;\n}\n\n.detail__link {\n align-items: start;\n color: var(--mer-text__primary);\n text-decoration: underline;\n}\n.detail__link:hover {\n color: var(--mer-text__primary--hover);\n}\n.detail__link:active {\n color: var(--mer-text__primary--active);\n}\n\n.detail__knowledge-base {\n grid-area: detail-knowledge-base;\n}\n\n.detail__version {\n grid-area: detail-version;\n}\n\n.detail__last-full-update {\n grid-area: detail-last-full-update;\n}\n\n.filter-container {\n container-type: inline-size;\n box-sizing: border-box;\n}\n\n.filter {\n display: grid;\n margin-block-start: var(--mer-spacing--lg);\n grid-template-areas: \"filter-search filter-types filter-actions filter-kb-properties filter-buttons\";\n grid-template-columns: 200px 200px 200px max-content 1fr;\n gap: 12px;\n}\n\n@container (max-width: 1100px) {\n .filter-container > .filter {\n grid-template-columns: 200px 200px 200px 1fr;\n grid-template-areas: \"filter-search filter-types filter-actions filter-buttons\" \"filter-kb-properties . . .\";\n grid-auto-rows: max-content;\n }\n}\n@container (max-width: 900px) {\n .filter-container > .filter {\n grid-template-columns: 1fr 1fr 1fr;\n grid-template-areas: \"filter-search filter-types filter-actions\" \"filter-kb-properties filter-buttons filter-buttons\";\n grid-auto-rows: max-content;\n }\n}\n.filter__search {\n grid-area: filter-search;\n}\n\n.filter__types {\n grid-area: filter-types;\n}\n\n.filter__actions {\n grid-area: filter-actions;\n}\n\n.filter__kb-properties {\n grid-area: filter-kb-properties;\n}\n\n.filter__buttons {\n margin-inline-start: auto;\n grid-area: filter-buttons;\n}\n\n.main {\n position: relative;\n display: grid;\n overflow: auto;\n}\n\n.loader {\n position: relative;\n inline-size: 100%;\n block-size: 100%;\n inset-block-start: 0;\n}\n\n.tabular-grid {\n border-radius: 4px;\n overflow: hidden;\n}\n\n.empty-state {\n block-size: 100%;\n}\n\n.loader {\n --elevation-background-color: var(--mer-surface__elevation--01);\n}\n\n.messages-list {\n margin: 0;\n padding: 0;\n list-style: none;\n max-inline-size: 800px;\n padding: 8px 0;\n list-style-type: none;\n display: flex;\n flex-direction: column;\n gap: var(--mer-spacing--3xs);\n}\n\n.message-description {\n line-height: 1.5;\n display: flex;\n align-items: center;\n gap: 8px;\n}\n\n.message-icon {\n flex-shrink: 0;\n}\n\n.tabular-grid.empty-result::part(main) {\n overflow: hidden;\n}\n\n.input-comments-container {\n position: relative;\n}\n\n.input-comments {\n --control__border-color: transparent;\n padding-block: 0 !important;\n padding-inline: 0 !important;\n --line-height-tight: 1.4;\n block-size: 100%;\n background-color: var(--mer-surface);\n transition: var(--mer-timing--super-fast) block-size, var(--mer-timing--super-fast) background-color, var(--mer-timing--super-fast) padding-block, var(--mer-timing--super-fast) padding-inline;\n}\n\n.input-comments:focus {\n position: absolute;\n block-size: 200px;\n inline-size: 100%;\n z-index: 99;\n background-color: var(--mer-surface__elevation--01);\n padding-block: var(--control__padding-block) !important;\n padding-inline: var(--control__padding-inline) !important;\n}\n\nch-tabular-grid-cell.tabular-grid-cell::part(actions-icon) {\n background-size: contain;\n margin-inline-end: 0;\n --icon-path: var(--icon__gemini-tools_show-more-vertical_neutral--enabled);\n cursor: pointer;\n}\nch-tabular-grid-cell.tabular-grid-cell::part(actions-icon):hover {\n --icon-path: var(--icon__gemini-tools_show-more-vertical_neutral--hover);\n}\nch-tabular-grid-cell.tabular-grid-cell::part(actions-icon):active {\n --icon-path: var(--icon__gemini-tools_show-more-vertical_neutral--active);\n}\n\n.tabular-grid-row-actions::part(main),\n.property-grid-row-actions::part(main) {\n gap: 0 !important;\n}\n\n.tabular-grid-row-actions > button {\n justify-content: start;\n}\n\n.pill {\n --pill-background-color: transparent;\n --pill-color: transparent;\n --pill-border-color: transparent;\n background-color: var(--pill-background-color);\n color: var(--pill-color);\n border: 1px solid var(--pill-border-color);\n inline-size: 100%;\n padding: var(--pill-padding-block) var(--pill-padding-inline);\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: var(--pill-border-radius);\n position: relative;\n font-weight: var(--font-weight-semi-bold);\n}\n.pill--update, .pill--pending {\n --pill-background-color: var();\n --pill-color: var(--mer-color__neutral-gray--400);\n --pill-border-color: var();\n}\n.pill--to-merge-marked {\n --pill-background-color: var();\n --pill-color: var(--mer-border-color__primary);\n --pill-border-color: var();\n}\n.pill--ignored {\n --pill-background-color: var(--mer-surface__elevation--02);\n --pill-color: var(--mer-text__on-disabled);\n --pill-border-color: var(--mer-border-color__primary--disabled);\n}\n.pill--pending {\n --pill-background-color: var(--mer-color__tinted-primary--8);\n --pill-color: var(--mer-border-color__primary);\n --pill-border-color: var(--mer-color__tinted-primary--50);\n}\n.pill--warning {\n --pill-background-color: var(--mer-color__tinted-yellow--5);\n --pill-color: var(--mer-border-color__warning);\n --pill-border-color: var(--mer-color__tinted-yellow--60);\n}\n.pill--error {\n --pill-background-color: var(--mer-color__tinted-red--5);\n --pill-color: var(--mer-border-color__error);\n --pill-border-color: var(--mer-color__tinted-red--60);\n}\n.pill--updated {\n --pill-background-color: var(--mer-color__tinted-green--5);\n --pill-color: var(--mer-border-color__success);\n --pill-border-color: var(--mer-color__tinted-green--60);\n}\n.pill--transitioning {\n --pill-color: transparent;\n}\n\n.updating-spinner-caption {\n display: flex;\n align-items: center;\n gap: 6px;\n --status-circle-color: transparent;\n --status-circle-size: $size;\n --status-circle-inset-inline-start: 14px;\n --pill-color: var(--mer-border-color__primary);\n}\n.updating-spinner-caption::before {\n display: inline-block;\n content: \"\";\n width: 14px;\n height: 14px;\n border: calc(14px / 7) solid var(--mer-color__tinted-primary--50);\n border-top: calc(14px / 7) solid var(--mer-color__primary--300);\n border-radius: 50%;\n animation: spin var(--mer-timing--regular) linear infinite;\n}\n@keyframes spin {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n\n.tabular-grid .button-secondary {\n --control__padding-block: var(--pill-padding-block);\n --control__padding-inline: var(--pill-padding-inline);\n font-size: inherit;\n font-weight: inherit;\n /* font-size: var(--pill-font-size); */\n}\n\n.tabular-grid .tabular-grid-cell--for-pill {\n --grid-cell__padding-block: 4px;\n align-items: center;\n justify-content: center;\n}\n\n.tabular-grid.disabled-custom-selector .tabular-grid-cell::part(selector-label),\n.tabular-grid.disabled-custom-selector .tabular-grid-column::part(bar-selector),\n.tabular-grid.disabled-custom-selector .tabular-grid-cell::part(actions-icon) {\n pointer-events: none;\n opacity: 0.5;\n}\n\n.tabular-grid-column--settings-custom-selector,\n.tabular-grid-cell--settings-custom-selector {\n --grid-cell__padding-inline: 0;\n --grid-cell__padding-block: 0;\n}\n\n.tabular-grid-cell::part(actions-icon) {\n padding-block: 6px;\n}\n\nch-tabular-grid-cell.tabular-grid-cell::part(actions-icon) {\n block-size: 100%;\n display: block;\n background-size: 14px;\n padding-inline: 16px;\n}\n\n.tabular-grid-cell.no-checkbox-custom-selector::part(selector-label) {\n visibility: hidden;\n}\n\n.tabular-grid-row-actions::part(window) {\n background-color: var(--mer-surface__elevation--02) !important;\n}\n\n.tabular-grid-row .tabular-grid-cell:nth-child(3) {\n min-inline-size: 200px;\n}";
22
12
 
13
+ var __classPrivateFieldGet = (undefined && undefined.__classPrivateFieldGet) || function (receiver, state, kind, f) {
14
+ if (kind === "a" && !f)
15
+ throw new TypeError("Private accessor was defined without a getter");
16
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
17
+ throw new TypeError("Cannot read private member from an object whose class did not declare it");
18
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
19
+ };
20
+ var __classPrivateFieldSet = (undefined && undefined.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
21
+ if (kind === "m")
22
+ throw new TypeError("Private method is not writable");
23
+ if (kind === "a" && !f)
24
+ throw new TypeError("Private accessor was defined without a setter");
25
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
26
+ throw new TypeError("Cannot write private member to an object whose class did not declare it");
27
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
28
+ };
29
+ var _GxIdeTeamDevUpdate_componentLocale, _GxIdeTeamDevUpdate_actionsComboBoxModel, _GxIdeTeamDevUpdate_rowCheckedChangedByTheUser, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, _GxIdeTeamDevUpdate_updateCheckedClickedHandler, _GxIdeTeamDevUpdate_reloadClickedHandler, _GxIdeTeamDevUpdate_updateObjectsHandler, _GxIdeTeamDevUpdate_renderActionCellContent, _GxIdeTeamDevUpdate_updateSingleObject, _GxIdeTeamDevUpdate_renderObjectStatus, _GxIdeTeamDevUpdate_renderRows, _GxIdeTeamDevUpdate_rowMarkingChangedHandler, _GxIdeTeamDevUpdate_updatePendingCheckedItems, _GxIdeTeamDevUpdate_searchInputHandler, _GxIdeTeamDevUpdate_actionChangedHandler, _GxIdeTeamDevUpdate_typeChangedHandler, _GxIdeTeamDevUpdate_setInitialObjectsStatus, _GxIdeTeamDevUpdate_loadData, _GxIdeTeamDevUpdate_markPendingObjects, _GxIdeTeamDevUpdate_applyClientFilter, _GxIdeTeamDevUpdate_onRowContextMenuHandler, _GxIdeTeamDevUpdate_revertPendingCommitsCheckboxes, _GxIdeTeamDevUpdate_togglePendingCommitsCheckboxes, _GxIdeTeamDevUpdate_kbPropertiesChangedHandler;
23
30
  const CSS_BUNDLES = [
24
31
  "resets/box-sizing",
25
- "components/tabular-grid"
32
+ "components/tabular-grid",
33
+ "utils/form--full",
34
+ "utils/layout",
35
+ "utils/typography",
36
+ "utils/spacing",
37
+ "chameleon/scrollbar"
26
38
  ];
39
+ const CHECKBOX_CHECKED_VALUE = "true";
40
+ const CHECKBOX_UNCHECKED_VALUE = "false";
41
+ const DETAIL_LABEL_CLASSES = "detail__label body-semi-bold-s";
42
+ // icons
43
+ const ADD_ICON = getIconPath({
44
+ category: "system",
45
+ name: "add",
46
+ colorType: "on-elevation"
47
+ });
48
+ const EDITED_ICON = getIconPath({
49
+ category: "system",
50
+ name: "edit",
51
+ colorType: "on-elevation"
52
+ });
53
+ const FILTER_ICON = getIconPath({
54
+ category: "window-tools",
55
+ name: "filter",
56
+ colorType: "on-elevation"
57
+ });
58
+ const SEARCH_ICON = getIconPath({
59
+ category: "system",
60
+ name: "search",
61
+ colorType: "on-elevation"
62
+ });
63
+ const SUBSTRACT_ICON = getIconPath({
64
+ category: "system",
65
+ name: "substract",
66
+ colorType: "on-elevation"
67
+ });
68
+ const WARNING_ICON = getIconPath({
69
+ category: "system",
70
+ name: "warning",
71
+ colorType: "warning"
72
+ });
73
+ const ERROR_ICON = getIconPath({
74
+ category: "system",
75
+ name: "error",
76
+ colorType: "error"
77
+ });
78
+ const SUCCESS_ICON = getIconPath({
79
+ category: "system",
80
+ name: "check ",
81
+ colorType: "success"
82
+ });
83
+ const INFO_ICON = getIconPath({
84
+ category: "system",
85
+ name: "information",
86
+ colorType: "on-elevation"
87
+ });
88
+ const REFRESH_ICON = getIconPath({
89
+ category: "gemini-tools",
90
+ name: "reset",
91
+ colorType: "neutral"
92
+ });
27
93
  const GxIdeTeamDevUpdate$1 = /*@__PURE__*/ proxyCustomElement(class GxIdeTeamDevUpdate extends HTMLElement {
28
94
  constructor() {
29
95
  super();
30
96
  this.__registerHost();
31
97
  this.__attachShadow();
32
- this.componentDidLoadEvent = createEvent(this, "componentDidLoadEvent", 7);
33
- this.componentDidRenderFirstTime = createEvent(this, "componentDidRenderFirstTime", 7);
34
- this.loadDataCalledFirstTime = false; // pending for update grid checkboxes, should be checked, after loadData has loaded objects for the first time.
35
- this.renderedFirstTime = false;
36
- // 9.LOCAL METHODS //
37
- this.onRowContextMenuHandler = (grid) => async (ev) => {
38
- if (this.objectsContextMenuCallback) {
39
- ev.preventDefault();
40
- ev.stopPropagation();
41
- let selection = [];
42
- if (grid === "pending") {
43
- selection = await this.chGridPendingForUpdateEl.getSelectedRows();
98
+ /**
99
+ * The component hard-coded strings translations.
100
+ */
101
+ // eslint-disable-next-line @stencil-community/own-props-must-be-private
102
+ _GxIdeTeamDevUpdate_componentLocale.set(this, void 0);
103
+ _GxIdeTeamDevUpdate_actionsComboBoxModel.set(this, void 0);
104
+ /**
105
+ * Used to determine if pendingItemsCheckedCallback callback has to be called or not.
106
+ * It should be ignored if the grid checkboxes state is changed programmatically, by
107
+ * setting markRow to false once the object has been successfully updated, for example.
108
+ */
109
+ _GxIdeTeamDevUpdate_rowCheckedChangedByTheUser.set(this, true);
110
+ _GxIdeTeamDevUpdate_chGridPendingForUpdateEl.set(this, void 0);
111
+ _GxIdeTeamDevUpdate_updateCheckedClickedHandler.set(this, async () => {
112
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_updateObjectsHandler, "f").call(this, [...this.markedObjectsSet]);
113
+ });
114
+ _GxIdeTeamDevUpdate_reloadClickedHandler.set(this, async () => {
115
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_loadData, "f").call(this, true);
116
+ });
117
+ _GxIdeTeamDevUpdate_updateObjectsHandler.set(this, async (selection) => {
118
+ __classPrivateFieldSet(this, _GxIdeTeamDevUpdate_rowCheckedChangedByTheUser, false, "f");
119
+ this.updating = true;
120
+ selection.forEach(itemToUpdate => {
121
+ this.objectsStatusMap.set(itemToUpdate, "updating");
122
+ });
123
+ const updateResult = await this.updateCallback(selection);
124
+ updateResult.forEach(async (objectResult) => {
125
+ const messages = objectResult.messages;
126
+ if (messages.length) {
127
+ this.objectsMessagesDataMap.set(objectResult.id, objectResult.messages);
44
128
  }
45
- else if (grid === "ignored") {
46
- selection = await this.chGridIgnoredObjectsEl.getSelectedRows();
129
+ else {
130
+ // clear messages
131
+ this.objectsMessagesDataMap.delete(objectResult.id);
47
132
  }
48
- else if (grid === "results") {
49
- selection = await this.chGridResultsEl.getSelectedRows();
133
+ if (objectResult.result === "updated") {
134
+ this.alreadyUpdatedObjectsIdsSet.add(objectResult.id);
135
+ this.objectsStatusMap.set(objectResult.id, "updated");
136
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").markRow(objectResult.id, false);
50
137
  }
51
- await this.objectsContextMenuCallback(grid, {
52
- selection: selection,
53
- clientX: ev.detail.clientX,
54
- clientY: ev.detail.clientY
55
- });
138
+ else {
139
+ this.objectsStatusMap.set(objectResult.id, "pending");
140
+ }
141
+ });
142
+ this.updating = false;
143
+ });
144
+ _GxIdeTeamDevUpdate_renderActionCellContent.set(this, (action) => {
145
+ let icon;
146
+ let caption;
147
+ let iconColor;
148
+ if (action === "deleted") {
149
+ icon = SUBSTRACT_ICON;
150
+ caption = __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.delete;
151
+ iconColor = "--mer-icon__error";
56
152
  }
57
- };
58
- this.markAllPendingToUpdateRows = () => {
59
- this.chGridPendingForUpdateEl.markAllRows();
60
- };
61
- this.gridOnSelectionChangedCallbackHandler = (grid) => async (ev) => {
62
- if (this.selectCallback) {
63
- await this.selectCallback(grid, ev.detail.rowsId);
153
+ else if (action === "inserted") {
154
+ icon = ADD_ICON;
155
+ caption = __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.insert;
156
+ iconColor = "--mer-icon__success";
64
157
  }
65
- };
66
- this.genexusServerUrlHandler = () => {
67
- var _a;
68
- if ((_a = this.updateFrom) === null || _a === void 0 ? void 0 : _a.serverUrl) {
69
- window.open(this.updateFrom.serverUrl);
158
+ else if (action === "modified") {
159
+ icon = EDITED_ICON;
160
+ caption = __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.modify;
161
+ iconColor = "--mer-icon__warning";
70
162
  }
71
- };
72
- this.renderOptions = () => {
73
- return (h("div", { class: "options-wrapper" }, h("gx-ide-container", { part: "options-update-from", containerTitle: this._componentLocale.options.updateFrom, titleType: "secondary", contentBorderEnd: true, noContentPadding: true }, h("gx-ide-list-selector", { type: "single-selection", listName: "commit-recent-messages", readonly: true, noListBorder: true }, h("gx-ide-list-selector-item", { icon: "window-tools/genexus-cloud", itemId: "genexus-server", itemValue: undefined, class: "genexus-server", onClick: this.genexusServerUrlHandler }, `${this._componentLocale.options.updateFrom}:`, h("gxg-text", { type: "text-link" }, this.updateFrom ? this.updateFrom.serverUrl : "")), h("gx-ide-list-selector-item", { icon: "general/knowledge-base", itemId: "knowledge-base", itemValue: `${this._componentLocale.options.knowledgeBase}: ${this.updateFrom ? this.updateFrom.kbName : ""}` }), h("gx-ide-list-selector-item", { icon: "general/version", itemId: "version", itemValue: `${this._componentLocale.options.version}: ${this.updateFrom ? this.updateFrom.versionName : ""}` }), h("gx-ide-list-selector-item", { icon: "window-tools/last-changes-view", itemId: "last-full-update", itemValue: `${this._componentLocale.options.lastFullUpdate}: ${formatDate(this.updateFrom.lastFullUpdate)}` }))), h("gx-ide-container", { part: "options-scope", containerTitle: this._componentLocale.options.scope, titleType: "secondary" }, h("div", { class: "scope" }, h("div", { class: "row" }, h("gxg-label", { labelPosition: "start", center: true, noMargin: true }, this._componentLocale.options.objects, ":"), h("span", { class: {
74
- bold: this.objectScopeText === "partial",
75
- value: true
76
- } }, this._componentLocale.options.scopeData.objects[this.objectScopeText.toLocaleLowerCase()]), h("gxg-text", { type: "text-link", onClick: this.objectsScope, part: "gxg-button gxg-button--scope-objects-change" }, this._componentLocale.options.changeBtn)), h("div", { class: "row" }, h("gxg-label", { labelPosition: "start", center: true, noMargin: true }, this._componentLocale.options.revision, ":"), h("span", { class: {
77
- bold: this.revisionScopeText !== undefined,
78
- value: true
79
- } }, this.revisionScopeText === undefined
80
- ? this._componentLocale.options.scopeData.revision.latest
81
- : this.revisionScopeText), h("gxg-text", { type: "text-link", onClick: this.revisionScope, part: "gxg-button gxg-button--scope-revision-change" }, this._componentLocale.options.changeBtn)), h("div", { class: "row" }, h("gxg-form-checkbox", { label: this._componentLocale.options.kbProperties, class: "align-center", part: "option-kb-properties" }))))));
82
- };
83
- this.renderFilter = () => {
84
- return (h("div", { class: {
85
- "filter-row": true
86
- } }, h("gxg-form-text", { "label-position": "start", centerLabel: true, label: this._componentLocale.filter.pattern, ref: (el) => (this.filterPatternEl = el), part: "filter-pattern", onInput: this.loadData, class: "combo" }), h("gxg-combo-box", { "label-position": "start", centerLabel: true, "disable-filter": true, label: this._componentLocale.filter.type, disabled: !this.types, ref: (el) => (this.filterTypeEl = el), onValueChanged: this.loadData, part: "filter-type", value: this.types[0].id, class: "combo" }, renderComboItems(this.types)), h("gxg-button", { type: "secondary-icon-only", icon: "gemini-tools/reset", onClick: this.loadData, part: "gxg-button gxg-button--reload", class: "button" })));
87
- };
88
- this.renderData = () => {
89
- return (h("gx-ide-container", { part: "data-container", noContentPadding: true, class: "gxi-overflow-auto", displayBorderTop: true }, h("gxg-tabs", { id: "dataTabs", part: "data-tabs" }, h("gxg-tab-bar", { slot: "tab-bar-container", displayBorder: true }, h("gxg-tab-button", { slot: "tab-bar", "tab-label": this._componentLocale.tabs.pendingForUpdate, tab: "pendingForUpdate", key: "pendingForUpdate", isSelected: true }), h("gxg-tab-button", { slot: "tab-bar", "tab-label": this._componentLocale.tabs.ignoredObjects, tab: "ignoredObjects", key: "ignoredObjects" }), h("gxg-tab-button", { slot: "tab-bar", "tab-label": this._componentLocale.tabs.results, tab: "results", key: "results", ref: (el) => (this.gxgTabButtonResultsEl = el) })), h("gxg-tab", { tab: "pendingForUpdate", key: "pendingForUpdate", noPadding: true, isSelected: true }, this.renderPendingForUpdate()), h("gxg-tab", { tab: "ignoredObjects", key: "ignoredObjects", noPadding: true }, this.renderIgnoredObjects()), h("gxg-tab", { tab: "results", key: "results", noPadding: true }, this.renderResults()))));
90
- };
91
- this.renderPendingForUpdate = () => {
92
- return (h("ch-tabular-grid", { class: "tabular-grid tabular-grid-pending-update", "row-selection-mode": "multiple", ref: (el) => (this.chGridPendingForUpdateEl = el), part: "ch-tabular-grid-pending-for-updates", onRowContextMenu: this.onRowContextMenuHandler("pending"), onSelectionChanged: this.gridOnSelectionChangedCallbackHandler("pending") }, h("ch-tabular-grid-columnset", { class: "tabular-grid-column-set" }, h("ch-tabular-grid-column", { settingable: false, sortable: false, "column-type": "rich", richRowSelector: true, richRowSelectorMode: "mark", size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { settingable: false, sortable: false, size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { settingable: false, sortable: false, size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.name, settingable: false, size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.type, settingable: false, size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.description, settingable: false, size: config.tabularGrid.colSize.commonDouble, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.modifiedOn, settingable: false, size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.status, settingable: false, size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.action, settingable: false, size: config.tabularGrid.colSize.maxContent, class: "tabular-grid-column" })), this.updateData.pendingForUpdate.map((obj) => (h("ch-tabular-grid-row", { rowid: obj.id, class: "tabular-grid-row" }, h("ch-tabular-grid-cell", { "cell-type": "rich", "row-selector": true, class: "tabular-grid-cell" }), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, h("ch-image", { src: obj.typeIcon, class: "icon-md" })), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, this.renderIconState(obj.state)), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.name), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.type), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.description), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, `${formatDate(obj.modifiedOn)}`), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.status), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.action))))));
93
- };
94
- this.renderIgnoredObjects = () => {
95
- return (h("ch-tabular-grid", { class: "tabular-grid", "row-selection-mode": "multiple", ref: (el) => (this.chGridIgnoredObjectsEl = el), part: "ch-grid-ignored-objects", onRowContextMenu: this.onRowContextMenuHandler("ignored"), onSelectionChanged: this.gridOnSelectionChangedCallbackHandler("ignored") }, h("ch-tabular-grid-columnset", { class: "tabular-grid-column-set" }, h("ch-tabular-grid-column", { settingable: false, sortable: false, size: "min-content", class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.name, settingable: false, size: "1fr", class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.type, settingable: false, size: "1fr", class: "tabular-grid-column" })), this.updateData.ignoredObjects.map((obj) => (h("ch-tabular-grid-row", { rowid: obj.id, class: "tabular-grid-row" }, h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, h("ch-image", { src: obj.typeIcon, class: "icon-md" })), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.name), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.type))))));
96
- };
97
- this.renderResults = () => {
98
- return (h("ch-tabular-grid", { class: "tabular-grid tabular-grid-results", "row-selection-mode": "multiple", ref: (el) => (this.chGridResultsEl = el), part: "ch-tabular-grid-results", onRowContextMenu: this.onRowContextMenuHandler("results"), onSelectionChanged: this.gridOnSelectionChangedCallbackHandler("results") }, h("ch-tabular-grid-columnset", { class: "tabular-grid-column-set" }, h("ch-tabular-grid-column", { settingable: false, sortable: false, "column-type": "tree", class: "tabular-grid-column" }), h("ch-tabular-grid-column", { settingable: false, sortable: false, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { settingable: false, sortable: false, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.name, settingable: false, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.type, settingable: false, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.description, settingable: false, class: "tabular-grid-column" }), h("ch-tabular-grid-column", { columnName: this._componentLocale.tableHead.notes, settingable: false, class: "tabular-grid-column" })), this.updateResultData.map((obj) => (h("ch-tabular-grid-row", { rowid: obj.id, class: "tabular-grid-row" }, h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, this.renderIconResult(obj.result)), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, h("ch-image", { src: obj.typeIcon, class: "icon-md" })), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, this.renderIconState(obj.state)), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.name), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.type), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.description), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, obj.notes), h("ch-tabular-grid-rowset", null, obj.messages.map(msg => {
99
- let msgType;
100
- switch (msg.type) {
101
- case "info":
102
- msgType = "text-alert-info";
103
- break;
104
- case "success":
105
- msgType = "text-alert-success";
106
- break;
107
- case "warning":
108
- msgType = "text-alert-warning";
109
- break;
110
- case "error":
111
- msgType = "text-alert-error";
112
- break;
113
- }
114
- return (h("ch-tabular-grid-rowset-empty", null, h("gxg-text", { type: msgType }, msg.text)));
115
- })))))));
116
- };
117
- this.renderIconState = (state) => {
118
- let type;
119
- switch (state) {
120
- case "Modified":
121
- type = "gx-server/changes-commit-pending";
122
- break;
123
- case "Inserted":
124
- type = "gx-server/new";
125
- break;
126
- case "Deleted":
127
- type = "gx-server/delete";
128
- break;
129
- case "Conflicted":
130
- type = "gx-server/conflict";
131
- break;
163
+ else if (action === "modified-with-conflicts") {
164
+ icon = WARNING_ICON;
165
+ caption = __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.modifyWithConflicts;
166
+ iconColor = "--mer-icon__warning";
132
167
  }
133
- return h("ch-image", { class: "icon-md", src: type });
134
- };
135
- this.renderIconResult = (result) => {
136
- let type;
137
- let color;
138
- switch (result) {
139
- case "info":
140
- type = "gemini-tools/notice";
141
- color = "primary-active";
142
- break;
143
- case "success":
144
- type = "gemini-tools/success";
145
- color = "success";
146
- break;
147
- case "warning":
148
- type = "gemini-tools/warning";
149
- color = "warning";
150
- break;
151
- case "error":
152
- type = "gemini-tools/error";
153
- color = "error";
154
- break;
168
+ else if (!action) {
169
+ // proably is "ignored"
170
+ return null;
155
171
  }
156
- return h("gxg-icon", { type: type, color: color });
157
- };
158
- this.loadData = async () => {
172
+ return (h("span", { class: "custom-icon-text-wrapper" }, h("ch-image", { type: "mask", class: "icon-md", src: icon, style: { backgroundColor: `var(${iconColor})` } }), `${caption}`));
173
+ });
174
+ _GxIdeTeamDevUpdate_updateSingleObject.set(this, objectId => async () => {
175
+ const newobjectsStatusMap = new Map(this.objectsStatusMap);
176
+ newobjectsStatusMap.set(objectId, "updating");
177
+ this.objectsStatusMap = newobjectsStatusMap;
178
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_updateObjectsHandler, "f").call(this, [objectId]);
179
+ });
180
+ _GxIdeTeamDevUpdate_renderObjectStatus.set(this, (objectId) => {
181
+ const status = this.objectsStatusMap.get(objectId);
182
+ const caption = status === "pending" && this.updatePillAsButton
183
+ ? __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").status.update
184
+ : __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").status[status];
185
+ if (status === "updating") {
186
+ return h("span", { class: "updating-spinner-caption" }, caption);
187
+ }
188
+ const classes = `pill pill--${status}`;
189
+ if (this.updatePillAsButton && status === "pending") {
190
+ return (h("button", { class: "button-secondary pill pill--update", onClick: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_updateSingleObject, "f").call(this, objectId) }, caption));
191
+ }
192
+ else {
193
+ return h("span", { class: classes }, caption);
194
+ }
195
+ });
196
+ _GxIdeTeamDevUpdate_renderRows.set(this, (type) => {
197
+ let objects;
198
+ if (type === "pending") {
199
+ objects = this.pendingObjectsAfterActionFilter;
200
+ }
201
+ else if (type === "ignored") {
202
+ objects = this.ignoredObjectsAfterActionFilter;
203
+ }
204
+ return objects.map(object => {
205
+ const objectType = {
206
+ id: object.id,
207
+ icon: object.typeIcon,
208
+ name: object.name
209
+ };
210
+ const alreadyUpdated = this.alreadyUpdatedObjectsIdsSet.has(object.id);
211
+ const hideCheckbox = alreadyUpdated || type === "ignored";
212
+ const marked = this.markedObjectsSet.has(object.id);
213
+ const messages = this.objectsMessagesDataMap.get(object.id);
214
+ return (h("ch-tabular-grid-row", { class: "tabular-grid-row", key: object.id, rowid: object.id, ref: (el) => marked && (el === null || el === void 0 ? void 0 : el.setAttribute("marked", "true")) }, h("ch-tabular-grid-cell", { "cell-type": "rich", "row-selector": "true", class: {
215
+ "tabular-grid-cell": true,
216
+ "no-checkbox-custom-selector": hideCheckbox
217
+ }, size: "max-content" }, object.name), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, renderObjectTypeWithIcon(objectType)), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, object.description), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, formatDate(object.modifiedOn)), h("ch-tabular-grid-cell", { class: "tabular-grid-cell" }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_renderActionCellContent, "f").call(this, object.action)), h("ch-tabular-grid-cell", { class: "tabular-grid-cell tabular-grid-cell--for-pill" }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_renderObjectStatus, "f").call(this, object.id)), (messages === null || messages === void 0 ? void 0 : messages.length) && (h("ch-tabular-grid-rowset", { class: "tabular-grid-rowset" }, h("ch-tabular-grid-rowset-empty", { class: {
218
+ "tabular-grid-rowset-empty": true
219
+ } }, h("ul", { class: "messages-list" }, messages.map(message => {
220
+ let MESSAGE_ICON;
221
+ if (message.type === "error") {
222
+ MESSAGE_ICON = ERROR_ICON;
223
+ }
224
+ else if (message.type === "warning") {
225
+ MESSAGE_ICON = WARNING_ICON;
226
+ }
227
+ else if (message.type === "success") {
228
+ MESSAGE_ICON = SUCCESS_ICON;
229
+ }
230
+ else {
231
+ // info
232
+ MESSAGE_ICON = INFO_ICON;
233
+ }
234
+ return (h("li", { class: "message-description" }, h("ch-image", { class: "icon-md message-icon", src: MESSAGE_ICON }), message.text));
235
+ })))))));
236
+ });
237
+ });
238
+ _GxIdeTeamDevUpdate_rowMarkingChangedHandler.set(this, async (event) => {
239
+ const markedRowsIds = event.detail.rowsId;
240
+ this.markedObjectsSet = new Set(markedRowsIds.filter(markedObjectId => !this.alreadyUpdatedObjectsIdsSet.has(markedObjectId)));
241
+ if (__classPrivateFieldGet(this, _GxIdeTeamDevUpdate_rowCheckedChangedByTheUser, "f")) {
242
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_updatePendingCheckedItems, "f").call(this, event);
243
+ }
244
+ });
245
+ _GxIdeTeamDevUpdate_updatePendingCheckedItems.set(this, async (event) => {
246
+ const addedRowsIds = event.detail.addedRowsId;
247
+ const removedRowsId = event.detail.removedRowsId;
248
+ const pendingItemCheckedResult = await this.pendingItemsCheckedCallback({
249
+ itemsChecked: addedRowsIds,
250
+ itemsUnchecked: removedRowsId
251
+ });
252
+ if (pendingItemCheckedResult === undefined) {
253
+ // undo check/uncheck
254
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_revertPendingCommitsCheckboxes, "f").call(this, addedRowsIds, removedRowsId);
255
+ }
256
+ else {
257
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_togglePendingCommitsCheckboxes, "f").call(this, pendingItemCheckedResult);
258
+ }
259
+ });
260
+ _GxIdeTeamDevUpdate_searchInputHandler.set(this, (event) => {
261
+ this.searchValue = event.detail;
262
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_loadData, "f").call(this);
263
+ });
264
+ // Local Methods Update
265
+ _GxIdeTeamDevUpdate_actionChangedHandler.set(this, (event) => {
266
+ this.selectedAction = event.detail;
267
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_loadData, "f").call(this);
268
+ });
269
+ _GxIdeTeamDevUpdate_typeChangedHandler.set(this, async (event) => {
270
+ this.selectedType = event.detail;
271
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_loadData, "f").call(this);
272
+ });
273
+ _GxIdeTeamDevUpdate_setInitialObjectsStatus.set(this, () => {
274
+ this.pendingAndIgnored.pendingForUpdate.forEach(pendingObject => {
275
+ var _a;
276
+ const status = (_a = pendingObject.status) !== null && _a !== void 0 ? _a : "pending";
277
+ this.objectsStatusMap.set(pendingObject.id, status);
278
+ if (status === "updated") {
279
+ this.alreadyUpdatedObjectsIdsSet.add(pendingObject.id);
280
+ }
281
+ });
282
+ this.pendingAndIgnored.ignoredObjects.forEach(ignoredObject => {
283
+ var _a;
284
+ const status = (_a = ignoredObject.status) !== null && _a !== void 0 ? _a : "ignored";
285
+ this.objectsStatusMap.set(ignoredObject.id, status);
286
+ });
287
+ });
288
+ _GxIdeTeamDevUpdate_loadData.set(this, async (forceLoad = false) => {
159
289
  const filters = {
160
- pattern: this.showFilter ? this.filterPatternEl.value : null,
161
- type: this.showFilter ? this.filterTypeEl.value : null
290
+ search: this.searchValue,
291
+ type: this.selectedType,
292
+ kbProperties: this.kbPropertiesChecked,
293
+ action: this.selectedAction
162
294
  };
163
- // this.updateData = null;
164
- this.isLoading = true;
165
- this.updateData = await this.loadCallback(filters);
166
- this.isLoading = false;
167
- if (!this.loadDataCalledFirstTime) {
168
- /* this allows checking the pending commits checkboxes on first load*/
169
- this.loadDataCalledFirstTime = true;
295
+ this.loading = true;
296
+ this.objectsMessagesDataMap.clear();
297
+ this.pendingAndIgnored = await this.loadCallback(filters, forceLoad);
298
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_setInitialObjectsStatus, "f").call(this);
299
+ this.loading = false;
300
+ // Is is required to mark/check all objects after loadCallback.
301
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_markPendingObjects, "f").call(this);
302
+ });
303
+ /**
304
+ * Marks all pending objects that have not been committed yet.
305
+ *
306
+ * Iterates through all pending object IDs and adds them to the marked objects set
307
+ * if they are not already in the committed objects set. This effectively identifies
308
+ * and marks all the pending objects that still need to be processed.
309
+ **/
310
+ _GxIdeTeamDevUpdate_markPendingObjects.set(this, () => {
311
+ for (const pendingId of this.pendingIdsSet) {
312
+ if (!this.alreadyUpdatedObjectsIdsSet.has(pendingId)) {
313
+ this.markedObjectsSet = new Set([...this.markedObjectsSet, pendingId]);
314
+ }
170
315
  }
171
- };
172
- this.update = async () => {
173
- if (this.updateCallback) {
174
- const pendingForUpdateMarked = await this.chGridPendingForUpdateEl.getMarkedRows();
175
- this.updateCallback(pendingForUpdateMarked).then((updateResultData) => {
176
- this.updateResultData = updateResultData;
177
- this.gxgTabButtonResultsEl.tabButtonClick();
316
+ });
317
+ _GxIdeTeamDevUpdate_applyClientFilter.set(this, () => {
318
+ // this.pendingObjectsAfterActionFilter = this.#filteredObjects(
319
+ // this.pendingAndIgnored.pendingForUpdate
320
+ // );
321
+ this.pendingObjectsAfterActionFilter =
322
+ this.pendingAndIgnored.pendingForUpdate;
323
+ // this.ignoredObjectsAfterActionFilter = this.#filteredObjects(
324
+ // this.pendingAndIgnored.ignoredObjects
325
+ // );
326
+ this.ignoredObjectsAfterActionFilter =
327
+ this.pendingAndIgnored.ignoredObjects;
328
+ });
329
+ // #filteredObjects = (objects: ModifiedObject[]): ModifiedObject[] => {
330
+ // let filtered = objects;
331
+ // // name or description
332
+ // if (this.searchValue.length) {
333
+ // filtered = filtered.filter(object => {
334
+ // const nameFiltered = object.name
335
+ // .toLowerCase()
336
+ // .includes(this.searchValue.toLowerCase());
337
+ // const descriptionFiltered = object.description
338
+ // .toLowerCase()
339
+ // .includes(this.searchValue.toLowerCase());
340
+ // return nameFiltered || descriptionFiltered;
341
+ // });
342
+ // }
343
+ // return filtered;
344
+ // };
345
+ _GxIdeTeamDevUpdate_onRowContextMenuHandler.set(this, () => async (ev) => {
346
+ ev.preventDefault();
347
+ ev.stopPropagation();
348
+ const selection = await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").getSelectedRows();
349
+ const selectedRowId = (await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").getSelectedCell()).rowId;
350
+ const source = this.pendingIdsSet.has(selectedRowId)
351
+ ? "pending"
352
+ : "ignored";
353
+ let filteredSelection = [];
354
+ // remove selected rows from the other source, if any.
355
+ if (selection.length > 1 && source === "pending") {
356
+ selection.forEach(async (selectedRowId) => {
357
+ if (this.ignoredIdsSet.has(selectedRowId)) {
358
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").selectRow(selectedRowId, false);
359
+ }
360
+ else {
361
+ filteredSelection.push(selectedRowId);
362
+ }
178
363
  });
179
364
  }
180
- };
181
- this.objectsScope = () => {
182
- if (this.objectsScopeCallback) {
183
- this.objectsScopeCallback().then(objectData => {
184
- if (objectData) {
185
- this.objectScopeText = objectData;
365
+ else if (selection.length > 1 && source === "ignored") {
366
+ selection.forEach(async (selectedRowId) => {
367
+ if (this.pendingIdsSet.has(selectedRowId)) {
368
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").selectRow(selectedRowId, false);
369
+ }
370
+ else {
371
+ filteredSelection.push(selectedRowId);
186
372
  }
187
373
  });
188
374
  }
189
- };
190
- this.revisionScope = () => {
191
- if (this.revisionScopeCallback) {
192
- this.revisionScopeCallback().then(revisionData => {
193
- this.revisionScopeText = revisionData;
194
- });
375
+ else {
376
+ filteredSelection = selection;
195
377
  }
196
- };
197
- this.pendingForUpdatesRowMarkingChangedHandler = async (e) => {
198
- // remove "rowMarkingChanged" until checkboxes have been added/removed on togglePendingCommitsCheckboxes, to prevent loops.
199
- this.chGridPendingForUpdateEl.removeEventListener("rowMarkingChanged", this.pendingForUpdatesRowMarkingChangedHandler);
200
- if (this.chGridPendingForUpdateEl) {
201
- const addedRowsIds = e.detail.addedRowsId;
202
- const removedRowsId = e.detail.removedRowsId;
203
- const pendingItemCheckedResult = await this.pendingItemsCheckedCallback({
204
- itemsChecked: addedRowsIds,
205
- itemsUnchecked: removedRowsId
206
- });
207
- if (pendingItemCheckedResult === undefined) {
208
- // undo check/uncheck
209
- await this.revertPendingCommitsCheckboxes(addedRowsIds, removedRowsId);
378
+ await this.contextMenuCallback(source, {
379
+ selection: filteredSelection,
380
+ clientX: ev.detail.clientX,
381
+ clientY: ev.detail.clientY
382
+ });
383
+ });
384
+ _GxIdeTeamDevUpdate_revertPendingCommitsCheckboxes.set(this, async (addedRowsIds, removedRowsId) => {
385
+ if (__classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f")) {
386
+ for (const rowId of addedRowsIds) {
387
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").markRow(rowId, false);
210
388
  }
211
- else {
212
- await this.togglePendingCommitsCheckboxes(pendingItemCheckedResult);
389
+ for (const rowId of removedRowsId) {
390
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").markRow(rowId, true);
213
391
  }
214
- this.chGridPendingForUpdateEl.addEventListener("rowMarkingChanged", this.pendingForUpdatesRowMarkingChangedHandler);
215
392
  }
216
- this.chGridPendingForUpdateEl.addEventListener("rowMarkingChanged", this.pendingForUpdatesRowMarkingChangedHandler);
217
- };
218
- this.togglePendingCommitsCheckboxes = async (itemsToToggle) => {
219
- if (this.chGridPendingForUpdateEl) {
393
+ });
394
+ _GxIdeTeamDevUpdate_togglePendingCommitsCheckboxes.set(this, async (itemsToToggle) => {
395
+ if (__classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f")) {
220
396
  const itemsToCheck = itemsToToggle.itemsToCheck;
221
397
  const itemsToUncheck = itemsToToggle.itemsToUncheck;
222
398
  // check
223
399
  for (const rowId of itemsToCheck) {
224
- await this.chGridPendingForUpdateEl.markRow(rowId, true);
400
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").markRow(rowId, true);
225
401
  }
226
402
  // uncheck
227
403
  for (const rowId of itemsToUncheck) {
228
- await this.chGridPendingForUpdateEl.markRow(rowId, false);
404
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, "f").markRow(rowId, false);
229
405
  }
230
406
  }
231
- };
232
- this.revertPendingCommitsCheckboxes = async (addedRowsIds, removedRowsId) => {
233
- if (this.chGridPendingForUpdateEl) {
234
- for (const rowId of addedRowsIds) {
235
- await this.chGridPendingForUpdateEl.markRow(rowId, false);
236
- }
237
- for (const rowId of removedRowsId) {
238
- await this.chGridPendingForUpdateEl.markRow(rowId, true);
239
- }
240
- }
241
- };
242
- this.isLoading = false;
243
- this.objectScopeText = "all";
244
- this.openTab = "pending";
245
- this.revisionScopeText = undefined;
246
- this.showFilter = false;
247
- this.updateData = {
407
+ });
408
+ _GxIdeTeamDevUpdate_kbPropertiesChangedHandler.set(this, (event) => {
409
+ this.kbPropertiesChecked = event.detail === CHECKBOX_CHECKED_VALUE;
410
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_loadData, "f").call(this, true);
411
+ });
412
+ this.atLeastOneObjectIsChecked = false;
413
+ this.loading = true;
414
+ this.menuContextAction = undefined;
415
+ this.searchValue = "";
416
+ this.selectedAction = "all-actions";
417
+ this.markedObjectsSet = new Set([]);
418
+ this.alreadyUpdatedObjectsIdsSet = new Set([]);
419
+ this.pendingIdsSet = new Set([]);
420
+ this.ignoredIdsSet = new Set([]);
421
+ this.objectsMessagesDataMap = new Map();
422
+ this.updating = false;
423
+ this.kbPropertiesChecked = false;
424
+ this.typesComboBoxModel = undefined;
425
+ this.selectedType = undefined;
426
+ this.objectsStatusMap = new Map();
427
+ this.contextMenuCallback = undefined;
428
+ this.pendingAndIgnored = {
248
429
  pendingForUpdate: [],
249
430
  ignoredObjects: []
250
431
  };
251
- this.updateResultData = [];
252
- this.displayTitle = false;
253
- this.confirmCallback = undefined;
254
- this.gridContextMenuCallback = undefined;
432
+ this.pendingObjectsAfterActionFilter = [];
433
+ this.ignoredObjectsAfterActionFilter = [];
255
434
  this.loadCallback = undefined;
256
- this.objectsScopeCallback = undefined;
257
- this.openServerCallback = undefined;
258
435
  this.pendingItemsCheckedCallback = undefined;
259
- this.revisionScopeCallback = undefined;
260
- this.objectsContextMenuCallback = undefined;
261
- this.selectCallback = undefined;
262
436
  this.types = undefined;
437
+ this.updatePillAsButton = false;
263
438
  this.updateCallback = undefined;
439
+ this.openServerCallback = undefined;
264
440
  this.updateFrom = undefined;
265
441
  }
266
- // 6.COMPONENT LIFECYCLE EVENTS //
442
+ markedObjectsSetChanged(newMarkedObjectsSet) {
443
+ this.atLeastOneObjectIsChecked = newMarkedObjectsSet.size > 0;
444
+ }
445
+ objectsStatusMapChanged(newObjectsStatusMap) {
446
+ const someObjectIsUpdating = [...newObjectsStatusMap.entries()].find(([, state]) => state === "updating");
447
+ if (!someObjectIsUpdating) {
448
+ this.updating = false;
449
+ }
450
+ }
451
+ pendingAndIgnoredChanged() {
452
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_applyClientFilter, "f").call(this);
453
+ this.pendingIdsSet.clear();
454
+ this.pendingAndIgnored.pendingForUpdate.forEach(pending => {
455
+ this.pendingIdsSet.add(pending.id);
456
+ });
457
+ this.ignoredIdsSet.clear();
458
+ this.pendingAndIgnored.ignoredObjects.forEach(ignored => {
459
+ this.ignoredIdsSet.add(ignored.id);
460
+ });
461
+ }
267
462
  async componentWillLoad() {
268
- this._componentLocale = await Locale.getComponentStrings(this.el);
269
- this.componentDidLoadEvent.emit(true);
463
+ var _a;
464
+ __classPrivateFieldSet(this, _GxIdeTeamDevUpdate_componentLocale, await Locale.getComponentStrings(this.el), "f");
465
+ // Initiate "actions" combo box filter
466
+ __classPrivateFieldSet(this, _GxIdeTeamDevUpdate_actionsComboBoxModel, [
467
+ {
468
+ caption: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.allActions,
469
+ value: "all-actions"
470
+ },
471
+ {
472
+ caption: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.insert,
473
+ value: "inserted"
474
+ },
475
+ {
476
+ caption: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.modify,
477
+ value: "modified"
478
+ },
479
+ {
480
+ caption: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.modifyWithConflicts,
481
+ value: "modified-with-conflicts"
482
+ },
483
+ {
484
+ caption: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").actions.delete,
485
+ value: "deleted"
486
+ }
487
+ ], "f");
488
+ // Set type initial value
489
+ this.selectedType = (_a = this.types[0]) === null || _a === void 0 ? void 0 : _a.id;
490
+ this.typesComboBoxModel = mapObjectTypeToComboBoxItemModel(this.types);
270
491
  }
271
492
  async componentDidLoad() {
272
- await this.loadData();
273
- this.filterPatternEl.focus();
274
- }
275
- async componentDidRender() {
276
- if (!this.renderedFirstTime) {
277
- this.componentDidRenderFirstTime.emit(this._componentLocale.componentName);
278
- this.renderedFirstTime = true;
279
- }
280
- if (this.loadDataCalledFirstTime) {
281
- // call this method only once
282
- await this.markAllPendingToUpdateRows();
283
- // attach "rowMarkingChanged" after rows have been checked for the first time.
284
- this.chGridPendingForUpdateEl.addEventListener("rowMarkingChanged", this.pendingForUpdatesRowMarkingChangedHandler);
285
- this.loadDataCalledFirstTime = false;
286
- }
493
+ await __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_loadData, "f").call(this, true);
287
494
  }
288
- // 7.LISTENERS //
289
- // 8.PUBLIC METHODS API //
290
495
  /**
291
- * The method used by the host to instruct the component to force a data reload in the grids.
496
+ * Used by the host to instruct the component to force a data reload in the grids.
292
497
  */
293
498
  async reload() {
294
- this.loadData();
499
+ __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_loadData, "f").call(this, true);
295
500
  }
296
- // 10.RENDER() FUNCTION //
297
501
  render() {
298
- return (h(Host, { class: "gx-ide-component" }, h("ch-theme", { model: CSS_BUNDLES }), h("div", { class: "gx-ide-main-wrapper" }, h("gx-ide-container", { displayBorderTop: true, noContentPadding: true, slimmerFooter: config.gxIdeContainer.slimmerFooter, containerTitle: this.displayTitle ? this._componentLocale.componentName : null }, this.renderOptions(), this.renderFilter(), this.renderData(), h("gxg-button", { id: "button-update", type: "primary-text-only", onClick: this.update, part: "gxg-button gxg-button--update", disabled: this.isLoading, slot: "footer-end" }, this._componentLocale.footer.btnUpdate)))));
502
+ const enableRichRowSelector = true;
503
+ const disableControls = this.updating || this.loading;
504
+ const gridIsEmpty = this.pendingObjectsAfterActionFilter.length === 0 &&
505
+ this.ignoredObjectsAfterActionFilter.length === 0;
506
+ return (h(Host, { class: "widget" }, h("ch-theme", { model: CSS_BUNDLES }), h("section", { class: "section" }, h("header", { class: "header spacing-body-inline spacing-body-block-start" }, h("div", {
507
+ // header details
508
+ class: "header__detail header__detail-1"
509
+ }, h("p", { class: "detail__heading-genexus-server subtitle-semi-bold-s" }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").commitDetail.title), h("div", {
510
+ // genexus server
511
+ class: "detail__genexus-server field field-block"
512
+ }, h("span", { class: DETAIL_LABEL_CLASSES }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").commitDetail.genexusServer), h("button", { class: "detail__link body-regular-s", onClick: this.openServerCallback }, this.updateFrom ? this.updateFrom.serverUrl : "")), h("div", {
513
+ // knowledge base
514
+ class: "detail__knowledge-base field field-block"
515
+ }, h("span", { class: DETAIL_LABEL_CLASSES }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").commitDetail.knowledgeBase), h("p", { class: "body-regular-s" }, this.updateFrom ? this.updateFrom.kbName : "")), h("div", {
516
+ // version
517
+ class: "detail__version field field-block"
518
+ }, h("span", { class: DETAIL_LABEL_CLASSES }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").commitDetail.version), h("p", { class: "body-regular-s" }, this.updateFrom ? this.updateFrom.versionName : "")), h("div", {
519
+ // last full update
520
+ class: "detail__last-full-update field field-block"
521
+ }, h("span", { class: DETAIL_LABEL_CLASSES }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").commitDetail.lastFullUpdate), h("p", { class: "body-regular-s" }, formatDate(this.updateFrom.lastFullUpdate))))), h("div", { class: "filter-container spacing-body-inline" }, h("div", { class: "filter" }, h("ch-edit", {
522
+ // search
523
+ class: "input filter__search", disabled: disableControls, startImgSrc: SEARCH_ICON, accessibleName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.searchAccessibleName, placeholder: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.searchPlaceholder, type: "search", onInput: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_searchInputHandler, "f"), debounce: config.inputDebounce
524
+ }), h("ch-combo-box-render", {
525
+ // types
526
+ class: "combo-box filter__types", disabled: disableControls, model: this.typesComboBoxModel, value: this.selectedType, accessibleName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.typeAccesibleName, placeholder: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.typePlaceholder, onInput: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_typeChangedHandler, "f")
527
+ }), h("ch-combo-box-render", {
528
+ // actions
529
+ class: "combo-box filter__actions", disabled: disableControls, model: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_actionsComboBoxModel, "f"), value: this.selectedAction, onInput: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_actionChangedHandler, "f"), accessibleName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.actionAccesibleName, placeholder: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.actionPlaceholder
530
+ }), h("ch-checkbox", {
531
+ // kb properties
532
+ class: "checkbox filter__kb-properties", caption: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.kbProperties, checkedValue: CHECKBOX_CHECKED_VALUE, value: CHECKBOX_UNCHECKED_VALUE, onInput: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_kbPropertiesChangedHandler, "f"), disabled: disableControls
533
+ }), h("div", { class: "buttons-spacer filter__buttons" }, h("button", {
534
+ // reload button
535
+ class: "button-secondary button-icon-and-text", disabled: disableControls, onClick: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_reloadClickedHandler, "f")
536
+ }, h("ch-image", { class: "icon-md", src: REFRESH_ICON }), __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.reload), h("button", {
537
+ // update button
538
+ class: "button-primary button-update", disabled: !this.atLeastOneObjectIsChecked || disableControls, onClick: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_updateCheckedClickedHandler, "f")
539
+ }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").filter.update)))), h("div", { class: "main spacing-body" }, !this.loading ? (h("ch-tabular-grid", { class: {
540
+ "tabular-grid": true,
541
+ "objects-tabular-grid": true,
542
+ "disabled-custom-selector": this.updating,
543
+ "empty-result": gridIsEmpty
544
+ }, keyboardNavigationMode: "focus", rowSelectionMode: "multiple", onRowMarkingChanged: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_rowMarkingChangedHandler, "f"), onRowContextMenu: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_onRowContextMenuHandler, "f").call(this), ref: (el) => (__classPrivateFieldSet(this, _GxIdeTeamDevUpdate_chGridPendingForUpdateEl, el, "f")) }, h("ch-tabular-grid-columnset", { class: "tabular-grid-column-set" }, h("ch-tabular-grid-column", { class: "tabular-grid-column", columnId: "name", columnName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.name, columnType: "rich", richRowSelector: enableRichRowSelector, richRowSelectorMode: "mark", settingable: false, size: "max-content" }), h("ch-tabular-grid-column", { class: "tabular-grid-column", columnId: "type", columnName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.type, settingable: false, size: "max-content" }), h("ch-tabular-grid-column", { class: "tabular-grid-column", columnId: "description", columnName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.description, settingable: false, size: config.tabularGrid.colSize.description }), h("ch-tabular-grid-column", { class: "tabular-grid-column", columnId: "modified-on", columnName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.modifiedOn, settingable: false, size: "max-content" }), h("ch-tabular-grid-column", { class: "tabular-grid-column", columnId: "action", columnName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.action, settingable: false, size: "max-content" }), h("ch-tabular-grid-column", {
545
+ // size of this column should the enough for the largest pill, and no more.
546
+ // this prevents layout shifts when pills state changes.
547
+ class: "tabular-grid-column", columnId: "status", columnName: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.status, settingable: false, size: "100px"
548
+ })), !gridIsEmpty
549
+ ? [
550
+ h("ch-tabular-grid-rowset", { class: "tabular-grid-rowset" }, h("ch-tabular-grid-rowset-legend", { class: "tabular-grid-rowset-legend" }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.pending), __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_renderRows, "f").call(this, "pending")),
551
+ h("ch-tabular-grid-rowset", { class: "tabular-grid-rowset" }, h("ch-tabular-grid-rowset-legend", { class: "tabular-grid-rowset-legend" }, __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").objects.ignored), __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_renderRows, "f").call(this, "ignored"))
552
+ ]
553
+ : null, h("ch-tabular-grid-rowset", { class: "tabular-grid-rowset" }, gridIsEmpty && (h("ch-tabular-grid-rowset-empty", null, h("gx-ide-empty-state", { class: "empty-state", isAnimated: true, stateIconSrc: FILTER_ICON, stateTitle: "No object matched your filter" })))))) : (h("gx-ide-loader", { cancelLabel: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").loader.cancelLabel, loaderTitle: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").loader.title, description: __classPrivateFieldGet(this, _GxIdeTeamDevUpdate_componentLocale, "f").loader.description, show: true, class: "loader" }))))));
299
554
  }
300
555
  static get assetsDirs() { return ["gx-ide-assets/team-dev-update"]; }
301
556
  get el() { return this; }
557
+ static get watchers() { return {
558
+ "markedObjectsSet": ["markedObjectsSetChanged"],
559
+ "objectsStatusMap": ["objectsStatusMapChanged"],
560
+ "pendingAndIgnored": ["pendingAndIgnoredChanged"]
561
+ }; }
302
562
  static get style() { return updateCss; }
303
563
  }, [1, "gx-ide-team-dev-update", {
304
- "displayTitle": [4, "display-title"],
305
- "confirmCallback": [16],
306
- "gridContextMenuCallback": [16],
564
+ "contextMenuCallback": [16],
307
565
  "loadCallback": [16],
308
- "objectsScopeCallback": [16],
309
- "openServerCallback": [16],
310
566
  "pendingItemsCheckedCallback": [16],
311
- "revisionScopeCallback": [16],
312
- "objectsContextMenuCallback": [16],
313
- "selectCallback": [16],
314
567
  "types": [16],
568
+ "updatePillAsButton": [4, "update-pill-as-button"],
315
569
  "updateCallback": [16],
570
+ "openServerCallback": [16],
316
571
  "updateFrom": [16],
317
- "isLoading": [32],
318
- "objectScopeText": [32],
319
- "openTab": [32],
320
- "revisionScopeText": [32],
321
- "showFilter": [32],
322
- "updateData": [32],
323
- "updateResultData": [32],
572
+ "atLeastOneObjectIsChecked": [32],
573
+ "loading": [32],
574
+ "menuContextAction": [32],
575
+ "searchValue": [32],
576
+ "selectedAction": [32],
577
+ "markedObjectsSet": [32],
578
+ "alreadyUpdatedObjectsIdsSet": [32],
579
+ "pendingIdsSet": [32],
580
+ "ignoredIdsSet": [32],
581
+ "objectsMessagesDataMap": [32],
582
+ "updating": [32],
583
+ "kbPropertiesChecked": [32],
584
+ "typesComboBoxModel": [32],
585
+ "selectedType": [32],
586
+ "objectsStatusMap": [32],
587
+ "pendingAndIgnored": [32],
588
+ "pendingObjectsAfterActionFilter": [32],
589
+ "ignoredObjectsAfterActionFilter": [32],
324
590
  "reload": [64]
591
+ }, undefined, {
592
+ "markedObjectsSet": ["markedObjectsSetChanged"],
593
+ "objectsStatusMap": ["objectsStatusMapChanged"],
594
+ "pendingAndIgnored": ["pendingAndIgnoredChanged"]
325
595
  }]);
596
+ _GxIdeTeamDevUpdate_componentLocale = new WeakMap(), _GxIdeTeamDevUpdate_actionsComboBoxModel = new WeakMap(), _GxIdeTeamDevUpdate_rowCheckedChangedByTheUser = new WeakMap(), _GxIdeTeamDevUpdate_chGridPendingForUpdateEl = new WeakMap(), _GxIdeTeamDevUpdate_updateCheckedClickedHandler = new WeakMap(), _GxIdeTeamDevUpdate_reloadClickedHandler = new WeakMap(), _GxIdeTeamDevUpdate_updateObjectsHandler = new WeakMap(), _GxIdeTeamDevUpdate_renderActionCellContent = new WeakMap(), _GxIdeTeamDevUpdate_updateSingleObject = new WeakMap(), _GxIdeTeamDevUpdate_renderObjectStatus = new WeakMap(), _GxIdeTeamDevUpdate_renderRows = new WeakMap(), _GxIdeTeamDevUpdate_rowMarkingChangedHandler = new WeakMap(), _GxIdeTeamDevUpdate_updatePendingCheckedItems = new WeakMap(), _GxIdeTeamDevUpdate_searchInputHandler = new WeakMap(), _GxIdeTeamDevUpdate_actionChangedHandler = new WeakMap(), _GxIdeTeamDevUpdate_typeChangedHandler = new WeakMap(), _GxIdeTeamDevUpdate_setInitialObjectsStatus = new WeakMap(), _GxIdeTeamDevUpdate_loadData = new WeakMap(), _GxIdeTeamDevUpdate_markPendingObjects = new WeakMap(), _GxIdeTeamDevUpdate_applyClientFilter = new WeakMap(), _GxIdeTeamDevUpdate_onRowContextMenuHandler = new WeakMap(), _GxIdeTeamDevUpdate_revertPendingCommitsCheckboxes = new WeakMap(), _GxIdeTeamDevUpdate_togglePendingCommitsCheckboxes = new WeakMap(), _GxIdeTeamDevUpdate_kbPropertiesChangedHandler = new WeakMap();
326
597
  function defineCustomElement$1() {
327
598
  if (typeof customElements === "undefined") {
328
599
  return;
329
600
  }
330
- const components = ["gx-ide-team-dev-update", "gx-ide-container", "gx-ide-list-selector", "gx-ide-list-selector-item", "gx-ide-title"];
601
+ const components = ["gx-ide-team-dev-update", "gx-ide-empty-state", "gx-ide-loader"];
331
602
  components.forEach(tagName => { switch (tagName) {
332
603
  case "gx-ide-team-dev-update":
333
604
  if (!customElements.get(tagName)) {
334
605
  customElements.define(tagName, GxIdeTeamDevUpdate$1);
335
606
  }
336
607
  break;
337
- case "gx-ide-container":
338
- if (!customElements.get(tagName)) {
339
- defineCustomElement$5();
340
- }
341
- break;
342
- case "gx-ide-list-selector":
343
- if (!customElements.get(tagName)) {
344
- defineCustomElement$4();
345
- }
346
- break;
347
- case "gx-ide-list-selector-item":
608
+ case "gx-ide-empty-state":
348
609
  if (!customElements.get(tagName)) {
349
610
  defineCustomElement$3();
350
611
  }
351
612
  break;
352
- case "gx-ide-title":
613
+ case "gx-ide-loader":
353
614
  if (!customElements.get(tagName)) {
354
615
  defineCustomElement$2();
355
616
  }