@zeedhi/teknisa-components-common 1.107.2 → 1.108.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.
Files changed (77) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +7 -7
  3. package/coverage/clover.xml +772 -692
  4. package/coverage/coverage-final.json +47 -47
  5. package/coverage/lcov-report/index.html +15 -15
  6. package/coverage/lcov-report/tests/__helpers__/component-event-helper.ts.html +2 -2
  7. package/coverage/lcov-report/tests/__helpers__/flush-promises-helper.ts.html +2 -2
  8. package/coverage/lcov-report/tests/__helpers__/get-child-helper.ts.html +7 -7
  9. package/coverage/lcov-report/tests/__helpers__/index.html +1 -1
  10. package/coverage/lcov-report/tests/__helpers__/index.ts.html +1 -1
  11. package/coverage/lcov-report/tests/__helpers__/mock-created-helper.ts.html +1 -1
  12. package/coverage/lcov.info +1459 -1275
  13. package/dist/tek-components-common.esm.js +375 -252
  14. package/dist/tek-components-common.umd.js +375 -252
  15. package/jest.config.js +1 -1
  16. package/package.json +2 -2
  17. package/tests/__helpers__/component-event-helper.ts +5 -5
  18. package/tests/__helpers__/flush-promises-helper.ts +3 -3
  19. package/tests/__helpers__/get-child-helper.ts +27 -27
  20. package/tests/__helpers__/index.ts +3 -3
  21. package/tests/__helpers__/mock-created-helper.ts +12 -12
  22. package/tests/__mocks__/@zeedhi/core/i18n.js +74 -74
  23. package/tests/__mocks__/@zeedhi/core.js +4 -4
  24. package/tests/unit/components/crud/crud-add-button.spec.ts +56 -56
  25. package/tests/unit/components/crud/crud-button.spec.ts +94 -94
  26. package/tests/unit/components/crud/crud-cancel-button.spec.ts +91 -91
  27. package/tests/unit/components/crud/crud-delete-button.spec.ts +122 -122
  28. package/tests/unit/components/crud/crud-form.spec.ts +165 -165
  29. package/tests/unit/components/crud/crud-save-button.spec.ts +118 -118
  30. package/tests/unit/components/tek-breadcrumb-header/tek-breadcrumb-header.spec.ts +42 -42
  31. package/tests/unit/components/tek-card-title/CardTitle.spec.ts +34 -34
  32. package/tests/unit/components/tek-datasource/memory-datasource.spec.ts +470 -470
  33. package/tests/unit/components/tek-datasource/rest-datasource.spec.ts +364 -364
  34. package/tests/unit/components/tek-drag-grid/tek-drag-grid.spec.ts +112 -112
  35. package/tests/unit/components/tek-grid/filter-helper.spec.ts +148 -148
  36. package/tests/unit/components/tek-grid/grid-column.spec.ts +270 -270
  37. package/tests/unit/components/tek-grid/grid-columns-button.spec.ts +195 -195
  38. package/tests/unit/components/tek-grid/grid-filter-button.spec.ts +967 -967
  39. package/tests/unit/components/tek-grid/grid.spec.ts +3340 -3116
  40. package/tests/unit/components/tek-grid/layout_options.spec.ts +980 -980
  41. package/tests/unit/components/tek-image/Image.spec.ts +67 -67
  42. package/tests/unit/components/tek-iterable-carousel/iterable-carousel.spec.ts +37 -37
  43. package/tests/unit/components/tek-iterable-component-render/iterable-component-render.spec.ts +200 -200
  44. package/tests/unit/components/tek-loading/Loading.spec.ts +30 -30
  45. package/tests/unit/components/tek-notifications/notifications.spec.ts +201 -201
  46. package/tests/unit/components/tek-product-card/product-card.spec.ts +61 -61
  47. package/tests/unit/components/tek-user-info/TekUserInfoContoller.spec.ts +220 -220
  48. package/tests/unit/components/tek-user-info/tek-user-info-list.spec.ts +86 -86
  49. package/tests/unit/components/tek-user-info/tek-user-info.spec.ts +430 -430
  50. package/tests/unit/components/tree-grid/tree-grid.spec.ts +776 -776
  51. package/tests/unit/utils/grid-base/delete-rows-error.spec.ts +24 -0
  52. package/tests/unit/utils/grid-base/export-options/button-option.spec.ts +44 -44
  53. package/tests/unit/utils/grid-base/export-options/multi-option.spec.ts +135 -135
  54. package/tests/unit/utils/grid-base/grid-controller.spec.ts +267 -174
  55. package/tests/unit/utils/report-filter/report-filter.spec.ts +66 -66
  56. package/tsconfig.eslint.json +8 -8
  57. package/types/components/tek-datasource/memory-datasource.d.ts +2 -4
  58. package/types/components/tek-datasource/rest-datasource.d.ts +6 -3
  59. package/types/components/tek-grid/grid.d.ts +50 -6
  60. package/types/components/tek-grid/interfaces.d.ts +5 -3
  61. package/types/components/tek-tree-grid/tree-grid.d.ts +5 -1
  62. package/types/utils/grid-base/grid-base.d.ts +12 -229
  63. package/types/utils/grid-base/grid-controller.d.ts +1 -3
  64. package/types/components/tek-ag-grid/default-icons.d.ts +0 -53
  65. package/types/components/tek-ag-grid/interfaces.d.ts +0 -9
  66. package/types/components/tek-ag-grid/tek-ag-grid.d.ts +0 -35
  67. package/types/components/tek-datasource/datasource.d.ts +0 -94
  68. package/types/components/tek-grid/default-icons.d.ts +0 -53
  69. package/types/components/tek-grid/filter-dynamic-values.d.ts +0 -9
  70. package/types/components/tek-grid/grid-controller.d.ts +0 -19
  71. package/types/components/tek-grid/grid_column.d.ts +0 -14
  72. package/types/components/tek-grid/grid_controller.d.ts +0 -15
  73. package/types/components/tek-grid/tek-grid.d.ts +0 -35
  74. package/types/components/tek-login/interfaces.d.ts +0 -3
  75. package/types/components/tek-login/login-children.d.ts +0 -3
  76. package/types/components/tek-login/login.d.ts +0 -58
  77. package/types/components/tek-login/login_children.d.ts +0 -3
@@ -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
+ });