@sankhyalabs/sankhyablocks 5.5.0 → 5.7.0

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 (224) hide show
  1. package/dist/cjs/{SnkMessageBuilder-26da04f7.js → SnkMessageBuilder-056d1c24.js} +23 -1
  2. package/dist/cjs/{filter-item-type.enum-3daf58d3.js → filter-item-type.enum-aa823a00.js} +1 -0
  3. package/dist/cjs/filter-type.enum-b14ce507.js +11 -0
  4. package/dist/cjs/index-8d94b7e0.js +7 -0
  5. package/dist/cjs/index-de79181a.js +201 -0
  6. package/dist/cjs/loader.cjs.js +1 -1
  7. package/dist/cjs/presentationMode-52ec3bdd.js +7 -0
  8. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  9. package/dist/cjs/snk-application.cjs.entry.js +1 -1
  10. package/dist/cjs/snk-attach.cjs.entry.js +2 -1
  11. package/dist/cjs/snk-crud.cjs.entry.js +2 -1
  12. package/dist/cjs/snk-data-exporter.cjs.entry.js +2 -2
  13. package/dist/cjs/{snk-data-unit-c43df27b.js → snk-data-unit-289081c4.js} +1 -1
  14. package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
  15. package/dist/cjs/snk-detail-view.cjs.entry.js +4 -3
  16. package/dist/cjs/snk-expression-item.cjs.entry.js +213 -0
  17. package/dist/cjs/snk-filter-bar.cjs.entry.js +52 -140
  18. package/dist/cjs/snk-filter-binary-select.cjs.entry.js +8 -1
  19. package/dist/cjs/snk-filter-detail.cjs.entry.js +1 -1
  20. package/dist/cjs/snk-filter-field-search_2.cjs.entry.js +435 -0
  21. package/dist/cjs/snk-filter-item.cjs.entry.js +1 -1
  22. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +66 -0
  23. package/dist/cjs/snk-filter-modal.cjs.entry.js +72 -49
  24. package/dist/cjs/snk-filter-multi-select.cjs.entry.js +3 -1
  25. package/dist/cjs/snk-filter-number.cjs.entry.js +3 -1
  26. package/dist/cjs/snk-filter-period.cjs.entry.js +11 -2
  27. package/dist/cjs/snk-filter-personalized.cjs.entry.js +3 -1
  28. package/dist/cjs/snk-filter-search.cjs.entry.js +3 -1
  29. package/dist/cjs/snk-filter-text.cjs.entry.js +2 -0
  30. package/dist/cjs/snk-grid.cjs.entry.js +3 -2
  31. package/dist/cjs/{snk-guides-viewer-e6a65393.js → snk-guides-viewer-9784c527.js} +1 -1
  32. package/dist/cjs/snk-guides-viewer.cjs.entry.js +3 -2
  33. package/dist/cjs/snk-personalized-filter.cjs.entry.js +126 -0
  34. package/dist/cjs/snk-simple-bar_2.cjs.entry.js +2 -1
  35. package/dist/cjs/snk-taskbar.cjs.entry.js +2 -1
  36. package/dist/cjs/taskbar-elements-bc2598f9.js +118 -0
  37. package/dist/collection/collection-manifest.json +3 -0
  38. package/dist/collection/components/snk-filter-bar/filter-item/editors/enum/presentationMode.js +5 -0
  39. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-binary-select.js +47 -0
  40. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-multi-select.js +19 -0
  41. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-number.js +19 -0
  42. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-period.js +50 -1
  43. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-personalized.js +19 -0
  44. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-search.js +19 -0
  45. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-text.js +19 -0
  46. package/dist/collection/components/snk-filter-bar/filter-item/filter-item-type.enum.js +1 -0
  47. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.css +31 -2
  48. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +116 -156
  49. package/dist/collection/components/snk-filter-bar/filter-modal/subcomponents/snk-filter-modal-item.css +4 -0
  50. package/dist/collection/components/snk-filter-bar/filter-modal/subcomponents/snk-filter-modal-item.js +115 -0
  51. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +19 -142
  52. package/dist/collection/components/snk-filter-bar/types/filter-type.enum.js +7 -0
  53. package/dist/collection/components/snk-filter-bar/utils/SnkFilterModalFactory.js +36 -0
  54. package/dist/collection/components/snk-filter-bar/utils/filters-mock.js +315 -0
  55. package/dist/collection/components/snk-filter-field-search/snk-filter-field-search.js +62 -69
  56. package/dist/collection/components/snk-personalized-filter/snk-personalized-filter.css +4 -0
  57. package/dist/collection/components/snk-personalized-filter/snk-personalized-filter.js +87 -0
  58. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-item/filter-operands/filter-operands.js +34 -0
  59. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.css +97 -0
  60. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.js +298 -0
  61. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-filter-param-config/snk-filter-param-config.js +2 -2
  62. package/dist/collection/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.js +63 -0
  63. package/dist/collection/lib/message/SnkMessageBuilder.js +2 -0
  64. package/dist/collection/lib/message/resources/snk-filter-bar.msg.js +9 -1
  65. package/dist/collection/lib/message/resources/snk-personalized-filter.msg.js +12 -0
  66. package/dist/collection/lib/store/index.js +2 -1
  67. package/dist/components/SnkMessageBuilder.js +23 -1
  68. package/dist/components/filter-item-type.enum.js +1 -0
  69. package/dist/components/index.d.ts +3 -0
  70. package/dist/components/index.js +3 -0
  71. package/dist/components/index2.js +1 -1
  72. package/dist/components/index3.js +199 -0
  73. package/dist/components/presentationMode.js +7 -0
  74. package/dist/components/snk-crud.js +22 -34
  75. package/dist/components/snk-data-exporter2.js +1 -1
  76. package/dist/components/snk-detail-view2.js +24 -46
  77. package/dist/components/snk-expression-item.d.ts +11 -0
  78. package/dist/components/snk-expression-item.js +6 -0
  79. package/dist/components/snk-expression-item2.js +241 -0
  80. package/dist/components/snk-filter-bar2.js +57 -157
  81. package/dist/components/snk-filter-binary-select.js +9 -1
  82. package/dist/components/snk-filter-field-search.js +1 -200
  83. package/dist/{esm/snk-filter-field-search.entry.js → components/snk-filter-field-search2.js} +65 -38
  84. package/dist/components/snk-filter-list.js +171 -1
  85. package/dist/components/snk-filter-modal-item.d.ts +11 -0
  86. package/dist/components/snk-filter-modal-item.js +6 -0
  87. package/dist/components/snk-filter-modal-item2.js +85 -0
  88. package/dist/components/snk-filter-modal.js +118 -1
  89. package/dist/components/snk-filter-multi-select.js +3 -1
  90. package/dist/components/snk-filter-number.js +3 -1
  91. package/dist/components/snk-filter-param-config.js +1 -273
  92. package/dist/{esm/snk-filter-param-config.entry.js → components/snk-filter-param-config2.js} +35 -11
  93. package/dist/components/snk-filter-period.js +12 -2
  94. package/dist/components/snk-filter-personalized.js +3 -1
  95. package/dist/components/snk-filter-search.js +3 -1
  96. package/dist/components/snk-filter-text.js +3 -1
  97. package/dist/components/snk-grid2.js +12 -23
  98. package/dist/components/snk-personalized-filter.d.ts +11 -0
  99. package/dist/components/snk-personalized-filter.js +158 -0
  100. package/dist/components/snk-taskbar2.js +3 -197
  101. package/dist/esm/{SnkMessageBuilder-7a9392e6.js → SnkMessageBuilder-23272e07.js} +23 -1
  102. package/dist/esm/{filter-item-type.enum-a79b2fa8.js → filter-item-type.enum-5028ed3f.js} +1 -0
  103. package/dist/esm/filter-type.enum-a80c1b6b.js +9 -0
  104. package/dist/esm/{index-6519a79e.js → index-507e19ec.js} +1 -1
  105. package/dist/esm/index-620ac460.js +7 -0
  106. package/dist/esm/index-8efbf198.js +199 -0
  107. package/dist/esm/loader.js +1 -1
  108. package/dist/esm/presentationMode-783bbf9d.js +7 -0
  109. package/dist/esm/sankhyablocks.js +1 -1
  110. package/dist/esm/snk-application.entry.js +1 -1
  111. package/dist/esm/snk-attach.entry.js +3 -2
  112. package/dist/esm/snk-crud.entry.js +3 -2
  113. package/dist/esm/snk-data-exporter.entry.js +3 -3
  114. package/dist/esm/{snk-data-unit-f9e4c694.js → snk-data-unit-34dc5371.js} +1 -1
  115. package/dist/esm/snk-data-unit.entry.js +2 -2
  116. package/dist/esm/snk-detail-view.entry.js +5 -4
  117. package/dist/esm/snk-expression-item.entry.js +209 -0
  118. package/dist/esm/snk-filter-bar.entry.js +53 -141
  119. package/dist/esm/snk-filter-binary-select.entry.js +9 -2
  120. package/dist/esm/snk-filter-detail.entry.js +1 -1
  121. package/dist/esm/snk-filter-field-search_2.entry.js +430 -0
  122. package/dist/esm/snk-filter-item.entry.js +1 -1
  123. package/dist/esm/snk-filter-modal-item.entry.js +62 -0
  124. package/dist/esm/snk-filter-modal.entry.js +73 -50
  125. package/dist/esm/snk-filter-multi-select.entry.js +4 -2
  126. package/dist/esm/snk-filter-number.entry.js +4 -2
  127. package/dist/esm/snk-filter-period.entry.js +12 -3
  128. package/dist/esm/snk-filter-personalized.entry.js +4 -2
  129. package/dist/esm/snk-filter-search.entry.js +4 -2
  130. package/dist/esm/snk-filter-text.entry.js +3 -1
  131. package/dist/esm/snk-grid.entry.js +3 -2
  132. package/dist/esm/{snk-guides-viewer-62a9f74d.js → snk-guides-viewer-4d12f268.js} +2 -2
  133. package/dist/esm/snk-guides-viewer.entry.js +4 -3
  134. package/dist/esm/snk-personalized-filter.entry.js +122 -0
  135. package/dist/esm/snk-simple-bar_2.entry.js +3 -2
  136. package/dist/esm/snk-taskbar.entry.js +3 -2
  137. package/dist/esm/taskbar-elements-e6af3e93.js +115 -0
  138. package/dist/sankhyablocks/p-0110b7da.entry.js +1 -0
  139. package/dist/sankhyablocks/p-1a68fb59.js +1 -0
  140. package/dist/sankhyablocks/p-27e264d9.entry.js +1 -0
  141. package/dist/sankhyablocks/p-343699ad.entry.js +1 -0
  142. package/dist/sankhyablocks/{p-f2223502.js → p-3db1d3de.js} +1 -1
  143. package/dist/sankhyablocks/p-433dfa63.entry.js +1 -0
  144. package/dist/sankhyablocks/p-45ee8b22.entry.js +1 -0
  145. package/dist/sankhyablocks/{p-f132e371.js → p-4c2015a9.js} +1 -1
  146. package/dist/sankhyablocks/p-4ce96831.entry.js +1 -0
  147. package/dist/sankhyablocks/p-4eefe631.entry.js +1 -0
  148. package/dist/sankhyablocks/{p-9dd2b8cb.js → p-584d7212.js} +1 -1
  149. package/dist/sankhyablocks/{p-a412992c.entry.js → p-64b03506.entry.js} +1 -1
  150. package/dist/sankhyablocks/p-6a02e236.js +1 -0
  151. package/dist/sankhyablocks/p-7695c404.entry.js +1 -0
  152. package/dist/sankhyablocks/p-786ae316.entry.js +1 -0
  153. package/dist/sankhyablocks/p-82bc97da.entry.js +1 -0
  154. package/dist/sankhyablocks/p-8bdf5e57.entry.js +1 -0
  155. package/dist/sankhyablocks/p-8efb0f47.entry.js +1 -0
  156. package/dist/sankhyablocks/p-9af04fc7.entry.js +1 -0
  157. package/dist/sankhyablocks/{p-3a2ce158.entry.js → p-a1c58536.entry.js} +1 -1
  158. package/dist/sankhyablocks/{p-afba9bbe.entry.js → p-bdbb2672.entry.js} +1 -1
  159. package/dist/sankhyablocks/{p-b2523981.entry.js → p-c1ab16d0.entry.js} +2 -2
  160. package/dist/sankhyablocks/{p-aeffd219.js → p-ccd26e3a.js} +1 -1
  161. package/dist/sankhyablocks/p-d410f45a.js +1 -0
  162. package/dist/sankhyablocks/p-d9804798.js +1 -0
  163. package/dist/sankhyablocks/p-df8f13b4.entry.js +1 -0
  164. package/dist/sankhyablocks/p-e2bb9c9a.entry.js +1 -0
  165. package/dist/sankhyablocks/p-e9f42525.entry.js +1 -0
  166. package/dist/sankhyablocks/p-ed3d6ab4.entry.js +1 -0
  167. package/dist/sankhyablocks/p-ee1381f4.entry.js +1 -0
  168. package/dist/sankhyablocks/p-f4184ce7.js +1 -0
  169. package/dist/sankhyablocks/p-f5f36fbb.js +1 -0
  170. package/dist/sankhyablocks/p-fd4ed40a.entry.js +1 -0
  171. package/dist/sankhyablocks/p-ff96b509.entry.js +27 -0
  172. package/dist/sankhyablocks/p-ffac37d5.entry.js +1 -0
  173. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  174. package/dist/types/components/snk-filter-bar/filter-item/editors/enum/presentationMode.d.ts +4 -0
  175. package/dist/types/components/snk-filter-bar/filter-item/editors/snk-filter-personalized.d.ts +5 -0
  176. package/dist/types/components/snk-filter-bar/filter-item/filter-item-type.enum.d.ts +2 -1
  177. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +3 -0
  178. package/dist/types/components/snk-filter-bar/filter-modal/snk-filter-modal.d.ts +37 -0
  179. package/dist/types/components/snk-filter-bar/filter-modal/subcomponents/snk-filter-modal-item.d.ts +17 -0
  180. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +2 -11
  181. package/dist/types/components/snk-filter-bar/types/filter-type.enum.d.ts +6 -0
  182. package/dist/types/components/snk-filter-bar/utils/SnkFilterModalFactory.d.ts +20 -0
  183. package/dist/types/components/snk-filter-bar/utils/filters-mock.d.ts +186 -0
  184. package/dist/types/components/snk-filter-field-search/interfaces/index.d.ts +14 -4
  185. package/dist/types/components/snk-filter-field-search/snk-filter-field-search.d.ts +13 -10
  186. package/dist/types/components/snk-personalized-filter/snk-personalized-filter.d.ts +20 -0
  187. package/dist/types/components/snk-personalized-filter/subcomponents/snk-expression-item/filter-operands/filter-operands.d.ts +9 -0
  188. package/dist/types/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.d.ts +54 -0
  189. package/dist/types/components/snk-personalized-filter/subcomponents/snk-filter-param-config/interfaces/IExpressionItem.d.ts +4 -2
  190. package/dist/types/components.d.ts +196 -63
  191. package/dist/types/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.d.ts +7 -0
  192. package/dist/types/lib/message/resources/snk-personalized-filter.msg.d.ts +1 -0
  193. package/dist/types/lib/store/index.d.ts +1 -0
  194. package/package.json +1 -1
  195. package/react/components.d.ts +3 -0
  196. package/react/components.js +3 -0
  197. package/react/components.js.map +1 -1
  198. package/dist/cjs/snk-filter-field-search.cjs.entry.js +0 -185
  199. package/dist/cjs/snk-filter-param-config.cjs.entry.js +0 -256
  200. package/dist/cjs/taskbar-elements-80285601.js +0 -313
  201. package/dist/components/snk-filter-list2.js +0 -173
  202. package/dist/components/snk-filter-modal2.js +0 -97
  203. package/dist/esm/taskbar-elements-055ba1ad.js +0 -309
  204. package/dist/sankhyablocks/p-4512cc6c.entry.js +0 -1
  205. package/dist/sankhyablocks/p-5cbbe1f7.entry.js +0 -1
  206. package/dist/sankhyablocks/p-5e62a17b.entry.js +0 -1
  207. package/dist/sankhyablocks/p-5fc55684.entry.js +0 -1
  208. package/dist/sankhyablocks/p-63d01871.entry.js +0 -1
  209. package/dist/sankhyablocks/p-73e830cf.entry.js +0 -1
  210. package/dist/sankhyablocks/p-741b00ef.entry.js +0 -1
  211. package/dist/sankhyablocks/p-79d22df0.entry.js +0 -1
  212. package/dist/sankhyablocks/p-86d29b6f.entry.js +0 -1
  213. package/dist/sankhyablocks/p-92a0fca4.js +0 -1
  214. package/dist/sankhyablocks/p-93d8fe00.entry.js +0 -1
  215. package/dist/sankhyablocks/p-999d1953.entry.js +0 -1
  216. package/dist/sankhyablocks/p-ad51bf1c.entry.js +0 -1
  217. package/dist/sankhyablocks/p-c336170d.entry.js +0 -1
  218. package/dist/sankhyablocks/p-c3efd4eb.entry.js +0 -1
  219. package/dist/sankhyablocks/p-d5c9c1f8.entry.js +0 -1
  220. package/dist/sankhyablocks/p-ebe876f5.entry.js +0 -1
  221. package/dist/sankhyablocks/p-ed438690.js +0 -1
  222. package/dist/sankhyablocks/p-ee82c157.entry.js +0 -1
  223. package/dist/sankhyablocks/p-f3d0c744.entry.js +0 -1
  224. package/dist/sankhyablocks/p-fac37198.entry.js +0 -1
@@ -0,0 +1,209 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host } from './index-cfd4bb13.js';
2
+ import { UserInterface, ApplicationContext } from '@sankhyalabs/core';
3
+ import { S as SelectedItemType } from './index-620ac460.js';
4
+ import { ApplicationUtils, CheckMode } from '@sankhyalabs/ezui/dist/collection/utils';
5
+ import { fieldBuilder } from '@sankhyalabs/ezui/dist/collection/components/ez-form-view/fieldbuilder/FieldBuilder';
6
+ import { c as FilterOperand } from './index-507e19ec.js';
7
+ import { s as store } from './index-8efbf198.js';
8
+
9
+ const FilterOperandDefault = [
10
+ { value: FilterOperand.EQUAL, label: "Igual (=)" },
11
+ { value: FilterOperand.DIFFERENT, label: "Diferente (<>)" },
12
+ { value: FilterOperand.LIKE, label: "Contendo (LIKE)" },
13
+ { value: FilterOperand.IN, label: "Contido em (IN)" },
14
+ { value: FilterOperand.START_WITH, label: "Iniciado com (%?)" },
15
+ { value: FilterOperand.FINISHED_WITH, label: "Terminado com (?%)" },
16
+ { value: FilterOperand.NULL, label: "Vazio (NULL)" },
17
+ { value: FilterOperand.NOT_NULL, label: "Não Vazio (NOT NULL)" },
18
+ { value: FilterOperand.LARGER, label: "Maior (>)" },
19
+ { value: FilterOperand.LARGER_EQUAL, label: "Maior ou Igual (>=)" },
20
+ { value: FilterOperand.SMALLER, label: "Menor (<)" },
21
+ { value: FilterOperand.SMALLER_EQUAL, label: "Menor ou Igual (<=)" }
22
+ ];
23
+ const FilterOperandTypeTextSearch = [
24
+ { value: FilterOperand.EQUAL, label: "Igual (=)" },
25
+ { value: FilterOperand.DIFFERENT, label: "Diferente (<>)" },
26
+ { value: FilterOperand.LIKE, label: "Contendo (LIKE)" },
27
+ { value: FilterOperand.IN, label: "Contido em (IN)" },
28
+ { value: FilterOperand.START_WITH, label: "Iniciado com (%?)" },
29
+ { value: FilterOperand.FINISHED_WITH, label: "Terminado com (?%)" },
30
+ { value: FilterOperand.NULL, label: "Vazio (NULL)" },
31
+ { value: FilterOperand.NOT_NULL, label: "Não Vazio (NOT NULL)" }
32
+ ];
33
+ const FIELD_TYPE_SEARCH_AND_TEXT = [
34
+ UserInterface.SEARCH,
35
+ UserInterface.SHORTTEXT,
36
+ UserInterface.PASSWORD,
37
+ UserInterface.MASKEDTEXT,
38
+ UserInterface.LONGTEXT,
39
+ UserInterface.HTML
40
+ ];
41
+
42
+ const snkExpressionItemCss = ".sc-snk-expression-item-h{display:flex;width:100%;--snk-expression-item--background-color:var(--background--xlight, #fff);--snk-expression-item__itens--padding:var(--space--small, 6px);--snk-expression-item__width--input-operator:220px;--snk-expression-item__width--input-value:240px;--snk-expression-item__width--input-value-variable:176px;--snk-expression-item--border-radius:var(--border--radius-medium, 12px);--snk-expression-item--border-color:var(--color--strokes, #DCE0E8);--snk-expression-item--border-style:var(--border--small, 1px solid)}.box.sc-snk-expression-item{width:100%;height:100%;background:var(--snk-expression-item--background-color);margin:var(--space--small, 6px);border:var(--snk-expression-item--border-color) var(--snk-expression-item--border-style);border-radius:var(--snk-expression-item--border-radius)}.box__container.sc-snk-expression-item{display:flex;align-items:center;justify-content:space-between;white-space:nowrap;margin:var(--space--small, 6px)}.box__container--input-filter.sc-snk-expression-item{width:100%}.box__container--input-operator.sc-snk-expression-item{display:flex;width:var(--snk-expression-item__width--input-operator);min-width:var(--snk-expression-item__width--input-operator)}.box__container--input-value.sc-snk-expression-item{display:flex;width:var(--snk-expression-item__width--input-value);min-width:var(--snk-expression-item__width--input-value)}.box__container--input-value-variable.sc-snk-expression-item{display:flex;width:var(--snk-expression-item__width--input-value-variable);min-width:var(--snk-expression-item__width--input-value-variable)}.box__container--button-delete.sc-snk-expression-item{display:flex}.box__container.sc-snk-expression-item>div.sc-snk-expression-item{padding-left:var(--snk-expression-item__itens--padding);padding-right:var(--snk-expression-item__itens--padding)}.box__container--button-delete--icon.sc-snk-expression-item{width:42px;min-width:42px}.box__container--input-value-variable--icon.sc-snk-expression-item{cursor:pointer}";
43
+
44
+ const SnkExpressionItem = class {
45
+ constructor(hostRef) {
46
+ registerInstance(this, hostRef);
47
+ this.ezFilterItemChange = createEvent(this, "ezFilterItemChange", 7);
48
+ this.ezFilterItemRemove = createEvent(this, "ezFilterItemRemove", 7);
49
+ this.application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
50
+ this.filterOperandDefault = FilterOperandDefault;
51
+ this.filterOperandTypeTextSearch = FilterOperandTypeTextSearch;
52
+ this._showValueVariable = false;
53
+ this._fieldSelected = undefined;
54
+ this._optionNotNull = false;
55
+ this.expression = undefined;
56
+ this.canRemove = true;
57
+ this.messagesBuilder = undefined;
58
+ }
59
+ expressionChanged(newValue, oldValue) {
60
+ if (newValue !== oldValue) {
61
+ this.ezFilterItemChange.emit(newValue);
62
+ }
63
+ }
64
+ componentWillLoad() {
65
+ this._dataSourceFetcher = store.get("filterFieldsDataSource");
66
+ store.onChange('filterFieldsDataSource', () => {
67
+ this._dataSourceFetcher = store.get("filterFieldsDataSource");
68
+ });
69
+ }
70
+ setValueExpression(key, value) {
71
+ this.expression[key] = value;
72
+ this.expressionChanged(this.expression);
73
+ }
74
+ getMessage(key, params) {
75
+ return this.application.messagesBuilder.getMessage(key, params);
76
+ }
77
+ handleSelectItem(filterField) {
78
+ if (filterField.type === SelectedItemType.FIELD) {
79
+ const field = filterField;
80
+ this._fieldSelected = field;
81
+ this.setValueExpression("fieldName", field.name);
82
+ }
83
+ }
84
+ handleFocus() {
85
+ if (this._elFilterFieldSearch)
86
+ this._elFilterFieldSearch.show();
87
+ }
88
+ handleChangeFilterInput(evt) {
89
+ this._elFilterFieldSearch.applyFilter(evt.detail);
90
+ }
91
+ handleChangeValueVariable(showValueVariable) {
92
+ this._showValueVariable = showValueVariable;
93
+ if (this._elFieldDynamic) {
94
+ this._elFieldDynamic.value = undefined;
95
+ this._elFieldDynamic.enabled = !showValueVariable;
96
+ }
97
+ }
98
+ openSnkFilterParamConfig() {
99
+ var _a;
100
+ (_a = this._elFilterParamConfigRef) === null || _a === void 0 ? void 0 : _a.open(this.expression).then(this.onOpenPromiseReady.bind(this)).catch(error => {
101
+ console.error(error);
102
+ });
103
+ }
104
+ onOpenPromiseReady(changes) {
105
+ this.expression = changes;
106
+ }
107
+ buildOptionsOperator() {
108
+ var _a;
109
+ if (FIELD_TYPE_SEARCH_AND_TEXT.includes((_a = this._fieldSelected) === null || _a === void 0 ? void 0 : _a.userInterface)) {
110
+ return this.filterOperandTypeTextSearch;
111
+ }
112
+ else {
113
+ return this.filterOperandDefault;
114
+ }
115
+ }
116
+ handleChangeOperator(optionSelected) {
117
+ this.checkOptionIsNull(optionSelected);
118
+ this.setValueExpression("operand", optionSelected);
119
+ }
120
+ checkOptionIsNull(optionSelected) {
121
+ if (optionSelected === FilterOperand.NULL || optionSelected === FilterOperand.NOT_NULL) {
122
+ this._optionNotNull = true;
123
+ if (this._elFieldDynamic) {
124
+ this._elFieldDynamic.enabled = false;
125
+ this._elFieldDynamic.value = undefined;
126
+ }
127
+ }
128
+ else {
129
+ this._optionNotNull = false;
130
+ if (this._elFieldDynamic) {
131
+ this._elFieldDynamic.enabled = this._showValueVariable ? false : true;
132
+ }
133
+ }
134
+ }
135
+ confirmRemove(evt) {
136
+ evt.preventDefault();
137
+ evt.stopPropagation();
138
+ ApplicationUtils.confirm(this.getMessage("snkPersonalizedFilter.confirm.title"), this.getMessage("snkPersonalizedFilter.confirm.description"))
139
+ .then((canRemove) => {
140
+ if (canRemove) {
141
+ this.ezFilterItemRemove.emit(this.expression);
142
+ }
143
+ });
144
+ }
145
+ buildFieldByType() {
146
+ var _a, _b;
147
+ if (!this._fieldSelected)
148
+ return;
149
+ const inputFieldData = (_a = fieldBuilder(this.configureFieldByType())) === null || _a === void 0 ? void 0 : _a.$children$.shift();
150
+ if (this._optionNotNull && inputFieldData || ((_b = this._elValueVariable) === null || _b === void 0 ? void 0 : _b.value) && inputFieldData) {
151
+ inputFieldData.$attrs$.enabled = false;
152
+ }
153
+ return h(inputFieldData.$tag$, Object.assign(Object.assign({}, inputFieldData.$attrs$), { ref: (el) => {
154
+ this._elFieldDynamic = el;
155
+ } }));
156
+ }
157
+ configureFieldByType() {
158
+ const field = {
159
+ userInterface: this._fieldSelected.userInterface,
160
+ name: this._fieldSelected.name,
161
+ label: this._fieldSelected.label,
162
+ canShowError: false
163
+ };
164
+ switch (field.userInterface) {
165
+ case UserInterface.OPTIONSELECTOR:
166
+ field.props = {
167
+ options: this._fieldSelected.properties.map(option => ({
168
+ value: option.value,
169
+ label: option.name,
170
+ })),
171
+ };
172
+ break;
173
+ case UserInterface.LONGTEXT:
174
+ field.rows = 1;
175
+ break;
176
+ case UserInterface.SEARCH:
177
+ field.optionLoader = searchArgument => this.setCriteriaSearch(searchArgument, this.application);
178
+ break;
179
+ }
180
+ return field;
181
+ }
182
+ setCriteriaSearch({ mode, argument }, application) {
183
+ if (application == undefined)
184
+ return;
185
+ const searchOptions = {
186
+ showInactives: false
187
+ };
188
+ const options = {
189
+ entity: this._fieldSelected.properties.ENTITYNAME,
190
+ searchOptions: searchOptions,
191
+ entityDescription: this._fieldSelected.label
192
+ };
193
+ return application.executePreparedSearch(mode, argument, options);
194
+ }
195
+ render() {
196
+ var _a;
197
+ return (h(Host, null, h("div", { class: "box" }, h("div", { class: "box__container" }, h("div", { class: "box__container--input-filter" }, h("ez-filter-input", { value: (_a = this._fieldSelected) === null || _a === void 0 ? void 0 : _a.path, label: this.getMessage("snkPersonalizedFilter.info.labelSearchField"), canShowError: false, onEzChange: (evt) => this.handleChangeFilterInput(evt), onFocus: () => this.handleFocus() }), h("snk-filter-field-search", { ref: ref => this._elFilterFieldSearch = ref, searchable: false, onEzSelectFilterItem: (ev) => this.handleSelectItem(ev.detail), fieldsDataSource: this._dataSourceFetcher })), h("div", { class: "box__container--input-operator" }, h("ez-combo-box", { label: this.getMessage("snkPersonalizedFilter.info.labelOperator"), canShowError: false, options: this.buildOptionsOperator(), onEzChange: (evt) => this.handleChangeOperator(evt.detail.value), suppressEmptyOption: true })), h("div", { class: "box__container--input-value" }, !this._fieldSelected ?
198
+ h("ez-number-input", { label: "Valor", canShowError: false, enabled: (!this._showValueVariable && !this._optionNotNull) }) :
199
+ this.buildFieldByType()), h("div", { class: "box__container--input-value-variable", title: this.getMessage("snkPersonalizedFilter.info.titleTooltip") }, !this._optionNotNull &&
200
+ h("ez-check", { ref: ref => this._elValueVariable = ref, label: this.getMessage("snkPersonalizedFilter.info.labelValueVarible"), mode: CheckMode.SWITCH, onEzChange: (evt) => this.handleChangeValueVariable(evt.detail) }), (this._showValueVariable && !this._optionNotNull) &&
201
+ h("ez-icon", { class: "box__container--input-value-variable--icon", size: "large", iconName: "settings-inverted", onClick: () => this.openSnkFilterParamConfig() }), h("snk-filter-param-config", { ref: (el) => this._elFilterParamConfigRef = el, messagesBuilder: this.messagesBuilder })), h("div", { class: "box__container--button-delete" }, h("div", { class: "box__container--button-delete--icon" }, this.canRemove && h("ez-button", { mode: "icon", iconName: "delete", onClick: (evt) => this.confirmRemove(evt) })))))));
202
+ }
203
+ static get watchers() { return {
204
+ "expression": ["expressionChanged"]
205
+ }; }
206
+ };
207
+ SnkExpressionItem.style = snkExpressionItemCss;
208
+
209
+ export { SnkExpressionItem as snk_expression_item };
@@ -1,10 +1,10 @@
1
1
  import { r as registerInstance, h, H as Host, g as getElement } from './index-cfd4bb13.js';
2
- import { DataType, ObjectUtils, ElementIDUtils, StringUtils, ErrorException, ApplicationContext } from '@sankhyalabs/core';
2
+ import { DataType, ObjectUtils, ElementIDUtils, ErrorException, ApplicationContext } from '@sankhyalabs/core';
3
3
  import { EzScrollDirection } from '@sankhyalabs/ezui/dist/collection/components/ez-scroller/EzScrollDirection';
4
- import { F as FilterItemType } from './filter-item-type.enum-a79b2fa8.js';
5
- import { ModalAction } from '@sankhyalabs/ezui/dist/collection/components/ez-modal-container';
6
- import { toString } from '@sankhyalabs/core/dist/dataunit/metadata/DataType';
7
4
  import { C as ConfigStorage } from './ConfigStorage-ac77ff39.js';
5
+ import { toString } from '@sankhyalabs/core/dist/dataunit/metadata/DataType';
6
+ import { F as FilterItemType } from './filter-item-type.enum-5028ed3f.js';
7
+ import { ApplicationUtils } from '@sankhyalabs/ezui/dist/collection/utils';
8
8
  import './form-config-fetcher-018e7e73.js';
9
9
  import './DataFetcher-b3d8b2d5.js';
10
10
  import './_commonjsHelpers-9943807e.js';
@@ -106,13 +106,43 @@ function buildPersonalized(item) {
106
106
  };
107
107
  }
108
108
 
109
+ class SnkFilterModalFactory {
110
+ constructor({ filterConfig, onComplete, getMessage }) {
111
+ this._filterConfig = filterConfig;
112
+ this._onComplete = onComplete;
113
+ this._getMessage = getMessage;
114
+ }
115
+ applyFilters(newFilterConfig) {
116
+ this._onComplete(newFilterConfig);
117
+ this._closeModal();
118
+ }
119
+ clearAll(filterConfigSnapshot) {
120
+ return filterConfigSnapshot.map(filterItem => (Object.assign(Object.assign({}, filterItem), { value: undefined })));
121
+ }
122
+ buildFilterModal() {
123
+ const filterModal = document.createElement("snk-filter-modal");
124
+ filterModal.filters = this._filterConfig;
125
+ filterModal.getMessage = this._getMessage.bind(this);
126
+ filterModal.applyFilters = this.applyFilters.bind(this);
127
+ filterModal.clearAll = this.clearAll.bind(this);
128
+ filterModal.closeModal = () => this._closeModal();
129
+ return filterModal;
130
+ }
131
+ async showModal() {
132
+ const filterModal = this.buildFilterModal();
133
+ const modalProps = {
134
+ content: filterModal,
135
+ position: 'left',
136
+ heightMode: 'full',
137
+ closeOutsideClick: false,
138
+ useScrimLight: true
139
+ };
140
+ this._closeModal = await ApplicationUtils.showModal(modalProps);
141
+ }
142
+ }
143
+
109
144
  const snkFilterBarCss = ".sc-snk-filter-bar-h{display:grid;grid-template-columns:minmax(100px, 100%) 1fr 1fr}.snk-filter__popover-container.sc-snk-filter-bar{display:flex;cursor:auto}.snk-filter__popover.sc-snk-filter-bar{display:flex;flex-direction:column;position:absolute;width:fit-content;height:fit-content;min-width:265px;z-index:var(--most-visible, 3);background-color:var(--background--xlight, #fff);border-radius:var(--border--radius-medium, 12px);box-shadow:var(--shadow, 0px 0px 16px 0px #000)}.snk-filter-item__editor-header.sc-snk-filter-bar{flex-grow:1;font-weight:var(--text-weight--medium, 400);color:var(--color--title-primary, #2B3A54)}.snk-filter__popover-rule.sc-snk-filter-bar{border-style:solid;border-color:var(--color--disable-secondary, #F2F5F8);border-radius:1px;border-width:1px;width:100%}.editor__ez-check.sc-snk-filter-bar{--ez-check__label--padding-left:0}.snk-filter-item__editor-header-button.sc-snk-filter-bar{cursor:pointer;background-color:transparent;border:none;padding:3px;outline-color:var(--color--primary)}.snk-filter-bar__divider.sc-snk-filter-bar{margin-bottom:var(--space--small)}.snk-filter-bar__filter-list-items-container.sc-snk-filter-bar{overflow-y:auto;max-height:360px;margin-top:var(--space--small, 6px)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar{cursor:pointer;border-radius:var(--border--radius-small, 6px);border:none;background-color:transparent}.snk-filter-bar__filter-list-item__label.sc-snk-filter-bar{color:var(--title--primary)}.snk-filter-bar__filter-list-item__label--secondary.sc-snk-filter-bar{color:var(--text--primary)}.snk-filter-bar__filter-list-item__icon.sc-snk-filter-bar{--ez-icon--color:var(--title--primary)}.snk-filter-bar__filter-list-item__icon--secondary.sc-snk-filter-bar{--ez-icon--color:var(--text--secondary)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar:focus-visible{outline:none;background-color:var(--background--medium)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar:hover{background-color:var(--background--medium)}.snk-filter-bar__filter-list-items-container--empty.sc-snk-filter-bar{width:100%;height:100px;display:flex;justify-content:center;align-self:center;align-items:center}.snk-filter-bar__filter-list-items-button--active.sc-snk-filter-bar{position:relative}.snk-filter-bar__filter-list-items-button--active.sc-snk-filter-bar::after{display:flex;position:absolute;content:\"\";width:8px;height:8px;top:7px;left:17px;background-color:var(--icon--alert--color, #008561);border-radius:50%}.snk-filter-bar__filter-modal-item.sc-snk-filter-bar{--modal-item-border-width:2px;display:flex;flex-direction:row;margin-left:var(--modal-item-border-width);border-radius:var(--border--radius-medium, 12px);background-color:var(--background--medium, #f0f3f7);border:none;width:100%}.snk-filter-bar__filter-modal-item.sc-snk-filter-bar:focus-visible{outline:var(--color--primary) solid var(--modal-item-border-width)}.snk-filter-bar__filter-modal-item__check.sc-snk-filter-bar{width:auto}.snk-filter-bar__filter-modal-item__label.sc-snk-filter-bar{font-weight:var(--text-weight--medium)}.snk-filter-bar__filter-modal-content.sc-snk-filter-bar{display:grid;grid-template-rows:auto auto 1fr auto;width:99%;height:100%}";
110
145
 
111
- const PERSONALIZED_FILTER = "PERSONALIZED_FILTER";
112
- const DEFAULT_FILTER = "DEFAULT_FILTER";
113
- const CLEAR_ALL_FILTERS = "CLEAR_ALL_FILTERS";
114
- const ADD_FILTER = "ADD_FILTER";
115
- const APPLIED_FILTERS = "APPLIED_FILTERS";
116
146
  const SnkFilterBar = class {
117
147
  constructor(hostRef) {
118
148
  registerInstance(this, hostRef);
@@ -200,9 +230,9 @@ const SnkFilterBar = class {
200
230
  * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
201
231
  * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-filter-bar.msg.ts"
202
232
  */
203
- getMessage(key, params) {
233
+ getMessage(key, params, defaultValue) {
204
234
  var _a;
205
- return (_a = this.messagesBuilder) === null || _a === void 0 ? void 0 : _a.getMessage(key, params);
235
+ return ((_a = this.messagesBuilder) === null || _a === void 0 ? void 0 : _a.getMessage(key, params)) || defaultValue;
206
236
  }
207
237
  getFilter(_dataUnit) {
208
238
  var _a;
@@ -291,110 +321,6 @@ const SnkFilterBar = class {
291
321
  return item;
292
322
  }).sort((a, b) => this._filtersComparator(a, b));
293
323
  }
294
- getAddListItems() {
295
- const hiddenItems = this.filterConfig
296
- .filter(item => !item.visible && this.isListable(item));
297
- const footerItems = [{ name: PERSONALIZED_FILTER, label: this.getMessage("snkFilterBar.customFilter"), iconName: "tune", kind: "FOOTER" }];
298
- if (this.allowDefault) {
299
- footerItems.push({ name: DEFAULT_FILTER, label: this.getMessage("snkFilterBar.defaultFilter"), iconName: "configuration", kind: "FOOTER" });
300
- }
301
- return hiddenItems.map(filter => { return { name: filter.id, label: filter.label, kind: "FILTER", iconName: null }; })
302
- .concat(footerItems);
303
- }
304
- getActiveClass() {
305
- const filterApplied = this.filterConfig.filter(item => item.value != undefined).length > 0;
306
- return filterApplied ? "sc-snk-filter-bar snk-filter-bar__filter-list-items-button--active" : "";
307
- }
308
- isListable(item, allowPersonalized = false) {
309
- return item.type !== FilterItemType.DEFAULT_FILTER && (allowPersonalized || item.type !== FilterItemType.PERSONALIZED);
310
- }
311
- getAppliedListItems() {
312
- const appliedItems = this.filterConfig
313
- .filter(item => this.isActiveFilter(item) && this.isListable(item, true));
314
- return appliedItems.map(filter => {
315
- return { name: filter.id, label: filter.label, kind: "FILTER", iconName: null };
316
- }).concat([
317
- { name: CLEAR_ALL_FILTERS, label: this.getMessage("snkFilterBar.clearAllFilters"), iconName: "cleaning", kind: "FOOTER" }
318
- ]);
319
- }
320
- addPersonalizedFilters(personalizedItems) {
321
- const activeFilters = {};
322
- personalizedItems.forEach(item => {
323
- if (item.active) {
324
- activeFilters[item.id] = true;
325
- }
326
- });
327
- this.filterConfig = this.filterConfig.map(item => {
328
- var _a, _b;
329
- if (item.type === FilterItemType.PERSONALIZED) {
330
- const visible = activeFilters[item.id];
331
- if (!item.visible && visible) {
332
- this.calculateUpdateSequence(item);
333
- if (((_b = (_a = item.props) === null || _a === void 0 ? void 0 : _a.personalizedFilter) === null || _b === void 0 ? void 0 : _b.parameters) != undefined) {
334
- this._pendingFilters.push(item.id);
335
- }
336
- }
337
- return this.normalizeItem(visible ? Object.assign(Object.assign({}, item), { visible }) : Object.assign(Object.assign({}, item), { visible, value: undefined, fixed: undefined }));
338
- }
339
- return item;
340
- }).sort((a, b) => this._filtersComparator(a, b));
341
- }
342
- openDefaultFilterModal() {
343
- const filterModal = document.createElement("snk-filter-modal");
344
- const defaultFilter = this.filterConfig.filter(item => item.type === FilterItemType.DEFAULT_FILTER);
345
- filterModal.getMessage = (key, props) => this.getMessage(key, props);
346
- filterModal.modalTitle = this.getMessage("snkFilterBar.modalDefaultFilterTitle");
347
- filterModal.infoText = this.getMessage(defaultFilter.length == 0 ? "snkFilterBar.modalInfoTextCreateDefault" : "snkFilterBar.modalInfoTextEditDefault");
348
- filterModal.items = defaultFilter.map(item => {
349
- return { id: item.id, active: true, enabled: false, label: item.label };
350
- });
351
- filterModal.processModalAction = (_action) => {
352
- this._application.closeModal();
353
- };
354
- this._application.showModal(filterModal);
355
- }
356
- openPersonalizedModal() {
357
- const filterModal = document.createElement("snk-filter-modal");
358
- const personalizedFilter = this.filterConfig
359
- .filter(item => item.type === FilterItemType.PERSONALIZED)
360
- .sort((itemA, itemB) => StringUtils.compare(itemA.label, itemB.label));
361
- filterModal.getMessage = (key, props) => this.getMessage(key, props);
362
- filterModal.modalTitle = this.getMessage("snkFilterBar.modalPersonalizedFilterTitle");
363
- filterModal.modalSubTitle = this.getMessage("snkFilterBar.modalPersonalizedFilterSubTitle");
364
- filterModal.okButtonLabel = this.getMessage("snkFilterBar.modalOkButtonLabel");
365
- filterModal.cancelButtonLabel = this.getMessage("snkFilterBar.modalCancelButtonLabel");
366
- filterModal.infoText = this.getMessage("snkFilterBar.modalInfoTextCreateEditPersonalized");
367
- filterModal.useSearch = true;
368
- filterModal.items = personalizedFilter.map(item => {
369
- return { id: item.id, active: item.visible, enabled: true, label: item.label };
370
- });
371
- filterModal.processModalAction = (action) => {
372
- if (action === ModalAction.CANCEL) {
373
- // O Botão de cancelar, tem efeito específico:
374
- // - Desmarcar todos os filtros personalizados.
375
- filterModal.items = filterModal.items.map(item => {
376
- return Object.assign(Object.assign({}, item), { active: false });
377
- });
378
- }
379
- else {
380
- if (action === ModalAction.OK) {
381
- this.addPersonalizedFilters(filterModal.items);
382
- }
383
- this._application.closeModal();
384
- }
385
- };
386
- this._application.showModal(filterModal);
387
- }
388
- clearFilters() {
389
- let changed = false;
390
- this.filterConfig = this.filterConfig.map(item => {
391
- if (item.value != undefined) {
392
- changed = true;
393
- }
394
- return Object.assign(Object.assign({}, item), { value: undefined });
395
- }).sort((a, b) => this._filtersComparator(a, b));
396
- return changed;
397
- }
398
324
  loadPermitions() {
399
325
  this._application.isUserSup().then(value => this.allowDefault = value);
400
326
  }
@@ -443,31 +369,17 @@ const SnkFilterBar = class {
443
369
  filterChangeListener(evt) {
444
370
  this.updateFilter(evt.detail);
445
371
  }
446
- addFilterHandler(itemName) {
447
- const filterItem = this.filterConfig.find(currentFilter => currentFilter.id === itemName);
448
- if (itemName === PERSONALIZED_FILTER) {
449
- this.openPersonalizedModal();
450
- }
451
- else if (itemName === DEFAULT_FILTER) {
452
- this.openDefaultFilterModal();
453
- }
454
- else if (filterItem) {
455
- this._pendingFilters.push(itemName);
456
- this.updateFilter(Object.assign(Object.assign({}, filterItem), { visible: true }));
457
- }
458
- }
459
- appliedFilterHandler(itemName) {
460
- if (itemName === CLEAR_ALL_FILTERS) {
461
- if (this.clearFilters()) {
462
- this._application.info(this.getMessage("snkFilterBar.successfullyCleaned"), { iconName: "check" });
463
- }
464
- }
465
- else {
466
- const filterItemElement = this._element.querySelector("#filter-" + itemName);
467
- if (filterItemElement) {
468
- filterItemElement.showUp(true);
469
- }
470
- }
372
+ async showFilterModal() {
373
+ const callbackOnApplyFilter = (filters) => {
374
+ this.filterConfig = filters.map(this.normalizeItem);
375
+ };
376
+ const factoryParams = {
377
+ filterConfig: this.filterConfig,
378
+ onComplete: callbackOnApplyFilter,
379
+ getMessage: (key, props) => this.getMessage(key, props)
380
+ };
381
+ const factory = new SnkFilterModalFactory(factoryParams);
382
+ await factory.showModal();
471
383
  }
472
384
  componentWillLoad() {
473
385
  this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
@@ -484,7 +396,7 @@ const SnkFilterBar = class {
484
396
  if (!this.dataUnit || !this.filterConfig || this.filterConfig.length === 0) {
485
397
  return undefined;
486
398
  }
487
- return (h(Host, null, h("ez-scroller", { direction: EzScrollDirection.HORIZONTAL, activeShadow: true, locked: this.scrollerLocked }, this.getFilterItems()), h("snk-filter-list", { id: APPLIED_FILTERS, onFocusin: () => this.itemFocused(APPLIED_FILTERS), items: this.getAppliedListItems(), getMessage: (key, params) => this.getMessage(key, params), emptyText: this.getMessage("snkFilterBar.emptyAppliedFiltersList"), findFilterText: this.getMessage("snkFilterBar.findFilter"), iconName: "filter", class: "ez-padding-left--medium", buttonClass: this.getActiveClass(), onSnkItemSelected: evt => this.appliedFilterHandler(evt.detail), "data-element-id": "apppliedFilters" }), h("snk-filter-list", { id: ADD_FILTER, onFocusin: () => this.itemFocused(ADD_FILTER), items: this.getAddListItems(), label: this.getMessage("snkFilterBar.addFilter"), getMessage: (key, params) => this.getMessage(key, params), emptyText: this.getMessage("snkFilterBar.emptyFiltersList"), findFilterText: this.getMessage("snkFilterBar.findField"), class: "ez-padding-left--medium", onSnkItemSelected: evt => this.addFilterHandler(evt.detail), "data-element-id": "addFilters" }, h("ez-icon", { slot: "leftIcon", class: "ez-padding-right--small", iconName: "plus" }))));
399
+ return (h(Host, null, h("ez-scroller", { direction: EzScrollDirection.HORIZONTAL, activeShadow: true, locked: this.scrollerLocked }, this.getFilterItems()), h("ez-button", { class: "ez-padding-left--medium", size: "small", label: this.getMessage('snkFilterBar.filters', undefined, 'Filtros'), onClick: this.showFilterModal.bind(this) }, h("ez-icon", { slot: "leftIcon", iconName: "plus", class: "ez-padding-right--small" }))));
488
400
  }
489
401
  get _element() { return getElement(this); }
490
402
  static get watchers() { return {
@@ -1,12 +1,15 @@
1
- import { r as registerInstance, h, H as Host, g as getElement } from './index-cfd4bb13.js';
1
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-cfd4bb13.js';
2
2
  import { ElementIDUtils } from '@sankhyalabs/core';
3
- import { F as FilterItemType } from './filter-item-type.enum-a79b2fa8.js';
3
+ import { F as FilterItemType } from './filter-item-type.enum-5028ed3f.js';
4
+ import { E as EPresentationMode } from './presentationMode-783bbf9d.js';
4
5
 
5
6
  const SnkFilterBinarySelect = class {
6
7
  constructor(hostRef) {
7
8
  registerInstance(this, hostRef);
9
+ this.valueChanged = createEvent(this, "valueChanged", 7);
8
10
  this.value = undefined;
9
11
  this.config = undefined;
12
+ this.presentationMode = EPresentationMode.CHIP;
10
13
  }
11
14
  isSelected(option) {
12
15
  return this.value == undefined || this.value === option;
@@ -41,6 +44,7 @@ const SnkFilterBinarySelect = class {
41
44
  else {
42
45
  this.value = undefined;
43
46
  }
47
+ this.valueChanged.emit(this.value);
44
48
  }
45
49
  /**
46
50
  * Exibe o componente snk-filter-binary-select
@@ -53,6 +57,9 @@ const SnkFilterBinarySelect = class {
53
57
  return undefined;
54
58
  }
55
59
  const [optOne, optTwo] = this.config.props.options;
60
+ if (this.presentationMode === EPresentationMode.MODAL) {
61
+ return (h(Host, null, h("div", { class: "ez-flex ez-flex--row ez-flex--align-items-center" }, h("label", { class: "ez-text ez-text--medium ez-text--primary", style: { flex: '1 1 0', width: '0px' } }, this.config.detailModal), h("ez-check", { compact: true, style: { flex: '1 1 0', width: '0px' }, id: `${this.config.id}_${optOne.name || "option1"}`, label: optOne.label, class: "sc-snk-filter-bar editor__ez-check", ref: (ref) => this._checkOne = ref, value: this.isSelected(optOne.name) }), h("ez-check", { compact: true, style: { flex: '1 1 0', width: '0px' }, id: `${this.config.id}_${optTwo.name || "option2"}`, label: optTwo.label, class: "sc-snk-filter-bar editor__ez-check", ref: (ref) => this._checkTwo = ref, value: this.isSelected(optTwo.name) }))));
62
+ }
56
63
  return (h(Host, null, h("ez-check", { id: `${this.config.id}_${optOne.name || "option1"}`, label: optOne.label, class: "sc-snk-filter-bar editor__ez-check", ref: (ref) => this._checkOne = ref, value: this.isSelected(optOne.name) }), h("ez-check", { id: `${this.config.id}_${optTwo.name || "option2"}`, label: optTwo.label, class: "sc-snk-filter-bar editor__ez-check", ref: (ref) => this._checkTwo = ref, value: this.isSelected(optTwo.name) })));
57
64
  }
58
65
  get _element() { return getElement(this); }
@@ -1,6 +1,6 @@
1
1
  import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-cfd4bb13.js';
2
2
  import { ApplicationUtils } from '@sankhyalabs/ezui/dist/collection/utils';
3
- import { F as FilterItemType } from './filter-item-type.enum-a79b2fa8.js';
3
+ import { F as FilterItemType } from './filter-item-type.enum-5028ed3f.js';
4
4
  import { ElementIDUtils, DataType } from '@sankhyalabs/core';
5
5
 
6
6
  const SnkFilterDetail = class {