@sankhyalabs/sankhyablocks 4.4.0-hotfix-ga-SKA-99999.1 → 4.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (123) hide show
  1. package/dist/cjs/{ConfigStorage-05b9b162.js → ConfigStorage-bc7d1d9b.js} +1 -1
  2. package/dist/cjs/{DataFetcher-451b3e68.js → DataFetcher-6acfc3a8.js} +3 -3
  3. package/dist/cjs/{SnkFormConfigManager-18ed80a5.js → SnkFormConfigManager-5230e010.js} +2 -2
  4. package/dist/cjs/{SnkMessageBuilder-0a6f6459.js → SnkMessageBuilder-d147f088.js} +8 -1
  5. package/dist/cjs/{constants-3d09ebea.js → constants-73803daf.js} +5 -0
  6. package/dist/cjs/{form-config-fetcher-a93d6334.js → form-config-fetcher-4a952a50.js} +1 -1
  7. package/dist/cjs/loader.cjs.js +1 -1
  8. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  9. package/dist/cjs/snk-application.cjs.entry.js +4 -4
  10. package/dist/cjs/snk-config-options.cjs.entry.js +1 -1
  11. package/dist/cjs/snk-configurator.cjs.entry.js +1 -1
  12. package/dist/cjs/snk-crud.cjs.entry.js +2 -2
  13. package/dist/cjs/snk-data-exporter.cjs.entry.js +4 -4
  14. package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
  15. package/dist/cjs/snk-detail-view.cjs.entry.js +6 -6
  16. package/dist/cjs/snk-field-config.cjs.entry.js +1 -1
  17. package/dist/cjs/snk-filter-bar.cjs.entry.js +3 -3
  18. package/dist/cjs/snk-filter-field-search.cjs.entry.js +185 -0
  19. package/dist/cjs/snk-form-config.cjs.entry.js +3 -3
  20. package/dist/cjs/snk-form.cjs.entry.js +4 -4
  21. package/dist/cjs/snk-grid-config.cjs.entry.js +4 -4
  22. package/dist/cjs/snk-grid.cjs.entry.js +3 -3
  23. package/dist/cjs/{snk-guides-viewer-618e5c1d.js → snk-guides-viewer-5d3dca5d.js} +3 -3
  24. package/dist/cjs/snk-guides-viewer.cjs.entry.js +6 -6
  25. package/dist/cjs/snk-select-box.cjs.entry.js +1 -1
  26. package/dist/cjs/snk-simple-crud.cjs.entry.js +252 -0
  27. package/dist/cjs/snk-tab-config.cjs.entry.js +1 -1
  28. package/dist/collection/collection-manifest.json +2 -0
  29. package/dist/collection/components/snk-filter-field-search/interfaces/index.js +5 -0
  30. package/dist/collection/components/snk-filter-field-search/snk-filter-field-search.css +41 -0
  31. package/dist/collection/components/snk-filter-field-search/snk-filter-field-search.js +297 -0
  32. package/dist/collection/components/snk-filter-field-search/subcomponents/index.js +1 -0
  33. package/dist/collection/components/snk-filter-field-search/subcomponents/list-item.js +24 -0
  34. package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +27 -0
  35. package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +343 -0
  36. package/dist/collection/lib/dataUnit/InMemoryLoader.js +112 -0
  37. package/dist/collection/lib/http/data-fetcher/DataFetcher.js +3 -3
  38. package/dist/collection/lib/http/data-fetcher/fetchers/fetchDataExporter/index.js +1 -1
  39. package/dist/collection/lib/http/data-fetcher/fetchers/fetchDataExporter/personalized-reports-fetcher.js +1 -1
  40. package/dist/collection/lib/message/SnkMessageBuilder.js +3 -1
  41. package/dist/collection/lib/message/resources/snk-filter-field-search.msg.js +5 -0
  42. package/dist/collection/lib/utils/constants.js +5 -0
  43. package/dist/components/DataFetcher.js +3 -3
  44. package/dist/components/SnkMessageBuilder.js +8 -1
  45. package/dist/components/constants.js +6 -1
  46. package/dist/components/index.d.ts +2 -0
  47. package/dist/components/index.js +2 -0
  48. package/dist/components/snk-data-exporter2.js +2 -2
  49. package/dist/components/snk-detail-view2.js +2 -1
  50. package/dist/components/snk-filter-field-search.d.ts +11 -0
  51. package/dist/components/snk-filter-field-search.js +205 -0
  52. package/dist/components/snk-grid2.js +2 -47
  53. package/dist/components/snk-simple-crud.d.ts +11 -0
  54. package/dist/components/snk-simple-crud.js +297 -0
  55. package/dist/components/taskbar-processor.js +47 -0
  56. package/dist/esm/{ConfigStorage-34caac5c.js → ConfigStorage-1b64cd96.js} +1 -1
  57. package/dist/esm/{DataFetcher-00309101.js → DataFetcher-5e99fa75.js} +3 -3
  58. package/dist/esm/{SnkFormConfigManager-d3a8aaf4.js → SnkFormConfigManager-0d9752c3.js} +2 -2
  59. package/dist/esm/{SnkMessageBuilder-9473ae03.js → SnkMessageBuilder-0e1ffd61.js} +8 -1
  60. package/dist/esm/{constants-fb9721cc.js → constants-9560e54f.js} +6 -1
  61. package/dist/esm/{form-config-fetcher-e58fc104.js → form-config-fetcher-677f86dd.js} +1 -1
  62. package/dist/esm/loader.js +1 -1
  63. package/dist/esm/sankhyablocks.js +1 -1
  64. package/dist/esm/snk-application.entry.js +4 -4
  65. package/dist/esm/snk-config-options.entry.js +1 -1
  66. package/dist/esm/snk-configurator.entry.js +1 -1
  67. package/dist/esm/snk-crud.entry.js +2 -2
  68. package/dist/esm/snk-data-exporter.entry.js +4 -4
  69. package/dist/esm/snk-data-unit.entry.js +2 -2
  70. package/dist/esm/snk-detail-view.entry.js +6 -6
  71. package/dist/esm/snk-field-config.entry.js +1 -1
  72. package/dist/esm/snk-filter-bar.entry.js +3 -3
  73. package/dist/esm/snk-filter-field-search.entry.js +181 -0
  74. package/dist/esm/snk-form-config.entry.js +3 -3
  75. package/dist/esm/snk-form.entry.js +4 -4
  76. package/dist/esm/snk-grid-config.entry.js +4 -4
  77. package/dist/esm/snk-grid.entry.js +3 -3
  78. package/dist/esm/{snk-guides-viewer-7c32399d.js → snk-guides-viewer-6bb54367.js} +3 -3
  79. package/dist/esm/snk-guides-viewer.entry.js +6 -6
  80. package/dist/esm/snk-select-box.entry.js +1 -1
  81. package/dist/esm/snk-simple-crud.entry.js +248 -0
  82. package/dist/esm/snk-tab-config.entry.js +1 -1
  83. package/dist/sankhyablocks/{p-9cff8df2.js → p-0c11c980.js} +1 -1
  84. package/dist/sankhyablocks/{p-52989652.entry.js → p-268ab84f.entry.js} +1 -1
  85. package/dist/sankhyablocks/{p-0fe01a57.entry.js → p-2a3996b0.entry.js} +1 -1
  86. package/dist/sankhyablocks/p-330813ff.entry.js +1 -0
  87. package/dist/sankhyablocks/{p-25341d65.js → p-3c4823fc.js} +1 -1
  88. package/dist/sankhyablocks/{p-44c23eb1.entry.js → p-4bd183ba.entry.js} +1 -1
  89. package/dist/sankhyablocks/{p-c4483cb2.js → p-5518d572.js} +1 -1
  90. package/dist/sankhyablocks/{p-e0416591.entry.js → p-7889d481.entry.js} +1 -1
  91. package/dist/sankhyablocks/p-79d22df0.entry.js +1 -0
  92. package/dist/sankhyablocks/{p-fc86a31e.entry.js → p-869d6616.entry.js} +1 -1
  93. package/dist/sankhyablocks/{p-99742169.entry.js → p-86efa17d.entry.js} +1 -1
  94. package/dist/sankhyablocks/{p-2980936b.entry.js → p-8b0e8deb.entry.js} +1 -1
  95. package/dist/sankhyablocks/{p-ca72cc38.js → p-9bf0319f.js} +1 -1
  96. package/dist/sankhyablocks/{p-83ddac9f.entry.js → p-9f00c061.entry.js} +1 -1
  97. package/dist/sankhyablocks/{p-43d8d388.entry.js → p-9f2306ba.entry.js} +1 -1
  98. package/dist/sankhyablocks/{p-9d4a25d2.js → p-9f98fc3c.js} +1 -1
  99. package/dist/sankhyablocks/{p-840494aa.entry.js → p-a056d61f.entry.js} +1 -1
  100. package/dist/sankhyablocks/{p-70037212.js → p-a6258eed.js} +1 -1
  101. package/dist/sankhyablocks/{p-de1ee26c.entry.js → p-b318cec6.entry.js} +1 -1
  102. package/dist/sankhyablocks/p-c0bfafcb.entry.js +1 -0
  103. package/dist/sankhyablocks/p-cf9d1b55.entry.js +1 -0
  104. package/dist/sankhyablocks/{p-8899a7ea.entry.js → p-d3199c18.entry.js} +1 -1
  105. package/dist/sankhyablocks/{p-9d62bbca.entry.js → p-dbeac5db.entry.js} +1 -1
  106. package/dist/sankhyablocks/{p-f5d3ecb3.js → p-ecbfbb4a.js} +1 -1
  107. package/dist/sankhyablocks/{p-6e6ef989.entry.js → p-f83e3219.entry.js} +1 -1
  108. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  109. package/dist/types/components/snk-filter-field-search/interfaces/index.d.ts +35 -0
  110. package/dist/types/components/snk-filter-field-search/snk-filter-field-search.d.ts +58 -0
  111. package/dist/types/components/snk-filter-field-search/subcomponents/index.d.ts +1 -0
  112. package/dist/types/components/snk-filter-field-search/subcomponents/list-item.d.ts +2 -0
  113. package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +41 -0
  114. package/dist/types/components.d.ts +81 -2
  115. package/dist/types/lib/dataUnit/InMemoryLoader.d.ts +21 -0
  116. package/dist/types/lib/message/resources/snk-filter-field-search.msg.d.ts +1 -0
  117. package/dist/types/lib/utils/constants.d.ts +4 -0
  118. package/package.json +2 -2
  119. package/react/components.d.ts +2 -0
  120. package/react/components.js +2 -0
  121. package/react/components.js.map +1 -1
  122. package/dist/sankhyablocks/p-4de78929.entry.js +0 -1
  123. package/dist/sankhyablocks/p-e7cc6e62.entry.js +0 -1
@@ -1,11 +1,11 @@
1
1
  import { r as registerInstance, c as createEvent, h, F as Fragment } from './index-cfd4bb13.js';
2
2
  import { ApplicationContext, ElementIDUtils } from '@sankhyalabs/core';
3
- import { S as SnkFormConfigManager } from './SnkFormConfigManager-d3a8aaf4.js';
3
+ import { S as SnkFormConfigManager } from './SnkFormConfigManager-0d9752c3.js';
4
4
  import { buildFormMetadata, FormMetadata } from '@sankhyalabs/ezui/dist/collection/utils/form';
5
5
  import { T as TaskbarProcessor } from './taskbar-processor-c2a99aba.js';
6
6
  import { T as TaskbarElement } from './taskbar-elements-10d80c79.js';
7
- import { c as VIEW_MODE } from './constants-fb9721cc.js';
8
- import './DataFetcher-00309101.js';
7
+ import { c as VIEW_MODE } from './constants-9560e54f.js';
8
+ import './DataFetcher-5e99fa75.js';
9
9
  import { P as PresentationMode } from './index-6519a79e.js';
10
10
 
11
11
  const snkGuidesViewerCss = ".sc-snk-guides-viewer-h{--snk-guides-viewer--space-large:var(--space--large, 24px);--snk-guides-viewer--space-medium:var(--space--medium, 12px);--snk-guides-viewer__header--min-height:94px;--snk-guides-viewer__header--z-index:var(--more-visible, 2);--snk-guides-viewer__header--background-color:var(--background--body, #fafcff);--snk-guides-viewer__guide-navigator--width:340px;display:block}snk-form-view.sc-snk-guides-viewer{width:100%}.snk-guides-viewer.sc-snk-guides-viewer{position:relative;padding-left:0px;padding-top:0px;padding-right:var(--snk-guides-viewer--space-large);padding-bottom:var(--snk-guides-viewer--space-large)}.snk-guides-viewer__detail-container.sc-snk-guides-viewer{display:flex;row-gap:24px;flex-direction:column}.snk-guides-viewer__header.sc-snk-guides-viewer{position:sticky;align-items:center;top:0;z-index:var(--snk-guides-viewer__header--z-index);background-color:var(--snk-guides-viewer__header--background-color);min-height:var(--snk-guides-viewer__header--min-height);width:calc(100% + (var(--snk-guides-viewer--space-large) * 2));padding-left:var(--snk-guides-viewer--space-large);padding-right:var(--snk-guides-viewer--space-large);padding-top:var(--snk-guides-viewer--space-large);padding-bottom:var(--snk-guides-viewer--space-medium);margin-left:calc(var(--snk-guides-viewer--space-large) * -1);margin-right:calc(var(--snk-guides-viewer--space-large) * -1);margin-bottom:var(--snk-guides-viewer--space-medium)}.snk-guides-viewer__container.sc-snk-guides-viewer{display:grid;grid-template-columns:minmax(0, auto) minmax(0, 100%);height:100%;column-gap:var(--snk-guides-viewer--space-large)}.snk-guides-viewer__guide-navigator.sc-snk-guides-viewer{position:sticky;top:calc(var(--snk-guides-viewer__header--min-height) + var(--snk-guides-viewer--space-medium));height:calc(100vh - var(--snk-guides-viewer__header--min-height) - var(--snk-guides-viewer--space-large) - var(--snk-guides-viewer--space-medium))}.snk-guides-viewer__guide-navigator[open].sc-snk-guides-viewer{width:var(--snk-guides-viewer__guide-navigator--width);max-width:var(--snk-guides-viewer__guide-navigator--width);min-width:var(--snk-guides-viewer__guide-navigator--width)}.snk-guides-viewer__detail-content.sc-snk-guides-viewer{min-height:100%;align-items:flex-start;align-content:flex-start}";
@@ -1,14 +1,14 @@
1
- export { S as snk_guides_viewer } from './snk-guides-viewer-7c32399d.js';
1
+ export { S as snk_guides_viewer } from './snk-guides-viewer-6bb54367.js';
2
2
  import './index-cfd4bb13.js';
3
3
  import '@sankhyalabs/core';
4
- import './SnkFormConfigManager-d3a8aaf4.js';
5
- import './ConfigStorage-34caac5c.js';
6
- import './form-config-fetcher-e58fc104.js';
7
- import './DataFetcher-00309101.js';
4
+ import './SnkFormConfigManager-0d9752c3.js';
5
+ import './ConfigStorage-1b64cd96.js';
6
+ import './form-config-fetcher-677f86dd.js';
7
+ import './DataFetcher-5e99fa75.js';
8
8
  import './_commonjsHelpers-9943807e.js';
9
9
  import '@sankhyalabs/ezui/dist/collection/utils/form';
10
10
  import './taskbar-processor-c2a99aba.js';
11
11
  import './taskbar-elements-10d80c79.js';
12
12
  import './index-6519a79e.js';
13
13
  import './index-e467ade5.js';
14
- import './constants-fb9721cc.js';
14
+ import './constants-9560e54f.js';
@@ -1,5 +1,5 @@
1
1
  import { r as registerInstance, c as createEvent, h } from './index-cfd4bb13.js';
2
- import { O as ORDER_VALUES } from './constants-fb9721cc.js';
2
+ import { O as ORDER_VALUES } from './constants-9560e54f.js';
3
3
 
4
4
  const snkSelectBoxCss = "ez-combo-box{width:100px}.grid-config-combo{--ez-text-input--height:28px;--ez-text-input__input--background-color:#fff;--ez-text-input__input--border-color:#dce0e8}";
5
5
 
@@ -0,0 +1,248 @@
1
+ import { r as registerInstance, h, g as getElement } from './index-cfd4bb13.js';
2
+ import { DataUnit, StringUtils, SortMode, DataType, ChangeOperation, UserInterface } from '@sankhyalabs/core';
3
+ import { c as VIEW_MODE, S as SIMPLE_CRUD_MODE } from './constants-9560e54f.js';
4
+ import { T as TaskbarElement } from './taskbar-elements-10d80c79.js';
5
+ import './DataFetcher-5e99fa75.js';
6
+ import { P as PresentationMode } from './index-6519a79e.js';
7
+ import { T as TaskbarProcessor } from './taskbar-processor-c2a99aba.js';
8
+ import './index-e467ade5.js';
9
+ import './_commonjsHelpers-9943807e.js';
10
+
11
+ class InMemoryLoader {
12
+ constructor(metadata, records) {
13
+ this.records = records || [];
14
+ this.metadata = metadata;
15
+ this._dataUnit = new DataUnit("InMemoryDataUnit");
16
+ this._dataUnit.metadataLoader = () => this.metadaLoader();
17
+ this._dataUnit.dataLoader = (_dataUnit, request) => this.dataLoader(_dataUnit, request);
18
+ this._dataUnit.saveLoader = (_dataUnit, changes) => this.saveLoader(_dataUnit, changes);
19
+ this._dataUnit.removeLoader = (_dataUnit, recordIds) => this.removeLoader(_dataUnit, recordIds);
20
+ this.dataUnit.loadMetadata().then(() => this.dataUnit.loadData());
21
+ }
22
+ get dataUnit() {
23
+ return this._dataUnit;
24
+ }
25
+ get records() {
26
+ return this._records;
27
+ }
28
+ set records(records) {
29
+ this._records = records === null || records === void 0 ? void 0 : records.map(record => {
30
+ if (!record["__record__id__"]) {
31
+ record["__record__id__"] = this.generateUniqueId();
32
+ }
33
+ return record;
34
+ });
35
+ if (this._dataUnit) {
36
+ this._dataUnit.records = [...this._records];
37
+ }
38
+ }
39
+ get metadata() {
40
+ return this._metadata;
41
+ }
42
+ set metadata(metadata) {
43
+ this._metadata = metadata;
44
+ if (this._dataUnit) {
45
+ this._dataUnit.metadata = this._metadata;
46
+ }
47
+ }
48
+ generateUniqueId() {
49
+ return StringUtils.generateUUID();
50
+ }
51
+ metadaLoader() {
52
+ return Promise.resolve(this._metadata);
53
+ }
54
+ dataLoader(_dataUnit, request) {
55
+ let records = [...this._records];
56
+ if (request.sort) {
57
+ request.sort.forEach(sort => {
58
+ records = records.sort((recordA, recordB) => {
59
+ const fieldA = recordA[sort.field];
60
+ const fieldB = recordB[sort.field];
61
+ const sortFn = this.getSortFn(sort.dataType);
62
+ return sortFn(fieldA, fieldB) * (sort.mode == SortMode.ASC ? 1 : -1);
63
+ });
64
+ });
65
+ }
66
+ return Promise.resolve({ records: records });
67
+ }
68
+ getSortFn(type) {
69
+ switch (type) {
70
+ case DataType.NUMBER:
71
+ return this.sortNumber;
72
+ case DataType.DATE:
73
+ return this.sortDate;
74
+ case DataType.OBJECT:
75
+ return this.sortObject;
76
+ default:
77
+ return StringUtils.compare;
78
+ }
79
+ }
80
+ sortObject(a, b) {
81
+ return StringUtils.compare(a["label"], b["label"]);
82
+ }
83
+ sortNumber(a, b) {
84
+ return a - b;
85
+ }
86
+ sortDate(a, b) {
87
+ let timeA = a.getTime(), timeB = b.getTime();
88
+ return timeA === timeB ? 0 : (timeA < timeB ? -1 : 1);
89
+ }
90
+ saveLoader(_dataUnit, changes) {
91
+ return new Promise((resolve) => {
92
+ let dataUnitRecords = [];
93
+ changes.forEach(change => {
94
+ let { record, updatingFields, operation } = change;
95
+ let isAdd = false;
96
+ if (operation === ChangeOperation.INSERT ||
97
+ operation === ChangeOperation.COPY) {
98
+ record["__old__id__"] = record["__record__id__"];
99
+ record["__record__id__"] = this.generateUniqueId();
100
+ isAdd = true;
101
+ }
102
+ const changedRecord = Object.assign(Object.assign({}, record), updatingFields);
103
+ if (isAdd) {
104
+ this.records.push(changedRecord);
105
+ }
106
+ else {
107
+ const recordIndex = this.records.findIndex(r => r["__record__id__"] == changedRecord["__record__id__"]);
108
+ this.records[recordIndex] = changedRecord;
109
+ }
110
+ dataUnitRecords.push(changedRecord);
111
+ });
112
+ resolve(dataUnitRecords);
113
+ });
114
+ }
115
+ removeLoader(_dataUnit, recordIds) {
116
+ return new Promise((resolve) => {
117
+ this._records = this._records.filter(record => !recordIds.includes(record["__record__id__"]));
118
+ resolve(recordIds);
119
+ });
120
+ }
121
+ }
122
+
123
+ const snkSimpleCrudCss = ".sc-snk-simple-crud-h{display:flex;height:100%;width:100%}.simple-crud__container.sc-snk-simple-crud{display:grid;grid-template-rows:auto;row-gap:12px;height:100%;width:100%}.simple-crud__taskbar.sc-snk-simple-crud{z-index:var(--more-visible, 2);margin-bottom:var(--space--medium)}ez-grid.sc-snk-simple-crud{--ez-grid__container--shadow:none;min-height:300px}ez-form.sc-snk-simple-crud{min-height:300px}";
124
+
125
+ const SnkSimpleCrud = class {
126
+ constructor(hostRef) {
127
+ registerInstance(this, hostRef);
128
+ this.REGULAR_DEFAULT_BTNS = ["INSERT", "PREVIOUS", "NEXT", "DIVIDER"];
129
+ this.REGULAR_SELECTED_BTNS = ["INSERT", "PREVIOUS", "NEXT", "DIVIDER", "CLONE", "REMOVE", "DIVIDER"];
130
+ this._taskbarProcessor = new TaskbarProcessor({
131
+ "snkSimpleCrudTaskbar.form_regular": this.REGULAR_DEFAULT_BTNS.concat(TaskbarElement.GRID_MODE),
132
+ "snkSimpleCrudTaskbar.grid_regular": this.REGULAR_DEFAULT_BTNS.concat(TaskbarElement.FORM_MODE),
133
+ "snkSimpleCrudTaskbar.form_selected": this.REGULAR_SELECTED_BTNS.concat(TaskbarElement.GRID_MODE),
134
+ "snkSimpleCrudTaskbar.grid_selected": this.REGULAR_SELECTED_BTNS.concat(TaskbarElement.FORM_MODE),
135
+ "snkSimpleCrudTaskbar.finish_edition": ["CANCEL", "SAVE"]
136
+ });
137
+ this._currentViewMode = VIEW_MODE.GRID;
138
+ this._config = undefined;
139
+ this.dataState = undefined;
140
+ this.dataUnit = undefined;
141
+ this.mode = SIMPLE_CRUD_MODE.SERVER;
142
+ this.taskbarManager = undefined;
143
+ }
144
+ /**
145
+ * Usado para alternar a visão entre GRID e FORM externamente.
146
+ */
147
+ async goToView(view) {
148
+ this._currentViewMode = view;
149
+ if (this._viewStack) {
150
+ this._viewStack.show(view);
151
+ }
152
+ }
153
+ actionClickListener(evt) {
154
+ const act = evt.detail;
155
+ if (act === TaskbarElement.GRID_MODE) {
156
+ this.goToView(VIEW_MODE.GRID);
157
+ }
158
+ else if (act === TaskbarElement.FORM_MODE) {
159
+ this.goToView(VIEW_MODE.FORM);
160
+ }
161
+ evt.stopPropagation();
162
+ }
163
+ onModeChange() {
164
+ if (this.mode == SIMPLE_CRUD_MODE.IN_MEMORY) {
165
+ this.initInMemoryDataUnit();
166
+ }
167
+ }
168
+ componentWillRender() {
169
+ this._taskbarProcessor.process(this.getTaskBarId(), this.taskbarManager, this.dataState, undefined);
170
+ }
171
+ componentWillLoad() {
172
+ this.processMetadata();
173
+ this.onModeChange();
174
+ }
175
+ getTaskBarId() {
176
+ var _a, _b;
177
+ if ((_a = this.dataState) === null || _a === void 0 ? void 0 : _a.isDirty) {
178
+ return "snkSimpleCrudTaskbar.finish_edition";
179
+ }
180
+ if (((_b = this.dataState) === null || _b === void 0 ? void 0 : _b.selectedRecords.length) > 0) {
181
+ return this._currentViewMode === VIEW_MODE.GRID ? "snkSimpleCrudTaskbar.grid_selected" : "snkSimpleCrudTaskbar.form_selected";
182
+ }
183
+ return this._currentViewMode === VIEW_MODE.GRID ? "snkSimpleCrudTaskbar.grid_regular" : "snkSimpleCrudTaskbar.form_regular";
184
+ }
185
+ initInMemoryDataUnit() {
186
+ this._inMemoryLoader = new InMemoryLoader(this._metadata);
187
+ this.dataUnit = this._inMemoryLoader.dataUnit;
188
+ }
189
+ setMetadata(metadata) {
190
+ if (this._inMemoryLoader) {
191
+ this._inMemoryLoader.metadata = metadata;
192
+ }
193
+ else if (this.dataUnit) {
194
+ this.dataUnit.metadata = metadata;
195
+ }
196
+ return Promise.resolve();
197
+ }
198
+ setRecords(records) {
199
+ if (this._inMemoryLoader) {
200
+ this._inMemoryLoader.records = records;
201
+ }
202
+ else if (this.dataUnit) {
203
+ this.dataUnit.records = records;
204
+ }
205
+ return Promise.resolve();
206
+ }
207
+ getRecords() {
208
+ return Promise.resolve(this.dataUnit.records);
209
+ }
210
+ processMetadata() {
211
+ const fieldsMetadataElem = this._element.querySelectorAll("snk-field-metadata");
212
+ const fieldMetadata = [];
213
+ const formConfig = { fields: [], emptyConfig: false };
214
+ fieldsMetadataElem.forEach(fieldElem => {
215
+ const field = {
216
+ name: fieldElem.getAttribute("name") || fieldElem.getAttribute("label"),
217
+ label: fieldElem.getAttribute("label"),
218
+ dataType: DataType[fieldElem.getAttribute("dataType")] || DataType.TEXT,
219
+ userInterface: UserInterface[fieldElem.getAttribute("userInterface")] || UserInterface.SHORTTEXT,
220
+ readOnly: fieldElem.getAttribute("readOnly") == "true",
221
+ required: fieldElem.getAttribute("required") == "true",
222
+ tab: fieldElem.getAttribute("tab") || undefined
223
+ };
224
+ const fieldConfig = { name: field.name, tab: field.tab };
225
+ formConfig.fields.push(fieldConfig);
226
+ fieldMetadata.push(field);
227
+ });
228
+ if (fieldMetadata.length > 0) {
229
+ this._config = formConfig;
230
+ this._metadata = {
231
+ name: "SimpleCrud",
232
+ label: "SimpleCrud",
233
+ fields: fieldMetadata
234
+ };
235
+ }
236
+ }
237
+ render() {
238
+ var _a;
239
+ return (h("snk-data-unit", { class: "simple-crud__container", dataUnit: this.dataUnit, onDataStateChange: evt => this.dataState = evt.detail, onInsertionMode: () => this.goToView(VIEW_MODE.FORM) }, h("header", null, h("slot", { name: "snkSimpleCrudHeader" })), h("section", { class: "ez-flex ez-box ez-box--shadow" }, h("snk-taskbar", { class: "simple-crud__taskbar 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", buttons: this._taskbarProcessor.buttons, disabledButtons: this._taskbarProcessor.disabledButtons, customButtons: this._taskbarProcessor.customButtons, slot: "leftButtons", presentationMode: PresentationMode.SECONDARY }), h("ez-view-stack", { class: "ez-flex ez-flex--column", ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, h("stack-item", null, h("ez-grid", { dataUnit: this.dataUnit, onEzDoubleClick: () => this.goToView(VIEW_MODE.FORM), "no-header": true }, h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, h("ez-form", { dataUnit: this.dataUnit, config: this._config }))))));
240
+ }
241
+ get _element() { return getElement(this); }
242
+ static get watchers() { return {
243
+ "mode": ["onModeChange"]
244
+ }; }
245
+ };
246
+ SnkSimpleCrud.style = snkSimpleCrudCss;
247
+
248
+ export { SnkSimpleCrud as snk_simple_crud };
@@ -1,7 +1,7 @@
1
1
  import { r as registerInstance, c as createEvent, h, F as Fragment, H as Host, g as getElement } from './index-cfd4bb13.js';
2
2
  import { d as draggable_bundle } from './draggable.bundle-41d56f06.js';
3
3
  import { ApplicationContext, ElementIDUtils } from '@sankhyalabs/core';
4
- import { C as CONFIG_EVENTS, K as KEY_EVENTS, b as TYPE_ACTIONS, T as TAB_NAMES } from './constants-fb9721cc.js';
4
+ import { C as CONFIG_EVENTS, K as KEY_EVENTS, b as TYPE_ACTIONS, T as TAB_NAMES } from './constants-9560e54f.js';
5
5
  import './_commonjsHelpers-9943807e.js';
6
6
 
7
7
  const snkTabConfigCss = "@keyframes activate{0%{clip-path:inset(calc(100% - 3px) 50% 0px 50%)}100%{clip-path:inset(calc(100% - 3px) 0px 0px 0px)}}.sc-snk-tab-config-h{--snk-tab-config--backward-icon:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" height=\"16px\" width=\"10px\"><path d=\"M 9.7808475,13.860393 3.9204526,8.0000004 9.7808475,2.0624965 7.9301965,0.28895552 0.21915255,8.0000004 7.9301965,15.711044 Z\"/></svg>');--snk-tab-config--forward-icon:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" height=\"16px\" width=\"10px\"><path d=\"M 0.21915251,13.860393 6.0795475,8.0000007 0.21915251,2.0624968 2.0698036,0.28895588 9.7808475,8.0000007 2.0698036,15.711044 Z\"/></svg>');--snk-tab-config__lower-bar--background-color:var(--color--disable-primary, #e5eaf0);--snk-tab-config__lower-bar--border:2px solid var(--color--disable-primary, #e5eaf0);--snk-tab-config__tab--color:var(--text--primary, #626e82);--snk-tab-config__tab--font-family:var(--font-pattern, \"Roboto\");--snk-tab-config__tab--font-size:var(--title--small, 14px);--snk-tab-config__tab--padding:var(--space--small, 6px) var(--space--medium, 12px);--snk-tab-config__tab-is-active--color:var(--color--primary, #008561);--snk-tab-config__tab-hover--color:var(--color--secondary, #383c45);--snk-tab-config__tab-is-focused--border:1px dashed var(--color--primary, #008561);--snk-tab-config__tab-label--text-shadow:var(--text-shadow, 0 0 0 #353535, 0 0 1px transparent);--snk-tab-config__tab-label--margin-bottom:var(--space--extra-small, 3px);--snk-tab-config__new-button-icon--color:var(--color--secondary-700, #1C1D22);--snk-tab-config__forward-button--background-color:var(--text--primary, #626e82);--snk-tab-config__forward-button-hover--background-color:var(--color--primary, #008561);--snk-tab-config__left-icon--padding-right:var(--space--small, 6px);--snk-tab-config__left-icon--color:var(--text--disable, #AFB6C0);--snk-tab-config__tab-label-disabled--color:var(--text--disable, #AFB6C0);--snk-tab-config__slot--margin-left:var(--space--small, 6px);display:flex;position:relative;width:100%;overflow:hidden}.tab-config__scroll.sc-snk-tab-config{display:flex;width:100%;scroll-behavior:smooth;overflow-x:auto;scrollbar-width:none}.tab-config__lower-bar.sc-snk-tab-config{position:absolute;left:0%;right:0%;top:91%;bottom:0%;border-radius:2px;background-color:var(--snk-tab-config__lower-bar--background-color);border:var(--snk-tab-config__lower-bar--border)}.tab-config__tab.sc-snk-tab-config{display:flex;border:none;background-color:unset;cursor:pointer;align-items:center;justify-content:center;min-width:fit-content;color:var(--snk-tab-config__tab--color);font-family:var(--snk-tab-config__tab--font-family);font-size:var(--snk-tab-config__tab--font-size);padding:var(--snk-tab-config__tab--padding)}.tab-config__tab.sc-snk-tab-config:focus,.tab-config__forward-button.sc-snk-tab-config,.tab-config__backward-button.sc-snk-tab-config{outline:none}.tab-config__tab--is-active.sc-snk-tab-config{position:relative;color:var(--snk-tab-config__tab-is-active--color)}.tab-config__tab.sc-snk-tab-config:hover{color:var(--snk-tab-config__tab-hover--color)}.tab-config__tab--is-active.sc-snk-tab-config:hover{color:var(--snk-tab-config__tab-is-active--color)}.tab-config__tab--is-active.sc-snk-tab-config::after{content:\"\";position:absolute;width:100%;height:100%;clip-path:inset(calc(100% - 3px) 0px 0px 0px);animation:activate 0.25s ease-in-out;background-color:var(--snk-tab-config__tab-is-active--color)}.tab-config__tab--is-focused.sc-snk-tab-config{border:var(--snk-tab-config__tab-is-focused--border)}.tab-config__tab-label.sc-snk-tab-config{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;text-shadow:var(--snk-tab-config__tab-label--text-shadow);margin-bottom:var(--snk-tab-config__tab-label--margin-bottom)}.tab-config__forward-button.sc-snk-tab-config,.tab-config__backward-button.sc-snk-tab-config{position:absolute;z-index:1;display:flex;box-sizing:border-box;padding:0px;top:0px;right:0px;width:16px;height:100%;border:none;background-color:unset;cursor:pointer;justify-content:center;align-items:center}.tab-config__new-button.sc-snk-tab-config{position:absolute;z-index:1;display:flex;box-sizing:border-box;padding:0px;top:0px;right:0px;height:100%;border:none;background-color:unset;cursor:pointer;justify-content:center;align-items:center}.tab-config__new-button.sc-snk-tab-config ez-icon.sc-snk-tab-config{--ez-icon--color:var(--snk-tab-config__new-button-icon--color)}.tab-config__backward-button.sc-snk-tab-config{left:0px;box-shadow:10px 10px 5px 5px white;background:white}.tab-config__forward-button.sc-snk-tab-config{box-shadow:10px 10px 5px 20px white;background:white}.tab-config__forward-button.sc-snk-tab-config::after,.tab-config__backward-button.sc-snk-tab-config::after{content:'';display:flex;width:10px;height:16px;background-color:var(--snk-tab-config__forward-button--background-color)}.tab-config__forward-button.sc-snk-tab-config::after{-webkit-mask-image:var(--snk-tab-config--forward-icon);mask-image:var(--snk-tab-config--forward-icon)}.tab-config__backward-button.sc-snk-tab-config::after{-webkit-mask-image:var(--snk-tab-config--backward-icon);mask-image:var(--snk-tab-config--backward-icon)}.tab-config__forward-button.sc-snk-tab-config:hover::after,.tab-config__backward-button.sc-snk-tab-config:hover::after{background-color:var(--snk-tab-config__forward-button-hover--background-color)}.tab-config__new-button.sc-snk-tab-config:hover ez-icon.sc-snk-tab-config{--ez-icon--color:var(--snk-tab-config__forward-button-hover--background-color)}.tab-config__hidden.sc-snk-tab-config{display:none}.tab-config__scroll.sc-snk-tab-config::-webkit-scrollbar{display:none}.tab-config__left-icon.sc-snk-tab-config{padding-right:var(--snk-tab-config__left-icon--padding-right);--ez-icon--color:var(--snk-tab-config__left-icon--color)}.tab-config__left-icon--eye-off.sc-snk-tab-config{--ez-icon--color:var(--snk-tab-config__left-icon--color)}.tab-config__right-icon.sc-snk-tab-config{visibility:hidden;padding-left:var(--snk-tab-config__left-icon--padding-right)}.tab-config__tab.sc-snk-tab-config:hover .tab-config__right-icon.sc-snk-tab-config{visibility:visible}.tab-config__tab--is-active.sc-snk-tab-config .tab-config__right-icon.sc-snk-tab-config{visibility:visible;--ez-icon--color:var(--snk-tab-config__tab-is-active--color)}.tab-config__tab.sc-snk-tab-config:hover .tab-config__right-icon.sc-snk-tab-config{--ez-icon--color:var(--snk-tab-config__tab-hover--color)}.tab-config__tab--is-active.sc-snk-tab-config:hover .tab-config__right-icon.sc-snk-tab-config{--ez-icon--color:var(--snk-tab-config__tab-is-active--color)}.tab-config__actions-button.sc-snk-tab-config{--ez-actions-button__btn-action--min-width:100px;visibility:hidden;opacity:0;transition:visibility 1s linear, opacity 0.3s linear}.tab-config__tab.sc-snk-tab-config:hover .tab-config__actions-button.sc-snk-tab-config{visibility:visible;opacity:1;transition:visibility 0.2s linear, opacity 0.10s linear}[data-draggable-element].sc-snk-tab-config{cursor:grab}.tab-config__tab-label-disabled.sc-snk-tab-config{color:var(--snk-tab-config__tab-label-disabled--color)}.tab-config__slot.sc-snk-tab-config{margin-left:var(--snk-tab-config__slot--margin-left)}";