using DOAN.Model.BZFM.Dto; using DOAN.Model.MES.base_; using DOAN.Model.MES.product; using DOAN.Repository; using DOAN.Service.MES.product.IService; using Infrastructure.Attribute; namespace DOAN.Service.MES.product; /// /// 报工Service业务层处理 /// [AppService(ServiceType = typeof(IProReportworkService), ServiceLifetime = LifeTime.Transient)] public class ProReportworkService : BaseService, IProReportworkService { public List GetRoute() { return Context.Queryable().ToList(); } /// /// 查询全部工序 /// /// public List GetBaseWorkProcesses() { return Context.Queryable().ToList(); } public List GetProcessByRoute(int route_id) { return Context .Queryable() .LeftJoin((rel, pro) => rel.FkWorkProcesses == pro.Id) .Where((rel, pro) => rel.FkWorkRoute == route_id) .Select((rel, pro) => pro) .ToList(); } /// /// 查询报工列表 /// /// /// public PagedInfo GetList(ProReportworkQueryDto parm) { var predicate = QueryExp(parm); var query = Queryable().Where(predicate.ToExpression()); var response = Context .Queryable(query) .LeftJoin((q, w) => q.ProcessId == w.Id) .LeftJoin((q, w, wo) => q.Workorder == wo.Workorder) .OrderBy((q, w, wo) => new { q.Workorder, w.Id }) .Select( (q, w, wo) => new ProReportworkDto { PlanNum = wo.PlanNum, ProcessName = w.Name, FeedOrder = wo.FeedOrder, ProductionName = wo.productionName, ProductionCode = wo.productionCode, MaterialCode = wo.MaterialCode, MaterialName = wo.MaterialName, StoveCode = wo.StoveCode, }, true ) .ToPage_NO_Convert(parm); return response; } /// /// 获取详情 /// /// /// public ProReportwork01 GetInfo(string Id) { var response = Queryable().Where(x => x.Id == Id).First(); return response; } /// /// 添加报工 /// /// /// public ProReportwork01 AddProReportwork(ProReportwork01 model) { //出货工序 if (model.ProcessId == 90 && !string.IsNullOrEmpty(model.Workorder)) { Context .Updateable() .SetColumns(it => it.ShipmentNum == model.FinishNum) .Where(it => it.Workorder == model.Workorder) .ExecuteCommand(); } return Insertable(model).ExecuteReturnEntity(); } /// /// 修改报工 /// /// /// public int UpdateProReportwork(ProReportwork01 model) { //出货工序 if (model.ProcessId == 90 && !string.IsNullOrEmpty(model.Workorder)) { Context .Updateable() .SetColumns(it => it.ShipmentNum == model.FinishNum) .Where(it => it.Workorder == model.Workorder) .ExecuteCommand(); } return Update(model, true); } /// /// 查询导出表达式 /// /// /// private static Expressionable QueryExp(ProReportworkQueryDto parm) { var predicate = Expressionable .Create() .AndIF( !string.IsNullOrEmpty(parm.Workorder), it => it.Workorder.Contains(parm.Workorder) ) //.AndIF(!string.IsNullOrEmpty(parm.Worker), it => it.Worker.Contains(parm.Worker)) .AndIF(!string.IsNullOrEmpty(parm.Worker), it => it.Worker.Contains(parm.Worker)) .AndIF(parm.RouteId.HasValue && parm.RouteId > 0, it => it.RouteId == parm.RouteId) .AndIF(parm.ProcessId.HasValue && parm.ProcessId > 0, it => it.ProcessId == parm.ProcessId) .AndIF( parm.JobDateTime != null && parm.JobDateTime[0] > DateTime.MinValue, it => it.JobDateTime >= parm.JobDateTime[0] ) .AndIF( parm.JobDateTime != null && parm.JobDateTime[1] > DateTime.MinValue, it => it.JobDateTime <= parm.JobDateTime[1].AddDays(1) ); return predicate; } /// /// 执行报工数据查询 /// /// /// private List ExecuteExportQuery(ISugarQueryable query) { var response = Context .Queryable(query) .LeftJoin((q, w) => q.ProcessId == w.Id) .LeftJoin((q, w, wo) => q.Workorder == wo.Workorder) .OrderBy((q, w, wo) => new { q.Workorder, w.Id }) .Select( (q, w, wo) => new ProReportworkDto { PlanNum = wo.PlanNum, ProcessName = w.Name, FeedOrder = wo.FeedOrder, ProductionName = wo.productionName, ProductionCode = wo.productionCode, MaterialCode = wo.MaterialCode, MaterialName = wo.MaterialName, StoveCode = wo.StoveCode, }, true ) .ToList(); return response; } /// /// 导出报工数据 /// /// /// public List ReportWorkExport(DateTime extportDate) { var startDate = extportDate.Date; var endDate = startDate.AddDays(1); var query = Queryable() .Where(it => it.JobDateTime >= startDate && it.JobDateTime < endDate); return ExecuteExportQuery(query); } /// /// 导出报工数据(带查询参数) /// /// /// public List GetExportList(ProReportworkQueryDto parm) { var predicate = QueryExp(parm); var query = Queryable().Where(predicate.ToExpression()); return ExecuteExportQuery(query); } }