PerformancesApplicationService.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.Entity;
  4. using System.Linq;
  5. using System.Threading.Tasks;
  6. using System.Web.Mvc;
  7. using Abp.Application.Services.Dto;
  8. using Abp.Auditing;
  9. using Abp.Authorization;
  10. using Abp.Domain.Repositories;
  11. using Abp.Runtime.Caching;
  12. using IwbZero.AppServiceBase;
  13. using IwbZero.Auditing;
  14. using ShwasherSys.Authorization.Permissions;
  15. using ShwasherSys.CompanyInfo.Performance.Dto;
  16. using ShwasherSys.Lambda;
  17. namespace ShwasherSys.CompanyInfo.Performance
  18. {
  19. [AbpAuthorize]
  20. public class PerformanceAppService : IwbZeroAsyncCrudAppService<EmployeeWorkPerformance, PerformanceDto, int, IwbPagedRequestDto, PerformanceCreateDto, PerformanceUpdateDto >, IPerformanceAppService
  21. {
  22. public PerformanceAppService(
  23. ICacheManager cacheManager,
  24. IRepository<EmployeeWorkPerformance, int> repository) : base(repository, "PerformanceNo")
  25. {
  26. CacheManager = cacheManager;
  27. }
  28. protected override bool KeyIsAuto { get; set; } = false;
  29. #region GetSelect
  30. [DisableAuditing]
  31. public override async Task<List<SelectListItem>> GetSelectList()
  32. {
  33. var list = await Repository.GetAllListAsync();
  34. var sList = new List<SelectListItem> {new SelectListItem {Text = @"请选择...", Value = "", Selected = true}};
  35. foreach (var l in list)
  36. {
  37. //sList.Add(new SelectListItem { Value = l.Id, Text = l. });
  38. }
  39. return sList;
  40. }
  41. [DisableAuditing]
  42. public override async Task<string> GetSelectStr()
  43. {
  44. var list = await Repository.GetAllListAsync();
  45. string str = "<option value=\"\" selected>请选择...</option>";
  46. foreach (var l in list)
  47. {
  48. //str += $"<option value=\"{l.Id}\">{l.}</option>";
  49. }
  50. return str;
  51. }
  52. #endregion
  53. #region CURD
  54. // [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceCreate)]
  55. public override async Task Create(PerformanceCreateDto input)
  56. {
  57. await CreateEntity(input);
  58. }
  59. // [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceUpdate)]
  60. public override async Task Update(PerformanceUpdateDto input)
  61. {
  62. await UpdateEntity(input);
  63. }
  64. // [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceDelete)]
  65. public override Task Delete(EntityDto<int> input)
  66. {
  67. return Repository.DeleteAsync(input.Id);
  68. }
  69. [DisableAuditing]
  70. [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceQuery)]
  71. public override async Task<PagedResultDto<PerformanceDto>> GetAll(IwbPagedRequestDto input)
  72. {
  73. var query = CreateFilteredQuery(input);
  74. var totalCount = await AsyncQueryableExecuter.CountAsync(query);
  75. query = ApplySorting(query, input);
  76. query = ApplyPaging(query, input);
  77. var entities = await AsyncQueryableExecuter.ToListAsync(query);
  78. var dtoList = new PagedResultDto<PerformanceDto>(totalCount, entities.Select(a=>new PerformanceDto()
  79. {
  80. Id = a.Id,
  81. PerformanceNo = a.PerformanceNo,
  82. ProductOrderNo = a.ProductOrderNo,
  83. EmployeeId = a.EmployeeId,
  84. EmployeeNo = a.EmployeeInfo.No,
  85. EmployeeName = a.EmployeeInfo.Name,
  86. Performance = a.Performance??0,
  87. PerformanceUnit = a.PerformanceUnit,
  88. PerformanceDesc = a.PerformanceDesc,
  89. WorkType = a.WorkType,
  90. RelatedNo = a.RelatedNo,
  91. CreationTime =a.CreationTime
  92. }).ToList());
  93. return dtoList;
  94. }
  95. #region GetEntity/Dto
  96. /// <summary>
  97. /// 查询实体Dto
  98. /// </summary>
  99. /// <param name="input"></param>
  100. /// <returns></returns>
  101. [DisableAuditing]
  102. [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceQuery)]
  103. public override async Task<PerformanceDto> GetDto(EntityDto<int> input)
  104. {
  105. var entity = await GetEntity(input);
  106. return MapToEntityDto(entity);
  107. }
  108. /// <summary>
  109. /// 查询实体Dto
  110. /// </summary>
  111. /// <param name="id"></param>
  112. /// <returns></returns>
  113. [DisableAuditing]
  114. [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceQuery)]
  115. public override async Task<PerformanceDto> GetDtoById(int id)
  116. {
  117. var entity = await GetEntityById(id);
  118. return MapToEntityDto(entity);
  119. }
  120. /// <summary>
  121. /// 查询实体Dto(需指明自定义字段)
  122. /// </summary>
  123. /// <param name="no"></param>
  124. /// <returns></returns>
  125. [DisableAuditing]
  126. [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceQuery)]
  127. public override async Task<PerformanceDto> GetDtoByNo(string no)
  128. {
  129. var entity = await GetEntityByNo(no);
  130. return MapToEntityDto(entity);
  131. }
  132. /// <summary>
  133. /// 查询实体
  134. /// </summary>
  135. /// <param name="input"></param>
  136. /// <returns></returns>
  137. [DisableAuditing]
  138. [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceQuery)]
  139. public override async Task<EmployeeWorkPerformance> GetEntity(EntityDto<int> input)
  140. {
  141. var entity = await GetEntityById(input.Id);
  142. return entity;
  143. }
  144. /// <summary>
  145. /// 查询实体
  146. /// </summary>
  147. /// <param name="id"></param>
  148. /// <returns></returns>
  149. [DisableAuditing]
  150. [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceQuery)]
  151. public override async Task<EmployeeWorkPerformance> GetEntityById(int id)
  152. {
  153. return await Repository.FirstOrDefaultAsync(a=>a.Id==id);
  154. }
  155. /// <summary>
  156. /// 查询实体(需指明自定义字段)
  157. /// </summary>
  158. /// <param name="no"></param>
  159. /// <returns></returns>
  160. [DisableAuditing]
  161. [AbpAuthorize(PermissionNames.PagesCompanyEmployeePerformanceQuery)]
  162. public override async Task<EmployeeWorkPerformance> GetEntityByNo(string no)
  163. {
  164. //CheckGetPermission();
  165. if (string.IsNullOrEmpty(KeyFiledName))
  166. {
  167. ThrowError("NoKeyFieldName");
  168. }
  169. return await base.GetEntityByNo(no);
  170. }
  171. #endregion
  172. #region Hide
  173. /// <summary>
  174. /// 根据给定的<see cref="IwbPagedRequestDto"/>创建 <see cref="IQueryable{EmployeeWorkPerformance}"/>过滤查询.
  175. /// </summary>
  176. /// <param name="input">The input.</param>
  177. protected override IQueryable<EmployeeWorkPerformance> CreateFilteredQuery(IwbPagedRequestDto input)
  178. {
  179. var query = Repository.GetAllIncluding(a=>a.EmployeeInfo);
  180. var pagedInput = input as IIwbPagedRequest;
  181. if (pagedInput == null)
  182. {
  183. return query;
  184. }
  185. if (!string.IsNullOrEmpty(pagedInput.KeyWords))
  186. {
  187. object keyWords = pagedInput.KeyWords;
  188. LambdaObject obj = new LambdaObject()
  189. {
  190. FieldType = (LambdaFieldType)pagedInput.FieldType,
  191. FieldName = pagedInput.KeyField,
  192. FieldValue = keyWords,
  193. ExpType = (LambdaExpType)pagedInput.ExpType
  194. };
  195. var exp = obj.GetExp<EmployeeWorkPerformance>();
  196. query = exp != null ? query.Where(exp) : query;
  197. }
  198. if (pagedInput.SearchList != null && pagedInput.SearchList.Count > 0)
  199. {
  200. List<LambdaObject> objList = new List<LambdaObject>();
  201. foreach (var o in pagedInput.SearchList)
  202. {
  203. if (string.IsNullOrEmpty(o.KeyWords))
  204. continue;
  205. if (o.KeyField.ToLower() == "employeeno")
  206. {
  207. query = query.Where(a => a.EmployeeInfo.No.Contains(o.KeyWords));
  208. continue;
  209. }
  210. if (o.KeyField.ToLower() == "employeename")
  211. {
  212. query = query.Where(a => a.EmployeeInfo.Name.Contains(o.KeyWords));
  213. continue;
  214. }
  215. object keyWords = o.KeyWords;
  216. objList.Add(new LambdaObject
  217. {
  218. FieldType = (LambdaFieldType)o.FieldType,
  219. FieldName = o.KeyField,
  220. FieldValue = keyWords,
  221. ExpType = (LambdaExpType)o.ExpType
  222. });
  223. }
  224. var exp = objList.GetExp<EmployeeWorkPerformance>();
  225. query = exp != null ? query.Where(exp) : query;
  226. }
  227. return query;
  228. }
  229. //protected override IQueryable<EmployeeWorkPerformance> ApplySorting(IQueryable<EmployeeWorkPerformance> query, IwbPagedRequestDto input)
  230. //{
  231. // return query.OrderBy(a => a.No);
  232. //}
  233. //protected override IQueryable<EmployeeWorkPerformance> ApplyPaging(IQueryable<EmployeeWorkPerformance> query, IwbPagedRequestDto input)
  234. //{
  235. // if (input is IPagedResultRequest pagedInput)
  236. // {
  237. // return query.Skip(pagedInput.SkipCount).Take(pagedInput.MaxResultCount);
  238. // }
  239. // return query;
  240. //}
  241. #endregion
  242. #endregion
  243. [AuditLog("员工绩效查询")]
  244. public async Task<string> PerformanceTotalQuery(PerformanceTotalQueryDto input)
  245. {
  246. DateTime startDate, endDate;
  247. if (input.Month == null)
  248. {
  249. startDate= new DateTime(input.Year,1,1);
  250. endDate = startDate.AddYears(1);
  251. }
  252. else
  253. {
  254. startDate= new DateTime(input.Year,input.Month??0,1);
  255. endDate = startDate.AddMonths(1);
  256. }
  257. var query = Repository.GetAll().Where(a =>
  258. a.EmployeeId == input.EmployeeId && a.WorkType == input.WorkType && a.CreationTime >= startDate &&
  259. a.CreationTime < endDate);
  260. var total =await query.SumAsync(a => a.Performance);
  261. return total + "";
  262. }
  263. }
  264. }