@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,430 +1,430 @@
1
- import {
2
- Button, ListItem, Modal, ModalService,
3
- } from '@zeedhi/common';
4
- import { Metadata, Http } from '@zeedhi/core';
5
- import { UserInfo } from '@zeedhi/zd-user-info-common';
6
- import { ITekUserInfo, TekUserInfo, TekUserInfoList } from '../../../../src';
7
- import { mockCreated } from '../../../__helpers__/mock-created-helper';
8
-
9
- function instantiateAndCreate(props: ITekUserInfo) {
10
- const instance = new TekUserInfo(props);
11
- mockCreated(instance, UserInfo.prototype);
12
- instance.onCreated();
13
- return instance;
14
- }
15
-
16
- describe('TekUserInfo', () => {
17
- afterEach(() => jest.clearAllMocks());
18
-
19
- describe('constructor()', () => {
20
- it('when called, should assign the default values', () => {
21
- const instance = new TekUserInfo({
22
- name: 'TekUserInfo',
23
- component: 'TekUserInfo',
24
- });
25
- expect(instance.bottomSlot).toMatchObject([]);
26
- expect(instance.aboutImage).toBe('');
27
- expect(instance.defaultEmail).toBe('');
28
- expect(instance.versionInfo).toBeNull();
29
- expect(instance.versionUrl).toBe('');
30
- });
31
-
32
- it('when called with props, should assign the defined values', () => {
33
- const instance = instantiateAndCreate({
34
- name: 'TekUserInfo',
35
- component: 'TekUserInfo',
36
- bottomSlot: [
37
- { name: 'test', component: 'ZdText' },
38
- ],
39
- aboutImage: 'path',
40
- defaultEmail: 'zeedhi@zd.com',
41
- versionInfo: {
42
- name: 'Zeedhi',
43
- version: '1.0.0',
44
- frontend: [{ name: 'package 1', version: '1.0.0' }],
45
- backend: [{ name: 'package 2', version: '2.0.0' }],
46
- modules: [{ name: 'package 3', version: '3.0.0' }],
47
- },
48
- versionUrl: '/version',
49
- });
50
-
51
- expect(instance.bottomSlot).toEqual([
52
- { name: 'test', component: 'ZdText' },
53
- ]);
54
- expect(instance.aboutImage).toBe('path');
55
- expect(instance.defaultEmail).toBe('zeedhi@zd.com');
56
- expect(instance.versionInfo).toEqual({
57
- name: 'Zeedhi',
58
- version: '1.0.0',
59
- frontend: [{ name: 'package 1', version: '1.0.0' }],
60
- backend: [{ name: 'package 2', version: '2.0.0' }],
61
- modules: [{ name: 'package 3', version: '3.0.0' }],
62
- });
63
- expect(instance.versionUrl).toBe('/version');
64
- });
65
- });
66
-
67
- describe('About Modal', () => {
68
- it('when about item is clicked, should open about modal', () => {
69
- const instance = instantiateAndCreate({
70
- name: 'TekUserInfo',
71
- component: 'TekUserInfo',
72
- aboutImage: 'path',
73
- versionInfo: {
74
- name: 'Zeedhi',
75
- version: '1.0.0',
76
- frontend: [{ name: 'package 1', version: '1.0.0' }],
77
- backend: [{ name: 'package 2', version: '2.0.0' }],
78
- modules: [{ name: 'package 3', version: '3.0.0' }],
79
- },
80
- });
81
- instance.onAboutClick();
82
-
83
- expect(instance.aboutModal).toMatchObject({
84
- children: [
85
- {
86
- component: 'ZdHeader',
87
- rightSlot: [{ component: 'ZdModalCloseButton' }],
88
- },
89
- {
90
- component: 'ZdTag',
91
- children: [{ component: 'ZdImage', src: 'path' }],
92
- },
93
- {
94
- component: 'ZdTabs',
95
- tabs: [
96
- {
97
- tabTitle: 'Frontend',
98
- children: [
99
- { component: 'ZdText', text: '{{TekUserInfoController_1.mainVersion}}' },
100
- { component: 'ZdText', text: '{{TekUserInfoController_1.frontendItems}}' },
101
- ],
102
- },
103
- {
104
- tabTitle: 'Backend',
105
- children: [
106
- { component: 'ZdText', text: '{{TekUserInfoController_1.mainVersion}}' },
107
- { component: 'ZdText', text: '{{TekUserInfoController_1.backendItems}}' },
108
- ],
109
- },
110
- {
111
- tabTitle: 'Modules',
112
- children: [
113
- { component: 'ZdText', text: '{{TekUserInfoController_1.mainVersion}}' },
114
- { component: 'ZdText', text: '{{TekUserInfoController_1.modulesItems}}' },
115
- ],
116
- },
117
- ],
118
- },
119
- ],
120
- });
121
- });
122
-
123
- it('when about item is clicked twice, should create the modal only once', () => {
124
- const spy = jest.spyOn(ModalService, 'create');
125
- const instance = instantiateAndCreate({
126
- name: 'TekUserInfo',
127
- component: 'TekUserInfo',
128
- versionInfo: {
129
- name: 'Zeedhi',
130
- version: '1.0.0',
131
- frontend: [{ name: 'package 1', version: '1.0.0' }],
132
- backend: [{ name: 'package 2', version: '2.0.0' }],
133
- modules: [{ name: 'package 3', version: '3.0.0' }],
134
- },
135
- });
136
- instance.onAboutClick();
137
- instance.onAboutClick();
138
-
139
- expect(spy).toHaveBeenCalledTimes(1);
140
- });
141
-
142
- it('when versionInfo is undefined, should create empty tabs inside the modal', () => {
143
- const instance = instantiateAndCreate({
144
- name: 'TekUserInfo',
145
- component: 'TekUserInfo',
146
- });
147
- instance.onAboutClick();
148
-
149
- expect(instance.aboutModal).toMatchObject({
150
- children: [
151
- {
152
- component: 'ZdHeader',
153
- rightSlot: [{ component: 'ZdModalCloseButton' }],
154
- },
155
- {
156
- component: 'ZdTag',
157
- children: [{ component: 'ZdImage', src: '' }],
158
- },
159
- {
160
- component: 'ZdTabs',
161
- tabs: [
162
- { tabTitle: 'Frontend', children: [] },
163
- { tabTitle: 'Backend', children: [] },
164
- { tabTitle: 'Modules', children: [] },
165
- ],
166
- },
167
- ],
168
- });
169
- });
170
- });
171
-
172
- describe('Report Modal', () => {
173
- it('when onReportClick is called, should open report modal', () => {
174
- const instance = instantiateAndCreate({
175
- name: 'TekUserInfo',
176
- component: 'TekUserInfo',
177
- defaultEmail: 'zeedhi@zd.com',
178
- });
179
- instance.onReportClick();
180
-
181
- expect(instance.reportModal).toMatchObject({
182
- children: [
183
- {
184
- component: 'ZdHeader',
185
- leftSlot: [{ component: 'ZdText', text: 'TEKUSERINFO_REPORT_ERROR' }],
186
- rightSlot: [{ component: 'ZdModalCloseButton' }],
187
- },
188
- {
189
- component: 'ZdForm',
190
- children: [
191
- {
192
- name: 'report_email',
193
- component: 'ZdTextInput',
194
- label: 'E-mail',
195
- value: 'zeedhi@zd.com',
196
- },
197
- {
198
- name: 'report_cc',
199
- component: 'ZdTextInput',
200
- label: 'CC',
201
- placeholder: 'TEKUSERINFO_EMAIL_PLACEHOLDER',
202
- },
203
- {
204
- name: 'report_type',
205
- component: 'ZdSelect',
206
- label: 'TEKUSERINFO_TYPE',
207
- datasource: {
208
- uniqueKey: 'value',
209
- translate: true,
210
- data: [
211
- { value: '0', text: 'TEKUSERINFO_ERROR' },
212
- { value: '1', text: 'TEKUSERINFO_IMPROVEMENT' },
213
- ],
214
- },
215
- },
216
- {
217
- name: 'report_description',
218
- component: 'ZdTextarea',
219
- label: 'TEKUSERINFO_DESCRIPTION',
220
- },
221
- ],
222
- },
223
- {
224
- component: 'ZdFooter',
225
- rightSlot: [
226
- { component: 'ZdButton', label: 'TEKUSERINFO_CANCEL' },
227
- { component: 'ZdButton', label: 'TEKUSERINFO_SEND' },
228
- ],
229
- },
230
- ],
231
- });
232
- });
233
-
234
- it('when onReportClick is called twice, should create the modal only once', () => {
235
- const spy = jest.spyOn(ModalService, 'create');
236
- const instance = instantiateAndCreate({
237
- name: 'TekUserInfo',
238
- component: 'TekUserInfo',
239
- defaultEmail: 'zeedhi@zd.com',
240
- });
241
-
242
- instance.onReportClick();
243
- instance.onReportClick();
244
-
245
- expect(spy).toHaveBeenCalledTimes(1);
246
-
247
- spy.mockClear();
248
- });
249
-
250
- it('when send button is clicked, should call onSendReport event', () => {
251
- const onSendReport = jest.fn();
252
- const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => ({
253
- validate: () => true,
254
- }));
255
- const instance = instantiateAndCreate({
256
- name: 'TekUserInfo',
257
- component: 'TekUserInfo',
258
- events: {
259
- onSendReport,
260
- },
261
- });
262
- instance.onReportClick();
263
- const button = instance.reportModal?.children[2].rightSlot[1];
264
- const buttonInstance = new Button(button);
265
-
266
- buttonInstance.click();
267
-
268
- expect(onSendReport).toHaveBeenCalled();
269
- spy.mockClear();
270
- });
271
-
272
- it('when send button is clicked and form is invalid, should not call onSendReport event', () => {
273
- const onSendReport = jest.fn();
274
- const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => ({
275
- validate: () => false,
276
- }));
277
- const instance = instantiateAndCreate({
278
- name: 'TekUserInfo',
279
- component: 'TekUserInfo',
280
- events: {
281
- onSendReport,
282
- },
283
- });
284
- instance.onReportClick();
285
- const button = instance.reportModal?.children[2].rightSlot[1];
286
- const buttonInstance = new Button(button);
287
-
288
- buttonInstance.click();
289
-
290
- expect(onSendReport).not.toHaveBeenCalled();
291
- spy.mockClear();
292
- });
293
-
294
- it('when reportModal is undefined, should not call onSendReport event', () => {
295
- const onSendReport = jest.fn();
296
- const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => ({
297
- validate: () => false,
298
- }));
299
- const instance = instantiateAndCreate({
300
- name: 'TekUserInfo',
301
- component: 'TekUserInfo',
302
- events: {
303
- onSendReport,
304
- },
305
- });
306
- instance.onReportClick();
307
- const button = instance.reportModal?.children[2].rightSlot[1];
308
- const buttonInstance = new Button(button);
309
-
310
- instance.reportModal = undefined;
311
- buttonInstance.click();
312
-
313
- expect(onSendReport).not.toHaveBeenCalled();
314
- spy.mockClear();
315
- });
316
-
317
- it('when cancel button is clicked, should close the modal', () => {
318
- const instance = instantiateAndCreate({
319
- name: 'TekUserInfo',
320
- component: 'TekUserInfo',
321
- });
322
- instance.onReportClick();
323
- const spy = jest.spyOn(instance.reportModal as Modal, 'hide');
324
- const button = instance.reportModal?.children[2].rightSlot[0];
325
- const buttonInstance = new Button(button);
326
-
327
- buttonInstance.click();
328
-
329
- expect(spy).toHaveBeenCalled();
330
- spy.mockClear();
331
- });
332
-
333
- it('when cancel button is clicked, should not throw if reportModal is undefined', () => {
334
- const instance = instantiateAndCreate({
335
- name: 'TekUserInfo',
336
- component: 'TekUserInfo',
337
- });
338
- instance.onReportClick();
339
- const button = instance.reportModal?.children[2].rightSlot[0];
340
- const buttonInstance = new Button(button);
341
-
342
- instance.reportModal = undefined;
343
-
344
- expect(() => buttonInstance.click()).not.toThrow();
345
- });
346
- });
347
-
348
- describe('onMounted', () => {
349
- it('when onMounted is called and versionUrl is defined, should make a GET request to versionUrl', async () => {
350
- const spy = jest.spyOn(Http, 'get').mockImplementation(() => Promise.resolve({
351
- data: {
352
- versionInfo: {
353
- name: 'Zeedhi',
354
- version: '1.0.0',
355
- frontend: [{ name: 'package 1', version: '1.0.0' }],
356
- backend: [{ name: 'package 2', version: '2.0.0' }],
357
- modules: [{ name: 'package 3', version: '3.0.0' }],
358
- },
359
- },
360
- }));
361
- const instance = new TekUserInfo({
362
- name: 'TekUserInfo',
363
- component: 'TekUserInfo',
364
- versionUrl: '/version',
365
- });
366
-
367
- await instance.onMounted({});
368
-
369
- expect(instance.versionInfo).toEqual({
370
- name: 'Zeedhi',
371
- version: '1.0.0',
372
- frontend: [{ name: 'package 1', version: '1.0.0' }],
373
- backend: [{ name: 'package 2', version: '2.0.0' }],
374
- modules: [{ name: 'package 3', version: '3.0.0' }],
375
- });
376
- spy.mockClear();
377
- });
378
- });
379
-
380
- describe('onCreated', () => {
381
- it('when onCreated is called and bottomSlot is empty, should assign default value to the latter', () => {
382
- const instance = instantiateAndCreate({
383
- name: 'TekUserInfo',
384
- component: 'TekUserInfo',
385
- });
386
-
387
- expect(instance.bottomSlot).toMatchObject([
388
- {
389
- name: 'TekUserInfo_bottom_list',
390
- component: 'TekUserInfoList',
391
- parentName: 'TekUserInfo',
392
- },
393
- ]);
394
- });
395
- });
396
-
397
- describe('visibleItems', () => {
398
- it('when visibleItems is changed, should hide or show an item', () => {
399
- const instance = instantiateAndCreate({
400
- name: 'UserInfo',
401
- component: 'UserInfo',
402
- visibleItems: {
403
- reportError: false,
404
- versionInfo: false,
405
- about: false,
406
- },
407
- });
408
- const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => (instance));
409
-
410
- const list = new TekUserInfoList({ parentName: 'UserInfo', ...instance.bottomSlot[0] });
411
- const versionInfo = new ListItem({ ...list.items[0] });
412
- const about = new ListItem({ ...list.items[1] });
413
- const reportError = new ListItem({ ...list.items[2] });
414
-
415
- expect(versionInfo.isVisible).toBeFalsy();
416
- expect(about.isVisible).toBeFalsy();
417
- expect(reportError.isVisible).toBeFalsy();
418
-
419
- instance.visibleItems.versionInfo = true;
420
- instance.visibleItems.about = true;
421
- instance.visibleItems.reportError = true;
422
-
423
- expect(versionInfo.isVisible).toBeTruthy();
424
- expect(about.isVisible).toBeTruthy();
425
- expect(reportError.isVisible).toBeTruthy();
426
-
427
- spy.mockReset();
428
- });
429
- });
430
- });
1
+ import {
2
+ Button, ListItem, Modal, ModalService,
3
+ } from '@zeedhi/common';
4
+ import { Metadata, Http } from '@zeedhi/core';
5
+ import { UserInfo } from '@zeedhi/zd-user-info-common';
6
+ import { ITekUserInfo, TekUserInfo, TekUserInfoList } from '../../../../src';
7
+ import { mockCreated } from '../../../__helpers__/mock-created-helper';
8
+
9
+ function instantiateAndCreate(props: ITekUserInfo) {
10
+ const instance = new TekUserInfo(props);
11
+ mockCreated(instance, UserInfo.prototype);
12
+ instance.onCreated();
13
+ return instance;
14
+ }
15
+
16
+ describe('TekUserInfo', () => {
17
+ afterEach(() => jest.clearAllMocks());
18
+
19
+ describe('constructor()', () => {
20
+ it('when called, should assign the default values', () => {
21
+ const instance = new TekUserInfo({
22
+ name: 'TekUserInfo',
23
+ component: 'TekUserInfo',
24
+ });
25
+ expect(instance.bottomSlot).toMatchObject([]);
26
+ expect(instance.aboutImage).toBe('');
27
+ expect(instance.defaultEmail).toBe('');
28
+ expect(instance.versionInfo).toBeNull();
29
+ expect(instance.versionUrl).toBe('');
30
+ });
31
+
32
+ it('when called with props, should assign the defined values', () => {
33
+ const instance = instantiateAndCreate({
34
+ name: 'TekUserInfo',
35
+ component: 'TekUserInfo',
36
+ bottomSlot: [
37
+ { name: 'test', component: 'ZdText' },
38
+ ],
39
+ aboutImage: 'path',
40
+ defaultEmail: 'zeedhi@zd.com',
41
+ versionInfo: {
42
+ name: 'Zeedhi',
43
+ version: '1.0.0',
44
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
45
+ backend: [{ name: 'package 2', version: '2.0.0' }],
46
+ modules: [{ name: 'package 3', version: '3.0.0' }],
47
+ },
48
+ versionUrl: '/version',
49
+ });
50
+
51
+ expect(instance.bottomSlot).toEqual([
52
+ { name: 'test', component: 'ZdText' },
53
+ ]);
54
+ expect(instance.aboutImage).toBe('path');
55
+ expect(instance.defaultEmail).toBe('zeedhi@zd.com');
56
+ expect(instance.versionInfo).toEqual({
57
+ name: 'Zeedhi',
58
+ version: '1.0.0',
59
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
60
+ backend: [{ name: 'package 2', version: '2.0.0' }],
61
+ modules: [{ name: 'package 3', version: '3.0.0' }],
62
+ });
63
+ expect(instance.versionUrl).toBe('/version');
64
+ });
65
+ });
66
+
67
+ describe('About Modal', () => {
68
+ it('when about item is clicked, should open about modal', () => {
69
+ const instance = instantiateAndCreate({
70
+ name: 'TekUserInfo',
71
+ component: 'TekUserInfo',
72
+ aboutImage: 'path',
73
+ versionInfo: {
74
+ name: 'Zeedhi',
75
+ version: '1.0.0',
76
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
77
+ backend: [{ name: 'package 2', version: '2.0.0' }],
78
+ modules: [{ name: 'package 3', version: '3.0.0' }],
79
+ },
80
+ });
81
+ instance.onAboutClick();
82
+
83
+ expect(instance.aboutModal).toMatchObject({
84
+ children: [
85
+ {
86
+ component: 'ZdHeader',
87
+ rightSlot: [{ component: 'ZdModalCloseButton' }],
88
+ },
89
+ {
90
+ component: 'ZdTag',
91
+ children: [{ component: 'ZdImage', src: 'path' }],
92
+ },
93
+ {
94
+ component: 'ZdTabs',
95
+ tabs: [
96
+ {
97
+ tabTitle: 'Frontend',
98
+ children: [
99
+ { component: 'ZdText', text: '{{TekUserInfoController_1.mainVersion}}' },
100
+ { component: 'ZdText', text: '{{TekUserInfoController_1.frontendItems}}' },
101
+ ],
102
+ },
103
+ {
104
+ tabTitle: 'Backend',
105
+ children: [
106
+ { component: 'ZdText', text: '{{TekUserInfoController_1.mainVersion}}' },
107
+ { component: 'ZdText', text: '{{TekUserInfoController_1.backendItems}}' },
108
+ ],
109
+ },
110
+ {
111
+ tabTitle: 'Modules',
112
+ children: [
113
+ { component: 'ZdText', text: '{{TekUserInfoController_1.mainVersion}}' },
114
+ { component: 'ZdText', text: '{{TekUserInfoController_1.modulesItems}}' },
115
+ ],
116
+ },
117
+ ],
118
+ },
119
+ ],
120
+ });
121
+ });
122
+
123
+ it('when about item is clicked twice, should create the modal only once', () => {
124
+ const spy = jest.spyOn(ModalService, 'create');
125
+ const instance = instantiateAndCreate({
126
+ name: 'TekUserInfo',
127
+ component: 'TekUserInfo',
128
+ versionInfo: {
129
+ name: 'Zeedhi',
130
+ version: '1.0.0',
131
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
132
+ backend: [{ name: 'package 2', version: '2.0.0' }],
133
+ modules: [{ name: 'package 3', version: '3.0.0' }],
134
+ },
135
+ });
136
+ instance.onAboutClick();
137
+ instance.onAboutClick();
138
+
139
+ expect(spy).toHaveBeenCalledTimes(1);
140
+ });
141
+
142
+ it('when versionInfo is undefined, should create empty tabs inside the modal', () => {
143
+ const instance = instantiateAndCreate({
144
+ name: 'TekUserInfo',
145
+ component: 'TekUserInfo',
146
+ });
147
+ instance.onAboutClick();
148
+
149
+ expect(instance.aboutModal).toMatchObject({
150
+ children: [
151
+ {
152
+ component: 'ZdHeader',
153
+ rightSlot: [{ component: 'ZdModalCloseButton' }],
154
+ },
155
+ {
156
+ component: 'ZdTag',
157
+ children: [{ component: 'ZdImage', src: '' }],
158
+ },
159
+ {
160
+ component: 'ZdTabs',
161
+ tabs: [
162
+ { tabTitle: 'Frontend', children: [] },
163
+ { tabTitle: 'Backend', children: [] },
164
+ { tabTitle: 'Modules', children: [] },
165
+ ],
166
+ },
167
+ ],
168
+ });
169
+ });
170
+ });
171
+
172
+ describe('Report Modal', () => {
173
+ it('when onReportClick is called, should open report modal', () => {
174
+ const instance = instantiateAndCreate({
175
+ name: 'TekUserInfo',
176
+ component: 'TekUserInfo',
177
+ defaultEmail: 'zeedhi@zd.com',
178
+ });
179
+ instance.onReportClick();
180
+
181
+ expect(instance.reportModal).toMatchObject({
182
+ children: [
183
+ {
184
+ component: 'ZdHeader',
185
+ leftSlot: [{ component: 'ZdText', text: 'TEKUSERINFO_REPORT_ERROR' }],
186
+ rightSlot: [{ component: 'ZdModalCloseButton' }],
187
+ },
188
+ {
189
+ component: 'ZdForm',
190
+ children: [
191
+ {
192
+ name: 'report_email',
193
+ component: 'ZdTextInput',
194
+ label: 'E-mail',
195
+ value: 'zeedhi@zd.com',
196
+ },
197
+ {
198
+ name: 'report_cc',
199
+ component: 'ZdTextInput',
200
+ label: 'CC',
201
+ placeholder: 'TEKUSERINFO_EMAIL_PLACEHOLDER',
202
+ },
203
+ {
204
+ name: 'report_type',
205
+ component: 'ZdSelect',
206
+ label: 'TEKUSERINFO_TYPE',
207
+ datasource: {
208
+ uniqueKey: 'value',
209
+ translate: true,
210
+ data: [
211
+ { value: '0', text: 'TEKUSERINFO_ERROR' },
212
+ { value: '1', text: 'TEKUSERINFO_IMPROVEMENT' },
213
+ ],
214
+ },
215
+ },
216
+ {
217
+ name: 'report_description',
218
+ component: 'ZdTextarea',
219
+ label: 'TEKUSERINFO_DESCRIPTION',
220
+ },
221
+ ],
222
+ },
223
+ {
224
+ component: 'ZdFooter',
225
+ rightSlot: [
226
+ { component: 'ZdButton', label: 'TEKUSERINFO_CANCEL' },
227
+ { component: 'ZdButton', label: 'TEKUSERINFO_SEND' },
228
+ ],
229
+ },
230
+ ],
231
+ });
232
+ });
233
+
234
+ it('when onReportClick is called twice, should create the modal only once', () => {
235
+ const spy = jest.spyOn(ModalService, 'create');
236
+ const instance = instantiateAndCreate({
237
+ name: 'TekUserInfo',
238
+ component: 'TekUserInfo',
239
+ defaultEmail: 'zeedhi@zd.com',
240
+ });
241
+
242
+ instance.onReportClick();
243
+ instance.onReportClick();
244
+
245
+ expect(spy).toHaveBeenCalledTimes(1);
246
+
247
+ spy.mockClear();
248
+ });
249
+
250
+ it('when send button is clicked, should call onSendReport event', () => {
251
+ const onSendReport = jest.fn();
252
+ const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => ({
253
+ validate: () => true,
254
+ }));
255
+ const instance = instantiateAndCreate({
256
+ name: 'TekUserInfo',
257
+ component: 'TekUserInfo',
258
+ events: {
259
+ onSendReport,
260
+ },
261
+ });
262
+ instance.onReportClick();
263
+ const button = instance.reportModal?.children[2].rightSlot[1];
264
+ const buttonInstance = new Button(button);
265
+
266
+ buttonInstance.click();
267
+
268
+ expect(onSendReport).toHaveBeenCalled();
269
+ spy.mockClear();
270
+ });
271
+
272
+ it('when send button is clicked and form is invalid, should not call onSendReport event', () => {
273
+ const onSendReport = jest.fn();
274
+ const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => ({
275
+ validate: () => false,
276
+ }));
277
+ const instance = instantiateAndCreate({
278
+ name: 'TekUserInfo',
279
+ component: 'TekUserInfo',
280
+ events: {
281
+ onSendReport,
282
+ },
283
+ });
284
+ instance.onReportClick();
285
+ const button = instance.reportModal?.children[2].rightSlot[1];
286
+ const buttonInstance = new Button(button);
287
+
288
+ buttonInstance.click();
289
+
290
+ expect(onSendReport).not.toHaveBeenCalled();
291
+ spy.mockClear();
292
+ });
293
+
294
+ it('when reportModal is undefined, should not call onSendReport event', () => {
295
+ const onSendReport = jest.fn();
296
+ const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => ({
297
+ validate: () => false,
298
+ }));
299
+ const instance = instantiateAndCreate({
300
+ name: 'TekUserInfo',
301
+ component: 'TekUserInfo',
302
+ events: {
303
+ onSendReport,
304
+ },
305
+ });
306
+ instance.onReportClick();
307
+ const button = instance.reportModal?.children[2].rightSlot[1];
308
+ const buttonInstance = new Button(button);
309
+
310
+ instance.reportModal = undefined;
311
+ buttonInstance.click();
312
+
313
+ expect(onSendReport).not.toHaveBeenCalled();
314
+ spy.mockClear();
315
+ });
316
+
317
+ it('when cancel button is clicked, should close the modal', () => {
318
+ const instance = instantiateAndCreate({
319
+ name: 'TekUserInfo',
320
+ component: 'TekUserInfo',
321
+ });
322
+ instance.onReportClick();
323
+ const spy = jest.spyOn(instance.reportModal as Modal, 'hide');
324
+ const button = instance.reportModal?.children[2].rightSlot[0];
325
+ const buttonInstance = new Button(button);
326
+
327
+ buttonInstance.click();
328
+
329
+ expect(spy).toHaveBeenCalled();
330
+ spy.mockClear();
331
+ });
332
+
333
+ it('when cancel button is clicked, should not throw if reportModal is undefined', () => {
334
+ const instance = instantiateAndCreate({
335
+ name: 'TekUserInfo',
336
+ component: 'TekUserInfo',
337
+ });
338
+ instance.onReportClick();
339
+ const button = instance.reportModal?.children[2].rightSlot[0];
340
+ const buttonInstance = new Button(button);
341
+
342
+ instance.reportModal = undefined;
343
+
344
+ expect(() => buttonInstance.click()).not.toThrow();
345
+ });
346
+ });
347
+
348
+ describe('onMounted', () => {
349
+ it('when onMounted is called and versionUrl is defined, should make a GET request to versionUrl', async () => {
350
+ const spy = jest.spyOn(Http, 'get').mockImplementation(() => Promise.resolve({
351
+ data: {
352
+ versionInfo: {
353
+ name: 'Zeedhi',
354
+ version: '1.0.0',
355
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
356
+ backend: [{ name: 'package 2', version: '2.0.0' }],
357
+ modules: [{ name: 'package 3', version: '3.0.0' }],
358
+ },
359
+ },
360
+ }));
361
+ const instance = new TekUserInfo({
362
+ name: 'TekUserInfo',
363
+ component: 'TekUserInfo',
364
+ versionUrl: '/version',
365
+ });
366
+
367
+ await instance.onMounted({});
368
+
369
+ expect(instance.versionInfo).toEqual({
370
+ name: 'Zeedhi',
371
+ version: '1.0.0',
372
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
373
+ backend: [{ name: 'package 2', version: '2.0.0' }],
374
+ modules: [{ name: 'package 3', version: '3.0.0' }],
375
+ });
376
+ spy.mockClear();
377
+ });
378
+ });
379
+
380
+ describe('onCreated', () => {
381
+ it('when onCreated is called and bottomSlot is empty, should assign default value to the latter', () => {
382
+ const instance = instantiateAndCreate({
383
+ name: 'TekUserInfo',
384
+ component: 'TekUserInfo',
385
+ });
386
+
387
+ expect(instance.bottomSlot).toMatchObject([
388
+ {
389
+ name: 'TekUserInfo_bottom_list',
390
+ component: 'TekUserInfoList',
391
+ parentName: 'TekUserInfo',
392
+ },
393
+ ]);
394
+ });
395
+ });
396
+
397
+ describe('visibleItems', () => {
398
+ it('when visibleItems is changed, should hide or show an item', () => {
399
+ const instance = instantiateAndCreate({
400
+ name: 'UserInfo',
401
+ component: 'UserInfo',
402
+ visibleItems: {
403
+ reportError: false,
404
+ versionInfo: false,
405
+ about: false,
406
+ },
407
+ });
408
+ const spy = jest.spyOn(Metadata, 'getInstance').mockImplementation(() => (instance));
409
+
410
+ const list = new TekUserInfoList({ parentName: 'UserInfo', ...instance.bottomSlot[0] });
411
+ const versionInfo = new ListItem({ ...list.items[0] });
412
+ const about = new ListItem({ ...list.items[1] });
413
+ const reportError = new ListItem({ ...list.items[2] });
414
+
415
+ expect(versionInfo.isVisible).toBeFalsy();
416
+ expect(about.isVisible).toBeFalsy();
417
+ expect(reportError.isVisible).toBeFalsy();
418
+
419
+ instance.visibleItems.versionInfo = true;
420
+ instance.visibleItems.about = true;
421
+ instance.visibleItems.reportError = true;
422
+
423
+ expect(versionInfo.isVisible).toBeTruthy();
424
+ expect(about.isVisible).toBeTruthy();
425
+ expect(reportError.isVisible).toBeTruthy();
426
+
427
+ spy.mockReset();
428
+ });
429
+ });
430
+ });