@genexus/genexus-ide-ui 1.0.18 → 1.0.20

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 (372) hide show
  1. package/dist/cjs/{assets-manager-4b67360e.js → assets-manager-a318866f.js} +31 -31
  2. package/dist/cjs/{assets-manager-4b67360e.js.map → assets-manager-a318866f.js.map} +1 -1
  3. package/dist/cjs/{form-validation-df39cabb.js → form-validation-0019e158.js} +2 -2
  4. package/dist/cjs/form-validation-0019e158.js.map +1 -0
  5. package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
  6. package/dist/cjs/gx-ide-ai-message.cjs.entry.js +2 -2
  7. package/dist/cjs/gx-ide-ai-message.cjs.entry.js.map +1 -1
  8. package/dist/cjs/gx-ide-connect-gx-server.cjs.entry.js +1 -1
  9. package/dist/cjs/gx-ide-create-kb-from-server.cjs.entry.js +1 -1
  10. package/dist/cjs/gx-ide-dashboard-home.cjs.entry.js +2 -2
  11. package/dist/cjs/gx-ide-data-selector.cjs.entry.js +3 -2
  12. package/dist/cjs/gx-ide-data-selector.cjs.entry.js.map +1 -1
  13. package/dist/cjs/{gx-ide-empty-state_2.cjs.entry.js → gx-ide-empty-state.cjs.entry.js} +3 -56
  14. package/dist/cjs/gx-ide-empty-state.cjs.entry.js.map +1 -0
  15. package/dist/cjs/gx-ide-entity-selector.cjs.entry.js +3 -3
  16. package/dist/cjs/gx-ide-entity-selector.cjs.entry.js.map +1 -1
  17. package/dist/cjs/gx-ide-kb-manager-export.cjs.entry.js +7 -4
  18. package/dist/cjs/gx-ide-kb-manager-export.cjs.entry.js.map +1 -1
  19. package/dist/cjs/gx-ide-kb-manager-import.cjs.entry.js +1 -1
  20. package/dist/cjs/gx-ide-list-selector_2.cjs.entry.js +4 -27
  21. package/dist/cjs/gx-ide-list-selector_2.cjs.entry.js.map +1 -1
  22. package/dist/cjs/gx-ide-loader.cjs.entry.js +61 -0
  23. package/dist/cjs/gx-ide-loader.cjs.entry.js.map +1 -0
  24. package/dist/cjs/gx-ide-manage-module-references-v2.cjs.entry.js +1 -1
  25. package/dist/cjs/gx-ide-manage-module-references.cjs.entry.js +1 -1
  26. package/dist/cjs/gx-ide-navigation-report.cjs.entry.js +228 -0
  27. package/dist/cjs/gx-ide-navigation-report.cjs.entry.js.map +1 -0
  28. package/dist/cjs/gx-ide-new-environment.cjs.entry.js +4 -3
  29. package/dist/cjs/gx-ide-new-environment.cjs.entry.js.map +1 -1
  30. package/dist/cjs/gx-ide-new-kb.cjs.entry.js +9 -8
  31. package/dist/cjs/gx-ide-new-kb.cjs.entry.js.map +1 -1
  32. package/dist/cjs/gx-ide-new-object.cjs.entry.js +4 -3
  33. package/dist/cjs/gx-ide-new-object.cjs.entry.js.map +1 -1
  34. package/dist/cjs/gx-ide-object-selector.cjs.entry.js +7 -6
  35. package/dist/cjs/gx-ide-object-selector.cjs.entry.js.map +1 -1
  36. package/dist/cjs/gx-ide-share-kb.cjs.entry.js +1 -1
  37. package/dist/cjs/gx-ide-splash.cjs.entry.js +76 -0
  38. package/dist/cjs/gx-ide-splash.cjs.entry.js.map +1 -0
  39. package/dist/cjs/gx-ide-start-page.cjs.entry.js +2645 -105
  40. package/dist/cjs/gx-ide-start-page.cjs.entry.js.map +1 -1
  41. package/dist/cjs/gx-ide-status-buttons.cjs.entry.js +35 -17
  42. package/dist/cjs/gx-ide-status-buttons.cjs.entry.js.map +1 -1
  43. package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js +1 -1
  44. package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js +1 -1
  45. package/dist/cjs/gx-ide-welcome-page.cjs.entry.js +257 -0
  46. package/dist/cjs/gx-ide-welcome-page.cjs.entry.js.map +1 -0
  47. package/dist/cjs/gx-ide-ww-images.cjs.entry.js +396 -279
  48. package/dist/cjs/gx-ide-ww-images.cjs.entry.js.map +1 -1
  49. package/dist/cjs/{helpers-b5b4a659.js → helpers-19194a5a.js} +1 -7
  50. package/dist/{genexus-ide-ui/p-c339f703.js.map → cjs/helpers-19194a5a.js.map} +1 -1
  51. package/dist/cjs/loader.cjs.js +1 -1
  52. package/dist/collection/collection-manifest.json +4 -2
  53. package/dist/collection/common/form-validation.js +1 -1
  54. package/dist/collection/common/form-validation.js.map +1 -1
  55. package/dist/collection/components/_helpers/entity-selector/entity-selector.css +2 -2
  56. package/dist/collection/components/_helpers/entity-selector/entity-selector.js +1 -1
  57. package/dist/collection/components/_helpers/entity-selector/entity-selector.js.map +1 -1
  58. package/dist/collection/components/_helpers/ide-loader/ide-loader.css +4 -1
  59. package/dist/collection/components/_helpers/ide-loader/ide-loader.js +2 -2
  60. package/dist/collection/components/_helpers/ide-loader/ide-loader.js.map +1 -1
  61. package/dist/collection/components/_helpers/list-selector/list-selector-item/list-selector-item.css +19 -332
  62. package/dist/collection/components/_helpers/list-selector/list-selector-item/list-selector-item.js +2 -64
  63. package/dist/collection/components/_helpers/list-selector/list-selector-item/list-selector-item.js.map +1 -1
  64. package/dist/collection/components/_helpers/list-selector/list-selector.css +11 -9
  65. package/dist/collection/components/_helpers/list-selector/list-selector.js +2 -75
  66. package/dist/collection/components/_helpers/list-selector/list-selector.js.map +1 -1
  67. package/dist/collection/components/_helpers/status-buttons/gx-ide-status-buttons.css +20 -61
  68. package/dist/collection/components/_helpers/status-buttons/gx-ide-status-buttons.js +34 -17
  69. package/dist/collection/components/_helpers/status-buttons/gx-ide-status-buttons.js.map +1 -1
  70. package/dist/collection/components/ai-assistant/ai-message.css +1 -1
  71. package/dist/collection/components/data-selector/data-selector.js +2 -1
  72. package/dist/collection/components/data-selector/data-selector.js.map +1 -1
  73. package/dist/collection/components/kb-manager-export/kb-manager-export.js +6 -3
  74. package/dist/collection/components/kb-manager-export/kb-manager-export.js.map +1 -1
  75. package/dist/collection/components/navigation-report/gx-ide-assets/navigation-report/langs/navigation-report.lang.en.json +6 -0
  76. package/dist/collection/components/navigation-report/gx-ide-assets/navigation-report/langs/navigation-report.lang.ja.json +3 -0
  77. package/dist/collection/components/navigation-report/helpers.js +17 -0
  78. package/dist/collection/components/navigation-report/helpers.js.map +1 -0
  79. package/dist/collection/components/navigation-report/navigation-report.css +75 -0
  80. package/dist/collection/components/navigation-report/navigation-report.js +407 -0
  81. package/dist/collection/components/navigation-report/navigation-report.js.map +1 -0
  82. package/dist/collection/components/new-environment/new-environment.js +2 -1
  83. package/dist/collection/components/new-environment/new-environment.js.map +1 -1
  84. package/dist/collection/components/new-kb/new-kb.js +7 -6
  85. package/dist/collection/components/new-kb/new-kb.js.map +1 -1
  86. package/dist/collection/components/new-object/new-object.js +4 -3
  87. package/dist/collection/components/new-object/new-object.js.map +1 -1
  88. package/dist/collection/components/object-selector/object-selector.js +5 -4
  89. package/dist/collection/components/object-selector/object-selector.js.map +1 -1
  90. package/dist/collection/components/splash/gx-ide-assets/splash/images/copyrights-illustration.png +0 -0
  91. package/dist/collection/components/splash/gx-ide-assets/splash/images/icon-next.svg +4 -0
  92. package/dist/collection/components/splash/gx-ide-assets/splash/langs/splash.lang.en.json +14 -0
  93. package/dist/collection/components/splash/gx-ide-assets/splash/langs/splash.lang.ja.json +13 -0
  94. package/dist/collection/components/splash/gx-ide-assets/splash/langs/splash.lang.zh.json +13 -0
  95. package/dist/collection/components/splash/splash.css +56 -0
  96. package/dist/collection/components/splash/splash.js +125 -0
  97. package/dist/collection/components/splash/splash.js.map +1 -0
  98. package/dist/collection/components/start-page/gx-ide-assets/start-page/langs/start-page.lang.en.json +19 -27
  99. package/dist/collection/components/start-page/gx-ide-assets/start-page/langs/start-page.lang.ja.json +18 -26
  100. package/dist/collection/components/start-page/gx-ide-assets/start-page/langs/start-page.lang.zh.json +23 -1
  101. package/dist/collection/components/start-page/start-page.css +142 -624
  102. package/dist/collection/components/start-page/start-page.js +198 -181
  103. package/dist/collection/components/start-page/start-page.js.map +1 -1
  104. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/arrow-next.svg +3 -0
  105. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/copyrights-base.svg +61 -0
  106. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/copyrights-illustration.png +0 -0
  107. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/fig-ellipse-blurred.svg +21 -0
  108. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/fig-ellipse-bottom-left.svg +14 -0
  109. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/fig-ellipse-top-left.svg +14 -0
  110. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/fig-polygon.svg +14 -0
  111. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/icon-next.svg +4 -0
  112. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/slide-1.svg +115 -0
  113. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/slide-2.svg +67 -0
  114. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/slide-3.svg +138 -0
  115. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/slide-4.svg +97 -0
  116. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/images/slide-5.svg +83 -0
  117. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/langs/welcome-page.lang.en.json +13 -0
  118. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/langs/welcome-page.lang.ja.json +13 -0
  119. package/dist/collection/components/welcome-page/gx-ide-assets/welcome-page/langs/welcome-page.lang.zh.json +13 -0
  120. package/dist/collection/components/welcome-page/welcome-page.css +264 -0
  121. package/dist/collection/components/welcome-page/welcome-page.js +360 -0
  122. package/dist/collection/components/welcome-page/welcome-page.js.map +1 -0
  123. package/dist/collection/components/ww-images/gx-ide-assets/ww-images/langs/ww-images.lang.en.json +7 -3
  124. package/dist/collection/components/ww-images/gx-ide-assets/ww-images/langs/ww-images.lang.ja.json +8 -4
  125. package/dist/collection/components/ww-images/helpers.js +11 -0
  126. package/dist/collection/components/ww-images/helpers.js.map +1 -0
  127. package/dist/collection/components/ww-images/ww-images.css +82 -720
  128. package/dist/collection/components/ww-images/ww-images.js +465 -413
  129. package/dist/collection/components/ww-images/ww-images.js.map +1 -1
  130. package/dist/collection/pages/assets/images/welcome-page/slide-1.svg +115 -0
  131. package/dist/collection/pages/assets/images/welcome-page/slide-2.svg +67 -0
  132. package/dist/collection/pages/assets/images/welcome-page/slide-3.svg +138 -0
  133. package/dist/collection/pages/assets/images/welcome-page/slide-4.svg +97 -0
  134. package/dist/collection/pages/assets/images/welcome-page/slide-5.svg +83 -0
  135. package/dist/components/ai-message.js +1 -1
  136. package/dist/components/ai-message.js.map +1 -1
  137. package/dist/components/assets-manager.js +30 -30
  138. package/dist/components/assets-manager.js.map +1 -1
  139. package/dist/components/entity-selector.js +2 -2
  140. package/dist/components/entity-selector.js.map +1 -1
  141. package/dist/components/form-validation.js +1 -1
  142. package/dist/components/form-validation.js.map +1 -1
  143. package/dist/components/gx-ide-data-selector.js +2 -1
  144. package/dist/components/gx-ide-data-selector.js.map +1 -1
  145. package/dist/components/gx-ide-kb-manager-export.js +6 -3
  146. package/dist/components/gx-ide-kb-manager-export.js.map +1 -1
  147. package/dist/components/gx-ide-navigation-report.d.ts +11 -0
  148. package/dist/components/gx-ide-navigation-report.js +279 -0
  149. package/dist/components/gx-ide-navigation-report.js.map +1 -0
  150. package/dist/components/gx-ide-new-environment.js +2 -1
  151. package/dist/components/gx-ide-new-environment.js.map +1 -1
  152. package/dist/components/gx-ide-new-kb.js +7 -6
  153. package/dist/components/gx-ide-new-kb.js.map +1 -1
  154. package/dist/components/gx-ide-new-object.js +4 -3
  155. package/dist/components/gx-ide-new-object.js.map +1 -1
  156. package/dist/components/gx-ide-object-selector.js +5 -4
  157. package/dist/components/gx-ide-object-selector.js.map +1 -1
  158. package/dist/components/{gx-ide-recent-news.d.ts → gx-ide-splash.d.ts} +4 -4
  159. package/dist/components/gx-ide-splash.js +96 -0
  160. package/dist/components/gx-ide-splash.js.map +1 -0
  161. package/dist/components/gx-ide-start-page.js +2654 -126
  162. package/dist/components/gx-ide-start-page.js.map +1 -1
  163. package/dist/components/gx-ide-status-buttons2.js +35 -17
  164. package/dist/components/gx-ide-status-buttons2.js.map +1 -1
  165. package/dist/components/gx-ide-welcome-page.d.ts +11 -0
  166. package/dist/components/gx-ide-welcome-page.js +283 -0
  167. package/dist/components/gx-ide-welcome-page.js.map +1 -0
  168. package/dist/components/gx-ide-ww-images.js +419 -306
  169. package/dist/components/gx-ide-ww-images.js.map +1 -1
  170. package/dist/components/helpers.js +1 -6
  171. package/dist/components/helpers.js.map +1 -1
  172. package/dist/components/ide-loader.js +3 -3
  173. package/dist/components/ide-loader.js.map +1 -1
  174. package/dist/components/list-selector-item.js +2 -19
  175. package/dist/components/list-selector-item.js.map +1 -1
  176. package/dist/components/list-selector.js +2 -13
  177. package/dist/components/list-selector.js.map +1 -1
  178. package/dist/esm/{assets-manager-251883e0.js → assets-manager-5ac25bb6.js} +31 -31
  179. package/dist/esm/{assets-manager-251883e0.js.map → assets-manager-5ac25bb6.js.map} +1 -1
  180. package/dist/esm/{form-validation-8b3f527c.js → form-validation-44b2c2a8.js} +2 -2
  181. package/dist/esm/form-validation-44b2c2a8.js.map +1 -0
  182. package/dist/esm/genexus-ide-ui.js +1 -1
  183. package/dist/esm/gx-ide-ai-message.entry.js +2 -2
  184. package/dist/esm/gx-ide-ai-message.entry.js.map +1 -1
  185. package/dist/esm/gx-ide-connect-gx-server.entry.js +1 -1
  186. package/dist/esm/gx-ide-create-kb-from-server.entry.js +1 -1
  187. package/dist/esm/gx-ide-dashboard-home.entry.js +2 -2
  188. package/dist/esm/gx-ide-data-selector.entry.js +3 -2
  189. package/dist/esm/gx-ide-data-selector.entry.js.map +1 -1
  190. package/dist/esm/{gx-ide-empty-state_2.entry.js → gx-ide-empty-state.entry.js} +5 -57
  191. package/dist/esm/gx-ide-empty-state.entry.js.map +1 -0
  192. package/dist/esm/gx-ide-entity-selector.entry.js +3 -3
  193. package/dist/esm/gx-ide-entity-selector.entry.js.map +1 -1
  194. package/dist/esm/gx-ide-kb-manager-export.entry.js +7 -4
  195. package/dist/esm/gx-ide-kb-manager-export.entry.js.map +1 -1
  196. package/dist/esm/gx-ide-kb-manager-import.entry.js +1 -1
  197. package/dist/esm/gx-ide-list-selector_2.entry.js +4 -27
  198. package/dist/esm/gx-ide-list-selector_2.entry.js.map +1 -1
  199. package/dist/esm/gx-ide-loader.entry.js +57 -0
  200. package/dist/esm/gx-ide-loader.entry.js.map +1 -0
  201. package/dist/esm/gx-ide-manage-module-references-v2.entry.js +1 -1
  202. package/dist/esm/gx-ide-manage-module-references.entry.js +1 -1
  203. package/dist/esm/gx-ide-navigation-report.entry.js +224 -0
  204. package/dist/esm/gx-ide-navigation-report.entry.js.map +1 -0
  205. package/dist/esm/gx-ide-new-environment.entry.js +4 -3
  206. package/dist/esm/gx-ide-new-environment.entry.js.map +1 -1
  207. package/dist/esm/gx-ide-new-kb.entry.js +9 -8
  208. package/dist/esm/gx-ide-new-kb.entry.js.map +1 -1
  209. package/dist/esm/gx-ide-new-object.entry.js +4 -3
  210. package/dist/esm/gx-ide-new-object.entry.js.map +1 -1
  211. package/dist/esm/gx-ide-object-selector.entry.js +7 -6
  212. package/dist/esm/gx-ide-object-selector.entry.js.map +1 -1
  213. package/dist/esm/gx-ide-share-kb.entry.js +1 -1
  214. package/dist/esm/gx-ide-splash.entry.js +72 -0
  215. package/dist/esm/gx-ide-splash.entry.js.map +1 -0
  216. package/dist/esm/gx-ide-start-page.entry.js +2645 -105
  217. package/dist/esm/gx-ide-start-page.entry.js.map +1 -1
  218. package/dist/esm/gx-ide-status-buttons.entry.js +35 -17
  219. package/dist/esm/gx-ide-status-buttons.entry.js.map +1 -1
  220. package/dist/esm/gx-ide-team-dev-commit.entry.js +1 -1
  221. package/dist/esm/gx-ide-team-dev-update.entry.js +1 -1
  222. package/dist/esm/gx-ide-welcome-page.entry.js +253 -0
  223. package/dist/esm/gx-ide-welcome-page.entry.js.map +1 -0
  224. package/dist/esm/gx-ide-ww-images.entry.js +396 -279
  225. package/dist/esm/gx-ide-ww-images.entry.js.map +1 -1
  226. package/dist/esm/{helpers-64e1dd0b.js → helpers-9ee6ddce.js} +2 -7
  227. package/dist/esm/helpers-9ee6ddce.js.map +1 -0
  228. package/dist/esm/loader.js +1 -1
  229. package/dist/genexus-ide-ui/genexus-ide-ui.css +1 -1
  230. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
  231. package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
  232. package/dist/genexus-ide-ui/gx-ide-assets/navigation-report/langs/navigation-report.lang.en.json +6 -0
  233. package/dist/genexus-ide-ui/gx-ide-assets/navigation-report/langs/navigation-report.lang.ja.json +3 -0
  234. package/dist/genexus-ide-ui/gx-ide-assets/splash/images/copyrights-illustration.png +0 -0
  235. package/dist/genexus-ide-ui/gx-ide-assets/splash/images/icon-next.svg +4 -0
  236. package/dist/genexus-ide-ui/gx-ide-assets/splash/langs/splash.lang.en.json +14 -0
  237. package/dist/genexus-ide-ui/gx-ide-assets/splash/langs/splash.lang.ja.json +13 -0
  238. package/dist/genexus-ide-ui/gx-ide-assets/splash/langs/splash.lang.zh.json +13 -0
  239. package/dist/genexus-ide-ui/gx-ide-assets/start-page/langs/start-page.lang.en.json +19 -27
  240. package/dist/genexus-ide-ui/gx-ide-assets/start-page/langs/start-page.lang.ja.json +18 -26
  241. package/dist/genexus-ide-ui/gx-ide-assets/start-page/langs/start-page.lang.zh.json +23 -1
  242. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/arrow-next.svg +3 -0
  243. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/copyrights-base.svg +61 -0
  244. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/copyrights-illustration.png +0 -0
  245. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/fig-ellipse-blurred.svg +21 -0
  246. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/fig-ellipse-bottom-left.svg +14 -0
  247. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/fig-ellipse-top-left.svg +14 -0
  248. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/fig-polygon.svg +14 -0
  249. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/icon-next.svg +4 -0
  250. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/slide-1.svg +115 -0
  251. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/slide-2.svg +67 -0
  252. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/slide-3.svg +138 -0
  253. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/slide-4.svg +97 -0
  254. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/images/slide-5.svg +83 -0
  255. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/langs/welcome-page.lang.en.json +13 -0
  256. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/langs/welcome-page.lang.ja.json +13 -0
  257. package/dist/genexus-ide-ui/gx-ide-assets/welcome-page/langs/welcome-page.lang.zh.json +13 -0
  258. package/dist/genexus-ide-ui/gx-ide-assets/ww-images/langs/ww-images.lang.en.json +7 -3
  259. package/dist/genexus-ide-ui/gx-ide-assets/ww-images/langs/ww-images.lang.ja.json +8 -4
  260. package/dist/genexus-ide-ui/{p-d5d0ed5e.entry.js → p-02bc66c1.entry.js} +2 -2
  261. package/dist/genexus-ide-ui/{p-c339f703.js → p-066028bc.js} +8 -14
  262. package/dist/genexus-ide-ui/p-066028bc.js.map +1 -0
  263. package/dist/genexus-ide-ui/{p-58e7d1ab.js → p-0b0ce806.js} +31 -31
  264. package/dist/genexus-ide-ui/p-0b0ce806.js.map +1 -0
  265. package/dist/genexus-ide-ui/p-120d283a.entry.js +2419 -0
  266. package/dist/genexus-ide-ui/p-120d283a.entry.js.map +1 -0
  267. package/dist/genexus-ide-ui/{p-a4a56375.entry.js → p-1ced155b.entry.js} +4 -4
  268. package/dist/genexus-ide-ui/p-1ced155b.entry.js.map +1 -0
  269. package/dist/genexus-ide-ui/{p-0a1167a6.entry.js → p-1f37f5b5.entry.js} +2 -2
  270. package/dist/genexus-ide-ui/{p-6b8f6569.entry.js → p-2465307a.entry.js} +54 -54
  271. package/dist/genexus-ide-ui/p-2465307a.entry.js.map +1 -0
  272. package/dist/genexus-ide-ui/{p-3b3f5ecb.entry.js → p-278afab1.entry.js} +3 -3
  273. package/dist/genexus-ide-ui/{p-940c83a6.entry.js → p-2dd09b01.entry.js} +22 -44
  274. package/dist/genexus-ide-ui/p-2dd09b01.entry.js.map +1 -0
  275. package/dist/genexus-ide-ui/{p-5961ae84.entry.js → p-3f5ea8bf.entry.js} +34 -34
  276. package/dist/genexus-ide-ui/p-3f5ea8bf.entry.js.map +1 -0
  277. package/dist/genexus-ide-ui/{p-f06147d7.entry.js → p-44d779c9.entry.js} +7 -7
  278. package/dist/genexus-ide-ui/p-44d779c9.entry.js.map +1 -0
  279. package/dist/genexus-ide-ui/{p-5bff0103.entry.js → p-4ce0a85e.entry.js} +3 -3
  280. package/dist/genexus-ide-ui/p-4ce0a85e.entry.js.map +1 -0
  281. package/dist/genexus-ide-ui/{p-fc64d088.entry.js → p-58e13823.entry.js} +2 -2
  282. package/dist/genexus-ide-ui/{p-cff74f8a.entry.js → p-60cd6b09.entry.js} +2 -2
  283. package/dist/genexus-ide-ui/p-62efd8f2.entry.js +712 -0
  284. package/dist/genexus-ide-ui/p-62efd8f2.entry.js.map +1 -0
  285. package/dist/genexus-ide-ui/{p-98b5b178.entry.js → p-658755d5.entry.js} +18 -87
  286. package/dist/genexus-ide-ui/p-658755d5.entry.js.map +1 -0
  287. package/dist/genexus-ide-ui/{p-dbfddffd.entry.js → p-69b88e9f.entry.js} +35 -23
  288. package/dist/genexus-ide-ui/p-69b88e9f.entry.js.map +1 -0
  289. package/dist/genexus-ide-ui/p-7a2d3f1c.entry.js +304 -0
  290. package/dist/genexus-ide-ui/p-7a2d3f1c.entry.js.map +1 -0
  291. package/dist/genexus-ide-ui/p-7ec19ed6.entry.js +73 -0
  292. package/dist/genexus-ide-ui/p-7ec19ed6.entry.js.map +1 -0
  293. package/dist/genexus-ide-ui/{p-23c9b4e6.entry.js → p-806fc181.entry.js} +14 -14
  294. package/dist/genexus-ide-ui/p-806fc181.entry.js.map +1 -0
  295. package/dist/genexus-ide-ui/{p-cfd29ed2.entry.js → p-8c986256.entry.js} +36 -36
  296. package/dist/genexus-ide-ui/p-8c986256.entry.js.map +1 -0
  297. package/dist/genexus-ide-ui/{p-fae9bd6c.entry.js → p-9efea53c.entry.js} +4 -4
  298. package/dist/genexus-ide-ui/p-9efea53c.entry.js.map +1 -0
  299. package/dist/genexus-ide-ui/{p-4ce47bcd.entry.js → p-acf0cbac.entry.js} +2 -2
  300. package/dist/genexus-ide-ui/{p-ca8b0024.entry.js → p-b785673d.entry.js} +2 -2
  301. package/dist/genexus-ide-ui/{p-41ea711a.js → p-b8624c0b.js} +2 -2
  302. package/dist/genexus-ide-ui/p-b8624c0b.js.map +1 -0
  303. package/dist/genexus-ide-ui/{p-39792ac8.entry.js → p-c4d1d0ce.entry.js} +2 -2
  304. package/dist/genexus-ide-ui/p-c8b4f34c.entry.js +113 -0
  305. package/dist/genexus-ide-ui/p-c8b4f34c.entry.js.map +1 -0
  306. package/dist/genexus-ide-ui/{p-b1f6fdd6.entry.js → p-cf2c8b3c.entry.js} +2 -2
  307. package/dist/genexus-ide-ui/p-de59d495.entry.js +273 -0
  308. package/dist/genexus-ide-ui/p-de59d495.entry.js.map +1 -0
  309. package/dist/types/components/_helpers/list-selector/list-selector-item/list-selector-item.d.ts +0 -11
  310. package/dist/types/components/_helpers/list-selector/list-selector.d.ts +0 -13
  311. package/dist/types/components/_helpers/status-buttons/gx-ide-status-buttons.d.ts +1 -4
  312. package/dist/types/components/navigation-report/helpers.d.ts +5 -0
  313. package/dist/types/components/navigation-report/navigation-report.d.ts +88 -0
  314. package/dist/types/components/splash/splash.d.ts +20 -0
  315. package/dist/types/components/start-page/start-page.d.ts +31 -53
  316. package/dist/types/components/welcome-page/welcome-page.d.ts +63 -0
  317. package/dist/types/components/ww-images/helpers.d.ts +3 -0
  318. package/dist/types/components/ww-images/ww-images.d.ts +98 -118
  319. package/dist/types/components.d.ts +236 -195
  320. package/package.json +8 -5
  321. package/dist/cjs/form-validation-df39cabb.js.map +0 -1
  322. package/dist/cjs/gx-ide-empty-state_2.cjs.entry.js.map +0 -1
  323. package/dist/cjs/gx-ide-recent-news.cjs.entry.js +0 -163
  324. package/dist/cjs/gx-ide-recent-news.cjs.entry.js.map +0 -1
  325. package/dist/cjs/helpers-b5b4a659.js.map +0 -1
  326. package/dist/collection/components/start-page/gx-ide-assets/recent-news/langs/recent-news.lang.en.json +0 -24
  327. package/dist/collection/components/start-page/gx-ide-assets/recent-news/langs/recent-news.lang.ja.json +0 -24
  328. package/dist/collection/components/start-page/recent-news.css +0 -641
  329. package/dist/collection/components/start-page/recent-news.js +0 -240
  330. package/dist/collection/components/start-page/recent-news.js.map +0 -1
  331. package/dist/components/gx-ide-recent-news.js +0 -8
  332. package/dist/components/gx-ide-recent-news.js.map +0 -1
  333. package/dist/components/recent-news.js +0 -197
  334. package/dist/components/recent-news.js.map +0 -1
  335. package/dist/esm/form-validation-8b3f527c.js.map +0 -1
  336. package/dist/esm/gx-ide-empty-state_2.entry.js.map +0 -1
  337. package/dist/esm/gx-ide-recent-news.entry.js +0 -159
  338. package/dist/esm/gx-ide-recent-news.entry.js.map +0 -1
  339. package/dist/esm/helpers-64e1dd0b.js.map +0 -1
  340. package/dist/genexus-ide-ui/gx-ide-assets/recent-news/langs/recent-news.lang.en.json +0 -24
  341. package/dist/genexus-ide-ui/gx-ide-assets/recent-news/langs/recent-news.lang.ja.json +0 -24
  342. package/dist/genexus-ide-ui/p-23c9b4e6.entry.js.map +0 -1
  343. package/dist/genexus-ide-ui/p-41ea711a.js.map +0 -1
  344. package/dist/genexus-ide-ui/p-58e7d1ab.js.map +0 -1
  345. package/dist/genexus-ide-ui/p-5961ae84.entry.js.map +0 -1
  346. package/dist/genexus-ide-ui/p-5bff0103.entry.js.map +0 -1
  347. package/dist/genexus-ide-ui/p-6b8f6569.entry.js.map +0 -1
  348. package/dist/genexus-ide-ui/p-940c83a6.entry.js.map +0 -1
  349. package/dist/genexus-ide-ui/p-98b5b178.entry.js.map +0 -1
  350. package/dist/genexus-ide-ui/p-a4a56375.entry.js.map +0 -1
  351. package/dist/genexus-ide-ui/p-cfd29ed2.entry.js.map +0 -1
  352. package/dist/genexus-ide-ui/p-d15717c5.entry.js +0 -211
  353. package/dist/genexus-ide-ui/p-d15717c5.entry.js.map +0 -1
  354. package/dist/genexus-ide-ui/p-dbfddffd.entry.js.map +0 -1
  355. package/dist/genexus-ide-ui/p-e08213ef.entry.js +0 -233
  356. package/dist/genexus-ide-ui/p-e08213ef.entry.js.map +0 -1
  357. package/dist/genexus-ide-ui/p-f06147d7.entry.js.map +0 -1
  358. package/dist/genexus-ide-ui/p-f96614f3.entry.js +0 -611
  359. package/dist/genexus-ide-ui/p-f96614f3.entry.js.map +0 -1
  360. package/dist/genexus-ide-ui/p-fae9bd6c.entry.js.map +0 -1
  361. package/dist/types/components/start-page/recent-news.d.ts +0 -43
  362. /package/dist/collection/components/{start-page/gx-ide-assets/recent-news/langs/recent-news.lang.zh.json → navigation-report/gx-ide-assets/navigation-report/langs/navigation-report.lang.zh.json} +0 -0
  363. /package/dist/genexus-ide-ui/gx-ide-assets/{recent-news/langs/recent-news.lang.zh.json → navigation-report/langs/navigation-report.lang.zh.json} +0 -0
  364. /package/dist/genexus-ide-ui/{p-d5d0ed5e.entry.js.map → p-02bc66c1.entry.js.map} +0 -0
  365. /package/dist/genexus-ide-ui/{p-0a1167a6.entry.js.map → p-1f37f5b5.entry.js.map} +0 -0
  366. /package/dist/genexus-ide-ui/{p-3b3f5ecb.entry.js.map → p-278afab1.entry.js.map} +0 -0
  367. /package/dist/genexus-ide-ui/{p-fc64d088.entry.js.map → p-58e13823.entry.js.map} +0 -0
  368. /package/dist/genexus-ide-ui/{p-cff74f8a.entry.js.map → p-60cd6b09.entry.js.map} +0 -0
  369. /package/dist/genexus-ide-ui/{p-4ce47bcd.entry.js.map → p-acf0cbac.entry.js.map} +0 -0
  370. /package/dist/genexus-ide-ui/{p-ca8b0024.entry.js.map → p-b785673d.entry.js.map} +0 -0
  371. /package/dist/genexus-ide-ui/{p-39792ac8.entry.js.map → p-c4d1d0ce.entry.js.map} +0 -0
  372. /package/dist/genexus-ide-ui/{p-b1f6fdd6.entry.js.map → p-cf2c8b3c.entry.js.map} +0 -0
@@ -1,240 +0,0 @@
1
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
2
- if (kind === "a" && !f)
3
- throw new TypeError("Private accessor was defined without a getter");
4
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
5
- throw new TypeError("Cannot read private member from an object whose class did not declare it");
6
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
7
- };
8
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
9
- if (kind === "m")
10
- throw new TypeError("Private method is not writable");
11
- if (kind === "a" && !f)
12
- throw new TypeError("Private accessor was defined without a setter");
13
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
14
- throw new TypeError("Cannot write private member to an object whose class did not declare it");
15
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
16
- };
17
- var _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR, _GxIdeRecentNews_newsRendered, _GxIdeRecentNews_setTimeOutNewsDelay, _GxIdeRecentNews_newsContainerEl, _GxIdeRecentNews_displayNews, _GxIdeRecentNews_evaluateNewsDisplay, _GxIdeRecentNews_evaluateNewsRender, _GxIdeRecentNews_getNews, _GxIdeRecentNews_openNewsHandler, _GxIdeRecentNews_refreshFilteredNews, _GxIdeRecentNews_renderNewsItem, _GxIdeRecentNews_renderNewsList;
18
- import { Host, h } from "@stencil/core";
19
- import { getIconPath } from "@genexus/mercury";
20
- import { Locale } from "../../common/locale";
21
- import { config } from "../../common/config";
22
- import { hiChar } from "../../common/helpers";
23
- const NEWS_ICON = getIconPath({
24
- category: "system",
25
- name: "news",
26
- colorType: "on-elevation"
27
- });
28
- const CSS_BUNDLES = [
29
- "resets/box-sizing",
30
- "components/button",
31
- "components/icon",
32
- "utils/typography",
33
- "utils/layout",
34
- "chameleon/scrollbar"
35
- ];
36
- export class GxIdeRecentNews {
37
- constructor() {
38
- _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR.set(this, "news-item");
39
- _GxIdeRecentNews_newsRendered.set(this, false);
40
- _GxIdeRecentNews_setTimeOutNewsDelay.set(this, 75);
41
- _GxIdeRecentNews_newsContainerEl.set(this, void 0);
42
- _GxIdeRecentNews_displayNews.set(this, () => {
43
- if (__classPrivateFieldGet(this, _GxIdeRecentNews_newsContainerEl, "f") !== undefined) {
44
- const news = Array.from(__classPrivateFieldGet(this, _GxIdeRecentNews_newsContainerEl, "f").querySelectorAll(`.${__classPrivateFieldGet(this, _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR, "f")}`));
45
- news.forEach(news => {
46
- // display news with a cascade effect
47
- setTimeout(() => {
48
- news.classList.add("visible");
49
- }, __classPrivateFieldGet(this, _GxIdeRecentNews_setTimeOutNewsDelay, "f"));
50
- __classPrivateFieldSet(this, _GxIdeRecentNews_setTimeOutNewsDelay, __classPrivateFieldGet(this, _GxIdeRecentNews_setTimeOutNewsDelay, "f") + 45, "f");
51
- });
52
- }
53
- });
54
- _GxIdeRecentNews_evaluateNewsDisplay.set(this, () => {
55
- if (!__classPrivateFieldGet(this, _GxIdeRecentNews_newsRendered, "f") &&
56
- this.news.length > 0 &&
57
- __classPrivateFieldGet(this, _GxIdeRecentNews_newsContainerEl, "f") !== undefined) {
58
- __classPrivateFieldGet(this, _GxIdeRecentNews_displayNews, "f").call(this);
59
- __classPrivateFieldSet(this, _GxIdeRecentNews_newsRendered, true, "f");
60
- }
61
- });
62
- _GxIdeRecentNews_evaluateNewsRender.set(this, () => {
63
- var _a;
64
- if (this.newsLoadFailed) {
65
- return (h("gx-ide-empty-state", { stateIconSrc: NEWS_ICON, stateTitle: this._componentLocale.recentNews.newsNotFetched.title }, h("button", { class: "empty-state__button button-primary", onClick: __classPrivateFieldGet(this, _GxIdeRecentNews_getNews, "f") }, this._componentLocale.recentNews.newsNotFetched
66
- .tryAgainButtonLabel), h("a", { class: "text-link text-body-regular-s", href: this._componentLocale.recentNews.newsNotFetched.onlineNewsURL, target: "_blank" }, this._componentLocale.recentNews.newsNotFetched.readThemOnline)));
67
- }
68
- if (this.news.length === 0) {
69
- return (h("gx-ide-empty-state", { stateIconSrc: NEWS_ICON, stateTitle: this._componentLocale.recentNews.noNewsToDisplay.title }, h("a", { class: "empty-state__link text-body-regular-s", href: this._componentLocale.recentNews.onlineNewsURL, target: "_blank" }, this._componentLocale.recentNews.readThemOnline)));
70
- }
71
- if (((_a = this.filteredNews) === null || _a === void 0 ? void 0 : _a.length) === 0) {
72
- return (h("gx-ide-empty-state", { class: "news-empty-state", stateIconSrc: NEWS_ICON, stateTitle: this._componentLocale.recentNews.noNewsFiltered.title }));
73
- }
74
- return __classPrivateFieldGet(this, _GxIdeRecentNews_renderNewsList, "f").call(this);
75
- });
76
- _GxIdeRecentNews_getNews.set(this, async () => {
77
- this.loadingNews = true;
78
- const newsResult = await this.getNewsCallback();
79
- this.loadingNews = false;
80
- if (newsResult && newsResult.length > 0) {
81
- this.news = newsResult;
82
- this.newsLoadFailed = false;
83
- }
84
- else {
85
- this.newsLoadFailed = true;
86
- }
87
- });
88
- _GxIdeRecentNews_openNewsHandler.set(this, (newsId) => async () => {
89
- await this.openNewsCallback(newsId);
90
- });
91
- _GxIdeRecentNews_refreshFilteredNews.set(this, (filterValue, news) => {
92
- this.filteredNews = news.filter(singleNews => {
93
- var _a, _b;
94
- return ((_a = singleNews.title) === null || _a === void 0 ? void 0 : _a.toLowerCase().includes(filterValue)) ||
95
- ((_b = singleNews.body) === null || _b === void 0 ? void 0 : _b.toLowerCase().includes(filterValue));
96
- });
97
- });
98
- _GxIdeRecentNews_renderNewsItem.set(this, (news) => {
99
- if (news.id && news.title) {
100
- return (h("article", null, h("button", { class: {
101
- "card-small": true,
102
- "card-small--actionable": true,
103
- "card-news": true,
104
- [__classPrivateFieldGet(this, _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR, "f")]: true,
105
- "visible": __classPrivateFieldGet(this, _GxIdeRecentNews_newsRendered, "f")
106
- }, id: news.id, key: news.id, type: "button", onClick: __classPrivateFieldGet(this, _GxIdeRecentNews_openNewsHandler, "f").call(this, news.id) }, h("header", { class: "card-news__header" }, h("ch-image", { src: NEWS_ICON, class: "icon-md" }), h("h2", { class: config.headingsClasses.cardSmall }, hiChar(news.title, this.filterValue))), news.body && (h("p", { class: "text-body-regular-s" }, hiChar(news.body, this.filterValue))))));
107
- }
108
- return null;
109
- });
110
- _GxIdeRecentNews_renderNewsList.set(this, () => {
111
- var _a;
112
- return (h("div", { class: "news-container", ref: el => (__classPrivateFieldSet(this, _GxIdeRecentNews_newsContainerEl, el, "f")) }, (_a = this.filteredNews) === null || _a === void 0 ? void 0 : _a.map(__classPrivateFieldGet(this, _GxIdeRecentNews_renderNewsItem, "f"))));
113
- });
114
- this.filteredNews = [];
115
- this.loadingNews = true;
116
- this.news = [];
117
- this.newsLoadFailed = false;
118
- this.getNewsCallback = undefined;
119
- this.openNewsCallback = undefined;
120
- this.filterValue = "";
121
- }
122
- newsChanged(news) {
123
- __classPrivateFieldGet(this, _GxIdeRecentNews_refreshFilteredNews, "f").call(this, this.filterValue, news);
124
- __classPrivateFieldGet(this, _GxIdeRecentNews_displayNews, "f").call(this);
125
- }
126
- watchNews(newFilterValue) {
127
- __classPrivateFieldGet(this, _GxIdeRecentNews_refreshFilteredNews, "f").call(this, newFilterValue, this.news);
128
- }
129
- async componentWillLoad() {
130
- this._componentLocale = await Locale.getComponentStrings(this.el);
131
- }
132
- componentDidRender() {
133
- __classPrivateFieldGet(this, _GxIdeRecentNews_evaluateNewsDisplay, "f").call(this);
134
- }
135
- componentDidLoad() {
136
- __classPrivateFieldGet(this, _GxIdeRecentNews_getNews, "f").call(this);
137
- }
138
- render() {
139
- return (h(Host
140
- // Improve accessibility by announcing live changes
141
- , { "aria-live": "polite", "aria-busy": this.loadingNews ? "true" : "false", class: { empty: this.filteredNews.length === 0, scrollable: true } }, h("ch-theme", { model: CSS_BUNDLES }), this.loadingNews ? (h("gx-ide-loader", { abortTime: 8000, loaderTitle: this._componentLocale.loader.title, description: this._componentLocale.loader.description, show: true })) : (__classPrivateFieldGet(this, _GxIdeRecentNews_evaluateNewsRender, "f").call(this))));
142
- }
143
- static get is() { return "gx-ide-recent-news"; }
144
- static get encapsulation() { return "shadow"; }
145
- static get originalStyleUrls() {
146
- return {
147
- "$": ["recent-news.scss"]
148
- };
149
- }
150
- static get styleUrls() {
151
- return {
152
- "$": ["recent-news.css"]
153
- };
154
- }
155
- static get assetsDirs() { return ["gx-ide-assets/recent-news"]; }
156
- static get properties() {
157
- return {
158
- "getNewsCallback": {
159
- "type": "unknown",
160
- "mutable": false,
161
- "complexType": {
162
- "original": "GetNewsCallback",
163
- "resolved": "() => Promise<NewsData[]>",
164
- "references": {
165
- "GetNewsCallback": {
166
- "location": "import",
167
- "path": "./start-page",
168
- "id": "src/components/start-page/start-page.tsx::GetNewsCallback"
169
- }
170
- }
171
- },
172
- "required": true,
173
- "optional": false,
174
- "docs": {
175
- "tags": [],
176
- "text": "Callback invoked to load the news feed (right panel \"Recent News\")."
177
- }
178
- },
179
- "openNewsCallback": {
180
- "type": "unknown",
181
- "mutable": false,
182
- "complexType": {
183
- "original": "OpenNewsCallback",
184
- "resolved": "(id: string) => Promise<void>",
185
- "references": {
186
- "OpenNewsCallback": {
187
- "location": "import",
188
- "path": "./start-page",
189
- "id": "src/components/start-page/start-page.tsx::OpenNewsCallback"
190
- }
191
- }
192
- },
193
- "required": true,
194
- "optional": false,
195
- "docs": {
196
- "tags": [],
197
- "text": "Callback invoked to open a news article."
198
- }
199
- },
200
- "filterValue": {
201
- "type": "string",
202
- "mutable": false,
203
- "complexType": {
204
- "original": "string",
205
- "resolved": "string",
206
- "references": {}
207
- },
208
- "required": false,
209
- "optional": false,
210
- "docs": {
211
- "tags": [],
212
- "text": "The news filter value inserted by the user on the news input filter"
213
- },
214
- "attribute": "filter-value",
215
- "reflect": false,
216
- "defaultValue": "\"\""
217
- }
218
- };
219
- }
220
- static get states() {
221
- return {
222
- "filteredNews": {},
223
- "loadingNews": {},
224
- "news": {},
225
- "newsLoadFailed": {}
226
- };
227
- }
228
- static get elementRef() { return "el"; }
229
- static get watchers() {
230
- return [{
231
- "propName": "news",
232
- "methodName": "newsChanged"
233
- }, {
234
- "propName": "filterValue",
235
- "methodName": "watchNews"
236
- }];
237
- }
238
- }
239
- _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR = new WeakMap(), _GxIdeRecentNews_newsRendered = new WeakMap(), _GxIdeRecentNews_setTimeOutNewsDelay = new WeakMap(), _GxIdeRecentNews_newsContainerEl = new WeakMap(), _GxIdeRecentNews_displayNews = new WeakMap(), _GxIdeRecentNews_evaluateNewsDisplay = new WeakMap(), _GxIdeRecentNews_evaluateNewsRender = new WeakMap(), _GxIdeRecentNews_getNews = new WeakMap(), _GxIdeRecentNews_openNewsHandler = new WeakMap(), _GxIdeRecentNews_refreshFilteredNews = new WeakMap(), _GxIdeRecentNews_renderNewsItem = new WeakMap(), _GxIdeRecentNews_renderNewsList = new WeakMap();
240
- //# sourceMappingURL=recent-news.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"recent-news.js","sourceRoot":"","sources":["../../../src/components/start-page/recent-news.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, h, Prop, Element, State, Watch } from \"@stencil/core\";\n\nimport { MercuryBundles, getIconPath } from \"@genexus/mercury\";\n\nimport { Locale } from \"../../common/locale\";\nimport { config } from \"../../common/config\";\nimport { hiChar } from \"../../common/helpers\";\nimport { NewsData, GetNewsCallback, OpenNewsCallback } from \"./start-page\";\n\nconst NEWS_ICON = getIconPath({\n category: \"system\",\n name: \"news\",\n colorType: \"on-elevation\"\n});\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/button\",\n \"components/icon\",\n \"utils/typography\",\n \"utils/layout\",\n \"chameleon/scrollbar\"\n];\n@Component({\n tag: \"gx-ide-recent-news\",\n styleUrl: \"recent-news.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/recent-news\"]\n})\nexport class GxIdeRecentNews {\n /**\n * The component hard-coded strings translations.\n */\n private _componentLocale: any;\n\n #NEWS_ITEM_CLASS_SELECTOR = \"news-item\";\n #newsRendered = false;\n #setTimeOutNewsDelay = 75;\n\n @Element() el: HTMLGxIdeRecentNewsElement;\n\n #newsContainerEl: HTMLDivElement;\n\n /**\n * The list of news after the filter\n */\n @State() filteredNews: NewsData[] = [];\n\n /**\n * True if news are being requested\n */\n @State() loadingNews = true;\n\n /**\n * The list of news\n */\n @State() news: NewsData[] = [];\n @Watch(\"news\")\n newsChanged(news: NewsData[]) {\n this.#refreshFilteredNews(this.filterValue, news);\n this.#displayNews();\n }\n\n /**\n * True if news couldn't be loaded\n */\n @State() newsLoadFailed = false;\n\n /**\n * Callback invoked to load the news feed (right panel \"Recent News\").\n */\n @Prop() readonly getNewsCallback!: GetNewsCallback;\n\n /**\n * Callback invoked to open a news article.\n */\n @Prop() readonly openNewsCallback!: OpenNewsCallback;\n\n /**\n * The news filter value inserted by the user on the news input filter\n */\n @Prop() readonly filterValue: string = \"\";\n @Watch(\"filterValue\")\n watchNews(newFilterValue: string) {\n this.#refreshFilteredNews(newFilterValue, this.news);\n }\n\n async componentWillLoad() {\n this._componentLocale = await Locale.getComponentStrings(this.el);\n }\n\n componentDidRender() {\n this.#evaluateNewsDisplay();\n }\n\n componentDidLoad() {\n this.#getNews();\n }\n\n #displayNews = () => {\n if (this.#newsContainerEl !== undefined) {\n const news = Array.from(\n this.#newsContainerEl.querySelectorAll(\n `.${this.#NEWS_ITEM_CLASS_SELECTOR}`\n )\n );\n news.forEach(news => {\n // display news with a cascade effect\n setTimeout(() => {\n news.classList.add(\"visible\");\n }, this.#setTimeOutNewsDelay);\n this.#setTimeOutNewsDelay += 45;\n });\n }\n };\n\n #evaluateNewsDisplay = () => {\n if (\n !this.#newsRendered &&\n this.news.length > 0 &&\n this.#newsContainerEl !== undefined\n ) {\n this.#displayNews();\n this.#newsRendered = true;\n }\n };\n\n #evaluateNewsRender = (): HTMLElement => {\n if (this.newsLoadFailed) {\n return (\n <gx-ide-empty-state\n stateIconSrc={NEWS_ICON}\n stateTitle={this._componentLocale.recentNews.newsNotFetched.title}\n >\n <button\n class=\"empty-state__button button-primary\"\n onClick={this.#getNews}\n >\n {\n this._componentLocale.recentNews.newsNotFetched\n .tryAgainButtonLabel\n }\n </button>\n <a\n class=\"text-link text-body-regular-s\"\n href={this._componentLocale.recentNews.newsNotFetched.onlineNewsURL}\n target=\"_blank\"\n >\n {this._componentLocale.recentNews.newsNotFetched.readThemOnline}\n </a>\n </gx-ide-empty-state>\n );\n }\n if (this.news.length === 0) {\n return (\n <gx-ide-empty-state\n stateIconSrc={NEWS_ICON}\n stateTitle={this._componentLocale.recentNews.noNewsToDisplay.title}\n >\n <a\n class=\"empty-state__link text-body-regular-s\"\n href={this._componentLocale.recentNews.onlineNewsURL}\n target=\"_blank\"\n >\n {this._componentLocale.recentNews.readThemOnline}\n </a>\n </gx-ide-empty-state>\n );\n }\n if (this.filteredNews?.length === 0) {\n return (\n <gx-ide-empty-state\n class=\"news-empty-state\"\n stateIconSrc={NEWS_ICON}\n stateTitle={this._componentLocale.recentNews.noNewsFiltered.title}\n ></gx-ide-empty-state>\n );\n }\n return this.#renderNewsList();\n };\n\n #getNews = async () => {\n this.loadingNews = true;\n const newsResult = await this.getNewsCallback();\n this.loadingNews = false;\n if (newsResult && newsResult.length > 0) {\n this.news = newsResult;\n this.newsLoadFailed = false;\n } else {\n this.newsLoadFailed = true;\n }\n };\n\n #openNewsHandler = (newsId: string) => async () => {\n await this.openNewsCallback(newsId);\n };\n\n #refreshFilteredNews = (filterValue: string, news: NewsData[]) => {\n this.filteredNews = news.filter(\n singleNews =>\n singleNews.title?.toLowerCase().includes(filterValue) ||\n singleNews.body?.toLowerCase().includes(filterValue)\n );\n };\n\n #renderNewsItem = (news: NewsData): HTMLGxgCardElement | null => {\n if (news.id && news.title) {\n return (\n <article>\n <button\n class={{\n \"card-small\": true,\n \"card-small--actionable\": true,\n \"card-news\": true,\n [this.#NEWS_ITEM_CLASS_SELECTOR]: true,\n \"visible\": this.#newsRendered\n }}\n id={news.id}\n key={news.id}\n type=\"button\"\n onClick={this.#openNewsHandler(news.id)}\n >\n <header class=\"card-news__header\">\n <ch-image src={NEWS_ICON} class=\"icon-md\"></ch-image>\n <h2 class={config.headingsClasses.cardSmall}>\n {hiChar(news.title, this.filterValue)}\n </h2>\n </header>\n {news.body && (\n <p class=\"text-body-regular-s\">\n {hiChar(news.body, this.filterValue)}\n </p>\n )}\n </button>\n </article>\n );\n }\n return null;\n };\n\n #renderNewsList = (): HTMLElement => (\n <div\n class=\"news-container\"\n ref={el => (this.#newsContainerEl = el as HTMLDivElement)}\n >\n {this.filteredNews?.map(this.#renderNewsItem)}\n </div>\n );\n\n render() {\n return (\n <Host\n // Improve accessibility by announcing live changes\n aria-live=\"polite\"\n // Wait until all changes are made to prevents assistive\n // technologies from announcing changes before updates are done\n aria-busy={this.loadingNews ? \"true\" : \"false\"}\n class={{ empty: this.filteredNews.length === 0, scrollable: true }}\n >\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n {this.loadingNews ? (\n <gx-ide-loader\n abortTime={8000}\n loaderTitle={this._componentLocale.loader.title}\n description={this._componentLocale.loader.description}\n show={true}\n ></gx-ide-loader>\n ) : (\n this.#evaluateNewsRender()\n )}\n </Host>\n );\n }\n}\n"]}
@@ -1,8 +0,0 @@
1
- import { G as GxIdeRecentNews$1, d as defineCustomElement$1 } from './recent-news.js';
2
-
3
- const GxIdeRecentNews = GxIdeRecentNews$1;
4
- const defineCustomElement = defineCustomElement$1;
5
-
6
- export { GxIdeRecentNews, defineCustomElement };
7
-
8
- //# sourceMappingURL=gx-ide-recent-news.js.map
@@ -1 +0,0 @@
1
- {"file":"gx-ide-recent-news.js","mappings":";;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
@@ -1,197 +0,0 @@
1
- import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
- import { g as getIconPath } from './assets-manager.js';
3
- import { L as Locale } from './locale.js';
4
- import { c as config } from './config.js';
5
- import { h as hiChar } from './helpers.js';
6
- import { d as defineCustomElement$2 } from './gx-ide-empty-state2.js';
7
- import { d as defineCustomElement$1 } from './ide-loader.js';
8
-
9
- const recentNewsCss = ":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)}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}: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}.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)}.hiChar{color:var(--mer-color__primary-blue--200);filter:brightness(1.3)}:host(.empty){overflow:hidden !important}.news-container{display:grid;gap:var(--mer-spacing--xs);grid-auto-rows:max-content}.news-item{opacity:0;transition:150ms opacity}.news-item.visible{opacity:1}.card-news{display:flex;flex-direction:column;align-items:start;gap:var(--mer-spacing--xs)}.card-news__header{display:flex;gap:var(--mer-spacing--sm);align-items:center}gx-ide-loader::part(loader-wrapper){border:var(--mer-border__width--sm) solid var(--mer-border-color__on-elevation--01);border-radius:var(--mer-border__radius--md)}.text-link{color:var(--mer-accent__primary)}.text-link:hover{text-decoration:underline}";
10
-
11
- var __classPrivateFieldGet = (undefined && undefined.__classPrivateFieldGet) || function (receiver, state, kind, f) {
12
- if (kind === "a" && !f)
13
- throw new TypeError("Private accessor was defined without a getter");
14
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
15
- throw new TypeError("Cannot read private member from an object whose class did not declare it");
16
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
17
- };
18
- var __classPrivateFieldSet = (undefined && undefined.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
19
- if (kind === "m")
20
- throw new TypeError("Private method is not writable");
21
- if (kind === "a" && !f)
22
- throw new TypeError("Private accessor was defined without a setter");
23
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver))
24
- throw new TypeError("Cannot write private member to an object whose class did not declare it");
25
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
26
- };
27
- var _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR, _GxIdeRecentNews_newsRendered, _GxIdeRecentNews_setTimeOutNewsDelay, _GxIdeRecentNews_newsContainerEl, _GxIdeRecentNews_displayNews, _GxIdeRecentNews_evaluateNewsDisplay, _GxIdeRecentNews_evaluateNewsRender, _GxIdeRecentNews_getNews, _GxIdeRecentNews_openNewsHandler, _GxIdeRecentNews_refreshFilteredNews, _GxIdeRecentNews_renderNewsItem, _GxIdeRecentNews_renderNewsList;
28
- const NEWS_ICON = getIconPath({
29
- category: "system",
30
- name: "news",
31
- colorType: "on-elevation"
32
- });
33
- const CSS_BUNDLES = [
34
- "resets/box-sizing",
35
- "components/button",
36
- "components/icon",
37
- "utils/typography",
38
- "utils/layout",
39
- "chameleon/scrollbar"
40
- ];
41
- const GxIdeRecentNews = /*@__PURE__*/ proxyCustomElement(class GxIdeRecentNews extends HTMLElement {
42
- constructor() {
43
- super();
44
- this.__registerHost();
45
- this.__attachShadow();
46
- _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR.set(this, "news-item");
47
- _GxIdeRecentNews_newsRendered.set(this, false);
48
- _GxIdeRecentNews_setTimeOutNewsDelay.set(this, 75);
49
- _GxIdeRecentNews_newsContainerEl.set(this, void 0);
50
- _GxIdeRecentNews_displayNews.set(this, () => {
51
- if (__classPrivateFieldGet(this, _GxIdeRecentNews_newsContainerEl, "f") !== undefined) {
52
- const news = Array.from(__classPrivateFieldGet(this, _GxIdeRecentNews_newsContainerEl, "f").querySelectorAll(`.${__classPrivateFieldGet(this, _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR, "f")}`));
53
- news.forEach(news => {
54
- // display news with a cascade effect
55
- setTimeout(() => {
56
- news.classList.add("visible");
57
- }, __classPrivateFieldGet(this, _GxIdeRecentNews_setTimeOutNewsDelay, "f"));
58
- __classPrivateFieldSet(this, _GxIdeRecentNews_setTimeOutNewsDelay, __classPrivateFieldGet(this, _GxIdeRecentNews_setTimeOutNewsDelay, "f") + 45, "f");
59
- });
60
- }
61
- });
62
- _GxIdeRecentNews_evaluateNewsDisplay.set(this, () => {
63
- if (!__classPrivateFieldGet(this, _GxIdeRecentNews_newsRendered, "f") &&
64
- this.news.length > 0 &&
65
- __classPrivateFieldGet(this, _GxIdeRecentNews_newsContainerEl, "f") !== undefined) {
66
- __classPrivateFieldGet(this, _GxIdeRecentNews_displayNews, "f").call(this);
67
- __classPrivateFieldSet(this, _GxIdeRecentNews_newsRendered, true, "f");
68
- }
69
- });
70
- _GxIdeRecentNews_evaluateNewsRender.set(this, () => {
71
- var _a;
72
- if (this.newsLoadFailed) {
73
- return (h("gx-ide-empty-state", { stateIconSrc: NEWS_ICON, stateTitle: this._componentLocale.recentNews.newsNotFetched.title }, h("button", { class: "empty-state__button button-primary", onClick: __classPrivateFieldGet(this, _GxIdeRecentNews_getNews, "f") }, this._componentLocale.recentNews.newsNotFetched
74
- .tryAgainButtonLabel), h("a", { class: "text-link text-body-regular-s", href: this._componentLocale.recentNews.newsNotFetched.onlineNewsURL, target: "_blank" }, this._componentLocale.recentNews.newsNotFetched.readThemOnline)));
75
- }
76
- if (this.news.length === 0) {
77
- return (h("gx-ide-empty-state", { stateIconSrc: NEWS_ICON, stateTitle: this._componentLocale.recentNews.noNewsToDisplay.title }, h("a", { class: "empty-state__link text-body-regular-s", href: this._componentLocale.recentNews.onlineNewsURL, target: "_blank" }, this._componentLocale.recentNews.readThemOnline)));
78
- }
79
- if (((_a = this.filteredNews) === null || _a === void 0 ? void 0 : _a.length) === 0) {
80
- return (h("gx-ide-empty-state", { class: "news-empty-state", stateIconSrc: NEWS_ICON, stateTitle: this._componentLocale.recentNews.noNewsFiltered.title }));
81
- }
82
- return __classPrivateFieldGet(this, _GxIdeRecentNews_renderNewsList, "f").call(this);
83
- });
84
- _GxIdeRecentNews_getNews.set(this, async () => {
85
- this.loadingNews = true;
86
- const newsResult = await this.getNewsCallback();
87
- this.loadingNews = false;
88
- if (newsResult && newsResult.length > 0) {
89
- this.news = newsResult;
90
- this.newsLoadFailed = false;
91
- }
92
- else {
93
- this.newsLoadFailed = true;
94
- }
95
- });
96
- _GxIdeRecentNews_openNewsHandler.set(this, (newsId) => async () => {
97
- await this.openNewsCallback(newsId);
98
- });
99
- _GxIdeRecentNews_refreshFilteredNews.set(this, (filterValue, news) => {
100
- this.filteredNews = news.filter(singleNews => {
101
- var _a, _b;
102
- return ((_a = singleNews.title) === null || _a === void 0 ? void 0 : _a.toLowerCase().includes(filterValue)) ||
103
- ((_b = singleNews.body) === null || _b === void 0 ? void 0 : _b.toLowerCase().includes(filterValue));
104
- });
105
- });
106
- _GxIdeRecentNews_renderNewsItem.set(this, (news) => {
107
- if (news.id && news.title) {
108
- return (h("article", null, h("button", { class: {
109
- "card-small": true,
110
- "card-small--actionable": true,
111
- "card-news": true,
112
- [__classPrivateFieldGet(this, _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR, "f")]: true,
113
- "visible": __classPrivateFieldGet(this, _GxIdeRecentNews_newsRendered, "f")
114
- }, id: news.id, key: news.id, type: "button", onClick: __classPrivateFieldGet(this, _GxIdeRecentNews_openNewsHandler, "f").call(this, news.id) }, h("header", { class: "card-news__header" }, h("ch-image", { src: NEWS_ICON, class: "icon-md" }), h("h2", { class: config.headingsClasses.cardSmall }, hiChar(news.title, this.filterValue))), news.body && (h("p", { class: "text-body-regular-s" }, hiChar(news.body, this.filterValue))))));
115
- }
116
- return null;
117
- });
118
- _GxIdeRecentNews_renderNewsList.set(this, () => {
119
- var _a;
120
- return (h("div", { class: "news-container", ref: el => (__classPrivateFieldSet(this, _GxIdeRecentNews_newsContainerEl, el, "f")) }, (_a = this.filteredNews) === null || _a === void 0 ? void 0 : _a.map(__classPrivateFieldGet(this, _GxIdeRecentNews_renderNewsItem, "f"))));
121
- });
122
- this.filteredNews = [];
123
- this.loadingNews = true;
124
- this.news = [];
125
- this.newsLoadFailed = false;
126
- this.getNewsCallback = undefined;
127
- this.openNewsCallback = undefined;
128
- this.filterValue = "";
129
- }
130
- newsChanged(news) {
131
- __classPrivateFieldGet(this, _GxIdeRecentNews_refreshFilteredNews, "f").call(this, this.filterValue, news);
132
- __classPrivateFieldGet(this, _GxIdeRecentNews_displayNews, "f").call(this);
133
- }
134
- watchNews(newFilterValue) {
135
- __classPrivateFieldGet(this, _GxIdeRecentNews_refreshFilteredNews, "f").call(this, newFilterValue, this.news);
136
- }
137
- async componentWillLoad() {
138
- this._componentLocale = await Locale.getComponentStrings(this.el);
139
- }
140
- componentDidRender() {
141
- __classPrivateFieldGet(this, _GxIdeRecentNews_evaluateNewsDisplay, "f").call(this);
142
- }
143
- componentDidLoad() {
144
- __classPrivateFieldGet(this, _GxIdeRecentNews_getNews, "f").call(this);
145
- }
146
- render() {
147
- return (h(Host
148
- // Improve accessibility by announcing live changes
149
- , { "aria-live": "polite", "aria-busy": this.loadingNews ? "true" : "false", class: { empty: this.filteredNews.length === 0, scrollable: true } }, h("ch-theme", { model: CSS_BUNDLES }), this.loadingNews ? (h("gx-ide-loader", { abortTime: 8000, loaderTitle: this._componentLocale.loader.title, description: this._componentLocale.loader.description, show: true })) : (__classPrivateFieldGet(this, _GxIdeRecentNews_evaluateNewsRender, "f").call(this))));
150
- }
151
- static get assetsDirs() { return ["gx-ide-assets/recent-news"]; }
152
- get el() { return this; }
153
- static get watchers() { return {
154
- "news": ["newsChanged"],
155
- "filterValue": ["watchNews"]
156
- }; }
157
- static get style() { return recentNewsCss; }
158
- }, [1, "gx-ide-recent-news", {
159
- "getNewsCallback": [16],
160
- "openNewsCallback": [16],
161
- "filterValue": [1, "filter-value"],
162
- "filteredNews": [32],
163
- "loadingNews": [32],
164
- "news": [32],
165
- "newsLoadFailed": [32]
166
- }, undefined, {
167
- "news": ["newsChanged"],
168
- "filterValue": ["watchNews"]
169
- }]);
170
- _GxIdeRecentNews_NEWS_ITEM_CLASS_SELECTOR = new WeakMap(), _GxIdeRecentNews_newsRendered = new WeakMap(), _GxIdeRecentNews_setTimeOutNewsDelay = new WeakMap(), _GxIdeRecentNews_newsContainerEl = new WeakMap(), _GxIdeRecentNews_displayNews = new WeakMap(), _GxIdeRecentNews_evaluateNewsDisplay = new WeakMap(), _GxIdeRecentNews_evaluateNewsRender = new WeakMap(), _GxIdeRecentNews_getNews = new WeakMap(), _GxIdeRecentNews_openNewsHandler = new WeakMap(), _GxIdeRecentNews_refreshFilteredNews = new WeakMap(), _GxIdeRecentNews_renderNewsItem = new WeakMap(), _GxIdeRecentNews_renderNewsList = new WeakMap();
171
- function defineCustomElement() {
172
- if (typeof customElements === "undefined") {
173
- return;
174
- }
175
- const components = ["gx-ide-recent-news", "gx-ide-empty-state", "gx-ide-loader"];
176
- components.forEach(tagName => { switch (tagName) {
177
- case "gx-ide-recent-news":
178
- if (!customElements.get(tagName)) {
179
- customElements.define(tagName, GxIdeRecentNews);
180
- }
181
- break;
182
- case "gx-ide-empty-state":
183
- if (!customElements.get(tagName)) {
184
- defineCustomElement$2();
185
- }
186
- break;
187
- case "gx-ide-loader":
188
- if (!customElements.get(tagName)) {
189
- defineCustomElement$1();
190
- }
191
- break;
192
- } });
193
- }
194
-
195
- export { GxIdeRecentNews as G, defineCustomElement as d };
196
-
197
- //# sourceMappingURL=recent-news.js.map
@@ -1 +0,0 @@
1
- {"file":"recent-news.js","mappings":"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","names":[],"sources":["src/components/start-page/recent-news.scss?tag=gx-ide-recent-news&encapsulation=shadow","src/components/start-page/recent-news.tsx"],"sourcesContent":["@import \"../../global/gx-ide-common.scss\";\n@import \"../../global/gx-ide-mixins.scss\";\n\n@include hiChar();\n\n:host(.empty) {\n overflow: hidden !important; // WA to avoid scrollbar \"flickering\"\n}\n.news-container {\n display: grid;\n gap: var(--mer-spacing--xs);\n grid-auto-rows: max-content;\n // padding-inline-end: var(--mer-spacing--xs);\n}\n.news-item {\n opacity: 0;\n transition: 150ms opacity;\n\n &.visible {\n opacity: 1;\n }\n}\n.card-news {\n display: flex;\n flex-direction: column;\n align-items: start;\n gap: var(--mer-spacing--xs);\n\n &__header {\n display: flex;\n gap: var(--mer-spacing--sm);\n align-items: center;\n }\n}\n\ngx-ide-loader::part(loader-wrapper) {\n border: var(--mer-border__width--sm) solid\n var(--mer-border-color__on-elevation--01);\n border-radius: var(--mer-border__radius--md);\n}\n\n.text-link {\n color: var(--mer-accent__primary);\n\n &:hover {\n text-decoration: underline;\n }\n}\n","import { Component, Host, h, Prop, Element, State, Watch } from \"@stencil/core\";\n\nimport { MercuryBundles, getIconPath } from \"@genexus/mercury\";\n\nimport { Locale } from \"../../common/locale\";\nimport { config } from \"../../common/config\";\nimport { hiChar } from \"../../common/helpers\";\nimport { NewsData, GetNewsCallback, OpenNewsCallback } from \"./start-page\";\n\nconst NEWS_ICON = getIconPath({\n category: \"system\",\n name: \"news\",\n colorType: \"on-elevation\"\n});\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/button\",\n \"components/icon\",\n \"utils/typography\",\n \"utils/layout\",\n \"chameleon/scrollbar\"\n];\n@Component({\n tag: \"gx-ide-recent-news\",\n styleUrl: \"recent-news.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/recent-news\"]\n})\nexport class GxIdeRecentNews {\n /**\n * The component hard-coded strings translations.\n */\n private _componentLocale: any;\n\n #NEWS_ITEM_CLASS_SELECTOR = \"news-item\";\n #newsRendered = false;\n #setTimeOutNewsDelay = 75;\n\n @Element() el: HTMLGxIdeRecentNewsElement;\n\n #newsContainerEl: HTMLDivElement;\n\n /**\n * The list of news after the filter\n */\n @State() filteredNews: NewsData[] = [];\n\n /**\n * True if news are being requested\n */\n @State() loadingNews = true;\n\n /**\n * The list of news\n */\n @State() news: NewsData[] = [];\n @Watch(\"news\")\n newsChanged(news: NewsData[]) {\n this.#refreshFilteredNews(this.filterValue, news);\n this.#displayNews();\n }\n\n /**\n * True if news couldn't be loaded\n */\n @State() newsLoadFailed = false;\n\n /**\n * Callback invoked to load the news feed (right panel \"Recent News\").\n */\n @Prop() readonly getNewsCallback!: GetNewsCallback;\n\n /**\n * Callback invoked to open a news article.\n */\n @Prop() readonly openNewsCallback!: OpenNewsCallback;\n\n /**\n * The news filter value inserted by the user on the news input filter\n */\n @Prop() readonly filterValue: string = \"\";\n @Watch(\"filterValue\")\n watchNews(newFilterValue: string) {\n this.#refreshFilteredNews(newFilterValue, this.news);\n }\n\n async componentWillLoad() {\n this._componentLocale = await Locale.getComponentStrings(this.el);\n }\n\n componentDidRender() {\n this.#evaluateNewsDisplay();\n }\n\n componentDidLoad() {\n this.#getNews();\n }\n\n #displayNews = () => {\n if (this.#newsContainerEl !== undefined) {\n const news = Array.from(\n this.#newsContainerEl.querySelectorAll(\n `.${this.#NEWS_ITEM_CLASS_SELECTOR}`\n )\n );\n news.forEach(news => {\n // display news with a cascade effect\n setTimeout(() => {\n news.classList.add(\"visible\");\n }, this.#setTimeOutNewsDelay);\n this.#setTimeOutNewsDelay += 45;\n });\n }\n };\n\n #evaluateNewsDisplay = () => {\n if (\n !this.#newsRendered &&\n this.news.length > 0 &&\n this.#newsContainerEl !== undefined\n ) {\n this.#displayNews();\n this.#newsRendered = true;\n }\n };\n\n #evaluateNewsRender = (): HTMLElement => {\n if (this.newsLoadFailed) {\n return (\n <gx-ide-empty-state\n stateIconSrc={NEWS_ICON}\n stateTitle={this._componentLocale.recentNews.newsNotFetched.title}\n >\n <button\n class=\"empty-state__button button-primary\"\n onClick={this.#getNews}\n >\n {\n this._componentLocale.recentNews.newsNotFetched\n .tryAgainButtonLabel\n }\n </button>\n <a\n class=\"text-link text-body-regular-s\"\n href={this._componentLocale.recentNews.newsNotFetched.onlineNewsURL}\n target=\"_blank\"\n >\n {this._componentLocale.recentNews.newsNotFetched.readThemOnline}\n </a>\n </gx-ide-empty-state>\n );\n }\n if (this.news.length === 0) {\n return (\n <gx-ide-empty-state\n stateIconSrc={NEWS_ICON}\n stateTitle={this._componentLocale.recentNews.noNewsToDisplay.title}\n >\n <a\n class=\"empty-state__link text-body-regular-s\"\n href={this._componentLocale.recentNews.onlineNewsURL}\n target=\"_blank\"\n >\n {this._componentLocale.recentNews.readThemOnline}\n </a>\n </gx-ide-empty-state>\n );\n }\n if (this.filteredNews?.length === 0) {\n return (\n <gx-ide-empty-state\n class=\"news-empty-state\"\n stateIconSrc={NEWS_ICON}\n stateTitle={this._componentLocale.recentNews.noNewsFiltered.title}\n ></gx-ide-empty-state>\n );\n }\n return this.#renderNewsList();\n };\n\n #getNews = async () => {\n this.loadingNews = true;\n const newsResult = await this.getNewsCallback();\n this.loadingNews = false;\n if (newsResult && newsResult.length > 0) {\n this.news = newsResult;\n this.newsLoadFailed = false;\n } else {\n this.newsLoadFailed = true;\n }\n };\n\n #openNewsHandler = (newsId: string) => async () => {\n await this.openNewsCallback(newsId);\n };\n\n #refreshFilteredNews = (filterValue: string, news: NewsData[]) => {\n this.filteredNews = news.filter(\n singleNews =>\n singleNews.title?.toLowerCase().includes(filterValue) ||\n singleNews.body?.toLowerCase().includes(filterValue)\n );\n };\n\n #renderNewsItem = (news: NewsData): HTMLGxgCardElement | null => {\n if (news.id && news.title) {\n return (\n <article>\n <button\n class={{\n \"card-small\": true,\n \"card-small--actionable\": true,\n \"card-news\": true,\n [this.#NEWS_ITEM_CLASS_SELECTOR]: true,\n \"visible\": this.#newsRendered\n }}\n id={news.id}\n key={news.id}\n type=\"button\"\n onClick={this.#openNewsHandler(news.id)}\n >\n <header class=\"card-news__header\">\n <ch-image src={NEWS_ICON} class=\"icon-md\"></ch-image>\n <h2 class={config.headingsClasses.cardSmall}>\n {hiChar(news.title, this.filterValue)}\n </h2>\n </header>\n {news.body && (\n <p class=\"text-body-regular-s\">\n {hiChar(news.body, this.filterValue)}\n </p>\n )}\n </button>\n </article>\n );\n }\n return null;\n };\n\n #renderNewsList = (): HTMLElement => (\n <div\n class=\"news-container\"\n ref={el => (this.#newsContainerEl = el as HTMLDivElement)}\n >\n {this.filteredNews?.map(this.#renderNewsItem)}\n </div>\n );\n\n render() {\n return (\n <Host\n // Improve accessibility by announcing live changes\n aria-live=\"polite\"\n // Wait until all changes are made to prevents assistive\n // technologies from announcing changes before updates are done\n aria-busy={this.loadingNews ? \"true\" : \"false\"}\n class={{ empty: this.filteredNews.length === 0, scrollable: true }}\n >\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n {this.loadingNews ? (\n <gx-ide-loader\n abortTime={8000}\n loaderTitle={this._componentLocale.loader.title}\n description={this._componentLocale.loader.description}\n show={true}\n ></gx-ide-loader>\n ) : (\n this.#evaluateNewsRender()\n )}\n </Host>\n );\n }\n}\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"form-validation-8b3f527c.js","mappings":"AAGA;MACa,oBAAoB,GAAG,CAClC,MAA+C,EAC/C,GAAQ;;IAER,MAAA,MAAM,CAAC,WAAW,0CAAE,OAAO,CAAC,OAAO;QACjC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;QACxB,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;QAChC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QAElC,MAAM,SAAS,GAAkB,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;QACjD,IAAI,SAAS,IAAI,QAAQ,IAAI,OAAO,CAAC,IAAI,EAAE,EAAE;YAC3C,SAAS,CAAC,gBAAgB,GAAG,OAAO,CAAC;YACrC,SAAS,CAAC,iBAAiB,GAAG,OAAO,CAAC;SACvC;aAAM,IAAI,SAAS,IAAI,CAAC,QAAQ,EAAE;YACjC,SAAS,CAAC,gBAAgB,GAAG,eAAe,CAAC;YAC7C,SAAS,CAAC,iBAAiB,GAAG,IAAI,CAAC;SACpC;KACF,CAAC,CAAC;AACL,EAAE;AAEF;AACA,MAAM,kCAAkC,GAAG;IACzC,aAAa,EAAE,gBAAgB;IAC/B,qBAAqB,EAAE,iBAAiB;IACxC,SAAS,EAAE,kBAAkB;CACrB,CAAC;AAEX,MAAM,gBAAgB,GAAG,CAAC,QAAiB,EAAE,OAAoB;IAC/D,MAAM,cAAc,GAAG,OAAO,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;IACrD,MAAM,UAAU,GACd,kCAAkC,CAChC,cAAiE,CAClE,CAAC;IACJ,IAAI,QAAQ,EAAE;QACZ,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;KACnC;SAAM;QACL,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;KACtC;AACH,CAAC,CAAC;MAEW,gBAAgB,GAAG,CAC9B,gBAAkC,EAClC,mBAAmD;IAEnD,MAAM,0BAA0B,GAAG,IAAI,GAAG,CAAC,mBAAmB,CAAC,CAAC;IAChE,gBAAgB,CAAC,WAAW,CAAC,OAAO,CAAC,WAAW;QAC9C,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC;QACjC,MAAM,aAAa,GAAG,WAAW,CAAC,QAAQ,CAAC;QAC3C,MAAM,gBAAgB,GAAG,0BAA0B,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAClE,IAAI,gBAAgB,aAAhB,gBAAgB,uBAAhB,gBAAgB,CAAE,SAAS,EAAE;;YAE/B,gBAAgB,CAAC,aAAa,EAAE,gBAAgB,CAAC,SAAS,CAAC,CAAC;YAC5D,0BAA0B,CAAC,GAAG,CAAC,QAAQ,kCAClC,gBAAgB,KACnB,QAAQ,EAAE,aAAa,EACvB,OAAO,EAAE,WAAW,CAAC,OAAO,IAC5B,CAAC;SACJ;KACF,CAAC,CAAC;;IAEH,OAAO,0BAA0B,CAAC;AACpC;;;;","names":[],"sources":["src/common/form-validation.ts"],"sourcesContent":["import { FormSubmitResult, ConnectionResultData } from \"../common/types\";\nimport { FormComponent } from \"@genexus/gemini/dist/types/common/interfaces\";\n\n// formSubmitValidation will be deprecated. use \"validateControls\" instead.\nexport const formSubmitValidation = (\n result: FormSubmitResult | ConnectionResultData,\n ref: any\n) => {\n result.fieldErrors?.forEach(element => {\n const key = element.key;\n const message = element.message;\n const hasError = element.hasError;\n\n const reference: FormComponent = ref[`${key}El`];\n if (reference && hasError && message.trim()) {\n reference.validationStatus = \"error\";\n reference.validationMessage = message;\n } else if (reference && !hasError) {\n reference.validationStatus = \"indeterminate\";\n reference.validationMessage = null;\n }\n });\n};\n\n// TODO: Improve the way we mark components with error. We must not use error classes.\nconst formElementsErrorClassesDictionary = {\n \"ch-checkbox\": \"checkbox-error\",\n \"ch-combo-box-render\": \"combo-box-error\",\n \"ch-edit\": \"form-input-error\"\n} as const;\n\nconst toggleErrorClass = (hasError: boolean, element: HTMLElement) => {\n const elementTagName = element.tagName.toLowerCase();\n const errorClass =\n formElementsErrorClassesDictionary[\n elementTagName as keyof typeof formElementsErrorClassesDictionary\n ];\n if (hasError) {\n element.classList.add(errorClass);\n } else {\n element.classList.remove(errorClass);\n }\n};\n\nexport const validateControls = (\n formSubmitResult: FormSubmitResult,\n validatableControls: Map<string, ControlValidation>\n): Map<string, ControlValidation> => {\n const validatableControlsUpdated = new Map(validatableControls);\n formSubmitResult.fieldErrors.forEach(fieldResult => {\n const fieldKey = fieldResult.key;\n const fieldHasError = fieldResult.hasError;\n const controlMapRecord = validatableControlsUpdated.get(fieldKey);\n if (controlMapRecord?.reference) {\n // toggle class to add or remove error style\n toggleErrorClass(fieldHasError, controlMapRecord.reference);\n validatableControlsUpdated.set(fieldKey, {\n ...controlMapRecord,\n hasError: fieldHasError,\n message: fieldResult.message\n });\n }\n });\n // return validatableControls updated.\n return validatableControlsUpdated;\n};\n\nexport type ControlValidation = {\n reference: HTMLElement;\n hasError: boolean;\n message: string;\n};\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"gx-ide-empty-state.gx-ide-loader.entry.js","mappings":";;AAAA,MAAM,kBAAkB,GAAG,gyZAAgyZ;;ACG3zZ,MAAMA,aAAW,GAAmB;IAClC,mBAAmB;IACnB,mBAAmB;IACnB,iBAAiB;IACjB,kBAAkB;CACnB,CAAC;MAOW,eAAe;;;0BAOa,KAAK;;;;;IAiB5C,MAAM;QACJ,QACE,EAAC,IAAI,IAAC,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,IACvC,gBAAU,KAAK,EAAEA,aAAW,GAAa,EACzC,eAAS,KAAK,EAAC,gBAAgB,IAC5B,IAAI,CAAC,YAAY,KAChB,YAAM,KAAK,EAAC,8BAA8B,IACxC,gBAAU,GAAG,EAAE,IAAI,CAAC,YAAY,EAAE,KAAK,EAAC,SAAS,GAAY,CACxD,CACR,EACD,WAAK,KAAK,EAAC,yBAAyB,IACjC,IAAI,CAAC,UAAU,KACd,UAAI,KAAK,EAAC,qBAAqB,IAAE,IAAI,CAAC,UAAU,CAAM,CACvD,EACA,IAAI,CAAC,gBAAgB,KACpB,SAAG,KAAK,EAAC,qBAAqB,IAAE,IAAI,CAAC,gBAAgB,CAAK,CAC3D,CACG,EACN,eAAa,CACL,CACL,EACP;KACH;;;;;AC7DH,MAAM,YAAY,GAAG,o+CAAo+C;;;;;;;;;;ACYz/C,MAAM,WAAW,GAAmB;IAClC,mBAAmB;IACnB,mBAAmB;IACnB,kBAAkB;CACnB,CAAC;MAMW,SAAS;;;;QACpB,8CAAiD;QA+CjD,mCAAiB;YACf,IAAI,IAAI,CAAC,cAAc,EAAE;gBACvB,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;YACD,YAAY,CAAC,uBAAA,IAAI,mCAAkB,CAAC,CAAC;YACrC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;SACnB,EAAC;QAEF,wCAAsB,MACpB,IAAI,CAAC,WAAW,KACd,eACE,cACE,KAAK,EAAC,kBAAkB,EACxB,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,uBAAA,IAAI,gCAAe,IAE3B,IAAI,CAAC,WAAW,CACV,CACL,CACP,EAAC;QAEJ,uCAAqB,MACnB,IAAI,CAAC,WAAW,IAAI,SAAG,KAAK,EAAC,oBAAoB,IAAE,IAAI,CAAC,WAAW,CAAK,EAAC;QAE3E,iCAAe,MACb,IAAI,CAAC,WAAW,IAAI,SAAG,KAAK,EAAC,qBAAqB,IAAE,IAAI,CAAC,WAAW,CAAK,EAAC;2BAnErD,IAAI;yBAKU,CAAC,GAAG,EAAE,GAAG,IAAI;;;;6BAoBS,KAAK;;oBAUhC,KAAK;;IAkCrC,MAAM;QACJ,QACE,EAAC,IAAI,QACH,gBAAU,KAAK,EAAE,WAAW,GAAa,EACxC,IAAI,CAAC,IAAI,KACR,WACE,KAAK,EAAE;gBACL,CAAC,iBAAiB,GAAG,IAAI;gBACzB,0BAA0B,EAAE,IAAI,CAAC,WAAW;aAC7C,EACD,IAAI,EAAC,gBAAgB,EACrB,OAAO,EAAC,EAAE,IAEV,WAAK,KAAK,EAAC,iBAAiB,GAAO,EACnC,WACE,KAAK,EAAE;gBACL,yBAAyB,EAAE,IAAI;gBAC/B,iCAAiC,EAC/B,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,WAAW;aAC9D,IAEA,uBAAA,IAAI,8BAAa,MAAjB,IAAI,CAAe,EACnB,uBAAA,IAAI,oCAAmB,MAAvB,IAAI,CAAqB,EACzB,uBAAA,IAAI,qCAAoB,MAAxB,IAAI,CAAsB,CACvB,CACF,CACP,CACI,EACP;KACH;;;;;;;","names":["CSS_BUNDLES"],"sources":["src/components/_helpers/empty-state/gx-ide-empty-state.scss?tag=gx-ide-empty-state&encapsulation=shadow","src/components/_helpers/empty-state/gx-ide-empty-state.tsx","src/components/_helpers/ide-loader/ide-loader.scss?tag=gx-ide-loader&encapsulation=shadow","src/components/_helpers/ide-loader/ide-loader.tsx"],"sourcesContent":["@import \"../../../global/gx-ide-common.scss\";\n\n:host {\n display: flex;\n align-items: center;\n justify-content: center;\n text-align: center;\n inline-size: 100%;\n position: relative;\n}\n:host(.animate) {\n animation: fadeIn var(--mer-timing--fast) forwards;\n inset-block-start: 0;\n}\n.main-container {\n max-width: 320px;\n margin: 0 auto;\n gap: var(--mer-spacing--md);\n padding: var(--mer-spacing--md);\n\n &__icon-wrapper {\n border: var(--mer-border__width--sm) dashed var(--mer-accent__primary);\n border-radius: 50%;\n min-width: 40px;\n min-height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n }\n\n &__content {\n gap: var(--mer-spacing--sm);\n }\n}\n.main-container,\n.main-container__content {\n display: flex;\n align-items: center;\n flex-direction: column;\n}\n\n@keyframes fadeIn {\n 0% {\n opacity: 0;\n inset-block-start: 5px;\n }\n}\n","import { Component, Host, h, Prop, Element } from \"@stencil/core\";\nimport { MercuryBundles } from \"@genexus/mercury\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/button\",\n \"components/icon\",\n \"utils/typography\"\n];\n\n@Component({\n tag: \"gx-ide-empty-state\",\n styleUrl: \"gx-ide-empty-state.scss\",\n shadow: true\n})\nexport class GxIdeEmptyState {\n @Element() el: HTMLGxIdeEmptyStateElement;\n\n /**\n * Includes a subtle entry animation\n */\n // eslint-disable-next-line @stencil-community/reserved-member-names\n @Prop() readonly isAnimated: boolean = false;\n\n /**\n * The state description\n */\n @Prop() readonly stateDescription?: string;\n\n /**\n * The state icon\n */\n @Prop() readonly stateIconSrc?: string;\n\n /**\n * The state title\n */\n @Prop() readonly stateTitle!: string;\n\n render() {\n return (\n <Host class={{ animate: this.isAnimated }}>\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <article class=\"main-container\">\n {this.stateIconSrc && (\n <span class=\"main-container__icon-wrapper\">\n <ch-image src={this.stateIconSrc} class=\"icon-md\"></ch-image>\n </span>\n )}\n <div class=\"main-container__content\">\n {this.stateTitle && (\n <h2 class=\"text-body-regular-m\">{this.stateTitle}</h2>\n )}\n {this.stateDescription && (\n <p class=\"text-body-regular-s\">{this.stateDescription}</p>\n )}\n </div>\n <slot></slot>\n </article>\n </Host>\n );\n }\n}\n",".loader {\n &__wrapper {\n position: absolute;\n border: none;\n opacity: 0;\n transition: var(--show-transition) opacity;\n inline-size: 100%;\n block-size: 100%;\n display: flex;\n background-color: var(--gxg-ide-loader-wrapper__background-color--from);\n backdrop-filter: var(--gxg-ide-loader-wrapper__backdrop-filter);\n padding: var(--gxg-ide-loader-wrapper__padding);\n flex-direction: column;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n color: var(--gxg-ide-loader-wrapper__color);\n z-index: 99; // WA to prevent tree-view chevron arrow to appear above.\n animation: fadeIn var(--mer-timing--fast) forwards;\n\n &--visible {\n opacity: 1;\n }\n }\n &__spinner {\n border: var(--gxg-ide-loader-spinner__border);\n border-block-start: var(--gxg-ide-loader-spinner__border-top);\n border-radius: 50%;\n animation: spinner 0.6s infinite linear;\n inline-size: var(--gxg-ide-loader-spinner__width);\n block-size: var(--gxg-ide-loader-spinner__width);\n flex-shrink: 0;\n opacity: 1;\n }\n\n &__content-wrapper {\n display: flex;\n text-align: center;\n flex-direction: column;\n margin-block-start: var(--gxg-ide-loader-content-wrapper__mbs);\n gap: var(--mer-spacing--md);\n max-block-size: var(--gxg-ide-loader-content-wrapper__max-width);\n &--hidden {\n display: none;\n }\n opacity: 1;\n }\n}\n\n/*background color animation*/\n@keyframes wrapper {\n 0% {\n background-color: var(--gxg-ide-loader-wrapper__background-color--from);\n }\n 100% {\n background-color: var(--gxg-ide-loader-wrapper__background-color--to);\n }\n}\n@keyframes spinner {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(359deg);\n }\n}\n\n:host([display-border]) {\n .loader {\n &__wrapper {\n border: 1px solid var(--mer-color__elevation--02);\n }\n }\n}\n\n@keyframes fadeIn {\n 0% {\n opacity: 0;\n }\n}\n","import {\n Component,\n Host,\n h,\n Prop,\n State,\n Event,\n EventEmitter\n} from \"@stencil/core\";\n\nimport { MercuryBundles } from \"@genexus/mercury\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/button\",\n \"utils/typography\"\n];\n@Component({\n tag: \"gx-ide-loader\",\n styleUrl: \"ide-loader.scss\",\n shadow: true\n})\nexport class IdeLoader {\n #timeoutReference: ReturnType<typeof setTimeout>;\n\n /**\n * shows the '.loader-wrapper'\n */\n @State() showWrapper = true;\n\n /**\n * The time the loader will await before abort.\n */\n @Prop() readonly abortTime: number = 5 * 60 * 1000; // 5 minutes\n\n /**\n * The cancel callback\n */\n @Prop() readonly cancelCallback: IdeLoaderCancelCallback;\n\n /**\n * The cancel button label (optional)\n */\n @Prop() readonly cancelLabel: string;\n\n /**\n * The loader description (optional)\n */\n @Prop() readonly description: string;\n\n /**\n * Displays a border all around\n */\n @Prop({ reflect: true }) readonly displayBorder: boolean = false;\n\n /**\n * The loader title (optional)\n */\n @Prop() readonly loaderTitle: string;\n\n /**\n * It shows the loader\n */\n @Prop({ mutable: true }) show = false;\n\n /**\n * This event is emitted when \"show\" is false.\n */\n @Event() loaderFinished: EventEmitter<void>;\n\n #cancelProcess = (): void => {\n if (this.cancelCallback) {\n this.cancelCallback();\n }\n clearTimeout(this.#timeoutReference);\n this.show = false;\n };\n\n #renderCancelButton = (): HTMLButtonElement | null =>\n this.cancelLabel && (\n <div>\n <button\n class=\"button-secondary\"\n type=\"button\"\n onClick={this.#cancelProcess}\n >\n {this.cancelLabel}\n </button>\n </div>\n );\n\n #renderDescription = (): HTMLParagraphElement | null =>\n this.description && <p class=\"text-body-italic-s\">{this.description}</p>;\n\n #renderTitle = (): HTMLParagraphElement | null =>\n this.loaderTitle && <p class=\"text-body-regular-m\">{this.loaderTitle}</p>;\n\n render() {\n return (\n <Host>\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n {this.show && (\n <div\n class={{\n [`loader__wrapper`]: true,\n \"loader__wrapper--visible\": this.showWrapper\n }}\n part=\"loader-wrapper\"\n popover=\"\"\n >\n <div class=\"loader__spinner\"></div>\n <div\n class={{\n \"loader__content-wrapper\": true,\n \"loader__content-wrapper--hidden\":\n !this.description && !this.loaderTitle && !this.cancelLabel\n }}\n >\n {this.#renderTitle()}\n {this.#renderDescription()}\n {this.#renderCancelButton()}\n </div>\n </div>\n )}\n </Host>\n );\n }\n}\n\nexport type IdeLoaderCancelCallback = () => void;\n"],"version":3}