OrderSendsApplicationService.cs 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Threading.Tasks;
  7. using Abp.Application.Services.Dto;
  8. using Abp.Authorization;
  9. using Abp.Domain.Repositories;
  10. using Abp.Extensions;
  11. using Abp.Timing;
  12. using IwbZero.AppServiceBase;
  13. using IwbZero.Auditing;
  14. using IwbZero.IdentityFramework;
  15. using IwbZero.Setting;
  16. using NPOI.HSSF.UserModel;
  17. using NPOI.SS.UserModel;
  18. using ShwasherSys.Authorization.Permissions;
  19. using ShwasherSys.Lambda;
  20. using ShwasherSys.Order;
  21. using ShwasherSys.OrderSendInfo.Dto;
  22. namespace ShwasherSys.OrderSendInfo
  23. {
  24. [AbpAuthorize]
  25. public class OrderSendAppService : ShwasherAsyncCrudAppService<OrderSend, OrderSendDto, int, PagedRequestDto, OrderSendCreateDto, OrderSendUpdateDto >, IOrderSendAppService
  26. {
  27. protected IRepository<ViewOrderItems> ViewOrderItemsRepository;
  28. protected IRepository<ViewOrderSend> ViewOrderSendRepository;
  29. public OrderSendAppService(IRepository<OrderSend, int> repository, IRepository<ViewOrderItems> viewOrderItemsRepository,IIwbSettingManager settingManager, IRepository<ViewOrderSend> viewOrderSendRepository) : base(repository)
  30. {
  31. ViewOrderItemsRepository = viewOrderItemsRepository;
  32. ViewOrderSendRepository = viewOrderSendRepository;
  33. SettingManager = settingManager;
  34. }
  35. protected override string GetPermissionName { get; set; } //= PermissionNames.PagesOrderSend;
  36. protected override string GetAllPermissionName { get; set; } //= PermissionNames.PagesOrderSend;
  37. protected override string CreatePermissionName { get; set; } //= PermissionNames.PagesOrderSendCreate;
  38. protected override string UpdatePermissionName { get; set; } //= PermissionNames.PagesOrderSendUpdate;
  39. protected override string DeletePermissionName { get; set; } //= PermissionNames.PagesOrderSendDelete;
  40. [AbpAuthorize(PermissionNames.PagesSendGoodsOrderSendQueryMgExportExcel),AuditLog("发货明细导入excel")]
  41. public async Task<string> ExportExcel(List<MultiSearchDto> input)
  42. {
  43. var query = ViewOrderSendRepository.GetAll();
  44. if (input != null && input.Count > 0)
  45. {
  46. List<LambdaObject> objList = new List<LambdaObject>();
  47. foreach (var o in input)
  48. {
  49. if (o.KeyWords.IsNullOrEmpty())
  50. {
  51. if (o.KeyField == "customerId")
  52. {
  53. CheckErrors(IwbIdentityResult.Failed("请在搜索项上填上【客户编号】"));
  54. }
  55. continue;
  56. }
  57. object keyWords = o.KeyWords;
  58. if (o.KeyWords == "0")
  59. {
  60. query = query.Where(i => i.OrderStickBillNo == "" || i.OrderStickBillNo == null);
  61. continue;
  62. }
  63. if (o.KeyWords == "1")
  64. {
  65. query = query.Where(i => i.OrderStickBillNo != "" && i.OrderStickBillNo != null);
  66. continue;
  67. }
  68. objList.Add(new LambdaObject
  69. {
  70. FieldType = (LambdaFieldType)o.FieldType,
  71. FieldName = o.KeyField,
  72. FieldValue = keyWords,
  73. ExpType = (LambdaExpType)o.ExpType
  74. });
  75. }
  76. var exp = objList.GetExp<ViewOrderSend>();
  77. query = query.Where(exp);
  78. }
  79. query = query.OrderByDescending(i => i.OrderDate);
  80. var list = await AsyncQueryableExecuter.ToListAsync(query);
  81. if (!list.Any())
  82. {
  83. CheckErrors(IwbIdentityResult.Failed("未查询到记录!"));
  84. return null;
  85. }
  86. string path = AppDomain.CurrentDomain.BaseDirectory + "Resources/OrderSendTemplate/客户发货单明细统计.xlsx";
  87. var savePath = "Download/Excel/SendBills";
  88. var work = ExcelHelper.CreateWorkBook07(path);
  89. var sheet = work.GetSheet("Worksheet");
  90. sheet.InsertRows(2,list.Count-1);
  91. var index = 2;
  92. foreach (var l in list)
  93. {
  94. sheet.GenerateCell(index,1).SetValue(l.CustomerId);
  95. sheet.GenerateCell(index,2).SetValue<DateTime>(l.OrderDate);
  96. sheet.GenerateCell(index,3).SetValue(l.StockNo);
  97. sheet.GenerateCell(index,4).SetValue(l.OrderNo);
  98. sheet.GenerateCell(index,5).SetValue(l.PartNo);
  99. sheet.GenerateCell(index,6).SetValue<DateTime>(l.SendDate);
  100. sheet.GenerateCell(index,7).SetValue(l.ProductNo);
  101. sheet.GenerateCell(index,8).SetValue(l.ProductName);
  102. sheet.GenerateCell(index,9).SetValue<decimal>(l.SendQuantity);
  103. sheet.GenerateCell(index,10).SetValue(l.OrderUnitName);
  104. sheet.GenerateCell(index,11).SetValue(l.OrderStickBillNo);
  105. if (await IsGrantedAsync(PermissionNames.PagesSendGoodsOrderSendQueryMgQueryPrice))
  106. {
  107. sheet.GenerateCell(index,12).SetValue<decimal>(l.TotalPrice);
  108. }
  109. index++;
  110. }
  111. decimal totalSendQuantity = list.Sum(a => a.SendQuantity),totalPrice= list.Sum(a=>a.TotalPrice);
  112. sheet.GenerateCell(index,3).SetValue<int>(list.Count);
  113. sheet.GenerateCell(index,9).SetValue<decimal>(totalSendQuantity);
  114. if (await IsGrantedAsync(PermissionNames.PagesSendGoodsOrderSendQueryMgQueryPrice))
  115. {
  116. sheet.GenerateCell(index,12).SetValue<decimal>(totalPrice);
  117. }
  118. var fileName = $"发货明细-{Clock.Now:yyMMddHHmmss}.xlsx";
  119. var result = work?.SaveWorkBook($"{AppDomain.CurrentDomain.BaseDirectory}{savePath}", fileName);
  120. if (!result.IsNullOrEmpty())
  121. {
  122. //CheckErrors(IwbIdentityResult.Failed(result));
  123. return null;
  124. }
  125. return $"/{savePath}/{fileName}";
  126. }
  127. /// <summary>
  128. /// 查询的完成订单明细
  129. /// </summary>
  130. /// <param name="input"></param>
  131. /// <returns></returns>
  132. [AbpAuthorize(PermissionNames.PagesSendGoodsOrderSendQueryMg),AuditLog("发货统计查询")]
  133. public async Task<PagedResultDto<ViewOrderSend>> GetViewOrderItemAll(PagedRequestDto input)
  134. {
  135. Stopwatch stopwatch = new Stopwatch();
  136. stopwatch.Start(); // 开始监视代码
  137. var query = ViewOrderSendRepository.GetAll();
  138. if (input.SearchList != null && input.SearchList.Count > 0)
  139. {
  140. List<LambdaObject> objList = new List<LambdaObject>();
  141. foreach (var o in input.SearchList)
  142. {
  143. if (o.KeyWords.IsNullOrEmpty())
  144. continue;
  145. object keyWords = o.KeyWords;
  146. if (o.KeyField == "isDoBill")
  147. {
  148. if (o.KeyWords == "0")
  149. {
  150. query= query.Where(i => i.OrderStickBillNo == "" || i.OrderStickBillNo == null);
  151. continue;
  152. }
  153. if (o.KeyWords == "1")
  154. {
  155. query = query.Where(i => i.OrderStickBillNo != "" && i.OrderStickBillNo != null);
  156. continue;
  157. }
  158. }
  159. objList.Add(new LambdaObject
  160. {
  161. FieldType = (LambdaFieldType)o.FieldType,
  162. FieldName = o.KeyField,
  163. FieldValue = keyWords,
  164. ExpType = (LambdaExpType)o.ExpType
  165. });
  166. }
  167. var exp = objList.GetExp<ViewOrderSend>();
  168. query = query.Where(exp);
  169. }
  170. var totalCount = await AsyncQueryableExecuter.CountAsync(query);
  171. query = query.OrderByDescending(i => i.SendDate);
  172. query = query.Skip(input.SkipCount).Take(input.MaxResultCount);
  173. var entities = await AsyncQueryableExecuter.ToListAsync(query);
  174. var dtos = new PagedResultDto<ViewOrderSend>(
  175. totalCount,
  176. entities
  177. );
  178. stopwatch.Stop(); // 停止监视
  179. long timeSpan = stopwatch.ElapsedMilliseconds;
  180. this.LogInfo(timeSpan.ToString());
  181. return dtos;
  182. }
  183. }
  184. }