verben-workflow-ui 0.0.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 (95) hide show
  1. package/README.md +25 -0
  2. package/esm2022/lib/components/forms/base-table-style.mjs +53 -0
  3. package/esm2022/lib/components/forms/form-details/form-details.component.mjs +672 -0
  4. package/esm2022/lib/components/forms/form-details/form-details.module.mjs +62 -0
  5. package/esm2022/lib/components/forms/form-details/form-fields.service.mjs +61 -0
  6. package/esm2022/lib/components/forms/form-details/helper.mjs +22 -0
  7. package/esm2022/lib/components/forms/form-fields/form-fields.component.mjs +835 -0
  8. package/esm2022/lib/components/forms/form-fields/form-fields.module.mjs +62 -0
  9. package/esm2022/lib/components/forms/form-fields/form-fields.service.mjs +56 -0
  10. package/esm2022/lib/components/forms/forms.component.mjs +668 -0
  11. package/esm2022/lib/components/forms/forms.module.mjs +81 -0
  12. package/esm2022/lib/components/forms/forms.service.mjs +51 -0
  13. package/esm2022/lib/components/forms/helper.mjs +39 -0
  14. package/esm2022/lib/components/task-history/task-history.component.mjs +83 -0
  15. package/esm2022/lib/components/task-history/task-history.module.mjs +38 -0
  16. package/esm2022/lib/components/workflow/column.mjs +38 -0
  17. package/esm2022/lib/components/workflow/helper.mjs +45 -0
  18. package/esm2022/lib/components/workflow/table-style.mjs +53 -0
  19. package/esm2022/lib/components/workflow/workflow.component.mjs +216 -0
  20. package/esm2022/lib/components/workflow/workflow.module.mjs +19 -0
  21. package/esm2022/lib/models/DataType.mjs +8 -0
  22. package/esm2022/lib/models/ErrorResponse.mjs +11 -0
  23. package/esm2022/lib/models/FormEntity.mjs +2 -0
  24. package/esm2022/lib/models/FormProperty.mjs +2 -0
  25. package/esm2022/lib/models/FormValues.mjs +2 -0
  26. package/esm2022/lib/models/Forms.mjs +2 -0
  27. package/esm2022/lib/models/PagedResult.mjs +2 -0
  28. package/esm2022/lib/models/SearchOperator.mjs +6 -0
  29. package/esm2022/lib/models/SearchPropertySign.mjs +11 -0
  30. package/esm2022/lib/models/SearchPropertyValue.mjs +2 -0
  31. package/esm2022/lib/models/SearchPropertyValueType.mjs +11 -0
  32. package/esm2022/lib/models/Tag.mjs +2 -0
  33. package/esm2022/lib/models/TaskAssignmentType.mjs +6 -0
  34. package/esm2022/lib/models/Workflow.mjs +7 -0
  35. package/esm2022/lib/models/base.mjs +2 -0
  36. package/esm2022/lib/models/object-state.mjs +8 -0
  37. package/esm2022/lib/models/operation-type.mjs +7 -0
  38. package/esm2022/lib/models/status.mjs +6 -0
  39. package/esm2022/lib/models/task-history.mjs +2 -0
  40. package/esm2022/lib/models/user.mjs +2 -0
  41. package/esm2022/lib/services/environment.service.mjs +26 -0
  42. package/esm2022/lib/services/http-web-request.service.mjs +83 -0
  43. package/esm2022/lib/services/util.service.mjs +56 -0
  44. package/esm2022/lib/shared/shared.module.mjs +81 -0
  45. package/esm2022/public-api.mjs +14 -0
  46. package/esm2022/verben-workflow-ui.mjs +5 -0
  47. package/fesm2022/verben-workflow-ui.mjs +3327 -0
  48. package/fesm2022/verben-workflow-ui.mjs.map +1 -0
  49. package/index.d.ts +5 -0
  50. package/lib/components/forms/base-table-style.d.ts +1 -0
  51. package/lib/components/forms/form-details/form-details.component.d.ts +100 -0
  52. package/lib/components/forms/form-details/form-details.module.d.ts +10 -0
  53. package/lib/components/forms/form-details/form-fields.service.d.ts +9 -0
  54. package/lib/components/forms/form-details/helper.d.ts +2 -0
  55. package/lib/components/forms/form-fields/form-fields.component.d.ts +121 -0
  56. package/lib/components/forms/form-fields/form-fields.module.d.ts +10 -0
  57. package/lib/components/forms/form-fields/form-fields.service.d.ts +9 -0
  58. package/lib/components/forms/forms.component.d.ts +107 -0
  59. package/lib/components/forms/forms.module.d.ts +15 -0
  60. package/lib/components/forms/forms.service.d.ts +9 -0
  61. package/lib/components/forms/helper.d.ts +2 -0
  62. package/lib/components/task-history/task-history.component.d.ts +19 -0
  63. package/lib/components/task-history/task-history.module.d.ts +10 -0
  64. package/lib/components/workflow/column.d.ts +3 -0
  65. package/lib/components/workflow/helper.d.ts +2 -0
  66. package/lib/components/workflow/table-style.d.ts +1 -0
  67. package/lib/components/workflow/workflow.component.d.ts +57 -0
  68. package/lib/components/workflow/workflow.module.d.ts +9 -0
  69. package/lib/models/DataType.d.ts +6 -0
  70. package/lib/models/ErrorResponse.d.ts +6 -0
  71. package/lib/models/FormEntity.d.ts +12 -0
  72. package/lib/models/FormProperty.d.ts +11 -0
  73. package/lib/models/FormValues.d.ts +14 -0
  74. package/lib/models/Forms.d.ts +11 -0
  75. package/lib/models/PagedResult.d.ts +5 -0
  76. package/lib/models/SearchOperator.d.ts +4 -0
  77. package/lib/models/SearchPropertySign.d.ts +9 -0
  78. package/lib/models/SearchPropertyValue.d.ts +10 -0
  79. package/lib/models/SearchPropertyValueType.d.ts +9 -0
  80. package/lib/models/Tag.d.ts +4 -0
  81. package/lib/models/TaskAssignmentType.d.ts +4 -0
  82. package/lib/models/Workflow.d.ts +16 -0
  83. package/lib/models/base.d.ts +11 -0
  84. package/lib/models/object-state.d.ts +6 -0
  85. package/lib/models/operation-type.d.ts +5 -0
  86. package/lib/models/status.d.ts +4 -0
  87. package/lib/models/task-history.d.ts +17 -0
  88. package/lib/models/user.d.ts +23 -0
  89. package/lib/services/environment.service.d.ts +16 -0
  90. package/lib/services/http-web-request.service.d.ts +23 -0
  91. package/lib/services/util.service.d.ts +11 -0
  92. package/lib/shared/shared.module.d.ts +9 -0
  93. package/package.json +31 -0
  94. package/public-api.d.ts +7 -0
  95. package/styles/styles.css +1262 -0
@@ -0,0 +1,672 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
+ import { DataFilterType, } from 'verben-ng-ui';
3
+ import { baseStyle } from '../base-table-style';
4
+ import { ErrorResponse } from '../../../models/ErrorResponse';
5
+ import { SearchOperator } from '../../../models/SearchOperator';
6
+ import { SearchPropertySign } from '../../../models/SearchPropertySign';
7
+ import { SearchPropertyValueType } from '../../../models/SearchPropertyValueType';
8
+ import { debounceTime, Subject } from 'rxjs';
9
+ import { Status } from '../../../models/status';
10
+ import { ObjectState } from '../../../models/object-state';
11
+ import { mockData } from './helper';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "../../../services/util.service";
14
+ import * as i2 from "../../../services/http-web-request.service";
15
+ import * as i3 from "@angular/forms";
16
+ import * as i4 from "../../../services/environment.service";
17
+ import * as i5 from "@angular/router";
18
+ import * as i6 from "./form-fields.service";
19
+ import * as i7 from "@angular/common";
20
+ import * as i8 from "verben-ng-ui";
21
+ var TaskUserPropertyName;
22
+ (function (TaskUserPropertyName) {
23
+ TaskUserPropertyName["User"] = "User";
24
+ TaskUserPropertyName["Date"] = "Date";
25
+ TaskUserPropertyName["Role"] = "Role";
26
+ TaskUserPropertyName["Service"] = "Service";
27
+ TaskUserPropertyName["Application"] = "Application";
28
+ TaskUserPropertyName["Tenant"] = "Tenant";
29
+ TaskUserPropertyName["Email"] = "Email";
30
+ TaskUserPropertyName["Status"] = "Status";
31
+ })(TaskUserPropertyName || (TaskUserPropertyName = {}));
32
+ var TaskUserPropertyMap;
33
+ (function (TaskUserPropertyMap) {
34
+ TaskUserPropertyMap["User"] = "Name";
35
+ TaskUserPropertyMap["Date"] = "CreatedAt";
36
+ TaskUserPropertyMap["Role"] = "RoleID";
37
+ TaskUserPropertyMap["Service"] = "ServiceName";
38
+ TaskUserPropertyMap["Application"] = "Application";
39
+ TaskUserPropertyMap["Tenant"] = "TenantId";
40
+ TaskUserPropertyMap["Email"] = "MailAddress";
41
+ TaskUserPropertyMap["Status"] = "Status";
42
+ })(TaskUserPropertyMap || (TaskUserPropertyMap = {}));
43
+ var FilterTypes;
44
+ (function (FilterTypes) {
45
+ FilterTypes["Before"] = "LT";
46
+ FilterTypes["On"] = "EQ";
47
+ FilterTypes["After"] = "GT";
48
+ FilterTypes["NEQ"] = "NEQ";
49
+ })(FilterTypes || (FilterTypes = {}));
50
+ export class FormDetailsComponent {
51
+ utilService;
52
+ server;
53
+ cdr;
54
+ fb;
55
+ envSvc;
56
+ router;
57
+ taskUsersSvc;
58
+ _location;
59
+ visibleColumnDef = [];
60
+ styles = baseStyle;
61
+ data = mockData;
62
+ path = '/documentation/workflow-forms/fields';
63
+ cardData = [];
64
+ queryParams = {};
65
+ currentData = null;
66
+ cardDataView;
67
+ dataView;
68
+ tableView;
69
+ application = null;
70
+ pageSize = 10;
71
+ searchDebounceTime = 500;
72
+ onViewProcessClicked = new EventEmitter();
73
+ pageState = null;
74
+ isOpen = false;
75
+ openDropdownId = null;
76
+ currentFilters = [];
77
+ currentSorts = [];
78
+ searchTerm$ = new Subject();
79
+ statusOptions = Object.values(Status);
80
+ users = [];
81
+ visibleColumns = [];
82
+ filterArray = [
83
+ {
84
+ name: TaskUserPropertyName.Date,
85
+ type: DataFilterType.Date,
86
+ checked: false,
87
+ },
88
+ {
89
+ name: TaskUserPropertyName.User,
90
+ type: DataFilterType.String,
91
+ checked: false,
92
+ },
93
+ {
94
+ name: TaskUserPropertyName.Email,
95
+ type: DataFilterType.String,
96
+ checked: false,
97
+ },
98
+ {
99
+ name: TaskUserPropertyName.Tenant,
100
+ type: DataFilterType.String,
101
+ checked: false,
102
+ },
103
+ {
104
+ name: TaskUserPropertyName.Application,
105
+ type: DataFilterType.String,
106
+ checked: false,
107
+ },
108
+ {
109
+ name: TaskUserPropertyName.Service,
110
+ type: DataFilterType.String,
111
+ checked: false,
112
+ },
113
+ {
114
+ name: TaskUserPropertyName.Role,
115
+ type: DataFilterType.String,
116
+ checked: false,
117
+ },
118
+ {
119
+ name: TaskUserPropertyName.Status,
120
+ type: DataFilterType.String,
121
+ checked: false,
122
+ },
123
+ ];
124
+ sortOptions = [
125
+ {
126
+ name: TaskUserPropertyName.Date,
127
+ type: DataFilterType.Date,
128
+ checked: false,
129
+ },
130
+ {
131
+ name: TaskUserPropertyName.User,
132
+ type: DataFilterType.String,
133
+ checked: false,
134
+ },
135
+ {
136
+ name: TaskUserPropertyName.Email,
137
+ type: DataFilterType.String,
138
+ checked: false,
139
+ },
140
+ {
141
+ name: TaskUserPropertyName.Tenant,
142
+ type: DataFilterType.String,
143
+ checked: false,
144
+ },
145
+ {
146
+ name: TaskUserPropertyName.Application,
147
+ type: DataFilterType.String,
148
+ checked: false,
149
+ },
150
+ {
151
+ name: TaskUserPropertyName.Service,
152
+ type: DataFilterType.String,
153
+ checked: false,
154
+ },
155
+ {
156
+ name: TaskUserPropertyName.Role,
157
+ type: DataFilterType.String,
158
+ checked: false,
159
+ },
160
+ ];
161
+ currentSearchTerm = '';
162
+ constructor(utilService, server, cdr, fb, envSvc, router, taskUsersSvc, _location) {
163
+ this.utilService = utilService;
164
+ this.server = server;
165
+ this.cdr = cdr;
166
+ this.fb = fb;
167
+ this.envSvc = envSvc;
168
+ this.router = router;
169
+ this.taskUsersSvc = taskUsersSvc;
170
+ this._location = _location;
171
+ this.visibleColumnDef = taskUsersSvc.formFieldColumns;
172
+ this.visibleColumns = taskUsersSvc.formFieldColumns.map((col) => ({
173
+ checked: true,
174
+ name: typeof col.header === 'string' ? col.header : col.id,
175
+ type: DataFilterType.Bool,
176
+ }));
177
+ }
178
+ async ngOnInit() {
179
+ this.searchTerm$
180
+ .pipe(debounceTime(this.searchDebounceTime)) // Adjust debounce time here (in ms)
181
+ .subscribe(async (searchTerm) => {
182
+ this.currentSearchTerm = searchTerm;
183
+ this.updateFiltersAndSorts(true);
184
+ });
185
+ this.setUpCardData();
186
+ }
187
+ async getAllTaskUsers() {
188
+ this.utilService.sendBI(true);
189
+ const res = await this.server.get(`TaskUser/GetTaskUsers/0/${this.pageSize}`, this.envSvc.environment.WorkFlowAPI);
190
+ this.utilService.sendBI(false);
191
+ if (res instanceof ErrorResponse) {
192
+ return undefined;
193
+ }
194
+ else {
195
+ this.pageState = res;
196
+ var result = res.Result;
197
+ return result;
198
+ }
199
+ }
200
+ async getUsers() {
201
+ var payload = [
202
+ {
203
+ PropertyName: 'IsCronUser',
204
+ EntityValue: 'true',
205
+ Operator: SearchOperator.And,
206
+ Sign: SearchPropertySign.EQ,
207
+ Type: SearchPropertyValueType.Bool,
208
+ },
209
+ ];
210
+ this.utilService.sendBI(true);
211
+ const res = await this.server.post(`User/SearchUsers/0/${this.pageSize}`, payload);
212
+ this.utilService.sendBI(false);
213
+ if (res instanceof ErrorResponse) {
214
+ return undefined;
215
+ }
216
+ else {
217
+ var result = res.Result;
218
+ return result;
219
+ }
220
+ }
221
+ async loadMoreUsers(event) {
222
+ var payload = [
223
+ {
224
+ PropertyName: 'IsCronUser',
225
+ EntityValue: 'true',
226
+ Operator: SearchOperator.And,
227
+ Sign: SearchPropertySign.EQ,
228
+ Type: SearchPropertyValueType.Bool,
229
+ },
230
+ ];
231
+ this.utilService.sendBI(true);
232
+ const res = await this.server.post(`User/SearchUsers/${event.loadTimes * this.pageSize}/${this.pageSize}`, payload);
233
+ this.utilService.sendBI(false);
234
+ if (res instanceof ErrorResponse) {
235
+ return [];
236
+ }
237
+ else {
238
+ var result = res.Result;
239
+ return result;
240
+ }
241
+ }
242
+ onUserSelected(event, item) {
243
+ const user = this.users.find((x) => x.Name == event.value);
244
+ if (user) {
245
+ item.Name = user.Name;
246
+ item.Duration = user.Duration;
247
+ item.ExpiryDate = user.ExpiryDate;
248
+ item.AllowAnonymous = user.AllowAnonymous;
249
+ item.CreatedAt = user.CreatedAt;
250
+ }
251
+ }
252
+ onClear(event, item) {
253
+ item.Name = '';
254
+ item.Duration = 0;
255
+ item.ExpiryDate = new Date();
256
+ item.AllowAnonymous = false;
257
+ item.CreatedAt = new Date();
258
+ }
259
+ getItemLabel(name) {
260
+ const item = this.users.find((user) => user.Name === name);
261
+ const otherCheck = this.data.find((data) => data.Name === name);
262
+ return item
263
+ ? item.Name
264
+ : otherCheck
265
+ ? otherCheck.Name
266
+ : '';
267
+ }
268
+ showActions(e) {
269
+ e.stopPropagation();
270
+ }
271
+ getAsyncLabel(value) {
272
+ const data = this.data.find((x) => x.Name == value);
273
+ return data ? data.Name : '';
274
+ }
275
+ async loadMore() {
276
+ if (!this.pageState) {
277
+ return;
278
+ }
279
+ this.utilService.sendBI(true);
280
+ const res = this.currentFilters.length > 0 ||
281
+ this.currentSorts.length > 0 ||
282
+ this.currentSearchTerm.trim().length > 0
283
+ ? await this.loadMoreFiltersAndSorts()
284
+ : await this.server.get(`TaskUser/GetTaskUsers/${this.pageState.Skip}/${this.pageSize}`, this.envSvc.environment.WorkFlowAPI);
285
+ this.utilService.sendBI(false);
286
+ if (res instanceof ErrorResponse) {
287
+ return;
288
+ }
289
+ else {
290
+ this.pageState = res;
291
+ var result = res.Result;
292
+ this.data = this.data.concat(result.map((x) => {
293
+ return {
294
+ ...x,
295
+ id: x.Id,
296
+ };
297
+ }));
298
+ this.setUpCardDataExtra(result);
299
+ }
300
+ }
301
+ setUpCardData() {
302
+ const cardData = this.data.map((x) => {
303
+ return {
304
+ selected: false,
305
+ title: x.Name,
306
+ data: x,
307
+ body: [],
308
+ children: [],
309
+ };
310
+ });
311
+ this.cardData = cardData;
312
+ }
313
+ setUpCardDataExtra(baseData) {
314
+ const cardData = baseData.map((x) => {
315
+ return {
316
+ selected: false,
317
+ title: x.Name,
318
+ data: x,
319
+ body: [],
320
+ children: [],
321
+ };
322
+ });
323
+ this.cardData = this.cardData.concat(cardData);
324
+ }
325
+ goToCardView(data) {
326
+ const item = this.cardData.find((x) => x.data == data);
327
+ if (item) {
328
+ this.userCardClicked(item, true);
329
+ }
330
+ }
331
+ goToTableView() {
332
+ if (!this.currentData) {
333
+ return;
334
+ }
335
+ this.dataView.toggleView();
336
+ const id = this.currentData.data ? this.currentData.data.Id : '';
337
+ if (id.trim().length > 0 && !this.tableView.isRowEditing(id)) {
338
+ this.tableView.toggleRowEdit(id);
339
+ }
340
+ }
341
+ viewProcesses(code) {
342
+ if (code.trim().length == 0) {
343
+ return;
344
+ }
345
+ this.onViewProcessClicked.emit(code);
346
+ }
347
+ userCardClicked(item, toggleView = false) {
348
+ this.currentData = this.cardDataView.onItemClick(item);
349
+ if (toggleView) {
350
+ this.dataView.toggleView();
351
+ }
352
+ }
353
+ async saveUser() {
354
+ if (this.currentData) {
355
+ var user = this.currentData.data;
356
+ if (this.currentData.data.Name.trim().length == 0) {
357
+ this.utilService.showInfo('Name cannot be empty');
358
+ return;
359
+ }
360
+ user.DataState =
361
+ user.DataState == ObjectState.New
362
+ ? ObjectState.New
363
+ : ObjectState.Changed;
364
+ user.Id = user.DataState == ObjectState.New ? '' : user.Id;
365
+ this.utilService.sendBI(true);
366
+ const res = await this.server.post(`TaskUser/SaveTaskUsers`, [user], this.envSvc.environment.WorkFlowAPI);
367
+ this.utilService.sendBI(false);
368
+ if (res instanceof ErrorResponse) {
369
+ }
370
+ else {
371
+ this.utilService.showSuccess('Active user saved successfully');
372
+ const result = res;
373
+ if (result.length > 0) {
374
+ var userResult = result[0];
375
+ const itemIndex = this.data.findIndex((x) => x == this.currentData?.data);
376
+ if (itemIndex > -1) {
377
+ this.data[itemIndex].Name = userResult.Name;
378
+ this.data[itemIndex].Id = userResult.Id;
379
+ this.data[itemIndex].id = userResult.Id;
380
+ this.data[itemIndex].DataState = userResult.DataState;
381
+ this.data[itemIndex].EntityValues = userResult.EntityValues;
382
+ this.data[itemIndex].AllowAnonymous = userResult.AllowAnonymous;
383
+ this.data = this.data.map((x) => x);
384
+ }
385
+ }
386
+ }
387
+ }
388
+ }
389
+ toggleAnonymous(value, row) {
390
+ const newValue = !value;
391
+ row.AllowAnonymous = newValue;
392
+ console.log(row);
393
+ }
394
+ setAnonymous(value, currentData) {
395
+ currentData.AllowAnonymous = value;
396
+ console.log(currentData);
397
+ }
398
+ async tableSaveUser(user, callBack) {
399
+ // if (user.Name.trim().length == 0) {
400
+ // this.utilService.showInfo('Name cannot be empty');
401
+ // return;
402
+ // }
403
+ // user.DataState =
404
+ // user.DataState == ObjectState.New ? ObjectState.New : ObjectState.Changed;
405
+ // user.Id = user.DataState == ObjectState.New ? '' : user.Id;
406
+ // this.utilService.sendBI(true);
407
+ // const res = await this.server.post(
408
+ // `TaskUser/SaveTaskUsers`,
409
+ // [user],
410
+ // this.envSvc.environment.WorkFlowAPI
411
+ // );
412
+ // this.utilService.sendBI(false);
413
+ // if (res instanceof ErrorResponse) {
414
+ // } else {
415
+ // this.utilService.showSuccess('Active user saved successfully');
416
+ // const result = res as Form[];
417
+ // if (result.length > 0) {
418
+ // var userResult = result[0];
419
+ // const itemIndex = this.data.findIndex((x) => x == user);
420
+ // if (itemIndex > -1) {
421
+ // this.data[itemIndex].Name = userResult.Name;
422
+ // this.data[itemIndex].Id = userResult.Id;
423
+ // this.data[itemIndex].id = userResult.id;
424
+ // this.data[itemIndex].DataState = userResult.DataState;
425
+ // this.data[itemIndex].AllowAnonymous = userResult.MaxValue;
426
+ // this.data[itemIndex].IsRequired = userResult.IsRequired;
427
+ // this.data = this.data.map((x) => x);
428
+ // }
429
+ // callBack();
430
+ // }
431
+ // }
432
+ }
433
+ updateTable() {
434
+ this.data = this.data.map((x) => x);
435
+ console.log(this.data);
436
+ }
437
+ convertToString(value, source) {
438
+ value = parseInt(value);
439
+ }
440
+ navigateToFields() {
441
+ const queryParams = this.queryParams;
442
+ this.router.navigate([`${this.path}`], { queryParams });
443
+ }
444
+ onClose() {
445
+ this.isOpen = false;
446
+ }
447
+ openDropdown(item) {
448
+ if (this.openDropdownId === item.Id) {
449
+ this.openDropdownId = null;
450
+ }
451
+ else {
452
+ this.openDropdownId = item.Id;
453
+ }
454
+ }
455
+ goBack() {
456
+ this._location.back();
457
+ }
458
+ isDropdownOpen(item) {
459
+ return this.openDropdownId === item.Id;
460
+ }
461
+ onViewChange(isGridView) { }
462
+ onStateChange(event) {
463
+ switch (event.key) {
464
+ case 'create':
465
+ var newUser = {
466
+ TenantId: '',
467
+ Code: '',
468
+ id: '',
469
+ Id: (this.cardData.length + 1).toString(),
470
+ ServiceName: '',
471
+ CreatedAt: new Date(),
472
+ UpdatedAt: new Date(),
473
+ DataState: ObjectState.New,
474
+ EntityValues: [],
475
+ IsValid: false,
476
+ AllowAnonymous: false,
477
+ URL: '',
478
+ Duration: 0,
479
+ ExpiryDate: new Date(),
480
+ Name: '',
481
+ };
482
+ const cardData = {
483
+ selected: false,
484
+ title: newUser.Name,
485
+ data: newUser,
486
+ body: [],
487
+ children: [],
488
+ };
489
+ this.data = this.data.concat([newUser]);
490
+ this.cardData.push(cardData);
491
+ this.userCardClicked(cardData);
492
+ this.dataView.isTableView = false;
493
+ break;
494
+ default:
495
+ break;
496
+ }
497
+ }
498
+ showTableView = false;
499
+ onSelectionChange(selectedRows) { }
500
+ retryMessage() { }
501
+ onColumnsUpdated(updatedColumns) {
502
+ const updatedColumnDef = [];
503
+ updatedColumns.forEach((col) => {
504
+ const matchingCol = this.taskUsersSvc.formFieldColumns.find((column) => column.header === col.name || column.id === col.name);
505
+ if (matchingCol) {
506
+ updatedColumnDef.push(matchingCol);
507
+ }
508
+ });
509
+ this.visibleColumnDef = [...updatedColumnDef];
510
+ }
511
+ async updateFiltersAndSorts(isSearch = false) {
512
+ if (!isSearch) {
513
+ this.dataView.onClearSearch();
514
+ this.currentSearchTerm = '';
515
+ this.cdr.detectChanges();
516
+ const clickEvent = new MouseEvent('click', {
517
+ bubbles: true,
518
+ cancelable: true,
519
+ view: window,
520
+ });
521
+ document.dispatchEvent(clickEvent);
522
+ }
523
+ var payload = this.currentFilters.map((x) => {
524
+ return {
525
+ PropertyName: TaskUserPropertyMap[x.name],
526
+ EntityValue: x.value,
527
+ Operator: SearchOperator.And,
528
+ Sign: x.condition && Object.keys(FilterTypes).includes(x.condition)
529
+ ? FilterTypes[x.condition]
530
+ : SearchPropertySign.EQ,
531
+ Type: x.name == TaskUserPropertyName.Date
532
+ ? SearchPropertyValueType.Date
533
+ : SearchPropertyValueType.String,
534
+ };
535
+ });
536
+ // payload.push({
537
+ // PropertyName: 'APIKey',
538
+ // EntityValue: this.envSvc.environment.APIKey,
539
+ // Operator: SearchOperator.And,
540
+ // Sign: SearchPropertySign.EQ,
541
+ // });
542
+ const sortParam = this.currentSorts.length > 0
543
+ ? {
544
+ Param: TaskUserPropertyMap[this.currentSorts[0].name],
545
+ Order: this.currentSorts[0].value,
546
+ }
547
+ : null;
548
+ const searchTermExists = this.currentSearchTerm.trim().length > 0;
549
+ this.utilService.sendBI(true);
550
+ const res = searchTermExists
551
+ ? await this.server.get(`TaskUser/GetTaskUserWithParam/${this.currentSearchTerm.trim()}/0/${this.pageSize}`, this.envSvc.environment.WorkFlowAPI)
552
+ : await this.server.post(sortParam
553
+ ? `TaskUser/SearchTaskUsers/0/${this.pageSize}/${sortParam.Param}/${sortParam.Order}`
554
+ : `TaskUser/SearchTaskUsers/0/${this.pageSize}`, payload, this.envSvc.environment.WorkFlowAPI);
555
+ this.utilService.sendBI(false);
556
+ if (res instanceof ErrorResponse) {
557
+ this.currentFilters = [];
558
+ this.currentSorts = [];
559
+ return undefined;
560
+ }
561
+ else {
562
+ this.pageState = res;
563
+ var result = res.Result;
564
+ this.data = result.map((x) => {
565
+ return {
566
+ ...x,
567
+ id: x.Id,
568
+ };
569
+ });
570
+ this.setUpCardData();
571
+ }
572
+ }
573
+ async loadMoreFiltersAndSorts() {
574
+ if (!this.pageState) {
575
+ return;
576
+ }
577
+ var payload = this.currentFilters.map((x) => {
578
+ return {
579
+ PropertyName: TaskUserPropertyMap[x.name],
580
+ EntityValue: x.value,
581
+ Operator: SearchOperator.And,
582
+ Sign: x.condition && Object.keys(FilterTypes).includes(x.condition)
583
+ ? FilterTypes[x.condition]
584
+ : SearchPropertySign.EQ,
585
+ Type: x.name == TaskUserPropertyName.Date
586
+ ? SearchPropertyValueType.Date
587
+ : SearchPropertyValueType.String,
588
+ };
589
+ });
590
+ const sortParam = this.currentSorts.length > 0
591
+ ? {
592
+ Param: TaskUserPropertyMap[this.currentSorts[0].name],
593
+ Order: this.currentSorts[0].value,
594
+ }
595
+ : null;
596
+ const searchTermExists = this.currentSearchTerm.trim().length > 0;
597
+ this.utilService.sendBI(true);
598
+ const res = searchTermExists
599
+ ? await this.server.get(`TaskUser/GetTaskUserWithParam/${this.currentSearchTerm.trim()}/${this.pageState.Skip}/${this.pageSize}`, this.envSvc.environment.WorkFlowAPI)
600
+ : await this.server.post(sortParam
601
+ ? `TaskUser/SearchTaskUsers/${this.pageState.Skip}/${this.pageSize}/${sortParam.Param}/${sortParam.Order}`
602
+ : `TaskUser/SearchTaskUsers/${this.pageState.Skip}/${this.pageSize}`, payload, this.envSvc.environment.WorkFlowAPI);
603
+ this.utilService.sendBI(false);
604
+ if (res instanceof ErrorResponse) {
605
+ return undefined;
606
+ }
607
+ else {
608
+ var result = res;
609
+ return result;
610
+ }
611
+ }
612
+ onFilterUpdated(updatedFilters) {
613
+ // Ensure updatedFilters is an array
614
+ if (Array.isArray(updatedFilters)) {
615
+ this.currentFilters = updatedFilters;
616
+ this.updateFiltersAndSorts();
617
+ }
618
+ }
619
+ onSortUpdated(updatedSorts) {
620
+ this.currentSorts = updatedSorts;
621
+ this.updateFiltersAndSorts();
622
+ }
623
+ handleSearch(event) {
624
+ this.searchTerm$.next(event.value);
625
+ }
626
+ handleExport(exportedData) {
627
+ // console.log('Exported data:', exportedData);
628
+ this.downloadCSV(exportedData);
629
+ }
630
+ downloadCSV(data) {
631
+ const headers = Object.keys(data[0]);
632
+ const csvContent = [
633
+ headers.join(','),
634
+ ...data.map((row) => headers.map((header) => row[header]).join(',')),
635
+ ].join('\n');
636
+ const blob = new Blob([csvContent], { type: 'text/csv;charset=utf-8;' });
637
+ const link = document.createElement('a');
638
+ if (link.download !== undefined) {
639
+ const url = URL.createObjectURL(blob);
640
+ link.setAttribute('href', url);
641
+ link.setAttribute('download', 'export.csv');
642
+ link.style.visibility = 'hidden';
643
+ document.body.appendChild(link);
644
+ link.click();
645
+ document.body.removeChild(link);
646
+ }
647
+ }
648
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormDetailsComponent, deps: [{ token: i1.UtilService }, { token: i2.HttpWebRequestService }, { token: i0.ChangeDetectorRef }, { token: i3.FormBuilder }, { token: i4.EnvironmentService }, { token: i5.Router }, { token: i6.FormsFieldService }, { token: i7.Location }], target: i0.ɵɵFactoryTarget.Component });
649
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormDetailsComponent, selector: "lib-form-details", inputs: { application: "application", pageSize: "pageSize", searchDebounceTime: "searchDebounceTime" }, outputs: { onViewProcessClicked: "onViewProcessClicked" }, viewQueries: [{ propertyName: "cardDataView", first: true, predicate: ["vdcv"], descendants: true }, { propertyName: "dataView", first: true, predicate: ["vdv"], descendants: true }, { propertyName: "tableView", first: true, predicate: ["dt"], descendants: true }], ngImport: i0, template: "<div #messageLog class=\"flex flex-col gap-4 message-log-container\">\n <verben-data-view\n #vdv\n [viewState]=\"{\n isSearch: true,\n isColumn: true,\n isFilter: true,\n isSort: true,\n isExport: true,\n isSelect: true,\n isCreate: true,\n isToggle:true,\n }\"\n [buttonClass]=\"'my-custom-button-class'\"\n [iconClass]=\"'my-icon-class'\"\n [activeIconClass]=\"'my-active-icon-class'\"\n [selectedColumnCount]=\"0\"\n [selectedSortCount]=\"0\"\n [selectedFilterTableCount]=\"0\"\n (viewChange)=\"onViewChange($event)\"\n (stateChange)=\"onStateChange($event)\"\n (onSearchChange)=\"handleSearch($event)\"\n >\n <div class=\"mt-2\" table-content>\n <lib-data-table\n #dt\n [data]=\"data\"\n [columns]=\"visibleColumnDef\"\n [styleConfig]=\"styles\"\n (selectionChange)=\"onSelectionChange($event)\"\n >\n <ng-container libColumn=\"select\">\n <ng-template\n #cell\n let-isSelected=\"isSelected\"\n let-toggleRowSelection=\"toggleRowSelection\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isSelected\"\n (change)=\"toggleRowSelection()\"\n />\n </ng-template>\n <ng-template\n #header\n let-allRowsSelected=\"allRowsSelected\"\n let-someRowsSelected=\"someRowsSelected\"\n let-toggleAllRows=\"toggleAllRows\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"allRowsSelected()\"\n [indeterminate]=\"someRowsSelected()\"\n (change)=\"toggleAllRows()\"\n />\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"createdAt\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value | date }}\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"name\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value.Name }}\n </ng-template>\n <ng-template\n #cellEdit\n let-row=\"row\"\n let-updateValue=\"updateValue\"\n let-value\n >\n <verbena-input\n inputContainerClass=\"w-fit\"\n [value]=\"value.Name\"\n ></verbena-input>\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"entities\">\n <ng-template #cell let-row=\"row\" let-value>\n <span class=\"flex gap-2\" *ngFor=\"let field of row.Entities\">\n <span\n class=\"inline-block bg-[#3479e98a] rounded-lg px-2 py-1 text-sm\"\n *ngFor=\"let property of field.Properties\"\n >\n {{ property.Name }}\n </span>\n </span>\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"expiry\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value | date }}\n </ng-template>\n </ng-container>\n\n <ng-container libColumn=\"responses\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value }}\n </ng-template>\n <ng-template\n #cellEdit\n let-row=\"row\"\n let-updateValue=\"updateValue\"\n let-value\n >\n <verbena-input\n [type]=\"'number'\"\n inputContainerClass=\"w-[60px]\"\n [value]=\"value\"\n ></verbena-input>\n </ng-template>\n </ng-container>\n\n <ng-container libColumn=\"anonymous\">\n <ng-template #cell let-row=\"row\" let-value>\n <verben-svg *ngIf=\"value === true\" [icon]=\"'check'\"></verben-svg>\n <verben-svg *ngIf=\"value === false\" [icon]=\"'error'\"></verben-svg>\n </ng-template>\n <ng-template\n #cellEdit\n let-row=\"row\"\n let-updateValue=\"updateValue\"\n let-value\n >\n <div\n (click)=\"toggleAnonymous(value, row)\"\n class=\"w-[53px] p-1 text-[#fff] h-[22px] relative bg-[#1A237E] rounded-2xl cursor-pointer\"\n >\n <!-- Toggle circle -->\n <span\n [ngClass]=\"{\n 'translate-x-[100%]': value === true,\n 'translate-x-0': value !== true\n }\"\n class=\"w-[50%] h-full block absolute left-0 top-0 bg-[#fff] rounded-full scale-[70%] transition-transform\"\n >\n </span>\n <!-- ON/OFF text -->\n <span *ngIf=\"value === true\" class=\"block text-xs ml-1\">ON</span>\n <span\n *ngIf=\"value === false\"\n class=\"block text-xs mr-1\"\n [ngClass]=\"{\n 'text-right': value === false,\n 'text-left': value === true\n }\"\n >OFF</span\n >\n </div>\n </ng-template>\n </ng-container>\n\n <ng-container libColumn=\"actions\">\n <ng-template\n #cell\n let-isEditing=\"isEditing\"\n let-toggleRowEdit=\"toggleRowEdit\"\n let-row=\"row\"\n let-value\n >\n <verben-pop-Up\n [customStyles]=\"{ 'z-index': '99' }\"\n [dropdownOpen]=\"isDropdownOpen(row)\"\n [enableMouseLeave]=\"false\"\n (close)=\"onClose()\"\n >\n <verben-svg\n class=\"cursor-pointer actions-icon\"\n (click)=\"openDropdown(row)\"\n dropdown-trigger\n icon=\"list\"\n ></verben-svg>\n <div class=\"pop-up-content flex flex-col\" dropdown-content>\n <div\n (click)=\"navigateToFields()\"\n class=\"pop-up-value cursor-pointer\"\n >\n View Fields\n </div>\n <div\n (click)=\"toggleRowEdit()\"\n class=\"pop-up-value cursor-pointer\"\n >\n Edit\n </div>\n <div class=\"pop-up-value cursor-pointer\">Delete</div>\n </div>\n </verben-pop-Up>\n </ng-template>\n <ng-template\n #cellEdit\n let-isEditing=\"isEditing\"\n let-toggleRowEdit=\"toggleRowEdit\"\n let-row=\"row\"\n let-value\n >\n <div class=\"flex gap-2 items-center\">\n <verben-svg\n icon=\"check\"\n [width]=\"15\"\n [height]=\"15\"\n (click)=\"tableSaveUser(value, toggleRowEdit)\"\n ></verben-svg>\n <verben-svg icon=\"delete\" [width]=\"15\" [height]=\"15\"></verben-svg>\n <verben-svg\n icon=\"cardViewAlt\"\n [width]=\"15\"\n [height]=\"15\"\n (click)=\"goToCardView(value)\"\n ></verben-svg>\n </div>\n </ng-template>\n </ng-container>\n </lib-data-table>\n </div>\n <div card-content>\n <verben-card-data-view\n borderRadius=\"12px\"\n #vdcv\n dataId=\"Id\"\n border=\"5px\"\n [cardDataList]=\"cardData\"\n rbgColor=\"#f5f6f9\"\n mg=\"0px\"\n >\n <verben-left-card-data-view class=\"space-y-7\">\n <verben-left-card-data\n #vlcd\n [parent]=\"vdcv\"\n dataId=\"MailAddress\"\n class=\"bg-secondary-100 rounded-xl border-primary border-[1px]\"\n [cardDataList]=\"cardData\"\n >\n <ng-template #card let-item>\n <div\n (click)=\"userCardClicked(item)\"\n class=\"flex cursor-pointer h-[max-content]\"\n >\n <!-- <verben-svg [width]=\"15\" [height]=\"15\" (click)=\"toggleChildren(item); $event.stopPropagation()\"\n [ngClass]=\"item.children && item.children.length?'visible':'invisible'\"\n class=\"items-center flex pr-1 cursor-pointer\" [icon]=\"item.isChildrenExpanded?'minus':'plus'\" /> -->\n <div class=\"flex w-full bg-secondary rounded-xl\">\n <div\n class=\"w-3 rounded-xl rounded-tr-none rounded-br-none\"\n [ngClass]=\"\n item.selected ? 'bg-primary' : 'bg-secondary-200'\n \"\n ></div>\n <div class=\"py-3 px-4 flex-1 h-[100%]\">\n <div\n class=\"flex items-start flex-1 gap-1 justify-between h-[100%]\"\n >\n <div\n class=\"flex flex-col flex-1 card-min-height justify-between h-[100%]\"\n >\n <div class=\"flex justify-between mr-4\">\n <div>\n <h3\n class=\"my-0 font-bold text-[#404040] leading-[19.5px]\"\n >\n {{ item.data.Name }}\n </h3>\n <span class=\"flex items-center gap-1 mt-2\">\n <span class=\"!text-[10px] text-[#404040]\"\n >Expiry:</span\n >\n <span class=\"!text-[13px] font-bold\">{{\n item.data.ExpiryDate | date\n }}</span>\n </span>\n </div>\n\n <div>\n <span class=\"!text-[10px] text-[#404040]\"\n >Responses:</span\n >\n <p class=\"!text-[12px]\">{{ item.data.Duration }}</p>\n </div>\n </div>\n <p\n (click)=\"showActions($event)\"\n class=\"underline cursor-pointer text-[#3479E9] text-sm text-right mr-10\"\n >\n Actions\n </p>\n \n </div>\n\n <!-- <div class=\"flex items-end h-[100%]\">\n <span class=\"enum-val {{item.data.Status}}\">{{item.data.Status}}</span>\n </div> -->\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </verben-left-card-data>\n </verben-left-card-data-view>\n <verben-right-card-data-view>\n <ng-template #parent>\n <div\n *ngIf=\"this.currentData\"\n class=\"flex flex-col rounded-xl h-full w-full relative space-y-6\"\n >\n <verbena-input\n name=\"Name\"\n label=\"Name\"\n (ngModelChange)=\"updateTable()\"\n [(ngModel)]=\"currentData.data.Name\"\n />\n\n <verbena-input\n name=\"expiryDate\"\n [type]=\"'date'\"\n [value]=\"currentData.data.ExpiryDate\"\n label=\"Expiry Date\"\n (ngModelChange)=\"updateTable()\"\n [(ngModel)]=\"currentData.data.ExpiryDate\"\n />\n <div>\n <p class=\"mb-2\">Anonymous</p>\n <div class=\"flex items-center gap-3\">\n <div class=\"flex items-center gap-2\">\n <input\n name=\"anonymous\"\n id=\"yes\"\n type=\"radio\"\n (change)=\"setAnonymous(true, currentData.data)\"\n />\n <label for=\"yes\">Yes</label>\n </div>\n <div class=\"flex items-center gap-2\">\n <input\n name=\"anonymous\"\n id=\"no\"\n type=\"radio\"\n (change)=\"setAnonymous(false, currentData.data)\"\n />\n <label for=\"no\">No</label>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-col gap-1\">\n <div>Field Groups</div>\n <verben-drop-down\n width=\"100%\"\n placeholder=\"Change Data Type\"\n >\n </verben-drop-down>\n </div>\n\n <!-- buttons -->\n <div class=\"flex justify-between w-full bottom-8 left-0 right-0\">\n <verbena-button\n class=\"verben-delete-button\"\n text=\"Delete\"\n ></verbena-button>\n <div class=\"flex gap-3\">\n <verbena-button\n class=\"verben-switch-button\"\n (click)=\"\n viewProcesses(\n this.currentData\n ? this.currentData.data\n ? this.currentData.data.Code\n : ''\n : ''\n )\n \"\n text=\"View Fields\"\n ></verbena-button>\n <verbena-button\n class=\"verben-switch-button\"\n (click)=\"goToTableView()\"\n text=\"Switch To Table\"\n ></verbena-button>\n <verbena-button\n class=\"verben-primary-button\"\n (click)=\"this.saveUser()\"\n text=\"Save\"\n ></verbena-button>\n </div>\n </div>\n </div>\n </ng-template>\n </verben-right-card-data-view>\n <!-- <verben-right-card-data-view>\n yeshhhhhh\n </verben-right-card-data-view> -->\n\n <verben-card-data-view-footer>\n <div class=\"flex gap-2 justify-between\">\n <div\n *ngIf=\"!vdcv.hasCurrentItem()\"\n class=\"message-log-button-container flex justify-between\"\n >\n <verbena-button\n [fontWeight]=\"'bold'\"\n [bgColor]=\"'#8E8D87'\"\n [borderRadius]=\"'4px'\"\n [textColor]=\"'#fff'\"\n [text]=\"'Delete'\"\n >\n </verbena-button>\n </div>\n <div\n class=\"flex {{\n vdcv.hasCurrentItem() ? 'flex-1' : ''\n }} justify-end items-center gap-5\"\n >\n <span class=\"paginator-text\"\n >{{ cardData.length }} records loaded</span\n >\n <button (click)=\"loadMore()\" class=\"load-more view-links\">\n Load more\n </button>\n </div>\n </div>\n </verben-card-data-view-footer>\n </verben-card-data-view>\n </div>\n <div column-content>\n <verben-visible-column\n (columnsUpdated)=\"onColumnsUpdated($event)\"\n [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n borderRadius=\"10px\"\n boxShadow=\"2px 2px 2px 0px silver\"\n bgColor=\"white\"\n width=\"400px\"\n textColor=\"black\"\n pd=\"1rem\"\n primaryColor=\"#FFE681\"\n secondaryColor=\"#3479E9\"\n [columns]=\"visibleColumns\"\n [displayedColumns]=\"5\"\n ></verben-visible-column>\n </div>\n <div filter-content>\n <verben-table-filter\n (filtersApplied)=\"onFilterUpdated($event)\"\n [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n borderRadius=\"10px\"\n boxShadow=\"2px 2px 2px 0px silver\"\n bgColor=\"white\"\n width=\"420px\"\n textColor=\"black\"\n pd=\"1rem\"\n primaryColor=\"#FFE681\"\n secondaryColor=\"#3479E9\"\n tertiaryColor=\"#404040\"\n [filterOptions]=\"filterArray\"\n [maxFilterLength]=\"3\"\n ></verben-table-filter>\n </div>\n <div sort-content>\n <verben-sort-table\n (selectedOptions)=\"onSortUpdated($event)\"\n [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n borderRadius=\"10px\"\n boxShadow=\"2px 2px 2px 0px silver\"\n bgColor=\"white\"\n width=\"400px\"\n textColor=\"black\"\n pd=\"1rem\"\n primaryColor=\"#FFE681\"\n secondaryColor=\"#3479E9\"\n tertiaryColor=\"#404040\"\n [enableDragAndDrop]=\"true\"\n [sortOptions]=\"sortOptions\"\n ></verben-sort-table>\n </div>\n <div export-content>\n <lib-data-export [data]=\"data\" (exportDataEvent)=\"handleExport($event)\">\n </lib-data-export>\n </div>\n </verben-data-view>\n <div *ngIf=\"vdv.isTableView\" class=\"flex gap-2 justify-between\">\n <div class=\"message-log-button-container flex justify-between\">\n <verbena-button\n [fontWeight]=\"'bold'\"\n [bgColor]=\"'#8E8D87'\"\n [borderRadius]=\"'4px'\"\n [textColor]=\"'#fff'\"\n [text]=\"'Delete'\"\n >\n </verbena-button>\n </div>\n <div class=\"flex justify-end items-center gap-5\">\n <span class=\"paginator-text\">{{ cardData.length }} records loaded</span>\n <button (click)=\"loadMore()\" class=\"load-more view-links\">\n Load more\n </button>\n </div>\n </div>\n</div>\n", styles: [".view-links{font-size:14px!important;color:#00f;font-weight:600;cursor:pointer}.view-links:hover{text-decoration:underline;text-underline-offset:3px}.context-banner{background-color:#d4a00773}.card-min-height{gap:10px}::ng-deep .childrenPadding{max-height:300px;overflow-y:auto}::ng-deep .toolbar{margin-bottom:15px}::ng-deep .master-only-container{margin:0!important;padding:0!important}::ng-deep .master-detail-container{margin:0!important;padding:0!important}.pop-up-content{border-radius:4px;background-color:#fff;border:1px solid rgba(212,161,7,.5)}.pop-up-value{padding:10px 20px}.pop-up-content>div:nth-child(1){border-bottom:4px solid #FFE681}.enum-val{padding:2px 10px;width:100%;min-width:max-content;text-align:center}.enum-val.Active{background-color:#d6f3e6;color:#2db76f}.enum-val.InActive{background-color:#ffdfdf;color:#eb5757}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.DataTableComponent, selector: "lib-data-table", inputs: ["data", "columns", "groupBy", "styleConfig"], outputs: ["rowEdit", "rowSave", "rowDelete", "selectionChange"] }, { kind: "directive", type: i8.ColumnDirective, selector: "[libColumn]", inputs: ["libColumn"] }, { kind: "component", type: i8.SvgComponent, selector: "verben-svg", inputs: ["icon", "width", "height", "fill", "stroke", "size"] }, { kind: "component", type: i8.VerbenPopUpComponent, selector: "verben-pop-Up", inputs: ["dropdownOpen", "dropdownWidth", "color", "customStyles", "popUpClass", "border", "borderRadius", "enableMouseLeave"], outputs: ["dropdownOpenChange", "close"] }, { kind: "component", type: i8.DataViewComponent, selector: "verben-data-view", inputs: ["buttonClass", "iconClass", "activeIconClass", "columnCustomClass", "filterCustomClass", "sortCustomClass", "exportCustomClass", "selectCustomClass", "zIndex", "createCustomClass", "tableIcon", "cardIcon", "cardClass", "tableClass", "searchKey", "searchValue", "viewState", "searchTemplate", "columnTemplate", "filterTemplate", "sortTemplate", "children", "exportTemplate", "createTemplate", "selectedColumnCount", "selectedSortCount", "selectedFilterTableCount", "inputWidth", "milliseconds", "showColumnChild", "showSortChild", "showFilterChild", "showExportChild", "create", "showSelected", "isTableView"], outputs: ["viewChange", "stateChange", "onSearchChange"] }, { kind: "component", type: i8.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "svgPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "styleType", "svg", "svgWidth", "svgHeight", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }, { kind: "component", type: i8.CardDataViewComponent, selector: "verben-card-data-view", inputs: ["pd", "mg", "lHeight", "rHeight", "rWidth", "lWidth", "textColor", "lbgColor", "rbgColor", "border", "display", "borderRadius", "activeCss", "inActiveCss", "displayAsRow", "cardDataList", "dataId", "totalRecords", "footer", "noOfVisibleChildren", "onItemClick", "onCardChildClick"], outputs: ["loadMoreClick"] }, { kind: "component", type: i8.LeftCardDataComponent, selector: "verben-left-card-data", inputs: ["pd", "mg", "height", "weight", "activeCss", "inActiveCss", "cardDataList", "iconCollapse", "iconExpanded", "parent", "dataId"] }, { kind: "component", type: i8.LeftCardDataViewComponent, selector: "verben-left-card-data-view", inputs: ["cardDataList"] }, { kind: "component", type: i8.RightCardDataViewComponent, selector: "verben-right-card-data-view", inputs: ["parentData", "chilData", "meth"] }, { kind: "component", type: i8.CardDataViewFooterComponent, selector: "verben-card-data-view-footer" }, { kind: "component", type: i8.DropDownComponent, selector: "verben-drop-down", inputs: ["options", "width", "showHorizontalLine", "horizontalLineColor", "optionLabel", "optionSubLabel", "optionValue", "placeholder", "invalidMessage", "errorPosition", "loadMoreCaption", "display", "showClear", "lazyLoad", "styleClass", "group", "multiselect", "filter", "avoidDuplication", "filterBy", "debounceTime", "minChar", "disabled", "required", "load", "asyncLabel", "search"], outputs: ["optionsChange", "onChange", "onClick", "onClear"] }, { kind: "component", type: i8.TableFilterComponent, selector: "verben-table-filter", inputs: ["filterOptions", "pd", "mg", "height", "width", "bgColor", "boxShadow", "textColor", "primaryColor", "secondaryColor", "tertiaryColor", "border", "borderRadius", "selectWidth", "maxFilterLength", "tooltip"], outputs: ["filtersApplied"] }, { kind: "component", type: i8.VisibleColumnComponent, selector: "verben-visible-column", inputs: ["columns", "items", "enableDragAndDrop", "displayedColumns", "showMore", "pd", "mg", "height", "width", "bgColor", "boxShadow", "textColor", "primaryColor", "secondaryColor", "tertiaryColor", "border", "borderRadius", "selectWidth", "closeColumn"], outputs: ["columnsUpdated"] }, { kind: "component", type: i8.SortTableComponent, selector: "verben-sort-table", inputs: ["enableDragAndDrop", "sortOptions", "resetText", "displayedOptions", "propertyText", "showMoreText", "sortButtonText", "pd", "mg", "height", "width", "bgColor", "boxShadow", "textColor", "primaryColor", "secondaryColor", "tertiaryColor", "border", "borderRadius", "selectWidth", "containerHeight"], outputs: ["selectedOptions"] }, { kind: "component", type: i8.DataExportComponent, selector: "lib-data-export", inputs: ["data"], outputs: ["exportDataEvent"] }, { kind: "component", type: i8.VerbenaInputComponent, selector: "verbena-input", inputs: ["label", "placeHolder", "required", "svgPosition", "minLength", "maxLength", "type", "bgColor", "border", "borderRadius", "textColor", "value", "labelPosition", "labelColor", "disable", "readOnly", "min", "max", "showBorder", "showErrorMessage", "errorMessageColor", "errorBorderColor", "errorPosition", "svg", "svgWidth", "svgHeight", "svgColor", "capitalization", "inputContainerClass", "inputFieldClass", "passLength", "inputWrapperClass", "passwordToggle", "customErrorMessages", "icon", "textPass"], outputs: ["valueChange"] }, { kind: "pipe", type: i7.DatePipe, name: "date" }] });
650
+ }
651
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormDetailsComponent, decorators: [{
652
+ type: Component,
653
+ args: [{ selector: 'lib-form-details', template: "<div #messageLog class=\"flex flex-col gap-4 message-log-container\">\n <verben-data-view\n #vdv\n [viewState]=\"{\n isSearch: true,\n isColumn: true,\n isFilter: true,\n isSort: true,\n isExport: true,\n isSelect: true,\n isCreate: true,\n isToggle:true,\n }\"\n [buttonClass]=\"'my-custom-button-class'\"\n [iconClass]=\"'my-icon-class'\"\n [activeIconClass]=\"'my-active-icon-class'\"\n [selectedColumnCount]=\"0\"\n [selectedSortCount]=\"0\"\n [selectedFilterTableCount]=\"0\"\n (viewChange)=\"onViewChange($event)\"\n (stateChange)=\"onStateChange($event)\"\n (onSearchChange)=\"handleSearch($event)\"\n >\n <div class=\"mt-2\" table-content>\n <lib-data-table\n #dt\n [data]=\"data\"\n [columns]=\"visibleColumnDef\"\n [styleConfig]=\"styles\"\n (selectionChange)=\"onSelectionChange($event)\"\n >\n <ng-container libColumn=\"select\">\n <ng-template\n #cell\n let-isSelected=\"isSelected\"\n let-toggleRowSelection=\"toggleRowSelection\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isSelected\"\n (change)=\"toggleRowSelection()\"\n />\n </ng-template>\n <ng-template\n #header\n let-allRowsSelected=\"allRowsSelected\"\n let-someRowsSelected=\"someRowsSelected\"\n let-toggleAllRows=\"toggleAllRows\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"allRowsSelected()\"\n [indeterminate]=\"someRowsSelected()\"\n (change)=\"toggleAllRows()\"\n />\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"createdAt\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value | date }}\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"name\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value.Name }}\n </ng-template>\n <ng-template\n #cellEdit\n let-row=\"row\"\n let-updateValue=\"updateValue\"\n let-value\n >\n <verbena-input\n inputContainerClass=\"w-fit\"\n [value]=\"value.Name\"\n ></verbena-input>\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"entities\">\n <ng-template #cell let-row=\"row\" let-value>\n <span class=\"flex gap-2\" *ngFor=\"let field of row.Entities\">\n <span\n class=\"inline-block bg-[#3479e98a] rounded-lg px-2 py-1 text-sm\"\n *ngFor=\"let property of field.Properties\"\n >\n {{ property.Name }}\n </span>\n </span>\n </ng-template>\n </ng-container>\n <ng-container libColumn=\"expiry\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value | date }}\n </ng-template>\n </ng-container>\n\n <ng-container libColumn=\"responses\">\n <ng-template #cell let-row=\"row\" let-value>\n {{ value }}\n </ng-template>\n <ng-template\n #cellEdit\n let-row=\"row\"\n let-updateValue=\"updateValue\"\n let-value\n >\n <verbena-input\n [type]=\"'number'\"\n inputContainerClass=\"w-[60px]\"\n [value]=\"value\"\n ></verbena-input>\n </ng-template>\n </ng-container>\n\n <ng-container libColumn=\"anonymous\">\n <ng-template #cell let-row=\"row\" let-value>\n <verben-svg *ngIf=\"value === true\" [icon]=\"'check'\"></verben-svg>\n <verben-svg *ngIf=\"value === false\" [icon]=\"'error'\"></verben-svg>\n </ng-template>\n <ng-template\n #cellEdit\n let-row=\"row\"\n let-updateValue=\"updateValue\"\n let-value\n >\n <div\n (click)=\"toggleAnonymous(value, row)\"\n class=\"w-[53px] p-1 text-[#fff] h-[22px] relative bg-[#1A237E] rounded-2xl cursor-pointer\"\n >\n <!-- Toggle circle -->\n <span\n [ngClass]=\"{\n 'translate-x-[100%]': value === true,\n 'translate-x-0': value !== true\n }\"\n class=\"w-[50%] h-full block absolute left-0 top-0 bg-[#fff] rounded-full scale-[70%] transition-transform\"\n >\n </span>\n <!-- ON/OFF text -->\n <span *ngIf=\"value === true\" class=\"block text-xs ml-1\">ON</span>\n <span\n *ngIf=\"value === false\"\n class=\"block text-xs mr-1\"\n [ngClass]=\"{\n 'text-right': value === false,\n 'text-left': value === true\n }\"\n >OFF</span\n >\n </div>\n </ng-template>\n </ng-container>\n\n <ng-container libColumn=\"actions\">\n <ng-template\n #cell\n let-isEditing=\"isEditing\"\n let-toggleRowEdit=\"toggleRowEdit\"\n let-row=\"row\"\n let-value\n >\n <verben-pop-Up\n [customStyles]=\"{ 'z-index': '99' }\"\n [dropdownOpen]=\"isDropdownOpen(row)\"\n [enableMouseLeave]=\"false\"\n (close)=\"onClose()\"\n >\n <verben-svg\n class=\"cursor-pointer actions-icon\"\n (click)=\"openDropdown(row)\"\n dropdown-trigger\n icon=\"list\"\n ></verben-svg>\n <div class=\"pop-up-content flex flex-col\" dropdown-content>\n <div\n (click)=\"navigateToFields()\"\n class=\"pop-up-value cursor-pointer\"\n >\n View Fields\n </div>\n <div\n (click)=\"toggleRowEdit()\"\n class=\"pop-up-value cursor-pointer\"\n >\n Edit\n </div>\n <div class=\"pop-up-value cursor-pointer\">Delete</div>\n </div>\n </verben-pop-Up>\n </ng-template>\n <ng-template\n #cellEdit\n let-isEditing=\"isEditing\"\n let-toggleRowEdit=\"toggleRowEdit\"\n let-row=\"row\"\n let-value\n >\n <div class=\"flex gap-2 items-center\">\n <verben-svg\n icon=\"check\"\n [width]=\"15\"\n [height]=\"15\"\n (click)=\"tableSaveUser(value, toggleRowEdit)\"\n ></verben-svg>\n <verben-svg icon=\"delete\" [width]=\"15\" [height]=\"15\"></verben-svg>\n <verben-svg\n icon=\"cardViewAlt\"\n [width]=\"15\"\n [height]=\"15\"\n (click)=\"goToCardView(value)\"\n ></verben-svg>\n </div>\n </ng-template>\n </ng-container>\n </lib-data-table>\n </div>\n <div card-content>\n <verben-card-data-view\n borderRadius=\"12px\"\n #vdcv\n dataId=\"Id\"\n border=\"5px\"\n [cardDataList]=\"cardData\"\n rbgColor=\"#f5f6f9\"\n mg=\"0px\"\n >\n <verben-left-card-data-view class=\"space-y-7\">\n <verben-left-card-data\n #vlcd\n [parent]=\"vdcv\"\n dataId=\"MailAddress\"\n class=\"bg-secondary-100 rounded-xl border-primary border-[1px]\"\n [cardDataList]=\"cardData\"\n >\n <ng-template #card let-item>\n <div\n (click)=\"userCardClicked(item)\"\n class=\"flex cursor-pointer h-[max-content]\"\n >\n <!-- <verben-svg [width]=\"15\" [height]=\"15\" (click)=\"toggleChildren(item); $event.stopPropagation()\"\n [ngClass]=\"item.children && item.children.length?'visible':'invisible'\"\n class=\"items-center flex pr-1 cursor-pointer\" [icon]=\"item.isChildrenExpanded?'minus':'plus'\" /> -->\n <div class=\"flex w-full bg-secondary rounded-xl\">\n <div\n class=\"w-3 rounded-xl rounded-tr-none rounded-br-none\"\n [ngClass]=\"\n item.selected ? 'bg-primary' : 'bg-secondary-200'\n \"\n ></div>\n <div class=\"py-3 px-4 flex-1 h-[100%]\">\n <div\n class=\"flex items-start flex-1 gap-1 justify-between h-[100%]\"\n >\n <div\n class=\"flex flex-col flex-1 card-min-height justify-between h-[100%]\"\n >\n <div class=\"flex justify-between mr-4\">\n <div>\n <h3\n class=\"my-0 font-bold text-[#404040] leading-[19.5px]\"\n >\n {{ item.data.Name }}\n </h3>\n <span class=\"flex items-center gap-1 mt-2\">\n <span class=\"!text-[10px] text-[#404040]\"\n >Expiry:</span\n >\n <span class=\"!text-[13px] font-bold\">{{\n item.data.ExpiryDate | date\n }}</span>\n </span>\n </div>\n\n <div>\n <span class=\"!text-[10px] text-[#404040]\"\n >Responses:</span\n >\n <p class=\"!text-[12px]\">{{ item.data.Duration }}</p>\n </div>\n </div>\n <p\n (click)=\"showActions($event)\"\n class=\"underline cursor-pointer text-[#3479E9] text-sm text-right mr-10\"\n >\n Actions\n </p>\n \n </div>\n\n <!-- <div class=\"flex items-end h-[100%]\">\n <span class=\"enum-val {{item.data.Status}}\">{{item.data.Status}}</span>\n </div> -->\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n </verben-left-card-data>\n </verben-left-card-data-view>\n <verben-right-card-data-view>\n <ng-template #parent>\n <div\n *ngIf=\"this.currentData\"\n class=\"flex flex-col rounded-xl h-full w-full relative space-y-6\"\n >\n <verbena-input\n name=\"Name\"\n label=\"Name\"\n (ngModelChange)=\"updateTable()\"\n [(ngModel)]=\"currentData.data.Name\"\n />\n\n <verbena-input\n name=\"expiryDate\"\n [type]=\"'date'\"\n [value]=\"currentData.data.ExpiryDate\"\n label=\"Expiry Date\"\n (ngModelChange)=\"updateTable()\"\n [(ngModel)]=\"currentData.data.ExpiryDate\"\n />\n <div>\n <p class=\"mb-2\">Anonymous</p>\n <div class=\"flex items-center gap-3\">\n <div class=\"flex items-center gap-2\">\n <input\n name=\"anonymous\"\n id=\"yes\"\n type=\"radio\"\n (change)=\"setAnonymous(true, currentData.data)\"\n />\n <label for=\"yes\">Yes</label>\n </div>\n <div class=\"flex items-center gap-2\">\n <input\n name=\"anonymous\"\n id=\"no\"\n type=\"radio\"\n (change)=\"setAnonymous(false, currentData.data)\"\n />\n <label for=\"no\">No</label>\n </div>\n </div>\n </div>\n\n <div class=\"flex flex-col gap-1\">\n <div>Field Groups</div>\n <verben-drop-down\n width=\"100%\"\n placeholder=\"Change Data Type\"\n >\n </verben-drop-down>\n </div>\n\n <!-- buttons -->\n <div class=\"flex justify-between w-full bottom-8 left-0 right-0\">\n <verbena-button\n class=\"verben-delete-button\"\n text=\"Delete\"\n ></verbena-button>\n <div class=\"flex gap-3\">\n <verbena-button\n class=\"verben-switch-button\"\n (click)=\"\n viewProcesses(\n this.currentData\n ? this.currentData.data\n ? this.currentData.data.Code\n : ''\n : ''\n )\n \"\n text=\"View Fields\"\n ></verbena-button>\n <verbena-button\n class=\"verben-switch-button\"\n (click)=\"goToTableView()\"\n text=\"Switch To Table\"\n ></verbena-button>\n <verbena-button\n class=\"verben-primary-button\"\n (click)=\"this.saveUser()\"\n text=\"Save\"\n ></verbena-button>\n </div>\n </div>\n </div>\n </ng-template>\n </verben-right-card-data-view>\n <!-- <verben-right-card-data-view>\n yeshhhhhh\n </verben-right-card-data-view> -->\n\n <verben-card-data-view-footer>\n <div class=\"flex gap-2 justify-between\">\n <div\n *ngIf=\"!vdcv.hasCurrentItem()\"\n class=\"message-log-button-container flex justify-between\"\n >\n <verbena-button\n [fontWeight]=\"'bold'\"\n [bgColor]=\"'#8E8D87'\"\n [borderRadius]=\"'4px'\"\n [textColor]=\"'#fff'\"\n [text]=\"'Delete'\"\n >\n </verbena-button>\n </div>\n <div\n class=\"flex {{\n vdcv.hasCurrentItem() ? 'flex-1' : ''\n }} justify-end items-center gap-5\"\n >\n <span class=\"paginator-text\"\n >{{ cardData.length }} records loaded</span\n >\n <button (click)=\"loadMore()\" class=\"load-more view-links\">\n Load more\n </button>\n </div>\n </div>\n </verben-card-data-view-footer>\n </verben-card-data-view>\n </div>\n <div column-content>\n <verben-visible-column\n (columnsUpdated)=\"onColumnsUpdated($event)\"\n [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n borderRadius=\"10px\"\n boxShadow=\"2px 2px 2px 0px silver\"\n bgColor=\"white\"\n width=\"400px\"\n textColor=\"black\"\n pd=\"1rem\"\n primaryColor=\"#FFE681\"\n secondaryColor=\"#3479E9\"\n [columns]=\"visibleColumns\"\n [displayedColumns]=\"5\"\n ></verben-visible-column>\n </div>\n <div filter-content>\n <verben-table-filter\n (filtersApplied)=\"onFilterUpdated($event)\"\n [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n borderRadius=\"10px\"\n boxShadow=\"2px 2px 2px 0px silver\"\n bgColor=\"white\"\n width=\"420px\"\n textColor=\"black\"\n pd=\"1rem\"\n primaryColor=\"#FFE681\"\n secondaryColor=\"#3479E9\"\n tertiaryColor=\"#404040\"\n [filterOptions]=\"filterArray\"\n [maxFilterLength]=\"3\"\n ></verben-table-filter>\n </div>\n <div sort-content>\n <verben-sort-table\n (selectedOptions)=\"onSortUpdated($event)\"\n [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n borderRadius=\"10px\"\n boxShadow=\"2px 2px 2px 0px silver\"\n bgColor=\"white\"\n width=\"400px\"\n textColor=\"black\"\n pd=\"1rem\"\n primaryColor=\"#FFE681\"\n secondaryColor=\"#3479E9\"\n tertiaryColor=\"#404040\"\n [enableDragAndDrop]=\"true\"\n [sortOptions]=\"sortOptions\"\n ></verben-sort-table>\n </div>\n <div export-content>\n <lib-data-export [data]=\"data\" (exportDataEvent)=\"handleExport($event)\">\n </lib-data-export>\n </div>\n </verben-data-view>\n <div *ngIf=\"vdv.isTableView\" class=\"flex gap-2 justify-between\">\n <div class=\"message-log-button-container flex justify-between\">\n <verbena-button\n [fontWeight]=\"'bold'\"\n [bgColor]=\"'#8E8D87'\"\n [borderRadius]=\"'4px'\"\n [textColor]=\"'#fff'\"\n [text]=\"'Delete'\"\n >\n </verbena-button>\n </div>\n <div class=\"flex justify-end items-center gap-5\">\n <span class=\"paginator-text\">{{ cardData.length }} records loaded</span>\n <button (click)=\"loadMore()\" class=\"load-more view-links\">\n Load more\n </button>\n </div>\n </div>\n</div>\n", styles: [".view-links{font-size:14px!important;color:#00f;font-weight:600;cursor:pointer}.view-links:hover{text-decoration:underline;text-underline-offset:3px}.context-banner{background-color:#d4a00773}.card-min-height{gap:10px}::ng-deep .childrenPadding{max-height:300px;overflow-y:auto}::ng-deep .toolbar{margin-bottom:15px}::ng-deep .master-only-container{margin:0!important;padding:0!important}::ng-deep .master-detail-container{margin:0!important;padding:0!important}.pop-up-content{border-radius:4px;background-color:#fff;border:1px solid rgba(212,161,7,.5)}.pop-up-value{padding:10px 20px}.pop-up-content>div:nth-child(1){border-bottom:4px solid #FFE681}.enum-val{padding:2px 10px;width:100%;min-width:max-content;text-align:center}.enum-val.Active{background-color:#d6f3e6;color:#2db76f}.enum-val.InActive{background-color:#ffdfdf;color:#eb5757}\n"] }]
654
+ }], ctorParameters: () => [{ type: i1.UtilService }, { type: i2.HttpWebRequestService }, { type: i0.ChangeDetectorRef }, { type: i3.FormBuilder }, { type: i4.EnvironmentService }, { type: i5.Router }, { type: i6.FormsFieldService }, { type: i7.Location }], propDecorators: { cardDataView: [{
655
+ type: ViewChild,
656
+ args: ['vdcv']
657
+ }], dataView: [{
658
+ type: ViewChild,
659
+ args: ['vdv']
660
+ }], tableView: [{
661
+ type: ViewChild,
662
+ args: ['dt']
663
+ }], application: [{
664
+ type: Input
665
+ }], pageSize: [{
666
+ type: Input
667
+ }], searchDebounceTime: [{
668
+ type: Input
669
+ }], onViewProcessClicked: [{
670
+ type: Output
671
+ }] } });
672
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/verben-workflow-ui/src/lib/components/forms/form-details/form-details.component.ts","../../../../../../../projects/verben-workflow-ui/src/lib/components/forms/form-details/form-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  CardData,\n  CardDataViewComponent,\n  ColumnDefinition,\n  DataFilterType,\n  DataTableComponent,\n  DataViewComponent,\n  DropdownChangeEvent,\n  DropdownLoadEvent,\n  IDataFilter,\n} from 'verben-ng-ui';\nimport { FormsService} from '../forms.service';\nimport { baseStyle } from '../base-table-style';\nimport { UtilService } from '../../../services/util.service';\nimport { HttpWebRequestService } from '../../../services/http-web-request.service';\nimport { ErrorResponse } from '../../../models/ErrorResponse';\nimport { PagedResult } from '../../../models/PagedResult';\nimport { SearchPropertyValue } from '../../../models/SearchPropertyValue';\nimport { SearchOperator } from '../../../models/SearchOperator';\nimport { SearchPropertySign } from '../../../models/SearchPropertySign';\nimport { EnvironmentService } from '../../../services/environment.service';\nimport { SearchPropertyValueType } from '../../../models/SearchPropertyValueType';\nimport { debounceTime, Subject } from 'rxjs';\nimport { Status } from '../../../models/status';\nimport { User } from '../../../models/user';\nimport { ObjectState } from '../../../models/object-state';\nimport { mockData } from './helper';\nimport {Router } from '@angular/router';\nimport { FormBuilder } from '@angular/forms';\nimport { FormsFieldService } from './form-fields.service';\nimport { Location } from '@angular/common';\nimport { FormValues } from '../../../models/FormValues';\n\nenum TaskUserPropertyName {\n  User = 'User',\n  Date = 'Date',\n  Role = 'Role',\n  Service = 'Service',\n  Application = 'Application',\n  Tenant = 'Tenant',\n  Email = 'Email',\n  Status = 'Status',\n}\nenum TaskUserPropertyMap {\n  User = 'Name',\n  Date = 'CreatedAt',\n  Role = 'RoleID',\n  Service = 'ServiceName',\n  Application = 'Application',\n  Tenant = 'TenantId',\n  Email = 'MailAddress',\n  Status = 'Status',\n}\n\nenum FilterTypes {\n  Before = SearchPropertySign.LT,\n  On = SearchPropertySign.EQ,\n  After = SearchPropertySign.GT,\n  NEQ = SearchPropertySign.NEQ,\n}\n\n@Component({\n  selector: 'lib-form-details',\n  templateUrl:'./form-details.component.html',\n  styleUrl: './form-details.component.css',\n})\nexport class FormDetailsComponent implements OnInit {\n  visibleColumnDef: ColumnDefinition<FormValues>[] = [];\n  styles = baseStyle;\n  data: FormValues[] = mockData\n  path:string='/documentation/workflow-forms/fields'\n  cardData: CardData[] = [];\n  queryParams:any={}\n  currentData: CardData | null = null;\n  @ViewChild('vdcv') cardDataView!: CardDataViewComponent;\n  @ViewChild('vdv') dataView!: DataViewComponent;\n  @ViewChild('dt') tableView!: DataTableComponent<FormValues>;\n  @Input() application: string | null = null;\n  @Input() pageSize: number = 10;\n  @Input() searchDebounceTime: number = 500;\n  @Output() onViewProcessClicked: EventEmitter<string> = new EventEmitter();\n\n  pageState: PagedResult<FormValues> | null = null;\n  isOpen: boolean = false;\n  openDropdownId: string | null = null;\n  currentFilters: IDataFilter[] = [];\n  currentSorts: IDataFilter[] = [];\n  searchTerm$ = new Subject<string>();\n  statusOptions: Status[] = Object.values(Status);\n  users: FormValues[] = [];\n\n  visibleColumns: IDataFilter[] = [];\n\n  filterArray: IDataFilter[] = [\n    {\n      name: TaskUserPropertyName.Date,\n      type: DataFilterType.Date,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.User,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Email,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Tenant,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Application,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Service,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Role,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Status,\n      type: DataFilterType.String,\n      checked: false,\n    },\n  ];\n\n  sortOptions: IDataFilter[] = [\n    {\n      name: TaskUserPropertyName.Date,\n      type: DataFilterType.Date,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.User,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Email,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Tenant,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Application,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Service,\n      type: DataFilterType.String,\n      checked: false,\n    },\n    {\n      name: TaskUserPropertyName.Role,\n      type: DataFilterType.String,\n      checked: false,\n    },\n  ];\n\n  private currentSearchTerm: string = '';\n\n  constructor(\n    private utilService: UtilService,\n    private server: HttpWebRequestService,\n    private cdr: ChangeDetectorRef,\n    private fb: FormBuilder,\n    private envSvc: EnvironmentService,\n    private router:Router,\n    private taskUsersSvc: FormsFieldService,\n    private _location: Location\n  ) {\n    this.visibleColumnDef = taskUsersSvc.formFieldColumns;\n    this.visibleColumns = taskUsersSvc.formFieldColumns.map((col) => ({\n      checked: true,\n      name: typeof col.header === 'string' ? col.header : col.id,\n      type: DataFilterType.Bool,\n    }));\n  }\n  async ngOnInit(): Promise<void> {\n   \n   \n    this.searchTerm$\n      .pipe(debounceTime(this.searchDebounceTime)) // Adjust debounce time here (in ms)\n      .subscribe(async (searchTerm) => {\n        this.currentSearchTerm = searchTerm;\n        this.updateFiltersAndSorts(true);\n      });\n      this.setUpCardData()\n  }\n  \n\n  async getAllTaskUsers(): Promise<FormValues[] | undefined> {\n    this.utilService.sendBI(true);\n    const res = await this.server.get(\n      `TaskUser/GetTaskUsers/0/${this.pageSize}`,\n      this.envSvc.environment.WorkFlowAPI\n    );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      return undefined;\n    } else {\n      this.pageState = res as PagedResult<FormValues>;\n      var result = (res as PagedResult<FormValues>).Result;\n      return result;\n    }\n  }\n  async getUsers(): Promise<User[] | undefined> {\n    var payload: SearchPropertyValue[] = [\n      {\n        PropertyName: 'IsCronUser',\n        EntityValue: 'true',\n        Operator: SearchOperator.And,\n        Sign: SearchPropertySign.EQ,\n        Type: SearchPropertyValueType.Bool,\n      },\n    ];\n    this.utilService.sendBI(true);\n    const res = await this.server.post(\n      `User/SearchUsers/0/${this.pageSize}`,\n      payload\n    );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      return undefined;\n    } else {\n      var result = (res as PagedResult<User>).Result;\n      return result;\n    }\n  }\n  async loadMoreUsers(event: DropdownLoadEvent): Promise<User[]> {\n    var payload: SearchPropertyValue[] = [\n      {\n        PropertyName: 'IsCronUser',\n        EntityValue: 'true',\n        Operator: SearchOperator.And,\n        Sign: SearchPropertySign.EQ,\n        Type: SearchPropertyValueType.Bool,\n      },\n    ];\n    this.utilService.sendBI(true);\n    const res = await this.server.post(\n      `User/SearchUsers/${event.loadTimes * this.pageSize}/${this.pageSize}`,\n      payload\n    );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      return [];\n    } else {\n      var result = (res as PagedResult<User>).Result;\n      return result;\n    }\n  }\n\n  onUserSelected(event: DropdownChangeEvent, item: FormValues) {\n    const user = this.users.find((x) => x.Name == event.value);\n    if (user) {\n      item.Name = user.Name;\n      item.Duration=user.Duration\n      item.ExpiryDate= user.ExpiryDate;\n      item.AllowAnonymous =user.AllowAnonymous\n      item.CreatedAt=user.CreatedAt\n    }\n  }\n  onClear(event: Event, item: FormValues) {\n    item.Name = '';\n    item.Duration = 0;\n    item.ExpiryDate = new Date();\n    item.AllowAnonymous= false\n    item.CreatedAt=new Date()\n\n  }\n\n  getItemLabel(name: string): string {\n    const item = this.users.find((user) => user.Name === name);\n    const otherCheck = this.data.find((data) => data.Name === name);\n    return item\n      ? item.Name\n      : otherCheck\n      ? otherCheck.Name\n      : '';\n  }\n  showActions(e:Event){\n  e.stopPropagation()\n  }\n\n  getAsyncLabel(value: any): string {\n    const data = this.data.find((x) => x.Name == value);\n\n    return data ? data.Name : '';\n  }\n\n  async loadMore() {\n    if (!this.pageState) {\n      return;\n    }\n    this.utilService.sendBI(true);\n    const res =\n      this.currentFilters.length > 0 ||\n      this.currentSorts.length > 0 ||\n      this.currentSearchTerm.trim().length > 0\n        ? await this.loadMoreFiltersAndSorts()\n        : await this.server.get(\n            `TaskUser/GetTaskUsers/${this.pageState.Skip}/${this.pageSize}`,\n            this.envSvc.environment.WorkFlowAPI\n          );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      return;\n    } else {\n      this.pageState = res as PagedResult<FormValues>;\n      var result = (res as PagedResult<FormValues>).Result;\n      this.data = this.data.concat(\n        result.map((x) => {\n          return {\n            ...x,\n            id: x.Id,\n          };\n        })\n      );\n      this.setUpCardDataExtra(result);\n    }\n  }\n\n  setUpCardData() {\n    const cardData: CardData[] = this.data.map((x) => {\n      return {\n        selected: false,\n        title: x.Name,\n        data: x,\n        body: [],\n        children: [],\n      };\n    });\n    this.cardData = cardData;\n  }\n\n  setUpCardDataExtra(baseData: FormValues[]) {\n    const cardData: CardData[] = baseData.map((x) => {\n      return {\n        selected: false,\n        title: x.Name,\n        data: x,\n        body: [],\n        children: [],\n      };\n    });\n    this.cardData = this.cardData.concat(cardData);\n  }\n\n  goToCardView(data: FormValues) {\n    const item = this.cardData.find((x) => x.data == data);\n    if (item) {\n      this.userCardClicked(item, true);\n    }\n  }\n\n  goToTableView() {\n    if (!this.currentData) {\n      return;\n    }\n    this.dataView.toggleView();\n    const id = this.currentData.data ? this.currentData.data.Id : '';\n    if (id.trim().length > 0 && !this.tableView.isRowEditing(id)) {\n      this.tableView.toggleRowEdit(id);\n    }\n  }\n\n  viewProcesses(code: string) {\n    if (code.trim().length == 0) {\n      return;\n    }\n    this.onViewProcessClicked.emit(code);\n  }\n\n  userCardClicked(item: CardData, toggleView: boolean = false) {\n    this.currentData = this.cardDataView.onItemClick(item);\n    if (toggleView) {\n      this.dataView.toggleView();\n    }\n  }\n\n  async saveUser() {\n    if (this.currentData) {\n      var user: FormValues = this.currentData.data as FormValues;\n\n      if (this.currentData.data.Name.trim().length == 0) {\n        this.utilService.showInfo('Name cannot be empty');\n        return;\n      }\n      user.DataState =\n        user.DataState == ObjectState.New\n          ? ObjectState.New\n          : ObjectState.Changed;\n      user.Id = user.DataState == ObjectState.New ? '' : user.Id;\n      this.utilService.sendBI(true);\n      const res = await this.server.post(\n        `TaskUser/SaveTaskUsers`,\n        [user],\n        this.envSvc.environment.WorkFlowAPI\n      );\n      this.utilService.sendBI(false);\n      if (res instanceof ErrorResponse) {\n      } else {\n        this.utilService.showSuccess('Active user saved successfully');\n        const result = res as FormValues[];\n        if (result.length > 0) {\n          var userResult = result[0];\n          const itemIndex = this.data.findIndex(\n            (x) => x == this.currentData?.data\n          );\n          if (itemIndex > -1) {\n            this.data[itemIndex].Name = userResult.Name;\n            this.data[itemIndex].Id = userResult.Id;\n            this.data[itemIndex].id = userResult.Id;\n            this.data[itemIndex].DataState = userResult.DataState;\n            this.data[itemIndex].EntityValues = userResult.EntityValues;\n            this.data[itemIndex].AllowAnonymous = userResult.AllowAnonymous;\n            this.data = this.data.map((x) => x);\n          }\n        }\n      }\n    }\n  }\n  toggleAnonymous(value: boolean, row:FormValues): void {\n    const newValue = !value;\n    row.AllowAnonymous=newValue\n   console.log(row);\n   \n  }\n  \n  setAnonymous(value: boolean, currentData:FormValues): void {\n    currentData.AllowAnonymous = value;\n    console.log(currentData);\n    \n  }\n  async tableSaveUser(user: FormValues, callBack: () => any) {\n    // if (user.Name.trim().length == 0) {\n    //   this.utilService.showInfo('Name cannot be empty');\n    //   return;\n    // }\n    // user.DataState =\n    //   user.DataState == ObjectState.New ? ObjectState.New : ObjectState.Changed;\n    // user.Id = user.DataState == ObjectState.New ? '' : user.Id;\n    // this.utilService.sendBI(true);\n    // const res = await this.server.post(\n    //   `TaskUser/SaveTaskUsers`,\n    //   [user],\n    //   this.envSvc.environment.WorkFlowAPI\n    // );\n    // this.utilService.sendBI(false);\n    // if (res instanceof ErrorResponse) {\n    // } else {\n    //   this.utilService.showSuccess('Active user saved successfully');\n    //   const result = res as Form[];\n    //   if (result.length > 0) {\n    //     var userResult = result[0];\n    //     const itemIndex = this.data.findIndex((x) => x == user);\n    //     if (itemIndex > -1) {\n    //       this.data[itemIndex].Name = userResult.Name;\n    //       this.data[itemIndex].Id = userResult.Id;\n    //       this.data[itemIndex].id = userResult.id;\n    //       this.data[itemIndex].DataState = userResult.DataState;\n    //       this.data[itemIndex].AllowAnonymous = userResult.MaxValue;\n    //       this.data[itemIndex].IsRequired = userResult.IsRequired;\n    //       this.data = this.data.map((x) => x);\n    //     }\n    //     callBack();\n    //   }\n    // }\n  }\n\n  updateTable() {\n    this.data = this.data.map((x) => x);\n    console.log(this.data);\n    \n    \n  }\n\n  \n  convertToString(value: any, source: FormValues) {\n    value = parseInt(value);\n  }\n\n\n  navigateToFields() {\n    const queryParams =this.queryParams\n    this.router.navigate([`${this.path}`], { queryParams });\n  }\n  onClose() {\n    this.isOpen = false;\n  }\n\n\n  openDropdown(item: any): void {\n    if (this.openDropdownId === item.Id) {\n      this.openDropdownId = null;\n    } else {\n      this.openDropdownId = item.Id;\n    }\n  }\n  goBack(){\n    this._location.back()\n  }\n  isDropdownOpen(item: any): boolean {\n    return this.openDropdownId === item.Id;\n  }\n\n  onViewChange(isGridView: boolean): void {}\n\n  onStateChange(event: { key: string; value: boolean }): void {\n    switch (event.key) {\n      case 'create':\n        var newUser: FormValues = {\n          TenantId: '',\n          Code: '',\n          id:'',\n          Id: (this.cardData.length + 1).toString(),\n          ServiceName: '',\n          CreatedAt: new Date(),\n          UpdatedAt: new Date(),\n          DataState: ObjectState.New,\n          EntityValues: [],\n          IsValid: false,\n          AllowAnonymous: false,\n          URL: '',\n          Duration: 0,\n          ExpiryDate: new Date(), \n          Name: '', \n        };\n        const cardData: CardData = {\n          selected: false,\n          title: newUser.Name,\n          data: newUser,\n          body: [],\n          children: [],\n        };\n        this.data = this.data.concat([newUser]);\n        this.cardData.push(cardData);\n        this.userCardClicked(cardData);\n        this.dataView.isTableView = false;\n        break;\n      default:\n        break;\n    }\n  }\n\n  showTableView: boolean = false;\n  onSelectionChange(selectedRows: FormValues[]) {}\n  retryMessage() {}\n\n  onColumnsUpdated(updatedColumns: IDataFilter[]) {\n    const updatedColumnDef: ColumnDefinition<FormValues>[] = [];\n    updatedColumns.forEach((col) => {\n      const matchingCol = this.taskUsersSvc.formFieldColumns.find(\n        (column) => column.header === col.name || column.id === col.name\n      );\n      if (matchingCol) {\n        updatedColumnDef.push(matchingCol);\n      }\n    });\n\n    this.visibleColumnDef = [...updatedColumnDef];\n  }\n\n  async updateFiltersAndSorts(isSearch: boolean = false) {\n    if (!isSearch) {\n      this.dataView.onClearSearch();\n      this.currentSearchTerm = '';\n      this.cdr.detectChanges();\n      const clickEvent = new MouseEvent('click', {\n        bubbles: true,\n        cancelable: true,\n        view: window,\n      });\n      document.dispatchEvent(clickEvent);\n    }\n    var payload: SearchPropertyValue[] = this.currentFilters.map((x) => {\n      return {\n        PropertyName:\n          TaskUserPropertyMap[x.name as keyof typeof TaskUserPropertyMap],\n        EntityValue: x.value,\n        Operator: SearchOperator.And,\n        Sign:\n          x.condition && Object.keys(FilterTypes).includes(x.condition)\n            ? (FilterTypes[\n                x.condition as keyof typeof FilterTypes\n              ] as unknown as SearchPropertySign)\n            : SearchPropertySign.EQ,\n        Type:\n          x.name == TaskUserPropertyName.Date\n            ? SearchPropertyValueType.Date\n            : SearchPropertyValueType.String,\n      };\n    });\n    // payload.push({\n    //   PropertyName: 'APIKey',\n    //   EntityValue: this.envSvc.environment.APIKey,\n    //   Operator: SearchOperator.And,\n    //   Sign: SearchPropertySign.EQ,\n    // });\n    const sortParam: { Param: string; Order: string } | null =\n      this.currentSorts.length > 0\n        ? {\n            Param:\n              TaskUserPropertyMap[\n                this.currentSorts[0].name as keyof typeof TaskUserPropertyMap\n              ],\n            Order: this.currentSorts[0].value,\n          }\n        : null;\n    const searchTermExists = this.currentSearchTerm.trim().length > 0;\n    this.utilService.sendBI(true);\n    const res = searchTermExists\n      ? await this.server.get(\n          `TaskUser/GetTaskUserWithParam/${this.currentSearchTerm.trim()}/0/${\n            this.pageSize\n          }`,\n          this.envSvc.environment.WorkFlowAPI\n        )\n      : await this.server.post(\n          sortParam\n            ? `TaskUser/SearchTaskUsers/0/${this.pageSize}/${sortParam.Param}/${sortParam.Order}`\n            : `TaskUser/SearchTaskUsers/0/${this.pageSize}`,\n          payload,\n          this.envSvc.environment.WorkFlowAPI\n        );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      this.currentFilters = [];\n      this.currentSorts = [];\n      return undefined;\n    } else {\n      this.pageState = res as PagedResult<FormValues>;\n      var result = (res as PagedResult<FormValues>).Result;\n      this.data = result.map((x) => {\n        return {\n          ...x,\n          id: x.Id,\n        };\n      });\n      this.setUpCardData();\n    }\n  }\n  async loadMoreFiltersAndSorts(): Promise<PagedResult<FormValues> | undefined> {\n    if (!this.pageState) {\n      return;\n    }\n    var payload: SearchPropertyValue[] = this.currentFilters.map((x) => {\n      return {\n        PropertyName:\n          TaskUserPropertyMap[x.name as keyof typeof TaskUserPropertyMap],\n        EntityValue: x.value,\n        Operator: SearchOperator.And,\n        Sign:\n          x.condition && Object.keys(FilterTypes).includes(x.condition)\n            ? (FilterTypes[\n                x.condition as keyof typeof FilterTypes\n              ] as unknown as SearchPropertySign)\n            : SearchPropertySign.EQ,\n        Type:\n          x.name == TaskUserPropertyName.Date\n            ? SearchPropertyValueType.Date\n            : SearchPropertyValueType.String,\n      };\n    });\n    const sortParam: { Param: string; Order: string } | null =\n      this.currentSorts.length > 0\n        ? {\n            Param:\n              TaskUserPropertyMap[\n                this.currentSorts[0].name as keyof typeof TaskUserPropertyMap\n              ],\n            Order: this.currentSorts[0].value,\n          }\n        : null;\n    const searchTermExists = this.currentSearchTerm.trim().length > 0;\n    this.utilService.sendBI(true);\n    const res = searchTermExists\n      ? await this.server.get(\n          `TaskUser/GetTaskUserWithParam/${this.currentSearchTerm.trim()}/${\n            this.pageState.Skip\n          }/${this.pageSize}`,\n          this.envSvc.environment.WorkFlowAPI\n        )\n      : await this.server.post(\n          sortParam\n            ? `TaskUser/SearchTaskUsers/${this.pageState.Skip}/${this.pageSize}/${sortParam.Param}/${sortParam.Order}`\n            : `TaskUser/SearchTaskUsers/${this.pageState.Skip}/${this.pageSize}`,\n          payload,\n          this.envSvc.environment.WorkFlowAPI\n        );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n      return undefined;\n    } else {\n      var result = res as PagedResult<FormValues>;\n      return result;\n    }\n  }\n  onFilterUpdated(updatedFilters: IDataFilter[] | string) {\n    // Ensure updatedFilters is an array\n    if (Array.isArray(updatedFilters)) {\n      this.currentFilters = updatedFilters;\n      this.updateFiltersAndSorts();\n    }\n  }\n  onSortUpdated(updatedSorts: IDataFilter[]) {\n    this.currentSorts = updatedSorts;\n    this.updateFiltersAndSorts();\n  }\n\n  handleSearch(event: { key: string; value: string }) {\n    this.searchTerm$.next(event.value);\n  }\n\n  handleExport(exportedData: Partial<any>[]) {\n    // console.log('Exported data:', exportedData);\n    this.downloadCSV(exportedData);\n  }\n  private downloadCSV(data: Partial<any>[]) {\n    const headers = Object.keys(data[0]);\n    const csvContent = [\n      headers.join(','),\n      ...data.map((row) => headers.map((header) => row[header]).join(',')),\n    ].join('\\n');\n\n    const blob = new Blob([csvContent], { type: 'text/csv;charset=utf-8;' });\n    const link = document.createElement('a');\n    if (link.download !== undefined) {\n      const url = URL.createObjectURL(blob);\n      link.setAttribute('href', url);\n      link.setAttribute('download', 'export.csv');\n      link.style.visibility = 'hidden';\n      document.body.appendChild(link);\n      link.click();\n      document.body.removeChild(link);\n    }\n  }\n}\n","<div #messageLog class=\"flex flex-col gap-4 message-log-container\">\n  <verben-data-view\n    #vdv\n    [viewState]=\"{\n        isSearch: true,\n        isColumn: true,\n        isFilter: true,\n        isSort: true,\n        isExport: true,\n        isSelect: true,\n        isCreate: true,\n        isToggle:true,\n      }\"\n    [buttonClass]=\"'my-custom-button-class'\"\n    [iconClass]=\"'my-icon-class'\"\n    [activeIconClass]=\"'my-active-icon-class'\"\n    [selectedColumnCount]=\"0\"\n    [selectedSortCount]=\"0\"\n    [selectedFilterTableCount]=\"0\"\n    (viewChange)=\"onViewChange($event)\"\n    (stateChange)=\"onStateChange($event)\"\n    (onSearchChange)=\"handleSearch($event)\"\n  >\n    <div class=\"mt-2\" table-content>\n      <lib-data-table\n        #dt\n        [data]=\"data\"\n        [columns]=\"visibleColumnDef\"\n        [styleConfig]=\"styles\"\n        (selectionChange)=\"onSelectionChange($event)\"\n      >\n        <ng-container libColumn=\"select\">\n          <ng-template\n            #cell\n            let-isSelected=\"isSelected\"\n            let-toggleRowSelection=\"toggleRowSelection\"\n          >\n            <input\n              type=\"checkbox\"\n              [checked]=\"isSelected\"\n              (change)=\"toggleRowSelection()\"\n            />\n          </ng-template>\n          <ng-template\n            #header\n            let-allRowsSelected=\"allRowsSelected\"\n            let-someRowsSelected=\"someRowsSelected\"\n            let-toggleAllRows=\"toggleAllRows\"\n          >\n            <input\n              type=\"checkbox\"\n              [checked]=\"allRowsSelected()\"\n              [indeterminate]=\"someRowsSelected()\"\n              (change)=\"toggleAllRows()\"\n            />\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"createdAt\">\n          <ng-template #cell let-row=\"row\" let-value>\n            {{ value | date }}\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"name\">\n          <ng-template #cell let-row=\"row\" let-value>\n            {{ value.Name }}\n          </ng-template>\n          <ng-template\n            #cellEdit\n            let-row=\"row\"\n            let-updateValue=\"updateValue\"\n            let-value\n          >\n            <verbena-input\n              inputContainerClass=\"w-fit\"\n              [value]=\"value.Name\"\n            ></verbena-input>\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"entities\">\n          <ng-template #cell let-row=\"row\" let-value>\n            <span class=\"flex gap-2\" *ngFor=\"let field of row.Entities\">\n              <span\n                class=\"inline-block bg-[#3479e98a] rounded-lg px-2 py-1 text-sm\"\n                *ngFor=\"let property of field.Properties\"\n              >\n                {{ property.Name }}\n              </span>\n            </span>\n          </ng-template>\n        </ng-container>\n        <ng-container libColumn=\"expiry\">\n          <ng-template #cell let-row=\"row\" let-value>\n            {{ value | date }}\n          </ng-template>\n        </ng-container>\n\n        <ng-container libColumn=\"responses\">\n          <ng-template #cell let-row=\"row\" let-value>\n            {{ value }}\n          </ng-template>\n          <ng-template\n            #cellEdit\n            let-row=\"row\"\n            let-updateValue=\"updateValue\"\n            let-value\n          >\n            <verbena-input\n              [type]=\"'number'\"\n              inputContainerClass=\"w-[60px]\"\n              [value]=\"value\"\n            ></verbena-input>\n          </ng-template>\n        </ng-container>\n\n        <ng-container libColumn=\"anonymous\">\n          <ng-template #cell let-row=\"row\" let-value>\n            <verben-svg *ngIf=\"value === true\" [icon]=\"'check'\"></verben-svg>\n            <verben-svg *ngIf=\"value === false\" [icon]=\"'error'\"></verben-svg>\n          </ng-template>\n          <ng-template\n            #cellEdit\n            let-row=\"row\"\n            let-updateValue=\"updateValue\"\n            let-value\n          >\n            <div\n              (click)=\"toggleAnonymous(value, row)\"\n              class=\"w-[53px] p-1 text-[#fff] h-[22px] relative bg-[#1A237E] rounded-2xl cursor-pointer\"\n            >\n              <!-- Toggle circle -->\n              <span\n                [ngClass]=\"{\n                  'translate-x-[100%]': value === true,\n                  'translate-x-0': value !== true\n                }\"\n                class=\"w-[50%] h-full block absolute left-0 top-0 bg-[#fff] rounded-full scale-[70%] transition-transform\"\n              >\n              </span>\n              <!-- ON/OFF text -->\n              <span *ngIf=\"value === true\" class=\"block text-xs ml-1\">ON</span>\n              <span\n                *ngIf=\"value === false\"\n                class=\"block text-xs mr-1\"\n                [ngClass]=\"{\n                  'text-right': value === false,\n                  'text-left': value === true\n                }\"\n                >OFF</span\n              >\n            </div>\n          </ng-template>\n        </ng-container>\n\n        <ng-container libColumn=\"actions\">\n          <ng-template\n            #cell\n            let-isEditing=\"isEditing\"\n            let-toggleRowEdit=\"toggleRowEdit\"\n            let-row=\"row\"\n            let-value\n          >\n            <verben-pop-Up\n              [customStyles]=\"{ 'z-index': '99' }\"\n              [dropdownOpen]=\"isDropdownOpen(row)\"\n              [enableMouseLeave]=\"false\"\n              (close)=\"onClose()\"\n            >\n              <verben-svg\n                class=\"cursor-pointer actions-icon\"\n                (click)=\"openDropdown(row)\"\n                dropdown-trigger\n                icon=\"list\"\n              ></verben-svg>\n              <div class=\"pop-up-content flex flex-col\" dropdown-content>\n                <div\n                  (click)=\"navigateToFields()\"\n                  class=\"pop-up-value cursor-pointer\"\n                >\n                  View Fields\n                </div>\n                <div\n                  (click)=\"toggleRowEdit()\"\n                  class=\"pop-up-value cursor-pointer\"\n                >\n                  Edit\n                </div>\n                <div class=\"pop-up-value cursor-pointer\">Delete</div>\n              </div>\n            </verben-pop-Up>\n          </ng-template>\n          <ng-template\n            #cellEdit\n            let-isEditing=\"isEditing\"\n            let-toggleRowEdit=\"toggleRowEdit\"\n            let-row=\"row\"\n            let-value\n          >\n            <div class=\"flex gap-2 items-center\">\n              <verben-svg\n                icon=\"check\"\n                [width]=\"15\"\n                [height]=\"15\"\n                (click)=\"tableSaveUser(value, toggleRowEdit)\"\n              ></verben-svg>\n              <verben-svg icon=\"delete\" [width]=\"15\" [height]=\"15\"></verben-svg>\n              <verben-svg\n                icon=\"cardViewAlt\"\n                [width]=\"15\"\n                [height]=\"15\"\n                (click)=\"goToCardView(value)\"\n              ></verben-svg>\n            </div>\n          </ng-template>\n        </ng-container>\n      </lib-data-table>\n    </div>\n    <div card-content>\n      <verben-card-data-view\n        borderRadius=\"12px\"\n        #vdcv\n        dataId=\"Id\"\n        border=\"5px\"\n        [cardDataList]=\"cardData\"\n        rbgColor=\"#f5f6f9\"\n        mg=\"0px\"\n      >\n        <verben-left-card-data-view class=\"space-y-7\">\n          <verben-left-card-data\n            #vlcd\n            [parent]=\"vdcv\"\n            dataId=\"MailAddress\"\n            class=\"bg-secondary-100 rounded-xl border-primary border-[1px]\"\n            [cardDataList]=\"cardData\"\n          >\n            <ng-template #card let-item>\n              <div\n                (click)=\"userCardClicked(item)\"\n                class=\"flex cursor-pointer h-[max-content]\"\n              >\n                <!-- <verben-svg [width]=\"15\" [height]=\"15\" (click)=\"toggleChildren(item); $event.stopPropagation()\"\n                    [ngClass]=\"item.children && item.children.length?'visible':'invisible'\"\n                    class=\"items-center flex  pr-1 cursor-pointer\" [icon]=\"item.isChildrenExpanded?'minus':'plus'\" /> -->\n                <div class=\"flex w-full bg-secondary rounded-xl\">\n                  <div\n                    class=\"w-3 rounded-xl rounded-tr-none rounded-br-none\"\n                    [ngClass]=\"\n                      item.selected ? 'bg-primary' : 'bg-secondary-200'\n                    \"\n                  ></div>\n                  <div class=\"py-3 px-4 flex-1 h-[100%]\">\n                    <div\n                      class=\"flex items-start flex-1 gap-1 justify-between h-[100%]\"\n                    >\n                      <div\n                        class=\"flex flex-col flex-1 card-min-height justify-between h-[100%]\"\n                      >\n                        <div class=\"flex justify-between mr-4\">\n                          <div>\n                            <h3\n                              class=\"my-0 font-bold text-[#404040] leading-[19.5px]\"\n                            >\n                              {{ item.data.Name }}\n                            </h3>\n                            <span class=\"flex items-center gap-1 mt-2\">\n                              <span class=\"!text-[10px] text-[#404040]\"\n                                >Expiry:</span\n                              >\n                              <span class=\"!text-[13px] font-bold\">{{\n                                item.data.ExpiryDate | date\n                              }}</span>\n                            </span>\n                          </div>\n\n                          <div>\n                            <span class=\"!text-[10px] text-[#404040]\"\n                              >Responses:</span\n                            >\n                            <p class=\"!text-[12px]\">{{ item.data.Duration }}</p>\n                          </div>\n                        </div>\n                        <p\n                          (click)=\"showActions($event)\"\n                          class=\"underline cursor-pointer text-[#3479E9] text-sm text-right mr-10\"\n                        >\n                          Actions\n                        </p>\n                        \n                      </div>\n\n                      <!-- <div class=\"flex items-end h-[100%]\">\n                          <span class=\"enum-val {{item.data.Status}}\">{{item.data.Status}}</span>\n                        </div> -->\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </ng-template>\n          </verben-left-card-data>\n        </verben-left-card-data-view>\n        <verben-right-card-data-view>\n          <ng-template #parent>\n            <div\n              *ngIf=\"this.currentData\"\n              class=\"flex flex-col rounded-xl h-full w-full relative space-y-6\"\n            >\n              <verbena-input\n                name=\"Name\"\n                label=\"Name\"\n                (ngModelChange)=\"updateTable()\"\n                [(ngModel)]=\"currentData.data.Name\"\n              />\n\n              <verbena-input\n                name=\"expiryDate\"\n                [type]=\"'date'\"\n                [value]=\"currentData.data.ExpiryDate\"\n                label=\"Expiry Date\"\n                (ngModelChange)=\"updateTable()\"\n                [(ngModel)]=\"currentData.data.ExpiryDate\"\n              />\n              <div>\n                <p class=\"mb-2\">Anonymous</p>\n                <div class=\"flex items-center gap-3\">\n                  <div class=\"flex items-center gap-2\">\n                    <input\n                      name=\"anonymous\"\n                      id=\"yes\"\n                      type=\"radio\"\n                      (change)=\"setAnonymous(true, currentData.data)\"\n                    />\n                    <label for=\"yes\">Yes</label>\n                  </div>\n                  <div class=\"flex items-center gap-2\">\n                    <input\n                      name=\"anonymous\"\n                      id=\"no\"\n                      type=\"radio\"\n                      (change)=\"setAnonymous(false, currentData.data)\"\n                    />\n                    <label for=\"no\">No</label>\n                  </div>\n                </div>\n              </div>\n\n              <div class=\"flex flex-col gap-1\">\n                <div>Field Groups</div>\n                <verben-drop-down\n                  width=\"100%\"\n                  placeholder=\"Change Data Type\"\n                >\n                </verben-drop-down>\n              </div>\n\n              <!-- buttons -->\n              <div class=\"flex justify-between w-full bottom-8 left-0 right-0\">\n                <verbena-button\n                  class=\"verben-delete-button\"\n                  text=\"Delete\"\n                ></verbena-button>\n                <div class=\"flex gap-3\">\n                  <verbena-button\n                    class=\"verben-switch-button\"\n                    (click)=\"\n                      viewProcesses(\n                        this.currentData\n                          ? this.currentData.data\n                            ? this.currentData.data.Code\n                            : ''\n                          : ''\n                      )\n                    \"\n                    text=\"View Fields\"\n                  ></verbena-button>\n                  <verbena-button\n                    class=\"verben-switch-button\"\n                    (click)=\"goToTableView()\"\n                    text=\"Switch To Table\"\n                  ></verbena-button>\n                  <verbena-button\n                    class=\"verben-primary-button\"\n                    (click)=\"this.saveUser()\"\n                    text=\"Save\"\n                  ></verbena-button>\n                </div>\n              </div>\n            </div>\n          </ng-template>\n        </verben-right-card-data-view>\n        <!-- <verben-right-card-data-view>\n            yeshhhhhh\n          </verben-right-card-data-view> -->\n\n        <verben-card-data-view-footer>\n          <div class=\"flex gap-2 justify-between\">\n            <div\n              *ngIf=\"!vdcv.hasCurrentItem()\"\n              class=\"message-log-button-container flex justify-between\"\n            >\n              <verbena-button\n                [fontWeight]=\"'bold'\"\n                [bgColor]=\"'#8E8D87'\"\n                [borderRadius]=\"'4px'\"\n                [textColor]=\"'#fff'\"\n                [text]=\"'Delete'\"\n              >\n              </verbena-button>\n            </div>\n            <div\n              class=\"flex {{\n                vdcv.hasCurrentItem() ? 'flex-1' : ''\n              }} justify-end items-center gap-5\"\n            >\n              <span class=\"paginator-text\"\n                >{{ cardData.length }} records loaded</span\n              >\n              <button (click)=\"loadMore()\" class=\"load-more view-links\">\n                Load more\n              </button>\n            </div>\n          </div>\n        </verben-card-data-view-footer>\n      </verben-card-data-view>\n    </div>\n    <div column-content>\n      <verben-visible-column\n        (columnsUpdated)=\"onColumnsUpdated($event)\"\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"400px\"\n        textColor=\"black\"\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        [columns]=\"visibleColumns\"\n        [displayedColumns]=\"5\"\n      ></verben-visible-column>\n    </div>\n    <div filter-content>\n      <verben-table-filter\n        (filtersApplied)=\"onFilterUpdated($event)\"\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"420px\"\n        textColor=\"black\"\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        tertiaryColor=\"#404040\"\n        [filterOptions]=\"filterArray\"\n        [maxFilterLength]=\"3\"\n      ></verben-table-filter>\n    </div>\n    <div sort-content>\n      <verben-sort-table\n        (selectedOptions)=\"onSortUpdated($event)\"\n        [border]=\"'1px solid rgba(212, 160, 7, 1)'\"\n        borderRadius=\"10px\"\n        boxShadow=\"2px 2px 2px 0px silver\"\n        bgColor=\"white\"\n        width=\"400px\"\n        textColor=\"black\"\n        pd=\"1rem\"\n        primaryColor=\"#FFE681\"\n        secondaryColor=\"#3479E9\"\n        tertiaryColor=\"#404040\"\n        [enableDragAndDrop]=\"true\"\n        [sortOptions]=\"sortOptions\"\n      ></verben-sort-table>\n    </div>\n    <div export-content>\n      <lib-data-export [data]=\"data\" (exportDataEvent)=\"handleExport($event)\">\n      </lib-data-export>\n    </div>\n  </verben-data-view>\n  <div *ngIf=\"vdv.isTableView\" class=\"flex gap-2 justify-between\">\n    <div class=\"message-log-button-container flex justify-between\">\n      <verbena-button\n        [fontWeight]=\"'bold'\"\n        [bgColor]=\"'#8E8D87'\"\n        [borderRadius]=\"'4px'\"\n        [textColor]=\"'#fff'\"\n        [text]=\"'Delete'\"\n      >\n      </verbena-button>\n    </div>\n    <div class=\"flex justify-end items-center gap-5\">\n      <span class=\"paginator-text\">{{ cardData.length }} records loaded</span>\n      <button (click)=\"loadMore()\" class=\"load-more view-links\">\n        Load more\n      </button>\n    </div>\n  </div>\n</div>\n"]}