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 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) .OrderBy((q,w)=>new { q.Workorder ,w.Id}) .Select((q, w) => new ProReportworkDto { ProcessName = w.Name }, 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) { return Insertable(model).ExecuteReturnEntity(); } /// /// 修改报工 /// /// /// public int UpdateProReportwork(ProReportwork01 model) { 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.RouteCode), it => it.RouteCode == parm.RouteCode) .AndIF(parm.ProcessId > 0, it => it.ProcessId == parm.ProcessId) .AndIF(parm.JobDate != null && parm.JobDate[0] > DateTime.MinValue, it => it.JobDate >= parm.JobDate[0]) .AndIF(parm.JobDate != null && parm.JobDate[1] > DateTime.MinValue, it => it.JobDate <= parm.JobDate[1].AddDays(1)) ; return predicate; } }