From 6e2b929cf381e2320ba6e7dec56c0371124d2b51 Mon Sep 17 00:00:00 2001
From: username@email.com <yzy2002yzy@163.com>
Date: 星期六, 27 八月 2022 15:03:00 +0800
Subject: [PATCH] 提交

---
 zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs |   69 ++++++++++++++++++++++++++++++++--
 1 files changed, 64 insertions(+), 5 deletions(-)

diff --git a/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs b/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs
index 2e3504b..bac4408 100644
--- a/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs
+++ b/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs
@@ -25,10 +25,12 @@
         private readonly IWfRunProcessService _wfRunProcessService;
         private readonly IWfHistoryService _wfHistoryService;
         private readonly IWfNeeddeelService _wfNeeddeelService;
+        private readonly IPltPageService _pltPageService;
         [CheckLogin]
         public SigninController(ILogger<SigninController> logger, IAdmSigninService signinService, ISysAttachmentService sysAttachmentService
             , IAdmAttendanceRuleService attendanceRuleService, ILiaotianService liaotianService, IWfRunProcessService wfRunProcessService
-            , IWfHistoryService wfHistoryService, IWfNeeddeelService wfNeeddeelService)
+            , IWfHistoryService wfHistoryService, IWfNeeddeelService wfNeeddeelService
+             , IPltPageService pltPageService)
         {
             _logger = logger;
             _signinService = signinService;
@@ -38,6 +40,7 @@
             _wfRunProcessService = wfRunProcessService;
             _wfHistoryService = wfHistoryService;
             _wfNeeddeelService = wfNeeddeelService;
+            _pltPageService = pltPageService;
         }
 
         #region 鑰冨嫟绛惧埌鎵撳崱
@@ -338,8 +341,37 @@
             admAsk.RecStatus = "A";
             ResultEntity resultEntity = new ResultEntity();
             resultEntity.Result = false;
-           
-                if (String.IsNullOrEmpty(admAsk.Id))
+
+            if(admAsk.Step == "鎻愪氦")
+            {
+                //璇峰亣鏃堕棿涓嶈兘閲嶅彔
+              var qingjia  =   _signinService.GetAskLeaveChongdie(curentuser.Id, admAsk.StratTime.Value, admAsk.EndTime.Value);
+                if (qingjia.Count > 0)
+                {
+                    resultEntity.Result = false;
+                    resultEntity.Message = "璇ユ椂闂存宸茬粡鏈夎鍋囷紒";
+                    return JsonConvert.SerializeObject(resultEntity);
+                }
+
+            //璇峰亣瓒呰繃涓夊ぉ锛屽繀椤绘彁鍓嶄笁澶╀互涓婅鍋囷紒
+                if (admAsk.LaveDay.Value >= 3 && admAsk.StratTime.Value.Date < DateTime.Now.Date.AddDays(3))
+                {
+                    resultEntity.Result = false;
+                    resultEntity.Message = "璇峰亣瓒呰繃涓夊ぉ锛屽繀椤绘彁鍓嶄笁澶╀互涓婅鍋囷紒";
+                    return JsonConvert.SerializeObject(resultEntity);
+                }
+
+                //璇峰亣瓒呰繃涓冨ぉ锛屽繀椤绘彁鍓嶄竷澶╀互涓婅鍋囷紒
+                if (admAsk.LaveDay.Value >= 7 && admAsk.StratTime.Value.Date < DateTime.Now.Date.AddDays(7))
+                {
+                    resultEntity.Result = false;
+                    resultEntity.Message = "璇峰亣瓒呰繃涓冨ぉ锛屽繀椤绘彁鍓嶄竷澶╀互涓婅鍋囷紒";
+                    return JsonConvert.SerializeObject(resultEntity);
+                }
+            }
+            
+
+            if (String.IsNullOrEmpty(admAsk.Id))
                 {
                     admAsk.Creater = curentuser.Id;
                     admAsk.Createtime = DateTime.Now;
@@ -910,8 +942,8 @@
             var curentuser = JsonConvert.DeserializeObject<PltUser>(HttpContext.Session.GetString("User"));
             ViewData["curentuser"] = curentuser;
             leaveOff.RecStatus = "A";
-            //鏈寕瀹℃壒娴侊紝鎻愪氦鐩存帴閫氳繃
-            leaveOff.ShenpiStatus = "A";
+            ////鏈寕瀹℃壒娴侊紝鎻愪氦鐩存帴閫氳繃
+            //leaveOff.ShenpiStatus = "A";
             if (String.IsNullOrEmpty(leaveOff.Id))
             {
                 leaveOff.Creater = curentuser.Id;
@@ -921,6 +953,27 @@
             leaveOff.Modifytime = DateTime.Now;
             ResultEntity resultEntity = new ResultEntity();
             resultEntity.Result = false;
+
+            if (leaveOff.Step == "鎻愪氦")
+            {
+                //璇峰亣鏃堕棿涓嶈兘閲嶅彔
+                var qingjia = _signinService.GetAskLeaveOffChongdie(curentuser.Id, leaveOff.StratTime.Value, leaveOff.EndTime.Value);
+                if (qingjia.Count > 0)
+                {
+                    resultEntity.Result = false;
+                    resultEntity.Message = "璇ユ椂闂存宸茬粡鏈夐攢鍋囷紒";
+                    return JsonConvert.SerializeObject(resultEntity);
+                }
+
+                //閿�鍋囧繀椤讳笁澶╀互鍐�
+                if (leaveOff.StratTime.Value.Date < DateTime.Now.Date.AddDays(-3))
+                {
+                    resultEntity.Result = false;
+                    resultEntity.Message = "璇峰湪72灏忔椂鍐呰繘琛岄攢鍋囧鐞嗭紝瓒呰繃72灏忔椂鏃犳硶鎻愪氦";
+                    return JsonConvert.SerializeObject(resultEntity);
+                }
+            }
+
             using (TransactionScope scope = new TransactionScope())
             {
                 if (leaveOff.Step == "鎻愪氦")
@@ -980,6 +1033,12 @@
         #region 鑰冨嫟瑙勫垯
         public IActionResult AttendanceRule()
         {
+            var curentuser = JsonConvert.DeserializeObject<PltUser>(HttpContext.Session.GetString("User"));
+            ViewData["curentuser"] = curentuser;
+            var pageEntities = _pltPageService.GetUserPage(curentuser.Id, "/Signin/AttendanceRule/");
+            var pageEntities2 = pageEntities.Where(x => x.PageMethod == "02").ToList();
+            ViewData["ActionInfo2"] = pageEntities2;
+
             AdmAttendanceRuleDTO admAttendanceRuleDTO =  _attendanceRuleService.Get("");
             admAttendanceRuleDTO.admAttendanceRulesDtlDTOs = _attendanceRuleService.GetDtlList("");
 

--
Gitblit v1.9.1