LegalContractApplicationService.cs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. using System.Collections.Generic;
  2. using System.Data.Entity;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5. using System.Web.Mvc;
  6. using Abp.Application.Services.Dto;
  7. using Abp.Auditing;
  8. using Abp.Authorization;
  9. using Abp.Domain.Repositories;
  10. using Abp.Runtime.Caching;
  11. using IwbZero.Auditing;
  12. using IwbZero.AppServiceBase;
  13. using ContractService.Authorization;
  14. using ContractService.Configuration;
  15. using ContractService.LegalCase.Dto;
  16. using ContractService.LegalContract.Contract.Dto;
  17. using IwbZero.ToolCommon.StringModel;
  18. namespace ContractService.LegalContract.Contract
  19. {
  20. [AbpAuthorize, AuditLog("合同信息")]
  21. public class LegalContractAppService : IwbAsyncCrudAppService<LegalContractInfo, LegalContractDto, string, IwbPagedRequestDto, LegalContractCreateDto, LegalContractUpdateDto >, ILegalContractAppService
  22. {
  23. public LegalContractAppService(
  24. ICacheManager cacheManager,
  25. IRepository<LegalContractInfo, string> repository, LegalManager legalManager, IRepository<LegalContractContentInfo, long> contentRepository) : base(repository, "Id")
  26. {
  27. LegalManager = legalManager;
  28. ContentRepository = contentRepository;
  29. CacheManager = cacheManager;
  30. }
  31. protected override bool KeyIsAuto { get; set; } = false;
  32. public LegalManager LegalManager { get; }
  33. protected IRepository<LegalContractContentInfo,long> ContentRepository { get; }
  34. #region GetSelect
  35. [DisableAuditing]
  36. public override async Task<List<SelectListItem>> GetSelectList()
  37. {
  38. var list = await Repository.GetAllListAsync();
  39. var sList = new List<SelectListItem> {new SelectListItem {Text = @"请选择...", Value = "", Selected = true}};
  40. foreach (var l in list)
  41. {
  42. sList.Add(new SelectListItem { Value = l.Id, Text = l.Name });
  43. }
  44. return sList;
  45. }
  46. [DisableAuditing]
  47. public override async Task<string> GetSelectStr()
  48. {
  49. var list = await Repository.GetAllListAsync();
  50. string str = "<option value=\"\" selected>请选择...</option>";
  51. foreach (var l in list)
  52. {
  53. str += $"<option value=\"{l.Id}\">{l.Name}</option>";
  54. }
  55. return str;
  56. }
  57. #endregion
  58. #region CURD
  59. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgCreate)]
  60. public override async Task Create(LegalContractCreateDto input)
  61. {
  62. var entity = MapToEntity(input);
  63. await LegalManager.CreateContract(entity,input.AttachFiles);
  64. }
  65. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgUpdate)]
  66. public override async Task Update(LegalContractUpdateDto input)
  67. {
  68. var entity = await GetEntityById(input.Id);
  69. if (entity == null)
  70. {
  71. CheckErrors(NotExistMessage);
  72. }
  73. MapToEntity(input, entity);
  74. await LegalManager.UpdateContract(entity, input.AttachFiles);
  75. }
  76. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgDelete)]
  77. public override Task Delete(EntityDto<string> input)
  78. {
  79. return LegalManager.DeleteContract(input.Id);
  80. }
  81. [DisableAuditing]
  82. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgQuery)]
  83. public override async Task<PagedResultDto<LegalContractDto>> GetAll(IwbPagedRequestDto input)
  84. {
  85. var query = LegalManager.QueryContract();
  86. if (input.SearchList?.Count > 0)
  87. {
  88. if (AbpSession.AccountType == AccountTypeDefinition.System)
  89. {
  90. if (input.SearchList.Any(a => a.KeyField.ToLower() == "haslawfirm"))
  91. {
  92. var search = input.SearchList.FirstOrDefault(a => a.KeyField.ToLower() == "haslawfirm");
  93. var name = search?.KeyWords ?? "";
  94. if (search != null) input.SearchList.Remove(search);
  95. query = LegalManager.QueryContractByHasLawFirm(query, name);
  96. }
  97. }
  98. if (input.SearchList.Any(a => a.KeyField.ToLower() == "casename"))
  99. {
  100. var search = input.SearchList.FirstOrDefault(a => a.KeyField.ToLower() == "casename");
  101. var name = search?.KeyWords ?? "";
  102. if (search != null) input.SearchList.Remove(search);
  103. query = query.Where(a => a.CaseInfo.Name.Contains(name));
  104. }
  105. if (AbpSession.AccountType == AccountTypeDefinition.System || AbpSession.AccountType == AccountTypeDefinition.Lawyer)
  106. {
  107. if (input.SearchList.Any(a => a.KeyField.ToLower() == "companyname"))
  108. {
  109. var search = input.SearchList.FirstOrDefault(a => a.KeyField.ToLower() == "companyname");
  110. var name = search?.KeyWords ?? "";
  111. if (search != null) input.SearchList.Remove(search);
  112. query = query.Where(a => a.CaseInfo.CompanyInfo.Name.Contains(name) || a.CaseInfo.CompanyInfo.DisplayName.Contains(name));
  113. }
  114. }
  115. }
  116. query = ApplyFilter(query, input);
  117. var totalCount = await AsyncQueryableExecuter.CountAsync(query);
  118. query = ApplySorting(query, input);
  119. query = ApplyPaging(query, input);
  120. var entities = await AsyncQueryableExecuter.ToListAsync(query);
  121. var dtoList = new PagedResultDto<LegalContractDto>(totalCount, entities.Select(MapToEntityDto).ToList());
  122. return dtoList;
  123. }
  124. protected override LegalContractDto MapToEntityDto(LegalContractInfo entity)
  125. {
  126. var dto = base.MapToEntityDto(entity);
  127. dto.CaseName = entity.CaseInfo?.Name;
  128. dto.CaseName = dto.CaseName.Empty() ? LegalManager.GetCacheName(dto.CaseNo) : dto.CaseName;
  129. dto.CaseState = entity.CaseInfo?.CaseState ?? 0;
  130. dto.CaseCode = entity.CaseInfo?.Code;
  131. dto.CompanyName = entity.CaseInfo?.CompanyInfo?.Name;
  132. dto.CompanyName = dto.CompanyName.Empty() ? LegalManager.GetCompanyNameByCase(dto.CaseNo) : dto.CompanyName;
  133. dto.LawFirmName = LegalManager.GetLawFirmNameByContract(entity.Id);
  134. dto.IsMaster = LegalManager.IsLawyerContractMaster(entity.Id);
  135. return dto;
  136. }
  137. protected override IQueryable<LegalContractInfo> SelfSorting(IQueryable<LegalContractInfo> query, IwbPagedRequestDto input)
  138. {
  139. return query.OrderByDescending(r => r.Id);
  140. }
  141. protected override IQueryable<LegalContractInfo> KeyWordFilter(IQueryable<LegalContractInfo> query, string keyword)
  142. {
  143. return query.Where(a => a.Code.Contains(keyword)|| a.Name.Contains(keyword));
  144. }
  145. #region GetEntity/Dto
  146. /// <summary>
  147. /// 查询实体Dto
  148. /// </summary>
  149. /// <param name="input"></param>
  150. /// <returns></returns>
  151. [DisableAuditing]
  152. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgQuery)]
  153. public override async Task<LegalContractDto> GetDto(EntityDto<string> input)
  154. {
  155. var entity = await GetEntity(input);
  156. return MapToEntityDto(entity);
  157. }
  158. /// <summary>
  159. /// 查询实体Dto
  160. /// </summary>
  161. /// <param name="id"></param>
  162. /// <returns></returns>
  163. [DisableAuditing]
  164. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgQuery)]
  165. public override async Task<LegalContractDto> GetDtoById(string id)
  166. {
  167. var entity = await GetEntityById(id);
  168. var content=await ContentRepository.GetAll().Where(a => a.No == id).OrderByDescending(a=>a.Id).FirstOrDefaultAsync();
  169. var dto = MapToEntityDto(entity);
  170. dto.ContentInfo = content?.ContentInfo??"";
  171. return dto;
  172. }
  173. /// <summary>
  174. /// 查询实体Dto(需指明自定义字段)
  175. /// </summary>
  176. /// <param name="no"></param>
  177. /// <returns></returns>
  178. [DisableAuditing]
  179. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgQuery)]
  180. public override async Task<LegalContractDto> GetDtoByNo(string no)
  181. {
  182. var entity = await GetEntityByNo(no);
  183. return MapToEntityDto(entity);
  184. }
  185. /// <summary>
  186. /// 查询实体
  187. /// </summary>
  188. /// <param name="input"></param>
  189. /// <returns></returns>
  190. [DisableAuditing]
  191. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgQuery)]
  192. public override async Task<LegalContractInfo> GetEntity(EntityDto<string> input)
  193. {
  194. var entity = await GetEntityById(input.Id);
  195. return entity;
  196. }
  197. /// <summary>
  198. /// 查询实体
  199. /// </summary>
  200. /// <param name="id"></param>
  201. /// <returns></returns>
  202. [DisableAuditing]
  203. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgQuery)]
  204. public override async Task<LegalContractInfo> GetEntityById(string id)
  205. {
  206. return await Repository.FirstOrDefaultAsync(a=>a.Id==id);
  207. }
  208. /// <summary>
  209. /// 查询实体(需指明自定义字段)
  210. /// </summary>
  211. /// <param name="no"></param>
  212. /// <returns></returns>
  213. [DisableAuditing]
  214. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgQuery)]
  215. public override async Task<LegalContractInfo> GetEntityByNo(string no)
  216. {
  217. //CheckGetPermission();
  218. if (string.IsNullOrEmpty(KeyFiledName))
  219. {
  220. ThrowError("NoKeyFieldName");
  221. }
  222. return await base.GetEntityByNo(no);
  223. }
  224. #endregion
  225. #region Hide
  226. ///// <summary>
  227. ///// 根据给定的<see cref="IwbPagedRequestDto"/>创建 <see cref="IQueryable{LegalContractInfo}"/>过滤查询.
  228. ///// </summary>
  229. ///// <param name="input">The input.</param>
  230. //protected override IQueryable<LegalContractInfo> CreateFilteredQuery(IwbPagedRequestDto input)
  231. //{
  232. // var query = Repository.GetAll();
  233. // var pagedInput = input as IIwbPagedRequest;
  234. // if (pagedInput == null)
  235. // {
  236. // return query;
  237. // }
  238. // if (!string.IsNullOrEmpty(pagedInput.KeyWords))
  239. // {
  240. // object keyWords = pagedInput.KeyWords;
  241. // LambdaObject obj = new LambdaObject()
  242. // {
  243. // FieldType = (LambdaFieldType)pagedInput.FieldType,
  244. // FieldName = pagedInput.KeyField,
  245. // FieldValue = keyWords,
  246. // ExpType = (LambdaExpType)pagedInput.ExpType
  247. // };
  248. // var exp = obj.GetExp<LegalContractInfo>();
  249. // query = exp != null ? query.Where(exp) : query;
  250. // }
  251. // if (pagedInput.SearchList != null && pagedInput.SearchList.Count > 0)
  252. // {
  253. // List<LambdaObject> objList = new List<LambdaObject>();
  254. // foreach (var o in pagedInput.SearchList)
  255. // {
  256. // if (string.IsNullOrEmpty(o.KeyWords))
  257. // continue;
  258. // object keyWords = o.KeyWords;
  259. // objList.Add(new LambdaObject
  260. // {
  261. // FieldType = (LambdaFieldType)o.FieldType,
  262. // FieldName = o.KeyField,
  263. // FieldValue = keyWords,
  264. // ExpType = (LambdaExpType)o.ExpType
  265. // });
  266. // }
  267. // var exp = objList.GetExp<LegalContractInfo>();
  268. // query = exp != null ? query.Where(exp) : query;
  269. // }
  270. // return query;
  271. //}
  272. //protected override IQueryable<LegalContractInfo> ApplySorting(IQueryable<LegalContractInfo> query, IwbPagedRequestDto input)
  273. //{
  274. // return query.OrderBy(a => a.No);
  275. //}
  276. //protected override IQueryable<LegalContractInfo> ApplyPaging(IQueryable<LegalContractInfo> query, IwbPagedRequestDto input)
  277. //{
  278. // if (input is IPagedResultRequest pagedInput)
  279. // {
  280. // return query.Skip(pagedInput.SkipCount).Take(pagedInput.MaxResultCount);
  281. // }
  282. // return query;
  283. //}
  284. #endregion
  285. #endregion
  286. /// <summary>
  287. /// 变更负责人
  288. /// </summary>
  289. /// <param name="input"></param>
  290. /// <returns></returns>
  291. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgChangeState), AuditLog("变更状态")]
  292. public async Task ChangeState(ChangeStaterDto input)
  293. {
  294. await LegalManager.ChangeState(input.Id, input.State, input.Reason, ServiceType.Contract);
  295. }
  296. public async Task<List<LegalContractDto>> GetAllContract(List<MultiSearchRequest> input)
  297. {
  298. var query = LegalManager.QueryContract();
  299. if (input.Count > 0)
  300. {
  301. if (input.Any(a => a.KeyField.ToLower() == "keyword"))
  302. {
  303. var search = input.FirstOrDefault(a => a.KeyField.ToLower() == "keyword");
  304. if (search != null)
  305. {
  306. var keyword = search.KeyWords ?? "";
  307. input.Remove(search);
  308. //query = query.Where(a =>
  309. // a.Code.Contains(keyword) || a.Name.Contains(keyword) || a.CaseInfo.Name.Contains(keyword) ||
  310. // a.CaseInfo.Code.Contains(keyword));
  311. query = KeyWordFilter(query, keyword);
  312. }
  313. }
  314. if (input.Any(a => a.KeyField.ToLower() == "case"))
  315. {
  316. var search = input.FirstOrDefault(a => a.KeyField.ToLower() == "case");
  317. if (search != null)
  318. {
  319. var keyword = search.KeyWords ?? "";
  320. input.Remove(search);
  321. query = query.Where(a => a.CaseInfo.Name.Contains(keyword) || a.CaseInfo.Code.Contains(keyword));
  322. }
  323. }
  324. if (input.Any(a => a.KeyField.ToLower() == "contract_state"))
  325. {
  326. var search = input.FirstOrDefault(a => a.KeyField.ToLower() == "contract_state");
  327. if (search != null)
  328. {
  329. input.Remove(search);
  330. query = query.Where(a =>
  331. (a.CaseInfo.CaseState == LegalContractStateDefinition.Running ||
  332. a.CaseInfo.CaseState == LegalContractStateDefinition.Running) &&
  333. (a.ContractState == LegalContractStateDefinition.Running ||
  334. a.ContractState == LegalContractStateDefinition.Hang));
  335. }
  336. }
  337. }
  338. query = SearchListFilter(query, input);
  339. query = query.OrderByDescending(a => a.CreationTime);
  340. var entities = await AsyncQueryableExecuter.ToListAsync(query);
  341. var dtoList = entities.Select(MapToEntityDto).ToList();
  342. return dtoList;
  343. }
  344. /// <summary>
  345. /// 关联职员
  346. /// </summary>
  347. /// <param name="input"></param>
  348. /// <returns></returns>
  349. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgSetStaff), AuditLog("关联职员")]
  350. public async Task SetStaff(SetStaffLawyerDto input)
  351. {
  352. if (input.Master.NotEmpty())
  353. {
  354. await LegalManager.SetContractMasterStaff(input.Id, input.Master);
  355. }
  356. await LegalManager.SetContractStaffs(input.Id, input.List);
  357. }
  358. /// <summary>
  359. /// 分配律师
  360. /// </summary>
  361. /// <param name="input"></param>
  362. /// <returns></returns>
  363. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgSetLawyer), AuditLog("分配律师")]
  364. public async Task SetLawyer(SetStaffLawyerDto input)
  365. {
  366. if (input.Master.NotEmpty())
  367. {
  368. await LegalManager.SetContractMasterLawyer(input.Id, input.Master);
  369. }
  370. await LegalManager.SetContractLawyers(input.Id, input.List);
  371. }
  372. /// <summary>
  373. /// 分配律所
  374. /// </summary>
  375. /// <param name="input"></param>
  376. /// <returns></returns>
  377. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgSetLawFirm), AuditLog("分配律所")]
  378. public async Task SetLawFirm(SetStaffLawyerDto input)
  379. {
  380. await LegalManager.SetContractLawFirm(input.Id, input.LawFirmNo);
  381. }
  382. /// <summary>
  383. /// 检查合同是否被分配律所
  384. /// </summary>
  385. /// <param name="no"></param>
  386. /// <returns></returns>
  387. public async Task<bool> CheckContractHasLawFirm(string no)
  388. {
  389. return await LegalManager.CheckContractHasLawFirm(no);
  390. }
  391. /// <summary>
  392. /// 查询合同的员工
  393. /// </summary>
  394. /// <param name="no"></param>
  395. /// <returns></returns>
  396. [DisableAuditing]
  397. public async Task<List<StaffLawyerDto>> GetContractStaffs(string no)
  398. {
  399. var staffs = await LegalManager.QueryContractAllStaffs(no).Select(a => new StaffLawyerDto()
  400. {
  401. Name = a.Name,
  402. No = a.Id,
  403. UserName = a.UserName,
  404. OrgName = a.OrganizationName,
  405. IsMaster = a.IsMaster
  406. }).ToListAsync();
  407. return staffs;
  408. }
  409. /// <summary>
  410. /// 查询合同的律师
  411. /// </summary>
  412. /// <param name="no"></param>
  413. /// <returns></returns>
  414. [DisableAuditing]
  415. public async Task<List<StaffLawyerDto>> GetContractLawyers(string no)
  416. {
  417. var isLawFirmMaster = LegalManager.IsLawFirmMaster(AbpSession.AccountNo);
  418. var staffs = await LegalManager.QueryContractAllLawyers(no).Where(a => isLawFirmMaster || !a.IsMaster).Select(a => new StaffLawyerDto()
  419. {
  420. Name = a.Name,
  421. No = a.Id,
  422. UserName = a.UserName,
  423. IsMaster = a.IsMaster
  424. }).ToListAsync();
  425. return staffs;
  426. }
  427. /// <summary>
  428. /// 合同备注
  429. /// </summary>
  430. /// <param name="input"></param>
  431. /// <returns></returns>
  432. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgNote,PermissionNames.PagesCaseContractMgContractMgLawNote), AuditLog("合同备注")]
  433. public async Task CreateNote(ContractNoteDto input)
  434. {
  435. var entity = ObjectMapper.Map<LegalContractNoteInfo>(input);
  436. entity.KeyPointNo = entity.KeyPointNo.Empty() ? null : entity.KeyPointNo;
  437. await LegalManager.ContractNote(entity);
  438. }
  439. /// <summary>
  440. /// 查询合同备注
  441. /// </summary>
  442. /// <param name="input"></param>
  443. /// <returns></returns>
  444. [DisableAuditing]
  445. public async Task<PagedResultDto<ContractNoteDto>> QueryNote(LazyQueryDto input)
  446. {
  447. var query = LegalManager.QueryContractNoteInfos(input.No, true);
  448. if (AbpSession.AccountType == AccountTypeDefinition.Lawyer)
  449. {
  450. query = LegalManager.QueryLawyerContractNoteInfos(input.No, true);
  451. }else if (AbpSession.AccountType == AccountTypeDefinition.Client)
  452. {
  453. query = LegalManager.QueryStaffContractNoteInfos(input.No, true);
  454. }
  455. if (input.Keyword.NotEmpty())
  456. {
  457. var wordArr = input.Keyword.Split('|');
  458. if (wordArr[0].NotEmpty())
  459. {
  460. var kpNo = wordArr[0];
  461. query = query.Where(a => a.KeyPointNo == kpNo);
  462. }
  463. if (wordArr.Length>1&& wordArr[1].NotEmpty())
  464. {
  465. var typeArr = wordArr[1].Split(',');
  466. List<int> arr = new List<int>();
  467. foreach (var s in typeArr)
  468. {
  469. if (int.TryParse(s, out var type))
  470. {
  471. arr.Add(type);
  472. }
  473. }
  474. if (arr.Any())
  475. {
  476. query = query.Where(a => arr.Contains(a.NoteType));
  477. }
  478. }
  479. }
  480. var totalCount = await query.CountAsync();
  481. query = query.OrderByDescending(a => a.Id).Skip(input.Skip).Take(input.Take);
  482. var list = await query.ToListAsync();
  483. return new PagedResultDto<ContractNoteDto>(totalCount, list.Select(MapNoteDto).ToList());
  484. }
  485. private ContractNoteDto MapNoteDto(LegalContractNoteInfo entity)
  486. {
  487. var dto = ObjectMapper.Map<ContractNoteDto>(entity);
  488. if (entity.CreatorUser != null)
  489. {
  490. dto.UserImage = entity.CreatorUser.ImagePath;
  491. dto.UserRealName = LegalManager.QueryStaffByUserName(entity.CreatorUser.UserName)?.Name ??
  492. LegalManager.QueryLawyerByUserName(entity.CreatorUser.UserName)?.Name ??
  493. entity.CreatorUser.Name;
  494. }
  495. dto.KeyPointName = entity.KeyPointInfo?.Name??"";
  496. return dto;
  497. }
  498. /// <summary>
  499. /// 补充合同
  500. /// </summary>
  501. /// <param name="input"></param>
  502. /// <returns></returns>
  503. [AbpAuthorize(PermissionNames.PagesCaseContractMgContractMgSupplement), AuditLog("补充合同")]
  504. public async Task CreateSupplement(SupplementDto input)
  505. {
  506. var entity = ObjectMapper.Map<LegalContractSupplementInfo>(input);
  507. await LegalManager.ContractSupplement(entity,input.AttachFiles);
  508. }
  509. /// <summary>
  510. /// 查询补充合同
  511. /// </summary>
  512. /// <param name="input"></param>
  513. /// <returns></returns>
  514. [DisableAuditing]
  515. public async Task<PagedResultDto<SupplementDto>> QuerySupplement(LazyQueryDto input)
  516. {
  517. var query = LegalManager.QueryContractSupplementInfos(input.No, true);
  518. if (input.Keyword.NotEmpty())
  519. {
  520. query = query.Where(a => a.KeyPointNo == input.Keyword);
  521. }
  522. else
  523. {
  524. query = query.Where(a => string.IsNullOrEmpty(a.KeyPointNo));
  525. }
  526. var totalCount = await query.CountAsync();
  527. query = query.OrderByDescending(a => a.Id).Skip(input.Skip).Take(input.Take);
  528. var list = await query.ToListAsync();
  529. return new PagedResultDto<SupplementDto>(totalCount, list.Select(MapSupplementDto).ToList());
  530. }
  531. private SupplementDto MapSupplementDto(LegalContractSupplementInfo entity)
  532. {
  533. var dto = ObjectMapper.Map<SupplementDto>(entity);
  534. var content = ContentRepository.GetAll().Where(a => a.No == entity.Id).OrderByDescending(a => a.Id).FirstOrDefault();
  535. dto.ContentInfo = content?.ContentInfo ?? "";
  536. return dto;
  537. }
  538. }
  539. }