@zeedhi/teknisa-components-common 1.107.1 → 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,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
+ });