| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  | using System; | 
					
						
							|  |  |  |  | using System.Collections.Generic; | 
					
						
							|  |  |  |  | using System.Linq; | 
					
						
							|  |  |  |  | using System.Text; | 
					
						
							|  |  |  |  | using System.Threading.Tasks; | 
					
						
							|  |  |  |  | using EmitMapper; | 
					
						
							|  |  |  |  | using EmitMapper.MappingConfiguration; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | namespace BLL | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     public static class APITestRecordService | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         #region 根据TestPlanId获取考试试卷人员列表 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据TestPlanId获取考试人员列表 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testPlanId"></param> | 
					
						
							|  |  |  |  |         /// <returns>考试人员</returns> | 
					
						
							|  |  |  |  |         public static List<Model.TestRecordItem> getTestRecordListByTestPlanId(string testPlanId) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getDataLists = (from x in db.Training_TestRecord | 
					
						
							|  |  |  |  |                                     where x.TestPlanId == testPlanId | 
					
						
							|  |  |  |  |                                     orderby x.TestStartTime descending | 
					
						
							|  |  |  |  |                                     select new Model.TestRecordItem | 
					
						
							|  |  |  |  |                                     { | 
					
						
							|  |  |  |  |                                         TestRecordId = x.TestRecordId, | 
					
						
							|  |  |  |  |                                         ProjectId = x.ProjectId, | 
					
						
							|  |  |  |  |                                         TestPlanId = x.TestPlanId, | 
					
						
							|  |  |  |  |                                         TestManId = x.TestManId, | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |                                         TestManName = db.SitePerson_Person.FirstOrDefault(p => p.PersonId == x.TestManId).PersonName, | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |                                         TestStartTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestStartTime), | 
					
						
							|  |  |  |  |                                         TestEndTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestEndTime), | 
					
						
							|  |  |  |  |                                         TestScores = x.TestScores ?? 0, | 
					
						
							|  |  |  |  |                                         TestType = x.TestType, | 
					
						
							|  |  |  |  |                                         TemporaryUser = x.TemporaryUser, | 
					
						
							|  |  |  |  |                                     }).ToList(); | 
					
						
							|  |  |  |  |                 return getDataLists; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         #region 根据试卷ID获取试卷记录详细 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据试卷ID获取试卷记录详细 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testRecordId"></param> | 
					
						
							|  |  |  |  |         /// <returns></returns> | 
					
						
							|  |  |  |  |         public static Model.TestRecordItem getTestRecordByTestRecordId(string testRecordId) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getDataLists = from x in db.Training_TestRecord | 
					
						
							|  |  |  |  |                                    join y in db.Training_TestPlan on x.TestPlanId equals y.TestPlanId | 
					
						
							|  |  |  |  |                                    where x.TestRecordId == testRecordId | 
					
						
							|  |  |  |  |                                    select new Model.TestRecordItem | 
					
						
							|  |  |  |  |                                    { | 
					
						
							|  |  |  |  |                                        TestRecordId = x.TestRecordId, | 
					
						
							|  |  |  |  |                                        ProjectId = x.ProjectId, | 
					
						
							|  |  |  |  |                                        TestPlanId = x.TestPlanId, | 
					
						
							|  |  |  |  |                                        TestPlanName = y.PlanName, | 
					
						
							|  |  |  |  |                                        TestManId = x.TestManId, | 
					
						
							|  |  |  |  |                                        TestManName = db.SitePerson_Person.First(u => u.PersonId == x.TestManId).PersonName, | 
					
						
							|  |  |  |  |                                        TestStartTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestStartTime), | 
					
						
							|  |  |  |  |                                        TestEndTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestEndTime), | 
					
						
							|  |  |  |  |                                        TestPlanEndTime = x.TestStartTime.HasValue ? string.Format("{0:yyyy-MM-dd HH:mm}", x.TestStartTime.Value.AddMinutes(x.Duration)) : "", | 
					
						
							|  |  |  |  |                                        Duration = y.Duration, | 
					
						
							|  |  |  |  |                                        TestScores = x.TestScores ?? 0, | 
					
						
							|  |  |  |  |                                        TestType = x.TestType, | 
					
						
							|  |  |  |  |                                        TemporaryUser = x.TemporaryUser, | 
					
						
							|  |  |  |  |                                    }; | 
					
						
							|  |  |  |  |                 return getDataLists.FirstOrDefault(); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-06 17:51:11 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         public static string CreateTestRecordItem(Model.Training_CompanyTrainingItem getCompanyTraining, string testRecordId, Model.SitePerson_Person person, Model.Sys_User user) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2025-03-06 17:51:11 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var trainingIds = getCompanyTraining.TestTrainingIds.Split(','); | 
					
						
							|  |  |  |  |                 var testTrainings = db.Training_TestTraining.Where(x => trainingIds.Contains(x.TrainingId)); | 
					
						
							|  |  |  |  |                 var getTestRecord = db.Training_TestRecord.FirstOrDefault(x => x.TestRecordId == testRecordId); | 
					
						
							|  |  |  |  |                 if (getTestRecord != null && !getTestRecord.TestStartTime.HasValue) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     ////考试时长 | 
					
						
							|  |  |  |  |                     getTestRecord.Duration = 120; | 
					
						
							|  |  |  |  |                     getTestRecord.TestStartTime = DateTime.Now; | 
					
						
							|  |  |  |  |                     db.SubmitChanges(); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 ////当前人考试记录  未加入考试计划的 当考试开始扫码时 不允许再参与考试           | 
					
						
							|  |  |  |  |                 var item = db.Training_TestRecordItem.FirstOrDefault(x => x.TestRecordId == getTestRecord.TestRecordId); | 
					
						
							|  |  |  |  |                 if (item == null) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     List<Model.Training_TestTrainingItem> getTestTrainingItemList = new List<Model.Training_TestTrainingItem>(); | 
					
						
							|  |  |  |  |                     //var testPlanTrainings = from x in db.Training_TestPlanTraining | 
					
						
							|  |  |  |  |                     //                        where x.TestPlanId == getTestPlan.TestPlanId | 
					
						
							|  |  |  |  |                     //                        select x; | 
					
						
							|  |  |  |  |                     //// 计划考试中单选、多选、判断题总数 | 
					
						
							|  |  |  |  |                     var sysTestRule = Funs.DB.Sys_TestRule.FirstOrDefault(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     int sumTestType1Count = 0;// testPlanTrainings.Sum(x => x.TestType1Count) ?? 0; | 
					
						
							|  |  |  |  |                     int sumTestType2Count = 0;//testPlanTrainings.Sum(x => x.TestType2Count) ?? 0; | 
					
						
							|  |  |  |  |                     int sumTestType3Count = 0;//testPlanTrainings.Sum(x => x.TestType3Count) ?? 0; | 
					
						
							|  |  |  |  |                     if (sysTestRule != null) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                         sumTestType1Count = sysTestRule.SCount; | 
					
						
							|  |  |  |  |                         sumTestType2Count = sysTestRule.MCount; | 
					
						
							|  |  |  |  |                         sumTestType3Count = sysTestRule.JCount; | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     ////获取类型下适合岗位试题集合 | 
					
						
							|  |  |  |  |                     List<Model.Training_TestTrainingItem> getTestTrainingItemALLs; | 
					
						
							|  |  |  |  |                     string WorkPostId = ""; | 
					
						
							|  |  |  |  |                     string DepartId = ""; | 
					
						
							|  |  |  |  |                     if (person != null) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         WorkPostId = person.WorkPostId; | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     if (user != null) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         DepartId = user.DepartId; | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     getTestTrainingItemALLs = (from x in db.Training_TestTrainingItem | 
					
						
							|  |  |  |  |                                                where x.TrainingId != null && (x.WorkPostIds == null || string.IsNullOrEmpty(WorkPostId) || x.WorkPostIds.Contains(WorkPostId)) || (x.DepartIds == null || string.IsNullOrEmpty(DepartId) || x.DepartIds.Contains(DepartId)) | 
					
						
							|  |  |  |  |                                                select x).ToList(); | 
					
						
							|  |  |  |  |                     foreach (var itemT in testTrainings) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         //// 获取类型下的题目 | 
					
						
							|  |  |  |  |                         var getTestTrainingItems = getTestTrainingItemALLs.Where(x => x.TrainingId == itemT.TrainingId).ToList(); | 
					
						
							|  |  |  |  |                         if (getTestTrainingItems.Count() > 0) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             ////单选题 | 
					
						
							|  |  |  |  |                             var getSItem = getTestTrainingItems.Where(x => x.TestType == "1").OrderBy(x => Guid.NewGuid()).Take(sumTestType1Count); | 
					
						
							|  |  |  |  |                             if (getSItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getSItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///多选题 | 
					
						
							|  |  |  |  |                             var getMItem = getTestTrainingItems.Where(x => x.TestType == "2").OrderBy(x => Guid.NewGuid()).Take(sumTestType2Count); | 
					
						
							|  |  |  |  |                             if (getMItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getMItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///判断题 | 
					
						
							|  |  |  |  |                             var getJItem = getTestTrainingItems.Where(x => x.TestType == "3").OrderBy(x => Guid.NewGuid()).Take(sumTestType3Count); | 
					
						
							|  |  |  |  |                             if (getJItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getJItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     //// 获取得到的单选题、多选题、判断题 数量 | 
					
						
							|  |  |  |  |                     int getDiffTestType1Count = sumTestType1Count - getTestTrainingItemList.Where(x => x.TestType == "1").Count(); | 
					
						
							|  |  |  |  |                     int getDiffTestType2Count = sumTestType2Count - getTestTrainingItemList.Where(x => x.TestType == "2").Count(); | 
					
						
							|  |  |  |  |                     int getDiffTestType3Count = sumTestType3Count - getTestTrainingItemList.Where(x => x.TestType == "3").Count(); | 
					
						
							|  |  |  |  |                     if (getDiffTestType1Count > 0 || getDiffTestType2Count > 0 || getDiffTestType3Count > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         var getTestTrainingItemNulls = getTestTrainingItemALLs.Where(x => x.WorkPostIds == null).ToList(); | 
					
						
							|  |  |  |  |                         if (getTestTrainingItemNulls.Count() > 0) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             /// 通用且未选择的题目 | 
					
						
							|  |  |  |  |                             var getTestTrainingItemDiffs = getTestTrainingItemNulls.Except(getTestTrainingItemList).ToList(); | 
					
						
							|  |  |  |  |                             ////单选题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType1Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getSItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "1").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType1Count); | 
					
						
							|  |  |  |  |                                 if (getSItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getSItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///多选题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType2Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getMItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "2").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType2Count); | 
					
						
							|  |  |  |  |                                 if (getMItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getMItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///判断题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType3Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getJItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "3").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType3Count); | 
					
						
							|  |  |  |  |                                 if (getJItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getJItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     if (getTestTrainingItemList.Count() > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         var getItems = from x in getTestTrainingItemList | 
					
						
							|  |  |  |  |                                        select new Model.Training_TestRecordItem | 
					
						
							|  |  |  |  |                                        { | 
					
						
							|  |  |  |  |                                            TestRecordItemId = SQLHelper.GetNewID(), | 
					
						
							|  |  |  |  |                                            TestRecordId = getTestRecord.TestRecordId, | 
					
						
							|  |  |  |  |                                            TrainingItemName = x.TrainingItemName, | 
					
						
							|  |  |  |  |                                            TrainingItemCode = x.TrainingItemCode, | 
					
						
							|  |  |  |  |                                            Abstracts = x.Abstracts, | 
					
						
							|  |  |  |  |                                            AttachUrl = x.AttachUrl, | 
					
						
							|  |  |  |  |                                            TestType = x.TestType, | 
					
						
							|  |  |  |  |                                            AItem = x.AItem, | 
					
						
							|  |  |  |  |                                            BItem = x.BItem, | 
					
						
							|  |  |  |  |                                            CItem = x.CItem, | 
					
						
							|  |  |  |  |                                            DItem = x.DItem, | 
					
						
							|  |  |  |  |                                            EItem = x.EItem, | 
					
						
							|  |  |  |  |                                            AnswerItems = x.AnswerItems, | 
					
						
							|  |  |  |  |                                            Score = x.TestType == "1" ? sysTestRule.SValue : (x.TestType == "2" ? sysTestRule.MValue : sysTestRule.JValue), | 
					
						
							|  |  |  |  |                                        }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                         db.Training_TestRecordItem.InsertAllOnSubmit(getItems); | 
					
						
							|  |  |  |  |                         db.SubmitChanges(); | 
					
						
							|  |  |  |  |                         BLL.RedisHelper redis = new BLL.RedisHelper(); | 
					
						
							|  |  |  |  |                         redis.SetObjString(testRecordId, getItems); | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return testRecordId; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |         #region 根据PersonId、TestPlanId生成试卷 扫码生成试卷 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据PersonId、TestPlanId生成试卷 扫码生成试卷 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testPlanId"></param> | 
					
						
							|  |  |  |  |         /// <returns></returns> | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |         public static string CreateTestRecordItem(Model.Training_TestPlan getTestPlan, string testRecordId, Model.SitePerson_Person person) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getTestRecord = db.Training_TestRecord.FirstOrDefault(x => x.TestRecordId == testRecordId); | 
					
						
							|  |  |  |  |                 if (getTestRecord != null && !getTestRecord.TestStartTime.HasValue) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     ////考试时长 | 
					
						
							|  |  |  |  |                     getTestRecord.Duration = getTestPlan.Duration; | 
					
						
							|  |  |  |  |                     getTestRecord.TestStartTime = DateTime.Now; | 
					
						
							|  |  |  |  |                     db.SubmitChanges(); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 ////当前人考试记录  未加入考试计划的 当考试开始扫码时 不允许再参与考试           | 
					
						
							|  |  |  |  |                 var item = db.Training_TestRecordItem.FirstOrDefault(x => x.TestRecordId == getTestRecord.TestRecordId); | 
					
						
							|  |  |  |  |                 if (item == null) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     List<Model.Training_TestTrainingItem> getTestTrainingItemList = new List<Model.Training_TestTrainingItem>(); | 
					
						
							|  |  |  |  |                     var testPlanTrainings = from x in db.Training_TestPlanTraining | 
					
						
							|  |  |  |  |                                             where x.TestPlanId == getTestPlan.TestPlanId | 
					
						
							|  |  |  |  |                                             select x; | 
					
						
							|  |  |  |  |                     //// 计划考试中单选、多选、判断题总数 | 
					
						
							|  |  |  |  |                     int sumTestType1Count = testPlanTrainings.Sum(x => x.TestType1Count) ?? 0; | 
					
						
							|  |  |  |  |                     int sumTestType2Count = testPlanTrainings.Sum(x => x.TestType2Count) ?? 0; | 
					
						
							|  |  |  |  |                     int sumTestType3Count = testPlanTrainings.Sum(x => x.TestType3Count) ?? 0; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     ////获取类型下适合岗位试题集合 | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |                     var getTestTrainingItemALLs = from x in db.Training_TestTrainingItem | 
					
						
							|  |  |  |  |                                                   where x.TrainingId != null && (x.WorkPostIds == null || (x.WorkPostIds.Contains(person.WorkPostId) && person.WorkPostId != null)) | 
					
						
							|  |  |  |  |                                                   select x; | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |                     foreach (var itemT in testPlanTrainings) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         //// 获取类型下的题目 | 
					
						
							|  |  |  |  |                         var getTestTrainingItems = getTestTrainingItemALLs.Where(x => x.TrainingId == itemT.TrainingId).ToList(); | 
					
						
							|  |  |  |  |                         if (getTestTrainingItems.Count() > 0) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             ////单选题 | 
					
						
							|  |  |  |  |                             var getSItem = getTestTrainingItems.Where(x => x.TestType == "1").OrderBy(x => Guid.NewGuid()).Take(itemT.TestType1Count ?? 1); | 
					
						
							|  |  |  |  |                             if (getSItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getSItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///多选题 | 
					
						
							|  |  |  |  |                             var getMItem = getTestTrainingItems.Where(x => x.TestType == "2").OrderBy(x => Guid.NewGuid()).Take(itemT.TestType2Count ?? 1); | 
					
						
							|  |  |  |  |                             if (getMItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getMItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///判断题 | 
					
						
							|  |  |  |  |                             var getJItem = getTestTrainingItems.Where(x => x.TestType == "3").OrderBy(x => Guid.NewGuid()).Take(itemT.TestType3Count ?? 1); | 
					
						
							|  |  |  |  |                             if (getJItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getJItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     //// 获取得到的单选题、多选题、判断题 数量 | 
					
						
							|  |  |  |  |                     int getDiffTestType1Count = sumTestType1Count - getTestTrainingItemList.Where(x => x.TestType == "1").Count(); | 
					
						
							|  |  |  |  |                     int getDiffTestType2Count = sumTestType2Count - getTestTrainingItemList.Where(x => x.TestType == "2").Count(); | 
					
						
							|  |  |  |  |                     int getDiffTestType3Count = sumTestType3Count - getTestTrainingItemList.Where(x => x.TestType == "3").Count(); | 
					
						
							|  |  |  |  |                     if (getDiffTestType1Count > 0 || getDiffTestType2Count > 0 || getDiffTestType3Count > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         var getTestTrainingItemNulls = getTestTrainingItemALLs.Where(x => x.WorkPostIds == null).ToList(); | 
					
						
							|  |  |  |  |                         if (getTestTrainingItemNulls.Count() > 0) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             /// 通用且未选择的题目 | 
					
						
							|  |  |  |  |                             var getTestTrainingItemDiffs = getTestTrainingItemNulls.Except(getTestTrainingItemList).ToList(); | 
					
						
							|  |  |  |  |                             ////单选题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType1Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getSItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "1").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType1Count); | 
					
						
							|  |  |  |  |                                 if (getSItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getSItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///多选题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType2Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getMItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "2").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType2Count); | 
					
						
							|  |  |  |  |                                 if (getMItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getMItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///判断题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType3Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getJItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "3").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType3Count); | 
					
						
							|  |  |  |  |                                 if (getJItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getJItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     if (getTestTrainingItemList.Count() > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         var getItems = from x in getTestTrainingItemList | 
					
						
							|  |  |  |  |                                        select new Model.Training_TestRecordItem | 
					
						
							|  |  |  |  |                                        { | 
					
						
							|  |  |  |  |                                            TestRecordItemId = SQLHelper.GetNewID(), | 
					
						
							|  |  |  |  |                                            TestRecordId = getTestRecord.TestRecordId, | 
					
						
							|  |  |  |  |                                            TrainingItemName = x.TrainingItemName, | 
					
						
							|  |  |  |  |                                            TrainingItemCode = x.TrainingItemCode, | 
					
						
							|  |  |  |  |                                            Abstracts = x.Abstracts, | 
					
						
							|  |  |  |  |                                            AttachUrl = x.AttachUrl, | 
					
						
							|  |  |  |  |                                            TestType = x.TestType, | 
					
						
							|  |  |  |  |                                            AItem = x.AItem, | 
					
						
							|  |  |  |  |                                            BItem = x.BItem, | 
					
						
							|  |  |  |  |                                            CItem = x.CItem, | 
					
						
							|  |  |  |  |                                            DItem = x.DItem, | 
					
						
							|  |  |  |  |                                            EItem = x.EItem, | 
					
						
							|  |  |  |  |                                            AnswerItems = x.AnswerItems, | 
					
						
							|  |  |  |  |                                            Score = x.TestType == "1" ? getTestPlan.SValue : (x.TestType == "2" ? getTestPlan.MValue : getTestPlan.JValue), | 
					
						
							|  |  |  |  |                                        }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                         db.Training_TestRecordItem.InsertAllOnSubmit(getItems); | 
					
						
							|  |  |  |  |                         db.SubmitChanges(); | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return testRecordId; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  |         #region 根据PersonId、TestPlanId生成试卷 扫码生成试卷 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据PersonId、TestPlanId生成试卷 扫码生成试卷 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testPlanId"></param> | 
					
						
							|  |  |  |  |         /// <returns></returns> | 
					
						
							|  |  |  |  |         public static string CreateFixTestRecordItem(Model.Training_TestPlan getTestPlan, string testRecordId, Model.SitePerson_Person person) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getTestRecord = db.Training_TestRecord.FirstOrDefault(x => x.TestRecordId == testRecordId); | 
					
						
							|  |  |  |  |                 if (getTestRecord != null && !getTestRecord.TestStartTime.HasValue) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     ////考试时长 | 
					
						
							|  |  |  |  |                     getTestRecord.Duration = getTestPlan.Duration; | 
					
						
							|  |  |  |  |                     getTestRecord.TestStartTime = DateTime.Now; | 
					
						
							|  |  |  |  |                     db.SubmitChanges(); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 ////当前人考试记录  未加入考试计划的 当考试开始扫码时 不允许再参与考试           | 
					
						
							|  |  |  |  |                 var item = db.Training_TestRecordItem.FirstOrDefault(x => x.TestRecordId == getTestRecord.TestRecordId); | 
					
						
							|  |  |  |  |                 if (item == null) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     List<Model.Training_TestTrainingItem> getTestTrainingItemList = new List<Model.Training_TestTrainingItem>(); | 
					
						
							|  |  |  |  |                     var testPlanTrainings = from x in db.Training_TestPlanTraining | 
					
						
							|  |  |  |  |                                             where x.TestPlanId == getTestPlan.TestPlanId | 
					
						
							|  |  |  |  |                                             select x; | 
					
						
							|  |  |  |  |                     //// 计划考试中单选、多选、判断题总数 | 
					
						
							|  |  |  |  |                     int sumTestType1Count = testPlanTrainings.Sum(x => x.TestType1Count) ?? 0; | 
					
						
							|  |  |  |  |                     int sumTestType2Count = testPlanTrainings.Sum(x => x.TestType2Count) ?? 0; | 
					
						
							|  |  |  |  |                     int sumTestType3Count = testPlanTrainings.Sum(x => x.TestType3Count) ?? 0; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     ////获取类型下适合岗位试题集合 | 
					
						
							|  |  |  |  |                     var getTestTrainingItemALLs = from x in db.Training_TestTrainingItem | 
					
						
							|  |  |  |  |                                                   where x.TrainingId != null && (x.WorkPostIds == null || (x.WorkPostIds.Contains(person.WorkPostId) && person.WorkPostId != null)) | 
					
						
							|  |  |  |  |                                                   select x; | 
					
						
							|  |  |  |  |                     foreach (var itemT in testPlanTrainings) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         //// 获取类型下的题目 | 
					
						
							|  |  |  |  |                         var getTestTrainingItems = getTestTrainingItemALLs.Where(x => x.TrainingId == itemT.TrainingId).ToList(); | 
					
						
							|  |  |  |  |                         if (getTestTrainingItems.Count() > 0) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             ////单选题 | 
					
						
							|  |  |  |  |                             var getSItem = getTestTrainingItems.Where(x => x.TestType == "1").OrderBy(x => Guid.NewGuid()).Take(itemT.TestType1Count ?? 1); | 
					
						
							|  |  |  |  |                             if (getSItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getSItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///多选题 | 
					
						
							|  |  |  |  |                             var getMItem = getTestTrainingItems.Where(x => x.TestType == "2").OrderBy(x => Guid.NewGuid()).Take(itemT.TestType2Count ?? 1); | 
					
						
							|  |  |  |  |                             if (getMItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getMItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///判断题 | 
					
						
							|  |  |  |  |                             var getJItem = getTestTrainingItems.Where(x => x.TestType == "3").OrderBy(x => Guid.NewGuid()).Take(itemT.TestType3Count ?? 1); | 
					
						
							|  |  |  |  |                             if (getJItem.Count() > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 getTestTrainingItemList.AddRange(getJItem); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     //// 获取得到的单选题、多选题、判断题 数量 | 
					
						
							|  |  |  |  |                     int getDiffTestType1Count = sumTestType1Count - getTestTrainingItemList.Where(x => x.TestType == "1").Count(); | 
					
						
							|  |  |  |  |                     int getDiffTestType2Count = sumTestType2Count - getTestTrainingItemList.Where(x => x.TestType == "2").Count(); | 
					
						
							|  |  |  |  |                     int getDiffTestType3Count = sumTestType3Count - getTestTrainingItemList.Where(x => x.TestType == "3").Count(); | 
					
						
							|  |  |  |  |                     if (getDiffTestType1Count > 0 || getDiffTestType2Count > 0 || getDiffTestType3Count > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         var getTestTrainingItemNulls = getTestTrainingItemALLs.Where(x => x.WorkPostIds == null).ToList(); | 
					
						
							|  |  |  |  |                         if (getTestTrainingItemNulls.Count() > 0) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             /// 通用且未选择的题目 | 
					
						
							|  |  |  |  |                             var getTestTrainingItemDiffs = getTestTrainingItemNulls.Except(getTestTrainingItemList).ToList(); | 
					
						
							|  |  |  |  |                             ////单选题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType1Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getSItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "1").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType1Count); | 
					
						
							|  |  |  |  |                                 if (getSItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getSItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///多选题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType2Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getMItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "2").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType2Count); | 
					
						
							|  |  |  |  |                                 if (getMItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getMItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                             ///判断题 | 
					
						
							|  |  |  |  |                             if (getDiffTestType3Count > 0) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getJItemD = getTestTrainingItemDiffs.Where(x => x.TestType == "3").OrderBy(x => Guid.NewGuid()).Take(getDiffTestType3Count); | 
					
						
							|  |  |  |  |                                 if (getJItemD.Count() > 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     getTestTrainingItemList.AddRange(getJItemD); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     if (getTestTrainingItemList.Count() > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         var getItems = from x in getTestTrainingItemList | 
					
						
							|  |  |  |  |                                        select new Model.Training_TestRecordItem | 
					
						
							|  |  |  |  |                                        { | 
					
						
							|  |  |  |  |                                            TestRecordItemId = SQLHelper.GetNewID(), | 
					
						
							|  |  |  |  |                                            TestRecordId = getTestRecord.TestRecordId, | 
					
						
							|  |  |  |  |                                            TrainingItemName = x.TrainingItemName, | 
					
						
							|  |  |  |  |                                            TrainingItemCode = x.TrainingItemCode, | 
					
						
							|  |  |  |  |                                            Abstracts = x.Abstracts, | 
					
						
							|  |  |  |  |                                            AttachUrl = x.AttachUrl, | 
					
						
							|  |  |  |  |                                            TestType = x.TestType, | 
					
						
							|  |  |  |  |                                            AItem = x.AItem, | 
					
						
							|  |  |  |  |                                            BItem = x.BItem, | 
					
						
							|  |  |  |  |                                            CItem = x.CItem, | 
					
						
							|  |  |  |  |                                            DItem = x.DItem, | 
					
						
							|  |  |  |  |                                            EItem = x.EItem, | 
					
						
							|  |  |  |  |                                            AnswerItems = x.AnswerItems, | 
					
						
							|  |  |  |  |                                            Score = x.TestType == "1" ? getTestPlan.SValue : (x.TestType == "2" ? getTestPlan.MValue : getTestPlan.JValue), | 
					
						
							|  |  |  |  |                                        }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                         db.Training_TestRecordItem.InsertAllOnSubmit(getItems); | 
					
						
							|  |  |  |  |                         db.SubmitChanges(); | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return testRecordId; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  |         #region 根据ProjectId、PersonId获取试卷列表 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据ProjectId、PersonId获取试卷列表 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="projectId">项目ID</param> | 
					
						
							|  |  |  |  |         /// <param name="personId">人员ID(null查全部)</param> | 
					
						
							|  |  |  |  |         /// <returns>考试记录列表</returns> | 
					
						
							|  |  |  |  |         public static List<Model.TestRecordItem> getTrainingTestRecordListByProjectIdPersonId(string projectId, string personId) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getDataLists = (from x in db.Training_TestRecord | 
					
						
							|  |  |  |  |                                     join y in db.Training_TestPlan on x.TestPlanId equals y.TestPlanId | 
					
						
							|  |  |  |  |                                     where x.ProjectId == projectId && x.TestManId == personId && x.TestStartTime.HasValue | 
					
						
							|  |  |  |  |                                     orderby x.TestStartTime descending | 
					
						
							|  |  |  |  |                                     select new Model.TestRecordItem | 
					
						
							|  |  |  |  |                                     { | 
					
						
							|  |  |  |  |                                         TestRecordId = x.TestRecordId, | 
					
						
							|  |  |  |  |                                         ProjectId = x.ProjectId, | 
					
						
							|  |  |  |  |                                         TestPlanId = x.TestPlanId, | 
					
						
							|  |  |  |  |                                         TestPlanName = y.PlanName, | 
					
						
							|  |  |  |  |                                         TestManId = x.TestManId, | 
					
						
							|  |  |  |  |                                         TestManName = db.SitePerson_Person.FirstOrDefault(p => p.PersonId == x.TestManId).PersonName, | 
					
						
							|  |  |  |  |                                         TestStartTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestStartTime), | 
					
						
							|  |  |  |  |                                         TestEndTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestEndTime), | 
					
						
							|  |  |  |  |                                         Duration = x.Duration, | 
					
						
							|  |  |  |  |                                         TestPlanEndTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestStartTime.Value.AddMinutes(x.Duration)), | 
					
						
							|  |  |  |  |                                         TotalScore = y.TotalScore ?? 0, | 
					
						
							|  |  |  |  |                                         TestScores = x.TestScores ?? 0, | 
					
						
							|  |  |  |  |                                         TestType = x.TestType, | 
					
						
							|  |  |  |  |                                         TemporaryUser = x.TemporaryUser, | 
					
						
							|  |  |  |  |                                     }).ToList(); | 
					
						
							|  |  |  |  |                 return getDataLists; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         #region 根据ProjectId、PersonId获取试卷列表 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据ProjectId、PersonId获取试卷列表 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="projectId">项目ID</param> | 
					
						
							|  |  |  |  |         /// <returns>考试记录列表</returns> | 
					
						
							|  |  |  |  |         public static List<Model.TestRecordItem> getTrainingTestRecordListByProjectId(string projectId, string unitId, string workPostId, string strPass, string strParam) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getDataLists = (from x in db.Training_TestRecord | 
					
						
							|  |  |  |  |                                     join y in db.Training_TestPlan on x.TestPlanId equals y.TestPlanId | 
					
						
							|  |  |  |  |                                     join z in db.SitePerson_Person on x.TestManId equals z.PersonId | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |                                     where x.ProjectId == projectId && x.TestStartTime.HasValue && x.TestEndTime.HasValue | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |                                     orderby x.TestStartTime descending | 
					
						
							|  |  |  |  |                                     select new Model.TestRecordItem | 
					
						
							|  |  |  |  |                                     { | 
					
						
							|  |  |  |  |                                         TestRecordId = x.TestRecordId, | 
					
						
							|  |  |  |  |                                         ProjectId = x.ProjectId, | 
					
						
							|  |  |  |  |                                         TestPlanId = x.TestPlanId, | 
					
						
							|  |  |  |  |                                         TestPlanName = y.PlanName, | 
					
						
							|  |  |  |  |                                         UnitId = z.UnitId, | 
					
						
							|  |  |  |  |                                         UnitName = getUnitName(z.UnitId), | 
					
						
							|  |  |  |  |                                         WorkPostId = z.WorkPostId, | 
					
						
							|  |  |  |  |                                         WorkPostName = db.Base_WorkPost.First(p => p.WorkPostId == z.WorkPostId).WorkPostName, | 
					
						
							|  |  |  |  |                                         TestManId = x.TestManId, | 
					
						
							|  |  |  |  |                                         TestManName = db.SitePerson_Person.FirstOrDefault(p => p.PersonId == x.TestManId).PersonName, | 
					
						
							|  |  |  |  |                                         TestStartTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestStartTime), | 
					
						
							|  |  |  |  |                                         TestEndTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestEndTime), | 
					
						
							|  |  |  |  |                                         Duration = x.Duration, | 
					
						
							|  |  |  |  |                                         TestPlanEndTime = string.Format("{0:yyyy-MM-dd HH:mm}", x.TestStartTime.Value.AddMinutes(x.Duration)), | 
					
						
							|  |  |  |  |                                         TotalScore = y.TotalScore ?? 0, | 
					
						
							|  |  |  |  |                                         TestScores = x.TestScores ?? 0, | 
					
						
							|  |  |  |  |                                         TestType = x.TestType, | 
					
						
							|  |  |  |  |                                         TemporaryUser = x.TemporaryUser, | 
					
						
							|  |  |  |  |                                     }); | 
					
						
							|  |  |  |  |                 if (!string.IsNullOrEmpty(unitId)) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     getDataLists = getDataLists.Where(x => x.UnitId == unitId); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 if (!string.IsNullOrEmpty(workPostId)) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     getDataLists = getDataLists.Where(x => x.WorkPostId == workPostId); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 if (!string.IsNullOrEmpty(strParam)) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     getDataLists = getDataLists.Where(x => x.TestManName.Contains(strParam)); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 if (!string.IsNullOrEmpty(strPass)) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     int PassingScore = SysConstSetService.getPassScore(); | 
					
						
							|  |  |  |  |                     if (strPass == "0") | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         getDataLists = getDataLists.Where(x => x.TestScores < PassingScore); | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     else | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         getDataLists = getDataLists.Where(x => x.TestScores >= PassingScore); | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 return getDataLists.ToList(); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         ///  | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testManId"></param> | 
					
						
							|  |  |  |  |         /// <returns></returns> | 
					
						
							|  |  |  |  |         public static string getUnitName(string testManId) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 string name = string.Empty; | 
					
						
							|  |  |  |  |                 var getPerson = db.SitePerson_Person.FirstOrDefault(x => x.PersonId == testManId); | 
					
						
							|  |  |  |  |                 if (getPerson != null) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     name = UnitService.GetUnitNameByUnitId(getPerson.UnitId); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 return name; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         #region 根据TestRecordId获取试卷题目列表 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据TestRecordId获取试卷题目列表 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testPlanId"></param> | 
					
						
							|  |  |  |  |         /// <returns>考试人员</returns> | 
					
						
							|  |  |  |  |         public static List<Model.TestRecordItemItem> geTestRecordItemListByTestRecordId(string testRecordId) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getDataLists = (from x in db.Training_TestRecordItem | 
					
						
							|  |  |  |  |                                     where x.TestRecordId == testRecordId | 
					
						
							|  |  |  |  |                                     orderby x.TestType, x.TrainingItemCode | 
					
						
							|  |  |  |  |                                     select new Model.TestRecordItemItem | 
					
						
							|  |  |  |  |                                     { | 
					
						
							|  |  |  |  |                                         TestRecordItemId = x.TestRecordItemId, | 
					
						
							|  |  |  |  |                                         TestRecordId = x.TestRecordId, | 
					
						
							|  |  |  |  |                                         TrainingItemCode = x.TrainingItemCode, | 
					
						
							|  |  |  |  |                                         TrainingItemName = x.TrainingItemName, | 
					
						
							|  |  |  |  |                                         Abstracts = x.Abstracts, | 
					
						
							|  |  |  |  |                                         AttachUrl = x.AttachUrl.Replace("\\", "/") ?? "", | 
					
						
							|  |  |  |  |                                         TestType = x.TestType, | 
					
						
							|  |  |  |  |                                         TestTypeName = x.TestType == "1" ? "单选题" : (x.TestType == "2" ? "多选题" : "判断题"), | 
					
						
							|  |  |  |  |                                         AItem = x.AItem ?? "", | 
					
						
							|  |  |  |  |                                         BItem = x.BItem ?? "", | 
					
						
							|  |  |  |  |                                         CItem = x.CItem ?? "", | 
					
						
							|  |  |  |  |                                         DItem = x.DItem ?? "", | 
					
						
							|  |  |  |  |                                         EItem = x.EItem ?? "", | 
					
						
							|  |  |  |  |                                         AnswerItems = x.AnswerItems ?? "", | 
					
						
							|  |  |  |  |                                         Score = x.Score ?? 0, | 
					
						
							|  |  |  |  |                                         SubjectScore = x.SubjectScore ?? 0, | 
					
						
							|  |  |  |  |                                         SelectedItem = x.SelectedItem ?? "", | 
					
						
							|  |  |  |  |                                     }).ToList(); | 
					
						
							|  |  |  |  |                 return getDataLists; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         #region 根据TestRecordItemId获取试卷题目详细 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据TestRecordItemId获取试卷题目详细 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testRecordItemId"></param> | 
					
						
							|  |  |  |  |         /// <returns>考试人员</returns> | 
					
						
							|  |  |  |  |         public static Model.TestRecordItemItem geTestRecordItemByTestRecordItemId(string testRecordItemId) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getDataLists = from x in db.Training_TestRecordItem | 
					
						
							|  |  |  |  |                                    where x.TestRecordItemId == testRecordItemId | 
					
						
							|  |  |  |  |                                    select new Model.TestRecordItemItem | 
					
						
							|  |  |  |  |                                    { | 
					
						
							|  |  |  |  |                                        TestRecordItemId = x.TestRecordItemId, | 
					
						
							|  |  |  |  |                                        TestRecordId = x.TestRecordId, | 
					
						
							|  |  |  |  |                                        TrainingItemCode = x.TrainingItemCode, | 
					
						
							|  |  |  |  |                                        TrainingItemName = x.TrainingItemName, | 
					
						
							|  |  |  |  |                                        Abstracts = x.Abstracts, | 
					
						
							|  |  |  |  |                                        AttachUrl = x.AttachUrl.Replace("\\", "/") ?? "", | 
					
						
							|  |  |  |  |                                        TestType = x.TestType, | 
					
						
							|  |  |  |  |                                        TestTypeName = x.TestType == "1" ? "单选题" : (x.TestType == "2" ? "多选题" : "判断题"), | 
					
						
							|  |  |  |  |                                        AItem = x.AItem ?? "", | 
					
						
							|  |  |  |  |                                        BItem = x.BItem ?? "", | 
					
						
							|  |  |  |  |                                        CItem = x.CItem ?? "", | 
					
						
							|  |  |  |  |                                        DItem = x.DItem ?? "", | 
					
						
							|  |  |  |  |                                        EItem = x.EItem ?? "", | 
					
						
							|  |  |  |  |                                        AnswerItems = x.AnswerItems ?? "", | 
					
						
							|  |  |  |  |                                        Score = x.Score ?? 0, | 
					
						
							|  |  |  |  |                                        SubjectScore = x.SubjectScore ?? 0, | 
					
						
							|  |  |  |  |                                        SelectedItem = x.SelectedItem ?? "", | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                                    }; | 
					
						
							|  |  |  |  |                 return getDataLists.FirstOrDefault(); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         #region 根据TestRecordItemId、AnswerItems 考生答题 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据TestRecordItemId、AnswerItems 考生答题 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testRecordItemId"></param> | 
					
						
							|  |  |  |  |         /// <param name="answerItems"></param> | 
					
						
							|  |  |  |  |         public static void getTestRecordItemAnswerBySelectedItem(Model.Training_TestRecordItem getTItemT, string selectedItem) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getTItem = db.Training_TestRecordItem.FirstOrDefault(x => x.TestRecordItemId == getTItemT.TestRecordItemId); | 
					
						
							|  |  |  |  |                 if (getTItem != null) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     getTItem.SubjectScore = 0; | 
					
						
							|  |  |  |  |                     getTItem.SelectedItem = selectedItem; | 
					
						
							|  |  |  |  |                     if (!string.IsNullOrEmpty(selectedItem)) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         if (getTItem.AnswerItems == selectedItem) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             getTItem.SubjectScore = getTItem.Score ?? 0; | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                         else | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             var listA = Funs.GetStrListByStr(getTItem.AnswerItems.ToUpper(), ','); | 
					
						
							|  |  |  |  |                             var listS = Funs.GetStrListByStr(selectedItem.ToUpper(), ','); | 
					
						
							|  |  |  |  |                             if (getTItem.TestType == "2" && listA.Count >= listS.Count) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 int i = 0; | 
					
						
							|  |  |  |  |                                 foreach (var item in listS) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     if (!listA.Contains(item)) | 
					
						
							|  |  |  |  |                                     { | 
					
						
							|  |  |  |  |                                         i++; | 
					
						
							|  |  |  |  |                                         break; | 
					
						
							|  |  |  |  |                                     } | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                                 if (i == 0) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     if (listA.Count == listS.Count) | 
					
						
							|  |  |  |  |                                     { | 
					
						
							|  |  |  |  |                                         getTItem.SubjectScore = getTItem.Score ?? 0; | 
					
						
							|  |  |  |  |                                     } | 
					
						
							|  |  |  |  |                                     else | 
					
						
							|  |  |  |  |                                     { | 
					
						
							|  |  |  |  |                                         getTItem.SubjectScore = Convert.ToDecimal((getTItem.Score ?? 0) * 1.0 / 2); | 
					
						
							|  |  |  |  |                                     } | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     db.SubmitChanges(); | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         #region 根据TestRecordId 提交试卷 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据TestRecordId 提交试卷 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testRecordId"></param> | 
					
						
							|  |  |  |  |         public static decimal getSubmitTestRecord(Model.Training_TestRecord testRecord) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             decimal getCode = 0; | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 var getTestRecord = db.Training_TestRecord.FirstOrDefault(e => e.TestRecordId == testRecord.TestRecordId); | 
					
						
							|  |  |  |  |                 /////试卷 | 
					
						
							|  |  |  |  |                 if (getTestRecord.TestStartTime.HasValue) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     getTestRecord.TestEndTime = DateTime.Now; | 
					
						
							|  |  |  |  |                     var getRItem = db.Training_TestRecordItem.Where(x => x.TestRecordId == getTestRecord.TestRecordId); | 
					
						
							|  |  |  |  |                     if (getRItem.Count() > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         getTestRecord.TestScores = getRItem.Sum(x => x.SubjectScore); | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                     db.SubmitChanges(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     getCode = getTestRecord.TestScores ?? 0; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return getCode; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         #endregion | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         ///  | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testPlanId"></param> | 
					
						
							|  |  |  |  |         public static void updateAll(string testPlanId) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-08-04 18:04:41 +08:00
										 |  |  |  |             using (Model.CNPCDB db = new Model.CNPCDB(Funs.ConnString)) | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 //// 获取考试计划 | 
					
						
							|  |  |  |  |                 var getTestPlan = db.Training_TestPlan.FirstOrDefault(x => x.TestPlanId == testPlanId); | 
					
						
							|  |  |  |  |                 if (getTestPlan != null) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     //// 获取参加考试 记录 | 
					
						
							|  |  |  |  |                     var getAllTestRecords = db.Training_TestRecord.Where(x => x.TestPlanId == getTestPlan.TestPlanId); | 
					
						
							|  |  |  |  |                     if (getAllTestRecords.Count() > 0) | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         /// 参加考试人数 | 
					
						
							|  |  |  |  |                         int testManCout = getAllTestRecords.Select(x => x.TestManId).Distinct().Count(); | 
					
						
							|  |  |  |  |                         //// 获取培训计划人员 | 
					
						
							|  |  |  |  |                         var getAllTrainingTasks = db.Training_Task.Where(x => x.PlanId == getTestPlan.PlanId); | 
					
						
							|  |  |  |  |                         //// 考试人数大于等于 培训人数 | 
					
						
							|  |  |  |  |                         if (testManCout >= getAllTrainingTasks.Count()) | 
					
						
							|  |  |  |  |                         { | 
					
						
							|  |  |  |  |                             ////所有人员 都交卷时 考试计划结束 状态置为3 | 
					
						
							|  |  |  |  |                             var getAllTestRecord = getAllTestRecords.FirstOrDefault(x => !x.TestEndTime.HasValue); | 
					
						
							|  |  |  |  |                             if (getAllTestRecord == null) | 
					
						
							|  |  |  |  |                             { | 
					
						
							|  |  |  |  |                                 var getTrainingTasks = getAllTrainingTasks.Where(x => x.States != "2" || x.States == null); | 
					
						
							|  |  |  |  |                                 foreach (var item in getTrainingTasks) | 
					
						
							|  |  |  |  |                                 { | 
					
						
							|  |  |  |  |                                     item.States = "2"; | 
					
						
							|  |  |  |  |                                     db.SubmitChanges(); | 
					
						
							|  |  |  |  |                                 } | 
					
						
							|  |  |  |  |                                 getTestPlan.States = "3"; | 
					
						
							|  |  |  |  |                                 db.SubmitChanges(); | 
					
						
							|  |  |  |  |                                 ////TODO 讲培训计划 考试记录 写入到培训记录 | 
					
						
							|  |  |  |  |                                 APITrainRecordService.InsertTrainRecord(getTestPlan); | 
					
						
							|  |  |  |  |                             } | 
					
						
							|  |  |  |  |                         } | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         #region 根据TestRecord生成一条补考记录 | 
					
						
							|  |  |  |  |         /// <summary> | 
					
						
							|  |  |  |  |         /// 根据TestRecord生成一条补考记录 | 
					
						
							|  |  |  |  |         /// </summary> | 
					
						
							|  |  |  |  |         /// <param name="testRecord"></param> | 
					
						
							|  |  |  |  |         public static string getResitTestRecord(Model.Training_TestRecord getTestRecord) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |             Model.Training_TestRecord newTestRecord = new Model.Training_TestRecord | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |             { | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |                 TestRecordId = SQLHelper.GetNewID(), | 
					
						
							|  |  |  |  |                 ProjectId = getTestRecord.ProjectId, | 
					
						
							|  |  |  |  |                 TestPlanId = getTestRecord.TestPlanId, | 
					
						
							|  |  |  |  |                 TestManId = getTestRecord.TestManId, | 
					
						
							|  |  |  |  |                 TestType = getTestRecord.TestType, | 
					
						
							|  |  |  |  |                 TemporaryUser = getTestRecord.TemporaryUser, | 
					
						
							|  |  |  |  |                 Duration = getTestRecord.Duration, | 
					
						
							|  |  |  |  |                 // TestStartTime = DateTime.Now, | 
					
						
							|  |  |  |  |             }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             Funs.DB.Training_TestRecord.InsertOnSubmit(newTestRecord); | 
					
						
							|  |  |  |  |             Funs.DB.SubmitChanges(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             var getTestPlan = Funs.DB.Training_TestPlan.FirstOrDefault(x => x.TestPlanId == newTestRecord.TestPlanId); | 
					
						
							|  |  |  |  |             var person = PersonService.GetPersonByUserId(newTestRecord.TestManId, getTestPlan.ProjectId); | 
					
						
							|  |  |  |  |             if (getTestPlan != null && person != null) | 
					
						
							| 
									
										
										
										
											2024-11-20 09:08:00 +08:00
										 |  |  |  |             { | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |                 CreateTestRecordItem(getTestPlan, newTestRecord.TestRecordId, person); | 
					
						
							| 
									
										
										
										
											2024-11-20 09:08:00 +08:00
										 |  |  |  |             } | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |             return newTestRecord.TestRecordId; | 
					
						
							| 
									
										
										
										
											2024-11-20 09:08:00 +08:00
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-02-05 17:57:14 +08:00
										 |  |  |  |         #endregion | 
					
						
							| 
									
										
										
										
											2024-11-19 09:45:27 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | } |