TprdProdSKUService.cs 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. using AutoMapper;
  2. using LinqKit;
  3. using Ropin.Inspection.Common.Accessor.Interface;
  4. using Ropin.Inspection.Model;
  5. using Ropin.Inspection.Model.Entities;
  6. using Ropin.Inspection.Repository;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Linq;
  10. using System.Linq.Expressions;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. namespace Ropin.Inspection.Service
  14. {
  15. public class TprdProdSKUService : ITprdProdSKUService
  16. {
  17. private readonly ITprdProdSKURepository _repository;
  18. private readonly IMapper _mapper;
  19. private readonly IClaimsAccessor _claims;
  20. public TprdProdSKUService(IClaimsAccessor claims, ITprdProdSKURepository repository, IMapper mapper)
  21. {
  22. _repository = repository;
  23. _mapper = mapper;
  24. _claims = claims;
  25. }
  26. public async Task CreateOneAsync(TprdProdSKUViewModel viewModel)
  27. {
  28. var content = _mapper.Map<TPRD_ProdSKU>(viewModel);
  29. content.C_SKUCode = Guid.NewGuid().ToString();
  30. content.C_CreateBy = _claims.ApiUserId;
  31. content.D_CreateOn = DateTime.Now;
  32. content.C_Status = "1";
  33. _repository.Create(content);
  34. var result = await _repository.SaveAsync();
  35. if (!result)
  36. {
  37. throw new Exception("创建失败");
  38. }
  39. }
  40. public async Task DeleteAsync(string id)
  41. {
  42. //var item = await _repository.GetByConditionAsync(i=>i.C_SKUCode == id);
  43. //var content = item.FirstOrDefault();
  44. var content = await _repository.GetByIdAsync(id);
  45. if (content == null)
  46. {
  47. throw new Exception("数据库中没有此数据");
  48. }
  49. content.C_LastUpdatedBy = _claims.ApiUserId;
  50. content.D_LastUpdatedOn = DateTime.Now;
  51. content.C_Status = "0";
  52. _repository.Update(content);
  53. var result = await _repository.SaveAsync();
  54. if (!result)
  55. {
  56. throw new Exception("删除失败");
  57. }
  58. }
  59. public async Task<IEnumerable<TprdProdSKUViewModel>> GetAllAsync()
  60. {
  61. var pagedList = await _repository.GetAllAsync();
  62. var contentDtoList = _mapper.Map<IEnumerable<TprdProdSKUViewModel>>(pagedList.Where(i => i.C_Status == "1").ToList());
  63. return contentDtoList.ToList();
  64. }
  65. public async Task<IEnumerable<TprdProdSKUViewModel>> GetConditionAsync(TprdProdSKUSearchModel searchModel)
  66. {
  67. var predicate = PredicateBuilder.New<TPRD_ProdSKU>(true);//查询条件,推荐后台使用这种方式灵活筛选
  68. #region 添加条件查询
  69. //predicate = predicate.And(i => i.C_Status.Equals("1"));
  70. if (null != searchModel.C_TypeCode && Guid.Empty.Equals(searchModel.C_TypeCode))
  71. {
  72. predicate = predicate.And(i => i.C_TypeCode.Equals(searchModel.C_TypeCode));
  73. }
  74. if (!string.IsNullOrEmpty(searchModel.C_Name))
  75. {
  76. predicate = predicate.And(i => i.C_Name.Contains(searchModel.C_Name));
  77. }
  78. if (!string.IsNullOrEmpty(searchModel.C_Spec))
  79. {
  80. predicate = predicate.And(i => i.C_Spec.Contains(searchModel.C_Spec));
  81. }
  82. if (!string.IsNullOrEmpty(searchModel.C_Brand))
  83. {
  84. predicate = predicate.And(i => i.C_Brand.Contains(searchModel.C_Brand));
  85. }
  86. if (!string.IsNullOrEmpty(searchModel.C_Vender))
  87. {
  88. predicate = predicate.And(i => i.C_Vender.Contains(searchModel.C_Vender));
  89. }
  90. if (!string.IsNullOrEmpty(searchModel.C_ProdArea))
  91. {
  92. predicate = predicate.And(i => i.C_ProdArea.Contains(searchModel.C_ProdArea));
  93. }
  94. #endregion
  95. var list = await _repository.GetPageAsync(predicate, "C_Name,-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
  96. searchModel.TotalCount = list.Totals;
  97. var dtoList = _mapper.Map<List<TPRD_ProdSKU>, List<TprdProdSKUViewModel>>(list.Rows);
  98. return dtoList;
  99. }
  100. public async Task<TprdProdSKUViewModel> GetByIdAsync(string id)
  101. {
  102. var item = await _repository.GetByConditionAsync(i => i.C_SKUCode == id);
  103. var content = item.FirstOrDefault();
  104. //var content = await _repository.GetByIdAsync(id);
  105. if (null == content)
  106. return null;
  107. var contentDto = _mapper.Map<TprdProdSKUViewModel>(content);
  108. return contentDto;
  109. }
  110. public async Task UpdateAsync(string id, TprdProdSKUUpdateModel updateModel)
  111. {
  112. var content = await _repository.GetByIdAsync(id);
  113. if (content == null)
  114. {
  115. throw new Exception("没有此数据");
  116. }
  117. content.C_LastUpdatedBy = _claims.ApiUserId;
  118. content.D_LastUpdatedOn = DateTime.Now;
  119. _mapper.Map(updateModel, content, typeof(TprdProdSKUUpdateModel), typeof(TPRD_ProdSKU));
  120. _repository.Update(content);
  121. var result = await _repository.SaveAsync();
  122. if (!result)
  123. {
  124. throw new Exception("更新失败");
  125. }
  126. }
  127. public Task<int> UpdateOneAsync(TprdProdSKUViewModel viewModel, params string[] fields)
  128. {
  129. throw new NotImplementedException();
  130. }
  131. public Task<bool> IsExistAsync(string id)
  132. {
  133. throw new NotImplementedException();
  134. }
  135. public Task<IEnumerable<TprdProdSKUViewModel>> GetByConditionAsync(Expression<Func<TprdProdSKUViewModel, bool>> expression)
  136. {
  137. throw new NotImplementedException();
  138. }
  139. }
  140. }