@platform-modules/foreign-ministry 1.3.320 → 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.
Files changed (90) hide show
  1. package/.env +9 -4
  2. package/dist/data-source.js +4 -0
  3. package/dist/index.d.ts +2 -0
  4. package/dist/index.js +2 -0
  5. package/dist/models/ChildrensEducationRequestModel.d.ts +1 -0
  6. package/dist/models/ChildrensEducationRequestModel.js +4 -0
  7. package/dist/models/EmbassyEvaluationDepartmentSettingModel.d.ts +14 -0
  8. package/dist/models/EmbassyEvaluationDepartmentSettingModel.js +56 -0
  9. package/dist/models/EvaluationMastersModel.d.ts +16 -0
  10. package/dist/models/EvaluationMastersModel.js +67 -0
  11. package/dist/models/EvaluationWorkflowModel.d.ts +60 -0
  12. package/dist/models/EvaluationWorkflowModel.js +215 -0
  13. package/dist/models/IneligibleForEvaluationModel.d.ts +8 -0
  14. package/dist/models/IneligibleForEvaluationModel.js +44 -0
  15. package/dist/models/MedicalExpensesRequestModel.d.ts +1 -0
  16. package/dist/models/MedicalExpensesRequestModel.js +4 -0
  17. package/dist/models/MissionTravelClassConfigModel.d.ts +10 -0
  18. package/dist/models/MissionTravelClassConfigModel.js +50 -0
  19. package/dist/models/MissionTravelPerdiemModel.d.ts +10 -0
  20. package/dist/models/MissionTravelPerdiemModel.js +54 -0
  21. package/dist/models/RecruitmentDomesticWorkersRequestModel.d.ts +1 -0
  22. package/dist/models/RecruitmentDomesticWorkersRequestModel.js +4 -0
  23. package/dist/models/SlaApprovalsViewModel.d.ts +31 -0
  24. package/dist/models/SlaApprovalsViewModel.js +174 -0
  25. package/dist/models/SlaMyRequestsViewModel.d.ts +29 -0
  26. package/dist/models/SlaMyRequestsViewModel.js +176 -0
  27. package/dist/models/TransferAllowanceRequestModel.d.ts +1 -0
  28. package/dist/models/TransferAllowanceRequestModel.js +4 -0
  29. package/dist/models/TransferSalaryBankAccountRequestModel.d.ts +1 -0
  30. package/dist/models/TransferSalaryBankAccountRequestModel.js +4 -0
  31. package/dist/models/UuidAuditModel.d.ts +9 -0
  32. package/dist/models/UuidAuditModel.js +41 -0
  33. package/package.json +25 -24
  34. package/scripts/check-column-types.js +38 -0
  35. package/scripts/check-service-tables.js +42 -0
  36. package/scripts/sync-sla-reports-sql.js +95 -0
  37. package/sql/sla-reports-sync.manifest.json +7 -0
  38. package/sql/sla_reports_admin_procedures.sql +283 -0
  39. package/sql/sla_reports_approvals_workbook.sql +383 -0
  40. package/sql/sla_reports_procedures.sql +874 -0
  41. package/sql/vw_sla_approvals.sql +108 -0
  42. package/sql/vw_sla_my_requests.sql +55 -0
  43. package/src/data-source.ts +690 -686
  44. package/src/index.ts +600 -598
  45. package/src/models/AnnualTravelTicketPriceConfigurationItemModel.ts +36 -36
  46. package/src/models/AnnualTravelTicketPriceConfigurationModel.ts +35 -35
  47. package/src/models/AnnualTravelTicketRequestModel.ts +42 -42
  48. package/src/models/ChildrensEducationRequestModel.ts +3 -0
  49. package/src/models/DiplomaticAcademyRequestModel.ts +80 -80
  50. package/src/models/DocumentationFileModel.ts +40 -40
  51. package/src/models/EmbassyEvaluationCycleModel.ts +38 -38
  52. package/src/models/EmbassyEvaluationRequestModel.ts +59 -59
  53. package/src/models/EmployeeEvaluationAnswerModel.ts +26 -26
  54. package/src/models/EvaluationEligibilitySettingModel.ts +51 -51
  55. package/src/models/EvaluationFormModel.ts +44 -44
  56. package/src/models/FinancialWorkFlowModel.ts +15 -15
  57. package/src/models/GatePassVisitorsModel.ts +7 -7
  58. package/src/models/LMSExternalEntityTrainedPersonModel.ts +45 -45
  59. package/src/models/LanguageCourseRequestModel.ts +67 -67
  60. package/src/models/LeaveApprovalsModel.ts +66 -66
  61. package/src/models/LeaveConfigModel.ts +71 -71
  62. package/src/models/MedicalExpensesRequestModel.ts +3 -0
  63. package/src/models/MissionTravelApprovalModel.ts +101 -101
  64. package/src/models/MissionTravelAttachmentModel.ts +56 -56
  65. package/src/models/MissionTravelChatModel.ts +52 -52
  66. package/src/models/MissionTravelPersonModel.ts +105 -105
  67. package/src/models/MissionTravelWorkflowModel.ts +54 -54
  68. package/src/models/PollOptionsModel.ts +26 -26
  69. package/src/models/PollVotesModel.ts +37 -37
  70. package/src/models/PollsModel.ts +49 -49
  71. package/src/models/ProjectContactsModel.ts +51 -51
  72. package/src/models/ProjectFaqModel.ts +36 -36
  73. package/src/models/ProjectInvoicesModel.ts +41 -41
  74. package/src/models/ProjectModel.ts +75 -75
  75. package/src/models/ProjectTasksModel.ts +75 -75
  76. package/src/models/RecruitmentDomesticWorkersRequestModel.ts +3 -0
  77. package/src/models/ResignationTerminationApprovalModel.ts +9 -9
  78. package/src/models/ResignationTerminationRequestModel.ts +17 -17
  79. package/src/models/SectionModel.ts +35 -35
  80. package/src/models/ServiceSlaApprovalModel.ts +63 -63
  81. package/src/models/ServicesNotificationConfigsModel.ts +55 -55
  82. package/src/models/SlaApprovalsViewModel.ts +135 -0
  83. package/src/models/SlaMyRequestsViewModel.ts +172 -0
  84. package/src/models/TelephoneDirectoryModel.ts +20 -20
  85. package/src/models/TransferAllowanceRequestModel.ts +3 -0
  86. package/src/models/TransferSalaryBankAccountRequestModel.ts +3 -0
  87. package/dist/models/EmbassyMasterModel.d.ts +0 -16
  88. package/dist/models/EmbassyMasterModel.js +0 -75
  89. package/dist/models/UserDependentsModel.d.ts +0 -18
  90. package/dist/models/UserDependentsModel.js +0 -94
@@ -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);
@@ -15,4 +15,5 @@ export declare class RecruitmentDomesticWorkersRequests extends BaseModel {
15
15
  user_id: number;
16
16
  status: RecruitmentDomesticWorkersRequestStatus;
17
17
  workflow_execution_id: string | null;
18
+ mc_location: string | null;
18
19
  }
@@ -57,6 +57,10 @@ __decorate([
57
57
  (0, typeorm_1.Column)({ type: 'varchar', nullable: true }),
58
58
  __metadata("design:type", Object)
59
59
  ], RecruitmentDomesticWorkersRequests.prototype, "workflow_execution_id", void 0);
60
+ __decorate([
61
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
62
+ __metadata("design:type", Object)
63
+ ], RecruitmentDomesticWorkersRequests.prototype, "mc_location", void 0);
60
64
  exports.RecruitmentDomesticWorkersRequests = RecruitmentDomesticWorkersRequests = __decorate([
61
65
  (0, typeorm_1.Entity)({ name: 'recruitment_domestic_workers_requests' })
62
66
  ], RecruitmentDomesticWorkersRequests);
@@ -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
+ }
@@ -22,4 +22,5 @@ export declare class TransferAllowanceRequests extends BaseModel {
22
22
  currency_type: string | null;
23
23
  destination: string | null;
24
24
  mission_type: string | null;
25
+ mc_location: string | null;
25
26
  }
@@ -85,6 +85,10 @@ __decorate([
85
85
  (0, typeorm_1.Column)({ type: 'varchar', length: 100, nullable: true }),
86
86
  __metadata("design:type", Object)
87
87
  ], TransferAllowanceRequests.prototype, "mission_type", void 0);
88
+ __decorate([
89
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
90
+ __metadata("design:type", Object)
91
+ ], TransferAllowanceRequests.prototype, "mc_location", void 0);
88
92
  exports.TransferAllowanceRequests = TransferAllowanceRequests = __decorate([
89
93
  (0, typeorm_1.Entity)({ name: 'transfer_allowance_requests' })
90
94
  ], TransferAllowanceRequests);
@@ -22,4 +22,5 @@ export declare class TransferSalaryBankAccountRequests extends BaseModel {
22
22
  branch_code: string | null;
23
23
  account_holder_name: string | null;
24
24
  percentage_of_salary: string | null;
25
+ mc_location: string | null;
25
26
  }
@@ -85,6 +85,10 @@ __decorate([
85
85
  (0, typeorm_1.Column)({ type: 'decimal', precision: 8, scale: 2, nullable: true }),
86
86
  __metadata("design:type", Object)
87
87
  ], TransferSalaryBankAccountRequests.prototype, "percentage_of_salary", void 0);
88
+ __decorate([
89
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
90
+ __metadata("design:type", Object)
91
+ ], TransferSalaryBankAccountRequests.prototype, "mc_location", void 0);
88
92
  exports.TransferSalaryBankAccountRequests = TransferSalaryBankAccountRequests = __decorate([
89
93
  (0, typeorm_1.Entity)({ name: 'transfer_salary_bank_account_requests' })
90
94
  ], TransferSalaryBankAccountRequests);
@@ -0,0 +1,9 @@
1
+ /** UUID primary key + audit columns + soft delete via deleted_at. */
2
+ export declare abstract class UuidAuditModel {
3
+ id: string;
4
+ created_by: string;
5
+ created_at: Date;
6
+ updated_by: string | null;
7
+ updated_at: Date;
8
+ deleted_at: Date | null;
9
+ }
@@ -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,24 +1,25 @@
1
- {
2
- "name": "@platform-modules/foreign-ministry",
3
- "version": "1.3.320",
4
- "main": "dist/index.js",
5
- "types": "dist/index.d.ts",
6
- "scripts": {
7
- "build": "tsc",
8
- "dev": "ts-node src/scripts.ts"
9
- },
10
- "publishConfig": {
11
- "access": "public"
12
- },
13
- "dependencies": {
14
- "moment-timezone": "^0.6.0",
15
- "pg": "^8.16.0",
16
- "typeorm": "^0.3.17"
17
- },
18
- "devDependencies": {
19
- "@types/moment-timezone": "^0.5.30",
20
- "dotenv": "^16.5.0",
21
- "ts-node": "^10.9.2",
22
- "typescript": "^5.2.0"
23
- }
24
- }
1
+ {
2
+ "name": "@platform-modules/foreign-ministry",
3
+ "version": "1.3.322",
4
+ "main": "dist/index.js",
5
+ "types": "dist/index.d.ts",
6
+ "scripts": {
7
+ "build": "tsc",
8
+ "dev": "ts-node src/scripts.ts",
9
+ "sync:sla-sql": "node scripts/sync-sla-reports-sql.js"
10
+ },
11
+ "publishConfig": {
12
+ "access": "public"
13
+ },
14
+ "dependencies": {
15
+ "moment-timezone": "^0.6.0",
16
+ "pg": "^8.16.0",
17
+ "typeorm": "^0.3.17"
18
+ },
19
+ "devDependencies": {
20
+ "@types/moment-timezone": "^0.5.30",
21
+ "dotenv": "^16.5.0",
22
+ "ts-node": "^10.9.2",
23
+ "typescript": "^5.2.0"
24
+ }
25
+ }
@@ -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
+ });