@sankhyalabs/sankhyablocks 8.16.0-dev.113 → 8.16.0-dev.115

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 (344) hide show
  1. package/dist/cjs/{ClientSideExporterProvider-a2753c93.js → ClientSideExporterProvider-0ce2bcd9.js} +2 -2
  2. package/dist/cjs/{ConfigStorage-df09fb78.js → ConfigStorage-48ba265b.js} +45 -17
  3. package/dist/cjs/FormConfigHelper-c664dbae.js +260 -0
  4. package/dist/cjs/{PersonalizedFilterUtils-0184ffbb.js → PersonalizedFilterUtils-7259cf65.js} +1 -1
  5. package/dist/cjs/{SnkFormConfigManager-45a8d7b7.js → SnkFormConfigManager-aa4631bd.js} +3 -4
  6. package/dist/cjs/{SnkMessageBuilder-9deeae08.js → SnkMessageBuilder-e3b7850b.js} +28 -3
  7. package/dist/cjs/config-header.cjs.entry.js +79 -0
  8. package/dist/cjs/configs-button.cjs.entry.js +61 -0
  9. package/dist/cjs/{constants-77c1b8bd.js → constants-6d82e405.js} +8 -38
  10. package/dist/cjs/default-filters-a09bf82b.js +8 -0
  11. package/dist/cjs/field-config_2.cjs.entry.js +324 -0
  12. package/dist/cjs/fields-layout.cjs.entry.js +341 -0
  13. package/dist/cjs/fields-selector.cjs.entry.js +74 -0
  14. package/dist/cjs/{filter-type.enum-b14ce507.js → filter-type.enum-2bb46d2a.js} +1 -0
  15. package/dist/cjs/guides-configurator.cjs.entry.js +164 -0
  16. package/dist/cjs/{index-102ba62d.js → index-0ad2baeb.js} +4 -5
  17. package/dist/cjs/{index-f9e81701.js → index-1cf293c1.js} +32 -10
  18. package/dist/cjs/{index-c5771aba.js → index-62760a9c.js} +5 -0
  19. package/dist/cjs/loader.cjs.js +2 -2
  20. package/dist/cjs/pesquisa-grid_2.cjs.entry.js +2 -2
  21. package/dist/cjs/sankhyablocks.cjs.js +2 -2
  22. package/dist/cjs/snk-actions-button_8.cjs.entry.js +3 -3
  23. package/dist/cjs/snk-actions-form.cjs.entry.js +1 -1
  24. package/dist/cjs/snk-application.cjs.entry.js +4 -4
  25. package/dist/cjs/snk-attach.cjs.entry.js +4 -4
  26. package/dist/cjs/snk-client-confirm.cjs.entry.js +1 -1
  27. package/dist/cjs/snk-configurator.cjs.entry.js +2 -2
  28. package/dist/cjs/snk-crud.cjs.entry.js +4 -4
  29. package/dist/cjs/snk-custom-slot-elements.cjs.entry.js +1 -1
  30. package/dist/cjs/snk-data-exporter.cjs.entry.js +4 -4
  31. package/dist/cjs/{snk-data-unit-57916de4.js → snk-data-unit-3684c96e.js} +2 -2
  32. package/dist/cjs/snk-data-unit.cjs.entry.js +3 -3
  33. package/dist/cjs/snk-default-filter.cjs.entry.js +77 -0
  34. package/dist/cjs/snk-detail-view.cjs.entry.js +8 -8
  35. package/dist/cjs/snk-entity-list.cjs.entry.js +1 -1
  36. package/dist/cjs/snk-exporter-email-sender.cjs.entry.js +1 -1
  37. package/dist/cjs/snk-expression-group_2.cjs.entry.js +10 -8
  38. package/dist/cjs/snk-filter-advanced-mode_2.cjs.entry.js +5 -4
  39. package/dist/cjs/snk-filter-bar_4.cjs.entry.js +82 -28
  40. package/dist/cjs/snk-filter-binary-select.cjs.entry.js +1 -1
  41. package/dist/cjs/snk-filter-checkbox-list.cjs.entry.js +1 -1
  42. package/dist/cjs/snk-filter-detail.cjs.entry.js +3 -3
  43. package/dist/cjs/snk-filter-field-search_2.cjs.entry.js +3 -3
  44. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  45. package/dist/cjs/snk-filter-multi-select.cjs.entry.js +1 -1
  46. package/dist/cjs/snk-filter-number.cjs.entry.js +1 -1
  47. package/dist/cjs/snk-filter-period.cjs.entry.js +1 -1
  48. package/dist/cjs/snk-filter-search.cjs.entry.js +1 -1
  49. package/dist/cjs/snk-filter-text.cjs.entry.js +1 -1
  50. package/dist/cjs/snk-form-summary.cjs.entry.js +1 -1
  51. package/dist/cjs/snk-form-view.cjs.entry.js +1 -1
  52. package/dist/cjs/snk-form_2.cjs.entry.js +433 -0
  53. package/dist/cjs/snk-grid.cjs.entry.js +6 -6
  54. package/dist/cjs/{snk-guides-viewer-d33379cd.js → snk-guides-viewer-edc0a00a.js} +5 -5
  55. package/dist/cjs/snk-guides-viewer.cjs.entry.js +7 -7
  56. package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +1 -1
  57. package/dist/cjs/snk-personalized-filter.cjs.entry.js +53 -18
  58. package/dist/cjs/snk-pesquisa.cjs.entry.js +2 -2
  59. package/dist/cjs/snk-print-selector.cjs.entry.js +1 -1
  60. package/dist/cjs/snk-simple-bar.cjs.entry.js +1 -1
  61. package/dist/cjs/snk-simple-crud.cjs.entry.js +7 -7
  62. package/dist/cjs/snk-taskbar.cjs.entry.js +3 -3
  63. package/dist/cjs/sortable.esm-9a110bb7.js +2668 -0
  64. package/dist/cjs/{taskbar-elements-6f4e06af.js → taskbar-elements-3b74cd21.js} +2 -2
  65. package/dist/cjs/teste-pesquisa.cjs.entry.js +1 -1
  66. package/dist/collection/collection-manifest.json +8 -14
  67. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +1 -1
  68. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +80 -12
  69. package/dist/collection/components/snk-filter-bar/filter-modal/subcomponents/snk-default-filter/snk-default-filter.css +34 -0
  70. package/dist/collection/components/snk-filter-bar/filter-modal/subcomponents/snk-default-filter/snk-default-filter.js +142 -0
  71. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +24 -15
  72. package/dist/collection/components/snk-filter-bar/types/default-filters.js +6 -0
  73. package/dist/collection/components/snk-filter-bar/types/filter-type.enum.js +1 -0
  74. package/dist/collection/components/snk-filter-bar/utils/SnkFilterModalFactory.js +4 -4
  75. package/dist/collection/components/snk-form-config/FormConfigHelper.js +245 -0
  76. package/dist/collection/components/snk-form-config/SnkFormConfigManager.js +4 -5
  77. package/dist/collection/components/snk-form-config/config-header/config-header.css +18 -0
  78. package/dist/collection/components/snk-form-config/config-header/config-header.js +236 -0
  79. package/dist/collection/components/snk-form-config/config-header/configs-button/configs-button.css +41 -0
  80. package/dist/collection/components/snk-form-config/config-header/configs-button/configs-button.js +170 -0
  81. package/dist/collection/components/snk-form-config/field-item/field-config/field-config.css +21 -0
  82. package/dist/collection/components/snk-form-config/field-item/field-config/field-config.js +408 -0
  83. package/dist/collection/components/snk-form-config/field-item/field-item.css +108 -0
  84. package/dist/collection/components/snk-form-config/field-item/field-item.js +206 -0
  85. package/dist/collection/components/snk-form-config/fields-layout/fields-layout.css +133 -0
  86. package/dist/collection/components/snk-form-config/fields-layout/fields-layout.js +578 -0
  87. package/dist/collection/components/snk-form-config/fields-selector/fields-selector.css +38 -0
  88. package/dist/collection/components/snk-form-config/fields-selector/fields-selector.js +146 -0
  89. package/dist/collection/components/snk-form-config/guides-configurator/guides-configurator.css +132 -0
  90. package/dist/collection/components/snk-form-config/guides-configurator/guides-configurator.js +317 -0
  91. package/dist/collection/components/snk-form-config/snk-form-config.css +16 -229
  92. package/dist/collection/components/snk-form-config/snk-form-config.js +288 -980
  93. package/dist/collection/components/snk-personalized-filter/interfaces/index.js +5 -0
  94. package/dist/collection/components/snk-personalized-filter/snk-personalized-filter.js +67 -13
  95. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-group/snk-expression-group.css +3 -0
  96. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-group/snk-expression-group.js +20 -1
  97. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.js +22 -3
  98. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-filter-assistent-mode/snk-filter-assistent-mode.js +20 -1
  99. package/dist/collection/lib/configs/ConfigStorage.js +16 -8
  100. package/dist/collection/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.js +29 -9
  101. package/dist/collection/lib/message/resources/snk-filter-bar.msg.js +6 -0
  102. package/dist/collection/lib/message/resources/snk-form.msg.js +16 -2
  103. package/dist/collection/lib/message/resources/snk-personalized-filter.msg.js +6 -1
  104. package/dist/collection/lib/utils/constants.js +7 -1
  105. package/dist/components/ConfigStorage.js +45 -17
  106. package/dist/components/PersonalizedFilterUtils.js +6 -1
  107. package/dist/components/SnkFormConfigManager.js +2 -3
  108. package/dist/components/SnkMessageBuilder.js +28 -3
  109. package/dist/components/{snk-tab-config.d.ts → config-header.d.ts} +4 -4
  110. package/dist/components/config-header.js +6 -0
  111. package/dist/components/config-header2.js +103 -0
  112. package/dist/components/configs-button.d.ts +11 -0
  113. package/dist/components/configs-button.js +6 -0
  114. package/dist/components/configs-button2.js +76 -0
  115. package/dist/components/constants.js +8 -34
  116. package/dist/components/field-config.d.ts +11 -0
  117. package/dist/components/field-config.js +6 -0
  118. package/dist/components/field-config2.js +525 -0
  119. package/dist/components/field-item.d.ts +11 -0
  120. package/dist/components/field-item.js +6 -0
  121. package/dist/components/field-item2.js +93 -0
  122. package/dist/components/fields-layout.d.ts +11 -0
  123. package/dist/components/fields-layout.js +6 -0
  124. package/dist/components/fields-layout2.js +370 -0
  125. package/dist/components/{snk-field-config.d.ts → fields-selector.d.ts} +4 -4
  126. package/dist/components/fields-selector.js +6 -0
  127. package/dist/components/fields-selector2.js +98 -0
  128. package/dist/components/guides-configurator.d.ts +11 -0
  129. package/dist/components/guides-configurator.js +6 -0
  130. package/dist/components/guides-configurator2.js +182 -0
  131. package/dist/components/index.d.ts +8 -3
  132. package/dist/components/index.js +8 -3
  133. package/dist/components/index2.js +3 -4
  134. package/dist/components/snk-application2.js +1 -1
  135. package/dist/components/snk-crud.js +86 -62
  136. package/dist/components/{snk-config-options.d.ts → snk-default-filter.d.ts} +4 -4
  137. package/dist/components/snk-default-filter.js +6 -0
  138. package/dist/components/snk-default-filter2.js +97 -0
  139. package/dist/components/snk-detail-view2.js +113 -89
  140. package/dist/components/snk-expression-group2.js +4 -2
  141. package/dist/components/snk-expression-item2.js +5 -3
  142. package/dist/components/snk-filter-assistent-mode2.js +4 -2
  143. package/dist/components/snk-filter-bar2.js +28 -19
  144. package/dist/components/snk-filter-modal-item2.js +1 -0
  145. package/dist/components/snk-filter-modal.js +59 -8
  146. package/dist/components/snk-form-config2.js +253 -953
  147. package/dist/components/snk-form.js +33 -9
  148. package/dist/components/snk-personalized-filter2.js +50 -14
  149. package/dist/components/sortable.esm.js +2666 -0
  150. package/dist/esm/{ClientSideExporterProvider-b3871edb.js → ClientSideExporterProvider-3ed744fd.js} +2 -2
  151. package/dist/esm/{ConfigStorage-71e6766f.js → ConfigStorage-79b9e180.js} +45 -17
  152. package/dist/esm/FormConfigHelper-49fe72ca.js +248 -0
  153. package/dist/esm/{PersonalizedFilterUtils-e2b38ef7.js → PersonalizedFilterUtils-2db38ff2.js} +1 -1
  154. package/dist/esm/{SnkFormConfigManager-be490a33.js → SnkFormConfigManager-b4b93298.js} +3 -4
  155. package/dist/esm/{SnkMessageBuilder-2dbd8fa2.js → SnkMessageBuilder-9c269caf.js} +28 -3
  156. package/dist/esm/config-header.entry.js +75 -0
  157. package/dist/esm/configs-button.entry.js +57 -0
  158. package/dist/esm/{constants-7db1128a.js → constants-7b422de0.js} +8 -34
  159. package/dist/esm/default-filters-50105e43.js +8 -0
  160. package/dist/esm/field-config_2.entry.js +319 -0
  161. package/dist/esm/fields-layout.entry.js +337 -0
  162. package/dist/esm/fields-selector.entry.js +70 -0
  163. package/dist/esm/{filter-type.enum-a80c1b6b.js → filter-type.enum-f6a8fe23.js} +1 -0
  164. package/dist/esm/guides-configurator.entry.js +160 -0
  165. package/dist/esm/{index-a7d3d3f1.js → index-479e1293.js} +32 -10
  166. package/dist/esm/{index-ae591a44.js → index-8acbae97.js} +6 -1
  167. package/dist/esm/{index-bdf75557.js → index-b72af127.js} +4 -5
  168. package/dist/esm/loader.js +3 -3
  169. package/dist/esm/pesquisa-grid_2.entry.js +2 -2
  170. package/dist/esm/sankhyablocks.js +3 -3
  171. package/dist/esm/snk-actions-button_8.entry.js +3 -3
  172. package/dist/esm/snk-actions-form.entry.js +1 -1
  173. package/dist/esm/snk-application.entry.js +4 -4
  174. package/dist/esm/snk-attach.entry.js +4 -4
  175. package/dist/esm/snk-client-confirm.entry.js +1 -1
  176. package/dist/esm/snk-configurator.entry.js +2 -2
  177. package/dist/esm/snk-crud.entry.js +4 -4
  178. package/dist/esm/snk-custom-slot-elements.entry.js +1 -1
  179. package/dist/esm/snk-data-exporter.entry.js +4 -4
  180. package/dist/esm/{snk-data-unit-65c9dd1a.js → snk-data-unit-027bca56.js} +2 -2
  181. package/dist/esm/snk-data-unit.entry.js +3 -3
  182. package/dist/esm/snk-default-filter.entry.js +73 -0
  183. package/dist/esm/snk-detail-view.entry.js +8 -8
  184. package/dist/esm/snk-entity-list.entry.js +1 -1
  185. package/dist/esm/snk-exporter-email-sender.entry.js +1 -1
  186. package/dist/esm/snk-expression-group_2.entry.js +10 -8
  187. package/dist/esm/snk-filter-advanced-mode_2.entry.js +5 -4
  188. package/dist/esm/snk-filter-bar_4.entry.js +82 -28
  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-detail.entry.js +3 -3
  192. package/dist/esm/snk-filter-field-search_2.entry.js +3 -3
  193. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  194. package/dist/esm/snk-filter-multi-select.entry.js +1 -1
  195. package/dist/esm/snk-filter-number.entry.js +1 -1
  196. package/dist/esm/snk-filter-period.entry.js +1 -1
  197. package/dist/esm/snk-filter-search.entry.js +1 -1
  198. package/dist/esm/snk-filter-text.entry.js +1 -1
  199. package/dist/esm/snk-form-summary.entry.js +1 -1
  200. package/dist/esm/snk-form-view.entry.js +1 -1
  201. package/dist/esm/snk-form_2.entry.js +428 -0
  202. package/dist/esm/snk-grid.entry.js +6 -6
  203. package/dist/esm/{snk-guides-viewer-72953334.js → snk-guides-viewer-32f3d3ab.js} +5 -5
  204. package/dist/esm/snk-guides-viewer.entry.js +7 -7
  205. package/dist/esm/snk-personalized-filter-editor.entry.js +1 -1
  206. package/dist/esm/snk-personalized-filter.entry.js +53 -18
  207. package/dist/esm/snk-pesquisa.entry.js +2 -2
  208. package/dist/esm/snk-print-selector.entry.js +1 -1
  209. package/dist/esm/snk-simple-bar.entry.js +1 -1
  210. package/dist/esm/snk-simple-crud.entry.js +7 -7
  211. package/dist/esm/snk-taskbar.entry.js +3 -3
  212. package/dist/esm/sortable.esm-842f85a3.js +2666 -0
  213. package/dist/esm/{taskbar-elements-f2cb4922.js → taskbar-elements-171476d4.js} +2 -2
  214. package/dist/esm/teste-pesquisa.entry.js +1 -1
  215. package/dist/sankhyablocks/{p-24a0dbd2.entry.js → p-0024d3fd.entry.js} +1 -1
  216. package/dist/sankhyablocks/{p-b8d649dd.entry.js → p-09e60995.entry.js} +1 -1
  217. package/dist/sankhyablocks/{p-bc101064.entry.js → p-0cb295c1.entry.js} +1 -1
  218. package/dist/sankhyablocks/{p-b0ab5066.entry.js → p-1456d7cb.entry.js} +1 -1
  219. package/dist/sankhyablocks/{p-9531fd46.entry.js → p-180716b2.entry.js} +1 -1
  220. package/dist/sankhyablocks/{p-6a03b190.entry.js → p-1ea34488.entry.js} +1 -1
  221. package/dist/sankhyablocks/p-21107f0d.entry.js +1 -0
  222. package/dist/sankhyablocks/{p-118e769b.entry.js → p-27482793.entry.js} +1 -1
  223. package/dist/sankhyablocks/p-290fea5f.entry.js +1 -0
  224. package/dist/sankhyablocks/{p-08ea6c86.entry.js → p-295aa209.entry.js} +1 -1
  225. package/dist/sankhyablocks/{p-c9675d64.js → p-2bde486e.js} +1 -1
  226. package/dist/sankhyablocks/{p-26b0ce3e.entry.js → p-2fdac5e6.entry.js} +1 -1
  227. package/dist/sankhyablocks/p-349d1968.entry.js +1 -0
  228. package/dist/sankhyablocks/p-35e73c5d.js +1 -0
  229. package/dist/sankhyablocks/{p-89c92727.entry.js → p-398cdd67.entry.js} +1 -1
  230. package/dist/sankhyablocks/{p-ddf93f36.entry.js → p-3a48bff3.entry.js} +1 -1
  231. package/dist/sankhyablocks/{p-434817f0.entry.js → p-3d41f5a8.entry.js} +1 -1
  232. package/dist/sankhyablocks/p-3f24c9b2.js +1 -0
  233. package/dist/sankhyablocks/{p-8002dcd0.entry.js → p-471b34f4.entry.js} +1 -1
  234. package/dist/sankhyablocks/{p-7e2ded86.entry.js → p-49d968e2.entry.js} +1 -1
  235. package/dist/sankhyablocks/p-4d2ff2fb.entry.js +1 -0
  236. package/dist/sankhyablocks/p-51833248.js +7 -0
  237. package/dist/sankhyablocks/p-60dd1d27.entry.js +1 -0
  238. package/dist/sankhyablocks/p-6416975c.js +56 -0
  239. package/dist/sankhyablocks/{p-7beeabc1.entry.js → p-65c5d430.entry.js} +1 -1
  240. package/dist/sankhyablocks/{p-21a81901.entry.js → p-667cab42.entry.js} +1 -1
  241. package/dist/sankhyablocks/p-6a4b21dd.js +1 -0
  242. package/dist/sankhyablocks/p-71a05822.entry.js +1 -0
  243. package/dist/sankhyablocks/{p-ac8d1cd6.entry.js → p-7345782c.entry.js} +1 -1
  244. package/dist/sankhyablocks/{p-885802c3.js → p-763b04fa.js} +1 -1
  245. package/dist/sankhyablocks/{p-d07b18a4.js → p-7de79adf.js} +1 -1
  246. package/dist/sankhyablocks/p-7e250432.entry.js +1 -0
  247. package/dist/sankhyablocks/{p-47178038.entry.js → p-83c100f2.entry.js} +1 -1
  248. package/dist/sankhyablocks/p-84345e7a.js +1 -0
  249. package/dist/sankhyablocks/p-86bd4478.entry.js +1 -0
  250. package/dist/sankhyablocks/p-9019a32f.js +1 -0
  251. package/dist/sankhyablocks/{p-54a5d52a.entry.js → p-90805683.entry.js} +1 -1
  252. package/dist/sankhyablocks/{p-c2e468c9.entry.js → p-91a9abb6.entry.js} +1 -1
  253. package/dist/sankhyablocks/p-9751c42f.entry.js +1 -0
  254. package/dist/sankhyablocks/{p-057fad05.js → p-988afe78.js} +1 -1
  255. package/dist/sankhyablocks/{p-16a1dd18.entry.js → p-9a63f3f7.entry.js} +1 -1
  256. package/dist/sankhyablocks/{p-90684a75.entry.js → p-9ad3557c.entry.js} +1 -1
  257. package/dist/sankhyablocks/{p-b6200d32.entry.js → p-9fd87bfd.entry.js} +1 -1
  258. package/dist/sankhyablocks/p-a06bf7b9.entry.js +1 -0
  259. package/dist/sankhyablocks/{p-33718dfc.entry.js → p-a227b650.entry.js} +1 -1
  260. package/dist/sankhyablocks/p-a349689a.js +1 -0
  261. package/dist/sankhyablocks/p-a5bb2f93.entry.js +1 -0
  262. package/dist/sankhyablocks/{p-ebdb9d89.js → p-a6513fcb.js} +1 -1
  263. package/dist/sankhyablocks/{p-8c235d4c.entry.js → p-a76e6d51.entry.js} +1 -1
  264. package/dist/sankhyablocks/p-b568c1d4.js +1 -0
  265. package/dist/sankhyablocks/{p-ce94e6c4.entry.js → p-bd665460.entry.js} +1 -1
  266. package/dist/sankhyablocks/p-c3324d79.entry.js +1 -0
  267. package/dist/sankhyablocks/{p-bf2acf72.entry.js → p-c6a8a8bc.entry.js} +1 -1
  268. package/dist/sankhyablocks/{p-165cde3b.entry.js → p-c926cf6b.entry.js} +1 -1
  269. package/dist/sankhyablocks/{p-79f823f3.entry.js → p-d67526b6.entry.js} +1 -1
  270. package/dist/sankhyablocks/{p-d2d301a6.js → p-d8d8169b.js} +1 -1
  271. package/dist/sankhyablocks/{p-5f157b09.entry.js → p-dff65083.entry.js} +1 -1
  272. package/dist/sankhyablocks/{p-3372178e.entry.js → p-e2988bb1.entry.js} +1 -1
  273. package/dist/sankhyablocks/{p-a4ebeec4.entry.js → p-e3521eae.entry.js} +1 -1
  274. package/dist/sankhyablocks/p-e7cccc45.entry.js +1 -0
  275. package/dist/sankhyablocks/{p-1f80174b.entry.js → p-f4e31122.entry.js} +1 -1
  276. package/dist/sankhyablocks/{p-0fadb620.js → p-fc0b609e.js} +1 -1
  277. package/dist/sankhyablocks/{p-a14a09c3.entry.js → p-ff7060bc.entry.js} +1 -1
  278. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  279. package/dist/types/components/snk-filter-bar/filter-modal/snk-filter-modal.d.ts +16 -4
  280. package/dist/types/components/snk-filter-bar/filter-modal/subcomponents/snk-default-filter/snk-default-filter.d.ts +27 -0
  281. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +4 -3
  282. package/dist/types/components/snk-filter-bar/types/default-filters.d.ts +5 -0
  283. package/dist/types/components/snk-filter-bar/types/filter-type.enum.d.ts +2 -1
  284. package/dist/types/components/snk-filter-bar/utils/SnkFilterModalFactory.d.ts +3 -3
  285. package/dist/types/components/snk-form-config/FormConfigHelper.d.ts +31 -0
  286. package/dist/types/components/snk-form-config/SnkFormConfigManager.d.ts +3 -3
  287. package/dist/types/components/snk-form-config/config-header/config-header.d.ts +23 -0
  288. package/dist/types/components/snk-form-config/config-header/configs-button/configs-button.d.ts +19 -0
  289. package/dist/types/components/snk-form-config/field-item/field-config/field-config.d.ts +56 -0
  290. package/dist/types/components/snk-form-config/fields-layout/fields-layout.d.ts +63 -0
  291. package/dist/types/components/snk-form-config/fields-selector/fields-selector.d.ts +18 -0
  292. package/dist/types/components/snk-form-config/guides-configurator/guides-configurator.d.ts +42 -0
  293. package/dist/types/components/snk-form-config/snk-form-config.d.ts +51 -120
  294. package/dist/types/components/snk-personalized-filter/interfaces/index.d.ts +4 -0
  295. package/dist/types/components/snk-personalized-filter/snk-personalized-filter.d.ts +7 -1
  296. package/dist/types/components/snk-personalized-filter/subcomponents/snk-expression-group/snk-expression-group.d.ts +4 -0
  297. package/dist/types/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.d.ts +4 -0
  298. package/dist/types/components/snk-personalized-filter/subcomponents/snk-filter-assistent-mode/snk-filter-assistent-mode.d.ts +4 -0
  299. package/dist/types/components.d.ts +276 -203
  300. package/dist/types/lib/configs/ConfigStorage.d.ts +4 -2
  301. package/dist/types/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.d.ts +8 -4
  302. package/dist/types/lib/utils/constants.d.ts +6 -0
  303. package/package.json +4 -2
  304. package/react/components.d.ts +8 -3
  305. package/react/components.js +8 -3
  306. package/react/components.js.map +1 -1
  307. package/dist/cjs/Sortable-fb1c4cbb.js +0 -2853
  308. package/dist/cjs/snk-config-options_3.cjs.entry.js +0 -1390
  309. package/dist/cjs/snk-field-config.cjs.entry.js +0 -60
  310. package/dist/cjs/snk-tab-config.cjs.entry.js +0 -332
  311. package/dist/collection/components/snk-form-config/subcomponents/snk-config-options/snk-config-options.css +0 -16
  312. package/dist/collection/components/snk-form-config/subcomponents/snk-config-options/snk-config-options.js +0 -346
  313. package/dist/collection/components/snk-form-config/subcomponents/snk-field-config/snk-field-config.css +0 -219
  314. package/dist/collection/components/snk-form-config/subcomponents/snk-field-config/snk-field-config.js +0 -184
  315. package/dist/collection/components/snk-form-config/subcomponents/snk-tab-config/snk-tab-config.css +0 -323
  316. package/dist/collection/components/snk-form-config/subcomponents/snk-tab-config/snk-tab-config.js +0 -527
  317. package/dist/components/snk-config-options.js +0 -6
  318. package/dist/components/snk-config-options2.js +0 -257
  319. package/dist/components/snk-field-config.js +0 -6
  320. package/dist/components/snk-field-config2.js +0 -76
  321. package/dist/components/snk-tab-config.js +0 -6
  322. package/dist/components/snk-tab-config2.js +0 -3202
  323. package/dist/esm/Sortable-83960219.js +0 -2851
  324. package/dist/esm/snk-config-options_3.entry.js +0 -1384
  325. package/dist/esm/snk-field-config.entry.js +0 -56
  326. package/dist/esm/snk-tab-config.entry.js +0 -328
  327. package/dist/sankhyablocks/p-03b68a74.js +0 -56
  328. package/dist/sankhyablocks/p-3749dffb.entry.js +0 -1
  329. package/dist/sankhyablocks/p-3ab6df3d.entry.js +0 -1
  330. package/dist/sankhyablocks/p-4689c2e6.js +0 -1
  331. package/dist/sankhyablocks/p-490b75b5.entry.js +0 -1
  332. package/dist/sankhyablocks/p-52d10014.entry.js +0 -1
  333. package/dist/sankhyablocks/p-5ffa0493.entry.js +0 -1
  334. package/dist/sankhyablocks/p-60137b7a.entry.js +0 -1
  335. package/dist/sankhyablocks/p-6dc031de.js +0 -1
  336. package/dist/sankhyablocks/p-9261d8a0.js +0 -1
  337. package/dist/sankhyablocks/p-933c0c0b.js +0 -1
  338. package/dist/sankhyablocks/p-9d3a025a.entry.js +0 -1
  339. package/dist/sankhyablocks/p-c0eb761b.entry.js +0 -1
  340. package/dist/sankhyablocks/p-d9804798.js +0 -1
  341. package/dist/sankhyablocks/p-fa816fb2.js +0 -1
  342. package/dist/types/components/snk-form-config/subcomponents/snk-config-options/snk-config-options.d.ts +0 -57
  343. package/dist/types/components/snk-form-config/subcomponents/snk-field-config/snk-field-config.d.ts +0 -43
  344. package/dist/types/components/snk-form-config/subcomponents/snk-tab-config/snk-tab-config.d.ts +0 -105
@@ -0,0 +1,341 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-1cf293c1.js');
6
+ const core = require('@sankhyalabs/core');
7
+ const sortable_esm = require('./sortable.esm-9a110bb7.js');
8
+ const FormConfigHelper = require('./FormConfigHelper-c664dbae.js');
9
+ const constants = require('./constants-6d82e405.js');
10
+ const utils = require('@sankhyalabs/ezui/dist/collection/utils');
11
+
12
+ const fieldsLayoutCss = ".sc-fields-layout-h{display:flex;padding:12px;box-shadow:var(--shadow--small, 0 0 16px rgba(0, 38, 111, 0.07));border-radius:var(--border--radius-medium, 6px);height:var(--snk-form-config-container-height);flex-direction:column}.layout-container.sc-fields-layout{container-type:inline-size;display:flex;flex-direction:column;overflow:auto;height:calc(100vh - 225px)}.guide-header.sc-fields-layout{display:flex;width:100%;font-size:20px;border-bottom:1px solid #dce0e8;margin-bottom:6px;align-items:center;height:45px}.guide-header.sc-fields-layout ez-button.sc-fields-layout{transition:all 0.2s ease-in-out;visibility:hidden;opacity:0}.guide-header.sc-fields-layout:hover ez-button.sc-fields-layout{visibility:visible;opacity:1}.guide-header-label.sc-fields-layout{display:block;padding:10px 0}.group-config.sc-fields-layout{padding:12px 0;display:flex;flex-direction:column;width:100%}.group-content.sc-fields-layout{display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;min-height:65px;width:100%;padding:6px 0}.group-content.empty-content.sc-fields-layout{position:relative}.group-content.empty-content.sc-fields-layout::before{content:\"Arraste e solte um campo aqui\";color:#cbcfd7;font-size:16px;font-weight:500;text-align:center;position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:opacity 0.3s;width:100%;height:100%;box-sizing:border-box;padding:10px;background:#f9f9f9;border:1px dashed #dce0e8;border-radius:6px}.no-group-container.sc-fields-layout{padding:12px 0;width:100%;border-bottom:1px solid #dce0e8}.no-group-container.sc-fields-layout::before{content:\"Inclua estes campos nos grupos ou deixe-os separados no topo do formulário\";width:100%;display:block;font-size:16px;font-weight:400;color:#AFB6C0;padding-bottom:12px}.add-group-container.sc-fields-layout{display:flex;align-items:center;border-top:1px solid #dce0e8;padding-top:22px;padding-bottom:12px;gap:6px;cursor:pointer;justify-content:center;width:100%;height:55px}.no-guide-selected.sc-fields-layout{display:block;margin:auto;font-size:24px;color:#AFB6C0;font-weight:500}.ghost.sc-fields-layout{opacity:.5;background:#c8fbe2}";
13
+
14
+ const FieldLayoutComponent = class {
15
+ constructor(hostRef) {
16
+ index.registerInstance(this, hostRef);
17
+ this.isEditingGuideName = index.createEvent(this, "isEditingGuideName", 7);
18
+ this.isEditingGroupName = index.createEvent(this, "isEditingGroupName", 7);
19
+ this.layoutChanged = index.createEvent(this, "layoutChanged", 7);
20
+ this.setFieldListAsAvailable = index.createEvent(this, "setFieldListAsAvailable", 7);
21
+ this.guideRenamed = index.createEvent(this, "guideRenamed", 7);
22
+ this.ID_GROUPS = 'container-groups';
23
+ this.ID_FIELDS = 'container-fields';
24
+ this.reservedGuideNames = [constants.TAB_NAMES.main.toLowerCase(), constants.TAB_NAMES.general.toLocaleLowerCase()];
25
+ this.groupsListMemory = [];
26
+ this.groupsRefList = [];
27
+ this.isEditGuideNameActive = false;
28
+ this.selectedGuide = undefined;
29
+ this.groupsList = [];
30
+ this.guideNames = [];
31
+ this.dataUnit = undefined;
32
+ this.messagesBuilder = undefined;
33
+ }
34
+ handleFieldConfigChanged({ detail }) {
35
+ const updatedField = detail;
36
+ const groupToUpdate = this.groupsListMemory.find(g => g.name === updatedField.group);
37
+ if (!groupToUpdate)
38
+ return;
39
+ const updatedFields = groupToUpdate.fields.map(field => {
40
+ return (field.name === updatedField.name) ? updatedField : field;
41
+ });
42
+ const updatedGroupList = this.groupsListMemory.map(group => {
43
+ return (group.name === groupToUpdate.name)
44
+ ? { name: group.name, fields: updatedFields }
45
+ : group;
46
+ });
47
+ this.applyGroupUpdate(updatedGroupList);
48
+ }
49
+ observeSelectedGuide() {
50
+ this.isEditGuideNameActive = false;
51
+ index.forceUpdate(this);
52
+ this.isEditingGroupName.emit(false);
53
+ }
54
+ observeGroupList(newValue) {
55
+ this.groupsListMemory = [...newValue];
56
+ }
57
+ observeIsEditGuideNameActive(newValue) {
58
+ this.isEditingGuideName.emit(newValue);
59
+ }
60
+ async addFieldToLayout(incomingField) {
61
+ incomingField.group = constants.GROUP_NAMES.noGroup;
62
+ incomingField.tab = this.selectedGuide.name;
63
+ const fixedFieldsGroup = this.getFixedFieldsGroup();
64
+ const newFixedFieldsGroup = {
65
+ name: constants.GROUP_NAMES.noGroup,
66
+ fields: fixedFieldsGroup ? [...fixedFieldsGroup.fields, incomingField] : [incomingField],
67
+ };
68
+ const updatedGroupListMemory = fixedFieldsGroup
69
+ ? [newFixedFieldsGroup, ...this.groupsListMemory.slice(1)]
70
+ : [newFixedFieldsGroup, ...this.groupsListMemory];
71
+ this.applyGroupUpdate(updatedGroupListMemory);
72
+ }
73
+ getFixedFieldsGroup() {
74
+ return this.groupsListMemory.find(g => g.name === constants.GROUP_NAMES.noGroup);
75
+ }
76
+ getMessage(key, params) {
77
+ return this.messagesBuilder.getMessage(key, params);
78
+ }
79
+ handleAddGroup() {
80
+ const newGroup = { name: this.buildNewGroupName(), fields: [] };
81
+ const updatedGroupsList = [...this.groupsListMemory, newGroup];
82
+ this.applyGroupUpdate(updatedGroupsList);
83
+ }
84
+ buildNewGroupName() {
85
+ var _a, _b;
86
+ const qtdWithNewGroupName = (_b = (_a = this.groupsListMemory.filter(g => g.name.includes(constants.GROUP_NAMES.newGroup))) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0;
87
+ return qtdWithNewGroupName === 0
88
+ ? constants.GROUP_NAMES.newGroup
89
+ : `${constants.GROUP_NAMES.newGroup} (${qtdWithNewGroupName})`;
90
+ }
91
+ makeDynamicFieldsContainersDraggable() {
92
+ const draggableGroups = this.groupsList.filter((g) => g.name !== constants.GROUP_NAMES.noGroup);
93
+ draggableGroups.forEach(group => {
94
+ this.makeFieldContainerDraggable(this.getFieldsContainerId(group.name));
95
+ });
96
+ }
97
+ getFieldsContainerId(groupName) {
98
+ return `${this.ID_FIELDS}-${core.StringUtils.replaceBlankCharacters(groupName)}`;
99
+ }
100
+ handleSortGroups(evt) {
101
+ var _a;
102
+ const htmlStructure = (_a = evt.to) === null || _a === void 0 ? void 0 : _a.children;
103
+ if (!htmlStructure)
104
+ return;
105
+ const groupsOrder = Array.from(htmlStructure).map(el => el.getAttribute('data-group-name'));
106
+ const updatedOrderGroupsList = [];
107
+ const fixedGroup = this.getFixedFieldsGroup();
108
+ if (fixedGroup) {
109
+ updatedOrderGroupsList.push(fixedGroup);
110
+ }
111
+ groupsOrder.forEach(groupName => {
112
+ const group = this.groupsListMemory.find(g => g.name === groupName);
113
+ if (group) {
114
+ updatedOrderGroupsList.push(group);
115
+ }
116
+ });
117
+ this.applyGroupUpdate(updatedOrderGroupsList);
118
+ }
119
+ handleFieldsChanged(evt) {
120
+ let updatedGroupsList = [...this.groupsListMemory];
121
+ updatedGroupsList = [...this.handleFieldsOnGroupUpdate(updatedGroupsList, evt, FormConfigHelper.SORTABLE_PATH.FROM)];
122
+ updatedGroupsList = [...this.handleFieldsOnGroupUpdate(updatedGroupsList, evt, FormConfigHelper.SORTABLE_PATH.TO)];
123
+ this.applyGroupUpdate(updatedGroupsList);
124
+ }
125
+ applyGroupUpdate(updatedGroupList) {
126
+ var _a;
127
+ (_a = this.groupsRefList) === null || _a === void 0 ? void 0 : _a.forEach((group) => group === null || group === void 0 ? void 0 : group.cancelEdition());
128
+ if (core.ObjectUtils.equals(updatedGroupList, this.groupsListMemory)) {
129
+ return false;
130
+ }
131
+ this.groupsListMemory = [...updatedGroupList];
132
+ this.layoutChanged.emit(this.groupsListMemory);
133
+ return true;
134
+ }
135
+ handleFieldsOnGroupUpdate(groupList, evt, path) {
136
+ const element = evt[path];
137
+ const isAvailableFields = element.id === FormConfigHelper.ID_AVAILABLE_FIELDS;
138
+ return isAvailableFields ? groupList : this.updateGroupList(groupList, element, path, evt);
139
+ }
140
+ updateGroupList(groupList, element, path, evt) {
141
+ const groupName = element.getAttribute('data-group-name');
142
+ const updatedGroup = {
143
+ name: groupName,
144
+ fields: FormConfigHelper.getFieldsStructure(evt, path, groupName, this.selectedGuide.name),
145
+ };
146
+ return this.replaceGroup(groupList, updatedGroup);
147
+ }
148
+ replaceGroup(groupList, newGroup) {
149
+ return groupList.map(group => group.name === newGroup.name ? newGroup : group);
150
+ }
151
+ makeGroupsDraggable() {
152
+ try {
153
+ const element = this.getContainerElement(this.ID_GROUPS);
154
+ if (!element)
155
+ return;
156
+ new sortable_esm.Sortable(element, {
157
+ group: 'groups',
158
+ ghostClass: 'ghost',
159
+ direction: 'horizontal',
160
+ animation: 15,
161
+ onSort: (evt) => this.handleSortGroups(evt),
162
+ });
163
+ }
164
+ catch (e) {
165
+ console.error('Falha ao tornar container de grupos arrastável: ', this.ID_GROUPS);
166
+ }
167
+ }
168
+ makeFieldContainerDraggable(containerId) {
169
+ try {
170
+ const element = this.getContainerElement(containerId);
171
+ if (!element)
172
+ return;
173
+ new sortable_esm.Sortable(element, {
174
+ group: 'fields',
175
+ ghostClass: 'ghost',
176
+ direction: 'vertical',
177
+ animation: 15,
178
+ onAdd: (evt) => this.handleFieldsChanged(evt),
179
+ onRemove: (evt) => this.handleFieldsChanged(evt),
180
+ onSort: (evt) => this.handleFieldsChanged(evt),
181
+ });
182
+ }
183
+ catch (e) {
184
+ console.error('Falha ao tornar grupo arrastável: ', containerId);
185
+ }
186
+ }
187
+ getContainerElement(id) {
188
+ return this.el.querySelector(`[id="${id}"]`);
189
+ }
190
+ handleSetFieldAsAvailable(field) {
191
+ var _a;
192
+ const groupName = (_a = field.group) !== null && _a !== void 0 ? _a : constants.GROUP_NAMES.noGroup;
193
+ const group = this.groupsListMemory.find(group => group.name === groupName);
194
+ const fields = group.fields.filter(f => f.name !== field.name);
195
+ const updatedGroup = { name: groupName, fields };
196
+ const updatedList = [...this.replaceGroup(this.groupsListMemory, updatedGroup)];
197
+ this.applyGroupUpdate(updatedList);
198
+ }
199
+ removeGroup(group) {
200
+ var _a, _b;
201
+ const groupFields = (_b = (_a = this.groupsListMemory.find(f => f.name === group.name)) === null || _a === void 0 ? void 0 : _a.fields) !== null && _b !== void 0 ? _b : [];
202
+ const updatedGroupList = [...this.groupsListMemory.filter(g => g.name !== group.name)];
203
+ if (this.applyGroupUpdate(updatedGroupList)) {
204
+ this.setFieldListAsAvailable.emit(groupFields);
205
+ }
206
+ }
207
+ handleRenameGroup(editDetails) {
208
+ const { value: actualName, newValue: newGroupName } = editDetails.detail;
209
+ const updatedGroupList = this.groupsListMemory.map(group => {
210
+ if (group.name !== actualName)
211
+ return Object.assign({}, group);
212
+ const updatedFields = group.fields.map(f => {
213
+ return Object.assign(Object.assign({}, f), { group: newGroupName });
214
+ });
215
+ return { name: newGroupName, fields: updatedFields };
216
+ });
217
+ this.applyGroupUpdate(updatedGroupList);
218
+ }
219
+ canSaveGroup(newLabel, index) {
220
+ const hasOtherWithThisName = this.groupsList.some(group => {
221
+ var _a;
222
+ return ((_a = group.name) !== null && _a !== void 0 ? _a : '').toLocaleLowerCase() === (newLabel !== null && newLabel !== void 0 ? newLabel : '').toLocaleLowerCase();
223
+ });
224
+ if (!hasOtherWithThisName)
225
+ return true;
226
+ const title = this.getMessage('snkFormConfig.confirm.title');
227
+ const message = this.buildDuplicatedGroupNameContent(newLabel);
228
+ utils.ApplicationUtils.alert(title, message).then(() => { var _a; return (_a = this.groupsRefList[index]) === null || _a === void 0 ? void 0 : _a.applyFocusTextEdit(); });
229
+ return false;
230
+ }
231
+ buildDuplicatedGroupNameContent(newLabel) {
232
+ const tabName = this.selectedGuide.name;
233
+ return `
234
+ ${this.getMessage('snkFormConfig.alert.titleGroupExists')}
235
+ <b>${newLabel}</b>
236
+ ${this.getMessage('snkFormConfig.alert.inTab')}
237
+ <b>${tabName === constants.TAB_NAMES.main ? this.getMessage('snkFormConfig.form.mainArea') : tabName}</b>.
238
+ <br/><br/>
239
+ ${this.getMessage('snkFormConfig.alert.infoValidTitle')}
240
+ `;
241
+ }
242
+ buildDuplicatedTabNameContent(newLabel) {
243
+ return `
244
+ ${this.getMessage('snkFormConfig.alert.titleGuideExists')}
245
+ <b>${newLabel}</b>.
246
+ <br/><br/>
247
+ ${this.getMessage('snkFormConfig.alert.infoValidTitle')}
248
+ `;
249
+ }
250
+ buildReservedTabNameContent(newLabel) {
251
+ return `
252
+ ${this.getMessage('snkFormConfig.alert.titleGuideReservedName')}
253
+ <br/><br/>
254
+ <b>${newLabel}</b>.
255
+ <br/><br/>
256
+ ${this.getMessage('snkFormConfig.alert.infoValidTitle')}
257
+ `;
258
+ }
259
+ renderFields(fields) {
260
+ if (fields.length === 0)
261
+ return;
262
+ return fields.map(field => (index.h("field-item", { key: field.name, fieldConfig: field, onLayoutConfig: true, dataUnit: this.dataUnit, messagesBuilder: this.messagesBuilder, onSetFieldAsAvailable: (e) => this.handleSetFieldAsAvailable(e.detail) })));
263
+ }
264
+ renderDraggableGroups() {
265
+ const draggableGroups = this.groupsList.filter(g => g.name !== constants.GROUP_NAMES.noGroup);
266
+ return (draggableGroups.map((group, index$1) => {
267
+ var _a;
268
+ return (index.h("div", { key: group.name, class: 'group-config', "data-group-name": group.name }, index.h("ez-collapsible-box", { ref: ref => this.groupsRefList[index$1] = ref, label: group.name, headerSize: "large", editable: true, removable: true, "icon-placement": "left", onEzRemove: () => this.removeGroup(group), onEzSaveEditLabel: (event => this.handleRenameGroup(event)), onEzEditLabelMode: ({ detail }) => this.isEditingGroupName.emit(detail), conditionalSave: (newLabel) => this.canSaveGroup(newLabel, index$1) }, index.h("div", { id: this.getFieldsContainerId(group.name), class: `group-content ${!((_a = group.fields) === null || _a === void 0 ? void 0 : _a.length) ? 'empty-content' : ''}`, "data-group-name": group.name }, this.renderFields(group.fields)))));
269
+ }));
270
+ }
271
+ renderFixedFields() {
272
+ var _a, _b;
273
+ const noGroupFields = (_b = (_a = this.groupsList.find(g => g.name === constants.GROUP_NAMES.noGroup)) === null || _a === void 0 ? void 0 : _a.fields) !== null && _b !== void 0 ? _b : [];
274
+ return this.renderFields(noGroupFields);
275
+ }
276
+ handleRenameGuide(editDetails) {
277
+ const { value: actualValue, newValue } = editDetails.detail;
278
+ this.isEditGuideNameActive = false;
279
+ if (newValue === actualValue) {
280
+ return;
281
+ }
282
+ const duplicatedName = this.guideNames.includes(newValue.toLowerCase());
283
+ const forbiddenName = this.reservedGuideNames.includes(newValue.toLowerCase());
284
+ if (forbiddenName || duplicatedName) {
285
+ const title = this.getMessage('snkFormConfig.confirm.title');
286
+ const message = forbiddenName ? this.buildReservedTabNameContent(newValue) : this.buildDuplicatedTabNameContent(newValue);
287
+ utils.ApplicationUtils.alert(title, message).then(() => this._refTextEdit.applyFocusSelect());
288
+ return;
289
+ }
290
+ this.guideRenamed.emit(newValue);
291
+ }
292
+ cancelEditGuideName() {
293
+ this.isEditGuideNameActive = false;
294
+ }
295
+ async startGuideNameEdition() {
296
+ this.isEditGuideNameActive = true;
297
+ setTimeout(async () => {
298
+ await this._refTextEdit.applyFocusSelect();
299
+ }, 200);
300
+ }
301
+ getTextEditStyle() {
302
+ return {
303
+ fontSize: '20px',
304
+ fontWeight: '500',
305
+ fontFamily: 'Roboto',
306
+ };
307
+ }
308
+ renderGuideName() {
309
+ var _a, _b;
310
+ if (this.isEditGuideNameActive) {
311
+ return (index.h("div", { class: 'guide-header' }, index.h("ez-text-edit", { class: "collapsible-box__text-edit", ref: ref => this._refTextEdit = ref, value: (_a = this.selectedGuide) === null || _a === void 0 ? void 0 : _a.label, styled: this.getTextEditStyle(), onSaveEdition: (ev) => this.handleRenameGuide(ev), onCancelEdition: () => this.cancelEditGuideName() })));
312
+ }
313
+ return (index.h("div", { class: 'guide-header' }, index.h("span", { class: 'guide-header-label' }, (_b = this.selectedGuide) === null || _b === void 0 ? void 0 : _b.label), this.renderEditGuideNameButton()));
314
+ }
315
+ renderEditGuideNameButton() {
316
+ var _a;
317
+ if (((_a = this.selectedGuide) === null || _a === void 0 ? void 0 : _a.name) === constants.TAB_NAMES.main)
318
+ return;
319
+ return (index.h("ez-button", { mode: "icon", class: "ez-button--tertiary", onClick: () => this.startGuideNameEdition(), size: "medium", iconName: 'edit', title: 'Renomear' }));
320
+ }
321
+ componentDidRender() {
322
+ this.makeGroupsDraggable();
323
+ this.makeDynamicFieldsContainersDraggable();
324
+ this.makeFieldContainerDraggable(constants.GROUP_NAMES.noGroup);
325
+ }
326
+ render() {
327
+ if (!this.selectedGuide) {
328
+ return (index.h(index.Host, { class: 'ez-flex-item--auto ez-size-height--full ez-box ez-padding--medium content-container' }, index.h("span", { class: 'no-guide-selected' }, "Selecione uma guia e comece a configurar")));
329
+ }
330
+ return (index.h(index.Host, { class: 'ez-flex-item--auto ez-size-height--full ez-box ez-padding--medium content-container' }, this.renderGuideName(), index.h("div", { class: 'layout-container' }, index.h("ez-scroller", { direction: 'vertical', activeShadow: true }, index.h("div", { class: 'no-group-container' }, index.h("div", { id: constants.GROUP_NAMES.noGroup, class: 'group-content', "data-group-name": constants.GROUP_NAMES.noGroup }, this.renderFixedFields())), index.h("hr", null), index.h("div", { id: this.ID_GROUPS, class: 'groups-container' }, this.renderDraggableGroups()))), index.h("div", { class: 'add-group-container', onClick: this.handleAddGroup.bind(this) }, index.h("ez-icon", { slot: "leftIcon", iconName: "plus" }), index.h("span", null, "Criar novo grupo"))));
331
+ }
332
+ get el() { return index.getElement(this); }
333
+ static get watchers() { return {
334
+ "selectedGuide": ["observeSelectedGuide"],
335
+ "groupsList": ["observeGroupList"],
336
+ "isEditGuideNameActive": ["observeIsEditGuideNameActive"]
337
+ }; }
338
+ };
339
+ FieldLayoutComponent.style = fieldsLayoutCss;
340
+
341
+ exports.fields_layout = FieldLayoutComponent;
@@ -0,0 +1,74 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-1cf293c1.js');
6
+ const sortable_esm = require('./sortable.esm-9a110bb7.js');
7
+ const FormConfigHelper = require('./FormConfigHelper-c664dbae.js');
8
+ const core = require('@sankhyalabs/core');
9
+ require('./constants-6d82e405.js');
10
+
11
+ const fieldsSelectorCss = ".sc-fields-selector-h{width:33.33333%;display:flex;box-shadow:var(--shadow--small, 0 0 16px rgba(0, 38, 111, 0.07));border-radius:var(--border--radius-medium, 6px);height:var(--snk-form-config-container-height);max-width:260px}.fields-label.sc-fields-selector{display:block;font-size:16px;font-weight:500;width:100%}.fields-count.sc-fields-selector{display:block;color:#AFB6C0;font-size:14px;padding:12px 0;font-weight:400;width:100%}.fields-container.sc-fields-selector{display:flex;flex-direction:column;gap:12px;height:calc(100vh - 220px);width:100%}.ghost.sc-fields-selector{opacity:.5;background:#c8fbe2}";
12
+
13
+ const FieldsSelector = class {
14
+ constructor(hostRef) {
15
+ index.registerInstance(this, hostRef);
16
+ this.fieldListChanged = index.createEvent(this, "fieldListChanged", 7);
17
+ this.availableFields = [];
18
+ this.dataUnit = undefined;
19
+ this.filterTerm = '';
20
+ }
21
+ onAddField(evt) {
22
+ const newIndex = evt.newIndex;
23
+ const item = evt.item;
24
+ const fieldConfig = item.fieldConfig;
25
+ const updatedFields = this.addItemInPosition(newIndex, fieldConfig);
26
+ this.fieldListChanged.emit(updatedFields);
27
+ }
28
+ addItemInPosition(newIndex, fieldConfig) {
29
+ return [
30
+ ...this.availableFields.slice(0, newIndex),
31
+ fieldConfig,
32
+ ...this.availableFields.slice(newIndex),
33
+ ];
34
+ }
35
+ onRemoveField(evt) {
36
+ const item = evt.item;
37
+ const fieldName = item.fieldConfig.name;
38
+ const updatedFields = [...this.availableFields.filter(f => f.name !== fieldName)];
39
+ this.fieldListChanged.emit(updatedFields);
40
+ requestAnimationFrame(() => item.remove());
41
+ return;
42
+ }
43
+ renderFields() {
44
+ const fieldsToShow = core.ArrayUtils.applyStringFilter(this.filterTerm, this.availableFields);
45
+ return fieldsToShow.map(field => (index.h("field-item", { key: field.name, dataUnit: this.dataUnit, fieldConfig: field })));
46
+ }
47
+ getCountText() {
48
+ if (!this.availableFields.length)
49
+ return 'Nenhum campo disponível';
50
+ if (this.availableFields.length === 1)
51
+ return '1 campo disponível';
52
+ return `${this.availableFields.length} campos disponíveis`;
53
+ }
54
+ initializeDraggableContainer() {
55
+ new sortable_esm.Sortable(this.el.querySelector(`#${FormConfigHelper.ID_AVAILABLE_FIELDS}`), {
56
+ group: 'fields',
57
+ direction: 'vertical',
58
+ ghostClass: 'ghost',
59
+ animation: 15,
60
+ onAdd: (evt) => this.onAddField(evt),
61
+ onRemove: (evt) => this.onRemoveField(evt),
62
+ });
63
+ }
64
+ componentDidRender() {
65
+ this.initializeDraggableContainer();
66
+ }
67
+ render() {
68
+ return (index.h(index.Host, { class: 'ez-col ez-col--sd-4 ez-col--tb-4 ez-padding--medium' }, index.h("span", { class: 'fields-label ez-padding-bottom--small' }, "Campos dispon\u00EDveis"), index.h("ez-filter-input", { slot: "content", mode: "slim", label: "Buscar campo", onEzChange: evt => this.filterTerm = evt.detail }), index.h("span", { class: 'fields-count' }, this.getCountText()), index.h("ez-scroller", { direction: 'vertical', activeShadow: true }, index.h("div", { id: FormConfigHelper.ID_AVAILABLE_FIELDS, class: 'fields-container' }, this.renderFields()))));
69
+ }
70
+ get el() { return index.getElement(this); }
71
+ };
72
+ FieldsSelector.style = fieldsSelectorCss;
73
+
74
+ exports.fields_selector = FieldsSelector;
@@ -5,6 +5,7 @@ var FilterType;
5
5
  FilterType["QUICK_FILTER"] = "QUICK_FILTER";
6
6
  FilterType["CUSTOM_FILTER"] = "CUSTOM_FILTER";
7
7
  FilterType["OTHER_FILTERS"] = "OTHER_FILTERS";
8
+ FilterType["DEFAULT_FILTER"] = "DEFAULT_FILTER";
8
9
  })(FilterType || (FilterType = {}));
9
10
  const FilterType$1 = FilterType;
10
11
 
@@ -0,0 +1,164 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-1cf293c1.js');
6
+ const sortable_esm = require('./sortable.esm-9a110bb7.js');
7
+ const core = require('@sankhyalabs/core');
8
+ const utils = require('@sankhyalabs/ezui/dist/collection/utils');
9
+ const constants = require('./constants-6d82e405.js');
10
+
11
+ const guidesConfiguratorCss = ".ezSidebarNavigator.sc-guides-configurator{--ez-sidebar-navigator--height:calc(100vh - 118px)}.navigator-container.sc-guides-configurator{height:calc(100vh - 175px);display:flex;flex-direction:column;justify-content:space-between}.collapsible-container.sc-guides-configurator{display:flex;flex-direction:column;gap:12px;flex-grow:1;max-height:calc(100vh - 240px);overflow:auto}.collapsible-item.sc-guides-configurator{padding:6px;border-radius:6px;border:1px solid #dce0e8}.add-button-container.sc-guides-configurator{display:flex;align-items:center;border-top:1px solid #dce0e8;padding-top:22px;gap:6px;cursor:pointer;justify-content:center}.add-button-container.sc-guides-configurator span.sc-guides-configurator{display:block}.guide-list.sc-guides-configurator{display:flex;flex-direction:column;width:100%;min-height:10px}.guide-list.hidden-empty-content.sc-guides-configurator::before{content:\"Nenhuma guia oculta\";display:block;font-size:16px;font-weight:400;color:#AFB6C0;margin:auto;padding:8px}.guide-list.visible-empty-content.sc-guides-configurator::before{content:\"Nenhuma guia visível\";display:block;font-size:16px;font-weight:400;color:#AFB6C0;margin:auto;padding:8px}.item-label.sc-guides-configurator{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-grow:1}.guide-item.sc-guides-configurator{margin:0 3px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:5px 10px;border-radius:6px;transition:all 0.2s ease-in-out;height:32px}.guide-item.sc-guides-configurator .actions.sc-guides-configurator{display:flex;gap:8px;transition:0.2s ease-in-out;visibility:hidden;opacity:0}.guide-item.sc-guides-configurator:hover .actions.sc-guides-configurator{visibility:visible;opacity:1}ez-button.sc-guides-configurator{width:24px;align-items:center;justify-content:center;display:flex}.ghost.sc-guides-configurator{opacity:.5;background:#e2eaf4}.main-guide.sc-guides-configurator{padding:12px;margin:12px 0;border:1px solid #dce0e8;border-radius:6px;transition:all 0.2s ease-in-out}.guide-item.selected.sc-guides-configurator,.main-guide.selected.sc-guides-configurator{background:#E2F4EF}.guide-item.sc-guides-configurator:hover,.main-guide.sc-guides-configurator:hover{background:#f5fcfa}";
12
+
13
+ const GuidesConfigurator = class {
14
+ constructor(hostRef) {
15
+ index.registerInstance(this, hostRef);
16
+ this.guideSelected = index.createEvent(this, "guideSelected", 7);
17
+ this.guideListChanged = index.createEvent(this, "guideListChanged", 7);
18
+ this.guideDeleted = index.createEvent(this, "guideDeleted", 7);
19
+ this.createNewGuide = index.createEvent(this, "createNewGuide", 7);
20
+ this.ID_VISIBLE_GUIDES = 'container-visible-guides';
21
+ this.ID_HIDDEN_GUIDES = 'container-hidden-guides';
22
+ this.sortLogic = (a, b) => {
23
+ var _a, _b;
24
+ const orderA = (_a = a.order) !== null && _a !== void 0 ? _a : Number.MAX_VALUE;
25
+ const orderB = (_b = b.order) !== null && _b !== void 0 ? _b : Number.MAX_VALUE;
26
+ return orderA - orderB;
27
+ };
28
+ this.mainGuide = undefined;
29
+ this.filterTerm = '';
30
+ this.visibleGuides = [];
31
+ this.hiddenGuides = [];
32
+ this.guidesList = [];
33
+ this.selectedGuide = undefined;
34
+ this.messagesBuilder = undefined;
35
+ }
36
+ observeVisibleGuides(newGuides) {
37
+ this.initGuidesConfig(newGuides);
38
+ }
39
+ observeSelectedGuide(newGuide) {
40
+ this.guideSelected.emit(newGuide);
41
+ }
42
+ getMessage(key, params) {
43
+ return this.messagesBuilder.getMessage(key, params);
44
+ }
45
+ initGuidesConfig(newGuides) {
46
+ const visibleAux = [...newGuides.filter(guide => (guide.visible && guide.name !== constants.TAB_NAMES.main))];
47
+ const hiddenAux = [...newGuides.filter(guide => (!guide.visible && guide.name !== constants.TAB_NAMES.main))];
48
+ this.visibleGuides = [...visibleAux.sort(this.sortLogic)];
49
+ this.hiddenGuides = [...hiddenAux.sort(this.sortLogic)];
50
+ this.mainGuide = newGuides.find(g => g.name === constants.TAB_NAMES.main);
51
+ }
52
+ handleAddGuide() {
53
+ this.createNewGuide.emit();
54
+ }
55
+ handleSelectGuide(guide, evt) {
56
+ evt.stopPropagation();
57
+ this.selectedGuide = guide;
58
+ }
59
+ toggleGuideVisibility(guide, evt) {
60
+ evt.stopPropagation();
61
+ const updatedGuide = Object.assign(Object.assign({}, guide), { visible: !guide.visible });
62
+ let visibleAux;
63
+ let hiddenAux;
64
+ if (guide.visible) {
65
+ visibleAux = [...this.visibleGuides.filter(g => g.name !== guide.name)];
66
+ hiddenAux = [...this.hiddenGuides, updatedGuide];
67
+ }
68
+ else {
69
+ visibleAux = [...this.visibleGuides, updatedGuide];
70
+ hiddenAux = [...this.hiddenGuides.filter(g => g.name !== guide.name)];
71
+ }
72
+ const updatedGuideList = [...visibleAux, ...hiddenAux];
73
+ this.applyGuidesUpdate(updatedGuideList);
74
+ }
75
+ adjustListOrder(guideList) {
76
+ return guideList.map((g, index) => {
77
+ return Object.assign(Object.assign({}, g), { order: index });
78
+ });
79
+ }
80
+ applyGuidesUpdate(updatedGuideList) {
81
+ let newGuidesList = this.adjustListOrder(updatedGuideList);
82
+ newGuidesList = [this.mainGuide, ...newGuidesList];
83
+ if (!core.ObjectUtils.equals(newGuidesList, this.guidesList)) {
84
+ this.guideListChanged.emit(newGuidesList);
85
+ }
86
+ }
87
+ async handleDeleteGuide(guide, e) {
88
+ e.stopPropagation();
89
+ const title = this.getMessage('snkFormConfig.confirm.title');
90
+ const message = this.getMessage('snkFormConfig.confirm.deleteGuide').replace('{0}', guide.label);
91
+ const canRemove = await utils.ApplicationUtils.confirm(title, message);
92
+ if (!canRemove)
93
+ return;
94
+ this.guideDeleted.emit(guide);
95
+ const deletedMessage = this.getMessage('snkFormConfig.info.successfullyGuideDeleted').replace('{0}', guide.label);
96
+ utils.ApplicationUtils.info(deletedMessage);
97
+ }
98
+ renderItems(guides) {
99
+ const guidesToShow = core.ArrayUtils.applyStringFilter(this.filterTerm, guides);
100
+ return guidesToShow.map(guide => {
101
+ var _a;
102
+ return (index.h("div", { key: guide.name, "data-guide-name": guide.name, title: guide.label, class: `guide-item ${((_a = this.selectedGuide) === null || _a === void 0 ? void 0 : _a.label) === guide.label ? 'selected' : ''} ${this.filterTerm.length ? 'disable-sort' : ''}`, onClick: e => this.handleSelectGuide(guide, e) }, index.h("span", null, index.h("ez-icon", { iconName: "drag-indicator", class: 'ez-margin-right--small' })), index.h("span", { class: 'item-label' }, guide.label), index.h("div", { class: 'actions' }, index.h("ez-button", { mode: "icon", class: "ez-button--tertiary", onClick: e => this.toggleGuideVisibility(guide, e), size: "medium", iconName: guide.visible ? 'eye-off' : 'eye', title: guide.visible ? 'Ocultar' : 'Tornar visível' }), index.h("ez-button", { mode: "icon", class: "ez-button--tertiary", onClick: e => this.handleDeleteGuide(guide, e), size: "medium", iconName: 'delete', title: 'Excluir' }))));
103
+ });
104
+ }
105
+ getContainerElement(id) {
106
+ return this.el.querySelector(`[id="${id}"]`);
107
+ }
108
+ handleSortGuide() {
109
+ const updatedGuideList = [...this.getGuidesFromStatus(true), ...this.getGuidesFromStatus(false)];
110
+ this.applyGuidesUpdate(updatedGuideList);
111
+ }
112
+ getGuidesFromStatus(visible) {
113
+ let updatedGuideList = [];
114
+ const orderedGuides = this.getOrderedGuideNames(visible ? this.ID_VISIBLE_GUIDES : this.ID_HIDDEN_GUIDES);
115
+ orderedGuides.forEach(guideName => {
116
+ const updatedGuide = this.guidesList.find(g => g.name === guideName);
117
+ if (updatedGuide) {
118
+ updatedGuideList.push(Object.assign(Object.assign({}, updatedGuide), { visible }));
119
+ }
120
+ });
121
+ return updatedGuideList;
122
+ }
123
+ getOrderedGuideNames(containerId) {
124
+ var _a;
125
+ const guidesCollection = (_a = this.getContainerElement(containerId)) === null || _a === void 0 ? void 0 : _a.children;
126
+ return Array.from(guidesCollection).map((element) => element.getAttribute('data-guide-name'));
127
+ }
128
+ initializeDraggableContainers() {
129
+ this._sortableVisibleGuides = new sortable_esm.Sortable(this.getContainerElement(this.ID_VISIBLE_GUIDES), {
130
+ group: 'guides',
131
+ ghostClass: 'ghost',
132
+ direction: 'vertical',
133
+ filter: '.disable-sort',
134
+ animation: 15,
135
+ onSort: () => this.handleSortGuide(),
136
+ });
137
+ this._sortableInvisibleGuides = new sortable_esm.Sortable(this.getContainerElement(this.ID_HIDDEN_GUIDES), {
138
+ group: 'guides',
139
+ ghostClass: 'ghost',
140
+ animation: 15,
141
+ filter: '.disable-sort',
142
+ onSort: () => this.handleSortGuide(),
143
+ });
144
+ }
145
+ handleSelectMainGuide() {
146
+ this.guideSelected.emit(this.mainGuide);
147
+ }
148
+ componentDidLoad() {
149
+ this.initializeDraggableContainers();
150
+ this.initGuidesConfig(this.guidesList);
151
+ }
152
+ render() {
153
+ var _a, _b, _c;
154
+ return (index.h("ez-sidebar-navigator", { class: 'ezSidebarNavigator', type: 'fixed', size: 'md', titleMenu: 'Guias' }, index.h("div", { class: 'navigator-container' }, index.h("ez-filter-input", { slot: "content", mode: "slim", label: "Buscar guia", onEzChange: evt => this.filterTerm = evt.detail }), index.h("div", { onClick: this.handleSelectMainGuide.bind(this), class: `main-guide ${((_a = this.selectedGuide) === null || _a === void 0 ? void 0 : _a.name) === ((_b = this.mainGuide) === null || _b === void 0 ? void 0 : _b.name) ? 'selected' : ''}` }, index.h("span", null, (_c = this.mainGuide) === null || _c === void 0 ? void 0 : _c.label)), index.h("div", { class: 'collapsible-container' }, index.h("div", { class: 'collapsible-item' }, index.h("ez-collapsible-box", { label: "Guias vis\u00EDveis", headerSize: "large" }, index.h("div", { id: this.ID_VISIBLE_GUIDES, class: `guide-list ${!this.visibleGuides.length ? 'visible-empty-content' : ''}` }, this.renderItems(this.visibleGuides)))), index.h("div", { class: 'collapsible-item' }, index.h("ez-collapsible-box", { label: "Guias ocultas", headerSize: "large" }, index.h("div", { id: this.ID_HIDDEN_GUIDES, class: `guide-list ${!this.hiddenGuides.length ? 'hidden-empty-content' : ''}` }, this.renderItems(this.hiddenGuides))))), index.h("div", { class: 'add-button-container', onClick: this.handleAddGuide.bind(this) }, index.h("ez-icon", { slot: "leftIcon", iconName: "plus" }), index.h("span", null, "Criar nova guia")))));
155
+ }
156
+ get el() { return index.getElement(this); }
157
+ static get watchers() { return {
158
+ "guidesList": ["observeVisibleGuides"],
159
+ "selectedGuide": ["observeSelectedGuide"]
160
+ }; }
161
+ };
162
+ GuidesConfigurator.style = guidesConfiguratorCss;
163
+
164
+ exports.guides_configurator = GuidesConfigurator;
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- const index = require('./index-f9e81701.js');
3
+ const index = require('./index-1cf293c1.js');
4
4
 
5
5
  const appendToMap = (map, propName, value) => {
6
6
  const items = map.get(propName);
@@ -38,7 +38,7 @@ const cleanupElements = debounce((map) => {
38
38
  for (let key of map.keys()) {
39
39
  map.set(key, map.get(key).filter(isConnected));
40
40
  }
41
- }, 2000);
41
+ }, 2_000);
42
42
  const stencilSubscription = () => {
43
43
  if (typeof index.getRenderingRef !== 'function') {
44
44
  // If we are not in a stencil project, we do nothing.
@@ -71,7 +71,7 @@ const stencilSubscription = () => {
71
71
  const unwrap = (val) => (typeof val === 'function' ? val() : val);
72
72
  const createObservableMap = (defaultState, shouldUpdate = (a, b) => a !== b) => {
73
73
  const unwrappedState = unwrap(defaultState);
74
- let states = new Map(Object.entries(unwrappedState !== null && unwrappedState !== void 0 ? unwrappedState : {}));
74
+ let states = new Map(Object.entries(unwrappedState ?? {}));
75
75
  const handlers = {
76
76
  dispose: [],
77
77
  get: [],
@@ -79,10 +79,9 @@ const createObservableMap = (defaultState, shouldUpdate = (a, b) => a !== b) =>
79
79
  reset: [],
80
80
  };
81
81
  const reset = () => {
82
- var _a;
83
82
  // When resetting the state, the default state may be a function - unwrap it to invoke it.
84
83
  // otherwise, the state won't be properly reset
85
- states = new Map(Object.entries((_a = unwrap(defaultState)) !== null && _a !== void 0 ? _a : {}));
84
+ states = new Map(Object.entries(unwrap(defaultState) ?? {}));
86
85
  handlers.reset.forEach((cb) => cb());
87
86
  };
88
87
  const dispose = () => {