@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,241 @@
1
+ import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
2
+ import { UserInterface, ApplicationContext } from '@sankhyalabs/core';
3
+ import { a as SelectedItemType, d as defineCustomElement$2 } from './snk-filter-field-search2.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 { a as FilterOperand } from './index2.js';
7
+ import { s as store } from './index3.js';
8
+ import { d as defineCustomElement$1 } from './snk-filter-param-config2.js';
9
+
10
+ const FilterOperandDefault = [
11
+ { value: FilterOperand.EQUAL, label: "Igual (=)" },
12
+ { value: FilterOperand.DIFFERENT, label: "Diferente (<>)" },
13
+ { value: FilterOperand.LIKE, label: "Contendo (LIKE)" },
14
+ { value: FilterOperand.IN, label: "Contido em (IN)" },
15
+ { value: FilterOperand.START_WITH, label: "Iniciado com (%?)" },
16
+ { value: FilterOperand.FINISHED_WITH, label: "Terminado com (?%)" },
17
+ { value: FilterOperand.NULL, label: "Vazio (NULL)" },
18
+ { value: FilterOperand.NOT_NULL, label: "Não Vazio (NOT NULL)" },
19
+ { value: FilterOperand.LARGER, label: "Maior (>)" },
20
+ { value: FilterOperand.LARGER_EQUAL, label: "Maior ou Igual (>=)" },
21
+ { value: FilterOperand.SMALLER, label: "Menor (<)" },
22
+ { value: FilterOperand.SMALLER_EQUAL, label: "Menor ou Igual (<=)" }
23
+ ];
24
+ const FilterOperandTypeTextSearch = [
25
+ { value: FilterOperand.EQUAL, label: "Igual (=)" },
26
+ { value: FilterOperand.DIFFERENT, label: "Diferente (<>)" },
27
+ { value: FilterOperand.LIKE, label: "Contendo (LIKE)" },
28
+ { value: FilterOperand.IN, label: "Contido em (IN)" },
29
+ { value: FilterOperand.START_WITH, label: "Iniciado com (%?)" },
30
+ { value: FilterOperand.FINISHED_WITH, label: "Terminado com (?%)" },
31
+ { value: FilterOperand.NULL, label: "Vazio (NULL)" },
32
+ { value: FilterOperand.NOT_NULL, label: "Não Vazio (NOT NULL)" }
33
+ ];
34
+ const FIELD_TYPE_SEARCH_AND_TEXT = [
35
+ UserInterface.SEARCH,
36
+ UserInterface.SHORTTEXT,
37
+ UserInterface.PASSWORD,
38
+ UserInterface.MASKEDTEXT,
39
+ UserInterface.LONGTEXT,
40
+ UserInterface.HTML
41
+ ];
42
+
43
+ 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}";
44
+
45
+ const SnkExpressionItem = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
46
+ constructor() {
47
+ super();
48
+ this.__registerHost();
49
+ this.ezFilterItemChange = createEvent(this, "ezFilterItemChange", 7);
50
+ this.ezFilterItemRemove = createEvent(this, "ezFilterItemRemove", 7);
51
+ this.application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
52
+ this.filterOperandDefault = FilterOperandDefault;
53
+ this.filterOperandTypeTextSearch = FilterOperandTypeTextSearch;
54
+ this._showValueVariable = false;
55
+ this._fieldSelected = undefined;
56
+ this._optionNotNull = false;
57
+ this.expression = undefined;
58
+ this.canRemove = true;
59
+ this.messagesBuilder = undefined;
60
+ }
61
+ expressionChanged(newValue, oldValue) {
62
+ if (newValue !== oldValue) {
63
+ this.ezFilterItemChange.emit(newValue);
64
+ }
65
+ }
66
+ componentWillLoad() {
67
+ this._dataSourceFetcher = store.get("filterFieldsDataSource");
68
+ store.onChange('filterFieldsDataSource', () => {
69
+ this._dataSourceFetcher = store.get("filterFieldsDataSource");
70
+ });
71
+ }
72
+ setValueExpression(key, value) {
73
+ this.expression[key] = value;
74
+ this.expressionChanged(this.expression);
75
+ }
76
+ getMessage(key, params) {
77
+ return this.application.messagesBuilder.getMessage(key, params);
78
+ }
79
+ handleSelectItem(filterField) {
80
+ if (filterField.type === SelectedItemType.FIELD) {
81
+ const field = filterField;
82
+ this._fieldSelected = field;
83
+ this.setValueExpression("fieldName", field.name);
84
+ }
85
+ }
86
+ handleFocus() {
87
+ if (this._elFilterFieldSearch)
88
+ this._elFilterFieldSearch.show();
89
+ }
90
+ handleChangeFilterInput(evt) {
91
+ this._elFilterFieldSearch.applyFilter(evt.detail);
92
+ }
93
+ handleChangeValueVariable(showValueVariable) {
94
+ this._showValueVariable = showValueVariable;
95
+ if (this._elFieldDynamic) {
96
+ this._elFieldDynamic.value = undefined;
97
+ this._elFieldDynamic.enabled = !showValueVariable;
98
+ }
99
+ }
100
+ openSnkFilterParamConfig() {
101
+ var _a;
102
+ (_a = this._elFilterParamConfigRef) === null || _a === void 0 ? void 0 : _a.open(this.expression).then(this.onOpenPromiseReady.bind(this)).catch(error => {
103
+ console.error(error);
104
+ });
105
+ }
106
+ onOpenPromiseReady(changes) {
107
+ this.expression = changes;
108
+ }
109
+ buildOptionsOperator() {
110
+ var _a;
111
+ if (FIELD_TYPE_SEARCH_AND_TEXT.includes((_a = this._fieldSelected) === null || _a === void 0 ? void 0 : _a.userInterface)) {
112
+ return this.filterOperandTypeTextSearch;
113
+ }
114
+ else {
115
+ return this.filterOperandDefault;
116
+ }
117
+ }
118
+ handleChangeOperator(optionSelected) {
119
+ this.checkOptionIsNull(optionSelected);
120
+ this.setValueExpression("operand", optionSelected);
121
+ }
122
+ checkOptionIsNull(optionSelected) {
123
+ if (optionSelected === FilterOperand.NULL || optionSelected === FilterOperand.NOT_NULL) {
124
+ this._optionNotNull = true;
125
+ if (this._elFieldDynamic) {
126
+ this._elFieldDynamic.enabled = false;
127
+ this._elFieldDynamic.value = undefined;
128
+ }
129
+ }
130
+ else {
131
+ this._optionNotNull = false;
132
+ if (this._elFieldDynamic) {
133
+ this._elFieldDynamic.enabled = this._showValueVariable ? false : true;
134
+ }
135
+ }
136
+ }
137
+ confirmRemove(evt) {
138
+ evt.preventDefault();
139
+ evt.stopPropagation();
140
+ ApplicationUtils.confirm(this.getMessage("snkPersonalizedFilter.confirm.title"), this.getMessage("snkPersonalizedFilter.confirm.description"))
141
+ .then((canRemove) => {
142
+ if (canRemove) {
143
+ this.ezFilterItemRemove.emit(this.expression);
144
+ }
145
+ });
146
+ }
147
+ buildFieldByType() {
148
+ var _a, _b;
149
+ if (!this._fieldSelected)
150
+ return;
151
+ const inputFieldData = (_a = fieldBuilder(this.configureFieldByType())) === null || _a === void 0 ? void 0 : _a.$children$.shift();
152
+ if (this._optionNotNull && inputFieldData || ((_b = this._elValueVariable) === null || _b === void 0 ? void 0 : _b.value) && inputFieldData) {
153
+ inputFieldData.$attrs$.enabled = false;
154
+ }
155
+ return h(inputFieldData.$tag$, Object.assign(Object.assign({}, inputFieldData.$attrs$), { ref: (el) => {
156
+ this._elFieldDynamic = el;
157
+ } }));
158
+ }
159
+ configureFieldByType() {
160
+ const field = {
161
+ userInterface: this._fieldSelected.userInterface,
162
+ name: this._fieldSelected.name,
163
+ label: this._fieldSelected.label,
164
+ canShowError: false
165
+ };
166
+ switch (field.userInterface) {
167
+ case UserInterface.OPTIONSELECTOR:
168
+ field.props = {
169
+ options: this._fieldSelected.properties.map(option => ({
170
+ value: option.value,
171
+ label: option.name,
172
+ })),
173
+ };
174
+ break;
175
+ case UserInterface.LONGTEXT:
176
+ field.rows = 1;
177
+ break;
178
+ case UserInterface.SEARCH:
179
+ field.optionLoader = searchArgument => this.setCriteriaSearch(searchArgument, this.application);
180
+ break;
181
+ }
182
+ return field;
183
+ }
184
+ setCriteriaSearch({ mode, argument }, application) {
185
+ if (application == undefined)
186
+ return;
187
+ const searchOptions = {
188
+ showInactives: false
189
+ };
190
+ const options = {
191
+ entity: this._fieldSelected.properties.ENTITYNAME,
192
+ searchOptions: searchOptions,
193
+ entityDescription: this._fieldSelected.label
194
+ };
195
+ return application.executePreparedSearch(mode, argument, options);
196
+ }
197
+ render() {
198
+ var _a;
199
+ 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 ?
200
+ h("ez-number-input", { label: "Valor", canShowError: false, enabled: (!this._showValueVariable && !this._optionNotNull) }) :
201
+ this.buildFieldByType()), h("div", { class: "box__container--input-value-variable", title: this.getMessage("snkPersonalizedFilter.info.titleTooltip") }, !this._optionNotNull &&
202
+ 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) &&
203
+ 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) })))))));
204
+ }
205
+ static get watchers() { return {
206
+ "expression": ["expressionChanged"]
207
+ }; }
208
+ static get style() { return snkExpressionItemCss; }
209
+ }, [2, "snk-expression-item", {
210
+ "expression": [16],
211
+ "canRemove": [516, "can-remove"],
212
+ "messagesBuilder": [1040],
213
+ "_showValueVariable": [32],
214
+ "_fieldSelected": [32],
215
+ "_optionNotNull": [32]
216
+ }]);
217
+ function defineCustomElement() {
218
+ if (typeof customElements === "undefined") {
219
+ return;
220
+ }
221
+ const components = ["snk-expression-item", "snk-filter-field-search", "snk-filter-param-config"];
222
+ components.forEach(tagName => { switch (tagName) {
223
+ case "snk-expression-item":
224
+ if (!customElements.get(tagName)) {
225
+ customElements.define(tagName, SnkExpressionItem);
226
+ }
227
+ break;
228
+ case "snk-filter-field-search":
229
+ if (!customElements.get(tagName)) {
230
+ defineCustomElement$2();
231
+ }
232
+ break;
233
+ case "snk-filter-param-config":
234
+ if (!customElements.get(tagName)) {
235
+ defineCustomElement$1();
236
+ }
237
+ break;
238
+ } });
239
+ }
240
+
241
+ export { SnkExpressionItem as S, defineCustomElement as d };
@@ -1,14 +1,12 @@
1
1
  import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
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.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.js';
8
- import { d as defineCustomElement$4 } from './snk-filter-detail2.js';
9
- import { d as defineCustomElement$3 } from './snk-filter-item2.js';
10
- import { d as defineCustomElement$2 } from './snk-filter-list2.js';
11
- import { d as defineCustomElement$1 } from './snk-filter-modal2.js';
5
+ import { toString } from '@sankhyalabs/core/dist/dataunit/metadata/DataType';
6
+ import { F as FilterItemType } from './filter-item-type.enum.js';
7
+ import { ApplicationUtils } from '@sankhyalabs/ezui/dist/collection/utils';
8
+ import { d as defineCustomElement$2 } from './snk-filter-detail2.js';
9
+ import { d as defineCustomElement$1 } from './snk-filter-item2.js';
12
10
 
13
11
  const buildFilter = (item) => {
14
12
  switch (item.type) {
@@ -107,13 +105,43 @@ function buildPersonalized(item) {
107
105
  };
108
106
  }
109
107
 
108
+ class SnkFilterModalFactory {
109
+ constructor({ filterConfig, onComplete, getMessage }) {
110
+ this._filterConfig = filterConfig;
111
+ this._onComplete = onComplete;
112
+ this._getMessage = getMessage;
113
+ }
114
+ applyFilters(newFilterConfig) {
115
+ this._onComplete(newFilterConfig);
116
+ this._closeModal();
117
+ }
118
+ clearAll(filterConfigSnapshot) {
119
+ return filterConfigSnapshot.map(filterItem => (Object.assign(Object.assign({}, filterItem), { value: undefined })));
120
+ }
121
+ buildFilterModal() {
122
+ const filterModal = document.createElement("snk-filter-modal");
123
+ filterModal.filters = this._filterConfig;
124
+ filterModal.getMessage = this._getMessage.bind(this);
125
+ filterModal.applyFilters = this.applyFilters.bind(this);
126
+ filterModal.clearAll = this.clearAll.bind(this);
127
+ filterModal.closeModal = () => this._closeModal();
128
+ return filterModal;
129
+ }
130
+ async showModal() {
131
+ const filterModal = this.buildFilterModal();
132
+ const modalProps = {
133
+ content: filterModal,
134
+ position: 'left',
135
+ heightMode: 'full',
136
+ closeOutsideClick: false,
137
+ useScrimLight: true
138
+ };
139
+ this._closeModal = await ApplicationUtils.showModal(modalProps);
140
+ }
141
+ }
142
+
110
143
  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%}";
111
144
 
112
- const PERSONALIZED_FILTER = "PERSONALIZED_FILTER";
113
- const DEFAULT_FILTER = "DEFAULT_FILTER";
114
- const CLEAR_ALL_FILTERS = "CLEAR_ALL_FILTERS";
115
- const ADD_FILTER = "ADD_FILTER";
116
- const APPLIED_FILTERS = "APPLIED_FILTERS";
117
145
  const SnkFilterBar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
118
146
  constructor() {
119
147
  super();
@@ -202,9 +230,9 @@ const SnkFilterBar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
202
230
  * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
203
231
  * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-filter-bar.msg.ts"
204
232
  */
205
- getMessage(key, params) {
233
+ getMessage(key, params, defaultValue) {
206
234
  var _a;
207
- 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;
208
236
  }
209
237
  getFilter(_dataUnit) {
210
238
  var _a;
@@ -293,110 +321,6 @@ const SnkFilterBar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
293
321
  return item;
294
322
  }).sort((a, b) => this._filtersComparator(a, b));
295
323
  }
296
- getAddListItems() {
297
- const hiddenItems = this.filterConfig
298
- .filter(item => !item.visible && this.isListable(item));
299
- const footerItems = [{ name: PERSONALIZED_FILTER, label: this.getMessage("snkFilterBar.customFilter"), iconName: "tune", kind: "FOOTER" }];
300
- if (this.allowDefault) {
301
- footerItems.push({ name: DEFAULT_FILTER, label: this.getMessage("snkFilterBar.defaultFilter"), iconName: "configuration", kind: "FOOTER" });
302
- }
303
- return hiddenItems.map(filter => { return { name: filter.id, label: filter.label, kind: "FILTER", iconName: null }; })
304
- .concat(footerItems);
305
- }
306
- getActiveClass() {
307
- const filterApplied = this.filterConfig.filter(item => item.value != undefined).length > 0;
308
- return filterApplied ? "sc-snk-filter-bar snk-filter-bar__filter-list-items-button--active" : "";
309
- }
310
- isListable(item, allowPersonalized = false) {
311
- return item.type !== FilterItemType.DEFAULT_FILTER && (allowPersonalized || item.type !== FilterItemType.PERSONALIZED);
312
- }
313
- getAppliedListItems() {
314
- const appliedItems = this.filterConfig
315
- .filter(item => this.isActiveFilter(item) && this.isListable(item, true));
316
- return appliedItems.map(filter => {
317
- return { name: filter.id, label: filter.label, kind: "FILTER", iconName: null };
318
- }).concat([
319
- { name: CLEAR_ALL_FILTERS, label: this.getMessage("snkFilterBar.clearAllFilters"), iconName: "cleaning", kind: "FOOTER" }
320
- ]);
321
- }
322
- addPersonalizedFilters(personalizedItems) {
323
- const activeFilters = {};
324
- personalizedItems.forEach(item => {
325
- if (item.active) {
326
- activeFilters[item.id] = true;
327
- }
328
- });
329
- this.filterConfig = this.filterConfig.map(item => {
330
- var _a, _b;
331
- if (item.type === FilterItemType.PERSONALIZED) {
332
- const visible = activeFilters[item.id];
333
- if (!item.visible && visible) {
334
- this.calculateUpdateSequence(item);
335
- if (((_b = (_a = item.props) === null || _a === void 0 ? void 0 : _a.personalizedFilter) === null || _b === void 0 ? void 0 : _b.parameters) != undefined) {
336
- this._pendingFilters.push(item.id);
337
- }
338
- }
339
- return this.normalizeItem(visible ? Object.assign(Object.assign({}, item), { visible }) : Object.assign(Object.assign({}, item), { visible, value: undefined, fixed: undefined }));
340
- }
341
- return item;
342
- }).sort((a, b) => this._filtersComparator(a, b));
343
- }
344
- openDefaultFilterModal() {
345
- const filterModal = document.createElement("snk-filter-modal");
346
- const defaultFilter = this.filterConfig.filter(item => item.type === FilterItemType.DEFAULT_FILTER);
347
- filterModal.getMessage = (key, props) => this.getMessage(key, props);
348
- filterModal.modalTitle = this.getMessage("snkFilterBar.modalDefaultFilterTitle");
349
- filterModal.infoText = this.getMessage(defaultFilter.length == 0 ? "snkFilterBar.modalInfoTextCreateDefault" : "snkFilterBar.modalInfoTextEditDefault");
350
- filterModal.items = defaultFilter.map(item => {
351
- return { id: item.id, active: true, enabled: false, label: item.label };
352
- });
353
- filterModal.processModalAction = (_action) => {
354
- this._application.closeModal();
355
- };
356
- this._application.showModal(filterModal);
357
- }
358
- openPersonalizedModal() {
359
- const filterModal = document.createElement("snk-filter-modal");
360
- const personalizedFilter = this.filterConfig
361
- .filter(item => item.type === FilterItemType.PERSONALIZED)
362
- .sort((itemA, itemB) => StringUtils.compare(itemA.label, itemB.label));
363
- filterModal.getMessage = (key, props) => this.getMessage(key, props);
364
- filterModal.modalTitle = this.getMessage("snkFilterBar.modalPersonalizedFilterTitle");
365
- filterModal.modalSubTitle = this.getMessage("snkFilterBar.modalPersonalizedFilterSubTitle");
366
- filterModal.okButtonLabel = this.getMessage("snkFilterBar.modalOkButtonLabel");
367
- filterModal.cancelButtonLabel = this.getMessage("snkFilterBar.modalCancelButtonLabel");
368
- filterModal.infoText = this.getMessage("snkFilterBar.modalInfoTextCreateEditPersonalized");
369
- filterModal.useSearch = true;
370
- filterModal.items = personalizedFilter.map(item => {
371
- return { id: item.id, active: item.visible, enabled: true, label: item.label };
372
- });
373
- filterModal.processModalAction = (action) => {
374
- if (action === ModalAction.CANCEL) {
375
- // O Botão de cancelar, tem efeito específico:
376
- // - Desmarcar todos os filtros personalizados.
377
- filterModal.items = filterModal.items.map(item => {
378
- return Object.assign(Object.assign({}, item), { active: false });
379
- });
380
- }
381
- else {
382
- if (action === ModalAction.OK) {
383
- this.addPersonalizedFilters(filterModal.items);
384
- }
385
- this._application.closeModal();
386
- }
387
- };
388
- this._application.showModal(filterModal);
389
- }
390
- clearFilters() {
391
- let changed = false;
392
- this.filterConfig = this.filterConfig.map(item => {
393
- if (item.value != undefined) {
394
- changed = true;
395
- }
396
- return Object.assign(Object.assign({}, item), { value: undefined });
397
- }).sort((a, b) => this._filtersComparator(a, b));
398
- return changed;
399
- }
400
324
  loadPermitions() {
401
325
  this._application.isUserSup().then(value => this.allowDefault = value);
402
326
  }
@@ -445,31 +369,17 @@ const SnkFilterBar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
445
369
  filterChangeListener(evt) {
446
370
  this.updateFilter(evt.detail);
447
371
  }
448
- addFilterHandler(itemName) {
449
- const filterItem = this.filterConfig.find(currentFilter => currentFilter.id === itemName);
450
- if (itemName === PERSONALIZED_FILTER) {
451
- this.openPersonalizedModal();
452
- }
453
- else if (itemName === DEFAULT_FILTER) {
454
- this.openDefaultFilterModal();
455
- }
456
- else if (filterItem) {
457
- this._pendingFilters.push(itemName);
458
- this.updateFilter(Object.assign(Object.assign({}, filterItem), { visible: true }));
459
- }
460
- }
461
- appliedFilterHandler(itemName) {
462
- if (itemName === CLEAR_ALL_FILTERS) {
463
- if (this.clearFilters()) {
464
- this._application.info(this.getMessage("snkFilterBar.successfullyCleaned"), { iconName: "check" });
465
- }
466
- }
467
- else {
468
- const filterItemElement = this._element.querySelector("#filter-" + itemName);
469
- if (filterItemElement) {
470
- filterItemElement.showUp(true);
471
- }
472
- }
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();
473
383
  }
474
384
  componentWillLoad() {
475
385
  this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
@@ -486,7 +396,7 @@ const SnkFilterBar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
486
396
  if (!this.dataUnit || !this.filterConfig || this.filterConfig.length === 0) {
487
397
  return undefined;
488
398
  }
489
- 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" }))));
490
400
  }
491
401
  get _element() { return this; }
492
402
  static get watchers() { return {
@@ -505,7 +415,7 @@ function defineCustomElement() {
505
415
  if (typeof customElements === "undefined") {
506
416
  return;
507
417
  }
508
- const components = ["snk-filter-bar", "snk-filter-detail", "snk-filter-item", "snk-filter-list", "snk-filter-modal"];
418
+ const components = ["snk-filter-bar", "snk-filter-detail", "snk-filter-item"];
509
419
  components.forEach(tagName => { switch (tagName) {
510
420
  case "snk-filter-bar":
511
421
  if (!customElements.get(tagName)) {
@@ -513,21 +423,11 @@ function defineCustomElement() {
513
423
  }
514
424
  break;
515
425
  case "snk-filter-detail":
516
- if (!customElements.get(tagName)) {
517
- defineCustomElement$4();
518
- }
519
- break;
520
- case "snk-filter-item":
521
- if (!customElements.get(tagName)) {
522
- defineCustomElement$3();
523
- }
524
- break;
525
- case "snk-filter-list":
526
426
  if (!customElements.get(tagName)) {
527
427
  defineCustomElement$2();
528
428
  }
529
429
  break;
530
- case "snk-filter-modal":
430
+ case "snk-filter-item":
531
431
  if (!customElements.get(tagName)) {
532
432
  defineCustomElement$1();
533
433
  }
@@ -1,13 +1,16 @@
1
- import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
1
+ import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
2
2
  import { ElementIDUtils } from '@sankhyalabs/core';
3
3
  import { F as FilterItemType } from './filter-item-type.enum.js';
4
+ import { E as EPresentationMode } from './presentationMode.js';
4
5
 
5
6
  const SnkFilterBinarySelect$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
6
7
  constructor() {
7
8
  super();
8
9
  this.__registerHost();
10
+ this.valueChanged = createEvent(this, "valueChanged", 7);
9
11
  this.value = undefined;
10
12
  this.config = undefined;
13
+ this.presentationMode = EPresentationMode.CHIP;
11
14
  }
12
15
  isSelected(option) {
13
16
  return this.value == undefined || this.value === option;
@@ -42,6 +45,7 @@ const SnkFilterBinarySelect$1 = /*@__PURE__*/ proxyCustomElement(class extends H
42
45
  else {
43
46
  this.value = undefined;
44
47
  }
48
+ this.valueChanged.emit(this.value);
45
49
  }
46
50
  /**
47
51
  * Exibe o componente snk-filter-binary-select
@@ -54,12 +58,16 @@ const SnkFilterBinarySelect$1 = /*@__PURE__*/ proxyCustomElement(class extends H
54
58
  return undefined;
55
59
  }
56
60
  const [optOne, optTwo] = this.config.props.options;
61
+ if (this.presentationMode === EPresentationMode.MODAL) {
62
+ 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) }))));
63
+ }
57
64
  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) })));
58
65
  }
59
66
  get _element() { return this; }
60
67
  }, [0, "snk-filter-binary-select", {
61
68
  "value": [1544],
62
69
  "config": [16],
70
+ "presentationMode": [2, "presentation-mode"],
63
71
  "show": [64]
64
72
  }, [[0, "ezChange", "ezChangeListener"]]]);
65
73
  function defineCustomElement$1() {