@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.
- package/dist/cjs/{ConfigStorage-05b9b162.js → ConfigStorage-bc7d1d9b.js} +1 -1
- package/dist/cjs/{DataFetcher-451b3e68.js → DataFetcher-6acfc3a8.js} +3 -3
- package/dist/cjs/{SnkFormConfigManager-18ed80a5.js → SnkFormConfigManager-5230e010.js} +2 -2
- package/dist/cjs/{SnkMessageBuilder-0a6f6459.js → SnkMessageBuilder-d147f088.js} +8 -1
- package/dist/cjs/{constants-3d09ebea.js → constants-73803daf.js} +5 -0
- package/dist/cjs/{form-config-fetcher-a93d6334.js → form-config-fetcher-4a952a50.js} +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/sankhyablocks.cjs.js +1 -1
- package/dist/cjs/snk-application.cjs.entry.js +4 -4
- package/dist/cjs/snk-config-options.cjs.entry.js +1 -1
- package/dist/cjs/snk-configurator.cjs.entry.js +1 -1
- package/dist/cjs/snk-crud.cjs.entry.js +2 -2
- package/dist/cjs/snk-data-exporter.cjs.entry.js +4 -4
- package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
- package/dist/cjs/snk-detail-view.cjs.entry.js +6 -6
- package/dist/cjs/snk-field-config.cjs.entry.js +1 -1
- package/dist/cjs/snk-filter-bar.cjs.entry.js +3 -3
- package/dist/cjs/snk-filter-field-search.cjs.entry.js +185 -0
- package/dist/cjs/snk-form-config.cjs.entry.js +3 -3
- package/dist/cjs/snk-form.cjs.entry.js +4 -4
- package/dist/cjs/snk-grid-config.cjs.entry.js +4 -4
- package/dist/cjs/snk-grid.cjs.entry.js +3 -3
- package/dist/cjs/{snk-guides-viewer-618e5c1d.js → snk-guides-viewer-5d3dca5d.js} +3 -3
- package/dist/cjs/snk-guides-viewer.cjs.entry.js +6 -6
- package/dist/cjs/snk-select-box.cjs.entry.js +1 -1
- package/dist/cjs/snk-simple-crud.cjs.entry.js +252 -0
- package/dist/cjs/snk-tab-config.cjs.entry.js +1 -1
- package/dist/collection/collection-manifest.json +2 -0
- package/dist/collection/components/snk-filter-field-search/interfaces/index.js +5 -0
- package/dist/collection/components/snk-filter-field-search/snk-filter-field-search.css +41 -0
- package/dist/collection/components/snk-filter-field-search/snk-filter-field-search.js +297 -0
- package/dist/collection/components/snk-filter-field-search/subcomponents/index.js +1 -0
- package/dist/collection/components/snk-filter-field-search/subcomponents/list-item.js +24 -0
- package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +27 -0
- package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +343 -0
- package/dist/collection/lib/dataUnit/InMemoryLoader.js +112 -0
- package/dist/collection/lib/http/data-fetcher/DataFetcher.js +3 -3
- package/dist/collection/lib/http/data-fetcher/fetchers/fetchDataExporter/index.js +1 -1
- package/dist/collection/lib/http/data-fetcher/fetchers/fetchDataExporter/personalized-reports-fetcher.js +1 -1
- package/dist/collection/lib/message/SnkMessageBuilder.js +3 -1
- package/dist/collection/lib/message/resources/snk-filter-field-search.msg.js +5 -0
- package/dist/collection/lib/utils/constants.js +5 -0
- package/dist/components/DataFetcher.js +3 -3
- package/dist/components/SnkMessageBuilder.js +8 -1
- package/dist/components/constants.js +6 -1
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.js +2 -0
- package/dist/components/snk-data-exporter2.js +2 -2
- package/dist/components/snk-detail-view2.js +2 -1
- package/dist/components/snk-filter-field-search.d.ts +11 -0
- package/dist/components/snk-filter-field-search.js +205 -0
- package/dist/components/snk-grid2.js +2 -47
- package/dist/components/snk-simple-crud.d.ts +11 -0
- package/dist/components/snk-simple-crud.js +297 -0
- package/dist/components/taskbar-processor.js +47 -0
- package/dist/esm/{ConfigStorage-34caac5c.js → ConfigStorage-1b64cd96.js} +1 -1
- package/dist/esm/{DataFetcher-00309101.js → DataFetcher-5e99fa75.js} +3 -3
- package/dist/esm/{SnkFormConfigManager-d3a8aaf4.js → SnkFormConfigManager-0d9752c3.js} +2 -2
- package/dist/esm/{SnkMessageBuilder-9473ae03.js → SnkMessageBuilder-0e1ffd61.js} +8 -1
- package/dist/esm/{constants-fb9721cc.js → constants-9560e54f.js} +6 -1
- package/dist/esm/{form-config-fetcher-e58fc104.js → form-config-fetcher-677f86dd.js} +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/esm/sankhyablocks.js +1 -1
- package/dist/esm/snk-application.entry.js +4 -4
- package/dist/esm/snk-config-options.entry.js +1 -1
- package/dist/esm/snk-configurator.entry.js +1 -1
- package/dist/esm/snk-crud.entry.js +2 -2
- package/dist/esm/snk-data-exporter.entry.js +4 -4
- package/dist/esm/snk-data-unit.entry.js +2 -2
- package/dist/esm/snk-detail-view.entry.js +6 -6
- package/dist/esm/snk-field-config.entry.js +1 -1
- package/dist/esm/snk-filter-bar.entry.js +3 -3
- package/dist/esm/snk-filter-field-search.entry.js +181 -0
- package/dist/esm/snk-form-config.entry.js +3 -3
- package/dist/esm/snk-form.entry.js +4 -4
- package/dist/esm/snk-grid-config.entry.js +4 -4
- package/dist/esm/snk-grid.entry.js +3 -3
- package/dist/esm/{snk-guides-viewer-7c32399d.js → snk-guides-viewer-6bb54367.js} +3 -3
- package/dist/esm/snk-guides-viewer.entry.js +6 -6
- package/dist/esm/snk-select-box.entry.js +1 -1
- package/dist/esm/snk-simple-crud.entry.js +248 -0
- package/dist/esm/snk-tab-config.entry.js +1 -1
- package/dist/sankhyablocks/{p-9cff8df2.js → p-0c11c980.js} +1 -1
- package/dist/sankhyablocks/{p-52989652.entry.js → p-268ab84f.entry.js} +1 -1
- package/dist/sankhyablocks/{p-0fe01a57.entry.js → p-2a3996b0.entry.js} +1 -1
- package/dist/sankhyablocks/p-330813ff.entry.js +1 -0
- package/dist/sankhyablocks/{p-25341d65.js → p-3c4823fc.js} +1 -1
- package/dist/sankhyablocks/{p-44c23eb1.entry.js → p-4bd183ba.entry.js} +1 -1
- package/dist/sankhyablocks/{p-c4483cb2.js → p-5518d572.js} +1 -1
- package/dist/sankhyablocks/{p-e0416591.entry.js → p-7889d481.entry.js} +1 -1
- package/dist/sankhyablocks/p-79d22df0.entry.js +1 -0
- package/dist/sankhyablocks/{p-fc86a31e.entry.js → p-869d6616.entry.js} +1 -1
- package/dist/sankhyablocks/{p-99742169.entry.js → p-86efa17d.entry.js} +1 -1
- package/dist/sankhyablocks/{p-2980936b.entry.js → p-8b0e8deb.entry.js} +1 -1
- package/dist/sankhyablocks/{p-ca72cc38.js → p-9bf0319f.js} +1 -1
- package/dist/sankhyablocks/{p-83ddac9f.entry.js → p-9f00c061.entry.js} +1 -1
- package/dist/sankhyablocks/{p-43d8d388.entry.js → p-9f2306ba.entry.js} +1 -1
- package/dist/sankhyablocks/{p-9d4a25d2.js → p-9f98fc3c.js} +1 -1
- package/dist/sankhyablocks/{p-840494aa.entry.js → p-a056d61f.entry.js} +1 -1
- package/dist/sankhyablocks/{p-70037212.js → p-a6258eed.js} +1 -1
- package/dist/sankhyablocks/{p-de1ee26c.entry.js → p-b318cec6.entry.js} +1 -1
- package/dist/sankhyablocks/p-c0bfafcb.entry.js +1 -0
- package/dist/sankhyablocks/p-cf9d1b55.entry.js +1 -0
- package/dist/sankhyablocks/{p-8899a7ea.entry.js → p-d3199c18.entry.js} +1 -1
- package/dist/sankhyablocks/{p-9d62bbca.entry.js → p-dbeac5db.entry.js} +1 -1
- package/dist/sankhyablocks/{p-f5d3ecb3.js → p-ecbfbb4a.js} +1 -1
- package/dist/sankhyablocks/{p-6e6ef989.entry.js → p-f83e3219.entry.js} +1 -1
- package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
- package/dist/types/components/snk-filter-field-search/interfaces/index.d.ts +35 -0
- package/dist/types/components/snk-filter-field-search/snk-filter-field-search.d.ts +58 -0
- package/dist/types/components/snk-filter-field-search/subcomponents/index.d.ts +1 -0
- package/dist/types/components/snk-filter-field-search/subcomponents/list-item.d.ts +2 -0
- package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +41 -0
- package/dist/types/components.d.ts +81 -2
- package/dist/types/lib/dataUnit/InMemoryLoader.d.ts +21 -0
- package/dist/types/lib/message/resources/snk-filter-field-search.msg.d.ts +1 -0
- package/dist/types/lib/utils/constants.d.ts +4 -0
- package/package.json +2 -2
- package/react/components.d.ts +2 -0
- package/react/components.js +2 -0
- package/react/components.js.map +1 -1
- package/dist/sankhyablocks/p-4de78929.entry.js +0 -1
- 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-
|
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-
|
8
|
-
import './DataFetcher-
|
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-
|
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-
|
5
|
-
import './ConfigStorage-
|
6
|
-
import './form-config-fetcher-
|
7
|
-
import './DataFetcher-
|
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-
|
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-
|
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-
|
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)}";
|