OrderProductionsApplicationService.cs 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. using System.Collections.Generic;
  2. using System.Linq;
  3. using System.Threading.Tasks;
  4. using System.Web.Mvc;
  5. using Abp.Application.Services.Dto;
  6. using Abp.Auditing;
  7. using Abp.Authorization;
  8. using Abp.Domain.Repositories;
  9. using Abp.Runtime.Caching;
  10. using IwbZero.Auditing;
  11. using IwbZero.AppServiceBase;
  12. //using IwbZero.ToolCommon.Lambda;
  13. using ShwasherSys.Authorization.Permissions;
  14. using ShwasherSys.ProductionOrderInfo.Dto;
  15. namespace ShwasherSys.ProductionOrderInfo
  16. {
  17. [AbpAuthorize]
  18. public class OrderProductionAppService : IwbZeroAsyncCrudAppService<OrderProduction, OrderProductionDto, int, IwbPagedRequestDto, OrderProductionCreateDto, OrderProductionUpdateDto >, IOrderProductionAppService
  19. {
  20. public OrderProductionAppService(
  21. ICacheManager cacheManager,
  22. IRepository<OrderProduction, int> repository) : base(repository, "Id")
  23. {
  24. CacheManager = cacheManager;
  25. }
  26. protected override bool KeyIsAuto { get; set; } = false;
  27. #region GetSelect
  28. [DisableAuditing]
  29. public override async Task<List<SelectListItem>> GetSelectList()
  30. {
  31. var list = await Repository.GetAllListAsync();
  32. var sList = new List<SelectListItem> {new SelectListItem {Text = @"请选择...", Value = "", Selected = true}};
  33. foreach (var l in list)
  34. {
  35. //sList.Add(new SelectListItem { Value = l.Id, Text = l. });
  36. }
  37. return sList;
  38. }
  39. [DisableAuditing]
  40. public override async Task<string> GetSelectStr()
  41. {
  42. var list = await Repository.GetAllListAsync();
  43. string str = "<option value=\"\" selected>请选择...</option>";
  44. foreach (var l in list)
  45. {
  46. //str += $"<option value=\"{l.Id}\">{l.}</option>";
  47. }
  48. return str;
  49. }
  50. #endregion
  51. #region CURD
  52. // [AbpAuthorize(PermissionNames.PagesMgOrderProductionMgCreate)]
  53. public override async Task Create(OrderProductionCreateDto input)
  54. {
  55. await CreateEntity(input);
  56. }
  57. // [AbpAuthorize(PermissionNames.PagesMgOrderProductionMgUpdate)]
  58. public override async Task Update(OrderProductionUpdateDto input)
  59. {
  60. await UpdateEntity(input);
  61. }
  62. //[AbpAuthorize(PermissionNames.PagesMgOrderProductionMgDelete)]
  63. public override Task Delete(EntityDto<int> input)
  64. {
  65. return Repository.DeleteAsync(input.Id);
  66. }
  67. [DisableAuditing]
  68. // [AbpAuthorize(PermissionNames.PagesMgOrderProductionMgQuery)]
  69. public override async Task<PagedResultDto<OrderProductionDto>> GetAll(IwbPagedRequestDto input)
  70. {
  71. var query = CreateFilteredQuery(input);
  72. query = ApplyFilter(query, input);
  73. var totalCount = await AsyncQueryableExecuter.CountAsync(query);
  74. query = ApplySorting(query, input);
  75. query = ApplyPaging(query, input);
  76. var entities = await AsyncQueryableExecuter.ToListAsync(query);
  77. var dtoList = new PagedResultDto<OrderProductionDto>(totalCount, entities.Select(MapToEntityDto).ToList());
  78. return dtoList;
  79. }
  80. #region GetEntity/Dto
  81. /// <summary>
  82. /// 查询实体Dto
  83. /// </summary>
  84. /// <param name="input"></param>
  85. /// <returns></returns>
  86. [DisableAuditing]
  87. // [AbpAuthorize(PermissionNames.PagesMgOrderProductionMgQuery)]
  88. public override async Task<OrderProductionDto> GetDto(EntityDto<int> input)
  89. {
  90. var entity = await GetEntity(input);
  91. return MapToEntityDto(entity);
  92. }
  93. /// <summary>
  94. /// 查询实体Dto
  95. /// </summary>
  96. /// <param name="id"></param>
  97. /// <returns></returns>
  98. [DisableAuditing]
  99. // [AbpAuthorize(PermissionNames.PagesMgOrderProductionMgQuery)]
  100. public override async Task<OrderProductionDto> GetDtoById(int id)
  101. {
  102. var entity = await GetEntityById(id);
  103. return MapToEntityDto(entity);
  104. }
  105. /// <summary>
  106. /// 查询实体Dto(需指明自定义字段)
  107. /// </summary>
  108. /// <param name="no"></param>
  109. /// <returns></returns>
  110. [DisableAuditing]
  111. // [AbpAuthorize(PermissionNames.PagesMgOrderProductionMgQuery)]
  112. public override async Task<OrderProductionDto> GetDtoByNo(string no)
  113. {
  114. var entity = await GetEntityByNo(no);
  115. return MapToEntityDto(entity);
  116. }
  117. /// <summary>
  118. /// 查询实体
  119. /// </summary>
  120. /// <param name="input"></param>
  121. /// <returns></returns>
  122. [DisableAuditing]
  123. //[AbpAuthorize(PermissionNames.PagesMgOrderProductionMgQuery)]
  124. public override async Task<OrderProduction> GetEntity(EntityDto<int> input)
  125. {
  126. var entity = await GetEntityById(input.Id);
  127. return entity;
  128. }
  129. /// <summary>
  130. /// 查询实体
  131. /// </summary>
  132. /// <param name="id"></param>
  133. /// <returns></returns>
  134. [DisableAuditing]
  135. // [AbpAuthorize(PermissionNames.PagesMgOrderProductionMgQuery)]
  136. public override async Task<OrderProduction> GetEntityById(int id)
  137. {
  138. return await Repository.FirstOrDefaultAsync(a=>a.Id==id);
  139. }
  140. /// <summary>
  141. /// 查询实体(需指明自定义字段)
  142. /// </summary>
  143. /// <param name="no"></param>
  144. /// <returns></returns>
  145. [DisableAuditing]
  146. //[AbpAuthorize(PermissionNames.PagesMgOrderProductionMgQuery)]
  147. public override async Task<OrderProduction> GetEntityByNo(string no)
  148. {
  149. //CheckGetPermission();
  150. if (string.IsNullOrEmpty(KeyFiledName))
  151. {
  152. ThrowError("NoKeyFieldName");
  153. }
  154. return await base.GetEntityByNo(no);
  155. }
  156. #endregion
  157. #region Hide
  158. ///// <summary>
  159. ///// 根据给定的<see cref="IwbPagedRequestDto"/>创建 <see cref="IQueryable{OrderProduction}"/>过滤查询.
  160. ///// </summary>
  161. ///// <param name="input">The input.</param>
  162. //protected override IQueryable<OrderProduction> CreateFilteredQuery(IwbPagedRequestDto input)
  163. //{
  164. // var query = Repository.GetAll();
  165. // var pagedInput = input as IIwbPagedRequest;
  166. // if (pagedInput == null)
  167. // {
  168. // return query;
  169. // }
  170. // if (!string.IsNullOrEmpty(pagedInput.KeyWords))
  171. // {
  172. // object keyWords = pagedInput.KeyWords;
  173. // LambdaObject obj = new LambdaObject()
  174. // {
  175. // FieldType = (LambdaFieldType)pagedInput.FieldType,
  176. // FieldName = pagedInput.KeyField,
  177. // FieldValue = keyWords,
  178. // ExpType = (LambdaExpType)pagedInput.ExpType
  179. // };
  180. // var exp = obj.GetExp<OrderProduction>();
  181. // query = exp != null ? query.Where(exp) : query;
  182. // }
  183. // if (pagedInput.SearchList != null && pagedInput.SearchList.Count > 0)
  184. // {
  185. // List<LambdaObject> objList = new List<LambdaObject>();
  186. // foreach (var o in pagedInput.SearchList)
  187. // {
  188. // if (string.IsNullOrEmpty(o.KeyWords))
  189. // continue;
  190. // object keyWords = o.KeyWords;
  191. // objList.Add(new LambdaObject
  192. // {
  193. // FieldType = (LambdaFieldType)o.FieldType,
  194. // FieldName = o.KeyField,
  195. // FieldValue = keyWords,
  196. // ExpType = (LambdaExpType)o.ExpType
  197. // });
  198. // }
  199. // var exp = objList.GetExp<OrderProduction>();
  200. // query = exp != null ? query.Where(exp) : query;
  201. // }
  202. // return query;
  203. //}
  204. //protected override IQueryable<OrderProduction> ApplySorting(IQueryable<OrderProduction> query, IwbPagedRequestDto input)
  205. //{
  206. // return query.OrderBy(a => a.No);
  207. //}
  208. //protected override IQueryable<OrderProduction> ApplyPaging(IQueryable<OrderProduction> query, IwbPagedRequestDto input)
  209. //{
  210. // if (input is IPagedResultRequest pagedInput)
  211. // {
  212. // return query.Skip(pagedInput.SkipCount).Take(pagedInput.MaxResultCount);
  213. // }
  214. // return query;
  215. //}
  216. #endregion
  217. #endregion
  218. }
  219. }