QualityController.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511
  1. using Hotline.Caching.Interfaces;
  2. using MapsterMapper;
  3. using XF.Domain.Authentications;
  4. using XF.Domain.Repository;
  5. using Hotline.Quality;
  6. using Hotline.Permissions;
  7. using Hotline.Repository.SqlSugar.Extensions;
  8. using Hotline.Settings;
  9. using Hotline.Share.Dtos;
  10. using Hotline.Share.Dtos.File;
  11. using Microsoft.AspNetCore.Mvc;
  12. using XF.Domain.Exceptions;
  13. using Hotline.Share.Dtos.Quality;
  14. using Hotline.Share.Dtos.Order;
  15. using Hotline.Share.Enums.Quality;
  16. using Hotline.Share.Enums.Order;
  17. using XF.Utility.EnumExtensions;
  18. using System.Xml.Linq;
  19. using System.Threading;
  20. namespace Hotline.Api.Controllers
  21. {
  22. public class QualityController : BaseController
  23. {
  24. private readonly ISessionContext _sessionContext;
  25. private readonly IMapper _mapper;
  26. private readonly IQualityRepository _qualitey;
  27. private readonly IRepository<QualityDetail> _qualiteyDetail;
  28. private readonly IRepository<QualityItem> _qualiteyItem;
  29. private readonly IRepository<QualityTemplate> _qualityTemplate;
  30. private readonly IRepository<QualityTemplateDetail> _qualiteyTemplateDetail;
  31. private readonly IRepository<QualityProhibited> _qualiteyProhibited;
  32. private readonly ISystemDicDataCacheManager _systemDicDataCacheManager;
  33. public QualityController(
  34. ISessionContext sessionContext,
  35. IMapper mapper,
  36. IQualityRepository qualitey,
  37. IRepository<Quality.QualityDetail> qualiteyDetail,
  38. IRepository<QualityItem> qualiteyItem,
  39. IRepository<QualityTemplate> qualityTemplate,
  40. IRepository<QualityTemplateDetail> qualiteyTemplateDetail,
  41. IRepository<QualityProhibited> qualiteyProhibited,
  42. ISystemDicDataCacheManager systemDicDataCacheManager
  43. )
  44. {
  45. _sessionContext = sessionContext;
  46. _mapper = mapper;
  47. _qualitey = qualitey;
  48. _qualiteyDetail = qualiteyDetail;
  49. _qualiteyItem = qualiteyItem;
  50. _qualityTemplate = qualityTemplate;
  51. _qualiteyTemplateDetail = qualiteyTemplateDetail;
  52. _qualiteyProhibited = qualiteyProhibited;
  53. _systemDicDataCacheManager = systemDicDataCacheManager;
  54. }
  55. #region 质检管理
  56. /// <summary>
  57. /// 删除质检
  58. /// </summary>
  59. /// <param name="dto"></param>
  60. /// <returns></returns>
  61. [HttpDelete]
  62. public async Task Delete([FromBody] DeleteQualityDto dto)
  63. {
  64. foreach (var Id in dto.Ids)
  65. {
  66. await _qualitey.RemoveAsync(x => x.Id == Id);
  67. List<QualityDetail> details = await _qualiteyDetail.Queryable().Where(x => x.QualityId == Id).ToListAsync();
  68. await _qualiteyDetail.RemoveRangeAsync(details, HttpContext.RequestAborted);
  69. }
  70. }
  71. /// <summary>
  72. /// 更新质检
  73. /// </summary>
  74. /// <param name="dto"></param>
  75. /// <returns></returns>
  76. [Permission(EPermission.UpdateQuality)]
  77. [HttpPut]
  78. public async Task Update([FromBody] UpdateQualityDto dto)
  79. {
  80. await _qualitey.UpdateQualityAsync(dto, HttpContext.RequestAborted);
  81. }
  82. /// <summary>
  83. /// 获取质检列表
  84. /// </summary>
  85. /// <param name="dto"></param>
  86. /// <returns></returns>
  87. [HttpGet("list")]
  88. public async Task<PagedDto<QualityDto>> List([FromQuery] QualityListDto dto)
  89. {
  90. var (total, items) = await _qualitey.Queryable()
  91. .Includes(x => x.Order)
  92. .Includes(x => x.Visit)
  93. .Includes(x => x.Visit,e=>e.Employee)
  94. .Includes(x => x.QualityDetails)
  95. .WhereIF(!string.IsNullOrEmpty(dto.Keyword), d => d.Order.Title.Contains(dto.Keyword!) || d.Order.No.Contains(dto.Keyword!))
  96. .WhereIF(dto.State.HasValue, d => d.State == dto.State)
  97. .WhereIF(dto.Source.HasValue, d => d.Source == dto.Source)
  98. .WhereIF(dto.CreationTimeStart.HasValue, d => d.CreationTime >= dto.CreationTimeStart)
  99. .WhereIF(dto.CreationTimeEnd.HasValue, d => d.CreationTime <= dto.CreationTimeEnd)
  100. .OrderByDescending(x => x.CreationTime)
  101. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  102. return new PagedDto<QualityDto>(total, _mapper.Map<IReadOnlyList<QualityDto>>(items));
  103. }
  104. /// <summary>
  105. /// 获取质检实体
  106. /// </summary>
  107. /// <param name="id"></param>
  108. /// <returns></returns>
  109. [HttpGet("{id}")]
  110. public async Task<Quality.Quality> Entity(string id)
  111. {
  112. return await _qualitey.Queryable()
  113. .Includes(x => x.QualityDetails)
  114. .FirstAsync(x => x.Id == id);
  115. }
  116. #endregion
  117. #region 质检项管理
  118. /// <summary>
  119. /// 新增项目
  120. /// </summary>
  121. /// <param name="dtos"></param>
  122. /// <returns></returns>
  123. [Permission(EPermission.AddQualityItem)]
  124. [HttpPost("item")]
  125. public async Task Add([FromBody] QualityItemAddDto dto)
  126. {
  127. var count = await _qualiteyItem.CountAsync(x => x.Name == dto.Name);
  128. if (count > 0)
  129. throw UserFriendlyException.SameMessage("质检项目名称已存在");
  130. var model = _mapper.Map<QualityItem>(dto);
  131. await _qualiteyItem.AddAsync(model, HttpContext.RequestAborted);
  132. }
  133. ///// <summary>
  134. ///// 删除项目
  135. ///// </summary>
  136. ///// <param name="dto"></param>
  137. ///// <returns></returns>
  138. //[Permission(EPermission.DeleteQualityItem)]
  139. //[HttpDelete("item")]
  140. //public async Task Delete([FromBody] QualityItemDeleteDto dto)
  141. //{
  142. // await _qualiteyItem.RemoveAsync(x => x.Id == dto.Id);
  143. //}
  144. /// <summary>
  145. /// 删除项目
  146. /// </summary>
  147. /// <param name="dto"></param>
  148. /// <returns></returns>
  149. [Permission(EPermission.DeleteQualityItem)]
  150. [HttpDelete("itemBatch")]
  151. public async Task Delete([FromBody] QualityItemBatchDeleteDto dto)
  152. {
  153. List<QualityItem> items = await _qualiteyItem.Queryable().In(x => x.Id, dto.Ids).ToListAsync();
  154. foreach (var item in items)
  155. {
  156. var detail = await _qualiteyDetail.Queryable().Where(x => x.Name == item.Name && !x.IsDeleted).AnyAsync();
  157. //质检中已存在 启用状态不可以删
  158. if (item.IsEnable == 0 || detail) items.Remove(item);
  159. }
  160. if (items.Any()) await _qualiteyItem.RemoveRangeAsync(items,true, HttpContext.RequestAborted);
  161. }
  162. /// <summary>
  163. /// 更新项目
  164. /// </summary>
  165. /// <param name="dto"></param>
  166. /// <returns></returns>
  167. [Permission(EPermission.UpdateQualityItem)]
  168. [HttpPut("item")]
  169. public async Task Update([FromBody] QualityItemUpdateDto dto)
  170. {
  171. var item = await _qualiteyItem.GetAsync(dto.Id, HttpContext.RequestAborted);
  172. if (item is null)
  173. throw UserFriendlyException.SameMessage("无效质检项目");
  174. if (item.IsEnable != dto.IsEnable || item.Name != dto.Name) {
  175. var detail = await _qualiteyDetail.Queryable().Where(x => x.Name == item.Name && !x.IsDeleted).AnyAsync();
  176. if(detail) throw UserFriendlyException.SameMessage("质检项目在中心质检中已使用,不能修改状态和名称!");
  177. }
  178. _mapper.Map(dto, item);
  179. item.LastModificationName = _sessionContext.UserName;
  180. await _qualiteyItem.UpdateAsync(item, HttpContext.RequestAborted);
  181. }
  182. /// <summary>
  183. /// 获取项目列表
  184. /// </summary>
  185. /// <param name="dto"></param>
  186. /// <returns></returns>
  187. [Permission(EPermission.QualityItemList)]
  188. [HttpGet("item/list")]
  189. public async Task<PagedDto<QualityItemDto>> List([FromQuery] QualityItemListDto dto)
  190. {
  191. var (total, items) = await _qualiteyItem.Queryable()
  192. .WhereIF(!string.IsNullOrEmpty(dto.Name), d => d.Name.Contains(dto.Name!))
  193. .WhereIF(!string.IsNullOrEmpty(dto.GroupingName), d => d.GroupingName.Contains(dto.GroupingName!))
  194. .WhereIF(dto.IsEnable.HasValue,d=>d.IsEnable == dto.IsEnable)
  195. .OrderByDescending(x => x.CreationTime)
  196. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  197. return new PagedDto<QualityItemDto>(total, _mapper.Map<IReadOnlyList<QualityItemDto>>(items));
  198. }
  199. /// <summary>
  200. /// 获取项目实体
  201. /// </summary>
  202. /// <param name="id"></param>
  203. /// <returns></returns>
  204. [HttpGet("item/{id}")]
  205. public async Task<QualityItem> ItemEntity(string id)
  206. {
  207. return await _qualiteyItem.Queryable()
  208. .FirstAsync(x => x.Id == id);
  209. }
  210. #endregion
  211. #region 质检模版管理
  212. /// <summary>
  213. /// 新增模版
  214. /// </summary>
  215. /// <param name="dtos"></param>
  216. /// <returns></returns>
  217. [Permission(EPermission.AddQualityTemplate)]
  218. [HttpPost("template")]
  219. public async Task Add([FromBody] TemplateAddDto dto)
  220. {
  221. var groupingCount = await _qualityTemplate.CountAsync(x => x.Grouping == dto.Grouping && x.IsEnable == 0);
  222. if (groupingCount > 0)
  223. throw UserFriendlyException.SameMessage("当前已存在");
  224. var names = dto.TemplateDetails.Select(x => x.ItemId).ToList();
  225. var nameCount= names.GroupBy(x => x).Count(c => c.Count() > 1);
  226. if (nameCount > 0)
  227. throw UserFriendlyException.SameMessage("质检模版存在重复质检项");
  228. var model = _mapper.Map<QualityTemplate>(dto);
  229. var id = await _qualityTemplate.AddAsync(model, HttpContext.RequestAborted);
  230. if (!string.IsNullOrEmpty(id))
  231. {
  232. foreach (var item in dto.TemplateDetails)
  233. {
  234. item.TemplateId = id;
  235. }
  236. List<QualityTemplateDetail> details = _mapper.Map<List<QualityTemplateDetail>>(dto.TemplateDetails);
  237. await _qualiteyTemplateDetail.AddRangeAsync(details, HttpContext.RequestAborted);
  238. }
  239. }
  240. /// <summary>
  241. /// 删除模版
  242. /// </summary>
  243. /// <param name="dto"></param>
  244. /// <returns></returns>
  245. [Permission(EPermission.DeleteQualityTemplate)]
  246. [HttpDelete("template")]
  247. public async Task Delete([FromBody] TemplateDeleteDto dto)
  248. {
  249. await _qualityTemplate.RemoveAsync(x => x.Id == dto.Id);
  250. List<QualityTemplateDetail> details = await _qualiteyTemplateDetail.Queryable().Where(x => x.TemplateId == dto.Id).ToListAsync();
  251. await _qualiteyTemplateDetail.RemoveRangeAsync(details, HttpContext.RequestAborted);
  252. }
  253. /// <summary>
  254. /// 删除模版
  255. /// </summary>
  256. /// <param name="dto"></param>
  257. /// <returns></returns>
  258. [Permission(EPermission.DeleteQualityTemplate)]
  259. [HttpDelete("templateBatch")]
  260. public async Task Delete([FromBody] TemplateBatchDeleteDto dto)
  261. {
  262. List<QualityTemplate> templates = await _qualityTemplate.Queryable().In(x=>x.Id,dto.Ids).ToListAsync();
  263. List<QualityTemplateDetail> details = await _qualiteyTemplateDetail.Queryable().In(x => x.TemplateId,dto.Ids).ToListAsync();
  264. await _qualityTemplate.RemoveRangeAsync(templates, HttpContext.RequestAborted);
  265. await _qualiteyTemplateDetail.RemoveRangeAsync(details, HttpContext.RequestAborted);
  266. }
  267. /// <summary>
  268. /// 更新模版
  269. /// </summary>
  270. /// <param name="dto"></param>
  271. /// <returns></returns>
  272. [Permission(EPermission.UpdateQualityTemplate)]
  273. [HttpPut("template")]
  274. public async Task Update([FromBody] TemplateUpdateDto dto)
  275. {
  276. var template = await _qualityTemplate.GetAsync(dto.Id, HttpContext.RequestAborted);
  277. if (template is null)
  278. throw UserFriendlyException.SameMessage("无效质检模版");
  279. var groupingCount = await _qualityTemplate.CountAsync(x => x.Grouping == dto.Grouping && x.Id != dto.Id && x.IsEnable == 0);
  280. if (groupingCount > 0)
  281. throw UserFriendlyException.SameMessage("当前质检分类已存在");
  282. _mapper.Map(dto, template);
  283. template.LastModificationName = _sessionContext.UserName;
  284. await _qualityTemplate.UpdateAsync(template, HttpContext.RequestAborted);
  285. if (dto.TemplateDetails.Any())
  286. {
  287. List<QualityTemplateDetail> details = await _qualiteyTemplateDetail.Queryable().Where(x => x.TemplateId == dto.Id).ToListAsync();
  288. await _qualiteyTemplateDetail.RemoveRangeAsync(details, HttpContext.RequestAborted);
  289. foreach (var item in dto.TemplateDetails)
  290. {
  291. item.TemplateId = dto.Id;
  292. }
  293. List<QualityTemplateDetail> newDetails = _mapper.Map<List<QualityTemplateDetail>>(dto.TemplateDetails);
  294. await _qualiteyTemplateDetail.AddRangeAsync(newDetails, HttpContext.RequestAborted);
  295. }
  296. }
  297. /// <summary>
  298. /// 获取模版列表
  299. /// </summary>
  300. /// <param name="dto"></param>
  301. /// <returns></returns>
  302. [Permission(EPermission.QualityTemplateList)]
  303. [HttpGet("template/list")]
  304. public async Task<PagedDto<QualityTemplateDto>> List([FromQuery] TemplateListDto dto)
  305. {
  306. var (total, items) = await _qualityTemplate.Queryable()
  307. .Includes(x => x.templateDetails)
  308. .Includes(x=>x.templateDetails,y=>y.QualityItem)
  309. .WhereIF(!string.IsNullOrEmpty(dto.Name), d => d.Name.Contains(dto.Name!))
  310. .WhereIF(dto.Grouping.HasValue, d => d.Grouping == dto.Grouping)
  311. .WhereIF(dto.IsEnable.HasValue, d => d.IsEnable == dto.IsEnable)
  312. .OrderByDescending(x => x.CreationTime)
  313. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  314. return new PagedDto<QualityTemplateDto>(total, _mapper.Map<IReadOnlyList<QualityTemplateDto>>(items));
  315. }
  316. /// <summary>
  317. /// 获取模版实体
  318. /// </summary>
  319. /// <param name="id"></param>
  320. /// <returns></returns>
  321. [HttpGet("template/{id}")]
  322. public async Task<QualityTemplateDto> TemplateEntity(string id)
  323. {
  324. var template = await _qualityTemplate.Queryable()
  325. .Includes(x => x.templateDetails)
  326. .Includes(x => x.templateDetails, y => y.QualityItem)
  327. .FirstAsync(x => x.Id == id);
  328. return _mapper.Map<QualityTemplateDto>(template);
  329. }
  330. /// <summary>
  331. /// 启禁用
  332. /// </summary>
  333. /// <param name="dto"></param>
  334. /// <returns></returns>
  335. [Permission(EPermission.EnableQualityTemplate)]
  336. [HttpPut("template/enable")]
  337. public async Task Enable([FromBody] TemplateUpdateDto dto)
  338. {
  339. var template = await _qualityTemplate.GetAsync(dto.Id, HttpContext.RequestAborted);
  340. if (template is null)
  341. throw UserFriendlyException.SameMessage("无效质检模版");
  342. _mapper.Map(dto, template);
  343. await _qualityTemplate.UpdateAsync(template, HttpContext.RequestAborted);
  344. }
  345. #endregion
  346. #region 质检词库管理
  347. /// <summary>
  348. /// 新增违禁词
  349. /// </summary>
  350. /// <param name="dtos"></param>
  351. /// <returns></returns>
  352. [Permission(EPermission.AddQualityProhibited)]
  353. [HttpPost("prohibited")]
  354. public async Task Add([FromBody] ProhibitedAddDto dto)
  355. {
  356. var model = _mapper.Map<QualityProhibited>(dto);
  357. await _qualiteyProhibited.AddAsync(model, HttpContext.RequestAborted);
  358. }
  359. /// <summary>
  360. /// 删除违禁词
  361. /// </summary>
  362. /// <param name="dto"></param>
  363. /// <returns></returns>
  364. [Permission(EPermission.DeleteQualityProhibited)]
  365. [HttpDelete("prohibited")]
  366. public async Task Delete([FromBody] ProhibitedDeleteDto dto)
  367. {
  368. await _qualiteyProhibited.RemoveAsync(x => x.Id == dto.Id);
  369. }
  370. /// <summary>
  371. /// 删除违禁词
  372. /// </summary>
  373. /// <param name="dto"></param>
  374. /// <returns></returns>
  375. [Permission(EPermission.DeleteQualityProhibited)]
  376. [HttpDelete("prohibitedBatch")]
  377. public async Task Delete([FromBody] ProhibitedBatchDeleteDto dto)
  378. {
  379. List<QualityProhibited> prohibiteds = await _qualiteyProhibited.Queryable().In(x=>x.Id,dto.Ids).ToListAsync();
  380. await _qualiteyProhibited.RemoveRangeAsync(prohibiteds, HttpContext.RequestAborted);
  381. }
  382. /// <summary>
  383. /// 更新违禁词
  384. /// </summary>
  385. /// <param name="dto"></param>
  386. /// <returns></returns>
  387. [Permission(EPermission.UpdateQualityProhibited)]
  388. [HttpPut("prohibited")]
  389. public async Task Update([FromBody] ProhibitedUpdateDto dto)
  390. {
  391. var prohibited = await _qualiteyProhibited.GetAsync(dto.Id, HttpContext.RequestAborted);
  392. if (prohibited is null)
  393. throw UserFriendlyException.SameMessage("无效质检模版");
  394. _mapper.Map(dto, prohibited);
  395. prohibited.LastModificationName = _sessionContext.UserName;
  396. await _qualiteyProhibited.UpdateAsync(prohibited, HttpContext.RequestAborted);
  397. }
  398. /// <summary>
  399. /// 获取违禁词列表
  400. /// </summary>
  401. /// <param name="dto"></param>
  402. /// <returns></returns>
  403. [Permission(EPermission.QualityProhibitedList)]
  404. [HttpGet("prohibited/list")]
  405. public async Task<PagedDto<QualityProhibitedDto>> List([FromQuery] ProhibitedListDto dto)
  406. {
  407. var (total, items) = await _qualiteyProhibited.Queryable()
  408. .WhereIF(!string.IsNullOrEmpty(dto.Name), d => d.Name.Contains(dto.Name!))
  409. .WhereIF(!string.IsNullOrEmpty(dto.Classify), d => d.Classify.Contains(dto.Classify!))
  410. .WhereIF(!string.IsNullOrEmpty(dto.Type), d => d.Type.Contains(dto.Type!))
  411. .OrderByDescending(x => x.CreationTime)
  412. .ToPagedListAsync(dto.PageIndex, dto.PageSize, HttpContext.RequestAborted);
  413. return new PagedDto<QualityProhibitedDto>(total, _mapper.Map<IReadOnlyList<QualityProhibitedDto>>(items));
  414. }
  415. /// <summary>
  416. /// 获取违禁词实体
  417. /// </summary>
  418. /// <param name="id"></param>
  419. /// <returns></returns>
  420. [HttpGet("prohibited/{id}")]
  421. public async Task<QualityProhibited> ProhibitedEntity(string id)
  422. {
  423. return await _qualiteyProhibited.Queryable()
  424. .FirstAsync(x => x.Id == id);
  425. }
  426. #endregion
  427. /// <summary>
  428. /// 获取质检基本信息
  429. /// </summary>
  430. /// <returns></returns>
  431. [HttpGet("base")]
  432. public async Task<object> Base()
  433. {
  434. var rsp = new
  435. {
  436. QualityState = EnumExts.GetDescriptions<EQualityState>(),
  437. QualitySource = EnumExts.GetDescriptions<EQualitySource>()
  438. };
  439. return rsp;
  440. }
  441. /// <summary>
  442. /// 获取质检项目基本信息
  443. /// </summary>
  444. /// <returns></returns>
  445. [HttpGet("item_base")]
  446. public async Task<object> ItemBase()
  447. {
  448. var rsp = new
  449. {
  450. QualityItemGrouping = _systemDicDataCacheManager.GetSysDicDataCache(SysDicTypeConsts.QualityItemGrouping)
  451. };
  452. return rsp;
  453. }
  454. /// <summary>
  455. /// 获取质检模版基本信息
  456. /// </summary>
  457. /// <returns></returns>
  458. [HttpGet("template_base")]
  459. public async Task<object> TemplateBase()
  460. {
  461. var rsp = new
  462. {
  463. TemplateGrouping = EnumExts.GetDescriptions<ETemplateGrouping>()
  464. };
  465. return rsp;
  466. }
  467. /// <summary>
  468. /// 获取质检违禁词基本信息
  469. /// </summary>
  470. /// <returns></returns>
  471. [HttpGet("prohibited_base")]
  472. public async Task<object> ProhibitedBase()
  473. {
  474. var rsp = new
  475. {
  476. ProhibitedClassify = _systemDicDataCacheManager.GetSysDicDataCache(SysDicTypeConsts.ProhibitedClassify),
  477. ProhibitedType = _systemDicDataCacheManager.GetSysDicDataCache(SysDicTypeConsts.ProhibitedType),
  478. };
  479. return rsp;
  480. }
  481. }
  482. }