@platform-modules/foreign-ministry 1.3.200 → 1.3.202

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 (55) hide show
  1. package/.env +15 -6
  2. package/dist/data-source.js +10 -0
  3. package/dist/index.d.ts +5 -0
  4. package/dist/index.js +6 -0
  5. package/dist/models/GatePassVisitorsModel.d.ts +1 -0
  6. package/dist/models/GatePassVisitorsModel.js +5 -0
  7. package/dist/models/HelpContentMappedCategoriesModel.d.ts +6 -0
  8. package/dist/models/HelpContentMappedCategoriesModel.js +34 -0
  9. package/dist/models/HelpContentMappedTagsModel.d.ts +6 -0
  10. package/dist/models/HelpContentMappedTagsModel.js +34 -0
  11. package/dist/models/HelpContentTagsModel.d.ts +5 -0
  12. package/dist/models/HelpContentTagsModel.js +29 -0
  13. package/dist/models/MediaApprovalModel.d.ts +23 -0
  14. package/dist/models/MediaApprovalModel.js +88 -0
  15. package/dist/models/MediaAttachmentModel.d.ts +11 -0
  16. package/dist/models/MediaAttachmentModel.js +52 -0
  17. package/dist/models/MediaChatModel.d.ts +19 -0
  18. package/dist/models/MediaChatModel.js +77 -0
  19. package/dist/models/MediaRequestModel.d.ts +75 -0
  20. package/dist/models/MediaRequestModel.js +162 -0
  21. package/dist/models/MediaWorkflowModel.d.ts +17 -0
  22. package/dist/models/MediaWorkflowModel.js +62 -0
  23. package/dist/models/questionTagsModel.d.ts +6 -0
  24. package/dist/models/questionTagsModel.js +34 -0
  25. package/package.json +1 -1
  26. package/src/data-source.ts +10 -0
  27. package/src/index.ts +6 -0
  28. package/src/models/DiplomaticAcademyRequestModel.ts +80 -80
  29. package/src/models/GatePassVisitorsModel.ts +4 -0
  30. package/src/models/LanguageCourseRequestModel.ts +67 -67
  31. package/src/models/LeaveConfigModel.ts +71 -71
  32. package/src/models/MediaApprovalModel.ts +59 -0
  33. package/src/models/MediaAttachmentModel.ts +29 -0
  34. package/src/models/MediaChatModel.ts +63 -0
  35. package/src/models/MediaRequestModel.ts +135 -0
  36. package/src/models/MediaWorkflowModel.ts +38 -0
  37. package/src/models/MissionTravelApprovalModel.ts +101 -101
  38. package/src/models/MissionTravelAttachmentModel.ts +56 -56
  39. package/src/models/MissionTravelChatModel.ts +52 -52
  40. package/src/models/MissionTravelPersonModel.ts +105 -105
  41. package/src/models/MissionTravelWorkflowModel.ts +54 -54
  42. package/src/models/ProjectMilestoneDocumentsModel.ts +40 -40
  43. package/src/models/ProjectMilestonesModel.ts +65 -65
  44. package/src/models/ProjectModel.ts +65 -65
  45. package/src/models/ProjectTaskActivityModel.ts +35 -35
  46. package/src/models/ProjectTaskCommentsModel.ts +17 -17
  47. package/src/models/ProjectTasksModel.ts +80 -80
  48. package/src/models/RegisterCandidateRequestModel.ts +183 -183
  49. package/src/models/SectionModel.ts +35 -35
  50. package/src/models/ServicesNotificationConfigsModel.ts +55 -55
  51. package/dist/models/MissionTravelClassConfigModel.d.ts +0 -10
  52. package/dist/models/MissionTravelClassConfigModel.js +0 -50
  53. package/dist/models/MissionTravelPerdiemModel.d.ts +0 -10
  54. package/dist/models/MissionTravelPerdiemModel.js +0 -54
  55. /package/src/models/{LeaveConfigGradesModel.Ts → LeaveConfigGradesModel.ts} +0 -0
@@ -1,72 +1,72 @@
1
- import { Column, Entity } from "typeorm";
2
- import { BaseModel } from './BaseModel';
3
-
4
- export enum enumFrequency {
5
- Monthly = 'Monthly',
6
- Yearly = 'Yearly',
7
- }
8
-
9
- //This model is used to store the Financial Grade declaration on the Admin Side
10
- @Entity({ name: 'leave_configuration' })
11
- export class LeaveConfiguration extends BaseModel {
12
-
13
- @Column({ type: 'varchar', nullable: true })
14
- category: string;
15
-
16
- @Column({ type: 'int', nullable: true })
17
- MandC_id: number;
18
-
19
- @Column({ type: 'int', nullable: true })
20
- leave_type_id: number;
21
-
22
- @Column({ type: 'varchar', nullable: true })
23
- frequency: enumFrequency;
24
-
25
- @Column({ type: 'varchar', nullable: true })
26
- region: string;
27
-
28
- @Column({ type: 'varchar', nullable: true })
29
- country: string;
30
-
31
- @Column({ type: 'varchar', nullable: true })
32
- location: string;
33
-
34
- @Column({ nullable: true, default: false })
35
- is_carryforward: boolean;
36
-
37
- @Column({ type: 'int', nullable: true, default: 0 })
38
- carryforward_limit: number;
39
-
40
- @Column({ type: 'date', nullable: true })
41
- from_date: Date;
42
-
43
- @Column({ type: 'date', nullable: true })
44
- to_date: Date;
45
-
46
- @Column({ type: 'varchar', nullable: true })
47
- reason: string;
48
-
49
- @Column({ type: 'int', nullable: true })
50
- emergency_balance_days: number | null;
51
-
52
- @Column({ type: 'date', nullable: true })
53
- last_credited: Date | null;
54
-
55
- constructor(category: string, MandC_id: number, leave_type_id: number, frequency: enumFrequency, region: string, country: string, location: string, is_carryforward: boolean, carryforward_limit: number, from_date: Date, to_date: Date, reason: string, emergency_balance_days?: number|null, last_credited?: Date|null) {
56
- super();
57
- this.category = category;
58
- this.MandC_id = MandC_id;
59
- this.leave_type_id = leave_type_id;
60
- this.frequency = frequency;
61
- this.region = region;
62
- this.country = country;
63
- this.location = location;
64
- this.is_carryforward = is_carryforward;
65
- this.carryforward_limit = carryforward_limit;
66
- this.from_date = from_date;
67
- this.to_date = to_date;
68
- this.reason = reason;
69
- this.emergency_balance_days = emergency_balance_days ?? null;
70
- this.last_credited = last_credited ?? null;
71
- }
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum enumFrequency {
5
+ Monthly = 'Monthly',
6
+ Yearly = 'Yearly',
7
+ }
8
+
9
+ //This model is used to store the Financial Grade declaration on the Admin Side
10
+ @Entity({ name: 'leave_configuration' })
11
+ export class LeaveConfiguration extends BaseModel {
12
+
13
+ @Column({ type: 'varchar', nullable: true })
14
+ category: string;
15
+
16
+ @Column({ type: 'int', nullable: true })
17
+ MandC_id: number;
18
+
19
+ @Column({ type: 'int', nullable: true })
20
+ leave_type_id: number;
21
+
22
+ @Column({ type: 'varchar', nullable: true })
23
+ frequency: enumFrequency;
24
+
25
+ @Column({ type: 'varchar', nullable: true })
26
+ region: string;
27
+
28
+ @Column({ type: 'varchar', nullable: true })
29
+ country: string;
30
+
31
+ @Column({ type: 'varchar', nullable: true })
32
+ location: string;
33
+
34
+ @Column({ nullable: true, default: false })
35
+ is_carryforward: boolean;
36
+
37
+ @Column({ type: 'int', nullable: true, default: 0 })
38
+ carryforward_limit: number;
39
+
40
+ @Column({ type: 'date', nullable: true })
41
+ from_date: Date;
42
+
43
+ @Column({ type: 'date', nullable: true })
44
+ to_date: Date;
45
+
46
+ @Column({ type: 'varchar', nullable: true })
47
+ reason: string;
48
+
49
+ @Column({ type: 'int', nullable: true })
50
+ emergency_balance_days: number | null;
51
+
52
+ @Column({ type: 'date', nullable: true })
53
+ last_credited: Date | null;
54
+
55
+ constructor(category: string, MandC_id: number, leave_type_id: number, frequency: enumFrequency, region: string, country: string, location: string, is_carryforward: boolean, carryforward_limit: number, from_date: Date, to_date: Date, reason: string, emergency_balance_days?: number|null, last_credited?: Date|null) {
56
+ super();
57
+ this.category = category;
58
+ this.MandC_id = MandC_id;
59
+ this.leave_type_id = leave_type_id;
60
+ this.frequency = frequency;
61
+ this.region = region;
62
+ this.country = country;
63
+ this.location = location;
64
+ this.is_carryforward = is_carryforward;
65
+ this.carryforward_limit = carryforward_limit;
66
+ this.from_date = from_date;
67
+ this.to_date = to_date;
68
+ this.reason = reason;
69
+ this.emergency_balance_days = emergency_balance_days ?? null;
70
+ this.last_credited = last_credited ?? null;
71
+ }
72
72
  }
@@ -0,0 +1,59 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaApprovalStatus {
5
+ PENDING = 'Pending',
6
+ IN_PROGRESS = 'In Progress',
7
+ APPROVED = 'Approved',
8
+ REJECTED = 'Rejected',
9
+ }
10
+
11
+ @Entity({ name: 'media_approvals' })
12
+ export class MediaApprovalDetails extends BaseModel {
13
+ @Column({ type: 'integer', nullable: false })
14
+ request_id: number;
15
+
16
+ @Column({ type: 'integer', nullable: true })
17
+ service_id: number | null;
18
+
19
+ @Column({ type: 'integer', nullable: true })
20
+ sub_service_id: number | null;
21
+
22
+ @Column({ type: 'integer', nullable: false })
23
+ level: number;
24
+
25
+ @Column({ type: 'integer', nullable: true })
26
+ approver_role_id: number;
27
+
28
+ @Column({ type: 'integer', nullable: true })
29
+ department_id: number | null;
30
+
31
+ @Column({ type: 'integer', nullable: true })
32
+ section_id: number | null;
33
+
34
+ @Column({ type: 'integer', nullable: true })
35
+ approver_user_id: number | null;
36
+
37
+ @Column({ type: 'integer', nullable: true })
38
+ delegate_user_id: number | null;
39
+
40
+ @Column({ type: 'integer', nullable: true })
41
+ approved_by: number | null;
42
+
43
+ @Column({ type: 'varchar', length: 500, nullable: true, default: '' })
44
+ comment: string;
45
+
46
+ @Column({
47
+ type: 'enum',
48
+ enum: MediaApprovalStatus,
49
+ default: MediaApprovalStatus.PENDING,
50
+ nullable: false,
51
+ })
52
+ approval_status: MediaApprovalStatus;
53
+
54
+ @Column({ type: 'boolean', default: true, nullable: false })
55
+ is_allowed: boolean;
56
+
57
+ @Column({ type: 'varchar', nullable: true })
58
+ task_name: string;
59
+ }
@@ -0,0 +1,29 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'media_attachments' })
5
+ export class MediaRequestAttachment extends BaseModel {
6
+ @Column({ type: 'integer', nullable: false })
7
+ request_id: number;
8
+
9
+ @Column({ type: 'integer', nullable: true })
10
+ service_id: number | null;
11
+
12
+ @Column({ type: 'integer', nullable: true })
13
+ sub_service_id: number | null;
14
+
15
+ @Column({ type: 'varchar', length: 500, nullable: false })
16
+ file_url: string;
17
+
18
+ @Column({ type: 'varchar', length: 255, nullable: true })
19
+ file_name: string;
20
+
21
+ @Column({ type: 'varchar', length: 100, nullable: true })
22
+ file_type: string;
23
+
24
+ @Column({ type: 'bigint', nullable: true })
25
+ file_size: number | null;
26
+
27
+ @Column({ type: 'integer', nullable: true })
28
+ chat_id: number | null;
29
+ }
@@ -0,0 +1,63 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaMessageType {
5
+ TEXT = 'text',
6
+ IMAGE = 'image',
7
+ VIDEO = 'video',
8
+ FILE = 'file',
9
+ LINK = 'link',
10
+ }
11
+
12
+ @Entity({ name: 'media_chats' })
13
+ export class MediaRequestChat extends BaseModel {
14
+ @Column({ type: 'integer', nullable: false })
15
+ request_id: number;
16
+
17
+ @Column({ type: 'integer', nullable: true })
18
+ service_id: number | null;
19
+
20
+ @Column({ type: 'integer', nullable: true })
21
+ sub_service_id: number | null;
22
+
23
+ @Column({ type: 'integer', nullable: false })
24
+ user_id: number;
25
+
26
+ @Column({ type: 'integer', nullable: true })
27
+ role_id: number;
28
+
29
+ @Column({ type: 'text', nullable: false })
30
+ message: string;
31
+
32
+ @Column({
33
+ type: 'enum',
34
+ enum: MediaMessageType,
35
+ default: MediaMessageType.TEXT,
36
+ nullable: false,
37
+ })
38
+ messageType: MediaMessageType;
39
+
40
+ @Column({ type: 'text', nullable: true })
41
+ status: string;
42
+
43
+ constructor(
44
+ request_id: number,
45
+ user_id: number,
46
+ role_id: number,
47
+ message: string,
48
+ service_id?: number,
49
+ sub_service_id?: number,
50
+ messageType?: MediaMessageType,
51
+ status?: string
52
+ ) {
53
+ super();
54
+ this.request_id = request_id;
55
+ this.service_id = service_id ?? null;
56
+ this.sub_service_id = sub_service_id ?? null;
57
+ this.user_id = user_id;
58
+ this.role_id = role_id;
59
+ this.message = message;
60
+ this.messageType = messageType ?? MediaMessageType.TEXT;
61
+ this.status = status ?? 'Pending';
62
+ }
63
+ }
@@ -0,0 +1,135 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaRequestStatus {
5
+ DRAFT = 'Draft',
6
+ PENDING_REVIEW = 'Pending Review',
7
+ APPROVED = 'Approved',
8
+ REJECTED = 'Rejected',
9
+ PUBLISHED = 'Published',
10
+ ARCHIVED = 'Archived',
11
+ }
12
+
13
+ export enum MediaAuthorPublisher {
14
+ MEDIA_TEAM = 'Media Team',
15
+ HR = 'HR',
16
+ EMBASSY = 'Embassy',
17
+ DEPARTMENT = 'department',
18
+ }
19
+
20
+ export enum MediaCategory {
21
+ WORLDWIDE = 'Worldwide',
22
+ IT = 'IT',
23
+ HR = 'HR',
24
+ DIPLOMATIC_MC = "Diplomatic M&C's",
25
+ }
26
+
27
+ export enum MediaRequestType {
28
+ EXTERNAL_MEDIA_COVERAGE = 'External media coverage',
29
+ EXTERNAL_ARTICLES_PUBLISH = 'External articles publish',
30
+ INTERNAL_MEDIA_COVERAGE = 'Internal media coverage',
31
+ INTERNAL_ARTICLES_PUBLISH = 'Internal articles publish',
32
+ PURCHASE_ORDERS = 'Purchase orders',
33
+ POST_ADVERTISEMENT_DIPLOMATIC_CAR = 'Post an advertisement for selling a diplomatic car',
34
+ INTERNAL_EVENTS_NATIONAL_DAY = 'Internal Events requirements (National Day) for Omani embassies',
35
+ MINISTRY_DEPARTMENTS_REQUESTS = 'Ministry Departments Requests',
36
+ }
37
+
38
+ export enum MediaClassification {
39
+ CLASSIFIED = 'Classified, Private',
40
+ PUBLIC = 'Public',
41
+ }
42
+
43
+ export enum MediaNotificationType {
44
+ REGULAR_UPDATE = 'Regular update',
45
+ URGENT_POPUP = 'urgent popup',
46
+ }
47
+
48
+ export enum MediaYesNo {
49
+ YES = 'Yes',
50
+ NO = 'No',
51
+ }
52
+
53
+ @Entity({ name: 'media_requests' })
54
+ export class MediaRequests extends BaseModel {
55
+ // Common columns (from meeting_requests)
56
+ @Column({ type: 'int', nullable: true })
57
+ req_user_department_id: number | null;
58
+
59
+ @Column({ type: 'int', nullable: true })
60
+ req_user_section_id: number | null;
61
+
62
+ @Column({ type: 'int', nullable: true })
63
+ service_id: number | null;
64
+
65
+ @Column({ type: 'int', nullable: true })
66
+ sub_service_id: number | null;
67
+
68
+ @Column({ type: 'int', nullable: false })
69
+ user_id: number;
70
+
71
+ @Column({
72
+ type: 'enum',
73
+ enum: MediaRequestStatus,
74
+ default: MediaRequestStatus.DRAFT,
75
+ nullable: false,
76
+ })
77
+ status: MediaRequestStatus;
78
+
79
+ @Column({ type: 'varchar', nullable: true })
80
+ workflow_execution_id: string | null;
81
+
82
+ // New columns
83
+ /** Headline of the news / announcement */
84
+ @Column({ type: 'varchar', length: 500, nullable: true })
85
+ title: string | null;
86
+
87
+ /** Short description or teaser (Rich Text) */
88
+ @Column({ type: 'text', nullable: true })
89
+ summary_abstract: string | null;
90
+
91
+ /** Main content with formatting (text, images, embedded videos) */
92
+ @Column({ type: 'text', nullable: true })
93
+ description: string | null;
94
+
95
+ @Column({ type: 'enum', enum: MediaAuthorPublisher, nullable: true })
96
+ author_publisher: MediaAuthorPublisher | null;
97
+
98
+ @Column({ type: 'enum', enum: MediaCategory, nullable: true })
99
+ category: MediaCategory | null;
100
+
101
+ @Column({ type: 'enum', enum: MediaRequestType, nullable: true })
102
+ request_type: MediaRequestType | null;
103
+
104
+ @Column({ type: 'enum', enum: MediaClassification, nullable: true })
105
+ classification: MediaClassification | null;
106
+
107
+ /** Target Audience: Departments, Teams, Roles (stored as JSON array or comma-separated) */
108
+ @Column({ type: 'text', nullable: true })
109
+ target_audience: string | null;
110
+
111
+ /** When content goes live */
112
+ @Column({ type: 'date', nullable: true })
113
+ publish_date: string | null;
114
+
115
+ /** When content should auto-hide */
116
+ @Column({ type: 'date', nullable: true })
117
+ expiry_date: string | null;
118
+
119
+ @Column({ type: 'boolean', default: false, nullable: true })
120
+ hide_flag: boolean | null;
121
+
122
+ /** Mandatory if hidden */
123
+ @Column({ type: 'text', nullable: true })
124
+ reason_for_hiding: string | null;
125
+
126
+ @Column({ type: 'enum', enum: MediaNotificationType, nullable: true })
127
+ notification_type: MediaNotificationType | null;
128
+
129
+ @Column({ type: 'enum', enum: MediaYesNo, nullable: true })
130
+ popup_mandatory: MediaYesNo | null;
131
+
132
+ /** How long the popup remains visible (e.g. seconds or description) */
133
+ @Column({ type: 'varchar', length: 100, nullable: true })
134
+ popup_duration: string | null;
135
+ }
@@ -0,0 +1,38 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaWorkFlowStatus {
5
+ COMPLETED = 'Completed',
6
+ NOT_YET_STARTED = 'Not Yet Started',
7
+ PENDING = 'Pending',
8
+ }
9
+
10
+ @Entity({ name: 'media_workflows' })
11
+ export class MediaWorkFlow extends BaseModel {
12
+ @Column({ type: 'integer', nullable: false })
13
+ request_id: number;
14
+
15
+ @Column({ type: 'integer', nullable: true })
16
+ service_id: number | null;
17
+
18
+ @Column({ type: 'integer', nullable: true })
19
+ sub_service_id: number | null;
20
+
21
+ @Column({ type: 'varchar', length: 500, nullable: false })
22
+ content: string;
23
+
24
+ @Column({ type: 'enum', enum: MediaWorkFlowStatus, default: MediaWorkFlowStatus.NOT_YET_STARTED, nullable: false })
25
+ status: MediaWorkFlowStatus;
26
+
27
+ @Column({ type: 'integer', nullable: true })
28
+ user_id: number | null;
29
+
30
+ @Column({ type: 'integer', nullable: true })
31
+ role_id: number | null;
32
+
33
+ @Column({ type: 'integer', nullable: true })
34
+ department_id: number | null;
35
+
36
+ @Column({ type: 'integer', nullable: true })
37
+ section_id: number | null;
38
+ }
@@ -1,101 +1,101 @@
1
- import { Column, Entity } from "typeorm";
2
- import { BaseModel } from './BaseModel';
3
-
4
- export enum MissionTravelApprovalStatus {
5
- PENDING = "Pending",
6
- APPROVED = "Approved",
7
- REJECTED = "Rejected",
8
- RFC = "RFC", // Request for Change
9
- IN_PROGRESS = "In Progress",
10
- CANCELLED = "Cancelled"
11
- }
12
-
13
- @Entity({ name: 'mission_travel_approvals' })
14
- export class MissionTravelApprovalDetails extends BaseModel {
15
- @Column({ type: 'integer', nullable: false })
16
- request_id: number;
17
-
18
- @Column({ type: 'integer', nullable: true })
19
- service_id: number | null;
20
-
21
- @Column({ type: 'integer', nullable: true })
22
- sub_service_id: number | null;
23
-
24
- @Column({ type: 'integer', nullable: false })
25
- level: number;
26
-
27
- @Column({ type: 'integer', nullable: true })
28
- approver_role_id: number;
29
-
30
- @Column({ type: 'integer', nullable: true })
31
- department_id: number | null;
32
-
33
- @Column({ type: 'integer', nullable: true })
34
- section_id: number | null;
35
-
36
- @Column({ type: 'integer', nullable: true })
37
- approver_user_id: number | null;
38
-
39
- @Column({ type: 'integer', nullable: true })
40
- delegate_user_id: number | null;
41
-
42
- @Column({ type: 'integer', nullable: true })
43
- approved_by: number | null;
44
-
45
- @Column({ type: 'varchar', length: 500, nullable: true, default: '' })
46
- comment: string;
47
-
48
- @Column({ type: 'enum', enum: MissionTravelApprovalStatus, default: MissionTravelApprovalStatus.PENDING, nullable: false })
49
- approval_status: MissionTravelApprovalStatus;
50
-
51
- @Column({ type: 'boolean', default: true, nullable: false })
52
- is_allowed: boolean;
53
-
54
- @Column({ type: 'boolean', default: false, nullable: false })
55
- is_reassign: boolean;
56
-
57
- @Column({ type: 'boolean', default: true, nullable: false })
58
- is_approval: boolean;
59
-
60
- @Column({ type: 'boolean', default: false, nullable: false })
61
- is_review: boolean;
62
-
63
- constructor(
64
- request_id: number,
65
- service_id: number | null,
66
- sub_service_id: number | null,
67
- level: number,
68
- approver_role_id: number,
69
- department_id: number | null,
70
- section_id: number | null,
71
- approver_user_id: number | null,
72
- delegate_user_id: number | null,
73
- approved_by: number | null,
74
- comment: string,
75
- approval_status: MissionTravelApprovalStatus,
76
- is_allowed: boolean,
77
- is_reassign: boolean,
78
- is_approval: boolean,
79
- is_review?: boolean
80
- ) {
81
- super();
82
- this.request_id = request_id;
83
- this.service_id = service_id;
84
- this.sub_service_id = sub_service_id;
85
- this.level = level;
86
- this.approver_role_id = approver_role_id;
87
- this.department_id = department_id;
88
- this.section_id = section_id;
89
- this.approver_user_id = approver_user_id;
90
- this.delegate_user_id = delegate_user_id;
91
- this.approved_by = approved_by;
92
- this.comment = comment;
93
- this.approval_status = approval_status;
94
- this.is_allowed = is_allowed;
95
- this.is_reassign = is_reassign;
96
- this.is_approval = is_approval;
97
- this.is_review = is_review ?? false;
98
- }
99
- }
100
-
101
-
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MissionTravelApprovalStatus {
5
+ PENDING = "Pending",
6
+ APPROVED = "Approved",
7
+ REJECTED = "Rejected",
8
+ RFC = "RFC", // Request for Change
9
+ IN_PROGRESS = "In Progress",
10
+ CANCELLED = "Cancelled"
11
+ }
12
+
13
+ @Entity({ name: 'mission_travel_approvals' })
14
+ export class MissionTravelApprovalDetails extends BaseModel {
15
+ @Column({ type: 'integer', nullable: false })
16
+ request_id: number;
17
+
18
+ @Column({ type: 'integer', nullable: true })
19
+ service_id: number | null;
20
+
21
+ @Column({ type: 'integer', nullable: true })
22
+ sub_service_id: number | null;
23
+
24
+ @Column({ type: 'integer', nullable: false })
25
+ level: number;
26
+
27
+ @Column({ type: 'integer', nullable: true })
28
+ approver_role_id: number;
29
+
30
+ @Column({ type: 'integer', nullable: true })
31
+ department_id: number | null;
32
+
33
+ @Column({ type: 'integer', nullable: true })
34
+ section_id: number | null;
35
+
36
+ @Column({ type: 'integer', nullable: true })
37
+ approver_user_id: number | null;
38
+
39
+ @Column({ type: 'integer', nullable: true })
40
+ delegate_user_id: number | null;
41
+
42
+ @Column({ type: 'integer', nullable: true })
43
+ approved_by: number | null;
44
+
45
+ @Column({ type: 'varchar', length: 500, nullable: true, default: '' })
46
+ comment: string;
47
+
48
+ @Column({ type: 'enum', enum: MissionTravelApprovalStatus, default: MissionTravelApprovalStatus.PENDING, nullable: false })
49
+ approval_status: MissionTravelApprovalStatus;
50
+
51
+ @Column({ type: 'boolean', default: true, nullable: false })
52
+ is_allowed: boolean;
53
+
54
+ @Column({ type: 'boolean', default: false, nullable: false })
55
+ is_reassign: boolean;
56
+
57
+ @Column({ type: 'boolean', default: true, nullable: false })
58
+ is_approval: boolean;
59
+
60
+ @Column({ type: 'boolean', default: false, nullable: false })
61
+ is_review: boolean;
62
+
63
+ constructor(
64
+ request_id: number,
65
+ service_id: number | null,
66
+ sub_service_id: number | null,
67
+ level: number,
68
+ approver_role_id: number,
69
+ department_id: number | null,
70
+ section_id: number | null,
71
+ approver_user_id: number | null,
72
+ delegate_user_id: number | null,
73
+ approved_by: number | null,
74
+ comment: string,
75
+ approval_status: MissionTravelApprovalStatus,
76
+ is_allowed: boolean,
77
+ is_reassign: boolean,
78
+ is_approval: boolean,
79
+ is_review?: boolean
80
+ ) {
81
+ super();
82
+ this.request_id = request_id;
83
+ this.service_id = service_id;
84
+ this.sub_service_id = sub_service_id;
85
+ this.level = level;
86
+ this.approver_role_id = approver_role_id;
87
+ this.department_id = department_id;
88
+ this.section_id = section_id;
89
+ this.approver_user_id = approver_user_id;
90
+ this.delegate_user_id = delegate_user_id;
91
+ this.approved_by = approved_by;
92
+ this.comment = comment;
93
+ this.approval_status = approval_status;
94
+ this.is_allowed = is_allowed;
95
+ this.is_reassign = is_reassign;
96
+ this.is_approval = is_approval;
97
+ this.is_review = is_review ?? false;
98
+ }
99
+ }
100
+
101
+