@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,430 @@
1
+ import { h, r as registerInstance, c as createEvent, g as getElement } from './index-cfd4bb13.js';
2
+ import { S as SelectedItemType } from './index-620ac460.js';
3
+ import { UserInterface, JSUtils, ElementIDUtils, ApplicationContext, StringUtils, DataType } from '@sankhyalabs/core';
4
+ import { ModalAction } from '@sankhyalabs/ezui/dist/collection/components/ez-modal-container';
5
+ import { c as FilterOperand, d as FilterConfigType, e as FilterEntities, F as FilterUserConfigTypes } from './index-507e19ec.js';
6
+
7
+ const ICON_MODES = {
8
+ [UserInterface.SHORTTEXT]: 'text',
9
+ [UserInterface.LONGTEXT]: 'text',
10
+ [UserInterface.INTEGERNUMBER]: 'number',
11
+ [UserInterface.DECIMALNUMBER]: 'number',
12
+ [UserInterface.DATE]: 'calendar',
13
+ [UserInterface.DATETIME]: 'calendar',
14
+ [UserInterface.SWITCH]: 'boolean',
15
+ [UserInterface.CHECKBOX]: 'check-circle-inverted',
16
+ [UserInterface.OPTIONSELECTOR]: 'list',
17
+ [UserInterface.SEARCH]: 'search',
18
+ [UserInterface.HTML]: 'tag_code',
19
+ [UserInterface.IMAGE]: 'png',
20
+ [UserInterface.FILE]: 'edit-file',
21
+ [UserInterface.TIME]: 'timer-outline',
22
+ [UserInterface.ELAPSEDTIME]: 'timer',
23
+ [UserInterface.MASKEDTEXT]: 'text',
24
+ [UserInterface.PASSWORD]: 'email',
25
+ };
26
+ const ListItem = ({ userInterface, description }) => {
27
+ return (h("ez-icon", { iconName: ICON_MODES[userInterface], className: "ez-padding-left--small", title: description }));
28
+ };
29
+
30
+ const snkFilterFieldSearchCss = ".sc-snk-filter-field-search-h{--snk-filter-field-search--container-width:468px;--snk-filter-field-search--container-height:322px}.snk-filter-field-search__container.sc-snk-filter-field-search{display:flex;flex-direction:column;padding:var(--space--medium);width:var(--snk-filter-field-search--container-width);height:var(--snk-filter-field-search--container-height)}.snk-filter-field-search__section.sc-snk-filter-field-search{display:grid;grid-template-columns:1fr 1fr;place-items:flex-start;overflow:hidden;gap:var(--space--small)}.snk-filter-field-search__input.sc-snk-filter-field-search{margin-bottom:var(--space--medium)}.snk-filter-field-search__list_container.sc-snk-filter-field-search{display:flex;flex-direction:column}.snk-filter-field-search__list.sc-snk-filter-field-search{overflow-y:auto}";
31
+
32
+ const SNK_CONTEXT_KEY = "__SNK__APPLICATION__";
33
+ const SnkFilterFieldSearch = class {
34
+ constructor(hostRef) {
35
+ registerInstance(this, hostRef);
36
+ this.ezSelectFilterItem = createEvent(this, "ezSelectFilterItem", 7);
37
+ this._filterMetadataStorage = new Map();
38
+ this._currentMetadata = null;
39
+ this._filterText = "";
40
+ this._isLoading = false;
41
+ this.searchable = true;
42
+ this.fieldsDataSource = undefined;
43
+ this.breadcrumbItems = [];
44
+ this.linkItems = [];
45
+ this.fieldItems = [];
46
+ }
47
+ /**
48
+ * Realiza a abertura do componente e faz a primeira carga
49
+ * de dados.
50
+ * */
51
+ async show() {
52
+ var _a;
53
+ (_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.show();
54
+ return this.loadData();
55
+ }
56
+ /**
57
+ * Filtra a fonte de dados do componente.
58
+ * @param {string} filterText - Texto para filtrar a fonte de dados.
59
+ * @throws {Error} - Quando o componente estiver com a propriedade searchable como true.
60
+ */
61
+ async applyFilter(filterText) {
62
+ if (this.searchable)
63
+ throw new Error('This method is not available when searchable is true');
64
+ this.handleFilterChange(filterText);
65
+ }
66
+ async loadData() {
67
+ this._isLoading = true;
68
+ let metadata;
69
+ if (this._currentLink != undefined) {
70
+ metadata = this._filterMetadataStorage.get(this._currentLink.uri);
71
+ }
72
+ if (!metadata) {
73
+ metadata = await this.fieldsDataSource.fetchData(this._currentLink);
74
+ this._currentLink = metadata.currentLink;
75
+ this._filterMetadataStorage.set(this._currentLink.uri, metadata);
76
+ }
77
+ const { fields, links } = metadata || {};
78
+ if (!Array.isArray(fields) || !Array.isArray(links))
79
+ throw new Error('Invalid metadata');
80
+ this._currentMetadata = metadata;
81
+ this.mapDataSourceToLinkItems();
82
+ this.mapDataSourceToFieldItems();
83
+ this._isLoading = false;
84
+ this._ezFieldList.scrollToTop();
85
+ this._ezLinkList.scrollToTop();
86
+ }
87
+ mapDataSourceToLinkItems() {
88
+ var _a;
89
+ const { links } = this._currentMetadata;
90
+ const filterLinkLabelMessage = this.getMessage('snkFilterFieldSearch.linkLabel', { link: (_a = this._currentLink) === null || _a === void 0 ? void 0 : _a.description });
91
+ const items = links.map(link => (Object.assign({ label: link.description }, link)));
92
+ this.linkItems = [{
93
+ group: filterLinkLabelMessage,
94
+ items,
95
+ }];
96
+ if (this.breadcrumbItems.length === 0) {
97
+ this.breadcrumbItems = [Object.assign({ id: JSUtils.generateUUID(), label: this._currentLink.description }, this._currentLink)];
98
+ }
99
+ }
100
+ mapDataSourceToFieldItems() {
101
+ var _a;
102
+ const { fields } = this._currentMetadata;
103
+ const filterFieldLabelMessage = this.getMessage('snkFilterFieldSearch.fieldLabel', { link: (_a = this._currentLink) === null || _a === void 0 ? void 0 : _a.description });
104
+ const filteredFields = fields.filter(field => {
105
+ if (!this._currentLink)
106
+ return true;
107
+ const searchableByDescription = field.description.toLowerCase().includes(this._filterText.toLowerCase());
108
+ const searchableByName = field.name.toLowerCase().includes(this._filterText.toLowerCase());
109
+ return searchableByDescription || searchableByName;
110
+ });
111
+ const items = filteredFields.map(field => (Object.assign({ label: field.description }, field)));
112
+ this.fieldItems = [{
113
+ group: filterFieldLabelMessage,
114
+ items
115
+ }];
116
+ }
117
+ handleFilterChange(filterText) {
118
+ if (this._isLoading)
119
+ return;
120
+ this._filterText = filterText;
121
+ this.mapDataSourceToFieldItems();
122
+ }
123
+ handleSelectLink({ detail: item }) {
124
+ if (this._isLoading)
125
+ return;
126
+ const breadcrumbByIndex = this.breadcrumbItems.findIndex(breadcrumbItem => breadcrumbItem.id === item.id);
127
+ item.cache = this._filterMetadataStorage.has(item.uri);
128
+ if (breadcrumbByIndex > -1) {
129
+ this.breadcrumbItems = this.breadcrumbItems.slice(0, (breadcrumbByIndex + 1));
130
+ }
131
+ else {
132
+ this.breadcrumbItems = [...this.breadcrumbItems, Object.assign({ id: JSUtils.generateUUID(), label: item.description }, item)];
133
+ }
134
+ const selectedItem = Object.assign(Object.assign({}, item), { type: SelectedItemType.LINK });
135
+ this._currentLink = selectedItem;
136
+ this.ezSelectFilterItem.emit(selectedItem);
137
+ this.loadData();
138
+ }
139
+ handleSelectField({ detail: item }) {
140
+ var _a;
141
+ const breadcrumbPath = this.breadcrumbItems.map(breadcrumbItem => breadcrumbItem.label).join('>>');
142
+ const selectedField = Object.assign(Object.assign({}, item), { type: SelectedItemType.FIELD, path: `${breadcrumbPath} >> ${item.description}` });
143
+ this.ezSelectFilterItem.emit(selectedField);
144
+ (_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.hide();
145
+ }
146
+ getElementID(sufix) {
147
+ return {
148
+ [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: ElementIDUtils.getInternalIDInfo(sufix)
149
+ };
150
+ }
151
+ /**
152
+ * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
153
+ * através de um pequeno modulo na estrutura da aplicação:
154
+ * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
155
+ * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-filter-field-search.msg.ts"
156
+ */
157
+ getMessage(key, params) {
158
+ var _a, _b, _c;
159
+ if (!this._application)
160
+ this._application = ApplicationContext.getContextValue(SNK_CONTEXT_KEY);
161
+ return (_c = (_b = (_a = this._application) === null || _a === void 0 ? void 0 : _a.messagesBuilder) === null || _b === void 0 ? void 0 : _b.getMessage) === null || _c === void 0 ? void 0 : _c.call(_b, key, params);
162
+ }
163
+ ;
164
+ componentWillLoad() {
165
+ this._application = ApplicationContext.getContextValue(SNK_CONTEXT_KEY);
166
+ }
167
+ componentDidLoad() {
168
+ ElementIDUtils.addIDInfoIfNotExists(this._ezPopover, 'popover');
169
+ }
170
+ disconnectedCallback() {
171
+ var _a;
172
+ this._filterMetadataStorage.clear();
173
+ (_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.hide();
174
+ }
175
+ render() {
176
+ var _a;
177
+ const searchLabelMessage = this.getMessage('snkFilterFieldSearch.searchLabel');
178
+ return (h("ez-popover", Object.assign({ ref: (el) => this._ezPopover = el, role: "dialog", overlayType: "none", "aria-hidden": !((_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.opened) }, this.getElementID('EzPopover')), h("div", { class: "snk-filter-field-search__container" }, h("header", { class: "snk-filter-field-search__header" }, this.searchable && !!searchLabelMessage && (h("ez-filter-input", Object.assign({ class: "snk-filter-field-search__input", label: searchLabelMessage, asyncSearch: true, canShowError: false, onEzSearching: (event) => this.handleFilterChange.bind(this)(event.detail), "aria-label": searchLabelMessage, "aria-required": "false", "aria-invalid": "false" }, this.getElementID('EzFilterInput')))), this.breadcrumbItems.length > 0 && (h("ez-breadcrumb", Object.assign({ items: this.breadcrumbItems, onSelectedItem: this.handleSelectLink.bind(this), role: "navigation", "aria-current": "step" }, this.getElementID('EzBreadcrumb')))), h("hr", { class: "ez-divider-horizontal ez-margin-vertical--medium" })), h("section", { class: "snk-filter-field-search__section" }, h("ez-list", Object.assign({ ref: (el) => this._ezLinkList = el, class: "snk-filter-field-search__list", id: "filterLinkList", useGroups: true, dataSource: this.linkItems, onEzSelectItem: this.handleSelectLink.bind(this), hoverFeedback: true, ezSelectable: true, itemSlotBuilder: ({ fieldCount }) => h("ez-badge", { label: fieldCount }), "aria-describedby": "filterLinkLabel" }, this.getElementID('EzListLinks'))), h("ez-list", Object.assign({ ref: (el) => this._ezFieldList = el, class: "snk-filter-field-search__list", id: "filterFieldList", useGroups: true, dataSource: this.fieldItems, onEzSelectItem: this.handleSelectField.bind(this), hoverFeedback: true, ezSelectable: true, itemSlotBuilder: ListItem, "aria-describedby": "filterFieldLabel" }, this.getElementID('EzListFields')))))));
179
+ }
180
+ };
181
+ SnkFilterFieldSearch.style = snkFilterFieldSearchCss;
182
+
183
+ class PersonalizedFilterUtils {
184
+ /**
185
+ * Cria uma expressão de filtro a partir de um IExpressionItem.
186
+ * @param expressionItem - Objeto com os parâmetros necessários para montar a expressão.
187
+ * @returns Retorna a expressão de filtro.
188
+ */
189
+ static buildFilterExpression(expressionItem) {
190
+ if (expressionItem == undefined) {
191
+ return;
192
+ }
193
+ const value = this.buildVariableParameterValue(expressionItem);
194
+ let expression = expressionItem.expression || "";
195
+ switch (expressionItem.operand) {
196
+ case FilterOperand.IN:
197
+ expression += ` ${expressionItem.operand} (${value})`;
198
+ break;
199
+ case FilterOperand.NULL:
200
+ case FilterOperand.NOT_NULL:
201
+ expression += ` IS ${value}`;
202
+ break;
203
+ case FilterOperand.LIKE:
204
+ expression += ` LIKE '%${value}%'`;
205
+ break;
206
+ case FilterOperand.START_WITH:
207
+ expression += ` LIKE '${value}%'`;
208
+ break;
209
+ case FilterOperand.FINISHED_WITH:
210
+ expression += ` LIKE '%${value}'`;
211
+ break;
212
+ default:
213
+ expression += ` ${expressionItem.operand} ${value}`;
214
+ }
215
+ return expression;
216
+ }
217
+ /**
218
+ * Obtém o valor do parâmetro a partir de um IExpressionItem.
219
+ * @param expressionItem - Objeto com os parâmetros necessários para montar a expressão.
220
+ * @returns Retorna o valor do parâmetro.
221
+ */
222
+ static buildVariableParameterValue(expressionItem) {
223
+ if (expressionItem == undefined) {
224
+ return;
225
+ }
226
+ if (expressionItem.systemConfig != undefined) {
227
+ const systemConfig = expressionItem.systemConfig;
228
+ return `?:{entidade=${systemConfig.entity || ""};campo=${systemConfig.fieldName || ""}}`;
229
+ }
230
+ if (expressionItem.userConfig != undefined) {
231
+ const userConfig = expressionItem.userConfig;
232
+ return `?:{desc=${userConfig.description || ""};tipo=${userConfig.type || ""}}`;
233
+ }
234
+ return `?:{entidade=${expressionItem.entityName || ""};campo=${expressionItem.fieldName || ""}}`;
235
+ }
236
+ }
237
+
238
+ const snkFilterParamConfigCss = ":host{--snk-filter-param-config__expression--color:var(--title--primary, #2b3a54);display:flex;position:relative}.snk-filter-param-config__expression{--text-area__input--disabled--color:var(--snk-filter-param-config__expression--color)}";
239
+
240
+ const SnkFilterParamConfig = class {
241
+ constructor(hostRef) {
242
+ registerInstance(this, hostRef);
243
+ this._opened = false;
244
+ this._configType = FilterConfigType.SYSTEM_CONFIG;
245
+ this._expressionItem = undefined;
246
+ this._informedInstance = false;
247
+ this._canSave = false;
248
+ this.messagesBuilder = undefined;
249
+ }
250
+ open(expressionItem) {
251
+ this._opened = true;
252
+ this._expressionItem = expressionItem;
253
+ this.loadValues();
254
+ return new Promise(accept => {
255
+ this._promiseResolver = accept;
256
+ });
257
+ }
258
+ close() {
259
+ this._opened = false;
260
+ return new Promise(accept => {
261
+ this._promiseResolver = accept;
262
+ });
263
+ }
264
+ /**
265
+ * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
266
+ * através de um pequeno modulo na estrutura da aplicação:
267
+ * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
268
+ * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-filter-param-config.msg.ts"
269
+ */
270
+ getMessage(key, params) {
271
+ var _a;
272
+ return (_a = this.messagesBuilder) === null || _a === void 0 ? void 0 : _a.getMessage(key, params);
273
+ }
274
+ getConfigValue(configName, inputName, inputAlias = "") {
275
+ var _a, _b, _c;
276
+ return ((_b = (_a = this._expressionItem) === null || _a === void 0 ? void 0 : _a[configName]) === null || _b === void 0 ? void 0 : _b[inputName])
277
+ || ((_c = this._expressionItem) === null || _c === void 0 ? void 0 : _c[inputAlias || inputName]);
278
+ }
279
+ loadValues() {
280
+ var _a;
281
+ const entityName = this.getConfigValue("systemConfig", "entity", "entityName");
282
+ const fieldName = this.getConfigValue("systemConfig", "fieldName");
283
+ const description = this.getConfigValue("userConfig", "description");
284
+ const type = this.getConfigValue("userConfig", "type");
285
+ if (((_a = this._expressionItem) === null || _a === void 0 ? void 0 : _a.userConfig) != undefined) {
286
+ this._configType = FilterConfigType.USER_CONFIG;
287
+ }
288
+ else {
289
+ this._configType = FilterConfigType.SYSTEM_CONFIG;
290
+ }
291
+ if (!StringUtils.isEmpty(entityName) && !StringUtils.isEmpty(fieldName)) {
292
+ this._instanceElement.value = { value: entityName, label: "" };
293
+ this._fieldElement.value = { value: fieldName, label: "" };
294
+ }
295
+ if (!StringUtils.isEmpty(description) && !StringUtils.isEmpty(type)) {
296
+ this._descriptionElement.value = description;
297
+ this._typeElement.value = type;
298
+ }
299
+ this.buildFilterExpression();
300
+ }
301
+ changeDefinitionUsed(option) {
302
+ this._configType = option !== null && option !== void 0 ? option : FilterConfigType.SYSTEM_CONFIG;
303
+ if (this._configType === FilterConfigType.SYSTEM_CONFIG) {
304
+ const entityName = this.getConfigValue("systemConfig", "entity", "entityName");
305
+ const fieldName = this.getConfigValue("systemConfig", "fieldName");
306
+ this._instanceElement.value = this._instanceElement.value || { value: entityName, label: "" };
307
+ this._fieldElement.value = this._fieldElement.value || { value: fieldName, label: "" };
308
+ }
309
+ else if (this._configType === FilterConfigType.USER_CONFIG) {
310
+ const description = this.getConfigValue("userConfig", "description");
311
+ const type = this.getConfigValue("userConfig", "type");
312
+ this._descriptionElement.value = this._descriptionElement.value || description;
313
+ this._typeElement.value = this._typeElement.value || type;
314
+ }
315
+ this.buildFilterExpression();
316
+ }
317
+ getTypeValue() {
318
+ var _a;
319
+ const value = (_a = this._typeElement) === null || _a === void 0 ? void 0 : _a.value;
320
+ return ((value === null || value === void 0 ? void 0 : value.value) || value);
321
+ }
322
+ getExpressionValues() {
323
+ var _a, _b, _c, _d, _e;
324
+ let systemConfig;
325
+ let userConfig;
326
+ if (this._configType === FilterConfigType.SYSTEM_CONFIG) {
327
+ const entity = (_b = (_a = this._instanceElement) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.value;
328
+ const fieldName = (_d = (_c = this._fieldElement) === null || _c === void 0 ? void 0 : _c.value) === null || _d === void 0 ? void 0 : _d.value;
329
+ systemConfig = { entity, fieldName };
330
+ }
331
+ else if (this._configType === FilterConfigType.USER_CONFIG) {
332
+ const description = (_e = this._descriptionElement) === null || _e === void 0 ? void 0 : _e.value;
333
+ const type = this.getTypeValue();
334
+ userConfig = { description, type };
335
+ }
336
+ return Object.assign(Object.assign(Object.assign({}, this._expressionItem), { systemConfig }), { userConfig });
337
+ }
338
+ isEnabled(value) {
339
+ return this._configType === value;
340
+ }
341
+ isInformedInstance() {
342
+ var _a, _b;
343
+ return !StringUtils.isEmpty((_b = (_a = this._instanceElement) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.value);
344
+ }
345
+ save() {
346
+ var _a;
347
+ this._expressionItem = Object.assign(Object.assign({}, this.getExpressionValues()), { expression: (_a = this._expressionElement) === null || _a === void 0 ? void 0 : _a.value });
348
+ this._promiseResolver(this._expressionItem);
349
+ this._opened = false;
350
+ }
351
+ buildFilterExpression() {
352
+ var _a;
353
+ this._informedInstance = this.isInformedInstance();
354
+ const expression = PersonalizedFilterUtils.buildFilterExpression(this.getExpressionValues());
355
+ this._expressionElement.value = expression || ((_a = this._expressionItem) === null || _a === void 0 ? void 0 : _a.expression);
356
+ this._canSave = this.getCanSave();
357
+ }
358
+ handleChangeInstance() {
359
+ this._informedInstance = this.isInformedInstance();
360
+ if (this._fieldElement != undefined && !StringUtils.isEmpty(this._fieldElement.value)) {
361
+ this._fieldElement.value = null;
362
+ }
363
+ this.buildFilterExpression();
364
+ }
365
+ getInstanceCriteria() {
366
+ var _a, _b;
367
+ const value = (_b = (_a = this._instanceElement) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.value;
368
+ return {
369
+ expression: "this.NOMETAB = (SELECT NOMETAB FROM TDDINS WHERE NOMEINSTANCIA = ?)",
370
+ params: [
371
+ {
372
+ name: "NOMEINSTANCIA",
373
+ dataType: DataType.TEXT,
374
+ value
375
+ }
376
+ ]
377
+ };
378
+ }
379
+ onSearch({ mode, argument }, entity) {
380
+ if (this._application == undefined) {
381
+ return;
382
+ }
383
+ const isField = entity === FilterEntities.FIELD;
384
+ const criteria = isField ? this.getInstanceCriteria() : undefined;
385
+ const messageKey = `snkFilterParamConfig.label${isField ? "Field" : "Instance"}`;
386
+ const entityDescription = this.getMessage(messageKey);
387
+ const searchOptions = {
388
+ descriptionFieldName: isField ? "DESCRCAMPO" : "DESCRINSTANCIA",
389
+ codeFieldName: isField ? "NOMECAMPO" : "NOMEINSTANCIA",
390
+ showInactives: false
391
+ };
392
+ const options = {
393
+ entity,
394
+ entityDescription,
395
+ criteria,
396
+ searchOptions
397
+ };
398
+ return this._application.executePreparedSearch(mode, argument, options);
399
+ }
400
+ getElementID(sufix) {
401
+ return {
402
+ [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: ElementIDUtils.getInternalIDInfo(sufix)
403
+ };
404
+ }
405
+ getCanSave() {
406
+ var _a;
407
+ if (this._configType === FilterConfigType.USER_CONFIG) {
408
+ const description = (_a = this._descriptionElement) === null || _a === void 0 ? void 0 : _a.value;
409
+ const type = this.getTypeValue();
410
+ return !StringUtils.isEmpty(description) && !StringUtils.isEmpty(type);
411
+ }
412
+ return true;
413
+ }
414
+ componentWillLoad() {
415
+ this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
416
+ }
417
+ render() {
418
+ ElementIDUtils.addIDInfoIfNotExists(this._element, 'snkFilterParamConfig');
419
+ return (h("ez-popup", Object.assign({ useHeader: false, size: "small", heightMode: "auto", opened: this._opened }, this.getElementID("popup")), h("ez-modal-container", Object.assign({ onEzModalAction: (evt) => {
420
+ if (evt.detail === ModalAction.CLOSE)
421
+ this.close();
422
+ }, modalTitle: this.getMessage("snkFilterParamConfig.modalTitle") }, this.getElementID("modalContainer")), h("div", { class: "ez-flex" }, h("div", { class: "ez-col ez-col--sd-6 ez-flex--column" }, h("ez-radio-button", Object.assign({ value: this._configType, onEzChange: (evt) => this.changeDefinitionUsed(evt.detail) }, this.getElementID("systemConfigOption")), h("ez-radio-button-option", { label: this.getMessage("snkFilterParamConfig.labelSystemConfig"), value: FilterConfigType.SYSTEM_CONFIG })), h("ez-search", Object.assign({ ref: (ref) => this._instanceElement = ref, label: this.getMessage("snkFilterParamConfig.labelInstance"), enabled: this.isEnabled(FilterConfigType.SYSTEM_CONFIG), suppressEmptyOption: true, showOptionValue: false, showSelectedValue: false, onEzChange: () => this.handleChangeInstance(), optionLoader: (searchArgument) => this.onSearch(searchArgument, FilterEntities.INSTANCE) }, this.getElementID("configFindEntity"))), h("ez-search", Object.assign({ ref: (ref) => this._fieldElement = ref, label: this.getMessage("snkFilterParamConfig.labelField"), enabled: this.isEnabled(FilterConfigType.SYSTEM_CONFIG) && this._informedInstance, suppressEmptyOption: true, showOptionValue: false, showSelectedValue: false, onEzChange: () => this.buildFilterExpression(), optionLoader: (searchArgument) => this.onSearch(searchArgument, FilterEntities.FIELD) }, this.getElementID("configFindField")))), h("div", { class: "ez-flex ez-padding--medium" }, h("hr", { class: "ez-divider-vertical" })), h("div", { class: "ez-col ez-col--sd-6 ez-flex--column" }, h("ez-radio-button", Object.assign({ value: this._configType, onEzChange: (evt) => this.changeDefinitionUsed(evt.detail) }, this.getElementID("userConfigOption")), h("ez-radio-button-option", { label: this.getMessage("snkFilterParamConfig.labelUserConfig"), value: FilterConfigType.USER_CONFIG })), h("ez-text-input", Object.assign({ ref: (ref) => this._descriptionElement = ref, label: this.getMessage("snkFilterParamConfig.labelDescription"), enabled: this.isEnabled(FilterConfigType.USER_CONFIG), onEzChange: () => this.buildFilterExpression() }, this.getElementID("configParamLabel"))), h("ez-combo-box", Object.assign({ ref: (ref) => this._typeElement = ref, label: this.getMessage("snkFilterParamConfig.labelType"), enabled: this.isEnabled(FilterConfigType.USER_CONFIG), suppressEmptyOption: true, onEzChange: () => this.buildFilterExpression() }, this.getElementID("configParamType")), Object.keys(FilterUserConfigTypes).map((configType) => {
423
+ return (h("option", { value: FilterUserConfigTypes[configType] }, this.getMessage(`snkFilterParamConfig.labelTypeValues.${configType.toLowerCase()}`)));
424
+ })))), h("ez-text-area", Object.assign({ ref: (ref) => this._expressionElement = ref, class: "snk-filter-param-config__expression", label: this.getMessage("snkFilterParamConfig.labelExpression"), enabled: false }, this.getElementID("presentationExpression"))), h("div", { class: "ez-col ez-col--sd-12 ez-flex--justify-end ez-margin-vertical--small" }, h("ez-button", Object.assign({ class: "ez-padding-right--medium", label: this.getMessage("snkFilterParamConfig.labelCancel"), onClick: () => this.close() }, this.getElementID("cancelEditParam"))), h("ez-button", Object.assign({ class: "ez-button--primary", label: this.getMessage("snkFilterParamConfig.labelSave"), onClick: () => this.save(), enabled: this._canSave }, this.getElementID("saveEditParam")))))));
425
+ }
426
+ get _element() { return getElement(this); }
427
+ };
428
+ SnkFilterParamConfig.style = snkFilterParamConfigCss;
429
+
430
+ export { SnkFilterFieldSearch as snk_filter_field_search, SnkFilterParamConfig as snk_filter_param_config };
@@ -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 { FloatingManager, 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
4
 
5
5
  const SnkFilterItem = class {
6
6
  constructor(hostRef) {
@@ -0,0 +1,62 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-cfd4bb13.js';
2
+ import { ElementIDUtils } from '@sankhyalabs/core';
3
+ import { F as FilterItemType } from './filter-item-type.enum-5028ed3f.js';
4
+ import { F as FilterType } from './filter-type.enum-a80c1b6b.js';
5
+ import { E as EPresentationMode } from './presentationMode-783bbf9d.js';
6
+
7
+ const snkFilterModalItemCss = ".grow{flex-grow:1}";
8
+
9
+ const SnkFilterModalItem = class {
10
+ constructor(hostRef) {
11
+ registerInstance(this, hostRef);
12
+ this.filterChange = createEvent(this, "filterChange", 7);
13
+ this.filterItem = undefined;
14
+ }
15
+ observeFilterItem(newValue) {
16
+ this.filterChange.emit(newValue);
17
+ }
18
+ getContentEditorConfig() {
19
+ const variations = { presentationMode: EPresentationMode.MODAL };
20
+ switch (this.filterItem.type) {
21
+ case FilterItemType.BINARY_SELECT:
22
+ return { tag: "snk-filter-binary-select", variations };
23
+ case FilterItemType.MULTI_SELECT:
24
+ return { tag: "snk-filter-multi-select" };
25
+ case FilterItemType.PERIOD:
26
+ return { tag: "snk-filter-period", variations };
27
+ case FilterItemType.SEARCH:
28
+ return { tag: "snk-filter-search" };
29
+ case FilterItemType.NUMBER:
30
+ return { tag: "snk-filter-number" };
31
+ case FilterItemType.PERSONALIZED:
32
+ return { tag: "snk-filter-personalized" };
33
+ case FilterItemType.MULTI_LIST:
34
+ return { tag: "snk-entity-list" };
35
+ }
36
+ return { tag: "snk-filter-text" };
37
+ }
38
+ updateFilterValue(newValue) {
39
+ this.filterItem = Object.assign(Object.assign({}, this.filterItem), { value: newValue });
40
+ }
41
+ canShowDetailModal() {
42
+ return this.filterItem.filterType !== FilterType.OTHER_FILTERS && this.filterItem.type !== FilterItemType.BINARY_SELECT;
43
+ }
44
+ componentDidLoad() {
45
+ if (this._element) {
46
+ ElementIDUtils.addIDInfo(this._element);
47
+ const dataElementIdDoFilterItem = this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME);
48
+ this._idContentEditor = `${dataElementIdDoFilterItem}_${this.filterItem.id}`;
49
+ }
50
+ }
51
+ render() {
52
+ const { tag: ContentEditor, variations } = this.getContentEditorConfig();
53
+ return (h(Host, null, h("div", { class: "ez-flex ez-flex--column grow" }, this.canShowDetailModal() && (h("div", { class: "col ez-col--sd-12 ez-align--right ez-padding-medium ez-flex--align-items-center" }, h("div", { class: "ez-text ez-title ez-title--small ez-padding--small sc-snk-filter-bar snk-filter-item__editor-header" }, this.filterItem.detailModal))), h(ContentEditor, Object.assign({ config: this.filterItem, value: this.filterItem.value, onValueChanged: (event) => this.updateFilterValue(event.detail), "data-element-id": this._idContentEditor }, variations)))));
54
+ }
55
+ get _element() { return getElement(this); }
56
+ static get watchers() { return {
57
+ "filterItem": ["observeFilterItem"]
58
+ }; }
59
+ };
60
+ SnkFilterModalItem.style = snkFilterModalItemCss;
61
+
62
+ export { SnkFilterModalItem as snk_filter_modal_item };
@@ -1,70 +1,93 @@
1
1
  import { r as registerInstance, h } from './index-cfd4bb13.js';
2
- import { ModalAction, ModalButtonStatus } from '@sankhyalabs/ezui/dist/collection/components/ez-modal-container';
3
- import { ArrayUtils } from '@sankhyalabs/core';
4
- import { CheckMode } from '@sankhyalabs/ezui/dist/collection/utils';
2
+ import { ModalAction } from '@sankhyalabs/ezui/dist/collection/components/ez-modal-container';
3
+ import { F as FilterType } from './filter-type.enum-a80c1b6b.js';
4
+ import { F as FilterItemType } from './filter-item-type.enum-5028ed3f.js';
5
5
 
6
- const snkFilterModalCss = ".snk-filter__modal-container{width:359px;max-width:359px}";
6
+ const snkFilterModalCss = "ez-modal{--ez-modal-content-padding:24px 12px}.snk-filter__modal-container{width:344px;max-width:344px;overflow:hidden}.snk-filter__modal-content{display:flex;flex-direction:column;gap:12px;max-height:760px;overflow-x:clip;overflow-y:auto;padding-right:4px}.snk-filter__modal-content::-webkit-scrollbar{width:var(--space--small);min-width:var(--space--small);max-width:var(--space--small)}.snk-filter__modal-collapsible-box{border:1px solid #DCE0E8;border-radius:var(--border--radius-medium)}";
7
7
 
8
8
  const SnkFilterModal = class {
9
9
  constructor(hostRef) {
10
10
  registerInstance(this, hostRef);
11
- this._filterArgument = undefined;
12
11
  this.getMessage = undefined;
13
- this.items = undefined;
14
- this.modalTitle = undefined;
15
- this.modalSubTitle = undefined;
16
- this.cancelButtonLabel = undefined;
17
- this.okButtonLabel = undefined;
18
- this.infoText = undefined;
19
- this.useSearch = undefined;
20
- this.processModalAction = undefined;
12
+ this.filters = undefined;
13
+ this.applyFilters = undefined;
14
+ this.clearAll = undefined;
15
+ this.closeModal = undefined;
21
16
  }
22
- updateValue(id, value = undefined) {
23
- this.items = this.items.map(item => {
24
- if (item.id === id && item.enabled) {
25
- if (value == undefined) {
26
- value = !item.active;
27
- }
28
- return Object.assign(Object.assign({}, item), { active: value });
29
- }
30
- return item;
31
- });
17
+ getCustomMessage(key, params) {
18
+ var _a;
19
+ return (_a = this.getMessage) === null || _a === void 0 ? void 0 : _a.call(this, `snkFilterBar.filterModal.${key}`, params);
20
+ }
21
+ handleClearAll() {
22
+ const cleanedFilters = this.clearAll(this.filters);
23
+ this.filters = cleanedFilters;
32
24
  }
33
- getActiveFiltersMsg() {
34
- const activeFilters = this.items.filter(item => item.active).length;
35
- if (activeFilters === 0) {
36
- return this.getMessage("snkFilterBar.noActiveFilters");
25
+ modalActionListener(evt) {
26
+ const modalAction = evt.detail;
27
+ switch (modalAction) {
28
+ case ModalAction.CANCEL:
29
+ this.handleClearAll();
30
+ break;
31
+ case ModalAction.OK:
32
+ this.applyFilters(this.filters);
33
+ case ModalAction.CLOSE:
34
+ this.closeModal();
37
35
  }
38
- return this.getMessage(activeFilters > 1 ? "snkFilterBar.activeFilters" : "snkFilterBar.activeFilter", { ACTIVE_FILTERS: activeFilters });
39
36
  }
40
- buildItems(list) {
41
- return list.map(item => {
42
- return (h("button", { onClick: () => this.updateValue(item.id), class: "ez-padding--medium sc-snk-filter-bar snk-filter-bar__filter-modal-item ez-align--middle ez-margin-bottom--small" }, h("ez-check", { id: `checkbox_${item.id}`, tabIndex: -1, class: "sc-snk-filter-bar snk-filter-bar__filter-modal-item__check", onEzChange: evt => this.updateValue(item.id, evt.detail), enabled: item.enabled, value: item.active, mode: CheckMode.SWITCH }), h("div", { class: "ez-text ez-title--primary ez-text--medium ez-margin-left--medium sc-snk-filter-bar snk-filter-bar__filter-modal-item__label" }, item.label)));
43
- });
37
+ handleFilterChange(filterConfig) {
38
+ this.filters = this.filters.map(filter => filter.id === filterConfig.id ? filterConfig : filter);
44
39
  }
45
- itemKeyBoardSelect(event, item) {
46
- if (event.key === "Enter" || event.key === " ") {
47
- this.updateValue(item.id);
48
- }
40
+ handleClearFilters(filterList) {
41
+ this.filters = this.filters.map(filter => filterList.includes(filter) ? (Object.assign(Object.assign({}, filter), { value: undefined })) : filter);
49
42
  }
50
- modalActionListener(evt) {
51
- const modalAction = evt.detail;
52
- if (modalAction === ModalAction.LOAD) {
53
- if (this._filterInput) {
54
- this._filterInput.setFocus();
43
+ renderFilterItem(filterItem, fullRow) {
44
+ return (h("snk-filter-modal-item", { class: fullRow ? 'ez-col ez-col--sd-12' : 'ez-col ez-col--sd-6 ez-padding--small', filterItem: filterItem, onFilterChange: (event) => this.handleFilterChange(event.detail) }));
45
+ }
46
+ mountFiltersLines(filters) {
47
+ const MAX_LINE_LENGTH = 2;
48
+ let currentLine = 0;
49
+ let forceAddCurrent = false;
50
+ const filtersLines = {};
51
+ for (let curr = 0; curr < filters.length; curr++) {
52
+ filtersLines[currentLine] = filtersLines[currentLine] || [];
53
+ const item = filters[curr];
54
+ const isLast = curr === filters.length - 1;
55
+ const currentItemMatch = [FilterItemType.TEXT, FilterItemType.NUMBER].includes(item.type);
56
+ const nextItemMatch = isLast ? false : [FilterItemType.TEXT, FilterItemType.NUMBER].includes(filters[curr + 1].type);
57
+ if ((currentItemMatch && nextItemMatch) || forceAddCurrent) {
58
+ filtersLines[currentLine].push(item);
59
+ forceAddCurrent = filtersLines[currentLine].length < MAX_LINE_LENGTH;
60
+ if (filtersLines[currentLine].length === MAX_LINE_LENGTH)
61
+ ++currentLine;
62
+ continue;
55
63
  }
64
+ filtersLines[currentLine] = filtersLines[currentLine] || [];
65
+ filtersLines[currentLine].push(item);
66
+ ++currentLine;
56
67
  }
57
- else {
58
- this.processModalAction(modalAction);
59
- }
68
+ return Object.values(filtersLines);
69
+ }
70
+ renderFilterLine(filters) {
71
+ const fullLine = filters.length === 1;
72
+ return (h("div", { class: "ez-row" }, filters.map((filter) => this.renderFilterItem(filter, fullLine))));
73
+ }
74
+ renderCollapsibleFilterBox(label, listItems) {
75
+ if (!listItems.length)
76
+ return null;
77
+ const appliedFilters = listItems.filter(filterItem => !!filterItem.value).length;
78
+ const lines = this.mountFiltersLines(listItems);
79
+ return (h("ez-collapsible-box", { className: "snk-filter__modal-collapsible-box ez-padding--medium", headerSize: "medium", value: true, label: label }, !!appliedFilters && (h("ez-badge", { className: "ez-badge--primary-subtle", slot: "rightSlot", label: appliedFilters })), lines.map(this.renderFilterLine.bind(this)), h("div", { class: "ez-flex ez-flex--justify-end grow" }, h("ez-button", { className: "ez-button--tertiary", size: "medium", label: "Limpar", onClick: () => this.handleClearFilters(listItems) }))));
80
+ }
81
+ componentWillRender() {
82
+ this._modalTitle = this.getCustomMessage('title');
83
+ this._okButtonLabel = this.getCustomMessage('okButtonLabel');
84
+ this._cancelButtonLabel = this.getCustomMessage('cancelButtonLabel');
60
85
  }
61
86
  render() {
62
- const allowCancel = this.items.filter(item => item.active).length > 0;
63
- const items = (this.items ? ArrayUtils.applyStringFilter(this._filterArgument, this.items) : []);
64
- return (h("ez-modal-container", { class: "snk-filter__modal-container", modalTitle: this.modalTitle, modalSubTitle: this.modalSubTitle, cancelButtonLabel: this.cancelButtonLabel, okButtonLabel: this.okButtonLabel, onEzModalAction: evt => this.modalActionListener(evt), cancelButtonStatus: allowCancel ? ModalButtonStatus.ENABLED : ModalButtonStatus.DISABLED }, h("div", { class: "sc-snk-filter-bar snk-filter-bar__filter-modal-content" }, h("div", null, this.useSearch ?
65
- h("ez-filter-input", { ref: ref => this._filterInput = ref, label: this.getMessage("snkFilterBar.modalFindFilter"), onEzChange: (evt) => this._filterArgument = evt.detail })
66
- :
67
- undefined), items.length > 0 ? h("div", { class: "ez-text ez-text--medium ez-text--primary ez-padding-bottom--small" }, this.getActiveFiltersMsg()) : undefined, h("div", null, this.buildItems(items)), h("div", { class: "ez-text ez-text--large ez-align--middle ez-text--secondary ez-text--center ez-padding-bottom--large" }, this.infoText))));
87
+ const customFilters = this.filters.filter(filter => filter.filterType === FilterType.CUSTOM_FILTER);
88
+ const quickFilters = this.filters.filter(filter => filter.filterType === FilterType.QUICK_FILTER);
89
+ const otherFilters = this.filters.filter(filter => filter.filterType === FilterType.OTHER_FILTERS);
90
+ return (h("ez-modal-container", { class: "snk-filter__modal-container", modalTitle: this._modalTitle, cancelButtonLabel: this._cancelButtonLabel, okButtonLabel: this._okButtonLabel, onEzModalAction: this.modalActionListener.bind(this) }, h("div", { class: "snk-filter__modal-content" }, this.renderCollapsibleFilterBox(this.getCustomMessage('customFilters'), customFilters), this.renderCollapsibleFilterBox(this.getCustomMessage('quickFilters'), quickFilters), otherFilters.map(filter => this.renderCollapsibleFilterBox(filter.label, [filter])))));
68
91
  }
69
92
  };
70
93
  SnkFilterModal.style = snkFilterModalCss;