using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Net.Http; using System.Web.Http; using BLL; namespace WebAPI.Controllers { /// /// 考试计划记录 /// public class TestPlanController : ApiController { #region 根据projectId、states获取考试计划列表 /// /// 根据projectId、states获取考试计划列表 /// /// 项目ID /// 状态(0-待提交;1-已发布;2-考试中;3考试结束) /// 分页 /// public Model.ResponeData getTestPlanListByProjectIdStates(string projectId, string states,int pageIndex) { var responeData = new Model.ResponeData(); try { var getQualityLists = APITestPlanService.getTestPlanListByProjectIdStates(projectId, states); int pageCount = getQualityLists.Count; if (pageCount > 0 && pageIndex > 0) { var getdata = from x in getQualityLists.OrderByDescending(u => u.TestStartTime).Skip(Funs.PageSize * (pageIndex - 1)).Take(Funs.PageSize) select x; responeData.data = new { pageCount, getdata }; } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据考试计划ID获取考试详细 /// /// 根据考试计划ID获取考试详细 /// /// 考试计划ID /// public Model.ResponeData getTestPlanByTestPlanId(string testPlanId) { var responeData = new Model.ResponeData(); try { responeData.data = APITestPlanService.getTestPlanByTestPlanId(testPlanId); } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据培训计划ID生成 考试计划信息 /// /// 根据培训计划ID生成 考试计划信息 /// /// 培训计划ID /// 用户ID /// public Model.ResponeData getSaveTestPlanByTrainingPlanId(string trainingPlanId,string userId) { var responeData = new Model.ResponeData(); try { var getTasks = new Model.SGGLDB(Funs.ConnString).Training_Task.FirstOrDefault(x => x.PlanId == trainingPlanId); if (getTasks != null) { if (CommonService.IsMainUnitOrAdmin(userId)) { responeData.data = APITestPlanService.SaveTestPlanByTrainingPlanId(trainingPlanId, userId); } else { responeData.code = 0; responeData.message = "非本单位用户,不能生成考试计划!"; } } else { responeData.code = 0; responeData.message = "培训计划下没有培训人员,不能生成考试计划!"; } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 保存 TestPlan [增加、修改、开始考试、结束考试] /// /// 保存TestPlan [增加、修改、开始考试、结束考试] /// /// 考试计划项目 [HttpPost] public Model.ResponeData SaveTestPlan([FromBody] Model.TestPlanItem testPlan) { var responeData = new Model.ResponeData(); try { responeData.message = APITestPlanService.SaveTestPlan(testPlan); if (!string.IsNullOrEmpty(responeData.message)) { responeData.code = 2; } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据TestPlanId获取考试试题类型列表 /// /// 根据TestPlanId获取考试试题类型列表 /// /// 考试计划ID /// 试题类型 public Model.ResponeData getTestPlanTrainingListByTestPlanId(string testPlanId) { var responeData = new Model.ResponeData(); try { responeData.data = APITestPlanService.getTestPlanTrainingListByTestPlanId(testPlanId); } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据TestPlanId获取考试试题类型列表 /// /// 根据TestPlanId获取考试试题类型列表 /// /// 考试计划ID /// 试题类型 public Model.ResponeData getTestPlanTrainingListByTestPlanId2(string testPlanId) { var responeData = new Model.ResponeData(); try { var getDataList = APITestPlanService.getTestPlanTrainingListByTestPlanId(testPlanId); int pageCount = getDataList.Count(); responeData.data = new { pageCount, getDataList }; } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据PersonId、TestPlanId扫描考试计划二维码 /// /// 根据PersonId、TestPlanId扫描考试计划二维码 /// /// 培训考试计划ID /// 人员ID /// public Model.ResponeData getTestPlanRecordItemByTestPlanIdPersonId(string testPlanId, string personId) { var responeData = new Model.ResponeData(); try { using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) { var getTestPlan = db.Training_TestPlan.FirstOrDefault(e => e.TestPlanId == testPlanId && e.States != "3" && e.TestStartTime <= DateTime.Now && e.TestEndTime >= DateTime.Now); if (getTestPlan != null) { var person = PersonService.GetPersonByUserId(personId, getTestPlan.ProjectId); if (person != null) { //2-考试中;生成考试试卷 if (getTestPlan.States == "2") { var testRecord = db.Training_TestRecord.FirstOrDefault(x => x.TestPlanId == getTestPlan.TestPlanId && x.TestManId == person.PersonId && !x.TestEndTime.HasValue); if (testRecord != null) { string testRecordId = APITestRecordService.CreateTestRecordItem(getTestPlan, testRecord.TestRecordId, person); responeData.code = 2; responeData.data = new { testRecordId }; } } else { if (string.IsNullOrEmpty(getTestPlan.PlanId) && getTestPlan.UnitIds.Contains(person.UnitId) && (getTestPlan.WorkPostIds == null || getTestPlan.WorkPostIds.Contains(person.WorkPostId))) { //0-待提交;1-已发布未考试 将人员添加进考试记录 var testTRecord = db.Training_TestRecord.FirstOrDefault(x => x.TestPlanId == testPlanId && x.TestManId == personId); if ((getTestPlan.States == "0" || getTestPlan.States == "1") && testTRecord == null && !string.IsNullOrEmpty(personId)) { Model.Training_TestRecord newTestRecord = new Model.Training_TestRecord { TestRecordId = SQLHelper.GetNewID(), ProjectId = getTestPlan.ProjectId, TestPlanId = getTestPlan.TestPlanId, TestManId = personId, }; if (string.IsNullOrEmpty(newTestRecord.TestType)) { var getTrainTypeName = db.Training_TestPlan.FirstOrDefault(x => x.TestPlanId == newTestRecord.TestPlanId); if (getTrainTypeName != null) { newTestRecord.TestType = getTrainTypeName.PlanName; } } TestRecordService.AddTestRecord(newTestRecord); responeData.code = 3; responeData.message = "您已加入考试计划!"; } } } } } if (responeData.code == 1) { //其他状态时 查看考试计划详细页 responeData.data = APITestPlanService.getTestPlanByTestPlanId(testPlanId); } } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion } }