@zeedhi/teknisa-components-common 1.108.0 → 1.109.1

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 (70) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +7 -7
  3. package/coverage/clover.xml +49 -49
  4. package/coverage/coverage-final.json +47 -47
  5. package/coverage/lcov-report/index.html +1 -1
  6. package/coverage/lcov-report/tests/__helpers__/component-event-helper.ts.html +1 -1
  7. package/coverage/lcov-report/tests/__helpers__/flush-promises-helper.ts.html +1 -1
  8. package/coverage/lcov-report/tests/__helpers__/get-child-helper.ts.html +1 -1
  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 +47 -47
  13. package/jest.config.js +1 -1
  14. package/package.json +2 -2
  15. package/tests/__helpers__/component-event-helper.ts +5 -5
  16. package/tests/__helpers__/flush-promises-helper.ts +3 -3
  17. package/tests/__helpers__/get-child-helper.ts +27 -27
  18. package/tests/__helpers__/index.ts +3 -3
  19. package/tests/__helpers__/mock-created-helper.ts +12 -12
  20. package/tests/__mocks__/@zeedhi/core/i18n.js +74 -74
  21. package/tests/__mocks__/@zeedhi/core.js +4 -4
  22. package/tests/unit/components/crud/crud-add-button.spec.ts +56 -56
  23. package/tests/unit/components/crud/crud-button.spec.ts +94 -94
  24. package/tests/unit/components/crud/crud-cancel-button.spec.ts +91 -91
  25. package/tests/unit/components/crud/crud-delete-button.spec.ts +122 -122
  26. package/tests/unit/components/crud/crud-form.spec.ts +165 -165
  27. package/tests/unit/components/crud/crud-save-button.spec.ts +118 -118
  28. package/tests/unit/components/tek-breadcrumb-header/tek-breadcrumb-header.spec.ts +42 -42
  29. package/tests/unit/components/tek-card-title/CardTitle.spec.ts +34 -34
  30. package/tests/unit/components/tek-datasource/memory-datasource.spec.ts +470 -470
  31. package/tests/unit/components/tek-datasource/rest-datasource.spec.ts +364 -364
  32. package/tests/unit/components/tek-drag-grid/tek-drag-grid.spec.ts +112 -112
  33. package/tests/unit/components/tek-grid/filter-helper.spec.ts +148 -148
  34. package/tests/unit/components/tek-grid/grid-column.spec.ts +270 -270
  35. package/tests/unit/components/tek-grid/grid-columns-button.spec.ts +195 -195
  36. package/tests/unit/components/tek-grid/grid-filter-button.spec.ts +967 -967
  37. package/tests/unit/components/tek-grid/grid.spec.ts +3340 -3340
  38. package/tests/unit/components/tek-grid/layout_options.spec.ts +980 -980
  39. package/tests/unit/components/tek-image/Image.spec.ts +67 -67
  40. package/tests/unit/components/tek-iterable-carousel/iterable-carousel.spec.ts +37 -37
  41. package/tests/unit/components/tek-iterable-component-render/iterable-component-render.spec.ts +200 -200
  42. package/tests/unit/components/tek-loading/Loading.spec.ts +30 -30
  43. package/tests/unit/components/tek-notifications/notifications.spec.ts +201 -201
  44. package/tests/unit/components/tek-product-card/product-card.spec.ts +61 -61
  45. package/tests/unit/components/tek-user-info/TekUserInfoContoller.spec.ts +220 -220
  46. package/tests/unit/components/tek-user-info/tek-user-info-list.spec.ts +86 -86
  47. package/tests/unit/components/tek-user-info/tek-user-info.spec.ts +430 -430
  48. package/tests/unit/components/tree-grid/tree-grid.spec.ts +776 -776
  49. package/tests/unit/utils/grid-base/delete-rows-error.spec.ts +24 -24
  50. package/tests/unit/utils/grid-base/export-options/button-option.spec.ts +44 -44
  51. package/tests/unit/utils/grid-base/export-options/multi-option.spec.ts +135 -135
  52. package/tests/unit/utils/grid-base/grid-controller.spec.ts +267 -267
  53. package/tests/unit/utils/report-filter/report-filter.spec.ts +66 -66
  54. package/tsconfig.eslint.json +8 -8
  55. package/types/components/tek-ag-grid/default-icons.d.ts +53 -0
  56. package/types/components/tek-ag-grid/interfaces.d.ts +9 -0
  57. package/types/components/tek-ag-grid/tek-ag-grid.d.ts +35 -0
  58. package/types/components/tek-datasource/datasource.d.ts +94 -0
  59. package/types/components/tek-datasource/memory-datasource.d.ts +4 -2
  60. package/types/components/tek-datasource/rest-datasource.d.ts +4 -6
  61. package/types/components/tek-grid/default-icons.d.ts +53 -0
  62. package/types/components/tek-grid/filter-dynamic-values.d.ts +9 -0
  63. package/types/components/tek-grid/grid-controller.d.ts +19 -0
  64. package/types/components/tek-grid/grid_column.d.ts +14 -0
  65. package/types/components/tek-grid/grid_controller.d.ts +15 -0
  66. package/types/components/tek-grid/tek-grid.d.ts +35 -0
  67. package/types/components/tek-login/interfaces.d.ts +3 -0
  68. package/types/components/tek-login/login-children.d.ts +3 -0
  69. package/types/components/tek-login/login.d.ts +58 -0
  70. package/types/components/tek-login/login_children.d.ts +3 -0
@@ -1,61 +1,61 @@
1
- import { ProductCard } from '../../../../src';
2
-
3
- describe('ProductCard', () => {
4
- describe('constructor()', () => {
5
- it('should create new ProductCard with default values', () => {
6
- const instance = new ProductCard({
7
- name: 'product',
8
- component: 'TekProductCard',
9
- });
10
- expect(instance.to).toBe('');
11
- expect(instance.id).toBe('');
12
- expect(instance.src).toBe('');
13
- expect(instance.productName).toBe('');
14
- expect(instance.errorImagePath).toBe('');
15
- expect(instance.errorImageText).toBe('UNAVAILABLE_IMAGE');
16
- expect(instance.width).toBe('');
17
- expect(instance.height).toBe('auto');
18
- expect(instance.maxHeight).toBe('none');
19
- expect(instance.minHeight).toBe('none');
20
- });
21
-
22
- it('should create new ProductCard replace default values', () => {
23
- const instance = new ProductCard({
24
- name: 'product',
25
- component: 'TekProductCard',
26
- to: '/home',
27
- id: 'id',
28
- src: '/img/zeedhi.svg',
29
- productName: 'ProductTest',
30
- productPrice: '150',
31
- errorImagePath: 'image-error.avif',
32
- errorImageText: 'Image not found',
33
- width: '200',
34
- height: '400px',
35
- minHeight: '300px',
36
- maxHeight: '500px',
37
- });
38
- expect(instance.to).toBe('/home');
39
- expect(instance.id).toBe('id');
40
- expect(instance.src).toBe('/img/zeedhi.svg');
41
- expect(instance.productName).toBe('ProductTest');
42
- expect(instance.errorImagePath).toBe('image-error.avif');
43
- expect(instance.errorImageText).toBe('Image not found');
44
- expect(instance.width).toBe('200');
45
- expect(instance.productPriceFormat).toBe('$150.00');
46
- expect(instance.height).toBe('400px');
47
- expect(instance.minHeight).toBe('300px');
48
- expect(instance.maxHeight).toBe('500px');
49
- });
50
-
51
- it('productPrice value 0', () => {
52
- const instance = new ProductCard({
53
- name: 'product',
54
- component: 'TekProductCard',
55
- productName: 'ProductTest',
56
- productPrice: 0,
57
- });
58
- expect(instance.productPriceFormat).toBe('$0.00');
59
- });
60
- });
61
- });
1
+ import { ProductCard } from '../../../../src';
2
+
3
+ describe('ProductCard', () => {
4
+ describe('constructor()', () => {
5
+ it('should create new ProductCard with default values', () => {
6
+ const instance = new ProductCard({
7
+ name: 'product',
8
+ component: 'TekProductCard',
9
+ });
10
+ expect(instance.to).toBe('');
11
+ expect(instance.id).toBe('');
12
+ expect(instance.src).toBe('');
13
+ expect(instance.productName).toBe('');
14
+ expect(instance.errorImagePath).toBe('');
15
+ expect(instance.errorImageText).toBe('UNAVAILABLE_IMAGE');
16
+ expect(instance.width).toBe('');
17
+ expect(instance.height).toBe('auto');
18
+ expect(instance.maxHeight).toBe('none');
19
+ expect(instance.minHeight).toBe('none');
20
+ });
21
+
22
+ it('should create new ProductCard replace default values', () => {
23
+ const instance = new ProductCard({
24
+ name: 'product',
25
+ component: 'TekProductCard',
26
+ to: '/home',
27
+ id: 'id',
28
+ src: '/img/zeedhi.svg',
29
+ productName: 'ProductTest',
30
+ productPrice: '150',
31
+ errorImagePath: 'image-error.avif',
32
+ errorImageText: 'Image not found',
33
+ width: '200',
34
+ height: '400px',
35
+ minHeight: '300px',
36
+ maxHeight: '500px',
37
+ });
38
+ expect(instance.to).toBe('/home');
39
+ expect(instance.id).toBe('id');
40
+ expect(instance.src).toBe('/img/zeedhi.svg');
41
+ expect(instance.productName).toBe('ProductTest');
42
+ expect(instance.errorImagePath).toBe('image-error.avif');
43
+ expect(instance.errorImageText).toBe('Image not found');
44
+ expect(instance.width).toBe('200');
45
+ expect(instance.productPriceFormat).toBe('$150.00');
46
+ expect(instance.height).toBe('400px');
47
+ expect(instance.minHeight).toBe('300px');
48
+ expect(instance.maxHeight).toBe('500px');
49
+ });
50
+
51
+ it('productPrice value 0', () => {
52
+ const instance = new ProductCard({
53
+ name: 'product',
54
+ component: 'TekProductCard',
55
+ productName: 'ProductTest',
56
+ productPrice: 0,
57
+ });
58
+ expect(instance.productPriceFormat).toBe('$0.00');
59
+ });
60
+ });
61
+ });
@@ -1,220 +1,220 @@
1
- import { TekUserInfo } from '../../../../src';
2
- import { TekUserInfoController } from '../../../../src/components/tek-user-info/TekUserInfoController';
3
-
4
- describe('TekUserInfoController', () => {
5
- describe('name property', () => {
6
- it('should get name property', () => {
7
- const component = new TekUserInfo({
8
- name: 'user-info',
9
- component: 'TekUserInfo',
10
- versionInfo: {
11
- name: 'Zeedhi',
12
- version: '1.0.0',
13
- frontend: [{ name: 'package 1', version: '1.0.0' }],
14
- backend: [{ name: 'package 2', version: '2.0.0' }],
15
- modules: [{ name: 'package 3', version: '3.0.0' }],
16
- },
17
- });
18
- const controller = new TekUserInfoController(component);
19
-
20
- expect(controller.name).toBe('Zeedhi');
21
- });
22
-
23
- it('when prop is defined, should set the component value', () => {
24
- const component = new TekUserInfo({
25
- name: 'user-info',
26
- component: 'TekUserInfo',
27
- versionInfo: {
28
- name: 'Zeedhi',
29
- version: '1.0.0',
30
- frontend: [{ name: 'package 1', version: '1.0.0' }],
31
- backend: [{ name: 'package 2', version: '2.0.0' }],
32
- modules: [{ name: 'package 3', version: '3.0.0' }],
33
- },
34
- });
35
- const controller = new TekUserInfoController(component);
36
-
37
- controller.name = 'new name';
38
-
39
- expect(controller.name).toBe('new name');
40
- expect(component.versionInfo?.name).toBe('new name');
41
- });
42
-
43
- it('when versionInfo is null, should get empty string', () => {
44
- const component = new TekUserInfo({
45
- name: 'user-info',
46
- component: 'TekUserInfo',
47
- versionInfo: null,
48
- });
49
- const controller = new TekUserInfoController(component);
50
-
51
- expect(controller.name).toBe('');
52
- });
53
-
54
- it('when versionInfo is null, should not throw when setting', () => {
55
- const component = new TekUserInfo({
56
- name: 'user-info',
57
- component: 'TekUserInfo',
58
- versionInfo: null,
59
- });
60
- const controller = new TekUserInfoController(component);
61
-
62
- expect(() => { controller.name = 'new name'; }).not.toThrow();
63
- });
64
- });
65
-
66
- describe('version property', () => {
67
- it('should get version property', () => {
68
- const component = new TekUserInfo({
69
- name: 'user-info',
70
- component: 'TekUserInfo',
71
- versionInfo: {
72
- name: 'Zeedhi',
73
- version: '1.0.0',
74
- frontend: [{ name: 'package 1', version: '1.0.0' }],
75
- backend: [{ name: 'package 2', version: '2.0.0' }],
76
- modules: [{ name: 'package 3', version: '3.0.0' }],
77
- },
78
- });
79
- const controller = new TekUserInfoController(component);
80
-
81
- expect(controller.version).toBe('1.0.0');
82
- });
83
-
84
- it('when prop is defined, should set the component value', () => {
85
- const component = new TekUserInfo({
86
- name: 'user-info',
87
- component: 'TekUserInfo',
88
- versionInfo: {
89
- name: 'Zeedhi',
90
- version: '1.0.0',
91
- frontend: [{ name: 'package 1', version: '1.0.0' }],
92
- backend: [{ name: 'package 2', version: '2.0.0' }],
93
- modules: [{ name: 'package 3', version: '3.0.0' }],
94
- },
95
- });
96
- const controller = new TekUserInfoController(component);
97
-
98
- controller.version = '2.0.0';
99
-
100
- expect(controller.version).toBe('2.0.0');
101
- expect(component.versionInfo?.version).toBe('2.0.0');
102
- });
103
-
104
- it('when versionInfo is null, should get empty string', () => {
105
- const component = new TekUserInfo({
106
- name: 'user-info',
107
- component: 'TekUserInfo',
108
- versionInfo: null,
109
- });
110
- const controller = new TekUserInfoController(component);
111
-
112
- expect(controller.version).toBe('');
113
- });
114
-
115
- it('when versionInfo is null, should not throw when setting', () => {
116
- const component = new TekUserInfo({
117
- name: 'user-info',
118
- component: 'TekUserInfo',
119
- versionInfo: null,
120
- });
121
- const controller = new TekUserInfoController(component);
122
-
123
- expect(() => { controller.version = '2.0.0'; }).not.toThrow();
124
- });
125
- });
126
-
127
- describe('defaultEmail property', () => {
128
- it('should get defaultEmail property', () => {
129
- const component = new TekUserInfo({
130
- name: 'user-info',
131
- component: 'TekUserInfo',
132
- defaultEmail: 'zeedhi@zd.com',
133
- });
134
- const controller = new TekUserInfoController(component);
135
-
136
- expect(controller.hasDefaultEmail).toBeTruthy();
137
- });
138
- });
139
-
140
- describe('mainVersion property', () => {
141
- it('should get mainVersion property', () => {
142
- const component = new TekUserInfo({
143
- name: 'user-info',
144
- component: 'TekUserInfo',
145
- versionInfo: {
146
- name: 'Zeedhi',
147
- version: '1.0.0',
148
- frontend: [{ name: 'package 1', version: '1.0.0' }],
149
- backend: [{ name: 'package 2', version: '2.0.0' }],
150
- modules: [{ name: 'package 3', version: '3.0.0' }],
151
- },
152
- });
153
- const controller = new TekUserInfoController(component);
154
-
155
- expect(controller.mainVersion).toBe('Zeedhi - <b>1.0.0</b>');
156
- });
157
-
158
- it('when versionInfo is null, mainVersion should return empty string', () => {
159
- const component = new TekUserInfo({
160
- name: 'user-info',
161
- component: 'TekUserInfo',
162
- versionInfo: null,
163
- });
164
- const controller = new TekUserInfoController(component);
165
-
166
- expect(controller.mainVersion).toBe('');
167
- });
168
- });
169
-
170
- describe('item properties', () => {
171
- it('should get the items', () => {
172
- const component = new TekUserInfo({
173
- name: 'user-info',
174
- component: 'TekUserInfo',
175
- versionInfo: {
176
- name: 'Zeedhi',
177
- version: '1.0.0',
178
- frontend: [{ name: 'package 1', version: '1.0.0' }],
179
- backend: [{ name: 'package 2', version: '2.0.0' }],
180
- modules: [{ name: 'package 3', version: '3.0.0' }],
181
- },
182
- });
183
- const controller = new TekUserInfoController(component);
184
-
185
- expect(controller.frontendItems).toEqual('<ul><li>package 1 - <b>1.0.0</b></li></ul>');
186
- expect(controller.backendItems).toEqual('<ul><li>package 2 - <b>2.0.0</b></li></ul>');
187
- expect(controller.modulesItems).toEqual('<ul><li>package 3 - <b>3.0.0</b></li></ul>');
188
- });
189
-
190
- it('when versionInfo is null, should get empty array', () => {
191
- const component = new TekUserInfo({
192
- name: 'user-info',
193
- component: 'TekUserInfo',
194
- versionInfo: null,
195
- });
196
- const controller = new TekUserInfoController(component);
197
-
198
- expect(controller.frontendItems).toEqual([]);
199
- expect(controller.backendItems).toEqual([]);
200
- expect(controller.modulesItems).toEqual([]);
201
- });
202
- });
203
-
204
- describe('aboutImage properties', () => {
205
- it('should return true if aboutImage is defined, false otherwise', () => {
206
- const component = new TekUserInfo({
207
- name: 'user-info',
208
- component: 'TekUserInfo',
209
- aboutImage: 'path',
210
- });
211
- const controller = new TekUserInfoController(component);
212
-
213
- expect(controller.hasAboutImage).toBeTruthy();
214
-
215
- component.aboutImage = '';
216
-
217
- expect(controller.hasAboutImage).toBeFalsy();
218
- });
219
- });
220
- });
1
+ import { TekUserInfo } from '../../../../src';
2
+ import { TekUserInfoController } from '../../../../src/components/tek-user-info/TekUserInfoController';
3
+
4
+ describe('TekUserInfoController', () => {
5
+ describe('name property', () => {
6
+ it('should get name property', () => {
7
+ const component = new TekUserInfo({
8
+ name: 'user-info',
9
+ component: 'TekUserInfo',
10
+ versionInfo: {
11
+ name: 'Zeedhi',
12
+ version: '1.0.0',
13
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
14
+ backend: [{ name: 'package 2', version: '2.0.0' }],
15
+ modules: [{ name: 'package 3', version: '3.0.0' }],
16
+ },
17
+ });
18
+ const controller = new TekUserInfoController(component);
19
+
20
+ expect(controller.name).toBe('Zeedhi');
21
+ });
22
+
23
+ it('when prop is defined, should set the component value', () => {
24
+ const component = new TekUserInfo({
25
+ name: 'user-info',
26
+ component: 'TekUserInfo',
27
+ versionInfo: {
28
+ name: 'Zeedhi',
29
+ version: '1.0.0',
30
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
31
+ backend: [{ name: 'package 2', version: '2.0.0' }],
32
+ modules: [{ name: 'package 3', version: '3.0.0' }],
33
+ },
34
+ });
35
+ const controller = new TekUserInfoController(component);
36
+
37
+ controller.name = 'new name';
38
+
39
+ expect(controller.name).toBe('new name');
40
+ expect(component.versionInfo?.name).toBe('new name');
41
+ });
42
+
43
+ it('when versionInfo is null, should get empty string', () => {
44
+ const component = new TekUserInfo({
45
+ name: 'user-info',
46
+ component: 'TekUserInfo',
47
+ versionInfo: null,
48
+ });
49
+ const controller = new TekUserInfoController(component);
50
+
51
+ expect(controller.name).toBe('');
52
+ });
53
+
54
+ it('when versionInfo is null, should not throw when setting', () => {
55
+ const component = new TekUserInfo({
56
+ name: 'user-info',
57
+ component: 'TekUserInfo',
58
+ versionInfo: null,
59
+ });
60
+ const controller = new TekUserInfoController(component);
61
+
62
+ expect(() => { controller.name = 'new name'; }).not.toThrow();
63
+ });
64
+ });
65
+
66
+ describe('version property', () => {
67
+ it('should get version property', () => {
68
+ const component = new TekUserInfo({
69
+ name: 'user-info',
70
+ component: 'TekUserInfo',
71
+ versionInfo: {
72
+ name: 'Zeedhi',
73
+ version: '1.0.0',
74
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
75
+ backend: [{ name: 'package 2', version: '2.0.0' }],
76
+ modules: [{ name: 'package 3', version: '3.0.0' }],
77
+ },
78
+ });
79
+ const controller = new TekUserInfoController(component);
80
+
81
+ expect(controller.version).toBe('1.0.0');
82
+ });
83
+
84
+ it('when prop is defined, should set the component value', () => {
85
+ const component = new TekUserInfo({
86
+ name: 'user-info',
87
+ component: 'TekUserInfo',
88
+ versionInfo: {
89
+ name: 'Zeedhi',
90
+ version: '1.0.0',
91
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
92
+ backend: [{ name: 'package 2', version: '2.0.0' }],
93
+ modules: [{ name: 'package 3', version: '3.0.0' }],
94
+ },
95
+ });
96
+ const controller = new TekUserInfoController(component);
97
+
98
+ controller.version = '2.0.0';
99
+
100
+ expect(controller.version).toBe('2.0.0');
101
+ expect(component.versionInfo?.version).toBe('2.0.0');
102
+ });
103
+
104
+ it('when versionInfo is null, should get empty string', () => {
105
+ const component = new TekUserInfo({
106
+ name: 'user-info',
107
+ component: 'TekUserInfo',
108
+ versionInfo: null,
109
+ });
110
+ const controller = new TekUserInfoController(component);
111
+
112
+ expect(controller.version).toBe('');
113
+ });
114
+
115
+ it('when versionInfo is null, should not throw when setting', () => {
116
+ const component = new TekUserInfo({
117
+ name: 'user-info',
118
+ component: 'TekUserInfo',
119
+ versionInfo: null,
120
+ });
121
+ const controller = new TekUserInfoController(component);
122
+
123
+ expect(() => { controller.version = '2.0.0'; }).not.toThrow();
124
+ });
125
+ });
126
+
127
+ describe('defaultEmail property', () => {
128
+ it('should get defaultEmail property', () => {
129
+ const component = new TekUserInfo({
130
+ name: 'user-info',
131
+ component: 'TekUserInfo',
132
+ defaultEmail: 'zeedhi@zd.com',
133
+ });
134
+ const controller = new TekUserInfoController(component);
135
+
136
+ expect(controller.hasDefaultEmail).toBeTruthy();
137
+ });
138
+ });
139
+
140
+ describe('mainVersion property', () => {
141
+ it('should get mainVersion property', () => {
142
+ const component = new TekUserInfo({
143
+ name: 'user-info',
144
+ component: 'TekUserInfo',
145
+ versionInfo: {
146
+ name: 'Zeedhi',
147
+ version: '1.0.0',
148
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
149
+ backend: [{ name: 'package 2', version: '2.0.0' }],
150
+ modules: [{ name: 'package 3', version: '3.0.0' }],
151
+ },
152
+ });
153
+ const controller = new TekUserInfoController(component);
154
+
155
+ expect(controller.mainVersion).toBe('Zeedhi - <b>1.0.0</b>');
156
+ });
157
+
158
+ it('when versionInfo is null, mainVersion should return empty string', () => {
159
+ const component = new TekUserInfo({
160
+ name: 'user-info',
161
+ component: 'TekUserInfo',
162
+ versionInfo: null,
163
+ });
164
+ const controller = new TekUserInfoController(component);
165
+
166
+ expect(controller.mainVersion).toBe('');
167
+ });
168
+ });
169
+
170
+ describe('item properties', () => {
171
+ it('should get the items', () => {
172
+ const component = new TekUserInfo({
173
+ name: 'user-info',
174
+ component: 'TekUserInfo',
175
+ versionInfo: {
176
+ name: 'Zeedhi',
177
+ version: '1.0.0',
178
+ frontend: [{ name: 'package 1', version: '1.0.0' }],
179
+ backend: [{ name: 'package 2', version: '2.0.0' }],
180
+ modules: [{ name: 'package 3', version: '3.0.0' }],
181
+ },
182
+ });
183
+ const controller = new TekUserInfoController(component);
184
+
185
+ expect(controller.frontendItems).toEqual('<ul><li>package 1 - <b>1.0.0</b></li></ul>');
186
+ expect(controller.backendItems).toEqual('<ul><li>package 2 - <b>2.0.0</b></li></ul>');
187
+ expect(controller.modulesItems).toEqual('<ul><li>package 3 - <b>3.0.0</b></li></ul>');
188
+ });
189
+
190
+ it('when versionInfo is null, should get empty array', () => {
191
+ const component = new TekUserInfo({
192
+ name: 'user-info',
193
+ component: 'TekUserInfo',
194
+ versionInfo: null,
195
+ });
196
+ const controller = new TekUserInfoController(component);
197
+
198
+ expect(controller.frontendItems).toEqual([]);
199
+ expect(controller.backendItems).toEqual([]);
200
+ expect(controller.modulesItems).toEqual([]);
201
+ });
202
+ });
203
+
204
+ describe('aboutImage properties', () => {
205
+ it('should return true if aboutImage is defined, false otherwise', () => {
206
+ const component = new TekUserInfo({
207
+ name: 'user-info',
208
+ component: 'TekUserInfo',
209
+ aboutImage: 'path',
210
+ });
211
+ const controller = new TekUserInfoController(component);
212
+
213
+ expect(controller.hasAboutImage).toBeTruthy();
214
+
215
+ component.aboutImage = '';
216
+
217
+ expect(controller.hasAboutImage).toBeFalsy();
218
+ });
219
+ });
220
+ });