@platform-modules/foreign-ministry 1.1.76 → 1.1.77

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 (134) hide show
  1. package/.env +11 -3
  2. package/dist/data-source.js +32 -16
  3. package/dist/index.d.ts +25 -8
  4. package/dist/index.js +40 -8
  5. package/dist/models/EarlyCheckoutBalanceModel.d.ts +7 -0
  6. package/dist/models/{DiplomaticClubCardChatModel.js → EarlyCheckoutBalanceModel.js} +21 -18
  7. package/dist/models/EarlyCheckoutConfigModel.d.ts +18 -0
  8. package/dist/models/EarlyCheckoutConfigModel.js +80 -0
  9. package/dist/models/EarlyCheckoutTransactionModel.d.ts +19 -0
  10. package/dist/models/EarlyCheckoutTransactionModel.js +66 -0
  11. package/dist/models/FinancialApprovalsModel.d.ts +1 -0
  12. package/dist/models/FinancialApprovalsModel.js +4 -0
  13. package/dist/models/FinancialGradeModel.d.ts +4 -3
  14. package/dist/models/FinancialGradeModel.js +12 -7
  15. package/dist/models/GeneralServiceApprovalsModel.d.ts +4 -1
  16. package/dist/models/GeneralServiceApprovalsModel.js +9 -0
  17. package/dist/models/HelpContentMappedCategoriesModel.d.ts +6 -0
  18. package/dist/models/HelpContentMappedCategoriesModel.js +34 -0
  19. package/dist/models/HelpContentMappedTagsModel.d.ts +6 -0
  20. package/dist/models/HelpContentMappedTagsModel.js +34 -0
  21. package/dist/models/HelpContentTagsModel.d.ts +5 -0
  22. package/dist/models/HelpContentTagsModel.js +29 -0
  23. package/dist/models/LeaveBalanceModel.d.ts +8 -0
  24. package/dist/models/{PassportRequestChatModel.js → LeaveBalanceModel.js} +23 -23
  25. package/dist/models/LeaveConfigGradesModel.d.ts +19 -0
  26. package/dist/models/LeaveConfigGradesModel.js +100 -0
  27. package/dist/models/LeaveConfigModel.d.ts +20 -0
  28. package/dist/models/LeaveConfigModel.js +90 -0
  29. package/dist/models/LeaveTransactionModel.d.ts +20 -0
  30. package/dist/models/LeaveTransactionModel.js +71 -0
  31. package/dist/models/LeaveTypesModel.d.ts +7 -1
  32. package/dist/models/LeaveTypesModel.js +20 -5
  33. package/dist/models/M&CMasterModel.d.ts +9 -0
  34. package/dist/models/M&CMasterModel.js +49 -0
  35. package/dist/models/ProfileUpdateRequestsModel.d.ts +106 -0
  36. package/dist/models/ProfileUpdateRequestsModel.js +409 -0
  37. package/dist/models/StationeryMaterialMasterModel.d.ts +11 -0
  38. package/dist/models/{DiplomaticTitlesMasterModel.js → StationeryMaterialMasterModel.js} +25 -23
  39. package/dist/models/StationeryRequestsModel.d.ts +27 -0
  40. package/dist/models/StationeryRequestsModel.js +93 -0
  41. package/dist/models/StayAfterHoursBalanceModel.d.ts +7 -0
  42. package/dist/models/StayAfterHoursBalanceModel.js +39 -0
  43. package/dist/models/StayAfterHoursTransactionModel.d.ts +19 -0
  44. package/dist/models/StayAfterHoursTransactionModel.js +66 -0
  45. package/dist/models/TransferMissionApprovalModel.d.ts +1 -0
  46. package/dist/models/TransferMissionApprovalModel.js +4 -0
  47. package/dist/models/UserEducationDetailsModel.d.ts +12 -0
  48. package/dist/models/UserEducationDetailsModel.js +44 -0
  49. package/dist/models/UserEmploymentDetailsModel.d.ts +50 -0
  50. package/dist/models/UserEmploymentDetailsModel.js +193 -0
  51. package/dist/models/UserPersonalDetailsModel.d.ts +48 -0
  52. package/dist/models/UserPersonalDetailsModel.js +185 -0
  53. package/dist/models/questionTagsModel.d.ts +6 -0
  54. package/dist/models/questionTagsModel.js +34 -0
  55. package/dist/models/user.d.ts +2 -1
  56. package/dist/models/user.js +7 -2
  57. package/package.json +1 -1
  58. package/src/data-source.ts +35 -17
  59. package/src/index.ts +25 -8
  60. package/src/models/EarlyCheckoutBalanceModel.ts +22 -0
  61. package/src/models/EarlyCheckoutConfigModel.ts +57 -0
  62. package/src/models/EarlyCheckoutTransactionModel.ts +53 -0
  63. package/src/models/FinancialApprovalsModel.ts +4 -0
  64. package/src/models/FinancialGradeModel.ts +13 -8
  65. package/src/models/GeneralServiceApprovalsModel.ts +10 -1
  66. package/src/models/LeaveBalanceModel.ts +26 -0
  67. package/src/models/LeaveConfigGradesModel.ts +72 -0
  68. package/src/models/LeaveConfigModel.ts +64 -0
  69. package/src/models/LeaveTransactionModel.ts +58 -0
  70. package/src/models/LeaveTypesModel.ts +27 -11
  71. package/src/models/M&CMasterModel.ts +37 -0
  72. package/src/models/ProfileUpdateRequestsModel.ts +317 -0
  73. package/src/models/StationeryMaterialMasterModel.ts +35 -0
  74. package/src/models/StationeryRequestsModel.ts +65 -0
  75. package/src/models/StayAfterHoursBalanceModel.ts +22 -0
  76. package/src/models/StayAfterHoursTransactionModel.ts +53 -0
  77. package/src/models/TransferMissionApprovalModel.ts +3 -0
  78. package/src/models/UserEducationDetailsModel.ts +26 -0
  79. package/src/models/UserEmploymentDetailsModel.ts +141 -0
  80. package/src/models/UserPersonalDetailsModel.ts +137 -0
  81. package/src/models/user.ts +5 -0
  82. package/dist/models/DiplomaticApprovalsModel.d.ts +0 -24
  83. package/dist/models/DiplomaticApprovalsModel.js +0 -94
  84. package/dist/models/DiplomaticAttachmentsModel.d.ts +0 -11
  85. package/dist/models/DiplomaticAttachmentsModel.js +0 -53
  86. package/dist/models/DiplomaticChatsModel.d.ts +0 -20
  87. package/dist/models/DiplomaticChatsModel.js +0 -70
  88. package/dist/models/DiplomaticClubCardApprovalModel.d.ts +0 -16
  89. package/dist/models/DiplomaticClubCardApprovalModel.js +0 -58
  90. package/dist/models/DiplomaticClubCardAttachmentModel.d.ts +0 -9
  91. package/dist/models/DiplomaticClubCardAttachmentModel.js +0 -44
  92. package/dist/models/DiplomaticClubCardChatModel.d.ts +0 -7
  93. package/dist/models/DiplomaticClubCardMemberModel.d.ts +0 -13
  94. package/dist/models/DiplomaticClubCardMemberModel.js +0 -60
  95. package/dist/models/DiplomaticClubCardMembersModel.d.ts +0 -26
  96. package/dist/models/DiplomaticClubCardMembersModel.js +0 -85
  97. package/dist/models/DiplomaticClubCardRequestModel.d.ts +0 -33
  98. package/dist/models/DiplomaticClubCardRequestModel.js +0 -98
  99. package/dist/models/DiplomaticClubCardWorkFlowModel.d.ts +0 -12
  100. package/dist/models/DiplomaticClubCardWorkFlowModel.js +0 -42
  101. package/dist/models/DiplomaticClubSubscriptionMasterModel.d.ts +0 -12
  102. package/dist/models/DiplomaticClubSubscriptionMasterModel.js +0 -64
  103. package/dist/models/DiplomaticRequestsModel.d.ts +0 -53
  104. package/dist/models/DiplomaticRequestsModel.js +0 -182
  105. package/dist/models/DiplomaticServiceDetailsModel.d.ts +0 -20
  106. package/dist/models/DiplomaticServiceDetailsModel.js +0 -65
  107. package/dist/models/DiplomaticSettingsModel.d.ts +0 -11
  108. package/dist/models/DiplomaticSettingsModel.js +0 -59
  109. package/dist/models/DiplomaticTitleModel.d.ts +0 -12
  110. package/dist/models/DiplomaticTitleModel.js +0 -45
  111. package/dist/models/DiplomaticTitlesMasterModel.d.ts +0 -13
  112. package/dist/models/DiplomaticWorkFlowModel.d.ts +0 -18
  113. package/dist/models/DiplomaticWorkFlowModel.js +0 -69
  114. package/dist/models/PassportRequestApprovalModel.d.ts +0 -22
  115. package/dist/models/PassportRequestApprovalModel.js +0 -91
  116. package/dist/models/PassportRequestAttachmentModel.d.ts +0 -10
  117. package/dist/models/PassportRequestAttachmentModel.js +0 -54
  118. package/dist/models/PassportRequestChatModel.d.ts +0 -8
  119. package/dist/models/PassportRequestDependentModel.d.ts +0 -20
  120. package/dist/models/PassportRequestDependentModel.js +0 -85
  121. package/dist/models/PassportRequestModel.d.ts +0 -40
  122. package/dist/models/PassportRequestModel.js +0 -128
  123. package/dist/models/PassportRequestWorkFlowModel.d.ts +0 -15
  124. package/dist/models/PassportRequestWorkFlowModel.js +0 -60
  125. package/dist/models/SubscriptionAmountModel.d.ts +0 -67
  126. package/dist/models/SubscriptionAmountModel.js +0 -114
  127. package/src/models/DiplomaticApprovalsModel.ts +0 -77
  128. package/src/models/DiplomaticAttachmentsModel.ts +0 -37
  129. package/src/models/DiplomaticChatsModel.ts +0 -53
  130. package/src/models/DiplomaticClubCardMembersModel.ts +0 -71
  131. package/src/models/DiplomaticClubSubscriptionMasterModel.ts +0 -50
  132. package/src/models/DiplomaticRequestsModel.ts +0 -151
  133. package/src/models/DiplomaticTitlesMasterModel.ts +0 -39
  134. package/src/models/DiplomaticWorkFlowModel.ts +0 -53
@@ -0,0 +1,65 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum StationeryRequestStatus {
5
+ PENDING = "Pending",
6
+ ASSIGNED = "Assigned",
7
+ IN_PROGRESS = "In Progress",
8
+ APPROVED = "Approved",
9
+ REJECTED = "Rejected",
10
+ COMPLETED = "Completed"
11
+ }
12
+
13
+
14
+ @Entity({ name: 'stationery_requests' })
15
+ export class StationeryRequests extends BaseModel {
16
+ @Column({ type: 'int', nullable: true })
17
+ req_user_department_id: number | null;
18
+
19
+ @Column({ type: 'int', nullable: true })
20
+ req_user_section_id: number | null;
21
+
22
+ @Column({ type: 'int', nullable: true })
23
+ service_id: number | null;
24
+
25
+ @Column({ type: 'int', nullable: true })
26
+ sub_service_id: number | null;
27
+
28
+ @Column({ type: 'int', nullable: false })
29
+ user_id: number;
30
+
31
+ @Column({ type: 'date', nullable: false })
32
+ date_of_request_preparation: Date;
33
+
34
+ @Column({ type: 'varchar', length: 255, nullable: false })
35
+ office: string;
36
+
37
+ @Column({ type: 'varchar', length: 255, nullable: false })
38
+ material_type: string;
39
+
40
+ @Column({ type: 'varchar', length: 255, nullable: false })
41
+ material_name: string;
42
+
43
+ @Column({ type: 'int', nullable: false })
44
+ quantity_required: number;
45
+
46
+ @Column({ type: 'varchar', length: 500, nullable: true })
47
+ comments: string | null;
48
+
49
+ @Column({ type: 'enum', enum: StationeryRequestStatus, default: StationeryRequestStatus.PENDING, nullable: false })
50
+ status: StationeryRequestStatus;
51
+
52
+ @Column({ type: 'varchar', nullable: true })
53
+ workflow_execution_id: string | null;
54
+
55
+ // Business logic fields
56
+ @Column({ type: 'boolean', default: false, nullable: true })
57
+ stock_available: boolean | null; // Whether stock is available in Stores Office
58
+
59
+ @Column({ type: 'varchar', length: 100, nullable: true })
60
+ po_number: string | null; // Purchase Order number from Finance
61
+
62
+ @Column({ type: 'date', nullable: true })
63
+ stock_available_date: Date | null; // When stock becomes available
64
+ }
65
+
@@ -0,0 +1,22 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'stay_after_hours_balance' })
5
+ export class StayAfterHoursBalance extends BaseModel {
6
+
7
+ @Column({ nullable: true })
8
+ user_id: string;
9
+
10
+ @Column({ nullable: true })
11
+ balance: number;
12
+
13
+ @Column({ nullable: true })
14
+ total_balance: number;
15
+
16
+ constructor(user_id: string, balance: number, total_balance: number) {
17
+ super();
18
+ this.user_id = user_id;
19
+ this.balance = balance;
20
+ this.total_balance = total_balance;
21
+ }
22
+ }
@@ -0,0 +1,53 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum StayAfterHoursTransactionStatus {
5
+ GRANTED = 'GRANTED',
6
+ TAKEN = 'TAKEN',
7
+ ADJUSTMENT = 'ADJUSTMENT',
8
+ CARRY_FORWARD = 'CARRY_FORWARD',
9
+ ENCASHMENT = 'ENCASHMENT',
10
+ AVAILED = 'AVAILED',
11
+ ELAPSED = 'ELAPSED'
12
+ }
13
+
14
+ //This model is used to store early checkout transactions for users
15
+ @Entity({ name: 'stay_after_hours_transactions' })
16
+ export class StayAfterHoursTransaction extends BaseModel {
17
+
18
+ @Column({ type: 'int', nullable: false })
19
+ user_id: number;
20
+
21
+ @Column({ type: 'varchar', nullable: true })
22
+ hours_count: string;
23
+
24
+ @Column({ type: 'date', nullable: true })
25
+ from_date: Date;
26
+
27
+ @Column({ type: 'date', nullable: true })
28
+ to_date: Date;
29
+
30
+ @Column({ type: 'int', nullable: true })
31
+ year: number;
32
+
33
+ @Column({ type: 'varchar', nullable: false })
34
+ status: StayAfterHoursTransactionStatus;
35
+
36
+ constructor(
37
+ user_id: number,
38
+ hours_count: string,
39
+ from_date: Date,
40
+ to_date: Date,
41
+ year: number,
42
+ status: StayAfterHoursTransactionStatus
43
+ ) {
44
+ super();
45
+ this.user_id = user_id;
46
+ this.hours_count = hours_count;
47
+ this.from_date = from_date;
48
+ this.to_date = to_date;
49
+ this.year = year;
50
+ this.status = status;
51
+ }
52
+ }
53
+
@@ -37,6 +37,9 @@ export class TransferMissionApprovalDetails extends BaseModel {
37
37
  @Column({ type: 'integer', nullable: true })
38
38
  delegate_user_id: number | null;
39
39
 
40
+ @Column({ type: 'integer', nullable: true })
41
+ group_id: number | null;
42
+
40
43
  @Column({ type: 'integer', nullable: true })
41
44
  approved_by: number | null;
42
45
 
@@ -0,0 +1,26 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ /**
5
+ * User Education Details - only fields from business requirements
6
+ * Linked by user_id (not request_id)
7
+ */
8
+ @Entity({ name: 'user_education_details' })
9
+ export class UserEducationDetails extends BaseModel {
10
+ @Column({ type: 'int', nullable: false })
11
+ user_id: number; // Foreign key to users table
12
+
13
+ // Education Information
14
+ @Column({ type: 'date', nullable: true })
15
+ study_start_date: Date | null;
16
+
17
+ @Column({ type: 'date', nullable: true })
18
+ study_end_date: Date | null;
19
+
20
+ // Training Information
21
+ @Column({ type: 'date', nullable: true })
22
+ training_course_start_date: Date | null;
23
+
24
+ @Column({ type: 'date', nullable: true })
25
+ training_course_end_date: Date | null;
26
+ }
@@ -0,0 +1,141 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ /**
5
+ * User Employment Details - only fields from business requirements
6
+ * Linked by user_id (not request_id)
7
+ * When profile update is approved, data from this table updates users table
8
+ */
9
+ @Entity({ name: 'user_employment_details' })
10
+ export class UserEmploymentDetails extends BaseModel {
11
+ @Column({ type: 'int', nullable: false })
12
+ user_id: number; // Foreign key to users table
13
+
14
+ // Job Information
15
+ @Column({ type: 'varchar', length: 255, nullable: true })
16
+ job_title: string | null;
17
+
18
+ @Column({ type: 'date', nullable: true })
19
+ date_of_decree_issuance: Date | null;
20
+
21
+ @Column({ type: 'varchar', length: 100, nullable: true })
22
+ civil_service_number: string | null;
23
+
24
+ @Column({ type: 'varchar', length: 100, nullable: true })
25
+ information_number: string | null;
26
+
27
+ @Column({ type: 'varchar', length: 100, nullable: true })
28
+ manpower_number: string | null;
29
+
30
+ @Column({ type: 'varchar', length: 100, nullable: true })
31
+ computer_number: string | null;
32
+
33
+ @Column({ type: 'boolean', nullable: true })
34
+ contract_employee: boolean | null;
35
+
36
+ @Column({ type: 'varchar', length: 255, nullable: true })
37
+ nature_of_work: string | null;
38
+
39
+ @Column({ type: 'date', nullable: true })
40
+ retirement_date: Date | null;
41
+
42
+ @Column({ type: 'varchar', length: 255, nullable: true })
43
+ proposed_position: string | null;
44
+
45
+ @Column({ type: 'varchar', length: 100, nullable: true })
46
+ proposed_financial_grade: string | null;
47
+
48
+ @Column({ type: 'date', nullable: true })
49
+ secondment_start_date: Date | null;
50
+
51
+ @Column({ type: 'date', nullable: true })
52
+ secondment_end_date: Date | null;
53
+
54
+ @Column({ type: 'varchar', length: 100, nullable: true })
55
+ disability_type: string | null;
56
+
57
+ @Column({ type: 'date', nullable: true })
58
+ retirement_start_date: Date | null;
59
+
60
+ @Column({ type: 'date', nullable: true })
61
+ contract_end_date: Date | null;
62
+
63
+ @Column({ type: 'varchar', length: 255, nullable: true })
64
+ job_type_group: string | null;
65
+
66
+ // Transfer Information
67
+ @Column({ type: 'varchar', length: 255, nullable: true })
68
+ entity_transferred_from: string | null;
69
+
70
+ @Column({ type: 'date', nullable: true })
71
+ date_of_transfer: Date | null; // Date of Transfer (from)
72
+
73
+ @Column({ type: 'varchar', length: 255, nullable: true })
74
+ entity_transferred_to: string | null;
75
+
76
+ @Column({ type: 'date', nullable: true })
77
+ date_of_transfer_to: Date | null; // Date of Transfer (to)
78
+
79
+ @Column({ type: 'text', nullable: true })
80
+ job_description: string | null;
81
+
82
+ // Appointment Information
83
+ @Column({ type: 'varchar', length: 255, nullable: true })
84
+ country_appointment: string | null;
85
+
86
+ @Column({ type: 'date', nullable: true })
87
+ date_of_appointment: Date | null;
88
+
89
+ @Column({ type: 'varchar', length: 100, nullable: true })
90
+ appointment_grade: string | null;
91
+
92
+ @Column({ type: 'varchar', length: 100, nullable: true })
93
+ type_of_appointment: string | null;
94
+
95
+ @Column({ type: 'varchar', length: 100, nullable: true })
96
+ unit_code: string | null;
97
+
98
+ @Column({ type: 'boolean', nullable: true })
99
+ mc_work: boolean | null; // M&C Work
100
+
101
+ @Column({ type: 'varchar', length: 255, nullable: true })
102
+ office: string | null;
103
+
104
+ @Column({ type: 'varchar', length: 255, nullable: true })
105
+ governorate_name: string | null;
106
+
107
+ @Column({ type: 'varchar', length: 255, nullable: true })
108
+ department: string | null;
109
+
110
+ @Column({ type: 'varchar', length: 255, nullable: true })
111
+ works_in_department: string | null;
112
+
113
+ // Mission Information
114
+ @Column({ type: 'varchar', length: 255, nullable: true })
115
+ full_name_of_mission: string | null;
116
+
117
+ @Column({ type: 'varchar', length: 255, nullable: true })
118
+ mission: string | null;
119
+
120
+ @Column({ type: 'text', nullable: true })
121
+ description_of_mission: string | null;
122
+
123
+ @Column({ type: 'date', nullable: true })
124
+ date_of_last_transfer_to_mission: Date | null;
125
+
126
+ @Column({ type: 'date', nullable: true })
127
+ date_of_last_transfer_from_mission: Date | null;
128
+
129
+ @Column({ type: 'boolean', nullable: true })
130
+ diplomat: boolean | null;
131
+
132
+ // Performance and Termination
133
+ @Column({ type: 'varchar', length: 100, nullable: true })
134
+ efficiency_rating_for_the_year_month: string | null; // Efficiency rating for the year/month
135
+
136
+ @Column({ type: 'date', nullable: true })
137
+ retirement_termination_of_service_date: Date | null; // Retirement/Termination of Service Date
138
+
139
+ @Column({ type: 'text', nullable: true })
140
+ reason_for_leaving_service: string | null;
141
+ }
@@ -0,0 +1,137 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ /**
5
+ * User Personal Details - only fields from business requirements
6
+ * Linked by user_id (not request_id)
7
+ * When profile update is approved, data from this table updates users table
8
+ */
9
+ @Entity({ name: 'user_personal_details' })
10
+ export class UserPersonalDetails extends BaseModel {
11
+ @Column({ type: 'int', nullable: false })
12
+ user_id: number; // Foreign key to users table
13
+
14
+ // Name fields
15
+ @Column({ type: 'varchar', length: 255, nullable: true })
16
+ title: string | null;
17
+
18
+ @Column({ type: 'varchar', length: 255, nullable: true })
19
+ first_name: string | null;
20
+
21
+ @Column({ type: 'varchar', length: 255, nullable: true })
22
+ second_name: string | null;
23
+
24
+ @Column({ type: 'varchar', length: 255, nullable: true })
25
+ third_name: string | null;
26
+
27
+ @Column({ type: 'varchar', length: 255, nullable: true })
28
+ fourth_name: string | null;
29
+
30
+ @Column({ type: 'varchar', length: 255, nullable: true })
31
+ family_name_tribe: string | null;
32
+
33
+ @Column({ type: 'varchar', length: 255, nullable: true })
34
+ previous_name: string | null;
35
+
36
+ // Personal Information
37
+ @Column({ type: 'varchar', length: 100, nullable: true })
38
+ religion: string | null;
39
+
40
+ @Column({ type: 'varchar', length: 100, nullable: true })
41
+ sect: string | null;
42
+
43
+ @Column({ type: 'date', nullable: true })
44
+ date_of_birth: Date | null;
45
+
46
+ @Column({ type: 'varchar', length: 255, nullable: true })
47
+ place_of_birth: string | null;
48
+
49
+ @Column({ type: 'varchar', length: 100, nullable: true })
50
+ nationality: string | null;
51
+
52
+ @Column({ type: 'varchar', length: 50, nullable: true })
53
+ gender: string | null;
54
+
55
+ @Column({ type: 'varchar', length: 50, nullable: true })
56
+ marital_status: string | null;
57
+
58
+ @Column({ type: 'int', nullable: true })
59
+ number_of_dependents: number | null;
60
+
61
+ // Passport Information
62
+ @Column({ type: 'varchar', length: 100, nullable: true })
63
+ passport_number: string | null;
64
+
65
+ @Column({ type: 'varchar', length: 50, nullable: true })
66
+ passport_type: string | null;
67
+
68
+ @Column({ type: 'date', nullable: true })
69
+ issue_date: Date | null; // Passport Issue Date
70
+
71
+ @Column({ type: 'varchar', length: 255, nullable: true })
72
+ place_of_issue: string | null; // Passport Place of Issue
73
+
74
+ @Column({ type: 'date', nullable: true })
75
+ expiry_date: Date | null; // Passport Expiry Date
76
+
77
+ // ID Card Information
78
+ @Column({ type: 'varchar', length: 100, nullable: true })
79
+ id_card_number: string | null;
80
+
81
+ @Column({ type: 'varchar', length: 255, nullable: true })
82
+ id_card_place_of_issue: string | null;
83
+
84
+ @Column({ type: 'date', nullable: true })
85
+ id_card_expiry_date: Date | null;
86
+
87
+ // Address Information
88
+ @Column({ type: 'text', nullable: true })
89
+ permanent_address: string | null;
90
+
91
+ @Column({ type: 'varchar', length: 255, nullable: true })
92
+ governorate_wilaya: string | null;
93
+
94
+ @Column({ type: 'varchar', length: 100, nullable: true })
95
+ po_box: string | null; // P.O. Box
96
+
97
+ @Column({ type: 'varchar', length: 50, nullable: true })
98
+ zip_code: string | null;
99
+
100
+ @Column({ type: 'varchar', length: 100, nullable: true })
101
+ house_number: string | null;
102
+
103
+ @Column({ type: 'varchar', length: 100, nullable: true })
104
+ railway_number: string | null;
105
+
106
+ @Column({ type: 'varchar', length: 255, nullable: true })
107
+ governorate: string | null;
108
+
109
+ @Column({ type: 'varchar', length: 255, nullable: true })
110
+ wilayat: string | null;
111
+
112
+ @Column({ type: 'varchar', length: 255, nullable: true })
113
+ locality: string | null;
114
+
115
+ @Column({ type: 'varchar', length: 100, nullable: true })
116
+ country: string | null;
117
+
118
+ // Contact Information
119
+ @Column({ type: 'varchar', length: 50, nullable: true })
120
+ phone_number: string | null;
121
+
122
+ @Column({ type: 'varchar', length: 50, nullable: true })
123
+ fax_number: string | null;
124
+
125
+ @Column({ type: 'varchar', length: 255, nullable: true })
126
+ email: string | null;
127
+
128
+ @Column({ type: 'varchar', length: 255, nullable: true })
129
+ email_address_personal: string | null; // Email Address (Personal)
130
+
131
+ // Additional Personal Information
132
+ @Column({ type: 'varchar', length: 255, nullable: true })
133
+ sheikh_name: string | null; // Sheikh's Name
134
+
135
+ @Column({ type: 'varchar', length: 500, nullable: true })
136
+ photo: string | null;
137
+ }
@@ -132,6 +132,9 @@ export class User extends BaseModel {
132
132
  @Column({ type: "enum", enum: ["FM", "Embassy"], nullable: false, default: "FM" })
133
133
  category: "FM" | "Embassy"; // Mandatory
134
134
 
135
+ @Column({ type: "int", nullable: true , default: 0})
136
+ mandc_number: number;
137
+
135
138
  constructor(
136
139
  employee_id?: number,
137
140
  employee_name?: string,
@@ -175,6 +178,7 @@ export class User extends BaseModel {
175
178
  children2_name?: string,
176
179
  language_preferences?: string,
177
180
  category?: "FM" | "Embassy",
181
+ mandc_number?: number,
178
182
  ) {
179
183
  super();
180
184
  this.employee_id = employee_id;
@@ -219,5 +223,6 @@ export class User extends BaseModel {
219
223
  this.children2_name = children2_name;
220
224
  this.language_preferences = language_preferences;
221
225
  this.category = category || "FM";
226
+ this.mandc_number = mandc_number || 0;
222
227
  }
223
228
  }
@@ -1,24 +0,0 @@
1
- import { BaseModel } from './BaseModel';
2
- import { DiplomaticRequests } from "./DiplomaticRequestsModel";
3
- export declare enum DiplomaticApprovalStatus {
4
- PENDING = "Pending",
5
- APPROVED = "Approved",
6
- REJECTED = "Rejected",
7
- IN_PROGRESS = "In Progress"
8
- }
9
- export declare class DiplomaticApprovals extends BaseModel {
10
- diplomatic_request_id: number;
11
- level: number;
12
- approver_user_id: number | null;
13
- approver_role_id: number;
14
- comment: string | null;
15
- approval_status: DiplomaticApprovalStatus;
16
- action_date: Date;
17
- department_id: number | null;
18
- section_id: number | null;
19
- approved_by: number | null;
20
- delegate_user_id: number | null;
21
- is_allowed: boolean;
22
- diplomaticRequest?: DiplomaticRequests;
23
- constructor(diplomatic_request_id: number, level: number, approver_role_id: number, approval_status: DiplomaticApprovalStatus, department_id: number | null, section_id: number | null, approved_by: number | null, delegate_user_id: number | null, is_allowed?: boolean);
24
- }
@@ -1,94 +0,0 @@
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.DiplomaticApprovals = exports.DiplomaticApprovalStatus = void 0;
13
- const typeorm_1 = require("typeorm");
14
- const BaseModel_1 = require("./BaseModel");
15
- const DiplomaticRequestsModel_1 = require("./DiplomaticRequestsModel");
16
- var DiplomaticApprovalStatus;
17
- (function (DiplomaticApprovalStatus) {
18
- DiplomaticApprovalStatus["PENDING"] = "Pending";
19
- DiplomaticApprovalStatus["APPROVED"] = "Approved";
20
- DiplomaticApprovalStatus["REJECTED"] = "Rejected";
21
- DiplomaticApprovalStatus["IN_PROGRESS"] = "In Progress";
22
- })(DiplomaticApprovalStatus || (exports.DiplomaticApprovalStatus = DiplomaticApprovalStatus = {}));
23
- let DiplomaticApprovals = class DiplomaticApprovals extends BaseModel_1.BaseModel {
24
- constructor(diplomatic_request_id, level, approver_role_id, approval_status, department_id, section_id, approved_by, delegate_user_id, is_allowed = true) {
25
- super();
26
- this.diplomatic_request_id = diplomatic_request_id;
27
- this.level = level;
28
- this.approver_role_id = approver_role_id;
29
- this.approval_status = approval_status;
30
- this.department_id = department_id;
31
- this.section_id = section_id;
32
- this.approved_by = approved_by;
33
- this.delegate_user_id = delegate_user_id;
34
- this.is_allowed = is_allowed;
35
- }
36
- };
37
- exports.DiplomaticApprovals = DiplomaticApprovals;
38
- __decorate([
39
- (0, typeorm_1.Column)({ type: 'int' }),
40
- __metadata("design:type", Number)
41
- ], DiplomaticApprovals.prototype, "diplomatic_request_id", void 0);
42
- __decorate([
43
- (0, typeorm_1.Column)({ type: 'int' }),
44
- __metadata("design:type", Number)
45
- ], DiplomaticApprovals.prototype, "level", void 0);
46
- __decorate([
47
- (0, typeorm_1.Column)({ type: 'int', nullable: true }),
48
- __metadata("design:type", Object)
49
- ], DiplomaticApprovals.prototype, "approver_user_id", void 0);
50
- __decorate([
51
- (0, typeorm_1.Column)({ type: 'int' }),
52
- __metadata("design:type", Number)
53
- ], DiplomaticApprovals.prototype, "approver_role_id", void 0);
54
- __decorate([
55
- (0, typeorm_1.Column)({ type: 'text', nullable: true }),
56
- __metadata("design:type", Object)
57
- ], DiplomaticApprovals.prototype, "comment", void 0);
58
- __decorate([
59
- (0, typeorm_1.Column)({ type: 'enum', enum: DiplomaticApprovalStatus, default: DiplomaticApprovalStatus.PENDING }),
60
- __metadata("design:type", String)
61
- ], DiplomaticApprovals.prototype, "approval_status", void 0);
62
- __decorate([
63
- (0, typeorm_1.Column)({ type: 'timestamp', nullable: true }),
64
- __metadata("design:type", Date)
65
- ], DiplomaticApprovals.prototype, "action_date", void 0);
66
- __decorate([
67
- (0, typeorm_1.Column)({ type: 'int', nullable: true }),
68
- __metadata("design:type", Object)
69
- ], DiplomaticApprovals.prototype, "department_id", void 0);
70
- __decorate([
71
- (0, typeorm_1.Column)({ type: 'int', nullable: true }),
72
- __metadata("design:type", Object)
73
- ], DiplomaticApprovals.prototype, "section_id", void 0);
74
- __decorate([
75
- (0, typeorm_1.Column)({ type: 'int', nullable: true }),
76
- __metadata("design:type", Object)
77
- ], DiplomaticApprovals.prototype, "approved_by", void 0);
78
- __decorate([
79
- (0, typeorm_1.Column)({ type: 'int', nullable: true }),
80
- __metadata("design:type", Object)
81
- ], DiplomaticApprovals.prototype, "delegate_user_id", void 0);
82
- __decorate([
83
- (0, typeorm_1.Column)({ type: 'boolean', default: true, nullable: false }),
84
- __metadata("design:type", Boolean)
85
- ], DiplomaticApprovals.prototype, "is_allowed", void 0);
86
- __decorate([
87
- (0, typeorm_1.ManyToOne)(() => DiplomaticRequestsModel_1.DiplomaticRequests, dr => dr.approvals),
88
- (0, typeorm_1.JoinColumn)({ name: 'diplomatic_request_id' }),
89
- __metadata("design:type", DiplomaticRequestsModel_1.DiplomaticRequests)
90
- ], DiplomaticApprovals.prototype, "diplomaticRequest", void 0);
91
- exports.DiplomaticApprovals = DiplomaticApprovals = __decorate([
92
- (0, typeorm_1.Entity)({ name: 'diplomatic_approvals' }),
93
- __metadata("design:paramtypes", [Number, Number, Number, String, Object, Object, Object, Object, Boolean])
94
- ], DiplomaticApprovals);
@@ -1,11 +0,0 @@
1
- import { BaseModel } from './BaseModel';
2
- import { DiplomaticRequests } from "./DiplomaticRequestsModel";
3
- export declare class DiplomaticAttachments extends BaseModel {
4
- diplomatic_request_id: number;
5
- file_url: string;
6
- file_name: string;
7
- file_type: string;
8
- file_size: number | null;
9
- diplomaticRequest?: DiplomaticRequests;
10
- constructor(diplomatic_request_id: number, file_url: string, file_name: string);
11
- }
@@ -1,53 +0,0 @@
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.DiplomaticAttachments = void 0;
13
- const typeorm_1 = require("typeorm");
14
- const BaseModel_1 = require("./BaseModel");
15
- const DiplomaticRequestsModel_1 = require("./DiplomaticRequestsModel");
16
- let DiplomaticAttachments = class DiplomaticAttachments extends BaseModel_1.BaseModel {
17
- constructor(diplomatic_request_id, file_url, file_name) {
18
- super();
19
- this.diplomatic_request_id = diplomatic_request_id;
20
- this.file_url = file_url;
21
- this.file_name = file_name;
22
- }
23
- };
24
- exports.DiplomaticAttachments = DiplomaticAttachments;
25
- __decorate([
26
- (0, typeorm_1.Column)({ type: 'int' }),
27
- __metadata("design:type", Number)
28
- ], DiplomaticAttachments.prototype, "diplomatic_request_id", void 0);
29
- __decorate([
30
- (0, typeorm_1.Column)({ type: 'varchar', length: 500 }),
31
- __metadata("design:type", String)
32
- ], DiplomaticAttachments.prototype, "file_url", void 0);
33
- __decorate([
34
- (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
35
- __metadata("design:type", String)
36
- ], DiplomaticAttachments.prototype, "file_name", void 0);
37
- __decorate([
38
- (0, typeorm_1.Column)({ type: 'varchar', length: 100, nullable: true }),
39
- __metadata("design:type", String)
40
- ], DiplomaticAttachments.prototype, "file_type", void 0);
41
- __decorate([
42
- (0, typeorm_1.Column)({ type: 'bigint', nullable: true }),
43
- __metadata("design:type", Object)
44
- ], DiplomaticAttachments.prototype, "file_size", void 0);
45
- __decorate([
46
- (0, typeorm_1.ManyToOne)(() => DiplomaticRequestsModel_1.DiplomaticRequests, dr => dr.attachments),
47
- (0, typeorm_1.JoinColumn)({ name: 'diplomatic_request_id' }),
48
- __metadata("design:type", DiplomaticRequestsModel_1.DiplomaticRequests)
49
- ], DiplomaticAttachments.prototype, "diplomaticRequest", void 0);
50
- exports.DiplomaticAttachments = DiplomaticAttachments = __decorate([
51
- (0, typeorm_1.Entity)({ name: 'diplomatic_attachments' }),
52
- __metadata("design:paramtypes", [Number, String, String])
53
- ], DiplomaticAttachments);