SemiProductsApplicationService.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using System.Web.Mvc;
  7. using Abp.Application.Services.Dto;
  8. using Abp.Authorization;
  9. using Abp.Domain.Repositories;
  10. using Abp.Timing;
  11. using IwbZero.AppServiceBase;
  12. using IwbZero.IdentityFramework;
  13. using IwbZero.Setting;
  14. using Newtonsoft.Json;
  15. using ShwasherSys.Authorization.Permissions;
  16. using ShwasherSys.BaseSysInfo;
  17. using ShwasherSys.BaseSysInfo.SysAttachFiles;
  18. using ShwasherSys.BaseSysInfo.SysAttachFiles.Dto;
  19. using ShwasherSys.Common;
  20. using ShwasherSys.EntityFramework;
  21. using ShwasherSys.ProductInfo.Dto;
  22. using ShwasherSys.ProductInfo.Dto.FileUpload;
  23. namespace ShwasherSys.ProductInfo
  24. {
  25. [AbpAuthorize]
  26. public class SemiProductsAppService : ShwasherAsyncCrudAppService<SemiProducts, SemiProductDto, string, PagedRequestDto, SemiProductCreateDto, SemiProductUpdateDto >, ISemiProductsAppService
  27. {
  28. public IRepository<SysAttachFile> AttachRepository { get; }
  29. public ISqlExecuter SqlExecuter { get; }
  30. protected IRepository<Product, string> ProductRepository { get; set; }
  31. public SemiProductsAppService(IRepository<SemiProducts, string> repository, IIwbSettingManager settingManager, IRepository<SysAttachFile> attachRepository, ISqlExecuter sqlExecuter, IRepository<Product, string> productRepository) : base(repository,"Id")
  32. {
  33. AttachRepository = attachRepository;
  34. SqlExecuter = sqlExecuter;
  35. SettingManager = settingManager;
  36. ProductRepository = productRepository;
  37. }
  38. protected override bool KeyIsAuto { get; set; } = false;
  39. protected override string GetPermissionName { get; set; } = PermissionNames.PagesProductInfoSemiProducts;
  40. protected override string GetAllPermissionName { get; set; } = PermissionNames.PagesProductInfoSemiProducts;
  41. protected override string CreatePermissionName { get; set; } = PermissionNames.PagesProductInfoSemiProductsCreate;
  42. protected override string UpdatePermissionName { get; set; } = PermissionNames.PagesProductInfoSemiProductsUpdate;
  43. protected override string DeletePermissionName { get; set; } = PermissionNames.PagesProductInfoSemiProductsDelete;
  44. public override async Task<SemiProductDto> Create(SemiProductCreateDto input)
  45. {
  46. CheckCreatePermission();
  47. var entity = ProductRepository.FirstOrDefault(i => i.Id == input.Id);
  48. if (entity == null)
  49. {
  50. string sEntity = JsonConvert.SerializeObject(input);
  51. var products = JsonConvert.DeserializeObject<Product>(sEntity);
  52. products.IsLock = "N";
  53. products.ProductName = input.SemiProductName;
  54. products.TimeLastMod = Clock.Now;
  55. products.UserIDLastMod = AbpSession.UserName;
  56. products.TimeCreated = Clock.Now;
  57. ProductRepository.Insert(products);
  58. }
  59. var resultEntity = await CreateEntity(input);
  60. if (!string.IsNullOrEmpty(input.FileInfo))
  61. {
  62. SysAttachFileCreateDto fileCreateDto = new SysAttachFileCreateDto()
  63. {
  64. AttachNo = Guid.NewGuid().ToString("N"),
  65. TableName = "SemiProducts",
  66. ColumnName = "SemiProductNo",
  67. SourceKey = input.Id,
  68. FileInfo = input.FileInfo,
  69. FileExt = input.FileExt,
  70. FileName = input.FileName
  71. };
  72. await CreateAttach(fileCreateDto);
  73. }
  74. return resultEntity;
  75. }
  76. public override async Task<SemiProductDto> Update(SemiProductUpdateDto input)
  77. {
  78. CheckCreatePermission();
  79. var entity = ProductRepository.FirstOrDefault(i => i.Id == input.Id);
  80. if (entity != null)
  81. {
  82. entity.ProductName = input.SemiProductName;
  83. entity.TimeLastMod = Clock.Now;
  84. entity.UserIDLastMod = AbpSession.UserName;
  85. ProductRepository.Update(entity);
  86. }
  87. else
  88. {
  89. var product = new Product();
  90. product.Id = input.Id;
  91. product.IsStandard = input.IsStandard;
  92. product.MaterialNo = input.MaterialNo;
  93. product.Material = input.Material;
  94. product.Model = input.Model;
  95. product.ModelNo = input.ModelNo;
  96. product.Rigidity = input.Rigidity;
  97. product.RigidityNo = input.RigidityNo;
  98. product.SurfaceColor = input.SurfaceColor;
  99. product.SurfaceColorNo = input.SurfaceColorNo;
  100. product.SpecialDesc = input.SpecialDesc;
  101. product.SpecialNo = input.SpecialNo;
  102. product.PartNo = input.PartNo;
  103. product.ProductDesc = input.ProductDesc;
  104. product.IsLock = "N";
  105. product.ProductName = input.SemiProductName;
  106. product.TimeLastMod = Clock.Now;
  107. product.UserIDLastMod = AbpSession.UserName;
  108. product.TimeCreated = Clock.Now;
  109. ProductRepository.Insert(product);
  110. }
  111. var resultEntity = await UpdateEntity(input);
  112. if (!string.IsNullOrEmpty(input.FileInfo))
  113. {
  114. SysAttachFileCreateDto fileCreateDto = new SysAttachFileCreateDto()
  115. {
  116. AttachNo = Guid.NewGuid().ToString("N"),
  117. TableName = "SemiProducts",
  118. ColumnName = "SemiProductNo",
  119. SourceKey = input.Id,
  120. FileInfo = input.FileInfo,
  121. FileExt = input.FileExt,
  122. FileName = input.FileName
  123. };
  124. await AttachRepository.DeleteAsync(i =>
  125. i.TableName == "SemiProducts" && i.ColumnName == "SemiProductNo" && i.SourceKey == input.Id);
  126. await CreateAttach(fileCreateDto);
  127. }
  128. return resultEntity;
  129. }
  130. private async Task CreateAttach(SysAttachFileCreateDto input)
  131. {
  132. if (await IsValidFileType(input.FileExt))
  133. {
  134. string filePath =
  135. $"{SettingManager.GetSettingValue(SettingNames.DownloadPath)}/{input.TableName}/{input.ColumnName}";
  136. var lcRetVal = SysAttachFileAppService.Base64ToFile(input.FileInfo,
  137. $"{input.FileName}-{DateTime.Now:yyMMddHHmmss}{new Random().Next(1000, 9999)}", input.FileExt,
  138. filePath);
  139. if (lcRetVal.StartsWith("error@"))
  140. {
  141. CheckErrors(
  142. IwbIdentityResult.Failed(lcRetVal.Split(new[] { '@' },
  143. StringSplitOptions.RemoveEmptyEntries)[1]));
  144. return;
  145. }
  146. input.FilePath = lcRetVal;
  147. var entity = ObjectMapper.Map<SysAttachFile>(input);
  148. entity = await AttachRepository.InsertAsync(entity);
  149. return;
  150. }
  151. CheckErrors(IwbIdentityResult.Failed("文件类型不合法,请上传合法文件。"));
  152. }
  153. private async Task<bool> IsValidFileType(string fileName, bool isName = false)
  154. {
  155. string ext = isName ? GetFileExt(fileName) : fileName;
  156. string lcExts = await SettingManager.GetSettingValueAsync(SettingNames.UploadFileExt);
  157. string[] loList = lcExts.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
  158. foreach (var lcExt in loList)
  159. {
  160. if (ext.ToLower() == lcExt.ToLower())
  161. return true;
  162. }
  163. this.LogError("上传的文件非法:" + fileName);
  164. return false;
  165. }
  166. private string GetFileExt(string fileName)
  167. {
  168. string fileExt = fileName.Substring(fileName.LastIndexOf(".", StringComparison.Ordinal) + 1, fileName.Length - fileName.LastIndexOf(".", StringComparison.Ordinal) - 1);
  169. return fileExt.ToLower();
  170. }
  171. [AbpAuthorize(PermissionNames.PagesProductInfoSemiProductsImportExcel)]
  172. public bool ImportExcel(FileUploadInfoDto input)
  173. {
  174. if (!string.IsNullOrEmpty(input.FileInfo))
  175. {
  176. string filePath =
  177. $"{SettingManager.GetSettingValue(SettingNames.DownloadPath)}/tmpUpload";
  178. var lcRetVal = SysAttachFileAppService.Base64ToFile(input.FileInfo,
  179. $"{input.FileName}-{DateTime.Now:yyMMddHHmmss}{new Random().Next(1000, 9999)}", input.FileExt,
  180. filePath);
  181. StringBuilder errStringBuilder = new StringBuilder();
  182. List<SemiProducts> resultEntityList = ExcelHelper.ExcelToEntityList<SemiProducts>(new Dictionary<string, string>() { { "Id", "半成品编码" }, { "PartNo", "零件号" }, { "Model", "规格" }, { "Material", "材质" }, { "Rigidity", "硬度" }, { "SurfaceColor", "表色" }, { "IsStandard", "是否标件" },{ "SemiProductName", "半成品名称"} }, $"{AppDomain.CurrentDomain.BaseDirectory}{lcRetVal}",
  183. out errStringBuilder);
  184. int indexCount = 1;
  185. StringBuilder sbSql = new StringBuilder();
  186. sbSql.Append("delete from SemiProducts;");
  187. foreach (var semiProductse in resultEntityList)
  188. {
  189. semiProductse.IsLock = "N";
  190. semiProductse.TimeLastMod = Clock.Now;
  191. semiProductse.TimeCreated = Clock.Now;
  192. semiProductse.UserIDLastMod = AbpSession.UserName;
  193. if (semiProductse.IsStandard == "是"|| semiProductse.IsStandard == "否")
  194. {
  195. semiProductse.IsStandard = semiProductse.IsStandard == "是" ? "Y" : "N";
  196. }
  197. semiProductse.SemiProductName = semiProductse.SemiProductName;
  198. semiProductse.Sequence = indexCount;
  199. semiProductse.Model = semiProductse.Model == "-" ? "" : semiProductse.Model;
  200. semiProductse.Material = semiProductse.Material == "-" ? "" : semiProductse.Material;
  201. semiProductse.Rigidity = semiProductse.Rigidity == "-" ? "" : semiProductse.Rigidity;
  202. semiProductse.SurfaceColor = semiProductse.SurfaceColor == "-" ? "" : semiProductse.SurfaceColor;
  203. semiProductse.PartNo = semiProductse.PartNo == "-" ? "" : semiProductse.PartNo;
  204. sbSql.Append(semiProductse.InsertSql()+"\r\n");
  205. indexCount++;
  206. }
  207. if (SqlExecuter.Execute(sbSql.ToString()) > 0)
  208. {
  209. return true;
  210. }
  211. this.LogError(errStringBuilder.ToString());
  212. }
  213. else
  214. {
  215. CheckErrors(new IwbIdentityResult("请先上传文件!"));
  216. }
  217. return false;
  218. }
  219. [AbpAllowAnonymous]
  220. public async Task<string> ExportExcel()
  221. {
  222. var query = Repository.GetAll();
  223. var entities = await AsyncQueryableExecuter.ToListAsync(query);
  224. string downloadUrl = await SettingManager.GetSettingValueAsync("SYSTEMDOWNLOADPATH");
  225. string lcFilePath = System.Web.HttpRuntime.AppDomainAppPath + "\\" +
  226. downloadUrl;
  227. var exportEntity = new Dictionary<string, string>()
  228. {
  229. {"Id", "半成品编码"},
  230. {"Model", "规格"},
  231. {"Material", "材质"},
  232. {"SurfaceColor", "表色"},
  233. {"Rigidity", "硬度"},
  234. {"IsStandard", "是否标件"},
  235. {"PartNo", "零件号"},
  236. {"SemiProductName", "半成品名称"},
  237. };
  238. string lcResultFileName = ExcelHelper.EntityListToExcel2003(exportEntity, entities, "sheet", lcFilePath);
  239. return Path.Combine(downloadUrl, lcResultFileName);
  240. }
  241. }
  242. }