@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.
- package/LICENSE +21 -21
- package/README.md +7 -7
- package/coverage/clover.xml +772 -692
- package/coverage/coverage-final.json +47 -47
- package/coverage/lcov-report/index.html +15 -15
- package/coverage/lcov-report/tests/__helpers__/component-event-helper.ts.html +2 -2
- package/coverage/lcov-report/tests/__helpers__/flush-promises-helper.ts.html +2 -2
- package/coverage/lcov-report/tests/__helpers__/get-child-helper.ts.html +7 -7
- package/coverage/lcov-report/tests/__helpers__/index.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/index.ts.html +1 -1
- package/coverage/lcov-report/tests/__helpers__/mock-created-helper.ts.html +1 -1
- package/coverage/lcov.info +1459 -1275
- package/dist/tek-components-common.esm.js +375 -252
- package/dist/tek-components-common.umd.js +375 -252
- package/jest.config.js +1 -1
- package/package.json +2 -2
- package/tests/__helpers__/component-event-helper.ts +5 -5
- package/tests/__helpers__/flush-promises-helper.ts +3 -3
- package/tests/__helpers__/get-child-helper.ts +27 -27
- package/tests/__helpers__/index.ts +3 -3
- package/tests/__helpers__/mock-created-helper.ts +12 -12
- package/tests/__mocks__/@zeedhi/core/i18n.js +74 -74
- package/tests/__mocks__/@zeedhi/core.js +4 -4
- package/tests/unit/components/crud/crud-add-button.spec.ts +56 -56
- package/tests/unit/components/crud/crud-button.spec.ts +94 -94
- package/tests/unit/components/crud/crud-cancel-button.spec.ts +91 -91
- package/tests/unit/components/crud/crud-delete-button.spec.ts +122 -122
- package/tests/unit/components/crud/crud-form.spec.ts +165 -165
- package/tests/unit/components/crud/crud-save-button.spec.ts +118 -118
- package/tests/unit/components/tek-breadcrumb-header/tek-breadcrumb-header.spec.ts +42 -42
- package/tests/unit/components/tek-card-title/CardTitle.spec.ts +34 -34
- package/tests/unit/components/tek-datasource/memory-datasource.spec.ts +470 -470
- package/tests/unit/components/tek-datasource/rest-datasource.spec.ts +364 -364
- package/tests/unit/components/tek-drag-grid/tek-drag-grid.spec.ts +112 -112
- package/tests/unit/components/tek-grid/filter-helper.spec.ts +148 -148
- package/tests/unit/components/tek-grid/grid-column.spec.ts +270 -270
- package/tests/unit/components/tek-grid/grid-columns-button.spec.ts +195 -195
- package/tests/unit/components/tek-grid/grid-filter-button.spec.ts +967 -967
- package/tests/unit/components/tek-grid/grid.spec.ts +3340 -3116
- package/tests/unit/components/tek-grid/layout_options.spec.ts +980 -980
- package/tests/unit/components/tek-image/Image.spec.ts +67 -67
- package/tests/unit/components/tek-iterable-carousel/iterable-carousel.spec.ts +37 -37
- package/tests/unit/components/tek-iterable-component-render/iterable-component-render.spec.ts +200 -200
- package/tests/unit/components/tek-loading/Loading.spec.ts +30 -30
- package/tests/unit/components/tek-notifications/notifications.spec.ts +201 -201
- package/tests/unit/components/tek-product-card/product-card.spec.ts +61 -61
- package/tests/unit/components/tek-user-info/TekUserInfoContoller.spec.ts +220 -220
- package/tests/unit/components/tek-user-info/tek-user-info-list.spec.ts +86 -86
- package/tests/unit/components/tek-user-info/tek-user-info.spec.ts +430 -430
- package/tests/unit/components/tree-grid/tree-grid.spec.ts +776 -776
- package/tests/unit/utils/grid-base/delete-rows-error.spec.ts +24 -0
- package/tests/unit/utils/grid-base/export-options/button-option.spec.ts +44 -44
- package/tests/unit/utils/grid-base/export-options/multi-option.spec.ts +135 -135
- package/tests/unit/utils/grid-base/grid-controller.spec.ts +267 -174
- package/tests/unit/utils/report-filter/report-filter.spec.ts +66 -66
- package/tsconfig.eslint.json +8 -8
- package/types/components/tek-datasource/memory-datasource.d.ts +2 -4
- package/types/components/tek-datasource/rest-datasource.d.ts +6 -3
- package/types/components/tek-grid/grid.d.ts +50 -6
- package/types/components/tek-grid/interfaces.d.ts +5 -3
- package/types/components/tek-tree-grid/tree-grid.d.ts +5 -1
- package/types/utils/grid-base/grid-base.d.ts +12 -229
- package/types/utils/grid-base/grid-controller.d.ts +1 -3
- package/types/components/tek-ag-grid/default-icons.d.ts +0 -53
- package/types/components/tek-ag-grid/interfaces.d.ts +0 -9
- package/types/components/tek-ag-grid/tek-ag-grid.d.ts +0 -35
- package/types/components/tek-datasource/datasource.d.ts +0 -94
- package/types/components/tek-grid/default-icons.d.ts +0 -53
- package/types/components/tek-grid/filter-dynamic-values.d.ts +0 -9
- package/types/components/tek-grid/grid-controller.d.ts +0 -19
- package/types/components/tek-grid/grid_column.d.ts +0 -14
- package/types/components/tek-grid/grid_controller.d.ts +0 -15
- package/types/components/tek-grid/tek-grid.d.ts +0 -35
- package/types/components/tek-login/interfaces.d.ts +0 -3
- package/types/components/tek-login/login-children.d.ts +0 -3
- package/types/components/tek-login/login.d.ts +0 -58
- 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
|
+
});
|