@platform-modules/foreign-ministry 1.3.237 → 1.3.239

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.
package/.env CHANGED
@@ -1,17 +1,5 @@
1
- # DB_HOST=localhost
2
- # DB_PORT=5432
3
- # DB_USER=postgres
4
- # DB_PASS=Fa@123
5
- # DB_NAME=FM
6
-
7
- DB_HOST=164.52.222.169
1
+ DB_HOST=localhost
8
2
  DB_PORT=5432
9
- DB_USER=postgres_admin_user
10
- DB_PASS=pg_admin_user_pwd_caa_fa_$%^&OIukhjgcvbn
3
+ DB_USER=postgres
4
+ DB_PASS=Fa@123
11
5
  DB_NAME=FM
12
-
13
- # DB_HOST=216.48.187.46
14
- # DB_PORT=5432
15
- # DB_USER=adminuser
16
- # DB_PASS=postgres_caa_fm_qa_34567
17
- # DB_NAME=FM_QA
@@ -0,0 +1,16 @@
1
+ import { BaseModel } from './BaseModel';
2
+ export declare class EmbassyMaster extends BaseModel {
3
+ embassy_name: string;
4
+ embassy_name_arabic: string | null;
5
+ country_id: number | null;
6
+ city: string | null;
7
+ address: string | null;
8
+ phone: string | null;
9
+ fax: string | null;
10
+ email: string | null;
11
+ website: string | null;
12
+ description: string | null;
13
+ is_active: boolean;
14
+ display_order: number;
15
+ constructor(embassy_name: string);
16
+ }
@@ -0,0 +1,75 @@
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.EmbassyMaster = void 0;
13
+ const typeorm_1 = require("typeorm");
14
+ const BaseModel_1 = require("./BaseModel");
15
+ let EmbassyMaster = class EmbassyMaster extends BaseModel_1.BaseModel {
16
+ constructor(embassy_name) {
17
+ super();
18
+ this.embassy_name = embassy_name;
19
+ this.is_active = true;
20
+ this.display_order = 0;
21
+ }
22
+ };
23
+ exports.EmbassyMaster = EmbassyMaster;
24
+ __decorate([
25
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: false }),
26
+ __metadata("design:type", String)
27
+ ], EmbassyMaster.prototype, "embassy_name", void 0);
28
+ __decorate([
29
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
30
+ __metadata("design:type", Object)
31
+ ], EmbassyMaster.prototype, "embassy_name_arabic", void 0);
32
+ __decorate([
33
+ (0, typeorm_1.Column)({ type: 'int', nullable: true }),
34
+ __metadata("design:type", Object)
35
+ ], EmbassyMaster.prototype, "country_id", void 0);
36
+ __decorate([
37
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
38
+ __metadata("design:type", Object)
39
+ ], EmbassyMaster.prototype, "city", void 0);
40
+ __decorate([
41
+ (0, typeorm_1.Column)({ type: 'text', nullable: true }),
42
+ __metadata("design:type", Object)
43
+ ], EmbassyMaster.prototype, "address", void 0);
44
+ __decorate([
45
+ (0, typeorm_1.Column)({ type: 'varchar', length: 50, nullable: true }),
46
+ __metadata("design:type", Object)
47
+ ], EmbassyMaster.prototype, "phone", void 0);
48
+ __decorate([
49
+ (0, typeorm_1.Column)({ type: 'varchar', length: 50, nullable: true }),
50
+ __metadata("design:type", Object)
51
+ ], EmbassyMaster.prototype, "fax", void 0);
52
+ __decorate([
53
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
54
+ __metadata("design:type", Object)
55
+ ], EmbassyMaster.prototype, "email", void 0);
56
+ __decorate([
57
+ (0, typeorm_1.Column)({ type: 'varchar', length: 500, nullable: true }),
58
+ __metadata("design:type", Object)
59
+ ], EmbassyMaster.prototype, "website", void 0);
60
+ __decorate([
61
+ (0, typeorm_1.Column)({ type: 'text', nullable: true }),
62
+ __metadata("design:type", Object)
63
+ ], EmbassyMaster.prototype, "description", void 0);
64
+ __decorate([
65
+ (0, typeorm_1.Column)({ type: 'boolean', default: true }),
66
+ __metadata("design:type", Boolean)
67
+ ], EmbassyMaster.prototype, "is_active", void 0);
68
+ __decorate([
69
+ (0, typeorm_1.Column)({ type: 'int', default: 0 }),
70
+ __metadata("design:type", Number)
71
+ ], EmbassyMaster.prototype, "display_order", void 0);
72
+ exports.EmbassyMaster = EmbassyMaster = __decorate([
73
+ (0, typeorm_1.Entity)({ name: 'embassy_master' }),
74
+ __metadata("design:paramtypes", [String])
75
+ ], EmbassyMaster);
@@ -6,5 +6,7 @@ export declare class ProjectMilestonePhases extends BaseModel {
6
6
  display_order: number;
7
7
  checklists: string[] | null;
8
8
  criteria: string[] | null;
9
- constructor(project_id?: number, milestone_id?: number, phase_name?: string, display_order?: number, checklists?: string[] | null, criteria?: string[] | null);
9
+ start_date: Date | null;
10
+ end_date: Date | null;
11
+ constructor(project_id?: number, milestone_id?: number, phase_name?: string, display_order?: number, checklists?: string[] | null, criteria?: string[] | null, start_date?: Date | null, end_date?: Date | null);
10
12
  }
@@ -13,7 +13,7 @@ exports.ProjectMilestonePhases = void 0;
13
13
  const typeorm_1 = require("typeorm");
14
14
  const BaseModel_1 = require("./BaseModel");
15
15
  let ProjectMilestonePhases = class ProjectMilestonePhases extends BaseModel_1.BaseModel {
16
- constructor(project_id, milestone_id, phase_name, display_order, checklists, criteria) {
16
+ constructor(project_id, milestone_id, phase_name, display_order, checklists, criteria, start_date, end_date) {
17
17
  super();
18
18
  this.project_id = project_id ?? 0;
19
19
  this.milestone_id = milestone_id ?? 0;
@@ -21,6 +21,8 @@ let ProjectMilestonePhases = class ProjectMilestonePhases extends BaseModel_1.Ba
21
21
  this.display_order = display_order ?? 1;
22
22
  this.checklists = checklists ?? null;
23
23
  this.criteria = criteria ?? null;
24
+ this.start_date = start_date ?? null;
25
+ this.end_date = end_date ?? null;
24
26
  }
25
27
  };
26
28
  exports.ProjectMilestonePhases = ProjectMilestonePhases;
@@ -48,7 +50,15 @@ __decorate([
48
50
  (0, typeorm_1.Column)({ type: 'jsonb', nullable: true }),
49
51
  __metadata("design:type", Object)
50
52
  ], ProjectMilestonePhases.prototype, "criteria", void 0);
53
+ __decorate([
54
+ (0, typeorm_1.Column)({ type: 'date', nullable: true }),
55
+ __metadata("design:type", Object)
56
+ ], ProjectMilestonePhases.prototype, "start_date", void 0);
57
+ __decorate([
58
+ (0, typeorm_1.Column)({ type: 'date', nullable: true }),
59
+ __metadata("design:type", Object)
60
+ ], ProjectMilestonePhases.prototype, "end_date", void 0);
51
61
  exports.ProjectMilestonePhases = ProjectMilestonePhases = __decorate([
52
62
  (0, typeorm_1.Entity)({ name: 'project_milestone_phases' }),
53
- __metadata("design:paramtypes", [Number, Number, String, Number, Object, Object])
63
+ __metadata("design:paramtypes", [Number, Number, String, Number, Object, Object, Object, Object])
54
64
  ], ProjectMilestonePhases);
@@ -18,5 +18,6 @@ export declare class ResignationTerminationApprovalDetails extends BaseModel {
18
18
  approved_by: number | null;
19
19
  comment: string;
20
20
  approval_status: ResignationTerminationApprovalStatus;
21
+ is_edit: boolean;
21
22
  is_allowed: boolean;
22
23
  }
@@ -70,6 +70,10 @@ __decorate([
70
70
  (0, typeorm_1.Column)({ type: 'enum', enum: ResignationTerminationApprovalStatus, default: ResignationTerminationApprovalStatus.PENDING, nullable: false }),
71
71
  __metadata("design:type", String)
72
72
  ], ResignationTerminationApprovalDetails.prototype, "approval_status", void 0);
73
+ __decorate([
74
+ (0, typeorm_1.Column)({ type: 'boolean', default: false, nullable: false }),
75
+ __metadata("design:type", Boolean)
76
+ ], ResignationTerminationApprovalDetails.prototype, "is_edit", void 0);
73
77
  __decorate([
74
78
  (0, typeorm_1.Column)({ type: 'boolean', default: true, nullable: false }),
75
79
  __metadata("design:type", Boolean)
@@ -0,0 +1,18 @@
1
+ import { BaseModel } from './BaseModel';
2
+ export declare class UserDependents extends BaseModel {
3
+ user_id: number;
4
+ first_name: string | null;
5
+ last_name: string | null;
6
+ family_name: string | null;
7
+ dob: Date | null;
8
+ age: number | null;
9
+ relation_type: string | null;
10
+ passport_available: boolean;
11
+ passport_number: string | null;
12
+ passport_type: string | null;
13
+ passport_issue_date: Date | null;
14
+ passport_place_of_issue: string | null;
15
+ passport_expiry_date: Date | null;
16
+ is_active: boolean;
17
+ constructor(user_id?: number, first_name?: string, last_name?: string, family_name?: string, dob?: Date, age?: number, relation_type?: string, passport_available?: boolean, passport_number?: string, passport_type?: string, passport_issue_date?: Date, passport_place_of_issue?: string, passport_expiry_date?: Date);
18
+ }
@@ -0,0 +1,94 @@
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.UserDependents = void 0;
13
+ const typeorm_1 = require("typeorm");
14
+ const BaseModel_1 = require("./BaseModel");
15
+ let UserDependents = class UserDependents extends BaseModel_1.BaseModel {
16
+ constructor(user_id, first_name, last_name, family_name, dob, age, relation_type, passport_available, passport_number, passport_type, passport_issue_date, passport_place_of_issue, passport_expiry_date) {
17
+ super();
18
+ this.user_id = user_id || 0;
19
+ this.first_name = first_name || null;
20
+ this.last_name = last_name || null;
21
+ this.family_name = family_name || null;
22
+ this.dob = dob || null;
23
+ this.age = age || null;
24
+ this.relation_type = relation_type || null;
25
+ this.passport_available = passport_available || false;
26
+ this.passport_number = passport_number || null;
27
+ this.passport_type = passport_type || null;
28
+ this.passport_issue_date = passport_issue_date || null;
29
+ this.passport_place_of_issue = passport_place_of_issue || null;
30
+ this.passport_expiry_date = passport_expiry_date || null;
31
+ this.is_active = true;
32
+ }
33
+ };
34
+ exports.UserDependents = UserDependents;
35
+ __decorate([
36
+ (0, typeorm_1.Column)({ type: 'int', nullable: false }),
37
+ __metadata("design:type", Number)
38
+ ], UserDependents.prototype, "user_id", void 0);
39
+ __decorate([
40
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
41
+ __metadata("design:type", Object)
42
+ ], UserDependents.prototype, "first_name", void 0);
43
+ __decorate([
44
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
45
+ __metadata("design:type", Object)
46
+ ], UserDependents.prototype, "last_name", void 0);
47
+ __decorate([
48
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
49
+ __metadata("design:type", Object)
50
+ ], UserDependents.prototype, "family_name", void 0);
51
+ __decorate([
52
+ (0, typeorm_1.Column)({ type: 'date', nullable: true }),
53
+ __metadata("design:type", Object)
54
+ ], UserDependents.prototype, "dob", void 0);
55
+ __decorate([
56
+ (0, typeorm_1.Column)({ type: 'int', nullable: true }),
57
+ __metadata("design:type", Object)
58
+ ], UserDependents.prototype, "age", void 0);
59
+ __decorate([
60
+ (0, typeorm_1.Column)({ type: 'varchar', length: 100, nullable: true }),
61
+ __metadata("design:type", Object)
62
+ ], UserDependents.prototype, "relation_type", void 0);
63
+ __decorate([
64
+ (0, typeorm_1.Column)({ type: 'boolean', default: false }),
65
+ __metadata("design:type", Boolean)
66
+ ], UserDependents.prototype, "passport_available", void 0);
67
+ __decorate([
68
+ (0, typeorm_1.Column)({ type: 'varchar', length: 100, nullable: true }),
69
+ __metadata("design:type", Object)
70
+ ], UserDependents.prototype, "passport_number", void 0);
71
+ __decorate([
72
+ (0, typeorm_1.Column)({ type: 'varchar', length: 100, nullable: true }),
73
+ __metadata("design:type", Object)
74
+ ], UserDependents.prototype, "passport_type", void 0);
75
+ __decorate([
76
+ (0, typeorm_1.Column)({ type: 'date', nullable: true }),
77
+ __metadata("design:type", Object)
78
+ ], UserDependents.prototype, "passport_issue_date", void 0);
79
+ __decorate([
80
+ (0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
81
+ __metadata("design:type", Object)
82
+ ], UserDependents.prototype, "passport_place_of_issue", void 0);
83
+ __decorate([
84
+ (0, typeorm_1.Column)({ type: 'date', nullable: true }),
85
+ __metadata("design:type", Object)
86
+ ], UserDependents.prototype, "passport_expiry_date", void 0);
87
+ __decorate([
88
+ (0, typeorm_1.Column)({ type: 'boolean', default: true }),
89
+ __metadata("design:type", Boolean)
90
+ ], UserDependents.prototype, "is_active", void 0);
91
+ exports.UserDependents = UserDependents = __decorate([
92
+ (0, typeorm_1.Entity)({ name: 'user_dependents' }),
93
+ __metadata("design:paramtypes", [Number, String, String, String, Date, Number, String, Boolean, String, String, Date, String, Date])
94
+ ], UserDependents);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@platform-modules/foreign-ministry",
3
- "version": "1.3.237",
3
+ "version": "1.3.239",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "scripts": {
@@ -33,15 +33,15 @@ export class FinancialWorkFlow extends BaseModel {
33
33
  @Column({ type: 'int', nullable: true })
34
34
  approved_by_role_id: number;
35
35
 
36
- @Column({ type: 'int', nullable: true })
37
- step_order: number;
38
-
39
- @Column({ type: 'varchar', length: 50, nullable: true })
40
- action: string | null;
41
-
42
- @ManyToOne(() => FinancialRequests, fr => fr.workflows)
43
- @JoinColumn({ name: 'financial_request_id' })
44
- financialRequest?: FinancialRequests;
36
+ @Column({ type: 'int', nullable: true })
37
+ step_order: number;
38
+
39
+ @Column({ type: 'varchar', length: 50, nullable: true })
40
+ action: string | null;
41
+
42
+ @ManyToOne(() => FinancialRequests, fr => fr.workflows)
43
+ @JoinColumn({ name: 'financial_request_id' })
44
+ financialRequest?: FinancialRequests;
45
45
 
46
46
  constructor(
47
47
  financial_request_id: number,
@@ -55,10 +55,10 @@ export class FinancialWorkFlow extends BaseModel {
55
55
  this.status = status;
56
56
  this.approved_by_user_id = approved_by_user_id;
57
57
  this.content = content;
58
- this.financial_approval_id = 0;
59
- this.activity_date = new Date();
60
- this.step_order = step_order;
61
- this.action = null;
62
- }
63
- }
58
+ this.financial_approval_id = 0;
59
+ this.activity_date = new Date();
60
+ this.step_order = step_order;
61
+ this.action = null;
62
+ }
63
+ }
64
64
 
@@ -85,10 +85,10 @@ export class GatePassVisitors extends BaseModel {
85
85
  @Column({ type: 'varchar', length: 255, nullable: true })
86
86
  visiting_person_in_department: string | null; // زائر في القسم (Visiting Person in Department)
87
87
 
88
- @Column({ type: 'int', nullable: true, unique: true })
89
- serial_number: number | null;
90
-
91
- // QR Code for Gate Pass
88
+ @Column({ type: 'int', nullable: true, unique: true })
89
+ serial_number: number | null;
90
+
91
+ // QR Code for Gate Pass
92
92
  @Column({ type: 'text', nullable: true })
93
93
  qr_code_url: string | null; // QR code URL for this visitor (data URL can be 6000+ characters)
94
94
 
@@ -134,9 +134,9 @@ export class GatePassVisitors extends BaseModel {
134
134
  this.visitor_email_address = visitor_email_address;
135
135
  this.visitor_mobile_number = visitor_mobile_number;
136
136
  this.visitor_photo_url = visitor_photo_url;
137
- this.visitor_photo_file_name = visitor_photo_file_name;
138
- this.serial_number = null;
139
- this.gate_pass_generated = false;
137
+ this.visitor_photo_file_name = visitor_photo_file_name;
138
+ this.serial_number = null;
139
+ this.gate_pass_generated = false;
140
140
  this.email_sent = false;
141
141
  }
142
142
  }
@@ -1,26 +1,26 @@
1
- import { Column, Entity, JoinColumn, ManyToOne, OneToMany } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
- import { Poll } from "./PollsModel";
4
- import { PollVote } from "./PollVotesModel";
5
-
6
- @Entity({ name: "poll_options" })
7
- export class PollOption extends BaseModel {
8
- @Column({ type: "int", nullable: false })
9
- poll_id: number;
10
-
11
- @Column({ type: "varchar", length: 500, nullable: false })
12
- option_text: string;
13
-
14
- @ManyToOne(() => Poll, (poll) => poll.options, { nullable: false })
15
- @JoinColumn({ name: "poll_id" })
16
- poll?: Poll;
17
-
18
- @OneToMany(() => PollVote, (vote) => vote.option)
19
- votes?: PollVote[];
20
-
21
- constructor() {
22
- super();
23
- this.poll_id = 0;
24
- this.option_text = "";
25
- }
26
- }
1
+ import { Column, Entity, JoinColumn, ManyToOne, OneToMany } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+ import { Poll } from "./PollsModel";
4
+ import { PollVote } from "./PollVotesModel";
5
+
6
+ @Entity({ name: "poll_options" })
7
+ export class PollOption extends BaseModel {
8
+ @Column({ type: "int", nullable: false })
9
+ poll_id: number;
10
+
11
+ @Column({ type: "varchar", length: 500, nullable: false })
12
+ option_text: string;
13
+
14
+ @ManyToOne(() => Poll, (poll) => poll.options, { nullable: false })
15
+ @JoinColumn({ name: "poll_id" })
16
+ poll?: Poll;
17
+
18
+ @OneToMany(() => PollVote, (vote) => vote.option)
19
+ votes?: PollVote[];
20
+
21
+ constructor() {
22
+ super();
23
+ this.poll_id = 0;
24
+ this.option_text = "";
25
+ }
26
+ }
@@ -1,37 +1,37 @@
1
- import { Column, Entity, Index, JoinColumn, ManyToOne } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
- import { Poll } from "./PollsModel";
4
- import { PollOption } from "./PollOptionsModel";
5
- import { User } from "./user";
6
-
7
- @Entity({ name: "poll_votes" })
8
- @Index("uq_poll_option_user", ["poll_id", "option_id", "user_id"], { unique: true })
9
- export class PollVote extends BaseModel {
10
- @Column({ type: "int", nullable: false })
11
- poll_id: number;
12
-
13
- @Column({ type: "int", nullable: false })
14
- option_id: number;
15
-
16
- @Column({ type: "int", nullable: false })
17
- user_id: number;
18
-
19
- @ManyToOne(() => Poll, (poll) => poll.votes, { nullable: false })
20
- @JoinColumn({ name: "poll_id" })
21
- poll?: Poll;
22
-
23
- @ManyToOne(() => PollOption, (option) => option.votes, { nullable: false })
24
- @JoinColumn({ name: "option_id" })
25
- option?: PollOption;
26
-
27
- @ManyToOne(() => User, { nullable: false })
28
- @JoinColumn({ name: "user_id" })
29
- user?: User;
30
-
31
- constructor() {
32
- super();
33
- this.poll_id = 0;
34
- this.option_id = 0;
35
- this.user_id = 0;
36
- }
37
- }
1
+ import { Column, Entity, Index, JoinColumn, ManyToOne } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+ import { Poll } from "./PollsModel";
4
+ import { PollOption } from "./PollOptionsModel";
5
+ import { User } from "./user";
6
+
7
+ @Entity({ name: "poll_votes" })
8
+ @Index("uq_poll_option_user", ["poll_id", "option_id", "user_id"], { unique: true })
9
+ export class PollVote extends BaseModel {
10
+ @Column({ type: "int", nullable: false })
11
+ poll_id: number;
12
+
13
+ @Column({ type: "int", nullable: false })
14
+ option_id: number;
15
+
16
+ @Column({ type: "int", nullable: false })
17
+ user_id: number;
18
+
19
+ @ManyToOne(() => Poll, (poll) => poll.votes, { nullable: false })
20
+ @JoinColumn({ name: "poll_id" })
21
+ poll?: Poll;
22
+
23
+ @ManyToOne(() => PollOption, (option) => option.votes, { nullable: false })
24
+ @JoinColumn({ name: "option_id" })
25
+ option?: PollOption;
26
+
27
+ @ManyToOne(() => User, { nullable: false })
28
+ @JoinColumn({ name: "user_id" })
29
+ user?: User;
30
+
31
+ constructor() {
32
+ super();
33
+ this.poll_id = 0;
34
+ this.option_id = 0;
35
+ this.user_id = 0;
36
+ }
37
+ }
@@ -1,49 +1,49 @@
1
- import { Column, Entity, JoinColumn, ManyToOne, OneToMany } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
- import { ConversationsV2 } from "./ConversationsV2Model";
4
- import { PollOption } from "./PollOptionsModel";
5
- import { PollVote } from "./PollVotesModel";
6
-
7
- @Entity({ name: "poll" })
8
- export class Poll extends BaseModel {
9
- @Column({ type: "int", nullable: false })
10
- group_id: number;
11
-
12
- @Column({ type: "int", nullable: true })
13
- meeting_id?: number | null;
14
-
15
- @Column({ type: "int", nullable: false })
16
- conversation_id: number;
17
-
18
- @Column({ type: "varchar", length: 255, nullable: false })
19
- title: string;
20
-
21
- @Column({ type: "text", nullable: false })
22
- question: string;
23
-
24
- @Column({ type: "timestamptz", nullable: true })
25
- expires_at?: Date | null;
26
-
27
- @Column({ type: "boolean", default: false })
28
- allow_multiple: boolean;
29
-
30
- @ManyToOne(() => ConversationsV2, { nullable: false })
31
- @JoinColumn({ name: "conversation_id" })
32
- conversation?: ConversationsV2;
33
-
34
- @OneToMany(() => PollOption, (option) => option.poll)
35
- options?: PollOption[];
36
-
37
- @OneToMany(() => PollVote, (vote) => vote.poll)
38
- votes?: PollVote[];
39
-
40
- constructor() {
41
- super();
42
- this.group_id = 0;
43
- this.meeting_id = null;
44
- this.conversation_id = 0;
45
- this.title = "";
46
- this.question = "";
47
- this.allow_multiple = false;
48
- }
49
- }
1
+ import { Column, Entity, JoinColumn, ManyToOne, OneToMany } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+ import { ConversationsV2 } from "./ConversationsV2Model";
4
+ import { PollOption } from "./PollOptionsModel";
5
+ import { PollVote } from "./PollVotesModel";
6
+
7
+ @Entity({ name: "poll" })
8
+ export class Poll extends BaseModel {
9
+ @Column({ type: "int", nullable: false })
10
+ group_id: number;
11
+
12
+ @Column({ type: "int", nullable: true })
13
+ meeting_id?: number | null;
14
+
15
+ @Column({ type: "int", nullable: false })
16
+ conversation_id: number;
17
+
18
+ @Column({ type: "varchar", length: 255, nullable: false })
19
+ title: string;
20
+
21
+ @Column({ type: "text", nullable: false })
22
+ question: string;
23
+
24
+ @Column({ type: "timestamptz", nullable: true })
25
+ expires_at?: Date | null;
26
+
27
+ @Column({ type: "boolean", default: false })
28
+ allow_multiple: boolean;
29
+
30
+ @ManyToOne(() => ConversationsV2, { nullable: false })
31
+ @JoinColumn({ name: "conversation_id" })
32
+ conversation?: ConversationsV2;
33
+
34
+ @OneToMany(() => PollOption, (option) => option.poll)
35
+ options?: PollOption[];
36
+
37
+ @OneToMany(() => PollVote, (vote) => vote.poll)
38
+ votes?: PollVote[];
39
+
40
+ constructor() {
41
+ super();
42
+ this.group_id = 0;
43
+ this.meeting_id = null;
44
+ this.conversation_id = 0;
45
+ this.title = "";
46
+ this.question = "";
47
+ this.allow_multiple = false;
48
+ }
49
+ }
@@ -21,13 +21,21 @@ export class ProjectMilestonePhases extends BaseModel {
21
21
  @Column({ type: 'jsonb', nullable: true })
22
22
  criteria: string[] | null;
23
23
 
24
+ @Column({ type: 'date', nullable: true })
25
+ start_date: Date | null;
26
+
27
+ @Column({ type: 'date', nullable: true })
28
+ end_date: Date | null;
29
+
24
30
  constructor(
25
31
  project_id?: number,
26
32
  milestone_id?: number,
27
33
  phase_name?: string,
28
34
  display_order?: number,
29
35
  checklists?: string[] | null,
30
- criteria?: string[] | null
36
+ criteria?: string[] | null,
37
+ start_date?: Date | null,
38
+ end_date?: Date | null
31
39
  ) {
32
40
  super();
33
41
  this.project_id = project_id ?? 0;
@@ -36,5 +44,7 @@ export class ProjectMilestonePhases extends BaseModel {
36
44
  this.display_order = display_order ?? 1;
37
45
  this.checklists = checklists ?? null;
38
46
  this.criteria = criteria ?? null;
47
+ this.start_date = start_date ?? null;
48
+ this.end_date = end_date ?? null;
39
49
  }
40
50
  }
@@ -43,9 +43,12 @@ export class ResignationTerminationApprovalDetails extends BaseModel {
43
43
  @Column({ type: 'varchar', length: 500, nullable: true, default: '' })
44
44
  comment: string;
45
45
 
46
- @Column({ type: 'enum', enum: ResignationTerminationApprovalStatus, default: ResignationTerminationApprovalStatus.PENDING, nullable: false })
47
- approval_status: ResignationTerminationApprovalStatus;
48
-
49
- @Column({ type: 'boolean', default: true, nullable: false })
50
- is_allowed: boolean;
51
- }
46
+ @Column({ type: 'enum', enum: ResignationTerminationApprovalStatus, default: ResignationTerminationApprovalStatus.PENDING, nullable: false })
47
+ approval_status: ResignationTerminationApprovalStatus;
48
+
49
+ @Column({ type: 'boolean', default: false, nullable: false })
50
+ is_edit: boolean;
51
+
52
+ @Column({ type: 'boolean', default: true, nullable: false })
53
+ is_allowed: boolean;
54
+ }
@@ -42,18 +42,18 @@ export class TelephoneDirectory extends BaseModel {
42
42
  @Column({ type: "varchar", length: 20, nullable: true })
43
43
  fax_number: string; // Fax Number
44
44
 
45
- @Column({ type: "varchar", length: 255, nullable: true })
46
- location: string; // Optional
47
-
48
- // External user specific optional fields
49
- @Column({ type: "varchar", length: 255, nullable: true })
50
- external_department: string;
51
-
52
- @Column({ type: "varchar", length: 255, nullable: true })
53
- external_position: string;
54
-
55
- @Column({ type: "varchar", length: 255, nullable: true })
56
- external_diplomatic_title: string;
45
+ @Column({ type: "varchar", length: 255, nullable: true })
46
+ location: string; // Optional
47
+
48
+ // External user specific optional fields
49
+ @Column({ type: "varchar", length: 255, nullable: true })
50
+ external_department: string;
51
+
52
+ @Column({ type: "varchar", length: 255, nullable: true })
53
+ external_position: string;
54
+
55
+ @Column({ type: "varchar", length: 255, nullable: true })
56
+ external_diplomatic_title: string;
57
57
 
58
58
  // Department Information
59
59
  @Column({ nullable: true })
@@ -88,7 +88,7 @@ export class TelephoneDirectory extends BaseModel {
88
88
  @Column({ type: "int", nullable: true })
89
89
  sub_service_id: number;
90
90
 
91
- constructor(select_type?: "personal" | "department" | "organization", category?: "FM" | "Embassy" | "M&C" | "external", name?: string, position?: string, diplomatic_title?: string, embassy_id?: number | null, contextual_search?: string | null, email?: string, contact_number?: string, extension_number?: string, fax_number?: string, location?: string, external_department?: string, external_position?: string, external_diplomatic_title?: string, department_id?: number, employee_id?: number, street?: string, city?: string, state?: string, zip_code?: string, country?: string, photo_url?: string, service_id?: number, sub_service_id?: number) {
91
+ constructor(select_type?: "personal" | "department" | "organization", category?: "FM" | "Embassy" | "M&C" | "external", name?: string, position?: string, diplomatic_title?: string, embassy_id?: number | null, contextual_search?: string | null, email?: string, contact_number?: string, extension_number?: string, fax_number?: string, location?: string, external_department?: string, external_position?: string, external_diplomatic_title?: string, department_id?: number, employee_id?: number, street?: string, city?: string, state?: string, zip_code?: string, country?: string, photo_url?: string, service_id?: number, sub_service_id?: number) {
92
92
  super();
93
93
  this.select_type = select_type || "personal";
94
94
  this.category = category || "FM";
@@ -99,13 +99,13 @@ export class TelephoneDirectory extends BaseModel {
99
99
  this.contextual_search = contextual_search || null;
100
100
  this.email = email || "";
101
101
  this.contact_number = contact_number || "";
102
- this.extension_number = extension_number || "";
103
- this.fax_number = fax_number || "";
104
- this.location = location || "";
105
- this.external_department = external_department || "";
106
- this.external_position = external_position || "";
107
- this.external_diplomatic_title = external_diplomatic_title || "";
108
- this.department_id = department_id || 0;
102
+ this.extension_number = extension_number || "";
103
+ this.fax_number = fax_number || "";
104
+ this.location = location || "";
105
+ this.external_department = external_department || "";
106
+ this.external_position = external_position || "";
107
+ this.external_diplomatic_title = external_diplomatic_title || "";
108
+ this.department_id = department_id || 0;
109
109
  this.employee_id = employee_id || 0;
110
110
  this.street = street || "";
111
111
  this.city = city || "";
@@ -1,3 +0,0 @@
1
- -- Run against the FM database before deploying the updated Departments entity.
2
- ALTER TABLE departments
3
- ADD COLUMN IF NOT EXISTS is_geographical_dept boolean NOT NULL DEFAULT false;