@platform-modules/civil-aviation-authority 2.3.259 → 2.3.261

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.
@@ -252,6 +252,7 @@ const MediaPublicationsChatModel_1 = require("./models/MediaPublicationsChatMode
252
252
  const MediaPublicationsWorkflowModel_1 = require("./models/MediaPublicationsWorkflowModel");
253
253
  const SlaRequestModel_1 = require("./models/SlaRequestModel");
254
254
  const SlaMyRequestsViewModel_1 = require("./models/SlaMyRequestsViewModel");
255
+ const SlaApprovalsViewModel_1 = require("./models/SlaApprovalsViewModel");
255
256
  const ServiceSlaApprovalModel_1 = require("./models/ServiceSlaApprovalModel");
256
257
  const SlaConfigModel_1 = require("./models/SlaConfigModel");
257
258
  exports.AppDataSource = new typeorm_1.DataSource({
@@ -510,6 +511,7 @@ exports.AppDataSource = new typeorm_1.DataSource({
510
511
  MediaPublicationsWorkflowModel_1.MediaPublicationsWorkFlow,
511
512
  SlaRequestModel_1.SlaRequest,
512
513
  SlaMyRequestsViewModel_1.SlaMyRequestsView,
514
+ SlaApprovalsViewModel_1.SlaApprovalsView,
513
515
  ServiceSlaApprovalModel_1.ServiceSlaApproval,
514
516
  SlaConfigModel_1.SlaConfig,
515
517
  ],
package/dist/index.d.ts CHANGED
@@ -402,6 +402,7 @@ export * from './models/ContractServiceRequestModel';
402
402
  export * from './models/SlaConfigModel';
403
403
  export * from './models/SlaRequestModel';
404
404
  export * from './models/SlaMyRequestsViewModel';
405
+ export * from './models/SlaApprovalsViewModel';
405
406
  export * from './models/ServiceSlaApprovalModel';
406
407
  export * from './sla/sla-table-sync.service';
407
408
  export * from './sla/sla-approval-mirror';
package/dist/index.js CHANGED
@@ -591,6 +591,7 @@ __exportStar(require("./models/ContractServiceRequestModel"), exports);
591
591
  __exportStar(require("./models/SlaConfigModel"), exports);
592
592
  __exportStar(require("./models/SlaRequestModel"), exports);
593
593
  __exportStar(require("./models/SlaMyRequestsViewModel"), exports);
594
+ __exportStar(require("./models/SlaApprovalsViewModel"), exports);
594
595
  __exportStar(require("./models/ServiceSlaApprovalModel"), exports);
595
596
  __exportStar(require("./sla/sla-table-sync.service"), exports);
596
597
  __exportStar(require("./sla/sla-approval-mirror"), exports);
@@ -1,26 +1,31 @@
1
+ /**
2
+ * Read-only view for SLA approvals listings (TypeORM).
3
+ * Approver matching (`sla_approval_matches_user` semantics) is applied in Reports_Service queries.
4
+ */
1
5
  export declare class SlaApprovalsView {
2
6
  sla_approval_id: number;
3
7
  source_approval_id: number;
4
8
  request_id: number;
5
- service_id: number | null;
6
- sub_service_id: number | null;
9
+ service_id: number;
10
+ sub_service_id: number;
7
11
  service_name: string;
8
12
  sub_service_name: string;
13
+ approval_role_id: number;
14
+ approval_role_name: string;
15
+ approval_department_id: number;
16
+ approval_department_name: string;
17
+ approval_section_id: number;
18
+ approval_section_name: string;
9
19
  approval_status: string;
10
20
  request_status: string;
11
21
  level: number;
12
- approver_user_id: number | null;
22
+ approver_user_id: number;
13
23
  approver_user_name: string;
14
- delegate_user_id: number | null;
24
+ delegate_user_id: number;
15
25
  delegate_user_name: string;
16
- approved_by: number | null;
26
+ approved_by: number;
17
27
  approved_by_name: string;
18
- comment: string | null;
19
- requester_user_id: number;
20
- requester_name: string;
21
- department_name: string;
22
- section_name: string;
23
- request_fields: Record<string, unknown>;
28
+ comment: string;
24
29
  created_at: Date;
25
30
  updated_at: Date;
26
31
  }
@@ -16,33 +16,28 @@ SELECT
16
16
  sa.id AS sla_approval_id,
17
17
  sa.source_approval_id,
18
18
  sa.request_id,
19
- sa.service_id,
20
- sa.sub_service_id,
19
+ sa.service_id AS service_id,
20
+ sa.sub_service_id AS sub_service_id,
21
21
  TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
22
22
  TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
23
- sa.approval_status,
23
+ sa.approver_role_id AS approval_role_id,
24
+ TRIM(COALESCE(ar.name, ''))::TEXT AS approval_role_name,
25
+ sa.department_id AS approval_department_id,
26
+ TRIM(COALESCE(adpt.department_name, ''))::TEXT AS approval_department_name,
27
+ sa.section_id AS approval_section_id,
28
+ TRIM(COALESCE(asec.section_name, ''))::TEXT AS approval_section_name,
29
+ sa.approval_status::TEXT AS approval_status,
24
30
  sr.status::TEXT AS request_status,
25
- sa.level,
26
- sa.approver_user_id,
31
+ sa.level AS level,
32
+ sa.approver_user_id AS approver_user_id,
27
33
  TRIM(COALESCE(au.employee_name, ''))::TEXT AS approver_user_name,
28
- sa.delegate_user_id,
34
+ sa.delegate_user_id AS delegate_user_id,
29
35
  TRIM(COALESCE(du.employee_name, ''))::TEXT AS delegate_user_name,
30
- sa.approved_by,
36
+ sa.approved_by AS approved_by,
31
37
  TRIM(COALESCE(ab.employee_name, ''))::TEXT AS approved_by_name,
32
- sa.comment,
33
- sr.user_id AS requester_user_id,
34
- TRIM(COALESCE(ru.employee_name, ''))::TEXT AS requester_name,
35
- TRIM(COALESCE(dept.department_name, ''))::TEXT AS department_name,
36
- TRIM(COALESCE(sec.section_name, ''))::TEXT AS section_name,
37
- (
38
- COALESCE(sr.request_obj, '{}'::jsonb)
39
- - 'id' - 'status' - 'role_id' - 'user_id' - 'createdBy' - 'created_at'
40
- - 'updated_by' - 'updated_at' - 'req_user_department_id' - 'workflow_execution_id'
41
- - 'department_id' - 'req_user_section_id' - 'service_type_id' - 'service_type'
42
- - 'created_by' - 'service_id' - 'sub_service_id' - 'attachments'
43
- ) AS request_fields,
44
- sa.created_at,
45
- sa.updated_at
38
+ sa.comment::TEXT AS comment,
39
+ sa.created_at AS created_at,
40
+ sa.updated_at AS updated_at
46
41
  FROM sla_approval sa
47
42
  INNER JOIN sla_requests sr
48
43
  ON sr.request_id = sa.request_id AND COALESCE(sr.is_deleted, false) = false
@@ -50,19 +45,24 @@ LEFT JOIN caa_services svc
50
45
  ON svc.id = sa.service_id AND COALESCE(svc.is_deleted, false) = false
51
46
  LEFT JOIN caa_sub_services subsvc
52
47
  ON subsvc.id = sa.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
53
- LEFT JOIN users au ON au.id = sa.approver_user_id
54
- LEFT JOIN users du ON du.id = sa.delegate_user_id
55
- LEFT JOIN users ab ON ab.id = sa.approved_by
56
- LEFT JOIN users ru
57
- ON ru.id = sr.user_id AND COALESCE(ru.is_deleted, false) = false
58
- LEFT JOIN departments dept
59
- ON dept.id = sr.req_user_department_id AND COALESCE(dept.is_deleted, false) = false
60
- LEFT JOIN sections sec
61
- ON sec.id = sr.req_user_section_id AND COALESCE(sec.is_deleted, false) = false
48
+ LEFT JOIN departments adpt
49
+ ON adpt.id = sa.department_id AND COALESCE(adpt.is_deleted, false) = false
50
+ LEFT JOIN sections asec
51
+ ON asec.id = sa.section_id AND COALESCE(asec.is_deleted, false) = false
52
+ LEFT JOIN role ar
53
+ ON ar.id = sa.approver_role_id AND COALESCE(ar.is_deleted, false) = false
54
+ LEFT JOIN users au
55
+ ON au.id = sa.approver_user_id AND COALESCE(au.is_deleted, false) = false
56
+ LEFT JOIN users du
57
+ ON du.id = sa.delegate_user_id AND COALESCE(du.is_deleted, false) = false
58
+ LEFT JOIN users ab
59
+ ON ab.id = sa.approved_by AND COALESCE(ab.is_deleted, false) = false
62
60
  WHERE COALESCE(sa.is_deleted, false) = false
63
- AND (sa.service_id = sr.service_id OR sa.service_id IS NULL)
64
- AND (sa.sub_service_id = sr.sub_service_id OR sa.sub_service_id IS NULL)
65
61
  `;
62
+ /**
63
+ * Read-only view for SLA approvals listings (TypeORM).
64
+ * Approver matching (`sla_approval_matches_user` semantics) is applied in Reports_Service queries.
65
+ */
66
66
  let SlaApprovalsView = class SlaApprovalsView {
67
67
  };
68
68
  exports.SlaApprovalsView = SlaApprovalsView;
@@ -80,11 +80,11 @@ __decorate([
80
80
  ], SlaApprovalsView.prototype, "request_id", void 0);
81
81
  __decorate([
82
82
  (0, typeorm_1.ViewColumn)(),
83
- __metadata("design:type", Object)
83
+ __metadata("design:type", Number)
84
84
  ], SlaApprovalsView.prototype, "service_id", void 0);
85
85
  __decorate([
86
86
  (0, typeorm_1.ViewColumn)(),
87
- __metadata("design:type", Object)
87
+ __metadata("design:type", Number)
88
88
  ], SlaApprovalsView.prototype, "sub_service_id", void 0);
89
89
  __decorate([
90
90
  (0, typeorm_1.ViewColumn)(),
@@ -96,64 +96,68 @@ __decorate([
96
96
  ], SlaApprovalsView.prototype, "sub_service_name", void 0);
97
97
  __decorate([
98
98
  (0, typeorm_1.ViewColumn)(),
99
- __metadata("design:type", String)
100
- ], SlaApprovalsView.prototype, "approval_status", void 0);
99
+ __metadata("design:type", Number)
100
+ ], SlaApprovalsView.prototype, "approval_role_id", void 0);
101
101
  __decorate([
102
102
  (0, typeorm_1.ViewColumn)(),
103
103
  __metadata("design:type", String)
104
- ], SlaApprovalsView.prototype, "request_status", void 0);
104
+ ], SlaApprovalsView.prototype, "approval_role_name", void 0);
105
105
  __decorate([
106
106
  (0, typeorm_1.ViewColumn)(),
107
107
  __metadata("design:type", Number)
108
- ], SlaApprovalsView.prototype, "level", void 0);
109
- __decorate([
110
- (0, typeorm_1.ViewColumn)(),
111
- __metadata("design:type", Object)
112
- ], SlaApprovalsView.prototype, "approver_user_id", void 0);
108
+ ], SlaApprovalsView.prototype, "approval_department_id", void 0);
113
109
  __decorate([
114
110
  (0, typeorm_1.ViewColumn)(),
115
111
  __metadata("design:type", String)
116
- ], SlaApprovalsView.prototype, "approver_user_name", void 0);
112
+ ], SlaApprovalsView.prototype, "approval_department_name", void 0);
117
113
  __decorate([
118
114
  (0, typeorm_1.ViewColumn)(),
119
- __metadata("design:type", Object)
120
- ], SlaApprovalsView.prototype, "delegate_user_id", void 0);
115
+ __metadata("design:type", Number)
116
+ ], SlaApprovalsView.prototype, "approval_section_id", void 0);
121
117
  __decorate([
122
118
  (0, typeorm_1.ViewColumn)(),
123
119
  __metadata("design:type", String)
124
- ], SlaApprovalsView.prototype, "delegate_user_name", void 0);
120
+ ], SlaApprovalsView.prototype, "approval_section_name", void 0);
125
121
  __decorate([
126
122
  (0, typeorm_1.ViewColumn)(),
127
- __metadata("design:type", Object)
128
- ], SlaApprovalsView.prototype, "approved_by", void 0);
123
+ __metadata("design:type", String)
124
+ ], SlaApprovalsView.prototype, "approval_status", void 0);
129
125
  __decorate([
130
126
  (0, typeorm_1.ViewColumn)(),
131
127
  __metadata("design:type", String)
132
- ], SlaApprovalsView.prototype, "approved_by_name", void 0);
128
+ ], SlaApprovalsView.prototype, "request_status", void 0);
133
129
  __decorate([
134
130
  (0, typeorm_1.ViewColumn)(),
135
- __metadata("design:type", Object)
136
- ], SlaApprovalsView.prototype, "comment", void 0);
131
+ __metadata("design:type", Number)
132
+ ], SlaApprovalsView.prototype, "level", void 0);
137
133
  __decorate([
138
134
  (0, typeorm_1.ViewColumn)(),
139
135
  __metadata("design:type", Number)
140
- ], SlaApprovalsView.prototype, "requester_user_id", void 0);
136
+ ], SlaApprovalsView.prototype, "approver_user_id", void 0);
141
137
  __decorate([
142
138
  (0, typeorm_1.ViewColumn)(),
143
139
  __metadata("design:type", String)
144
- ], SlaApprovalsView.prototype, "requester_name", void 0);
140
+ ], SlaApprovalsView.prototype, "approver_user_name", void 0);
141
+ __decorate([
142
+ (0, typeorm_1.ViewColumn)(),
143
+ __metadata("design:type", Number)
144
+ ], SlaApprovalsView.prototype, "delegate_user_id", void 0);
145
145
  __decorate([
146
146
  (0, typeorm_1.ViewColumn)(),
147
147
  __metadata("design:type", String)
148
- ], SlaApprovalsView.prototype, "department_name", void 0);
148
+ ], SlaApprovalsView.prototype, "delegate_user_name", void 0);
149
+ __decorate([
150
+ (0, typeorm_1.ViewColumn)(),
151
+ __metadata("design:type", Number)
152
+ ], SlaApprovalsView.prototype, "approved_by", void 0);
149
153
  __decorate([
150
154
  (0, typeorm_1.ViewColumn)(),
151
155
  __metadata("design:type", String)
152
- ], SlaApprovalsView.prototype, "section_name", void 0);
156
+ ], SlaApprovalsView.prototype, "approved_by_name", void 0);
153
157
  __decorate([
154
158
  (0, typeorm_1.ViewColumn)(),
155
- __metadata("design:type", Object)
156
- ], SlaApprovalsView.prototype, "request_fields", void 0);
159
+ __metadata("design:type", String)
160
+ ], SlaApprovalsView.prototype, "comment", void 0);
157
161
  __decorate([
158
162
  (0, typeorm_1.ViewColumn)(),
159
163
  __metadata("design:type", Date)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@platform-modules/civil-aviation-authority",
3
- "version": "2.3.259",
3
+ "version": "2.3.261",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "scripts": {
@@ -0,0 +1,54 @@
1
+ -- SLA approvals read model: joined display names for approval routing.
2
+ -- Approver-scope filtering is applied in Reports_Service (TypeORM), not in this view.
3
+ -- Run once against the EmpPortal PostgreSQL database:
4
+ -- psql -U <user> -d <database> -f sql/vw_sla_approvals.sql
5
+
6
+ DROP VIEW IF EXISTS vw_sla_approvals CASCADE;
7
+
8
+ CREATE VIEW vw_sla_approvals AS
9
+ SELECT
10
+ sa.id AS sla_approval_id,
11
+ sa.source_approval_id,
12
+ sa.request_id,
13
+ sa.service_id AS service_id,
14
+ sa.sub_service_id AS sub_service_id,
15
+ TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
16
+ TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
17
+ sa.approver_role_id AS approval_role_id,
18
+ TRIM(COALESCE(ar.name, ''))::TEXT AS approval_role_name,
19
+ sa.department_id AS approval_department_id,
20
+ TRIM(COALESCE(adpt.department_name, ''))::TEXT AS approval_department_name,
21
+ sa.section_id AS approval_section_id,
22
+ TRIM(COALESCE(asec.section_name, ''))::TEXT AS approval_section_name,
23
+ sa.approval_status::TEXT AS approval_status,
24
+ sr.status::TEXT AS request_status,
25
+ sa.level AS level,
26
+ sa.approver_user_id AS approver_user_id,
27
+ TRIM(COALESCE(au.employee_name, ''))::TEXT AS approver_user_name,
28
+ sa.delegate_user_id AS delegate_user_id,
29
+ TRIM(COALESCE(du.employee_name, ''))::TEXT AS delegate_user_name,
30
+ sa.approved_by AS approved_by,
31
+ TRIM(COALESCE(ab.employee_name, ''))::TEXT AS approved_by_name,
32
+ sa.comment::TEXT AS comment,
33
+ sa.created_at AS created_at,
34
+ sa.updated_at AS updated_at
35
+ FROM sla_approval sa
36
+ INNER JOIN sla_requests sr
37
+ ON sr.request_id = sa.request_id AND COALESCE(sr.is_deleted, false) = false
38
+ LEFT JOIN caa_services svc
39
+ ON svc.id = sa.service_id AND COALESCE(svc.is_deleted, false) = false
40
+ LEFT JOIN caa_sub_services subsvc
41
+ ON subsvc.id = sa.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
42
+ LEFT JOIN departments adpt
43
+ ON adpt.id = sa.department_id AND COALESCE(adpt.is_deleted, false) = false
44
+ LEFT JOIN sections asec
45
+ ON asec.id = sa.section_id AND COALESCE(asec.is_deleted, false) = false
46
+ LEFT JOIN role ar
47
+ ON ar.id = sa.approver_role_id AND COALESCE(ar.is_deleted, false) = false
48
+ LEFT JOIN users au
49
+ ON au.id = sa.approver_user_id AND COALESCE(au.is_deleted, false) = false
50
+ LEFT JOIN users du
51
+ ON du.id = sa.delegate_user_id AND COALESCE(du.is_deleted, false) = false
52
+ LEFT JOIN users ab
53
+ ON ab.id = sa.approved_by AND COALESCE(ab.is_deleted, false) = false
54
+ WHERE COALESCE(sa.is_deleted, false) = false;
@@ -250,6 +250,7 @@ import { MediaPublicationsChat } from './models/MediaPublicationsChatModel';
250
250
  import { MediaPublicationsWorkFlow } from './models/MediaPublicationsWorkflowModel';
251
251
  import { SlaRequest } from './models/SlaRequestModel';
252
252
  import { SlaMyRequestsView } from './models/SlaMyRequestsViewModel';
253
+ import { SlaApprovalsView } from './models/SlaApprovalsViewModel';
253
254
  import { ServiceSlaApproval } from './models/ServiceSlaApprovalModel';
254
255
  import { SlaConfig } from './models/SlaConfigModel';
255
256
 
@@ -509,6 +510,7 @@ export const AppDataSource = new DataSource({
509
510
  MediaPublicationsWorkFlow,
510
511
  SlaRequest,
511
512
  SlaMyRequestsView,
513
+ SlaApprovalsView,
512
514
  ServiceSlaApproval,
513
515
  SlaConfig,
514
516
  ],
package/src/index.ts CHANGED
@@ -490,6 +490,7 @@ export * from './models/RequestTenderAnalysisRequestModel';
490
490
  export * from './models/ContractServiceRequestModel';export * from './models/SlaConfigModel';
491
491
  export * from './models/SlaRequestModel';
492
492
  export * from './models/SlaMyRequestsViewModel';
493
+ export * from './models/SlaApprovalsViewModel';
493
494
  export * from './models/ServiceSlaApprovalModel';
494
495
  export * from './sla/sla-table-sync.service';
495
496
  export * from './sla/sla-approval-mirror';
@@ -0,0 +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
+ }