@sankhyalabs/sankhyablocks 8.15.0-rc.9 → 8.15.1-rc.1

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 (231) hide show
  1. package/dist/cjs/{ConfigStorage-d4c99a5e.js → ConfigStorage-942ce74b.js} +70 -7
  2. package/dist/cjs/{DataFetcher-99f0f6ed.js → DataFetcher-313debd8.js} +13 -5
  3. package/dist/cjs/{SnkFormConfigManager-3621bfc4.js → SnkFormConfigManager-f9dc0d28.js} +21 -13
  4. package/dist/cjs/{SnkMessageBuilder-141aa18d.js → SnkMessageBuilder-66aa2557.js} +4 -0
  5. package/dist/cjs/SnkMultiSelectionListDataSource-303e85d1.js +140 -0
  6. package/dist/cjs/{auth-fetcher-5161d082.js → auth-fetcher-54f5ff9d.js} +1 -1
  7. package/dist/cjs/{form-config-fetcher-9f1a13ca.js → form-config-fetcher-2dd00e5b.js} +13 -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-8bbee432.js → pesquisa-fetcher-213797ec.js} +273 -50
  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} +519 -4
  13. package/dist/cjs/snk-application.cjs.entry.js +19 -11
  14. package/dist/cjs/snk-attach.cjs.entry.js +66 -46
  15. package/dist/cjs/snk-configurator.cjs.entry.js +1 -1
  16. package/dist/cjs/snk-crud.cjs.entry.js +25 -17
  17. package/dist/cjs/snk-custom-slot-elements.cjs.entry.js +6 -2
  18. package/dist/cjs/snk-data-exporter.cjs.entry.js +5 -5
  19. package/dist/cjs/{snk-data-unit-6026a9f7.js → snk-data-unit-41c29713.js} +1 -1
  20. package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
  21. package/dist/cjs/snk-detail-view.cjs.entry.js +8 -9
  22. package/dist/cjs/snk-filter-bar.cjs.entry.js +31 -7
  23. package/dist/cjs/snk-filter-detail.cjs.entry.js +4 -1
  24. package/dist/cjs/snk-filter-item.cjs.entry.js +10 -6
  25. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  26. package/dist/cjs/snk-form-config.cjs.entry.js +8 -2
  27. package/dist/cjs/snk-form.cjs.entry.js +11 -4
  28. package/dist/cjs/snk-grid.cjs.entry.js +40 -21
  29. package/dist/cjs/{snk-guides-viewer-e87f01b9.js → snk-guides-viewer-4b6ecda8.js} +20 -11
  30. package/dist/cjs/snk-guides-viewer.cjs.entry.js +6 -7
  31. package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
  32. package/dist/cjs/snk-simple-crud.cjs.entry.js +255 -21
  33. package/dist/cjs/snk-taskbar.cjs.entry.js +69 -8
  34. package/dist/collection/collection-manifest.json +6 -6
  35. package/dist/collection/components/snk-application/snk-application.js +55 -6
  36. package/dist/collection/components/snk-attach/snk-attach.js +39 -24
  37. package/dist/collection/components/snk-attach/structure/builder/attach-crud-config.builder.js +1 -1
  38. package/dist/collection/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.js +29 -22
  39. package/dist/collection/components/snk-configurator/snk-configurator.js +1 -1
  40. package/dist/collection/components/snk-crud/snk-crud.js +71 -11
  41. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +2 -2
  42. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +50 -7
  43. package/dist/collection/components/snk-custom-slot-elements/snk-custom-slot-elements.css +1 -1
  44. package/dist/collection/components/snk-custom-slot-elements/snk-custom-slot-elements.js +22 -1
  45. package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +2 -2
  46. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-detail.js +22 -1
  47. package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.js +28 -6
  48. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +2 -1
  49. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +44 -3
  50. package/dist/collection/components/snk-form/snk-form.js +25 -1
  51. package/dist/collection/components/{snk-form → snk-form-config}/SnkFormConfigManager.js +20 -12
  52. package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.js +11 -5
  53. package/dist/collection/components/snk-grid/snk-grid.js +86 -16
  54. package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.js +130 -123
  55. package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.js +1 -1
  56. package/dist/collection/components/snk-simple-crud/regular-buttons.js +3 -0
  57. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +10 -2
  58. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +421 -17
  59. package/dist/collection/components/snk-taskbar/snk-taskbar.js +86 -8
  60. package/dist/collection/lib/configs/ConfigStorage.js +63 -3
  61. package/dist/collection/lib/dataUnit/InMemoryLoader.js +9 -40
  62. package/dist/collection/lib/dataUnit/dataUnitInMemoryUtils.js +33 -0
  63. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +13 -5
  64. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +12 -0
  65. package/dist/collection/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.js +6 -3
  66. package/dist/collection/lib/message/SnkMessageBuilder.js +20 -20
  67. package/dist/collection/lib/message/resources/snk-simple-crud.msg.js +4 -0
  68. package/dist/collection/lib/utils/CrudUtils.js +13 -1
  69. package/dist/components/ConfigStorage.js +68 -5
  70. package/dist/components/DataFetcher.js +13 -5
  71. package/dist/components/SnkFormConfigManager.js +19 -11
  72. package/dist/components/SnkMessageBuilder.js +4 -0
  73. package/dist/components/dataunit-fetcher.js +41 -39
  74. package/dist/components/field-search.js +93 -3
  75. package/dist/components/form-config-fetcher.js +12 -0
  76. package/dist/components/index.d.ts +6 -6
  77. package/dist/components/snk-application2.js +15 -4
  78. package/dist/components/snk-attach2.js +115 -52
  79. package/dist/components/snk-configurator2.js +1 -1
  80. package/dist/components/snk-crud.js +23 -11
  81. package/dist/components/snk-custom-slot-elements.js +7 -3
  82. package/dist/components/snk-data-exporter2.js +2 -2
  83. package/dist/components/snk-detail-view2.js +48 -11
  84. package/dist/components/snk-filter-bar2.js +29 -4
  85. package/dist/components/snk-filter-detail2.js +5 -1
  86. package/dist/components/snk-filter-item2.js +11 -6
  87. package/dist/components/snk-form-config2.js +7 -1
  88. package/dist/components/snk-form.js +8 -0
  89. package/dist/components/snk-grid-config2.js +128 -102
  90. package/dist/components/snk-grid2.js +42 -18
  91. package/dist/components/snk-simple-crud2.js +317 -29
  92. package/dist/components/snk-taskbar2.js +75 -11
  93. package/dist/esm/{ConfigStorage-39ed8aeb.js → ConfigStorage-86187da3.js} +70 -7
  94. package/dist/esm/{DataFetcher-a650ae58.js → DataFetcher-c1baf61d.js} +13 -5
  95. package/dist/esm/{SnkFormConfigManager-692e20c7.js → SnkFormConfigManager-f53f9f87.js} +21 -13
  96. package/dist/esm/{SnkMessageBuilder-9747ddd2.js → SnkMessageBuilder-0a4becdd.js} +4 -0
  97. package/dist/esm/SnkMultiSelectionListDataSource-36918dbf.js +133 -0
  98. package/dist/esm/{auth-fetcher-17dc5b5e.js → auth-fetcher-039abba3.js} +1 -1
  99. package/dist/esm/{form-config-fetcher-f121f880.js → form-config-fetcher-30fb808f.js} +13 -1
  100. package/dist/esm/index-a7d3d3f1.js +2 -10
  101. package/dist/esm/loader.js +1 -1
  102. package/dist/esm/{pesquisa-fetcher-5a8cae10.js → pesquisa-fetcher-fe6f3826.js} +262 -43
  103. package/dist/esm/sankhyablocks.js +1 -1
  104. package/dist/esm/{snk-actions-button_2.entry.js → snk-actions-button_4.entry.js} +518 -5
  105. package/dist/esm/snk-application.entry.js +19 -11
  106. package/dist/esm/snk-attach.entry.js +65 -45
  107. package/dist/esm/snk-configurator.entry.js +1 -1
  108. package/dist/esm/snk-crud.entry.js +25 -17
  109. package/dist/esm/snk-custom-slot-elements.entry.js +7 -3
  110. package/dist/esm/snk-data-exporter.entry.js +5 -5
  111. package/dist/esm/{snk-data-unit-4c343635.js → snk-data-unit-de1d140d.js} +1 -1
  112. package/dist/esm/snk-data-unit.entry.js +2 -2
  113. package/dist/esm/snk-detail-view.entry.js +8 -9
  114. package/dist/esm/snk-filter-bar.entry.js +31 -7
  115. package/dist/esm/snk-filter-detail.entry.js +4 -1
  116. package/dist/esm/snk-filter-item.entry.js +10 -6
  117. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  118. package/dist/esm/snk-form-config.entry.js +9 -3
  119. package/dist/esm/snk-form.entry.js +11 -4
  120. package/dist/esm/snk-grid.entry.js +41 -22
  121. package/dist/esm/{snk-guides-viewer-ba8ce538.js → snk-guides-viewer-113be3fd.js} +20 -11
  122. package/dist/esm/snk-guides-viewer.entry.js +6 -7
  123. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  124. package/dist/esm/snk-simple-crud.entry.js +256 -22
  125. package/dist/esm/snk-taskbar.entry.js +70 -9
  126. package/dist/sankhyablocks/p-032fe52e.js +1 -0
  127. package/dist/sankhyablocks/p-07a61550.entry.js +1 -0
  128. package/dist/sankhyablocks/p-0899e0b5.entry.js +1 -0
  129. package/dist/sankhyablocks/p-14a08904.entry.js +1 -0
  130. package/dist/sankhyablocks/p-154a7f33.entry.js +1 -0
  131. package/dist/sankhyablocks/p-15802c59.entry.js +1 -0
  132. package/dist/sankhyablocks/p-164666b1.js +65 -0
  133. package/dist/sankhyablocks/p-21a81901.entry.js +1 -0
  134. package/dist/sankhyablocks/p-32556aa6.js +1 -0
  135. package/dist/sankhyablocks/p-328585d0.entry.js +1 -0
  136. package/dist/sankhyablocks/{p-9a5d1b39.js → p-52c8e589.js} +1 -1
  137. package/dist/sankhyablocks/p-54a5d52a.entry.js +1 -0
  138. package/dist/sankhyablocks/p-5cb07080.js +1 -0
  139. package/dist/sankhyablocks/p-74d349c3.entry.js +1 -0
  140. package/dist/sankhyablocks/p-7663f597.entry.js +1 -0
  141. package/dist/sankhyablocks/p-7fe120b8.entry.js +11 -0
  142. package/dist/sankhyablocks/{p-50783a8b.js → p-913a9979.js} +1 -1
  143. package/dist/sankhyablocks/{p-827e4b01.entry.js → p-a1d72395.entry.js} +1 -1
  144. package/dist/sankhyablocks/p-add17f6a.entry.js +1 -0
  145. package/dist/sankhyablocks/p-af1ac81f.entry.js +1 -0
  146. package/dist/sankhyablocks/p-aff76a53.js +56 -0
  147. package/dist/sankhyablocks/p-b4525fc0.entry.js +1 -0
  148. package/dist/sankhyablocks/p-cce0865d.js +1 -0
  149. package/dist/sankhyablocks/{p-be75153c.js → p-dc7c9047.js} +1 -1
  150. package/dist/sankhyablocks/p-dec65f6c.entry.js +1 -0
  151. package/dist/sankhyablocks/p-df5451c7.js +26 -0
  152. package/dist/sankhyablocks/p-e8763234.entry.js +1 -0
  153. package/dist/sankhyablocks/{p-9d608b62.entry.js → p-eae7a817.entry.js} +1 -1
  154. package/dist/sankhyablocks/{p-20b46647.entry.js → p-ee9536bc.entry.js} +1 -1
  155. package/dist/sankhyablocks/p-f13f7616.entry.js +1 -0
  156. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  157. package/dist/types/components/snk-application/snk-application.d.ts +9 -1
  158. package/dist/types/components/snk-attach/snk-attach.d.ts +2 -1
  159. package/dist/types/components/snk-attach/structure/builder/attach-crud-config.builder.d.ts +10 -1
  160. package/dist/types/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.d.ts +5 -4
  161. package/dist/types/components/snk-crud/snk-crud.d.ts +12 -0
  162. package/dist/types/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.d.ts +1 -1
  163. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +11 -1
  164. package/dist/types/components/snk-custom-slot-elements/snk-custom-slot-elements.d.ts +6 -0
  165. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-detail.d.ts +4 -0
  166. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +6 -2
  167. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +8 -0
  168. package/dist/types/components/snk-form/snk-form.d.ts +6 -1
  169. package/dist/types/components/{snk-form → snk-form-config}/SnkFormConfigManager.d.ts +2 -1
  170. package/dist/types/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.d.ts +4 -3
  171. package/dist/types/components/snk-grid/snk-grid.d.ts +14 -1
  172. package/dist/types/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.d.ts +11 -6
  173. package/dist/types/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.d.ts +1 -1
  174. package/dist/types/components/snk-simple-crud/regular-buttons.d.ts +3 -0
  175. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +76 -3
  176. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +11 -0
  177. package/dist/types/components.d.ts +172 -11
  178. package/dist/types/lib/configs/ConfigStorage.d.ts +21 -1
  179. package/dist/types/lib/dataUnit/InMemoryLoader.d.ts +0 -2
  180. package/dist/types/lib/dataUnit/dataUnitInMemoryUtils.d.ts +4 -0
  181. package/dist/types/lib/http/data-fetcher/fetchers/form-config-fetcher.d.ts +2 -0
  182. package/dist/types/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.d.ts +2 -1
  183. package/dist/types/lib/utils/CrudUtils.d.ts +3 -0
  184. package/package.json +1 -1
  185. package/dist/cjs/PreloadManager-84466da6.js +0 -224
  186. package/dist/cjs/SnkMultiSelectionListDataSource-ba5838c2.js +0 -49
  187. package/dist/cjs/snk-grid-config.cjs.entry.js +0 -483
  188. package/dist/cjs/snk-select-box.cjs.entry.js +0 -25
  189. package/dist/esm/PreloadManager-c1c2f2b4.js +0 -222
  190. package/dist/esm/SnkMultiSelectionListDataSource-44494b0e.js +0 -43
  191. package/dist/esm/snk-grid-config.entry.js +0 -479
  192. package/dist/esm/snk-select-box.entry.js +0 -21
  193. package/dist/sankhyablocks/p-094c30cb.js +0 -1
  194. package/dist/sankhyablocks/p-1c55becf.entry.js +0 -1
  195. package/dist/sankhyablocks/p-230f5148.entry.js +0 -1
  196. package/dist/sankhyablocks/p-2936303b.js +0 -1
  197. package/dist/sankhyablocks/p-2e4eb644.entry.js +0 -1
  198. package/dist/sankhyablocks/p-3e2e2424.entry.js +0 -1
  199. package/dist/sankhyablocks/p-3e91d5ea.entry.js +0 -1
  200. package/dist/sankhyablocks/p-43de1258.entry.js +0 -1
  201. package/dist/sankhyablocks/p-4ce6cb02.entry.js +0 -11
  202. package/dist/sankhyablocks/p-5e681b7b.js +0 -65
  203. package/dist/sankhyablocks/p-5f74c859.entry.js +0 -1
  204. package/dist/sankhyablocks/p-67aedbe0.js +0 -56
  205. package/dist/sankhyablocks/p-69754d94.entry.js +0 -1
  206. package/dist/sankhyablocks/p-725d04ba.js +0 -1
  207. package/dist/sankhyablocks/p-86801b08.entry.js +0 -1
  208. package/dist/sankhyablocks/p-8a3a2631.entry.js +0 -1
  209. package/dist/sankhyablocks/p-965b79a9.js +0 -1
  210. package/dist/sankhyablocks/p-98674137.entry.js +0 -1
  211. package/dist/sankhyablocks/p-a13ccb86.js +0 -26
  212. package/dist/sankhyablocks/p-aba0e87f.entry.js +0 -1
  213. package/dist/sankhyablocks/p-c22c1d8e.js +0 -1
  214. package/dist/sankhyablocks/p-d26e0a02.entry.js +0 -1
  215. package/dist/sankhyablocks/p-d6317851.entry.js +0 -1
  216. package/dist/sankhyablocks/p-d7d85fa9.entry.js +0 -1
  217. package/dist/sankhyablocks/p-e3bd000e.entry.js +0 -1
  218. package/dist/sankhyablocks/p-e7dbe53a.entry.js +0 -1
  219. package/dist/sankhyablocks/p-fcdcb0e2.entry.js +0 -1
  220. /package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.css +0 -0
  221. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.css +0 -0
  222. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.js +0 -0
  223. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.css +0 -0
  224. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.js +0 -0
  225. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.css +0 -0
  226. /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.js +0 -0
  227. /package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.css +0 -0
  228. /package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.css +0 -0
  229. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.d.ts +0 -0
  230. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.d.ts +0 -0
  231. /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.d.ts +0 -0
@@ -1,9 +1,9 @@
1
- import { StringUtils, ElementIDUtils } from '@sankhyalabs/core';
1
+ import { StringUtils, ElementIDUtils, ApplicationContext } from '@sankhyalabs/core';
2
2
  import { ApplicationUtils, DialogType } from '@sankhyalabs/ezui/dist/collection/utils';
3
3
  import { CheckMode } from '@sankhyalabs/ezui/dist/collection/components/ez-check/CheckMode';
4
4
  import { h, Host } from '@stencil/core';
5
- import { ConfigStorage } from '../../../../lib/configs/ConfigStorage';
6
- import { ORDER_VALUES } from '../../../../lib/utils/constants';
5
+ import { ConfigStorage } from '../../lib/configs/ConfigStorage';
6
+ import { ORDER_VALUES } from '../../lib/utils/constants';
7
7
  export class SnkGridConfig {
8
8
  constructor() {
9
9
  this._orderListItems = [];
@@ -13,7 +13,6 @@ export class SnkGridConfig {
13
13
  this._dataChanged = false;
14
14
  this._componenteInternalKey = Date.now();
15
15
  this.selectedIndex = 0;
16
- this.application = undefined;
17
16
  this.columns = undefined;
18
17
  this.config = undefined;
19
18
  this.configName = undefined;
@@ -27,9 +26,10 @@ export class SnkGridConfig {
27
26
  * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-grid.msg.ts"
28
27
  */
29
28
  getMessage(key, params) {
30
- return this.application.messagesBuilder.getMessage(key, params);
29
+ const application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
30
+ return application.messagesBuilder.getMessage(key, params);
31
31
  }
32
- createOrderList() {
32
+ getSortableColumns() {
33
33
  let newList = [];
34
34
  this.columns.filter(col => { var _a; return StringUtils.getBooleanValue((_a = col === null || col === void 0 ? void 0 : col.props) === null || _a === void 0 ? void 0 : _a.get("sortable"), true); }).forEach((column) => {
35
35
  var _a;
@@ -43,7 +43,11 @@ export class SnkGridConfig {
43
43
  newList.push(item);
44
44
  }
45
45
  });
46
- newList.sort((a, b) => {
46
+ return newList;
47
+ }
48
+ createOrderList() {
49
+ let newSortableList = this.getSortableColumns();
50
+ newSortableList.sort((a, b) => {
47
51
  //OS dois tem order index 0 e pelo menos um deles tem orientação de ordenação.
48
52
  if (a.orderIndex == 0 && b.orderIndex == 0 && (a.ascending != undefined || b.ascending != undefined)) {
49
53
  if (a.ascending != undefined)
@@ -66,7 +70,7 @@ export class SnkGridConfig {
66
70
  }
67
71
  return (a.orderIndex - b.orderIndex);
68
72
  });
69
- this._orderListItems = newList;
73
+ this._orderListItems = newSortableList;
70
74
  }
71
75
  createColumnList() {
72
76
  let visibleGroup = {
@@ -89,12 +93,18 @@ export class SnkGridConfig {
89
93
  });
90
94
  this._columListItems = [visibleGroup, hiddenGroup];
91
95
  }
96
+ createColumnListSlotDataElementId(item) {
97
+ return `configItem_${StringUtils.replaceAccentuatedChars(StringUtils.toCamelCase(item.label))}`;
98
+ }
92
99
  buildColumnListSlot(item, group) {
93
- const dataElementId = `configItem_${StringUtils.replaceAccentuatedChars(StringUtils.toCamelCase(item.label))}`;
100
+ const dataElementId = this.createColumnListSlotDataElementId(item);
94
101
  return (h("div", null, h("ez-check", { mode: CheckMode.SWITCH, id: CheckMode.SWITCH + ((item === null || item === void 0 ? void 0 : item.label) || '') + ((group === null || group === void 0 ? void 0 : group.group) || ''), value: group.group === this.getMessage("snkGridConfig.group.visible"), "data-element-id": dataElementId, onEzChange: (evt) => { this.switchColumnGroup(evt, item); } })));
95
102
  }
103
+ createOrderListSlotDataElementId(item) {
104
+ return `${this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME)}_configItem_${StringUtils.toCamelCase(item.label)}`;
105
+ }
96
106
  buildOrderListSlot(item) {
97
- const dataElementId = `${this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME)}_configItem_${StringUtils.toCamelCase(item.label)}`;
107
+ const dataElementId = this.createOrderListSlotDataElementId(item);
98
108
  let selectedOption = ORDER_VALUES.none.value;
99
109
  if ((item === null || item === void 0 ? void 0 : item.ascending) != undefined) {
100
110
  selectedOption = item.ascending == true ? ORDER_VALUES.asc.value : ORDER_VALUES.desc.value;
@@ -112,7 +122,7 @@ export class SnkGridConfig {
112
122
  let orderArray;
113
123
  if (((_a = this._orderPriorityList) === null || _a === void 0 ? void 0 : _a.length) > 0) {
114
124
  this._orderPriorityList.find((item) => item.label === newItem.label).sort = sortOrder;
115
- this._orderPriorityList.filter((item) => item.sort).map((item, index) => {
125
+ this._orderPriorityList.filter((item) => item.sort).forEach((item, index) => {
116
126
  if (item.label === newItem.label) {
117
127
  newItem.sortIndex = index;
118
128
  }
@@ -181,6 +191,35 @@ export class SnkGridConfig {
181
191
  this.closeConfig();
182
192
  this.save();
183
193
  }
194
+ saveGridConfigOnStorage(_newConfig) {
195
+ ConfigStorage.saveGridConfig(_newConfig, this.configName, this.resourceID)
196
+ .then((savedConfig) => {
197
+ this.configChange.emit(savedConfig);
198
+ this._orderList.clearHistory();
199
+ ApplicationUtils.info(this.getMessage("snkGridConfig.info.successfullyConfigSaved"), { iconName: "check" });
200
+ });
201
+ }
202
+ reOrderPriorityColumns(columns, orderPriorityList) {
203
+ let orderArray = [];
204
+ orderArray = columns.filter((item) => item.sort && item.hidden !== true)
205
+ .map((item) => {
206
+ return { label: item.label, orderIndex: 0 };
207
+ });
208
+ let indexCount = 0;
209
+ let newOrderArray = [];
210
+ orderPriorityList.forEach((orderPriorityItem) => {
211
+ let item = orderArray.find((column) => column.label === orderPriorityItem.label);
212
+ if (item) {
213
+ item.orderIndex = indexCount;
214
+ newOrderArray.push(item);
215
+ indexCount++;
216
+ }
217
+ });
218
+ if (newOrderArray.length > 0) {
219
+ orderArray = newOrderArray;
220
+ }
221
+ return orderArray;
222
+ }
184
223
  save() {
185
224
  var _a;
186
225
  let _newConfig;
@@ -193,30 +232,12 @@ export class SnkGridConfig {
193
232
  let _newColumnConfigList = [];
194
233
  let orderArray;
195
234
  if (((_a = this._orderPriorityList) === null || _a === void 0 ? void 0 : _a.length) > 0) {
196
- orderArray = this.columns.filter((item) => item.sort && item.hidden !== true)
197
- .map((item) => {
198
- return { label: item.label, orderIndex: 0 };
199
- });
200
- let indexCount = 0;
201
- let newOrderArray = [];
202
- this._orderPriorityList.forEach((orderPriorityItem) => {
203
- let item = orderArray.find((column) => column.label === orderPriorityItem.label);
204
- if (item) {
205
- item.orderIndex = indexCount;
206
- newOrderArray.push(item);
207
- indexCount++;
208
- }
209
- });
210
- if (newOrderArray.length > 0) {
211
- orderArray = newOrderArray;
212
- }
235
+ orderArray = this.reOrderPriorityColumns(this.columns, this._orderPriorityList);
213
236
  }
214
- for (let i = 0; i < this.columns.length; i++) {
215
- const column = this.columns[i];
237
+ this.columns.forEach((column) => {
216
238
  let _newColumnConfig = _newConfig.columns.find((_newColumnConfig) => column.name === _newColumnConfig.name);
217
- if (column.hidden === true && _newColumnConfig) {
218
- continue;
219
- }
239
+ if (column.hidden === true && _newColumnConfig)
240
+ return;
220
241
  if (_newColumnConfig) {
221
242
  _newColumnConfig.width = column.width;
222
243
  }
@@ -239,14 +260,9 @@ export class SnkGridConfig {
239
260
  }
240
261
  _newColumnConfigList.push(_newColumnConfig);
241
262
  }
242
- }
243
- _newConfig.columns = _newColumnConfigList;
244
- ConfigStorage.saveGridConfig(_newConfig, this.configName, this.resourceID)
245
- .then((savedConfig) => {
246
- this.configChange.emit(savedConfig);
247
- this._orderList.clearHistory();
248
- ApplicationUtils.info(this.getMessage("snkGridConfig.info.successfullyConfigSaved"), { iconName: "check" });
249
263
  });
264
+ _newConfig.columns = _newColumnConfigList;
265
+ this.saveGridConfigOnStorage(_newConfig);
250
266
  function adjustPriorityOrder(column, _newColumnConfig) {
251
267
  if (orderArray) {
252
268
  let orderItem = orderArray.find((item) => item.label === column.label);
@@ -281,85 +297,96 @@ export class SnkGridConfig {
281
297
  async locateColumn(evt, searchingText) {
282
298
  var _a;
283
299
  const hitEnter = evt.key === "Enter";
300
+ searchingText = searchingText || ((_a = evt.currentTarget) === null || _a === void 0 ? void 0 : _a.value);
284
301
  if (!searchingText) {
285
- searchingText = (_a = evt.currentTarget) === null || _a === void 0 ? void 0 : _a.value;
302
+ this.removeSelection();
303
+ return;
286
304
  }
287
- let newSelected = -1;
305
+ const matchedIndexes = await this.getMatchedIndexes(searchingText);
306
+ const newSelected = this.getNewSelectedIndex(matchedIndexes, hitEnter);
307
+ this._selectedIndex = newSelected;
288
308
  if (this.selectedIndex === 1) {
289
- if (searchingText) {
290
- const matchedIndexes = [];
291
- let orderListDatasource;
292
- await this._orderList.getList().then((listGroup) => {
293
- orderListDatasource = listGroup;
294
- orderListDatasource.forEach((column, index) => {
295
- if (this.compareWords(column, searchingText)) {
296
- matchedIndexes.push(index);
297
- }
298
- });
299
- });
300
- if (matchedIndexes.length > 0) {
301
- if (hitEnter) {
302
- for (let j = 0; j < matchedIndexes.length; j++) {
303
- if (matchedIndexes[j] > this._selectedIndex) {
304
- newSelected = matchedIndexes[j];
305
- break;
306
- }
307
- }
308
- }
309
- if (newSelected === -1) {
310
- newSelected = matchedIndexes[0];
311
- }
309
+ this.updateOrderListSelection(newSelected);
310
+ }
311
+ else {
312
+ this.updateColumnListSelection(newSelected);
313
+ }
314
+ }
315
+ async getMatchedIndexes(searchingText) {
316
+ const matchedIndexes = [];
317
+ if (this.selectedIndex === 1) {
318
+ const orderListDatasource = await this._orderList.getList();
319
+ orderListDatasource.forEach((column, index) => {
320
+ if (this.compareWords(column, searchingText)) {
321
+ matchedIndexes.push(index);
312
322
  }
313
- this._selectedIndex = newSelected;
314
- let selectedColumn;
315
- selectedColumn = orderListDatasource[newSelected];
316
- if (selectedColumn) {
317
- this._orderList.setSelection(selectedColumn, true);
323
+ });
324
+ }
325
+ else {
326
+ this.columns.forEach((column, index) => {
327
+ if (this.compareWords(column, searchingText)) {
328
+ matchedIndexes.push(index);
318
329
  }
319
- else {
320
- this._orderList.removeSelection();
330
+ });
331
+ }
332
+ return matchedIndexes;
333
+ }
334
+ getNewSelectedIndex(matchedIndexes, hitEnter) {
335
+ if (matchedIndexes.length === 0)
336
+ return -1;
337
+ if (hitEnter) {
338
+ for (const index of matchedIndexes) {
339
+ if (index > this._selectedIndex) {
340
+ return index;
321
341
  }
322
342
  }
343
+ }
344
+ return matchedIndexes[0];
345
+ }
346
+ updateOrderListSelection(newSelected) {
347
+ if (newSelected === -1) {
348
+ this._orderList.removeSelection();
349
+ return;
350
+ }
351
+ this._orderList.getList().then((orderListDatasource) => {
352
+ const selectedColumn = orderListDatasource[newSelected];
353
+ if (selectedColumn) {
354
+ this._orderList.setSelection(selectedColumn, true);
355
+ }
323
356
  else {
324
357
  this._orderList.removeSelection();
325
358
  }
359
+ });
360
+ }
361
+ updateColumnListSelection(newSelected) {
362
+ if (newSelected === -1) {
363
+ this._columnList.removeSelection();
364
+ return;
326
365
  }
327
- else {
328
- if (searchingText) {
329
- const matchedIndexes = [];
330
- this.columns.forEach((column, index) => {
331
- if (this.compareWords(column, searchingText)) {
332
- matchedIndexes.push(index);
333
- }
334
- });
335
- if (matchedIndexes.length > 0) {
336
- if (hitEnter) {
337
- for (let j = 0; j < matchedIndexes.length; j++) {
338
- if (matchedIndexes[j] > this._selectedIndex) {
339
- newSelected = matchedIndexes[j];
340
- break;
341
- }
342
- }
343
- }
344
- if (newSelected === -1) {
345
- newSelected = matchedIndexes[0];
346
- }
347
- }
348
- this._selectedIndex = newSelected;
349
- let selectedColumn = this.columns[newSelected];
350
- if (selectedColumn) {
351
- const listItem = this._columListItems.map(group => group.items).flat().find(item => item.label === selectedColumn.label);
352
- if (listItem)
353
- this._columnList.setSelection(listItem, true);
354
- }
355
- else {
356
- this._columnList.removeSelection();
357
- }
366
+ const selectedColumn = this.columns[newSelected];
367
+ if (selectedColumn) {
368
+ const listItem = this._columListItems
369
+ .map(group => group.items)
370
+ .flat()
371
+ .find(item => item.label === selectedColumn.label);
372
+ if (listItem) {
373
+ this._columnList.setSelection(listItem, true);
358
374
  }
359
375
  else {
360
376
  this._columnList.removeSelection();
361
377
  }
362
378
  }
379
+ else {
380
+ this._columnList.removeSelection();
381
+ }
382
+ }
383
+ removeSelection() {
384
+ if (this.selectedIndex === 1) {
385
+ this._orderList.removeSelection();
386
+ }
387
+ else {
388
+ this._columnList.removeSelection();
389
+ }
363
390
  }
364
391
  compareWords(column, searchingText) {
365
392
  var _a, _b;
@@ -493,26 +520,6 @@ export class SnkGridConfig {
493
520
  "reflect": false,
494
521
  "defaultValue": "0"
495
522
  },
496
- "application": {
497
- "type": "unknown",
498
- "mutable": false,
499
- "complexType": {
500
- "original": "SnkApplication",
501
- "resolved": "SnkApplication",
502
- "references": {
503
- "SnkApplication": {
504
- "location": "import",
505
- "path": "../../../snk-application/snk-application"
506
- }
507
- }
508
- },
509
- "required": false,
510
- "optional": false,
511
- "docs": {
512
- "tags": [],
513
- "text": "Refer\u00EAncia para o SnkApplication"
514
- }
515
- },
516
523
  "columns": {
517
524
  "type": "unknown",
518
525
  "mutable": true,
@@ -1,5 +1,5 @@
1
1
  import { h } from '@stencil/core';
2
- import { ORDER_VALUES } from '../../../../lib/utils/constants';
2
+ import { ORDER_VALUES } from '../../../lib/utils/constants';
3
3
  export class SelectBox {
4
4
  constructor() {
5
5
  this.selectedOption = ORDER_VALUES.none;
@@ -0,0 +1,3 @@
1
+ const REGULAR_DEFAULT_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "MORE_OPTIONS"];
2
+ const REGULAR_SELECTED_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "CLONE", "REMOVE", "DIVIDER", "MORE_OPTIONS"];
3
+ export { REGULAR_DEFAULT_BTNS, REGULAR_SELECTED_BTNS };
@@ -2,11 +2,14 @@
2
2
  display: flex;
3
3
  height: 100%;
4
4
  width: 100%;
5
+
6
+ /*@doc Define a altura minima da grid.*/
7
+ --snk-simple-crud-grid--min-height: 300px;
5
8
  }
6
9
 
7
10
  .simple-crud__container {
8
11
  display: grid;
9
- grid-template-rows: max-content;
12
+ grid-template-rows: auto 1fr;
10
13
  row-gap: 12px;
11
14
  height: 100%;
12
15
  width: 100%;
@@ -16,9 +19,14 @@
16
19
  flex-wrap: unset;
17
20
  flex-direction: column;
18
21
  }
22
+
23
+ .simple-crud__form--hidden {
24
+ display: none;
25
+ }
26
+
19
27
  ez-grid {
20
28
  --ez-grid__container--shadow: none;
21
- min-height: 300px;
29
+ --ez-grid--min-height: var(--snk-simple-crud-grid--min-height);
22
30
  }
23
31
 
24
32
  ez-form {