LargeScreenControlService.cs 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. using AutoMapper;
  2. using Ropin.Inspection.Common.Accessor.Interface;
  3. using Ropin.Inspection.Model.Entities;
  4. using Ropin.Inspection.Model.SearchModel.LGS;
  5. using Ropin.Inspection.Model.ViewModel.LGS;
  6. using Ropin.Inspection.Repository.LGS.Interface;
  7. using Ropin.Inspection.Service.LGS.Interface;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. namespace Ropin.Inspection.Service.LGS
  14. {
  15. public class LargeScreenControlService: ILargeScreenControlService
  16. {
  17. private readonly ILargeScreenControlRepository _repository;
  18. private readonly IMapper _mapper;
  19. private readonly IClaimsAccessor _claims;
  20. private readonly InspectionDbContext _sqlDBContext;
  21. public LargeScreenControlService(IClaimsAccessor claims, InspectionDbContext sqlDBContext, ILargeScreenControlRepository repository, IMapper mapper)
  22. {
  23. _repository = repository;
  24. _mapper = mapper;
  25. _claims = claims;
  26. _sqlDBContext = sqlDBContext;
  27. }
  28. public async Task<IEnumerable<LargeScreenControlViewModel>> GetConditionAsync(LargeScreenControlSearch searchModel)
  29. {
  30. var list = await _repository.GetConditionAsync(searchModel);
  31. return list;
  32. }
  33. public async Task CreateOneAsync(LargeScreenControlViewModel viewModel)
  34. {
  35. var content = _mapper.Map<TLGS_LargeScreenControl>(viewModel);
  36. content.C_ID = Guid.NewGuid().ToString();
  37. content.C_CreateBy = _claims.ApiUserId.ToString();
  38. content.C_Creator = _claims.ApiUserName;
  39. content.D_CreateOn = DateTime.Now;
  40. content.C_Status = "1";
  41. _repository.Create(content);
  42. var result = await _repository.SaveAsync();
  43. if (!result)
  44. {
  45. throw new Exception("创建失败");
  46. }
  47. }
  48. public async Task UpdateAsync(LargeScreenControlViewModel viewModel, string Id)
  49. {
  50. var content = await _repository.GetByIdAsync(Id);
  51. if (content == null)
  52. {
  53. throw new Exception("没有此数据");
  54. }
  55. _mapper.Map(viewModel, content, typeof(LargeScreenControlViewModel), typeof(TLGS_LargeScreenControl));
  56. content.C_LastUpdatedBy = _claims.Linsence == null ? _claims.ApiUserId.ToString() : "6e864cbc-5252-11ec-8681-fa163e02b3e4";
  57. content.D_LastUpdatedOn = DateTime.Now;
  58. content.C_Modifier = _claims.ApiUserName;
  59. _repository.Update(content);
  60. var result = await _repository.SaveAsync();
  61. if (!result)
  62. {
  63. throw new Exception("更新失败");
  64. }
  65. }
  66. public async Task SaveAsync(List<LargeScreenControlViewModel> viewModel)
  67. {
  68. try
  69. {
  70. foreach (var item in viewModel)
  71. {
  72. if (string.IsNullOrEmpty(item.C_ID))
  73. {
  74. var content = _mapper.Map<TLGS_LargeScreenControl>(item);
  75. content.C_ID = Guid.NewGuid().ToString();
  76. content.C_CreateBy = _claims.ApiUserId.ToString();
  77. content.C_Creator = _claims.ApiUserName;
  78. content.D_CreateOn = DateTime.Now;
  79. content.C_Status = "1";
  80. _repository.Create(content);
  81. }
  82. else
  83. {
  84. var content = await _repository.GetByIdAsync(item.C_ID);
  85. if (content == null)
  86. {
  87. throw new Exception("没有此数据");
  88. }
  89. _mapper.Map(item, content, typeof(LargeScreenControlViewModel), typeof(TLGS_LargeScreenControl));
  90. content.C_LastUpdatedBy = _claims.Linsence == null ? _claims.ApiUserId.ToString() : "6e864cbc-5252-11ec-8681-fa163e02b3e4";
  91. content.D_LastUpdatedOn = DateTime.Now;
  92. content.C_Modifier = _claims.ApiUserName;
  93. _repository.Update(content);
  94. }
  95. }
  96. var result = await _repository.SaveAsync();
  97. if (!result)
  98. {
  99. throw new Exception("创建失败");
  100. }
  101. }
  102. catch (Exception ex)
  103. {
  104. throw new Exception("创建异常");
  105. }
  106. }
  107. public async Task DeleteAsync(string id)
  108. {
  109. var content = await _repository.GetByIdAsync(id);
  110. if (content == null)
  111. {
  112. throw new Exception("数据库中没有此数据");
  113. }
  114. content.C_LastUpdatedBy = _claims.ApiUserId.ToString();
  115. content.D_LastUpdatedOn = DateTime.Now;
  116. content.C_Modifier = _claims.ApiUserName;
  117. content.C_Status = "0";
  118. _repository.Update(content);
  119. var result = await _repository.SaveAsync();
  120. if (!result)
  121. {
  122. throw new Exception("删除失败");
  123. }
  124. }
  125. public async Task DeleteByLargeScreenCodeAsync(string LargeScreenCode)
  126. {
  127. var content=await _repository.GetByConditionAsync(t=>t.C_LargeScreenCode == LargeScreenCode);
  128. if (content!=null&& content.Count()>0)
  129. {
  130. var result = await _repository.DeleteByLargeScreenCodeAsync(LargeScreenCode);
  131. if (!result)
  132. {
  133. throw new Exception("删除失败");
  134. }
  135. }
  136. }
  137. public async Task<LargeScreenControlViewModel> GetByIdAsync(string id)
  138. {
  139. LargeScreenControlSearch searchModel = new LargeScreenControlSearch();
  140. searchModel.IsPagination = false;
  141. searchModel.C_ID = id;
  142. var list = await _repository.GetConditionAsync(searchModel);
  143. return list?.FirstOrDefault();
  144. }
  145. public Task<bool> IsExistAsync(string id)
  146. {
  147. throw new NotImplementedException();
  148. }
  149. public Task<int> UpdateOneAsync(LargeScreenControlViewModel viewModel, params string[] fields)
  150. {
  151. throw new NotImplementedException();
  152. }
  153. }
  154. }