Files
kunshan-bzfm-mes-backend/DOAN.Service/MES/Product/ProReportworkService.cs

215 lines
7.0 KiB
C#
Raw Normal View History

2024-12-03 19:02:23 +08:00
using DOAN.Model.BZFM.Dto;
2024-12-03 20:24:07 +08:00
using DOAN.Model.MES.base_;
2024-12-03 19:02:23 +08:00
using DOAN.Model.MES.product;
using DOAN.Repository;
2024-12-03 19:07:34 +08:00
using DOAN.Service.MES.product.IService;
2024-12-03 20:24:07 +08:00
using Infrastructure.Attribute;
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
namespace DOAN.Service.MES.product;
2024-12-03 19:07:34 +08:00
2024-12-03 20:24:07 +08:00
/// <summary>
/// 报工Service业务层处理
/// </summary>
[AppService(ServiceType = typeof(IProReportworkService), ServiceLifetime = LifeTime.Transient)]
public class ProReportworkService : BaseService<ProReportwork01>, IProReportworkService
2024-12-03 19:02:23 +08:00
{
2024-12-23 14:00:01 +08:00
public List<BaseWorkRoute> GetRoute()
2024-12-21 16:39:26 +08:00
{
return Context.Queryable<BaseWorkRoute>().ToList();
}
2025-03-12 15:36:04 +08:00
/// <summary>
/// 查询全部工序
/// </summary>
/// <returns></returns>
public List<BaseWorkProcesses> GetBaseWorkProcesses()
{
2026-01-07 20:06:02 +08:00
return Context.Queryable<BaseWorkProcesses>().ToList();
}
public List<BaseWorkProcesses> GetProcessByRoute(int route_id)
2024-12-21 16:39:26 +08:00
{
2026-01-07 20:06:02 +08:00
return Context
.Queryable<BaseRelWorkRouteProcesses>()
.LeftJoin<BaseWorkProcesses>((rel, pro) => rel.FkWorkProcesses == pro.Id)
.Where((rel, pro) => rel.FkWorkRoute == route_id)
.Select((rel, pro) => pro)
2024-12-21 16:39:26 +08:00
.ToList();
}
2026-01-07 20:06:02 +08:00
2024-12-03 19:02:23 +08:00
/// <summary>
2024-12-03 20:24:07 +08:00
/// 查询报工列表
2024-12-03 19:02:23 +08:00
/// </summary>
2024-12-03 20:24:07 +08:00
/// <param name="parm"></param>
/// <returns></returns>
public PagedInfo<ProReportworkDto> GetList(ProReportworkQueryDto parm)
2024-12-03 19:02:23 +08:00
{
2024-12-03 20:24:07 +08:00
var predicate = QueryExp(parm);
2024-12-03 19:02:23 +08:00
2026-01-07 20:06:02 +08:00
var query = Queryable().Where(predicate.ToExpression());
var response = Context
.Queryable(query)
.LeftJoin<BaseWorkProcesses>((q, w) => q.ProcessId == w.Id)
.LeftJoin<ProWorkorder>((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
)
2024-12-03 20:24:07 +08:00
.ToPage_NO_Convert(parm);
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
return response;
}
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
/// <summary>
/// 获取详情
/// </summary>
/// <param name="Id"></param>
/// <returns></returns>
public ProReportwork01 GetInfo(string Id)
{
2026-01-07 20:06:02 +08:00
var response = Queryable().Where(x => x.Id == Id).First();
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
return response;
}
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
/// <summary>
/// 添加报工
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public ProReportwork01 AddProReportwork(ProReportwork01 model)
{
2025-02-18 13:11:15 +08:00
//出货工序
2026-01-07 20:06:02 +08:00
if (model.ProcessId == 90 && !string.IsNullOrEmpty(model.Workorder))
2025-02-18 13:11:15 +08:00
{
2026-01-07 20:06:02 +08:00
Context
.Updateable<ProWorkorder>()
2025-02-18 13:11:15 +08:00
.SetColumns(it => it.ShipmentNum == model.FinishNum)
2026-01-07 20:06:02 +08:00
.Where(it => it.Workorder == model.Workorder)
.ExecuteCommand();
2025-02-18 13:11:15 +08:00
}
2024-12-03 20:24:07 +08:00
return Insertable(model).ExecuteReturnEntity();
}
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
/// <summary>
/// 修改报工
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public int UpdateProReportwork(ProReportwork01 model)
{
2025-02-18 13:11:15 +08:00
//出货工序
if (model.ProcessId == 90 && !string.IsNullOrEmpty(model.Workorder))
{
2026-01-07 20:06:02 +08:00
Context
.Updateable<ProWorkorder>()
2025-02-18 13:11:15 +08:00
.SetColumns(it => it.ShipmentNum == model.FinishNum)
2026-01-07 20:06:02 +08:00
.Where(it => it.Workorder == model.Workorder)
.ExecuteCommand();
2025-02-18 13:11:15 +08:00
}
2024-12-03 20:24:07 +08:00
return Update(model, true);
}
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
/// <summary>
/// 查询导出表达式
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
private static Expressionable<ProReportwork01> QueryExp(ProReportworkQueryDto parm)
{
2026-01-07 20:06:02 +08:00
var predicate = Expressionable
.Create<ProReportwork01>()
.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)
2026-01-07 20:06:02 +08:00
.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)
);
2024-12-03 19:02:23 +08:00
2024-12-03 20:24:07 +08:00
return predicate;
2024-12-03 19:02:23 +08:00
}
/// <summary>
/// 执行报工数据查询
/// </summary>
/// <param name="query"></param>
/// <returns></returns>
private List<ProReportworkDto> ExecuteExportQuery(ISugarQueryable<ProReportwork01> query)
{
var response = Context
.Queryable(query)
.LeftJoin<BaseWorkProcesses>((q, w) => q.ProcessId == w.Id)
.LeftJoin<ProWorkorder>((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;
}
/// <summary>
/// 导出报工数据
/// </summary>
/// <param name="extportDate"></param>
/// <returns></returns>
public List<ProReportworkDto> 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);
}
/// <summary>
/// 导出报工数据(带查询参数)
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
public List<ProReportworkDto> GetExportList(ProReportworkQueryDto parm)
{
var predicate = QueryExp(parm);
var query = Queryable().Where(predicate.ToExpression());
return ExecuteExportQuery(query);
}
2026-01-07 20:06:02 +08:00
}