@sankhyalabs/sankhyablocks 8.16.0-rc.10 → 8.16.0-rc.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (180) hide show
  1. package/dist/cjs/{ConfigStorage-e49214c6.js → ConfigStorage-ecc0ed20.js} +2 -2
  2. package/dist/cjs/{IExporterProvider-8c030a7e.js → ContinuousInsertUtils-807730a8.js} +38 -5
  3. package/dist/cjs/{DataFetcher-77729a93.js → DataFetcher-cadeef8e.js} +21 -20
  4. package/dist/cjs/{SnkFormConfigManager-beebf47a.js → SnkFormConfigManager-f1c92f79.js} +72 -16
  5. package/dist/cjs/{SnkMessageBuilder-cceebbae.js → SnkMessageBuilder-bae64d0d.js} +5 -1
  6. package/dist/cjs/{auth-fetcher-29bb791c.js → auth-fetcher-d68841bc.js} +1 -1
  7. package/dist/cjs/{dataunit-fetcher-d4873076.js → dataunit-fetcher-f89461c1.js} +46 -18
  8. package/dist/cjs/{field-search-f56aa7d6.js → field-search-68e34bf4.js} +5 -1
  9. package/dist/cjs/{form-config-fetcher-feb08214.js → form-config-fetcher-ed497282.js} +5 -2
  10. package/dist/cjs/loader.cjs.js +1 -1
  11. package/dist/cjs/{pesquisa-fetcher-a1d0353f.js → pesquisa-fetcher-ca89181c.js} +1 -1
  12. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  13. package/dist/cjs/snk-actions-button_4.cjs.entry.js +5 -5
  14. package/dist/cjs/snk-application.cjs.entry.js +7 -7
  15. package/dist/cjs/snk-attach.cjs.entry.js +37 -28
  16. package/dist/cjs/snk-crud.cjs.entry.js +12 -6
  17. package/dist/cjs/snk-data-exporter.cjs.entry.js +6 -6
  18. package/dist/cjs/{snk-data-unit-c7dcfa19.js → snk-data-unit-47202e42.js} +4 -3
  19. package/dist/cjs/snk-data-unit.cjs.entry.js +4 -4
  20. package/dist/cjs/snk-detail-view.cjs.entry.js +10 -10
  21. package/dist/cjs/snk-filter-bar.cjs.entry.js +22 -18
  22. package/dist/cjs/snk-filter-binary-select.cjs.entry.js +1 -1
  23. package/dist/cjs/snk-filter-checkbox-list.cjs.entry.js +1 -1
  24. package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
  25. package/dist/cjs/snk-form-config.cjs.entry.js +15 -4
  26. package/dist/cjs/snk-form.cjs.entry.js +7 -6
  27. package/dist/cjs/snk-grid.cjs.entry.js +58 -18
  28. package/dist/cjs/{snk-guides-viewer-69ec61af.js → snk-guides-viewer-68777d37.js} +23 -11
  29. package/dist/cjs/snk-guides-viewer.cjs.entry.js +9 -9
  30. package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +1 -1
  31. package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
  32. package/dist/cjs/snk-print-selector.cjs.entry.js +1 -1
  33. package/dist/cjs/snk-simple-bar.cjs.entry.js +1 -1
  34. package/dist/cjs/snk-simple-crud.cjs.entry.js +51 -18
  35. package/dist/collection/components/snk-attach/snk-attach.js +24 -15
  36. package/dist/collection/components/snk-attach/structure/fetcher/factory/attach-fetcher-data-unit.factory.js +2 -4
  37. package/dist/collection/components/snk-crud/snk-crud.js +59 -1
  38. package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +1 -1
  39. package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +50 -5
  40. package/dist/collection/components/snk-data-unit/snk-data-unit.js +2 -1
  41. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-binary-select.js +1 -1
  42. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-checkbox-list.js +1 -1
  43. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.js +1 -1
  44. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +1 -1
  45. package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +44 -14
  46. package/dist/collection/components/snk-form/snk-form.js +2 -2
  47. package/dist/collection/components/snk-form-config/SnkFormConfigManager.js +70 -14
  48. package/dist/collection/components/snk-form-config/snk-form-config.js +13 -2
  49. package/dist/collection/components/snk-grid/snk-grid.css +2 -0
  50. package/dist/collection/components/snk-grid/snk-grid.js +67 -7
  51. package/dist/collection/components/snk-print-selector/snk-print-selector.js +1 -1
  52. package/dist/collection/components/snk-simple-bar/snk-simple-bar.js +1 -1
  53. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +0 -1
  54. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +61 -9
  55. package/dist/collection/components/snk-taskbar/processor/taskbar-processor.js +5 -1
  56. package/dist/collection/lib/DefaultCustomFormatters/RmPrecisionCustomValueFormatter.js +1 -1
  57. package/dist/collection/lib/dataUnit/InMemoryLoader.js +2 -4
  58. package/dist/collection/lib/dataUnit/dataUnitInMemoryUtils.js +34 -9
  59. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +21 -20
  60. package/dist/collection/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.js +7 -5
  61. package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/loadstrategy/DatasetStrategy.js +9 -2
  62. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +4 -1
  63. package/dist/collection/lib/message/resources/snk-grid.msg.js +5 -1
  64. package/dist/collection/lib/utils/ContinuousInsertUtils.js +31 -0
  65. package/dist/components/{IExporterProvider.js → ContinuousInsertUtils.js} +38 -3
  66. package/dist/components/DataFetcher.js +21 -20
  67. package/dist/components/SnkFormConfigManager.js +70 -14
  68. package/dist/components/SnkMessageBuilder.js +5 -1
  69. package/dist/components/dataunit-fetcher.js +45 -15
  70. package/dist/components/form-config-fetcher.js +4 -1
  71. package/dist/components/snk-attach2.js +33 -24
  72. package/dist/components/snk-crud.js +9 -1
  73. package/dist/components/snk-data-unit2.js +3 -2
  74. package/dist/components/snk-detail-view2.js +21 -7
  75. package/dist/components/snk-filter-bar2.js +20 -15
  76. package/dist/components/snk-filter-binary-select.js +1 -1
  77. package/dist/components/snk-filter-checkbox-list.js +1 -1
  78. package/dist/components/snk-form-config2.js +13 -2
  79. package/dist/components/snk-form.js +2 -2
  80. package/dist/components/snk-grid2.js +50 -8
  81. package/dist/components/snk-personalized-filter-editor.js +1 -1
  82. package/dist/components/snk-print-selector.js +1 -1
  83. package/dist/components/snk-simple-bar2.js +1 -1
  84. package/dist/components/snk-simple-crud2.js +42 -7
  85. package/dist/esm/{ConfigStorage-e476378d.js → ConfigStorage-7b36d041.js} +2 -2
  86. package/dist/esm/{IExporterProvider-f86019db.js → ContinuousInsertUtils-1a82a768.js} +38 -6
  87. package/dist/esm/{DataFetcher-773a3e4b.js → DataFetcher-a9c598f2.js} +21 -20
  88. package/dist/esm/{SnkFormConfigManager-298cd647.js → SnkFormConfigManager-139f09fa.js} +72 -16
  89. package/dist/esm/{SnkMessageBuilder-ae87b754.js → SnkMessageBuilder-6fff4a4c.js} +5 -1
  90. package/dist/esm/{auth-fetcher-a411f73c.js → auth-fetcher-749d880f.js} +1 -1
  91. package/dist/esm/{dataunit-fetcher-3d2ec959.js → dataunit-fetcher-c24c76c6.js} +46 -16
  92. package/dist/esm/{field-search-efbe307f.js → field-search-f8b1d91e.js} +5 -1
  93. package/dist/esm/{form-config-fetcher-e0382e5a.js → form-config-fetcher-adbe5d34.js} +5 -2
  94. package/dist/esm/loader.js +1 -1
  95. package/dist/esm/{pesquisa-fetcher-a87445a0.js → pesquisa-fetcher-8edaa8cd.js} +1 -1
  96. package/dist/esm/sankhyablocks.js +1 -1
  97. package/dist/esm/snk-actions-button_4.entry.js +5 -5
  98. package/dist/esm/snk-application.entry.js +7 -7
  99. package/dist/esm/snk-attach.entry.js +37 -28
  100. package/dist/esm/snk-crud.entry.js +12 -6
  101. package/dist/esm/snk-data-exporter.entry.js +6 -6
  102. package/dist/esm/{snk-data-unit-3276e55e.js → snk-data-unit-de45e0e1.js} +4 -3
  103. package/dist/esm/snk-data-unit.entry.js +4 -4
  104. package/dist/esm/snk-detail-view.entry.js +10 -10
  105. package/dist/esm/snk-filter-bar.entry.js +22 -18
  106. package/dist/esm/snk-filter-binary-select.entry.js +1 -1
  107. package/dist/esm/snk-filter-checkbox-list.entry.js +1 -1
  108. package/dist/esm/snk-filter-modal-item.entry.js +3 -3
  109. package/dist/esm/snk-form-config.entry.js +15 -4
  110. package/dist/esm/snk-form.entry.js +7 -6
  111. package/dist/esm/snk-grid.entry.js +53 -13
  112. package/dist/esm/{snk-guides-viewer-43f21b03.js → snk-guides-viewer-b5dd30e6.js} +23 -11
  113. package/dist/esm/snk-guides-viewer.entry.js +9 -9
  114. package/dist/esm/snk-personalized-filter-editor.entry.js +1 -1
  115. package/dist/esm/snk-personalized-filter.entry.js +3 -3
  116. package/dist/esm/snk-print-selector.entry.js +1 -1
  117. package/dist/esm/snk-simple-bar.entry.js +1 -1
  118. package/dist/esm/snk-simple-crud.entry.js +47 -14
  119. package/dist/sankhyablocks/p-0035ad6e.entry.js +1 -0
  120. package/dist/sankhyablocks/{p-181975f1.js → p-06421fdb.js} +2 -2
  121. package/dist/sankhyablocks/p-0911e61a.entry.js +1 -0
  122. package/dist/sankhyablocks/p-17425c72.js +1 -0
  123. package/dist/sankhyablocks/{p-25f1fc39.js → p-1bf06cd3.js} +2 -2
  124. package/dist/sankhyablocks/{p-9dfda04a.entry.js → p-212213d9.entry.js} +1 -1
  125. package/dist/sankhyablocks/p-23736d75.js +1 -0
  126. package/dist/sankhyablocks/p-3ae9d08a.js +1 -0
  127. package/dist/sankhyablocks/p-3e3cc017.js +1 -0
  128. package/dist/sankhyablocks/{p-72fc257b.entry.js → p-434817f0.entry.js} +1 -1
  129. package/dist/sankhyablocks/{p-3287a6cc.js → p-4d9549cf.js} +1 -1
  130. package/dist/sankhyablocks/p-50779ad3.entry.js +1 -0
  131. package/dist/sankhyablocks/p-5b51491f.entry.js +1 -0
  132. package/dist/sankhyablocks/{p-aaa3ee68.entry.js → p-5f157b09.entry.js} +1 -1
  133. package/dist/sankhyablocks/p-60b29483.entry.js +1 -0
  134. package/dist/sankhyablocks/{p-92ed1d24.entry.js → p-62e048c6.entry.js} +1 -1
  135. package/dist/sankhyablocks/{p-fd8a58ff.entry.js → p-694e1c4a.entry.js} +1 -1
  136. package/dist/sankhyablocks/p-73185e58.entry.js +1 -0
  137. package/dist/sankhyablocks/p-7ac7932c.js +60 -0
  138. package/dist/sankhyablocks/p-7eef0898.entry.js +1 -0
  139. package/dist/sankhyablocks/{p-41f8bfa3.entry.js → p-8c235d4c.entry.js} +1 -1
  140. package/dist/sankhyablocks/{p-162b9a59.entry.js → p-a42e7a1e.entry.js} +2 -2
  141. package/dist/sankhyablocks/p-afbb070d.js +1 -0
  142. package/dist/sankhyablocks/p-b9679243.entry.js +1 -0
  143. package/dist/sankhyablocks/{p-6d55957a.js → p-bccfc262.js} +1 -1
  144. package/dist/sankhyablocks/p-c2e468c9.entry.js +1 -0
  145. package/dist/sankhyablocks/{p-0cd3c0a9.js → p-ca5ec380.js} +1 -1
  146. package/dist/sankhyablocks/{p-1a21b61a.entry.js → p-da34270e.entry.js} +1 -1
  147. package/dist/sankhyablocks/p-e16e87fc.entry.js +1 -0
  148. package/dist/sankhyablocks/{p-1e596b15.entry.js → p-eb9f0407.entry.js} +1 -1
  149. package/dist/sankhyablocks/{p-594bc21d.js → p-f3434fc4.js} +1 -1
  150. package/dist/sankhyablocks/{p-bd008859.entry.js → p-fb34e0cf.entry.js} +1 -1
  151. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  152. package/dist/types/components/snk-attach/snk-attach.d.ts +1 -0
  153. package/dist/types/components/snk-crud/snk-crud.d.ts +9 -0
  154. package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +11 -0
  155. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +4 -0
  156. package/dist/types/components/snk-form-config/SnkFormConfigManager.d.ts +7 -2
  157. package/dist/types/components/snk-grid/snk-grid.d.ts +12 -0
  158. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +10 -0
  159. package/dist/types/components/snk-taskbar/processor/taskbar-processor.d.ts +1 -0
  160. package/dist/types/components.d.ts +57 -0
  161. package/dist/types/lib/dataUnit/dataUnitInMemoryUtils.d.ts +12 -2
  162. package/dist/types/lib/http/data-fetcher/fetchers/AttachFetcher/anexo-sistema-fetcher.d.ts +3 -2
  163. package/dist/types/lib/utils/ContinuousInsertUtils.d.ts +10 -0
  164. package/package.json +1 -1
  165. package/dist/sankhyablocks/p-091ce761.js +0 -60
  166. package/dist/sankhyablocks/p-1f35c795.js +0 -1
  167. package/dist/sankhyablocks/p-2e9c764c.entry.js +0 -1
  168. package/dist/sankhyablocks/p-42f7b05d.entry.js +0 -1
  169. package/dist/sankhyablocks/p-4e1b47a4.js +0 -1
  170. package/dist/sankhyablocks/p-53412c1d.entry.js +0 -1
  171. package/dist/sankhyablocks/p-5b26cc7c.entry.js +0 -1
  172. package/dist/sankhyablocks/p-5f016aed.js +0 -1
  173. package/dist/sankhyablocks/p-7b8f7242.entry.js +0 -1
  174. package/dist/sankhyablocks/p-7c4aabe2.js +0 -1
  175. package/dist/sankhyablocks/p-88aa931b.entry.js +0 -1
  176. package/dist/sankhyablocks/p-939e15d3.entry.js +0 -1
  177. package/dist/sankhyablocks/p-aa5b3b2c.entry.js +0 -1
  178. package/dist/sankhyablocks/p-aa6d510d.entry.js +0 -1
  179. package/dist/sankhyablocks/p-b11aa1e0.entry.js +0 -1
  180. package/dist/sankhyablocks/p-c2495304.js +0 -1
@@ -36,7 +36,7 @@ const SnkSimpleBar = class {
36
36
  this._application = core.ApplicationContext.getContextValue("__SNK__APPLICATION__");
37
37
  }
38
38
  render() {
39
- return (index.h("div", { class: "simple-bar__container ez-margin-vertical--medium ez-padding--extra-small" }, index.h("div", { class: "simple-bar__left-slot" }, index.h("ez-button", { class: "ez-padding-right--medium", title: this.getMessage('snkSimpleBar.backTitle'), mode: 'icon', iconName: "arrow_back", size: 'medium', onClick: () => this.exit.emit() }), index.h("div", { class: "simple-bar__column" }, index.h("h1", { class: "ez-title ez-title--primary ez-title--extra-large" }, this.label), index.h("ez-breadcrumb", { items: this.breadcrumbItens, onSelectedItem: ({ detail }) => this.clickBreadcrumbItem.emit(detail) }))), index.h("div", { class: "simple-bar__right-slot" }, index.h("slot", { name: "rightSlot" }))));
39
+ return (index.h("div", { class: "simple-bar__container ez-margin-vertical--small ez-padding--extra-small" }, index.h("div", { class: "simple-bar__left-slot" }, index.h("ez-button", { class: "ez-padding-right--medium", title: this.getMessage('snkSimpleBar.backTitle'), mode: 'icon', iconName: "arrow_back", size: 'medium', onClick: () => this.exit.emit() }), index.h("div", { class: "simple-bar__column" }, index.h("h1", { class: "ez-title ez-title--primary ez-title--extra-large" }, this.label), index.h("ez-breadcrumb", { items: this.breadcrumbItens, onSelectedItem: ({ detail }) => this.clickBreadcrumbItem.emit(detail) }))), index.h("div", { class: "simple-bar__right-slot" }, index.h("slot", { name: "rightSlot" }))));
40
40
  }
41
41
  get _element() { return index.getElement(this); }
42
42
  };
@@ -7,19 +7,19 @@ const core = require('@sankhyalabs/core');
7
7
  const utils = require('@sankhyalabs/ezui/dist/collection/utils');
8
8
  const constants = require('./constants-35ddd366.js');
9
9
  const taskbarElements = require('./taskbar-elements-9ad1f9c0.js');
10
- require('./DataFetcher-77729a93.js');
11
- require('./pesquisa-fetcher-a1d0353f.js');
12
- const IExporterProvider = require('./IExporterProvider-8c030a7e.js');
10
+ require('./DataFetcher-cadeef8e.js');
11
+ require('./pesquisa-fetcher-ca89181c.js');
12
+ const ContinuousInsertUtils = require('./ContinuousInsertUtils-807730a8.js');
13
13
  const index = require('./index-1dfc7a6e.js');
14
14
  require('./ISave-e91b70a7.js');
15
15
  require('@sankhyalabs/ezui/dist/collection/utils/constants');
16
16
  require('@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata');
17
- const dataunitFetcher = require('./dataunit-fetcher-d4873076.js');
17
+ const dataunitFetcher = require('./dataunit-fetcher-f89461c1.js');
18
18
  require('./filter-item-type.enum-a7ffdaa6.js');
19
- const formConfigFetcher = require('./form-config-fetcher-feb08214.js');
20
- const fieldSearch = require('./field-search-f56aa7d6.js');
21
- const ConfigStorage = require('./ConfigStorage-e49214c6.js');
22
- const SnkFormConfigManager = require('./SnkFormConfigManager-beebf47a.js');
19
+ const formConfigFetcher = require('./form-config-fetcher-ed497282.js');
20
+ const fieldSearch = require('./field-search-68e34bf4.js');
21
+ const ConfigStorage = require('./ConfigStorage-ecc0ed20.js');
22
+ const SnkFormConfigManager = require('./SnkFormConfigManager-f1c92f79.js');
23
23
  const GetSelectedRecordsIDsInfo = require('./GetSelectedRecordsIDsInfo-bd50caf1.js');
24
24
  const index$2 = require('./index-102ba62d.js');
25
25
  require('./PrintUtils-bcaeb82f.js');
@@ -31,7 +31,7 @@ require('./ResourceIDUtils-5ff86aa7.js');
31
31
  const REGULAR_DEFAULT_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "MORE_OPTIONS"];
32
32
  const REGULAR_SELECTED_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "CLONE", "REMOVE", "DIVIDER", "MORE_OPTIONS"];
33
33
 
34
- class ClientSideExporterProvider extends IExporterProvider.CommonsExporter {
34
+ class ClientSideExporterProvider extends ContinuousInsertUtils.CommonsExporter {
35
35
  getSelectedNumber() {
36
36
  return this.dataUnit.getSelectionInfo().length;
37
37
  }
@@ -86,7 +86,7 @@ class ClientSideExporterProvider extends IExporterProvider.CommonsExporter {
86
86
  }
87
87
  }
88
88
 
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}";
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;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
90
 
91
91
  const SnkSimpleCrud = class {
92
92
  constructor(hostRef) {
@@ -97,7 +97,7 @@ const SnkSimpleCrud = class {
97
97
  this.formItemsReady = index$1.createEvent(this, "formItemsReady", 7);
98
98
  this.configuratorSave = index$1.createEvent(this, "configuratorSave", 7);
99
99
  this.configuratorCancel = index$1.createEvent(this, "configuratorCancel", 7);
100
- this._multiSelectionListDataSource = new IExporterProvider.SnkMultiSelectionListDataSource();
100
+ this._multiSelectionListDataSource = new ContinuousInsertUtils.SnkMultiSelectionListDataSource();
101
101
  this._keyDownHandler = (event) => this.keyDownListener(event);
102
102
  this._formConfigFetcher = new formConfigFetcher.FormConfigFetcher();
103
103
  this._customEditors = new Map();
@@ -107,7 +107,7 @@ const SnkSimpleCrud = class {
107
107
  "snkSimpleCrudTaskbar.grid_regular": this.getButtons(false, [taskbarElements.TaskbarElement.DATA_EXPORTER, taskbarElements.TaskbarElement.FORM_MODE]),
108
108
  "snkSimpleCrudTaskbar.form_selected": this.getButtons(true, [taskbarElements.TaskbarElement.GRID_MODE]),
109
109
  "snkSimpleCrudTaskbar.grid_selected": this.getButtons(true, [taskbarElements.TaskbarElement.DATA_EXPORTER, taskbarElements.TaskbarElement.FORM_MODE]),
110
- "snkSimpleCrudTaskbar.finish_edition": ["CANCEL", "SAVE"]
110
+ "snkSimpleCrudTaskbar.finish_edition": this.getFinishEditionButtonsCallback.bind(this)
111
111
  });
112
112
  this._showPopUpGridConfig = false;
113
113
  this._showFormConfig = false;
@@ -123,10 +123,12 @@ const SnkSimpleCrud = class {
123
123
  this.formConfig = undefined;
124
124
  this._formFields = [];
125
125
  this._fieldsProps = new Map();
126
+ this._enableContinuousInsert = true;
126
127
  this.multipleSelection = undefined;
127
128
  this.useCancelConfirm = true;
128
129
  this.pageSize = 150;
129
130
  this.resourceID = undefined;
131
+ this.enableGridInsert = false;
130
132
  this.taskbarManager = undefined;
131
133
  this.messagesBuilder = undefined;
132
134
  this.useEnterLikeTab = false;
@@ -196,6 +198,13 @@ const SnkSimpleCrud = class {
196
198
  newCustomFieldProps.set(fieldName, Object.assign(Object.assign({}, currentProps), { [propName]: value }));
197
199
  this._fieldsProps = newCustomFieldProps;
198
200
  }
201
+ getFinishEditionButtonsCallback() {
202
+ const btns = ["CANCEL", "SAVE"];
203
+ if (this.enableGridInsert && this._currentViewMode !== constants.VIEW_MODE.ATTACHMENT) {
204
+ btns.push(this._currentViewMode === constants.VIEW_MODE.GRID ? taskbarElements.TaskbarElement.FORM_MODE : taskbarElements.TaskbarElement.GRID_MODE);
205
+ }
206
+ return btns;
207
+ }
199
208
  getButtons(selected, extraButtons) {
200
209
  return this.addConfigButton(this.resolveInMemoryBtns(selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS)
201
210
  .concat(extraButtons));
@@ -359,7 +368,7 @@ const SnkSimpleCrud = class {
359
368
  return;
360
369
  }
361
370
  if (this._formConfigManager == undefined) {
362
- this._formConfigManager = new SnkFormConfigManager.SnkFormConfigManager(this.configName, this.resolveResourceID());
371
+ this._formConfigManager = new SnkFormConfigManager.SnkFormConfigManager(this.configName, this.resolveResourceID(), undefined, this.dataUnit);
363
372
  this._formConfigManager.setConfig(this.formConfig);
364
373
  }
365
374
  if (this.formConfigIsLoaded() && !forceLoad) {
@@ -399,7 +408,11 @@ const SnkSimpleCrud = class {
399
408
  this.processMetadata();
400
409
  this.onModeChange();
401
410
  this.configDatasource();
402
- this._rmPrecisionCustomValueFormatter = new IExporterProvider.RmPrecisionCustomValueFormatter();
411
+ this._rmPrecisionCustomValueFormatter = new ContinuousInsertUtils.RmPrecisionCustomValueFormatter();
412
+ this._continuousInsertUtils = new ContinuousInsertUtils.ContinuousInsertUtils(this.application, this.resolveResourceID(), this.configName);
413
+ if (this.enableGridInsert) {
414
+ this._continuousInsertUtils.getConfig().then(value => this._enableContinuousInsert = value);
415
+ }
403
416
  }
404
417
  componentDidLoad() {
405
418
  utils.CSSVarsUtils.applyVarsGrid(this._element, this._grid);
@@ -634,6 +647,9 @@ const SnkSimpleCrud = class {
634
647
  const options = filteredFields.map(field => ({ value: field.name, label: field.label }));
635
648
  return Promise.resolve(options);
636
649
  }
650
+ isGridInsertActive() {
651
+ return this.enableGridInsert && this.dataUnit.hasNewRecord();
652
+ }
637
653
  getActionsList() {
638
654
  var _a, _b;
639
655
  const hardList = [{
@@ -645,11 +661,22 @@ const SnkSimpleCrud = class {
645
661
  ? this.getColumnSearch(actionButton, item)
646
662
  : this.getFieldSearch(actionButton, item)
647
663
  }];
664
+ if (this.enableGridInsert) {
665
+ hardList.push(this._continuousInsertUtils.actionContinuousInsert(this._enableContinuousInsert, this.handleEnableContinuousInsert));
666
+ }
667
+ if (this.isGridInsertActive())
668
+ return hardList;
648
669
  if (this.taskbarManager != undefined && this.taskbarManager.getMoreOptions != undefined) {
649
670
  const taskbarID = this.getTopTaskBarId();
650
671
  return hardList.concat(this.taskbarManager.getMoreOptions(taskbarID, this.configName, this.dataState, this.actionsList));
651
672
  }
652
- 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);
653
680
  }
654
681
  getTopTaskBarId() {
655
682
  var _a;
@@ -723,7 +750,7 @@ const SnkSimpleCrud = class {
723
750
  }
724
751
  setGridConfig(config) {
725
752
  this.gridConfig = config;
726
- IExporterProvider.CrudUtils.assertDefaultSorting(this.gridConfig, this.dataUnit);
753
+ ContinuousInsertUtils.CrudUtils.assertDefaultSorting(this.gridConfig, this.dataUnit);
727
754
  }
728
755
  setFormConfig(config, forceUpdate) {
729
756
  if (this.formConfig && !forceUpdate)
@@ -768,15 +795,21 @@ const SnkSimpleCrud = class {
768
795
  }
769
796
  this._formConfigManager.setConfig(this.formConfig);
770
797
  }
798
+ handleDataUnitOnInsertionMode() {
799
+ if (this.enableGridInsert)
800
+ return;
801
+ this.goToView(constants.VIEW_MODE.FORM);
802
+ }
771
803
  /* istanbul ignore next */
772
804
  render() {
773
805
  var _a;
774
806
  if (this.dataUnit == undefined) {
775
807
  return;
776
808
  }
777
- return (index$1.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(constants.VIEW_MODE.FORM), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), ignoreSaveMessage: this._currentViewMode === constants.VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail, onDataUnitFieldsHidded: this.updateFormConfig.bind(this), domainMessagesBuilder: this.domainMessagesBuilder }, index$1.h("header", null, index$1.h("slot", { name: "snkSimpleCrudHeader" })), index$1.h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, index$1.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: index.PresentationMode.SECONDARY }, index$1.h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })), index$1.h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, index$1.h("stack-item", null, index$1.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(constants.VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(dataunitFetcher.InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
809
+ const taskbarContent = (index$1.h("snk-taskbar", { class: this._currentViewMode === constants.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: index.PresentationMode.SECONDARY }, index$1.h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })));
810
+ return (index$1.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 === constants.VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail, onDataUnitFieldsHidded: this.updateFormConfig.bind(this), domainMessagesBuilder: this.domainMessagesBuilder }, index$1.h("header", null, index$1.h("slot", { name: "snkSimpleCrudHeader" })), index$1.h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, this._currentViewMode === constants.VIEW_MODE.FORM && taskbarContent, index$1.h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, index$1.h("stack-item", null, index$1.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(constants.VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(dataunitFetcher.InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
778
811
  ? undefined
779
- : this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab, autoFocus: this.autoFocus }, index$1.h("div", { slot: "footer" }, index$1.h("slot", { name: "snkSimpleCrudFooter" })))), index$1.h("stack-item", null, index$1.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() && index$1.h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this.dataUnit, configManager: this._formConfigManager, onConfigClose: () => this.closeFormConfig() })), this.messagesBuilder && index$1.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 })), index$1.h("div", { id: `${this._customContainerId}` }, index$1.h("slot", { name: "SnkConfigContainerSlot" }))), index$1.h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._showPopUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, index$1.h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(core.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 === constants.VIEW_MODE.GRID && taskbarContent, index$1.h("div", { slot: "footer" }, index$1.h("slot", { name: "snkSimpleCrudFooter" })))), index$1.h("stack-item", null, index$1.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() && index$1.h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this.dataUnit, configManager: this._formConfigManager, onConfigClose: () => this.closeFormConfig() })), this.messagesBuilder && index$1.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 })), index$1.h("div", { id: `${this._customContainerId}` }, index$1.h("slot", { name: "SnkConfigContainerSlot" }))), index$1.h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._showPopUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, index$1.h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(core.ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this.resolveResourceID() }))));
780
813
  }
781
814
  get _element() { return index$1.getElement(this); }
782
815
  static get watchers() { return {
@@ -46,11 +46,20 @@ export class SnkAttach {
46
46
  this.loadAttachmentDataUnit();
47
47
  }
48
48
  if (oldRegisterKey !== newRegisterKey) {
49
+ if (this._currentFetcher instanceof AnexoSistemaFetcher) {
50
+ this._currentFetcher.registerKey = newRegisterKey;
51
+ }
49
52
  await ((_a = this._currentDataUnit) === null || _a === void 0 ? void 0 : _a.loadData());
50
53
  }
51
54
  }
55
+ getAnexoSistemaFetcherInstance() {
56
+ var _a;
57
+ const anexoSistemaFetcher = new AnexoSistemaFetcher(this.entityName, (_a = this._currentDataUnit) === null || _a === void 0 ? void 0 : _a.name);
58
+ anexoSistemaFetcher.registerKey = this.registerKey;
59
+ return anexoSistemaFetcher;
60
+ }
52
61
  async initAttach() {
53
- var _a, _b, _c, _d, _e, _f;
62
+ var _a, _b, _c, _d, _e;
54
63
  if (!this.fetcherType && !this.registerKey)
55
64
  return;
56
65
  if (!this.fetcherType) {
@@ -58,18 +67,18 @@ export class SnkAttach {
58
67
  }
59
68
  this.returnToGridMode();
60
69
  if (this.fetcherType === "AnexoSistema") {
61
- this._currentFetcher = new AnexoSistemaFetcher(this.entityName, this.registerKey, (_a = this._currentDataUnit) === null || _a === void 0 ? void 0 : _a.name);
62
- (_b = this._currentDataUnitBuilder) === null || _b === void 0 ? void 0 : _b.initLoaders(this._currentDataUnit, this._currentFetcher, this.returnToGridMode.bind(this));
63
- await ((_c = this._currentDataUnit) === null || _c === void 0 ? void 0 : _c.loadData());
70
+ this._currentFetcher = this.getAnexoSistemaFetcherInstance();
71
+ (_a = this._currentDataUnitBuilder) === null || _a === void 0 ? void 0 : _a.initLoaders(this._currentDataUnit, this._currentFetcher, this.returnToGridMode.bind(this));
72
+ await ((_b = this._currentDataUnit) === null || _b === void 0 ? void 0 : _b.loadData());
64
73
  return;
65
74
  }
66
75
  if (this.fetcherType === "Attach") {
67
- const hasMoreOneItem = ((_d = this.registerKey) === null || _d === void 0 ? void 0 : _d.split("_").length) > 1;
76
+ const hasMoreOneItem = ((_c = this.registerKey) === null || _c === void 0 ? void 0 : _c.split("_").length) > 1;
68
77
  if (hasMoreOneItem)
69
78
  return;
70
79
  }
71
- await ((_e = this._currentDataUnit) === null || _e === void 0 ? void 0 : _e.loadMetadata());
72
- await ((_f = this._currentDataUnit) === null || _f === void 0 ? void 0 : _f.loadData(undefined, undefined, true, this.registerKey));
80
+ await ((_d = this._currentDataUnit) === null || _d === void 0 ? void 0 : _d.loadMetadata());
81
+ await ((_e = this._currentDataUnit) === null || _e === void 0 ? void 0 : _e.loadData(undefined, undefined, true, this.registerKey));
73
82
  }
74
83
  /**
75
84
  * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
@@ -128,11 +137,11 @@ export class SnkAttach {
128
137
  }
129
138
  }
130
139
  async loadAnexoSistema() {
131
- var _a, _b, _c;
140
+ var _a, _b;
132
141
  this._currentDataUnit = new DataUnitFetcher().getDataUnit(RESOURCE_ID, DATA_UNIT_NAME);
133
- this._currentFetcher = new AnexoSistemaFetcher(this.entityName, this.registerKey, (_a = this._currentDataUnit) === null || _a === void 0 ? void 0 : _a.name);
142
+ this._currentFetcher = this.getAnexoSistemaFetcherInstance();
134
143
  if (!this._currentDataUnit.metadata) {
135
- await ((_b = this._currentDataUnit) === null || _b === void 0 ? void 0 : _b.loadMetadata());
144
+ await ((_a = this._currentDataUnit) === null || _a === void 0 ? void 0 : _a.loadMetadata());
136
145
  this.crudConfig = Object.assign({}, anexoSistemaCrudConfig);
137
146
  }
138
147
  this.initDataUnitLoaders();
@@ -142,7 +151,7 @@ export class SnkAttach {
142
151
  this._currentDataUnit.addInterceptor({
143
152
  interceptAction: (action) => this._currentDataUnitBuilder.getInterceptions(this._currentDataUnit, action, this._crudElement)
144
153
  });
145
- await ((_c = this._currentDataUnit) === null || _c === void 0 ? void 0 : _c.loadData());
154
+ await ((_b = this._currentDataUnit) === null || _b === void 0 ? void 0 : _b.loadData());
146
155
  this.disableEditFieldsNotInForm();
147
156
  }
148
157
  async loadAttach() {
@@ -168,16 +177,16 @@ export class SnkAttach {
168
177
  }
169
178
  }
170
179
  initDataUnitLoaders() {
171
- var _a, _b, _c;
180
+ var _a, _b;
172
181
  if (this.fetcherType === "AnexoSistema") {
173
- this._currentFetcher = new AnexoSistemaFetcher(this.entityName, this.registerKey, (_a = this._currentDataUnit) === null || _a === void 0 ? void 0 : _a.name);
182
+ this._currentFetcher = this.getAnexoSistemaFetcherInstance();
174
183
  this._currentDataUnitBuilder = new AnexoSistemaDataUnitFactory(this.entityName, this.getMessage.bind(this));
175
- (_b = this._currentDataUnitBuilder) === null || _b === void 0 ? void 0 : _b.initLoaders(this._currentDataUnit, this._currentFetcher, this.returnToGridMode.bind(this));
184
+ (_a = this._currentDataUnitBuilder) === null || _a === void 0 ? void 0 : _a.initLoaders(this._currentDataUnit, this._currentFetcher, this.returnToGridMode.bind(this));
176
185
  }
177
186
  if (this.fetcherType === "Attach") {
178
187
  this._currentFetcher = new AttachFetcher();
179
188
  this._currentDataUnitBuilder = new AttachFetcherDataUnitFactory(this.getMessage.bind(this));
180
- (_c = this._currentDataUnitBuilder) === null || _c === void 0 ? void 0 : _c.initLoaders(this._currentDataUnit, this._currentFetcher, async () => {
189
+ (_b = this._currentDataUnitBuilder) === null || _b === void 0 ? void 0 : _b.initLoaders(this._currentDataUnit, this._currentFetcher, async () => {
181
190
  this.returnToGridMode();
182
191
  await this._currentDataUnit.loadData(undefined, undefined, true, this.registerKey);
183
192
  });
@@ -3,7 +3,7 @@ import { SaveErrorsEnum } from '../../../../../lib/http/data-fetcher/fetchers/At
3
3
  import { AutorizationType } from '../../../../../lib/http/data-fetcher/fetchers/auth-fetcher';
4
4
  import { attachFetcherMetadataBuilder } from '../../builder/attach-crud-config.builder';
5
5
  import { VIEW_MODE } from '../../../../../lib/utils/constants';
6
- import { applyFilter, applySorting, buildPaginationInfo } from '../../../../../lib/dataUnit/dataUnitInMemoryUtils';
6
+ import { buildLoadDataResponse } from '../../../../../lib/dataUnit/dataUnitInMemoryUtils';
7
7
  const SERVICE_LOAD = "Attach.load";
8
8
  export class AttachFetcherDataUnitFactory {
9
9
  constructor(getMessage) {
@@ -49,9 +49,7 @@ export class AttachFetcherDataUnitFactory {
49
49
  });
50
50
  this._records = records;
51
51
  }
52
- let records = applyFilter(this._records, dataUnit, request.filters);
53
- records = applySorting(records, dataUnit, request.sort);
54
- return Promise.resolve({ records, paginationInfo: buildPaginationInfo(records, request.offset, request.limit) });
52
+ return buildLoadDataResponse(this._records, dataUnit, request);
55
53
  }
56
54
  saveLoader(changes, fetcher) {
57
55
  return new Promise((resolve) => {
@@ -39,7 +39,9 @@ export class SnkCrud {
39
39
  this.disablePersonalizedFilter = undefined;
40
40
  this.autoLoad = undefined;
41
41
  this.autoFocus = true;
42
+ this.enableGridInsert = false;
42
43
  this.domainMessagesBuilder = undefined;
44
+ this.setCustomFormTitle = undefined;
43
45
  this.customContainerId = `SNK-CRUD-CUSTOM-CONTAINER-${StringUtils.generateUUID()}`;
44
46
  }
45
47
  /**
@@ -148,6 +150,7 @@ export class SnkCrud {
148
150
  else if (viewMode === VIEW_MODE.FORM) {
149
151
  this._guidesViewer.setFocus();
150
152
  }
153
+ this.viewModeChanged.emit(viewMode);
151
154
  }
152
155
  openConfig(viewMode) {
153
156
  this._snkConfigurator.close();
@@ -163,6 +166,8 @@ export class SnkCrud {
163
166
  ElementIDUtils.addIDInfo(this._element, null, dataInfo);
164
167
  }
165
168
  insertionModeHandler() {
169
+ if (this.enableGridInsert)
170
+ return;
166
171
  this.gridToForm();
167
172
  }
168
173
  cancelHandler() {
@@ -378,7 +383,7 @@ export class SnkCrud {
378
383
  return;
379
384
  }
380
385
  this._snkDataUnit.ignoreSaveMessage = this._currentViewMode === VIEW_MODE.GRID;
381
- return (h(Host, null, h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "crud" }, h("stack-item", null, h("snk-grid", { ref: (ref) => this._snkGrid = ref, filterBarTitle: this.filterBarTitle, "data-element-id": "crud_grid", configName: this.configName, onGridDoubleClick: () => this.gridToForm(true), taskbarManager: this.taskbarManager, onActionClick: evt => this.executeAction(evt.detail), messagesBuilder: this.messagesBuilder, actionsList: this.actionsList, statusResolver: this.statusResolver, multipleSelection: this.multipleSelection, presentationMode: this.presentationMode, recordsValidator: this.recordsValidator, selectionToastConfig: this.selectionToastConfig, useEnterLikeTab: this.useEnterLikeTab, canEdit: this._canEdit, resourceID: this._resourceID, disablePersonalizedFilter: this.disablePersonalizedFilter, gridLegacyConfigName: this.gridLegacyConfigName, filterBarLegacyConfigName: this.filterBarLegacyConfigName, autoLoad: this.autoLoad, autoFocus: this.autoFocus }, h("slot", { name: "GRID_TASKBAR_CUSTOM_ELEMENTS" }), h("slot", { name: "GRID_HEADER_CUSTOM_ELEMENTS" }), h("slot", { name: "SnkGridHeader" }), h("slot", { name: "SnkGridFooter" }), h("slot", { name: "SnkGridTaskBar" }))), h("stack-item", null, h("snk-guides-viewer", { ref: ref => this._guidesViewer = ref, entityPath: this._snkDataUnit.entityName, messagesBuilder: this.messagesBuilder, onExit: () => this.setViewMode(VIEW_MODE.GRID), dataState: this._dataState, dataUnit: this._dataUnit, actionsList: this.actionsList, taskbarManager: this.taskbarManager, configName: this.configName, onActionClick: evt => this.executeAction(evt.detail), presentationMode: this.presentationMode, "data-element-id": "crud_form", canEdit: this._canEdit, recordsValidator: this.recordsValidator, resourceID: this._resourceID, detailTaskbarCustomContainerId: this.customContainerId, formLegacyConfigName: this.formLegacyConfigName }, h("slot", { name: "GUIDES_VIEWER_TASKBAR_CUSTOM_ELEMENTS" }), h("slot", { name: "SnkFormTaskBar" }))), h("stack-item", null, h("snk-attach", { registerKey: this.attachmentRegisterKey, messagesBuilder: this.messagesBuilder, entityName: this._snkDataUnit.entityName, onBack: this.backView.bind(this) })), h("snk-configurator", { ref: (ref) => this._snkConfigurator = ref, viewMode: this._currentViewMode, messagesBuilder: this.messagesBuilder, onConfigSelected: (evt) => this.setViewMode(evt.detail), onOpenConfig: (evt) => this.openConfig(evt.detail), showActionButtons: this.showActionButtons, onSave: evt => this.handleConfiguratorEvent(evt, 'SAVE'), onCancel: evt => this.handleConfiguratorEvent(evt, 'CANCEL'), resourceID: this._resourceID, customContainerId: this.customContainerId })), h("div", { id: `${this.customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }), h("slot", { name: "DETAIL_GRID_HEADER_CUSTOM_ELEMENTS" }), h("slot", { name: "DETAIL_GRID_TASKBAR_CUSTOM_ELEMENTS" }), h("slot", { name: "DETAIL_TASKBAR_CUSTOM_ELEMENTS" }))));
386
+ return (h(Host, null, h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "crud" }, h("stack-item", null, h("snk-grid", { ref: (ref) => this._snkGrid = ref, filterBarTitle: this.filterBarTitle, "data-element-id": "crud_grid", configName: this.configName, onGridDoubleClick: () => this.gridToForm(true), taskbarManager: this.taskbarManager, onActionClick: evt => this.executeAction(evt.detail), messagesBuilder: this.messagesBuilder, actionsList: this.actionsList, statusResolver: this.statusResolver, multipleSelection: this.multipleSelection, presentationMode: this.presentationMode, recordsValidator: this.recordsValidator, selectionToastConfig: this.selectionToastConfig, useEnterLikeTab: this.useEnterLikeTab, canEdit: this._canEdit, resourceID: this._resourceID, disablePersonalizedFilter: this.disablePersonalizedFilter, gridLegacyConfigName: this.gridLegacyConfigName, filterBarLegacyConfigName: this.filterBarLegacyConfigName, autoLoad: this.autoLoad, autoFocus: this.autoFocus, enableGridInsert: this.enableGridInsert }, h("slot", { name: "GRID_TASKBAR_CUSTOM_ELEMENTS" }), h("slot", { name: "GRID_HEADER_CUSTOM_ELEMENTS" }), h("slot", { name: "SnkGridHeader" }), h("slot", { name: "SnkGridFooter" }), h("slot", { name: "SnkGridTaskBar" }))), h("stack-item", null, h("snk-guides-viewer", { ref: ref => this._guidesViewer = ref, entityPath: this._snkDataUnit.entityName, messagesBuilder: this.messagesBuilder, onExit: () => this.setViewMode(VIEW_MODE.GRID), dataState: this._dataState, dataUnit: this._dataUnit, actionsList: this.actionsList, taskbarManager: this.taskbarManager, configName: this.configName, onActionClick: evt => this.executeAction(evt.detail), presentationMode: this.presentationMode, "data-element-id": "crud_form", canEdit: this._canEdit, recordsValidator: this.recordsValidator, resourceID: this._resourceID, detailTaskbarCustomContainerId: this.customContainerId, formLegacyConfigName: this.formLegacyConfigName, enableGridInsert: this.enableGridInsert, getCustomTitle: this.setCustomFormTitle }, h("slot", { name: "GUIDES_VIEWER_TASKBAR_CUSTOM_ELEMENTS" }), h("slot", { name: "SnkFormTaskBar" }))), h("stack-item", null, h("snk-attach", { registerKey: this.attachmentRegisterKey, messagesBuilder: this.messagesBuilder, entityName: this._snkDataUnit.entityName, onBack: this.backView.bind(this) })), h("snk-configurator", { ref: (ref) => this._snkConfigurator = ref, viewMode: this._currentViewMode, messagesBuilder: this.messagesBuilder, onConfigSelected: (evt) => this.setViewMode(evt.detail), onOpenConfig: (evt) => this.openConfig(evt.detail), showActionButtons: this.showActionButtons, onSave: evt => this.handleConfiguratorEvent(evt, 'SAVE'), onCancel: evt => this.handleConfiguratorEvent(evt, 'CANCEL'), resourceID: this._resourceID, customContainerId: this.customContainerId })), h("div", { id: `${this.customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }), h("slot", { name: "DETAIL_GRID_HEADER_CUSTOM_ELEMENTS" }), h("slot", { name: "DETAIL_GRID_TASKBAR_CUSTOM_ELEMENTS" }), h("slot", { name: "DETAIL_TASKBAR_CUSTOM_ELEMENTS" }))));
382
387
  }
383
388
  static get is() { return "snk-crud"; }
384
389
  static get encapsulation() { return "scoped"; }
@@ -735,6 +740,24 @@ export class SnkCrud {
735
740
  "reflect": false,
736
741
  "defaultValue": "true"
737
742
  },
743
+ "enableGridInsert": {
744
+ "type": "boolean",
745
+ "mutable": false,
746
+ "complexType": {
747
+ "original": "boolean",
748
+ "resolved": "boolean",
749
+ "references": {}
750
+ },
751
+ "required": false,
752
+ "optional": true,
753
+ "docs": {
754
+ "tags": [],
755
+ "text": "Ativa inser\u00E7\u00E3o de registros no modo grade."
756
+ },
757
+ "attribute": "enable-grid-insert",
758
+ "reflect": false,
759
+ "defaultValue": "false"
760
+ },
738
761
  "domainMessagesBuilder": {
739
762
  "type": "string",
740
763
  "mutable": false,
@@ -751,6 +774,21 @@ export class SnkCrud {
751
774
  },
752
775
  "attribute": "domain-messages-builder",
753
776
  "reflect": false
777
+ },
778
+ "setCustomFormTitle": {
779
+ "type": "unknown",
780
+ "mutable": false,
781
+ "complexType": {
782
+ "original": "() => string",
783
+ "resolved": "() => string",
784
+ "references": {}
785
+ },
786
+ "required": false,
787
+ "optional": false,
788
+ "docs": {
789
+ "tags": [],
790
+ "text": "Define uma fun\u00E7\u00E3o para configurar um t\u00EDtulo cusotmizado no modo formul\u00E1rio."
791
+ }
754
792
  }
755
793
  };
756
794
  }
@@ -833,6 +871,26 @@ export class SnkCrud {
833
871
  }
834
872
  }
835
873
  }
874
+ }, {
875
+ "method": "viewModeChanged",
876
+ "name": "viewModeChanged",
877
+ "bubbles": true,
878
+ "cancelable": true,
879
+ "composed": true,
880
+ "docs": {
881
+ "tags": [],
882
+ "text": ""
883
+ },
884
+ "complexType": {
885
+ "original": "VIEW_MODE",
886
+ "resolved": "VIEW_MODE.ATTACHMENT | VIEW_MODE.FORM | VIEW_MODE.GRID",
887
+ "references": {
888
+ "VIEW_MODE": {
889
+ "location": "import",
890
+ "path": "../../lib/utils/constants"
891
+ }
892
+ }
893
+ }
836
894
  }];
837
895
  }
838
896
  static get methods() {
@@ -222,7 +222,7 @@ export class SnkDetailView {
222
222
  }
223
223
  componentWillLoad() {
224
224
  this._configName = `dynaform.${this.entityName}`;
225
- this.formConfigManager = new SnkFormConfigManager(this._configName, this.resourceID, () => this.loadMetadata());
225
+ this.formConfigManager = new SnkFormConfigManager(this._configName, this.resourceID, () => this.loadMetadata(), this.dataUnit);
226
226
  this.formConfigManager.loadConfig();
227
227
  if (this.messagesBuilder == undefined) {
228
228
  this.messagesBuilder = new SnkMessageBuilder(this.entityName);
@@ -27,6 +27,8 @@ export class SnkGuidesViewer {
27
27
  this.resourceID = undefined;
28
28
  this.detailTaskbarCustomContainerId = undefined;
29
29
  this.formLegacyConfigName = undefined;
30
+ this.enableGridInsert = false;
31
+ this.getCustomTitle = undefined;
30
32
  this._hasToCreateFieldSearch = true;
31
33
  this._breadcrumbItems = [];
32
34
  this._guides = undefined;
@@ -95,7 +97,7 @@ export class SnkGuidesViewer {
95
97
  this._container.focus();
96
98
  }
97
99
  exitViewer() {
98
- if (this.dataUnit.isDirty()) {
100
+ if (!this.enableGridInsert && this.dataUnit.isDirty()) {
99
101
  this.dataUnit.cancelEdition({ after: () => this.exit.emit() });
100
102
  }
101
103
  else {
@@ -204,10 +206,13 @@ export class SnkGuidesViewer {
204
206
  const invisibleButtons = this.getInvisibleButtons();
205
207
  this._taskbarProcessor = new TaskbarProcessor({
206
208
  "snkGuideViewer.regular": btnsRegularMode,
207
- "snkGuideViewer.finish_edition": ["CANCEL", "SAVE"],
209
+ "snkGuideViewer.finish_edition": ["CANCEL", "SAVE", this.handleAddGridMode()],
208
210
  });
209
211
  this._taskbarProcessor.process(taskbarId, this.taskbarManager, this.dataState, disabledButtons, invisibleButtons);
210
212
  }
213
+ handleAddGridMode() {
214
+ return this.enableGridInsert ? TaskbarElement.GRID_MODE : "";
215
+ }
211
216
  getInvisibleButtons() {
212
217
  const invisibleButtons = [];
213
218
  if (this.dataState && this.dataState.selectionInfo.mode === SelectionMode.ALL_RECORDS)
@@ -360,11 +365,14 @@ export class SnkGuidesViewer {
360
365
  this._configManager.addFormLegacyConfig(this.formLegacyConfigName);
361
366
  }
362
367
  }
368
+ setMasterFormConfig(config) {
369
+ this.masterFormConfig = config;
370
+ }
363
371
  componentWillLoad() {
364
372
  if (this.resourceID == undefined) {
365
373
  throw new Error("Erro interno: resourceID não informado");
366
374
  }
367
- this._configManager = new SnkFormConfigManager(this.configName, this.resourceID, config => this.masterFormConfig = config);
375
+ this._configManager = new SnkFormConfigManager(this.configName, this.resourceID, this.setMasterFormConfig.bind(this), this.dataUnit);
368
376
  this.addFormLegacyConfigName();
369
377
  this._configManager.loadConfig();
370
378
  }
@@ -392,7 +400,7 @@ export class SnkGuidesViewer {
392
400
  return this._fieldSearch;
393
401
  }
394
402
  fieldsOptionLoader(argument) {
395
- return Promise.resolve(this._configManager.getFieldsList(this.dataUnit, argument)
403
+ return Promise.resolve(this._configManager.getFieldsList(argument)
396
404
  .map(field => ({ value: field.name, label: field.label })));
397
405
  }
398
406
  onSelectField(option, actionButton) {
@@ -464,6 +472,10 @@ export class SnkGuidesViewer {
464
472
  }
465
473
  return "";
466
474
  }
475
+ getTitle() {
476
+ var _a, _b;
477
+ return (_b = (_a = this.getCustomTitle) === null || _a === void 0 ? void 0 : _a.call(this)) !== null && _b !== void 0 ? _b : this.getMessage("snkCrud.title");
478
+ }
467
479
  componentDidLoad() {
468
480
  this.dataUnit.subscribe(this.dataUnitActionHandler.bind(this));
469
481
  }
@@ -477,7 +489,7 @@ export class SnkGuidesViewer {
477
489
  }
478
490
  this.loadTaskbarProcessor();
479
491
  const showGuides = this._guides && (this._guides.length > 1);
480
- 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 &&
492
+ 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 &&
481
493
  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 ?
482
494
  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) })
483
495
  :
@@ -794,6 +806,39 @@ export class SnkGuidesViewer {
794
806
  },
795
807
  "attribute": "form-legacy-config-name",
796
808
  "reflect": false
809
+ },
810
+ "enableGridInsert": {
811
+ "type": "boolean",
812
+ "mutable": false,
813
+ "complexType": {
814
+ "original": "boolean",
815
+ "resolved": "boolean",
816
+ "references": {}
817
+ },
818
+ "required": false,
819
+ "optional": true,
820
+ "docs": {
821
+ "tags": [],
822
+ "text": "Ativa inser\u00E7\u00E3o de registros no modo grade."
823
+ },
824
+ "attribute": "enable-grid-insert",
825
+ "reflect": false,
826
+ "defaultValue": "false"
827
+ },
828
+ "getCustomTitle": {
829
+ "type": "unknown",
830
+ "mutable": false,
831
+ "complexType": {
832
+ "original": "() => string",
833
+ "resolved": "() => string",
834
+ "references": {}
835
+ },
836
+ "required": false,
837
+ "optional": false,
838
+ "docs": {
839
+ "tags": [],
840
+ "text": "Fornece uma fun\u00E7\u00E3o para obter um t\u00EDtulo customizado do formul\u00E1rio."
841
+ }
797
842
  }
798
843
  };
799
844
  }
@@ -560,7 +560,8 @@ export class SnkDataUnit {
560
560
  }
561
561
  this.dataUnit.addInterceptor(this);
562
562
  if ((_b = this.dataUnit.records) === null || _b === void 0 ? void 0 : _b.length) {
563
- this.getMetadataByRow(this.dataUnit);
563
+ const { records } = this.getMetadataByRow(this.dataUnit);
564
+ this.dataUnit.records = records;
564
565
  }
565
566
  this.dataState = this.buildDataState();
566
567
  let resolver;
@@ -74,7 +74,7 @@ export class SnkFilterBinarySelect {
74
74
  }
75
75
  const [optOne, optTwo] = this.config.props.options;
76
76
  if (this.presentationMode === EPresentationMode.MODAL) {
77
- return (h(Host, null, h("div", { class: "ez-row ez-size-height--full" }, h("label", { class: "ez-text ez-title--small ez-title--primary ez-size-height--full ez-flex ez-flex--row ez-flex--align-items-center ez-col ez-col--sd-4" }, this.config.detailModal), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkOne = ref, id: `${this.config.id}_${optOne.name || "option1"}`, class: "sc-snk-filter-bar editor__ez-check", label: optOne.label, value: this.isSelected(optOne.name), compact: true })), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkTwo = ref, id: `${this.config.id}_${optTwo.name || "option2"}`, class: "sc-snk-filter-bar editor__ez-check", label: optTwo.label, value: this.isSelected(optTwo.name), compact: true })))));
77
+ return (h(Host, null, h("div", { class: "ez-row ez-size-height--full" }, h("label", { class: "ez-text ez-title--small ez-title--primary ez-size-height--full ez-flex ez-flex--row ez-flex--align-items-center ez-col ez-col--sd-4" }, this.config.detailModal), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkOne = ref, id: `${this.config.id}_${optOne.name || "option1"}`, class: "sc-snk-filter-bar editor__ez-check", label: optOne.label, value: this.isSelected(optOne.name) })), h("div", { class: "ez-col ez-col--sd-4" }, h("ez-check", { ref: (ref) => this._checkTwo = ref, id: `${this.config.id}_${optTwo.name || "option2"}`, class: "sc-snk-filter-bar editor__ez-check", label: optTwo.label, value: this.isSelected(optTwo.name) })))));
78
78
  }
79
79
  return (h(Host, null, h("ez-radio-button", { value: this._radioButtonValue }, h("ez-radio-button-option", { id: `${this.config.id}_${optOne.name || "option1"}`, class: "sc-snk-filter-bar editor__ez-check", label: optOne.label, value: optOne.name }), h("ez-radio-button-option", { id: `${this.config.id}_${optTwo.name || "option2"}`, class: "sc-snk-filter-bar editor__ez-check", label: optTwo.label, value: optTwo.name }), h("ez-radio-button-option", { id: `${this.config.id}_option3`, class: "sc-snk-filter-bar editor__ez-check", label: `${optOne.label} + ${optTwo.label}`, value: this._noOptionValue }))));
80
80
  }
@@ -19,7 +19,7 @@ export class SnkFilterCheckboxList {
19
19
  this.valueChanged.emit((_b = this.config) === null || _b === void 0 ? void 0 : _b.value);
20
20
  }
21
21
  renderOptions() {
22
- return this.optionsList.map(option => (h("ez-check", { label: option.label, compact: true, onEzChange: (event) => this.handleToggleCheck(option, event.detail), value: !!this.isChecked(option.name) })));
22
+ return this.optionsList.map(option => (h("ez-check", { label: option.label, onEzChange: (event) => this.handleToggleCheck(option, event.detail), value: !!this.isChecked(option.name) })));
23
23
  }
24
24
  isChecked(itemName) {
25
25
  var _a;
@@ -39,7 +39,7 @@ export class SnkFilterPersonalized {
39
39
  }
40
40
  getItemContent(item) {
41
41
  var _a, _b;
42
- const CheckboxElement = () => (h("ez-check", Object.assign({ class: "SnkFilterPersonalized_checkbox", id: `param_${item.id}`, key: item.id, compact: true, value: item.visible, label: item.label, onEzChange: ({ detail: visible }) => this.handleItemChange.bind(this)(visible, item.id) }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: `${ElementIDUtils.getInternalIDInfo(`checkboxFilter_${item.id}`)}` })));
42
+ const CheckboxElement = () => (h("ez-check", Object.assign({ class: "SnkFilterPersonalized_checkbox", id: `param_${item.id}`, key: item.id, value: item.visible, label: item.label, onEzChange: ({ detail: visible }) => this.handleItemChange.bind(this)(visible, item.id) }, { [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: `${ElementIDUtils.getInternalIDInfo(`checkboxFilter_${item.id}`)}` })));
43
43
  const isVariable = !!((_b = (_a = item.props) === null || _a === void 0 ? void 0 : _a.personalizedFilter) === null || _b === void 0 ? void 0 : _b.parameters.length);
44
44
  return (h("div", { class: `${!this.isModalMode() ? "SnkFilterPersonalized_list-item--chip" : ""}` }, h("li", { class: `${this.isModalMode() ? "SnkFilterPersonalized_list-item--modal" : ""}` }, h("div", { class: "ez-flex ez-flex--align-items-center ez-margin-right--small ez-size-width--full" }, h(CheckboxElement, null), this.buildModalListActions(item, isVariable))), (item.visible && isVariable) && (h("div", { class: "ez-row ez-padding--small" }, this.getFormField(item)))));
45
45
  }
@@ -105,7 +105,7 @@
105
105
 
106
106
  .snk-filter-bar__filter-item-container {
107
107
  display: flex;
108
- align-self: center;
108
+ align-items: start;
109
109
  }
110
110
 
111
111
  .snk-filter-bar__scroller :first-child {