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)
.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)
{
//出货工序
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==parm.Worker)
.AndIF(parm.RouteId>0, it => it.RouteId == parm.RouteId)
.AndIF(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;
}
}