@zeedhi/teknisa-components-common 1.108.0 → 1.109.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -21
- package/README.md +7 -7
- package/coverage/clover.xml +49 -49
- package/coverage/coverage-final.json +47 -47
- package/coverage/lcov-report/index.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/component-event-helper.ts.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/flush-promises-helper.ts.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/get-child-helper.ts.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/index.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/index.ts.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/mock-created-helper.ts.html +1 -1
- package/coverage/lcov.info +47 -47
- package/jest.config.js +1 -1
- package/package.json +2 -2
- package/tests/__helpers__/component-event-helper.ts +5 -5
- package/tests/__helpers__/flush-promises-helper.ts +3 -3
- package/tests/__helpers__/get-child-helper.ts +27 -27
- package/tests/__helpers__/index.ts +3 -3
- package/tests/__helpers__/mock-created-helper.ts +12 -12
- package/tests/__mocks__/@zeedhi/core/i18n.js +74 -74
- package/tests/__mocks__/@zeedhi/core.js +4 -4
- package/tests/unit/components/crud/crud-add-button.spec.ts +56 -56
- package/tests/unit/components/crud/crud-button.spec.ts +94 -94
- package/tests/unit/components/crud/crud-cancel-button.spec.ts +91 -91
- package/tests/unit/components/crud/crud-delete-button.spec.ts +122 -122
- package/tests/unit/components/crud/crud-form.spec.ts +165 -165
- package/tests/unit/components/crud/crud-save-button.spec.ts +118 -118
- package/tests/unit/components/tek-breadcrumb-header/tek-breadcrumb-header.spec.ts +42 -42
- package/tests/unit/components/tek-card-title/CardTitle.spec.ts +34 -34
- package/tests/unit/components/tek-datasource/memory-datasource.spec.ts +470 -470
- package/tests/unit/components/tek-datasource/rest-datasource.spec.ts +364 -364
- package/tests/unit/components/tek-drag-grid/tek-drag-grid.spec.ts +112 -112
- package/tests/unit/components/tek-grid/filter-helper.spec.ts +148 -148
- package/tests/unit/components/tek-grid/grid-column.spec.ts +270 -270
- package/tests/unit/components/tek-grid/grid-columns-button.spec.ts +195 -195
- package/tests/unit/components/tek-grid/grid-filter-button.spec.ts +967 -967
- package/tests/unit/components/tek-grid/grid.spec.ts +3340 -3340
- package/tests/unit/components/tek-grid/layout_options.spec.ts +980 -980
- package/tests/unit/components/tek-image/Image.spec.ts +67 -67
- package/tests/unit/components/tek-iterable-carousel/iterable-carousel.spec.ts +37 -37
- package/tests/unit/components/tek-iterable-component-render/iterable-component-render.spec.ts +200 -200
- package/tests/unit/components/tek-loading/Loading.spec.ts +30 -30
- package/tests/unit/components/tek-notifications/notifications.spec.ts +201 -201
- package/tests/unit/components/tek-product-card/product-card.spec.ts +61 -61
- package/tests/unit/components/tek-user-info/TekUserInfoContoller.spec.ts +220 -220
- package/tests/unit/components/tek-user-info/tek-user-info-list.spec.ts +86 -86
- package/tests/unit/components/tek-user-info/tek-user-info.spec.ts +430 -430
- package/tests/unit/components/tree-grid/tree-grid.spec.ts +776 -776
- package/tests/unit/utils/grid-base/delete-rows-error.spec.ts +24 -24
- package/tests/unit/utils/grid-base/export-options/button-option.spec.ts +44 -44
- package/tests/unit/utils/grid-base/export-options/multi-option.spec.ts +135 -135
- package/tests/unit/utils/grid-base/grid-controller.spec.ts +267 -267
- package/tests/unit/utils/report-filter/report-filter.spec.ts +66 -66
- package/tsconfig.eslint.json +8 -8
- package/types/components/tek-ag-grid/default-icons.d.ts +53 -0
- package/types/components/tek-ag-grid/interfaces.d.ts +9 -0
- package/types/components/tek-ag-grid/tek-ag-grid.d.ts +35 -0
- package/types/components/tek-datasource/datasource.d.ts +94 -0
- package/types/components/tek-datasource/memory-datasource.d.ts +4 -2
- package/types/components/tek-datasource/rest-datasource.d.ts +3 -6
- package/types/components/tek-grid/default-icons.d.ts +53 -0
- package/types/components/tek-grid/filter-dynamic-values.d.ts +9 -0
- package/types/components/tek-grid/grid-controller.d.ts +19 -0
- package/types/components/tek-grid/grid_column.d.ts +14 -0
- package/types/components/tek-grid/grid_controller.d.ts +15 -0
- package/types/components/tek-grid/tek-grid.d.ts +35 -0
- package/types/components/tek-login/interfaces.d.ts +3 -0
- package/types/components/tek-login/login-children.d.ts +3 -0
- package/types/components/tek-login/login.d.ts +58 -0
- package/types/components/tek-login/login_children.d.ts +3 -0
|
@@ -1,470 +1,470 @@
|
|
|
1
|
-
import {
|
|
2
|
-
init,
|
|
3
|
-
Router,
|
|
4
|
-
URL,
|
|
5
|
-
} from '@zeedhi/core';
|
|
6
|
-
import {
|
|
7
|
-
TekMemoryDatasource, ITekMemoryDatasource,
|
|
8
|
-
} from '../../../../src';
|
|
9
|
-
|
|
10
|
-
describe('TekMemoryDatasource', () => {
|
|
11
|
-
init({
|
|
12
|
-
controllers: {
|
|
13
|
-
AppController: class AppController {
|
|
14
|
-
public value = '1';
|
|
15
|
-
},
|
|
16
|
-
},
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
let datasource: ITekMemoryDatasource;
|
|
20
|
-
let router: any;
|
|
21
|
-
|
|
22
|
-
beforeEach(() => {
|
|
23
|
-
datasource = {
|
|
24
|
-
uniqueKey: 'id',
|
|
25
|
-
data: [
|
|
26
|
-
{ name: 'name 1', id: 1 }, { name: 'name 2', id: 2 }, { name: 'name 3', id: 3 },
|
|
27
|
-
{ name: 'name 4', id: 4 }, { name: 'name 5', id: 5 }, { name: 'name 6', id: 6 },
|
|
28
|
-
],
|
|
29
|
-
};
|
|
30
|
-
router = {
|
|
31
|
-
push: () => jest.fn,
|
|
32
|
-
replace: (route: any) => {
|
|
33
|
-
window.history.replaceState(null, '', `${window.location.pathname}?${URL.getFormattedQueryString(route.query)}`);
|
|
34
|
-
},
|
|
35
|
-
back: () => jest.fn,
|
|
36
|
-
getCurrentRoute: () => ({
|
|
37
|
-
path: '',
|
|
38
|
-
hash: '',
|
|
39
|
-
query: {},
|
|
40
|
-
params: {},
|
|
41
|
-
fullPath: '',
|
|
42
|
-
}),
|
|
43
|
-
getPath: () => '',
|
|
44
|
-
getHash: () => '',
|
|
45
|
-
getQuery: () => ({}),
|
|
46
|
-
getParams: () => ({}),
|
|
47
|
-
getFullPath: () => '',
|
|
48
|
-
};
|
|
49
|
-
Router.setInstance(router);
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
describe('constuctor()', () => {
|
|
53
|
-
it('should assign all properties', async () => {
|
|
54
|
-
const flushPromises = () => new Promise(setImmediate);
|
|
55
|
-
const instance = new TekMemoryDatasource({
|
|
56
|
-
...datasource,
|
|
57
|
-
dynamicFilter: {
|
|
58
|
-
name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }],
|
|
59
|
-
},
|
|
60
|
-
searchJoin: { col1: ['1', '2'], col2: [2], col3: [] },
|
|
61
|
-
});
|
|
62
|
-
await flushPromises();
|
|
63
|
-
|
|
64
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
65
|
-
expect(instance.searchJoin).toEqual({ col1: ['1', '2'], col2: [2], col3: [] });
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it('should assign all properties with accessor', async () => {
|
|
69
|
-
const flushPromises = () => new Promise(setImmediate);
|
|
70
|
-
const instance = new TekMemoryDatasource({
|
|
71
|
-
...datasource,
|
|
72
|
-
dynamicFilter: {
|
|
73
|
-
name: [{ operation: 'EQUALS', relation: 'AND', value: '{{AppController.value}}' }],
|
|
74
|
-
},
|
|
75
|
-
searchJoin: { col1: ['1', '2'], col2: [2], col3: [] },
|
|
76
|
-
});
|
|
77
|
-
await flushPromises();
|
|
78
|
-
|
|
79
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
80
|
-
expect(instance.searchJoin).toEqual({ col1: ['1', '2'], col2: [2], col3: [] });
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
it('should create using default parameters', async () => {
|
|
84
|
-
const instance = new TekMemoryDatasource({});
|
|
85
|
-
|
|
86
|
-
expect(instance.dynamicFilter).toEqual({});
|
|
87
|
-
expect(instance.searchJoin).toEqual({});
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
it('should set values from url', () => {
|
|
91
|
-
router.getFullPath = () => 'localhost/?page=2&limit=10&order=id.asc&search=2&id=1';
|
|
92
|
-
const instance = new TekMemoryDatasource({
|
|
93
|
-
...datasource,
|
|
94
|
-
watchUrl: true,
|
|
95
|
-
});
|
|
96
|
-
expect(instance.filter).toEqual({ id: '1' });
|
|
97
|
-
expect(instance.limit).toBe(10);
|
|
98
|
-
expect(instance.order).toEqual(['id.asc']);
|
|
99
|
-
expect(instance.page).toBe(2);
|
|
100
|
-
expect(instance.search).toBe('2');
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
it('should set dynamicFilter from url', () => {
|
|
104
|
-
router.getFullPath = () => 'localhost/?dynamic_filter=eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMSJ9XX0='; // eslint-disable-line max-len
|
|
105
|
-
datasource.watchUrl = true;
|
|
106
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
107
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
it('should set searchJoin from url', () => {
|
|
111
|
-
router.getFullPath = () => 'localhost/?search_join=eyAiY29sMSI6IFsiMSIsICIyIl0sICJjb2wyIjogWzJdLCAiY29sMyI6IFtdIH0='; // eslint-disable-line max-len
|
|
112
|
-
datasource.watchUrl = true;
|
|
113
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
114
|
-
expect(instance.searchJoin).toEqual({ col1: ['1', '2'], col2: [2], col3: [] });
|
|
115
|
-
});
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
describe('dynamicFilter', () => {
|
|
119
|
-
it('should retrieve data using dynamic filter', async () => {
|
|
120
|
-
const flushPromises = () => new Promise(setImmediate);
|
|
121
|
-
datasource.watchUrl = false;
|
|
122
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
123
|
-
|
|
124
|
-
await flushPromises();
|
|
125
|
-
expect(instance.data.length).toBe(6);
|
|
126
|
-
|
|
127
|
-
instance.dynamicFilter = {
|
|
128
|
-
name: [
|
|
129
|
-
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
130
|
-
],
|
|
131
|
-
};
|
|
132
|
-
await instance.get();
|
|
133
|
-
expect(instance.data.length).toBe(1);
|
|
134
|
-
|
|
135
|
-
instance.dynamicFilter = {
|
|
136
|
-
name: [
|
|
137
|
-
{ operation: 'CONTAINS', relation: 'AND', value: 'name' },
|
|
138
|
-
],
|
|
139
|
-
};
|
|
140
|
-
await instance.get();
|
|
141
|
-
expect(instance.data.length).toBe(6);
|
|
142
|
-
|
|
143
|
-
instance.dynamicFilter = {
|
|
144
|
-
name: [
|
|
145
|
-
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
146
|
-
{ operation: 'CONTAINS', relation: 'OR', value: '2' },
|
|
147
|
-
],
|
|
148
|
-
};
|
|
149
|
-
await instance.get();
|
|
150
|
-
expect(instance.data.length).toBe(2);
|
|
151
|
-
|
|
152
|
-
instance.dynamicFilter = {
|
|
153
|
-
name: [
|
|
154
|
-
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
155
|
-
{ operation: 'CONTAINS', relation: 'AND', value: '2' },
|
|
156
|
-
],
|
|
157
|
-
};
|
|
158
|
-
await instance.get();
|
|
159
|
-
expect(instance.data.length).toBe(0);
|
|
160
|
-
|
|
161
|
-
instance.dynamicFilter = {
|
|
162
|
-
name: [
|
|
163
|
-
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
164
|
-
],
|
|
165
|
-
id: [
|
|
166
|
-
{ operation: 'CONTAINS', relation: 'OR', value: '2' },
|
|
167
|
-
],
|
|
168
|
-
};
|
|
169
|
-
await instance.get();
|
|
170
|
-
expect(instance.data.length).toBe(2);
|
|
171
|
-
|
|
172
|
-
instance.dynamicFilter = {
|
|
173
|
-
name: [
|
|
174
|
-
{ operation: 'NOT_CONTAINS', relation: 'AND', value: '1' },
|
|
175
|
-
],
|
|
176
|
-
};
|
|
177
|
-
await instance.get();
|
|
178
|
-
expect(instance.data.length).toBe(5);
|
|
179
|
-
|
|
180
|
-
instance.dynamicFilter = {
|
|
181
|
-
name: [
|
|
182
|
-
{ operation: 'EQUALS', relation: 'AND', value: '1' },
|
|
183
|
-
],
|
|
184
|
-
};
|
|
185
|
-
await instance.get();
|
|
186
|
-
expect(instance.data.length).toBe(0);
|
|
187
|
-
|
|
188
|
-
instance.dynamicFilter = {
|
|
189
|
-
name: [
|
|
190
|
-
{ operation: 'EQUALS', relation: 'AND', value: 'name 1' },
|
|
191
|
-
],
|
|
192
|
-
};
|
|
193
|
-
await instance.get();
|
|
194
|
-
expect(instance.data.length).toBe(1);
|
|
195
|
-
|
|
196
|
-
instance.dynamicFilter = {
|
|
197
|
-
name: [
|
|
198
|
-
{ operation: 'NOT_EQUALS', relation: 'AND', value: 'name 1' },
|
|
199
|
-
],
|
|
200
|
-
};
|
|
201
|
-
await instance.get();
|
|
202
|
-
expect(instance.data.length).toBe(5);
|
|
203
|
-
|
|
204
|
-
instance.dynamicFilter = {
|
|
205
|
-
id: [
|
|
206
|
-
{ operation: 'GREATER_THAN', relation: 'AND', value: '2' },
|
|
207
|
-
],
|
|
208
|
-
};
|
|
209
|
-
await instance.get();
|
|
210
|
-
expect(instance.data.length).toBe(4);
|
|
211
|
-
|
|
212
|
-
instance.dynamicFilter = {
|
|
213
|
-
id: [
|
|
214
|
-
{ operation: 'LESS_THAN', relation: 'AND', value: '2' },
|
|
215
|
-
],
|
|
216
|
-
};
|
|
217
|
-
await instance.get();
|
|
218
|
-
expect(instance.data.length).toBe(1);
|
|
219
|
-
|
|
220
|
-
instance.dynamicFilter = {
|
|
221
|
-
id: [
|
|
222
|
-
{ operation: 'GREATER_THAN_EQUALS', relation: 'AND', value: '2' },
|
|
223
|
-
],
|
|
224
|
-
};
|
|
225
|
-
await instance.get();
|
|
226
|
-
expect(instance.data.length).toBe(5);
|
|
227
|
-
|
|
228
|
-
instance.dynamicFilter = {
|
|
229
|
-
id: [
|
|
230
|
-
{ operation: 'LESS_THAN_EQUALS', relation: 'AND', value: '2' },
|
|
231
|
-
],
|
|
232
|
-
};
|
|
233
|
-
await instance.get();
|
|
234
|
-
expect(instance.data.length).toBe(2);
|
|
235
|
-
|
|
236
|
-
instance.dynamicFilter = {
|
|
237
|
-
name: [
|
|
238
|
-
{ operation: 'GREATER_THAN', relation: 'AND', value: 'name 2' },
|
|
239
|
-
],
|
|
240
|
-
};
|
|
241
|
-
await instance.get();
|
|
242
|
-
expect(instance.data.length).toBe(4);
|
|
243
|
-
|
|
244
|
-
instance.dynamicFilter = {
|
|
245
|
-
name: [
|
|
246
|
-
{ operation: 'LESS_THAN', relation: 'AND', value: 'name 2' },
|
|
247
|
-
],
|
|
248
|
-
};
|
|
249
|
-
await instance.get();
|
|
250
|
-
expect(instance.data.length).toBe(1);
|
|
251
|
-
|
|
252
|
-
instance.dynamicFilter = {
|
|
253
|
-
name: [
|
|
254
|
-
{ operation: 'GREATER_THAN_EQUALS', relation: 'AND', value: 'name 2' },
|
|
255
|
-
],
|
|
256
|
-
};
|
|
257
|
-
await instance.get();
|
|
258
|
-
expect(instance.data.length).toBe(5);
|
|
259
|
-
|
|
260
|
-
instance.dynamicFilter = {
|
|
261
|
-
name: [
|
|
262
|
-
{ operation: 'LESS_THAN_EQUALS', relation: 'AND', value: 'name 2' },
|
|
263
|
-
],
|
|
264
|
-
};
|
|
265
|
-
await instance.get();
|
|
266
|
-
expect(instance.data.length).toBe(2);
|
|
267
|
-
|
|
268
|
-
instance.dynamicFilter = {
|
|
269
|
-
id: [
|
|
270
|
-
{ operation: 'IN', relation: 'AND', value: ['1', '2'] },
|
|
271
|
-
],
|
|
272
|
-
};
|
|
273
|
-
await instance.get();
|
|
274
|
-
expect(instance.data.length).toBe(2);
|
|
275
|
-
|
|
276
|
-
instance.dynamicFilter = {
|
|
277
|
-
id: [
|
|
278
|
-
{ operation: 'NOT_IN', relation: 'AND', value: ['1', '2'] },
|
|
279
|
-
],
|
|
280
|
-
};
|
|
281
|
-
await instance.get();
|
|
282
|
-
expect(instance.data.length).toBe(4);
|
|
283
|
-
|
|
284
|
-
instance.dynamicFilter = {
|
|
285
|
-
id: [
|
|
286
|
-
{ operation: 'BETWEEN', relation: 'AND', value: ['2', '5'] },
|
|
287
|
-
],
|
|
288
|
-
};
|
|
289
|
-
await instance.get();
|
|
290
|
-
expect(instance.data.length).toBe(4);
|
|
291
|
-
|
|
292
|
-
instance.dynamicFilter = {
|
|
293
|
-
name: [
|
|
294
|
-
{ operation: 'BETWEEN', relation: 'AND', value: ['name 2', 'name 5'] },
|
|
295
|
-
],
|
|
296
|
-
};
|
|
297
|
-
await instance.get();
|
|
298
|
-
expect(instance.data.length).toBe(4);
|
|
299
|
-
|
|
300
|
-
instance.dynamicFilter = {
|
|
301
|
-
name: [
|
|
302
|
-
{ operation: '', relation: 'AND', value: ['1', '2'] },
|
|
303
|
-
],
|
|
304
|
-
};
|
|
305
|
-
await instance.get();
|
|
306
|
-
expect(instance.data.length).toBe(0);
|
|
307
|
-
|
|
308
|
-
instance.dynamicFilter = {
|
|
309
|
-
name: [
|
|
310
|
-
{ operation: '', relation: 'AND', value: '1' },
|
|
311
|
-
],
|
|
312
|
-
};
|
|
313
|
-
await instance.get();
|
|
314
|
-
expect(instance.data.length).toBe(0);
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
it('should not retrieve data with wrong operator', async () => {
|
|
318
|
-
const flushPromises = () => new Promise(setImmediate);
|
|
319
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
320
|
-
|
|
321
|
-
await flushPromises();
|
|
322
|
-
expect(instance.data.length).toBe(6);
|
|
323
|
-
|
|
324
|
-
instance.dynamicFilter = {
|
|
325
|
-
name: [
|
|
326
|
-
{ operation: 'TEST', relation: 'AND', value: '1' },
|
|
327
|
-
],
|
|
328
|
-
};
|
|
329
|
-
await instance.get();
|
|
330
|
-
expect(instance.data.length).toBe(0);
|
|
331
|
-
});
|
|
332
|
-
});
|
|
333
|
-
|
|
334
|
-
describe('searchJoin', () => {
|
|
335
|
-
it('should retrieve data using search join', async () => {
|
|
336
|
-
const flushPromises = () => new Promise(setImmediate);
|
|
337
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
338
|
-
|
|
339
|
-
await flushPromises();
|
|
340
|
-
expect(instance.data.length).toBe(6);
|
|
341
|
-
|
|
342
|
-
instance.searchJoin = {
|
|
343
|
-
name: ['name 1', 'name 2'],
|
|
344
|
-
};
|
|
345
|
-
instance.search = 'aaa';
|
|
346
|
-
await instance.get();
|
|
347
|
-
expect(instance.data.length).toBe(2);
|
|
348
|
-
});
|
|
349
|
-
});
|
|
350
|
-
|
|
351
|
-
describe('addDynamicFilter()', () => {
|
|
352
|
-
it('should add/remove dynamic filter value', () => {
|
|
353
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
354
|
-
instance.addDynamicFilter('name', [{ operation: 'EQUALS', relation: 'AND', value: '1' }]);
|
|
355
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
356
|
-
instance.addDynamicFilter('name', [{ operation: 'foo', relation: 'AND', value: '1' }]);
|
|
357
|
-
expect(instance.dynamicFilter).toEqual({});
|
|
358
|
-
});
|
|
359
|
-
});
|
|
360
|
-
|
|
361
|
-
describe('setDynamicFilter()', () => {
|
|
362
|
-
it('should add/remove dynamic filter value', () => {
|
|
363
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
364
|
-
instance.setDynamicFilter({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
365
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
366
|
-
|
|
367
|
-
instance.setDynamicFilter({ name: [{ operation: 'foo', relation: 'AND', value: '1' }] });
|
|
368
|
-
expect(instance.dynamicFilter).toEqual({});
|
|
369
|
-
|
|
370
|
-
instance.setDynamicFilter({
|
|
371
|
-
name: [], id: [{}],
|
|
372
|
-
});
|
|
373
|
-
expect(instance.dynamicFilter).toEqual({});
|
|
374
|
-
});
|
|
375
|
-
|
|
376
|
-
it('should add dynamic filter value with watchUrl', () => {
|
|
377
|
-
let dynamicFilterValue = 'eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMSJ9XX0=';
|
|
378
|
-
router.getFullPath = () => `localhost/?dynamic_filter=${dynamicFilterValue}`;
|
|
379
|
-
const urlSpy = jest.spyOn(URL, 'updateQueryString');
|
|
380
|
-
|
|
381
|
-
datasource.watchUrl = true;
|
|
382
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
383
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
384
|
-
|
|
385
|
-
dynamicFilterValue = 'eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMiJ9XX0=';
|
|
386
|
-
instance.setDynamicFilter({ name: [{ operation: 'EQUALS', relation: 'AND', value: '2' }] });
|
|
387
|
-
expect(urlSpy).toHaveBeenCalledWith({
|
|
388
|
-
dynamic_filter: dynamicFilterValue,
|
|
389
|
-
});
|
|
390
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '2' }] });
|
|
391
|
-
urlSpy.mockClear();
|
|
392
|
-
});
|
|
393
|
-
|
|
394
|
-
it('deve chamar setDynamicFilter ao usar setBaseFilter', () => {
|
|
395
|
-
const ds = new TekMemoryDatasource({ uniqueKey: 'id', data: [] });
|
|
396
|
-
const filtro = { ativo: true };
|
|
397
|
-
const spy = jest.spyOn(ds, 'setDynamicFilter');
|
|
398
|
-
|
|
399
|
-
ds.setBaseFilter(filtro);
|
|
400
|
-
|
|
401
|
-
expect(spy).toHaveBeenCalledWith(filtro);
|
|
402
|
-
});
|
|
403
|
-
});
|
|
404
|
-
|
|
405
|
-
describe('clearDynamicFilter()', () => {
|
|
406
|
-
it('should clear dynamic filter', () => {
|
|
407
|
-
datasource.watchUrl = false;
|
|
408
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
409
|
-
instance.setDynamicFilter({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
410
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
411
|
-
instance.clearDynamicFilter();
|
|
412
|
-
expect(instance.dynamicFilter).toEqual({});
|
|
413
|
-
});
|
|
414
|
-
|
|
415
|
-
it('should clear dynamic filter value with watchUrl', () => {
|
|
416
|
-
let dynamicFilterValue = 'eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMSJ9XX0=';
|
|
417
|
-
router.getFullPath = () => `localhost/?dynamic_filter=${dynamicFilterValue}`;
|
|
418
|
-
const urlSpy = jest.spyOn(URL, 'updateQueryString');
|
|
419
|
-
|
|
420
|
-
datasource.watchUrl = true;
|
|
421
|
-
const instance = new TekMemoryDatasource(datasource);
|
|
422
|
-
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
423
|
-
|
|
424
|
-
dynamicFilterValue = '';
|
|
425
|
-
instance.clearDynamicFilter();
|
|
426
|
-
expect(urlSpy).toHaveBeenCalledWith({
|
|
427
|
-
dynamic_filter: undefined,
|
|
428
|
-
});
|
|
429
|
-
expect(instance.dynamicFilter).toEqual({});
|
|
430
|
-
urlSpy.mockClear();
|
|
431
|
-
});
|
|
432
|
-
});
|
|
433
|
-
|
|
434
|
-
describe('clone', () => {
|
|
435
|
-
it('should return an object with all datasource props', async () => {
|
|
436
|
-
const data = [{ value: 'item 1' }];
|
|
437
|
-
const dynamicFilter = {
|
|
438
|
-
name: { operation: 'EQUALS', relation: 'AND', value: 'item 1' },
|
|
439
|
-
};
|
|
440
|
-
const searchJoin = { col1: ['1', '2'], col2: [2], col3: [] };
|
|
441
|
-
const instance = new TekMemoryDatasource({
|
|
442
|
-
route: '/zeedhi',
|
|
443
|
-
data,
|
|
444
|
-
dynamicFilter,
|
|
445
|
-
searchJoin,
|
|
446
|
-
});
|
|
447
|
-
|
|
448
|
-
const props = instance.clone();
|
|
449
|
-
|
|
450
|
-
expect(props).toEqual({
|
|
451
|
-
data,
|
|
452
|
-
dynamicFilter,
|
|
453
|
-
searchJoin,
|
|
454
|
-
currentRow: {},
|
|
455
|
-
filter: {},
|
|
456
|
-
limit: 10,
|
|
457
|
-
order: [],
|
|
458
|
-
page: 1,
|
|
459
|
-
search: '',
|
|
460
|
-
searchIn: [],
|
|
461
|
-
uniqueKey: 'id',
|
|
462
|
-
watchUrl: false,
|
|
463
|
-
events: {},
|
|
464
|
-
loadAll: false,
|
|
465
|
-
type: 'tek-memory',
|
|
466
|
-
translate: false,
|
|
467
|
-
});
|
|
468
|
-
});
|
|
469
|
-
});
|
|
470
|
-
});
|
|
1
|
+
import {
|
|
2
|
+
init,
|
|
3
|
+
Router,
|
|
4
|
+
URL,
|
|
5
|
+
} from '@zeedhi/core';
|
|
6
|
+
import {
|
|
7
|
+
TekMemoryDatasource, ITekMemoryDatasource,
|
|
8
|
+
} from '../../../../src';
|
|
9
|
+
|
|
10
|
+
describe('TekMemoryDatasource', () => {
|
|
11
|
+
init({
|
|
12
|
+
controllers: {
|
|
13
|
+
AppController: class AppController {
|
|
14
|
+
public value = '1';
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
let datasource: ITekMemoryDatasource;
|
|
20
|
+
let router: any;
|
|
21
|
+
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
datasource = {
|
|
24
|
+
uniqueKey: 'id',
|
|
25
|
+
data: [
|
|
26
|
+
{ name: 'name 1', id: 1 }, { name: 'name 2', id: 2 }, { name: 'name 3', id: 3 },
|
|
27
|
+
{ name: 'name 4', id: 4 }, { name: 'name 5', id: 5 }, { name: 'name 6', id: 6 },
|
|
28
|
+
],
|
|
29
|
+
};
|
|
30
|
+
router = {
|
|
31
|
+
push: () => jest.fn,
|
|
32
|
+
replace: (route: any) => {
|
|
33
|
+
window.history.replaceState(null, '', `${window.location.pathname}?${URL.getFormattedQueryString(route.query)}`);
|
|
34
|
+
},
|
|
35
|
+
back: () => jest.fn,
|
|
36
|
+
getCurrentRoute: () => ({
|
|
37
|
+
path: '',
|
|
38
|
+
hash: '',
|
|
39
|
+
query: {},
|
|
40
|
+
params: {},
|
|
41
|
+
fullPath: '',
|
|
42
|
+
}),
|
|
43
|
+
getPath: () => '',
|
|
44
|
+
getHash: () => '',
|
|
45
|
+
getQuery: () => ({}),
|
|
46
|
+
getParams: () => ({}),
|
|
47
|
+
getFullPath: () => '',
|
|
48
|
+
};
|
|
49
|
+
Router.setInstance(router);
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
describe('constuctor()', () => {
|
|
53
|
+
it('should assign all properties', async () => {
|
|
54
|
+
const flushPromises = () => new Promise(setImmediate);
|
|
55
|
+
const instance = new TekMemoryDatasource({
|
|
56
|
+
...datasource,
|
|
57
|
+
dynamicFilter: {
|
|
58
|
+
name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }],
|
|
59
|
+
},
|
|
60
|
+
searchJoin: { col1: ['1', '2'], col2: [2], col3: [] },
|
|
61
|
+
});
|
|
62
|
+
await flushPromises();
|
|
63
|
+
|
|
64
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
65
|
+
expect(instance.searchJoin).toEqual({ col1: ['1', '2'], col2: [2], col3: [] });
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it('should assign all properties with accessor', async () => {
|
|
69
|
+
const flushPromises = () => new Promise(setImmediate);
|
|
70
|
+
const instance = new TekMemoryDatasource({
|
|
71
|
+
...datasource,
|
|
72
|
+
dynamicFilter: {
|
|
73
|
+
name: [{ operation: 'EQUALS', relation: 'AND', value: '{{AppController.value}}' }],
|
|
74
|
+
},
|
|
75
|
+
searchJoin: { col1: ['1', '2'], col2: [2], col3: [] },
|
|
76
|
+
});
|
|
77
|
+
await flushPromises();
|
|
78
|
+
|
|
79
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
80
|
+
expect(instance.searchJoin).toEqual({ col1: ['1', '2'], col2: [2], col3: [] });
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
it('should create using default parameters', async () => {
|
|
84
|
+
const instance = new TekMemoryDatasource({});
|
|
85
|
+
|
|
86
|
+
expect(instance.dynamicFilter).toEqual({});
|
|
87
|
+
expect(instance.searchJoin).toEqual({});
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
it('should set values from url', () => {
|
|
91
|
+
router.getFullPath = () => 'localhost/?page=2&limit=10&order=id.asc&search=2&id=1';
|
|
92
|
+
const instance = new TekMemoryDatasource({
|
|
93
|
+
...datasource,
|
|
94
|
+
watchUrl: true,
|
|
95
|
+
});
|
|
96
|
+
expect(instance.filter).toEqual({ id: '1' });
|
|
97
|
+
expect(instance.limit).toBe(10);
|
|
98
|
+
expect(instance.order).toEqual(['id.asc']);
|
|
99
|
+
expect(instance.page).toBe(2);
|
|
100
|
+
expect(instance.search).toBe('2');
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('should set dynamicFilter from url', () => {
|
|
104
|
+
router.getFullPath = () => 'localhost/?dynamic_filter=eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMSJ9XX0='; // eslint-disable-line max-len
|
|
105
|
+
datasource.watchUrl = true;
|
|
106
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
107
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
it('should set searchJoin from url', () => {
|
|
111
|
+
router.getFullPath = () => 'localhost/?search_join=eyAiY29sMSI6IFsiMSIsICIyIl0sICJjb2wyIjogWzJdLCAiY29sMyI6IFtdIH0='; // eslint-disable-line max-len
|
|
112
|
+
datasource.watchUrl = true;
|
|
113
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
114
|
+
expect(instance.searchJoin).toEqual({ col1: ['1', '2'], col2: [2], col3: [] });
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
describe('dynamicFilter', () => {
|
|
119
|
+
it('should retrieve data using dynamic filter', async () => {
|
|
120
|
+
const flushPromises = () => new Promise(setImmediate);
|
|
121
|
+
datasource.watchUrl = false;
|
|
122
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
123
|
+
|
|
124
|
+
await flushPromises();
|
|
125
|
+
expect(instance.data.length).toBe(6);
|
|
126
|
+
|
|
127
|
+
instance.dynamicFilter = {
|
|
128
|
+
name: [
|
|
129
|
+
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
130
|
+
],
|
|
131
|
+
};
|
|
132
|
+
await instance.get();
|
|
133
|
+
expect(instance.data.length).toBe(1);
|
|
134
|
+
|
|
135
|
+
instance.dynamicFilter = {
|
|
136
|
+
name: [
|
|
137
|
+
{ operation: 'CONTAINS', relation: 'AND', value: 'name' },
|
|
138
|
+
],
|
|
139
|
+
};
|
|
140
|
+
await instance.get();
|
|
141
|
+
expect(instance.data.length).toBe(6);
|
|
142
|
+
|
|
143
|
+
instance.dynamicFilter = {
|
|
144
|
+
name: [
|
|
145
|
+
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
146
|
+
{ operation: 'CONTAINS', relation: 'OR', value: '2' },
|
|
147
|
+
],
|
|
148
|
+
};
|
|
149
|
+
await instance.get();
|
|
150
|
+
expect(instance.data.length).toBe(2);
|
|
151
|
+
|
|
152
|
+
instance.dynamicFilter = {
|
|
153
|
+
name: [
|
|
154
|
+
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
155
|
+
{ operation: 'CONTAINS', relation: 'AND', value: '2' },
|
|
156
|
+
],
|
|
157
|
+
};
|
|
158
|
+
await instance.get();
|
|
159
|
+
expect(instance.data.length).toBe(0);
|
|
160
|
+
|
|
161
|
+
instance.dynamicFilter = {
|
|
162
|
+
name: [
|
|
163
|
+
{ operation: 'CONTAINS', relation: 'AND', value: '1' },
|
|
164
|
+
],
|
|
165
|
+
id: [
|
|
166
|
+
{ operation: 'CONTAINS', relation: 'OR', value: '2' },
|
|
167
|
+
],
|
|
168
|
+
};
|
|
169
|
+
await instance.get();
|
|
170
|
+
expect(instance.data.length).toBe(2);
|
|
171
|
+
|
|
172
|
+
instance.dynamicFilter = {
|
|
173
|
+
name: [
|
|
174
|
+
{ operation: 'NOT_CONTAINS', relation: 'AND', value: '1' },
|
|
175
|
+
],
|
|
176
|
+
};
|
|
177
|
+
await instance.get();
|
|
178
|
+
expect(instance.data.length).toBe(5);
|
|
179
|
+
|
|
180
|
+
instance.dynamicFilter = {
|
|
181
|
+
name: [
|
|
182
|
+
{ operation: 'EQUALS', relation: 'AND', value: '1' },
|
|
183
|
+
],
|
|
184
|
+
};
|
|
185
|
+
await instance.get();
|
|
186
|
+
expect(instance.data.length).toBe(0);
|
|
187
|
+
|
|
188
|
+
instance.dynamicFilter = {
|
|
189
|
+
name: [
|
|
190
|
+
{ operation: 'EQUALS', relation: 'AND', value: 'name 1' },
|
|
191
|
+
],
|
|
192
|
+
};
|
|
193
|
+
await instance.get();
|
|
194
|
+
expect(instance.data.length).toBe(1);
|
|
195
|
+
|
|
196
|
+
instance.dynamicFilter = {
|
|
197
|
+
name: [
|
|
198
|
+
{ operation: 'NOT_EQUALS', relation: 'AND', value: 'name 1' },
|
|
199
|
+
],
|
|
200
|
+
};
|
|
201
|
+
await instance.get();
|
|
202
|
+
expect(instance.data.length).toBe(5);
|
|
203
|
+
|
|
204
|
+
instance.dynamicFilter = {
|
|
205
|
+
id: [
|
|
206
|
+
{ operation: 'GREATER_THAN', relation: 'AND', value: '2' },
|
|
207
|
+
],
|
|
208
|
+
};
|
|
209
|
+
await instance.get();
|
|
210
|
+
expect(instance.data.length).toBe(4);
|
|
211
|
+
|
|
212
|
+
instance.dynamicFilter = {
|
|
213
|
+
id: [
|
|
214
|
+
{ operation: 'LESS_THAN', relation: 'AND', value: '2' },
|
|
215
|
+
],
|
|
216
|
+
};
|
|
217
|
+
await instance.get();
|
|
218
|
+
expect(instance.data.length).toBe(1);
|
|
219
|
+
|
|
220
|
+
instance.dynamicFilter = {
|
|
221
|
+
id: [
|
|
222
|
+
{ operation: 'GREATER_THAN_EQUALS', relation: 'AND', value: '2' },
|
|
223
|
+
],
|
|
224
|
+
};
|
|
225
|
+
await instance.get();
|
|
226
|
+
expect(instance.data.length).toBe(5);
|
|
227
|
+
|
|
228
|
+
instance.dynamicFilter = {
|
|
229
|
+
id: [
|
|
230
|
+
{ operation: 'LESS_THAN_EQUALS', relation: 'AND', value: '2' },
|
|
231
|
+
],
|
|
232
|
+
};
|
|
233
|
+
await instance.get();
|
|
234
|
+
expect(instance.data.length).toBe(2);
|
|
235
|
+
|
|
236
|
+
instance.dynamicFilter = {
|
|
237
|
+
name: [
|
|
238
|
+
{ operation: 'GREATER_THAN', relation: 'AND', value: 'name 2' },
|
|
239
|
+
],
|
|
240
|
+
};
|
|
241
|
+
await instance.get();
|
|
242
|
+
expect(instance.data.length).toBe(4);
|
|
243
|
+
|
|
244
|
+
instance.dynamicFilter = {
|
|
245
|
+
name: [
|
|
246
|
+
{ operation: 'LESS_THAN', relation: 'AND', value: 'name 2' },
|
|
247
|
+
],
|
|
248
|
+
};
|
|
249
|
+
await instance.get();
|
|
250
|
+
expect(instance.data.length).toBe(1);
|
|
251
|
+
|
|
252
|
+
instance.dynamicFilter = {
|
|
253
|
+
name: [
|
|
254
|
+
{ operation: 'GREATER_THAN_EQUALS', relation: 'AND', value: 'name 2' },
|
|
255
|
+
],
|
|
256
|
+
};
|
|
257
|
+
await instance.get();
|
|
258
|
+
expect(instance.data.length).toBe(5);
|
|
259
|
+
|
|
260
|
+
instance.dynamicFilter = {
|
|
261
|
+
name: [
|
|
262
|
+
{ operation: 'LESS_THAN_EQUALS', relation: 'AND', value: 'name 2' },
|
|
263
|
+
],
|
|
264
|
+
};
|
|
265
|
+
await instance.get();
|
|
266
|
+
expect(instance.data.length).toBe(2);
|
|
267
|
+
|
|
268
|
+
instance.dynamicFilter = {
|
|
269
|
+
id: [
|
|
270
|
+
{ operation: 'IN', relation: 'AND', value: ['1', '2'] },
|
|
271
|
+
],
|
|
272
|
+
};
|
|
273
|
+
await instance.get();
|
|
274
|
+
expect(instance.data.length).toBe(2);
|
|
275
|
+
|
|
276
|
+
instance.dynamicFilter = {
|
|
277
|
+
id: [
|
|
278
|
+
{ operation: 'NOT_IN', relation: 'AND', value: ['1', '2'] },
|
|
279
|
+
],
|
|
280
|
+
};
|
|
281
|
+
await instance.get();
|
|
282
|
+
expect(instance.data.length).toBe(4);
|
|
283
|
+
|
|
284
|
+
instance.dynamicFilter = {
|
|
285
|
+
id: [
|
|
286
|
+
{ operation: 'BETWEEN', relation: 'AND', value: ['2', '5'] },
|
|
287
|
+
],
|
|
288
|
+
};
|
|
289
|
+
await instance.get();
|
|
290
|
+
expect(instance.data.length).toBe(4);
|
|
291
|
+
|
|
292
|
+
instance.dynamicFilter = {
|
|
293
|
+
name: [
|
|
294
|
+
{ operation: 'BETWEEN', relation: 'AND', value: ['name 2', 'name 5'] },
|
|
295
|
+
],
|
|
296
|
+
};
|
|
297
|
+
await instance.get();
|
|
298
|
+
expect(instance.data.length).toBe(4);
|
|
299
|
+
|
|
300
|
+
instance.dynamicFilter = {
|
|
301
|
+
name: [
|
|
302
|
+
{ operation: '', relation: 'AND', value: ['1', '2'] },
|
|
303
|
+
],
|
|
304
|
+
};
|
|
305
|
+
await instance.get();
|
|
306
|
+
expect(instance.data.length).toBe(0);
|
|
307
|
+
|
|
308
|
+
instance.dynamicFilter = {
|
|
309
|
+
name: [
|
|
310
|
+
{ operation: '', relation: 'AND', value: '1' },
|
|
311
|
+
],
|
|
312
|
+
};
|
|
313
|
+
await instance.get();
|
|
314
|
+
expect(instance.data.length).toBe(0);
|
|
315
|
+
});
|
|
316
|
+
|
|
317
|
+
it('should not retrieve data with wrong operator', async () => {
|
|
318
|
+
const flushPromises = () => new Promise(setImmediate);
|
|
319
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
320
|
+
|
|
321
|
+
await flushPromises();
|
|
322
|
+
expect(instance.data.length).toBe(6);
|
|
323
|
+
|
|
324
|
+
instance.dynamicFilter = {
|
|
325
|
+
name: [
|
|
326
|
+
{ operation: 'TEST', relation: 'AND', value: '1' },
|
|
327
|
+
],
|
|
328
|
+
};
|
|
329
|
+
await instance.get();
|
|
330
|
+
expect(instance.data.length).toBe(0);
|
|
331
|
+
});
|
|
332
|
+
});
|
|
333
|
+
|
|
334
|
+
describe('searchJoin', () => {
|
|
335
|
+
it('should retrieve data using search join', async () => {
|
|
336
|
+
const flushPromises = () => new Promise(setImmediate);
|
|
337
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
338
|
+
|
|
339
|
+
await flushPromises();
|
|
340
|
+
expect(instance.data.length).toBe(6);
|
|
341
|
+
|
|
342
|
+
instance.searchJoin = {
|
|
343
|
+
name: ['name 1', 'name 2'],
|
|
344
|
+
};
|
|
345
|
+
instance.search = 'aaa';
|
|
346
|
+
await instance.get();
|
|
347
|
+
expect(instance.data.length).toBe(2);
|
|
348
|
+
});
|
|
349
|
+
});
|
|
350
|
+
|
|
351
|
+
describe('addDynamicFilter()', () => {
|
|
352
|
+
it('should add/remove dynamic filter value', () => {
|
|
353
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
354
|
+
instance.addDynamicFilter('name', [{ operation: 'EQUALS', relation: 'AND', value: '1' }]);
|
|
355
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
356
|
+
instance.addDynamicFilter('name', [{ operation: 'foo', relation: 'AND', value: '1' }]);
|
|
357
|
+
expect(instance.dynamicFilter).toEqual({});
|
|
358
|
+
});
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
describe('setDynamicFilter()', () => {
|
|
362
|
+
it('should add/remove dynamic filter value', () => {
|
|
363
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
364
|
+
instance.setDynamicFilter({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
365
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
366
|
+
|
|
367
|
+
instance.setDynamicFilter({ name: [{ operation: 'foo', relation: 'AND', value: '1' }] });
|
|
368
|
+
expect(instance.dynamicFilter).toEqual({});
|
|
369
|
+
|
|
370
|
+
instance.setDynamicFilter({
|
|
371
|
+
name: [], id: [{}],
|
|
372
|
+
});
|
|
373
|
+
expect(instance.dynamicFilter).toEqual({});
|
|
374
|
+
});
|
|
375
|
+
|
|
376
|
+
it('should add dynamic filter value with watchUrl', () => {
|
|
377
|
+
let dynamicFilterValue = 'eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMSJ9XX0=';
|
|
378
|
+
router.getFullPath = () => `localhost/?dynamic_filter=${dynamicFilterValue}`;
|
|
379
|
+
const urlSpy = jest.spyOn(URL, 'updateQueryString');
|
|
380
|
+
|
|
381
|
+
datasource.watchUrl = true;
|
|
382
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
383
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
384
|
+
|
|
385
|
+
dynamicFilterValue = 'eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMiJ9XX0=';
|
|
386
|
+
instance.setDynamicFilter({ name: [{ operation: 'EQUALS', relation: 'AND', value: '2' }] });
|
|
387
|
+
expect(urlSpy).toHaveBeenCalledWith({
|
|
388
|
+
dynamic_filter: dynamicFilterValue,
|
|
389
|
+
});
|
|
390
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '2' }] });
|
|
391
|
+
urlSpy.mockClear();
|
|
392
|
+
});
|
|
393
|
+
|
|
394
|
+
it('deve chamar setDynamicFilter ao usar setBaseFilter', () => {
|
|
395
|
+
const ds = new TekMemoryDatasource({ uniqueKey: 'id', data: [] });
|
|
396
|
+
const filtro = { ativo: true };
|
|
397
|
+
const spy = jest.spyOn(ds, 'setDynamicFilter');
|
|
398
|
+
|
|
399
|
+
ds.setBaseFilter(filtro);
|
|
400
|
+
|
|
401
|
+
expect(spy).toHaveBeenCalledWith(filtro);
|
|
402
|
+
});
|
|
403
|
+
});
|
|
404
|
+
|
|
405
|
+
describe('clearDynamicFilter()', () => {
|
|
406
|
+
it('should clear dynamic filter', () => {
|
|
407
|
+
datasource.watchUrl = false;
|
|
408
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
409
|
+
instance.setDynamicFilter({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
410
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
411
|
+
instance.clearDynamicFilter();
|
|
412
|
+
expect(instance.dynamicFilter).toEqual({});
|
|
413
|
+
});
|
|
414
|
+
|
|
415
|
+
it('should clear dynamic filter value with watchUrl', () => {
|
|
416
|
+
let dynamicFilterValue = 'eyJuYW1lIjpbeyJvcGVyYXRpb24iOiJFUVVBTFMiLCJyZWxhdGlvbiI6IkFORCIsInZhbHVlIjoiMSJ9XX0=';
|
|
417
|
+
router.getFullPath = () => `localhost/?dynamic_filter=${dynamicFilterValue}`;
|
|
418
|
+
const urlSpy = jest.spyOn(URL, 'updateQueryString');
|
|
419
|
+
|
|
420
|
+
datasource.watchUrl = true;
|
|
421
|
+
const instance = new TekMemoryDatasource(datasource);
|
|
422
|
+
expect(instance.dynamicFilter).toEqual({ name: [{ operation: 'EQUALS', relation: 'AND', value: '1' }] });
|
|
423
|
+
|
|
424
|
+
dynamicFilterValue = '';
|
|
425
|
+
instance.clearDynamicFilter();
|
|
426
|
+
expect(urlSpy).toHaveBeenCalledWith({
|
|
427
|
+
dynamic_filter: undefined,
|
|
428
|
+
});
|
|
429
|
+
expect(instance.dynamicFilter).toEqual({});
|
|
430
|
+
urlSpy.mockClear();
|
|
431
|
+
});
|
|
432
|
+
});
|
|
433
|
+
|
|
434
|
+
describe('clone', () => {
|
|
435
|
+
it('should return an object with all datasource props', async () => {
|
|
436
|
+
const data = [{ value: 'item 1' }];
|
|
437
|
+
const dynamicFilter = {
|
|
438
|
+
name: { operation: 'EQUALS', relation: 'AND', value: 'item 1' },
|
|
439
|
+
};
|
|
440
|
+
const searchJoin = { col1: ['1', '2'], col2: [2], col3: [] };
|
|
441
|
+
const instance = new TekMemoryDatasource({
|
|
442
|
+
route: '/zeedhi',
|
|
443
|
+
data,
|
|
444
|
+
dynamicFilter,
|
|
445
|
+
searchJoin,
|
|
446
|
+
});
|
|
447
|
+
|
|
448
|
+
const props = instance.clone();
|
|
449
|
+
|
|
450
|
+
expect(props).toEqual({
|
|
451
|
+
data,
|
|
452
|
+
dynamicFilter,
|
|
453
|
+
searchJoin,
|
|
454
|
+
currentRow: {},
|
|
455
|
+
filter: {},
|
|
456
|
+
limit: 10,
|
|
457
|
+
order: [],
|
|
458
|
+
page: 1,
|
|
459
|
+
search: '',
|
|
460
|
+
searchIn: [],
|
|
461
|
+
uniqueKey: 'id',
|
|
462
|
+
watchUrl: false,
|
|
463
|
+
events: {},
|
|
464
|
+
loadAll: false,
|
|
465
|
+
type: 'tek-memory',
|
|
466
|
+
translate: false,
|
|
467
|
+
});
|
|
468
|
+
});
|
|
469
|
+
});
|
|
470
|
+
});
|