@sankhyalabs/sankhyablocks 8.15.0-dev.7 → 8.15.0-dev.70

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 (382) hide show
  1. package/dist/cjs/{ConfigStorage-8009ecb2.js → ConfigStorage-9a53a42c.js} +94 -21
  2. package/dist/cjs/{DataFetcher-ba94ed5b.js → DataFetcher-515bda03.js} +7 -4
  3. package/dist/cjs/IExporterProvider-90690372.js +230 -0
  4. package/dist/cjs/{ISave-d68ce3cd.js → ISave-e91b70a7.js} +1 -0
  5. package/dist/cjs/RecordIDUtils-3735135c.js +43 -0
  6. package/dist/cjs/{SnkFormConfigManager-7d850fbc.js → SnkFormConfigManager-7b222c78.js} +23 -15
  7. package/dist/cjs/{SnkMessageBuilder-7293d0ad.js → SnkMessageBuilder-4a95fe86.js} +25 -13
  8. package/dist/cjs/{auth-fetcher-c8467c07.js → auth-fetcher-5acb0335.js} +1 -1
  9. package/dist/cjs/{dataunit-fetcher-14108bec.js → dataunit-fetcher-7a08e4dd.js} +409 -77
  10. package/dist/cjs/{form-config-fetcher-df043d3d.js → form-config-fetcher-3f430aee.js} +13 -1
  11. package/dist/cjs/index-f9e81701.js +2 -10
  12. package/dist/cjs/loader.cjs.js +1 -1
  13. package/dist/cjs/{pesquisa-fetcher-ef050a47.js → pesquisa-fetcher-916a935c.js} +12 -13
  14. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  15. package/dist/cjs/{snk-actions-button_2.cjs.entry.js → snk-actions-button_4.cjs.entry.js} +526 -8
  16. package/dist/cjs/snk-application.cjs.entry.js +68 -24
  17. package/dist/cjs/snk-attach.cjs.entry.js +430 -71
  18. package/dist/cjs/snk-crud.cjs.entry.js +124 -28
  19. package/dist/cjs/snk-data-exporter.cjs.entry.js +207 -83
  20. package/dist/cjs/snk-data-unit-3718477f.js +670 -0
  21. package/dist/cjs/snk-data-unit.cjs.entry.js +11 -2
  22. package/dist/cjs/snk-detail-view.cjs.entry.js +52 -13
  23. package/dist/cjs/snk-entity-list.cjs.entry.js +5 -3
  24. package/dist/cjs/snk-filter-bar.cjs.entry.js +70 -10
  25. package/dist/cjs/snk-filter-detail.cjs.entry.js +4 -1
  26. package/dist/cjs/snk-filter-item.cjs.entry.js +13 -6
  27. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  28. package/dist/cjs/snk-filter-modal.cjs.entry.js +2 -1
  29. package/dist/cjs/snk-filter-multi-select.cjs.entry.js +2 -1
  30. package/dist/cjs/snk-form-config.cjs.entry.js +47 -27
  31. package/dist/cjs/snk-form-view.cjs.entry.js +67 -0
  32. package/dist/cjs/snk-form.cjs.entry.js +60 -8
  33. package/dist/cjs/snk-grid.cjs.entry.js +199 -122
  34. package/dist/cjs/{snk-guides-viewer-e7f76399.js → snk-guides-viewer-7fb9e5a1.js} +56 -20
  35. package/dist/cjs/snk-guides-viewer.cjs.entry.js +10 -10
  36. package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +3 -1
  37. package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
  38. package/dist/cjs/snk-pesquisa.cjs.entry.js +1 -1
  39. package/dist/cjs/snk-simple-crud.cjs.entry.js +507 -39
  40. package/dist/cjs/snk-taskbar.cjs.entry.js +124 -15
  41. package/dist/cjs/{taskbar-elements-01b85b99.js → taskbar-elements-d9392685.js} +11 -11
  42. package/dist/collection/collection-manifest.json +8 -8
  43. package/dist/collection/components/snk-application/__mocks__/snk-application.js +7 -0
  44. package/dist/collection/components/snk-application/snk-application.js +122 -19
  45. package/dist/collection/components/snk-attach/snk-attach.js +220 -53
  46. package/dist/collection/components/snk-attach/structure/{crud-config-builder.js → builder/anexo-sistema-crud-config.builder.js} +1 -1
  47. package/dist/collection/components/snk-attach/structure/builder/attach-crud-config.builder.js +62 -0
  48. package/dist/collection/components/snk-attach/structure/{taskbar-builder.js → builder/taskbar-builder.js} +1 -1
  49. package/dist/collection/components/snk-attach/structure/fetcher/facade/fetcher.facade.js +1 -0
  50. package/dist/collection/components/snk-attach/structure/{data-unit-builder.js → fetcher/factory/anexo-sistema-data-unit.factory.js} +14 -11
  51. package/dist/collection/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.js +118 -0
  52. package/dist/collection/components/snk-attach/structure/index.js +6 -3
  53. package/dist/collection/components/snk-crud/interfaces/PropsCustomEditor.js +1 -0
  54. package/dist/collection/components/snk-crud/interfaces/PropsCustomRender.js +1 -0
  55. package/dist/collection/components/snk-crud/snk-crud.js +340 -19
  56. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +137 -2
  57. package/dist/collection/components/snk-crud/subcomponents/snk-form-view.js +161 -0
  58. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.css +11 -2
  59. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +163 -13
  60. package/dist/collection/components/snk-data-exporter/exporter-strategy/ClientSideExporterStrategy.js +90 -0
  61. package/dist/collection/components/snk-data-exporter/exporter-strategy/ServerSideExporterStrategy.js +68 -0
  62. package/dist/collection/components/snk-data-exporter/interfaces/IExporterProvider.js +54 -1
  63. package/dist/collection/components/snk-data-exporter/interfaces/IExporterStrategy.js +1 -0
  64. package/dist/collection/components/snk-data-exporter/providers/ClientSideExporterProvider.js +58 -0
  65. package/dist/collection/components/snk-data-exporter/providers/ServerSideExporterProvider.js +55 -0
  66. package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +44 -50
  67. package/dist/collection/components/snk-data-exporter/test/resources/ClientSideExporterStrategyResources.js +88 -0
  68. package/dist/collection/components/snk-data-exporter/utils/RecordIDUtils.js +38 -0
  69. package/dist/collection/components/snk-data-unit/snk-data-unit.js +500 -216
  70. package/dist/collection/components/snk-data-unit/test/resources/metadataMock.js +24 -0
  71. package/dist/collection/components/snk-entity-list/snk-entity-list.js +5 -3
  72. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-multi-select.js +2 -1
  73. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.js +3 -1
  74. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-detail.js +22 -1
  75. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.js +31 -6
  76. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +19 -1
  77. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +24 -1
  78. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +180 -5
  79. package/dist/collection/components/snk-filter-bar/utils/SnkFilterModalFactory.js +3 -1
  80. package/dist/collection/components/snk-form/snk-form.js +126 -5
  81. package/dist/collection/components/{snk-form → snk-form-config}/SnkFormConfigManager.js +22 -14
  82. package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.js +50 -30
  83. package/dist/collection/components/snk-grid/snk-grid.js +341 -115
  84. package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.js +130 -123
  85. package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.js +1 -1
  86. package/dist/collection/components/snk-pesquisa/snk-pesquisa.css +2 -4
  87. package/dist/collection/components/snk-simple-crud/regular-buttons.js +3 -0
  88. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +10 -2
  89. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +824 -22
  90. package/dist/collection/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.js +4 -2
  91. package/dist/collection/components/snk-taskbar/elements/taskbar-elements.js +11 -11
  92. package/dist/collection/components/snk-taskbar/snk-taskbar.css +17 -0
  93. package/dist/collection/components/snk-taskbar/snk-taskbar.js +167 -14
  94. package/dist/collection/lib/DefaultCustomFormatters/RmPrecisionCustomValueFormatter.js +35 -0
  95. package/dist/collection/lib/configs/ConfigStorage.js +86 -16
  96. package/dist/collection/lib/dataUnit/InMemoryLoader.js +15 -42
  97. package/dist/collection/lib/dataUnit/ValueFormatter.js +4 -0
  98. package/dist/collection/lib/dataUnit/dataUnitInMemoryUtils.js +33 -0
  99. package/dist/collection/lib/dataUnit/interfaces/InMemoryLoaderConfig.js +1 -0
  100. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +7 -4
  101. package/dist/collection/lib/http/data-fetcher/fetchers/{attach-fetcher.js → AttachFetcher/anexo-sistema-fetcher.js} +16 -15
  102. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/attach-fetcher.js +90 -0
  103. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/facade/attach-fetcher.facade.js +1 -0
  104. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/index.js +2 -0
  105. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/interfaces/IDelete.js +1 -0
  106. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/interfaces/IDownloadKey.js +1 -0
  107. package/dist/collection/lib/http/data-fetcher/fetchers/{fecthAttach → AttachFetcher}/interfaces/ISave.js +1 -0
  108. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/DataUnitDataLoader.js +3 -0
  109. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/cache/ArrayRepository.js +4 -0
  110. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/cache/PreloadManager.js +11 -13
  111. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/dataunit-fetcher.js +30 -2
  112. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/interfaces/IBuildRequestBodyLoadRowMetadata.js +1 -0
  113. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/interfaces/IRowMetadata.js +1 -0
  114. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy.js +87 -24
  115. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/test/resources/metadataMock.js +22 -0
  116. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +12 -0
  117. package/dist/collection/lib/http/data-fetcher/fetchers/parameters-fecher.js +21 -0
  118. package/dist/collection/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.js +6 -3
  119. package/dist/collection/lib/http/data-fetcher/fetchers/pesquisa-fetcher.js +12 -13
  120. package/dist/collection/lib/index.js +1 -1
  121. package/dist/collection/lib/message/SnkMessageBuilder.js +25 -32
  122. package/dist/collection/lib/message/resources/snk-attach.msg.js +13 -0
  123. package/dist/collection/lib/message/resources/snk-data-exporter.msg.js +2 -1
  124. package/dist/collection/lib/message/resources/snk-data-unit.msg.js +1 -0
  125. package/dist/collection/lib/message/resources/snk-simple-crud.msg.js +4 -0
  126. package/dist/collection/lib/utils/CrudUtils.js +13 -1
  127. package/dist/components/ConfigStorage.js +92 -19
  128. package/dist/components/DataFetcher.js +7 -4
  129. package/dist/components/IExporterProvider.js +298 -0
  130. package/dist/components/ISave.js +42 -0
  131. package/dist/components/SnkFormConfigManager.js +21 -13
  132. package/dist/components/SnkMessageBuilder.js +25 -13
  133. package/dist/components/dataunit-fetcher.js +185 -241
  134. package/dist/components/form-config-fetcher.js +12 -0
  135. package/dist/components/index.d.ts +6 -6
  136. package/dist/components/index2.js +198 -33
  137. package/dist/{esm/pesquisa-fetcher-dd3ca0a5.js → components/pesquisa-fetcher.js} +13 -14
  138. package/dist/components/snk-actions-button2.js +4 -10
  139. package/dist/components/snk-application2.js +66 -18
  140. package/dist/components/snk-attach2.js +485 -78
  141. package/dist/components/snk-crud.js +131 -23
  142. package/dist/components/snk-data-exporter2.js +202 -83
  143. package/dist/components/snk-data-unit2.js +463 -214
  144. package/dist/components/snk-detail-view2.js +137 -23
  145. package/dist/components/snk-entity-list.js +5 -3
  146. package/dist/components/snk-expression-item2.js +1 -1
  147. package/dist/components/snk-filter-bar2.js +74 -8
  148. package/dist/components/snk-filter-detail2.js +5 -1
  149. package/dist/components/snk-filter-item2.js +14 -6
  150. package/dist/components/snk-filter-modal.js +4 -2
  151. package/dist/components/snk-filter-multi-select.js +2 -1
  152. package/dist/components/snk-form-config2.js +46 -26
  153. package/dist/components/snk-form-view2.js +72 -1
  154. package/dist/components/snk-form.js +60 -5
  155. package/dist/components/snk-grid-config2.js +128 -102
  156. package/dist/components/snk-grid2.js +207 -119
  157. package/dist/components/snk-personalized-filter-editor.js +3 -1
  158. package/dist/components/snk-personalized-filter2.js +1 -1
  159. package/dist/components/snk-pesquisa2.js +1 -1
  160. package/dist/components/snk-simple-crud2.js +568 -35
  161. package/dist/components/snk-taskbar2.js +144 -29
  162. package/dist/components/taskbar-actions-button2.js +4 -2
  163. package/dist/esm/{ConfigStorage-1244b8b0.js → ConfigStorage-174101b9.js} +94 -21
  164. package/dist/esm/{DataFetcher-aa159c5a.js → DataFetcher-4b4b7beb.js} +7 -4
  165. package/dist/esm/IExporterProvider-ce2ca127.js +221 -0
  166. package/dist/esm/{ISave-4412b20c.js → ISave-d8c8bc59.js} +1 -0
  167. package/dist/esm/RecordIDUtils-87d02110.js +41 -0
  168. package/dist/esm/{SnkFormConfigManager-9be0e7d4.js → SnkFormConfigManager-3bdb3e1f.js} +23 -15
  169. package/dist/esm/{SnkMessageBuilder-ca843d1b.js → SnkMessageBuilder-3a767111.js} +25 -13
  170. package/dist/esm/{auth-fetcher-c05dc474.js → auth-fetcher-9f86c346.js} +1 -1
  171. package/dist/esm/{dataunit-fetcher-cbec1594.js → dataunit-fetcher-f3fa35b9.js} +392 -70
  172. package/dist/esm/{form-config-fetcher-36219cd3.js → form-config-fetcher-5d72aaf1.js} +13 -1
  173. package/dist/esm/index-a7d3d3f1.js +2 -10
  174. package/dist/esm/loader.js +1 -1
  175. package/dist/esm/pesquisa-fetcher-9cfab836.js +164 -0
  176. package/dist/esm/sankhyablocks.js +1 -1
  177. package/dist/esm/{snk-actions-button_2.entry.js → snk-actions-button_4.entry.js} +525 -9
  178. package/dist/esm/snk-application.entry.js +68 -24
  179. package/dist/esm/snk-attach.entry.js +430 -71
  180. package/dist/esm/snk-crud.entry.js +124 -28
  181. package/dist/esm/snk-data-exporter.entry.js +208 -84
  182. package/dist/esm/snk-data-unit-8d6afa43.js +668 -0
  183. package/dist/esm/snk-data-unit.entry.js +11 -2
  184. package/dist/esm/snk-detail-view.entry.js +52 -13
  185. package/dist/esm/snk-entity-list.entry.js +5 -3
  186. package/dist/esm/snk-filter-bar.entry.js +70 -10
  187. package/dist/esm/snk-filter-detail.entry.js +4 -1
  188. package/dist/esm/snk-filter-item.entry.js +13 -6
  189. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  190. package/dist/esm/snk-filter-modal.entry.js +2 -1
  191. package/dist/esm/snk-filter-multi-select.entry.js +2 -1
  192. package/dist/esm/snk-form-config.entry.js +48 -28
  193. package/dist/esm/snk-form-view.entry.js +67 -0
  194. package/dist/esm/snk-form.entry.js +60 -8
  195. package/dist/esm/snk-grid.entry.js +199 -122
  196. package/dist/esm/{snk-guides-viewer-c7aaf02a.js → snk-guides-viewer-dabd574c.js} +56 -20
  197. package/dist/esm/snk-guides-viewer.entry.js +10 -10
  198. package/dist/esm/snk-personalized-filter-editor.entry.js +3 -1
  199. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  200. package/dist/esm/snk-pesquisa.entry.js +1 -1
  201. package/dist/esm/snk-simple-crud.entry.js +500 -32
  202. package/dist/esm/snk-taskbar.entry.js +125 -16
  203. package/dist/esm/{taskbar-elements-d4d0b424.js → taskbar-elements-ad766858.js} +11 -11
  204. package/dist/sankhyablocks/{p-9695f78b.js → p-010d475f.js} +1 -1
  205. package/dist/sankhyablocks/p-109e0551.js +1 -0
  206. package/dist/sankhyablocks/p-1918789e.js +1 -0
  207. package/dist/sankhyablocks/p-19ba2e08.entry.js +1 -0
  208. package/dist/sankhyablocks/p-1c628fb2.entry.js +1 -0
  209. package/dist/sankhyablocks/p-1db45d26.entry.js +1 -0
  210. package/dist/sankhyablocks/p-1e9c3f95.entry.js +1 -0
  211. package/dist/sankhyablocks/{p-9e7d65a4.js → p-21749402.js} +1 -1
  212. package/dist/sankhyablocks/p-2a84e45b.entry.js +1 -0
  213. package/dist/sankhyablocks/p-2acc8816.entry.js +1 -0
  214. package/dist/sankhyablocks/p-2c9ea7b6.entry.js +1 -0
  215. package/dist/sankhyablocks/p-33718dfc.entry.js +1 -0
  216. package/dist/sankhyablocks/p-3e4c2cfe.entry.js +11 -0
  217. package/dist/sankhyablocks/p-4a8a149d.entry.js +1 -0
  218. package/dist/sankhyablocks/p-4ce73e88.js +1 -0
  219. package/dist/sankhyablocks/p-52df8935.entry.js +1 -0
  220. package/dist/sankhyablocks/p-54a5d52a.entry.js +1 -0
  221. package/dist/sankhyablocks/p-566f5f50.js +56 -0
  222. package/dist/sankhyablocks/{p-3520c088.entry.js → p-59dccb7a.entry.js} +1 -1
  223. package/dist/sankhyablocks/p-5bd78e4c.entry.js +1 -0
  224. package/dist/sankhyablocks/p-61dd89eb.js +1 -0
  225. package/dist/sankhyablocks/p-6b2be902.js +6 -0
  226. package/dist/sankhyablocks/p-70a4af56.entry.js +1 -0
  227. package/dist/sankhyablocks/p-9863d682.js +1 -0
  228. package/dist/sankhyablocks/{p-e6380c60.js → p-a6dfa396.js} +1 -1
  229. package/dist/sankhyablocks/{p-f514913b.entry.js → p-aa854fa8.entry.js} +1 -1
  230. package/dist/sankhyablocks/p-aa9c4099.entry.js +1 -0
  231. package/dist/sankhyablocks/p-b11aa1e0.entry.js +1 -0
  232. package/dist/sankhyablocks/p-b27114c4.js +1 -0
  233. package/dist/sankhyablocks/p-b643f746.entry.js +1 -0
  234. package/dist/sankhyablocks/p-bf2acf72.entry.js +1 -0
  235. package/dist/sankhyablocks/p-cfb98f51.entry.js +1 -0
  236. package/dist/sankhyablocks/{p-247a8b36.entry.js → p-d1791da2.entry.js} +1 -1
  237. package/dist/sankhyablocks/p-e0c27486.js +26 -0
  238. package/dist/sankhyablocks/p-e238279a.entry.js +1 -0
  239. package/dist/sankhyablocks/p-e8763234.entry.js +1 -0
  240. package/dist/sankhyablocks/p-eae66367.js +1 -0
  241. package/dist/sankhyablocks/p-fde91811.js +60 -0
  242. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  243. package/dist/types/components/snk-application/__mocks__/snk-application.d.ts +3 -0
  244. package/dist/types/components/snk-application/snk-application.d.ts +21 -2
  245. package/dist/types/components/snk-attach/{structure/crud-config-builder.d.ts → interfaces/ICrudConfig.d.ts} +1 -2
  246. package/dist/types/components/snk-attach/interfaces/TFetcherType.d.ts +1 -0
  247. package/dist/types/components/snk-attach/snk-attach.d.ts +33 -10
  248. package/dist/types/components/snk-attach/structure/builder/anexo-sistema-crud-config.builder.d.ts +2 -0
  249. package/dist/types/components/snk-attach/structure/builder/attach-crud-config.builder.d.ts +40 -0
  250. package/dist/types/components/snk-attach/structure/{taskbar-builder.d.ts → builder/taskbar-builder.d.ts} +1 -1
  251. package/dist/types/components/snk-attach/structure/fetcher/facade/fetcher.facade.d.ts +11 -0
  252. package/dist/types/components/snk-attach/structure/fetcher/factory/anexo-sistema-data-unit.factory.d.ts +17 -0
  253. package/dist/types/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.d.ts +16 -0
  254. package/dist/types/components/snk-attach/structure/index.d.ts +6 -3
  255. package/dist/types/components/snk-crud/interfaces/PropsCustomEditor.d.ts +4 -0
  256. package/dist/types/components/snk-crud/interfaces/PropsCustomRender.d.ts +4 -0
  257. package/dist/types/components/snk-crud/snk-crud.d.ts +53 -1
  258. package/dist/types/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.d.ts +24 -1
  259. package/dist/types/components/snk-crud/subcomponents/snk-form-view.d.ts +28 -3
  260. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +30 -1
  261. package/dist/types/components/snk-data-exporter/exporter-strategy/ClientSideExporterStrategy.d.ts +13 -0
  262. package/dist/types/components/snk-data-exporter/exporter-strategy/ServerSideExporterStrategy.d.ts +11 -0
  263. package/dist/types/components/snk-data-exporter/interfaces/IExporterProvider.d.ts +24 -4
  264. package/dist/types/components/snk-data-exporter/interfaces/IExporterStrategy.d.ts +5 -0
  265. package/dist/types/components/snk-data-exporter/providers/ClientSideExporterProvider.d.ts +17 -0
  266. package/dist/types/components/snk-data-exporter/providers/ServerSideExporterProvider.d.ts +17 -0
  267. package/dist/types/components/snk-data-exporter/snk-data-exporter.d.ts +3 -1
  268. package/dist/types/components/snk-data-exporter/test/resources/ClientSideExporterStrategyResources.d.ts +77 -0
  269. package/dist/types/components/snk-data-exporter/utils/RecordIDUtils.d.ts +3 -0
  270. package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +61 -2
  271. package/dist/types/components/snk-data-unit/test/resources/metadataMock.d.ts +3 -0
  272. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-detail.d.ts +4 -0
  273. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +7 -3
  274. package/dist/types/components/snk-filter-bar/filter-modal/snk-filter-modal.d.ts +5 -0
  275. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +31 -1
  276. package/dist/types/components/snk-filter-bar/utils/SnkFilterModalFactory.d.ts +3 -1
  277. package/dist/types/components/snk-form/snk-form.d.ts +20 -1
  278. package/dist/types/components/{snk-form → snk-form-config}/SnkFormConfigManager.d.ts +2 -1
  279. package/dist/types/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.d.ts +5 -3
  280. package/dist/types/components/snk-grid/snk-grid.d.ts +65 -7
  281. package/dist/types/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.d.ts +11 -6
  282. package/dist/types/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.d.ts +1 -1
  283. package/dist/types/components/snk-simple-crud/regular-buttons.d.ts +3 -0
  284. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +138 -6
  285. package/dist/types/components/snk-taskbar/elements/taskbar-elements.d.ts +1 -1
  286. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +34 -1
  287. package/dist/types/components.d.ts +502 -16
  288. package/dist/types/lib/DefaultCustomFormatters/RmPrecisionCustomValueFormatter.d.ts +11 -0
  289. package/dist/types/lib/configs/ConfigStorage.d.ts +25 -1
  290. package/dist/types/lib/dataUnit/InMemoryLoader.d.ts +2 -3
  291. package/dist/types/lib/dataUnit/ValueFormatter.d.ts +2 -0
  292. package/dist/types/lib/dataUnit/dataUnitInMemoryUtils.d.ts +4 -0
  293. package/dist/types/lib/dataUnit/interfaces/InMemoryLoaderConfig.d.ts +3 -0
  294. package/dist/types/lib/http/data-fetcher/DataFetcher.d.ts +1 -1
  295. package/dist/types/lib/http/data-fetcher/fetchers/{attach-fetcher.d.ts → AttachFetcher/anexo-sistema-fetcher.d.ts} +3 -2
  296. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/attach-fetcher.d.ts +11 -0
  297. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/facade/attach-fetcher.facade.d.ts +8 -0
  298. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/index.d.ts +3 -0
  299. package/dist/types/lib/http/data-fetcher/fetchers/{fecthAttach → AttachFetcher}/interfaces/ISave.d.ts +2 -1
  300. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/DataUnitDataLoader.d.ts +2 -1
  301. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/cache/ArrayRepository.d.ts +1 -0
  302. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/cache/PreloadManager.d.ts +1 -0
  303. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/dataunit-fetcher.d.ts +2 -0
  304. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/interfaces/IBuildRequestBodyLoadRowMetadata.d.ts +10 -0
  305. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/interfaces/IRowMetadata.d.ts +7 -0
  306. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy.d.ts +7 -0
  307. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/test/resources/metadataMock.d.ts +20 -0
  308. package/dist/types/lib/http/data-fetcher/fetchers/fetchDataExporter/interfaces/IExporterColumnMetadata.d.ts +3 -0
  309. package/dist/types/lib/http/data-fetcher/fetchers/form-config-fetcher.d.ts +2 -0
  310. package/dist/types/lib/http/data-fetcher/fetchers/parameters-fecher.d.ts +1 -0
  311. package/dist/types/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.d.ts +2 -1
  312. package/dist/types/lib/http/data-fetcher/fetchers/pesquisa-fetcher.d.ts +1 -0
  313. package/dist/types/lib/index.d.ts +1 -1
  314. package/dist/types/lib/utils/CrudUtils.d.ts +3 -0
  315. package/package.json +15 -6
  316. package/dist/cjs/PreloadManager-84466da6.js +0 -224
  317. package/dist/cjs/SnkMultiSelectionListDataSource-ba5838c2.js +0 -49
  318. package/dist/cjs/snk-data-unit-1bc69073.js +0 -462
  319. package/dist/cjs/snk-grid-config.cjs.entry.js +0 -483
  320. package/dist/cjs/snk-select-box.cjs.entry.js +0 -25
  321. package/dist/collection/lib/http/data-fetcher/fetchers/fetchDataExporter/index.js +0 -34
  322. package/dist/components/field-search.js +0 -121
  323. package/dist/components/index3.js +0 -199
  324. package/dist/esm/PreloadManager-c1c2f2b4.js +0 -222
  325. package/dist/esm/SnkMultiSelectionListDataSource-44494b0e.js +0 -43
  326. package/dist/esm/snk-data-unit-6208ebf0.js +0 -460
  327. package/dist/esm/snk-grid-config.entry.js +0 -479
  328. package/dist/esm/snk-select-box.entry.js +0 -21
  329. package/dist/sankhyablocks/p-03dcc5ff.entry.js +0 -1
  330. package/dist/sankhyablocks/p-0874adb5.entry.js +0 -1
  331. package/dist/sankhyablocks/p-094c30cb.js +0 -1
  332. package/dist/sankhyablocks/p-0d7863ed.js +0 -26
  333. package/dist/sankhyablocks/p-11081798.entry.js +0 -1
  334. package/dist/sankhyablocks/p-20726710.entry.js +0 -1
  335. package/dist/sankhyablocks/p-25927311.entry.js +0 -1
  336. package/dist/sankhyablocks/p-32f0935f.js +0 -1
  337. package/dist/sankhyablocks/p-374d03f6.js +0 -1
  338. package/dist/sankhyablocks/p-3891ae6f.js +0 -60
  339. package/dist/sankhyablocks/p-4775a293.entry.js +0 -1
  340. package/dist/sankhyablocks/p-585294ee.js +0 -56
  341. package/dist/sankhyablocks/p-6977a26c.entry.js +0 -1
  342. package/dist/sankhyablocks/p-69efa80d.entry.js +0 -1
  343. package/dist/sankhyablocks/p-776ee8e3.js +0 -1
  344. package/dist/sankhyablocks/p-809f367d.entry.js +0 -1
  345. package/dist/sankhyablocks/p-8c243e7e.entry.js +0 -11
  346. package/dist/sankhyablocks/p-8d16f9ce.js +0 -1
  347. package/dist/sankhyablocks/p-8d70b5d5.entry.js +0 -1
  348. package/dist/sankhyablocks/p-98674137.entry.js +0 -1
  349. package/dist/sankhyablocks/p-a9e5b094.entry.js +0 -1
  350. package/dist/sankhyablocks/p-c22c1d8e.js +0 -1
  351. package/dist/sankhyablocks/p-c4d19840.entry.js +0 -1
  352. package/dist/sankhyablocks/p-c627ba91.entry.js +0 -1
  353. package/dist/sankhyablocks/p-c758265f.entry.js +0 -1
  354. package/dist/sankhyablocks/p-cb7419e0.entry.js +0 -1
  355. package/dist/sankhyablocks/p-d4f9ee17.entry.js +0 -1
  356. package/dist/sankhyablocks/p-d6317851.entry.js +0 -1
  357. package/dist/sankhyablocks/p-d81f20c4.entry.js +0 -1
  358. package/dist/sankhyablocks/p-d9bb09b3.js +0 -6
  359. package/dist/sankhyablocks/p-dc8b6418.entry.js +0 -1
  360. package/dist/sankhyablocks/p-f2056f66.entry.js +0 -1
  361. package/dist/sankhyablocks/p-fd8814b9.entry.js +0 -1
  362. package/dist/sankhyablocks/p-ff6064e7.js +0 -1
  363. package/dist/types/components/snk-attach/structure/data-unit-builder.d.ts +0 -15
  364. package/dist/types/lib/http/data-fetcher/fetchers/fetchDataExporter/index.d.ts +0 -3
  365. /package/dist/collection/{lib/http/data-fetcher/fetchers/fecthAttach/interfaces/IDelete.js → components/snk-attach/interfaces/ICrudConfig.js} +0 -0
  366. /package/dist/collection/{lib/http/data-fetcher/fetchers/fecthAttach/interfaces/IDownloadKey.js → components/snk-attach/interfaces/TFetcherType.js} +0 -0
  367. /package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.css +0 -0
  368. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.css +0 -0
  369. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.js +0 -0
  370. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.css +0 -0
  371. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.js +0 -0
  372. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.css +0 -0
  373. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.js +0 -0
  374. /package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.css +0 -0
  375. /package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.css +0 -0
  376. /package/dist/collection/lib/http/data-fetcher/fetchers/{fecthAttach → AttachFetcher}/interfaces/index.js +0 -0
  377. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.d.ts +0 -0
  378. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.d.ts +0 -0
  379. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.d.ts +0 -0
  380. /package/dist/types/lib/http/data-fetcher/fetchers/{fecthAttach → AttachFetcher}/interfaces/IDelete.d.ts +0 -0
  381. /package/dist/types/lib/http/data-fetcher/fetchers/{fecthAttach → AttachFetcher}/interfaces/IDownloadKey.d.ts +0 -0
  382. /package/dist/types/lib/http/data-fetcher/fetchers/{fecthAttach → AttachFetcher}/interfaces/index.d.ts +0 -0
@@ -1,7 +1,46 @@
1
1
  import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
2
- import { Action, ObjectUtils, JSUtils, DataUnitAction, ApplicationContext, DataType } from '@sankhyalabs/core';
2
+ import { JSUtils, DataType, Action, ObjectUtils, DataUnitAction, StringUtils, ApplicationContext } from '@sankhyalabs/core';
3
3
  import { ApplicationUtils, DialogType } from '@sankhyalabs/ezui/dist/collection/utils';
4
4
  import { O as OperationMap, S as SnkMessageBuilder } from './SnkMessageBuilder.js';
5
+ import { g as getRecordValue, d as DatasetStrategy } from './dataunit-fetcher.js';
6
+
7
+ const getSelectedIDs = (dataUnit) => {
8
+ const selectionInfo = dataUnit.getSelectionInfo();
9
+ if (selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.isAllRecords()) {
10
+ return [];
11
+ }
12
+ const selectedRecordsIDsInfo = [];
13
+ const selectedRecords = selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.recordIds;
14
+ if ((selectedRecords === null || selectedRecords === void 0 ? void 0 : selectedRecords.length) > 0) {
15
+ selectedRecords.forEach(recordId => {
16
+ if (!dataUnit.isNewRecord(recordId)) {
17
+ /*
18
+ Esse if foi necessário para tratar corretamente o ID
19
+ do record quando está sendo utilizado no modo standAlone
20
+ isso não faz a exportação da grid funcionar no modo standAlone
21
+ mas deixa de causar erro nas oprações de CRUD.
22
+ */
23
+ if (!JSUtils.isBase64(recordId)) {
24
+ selectedRecordsIDsInfo.push({
25
+ name: "__record__id__",
26
+ type: DataType.TEXT,
27
+ value: recordId
28
+ });
29
+ return;
30
+ }
31
+ const revertBase64ToObject = JSON.parse(window.atob(recordId));
32
+ Object.entries(revertBase64ToObject).forEach(([name, value]) => {
33
+ const metadataField = dataUnit === null || dataUnit === void 0 ? void 0 : dataUnit.getField(name);
34
+ if (metadataField == undefined) {
35
+ return;
36
+ }
37
+ selectedRecordsIDsInfo.push(Object.assign({ name, type: metadataField.dataType }, value));
38
+ });
39
+ }
40
+ });
41
+ }
42
+ return selectedRecordsIDsInfo;
43
+ };
5
44
 
6
45
  const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
7
46
  constructor() {
@@ -10,54 +49,37 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
10
49
  this.dataStateChange = createEvent(this, "dataStateChange", 3);
11
50
  this.dataUnitReady = createEvent(this, "dataUnitReady", 3);
12
51
  this.messagesBuilderUpdated = createEvent(this, "messagesBuilderUpdated", 3);
52
+ this.dataUnitFieldsHidded = createEvent(this, "dataUnitFieldsHidded", 7);
13
53
  this.insertionMode = createEvent(this, "insertionMode", 3);
14
54
  this.cancelEdition = createEvent(this, "cancelEdition", 3);
15
55
  this._onDataUnitResolve = [];
16
56
  this._openedAlert = false;
17
- this._dataUnitObserver = (action) => {
18
- var _a, _b;
19
- const duState = this.buildDataState();
57
+ this._fieldsWithRmp = [];
58
+ this._fieldsWithRmPrecision = [];
59
+ this._metadataByRow = new Map();
60
+ this._rowMetadataCache = new Map();
61
+ this.REGEX_DATAUNIT_NAME = /dd:\/\/(.+?)\//;
62
+ this._dataUnitObserver = async (action) => {
63
+ const duState = this.buildDataState(action.type);
20
64
  this.dataState = duState;
21
- if (action.type === Action.DATA_SAVED) {
22
- if (this.ignoreSaveMessage) {
23
- return;
24
- }
25
- const msg = this.getMessage("snkDataUnit.saveInfo", action.payload.records[0]);
26
- if (msg != undefined) {
27
- this.showSuccessMessage(msg);
28
- }
29
- }
30
- if (action.type === Action.RECORDS_ADDED || action.type === Action.RECORDS_COPIED) {
31
- this.insertionMode.emit();
32
- }
33
- if (action.type === Action.EDITION_CANCELED) {
34
- this.cancelEdition.emit();
35
- }
36
- if (action.type === Action.RECORDS_REMOVED) {
37
- const cachedRecords = action.payload.cachedRecords;
38
- let removeFinishMsg;
39
- if ((cachedRecords === null || cachedRecords === void 0 ? void 0 : cachedRecords.length) > 1) {
40
- removeFinishMsg = this.getMessage("snkDataUnit.removeAllInfo", { size: cachedRecords.length });
41
- }
42
- else {
43
- removeFinishMsg = this.getMessage("snkDataUnit.removeInfo", action.payload.cachedRecords[0]);
44
- }
45
- if (removeFinishMsg != undefined) {
46
- this.showSuccessMessage(removeFinishMsg);
47
- }
48
- const recordsCount = (_b = (_a = this.dataUnit.records) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0;
49
- const paginationInfo = this.dataUnit.getPaginationInfo();
50
- if (paginationInfo) {
51
- if (recordsCount > 0 || paginationInfo.hasMore) {
52
- this.dataUnit.gotoPage(paginationInfo.currentPage);
53
- }
54
- else {
55
- this.dataUnit.gotoPage(0);
56
- }
57
- }
58
- }
59
65
  this.messagesBuilder.currentOperation = this.getMessageOperation();
66
+ switch (action.type) {
67
+ case Action.DATA_SAVED:
68
+ await this.handleDataSaved(action);
69
+ break;
70
+ case Action.RECORDS_ADDED:
71
+ case Action.RECORDS_COPIED:
72
+ this.insertionMode.emit();
73
+ break;
74
+ case Action.EDITION_CANCELED:
75
+ this.cancelEdition.emit();
76
+ break;
77
+ case Action.RECORDS_REMOVED:
78
+ this.handleRecordsRemoved(action);
79
+ break;
80
+ }
60
81
  };
82
+ this.fieldsToLink = [];
61
83
  this.dataState = undefined;
62
84
  this.messagesBuilder = undefined;
63
85
  this.dataUnitName = undefined;
@@ -125,179 +147,336 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
125
147
  * @returns Retorna a lista de IDs dos registros selecionados.
126
148
  */
127
149
  async getSelectedRecordsIDsInfo() {
128
- var _a;
129
- const selectionInfo = (_a = this.dataUnit) === null || _a === void 0 ? void 0 : _a.getSelectionInfo();
130
- if (selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.isAllRecords()) {
131
- return [];
132
- }
133
- const selectedRecordsIDsInfo = [];
134
- const selectedRecords = selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.records;
135
- if ((selectedRecords === null || selectedRecords === void 0 ? void 0 : selectedRecords.length) > 0) {
136
- selectedRecords.forEach(({ __record__id__ }) => {
137
- if (!this.dataUnit.isNewRecord(__record__id__)) {
138
- /*
139
- Esse if foi necessário para tratar corretamente o ID
140
- do record quando está sendo utilizado no modo standAlone
141
- isso não faz a exportação da grid funcionar no modo standAlone
142
- mas deixa de causar erro nas oprações de CRUD.
143
- */
144
- if (!JSUtils.isBase64(__record__id__)) {
145
- selectedRecordsIDsInfo.push({
146
- name: "__record__id__",
147
- type: DataType.TEXT,
148
- value: __record__id__
149
- });
150
- return;
151
- }
152
- const revertBase64ToObject = JSON.parse(window.atob(__record__id__));
153
- Object.entries(revertBase64ToObject).forEach(([name, value]) => {
154
- var _a;
155
- const metadataField = (_a = this.dataUnit) === null || _a === void 0 ? void 0 : _a.getField(name);
156
- if (metadataField == undefined) {
157
- return;
158
- }
159
- selectedRecordsIDsInfo.push(Object.assign({ name, type: metadataField.dataType }, value));
160
- });
161
- }
162
- });
150
+ return Promise.resolve(getSelectedIDs(this.dataUnit));
151
+ }
152
+ /**
153
+ * Retorna os campos que possuem a propriedade "rmp" (Row Metadata Provider).
154
+ */
155
+ async getFieldsWithRmp() {
156
+ return this._fieldsWithRmp;
157
+ }
158
+ /**
159
+ * Retorna os campos que possuem a propriedade "rm_precision" (Row Metadata Precision).
160
+ */
161
+ async getFieldsWithRmPrecision() {
162
+ return this._fieldsWithRmPrecision;
163
+ }
164
+ /**
165
+ * Busca os metadados da linha selecionada.
166
+ */
167
+ async getRowMetadata(record) {
168
+ return this.doGetRowMetadata(record);
169
+ }
170
+ doGetRowMetadata(record) {
171
+ const selectedRecord = this.dataUnit.getSelectedRecord();
172
+ if (!record && !selectedRecord) {
173
+ return;
174
+ }
175
+ const currentRecord = record || selectedRecord;
176
+ const recordId = typeof currentRecord === 'string' ? currentRecord : currentRecord.__record__id__;
177
+ const rowMetadata = this._metadataByRow.get(recordId);
178
+ if (!rowMetadata) {
179
+ return;
180
+ }
181
+ rowMetadata.getProp = this.buildGetPropRowMetadata(rowMetadata);
182
+ return Object.assign({}, rowMetadata);
183
+ }
184
+ buildGetPropRowMetadata(rowMetadata) {
185
+ return (propPath, fieldName) => {
186
+ if (propPath === "rm_precision") {
187
+ propPath = this.resolvePrecisionFromMetadata(fieldName);
188
+ }
189
+ return ObjectUtils.getProp(rowMetadata, propPath);
190
+ };
191
+ }
192
+ resolvePrecisionFromMetadata(fieldName) {
193
+ var _a, _b;
194
+ if (!fieldName) {
195
+ ApplicationUtils.error(this.getMessage("snkDataUnit.fieldNameRequired"));
196
+ return;
197
+ }
198
+ const rmPrecision = (_b = (_a = this.dataUnit.getField(fieldName)) === null || _a === void 0 ? void 0 : _a.properties) === null || _b === void 0 ? void 0 : _b.rm_precision;
199
+ if (!rmPrecision) {
200
+ return '';
163
201
  }
164
- return selectedRecordsIDsInfo;
202
+ let rmPrecisionPath = rmPrecision.split('.').filter((_, index) => index !== 1).join('.');
203
+ return rmPrecisionPath;
165
204
  }
166
205
  getCleanOnCopyFields() {
167
206
  var _a;
168
207
  return (_a = this.dataUnit.metadata) === null || _a === void 0 ? void 0 : _a.fields.filter(field => { var _a; return (_a = field.properties) === null || _a === void 0 ? void 0 : _a.cleanOnCopy; }).map(field => field.name);
169
208
  }
170
- async interceptAction(action) {
171
- return new Promise(resolve => {
172
- var _a, _b, _c, _d, _e;
173
- switch (action.type) {
174
- case Action.RECORDS_ADDED:
175
- if (this.isAllowed("INSERT")) {
176
- resolve(action);
177
- }
178
- else {
179
- ApplicationUtils.info(this.getMessage("snkDataUnit.forbiddenInsert"));
180
- }
181
- break;
182
- case Action.RECORDS_COPIED:
183
- if (this.isAllowed("CLONE")) {
184
- const cleanFields = this.getCleanOnCopyFields();
185
- if (cleanFields.length > 0) {
186
- const records = action.payload;
187
- action = new DataUnitAction(Action.RECORDS_COPIED, records.map(record => {
188
- const newRecord = Object.assign({}, record);
189
- cleanFields.forEach(fieldName => delete newRecord[fieldName]);
190
- return newRecord;
191
- }));
192
- }
193
- resolve(action);
194
- }
195
- else {
196
- ApplicationUtils.info(this.getMessage("snkDataUnit.forbiddenClone"));
197
- }
198
- break;
199
- case Action.DATA_CHANGED:
200
- case Action.CHANGING_DATA:
201
- if (this.isAllowed("UPDATE"))
202
- return resolve(action);
203
- if (this._openedAlert)
204
- return this.dataUnit.cancelEdition();
205
- this._openedAlert = true;
206
- this.dataUnit.cancelEdition();
207
- ApplicationUtils.alert(this.getMessage("snkDataUnit.forbidden"), this.getMessage("snkDataUnit.forbiddenUpdate")).then(() => {
208
- this._openedAlert = false;
209
- });
210
- break;
211
- case Action.SAVING_DATA:
212
- if (this.beforeSave) {
213
- const continueAction = this.beforeSave(this.dataUnit);
214
- if (continueAction instanceof Promise) {
215
- continueAction.then(result => resolve(result ? action : undefined));
216
- }
217
- else {
218
- resolve(continueAction ? action : undefined);
219
- }
220
- }
221
- else {
222
- resolve(action);
223
- }
224
- break;
225
- case Action.DATA_SAVED:
226
- if (this.afterSave) {
227
- this.afterSave(this.dataUnit);
228
- }
229
- else {
230
- resolve(action);
231
- }
232
- break;
233
- case Action.EDITION_CANCELED:
234
- if (!this.useCancelConfirm)
235
- return resolve(action);
236
- if (this.dataState.hasDirtyRecords) {
237
- const cancelConfirmation = this.getMessage("snkDataUnit.cancelConfirmation");
238
- if (((_a = action.payload) === null || _a === void 0 ? void 0 : _a.fromParent) || ((_b = action.payload) === null || _b === void 0 ? void 0 : _b.silent)) {
239
- resolve(action);
240
- return;
241
- }
242
- if (cancelConfirmation == undefined) {
243
- this.showSuccessMessage(this.getMessage("snkDataUnit.cancelInfo"));
244
- resolve(action);
245
- }
246
- else {
247
- const cancelConfirmationTitle = this.getMessage("snkDataUnit.cancelConfirmationTitle");
248
- ApplicationUtils.confirm(cancelConfirmationTitle, cancelConfirmation)
249
- .then((result) => {
250
- result && this.showSuccessMessage(this.getMessage("snkDataUnit.cancelInfo"));
251
- resolve(result ? action : undefined);
252
- });
253
- }
254
- }
255
- else {
256
- resolve(action);
257
- }
258
- break;
259
- case Action.REMOVING_RECORDS:
260
- if (this.isAllowed("REMOVE")) {
261
- let multipleSelection = false;
262
- let removeConfirmation = !((_c = action.payload) === null || _c === void 0 ? void 0 : _c.silent) && this.getMessage("snkDataUnit.removeConfirmation");
263
- const selection = (_d = this.dataUnit) === null || _d === void 0 ? void 0 : _d.getSelectionInfo();
264
- if (!((_e = action.payload) === null || _e === void 0 ? void 0 : _e.silent) && (selection === null || selection === void 0 ? void 0 : selection.length) > 1) {
265
- removeConfirmation = this.getMessage("snkDataUnit.removeAllConfirmation", { size: selection.length });
266
- multipleSelection = true;
267
- }
268
- if (!removeConfirmation) {
269
- resolve(action);
270
- }
271
- else {
272
- const options = {
273
- canClose: false,
274
- labelCancel: this.getMessage(`snkDataUnit.confirm.${multipleSelection ? "no" : "cancel"}`),
275
- labelConfirm: this.getMessage(`snkDataUnit.confirm.${multipleSelection ? "yes" : "delete"}`),
276
- btnConfirmDanger: false
277
- };
278
- const removeConfirmationTitle = this.getMessage("snkDataUnit.removeConfirmationTitle");
279
- ApplicationUtils.confirm(removeConfirmationTitle, removeConfirmation, null, DialogType.WARN, options)
280
- .then((result) => resolve(result ? action : undefined));
281
- }
282
- }
283
- else {
284
- ApplicationUtils.info(this.getMessage("snkDataUnit.forbiddenRemove"));
285
- }
286
- break;
287
- default:
288
- resolve(action);
209
+ fillFieldsWithRmp(payload) {
210
+ payload.fields.forEach((field) => {
211
+ var _a;
212
+ if (((_a = field.properties) === null || _a === void 0 ? void 0 : _a.rmp) && !this._fieldsWithRmp.includes(field.name)) {
213
+ this._fieldsWithRmp.push(field.name);
214
+ }
215
+ });
216
+ }
217
+ fillFieldsWithRmPrecision(payload) {
218
+ payload.fields.forEach((field) => {
219
+ var _a;
220
+ if (((_a = field.properties) === null || _a === void 0 ? void 0 : _a.rm_precision) && !this._fieldsWithRmPrecision.includes(field.name)) {
221
+ this._fieldsWithRmPrecision.push(field.name);
222
+ }
223
+ });
224
+ }
225
+ getCacheName(fieldName, metadataName, fieldValue) {
226
+ const cacheName = [fieldName, metadataName, fieldValue].join("_");
227
+ return cacheName;
228
+ }
229
+ updateDataStateRmp(newValue) {
230
+ Object.assign(this.dataState.rowMetadata || {}, newValue);
231
+ }
232
+ saveCacheRmd(record) {
233
+ const rmd = record.__record__metadata__;
234
+ const keysRmd = Object.keys(rmd);
235
+ keysRmd.shift();
236
+ keysRmd.forEach((fieldName) => {
237
+ const fieldValue = getRecordValue(record, fieldName);
238
+ const cacheName = this.getCacheName(fieldName, rmd.provider, fieldValue);
239
+ this._rowMetadataCache.set(cacheName, Object.assign({}, rmd));
240
+ });
241
+ }
242
+ getMetadataByRow(payload) {
243
+ var _a;
244
+ if (!((_a = payload.records) === null || _a === void 0 ? void 0 : _a.length)) {
245
+ return payload;
246
+ }
247
+ if (!this._fieldsWithRmp.length) {
248
+ const records = payload.records.map((record) => {
249
+ delete record.__record__metadata__;
250
+ return record;
251
+ });
252
+ return Object.assign(Object.assign({}, payload), { records });
253
+ }
254
+ const records = payload.records.map((record) => {
255
+ if (!record.__record__metadata__) {
256
+ return record;
289
257
  }
258
+ this.saveCacheRmd(record);
259
+ const rowMetadata = Object.assign({}, record.__record__metadata__);
260
+ rowMetadata.getProp = this.buildGetPropRowMetadata(rowMetadata);
261
+ this._metadataByRow.set(record.__record__id__, rowMetadata);
262
+ delete record.__record__metadata__;
263
+ return record;
264
+ });
265
+ return Object.assign(Object.assign({}, payload), { records });
266
+ }
267
+ interceptRecordsAdded(action) {
268
+ if (!this.isAllowed("INSERT")) {
269
+ ApplicationUtils.info(this.getMessage("snkDataUnit.forbiddenInsert"));
270
+ return;
271
+ }
272
+ return new DataUnitAction(Action.RECORDS_ADDED, this.handleLinksWithParent(action.payload));
273
+ }
274
+ interceptRecordsCopied(action) {
275
+ if (!this.isAllowed("CLONE")) {
276
+ ApplicationUtils.info(this.getMessage("snkDataUnit.forbiddenClone"));
277
+ return;
278
+ }
279
+ return new DataUnitAction(Action.RECORDS_COPIED, this.handleRecordsCopied(action.payload));
280
+ }
281
+ async interceptDataChange(action) {
282
+ if (this.isAllowed("UPDATE")) {
283
+ return action;
284
+ }
285
+ if (this._openedAlert) {
286
+ await this.dataUnit.cancelEdition();
287
+ return;
288
+ }
289
+ this._openedAlert = true;
290
+ await this.dataUnit.cancelEdition();
291
+ await ApplicationUtils.alert(this.getMessage("snkDataUnit.forbidden"), this.getMessage("snkDataUnit.forbiddenUpdate"));
292
+ this._openedAlert = false;
293
+ }
294
+ async interceptSavingData(action) {
295
+ if (!this.beforeSave) {
296
+ return action;
297
+ }
298
+ const continueAction = this.beforeSave(this.dataUnit);
299
+ if (continueAction instanceof Promise) {
300
+ const result = await continueAction;
301
+ return result ? action : undefined;
302
+ }
303
+ return continueAction ? action : undefined;
304
+ }
305
+ interceptDataSaved(action) {
306
+ if (this.afterSave) {
307
+ this.afterSave(this.dataUnit);
308
+ return;
309
+ }
310
+ return action;
311
+ }
312
+ async interceptEditionCanceled(action) {
313
+ var _a, _b;
314
+ if (!this.useCancelConfirm || !this.dataState.hasDirtyRecords || ((_a = action.payload) === null || _a === void 0 ? void 0 : _a.fromParent) || ((_b = action.payload) === null || _b === void 0 ? void 0 : _b.silent)) {
315
+ return action;
316
+ }
317
+ const cancelConfirmation = this.getMessage("snkDataUnit.cancelConfirmation");
318
+ if (cancelConfirmation == undefined) {
319
+ this.showSuccessMessage(this.getMessage("snkDataUnit.cancelInfo"));
320
+ return action;
321
+ }
322
+ const cancelConfirmationTitle = this.getMessage("snkDataUnit.cancelConfirmationTitle");
323
+ const confirm = await ApplicationUtils.confirm(cancelConfirmationTitle, cancelConfirmation);
324
+ confirm && this.showSuccessMessage(this.getMessage("snkDataUnit.cancelInfo"));
325
+ return confirm ? action : undefined;
326
+ }
327
+ async interceptRemovingRecords(action) {
328
+ var _a, _b, _c;
329
+ if (!this.isAllowed("REMOVE")) {
330
+ ApplicationUtils.info(this.getMessage("snkDataUnit.forbiddenRemove"));
331
+ return;
332
+ }
333
+ let multipleSelection = false;
334
+ let removeConfirmation = !((_a = action.payload) === null || _a === void 0 ? void 0 : _a.silent) && this.getMessage("snkDataUnit.removeConfirmation");
335
+ const selection = (_b = this.dataUnit) === null || _b === void 0 ? void 0 : _b.getSelectionInfo();
336
+ if (!((_c = action.payload) === null || _c === void 0 ? void 0 : _c.silent) && (selection === null || selection === void 0 ? void 0 : selection.length) > 1) {
337
+ removeConfirmation = this.getMessage("snkDataUnit.removeAllConfirmation", { size: selection.length });
338
+ multipleSelection = true;
339
+ }
340
+ if (!removeConfirmation) {
341
+ return action;
342
+ }
343
+ const options = {
344
+ canClose: false,
345
+ labelCancel: this.getMessage(`snkDataUnit.confirm.${multipleSelection ? "no" : "cancel"}`),
346
+ labelConfirm: this.getMessage(`snkDataUnit.confirm.${multipleSelection ? "yes" : "delete"}`),
347
+ btnConfirmDanger: false
348
+ };
349
+ const removeConfirmationTitle = this.getMessage("snkDataUnit.removeConfirmationTitle");
350
+ const confirm = await ApplicationUtils.confirm(removeConfirmationTitle, removeConfirmation, null, DialogType.WARN, options);
351
+ return confirm ? action : undefined;
352
+ }
353
+ interceptDataLoaded(action) {
354
+ const newPayload = this.getMetadataByRow(action.payload);
355
+ action = new DataUnitAction(Action.DATA_LOADED, newPayload);
356
+ return action;
357
+ }
358
+ interceptMetadataLoaded(action) {
359
+ this.fillFieldsWithRmp(action.payload);
360
+ this.fillFieldsWithRmPrecision(action.payload);
361
+ return new DataUnitAction(Action.METADATA_LOADED, this.handleDULinksOnMetadataLoaded(action.payload));
362
+ }
363
+ async interceptAction(action) {
364
+ switch (action.type) {
365
+ case Action.RECORDS_ADDED:
366
+ return this.interceptRecordsAdded(action);
367
+ case Action.RECORDS_COPIED:
368
+ return this.interceptRecordsCopied(action);
369
+ case Action.DATA_CHANGED:
370
+ await this.handleLoadRowMetadata(action);
371
+ return await this.interceptDataChange(action);
372
+ case Action.CHANGING_DATA:
373
+ return await this.interceptDataChange(action);
374
+ case Action.SAVING_DATA:
375
+ return await this.interceptSavingData(action);
376
+ case Action.DATA_SAVED:
377
+ return this.interceptDataSaved(action);
378
+ case Action.EDITION_CANCELED:
379
+ return await this.interceptEditionCanceled(action);
380
+ case Action.REMOVING_RECORDS:
381
+ return await this.interceptRemovingRecords(action);
382
+ case Action.DATA_LOADED:
383
+ return this.interceptDataLoaded(action);
384
+ case Action.METADATA_LOADED:
385
+ return this.interceptMetadataLoaded(action);
386
+ default:
387
+ return action;
388
+ }
389
+ }
390
+ async handleLoadRowMetadata(action) {
391
+ const record = action.type === Action.DATA_CHANGED ? action.payload : action.payload.changes[0].record;
392
+ const keysPayload = Object.keys(record);
393
+ const rmpField = keysPayload.find((field) => this._fieldsWithRmp.includes(field));
394
+ if (rmpField) {
395
+ const metadataName = this.dataUnit.getField(rmpField).properties.rmp;
396
+ const fieldValue = getRecordValue(record, rmpField);
397
+ return await this.updateRowMetadata({
398
+ fieldName: rmpField,
399
+ fieldValue,
400
+ metadataName,
401
+ updatedFields: record,
402
+ });
403
+ }
404
+ }
405
+ async updateRowMetadata({ fieldName, fieldValue, metadataName, updatedFields }) {
406
+ const cacheName = this.getCacheName(fieldName, metadataName, fieldValue);
407
+ const cacheValue = this._rowMetadataCache.get(cacheName);
408
+ if (cacheValue) {
409
+ this.updateDataStateRmp(cacheValue);
410
+ return cacheValue;
411
+ }
412
+ else {
413
+ const datasetStrategy = new DatasetStrategy();
414
+ const response = await datasetStrategy.loadRowMetadata(this, fieldName, metadataName, updatedFields);
415
+ this.updateDataStateRmp(response._rmd);
416
+ this._rowMetadataCache.set(cacheName, Object.assign({}, response._rmd));
417
+ return Object.assign({}, response._rmd);
418
+ }
419
+ }
420
+ handleDULinksOnMetadataLoaded(payload) {
421
+ const metadata = Object.assign({}, payload);
422
+ this.processLinks(metadata);
423
+ return metadata;
424
+ }
425
+ handleRecordsCopied(initialRecords) {
426
+ let records = [...initialRecords];
427
+ records = this.handleCleanOnCopy(records);
428
+ return this.handleLinksWithParent(records);
429
+ }
430
+ handleLinksWithParent(records) {
431
+ var _a, _b;
432
+ const parentDataUnit = (_a = this._parentDataUnit) !== null && _a !== void 0 ? _a : (_b = this.dataUnit) === null || _b === void 0 ? void 0 : _b.getParentDataUnit();
433
+ if (!parentDataUnit)
434
+ return records;
435
+ const parentSelectedRecord = parentDataUnit.getSelectedRecord();
436
+ const selfInfo = parentDataUnit === null || parentDataUnit === void 0 ? void 0 : parentDataUnit.getChildInfo(this.getCleanDataUnitName());
437
+ const { links } = selfInfo;
438
+ if (!links || links.length === 0)
439
+ return records;
440
+ return records.map(record => {
441
+ return this.buildRecordWithLinkedFields(record, links, parentSelectedRecord);
290
442
  });
291
443
  }
444
+ buildRecordWithLinkedFields(record, links, parentSelectedRecord) {
445
+ const newRecord = Object.assign({}, record);
446
+ links.forEach(link => newRecord[link.target] = parentSelectedRecord[link.source]);
447
+ return newRecord;
448
+ }
449
+ handleCleanOnCopy(records) {
450
+ const cleanFields = this.getCleanOnCopyFields();
451
+ if (cleanFields.length > 0) {
452
+ records = records.map(record => this.buildCopyWithCleanedFields(record, cleanFields));
453
+ }
454
+ return records;
455
+ }
456
+ buildCopyWithCleanedFields(record, cleanFields) {
457
+ const newRecord = Object.assign({}, record);
458
+ cleanFields.forEach(fieldName => delete newRecord[fieldName]);
459
+ return newRecord;
460
+ }
292
461
  showSuccessMessage(message) {
293
462
  ApplicationUtils.info(message, { iconName: "check" });
294
463
  }
295
464
  isAllowed(flag) {
296
465
  return this._permissions ? this._permissions.isSup || this._permissions[flag] : false;
297
466
  }
298
- buildDataState() {
467
+ buildDataState(actionType) {
468
+ var _a;
299
469
  const selectionInfo = this.dataUnit.getSelectionInfo();
300
470
  const isStartingInsertionMode = (this.dataUnit.hasDirtyRecords() || this.dataUnit.hasWaitingChanges()) && (selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.isEmpty());
471
+ const selectedRecord = this.dataUnit.getSelectedRecord();
472
+ let rowMetadata = (_a = this.dataState) === null || _a === void 0 ? void 0 : _a.rowMetadata;
473
+ const allowedOverwrite = [Action.SELECTION_CHANGED, Action.EDITION_CANCELED, Action.NEXT_SELECTED, Action.PREVIOUS_SELECTED];
474
+ if (selectedRecord && (!rowMetadata || allowedOverwrite.includes(actionType))) {
475
+ rowMetadata = this.doGetRowMetadata(selectedRecord);
476
+ }
477
+ else if (rowMetadata) {
478
+ rowMetadata.getProp = this.buildGetPropRowMetadata(rowMetadata);
479
+ }
301
480
  return new DataStateImpl({
302
481
  insertionMode: this.dataUnit.hasNewRecord(),
303
482
  isStartingInsertionMode,
@@ -308,10 +487,48 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
308
487
  hasDirtyRecords: this.dataUnit.hasDirtyRecords(),
309
488
  selectedRecords: undefined,
310
489
  selectionInfo,
311
- selectedRecord: this.dataUnit.getSelectedRecord(),
312
- recordsIsEmpty: this.dataUnit.records.length === 0
490
+ selectedRecord,
491
+ recordsIsEmpty: this.dataUnit.records.length === 0,
492
+ metadataByRow: this._metadataByRow,
493
+ rowMetadata
313
494
  });
314
495
  }
496
+ async handleDataSaved(action) {
497
+ const newRowMetadata = await this.handleLoadRowMetadata(action);
498
+ if (newRowMetadata) {
499
+ newRowMetadata.getProp = this.buildGetPropRowMetadata(newRowMetadata);
500
+ }
501
+ const recordId = action.payload.records[0].__record__id__;
502
+ this._metadataByRow.set(recordId, newRowMetadata);
503
+ this.dataState = this.buildDataState();
504
+ if (this.ignoreSaveMessage) {
505
+ return;
506
+ }
507
+ const msg = this.getMessage("snkDataUnit.saveInfo", action.payload.records[0]);
508
+ if (msg != undefined) {
509
+ this.showSuccessMessage(msg);
510
+ }
511
+ }
512
+ handleRecordsRemoved(action) {
513
+ var _a, _b;
514
+ const cachedRecords = action.payload.cachedRecords;
515
+ let removeFinishMsg;
516
+ if ((cachedRecords === null || cachedRecords === void 0 ? void 0 : cachedRecords.length) > 1) {
517
+ removeFinishMsg = this.getMessage("snkDataUnit.removeAllInfo", { size: cachedRecords.length });
518
+ }
519
+ else {
520
+ removeFinishMsg = this.getMessage("snkDataUnit.removeInfo", action.payload.cachedRecords[0]);
521
+ }
522
+ if (removeFinishMsg != undefined) {
523
+ this.showSuccessMessage(removeFinishMsg);
524
+ }
525
+ const recordsCount = (_b = (_a = this.dataUnit.records) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0;
526
+ const paginationInfo = this.dataUnit.getPaginationInfo();
527
+ if (paginationInfo) {
528
+ const page = recordsCount > 0 || paginationInfo.hasMore ? paginationInfo.currentPage : 0;
529
+ this.dataUnit.gotoPage(page);
530
+ }
531
+ }
315
532
  /**
316
533
  * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
317
534
  * através de um pequeno modulo na estrutura da aplicação:
@@ -346,13 +563,14 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
346
563
  const cacheName = this.dataUnitName ? this.dataUnitName : this.entityName;
347
564
  if (this._parentSnkDataUnit) {
348
565
  this._parentDataUnit = await ((_a = this._parentSnkDataUnit) === null || _a === void 0 ? void 0 : _a.getDataUnit());
349
- return await this._application.getDataUnit(this.entityName, cacheName, this._parentDataUnit, this.configName, this.resourceID);
566
+ return await this._application.getDataUnit(this.entityName, cacheName, this._parentDataUnit, this.configName, this.resourceID, { skipLoadMetadata: true });
350
567
  }
351
568
  else {
352
- return await this._application.getDataUnit(this.entityName, cacheName, null, this.configName, this.resourceID);
569
+ return await this._application.getDataUnit(this.entityName, cacheName, null, this.configName, this.resourceID, { skipLoadMetadata: true });
353
570
  }
354
571
  }
355
572
  async loadDataUnit() {
573
+ var _a;
356
574
  if (this.dataUnit == null && this._application && this.entityName) {
357
575
  this.dataUnit = await this.getDataUnitParentOrChild();
358
576
  }
@@ -361,6 +579,10 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
361
579
  this.dataUnit.unsubscribe(this._dataUnitObserver);
362
580
  this.dataUnit.addInterceptor(this);
363
581
  this.dataUnit.subscribe(this._dataUnitObserver);
582
+ await this.dataUnit.loadMetadata();
583
+ if ((_a = this.dataUnit.records) === null || _a === void 0 ? void 0 : _a.length) {
584
+ this.getMetadataByRow(this.dataUnit);
585
+ }
364
586
  this.dataState = this.buildDataState();
365
587
  let resolver;
366
588
  while (resolver = this._onDataUnitResolve.pop()) {
@@ -379,20 +601,40 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
379
601
  return;
380
602
  }
381
603
  handlerLinkFields() {
382
- var _a, _b;
383
- const metadata = Object.assign({}, this.dataUnit.metadata);
384
- if (!this._parentDataUnit)
604
+ var _a, _b, _c, _d;
605
+ const parentDU = (_a = this._parentDataUnit) !== null && _a !== void 0 ? _a : (_b = this.dataUnit) === null || _b === void 0 ? void 0 : _b.getParentDataUnit();
606
+ if (!parentDU)
385
607
  return;
386
- const child = this._parentDataUnit.getChildInfo(this.entityName);
608
+ const childName = (_c = this.entityName) !== null && _c !== void 0 ? _c : this.getCleanDataUnitName();
609
+ const child = parentDU.getChildInfo(childName);
387
610
  if (!child)
388
611
  return;
389
- const fieldsLink = (_a = child === null || child === void 0 ? void 0 : child.links) === null || _a === void 0 ? void 0 : _a.map(link => link.target);
390
- (_b = metadata === null || metadata === void 0 ? void 0 : metadata.fields) === null || _b === void 0 ? void 0 : _b.forEach(field => {
391
- if (fieldsLink === null || fieldsLink === void 0 ? void 0 : fieldsLink.includes(field.name)) {
612
+ const links = (_d = child === null || child === void 0 ? void 0 : child.links) === null || _d === void 0 ? void 0 : _d.map(link => link.target);
613
+ this.handleDUWithLinks(links);
614
+ }
615
+ handleDUWithLinks(fieldsToLink) {
616
+ this.fieldsToLink = fieldsToLink;
617
+ const metadata = Object.assign({}, this.dataUnit.metadata);
618
+ this.processLinks(metadata);
619
+ this.dataUnit.metadata = metadata;
620
+ this.dataUnitFieldsHidded.emit();
621
+ }
622
+ processLinks(metadata) {
623
+ var _a;
624
+ (_a = metadata === null || metadata === void 0 ? void 0 : metadata.fields) === null || _a === void 0 ? void 0 : _a.forEach(field => {
625
+ var _a;
626
+ if ((_a = this.fieldsToLink) === null || _a === void 0 ? void 0 : _a.includes(field.name)) {
392
627
  field.visible = false;
393
628
  }
394
629
  });
395
- this.dataUnit.metadata = metadata;
630
+ }
631
+ getCleanDataUnitName() {
632
+ var _a;
633
+ const uri = this.dataUnit.name;
634
+ if (StringUtils.isEmpty(uri))
635
+ return uri;
636
+ const matcher = this.REGEX_DATAUNIT_NAME.exec(uri);
637
+ return (_a = matcher === null || matcher === void 0 ? void 0 : matcher[1]) !== null && _a !== void 0 ? _a : uri;
396
638
  }
397
639
  static getNearestInstance(element) {
398
640
  let parent = element.parentElement;
@@ -419,8 +661,9 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
419
661
  this.dataUnit.releaseCallbacks();
420
662
  }
421
663
  }
422
- componentDidLoad() {
423
- this.loadDataUnit();
664
+ async componentDidLoad() {
665
+ await this.loadDataUnit();
666
+ this.handlerLinkFields();
424
667
  }
425
668
  render() {
426
669
  return (h(Host, null));
@@ -447,8 +690,12 @@ const SnkDataUnit = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
447
690
  "ignoreSaveMessage": [4, "ignore-save-message"],
448
691
  "configName": [1, "config-name"],
449
692
  "resourceID": [1, "resource-i-d"],
693
+ "fieldsToLink": [32],
450
694
  "getDataUnit": [64],
451
- "getSelectedRecordsIDsInfo": [64]
695
+ "getSelectedRecordsIDsInfo": [64],
696
+ "getFieldsWithRmp": [64],
697
+ "getFieldsWithRmPrecision": [64],
698
+ "getRowMetadata": [64]
452
699
  }]);
453
700
  class DataStateImpl {
454
701
  constructor(datastate) {
@@ -462,6 +709,8 @@ class DataStateImpl {
462
709
  this.selectionInfo = datastate.selectionInfo;
463
710
  this.selectedRecord = datastate.selectedRecord;
464
711
  this.recordsIsEmpty = datastate.recordsIsEmpty;
712
+ this.metadataByRow = datastate.metadataByRow;
713
+ this.rowMetadata = datastate.rowMetadata;
465
714
  }
466
715
  get selectedRecords() {
467
716
  var _a;
@@ -486,4 +735,4 @@ function defineCustomElement() {
486
735
  } });
487
736
  }
488
737
 
489
- export { SnkDataUnit as S, defineCustomElement as d };
738
+ export { SnkDataUnit as S, defineCustomElement as d, getSelectedIDs as g };