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

Sign up to get free protection for your applications and to get access to all the features.
Files changed (200) hide show
  1. package/dist/cjs/{ConfigStorage-a343e418.js → ConfigStorage-ecc0ed20.js} +2 -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-166cbd1f.js → SnkFormConfigManager-f1c92f79.js} +72 -16
  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 +12 -6
  18. package/dist/cjs/snk-data-exporter.cjs.entry.js +9 -9
  19. package/dist/cjs/{snk-data-unit-04df81bf.js → snk-data-unit-47202e42.js} +20 -11
  20. package/dist/cjs/snk-data-unit.cjs.entry.js +5 -5
  21. package/dist/cjs/snk-detail-view.cjs.entry.js +11 -11
  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 +15 -4
  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-bdc41281.js → snk-guides-viewer-68777d37.js} +23 -11
  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 +53 -21
  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 +59 -1
  39. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +2 -2
  40. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +50 -5
  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 +18 -9
  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 +70 -14
  51. package/dist/collection/components/snk-form-config/snk-form-config.js +13 -2
  52. package/dist/collection/components/snk-grid/snk-grid.css +2 -0
  53. package/dist/collection/components/snk-grid/snk-grid.js +68 -8
  54. package/dist/collection/components/snk-simple-bar/snk-simple-bar.js +1 -1
  55. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +0 -1
  56. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +62 -29
  57. package/dist/collection/components/snk-taskbar/processor/taskbar-processor.js +5 -1
  58. package/dist/collection/components/snk-taskbar/snk-taskbar.js +64 -0
  59. package/dist/collection/lib/DefaultCustomFormatters/RmPrecisionCustomValueFormatter.js +3 -3
  60. package/dist/collection/lib/dataUnit/InMemoryLoader.js +2 -4
  61. package/dist/collection/lib/dataUnit/dataUnitInMemoryUtils.js +34 -9
  62. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +22 -16
  63. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.js +7 -5
  64. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy.js +9 -2
  65. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +4 -1
  66. package/dist/collection/lib/message/resources/snk-data-unit.msg.js +1 -1
  67. package/dist/collection/lib/message/resources/snk-exporter.msg.js +1 -1
  68. package/dist/collection/lib/message/resources/snk-grid.msg.js +5 -1
  69. package/dist/collection/lib/utils/ContinuousInsertUtils.js +31 -0
  70. package/dist/collection/{components/snk-data-exporter/utils/RecordIDUtils.js → lib/utils/GetSelectedRecordsIDsInfo.js} +9 -9
  71. package/dist/components/{IExporterProvider.js → ContinuousInsertUtils.js} +40 -5
  72. package/dist/components/DataFetcher.js +22 -16
  73. package/dist/{esm/RecordIDUtils-87d02110.js → components/GetSelectedRecordsIDsInfo.js} +10 -10
  74. package/dist/components/SnkFormConfigManager.js +70 -14
  75. package/dist/components/SnkMessageBuilder.js +7 -3
  76. package/dist/components/dataunit-fetcher.js +45 -15
  77. package/dist/components/form-config-fetcher.js +4 -1
  78. package/dist/components/snk-actions-button2.js +12 -9
  79. package/dist/components/snk-attach2.js +33 -24
  80. package/dist/components/snk-crud.js +9 -1
  81. package/dist/components/snk-data-exporter2.js +2 -2
  82. package/dist/components/snk-data-unit2.js +21 -49
  83. package/dist/components/snk-detail-view2.js +22 -8
  84. package/dist/components/snk-exporter-email-sender2.js +1 -1
  85. package/dist/components/snk-filter-bar2.js +35 -22
  86. package/dist/components/snk-filter-checkbox-list.js +1 -1
  87. package/dist/components/snk-form-config2.js +13 -2
  88. package/dist/components/snk-form.js +2 -2
  89. package/dist/components/snk-grid2.js +53 -11
  90. package/dist/components/snk-simple-bar2.js +1 -1
  91. package/dist/components/snk-simple-crud2.js +45 -10
  92. package/dist/components/snk-taskbar2.js +24 -2
  93. package/dist/esm/{ConfigStorage-3806514e.js → ConfigStorage-7b36d041.js} +2 -2
  94. package/dist/esm/{IExporterProvider-63a188b6.js → ContinuousInsertUtils-1a82a768.js} +40 -8
  95. package/dist/esm/{DataFetcher-c1baf61d.js → DataFetcher-a9c598f2.js} +22 -16
  96. package/dist/esm/GetSelectedRecordsIDsInfo-9fa41508.js +41 -0
  97. package/dist/esm/{SnkFormConfigManager-31b24066.js → SnkFormConfigManager-139f09fa.js} +72 -16
  98. package/dist/esm/{SnkMessageBuilder-89925609.js → SnkMessageBuilder-6fff4a4c.js} +7 -3
  99. package/dist/esm/{auth-fetcher-039abba3.js → auth-fetcher-749d880f.js} +1 -1
  100. package/dist/esm/{dataunit-fetcher-264191b2.js → dataunit-fetcher-c24c76c6.js} +46 -16
  101. package/dist/esm/{field-search-efbe307f.js → field-search-f8b1d91e.js} +5 -1
  102. package/dist/esm/{form-config-fetcher-30fb808f.js → form-config-fetcher-adbe5d34.js} +5 -2
  103. package/dist/esm/loader.js +1 -1
  104. package/dist/esm/{pesquisa-fetcher-03c8f919.js → pesquisa-fetcher-8edaa8cd.js} +1 -1
  105. package/dist/esm/sankhyablocks.js +1 -1
  106. package/dist/esm/snk-actions-button_4.entry.js +17 -14
  107. package/dist/esm/snk-application.entry.js +7 -7
  108. package/dist/esm/snk-attach.entry.js +37 -28
  109. package/dist/esm/snk-crud.entry.js +12 -6
  110. package/dist/esm/snk-data-exporter.entry.js +9 -9
  111. package/dist/esm/{snk-data-unit-8eec78bd.js → snk-data-unit-de45e0e1.js} +20 -11
  112. package/dist/esm/snk-data-unit.entry.js +5 -5
  113. package/dist/esm/snk-detail-view.entry.js +11 -11
  114. package/dist/esm/snk-exporter-email-sender.entry.js +1 -1
  115. package/dist/esm/snk-filter-bar.entry.js +37 -25
  116. package/dist/esm/snk-filter-checkbox-list.entry.js +1 -1
  117. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  118. package/dist/esm/snk-form-config.entry.js +15 -4
  119. package/dist/esm/snk-form.entry.js +7 -6
  120. package/dist/esm/snk-grid.entry.js +56 -16
  121. package/dist/esm/{snk-guides-viewer-dda0fede.js → snk-guides-viewer-b5dd30e6.js} +23 -11
  122. package/dist/esm/snk-guides-viewer.entry.js +9 -9
  123. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  124. package/dist/esm/snk-simple-bar.entry.js +1 -1
  125. package/dist/esm/snk-simple-crud.entry.js +49 -17
  126. package/dist/esm/snk-taskbar.entry.js +23 -1
  127. package/dist/sankhyablocks/p-0035ad6e.entry.js +1 -0
  128. package/dist/sankhyablocks/{p-df5451c7.js → p-06421fdb.js} +2 -2
  129. package/dist/sankhyablocks/p-0911e61a.entry.js +1 -0
  130. package/dist/sankhyablocks/p-16a1dd18.entry.js +1 -0
  131. package/dist/sankhyablocks/p-17425c72.js +1 -0
  132. package/dist/sankhyablocks/p-18ed15f4.entry.js +1 -0
  133. package/dist/sankhyablocks/{p-af8efd95.js → p-1bf06cd3.js} +2 -2
  134. package/dist/sankhyablocks/{p-47db7e88.entry.js → p-212213d9.entry.js} +1 -1
  135. package/dist/sankhyablocks/p-23736d75.js +1 -0
  136. package/dist/sankhyablocks/p-3ae9d08a.js +1 -0
  137. package/dist/sankhyablocks/p-3e3cc017.js +1 -0
  138. package/dist/sankhyablocks/{p-52920496.js → p-4d9549cf.js} +1 -1
  139. package/dist/sankhyablocks/p-50779ad3.entry.js +1 -0
  140. package/dist/sankhyablocks/{p-aaa3ee68.entry.js → p-5f157b09.entry.js} +1 -1
  141. package/dist/sankhyablocks/p-60b29483.entry.js +1 -0
  142. package/dist/sankhyablocks/p-62e048c6.entry.js +1 -0
  143. package/dist/sankhyablocks/{p-c1d57831.entry.js → p-694e1c4a.entry.js} +1 -1
  144. package/dist/sankhyablocks/p-73185e58.entry.js +1 -0
  145. package/dist/sankhyablocks/p-7ac7932c.js +60 -0
  146. package/dist/sankhyablocks/p-7dd49d15.js +1 -0
  147. package/dist/sankhyablocks/p-7eef0898.entry.js +1 -0
  148. package/dist/sankhyablocks/{p-045eae4d.entry.js → p-a42e7a1e.entry.js} +2 -2
  149. package/dist/sankhyablocks/p-afbb070d.js +1 -0
  150. package/dist/sankhyablocks/p-b9679243.entry.js +1 -0
  151. package/dist/sankhyablocks/p-bccfc262.js +1 -0
  152. package/dist/sankhyablocks/p-c2e468c9.entry.js +1 -0
  153. package/dist/sankhyablocks/{p-913a9979.js → p-ca5ec380.js} +1 -1
  154. package/dist/sankhyablocks/p-da34270e.entry.js +1 -0
  155. package/dist/sankhyablocks/p-e16e87fc.entry.js +1 -0
  156. package/dist/sankhyablocks/p-eb9f0407.entry.js +1 -0
  157. package/dist/sankhyablocks/p-f3434fc4.js +1 -0
  158. package/dist/sankhyablocks/{p-2c68b3ae.entry.js → p-fb34e0cf.entry.js} +1 -1
  159. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  160. package/dist/types/components/snk-actions-button/actions/index.d.ts +1 -0
  161. package/dist/types/components/snk-attach/snk-attach.d.ts +1 -0
  162. package/dist/types/components/snk-crud/snk-crud.d.ts +9 -0
  163. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +11 -0
  164. package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +1 -0
  165. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +5 -0
  166. package/dist/types/components/snk-form-config/SnkFormConfigManager.d.ts +7 -2
  167. package/dist/types/components/snk-grid/snk-grid.d.ts +12 -0
  168. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +10 -4
  169. package/dist/types/components/snk-taskbar/processor/taskbar-processor.d.ts +1 -0
  170. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +11 -0
  171. package/dist/types/components.d.ts +67 -2
  172. package/dist/types/lib/dataUnit/dataUnitInMemoryUtils.d.ts +12 -2
  173. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.d.ts +3 -2
  174. package/dist/types/lib/utils/ContinuousInsertUtils.d.ts +10 -0
  175. package/dist/types/lib/utils/GetSelectedRecordsIDsInfo.d.ts +3 -0
  176. package/package.json +2 -2
  177. package/dist/sankhyablocks/p-219f888d.entry.js +0 -1
  178. package/dist/sankhyablocks/p-2a408684.js +0 -1
  179. package/dist/sankhyablocks/p-3a212712.js +0 -1
  180. package/dist/sankhyablocks/p-450c60e4.entry.js +0 -1
  181. package/dist/sankhyablocks/p-46d38387.entry.js +0 -1
  182. package/dist/sankhyablocks/p-4e5e1313.entry.js +0 -1
  183. package/dist/sankhyablocks/p-547eeac8.entry.js +0 -1
  184. package/dist/sankhyablocks/p-62ba211a.entry.js +0 -1
  185. package/dist/sankhyablocks/p-7505da04.entry.js +0 -1
  186. package/dist/sankhyablocks/p-75e674ed.entry.js +0 -1
  187. package/dist/sankhyablocks/p-7a337364.js +0 -1
  188. package/dist/sankhyablocks/p-7a85fd49.entry.js +0 -1
  189. package/dist/sankhyablocks/p-7b08d0f8.entry.js +0 -1
  190. package/dist/sankhyablocks/p-88aa931b.entry.js +0 -1
  191. package/dist/sankhyablocks/p-9863d682.js +0 -1
  192. package/dist/sankhyablocks/p-b05d8893.entry.js +0 -1
  193. package/dist/sankhyablocks/p-c2495304.js +0 -1
  194. package/dist/sankhyablocks/p-d6e26ea8.entry.js +0 -1
  195. package/dist/sankhyablocks/p-dc7c9047.js +0 -1
  196. package/dist/sankhyablocks/p-e549f7d1.js +0 -1
  197. package/dist/sankhyablocks/p-f2809746.entry.js +0 -1
  198. package/dist/sankhyablocks/p-fa4d8cb4.js +0 -1
  199. package/dist/sankhyablocks/p-fe79f83a.js +0 -60
  200. package/dist/types/components/snk-data-exporter/utils/RecordIDUtils.d.ts +0 -3
@@ -99,7 +99,7 @@ const SnkForm$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
99
99
  if (this.resourceID == undefined) {
100
100
  this.resourceID = await ResourceIDUtils.getResourceID();
101
101
  }
102
- this._configManager = new SnkFormConfigManager(this.configName, this.resourceID);
102
+ this._configManager = new SnkFormConfigManager(this.configName, this.resourceID, undefined, this._dataUnit);
103
103
  this.addFormLegacyConfig();
104
104
  await this._configManager.loadConfig();
105
105
  }
@@ -128,7 +128,7 @@ const SnkForm$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
128
128
  if (!this._dataUnit || !this._dataState) {
129
129
  return undefined;
130
130
  }
131
- return (h("section", null, h("div", { class: "ez-row" }, h("div", { class: "ez-col ez-col--sd-12" }, h("ez-form", { ref: (ref) => this._form = ref, key: "ezForm" + this._snkDataUnit.entityName, "data-element-id": "embedded", dataUnit: this._dataUnit, config: this._configManager.getConfig(this._dataState.insertionMode, this._dataUnit), recordsValidator: this.recordsValidator, class: this._showFormConfig ? 'snk-form__form--hidden' : '' }), this._showFormConfig &&
131
+ return (h("section", null, h("div", { class: "ez-row" }, h("div", { class: "ez-col ez-col--sd-12" }, h("ez-form", { ref: (ref) => this._form = ref, key: "ezForm" + this._snkDataUnit.entityName, "data-element-id": "embedded", dataUnit: this._dataUnit, config: this._configManager.getConfig(this._dataUnit), recordsValidator: this.recordsValidator, class: this._showFormConfig ? 'snk-form__form--hidden' : '' }), this._showFormConfig &&
132
132
  h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this._dataUnit, configManager: this._configManager, onConfigClose: () => this.closeConfig() })))));
133
133
  }
134
134
  get _element() { return this; }
@@ -1,9 +1,9 @@
1
1
  import { proxyCustomElement, HTMLElement, createEvent, h, Fragment } from '@stencil/core/internal/client';
2
2
  import { Action, ElementIDUtils, ApplicationContext, StringUtils } from '@sankhyalabs/core';
3
- import { d as defineCustomElement$2, T as TaskbarElement } from './snk-taskbar2.js';
3
+ import { T as TaskbarElement, d as defineCustomElement$2 } from './snk-taskbar2.js';
4
4
  import { C as ConfigStorage } from './ConfigStorage.js';
5
5
  import { P as PresentationMode } from './ISave.js';
6
- import { C as CommonsExporter, T as TaskbarProcessor, S as SnkMultiSelectionListDataSource, o as openFieldSearch, a as CrudUtils, R as RmPrecisionCustomValueFormatter, b as buildFieldSearch } from './IExporterProvider.js';
6
+ import { C as CommonsExporter, T as TaskbarProcessor, S as SnkMultiSelectionListDataSource, o as openFieldSearch, a as CrudUtils, R as RmPrecisionCustomValueFormatter, c as ContinuousInsertUtils, b as buildFieldSearch } from './ContinuousInsertUtils.js';
7
7
  import { s as store } from './index2.js';
8
8
  import { SelectionMode } from '@sankhyalabs/core/dist/dataunit/DataUnit';
9
9
  import './DataFetcher.js';
@@ -13,7 +13,7 @@ import '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
13
13
  import './dataunit-fetcher.js';
14
14
  import './filter-item-type.enum.js';
15
15
  import './form-config-fetcher.js';
16
- import { g as getSelectedIDs } from './snk-data-unit2.js';
16
+ import { g as getSelectedRecordsIDsInfo } from './GetSelectedRecordsIDsInfo.js';
17
17
  import { d as defineCustomElement$i } from './snk-actions-button2.js';
18
18
  import { d as defineCustomElement$h } from './snk-data-exporter2.js';
19
19
  import { d as defineCustomElement$g } from './snk-exporter-email-sender2.js';
@@ -54,7 +54,7 @@ class ServerSideExporterProvider extends CommonsExporter {
54
54
  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;
55
55
  }
56
56
  getSelectedIDs() {
57
- return getSelectedIDs(this.dataUnit);
57
+ return getSelectedRecordsIDsInfo(this.dataUnit);
58
58
  }
59
59
  getOffset() {
60
60
  return this.getExporterOffset(this.getPaginationInfo());
@@ -86,7 +86,7 @@ class ServerSideExporterProvider extends CommonsExporter {
86
86
  }
87
87
  }
88
88
 
89
- 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}";
89
+ 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}";
90
90
 
91
91
  const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
92
92
  constructor() {
@@ -100,7 +100,7 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
100
100
  "snkGridTopTaskbar.regular": ["FORM_MODE", "CONFIGURATOR", "INSERT"],
101
101
  "snkGridTopTaskbar.regular.secondary": ["FORM_MODE", "CONFIGURATOR", "INSERT"],
102
102
  "snkGridTopTaskbar.regular.singleTaskbar": [],
103
- "snkGridTopTaskbar.finish_edition": ["CANCEL", "SAVE"],
103
+ "snkGridTopTaskbar.finish_edition": ["CANCEL", "SAVE", this.handleAddFormMode()],
104
104
  "snkGridTopTaskbar.finish_edition.secondary": [],
105
105
  "snkGridTopTaskbar.finish_edition.singleTaskbar": [],
106
106
  });
@@ -113,7 +113,7 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
113
113
  "snkGridHeaderTaskbar.singleTaskbar.selected": ["UPDATE", "CLONE", "REMOVE", "MORE_OPTIONS", "DIVIDER", "ATTACH", "FORM_MODE", "CONFIGURATOR", "REFRESH", "DATA_EXPORTER", "ACTIONS_BUTTON"],
114
114
  "snkGridHeaderTaskbar.singleTaskbar.detail.unselected": ["INSERT", "FORM_MODE", "CONFIGURATOR", "REFRESH", "MORE_OPTIONS"],
115
115
  "snkGridHeaderTaskbar.singleTaskbar.detail.selected": ["UPDATE", "ATTACH", "CLONE", "REMOVE", "MORE_OPTIONS", "DIVIDER", "FORM_MODE", "CONFIGURATOR", "REFRESH"],
116
- "snkGridHeaderTaskbar.singleTaskbar.finish_edition": ["CANCEL", "SAVE"]
116
+ "snkGridHeaderTaskbar.singleTaskbar.finish_edition": ["CANCEL", "SAVE", this.handleAddFormMode()]
117
117
  });
118
118
  this.dataUnitInterceptor = {
119
119
  interceptAction: async (action) => {
@@ -128,6 +128,7 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
128
128
  this._gridConfig = undefined;
129
129
  this._popUpGridConfig = false;
130
130
  this._showSnkFilterBar = true;
131
+ this._enableContinuousInsert = false;
131
132
  this.columnFilterDataSource = new SnkMultiSelectionListDataSource();
132
133
  this.configName = undefined;
133
134
  this.filterBarTitle = undefined;
@@ -151,6 +152,7 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
151
152
  this.filterBarLegacyConfigName = undefined;
152
153
  this.autoLoad = undefined;
153
154
  this.autoFocus = true;
155
+ this.enableGridInsert = false;
154
156
  }
155
157
  /**
156
158
  * Exibe a janela de configurações da grade.
@@ -237,6 +239,16 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
237
239
  async setFocus() {
238
240
  this._grid.setFocus();
239
241
  }
242
+ async handleClick(event) {
243
+ if (this.hasToBlockEvent(event)) {
244
+ event.preventDefault();
245
+ event.stopPropagation();
246
+ await this._dataUnit.cancelEdition();
247
+ }
248
+ }
249
+ hasToBlockEvent(event) {
250
+ return this._snkFilterBar.contains(event.target) && this.enableGridInsert && this._dataUnit.hasNewRecord();
251
+ }
240
252
  async handleGridLegacyConfigName(newLegacyConfig, oldLegacyConfig) {
241
253
  if (!newLegacyConfig) {
242
254
  return;
@@ -247,6 +259,9 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
247
259
  this.addGridLegacyConfigName();
248
260
  this.loadConfig();
249
261
  }
262
+ handleAddFormMode() {
263
+ return this.enableGridInsert ? TaskbarElement.FORM_MODE : "";
264
+ }
250
265
  openGridConfig() {
251
266
  this._grid.getColumnsState()
252
267
  .then((gridColumns) => {
@@ -371,13 +386,21 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
371
386
  }
372
387
  parent = parent.parentElement;
373
388
  }
389
+ if (this._snkFilterBar) {
390
+ this._snkFilterBar.addEventListener('click', this.handleClick);
391
+ }
374
392
  this._rmPrecisionCustomValueFormatter = new RmPrecisionCustomValueFormatter();
375
393
  this.addGridLegacyConfigName();
376
394
  this.loadConfig();
395
+ this._continuousInsertUtils = new ContinuousInsertUtils(this._application, this.resourceID, this.configName);
396
+ if (this.enableGridInsert) {
397
+ this._continuousInsertUtils.getConfig().then(value => this._enableContinuousInsert = value);
398
+ }
377
399
  }
378
400
  componentDidRender() {
401
+ var _a, _b;
379
402
  this._rmPrecisionCustomValueFormatter.setGrid(this._grid);
380
- this.loadGridCustomFormatters(this._dataUnit.metadata.fields);
403
+ this.loadGridCustomFormatters((_b = (_a = this._dataUnit) === null || _a === void 0 ? void 0 : _a.metadata) === null || _b === void 0 ? void 0 : _b.fields);
381
404
  this.setCustomRenders();
382
405
  this.setCustomEditors();
383
406
  }
@@ -390,7 +413,7 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
390
413
  const disabledButtons = [];
391
414
  if ((_a = this._dataState) === null || _a === void 0 ? void 0 : _a.selectionInfo) {
392
415
  if (this._dataState.selectionInfo.length > 1) {
393
- disabledButtons.push(TaskbarElement.CLONE, "ATTACH");
416
+ disabledButtons.push(TaskbarElement.CLONE, "ATTACH", TaskbarElement.UPDATE);
394
417
  }
395
418
  if (this._dataState.selectionInfo.isAllRecords()) {
396
419
  disabledButtons.push("REMOVE");
@@ -475,12 +498,21 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
475
498
  eagerInitialize: true,
476
499
  itemBuilder: (actionButton, item) => this.getColumnSearch(actionButton, item)
477
500
  }];
501
+ if (this.enableGridInsert) {
502
+ hardList.push(this._continuousInsertUtils.actionContinuousInsert(this._enableContinuousInsert, this.handleEnableContinuousInsert));
503
+ }
504
+ if (this.isGridInsertActive())
505
+ return hardList;
478
506
  if (this.taskbarManager != undefined && this.taskbarManager.getMoreOptions != undefined) {
479
507
  const taskbarID = this.getTopTaskBarId();
480
508
  return hardList.concat(this.taskbarManager.getMoreOptions(taskbarID, this.configName, this._dataState, this.actionsList));
481
509
  }
482
510
  return hardList.concat(this.actionsList);
483
511
  }
512
+ handleEnableContinuousInsert() {
513
+ this._enableContinuousInsert = !this._enableContinuousInsert;
514
+ this._continuousInsertUtils.handleSaveConfig(this._enableContinuousInsert);
515
+ }
484
516
  handleFilterConfigUpdated(filterConfig) {
485
517
  if (!filterConfig.length) {
486
518
  this._showSnkFilterBar = false;
@@ -492,12 +524,20 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
492
524
  }
493
525
  this._showSnkFilterBar = true;
494
526
  }
527
+ getGridHeaderButtons() {
528
+ if (this.isGridInsertActive())
529
+ return TaskbarElement.MORE_OPTIONS;
530
+ return this._headerTaskbarProcessor.buttons;
531
+ }
532
+ isGridInsertActive() {
533
+ return this.enableGridInsert && this._dataUnit.hasNewRecord();
534
+ }
495
535
  render() {
496
536
  if (!this._dataUnit) {
497
537
  return undefined;
498
538
  }
499
- 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 &&
500
- 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 }))));
539
+ 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 &&
540
+ 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 }))));
501
541
  }
502
542
  get _element() { return this; }
503
543
  static get watchers() { return {
@@ -528,11 +568,13 @@ const SnkGrid = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
528
568
  "filterBarLegacyConfigName": [1, "filter-bar-legacy-config-name"],
529
569
  "autoLoad": [4, "auto-load"],
530
570
  "autoFocus": [4, "auto-focus"],
571
+ "enableGridInsert": [4, "enable-grid-insert"],
531
572
  "_dataUnit": [32],
532
573
  "_dataState": [32],
533
574
  "_gridConfig": [32],
534
575
  "_popUpGridConfig": [32],
535
576
  "_showSnkFilterBar": [32],
577
+ "_enableContinuousInsert": [32],
536
578
  "showConfig": [64],
537
579
  "hideConfig": [64],
538
580
  "setConfig": [64],
@@ -33,7 +33,7 @@ const SnkSimpleBar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
33
33
  this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
34
34
  }
35
35
  render() {
36
- 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" }))));
36
+ 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" }))));
37
37
  }
38
38
  get _element() { return this; }
39
39
  static get style() { return snkSimpleBarCss; }
@@ -5,7 +5,7 @@ import { V as VIEW_MODE, S as SIMPLE_CRUD_MODE } from './constants.js';
5
5
  import { T as TaskbarElement, d as defineCustomElement$2 } from './snk-taskbar2.js';
6
6
  import './DataFetcher.js';
7
7
  import './pesquisa-fetcher.js';
8
- import { C as CommonsExporter, S as SnkMultiSelectionListDataSource, T as TaskbarProcessor, R as RmPrecisionCustomValueFormatter, b as buildFieldSearch, o as openFieldSearch, a as CrudUtils } from './IExporterProvider.js';
8
+ import { C as CommonsExporter, S as SnkMultiSelectionListDataSource, T as TaskbarProcessor, R as RmPrecisionCustomValueFormatter, c as ContinuousInsertUtils, b as buildFieldSearch, o as openFieldSearch, a as CrudUtils } from './ContinuousInsertUtils.js';
9
9
  import { D as DataExporterOption, P as PresentationMode } from './ISave.js';
10
10
  import '@sankhyalabs/ezui/dist/collection/utils/constants';
11
11
  import '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
@@ -14,12 +14,13 @@ import './filter-item-type.enum.js';
14
14
  import { F as FormConfigFetcher } from './form-config-fetcher.js';
15
15
  import { C as ConfigStorage } from './ConfigStorage.js';
16
16
  import { S as SnkFormConfigManager } from './SnkFormConfigManager.js';
17
- import { g as getSelectedIDs, d as defineCustomElement$9 } from './snk-data-unit2.js';
17
+ import { g as getSelectedRecordsIDsInfo } from './GetSelectedRecordsIDsInfo.js';
18
18
  import { s as store } from './index2.js';
19
19
  import { d as defineCustomElement$d } from './snk-actions-button2.js';
20
20
  import { d as defineCustomElement$c } from './snk-config-options2.js';
21
21
  import { d as defineCustomElement$b } from './snk-configurator2.js';
22
22
  import { d as defineCustomElement$a } from './snk-data-exporter2.js';
23
+ import { d as defineCustomElement$9 } from './snk-data-unit2.js';
23
24
  import { d as defineCustomElement$8 } from './snk-exporter-email-sender2.js';
24
25
  import { d as defineCustomElement$7 } from './snk-field-config2.js';
25
26
  import { d as defineCustomElement$6 } from './snk-form-config2.js';
@@ -41,7 +42,7 @@ class ClientSideExporterProvider extends CommonsExporter {
41
42
  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;
42
43
  }
43
44
  getSelectedIDs() {
44
- return getSelectedIDs(this.dataUnit);
45
+ return getSelectedRecordsIDsInfo(this.dataUnit);
45
46
  }
46
47
  getRecordID() {
47
48
  var _a, _b, _c;
@@ -86,7 +87,7 @@ class ClientSideExporterProvider extends CommonsExporter {
86
87
  }
87
88
  }
88
89
 
89
- 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}";
90
+ 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}";
90
91
 
91
92
  const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
92
93
  constructor() {
@@ -108,7 +109,7 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
108
109
  "snkSimpleCrudTaskbar.grid_regular": this.getButtons(false, [TaskbarElement.DATA_EXPORTER, TaskbarElement.FORM_MODE]),
109
110
  "snkSimpleCrudTaskbar.form_selected": this.getButtons(true, [TaskbarElement.GRID_MODE]),
110
111
  "snkSimpleCrudTaskbar.grid_selected": this.getButtons(true, [TaskbarElement.DATA_EXPORTER, TaskbarElement.FORM_MODE]),
111
- "snkSimpleCrudTaskbar.finish_edition": ["CANCEL", "SAVE"]
112
+ "snkSimpleCrudTaskbar.finish_edition": this.getFinishEditionButtonsCallback.bind(this)
112
113
  });
113
114
  this._showPopUpGridConfig = false;
114
115
  this._showFormConfig = false;
@@ -124,10 +125,12 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
124
125
  this.formConfig = undefined;
125
126
  this._formFields = [];
126
127
  this._fieldsProps = new Map();
128
+ this._enableContinuousInsert = true;
127
129
  this.multipleSelection = undefined;
128
130
  this.useCancelConfirm = true;
129
131
  this.pageSize = 150;
130
132
  this.resourceID = undefined;
133
+ this.enableGridInsert = false;
131
134
  this.taskbarManager = undefined;
132
135
  this.messagesBuilder = undefined;
133
136
  this.useEnterLikeTab = false;
@@ -139,7 +142,6 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
139
142
  this.ignoreReadOnlyFormFields = false;
140
143
  this.autoFocus = true;
141
144
  this.domainMessagesBuilder = undefined;
142
- this.domainMessagesBuilder = 'InMemoryDomain';
143
145
  this.autoLoad = undefined;
144
146
  }
145
147
  /**
@@ -198,6 +200,13 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
198
200
  newCustomFieldProps.set(fieldName, Object.assign(Object.assign({}, currentProps), { [propName]: value }));
199
201
  this._fieldsProps = newCustomFieldProps;
200
202
  }
203
+ getFinishEditionButtonsCallback() {
204
+ const btns = ["CANCEL", "SAVE"];
205
+ if (this.enableGridInsert && this._currentViewMode !== VIEW_MODE.ATTACHMENT) {
206
+ btns.push(this._currentViewMode === VIEW_MODE.GRID ? TaskbarElement.FORM_MODE : TaskbarElement.GRID_MODE);
207
+ }
208
+ return btns;
209
+ }
201
210
  getButtons(selected, extraButtons) {
202
211
  return this.addConfigButton(this.resolveInMemoryBtns(selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS)
203
212
  .concat(extraButtons));
@@ -361,7 +370,7 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
361
370
  return;
362
371
  }
363
372
  if (this._formConfigManager == undefined) {
364
- this._formConfigManager = new SnkFormConfigManager(this.configName, this.resolveResourceID());
373
+ this._formConfigManager = new SnkFormConfigManager(this.configName, this.resolveResourceID(), undefined, this.dataUnit);
365
374
  this._formConfigManager.setConfig(this.formConfig);
366
375
  }
367
376
  if (this.formConfigIsLoaded() && !forceLoad) {
@@ -402,6 +411,10 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
402
411
  this.onModeChange();
403
412
  this.configDatasource();
404
413
  this._rmPrecisionCustomValueFormatter = new RmPrecisionCustomValueFormatter();
414
+ this._continuousInsertUtils = new ContinuousInsertUtils(this.application, this.resolveResourceID(), this.configName);
415
+ if (this.enableGridInsert) {
416
+ this._continuousInsertUtils.getConfig().then(value => this._enableContinuousInsert = value);
417
+ }
405
418
  }
406
419
  componentDidLoad() {
407
420
  CSSVarsUtils.applyVarsGrid(this._element, this._grid);
@@ -636,6 +649,9 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
636
649
  const options = filteredFields.map(field => ({ value: field.name, label: field.label }));
637
650
  return Promise.resolve(options);
638
651
  }
652
+ isGridInsertActive() {
653
+ return this.enableGridInsert && this.dataUnit.hasNewRecord();
654
+ }
639
655
  getActionsList() {
640
656
  var _a, _b;
641
657
  const hardList = [{
@@ -647,11 +663,22 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
647
663
  ? this.getColumnSearch(actionButton, item)
648
664
  : this.getFieldSearch(actionButton, item)
649
665
  }];
666
+ if (this.enableGridInsert) {
667
+ hardList.push(this._continuousInsertUtils.actionContinuousInsert(this._enableContinuousInsert, this.handleEnableContinuousInsert));
668
+ }
669
+ if (this.isGridInsertActive())
670
+ return hardList;
650
671
  if (this.taskbarManager != undefined && this.taskbarManager.getMoreOptions != undefined) {
651
672
  const taskbarID = this.getTopTaskBarId();
652
673
  return hardList.concat(this.taskbarManager.getMoreOptions(taskbarID, this.configName, this.dataState, this.actionsList));
653
674
  }
654
- return hardList.concat(this.actionsList);
675
+ if (this.actionsList)
676
+ return hardList.concat(this.actionsList);
677
+ return hardList;
678
+ }
679
+ handleEnableContinuousInsert() {
680
+ this._enableContinuousInsert = !this._enableContinuousInsert;
681
+ this._continuousInsertUtils.handleSaveConfig(this._enableContinuousInsert);
655
682
  }
656
683
  getTopTaskBarId() {
657
684
  var _a;
@@ -770,15 +797,21 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
770
797
  }
771
798
  this._formConfigManager.setConfig(this.formConfig);
772
799
  }
800
+ handleDataUnitOnInsertionMode() {
801
+ if (this.enableGridInsert)
802
+ return;
803
+ this.goToView(VIEW_MODE.FORM);
804
+ }
773
805
  /* istanbul ignore next */
774
806
  render() {
775
807
  var _a;
776
808
  if (this.dataUnit == undefined) {
777
809
  return;
778
810
  }
779
- 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), domainMessagesBuilder: this.domainMessagesBuilder }, 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)
811
+ 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" })));
812
+ 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)
780
813
  ? undefined
781
- : 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() }))));
814
+ : 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() }))));
782
815
  }
783
816
  get _element() { return this; }
784
817
  static get watchers() { return {
@@ -801,6 +834,7 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
801
834
  "useCancelConfirm": [4, "use-cancel-confirm"],
802
835
  "pageSize": [2, "page-size"],
803
836
  "resourceID": [1, "resource-i-d"],
837
+ "enableGridInsert": [4, "enable-grid-insert"],
804
838
  "taskbarManager": [16],
805
839
  "messagesBuilder": [1040],
806
840
  "useEnterLikeTab": [4, "use-enter-like-tab"],
@@ -821,6 +855,7 @@ const SnkSimpleCrud = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement
821
855
  "_customContainerId": [32],
822
856
  "_formFields": [32],
823
857
  "_fieldsProps": [32],
858
+ "_enableContinuousInsert": [32],
824
859
  "addCustomEditor": [64],
825
860
  "addGridCustomRender": [64],
826
861
  "addCustomValueFormatter": [64],
@@ -128,6 +128,8 @@ const SnkTaskbar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
128
128
  super();
129
129
  this.__registerHost();
130
130
  this.actionClick = createEvent(this, "actionClick", 7);
131
+ this.taskbarSaveLocker = createEvent(this, "taskbarSaveLocker", 7);
132
+ this.taskbarSaveUnlocker = createEvent(this, "taskbarSaveUnlocker", 7);
131
133
  this.TASKBAR_ITEM_ID_PREFIX = 'TASKBAR_ITEM_';
132
134
  this.TASKBAR_CUSTOM_ELEMENTS_CONTAINER_CLASS_NAME = 'taskbar-custom-elements-container';
133
135
  this.ACTIONS_BUTTON_TAG = 'TASKBAR-ACTIONS-BUTTON';
@@ -151,6 +153,7 @@ const SnkTaskbar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
151
153
  this.onSaveEvent = (action) => {
152
154
  switch (action.type) {
153
155
  case Action.FIELD_INVALIDATED:
156
+ case Action.INVALIDATE_CLEAN:
154
157
  case Action.DATA_SAVED:
155
158
  case Action.SAVING_ERROR:
156
159
  this._isWaitingForSave = false;
@@ -189,6 +192,16 @@ const SnkTaskbar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
189
192
  this.getCustomElements(true);
190
193
  }
191
194
  }
195
+ handleTaskbarSaveLocker() {
196
+ if (this._isWaitingForSave !== true) {
197
+ this._isWaitingForSave = true;
198
+ }
199
+ }
200
+ handleTaskbarSaveUnlocker() {
201
+ if (this._isWaitingForSave === true) {
202
+ this._isWaitingForSave = false;
203
+ }
204
+ }
192
205
  hasToSearchCustomElements(event) {
193
206
  return this.customSlotId === event.detail && !this._slotContainer;
194
207
  }
@@ -207,6 +220,14 @@ const SnkTaskbar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
207
220
  this._hasToUpdateOverFlow = true;
208
221
  }
209
222
  }
223
+ observeIsWaitingForSave(newValue, oldValue) {
224
+ if (newValue == true && oldValue == false) {
225
+ this.taskbarSaveLocker.emit();
226
+ }
227
+ if (newValue == false && oldValue == true) {
228
+ this.taskbarSaveUnlocker.emit();
229
+ }
230
+ }
210
231
  // Internal methods
211
232
  elementsFromString(strButtons) {
212
233
  const elements = [];
@@ -535,7 +556,8 @@ const SnkTaskbar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
535
556
  static get watchers() { return {
536
557
  "buttons": ["observeButtons"],
537
558
  "disabledButtons": ["observeDisabledButtons"],
538
- "_lastWidth": ["observeLastWidth"]
559
+ "_lastWidth": ["observeLastWidth"],
560
+ "_isWaitingForSave": ["observeIsWaitingForSave"]
539
561
  }; }
540
562
  static get style() { return snkTaskbarCss; }
541
563
  }, [6, "snk-taskbar", {
@@ -562,7 +584,7 @@ const SnkTaskbar = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
562
584
  "_lastWidth": [32],
563
585
  "_hasToUpdateOverFlow": [32],
564
586
  "_isWaitingForSave": [32]
565
- }, [[8, "snkCustomSlotElementsLoaded", "handleCustomSlotElementsLoaded"]]]);
587
+ }, [[8, "snkCustomSlotElementsLoaded", "handleCustomSlotElementsLoaded"], [8, "taskbarSaveLocker", "handleTaskbarSaveLocker"], [8, "taskbarSaveUnlocker", "handleTaskbarSaveUnlocker"]]]);
566
588
  function defineCustomElement() {
567
589
  if (typeof customElements === "undefined") {
568
590
  return;
@@ -1,7 +1,7 @@
1
- import { R as ResourceFetcher, F as FormConfigFetcher } from './form-config-fetcher-30fb808f.js';
1
+ import { R as ResourceFetcher, F as FormConfigFetcher } from './form-config-fetcher-adbe5d34.js';
2
2
  import { F as FilterItemType } from './filter-item-type.enum-d45e026f.js';
3
3
  import { ObjectUtils } from '@sankhyalabs/core';
4
- import { d as dist, D as DataFetcher } from './DataFetcher-c1baf61d.js';
4
+ import { d as dist, D as DataFetcher } from './DataFetcher-a9c598f2.js';
5
5
 
6
6
  class GridConfigFetcher extends ResourceFetcher {
7
7
  constructor() {
@@ -1,14 +1,15 @@
1
- import { D as DataFetcher } from './DataFetcher-c1baf61d.js';
2
- import './pesquisa-fetcher-03c8f919.js';
3
- import { SortMode, ApplicationContext, UserInterface, DateUtils, ObjectUtils, NumberUtils, DataType } from '@sankhyalabs/core';
1
+ import { D as DataFetcher } from './DataFetcher-a9c598f2.js';
2
+ import './pesquisa-fetcher-8edaa8cd.js';
3
+ import { SortMode, ApplicationContext, UserInterface, DateUtils, ObjectUtils, StringUtils, NumberUtils, DataType } from '@sankhyalabs/core';
4
4
  import './index-3aa4977a.js';
5
5
  import './ISave-d8c8bc59.js';
6
6
  import '@sankhyalabs/ezui/dist/collection/utils/constants';
7
7
  import { UserInterface as UserInterface$1 } from '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
8
- import { P as PreloadManager } from './dataunit-fetcher-264191b2.js';
8
+ import { P as PreloadManager } from './dataunit-fetcher-c24c76c6.js';
9
9
  import './filter-item-type.enum-d45e026f.js';
10
- import './form-config-fetcher-30fb808f.js';
10
+ import './form-config-fetcher-adbe5d34.js';
11
11
  import InMemoryFilterColumnDataSource from '@sankhyalabs/ezui/dist/collection/components/ez-grid/utils/InMemoryFilterColumnDataSource';
12
+ import { h } from './index-a7d3d3f1.js';
12
13
 
13
14
  class CrudUtils {
14
15
  static assertDefaultSorting(gridConfig, dataUnit) {
@@ -140,7 +141,7 @@ class RmPrecisionCustomValueFormatter {
140
141
  this.refreshSelectedRows();
141
142
  }
142
143
  setDataState(dataState) {
143
- if (ObjectUtils.objectToString(dataState) === ObjectUtils.objectToString(this._dataState)) {
144
+ if (this._dataState && ObjectUtils.equals(dataState === null || dataState === void 0 ? void 0 : dataState.metadataByRow, this._dataState.metadataByRow)) {
144
145
  return;
145
146
  }
146
147
  this._dataState = dataState;
@@ -148,7 +149,7 @@ class RmPrecisionCustomValueFormatter {
148
149
  }
149
150
  format(currentValue, column, recordId) {
150
151
  var _a;
151
- if (!currentValue) {
152
+ if (StringUtils.isEmpty(currentValue)) {
152
153
  return currentValue;
153
154
  }
154
155
  const rowMetadata = (_a = this._dataState) === null || _a === void 0 ? void 0 : _a.metadataByRow.get(recordId);
@@ -218,4 +219,35 @@ class CommonsExporter {
218
219
  }
219
220
  }
220
221
 
221
- export { CommonsExporter as C, RmPrecisionCustomValueFormatter as R, SnkMultiSelectionListDataSource as S, CrudUtils as a };
222
+ class ContinuousInsertUtils {
223
+ constructor(snkApplication, resourceID, configName) {
224
+ this.snkApplication = snkApplication;
225
+ this.keyConfigEnableContinuousInsert = `${resourceID}enableContinuousInsert${configName ? configName : ''}`;
226
+ }
227
+ handleSaveConfig(enableContinuousInsert) {
228
+ return this.snkApplication.saveConfig(this.keyConfigEnableContinuousInsert, enableContinuousInsert);
229
+ }
230
+ getConfig() {
231
+ return this.snkApplication.getConfig(this.keyConfigEnableContinuousInsert).then(value => {
232
+ if (value) {
233
+ return value == "true" ? true : false;
234
+ }
235
+ return false;
236
+ }).catch(() => {
237
+ return false;
238
+ });
239
+ }
240
+ actionContinuousInsert(enableContinuousInsert, handleEnableContinuousInsert) {
241
+ return {
242
+ value: StringUtils.generateUUID(),
243
+ label: enableContinuousInsert ? 'Desativar inclusão contínua' : 'Ativar inclusão contínua',
244
+ enabled: true,
245
+ itemBuilder: () => {
246
+ return (h("div", { class: "ez-dropdown__item-wrapper", onClick: () => handleEnableContinuousInsert() },
247
+ h("span", { class: "ez-dropdown__item-label" }, enableContinuousInsert ? 'Desativar inclusão contínua' : 'Ativar inclusão contínua')));
248
+ },
249
+ };
250
+ }
251
+ }
252
+
253
+ export { CommonsExporter as C, RmPrecisionCustomValueFormatter as R, SnkMultiSelectionListDataSource as S, CrudUtils as a, ContinuousInsertUtils as b };