@platform-modules/foreign-ministry 1.3.321 → 1.3.322
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/.env +4 -11
- package/dist/data-source.js +4 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +2 -0
- package/dist/models/EmbassyEvaluationDepartmentSettingModel.d.ts +14 -0
- package/dist/models/EmbassyEvaluationDepartmentSettingModel.js +56 -0
- package/dist/models/EvaluationMastersModel.d.ts +16 -0
- package/dist/models/EvaluationMastersModel.js +67 -0
- package/dist/models/EvaluationQuestionMasterModel.d.ts +10 -0
- package/dist/models/EvaluationQuestionMasterModel.js +42 -0
- package/dist/models/EvaluationSectionMasterModel.d.ts +7 -0
- package/dist/models/EvaluationSectionMasterModel.js +36 -0
- package/dist/models/EvaluationWorkflowModel.d.ts +60 -0
- package/dist/models/EvaluationWorkflowModel.js +215 -0
- package/dist/models/IneligibleForEvaluationModel.d.ts +8 -0
- package/dist/models/IneligibleForEvaluationModel.js +44 -0
- package/dist/models/MissionTravelClassConfigModel.d.ts +10 -0
- package/dist/models/MissionTravelClassConfigModel.js +50 -0
- package/dist/models/MissionTravelPerdiemModel.d.ts +10 -0
- package/dist/models/MissionTravelPerdiemModel.js +54 -0
- package/dist/models/SlaApprovalsViewModel.d.ts +31 -0
- package/dist/models/SlaApprovalsViewModel.js +174 -0
- package/dist/models/SlaMyRequestsViewModel.d.ts +29 -0
- package/dist/models/SlaMyRequestsViewModel.js +176 -0
- package/dist/models/UuidAuditModel.d.ts +9 -0
- package/dist/models/UuidAuditModel.js +41 -0
- package/package.json +3 -2
- package/scripts/check-column-types.js +38 -0
- package/scripts/check-service-tables.js +42 -0
- package/scripts/sync-sla-reports-sql.js +95 -0
- package/sql/sla-reports-sync.manifest.json +7 -0
- package/sql/sla_reports_admin_procedures.sql +283 -0
- package/sql/sla_reports_approvals_workbook.sql +383 -0
- package/sql/sla_reports_procedures.sql +874 -0
- package/sql/vw_sla_approvals.sql +108 -0
- package/sql/vw_sla_my_requests.sql +55 -0
- package/src/data-source.ts +690 -686
- package/src/index.ts +600 -598
- package/src/models/DiplomaticAcademyRequestModel.ts +80 -80
- package/src/models/DocumentationFileModel.ts +40 -40
- package/src/models/EmbassyEvaluationCycleModel.ts +38 -38
- package/src/models/EmbassyEvaluationRequestModel.ts +59 -59
- package/src/models/EmployeeEvaluationAnswerModel.ts +26 -26
- package/src/models/EvaluationEligibilitySettingModel.ts +51 -51
- package/src/models/EvaluationFormModel.ts +44 -44
- package/src/models/LMSExternalEntityTrainedPersonModel.ts +45 -45
- package/src/models/LanguageCourseRequestModel.ts +67 -67
- package/src/models/LeaveApprovalsModel.ts +66 -66
- package/src/models/LeaveConfigModel.ts +71 -71
- package/src/models/MissionTravelApprovalModel.ts +101 -101
- package/src/models/MissionTravelAttachmentModel.ts +56 -56
- package/src/models/MissionTravelChatModel.ts +52 -52
- package/src/models/MissionTravelPersonModel.ts +105 -105
- package/src/models/MissionTravelWorkflowModel.ts +54 -54
- package/src/models/ProjectContactsModel.ts +51 -51
- package/src/models/ProjectFaqModel.ts +36 -36
- package/src/models/ProjectInvoicesModel.ts +41 -41
- package/src/models/ProjectModel.ts +75 -75
- package/src/models/ProjectTasksModel.ts +75 -75
- package/src/models/SectionModel.ts +35 -35
- package/src/models/ServiceSlaApprovalModel.ts +63 -63
- package/src/models/ServicesNotificationConfigsModel.ts +55 -55
- package/src/models/SlaApprovalsViewModel.ts +135 -0
- package/src/models/SlaMyRequestsViewModel.ts +172 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { BaseModel } from './BaseModel';
|
|
2
|
+
import { TravelClass } from './MissionTravelPersonModel';
|
|
3
|
+
export declare class MissionTravelClassConfig extends BaseModel {
|
|
4
|
+
grade: number | null;
|
|
5
|
+
position: string | null;
|
|
6
|
+
travel_class: TravelClass;
|
|
7
|
+
is_active: boolean;
|
|
8
|
+
description: string | null;
|
|
9
|
+
constructor(grade: number | null, position: string | null, travel_class: TravelClass, description: string | null);
|
|
10
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.MissionTravelClassConfig = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const BaseModel_1 = require("./BaseModel");
|
|
15
|
+
const MissionTravelPersonModel_1 = require("./MissionTravelPersonModel");
|
|
16
|
+
let MissionTravelClassConfig = class MissionTravelClassConfig extends BaseModel_1.BaseModel {
|
|
17
|
+
constructor(grade, position, travel_class, description) {
|
|
18
|
+
super();
|
|
19
|
+
this.grade = grade;
|
|
20
|
+
this.position = position;
|
|
21
|
+
this.travel_class = travel_class;
|
|
22
|
+
this.description = description;
|
|
23
|
+
this.is_active = true;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
exports.MissionTravelClassConfig = MissionTravelClassConfig;
|
|
27
|
+
__decorate([
|
|
28
|
+
(0, typeorm_1.Column)({ type: 'int', nullable: true }),
|
|
29
|
+
__metadata("design:type", Object)
|
|
30
|
+
], MissionTravelClassConfig.prototype, "grade", void 0);
|
|
31
|
+
__decorate([
|
|
32
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
|
|
33
|
+
__metadata("design:type", Object)
|
|
34
|
+
], MissionTravelClassConfig.prototype, "position", void 0);
|
|
35
|
+
__decorate([
|
|
36
|
+
(0, typeorm_1.Column)({ type: 'enum', enum: MissionTravelPersonModel_1.TravelClass, nullable: false }),
|
|
37
|
+
__metadata("design:type", String)
|
|
38
|
+
], MissionTravelClassConfig.prototype, "travel_class", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
(0, typeorm_1.Column)({ type: 'boolean', default: true }),
|
|
41
|
+
__metadata("design:type", Boolean)
|
|
42
|
+
], MissionTravelClassConfig.prototype, "is_active", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
45
|
+
__metadata("design:type", Object)
|
|
46
|
+
], MissionTravelClassConfig.prototype, "description", void 0);
|
|
47
|
+
exports.MissionTravelClassConfig = MissionTravelClassConfig = __decorate([
|
|
48
|
+
(0, typeorm_1.Entity)({ name: 'mission_travel_class_config' }),
|
|
49
|
+
__metadata("design:paramtypes", [Object, Object, String, Object])
|
|
50
|
+
], MissionTravelClassConfig);
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { BaseModel } from './BaseModel';
|
|
2
|
+
export declare class MissionTravelPerdiem extends BaseModel {
|
|
3
|
+
grade: number;
|
|
4
|
+
perdiem_amount: number;
|
|
5
|
+
currency: string | null;
|
|
6
|
+
effective_from: Date | null;
|
|
7
|
+
effective_to: Date | null;
|
|
8
|
+
is_active: boolean;
|
|
9
|
+
constructor(grade: number, perdiem_amount: number, currency: string | null, effective_from: Date | null, effective_to: Date | null);
|
|
10
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.MissionTravelPerdiem = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const BaseModel_1 = require("./BaseModel");
|
|
15
|
+
let MissionTravelPerdiem = class MissionTravelPerdiem extends BaseModel_1.BaseModel {
|
|
16
|
+
constructor(grade, perdiem_amount, currency, effective_from, effective_to) {
|
|
17
|
+
super();
|
|
18
|
+
this.grade = grade;
|
|
19
|
+
this.perdiem_amount = perdiem_amount;
|
|
20
|
+
this.currency = currency;
|
|
21
|
+
this.effective_from = effective_from;
|
|
22
|
+
this.effective_to = effective_to;
|
|
23
|
+
this.is_active = true;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
exports.MissionTravelPerdiem = MissionTravelPerdiem;
|
|
27
|
+
__decorate([
|
|
28
|
+
(0, typeorm_1.Column)({ type: 'int', nullable: false }),
|
|
29
|
+
__metadata("design:type", Number)
|
|
30
|
+
], MissionTravelPerdiem.prototype, "grade", void 0);
|
|
31
|
+
__decorate([
|
|
32
|
+
(0, typeorm_1.Column)({ type: 'decimal', precision: 10, scale: 2, nullable: false }),
|
|
33
|
+
__metadata("design:type", Number)
|
|
34
|
+
], MissionTravelPerdiem.prototype, "perdiem_amount", void 0);
|
|
35
|
+
__decorate([
|
|
36
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 50, nullable: true }),
|
|
37
|
+
__metadata("design:type", Object)
|
|
38
|
+
], MissionTravelPerdiem.prototype, "currency", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
(0, typeorm_1.Column)({ type: 'date', nullable: true }),
|
|
41
|
+
__metadata("design:type", Object)
|
|
42
|
+
], MissionTravelPerdiem.prototype, "effective_from", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, typeorm_1.Column)({ type: 'date', nullable: true }),
|
|
45
|
+
__metadata("design:type", Object)
|
|
46
|
+
], MissionTravelPerdiem.prototype, "effective_to", void 0);
|
|
47
|
+
__decorate([
|
|
48
|
+
(0, typeorm_1.Column)({ type: 'boolean', default: true }),
|
|
49
|
+
__metadata("design:type", Boolean)
|
|
50
|
+
], MissionTravelPerdiem.prototype, "is_active", void 0);
|
|
51
|
+
exports.MissionTravelPerdiem = MissionTravelPerdiem = __decorate([
|
|
52
|
+
(0, typeorm_1.Entity)({ name: 'mission_travel_perdiem' }),
|
|
53
|
+
__metadata("design:paramtypes", [Number, Number, Object, Object, Object])
|
|
54
|
+
], MissionTravelPerdiem);
|
|
@@ -0,0 +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
|
+
*/
|
|
5
|
+
export declare class SlaApprovalsView {
|
|
6
|
+
sla_approval_id: number;
|
|
7
|
+
source_approval_id: number;
|
|
8
|
+
request_id: number;
|
|
9
|
+
service_id: number;
|
|
10
|
+
sub_service_id: number;
|
|
11
|
+
service_name: string;
|
|
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;
|
|
19
|
+
approval_status: string;
|
|
20
|
+
request_status: string;
|
|
21
|
+
level: number;
|
|
22
|
+
approver_user_id: number;
|
|
23
|
+
approver_user_name: string;
|
|
24
|
+
delegate_user_id: number;
|
|
25
|
+
delegate_user_name: string;
|
|
26
|
+
approved_by: number;
|
|
27
|
+
approved_by_name: string;
|
|
28
|
+
comment: string;
|
|
29
|
+
created_at: Date;
|
|
30
|
+
updated_at: Date;
|
|
31
|
+
}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.SlaApprovalsView = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const VW_SLA_APPROVALS_SQL = `
|
|
15
|
+
SELECT
|
|
16
|
+
sa.id AS sla_approval_id,
|
|
17
|
+
sa.source_approval_id,
|
|
18
|
+
sa.request_id,
|
|
19
|
+
sa.service_id AS service_id,
|
|
20
|
+
sa.sub_service_id AS sub_service_id,
|
|
21
|
+
TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
|
|
22
|
+
TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
|
|
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,
|
|
30
|
+
sr.status::TEXT AS request_status,
|
|
31
|
+
sa.level AS level,
|
|
32
|
+
sa.approver_user_id AS approver_user_id,
|
|
33
|
+
TRIM(COALESCE(au.employee_name, ''))::TEXT AS approver_user_name,
|
|
34
|
+
sa.delegate_user_id AS delegate_user_id,
|
|
35
|
+
TRIM(COALESCE(du.employee_name, ''))::TEXT AS delegate_user_name,
|
|
36
|
+
sa.approved_by AS approved_by,
|
|
37
|
+
TRIM(COALESCE(ab.employee_name, ''))::TEXT AS approved_by_name,
|
|
38
|
+
sa.comment::TEXT AS comment,
|
|
39
|
+
sa.created_at AS created_at,
|
|
40
|
+
sa.updated_at AS updated_at
|
|
41
|
+
FROM sla_approval sa
|
|
42
|
+
INNER JOIN sla_requests sr
|
|
43
|
+
ON sr.request_id = sa.request_id AND COALESCE(sr.is_deleted, false) = false
|
|
44
|
+
LEFT JOIN fm_services svc
|
|
45
|
+
ON svc.id = sa.service_id AND COALESCE(svc.is_deleted, false) = false
|
|
46
|
+
LEFT JOIN fm_sub_services subsvc
|
|
47
|
+
ON subsvc.id = sa.sub_service_id AND COALESCE(subsvc.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
|
|
60
|
+
WHERE COALESCE(sa.is_deleted, false) = false
|
|
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
|
+
let SlaApprovalsView = class SlaApprovalsView {
|
|
67
|
+
};
|
|
68
|
+
exports.SlaApprovalsView = SlaApprovalsView;
|
|
69
|
+
__decorate([
|
|
70
|
+
(0, typeorm_1.ViewColumn)(),
|
|
71
|
+
__metadata("design:type", Number)
|
|
72
|
+
], SlaApprovalsView.prototype, "sla_approval_id", void 0);
|
|
73
|
+
__decorate([
|
|
74
|
+
(0, typeorm_1.ViewColumn)(),
|
|
75
|
+
__metadata("design:type", Number)
|
|
76
|
+
], SlaApprovalsView.prototype, "source_approval_id", void 0);
|
|
77
|
+
__decorate([
|
|
78
|
+
(0, typeorm_1.ViewColumn)(),
|
|
79
|
+
__metadata("design:type", Number)
|
|
80
|
+
], SlaApprovalsView.prototype, "request_id", void 0);
|
|
81
|
+
__decorate([
|
|
82
|
+
(0, typeorm_1.ViewColumn)(),
|
|
83
|
+
__metadata("design:type", Number)
|
|
84
|
+
], SlaApprovalsView.prototype, "service_id", void 0);
|
|
85
|
+
__decorate([
|
|
86
|
+
(0, typeorm_1.ViewColumn)(),
|
|
87
|
+
__metadata("design:type", Number)
|
|
88
|
+
], SlaApprovalsView.prototype, "sub_service_id", void 0);
|
|
89
|
+
__decorate([
|
|
90
|
+
(0, typeorm_1.ViewColumn)(),
|
|
91
|
+
__metadata("design:type", String)
|
|
92
|
+
], SlaApprovalsView.prototype, "service_name", void 0);
|
|
93
|
+
__decorate([
|
|
94
|
+
(0, typeorm_1.ViewColumn)(),
|
|
95
|
+
__metadata("design:type", String)
|
|
96
|
+
], SlaApprovalsView.prototype, "sub_service_name", void 0);
|
|
97
|
+
__decorate([
|
|
98
|
+
(0, typeorm_1.ViewColumn)(),
|
|
99
|
+
__metadata("design:type", Number)
|
|
100
|
+
], SlaApprovalsView.prototype, "approval_role_id", void 0);
|
|
101
|
+
__decorate([
|
|
102
|
+
(0, typeorm_1.ViewColumn)(),
|
|
103
|
+
__metadata("design:type", String)
|
|
104
|
+
], SlaApprovalsView.prototype, "approval_role_name", void 0);
|
|
105
|
+
__decorate([
|
|
106
|
+
(0, typeorm_1.ViewColumn)(),
|
|
107
|
+
__metadata("design:type", Number)
|
|
108
|
+
], SlaApprovalsView.prototype, "approval_department_id", void 0);
|
|
109
|
+
__decorate([
|
|
110
|
+
(0, typeorm_1.ViewColumn)(),
|
|
111
|
+
__metadata("design:type", String)
|
|
112
|
+
], SlaApprovalsView.prototype, "approval_department_name", void 0);
|
|
113
|
+
__decorate([
|
|
114
|
+
(0, typeorm_1.ViewColumn)(),
|
|
115
|
+
__metadata("design:type", Number)
|
|
116
|
+
], SlaApprovalsView.prototype, "approval_section_id", void 0);
|
|
117
|
+
__decorate([
|
|
118
|
+
(0, typeorm_1.ViewColumn)(),
|
|
119
|
+
__metadata("design:type", String)
|
|
120
|
+
], SlaApprovalsView.prototype, "approval_section_name", void 0);
|
|
121
|
+
__decorate([
|
|
122
|
+
(0, typeorm_1.ViewColumn)(),
|
|
123
|
+
__metadata("design:type", String)
|
|
124
|
+
], SlaApprovalsView.prototype, "approval_status", void 0);
|
|
125
|
+
__decorate([
|
|
126
|
+
(0, typeorm_1.ViewColumn)(),
|
|
127
|
+
__metadata("design:type", String)
|
|
128
|
+
], SlaApprovalsView.prototype, "request_status", void 0);
|
|
129
|
+
__decorate([
|
|
130
|
+
(0, typeorm_1.ViewColumn)(),
|
|
131
|
+
__metadata("design:type", Number)
|
|
132
|
+
], SlaApprovalsView.prototype, "level", void 0);
|
|
133
|
+
__decorate([
|
|
134
|
+
(0, typeorm_1.ViewColumn)(),
|
|
135
|
+
__metadata("design:type", Number)
|
|
136
|
+
], SlaApprovalsView.prototype, "approver_user_id", void 0);
|
|
137
|
+
__decorate([
|
|
138
|
+
(0, typeorm_1.ViewColumn)(),
|
|
139
|
+
__metadata("design:type", String)
|
|
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
|
+
__decorate([
|
|
146
|
+
(0, typeorm_1.ViewColumn)(),
|
|
147
|
+
__metadata("design:type", String)
|
|
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);
|
|
153
|
+
__decorate([
|
|
154
|
+
(0, typeorm_1.ViewColumn)(),
|
|
155
|
+
__metadata("design:type", String)
|
|
156
|
+
], SlaApprovalsView.prototype, "approved_by_name", void 0);
|
|
157
|
+
__decorate([
|
|
158
|
+
(0, typeorm_1.ViewColumn)(),
|
|
159
|
+
__metadata("design:type", String)
|
|
160
|
+
], SlaApprovalsView.prototype, "comment", void 0);
|
|
161
|
+
__decorate([
|
|
162
|
+
(0, typeorm_1.ViewColumn)(),
|
|
163
|
+
__metadata("design:type", Date)
|
|
164
|
+
], SlaApprovalsView.prototype, "created_at", void 0);
|
|
165
|
+
__decorate([
|
|
166
|
+
(0, typeorm_1.ViewColumn)(),
|
|
167
|
+
__metadata("design:type", Date)
|
|
168
|
+
], SlaApprovalsView.prototype, "updated_at", void 0);
|
|
169
|
+
exports.SlaApprovalsView = SlaApprovalsView = __decorate([
|
|
170
|
+
(0, typeorm_1.ViewEntity)({
|
|
171
|
+
name: "vw_sla_approvals",
|
|
172
|
+
expression: VW_SLA_APPROVALS_SQL,
|
|
173
|
+
})
|
|
174
|
+
], SlaApprovalsView);
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { SlaRequestStatus } from "./SlaRequestModel";
|
|
2
|
+
/** Top-level `request_obj` keys omitted from `request_fields` (see sql/vw_sla_my_requests.sql). */
|
|
3
|
+
export declare const SLA_MY_REQUESTS_REQUEST_OBJ_EXCLUDED_KEYS: readonly ["id", "status", "role_id", "user_id", "createdBy", "created_at", "updated_by", "updated_at", "req_user_department_id", "workflow_execution_id", "department_id", "req_user_section_id", "service_type_id", "service_type", "created_by", "service_id", "sub_service_id", "attachments", "is_deleted", "sla_request", "sla_request_id"];
|
|
4
|
+
/**
|
|
5
|
+
* Read-only view for SLA "my requests" listings.
|
|
6
|
+
* Display-name columns reuse sla_requests field names; values come from joined lookup tables.
|
|
7
|
+
* Service-specific payload keys live in `request_fields` (filtered `request_obj`).
|
|
8
|
+
*/
|
|
9
|
+
export declare class SlaMyRequestsView {
|
|
10
|
+
sla_request_id: number;
|
|
11
|
+
/** Request owner (`sla_requests.user_id`) — filter with WHERE user_id = :userId for "my requests". */
|
|
12
|
+
user_id: number;
|
|
13
|
+
/** Numeric fm_services.id used for filtering. */
|
|
14
|
+
service_id: number;
|
|
15
|
+
/** Numeric fm_sub_services.id used for filtering. */
|
|
16
|
+
sub_service_id: number;
|
|
17
|
+
created_by: string;
|
|
18
|
+
created_at: Date;
|
|
19
|
+
req_user_department_id: string;
|
|
20
|
+
req_user_section_id: string;
|
|
21
|
+
service_name: string;
|
|
22
|
+
sub_service_name: string;
|
|
23
|
+
status: SlaRequestStatus | string;
|
|
24
|
+
request_id: number;
|
|
25
|
+
/** Remaining `request_obj` keys after excluding workflow/common duplicates. */
|
|
26
|
+
request_fields: Record<string, unknown>;
|
|
27
|
+
}
|
|
28
|
+
/** Flatten view row: fixed columns plus each entry in `request_fields`. */
|
|
29
|
+
export declare function flattenSlaMyRequestsViewRow(row: SlaMyRequestsView): Record<string, unknown>;
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.SlaMyRequestsView = exports.SLA_MY_REQUESTS_REQUEST_OBJ_EXCLUDED_KEYS = void 0;
|
|
13
|
+
exports.flattenSlaMyRequestsViewRow = flattenSlaMyRequestsViewRow;
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
/** Top-level `request_obj` keys omitted from `request_fields` (see sql/vw_sla_my_requests.sql). */
|
|
16
|
+
exports.SLA_MY_REQUESTS_REQUEST_OBJ_EXCLUDED_KEYS = [
|
|
17
|
+
"id",
|
|
18
|
+
"status",
|
|
19
|
+
"role_id",
|
|
20
|
+
"user_id",
|
|
21
|
+
"createdBy",
|
|
22
|
+
"created_at",
|
|
23
|
+
"updated_by",
|
|
24
|
+
"updated_at",
|
|
25
|
+
"req_user_department_id",
|
|
26
|
+
"workflow_execution_id",
|
|
27
|
+
"department_id",
|
|
28
|
+
"req_user_section_id",
|
|
29
|
+
"service_type_id",
|
|
30
|
+
"service_type",
|
|
31
|
+
"created_by",
|
|
32
|
+
"service_id",
|
|
33
|
+
"sub_service_id",
|
|
34
|
+
"attachments",
|
|
35
|
+
"is_deleted",
|
|
36
|
+
"sla_request",
|
|
37
|
+
"sla_request_id",
|
|
38
|
+
];
|
|
39
|
+
const VW_SLA_MY_REQUESTS_SQL = `
|
|
40
|
+
SELECT
|
|
41
|
+
sr.id AS sla_request_id,
|
|
42
|
+
sr.user_id,
|
|
43
|
+
sr.service_id AS service_id,
|
|
44
|
+
sr.sub_service_id AS sub_service_id,
|
|
45
|
+
TRIM(COALESCE(creator.employee_name, ''))::TEXT AS created_by,
|
|
46
|
+
sr.created_at,
|
|
47
|
+
TRIM(COALESCE(dept.department_name, ''))::TEXT AS req_user_department_id,
|
|
48
|
+
TRIM(COALESCE(sec.section_name, ''))::TEXT AS req_user_section_id,
|
|
49
|
+
TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
|
|
50
|
+
TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
|
|
51
|
+
sr.status::TEXT AS status,
|
|
52
|
+
sr.request_id,
|
|
53
|
+
(
|
|
54
|
+
COALESCE(sr.request_obj, '{}'::jsonb)
|
|
55
|
+
- 'id'
|
|
56
|
+
- 'status'
|
|
57
|
+
- 'role_id'
|
|
58
|
+
- 'user_id'
|
|
59
|
+
- 'createdBy'
|
|
60
|
+
- 'created_at'
|
|
61
|
+
- 'updated_by'
|
|
62
|
+
- 'updated_at'
|
|
63
|
+
- 'req_user_department_id'
|
|
64
|
+
- 'workflow_execution_id'
|
|
65
|
+
- 'department_id'
|
|
66
|
+
- 'req_user_section_id'
|
|
67
|
+
- 'service_type_id'
|
|
68
|
+
- 'service_type'
|
|
69
|
+
- 'created_by'
|
|
70
|
+
- 'service_id'
|
|
71
|
+
- 'sub_service_id'
|
|
72
|
+
- 'attachments'
|
|
73
|
+
- 'is_deleted'
|
|
74
|
+
- 'sla_request'
|
|
75
|
+
- 'sla_request_id'
|
|
76
|
+
) AS request_fields
|
|
77
|
+
FROM sla_requests sr
|
|
78
|
+
LEFT JOIN users creator
|
|
79
|
+
ON sr.created_by ~ '^[0-9]+$'
|
|
80
|
+
AND creator.id = sr.created_by::integer
|
|
81
|
+
AND COALESCE(creator.is_deleted, false) = false
|
|
82
|
+
LEFT JOIN departments dept
|
|
83
|
+
ON dept.id = sr.req_user_department_id AND COALESCE(dept.is_deleted, false) = false
|
|
84
|
+
LEFT JOIN sections sec
|
|
85
|
+
ON sec.id = sr.req_user_section_id AND COALESCE(sec.is_deleted, false) = false
|
|
86
|
+
LEFT JOIN fm_services svc
|
|
87
|
+
ON svc.id = sr.service_id AND COALESCE(svc.is_deleted, false) = false
|
|
88
|
+
LEFT JOIN fm_sub_services subsvc
|
|
89
|
+
ON subsvc.id = sr.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
|
|
90
|
+
WHERE COALESCE(sr.is_deleted, false) = false
|
|
91
|
+
`;
|
|
92
|
+
/**
|
|
93
|
+
* Read-only view for SLA "my requests" listings.
|
|
94
|
+
* Display-name columns reuse sla_requests field names; values come from joined lookup tables.
|
|
95
|
+
* Service-specific payload keys live in `request_fields` (filtered `request_obj`).
|
|
96
|
+
*/
|
|
97
|
+
let SlaMyRequestsView = class SlaMyRequestsView {
|
|
98
|
+
};
|
|
99
|
+
exports.SlaMyRequestsView = SlaMyRequestsView;
|
|
100
|
+
__decorate([
|
|
101
|
+
(0, typeorm_1.ViewColumn)(),
|
|
102
|
+
__metadata("design:type", Number)
|
|
103
|
+
], SlaMyRequestsView.prototype, "sla_request_id", void 0);
|
|
104
|
+
__decorate([
|
|
105
|
+
(0, typeorm_1.ViewColumn)(),
|
|
106
|
+
__metadata("design:type", Number)
|
|
107
|
+
], SlaMyRequestsView.prototype, "user_id", void 0);
|
|
108
|
+
__decorate([
|
|
109
|
+
(0, typeorm_1.ViewColumn)(),
|
|
110
|
+
__metadata("design:type", Number)
|
|
111
|
+
], SlaMyRequestsView.prototype, "service_id", void 0);
|
|
112
|
+
__decorate([
|
|
113
|
+
(0, typeorm_1.ViewColumn)(),
|
|
114
|
+
__metadata("design:type", Number)
|
|
115
|
+
], SlaMyRequestsView.prototype, "sub_service_id", void 0);
|
|
116
|
+
__decorate([
|
|
117
|
+
(0, typeorm_1.ViewColumn)(),
|
|
118
|
+
__metadata("design:type", String)
|
|
119
|
+
], SlaMyRequestsView.prototype, "created_by", void 0);
|
|
120
|
+
__decorate([
|
|
121
|
+
(0, typeorm_1.ViewColumn)(),
|
|
122
|
+
__metadata("design:type", Date)
|
|
123
|
+
], SlaMyRequestsView.prototype, "created_at", void 0);
|
|
124
|
+
__decorate([
|
|
125
|
+
(0, typeorm_1.ViewColumn)(),
|
|
126
|
+
__metadata("design:type", String)
|
|
127
|
+
], SlaMyRequestsView.prototype, "req_user_department_id", void 0);
|
|
128
|
+
__decorate([
|
|
129
|
+
(0, typeorm_1.ViewColumn)(),
|
|
130
|
+
__metadata("design:type", String)
|
|
131
|
+
], SlaMyRequestsView.prototype, "req_user_section_id", void 0);
|
|
132
|
+
__decorate([
|
|
133
|
+
(0, typeorm_1.ViewColumn)(),
|
|
134
|
+
__metadata("design:type", String)
|
|
135
|
+
], SlaMyRequestsView.prototype, "service_name", void 0);
|
|
136
|
+
__decorate([
|
|
137
|
+
(0, typeorm_1.ViewColumn)(),
|
|
138
|
+
__metadata("design:type", String)
|
|
139
|
+
], SlaMyRequestsView.prototype, "sub_service_name", void 0);
|
|
140
|
+
__decorate([
|
|
141
|
+
(0, typeorm_1.ViewColumn)(),
|
|
142
|
+
__metadata("design:type", String)
|
|
143
|
+
], SlaMyRequestsView.prototype, "status", void 0);
|
|
144
|
+
__decorate([
|
|
145
|
+
(0, typeorm_1.ViewColumn)(),
|
|
146
|
+
__metadata("design:type", Number)
|
|
147
|
+
], SlaMyRequestsView.prototype, "request_id", void 0);
|
|
148
|
+
__decorate([
|
|
149
|
+
(0, typeorm_1.ViewColumn)(),
|
|
150
|
+
__metadata("design:type", Object)
|
|
151
|
+
], SlaMyRequestsView.prototype, "request_fields", void 0);
|
|
152
|
+
exports.SlaMyRequestsView = SlaMyRequestsView = __decorate([
|
|
153
|
+
(0, typeorm_1.ViewEntity)({
|
|
154
|
+
name: "vw_sla_my_requests",
|
|
155
|
+
expression: VW_SLA_MY_REQUESTS_SQL,
|
|
156
|
+
})
|
|
157
|
+
], SlaMyRequestsView);
|
|
158
|
+
/** Flatten view row: fixed columns plus each entry in `request_fields`. */
|
|
159
|
+
function flattenSlaMyRequestsViewRow(row) {
|
|
160
|
+
const { sla_request_id, user_id, service_id, sub_service_id, created_by, created_at, req_user_department_id, req_user_section_id, service_name, sub_service_name, status, request_id, request_fields, } = row;
|
|
161
|
+
return {
|
|
162
|
+
sla_request_id,
|
|
163
|
+
user_id,
|
|
164
|
+
service_id,
|
|
165
|
+
sub_service_id,
|
|
166
|
+
created_by,
|
|
167
|
+
created_at,
|
|
168
|
+
req_user_department_id,
|
|
169
|
+
req_user_section_id,
|
|
170
|
+
service_name,
|
|
171
|
+
sub_service_name,
|
|
172
|
+
status,
|
|
173
|
+
request_id,
|
|
174
|
+
...(request_fields ?? {}),
|
|
175
|
+
};
|
|
176
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.UuidAuditModel = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
/** UUID primary key + audit columns + soft delete via deleted_at. */
|
|
15
|
+
class UuidAuditModel {
|
|
16
|
+
}
|
|
17
|
+
exports.UuidAuditModel = UuidAuditModel;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
|
|
20
|
+
__metadata("design:type", String)
|
|
21
|
+
], UuidAuditModel.prototype, "id", void 0);
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 128, nullable: false, default: '' }),
|
|
24
|
+
__metadata("design:type", String)
|
|
25
|
+
], UuidAuditModel.prototype, "created_by", void 0);
|
|
26
|
+
__decorate([
|
|
27
|
+
(0, typeorm_1.CreateDateColumn)({ type: 'timestamptz', default: () => 'CURRENT_TIMESTAMP' }),
|
|
28
|
+
__metadata("design:type", Date)
|
|
29
|
+
], UuidAuditModel.prototype, "created_at", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 128, nullable: true }),
|
|
32
|
+
__metadata("design:type", Object)
|
|
33
|
+
], UuidAuditModel.prototype, "updated_by", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, typeorm_1.UpdateDateColumn)({ type: 'timestamptz', default: () => 'CURRENT_TIMESTAMP' }),
|
|
36
|
+
__metadata("design:type", Date)
|
|
37
|
+
], UuidAuditModel.prototype, "updated_at", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, typeorm_1.DeleteDateColumn)({ type: 'timestamptz', nullable: true }),
|
|
40
|
+
__metadata("design:type", Object)
|
|
41
|
+
], UuidAuditModel.prototype, "deleted_at", void 0);
|
package/package.json
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@platform-modules/foreign-ministry",
|
|
3
|
-
"version": "1.3.
|
|
3
|
+
"version": "1.3.322",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"types": "dist/index.d.ts",
|
|
6
6
|
"scripts": {
|
|
7
7
|
"build": "tsc",
|
|
8
|
-
"dev": "ts-node src/scripts.ts"
|
|
8
|
+
"dev": "ts-node src/scripts.ts",
|
|
9
|
+
"sync:sla-sql": "node scripts/sync-sla-reports-sql.js"
|
|
9
10
|
},
|
|
10
11
|
"publishConfig": {
|
|
11
12
|
"access": "public"
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
const dotenv = require('dotenv');
|
|
2
|
+
const { Client } = require('pg');
|
|
3
|
+
|
|
4
|
+
dotenv.config({ path: '../Reports_Service/.env' });
|
|
5
|
+
dotenv.config({ path: '.env', override: true });
|
|
6
|
+
|
|
7
|
+
async function main() {
|
|
8
|
+
const client = new Client({
|
|
9
|
+
host: process.env.DB_HOST.trim(),
|
|
10
|
+
port: 5432,
|
|
11
|
+
user: process.env.DB_USER.trim(),
|
|
12
|
+
password: process.env.DB_PASS,
|
|
13
|
+
database: process.env.DB_NAME.trim(),
|
|
14
|
+
});
|
|
15
|
+
await client.connect();
|
|
16
|
+
|
|
17
|
+
const tables = ['sla_requests', 'users', 'departments', 'sections', 'fm_services', 'fm_sub_services'];
|
|
18
|
+
for (const table of tables) {
|
|
19
|
+
const { rows } = await client.query(
|
|
20
|
+
`SELECT column_name, data_type
|
|
21
|
+
FROM information_schema.columns
|
|
22
|
+
WHERE table_schema = 'public' AND table_name = $1
|
|
23
|
+
ORDER BY ordinal_position`,
|
|
24
|
+
[table]
|
|
25
|
+
);
|
|
26
|
+
console.log(`\n${table}:`);
|
|
27
|
+
for (const row of rows) {
|
|
28
|
+
console.log(` ${row.column_name}: ${row.data_type}`);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
await client.end();
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
main().catch((err) => {
|
|
36
|
+
console.error(err.message);
|
|
37
|
+
process.exit(1);
|
|
38
|
+
});
|