@platform-modules/civil-aviation-authority 2.0.90 → 2.1.1

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 (50) hide show
  1. package/dist/data-source.js +11 -1
  2. package/dist/index.d.ts +5 -0
  3. package/dist/index.js +5 -0
  4. package/dist/models/HotelApprovalModel.d.ts +22 -0
  5. package/dist/models/HotelApprovalModel.js +91 -0
  6. package/dist/models/HotelAttachedModel.d.ts +14 -0
  7. package/dist/models/HotelAttachedModel.js +74 -0
  8. package/dist/models/HotelChatModel.d.ts +17 -0
  9. package/dist/models/HotelChatModel.js +67 -0
  10. package/dist/models/HotelWorkFlowModel.d.ts +14 -0
  11. package/dist/models/HotelWorkFlowModel.js +56 -0
  12. package/dist/models/HotelreservationModal.d.ts +30 -0
  13. package/dist/models/HotelreservationModal.js +119 -0
  14. package/dist/models/HotelreservationModel.d.ts +45 -0
  15. package/dist/models/HotelreservationModel.js +176 -0
  16. package/dist/models/ITApprovalSettings.d.ts +7 -0
  17. package/dist/models/ITApprovalSettings.js +40 -0
  18. package/dist/models/ITHelpDeskModel.d.ts +1 -5
  19. package/dist/models/ITHelpDeskModel.js +2 -22
  20. package/dist/models/ITRequestAttachmentModel.d.ts +1 -3
  21. package/dist/models/ITRequestAttachmentModel.js +2 -12
  22. package/dist/models/ITServicesTypesMuscatModel.d.ts +6 -0
  23. package/dist/models/ITServicesTypesMuscatModel.js +34 -0
  24. package/dist/models/ITServicesTypesSalalahModel.d.ts +6 -0
  25. package/dist/models/ITServicesTypesSalalahModel.js +34 -0
  26. package/dist/models/ItApprovalsModel.d.ts +1 -4
  27. package/dist/models/ItApprovalsModel.js +2 -17
  28. package/dist/models/ItWorkflowModel.d.ts +1 -3
  29. package/dist/models/ItWorkflowModel.js +2 -12
  30. package/dist/models/VpnApprovalModel.d.ts +2 -4
  31. package/dist/models/VpnApprovalModel.js +2 -8
  32. package/dist/models/WorkflowTask.d.ts +1 -4
  33. package/dist/models/WorkflowTask.js +2 -17
  34. package/dist/models/Workflows.d.ts +0 -0
  35. package/dist/models/Workflows.js +31 -0
  36. package/package.json +1 -1
  37. package/src/data-source.ts +11 -1
  38. package/src/index.ts +5 -0
  39. package/src/models/HotelApprovalModel.ts +79 -0
  40. package/src/models/HotelAttachedModel.ts +64 -0
  41. package/src/models/HotelChatModel.ts +55 -0
  42. package/src/models/HotelWorkFlowModel.ts +42 -0
  43. package/src/models/HotelreservationModel.ts +164 -0
  44. package/src/models/ITHelpDeskModel.ts +100 -120
  45. package/src/models/ITRequestAttachmentModel.ts +1 -11
  46. package/src/models/ItApprovalsModel.ts +1 -11
  47. package/src/models/ItWorkflowModel.ts +1 -9
  48. package/src/models/VpnApprovalModel.ts +2 -8
  49. package/src/models/WorkflowTask.ts +1 -16
  50. package/src/models/user.ts +0 -1
@@ -24,15 +24,12 @@ const WorkflowTaskNames_2 = require("./WorkflowTaskNames");
24
24
  // NOTIFICATION = 'NOTIFICATION'
25
25
  // }
26
26
  let WorkflowTask = class WorkflowTask extends BaseModel_1.BaseModel {
27
- constructor(name, task_id, task_type, category, service_id, sub_service_id, service_type) {
27
+ constructor(name, task_id, task_type, category) {
28
28
  super();
29
29
  this.name = name;
30
30
  this.task_id = task_id || 0;
31
31
  this.task_type = task_type || WorkflowTaskNames_1.TaskType.SIMPLE;
32
32
  this.category = category || WorkflowTaskNames_2.CategoryType.CREATE;
33
- this.service_id = service_id ?? null;
34
- this.sub_service_id = sub_service_id ?? null;
35
- this.service_type = service_type ?? null;
36
33
  }
37
34
  };
38
35
  exports.WorkflowTask = WorkflowTask;
@@ -44,18 +41,6 @@ __decorate([
44
41
  (0, typeorm_1.Column)({ type: 'varchar', length: 100, nullable: false }),
45
42
  __metadata("design:type", String)
46
43
  ], WorkflowTask.prototype, "name", void 0);
47
- __decorate([
48
- (0, typeorm_1.Column)({ type: 'int', nullable: true }),
49
- __metadata("design:type", Object)
50
- ], WorkflowTask.prototype, "service_id", void 0);
51
- __decorate([
52
- (0, typeorm_1.Column)({ type: 'int', nullable: true }),
53
- __metadata("design:type", Object)
54
- ], WorkflowTask.prototype, "sub_service_id", void 0);
55
- __decorate([
56
- (0, typeorm_1.Column)({ type: 'varchar', length: 50, nullable: true }),
57
- __metadata("design:type", Object)
58
- ], WorkflowTask.prototype, "service_type", void 0);
59
44
  __decorate([
60
45
  (0, typeorm_1.Column)({
61
46
  type: 'enum',
@@ -74,5 +59,5 @@ __decorate([
74
59
  ], WorkflowTask.prototype, "category", void 0);
75
60
  exports.WorkflowTask = WorkflowTask = __decorate([
76
61
  (0, typeorm_1.Entity)({ name: 'workflow_tasks' }),
77
- __metadata("design:paramtypes", [String, Number, String, String, Object, Object, Object])
62
+ __metadata("design:paramtypes", [String, Number, String, String])
78
63
  ], WorkflowTask);
File without changes
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ // import { Column, Entity, Unique } from "typeorm";
3
+ // import { BaseModel } from './BaseModel';
4
+ // @Entity({ name: 'workflows' })
5
+ // @Unique(['service_id', 'sub_service_id', 'request_for'])
6
+ // export class Workflows extends BaseModel {
7
+ // @Column({ type: 'varchar', length: 100, nullable: false })
8
+ // name: string;
9
+ // @Column({ type: 'bigint', nullable: false })
10
+ // service_id: number;
11
+ // @Column({ type: 'bigint', nullable: false })
12
+ // sub_service_id: number;
13
+ // @Column({ type: 'varchar', length: 20, nullable: false })
14
+ // request_for: string; // 'Self' | 'Behalf of' | 'Internal'
15
+ // @Column({ type: 'int', nullable: false })
16
+ // levels: number;
17
+ // constructor(
18
+ // name: string,
19
+ // service_id: number,
20
+ // sub_service_id: number,
21
+ // request_for: string,
22
+ // levels: number,
23
+ // ) {
24
+ // super();
25
+ // this.name = name;
26
+ // this.service_id = service_id;
27
+ // this.sub_service_id = sub_service_id;
28
+ // this.request_for = request_for;
29
+ // this.levels = levels;
30
+ // }
31
+ // }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@platform-modules/civil-aviation-authority",
3
- "version": "2.0.90",
3
+ "version": "2.1.1",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "scripts": {
@@ -47,6 +47,11 @@ import { VpnWorkFlow } from './models/VpnWorkflowModel';
47
47
  import { VpnRequestAttachment } from './models/VpnRequestAttachmentModel';
48
48
  import { VpnRequestChat } from './models/VpnRequestChatModel';
49
49
 
50
+ import { HotelReservation } from './models/HotelreservationModel'
51
+ import { HotelApprovalDetails } from './models/HotelApprovalModel';
52
+ import { HotelWorkFlow } from './models/HotelWorkFlowModel';
53
+ import { HotelRequestChat } from './models/HotelChatModel';
54
+ import { HotelRequestAttachment } from './models/HotelAttachedModel';
50
55
 
51
56
  export const AppDataSource = new DataSource({
52
57
  type: 'postgres',
@@ -100,6 +105,11 @@ export const AppDataSource = new DataSource({
100
105
  VpnApprovalDetails,
101
106
  VpnWorkFlow,
102
107
  VpnRequestAttachment,
103
- VpnRequestChat
108
+ VpnRequestChat,
109
+ HotelReservation,
110
+ HotelApprovalDetails,
111
+ HotelWorkFlow,
112
+ HotelRequestChat,
113
+ HotelRequestAttachment
104
114
  ],
105
115
  });
package/src/index.ts CHANGED
@@ -42,3 +42,8 @@ export * from './models/VpnApprovalModel';
42
42
  export * from './models/VpnWorkflowModel';
43
43
  export * from './models/VpnRequestChatModel';
44
44
  export * from './models/VpnRequestAttachmentModel';
45
+ export * from './models/HotelreservationModel';
46
+ export * from './models/HotelApprovalModel';
47
+ export * from './models/HotelWorkFlowModel';
48
+ export * from './models/HotelChatModel';
49
+ export * from './models/HotelAttachedModel';
@@ -0,0 +1,79 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+
5
+ export enum HotelApprovalStatus {
6
+ PENDING = "Pending",
7
+ IN_PROGRESS = "In Progress",
8
+ APPROVED = "Approved",
9
+ REJECTED = "Rejected"
10
+ }
11
+
12
+ @Entity({ name: 'hotelapprovals' })
13
+
14
+ export class HotelApprovalDetails 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: false })
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: HotelApprovalStatus,default: HotelApprovalStatus.PENDING, nullable: false })
49
+ approval_status: HotelApprovalStatus;
50
+
51
+ constructor(
52
+ request_id: number,
53
+ approver_role_id: number,
54
+ comment: string,
55
+ approval_status: HotelApprovalStatus,
56
+ level: number,
57
+ department_id?: number | null,
58
+ section_id?: number | null,
59
+ approver_user_id?: number | null,
60
+ delegate_user_id?: number | null,
61
+ approved_by?: number | null,
62
+ service_id?: number,
63
+ sub_service_id?: number
64
+ ) {
65
+ super();
66
+ this.request_id = request_id;
67
+ this.service_id = service_id || null;
68
+ this.sub_service_id = sub_service_id || null;
69
+ this.approver_role_id = approver_role_id;
70
+ this.comment = comment;
71
+ this.approval_status = approval_status;
72
+ this.level = level;
73
+ this.department_id = department_id || null;
74
+ this.section_id = section_id || null;
75
+ this.approver_user_id = approver_user_id || null;
76
+ this.delegate_user_id = delegate_user_id || null;
77
+ this.approved_by = approved_by || null;
78
+ }
79
+ }
@@ -0,0 +1,64 @@
1
+ import { Column, Entity, ManyToOne, JoinColumn } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+
5
+ @Entity({ name: 'hotel_request_attachments' })
6
+ export class HotelRequestAttachment extends BaseModel {
7
+
8
+ @Column({ type: 'integer', nullable: false })
9
+ request_id: number;
10
+
11
+ @Column({ type: 'integer', nullable: true })
12
+ service_id: number | null;
13
+
14
+ @Column({ type: 'integer', nullable: true })
15
+ sub_service_id: number | null;
16
+
17
+ @Column({ type: 'varchar', length: 500, nullable: false })
18
+ file_url: string;
19
+
20
+ @Column({ type: 'varchar', length: 255, nullable: true })
21
+ file_name: string;
22
+
23
+ @Column({ type: 'varchar', length: 100, nullable: true })
24
+ file_type: string;
25
+
26
+ @Column({ type: 'bigint', nullable: true })
27
+ file_size: number | null;
28
+
29
+ @Column({ type: 'integer', nullable: true })
30
+ chat_id: number | null;
31
+
32
+ @Column({ type: "integer", nullable: false })
33
+ uploaded_by: number;
34
+
35
+ @Column({ type: "text", nullable: true })
36
+ description: string;
37
+
38
+
39
+ constructor(
40
+ request_id: number,
41
+ uploaded_by: number,
42
+ file_url: string,
43
+ file_name?: string,
44
+ file_type?: string,
45
+ file_size?: number,
46
+ service_id?: number,
47
+ sub_service_id?: number,
48
+ chat_id?: number,
49
+ description?: string
50
+ ) {
51
+ super();
52
+ this.request_id = request_id;
53
+ this.service_id = service_id || null;
54
+ this.sub_service_id = sub_service_id || null;
55
+ this.file_url = file_url;
56
+ this.file_name = file_name || '';
57
+ this.file_type = file_type || '';
58
+ this.file_size = file_size || null;
59
+ this.chat_id = chat_id || null;
60
+ this.uploaded_by = uploaded_by;
61
+ this.description = description || '';
62
+ }
63
+ }
64
+
@@ -0,0 +1,55 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum HotelMessageTypes {
5
+ TEXT = "text",
6
+ IMAGE = "image",
7
+ VIDEO = "video",
8
+ FILE = "file",
9
+ LINK = "link"
10
+ }
11
+
12
+ @Entity({ name: 'Hotel_request_chat' })
13
+ export class HotelRequestChat extends BaseModel {
14
+
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
+ user_id: number;
26
+
27
+ @Column({ type: 'text', nullable: false })
28
+ message: string;
29
+
30
+ @Column({
31
+ type: 'enum',
32
+ enum: HotelMessageTypes,
33
+ default: HotelMessageTypes.TEXT,
34
+ nullable: false
35
+ })
36
+ messageType: HotelMessageTypes;
37
+
38
+ constructor(
39
+ request_id: number,
40
+ user_id: number,
41
+ message: string,
42
+ service_id?: number,
43
+ sub_service_id?: number,
44
+ messageType?: HotelMessageTypes
45
+ ) {
46
+ super();
47
+ this.request_id = request_id;
48
+ this.service_id = service_id || null;
49
+ this.sub_service_id = sub_service_id || null;
50
+ this.user_id = user_id;
51
+ this.message = message;
52
+ this.messageType = messageType || HotelMessageTypes.TEXT;
53
+ }
54
+ }
55
+
@@ -0,0 +1,42 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum HotelWorkFlowStatus {
5
+ COMPLETED = "Completed",
6
+ NOT_YET_STARTED = "Not Yet Started",
7
+ PENDING = "Pending"
8
+ }
9
+
10
+ //This model is used to store the logistics workflow status and activity logs
11
+ @Entity({ name: 'hotel_workflows' })
12
+ export class HotelWorkFlow 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: 'varchar', length: 500, nullable: false })
23
+ content: string;
24
+
25
+ @Column({ type: 'enum', enum: HotelWorkFlowStatus, default: HotelWorkFlowStatus.NOT_YET_STARTED, nullable: false })
26
+ status: HotelWorkFlowStatus;
27
+
28
+ constructor(
29
+ request_id: number,
30
+ content: string,
31
+ status: HotelWorkFlowStatus,
32
+ service_id?: number,
33
+ sub_service_id?: number
34
+ ) {
35
+ super();
36
+ this.request_id = request_id;
37
+ this.service_id = service_id || null;
38
+ this.sub_service_id = sub_service_id || null;
39
+ this.content = content;
40
+ this.status = status;
41
+ }
42
+ }
@@ -0,0 +1,164 @@
1
+ import { Entity, Column } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MealType {
5
+ BREAKFAST = "Breakfast",
6
+ LUNCH = "Lunch",
7
+ DINNER = "Dinner",
8
+ }
9
+
10
+ export enum ServiceTypes {
11
+ LAUNDRY = "Laundry",
12
+ TELEPHONE = "Telephone Service",
13
+ }
14
+
15
+ export enum HotelReservationStatus {
16
+ PENDING = "Pending",
17
+ APPROVED = "Approved",
18
+ REJECTED = "Rejected",
19
+ IN_PROGRESS = "In Progress"
20
+ }
21
+
22
+ @Entity({ name:'hotelreservations'})
23
+ export class HotelReservation extends BaseModel {
24
+ // Workflow fields (similar to IT Help Desk)
25
+ @Column({ type: 'int', nullable: true })
26
+ req_user_department_id: number | null;
27
+
28
+ @Column({ type: 'int', nullable: true })
29
+ req_user_section_id: number | null;
30
+
31
+ @Column({ type: 'int', nullable: true })
32
+ service_id: number | null;
33
+
34
+ @Column({ type: 'int', nullable: true })
35
+ sub_service_id: number | null;
36
+
37
+ @Column({ type: 'varchar', length: 20, nullable: true })
38
+ service_type: string | null; // 'internal' or 'external'
39
+
40
+ @Column({ type: 'varchar', nullable: true })
41
+ workflow_execution_id: string | null;
42
+
43
+ @Column({
44
+ type: "enum",
45
+ enum: HotelReservationStatus,
46
+ default: HotelReservationStatus.PENDING,
47
+ nullable: false,
48
+ })
49
+ status: HotelReservationStatus;
50
+
51
+ @Column({ nullable: false })
52
+ user_id: number;
53
+
54
+ // Hotel reservation specific fields
55
+ @Column({ type: 'varchar', length: 50 })
56
+ type_of_accommodation: string;
57
+
58
+ @Column({ type: 'decimal', precision: 10, scale: 2, nullable: false })
59
+ price: number;
60
+
61
+ @Column({ type: 'enum', enum: MealType, nullable: false, })
62
+ meal: MealType;
63
+
64
+ @Column({ type: 'enum', enum: ServiceTypes, nullable: false, })
65
+ service: ServiceTypes;
66
+
67
+ @Column({ type: 'timestamptz', nullable: false })
68
+ date_of_request: Date;
69
+
70
+ @Column({ type: 'varchar', length: 100, nullable: false })
71
+ hotel_name: string;
72
+
73
+ @Column({ type: 'date', nullable: false })
74
+ check_in_date: Date;
75
+
76
+ @Column({ type: 'time', nullable: false })
77
+ check_in_time: string;
78
+
79
+ @Column({ type: 'date', nullable: false })
80
+ check_out_date: Date;
81
+
82
+ @Column({ type: 'date', nullable: false })
83
+ booking_date: Date;
84
+
85
+ @Column({ type: 'time', nullable: false })
86
+ check_out_time: string;
87
+
88
+ @Column({ type: 'int', nullable: false })
89
+ number_of_guests: number;
90
+
91
+ @Column({ type: 'text', nullable: true })
92
+ description: string;
93
+
94
+ @Column({ type: 'text', nullable: true })
95
+ attachment_url: string | null;
96
+
97
+ @Column({ type: 'varchar', length: 100, nullable: false })
98
+ requested_by: string;
99
+
100
+ @Column({ type: 'varchar', length: 100, nullable: true })
101
+ visitor_name: string | null;
102
+
103
+ @Column({ type: 'boolean', default: false })
104
+ hr_approval: boolean;
105
+
106
+ @Column({ type: 'boolean', default: false })
107
+ pr_approval: boolean;
108
+
109
+
110
+ constructor(
111
+ type_of_accommodation: string,
112
+ price: number,
113
+ meal: MealType,
114
+ service: ServiceTypes,
115
+ date_of_request: Date,
116
+ hotel_name: string,
117
+ check_in_date: Date,
118
+ check_in_time: string,
119
+ check_out_date: Date,
120
+ check_out_time: string,
121
+ number_of_guests: number,
122
+ description: string,
123
+ requested_by: string,
124
+ visitor_name: string,
125
+ user_id: number,
126
+ status: HotelReservationStatus = HotelReservationStatus.PENDING,
127
+ hr_approval: boolean = false,
128
+ pr_approval: boolean = false,
129
+ service_id?: number | null,
130
+ sub_service_id?: number | null,
131
+ service_type?: string | null,
132
+ workflow_execution_id?: string | null,
133
+ req_user_department_id?: number | null,
134
+ req_user_section_id?: number | null,
135
+ attachment_url?: string | null
136
+ ) {
137
+ super();
138
+ this.type_of_accommodation = type_of_accommodation;
139
+ this.price = price;
140
+ this.meal = meal;
141
+ this.service = service;
142
+ this.date_of_request = date_of_request;
143
+ this.hotel_name = hotel_name;
144
+ this.check_in_date = check_in_date;
145
+ this.check_in_time = check_in_time;
146
+ this.check_out_date = check_out_date;
147
+ this.check_out_time = check_out_time;
148
+ this.number_of_guests = number_of_guests;
149
+ this.description = description;
150
+ this.requested_by = requested_by;
151
+ this.visitor_name = visitor_name;
152
+ this.user_id = user_id;
153
+ this.status = status;
154
+ this.hr_approval = hr_approval;
155
+ this.pr_approval = pr_approval;
156
+ this.service_id = service_id ?? null;
157
+ this.sub_service_id = sub_service_id ?? null;
158
+ this.service_type = service_type ?? null;
159
+ this.workflow_execution_id = workflow_execution_id ?? null;
160
+ this.req_user_department_id = req_user_department_id ?? null;
161
+ this.req_user_section_id = req_user_section_id ?? null;
162
+ this.attachment_url = attachment_url ?? null;
163
+ }
164
+ }