TdevDevSpotService.cs 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  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 TdevDevSpotService : ITdevDevSpotService
  17. {
  18. private readonly ITdevDevSpotRepository _repository;
  19. private readonly IUnitOfWork _unitOfWork;
  20. private readonly ITispSpotRepository _tispSpotRepository;
  21. private readonly IMapper _mapper;
  22. private readonly IClaimsAccessor _claims;
  23. public TdevDevSpotService(IClaimsAccessor claims, ITdevDevSpotRepository repository, IUnitOfWork unitOfWork, ITispSpotRepository tispSpotRepository, IMapper mapper)
  24. {
  25. _repository = repository;
  26. _unitOfWork = unitOfWork;
  27. _tispSpotRepository= tispSpotRepository;
  28. _mapper = mapper;
  29. _claims = claims;
  30. }
  31. public async Task CreateOneAsync(TdevDevSpotViewModel viewModel)
  32. {
  33. var content = _mapper.Map<TDEV_DevSpot>(viewModel);
  34. content.C_ID = Guid.NewGuid().ToString();
  35. content.C_CreateBy = _claims.ApiUserId;
  36. content.D_CreateOn = DateTime.Now;
  37. //content.C_Status = "1";
  38. _repository.Create(content);
  39. var result = await _repository.SaveAsync();
  40. if (!result)
  41. {
  42. throw new Exception("创建失败");
  43. }
  44. }
  45. public async Task DeleteAsync(Guid id)
  46. {
  47. var content = await _repository.GetByIdAsync(id);
  48. if (content == null)
  49. {
  50. throw new Exception("数据库中没有此数据");
  51. }
  52. //_repository.Delete(content);
  53. //var result = await _repository.SaveAsync();
  54. //content.C_LastUpdatedBy = _claims.ApiUserId;
  55. //content.D_LastUpdatedOn = DateTime.Now;
  56. //content.C_Status = "0";
  57. _repository.Update(content);
  58. var result = await _repository.SaveAsync();
  59. if (!result)
  60. {
  61. throw new Exception("删除失败");
  62. }
  63. }
  64. public async Task DeleteAsync(string code)
  65. {
  66. bool result = false;
  67. try
  68. {
  69. var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  70. var content = items.FirstOrDefault();
  71. if (content == null)
  72. {
  73. throw new Exception("没有此数据");
  74. }
  75. //content.C_LastUpdatedBy = _claims.ApiUserId;
  76. //content.D_LastUpdatedOn = DateTime.Now;
  77. //content.C_Status = "0";
  78. //_repository.Delete(content);
  79. //var result = await _repository.SaveAsync();
  80. Guid spotCode= new Guid(content.C_SpotCode);
  81. TISP_Spot tispSpot = await _tispSpotRepository.GetByIdAsync(spotCode);
  82. tispSpot.C_Status = "0";
  83. _unitOfWork.BeginTransaction();
  84. result = await _unitOfWork.RegisterDeleted(content);
  85. if (result)
  86. {
  87. result = await _unitOfWork.RegisterDirty(tispSpot);
  88. }
  89. if (!result)
  90. {
  91. throw new Exception("删除失败");
  92. }
  93. }
  94. catch
  95. {
  96. _unitOfWork.Rollback();
  97. throw;
  98. }
  99. finally
  100. {
  101. if (result)
  102. await _unitOfWork.CommitAsync();
  103. else
  104. _unitOfWork.Rollback();
  105. }
  106. }
  107. public async Task<IEnumerable<TdevDevSpotViewModel>> GetAllAsync()
  108. {
  109. var pagedList = await _repository.GetAllAsync();
  110. var contentDtoList = _mapper.Map<IEnumerable<TdevDevSpotViewModel>>(pagedList.ToList());
  111. return contentDtoList.ToList();
  112. }
  113. public async Task<IEnumerable<TdevDevSpotViewModel>> GetConditionAsync(TdevDevSpotSearchModel searchModel)
  114. {
  115. var predicate = PredicateBuilder.New<TDEV_DevSpot>(true);//查询条件,推荐后台使用这种方式灵活筛选
  116. #region 添加条件查询
  117. //predicate = predicate.And(i => i.C_Status.Equals("1"));
  118. if (!string.IsNullOrEmpty(searchModel.C_SpotCode))
  119. {
  120. predicate = predicate.And(i => i.C_SpotCode.Equals(searchModel.C_SpotCode));
  121. }
  122. if (!string.IsNullOrEmpty(searchModel.C_DevStoreCode))
  123. {
  124. predicate = predicate.And(i => i.C_DevStoreCode.Equals(searchModel.C_DevStoreCode));
  125. }
  126. if (!string.IsNullOrEmpty(searchModel.C_ID))
  127. {
  128. predicate = predicate.And(i => i.C_ID.Equals(searchModel.C_ID));
  129. }
  130. #endregion
  131. var list = await _repository.GetPageAsync(predicate, "-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
  132. searchModel.TotalCount = list.Totals;
  133. var dtoList = _mapper.Map<List<TDEV_DevSpot>, List<TdevDevSpotViewModel>>(list.Rows);
  134. return dtoList;
  135. }
  136. public async Task<TdevDevSpotViewModel> GetByIdAsync(Guid id)
  137. {
  138. var content = await _repository.GetByIdAsync(id);
  139. var contentDto = _mapper.Map<TdevDevSpotViewModel>(content);
  140. return contentDto;
  141. }
  142. public async Task UpdateAsync(string code, TdevDevSpotUpdateModel updateModel)
  143. {
  144. var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  145. var content = items.FirstOrDefault();
  146. if (content == null)
  147. {
  148. throw new Exception("没有此数据");
  149. }
  150. //content.C_LastUpdatedBy = _claims.ApiUserId;
  151. //content.D_LastUpdatedOn = DateTime.Now;
  152. _mapper.Map(updateModel, content, typeof(TdevDevSpotUpdateModel), typeof(TDEV_DevSpot));
  153. _repository.Update(content);
  154. var result = await _repository.SaveAsync();
  155. if (!result)
  156. {
  157. throw new Exception("更新失败");
  158. }
  159. }
  160. public async Task UpdateDevSpotAsync(TdevDevSpotsUpdateModel updateModel)
  161. {
  162. var result = false;
  163. //_unitOfWork.BeginTransaction();
  164. try
  165. {
  166. //MySqlConnector.MySqlParameter[] parameters = new[] { new MySqlConnector.MySqlParameter("DevStoreCode", updateModel.C_DevStoreCode) };
  167. //string sql = "DELETE from TDEV_DevSpot WHERE C_DevStoreCode = @DevStoreCode";
  168. //await _unitOfWork.ExecuteSqlCommandAsync(sql, parameters);
  169. await _repository.DeleteByDevIdAsync(updateModel.C_DevStoreCode);
  170. IList<TDEV_DevSpot> contentList = new List<TDEV_DevSpot>();
  171. if (null != updateModel.SpotCodeList)
  172. {
  173. foreach (var item in updateModel.SpotCodeList)
  174. {
  175. TDEV_DevSpot devspot = new TDEV_DevSpot();
  176. devspot.C_ID = Guid.NewGuid().ToString();
  177. devspot.C_Remark = updateModel.C_Remark;
  178. devspot.C_SpotCode = item;
  179. devspot.C_DevStoreCode = updateModel.C_DevStoreCode;
  180. devspot.C_CreateBy = _claims.ApiUserId;
  181. devspot.D_CreateOn = DateTime.Now;
  182. contentList.Add(devspot);
  183. }
  184. //result = await _unitOfWork.RegisterRangeNew(contentList);
  185. result = await _repository.CreateRangeAsync(contentList)>0;
  186. }
  187. }
  188. catch (Exception ex)
  189. {
  190. throw new Exception("创建失败");
  191. }
  192. finally
  193. {
  194. //if (result)
  195. // await _unitOfWork.CommitAsync();
  196. //else
  197. // _unitOfWork.Rollback();
  198. }
  199. //var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  200. //var content = items.FirstOrDefault();
  201. //if (content == null)
  202. //{
  203. // throw new Exception("没有此数据");
  204. //}
  205. ////content.C_LastUpdatedBy = _claims.ApiUserId;
  206. ////content.D_LastUpdatedOn = DateTime.Now;
  207. //foreach (var item in updateModel.SpotCodeList)
  208. //{
  209. // TDEV_DevSpot devSpot = new TDEV_DevSpot();
  210. //}
  211. //_mapper.Map(updateModel, content, typeof(TdevDevSpotUpdateModel), typeof(TDEV_DevSpot));
  212. //_repository.Update(content);
  213. //var result = await _repository.SaveAsync();
  214. //if (!result)
  215. //{
  216. // throw new Exception("更新失败");
  217. //}
  218. }
  219. public Task<int> UpdateOneAsync(TdevDevSpotViewModel viewModel, params string[] fields)
  220. {
  221. throw new NotImplementedException();
  222. }
  223. public Task<bool> IsExistAsync(Guid id)
  224. {
  225. throw new NotImplementedException();
  226. }
  227. public Task<IEnumerable<TdevDevSpotViewModel>> GetByConditionAsync(Expression<Func<TdevDevSpotViewModel, bool>> expression)
  228. {
  229. throw new NotImplementedException();
  230. }
  231. public Task UpdateAsync(string code, TpntAreaUpdateModel updateModel)
  232. {
  233. throw new NotImplementedException();
  234. }
  235. public Task<IEnumerable<TdevDevSpotViewModel>> GetConditionAsync(TpntAreaSearchModel searchModel)
  236. {
  237. throw new NotImplementedException();
  238. }
  239. }
  240. }