@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.
- package/dist/data-source.js +2 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/models/SlaApprovalsViewModel.d.ts +16 -11
- package/dist/models/SlaApprovalsViewModel.js +61 -57
- package/package.json +1 -1
- package/sql/vw_sla_approvals.sql +54 -0
- package/src/data-source.ts +2 -0
- package/src/index.ts +1 -0
- package/src/models/SlaApprovalsViewModel.ts +135 -0
package/dist/data-source.js
CHANGED
|
@@ -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
|
|
6
|
-
sub_service_id: number
|
|
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
|
|
22
|
+
approver_user_id: number;
|
|
13
23
|
approver_user_name: string;
|
|
14
|
-
delegate_user_id: number
|
|
24
|
+
delegate_user_id: number;
|
|
15
25
|
delegate_user_name: string;
|
|
16
|
-
approved_by: number
|
|
26
|
+
approved_by: number;
|
|
17
27
|
approved_by_name: string;
|
|
18
|
-
comment: string
|
|
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.
|
|
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
|
-
|
|
34
|
-
|
|
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
|
|
54
|
-
|
|
55
|
-
LEFT JOIN
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
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",
|
|
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",
|
|
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",
|
|
100
|
-
], SlaApprovalsView.prototype, "
|
|
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, "
|
|
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, "
|
|
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, "
|
|
112
|
+
], SlaApprovalsView.prototype, "approval_department_name", void 0);
|
|
117
113
|
__decorate([
|
|
118
114
|
(0, typeorm_1.ViewColumn)(),
|
|
119
|
-
__metadata("design:type",
|
|
120
|
-
], SlaApprovalsView.prototype, "
|
|
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, "
|
|
120
|
+
], SlaApprovalsView.prototype, "approval_section_name", void 0);
|
|
125
121
|
__decorate([
|
|
126
122
|
(0, typeorm_1.ViewColumn)(),
|
|
127
|
-
__metadata("design:type",
|
|
128
|
-
], SlaApprovalsView.prototype, "
|
|
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, "
|
|
128
|
+
], SlaApprovalsView.prototype, "request_status", void 0);
|
|
133
129
|
__decorate([
|
|
134
130
|
(0, typeorm_1.ViewColumn)(),
|
|
135
|
-
__metadata("design:type",
|
|
136
|
-
], SlaApprovalsView.prototype, "
|
|
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, "
|
|
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, "
|
|
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, "
|
|
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, "
|
|
156
|
+
], SlaApprovalsView.prototype, "approved_by_name", void 0);
|
|
153
157
|
__decorate([
|
|
154
158
|
(0, typeorm_1.ViewColumn)(),
|
|
155
|
-
__metadata("design:type",
|
|
156
|
-
], SlaApprovalsView.prototype, "
|
|
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
|
@@ -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;
|
package/src/data-source.ts
CHANGED
|
@@ -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
|
+
}
|