TmtnDevOperateRecordService.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. using AutoMapper;
  2. using Google.Protobuf;
  3. using LinqKit;
  4. using Microsoft.EntityFrameworkCore;
  5. using Newtonsoft.Json;
  6. using Ropin.Inspection.Common.Accessor.Interface;
  7. using Ropin.Inspection.Model;
  8. using Ropin.Inspection.Model.Entities;
  9. using Ropin.Inspection.Model.ViewModel;
  10. using Ropin.Inspection.Repository;
  11. using Ropin.Inspection.Repository.Interface;
  12. using System;
  13. using System.Collections.Generic;
  14. using System.Linq;
  15. using System.Linq.Expressions;
  16. using System.Text;
  17. using System.Threading.Tasks;
  18. namespace Ropin.Inspection.Service
  19. {
  20. public class TmtnDevOperateRecordService : ITmtnDevOperateRecordService
  21. {
  22. private readonly ITmtnDevOperateRecordRepository _repository;
  23. private readonly IMapper _mapper;
  24. private readonly IClaimsAccessor _claims;
  25. private readonly InspectionDbContext _sqlDBContext;
  26. public TmtnDevOperateRecordService(InspectionDbContext sqlDBContext, IClaimsAccessor claims, ITmtnDevOperateRecordRepository repository, IMapper mapper)
  27. {
  28. _repository = repository;
  29. _mapper = mapper;
  30. _claims = claims;
  31. _sqlDBContext = sqlDBContext;
  32. }
  33. public async Task<RepairStatistics> GetDevOpsStatisticsAsync(string storeCode)
  34. {
  35. return await _repository.GetDevOpsStatisticsAsync(storeCode);
  36. }
  37. public async Task<IEnumerable<FullScreenRecordItem>> GetDevOpsStatisticsFullScreenAsync(string storeCode)
  38. {
  39. RepairStatistics repair = await _repository.GetDevOpsStatisticsAsync(storeCode);
  40. if (null == repair)
  41. {
  42. return new FullScreenRecordItem[0];
  43. }
  44. IEnumerable<FullScreenRecordItem> fullScreenRecordItems = new FullScreenRecordItem[5] {
  45. new FullScreenRecordItem
  46. {
  47. x = "取消维保",
  48. y = Convert.ToString(repair.Cancel)
  49. }
  50. ,
  51. new FullScreenRecordItem
  52. {
  53. x = "确认维保",
  54. y = Convert.ToString(repair.Confirm)
  55. }
  56. ,
  57. new FullScreenRecordItem
  58. {
  59. x = "完成维保",
  60. y = Convert.ToString(repair.Complete)
  61. }
  62. ,
  63. new FullScreenRecordItem
  64. {
  65. x = "审批中",
  66. y = Convert.ToString(repair.Approval)
  67. }
  68. ,
  69. new FullScreenRecordItem
  70. {
  71. x = "正在维保",
  72. y = Convert.ToString(repair.RepairOn)
  73. }
  74. };
  75. return await Task.FromResult(fullScreenRecordItems);
  76. }
  77. public async Task CreateOneAsync(TmtnDevOperateRecordViewModel viewModel)
  78. {
  79. var content = _mapper.Map<TMTN_DevOperateRecord>(viewModel);
  80. content.C_ID = Guid.NewGuid().ToString();
  81. content.C_CreateBy = _claims.ApiUserId;
  82. content.D_CreateOn = DateTime.Now;
  83. content.C_Status = "1";
  84. _repository.Create(content);
  85. var result = await _repository.SaveAsync();
  86. if (!result)
  87. {
  88. throw new Exception("创建失败");
  89. }
  90. }
  91. public async Task DeleteAsync(Guid id)
  92. {
  93. var content = await _repository.GetByIdAsync(id);
  94. if (content == null)
  95. {
  96. throw new Exception("数据库中没有此数据");
  97. }
  98. //_repository.Delete(content);
  99. //var result = await _repository.SaveAsync();
  100. content.C_LastUpdatedBy = _claims.ApiUserId;
  101. content.D_LastUpdatedOn = DateTime.Now;
  102. content.C_Status = "0";
  103. _repository.Update(content);
  104. var result = await _repository.SaveAsync();
  105. if (!result)
  106. {
  107. throw new Exception("删除失败");
  108. }
  109. }
  110. public async Task DeleteAsync(string code)
  111. {
  112. var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  113. var content = items.FirstOrDefault();
  114. if (content == null)
  115. {
  116. throw new Exception("没有此数据");
  117. }
  118. content.C_LastUpdatedBy = _claims.ApiUserId;
  119. content.D_LastUpdatedOn = DateTime.Now;
  120. content.C_Status = "0";
  121. _repository.Update(content);
  122. var result = await _repository.SaveAsync();
  123. if (!result)
  124. {
  125. throw new Exception("删除失败");
  126. }
  127. }
  128. public async Task<IEnumerable<TmtnDevOperateRecordViewModel>> GetAllAsync()
  129. {
  130. var pagedList = await _repository.GetAllAsync();
  131. var contentDtoList = _mapper.Map<IEnumerable<TmtnDevOperateRecordViewModel>>(pagedList.Where(i => i.C_Status == "1").ToList());
  132. return contentDtoList.ToList();
  133. }
  134. public async Task<IEnumerable<TmtnDevOperateRecordViewModel>> GetConditionAsync(TmtnDevOperateRecordSearchModel searchModel)
  135. {
  136. var predicate = PredicateBuilder.New<TMTN_DevOperateRecord>(true);//查询条件,推荐后台使用这种方式灵活筛选
  137. #region 添加条件查询
  138. //predicate = predicate.And(i => i.C_Status.Equals("1"));
  139. if (!string.IsNullOrEmpty(searchModel.C_SpotCode))
  140. {
  141. predicate = predicate.And(i => i.C_SpotCode.Equals(searchModel.C_SpotCode));
  142. }
  143. if (!string.IsNullOrEmpty(searchModel.C_ID))
  144. {
  145. predicate = predicate.And(i => i.C_ID.Equals(searchModel.C_ID));
  146. }
  147. if (!string.IsNullOrEmpty(searchModel.C_Record))
  148. {
  149. predicate = predicate.And(i => i.C_Record.Contains(searchModel.C_Record));
  150. }
  151. #endregion
  152. var list = await _repository.GetPageAsync(predicate, "C_Name,-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
  153. searchModel.TotalCount = list.Totals;
  154. var dtoList = _mapper.Map<List<TMTN_DevOperateRecord>, List<TmtnDevOperateRecordViewModel>>(list.Rows);
  155. return dtoList;
  156. }
  157. public async Task<TmtnDevOperateRecordViewModel> GetByIdAsync(Guid id)
  158. {
  159. var content = await _repository.GetByIdAsync(id);
  160. var contentDto = _mapper.Map<TmtnDevOperateRecordViewModel>(content);
  161. return contentDto;
  162. }
  163. public async Task UpdateAsync(string code, TmtnDevOperateRecordUpdateModel updateModel)
  164. {
  165. var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
  166. var content = items.FirstOrDefault();
  167. if (content == null)
  168. {
  169. throw new Exception("没有此数据");
  170. }
  171. content.C_LastUpdatedBy = _claims.ApiUserId;
  172. content.D_LastUpdatedOn = DateTime.Now;
  173. _mapper.Map(updateModel, content, typeof(TmtnDevOperateRecordUpdateModel), typeof(TMTN_DevOperateRecord));
  174. _repository.Update(content);
  175. var result = await _repository.SaveAsync();
  176. if (!result)
  177. {
  178. throw new Exception("更新失败");
  179. }
  180. }
  181. public async Task<TmtnDevOpsRecordItemDetailViewMode> GetDevOpsRecordItemAsync(string devId, string repairId)
  182. {
  183. var vm = new TmtnDevOpsRecordItemDetailViewMode();
  184. var sysUsers = _sqlDBContext.GetDbSet<TSYS_User>().AsNoTracking().Where(x => x.C_Status == "1");
  185. var repairOrderItemSet = _sqlDBContext.GetDbSet<TMTN_DevOpsRecord>();
  186. var orderItem_group_datas = await (from orderItem in repairOrderItemSet.AsNoTracking().Where(t => t.C_DevOpsCode == repairId)
  187. join user in sysUsers on orderItem.C_CreateBy equals user.C_UserID
  188. group orderItem by new { orderItem.C_ID, orderItem.C_Remark, orderItem.C_Record, orderItem.C_Status, orderItem.C_SpotDevOpsContentCode, orderItem.D_CreateOn, orderItem.C_SolidWaste, user.C_Name } into sg
  189. select new DevOpsRecordItemViewMode
  190. {
  191. C_ID = sg.Key.C_ID,
  192. D_CreateOn = sg.Key.D_CreateOn,
  193. C_Remark = sg.Key.C_Remark,
  194. C_SpotDevOpsContentCode = sg.Key.C_SpotDevOpsContentCode,
  195. C_Status = sg.Key.C_Status,
  196. C_Record = sg.Key.C_Record,
  197. C_SolidWaste = sg.Key.C_SolidWaste,
  198. CreateUserName = sg.Key.C_Name,
  199. }).OrderBy(x => x.D_CreateOn).ToListAsync();
  200. //group orderItem by new { orderItem.C_ID, orderItem.C_Remark, orderItem.C_Record, orderItem.C_Status, orderItem.C_SpotDevOpsContentCode, orderItem.D_CreateOn, user.C_Name } into sg
  201. //select new DevOpsRecordItemViewMode
  202. //{
  203. // C_ID = sg.Key.C_ID,
  204. // D_CreateOn = sg.Key.D_CreateOn,
  205. // C_Remark = sg.Key.C_Remark,
  206. // C_SpotDevOpsContentCode = sg.Key.C_SpotDevOpsContentCode,
  207. // C_Status = sg.Key.C_Status,
  208. // C_RepairRecord = sg.Key.C_Record,
  209. // CreateUserName = sg.Key.C_Name,
  210. //}).OrderBy(x => x.D_CreateOn).ToListAsync();
  211. List<DevOpsRecordItemViewMode> devOpsItem = new List<DevOpsRecordItemViewMode>();
  212. List<SolidWaste> DevOpsRecordSolidWaste = new List<SolidWaste>();
  213. foreach (IGrouping<string, DevOpsRecordItemViewMode> item in orderItem_group_datas.GroupBy(p => p.C_Status).ToList())
  214. {
  215. devOpsItem.Add(item.FirstOrDefault());
  216. if (item.FirstOrDefault()?.C_Status == "7")
  217. {
  218. foreach(var item2 in item.ToList<DevOpsRecordItemViewMode>())
  219. {
  220. if(!string.IsNullOrEmpty(item2.C_SolidWaste))
  221. DevOpsRecordSolidWaste.Add(JsonConvert.DeserializeObject<SolidWaste>(item2.C_SolidWaste)) ;
  222. }
  223. }
  224. }
  225. vm.DevOpsRecordSolidWasteItems = DevOpsRecordSolidWaste;
  226. vm.DevOpsRecordItems = devOpsItem;
  227. var store_dev = await (from devStore in _sqlDBContext.GetDbSet<TDEV_DevStore>().AsNoTracking().Where(t => t.C_ID == devId)
  228. join store in _sqlDBContext.GetDbSet<TPNT_Store>().AsNoTracking() on devStore.C_StoreCode equals store.C_ID.ToString()
  229. select new
  230. {
  231. store.C_Logo,
  232. store.C_LicenseCode,
  233. store.C_Name,
  234. devStore.D_CreateOn
  235. }).FirstOrDefaultAsync();
  236. vm.StoreName = store_dev.C_Name;
  237. vm.DevCreateOn = store_dev.D_CreateOn;
  238. vm.C_Logo = store_dev.C_Logo;
  239. var devUserName = await (from user in sysUsers
  240. join userRole in _sqlDBContext.GetDbSet<TSYS_UserRole>().AsNoTracking() on user.C_UserID equals userRole.C_UserCode
  241. join role in _sqlDBContext.GetDbSet<TSYS_Role>().AsNoTracking().Where(t => t.C_LicenseCode == store_dev.C_LicenseCode && t.C_Status == "1") on userRole.C_RoleCode equals role.C_Code
  242. select new
  243. {
  244. RoleName = role.C_Name,
  245. user.C_Name,
  246. user.C_Mobile
  247. }).ToListAsync();
  248. devUserName.ToList().ForEach(x => {
  249. if (x.RoleName.Contains("设备管理员"))
  250. vm.DevManager += x.C_Name + " " + x.C_Mobile + " ";
  251. if (x.RoleName.Contains("设备运维员"))
  252. vm.DevOpser += x.C_Name + " " + x.C_Mobile + " ";
  253. });
  254. return vm;
  255. }
  256. public Task<int> UpdateOneAsync(TmtnDevOperateRecordViewModel viewModel, params string[] fields)
  257. {
  258. throw new NotImplementedException();
  259. }
  260. public Task<bool> IsExistAsync(Guid id)
  261. {
  262. throw new NotImplementedException();
  263. }
  264. public Task<IEnumerable<TmtnDevOperateRecordViewModel>> GetByConditionAsync(Expression<Func<TmtnDevOperateRecordViewModel, bool>> expression)
  265. {
  266. throw new NotImplementedException();
  267. }
  268. public Task UpdateAsync(string code, TpntAreaUpdateModel updateModel)
  269. {
  270. throw new NotImplementedException();
  271. }
  272. public Task<IEnumerable<TmtnDevOperateRecordViewModel>> GetConditionAsync(TpntAreaSearchModel searchModel)
  273. {
  274. throw new NotImplementedException();
  275. }
  276. }
  277. }