/* *所有关于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(); /// /// 新建 /// /// /// 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 listData = new List(); 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); } /// /// 删除不良品项 /// /// /// /// 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); } /// /// 编辑 /// /// /// public override WebResponseContent Update(SaveModel saveDataModel) { //编辑方法保存数据库前处理 UpdateOnExecuting = (Base_DefectItem defectItem, object addList, object updateList, List 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 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); } /// /// 导入 /// /// /// public override WebResponseContent Import(List files) { //导入保存前处理(可以对list设置新的值) ImportOnExecuting = (List 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 list) => { return webResponse.OK(); }; return base.Import(files); } /// /// 自动生成不良品编号 /// /// 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"); } } } }