@sankhyalabs/sankhyablocks 8.16.0-dev.3 → 8.16.0-dev.30

Sign up to get free protection for your applications and to get access to all the features.
Files changed (204) hide show
  1. package/dist/cjs/{ConfigStorage-942ce74b.js → ConfigStorage-ecc0ed20.js} +3 -2
  2. package/dist/cjs/{IExporterProvider-597949f9.js → ContinuousInsertUtils-807730a8.js} +39 -6
  3. package/dist/cjs/{DataFetcher-313debd8.js → DataFetcher-cadeef8e.js} +21 -15
  4. package/dist/cjs/{RecordIDUtils-3735135c.js → GetSelectedRecordsIDsInfo-bd50caf1.js} +10 -10
  5. package/dist/cjs/{SnkFormConfigManager-1b13bacd.js → SnkFormConfigManager-f1c92f79.js} +74 -20
  6. package/dist/cjs/{SnkMessageBuilder-722b104e.js → SnkMessageBuilder-bae64d0d.js} +7 -3
  7. package/dist/cjs/{auth-fetcher-54f5ff9d.js → auth-fetcher-d68841bc.js} +1 -1
  8. package/dist/cjs/{dataunit-fetcher-688d3f05.js → dataunit-fetcher-f89461c1.js} +46 -18
  9. package/dist/cjs/{field-search-f56aa7d6.js → field-search-68e34bf4.js} +5 -1
  10. package/dist/cjs/{form-config-fetcher-2dd00e5b.js → form-config-fetcher-ed497282.js} +5 -2
  11. package/dist/cjs/loader.cjs.js +1 -1
  12. package/dist/cjs/{pesquisa-fetcher-680e198f.js → pesquisa-fetcher-ca89181c.js} +1 -1
  13. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  14. package/dist/cjs/snk-actions-button_4.cjs.entry.js +17 -14
  15. package/dist/cjs/snk-application.cjs.entry.js +7 -7
  16. package/dist/cjs/snk-attach.cjs.entry.js +37 -28
  17. package/dist/cjs/snk-crud.cjs.entry.js +14 -6
  18. package/dist/cjs/snk-data-exporter.cjs.entry.js +9 -9
  19. package/dist/cjs/{snk-data-unit-685272e7.js → snk-data-unit-668dc5e8.js} +42 -22
  20. package/dist/cjs/snk-data-unit.cjs.entry.js +5 -5
  21. package/dist/cjs/snk-detail-view.cjs.entry.js +12 -13
  22. package/dist/cjs/snk-exporter-email-sender.cjs.entry.js +1 -1
  23. package/dist/cjs/snk-filter-bar.cjs.entry.js +37 -25
  24. package/dist/cjs/snk-filter-checkbox-list.cjs.entry.js +1 -1
  25. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  26. package/dist/cjs/snk-form-config.cjs.entry.js +17 -6
  27. package/dist/cjs/snk-form.cjs.entry.js +7 -6
  28. package/dist/cjs/snk-grid.cjs.entry.js +61 -21
  29. package/dist/cjs/{snk-guides-viewer-67605336.js → snk-guides-viewer-68777d37.js} +24 -12
  30. package/dist/cjs/snk-guides-viewer.cjs.entry.js +9 -9
  31. package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
  32. package/dist/cjs/snk-simple-bar.cjs.entry.js +1 -1
  33. package/dist/cjs/snk-simple-crud.cjs.entry.js +64 -26
  34. package/dist/cjs/snk-taskbar.cjs.entry.js +23 -1
  35. package/dist/collection/components/snk-actions-button/actions/index.js +12 -9
  36. package/dist/collection/components/snk-attach/snk-attach.js +24 -15
  37. package/dist/collection/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.js +2 -4
  38. package/dist/collection/components/snk-crud/snk-crud.js +78 -1
  39. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +3 -4
  40. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +51 -6
  41. package/dist/collection/components/snk-data-exporter/exporter-email-sender/options-step.js +1 -1
  42. package/dist/collection/components/snk-data-exporter/providers/ClientSideExporterProvider.js +1 -1
  43. package/dist/collection/components/snk-data-exporter/providers/ServerSideExporterProvider.js +1 -1
  44. package/dist/collection/components/snk-data-exporter/structure/ItemBuilder.js +2 -2
  45. package/dist/collection/components/snk-data-unit/snk-data-unit.js +57 -20
  46. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-checkbox-list.js +1 -1
  47. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +1 -1
  48. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +59 -21
  49. package/dist/collection/components/snk-form/snk-form.js +2 -2
  50. package/dist/collection/components/snk-form-config/SnkFormConfigManager.js +72 -18
  51. package/dist/collection/components/snk-form-config/snk-form-config.css +8 -3
  52. package/dist/collection/components/snk-form-config/snk-form-config.js +14 -3
  53. package/dist/collection/components/snk-grid/snk-grid.css +2 -0
  54. package/dist/collection/components/snk-grid/snk-grid.js +68 -8
  55. package/dist/collection/components/snk-simple-bar/snk-simple-bar.js +1 -1
  56. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +0 -1
  57. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +89 -15
  58. package/dist/collection/components/snk-taskbar/processor/taskbar-processor.js +5 -1
  59. package/dist/collection/components/snk-taskbar/snk-taskbar.js +64 -0
  60. package/dist/collection/lib/DefaultCustomFormatters/RmPrecisionCustomValueFormatter.js +3 -3
  61. package/dist/collection/lib/configs/ConfigStorage.js +1 -0
  62. package/dist/collection/lib/dataUnit/InMemoryLoader.js +2 -4
  63. package/dist/collection/lib/dataUnit/dataUnitInMemoryUtils.js +34 -9
  64. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +22 -16
  65. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.js +7 -5
  66. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy.js +9 -2
  67. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +4 -1
  68. package/dist/collection/lib/message/resources/snk-data-unit.msg.js +1 -1
  69. package/dist/collection/lib/message/resources/snk-exporter.msg.js +1 -1
  70. package/dist/collection/lib/message/resources/snk-grid.msg.js +5 -1
  71. package/dist/collection/lib/utils/ContinuousInsertUtils.js +31 -0
  72. package/dist/collection/{components/snk-data-exporter/utils/RecordIDUtils.js → lib/utils/GetSelectedRecordsIDsInfo.js} +9 -9
  73. package/dist/components/ConfigStorage.js +1 -0
  74. package/dist/components/{IExporterProvider.js → ContinuousInsertUtils.js} +40 -5
  75. package/dist/components/DataFetcher.js +22 -16
  76. package/dist/{esm/RecordIDUtils-87d02110.js → components/GetSelectedRecordsIDsInfo.js} +10 -10
  77. package/dist/components/SnkFormConfigManager.js +72 -18
  78. package/dist/components/SnkMessageBuilder.js +7 -3
  79. package/dist/components/dataunit-fetcher.js +45 -15
  80. package/dist/components/form-config-fetcher.js +4 -1
  81. package/dist/components/snk-actions-button2.js +12 -9
  82. package/dist/components/snk-attach2.js +33 -24
  83. package/dist/components/snk-crud.js +12 -1
  84. package/dist/components/snk-data-exporter2.js +2 -2
  85. package/dist/components/snk-data-unit2.js +44 -60
  86. package/dist/components/snk-detail-view2.js +24 -11
  87. package/dist/components/snk-exporter-email-sender2.js +1 -1
  88. package/dist/components/snk-filter-bar2.js +35 -22
  89. package/dist/components/snk-filter-checkbox-list.js +1 -1
  90. package/dist/components/snk-form-config2.js +15 -4
  91. package/dist/components/snk-form.js +2 -2
  92. package/dist/components/snk-grid2.js +53 -11
  93. package/dist/components/snk-simple-bar2.js +1 -1
  94. package/dist/components/snk-simple-crud2.js +57 -15
  95. package/dist/components/snk-taskbar2.js +24 -2
  96. package/dist/esm/{ConfigStorage-86187da3.js → ConfigStorage-7b36d041.js} +3 -2
  97. package/dist/esm/{IExporterProvider-63a188b6.js → ContinuousInsertUtils-1a82a768.js} +40 -8
  98. package/dist/esm/{DataFetcher-c1baf61d.js → DataFetcher-a9c598f2.js} +22 -16
  99. package/dist/esm/GetSelectedRecordsIDsInfo-9fa41508.js +41 -0
  100. package/dist/esm/{SnkFormConfigManager-d4554df9.js → SnkFormConfigManager-139f09fa.js} +74 -20
  101. package/dist/esm/{SnkMessageBuilder-89925609.js → SnkMessageBuilder-6fff4a4c.js} +7 -3
  102. package/dist/esm/{auth-fetcher-039abba3.js → auth-fetcher-749d880f.js} +1 -1
  103. package/dist/esm/{dataunit-fetcher-264191b2.js → dataunit-fetcher-c24c76c6.js} +46 -16
  104. package/dist/esm/{field-search-efbe307f.js → field-search-f8b1d91e.js} +5 -1
  105. package/dist/esm/{form-config-fetcher-30fb808f.js → form-config-fetcher-adbe5d34.js} +5 -2
  106. package/dist/esm/loader.js +1 -1
  107. package/dist/esm/{pesquisa-fetcher-03c8f919.js → pesquisa-fetcher-8edaa8cd.js} +1 -1
  108. package/dist/esm/sankhyablocks.js +1 -1
  109. package/dist/esm/snk-actions-button_4.entry.js +17 -14
  110. package/dist/esm/snk-application.entry.js +7 -7
  111. package/dist/esm/snk-attach.entry.js +37 -28
  112. package/dist/esm/snk-crud.entry.js +14 -6
  113. package/dist/esm/snk-data-exporter.entry.js +9 -9
  114. package/dist/esm/{snk-data-unit-63f83504.js → snk-data-unit-0fdfb6c2.js} +42 -22
  115. package/dist/esm/snk-data-unit.entry.js +5 -5
  116. package/dist/esm/snk-detail-view.entry.js +12 -13
  117. package/dist/esm/snk-exporter-email-sender.entry.js +1 -1
  118. package/dist/esm/snk-filter-bar.entry.js +37 -25
  119. package/dist/esm/snk-filter-checkbox-list.entry.js +1 -1
  120. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  121. package/dist/esm/snk-form-config.entry.js +17 -6
  122. package/dist/esm/snk-form.entry.js +7 -6
  123. package/dist/esm/snk-grid.entry.js +56 -16
  124. package/dist/esm/{snk-guides-viewer-151f6091.js → snk-guides-viewer-b5dd30e6.js} +24 -12
  125. package/dist/esm/snk-guides-viewer.entry.js +9 -9
  126. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  127. package/dist/esm/snk-simple-bar.entry.js +1 -1
  128. package/dist/esm/snk-simple-crud.entry.js +60 -22
  129. package/dist/esm/snk-taskbar.entry.js +23 -1
  130. package/dist/sankhyablocks/p-0035ad6e.entry.js +1 -0
  131. package/dist/sankhyablocks/{p-df5451c7.js → p-06421fdb.js} +2 -2
  132. package/dist/sankhyablocks/p-16a1dd18.entry.js +1 -0
  133. package/dist/sankhyablocks/p-17425c72.js +1 -0
  134. package/dist/sankhyablocks/p-18ed15f4.entry.js +1 -0
  135. package/dist/sankhyablocks/{p-af8efd95.js → p-1bf06cd3.js} +2 -2
  136. package/dist/sankhyablocks/p-1e4c25e3.entry.js +1 -0
  137. package/dist/sankhyablocks/{p-a1d72395.entry.js → p-212213d9.entry.js} +1 -1
  138. package/dist/sankhyablocks/p-23736d75.js +1 -0
  139. package/dist/sankhyablocks/p-3ae9d08a.js +1 -0
  140. package/dist/sankhyablocks/p-3e3cc017.js +1 -0
  141. package/dist/sankhyablocks/{p-aff76a53.js → p-4d9549cf.js} +2 -2
  142. package/dist/sankhyablocks/p-50779ad3.entry.js +1 -0
  143. package/dist/sankhyablocks/p-5dd8cf4f.js +1 -0
  144. package/dist/sankhyablocks/{p-aaa3ee68.entry.js → p-5f157b09.entry.js} +1 -1
  145. package/dist/sankhyablocks/p-60b29483.entry.js +1 -0
  146. package/dist/sankhyablocks/p-694e1c4a.entry.js +1 -0
  147. package/dist/sankhyablocks/p-7ac7932c.js +60 -0
  148. package/dist/sankhyablocks/p-7dd49d15.js +1 -0
  149. package/dist/sankhyablocks/p-7eef0898.entry.js +1 -0
  150. package/dist/sankhyablocks/{p-82a0bfb0.entry.js → p-a42e7a1e.entry.js} +2 -2
  151. package/dist/sankhyablocks/p-afbb070d.js +1 -0
  152. package/dist/sankhyablocks/p-b9679243.entry.js +1 -0
  153. package/dist/sankhyablocks/p-b9c67e45.entry.js +1 -0
  154. package/dist/sankhyablocks/p-c2e468c9.entry.js +1 -0
  155. package/dist/sankhyablocks/{p-913a9979.js → p-ca5ec380.js} +1 -1
  156. package/dist/sankhyablocks/p-d80a84fd.entry.js +1 -0
  157. package/dist/sankhyablocks/p-d836f72b.entry.js +1 -0
  158. package/dist/sankhyablocks/p-e16e87fc.entry.js +1 -0
  159. package/dist/sankhyablocks/p-eb9f0407.entry.js +1 -0
  160. package/dist/sankhyablocks/p-f3434fc4.js +1 -0
  161. package/dist/sankhyablocks/{p-eae7a817.entry.js → p-fb34e0cf.entry.js} +1 -1
  162. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  163. package/dist/types/components/snk-actions-button/actions/index.d.ts +1 -0
  164. package/dist/types/components/snk-attach/snk-attach.d.ts +1 -0
  165. package/dist/types/components/snk-crud/snk-crud.d.ts +13 -0
  166. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +11 -0
  167. package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +7 -0
  168. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +5 -0
  169. package/dist/types/components/snk-form-config/SnkFormConfigManager.d.ts +9 -4
  170. package/dist/types/components/snk-grid/snk-grid.d.ts +12 -0
  171. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +14 -0
  172. package/dist/types/components/snk-taskbar/processor/taskbar-processor.d.ts +1 -0
  173. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +11 -0
  174. package/dist/types/components.d.ts +89 -0
  175. package/dist/types/lib/dataUnit/dataUnitInMemoryUtils.d.ts +12 -2
  176. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.d.ts +3 -2
  177. package/dist/types/lib/utils/ContinuousInsertUtils.d.ts +10 -0
  178. package/dist/types/lib/utils/GetSelectedRecordsIDsInfo.d.ts +3 -0
  179. package/package.json +2 -2
  180. package/dist/sankhyablocks/p-14a08904.entry.js +0 -1
  181. package/dist/sankhyablocks/p-14b9f964.entry.js +0 -1
  182. package/dist/sankhyablocks/p-219f888d.entry.js +0 -1
  183. package/dist/sankhyablocks/p-3a212712.js +0 -1
  184. package/dist/sankhyablocks/p-3a216b81.entry.js +0 -1
  185. package/dist/sankhyablocks/p-47b60deb.entry.js +0 -1
  186. package/dist/sankhyablocks/p-7505da04.entry.js +0 -1
  187. package/dist/sankhyablocks/p-75f83d1d.entry.js +0 -1
  188. package/dist/sankhyablocks/p-7a337364.js +0 -1
  189. package/dist/sankhyablocks/p-829d4045.js +0 -1
  190. package/dist/sankhyablocks/p-88aa931b.entry.js +0 -1
  191. package/dist/sankhyablocks/p-8fc470e5.entry.js +0 -1
  192. package/dist/sankhyablocks/p-941bf3ef.entry.js +0 -1
  193. package/dist/sankhyablocks/p-9863d682.js +0 -1
  194. package/dist/sankhyablocks/p-b4b21558.entry.js +0 -1
  195. package/dist/sankhyablocks/p-bad55caa.entry.js +0 -1
  196. package/dist/sankhyablocks/p-c053256c.entry.js +0 -1
  197. package/dist/sankhyablocks/p-c2495304.js +0 -1
  198. package/dist/sankhyablocks/p-c5268346.entry.js +0 -1
  199. package/dist/sankhyablocks/p-cefba299.js +0 -1
  200. package/dist/sankhyablocks/p-dc7c9047.js +0 -1
  201. package/dist/sankhyablocks/p-f2809746.entry.js +0 -1
  202. package/dist/sankhyablocks/p-fcac4dfc.js +0 -1
  203. package/dist/sankhyablocks/p-fe79f83a.js +0 -60
  204. package/dist/types/components/snk-data-exporter/utils/RecordIDUtils.d.ts +0 -3
@@ -1,21 +1,21 @@
1
1
  import { r as registerInstance, c as createEvent, h, F as Fragment, g as getElement } from './index-a7d3d3f1.js';
2
2
  import { Action, ElementIDUtils, ApplicationContext, StringUtils } from '@sankhyalabs/core';
3
3
  import { T as TaskbarElement } from './taskbar-elements-d59867f1.js';
4
- import { C as ConfigStorage } from './ConfigStorage-86187da3.js';
4
+ import { C as ConfigStorage } from './ConfigStorage-7b36d041.js';
5
5
  import { P as PresentationMode } from './index-3aa4977a.js';
6
- import { T as TaskbarProcessor, o as openFieldSearch, b as buildFieldSearch } from './field-search-efbe307f.js';
6
+ import { T as TaskbarProcessor, o as openFieldSearch, b as buildFieldSearch } from './field-search-f8b1d91e.js';
7
7
  import { s as store } from './index-bdf75557.js';
8
- import { C as CommonsExporter, S as SnkMultiSelectionListDataSource, a as CrudUtils, R as RmPrecisionCustomValueFormatter } from './IExporterProvider-63a188b6.js';
8
+ import { C as CommonsExporter, S as SnkMultiSelectionListDataSource, a as CrudUtils, R as RmPrecisionCustomValueFormatter, b as ContinuousInsertUtils } from './ContinuousInsertUtils-1a82a768.js';
9
9
  import { SelectionMode } from '@sankhyalabs/core/dist/dataunit/DataUnit';
10
- import './DataFetcher-c1baf61d.js';
11
- import './pesquisa-fetcher-03c8f919.js';
10
+ import './DataFetcher-a9c598f2.js';
11
+ import './pesquisa-fetcher-8edaa8cd.js';
12
12
  import './ISave-d8c8bc59.js';
13
13
  import '@sankhyalabs/ezui/dist/collection/utils/constants';
14
14
  import '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
15
- import './dataunit-fetcher-264191b2.js';
15
+ import './dataunit-fetcher-c24c76c6.js';
16
16
  import './filter-item-type.enum-d45e026f.js';
17
- import './form-config-fetcher-30fb808f.js';
18
- import { g as getSelectedIDs } from './RecordIDUtils-87d02110.js';
17
+ import './form-config-fetcher-adbe5d34.js';
18
+ import { g as getSelectedRecordsIDsInfo } from './GetSelectedRecordsIDsInfo-9fa41508.js';
19
19
  import '@sankhyalabs/ezui/dist/collection/components/ez-grid/utils/InMemoryFilterColumnDataSource';
20
20
  import './PrintUtils-3e4ff0f5.js';
21
21
  import '@sankhyalabs/ezui/dist/collection/components/ez-grid/utils';
@@ -44,7 +44,7 @@ class ServerSideExporterProvider extends CommonsExporter {
44
44
  return total !== null && total !== void 0 ? total : (_c = (_b = this.dataUnit) === null || _b === void 0 ? void 0 : _b.records) === null || _c === void 0 ? void 0 : _c.length;
45
45
  }
46
46
  getSelectedIDs() {
47
- return getSelectedIDs(this.dataUnit);
47
+ return getSelectedRecordsIDsInfo(this.dataUnit);
48
48
  }
49
49
  getOffset() {
50
50
  return this.getExporterOffset(this.getPaginationInfo());
@@ -76,7 +76,7 @@ class ServerSideExporterProvider extends CommonsExporter {
76
76
  }
77
77
  }
78
78
 
79
- const snkGridCss = ".sc-snk-grid-h{--snk-grid-min-height:300px}.snk-grid__container.sc-snk-grid{display:flex;height:100%;width:100%}.snk-grid__header.sc-snk-grid{width:100%;display:flex;flex-wrap:nowrap;justify-content:flex-end}.snk-grid__filter-bar.sc-snk-grid{width:100%}.snk-grid__header-divider.sc-snk-grid{margin-bottom:var(--space--medium)}.snk-grid__table.sc-snk-grid{min-height:var(--snk-grid-min-height)}.snk-grid-container__without-shadow.sc-snk-grid{--ezgrid__container--shadow:unset}";
79
+ const snkGridCss = ".sc-snk-grid-h{--snk-grid-min-height:300px;--snk-grid-padding:var(--space--small)}.snk-grid__container.sc-snk-grid{display:flex;height:100%;width:100%;padding:var(--snk-grid-padding)}.snk-grid__header.sc-snk-grid{width:100%;display:flex;flex-wrap:nowrap;justify-content:flex-end}.snk-grid__filter-bar.sc-snk-grid{width:100%}.snk-grid__header-divider.sc-snk-grid{margin-bottom:var(--space--medium)}.snk-grid__table.sc-snk-grid{min-height:var(--snk-grid-min-height)}.snk-grid-container__without-shadow.sc-snk-grid{--ezgrid__container--shadow:unset}";
80
80
 
81
81
  const SnkGrid = class {
82
82
  constructor(hostRef) {
@@ -89,7 +89,7 @@ const SnkGrid = class {
89
89
  "snkGridTopTaskbar.regular": ["FORM_MODE", "CONFIGURATOR", "INSERT"],
90
90
  "snkGridTopTaskbar.regular.secondary": ["FORM_MODE", "CONFIGURATOR", "INSERT"],
91
91
  "snkGridTopTaskbar.regular.singleTaskbar": [],
92
- "snkGridTopTaskbar.finish_edition": ["CANCEL", "SAVE"],
92
+ "snkGridTopTaskbar.finish_edition": ["CANCEL", "SAVE", this.handleAddFormMode()],
93
93
  "snkGridTopTaskbar.finish_edition.secondary": [],
94
94
  "snkGridTopTaskbar.finish_edition.singleTaskbar": [],
95
95
  });
@@ -102,7 +102,7 @@ const SnkGrid = class {
102
102
  "snkGridHeaderTaskbar.singleTaskbar.selected": ["UPDATE", "CLONE", "REMOVE", "MORE_OPTIONS", "DIVIDER", "ATTACH", "FORM_MODE", "CONFIGURATOR", "REFRESH", "DATA_EXPORTER", "ACTIONS_BUTTON"],
103
103
  "snkGridHeaderTaskbar.singleTaskbar.detail.unselected": ["INSERT", "FORM_MODE", "CONFIGURATOR", "REFRESH", "MORE_OPTIONS"],
104
104
  "snkGridHeaderTaskbar.singleTaskbar.detail.selected": ["UPDATE", "ATTACH", "CLONE", "REMOVE", "MORE_OPTIONS", "DIVIDER", "FORM_MODE", "CONFIGURATOR", "REFRESH"],
105
- "snkGridHeaderTaskbar.singleTaskbar.finish_edition": ["CANCEL", "SAVE"]
105
+ "snkGridHeaderTaskbar.singleTaskbar.finish_edition": ["CANCEL", "SAVE", this.handleAddFormMode()]
106
106
  });
107
107
  this.dataUnitInterceptor = {
108
108
  interceptAction: async (action) => {
@@ -117,6 +117,7 @@ const SnkGrid = class {
117
117
  this._gridConfig = undefined;
118
118
  this._popUpGridConfig = false;
119
119
  this._showSnkFilterBar = true;
120
+ this._enableContinuousInsert = false;
120
121
  this.columnFilterDataSource = new SnkMultiSelectionListDataSource();
121
122
  this.configName = undefined;
122
123
  this.filterBarTitle = undefined;
@@ -140,6 +141,7 @@ const SnkGrid = class {
140
141
  this.filterBarLegacyConfigName = undefined;
141
142
  this.autoLoad = undefined;
142
143
  this.autoFocus = true;
144
+ this.enableGridInsert = false;
143
145
  }
144
146
  /**
145
147
  * Exibe a janela de configurações da grade.
@@ -226,6 +228,16 @@ const SnkGrid = class {
226
228
  async setFocus() {
227
229
  this._grid.setFocus();
228
230
  }
231
+ async handleClick(event) {
232
+ if (this.hasToBlockEvent(event)) {
233
+ event.preventDefault();
234
+ event.stopPropagation();
235
+ await this._dataUnit.cancelEdition();
236
+ }
237
+ }
238
+ hasToBlockEvent(event) {
239
+ return this._snkFilterBar.contains(event.target) && this.enableGridInsert && this._dataUnit.hasNewRecord();
240
+ }
229
241
  async handleGridLegacyConfigName(newLegacyConfig, oldLegacyConfig) {
230
242
  if (!newLegacyConfig) {
231
243
  return;
@@ -236,6 +248,9 @@ const SnkGrid = class {
236
248
  this.addGridLegacyConfigName();
237
249
  this.loadConfig();
238
250
  }
251
+ handleAddFormMode() {
252
+ return this.enableGridInsert ? TaskbarElement.FORM_MODE : "";
253
+ }
239
254
  openGridConfig() {
240
255
  this._grid.getColumnsState()
241
256
  .then((gridColumns) => {
@@ -360,13 +375,21 @@ const SnkGrid = class {
360
375
  }
361
376
  parent = parent.parentElement;
362
377
  }
378
+ if (this._snkFilterBar) {
379
+ this._snkFilterBar.addEventListener('click', this.handleClick);
380
+ }
363
381
  this._rmPrecisionCustomValueFormatter = new RmPrecisionCustomValueFormatter();
364
382
  this.addGridLegacyConfigName();
365
383
  this.loadConfig();
384
+ this._continuousInsertUtils = new ContinuousInsertUtils(this._application, this.resourceID, this.configName);
385
+ if (this.enableGridInsert) {
386
+ this._continuousInsertUtils.getConfig().then(value => this._enableContinuousInsert = value);
387
+ }
366
388
  }
367
389
  componentDidRender() {
390
+ var _a, _b;
368
391
  this._rmPrecisionCustomValueFormatter.setGrid(this._grid);
369
- this.loadGridCustomFormatters(this._dataUnit.metadata.fields);
392
+ this.loadGridCustomFormatters((_b = (_a = this._dataUnit) === null || _a === void 0 ? void 0 : _a.metadata) === null || _b === void 0 ? void 0 : _b.fields);
370
393
  this.setCustomRenders();
371
394
  this.setCustomEditors();
372
395
  }
@@ -379,7 +402,7 @@ const SnkGrid = class {
379
402
  const disabledButtons = [];
380
403
  if ((_a = this._dataState) === null || _a === void 0 ? void 0 : _a.selectionInfo) {
381
404
  if (this._dataState.selectionInfo.length > 1) {
382
- disabledButtons.push(TaskbarElement.CLONE, "ATTACH");
405
+ disabledButtons.push(TaskbarElement.CLONE, "ATTACH", TaskbarElement.UPDATE);
383
406
  }
384
407
  if (this._dataState.selectionInfo.isAllRecords()) {
385
408
  disabledButtons.push("REMOVE");
@@ -464,12 +487,21 @@ const SnkGrid = class {
464
487
  eagerInitialize: true,
465
488
  itemBuilder: (actionButton, item) => this.getColumnSearch(actionButton, item)
466
489
  }];
490
+ if (this.enableGridInsert) {
491
+ hardList.push(this._continuousInsertUtils.actionContinuousInsert(this._enableContinuousInsert, this.handleEnableContinuousInsert));
492
+ }
493
+ if (this.isGridInsertActive())
494
+ return hardList;
467
495
  if (this.taskbarManager != undefined && this.taskbarManager.getMoreOptions != undefined) {
468
496
  const taskbarID = this.getTopTaskBarId();
469
497
  return hardList.concat(this.taskbarManager.getMoreOptions(taskbarID, this.configName, this._dataState, this.actionsList));
470
498
  }
471
499
  return hardList.concat(this.actionsList);
472
500
  }
501
+ handleEnableContinuousInsert() {
502
+ this._enableContinuousInsert = !this._enableContinuousInsert;
503
+ this._continuousInsertUtils.handleSaveConfig(this._enableContinuousInsert);
504
+ }
473
505
  handleFilterConfigUpdated(filterConfig) {
474
506
  if (!filterConfig.length) {
475
507
  this._showSnkFilterBar = false;
@@ -481,12 +513,20 @@ const SnkGrid = class {
481
513
  }
482
514
  this._showSnkFilterBar = true;
483
515
  }
516
+ getGridHeaderButtons() {
517
+ if (this.isGridInsertActive())
518
+ return TaskbarElement.MORE_OPTIONS;
519
+ return this._headerTaskbarProcessor.buttons;
520
+ }
521
+ isGridInsertActive() {
522
+ return this.enableGridInsert && this._dataUnit.hasNewRecord();
523
+ }
484
524
  render() {
485
525
  if (!this._dataUnit) {
486
526
  return undefined;
487
527
  }
488
- return (h("div", { class: "snk-grid__container ez-flex ez-flex--column ez-flex-item--auto ez-padding--large" }, h("div", { class: "snk-grid__header ez-margin-bottom--medium" }, this._showSnkFilterBar &&
489
- h(Fragment, null, h("snk-filter-bar", { ref: (ref) => this._snkFilterBar = ref, title: this.filterBarTitle, dataUnit: this._dataUnit, "data-element-id": "gridFilter", class: "snk-grid__filter-bar ez-align--top", configName: this.configName, messagesBuilder: this.messagesBuilder, resourceID: this.resourceID, onConfigUpdated: evt => this.handleFilterConfigUpdated(evt.detail), disablePersonalizedFilter: this.disablePersonalizedFilter, filterBarLegacyConfigName: this.filterBarLegacyConfigName, autoLoad: this.autoLoad }), h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin-left--medium snk-grid__header-divider" })), h("snk-taskbar", { class: "ez-padding-left--medium", "data-element-id": "grid_top", key: "topTaskbar", configName: this.configName, dataUnit: this._dataUnit, messagesBuilder: this.messagesBuilder, buttons: this._topTaskbarProcessor.buttons, disabledButtons: this._topTaskbarProcessor.disabledButtons, customButtons: this._topTaskbarProcessor.customButtons, primaryButton: this.getPrimaryButton(), resourceID: this.resourceID, customContainerId: this.taskbarCustomContainerId, customSlotId: this.topTaskbarCustomSlotId, overflowStrategy: 'none' }, h("slot", { name: this.topTaskbarCustomSlotId }))), h("ez-grid", { ref: ref => this._grid = ref, class: (this.presentationMode === PresentationMode.SECONDARY ? "snk-grid-container__without-shadow " : "") + "snk-grid__table", "data-element-id": "embedded", dataUnit: this._dataUnit, key: "grid-" + this._snkDataUnit.entityName, config: this._gridConfig, onConfigChange: (evt) => { this.gridConfigChangeHandler(evt); }, onEzDoubleClick: (evt) => this.gridDoubleClick.emit(evt.detail), statusResolver: this.statusResolver, multipleSelection: this.multipleSelection, columnfilterDataSource: this.columnFilterDataSource, selectionToastConfig: this.selectionToastConfig, useEnterLikeTab: this.useEnterLikeTab, recordsValidator: this.recordsValidator, canEdit: this.canEdit, autoFocus: this.autoFocus }, h("snk-taskbar", { id: 'teste', dataUnit: this._dataUnit, configName: this.configName, messagesBuilder: this.messagesBuilder, "data-element-id": "grid_left", buttons: this._headerTaskbarProcessor.buttons, presentationMode: this.presentationMode, disabledButtons: this._headerTaskbarProcessor.disabledButtons, customButtons: this._headerTaskbarProcessor.customButtons, slot: "leftButtons", actionsList: this.getActionsList(), primaryButton: this.getPrimaryButton(), resourceID: this.resourceID, customContainerId: this.taskbarCustomContainerId, customSlotId: this.gridHeaderCustomSlotId }, h("slot", { name: this.gridHeaderCustomSlotId }))), h("div", { class: "ez-col ez-col--sd-12" }, h("slot", { name: "SnkGridFooter" })), h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._popUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this._gridConfig, "data-element-id": this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this.resourceID }))));
528
+ return (h("div", { class: "snk-grid__container ez-flex ez-flex--column ez-flex-item--auto ez-padding--large" }, h("div", { class: "snk-grid__header ez-margin-bottom--extra-small" }, this._showSnkFilterBar &&
529
+ h(Fragment, null, h("snk-filter-bar", { ref: (ref) => this._snkFilterBar = ref, title: this.filterBarTitle, dataUnit: this._dataUnit, "data-element-id": "gridFilter", class: "snk-grid__filter-bar ez-align--top", configName: this.configName, messagesBuilder: this.messagesBuilder, resourceID: this.resourceID, onConfigUpdated: evt => this.handleFilterConfigUpdated(evt.detail), disablePersonalizedFilter: this.disablePersonalizedFilter, filterBarLegacyConfigName: this.filterBarLegacyConfigName, autoLoad: this.autoLoad }), h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin-left--medium snk-grid__header-divider" })), h("snk-taskbar", { class: "ez-padding-left--medium", "data-element-id": "grid_top", key: "topTaskbar", configName: this.configName, dataUnit: this._dataUnit, messagesBuilder: this.messagesBuilder, buttons: this._topTaskbarProcessor.buttons, disabledButtons: this._topTaskbarProcessor.disabledButtons, customButtons: this._topTaskbarProcessor.customButtons, primaryButton: this.getPrimaryButton(), resourceID: this.resourceID, customContainerId: this.taskbarCustomContainerId, customSlotId: this.topTaskbarCustomSlotId, overflowStrategy: 'none' }, h("slot", { name: this.topTaskbarCustomSlotId }))), h("ez-grid", { ref: ref => this._grid = ref, class: (this.presentationMode === PresentationMode.SECONDARY ? "snk-grid-container__without-shadow " : "") + "snk-grid__table", "data-element-id": "embedded", dataUnit: this._dataUnit, key: "grid-" + this._snkDataUnit.entityName, config: this._gridConfig, onConfigChange: (evt) => { this.gridConfigChangeHandler(evt); }, onEzDoubleClick: (evt) => this.gridDoubleClick.emit(evt.detail), statusResolver: this.statusResolver, multipleSelection: this.multipleSelection, columnfilterDataSource: this.columnFilterDataSource, selectionToastConfig: this.selectionToastConfig, useEnterLikeTab: this.useEnterLikeTab, recordsValidator: this.recordsValidator, canEdit: this.canEdit, autoFocus: this.autoFocus, enableGridInsert: this.enableGridInsert, enableContinuousInsert: this._enableContinuousInsert }, h("snk-taskbar", { id: 'teste', dataUnit: this._dataUnit, configName: this.configName, messagesBuilder: this.messagesBuilder, "data-element-id": "grid_left", buttons: this.getGridHeaderButtons(), presentationMode: this.presentationMode, disabledButtons: this._headerTaskbarProcessor.disabledButtons, customButtons: this._headerTaskbarProcessor.customButtons, slot: "leftButtons", actionsList: this.getActionsList(), primaryButton: this.getPrimaryButton(), resourceID: this.resourceID, customContainerId: this.taskbarCustomContainerId, customSlotId: this.gridHeaderCustomSlotId }, h("slot", { name: this.gridHeaderCustomSlotId }))), h("div", { class: "ez-col ez-col--sd-12" }, h("slot", { name: "SnkGridFooter" })), h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._popUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this._gridConfig, "data-element-id": this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this.resourceID }))));
490
530
  }
491
531
  get _element() { return getElement(this); }
492
532
  static get watchers() { return {
@@ -1,19 +1,19 @@
1
1
  import { r as registerInstance, c as createEvent, h, F as Fragment } from './index-a7d3d3f1.js';
2
2
  import { Action, ElementIDUtils } from '@sankhyalabs/core';
3
- import { S as SnkFormConfigManager } from './SnkFormConfigManager-d4554df9.js';
3
+ import { S as SnkFormConfigManager } from './SnkFormConfigManager-139f09fa.js';
4
4
  import { buildFormMetadata, FormMetadata } from '@sankhyalabs/ezui/dist/collection/utils/form';
5
- import { o as openFieldSearch, T as TaskbarProcessor, b as buildFieldSearch } from './field-search-efbe307f.js';
5
+ import { o as openFieldSearch, T as TaskbarProcessor, b as buildFieldSearch } from './field-search-f8b1d91e.js';
6
6
  import { T as TaskbarElement } from './taskbar-elements-d59867f1.js';
7
7
  import { d as VIEW_MODE } from './constants-8457af36.js';
8
- import './DataFetcher-c1baf61d.js';
9
- import './pesquisa-fetcher-03c8f919.js';
8
+ import './DataFetcher-a9c598f2.js';
9
+ import './pesquisa-fetcher-8edaa8cd.js';
10
10
  import { P as PresentationMode } from './index-3aa4977a.js';
11
11
  import './ISave-d8c8bc59.js';
12
12
  import '@sankhyalabs/ezui/dist/collection/utils/constants';
13
13
  import '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
14
- import './dataunit-fetcher-264191b2.js';
14
+ import './dataunit-fetcher-c24c76c6.js';
15
15
  import './filter-item-type.enum-d45e026f.js';
16
- import './form-config-fetcher-30fb808f.js';
16
+ import './form-config-fetcher-adbe5d34.js';
17
17
  import { SelectionMode } from '@sankhyalabs/core/dist/dataunit/DataUnit';
18
18
 
19
19
  const snkGuidesViewerCss = ".sc-snk-guides-viewer-h{--snk-guides-viewer--space-large:var(--space--large, 24px);--snk-guides-viewer--space-medium:var(--space--medium, 12px);--snk-guides-viewer__header--min-height:94px;--snk-guides-viewer__header--z-index:var(--more-visible, 2);--snk-guides-viewer__header--background-color:var(--background--body, #fafcff);--snk-guides-viewer__guide-navigator--width:340px;display:block}snk-form-view.sc-snk-guides-viewer{width:100%}.snk-guides-viewer.sc-snk-guides-viewer{position:relative;padding-left:0px;padding-top:0px;padding-right:var(--snk-guides-viewer--space-large);padding-bottom:var(--snk-guides-viewer--space-large)}.snk-guides-viewer__detail-container.sc-snk-guides-viewer{display:flex;row-gap:24px;flex-direction:column}.snk-guides-viewer__header.sc-snk-guides-viewer{position:sticky;align-items:center;top:0;z-index:var(--snk-guides-viewer__header--z-index);background-color:var(--snk-guides-viewer__header--background-color);min-height:var(--snk-guides-viewer__header--min-height);width:calc(100% + (var(--snk-guides-viewer--space-large) * 2));padding-left:var(--snk-guides-viewer--space-large);padding-right:var(--snk-guides-viewer--space-large);padding-top:var(--snk-guides-viewer--space-large);padding-bottom:var(--snk-guides-viewer--space-medium);margin-left:calc(var(--snk-guides-viewer--space-large) * -1);margin-right:calc(var(--snk-guides-viewer--space-large) * -1);margin-bottom:var(--snk-guides-viewer--space-medium)}.snk-guides-viewer__header-breadcrumb.sc-snk-guides-viewer{width:25%;display:flex}.snk-guides-viewer__header-taskbar.sc-snk-guides-viewer{width:75%}.snk-guides-viewer__container.sc-snk-guides-viewer{display:grid;grid-template-columns:minmax(0, auto) minmax(0, 100%);height:100%;column-gap:var(--snk-guides-viewer--space-large)}.snk-guides-viewer__guide-navigator.sc-snk-guides-viewer{position:sticky;top:calc(var(--snk-guides-viewer__header--min-height) + var(--snk-guides-viewer--space-medium));height:calc(100vh - var(--snk-guides-viewer__header--min-height) - var(--snk-guides-viewer--space-large) - var(--snk-guides-viewer--space-medium))}.snk-guides-viewer__guide-navigator[open].sc-snk-guides-viewer{width:var(--snk-guides-viewer__guide-navigator--width);max-width:var(--snk-guides-viewer__guide-navigator--width);min-width:var(--snk-guides-viewer__guide-navigator--width)}.snk-guides-viewer__detail-content.sc-snk-guides-viewer{min-height:100%;align-items:flex-start;align-content:flex-start}";
@@ -41,6 +41,8 @@ const SnkGuidesViewer = class {
41
41
  this.resourceID = undefined;
42
42
  this.detailTaskbarCustomContainerId = undefined;
43
43
  this.formLegacyConfigName = undefined;
44
+ this.enableGridInsert = false;
45
+ this.getCustomTitle = undefined;
44
46
  this._hasToCreateFieldSearch = true;
45
47
  this._breadcrumbItems = [];
46
48
  this._guides = undefined;
@@ -109,7 +111,7 @@ const SnkGuidesViewer = class {
109
111
  this._container.focus();
110
112
  }
111
113
  exitViewer() {
112
- if (this.dataUnit.isDirty()) {
114
+ if (!this.enableGridInsert && this.dataUnit.isDirty()) {
113
115
  this.dataUnit.cancelEdition({ after: () => this.exit.emit() });
114
116
  }
115
117
  else {
@@ -127,7 +129,7 @@ const SnkGuidesViewer = class {
127
129
  }
128
130
  onContentCardChanged(evt) {
129
131
  SnkGuidesViewer.updateContentCard(evt.detail.formName, evt.detail.cardConfig, evt.detail.propertyChanged, this._configManager)
130
- .then(() => this.masterFormConfig = this._configManager.getConfig(this.dataState.insertionMode, this.dataUnit));
132
+ .then(() => this.masterFormConfig = this._configManager.getConfig(this.dataUnit));
131
133
  }
132
134
  /**
133
135
  * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
@@ -218,10 +220,13 @@ const SnkGuidesViewer = class {
218
220
  const invisibleButtons = this.getInvisibleButtons();
219
221
  this._taskbarProcessor = new TaskbarProcessor({
220
222
  "snkGuideViewer.regular": btnsRegularMode,
221
- "snkGuideViewer.finish_edition": ["CANCEL", "SAVE"],
223
+ "snkGuideViewer.finish_edition": ["CANCEL", "SAVE", this.handleAddGridMode()],
222
224
  });
223
225
  this._taskbarProcessor.process(taskbarId, this.taskbarManager, this.dataState, disabledButtons, invisibleButtons);
224
226
  }
227
+ handleAddGridMode() {
228
+ return this.enableGridInsert ? TaskbarElement.GRID_MODE : "";
229
+ }
225
230
  getInvisibleButtons() {
226
231
  const invisibleButtons = [];
227
232
  if (this.dataState && this.dataState.selectionInfo.mode === SelectionMode.ALL_RECORDS)
@@ -374,11 +379,14 @@ const SnkGuidesViewer = class {
374
379
  this._configManager.addFormLegacyConfig(this.formLegacyConfigName);
375
380
  }
376
381
  }
382
+ setMasterFormConfig(config) {
383
+ this.masterFormConfig = config;
384
+ }
377
385
  componentWillLoad() {
378
386
  if (this.resourceID == undefined) {
379
387
  throw new Error("Erro interno: resourceID não informado");
380
388
  }
381
- this._configManager = new SnkFormConfigManager(this.configName, this.resourceID, config => this.masterFormConfig = config);
389
+ this._configManager = new SnkFormConfigManager(this.configName, this.resourceID, this.setMasterFormConfig.bind(this), this.dataUnit);
382
390
  this.addFormLegacyConfigName();
383
391
  this._configManager.loadConfig();
384
392
  }
@@ -406,7 +414,7 @@ const SnkGuidesViewer = class {
406
414
  return this._fieldSearch;
407
415
  }
408
416
  fieldsOptionLoader(argument) {
409
- return Promise.resolve(this._configManager.getFieldsList(this.dataUnit, argument)
417
+ return Promise.resolve(this._configManager.getFieldsList(argument)
410
418
  .map(field => ({ value: field.name, label: field.label })));
411
419
  }
412
420
  onSelectField(option, actionButton) {
@@ -478,6 +486,10 @@ const SnkGuidesViewer = class {
478
486
  }
479
487
  return "";
480
488
  }
489
+ getTitle() {
490
+ var _a, _b;
491
+ return (_b = (_a = this.getCustomTitle) === null || _a === void 0 ? void 0 : _a.call(this)) !== null && _b !== void 0 ? _b : this.getMessage("snkCrud.title");
492
+ }
481
493
  componentDidLoad() {
482
494
  this.dataUnit.subscribe(this.dataUnitActionHandler.bind(this));
483
495
  }
@@ -491,7 +503,7 @@ const SnkGuidesViewer = class {
491
503
  }
492
504
  this.loadTaskbarProcessor();
493
505
  const showGuides = this._guides && (this._guides.length > 1);
494
- return (h("section", { class: "snk-guides-viewer", ref: ref => this._container = ref, tabindex: -1 }, h("div", { class: "ez-row snk-guides-viewer__header" }, h("div", { class: "snk-guides-viewer__header-breadcrumb ez-flex--align-items-center ez-flex-item--align-center ez-padding-left--large", key: "header" }, h("ez-button", { onClick: () => this.exitViewer(), title: this.getMessage("snkCrud.goBackTitle"), mode: "icon", iconName: "arrow_back", class: "ez-padding-right--medium", size: "small" }), h("div", { class: "ez-flex ez-flex--column ez-flex-item--auto" }, h("h1", { class: "ez-title ez-title--primary ez-title--xlarge" }, this.getMessage("snkCrud.title")), ((_a = this._breadcrumbItems) === null || _a === void 0 ? void 0 : _a.length) > 1 &&
506
+ return (h("section", { class: "snk-guides-viewer", ref: ref => this._container = ref, tabindex: -1 }, h("div", { class: "ez-row snk-guides-viewer__header" }, h("div", { class: "snk-guides-viewer__header-breadcrumb ez-flex--align-items-center ez-flex-item--align-center ez-padding-left--large", key: "header" }, h("ez-button", { onClick: () => this.exitViewer(), title: this.getMessage("snkCrud.goBackTitle"), mode: "icon", iconName: "arrow_back", class: "ez-padding-right--medium", size: "small" }), h("div", { class: "ez-flex ez-flex--column ez-flex-item--auto" }, h("h1", { class: "ez-title ez-title--primary ez-title--xlarge" }, this.getTitle()), ((_a = this._breadcrumbItems) === null || _a === void 0 ? void 0 : _a.length) > 1 &&
495
507
  h("div", { class: "ez-margin-top--extra-small" }, h("ez-breadcrumb", Object.assign({ items: this._breadcrumbItems, onSelectedItem: (evt) => this.onBreadcrumbClickHandler(evt === null || evt === void 0 ? void 0 : evt.detail) }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: `${ElementIDUtils.getInternalIDInfo("breadcrumb")}` }))))), this.presentationMode != PresentationMode.SECONDARY && this.buildTaskBar()), h("div", { class: "snk-guides-viewer__container" }, showGuides ?
496
508
  h("ez-guide-navigator", { ref: (ref) => this._guideNavigator = ref, class: "snk-guides-viewer__guide-navigator", items: this._guides, selectedId: this.selectedGuide ? this.selectedGuide.id : undefined, onEzSelectionChange: evt => this.updateSelectedGuideHandler(evt.detail) })
497
509
  :
@@ -1,23 +1,23 @@
1
- export { S as snk_guides_viewer } from './snk-guides-viewer-151f6091.js';
1
+ export { S as snk_guides_viewer } from './snk-guides-viewer-b5dd30e6.js';
2
2
  import './index-a7d3d3f1.js';
3
3
  import '@sankhyalabs/core';
4
- import './SnkFormConfigManager-d4554df9.js';
5
- import './ConfigStorage-86187da3.js';
6
- import './form-config-fetcher-30fb808f.js';
7
- import './DataFetcher-c1baf61d.js';
4
+ import './SnkFormConfigManager-139f09fa.js';
5
+ import './ConfigStorage-7b36d041.js';
6
+ import './form-config-fetcher-adbe5d34.js';
7
+ import './DataFetcher-a9c598f2.js';
8
8
  import './PrintUtils-3e4ff0f5.js';
9
9
  import '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
10
10
  import './filter-item-type.enum-d45e026f.js';
11
+ import './constants-8457af36.js';
11
12
  import '@sankhyalabs/ezui/dist/collection/utils/form';
12
- import './field-search-efbe307f.js';
13
+ import './field-search-f8b1d91e.js';
13
14
  import './taskbar-elements-d59867f1.js';
14
15
  import './index-3aa4977a.js';
15
16
  import './index-bdf75557.js';
16
- import './constants-8457af36.js';
17
- import './pesquisa-fetcher-03c8f919.js';
17
+ import './pesquisa-fetcher-8edaa8cd.js';
18
18
  import './ISave-d8c8bc59.js';
19
19
  import '@sankhyalabs/ezui/dist/collection/utils/constants';
20
- import './dataunit-fetcher-264191b2.js';
20
+ import './dataunit-fetcher-c24c76c6.js';
21
21
  import '@sankhyalabs/ezui/dist/collection/components/ez-grid/utils';
22
22
  import '@sankhyalabs/core/dist/utils/SortingUtils';
23
23
  import './ResourceIDUtils-a114189a.js';
@@ -1,13 +1,13 @@
1
1
  import { r as registerInstance, c as createEvent, h, F as Fragment, H as Host } from './index-a7d3d3f1.js';
2
2
  import { StringUtils, ObjectUtils, ApplicationContext, ElementIDUtils } from '@sankhyalabs/core';
3
3
  import { P as PersonalizedFilterUtils } from './PersonalizedFilterUtils-e2b38ef7.js';
4
- import { P as PersonalizedFilterFetcher, C as ConfigStorage } from './ConfigStorage-86187da3.js';
4
+ import { P as PersonalizedFilterFetcher, C as ConfigStorage } from './ConfigStorage-7b36d041.js';
5
5
  import { ApplicationUtils } from '@sankhyalabs/ezui/dist/collection/utils';
6
6
  import { a as FilterGroupCondition } from './index-ae591a44.js';
7
7
  import { s as store } from './index-bdf75557.js';
8
8
  import './filter-item-type.enum-d45e026f.js';
9
- import './form-config-fetcher-30fb808f.js';
10
- import './DataFetcher-c1baf61d.js';
9
+ import './form-config-fetcher-adbe5d34.js';
10
+ import './DataFetcher-a9c598f2.js';
11
11
  import './PrintUtils-3e4ff0f5.js';
12
12
  import '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
13
13
 
@@ -32,7 +32,7 @@ const SnkSimpleBar = class {
32
32
  this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
33
33
  }
34
34
  render() {
35
- return (h("div", { class: "simple-bar__container ez-margin-vertical--medium ez-padding--extra-small" }, h("div", { class: "simple-bar__left-slot" }, h("ez-button", { class: "ez-padding-right--medium", title: this.getMessage('snkSimpleBar.backTitle'), mode: 'icon', iconName: "arrow_back", size: 'medium', onClick: () => this.exit.emit() }), h("div", { class: "simple-bar__column" }, h("h1", { class: "ez-title ez-title--primary ez-title--extra-large" }, this.label), h("ez-breadcrumb", { items: this.breadcrumbItens, onSelectedItem: ({ detail }) => this.clickBreadcrumbItem.emit(detail) }))), h("div", { class: "simple-bar__right-slot" }, h("slot", { name: "rightSlot" }))));
35
+ return (h("div", { class: "simple-bar__container ez-margin-vertical--small ez-padding--extra-small" }, h("div", { class: "simple-bar__left-slot" }, h("ez-button", { class: "ez-padding-right--medium", title: this.getMessage('snkSimpleBar.backTitle'), mode: 'icon', iconName: "arrow_back", size: 'medium', onClick: () => this.exit.emit() }), h("div", { class: "simple-bar__column" }, h("h1", { class: "ez-title ez-title--primary ez-title--extra-large" }, this.label), h("ez-breadcrumb", { items: this.breadcrumbItens, onSelectedItem: ({ detail }) => this.clickBreadcrumbItem.emit(detail) }))), h("div", { class: "simple-bar__right-slot" }, h("slot", { name: "rightSlot" }))));
36
36
  }
37
37
  get _element() { return getElement(this); }
38
38
  };
@@ -3,20 +3,20 @@ import { UserInterface, StringUtils, ApplicationContext, ObjectUtils, DataType,
3
3
  import { CSSVarsUtils } from '@sankhyalabs/ezui/dist/collection/utils';
4
4
  import { d as VIEW_MODE, S as SIMPLE_CRUD_MODE } from './constants-8457af36.js';
5
5
  import { T as TaskbarElement } from './taskbar-elements-d59867f1.js';
6
- import './DataFetcher-c1baf61d.js';
7
- import './pesquisa-fetcher-03c8f919.js';
8
- import { C as CommonsExporter, S as SnkMultiSelectionListDataSource, R as RmPrecisionCustomValueFormatter, a as CrudUtils } from './IExporterProvider-63a188b6.js';
6
+ import './DataFetcher-a9c598f2.js';
7
+ import './pesquisa-fetcher-8edaa8cd.js';
8
+ import { C as CommonsExporter, S as SnkMultiSelectionListDataSource, R as RmPrecisionCustomValueFormatter, b as ContinuousInsertUtils, a as CrudUtils } from './ContinuousInsertUtils-1a82a768.js';
9
9
  import { D as DataExporterOption, P as PresentationMode } from './index-3aa4977a.js';
10
10
  import './ISave-d8c8bc59.js';
11
11
  import '@sankhyalabs/ezui/dist/collection/utils/constants';
12
12
  import '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
13
- import { I as InMemoryLoader } from './dataunit-fetcher-264191b2.js';
13
+ import { I as InMemoryLoader } from './dataunit-fetcher-c24c76c6.js';
14
14
  import './filter-item-type.enum-d45e026f.js';
15
- import { F as FormConfigFetcher } from './form-config-fetcher-30fb808f.js';
16
- import { T as TaskbarProcessor, b as buildFieldSearch, o as openFieldSearch } from './field-search-efbe307f.js';
17
- import { C as ConfigStorage } from './ConfigStorage-86187da3.js';
18
- import { S as SnkFormConfigManager } from './SnkFormConfigManager-d4554df9.js';
19
- import { g as getSelectedIDs } from './RecordIDUtils-87d02110.js';
15
+ import { F as FormConfigFetcher } from './form-config-fetcher-adbe5d34.js';
16
+ import { T as TaskbarProcessor, b as buildFieldSearch, o as openFieldSearch } from './field-search-f8b1d91e.js';
17
+ import { C as ConfigStorage } from './ConfigStorage-7b36d041.js';
18
+ import { S as SnkFormConfigManager } from './SnkFormConfigManager-139f09fa.js';
19
+ import { g as getSelectedRecordsIDsInfo } from './GetSelectedRecordsIDsInfo-9fa41508.js';
20
20
  import { s as store } from './index-bdf75557.js';
21
21
  import './PrintUtils-3e4ff0f5.js';
22
22
  import '@sankhyalabs/ezui/dist/collection/components/ez-grid/utils/InMemoryFilterColumnDataSource';
@@ -37,7 +37,7 @@ class ClientSideExporterProvider extends CommonsExporter {
37
37
  return total !== null && total !== void 0 ? total : (_c = (_b = this.dataUnit) === null || _b === void 0 ? void 0 : _b.records) === null || _c === void 0 ? void 0 : _c.length;
38
38
  }
39
39
  getSelectedIDs() {
40
- return getSelectedIDs(this.dataUnit);
40
+ return getSelectedRecordsIDsInfo(this.dataUnit);
41
41
  }
42
42
  getRecordID() {
43
43
  var _a, _b, _c;
@@ -82,7 +82,7 @@ class ClientSideExporterProvider extends CommonsExporter {
82
82
  }
83
83
  }
84
84
 
85
- const snkSimpleCrudCss = ".sc-snk-simple-crud-h{display:flex;height:100%;width:100%;--snk-simple-crud-grid--min-height:300px}.simple-crud__container.sc-snk-simple-crud{display:grid;grid-template-rows:auto 1fr;row-gap:12px;height:100%;width:100%}.simple-crud__container-section.sc-snk-simple-crud{flex-wrap:unset;flex-direction:column}.simple-crud__form--hidden.sc-snk-simple-crud{display:none}ez-grid.sc-snk-simple-crud{--ez-grid__container--shadow:none;--ez-grid--min-height:var(--snk-simple-crud-grid--min-height)}ez-form.sc-snk-simple-crud{min-height:300px}";
85
+ const snkSimpleCrudCss = ".sc-snk-simple-crud-h{display:flex;height:100%;width:100%;--snk-simple-crud-grid--min-height:300px}.simple-crud__container.sc-snk-simple-crud{display:grid;grid-template-rows:auto 1fr;height:100%;width:100%}.simple-crud__container-section.sc-snk-simple-crud{flex-wrap:unset;flex-direction:column}.simple-crud__form--hidden.sc-snk-simple-crud{display:none}ez-grid.sc-snk-simple-crud{--ez-grid__container--shadow:none;--ez-grid--min-height:var(--snk-simple-crud-grid--min-height)}ez-form.sc-snk-simple-crud{min-height:300px}";
86
86
 
87
87
  const SnkSimpleCrud = class {
88
88
  constructor(hostRef) {
@@ -99,11 +99,11 @@ const SnkSimpleCrud = class {
99
99
  this._customEditors = new Map();
100
100
  this._customRenders = new Map();
101
101
  this._taskbarProcessor = new TaskbarProcessor({
102
- "snkSimpleCrudTaskbar.form_regular": this.getButtons(false, [TaskbarElement.GRID_MODE]),
102
+ "snkSimpleCrudTaskbar.form_regular": this.getButtons(false, [TaskbarElement.GRID_MODE], true),
103
103
  "snkSimpleCrudTaskbar.grid_regular": this.getButtons(false, [TaskbarElement.DATA_EXPORTER, TaskbarElement.FORM_MODE]),
104
- "snkSimpleCrudTaskbar.form_selected": this.getButtons(true, [TaskbarElement.GRID_MODE]),
104
+ "snkSimpleCrudTaskbar.form_selected": this.getButtons(true, [TaskbarElement.GRID_MODE], true),
105
105
  "snkSimpleCrudTaskbar.grid_selected": this.getButtons(true, [TaskbarElement.DATA_EXPORTER, TaskbarElement.FORM_MODE]),
106
- "snkSimpleCrudTaskbar.finish_edition": ["CANCEL", "SAVE"]
106
+ "snkSimpleCrudTaskbar.finish_edition": this.getFinishEditionButtonsCallback.bind(this)
107
107
  });
108
108
  this._showPopUpGridConfig = false;
109
109
  this._showFormConfig = false;
@@ -119,10 +119,12 @@ const SnkSimpleCrud = class {
119
119
  this.formConfig = undefined;
120
120
  this._formFields = [];
121
121
  this._fieldsProps = new Map();
122
+ this._enableContinuousInsert = true;
122
123
  this.multipleSelection = undefined;
123
124
  this.useCancelConfirm = true;
124
125
  this.pageSize = 150;
125
126
  this.resourceID = undefined;
127
+ this.enableGridInsert = false;
126
128
  this.taskbarManager = undefined;
127
129
  this.messagesBuilder = undefined;
128
130
  this.useEnterLikeTab = false;
@@ -133,6 +135,7 @@ const SnkSimpleCrud = class {
133
135
  this.formLegacyConfigName = undefined;
134
136
  this.ignoreReadOnlyFormFields = false;
135
137
  this.autoFocus = true;
138
+ this.domainMessagesBuilder = undefined;
136
139
  this.autoLoad = undefined;
137
140
  }
138
141
  /**
@@ -191,8 +194,19 @@ const SnkSimpleCrud = class {
191
194
  newCustomFieldProps.set(fieldName, Object.assign(Object.assign({}, currentProps), { [propName]: value }));
192
195
  this._fieldsProps = newCustomFieldProps;
193
196
  }
194
- getButtons(selected, extraButtons) {
195
- return this.addConfigButton(this.resolveInMemoryBtns(selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS)
197
+ getFinishEditionButtonsCallback() {
198
+ const btns = ["CANCEL", "SAVE"];
199
+ if (this.enableGridInsert && this._currentViewMode !== VIEW_MODE.ATTACHMENT) {
200
+ btns.push(this._currentViewMode === VIEW_MODE.GRID ? TaskbarElement.FORM_MODE : TaskbarElement.GRID_MODE);
201
+ }
202
+ return btns;
203
+ }
204
+ getButtons(selected, extraButtons, removeRefresh) {
205
+ let btnList = selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS;
206
+ if (removeRefresh) {
207
+ btnList = btnList.filter(item => item !== TaskbarElement.REFRESH);
208
+ }
209
+ return this.addConfigButton(this.resolveInMemoryBtns(btnList)
196
210
  .concat(extraButtons));
197
211
  }
198
212
  addConfigButton(buttons) {
@@ -354,7 +368,7 @@ const SnkSimpleCrud = class {
354
368
  return;
355
369
  }
356
370
  if (this._formConfigManager == undefined) {
357
- this._formConfigManager = new SnkFormConfigManager(this.configName, this.resolveResourceID());
371
+ this._formConfigManager = new SnkFormConfigManager(this.configName, this.resolveResourceID(), undefined, this.dataUnit);
358
372
  this._formConfigManager.setConfig(this.formConfig);
359
373
  }
360
374
  if (this.formConfigIsLoaded() && !forceLoad) {
@@ -395,6 +409,10 @@ const SnkSimpleCrud = class {
395
409
  this.onModeChange();
396
410
  this.configDatasource();
397
411
  this._rmPrecisionCustomValueFormatter = new RmPrecisionCustomValueFormatter();
412
+ this._continuousInsertUtils = new ContinuousInsertUtils(this.application, this.resolveResourceID(), this.configName);
413
+ if (this.enableGridInsert) {
414
+ this._continuousInsertUtils.getConfig().then(value => this._enableContinuousInsert = value);
415
+ }
398
416
  }
399
417
  componentDidLoad() {
400
418
  CSSVarsUtils.applyVarsGrid(this._element, this._grid);
@@ -629,6 +647,9 @@ const SnkSimpleCrud = class {
629
647
  const options = filteredFields.map(field => ({ value: field.name, label: field.label }));
630
648
  return Promise.resolve(options);
631
649
  }
650
+ isGridInsertActive() {
651
+ return this.enableGridInsert && this.dataUnit.hasNewRecord();
652
+ }
632
653
  getActionsList() {
633
654
  var _a, _b;
634
655
  const hardList = [{
@@ -640,11 +661,22 @@ const SnkSimpleCrud = class {
640
661
  ? this.getColumnSearch(actionButton, item)
641
662
  : this.getFieldSearch(actionButton, item)
642
663
  }];
664
+ if (this.enableGridInsert) {
665
+ hardList.push(this._continuousInsertUtils.actionContinuousInsert(this._enableContinuousInsert, this.handleEnableContinuousInsert));
666
+ }
667
+ if (this.isGridInsertActive())
668
+ return hardList;
643
669
  if (this.taskbarManager != undefined && this.taskbarManager.getMoreOptions != undefined) {
644
670
  const taskbarID = this.getTopTaskBarId();
645
671
  return hardList.concat(this.taskbarManager.getMoreOptions(taskbarID, this.configName, this.dataState, this.actionsList));
646
672
  }
647
- return hardList.concat(this.actionsList);
673
+ if (this.actionsList)
674
+ return hardList.concat(this.actionsList);
675
+ return hardList;
676
+ }
677
+ handleEnableContinuousInsert() {
678
+ this._enableContinuousInsert = !this._enableContinuousInsert;
679
+ this._continuousInsertUtils.handleSaveConfig(this._enableContinuousInsert);
648
680
  }
649
681
  getTopTaskBarId() {
650
682
  var _a;
@@ -748,8 +780,8 @@ const SnkSimpleCrud = class {
748
780
  return StringUtils.isEmpty(this.resourceID) ? this._resourceID : this.resourceID;
749
781
  }
750
782
  getFormConfig() {
751
- var _a, _b;
752
- const configFromManager = (_a = this._formConfigManager) === null || _a === void 0 ? void 0 : _a.getConfig((_b = this.dataState) === null || _b === void 0 ? void 0 : _b.insertionMode, this.dataUnit, this.ignoreReadOnlyFormFields);
783
+ var _a;
784
+ const configFromManager = (_a = this._formConfigManager) === null || _a === void 0 ? void 0 : _a.getConfig(this.dataUnit, this.ignoreReadOnlyFormFields);
753
785
  if (!this.configName && !configFromManager) {
754
786
  return this.formConfig;
755
787
  }
@@ -763,15 +795,21 @@ const SnkSimpleCrud = class {
763
795
  }
764
796
  this._formConfigManager.setConfig(this.formConfig);
765
797
  }
798
+ handleDataUnitOnInsertionMode() {
799
+ if (this.enableGridInsert)
800
+ return;
801
+ this.goToView(VIEW_MODE.FORM);
802
+ }
766
803
  /* istanbul ignore next */
767
804
  render() {
768
805
  var _a;
769
806
  if (this.dataUnit == undefined) {
770
807
  return;
771
808
  }
772
- 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.goToView(VIEW_MODE.FORM), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), ignoreSaveMessage: this._currentViewMode === VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail, onDataUnitFieldsHidded: this.updateFormConfig.bind(this) }, h("header", null, h("slot", { name: "snkSimpleCrudHeader" })), h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, h("snk-taskbar", { class: "ez-box ez-box--shadow ez-padding--medium", dataUnit: this.dataUnit, primaryButton: ((_a = this.dataState) === null || _a === void 0 ? void 0 : _a.isDirty) ? "SAVE" : "INSERT", "data-element-id": "grid_left", messagesBuilder: this.messagesBuilder, buttons: this._taskbarProcessor.buttons, actionsList: this.getActionsList(), disabledButtons: this._taskbarProcessor.disabledButtons, customButtons: this._taskbarProcessor.customButtons, "data-exporter-store-key": this.getDataExporterStoreKey(), slot: "leftButtons", presentationMode: PresentationMode.SECONDARY }, h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })), h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, h("stack-item", null, h("ez-grid", { class: "ez-margin-bottom--large", ref: ref => this._grid = ref, dataUnit: this.dataUnit, config: this.gridConfig, "no-header": true, multipleSelection: this.multipleSelection, onEzDoubleClick: () => this.goToView(VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
809
+ const taskbarContent = (h("snk-taskbar", { class: this._currentViewMode === VIEW_MODE.FORM && "ez-box ez-box--shadow ez-padding--small", dataUnit: this.dataUnit, primaryButton: ((_a = this.dataState) === null || _a === void 0 ? void 0 : _a.isDirty) ? "SAVE" : "INSERT", "data-element-id": "grid_left", messagesBuilder: this.messagesBuilder, buttons: this._taskbarProcessor.buttons, actionsList: this.getActionsList(), disabledButtons: this._taskbarProcessor.disabledButtons, customButtons: this._taskbarProcessor.customButtons, "data-exporter-store-key": this.getDataExporterStoreKey(), slot: "leftButtons", presentationMode: PresentationMode.SECONDARY }, h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })));
810
+ 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), ignoreSaveMessage: this._currentViewMode === VIEW_MODE.GRID, 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--shadow simple-crud__container-section" }, this._currentViewMode === VIEW_MODE.FORM && taskbarContent, h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, h("stack-item", null, h("ez-grid", { class: "ez-margin-bottom--large", ref: ref => this._grid = ref, dataUnit: this.dataUnit, config: this.gridConfig, "no-header": true, multipleSelection: this.multipleSelection, onEzDoubleClick: () => this.goToView(VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
773
811
  ? undefined
774
- : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab, autoFocus: this.autoFocus }, h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, h("ez-form", { ref: (ref) => this._form = ref, class: `ez-margin-top--large ${this.handleShowFormConfig() ? "simple-crud__form--hidden" : ""}`, dataUnit: this.dataUnit, config: this.getFormConfig(), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this) }), this.handleShowFormConfig() && h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this.dataUnit, configManager: this._formConfigManager, onConfigClose: () => this.closeFormConfig() })), this.messagesBuilder && h("snk-configurator", { ref: (ref) => this._snkConfigurator = ref, viewMode: this._currentViewMode, messagesBuilder: this.messagesBuilder, onConfigSelected: (evt) => this.goToView(evt.detail), onOpenConfig: (evt) => this.openConfig(evt.detail), showActionButtons: this.showConfiguratorButtons, onSave: evt => this.handleConfiguratorEvent(evt, 'SAVE'), onCancel: evt => this.handleConfiguratorEvent(evt, 'CANCEL'), resourceID: this.resolveResourceID(), customContainerId: this._customContainerId })), h("div", { id: `${this._customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }))), h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._showPopUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this.resolveResourceID() }))));
812
+ : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab, autoFocus: this.autoFocus, enableGridInsert: this.enableGridInsert, enableContinuousInsert: this._enableContinuousInsert }, this._currentViewMode === VIEW_MODE.GRID && taskbarContent, h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, h("ez-form", { ref: (ref) => this._form = ref, class: `ez-margin-top--large ${this.handleShowFormConfig() ? "simple-crud__form--hidden" : ""}`, dataUnit: this.dataUnit, config: this.getFormConfig(), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this) }), this.handleShowFormConfig() && h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this.dataUnit, configManager: this._formConfigManager, onConfigClose: () => this.closeFormConfig() })), this.messagesBuilder && h("snk-configurator", { ref: (ref) => this._snkConfigurator = ref, viewMode: this._currentViewMode, messagesBuilder: this.messagesBuilder, onConfigSelected: (evt) => this.goToView(evt.detail), onOpenConfig: (evt) => this.openConfig(evt.detail), showActionButtons: this.showConfiguratorButtons, onSave: evt => this.handleConfiguratorEvent(evt, 'SAVE'), onCancel: evt => this.handleConfiguratorEvent(evt, 'CANCEL'), resourceID: this.resolveResourceID(), customContainerId: this._customContainerId })), h("div", { id: `${this._customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }))), h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._showPopUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this.resolveResourceID() }))));
775
813
  }
776
814
  get _element() { return getElement(this); }
777
815
  static get watchers() { return {