@platform-modules/foreign-ministry 1.3.276 → 1.3.286

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 (91) hide show
  1. package/.env +10 -5
  2. package/dist/data-source.js +24 -1
  3. package/dist/helpers/evaluation-eligibility.utils.d.ts +10 -0
  4. package/dist/helpers/evaluation-eligibility.utils.js +39 -0
  5. package/dist/index.d.ts +12 -0
  6. package/dist/index.js +38 -1
  7. package/dist/models/EmployeeEvaluationAnswerModel.d.ts +13 -0
  8. package/dist/models/EmployeeEvaluationAnswerModel.js +46 -0
  9. package/dist/models/EmployeeEvaluationApprovalModel.d.ts +22 -0
  10. package/dist/models/EmployeeEvaluationApprovalModel.js +84 -0
  11. package/dist/models/EmployeeEvaluationAttachmentModel.d.ts +11 -0
  12. package/dist/models/EmployeeEvaluationAttachmentModel.js +52 -0
  13. package/dist/models/EmployeeEvaluationChatModel.d.ts +18 -0
  14. package/dist/models/EmployeeEvaluationChatModel.js +65 -0
  15. package/dist/models/EmployeeEvaluationModel.d.ts +16 -0
  16. package/dist/models/EmployeeEvaluationModel.js +59 -0
  17. package/dist/models/EmployeeEvaluationRequestModel.d.ts +34 -0
  18. package/dist/models/EmployeeEvaluationRequestModel.js +104 -0
  19. package/dist/models/EmployeeEvaluationWorkflowModel.d.ts +17 -0
  20. package/dist/models/EmployeeEvaluationWorkflowModel.js +67 -0
  21. package/dist/models/EvaluationEligibilitySettingModel.d.ts +23 -0
  22. package/dist/models/EvaluationEligibilitySettingModel.js +71 -0
  23. package/dist/models/EvaluationFormModel.d.ts +17 -0
  24. package/dist/models/EvaluationFormModel.js +64 -0
  25. package/dist/models/EvaluationFormQuestionModel.d.ts +22 -0
  26. package/dist/models/EvaluationFormQuestionModel.js +78 -0
  27. package/dist/models/EvaluationFormSectionModel.d.ts +12 -0
  28. package/dist/models/EvaluationFormSectionModel.js +54 -0
  29. package/dist/models/EvaluationMastersModel.d.ts +16 -0
  30. package/dist/models/EvaluationMastersModel.js +67 -0
  31. package/dist/models/EvaluationQuestionMasterModel.d.ts +10 -0
  32. package/dist/models/EvaluationQuestionMasterModel.js +42 -0
  33. package/dist/models/EvaluationSectionMasterModel.d.ts +7 -0
  34. package/dist/models/EvaluationSectionMasterModel.js +36 -0
  35. package/dist/models/EvaluationWorkflowModel.d.ts +60 -0
  36. package/dist/models/EvaluationWorkflowModel.js +215 -0
  37. package/dist/models/IneligibleForEvaluationModel.d.ts +8 -0
  38. package/dist/models/IneligibleForEvaluationModel.js +44 -0
  39. package/dist/models/MissionTravelClassConfigModel.d.ts +10 -0
  40. package/dist/models/MissionTravelClassConfigModel.js +50 -0
  41. package/dist/models/MissionTravelPerdiemModel.d.ts +10 -0
  42. package/dist/models/MissionTravelPerdiemModel.js +54 -0
  43. package/dist/models/UuidAuditModel.d.ts +9 -0
  44. package/dist/models/UuidAuditModel.js +41 -0
  45. package/package.json +1 -1
  46. package/src/data-source.ts +30 -2
  47. package/src/helpers/evaluation-eligibility.utils.ts +36 -0
  48. package/src/index.ts +468 -429
  49. package/src/models/AnnualTravelTicketPriceConfigurationItemModel.ts +36 -36
  50. package/src/models/AnnualTravelTicketPriceConfigurationModel.ts +35 -35
  51. package/src/models/AnnualTravelTicketRequestModel.ts +42 -42
  52. package/src/models/DiplomaticAcademyRequestModel.ts +80 -80
  53. package/src/models/DocumentationFileModel.ts +40 -40
  54. package/src/models/EmployeeEvaluationAnswerModel.ts +28 -0
  55. package/src/models/EmployeeEvaluationApprovalModel.ts +56 -0
  56. package/src/models/EmployeeEvaluationAttachmentModel.ts +29 -0
  57. package/src/models/EmployeeEvaluationChatModel.ts +42 -0
  58. package/src/models/EmployeeEvaluationModel.ts +38 -0
  59. package/src/models/EmployeeEvaluationRequestModel.ts +77 -0
  60. package/src/models/EmployeeEvaluationWorkflowModel.ts +43 -0
  61. package/src/models/EvaluationEligibilitySettingModel.ts +47 -0
  62. package/src/models/EvaluationFormModel.ts +40 -0
  63. package/src/models/EvaluationFormQuestionModel.ts +52 -0
  64. package/src/models/EvaluationFormSectionModel.ts +33 -0
  65. package/src/models/FinancialWorkFlowModel.ts +15 -15
  66. package/src/models/GatePassVisitorsModel.ts +7 -7
  67. package/src/models/LMSExternalEntityTrainedPersonModel.ts +45 -45
  68. package/src/models/LanguageCourseRequestModel.ts +67 -67
  69. package/src/models/LeaveConfigModel.ts +71 -71
  70. package/src/models/MissionTravelApprovalModel.ts +101 -101
  71. package/src/models/MissionTravelAttachmentModel.ts +56 -56
  72. package/src/models/MissionTravelChatModel.ts +52 -52
  73. package/src/models/MissionTravelPersonModel.ts +105 -105
  74. package/src/models/MissionTravelWorkflowModel.ts +54 -54
  75. package/src/models/PollOptionsModel.ts +26 -26
  76. package/src/models/PollVotesModel.ts +37 -37
  77. package/src/models/PollsModel.ts +49 -49
  78. package/src/models/ProjectContactsModel.ts +51 -51
  79. package/src/models/ProjectFaqModel.ts +36 -36
  80. package/src/models/ProjectInvoicesModel.ts +41 -41
  81. package/src/models/ProjectModel.ts +75 -75
  82. package/src/models/ProjectTasksModel.ts +75 -75
  83. package/src/models/ResignationTerminationApprovalModel.ts +9 -9
  84. package/src/models/ResignationTerminationRequestModel.ts +17 -17
  85. package/src/models/SectionModel.ts +35 -35
  86. package/src/models/ServicesNotificationConfigsModel.ts +55 -55
  87. package/src/models/TelephoneDirectoryModel.ts +20 -20
  88. package/dist/models/EmbassyMasterModel.d.ts +0 -16
  89. package/dist/models/EmbassyMasterModel.js +0 -75
  90. package/dist/models/UserDependentsModel.d.ts +0 -18
  91. package/dist/models/UserDependentsModel.js +0 -94
@@ -1,36 +1,36 @@
1
- import { Column, Entity, JoinColumn, ManyToOne, Unique } from 'typeorm';
2
- import { BaseModel } from './BaseModel';
3
- import { AnnualTravelTicketPriceConfiguration } from './AnnualTravelTicketPriceConfigurationModel';
4
-
5
- /**
6
- * Individual price slab within an annual travel ticket pricing configuration.
7
- * age_from is inclusive and age_to is exclusive to allow adjacent ranges.
8
- */
9
- @Entity({ name: 'annual_travel_ticket_price_configuration_items' })
10
- @Unique(['configuration_id', 'ticket_class', 'age_from', 'age_to'])
11
- export class AnnualTravelTicketPriceConfigurationItem extends BaseModel {
12
- @Column({ type: 'int', nullable: false })
13
- configuration_id: number;
14
-
15
- @ManyToOne(() => AnnualTravelTicketPriceConfiguration, (configuration) => configuration.price_slabs, { onDelete: 'CASCADE' })
16
- @JoinColumn({ name: 'configuration_id' })
17
- configuration: AnnualTravelTicketPriceConfiguration;
18
-
19
- @Column({ type: 'varchar', length: 100, nullable: true })
20
- ticket_class: string | null;
21
-
22
- @Column({ type: 'int', nullable: false })
23
- age_from: number;
24
-
25
- @Column({ type: 'int', nullable: false })
26
- age_to: number;
27
-
28
- @Column({ type: 'decimal', precision: 12, scale: 2, nullable: false })
29
- price: number | string;
30
-
31
- @Column({ type: 'varchar', length: 10, nullable: true, default: 'OMR' })
32
- currency_code: string | null;
33
-
34
- @Column({ type: 'text', nullable: true })
35
- notes: string | null;
36
- }
1
+ import { Column, Entity, JoinColumn, ManyToOne, Unique } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+ import { AnnualTravelTicketPriceConfiguration } from './AnnualTravelTicketPriceConfigurationModel';
4
+
5
+ /**
6
+ * Individual price slab within an annual travel ticket pricing configuration.
7
+ * age_from is inclusive and age_to is exclusive to allow adjacent ranges.
8
+ */
9
+ @Entity({ name: 'annual_travel_ticket_price_configuration_items' })
10
+ @Unique(['configuration_id', 'ticket_class', 'age_from', 'age_to'])
11
+ export class AnnualTravelTicketPriceConfigurationItem extends BaseModel {
12
+ @Column({ type: 'int', nullable: false })
13
+ configuration_id: number;
14
+
15
+ @ManyToOne(() => AnnualTravelTicketPriceConfiguration, (configuration) => configuration.price_slabs, { onDelete: 'CASCADE' })
16
+ @JoinColumn({ name: 'configuration_id' })
17
+ configuration: AnnualTravelTicketPriceConfiguration;
18
+
19
+ @Column({ type: 'varchar', length: 100, nullable: true })
20
+ ticket_class: string | null;
21
+
22
+ @Column({ type: 'int', nullable: false })
23
+ age_from: number;
24
+
25
+ @Column({ type: 'int', nullable: false })
26
+ age_to: number;
27
+
28
+ @Column({ type: 'decimal', precision: 12, scale: 2, nullable: false })
29
+ price: number | string;
30
+
31
+ @Column({ type: 'varchar', length: 10, nullable: true, default: 'OMR' })
32
+ currency_code: string | null;
33
+
34
+ @Column({ type: 'text', nullable: true })
35
+ notes: string | null;
36
+ }
@@ -1,35 +1,35 @@
1
- import { Column, Entity, OneToMany, Unique } from 'typeorm';
2
- import { BaseModel } from './BaseModel';
3
- import { AnnualTravelTicketPriceConfigurationItem } from './AnnualTravelTicketPriceConfigurationItemModel';
4
-
5
- /**
6
- * Admin configuration for annual travel ticket pricing.
7
- * One record per year (and optional service/sub-service pair), with multiple age slabs.
8
- */
9
- @Entity({ name: 'annual_travel_ticket_price_configurations' })
10
- @Unique(['service_id', 'sub_service_id', 'ticket_year'])
11
- export class AnnualTravelTicketPriceConfiguration extends BaseModel {
12
- @Column({ type: 'int', nullable: true })
13
- service_id: number | null;
14
-
15
- @Column({ type: 'int', nullable: true })
16
- sub_service_id: number | null;
17
-
18
- @Column({ type: 'int', nullable: false })
19
- ticket_year: number;
20
-
21
- @Column({ type: 'varchar', length: 255, nullable: true })
22
- configuration_name: string | null;
23
-
24
- @Column({ type: 'varchar', length: 10, nullable: true, default: 'OMR' })
25
- currency_code: string | null;
26
-
27
- @Column({ type: 'text', nullable: true })
28
- description: string | null;
29
-
30
- @Column({ type: 'boolean', default: true, nullable: false })
31
- is_active: boolean;
32
-
33
- @OneToMany(() => AnnualTravelTicketPriceConfigurationItem, (item) => item.configuration)
34
- price_slabs?: AnnualTravelTicketPriceConfigurationItem[];
35
- }
1
+ import { Column, Entity, OneToMany, Unique } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+ import { AnnualTravelTicketPriceConfigurationItem } from './AnnualTravelTicketPriceConfigurationItemModel';
4
+
5
+ /**
6
+ * Admin configuration for annual travel ticket pricing.
7
+ * One record per year (and optional service/sub-service pair), with multiple age slabs.
8
+ */
9
+ @Entity({ name: 'annual_travel_ticket_price_configurations' })
10
+ @Unique(['service_id', 'sub_service_id', 'ticket_year'])
11
+ export class AnnualTravelTicketPriceConfiguration extends BaseModel {
12
+ @Column({ type: 'int', nullable: true })
13
+ service_id: number | null;
14
+
15
+ @Column({ type: 'int', nullable: true })
16
+ sub_service_id: number | null;
17
+
18
+ @Column({ type: 'int', nullable: false })
19
+ ticket_year: number;
20
+
21
+ @Column({ type: 'varchar', length: 255, nullable: true })
22
+ configuration_name: string | null;
23
+
24
+ @Column({ type: 'varchar', length: 10, nullable: true, default: 'OMR' })
25
+ currency_code: string | null;
26
+
27
+ @Column({ type: 'text', nullable: true })
28
+ description: string | null;
29
+
30
+ @Column({ type: 'boolean', default: true, nullable: false })
31
+ is_active: boolean;
32
+
33
+ @OneToMany(() => AnnualTravelTicketPriceConfigurationItem, (item) => item.configuration)
34
+ price_slabs?: AnnualTravelTicketPriceConfigurationItem[];
35
+ }
@@ -1,23 +1,23 @@
1
- import { Column, Entity } from 'typeorm';
2
- import { BaseModel } from './BaseModel';
3
-
4
- export enum AnnualTravelTicketPermanentResidence {
5
- SALALAH = 'Salalah',
6
- MUSANDAM = 'Musandam',
7
- }
8
-
9
- export interface AnnualTravelTicketFamilyDetail {
10
- person_name: string;
11
- relation: string;
12
- age: number;
13
- age_category: string;
14
- price: number | string;
15
- }
16
-
17
- /** Aligns with mission bank account request lifecycle for shared workflow UI. */
18
- export enum AnnualTravelTicketRequestStatus {
19
- PENDING = 'Pending',
20
- ASSIGNED = 'Assigned',
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum AnnualTravelTicketPermanentResidence {
5
+ SALALAH = 'Salalah',
6
+ MUSANDAM = 'Musandam',
7
+ }
8
+
9
+ export interface AnnualTravelTicketFamilyDetail {
10
+ person_name: string;
11
+ relation: string;
12
+ age: number;
13
+ age_category: string;
14
+ price: number | string;
15
+ }
16
+
17
+ /** Aligns with mission bank account request lifecycle for shared workflow UI. */
18
+ export enum AnnualTravelTicketRequestStatus {
19
+ PENDING = 'Pending',
20
+ ASSIGNED = 'Assigned',
21
21
  IN_PROGRESS = 'In Progress',
22
22
  APPROVED = 'Approved',
23
23
  REJECTED = 'Rejected',
@@ -47,28 +47,28 @@ export class AnnualTravelTicketRequests extends BaseModel {
47
47
  @Column({ type: 'varchar', length: 120, nullable: false })
48
48
  civil_id_or_passport_number: string;
49
49
 
50
- @Column({ type: 'enum', enum: AnnualTravelTicketPermanentResidence, nullable: false })
51
- permanent_residence: AnnualTravelTicketPermanentResidence;
52
-
53
- /** Traveler list with person name, relation, age, age category, and price. */
54
- @Column({ type: 'jsonb', nullable: true })
55
- family_details: AnnualTravelTicketFamilyDetail[] | null;
56
-
57
- @Column({ type: 'varchar', length: 100, nullable: false })
58
- bank_account_number: string;
59
-
60
- @Column({ type: 'varchar', length: 255, nullable: false })
61
- travel_from: string;
62
-
63
- @Column({ type: 'varchar', length: 255, nullable: false })
64
- travel_to: string;
65
-
66
- @Column({ type: 'date', nullable: false })
67
- date_of_travel: string;
68
-
69
- @Column({
70
- type: 'enum',
71
- enum: AnnualTravelTicketRequestStatus,
50
+ @Column({ type: 'enum', enum: AnnualTravelTicketPermanentResidence, nullable: false })
51
+ permanent_residence: AnnualTravelTicketPermanentResidence;
52
+
53
+ /** Traveler list with person name, relation, age, age category, and price. */
54
+ @Column({ type: 'jsonb', nullable: true })
55
+ family_details: AnnualTravelTicketFamilyDetail[] | null;
56
+
57
+ @Column({ type: 'varchar', length: 100, nullable: false })
58
+ bank_account_number: string;
59
+
60
+ @Column({ type: 'varchar', length: 255, nullable: false })
61
+ travel_from: string;
62
+
63
+ @Column({ type: 'varchar', length: 255, nullable: false })
64
+ travel_to: string;
65
+
66
+ @Column({ type: 'date', nullable: false })
67
+ date_of_travel: string;
68
+
69
+ @Column({
70
+ type: 'enum',
71
+ enum: AnnualTravelTicketRequestStatus,
72
72
  default: AnnualTravelTicketRequestStatus.PENDING,
73
73
  nullable: false,
74
74
  })
@@ -1,80 +1,80 @@
1
- import { Column, Entity } from "typeorm";
2
- import { BaseModel } from './BaseModel';
3
-
4
- export enum DiplomaticAcademyStatus {
5
- SUBMITTED = "Submitted",
6
- PENDING = "Pending",
7
- ASSIGNED = "Assigned",
8
- IN_PROGRESS = "In Progress",
9
- APPROVED = "Approved",
10
- REJECTED = "Rejected"
11
- }
12
-
13
- @Entity({ name: 'diplomatic_academy_requests' })
14
- export class DiplomaticAcademyRequests extends BaseModel {
15
-
16
- // Common columns
17
- @Column({ type: 'int', nullable: true })
18
- req_user_department_id: number | null;
19
-
20
- @Column({ type: 'int', nullable: true })
21
- req_user_section_id: number | null;
22
-
23
- @Column({ type: 'int', nullable: true })
24
- service_id: number | null;
25
-
26
- @Column({ type: 'int', nullable: true })
27
- sub_service_id: number | null;
28
-
29
- @Column({ type: 'int', nullable: false })
30
- user_id: number;
31
-
32
- // Diplomatic Academy specific columns
33
- @Column({ type: 'varchar', length: 500, nullable: false })
34
- course_name: string;
35
-
36
- @Column({ type: 'jsonb', nullable: true })
37
- cost_details: {
38
- material_price?: number;
39
- transportation?: number;
40
- accommodation?: number;
41
- allowances?: number;
42
- food?: number;
43
- present?: number;
44
- } | null;
45
-
46
- @Column({ type: 'int', nullable: false })
47
- estimated_participants: number;
48
-
49
- @Column({ type: 'date', nullable: false })
50
- timeline_date_from: Date;
51
-
52
- @Column({ type: 'date', nullable: false })
53
- timeline_date_to: Date;
54
-
55
- @Column({ type: 'time', nullable: true })
56
- timeline_time_from: string | null;
57
-
58
- @Column({ type: 'time', nullable: true })
59
- timeline_time_to: string | null;
60
-
61
- @Column({ type: 'jsonb', nullable: false })
62
- participants_details: Array<{
63
- full_name: string;
64
- passport: string;
65
- age: number;
66
- qualifications: string;
67
- experience: string;
68
- institution: string;
69
- }>;
70
-
71
- @Column({ type: 'enum', enum: DiplomaticAcademyStatus, default: DiplomaticAcademyStatus.PENDING, nullable: false })
72
- status: DiplomaticAcademyStatus;
73
-
74
- @Column({ type: 'int', nullable: true })
75
- course_id: number | null;
76
-
77
- @Column({ type: 'varchar', nullable: true })
78
- workflow_execution_id: string | null;
79
-
80
- }
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum DiplomaticAcademyStatus {
5
+ SUBMITTED = "Submitted",
6
+ PENDING = "Pending",
7
+ ASSIGNED = "Assigned",
8
+ IN_PROGRESS = "In Progress",
9
+ APPROVED = "Approved",
10
+ REJECTED = "Rejected"
11
+ }
12
+
13
+ @Entity({ name: 'diplomatic_academy_requests' })
14
+ export class DiplomaticAcademyRequests extends BaseModel {
15
+
16
+ // Common columns
17
+ @Column({ type: 'int', nullable: true })
18
+ req_user_department_id: number | null;
19
+
20
+ @Column({ type: 'int', nullable: true })
21
+ req_user_section_id: number | null;
22
+
23
+ @Column({ type: 'int', nullable: true })
24
+ service_id: number | null;
25
+
26
+ @Column({ type: 'int', nullable: true })
27
+ sub_service_id: number | null;
28
+
29
+ @Column({ type: 'int', nullable: false })
30
+ user_id: number;
31
+
32
+ // Diplomatic Academy specific columns
33
+ @Column({ type: 'varchar', length: 500, nullable: false })
34
+ course_name: string;
35
+
36
+ @Column({ type: 'jsonb', nullable: true })
37
+ cost_details: {
38
+ material_price?: number;
39
+ transportation?: number;
40
+ accommodation?: number;
41
+ allowances?: number;
42
+ food?: number;
43
+ present?: number;
44
+ } | null;
45
+
46
+ @Column({ type: 'int', nullable: false })
47
+ estimated_participants: number;
48
+
49
+ @Column({ type: 'date', nullable: false })
50
+ timeline_date_from: Date;
51
+
52
+ @Column({ type: 'date', nullable: false })
53
+ timeline_date_to: Date;
54
+
55
+ @Column({ type: 'time', nullable: true })
56
+ timeline_time_from: string | null;
57
+
58
+ @Column({ type: 'time', nullable: true })
59
+ timeline_time_to: string | null;
60
+
61
+ @Column({ type: 'jsonb', nullable: false })
62
+ participants_details: Array<{
63
+ full_name: string;
64
+ passport: string;
65
+ age: number;
66
+ qualifications: string;
67
+ experience: string;
68
+ institution: string;
69
+ }>;
70
+
71
+ @Column({ type: 'enum', enum: DiplomaticAcademyStatus, default: DiplomaticAcademyStatus.PENDING, nullable: false })
72
+ status: DiplomaticAcademyStatus;
73
+
74
+ @Column({ type: 'int', nullable: true })
75
+ course_id: number | null;
76
+
77
+ @Column({ type: 'varchar', nullable: true })
78
+ workflow_execution_id: string | null;
79
+
80
+ }
@@ -1,40 +1,40 @@
1
- import { Column, Entity } from 'typeorm';
2
- import { BaseModel } from './BaseModel';
3
-
4
- @Entity({ name: 'documentation_files' })
5
- export class DocumentationFile extends BaseModel {
6
- @Column({ type: 'int', nullable: true })
7
- project_id: number | null;
8
-
9
- @Column({ type: 'int' })
10
- folder_id: number;
11
-
12
- @Column({ type: 'text', nullable: true })
13
- file_path: string;
14
-
15
- @Column({ type: 'varchar', length: 500, nullable: true })
16
- filename: string;
17
-
18
- @Column({ type: 'bigint', nullable: true })
19
- filesize: number;
20
-
21
- @Column({ type: 'varchar', length: 100, nullable: true })
22
- filetype: string;
23
-
24
- constructor(
25
- project_id?: number | null,
26
- folder_id?: number,
27
- file_path?: string,
28
- filename?: string,
29
- filesize?: number,
30
- filetype?: string
31
- ) {
32
- super();
33
- this.project_id = project_id ?? null;
34
- this.folder_id = folder_id ?? 0;
35
- this.file_path = file_path ?? '';
36
- this.filename = filename ?? '';
37
- this.filesize = filesize ?? 0;
38
- this.filetype = filetype ?? '';
39
- }
40
- }
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'documentation_files' })
5
+ export class DocumentationFile extends BaseModel {
6
+ @Column({ type: 'int', nullable: true })
7
+ project_id: number | null;
8
+
9
+ @Column({ type: 'int' })
10
+ folder_id: number;
11
+
12
+ @Column({ type: 'text', nullable: true })
13
+ file_path: string;
14
+
15
+ @Column({ type: 'varchar', length: 500, nullable: true })
16
+ filename: string;
17
+
18
+ @Column({ type: 'bigint', nullable: true })
19
+ filesize: number;
20
+
21
+ @Column({ type: 'varchar', length: 100, nullable: true })
22
+ filetype: string;
23
+
24
+ constructor(
25
+ project_id?: number | null,
26
+ folder_id?: number,
27
+ file_path?: string,
28
+ filename?: string,
29
+ filesize?: number,
30
+ filetype?: string
31
+ ) {
32
+ super();
33
+ this.project_id = project_id ?? null;
34
+ this.folder_id = folder_id ?? 0;
35
+ this.file_path = file_path ?? '';
36
+ this.filename = filename ?? '';
37
+ this.filesize = filesize ?? 0;
38
+ this.filetype = filetype ?? '';
39
+ }
40
+ }
@@ -0,0 +1,28 @@
1
+ import { Column, Entity, JoinColumn, ManyToOne } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+ import { EvaluationFormSection } from './EvaluationFormSectionModel';
4
+ import { EvaluationFormQuestion } from './EvaluationFormQuestionModel';
5
+ import { EmployeeEvaluation } from './EmployeeEvaluationModel';
6
+
7
+ @Entity({ name: 'employee_evaluation_answers' })
8
+ export class EmployeeEvaluationAnswers extends BaseModel {
9
+ @ManyToOne(() => EmployeeEvaluation, { onDelete: 'CASCADE' })
10
+ @JoinColumn({ name: 'employee_evaluation_id' })
11
+ employee_evaluation: EmployeeEvaluation;
12
+
13
+ /** Form section (replaces legacy evaluation_section_master). */
14
+ @ManyToOne(() => EvaluationFormSection, { onDelete: 'RESTRICT' })
15
+ @JoinColumn({ name: 'evaluation_section_id' })
16
+ evaluation_section: EvaluationFormSection;
17
+
18
+ /** Form question (replaces legacy evaluation_question_master). */
19
+ @ManyToOne(() => EvaluationFormQuestion, { onDelete: 'RESTRICT' })
20
+ @JoinColumn({ name: 'evaluation_question_id' })
21
+ evaluation_question: EvaluationFormQuestion;
22
+
23
+ @Column({ type: 'int', nullable: false })
24
+ score: number;
25
+
26
+ @Column({ type: 'text', nullable: true })
27
+ remarks: string | null;
28
+ }
@@ -0,0 +1,56 @@
1
+ import { Column, Entity } from 'typeorm';
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum EmployeeEvaluationApprovalStatus {
5
+ PENDING = 'Pending',
6
+ IN_PROGRESS = 'In Progress',
7
+ APPROVED = 'Approved',
8
+ REJECTED = 'Rejected',
9
+ }
10
+
11
+ @Entity({ name: 'employee_evaluation_approvals' })
12
+ export class EmployeeEvaluationApprovalDetails 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: false })
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: EmployeeEvaluationApprovalStatus,
49
+ default: EmployeeEvaluationApprovalStatus.PENDING,
50
+ nullable: false,
51
+ })
52
+ approval_status: EmployeeEvaluationApprovalStatus;
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: 'employee_evaluation_attachments' })
5
+ export class EmployeeEvaluationRequestAttachment 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 | null;
20
+
21
+ @Column({ type: 'varchar', length: 100, nullable: true })
22
+ file_type: string | null;
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 EmployeeEvaluationMessageType {
5
+ TEXT = 'text',
6
+ IMAGE = 'image',
7
+ VIDEO = 'video',
8
+ FILE = 'file',
9
+ LINK = 'link',
10
+ }
11
+
12
+ @Entity({ name: 'employee_evaluation_chats' })
13
+ export class EmployeeEvaluationRequestChat 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 | null;
28
+
29
+ @Column({ type: 'text', nullable: false })
30
+ message: string;
31
+
32
+ @Column({
33
+ type: 'enum',
34
+ enum: EmployeeEvaluationMessageType,
35
+ default: EmployeeEvaluationMessageType.TEXT,
36
+ nullable: false,
37
+ })
38
+ message_type: EmployeeEvaluationMessageType;
39
+
40
+ @Column({ type: 'text', nullable: true })
41
+ status: string | null;
42
+ }