@sankhyalabs/sankhyablocks 8.16.0-dev.6 → 8.16.0-dev.61

Sign up to get free protection for your applications and to get access to all the features.
Files changed (302) hide show
  1. package/dist/cjs/{ConfigStorage-a343e418.js → ConfigStorage-9b965af9.js} +2 -2
  2. package/dist/cjs/{IExporterProvider-597949f9.js → ContinuousInsertUtils-42636ac1.js} +64 -22
  3. package/dist/cjs/{DataFetcher-313debd8.js → DataFetcher-e059eb72.js} +28 -20
  4. package/dist/cjs/{RecordIDUtils-3735135c.js → GetSelectedRecordsIDsInfo-bd50caf1.js} +10 -10
  5. package/dist/cjs/{SnkFormConfigManager-166cbd1f.js → SnkFormConfigManager-51caf3d0.js} +72 -16
  6. package/dist/cjs/{SnkMessageBuilder-722b104e.js → SnkMessageBuilder-bae64d0d.js} +7 -3
  7. package/dist/cjs/{auth-fetcher-54f5ff9d.js → auth-fetcher-a78242d1.js} +1 -1
  8. package/dist/cjs/{dataunit-fetcher-688d3f05.js → dataunit-fetcher-228016f4.js} +48 -20
  9. package/dist/cjs/{field-search-f56aa7d6.js → field-search-68e34bf4.js} +5 -1
  10. package/dist/cjs/{form-config-fetcher-2dd00e5b.js → form-config-fetcher-91fba2b1.js} +42 -2
  11. package/dist/cjs/index-f9e81701.js +12 -32
  12. package/dist/cjs/loader.cjs.js +1 -1
  13. package/dist/cjs/{pesquisa-fetcher-680e198f.js → pesquisa-fetcher-2ec4811b.js} +10 -2
  14. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  15. package/dist/cjs/{snk-actions-button_4.cjs.entry.js → snk-actions-button_5.cjs.entry.js} +130 -36
  16. package/dist/cjs/snk-application.cjs.entry.js +119 -61
  17. package/dist/cjs/snk-attach.cjs.entry.js +46 -33
  18. package/dist/cjs/{snk-form-config.cjs.entry.js → snk-config-options_3.cjs.entry.js} +398 -12
  19. package/dist/cjs/snk-crud.cjs.entry.js +23 -8
  20. package/dist/cjs/snk-data-exporter.cjs.entry.js +23 -24
  21. package/dist/cjs/{snk-data-unit-685272e7.js → snk-data-unit-3d9b6ed4.js} +66 -34
  22. package/dist/cjs/snk-data-unit.cjs.entry.js +5 -5
  23. package/dist/cjs/snk-detail-view.cjs.entry.js +12 -12
  24. package/dist/cjs/snk-exporter-email-sender.cjs.entry.js +1 -1
  25. package/dist/cjs/snk-filter-bar_4.cjs.entry.js +1422 -0
  26. package/dist/cjs/snk-filter-binary-select.cjs.entry.js +1 -1
  27. package/dist/cjs/snk-filter-checkbox-list.cjs.entry.js +1 -1
  28. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  29. package/dist/cjs/snk-filter-text.cjs.entry.js +2 -1
  30. package/dist/cjs/snk-grid.cjs.entry.js +67 -21
  31. package/dist/cjs/{snk-guides-viewer-bdc41281.js → snk-guides-viewer-421555af.js} +29 -13
  32. package/dist/cjs/snk-guides-viewer.cjs.entry.js +9 -9
  33. package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +4 -4
  34. package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
  35. package/dist/cjs/snk-print-selector.cjs.entry.js +1 -1
  36. package/dist/cjs/snk-simple-bar.cjs.entry.js +1 -1
  37. package/dist/cjs/snk-simple-crud.cjs.entry.js +101 -44
  38. package/dist/cjs/snk-taskbar.cjs.entry.js +64 -38
  39. package/dist/collection/collection-manifest.json +12 -31
  40. package/dist/collection/components/snk-actions-button/actions/index.js +12 -9
  41. package/dist/collection/components/snk-actions-button/interfaces/index.js +1 -0
  42. package/dist/collection/components/snk-actions-button/snk-actions-button.js +27 -26
  43. package/dist/collection/components/snk-application/request-listener/DebouncedRequestListener.js +28 -0
  44. package/dist/collection/components/snk-application/request-listener/RequestListenerFactory.js +16 -0
  45. package/dist/collection/components/snk-application/request-listener/RequestListenerLoadingBar.js +52 -0
  46. package/dist/collection/components/snk-application/snk-application.js +44 -54
  47. package/dist/collection/components/snk-attach/snk-attach.js +25 -16
  48. package/dist/collection/components/snk-attach/structure/builder/taskbar-builder.js +8 -4
  49. package/dist/collection/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.js +2 -4
  50. package/dist/collection/components/snk-crud/snk-crud.js +122 -3
  51. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +3 -3
  52. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.css +6 -6
  53. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +72 -6
  54. package/dist/collection/components/snk-data-exporter/exporter-email-sender/options-step.js +1 -1
  55. package/dist/collection/components/snk-data-exporter/exporter-strategy/ClientSideExporterStrategy.js +7 -7
  56. package/dist/collection/components/snk-data-exporter/exporter-strategy/ServerSideExporterStrategy.js +5 -5
  57. package/dist/collection/components/snk-data-exporter/providers/ClientSideExporterProvider.js +1 -1
  58. package/dist/collection/components/snk-data-exporter/providers/ServerSideExporterProvider.js +1 -1
  59. package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +3 -5
  60. package/dist/collection/components/snk-data-exporter/structure/ItemBuilder.js +2 -2
  61. package/dist/collection/components/snk-data-exporter/test/resources/ClientSideExporterStrategyResources.js +4 -4
  62. package/dist/collection/components/snk-data-unit/snk-data-unit.js +81 -32
  63. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-binary-select.js +1 -1
  64. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-checkbox-list.js +1 -1
  65. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-text.js +2 -1
  66. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.css +13 -0
  67. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.js +3 -3
  68. package/dist/collection/components/snk-filter-bar/filter-item/filter-item-type-mask.enum.js +8 -0
  69. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.js +5 -1
  70. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +3 -1
  71. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +1 -1
  72. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +79 -21
  73. package/dist/collection/components/snk-form/snk-form.js +2 -2
  74. package/dist/collection/components/snk-form-config/SnkFormConfigManager.js +70 -14
  75. package/dist/collection/components/snk-form-config/snk-form-config.css +8 -3
  76. package/dist/collection/components/snk-form-config/snk-form-config.js +49 -8
  77. package/dist/collection/components/snk-grid/snk-grid.css +2 -0
  78. package/dist/collection/components/snk-grid/snk-grid.js +119 -8
  79. package/dist/collection/components/snk-print-selector/snk-print-selector.js +1 -1
  80. package/dist/collection/components/snk-simple-bar/snk-simple-bar.js +1 -1
  81. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +1 -1
  82. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +163 -35
  83. package/dist/collection/components/snk-simple-form-config/snk-simple-form-config.css +22 -0
  84. package/dist/collection/components/snk-simple-form-config/snk-simple-form-config.js +179 -0
  85. package/dist/collection/components/snk-taskbar/processor/taskbar-processor.js +5 -1
  86. package/dist/collection/components/snk-taskbar/snk-taskbar.js +106 -38
  87. package/dist/collection/lib/DefaultCustomFormatters/RmPrecisionCustomValueFormatter.js +3 -3
  88. package/dist/collection/lib/dataUnit/InMemoryLoader.js +2 -4
  89. package/dist/collection/lib/dataUnit/dataUnitInMemoryUtils.js +34 -9
  90. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +29 -21
  91. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.js +7 -5
  92. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/DataUnitDataLoader.js +2 -2
  93. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy.js +9 -2
  94. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +45 -5
  95. package/dist/collection/lib/http/data-fetcher/fetchers/parameters-fecher.js +7 -1
  96. package/dist/collection/lib/http/data-fetcher/fetchers/pesquisa-fetcher.js +10 -2
  97. package/dist/collection/lib/message/resources/snk-data-unit.msg.js +1 -1
  98. package/dist/collection/lib/message/resources/snk-exporter.msg.js +1 -1
  99. package/dist/collection/lib/message/resources/snk-grid.msg.js +5 -1
  100. package/dist/collection/lib/utils/ContinuousInsertUtils.js +31 -0
  101. package/dist/collection/lib/utils/CrudUtils.js +25 -16
  102. package/dist/collection/{components/snk-data-exporter/utils/RecordIDUtils.js → lib/utils/GetSelectedRecordsIDsInfo.js} +9 -9
  103. package/dist/collection/sw.js +46 -0
  104. package/dist/components/{IExporterProvider.js → ContinuousInsertUtils.js} +65 -21
  105. package/dist/components/DataFetcher.js +29 -21
  106. package/dist/{esm/RecordIDUtils-87d02110.js → components/GetSelectedRecordsIDsInfo.js} +10 -10
  107. package/dist/components/SnkFormConfigManager.js +70 -14
  108. package/dist/components/SnkMessageBuilder.js +7 -3
  109. package/dist/components/dataunit-fetcher.js +47 -17
  110. package/dist/components/form-config-fetcher.js +41 -1
  111. package/dist/components/index.d.ts +1 -0
  112. package/dist/components/index.js +1 -0
  113. package/dist/components/pesquisa-fetcher.js +10 -2
  114. package/dist/components/snk-actions-button2.js +39 -35
  115. package/dist/components/snk-application2.js +114 -55
  116. package/dist/components/snk-attach2.js +54 -59
  117. package/dist/components/snk-crud.js +84 -58
  118. package/dist/components/snk-data-exporter2.js +16 -17
  119. package/dist/components/snk-data-unit2.js +68 -72
  120. package/dist/components/snk-detail-view2.js +114 -104
  121. package/dist/components/snk-exporter-email-sender2.js +1 -1
  122. package/dist/components/snk-filter-bar2.js +41 -22
  123. package/dist/components/snk-filter-binary-select.js +1 -1
  124. package/dist/components/snk-filter-checkbox-list.js +1 -1
  125. package/dist/components/snk-filter-item2.js +5 -1
  126. package/dist/components/snk-filter-modal.js +3 -1
  127. package/dist/components/snk-filter-text.js +2 -1
  128. package/dist/components/snk-form-config2.js +34 -9
  129. package/dist/components/snk-form.js +2 -2
  130. package/dist/components/snk-grid2.js +62 -12
  131. package/dist/components/snk-personalized-filter-editor.js +4 -4
  132. package/dist/components/snk-print-selector.js +1 -1
  133. package/dist/components/snk-simple-bar2.js +1 -1
  134. package/dist/components/snk-simple-crud2.js +108 -64
  135. package/dist/components/snk-simple-form-config.d.ts +11 -0
  136. package/dist/components/snk-simple-form-config.js +6 -0
  137. package/dist/components/snk-simple-form-config2.js +119 -0
  138. package/dist/components/snk-taskbar2.js +66 -40
  139. package/dist/esm/{ConfigStorage-3806514e.js → ConfigStorage-ff99377a.js} +2 -2
  140. package/dist/esm/{IExporterProvider-63a188b6.js → ContinuousInsertUtils-071e0b6a.js} +65 -24
  141. package/dist/esm/{DataFetcher-c1baf61d.js → DataFetcher-5034df59.js} +29 -21
  142. package/dist/esm/GetSelectedRecordsIDsInfo-9fa41508.js +41 -0
  143. package/dist/esm/{SnkFormConfigManager-31b24066.js → SnkFormConfigManager-a7770e24.js} +72 -16
  144. package/dist/esm/{SnkMessageBuilder-89925609.js → SnkMessageBuilder-6fff4a4c.js} +7 -3
  145. package/dist/esm/{auth-fetcher-039abba3.js → auth-fetcher-0b78ca31.js} +1 -1
  146. package/dist/esm/{constants-8457af36.js → constants-7302ee87.js} +1 -1
  147. package/dist/esm/{dataunit-fetcher-264191b2.js → dataunit-fetcher-56cb648b.js} +48 -18
  148. package/dist/esm/{field-search-efbe307f.js → field-search-f8b1d91e.js} +5 -1
  149. package/dist/esm/{form-config-fetcher-30fb808f.js → form-config-fetcher-0c2620ef.js} +42 -2
  150. package/dist/esm/index-a7d3d3f1.js +12 -32
  151. package/dist/esm/loader.js +1 -1
  152. package/dist/esm/{pesquisa-fetcher-03c8f919.js → pesquisa-fetcher-24e5bba0.js} +11 -3
  153. package/dist/esm/sankhyablocks.js +1 -1
  154. package/dist/esm/{snk-actions-button_4.entry.js → snk-actions-button_5.entry.js} +132 -39
  155. package/dist/esm/snk-application.entry.js +119 -61
  156. package/dist/esm/snk-attach.entry.js +47 -34
  157. package/dist/esm/{snk-form-config.entry.js → snk-config-options_3.entry.js} +399 -15
  158. package/dist/esm/snk-configurator.entry.js +1 -1
  159. package/dist/esm/snk-crud.entry.js +24 -9
  160. package/dist/esm/snk-data-exporter.entry.js +24 -25
  161. package/dist/esm/{snk-data-unit-63f83504.js → snk-data-unit-9fa7d2b9.js} +66 -34
  162. package/dist/esm/snk-data-unit.entry.js +5 -5
  163. package/dist/esm/snk-detail-view.entry.js +13 -13
  164. package/dist/esm/snk-exporter-email-sender.entry.js +1 -1
  165. package/dist/esm/snk-field-config.entry.js +1 -1
  166. package/dist/esm/snk-filter-bar_4.entry.js +1415 -0
  167. package/dist/esm/snk-filter-binary-select.entry.js +1 -1
  168. package/dist/esm/snk-filter-checkbox-list.entry.js +1 -1
  169. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  170. package/dist/esm/snk-filter-text.entry.js +2 -1
  171. package/dist/esm/snk-grid.entry.js +62 -16
  172. package/dist/esm/{snk-guides-viewer-dda0fede.js → snk-guides-viewer-b740a1fe.js} +30 -14
  173. package/dist/esm/snk-guides-viewer.entry.js +9 -9
  174. package/dist/esm/snk-personalized-filter-editor.entry.js +4 -4
  175. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  176. package/dist/esm/snk-print-selector.entry.js +1 -1
  177. package/dist/esm/snk-simple-bar.entry.js +1 -1
  178. package/dist/esm/snk-simple-crud.entry.js +99 -42
  179. package/dist/esm/snk-tab-config.entry.js +1 -1
  180. package/dist/esm/snk-taskbar.entry.js +65 -39
  181. package/dist/sankhyablocks/p-00278e07.js +1 -0
  182. package/dist/sankhyablocks/p-036b4807.entry.js +1 -0
  183. package/dist/sankhyablocks/p-0d2a2e9e.entry.js +1 -0
  184. package/dist/sankhyablocks/p-16a1dd18.entry.js +1 -0
  185. package/dist/sankhyablocks/p-17425c72.js +1 -0
  186. package/dist/sankhyablocks/p-23736d75.js +1 -0
  187. package/dist/sankhyablocks/p-29643bef.entry.js +1 -0
  188. package/dist/sankhyablocks/{p-8eb67fa4.entry.js → p-2d3f9482.entry.js} +1 -1
  189. package/dist/sankhyablocks/p-342eeb3b.js +1 -0
  190. package/dist/sankhyablocks/{p-2c68b3ae.entry.js → p-35882caf.entry.js} +1 -1
  191. package/dist/sankhyablocks/p-365d8ed4.entry.js +1 -0
  192. package/dist/sankhyablocks/p-399e1b74.entry.js +1 -0
  193. package/dist/sankhyablocks/{p-7663f597.entry.js → p-41793e17.entry.js} +1 -1
  194. package/dist/sankhyablocks/{p-72fc257b.entry.js → p-434817f0.entry.js} +1 -1
  195. package/dist/sankhyablocks/p-47178038.entry.js +1 -0
  196. package/dist/sankhyablocks/p-47d24ac8.js +60 -0
  197. package/dist/sankhyablocks/p-53ae0296.entry.js +1 -0
  198. package/dist/sankhyablocks/{p-aaa3ee68.entry.js → p-5f157b09.entry.js} +1 -1
  199. package/dist/sankhyablocks/p-619aeac8.entry.js +1 -0
  200. package/dist/sankhyablocks/p-65650e05.entry.js +1 -0
  201. package/dist/sankhyablocks/p-72a451c8.js +1 -0
  202. package/dist/sankhyablocks/{p-52920496.js → p-763edad2.js} +1 -1
  203. package/dist/sankhyablocks/p-7dd49d15.js +1 -0
  204. package/dist/sankhyablocks/p-82274cb0.js +1 -0
  205. package/dist/sankhyablocks/p-89c92727.entry.js +1 -0
  206. package/dist/sankhyablocks/{p-c1d57831.entry.js → p-89da2953.entry.js} +1 -1
  207. package/dist/sankhyablocks/{p-95df461f.entry.js → p-8b4fc28f.entry.js} +1 -1
  208. package/dist/sankhyablocks/{p-41f8bfa3.entry.js → p-8c235d4c.entry.js} +1 -1
  209. package/dist/sankhyablocks/p-8cf0a9fe.entry.js +1 -0
  210. package/dist/sankhyablocks/{p-b0ef4383.js → p-95ce311a.js} +1 -1
  211. package/dist/sankhyablocks/p-acca8a69.js +26 -0
  212. package/dist/sankhyablocks/p-c271fbf1.js +1 -0
  213. package/dist/sankhyablocks/p-c2e468c9.entry.js +1 -0
  214. package/dist/sankhyablocks/p-c629c07a.entry.js +1 -0
  215. package/dist/sankhyablocks/p-cd8fa07b.entry.js +1 -0
  216. package/dist/sankhyablocks/p-e6683406.js +6 -0
  217. package/dist/sankhyablocks/{p-47db7e88.entry.js → p-e9432f45.entry.js} +1 -1
  218. package/dist/sankhyablocks/p-eda55eef.entry.js +11 -0
  219. package/dist/sankhyablocks/p-fcc662c6.js +1 -0
  220. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  221. package/dist/types/components/snk-actions-button/actions/index.d.ts +1 -0
  222. package/dist/types/components/snk-actions-button/interfaces/index.d.ts +3 -0
  223. package/dist/types/components/snk-actions-button/snk-actions-button.d.ts +3 -2
  224. package/dist/types/components/snk-application/request-listener/DebouncedRequestListener.d.ts +11 -0
  225. package/dist/types/components/snk-application/request-listener/RequestListenerFactory.d.ts +12 -0
  226. package/dist/types/components/snk-application/request-listener/RequestListenerLoadingBar.d.ts +13 -0
  227. package/dist/types/components/snk-application/snk-application.d.ts +9 -13
  228. package/dist/types/components/snk-attach/snk-attach.d.ts +1 -0
  229. package/dist/types/components/snk-crud/snk-crud.d.ts +21 -0
  230. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +15 -0
  231. package/dist/types/components/snk-data-exporter/test/resources/ClientSideExporterStrategyResources.d.ts +3 -3
  232. package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +7 -0
  233. package/dist/types/components/snk-filter-bar/filter-item/filter-item-type-mask.enum.d.ts +7 -0
  234. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +2 -0
  235. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +9 -0
  236. package/dist/types/components/snk-form-config/SnkFormConfigManager.d.ts +7 -2
  237. package/dist/types/components/snk-form-config/snk-form-config.d.ts +4 -0
  238. package/dist/types/components/snk-grid/snk-grid.d.ts +21 -0
  239. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +24 -3
  240. package/dist/types/components/snk-simple-form-config/snk-simple-form-config.d.ts +33 -0
  241. package/dist/types/components/snk-taskbar/processor/taskbar-processor.d.ts +1 -0
  242. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +11 -0
  243. package/dist/types/components.d.ts +197 -0
  244. package/dist/types/lib/dataUnit/dataUnitInMemoryUtils.d.ts +12 -2
  245. package/dist/types/lib/http/data-fetcher/DataFetcher.d.ts +1 -0
  246. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.d.ts +3 -2
  247. package/dist/types/lib/http/data-fetcher/fetchers/fetchDataExporter/interfaces/IFetchDataExporterParams.d.ts +1 -1
  248. package/dist/types/lib/http/data-fetcher/fetchers/form-config-fetcher.d.ts +8 -2
  249. package/dist/types/lib/http/data-fetcher/fetchers/parameters-fecher.d.ts +1 -0
  250. package/dist/types/lib/utils/ContinuousInsertUtils.d.ts +10 -0
  251. package/dist/types/lib/utils/CrudUtils.d.ts +1 -0
  252. package/dist/types/lib/utils/GetSelectedRecordsIDsInfo.d.ts +3 -0
  253. package/package.json +4 -3
  254. package/react/components.d.ts +1 -0
  255. package/react/components.js +1 -0
  256. package/react/components.js.map +1 -1
  257. package/dist/cjs/snk-config-options.cjs.entry.js +0 -239
  258. package/dist/cjs/snk-filter-bar.cjs.entry.js +0 -714
  259. package/dist/cjs/snk-filter-item.cjs.entry.js +0 -312
  260. package/dist/cjs/snk-filter-list.cjs.entry.js +0 -152
  261. package/dist/cjs/snk-filter-modal.cjs.entry.js +0 -249
  262. package/dist/cjs/snk-form.cjs.entry.js +0 -143
  263. package/dist/esm/snk-config-options.entry.js +0 -235
  264. package/dist/esm/snk-filter-bar.entry.js +0 -710
  265. package/dist/esm/snk-filter-item.entry.js +0 -308
  266. package/dist/esm/snk-filter-list.entry.js +0 -148
  267. package/dist/esm/snk-filter-modal.entry.js +0 -245
  268. package/dist/esm/snk-form.entry.js +0 -139
  269. package/dist/sankhyablocks/p-045eae4d.entry.js +0 -11
  270. package/dist/sankhyablocks/p-219f888d.entry.js +0 -1
  271. package/dist/sankhyablocks/p-2a408684.js +0 -1
  272. package/dist/sankhyablocks/p-3a212712.js +0 -1
  273. package/dist/sankhyablocks/p-3b60db06.entry.js +0 -1
  274. package/dist/sankhyablocks/p-450c60e4.entry.js +0 -1
  275. package/dist/sankhyablocks/p-4e5e1313.entry.js +0 -1
  276. package/dist/sankhyablocks/p-4f3717df.entry.js +0 -1
  277. package/dist/sankhyablocks/p-62ba211a.entry.js +0 -1
  278. package/dist/sankhyablocks/p-70a4af56.entry.js +0 -1
  279. package/dist/sankhyablocks/p-7505da04.entry.js +0 -1
  280. package/dist/sankhyablocks/p-75e674ed.entry.js +0 -1
  281. package/dist/sankhyablocks/p-75f83d1d.entry.js +0 -1
  282. package/dist/sankhyablocks/p-7a337364.js +0 -1
  283. package/dist/sankhyablocks/p-7a85fd49.entry.js +0 -1
  284. package/dist/sankhyablocks/p-88aa931b.entry.js +0 -1
  285. package/dist/sankhyablocks/p-913a9979.js +0 -1
  286. package/dist/sankhyablocks/p-941bf3ef.entry.js +0 -1
  287. package/dist/sankhyablocks/p-96a89d58.entry.js +0 -1
  288. package/dist/sankhyablocks/p-9863d682.js +0 -1
  289. package/dist/sankhyablocks/p-af8efd95.js +0 -6
  290. package/dist/sankhyablocks/p-b11aa1e0.entry.js +0 -1
  291. package/dist/sankhyablocks/p-c2495304.js +0 -1
  292. package/dist/sankhyablocks/p-c5268346.entry.js +0 -1
  293. package/dist/sankhyablocks/p-d3f53df2.entry.js +0 -1
  294. package/dist/sankhyablocks/p-d6e26ea8.entry.js +0 -1
  295. package/dist/sankhyablocks/p-dc7c9047.js +0 -1
  296. package/dist/sankhyablocks/p-df5451c7.js +0 -26
  297. package/dist/sankhyablocks/p-e8763234.entry.js +0 -1
  298. package/dist/sankhyablocks/p-f2809746.entry.js +0 -1
  299. package/dist/sankhyablocks/p-fa4d8cb4.js +0 -1
  300. package/dist/sankhyablocks/p-fcac4dfc.js +0 -1
  301. package/dist/sankhyablocks/p-fe79f83a.js +0 -60
  302. package/dist/types/components/snk-data-exporter/utils/RecordIDUtils.d.ts +0 -3
@@ -1,5 +1,9 @@
1
1
  export const snkGridMessages = {
2
- findColumn: "Busca de colunas"
2
+ findColumn: "Busca de colunas",
3
+ cancelConfirmation: {
4
+ title: "Aviso",
5
+ message: "As alterações realizadas serão descartadas<br/><br/><b>Você realmente gostaria de cancelar?</b>",
6
+ }
3
7
  };
4
8
  export const snkGridConfigMessages = {
5
9
  gridConfiguration: "Configuração da Grade",
@@ -0,0 +1,31 @@
1
+ import { h } from '@stencil/core';
2
+ import { StringUtils } from '@sankhyalabs/core';
3
+ export class ContinuousInsertUtils {
4
+ constructor(snkApplication, resourceID, configName) {
5
+ this.snkApplication = snkApplication;
6
+ this.keyConfigEnableContinuousInsert = `${resourceID}enableContinuousInsert${configName ? configName : ''}`;
7
+ }
8
+ handleSaveConfig(enableContinuousInsert) {
9
+ return this.snkApplication.saveConfig(this.keyConfigEnableContinuousInsert, enableContinuousInsert);
10
+ }
11
+ getConfig() {
12
+ return this.snkApplication.getConfig(this.keyConfigEnableContinuousInsert).then(value => {
13
+ if (value) {
14
+ return value == "true" ? true : false;
15
+ }
16
+ return false;
17
+ }).catch(() => {
18
+ return false;
19
+ });
20
+ }
21
+ actionContinuousInsert(enableContinuousInsert, handleEnableContinuousInsert) {
22
+ return {
23
+ value: StringUtils.generateUUID(),
24
+ label: enableContinuousInsert ? 'Desativar inclusão contínua' : 'Ativar inclusão contínua',
25
+ enabled: true,
26
+ itemBuilder: () => {
27
+ return (h("div", { class: "ez-dropdown__item-wrapper", onClick: handleEnableContinuousInsert }, h("span", { class: "ez-dropdown__item-label" }, enableContinuousInsert ? 'Desativar inclusão contínua' : 'Ativar inclusão contínua')));
28
+ },
29
+ };
30
+ }
31
+ }
@@ -13,6 +13,28 @@ export class CrudUtils {
13
13
  });
14
14
  }
15
15
  }
16
+ static parseCrudResults(entities, onlyFirst) {
17
+ if (!Array.isArray(entities)) {
18
+ entities = [entities];
19
+ }
20
+ const crudFindResults = [];
21
+ for (const entity of entities) {
22
+ let crudFindResult = {
23
+ fields: new Map()
24
+ };
25
+ for (let key in entity) {
26
+ let fieldValue = entity[key];
27
+ if (fieldValue.hasOwnProperty('$')) {
28
+ crudFindResult.fields.set(key, fieldValue.$);
29
+ }
30
+ if (onlyFirst) {
31
+ break;
32
+ }
33
+ }
34
+ crudFindResults.push(crudFindResult);
35
+ }
36
+ return crudFindResults.length > 1 ? crudFindResults : crudFindResults[0];
37
+ }
16
38
  static find(entityName, fields, criteria, onlyFirst = true, criteriaExpression, orderBy) {
17
39
  const SERVICE_CRUD_FIND = "mge@crud.find";
18
40
  let parsedFields = [];
@@ -61,24 +83,11 @@ export class CrudUtils {
61
83
  DataFetcher.get().callServiceBroker(SERVICE_CRUD_FIND, JSON.stringify(request)).then((result) => {
62
84
  var _a;
63
85
  let entities = (_a = result.entidades) === null || _a === void 0 ? void 0 : _a.entidade;
64
- if (entities != undefined) {
65
- let crudFindResult = {
66
- fields: new Map()
67
- };
68
- for (let key in entities) {
69
- let fieldValue = entities[key];
70
- if (fieldValue.hasOwnProperty('$')) {
71
- crudFindResult.fields.set(key, fieldValue.$);
72
- }
73
- if (onlyFirst) {
74
- break;
75
- }
76
- }
77
- resolve(crudFindResult);
78
- }
79
- else {
86
+ if (!entities) {
80
87
  resolve(null);
81
88
  }
89
+ const crudFindResults = this.parseCrudResults(entities, onlyFirst);
90
+ resolve(crudFindResults);
82
91
  });
83
92
  });
84
93
  }
@@ -1,29 +1,29 @@
1
1
  import { DataType, JSUtils } from "@sankhyalabs/core";
2
- export const getSelectedIDs = (dataUnit) => {
3
- const selectionInfo = dataUnit.getSelectionInfo();
2
+ export function getSelectedRecordsIDsInfo(dataUnit) {
3
+ const selectionInfo = dataUnit === null || dataUnit === void 0 ? void 0 : dataUnit.getSelectionInfo();
4
4
  if (selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.isAllRecords()) {
5
5
  return [];
6
6
  }
7
7
  const selectedRecordsIDsInfo = [];
8
- const selectedRecords = selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.recordIds;
8
+ const selectedRecords = selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.records;
9
9
  if ((selectedRecords === null || selectedRecords === void 0 ? void 0 : selectedRecords.length) > 0) {
10
- selectedRecords.forEach(recordId => {
11
- if (!dataUnit.isNewRecord(recordId)) {
10
+ selectedRecords.forEach(({ __record__id__ }) => {
11
+ if (!dataUnit.isNewRecord(__record__id__)) {
12
12
  /*
13
13
  Esse if foi necessário para tratar corretamente o ID
14
14
  do record quando está sendo utilizado no modo standAlone
15
15
  isso não faz a exportação da grid funcionar no modo standAlone
16
16
  mas deixa de causar erro nas oprações de CRUD.
17
17
  */
18
- if (!JSUtils.isBase64(recordId)) {
18
+ if (!JSUtils.isBase64(__record__id__)) {
19
19
  selectedRecordsIDsInfo.push({
20
20
  name: "__record__id__",
21
21
  type: DataType.TEXT,
22
- value: recordId
22
+ value: __record__id__
23
23
  });
24
24
  return;
25
25
  }
26
- const revertBase64ToObject = JSON.parse(window.atob(recordId));
26
+ const revertBase64ToObject = JSON.parse(window.atob(__record__id__));
27
27
  Object.entries(revertBase64ToObject).forEach(([name, value]) => {
28
28
  const metadataField = dataUnit === null || dataUnit === void 0 ? void 0 : dataUnit.getField(name);
29
29
  if (metadataField == undefined) {
@@ -35,4 +35,4 @@ export const getSelectedIDs = (dataUnit) => {
35
35
  });
36
36
  }
37
37
  return selectedRecordsIDsInfo;
38
- };
38
+ }
@@ -0,0 +1,46 @@
1
+ import { precacheAndRoute, createHandlerBoundToURL } from 'workbox-precaching';
2
+ import { registerRoute } from 'workbox-routing';
3
+ import { StaleWhileRevalidate, CacheFirst } from 'workbox-strategies';
4
+ import { CacheableResponsePlugin } from 'workbox-cacheable-response';
5
+ import { ExpirationPlugin } from 'workbox-expiration';
6
+
7
+ // Placeholder for Workbox to inject the precache manifest
8
+ precacheAndRoute([]);
9
+
10
+ // Additional custom logic follows...
11
+ registerRoute(
12
+ ({ url }) =>
13
+ url.pathname.endsWith('/service.sbr') &&
14
+ url.searchParams.has('serviceName'),
15
+ new StaleWhileRevalidate({
16
+ cacheName: 'api-cache',
17
+ plugins: [new CacheableResponsePlugin({ statuses: [200] })],
18
+ })
19
+ );
20
+
21
+ registerRoute(
22
+ ({ request }) =>
23
+ ['image', 'font', 'style'].includes(request.destination),
24
+ new CacheFirst({
25
+ cacheName: 'assets-cache',
26
+ plugins: [
27
+ new CacheableResponsePlugin({ statuses: [0, 200] }),
28
+ new ExpirationPlugin({ maxEntries: 50, maxAgeSeconds: 30 * 24 * 60 * 60 }),
29
+ ],
30
+ })
31
+ );
32
+
33
+ registerRoute(
34
+ ({ request }) => request.mode === 'navigate',
35
+ createHandlerBoundToURL('/index.html')
36
+ );
37
+
38
+ self.addEventListener('install', (event) => {
39
+ console.log('Service Worker installing.');
40
+ self.skipWaiting();
41
+ });
42
+
43
+ self.addEventListener('activate', (event) => {
44
+ console.log('Service Worker activating.');
45
+ clients.claim();
46
+ });
@@ -1,6 +1,6 @@
1
1
  import { D as DataFetcher } from './DataFetcher.js';
2
2
  import './pesquisa-fetcher.js';
3
- import { SortMode, ApplicationContext, UserInterface, DateUtils, ObjectUtils, NumberUtils, DataType } from '@sankhyalabs/core';
3
+ import { SortMode, ApplicationContext, UserInterface, DateUtils, ObjectUtils, StringUtils, NumberUtils, DataType } from '@sankhyalabs/core';
4
4
  import './ISave.js';
5
5
  import '@sankhyalabs/ezui/dist/collection/utils/constants';
6
6
  import { UserInterface as UserInterface$1 } from '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
@@ -23,6 +23,28 @@ class CrudUtils {
23
23
  });
24
24
  }
25
25
  }
26
+ static parseCrudResults(entities, onlyFirst) {
27
+ if (!Array.isArray(entities)) {
28
+ entities = [entities];
29
+ }
30
+ const crudFindResults = [];
31
+ for (const entity of entities) {
32
+ let crudFindResult = {
33
+ fields: new Map()
34
+ };
35
+ for (let key in entity) {
36
+ let fieldValue = entity[key];
37
+ if (fieldValue.hasOwnProperty('$')) {
38
+ crudFindResult.fields.set(key, fieldValue.$);
39
+ }
40
+ if (onlyFirst) {
41
+ break;
42
+ }
43
+ }
44
+ crudFindResults.push(crudFindResult);
45
+ }
46
+ return crudFindResults.length > 1 ? crudFindResults : crudFindResults[0];
47
+ }
26
48
  static find(entityName, fields, criteria, onlyFirst = true, criteriaExpression, orderBy) {
27
49
  const SERVICE_CRUD_FIND = "mge@crud.find";
28
50
  let parsedFields = [];
@@ -70,24 +92,11 @@ class CrudUtils {
70
92
  DataFetcher.get().callServiceBroker(SERVICE_CRUD_FIND, JSON.stringify(request)).then((result) => {
71
93
  var _a;
72
94
  let entities = (_a = result.entidades) === null || _a === void 0 ? void 0 : _a.entidade;
73
- if (entities != undefined) {
74
- let crudFindResult = {
75
- fields: new Map()
76
- };
77
- for (let key in entities) {
78
- let fieldValue = entities[key];
79
- if (fieldValue.hasOwnProperty('$')) {
80
- crudFindResult.fields.set(key, fieldValue.$);
81
- }
82
- if (onlyFirst) {
83
- break;
84
- }
85
- }
86
- resolve(crudFindResult);
87
- }
88
- else {
95
+ if (!entities) {
89
96
  resolve(null);
90
97
  }
98
+ const crudFindResults = this.parseCrudResults(entities, onlyFirst);
99
+ resolve(crudFindResults);
91
100
  });
92
101
  });
93
102
  }
@@ -124,12 +133,16 @@ class TaskbarProcessor {
124
133
  });
125
134
  }
126
135
  getButtonsArray(taskbarId, taskbarManager, dataState) {
127
- const defaults = this._defaultButtons[taskbarId];
136
+ const defaults = this.getButtonsFromKey(taskbarId);
128
137
  if (taskbarManager) {
129
138
  return taskbarManager.getButtons(taskbarId, dataState, [...defaults]);
130
139
  }
131
140
  return defaults;
132
141
  }
142
+ getButtonsFromKey(taskbarId) {
143
+ const btnsValue = this._defaultButtons[taskbarId];
144
+ return typeof btnsValue === 'function' ? btnsValue() : btnsValue;
145
+ }
133
146
  isEnabled(taskbarId, taskbarManager, buttonName, dataState, disabled) {
134
147
  const originalValue = disabled.includes(buttonName) ? false : true;
135
148
  if (taskbarManager && taskbarManager.isEnabled) {
@@ -217,7 +230,7 @@ class RmPrecisionCustomValueFormatter {
217
230
  this.refreshSelectedRows();
218
231
  }
219
232
  setDataState(dataState) {
220
- if (ObjectUtils.objectToString(dataState) === ObjectUtils.objectToString(this._dataState)) {
233
+ if (this._dataState && ObjectUtils.equals(dataState === null || dataState === void 0 ? void 0 : dataState.metadataByRow, this._dataState.metadataByRow)) {
221
234
  return;
222
235
  }
223
236
  this._dataState = dataState;
@@ -225,7 +238,7 @@ class RmPrecisionCustomValueFormatter {
225
238
  }
226
239
  format(currentValue, column, recordId) {
227
240
  var _a;
228
- if (!currentValue) {
241
+ if (StringUtils.isEmpty(currentValue)) {
229
242
  return currentValue;
230
243
  }
231
244
  const rowMetadata = (_a = this._dataState) === null || _a === void 0 ? void 0 : _a.metadataByRow.get(recordId);
@@ -295,4 +308,35 @@ class CommonsExporter {
295
308
  }
296
309
  }
297
310
 
298
- export { CommonsExporter as C, RmPrecisionCustomValueFormatter as R, SnkMultiSelectionListDataSource as S, TaskbarProcessor as T, CrudUtils as a, buildFieldSearch as b, openFieldSearch as o };
311
+ class ContinuousInsertUtils {
312
+ constructor(snkApplication, resourceID, configName) {
313
+ this.snkApplication = snkApplication;
314
+ this.keyConfigEnableContinuousInsert = `${resourceID}enableContinuousInsert${configName ? configName : ''}`;
315
+ }
316
+ handleSaveConfig(enableContinuousInsert) {
317
+ return this.snkApplication.saveConfig(this.keyConfigEnableContinuousInsert, enableContinuousInsert);
318
+ }
319
+ getConfig() {
320
+ return this.snkApplication.getConfig(this.keyConfigEnableContinuousInsert).then(value => {
321
+ if (value) {
322
+ return value == "true" ? true : false;
323
+ }
324
+ return false;
325
+ }).catch(() => {
326
+ return false;
327
+ });
328
+ }
329
+ actionContinuousInsert(enableContinuousInsert, handleEnableContinuousInsert) {
330
+ return {
331
+ value: StringUtils.generateUUID(),
332
+ label: enableContinuousInsert ? 'Desativar inclusão contínua' : 'Ativar inclusão contínua',
333
+ enabled: true,
334
+ itemBuilder: () => {
335
+ return (h("div", { class: "ez-dropdown__item-wrapper", onClick: handleEnableContinuousInsert },
336
+ h("span", { class: "ez-dropdown__item-label" }, enableContinuousInsert ? 'Desativar inclusão contínua' : 'Ativar inclusão contínua')));
337
+ },
338
+ };
339
+ }
340
+ }
341
+
342
+ export { CommonsExporter as C, RmPrecisionCustomValueFormatter as R, SnkMultiSelectionListDataSource as S, TaskbarProcessor as T, CrudUtils as a, buildFieldSearch as b, ContinuousInsertUtils as c, openFieldSearch as o };
@@ -1,4 +1,4 @@
1
- import { DataType, ApplicationContext, StringUtils, ErrorException, WarningException, ObjectUtils } from '@sankhyalabs/core';
1
+ import { DataType, ApplicationContext, StringUtils, ErrorException, WarningException, ObjectUtils, ServiceCanceledException } from '@sankhyalabs/core';
2
2
  import { P as PrintUtils } from './PrintUtils.js';
3
3
  import { DataUnitTransient } from '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
4
4
 
@@ -6777,7 +6777,8 @@ class DataFetcher {
6777
6777
  }
6778
6778
  payloadJson['requestBody']['clientEventList'].clientEvent.push({ $: key });
6779
6779
  }
6780
- DataFetcher.requestListener.forEach(listener => listener.onRequestStart({ url: url, requestBody: payload }));
6780
+ const requestId = StringUtils.generateUUID();
6781
+ DataFetcher.requestListener.forEach(listener => listener.onRequestStart({ url: url, requestBody: payload, requestId }));
6781
6782
  http.open("POST", url, true);
6782
6783
  http.withCredentials = true;
6783
6784
  http.send(ObjectUtils.objectToString(payloadJson));
@@ -6817,7 +6818,7 @@ class DataFetcher {
6817
6818
  else if (http.readyState == 4 && http.status != 200) {
6818
6819
  reject(new ErrorException(`Erro ao executar serviço: ${serviceName}`, http.responseText));
6819
6820
  }
6820
- DataFetcher.requestListener.forEach(listener => listener.onRequestEnd({ url: url, requestBody: payload }));
6821
+ DataFetcher.requestListener.forEach(listener => listener.onRequestEnd({ url: url, requestBody: payload, requestId }));
6821
6822
  };
6822
6823
  });
6823
6824
  }
@@ -6863,6 +6864,7 @@ class DataFetcher {
6863
6864
  }
6864
6865
  }
6865
6866
  async executePendingRequest(watingRequestsById) {
6867
+ var _a, _b;
6866
6868
  const requestsBatch = [];
6867
6869
  let quietMode = true;
6868
6870
  watingRequestsById.forEach((waitingReq) => {
@@ -6873,31 +6875,36 @@ class DataFetcher {
6873
6875
  const response = await this.fecthGraphQL(requestsBatch, quietMode);
6874
6876
  const { data: dataResponse, errors: errorsResponse, extensions } = response;
6875
6877
  //Reject promises with errors from query
6876
- errorsResponse.forEach((errorResponse) => {
6877
- Object.entries(errorResponse).forEach(async ([key, val]) => {
6878
- const waitingRequest = watingRequestsById.get(val.request.variables[val.index].queryID);
6878
+ for (const errorResponse of errorsResponse) {
6879
+ const values = Object.values(errorResponse);
6880
+ for (const value of values) {
6881
+ const waitingRequest = watingRequestsById.get(value.request.variables[value.index].queryID);
6879
6882
  const hasClientEvent = await this.proccesGraphQLClientEvents(extensions, waitingRequest.request, waitingRequest.resolve, waitingRequest.reject);
6880
- Promise.race([
6883
+ const data = await Promise.race([
6881
6884
  waitingRequest.promise,
6882
6885
  new Promise((resolve) => {
6883
6886
  resolve(false);
6884
6887
  })
6885
- ]).then((data) => {
6886
- var _a;
6887
- if (!hasClientEvent || data === false) {
6888
- (((_a = watingRequestsById.get(val.request.variables[val.index].queryID)) === null || _a === void 0 ? void 0 : _a.reject) || Promise.reject)(new ErrorException("Falha detectada", val.message));
6888
+ ]);
6889
+ if (!hasClientEvent || data === false) {
6890
+ if (Object.keys(errorResponse[0].extensions).includes("SERVICE_CANCELED") || Object.keys(extensions).includes("isServiceCancelled")) {
6891
+ (((_a = watingRequestsById.get(value.request.variables[value.index].queryID)) === null || _a === void 0 ? void 0 : _a.reject) || Promise.reject)(new ServiceCanceledException("Service canceled", value.message));
6889
6892
  }
6890
- });
6891
- });
6892
- });
6893
+ else {
6894
+ (((_b = watingRequestsById.get(value.request.variables[value.index].queryID)) === null || _b === void 0 ? void 0 : _b.reject) || Promise.reject)(new ErrorException("Falha detectada", value.message));
6895
+ }
6896
+ }
6897
+ }
6898
+ }
6893
6899
  //Resolve promises with data from query
6894
- dataResponse.forEach((data) => {
6895
- Object.entries(data).forEach(async ([key, val]) => {
6900
+ for (const data of dataResponse) {
6901
+ const entries = Object.entries(data);
6902
+ for (const [key, val] of entries) {
6896
6903
  const waitingRequest = watingRequestsById.get(key);
6897
6904
  await this.proccesGraphQLClientEvents(extensions, waitingRequest.request, waitingRequest.resolve, waitingRequest.reject);
6898
6905
  ((waitingRequest === null || waitingRequest === void 0 ? void 0 : waitingRequest.resolve) || Promise.resolve)(val);
6899
- });
6900
- });
6906
+ }
6907
+ }
6901
6908
  }
6902
6909
  buildGraphQlURL(quietMode) {
6903
6910
  const urlParams = UrlUtils.getQueryParams(location.search);
@@ -6916,7 +6923,8 @@ class DataFetcher {
6916
6923
  const errorsResponse = [];
6917
6924
  const responseExtensions = [];
6918
6925
  const url = this.buildGraphQlURL(quietMode);
6919
- DataFetcher.requestListener.forEach(listener => listener.onRequestStart({ url, requestBody: request }));
6926
+ const requestId = StringUtils.generateUUID();
6927
+ DataFetcher.requestListener.forEach(listener => listener.onRequestStart({ url, requestBody: request, requestId }));
6920
6928
  try {
6921
6929
  const response = await dist.batchRequests(url, request, { 'Content-Type': `application/json; charset=${window['SERVER_ENCODING'] || 'UTF-8'}` });
6922
6930
  response.forEach((resItem, index) => {
@@ -6950,11 +6958,11 @@ class DataFetcher {
6950
6958
  });
6951
6959
  }
6952
6960
  else {
6953
- DataFetcher.requestListener.forEach(listener => listener.onRequestEnd({ url, requestBody: request }));
6961
+ DataFetcher.requestListener.forEach(listener => listener.onRequestEnd({ url, requestBody: request, requestId }));
6954
6962
  throw new ErrorException("Falha de comunicação", err.message);
6955
6963
  }
6956
6964
  }
6957
- DataFetcher.requestListener.forEach(listener => listener.onRequestEnd({ url, requestBody: request }));
6965
+ DataFetcher.requestListener.forEach(listener => listener.onRequestEnd({ url, requestBody: request, requestId }));
6958
6966
  return { data: dataResponse, errors: errorsResponse, extensions: responseExtensions };
6959
6967
  }
6960
6968
  isHttpError(err) {
@@ -1,30 +1,30 @@
1
1
  import { JSUtils, DataType } from '@sankhyalabs/core';
2
2
 
3
- const getSelectedIDs = (dataUnit) => {
4
- const selectionInfo = dataUnit.getSelectionInfo();
3
+ function getSelectedRecordsIDsInfo(dataUnit) {
4
+ const selectionInfo = dataUnit === null || dataUnit === void 0 ? void 0 : dataUnit.getSelectionInfo();
5
5
  if (selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.isAllRecords()) {
6
6
  return [];
7
7
  }
8
8
  const selectedRecordsIDsInfo = [];
9
- const selectedRecords = selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.recordIds;
9
+ const selectedRecords = selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.records;
10
10
  if ((selectedRecords === null || selectedRecords === void 0 ? void 0 : selectedRecords.length) > 0) {
11
- selectedRecords.forEach(recordId => {
12
- if (!dataUnit.isNewRecord(recordId)) {
11
+ selectedRecords.forEach(({ __record__id__ }) => {
12
+ if (!dataUnit.isNewRecord(__record__id__)) {
13
13
  /*
14
14
  Esse if foi necessário para tratar corretamente o ID
15
15
  do record quando está sendo utilizado no modo standAlone
16
16
  isso não faz a exportação da grid funcionar no modo standAlone
17
17
  mas deixa de causar erro nas oprações de CRUD.
18
18
  */
19
- if (!JSUtils.isBase64(recordId)) {
19
+ if (!JSUtils.isBase64(__record__id__)) {
20
20
  selectedRecordsIDsInfo.push({
21
21
  name: "__record__id__",
22
22
  type: DataType.TEXT,
23
- value: recordId
23
+ value: __record__id__
24
24
  });
25
25
  return;
26
26
  }
27
- const revertBase64ToObject = JSON.parse(window.atob(recordId));
27
+ const revertBase64ToObject = JSON.parse(window.atob(__record__id__));
28
28
  Object.entries(revertBase64ToObject).forEach(([name, value]) => {
29
29
  const metadataField = dataUnit === null || dataUnit === void 0 ? void 0 : dataUnit.getField(name);
30
30
  if (metadataField == undefined) {
@@ -36,6 +36,6 @@ const getSelectedIDs = (dataUnit) => {
36
36
  });
37
37
  }
38
38
  return selectedRecordsIDsInfo;
39
- };
39
+ }
40
40
 
41
- export { getSelectedIDs as g };
41
+ export { getSelectedRecordsIDsInfo as g };
@@ -1,12 +1,14 @@
1
1
  import { C as ConfigStorage } from './ConfigStorage.js';
2
2
  import { ObjectUtils, StringUtils } from '@sankhyalabs/core';
3
3
  import { F as FormConfigFetcher } from './form-config-fetcher.js';
4
+ import { c as TAB_NAMES } from './constants.js';
4
5
 
5
6
  class SnkFormConfigManager {
6
- constructor(configName, resourceID, onConfigChange) {
7
+ constructor(configName, resourceID, onConfigChange, dataUnit) {
7
8
  this._resourceID = resourceID;
8
9
  this._configName = configName;
9
10
  this._onConfigChange = onConfigChange;
11
+ this._dataUnit = dataUnit;
10
12
  }
11
13
  addFormLegacyConfig(legacyConfigName) {
12
14
  if (this._configName) {
@@ -17,6 +19,7 @@ class SnkFormConfigManager {
17
19
  return new Promise(resolve => {
18
20
  ConfigStorage.loadFormConfig(this._configName, this._resourceID)
19
21
  .then((config) => {
22
+ config = this.buildFormMetadataUITabs(config);
20
23
  this.setConfig(config);
21
24
  resolve(config);
22
25
  })
@@ -25,6 +28,10 @@ class SnkFormConfigManager {
25
28
  });
26
29
  });
27
30
  }
31
+ getEmptyConfig() {
32
+ const config = this.buildFormMetadataUITabs({ fields: [], emptyConfig: true }, true);
33
+ return config;
34
+ }
28
35
  saveConfig(config) {
29
36
  const configToSave = ObjectUtils.copy(config);
30
37
  return new Promise(accept => {
@@ -68,25 +75,36 @@ class SnkFormConfigManager {
68
75
  }
69
76
  return updatingCardConfig;
70
77
  }
71
- getFieldsList(dataUnit, descriptionFilter) {
78
+ hasConfig(config) {
79
+ var _a;
80
+ const currentConfig = config !== null && config !== void 0 ? config : this._config;
81
+ if (currentConfig && ((_a = currentConfig.fields) === null || _a === void 0 ? void 0 : _a.length)) {
82
+ return true;
83
+ }
84
+ return false;
85
+ }
86
+ getFieldsList(descriptionFilter, forceEmptyConfig = false) {
72
87
  var _a;
73
88
  const fields = (_a = this._config) === null || _a === void 0 ? void 0 : _a.fields;
74
- if (fields != undefined && fields.length > 0) {
75
- return fields.map(({ label, name, readOnly, visible, required }) => {
89
+ const hasConfig = this.hasConfig();
90
+ if (hasConfig && !forceEmptyConfig) {
91
+ return fields.map(({ label, name, readOnly, visible, required, tab }) => {
92
+ var _a;
76
93
  if (label == undefined) {
77
- const currentField = dataUnit.getField(name);
78
- return Object.assign(Object.assign({}, currentField), { name: name !== null && name !== void 0 ? name : currentField.name, readOnly: readOnly !== null && readOnly !== void 0 ? readOnly : currentField.readOnly, visible: visible !== null && visible !== void 0 ? visible : currentField.visible, required: required !== null && required !== void 0 ? required : currentField.required });
94
+ const currentField = (_a = this._dataUnit) === null || _a === void 0 ? void 0 : _a.getField(name);
95
+ return Object.assign(Object.assign({}, currentField), { name: name !== null && name !== void 0 ? name : currentField.name, readOnly: readOnly !== null && readOnly !== void 0 ? readOnly : currentField.readOnly, visible: visible !== null && visible !== void 0 ? visible : currentField.visible, required: required !== null && required !== void 0 ? required : currentField.required, tab: tab });
79
96
  }
80
- return { name, label, readOnly, visible, required };
97
+ return { name, label, readOnly, visible, required, tab };
81
98
  })
82
99
  .filter(field => this.isFieldVisible(field, descriptionFilter));
83
100
  }
84
- if (dataUnit != undefined) {
85
- return dataUnit.metadata.fields
86
- .filter(field => this.isFieldVisible(field, descriptionFilter))
87
- .map(({ label, name, readOnly }) => { return { label, name, readOnly }; });
101
+ if (!this._dataUnit) {
102
+ return [];
88
103
  }
89
- return [];
104
+ const filteredFields = this._dataUnit.metadata.fields
105
+ .filter(field => this.isFieldVisible(field, descriptionFilter))
106
+ .map(({ label, name, readOnly, visible, required, properties }) => ({ label, name, readOnly, visible, required, tab: properties === null || properties === void 0 ? void 0 : properties.UITabName }));
107
+ return filteredFields;
90
108
  }
91
109
  isFieldVisible(field, descriptionFilter) {
92
110
  if (field.visible === false) {
@@ -99,8 +117,8 @@ class SnkFormConfigManager {
99
117
  const normalizedFilter = StringUtils.replaceAccentuatedCharsLower(descriptionFilter.toLocaleLowerCase());
100
118
  return normalizedText.includes(normalizedFilter);
101
119
  }
102
- getFormConfig(dataUnit, ignoreReadOnlyFormFields) {
103
- let fields = this.getFieldsList(dataUnit);
120
+ getFormConfig(dataUnit, ignoreReadOnlyFormFields, forceEmptyConfig = false) {
121
+ let fields = this.getFieldsList(undefined, forceEmptyConfig);
104
122
  if (ignoreReadOnlyFormFields) {
105
123
  fields = fields.filter(field => {
106
124
  if (dataUnit) {
@@ -153,6 +171,44 @@ class SnkFormConfigManager {
153
171
  async fetchDefaultConfig() {
154
172
  return this.getFormConfigFetcher().fetchDefaultConfig(this._configName, this._resourceID);
155
173
  }
174
+ parseObjectList(object) {
175
+ if (!object) {
176
+ return [];
177
+ }
178
+ return Array.isArray(object) ? object : [object];
179
+ }
180
+ buildFormMetadataUITabs(config, forceEmptyConfig = false) {
181
+ var _a;
182
+ const hasConfig = this.hasConfig(config);
183
+ if (!forceEmptyConfig && (!this._dataUnit || hasConfig)) {
184
+ return config;
185
+ }
186
+ config = this.getFormConfig(this._dataUnit, false, true);
187
+ config.tabs = this.parseObjectList(config.tabs);
188
+ config.emptyConfig = false;
189
+ config.defaultConfiguration = true;
190
+ const fields = this._dataUnit.metadata.fields;
191
+ for (const currentField of fields) {
192
+ const field = config.fields.find(field => field.name === currentField.name);
193
+ const uiTabName = (_a = currentField.properties) === null || _a === void 0 ? void 0 : _a.UITabName;
194
+ if (!uiTabName || uiTabName === TAB_NAMES.main) {
195
+ continue;
196
+ }
197
+ const haveTab = config.tabs.some((tab) => tab.label === uiTabName);
198
+ if (!haveTab) {
199
+ config.tabs.push({
200
+ label: uiTabName,
201
+ name: uiTabName,
202
+ order: 0,
203
+ visible: true,
204
+ });
205
+ }
206
+ if (field) {
207
+ field.tab = uiTabName;
208
+ }
209
+ }
210
+ return config;
211
+ }
156
212
  }
157
213
 
158
214
  export { SnkFormConfigManager as S };
@@ -8,7 +8,7 @@ const snkDataUnitMessages = {
8
8
  },
9
9
  cancelInfo: {
10
10
  clone: "Duplicação descartada!",
11
- insert: "A inclusão descartada!",
11
+ insert: "A inclusão foi descartada!",
12
12
  update: "A edição foi descartada!"
13
13
  },
14
14
  confirm: {
@@ -122,7 +122,7 @@ const snkExporterMessages = {
122
122
  emailSenderOptStep_subtitle: "Primeiro, escolha o formato do arquivo",
123
123
  emailSenderOptStep_lblFormat: "Formato:",
124
124
  emailSenderOptStep_formatPDF: "PDF (.pdf)",
125
- emailSenderOptStep_formatXLSX: "Planilha (.xlsx)",
125
+ emailSenderOptStep_formatXLS: "Planilha (.xls)",
126
126
  emailSenderOptStep_export: "Exportar:",
127
127
  emailSenderOptStep_allData: "Toda a grade",
128
128
  emailSenderOptStep_currentPage: "Somente a página atual",
@@ -245,7 +245,11 @@ const snkConfiguratorMessages = {
245
245
  };
246
246
 
247
247
  const snkGridMessages = {
248
- findColumn: "Busca de colunas"
248
+ findColumn: "Busca de colunas",
249
+ cancelConfirmation: {
250
+ title: "Aviso",
251
+ message: "As alterações realizadas serão descartadas<br/><br/><b>Você realmente gostaria de cancelar?</b>",
252
+ }
249
253
  };
250
254
  const snkGridConfigMessages = {
251
255
  gridConfiguration: "Configuração da Grade",