@sankhyalabs/core 6.1.0-dev.2 → 6.1.0-dev.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/.docs/classes/Change.md +11 -11
  2. package/.docs/classes/ColumnFilterManager.md +6 -6
  3. package/.docs/classes/DataUnit.md +157 -157
  4. package/.docs/classes/DataUnitLoaderUtils.md +6 -6
  5. package/.docs/classes/SelectionInfo.md +16 -16
  6. package/.docs/enumerations/ChangeOperation.md +4 -4
  7. package/.docs/enumerations/SelectionMode.md +2 -2
  8. package/.docs/functions/defaultDataLoader.md +1 -1
  9. package/.docs/interfaces/DUActionInterceptor.md +1 -1
  10. package/.docs/interfaces/PageRequest.md +3 -3
  11. package/.docs/interfaces/PaginationInfoBuilderParams.md +3 -3
  12. package/.docs/interfaces/QuickFilter.md +3 -3
  13. package/.docs/interfaces/Record.md +4 -4
  14. package/.docs/interfaces/SavedRecord.md +5 -5
  15. package/.docs/interfaces/WaitingChange.md +3 -3
  16. package/.docs/type-aliases/DataUnitEventOptions.md +1 -1
  17. package/dist/dataunit/Changes.d.ts +52 -0
  18. package/dist/dataunit/Changes.js +64 -0
  19. package/dist/dataunit/Changes.js.map +1 -0
  20. package/dist/dataunit/DataUnit.d.ts +9 -129
  21. package/dist/dataunit/DataUnit.js +87 -177
  22. package/dist/dataunit/DataUnit.js.map +1 -1
  23. package/dist/dataunit/DataUnitHelper.d.ts +2 -1
  24. package/dist/dataunit/DataUnitHelper.js.map +1 -1
  25. package/dist/dataunit/SelectionInfo.d.ts +16 -0
  26. package/dist/dataunit/SelectionInfo.js +39 -0
  27. package/dist/dataunit/SelectionInfo.js.map +1 -0
  28. package/dist/dataunit/interfaces/dataUnit.d.ts +61 -0
  29. package/dist/dataunit/interfaces/dataUnit.js +13 -0
  30. package/dist/dataunit/interfaces/dataUnit.js.map +1 -0
  31. package/dist/dataunit/loader/utils/dataUnitLoaderUtils.d.ts +2 -1
  32. package/dist/dataunit/loader/utils/dataUnitLoaderUtils.js.map +1 -1
  33. package/dist/dataunit/loading/LoadDataRequest.d.ts +1 -1
  34. package/dist/dataunit/loading/LoadDataResponse.d.ts +1 -1
  35. package/dist/dataunit/sorting/FieldComparator.d.ts +1 -1
  36. package/dist/dataunit/state/slice/AddedRecordsSlice.d.ts +1 -1
  37. package/dist/dataunit/state/slice/ChangesSlice.d.ts +2 -1
  38. package/dist/dataunit/state/slice/ChangesSlice.js +2 -1
  39. package/dist/dataunit/state/slice/ChangesSlice.js.map +1 -1
  40. package/dist/dataunit/state/slice/LoadingControlSlice.js.map +1 -1
  41. package/dist/dataunit/state/slice/RecordsSlice.d.ts +1 -1
  42. package/dist/dataunit/state/slice/RecordsSlice.js +1 -1
  43. package/dist/dataunit/state/slice/RecordsSlice.js.map +1 -1
  44. package/dist/dataunit/state/slice/SelectionSlice.d.ts +2 -1
  45. package/dist/dataunit/state/slice/SelectionSlice.js +2 -1
  46. package/dist/dataunit/state/slice/SelectionSlice.js.map +1 -1
  47. package/dist/dataunit/state/slice/SnapshotSlice.d.ts +1 -1
  48. package/dist/dataunit/state/slice/WaitingChangesSlice.d.ts +1 -1
  49. package/dist/index.d.ts +4 -1
  50. package/dist/index.js +4 -1
  51. package/dist/index.js.map +1 -1
  52. package/dist/utils/ColumnFilterManager.d.ts +2 -1
  53. package/dist/utils/ColumnFilterManager.js.map +1 -1
  54. package/dist/utils/SortingUtils.d.ts +1 -1
  55. package/package.json +2 -1
  56. package/reports/test-report.xml +648 -447
  57. package/src/dataunit/Changes.ts +77 -0
  58. package/src/dataunit/DataUnit.ts +242 -397
  59. package/src/dataunit/DataUnitHelper.ts +2 -1
  60. package/src/dataunit/SelectionInfo.ts +55 -0
  61. package/src/dataunit/interfaces/dataUnit.ts +71 -0
  62. package/src/dataunit/loader/utils/dataUnitLoaderUtils.ts +2 -1
  63. package/src/dataunit/loading/LoadDataRequest.ts +1 -1
  64. package/src/dataunit/loading/LoadDataResponse.ts +1 -1
  65. package/src/dataunit/sorting/FieldComparator.ts +1 -1
  66. package/src/dataunit/state/slice/AddedRecordsSlice.ts +1 -1
  67. package/src/dataunit/state/slice/ChangesSlice.ts +2 -1
  68. package/src/dataunit/state/slice/LoadingControlSlice.ts +1 -2
  69. package/src/dataunit/state/slice/RecordsSlice.ts +3 -2
  70. package/src/dataunit/state/slice/SelectionSlice.ts +2 -1
  71. package/src/dataunit/state/slice/SnapshotSlice.ts +1 -1
  72. package/src/dataunit/state/slice/WaitingChangesSlice.ts +1 -1
  73. package/src/dataunit/state/slice/test/RecordsSlice.spec.ts +1 -1
  74. package/src/index.ts +4 -1
  75. package/src/utils/ColumnFilterManager.ts +2 -1
  76. package/src/utils/SortingUtils.ts +1 -1
  77. package/test/dataunit/AccessParentsDataUnit.spec.ts +69 -0
  78. package/test/dataunit/Actions.spec.ts +74 -0
  79. package/test/dataunit/Change.spec.ts +66 -0
  80. package/test/dataunit/FieldManager.spec.ts +286 -0
  81. package/test/dataunit/FilterSortsLockersAndObservers.spec.ts +339 -0
  82. package/test/dataunit/InfoManager.spec.ts +254 -0
  83. package/test/dataunit/LoadDataAndMetadata.spec.ts +269 -0
  84. package/test/dataunit/RecodsSelection.spec.ts +229 -0
  85. package/test/dataunit/RecordsManager.spec.ts +323 -0
  86. package/test/dataunit/SavingData.spec.ts +206 -0
  87. package/test/dataunit/SelectionInfo.spec.ts +143 -0
  88. package/test/dataunit/loader/dataUnitInMemoryLoader.spec.ts +2 -1
  89. package/test/dataunit/loader/utils/createDataUnitMock.ts +34 -0
  90. package/test/dataunit/loader/utils/dataUnitLoaderUtils.spec.ts +1 -1
  91. package/test/dataunit/resources/metadata.ts +39 -0
  92. package/test/dataunit/resources/records.ts +29 -0
  93. package/test/util/ColumnFilterManager.spec.ts +2 -1
  94. package/tsconfig.json +1 -0
  95. package/src/dataunit/test/DataUnit.spec.ts +0 -44
@@ -1,4 +1,5 @@
1
- import DataUnit, { Record } from './DataUnit.js';
1
+ import DataUnit from './DataUnit.js';
2
+ import { Record } from './interfaces/dataUnit.js';
2
3
  import { DataType } from './metadata/DataType.js';
3
4
  import { LoadDataRequest, LoadDataResponse, PaginationInfo, Sort, SortMode, StringUtils } from '../index.js';
4
5
 
@@ -0,0 +1,55 @@
1
+ import { Record, SelectionMode } from "./interfaces/dataUnit.js";
2
+ import { Filter, Sort } from "./metadata/UnitMetadata.js";
3
+
4
+ export class SelectionInfo {
5
+
6
+ public mode: SelectionMode;
7
+ public filters?: Array<Filter>;
8
+ public sort?: Array<Sort>;
9
+ public getAllRecords?: () => Array<Record>;
10
+ private _records: Array<Record>;
11
+ private _total?: number;
12
+
13
+ constructor(records: Array<Record>, mode: SelectionMode = SelectionMode.SOME_RECORDS, total?: number, filters?: Array<Filter>, sort?: Array<Sort>) {
14
+ this._records = records;
15
+ this._total = total;
16
+ this.mode = mode;
17
+ this.filters = filters;
18
+ this.sort = sort;
19
+ }
20
+
21
+ public get records(): Array<Record> {
22
+ if (this.isAllRecords()) {
23
+ if (this.getAllRecords != undefined) {
24
+ return this.getAllRecords();
25
+ }
26
+ throw new Error("Erro interno: Impossível retornar os registros selecionados numa seleção virtual.");
27
+ }
28
+ return this._records;
29
+ }
30
+
31
+ public get recordIds(): Array<string> | undefined {
32
+
33
+ const records = this.records;
34
+
35
+ if (records == undefined) {
36
+ return undefined;
37
+ }
38
+ return records.map(record => record.__record__id__);
39
+ }
40
+
41
+ public get length(): number {
42
+ if (this.isAllRecords()) {
43
+ return this._total || 0;
44
+ }
45
+ return this.records == undefined ? 0 : (this.records as Array<Record>).length;
46
+ }
47
+
48
+ public isAllRecords(): boolean {
49
+ return this.mode === SelectionMode.ALL_RECORDS;
50
+ }
51
+
52
+ public isEmpty(): boolean {
53
+ return this.length === 0;
54
+ }
55
+ }
@@ -0,0 +1,71 @@
1
+ import { Filter } from "../metadata/UnitMetadata.js";
2
+ import { DataUnitAction, ExecutionContext } from "../state/action/DataUnitAction.js";
3
+
4
+ export interface LoadDataParams {
5
+ quickFilter?: QuickFilter;
6
+ executionCtx?: ExecutionContext;
7
+ checkLastFilter?: boolean;
8
+ source?: string;
9
+ selectFirstRecord?: boolean;
10
+ keepSelection?: boolean
11
+ }
12
+
13
+ export interface DUActionInterceptor {
14
+ interceptAction(action: DataUnitAction): DataUnitAction | Promise<DataUnitAction>;
15
+ }
16
+
17
+ export interface Record {
18
+ __record__id__: string;
19
+ __record__label__?: string;
20
+ __parent__record__id__?: string;
21
+ __owner__dataunit__name__?: string;
22
+ [key: string]: any;
23
+ }
24
+
25
+ export interface SavedRecord extends Record {
26
+ __old__id__?: string;
27
+ }
28
+
29
+ export enum ChangeOperation {
30
+ INSERT = "INSERT",
31
+ COPY = "COPY",
32
+ UPDATE = "UPDATE",
33
+ DELETE = "DELETE",
34
+ }
35
+
36
+ export interface WaitingChange {
37
+ waitmessage: string;
38
+ blocking: boolean;
39
+ promise?: Promise<any>;
40
+ }
41
+
42
+ export interface PageRequest {
43
+ limit: number;
44
+ offset: number;
45
+ quickFilter?: QuickFilter;
46
+ }
47
+
48
+ export interface QuickFilter {
49
+ term: string;
50
+ fields?: Array<string>;
51
+ filter?: Filter;
52
+ }
53
+
54
+ export interface PageResponse {
55
+ limit: number;
56
+ offset: number;
57
+ total: number;
58
+ hasMore: boolean;
59
+ records: Array<Record>;
60
+ }
61
+
62
+ export enum SelectionMode {
63
+ ALL_RECORDS = "ALL_RECORDS",
64
+ SOME_RECORDS = "SOME_RECORDS"
65
+ }
66
+
67
+ export type DataUnitEventOptions = { [key: string]: any };
68
+
69
+ export type HideFieldOptions = {
70
+ visibleOnConfig: boolean
71
+ };
@@ -1,4 +1,5 @@
1
- import DataUnit, { Record } from '../../DataUnit.js';
1
+ import DataUnit from '../../DataUnit.js';
2
+ import { Record } from '../../interfaces/dataUnit.js';
2
3
  import { Filter, Sort } from '../../metadata/UnitMetadata.js';
3
4
  import { LoadDataRequest } from '../../loading/LoadDataRequest.js';
4
5
  import { PaginationInfo } from '../../loading/PaginationInfo.js';
@@ -1,4 +1,4 @@
1
- import { QuickFilter } from "../DataUnit.js";
1
+ import { QuickFilter } from '../interfaces/dataUnit.js';
2
2
  import { Filter, Sort } from "../metadata/UnitMetadata.js";
3
3
 
4
4
  /** Atributos enviados na requisição de carregamento dos registros */
@@ -1,4 +1,4 @@
1
- import { Record } from "../DataUnit.js";
1
+ import { Record } from "../interfaces/dataUnit.js";
2
2
  import { PaginationInfo } from "./PaginationInfo.js";
3
3
 
4
4
  /** Retorno dos registros da requisição de carregamento de dados */
@@ -1,4 +1,4 @@
1
- import { Record } from '../DataUnit.js';
1
+ import { Record } from "../interfaces/dataUnit.js";
2
2
  import { compareValues } from '../metadata/DataType.js';
3
3
  import { FieldDescriptor } from '../metadata/UnitMetadata.js';
4
4
 
@@ -2,7 +2,7 @@
2
2
  import { ActionReducer, StateAction } from "../StateManager.js";
3
3
  import { Action } from "../action/DataUnitAction.js";
4
4
  import StateManager from "../StateManager.js";
5
- import { Record } from "../../DataUnit.js";
5
+ import { Record } from "../../interfaces/dataUnit.js";
6
6
 
7
7
  class AddedRecordsReducerImpl implements ActionReducer{
8
8
 
@@ -6,7 +6,8 @@ import { getSelection } from "./SelectionSlice.js";
6
6
  import { getRecords } from "./RecordsSlice.js";
7
7
  import { getRemovedRecords } from "./RemovedRecordsSlice.js";
8
8
  import { getAddedRecords, isAddedRecord } from "./AddedRecordsSlice.js";
9
- import { Change, ChangeOperation, Record } from "../../DataUnit.js";
9
+ import { ChangeOperation, Record } from "../../interfaces/dataUnit.js";
10
+ import { Change } from "../../Changes.js";
10
11
  import { getWaitingChanges } from "./WaitingChangesSlice.js";
11
12
  import { getSelectionRecords } from "./SnapshotSlice.js";
12
13
 
@@ -1,5 +1,4 @@
1
-
2
- import { ChangeOperation } from "../../DataUnit.js";
1
+ import { ChangeOperation } from "../../interfaces/dataUnit.js";
3
2
  import { LoadDataRequest } from "../../loading/LoadDataRequest.js";
4
3
  import { PaginationInfo } from "../../loading/PaginationInfo.js";
5
4
  import { Action } from "../action/DataUnitAction.js";
@@ -2,7 +2,8 @@ import { ActionReducer, StateAction } from "../StateManager.js";
2
2
  import StateManager from "../StateManager.js";
3
3
  import { getRemovedRecords } from "./RemovedRecordsSlice.js";
4
4
  import { Action } from "../action/DataUnitAction.js";
5
- import { Record, SavedRecord } from "../../DataUnit.js";
5
+ import { Record, SavedRecord } from "../../interfaces/dataUnit.js";
6
+
6
7
 
7
8
  class RecordsReducerImpl implements ActionReducer {
8
9
 
@@ -12,7 +13,7 @@ class RecordsReducerImpl implements ActionReducer {
12
13
  switch (action.type) {
13
14
 
14
15
  case Action.DATA_LOADED:
15
- return action.payload ? action.payload.records : undefined;
16
+ return action.payload ? action.payload.records : [];
16
17
  case Action.RECORDS_REMOVED:
17
18
 
18
19
  const {records, buffered} = action.payload;
@@ -2,7 +2,8 @@ import { ActionReducer, StateAction } from "../StateManager.js";
2
2
  import { Action } from "../action/DataUnitAction.js";
3
3
  import StateManager from "../StateManager.js";
4
4
  import { getCurrentRecords, getSelectionRecords } from "./SnapshotSlice.js";
5
- import { Record, SavedRecord, SelectionInfo, SelectionMode } from "../../DataUnit.js";
5
+ import { Record, SavedRecord, SelectionMode } from "../../interfaces/dataUnit.js";
6
+ import { SelectionInfo } from "../../SelectionInfo.js";
6
7
  import { getCurrentRequest, getPaginationInfo } from "./LoadingControlSlice.js";
7
8
  import { PaginationInfo } from "../../loading/PaginationInfo.js";
8
9
 
@@ -1,7 +1,7 @@
1
1
 
2
2
  import { ActionReducer } from "../StateManager.js";
3
3
  import StateManager from "../StateManager.js";
4
- import { Record } from "../../DataUnit.js";
4
+ import { Record } from "../../interfaces/dataUnit.js";
5
5
  import { getRecords } from "./RecordsSlice.js";
6
6
  import { getSelection } from "./SelectionSlice.js";
7
7
  import { getChangedFieldValue, getChanges } from "./ChangesSlice.js";
@@ -1,5 +1,5 @@
1
1
 
2
- import { WaitingChange } from "../../DataUnit.js";
2
+ import { WaitingChange } from "../../interfaces/dataUnit.js";
3
3
  import { Action } from "../action/DataUnitAction.js";
4
4
  import StateManager, { ActionReducer, StateAction } from "../StateManager.js";
5
5
 
@@ -1,7 +1,7 @@
1
1
 
2
2
  import * as RecordsReducerModule from '../RecordsSlice';
3
3
  import StateManager from '../../StateManager';
4
- import { Record } from '../../../DataUnit';
4
+ import { Record } from '../../../interfaces/dataUnit';
5
5
  import { Action } from '../../action/DataUnitAction';
6
6
 
7
7
  jest.spyOn(RecordsReducerModule, "getRecords").mockImplementation(() => [
package/src/index.ts CHANGED
@@ -9,7 +9,10 @@ import { HttpProvider } from "./http/HttpProvider.js";
9
9
  import { SkwHttpProvider } from "./http/SkwHttpProvider.js";
10
10
  import { RequestMetadata } from "./http/RequestMetadata.js";
11
11
  import { AuthorizedServiceCaller } from "./http/AuthorizedServiceCaller.js";
12
- import DataUnit, {SavedRecord, Record, Change, ChangeOperation, DUActionInterceptor, WaitingChange, PageRequest, QuickFilter, SelectionMode, SelectionInfo, DataUnitEventOptions} from "./dataunit/DataUnit.js";
12
+ import DataUnit from "./dataunit/DataUnit.js";
13
+ import {SavedRecord, Record, ChangeOperation, DUActionInterceptor, WaitingChange, PageRequest, QuickFilter, SelectionMode, DataUnitEventOptions} from "./dataunit/interfaces/dataUnit.js";
14
+ import { Change } from "./dataunit/Changes.js";
15
+ import { SelectionInfo } from "./dataunit/SelectionInfo.js";
13
16
  import { DataType } from "./dataunit/metadata/DataType.js";
14
17
  import { UnitMetadata, FieldDescriptor, UserInterface, Sort, SortMode, SortingProvider, Filter, DependencyType, ChildDescriptor, ChildLink } from "./dataunit/metadata/UnitMetadata.js";
15
18
  import { DataUnitAction, Action, ExecutionContext } from "./dataunit/state/action/DataUnitAction.js";
@@ -1,5 +1,6 @@
1
1
  import { Filter } from '../dataunit/metadata/UnitMetadata.js';
2
- import DataUnit, { Record } from '../dataunit/DataUnit.js';
2
+ import DataUnit from '../dataunit/DataUnit.js';
3
+ import { Record } from '../dataunit/interfaces/dataUnit.js';
3
4
  import { FieldComparator } from '../dataunit/sorting/FieldComparator.js';
4
5
  import { LoadDataRequest } from '../dataunit/loading/LoadDataRequest.js';
5
6
 
@@ -1,7 +1,7 @@
1
1
  import DataUnit from "../dataunit/DataUnit.js";
2
2
  import { FieldDescriptor, Sort, SortMode } from "../dataunit/metadata/UnitMetadata.js";
3
3
  import { FieldComparator } from "../dataunit/sorting/FieldComparator.js";
4
- import { Record } from '../dataunit/DataUnit.js';
4
+ import { Record } from '../dataunit/interfaces/dataUnit.js';
5
5
 
6
6
  /**
7
7
  * `SortingUtils`: Utilizado para auxiliar na ordenacao de registros.
@@ -0,0 +1,69 @@
1
+ import DataUnit from "../../src/dataunit/DataUnit";
2
+ import { createDataUnitMock } from "./loader/utils/createDataUnitMock";
3
+ import { metadata } from "./resources/metadata";
4
+
5
+ describe('Access parent dataUnits', () => {
6
+ let dataUnit: DataUnit;
7
+ let metadataLoaderMock = jest.fn();
8
+
9
+ beforeEach(() => {
10
+ jest.clearAllMocks();
11
+ window.requestAnimationFrame = (functionCallback: Function) => functionCallback();
12
+ ({ dataUnit, metadataLoaderMock } = createDataUnitMock());
13
+ });
14
+
15
+ describe('getChildInfo', () => {
16
+ beforeEach(async () => {
17
+ await dataUnit.loadMetadata();
18
+ await dataUnit.loadData();
19
+ });
20
+
21
+ it('should return metadata children data', () => {
22
+ const name = dataUnit.getChildInfo('child');
23
+ expect(name).toStrictEqual(metadata.children![0]);
24
+ });
25
+
26
+ it('should return undefined when dont has metadata', async () => {
27
+ metadataLoaderMock.mockResolvedValue(undefined);
28
+ await dataUnit.loadMetadata();
29
+ const name = dataUnit.getChildInfo('child');
30
+ expect(name).toBeUndefined();
31
+ });
32
+
33
+ it('should return undefined when dont has metadata children data', async () => {
34
+ metadataLoaderMock.mockResolvedValue({ ...metadata, children: undefined });
35
+ await dataUnit.loadMetadata();
36
+ const name = dataUnit.getChildInfo('child');
37
+ expect(name).toBeUndefined();
38
+ });
39
+ });
40
+
41
+ describe('getParentDataUnit', () => {
42
+ it('should return parent dataUnit', () => {
43
+ const childDataUnit = new DataUnit('child', dataUnit);
44
+ const parentDataUnit = childDataUnit.getParentDataUnit();
45
+ expect(parentDataUnit).toStrictEqual(dataUnit);
46
+ });
47
+ });
48
+
49
+ describe('isParentDirty', () => {
50
+ it('should return true when parent is dirty', async () => {
51
+ dataUnit.selectFirst();
52
+ await dataUnit.setFieldValue('column_name_1', 'new_value');
53
+ const childDataUnit = new DataUnit('child', dataUnit);
54
+ const parentIsDirty = childDataUnit.isParentDirty();
55
+ expect(parentIsDirty).toBeTruthy();
56
+ });
57
+
58
+ it('should return false when parent is not dirty', () => {
59
+ const childDataUnit = new DataUnit('child', dataUnit);
60
+ const parentIsDirty = childDataUnit.isParentDirty();
61
+ expect(parentIsDirty).toBeFalsy();
62
+ });
63
+
64
+ it('should return false when dont has parent', () => {
65
+ const parentIsDirty = dataUnit.isParentDirty();
66
+ expect(parentIsDirty).toBeFalsy();
67
+ });
68
+ });
69
+ });
@@ -0,0 +1,74 @@
1
+ import DataUnit from "../../src/dataunit/DataUnit";
2
+ import { Action, DataUnitAction } from "../../src/dataunit/state/action/DataUnitAction";
3
+ import { createDataUnitMock } from "./loader/utils/createDataUnitMock";
4
+ import { recordsTest } from "./resources/records";
5
+
6
+ describe('Actions', () => {
7
+ let dataUnit: DataUnit;
8
+
9
+ beforeEach(() => {
10
+ jest.clearAllMocks();
11
+ window.requestAnimationFrame = (functionCallback: Function) => functionCallback();
12
+ ({ dataUnit } = createDataUnitMock());
13
+ });
14
+
15
+ describe('savingCanceled', () => {
16
+ it('should emit event savingCanceled', async () => {
17
+ const savingCanceled = jest.fn();
18
+ const observer = async (action: DataUnitAction) => {
19
+ if (action.type === Action.SAVING_CANCELED) {
20
+ savingCanceled();
21
+ }
22
+ return;
23
+ }
24
+ dataUnit.subscribe(observer);
25
+ dataUnit.selectFirst();
26
+ await dataUnit.setFieldValue('column_name_1', 'new_value');
27
+ dataUnit.savingCanceled([{ name: 'column_name_1', message: 'cancel_saving' }], 'test_1');
28
+ expect(savingCanceled).toHaveBeenCalled();
29
+ });
30
+ });
31
+
32
+ describe('clearInvalid', () => {
33
+ beforeEach(async () => {
34
+ await dataUnit.loadMetadata();
35
+ await dataUnit.loadData();
36
+ });
37
+
38
+ it('should emit event savingCanceled', async () => {
39
+ const invalidateClean = jest.fn();
40
+ const observer = async (action: DataUnitAction) => {
41
+ if (action.type === Action.INVALIDATE_CLEAN) {
42
+ invalidateClean();
43
+ }
44
+ return;
45
+ }
46
+ dataUnit.subscribe(observer);
47
+ dataUnit.selectFirst();
48
+ await dataUnit.setFieldValue('column_name_1', 'new_value');
49
+ dataUnit.clearInvalid('test_1', 'column_name_1');
50
+ expect(invalidateClean).toHaveBeenCalled();
51
+ });
52
+ });
53
+
54
+ describe('redo', () => {
55
+ beforeEach(async () => {
56
+ await dataUnit.loadMetadata();
57
+ await dataUnit.loadData();
58
+ const saveLoaderMock = jest.fn().mockResolvedValue(recordsTest);
59
+ dataUnit.saveLoader = saveLoaderMock;
60
+ });
61
+
62
+
63
+ it('should return true when field value changes can redo', async () => {
64
+ dataUnit.selectFirst();
65
+ await dataUnit.setFieldValue('column_name_1', 'new_value');
66
+ dataUnit.undo();
67
+ let fieldValue = dataUnit.getFieldValue('column_name_1');
68
+ expect(fieldValue).toBe('column_value_1');
69
+ dataUnit.redo();
70
+ fieldValue = dataUnit.getFieldValue('column_name_1');
71
+ expect(fieldValue).toBe('new_value');
72
+ });
73
+ });
74
+ });
@@ -0,0 +1,66 @@
1
+ import { Change } from "../../src/dataunit/Changes";
2
+ import { ChangeOperation } from "../../src/dataunit/interfaces/dataUnit";
3
+
4
+ describe('Change', () => {
5
+ let change: Change;
6
+ beforeEach(() => {
7
+ change = new Change(
8
+ 'test',
9
+ { __record__id__: 'test_1' },
10
+ undefined,
11
+ ChangeOperation.COPY,
12
+ 'source_id',
13
+ );
14
+ });
15
+
16
+ it('should return operation', () => {
17
+ const response = change.operation;
18
+ expect(response).toBe('COPY');
19
+ });
20
+
21
+ it('should return false when operation is not insert', () => {
22
+ const response = change.isInsert();
23
+ expect(response).toBeFalsy();
24
+ });
25
+
26
+ it('should return true when operation is insert', () => {
27
+ change = new Change(
28
+ 'test',
29
+ { __record__id__: 'test_1' },
30
+ undefined,
31
+ ChangeOperation.INSERT,
32
+ 'source_id',
33
+ );
34
+ const response = change.isInsert();
35
+ expect(response).toBeTruthy();
36
+ });
37
+
38
+ it('should return true when operation is copy', () => {
39
+ const response = change.isCopy();
40
+ expect(response).toBeTruthy();
41
+ });
42
+
43
+ it('should return true when operation is delete', () => {
44
+ change = new Change(
45
+ 'test',
46
+ { __record__id__: 'test_1' },
47
+ undefined,
48
+ ChangeOperation.DELETE,
49
+ 'source_id',
50
+ );
51
+ const response = change.isDelete();
52
+ expect(response).toBeTruthy();
53
+ });
54
+
55
+ it('should return true when operation is update', () => {
56
+ change = new Change(
57
+ 'test',
58
+ { __record__id__: 'test_1' },
59
+ undefined,
60
+ ChangeOperation.UPDATE,
61
+ 'source_id',
62
+ );
63
+ const response = change.isUpdate();
64
+ expect(response).toBeTruthy();
65
+ });
66
+ });