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

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-531a191c.js} +21 -13
  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-76b4c346.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 +215 -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 +20 -12
  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 +344 -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 +19 -11
  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 +272 -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-02ecf57f.js} +21 -13
  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-90ca9105.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 +216 -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-2cfe0c2c.entry.js +1 -0
  125. package/dist/sankhyablocks/p-33718dfc.entry.js +1 -0
  126. package/dist/sankhyablocks/p-384fd6ae.js +1 -0
  127. package/dist/sankhyablocks/p-50783a8b.js +1 -0
  128. package/dist/sankhyablocks/p-5c0b53ce.js +56 -0
  129. package/dist/sankhyablocks/p-663ff67b.entry.js +1 -0
  130. package/dist/sankhyablocks/{p-7f3c7b09.entry.js → p-6b28cc74.entry.js} +1 -1
  131. package/dist/sankhyablocks/{p-e0fd9555.entry.js → p-7ddd95b6.entry.js} +1 -1
  132. package/dist/sankhyablocks/p-7e05bd83.entry.js +1 -0
  133. package/dist/sankhyablocks/p-7f97fee2.entry.js +1 -0
  134. package/dist/sankhyablocks/p-8111f63f.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-a83487a0.entry.js +1 -0
  138. package/dist/sankhyablocks/p-ae4fc9a9.js +1 -0
  139. package/dist/sankhyablocks/p-b11aa1e0.entry.js +1 -0
  140. package/dist/sankhyablocks/p-b41a622a.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-e7dbe53a.entry.js +1 -0
  147. package/dist/sankhyablocks/p-fad4c2fe.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 +2 -1
  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 +65 -3
  164. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +28 -1
  165. package/dist/types/components.d.ts +201 -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
@@ -1,28 +1,32 @@
1
- import { ApplicationContext, DataType, FloatingManager, JSUtils, ObjectUtils, StringUtils, UserInterface, } from '@sankhyalabs/core';
1
+ import { ApplicationContext, DataType, ElementIDUtils, FloatingManager, JSUtils, ObjectUtils, StringUtils, UserInterface, } from '@sankhyalabs/core';
2
2
  import { h } from '@stencil/core';
3
3
  import { SIMPLE_CRUD_MODE, VIEW_MODE } from '../../lib/utils/constants';
4
4
  import { TaskbarElement } from '../snk-taskbar/elements/taskbar-elements';
5
- import { PresentationMode } from '../../lib';
5
+ import { CrudUtils, PresentationMode } from '../../lib';
6
6
  import TaskbarProcessor from '../snk-taskbar/processor/taskbar-processor';
7
7
  import InMemoryLoader from '../../lib/dataUnit/InMemoryLoader';
8
8
  import SnkMultiSelectionListDataSource from '../snk-grid/filtercolumn/SnkMultiSelectionListDataSource';
9
9
  import { buildFieldSearch, openFieldSearch } from '../snk-taskbar/subcomponents/field-search';
10
+ import { ConfigStorage } from '../../lib/configs/ConfigStorage';
11
+ import { SnkFormConfigManager } from '../snk-form-config/SnkFormConfigManager';
12
+ import { REGULAR_DEFAULT_BTNS, REGULAR_SELECTED_BTNS } from './regular-buttons';
10
13
  export class SnkSimpleCrud {
11
14
  constructor() {
12
- this.REGULAR_DEFAULT_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "MORE_OPTIONS"];
13
- this.REGULAR_SELECTED_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "CLONE", "REMOVE", "DIVIDER", "MORE_OPTIONS"];
14
15
  this._multiSelectionListDataSource = new SnkMultiSelectionListDataSource();
15
16
  this._keyDownHandler = (event) => this.keyDownListener(event);
16
17
  this._taskbarProcessor = new TaskbarProcessor({
17
- "snkSimpleCrudTaskbar.form_regular": this.resolveInMemoryBtns(this.REGULAR_DEFAULT_BTNS).concat(TaskbarElement.GRID_MODE),
18
- "snkSimpleCrudTaskbar.grid_regular": this.resolveInMemoryBtns(this.REGULAR_DEFAULT_BTNS).concat(TaskbarElement.FORM_MODE),
19
- "snkSimpleCrudTaskbar.form_selected": this.resolveInMemoryBtns(this.REGULAR_SELECTED_BTNS).concat(TaskbarElement.GRID_MODE),
20
- "snkSimpleCrudTaskbar.grid_selected": this.resolveInMemoryBtns(this.REGULAR_SELECTED_BTNS).concat(TaskbarElement.FORM_MODE),
18
+ "snkSimpleCrudTaskbar.form_regular": this.getButtons(false, TaskbarElement.GRID_MODE),
19
+ "snkSimpleCrudTaskbar.grid_regular": this.getButtons(false, TaskbarElement.FORM_MODE),
20
+ "snkSimpleCrudTaskbar.form_selected": this.getButtons(true, TaskbarElement.GRID_MODE),
21
+ "snkSimpleCrudTaskbar.grid_selected": this.getButtons(true, TaskbarElement.FORM_MODE),
21
22
  "snkSimpleCrudTaskbar.finish_edition": ["CANCEL", "SAVE"]
22
23
  });
24
+ this._showPopUpGridConfig = false;
25
+ this._showFormConfig = false;
23
26
  this._currentViewMode = VIEW_MODE.GRID;
24
27
  this._config = undefined;
25
28
  this._fieldToGetFocus = undefined;
29
+ this._customContainerId = `SNK-SIMPLE-CRUD-CUSTOM-CONTAINER-${StringUtils.generateUUID()}`;
26
30
  this.dataState = undefined;
27
31
  this.dataUnit = undefined;
28
32
  this.mode = SIMPLE_CRUD_MODE.SERVER;
@@ -36,6 +40,23 @@ export class SnkSimpleCrud {
36
40
  this.useEnterLikeTab = false;
37
41
  this.actionsList = undefined;
38
42
  this.configName = undefined;
43
+ this.showConfiguratorButtons = undefined;
44
+ this.gridLegacyConfigName = undefined;
45
+ this.formLegacyConfigName = undefined;
46
+ this.ignoreReadOnlyFormFields = false;
47
+ }
48
+ getButtons(selected, changeModeBtn) {
49
+ return this.addConfigButton(this.resolveInMemoryBtns(selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS)
50
+ .concat(changeModeBtn));
51
+ }
52
+ addConfigButton(buttons) {
53
+ if (this.configName === undefined) {
54
+ return buttons;
55
+ }
56
+ return buttons.concat(TaskbarElement.CONFIGURATOR);
57
+ }
58
+ get application() {
59
+ return ApplicationContext.getContextValue("__SNK__APPLICATION__");
39
60
  }
40
61
  resolveInMemoryBtns(taskbarButtons) {
41
62
  const newTaskBarConfig = [...taskbarButtons];
@@ -55,7 +76,10 @@ export class SnkSimpleCrud {
55
76
  }
56
77
  actionClickListener(evt) {
57
78
  const act = evt.detail;
58
- if (act === TaskbarElement.GRID_MODE) {
79
+ if (act === TaskbarElement.CONFIGURATOR) {
80
+ this._snkConfigurator.open();
81
+ }
82
+ else if (act === TaskbarElement.GRID_MODE) {
59
83
  this.goToView(VIEW_MODE.GRID);
60
84
  }
61
85
  else if (act === TaskbarElement.FORM_MODE) {
@@ -73,8 +97,111 @@ export class SnkSimpleCrud {
73
97
  this.dataStateChange.emit(newValue);
74
98
  }
75
99
  }
76
- componentWillRender() {
100
+ async observeFormLegacy() {
101
+ await this.handleUpdateFormLegacyConfig();
102
+ }
103
+ async observeGridLegacy() {
104
+ await this.handleUpdateGridLegacyConfig();
105
+ }
106
+ async handleUpdateGridLegacyConfig() {
107
+ if (this.gridLegacyConfigName) {
108
+ this.addGridLegacyConfigName();
109
+ if (this._gridConfigAlreadyLoaded) {
110
+ await this.loadGridConfig(true);
111
+ }
112
+ }
113
+ }
114
+ async handleUpdateFormLegacyConfig() {
115
+ var _a, _b, _c;
116
+ if (this.formLegacyConfigName) {
117
+ const legacyConfig = await this.fetchFormLegacyConfig();
118
+ if (!legacyConfig)
119
+ return;
120
+ 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 : [];
121
+ const fields = Array.isArray(rawFields) ? rawFields : [rawFields];
122
+ const newConfig = { emptyConfig: false, fields: fields };
123
+ this.setFormConfig(newConfig, true);
124
+ this._formConfigManager.setConfig(this.formConfig);
125
+ }
126
+ }
127
+ async fetchFormLegacyConfig() {
128
+ const payload = {
129
+ 'requestBody': {
130
+ 'config': {
131
+ 'chave': this.formLegacyConfigName,
132
+ 'tipo': 'T',
133
+ },
134
+ },
135
+ };
136
+ return await this.application.callServiceBroker('SystemUtilsSP.getConf', JSON.stringify(payload));
137
+ }
138
+ openConfig(viewMode) {
139
+ this._snkConfigurator.close();
140
+ if (viewMode === VIEW_MODE.GRID) {
141
+ this.openGridConfig();
142
+ }
143
+ else if (viewMode === VIEW_MODE.FORM) {
144
+ this.openFormConfig();
145
+ }
146
+ }
147
+ openGridConfig() {
148
+ this._grid.getColumnsState()
149
+ .then((gridColumns) => {
150
+ this._snkGridConfig.columns = gridColumns.filter(c => c.name);
151
+ this._snkGridConfig.selectedIndex = 0;
152
+ this._showPopUpGridConfig = true;
153
+ });
154
+ }
155
+ openFormConfig() {
156
+ //No momento não daremos suporte para configuraçao de formulário quando houver legacy config
157
+ if (this.formLegacyConfigName)
158
+ return;
159
+ this._showFormConfig = true;
160
+ }
161
+ addGridLegacyConfigName() {
162
+ if (this.gridLegacyConfigName && this.configName) {
163
+ ConfigStorage.addGridLegacyConfig(this.configName, this.gridLegacyConfigName);
164
+ }
165
+ }
166
+ loadGridConfig(forceUpdate) {
167
+ if ((this.gridConfig != undefined || this._gridConfigAlreadyLoaded) && !forceUpdate) {
168
+ return;
169
+ }
170
+ this._gridConfigAlreadyLoaded = true;
171
+ return new Promise((accept, reject) => {
172
+ ConfigStorage.loadGridConfig(this.configName, this._resourceID)
173
+ .then(config => {
174
+ this.setGridConfig(config);
175
+ accept();
176
+ })
177
+ .catch(reason => {
178
+ reject(reason);
179
+ });
180
+ });
181
+ }
182
+ async loadFormConfig() {
183
+ if (this._formConfigManager == undefined) {
184
+ this._formConfigManager = new SnkFormConfigManager(this.configName, this._resourceID);
185
+ this._formConfigManager.setConfig(this.formConfig);
186
+ }
187
+ if (this.formConfig != undefined || this._formConfigAlreadyLoaded) {
188
+ return;
189
+ }
190
+ this._formConfigAlreadyLoaded = true;
191
+ this.setFormConfig(await this._formConfigManager.loadConfig());
192
+ }
193
+ async componentWillRender() {
194
+ this._resourceID = await this.application.getResourceID();
77
195
  this._taskbarProcessor.process(this.getTaskBarId(), this.taskbarManager, this.dataState, this.getTaskBarDisabledButtons());
196
+ if (this.configName === undefined) {
197
+ return;
198
+ }
199
+ if (this.gridConfig != undefined || this._gridConfigAlreadyLoaded) {
200
+ return;
201
+ }
202
+ await this.addGridLegacyConfigName();
203
+ this.loadGridConfig();
204
+ this.loadFormConfig();
78
205
  }
79
206
  componentWillLoad() {
80
207
  this.processMetadata();
@@ -82,8 +209,7 @@ export class SnkSimpleCrud {
82
209
  this.configDatasource();
83
210
  }
84
211
  configDatasource() {
85
- const application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
86
- this._multiSelectionListDataSource.setApplication(application);
212
+ this._multiSelectionListDataSource.setApplication(this.application);
87
213
  this._multiSelectionListDataSource.setDataUnit(this.dataUnit);
88
214
  }
89
215
  getTaskBarId() {
@@ -124,6 +250,20 @@ export class SnkSimpleCrud {
124
250
  getRecords() {
125
251
  return Promise.resolve(this.dataUnit.records);
126
252
  }
253
+ /**
254
+ * Usado para abrir o configurator do CRUD
255
+ */
256
+ async openConfigurator() {
257
+ var _a;
258
+ (_a = this._snkConfigurator) === null || _a === void 0 ? void 0 : _a.open();
259
+ }
260
+ /**
261
+ * Usado para fechar o configurator do CRUD
262
+ */
263
+ async closeConfigurator() {
264
+ var _a;
265
+ (_a = this._snkConfigurator) === null || _a === void 0 ? void 0 : _a.close();
266
+ }
127
267
  processMetadata() {
128
268
  const fieldsMetadataElem = this._element.querySelectorAll("snk-field-metadata");
129
269
  const fieldMetadata = [];
@@ -178,6 +318,14 @@ export class SnkSimpleCrud {
178
318
  this.dataUnit.clearSelection();
179
319
  }
180
320
  }
321
+ handleConfiguratorEvent(evt, type) {
322
+ evt.stopImmediatePropagation();
323
+ if (type === 'SAVE') {
324
+ this.configuratorSave.emit();
325
+ return;
326
+ }
327
+ this.configuratorCancel.emit();
328
+ }
181
329
  getColumnSearch(actionButton, item) {
182
330
  if (this._columnSearch != undefined) {
183
331
  return this._columnSearch;
@@ -219,7 +367,9 @@ export class SnkSimpleCrud {
219
367
  return (_b = (_a = this.formConfig) === null || _a === void 0 ? void 0 : _a.fields) !== null && _b !== void 0 ? _b : this._formFields;
220
368
  }
221
369
  handleFormSetFields(fields) {
222
- this._formFields = fields !== null && fields !== void 0 ? fields : [];
370
+ if (!ObjectUtils.equals(this._formFields, fields)) {
371
+ this._formFields = fields !== null && fields !== void 0 ? fields : [];
372
+ }
223
373
  }
224
374
  fieldsOptionLoader(argument) {
225
375
  const searchTerm = argument === null || argument === void 0 ? void 0 : argument.toLowerCase();
@@ -291,11 +441,48 @@ export class SnkSimpleCrud {
291
441
  disconnectedCallback() {
292
442
  window.removeEventListener("keydown", this._keyDownHandler);
293
443
  }
444
+ gridConfigChangeHandler(evt) {
445
+ const config = evt.detail;
446
+ ConfigStorage.saveGridConfig(config, this.configName, this._resourceID);
447
+ evt.stopPropagation();
448
+ }
449
+ modalConfigChangeHandler(evt) {
450
+ const config = evt.detail;
451
+ this._grid.setColumnsState(config.columns)
452
+ .then(() => {
453
+ this.setGridConfig(config);
454
+ this.closeGridConfig();
455
+ });
456
+ evt.stopPropagation();
457
+ }
458
+ setGridConfig(config) {
459
+ this.gridConfig = config;
460
+ CrudUtils.assertDefaultSorting(this.gridConfig, this.dataUnit);
461
+ }
462
+ setFormConfig(config, forceUpdate) {
463
+ if (this.formConfig && !forceUpdate)
464
+ return;
465
+ this.formConfig = config;
466
+ }
467
+ closeGridConfig() {
468
+ this._showPopUpGridConfig = false;
469
+ }
470
+ closeFormConfig() {
471
+ this._showFormConfig = false;
472
+ }
473
+ //No momento não daremos suporte para configuração de formulário quando houver formLegacyConfigName
474
+ handleShowFormConfig() {
475
+ return this._showFormConfig && !this.formLegacyConfigName;
476
+ }
477
+ /* istanbul ignore next */
294
478
  render() {
295
- var _a;
296
- return (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(VIEW_MODE.FORM), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), ignoreSaveMessage: this._currentViewMode === VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail }, h("header", null, h("slot", { name: "snkSimpleCrudHeader" })), h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, 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: PresentationMode.SECONDARY }, h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })), h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, h("stack-item", null, h("ez-grid", { ref: ref => this._grid = ref, dataUnit: this.dataUnit, config: this.gridConfig, "no-header": true, multipleSelection: this.multipleSelection, onEzDoubleClick: () => this.goToView(VIEW_MODE.FORM), columnfilterDataSource: this.dataUnit.name.includes(InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
479
+ var _a, _b, _c;
480
+ if (this.dataUnit == undefined) {
481
+ return;
482
+ }
483
+ return (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(VIEW_MODE.FORM), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), ignoreSaveMessage: this._currentViewMode === VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail }, h("header", null, h("slot", { name: "snkSimpleCrudHeader" })), h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, 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: PresentationMode.SECONDARY }, h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })), h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, h("stack-item", null, 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(VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
297
484
  ? undefined
298
- : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab }, h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, h("ez-form", { dataUnit: this.dataUnit, config: this.formConfig, fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this) }))))));
485
+ : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab }, h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, 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, this.ignoreReadOnlyFormFields), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this) }), this.handleShowFormConfig() && h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this.dataUnit, configManager: this._formConfigManager, onConfigClose: () => this.closeFormConfig() })), this.messagesBuilder && 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 })), h("div", { id: `${this._customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }))), h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._showPopUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this._resourceID }))));
299
486
  }
300
487
  static get is() { return "snk-simple-crud"; }
301
488
  static get encapsulation() { return "scoped"; }
@@ -376,7 +563,7 @@ export class SnkSimpleCrud {
376
563
  },
377
564
  "gridConfig": {
378
565
  "type": "unknown",
379
- "mutable": false,
566
+ "mutable": true,
380
567
  "complexType": {
381
568
  "original": "IGridConfig",
382
569
  "resolved": "IGridConfig",
@@ -546,14 +733,86 @@ export class SnkSimpleCrud {
546
733
  },
547
734
  "attribute": "config-name",
548
735
  "reflect": false
736
+ },
737
+ "showConfiguratorButtons": {
738
+ "type": "boolean",
739
+ "mutable": false,
740
+ "complexType": {
741
+ "original": "boolean",
742
+ "resolved": "boolean",
743
+ "references": {}
744
+ },
745
+ "required": false,
746
+ "optional": false,
747
+ "docs": {
748
+ "tags": [],
749
+ "text": "Usado para exibir os bot\u00F5es de a\u00E7\u00E3o do snk-configurator."
750
+ },
751
+ "attribute": "show-configurator-buttons",
752
+ "reflect": false
753
+ },
754
+ "gridLegacyConfigName": {
755
+ "type": "string",
756
+ "mutable": false,
757
+ "complexType": {
758
+ "original": "string",
759
+ "resolved": "string",
760
+ "references": {}
761
+ },
762
+ "required": false,
763
+ "optional": false,
764
+ "docs": {
765
+ "tags": [],
766
+ "text": "Chave da configura\u00E7\u00E3o legado da grade."
767
+ },
768
+ "attribute": "grid-legacy-config-name",
769
+ "reflect": false
770
+ },
771
+ "formLegacyConfigName": {
772
+ "type": "string",
773
+ "mutable": false,
774
+ "complexType": {
775
+ "original": "string",
776
+ "resolved": "string",
777
+ "references": {}
778
+ },
779
+ "required": false,
780
+ "optional": false,
781
+ "docs": {
782
+ "tags": [],
783
+ "text": "Chave da configura\u00E7\u00E3o legado do formul\u00E1rio."
784
+ },
785
+ "attribute": "form-legacy-config-name",
786
+ "reflect": false
787
+ },
788
+ "ignoreReadOnlyFormFields": {
789
+ "type": "boolean",
790
+ "mutable": false,
791
+ "complexType": {
792
+ "original": "boolean",
793
+ "resolved": "boolean",
794
+ "references": {}
795
+ },
796
+ "required": false,
797
+ "optional": false,
798
+ "docs": {
799
+ "tags": [],
800
+ "text": "Ignora os campos \"somente leitura\" no modo de inser\u00E7\u00E3o."
801
+ },
802
+ "attribute": "ignore-read-only-form-fields",
803
+ "reflect": false,
804
+ "defaultValue": "false"
549
805
  }
550
806
  };
551
807
  }
552
808
  static get states() {
553
809
  return {
810
+ "_showPopUpGridConfig": {},
811
+ "_showFormConfig": {},
554
812
  "_currentViewMode": {},
555
813
  "_config": {},
556
814
  "_fieldToGetFocus": {},
815
+ "_customContainerId": {},
557
816
  "_formFields": {}
558
817
  };
559
818
  }
@@ -635,6 +894,36 @@ export class SnkSimpleCrud {
635
894
  }
636
895
  }
637
896
  }
897
+ }, {
898
+ "method": "configuratorSave",
899
+ "name": "configuratorSave",
900
+ "bubbles": true,
901
+ "cancelable": true,
902
+ "composed": true,
903
+ "docs": {
904
+ "tags": [],
905
+ "text": "Emitido quando salva a configura\u00E7\u00E3o no configurator do CRUD."
906
+ },
907
+ "complexType": {
908
+ "original": "any",
909
+ "resolved": "any",
910
+ "references": {}
911
+ }
912
+ }, {
913
+ "method": "configuratorCancel",
914
+ "name": "configuratorCancel",
915
+ "bubbles": true,
916
+ "cancelable": true,
917
+ "composed": true,
918
+ "docs": {
919
+ "tags": [],
920
+ "text": "Emitido quando cancela o salvamento da configura\u00E7\u00E3o no configurator do CRUD."
921
+ },
922
+ "complexType": {
923
+ "original": "any",
924
+ "resolved": "any",
925
+ "references": {}
926
+ }
638
927
  }];
639
928
  }
640
929
  static get methods() {
@@ -733,6 +1022,38 @@ export class SnkSimpleCrud {
733
1022
  "text": "",
734
1023
  "tags": []
735
1024
  }
1025
+ },
1026
+ "openConfigurator": {
1027
+ "complexType": {
1028
+ "signature": "() => Promise<void>",
1029
+ "parameters": [],
1030
+ "references": {
1031
+ "Promise": {
1032
+ "location": "global"
1033
+ }
1034
+ },
1035
+ "return": "Promise<void>"
1036
+ },
1037
+ "docs": {
1038
+ "text": "Usado para abrir o configurator do CRUD",
1039
+ "tags": []
1040
+ }
1041
+ },
1042
+ "closeConfigurator": {
1043
+ "complexType": {
1044
+ "signature": "() => Promise<void>",
1045
+ "parameters": [],
1046
+ "references": {
1047
+ "Promise": {
1048
+ "location": "global"
1049
+ }
1050
+ },
1051
+ "return": "Promise<void>"
1052
+ },
1053
+ "docs": {
1054
+ "text": "Usado para fechar o configurator do CRUD",
1055
+ "tags": []
1056
+ }
736
1057
  }
737
1058
  };
738
1059
  }
@@ -744,6 +1065,12 @@ export class SnkSimpleCrud {
744
1065
  }, {
745
1066
  "propName": "dataState",
746
1067
  "methodName": "observeDataState"
1068
+ }, {
1069
+ "propName": "formLegacyConfigName",
1070
+ "methodName": "observeFormLegacy"
1071
+ }, {
1072
+ "propName": "gridLegacyConfigName",
1073
+ "methodName": "observeGridLegacy"
747
1074
  }];
748
1075
  }
749
1076
  static get listeners() {
@@ -118,7 +118,7 @@ export class TaskbarActionsButton {
118
118
  this.taskbarActionsButtonDisconnected.emit();
119
119
  }
120
120
  render() {
121
- return (h(Host, null, h("div", { class: `ez-padding-left--medium ${this.canShowDropdown() ? ' ez-elevation--16' : ''}` }, h("ez-button", { title: this.title, mode: 'icon', iconName: 'dots-vertical', size: 'small', enabled: this.enabled, onClick: () => this.controlDropdown() }), this.canShowDropdown() && h("ez-dropdown", { items: this.loadItems(), onEzClick: (evt) => this.onSelectAction(evt.detail), onEzOutsideClick: () => this._showDropdown = false, itemBuilder: (item, level) => this.dropdownItemBuilder(item, level) }))));
121
+ return (h(Host, null, h("div", { class: `${this.canShowDropdown() ? ' ez-elevation--16' : ''}` }, h("ez-button", { title: this.title, mode: 'icon', iconName: 'dots-vertical', size: 'small', enabled: this.enabled, onClick: () => this.controlDropdown() }), this.canShowDropdown() && h("ez-dropdown", { items: this.loadItems(), onEzClick: (evt) => this.onSelectAction(evt.detail), onEzOutsideClick: () => this._showDropdown = false, itemBuilder: (item, level) => this.dropdownItemBuilder(item, level) }))));
122
122
  }
123
123
  static get is() { return "taskbar-actions-button"; }
124
124
  static get encapsulation() { return "scoped"; }
@@ -86,29 +86,29 @@ export const buildElem = (element, className, dataElementId, getTitle, action, i
86
86
  case TaskbarElement.CONFIGURATOR:
87
87
  return iconButton("settings-inverted", element, className, dataElementId, title, action, isEnabled);
88
88
  case TaskbarElement.MORE_OPTIONS:
89
- return actionButton(element, dataElementId, title, isEnabled, actions, action);
89
+ return actionButton(element, className, dataElementId, title, isEnabled, actions, action);
90
90
  case TaskbarElement.DIVIDER:
91
- return h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin-horizontal--medium", "data-taskbar-divider": true });
91
+ return h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin--none ez-margin-left--medium", "data-taskbar-divider": true });
92
92
  case TaskbarElement.DATA_EXPORTER:
93
93
  const provider = (_a = store.get("exporterProviders")) === null || _a === void 0 ? void 0 : _a[configName];
94
- return h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId });
94
+ return h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId, "data-taskbar-element": element });
95
95
  case TaskbarElement.ATTACH:
96
96
  return iconButton("anexo", element, className, dataElementId, title, action, isEnabled);
97
97
  case TaskbarElement.ACTIONS_BUTTON:
98
- return h("snk-actions-button", { "data-element-id": dataElementId });
98
+ return h("snk-actions-button", { "data-element-id": dataElementId, "data-taskbar-element": element });
99
99
  }
100
100
  };
101
101
  function textButton(name, className, dataElementId, text, title, action, isEnabled) {
102
- return h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) });
102
+ return 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) });
103
103
  }
104
104
  function iconButton(iconName, name, className, dataElementId, title, action, isEnabled) {
105
- return 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) });
105
+ return 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) });
106
106
  }
107
107
  function iconTextButton(iconName, name, className, dataElementId, text, title, action, isEnabled) {
108
- return h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) }, h("ez-icon", { class: "ez-padding-right--small", slot: "leftIcon", iconName: iconName }));
108
+ return 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) }, h("ez-icon", { class: "ez-padding-right--small", slot: "leftIcon", iconName: iconName }));
109
109
  }
110
- function actionButton(element, dataElementId, title, isEnabled, actions, action) {
110
+ function actionButton(element, className, dataElementId, title, isEnabled, actions, action) {
111
111
  return actions && actions.length > 0
112
- ? h("taskbar-actions-button", { key: dataElementId, title: title, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, onTaskbarActionSelected: (evt) => action(evt.detail.value) })
112
+ ? 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) })
113
113
  : undefined;
114
114
  }
@@ -1,3 +1,20 @@
1
1
  :host {
2
2
  display: flex;
3
+ flex-wrap: wrap;
4
+ }
5
+
6
+ :host.no-wrap {
7
+ flex-wrap: nowrap;
8
+ }
9
+
10
+ :host.full-width{
11
+ width: 100%;
12
+ }
13
+
14
+ :host.align-right{
15
+ justify-content: flex-end;
16
+ }
17
+
18
+ .overflowed {
19
+ display: none;
3
20
  }