@platform-modules/civil-aviation-authority 2.3.208 → 2.3.210

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 (36) hide show
  1. package/dist/data-source.js +20 -0
  2. package/dist/index.d.ts +10 -0
  3. package/dist/index.js +11 -0
  4. package/dist/models/MaintenanceApprovalModel.d.ts +22 -0
  5. package/dist/models/MaintenanceApprovalModel.js +84 -0
  6. package/dist/models/MaintenanceAttachmentModel.d.ts +11 -0
  7. package/dist/models/MaintenanceAttachmentModel.js +52 -0
  8. package/dist/models/MaintenanceChatModel.d.ts +18 -0
  9. package/dist/models/MaintenanceChatModel.js +65 -0
  10. package/dist/models/MaintenanceRequestModel.d.ts +42 -0
  11. package/dist/models/MaintenanceRequestModel.js +125 -0
  12. package/dist/models/MaintenanceWorkflowModel.d.ts +17 -0
  13. package/dist/models/MaintenanceWorkflowModel.js +67 -0
  14. package/dist/models/MediaPublicationsApprovalModel.d.ts +22 -0
  15. package/dist/models/MediaPublicationsApprovalModel.js +84 -0
  16. package/dist/models/MediaPublicationsAttachmentModel.d.ts +11 -0
  17. package/dist/models/MediaPublicationsAttachmentModel.js +52 -0
  18. package/dist/models/MediaPublicationsChatModel.d.ts +18 -0
  19. package/dist/models/MediaPublicationsChatModel.js +65 -0
  20. package/dist/models/MediaPublicationsRequestModel.d.ts +40 -0
  21. package/dist/models/MediaPublicationsRequestModel.js +138 -0
  22. package/dist/models/MediaPublicationsWorkflowModel.d.ts +17 -0
  23. package/dist/models/MediaPublicationsWorkflowModel.js +67 -0
  24. package/package.json +1 -1
  25. package/src/data-source.ts +20 -0
  26. package/src/index.ts +12 -0
  27. package/src/models/MaintenanceApprovalModel.ts +56 -0
  28. package/src/models/MaintenanceAttachmentModel.ts +29 -0
  29. package/src/models/MaintenanceChatModel.ts +42 -0
  30. package/src/models/MaintenanceRequestModel.ts +94 -0
  31. package/src/models/MaintenanceWorkflowModel.ts +43 -0
  32. package/src/models/MediaPublicationsApprovalModel.ts +56 -0
  33. package/src/models/MediaPublicationsAttachmentModel.ts +29 -0
  34. package/src/models/MediaPublicationsChatModel.ts +42 -0
  35. package/src/models/MediaPublicationsRequestModel.ts +102 -0
  36. package/src/models/MediaPublicationsWorkflowModel.ts +43 -0
@@ -0,0 +1,42 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MaintenanceMessageType {
5
+ TEXT = 'text',
6
+ IMAGE = 'image',
7
+ VIDEO = 'video',
8
+ FILE = 'file',
9
+ LINK = 'link',
10
+ }
11
+
12
+ @Entity({ name: 'maintenance_chats' })
13
+ export class MaintenanceChat 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: MaintenanceMessageType,
35
+ default: MaintenanceMessageType.TEXT,
36
+ nullable: false,
37
+ })
38
+ messageType: MaintenanceMessageType;
39
+
40
+ @Column({ type: 'text', nullable: true })
41
+ status: string;
42
+ }
@@ -0,0 +1,94 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ /** Subject / handling priority classification */
5
+ export enum MaintenanceSubjectClassification {
6
+ URGENT = 'Urgent',
7
+ VERY_URGENT = 'Very Urgent',
8
+ CONFIDENTIAL = 'Confidential',
9
+ INFORMATIONAL = 'Informational',
10
+ NORMAL = 'Normal',
11
+ }
12
+
13
+ /** Concerned department under General Manager of Support Services */
14
+ export enum MaintenanceConcernedDepartment {
15
+ IT = 'IT',
16
+ HR = 'HR',
17
+ TRAINING = 'Training',
18
+ FINANCE = 'Finance',
19
+ PROJECTS_AND_MAINTENANCE = 'Projects & Maintenance',
20
+ }
21
+
22
+ export enum MaintenanceRequestStatus {
23
+ PENDING = 'Pending',
24
+ ASSIGNED = 'Assigned',
25
+ IN_PROGRESS = 'In Progress',
26
+ APPROVED = 'Approved',
27
+ REJECTED = 'Rejected',
28
+ }
29
+
30
+ @Entity({ name: 'maintenance_requests' })
31
+ export class MaintenanceRequests extends BaseModel {
32
+ @Column({ type: 'int', nullable: true })
33
+ req_user_department_id: number | null;
34
+
35
+ @Column({ type: 'int', nullable: true })
36
+ req_user_section_id: number | null;
37
+
38
+ @Column({ nullable: true })
39
+ service_id: number;
40
+
41
+ @Column({ nullable: true })
42
+ sub_service_id: number;
43
+
44
+ @Column({ nullable: false })
45
+ user_id: number;
46
+
47
+ @Column({ type: 'varchar', length: 500, nullable: false })
48
+ sent_by: string;
49
+
50
+ @Column({ type: 'date', nullable: false })
51
+ letter_date: Date;
52
+
53
+ @Column({ type: 'varchar', length: 500, nullable: false })
54
+ subject: string;
55
+
56
+ @Column({
57
+ type: 'enum',
58
+ enum: MaintenanceSubjectClassification,
59
+ enumName: 'maintenance_subject_classification_en',
60
+ nullable: false,
61
+ })
62
+ subject_classification: MaintenanceSubjectClassification;
63
+
64
+ @Column({ type: 'text', nullable: false })
65
+ topic: string;
66
+
67
+ @Column({
68
+ type: 'enum',
69
+ enum: MaintenanceConcernedDepartment,
70
+ enumName: 'maintenance_concerned_department_en',
71
+ nullable: false,
72
+ })
73
+ concerned_department: MaintenanceConcernedDepartment;
74
+
75
+ @Column({ type: 'date', nullable: false })
76
+ date_from: Date;
77
+
78
+ @Column({ type: 'date', nullable: false })
79
+ date_to: Date;
80
+
81
+ @Column({ type: 'date', nullable: false, default: () => 'CURRENT_DATE' })
82
+ request_submission_date: Date;
83
+
84
+ @Column({
85
+ type: 'enum',
86
+ enum: MaintenanceRequestStatus,
87
+ default: MaintenanceRequestStatus.PENDING,
88
+ nullable: false,
89
+ })
90
+ status: MaintenanceRequestStatus;
91
+
92
+ @Column({ type: 'varchar', nullable: true })
93
+ workflow_execution_id: string | null;
94
+ }
@@ -0,0 +1,43 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MaintenanceWorkFlowStatus {
5
+ COMPLETED = 'Completed',
6
+ NOT_YET_STARTED = 'Not Yet Started',
7
+ PENDING = 'Pending',
8
+ }
9
+
10
+ @Entity({ name: 'maintenance_workflows' })
11
+ export class MaintenanceWorkFlow 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({
25
+ type: 'enum',
26
+ enum: MaintenanceWorkFlowStatus,
27
+ default: MaintenanceWorkFlowStatus.NOT_YET_STARTED,
28
+ nullable: false,
29
+ })
30
+ status: MaintenanceWorkFlowStatus;
31
+
32
+ @Column({ type: 'integer', nullable: true })
33
+ user_id: number | null;
34
+
35
+ @Column({ type: 'integer', nullable: true })
36
+ role_id: number | null;
37
+
38
+ @Column({ type: 'integer', nullable: true })
39
+ department_id: number | null;
40
+
41
+ @Column({ type: 'integer', nullable: true })
42
+ section_id: number | null;
43
+ }
@@ -0,0 +1,56 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaPublicationsApprovalStatus {
5
+ PENDING = 'Pending',
6
+ IN_PROGRESS = 'In Progress',
7
+ APPROVED = 'Approved',
8
+ REJECTED = 'Rejected',
9
+ }
10
+
11
+ @Entity({ name: 'media_publications_approvals' })
12
+ export class MediaPublicationsApprovalDetails 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: MediaPublicationsApprovalStatus,
49
+ default: MediaPublicationsApprovalStatus.PENDING,
50
+ nullable: false,
51
+ })
52
+ approval_status: MediaPublicationsApprovalStatus;
53
+
54
+ @Column({ type: 'boolean', default: true, nullable: false })
55
+ is_allowed: boolean;
56
+ }
@@ -0,0 +1,29 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'media_publications_attachments' })
5
+ export class MediaPublicationsAttachment 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,42 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaPublicationsMessageType {
5
+ TEXT = 'text',
6
+ IMAGE = 'image',
7
+ VIDEO = 'video',
8
+ FILE = 'file',
9
+ LINK = 'link',
10
+ }
11
+
12
+ @Entity({ name: 'media_publications_chats' })
13
+ export class MediaPublicationsChat 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: MediaPublicationsMessageType,
35
+ default: MediaPublicationsMessageType.TEXT,
36
+ nullable: false,
37
+ })
38
+ messageType: MediaPublicationsMessageType;
39
+
40
+ @Column({ type: 'text', nullable: true })
41
+ status: string;
42
+ }
@@ -0,0 +1,102 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaPublicationsRequestType {
5
+ NORMAL = 'Normal',
6
+ URGENT = 'Urgent',
7
+ }
8
+
9
+ export enum MediaPublicationsEventType {
10
+ LOCAL_INTERNAL = 'Local Internal Event',
11
+ LOCAL_EXTERNAL = 'Local External Event',
12
+ REGIONAL_OR_INTERNATIONAL = 'Regional or International Event',
13
+ }
14
+
15
+ export enum MediaPublicationsRequestStatus {
16
+ PENDING = 'Pending',
17
+ ASSIGNED = 'Assigned',
18
+ IN_PROGRESS = 'In Progress',
19
+ APPROVED = 'Approved',
20
+ REJECTED = 'Rejected',
21
+ }
22
+
23
+ @Entity({ name: 'media_publications_requests' })
24
+ export class MediaPublicationsRequests extends BaseModel {
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({ nullable: true })
32
+ service_id: number;
33
+
34
+ @Column({ nullable: true })
35
+ sub_service_id: number;
36
+
37
+ @Column({ nullable: false })
38
+ user_id: number;
39
+
40
+ @Column({ type: 'date', nullable: false, default: () => 'CURRENT_DATE' })
41
+ request_submission_date: Date;
42
+
43
+ @Column({ type: 'varchar', length: 500, nullable: true })
44
+ requestor_name: string | null;
45
+
46
+ @Column({ type: 'varchar', length: 500, nullable: true })
47
+ requestor_department: string | null;
48
+
49
+ @Column({ type: 'varchar', length: 500, nullable: true })
50
+ requestor_designation: string | null;
51
+
52
+ @Column({ type: 'varchar', length: 100, nullable: true })
53
+ contact_number: string | null;
54
+
55
+ @Column({ type: 'varchar', length: 320, nullable: true })
56
+ email: string | null;
57
+
58
+ @Column({
59
+ type: 'enum',
60
+ enum: MediaPublicationsRequestType,
61
+ enumName: 'media_publications_request_type_en',
62
+ nullable: false,
63
+ })
64
+ request_type: MediaPublicationsRequestType;
65
+
66
+ @Column({ type: 'varchar', length: 120, nullable: false })
67
+ item_code: string;
68
+
69
+ @Column({ type: 'text', nullable: false })
70
+ description: string;
71
+
72
+ @Column({ type: 'decimal', precision: 14, scale: 2, nullable: false })
73
+ cost: number;
74
+
75
+ @Column({ type: 'date', nullable: false })
76
+ publication_date: Date;
77
+
78
+ @Column({
79
+ type: 'enum',
80
+ enum: MediaPublicationsEventType,
81
+ enumName: 'media_publications_event_type_en',
82
+ nullable: false,
83
+ })
84
+ event_type: MediaPublicationsEventType;
85
+
86
+ @Column({ type: 'int', nullable: true })
87
+ quantity: number | null;
88
+
89
+ @Column({ type: 'decimal', precision: 14, scale: 2, nullable: true })
90
+ unit_price: number | null;
91
+
92
+ @Column({
93
+ type: 'enum',
94
+ enum: MediaPublicationsRequestStatus,
95
+ default: MediaPublicationsRequestStatus.PENDING,
96
+ nullable: false,
97
+ })
98
+ status: MediaPublicationsRequestStatus;
99
+
100
+ @Column({ type: 'varchar', nullable: true })
101
+ workflow_execution_id: string | null;
102
+ }
@@ -0,0 +1,43 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum MediaPublicationsWorkFlowStatus {
5
+ COMPLETED = 'Completed',
6
+ NOT_YET_STARTED = 'Not Yet Started',
7
+ PENDING = 'Pending',
8
+ }
9
+
10
+ @Entity({ name: 'media_publications_workflows' })
11
+ export class MediaPublicationsWorkFlow 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({
25
+ type: 'enum',
26
+ enum: MediaPublicationsWorkFlowStatus,
27
+ default: MediaPublicationsWorkFlowStatus.NOT_YET_STARTED,
28
+ nullable: false,
29
+ })
30
+ status: MediaPublicationsWorkFlowStatus;
31
+
32
+ @Column({ type: 'integer', nullable: true })
33
+ user_id: number | null;
34
+
35
+ @Column({ type: 'integer', nullable: true })
36
+ role_id: number | null;
37
+
38
+ @Column({ type: 'integer', nullable: true })
39
+ department_id: number | null;
40
+
41
+ @Column({ type: 'integer', nullable: true })
42
+ section_id: number | null;
43
+ }