@sankhyalabs/sankhyablocks 8.15.0-rc.1 → 8.15.0-rc.10

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 (216) hide show
  1. package/dist/cjs/{ConfigStorage-302bbbd4.js → ConfigStorage-34be11ce.js} +70 -7
  2. package/dist/cjs/{DataFetcher-ba94ed5b.js → DataFetcher-99f0f6ed.js} +5 -3
  3. package/dist/cjs/{SnkFormConfigManager-71c4768e.js → SnkFormConfigManager-6211fb28.js} +7 -2
  4. package/dist/cjs/{SnkMessageBuilder-e7dcf408.js → SnkMessageBuilder-141aa18d.js} +2 -1
  5. package/dist/cjs/SnkMultiSelectionListDataSource-5213120b.js +140 -0
  6. package/dist/cjs/{auth-fetcher-c8467c07.js → auth-fetcher-5161d082.js} +1 -1
  7. package/dist/cjs/{form-config-fetcher-df043d3d.js → form-config-fetcher-9f1a13ca.js} +1 -1
  8. package/dist/cjs/index-f9e81701.js +2 -10
  9. package/dist/cjs/loader.cjs.js +1 -1
  10. package/dist/cjs/{pesquisa-fetcher-e4a7c4c3.js → pesquisa-fetcher-94f6b316.js} +235 -24
  11. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  12. package/dist/cjs/{snk-actions-button_2.cjs.entry.js → snk-actions-button_4.cjs.entry.js} +520 -5
  13. package/dist/cjs/snk-application.cjs.entry.js +34 -8
  14. package/dist/cjs/snk-attach.cjs.entry.js +7 -8
  15. package/dist/cjs/snk-crud.cjs.entry.js +16 -10
  16. package/dist/cjs/snk-data-exporter.cjs.entry.js +8 -4
  17. package/dist/cjs/{snk-data-unit-82c08a8c.js → snk-data-unit-6026a9f7.js} +1 -1
  18. package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
  19. package/dist/cjs/snk-detail-view.cjs.entry.js +9 -10
  20. package/dist/cjs/snk-entity-list.cjs.entry.js +5 -3
  21. package/dist/cjs/snk-filter-bar.cjs.entry.js +36 -7
  22. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  23. package/dist/cjs/snk-form-config.cjs.entry.js +47 -27
  24. package/dist/cjs/snk-form.cjs.entry.js +11 -4
  25. package/dist/cjs/snk-grid.cjs.entry.js +40 -22
  26. package/dist/cjs/{snk-guides-viewer-d32c096f.js → snk-guides-viewer-508bb6fe.js} +15 -9
  27. package/dist/cjs/snk-guides-viewer.cjs.entry.js +7 -8
  28. package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +3 -1
  29. package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
  30. package/dist/cjs/snk-simple-crud.cjs.entry.js +214 -23
  31. package/dist/cjs/snk-taskbar.cjs.entry.js +100 -14
  32. package/dist/cjs/{taskbar-elements-01b85b99.js → taskbar-elements-3ecd1278.js} +9 -9
  33. package/dist/collection/collection-manifest.json +6 -6
  34. package/dist/collection/components/snk-application/__mocks__/snk-application.js +7 -0
  35. package/dist/collection/components/snk-application/snk-application.js +51 -11
  36. package/dist/collection/components/snk-crud/snk-crud.js +95 -3
  37. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +2 -2
  38. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.css +11 -2
  39. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +27 -3
  40. package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +5 -1
  41. package/dist/collection/components/snk-entity-list/snk-entity-list.js +5 -3
  42. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.js +3 -1
  43. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +23 -1
  44. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +116 -4
  45. package/dist/collection/components/snk-form/snk-form.js +25 -1
  46. package/dist/collection/components/{snk-form → snk-form-config}/SnkFormConfigManager.js +6 -1
  47. package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.js +50 -30
  48. package/dist/collection/components/snk-grid/snk-grid.js +103 -16
  49. package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.js +130 -123
  50. package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.js +1 -1
  51. package/dist/collection/components/snk-simple-crud/regular-buttons.js +3 -0
  52. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +5 -0
  53. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +325 -17
  54. package/dist/collection/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.js +1 -1
  55. package/dist/collection/components/snk-taskbar/elements/taskbar-elements.js +9 -9
  56. package/dist/collection/components/snk-taskbar/snk-taskbar.css +17 -0
  57. package/dist/collection/components/snk-taskbar/snk-taskbar.js +139 -13
  58. package/dist/collection/lib/configs/ConfigStorage.js +63 -3
  59. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +5 -3
  60. package/dist/collection/lib/http/data-fetcher/fetchers/parameters-fecher.js +21 -0
  61. package/dist/collection/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.js +6 -3
  62. package/dist/collection/lib/http/data-fetcher/fetchers/pesquisa-fetcher.js +4 -11
  63. package/dist/collection/lib/message/resources/snk-data-exporter.msg.js +2 -1
  64. package/dist/collection/lib/utils/CrudUtils.js +13 -1
  65. package/dist/components/ConfigStorage.js +68 -5
  66. package/dist/components/DataFetcher.js +5 -3
  67. package/dist/components/SnkFormConfigManager.js +5 -0
  68. package/dist/components/SnkMessageBuilder.js +2 -1
  69. package/dist/components/dataunit-fetcher.js +4 -11
  70. package/dist/components/field-search.js +93 -3
  71. package/dist/components/index.d.ts +6 -6
  72. package/dist/components/snk-application2.js +30 -1
  73. package/dist/components/snk-attach2.js +54 -12
  74. package/dist/components/snk-crud.js +15 -3
  75. package/dist/components/snk-data-exporter2.js +5 -1
  76. package/dist/components/snk-detail-view2.js +40 -7
  77. package/dist/components/snk-entity-list.js +5 -3
  78. package/dist/components/snk-filter-bar2.js +38 -5
  79. package/dist/components/snk-form-config2.js +46 -26
  80. package/dist/components/snk-form.js +8 -0
  81. package/dist/components/snk-grid-config2.js +128 -102
  82. package/dist/components/snk-grid2.js +41 -17
  83. package/dist/components/snk-personalized-filter-editor.js +3 -1
  84. package/dist/components/snk-simple-crud2.js +270 -28
  85. package/dist/components/snk-taskbar2.js +114 -24
  86. package/dist/components/taskbar-actions-button2.js +1 -1
  87. package/dist/esm/{ConfigStorage-4151acc8.js → ConfigStorage-101a2b4c.js} +70 -7
  88. package/dist/esm/{DataFetcher-aa159c5a.js → DataFetcher-a650ae58.js} +5 -3
  89. package/dist/esm/{SnkFormConfigManager-5c7d3771.js → SnkFormConfigManager-d86ba46f.js} +7 -2
  90. package/dist/esm/{SnkMessageBuilder-0fb796b9.js → SnkMessageBuilder-9747ddd2.js} +2 -1
  91. package/dist/esm/SnkMultiSelectionListDataSource-7e7eada5.js +133 -0
  92. package/dist/esm/{auth-fetcher-c05dc474.js → auth-fetcher-17dc5b5e.js} +1 -1
  93. package/dist/esm/{form-config-fetcher-36219cd3.js → form-config-fetcher-f121f880.js} +1 -1
  94. package/dist/esm/index-a7d3d3f1.js +2 -10
  95. package/dist/esm/loader.js +1 -1
  96. package/dist/esm/{pesquisa-fetcher-fa0c2540.js → pesquisa-fetcher-f05a12ca.js} +226 -16
  97. package/dist/esm/sankhyablocks.js +1 -1
  98. package/dist/esm/{snk-actions-button_2.entry.js → snk-actions-button_4.entry.js} +519 -6
  99. package/dist/esm/snk-application.entry.js +34 -8
  100. package/dist/esm/snk-attach.entry.js +6 -7
  101. package/dist/esm/snk-crud.entry.js +16 -10
  102. package/dist/esm/snk-data-exporter.entry.js +8 -4
  103. package/dist/esm/{snk-data-unit-5d201fb3.js → snk-data-unit-4c343635.js} +1 -1
  104. package/dist/esm/snk-data-unit.entry.js +2 -2
  105. package/dist/esm/snk-detail-view.entry.js +9 -10
  106. package/dist/esm/snk-entity-list.entry.js +5 -3
  107. package/dist/esm/snk-filter-bar.entry.js +36 -7
  108. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  109. package/dist/esm/snk-form-config.entry.js +48 -28
  110. package/dist/esm/snk-form.entry.js +11 -4
  111. package/dist/esm/snk-grid.entry.js +41 -23
  112. package/dist/esm/{snk-guides-viewer-f49613c6.js → snk-guides-viewer-18859840.js} +15 -9
  113. package/dist/esm/snk-guides-viewer.entry.js +7 -8
  114. package/dist/esm/snk-personalized-filter-editor.entry.js +3 -1
  115. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  116. package/dist/esm/snk-simple-crud.entry.js +215 -24
  117. package/dist/esm/snk-taskbar.entry.js +101 -15
  118. package/dist/esm/{taskbar-elements-d4d0b424.js → taskbar-elements-2473c8ac.js} +9 -9
  119. package/dist/sankhyablocks/p-1f3174cb.entry.js +1 -0
  120. package/dist/sankhyablocks/p-1fa5a18c.entry.js +11 -0
  121. package/dist/sankhyablocks/p-20b46647.entry.js +1 -0
  122. package/dist/sankhyablocks/p-2897fb8c.js +1 -0
  123. package/dist/sankhyablocks/{p-05243555.js → p-2936303b.js} +1 -1
  124. package/dist/sankhyablocks/p-2b909f08.entry.js +1 -0
  125. package/dist/sankhyablocks/p-33718dfc.entry.js +1 -0
  126. package/dist/sankhyablocks/p-50783a8b.js +1 -0
  127. package/dist/sankhyablocks/p-5c0b53ce.js +56 -0
  128. package/dist/sankhyablocks/p-5dbc1a3f.js +1 -0
  129. package/dist/sankhyablocks/p-60fa6c7a.js +1 -0
  130. package/dist/sankhyablocks/p-64c1b368.entry.js +1 -0
  131. package/dist/sankhyablocks/{p-7f3c7b09.entry.js → p-6b28cc74.entry.js} +1 -1
  132. package/dist/sankhyablocks/{p-e0fd9555.entry.js → p-7ddd95b6.entry.js} +1 -1
  133. package/dist/sankhyablocks/p-7e05bd83.entry.js +1 -0
  134. package/dist/sankhyablocks/p-7f97fee2.entry.js +1 -0
  135. package/dist/sankhyablocks/{p-f3d1c48e.js → p-9a5d1b39.js} +1 -1
  136. package/dist/sankhyablocks/{p-0d7863ed.js → p-a13ccb86.js} +1 -1
  137. package/dist/sankhyablocks/p-ae4fc9a9.js +1 -0
  138. package/dist/sankhyablocks/p-b11aa1e0.entry.js +1 -0
  139. package/dist/sankhyablocks/p-b41a622a.entry.js +1 -0
  140. package/dist/sankhyablocks/p-b4de81ac.entry.js +1 -0
  141. package/dist/sankhyablocks/p-ba4871b5.entry.js +1 -0
  142. package/dist/sankhyablocks/{p-9695f78b.js → p-be75153c.js} +1 -1
  143. package/dist/sankhyablocks/p-d01ceda6.entry.js +1 -0
  144. package/dist/sankhyablocks/p-d304659d.entry.js +1 -0
  145. package/dist/sankhyablocks/p-d78d4062.js +65 -0
  146. package/dist/sankhyablocks/p-e4fb3308.entry.js +1 -0
  147. package/dist/sankhyablocks/p-e7dbe53a.entry.js +1 -0
  148. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  149. package/dist/types/components/snk-actions-button/subcomponents/snk-actions-form.d.ts +1 -1
  150. package/dist/types/components/snk-application/__mocks__/snk-application.d.ts +3 -0
  151. package/dist/types/components/snk-application/snk-application.d.ts +8 -0
  152. package/dist/types/components/snk-crud/snk-crud.d.ts +21 -0
  153. package/dist/types/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.d.ts +1 -1
  154. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +6 -1
  155. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +19 -1
  156. package/dist/types/components/snk-form/snk-form.d.ts +6 -1
  157. package/dist/types/components/{snk-form → snk-form-config}/SnkFormConfigManager.d.ts +1 -0
  158. package/dist/types/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.d.ts +5 -3
  159. package/dist/types/components/snk-grid/snk-grid.d.ts +20 -1
  160. package/dist/types/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.d.ts +11 -6
  161. package/dist/types/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.d.ts +1 -1
  162. package/dist/types/components/snk-simple-crud/regular-buttons.d.ts +3 -0
  163. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +61 -3
  164. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +28 -1
  165. package/dist/types/components.d.ts +193 -12
  166. package/dist/types/lib/configs/ConfigStorage.d.ts +21 -1
  167. package/dist/types/lib/http/data-fetcher/fetchers/parameters-fecher.d.ts +1 -0
  168. package/dist/types/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.d.ts +2 -1
  169. package/dist/types/lib/utils/CrudUtils.d.ts +3 -0
  170. package/package.json +9 -2
  171. package/dist/cjs/PreloadManager-84466da6.js +0 -224
  172. package/dist/cjs/SnkMultiSelectionListDataSource-ba5838c2.js +0 -49
  173. package/dist/cjs/snk-grid-config.cjs.entry.js +0 -483
  174. package/dist/cjs/snk-select-box.cjs.entry.js +0 -25
  175. package/dist/esm/PreloadManager-c1c2f2b4.js +0 -222
  176. package/dist/esm/SnkMultiSelectionListDataSource-44494b0e.js +0 -43
  177. package/dist/esm/snk-grid-config.entry.js +0 -479
  178. package/dist/esm/snk-select-box.entry.js +0 -21
  179. package/dist/sankhyablocks/p-02e3a45b.entry.js +0 -1
  180. package/dist/sankhyablocks/p-094c30cb.js +0 -1
  181. package/dist/sankhyablocks/p-0ec5b2e5.js +0 -1
  182. package/dist/sankhyablocks/p-1d75d9f9.entry.js +0 -1
  183. package/dist/sankhyablocks/p-2582537c.entry.js +0 -1
  184. package/dist/sankhyablocks/p-282789a6.entry.js +0 -1
  185. package/dist/sankhyablocks/p-374d03f6.js +0 -1
  186. package/dist/sankhyablocks/p-3b0e4e08.js +0 -65
  187. package/dist/sankhyablocks/p-40915359.entry.js +0 -1
  188. package/dist/sankhyablocks/p-573a07c5.js +0 -1
  189. package/dist/sankhyablocks/p-62896624.entry.js +0 -1
  190. package/dist/sankhyablocks/p-69efa80d.entry.js +0 -1
  191. package/dist/sankhyablocks/p-761ed32f.entry.js +0 -1
  192. package/dist/sankhyablocks/p-98674137.entry.js +0 -1
  193. package/dist/sankhyablocks/p-9b5944a4.entry.js +0 -1
  194. package/dist/sankhyablocks/p-9bdbc7d8.entry.js +0 -1
  195. package/dist/sankhyablocks/p-aa95fb2c.js +0 -56
  196. package/dist/sankhyablocks/p-ac384baf.entry.js +0 -1
  197. package/dist/sankhyablocks/p-b05ab13d.entry.js +0 -1
  198. package/dist/sankhyablocks/p-c22c1d8e.js +0 -1
  199. package/dist/sankhyablocks/p-c4874327.entry.js +0 -1
  200. package/dist/sankhyablocks/p-c758265f.entry.js +0 -1
  201. package/dist/sankhyablocks/p-cb7419e0.entry.js +0 -1
  202. package/dist/sankhyablocks/p-d4f9ee17.entry.js +0 -1
  203. package/dist/sankhyablocks/p-e6380c60.js +0 -1
  204. package/dist/sankhyablocks/p-e817f254.entry.js +0 -11
  205. /package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.css +0 -0
  206. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.css +0 -0
  207. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.js +0 -0
  208. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.css +0 -0
  209. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.js +0 -0
  210. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.css +0 -0
  211. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.js +0 -0
  212. /package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.css +0 -0
  213. /package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.css +0 -0
  214. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.d.ts +0 -0
  215. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.d.ts +0 -0
  216. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.d.ts +0 -0
@@ -5,25 +5,29 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  const index = require('./index-f9e81701.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
  const constants = require('./constants-35ddd366.js');
8
- const taskbarElements = require('./taskbar-elements-01b85b99.js');
9
- require('./DataFetcher-ba94ed5b.js');
10
- const pesquisaFetcher = require('./pesquisa-fetcher-e4a7c4c3.js');
8
+ const taskbarElements = require('./taskbar-elements-3ecd1278.js');
9
+ require('./DataFetcher-99f0f6ed.js');
10
+ const pesquisaFetcher = require('./pesquisa-fetcher-94f6b316.js');
11
+ const SnkMultiSelectionListDataSource = require('./SnkMultiSelectionListDataSource-5213120b.js');
11
12
  const index$1 = require('./index-0922807b.js');
12
13
  require('./ISave-e91b70a7.js');
13
14
  require('@sankhyalabs/ezui/dist/collection/utils/constants');
14
15
  require('@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata');
15
- require('./PreloadManager-84466da6.js');
16
16
  require('./filter-item-type.enum-a7ffdaa6.js');
17
- require('./form-config-fetcher-df043d3d.js');
17
+ require('./form-config-fetcher-9f1a13ca.js');
18
18
  const fieldSearch = require('./field-search-f56aa7d6.js');
19
- const SnkMultiSelectionListDataSource = require('./SnkMultiSelectionListDataSource-ba5838c2.js');
19
+ const ConfigStorage = require('./ConfigStorage-34be11ce.js');
20
+ const SnkFormConfigManager = require('./SnkFormConfigManager-6211fb28.js');
20
21
  require('./index-102ba62d.js');
21
22
  require('./PrintUtils-bcaeb82f.js');
22
- require('./ResourceIDUtils-5ff86aa7.js');
23
23
  require('@sankhyalabs/ezui/dist/collection/components/ez-grid/utils');
24
+ require('./ResourceIDUtils-5ff86aa7.js');
24
25
  require('@sankhyalabs/ezui/dist/collection/components/ez-grid/utils/InMemoryFilterColumnDataSource');
25
26
 
26
- const snkSimpleCrudCss = ".sc-snk-simple-crud-h{display:flex;height:100%;width:100%}.simple-crud__container.sc-snk-simple-crud{display:grid;grid-template-rows:max-content;row-gap:12px;height:100%;width:100%}.simple-crud__container-section.sc-snk-simple-crud{flex-wrap:unset;flex-direction:column}ez-grid.sc-snk-simple-crud{--ez-grid__container--shadow:none;min-height:300px}ez-form.sc-snk-simple-crud{min-height:300px}";
27
+ const REGULAR_DEFAULT_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "MORE_OPTIONS"];
28
+ const REGULAR_SELECTED_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "CLONE", "REMOVE", "DIVIDER", "MORE_OPTIONS"];
29
+
30
+ const snkSimpleCrudCss = ".sc-snk-simple-crud-h{display:flex;height:100%;width:100%}.simple-crud__container.sc-snk-simple-crud{display:grid;grid-template-rows:max-content;row-gap:12px;height:100%;width:100%}.simple-crud__container-section.sc-snk-simple-crud{flex-wrap:unset;flex-direction:column}.simple-crud__form--hidden.sc-snk-simple-crud{display:none}ez-grid.sc-snk-simple-crud{--ez-grid__container--shadow:none;min-height:300px}ez-form.sc-snk-simple-crud{min-height:300px}";
27
31
 
28
32
  const SnkSimpleCrud = class {
29
33
  constructor(hostRef) {
@@ -32,20 +36,23 @@ const SnkSimpleCrud = class {
32
36
  this.dataUnitReady = index.createEvent(this, "dataUnitReady", 3);
33
37
  this.actionClick = index.createEvent(this, "actionClick", 7);
34
38
  this.formItemsReady = index.createEvent(this, "formItemsReady", 7);
35
- this.REGULAR_DEFAULT_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "MORE_OPTIONS"];
36
- this.REGULAR_SELECTED_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "CLONE", "REMOVE", "DIVIDER", "MORE_OPTIONS"];
39
+ this.configuratorSave = index.createEvent(this, "configuratorSave", 7);
40
+ this.configuratorCancel = index.createEvent(this, "configuratorCancel", 7);
37
41
  this._multiSelectionListDataSource = new SnkMultiSelectionListDataSource.SnkMultiSelectionListDataSource();
38
42
  this._keyDownHandler = (event) => this.keyDownListener(event);
39
43
  this._taskbarProcessor = new fieldSearch.TaskbarProcessor({
40
- "snkSimpleCrudTaskbar.form_regular": this.resolveInMemoryBtns(this.REGULAR_DEFAULT_BTNS).concat(taskbarElements.TaskbarElement.GRID_MODE),
41
- "snkSimpleCrudTaskbar.grid_regular": this.resolveInMemoryBtns(this.REGULAR_DEFAULT_BTNS).concat(taskbarElements.TaskbarElement.FORM_MODE),
42
- "snkSimpleCrudTaskbar.form_selected": this.resolveInMemoryBtns(this.REGULAR_SELECTED_BTNS).concat(taskbarElements.TaskbarElement.GRID_MODE),
43
- "snkSimpleCrudTaskbar.grid_selected": this.resolveInMemoryBtns(this.REGULAR_SELECTED_BTNS).concat(taskbarElements.TaskbarElement.FORM_MODE),
44
+ "snkSimpleCrudTaskbar.form_regular": this.getButtons(false, taskbarElements.TaskbarElement.GRID_MODE),
45
+ "snkSimpleCrudTaskbar.grid_regular": this.getButtons(false, taskbarElements.TaskbarElement.FORM_MODE),
46
+ "snkSimpleCrudTaskbar.form_selected": this.getButtons(true, taskbarElements.TaskbarElement.GRID_MODE),
47
+ "snkSimpleCrudTaskbar.grid_selected": this.getButtons(true, taskbarElements.TaskbarElement.FORM_MODE),
44
48
  "snkSimpleCrudTaskbar.finish_edition": ["CANCEL", "SAVE"]
45
49
  });
50
+ this._showPopUpGridConfig = false;
51
+ this._showFormConfig = false;
46
52
  this._currentViewMode = constants.VIEW_MODE.GRID;
47
53
  this._config = undefined;
48
54
  this._fieldToGetFocus = undefined;
55
+ this._customContainerId = `SNK-SIMPLE-CRUD-CUSTOM-CONTAINER-${core.StringUtils.generateUUID()}`;
49
56
  this.dataState = undefined;
50
57
  this.dataUnit = undefined;
51
58
  this.mode = constants.SIMPLE_CRUD_MODE.SERVER;
@@ -59,6 +66,22 @@ const SnkSimpleCrud = class {
59
66
  this.useEnterLikeTab = false;
60
67
  this.actionsList = undefined;
61
68
  this.configName = undefined;
69
+ this.showConfiguratorButtons = undefined;
70
+ this.gridLegacyConfigName = undefined;
71
+ this.formLegacyConfigName = undefined;
72
+ }
73
+ getButtons(selected, changeModeBtn) {
74
+ return this.addConfigButton(this.resolveInMemoryBtns(selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS)
75
+ .concat(changeModeBtn));
76
+ }
77
+ addConfigButton(buttons) {
78
+ if (this.configName === undefined) {
79
+ return buttons;
80
+ }
81
+ return buttons.concat(taskbarElements.TaskbarElement.CONFIGURATOR);
82
+ }
83
+ get application() {
84
+ return core.ApplicationContext.getContextValue("__SNK__APPLICATION__");
62
85
  }
63
86
  resolveInMemoryBtns(taskbarButtons) {
64
87
  const newTaskBarConfig = [...taskbarButtons];
@@ -78,7 +101,10 @@ const SnkSimpleCrud = class {
78
101
  }
79
102
  actionClickListener(evt) {
80
103
  const act = evt.detail;
81
- if (act === taskbarElements.TaskbarElement.GRID_MODE) {
104
+ if (act === taskbarElements.TaskbarElement.CONFIGURATOR) {
105
+ this._snkConfigurator.open();
106
+ }
107
+ else if (act === taskbarElements.TaskbarElement.GRID_MODE) {
82
108
  this.goToView(constants.VIEW_MODE.GRID);
83
109
  }
84
110
  else if (act === taskbarElements.TaskbarElement.FORM_MODE) {
@@ -96,8 +122,111 @@ const SnkSimpleCrud = class {
96
122
  this.dataStateChange.emit(newValue);
97
123
  }
98
124
  }
99
- componentWillRender() {
125
+ async observeFormLegacy() {
126
+ await this.handleUpdateFormLegacyConfig();
127
+ }
128
+ async observeGridLegacy() {
129
+ await this.handleUpdateGridLegacyConfig();
130
+ }
131
+ async handleUpdateGridLegacyConfig() {
132
+ if (this.gridLegacyConfigName) {
133
+ this.addGridLegacyConfigName();
134
+ if (this._gridConfigAlreadyLoaded) {
135
+ await this.loadGridConfig(true);
136
+ }
137
+ }
138
+ }
139
+ async handleUpdateFormLegacyConfig() {
140
+ var _a, _b, _c;
141
+ if (this.formLegacyConfigName) {
142
+ const legacyConfig = await this.fetchFormLegacyConfig();
143
+ if (!legacyConfig)
144
+ return;
145
+ const rawFields = (_c = (_b = (_a = legacyConfig === null || legacyConfig === void 0 ? void 0 : legacyConfig.formConfig) === null || _a === void 0 ? void 0 : _a.layout) === null || _b === void 0 ? void 0 : _b.field) !== null && _c !== void 0 ? _c : [];
146
+ const fields = Array.isArray(rawFields) ? rawFields : [rawFields];
147
+ const newConfig = { emptyConfig: false, fields: fields };
148
+ this.setFormConfig(newConfig, true);
149
+ this._formConfigManager.setConfig(this.formConfig);
150
+ }
151
+ }
152
+ async fetchFormLegacyConfig() {
153
+ const payload = {
154
+ 'requestBody': {
155
+ 'config': {
156
+ 'chave': this.formLegacyConfigName,
157
+ 'tipo': 'T',
158
+ },
159
+ },
160
+ };
161
+ return await this.application.callServiceBroker('SystemUtilsSP.getConf', JSON.stringify(payload));
162
+ }
163
+ openConfig(viewMode) {
164
+ this._snkConfigurator.close();
165
+ if (viewMode === constants.VIEW_MODE.GRID) {
166
+ this.openGridConfig();
167
+ }
168
+ else if (viewMode === constants.VIEW_MODE.FORM) {
169
+ this.openFormConfig();
170
+ }
171
+ }
172
+ openGridConfig() {
173
+ this._grid.getColumnsState()
174
+ .then((gridColumns) => {
175
+ this._snkGridConfig.columns = gridColumns.filter(c => c.name);
176
+ this._snkGridConfig.selectedIndex = 0;
177
+ this._showPopUpGridConfig = true;
178
+ });
179
+ }
180
+ openFormConfig() {
181
+ //No momento não daremos suporte para configuraçao de formulário quando houver legacy config
182
+ if (this.formLegacyConfigName)
183
+ return;
184
+ this._showFormConfig = true;
185
+ }
186
+ addGridLegacyConfigName() {
187
+ if (this.gridLegacyConfigName && this.configName) {
188
+ ConfigStorage.ConfigStorage.addGridLegacyConfig(this.configName, this.gridLegacyConfigName);
189
+ }
190
+ }
191
+ loadGridConfig(forceUpdate) {
192
+ if ((this.gridConfig != undefined || this._gridConfigAlreadyLoaded) && !forceUpdate) {
193
+ return;
194
+ }
195
+ this._gridConfigAlreadyLoaded = true;
196
+ return new Promise((accept, reject) => {
197
+ ConfigStorage.ConfigStorage.loadGridConfig(this.configName, this._resourceID)
198
+ .then(config => {
199
+ this.setGridConfig(config);
200
+ accept();
201
+ })
202
+ .catch(reason => {
203
+ reject(reason);
204
+ });
205
+ });
206
+ }
207
+ async loadFormConfig() {
208
+ if (this._formConfigManager == undefined) {
209
+ this._formConfigManager = new SnkFormConfigManager.SnkFormConfigManager(this.configName, this._resourceID);
210
+ this._formConfigManager.setConfig(this.formConfig);
211
+ }
212
+ if (this.formConfig != undefined || this._formConfigAlreadyLoaded) {
213
+ return;
214
+ }
215
+ this._formConfigAlreadyLoaded = true;
216
+ this.setFormConfig(await this._formConfigManager.loadConfig());
217
+ }
218
+ async componentWillRender() {
219
+ this._resourceID = await this.application.getResourceID();
100
220
  this._taskbarProcessor.process(this.getTaskBarId(), this.taskbarManager, this.dataState, this.getTaskBarDisabledButtons());
221
+ if (this.configName === undefined) {
222
+ return;
223
+ }
224
+ if (this.gridConfig != undefined || this._gridConfigAlreadyLoaded) {
225
+ return;
226
+ }
227
+ await this.addGridLegacyConfigName();
228
+ this.loadGridConfig();
229
+ this.loadFormConfig();
101
230
  }
102
231
  componentWillLoad() {
103
232
  this.processMetadata();
@@ -105,8 +234,7 @@ const SnkSimpleCrud = class {
105
234
  this.configDatasource();
106
235
  }
107
236
  configDatasource() {
108
- const application = core.ApplicationContext.getContextValue("__SNK__APPLICATION__");
109
- this._multiSelectionListDataSource.setApplication(application);
237
+ this._multiSelectionListDataSource.setApplication(this.application);
110
238
  this._multiSelectionListDataSource.setDataUnit(this.dataUnit);
111
239
  }
112
240
  getTaskBarId() {
@@ -147,6 +275,20 @@ const SnkSimpleCrud = class {
147
275
  getRecords() {
148
276
  return Promise.resolve(this.dataUnit.records);
149
277
  }
278
+ /**
279
+ * Usado para abrir o configurator do CRUD
280
+ */
281
+ async openConfigurator() {
282
+ var _a;
283
+ (_a = this._snkConfigurator) === null || _a === void 0 ? void 0 : _a.open();
284
+ }
285
+ /**
286
+ * Usado para fechar o configurator do CRUD
287
+ */
288
+ async closeConfigurator() {
289
+ var _a;
290
+ (_a = this._snkConfigurator) === null || _a === void 0 ? void 0 : _a.close();
291
+ }
150
292
  processMetadata() {
151
293
  const fieldsMetadataElem = this._element.querySelectorAll("snk-field-metadata");
152
294
  const fieldMetadata = [];
@@ -201,6 +343,14 @@ const SnkSimpleCrud = class {
201
343
  this.dataUnit.clearSelection();
202
344
  }
203
345
  }
346
+ handleConfiguratorEvent(evt, type) {
347
+ evt.stopImmediatePropagation();
348
+ if (type === 'SAVE') {
349
+ this.configuratorSave.emit();
350
+ return;
351
+ }
352
+ this.configuratorCancel.emit();
353
+ }
204
354
  getColumnSearch(actionButton, item) {
205
355
  if (this._columnSearch != undefined) {
206
356
  return this._columnSearch;
@@ -242,7 +392,9 @@ const SnkSimpleCrud = class {
242
392
  return (_b = (_a = this.formConfig) === null || _a === void 0 ? void 0 : _a.fields) !== null && _b !== void 0 ? _b : this._formFields;
243
393
  }
244
394
  handleFormSetFields(fields) {
245
- this._formFields = fields !== null && fields !== void 0 ? fields : [];
395
+ if (!core.ObjectUtils.equals(this._formFields, fields)) {
396
+ this._formFields = fields !== null && fields !== void 0 ? fields : [];
397
+ }
246
398
  }
247
399
  fieldsOptionLoader(argument) {
248
400
  const searchTerm = argument === null || argument === void 0 ? void 0 : argument.toLowerCase();
@@ -314,16 +466,55 @@ const SnkSimpleCrud = class {
314
466
  disconnectedCallback() {
315
467
  window.removeEventListener("keydown", this._keyDownHandler);
316
468
  }
469
+ gridConfigChangeHandler(evt) {
470
+ const config = evt.detail;
471
+ ConfigStorage.ConfigStorage.saveGridConfig(config, this.configName, this._resourceID);
472
+ evt.stopPropagation();
473
+ }
474
+ modalConfigChangeHandler(evt) {
475
+ const config = evt.detail;
476
+ this._grid.setColumnsState(config.columns)
477
+ .then(() => {
478
+ this.setGridConfig(config);
479
+ this.closeGridConfig();
480
+ });
481
+ evt.stopPropagation();
482
+ }
483
+ setGridConfig(config) {
484
+ this.gridConfig = config;
485
+ SnkMultiSelectionListDataSource.CrudUtils.assertDefaultSorting(this.gridConfig, this.dataUnit);
486
+ }
487
+ setFormConfig(config, forceUpdate) {
488
+ if (this.formConfig && !forceUpdate)
489
+ return;
490
+ this.formConfig = config;
491
+ }
492
+ closeGridConfig() {
493
+ this._showPopUpGridConfig = false;
494
+ }
495
+ closeFormConfig() {
496
+ this._showFormConfig = false;
497
+ }
498
+ //No momento não daremos suporte para configuração de formulário quando houver formLegacyConfigName
499
+ handleShowFormConfig() {
500
+ return this._showFormConfig && !this.formLegacyConfigName;
501
+ }
502
+ /* istanbul ignore next */
317
503
  render() {
318
- var _a;
319
- return (index.h("snk-data-unit", { class: "simple-crud__container", dataUnit: this.dataUnit, useCancelConfirm: this.useCancelConfirm, onDataStateChange: evt => this.onDataStateChange(evt), onCancelEdition: this.handleCancelEdit.bind(this), onInsertionMode: () => this.goToView(constants.VIEW_MODE.FORM), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), ignoreSaveMessage: this._currentViewMode === constants.VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail }, index.h("header", null, index.h("slot", { name: "snkSimpleCrudHeader" })), index.h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, index.h("snk-taskbar", { class: "ez-box ez-box--shadow ez-padding--medium ez-margin-bottom--large", dataUnit: this.dataUnit, primaryButton: ((_a = this.dataState) === null || _a === void 0 ? void 0 : _a.isDirty) ? "SAVE" : "INSERT", "data-element-id": "grid_left", messagesBuilder: this.messagesBuilder, buttons: this._taskbarProcessor.buttons, actionsList: this.getActionsList(), disabledButtons: this._taskbarProcessor.disabledButtons, customButtons: this._taskbarProcessor.customButtons, slot: "leftButtons", presentationMode: index$1.PresentationMode.SECONDARY }, index.h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })), index.h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, index.h("stack-item", null, index.h("ez-grid", { ref: ref => this._grid = ref, dataUnit: this.dataUnit, config: this.gridConfig, "no-header": true, multipleSelection: this.multipleSelection, onEzDoubleClick: () => this.goToView(constants.VIEW_MODE.FORM), columnfilterDataSource: this.dataUnit.name.includes(pesquisaFetcher.InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
504
+ var _a, _b, _c;
505
+ if (this.dataUnit == undefined) {
506
+ return;
507
+ }
508
+ return (index.h("snk-data-unit", { class: "simple-crud__container", dataUnit: this.dataUnit, useCancelConfirm: this.useCancelConfirm, onDataStateChange: evt => this.onDataStateChange(evt), onCancelEdition: this.handleCancelEdit.bind(this), onInsertionMode: () => this.goToView(constants.VIEW_MODE.FORM), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), ignoreSaveMessage: this._currentViewMode === constants.VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail }, index.h("header", null, index.h("slot", { name: "snkSimpleCrudHeader" })), index.h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, index.h("snk-taskbar", { class: "ez-box ez-box--shadow ez-padding--medium", dataUnit: this.dataUnit, primaryButton: ((_a = this.dataState) === null || _a === void 0 ? void 0 : _a.isDirty) ? "SAVE" : "INSERT", "data-element-id": "grid_left", messagesBuilder: this.messagesBuilder, buttons: this._taskbarProcessor.buttons, actionsList: this.getActionsList(), disabledButtons: this._taskbarProcessor.disabledButtons, customButtons: this._taskbarProcessor.customButtons, slot: "leftButtons", presentationMode: index$1.PresentationMode.SECONDARY }, index.h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })), index.h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, index.h("stack-item", null, index.h("ez-grid", { class: "ez-margin-bottom--large", ref: ref => this._grid = ref, dataUnit: this.dataUnit, config: this.gridConfig, "no-header": true, multipleSelection: this.multipleSelection, onEzDoubleClick: () => this.goToView(constants.VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(pesquisaFetcher.InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
320
509
  ? undefined
321
- : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab }, index.h("div", { slot: "footer" }, index.h("slot", { name: "snkSimpleCrudFooter" })))), index.h("stack-item", null, index.h("ez-form", { dataUnit: this.dataUnit, config: this.formConfig, fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this) }))))));
510
+ : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab }, index.h("div", { slot: "footer" }, index.h("slot", { name: "snkSimpleCrudFooter" })))), index.h("stack-item", null, index.h("ez-form", { class: `ez-margin-top--large ${this.handleShowFormConfig() ? "simple-crud__form--hidden" : ""}`, dataUnit: this.dataUnit, config: (_b = this._formConfigManager) === null || _b === void 0 ? void 0 : _b.getConfig((_c = this.dataState) === null || _c === void 0 ? void 0 : _c.insertionMode, this.dataUnit), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this) }), this.handleShowFormConfig() && index.h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this.dataUnit, configManager: this._formConfigManager, onConfigClose: () => this.closeFormConfig() })), this.messagesBuilder && index.h("snk-configurator", { ref: (ref) => this._snkConfigurator = ref, viewMode: this._currentViewMode, messagesBuilder: this.messagesBuilder, onConfigSelected: (evt) => this.goToView(evt.detail), onOpenConfig: (evt) => this.openConfig(evt.detail), showActionButtons: this.showConfiguratorButtons, onSave: evt => this.handleConfiguratorEvent(evt, 'SAVE'), onCancel: evt => this.handleConfiguratorEvent(evt, 'CANCEL'), resourceID: this._resourceID, customContainerId: this._customContainerId })), index.h("div", { id: `${this._customContainerId}` }, index.h("slot", { name: "SnkConfigContainerSlot" }))), index.h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._showPopUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, index.h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(core.ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this._resourceID }))));
322
511
  }
323
512
  get _element() { return index.getElement(this); }
324
513
  static get watchers() { return {
325
514
  "mode": ["onModeChange"],
326
- "dataState": ["observeDataState"]
515
+ "dataState": ["observeDataState"],
516
+ "formLegacyConfigName": ["observeFormLegacy"],
517
+ "gridLegacyConfigName": ["observeGridLegacy"]
327
518
  }; }
328
519
  };
329
520
  SnkSimpleCrud.style = snkSimpleCrudCss;
@@ -5,17 +5,20 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  const index = require('./index-f9e81701.js');
6
6
  const core = require('@sankhyalabs/core');
7
7
  const AuthorizationConfig = require('./AuthorizationConfig-79ffae4b.js');
8
- const taskbarElements = require('./taskbar-elements-01b85b99.js');
8
+ const taskbarElements = require('./taskbar-elements-3ecd1278.js');
9
9
  const index$1 = require('./index-0922807b.js');
10
10
  require('./index-102ba62d.js');
11
11
 
12
- const snkTaskbarCss = ".sc-snk-taskbar-h{display:flex}";
12
+ const snkTaskbarCss = ".sc-snk-taskbar-h{display:flex;flex-wrap:wrap}.no-wrap.sc-snk-taskbar-h{flex-wrap:nowrap}.full-width.sc-snk-taskbar-h{width:100%}.align-right.sc-snk-taskbar-h{justify-content:flex-end}.overflowed.sc-snk-taskbar{display:none}";
13
13
 
14
14
  const SnkTaskbar = class {
15
15
  constructor(hostRef) {
16
16
  index.registerInstance(this, hostRef);
17
17
  this.actionClick = index.createEvent(this, "actionClick", 7);
18
18
  this.TASKBAR_ITEM_ID_PREFIX = 'TASKBAR_ITEM_';
19
+ this.TASKBAR_CUSTOM_ELEMENTS_CONTAINER_CLASS_NAME = 'taskbar-custom-elements-container';
20
+ this.ACTIONS_BUTTON_TAG = 'TASKBAR-ACTIONS-BUTTON';
21
+ this.NOT_OVERFLOW_ELEMENTS = ["moreOptions", "dataExporter_snkDataExporter", "actionsButton_snkActionsButton"];
19
22
  this._titleKeyByElement = {
20
23
  [taskbarElements.TaskbarElement.UPDATE]: "snkTaskbar.titleUpdate",
21
24
  [taskbarElements.TaskbarElement.PREVIOUS]: "snkTaskbar.titlePrevious",
@@ -33,11 +36,15 @@ const SnkTaskbar = class {
33
36
  [taskbarElements.TaskbarElement.ATTACH]: "snkTaskbar.titleAttach",
34
37
  };
35
38
  this._permissions = undefined;
39
+ this._overFlowedElements = [];
36
40
  this._customElements = undefined;
37
41
  this._customElementsId = undefined;
38
42
  this._slotContainer = undefined;
43
+ this._hiddenActionsList = [];
44
+ this.alignRigth = false;
39
45
  this.customSlotId = "TASKBAR_CUSTOM_ELEMENTS";
40
46
  this.customContainerId = undefined;
47
+ this.overflowStrategy = 'hiddenItems';
41
48
  this.configName = undefined;
42
49
  this.resourceID = undefined;
43
50
  this.buttons = undefined;
@@ -51,6 +58,13 @@ const SnkTaskbar = class {
51
58
  }
52
59
  observeButtons() {
53
60
  this._definitions = undefined;
61
+ requestAnimationFrame(() => {
62
+ requestAnimationFrame(() => { var _a; return (_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.forceUpdate(); });
63
+ });
64
+ }
65
+ observeDisabledButtons() {
66
+ var _a;
67
+ (_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.forceUpdate();
54
68
  }
55
69
  // Internal methods
56
70
  elementsFromString(strButtons) {
@@ -146,12 +160,19 @@ const SnkTaskbar = class {
146
160
  }
147
161
  const taskbarElement = taskbarElements.TaskbarElement[def.toString()];
148
162
  if (taskbarElement) {
149
- return taskbarElements.buildElem(def, className, this.getIdElemBtnNative(def), elem => this.getTitle(elem), elem => this.elementClick(elem), elem => this.isEnabled(elem), this.actionsList, this.configName, this.presentationMode);
163
+ return taskbarElements.buildElem(def, className, this.getIdElemBtnNative(def), elem => this.getTitle(elem), elem => this.elementClick(elem), elem => this.isEnabled(elem), this.buildDynamicActionsList(), this.configName, this.presentationMode);
150
164
  }
151
165
  else {
152
166
  return taskbarElements.buildCustomButton(def, className, this.getIdElemBtnCustom(def), elem => this.elementClick(elem), elem => this.isEnabled(elem));
153
167
  }
154
168
  }
169
+ buildDynamicActionsList() {
170
+ var _a;
171
+ if (this._hiddenActionsList.length) {
172
+ return [...((_a = this.actionsList) !== null && _a !== void 0 ? _a : []), { type: 'divider', label: "", value: "" }, ...this._hiddenActionsList];
173
+ }
174
+ return this.actionsList;
175
+ }
155
176
  getIdElemBtnNative(taskbarElem) {
156
177
  return core.StringUtils.toCamelCase(taskbarElem);
157
178
  }
@@ -192,11 +213,13 @@ const SnkTaskbar = class {
192
213
  });
193
214
  }
194
215
  addCustomElementContainer(elem) {
216
+ var _a;
195
217
  const elementId = `${this.TASKBAR_ITEM_ID_PREFIX}${elem}`;
196
218
  if (!this._customElementsId.includes(elementId)) {
197
219
  this._customElementsId.push(elementId);
220
+ (_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.addNotOverFlowElement(elementId);
198
221
  }
199
- return index.h("span", { key: elementId, id: elementId });
222
+ return index.h("span", { class: "ez-padding-left--medium", key: elementId, id: elementId });
200
223
  }
201
224
  getCustomElements() {
202
225
  var _a, _b;
@@ -231,15 +254,76 @@ const SnkTaskbar = class {
231
254
  }
232
255
  this.validatePresentationMode();
233
256
  }
257
+ handleOverFlow(overFlowingElements) {
258
+ const elementsToHandle = overFlowingElements.filter(element => !this.hasToIgnoreOverFlow(element));
259
+ this.resetOverFlowedElements();
260
+ this.doOverFlowElements(elementsToHandle);
261
+ }
262
+ resetOverFlowedElements() {
263
+ this._overFlowedElements.forEach(element => {
264
+ element.classList.remove(core.OVERFLOWED_CLASS_NAME);
265
+ });
266
+ this._hiddenActionsList = [];
267
+ this._overFlowedElements = [];
268
+ }
269
+ doOverFlowElements(overFlowedElements) {
270
+ overFlowedElements.forEach(element => {
271
+ element.classList.add(core.OVERFLOWED_CLASS_NAME);
272
+ this._overFlowedElements.push(element);
273
+ this.addItemToActionList(element);
274
+ });
275
+ }
276
+ addItemToActionList(element) {
277
+ const taskbarElement = this.getTaskbarElementName(element);
278
+ if (taskbarElement && this.isEnabled(taskbarElement) && this.isAllowed(taskbarElement)) {
279
+ const optionItem = {
280
+ value: taskbarElement,
281
+ label: this.getTaskbarElementLabel(element),
282
+ iconName: this.getTaskbarElementIcon(element)
283
+ };
284
+ this._hiddenActionsList.push(optionItem);
285
+ }
286
+ }
287
+ getTaskbarElementName(element) {
288
+ var _a;
289
+ return (_a = element.getAttribute('data-taskbar-element')) !== null && _a !== void 0 ? _a : "";
290
+ }
291
+ getTaskbarElementIcon(element) {
292
+ var _a;
293
+ return (_a = element.getAttribute('data-taskbar-icon')) !== null && _a !== void 0 ? _a : "";
294
+ }
295
+ getTaskbarElementLabel(element) {
296
+ var _a;
297
+ return (_a = element.getAttribute('data-taskbar-label')) !== null && _a !== void 0 ? _a : "";
298
+ }
299
+ hasToIgnoreOverFlow(element) {
300
+ return element.classList.contains(this.TASKBAR_CUSTOM_ELEMENTS_CONTAINER_CLASS_NAME);
301
+ }
302
+ handleOverFlowStrategy() {
303
+ if (this.overflowStrategy === 'hiddenItems') {
304
+ this._overFlowWatcher = new core.OverflowWatcher(this.buildOverFlowWatcherParams());
305
+ }
306
+ }
307
+ buildOverFlowWatcherParams() {
308
+ return {
309
+ element: this._element,
310
+ callback: this.handleOverFlow.bind(this),
311
+ overFlowDirection: core.OverflowDirection.HORIZONTAL,
312
+ notOverFlow: this.NOT_OVERFLOW_ELEMENTS
313
+ };
314
+ }
234
315
  componentDidLoad() {
235
316
  const dataInfo = { dataUnit: this.dataUnit };
236
317
  core.ElementIDUtils.addIDInfo(this._element, null, dataInfo);
318
+ this.handleOverFlowStrategy();
237
319
  }
238
320
  componentDidRender() {
239
321
  this.appendCustomElementsInTaskbar();
240
322
  }
241
323
  disconnectedCallback() {
324
+ var _a;
242
325
  this.unlinkAllCustomElements();
326
+ (_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.destroy();
243
327
  }
244
328
  unlinkAllCustomElements() {
245
329
  var _a;
@@ -257,14 +341,9 @@ const SnkTaskbar = class {
257
341
  return undefined;
258
342
  }
259
343
  let index$1 = 0;
260
- return (index.h(index.Host, null, this.removeEmpty(this._definitions.map((elem) => {
261
- var _a;
262
- if (elem === taskbarElements.TaskbarElement.DIVIDER) {
263
- index$1 = 0;
264
- }
265
- else {
266
- index$1++;
267
- }
344
+ return (index.h(index.Host, { class: this.getHostClasses() }, this.removeEmpty(this._definitions.map((elem) => {
345
+ var _a, _b;
346
+ index$1++;
268
347
  if (taskbarElements.TaskbarElement[elem]) {
269
348
  return this.getElement(index$1, taskbarElements.TaskbarElement[elem]);
270
349
  }
@@ -274,12 +353,19 @@ const SnkTaskbar = class {
274
353
  if (this._customElements.has(elem)) {
275
354
  return this.addCustomElementContainer(elem);
276
355
  }
356
+ (_b = this._overFlowWatcher) === null || _b === void 0 ? void 0 : _b.addNotOverFlowElement(elem);
277
357
  return index.h("slot", { name: elem });
278
- })), index.h("div", { class: "taskbar-custom-elements-container" }, index.h("slot", { name: this.customSlotId }))));
358
+ })), index.h("div", { class: this.TASKBAR_CUSTOM_ELEMENTS_CONTAINER_CLASS_NAME }, index.h("slot", { name: this.customSlotId }))));
359
+ }
360
+ getHostClasses() {
361
+ if (this.overflowStrategy !== 'hiddenItems')
362
+ return 'no-wrap';
363
+ return `full-width ${this.alignRigth ? 'align-right' : ""}`;
279
364
  }
280
365
  get _element() { return index.getElement(this); }
281
366
  static get watchers() { return {
282
- "buttons": ["observeButtons"]
367
+ "buttons": ["observeButtons"],
368
+ "disabledButtons": ["observeDisabledButtons"]
283
369
  }; }
284
370
  };
285
371
  SnkTaskbar.style = snkTaskbarCss;
@@ -89,31 +89,31 @@ const buildElem = (element, className, dataElementId, getTitle, action, isEnable
89
89
  case exports.TaskbarElement.CONFIGURATOR:
90
90
  return iconButton("settings-inverted", element, className, dataElementId, title, action, isEnabled);
91
91
  case exports.TaskbarElement.MORE_OPTIONS:
92
- return actionButton(element, dataElementId, title, isEnabled, actions, action);
92
+ return actionButton(element, className, dataElementId, title, isEnabled, actions, action);
93
93
  case exports.TaskbarElement.DIVIDER:
94
- return index.h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin-horizontal--medium", "data-taskbar-divider": true });
94
+ return index.h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin--none ez-margin-left--medium", "data-taskbar-divider": true });
95
95
  case exports.TaskbarElement.DATA_EXPORTER:
96
96
  const provider = (_a = index$1.store.get("exporterProviders")) === null || _a === void 0 ? void 0 : _a[configName];
97
- return index.h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId });
97
+ return index.h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId, "data-taskbar-element": element });
98
98
  case exports.TaskbarElement.ATTACH:
99
99
  return iconButton("anexo", element, className, dataElementId, title, action, isEnabled);
100
100
  case exports.TaskbarElement.ACTIONS_BUTTON:
101
- return index.h("snk-actions-button", { "data-element-id": dataElementId });
101
+ return index.h("snk-actions-button", { "data-element-id": dataElementId, "data-taskbar-element": element });
102
102
  }
103
103
  };
104
104
  function textButton(name, className, dataElementId, text, title, action, isEnabled) {
105
- return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) });
105
+ return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-taskbar-label": text, "data-taskbar-element": name, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) });
106
106
  }
107
107
  function iconButton(iconName, name, className, dataElementId, title, action, isEnabled) {
108
- return index.h("ez-button", { key: dataElementId, title: title, mode: "icon", size: "small", class: className, "data-element-id": dataElementId, iconName: iconName, enabled: isEnabled(name), onClick: () => action(name) });
108
+ return index.h("ez-button", { key: dataElementId, title: title, mode: "icon", size: "small", class: className, "data-taskbar-label": title, "data-taskbar-element": name, "data-taskbar-icon": iconName, "data-element-id": dataElementId, iconName: iconName, enabled: isEnabled(name), onClick: () => action(name) });
109
109
  }
110
110
  function iconTextButton(iconName, name, className, dataElementId, text, title, action, isEnabled) {
111
- return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) },
111
+ return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-taskbar-label": text, "data-taskbar-icon": iconName, "data-taskbar-element": name, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) },
112
112
  index.h("ez-icon", { class: "ez-padding-right--small", slot: "leftIcon", iconName: iconName }));
113
113
  }
114
- function actionButton(element, dataElementId, title, isEnabled, actions, action) {
114
+ function actionButton(element, className, dataElementId, title, isEnabled, actions, action) {
115
115
  return actions && actions.length > 0
116
- ? index.h("taskbar-actions-button", { key: dataElementId, title: title, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, onTaskbarActionSelected: (evt) => action(evt.detail.value) })
116
+ ? index.h("taskbar-actions-button", { class: className, key: dataElementId, title: title, "data-taskbar-element": element, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, onTaskbarActionSelected: (evt) => action(evt.detail.value) })
117
117
  : undefined;
118
118
  }
119
119
 
@@ -6,7 +6,6 @@
6
6
  "./components/snk-taskbar/snk-taskbar.js",
7
7
  "./components/snk-filter-bar/filter-list/snk-filter-list.js",
8
8
  "./components/snk-print-selector/snk-print-selector.js",
9
- "./components/snk-form/subcomponents/snk-tab-config/snk-tab-config.js",
10
9
  "./components/snk-actions-button/snk-actions-button.js",
11
10
  "./components/snk-actions-button/subcomponents/snk-actions-form.js",
12
11
  "./components/snk-actions-button/subcomponents/snk-client-confirm.js",
@@ -35,12 +34,13 @@
35
34
  "./components/snk-filter-bar/filter-modal/subcomponents/snk-filter-modal-item.js",
36
35
  "./components/snk-filter-field-search/snk-filter-field-search.js",
37
36
  "./components/snk-form/snk-form.js",
38
- "./components/snk-form/subcomponents/snk-config-options/snk-config-options.js",
39
- "./components/snk-form/subcomponents/snk-field-config/snk-field-config.js",
40
- "./components/snk-form/subcomponents/snk-form-config/snk-form-config.js",
37
+ "./components/snk-form-config/subcomponents/snk-tab-config/snk-tab-config.js",
38
+ "./components/snk-form-config/snk-form-config.js",
39
+ "./components/snk-form-config/subcomponents/snk-config-options/snk-config-options.js",
40
+ "./components/snk-form-config/subcomponents/snk-field-config/snk-field-config.js",
41
41
  "./components/snk-grid/snk-grid.js",
42
- "./components/snk-grid/subcomponents/snk-grid-config/snk-grid-config.js",
43
- "./components/snk-grid/subcomponents/snk-select-box/snk-select-box.js",
42
+ "./components/snk-grid-config/snk-grid-config.js",
43
+ "./components/snk-grid-config/snk-select-box/snk-select-box.js",
44
44
  "./components/snk-personalized-filter/snk-personalized-filter.js",
45
45
  "./components/snk-personalized-filter/subcomponents/snk-expression-group/snk-expression-group.js",
46
46
  "./components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.js",
@@ -0,0 +1,7 @@
1
+ const SnkApplication = jest.fn()
2
+ .mockImplementation(() => {
3
+ return {
4
+ executePreparedSearch: jest.fn(),
5
+ };
6
+ });
7
+ export { SnkApplication };