/*
*所有关于Production_SalesOrder类的业务代码应在此处编写
*可使用repository.调用常用方法,获取EF/Dapper等信息
*如果需要事务请使用repository.DbContextBeginTransaction
*也可使用DBServerProvider.手动获取数据库相关信息
*用户信息、权限、角色等使用UserContext.Current操作
*Production_SalesOrderService对增、删、改查、导入、导出、审核业务代码扩展参照ServiceFunFilter
*/
using iMES.Core.BaseProvider;
using iMES.Core.Extensions.AutofacManager;
using iMES.Entity.DomainModels;
using System.Linq;
using iMES.Core.Utilities;
using System.Linq.Expressions;
using iMES.Core.Extensions;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.AspNetCore.Http;
using iMES.Production.IRepositories;
using System;
using iMES.Custom.IRepositories;
using System.Collections.Generic;
using iMES.Custom.Services;
using iMES.Custom.IServices;
using iMES.Core.ManageUser;
using iMES.Production.Repositories;
using iMES.Core.Enums;
using iMES.Core.DBManager;
namespace iMES.Production.Services
{
public partial class Production_SalesOrderService
{
private readonly IHttpContextAccessor _httpContextAccessor;
private readonly IProduction_SalesOrderRepository _repository;//访问数据库
private readonly IProduction_SalesOrderListRepository _salesOrderListrepository;//访问数据库
private readonly IBase_NumberRuleRepository _numberRuleRepository;//自定义编码规则访问数据库
private readonly IProduction_WorkOrderRepository _workOrderRepository;//访问数据库
private readonly IBase_ProductRepository _productRepository;//访问数据库
private readonly IBase_ProcessService _processService;//访问业务代码
private readonly IBase_ProcessRepository _processRepository;//访问数据库]
private readonly IBase_ProcessLineRepository _processLineRepository;
private readonly IProduction_WorkOrderListRepository _workOrderListRepository;//访问数据库
[ActivatorUtilitiesConstructor]
public Production_SalesOrderService(
IProduction_SalesOrderRepository dbRepository,
IBase_NumberRuleRepository numberRuleRepository,
IHttpContextAccessor httpContextAccessor,
IProduction_WorkOrderRepository workOrderRepository,
IBase_ProductRepository productRepository,
IBase_ProcessService processService,
IBase_ProcessRepository processRepository,
IProduction_WorkOrderListRepository workOrderListRepository,
IProduction_SalesOrderListRepository salesOrderListrepository,
IBase_ProcessLineRepository processLineRepository
)
: base(dbRepository)
{
_httpContextAccessor = httpContextAccessor;
_numberRuleRepository = numberRuleRepository;
_repository = dbRepository;
_workOrderRepository = workOrderRepository;
_productRepository = productRepository;
_processService = processService;
_processRepository = processRepository;
_workOrderListRepository = workOrderListRepository;
_salesOrderListrepository = salesOrderListrepository;
_processLineRepository = processLineRepository;
//多租户会用到这init代码,其他情况可以不用
//base.Init(dbRepository);
}
WebResponseContent webResponse = new WebResponseContent();
///
/// 新建
///
///
///
public override WebResponseContent Add(SaveModel saveDataModel)
{
//此处saveModel是从前台提交的原生数据,可对数据进修改过滤
AddOnExecuting = (Production_SalesOrder salesOrder, object list) =>
{
if (string.IsNullOrWhiteSpace(salesOrder.SalesOrderCode))
salesOrder.SalesOrderCode = GetSalesOrderCode();
//如果返回false,后面代码不会再执行
if (repository.Exists(x => x.SalesOrderCode == salesOrder.SalesOrderCode))
{
return webResponse.Error("销售订单编号已存在");
}
UserInfo userInfo = UserContext.Current.UserInfo;
List orderLists = list as List;
int sequence = 1;
string maxWorkOrderCode = _workOrderRepository.FindAsIQueryable(x => x.WorkOrderCode.Contains(salesOrder.SalesOrderCode))
.OrderByDescending(x => x.CreateDate)
.Select(s => s.WorkOrderCode)
.FirstOrDefault();
if (!string.IsNullOrEmpty(maxWorkOrderCode) && maxWorkOrderCode.Contains("-"))
{
sequence = maxWorkOrderCode.Split('-')[1].GetInt() + 1;
}
for (int i = 0; i < orderLists.Count; i++)
{
sequence += i;
orderLists[i].WorkOrderCode = salesOrder.SalesOrderCode + "-" + sequence;
Production_WorkOrder workOrder = new Production_WorkOrder();
workOrder.WorkOrderCode = orderLists[i].WorkOrderCode;
workOrder.Product_Id = orderLists[i].Product_Id;
workOrder.ProductCode = orderLists[i].ProductCode;
workOrder.ProductName = orderLists[i].ProductName;
workOrder.ProductStandard = orderLists[i].ProductStandard;
var product = _productRepository.FindAsIQueryable(x => x.Product_Id == orderLists[i].Product_Id)
.OrderByDescending(x => x.CreateDate)
.Select(s => new
{
s.Unit_Id,
s.Product_Id,
s.Process_Id
})
.FirstOrDefault();
workOrder.Unit_Id = product.Unit_Id;
workOrder.AssociatedForm = salesOrder.SalesOrderCode;
workOrder.FromType = "SalesOrder";
workOrder.Status = "1";
workOrder.PlanStartDate = (DateTime)DateTime.Now.ToString("yyyy-MM-dd 00:00:00").ToDateTime();
workOrder.PlanEndDate = (DateTime)DateTime.Now.ToString("yyyy-MM-dd 23:59:59").ToDateTime();
workOrder.PlanQty = orderLists[i].Qty;
workOrder.RealQty = 0;
workOrder.GoodQty = 0;
workOrder.NoGoodQty = 0;
workOrder.CreateID = userInfo.User_Id;
workOrder.Creator = userInfo.UserTrueName;
workOrder.CreateDate = DateTime.Now;
_workOrderRepository.Add(workOrder, true);
List processList = (List)_processService.GetProcessListByLineID(product.Process_Id.GetInt());
List orderListNext = new List();
for (int j = 0; j < processList.Count; j++)
{
var process = _processRepository.FindAsIQueryable(x => x.Process_Id == processList[j].Process_Id)
.OrderByDescending(x => x.CreateDate)
.Select(s => new
{
s.Process_Id,
s.ProcessName,
s.ProcessCode,
s.SubmitWorkLimit,
s.SubmitWorkMatch,
s.DefectItem
})
.FirstOrDefault();
Production_WorkOrderList entity = new Production_WorkOrderList();
entity.Process_Id = process.Process_Id;
entity.ProcessName = process.ProcessName;
entity.ProcessCode = process.ProcessCode;
entity.SubmitWorkLimit = process.SubmitWorkLimit;
entity.SubmitWorkMatch = process.SubmitWorkMatch;
entity.DefectItem = process.DefectItem;
var processLine = _processLineRepository.FindAsIQueryable(x => x.ProcessLine_Id == product.Process_Id.GetInt())
.OrderByDescending(x => x.CreateDate)
.Select(s => new
{
s.ProcessLine_Id,
s.Approve
})
.FirstOrDefault();
entity.ProcessLine_Id = product.Process_Id.GetInt();
entity.ProcessLine_Approve = processLine.Approve;
entity.PlanStartDate = (DateTime)DateTime.Now.ToString("yyyy-MM-dd 00:00:00").ToDateTime();
entity.PlanEndDate = (DateTime)DateTime.Now.ToString("yyyy-MM-dd 23:59:59").ToDateTime();
entity.PlanQty = orderLists[i].Qty;
entity.GoodQty = 0;
entity.NoGoodQty = 0;
entity.WorkOrder_Id = workOrder.WorkOrder_Id;
entity.WorkOrderCode = workOrder.WorkOrderCode;
entity.CreateID = userInfo.User_Id;
entity.Creator = userInfo.UserTrueName;
entity.CreateDate = DateTime.Now;
orderListNext.Add(entity);
}
_workOrderListRepository.AddRange(orderListNext, true);
}
return webResponse.OK();
};
return base.Add(saveDataModel);
}
///
/// 编辑操作
///
///
///
public override WebResponseContent Update(SaveModel saveModel)
{
UpdateOnExecute = (SaveModel model) =>
{
return webResponse.OK();
};
//编辑方法保存数据库前处理
UpdateOnExecuting = (Production_SalesOrder salesOrder, object addList, object updateList, List