@platform-modules/foreign-ministry 1.1.104 → 1.1.106

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 (183) hide show
  1. package/.env +11 -3
  2. package/dist/data-source.js +58 -14
  3. package/dist/index.d.ts +38 -7
  4. package/dist/index.js +53 -7
  5. package/dist/models/CountryMasterModel.d.ts +11 -0
  6. package/dist/models/CountryMasterModel.js +55 -0
  7. package/dist/models/DiplomaticTitlesMasterModel.d.ts +3 -7
  8. package/dist/models/DiplomaticTitlesMasterModel.js +9 -16
  9. package/dist/models/EarlyCheckoutBalanceModel.d.ts +7 -0
  10. package/dist/models/{DiplomaticClubCardChatModel.js → EarlyCheckoutBalanceModel.js} +21 -18
  11. package/dist/models/EarlyCheckoutConfigModel.d.ts +18 -0
  12. package/dist/models/EarlyCheckoutConfigModel.js +80 -0
  13. package/dist/models/EarlyCheckoutTransactionModel.d.ts +19 -0
  14. package/dist/models/EarlyCheckoutTransactionModel.js +66 -0
  15. package/dist/models/FinancialApprovalsModel.d.ts +1 -0
  16. package/dist/models/FinancialApprovalsModel.js +4 -0
  17. package/dist/models/FinancialGradeModel.d.ts +4 -3
  18. package/dist/models/FinancialGradeModel.js +12 -7
  19. package/dist/models/GeneralServiceApprovalsModel.d.ts +4 -1
  20. package/dist/models/GeneralServiceApprovalsModel.js +9 -0
  21. package/dist/models/HelpContentMappedCategoriesModel.d.ts +6 -0
  22. package/dist/models/HelpContentMappedCategoriesModel.js +34 -0
  23. package/dist/models/HelpContentMappedTagsModel.d.ts +6 -0
  24. package/dist/models/HelpContentMappedTagsModel.js +34 -0
  25. package/dist/models/HelpContentTagsModel.d.ts +5 -0
  26. package/dist/models/HelpContentTagsModel.js +29 -0
  27. package/dist/models/LeaveApprovalsModel.d.ts +4 -2
  28. package/dist/models/LeaveApprovalsModel.js +8 -2
  29. package/dist/models/LeaveBalanceModel.d.ts +8 -0
  30. package/dist/models/{PassportRequestChatModel.js → LeaveBalanceModel.js} +23 -23
  31. package/dist/models/LeaveConfigGradesModel.d.ts +19 -0
  32. package/dist/models/LeaveConfigGradesModel.js +100 -0
  33. package/dist/models/LeaveConfigModel.d.ts +20 -0
  34. package/dist/models/LeaveConfigModel.js +90 -0
  35. package/dist/models/LeaveTransactionModel.d.ts +20 -0
  36. package/dist/models/LeaveTransactionModel.js +71 -0
  37. package/dist/models/LeaveTypesModel.d.ts +7 -1
  38. package/dist/models/LeaveTypesModel.js +20 -5
  39. package/dist/models/M&CMasterModel.d.ts +9 -0
  40. package/dist/models/M&CMasterModel.js +49 -0
  41. package/dist/models/NationalityMasterModel.d.ts +10 -0
  42. package/dist/models/{DiplomaticClubCardAttachmentModel.js → NationalityMasterModel.js} +29 -22
  43. package/dist/models/OfficeMasterModel.d.ts +12 -0
  44. package/dist/models/OfficeMasterModel.js +59 -0
  45. package/dist/models/ProfileUpdateRequestsModel.d.ts +106 -0
  46. package/dist/models/ProfileUpdateRequestsModel.js +409 -0
  47. package/dist/models/RegisterCandidateApprovalModel.d.ts +22 -0
  48. package/dist/models/RegisterCandidateApprovalModel.js +79 -0
  49. package/dist/models/RegisterCandidateAttachmentModel.d.ts +11 -0
  50. package/dist/models/RegisterCandidateAttachmentModel.js +52 -0
  51. package/dist/models/RegisterCandidateChatModel.d.ts +19 -0
  52. package/dist/models/RegisterCandidateChatModel.js +78 -0
  53. package/dist/models/RegisterCandidateRequestModel.d.ts +69 -0
  54. package/dist/models/RegisterCandidateRequestModel.js +247 -0
  55. package/dist/models/RegisterCandidateWorkflowModel.d.ts +17 -0
  56. package/dist/models/RegisterCandidateWorkflowModel.js +62 -0
  57. package/dist/models/RegisterVacancyApprovalModel.d.ts +22 -0
  58. package/dist/models/RegisterVacancyApprovalModel.js +79 -0
  59. package/dist/models/RegisterVacancyAttachmentModel.d.ts +11 -0
  60. package/dist/models/RegisterVacancyAttachmentModel.js +52 -0
  61. package/dist/models/RegisterVacancyChatModel.d.ts +19 -0
  62. package/dist/models/RegisterVacancyChatModel.js +78 -0
  63. package/dist/models/RegisterVacancyRequestModel.d.ts +22 -0
  64. package/dist/models/RegisterVacancyRequestModel.js +76 -0
  65. package/dist/models/RegisterVacancyWorkflowModel.d.ts +17 -0
  66. package/dist/models/RegisterVacancyWorkflowModel.js +62 -0
  67. package/dist/models/StationeryMaterialMasterModel.d.ts +11 -0
  68. package/dist/models/StationeryMaterialMasterModel.js +56 -0
  69. package/dist/models/StationeryRequestsModel.d.ts +26 -0
  70. package/dist/models/StationeryRequestsModel.js +89 -0
  71. package/dist/models/StayAfterHoursBalanceModel.d.ts +7 -0
  72. package/dist/models/StayAfterHoursBalanceModel.js +39 -0
  73. package/dist/models/StayAfterHoursTransactionModel.d.ts +19 -0
  74. package/dist/models/StayAfterHoursTransactionModel.js +66 -0
  75. package/dist/models/TelephoneDirectoryModel.d.ts +3 -2
  76. package/dist/models/TelephoneDirectoryModel.js +11 -6
  77. package/dist/models/TransferMissionApprovalModel.d.ts +2 -0
  78. package/dist/models/TransferMissionApprovalModel.js +8 -0
  79. package/dist/models/UpdateAttendanceApprovalModel.d.ts +1 -0
  80. package/dist/models/UpdateAttendanceApprovalModel.js +4 -0
  81. package/dist/models/UserEducationDetailsModel.d.ts +12 -0
  82. package/dist/models/UserEducationDetailsModel.js +44 -0
  83. package/dist/models/UserEmploymentDetailsModel.d.ts +50 -0
  84. package/dist/models/UserEmploymentDetailsModel.js +193 -0
  85. package/dist/models/UserPersonalDetailsModel.d.ts +48 -0
  86. package/dist/models/UserPersonalDetailsModel.js +185 -0
  87. package/dist/models/questionTagsModel.d.ts +6 -0
  88. package/dist/models/questionTagsModel.js +34 -0
  89. package/dist/models/user.d.ts +2 -1
  90. package/dist/models/user.js +7 -2
  91. package/package.json +1 -1
  92. package/src/data-source.ts +62 -16
  93. package/src/index.ts +38 -7
  94. package/src/models/CountryMasterModel.ts +34 -0
  95. package/src/models/DiplomaticTitlesMasterModel.ts +9 -20
  96. package/src/models/EarlyCheckoutBalanceModel.ts +22 -0
  97. package/src/models/EarlyCheckoutConfigModel.ts +57 -0
  98. package/src/models/EarlyCheckoutTransactionModel.ts +53 -0
  99. package/src/models/FinancialApprovalsModel.ts +4 -0
  100. package/src/models/FinancialGradeModel.ts +13 -8
  101. package/src/models/GeneralServiceApprovalsModel.ts +10 -1
  102. package/src/models/LeaveApprovalsModel.ts +7 -2
  103. package/src/models/LeaveBalanceModel.ts +26 -0
  104. package/src/models/LeaveConfigGradesModel.ts +72 -0
  105. package/src/models/LeaveConfigModel.ts +64 -0
  106. package/src/models/LeaveTransactionModel.ts +58 -0
  107. package/src/models/LeaveTypesModel.ts +27 -11
  108. package/src/models/M&CMasterModel.ts +37 -0
  109. package/src/models/NationalityMasterModel.ts +31 -0
  110. package/src/models/OfficeMasterModel.ts +37 -0
  111. package/src/models/ProfileUpdateRequestsModel.ts +317 -0
  112. package/src/models/RegisterCandidateApprovalModel.ts +51 -0
  113. package/src/models/RegisterCandidateAttachmentModel.ts +30 -0
  114. package/src/models/RegisterCandidateChatModel.ts +65 -0
  115. package/src/models/RegisterCandidateRequestModel.ts +193 -0
  116. package/src/models/RegisterCandidateWorkflowModel.ts +38 -0
  117. package/src/models/RegisterVacancyApprovalModel.ts +52 -0
  118. package/src/models/RegisterVacancyAttachmentModel.ts +31 -0
  119. package/src/models/RegisterVacancyChatModel.ts +66 -0
  120. package/src/models/RegisterVacancyRequestModel.ts +53 -0
  121. package/src/models/RegisterVacancyWorkflowModel.ts +39 -0
  122. package/src/models/StationeryMaterialMasterModel.ts +35 -0
  123. package/src/models/StationeryRequestsModel.ts +62 -0
  124. package/src/models/StayAfterHoursBalanceModel.ts +22 -0
  125. package/src/models/StayAfterHoursTransactionModel.ts +53 -0
  126. package/src/models/TelephoneDirectoryModel.ts +8 -4
  127. package/src/models/TransferMissionApprovalModel.ts +6 -0
  128. package/src/models/TransferMissionRequestModel.ts +1 -0
  129. package/src/models/UpdateAttendanceApprovalModel.ts +3 -0
  130. package/src/models/UserEducationDetailsModel.ts +26 -0
  131. package/src/models/UserEmploymentDetailsModel.ts +141 -0
  132. package/src/models/UserPersonalDetailsModel.ts +137 -0
  133. package/src/models/user.ts +5 -0
  134. package/dist/models/DiplomaticApprovalsModel.d.ts +0 -24
  135. package/dist/models/DiplomaticApprovalsModel.js +0 -94
  136. package/dist/models/DiplomaticAttachmentsModel.d.ts +0 -11
  137. package/dist/models/DiplomaticAttachmentsModel.js +0 -53
  138. package/dist/models/DiplomaticChatsModel.d.ts +0 -20
  139. package/dist/models/DiplomaticChatsModel.js +0 -70
  140. package/dist/models/DiplomaticClubCardApprovalModel.d.ts +0 -16
  141. package/dist/models/DiplomaticClubCardApprovalModel.js +0 -58
  142. package/dist/models/DiplomaticClubCardAttachmentModel.d.ts +0 -9
  143. package/dist/models/DiplomaticClubCardChatModel.d.ts +0 -7
  144. package/dist/models/DiplomaticClubCardMemberModel.d.ts +0 -13
  145. package/dist/models/DiplomaticClubCardMemberModel.js +0 -60
  146. package/dist/models/DiplomaticClubCardMembersModel.d.ts +0 -26
  147. package/dist/models/DiplomaticClubCardMembersModel.js +0 -85
  148. package/dist/models/DiplomaticClubCardRequestModel.d.ts +0 -33
  149. package/dist/models/DiplomaticClubCardRequestModel.js +0 -98
  150. package/dist/models/DiplomaticClubCardWorkFlowModel.d.ts +0 -12
  151. package/dist/models/DiplomaticClubCardWorkFlowModel.js +0 -42
  152. package/dist/models/DiplomaticClubSubscriptionMasterModel.d.ts +0 -12
  153. package/dist/models/DiplomaticClubSubscriptionMasterModel.js +0 -64
  154. package/dist/models/DiplomaticRequestsModel.d.ts +0 -54
  155. package/dist/models/DiplomaticRequestsModel.js +0 -186
  156. package/dist/models/DiplomaticServiceDetailsModel.d.ts +0 -20
  157. package/dist/models/DiplomaticServiceDetailsModel.js +0 -65
  158. package/dist/models/DiplomaticSettingsModel.d.ts +0 -11
  159. package/dist/models/DiplomaticSettingsModel.js +0 -59
  160. package/dist/models/DiplomaticTitleModel.d.ts +0 -12
  161. package/dist/models/DiplomaticTitleModel.js +0 -45
  162. package/dist/models/DiplomaticWorkFlowModel.d.ts +0 -20
  163. package/dist/models/DiplomaticWorkFlowModel.js +0 -77
  164. package/dist/models/PassportRequestApprovalModel.d.ts +0 -22
  165. package/dist/models/PassportRequestApprovalModel.js +0 -91
  166. package/dist/models/PassportRequestAttachmentModel.d.ts +0 -10
  167. package/dist/models/PassportRequestAttachmentModel.js +0 -54
  168. package/dist/models/PassportRequestChatModel.d.ts +0 -8
  169. package/dist/models/PassportRequestDependentModel.d.ts +0 -20
  170. package/dist/models/PassportRequestDependentModel.js +0 -85
  171. package/dist/models/PassportRequestModel.d.ts +0 -40
  172. package/dist/models/PassportRequestModel.js +0 -128
  173. package/dist/models/PassportRequestWorkFlowModel.d.ts +0 -15
  174. package/dist/models/PassportRequestWorkFlowModel.js +0 -60
  175. package/dist/models/SubscriptionAmountModel.d.ts +0 -67
  176. package/dist/models/SubscriptionAmountModel.js +0 -114
  177. package/src/models/DiplomaticApprovalsModel.ts +0 -77
  178. package/src/models/DiplomaticAttachmentsModel.ts +0 -37
  179. package/src/models/DiplomaticChatsModel.ts +0 -53
  180. package/src/models/DiplomaticClubCardMembersModel.ts +0 -71
  181. package/src/models/DiplomaticClubSubscriptionMasterModel.ts +0 -50
  182. package/src/models/DiplomaticRequestsModel.ts +0 -154
  183. package/src/models/DiplomaticWorkFlowModel.ts +0 -59
@@ -0,0 +1,64 @@
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
+ 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) {
50
+ super();
51
+ this.category = category;
52
+ this.MandC_id = MandC_id;
53
+ this.leave_type_id = leave_type_id;
54
+ this.frequency = frequency;
55
+ this.region = region;
56
+ this.country = country;
57
+ this.location = location;
58
+ this.is_carryforward = is_carryforward;
59
+ this.carryforward_limit = carryforward_limit;
60
+ this.from_date = from_date;
61
+ this.to_date = to_date;
62
+ this.reason = reason;
63
+ }
64
+ }
@@ -0,0 +1,58 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum LeaveTransactionStatus {
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 leave transactions for users
15
+ @Entity({ name: 'leave_transactions' })
16
+ export class LeaveTransaction extends BaseModel {
17
+
18
+ @Column({ type: 'int', nullable: false })
19
+ user_id: number;
20
+
21
+ @Column({ type: 'int', nullable: false })
22
+ leave_type_id: number;
23
+
24
+ @Column({ type: 'decimal', precision: 10, scale: 2, nullable: true })
25
+ leave_count: number;
26
+
27
+ @Column({ type: 'date', nullable: true })
28
+ from_date: Date;
29
+
30
+ @Column({ type: 'date', nullable: true })
31
+ to_date: Date;
32
+
33
+ @Column({ type: 'int', nullable: true })
34
+ year: number;
35
+
36
+ @Column({ type: 'varchar', nullable: false })
37
+ status: LeaveTransactionStatus;
38
+
39
+ constructor(
40
+ user_id: number,
41
+ leave_type_id: number,
42
+ leave_count: number,
43
+ from_date: Date,
44
+ to_date: Date,
45
+ year: number,
46
+ status: LeaveTransactionStatus
47
+ ) {
48
+ super();
49
+ this.user_id = user_id;
50
+ this.leave_type_id = leave_type_id;
51
+ this.leave_count = leave_count;
52
+ this.from_date = from_date;
53
+ this.to_date = to_date;
54
+ this.year = year;
55
+ this.status = status;
56
+ }
57
+ }
58
+
@@ -1,31 +1,47 @@
1
1
  import { Column, Entity } from "typeorm";
2
2
  import { BaseModel } from './BaseModel';
3
3
 
4
+ export enum genderType {
5
+ Male = 'Male',
6
+ Female = 'Female',
7
+ All = 'All',
8
+ }
9
+
4
10
  @Entity({ name: 'leave_types' })
5
11
  export class LeaveTypes extends BaseModel {
6
12
 
7
- @Column({ nullable: true })
13
+ @Column({type: 'varchar', nullable: true })
8
14
  name: string;
9
15
 
10
- @Column({ nullable: true })
16
+ @Column({type: 'varchar', nullable: true })
11
17
  name_in_arabic: string;
12
18
 
13
- @Column({ nullable: true, default: false })
14
- omani_only?: boolean = false;
19
+ @Column({ nullable: true, default: false })
20
+ omani_only?: boolean = false;
15
21
 
16
- @Column({ nullable: true, default: false })
17
- non_omani_muslim?: boolean = false;
22
+ @Column({ nullable: true, default: false })
23
+ non_omani_muslim?: boolean = false;
18
24
 
19
- @Column({ nullable: true, default: false })
20
- non_omani_non_muslim?: boolean = false;
25
+ @Column({ nullable: true, default: false })
26
+ non_omani_non_muslim?: boolean = false;
21
27
 
28
+ @Column({ nullable: true, default: genderType.All })
29
+ gender: genderType = genderType.All;
22
30
 
23
- constructor(
31
+ constructor(
24
32
  name: string,
25
33
  name_in_arabic: string,
34
+ omani_only: boolean,
35
+ non_omani_muslim: boolean,
36
+ non_omani_non_muslim: boolean,
37
+ gender: genderType
26
38
  ) {
27
- super();
39
+ super();
28
40
  this.name = name
29
- this.name_in_arabic = name_in_arabic
41
+ this.name_in_arabic = name_in_arabic
42
+ this.omani_only = omani_only
43
+ this.non_omani_muslim = non_omani_muslim
44
+ this.non_omani_non_muslim = non_omani_non_muslim
45
+ this.gender = gender
30
46
  }
31
47
  }
@@ -0,0 +1,37 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'M&C_names' })
5
+ export class MandCMaster extends BaseModel {
6
+
7
+ @Column({type: 'varchar', nullable: true })
8
+ name: string;
9
+
10
+ @Column({type: 'varchar', nullable: true })
11
+ name_in_arabic: string;
12
+
13
+ @Column({type: 'varchar', nullable: true })
14
+ region:string;
15
+
16
+ @Column({type: 'varchar', nullable: true })
17
+ country:string;
18
+
19
+ @Column({type: 'varchar', nullable: true })
20
+ location:string;
21
+
22
+
23
+ constructor(
24
+ name: string,
25
+ name_in_arabic: string,
26
+ region: string,
27
+ country: string,
28
+ location: string
29
+ ) {
30
+ super();
31
+ this.name = name
32
+ this.name_in_arabic = name_in_arabic
33
+ this.region = region
34
+ this.country = country
35
+ this.location = location
36
+ }
37
+ }
@@ -0,0 +1,31 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'nationality_master' })
5
+ export class NationalityMaster extends BaseModel {
6
+ @Column({ type: 'varchar', length: 255, nullable: false })
7
+ nationality_name: string; // Nationality name
8
+
9
+ @Column({ type: 'varchar', length: 255, nullable: true })
10
+ nationality_name_arabic: string | null; // Arabic translation
11
+
12
+ @Column({ type: 'varchar', length: 10, nullable: true })
13
+ country_code: string | null; // Associated country code
14
+
15
+ @Column({ type: 'text', nullable: true })
16
+ description: string | null; // Description of the nationality
17
+
18
+ @Column({ type: 'boolean', default: true })
19
+ is_active: boolean; // Whether the nationality is active
20
+
21
+ @Column({ type: 'int', default: 0 })
22
+ display_order: number; // Order for display in dropdowns
23
+
24
+ constructor(nationality_name: string) {
25
+ super();
26
+ this.nationality_name = nationality_name;
27
+ this.is_active = true;
28
+ this.display_order = 0;
29
+ }
30
+ }
31
+
@@ -0,0 +1,37 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'office_master' })
5
+ export class OfficeMaster extends BaseModel {
6
+ @Column({ type: 'varchar', length: 255, nullable: false })
7
+ office_name: string; // Office name
8
+
9
+ @Column({ type: 'varchar', length: 255, nullable: true })
10
+ office_name_arabic: string | null; // Arabic translation
11
+
12
+ @Column({ type: 'varchar', length: 100, nullable: true })
13
+ office_code: string | null; // Optional office code for identification
14
+
15
+ @Column({ type: 'text', nullable: true })
16
+ description: string | null; // Description of the office
17
+
18
+ @Column({ type: 'varchar', length: 255, nullable: true })
19
+ location: string | null; // Office location
20
+
21
+ @Column({ type: 'varchar', length: 255, nullable: true })
22
+ address: string | null; // Office address
23
+
24
+ @Column({ type: 'boolean', default: true })
25
+ is_active: boolean; // Whether the office is active
26
+
27
+ @Column({ type: 'int', default: 0 })
28
+ display_order: number; // Order for display in dropdowns
29
+
30
+ constructor(office_name: string) {
31
+ super();
32
+ this.office_name = office_name;
33
+ this.is_active = true;
34
+ this.display_order = 0;
35
+ }
36
+ }
37
+
@@ -0,0 +1,317 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum ProfileUpdateRequestStatus {
5
+ PENDING = "Pending",
6
+ ASSIGNED = "Assigned",
7
+ IN_PROGRESS = "In Progress",
8
+ APPROVED = "Approved",
9
+ REJECTED = "Rejected",
10
+ COMPLETED = "Completed"
11
+ }
12
+
13
+ @Entity({ name: 'user_profile_update_requests' })
14
+ export class ProfileUpdateRequests extends BaseModel {
15
+ @Column({ type: 'int', nullable: true })
16
+ req_user_department_id: number | null;
17
+
18
+ @Column({ type: 'int', nullable: true })
19
+ req_user_section_id: number | null;
20
+
21
+ @Column({ type: 'int', nullable: true })
22
+ service_id: number | null;
23
+
24
+ @Column({ type: 'int', nullable: true })
25
+ sub_service_id: number | null;
26
+
27
+ @Column({ type: 'int', nullable: false })
28
+ user_id: number;
29
+
30
+ @Column({ type: 'enum', enum: ProfileUpdateRequestStatus, default: ProfileUpdateRequestStatus.PENDING, nullable: false })
31
+ status: ProfileUpdateRequestStatus;
32
+
33
+ @Column({ type: 'varchar', nullable: true })
34
+ workflow_execution_id: string | null;
35
+
36
+ // Decision workflow fields
37
+ @Column({ type: 'varchar', length: 50, nullable: true })
38
+ employee_type: string | null; // 'FM', 'M&C'
39
+
40
+ @Column({ type: 'boolean', default: false, nullable: true })
41
+ is_diplomatic: boolean | null;
42
+
43
+ @Column({ type: 'varchar', length: 255, nullable: true })
44
+ assigned_to_department: string | null; // 'HR_FM' or 'M&C_Admin_Finance'
45
+
46
+ @Column({ type: 'varchar', length: 500, nullable: true })
47
+ comments: string | null;
48
+
49
+ // ========== PERSONAL DETAILS FIELDS (all nullable) ==========
50
+ // Name fields
51
+ @Column({ type: 'int', nullable: true })
52
+ diplomatic_title_id: number | null; // Reference to diplomatic_titles_master table
53
+
54
+ @Column({ type: 'varchar', length: 255, nullable: true })
55
+ first_name: string | null;
56
+
57
+ @Column({ type: 'varchar', length: 255, nullable: true })
58
+ second_name: string | null;
59
+
60
+ @Column({ type: 'varchar', length: 255, nullable: true })
61
+ third_name: string | null;
62
+
63
+ @Column({ type: 'varchar', length: 255, nullable: true })
64
+ fourth_name: string | null;
65
+
66
+ @Column({ type: 'varchar', length: 255, nullable: true })
67
+ family_name_tribe: string | null;
68
+
69
+ @Column({ type: 'varchar', length: 255, nullable: true })
70
+ previous_name: string | null;
71
+
72
+ // Personal Information
73
+ @Column({ type: 'varchar', length: 100, nullable: true })
74
+ religion: string | null;
75
+
76
+ @Column({ type: 'varchar', length: 100, nullable: true })
77
+ sect: string | null;
78
+
79
+ @Column({ type: 'date', nullable: true })
80
+ date_of_birth: Date | null;
81
+
82
+ @Column({ type: 'varchar', length: 255, nullable: true })
83
+ place_of_birth: string | null;
84
+
85
+ @Column({ type: 'int', nullable: true })
86
+ nationality_id: number | null; // Reference to nationality_master table
87
+
88
+ @Column({ type: 'varchar', length: 50, nullable: true })
89
+ gender: string | null;
90
+
91
+ @Column({ type: 'varchar', length: 50, nullable: true })
92
+ marital_status: string | null;
93
+
94
+ @Column({ type: 'int', nullable: true })
95
+ number_of_dependents: number | null;
96
+
97
+ // Passport Information
98
+ @Column({ type: 'varchar', length: 100, nullable: true })
99
+ passport_number: string | null;
100
+
101
+ @Column({ type: 'varchar', length: 50, nullable: true })
102
+ passport_type: string | null;
103
+
104
+ @Column({ type: 'date', nullable: true })
105
+ issue_date: Date | null; // Passport Issue Date
106
+
107
+ @Column({ type: 'varchar', length: 255, nullable: true })
108
+ place_of_issue: string | null; // Passport Place of Issue
109
+
110
+ @Column({ type: 'date', nullable: true })
111
+ expiry_date: Date | null; // Passport Expiry Date
112
+
113
+ // ID Card Information
114
+ @Column({ type: 'varchar', length: 100, nullable: true })
115
+ id_card_number: string | null;
116
+
117
+ @Column({ type: 'varchar', length: 255, nullable: true })
118
+ id_card_place_of_issue: string | null;
119
+
120
+ @Column({ type: 'date', nullable: true })
121
+ id_card_expiry_date: Date | null;
122
+
123
+ // Address Information
124
+ @Column({ type: 'text', nullable: true })
125
+ permanent_address: string | null;
126
+
127
+ @Column({ type: 'varchar', length: 255, nullable: true })
128
+ governorate_wilaya: string | null;
129
+
130
+ @Column({ type: 'varchar', length: 100, nullable: true })
131
+ po_box: string | null; // P.O. Box
132
+
133
+ @Column({ type: 'varchar', length: 50, nullable: true })
134
+ zip_code: string | null;
135
+
136
+ @Column({ type: 'varchar', length: 100, nullable: true })
137
+ house_number: string | null;
138
+
139
+ @Column({ type: 'varchar', length: 100, nullable: true })
140
+ railway_number: string | null;
141
+
142
+ @Column({ type: 'varchar', length: 255, nullable: true })
143
+ governorate: string | null;
144
+
145
+ @Column({ type: 'varchar', length: 255, nullable: true })
146
+ wilayat: string | null;
147
+
148
+ @Column({ type: 'varchar', length: 255, nullable: true })
149
+ locality: string | null;
150
+
151
+ @Column({ type: 'int', nullable: true })
152
+ country_id: number | null; // Reference to country_master table
153
+
154
+ // Contact Information
155
+ @Column({ type: 'varchar', length: 50, nullable: true })
156
+ phone_number: string | null;
157
+
158
+ @Column({ type: 'varchar', length: 50, nullable: true })
159
+ fax_number: string | null;
160
+
161
+ @Column({ type: 'varchar', length: 255, nullable: true })
162
+ email: string | null;
163
+
164
+ @Column({ type: 'varchar', length: 255, nullable: true })
165
+ email_address_personal: string | null; // Email Address (Personal)
166
+
167
+ // Additional Personal Information
168
+ @Column({ type: 'varchar', length: 255, nullable: true })
169
+ sheikh_name: string | null; // Sheikh's Name
170
+
171
+ @Column({ type: 'varchar', length: 500, nullable: true })
172
+ photo: string | null;
173
+
174
+ // ========== EMPLOYMENT DETAILS FIELDS (all nullable) ==========
175
+ // Job Information
176
+ @Column({ type: 'varchar', length: 255, nullable: true })
177
+ job_title: string | null;
178
+
179
+ @Column({ type: 'date', nullable: true })
180
+ date_of_decree_issuance: Date | null;
181
+
182
+ @Column({ type: 'varchar', length: 100, nullable: true })
183
+ civil_service_number: string | null;
184
+
185
+ @Column({ type: 'varchar', length: 100, nullable: true })
186
+ information_number: string | null;
187
+
188
+ @Column({ type: 'varchar', length: 100, nullable: true })
189
+ manpower_number: string | null;
190
+
191
+ @Column({ type: 'varchar', length: 100, nullable: true })
192
+ computer_number: string | null;
193
+
194
+ @Column({ type: 'boolean', nullable: true })
195
+ contract_employee: boolean | null;
196
+
197
+ @Column({ type: 'varchar', length: 255, nullable: true })
198
+ nature_of_work: string | null;
199
+
200
+ @Column({ type: 'date', nullable: true })
201
+ retirement_date: Date | null;
202
+
203
+ @Column({ type: 'varchar', length: 255, nullable: true })
204
+ proposed_position: string | null;
205
+
206
+ @Column({ type: 'int', nullable: true })
207
+ proposed_financial_grade_id: number | null; // Reference to financial_grade table
208
+
209
+ @Column({ type: 'date', nullable: true })
210
+ secondment_start_date: Date | null;
211
+
212
+ @Column({ type: 'date', nullable: true })
213
+ secondment_end_date: Date | null;
214
+
215
+ @Column({ type: 'varchar', length: 100, nullable: true })
216
+ disability_type: string | null;
217
+
218
+ @Column({ type: 'date', nullable: true })
219
+ retirement_start_date: Date | null;
220
+
221
+ @Column({ type: 'date', nullable: true })
222
+ contract_end_date: Date | null;
223
+
224
+ @Column({ type: 'varchar', length: 255, nullable: true })
225
+ job_type_group: string | null;
226
+
227
+ // Transfer Information
228
+ @Column({ type: 'varchar', length: 255, nullable: true })
229
+ entity_transferred_from: string | null;
230
+
231
+ @Column({ type: 'date', nullable: true })
232
+ date_of_transfer: Date | null; // Date of Transfer (from)
233
+
234
+ @Column({ type: 'varchar', length: 255, nullable: true })
235
+ entity_transferred_to: string | null;
236
+
237
+ @Column({ type: 'date', nullable: true })
238
+ date_of_transfer_to: Date | null; // Date of Transfer (to)
239
+
240
+ @Column({ type: 'text', nullable: true })
241
+ job_description: string | null;
242
+
243
+ // Appointment Information
244
+ @Column({ type: 'int', nullable: true })
245
+ country_appointment_id: number | null; // Reference to country_master table
246
+
247
+ @Column({ type: 'date', nullable: true })
248
+ date_of_appointment: Date | null;
249
+
250
+ @Column({ type: 'varchar', length: 100, nullable: true })
251
+ appointment_grade: string | null;
252
+
253
+ @Column({ type: 'varchar', length: 100, nullable: true })
254
+ type_of_appointment: string | null;
255
+
256
+ @Column({ type: 'varchar', length: 100, nullable: true })
257
+ unit_code: string | null;
258
+
259
+ @Column({ type: 'boolean', nullable: true })
260
+ mc_work: boolean | null; // M&C Work
261
+
262
+ @Column({ type: 'varchar', length: 255, nullable: true })
263
+ office: string | null;
264
+
265
+ @Column({ type: 'varchar', length: 255, nullable: true })
266
+ governorate_name: string | null;
267
+
268
+ @Column({ type: 'varchar', length: 255, nullable: true })
269
+ department: string | null;
270
+
271
+ @Column({ type: 'varchar', length: 255, nullable: true })
272
+ works_in_department: string | null;
273
+
274
+ // Mission Information
275
+ @Column({ type: 'varchar', length: 255, nullable: true })
276
+ full_name_of_mission: string | null;
277
+
278
+ @Column({ type: 'varchar', length: 255, nullable: true })
279
+ mission: string | null;
280
+
281
+ @Column({ type: 'text', nullable: true })
282
+ description_of_mission: string | null;
283
+
284
+ @Column({ type: 'date', nullable: true })
285
+ date_of_last_transfer_to_mission: Date | null;
286
+
287
+ @Column({ type: 'date', nullable: true })
288
+ date_of_last_transfer_from_mission: Date | null;
289
+
290
+ @Column({ type: 'boolean', nullable: true })
291
+ diplomat: boolean | null;
292
+
293
+ // Performance and Termination
294
+ @Column({ type: 'varchar', length: 100, nullable: true })
295
+ efficiency_rating_for_the_year_month: string | null; // Efficiency rating for the year/month
296
+
297
+ @Column({ type: 'date', nullable: true })
298
+ retirement_termination_of_service_date: Date | null; // Retirement/Termination of Service Date
299
+
300
+ @Column({ type: 'text', nullable: true })
301
+ reason_for_leaving_service: string | null;
302
+
303
+ // ========== EDUCATION DETAILS FIELDS (all nullable) ==========
304
+ // Education Information
305
+ @Column({ type: 'date', nullable: true })
306
+ study_start_date: Date | null;
307
+
308
+ @Column({ type: 'date', nullable: true })
309
+ study_end_date: Date | null;
310
+
311
+ // Training Information
312
+ @Column({ type: 'date', nullable: true })
313
+ training_course_start_date: Date | null;
314
+
315
+ @Column({ type: 'date', nullable: true })
316
+ training_course_end_date: Date | null;
317
+ }
@@ -0,0 +1,51 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum RegisterCandidateApprovalStatus {
5
+ PENDING = "Pending",
6
+ IN_PROGRESS = "In Progress",
7
+ APPROVED = "Approved",
8
+ REJECTED = "Rejected"
9
+ }
10
+
11
+ @Entity({ name: 'register_candidate_approvals' })
12
+ export class RegisterCandidateApprovalDetails 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({ type: 'enum', enum: RegisterCandidateApprovalStatus, default: RegisterCandidateApprovalStatus.PENDING, nullable: false })
47
+ approval_status: RegisterCandidateApprovalStatus;
48
+
49
+ @Column({ type: 'boolean', default: true, nullable: false })
50
+ is_allowed: boolean;
51
+ }
@@ -0,0 +1,30 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'register_candidate_attachments' })
5
+ export class RegisterCandidateRequestAttachment extends BaseModel {
6
+
7
+ @Column({ type: 'integer', nullable: false })
8
+ request_id: number;
9
+
10
+ @Column({ type: 'integer', nullable: true })
11
+ service_id: number | null;
12
+
13
+ @Column({ type: 'integer', nullable: true })
14
+ sub_service_id: number | null;
15
+
16
+ @Column({ type: 'varchar', length: 500, nullable: false })
17
+ file_url: string;
18
+
19
+ @Column({ type: 'varchar', length: 255, nullable: true })
20
+ file_name: string;
21
+
22
+ @Column({ type: 'varchar', length: 100, nullable: true })
23
+ file_type: string;
24
+
25
+ @Column({ type: 'bigint', nullable: true })
26
+ file_size: number | null;
27
+
28
+ @Column({ type: 'integer', nullable: true })
29
+ chat_id: number | null;
30
+ }