@talxis/base-controls 1.2408.1 → 1.2408.2
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/components/DateTime/DateTime.js +133 -1
- package/dist/components/DateTime/DateTime.js.map +1 -0
- package/dist/components/DateTime/components/Calendar.js +63 -1
- package/dist/components/DateTime/components/Calendar.js.map +1 -0
- package/dist/components/DateTime/hooks/useDateTime.js +137 -1
- package/dist/components/DateTime/hooks/useDateTime.js.map +1 -0
- package/dist/components/DateTime/index.js +3 -1
- package/dist/components/DateTime/index.js.map +1 -0
- package/dist/components/DateTime/styles.js +37 -1
- package/dist/components/DateTime/styles.js.map +1 -0
- package/dist/components/DateTime/translations.js +23 -1
- package/dist/components/DateTime/translations.js.map +1 -0
- package/dist/components/Decimal/Decimal.js +200 -1
- package/dist/components/Decimal/Decimal.js.map +1 -0
- package/dist/components/Decimal/components/ArrowButtons.js +38 -1
- package/dist/components/Decimal/components/ArrowButtons.js.map +1 -0
- package/dist/components/Decimal/components/styles.js +26 -1
- package/dist/components/Decimal/components/styles.js.map +1 -0
- package/dist/components/Decimal/index.js +2 -1
- package/dist/components/Decimal/index.js.map +1 -0
- package/dist/components/Decimal/interfaces.d.ts +1 -1
- package/dist/components/Duration/Duration.js +132 -1
- package/dist/components/Duration/Duration.js.map +1 -0
- package/dist/components/Duration/durationOptions.d.ts +2 -0
- package/dist/components/Duration/durationOptions.js +27 -0
- package/dist/components/Duration/durationOptions.js.map +1 -0
- package/dist/components/Duration/index.js +2 -1
- package/dist/components/Duration/index.js.map +1 -0
- package/dist/components/Duration/translations.js +31 -1
- package/dist/components/Duration/translations.js.map +1 -0
- package/dist/components/Grid/Grid.js +30 -1
- package/dist/components/Grid/Grid.js.map +1 -0
- package/dist/components/Grid/GridContext.js +6 -1
- package/dist/components/Grid/GridContext.js.map +1 -0
- package/dist/components/Grid/constants.js +4 -1
- package/dist/components/Grid/constants.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/AgGrid.js +85 -1
- package/dist/components/Grid/core/components/AgGrid/AgGrid.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.js +12 -1
- package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/styles.js +23 -1
- package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/styles.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/components/LoadingOverlay/LoadingOverlay.js +11 -1
- package/dist/components/Grid/core/components/AgGrid/components/LoadingOverlay/LoadingOverlay.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/components/LoadingOverlay/styles.js +82 -1
- package/dist/components/Grid/core/components/AgGrid/components/LoadingOverlay/styles.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/controllers/useAgGridController.js +169 -1
- package/dist/components/Grid/core/components/AgGrid/controllers/useAgGridController.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/model/AgGrid.js +116 -1
- package/dist/components/Grid/core/components/AgGrid/model/AgGrid.js.map +1 -0
- package/dist/components/Grid/core/components/AgGrid/styles.js +91 -1
- package/dist/components/Grid/core/components/AgGrid/styles.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/Commands/Commands.js +29 -1
- package/dist/components/Grid/core/components/Cell/Commands/Commands.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/Commands/Icon.js +14 -1
- package/dist/components/Grid/core/components/Cell/Commands/Icon.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/Commands/styles.js +54 -1
- package/dist/components/Grid/core/components/Cell/Commands/styles.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/Commands/useCommands.js +52 -1
- package/dist/components/Grid/core/components/Cell/Commands/useCommands.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/EditableCell/EditableCell.js +148 -1
- package/dist/components/Grid/core/components/Cell/EditableCell/EditableCell.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/ReadOnlyCell.js +139 -1
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/ReadOnlyCell.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/ReadOnlyOptionSet/ReadOnlyOptionSet.js +49 -1
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/ReadOnlyOptionSet/ReadOnlyOptionSet.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/ReadOnlyOptionSet/styles.js +27 -1
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/ReadOnlyOptionSet/styles.js.map +1 -0
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/styles.js +58 -1
- package/dist/components/Grid/core/components/Cell/ReadOnlyCell/styles.js.map +1 -0
- package/dist/components/Grid/core/components/ColumnHeader/ColumnHeader.js +60 -1
- package/dist/components/Grid/core/components/ColumnHeader/ColumnHeader.js.map +1 -0
- package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.js +26 -1
- package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.js.map +1 -0
- package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/styles.js +19 -1
- package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/styles.js.map +1 -0
- package/dist/components/Grid/core/components/ColumnHeader/styles.js +44 -1
- package/dist/components/Grid/core/components/ColumnHeader/styles.js.map +1 -0
- package/dist/components/Grid/core/components/Component/Component.js +53 -1
- package/dist/components/Grid/core/components/Component/Component.js.map +1 -0
- package/dist/components/Grid/core/components/Component/controller/useComponentController.js +31 -1
- package/dist/components/Grid/core/components/Component/controller/useComponentController.js.map +1 -0
- package/dist/components/Grid/core/components/Component/model/Component.js +225 -1
- package/dist/components/Grid/core/components/Component/model/Component.js.map +1 -0
- package/dist/components/Grid/core/components/Dialog/Constants.js +9 -1
- package/dist/components/Grid/core/components/Dialog/Constants.js.map +1 -0
- package/dist/components/Grid/core/components/Dialog/Styles.js +61 -1
- package/dist/components/Grid/core/components/Dialog/Styles.js.map +1 -0
- package/dist/components/Grid/core/components/Dialog/index.js +16 -1
- package/dist/components/Grid/core/components/Dialog/index.js.map +1 -0
- package/dist/components/Grid/core/components/Dialog/interfaces/index.js +1 -0
- package/dist/components/Grid/core/components/Dialog/interfaces/index.js.map +1 -0
- package/dist/components/Grid/core/components/Save/Save.js +47 -1
- package/dist/components/Grid/core/components/Save/Save.js.map +1 -0
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.js +39 -1
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.js.map +1 -0
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/RecordGrids/RecordGrids.js +136 -1
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/RecordGrids/RecordGrids.js.map +1 -0
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/RecordGrids/styles.js +54 -1
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/RecordGrids/styles.js.map +1 -0
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.js +37 -1
- package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.js.map +1 -0
- package/dist/components/Grid/core/components/Save/hooks/useSave.js +45 -1
- package/dist/components/Grid/core/components/Save/hooks/useSave.js.map +1 -0
- package/dist/components/Grid/core/components/Save/styles.js +44 -1
- package/dist/components/Grid/core/components/Save/styles.js.map +1 -0
- package/dist/components/Grid/core/controllers/useGridController.js +39 -1
- package/dist/components/Grid/core/controllers/useGridController.js.map +1 -0
- package/dist/components/Grid/core/enums/ConditionOperator.js +50 -1
- package/dist/components/Grid/core/enums/ConditionOperator.js.map +1 -0
- package/dist/components/Grid/core/enums/DataType.js +30 -1
- package/dist/components/Grid/core/enums/DataType.js.map +1 -0
- package/dist/components/Grid/core/hooks/useGridInstance.js +9 -1
- package/dist/components/Grid/core/hooks/useGridInstance.js.map +1 -0
- package/dist/components/Grid/core/hooks/useRefreshCallback.js +20 -1
- package/dist/components/Grid/core/hooks/useRefreshCallback.js.map +1 -0
- package/dist/components/Grid/core/hooks/useRerender.js +13 -1
- package/dist/components/Grid/core/hooks/useRerender.js.map +1 -0
- package/dist/components/Grid/core/model/Grid.js +249 -1
- package/dist/components/Grid/core/model/Grid.js.map +1 -0
- package/dist/components/Grid/core/model/GridDependency.js +28 -1
- package/dist/components/Grid/core/model/GridDependency.js.map +1 -0
- package/dist/components/Grid/core/model/Metadata.js +22 -1
- package/dist/components/Grid/core/model/Metadata.js.map +1 -0
- package/dist/components/Grid/core/services/RecordUpdateService/controllers/useRecordUpdateServiceController.js +25 -1
- package/dist/components/Grid/core/services/RecordUpdateService/controllers/useRecordUpdateServiceController.js.map +1 -0
- package/dist/components/Grid/core/services/RecordUpdateService/model/RecordUpdateService.js +190 -1
- package/dist/components/Grid/core/services/RecordUpdateService/model/RecordUpdateService.js.map +1 -0
- package/dist/components/Grid/filtering/components/FilterCallout/FilterCallout.js +50 -1
- package/dist/components/Grid/filtering/components/FilterCallout/FilterCallout.js.map +1 -0
- package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.js +58 -1
- package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.js.map +1 -0
- package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.js +52 -1
- package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.js.map +1 -0
- package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.js +125 -1
- package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.js.map +1 -0
- package/dist/components/Grid/filtering/components/FilterCallout/styles.js +40 -1
- package/dist/components/Grid/filtering/components/FilterCallout/styles.js.map +1 -0
- package/dist/components/Grid/filtering/constants.js +51 -1
- package/dist/components/Grid/filtering/constants.js.map +1 -0
- package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.js +42 -1
- package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.js.map +1 -0
- package/dist/components/Grid/filtering/model/Condition.js +297 -1
- package/dist/components/Grid/filtering/model/Condition.js.map +1 -0
- package/dist/components/Grid/filtering/model/Filtering.js +78 -1
- package/dist/components/Grid/filtering/model/Filtering.js.map +1 -0
- package/dist/components/Grid/filtering/utils/FilteringUtilts.js +195 -1
- package/dist/components/Grid/filtering/utils/FilteringUtilts.js.map +1 -0
- package/dist/components/Grid/index.js +2 -1
- package/dist/components/Grid/index.js.map +1 -0
- package/dist/components/Grid/paging/components/Paging/Paging.js +63 -1
- package/dist/components/Grid/paging/components/Paging/Paging.js.map +1 -0
- package/dist/components/Grid/paging/components/Paging/styles.js +41 -1
- package/dist/components/Grid/paging/components/Paging/styles.js.map +1 -0
- package/dist/components/Grid/paging/controllers/usePagingController.js +23 -1
- package/dist/components/Grid/paging/controllers/usePagingController.js.map +1 -0
- package/dist/components/Grid/paging/model/Paging.js +56 -1
- package/dist/components/Grid/paging/model/Paging.js.map +1 -0
- package/dist/components/Grid/selection/controllers/useSelectionController.js +17 -1
- package/dist/components/Grid/selection/controllers/useSelectionController.js.map +1 -0
- package/dist/components/Grid/selection/model/Selection.js +69 -1
- package/dist/components/Grid/selection/model/Selection.js.map +1 -0
- package/dist/components/Grid/sorting/Sorting.js +33 -1
- package/dist/components/Grid/sorting/Sorting.js.map +1 -0
- package/dist/components/Grid/sorting/components/SortingContextualMenu/SortingContextualMenu.js +120 -1
- package/dist/components/Grid/sorting/components/SortingContextualMenu/SortingContextualMenu.js.map +1 -0
- package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.js +15 -1
- package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.js.map +1 -0
- package/dist/components/Grid/sorting/controllers/useColumnSortingController.js +21 -1
- package/dist/components/Grid/sorting/controllers/useColumnSortingController.js.map +1 -0
- package/dist/components/Grid/translations.js +81 -1
- package/dist/components/Grid/translations.js.map +1 -0
- package/dist/components/Grid/validation/controllers/useRecordValidationController.js +25 -1
- package/dist/components/Grid/validation/controllers/useRecordValidationController.js.map +1 -0
- package/dist/components/Grid/validation/model/ColumnValidation.js +84 -1
- package/dist/components/Grid/validation/model/ColumnValidation.js.map +1 -0
- package/dist/components/Lookup/Lookup.js +201 -1
- package/dist/components/Lookup/Lookup.js.map +1 -0
- package/dist/components/Lookup/components/RecordCreator.js +37 -1
- package/dist/components/Lookup/components/RecordCreator.js.map +1 -0
- package/dist/components/Lookup/components/TargetSelector.js +19 -1
- package/dist/components/Lookup/components/TargetSelector.js.map +1 -0
- package/dist/components/Lookup/hooks/useFetchXml.js +27 -1
- package/dist/components/Lookup/hooks/useFetchXml.js.map +1 -0
- package/dist/components/Lookup/hooks/useLoadedEntities.js +20 -1
- package/dist/components/Lookup/hooks/useLoadedEntities.js.map +1 -0
- package/dist/components/Lookup/hooks/useLookup.js +111 -1
- package/dist/components/Lookup/hooks/useLookup.js.map +1 -0
- package/dist/components/Lookup/index.js +3 -1
- package/dist/components/Lookup/index.js.map +1 -0
- package/dist/components/Lookup/styles.js +98 -1
- package/dist/components/Lookup/styles.js.map +1 -0
- package/dist/components/Lookup/translations.js +33 -1
- package/dist/components/Lookup/translations.js.map +1 -0
- package/dist/components/MultiSelectOptionSet/MultiSelectOptionSet.js +74 -1
- package/dist/components/MultiSelectOptionSet/MultiSelectOptionSet.js.map +1 -0
- package/dist/components/MultiSelectOptionSet/index.js +2 -1
- package/dist/components/MultiSelectOptionSet/index.js.map +1 -0
- package/dist/components/OptionSet/OptionSet.js +61 -1
- package/dist/components/OptionSet/OptionSet.js.map +1 -0
- package/dist/components/OptionSet/index.js +2 -1
- package/dist/components/OptionSet/index.js.map +1 -0
- package/dist/components/TextField/TextField.js +113 -1
- package/dist/components/TextField/TextField.js.map +1 -0
- package/dist/components/TextField/index.js +2 -1
- package/dist/components/TextField/index.js.map +1 -0
- package/dist/components/TwoOptions/TwoOptions.js +36 -1
- package/dist/components/TwoOptions/TwoOptions.js.map +1 -0
- package/dist/components/TwoOptions/index.js +2 -1
- package/dist/components/TwoOptions/index.js.map +1 -0
- package/dist/constants.js +35 -1
- package/dist/constants.js.map +1 -0
- package/dist/hooks/index.js +7 -1
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useControl.js +95 -1
- package/dist/hooks/useControl.js.map +1 -0
- package/dist/hooks/useControlSizing.js +15 -1
- package/dist/hooks/useControlSizing.js.map +1 -0
- package/dist/hooks/useControlTheme.js +9 -1
- package/dist/hooks/useControlTheme.js.map +1 -0
- package/dist/hooks/useFocusIn.js +33 -1
- package/dist/hooks/useFocusIn.js.map +1 -0
- package/dist/hooks/useInputBasedControl.js +38 -1
- package/dist/hooks/useInputBasedControl.js.map +1 -0
- package/dist/hooks/useMouseOver.js +23 -1
- package/dist/hooks/useMouseOver.js.map +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +19 -1
- package/dist/index.js.map +1 -0
- package/dist/interfaces/index.js +1 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/utils/Numeral.js +64 -1
- package/dist/utils/Numeral.js.map +1 -0
- package/dist/utils/Theme.js +72 -1
- package/dist/utils/Theme.js.map +1 -0
- package/dist/utils/index.js +3 -1
- package/dist/utils/index.js.map +1 -0
- package/package.json +4 -2
- package/dist/Grid-b7e6190d.js +0 -1
- package/dist/components/DateTime/interfaces.js +0 -1
- package/dist/components/Decimal/interfaces.js +0 -1
- package/dist/components/Duration/interfaces.js +0 -1
- package/dist/components/Grid/core/interfaces/IGridColumn.js +0 -1
- package/dist/components/Grid/core/interfaces/IGridContext.js +0 -1
- package/dist/components/Grid/interfaces.js +0 -1
- package/dist/components/Lookup/interfaces.js +0 -1
- package/dist/components/MultiSelectOptionSet/interfaces.js +0 -1
- package/dist/components/OptionSet/interfaces.js +0 -1
- package/dist/components/TextField/interfaces.js +0 -1
- package/dist/components/TwoOptions/interfaces.js +0 -1
- package/dist/interfaces/context.js +0 -1
- package/dist/interfaces/parameters.js +0 -1
- package/dist/interfaces/property.js +0 -1
- package/dist/interfaces/theme.js +0 -1
|
@@ -1 +1,190 @@
|
|
|
1
|
-
import
|
|
1
|
+
import equal from 'fast-deep-equal/es6';
|
|
2
|
+
import { cloneDeep } from 'lodash';
|
|
3
|
+
import numeral from 'numeral';
|
|
4
|
+
import { Numeral } from '../../../../../../utils/Numeral.js';
|
|
5
|
+
import { ColumnValidation } from '../../../../validation/model/ColumnValidation.js';
|
|
6
|
+
import { DataType } from '../../../enums/DataType.js';
|
|
7
|
+
import { GridDependency } from '../../../model/GridDependency.js';
|
|
8
|
+
|
|
9
|
+
class RecordUpdateService extends GridDependency {
|
|
10
|
+
constructor(grid) {
|
|
11
|
+
super(grid);
|
|
12
|
+
this._updatedRecords = new Map();
|
|
13
|
+
this._internalRecordMap = new Map();
|
|
14
|
+
const updatedRecordsFromState = this._grid.state?.['__updatedRecords'];
|
|
15
|
+
//@ts-ignore - getRecordId could be undefined if it comes from serialized state
|
|
16
|
+
if (updatedRecordsFromState && updatedRecordsFromState?.length > 0 && updatedRecordsFromState[0].getRecordId) {
|
|
17
|
+
this._updatedRecords = new Map(updatedRecordsFromState.map(x => {
|
|
18
|
+
const originalClear = x.clear;
|
|
19
|
+
const originalSetValue = x.setValue;
|
|
20
|
+
const originalSave = x.save;
|
|
21
|
+
x.clear = () => {
|
|
22
|
+
this._updatedRecords.delete(x.getRecordId());
|
|
23
|
+
originalClear();
|
|
24
|
+
this._pcfContext.factory.requestRender();
|
|
25
|
+
};
|
|
26
|
+
x.save = async () => {
|
|
27
|
+
const result = await originalSave();
|
|
28
|
+
if (result) {
|
|
29
|
+
this._updatedRecords.delete(x.getRecordId());
|
|
30
|
+
}
|
|
31
|
+
[...x.columns.values()].map(col => {
|
|
32
|
+
this._internalRecordMap.get(x.getRecordId())?.setValue(col.name, x.getValue(col.name));
|
|
33
|
+
});
|
|
34
|
+
return result;
|
|
35
|
+
};
|
|
36
|
+
x.setValue = (columnName, value) => {
|
|
37
|
+
originalSetValue(columnName, value);
|
|
38
|
+
this._pcfContext.factory.requestRender();
|
|
39
|
+
};
|
|
40
|
+
return [x.getRecordId(), x];
|
|
41
|
+
}));
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
get updatedRecords() {
|
|
45
|
+
if (this._isReadOnlyChangeEditor() && this._updatedRecords.size === 0) {
|
|
46
|
+
const record = this._grid.records[0];
|
|
47
|
+
for (const column of this._grid.columns) {
|
|
48
|
+
this.record(record.getRecordId()).setValue(column.key, record.getValue(column.key), true);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return [...this._updatedRecords.values()];
|
|
52
|
+
}
|
|
53
|
+
get isDirty() {
|
|
54
|
+
return this._updatedRecords.size > 0;
|
|
55
|
+
}
|
|
56
|
+
get hasInvalidRecords() {
|
|
57
|
+
return [...this._updatedRecords.values()].find(x => {
|
|
58
|
+
for (const column of x.columns.values()) {
|
|
59
|
+
if (!x.isValid(column.name)) {
|
|
60
|
+
return true;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return false;
|
|
64
|
+
}) ? true : false;
|
|
65
|
+
}
|
|
66
|
+
record(recordId) {
|
|
67
|
+
return {
|
|
68
|
+
get: () => this._updatedRecords.get(recordId),
|
|
69
|
+
setValue: (columnKey, value, doNotPropagateToDatasetRecord) => {
|
|
70
|
+
if (!doNotPropagateToDatasetRecord && this._isEqual(columnKey, this._internalRecordMap.get(recordId).getValue(columnKey), value)) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
const updatedRecord = this._updatedRecords.get(recordId);
|
|
74
|
+
if (!updatedRecord) {
|
|
75
|
+
const deepCopiedRecord = cloneDeep(this._internalRecordMap.get(recordId));
|
|
76
|
+
this._updatedRecords.set(recordId, {
|
|
77
|
+
columns: new Map([[columnKey, this._getEntityColumnByKey(columnKey)]]),
|
|
78
|
+
getRecordId: () => recordId,
|
|
79
|
+
getValue: (columnKey) => this._internalRecordMap.get(recordId)?.getValue(columnKey),
|
|
80
|
+
getFormattedValue: (columnKey) => this._internalRecordMap.get(recordId)?.getFormattedValue(columnKey),
|
|
81
|
+
getNamedReference: () => deepCopiedRecord.getNamedReference(),
|
|
82
|
+
getOriginalValue: (columnKey) => deepCopiedRecord.getValue(columnKey),
|
|
83
|
+
getOriginalFormattedValue: (columnKey) => deepCopiedRecord.getFormattedValue(columnKey),
|
|
84
|
+
getOriginalFormattedPrimaryNameValue: () => {
|
|
85
|
+
let primaryColumn = this._dataset.columns.find(x => x.isPrimary);
|
|
86
|
+
if (!primaryColumn) {
|
|
87
|
+
primaryColumn = this._dataset.columns[0];
|
|
88
|
+
}
|
|
89
|
+
let value = deepCopiedRecord.getFormattedValue(primaryColumn.name);
|
|
90
|
+
if (!value) {
|
|
91
|
+
value = this._grid.labels["no-name"]();
|
|
92
|
+
}
|
|
93
|
+
return value;
|
|
94
|
+
},
|
|
95
|
+
setValue: (columnKey, value) => {
|
|
96
|
+
this._internalRecordMap.get(recordId)?.setValue(columnKey, value);
|
|
97
|
+
},
|
|
98
|
+
isValid: (columnKey) => {
|
|
99
|
+
const column = this._grid.columns.find(x => x.key === columnKey);
|
|
100
|
+
if (!column) {
|
|
101
|
+
return true;
|
|
102
|
+
}
|
|
103
|
+
const [result, message] = new ColumnValidation(this._grid, column).validate(this._internalRecordMap.get(recordId)?.getValue(columnKey));
|
|
104
|
+
return result;
|
|
105
|
+
},
|
|
106
|
+
clear: () => {
|
|
107
|
+
const updatedRecord = this._updatedRecords.get(recordId);
|
|
108
|
+
const columns = [...updatedRecord.columns.values()];
|
|
109
|
+
this._updatedRecords.delete(recordId);
|
|
110
|
+
for (const column of columns) {
|
|
111
|
+
this._internalRecordMap.get(recordId)?.setValue(column.name, deepCopiedRecord.getValue(column.name));
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
save: async () => {
|
|
115
|
+
try {
|
|
116
|
+
await this._internalRecordMap.get(recordId)?.save();
|
|
117
|
+
this._updatedRecords.delete(recordId);
|
|
118
|
+
}
|
|
119
|
+
catch (err) {
|
|
120
|
+
this._grid.pcfContext.navigation.openErrorDialog({
|
|
121
|
+
message: 'An error occurred during saving. Some of you changes might now have been saved.',
|
|
122
|
+
//@ts-ignore
|
|
123
|
+
details: err.message
|
|
124
|
+
});
|
|
125
|
+
return false;
|
|
126
|
+
}
|
|
127
|
+
return true;
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
updatedRecord.columns.set(columnKey, this._getEntityColumnByKey(columnKey));
|
|
133
|
+
}
|
|
134
|
+
if (!doNotPropagateToDatasetRecord) {
|
|
135
|
+
const updatedRecord = this._updatedRecords.get(recordId);
|
|
136
|
+
updatedRecord?.setValue(columnKey, value);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
async saveAll() {
|
|
142
|
+
const savePromises = [];
|
|
143
|
+
for (const record of this._updatedRecords.values()) {
|
|
144
|
+
savePromises.push(record.save());
|
|
145
|
+
}
|
|
146
|
+
const result = await Promise.all(savePromises);
|
|
147
|
+
return !result.find(x => x === false);
|
|
148
|
+
}
|
|
149
|
+
async clearAll() {
|
|
150
|
+
for (const record of this._updatedRecords.values()) {
|
|
151
|
+
record.clear();
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
onDependenciesUpdated() {
|
|
155
|
+
for (const [recordId, record] of Object.entries(this._grid.dataset.records)) {
|
|
156
|
+
this._internalRecordMap.set(recordId, record);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
_getEntityColumnByKey(columnKey) {
|
|
160
|
+
const gridColumn = this._grid.columns.find(x => x.key === columnKey);
|
|
161
|
+
return this._dataset.columns.find(x => {
|
|
162
|
+
if (!gridColumn.entityAliasName) {
|
|
163
|
+
return x.name === gridColumn.attributeName;
|
|
164
|
+
}
|
|
165
|
+
return x.name === gridColumn.attributeName && x.alias === gridColumn.entityAliasName;
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
_isReadOnlyChangeEditor() {
|
|
169
|
+
return this._grid.props.parameters.ChangeEditorMode?.raw === 'read';
|
|
170
|
+
}
|
|
171
|
+
_isEqual(columnKey, oldValue, newValue) {
|
|
172
|
+
const column = this._grid.columns.find(x => x.key === columnKey);
|
|
173
|
+
//skip in special case for currency
|
|
174
|
+
//PCF has no info about the currency, which sometimes make it to ouput change
|
|
175
|
+
if (column?.dataType === DataType.CURRENCY) {
|
|
176
|
+
Numeral.currency(this._grid.pcfContext.userSettings.numberFormattingInfo);
|
|
177
|
+
newValue = numeral(newValue).value();
|
|
178
|
+
if (newValue === oldValue) {
|
|
179
|
+
return true;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
if (oldValue == newValue) {
|
|
183
|
+
return true;
|
|
184
|
+
}
|
|
185
|
+
return equal(oldValue, newValue);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
export { RecordUpdateService };
|
|
190
|
+
//# sourceMappingURL=RecordUpdateService.js.map
|
package/dist/components/Grid/core/services/RecordUpdateService/model/RecordUpdateService.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RecordUpdateService.js","sources":["../../../../../../../src/components/Grid/core/services/RecordUpdateService/model/RecordUpdateService.ts"],"sourcesContent":["import equal from \"fast-deep-equal/es6\";\nimport { cloneDeep } from \"lodash\";\nimport numeral from \"numeral\";\nimport { Numeral } from \"../../../../../../utils/Numeral\";\nimport { IEntityColumn, IEntityRecord } from \"../../../../interfaces\";\nimport { ColumnValidation } from \"../../../../validation/model/ColumnValidation\";\nimport { DataType } from \"../../../enums/DataType\";\nimport { Grid } from \"../../../model/Grid\";\nimport { GridDependency } from \"../../../model/GridDependency\";\n\nexport interface IUpdatedRecord extends Omit<IEntityRecord, 'save'> {\n columns: Map<string, IEntityColumn>,\n isValid: (columnKey: string) => boolean,\n getOriginalValue: (columnKey: string) => any;\n getOriginalFormattedValue: (columnKey: string) => any;\n getOriginalFormattedPrimaryNameValue: () => any;\n save: () => Promise<boolean>,\n clear: () => void;\n}\n\nexport class RecordUpdateService extends GridDependency {\n private _updatedRecords: Map<string, IUpdatedRecord> = new Map();\n private _internalRecordMap: Map<string, IEntityRecord> = new Map();\n\n constructor(grid: Grid) {\n super(grid);\n const updatedRecordsFromState: IUpdatedRecord[] | undefined = this._grid.state?.['__updatedRecords'];\n //@ts-ignore - getRecordId could be undefined if it comes from serialized state\n if(updatedRecordsFromState && updatedRecordsFromState?.length > 0 && updatedRecordsFromState[0].getRecordId) {\n this._updatedRecords = new Map(updatedRecordsFromState.map(x => {\n const originalClear = x.clear;\n const originalSetValue = x.setValue;\n const originalSave = x.save;\n x.clear = () => {\n this._updatedRecords.delete(x.getRecordId());\n originalClear();\n this._pcfContext.factory.requestRender();\n }\n x.save = async () => {\n const result = await originalSave();\n if(result) {\n this._updatedRecords.delete(x.getRecordId());\n }\n [...x.columns.values()].map(col => {\n this._internalRecordMap.get(x.getRecordId())?.setValue(col.name, x.getValue(col.name));\n })\n return result;\n }\n x.setValue = (columnName: string, value: any) => {\n originalSetValue(columnName, value);\n this._pcfContext.factory.requestRender();\n }\n return [x.getRecordId(), x]\n }))\n }\n }\n\n public get updatedRecords() {\n if (this._isReadOnlyChangeEditor() && this._updatedRecords.size === 0) {\n const record = this._grid.records[0];\n for (const column of this._grid.columns) {\n this.record(record.getRecordId()).setValue(column.key, record.getValue(column.key), true);\n }\n }\n return [...this._updatedRecords.values()];\n }\n\n public get isDirty() {\n return this._updatedRecords.size > 0;\n }\n\n public get hasInvalidRecords() {\n return [...this._updatedRecords.values()].find(x => {\n for(const column of x.columns.values()) {\n if(!x.isValid(column.name)) {\n return true;\n }\n }\n return false;\n }) ? true : false;\n }\n\n public record(recordId: string) {\n return {\n get: () => this._updatedRecords.get(recordId),\n setValue: (columnKey: string, value: any, doNotPropagateToDatasetRecord?: boolean) => {\n if(!doNotPropagateToDatasetRecord && this._isEqual(columnKey, this._internalRecordMap.get(recordId)!.getValue(columnKey), value)) {\n return;\n }\n const updatedRecord = this._updatedRecords.get(recordId);\n if (!updatedRecord) {\n const deepCopiedRecord = cloneDeep(this._internalRecordMap.get(recordId)!);\n this._updatedRecords.set(recordId, {\n columns: new Map([[columnKey, this._getEntityColumnByKey(columnKey)]]),\n getRecordId: () => recordId,\n getValue: (columnKey: string) => this._internalRecordMap.get(recordId)?.getValue(columnKey)!,\n getFormattedValue: (columnKey: string) => this._internalRecordMap.get(recordId)?.getFormattedValue(columnKey)!,\n getNamedReference: () => deepCopiedRecord.getNamedReference(),\n getOriginalValue: (columnKey: string) => deepCopiedRecord.getValue(columnKey),\n getOriginalFormattedValue: (columnKey: string) => deepCopiedRecord.getFormattedValue(columnKey),\n getOriginalFormattedPrimaryNameValue: () => {\n let primaryColumn = this._dataset.columns.find(x => x.isPrimary);\n if(!primaryColumn) {\n primaryColumn = this._dataset.columns[0];\n }\n let value = deepCopiedRecord.getFormattedValue(primaryColumn.name);\n if(!value) {\n value = this._grid.labels[\"no-name\"]();\n }\n return value;\n },\n setValue: (columnKey: string, value: any) => {\n this._internalRecordMap.get(recordId)?.setValue(columnKey, value);\n },\n isValid: (columnKey: string) => {\n const column = this._grid.columns.find(x => x.key === columnKey);\n if(!column) {\n return true;\n }\n const [result, message] = new ColumnValidation(this._grid, column).validate(this._internalRecordMap.get(recordId)?.getValue(columnKey)!)\n return result;\n },\n clear: () => {\n const updatedRecord = this._updatedRecords.get(recordId);\n const columns = [...updatedRecord!.columns.values()];\n this._updatedRecords.delete(recordId);\n for(const column of columns) {\n this._internalRecordMap.get(recordId)?.setValue(column.name, deepCopiedRecord.getValue(column.name));\n }\n },\n save: async () => {\n try {\n await this._internalRecordMap.get(recordId)?.save();\n this._updatedRecords.delete(recordId);\n }\n catch (err) {\n this._grid.pcfContext.navigation.openErrorDialog({\n message: 'An error occurred during saving. Some of you changes might now have been saved.',\n //@ts-ignore\n details: err.message\n })\n return false;\n }\n return true;\n }\n })\n }\n else {\n updatedRecord.columns.set(columnKey, this._getEntityColumnByKey(columnKey))\n }\n if (!doNotPropagateToDatasetRecord) {\n const updatedRecord = this._updatedRecords.get(recordId);\n updatedRecord?.setValue(columnKey, value);\n }\n }\n }\n }\n\n public async saveAll(): Promise<boolean> {\n const savePromises: Promise<boolean>[] = [];\n for (const record of this._updatedRecords.values()) {\n savePromises.push(record.save());\n }\n const result = await Promise.all(savePromises);\n return !result.find(x => x === false)\n }\n public async clearAll() {\n for (const record of this._updatedRecords.values()) {\n record.clear();\n }\n }\n\n public onDependenciesUpdated(): void {\n for (const [recordId, record] of Object.entries(this._grid.dataset.records)) {\n this._internalRecordMap.set(recordId, record);\n }\n }\n private _getEntityColumnByKey(columnKey: string) {\n const gridColumn = this._grid.columns.find(x => x.key === columnKey)!;\n return this._dataset.columns.find(x => {\n if (!gridColumn.entityAliasName) {\n return x.name === gridColumn.attributeName;\n }\n return x.name === gridColumn.attributeName && x.alias === gridColumn.entityAliasName;\n })!;\n }\n private _isReadOnlyChangeEditor() {\n return this._grid.props.parameters.ChangeEditorMode?.raw === 'read';\n }\n private _isEqual(columnKey: string, oldValue: any, newValue: any) {\n const column = this._grid.columns.find(x => x.key === columnKey);\n //skip in special case for currency\n //PCF has no info about the currency, which sometimes make it to ouput change\n if(column?.dataType === DataType.CURRENCY) {\n Numeral.currency(this._grid.pcfContext.userSettings.numberFormattingInfo);\n newValue = numeral(newValue).value();\n if(newValue === oldValue) {\n return true\n }\n\n }\n if(oldValue == newValue) {\n return true;\n }\n return equal(oldValue, newValue);\n }\n}"],"names":[],"mappings":"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"}
|
|
@@ -1 +1,50 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { Callout, Text, IconButton, PrimaryButton, Button } from '@fluentui/react';
|
|
4
|
+
import { filterCalloutStyles } from './styles.js';
|
|
5
|
+
import { useColumnFilterConditionController } from '../../controller/useColumnFilterConditionController.js';
|
|
6
|
+
import { FilteringUtils } from '../../utils/FilteringUtilts.js';
|
|
7
|
+
import { ConditionOperator } from './components/ConditionOperator/ConditionOperator.js';
|
|
8
|
+
import { ConditionValue } from './components/ConditionValue/ConditionValue.js';
|
|
9
|
+
import { useGridInstance } from '../../../core/hooks/useGridInstance.js';
|
|
10
|
+
|
|
11
|
+
const FilterCallout = (props) => {
|
|
12
|
+
const { column, onDismiss } = { ...props };
|
|
13
|
+
const condition = useColumnFilterConditionController(column);
|
|
14
|
+
const grid = useGridInstance();
|
|
15
|
+
const conditionRef = React.useRef();
|
|
16
|
+
conditionRef.current = condition;
|
|
17
|
+
const conditionOperator = condition?.operator.get();
|
|
18
|
+
const conditionValue = condition?.value.get();
|
|
19
|
+
const conditionUtils = FilteringUtils.condition();
|
|
20
|
+
const isDeleteButtonDisabled = () => {
|
|
21
|
+
switch (conditionValue) {
|
|
22
|
+
case null:
|
|
23
|
+
case undefined:
|
|
24
|
+
case "": {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return false;
|
|
29
|
+
};
|
|
30
|
+
React.useEffect(() => {
|
|
31
|
+
return () => {
|
|
32
|
+
conditionRef.current?.clear();
|
|
33
|
+
};
|
|
34
|
+
}, []);
|
|
35
|
+
return (jsxs(Callout, { ...props, calloutWidth: 230, className: filterCalloutStyles.root, children: [jsxs("div", { className: filterCalloutStyles.header, children: [jsx(Text, { className: filterCalloutStyles.title, variant: "mediumPlus", children: grid.labels['filtermenu-filterby']() }), jsx(IconButton, { onClick: () => onDismiss(), iconProps: {
|
|
36
|
+
iconName: 'ChromeClose',
|
|
37
|
+
} })] }), condition &&
|
|
38
|
+
jsxs(Fragment, { children: [jsxs("div", { className: filterCalloutStyles.controls, children: [jsx(ConditionOperator, { column: column }), conditionUtils.value(conditionOperator).isEditable &&
|
|
39
|
+
jsx(ConditionValue, { column: column })] }), jsxs("div", { className: filterCalloutStyles.footer, children: [jsx(PrimaryButton, { text: grid.labels['filtermenu-applybutton'](), onClick: async () => {
|
|
40
|
+
if (await condition.save()) {
|
|
41
|
+
props.onDismiss();
|
|
42
|
+
}
|
|
43
|
+
} }), conditionUtils.value(conditionOperator).isEditable &&
|
|
44
|
+
jsx(Button, { text: grid.labels['filtermenu-clearbutton'](), disabled: isDeleteButtonDisabled(), onClick: () => {
|
|
45
|
+
condition.value.set(null);
|
|
46
|
+
} })] })] })] }));
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
export { FilterCallout };
|
|
50
|
+
//# sourceMappingURL=FilterCallout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterCallout.js","sources":["../../../../../../src/components/Grid/filtering/components/FilterCallout/FilterCallout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Callout, IconButton, PrimaryButton, Button, ICalloutProps } from '@fluentui/react';\nimport { Text } from '@fluentui/react';\nimport { filterCalloutStyles } from './styles';\nimport { IColumnFilterConditionController, useColumnFilterConditionController } from '../../controller/useColumnFilterConditionController';\nimport { IGridColumn } from '../../../core/interfaces/IGridColumn';\nimport { FilteringUtils } from '../../utils/FilteringUtilts';\nimport { ConditionOperator } from './components/ConditionOperator/ConditionOperator';\nimport { ConditionValue } from './components/ConditionValue/ConditionValue';\nimport { useGridInstance } from '../../../core/hooks/useGridInstance';\n\nexport interface IFilterCallout extends ICalloutProps {\n column: IGridColumn;\n onDismiss: () => void;\n}\n\nexport const FilterCallout = (props: IFilterCallout) => {\n const {column, onDismiss} = {...props};\n const condition = useColumnFilterConditionController(column);\n const grid = useGridInstance();\n const conditionRef = React.useRef<IColumnFilterConditionController | null>();\n conditionRef.current = condition;\n const conditionOperator = condition?.operator.get();\n const conditionValue = condition?.value.get();\n const conditionUtils = FilteringUtils.condition();\n\n const isDeleteButtonDisabled = () => {\n switch(conditionValue) {\n case null:\n case undefined:\n case \"\": {\n return true;\n }\n }\n return false;\n }\n\n React.useEffect(() => {\n return () => {\n conditionRef.current?.clear();\n }\n }, []);\n\n return (\n <Callout\n {...props}\n calloutWidth={230}\n className={filterCalloutStyles.root}>\n <div className={filterCalloutStyles.header}>\n <Text className={filterCalloutStyles.title} variant=\"mediumPlus\">{grid.labels['filtermenu-filterby']()}</Text>\n <IconButton onClick={() => onDismiss()} iconProps={{\n iconName: 'ChromeClose',\n }} />\n </div>\n {condition &&\n <>\n <div className={filterCalloutStyles.controls}>\n <ConditionOperator column={column} />\n {conditionUtils.value(conditionOperator!).isEditable &&\n <ConditionValue\n column={column} />\n }\n </div>\n <div className={filterCalloutStyles.footer}>\n <PrimaryButton text={grid.labels['filtermenu-applybutton']()}\n onClick={async () => {\n if(await condition.save()) {\n props.onDismiss();\n }\n }} />\n {conditionUtils.value(conditionOperator!).isEditable &&\n <Button text={grid.labels['filtermenu-clearbutton']()}\n disabled={isDeleteButtonDisabled()}\n onClick={() => {\n condition.value.set(null);\n }} />\n }\n </div>\n </>\n }\n </Callout>\n );\n};"],"names":["_jsxs","_jsx","_Fragment"],"mappings":"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"}
|
|
@@ -1 +1,58 @@
|
|
|
1
|
-
import{jsx
|
|
1
|
+
import { jsx, Fragment } from 'react/jsx-runtime';
|
|
2
|
+
import { ComboBox } from '@talxis/react-components';
|
|
3
|
+
import { DataType } from '../../../../../core/enums/DataType.js';
|
|
4
|
+
import { useTheme } from '@fluentui/react';
|
|
5
|
+
import { FilteringUtils } from '../../../../utils/FilteringUtilts.js';
|
|
6
|
+
import { useGridInstance } from '../../../../../core/hooks/useGridInstance.js';
|
|
7
|
+
import { useColumnFilterConditionController } from '../../../../controller/useColumnFilterConditionController.js';
|
|
8
|
+
|
|
9
|
+
const ConditionOperator = (props) => {
|
|
10
|
+
const { column } = { ...props };
|
|
11
|
+
const operatorUtils = FilteringUtils.condition().operator();
|
|
12
|
+
const grid = useGridInstance();
|
|
13
|
+
const condition = useColumnFilterConditionController(column);
|
|
14
|
+
useTheme();
|
|
15
|
+
//TODO: add missing text operator (begins with, ends with)
|
|
16
|
+
const getOptions = () => {
|
|
17
|
+
let operators = operatorUtils.textFieldOperators;
|
|
18
|
+
switch (column.dataType) {
|
|
19
|
+
case DataType.WHOLE_NONE:
|
|
20
|
+
case DataType.DECIMAL:
|
|
21
|
+
case DataType.FP:
|
|
22
|
+
case DataType.WHOLE_DURATION:
|
|
23
|
+
case DataType.CURRENCY:
|
|
24
|
+
operators = operatorUtils.numberOperators;
|
|
25
|
+
break;
|
|
26
|
+
case DataType.DATE_AND_TIME_DATE_AND_TIME:
|
|
27
|
+
case DataType.DATE_AND_TIME_DATE_ONLY:
|
|
28
|
+
operators = operatorUtils.dateOperators;
|
|
29
|
+
break;
|
|
30
|
+
case DataType.MULTI_SELECT_OPTIONSET:
|
|
31
|
+
operators = operatorUtils.multipleOptionSetOperators;
|
|
32
|
+
break;
|
|
33
|
+
case DataType.FILE:
|
|
34
|
+
case DataType.IMAGE: {
|
|
35
|
+
operators = operatorUtils.fileOperators;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return operators.map(operator => {
|
|
39
|
+
return {
|
|
40
|
+
key: operator.type,
|
|
41
|
+
text: grid.labels[operator.key]()
|
|
42
|
+
};
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
if (!condition) {
|
|
46
|
+
return jsx(Fragment, {});
|
|
47
|
+
}
|
|
48
|
+
return jsx(ComboBox, { ...props, selectedKey: condition.operator.get(), shouldRestoreFocus: false, options: getOptions(), useComboBoxAsMenuWidth: true, styles: {
|
|
49
|
+
callout: {
|
|
50
|
+
maxHeight: '300px !important'
|
|
51
|
+
}
|
|
52
|
+
}, onChange: (e, option) => {
|
|
53
|
+
condition.operator.set(option.key);
|
|
54
|
+
} });
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
export { ConditionOperator };
|
|
58
|
+
//# sourceMappingURL=ConditionOperator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConditionOperator.js","sources":["../../../../../../../../src/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.tsx"],"sourcesContent":["import { ComboBox } from \"@talxis/react-components\";\nimport { DataType } from '../../../../../core/enums/DataType';\nimport { IComboBoxOption, useTheme } from '@fluentui/react';\nimport { FilteringUtils } from '../../../../utils/FilteringUtilts';\nimport { useGridInstance } from '../../../../../core/hooks/useGridInstance';\nimport { useColumnFilterConditionController } from '../../../../controller/useColumnFilterConditionController';\nimport { IGridColumn } from '../../../../../core/interfaces/IGridColumn';\nimport { DatasetConditionOperator } from '../../../../../core/enums/ConditionOperator';\nimport React from 'react';\nimport { ITheme } from \"../../../../../../../interfaces/theme\";\n\ninterface IConditionOperator {\n column: IGridColumn;\n}\nexport const ConditionOperator = (props: IConditionOperator) => {\n const { column } = { ...props };\n const operatorUtils = FilteringUtils.condition().operator();\n const grid = useGridInstance();\n const condition = useColumnFilterConditionController(column);\n const theme: ITheme = useTheme();\n\n //TODO: add missing text operator (begins with, ends with)\n const getOptions = (): IComboBoxOption[] => {\n let operators = operatorUtils.textFieldOperators;\n switch (column.dataType) {\n case DataType.WHOLE_NONE:\n case DataType.DECIMAL:\n case DataType.FP:\n case DataType.WHOLE_DURATION:\n case DataType.CURRENCY:\n operators = operatorUtils.numberOperators;\n break;\n case DataType.DATE_AND_TIME_DATE_AND_TIME:\n case DataType.DATE_AND_TIME_DATE_ONLY:\n operators = operatorUtils.dateOperators;\n break;\n case DataType.MULTI_SELECT_OPTIONSET:\n operators = operatorUtils.multipleOptionSetOperators;\n break;\n case DataType.FILE:\n case DataType.IMAGE: {\n operators = operatorUtils.fileOperators;\n }\n }\n return operators.map(operator => {\n return {\n key: operator.type,\n text: grid.labels[operator.key]()\n };\n });\n };\n if(!condition) {\n return <></>\n }\n return <ComboBox\n {...props}\n selectedKey={condition.operator.get()}\n shouldRestoreFocus={false}\n options={getOptions()}\n useComboBoxAsMenuWidth\n styles={{\n callout: {\n maxHeight: '300px !important'\n }\n }}\n onChange={(e, option) => {\n condition.operator.set(option!.key as DatasetConditionOperator)\n }} />;\n}"],"names":["_jsx"],"mappings":";;;;;;;;AAca,MAAA,iBAAiB,GAAG,CAAC,KAAyB,KAAI;IAC3D,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;IAChC,MAAM,aAAa,GAAG,cAAc,CAAC,SAAS,EAAE,CAAC,QAAQ,EAAE,CAAC;AAC5D,IAAA,MAAM,IAAI,GAAG,eAAe,EAAE,CAAC;AAC/B,IAAA,MAAM,SAAS,GAAG,kCAAkC,CAAC,MAAM,CAAC,CAAC;AAC7D,IAAsB,QAAQ,GAAG;;IAGjC,MAAM,UAAU,GAAG,MAAwB;AACvC,QAAA,IAAI,SAAS,GAAG,aAAa,CAAC,kBAAkB,CAAC;QACjD,QAAQ,MAAM,CAAC,QAAQ;YACnB,KAAK,QAAQ,CAAC,UAAU,CAAC;YACzB,KAAK,QAAQ,CAAC,OAAO,CAAC;YACtB,KAAK,QAAQ,CAAC,EAAE,CAAC;YACjB,KAAK,QAAQ,CAAC,cAAc,CAAC;YAC7B,KAAK,QAAQ,CAAC,QAAQ;AAClB,gBAAA,SAAS,GAAG,aAAa,CAAC,eAAe,CAAC;gBAC1C,MAAM;YACV,KAAK,QAAQ,CAAC,2BAA2B,CAAC;YAC1C,KAAK,QAAQ,CAAC,uBAAuB;AACjC,gBAAA,SAAS,GAAG,aAAa,CAAC,aAAa,CAAC;gBACxC,MAAM;YACV,KAAK,QAAQ,CAAC,sBAAsB;AAChC,gBAAA,SAAS,GAAG,aAAa,CAAC,0BAA0B,CAAC;gBACrD,MAAM;YACV,KAAK,QAAQ,CAAC,IAAI,CAAC;AACnB,YAAA,KAAK,QAAQ,CAAC,KAAK,EAAE;AACjB,gBAAA,SAAS,GAAG,aAAa,CAAC,aAAa,CAAC;AAC3C,aAAA;AACJ,SAAA;AACD,QAAA,OAAO,SAAS,CAAC,GAAG,CAAC,QAAQ,IAAG;YAC5B,OAAO;gBACH,GAAG,EAAE,QAAQ,CAAC,IAAI;gBAClB,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;aACpC,CAAC;AACN,SAAC,CAAC,CAAC;AACP,KAAC,CAAC;IACF,IAAG,CAAC,SAAS,EAAE;AACX,QAAA,OAAOA,iBAAK,CAAA;AACf,KAAA;IACD,OAAOA,GAAA,CAAC,QAAQ,EAAA,EAAA,GACR,KAAK,EACT,WAAW,EAAE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAE,EACrC,kBAAkB,EAAE,KAAK,EACzB,OAAO,EAAE,UAAU,EAAE,EACrB,sBAAsB,EACtB,IAAA,EAAA,MAAM,EAAE;AACJ,YAAA,OAAO,EAAE;AACL,gBAAA,SAAS,EAAE,kBAAkB;AAChC,aAAA;AACJ,SAAA,EACD,QAAQ,EAAE,CAAC,CAAC,EAAE,MAAM,KAAI;YACpB,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAO,CAAC,GAA+B,CAAC,CAAA;AACnE,SAAC,GAAI,CAAC;AACd;;;;"}
|
|
@@ -1 +1,52 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx, Fragment } from 'react/jsx-runtime';
|
|
2
|
+
import { useRef, useMemo, useEffect } from 'react';
|
|
3
|
+
import { Component } from '../../../../../core/components/Component/Component.js';
|
|
4
|
+
import { useColumnFilterConditionController } from '../../../../controller/useColumnFilterConditionController.js';
|
|
5
|
+
import { ConditionComponentValue } from './model/ConditionComponentValue.js';
|
|
6
|
+
|
|
7
|
+
const ConditionValue = (props) => {
|
|
8
|
+
const condition = useColumnFilterConditionController(props.column);
|
|
9
|
+
if (!condition) {
|
|
10
|
+
return jsx(Fragment, {});
|
|
11
|
+
}
|
|
12
|
+
return jsx(InternalConditionValue, { ...condition });
|
|
13
|
+
};
|
|
14
|
+
const InternalConditionValue = (controller) => {
|
|
15
|
+
const componentContainerRef = useRef(null);
|
|
16
|
+
const controllerRef = useRef(controller);
|
|
17
|
+
controllerRef.current = controller;
|
|
18
|
+
const conditionComponentValue = useMemo(() => new ConditionComponentValue(controllerRef), []);
|
|
19
|
+
const column = conditionComponentValue.column;
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
if (conditionComponentValue.get() === null) {
|
|
22
|
+
const input = componentContainerRef.current?.querySelector('input');
|
|
23
|
+
input?.focus();
|
|
24
|
+
}
|
|
25
|
+
}, [conditionComponentValue.get()]);
|
|
26
|
+
return (jsx("div", { ref: componentContainerRef, children: jsx(Component, { column: column, value: conditionComponentValue.get(), onNotifyOutputChanged: (value) => conditionComponentValue.set(value), onOverrideControlProps: (props) => {
|
|
27
|
+
return {
|
|
28
|
+
...props,
|
|
29
|
+
parameters: {
|
|
30
|
+
...props.parameters,
|
|
31
|
+
MultipleEnabled: {
|
|
32
|
+
raw: true
|
|
33
|
+
},
|
|
34
|
+
IsInlineNewEnabled: {
|
|
35
|
+
raw: false
|
|
36
|
+
},
|
|
37
|
+
ShowErrorMessage: {
|
|
38
|
+
raw: true
|
|
39
|
+
},
|
|
40
|
+
value: {
|
|
41
|
+
...props.parameters.value,
|
|
42
|
+
getAllViews: async (entityName) => {
|
|
43
|
+
return props.parameters.value.getAllViews(entityName, 1);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
} }) }));
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export { ConditionValue };
|
|
52
|
+
//# sourceMappingURL=ConditionValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConditionValue.js","sources":["../../../../../../../../src/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.tsx"],"sourcesContent":["import { useEffect, useMemo, useRef } from \"react\";\nimport { Component } from \"../../../../../core/components/Component/Component\";\nimport { IGridColumn } from \"../../../../../core/interfaces/IGridColumn\";\nimport { IColumnFilterConditionController, useColumnFilterConditionController } from \"../../../../controller/useColumnFilterConditionController\";\nimport { ConditionComponentValue } from \"./model/ConditionComponentValue\";\nimport React from 'react';\n\ninterface IConditionValue {\n column: IGridColumn;\n}\n\nexport const ConditionValue = (props: IConditionValue) => {\n const condition = useColumnFilterConditionController(props.column);\n if (!condition) {\n return <></>\n }\n return <InternalConditionValue {...condition} />\n}\n\nconst InternalConditionValue = (controller: IColumnFilterConditionController) => {\n const componentContainerRef = useRef<HTMLDivElement>(null);\n const controllerRef = useRef<IColumnFilterConditionController>(controller);\n controllerRef.current = controller;\n const conditionComponentValue = useMemo(() => new ConditionComponentValue(controllerRef), []);\n const column = conditionComponentValue.column;\n\n useEffect(() => {\n if (conditionComponentValue.get() === null) {\n const input = componentContainerRef.current?.querySelector('input')\n input?.focus()\n }\n }, [conditionComponentValue.get()])\n\n return (\n <div ref={componentContainerRef}>\n <Component\n column={column}\n value={conditionComponentValue.get()}\n onNotifyOutputChanged={(value) => conditionComponentValue.set(value)}\n onOverrideControlProps={(props) => {\n return {\n ...props,\n parameters: {\n ...props.parameters,\n MultipleEnabled: {\n raw: true\n },\n IsInlineNewEnabled: {\n raw: false\n },\n ShowErrorMessage: {\n raw: true\n },\n value: {\n ...props.parameters.value,\n getAllViews: async (entityName: string) => {\n return props.parameters.value.getAllViews(entityName, 1);\n }\n }\n }\n }\n }}\n />\n </div>\n )\n}\n"],"names":["_jsx"],"mappings":";;;;;;AAWa,MAAA,cAAc,GAAG,CAAC,KAAsB,KAAI;IACrD,MAAM,SAAS,GAAG,kCAAkC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACnE,IAAI,CAAC,SAAS,EAAE;AACZ,QAAA,OAAOA,iBAAK,CAAA;AACf,KAAA;AACD,IAAA,OAAOA,GAAC,CAAA,sBAAsB,EAAK,EAAA,GAAA,SAAS,GAAI,CAAA;AACpD,EAAC;AAED,MAAM,sBAAsB,GAAG,CAAC,UAA4C,KAAI;AAC5E,IAAA,MAAM,qBAAqB,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;AAC3D,IAAA,MAAM,aAAa,GAAG,MAAM,CAAmC,UAAU,CAAC,CAAC;AAC3E,IAAA,aAAa,CAAC,OAAO,GAAG,UAAU,CAAC;AACnC,IAAA,MAAM,uBAAuB,GAAG,OAAO,CAAC,MAAM,IAAI,uBAAuB,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;AAC9F,IAAA,MAAM,MAAM,GAAG,uBAAuB,CAAC,MAAM,CAAC;IAE9C,SAAS,CAAC,MAAK;AACX,QAAA,IAAI,uBAAuB,CAAC,GAAG,EAAE,KAAK,IAAI,EAAE;YACxC,MAAM,KAAK,GAAG,qBAAqB,CAAC,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC,CAAA;YACnE,KAAK,EAAE,KAAK,EAAE,CAAA;AACjB,SAAA;KACJ,EAAE,CAAC,uBAAuB,CAAC,GAAG,EAAE,CAAC,CAAC,CAAA;AAEnC,IAAA,QACIA,GAAK,CAAA,KAAA,EAAA,EAAA,GAAG,EAAE,qBAAqB,YAC3BA,GAAC,CAAA,SAAS,EACN,EAAA,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,uBAAuB,CAAC,GAAG,EAAE,EACpC,qBAAqB,EAAE,CAAC,KAAK,KAAK,uBAAuB,CAAC,GAAG,CAAC,KAAK,CAAC,EACpE,sBAAsB,EAAE,CAAC,KAAK,KAAI;gBAC9B,OAAO;AACH,oBAAA,GAAG,KAAK;AACR,oBAAA,UAAU,EAAE;wBACR,GAAG,KAAK,CAAC,UAAU;AACnB,wBAAA,eAAe,EAAE;AACb,4BAAA,GAAG,EAAE,IAAI;AACZ,yBAAA;AACD,wBAAA,kBAAkB,EAAE;AAChB,4BAAA,GAAG,EAAE,KAAK;AACb,yBAAA;AACD,wBAAA,gBAAgB,EAAE;AACd,4BAAA,GAAG,EAAE,IAAI;AACZ,yBAAA;AACD,wBAAA,KAAK,EAAE;AACH,4BAAA,GAAG,KAAK,CAAC,UAAU,CAAC,KAAK;AACzB,4BAAA,WAAW,EAAE,OAAO,UAAkB,KAAI;AACtC,gCAAA,OAAO,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;6BAC5D;AACJ,yBAAA;AACJ,qBAAA;iBACJ,CAAA;aACJ,EAAA,CACH,EACA,CAAA,EACT;AACL,CAAC;;;;"}
|
|
@@ -1 +1,125 @@
|
|
|
1
|
-
import
|
|
1
|
+
import dayjs from 'dayjs';
|
|
2
|
+
import { DatasetConditionOperator } from '../../../../../../core/enums/ConditionOperator.js';
|
|
3
|
+
import { DataType } from '../../../../../../core/enums/DataType.js';
|
|
4
|
+
import { FilteringUtils } from '../../../../../utils/FilteringUtilts.js';
|
|
5
|
+
|
|
6
|
+
class ConditionComponentValue {
|
|
7
|
+
constructor(columnFilterConditionControllerRef) {
|
|
8
|
+
this._conditionUtils = FilteringUtils.condition();
|
|
9
|
+
this._columnFilterConditionControllerRef = columnFilterConditionControllerRef;
|
|
10
|
+
}
|
|
11
|
+
get column() {
|
|
12
|
+
const _column = { ...this._columnFilterConditionController.column };
|
|
13
|
+
_column.isRequired = false;
|
|
14
|
+
//always needs to be required for filter values if non valid value is present
|
|
15
|
+
if (!this._columnFilterConditionController.value.valid) {
|
|
16
|
+
_column.isRequired = true;
|
|
17
|
+
}
|
|
18
|
+
switch (this._columnFilterConditionController.column.dataType) {
|
|
19
|
+
case DataType.OPTIONSET:
|
|
20
|
+
case DataType.TWO_OPTIONS: {
|
|
21
|
+
_column.dataType = DataType.MULTI_SELECT_OPTIONSET;
|
|
22
|
+
break;
|
|
23
|
+
}
|
|
24
|
+
//skip this validation because operators like contains should not fail on regexes
|
|
25
|
+
case DataType.SINGLE_LINE_EMAIL:
|
|
26
|
+
case DataType.SINGLE_LINE_URL: {
|
|
27
|
+
_column.dataType = DataType.SINGLE_LINE_TEXT;
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
//In Power Apps, DateTime fields filters do not allow setting filters for time, only for the date
|
|
31
|
+
case DataType.DATE_AND_TIME_DATE_AND_TIME: {
|
|
32
|
+
_column.dataType = DataType.DATE_AND_TIME_DATE_ONLY;
|
|
33
|
+
break;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber;
|
|
37
|
+
if (this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber) {
|
|
38
|
+
_column.dataType = DataType.WHOLE_NONE;
|
|
39
|
+
}
|
|
40
|
+
if (this._conditionUtils.operator(this._operator.get()).allowsOnlyFreeText) {
|
|
41
|
+
_column.dataType = DataType.SINGLE_LINE_TEXT;
|
|
42
|
+
}
|
|
43
|
+
return _column;
|
|
44
|
+
}
|
|
45
|
+
get() {
|
|
46
|
+
let value = this._value.get();
|
|
47
|
+
if (!value) {
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
switch (this.column.dataType) {
|
|
51
|
+
case DataType.MULTI_SELECT_OPTIONSET: {
|
|
52
|
+
if (typeof value === 'string') {
|
|
53
|
+
value = [value];
|
|
54
|
+
}
|
|
55
|
+
return value.map((x) => parseInt(x));
|
|
56
|
+
}
|
|
57
|
+
case DataType.LOOKUP_OWNER:
|
|
58
|
+
case DataType.LOOKUP_SIMPLE:
|
|
59
|
+
case DataType.LOOKUP_CUSTOMER: {
|
|
60
|
+
if (typeof value === 'string') {
|
|
61
|
+
value = [value];
|
|
62
|
+
}
|
|
63
|
+
return value.map((x) => {
|
|
64
|
+
return {
|
|
65
|
+
entityType: "",
|
|
66
|
+
name: "",
|
|
67
|
+
id: x
|
|
68
|
+
};
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return value;
|
|
73
|
+
}
|
|
74
|
+
set(value) {
|
|
75
|
+
switch (this.column.dataType) {
|
|
76
|
+
case DataType.DATE_AND_TIME_DATE_AND_TIME:
|
|
77
|
+
case DataType.DATE_AND_TIME_DATE_ONLY: {
|
|
78
|
+
if (value instanceof Date) {
|
|
79
|
+
//the column of date time is always converted to Date column in Power Apps
|
|
80
|
+
value = dayjs(value).format('YYYY-MM-DD');
|
|
81
|
+
}
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
case DataType.MULTI_SELECT_OPTIONSET: {
|
|
85
|
+
switch (this._operator.get()) {
|
|
86
|
+
case DatasetConditionOperator.Equal:
|
|
87
|
+
case DatasetConditionOperator.NotEqual: {
|
|
88
|
+
if (value?.length === 1) {
|
|
89
|
+
value = value[0].toString();
|
|
90
|
+
this._value.set(value);
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
for (let i = 0; i < value?.length; i++) {
|
|
96
|
+
value[i] = value[i].toString();
|
|
97
|
+
}
|
|
98
|
+
this._value.set(value);
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
case DataType.LOOKUP_OWNER:
|
|
102
|
+
case DataType.LOOKUP_SIMPLE:
|
|
103
|
+
case DataType.LOOKUP_CUSTOMER: {
|
|
104
|
+
if (value?.length > 1) {
|
|
105
|
+
value = value.map((x) => x.id);
|
|
106
|
+
break;
|
|
107
|
+
}
|
|
108
|
+
value = value[0]?.id;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
this._value.set(value);
|
|
112
|
+
}
|
|
113
|
+
get _columnFilterConditionController() {
|
|
114
|
+
return this._columnFilterConditionControllerRef.current;
|
|
115
|
+
}
|
|
116
|
+
get _value() {
|
|
117
|
+
return this._columnFilterConditionController.value;
|
|
118
|
+
}
|
|
119
|
+
get _operator() {
|
|
120
|
+
return this._columnFilterConditionController.operator;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
export { ConditionComponentValue };
|
|
125
|
+
//# sourceMappingURL=ConditionComponentValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConditionComponentValue.js","sources":["../../../../../../../../../src/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.ts"],"sourcesContent":["import dayjs from \"dayjs\";\nimport { DatasetConditionOperator } from \"../../../../../../core/enums/ConditionOperator\";\nimport { DataType } from \"../../../../../../core/enums/DataType\";\nimport { IColumnFilterConditionController } from \"../../../../../controller/useColumnFilterConditionController\";\nimport { FilteringUtils } from \"../../../../../utils/FilteringUtilts\";\n\nexport class ConditionComponentValue {\n //needs to be ref to keep the current reference\n private _columnFilterConditionControllerRef: React.MutableRefObject<IColumnFilterConditionController>;\n private _conditionUtils = FilteringUtils.condition();\n\n constructor(columnFilterConditionControllerRef: React.MutableRefObject<IColumnFilterConditionController>) {\n this._columnFilterConditionControllerRef = columnFilterConditionControllerRef;\n }\n\n public get column() {\n const _column = {...this._columnFilterConditionController.column};\n _column.isRequired = false;\n //always needs to be required for filter values if non valid value is present\n if(!this._columnFilterConditionController.value.valid) {\n _column.isRequired = true;\n }\n switch (this._columnFilterConditionController.column.dataType) {\n case DataType.OPTIONSET:\n case DataType.TWO_OPTIONS: {\n _column.dataType = DataType.MULTI_SELECT_OPTIONSET;\n break;\n }\n //skip this validation because operators like contains should not fail on regexes\n case DataType.SINGLE_LINE_EMAIL:\n case DataType.SINGLE_LINE_URL: {\n _column.dataType = DataType.SINGLE_LINE_TEXT;\n break;\n }\n //In Power Apps, DateTime fields filters do not allow setting filters for time, only for the date\n case DataType.DATE_AND_TIME_DATE_AND_TIME: {\n _column.dataType = DataType.DATE_AND_TIME_DATE_ONLY;\n break;\n }\n }\n this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber\n if (this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber) {\n _column.dataType = DataType.WHOLE_NONE;\n }\n if (this._conditionUtils.operator(this._operator.get()).allowsOnlyFreeText) {\n _column.dataType = DataType.SINGLE_LINE_TEXT;\n }\n return _column;\n }\n public get() {\n let value = this._value.get();\n if (!value) {\n return null;\n }\n switch (this.column.dataType) {\n case DataType.MULTI_SELECT_OPTIONSET: {\n if (typeof value === 'string') {\n value = [value];\n }\n return value.map((x: string) => parseInt(x))\n }\n case DataType.LOOKUP_OWNER:\n case DataType.LOOKUP_SIMPLE:\n case DataType.LOOKUP_CUSTOMER: {\n if (typeof value === 'string') {\n value = [value];\n }\n return value.map((x: string) => {\n return {\n entityType: \"\",\n name: \"\",\n id: x\n } as ComponentFramework.LookupValue;\n })\n }\n }\n return value;\n }\n public set(value: any) {\n switch (this.column.dataType) {\n case DataType.DATE_AND_TIME_DATE_AND_TIME:\n case DataType.DATE_AND_TIME_DATE_ONLY: {\n if(value instanceof Date) {\n\n //the column of date time is always converted to Date column in Power Apps\n value = dayjs(value).format('YYYY-MM-DD');\n }\n break;\n }\n case DataType.MULTI_SELECT_OPTIONSET: {\n switch (this._operator.get()) {\n case DatasetConditionOperator.Equal:\n case DatasetConditionOperator.NotEqual: {\n if (value?.length === 1) {\n value = value[0].toString();\n this._value.set(value);\n return;\n }\n }\n }\n for (let i = 0; i < value?.length; i++) {\n value[i] = value[i].toString()\n }\n this._value.set(value);\n return;\n }\n case DataType.LOOKUP_OWNER:\n case DataType.LOOKUP_SIMPLE:\n case DataType.LOOKUP_CUSTOMER: {\n if(value?.length > 1) {\n value = value.map((x: ComponentFramework.LookupValue) => x.id);\n break;\n }\n value = value[0]?.id;\n }\n\n }\n this._value.set(value);\n }\n private get _columnFilterConditionController() {\n return this._columnFilterConditionControllerRef.current;\n }\n private get _value() {\n return this._columnFilterConditionController.value;\n }\n private get _operator() {\n return this._columnFilterConditionController.operator;\n }\n}"],"names":[],"mappings":"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"}
|