Files
iMES_Net/iMES.Custom/Services/Custom/Partial/Base_DefectItemService.cs

285 lines
14 KiB
C#
Raw Normal View History

2026-02-06 18:34:35 +08:00
/*
*Base_DefectItem类的业务代码应在此处编写
*使repository.EF/Dapper等信息
*使repository.DbContextBeginTransaction
*使DBServerProvider.
*使UserContext.Current操作
*Base_DefectItemService对增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.Custom.IRepositories;
using System.Collections.Generic;
using System;
using iMES.Custom.IServices;
using Newtonsoft.Json.Linq;
using Newtonsoft.Json;
namespace iMES.Custom.Services
{
public partial class Base_DefectItemService
{
private readonly IHttpContextAccessor _httpContextAccessor;
private readonly IBase_DefectItemRepository _repository;//访问数据库
private readonly IBase_NumberRuleRepository _numberRuleRepository;//自定义编码规则访问数据库
private readonly ISys_Table_ExtendRepository _sysTableExtendRepository;//扩展字段访问数据库
private readonly IBase_DefectItem_ExtendDataRepository _baseDefectItemExtendDataRepository;//扩展字段访问数据库
private readonly IBase_DefectItem_ExtendDataService _baseDefectItemExtendDataService;//访问业务代码
[ActivatorUtilitiesConstructor]
public Base_DefectItemService(
IBase_DefectItemRepository dbRepository,
IBase_NumberRuleRepository numberRuleRepository,
ISys_Table_ExtendRepository sysTableExtendRepository,
IBase_DefectItem_ExtendDataRepository baseDefectItemExtendDataRepository,
IBase_DefectItem_ExtendDataService baseDefectItemExtendDataService,
IHttpContextAccessor httpContextAccessor
)
: base(dbRepository)
{
_httpContextAccessor = httpContextAccessor;
_repository = dbRepository;
_numberRuleRepository = numberRuleRepository;
_sysTableExtendRepository = sysTableExtendRepository;
_baseDefectItemExtendDataRepository = baseDefectItemExtendDataRepository;
_baseDefectItemExtendDataService = baseDefectItemExtendDataService;
//多租户会用到这init代码其他情况可以不用
//base.Init(dbRepository);
}
WebResponseContent webResponse = new WebResponseContent();
/// <summary>
/// 新建
/// </summary>
/// <param name="saveDataModel"></param>
/// <returns></returns>
public override WebResponseContent Add(SaveModel saveDataModel)
{
//此处saveModel是从前台提交的原生数据可对数据进修改过滤
AddOnExecuting = (Base_DefectItem defectItem, object list) =>
{
if (string.IsNullOrWhiteSpace(defectItem.DefectItemCode))
defectItem.DefectItemCode = GetDefectItemCode(1);
//如果返回false,后面代码不会再执行、
if (repository.Exists(x => x.DefectItemName == defectItem.DefectItemName))
{
return webResponse.Error("不良品项名称已存在");
}
if (repository.Exists(x => x.DefectItemCode == defectItem.DefectItemCode))
{
return webResponse.Error("不良品项编号已存在");
}
return webResponse.OK();
};
//扩展字段开始 start
AddOnExecuted = (Base_DefectItem defectItem, object list) =>
{
if (saveDataModel.Extra != null)
{
var extra = saveDataModel.Extra.ToString();
JObject jo = (JObject)JsonConvert.DeserializeObject(extra);
int defectItem_Id = defectItem.DefectItem_Id.GetInt();
var extend = _sysTableExtendRepository.Find(x => x.TableName == "Base_DefectItem", a => new
{
TableEx_Id = a.TableEx_Id,
FieldName = a.FieldName,
FieldCode = a.FieldCode,
FieldType = a.FieldType
}).ToList();
List<Base_DefectItem_ExtendData> listData = new List<Base_DefectItem_ExtendData>();
for (int i = 0; i < extend.Count; i++)
{
Base_DefectItem_ExtendData extendData = new Base_DefectItem_ExtendData();
extendData.DefectItem_Id = defectItem_Id;
extendData.TableEx_Id = extend[i].TableEx_Id;
extendData.FieldValue = jo[extend[i].FieldCode].ToString();
extendData.FieldName = extend[i].FieldName;
extendData.FieldCode = extend[i].FieldCode;
extendData.CreateDate = defectItem.CreateDate;
extendData.CreateID = defectItem.CreateID;
extendData.Creator = defectItem.Creator;
listData.Add(extendData);
}
_baseDefectItemExtendDataRepository.AddRange(listData, true);
}
return webResponse.OK();
};
//扩展字段开始 end
return base.Add(saveDataModel);
}
/// <summary>
/// 删除不良品项
/// </summary>
/// <param name="keys"></param>
/// <param name="delList"></param>
/// <returns></returns>
public override WebResponseContent Del(object[] keys, bool delList = false)
{
base.DelOnExecuted = (object[] defectItemIds) =>
{
for (int i = 0; i < defectItemIds.Length; i++)
{
var defectItemExtend = _baseDefectItemExtendDataRepository.Find(x => x.DefectItem_Id == defectItemIds[i].GetInt(), a => new
{
DefectItemExData_Id = a.DefectItemExData_Id,
DefectItem_Id = a.DefectItem_Id,
TableEx_Id = a.TableEx_Id
}).ToList();
object[] keys = new object[defectItemExtend.Count];
for (int j = 0; j < defectItemExtend.Count; j++)
{
keys[j] = defectItemExtend[j].DefectItemExData_Id.GetInt();
}
if (keys.Length > 0)
_baseDefectItemExtendDataRepository.DeleteWithKeys(keys, false);
};
return new WebResponseContent() { Status = true };
};
return base.Del(keys, delList);
}
/// <summary>
/// 编辑
/// </summary>
/// <param name="saveDataModel"></param>
/// <returns></returns>
public override WebResponseContent Update(SaveModel saveDataModel)
{
//编辑方法保存数据库前处理
UpdateOnExecuting = (Base_DefectItem defectItem, object addList, object updateList, List<object> delKeys) =>
{
if (repository.Exists(x => x.DefectItemName == defectItem.DefectItemName && x.DefectItem_Id != defectItem.DefectItem_Id))
{
return webResponse.Error("不良品项名称已存在");
}
if (repository.Exists(x => x.DefectItemCode == defectItem.DefectItemCode && x.DefectItem_Id != defectItem.DefectItem_Id))
{
return webResponse.Error("不良品项编号已存在");
}
return webResponse.OK();
};
base.UpdateOnExecuted = (Base_DefectItem defectItem, object obj1, object obj2, List<object> List) =>
{
if (saveDataModel.Extra != null)
{
var extra = saveDataModel.Extra.ToString();
JObject jo = (JObject)JsonConvert.DeserializeObject(extra);
int defectItem_Id = defectItem.DefectItem_Id.GetInt();
var defectItemExtend = _sysTableExtendRepository.Find(x => x.TableName == "Base_DefectItem", a => new
{
TableEx_Id = a.TableEx_Id,
FieldName = a.FieldName,
FieldCode = a.FieldCode,
FieldType = a.FieldType
}).ToList();
for (int i = 0; i < defectItemExtend.Count; i++)
{
Base_DefectItem_ExtendData defectItemExtendData = _baseDefectItemExtendDataRepository.FindAsIQueryable(x => x.DefectItem_Id == defectItem_Id && x.TableEx_Id == defectItemExtend[i].TableEx_Id)
.FirstOrDefault();
if (defectItemExtendData == null)
{
Base_DefectItem_ExtendData extendData = new Base_DefectItem_ExtendData();
extendData.DefectItem_Id = defectItem_Id;
extendData.TableEx_Id = defectItemExtend[i].TableEx_Id;
extendData.FieldValue = jo[defectItemExtend[i].FieldCode].ToString();
extendData.FieldName = defectItemExtend[i].FieldName;
extendData.FieldCode = defectItemExtend[i].FieldCode;
extendData.CreateDate = defectItem.ModifyDate;
extendData.CreateID = defectItem.ModifyID;
extendData.Creator = defectItem.Modifier;
_baseDefectItemExtendDataRepository.Add(extendData, true);
}
else
{
defectItemExtendData.ModifyDate = defectItem.ModifyDate;
defectItemExtendData.ModifyID = defectItem.ModifyID;
defectItemExtendData.Modifier = defectItem.Modifier;
defectItemExtendData.FieldValue = jo[defectItemExtend[i].FieldCode].ToString();
_baseDefectItemExtendDataRepository.Update(defectItemExtendData, true);
};
}
}
return new WebResponseContent(true);
};
return base.Update(saveDataModel);
}
/// <summary>
/// 导入
/// </summary>
/// <param name="files"></param>
/// <returns></returns>
public override WebResponseContent Import(List<IFormFile> files)
{
//导入保存前处理(可以对list设置新的值)
ImportOnExecuting = (List<Base_DefectItem> list) =>
{
for (int i = 0; i < list.Count; i++)
{
if (string.IsNullOrWhiteSpace(list[i].DefectItemCode))
list[i].DefectItemCode = GetDefectItemCode(1);
if (i > 0)
{
list[i].DefectItemCode = GetDefectItemCode(i + 1);
}
if (repository.Exists(x => x.DefectItemName == list[i].DefectItemName))
{
return webResponse.Error("不良品项名称已存在");
}
if (repository.Exists(x => x.DefectItemCode == list[i].DefectItemCode))
{
return webResponse.Error("不良品项编号已存在");
}
}
return webResponse.OK();
};
//导入后处理(已经写入到数据库了)
ImportOnExecuted = (List<Base_DefectItem> list) =>
{
return webResponse.OK();
};
return base.Import(files);
}
/// <summary>
/// 自动生成不良品编号
/// </summary>
/// <returns></returns>
public string GetDefectItemCode(int i)
{
DateTime dateNow = (DateTime)DateTime.Now.ToString("yyyy-MM-dd").GetDateTime();
//查询当天最新的订单号
string defectItemCode = repository.FindAsIQueryable(x => x.CreateDate > dateNow && x.DefectItemCode.Length>8)
.OrderByDescending(x => x.DefectItemCode)
.Select(s => s.DefectItemCode)
.FirstOrDefault();
Base_NumberRule numberRule = _numberRuleRepository.FindAsIQueryable(x => x.FormCode == "DefectItem")
.OrderByDescending(x => x.CreateDate)
.FirstOrDefault();
if (numberRule != null)
{
string rule = numberRule.Prefix + DateTime.Now.ToString(numberRule.SubmitTime.Replace("hh", "HH"));
if (string.IsNullOrEmpty(defectItemCode))
{
rule += i.ToString().PadLeft(numberRule.SerialNumber, '0');
}
else
{
rule += (defectItemCode.Substring(defectItemCode.Length - numberRule.SerialNumber).GetInt() + i).ToString("0".PadLeft(numberRule.SerialNumber, '0'));
}
return rule;
}
else //如果自定义序号配置项不存在,则使用日期生成
{
return DateTime.Now.ToString("yyyyMMddHHmmssffff");
}
}
}
}