@sankhyalabs/ezui 5.22.0-dev.37 → 5.22.0-dev.39
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/DataBinder-aff1dcc7.js +445 -0
- package/dist/cjs/FocusResolver-885f2173.js +35 -0
- package/dist/cjs/ez-actions-button.cjs.entry.js +1 -1
- package/dist/cjs/ez-alert-list.cjs.entry.js +1 -1
- package/dist/cjs/ez-alert.cjs.entry.js +1 -1
- package/dist/cjs/ez-application.cjs.entry.js +1 -1
- package/dist/cjs/ez-badge.cjs.entry.js +1 -1
- package/dist/cjs/ez-breadcrumb.cjs.entry.js +1 -1
- package/dist/cjs/ez-button.cjs.entry.js +1 -1
- package/dist/cjs/ez-calendar.cjs.entry.js +1 -1
- package/dist/cjs/ez-card-item_3.cjs.entry.js +9 -3
- package/dist/cjs/ez-chart.cjs.entry.js +1 -1
- package/dist/cjs/ez-check.cjs.entry.js +1 -1
- package/dist/cjs/ez-chip.cjs.entry.js +1 -1
- package/dist/cjs/ez-collapsible-box.cjs.entry.js +1 -1
- package/dist/cjs/ez-combo-box.cjs.entry.js +47 -11
- package/dist/cjs/ez-custom-form-input_2.cjs.entry.js +2 -2
- package/dist/cjs/ez-date-input.cjs.entry.js +9 -3
- package/dist/cjs/ez-date-time-input.cjs.entry.js +9 -3
- package/dist/cjs/ez-dialog.cjs.entry.js +10 -2
- package/dist/cjs/ez-dropdown_2.cjs.entry.js +1 -1
- package/dist/cjs/ez-file-item.cjs.entry.js +1 -1
- package/dist/cjs/ez-form-view.cjs.entry.js +1 -1
- package/dist/cjs/ez-form.cjs.entry.js +4 -325
- package/dist/cjs/ez-grid.cjs.entry.js +255 -63
- package/dist/cjs/ez-guide-navigator.cjs.entry.js +1 -1
- package/dist/cjs/ez-icon.cjs.entry.js +1 -1
- package/dist/cjs/ez-list.cjs.entry.js +1 -1
- package/dist/cjs/ez-loading-bar.cjs.entry.js +1 -1
- package/dist/cjs/ez-modal-container.cjs.entry.js +1 -1
- package/dist/cjs/ez-modal.cjs.entry.js +1 -1
- package/dist/cjs/ez-multi-selection-list.cjs.entry.js +1 -1
- package/dist/cjs/ez-number-input.cjs.entry.js +8 -1
- package/dist/cjs/ez-popover.cjs.entry.js +1 -1
- package/dist/cjs/ez-popup.cjs.entry.js +1 -1
- package/dist/cjs/ez-radio-button.cjs.entry.js +1 -1
- package/dist/cjs/ez-scroller_2.cjs.entry.js +1 -1
- package/dist/cjs/ez-search.cjs.entry.js +29 -13
- package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +1 -1
- package/dist/cjs/ez-split-button.cjs.entry.js +1 -1
- package/dist/cjs/ez-split-item.cjs.entry.js +1 -1
- package/dist/cjs/ez-split-panel.cjs.entry.js +1 -1
- package/dist/cjs/ez-tabselector.cjs.entry.js +1 -1
- package/dist/cjs/ez-text-area.cjs.entry.js +7 -1
- package/dist/cjs/ez-text-input.cjs.entry.js +8 -2
- package/dist/cjs/ez-time-input.cjs.entry.js +7 -1
- package/dist/cjs/ez-toast.cjs.entry.js +1 -1
- package/dist/cjs/ez-tree.cjs.entry.js +1 -1
- package/dist/cjs/ez-upload.cjs.entry.js +1 -1
- package/dist/cjs/ez-view-stack.cjs.entry.js +1 -1
- package/dist/cjs/ezui.cjs.js +2 -2
- package/dist/cjs/filter-column.cjs.entry.js +1 -1
- package/dist/cjs/{index-a7b0c73d.js → index-9e5554cb.js} +3 -0
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/collection/collection-manifest.json +1 -1
- package/dist/collection/components/ez-combo-box/ez-combo-box.js +75 -14
- package/dist/collection/components/ez-date-input/ez-date-input.js +35 -4
- package/dist/collection/components/ez-date-time-input/ez-date-time-input.js +35 -4
- package/dist/collection/components/ez-dialog/ez-dialog.js +9 -1
- package/dist/collection/components/ez-filter-input/ez-filter-input.js +35 -4
- package/dist/collection/components/ez-grid/controller/ag-grid/AgGridController.js +52 -14
- package/dist/collection/components/ez-grid/controller/ag-grid/DataSource.js +3 -0
- package/dist/collection/components/ez-grid/controller/ag-grid/GridEditionManager.js +166 -45
- package/dist/collection/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.js +7 -0
- package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/ComboBox.tpl.js +1 -0
- package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/DateInput.tpl.js +1 -0
- package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/NumberInput.tpl.js +1 -0
- package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/Search.tpl.js +1 -0
- package/dist/collection/components/ez-grid/controller/ag-grid/editor/templates/TextInput.tpl.js +4 -1
- package/dist/collection/components/ez-grid/ez-grid.js +83 -1
- package/dist/collection/components/ez-number-input/ez-number-input.js +25 -0
- package/dist/collection/components/ez-search/ez-search.js +55 -14
- package/dist/collection/components/ez-text-area/ez-text-area.js +24 -0
- package/dist/collection/components/ez-text-input/ez-text-input.css +14 -38
- package/dist/collection/components/ez-text-input/ez-text-input.js +24 -0
- package/dist/collection/components/ez-time-input/ez-time-input.js +24 -0
- package/dist/collection/utils/FocusResolver.js +31 -0
- package/dist/collection/utils/form/DataBinder.js +18 -3
- package/dist/custom-elements/index.js +443 -103
- package/dist/esm/DataBinder-bd240826.js +441 -0
- package/dist/esm/FocusResolver-1ccbf850.js +33 -0
- package/dist/esm/ez-actions-button.entry.js +1 -1
- package/dist/esm/ez-alert-list.entry.js +1 -1
- package/dist/esm/ez-alert.entry.js +1 -1
- package/dist/esm/ez-application.entry.js +1 -1
- package/dist/esm/ez-badge.entry.js +1 -1
- package/dist/esm/ez-breadcrumb.entry.js +1 -1
- package/dist/esm/ez-button.entry.js +1 -1
- package/dist/esm/ez-calendar.entry.js +1 -1
- package/dist/esm/ez-card-item_3.entry.js +9 -3
- package/dist/esm/ez-chart.entry.js +1 -1
- package/dist/esm/ez-check.entry.js +1 -1
- package/dist/esm/ez-chip.entry.js +1 -1
- package/dist/esm/ez-collapsible-box.entry.js +1 -1
- package/dist/esm/ez-combo-box.entry.js +48 -12
- package/dist/esm/ez-custom-form-input_2.entry.js +2 -2
- package/dist/esm/ez-date-input.entry.js +9 -3
- package/dist/esm/ez-date-time-input.entry.js +9 -3
- package/dist/esm/ez-dialog.entry.js +10 -2
- package/dist/esm/ez-dropdown_2.entry.js +1 -1
- package/dist/esm/ez-file-item.entry.js +1 -1
- package/dist/esm/ez-form-view.entry.js +1 -1
- package/dist/esm/ez-form.entry.js +3 -324
- package/dist/esm/ez-grid.entry.js +254 -62
- package/dist/esm/ez-guide-navigator.entry.js +1 -1
- package/dist/esm/ez-icon.entry.js +1 -1
- package/dist/esm/ez-list.entry.js +1 -1
- package/dist/esm/ez-loading-bar.entry.js +1 -1
- package/dist/esm/ez-modal-container.entry.js +1 -1
- package/dist/esm/ez-modal.entry.js +1 -1
- package/dist/esm/ez-multi-selection-list.entry.js +1 -1
- package/dist/esm/ez-number-input.entry.js +8 -1
- package/dist/esm/ez-popover.entry.js +1 -1
- package/dist/esm/ez-popup.entry.js +1 -1
- package/dist/esm/ez-radio-button.entry.js +1 -1
- package/dist/esm/ez-scroller_2.entry.js +1 -1
- package/dist/esm/ez-search.entry.js +29 -13
- package/dist/esm/ez-sidebar-navigator.entry.js +1 -1
- package/dist/esm/ez-split-button.entry.js +1 -1
- package/dist/esm/ez-split-item.entry.js +1 -1
- package/dist/esm/ez-split-panel.entry.js +1 -1
- package/dist/esm/ez-tabselector.entry.js +1 -1
- package/dist/esm/ez-text-area.entry.js +7 -1
- package/dist/esm/ez-text-input.entry.js +8 -2
- package/dist/esm/ez-time-input.entry.js +7 -1
- package/dist/esm/ez-toast.entry.js +1 -1
- package/dist/esm/ez-tree.entry.js +1 -1
- package/dist/esm/ez-upload.entry.js +1 -1
- package/dist/esm/ez-view-stack.entry.js +1 -1
- package/dist/esm/ezui.js +3 -3
- package/dist/esm/filter-column.entry.js +1 -1
- package/dist/esm/{index-baa5e267.js → index-5a720e56.js} +3 -1
- package/dist/esm/loader.js +3 -3
- package/dist/ezui/ezui.esm.js +1 -1
- package/dist/ezui/{p-44caad9a.entry.js → p-0378416a.entry.js} +1 -1
- package/dist/ezui/{p-5b205c80.entry.js → p-044d46d5.entry.js} +1 -1
- package/dist/ezui/p-076e868b.entry.js +1 -0
- package/dist/ezui/{p-b54e17d2.entry.js → p-0e1cc2d1.entry.js} +1 -1
- package/dist/ezui/{p-1285c902.entry.js → p-11b09aa1.entry.js} +1 -1
- package/dist/ezui/{p-77a4bd35.entry.js → p-11bfeca3.entry.js} +1 -1
- package/dist/ezui/p-16e21a40.entry.js +1 -0
- package/dist/ezui/{p-8888d9ed.entry.js → p-1b08bf3c.entry.js} +1 -1
- package/dist/ezui/p-2c3ac210.entry.js +1 -0
- package/dist/ezui/{p-abce5219.entry.js → p-2de9f0aa.entry.js} +1 -1
- package/dist/ezui/{p-baf80b13.entry.js → p-30951bd7.entry.js} +1 -1
- package/dist/ezui/{p-a2e5b8c3.entry.js → p-3b546374.entry.js} +1 -1
- package/dist/ezui/{p-37219d42.entry.js → p-3cc9b84a.entry.js} +1 -1
- package/dist/ezui/p-3d38bfea.entry.js +1 -0
- package/dist/ezui/{p-7bc07c31.entry.js → p-3f8c33e0.entry.js} +1 -1
- package/dist/ezui/{p-cdc472cc.entry.js → p-52100a6e.entry.js} +1 -1
- package/dist/ezui/{p-6d79930d.entry.js → p-554522db.entry.js} +1 -1
- package/dist/ezui/{p-1f50fa05.entry.js → p-6b51c9cc.entry.js} +1 -1
- package/dist/ezui/p-6bc25bc8.entry.js +1 -0
- package/dist/ezui/p-6ec40dec.entry.js +1 -0
- package/dist/ezui/{p-5ed81457.entry.js → p-6fc26622.entry.js} +1 -1
- package/dist/ezui/{p-f9e551de.entry.js → p-70f1c812.entry.js} +1 -1
- package/dist/ezui/{p-555c9018.entry.js → p-7567ccdd.entry.js} +1 -1
- package/dist/ezui/{p-bfad39eb.entry.js → p-7f5afb1f.entry.js} +1 -1
- package/dist/ezui/p-802dc63e.entry.js +1 -0
- package/dist/ezui/{p-1e7a8633.entry.js → p-81461d2f.entry.js} +1 -1
- package/dist/ezui/p-81f06699.js +1 -0
- package/dist/ezui/{p-8df1ca33.entry.js → p-82fa4b09.entry.js} +1 -1
- package/dist/ezui/{p-bcb53f27.entry.js → p-868b56f7.entry.js} +1 -1
- package/dist/ezui/{p-09de35a2.entry.js → p-91ccae0c.entry.js} +1 -1
- package/dist/ezui/{p-c0d9c4f8.entry.js → p-92748142.entry.js} +1 -1
- package/dist/ezui/p-940760bf.entry.js +1 -0
- package/dist/ezui/{p-c4320a39.entry.js → p-a563df31.entry.js} +1 -1
- package/dist/ezui/{p-990b4318.entry.js → p-a921e3e7.entry.js} +1 -1
- package/dist/ezui/{p-17be134a.entry.js → p-b2f6bc0a.entry.js} +1 -1
- package/dist/ezui/{p-c3045972.entry.js → p-b858fc6e.entry.js} +1 -1
- package/dist/ezui/p-be34c77f.entry.js +1 -0
- package/dist/ezui/{p-e347df9c.entry.js → p-bef7daac.entry.js} +1 -1
- package/dist/ezui/p-bfc30e61.entry.js +1 -0
- package/dist/ezui/p-bfc59380.entry.js +1 -0
- package/dist/ezui/{p-9f5fa3f9.entry.js → p-c2b20f78.entry.js} +1 -1
- package/dist/ezui/p-dc628ed3.js +1 -0
- package/dist/ezui/{p-a80b1287.entry.js → p-dfca5946.entry.js} +1 -1
- package/dist/ezui/{p-7fdd479f.entry.js → p-e18d9e6a.entry.js} +1 -1
- package/dist/ezui/{p-9d9ecb7c.entry.js → p-e3ec7422.entry.js} +1 -1
- package/dist/ezui/{p-23a36bb6.js → p-e4c7eb39.js} +2 -2
- package/dist/ezui/{p-0306dff7.entry.js → p-e6b38ade.entry.js} +1 -1
- package/dist/ezui/{p-90bcd2ba.entry.js → p-e7395eae.entry.js} +1 -1
- package/dist/ezui/{p-650e4b6d.entry.js → p-f1c2c19e.entry.js} +1 -1
- package/dist/ezui/{p-6e429cff.entry.js → p-fc194825.entry.js} +1 -1
- package/dist/ezui/{p-c3c3d640.entry.js → p-fc8b1807.entry.js} +2 -2
- package/dist/ezui/p-fe10f986.entry.js +1 -0
- package/dist/types/components/ez-combo-box/ez-combo-box.d.ts +7 -1
- package/dist/types/components/ez-date-input/ez-date-input.d.ts +6 -1
- package/dist/types/components/ez-date-time-input/ez-date-time-input.d.ts +6 -1
- package/dist/types/components/ez-dialog/ez-dialog.d.ts +2 -0
- package/dist/types/components/ez-filter-input/ez-filter-input.d.ts +6 -1
- package/dist/types/components/ez-grid/controller/EzGridController.d.ts +10 -0
- package/dist/types/components/ez-grid/controller/ag-grid/AgGridController.d.ts +4 -0
- package/dist/types/components/ez-grid/controller/ag-grid/GridEditionManager.d.ts +18 -6
- package/dist/types/components/ez-grid/controller/ag-grid/components/EzGridCustomCellEditor.d.ts +2 -0
- package/dist/types/components/ez-grid/controller/ag-grid/editor/IUICellEditor.d.ts +1 -0
- package/dist/types/components/ez-grid/ez-grid.d.ts +10 -0
- package/dist/types/components/ez-number-input/ez-number-input.d.ts +4 -0
- package/dist/types/components/ez-search/ez-search.d.ts +6 -1
- package/dist/types/components/ez-text-area/ez-text-area.d.ts +4 -0
- package/dist/types/components/ez-text-input/ez-text-input.d.ts +4 -0
- package/dist/types/components/ez-time-input/ez-time-input.d.ts +4 -0
- package/dist/types/components.d.ts +91 -6
- package/dist/types/utils/FocusResolver.d.ts +5 -0
- package/dist/types/utils/form/DataBinder.d.ts +3 -0
- package/package.json +1 -1
- package/dist/cjs/RecordValidationProcessor-10846595.js +0 -108
- package/dist/esm/RecordValidationProcessor-9c6cc267.js +0 -105
- package/dist/ezui/p-0f3b2e67.entry.js +0 -1
- package/dist/ezui/p-10820c20.entry.js +0 -1
- package/dist/ezui/p-49456b34.entry.js +0 -1
- package/dist/ezui/p-5a90d7d1.entry.js +0 -1
- package/dist/ezui/p-62732269.entry.js +0 -1
- package/dist/ezui/p-b3b94f72.entry.js +0 -1
- package/dist/ezui/p-b95632e8.entry.js +0 -1
- package/dist/ezui/p-bc2f844e.entry.js +0 -1
- package/dist/ezui/p-c25f0e92.entry.js +0 -1
- package/dist/ezui/p-d2c06f38.entry.js +0 -1
- package/dist/ezui/p-e85c48d7.entry.js +0 -1
- package/dist/ezui/p-f299c608.entry.js +0 -1
- package/dist/ezui/p-f42855b9.js +0 -1
|
@@ -0,0 +1,445 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const core = require('@sankhyalabs/core');
|
|
4
|
+
const ApplicationUtils = require('./ApplicationUtils-c9d1205c.js');
|
|
5
|
+
|
|
6
|
+
const buildFieldMetadata = (descriptor, config) => {
|
|
7
|
+
let { name, label, group } = Object.assign({}, config);
|
|
8
|
+
let { readOnly, required } = Object.assign({}, config);
|
|
9
|
+
let props;
|
|
10
|
+
let userInterface;
|
|
11
|
+
if (descriptor) {
|
|
12
|
+
label = label || descriptor.label;
|
|
13
|
+
name = name || descriptor.name;
|
|
14
|
+
required = descriptor.required || (config === null || config === void 0 ? void 0 : config.required);
|
|
15
|
+
readOnly = descriptor.readOnly || (config === null || config === void 0 ? void 0 : config.readOnly);
|
|
16
|
+
props = descriptor.properties;
|
|
17
|
+
userInterface = descriptor.userInterface;
|
|
18
|
+
}
|
|
19
|
+
return {
|
|
20
|
+
name, label, group,
|
|
21
|
+
readOnly, required,
|
|
22
|
+
props,
|
|
23
|
+
userInterface: userInterface || core.UserInterface.SHORTTEXT
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
class RecordValidationProcessor {
|
|
28
|
+
constructor(dataUnit, validationSource, validator) {
|
|
29
|
+
this._dataUnit = dataUnit;
|
|
30
|
+
this._validationSource = validationSource;
|
|
31
|
+
this._validator = validator;
|
|
32
|
+
}
|
|
33
|
+
validate(isSaving = true) {
|
|
34
|
+
return new Promise((accept, reject) => {
|
|
35
|
+
const records = this._dataUnit.getModifiedRecords();
|
|
36
|
+
for (let i = 0; i < records.length; i++) {
|
|
37
|
+
const record = records[i];
|
|
38
|
+
const invalidResults = [];
|
|
39
|
+
let validationResult = this.validateRequired(record);
|
|
40
|
+
if (validationResult && !validationResult.isValid) {
|
|
41
|
+
invalidResults.push(validationResult);
|
|
42
|
+
}
|
|
43
|
+
if (this._validator) {
|
|
44
|
+
validationResult = this._validator.validateRecord(record);
|
|
45
|
+
if (validationResult && !validationResult.isValid) {
|
|
46
|
+
invalidResults.push(validationResult);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
if (invalidResults.length > 0) {
|
|
50
|
+
if (!isSaving && invalidResults[0].invalidFields.length > 0) {
|
|
51
|
+
this._validationSource.markAsInvalid(invalidResults[0].invalidFields[0], record.__record__id__);
|
|
52
|
+
reject();
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
this.processValidationResult(invalidResults, record.__record__id__);
|
|
56
|
+
reject();
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return accept();
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
validateRequired(record) {
|
|
64
|
+
const requiredFields = this._validationSource.getRequiredFields();
|
|
65
|
+
const invalidFields = [];
|
|
66
|
+
new Set(requiredFields).forEach(field => {
|
|
67
|
+
const value = record[field];
|
|
68
|
+
if (value == undefined || value === "") {
|
|
69
|
+
const errorMessage = this._validationSource.getMessageForField(field, record.__record__id__);
|
|
70
|
+
if (errorMessage) {
|
|
71
|
+
invalidFields.push({ name: field, message: errorMessage });
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
invalidFields.push({ name: field, message: "Essa informação é obrigatória" });
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
if (invalidFields.length > 0) {
|
|
79
|
+
return { isValid: false, invalidFields, infoMessage: "Há pelo menos um campo obrigatório não preenchido." };
|
|
80
|
+
}
|
|
81
|
+
return undefined;
|
|
82
|
+
}
|
|
83
|
+
processValidationResult(validationResult, recordId) {
|
|
84
|
+
validationResult.forEach(invalidResult => {
|
|
85
|
+
const invalidFields = invalidResult.invalidFields;
|
|
86
|
+
this._dataUnit.savingCanceled(invalidFields, recordId);
|
|
87
|
+
if (invalidFields) {
|
|
88
|
+
invalidFields.forEach(field => {
|
|
89
|
+
this.markAsInvalid(field, recordId);
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
if (invalidResult.infoMessage) {
|
|
93
|
+
ApplicationUtils.ApplicationUtils.info(invalidResult.infoMessage);
|
|
94
|
+
}
|
|
95
|
+
if (invalidResult.errorMessage) {
|
|
96
|
+
const { errorTitle, errorMessage } = invalidResult;
|
|
97
|
+
ApplicationUtils.ApplicationUtils.error(errorTitle, errorMessage);
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
markAsInvalid(field, recordId) {
|
|
102
|
+
this._dataUnit.setInvalidField(field.name, field.message, recordId);
|
|
103
|
+
this._validationSource.markAsInvalid(field, recordId);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
class DataBinder {
|
|
108
|
+
constructor(dataUnit) {
|
|
109
|
+
this.onDataUnitEvent = (action) => {
|
|
110
|
+
var _a, _b;
|
|
111
|
+
switch (action.type) {
|
|
112
|
+
case core.Action.DATA_LOADED:
|
|
113
|
+
case core.Action.DATA_SAVED:
|
|
114
|
+
case core.Action.RECORDS_REMOVED:
|
|
115
|
+
case core.Action.RECORDS_ADDED:
|
|
116
|
+
case core.Action.RECORDS_COPIED:
|
|
117
|
+
case core.Action.EDITION_CANCELED:
|
|
118
|
+
case core.Action.SELECTION_CHANGED:
|
|
119
|
+
case core.Action.NEXT_SELECTED:
|
|
120
|
+
case core.Action.PREVIOUS_SELECTED:
|
|
121
|
+
this.clearInvalid();
|
|
122
|
+
case core.Action.DATA_CHANGED:
|
|
123
|
+
case core.Action.CHANGE_UNDONE:
|
|
124
|
+
case core.Action.CHANGE_REDONE:
|
|
125
|
+
case core.Action.RECORD_LOADED:
|
|
126
|
+
(_a = this._fields) === null || _a === void 0 ? void 0 : _a.forEach(field => {
|
|
127
|
+
this.updateValue(field.fieldName, field.field);
|
|
128
|
+
});
|
|
129
|
+
this.clearFieldError(Object.keys(action.payload)[0]);
|
|
130
|
+
break;
|
|
131
|
+
case core.Action.FIELD_INVALIDATED:
|
|
132
|
+
(_b = this._fields) === null || _b === void 0 ? void 0 : _b.forEach(field => {
|
|
133
|
+
this.updateErrorMessage(field.fieldName, field.field);
|
|
134
|
+
});
|
|
135
|
+
break;
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
this._uuid = core.StringUtils.generateUUID();
|
|
139
|
+
this._fields = new Map();
|
|
140
|
+
this._dataUnit = dataUnit;
|
|
141
|
+
this.applyDefaultValues();
|
|
142
|
+
this._dataUnit.subscribe(this.onDataUnitEvent);
|
|
143
|
+
this._dataUnit.addInterceptor(this);
|
|
144
|
+
this.setContextDataBinder(dataUnit);
|
|
145
|
+
}
|
|
146
|
+
get dataBinderId() {
|
|
147
|
+
return this._uuid;
|
|
148
|
+
}
|
|
149
|
+
setContextDataBinder(dataUnit) {
|
|
150
|
+
const dataBindersByDataUnit = core.ApplicationContext.getContextValue("__DATABINDER_BY_DATAUNIT__") || new Map();
|
|
151
|
+
const dataBinders = [...(dataBindersByDataUnit.get(dataUnit.dataUnitId) || []), this];
|
|
152
|
+
dataBindersByDataUnit.set(dataUnit.dataUnitId, dataBinders);
|
|
153
|
+
core.ApplicationContext.setContextValue("__DATABINDER_BY_DATAUNIT__", dataBindersByDataUnit);
|
|
154
|
+
}
|
|
155
|
+
applyDefaultValues() {
|
|
156
|
+
const recordIds = (this._dataUnit.getAddedRecords() || []).map(r => r.__record__id__);
|
|
157
|
+
if (recordIds.length > 0) {
|
|
158
|
+
const defaultValues = this.getDefaultValues();
|
|
159
|
+
if (defaultValues) {
|
|
160
|
+
Object.keys(defaultValues).forEach(field => {
|
|
161
|
+
this._dataUnit.setFieldValue(field, defaultValues[field], recordIds);
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
bind(fields, currentContextName, formMetadata, recordsValidator) {
|
|
167
|
+
fields.forEach(fieldElement => {
|
|
168
|
+
const { fieldName, contextName } = fieldElement.dataset;
|
|
169
|
+
if (contextName == undefined || contextName === currentContextName) {
|
|
170
|
+
this.updateBind(fieldName, fieldElement);
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
this._formMetadata = formMetadata;
|
|
174
|
+
this._recordValidatorProcessor = new RecordValidationProcessor(this._dataUnit, {
|
|
175
|
+
getRequiredFields: () => this.getFormRequiredFields(),
|
|
176
|
+
markAsInvalid: field => this.markInvalid(field),
|
|
177
|
+
getMessageForField: field => this.getErrorMessage(field),
|
|
178
|
+
}, recordsValidator);
|
|
179
|
+
}
|
|
180
|
+
getFormRequiredFields() {
|
|
181
|
+
return this._formMetadata.getRequiredFields();
|
|
182
|
+
}
|
|
183
|
+
disconnectDataUnit() {
|
|
184
|
+
const dataBindersByDataUnit = core.ApplicationContext.getContextValue("__DATABINDER_BY_DATAUNIT__") || new Map();
|
|
185
|
+
const dataBinders = dataBindersByDataUnit.get(this._dataUnit.dataUnitId);
|
|
186
|
+
const dataBindersFiltered = dataBinders.filter((dataBinder) => dataBinder.dataBinderId !== this.dataBinderId);
|
|
187
|
+
dataBindersByDataUnit.set(this._dataUnit.dataUnitId, dataBindersFiltered);
|
|
188
|
+
core.ApplicationContext.setContextValue("__DATABINDER_BY_DATAUNIT__", dataBindersByDataUnit);
|
|
189
|
+
}
|
|
190
|
+
onDisconnectedCallback() {
|
|
191
|
+
this._dataUnit.unsubscribe(this.onDataUnitEvent);
|
|
192
|
+
this._dataUnit.removeInterceptor(this);
|
|
193
|
+
this.disconnectDataUnit();
|
|
194
|
+
}
|
|
195
|
+
getCurrentRecordId() {
|
|
196
|
+
const record = this._dataUnit.getSelectedRecord();
|
|
197
|
+
return record === null || record === void 0 ? void 0 : record.__record__id__;
|
|
198
|
+
}
|
|
199
|
+
markInvalid(field) {
|
|
200
|
+
if (this._fields.has(field.name)) {
|
|
201
|
+
const fieldElement = this._fields.get(field.name).field;
|
|
202
|
+
this.updateErrorMessage(field.name, fieldElement, field.message);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
setFocus(fieldName) {
|
|
206
|
+
if (!this._fields.has(fieldName)) {
|
|
207
|
+
return;
|
|
208
|
+
}
|
|
209
|
+
const fieldElement = this._fields.get(fieldName).field;
|
|
210
|
+
if (typeof fieldElement["setFocus"] != "function") {
|
|
211
|
+
return;
|
|
212
|
+
}
|
|
213
|
+
fieldElement["setFocus"]();
|
|
214
|
+
}
|
|
215
|
+
clearInvalid(recordId) {
|
|
216
|
+
this._dataUnit.clearInvalid(recordId);
|
|
217
|
+
this._fields.forEach(fieldBinder => {
|
|
218
|
+
const fieldElement = fieldBinder.field;
|
|
219
|
+
fieldElement["errorMessage"] = "";
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
clearFieldError(fieldName) {
|
|
223
|
+
var _a;
|
|
224
|
+
const field = (_a = this._fields.get(fieldName)) === null || _a === void 0 ? void 0 : _a.field;
|
|
225
|
+
if (field["errorMessage"]) {
|
|
226
|
+
field["errorMessage"] = "";
|
|
227
|
+
this._dataUnit.clearInvalid(this.getCurrentRecordId(), fieldName);
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
updateValue(fieldName, field) {
|
|
231
|
+
const bind = this._fields.get(fieldName);
|
|
232
|
+
try {
|
|
233
|
+
if (bind) {
|
|
234
|
+
bind.listen = false;
|
|
235
|
+
}
|
|
236
|
+
field["value"] = this._dataUnit.getFieldValue(fieldName);
|
|
237
|
+
this.updateErrorMessage(fieldName, field);
|
|
238
|
+
}
|
|
239
|
+
finally {
|
|
240
|
+
if (bind) {
|
|
241
|
+
bind.listen = true;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
validate() {
|
|
246
|
+
return this._recordValidatorProcessor.validate();
|
|
247
|
+
}
|
|
248
|
+
static async validateByDataunit(dataUnit) {
|
|
249
|
+
try {
|
|
250
|
+
const dataBinders = this.getDataBindersByDataUnit(dataUnit);
|
|
251
|
+
await Promise.all(dataBinders.map((dataBinder) => dataBinder.validate()));
|
|
252
|
+
return true;
|
|
253
|
+
}
|
|
254
|
+
catch (_a) {
|
|
255
|
+
return false;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
static getDataBindersByDataUnit(dataUnit) {
|
|
259
|
+
const dataBindersByDataUnit = core.ApplicationContext.getContextValue("__DATABINDER_BY_DATAUNIT__");
|
|
260
|
+
return dataBindersByDataUnit.get(dataUnit.dataUnitId) || [];
|
|
261
|
+
}
|
|
262
|
+
updateErrorMessage(fieldName, field, message) {
|
|
263
|
+
if (message == undefined) {
|
|
264
|
+
message = this._dataUnit.getInvalidMessage(this.getCurrentRecordId(), fieldName);
|
|
265
|
+
}
|
|
266
|
+
if (!field["errorMessage"]) {
|
|
267
|
+
field["errorMessage"] = message;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
getErrorMessage(fieldName) {
|
|
271
|
+
if (this._fields.has(fieldName)) {
|
|
272
|
+
const fieldElement = this._fields.get(fieldName).field;
|
|
273
|
+
return fieldElement["errorMessage"];
|
|
274
|
+
}
|
|
275
|
+
return undefined;
|
|
276
|
+
}
|
|
277
|
+
updateBind(fieldName, field) {
|
|
278
|
+
const oldBind = this._fields.get(fieldName);
|
|
279
|
+
if (oldBind) {
|
|
280
|
+
oldBind.destroy();
|
|
281
|
+
}
|
|
282
|
+
this.bindSearchOptionsLoader(fieldName, field);
|
|
283
|
+
field["value"] = this._dataUnit.getFieldValue(fieldName);
|
|
284
|
+
this.updateErrorMessage(fieldName, field);
|
|
285
|
+
this._fields.set(fieldName, Bind.create(fieldName, field, (fieldName, waitingChange) => this.changeStarted(fieldName, waitingChange), (fieldName) => this.cancelWaitingChange(fieldName), (fieldName, newValue) => this.setFieldValue(fieldName, newValue)));
|
|
286
|
+
this.applyEzUploadContext(fieldName, field);
|
|
287
|
+
}
|
|
288
|
+
changeStarted(fieldName, waitingChange) {
|
|
289
|
+
/**
|
|
290
|
+
* se o waitingChange não é blocante, add um event listener pra
|
|
291
|
+
* fazer o accept da promise
|
|
292
|
+
*
|
|
293
|
+
* se não tiver promise no waitingChange, eu crio uma e resolvo no bind
|
|
294
|
+
*
|
|
295
|
+
*
|
|
296
|
+
*/
|
|
297
|
+
if (this._dataUnit.records.length === 0) {
|
|
298
|
+
this._dataUnit.addRecord();
|
|
299
|
+
}
|
|
300
|
+
if (!waitingChange.blocking && waitingChange.promise == undefined) {
|
|
301
|
+
const bind = this._fields.get(fieldName);
|
|
302
|
+
if (bind) {
|
|
303
|
+
waitingChange.promise = new Promise((resolve, reject) => {
|
|
304
|
+
bind.waitingChangePromiseResolve = resolve;
|
|
305
|
+
bind.waitingChangePromiseReject = reject;
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
this._dataUnit.startChange(fieldName, waitingChange);
|
|
310
|
+
}
|
|
311
|
+
cancelWaitingChange(fieldName) {
|
|
312
|
+
if (this._dataUnit.waitingForChange(fieldName)) {
|
|
313
|
+
this._dataUnit.cancelWaitingChange(fieldName);
|
|
314
|
+
const bind = this._fields.get(fieldName);
|
|
315
|
+
if (bind) {
|
|
316
|
+
bind.rejectWaitingChange(new core.WaitingChangeException("Change canceled", fieldName));
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
setFieldValue(fieldName, newValue) {
|
|
321
|
+
if (this._dataUnit.records.length === 0) {
|
|
322
|
+
this._dataUnit.addRecord();
|
|
323
|
+
}
|
|
324
|
+
this._dataUnit.clearInvalid(this.getCurrentRecordId(), fieldName);
|
|
325
|
+
const record = this._dataUnit.getSelectedRecord();
|
|
326
|
+
this._dataUnit.setFieldValue(fieldName, newValue, record ? [record.__record__id__] : undefined);
|
|
327
|
+
if (this._dataUnit.waitingForChange(fieldName)) {
|
|
328
|
+
const bind = this._fields.get(fieldName);
|
|
329
|
+
if (bind) {
|
|
330
|
+
bind.acceptWaitingChange();
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
bindSearchOptionsLoader(fieldName, field) {
|
|
335
|
+
if (field.nodeName === "EZ-SEARCH" && field["optionLoader"] == undefined) {
|
|
336
|
+
const loader = core.ApplicationContext.getContextValue("__EZUI__SEARCH__OPTION__LOADER__");
|
|
337
|
+
if (loader) {
|
|
338
|
+
field["optionLoader"] = (arg) => {
|
|
339
|
+
return loader(arg, fieldName, this._dataUnit);
|
|
340
|
+
};
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
applyEzUploadContext(fieldName, field) {
|
|
345
|
+
var _a, _b;
|
|
346
|
+
if (field.nodeName === "EZ-UPLOAD") {
|
|
347
|
+
field["urlUpload"] = core.ApplicationContext.getContextValue("__EZUI__UPLOAD__ADD__URL__");
|
|
348
|
+
field["urlDelete"] = core.ApplicationContext.getContextValue("__EZUI__UPLOAD__DEL__URL__");
|
|
349
|
+
const descriptor = this._dataUnit.getField(fieldName);
|
|
350
|
+
const destination = (_a = descriptor.properties) === null || _a === void 0 ? void 0 : _a.DESTINATION;
|
|
351
|
+
if (destination) {
|
|
352
|
+
field["requestHeaders"] = { XTRAINF: `{"destination": "${destination}"}` };
|
|
353
|
+
}
|
|
354
|
+
field["maxFiles"] = ((_b = descriptor.properties) === null || _b === void 0 ? void 0 : _b.MAX_FILES) || 0;
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
interceptAction(action) {
|
|
358
|
+
if (action.type === core.Action.RECORDS_COPIED) {
|
|
359
|
+
const cleanFields = this._formMetadata.getCleanOnCopyFields();
|
|
360
|
+
if (cleanFields) {
|
|
361
|
+
const records = action.payload;
|
|
362
|
+
return new core.DataUnitAction(core.Action.RECORDS_COPIED, records.map(record => {
|
|
363
|
+
const newRecord = Object.assign({}, record);
|
|
364
|
+
cleanFields.forEach(fieldName => delete newRecord[fieldName]);
|
|
365
|
+
return newRecord;
|
|
366
|
+
}));
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
if (action.type === core.Action.SAVING_DATA) {
|
|
370
|
+
return new Promise((resolve) => {
|
|
371
|
+
this.validate()
|
|
372
|
+
.then(() => resolve(action))
|
|
373
|
+
.catch(() => { });
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
if (action.type === core.Action.RECORDS_ADDED) {
|
|
377
|
+
const defaultValues = this.getDefaultValues();
|
|
378
|
+
if (defaultValues) {
|
|
379
|
+
const records = action.payload;
|
|
380
|
+
return new core.DataUnitAction(core.Action.RECORDS_ADDED, records.map(record => {
|
|
381
|
+
return Object.assign(Object.assign({}, record), defaultValues);
|
|
382
|
+
}));
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
return action;
|
|
386
|
+
}
|
|
387
|
+
getDefaultValues() {
|
|
388
|
+
var _a;
|
|
389
|
+
const rawDefaultValues = (_a = this._formMetadata) === null || _a === void 0 ? void 0 : _a.getDefaultValues();
|
|
390
|
+
if (rawDefaultValues) {
|
|
391
|
+
const defaultValues = {};
|
|
392
|
+
for (const field in rawDefaultValues) {
|
|
393
|
+
defaultValues[field] = this._dataUnit.valueFromString(field, rawDefaultValues[field]);
|
|
394
|
+
}
|
|
395
|
+
return defaultValues;
|
|
396
|
+
}
|
|
397
|
+
return undefined;
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
class Bind {
|
|
401
|
+
constructor() {
|
|
402
|
+
this.listen = true;
|
|
403
|
+
this.startChangeEventName = "ezStartChange";
|
|
404
|
+
this.cancelWaitingChangeEventName = "ezCancelWaitingChange";
|
|
405
|
+
this.changeEventName = "ezChange";
|
|
406
|
+
}
|
|
407
|
+
destroy() {
|
|
408
|
+
this.field.removeEventListener(this.startChangeEventName, this.startChangeListener);
|
|
409
|
+
this.field.removeEventListener(this.cancelWaitingChangeEventName, this.cancelWaitingChangeListener);
|
|
410
|
+
this.field.removeEventListener(this.changeEventName, this.changeListener);
|
|
411
|
+
}
|
|
412
|
+
acceptWaitingChange() {
|
|
413
|
+
if (this.waitingChangePromiseResolve) {
|
|
414
|
+
this.waitingChangePromiseResolve();
|
|
415
|
+
this.waitingChangePromiseReject = undefined;
|
|
416
|
+
this.waitingChangePromiseResolve = undefined;
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
rejectWaitingChange(reason) {
|
|
420
|
+
if (this.waitingChangePromiseReject) {
|
|
421
|
+
this.waitingChangePromiseReject(reason);
|
|
422
|
+
this.waitingChangePromiseReject = undefined;
|
|
423
|
+
this.waitingChangePromiseResolve = undefined;
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
static create(fieldName, field, startChangeCallback, cancelWaitingChangeCallback, changeCallback) {
|
|
427
|
+
const b = new Bind();
|
|
428
|
+
b.field = field;
|
|
429
|
+
b.fieldName = fieldName;
|
|
430
|
+
b.startChangeListener = (evt) => { if (b.listen)
|
|
431
|
+
startChangeCallback(fieldName, evt.detail); };
|
|
432
|
+
b.field.addEventListener(b.startChangeEventName, b.startChangeListener);
|
|
433
|
+
b.cancelWaitingChangeListener = () => { if (b.listen)
|
|
434
|
+
cancelWaitingChangeCallback(fieldName); };
|
|
435
|
+
b.field.addEventListener(b.cancelWaitingChangeEventName, b.cancelWaitingChangeListener);
|
|
436
|
+
b.changeListener = (evt) => { if (b.listen)
|
|
437
|
+
changeCallback(fieldName, evt.detail); };
|
|
438
|
+
b.field.addEventListener(b.changeEventName, b.changeListener);
|
|
439
|
+
return b;
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
exports.DataBinder = DataBinder;
|
|
444
|
+
exports.RecordValidationProcessor = RecordValidationProcessor;
|
|
445
|
+
exports.buildFieldMetadata = buildFieldMetadata;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
class FocusResolver {
|
|
4
|
+
static resolveFocus(element, selectText = true) {
|
|
5
|
+
var _a;
|
|
6
|
+
if (!element)
|
|
7
|
+
return;
|
|
8
|
+
(_a = element.focus) === null || _a === void 0 ? void 0 : _a.call(element);
|
|
9
|
+
if (element.setFocus) {
|
|
10
|
+
element.setFocus({ selectText });
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
this.resolveFocusOnChild(element, selectText);
|
|
14
|
+
}
|
|
15
|
+
static resolveFocusOnChild(element, selectText = true) {
|
|
16
|
+
var _a, _b;
|
|
17
|
+
if (this.isGridCell(element) && element.firstElementChild) {
|
|
18
|
+
this.resolveFocusOnChild(element.firstElementChild);
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
if (!element || !element.classList.contains('hydrated'))
|
|
22
|
+
return;
|
|
23
|
+
const firstChild = element.firstElementChild;
|
|
24
|
+
if (!(firstChild === null || firstChild === void 0 ? void 0 : firstChild.focus) && !(firstChild === null || firstChild === void 0 ? void 0 : firstChild.setFocus))
|
|
25
|
+
return;
|
|
26
|
+
(_a = firstChild === null || firstChild === void 0 ? void 0 : firstChild.focus) === null || _a === void 0 ? void 0 : _a.call(firstChild);
|
|
27
|
+
(_b = firstChild === null || firstChild === void 0 ? void 0 : firstChild.setFocus) === null || _b === void 0 ? void 0 : _b.call(firstChild, { selectText });
|
|
28
|
+
}
|
|
29
|
+
static isGridCell(element) {
|
|
30
|
+
var _a;
|
|
31
|
+
return ((_a = element === null || element === void 0 ? void 0 : element.getAttribute) === null || _a === void 0 ? void 0 : _a.call(element, "role")) === 'gridcell';
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
exports.FocusResolver = FocusResolver;
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-9e5554cb.js');
|
|
6
6
|
const core = require('@sankhyalabs/core');
|
|
7
7
|
require('./ApplicationUtils-c9d1205c.js');
|
|
8
8
|
const CSSVarsUtils = require('./CSSVarsUtils-10c9d5b4.js');
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-9e5554cb.js');
|
|
6
6
|
const core = require('@sankhyalabs/core');
|
|
7
7
|
|
|
8
8
|
const ezAlertListCss = ":host {\n display: flex;\n\n /* Alert List */\n \n /*@doc Define a largura da lista minimizado */\n --ez-alert-list__container--width: 680px;\n /*@doc Define a altura da lista minimizado */\n --ez-alert-list__container--height: 220px;\n \n /*@doc Define a largura da lista maximizada */\n --ez-alert-list__container--width--expanded: 920px;\n /*@doc Define a altura da lista maximizada */\n --ez-alert-list__container--height--expanded: 540px;\n\n /* Title */\n /*@doc Define a fonte do título do componente */\n --ez-alert-list__title--font-family: var(--font-pattern, \"Roboto\");\n /*@doc Define o tamanho da fonte do título do popup.*/\n --ez-alert-list__title--font-size: var(--title--large, 20px);\n /*@doc Define a cor da fonte do título do popup.*/\n --ez-alert-list__title--color: var(--title--primary, #2b3a54);\n /*@doc Define o peso da fonte do título do popup.*/\n --ez-alert-list__title--font-weight: var(--text-weight--extra-large, 700);\n\n /* @doc Define a borda inferior do item da lista. */\n --ez-list__item--border-bottom: var(--border--small, 1px solid);\n\n /* @doc Define a cor da borda inferior do item da lista. */\n --ez-list__item--border-bottom-color: var(--color--strokes, #DCE0E8);\n\n /* @doc Define o tipo da quebra de linha do item da lista. */\n --ez-list__item--white-space: break-space;\n}\n\n.alert-list__content {\n display: flex;\n flex-direction: column;\n \n gap: var(--space--xs);\n margin: var(--space--large, 24px);\n width: 100%;\n}\n\n.alert-list__container {\n z-index: var(--ez-elevation--8, 8);\n display: flex;\n height: var(--ez-alert-list__container--height);\n width: var(--ez-alert-list__container--width);\n border-radius: var(--border--radius-medium);\n background-color: var(--background--xlight);\n box-shadow: var(--shadow--medium);\n\n &.expanded {\n height: var(--ez-alert-list__container--height--expanded);\n width: var(--ez-alert-list__container--width--expanded);\n }\n\n @media (max-height: 640px) {\n max-height: calc(100vh - var(--space--3xl));\n } \n}\n\n.alert-list__header {\n width: 100%;\n display: flex;\n align-items: center;\n justify-content: space-between;\n}\n\n.alert-list__title {\n font-family: var(--ez-alert-list__title--font-family);\n font-size: var(--ez-alert-list__title--font-size);\n font-weight: var(--ez-alert-list__title--font-weight);\n color: var(--ez-alert-list__title--color);\n}\n\n.alert-list__header__buttons {\n display: flex;\n gap: var(--space--xs);\n}\n\n.alert-list__expandable-content {\n overflow-y: auto;\n scrollbar-width: thin;\n}\n\n";
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-9e5554cb.js');
|
|
6
6
|
const core = require('@sankhyalabs/core');
|
|
7
7
|
|
|
8
8
|
const ezAlertCss = ":host{--ez-alert-alert-container--padding-up-down:var(--space--small, 6px);--ez-alert-alert-container--padding-right-left:var(--space--medium, 12px);--ez-alert-alert-container--gap:var(--space--medium, 12px);--ez-alert-alert-container--border-radius:var(--border--radius-medium, 12px);--ez-alert-alert-container--font-color-warn:var(--color--alert-warning-900, #8C6B00);--ez-alert-alert-container--icon-warn:var(--color--alert-warning-900, #8C6B00);--ez-alert-alert-container--background-color-warn:var(--color--alert-warning-200, #FFF7D5);--ez-alert-alert-container--font-color-critical:var(--color--alert-error, #BD0025);--ez-alert-alert-container--icon-critical:var(--color--alert-error, #BD0025);--ez-alert-alert-container--background-color-critical:var(--color--alert-error-200, #F7E0E5);--ez-alert-alert-container--font-color-success:var(--color--alert-success, #157A00);--ez-alert-alert-container--icon-success:var(--color--alert-success, #157A00);--ez-alert-alert-container--background-color-success:var(--color--alert-success-200, #E7F6E0);font-size:var(--text--small, 12px);font-family:var(--font-pattern, \"Roboto\");width:100%;hyphens:auto;display:block}.alert-container{display:flex;align-items:center;gap:var(--ez-alert-alert-container--gap);padding:var(--ez-alert-alert-container--padding-up-down) var(--ez-alert-alert-container--padding-right-left);border-radius:var(--ez-alert-alert-container--border-radius)}.warn{background-color:var(--ez-alert-alert-container--background-color-warn);color:var(--ez-alert-alert-container--font-color-warn)}.critical{background-color:var(--ez-alert-alert-container--background-color-critical);color:var(--ez-alert-alert-container--font-color-critical)}.success{background-color:var(--ez-alert-alert-container--background-color-success);color:var(--ez-alert-alert-container--font-color-success)}ez-icon{--ez-icon--color:inherit}.alert-container__icon-warn{--ez-icon--color:var(--ez-alert-alert-container--icon-warn)}.alert-container__icon-critical{--ez-icon--color:var(--ez-alert-alert-container--icon-critical)}.alert-container__icon-success{--ez-icon--color:var(--ez-alert-alert-container--icon-success)}";
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-9e5554cb.js');
|
|
6
6
|
const core = require('@sankhyalabs/core');
|
|
7
7
|
|
|
8
8
|
const ezButtonCss = ":host{--ez-button--min-width:100px;--ez-button--width:'auto';--ez-button--height:42px;--ez-button__icon--width:18px;--ez-button__inline__icon--padding:12px;--ez-button--padding-top:0px;--ez-button--padding-bottom:0px;--ez-button--padding-right:var(--space--large, 24px);--ez-button--padding-left:var(--space--large, 24px);--ez-button--color:var(--title--primary, #2B3A54);--ez-button--font-size:var(--text--medium, 14px);--ez-button--font-family:var(--font-pattern, Arial);--ez-button--font-weight:var(--text-weight--large);--ez-button--background-color:var(--background--light, #ffffff);--ez-button--border-radius:var(--border--radius-large, 24px);--ez-button--border:1px solid var(--color--strokes);--ez-button--justify-content:center;--ez-button--hover-color:var(--color--primary-600, #007a5a);--ez-button--hover--background-color:var(--background--light, #ffffff);--ez-button--disabled-color:var(--text--disable);--ez-button--disabled--background-color:var(--color--disable-secondary);--ez-button--focus--border:var(--border--medium, 2px solid) var(--color--primary-300);--ez-button--focus--box-shadow:var(--color--primary-300) 0px 0px 0px 2px;--ez-button--active-color:var(--color--primary-700);--ez-button--active--background-color:var(--background--strong);--ez-button--link-color:var(--color--primary, '#008561');--ez-button--link--hover-color:var(--color--primary-700, '#1C1D22');--ez-button--link-disabled-color:var(--text--secondary, #a2abb9);--ez-button--link--small--font-size:var(--text--small, 12px);--ez-button--link--medium--font-size:var(--text--medium, 14px);--ez-button--link--large--font-size:var(--text--large, 16px)}ez-icon{--ez-icon--color:inherit}button{position:relative;display:flex;align-items:center;margin:0;cursor:pointer;transition:background-color 0.2s linear;white-space:nowrap;min-width:var(--ez-button--min-width);width:var(--ez-button--width);height:var(--ez-button--height);font-family:var(--ez-button--font-family);font-size:var(--ez-button--font-size);font-weight:var(--ez-button--font-weight);padding:var(--ez-button--padding-top) var(--ez-button--padding-right) var(--ez-button--padding-bottom) var(--ez-button--padding-left);border-radius:var(--ez-button--border-radius);background-color:var(--ez-button--background-color);color:var(--ez-button--color);fill:var(--ez-button--color);border:var(--ez-button--border);justify-content:var(--ez-button--justify-content)}button:focus{outline:var(--ez-button--focus--border);box-shadow:none}button:hover{outline:none;background-color:var(--ez-button--hover--background-color);color:var(--ez-button--hover-color);fill:var(--ez-button--hover-color);--ez-icon--color:var(--ez-button--hover-color)}button:active{outline:none;box-shadow:none;background-color:var(--ez-button--active--background-color);color:var(--ez-button--active-color);fill:var(--ez-button--active-color);--ez-icon--color:var(--ez-button--active-color)}button:disabled{background-color:var(--ez-button--disabled--background-color);color:var(--ez-button--disabled-color);fill:var(--ez-button--disabled-color);--ez-icon--color:var(--ez-button--disabled-color);cursor:no-drop}.x-small{height:28px;--ez-button--font-size:var(--text--small, 12px)}.small{height:32px;--ez-button--font-size:var(--text--small, 12px)}.medium{height:42px}.large{height:46px}.btn-icon{padding:0px}.btn-icon--medium{width:42px;min-width:42px;height:42px}.btn-icon--x-small{width:28px;min-width:28px;height:28px}.btn-icon--small{width:32px;min-width:32px;height:32px}.btn-icon--large{width:46px;min-width:46px;height:46px}.label-icon{display:flex;flex-direction:column;align-items:center;color:var(--ez-button--color)}.label-icon:hover{color:var(--ez-button--hover-color);fill:var(--ez-button--hover-color);--ez-icon--color:var(--ez-button--hover-color)}.label-icon:active{color:var(--ez-button--active-color);fill:var(--ez-button--active-color);--ez-icon--color:var(--ez-button--active-color)}.label-icon label{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;font-family:var(--ez-button--font-family);font-size:var(--ez-button--font-size);font-weight:var(--ez-button--font-weight);user-select:none}button:disabled+label{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;font-family:var(--ez-button--font-family);font-size:var(--ez-button--font-size);font-weight:var(--ez-button--font-weight);color:var(--ez-button--disabled-color);cursor:no-drop}div.label-icon{cursor:pointer}div.label-icon,button:disabled{cursor:no-drop}a{font-family:var(--ez-button--font-family);font-weight:var(--ez-button--font-weight);color:var(--ez-button--link-color);cursor:pointer;display:flex;align-items:center;justify-content:center;}a:hover{color:var(--ez-button--link--hover-color)}a.small{font-size:var(--ez-button--link--small--font-size);line-height:var(--ez-button--link--small--font-size)}a.medium{font-size:var(--ez-button--link--medium--font-size);line-height:var(--ez-button--link--medium--font-size)}a.large{font-size:var(--ez-button--link--large--font-size);line-height:var(--ez-button--link--large--font-size)}a.disabled{color:var(--ez-button--link-disabled-color);cursor:not-allowed}";
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-9e5554cb.js');
|
|
6
6
|
const core = require('@sankhyalabs/core');
|
|
7
7
|
|
|
8
8
|
const ezCalendarCss = ":host{--ez-calendar--font-family:var(--font-pattern, Arial);--ez-calendar--color:var(--title--primary, #626e82);--ez-calendar--text-shadow:var(--text-shadow, 0 0 0 #353535, 0 0 1px transparent);--ez-calendar__body--background-color:var(--background--xlight, #FFF);--ez-calendar__time--background-color:var(--background--xlight, #FAFAFA);--ez-calendar__body--padding:var(--space--medium, 12px) var(--space--small, 6px);--ez-calendar__body--border-radius:var(--border--radius-medium, 12px);--ez-calendar__body--shadow:var(--shadow, 0px 0px 16px 0px #000);--ez-container--z-index:var(--more-visible, 2);--ez-calendar__header-line--stroke:1px;--ez-calendar__header-line--color:var(--color--strokes, #C0C0C0);--ez-calendar__nav-btn--fill:var(--text--primary, #008561);--ez-calendar__nav-btn--hover--fill:var(--color--primary, #350404);--ez-calendar__nav-btn--width:10px;--ez-calendar__nav-btn--height:16px;--ez-calendar__nav-btn--previous-image: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>');--ez-calendar__nav-btn--next-image: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>');--ez-calendar__cell--margin:0px 1.5px;--ez-calendar__cell--width:var(--space--large, 24px);--ez-calendar__cell--padding:1.5px 0px;--ez-calendar__cell--border-radius:var(--border--radius-small, 6px);--ez-calendar__cell--over--background-color:var(--color--primary, #E2F4EF);--ez-calendar__cell--over--color:var(--color--primary-300, #008561);--ez-calendar__cell--outset--color:var(--color--disable-primary, #E5EAF0);--ez-calendar__cell--selected--background-color:var(--color--primary, #008561);--ez-calendar__cell--selected--color:var(--color--inverted, #FFF);--ez-calendar__btn-today--color:var(--color--primary);--ez-calendar__btn-today--hover--background-color:var(--color--primary-300, #E2F4EF);--ez-calendar__btn-today--border-radius:var(--border--radius-small, 6px);position:relative;display:flex;user-select:none}.calendar__container{display:flex;z-index:var(--more-visible, 2)}.calendar{display:flex;flex-direction:column;z-index:var(--more-visible, 2);background-color:var(--ez-calendar__body--background-color);padding:var(--ez-calendar__body--padding);border-radius:var(--ez-calendar__body--border-radius);box-shadow:var(--ez-calendar__body--shadow)}.calendar__header{display:flex;justify-content:space-between;padding-bottom:var(--space--small, 6px);margin:0px var(--space--, 12px) var(--space--small, 6px) var(--space--, 12px);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow);border-bottom:solid var(--ez-calendar__header-line--stroke) var(--ez-calendar__header-line--color)}.calendar__btn-next,.calendar__btn-previous{outline:none;border:none;background-color:unset;cursor:pointer;padding:0px}.calendar__btn-next::after,.calendar__btn-previous::after{content:'';display:flex;background-color:var(--ez-calendar__nav-btn--fill);width:var(--ez-calendar__nav-btn--width);height:var(--ez-calendar__nav-btn--height)}.calendar__btn-previous::after{-webkit-mask-image:var(--ez-calendar__nav-btn--previous-image);mask-image:var(--ez-calendar__nav-btn--previous-image)}.calendar__btn-next::after{-webkit-mask-image:var(--ez-calendar__nav-btn--next-image);mask-image:var(--ez-calendar__nav-btn--next-image)}.calendar__btn-next:hover::after,.calendar__btn-previous:hover::after{background-color:var(--ez-calendar__nav-btn--hover--fill)}.calendar__lbl-month{font-weight:var(--text-weight--extra-large, 700);font-size:var(--title--small, 14px);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow)}.calendar__line{display:flex;padding:0px;margin:0px}.calendar__cell{display:flex;justify-content:center;align-content:center;cursor:pointer;font-size:var(--text--extra-small, 10px);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow);padding:var(--ez-calendar__cell--padding);margin:var(--ez-calendar__cell--margin);min-width:var(--ez-calendar__cell--width);border-radius:var(--ez-calendar__cell--border-radius)}.calendar__cell:hover{background-color:var(--ez-calendar__cell--over--background-color);color:var(--ez-calendar__cell--over--color)}.calendar__cell--secondary{color:var(--ez-calendar__cell--outset--color)}.calendar__cell--unselectable:hover{background-color:unset;border-radius:unset;cursor:unset;color:var(--ez-calendar--color)}.calendar__cell--unselectable{font-weight:var(--text-weight--large, 600);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow)}.calendar__cell--selected,.calendar__cell--selected:hover{background-color:var(--ez-calendar__cell--selected--background-color);color:var(--ez-calendar__cell--selected--color)}.calendar__footer{display:flex;flex-direction:column}.calendar__btn-today{border:none;background-color:unset;cursor:pointer;padding:0px;font-weight:var(--text-weight--large, 600);font-size:var(--title--extra-small, 12px);font-family:var(--ez-calendar--font-family);text-shadow:var(--ez-calendar--text-shadow);color:var(--ez-calendar__btn-today--color);border-radius:var(--ez-calendar__btn-today--border-radius)}.calendar__btn-today:hover{background-color:var(--ez-calendar__btn-today--hover--background-color)}section{display:flex}.calendar-time{margin-left:-10px;display:flex;flex-direction:column;padding:12px 0px 0px 10px;background-color:var(--ez-calendar__time--background-color);border-top-right-radius:var(--ez-calendar__body--border-radius);border-bottom-right-radius:var(--ez-calendar__body--border-radius);box-shadow:var(--ez-calendar__body--shadow)}.calendar__column{height:136px;padding:0px;margin:0px;overflow:auto;scrollbar-width:none}.calendar__column::-webkit-scrollbar{width:0px;max-width:0px;min-width:0px}.calendar-time__header{display:flex;justify-content:space-between;padding-left:var(--space--small, 6px);padding-right:var(--space--small, 6px);padding-bottom:var(--space--small, 6px);margin:0px var(--space--, 12px) var(--space--small, 6px) var(--space--, 12px);font-weight:var(--text-weight--extra-large, 700);font-size:var(--title--small, 14px);text-shadow:var(--ez-calendar--text-shadow);border-bottom:solid var(--ez-calendar__header-line--stroke) var(--ez-calendar__header-line--color);font-family:var(--ez-calendar--font-family);color:var(--ez-calendar--color);text-shadow:var(--ez-calendar--text-shadow)}.separatorTime{color:#A2ABB9;padding:0px 1px;line-height:16px;font-size:17px;font-weight:normal}.endHidden{-webkit-mask-image:linear-gradient(180deg, #000 calc(100% - 48px), transparent 100%)}.calendar__column .calendar__cell{margin:0px;padding:1.5px 1.5px}";
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-9e5554cb.js');
|
|
6
6
|
const core = require('@sankhyalabs/core');
|
|
7
7
|
const CSSVarsUtils = require('./CSSVarsUtils-10c9d5b4.js');
|
|
8
8
|
|
|
@@ -86,6 +86,7 @@ const EzFilterInput = class {
|
|
|
86
86
|
this.mode = "regular";
|
|
87
87
|
this.asyncSearch = false;
|
|
88
88
|
this.canShowError = true;
|
|
89
|
+
this.autoFocus = false;
|
|
89
90
|
}
|
|
90
91
|
observeLabel() {
|
|
91
92
|
if (this._textInput) {
|
|
@@ -106,8 +107,8 @@ const EzFilterInput = class {
|
|
|
106
107
|
/**
|
|
107
108
|
* Aplica o foco no campo.
|
|
108
109
|
*/
|
|
109
|
-
async setFocus() {
|
|
110
|
-
this._textInput.setFocus();
|
|
110
|
+
async setFocus(options) {
|
|
111
|
+
this._textInput.setFocus(options);
|
|
111
112
|
}
|
|
112
113
|
/**
|
|
113
114
|
* Remove o foco do campo.
|
|
@@ -160,6 +161,11 @@ const EzFilterInput = class {
|
|
|
160
161
|
}
|
|
161
162
|
componentDidLoad() {
|
|
162
163
|
CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this._elem, this._textInput);
|
|
164
|
+
if (this.autoFocus) {
|
|
165
|
+
requestAnimationFrame(() => {
|
|
166
|
+
this.setFocus({ selectText: true });
|
|
167
|
+
});
|
|
168
|
+
}
|
|
163
169
|
}
|
|
164
170
|
render() {
|
|
165
171
|
core.ElementIDUtils.addIDInfoIfNotExists(this._elem, 'input');
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-9e5554cb.js');
|
|
6
6
|
const core = require('@sankhyalabs/core');
|
|
7
7
|
|
|
8
8
|
const ezChipCss = ":host{--ez-label-chip--height:30px;--ez-label-chip__label--font-size:var(--text--medium, 14px);--ez-label-chip__label--font-family:var(--font-pattern, Arial);--ez-label-chip__label--font-weight:var(--text-weight--medium, 400);--ez-label-chip__label--space--medium:var(--space--medium, 12px);--ez-label-chip__label--title--primary:var(--title--primary, #2B3A54);--ez-label-chip__label--text--primary:var(--text--primary, #626e82);--ez-label-chip__label__container--border-radius:var(--border--radius-large, 24px);--ez-label-chip__label__container--border:1px solid;--ez-label-chip__label__container--border-color-strokes:var(--color--strokes, #DCE0E8);--ez-label-chip__label__container--color-primary:var(--color--primary, #008561);--ez-label-chip__label__container-color--disable-secondary:var(--color--disable-secondary, #F2F5F8);--ez-label-chip__label__container--background-color:var(--color--primary-300);--ez-label-chip__label__container--border-color:#0085610F;--ez-label-chip__label__container--default--border-color--active:var(--color--primary, #007a5a);--ez-label-chip__label__container--default--background-color--hover:var(--color--primary-300, #f2faf8);--ez-label-chip__label__container--default--color--hover:var(--color--primary, #f2faf8);--ez-label-chip__label__container--text--disabled:var(--text--disable, #AFB6C0);--ez-label-chip__label__container--default--border-color--active:var(--color--primary)}.lbl{display:flex;white-space:nowrap;align-items:center;cursor:pointer;user-select:none;color:var(--ez-label-chip__label--title--primary);height:var(--ez-label-chip--height);font-family:var(--ez-label-chip__label--font-family);font-size:var(--ez-label-chip__label--font-size);font-weight:var(--ez-label-chip__label--font-weight)}.lbl--active{color:var(--ez-label-chip__label__container--default--color--hover)}.lbl--disabled{color:var(--ez-label-chip__label__container--text--disabled)}.label__container{cursor:pointer;width:max-content;display:flex;flex-wrap:wrap;align-items:center;background-color:#FFFFFF;color:var(--ez-label-chip__label--text--primary);fill:var(--ez-label-chip__label--text--primary);--ez-icon--color:var(--ez-label-chip__label--text--primary);border:var(--ez-label-chip__label__container--border);border-radius:var(--ez-label-chip__label__container--border-radius);border-color:var(--ez-label-chip__label__container--border-color-strokes);padding-right:var(--ez-label-chip__label--space--medium);padding-left:var(--ez-label-chip__label--space--medium);outline-color:var(--ez-label-chip__label__container--default--border-color--active)}.label__content{display:flex;align-items:center;flex-wrap:wrap;--ez-icon--color:var(--ez-label-chip__label--text--primary)}.label__container--disabled{cursor:default;border-color:var(--ez-label-chip__label__container-color--disable-secondary);background-color:var(--ez-label-chip__label__container-color--disable-secondary);fill:var(--ez-label-chip__label__container--text--disabled);color:var(--ez-label-chip__label__container--text--disabled);--ez-icon--color:var(--ez-label-chip__label__container--text--disabled)}.label__container--active{border-color:var(--ez-label-chip__label__container--default--background-color--hover);background-color:var(--ez-label-chip__label__container--default--background-color--hover);color:var(--ez-label-chip__label__container--default--color--hover);fill:var(--ez-label-chip__label__container--default--color--hover);--ez-icon--color:var(--ez-label-chip__label__container--default--color--hover)}.label__container:hover{border-color:var(--ez-label-chip__label__container--default--border-color--active)}.label__container:focus{outline:var(--border--medium) var(--ez-label-chip__label__container--default--border-color--active)}.label__container--disabled:hover{cursor:default;border:var(--ez-label-chip__label__container--border);border-color:var(--ez-label-chip__label__container-color--disable-secondary);background-color:var(--ez-label-chip__label__container-color--disable-secondary);fill:var(--ez-label-chip__label__container--text--disabled);color:var(--ez-label-chip__label__container--text--disabled);--ez-icon--color:var(--ez-label-chip__label__container--text--disabled)}.label__content__icon{display:flex;cursor:pointer;color:var(--ez-label-chip__label--text--primary);fill:var(--ez-label-chip__label--text--primary);--ez-icon--color:var(--ez-label-chip__label--text--primary)}.label__container--row-reverse{flex-direction:row-reverse}.label__container .btn-close{padding:0px 0px 0px 8px}.label__container--row-reverse .btn-close{padding:0px 8px 0px 0px}.cursor-disable{cursor:default}ez-icon{--ez-icon--color:inherit}";
|