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
}
}