@sankhyalabs/sankhyablocks 10.1.0-dev.5 → 10.1.0-dev.50

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 (452) hide show
  1. package/LICENSE +4 -1
  2. package/dist/cjs/{ConfigStorage-72f34bd4.js → ConfigStorage-a1fab5ca.js} +19 -2
  3. package/dist/cjs/ContinuousInsertUtils-1ae0c6ac.js +41 -0
  4. package/dist/cjs/{DataFetcher-991b0349.js → DataFetcher-384d2ce8.js} +2 -2751
  5. package/dist/cjs/{FormConfigHelper-e253a418.js → FormConfigHelper-28fe4668.js} +3 -1
  6. package/dist/cjs/{ISave-ebf6b4ed.js → ISave-ecbe9336.js} +1 -1
  7. package/dist/cjs/ImageUtils-d6139911.js +144 -0
  8. package/dist/cjs/{PersonalizedFilterUtils-7259cf65.js → PersonalizedFilterUtils-eccb267a.js} +13 -0
  9. package/dist/cjs/{SnkFormConfigManager-cdbb29d4.js → SnkFormConfigManager-44386305.js} +5 -5
  10. package/dist/cjs/SnkMessageBuilder-a9300ebe.js +2833 -0
  11. package/dist/cjs/{SnkMultiSelectionListDataSource-011bec79.js → SnkMultiSelectionListDataSource-293bc3d2.js} +61 -47
  12. package/dist/cjs/{auth-fetcher-c3cac878.js → auth-fetcher-6b134ec4.js} +1 -1
  13. package/dist/cjs/config-header.cjs.entry.js +1 -1
  14. package/dist/cjs/configs-button.cjs.entry.js +1 -1
  15. package/dist/cjs/css-shim-a27d231b.js +6 -0
  16. package/dist/cjs/{dataunit-fetcher-8bf469e7.js → dataunit-fetcher-b9822794.js} +66 -6
  17. package/dist/cjs/dom-ff96a4bc.js +75 -0
  18. package/dist/cjs/field-config_2.cjs.entry.js +3 -3
  19. package/dist/cjs/fields-layout.cjs.entry.js +6 -6
  20. package/dist/cjs/fields-selector.cjs.entry.js +3 -3
  21. package/dist/cjs/{form-config-fetcher-c7af90d8.js → form-config-fetcher-45d1964c.js} +19 -1
  22. package/dist/cjs/guides-configurator.cjs.entry.js +3 -3
  23. package/dist/cjs/{index-1cf293c1.js → index-1894343a.js} +1529 -177
  24. package/dist/cjs/{index-13d05f03.js → index-f0fe7e6e.js} +90 -21
  25. package/dist/cjs/loader.cjs.js +16 -2
  26. package/dist/cjs/pesquisa-grid_2.cjs.entry.js +6 -5
  27. package/dist/cjs/sankhyablocks.cjs.js +132 -4
  28. package/dist/cjs/shadow-css-7e3e0ab1.js +389 -0
  29. package/dist/cjs/snk-actions-button_9.cjs.entry.js +166 -116
  30. package/dist/cjs/snk-actions-form.cjs.entry.js +1 -1
  31. package/dist/cjs/snk-application.cjs.entry.js +29 -9
  32. package/dist/cjs/snk-attach.cjs.entry.js +63 -25
  33. package/dist/cjs/snk-client-confirm.cjs.entry.js +1 -1
  34. package/dist/cjs/snk-configurator.cjs.entry.js +3 -1
  35. package/dist/cjs/snk-crud.cjs.entry.js +350 -109
  36. package/dist/cjs/snk-custom-slot-elements.cjs.entry.js +1 -1
  37. package/dist/cjs/snk-custom-slot-guide.cjs.entry.js +40 -0
  38. package/dist/cjs/snk-data-exporter.cjs.entry.js +9 -7
  39. package/dist/cjs/{snk-data-unit-7d587ad5.js → snk-data-unit-4b6dc396.js} +21 -12
  40. package/dist/cjs/snk-data-unit.cjs.entry.js +5 -4
  41. package/dist/cjs/snk-default-filter.cjs.entry.js +1 -1
  42. package/dist/cjs/snk-detail-view.cjs.entry.js +19 -20
  43. package/dist/cjs/snk-entity-list.cjs.entry.js +1 -1
  44. package/dist/cjs/snk-entity-search.cjs.entry.js +211 -0
  45. package/dist/cjs/snk-exporter-email-sender.cjs.entry.js +2 -2
  46. package/dist/cjs/snk-expression-group_2.cjs.entry.js +2 -2
  47. package/dist/cjs/{snk-filter-advanced-mode_2.cjs.entry.js → snk-filter-advanced-mode_3.cjs.entry.js} +41 -3
  48. package/dist/cjs/snk-filter-bar_4.cjs.entry.js +147 -94
  49. package/dist/cjs/snk-filter-binary-select.cjs.entry.js +1 -1
  50. package/dist/cjs/snk-filter-checkbox-list.cjs.entry.js +1 -1
  51. package/dist/cjs/snk-filter-detail.cjs.entry.js +3 -3
  52. package/dist/cjs/snk-filter-field-search_2.cjs.entry.js +2 -2
  53. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +5 -4
  54. package/dist/cjs/snk-filter-multi-select.cjs.entry.js +1 -1
  55. package/dist/cjs/snk-filter-number.cjs.entry.js +11 -7
  56. package/dist/cjs/snk-filter-period.cjs.entry.js +14 -7
  57. package/dist/cjs/snk-filter-search.cjs.entry.js +1 -1
  58. package/dist/cjs/snk-filter-text.cjs.entry.js +2 -2
  59. package/dist/cjs/snk-form-summary.cjs.entry.js +1 -1
  60. package/dist/cjs/snk-form-view.cjs.entry.js +70 -8
  61. package/dist/cjs/snk-form_2.cjs.entry.js +22 -11
  62. package/dist/cjs/snk-grid.cjs.entry.js +67 -34
  63. package/dist/cjs/{snk-guides-viewer-366d5c32.js → snk-guides-viewer-b4ca3437.js} +78 -214
  64. package/dist/cjs/snk-guides-viewer.cjs.entry.js +11 -18
  65. package/dist/cjs/snk-image-input.cjs.entry.js +160 -0
  66. package/dist/cjs/snk-layout-form-config.cjs.entry.js +72 -0
  67. package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +1 -1
  68. package/dist/cjs/snk-personalized-filter.cjs.entry.js +8 -7
  69. package/dist/cjs/snk-pesquisa.cjs.entry.js +6 -6
  70. package/dist/cjs/snk-print-selector.cjs.entry.js +1 -1
  71. package/dist/cjs/snk-simple-crud.cjs.entry.js +30 -35
  72. package/dist/cjs/snk-taskbar.cjs.entry.js +183 -126
  73. package/dist/cjs/{sortable.esm-9a110bb7.js → sortable.esm-b87669ab.js} +76 -90
  74. package/dist/cjs/taskbar-elements-80eddec8.js +152 -0
  75. package/dist/cjs/teste-pesquisa.cjs.entry.js +1 -1
  76. package/dist/collection/collection-manifest.json +9 -0
  77. package/dist/collection/components/snk-actions-button/actions/executor/launch-screen.executor.js +6 -3
  78. package/dist/collection/components/snk-actions-button/snk-actions-button.js +27 -3
  79. package/dist/collection/components/snk-application/errorhandler/snk-error-handler.js +1 -0
  80. package/dist/collection/components/snk-application/snk-application.js +20 -2
  81. package/dist/collection/components/snk-attach/snk-attach.css +29 -7
  82. package/dist/collection/components/snk-attach/snk-attach.js +94 -19
  83. package/dist/collection/components/snk-configurator/snk-configurator.js +2 -0
  84. package/dist/collection/components/snk-crud/snk-crud.css +50 -0
  85. package/dist/collection/components/snk-crud/snk-crud.js +165 -98
  86. package/dist/collection/components/snk-crud/subcomponents/GuideBuilder.js +1 -1
  87. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +5 -5
  88. package/dist/collection/components/snk-crud/subcomponents/snk-entity-search.css +17 -0
  89. package/dist/collection/components/snk-crud/subcomponents/snk-entity-search.js +330 -0
  90. package/dist/collection/components/snk-crud/subcomponents/snk-form-view.js +90 -8
  91. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.css +22 -8
  92. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +90 -205
  93. package/dist/collection/components/snk-crud/utils/taskbarUtils.js +144 -0
  94. package/dist/collection/components/snk-custom-slot-guide/snk-custom-slot-guide.css +3 -0
  95. package/dist/collection/components/snk-custom-slot-guide/snk-custom-slot-guide.js +95 -0
  96. package/dist/collection/components/snk-data-exporter/exporter-email-sender/snk-exporter-email-sender.js +1 -1
  97. package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +20 -1
  98. package/dist/collection/components/snk-data-unit/snk-data-unit.js +9 -0
  99. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-number.js +13 -9
  100. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-period.js +14 -7
  101. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-text.js +1 -1
  102. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-detail.js +1 -1
  103. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.css +5 -1
  104. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.js +28 -2
  105. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.css +7 -1
  106. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +22 -8
  107. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +1 -6
  108. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +166 -78
  109. package/dist/collection/components/snk-form-config/FormConfigHelper.js +3 -1
  110. package/dist/collection/components/snk-form-config/SnkFormConfigManager.js +3 -3
  111. package/dist/collection/components/snk-form-config/field-item/field-config/field-config.css +1 -0
  112. package/dist/collection/components/snk-form-config/fields-layout/fields-layout.css +16 -0
  113. package/dist/collection/components/snk-form-config/fields-layout/fields-layout.js +4 -4
  114. package/dist/collection/components/snk-form-config/guides-configurator/guides-configurator.css +3 -4
  115. package/dist/collection/components/snk-form-config/guides-configurator/guides-configurator.js +2 -2
  116. package/dist/collection/components/snk-form-config/snk-form-config.js +15 -5
  117. package/dist/collection/components/snk-grid/snk-grid.css +24 -3
  118. package/dist/collection/components/snk-grid/snk-grid.js +174 -22
  119. package/dist/collection/components/snk-grid-config/snk-grid-config.js +153 -51
  120. package/dist/collection/components/snk-image-input/snk-image-input.css +3 -0
  121. package/dist/collection/components/snk-image-input/snk-image-input.js +338 -0
  122. package/dist/collection/components/snk-image-input/utils/ImageUtils.js +135 -0
  123. package/dist/collection/components/snk-layout-form-config/snk-layout-form-config.js +1 -1
  124. package/dist/collection/components/snk-layout-form-config/snk-view-representation/snk-view-representation.js +1 -1
  125. package/dist/collection/components/snk-personalized-filter/snk-personalized-filter.js +1 -1
  126. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-filter-param-config/utils/PersonalizedFilterUtils.js +13 -0
  127. package/dist/collection/components/snk-pesquisa/snk-pesquisa.js +0 -4
  128. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +35 -23
  129. package/dist/collection/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.css +8 -0
  130. package/dist/collection/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.js +38 -2
  131. package/dist/collection/components/snk-taskbar/elements/taskbar-elements.js +54 -37
  132. package/dist/collection/components/snk-taskbar/elements/taskbar-split-button/taskbar-split-button.js +27 -1
  133. package/dist/collection/components/snk-taskbar/processor/simple-taskbar-processor.js +55 -0
  134. package/dist/collection/components/snk-taskbar/snk-taskbar.css +44 -1
  135. package/dist/collection/components/snk-taskbar/snk-taskbar.js +248 -132
  136. package/dist/collection/components/snk-taskbar/subcomponents/snk-taskbar-skeleton.css +12 -0
  137. package/dist/collection/components/snk-taskbar/subcomponents/snk-taskbar-skeleton.js +19 -0
  138. package/dist/collection/lib/configs/ConfigStorage.js +5 -0
  139. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/cache/PreloadManager.js +40 -3
  140. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/dataunit-fetcher.js +24 -2
  141. package/dist/collection/lib/http/data-fetcher/fetchers/grid-config-fetcher.js +12 -0
  142. package/dist/collection/lib/http/data-fetcher/fetchers/resource-fetcher.js +18 -0
  143. package/dist/collection/lib/message/SnkMessageBuilder.js +11 -2
  144. package/dist/collection/lib/message/messageResourceEnUSUtils.js +2 -0
  145. package/dist/collection/lib/message/messageResourceEsESUtils.js +2 -0
  146. package/dist/collection/lib/message/messageResourcePtBRUtils.js +2 -0
  147. package/dist/collection/lib/message/resources/en-us/snk-crud.msg.js +9 -1
  148. package/dist/collection/lib/message/resources/en-us/snk-form.msg.js +1 -0
  149. package/dist/collection/lib/message/resources/en-us/snk-image-input.msg.js +11 -0
  150. package/dist/collection/lib/message/resources/en-us/snk-layout-form-config.msg.js +10 -2
  151. package/dist/collection/lib/message/resources/es-es/snk-crud.msg.js +9 -1
  152. package/dist/collection/lib/message/resources/es-es/snk-form.msg.js +1 -0
  153. package/dist/collection/lib/message/resources/es-es/snk-image-input.msg.js +11 -0
  154. package/dist/collection/lib/message/resources/es-es/snk-layout-form-config.msg.js +8 -0
  155. package/dist/collection/lib/message/resources/pt-br/snk-configurator.msg.js +1 -1
  156. package/dist/collection/lib/message/resources/pt-br/snk-crud.msg.js +9 -1
  157. package/dist/collection/lib/message/resources/pt-br/snk-form.msg.js +1 -0
  158. package/dist/collection/lib/message/resources/pt-br/snk-image-input.msg.js +11 -0
  159. package/dist/collection/lib/message/resources/pt-br/snk-layout-form-config.msg.js +10 -2
  160. package/dist/components/ConfigStorage.js +17 -0
  161. package/dist/components/ContinuousInsertUtils.js +1 -1
  162. package/dist/components/DataFetcher.js +3 -2731
  163. package/dist/components/PersonalizedFilterUtils.js +13 -0
  164. package/dist/components/SnkFormConfigManager.js +3 -3
  165. package/dist/components/SnkMessageBuilder.js +2831 -0
  166. package/dist/components/dataunit-fetcher.js +65 -5
  167. package/dist/components/field-config2.js +4 -2
  168. package/dist/components/fields-layout2.js +4 -4
  169. package/dist/components/form-config-fetcher.js +18 -0
  170. package/dist/components/guides-configurator2.js +2 -2
  171. package/dist/components/index.d.ts +4 -0
  172. package/dist/components/index.js +4 -0
  173. package/dist/components/index2.js +90 -21
  174. package/dist/components/snk-actions-button2.js +12 -6
  175. package/dist/components/snk-application2.js +22 -2
  176. package/dist/components/snk-attach2.js +70 -28
  177. package/dist/components/snk-configurator2.js +2 -0
  178. package/dist/components/snk-crud.js +433 -176
  179. package/dist/components/snk-custom-slot-guide.d.ts +11 -0
  180. package/dist/components/snk-custom-slot-guide.js +55 -0
  181. package/dist/components/snk-data-exporter2.js +3 -1
  182. package/dist/components/snk-data-unit2.js +10 -1
  183. package/dist/components/snk-detail-view2.js +213 -318
  184. package/dist/components/snk-entity-search.d.ts +11 -0
  185. package/dist/components/snk-entity-search.js +6 -0
  186. package/dist/components/snk-entity-search2.js +231 -0
  187. package/dist/components/snk-exporter-email-sender2.js +1 -1
  188. package/dist/components/snk-filter-bar2.js +116 -80
  189. package/dist/components/snk-filter-detail2.js +1 -1
  190. package/dist/components/snk-filter-item2.js +9 -3
  191. package/dist/components/snk-filter-modal2.js +22 -9
  192. package/dist/components/snk-filter-number.js +12 -8
  193. package/dist/components/snk-filter-period.js +13 -6
  194. package/dist/components/snk-filter-text.js +1 -1
  195. package/dist/components/snk-form-config2.js +15 -5
  196. package/dist/components/snk-form-view2.js +79 -10
  197. package/dist/components/snk-grid-config2.js +109 -50
  198. package/dist/components/snk-grid2.js +107 -63
  199. package/dist/components/snk-image-input.d.ts +11 -0
  200. package/dist/components/snk-image-input.js +6 -0
  201. package/dist/components/snk-image-input2.js +316 -0
  202. package/dist/components/snk-layout-form-config2.js +1 -1
  203. package/dist/components/snk-personalized-filter2.js +1 -1
  204. package/dist/components/snk-pesquisa2.js +0 -1
  205. package/dist/components/snk-simple-crud2.js +47 -46
  206. package/dist/components/snk-taskbar-skeleton.d.ts +11 -0
  207. package/dist/components/snk-taskbar-skeleton.js +6 -0
  208. package/dist/components/snk-taskbar-skeleton2.js +29 -0
  209. package/dist/components/snk-taskbar2.js +256 -176
  210. package/dist/components/snk-view-representation2.js +1 -1
  211. package/dist/components/sortable.esm.js +76 -90
  212. package/dist/components/taskbar-actions-button2.js +21 -2
  213. package/dist/components/taskbar-split-button2.js +10 -1
  214. package/dist/esm/{ConfigStorage-22324b6b.js → ConfigStorage-76872695.js} +19 -2
  215. package/dist/esm/ContinuousInsertUtils-bce77dc1.js +39 -0
  216. package/dist/esm/{DataFetcher-450828a0.js → DataFetcher-e60f8d53.js} +3 -2731
  217. package/dist/esm/{FormConfigHelper-e89ca25c.js → FormConfigHelper-d09669f3.js} +3 -1
  218. package/dist/esm/{ISave-61153166.js → ISave-4929c071.js} +1 -1
  219. package/dist/esm/ImageUtils-efbea0e4.js +138 -0
  220. package/dist/esm/{PersonalizedFilterUtils-2db38ff2.js → PersonalizedFilterUtils-d2439a9a.js} +13 -0
  221. package/dist/esm/{SnkFormConfigManager-b5a92e12.js → SnkFormConfigManager-83f6b22f.js} +5 -5
  222. package/dist/esm/SnkMessageBuilder-1eb7a1af.js +2831 -0
  223. package/dist/esm/{SnkMultiSelectionListDataSource-d7ce2e54.js → SnkMultiSelectionListDataSource-f6cabd15.js} +55 -41
  224. package/dist/esm/{auth-fetcher-eef9d01e.js → auth-fetcher-1a31c1e4.js} +1 -1
  225. package/dist/esm/config-header.entry.js +1 -1
  226. package/dist/esm/configs-button.entry.js +1 -1
  227. package/dist/esm/css-shim-9f2d321e.js +4 -0
  228. package/dist/esm/{dataunit-fetcher-da9596f6.js → dataunit-fetcher-c176e002.js} +65 -5
  229. package/dist/esm/dom-64053c71.js +73 -0
  230. package/dist/esm/field-config_2.entry.js +3 -3
  231. package/dist/esm/fields-layout.entry.js +6 -6
  232. package/dist/esm/fields-selector.entry.js +3 -3
  233. package/dist/esm/{form-config-fetcher-8d0a5e1c.js → form-config-fetcher-b44b2727.js} +19 -1
  234. package/dist/esm/guides-configurator.entry.js +3 -3
  235. package/dist/esm/{index-479e1293.js → index-04f73a26.js} +1521 -177
  236. package/dist/esm/{index-446f9341.js → index-ea250be6.js} +90 -21
  237. package/dist/esm/loader.js +17 -3
  238. package/dist/esm/pesquisa-grid_2.entry.js +6 -5
  239. package/dist/esm/sankhyablocks.js +133 -5
  240. package/dist/esm/shadow-css-98135883.js +387 -0
  241. package/dist/esm/snk-actions-button_9.entry.js +167 -117
  242. package/dist/esm/snk-actions-form.entry.js +1 -1
  243. package/dist/esm/snk-application.entry.js +28 -8
  244. package/dist/esm/snk-attach.entry.js +62 -24
  245. package/dist/esm/snk-client-confirm.entry.js +1 -1
  246. package/dist/esm/snk-configurator.entry.js +3 -1
  247. package/dist/esm/snk-crud.entry.js +342 -101
  248. package/dist/esm/snk-custom-slot-elements.entry.js +1 -1
  249. package/dist/esm/snk-custom-slot-guide.entry.js +36 -0
  250. package/dist/esm/snk-data-exporter.entry.js +9 -7
  251. package/dist/esm/{snk-data-unit-99616a07.js → snk-data-unit-d8cfa950.js} +12 -3
  252. package/dist/esm/snk-data-unit.entry.js +5 -4
  253. package/dist/esm/snk-default-filter.entry.js +1 -1
  254. package/dist/esm/snk-detail-view.entry.js +17 -18
  255. package/dist/esm/snk-entity-list.entry.js +1 -1
  256. package/dist/esm/snk-entity-search.entry.js +207 -0
  257. package/dist/esm/snk-exporter-email-sender.entry.js +2 -2
  258. package/dist/esm/snk-expression-group_2.entry.js +2 -2
  259. package/dist/esm/{snk-filter-advanced-mode_2.entry.js → snk-filter-advanced-mode_3.entry.js} +41 -4
  260. package/dist/esm/snk-filter-bar_4.entry.js +148 -95
  261. package/dist/esm/snk-filter-binary-select.entry.js +1 -1
  262. package/dist/esm/snk-filter-checkbox-list.entry.js +1 -1
  263. package/dist/esm/snk-filter-detail.entry.js +3 -3
  264. package/dist/esm/snk-filter-field-search_2.entry.js +2 -2
  265. package/dist/esm/snk-filter-modal-item.entry.js +5 -4
  266. package/dist/esm/snk-filter-multi-select.entry.js +1 -1
  267. package/dist/esm/snk-filter-number.entry.js +11 -7
  268. package/dist/esm/snk-filter-period.entry.js +14 -7
  269. package/dist/esm/snk-filter-search.entry.js +1 -1
  270. package/dist/esm/snk-filter-text.entry.js +2 -2
  271. package/dist/esm/snk-form-summary.entry.js +1 -1
  272. package/dist/esm/snk-form-view.entry.js +71 -9
  273. package/dist/esm/snk-form_2.entry.js +22 -11
  274. package/dist/esm/snk-grid.entry.js +64 -31
  275. package/dist/esm/{snk-guides-viewer-240de636.js → snk-guides-viewer-cc37535b.js} +79 -215
  276. package/dist/esm/snk-guides-viewer.entry.js +11 -18
  277. package/dist/esm/snk-image-input.entry.js +156 -0
  278. package/dist/esm/snk-layout-form-config.entry.js +68 -0
  279. package/dist/esm/snk-personalized-filter-editor.entry.js +1 -1
  280. package/dist/esm/snk-personalized-filter.entry.js +8 -7
  281. package/dist/esm/snk-pesquisa.entry.js +6 -6
  282. package/dist/esm/snk-print-selector.entry.js +1 -1
  283. package/dist/esm/snk-simple-crud.entry.js +28 -33
  284. package/dist/esm/snk-taskbar.entry.js +184 -127
  285. package/dist/esm/{sortable.esm-842f85a3.js → sortable.esm-bc277c12.js} +76 -90
  286. package/dist/esm/taskbar-elements-63651ca7.js +149 -0
  287. package/dist/esm/teste-pesquisa.entry.js +1 -1
  288. package/dist/sankhyablocks/{p-7f7fe6c4.entry.js → p-0a160fb5.entry.js} +1 -1
  289. package/dist/sankhyablocks/p-0afc64df.entry.js +1 -0
  290. package/dist/sankhyablocks/p-10f27dc6.entry.js +1 -0
  291. package/dist/sankhyablocks/p-134702f6.entry.js +1 -0
  292. package/dist/sankhyablocks/{p-162bddae.entry.js → p-175c9576.entry.js} +1 -1
  293. package/dist/sankhyablocks/p-20f03230.entry.js +1 -0
  294. package/dist/sankhyablocks/p-26f1919e.entry.js +1 -0
  295. package/dist/sankhyablocks/p-2af8aca3.js +1 -0
  296. package/dist/sankhyablocks/p-2c9d0870.js +2 -0
  297. package/dist/sankhyablocks/{p-cb4343c4.entry.js → p-2cc2526e.entry.js} +1 -1
  298. package/dist/sankhyablocks/{p-75af335e.entry.js → p-2ebda226.entry.js} +1 -1
  299. package/dist/sankhyablocks/p-3072136e.js +1 -0
  300. package/dist/sankhyablocks/p-33492640.entry.js +1 -0
  301. package/dist/sankhyablocks/{p-002d4d2b.js → p-3704bf1b.js} +1 -1
  302. package/dist/sankhyablocks/p-3870748a.js +28 -0
  303. package/dist/sankhyablocks/p-3a35917e.entry.js +1 -0
  304. package/dist/sankhyablocks/{p-7d6f1285.js → p-3c990841.js} +2 -2
  305. package/dist/sankhyablocks/{p-49ddc27a.entry.js → p-438a225f.entry.js} +1 -1
  306. package/dist/sankhyablocks/p-4d04bc75.entry.js +1 -0
  307. package/dist/sankhyablocks/{p-840fb68c.js → p-4f7adf97.js} +2 -2
  308. package/dist/sankhyablocks/p-554c0e54.js +1 -0
  309. package/dist/sankhyablocks/{p-27482793.entry.js → p-5aae5c74.entry.js} +1 -1
  310. package/dist/sankhyablocks/p-68c1a093.js +1 -0
  311. package/dist/sankhyablocks/p-6ae7543b.entry.js +1 -0
  312. package/dist/sankhyablocks/p-6e278003.js +60 -0
  313. package/dist/sankhyablocks/{p-825098c1.entry.js → p-752c57f4.entry.js} +1 -1
  314. package/dist/sankhyablocks/{p-e258de96.entry.js → p-76729994.entry.js} +1 -1
  315. package/dist/sankhyablocks/p-771b137e.js +1 -0
  316. package/dist/sankhyablocks/p-77f608bc.entry.js +1 -0
  317. package/dist/sankhyablocks/p-7ad91135.entry.js +1 -0
  318. package/dist/sankhyablocks/p-82bcb4cf.entry.js +1 -0
  319. package/dist/sankhyablocks/p-855ccf64.entry.js +1 -0
  320. package/dist/sankhyablocks/{p-118c221e.js → p-8b4d6719.js} +1 -1
  321. package/dist/sankhyablocks/{p-3d41f5a8.entry.js → p-8d946600.entry.js} +1 -1
  322. package/dist/sankhyablocks/p-8fe740b7.entry.js +11 -0
  323. package/dist/sankhyablocks/{p-96d45943.entry.js → p-90ae6c2e.entry.js} +1 -1
  324. package/dist/sankhyablocks/p-95af0bb1.entry.js +1 -0
  325. package/dist/sankhyablocks/{p-0b9a42ad.entry.js → p-9742ea0e.entry.js} +1 -1
  326. package/dist/sankhyablocks/{p-2fdac5e6.entry.js → p-9e109f5e.entry.js} +1 -1
  327. package/dist/sankhyablocks/p-9e77e136.js +1 -0
  328. package/dist/sankhyablocks/p-9e7dc97d.entry.js +1 -0
  329. package/dist/sankhyablocks/p-a2a9f520.entry.js +1 -0
  330. package/dist/sankhyablocks/p-a46ac091.js +1 -0
  331. package/dist/sankhyablocks/p-a73b6b00.js +1 -0
  332. package/dist/sankhyablocks/p-a905712a.entry.js +1 -0
  333. package/dist/sankhyablocks/{p-92cfc028.js → p-ab5e12fa.js} +1 -1
  334. package/dist/sankhyablocks/{p-180716b2.entry.js → p-ae326d06.entry.js} +1 -1
  335. package/dist/sankhyablocks/p-af673291.js +1 -0
  336. package/dist/sankhyablocks/p-aff2d081.entry.js +1 -0
  337. package/dist/sankhyablocks/p-b0a357b4.entry.js +1 -0
  338. package/dist/sankhyablocks/p-b555ce38.entry.js +1 -0
  339. package/dist/sankhyablocks/p-bab4cde4.entry.js +1 -0
  340. package/dist/sankhyablocks/p-c0d6a821.entry.js +1 -0
  341. package/dist/sankhyablocks/p-c3ec6642.js +19 -0
  342. package/dist/sankhyablocks/p-ca3728c0.entry.js +1 -0
  343. package/dist/sankhyablocks/p-cbb8e351.js +7 -0
  344. package/dist/sankhyablocks/{p-c3dbf441.entry.js → p-cc64239c.entry.js} +1 -1
  345. package/dist/sankhyablocks/{p-471b34f4.entry.js → p-cd00a3d1.entry.js} +1 -1
  346. package/dist/sankhyablocks/p-ce8ccd72.entry.js +1 -0
  347. package/dist/sankhyablocks/{p-4c763b10.entry.js → p-d657f71f.entry.js} +1 -1
  348. package/dist/sankhyablocks/p-d9ec8c4b.entry.js +1 -0
  349. package/dist/sankhyablocks/p-da455c82.js +12 -0
  350. package/dist/sankhyablocks/p-e5a3711f.js +1 -0
  351. package/dist/sankhyablocks/{p-9a63f3f7.entry.js → p-e737fd5a.entry.js} +1 -1
  352. package/dist/sankhyablocks/p-e8df1dea.entry.js +1 -0
  353. package/dist/sankhyablocks/p-ee56dda6.entry.js +1 -0
  354. package/dist/sankhyablocks/p-ef9343c3.entry.js +1 -0
  355. package/dist/sankhyablocks/{p-667cab42.entry.js → p-f152ef98.entry.js} +1 -1
  356. package/dist/sankhyablocks/p-f5ad0720.js +1 -0
  357. package/dist/sankhyablocks/{p-7e250432.entry.js → p-f7170e10.entry.js} +1 -1
  358. package/dist/sankhyablocks/{p-7345782c.entry.js → p-f921270b.entry.js} +1 -1
  359. package/dist/sankhyablocks/p-fec88660.entry.js +1 -0
  360. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  361. package/dist/types/components/snk-actions-button/snk-actions-button.d.ts +4 -0
  362. package/dist/types/components/snk-application/snk-application.d.ts +1 -1
  363. package/dist/types/components/snk-attach/snk-attach.d.ts +22 -4
  364. package/dist/types/components/snk-crud/snk-crud.d.ts +33 -11
  365. package/dist/types/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.d.ts +1 -1
  366. package/dist/types/components/snk-crud/subcomponents/snk-entity-search.d.ts +62 -0
  367. package/dist/types/components/snk-crud/subcomponents/snk-form-view.d.ts +12 -0
  368. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +13 -25
  369. package/dist/types/components/snk-crud/utils/taskbarUtils.d.ts +13 -0
  370. package/dist/types/components/snk-custom-slot-guide/snk-custom-slot-guide.d.ts +16 -0
  371. package/dist/types/components/snk-data-exporter/snk-data-exporter.d.ts +4 -0
  372. package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +1 -0
  373. package/dist/types/components/snk-filter-bar/filter-item/editors/snk-filter-number.d.ts +1 -1
  374. package/dist/types/components/snk-filter-bar/filter-item/editors/snk-filter-period.d.ts +1 -0
  375. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +5 -1
  376. package/dist/types/components/snk-filter-bar/filter-modal/snk-filter-modal.d.ts +2 -1
  377. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +33 -16
  378. package/dist/types/components/snk-form-config/FormConfigHelper.d.ts +1 -1
  379. package/dist/types/components/snk-form-config/fields-layout/fields-layout.d.ts +2 -2
  380. package/dist/types/components/snk-form-config/guides-configurator/guides-configurator.d.ts +1 -1
  381. package/dist/types/components/snk-form-config/snk-form-config.d.ts +2 -1
  382. package/dist/types/components/snk-grid/snk-grid.d.ts +29 -1
  383. package/dist/types/components/snk-grid-config/snk-grid-config.d.ts +11 -0
  384. package/dist/types/components/snk-image-input/snk-image-input.d.ts +57 -0
  385. package/dist/types/components/snk-image-input/utils/ImageUtils.d.ts +15 -0
  386. package/dist/types/components/snk-personalized-filter/interfaces/IParameter.d.ts +1 -0
  387. package/dist/types/components/snk-pesquisa/snk-pesquisa.d.ts +0 -1
  388. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +4 -1
  389. package/dist/types/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.d.ts +6 -0
  390. package/dist/types/components/snk-taskbar/elements/taskbar-elements.d.ts +29 -2
  391. package/dist/types/components/snk-taskbar/elements/taskbar-split-button/taskbar-split-button.d.ts +5 -0
  392. package/dist/types/components/snk-taskbar/processor/simple-taskbar-processor.d.ts +31 -0
  393. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +32 -21
  394. package/dist/types/components/snk-taskbar/subcomponents/snk-taskbar-skeleton.d.ts +3 -0
  395. package/dist/types/components.d.ts +347 -5
  396. package/dist/types/lib/configs/ConfigStorage.d.ts +1 -0
  397. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/cache/PreloadManager.d.ts +1 -0
  398. package/dist/types/lib/http/data-fetcher/fetchers/data-unit/dataunit-fetcher.d.ts +2 -1
  399. package/dist/types/lib/http/data-fetcher/fetchers/grid-config-fetcher.d.ts +1 -0
  400. package/dist/types/lib/http/data-fetcher/fetchers/resource-fetcher.d.ts +1 -0
  401. package/dist/types/lib/message/resources/en-us/snk-image-input.msg.d.ts +1 -0
  402. package/dist/types/lib/message/resources/es-es/snk-image-input.msg.d.ts +1 -0
  403. package/dist/types/lib/message/resources/pt-br/snk-image-input.msg.d.ts +1 -0
  404. package/package.json +7 -8
  405. package/react/components.d.ts +4 -0
  406. package/react/components.js +4 -0
  407. package/react/components.js.map +1 -1
  408. package/dist/cjs/snk-simple-bar.cjs.entry.js +0 -45
  409. package/dist/cjs/taskbar-elements-fb5d1e08.js +0 -132
  410. package/dist/cjs/taskbar-processor-2fba34a8.js +0 -53
  411. package/dist/esm/snk-simple-bar.entry.js +0 -41
  412. package/dist/esm/taskbar-elements-faaf5d8f.js +0 -129
  413. package/dist/esm/taskbar-processor-3436124c.js +0 -51
  414. package/dist/sankhyablocks/p-093f58fa.entry.js +0 -1
  415. package/dist/sankhyablocks/p-0948dc0a.entry.js +0 -11
  416. package/dist/sankhyablocks/p-1a0caadb.js +0 -1
  417. package/dist/sankhyablocks/p-1a9c5684.entry.js +0 -1
  418. package/dist/sankhyablocks/p-1d589380.entry.js +0 -1
  419. package/dist/sankhyablocks/p-21107f0d.entry.js +0 -1
  420. package/dist/sankhyablocks/p-28f50632.js +0 -1
  421. package/dist/sankhyablocks/p-39be771c.js +0 -1
  422. package/dist/sankhyablocks/p-3ed04f0d.entry.js +0 -1
  423. package/dist/sankhyablocks/p-4963dd2a.entry.js +0 -1
  424. package/dist/sankhyablocks/p-51833248.js +0 -7
  425. package/dist/sankhyablocks/p-55798617.js +0 -1
  426. package/dist/sankhyablocks/p-55f6fef2.entry.js +0 -1
  427. package/dist/sankhyablocks/p-56f16390.entry.js +0 -1
  428. package/dist/sankhyablocks/p-58683e28.js +0 -60
  429. package/dist/sankhyablocks/p-5ea893c5.entry.js +0 -1
  430. package/dist/sankhyablocks/p-60dd1d27.entry.js +0 -1
  431. package/dist/sankhyablocks/p-62aef37a.js +0 -1
  432. package/dist/sankhyablocks/p-62e9b9b8.entry.js +0 -1
  433. package/dist/sankhyablocks/p-669bb869.entry.js +0 -1
  434. package/dist/sankhyablocks/p-6ee2ca7a.entry.js +0 -1
  435. package/dist/sankhyablocks/p-7cac3870.entry.js +0 -1
  436. package/dist/sankhyablocks/p-86e54841.entry.js +0 -1
  437. package/dist/sankhyablocks/p-88b337fe.entry.js +0 -1
  438. package/dist/sankhyablocks/p-91005a00.entry.js +0 -1
  439. package/dist/sankhyablocks/p-91a9abb6.entry.js +0 -1
  440. package/dist/sankhyablocks/p-988afe78.js +0 -1
  441. package/dist/sankhyablocks/p-ada013c0.entry.js +0 -1
  442. package/dist/sankhyablocks/p-b7e891cc.entry.js +0 -1
  443. package/dist/sankhyablocks/p-b987e15d.js +0 -1
  444. package/dist/sankhyablocks/p-c35fc941.js +0 -26
  445. package/dist/sankhyablocks/p-c4fcf1fb.entry.js +0 -1
  446. package/dist/sankhyablocks/p-c98c79c3.entry.js +0 -1
  447. package/dist/sankhyablocks/p-cadf4846.entry.js +0 -1
  448. package/dist/sankhyablocks/p-d8d8169b.js +0 -2
  449. package/dist/sankhyablocks/p-e91c3c57.entry.js +0 -1
  450. package/dist/sankhyablocks/p-ea729922.entry.js +0 -1
  451. package/dist/sankhyablocks/p-ec5fbad8.js +0 -1
  452. package/dist/sankhyablocks/p-f5e942b7.entry.js +0 -1
@@ -57,6 +57,7 @@ export class SnkSimpleCrud {
57
57
  this.domainMessagesBuilder = undefined;
58
58
  this.multipleEditionEnabled = true;
59
59
  this.layoutFormConfig = true;
60
+ this.disableGridEdition = false;
60
61
  this.autoLoad = undefined;
61
62
  this.outlineMode = false;
62
63
  }
@@ -157,11 +158,10 @@ export class SnkSimpleCrud {
157
158
  }
158
159
  getButtons(selected, extraButtons, removeRefresh) {
159
160
  let btnList = selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS;
160
- if (removeRefresh) {
161
+ if (removeRefresh || this.mode === SIMPLE_CRUD_MODE.IN_MEMORY) {
161
162
  btnList = btnList.filter(item => item !== TaskbarElement.REFRESH);
162
163
  }
163
- return this.addConfigButton(this.resolveInMemoryBtns(btnList)
164
- .concat(extraButtons));
164
+ return this.addConfigButton(btnList.concat(extraButtons));
165
165
  }
166
166
  addConfigButton(buttons) {
167
167
  if (this.configName === undefined || (this.configName && this.gridLegacyConfigName)) {
@@ -172,13 +172,6 @@ export class SnkSimpleCrud {
172
172
  get application() {
173
173
  return ApplicationContext.getContextValue("__SNK__APPLICATION__");
174
174
  }
175
- resolveInMemoryBtns(taskbarButtons) {
176
- const newTaskBarConfig = [...taskbarButtons];
177
- if (this.mode === SIMPLE_CRUD_MODE.IN_MEMORY) {
178
- newTaskBarConfig.splice(1, 1);
179
- }
180
- return newTaskBarConfig;
181
- }
182
175
  /**
183
176
  * @description Usado para alternar a visão entre GRID e FORM externamente.
184
177
  * @param {VIEW_MODE} view - A visão para a qual navegar.
@@ -279,22 +272,23 @@ export class SnkSimpleCrud {
279
272
  }
280
273
  await this.loadFormConfig(true);
281
274
  }
282
- openConfig(viewMode) {
283
- this._snkConfigurator.close();
275
+ async openConfig(viewMode) {
276
+ await this._snkConfigurator.close();
284
277
  if (viewMode === VIEW_MODE.GRID) {
285
- this.openGridConfig();
278
+ await this.openGridConfig();
286
279
  }
287
280
  else if (viewMode === VIEW_MODE.FORM) {
288
- this.openFormConfig();
281
+ await this.openFormConfig();
289
282
  }
290
283
  }
291
- openGridConfig() {
292
- this._grid.getColumnsState()
293
- .then((gridColumns) => {
294
- this._snkGridConfig.columns = gridColumns.filter(c => c.name);
295
- this._snkGridConfig.selectedIndex = 0;
296
- this._showPopUpGridConfig = true;
297
- });
284
+ async openGridConfig() {
285
+ var _a, _b, _c, _d;
286
+ const originalColumns = (_b = await ((_a = this._grid) === null || _a === void 0 ? void 0 : _a.getColumns())) !== null && _b !== void 0 ? _b : [];
287
+ const gridColumns = (_d = await ((_c = this._grid) === null || _c === void 0 ? void 0 : _c.getColumnsState())) !== null && _d !== void 0 ? _d : [];
288
+ this._snkGridConfig.columns = gridColumns.filter(c => c.name);
289
+ this._snkGridConfig.originalColumns = originalColumns.filter(c => c.name);
290
+ this._snkGridConfig.selectedIndex = 0;
291
+ this._showPopUpGridConfig = true;
298
292
  }
299
293
  async openFormConfig() {
300
294
  if (this.formLegacyConfigName || this.configName) {
@@ -819,7 +813,7 @@ export class SnkSimpleCrud {
819
813
  }
820
814
  return (h("snk-data-unit", { ref: ref => this._snkDataUnit = ref, class: "simple-crud__container", dataUnit: this.dataUnit, useCancelConfirm: this.useCancelConfirm, onDataStateChange: evt => this.onDataStateChange(evt), onCancelEdition: this.handleCancelEdit.bind(this), pageSize: this.getPageSize(), onInsertionMode: this.handleDataUnitOnInsertionMode.bind(this), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail, onDataUnitFieldsHidded: this.updateFormConfig.bind(this), domainMessagesBuilder: this.domainMessagesBuilder }, h("header", null, h("slot", { name: "snkSimpleCrudHeader" })), h("section", { class: `ez-box ez-box--no-outline ${this.outlineMode ? 'ez-box--outline' : 'ez-box--shadow'} simple-crud__container-section`, ref: (ref) => this._container = ref, tabindex: "0" }, 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 ez-box--no-outline", 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)
821
815
  ? undefined
822
- : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab, autoFocus: this.autoFocus, enableGridInsert: this.enableGridInsert, enableContinuousInsert: this.enableContinuousInsert, enableLockManagerTaskbarClick: this.enableLockManagerTaskbarClick, enableLockManagerLoadingComp: this.enableLockManagerLoadingComp, outlineMode: this.outlineMode, tabindex: "0", paginationCounterMode: this.paginationCounterMode }, this.renderTaskbarContent(VIEW_MODE.GRID), h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, this.renderTaskbarContent(VIEW_MODE.FORM), h("ez-form", { ref: (ref) => this._form = ref, class: `ez-margin-top--large ez-box--no-outline`, dataUnit: this.dataUnit, config: this.getFormConfig(), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this), elementFocusSearchField: this._container, tabindex: "0" }), h("snk-simple-form-config", { ref: (ref) => this._snkSimpleFormConfig = ref, dataUnit: this.dataUnit, onSnkConfigSaved: this.handleFormConfigSaved.bind(this), configName: (_a = this.formLegacyConfigName) !== null && _a !== void 0 ? _a : this.configName, messagesBuilder: this.messagesBuilder })), 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.resolveResourceID(), customContainerId: this._customContainerId, layoutFormConfig: this.layoutFormConfig })), h("div", { id: `${this._customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }))), h("ez-popup", { size: "medium", heightMode: "auto", useHeader: false, opened: this._showPopUpGridConfig, onEzClosePopup: () => 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.resolveResourceID() }))));
816
+ : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab, autoFocus: this.autoFocus, enableGridInsert: this.enableGridInsert, enableContinuousInsert: this.enableContinuousInsert, enableLockManagerTaskbarClick: this.enableLockManagerTaskbarClick, enableLockManagerLoadingComp: this.enableLockManagerLoadingComp, outlineMode: this.outlineMode, tabindex: "0", paginationCounterMode: this.paginationCounterMode, canEdit: !this.disableGridEdition }, this.renderTaskbarContent(VIEW_MODE.GRID), h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, this.renderTaskbarContent(VIEW_MODE.FORM), h("ez-form", { ref: (ref) => this._form = ref, class: `ez-margin-top--large ez-box--no-outline`, dataUnit: this.dataUnit, config: this.getFormConfig(), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this), elementFocusSearchField: this._container, tabindex: "0" }), h("slot", { name: "snkSimpleCrudFormFooter" }), h("snk-simple-form-config", { ref: (ref) => this._snkSimpleFormConfig = ref, dataUnit: this.dataUnit, onSnkConfigSaved: this.handleFormConfigSaved.bind(this), configName: (_a = this.formLegacyConfigName) !== null && _a !== void 0 ? _a : this.configName, messagesBuilder: this.messagesBuilder })), 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.resolveResourceID(), customContainerId: this._customContainerId, layoutFormConfig: this.layoutFormConfig })), h("div", { id: `${this._customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }))), h("ez-popup", { size: "medium", heightMode: "auto", useHeader: false, opened: this._showPopUpGridConfig, onEzClosePopup: () => 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.resolveResourceID() }))));
823
817
  }
824
818
  static get is() { return "snk-simple-crud"; }
825
819
  static get encapsulation() { return "scoped"; }
@@ -879,7 +873,7 @@ export class SnkSimpleCrud {
879
873
  },
880
874
  "dataState": {
881
875
  "type": "unknown",
882
- "mutable": false,
876
+ "mutable": true,
883
877
  "complexType": {
884
878
  "original": "DataState",
885
879
  "resolved": "DataState",
@@ -1438,6 +1432,24 @@ export class SnkSimpleCrud {
1438
1432
  "reflect": false,
1439
1433
  "defaultValue": "true"
1440
1434
  },
1435
+ "disableGridEdition": {
1436
+ "type": "boolean",
1437
+ "mutable": false,
1438
+ "complexType": {
1439
+ "original": "boolean",
1440
+ "resolved": "boolean",
1441
+ "references": {}
1442
+ },
1443
+ "required": false,
1444
+ "optional": false,
1445
+ "docs": {
1446
+ "tags": [],
1447
+ "text": "Desabilita a edi\u00E7\u00E3o na grade."
1448
+ },
1449
+ "attribute": "disable-grid-edition",
1450
+ "reflect": false,
1451
+ "defaultValue": "false"
1452
+ },
1441
1453
  "autoLoad": {
1442
1454
  "type": "boolean",
1443
1455
  "mutable": false,
@@ -16,4 +16,12 @@
16
16
  position: absolute;
17
17
  display: block;
18
18
  min-width: var(--ez-dropdown--min-width);
19
+ top: 100%;
20
+ left: 0;
21
+ margin-top: 4px;
22
+ }
23
+
24
+ .ez-dropdown--open-left {
25
+ left: auto;
26
+ right: 0;
19
27
  }
@@ -2,9 +2,11 @@ import { h, Host } from '@stencil/core';
2
2
  export class TaskbarActionsButton {
3
3
  constructor() {
4
4
  this._showDropdown = false;
5
+ this._openToLeft = false;
5
6
  this.title = undefined;
6
7
  this.enabled = undefined;
7
8
  this.actions = undefined;
9
+ this.size = 'medium';
8
10
  }
9
11
  async handleKeyDown(event) {
10
12
  if (event.key === 'Escape' || event.key === 'Esc') {
@@ -18,6 +20,7 @@ export class TaskbarActionsButton {
18
20
  * Exibe a lista de ações.
19
21
  */
20
22
  async showActions() {
23
+ this.checkDropdownPosition();
21
24
  this._showDropdown = true;
22
25
  requestAnimationFrame(() => {
23
26
  this._element.scrollIntoView({ behavior: 'smooth', block: 'nearest', inline: 'nearest' });
@@ -36,8 +39,19 @@ export class TaskbarActionsButton {
36
39
  return this._showDropdown;
37
40
  }
38
41
  controlDropdown() {
42
+ if (!this._showDropdown) {
43
+ this.checkDropdownPosition();
44
+ }
39
45
  this._showDropdown = !this._showDropdown;
40
46
  }
47
+ checkDropdownPosition() {
48
+ const rect = this._element.getBoundingClientRect();
49
+ const viewportWidth = window.innerWidth;
50
+ const dropdownMinWidth = 150; // Largura mínima do dropdown
51
+ const spaceOnRight = viewportWidth - rect.right;
52
+ // Se não houver espaço suficiente à direita, abre para a esquerda
53
+ this._openToLeft = spaceOnRight < dropdownMinWidth;
54
+ }
41
55
  loadItems() {
42
56
  return this.actions.filter(action => action !== undefined).map(action => {
43
57
  var _a;
@@ -118,7 +132,10 @@ export class TaskbarActionsButton {
118
132
  this.taskbarActionsButtonDisconnected.emit();
119
133
  }
120
134
  render() {
121
- return (h(Host, null, h("div", { class: `${this.canShowDropdown() ? ' ez-elevation--16' : ''} ez-dropdown-container` }, h("ez-button", { title: this.title, mode: 'icon', iconName: 'dots-vertical', size: 'small', enabled: this.enabled, onClick: () => this.controlDropdown() }), this.canShowDropdown() && h("ez-dropdown", { class: `ez-dropdown--sticky`, items: this.loadItems(), onEzClick: (evt) => this.onSelectAction(evt.detail), onEzOutsideClick: () => this._showDropdown = false, itemBuilder: (item, level) => this.dropdownItemBuilder(item, level) }))));
135
+ return (h(Host, null, h("div", { class: `${this.canShowDropdown() ? ' ez-elevation--16' : ''} ez-dropdown-container` }, h("ez-tooltip", { message: this.title }, h("ez-button", { mode: 'icon', iconName: 'dots-vertical', isDisabled: !this.enabled, onClick: () => this.controlDropdown(), size: this.size })), this.canShowDropdown() && (h("ez-dropdown", { class: {
136
+ 'ez-dropdown--sticky': true,
137
+ 'ez-dropdown--open-left': this._openToLeft
138
+ }, items: this.loadItems(), onEzClick: (evt) => this.onSelectAction(evt.detail), onEzOutsideClick: () => this._showDropdown = false, itemBuilder: (item, level) => this.dropdownItemBuilder(item, level) })))));
122
139
  }
123
140
  static get is() { return "taskbar-actions-button"; }
124
141
  static get encapsulation() { return "scoped"; }
@@ -190,12 +207,31 @@ export class TaskbarActionsButton {
190
207
  "tags": [],
191
208
  "text": "Define a lista de a\u00E7\u00F5es."
192
209
  }
210
+ },
211
+ "size": {
212
+ "type": "string",
213
+ "mutable": false,
214
+ "complexType": {
215
+ "original": "'small' | 'medium' | 'large'",
216
+ "resolved": "\"large\" | \"medium\" | \"small\"",
217
+ "references": {}
218
+ },
219
+ "required": false,
220
+ "optional": false,
221
+ "docs": {
222
+ "tags": [],
223
+ "text": "Define o tamanho do bot\u00E3o, podendo ser 'small', 'medium' ou 'large'."
224
+ },
225
+ "attribute": "size",
226
+ "reflect": false,
227
+ "defaultValue": "'medium'"
193
228
  }
194
229
  };
195
230
  }
196
231
  static get states() {
197
232
  return {
198
- "_showDropdown": {}
233
+ "_showDropdown": {},
234
+ "_openToLeft": {}
199
235
  };
200
236
  }
201
237
  static get events() {
@@ -16,6 +16,7 @@ export var TaskbarElement;
16
16
  TaskbarElement["FORM_MODE"] = "FORM_MODE";
17
17
  TaskbarElement["MORE_OPTIONS"] = "MORE_OPTIONS";
18
18
  TaskbarElement["DIVIDER"] = "DIVIDER";
19
+ TaskbarElement["SPACER"] = "SPACER";
19
20
  TaskbarElement["CONFIGURATOR"] = "CONFIGURATOR";
20
21
  TaskbarElement["DATA_EXPORTER"] = "DATA_EXPORTER";
21
22
  TaskbarElement["ATTACH"] = "ATTACH";
@@ -34,92 +35,108 @@ export var VisibleWhenForbidden;
34
35
  (function (VisibleWhenForbidden) {
35
36
  VisibleWhenForbidden["CONFIGURATOR"] = "CONFIGURATOR";
36
37
  })(VisibleWhenForbidden || (VisibleWhenForbidden = {}));
37
- export const buildCustomButton = (def, className, dataElementId, action, isEnabled) => {
38
+ export const buildCustomButton = ({ def, className, dataElementId, action, isEnabled, size }) => {
38
39
  const { hint, text, iconName } = def;
39
40
  if (iconName) {
40
41
  if (text) {
41
- return iconTextButton(iconName, def.name, className, dataElementId, hint, text, action, isEnabled);
42
+ return iconTextButton({ iconName, element: def.name, className, dataElementId, title: hint, action, isEnabled, size });
42
43
  }
43
44
  else {
44
- return iconButton(iconName, def.name, className, dataElementId, hint, action, isEnabled);
45
+ return iconButton({ iconName, element: def.name, className, dataElementId, title: hint, action, isEnabled, size });
45
46
  }
46
47
  }
47
48
  else {
48
- return textButton(def.name, className, dataElementId, text, hint, action, isEnabled);
49
+ return textButton({ element: def.name, className, dataElementId, title: hint, action, isEnabled, size });
49
50
  }
50
51
  };
51
- export const buildElem = (element, className, dataElementId, getTitle, action, isEnabled, actions, dataExporterStoreKey, presentationMode) => {
52
- var _a;
52
+ export const buildElem = ({ element, className, dataElementId, getTitle, action, isEnabled, actions, dataExporterStoreKey, presentationMode, variant, size }) => {
53
+ var _a, _b;
53
54
  const title = getTitle(element);
55
+ const propertiesItem = {
56
+ element, className, dataElementId, title, action, isEnabled, actions, variant, size
57
+ };
54
58
  switch (element) {
55
59
  case TaskbarElement.PREVIOUS:
56
- return iconButton("chevron-left", element, className, dataElementId, title, action, isEnabled);
60
+ return iconButton(Object.assign({ iconName: "chevron-left" }, propertiesItem));
57
61
  case TaskbarElement.NEXT:
58
- return iconButton("chevron-right", element, className, dataElementId, title, action, isEnabled);
62
+ return iconButton(Object.assign({ iconName: "chevron-right" }, propertiesItem));
59
63
  case TaskbarElement.REFRESH:
60
- return iconButton("sync", element, className, dataElementId, title, action, isEnabled);
64
+ return iconButton(Object.assign({ iconName: "sync" }, propertiesItem));
61
65
  case TaskbarElement.UPDATE:
62
- return iconButton("edit", element, className, dataElementId, title, action, isEnabled);
66
+ return iconButton(Object.assign({ iconName: "edit" }, propertiesItem));
63
67
  case TaskbarElement.UPDATE_MULTIPLE:
64
- return iconButton("edit-table", element, className, dataElementId, title, action, isEnabled);
68
+ return iconButton(Object.assign({ iconName: "edit-table" }, propertiesItem));
65
69
  case TaskbarElement.CLONE:
66
- return iconButton("copy", element, className, dataElementId, title, action, isEnabled);
70
+ return iconButton(Object.assign({ iconName: "copy" }, propertiesItem));
67
71
  case TaskbarElement.REMOVE:
68
- return iconButton("delete", element, className, dataElementId, title, action, isEnabled);
72
+ return iconButton(Object.assign({ iconName: "delete" }, propertiesItem));
69
73
  case TaskbarElement.INSERT:
70
74
  if (presentationMode === PresentationMode.PRIMARY) {
71
- return iconTextButton("plus", element, className, dataElementId, title, title, action, isEnabled);
75
+ return textButton(Object.assign({}, propertiesItem));
72
76
  }
73
77
  else {
74
- return iconButton("plus", element, className, dataElementId, title, action, isEnabled);
78
+ return iconButton(Object.assign({ iconName: "plus" }, propertiesItem));
75
79
  }
76
80
  case TaskbarElement.CANCEL:
77
- return textButton(element, className, dataElementId, title, title, action, isEnabled);
81
+ return textButton(Object.assign({}, propertiesItem));
78
82
  case TaskbarElement.SAVE:
79
83
  if (presentationMode === PresentationMode.PRIMARY) {
80
- return iconTextButton("save", element, className, dataElementId, title, title, action, isEnabled);
84
+ return iconTextButton(Object.assign(Object.assign({ iconName: "save" }, propertiesItem), { variant: "primary" }));
81
85
  }
82
86
  else {
83
- return iconButton("save", element, className, dataElementId, title, action, isEnabled);
87
+ return iconButton(Object.assign(Object.assign({ iconName: "save" }, propertiesItem), { variant: "primary" }));
84
88
  }
85
89
  case TaskbarElement.GRID_MODE:
86
- return iconButton("table", element, className, dataElementId, title, action, isEnabled);
90
+ return iconButton(Object.assign({ iconName: "table" }, propertiesItem));
87
91
  case TaskbarElement.FORM_MODE:
88
- return iconButton("list", element, className, dataElementId, title, action, isEnabled);
92
+ return iconButton(Object.assign({ iconName: "list" }, propertiesItem));
89
93
  case TaskbarElement.CONFIGURATOR:
90
94
  if ((actions === null || actions === void 0 ? void 0 : actions.length) > 0) {
91
- return splitButton("settings-inverted", element, className, title, dataElementId, isEnabled, actions, action);
95
+ return splitButton(Object.assign({ iconName: "settings-inverted" }, propertiesItem));
92
96
  }
93
- return iconButton("settings-inverted", element, className, dataElementId, title, action, isEnabled);
97
+ return iconButton(Object.assign({ iconName: "settings-inverted" }, propertiesItem));
94
98
  case TaskbarElement.MORE_OPTIONS:
95
- return actionButton(element, className, dataElementId, title, isEnabled, actions, action);
99
+ const definedActions = (_a = actions === null || actions === void 0 ? void 0 : actions.filter(a => a !== undefined)) !== null && _a !== void 0 ? _a : [];
100
+ return actionButton(Object.assign(Object.assign({}, propertiesItem), { actions: definedActions }));
96
101
  case TaskbarElement.DIVIDER:
97
102
  return h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin--none ez-margin-left--medium", "data-taskbar-divider": true });
98
103
  case TaskbarElement.DATA_EXPORTER:
99
- const provider = (_a = store.get("exporterProviders")) === null || _a === void 0 ? void 0 : _a[dataExporterStoreKey];
100
- return h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId, "data-taskbar-element": element });
104
+ const provider = (_b = store.get("exporterProviders")) === null || _b === void 0 ? void 0 : _b[dataExporterStoreKey];
105
+ return h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId, "data-taskbar-element": element, size: size });
101
106
  case TaskbarElement.ATTACH:
102
- return iconButton("anexo", element, className, dataElementId, title, action, isEnabled);
107
+ return iconButton(Object.assign({ iconName: "anexo" }, propertiesItem));
103
108
  case TaskbarElement.ACTIONS_BUTTON:
104
- return h("snk-actions-button", { "data-element-id": dataElementId, "data-taskbar-element": element });
109
+ return h("snk-actions-button", { "data-element-id": dataElementId, "data-taskbar-element": element, class: className, size: size });
105
110
  }
106
111
  };
107
- function textButton(name, className, dataElementId, text, title, action, isEnabled) {
108
- 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) });
112
+ function textButton({ action, className, dataElementId, title, element, isEnabled, variant, size }) {
113
+ return (h("ez-tooltip", { key: dataElementId, message: title, class: className }, h("ez-button", { label: title, "data-taskbar-label": title, "data-taskbar-element": element, "data-element-id": dataElementId, isDisabled: !isEnabled(element), onClick: () => action(element), variant: variant, size: size })));
109
114
  }
110
- function iconButton(iconName, name, className, dataElementId, title, action, isEnabled) {
111
- 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) });
115
+ function concatClass(className) {
116
+ if (typeof className === "string") {
117
+ return className;
118
+ }
119
+ else {
120
+ return Object.keys(className).filter(key => className[key]).join(" ");
121
+ }
122
+ }
123
+ function iconButton({ iconName, element, className, dataElementId, title, action, isEnabled, variant, size }) {
124
+ return (h("ez-tooltip", { key: dataElementId, message: title, class: {
125
+ [concatClass(className)]: true,
126
+ [`icon-button--${size}`]: true
127
+ } }, h("ez-button", { mode: "icon", "data-taskbar-label": title, "data-taskbar-element": element, "data-taskbar-icon": iconName, "data-element-id": dataElementId, iconName: iconName, isDisabled: !isEnabled(element), onClick: () => action(element), variant: variant, size: size })));
112
128
  }
113
- function iconTextButton(iconName, name, className, dataElementId, text, title, action, isEnabled) {
114
- 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 }));
129
+ function iconTextButton({ iconName, element, className, dataElementId, title, action, isEnabled, variant, size }) {
130
+ return (h("ez-tooltip", { key: dataElementId, message: title, class: className }, h("ez-button", { label: title, "data-taskbar-label": title, "data-taskbar-icon": iconName, "data-taskbar-element": element, "data-element-id": dataElementId, isDisabled: !isEnabled(element), onClick: () => action(element), variant: variant, size: size }, h("ez-icon", { class: "ez-padding-right--small", slot: "leftIcon", iconName: iconName }))));
115
131
  }
116
- function splitButton(iconName, element, className, title, dataElementId, isEnabled, actions, action) {
132
+ function splitButton({ iconName, element, className, title, dataElementId, isEnabled, actions, action, size }) {
117
133
  return actions && actions.length > 0
118
- ? h("taskbar-split-button", { iconName: iconName, class: className, key: dataElementId, "data-taskbar-icon": iconName, "data-taskbar-label": title, "data-taskbar-element": element, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, title: title, action: () => action(element) })
134
+ ?
135
+ h("taskbar-split-button", { key: dataElementId, class: className, iconName: iconName, "data-taskbar-icon": iconName, "data-taskbar-label": title, title: title, "data-taskbar-element": element, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, action: () => action(element), size: size })
119
136
  : undefined;
120
137
  }
121
- function actionButton(element, className, dataElementId, title, isEnabled, actions, action) {
138
+ function actionButton({ element, className, dataElementId, title, isEnabled, actions, action, size }) {
122
139
  return actions && actions.length > 0
123
- ? 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) })
140
+ ? 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), size: size })
124
141
  : undefined;
125
142
  }
@@ -10,6 +10,7 @@ export class TaskbarSplitButton {
10
10
  this.title = undefined;
11
11
  this.enabled = undefined;
12
12
  this.actions = undefined;
13
+ this.size = 'medium';
13
14
  }
14
15
  initializeEagerItems() {
15
16
  var _a;
@@ -50,8 +51,15 @@ export class TaskbarSplitButton {
50
51
  };
51
52
  });
52
53
  }
54
+ // Padroniza o tamanho do split button para se adequar aos demais tamanhos dos botões do taskbar
55
+ ajustSizeButton() {
56
+ if (!this.size || this.size === 'small') {
57
+ return 'medium';
58
+ }
59
+ return 'large';
60
+ }
53
61
  render() {
54
- return (h(Host, null, h("ez-split-button", { ref: (ref) => this._splitButtonRef = ref, key: this.dataElementId, class: `${this.className} "ez-split-button--tertiary ez-padding--medium"`, items: this.loadItems(), mode: "icon-only", iconName: this.iconName, enabled: this.enabled, show: this._showDropdown, onButtonClick: () => this.action(this.name), itemBuilder: (item, level) => this.dropdownItemBuilder(item, level) })));
62
+ return (h(Host, null, h("ez-split-button", { ref: (ref) => this._splitButtonRef = ref, key: this.dataElementId, class: `${this.className} "ez-split-button--tertiary ez-padding--medium"`, items: this.loadItems(), mode: "icon-only", size: this.ajustSizeButton(), leftIconName: this.iconName, isDisabled: !this.enabled, show: this._showDropdown, onButtonClick: () => this.action(this.name), itemBuilder: (item, level) => this.dropdownItemBuilder(item, level), leftTitle: this.title })));
55
63
  }
56
64
  static get is() { return "taskbar-split-button"; }
57
65
  static get encapsulation() { return "scoped"; }
@@ -209,6 +217,24 @@ export class TaskbarSplitButton {
209
217
  "tags": [],
210
218
  "text": "Define a lista de a\u00E7\u00F5es dispon\u00EDveis no dropdown do bot\u00E3o."
211
219
  }
220
+ },
221
+ "size": {
222
+ "type": "string",
223
+ "mutable": false,
224
+ "complexType": {
225
+ "original": "'small' | 'medium' | 'large'",
226
+ "resolved": "\"large\" | \"medium\" | \"small\"",
227
+ "references": {}
228
+ },
229
+ "required": false,
230
+ "optional": false,
231
+ "docs": {
232
+ "tags": [],
233
+ "text": "Define o tamanho do bot\u00E3o, podendo ser 'small', 'medium' ou 'large'."
234
+ },
235
+ "attribute": "size",
236
+ "reflect": false,
237
+ "defaultValue": "'medium'"
212
238
  }
213
239
  };
214
240
  }
@@ -0,0 +1,55 @@
1
+ export default class SimpleTaskbarProcessor {
2
+ /**
3
+ * Cria uma nova instância do processador de taskbar.
4
+ * @param defaultButtons - Array com os botões padrão a serem exibidos
5
+ */
6
+ constructor(defaultButtons) {
7
+ this._defaultButtons = [];
8
+ this._defaultButtons = [...defaultButtons];
9
+ }
10
+ /**
11
+ * Processa a taskbar aplicando regras de visibilidade e habilitação.
12
+ * @param taskbarID - Identificador único da taskbar
13
+ * @param taskbarManager - Gerenciador de taskbar com regras customizadas
14
+ * @param dataState - Estado atual dos dados
15
+ * @param disabledButtons - Array de botões desabilitados
16
+ * @param invisibleButtons - Array de botões invisíveis
17
+ */
18
+ process(taskbarID, taskbarManager, dataState, disabledButtons = [], invisibleButtons = []) {
19
+ var _a;
20
+ this.taskbarID = taskbarID;
21
+ this.customButtons = new Map();
22
+ this.buttonsArray = [];
23
+ this.disabledButtons = [...disabledButtons];
24
+ (_a = this.getButtonsArray(taskbarManager, dataState)) === null || _a === void 0 ? void 0 : _a.forEach((btnDef) => {
25
+ let buttonName;
26
+ if (typeof btnDef === "string") {
27
+ buttonName = btnDef;
28
+ }
29
+ else {
30
+ this.customButtons.set(btnDef.name, btnDef);
31
+ buttonName = btnDef.name;
32
+ }
33
+ if (!invisibleButtons.includes(buttonName)) {
34
+ if (!this.isEnabled(taskbarManager, buttonName, dataState, disabledButtons)) {
35
+ this.disabledButtons.push(buttonName);
36
+ }
37
+ this.buttonsArray.push(buttonName);
38
+ }
39
+ });
40
+ this.buttons = this.buttonsArray.join(",");
41
+ }
42
+ getButtonsArray(taskbarManager, dataState) {
43
+ if (taskbarManager) {
44
+ return taskbarManager.getButtons(this.taskbarID, dataState, [...this._defaultButtons]);
45
+ }
46
+ return this._defaultButtons;
47
+ }
48
+ isEnabled(taskbarManager, buttonName, dataState, disabled) {
49
+ const originalValue = !disabled.includes(buttonName);
50
+ if (taskbarManager && taskbarManager.isEnabled) {
51
+ return taskbarManager.isEnabled(this.taskbarID, dataState, buttonName, originalValue);
52
+ }
53
+ return originalValue;
54
+ }
55
+ }
@@ -1,6 +1,6 @@
1
1
  :host {
2
2
  display: flex;
3
- flex-wrap: wrap;
3
+ flex-wrap: nowrap;
4
4
  }
5
5
 
6
6
  :host.no-wrap {
@@ -18,3 +18,46 @@
18
18
  .overflowed {
19
19
  display: none;
20
20
  }
21
+
22
+ .taskbar-element {
23
+ width: auto;
24
+ }
25
+
26
+ .space-between-item {
27
+ margin-left: var(--space--8, 8px);
28
+ }
29
+
30
+ .icon-button--small {
31
+ width: 32px;
32
+ height: 32px;
33
+ }
34
+
35
+ .icon-button--medium {
36
+ width: 42px;
37
+ height: 42px;
38
+ }
39
+
40
+ .icon-button--large {
41
+ width: 46px;
42
+ height: 46px;
43
+ }
44
+
45
+ .taskbar-spacer {
46
+ flex: 1;
47
+ }
48
+
49
+ .taskbar-group {
50
+ display: flex;
51
+ flex-wrap: wrap;
52
+ min-width: 0;
53
+ }
54
+
55
+ .taskbar-group--start {
56
+ flex: 1 1 auto;
57
+ justify-content: flex-start;
58
+ }
59
+
60
+ .taskbar-group--end {
61
+ flex: 0 0 auto;
62
+ justify-content: flex-end;
63
+ }