@sankhyalabs/sankhyablocks 8.16.0-dev.7 → 8.16.0-dev.71

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 (336) hide show
  1. package/dist/cjs/{ConfigStorage-a343e418.js → ConfigStorage-d024aec8.js} +2 -2
  2. package/dist/cjs/{IExporterProvider-597949f9.js → ContinuousInsertUtils-54d44192.js} +65 -23
  3. package/dist/cjs/{DataFetcher-313debd8.js → DataFetcher-65879b2c.js} +216 -76
  4. package/dist/cjs/{RecordIDUtils-3735135c.js → GetSelectedRecordsIDsInfo-bd50caf1.js} +10 -10
  5. package/dist/cjs/{SnkFormConfigManager-166cbd1f.js → SnkFormConfigManager-07f747be.js} +75 -17
  6. package/dist/cjs/{SnkMessageBuilder-722b104e.js → SnkMessageBuilder-bae64d0d.js} +7 -3
  7. package/dist/cjs/{auth-fetcher-54f5ff9d.js → auth-fetcher-8480751c.js} +1 -1
  8. package/dist/cjs/{dataunit-fetcher-688d3f05.js → dataunit-fetcher-8ea97d88.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-90126e4c.js} +42 -2
  11. package/dist/cjs/index-f9e81701.js +16 -32
  12. package/dist/cjs/loader.cjs.js +1 -1
  13. package/dist/cjs/{pesquisa-fetcher-680e198f.js → pesquisa-fetcher-f3454c23.js} +185 -2
  14. package/dist/cjs/pesquisa-grid_2.cjs.entry.js +133 -0
  15. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  16. package/dist/cjs/{snk-actions-button_4.cjs.entry.js → snk-actions-button_5.cjs.entry.js} +136 -40
  17. package/dist/cjs/snk-application.cjs.entry.js +248 -69
  18. package/dist/cjs/snk-attach.cjs.entry.js +46 -33
  19. package/dist/cjs/{snk-form-config.cjs.entry.js → snk-config-options_3.cjs.entry.js} +398 -12
  20. package/dist/cjs/snk-crud.cjs.entry.js +22 -8
  21. package/dist/cjs/snk-data-exporter.cjs.entry.js +34 -22
  22. package/dist/cjs/{snk-data-unit-04df81bf.js → snk-data-unit-72ef8777.js} +54 -32
  23. package/dist/cjs/snk-data-unit.cjs.entry.js +5 -5
  24. package/dist/cjs/snk-detail-view.cjs.entry.js +12 -12
  25. package/dist/cjs/snk-exporter-email-sender.cjs.entry.js +1 -1
  26. package/dist/cjs/snk-filter-bar_4.cjs.entry.js +1436 -0
  27. package/dist/cjs/snk-filter-binary-select.cjs.entry.js +1 -1
  28. package/dist/cjs/snk-filter-checkbox-list.cjs.entry.js +1 -1
  29. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  30. package/dist/cjs/snk-filter-text.cjs.entry.js +2 -1
  31. package/dist/cjs/snk-grid.cjs.entry.js +71 -21
  32. package/dist/cjs/{snk-guides-viewer-bdc41281.js → snk-guides-viewer-b20b0cfd.js} +29 -13
  33. package/dist/cjs/snk-guides-viewer.cjs.entry.js +9 -9
  34. package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +4 -4
  35. package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
  36. package/dist/cjs/snk-pesquisa.cjs.entry.js +123 -31
  37. package/dist/cjs/snk-print-selector.cjs.entry.js +1 -1
  38. package/dist/cjs/snk-simple-bar.cjs.entry.js +1 -1
  39. package/dist/cjs/snk-simple-crud.cjs.entry.js +101 -45
  40. package/dist/cjs/snk-taskbar.cjs.entry.js +64 -38
  41. package/dist/collection/collection-manifest.json +14 -31
  42. package/dist/collection/components/snk-actions-button/actions/index.js +16 -13
  43. package/dist/collection/components/snk-actions-button/interfaces/index.js +1 -0
  44. package/dist/collection/components/snk-actions-button/snk-actions-button.js +27 -26
  45. package/dist/collection/components/snk-application/request-listener/DebouncedRequestListener.js +29 -0
  46. package/dist/collection/components/snk-application/request-listener/RequestListenerFactory.js +16 -0
  47. package/dist/collection/components/snk-application/request-listener/RequestListenerLoadingBar.js +52 -0
  48. package/dist/collection/components/snk-application/snk-application.css +34 -0
  49. package/dist/collection/components/snk-application/snk-application.js +235 -64
  50. package/dist/collection/components/snk-attach/snk-attach.js +25 -16
  51. package/dist/collection/components/snk-attach/structure/builder/taskbar-builder.js +8 -4
  52. package/dist/collection/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.js +2 -4
  53. package/dist/collection/components/snk-crud/snk-crud.js +122 -3
  54. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +3 -3
  55. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.css +6 -6
  56. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +72 -6
  57. package/dist/collection/components/snk-data-exporter/exporter-email-sender/options-step.js +1 -1
  58. package/dist/collection/components/snk-data-exporter/exporter-strategy/ClientSideExporterStrategy.js +13 -7
  59. package/dist/collection/components/snk-data-exporter/exporter-strategy/ServerSideExporterStrategy.js +9 -2
  60. package/dist/collection/components/snk-data-exporter/interfaces/IExporterProvider.js +1 -1
  61. package/dist/collection/components/snk-data-exporter/providers/ClientSideExporterProvider.js +1 -1
  62. package/dist/collection/components/snk-data-exporter/providers/ServerSideExporterProvider.js +1 -1
  63. package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +3 -5
  64. package/dist/collection/components/snk-data-exporter/structure/ItemBuilder.js +2 -2
  65. package/dist/collection/components/snk-data-exporter/test/resources/ClientSideExporterStrategyResources.js +4 -4
  66. package/dist/collection/components/snk-data-exporter/utils/ParserExport.js +1 -1
  67. package/dist/collection/components/snk-data-unit/snk-data-unit.js +52 -30
  68. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-binary-select.js +1 -1
  69. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-checkbox-list.js +1 -1
  70. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-text.js +2 -1
  71. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.css +13 -0
  72. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.js +3 -3
  73. package/dist/collection/components/snk-filter-bar/filter-item/filter-item-type-mask.enum.js +8 -0
  74. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.js +5 -1
  75. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.css +1 -1
  76. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +3 -1
  77. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +1 -1
  78. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +118 -28
  79. package/dist/collection/components/snk-form/snk-form.js +2 -2
  80. package/dist/collection/components/snk-form-config/SnkFormConfigManager.js +73 -15
  81. package/dist/collection/components/snk-form-config/snk-form-config.css +8 -3
  82. package/dist/collection/components/snk-form-config/snk-form-config.js +49 -8
  83. package/dist/collection/components/snk-grid/snk-grid.css +2 -0
  84. package/dist/collection/components/snk-grid/snk-grid.js +153 -8
  85. package/dist/collection/components/snk-pesquisa/pesquisa-grid/pesquisa-grid.css +10 -0
  86. package/dist/collection/components/snk-pesquisa/pesquisa-grid/pesquisa-grid.js +190 -0
  87. package/dist/collection/components/snk-pesquisa/pesquisa-tree/pesquisa-tree.css +25 -0
  88. package/dist/collection/components/snk-pesquisa/pesquisa-tree/pesquisa-tree.js +179 -0
  89. package/dist/collection/components/snk-pesquisa/pesquisaHelper.js +89 -0
  90. package/dist/collection/components/snk-pesquisa/snk-pesquisa.css +24 -5
  91. package/dist/collection/components/snk-pesquisa/snk-pesquisa.js +186 -32
  92. package/dist/collection/components/snk-print-selector/snk-print-selector.js +1 -1
  93. package/dist/collection/components/snk-simple-bar/snk-simple-bar.js +1 -1
  94. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +1 -1
  95. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +160 -50
  96. package/dist/collection/components/snk-simple-form-config/snk-simple-form-config.css +22 -0
  97. package/dist/collection/components/snk-simple-form-config/snk-simple-form-config.js +181 -0
  98. package/dist/collection/components/snk-taskbar/processor/taskbar-processor.js +5 -1
  99. package/dist/collection/components/snk-taskbar/snk-taskbar.js +106 -38
  100. package/dist/collection/lib/DefaultCustomFormatters/RmPrecisionCustomValueFormatter.js +3 -3
  101. package/dist/collection/lib/dataUnit/InMemoryLoader.js +2 -4
  102. package/dist/collection/lib/dataUnit/dataUnitInMemoryUtils.js +34 -9
  103. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +29 -21
  104. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.js +7 -5
  105. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/DataUnitDataLoader.js +2 -2
  106. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy.js +9 -2
  107. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +45 -5
  108. package/dist/collection/lib/http/data-fetcher/fetchers/parameters-fecher.js +7 -1
  109. package/dist/collection/lib/http/data-fetcher/fetchers/pesquisa-fetcher.js +98 -4
  110. package/dist/collection/lib/message/resources/snk-data-unit.msg.js +1 -1
  111. package/dist/collection/lib/message/resources/snk-exporter.msg.js +1 -1
  112. package/dist/collection/lib/message/resources/snk-grid.msg.js +5 -1
  113. package/dist/collection/lib/utils/ContinuousInsertUtils.js +31 -0
  114. package/dist/collection/lib/utils/CrudUtils.js +25 -16
  115. package/dist/collection/{components/snk-data-exporter/utils/RecordIDUtils.js → lib/utils/GetSelectedRecordsIDsInfo.js} +9 -9
  116. package/dist/collection/sw.js +46 -0
  117. package/dist/components/{IExporterProvider.js → ContinuousInsertUtils.js} +66 -23
  118. package/dist/components/DataFetcher.js +217 -77
  119. package/dist/{esm/RecordIDUtils-87d02110.js → components/GetSelectedRecordsIDsInfo.js} +10 -10
  120. package/dist/components/ISave.js +346 -1
  121. package/dist/components/SnkFormConfigManager.js +73 -15
  122. package/dist/components/SnkMessageBuilder.js +7 -3
  123. package/dist/components/dataunit-fetcher.js +47 -17
  124. package/dist/components/form-config-fetcher.js +41 -1
  125. package/dist/components/index.d.ts +3 -0
  126. package/dist/components/index.js +3 -0
  127. package/dist/components/pesquisa-grid.d.ts +11 -0
  128. package/dist/components/pesquisa-grid.js +6 -0
  129. package/dist/components/pesquisa-grid2.js +86 -0
  130. package/dist/components/pesquisa-tree.d.ts +11 -0
  131. package/dist/components/pesquisa-tree.js +6 -0
  132. package/dist/components/pesquisa-tree2.js +82 -0
  133. package/dist/components/snk-actions-button2.js +43 -40
  134. package/dist/components/snk-application2.js +264 -68
  135. package/dist/components/snk-attach2.js +54 -60
  136. package/dist/components/snk-crud.js +83 -59
  137. package/dist/components/snk-data-exporter2.js +28 -17
  138. package/dist/components/snk-data-unit2.js +55 -70
  139. package/dist/components/snk-detail-view2.js +114 -105
  140. package/dist/components/snk-exporter-email-sender2.js +1 -1
  141. package/dist/components/snk-filter-bar2.js +64 -30
  142. package/dist/components/snk-filter-binary-select.js +1 -1
  143. package/dist/components/snk-filter-checkbox-list.js +1 -1
  144. package/dist/components/snk-filter-item2.js +5 -1
  145. package/dist/components/snk-filter-modal.js +4 -2
  146. package/dist/components/snk-filter-text.js +2 -1
  147. package/dist/components/snk-form-config2.js +34 -9
  148. package/dist/components/snk-form.js +2 -2
  149. package/dist/components/snk-grid2.js +68 -13
  150. package/dist/components/snk-personalized-filter-editor.js +4 -4
  151. package/dist/components/snk-pesquisa2.js +136 -33
  152. package/dist/components/snk-print-selector.js +1 -1
  153. package/dist/components/snk-simple-bar2.js +1 -1
  154. package/dist/components/snk-simple-crud2.js +108 -66
  155. package/dist/components/snk-simple-form-config.d.ts +11 -0
  156. package/dist/components/snk-simple-form-config.js +6 -0
  157. package/dist/components/snk-simple-form-config2.js +120 -0
  158. package/dist/components/snk-taskbar2.js +66 -40
  159. package/dist/components/teste-pesquisa.js +13 -1
  160. package/dist/esm/{ConfigStorage-3806514e.js → ConfigStorage-373bb440.js} +2 -2
  161. package/dist/esm/{IExporterProvider-63a188b6.js → ContinuousInsertUtils-25e7bd9a.js} +66 -25
  162. package/dist/esm/{DataFetcher-c1baf61d.js → DataFetcher-5221b992.js} +217 -77
  163. package/dist/esm/GetSelectedRecordsIDsInfo-9fa41508.js +41 -0
  164. package/dist/esm/{SnkFormConfigManager-31b24066.js → SnkFormConfigManager-1ff928fa.js} +75 -17
  165. package/dist/esm/{SnkMessageBuilder-89925609.js → SnkMessageBuilder-6fff4a4c.js} +7 -3
  166. package/dist/esm/{auth-fetcher-039abba3.js → auth-fetcher-e32fe8a4.js} +1 -1
  167. package/dist/esm/{constants-8457af36.js → constants-7302ee87.js} +1 -1
  168. package/dist/esm/{dataunit-fetcher-264191b2.js → dataunit-fetcher-8dd93d8b.js} +48 -18
  169. package/dist/esm/{field-search-efbe307f.js → field-search-f8b1d91e.js} +5 -1
  170. package/dist/esm/{form-config-fetcher-30fb808f.js → form-config-fetcher-126e2471.js} +42 -2
  171. package/dist/esm/index-a7d3d3f1.js +16 -32
  172. package/dist/esm/loader.js +1 -1
  173. package/dist/{components/pesquisa-fetcher.js → esm/pesquisa-fetcher-0af41f09.js} +186 -4
  174. package/dist/esm/pesquisa-grid_2.entry.js +128 -0
  175. package/dist/esm/sankhyablocks.js +1 -1
  176. package/dist/esm/{snk-actions-button_4.entry.js → snk-actions-button_5.entry.js} +138 -43
  177. package/dist/esm/snk-application.entry.js +250 -71
  178. package/dist/esm/snk-attach.entry.js +47 -34
  179. package/dist/esm/{snk-form-config.entry.js → snk-config-options_3.entry.js} +399 -15
  180. package/dist/esm/snk-configurator.entry.js +1 -1
  181. package/dist/esm/snk-crud.entry.js +23 -9
  182. package/dist/esm/snk-data-exporter.entry.js +35 -23
  183. package/dist/esm/{snk-data-unit-8eec78bd.js → snk-data-unit-11a49fc3.js} +54 -32
  184. package/dist/esm/snk-data-unit.entry.js +5 -5
  185. package/dist/esm/snk-detail-view.entry.js +13 -13
  186. package/dist/esm/snk-exporter-email-sender.entry.js +1 -1
  187. package/dist/esm/snk-field-config.entry.js +1 -1
  188. package/dist/esm/snk-filter-bar_4.entry.js +1429 -0
  189. package/dist/esm/snk-filter-binary-select.entry.js +1 -1
  190. package/dist/esm/snk-filter-checkbox-list.entry.js +1 -1
  191. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  192. package/dist/esm/snk-filter-text.entry.js +2 -1
  193. package/dist/esm/snk-grid.entry.js +66 -16
  194. package/dist/esm/{snk-guides-viewer-dda0fede.js → snk-guides-viewer-94918cf7.js} +30 -14
  195. package/dist/esm/snk-guides-viewer.entry.js +9 -9
  196. package/dist/esm/snk-personalized-filter-editor.entry.js +4 -4
  197. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  198. package/dist/esm/snk-pesquisa.entry.js +123 -31
  199. package/dist/esm/snk-print-selector.entry.js +1 -1
  200. package/dist/esm/snk-simple-bar.entry.js +1 -1
  201. package/dist/esm/snk-simple-crud.entry.js +99 -43
  202. package/dist/esm/snk-tab-config.entry.js +1 -1
  203. package/dist/esm/snk-taskbar.entry.js +65 -39
  204. package/dist/sankhyablocks/p-09067bee.entry.js +1 -0
  205. package/dist/sankhyablocks/p-0d86c004.entry.js +1 -0
  206. package/dist/sankhyablocks/p-1435701f.js +26 -0
  207. package/dist/sankhyablocks/p-16a1dd18.entry.js +1 -0
  208. package/dist/sankhyablocks/p-16cc8640.entry.js +11 -0
  209. package/dist/sankhyablocks/p-17425c72.js +1 -0
  210. package/dist/sankhyablocks/{p-52920496.js → p-19dc71e9.js} +1 -1
  211. package/dist/sankhyablocks/p-1a91d1f3.entry.js +1 -0
  212. package/dist/sankhyablocks/{p-47db7e88.entry.js → p-1cf39cfd.entry.js} +1 -1
  213. package/dist/sankhyablocks/p-23736d75.js +1 -0
  214. package/dist/sankhyablocks/{p-8eb67fa4.entry.js → p-2d3f9482.entry.js} +1 -1
  215. package/dist/sankhyablocks/p-3150ad41.js +1 -0
  216. package/dist/sankhyablocks/{p-c1d57831.entry.js → p-3a3d4055.entry.js} +1 -1
  217. package/dist/sankhyablocks/{p-7663f597.entry.js → p-41793e17.entry.js} +1 -1
  218. package/dist/sankhyablocks/{p-72fc257b.entry.js → p-434817f0.entry.js} +1 -1
  219. package/dist/sankhyablocks/p-469384a2.entry.js +1 -0
  220. package/dist/sankhyablocks/p-47178038.entry.js +1 -0
  221. package/dist/sankhyablocks/p-471785a1.entry.js +1 -0
  222. package/dist/sankhyablocks/p-4ca8e061.entry.js +1 -0
  223. package/dist/sankhyablocks/{p-aaa3ee68.entry.js → p-5f157b09.entry.js} +1 -1
  224. package/dist/sankhyablocks/p-60e4db34.js +1 -0
  225. package/dist/sankhyablocks/p-618a29ed.entry.js +1 -0
  226. package/dist/sankhyablocks/p-619aeac8.entry.js +1 -0
  227. package/dist/sankhyablocks/p-68134a67.entry.js +1 -0
  228. package/dist/sankhyablocks/p-798386c7.js +6 -0
  229. package/dist/sankhyablocks/p-7dd49d15.js +1 -0
  230. package/dist/sankhyablocks/{p-2c68b3ae.entry.js → p-82ee6dc3.entry.js} +1 -1
  231. package/dist/sankhyablocks/p-89c92727.entry.js +1 -0
  232. package/dist/sankhyablocks/p-8a1ee5b5.js +1 -0
  233. package/dist/sankhyablocks/{p-95df461f.entry.js → p-8b4fc28f.entry.js} +1 -1
  234. package/dist/sankhyablocks/p-8bd86610.entry.js +1 -0
  235. package/dist/sankhyablocks/{p-41f8bfa3.entry.js → p-8c235d4c.entry.js} +1 -1
  236. package/dist/sankhyablocks/{p-b0ef4383.js → p-95ce311a.js} +1 -1
  237. package/dist/sankhyablocks/p-a3803d7c.entry.js +1 -0
  238. package/dist/sankhyablocks/p-aaef93e8.js +1 -0
  239. package/dist/sankhyablocks/p-c2e468c9.entry.js +1 -0
  240. package/dist/sankhyablocks/p-d62228fb.js +1 -0
  241. package/dist/sankhyablocks/p-d92d4f91.entry.js +1 -0
  242. package/dist/sankhyablocks/p-ddefbbc7.js +60 -0
  243. package/dist/sankhyablocks/p-edbe8e15.entry.js +1 -0
  244. package/dist/sankhyablocks/{p-913a9979.js → p-f0b9303b.js} +1 -1
  245. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  246. package/dist/types/components/snk-actions-button/actions/index.d.ts +1 -0
  247. package/dist/types/components/snk-actions-button/interfaces/index.d.ts +3 -0
  248. package/dist/types/components/snk-actions-button/snk-actions-button.d.ts +3 -2
  249. package/dist/types/components/snk-application/request-listener/DebouncedRequestListener.d.ts +11 -0
  250. package/dist/types/components/snk-application/request-listener/RequestListenerFactory.d.ts +12 -0
  251. package/dist/types/components/snk-application/request-listener/RequestListenerLoadingBar.d.ts +13 -0
  252. package/dist/types/components/snk-application/snk-application.d.ts +28 -14
  253. package/dist/types/components/snk-attach/snk-attach.d.ts +1 -0
  254. package/dist/types/components/snk-crud/snk-crud.d.ts +21 -0
  255. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +15 -0
  256. package/dist/types/components/snk-data-exporter/exporter-strategy/ClientSideExporterStrategy.d.ts +1 -0
  257. package/dist/types/components/snk-data-exporter/exporter-strategy/ServerSideExporterStrategy.d.ts +1 -0
  258. package/dist/types/components/snk-data-exporter/test/resources/ClientSideExporterStrategyResources.d.ts +3 -3
  259. package/dist/types/components/snk-data-exporter/utils/ParserExport.d.ts +1 -1
  260. package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +2 -0
  261. package/dist/types/components/snk-filter-bar/filter-item/filter-item-type-mask.enum.d.ts +7 -0
  262. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +2 -0
  263. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +15 -1
  264. package/dist/types/components/snk-form-config/SnkFormConfigManager.d.ts +7 -2
  265. package/dist/types/components/snk-form-config/snk-form-config.d.ts +4 -0
  266. package/dist/types/components/snk-grid/snk-grid.d.ts +26 -0
  267. package/dist/types/components/snk-pesquisa/pesquisa-grid/pesquisa-grid.d.ts +38 -0
  268. package/dist/types/components/snk-pesquisa/pesquisa-tree/pesquisa-tree.d.ts +29 -0
  269. package/dist/types/components/snk-pesquisa/pesquisaHelper.d.ts +19 -0
  270. package/dist/types/components/snk-pesquisa/snk-pesquisa.d.ts +36 -1
  271. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +27 -7
  272. package/dist/types/components/snk-simple-form-config/snk-simple-form-config.d.ts +34 -0
  273. package/dist/types/components/snk-taskbar/processor/taskbar-processor.d.ts +1 -0
  274. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +11 -0
  275. package/dist/types/components.d.ts +372 -15
  276. package/dist/types/lib/dataUnit/dataUnitInMemoryUtils.d.ts +12 -2
  277. package/dist/types/lib/http/data-fetcher/DataFetcher.d.ts +1 -0
  278. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.d.ts +3 -2
  279. package/dist/types/lib/http/data-fetcher/fetchers/fetchDataExporter/interfaces/IFetchDataExporterParams.d.ts +1 -1
  280. package/dist/types/lib/http/data-fetcher/fetchers/form-config-fetcher.d.ts +8 -2
  281. package/dist/types/lib/http/data-fetcher/fetchers/parameters-fecher.d.ts +1 -0
  282. package/dist/types/lib/http/data-fetcher/fetchers/pesquisa-fetcher.d.ts +10 -1
  283. package/dist/types/lib/utils/ContinuousInsertUtils.d.ts +10 -0
  284. package/dist/types/lib/utils/CrudUtils.d.ts +1 -0
  285. package/dist/types/lib/utils/GetSelectedRecordsIDsInfo.d.ts +3 -0
  286. package/package.json +4 -3
  287. package/react/components.d.ts +3 -0
  288. package/react/components.js +3 -0
  289. package/react/components.js.map +1 -1
  290. package/dist/cjs/snk-config-options.cjs.entry.js +0 -239
  291. package/dist/cjs/snk-filter-bar.cjs.entry.js +0 -714
  292. package/dist/cjs/snk-filter-item.cjs.entry.js +0 -312
  293. package/dist/cjs/snk-filter-list.cjs.entry.js +0 -152
  294. package/dist/cjs/snk-filter-modal.cjs.entry.js +0 -249
  295. package/dist/cjs/snk-form.cjs.entry.js +0 -143
  296. package/dist/esm/pesquisa-fetcher-03c8f919.js +0 -164
  297. package/dist/esm/snk-config-options.entry.js +0 -235
  298. package/dist/esm/snk-filter-bar.entry.js +0 -710
  299. package/dist/esm/snk-filter-item.entry.js +0 -308
  300. package/dist/esm/snk-filter-list.entry.js +0 -148
  301. package/dist/esm/snk-filter-modal.entry.js +0 -245
  302. package/dist/esm/snk-form.entry.js +0 -139
  303. package/dist/sankhyablocks/p-045eae4d.entry.js +0 -11
  304. package/dist/sankhyablocks/p-219f888d.entry.js +0 -1
  305. package/dist/sankhyablocks/p-2a408684.js +0 -1
  306. package/dist/sankhyablocks/p-3a212712.js +0 -1
  307. package/dist/sankhyablocks/p-3b60db06.entry.js +0 -1
  308. package/dist/sankhyablocks/p-450c60e4.entry.js +0 -1
  309. package/dist/sankhyablocks/p-46d38387.entry.js +0 -1
  310. package/dist/sankhyablocks/p-4e5e1313.entry.js +0 -1
  311. package/dist/sankhyablocks/p-547eeac8.entry.js +0 -1
  312. package/dist/sankhyablocks/p-62ba211a.entry.js +0 -1
  313. package/dist/sankhyablocks/p-70a4af56.entry.js +0 -1
  314. package/dist/sankhyablocks/p-7505da04.entry.js +0 -1
  315. package/dist/sankhyablocks/p-75e674ed.entry.js +0 -1
  316. package/dist/sankhyablocks/p-7a337364.js +0 -1
  317. package/dist/sankhyablocks/p-7a85fd49.entry.js +0 -1
  318. package/dist/sankhyablocks/p-7b08d0f8.entry.js +0 -1
  319. package/dist/sankhyablocks/p-88aa931b.entry.js +0 -1
  320. package/dist/sankhyablocks/p-96a89d58.entry.js +0 -1
  321. package/dist/sankhyablocks/p-9863d682.js +0 -1
  322. package/dist/sankhyablocks/p-af8efd95.js +0 -6
  323. package/dist/sankhyablocks/p-b05d8893.entry.js +0 -1
  324. package/dist/sankhyablocks/p-b11aa1e0.entry.js +0 -1
  325. package/dist/sankhyablocks/p-c2495304.js +0 -1
  326. package/dist/sankhyablocks/p-d1791da2.entry.js +0 -1
  327. package/dist/sankhyablocks/p-d3f53df2.entry.js +0 -1
  328. package/dist/sankhyablocks/p-d6e26ea8.entry.js +0 -1
  329. package/dist/sankhyablocks/p-dc7c9047.js +0 -1
  330. package/dist/sankhyablocks/p-df5451c7.js +0 -26
  331. package/dist/sankhyablocks/p-e549f7d1.js +0 -1
  332. package/dist/sankhyablocks/p-e8763234.entry.js +0 -1
  333. package/dist/sankhyablocks/p-f2809746.entry.js +0 -1
  334. package/dist/sankhyablocks/p-fa4d8cb4.js +0 -1
  335. package/dist/sankhyablocks/p-fe79f83a.js +0 -60
  336. package/dist/types/components/snk-data-exporter/utils/RecordIDUtils.d.ts +0 -3
@@ -4,8 +4,8 @@ import { ApplicationUtils, DialogType } from '@sankhyalabs/ezui/dist/collection/
4
4
  import { OperationMap, SnkMessageBuilder } from '../../lib/message/SnkMessageBuilder';
5
5
  import { DatasetStrategy } from '../../lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy';
6
6
  import { getRecordValue } from '../../lib/dataUnit/ValueFormatter';
7
- import { getSelectedIDs } from '../snk-data-exporter/utils/RecordIDUtils';
8
7
  import { convertType } from '@sankhyalabs/core/dist/dataunit/metadata/DataType';
8
+ import { getSelectedRecordsIDsInfo } from '../../lib/utils/GetSelectedRecordsIDsInfo';
9
9
  export class SnkDataUnit {
10
10
  constructor() {
11
11
  this._onDataUnitResolve = [];
@@ -16,7 +16,7 @@ export class SnkDataUnit {
16
16
  this._rowMetadataCache = new Map();
17
17
  this.REGEX_DATAUNIT_NAME = /dd:\/\/(.+?)\//;
18
18
  this._dataUnitObserver = async (action) => {
19
- const duState = this.buildDataState(action.type);
19
+ const duState = await this.buildDataState(action.type);
20
20
  this.dataState = duState;
21
21
  this.messagesBuilder.currentOperation = this.getMessageOperation();
22
22
  switch (action.type) {
@@ -110,7 +110,7 @@ export class SnkDataUnit {
110
110
  * @returns Retorna a lista de IDs dos registros selecionados.
111
111
  */
112
112
  async getSelectedRecordsIDsInfo() {
113
- return Promise.resolve(getSelectedIDs(this.dataUnit));
113
+ return getSelectedRecordsIDsInfo(this.dataUnit);
114
114
  }
115
115
  /**
116
116
  * Retorna os campos que possuem a propriedade "rmp" (Row Metadata Provider).
@@ -130,14 +130,22 @@ export class SnkDataUnit {
130
130
  async getRowMetadata(record) {
131
131
  return this.doGetRowMetadata(record);
132
132
  }
133
- doGetRowMetadata(record) {
133
+ async doGetRowMetadata(record) {
134
134
  const selectedRecord = this.dataUnit.getSelectedRecord();
135
135
  if (!record && !selectedRecord) {
136
136
  return;
137
137
  }
138
138
  const currentRecord = record || selectedRecord;
139
139
  const recordId = typeof currentRecord === 'string' ? currentRecord : currentRecord.__record__id__;
140
- const rowMetadata = this._metadataByRow.get(recordId);
140
+ let rowMetadata = this._metadataByRow.get(recordId);
141
+ /*
142
+ Nao fazemos cache de metadataByRow pra registros novos, pois a chave do mesmo
143
+ muda ao ser salvo, por isso essa tratativa é necessária para que o dataState fique com metadados
144
+ corretos nao confiando apenas no _metadataByRow
145
+ */
146
+ if (this.dataUnit.isNewRecord(recordId) && !rowMetadata) {
147
+ rowMetadata = await this.handleLoadRowMetadata(selectedRecord);
148
+ }
141
149
  if (!rowMetadata) {
142
150
  return;
143
151
  }
@@ -331,7 +339,7 @@ export class SnkDataUnit {
331
339
  case Action.RECORDS_COPIED:
332
340
  return this.interceptRecordsCopied(action);
333
341
  case Action.DATA_CHANGED:
334
- await this.handleLoadRowMetadata(action);
342
+ await this.handleLoadRowMetadata(action.payload);
335
343
  return await this.interceptDataChange(action);
336
344
  case Action.CHANGING_DATA:
337
345
  return await this.interceptDataChange(action);
@@ -351,8 +359,9 @@ export class SnkDataUnit {
351
359
  return action;
352
360
  }
353
361
  }
354
- async handleLoadRowMetadata(action) {
355
- const record = action.type === Action.DATA_CHANGED ? action.payload : action.payload.changes[0].record;
362
+ async handleLoadRowMetadata(record) {
363
+ if (!record)
364
+ return;
356
365
  const keysPayload = Object.keys(record);
357
366
  const rmpField = keysPayload.find((field) => this._fieldsWithRmp.includes(field));
358
367
  if (rmpField) {
@@ -431,7 +440,7 @@ export class SnkDataUnit {
431
440
  isAllowed(flag) {
432
441
  return this._permissions ? this._permissions.isSup || this._permissions[flag] : false;
433
442
  }
434
- buildDataState(actionType) {
443
+ async buildDataState(actionType) {
435
444
  var _a;
436
445
  const selectionInfo = this.dataUnit.getSelectionInfo();
437
446
  const isStartingInsertionMode = (this.dataUnit.hasDirtyRecords() || this.dataUnit.hasWaitingChanges()) && (selectionInfo === null || selectionInfo === void 0 ? void 0 : selectionInfo.isEmpty());
@@ -439,7 +448,7 @@ export class SnkDataUnit {
439
448
  let rowMetadata = (_a = this.dataState) === null || _a === void 0 ? void 0 : _a.rowMetadata;
440
449
  const allowedOverwrite = [Action.SELECTION_CHANGED, Action.EDITION_CANCELED, Action.NEXT_SELECTED, Action.PREVIOUS_SELECTED];
441
450
  if (selectedRecord && (!rowMetadata || allowedOverwrite.includes(actionType))) {
442
- rowMetadata = this.doGetRowMetadata(selectedRecord);
451
+ rowMetadata = await this.doGetRowMetadata(selectedRecord);
443
452
  }
444
453
  else if (rowMetadata) {
445
454
  rowMetadata.getProp = this.buildGetPropRowMetadata(rowMetadata);
@@ -461,17 +470,20 @@ export class SnkDataUnit {
461
470
  });
462
471
  }
463
472
  async handleDataSaved(action) {
464
- const newRowMetadata = await this.handleLoadRowMetadata(action);
473
+ var _a, _b, _c;
474
+ const newRowMetadata = await this.handleLoadRowMetadata((_c = (_b = (_a = action === null || action === void 0 ? void 0 : action.payload) === null || _a === void 0 ? void 0 : _a.changes) === null || _b === void 0 ? void 0 : _b[0]) === null || _c === void 0 ? void 0 : _c.record);
465
475
  if (newRowMetadata) {
466
476
  newRowMetadata.getProp = this.buildGetPropRowMetadata(newRowMetadata);
467
477
  }
468
478
  const recordId = action.payload.records[0].__record__id__;
469
479
  this._metadataByRow.set(recordId, newRowMetadata);
470
- this.dataState = this.buildDataState();
471
- if (this.ignoreSaveMessage) {
480
+ this.dataState = await this.buildDataState();
481
+ let saveOperation = action.payload.changes[0]._operation.toLowerCase();
482
+ if (saveOperation == 'copy')
483
+ saveOperation = OperationMap.CLONE;
484
+ if (this.ignoreSaveMessage && ![OperationMap.CLONE, OperationMap.INSERT].includes(saveOperation)) {
472
485
  return;
473
486
  }
474
- const saveOperation = action.payload.changes[0]._operation.toLowerCase();
475
487
  const msg = this.getMessage("snkDataUnit.saveInfo", action.payload.records[0], saveOperation);
476
488
  if (msg != undefined) {
477
489
  this.showSuccessMessage(msg);
@@ -479,14 +491,7 @@ export class SnkDataUnit {
479
491
  }
480
492
  handleRecordsRemoved(action) {
481
493
  var _a, _b;
482
- const cachedRecords = action.payload.cachedRecords;
483
- let removeFinishMsg;
484
- if ((cachedRecords === null || cachedRecords === void 0 ? void 0 : cachedRecords.length) > 1) {
485
- removeFinishMsg = this.getMessage("snkDataUnit.removeAllInfo", { size: cachedRecords.length });
486
- }
487
- else {
488
- removeFinishMsg = this.getMessage("snkDataUnit.removeInfo", action.payload.cachedRecords[0]);
489
- }
494
+ let removeFinishMsg = this.buildRemoveFinishMessage(action);
490
495
  if (removeFinishMsg != undefined) {
491
496
  this.showSuccessMessage(removeFinishMsg);
492
497
  }
@@ -497,6 +502,14 @@ export class SnkDataUnit {
497
502
  this.dataUnit.gotoPage(page);
498
503
  }
499
504
  }
505
+ buildRemoveFinishMessage(action) {
506
+ const records = action.payload.records;
507
+ if (!records || !records.length)
508
+ return undefined;
509
+ if ((records === null || records === void 0 ? void 0 : records.length) > 1)
510
+ return this.getMessage('snkDataUnit.removeAllInfo', { size: records.length });
511
+ return this.getMessage('snkDataUnit.removeInfo', records);
512
+ }
500
513
  /**
501
514
  * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
502
515
  * através de um pequeno modulo na estrutura da aplicação:
@@ -540,21 +553,30 @@ export class SnkDataUnit {
540
553
  return await this._application.getDataUnit(this.entityName, cacheName, null, this.configName, this.resourceID);
541
554
  }
542
555
  }
556
+ updateMetadataWithRMP() {
557
+ this.fillFieldsWithRmp(this.dataUnit.metadata);
558
+ this.fillFieldsWithRmPrecision(this.dataUnit.metadata);
559
+ const dataUnitUpdatedMetadata = this.handleDULinksOnMetadataLoaded(this.dataUnit.metadata);
560
+ this.dataUnit.metadata = dataUnitUpdatedMetadata;
561
+ }
543
562
  async loadDataUnit() {
544
- var _a;
563
+ var _a, _b;
545
564
  if (this.dataUnit == null && this._application && this.entityName) {
546
565
  this.dataUnit = await this.getDataUnitParentOrChild();
547
566
  }
548
567
  if (this.dataUnit) {
549
568
  this.dataUnit.pageSize = this.pageSize;
550
569
  this.dataUnit.unsubscribe(this._dataUnitObserver);
551
- this.dataUnit.addInterceptor(this);
552
570
  this.dataUnit.subscribe(this._dataUnitObserver);
553
- await this.dataUnit.loadMetadata();
554
- if ((_a = this.dataUnit.records) === null || _a === void 0 ? void 0 : _a.length) {
555
- this.getMetadataByRow(this.dataUnit);
571
+ if ((_a = this.dataUnit) === null || _a === void 0 ? void 0 : _a.metadata) {
572
+ this.updateMetadataWithRMP();
556
573
  }
557
- this.dataState = this.buildDataState();
574
+ this.dataUnit.addInterceptor(this);
575
+ if ((_b = this.dataUnit.records) === null || _b === void 0 ? void 0 : _b.length) {
576
+ const { records } = this.getMetadataByRow(this.dataUnit);
577
+ this.dataUnit.records = records;
578
+ }
579
+ this.dataState = await this.buildDataState();
558
580
  let resolver;
559
581
  while (resolver = this._onDataUnitResolve.pop()) {
560
582
  resolver(this.dataUnit);
@@ -617,11 +639,11 @@ export class SnkDataUnit {
617
639
  }
618
640
  }
619
641
  instanceMessagesBuilder() {
620
- var _a, _b;
642
+ var _a;
621
643
  if (this.messagesBuilder) {
622
644
  return;
623
645
  }
624
- this.messagesBuilder = new SnkMessageBuilder((_b = (_a = this.domainMessagesBuilder) !== null && _a !== void 0 ? _a : this.entityName) !== null && _b !== void 0 ? _b : 'InMemoryDomain');
646
+ this.messagesBuilder = new SnkMessageBuilder((_a = this.domainMessagesBuilder) !== null && _a !== void 0 ? _a : this.entityName);
625
647
  }
626
648
  //---------------------------------------------
627
649
  // Lifecycle web component
@@ -74,7 +74,7 @@ export class SnkFilterBinarySelect {
74
74
  }
75
75
  const [optOne, optTwo] = this.config.props.options;
76
76
  if (this.presentationMode === EPresentationMode.MODAL) {
77
- return (h(Host, null, h("div", { class: "ez-row ez-size-height--full" }, h("label", { class: "ez-text ez-title--small ez-title--primary ez-size-height--full ez-flex ez-flex--row ez-flex--align-items-center ez-col ez-col--sd-4" }, this.config.detailModal), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkOne = ref, id: `${this.config.id}_${optOne.name || "option1"}`, class: "sc-snk-filter-bar editor__ez-check", label: optOne.label, value: this.isSelected(optOne.name), compact: true })), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkTwo = ref, id: `${this.config.id}_${optTwo.name || "option2"}`, class: "sc-snk-filter-bar editor__ez-check", label: optTwo.label, value: this.isSelected(optTwo.name), compact: true })))));
77
+ return (h(Host, null, h("div", { class: "ez-row ez-size-height--full" }, h("label", { class: "ez-text ez-title--small ez-title--primary ez-size-height--full ez-flex ez-flex--row ez-flex--align-items-center ez-col ez-col--sd-4" }, this.config.detailModal), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkOne = ref, id: `${this.config.id}_${optOne.name || "option1"}`, class: "sc-snk-filter-bar editor__ez-check", label: optOne.label, value: this.isSelected(optOne.name) })), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkTwo = ref, id: `${this.config.id}_${optTwo.name || "option2"}`, class: "sc-snk-filter-bar editor__ez-check", label: optTwo.label, value: this.isSelected(optTwo.name) })))));
78
78
  }
79
79
  return (h(Host, null, h("ez-radio-button", { value: this._radioButtonValue }, h("ez-radio-button-option", { id: `${this.config.id}_${optOne.name || "option1"}`, class: "sc-snk-filter-bar editor__ez-check", label: optOne.label, value: optOne.name }), h("ez-radio-button-option", { id: `${this.config.id}_${optTwo.name || "option2"}`, class: "sc-snk-filter-bar editor__ez-check", label: optTwo.label, value: optTwo.name }), h("ez-radio-button-option", { id: `${this.config.id}_option3`, class: "sc-snk-filter-bar editor__ez-check", label: `${optOne.label} + ${optTwo.label}`, value: this._noOptionValue }))));
80
80
  }
@@ -19,7 +19,7 @@ export class SnkFilterCheckboxList {
19
19
  this.valueChanged.emit((_b = this.config) === null || _b === void 0 ? void 0 : _b.value);
20
20
  }
21
21
  renderOptions() {
22
- return this.optionsList.map(option => (h("ez-check", { label: option.label, compact: true, onEzChange: (event) => this.handleToggleCheck(option, event.detail), value: !!this.isChecked(option.name) })));
22
+ return this.optionsList.map(option => (h("ez-check", { label: option.label, onEzChange: (event) => this.handleToggleCheck(option, event.detail), value: !!this.isChecked(option.name) })));
23
23
  }
24
24
  isChecked(itemName) {
25
25
  var _a;
@@ -18,10 +18,11 @@ export class SnkFilterText {
18
18
  }
19
19
  }
20
20
  render() {
21
+ var _a;
21
22
  if (!this.config) {
22
23
  return undefined;
23
24
  }
24
- return (h("ez-text-input", { id: this.config.id, ref: ref => this._textInputElement = ref, label: this.config.label, value: this.config.value }));
25
+ return (h("ez-text-input", { id: this.config.id, ref: ref => this._textInputElement = ref, label: this.config.label, value: this.config.value, mask: (_a = this.config) === null || _a === void 0 ? void 0 : _a.mask, cleanValueMask: true }));
25
26
  }
26
27
  static get is() { return "snk-filter-text"; }
27
28
  static get properties() {
@@ -48,6 +48,7 @@
48
48
  .SnkFilterPersonalized_list-actions {
49
49
  display: none;
50
50
  align-items: center;
51
+ gap: var(--space--3xs);
51
52
  }
52
53
 
53
54
  .SnkFilterPersonalized_list-item--modal:hover .SnkFilterPersonalized_list-actions {
@@ -64,3 +65,15 @@
64
65
  .SnkFilterPersonalized_list-item--chip :first-of-type {
65
66
  gap: var(--space--3xs);
66
67
  }
68
+
69
+ .SnkFilterPersonalized_list-icon {
70
+ --ez-icon--color: var(--title--primary, #2B3A54);
71
+ cursor: pointer;
72
+ }
73
+
74
+ .SnkFilterPersonalized_list-icon:hover {
75
+ outline: none;
76
+ color: var(--color--primary-600, #007a5a);
77
+ fill: var(--color--primary-600, #007a5a);
78
+ --ez-icon--color: var(--color--primary-600, #007a5a);
79
+ }
@@ -39,15 +39,15 @@ export class SnkFilterPersonalized {
39
39
  }
40
40
  getItemContent(item) {
41
41
  var _a, _b;
42
- const CheckboxElement = () => (h("ez-check", Object.assign({ class: "SnkFilterPersonalized_checkbox", id: `param_${item.id}`, key: item.id, compact: true, value: item.visible, label: item.label, onEzChange: ({ detail: visible }) => this.handleItemChange.bind(this)(visible, item.id) }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: `${ElementIDUtils.getInternalIDInfo(`checkboxFilter_${item.id}`)}` })));
42
+ const CheckboxElement = () => (h("ez-check", Object.assign({ class: "SnkFilterPersonalized_checkbox", id: `param_${item.id}`, key: item.id, value: item.visible, label: item.label, onEzChange: ({ detail: visible }) => this.handleItemChange.bind(this)(visible, item.id) }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: `${ElementIDUtils.getInternalIDInfo(`checkboxFilter_${item.id}`)}` })));
43
43
  const isVariable = !!((_b = (_a = item.props) === null || _a === void 0 ? void 0 : _a.personalizedFilter) === null || _b === void 0 ? void 0 : _b.parameters.length);
44
- return (h("div", { class: `${!this.isModalMode() ? "SnkFilterPersonalized_list-item--chip" : ""}` }, h("li", { class: `${this.isModalMode() ? "SnkFilterPersonalized_list-item--modal" : ""}` }, h("div", { class: "ez-flex ez-flex--align-items-center ez-margin-right--small ez-size-width--full" }, h(CheckboxElement, null), this.buildModalListActions(item, isVariable))), (item.visible && isVariable) && (h("div", { class: "ez-row ez-padding--small" }, this.getFormField(item)))));
44
+ return (h("div", { class: `${!this.isModalMode() ? "SnkFilterPersonalized_list-item--chip" : ""}` }, h("li", { class: `${this.isModalMode() ? "SnkFilterPersonalized_list-item--modal" : ""}` }, h("div", { class: "ez-flex ez-flex--align-items-center ez-flex--justify-between ez-size-width--full" }, h(CheckboxElement, null), this.buildModalListActions(item, isVariable))), (item.visible && isVariable) && (h("div", { class: "ez-row ez-padding--small" }, this.getFormField(item)))));
45
45
  }
46
46
  buildModalListActions(item, isVariable) {
47
47
  if (!this.isModalMode())
48
48
  return;
49
49
  return (this.isModalMode() ?
50
- h("div", { class: "SnkFilterPersonalized_list-actions" }, h("ez-button", { size: "small", mode: "icon", iconName: "edit", title: this.getMessage('snkPersonalizedFilter.listActions.edit'), onClick: () => this.editFilter.emit(item.id) }), h("ez-button", { size: "small", mode: "icon", iconName: "delete", title: this.getMessage('snkPersonalizedFilter.listActions.delete'), onClick: this.handleDeleteFilter.bind(this, item) }))
50
+ h("div", { class: "SnkFilterPersonalized_list-actions" }, h("ez-icon", { class: 'SnkFilterPersonalized_list-icon', iconName: "edit", title: this.getMessage('snkPersonalizedFilter.listActions.edit'), onClick: () => this.editFilter.emit(item.id) }), h("ez-icon", { class: 'SnkFilterPersonalized_list-icon', iconName: "delete", title: this.getMessage('snkPersonalizedFilter.listActions.delete'), onClick: this.handleDeleteFilter.bind(this, item) }))
51
51
  :
52
52
  isVariable && (h("ez-badge", Object.assign({ class: "ez-badge--warning-subtle ez-margin-right--small", label: this.getMessage('snkPersonalizedFilter.info.badgeVariable'), size: "medium" }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: `${ElementIDUtils.getInternalIDInfo(`variableBadge_${item.id}`)}` }))));
53
53
  }
@@ -0,0 +1,8 @@
1
+ var FilterItemTypeMask;
2
+ (function (FilterItemTypeMask) {
3
+ FilterItemTypeMask["CEP"] = "#####-###";
4
+ FilterItemTypeMask["TELEFONE"] = "(##) ####-####";
5
+ FilterItemTypeMask["CPF"] = "###.###.###-##";
6
+ FilterItemTypeMask["CNPJ"] = "##.###.###/####-##";
7
+ })(FilterItemTypeMask || (FilterItemTypeMask = {}));
8
+ export default FilterItemTypeMask;
@@ -1,4 +1,4 @@
1
- import { ElementIDUtils, FloatingManager, DateUtils } from '@sankhyalabs/core';
1
+ import { ElementIDUtils, FloatingManager, DateUtils, MaskFormatter } from '@sankhyalabs/core';
2
2
  import { h, Host } from '@stencil/core';
3
3
  import FilterItemType from './filter-item-type.enum';
4
4
  import { FilterNumberVariation } from './editors/enum/filterNumberVariation';
@@ -211,6 +211,10 @@ export class SnkFilterItem {
211
211
  return `${label}: ${this.getMessage('snkFilterBar.onlyEndToltip')} ${Number(end)}`;
212
212
  }
213
213
  }
214
+ if (this.config.mask) {
215
+ const _maskFormatter = new MaskFormatter(this.config.mask);
216
+ return `${label}: ${_maskFormatter.format(value)}`;
217
+ }
214
218
  return `${label}: ${value}`;
215
219
  }
216
220
  return label;
@@ -24,7 +24,7 @@ ez-modal {
24
24
 
25
25
  .snk-filter-modal__rendered-items {
26
26
  max-height: 760px;
27
- overflow-x: clip;
27
+ overflow-x: hidden;
28
28
  overflow-y: auto;
29
29
  }
30
30
 
@@ -144,7 +144,9 @@ export class SnkFilterModal {
144
144
  this.filters = ObjectUtils.copy(filterListCopy);
145
145
  return;
146
146
  }
147
- this.filters.find(filter => filter.id === filterItem.id).value = undefined;
147
+ const filter = this.filters.find(filter => filter.id === filterItem.id);
148
+ filter.value = undefined;
149
+ this.filters = ObjectUtils.copy(this.filters);
148
150
  }
149
151
  uncheckFilterValues(valueList) {
150
152
  valueList.forEach(value => {
@@ -105,7 +105,7 @@
105
105
 
106
106
  .snk-filter-bar__filter-item-container {
107
107
  display: flex;
108
- align-self: center;
108
+ align-items: start;
109
109
  }
110
110
 
111
111
  .snk-filter-bar__scroller :first-child {
@@ -1,4 +1,4 @@
1
- import { ApplicationContext, ElementIDUtils, ErrorException, ObjectUtils } from '@sankhyalabs/core';
1
+ import { ApplicationContext, ElementIDUtils, ObjectUtils, ErrorException, LockManager, LockManagerOperation } from '@sankhyalabs/core';
2
2
  import { EzScrollDirection } from '@sankhyalabs/ezui/dist/collection/components/ez-scroller/EzScrollDirection';
3
3
  import { h, Host } from '@stencil/core';
4
4
  import { ConfigStorage } from '../../lib/configs/ConfigStorage';
@@ -14,19 +14,22 @@ export class SnkFilterBar {
14
14
  this._firstLoad = true;
15
15
  this._pendingVariables = false;
16
16
  this._customfiltersToBeUpdated = [];
17
+ this._resolveLoading = undefined;
17
18
  this._calculateSortIndex = (item) => {
18
- let index = item.hardFixed ? 1000000 : 0;
19
- //campos Hard Fixed não variam a ordem
20
- if (!item.hardFixed) {
21
- index += item.fixed ? 100000 : 0;
22
- index += item.value == undefined ? 0 : 10000;
23
- index += this._updateSequence.lastIndexOf(item.id) + 1;
24
- }
19
+ if (!item.visible)
20
+ return 0;
21
+ if (item.hardFixed)
22
+ return 1000000; //campos Hard Fixed não variam a ordem
23
+ let index = item.fixed ? 100000 : 0;
24
+ index += this.hasValidValue(item) ? 10000 : 0;
25
+ index += this._updateSequence.lastIndexOf(item.id) + 1;
25
26
  return index;
26
27
  };
27
28
  this._filtersComparator = (a, b) => {
28
29
  return this._calculateSortIndex(b) - this._calculateSortIndex(a);
29
30
  };
31
+ this.enableLockManagerLoadingComp = false;
32
+ this.customFilterBarConfig = undefined;
30
33
  this.dataUnit = undefined;
31
34
  this.title = undefined;
32
35
  this.configName = undefined;
@@ -37,11 +40,19 @@ export class SnkFilterBar {
37
40
  this.disablePersonalizedFilter = undefined;
38
41
  this.filterBarLegacyConfigName = undefined;
39
42
  this.autoLoad = undefined;
43
+ this.afterApplyConfig = undefined;
40
44
  this.allowDefault = undefined;
41
45
  this.scrollerLocked = false;
42
46
  this.showPersonalizedFilter = false;
43
47
  this.personalizedFilterId = undefined;
44
48
  }
49
+ hasValidValue(item) {
50
+ if (item.value === undefined || item.value === null)
51
+ return false;
52
+ if (!Array.isArray(item.value))
53
+ return true;
54
+ return item.value.some(filterItem => filterItem.check === true);
55
+ }
45
56
  observeFilterConfig(newValue, oldValue) {
46
57
  if (ObjectUtils.equals(newValue, oldValue))
47
58
  return;
@@ -166,6 +177,7 @@ export class SnkFilterBar {
166
177
  return this.filterConfig.find(item => item.type === FilterItemType.PERSONALIZED);
167
178
  }
168
179
  async processAfterUpdateConfig() {
180
+ var _a;
169
181
  if (this._loadingPending) {
170
182
  if (await this._application.isLoadedByPk() && !this._configUpdated)
171
183
  return;
@@ -180,6 +192,7 @@ export class SnkFilterBar {
180
192
  if (this._configUpdated) {
181
193
  this._configUpdated = false;
182
194
  ConfigStorage.saveFilterBarConfig(this.filterConfig, this.configName, this.resourceID);
195
+ (_a = this.afterApplyConfig) === null || _a === void 0 ? void 0 : _a.call(this);
183
196
  }
184
197
  }
185
198
  async doLoadData(forceReload = false) {
@@ -268,7 +281,7 @@ export class SnkFilterBar {
268
281
  getFilterItems() {
269
282
  const pinnedItems = [];
270
283
  const unpinnedItems = [];
271
- this.filterConfig
284
+ this.filterConfig.sort((a, b) => this._filtersComparator(a, b))
272
285
  .filter(this.filterActiveFilter)
273
286
  .forEach((item, index) => {
274
287
  item = ObjectUtils.copy(item);
@@ -330,19 +343,23 @@ export class SnkFilterBar {
330
343
  }
331
344
  }
332
345
  async loadConfigFromStorage(clearCache) {
333
- if (clearCache) {
334
- await ConfigStorage.deleteFilterBarConfigCache(this.configName, this.resourceID);
346
+ try {
347
+ if (clearCache) {
348
+ await ConfigStorage.deleteFilterBarConfigCache(this.configName, this.resourceID);
349
+ }
350
+ let config;
351
+ if (this.customFilterBarConfig) {
352
+ config = await this.customFilterBarConfig(this.configName, this.resourceID, { contextURI: this.dataUnit.name });
353
+ }
354
+ else {
355
+ config = await ConfigStorage.loadFilterBarConfig(this.configName, this.resourceID, { contextURI: this.dataUnit.name });
356
+ }
357
+ this.filterConfig = config.map(item => this.normalizeItem(item));
358
+ this.filterConfig.sort((a, b) => this._filtersComparator(a, b));
359
+ }
360
+ catch (e) {
361
+ throw new ErrorException(this.getMessage("snkFilterBar.failToLoadConfig"), e);
335
362
  }
336
- return new Promise(accept => {
337
- ConfigStorage.loadFilterBarConfig(this.configName, this.resourceID, { contextURI: this.dataUnit.name })
338
- .then((filters) => {
339
- accept();
340
- this.filterConfig = filters.map(item => this.normalizeItem(item));
341
- })
342
- .catch(reason => {
343
- throw new ErrorException(this.getMessage("snkFilterBar.failToLoadConfig"), reason);
344
- });
345
- });
346
363
  }
347
364
  attachDataUnit() {
348
365
  if (this.dataUnit == undefined) {
@@ -380,7 +397,9 @@ export class SnkFilterBar {
380
397
  */
381
398
  async showFilterModal() {
382
399
  const callbackOnApplyFilter = (filters) => {
400
+ var _a;
383
401
  this.filterConfig = filters.map(this.normalizeItem).sort((a, b) => this._filtersComparator(a, b));
402
+ (_a = this.afterApplyConfig) === null || _a === void 0 ? void 0 : _a.call(this);
384
403
  };
385
404
  let filtersConfigCopy = ObjectUtils.copy(this.filterConfig);
386
405
  filtersConfigCopy = filtersConfigCopy.sort((itemA, itemB) => {
@@ -431,14 +450,26 @@ export class SnkFilterBar {
431
450
  this.personalizedFilterId = undefined;
432
451
  this.showPersonalizedFilter = false;
433
452
  }
434
- componentWillLoad() {
435
- this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
436
- if (this._application) {
437
- this.loadPermitions();
438
- this.addFilterBarLegacyConfigName();
439
- this.loadConfigFromStorage();
453
+ async componentWillLoad() {
454
+ var _a;
455
+ try {
456
+ this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
457
+ await this.attachDataUnit();
458
+ if (this._application) {
459
+ if (this._application.enableLockManagerLoadingApp && this.enableLockManagerLoadingComp) {
460
+ const appLoadLockerID = LockManager.addLockManagerCtxId(this._element);
461
+ this._resolveLoading = LockManager.lock(appLoadLockerID, LockManagerOperation.APP_LOADING);
462
+ }
463
+ await Promise.all([
464
+ this.loadPermitions(),
465
+ this.addFilterBarLegacyConfigName(),
466
+ this.loadConfigFromStorage(),
467
+ ]);
468
+ }
469
+ }
470
+ finally {
471
+ (_a = this._resolveLoading) === null || _a === void 0 ? void 0 : _a.call(this);
440
472
  }
441
- this.attachDataUnit();
442
473
  }
443
474
  componentDidRender() {
444
475
  this.processPendingFilter();
@@ -469,6 +500,50 @@ export class SnkFilterBar {
469
500
  }
470
501
  static get properties() {
471
502
  return {
503
+ "enableLockManagerLoadingComp": {
504
+ "type": "boolean",
505
+ "mutable": false,
506
+ "complexType": {
507
+ "original": "boolean",
508
+ "resolved": "boolean",
509
+ "references": {}
510
+ },
511
+ "required": false,
512
+ "optional": true,
513
+ "docs": {
514
+ "tags": [],
515
+ "text": "Define se o componente deve usar o LockManager para controle de carregamento"
516
+ },
517
+ "attribute": "enable-lock-manager-loading-comp",
518
+ "reflect": false,
519
+ "defaultValue": "false"
520
+ },
521
+ "customFilterBarConfig": {
522
+ "type": "unknown",
523
+ "mutable": false,
524
+ "complexType": {
525
+ "original": "(configName: string, resourceId: string, options: any) => Promise<Array<SnkFilterItemConfig>>",
526
+ "resolved": "(configName: string, resourceId: string, options: any) => Promise<SnkFilterItemConfig[]>",
527
+ "references": {
528
+ "Promise": {
529
+ "location": "global"
530
+ },
531
+ "Array": {
532
+ "location": "global"
533
+ },
534
+ "SnkFilterItemConfig": {
535
+ "location": "import",
536
+ "path": "./filter-item/snk-filter-item"
537
+ }
538
+ }
539
+ },
540
+ "required": false,
541
+ "optional": true,
542
+ "docs": {
543
+ "tags": [],
544
+ "text": "Loader customizado para carregar as configura\u00E7\u00F5es"
545
+ }
546
+ },
472
547
  "dataUnit": {
473
548
  "type": "unknown",
474
549
  "mutable": true,
@@ -651,6 +726,21 @@ export class SnkFilterBar {
651
726
  },
652
727
  "attribute": "auto-load",
653
728
  "reflect": false
729
+ },
730
+ "afterApplyConfig": {
731
+ "type": "unknown",
732
+ "mutable": false,
733
+ "complexType": {
734
+ "original": "() => void",
735
+ "resolved": "() => void",
736
+ "references": {}
737
+ },
738
+ "required": false,
739
+ "optional": true,
740
+ "docs": {
741
+ "tags": [],
742
+ "text": "Fun\u00E7\u00E3o chamada depois de aplicar os filtros."
743
+ }
654
744
  }
655
745
  };
656
746
  }
@@ -87,7 +87,7 @@ export class SnkForm {
87
87
  if (this.resourceID == undefined) {
88
88
  this.resourceID = await ResourceIDUtils.getResourceID();
89
89
  }
90
- this._configManager = new SnkFormConfigManager(this.configName, this.resourceID);
90
+ this._configManager = new SnkFormConfigManager(this.configName, this.resourceID, undefined, this._dataUnit);
91
91
  this.addFormLegacyConfig();
92
92
  await this._configManager.loadConfig();
93
93
  }
@@ -117,7 +117,7 @@ export class SnkForm {
117
117
  if (!this._dataUnit || !this._dataState) {
118
118
  return undefined;
119
119
  }
120
- return (h("section", null, h("div", { class: "ez-row" }, h("div", { class: "ez-col ez-col--sd-12" }, h("ez-form", { ref: (ref) => this._form = ref, key: "ezForm" + this._snkDataUnit.entityName, "data-element-id": "embedded", dataUnit: this._dataUnit, config: this._configManager.getConfig(this._dataState.insertionMode, this._dataUnit), recordsValidator: this.recordsValidator, class: this._showFormConfig ? 'snk-form__form--hidden' : '' }), this._showFormConfig &&
120
+ return (h("section", null, h("div", { class: "ez-row" }, h("div", { class: "ez-col ez-col--sd-12" }, h("ez-form", { ref: (ref) => this._form = ref, key: "ezForm" + this._snkDataUnit.entityName, "data-element-id": "embedded", dataUnit: this._dataUnit, config: this._configManager.getConfig(this._dataUnit), recordsValidator: this.recordsValidator, class: this._showFormConfig ? 'snk-form__form--hidden' : '' }), this._showFormConfig &&
121
121
  h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this._dataUnit, configManager: this._configManager, onConfigClose: () => this.closeConfig() })))));
122
122
  }
123
123
  static get is() { return "snk-form"; }