TpntStoreService.cs 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  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 Ropin.Inspection.Repository.Interface;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Linq;
  11. using System.Linq.Expressions;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. namespace Ropin.Inspection.Service
  15. {
  16. public class TpntStoreService : ITpntStoreService
  17. {
  18. private readonly ITpntStoreRepository _repository;
  19. private readonly ITpntStoreOrgRepository _storeOrgrepository;
  20. private readonly IUnitOfWork _unitOfWork;
  21. private readonly IMapper _mapper;
  22. private readonly IClaimsAccessor _claims;
  23. public TpntStoreService(IClaimsAccessor claims, ITpntStoreRepository repository, ITpntStoreOrgRepository storeOrgrepository, IUnitOfWork unitOfWork, IMapper mapper)
  24. {
  25. _repository = repository;
  26. _storeOrgrepository = storeOrgrepository;
  27. _unitOfWork = unitOfWork;
  28. _mapper = mapper;
  29. _claims = claims;
  30. }
  31. public async Task CreateOneAsync(TpntStoreViewModel viewModel)
  32. {
  33. var content = _mapper.Map<TPNT_Store>(viewModel);
  34. content.C_ID = Guid.NewGuid();
  35. content.C_Code = content.C_ID.ToString();
  36. content.C_CreateBy = _claims.ApiUserId;
  37. content.D_CreateOn = DateTime.Now;
  38. content.C_Status = "1";
  39. _repository.Create(content);
  40. var result = await _repository.SaveAsync();
  41. if (!result)
  42. {
  43. throw new Exception("创建失败");
  44. }
  45. }
  46. public async Task CreateStoreByOrgAsync(Guid orgCode, TpntStoreCreateModel viewModel)
  47. {
  48. var content = _mapper.Map<TPNT_Store>(viewModel);
  49. content.C_ID = Guid.NewGuid();
  50. content.C_Code = content.C_ID.ToString();
  51. content.C_CreateBy = _claims.ApiUserId;
  52. content.D_CreateOn = DateTime.Now;
  53. content.C_Status = "1";
  54. //_repository.Create(content);
  55. //var result = await _repository.SaveAsync();
  56. //_storeOrgrepository.Create(
  57. // new TPNT_StoreOrg { C_StoreCode = content.C_Code,
  58. // C_OrgCode = orgCode,C_CreateBy = _claims.ApiUserId,
  59. // D_CreateOn = DateTime.Now });
  60. //result = await _storeOrgrepository.SaveAsync();
  61. //if (!result)
  62. //{
  63. // throw new Exception("创建失败");
  64. //}
  65. bool bResult = false;
  66. try
  67. {
  68. _unitOfWork.BeginTransaction();
  69. bResult = await _unitOfWork.RegisterNew(content);
  70. var storeOrg = new TPNT_StoreOrg
  71. {
  72. C_StoreCode = content.C_Code,
  73. C_OrgCode = orgCode,
  74. C_Type = "1",
  75. C_CreateBy = _claims.ApiUserId,
  76. D_CreateOn = DateTime.Now
  77. };
  78. bResult = await _unitOfWork.RegisterNew(storeOrg);
  79. }
  80. catch
  81. {
  82. _unitOfWork.Rollback();
  83. throw ;
  84. }
  85. finally
  86. {
  87. if (bResult)
  88. await _unitOfWork.CommitAsync();
  89. else
  90. _unitOfWork.Rollback();
  91. }
  92. }
  93. public async Task AllotStoreByOrgAsync(Guid orgCode, Guid storeCode)
  94. {
  95. List<TPNT_StoreOrg> StoreOrgList = _storeOrgrepository.GetAll().Where(t => t.C_OrgCode == orgCode && t.C_StoreCode == storeCode.ToString()).ToList();
  96. if (StoreOrgList.Count > 0)
  97. {
  98. throw new Exception("该组织下已经分配了相同的业主!");
  99. }
  100. bool bResult = false;
  101. try
  102. {
  103. _unitOfWork.BeginTransaction();
  104. var storeOrg = new TPNT_StoreOrg
  105. {
  106. C_StoreCode = storeCode.ToString(),
  107. C_OrgCode = orgCode,
  108. C_Type = "2",
  109. C_CreateBy = _claims.ApiUserId,
  110. D_CreateOn = DateTime.Now
  111. };
  112. bResult = await _unitOfWork.RegisterNew(storeOrg);
  113. }
  114. catch
  115. {
  116. _unitOfWork.Rollback();
  117. throw;
  118. }
  119. finally
  120. {
  121. if (bResult)
  122. await _unitOfWork.CommitAsync();
  123. else
  124. _unitOfWork.Rollback();
  125. }
  126. }
  127. public async Task DeleteAsync(Guid id)
  128. {
  129. var content = await _repository.GetByIdAsync(id);
  130. if (content == null)
  131. {
  132. throw new Exception("数据库中没有此数据");
  133. }
  134. //_repository.Delete(content);
  135. //var result = await _repository.SaveAsync();
  136. content.C_LastUpdatedBy = _claims.ApiUserId;
  137. content.D_LastUpdatedOn = DateTime.Now;
  138. content.C_Status = "0";
  139. _repository.Update(content);
  140. var result = await _repository.SaveAsync();
  141. if (!result)
  142. {
  143. throw new Exception("删除失败");
  144. }
  145. }
  146. public async Task<IEnumerable<TpntStoreViewModel>> GetAllAsync()
  147. {
  148. var pagedList = await _repository.GetAllAsync();
  149. var contentDtoList = _mapper.Map<IEnumerable<TpntStoreViewModel>>(pagedList.Where(i => i.C_Status == "1").ToList());
  150. return contentDtoList.ToList();
  151. }
  152. public async Task<IEnumerable<TpntStoreViewModel>> GetConditionAsync(TpntStoreSearchModel searchModel)
  153. {
  154. var predicate = PredicateBuilder.New<TPNT_Store>(true);//查询条件,推荐后台使用这种方式灵活筛选
  155. #region 添加条件查询
  156. predicate = predicate.And(i => i.C_Status.Equals("1"));
  157. if (!string.IsNullOrEmpty(searchModel.C_Name))
  158. {
  159. predicate = predicate.And(i => i.C_Name.Contains(searchModel.C_Name));
  160. }
  161. #endregion
  162. var list = await _repository.GetPageAsync(predicate, "C_Name,-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
  163. searchModel.TotalCount = list.Totals;
  164. var dtoList = _mapper.Map<List<TPNT_Store>, List<TpntStoreViewModel>>(list.Rows);
  165. return dtoList;
  166. }
  167. public async Task<TpntStoreViewModel> GetByIdAsync(Guid id)
  168. {
  169. var content = await _repository.GetByIdAsync(id);
  170. var contentDto = _mapper.Map<TpntStoreViewModel>(content);
  171. return contentDto;
  172. }
  173. public async Task UpdateAsync(Guid id, TpntStoreUpdateModel updateModel)
  174. {
  175. var content = await _repository.GetByIdAsync(id);
  176. if (content == null)
  177. {
  178. throw new Exception("没有此数据");
  179. }
  180. content.C_LastUpdatedBy = _claims.ApiUserId;
  181. content.D_LastUpdatedOn = DateTime.Now;
  182. _mapper.Map(updateModel, content, typeof(TpntStoreUpdateModel), typeof(TPNT_Store));
  183. _repository.Update(content);
  184. var result = await _repository.SaveAsync();
  185. if (!result)
  186. {
  187. throw new Exception("更新失败");
  188. }
  189. }
  190. public Task<IList<TpntTypeViewModel>> GetAllPntType()
  191. {
  192. var v = _repository.GetAllPntType();
  193. var list = _mapper.Map<IList<TpntTypeViewModel>>(v);
  194. return Task.FromResult(list);
  195. }
  196. public Task<TpntStoreViewModel> GetStoreByCodeAsync(string code)
  197. {
  198. return _repository.GetStoreByCodeAsync(code);
  199. }
  200. public Task<int> UpdateOneAsync(TpntStoreViewModel viewModel, params string[] fields)
  201. {
  202. throw new NotImplementedException();
  203. }
  204. public Task<bool> IsExistAsync(Guid id)
  205. {
  206. throw new NotImplementedException();
  207. }
  208. public Task<IEnumerable<TpntStoreViewModel>> GetByConditionAsync(Expression<Func<TpntStoreViewModel, bool>> expression)
  209. {
  210. throw new NotImplementedException();
  211. }
  212. }
  213. }