TdevBoxDevSpotService.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. using AutoMapper;
  2. using LinqKit;
  3. using Microsoft.AspNetCore.Mvc;
  4. using Microsoft.AspNetCore.NodeServices;
  5. using Microsoft.EntityFrameworkCore;
  6. using Newtonsoft.Json;
  7. using Ropin.Core.Common;
  8. using Ropin.Inspection.Common;
  9. using Ropin.Inspection.Common.Accessor.Interface;
  10. using Ropin.Inspection.Common.Helper;
  11. using Ropin.Inspection.Model;
  12. using Ropin.Inspection.Model.Entities;
  13. using Ropin.Inspection.Repository;
  14. using Ropin.Inspection.Repository.Interface;
  15. using System;
  16. using System.Collections.Generic;
  17. using System.ComponentModel;
  18. using System.ComponentModel.DataAnnotations;
  19. using System.Drawing;
  20. using System.IO;
  21. using System.Linq;
  22. using System.Linq.Expressions;
  23. using System.Reflection;
  24. using System.Text;
  25. using System.Threading.Tasks;
  26. using System.Xml.Linq;
  27. using static System.Net.Mime.MediaTypeNames;
  28. namespace Ropin.Inspection.Service
  29. {
  30. public class TdevBoxDevSpotService : ITdevBoxDevSpotService
  31. {
  32. private readonly ITdevBoxDevSpotRepository _repository;
  33. private readonly IMapper _mapper;
  34. private readonly IClaimsAccessor _claims;
  35. private readonly InspectionDbContext _sqlDBContext;
  36. private readonly ITmtnDevOpsRecordRepository _tmtnDevOpsRecordRepository;
  37. public TdevBoxDevSpotService(ITmtnDevOpsRecordRepository tmtnDevOpsRecordRepository,IClaimsAccessor claims, InspectionDbContext sqlDBContext, ITdevBoxDevSpotRepository repository, IMapper mapper)
  38. {
  39. _repository = repository;
  40. _mapper = mapper;
  41. _claims = claims;
  42. _sqlDBContext = sqlDBContext;
  43. _tmtnDevOpsRecordRepository = tmtnDevOpsRecordRepository;
  44. }
  45. public async Task CreateOneAsync(TdevBoxDevSpotViewModel viewModel)
  46. {
  47. var item = await _repository.GetByConditionAsync(C => C.C_ChineseName == viewModel.C_ChineseName&&C.C_BoxCode==viewModel.C_BoxCode);
  48. if (item.FirstOrDefault() != null)
  49. {
  50. throw new Exception("中文名已被占用");
  51. }
  52. var id = Guid.NewGuid().ToString();
  53. var content = _mapper.Map<TDEV_BoxDevSpot>(viewModel);
  54. content.C_ID = id;
  55. content.C_CreateBy = _claims.ApiUserId;
  56. content.D_CreateOn = DateTime.Now;
  57. content.C_DevSpotCode= Guid.NewGuid().ToString();
  58. if (string.IsNullOrEmpty(content.C_DevSpotCode))
  59. {
  60. content.C_DevSpotCode = id;
  61. }
  62. content.C_Status = "1";
  63. _repository.Create(content);
  64. var result = await _repository.SaveAsync();
  65. if (!result)
  66. {
  67. throw new Exception("创建失败");
  68. }
  69. }
  70. public async Task DeleteAsync(string id)
  71. {
  72. var content = await _repository.GetByIdAsync(id);
  73. if (content == null)
  74. {
  75. throw new Exception("数据库中没有此数据");
  76. }
  77. content.C_LastUpdatedBy = _claims.ApiUserId;
  78. content.D_LastUpdatedOn = DateTime.Now;
  79. content.C_Status = "0";
  80. _repository.Update(content);
  81. var result = await _repository.SaveAsync();
  82. if (!result)
  83. {
  84. throw new Exception("删除失败");
  85. }
  86. }
  87. public async Task UpdateAsync(string code, TdevBoxDevSpotUpdateModel updateModel)
  88. {
  89. var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  90. var content = items.FirstOrDefault();
  91. if (content == null)
  92. {
  93. throw new Exception("没有此数据");
  94. }
  95. if (content.C_ChineseName != updateModel.C_ChineseName)
  96. {
  97. var item = await _repository.GetByConditionAsync(C => C.C_ChineseName == updateModel.C_ChineseName && C.C_BoxCode == updateModel.C_BoxCode&& C.C_ID != code);
  98. if (item.FirstOrDefault() != null)
  99. {
  100. throw new Exception("中文名已被占用");
  101. }
  102. }
  103. content.C_LastUpdatedBy = _claims.Linsence == null ? _claims.ApiUserId : Guid.Parse("6e864cbc-5252-11ec-8681-fa163e02b3e4");
  104. content.D_LastUpdatedOn = DateTime.Now;
  105. _mapper.Map(updateModel, content, typeof(TdevBoxDevSpotViewModel), typeof(TDEV_BoxDevSpot));
  106. _repository.Update(content);
  107. var result = await _repository.SaveAsync();
  108. if (!result)
  109. {
  110. throw new Exception("更新失败");
  111. }
  112. }
  113. public async Task<IEnumerable<TdevBoxDevSpotViewModel>> GetConditionAsync(TdevBoxDevSpotSearchModel searchModel)
  114. {
  115. var predicate = PredicateBuilder.New<TDEV_BoxDevSpot>(true);//查询条件,推荐后台使用这种方式灵活筛选
  116. #region 添加条件查询
  117. if (!string.IsNullOrEmpty(searchModel.C_Status))
  118. {
  119. if (searchModel.C_Status!="2")
  120. {
  121. predicate = predicate.And(i => i.C_Status.Equals(searchModel.C_Status));
  122. }
  123. }
  124. else
  125. {
  126. predicate = predicate.And(i => !i.C_Status.Equals("0"));
  127. }
  128. if (!string.IsNullOrEmpty(searchModel.C_ID))
  129. {
  130. predicate = predicate.And(i => i.C_ID.Equals(searchModel.C_ID));
  131. }
  132. if (!string.IsNullOrEmpty(searchModel.C_BoxCode))
  133. {
  134. predicate = predicate.And(i => i.C_BoxCode.Equals(searchModel.C_BoxCode));
  135. }
  136. if (!string.IsNullOrEmpty(searchModel.C_DevSpotCode))
  137. {
  138. predicate = predicate.And(i => i.C_DevSpotCode == searchModel.C_DevSpotCode);
  139. }
  140. if (!string.IsNullOrEmpty(searchModel.C_ChineseName))
  141. {
  142. predicate = predicate.And(i => i.C_ChineseName.Contains(searchModel.C_ChineseName));
  143. }
  144. #endregion
  145. var list = await _repository.GetPageAsync(predicate, "C_ChineseName,-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
  146. searchModel.TotalCount = list.Totals;
  147. var dtoList = _mapper.Map<List<TDEV_BoxDevSpot>, List<TdevBoxDevSpotViewModel>>(list.Rows);
  148. return dtoList;
  149. }
  150. public Task<int> UpdateOneAsync(TdevBoxDevSpotViewModel viewModel, params string[] fields)
  151. {
  152. throw new NotImplementedException();
  153. }
  154. public Task<TdevBoxDevSpotViewModel> GetByIdAsync(string id)
  155. {
  156. throw new NotImplementedException();
  157. }
  158. public Task<bool> IsExistAsync(string id)
  159. {
  160. throw new NotImplementedException();
  161. }
  162. }
  163. }