diff --git a/BMA.EHR.Application/Repositories/Leaves/LeaveRequests/LeaveRequestRepository.cs b/BMA.EHR.Application/Repositories/Leaves/LeaveRequests/LeaveRequestRepository.cs
index 6223d786..ce22cd23 100644
--- a/BMA.EHR.Application/Repositories/Leaves/LeaveRequests/LeaveRequestRepository.cs
+++ b/BMA.EHR.Application/Repositories/Leaves/LeaveRequests/LeaveRequestRepository.cs
@@ -289,6 +289,11 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
rawData = rawData
.Where(x => node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true)))))).ToList();
}
+ else if (role == "BROTHER")
+ {
+ rawData = rawData
+ .Where(x => node == 4 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true))))).ToList();
+ }
else if (role == "ROOT")
{
rawData = rawData
@@ -398,6 +403,11 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
rawData = rawData
.Where(x => node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true))))));
}
+ else if (role == "BROTHER")
+ {
+ rawData = rawData
+ .Where(x => node == 4 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true)))));
+ }
else if (role == "ROOT")
{
rawData = rawData
@@ -575,6 +585,11 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
rawData = rawData
.Where(x => node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true))))));
}
+ else if (role == "BROTHER")
+ {
+ rawData = rawData
+ .Where(x => node == 4 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true)))));
+ }
else if (role == "ROOT")
{
rawData = rawData
@@ -875,7 +890,7 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
// fix: If no commander, skip notification
if (firstCommander != null)
- {
+ {
// Send Notification
var noti1 = new Notification
{
@@ -955,7 +970,9 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
approver.ApproveStatus = "APPROVE";
approver.Comment = reason;
-
+ approver.LastUpdateFullName = FullName ?? "";
+ approver.LastUpdateUserId = userId.ToString("D");
+ approver.LastUpdatedAt = DateTime.Now;
//await _dbContext.SaveChangesAsync();
if (approver.Seq != maxSeq)
@@ -1045,7 +1062,9 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
approver.ApproveStatus = "REJECT";
approver.Comment = reason;
-
+ approver.LastUpdateFullName = FullName ?? "";
+ approver.LastUpdateUserId = userId.ToString("D");
+ approver.LastUpdatedAt = DateTime.Now;
if (approver.Seq != maxSeq)
{
@@ -1108,7 +1127,7 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
.Where(x => x.ApproveType!.ToUpper() == "COMMANDER")
.OrderBy(x => x.Seq)
.ToList();
- if(commanders.Count > 0 || commanders != null)
+ if (commanders.Count > 0 || commanders != null)
{
if (rawData.ApproveStep != "st3")
{
@@ -1141,7 +1160,9 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
approver.ApproveStatus = "APPROVE";
approver.Comment = reason;
-
+ approver.LastUpdateFullName = FullName ?? "";
+ approver.LastUpdateUserId = userId.ToString("D");
+ approver.LastUpdatedAt = DateTime.Now;
if (approver.Seq != maxSeq)
{
var nextApprover = approvers.FirstOrDefault(x => x.Seq == approver.Seq + 1);
@@ -1294,7 +1315,9 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
approver.ApproveStatus = "REJECT";
approver.Comment = reason;
-
+ approver.LastUpdateFullName = FullName ?? "";
+ approver.LastUpdateUserId = userId.ToString("D");
+ approver.LastUpdatedAt = DateTime.Now;
if (approver.Seq != maxSeq)
{
var nextApprover = approvers.FirstOrDefault(x => x.Seq == approver.Seq + 1);
@@ -1586,6 +1609,16 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
node == null ? true : true
).ToList();
}
+ else if (role == "BROTHER")
+ {
+ data = data.Where(x =>
+ node == 4 ? x.Child3DnaId == Guid.Parse(nodeId) :
+ node == 3 ? x.Child2DnaId == Guid.Parse(nodeId) :
+ node == 2 ? x.Child1DnaId == Guid.Parse(nodeId) :
+ node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId) :
+ node == null ? true : true
+ ).ToList();
+ }
else if (role == "ROOT")
{
data = data.Where(x => x.RootDnaId == Guid.Parse(nodeId)).ToList();
@@ -1606,7 +1639,7 @@ namespace BMA.EHR.Application.Repositories.Leaves.LeaveRequests
).ToList();
}
// กรองตามที่ fe ส่งมา
- if (role == "ROOT" || role == "OWNER" || role == "CHILD" || role == "PARENT")
+ if (role == "ROOT" || role == "OWNER" || role == "CHILD" || role == "BROTHER" || role == "PARENT")
{
data = data
.Where(x => nodeByReq == 4 ? x.Child4Id == Guid.Parse(nodeIdByReq) : nodeByReq == 3 ? x.Child3Id == Guid.Parse(nodeIdByReq) : nodeByReq == 2 ? x.Child2Id == Guid.Parse(nodeIdByReq) : nodeByReq == 1 ? x.Child1Id == Guid.Parse(nodeIdByReq) : nodeByReq == 0 ? x.RootId == Guid.Parse(nodeIdByReq) : true)
diff --git a/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/AdditionalCheckRequestRepository.cs b/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/AdditionalCheckRequestRepository.cs
index 68d4f32a..04c0c921 100644
--- a/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/AdditionalCheckRequestRepository.cs
+++ b/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/AdditionalCheckRequestRepository.cs
@@ -160,6 +160,12 @@ namespace BMA.EHR.Application.Repositories.Leaves.TimeAttendants
.Where(x => node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true))))))
.ToList();
}
+ else if (role == "BROTHER")
+ {
+ data = data
+ .Where(x => node == 4 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true)))))
+ .ToList();
+ }
else if (role == "ROOT")
{
data = data
diff --git a/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/ProcessUserTimeStampRepository.cs b/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/ProcessUserTimeStampRepository.cs
index bc517b13..64d32a19 100644
--- a/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/ProcessUserTimeStampRepository.cs
+++ b/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/ProcessUserTimeStampRepository.cs
@@ -158,6 +158,16 @@ namespace BMA.EHR.Application.Repositories.Leaves.TimeAttendants
node == null ? true : true
).ToList();
}
+ else if (role == "BROTHER")
+ {
+ data = data.Where(x =>
+ node == 4 ? x.Child3DnaId == Guid.Parse(nodeId) :
+ node == 3 ? x.Child2DnaId == Guid.Parse(nodeId) :
+ node == 2 ? x.Child1DnaId == Guid.Parse(nodeId) :
+ node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId) :
+ node == null ? true : true
+ ).ToList();
+ }
else if (role == "ROOT")
{
data = data.Where(x => x.RootDnaId == Guid.Parse(nodeId)).ToList();
@@ -178,7 +188,7 @@ namespace BMA.EHR.Application.Repositories.Leaves.TimeAttendants
).ToList();
}
// กรองตามที่ fe ส่งมา
- if (role == "ROOT" || role == "OWNER" || role == "CHILD" || role == "PARENT")
+ if (role == "ROOT" || role == "OWNER" || role == "CHILD" || role == "BROTHER" || role == "PARENT")
{
data = data.Where(x =>
nodeByReq == 4 ? x.Child4Id == Guid.Parse(nodeIdByReq) :
@@ -266,6 +276,12 @@ namespace BMA.EHR.Application.Repositories.Leaves.TimeAttendants
.Where(x => node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true))))))
.ToList();
}
+ else if (role == "BROTHER")
+ {
+ data = data
+ .Where(x => node == 4 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true)))))
+ .ToList();
+ }
else if (role == "ROOT")
{
data = data
diff --git a/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/UserTimeStampRepository.cs b/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/UserTimeStampRepository.cs
index a5415537..b7a766e9 100644
--- a/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/UserTimeStampRepository.cs
+++ b/BMA.EHR.Application/Repositories/Leaves/TimeAttendants/UserTimeStampRepository.cs
@@ -124,6 +124,12 @@ namespace BMA.EHR.Application.Repositories.Leaves.TimeAttendants
.Where(x => node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true))))))
.ToList();
}
+ else if (role == "BROTHER")
+ {
+ data = data
+ .Where(x => node == 4 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true)))))
+ .ToList();
+ }
else if (role == "ROOT")
{
data = data
diff --git a/BMA.EHR.Discipline.Service/Controllers/DisciplineComplaint_AppealController.cs b/BMA.EHR.Discipline.Service/Controllers/DisciplineComplaint_AppealController.cs
index bd5e3134..a9d14a71 100644
--- a/BMA.EHR.Discipline.Service/Controllers/DisciplineComplaint_AppealController.cs
+++ b/BMA.EHR.Discipline.Service/Controllers/DisciplineComplaint_AppealController.cs
@@ -772,6 +772,18 @@ namespace BMA.EHR.DisciplineComplaint_Appeal.Service.Controllers
? profileAdmin?.RootDnaId
: "";
}
+ if (role == "BROTHER")
+ {
+ nodeId = profileAdmin?.Node == 4
+ ? profileAdmin?.Child3DnaId
+ : profileAdmin?.Node == 3
+ ? profileAdmin?.Child2DnaId
+ : profileAdmin?.Node == 2
+ ? profileAdmin?.Child1DnaId
+ : profileAdmin?.Node == 1 || profileAdmin?.Node == 0
+ ? profileAdmin?.RootDnaId
+ : "";
+ }
else if (role == "ROOT" || role == "PARENT")
{
nodeId = profileAdmin?.RootDnaId;
@@ -802,6 +814,11 @@ namespace BMA.EHR.DisciplineComplaint_Appeal.Service.Controllers
data_search = data_search
.Where(x => node == 4 ? x.child4DnaId == nodeId : (node == 3 ? x.child3DnaId == nodeId : (node == 2 ? x.child2DnaId == nodeId : (node == 1 ? x.child1DnaId == nodeId : (node == 0 ? x.rootDnaId == nodeId : (node == null ? true : true)))))).ToList();
}
+ else if (role == "BROTHER")
+ {
+ data_search = data_search
+ .Where(x => node == 4 ? x.child3DnaId == nodeId : (node == 3 ? x.child2DnaId == nodeId : (node == 2 ? x.child1DnaId == nodeId : (node == 1 || node == 0 ? x.rootDnaId == nodeId : (node == null ? true : true))))).ToList();
+ }
else if (role == "ROOT")
{
data_search = data_search
diff --git a/BMA.EHR.Domain/Models/Leave/Requests/LeaveRequestApprover.cs b/BMA.EHR.Domain/Models/Leave/Requests/LeaveRequestApprover.cs
index 11b1b719..10e7175d 100644
--- a/BMA.EHR.Domain/Models/Leave/Requests/LeaveRequestApprover.cs
+++ b/BMA.EHR.Domain/Models/Leave/Requests/LeaveRequestApprover.cs
@@ -1,4 +1,5 @@
using BMA.EHR.Domain.Models.Base;
+using Microsoft.EntityFrameworkCore;
namespace BMA.EHR.Domain.Models.Leave.Requests
{
@@ -16,6 +17,9 @@ namespace BMA.EHR.Domain.Models.Leave.Requests
public string PositionName { get; set; } = string.Empty;
+ [Comment("ตำแหน่งใต้ลายเช็นต์")]
+ public string? PositionSign { get; set; } = string.Empty;
+
public Guid ProfileId { get; set; } = Guid.Empty;
public Guid KeycloakId { get; set; } = Guid.Empty;
diff --git a/BMA.EHR.Infrastructure/Migrations/LeaveDb/20251211080157_update_LeaveRequestApprover_add_PositionSign.Designer.cs b/BMA.EHR.Infrastructure/Migrations/LeaveDb/20251211080157_update_LeaveRequestApprover_add_PositionSign.Designer.cs
new file mode 100644
index 00000000..d62357c4
--- /dev/null
+++ b/BMA.EHR.Infrastructure/Migrations/LeaveDb/20251211080157_update_LeaveRequestApprover_add_PositionSign.Designer.cs
@@ -0,0 +1,1597 @@
+//
+using System;
+using BMA.EHR.Infrastructure.Persistence;
+using Microsoft.EntityFrameworkCore;
+using Microsoft.EntityFrameworkCore.Infrastructure;
+using Microsoft.EntityFrameworkCore.Migrations;
+using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
+
+#nullable disable
+
+namespace BMA.EHR.Infrastructure.Migrations.LeaveDb
+{
+ [DbContext(typeof(LeaveDbContext))]
+ [Migration("20251211080157_update_LeaveRequestApprover_add_PositionSign")]
+ partial class update_LeaveRequestApprover_add_PositionSign
+ {
+ ///
+ protected override void BuildTargetModel(ModelBuilder modelBuilder)
+ {
+#pragma warning disable 612, 618
+ modelBuilder
+ .HasAnnotation("ProductVersion", "7.0.9")
+ .HasAnnotation("Relational:MaxIdentifierLength", 64);
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Documents.Document", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)");
+
+ b.Property("CreatedDate")
+ .HasColumnType("datetime(6)");
+
+ b.Property("Detail")
+ .IsRequired()
+ .HasColumnType("text");
+
+ b.Property("FileName")
+ .IsRequired()
+ .HasMaxLength(255)
+ .HasColumnType("varchar(255)");
+
+ b.Property("FileSize")
+ .HasColumnType("int");
+
+ b.Property("FileType")
+ .IsRequired()
+ .HasMaxLength(128)
+ .HasColumnType("varchar(128)");
+
+ b.Property("ObjectRefId")
+ .HasColumnType("char(36)");
+
+ b.HasKey("Id");
+
+ b.ToTable("Document");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.Commons.LeaveType", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("Code")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("รหัสประเภทการลา");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("Limit")
+ .HasColumnType("int")
+ .HasComment("จำนวนวันลาสูงสุดประจำปี");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("ชื่อประเภทการลา");
+
+ b.HasKey("Id");
+
+ b.ToTable("LeaveTypes");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.Requests.LeaveBeginning", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("Child1DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child2DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child3DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child4DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("FirstName")
+ .HasColumnType("longtext");
+
+ b.Property("LastName")
+ .HasColumnType("longtext");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("LeaveDays")
+ .HasColumnType("double")
+ .HasComment("จำนวนวันลายกมา");
+
+ b.Property("LeaveDaysUsed")
+ .HasColumnType("double")
+ .HasComment("จำนวนวันลาที่ใช้ไป");
+
+ b.Property("LeaveTypeId")
+ .HasColumnType("char(36)")
+ .HasComment("รหัสประเภทการลา");
+
+ b.Property("LeaveYear")
+ .HasColumnType("int")
+ .HasComment("ปีงบประมาณ");
+
+ b.Property("Prefix")
+ .HasColumnType("longtext");
+
+ b.Property("ProfileId")
+ .HasColumnType("char(36)")
+ .HasComment("รหัส Profile ในระบบทะเบียนประวัติ");
+
+ b.Property("RootDnaId")
+ .HasColumnType("char(36)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("LeaveTypeId");
+
+ b.ToTable("LeaveBeginnings");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.Requests.LeaveDocument", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("DocumentId")
+ .HasColumnType("char(36)");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("LeaveRequestId")
+ .HasColumnType("char(36)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("DocumentId");
+
+ b.HasIndex("LeaveRequestId");
+
+ b.ToTable("LeaveDocuments");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.Requests.LeaveRequest", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("AbsentDayAt")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("AbsentDayGetIn")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("AbsentDayLocation")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("AbsentDayRegistorDate")
+ .HasColumnType("datetime(6)");
+
+ b.Property("AbsentDaySummon")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("Amount")
+ .HasColumnType("double");
+
+ b.Property("ApproveStep")
+ .HasColumnType("longtext")
+ .HasComment("step การอนุมัติ st1 = จทน.อนุมัตื,st2 = ผู้บังคับบัญชา อนุมัติ ");
+
+ b.Property("BirthDate")
+ .HasColumnType("datetime(6)");
+
+ b.Property("CancelLeaveWrote")
+ .HasColumnType("longtext")
+ .HasComment("เขียนที่ (ขอยกเลิก)");
+
+ b.Property("Child1")
+ .HasColumnType("longtext");
+
+ b.Property("Child1DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child1Id")
+ .HasColumnType("char(36)");
+
+ b.Property("Child2")
+ .HasColumnType("longtext");
+
+ b.Property("Child2DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child2Id")
+ .HasColumnType("char(36)");
+
+ b.Property("Child3")
+ .HasColumnType("longtext");
+
+ b.Property("Child3DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child3Id")
+ .HasColumnType("char(36)");
+
+ b.Property("Child4")
+ .HasColumnType("longtext");
+
+ b.Property("Child4DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child4Id")
+ .HasColumnType("char(36)");
+
+ b.Property("CitizenId")
+ .HasColumnType("longtext");
+
+ b.Property("CommanderPosition")
+ .HasColumnType("longtext");
+
+ b.Property("CoupleDayCountryHistory")
+ .HasColumnType("longtext");
+
+ b.Property("CoupleDayEndDateHistory")
+ .HasColumnType("datetime(6)");
+
+ b.Property("CoupleDayLevel")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("CoupleDayLevelCountry")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("CoupleDayName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("CoupleDayPosition")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("CoupleDayStartDateHistory")
+ .HasColumnType("datetime(6)");
+
+ b.Property("CoupleDaySumTotalHistory")
+ .HasColumnType("longtext");
+
+ b.Property("CoupleDayTotalHistory")
+ .HasColumnType("longtext");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("DateAppoint")
+ .HasColumnType("datetime(6)");
+
+ b.Property("Dear")
+ .HasColumnType("longtext")
+ .HasComment("เรียนใคร");
+
+ b.Property("FirstName")
+ .HasColumnType("longtext");
+
+ b.Property("Gender")
+ .HasColumnType("longtext");
+
+ b.Property("HajjDayStatus")
+ .HasColumnType("tinyint(1)");
+
+ b.Property("KeycloakUserId")
+ .HasColumnType("char(36)");
+
+ b.Property("LastName")
+ .HasColumnType("longtext");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("LeaveAddress")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("สถานที่ติดต่อขณะลา");
+
+ b.Property("LeaveBirthDate")
+ .HasColumnType("datetime(6)");
+
+ b.Property("LeaveCancelComment")
+ .HasColumnType("longtext")
+ .HasComment("เหตุผลในการขอยกเลิก");
+
+ b.Property("LeaveCancelDocumentId")
+ .HasColumnType("char(36)");
+
+ b.Property("LeaveCancelStatus")
+ .HasColumnType("longtext")
+ .HasComment("สถานะของคำขอยกเลิก");
+
+ b.Property("LeaveComment")
+ .HasColumnType("longtext")
+ .HasComment("ความเห็นของผู้บังคับบัญชา");
+
+ b.Property("LeaveDetail")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("รายละเอียดการลา");
+
+ b.Property("LeaveDirectorComment")
+ .HasColumnType("longtext")
+ .HasComment("ความเห็นของผู้อำนวยการสำนัก");
+
+ b.Property("LeaveDraftDocumentId")
+ .HasColumnType("char(36)");
+
+ b.Property("LeaveEndDate")
+ .HasColumnType("datetime(6)")
+ .HasComment("วัน เดือน ปีสิ้นสุดลา");
+
+ b.Property("LeaveGovernmentDate")
+ .HasColumnType("datetime(6)");
+
+ b.Property("LeaveLast")
+ .HasColumnType("datetime(6)");
+
+ b.Property("LeaveNumber")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("หมายเลขที่ติดต่อขณะลา");
+
+ b.Property("LeaveRange")
+ .HasColumnType("longtext")
+ .HasComment("ช่วงของการลาของวันเริ่ม เช่น ลาทั้งวัน ครึ่งวันเช้า ครึ่งวันบ่าย");
+
+ b.Property("LeaveRangeEnd")
+ .HasColumnType("longtext")
+ .HasComment("ช่วงของการลาของวันสิ้นสุด เช่น ลาทั้งวัน ครึ่งวันเช้า ครึ่งวันบ่าย");
+
+ b.Property("LeaveSalary")
+ .HasColumnType("int");
+
+ b.Property("LeaveSalaryText")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("LeaveStartDate")
+ .HasColumnType("datetime(6)")
+ .HasComment("วัน เดือน ปีเริ่มต้นลา");
+
+ b.Property("LeaveStatus")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("สถานะของคำร้อง");
+
+ b.Property("LeaveSubTypeName")
+ .HasColumnType("longtext");
+
+ b.Property("LeaveTotal")
+ .HasColumnType("double");
+
+ b.Property("LeaveTypeCode")
+ .HasColumnType("longtext")
+ .HasComment("code ของประเภทการลา");
+
+ b.Property("LeaveWrote")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("เขียนที่");
+
+ b.Property("OrdainDayBuddhistLentAddress")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("OrdainDayBuddhistLentName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("OrdainDayLocationAddress")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("OrdainDayLocationName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("OrdainDayLocationNumber")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("OrdainDayOrdination")
+ .HasColumnType("datetime(6)");
+
+ b.Property("OrdainDayStatus")
+ .HasColumnType("tinyint(1)");
+
+ b.Property("OrganizationName")
+ .HasColumnType("longtext")
+ .HasComment("สังกัดผู้ยื่นขอ");
+
+ b.Property("PositionLevelName")
+ .HasColumnType("longtext")
+ .HasComment("ระดับผู้ยื่นขอ");
+
+ b.Property("PositionName")
+ .HasColumnType("longtext")
+ .HasComment("ตำแหน่งผู้ยื่นขอ");
+
+ b.Property("Prefix")
+ .HasColumnType("longtext");
+
+ b.Property("ProfileId")
+ .HasColumnType("char(36)");
+
+ b.Property("ProfileType")
+ .HasColumnType("longtext");
+
+ b.Property("RestDayCurrentTotal")
+ .HasColumnType("double");
+
+ b.Property("RestDayOldTotal")
+ .HasColumnType("double");
+
+ b.Property("Root")
+ .HasColumnType("longtext");
+
+ b.Property("RootDnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("RootId")
+ .HasColumnType("char(36)");
+
+ b.Property("StudyDayCountry")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("StudyDayDegreeLevel")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("StudyDayScholarship")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("StudyDaySubject")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("StudyDayTrainingName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("StudyDayTrainingSubject")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("StudyDayUniversityName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("TypeId")
+ .HasColumnType("char(36)");
+
+ b.Property("WifeDayDateBorn")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("WifeDayName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.HasKey("Id");
+
+ b.HasIndex("LeaveCancelDocumentId");
+
+ b.HasIndex("LeaveDraftDocumentId");
+
+ b.HasIndex("TypeId");
+
+ b.ToTable("LeaveRequests");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.Requests.LeaveRequestApprover", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("ApproveStatus")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("ApproveType")
+ .HasColumnType("longtext");
+
+ b.Property("Comment")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("FirstName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("KeycloakId")
+ .HasColumnType("char(36)");
+
+ b.Property("LastName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("LeaveRequestId")
+ .HasColumnType("char(36)");
+
+ b.Property("PositionName")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("PositionSign")
+ .HasColumnType("longtext")
+ .HasComment("ตำแหน่งใต้ลายเช็นต์");
+
+ b.Property("Prefix")
+ .IsRequired()
+ .HasColumnType("longtext");
+
+ b.Property("ProfileId")
+ .HasColumnType("char(36)");
+
+ b.Property("Seq")
+ .HasColumnType("int");
+
+ b.HasKey("Id");
+
+ b.HasIndex("LeaveRequestId");
+
+ b.ToTable("LeaveRequestApprovers");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.TimeAttendants.AdditionalCheckRequest", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("CheckDate")
+ .HasColumnType("datetime(6)")
+ .HasComment("*วันที่ลงเวลา");
+
+ b.Property("CheckInEdit")
+ .HasColumnType("tinyint(1)")
+ .HasComment("*ขอลงเวลาช่วงเช้า");
+
+ b.Property("CheckOutEdit")
+ .HasColumnType("tinyint(1)")
+ .HasComment("*ขอลงเวลาช่วงบ่าย");
+
+ b.Property("Child1DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child2DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child3DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child4DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Comment")
+ .HasColumnType("longtext")
+ .HasComment("หมายเหตุในการการอนุมัติ/ไม่อนุมัติ");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("Description")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("*หมายเหตุขอลงเวลาพิเศษ");
+
+ b.Property("FirstName")
+ .HasColumnType("longtext");
+
+ b.Property("KeycloakUserId")
+ .HasColumnType("char(36)")
+ .HasComment("รหัส User ของ Keycloak ที่ร้องขอ");
+
+ b.Property("LastName")
+ .HasColumnType("longtext");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("Latitude")
+ .HasColumnType("double");
+
+ b.Property("Longitude")
+ .HasColumnType("double");
+
+ b.Property("POI")
+ .HasColumnType("longtext");
+
+ b.Property("Prefix")
+ .HasColumnType("longtext");
+
+ b.Property("RootDnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Status")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("สถานะการอนุมัติ");
+
+ b.HasKey("Id");
+
+ b.ToTable("AdditionalCheckRequests");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.TimeAttendants.DutyTime", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("Description")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("คำอธิบาย");
+
+ b.Property("EndTimeAfternoon")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("เวลาออกงานช่วงบ่าย");
+
+ b.Property("EndTimeMorning")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("เวลาออกงานช่วงเช้า");
+
+ b.Property("IsActive")
+ .HasColumnType("tinyint(1)")
+ .HasComment("สถานะการเปิดใช้งาน (เปิด/ปิด)");
+
+ b.Property("IsDefault")
+ .HasColumnType("tinyint(1)")
+ .HasComment("สถานะว่ารอบใดเป็นค่า Default ของข้าราชการ (สำหรับทุกคนที่ยังไม่ได้ทำการเลือกรอบ)");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("StartTimeAfternoon")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("เวลาเข้างานช่วงบ่าย");
+
+ b.Property("StartTimeMorning")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("เวลาเข้างานช่วงเช้า");
+
+ b.HasKey("Id");
+
+ b.ToTable("DutyTimes");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.TimeAttendants.ProcessUserTimeStamp", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("CheckIn")
+ .HasColumnType("datetime(6)")
+ .HasComment("วัน เวลา เข้างาน");
+
+ b.Property("CheckInImageUrl")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("รูปถ่ายสถานที่ Check-In");
+
+ b.Property("CheckInLat")
+ .HasColumnType("double")
+ .HasComment("พิกัดละติจูด Check-In");
+
+ b.Property("CheckInLocationName")
+ .HasColumnType("longtext")
+ .HasComment("กรณีเลือกนอกสถานที่ตั้ง ต้องระบุข้อมูลชื่อสถานะที่ Check-In");
+
+ b.Property("CheckInLon")
+ .HasColumnType("double")
+ .HasComment("พิกัดลองจิจูด Check-In");
+
+ b.Property("CheckInPOI")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("ชื่อสถานที่ ได้มาจากระบบ ArcGis ของกองสารสนเทศภูมิศาสตร์ Check-In");
+
+ b.Property("CheckInRemark")
+ .HasColumnType("longtext")
+ .HasComment("ข้อความหมายเหตุที่ต้องการระบุเพิ่ม(มีเผื่อไว้อาจไม่ได้ใช้) Check-In");
+
+ b.Property("CheckInStatus")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("สถานะ Check-In");
+
+ b.Property("CheckOut")
+ .HasColumnType("datetime(6)")
+ .HasComment("วัน เวลา ออกงาน");
+
+ b.Property("CheckOutImageUrl")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("รูปถ่ายสถานที่ Check-Out");
+
+ b.Property("CheckOutLat")
+ .HasColumnType("double")
+ .HasComment("พิกัดละติจูด Check-Out");
+
+ b.Property("CheckOutLocationName")
+ .HasColumnType("longtext")
+ .HasComment("กรณีเลือกนอกสถานที่ตั้ง ต้องระบุข้อมูลชื่อสถานะที่ Check-Out");
+
+ b.Property("CheckOutLon")
+ .HasColumnType("double")
+ .HasComment("พิกัดลองจิจูด Check-Out");
+
+ b.Property("CheckOutPOI")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("ชื่อสถานที่ ได้มาจากระบบ ArcGis ของกองสารสนเทศภูมิศาสตร์ Check-Out");
+
+ b.Property("CheckOutRemark")
+ .HasColumnType("longtext")
+ .HasComment("ข้อความหมายเหตุที่ต้องการระบุเพิ่ม(มีเผื่อไว้อาจไม่ได้ใช้) Check-Out");
+
+ b.Property("CheckOutStatus")
+ .HasColumnType("longtext")
+ .HasComment("สถานะ Check-Out");
+
+ b.Property("Child1")
+ .HasColumnType("longtext");
+
+ b.Property("Child1DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child1Id")
+ .HasColumnType("char(36)");
+
+ b.Property("Child2")
+ .HasColumnType("longtext");
+
+ b.Property("Child2DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child2Id")
+ .HasColumnType("char(36)");
+
+ b.Property("Child3")
+ .HasColumnType("longtext");
+
+ b.Property("Child3DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child3Id")
+ .HasColumnType("char(36)");
+
+ b.Property("Child4")
+ .HasColumnType("longtext");
+
+ b.Property("Child4DnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("Child4Id")
+ .HasColumnType("char(36)");
+
+ b.Property("CitizenId")
+ .HasColumnType("longtext");
+
+ b.Property("CreatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(100)
+ .HasComment("สร้างข้อมูลเมื่อ");
+
+ b.Property("CreatedFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(104)
+ .HasComment("ชื่อ User ที่สร้างข้อมูล");
+
+ b.Property("CreatedUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(101)
+ .HasComment("User Id ที่สร้างข้อมูล");
+
+ b.Property("EditReason")
+ .HasColumnType("longtext")
+ .HasComment("เหตุผลการอนุมัติ/ไม่อนุมัติขอลงเวลาพิเศษ");
+
+ b.Property("EditStatus")
+ .HasColumnType("longtext")
+ .HasComment("สถานะการของลงเวลาพิเศษ");
+
+ b.Property("FirstName")
+ .HasColumnType("longtext");
+
+ b.Property("Gender")
+ .HasColumnType("longtext");
+
+ b.Property("IsLocationCheckIn")
+ .HasColumnType("tinyint(1)")
+ .HasComment("true คือ ณ สถานที่ตั้ง, false คือ นอกสถานที่ตั้ง Check-In");
+
+ b.Property("IsLocationCheckOut")
+ .HasColumnType("tinyint(1)")
+ .HasComment("true คือ ณ สถานที่ตั้ง, false คือ นอกสถานที่ตั้ง Check-Out");
+
+ b.Property("IsProcess")
+ .HasColumnType("tinyint(1)")
+ .HasComment("นำไปประมวลผลแล้วหรือยัง");
+
+ b.Property("KeycloakUserId")
+ .HasColumnType("char(36)")
+ .HasComment("รหัส User ของ Keycloak");
+
+ b.Property("LastName")
+ .HasColumnType("longtext");
+
+ b.Property("LastUpdateFullName")
+ .IsRequired()
+ .HasMaxLength(200)
+ .HasColumnType("varchar(200)")
+ .HasColumnOrder(105)
+ .HasComment("ชื่อ User ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdateUserId")
+ .IsRequired()
+ .HasMaxLength(40)
+ .HasColumnType("varchar(40)")
+ .HasColumnOrder(103)
+ .HasComment("User Id ที่แก้ไขข้อมูลล่าสุด");
+
+ b.Property("LastUpdatedAt")
+ .HasColumnType("datetime(6)")
+ .HasColumnOrder(102)
+ .HasComment("แก้ไขข้อมูลล่าสุดเมื่อ");
+
+ b.Property("Prefix")
+ .HasColumnType("longtext");
+
+ b.Property("ProfileId")
+ .HasColumnType("char(36)");
+
+ b.Property("ProfileType")
+ .HasColumnType("longtext");
+
+ b.Property("Root")
+ .HasColumnType("longtext");
+
+ b.Property("RootDnaId")
+ .HasColumnType("char(36)");
+
+ b.Property("RootId")
+ .HasColumnType("char(36)");
+
+ b.HasKey("Id");
+
+ b.ToTable("ProcessUserTimeStamps");
+ });
+
+ modelBuilder.Entity("BMA.EHR.Domain.Models.Leave.TimeAttendants.UserCalendar", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("char(36)")
+ .HasColumnOrder(0)
+ .HasComment("PrimaryKey")
+ .HasAnnotation("Relational:JsonPropertyName", "id");
+
+ b.Property("Calendar")
+ .IsRequired()
+ .HasColumnType("longtext")
+ .HasComment("ปฏิทินการทำงานของ ขรก ปกติ หรือ 6 วันต่อสัปดาห์");
+
+ b.Property