@platform-modules/civil-aviation-authority 2.3.265 → 2.3.266

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 (80) hide show
  1. package/.env +0 -15
  2. package/dist/models/AnnualIncrementRequestEmployeeModel.d.ts +2 -1
  3. package/dist/models/AnnualIncrementRequestEmployeeModel.js +7 -2
  4. package/dist/models/AnnualIncrementRequestModel.d.ts +2 -1
  5. package/dist/models/AnnualIncrementRequestModel.js +7 -2
  6. package/dist/models/SlaApprovalsViewModel.js +47 -47
  7. package/dist/models/SlaMyRequestsViewModel.js +50 -50
  8. package/package.json +1 -1
  9. package/scripts/sync-sla-reports-sql.js +98 -94
  10. package/sql/README.md +21 -25
  11. package/sql/sla-reports-sync.manifest.json +7 -7
  12. package/sql/sla_reports_admin_procedures.sql +283 -283
  13. package/sql/sla_reports_approvals_workbook.sql +383 -383
  14. package/sql/sla_reports_procedures.sql +874 -874
  15. package/sql/vw_sla_approvals.sql +108 -108
  16. package/sql/vw_sla_my_requests.sql +53 -53
  17. package/src/data-source.ts +517 -517
  18. package/src/index.ts +495 -495
  19. package/src/models/AccessCardRequestModel.ts +135 -135
  20. package/src/models/AirportEntryPermitModel.ts +276 -276
  21. package/src/models/AnnualIncrementRequestEmployeeModel.ts +6 -1
  22. package/src/models/AnnualIncrementRequestModel.ts +6 -1
  23. package/src/models/AnnualTrainingPlanRequestModel.ts +153 -153
  24. package/src/models/DepartmentsModel.ts +25 -25
  25. package/src/models/DocumentDriveModel.ts +28 -28
  26. package/src/models/DocumentFolderModel.ts +45 -45
  27. package/src/models/HotelApprovalModel.ts +83 -83
  28. package/src/models/HousingContractCancelApprovalModel.ts +64 -64
  29. package/src/models/HousingContractCancelChatModel.ts +56 -56
  30. package/src/models/HousingContractRenewalApprovalModel.ts +64 -64
  31. package/src/models/HousingContractRenewalChatModel.ts +59 -59
  32. package/src/models/ITRequestAttachmentModel.ts +73 -73
  33. package/src/models/ITRequestChatModel.ts +74 -74
  34. package/src/models/ItApprovalsModel.ts +84 -84
  35. package/src/models/ItWorkflowModel.ts +55 -55
  36. package/src/models/LegalConsultationApprovalModel.ts +65 -65
  37. package/src/models/MissionTravelPassportExpiryNotificationConfigModel.ts +36 -36
  38. package/src/models/NotificationModel.ts +89 -89
  39. package/src/models/ResidentialUnitRentalApprovalModel.ts +143 -143
  40. package/src/models/ResidentialUnitRentalChatModel.ts +56 -56
  41. package/src/models/ResidentialUnitRentalRequestModel.ts +218 -218
  42. package/src/models/ServiceExtensionAfter60ApprovalModel.ts +87 -87
  43. package/src/models/ServiceSlaApprovalModel.ts +64 -64
  44. package/src/models/ServicesNotificationConfigModel.ts +55 -55
  45. package/src/models/SlaApprovalsViewModel.ts +135 -135
  46. package/src/models/SlaMyRequestsViewModel.ts +170 -170
  47. package/src/models/SlaRequestModel.ts +65 -65
  48. package/src/models/StudyLeaveRequestModel.ts +144 -144
  49. package/src/models/TrainingRequestModel.ts +164 -164
  50. package/src/models/TrainingRoomBookingRequestModel.ts +142 -142
  51. package/src/models/TrainingRoomNotificationConfigModel.ts +30 -30
  52. package/src/models/role.ts +34 -34
  53. package/src/models/user.ts +233 -233
  54. package/src/sla/sla-table-sync.service.ts +90 -90
  55. package/dist/models/DocumentMetadataModel.d.ts +0 -45
  56. package/dist/models/DocumentMetadataModel.js +0 -171
  57. package/dist/models/DocumentationDepartmentsModel.d.ts +0 -13
  58. package/dist/models/DocumentationDepartmentsModel.js +0 -53
  59. package/dist/models/FolderModel.d.ts +0 -16
  60. package/dist/models/FolderModel.js +0 -85
  61. package/dist/models/ImportExportMaterialModels.d.ts +0 -92
  62. package/dist/models/ImportExportMaterialModels.js +0 -307
  63. package/dist/models/PermissionModel.d.ts +0 -18
  64. package/dist/models/PermissionModel.js +0 -68
  65. package/dist/models/SecurityAccessApprovalModel.d.ts +0 -23
  66. package/dist/models/SecurityAccessApprovalModel.js +0 -82
  67. package/dist/models/SecurityAccessAttachmentModel.d.ts +0 -12
  68. package/dist/models/SecurityAccessAttachmentModel.js +0 -56
  69. package/dist/models/SecurityAccessChatModel.d.ts +0 -12
  70. package/dist/models/SecurityAccessChatModel.js +0 -56
  71. package/dist/models/SecurityAccessRequestModel.d.ts +0 -25
  72. package/dist/models/SecurityAccessRequestModel.js +0 -80
  73. package/dist/models/SecurityAccessWorkflowModel.d.ts +0 -24
  74. package/dist/models/SecurityAccessWorkflowModel.js +0 -84
  75. package/dist/models/ServiceExtensionAfterAge60Models.d.ts +0 -93
  76. package/dist/models/ServiceExtensionAfterAge60Models.js +0 -312
  77. package/dist/models/UUIDBaseModel.d.ts +0 -14
  78. package/dist/models/UUIDBaseModel.js +0 -66
  79. package/dist/models/WorkingHoursExtensionModels.d.ts +0 -88
  80. package/dist/models/WorkingHoursExtensionModels.js +0 -295
@@ -1,64 +1,64 @@
1
- import { Column, Entity, Index } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
-
4
- /**
5
- * Cross-service SLA tracking row for any microservice (HR, IT, Tender, …).
6
- * Segregated by service_id, sub_service_id, request_id.
7
- * source_approval_id = native approval row PK in the owning service (e.g. hr_service_approvals.id, vpn_approvals.id); not a DB FK.
8
- */
9
- @Entity({ name: "sla_approval" })
10
- @Index("idx_sla_approval_request_id", ["request_id"])
11
- @Index("idx_sla_approval_source_approval_id", ["source_approval_id"])
12
- @Index("idx_sla_approval_service_subservice", ["service_id", "sub_service_id"])
13
- @Index("idx_sla_approval_approval_status", ["approval_status"])
14
- @Index("idx_sla_approval_level", ["level"])
15
- @Index("idx_sla_approval_approver_user_id", ["approver_user_id"])
16
- @Index("idx_sla_approval_request_level", ["request_id", "level"])
17
- @Index("idx_sla_approval_svc_sub_status", ["service_id", "sub_service_id", "approval_status"])
18
- export class ServiceSlaApproval extends BaseModel {
19
- @Column({ type: "int" })
20
- request_id: number;
21
-
22
- @Column({ type: "int" })
23
- source_approval_id: number;
24
-
25
- @Column({ type: "int", nullable: true })
26
- service_id: number | null;
27
-
28
- @Column({ type: "int", nullable: true })
29
- sub_service_id: number | null;
30
-
31
- @Column({ type: "varchar", length: 64 })
32
- approval_status: string;
33
-
34
- @Column({ type: "int" })
35
- level: number;
36
-
37
- @Column({ type: "int", nullable: true })
38
- approver_user_id: number | null;
39
-
40
- @Column({ type: "int", nullable: true })
41
- approver_role_id: number | null;
42
-
43
- @Column({ type: "int", nullable: true })
44
- department_id: number | null;
45
-
46
- @Column({ type: "int", nullable: true })
47
- section_id: number | null;
48
-
49
- /** Mirrors native approval `delegate_user_id` (IT master tables may use `delegation_user_id`). */
50
- @Column({ type: "int", nullable: true })
51
- delegate_user_id: number | null;
52
-
53
- /** Mirrors native approval `approved_by` (acting user when status was last resolved). */
54
- @Column({ type: "int", nullable: true })
55
- approved_by: number | null;
56
-
57
- /** Mirrors native approval comment / rejection reason. */
58
- @Column({ type: "varchar", length: 255, nullable: true })
59
- comment: string | null;
60
-
61
- constructor() {
62
- super();
63
- }
64
- }
1
+ import { Column, Entity, Index } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+
4
+ /**
5
+ * Cross-service SLA tracking row for any microservice (HR, IT, Tender, …).
6
+ * Segregated by service_id, sub_service_id, request_id.
7
+ * source_approval_id = native approval row PK in the owning service (e.g. hr_service_approvals.id, vpn_approvals.id); not a DB FK.
8
+ */
9
+ @Entity({ name: "sla_approval" })
10
+ @Index("idx_sla_approval_request_id", ["request_id"])
11
+ @Index("idx_sla_approval_source_approval_id", ["source_approval_id"])
12
+ @Index("idx_sla_approval_service_subservice", ["service_id", "sub_service_id"])
13
+ @Index("idx_sla_approval_approval_status", ["approval_status"])
14
+ @Index("idx_sla_approval_level", ["level"])
15
+ @Index("idx_sla_approval_approver_user_id", ["approver_user_id"])
16
+ @Index("idx_sla_approval_request_level", ["request_id", "level"])
17
+ @Index("idx_sla_approval_svc_sub_status", ["service_id", "sub_service_id", "approval_status"])
18
+ export class ServiceSlaApproval extends BaseModel {
19
+ @Column({ type: "int" })
20
+ request_id: number;
21
+
22
+ @Column({ type: "int" })
23
+ source_approval_id: number;
24
+
25
+ @Column({ type: "int", nullable: true })
26
+ service_id: number | null;
27
+
28
+ @Column({ type: "int", nullable: true })
29
+ sub_service_id: number | null;
30
+
31
+ @Column({ type: "varchar", length: 64 })
32
+ approval_status: string;
33
+
34
+ @Column({ type: "int" })
35
+ level: number;
36
+
37
+ @Column({ type: "int", nullable: true })
38
+ approver_user_id: number | null;
39
+
40
+ @Column({ type: "int", nullable: true })
41
+ approver_role_id: number | null;
42
+
43
+ @Column({ type: "int", nullable: true })
44
+ department_id: number | null;
45
+
46
+ @Column({ type: "int", nullable: true })
47
+ section_id: number | null;
48
+
49
+ /** Mirrors native approval `delegate_user_id` (IT master tables may use `delegation_user_id`). */
50
+ @Column({ type: "int", nullable: true })
51
+ delegate_user_id: number | null;
52
+
53
+ /** Mirrors native approval `approved_by` (acting user when status was last resolved). */
54
+ @Column({ type: "int", nullable: true })
55
+ approved_by: number | null;
56
+
57
+ /** Mirrors native approval comment / rejection reason. */
58
+ @Column({ type: "varchar", length: 255, nullable: true })
59
+ comment: string | null;
60
+
61
+ constructor() {
62
+ super();
63
+ }
64
+ }
@@ -1,55 +1,55 @@
1
- import { Column, Entity } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
-
4
- export enum ServicesNotificationTriggerType {
5
- FINAL_APPROVAL = "final_approval",
6
- EVERY_APPROVAL = "every_approval"
7
- }
8
-
9
- @Entity({ name: "services_notification_configs" })
10
- export class ServicesNotificationConfigs extends BaseModel {
11
- @Column({ type: "integer", nullable: false })
12
- service_id: number;
13
-
14
- @Column({ type: "integer", nullable: false })
15
- sub_service_id: number;
16
-
17
- @Column({ type: "integer", nullable: false })
18
- department_id: number;
19
-
20
- @Column({ type: "integer", nullable: true })
21
- section_id: number | null;
22
-
23
- @Column({ type: "integer", nullable: true })
24
- role_id: number | null;
25
-
26
- @Column({
27
- type: "enum",
28
- enum: ServicesNotificationTriggerType,
29
- nullable: false,
30
- default: ServicesNotificationTriggerType.FINAL_APPROVAL
31
- })
32
- trigger: ServicesNotificationTriggerType;
33
-
34
- @Column({ type: "boolean", nullable: false, default: true })
35
- is_active: boolean;
36
-
37
- constructor(
38
- service_id: number,
39
- sub_service_id: number,
40
- department_id: number,
41
- section_id: number | null = null,
42
- role_id: number | null = null,
43
- trigger: ServicesNotificationTriggerType = ServicesNotificationTriggerType.FINAL_APPROVAL,
44
- is_active: boolean = true
45
- ) {
46
- super();
47
- this.service_id = service_id;
48
- this.sub_service_id = sub_service_id;
49
- this.department_id = department_id;
50
- this.section_id = section_id;
51
- this.role_id = role_id;
52
- this.trigger = trigger;
53
- this.is_active = is_active;
54
- }
55
- }
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+
4
+ export enum ServicesNotificationTriggerType {
5
+ FINAL_APPROVAL = "final_approval",
6
+ EVERY_APPROVAL = "every_approval"
7
+ }
8
+
9
+ @Entity({ name: "services_notification_configs" })
10
+ export class ServicesNotificationConfigs extends BaseModel {
11
+ @Column({ type: "integer", nullable: false })
12
+ service_id: number;
13
+
14
+ @Column({ type: "integer", nullable: false })
15
+ sub_service_id: number;
16
+
17
+ @Column({ type: "integer", nullable: false })
18
+ department_id: number;
19
+
20
+ @Column({ type: "integer", nullable: true })
21
+ section_id: number | null;
22
+
23
+ @Column({ type: "integer", nullable: true })
24
+ role_id: number | null;
25
+
26
+ @Column({
27
+ type: "enum",
28
+ enum: ServicesNotificationTriggerType,
29
+ nullable: false,
30
+ default: ServicesNotificationTriggerType.FINAL_APPROVAL
31
+ })
32
+ trigger: ServicesNotificationTriggerType;
33
+
34
+ @Column({ type: "boolean", nullable: false, default: true })
35
+ is_active: boolean;
36
+
37
+ constructor(
38
+ service_id: number,
39
+ sub_service_id: number,
40
+ department_id: number,
41
+ section_id: number | null = null,
42
+ role_id: number | null = null,
43
+ trigger: ServicesNotificationTriggerType = ServicesNotificationTriggerType.FINAL_APPROVAL,
44
+ is_active: boolean = true
45
+ ) {
46
+ super();
47
+ this.service_id = service_id;
48
+ this.sub_service_id = sub_service_id;
49
+ this.department_id = department_id;
50
+ this.section_id = section_id;
51
+ this.role_id = role_id;
52
+ this.trigger = trigger;
53
+ this.is_active = is_active;
54
+ }
55
+ }
@@ -1,135 +1,135 @@
1
- import { ViewColumn, ViewEntity } from "typeorm";
2
-
3
- const VW_SLA_APPROVALS_SQL = `
4
- SELECT
5
- sa.id AS sla_approval_id,
6
- sa.source_approval_id,
7
- sa.request_id,
8
- sa.service_id AS service_id,
9
- sa.sub_service_id AS sub_service_id,
10
- TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
11
- TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
12
- sa.approver_role_id AS approval_role_id,
13
- TRIM(COALESCE(ar.name, ''))::TEXT AS approval_role_name,
14
- sa.department_id AS approval_department_id,
15
- TRIM(COALESCE(adpt.department_name, ''))::TEXT AS approval_department_name,
16
- sa.section_id AS approval_section_id,
17
- TRIM(COALESCE(asec.section_name, ''))::TEXT AS approval_section_name,
18
- sa.approval_status::TEXT AS approval_status,
19
- sr.status::TEXT AS request_status,
20
- sa.level AS level,
21
- sa.approver_user_id AS approver_user_id,
22
- TRIM(COALESCE(au.employee_name, ''))::TEXT AS approver_user_name,
23
- sa.delegate_user_id AS delegate_user_id,
24
- TRIM(COALESCE(du.employee_name, ''))::TEXT AS delegate_user_name,
25
- sa.approved_by AS approved_by,
26
- TRIM(COALESCE(ab.employee_name, ''))::TEXT AS approved_by_name,
27
- sa.comment::TEXT AS comment,
28
- sa.created_at AS created_at,
29
- sa.updated_at AS updated_at
30
- FROM sla_approval sa
31
- INNER JOIN sla_requests sr
32
- ON sr.request_id = sa.request_id AND COALESCE(sr.is_deleted, false) = false
33
- LEFT JOIN caa_services svc
34
- ON svc.id = sa.service_id AND COALESCE(svc.is_deleted, false) = false
35
- LEFT JOIN caa_sub_services subsvc
36
- ON subsvc.id = sa.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
37
- LEFT JOIN departments adpt
38
- ON adpt.id = sa.department_id AND COALESCE(adpt.is_deleted, false) = false
39
- LEFT JOIN sections asec
40
- ON asec.id = sa.section_id AND COALESCE(asec.is_deleted, false) = false
41
- LEFT JOIN role ar
42
- ON ar.id = sa.approver_role_id AND COALESCE(ar.is_deleted, false) = false
43
- LEFT JOIN users au
44
- ON au.id = sa.approver_user_id AND COALESCE(au.is_deleted, false) = false
45
- LEFT JOIN users du
46
- ON du.id = sa.delegate_user_id AND COALESCE(du.is_deleted, false) = false
47
- LEFT JOIN users ab
48
- ON ab.id = sa.approved_by AND COALESCE(ab.is_deleted, false) = false
49
- WHERE COALESCE(sa.is_deleted, false) = false
50
- `;
51
-
52
- /**
53
- * Read-only view for SLA approvals listings (TypeORM).
54
- * Approver matching (`sla_approval_matches_user` semantics) is applied in Reports_Service queries.
55
- */
56
- @ViewEntity({
57
- name: "vw_sla_approvals",
58
- expression: VW_SLA_APPROVALS_SQL,
59
- })
60
- export class SlaApprovalsView {
61
- @ViewColumn()
62
- sla_approval_id: number;
63
-
64
- @ViewColumn()
65
- source_approval_id: number;
66
-
67
- @ViewColumn()
68
- request_id: number;
69
-
70
- @ViewColumn()
71
- service_id: number;
72
-
73
- @ViewColumn()
74
- sub_service_id: number;
75
-
76
- @ViewColumn()
77
- service_name: string;
78
-
79
- @ViewColumn()
80
- sub_service_name: string;
81
-
82
- @ViewColumn()
83
- approval_role_id: number;
84
-
85
- @ViewColumn()
86
- approval_role_name: string;
87
-
88
- @ViewColumn()
89
- approval_department_id: number;
90
-
91
- @ViewColumn()
92
- approval_department_name: string;
93
-
94
- @ViewColumn()
95
- approval_section_id: number;
96
-
97
- @ViewColumn()
98
- approval_section_name: string;
99
-
100
- @ViewColumn()
101
- approval_status: string;
102
-
103
- @ViewColumn()
104
- request_status: string;
105
-
106
- @ViewColumn()
107
- level: number;
108
-
109
- @ViewColumn()
110
- approver_user_id: number;
111
-
112
- @ViewColumn()
113
- approver_user_name: string;
114
-
115
- @ViewColumn()
116
- delegate_user_id: number;
117
-
118
- @ViewColumn()
119
- delegate_user_name: string;
120
-
121
- @ViewColumn()
122
- approved_by: number;
123
-
124
- @ViewColumn()
125
- approved_by_name: string;
126
-
127
- @ViewColumn()
128
- comment: string;
129
-
130
- @ViewColumn()
131
- created_at: Date;
132
-
133
- @ViewColumn()
134
- updated_at: Date;
135
- }
1
+ import { ViewColumn, ViewEntity } from "typeorm";
2
+
3
+ const VW_SLA_APPROVALS_SQL = `
4
+ SELECT
5
+ sa.id AS sla_approval_id,
6
+ sa.source_approval_id,
7
+ sa.request_id,
8
+ sa.service_id AS service_id,
9
+ sa.sub_service_id AS sub_service_id,
10
+ TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
11
+ TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
12
+ sa.approver_role_id AS approval_role_id,
13
+ TRIM(COALESCE(ar.name, ''))::TEXT AS approval_role_name,
14
+ sa.department_id AS approval_department_id,
15
+ TRIM(COALESCE(adpt.department_name, ''))::TEXT AS approval_department_name,
16
+ sa.section_id AS approval_section_id,
17
+ TRIM(COALESCE(asec.section_name, ''))::TEXT AS approval_section_name,
18
+ sa.approval_status::TEXT AS approval_status,
19
+ sr.status::TEXT AS request_status,
20
+ sa.level AS level,
21
+ sa.approver_user_id AS approver_user_id,
22
+ TRIM(COALESCE(au.employee_name, ''))::TEXT AS approver_user_name,
23
+ sa.delegate_user_id AS delegate_user_id,
24
+ TRIM(COALESCE(du.employee_name, ''))::TEXT AS delegate_user_name,
25
+ sa.approved_by AS approved_by,
26
+ TRIM(COALESCE(ab.employee_name, ''))::TEXT AS approved_by_name,
27
+ sa.comment::TEXT AS comment,
28
+ sa.created_at AS created_at,
29
+ sa.updated_at AS updated_at
30
+ FROM sla_approval sa
31
+ INNER JOIN sla_requests sr
32
+ ON sr.request_id = sa.request_id AND COALESCE(sr.is_deleted, false) = false
33
+ LEFT JOIN caa_services svc
34
+ ON svc.id = sa.service_id AND COALESCE(svc.is_deleted, false) = false
35
+ LEFT JOIN caa_sub_services subsvc
36
+ ON subsvc.id = sa.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
37
+ LEFT JOIN departments adpt
38
+ ON adpt.id = sa.department_id AND COALESCE(adpt.is_deleted, false) = false
39
+ LEFT JOIN sections asec
40
+ ON asec.id = sa.section_id AND COALESCE(asec.is_deleted, false) = false
41
+ LEFT JOIN role ar
42
+ ON ar.id = sa.approver_role_id AND COALESCE(ar.is_deleted, false) = false
43
+ LEFT JOIN users au
44
+ ON au.id = sa.approver_user_id AND COALESCE(au.is_deleted, false) = false
45
+ LEFT JOIN users du
46
+ ON du.id = sa.delegate_user_id AND COALESCE(du.is_deleted, false) = false
47
+ LEFT JOIN users ab
48
+ ON ab.id = sa.approved_by AND COALESCE(ab.is_deleted, false) = false
49
+ WHERE COALESCE(sa.is_deleted, false) = false
50
+ `;
51
+
52
+ /**
53
+ * Read-only view for SLA approvals listings (TypeORM).
54
+ * Approver matching (`sla_approval_matches_user` semantics) is applied in Reports_Service queries.
55
+ */
56
+ @ViewEntity({
57
+ name: "vw_sla_approvals",
58
+ expression: VW_SLA_APPROVALS_SQL,
59
+ })
60
+ export class SlaApprovalsView {
61
+ @ViewColumn()
62
+ sla_approval_id: number;
63
+
64
+ @ViewColumn()
65
+ source_approval_id: number;
66
+
67
+ @ViewColumn()
68
+ request_id: number;
69
+
70
+ @ViewColumn()
71
+ service_id: number;
72
+
73
+ @ViewColumn()
74
+ sub_service_id: number;
75
+
76
+ @ViewColumn()
77
+ service_name: string;
78
+
79
+ @ViewColumn()
80
+ sub_service_name: string;
81
+
82
+ @ViewColumn()
83
+ approval_role_id: number;
84
+
85
+ @ViewColumn()
86
+ approval_role_name: string;
87
+
88
+ @ViewColumn()
89
+ approval_department_id: number;
90
+
91
+ @ViewColumn()
92
+ approval_department_name: string;
93
+
94
+ @ViewColumn()
95
+ approval_section_id: number;
96
+
97
+ @ViewColumn()
98
+ approval_section_name: string;
99
+
100
+ @ViewColumn()
101
+ approval_status: string;
102
+
103
+ @ViewColumn()
104
+ request_status: string;
105
+
106
+ @ViewColumn()
107
+ level: number;
108
+
109
+ @ViewColumn()
110
+ approver_user_id: number;
111
+
112
+ @ViewColumn()
113
+ approver_user_name: string;
114
+
115
+ @ViewColumn()
116
+ delegate_user_id: number;
117
+
118
+ @ViewColumn()
119
+ delegate_user_name: string;
120
+
121
+ @ViewColumn()
122
+ approved_by: number;
123
+
124
+ @ViewColumn()
125
+ approved_by_name: string;
126
+
127
+ @ViewColumn()
128
+ comment: string;
129
+
130
+ @ViewColumn()
131
+ created_at: Date;
132
+
133
+ @ViewColumn()
134
+ updated_at: Date;
135
+ }