MiddleService.cs 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5. using GxPress.Common.Exceptions;
  6. using GxPress.Repository.Interface;
  7. using GxPress.Request.App.Middle;
  8. using GxPress.Request.Notice;
  9. using GxPress.Service.Interface.Middle;
  10. using Datory;
  11. using GxPress.Entity.Middle;
  12. using GxPress.Result.App.Middle;
  13. using System.Transactions;
  14. using GxPress.Repository.Interface.Collection;
  15. using GxPress.Repository.Interface.Note;
  16. using GxPress.Repository.Interface.Missive;
  17. using GxPress.Common.Tools;
  18. using GxPress.Repository.Interface.Analyze;
  19. using GxPress.Service.Interface.UserMiddle;
  20. using GxPress.Repository.Interface.RecordFolder;
  21. using GxPress.Service.Interface.Analyze;
  22. using GxPress.Request.App.Analyze;
  23. using GxPress.EnumConst;
  24. using System.Transactions;
  25. using GxPress.Request.UserMiddle;
  26. using Dapper;
  27. namespace GxPress.Service.Implement.Middle
  28. {
  29. public class MiddleService : IMiddleService
  30. {
  31. private readonly IMiddleRepository _middleRepository;
  32. private readonly IFolderUserRepository _folderUserRepository;
  33. private readonly IUserRepository _userRepository;
  34. private readonly ICollectionRepository _collectionRepository;
  35. private readonly INoteRepository _noteRepository;
  36. private readonly IMissiveRepository _missiveRepository;
  37. private readonly IGroupRepository _groupRepository;
  38. private readonly IAnalyzeRepository _analyzeRepository;
  39. private readonly INoticeRepository _noticeRepository;
  40. private readonly IUserMiddleService _userMiddleService;
  41. private readonly IAddresseeRepository _addresseeRepository;
  42. private readonly IRecordFolderRepository recordFolderRepository;
  43. private readonly IAnalyzeService analyzeService;
  44. public MiddleService(IMiddleRepository middleRepository, IFolderUserRepository folderUserRepository,
  45. IUserRepository userRepository, ICollectionRepository collectionRepository, INoteRepository noteRepository,
  46. IMissiveRepository missiveRepository, IGroupRepository groupRepository, INoticeRepository noticeRepository, IAnalyzeRepository analyzeRepository, IUserMiddleService userMiddleService, IAddresseeRepository addresseeRepository, IRecordFolderRepository recordFolderRepository, IAnalyzeService analyzeService)
  47. {
  48. _middleRepository = middleRepository;
  49. _folderUserRepository = folderUserRepository;
  50. _userRepository = userRepository;
  51. _collectionRepository = collectionRepository;
  52. _noteRepository = noteRepository;
  53. _missiveRepository = missiveRepository;
  54. _groupRepository = groupRepository;
  55. _noticeRepository = noticeRepository;
  56. _analyzeRepository = analyzeRepository;
  57. _userMiddleService = userMiddleService;
  58. _addresseeRepository = addresseeRepository;
  59. this.recordFolderRepository = recordFolderRepository;
  60. this.analyzeService = analyzeService;
  61. }
  62. /// <summary>
  63. /// 添加文件夹
  64. /// </summary>
  65. /// <param name="request"></param>
  66. /// <returns></returns>
  67. public async Task<int> InsertAsync(MiddleInsertRequest request)
  68. {
  69. var folderRoleId = new List<int> { 1, 2, 3 };
  70. if (!folderRoleId.Contains(request.RoleId) && (request.FolderType == 3 || request.FolderType == 4))
  71. throw new BusinessException("文件夹权限有误!");
  72. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  73. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  74. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  75. .Where(nameof(Entity.Middle.Middle.FolderType), request.FolderType)
  76. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  77. .Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId).Where(nameof(Entity.Middle.Middle.IsDelete), false));
  78. if (string.IsNullOrEmpty(request.FolderName))
  79. throw new BusinessException("文件名称未填写!");
  80. if (oldMiddle != null)
  81. throw new BusinessException("文件夹名称重复,请重新命名!");
  82. var middle = new Entity.Middle.Middle
  83. {
  84. FolderName = request.FolderName,
  85. FolderType = request.FolderType,
  86. IsTop = false,
  87. AttributeValue = 2,
  88. ParentId = request.ParentId,
  89. RoleId = request.RoleId,
  90. UserId = request.UserId,
  91. Sort = 0
  92. };
  93. //存在父级
  94. var middleDto = new Entity.Middle.Middle();
  95. if (request.ParentId > 0)
  96. {
  97. //获取父级数据
  98. middleDto = await _middleRepository.GetMiddleAsync(request.ParentId);
  99. if (middleDto != null)
  100. {
  101. middle.RoleId = middleDto.RoleId;
  102. request.RoleId = middleDto.RoleId;
  103. if (middleDto.ParentId == 0)
  104. middle.MiddleSonId = middleDto.Id;
  105. else middle.MiddleSonId = middleDto.MiddleSonId;
  106. }
  107. }
  108. if (request.RoleId == 0)
  109. middle.RoleId = 1;
  110. if (request.RoleId == 3)
  111. {
  112. if (request.UserIds == null)
  113. request.UserIds = new List<int>();
  114. if (request.UserIds.Count == 0 && request.UserMiddles.Count == 0 && request.ParentId == 0)
  115. throw new BusinessException("共享用户必须");
  116. }
  117. if (request.RoleId > 0)
  118. middle.RoleId = request.RoleId;
  119. var middleId = await _middleRepository.InsertAsync(middle);
  120. if (middle.ParentId == 0)
  121. {
  122. middle = await _middleRepository.GetMiddleAsync(middleId);
  123. if (middle != null)
  124. {
  125. middle.MiddleSonId = middleId;
  126. await _middleRepository.UpdateAsync(middle);
  127. }
  128. }
  129. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.Sort), middleId)
  130. .Where(nameof(Entity.Middle.Middle.Id), middleId));
  131. if (request.RoleId == 3 && request.ParentId == 0)
  132. //添加人员
  133. await InsertFolderUsers(request, middleId);
  134. return middleId;
  135. }
  136. /// <summary>
  137. /// 添加文件夹用户
  138. /// </summary>
  139. /// <param name="userIds"></param>
  140. /// <param name="middleId"></param>
  141. /// <returns></returns>
  142. public async Task<bool> InsertFolderUsers(MiddleInsertRequest request, int middleId)
  143. {
  144. //添加
  145. if (request.UserMiddles.Count > 0)
  146. {
  147. foreach (var item in request.UserMiddles)
  148. {
  149. item.DataSourceId = middleId;
  150. item.MiddleType = request.FolderType;
  151. }
  152. //添加中间表
  153. await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  154. var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, middleId);
  155. request.UserIds = users.Select(n => n.Id).ToList();
  156. }
  157. if (request.UserIds.Count > 0)
  158. {
  159. var users = await _userRepository.GetAllAsync(Q.WhereIn(nameof(Entity.User.Id), request.UserIds));
  160. //插入用户
  161. var folderUsers = new List<FolderUser>();
  162. foreach (var user in users)
  163. {
  164. var folderUser = new FolderUser();
  165. folderUser.UserId = user.Id;
  166. folderUser.UserName = user.Name;
  167. folderUser.MiddleId = middleId;
  168. folderUsers.Add(folderUser);
  169. }
  170. return await _folderUserRepository.InsertsAsync(folderUsers.ToList());
  171. }
  172. return false;
  173. }
  174. /// <summary>
  175. /// 修改文件夹名称
  176. /// </summary>
  177. /// <param name="request"></param>
  178. /// <returns></returns>
  179. public async Task<bool> UpdateNameAsync(MiddleUpdateNameRequest request)
  180. {
  181. var middle =
  182. await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.MiddleId)
  183. .Where(nameof(Entity.Middle.Middle.AttributeValue), 1));
  184. if (middle == null)
  185. throw new BusinessException("文件不存在");
  186. return await _middleRepository.UpdateAsync(
  187. Q.Set(nameof(Entity.Middle.Middle.FolderName), request.FolderName).Where(
  188. nameof(Entity.Middle.Middle.Id),
  189. request.MiddleId));
  190. }
  191. /// <summary>
  192. /// 添加数据
  193. /// </summary>
  194. /// <param name="request"></param>
  195. /// <returns></returns>
  196. public async Task<int> InsertAsync(MiddleInsertTypeRequest request)
  197. {
  198. var middle = new Entity.Middle.Middle
  199. {
  200. MiddleId = request.MiddleId,
  201. FolderType = request.FolderType,
  202. IsTop = false,
  203. AttributeValue = request.AttributeValue,
  204. ParentId = request.FolderId,
  205. UserId = request.UserId,
  206. MiddleSonId = request.MiddleSonId,
  207. IsAdmin = request.IsAdmin,
  208. NoticeAddresseeType = request.NoticeAddresseeType,
  209. Title = request.Title,
  210. IsRead = false,
  211. IsUpload = false,
  212. TitleLong = request.TitleLong,
  213. Content = "",
  214. AddressUser = request.AddressUser,
  215. CcUser = request.CcUser,
  216. CcUserComplete = request.CcUserComplete,
  217. AddressUserComplete = request.AddressUserComplete,
  218. IsRecall = false
  219. };
  220. if (request.AttributeValue == 0)
  221. middle.AttributeValue = 1;
  222. var middleId = await _middleRepository.InsertAsync(middle);
  223. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.Sort), middleId)
  224. .Where(nameof(Entity.Middle.Middle.Id), middleId));
  225. return middleId;
  226. }
  227. /// <summary>
  228. /// 添加数据
  229. /// </summary>
  230. /// <param name="request"></param>
  231. /// <returns></returns>
  232. public async Task<bool> AddOrUpdateAsync(MiddleInsertTypeRequest request)
  233. {
  234. var middle = await _middleRepository.GetMiddleAsync(Q
  235. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  236. .Where(nameof(Entity.Middle.Middle.AttributeValue), 3)
  237. .Where(nameof(Entity.Middle.Middle.FolderType), request.FolderType));
  238. if (middle == null)
  239. {
  240. middle = new Entity.Middle.Middle
  241. {
  242. MiddleId = request.MiddleId,
  243. FolderType = request.FolderType,
  244. IsTop = false,
  245. AttributeValue = request.AttributeValue,
  246. ParentId = request.FolderId,
  247. UserId = request.UserId,
  248. MiddleSonId = request.MiddleSonId
  249. };
  250. var middleId = await _middleRepository.InsertAsync(middle);
  251. //修改Middle sort
  252. await _middleRepository.UpdateAsync(Q.Where(nameof(Entity.Middle.Middle.Id), middleId).Set(nameof(Entity.Middle.Middle.Sort), middleId));
  253. return true;
  254. }
  255. return await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.IsDelete), false)
  256. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  257. .Where(nameof(Entity.Middle.Middle.AttributeValue), 3));
  258. }
  259. /// <summary>
  260. /// 排序
  261. /// </summary>
  262. /// <param name="request"></param>
  263. /// <returns></returns>
  264. public async Task<bool> MiddleSortAsync(MiddleSortRequest request)
  265. {
  266. return await _middleRepository.SetSortAsync(request);
  267. }
  268. /// <summary>
  269. /// 设置置顶
  270. /// </summary>
  271. /// <param name="id"></param>
  272. /// <returns></returns>
  273. public async Task<bool> SetTopAsync(int id)
  274. {
  275. return await _middleRepository.SetTopAsync(id);
  276. }
  277. /// <summary>
  278. /// 删除 1 通知 2话题 3 收藏 4笔记 5 普通站内信 6匿名站内信 7 小组
  279. /// </summary>
  280. /// <param name="request"></param>
  281. /// <returns></returns>
  282. public async Task<bool> DeleteAsync(NoticeDeRequest request)
  283. {
  284. try
  285. {
  286. using TransactionScope transactionScope = new TransactionScope();
  287. //查询middle
  288. var middles = await _middleRepository.FindAsync(Q.WhereIn(nameof(Entity.Middle.Middle.Id), request.MiddleIds));
  289. var ids = middles.Select(n => n.MiddleId).ToList();
  290. //收藏
  291. if (request.FolderType == AllTypeConst.Collect.GetHashCode())
  292. {
  293. //查询收藏
  294. var collections = await _collectionRepository.GetAllAsync(Q.WhereIn(nameof(Entity.Collection.Id), ids));
  295. foreach (var item in collections)
  296. {
  297. var analyzeRequest = new AnalyzeRequest();
  298. analyzeRequest.AnalyzeType = 3;
  299. analyzeRequest.SourceId = item.CollectionDataId;
  300. analyzeRequest.UserId = item.UserId;
  301. //删除文章收藏
  302. if (item.CollectionType == AllTypeConst.Article.GetHashCode())
  303. {
  304. analyzeRequest.TypeValue = item.CollectionType;
  305. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  306. if (analyze != null)
  307. await _analyzeRepository.DeleteAsync(analyze.Id);
  308. }
  309. //删除话题收藏
  310. if (item.CollectionType == AllTypeConst.Topic.GetHashCode())
  311. {
  312. analyzeRequest.TypeValue = item.CollectionType;
  313. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  314. if (analyze != null)
  315. await _analyzeRepository.DeleteAsync(analyze.Id);
  316. }
  317. //删除笔记收藏
  318. if (item.CollectionType == AllTypeConst.Note.GetHashCode())
  319. {
  320. analyzeRequest.TypeValue = item.CollectionType;
  321. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  322. if (analyze != null)
  323. await _analyzeRepository.DeleteAsync(analyze.Id);
  324. }
  325. //删除通知收藏
  326. if (item.CollectionType == AllTypeConst.Notice.GetHashCode())
  327. {
  328. analyzeRequest.TypeValue = item.CollectionType;
  329. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  330. if (analyze != null)
  331. await _analyzeRepository.DeleteAsync(analyze.Id);
  332. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true));
  333. }
  334. //删除站内信收藏
  335. if (item.CollectionType == AllTypeConst.Missive.GetHashCode())
  336. {
  337. analyzeRequest.TypeValue = item.CollectionType;
  338. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  339. if (analyze != null)
  340. await _analyzeRepository.DeleteAsync(analyze.Id);
  341. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true));
  342. }
  343. //删除收藏会议
  344. if (item.CollectionType == AllTypeConst.Meeting.GetHashCode())
  345. {
  346. analyzeRequest.TypeValue = item.CollectionType;
  347. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  348. if (analyze != null)
  349. await _analyzeRepository.DeleteAsync(analyze.Id);
  350. }
  351. //收藏笔记文件夹
  352. if (item.CollectionType == AllTypeConst.NoteFolder.GetHashCode() || item.CollectionType == AllTypeConst.CollectFolder.GetHashCode())
  353. {
  354. analyzeRequest.TypeValue = item.CollectionType;
  355. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  356. if (analyze != null)
  357. await _analyzeRepository.DeleteAsync(analyze.Id);
  358. }
  359. }
  360. //删除收藏
  361. request.IsDelete = true;
  362. //删除
  363. await _collectionRepository.RecursionDeleteAsync(request.MiddleIds);
  364. }
  365. //删除笔记
  366. if (request.FolderType == AllTypeConst.Note.GetHashCode())
  367. {
  368. await _noteRepository.UpdateAsync(Q.WhereIn(nameof(Entity.Note.Note.Id), ids).Set(nameof(Entity.Note.Note.IsDelete), true));
  369. //删除默认共享文件夹
  370. await recordFolderRepository.DeleteAsync(request.FolderType, request.UserId, request.MiddleIds);
  371. }
  372. //小组
  373. if (request.FolderType == AllTypeConst.Group.GetHashCode())
  374. await _groupRepository.DeleteAsync(Q.WhereIn(nameof(Entity.Group.Id), ids));
  375. //删除收件箱
  376. if (request.FolderType == AllTypeConst.Inbox.GetHashCode())
  377. {
  378. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true).Set(nameof(Entity.Addressee.IsRead), true));
  379. }
  380. if (request.FolderType == AllTypeConst.Inbox.GetHashCode())
  381. {
  382. foreach (var item in middles)
  383. {
  384. if (item.AttributeValue == 2)
  385. {
  386. //永久删除文件夹
  387. await _middleRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.Middle.Id), item.Id));
  388. //修改文件夹下级数据
  389. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.IsDelete), 1).Where(nameof(Entity.Middle.Middle.ParentId), item.Id));
  390. }
  391. }
  392. }
  393. //删除信源以及文件夹
  394. if (request.FolderType == AllTypeConst.Wechat.GetHashCode())
  395. {
  396. foreach (var middle in middles)
  397. {
  398. //判断是否文件夹
  399. if (middle.AttributeValue == 2)
  400. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.ParentId), 0).Where(nameof(Entity.Middle.Middle.ParentId), middle.Id).Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Wechat.GetHashCode()));
  401. }
  402. }
  403. await _middleRepository.DeleteAsync(request);
  404. transactionScope.Complete();
  405. }
  406. catch (Exception ex)
  407. {
  408. throw new BusinessException(ex.Message);
  409. }
  410. return true;
  411. }
  412. public async Task<bool> RecoverDeleteAsync(NoticeDeRequest request)
  413. {
  414. return await _middleRepository.RecoverDeleteAsync(request);
  415. }
  416. /// <summary>
  417. /// 移动到
  418. /// </summary>
  419. /// <param name="request"></param>
  420. /// <returns></returns>
  421. public async Task<bool> SetMove(MiddleMoveRequest request)
  422. {
  423. if (request.ParentId == 0 && request.TypeId == -AllTypeConst.Note.GetHashCode())
  424. request.Ids = await _middleRepository.GetMiddleIsFolderAsync(request.Ids);
  425. try
  426. {
  427. using (var transactionScope = new TransactionScope())
  428. {
  429. var middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.ParentId));
  430. if (request.ParentId > 0 && middle != null)
  431. {
  432. //获取父级子集集合
  433. var ids = await _middleRepository.GetAllMiddleChildrenByParentIdAsync(request.Ids.ToList(), request.Ids.ToList());
  434. //修改
  435. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.ParentId), request.ParentId).Set(nameof(Entity.Middle.Middle.RoleId), middle.RoleId).WhereIn(nameof(Entity.Middle.Middle.Id), request.Ids));
  436. //修改共享
  437. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.MiddleSonId), middle.MiddleSonId).WhereIn(nameof(Entity.Middle.Middle.Id), ids));
  438. }
  439. if (request.ParentId == 0)
  440. {
  441. middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.Ids.First()));
  442. if (middle.RoleId == 3)
  443. {
  444. /// <summary>
  445. /// 获取共享人员
  446. /// </summary>
  447. /// <returns></returns>
  448. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, middle.MiddleSonId);
  449. foreach (var id in request.Ids)
  450. {
  451. var userMiddleInRequest = new List<UserMiddleInRequest>();
  452. foreach (var userMiddle in userMiddles)
  453. {
  454. userMiddleInRequest.Add(new UserMiddleInRequest
  455. {
  456. MiddleType = userMiddle.MiddleType,
  457. SourceType = userMiddle.SourceType,
  458. SourceId = userMiddle.SourceId,
  459. SourceName = userMiddle.SourceName,
  460. DataSourceId = id,
  461. SourceTypeValue = userMiddle.SourceTypeValue
  462. });
  463. }
  464. //添加共享人员
  465. await _userMiddleService.AddUserMiddleAsync(userMiddleInRequest);
  466. }
  467. }
  468. //修改
  469. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.ParentId), request.ParentId).WhereIn(nameof(Entity.Middle.Middle.Id), request.Ids));
  470. foreach (var item in request.Ids)
  471. {
  472. var ids = await _middleRepository.GetAllMiddleChildrenByParentIdAsync(new List<int> { item }, new List<int> { });
  473. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.MiddleSonId), item).WhereIn(nameof(Entity.Middle.Middle.Id), ids));
  474. }
  475. }
  476. transactionScope.Complete();
  477. }
  478. }
  479. catch
  480. {
  481. return false;
  482. }
  483. return true;
  484. }
  485. /// <summary>
  486. /// 恢复全部
  487. /// </summary>
  488. /// <param name="folderType"></param>
  489. /// <returns></returns>
  490. public async Task<bool> RecoverAllAsync(int folderType, int userId)
  491. {
  492. return await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.IsDelete), false).Where(nameof(Entity.Middle.Middle.FolderType), folderType).Where(nameof(Entity.Middle.Middle.UserId), userId));
  493. }
  494. /// <summary>
  495. /// 修改文件夹名称
  496. /// </summary>
  497. /// <param name="request"></param>
  498. /// <returns></returns>
  499. public async Task<bool> UpdateFolderNameAsync(MiddleFolderNameRequest request)
  500. {
  501. var middle = await _middleRepository.GetMiddleAsync(request.Id);
  502. if (middle == null)
  503. throw new BusinessException("文件夹不存在");
  504. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  505. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  506. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  507. .Where(nameof(Entity.Middle.Middle.FolderType), middle.FolderType)
  508. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  509. .Where(nameof(Entity.Middle.Middle.IsDelete), false));
  510. if (oldMiddle != null && oldMiddle.Id != middle.Id)
  511. throw new BusinessException("文件夹名称重复,请重新命名!");
  512. return await _middleRepository.UpdateFolderNameAsync(request);
  513. }
  514. /// <summary>
  515. /// 查询文件夹
  516. /// </summary>
  517. /// <param name="request"></param>
  518. /// <returns></returns>
  519. public async Task<List<MiddleSearchFolderResult>> SearchFolderAsync(MiddleSearchFolderRequest request)
  520. {
  521. var query = Q.NewQuery();
  522. query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId)
  523. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2);
  524. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  525. query.Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode());
  526. else
  527. query.Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId);
  528. query.Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  529. .Where(nameof(Entity.Middle.Middle.IsDelete), false);
  530. if (request.FolderIds != null && request.FolderIds.Count > 0)
  531. query.WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds);
  532. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  533. query.WhereLike(nameof(Entity.Middle.Middle.FolderName), $"%{request.KeyWord}%");
  534. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  535. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 1, 3 });
  536. if (request.TypeId == AllTypeConst.Note.GetHashCode())
  537. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 2 });
  538. var middles = await _middleRepository.FindAsync(query.OrderByDesc(nameof(Entity.Middle.Middle.IsSystemDefault), nameof(Entity.Middle.Middle.IsTop), nameof(Entity.Middle.Middle.Sort), nameof(Entity.Middle.Middle.LastModifiedDate)));
  539. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  540. foreach (var item in middles)
  541. {
  542. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  543. {
  544. Name = item.FolderName,
  545. Id = item.Id,
  546. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  547. RoleId = item.RoleId,
  548. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  549. IsTop = item.IsTop,
  550. IsSystemDefault = item.IsSystemDefault
  551. };
  552. if (item.RoleId == 3)
  553. {
  554. var sourceId = item.Id;
  555. if (item.ParentId != 0)
  556. sourceId = item.MiddleSonId;
  557. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  558. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  559. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  560. }
  561. result.Add(middleSearchFolderResult);
  562. }
  563. return result;
  564. }
  565. /// <summary>
  566. /// 查询文件夹包含父级
  567. /// </summary>
  568. /// <param name="request"></param>
  569. /// <returns></returns>
  570. public async Task<MiddleSearchFolderByParendIsResult> SearchFolderAndParentIdAsync(MiddleSearchFolderRequest request)
  571. {
  572. var query = Q.NewQuery();
  573. query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId)
  574. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2);
  575. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  576. query.Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode());
  577. else
  578. query.Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId);
  579. query.Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  580. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  581. .Where(nameof(Entity.Middle.Middle.IsDelete), false).WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds);
  582. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  583. query.WhereLike(nameof(Entity.Middle.Middle.FolderName), $"%{request.KeyWord}%");
  584. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  585. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 1, 3 });
  586. if (request.TypeId == AllTypeConst.Note.GetHashCode())
  587. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 2 });
  588. var middles = await _middleRepository.FindAsync(query.OrderByDesc(nameof(Entity.Middle.Middle.IsTop), nameof(Entity.Middle.Middle.Sort), nameof(Entity.Middle.Middle.LastModifiedDate)));
  589. var middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.ParentId));
  590. var result = new MiddleSearchFolderByParendIsResult() { Name = middle == null ? "" : middle.FolderName };
  591. if (middle != null && middle.ParentId > 0)
  592. {
  593. middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), middle.ParentId));
  594. result.Id = middle == null ? 0 : middle.Id;
  595. result.Name = middle == null ? "" : middle.FolderName;
  596. }
  597. result.Item = new List<MiddleSearchFolderResult>();
  598. foreach (var item in middles)
  599. {
  600. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  601. {
  602. Name = item.FolderName,
  603. Id = item.Id,
  604. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  605. RoleId = item.RoleId,
  606. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  607. IsTop = item.IsTop
  608. };
  609. if (item.RoleId == 3)
  610. {
  611. var sourceId = item.Id;
  612. if (item.ParentId != 0)
  613. sourceId = item.MiddleSonId;
  614. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  615. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  616. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  617. }
  618. result.Item.Add(middleSearchFolderResult);
  619. }
  620. return result;
  621. }
  622. /// <summary>
  623. /// 修改权限
  624. /// </summary>
  625. /// <param name="request"></param>
  626. /// <returns></returns>
  627. public async Task<bool> UpdateFolderRoleAsync(MiddleUpdateFolderRoleRequest request)
  628. {
  629. var middle = await _middleRepository.GetMiddleAsync(request.MiddleId);
  630. if (middle == null)
  631. throw new BusinessException("文件夹不存在");
  632. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  633. .Where(nameof(Entity.Middle.Middle.UserId), middle.UserId)
  634. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  635. .Where(nameof(Entity.Middle.Middle.FolderType), middle.FolderType)
  636. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  637. .Where(nameof(Entity.Middle.Middle.ParentId), middle.ParentId).Where(nameof(Entity.Middle.Middle.IsDelete), false));
  638. if (string.IsNullOrEmpty(request.FolderName))
  639. throw new BusinessException("文件名称未填写");
  640. if (oldMiddle != null && oldMiddle.Id != middle.Id)
  641. throw new BusinessException("文件夹名称重复,请重新命名!");
  642. if (middle.RoleId == 3)
  643. {
  644. if (request.RoleId != 3)
  645. {
  646. //删除共享用户
  647. await _folderUserRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.FolderUser.MiddleId), middle.Id));
  648. //删除
  649. await _userMiddleService.DeleteAsync(middle.Id, middle.FolderType);
  650. }
  651. }
  652. if (request.RoleId == 3 && middle.ParentId == 0)
  653. {
  654. if (request.UserIds.Count == 0 && request.UserMiddles.Count == 0)
  655. throw new BusinessException("共享成员必须");
  656. //添加人员
  657. await _folderUserRepository.DeleteAsync(Q.Where(nameof(FolderUser.MiddleId), request.MiddleId));
  658. var middleInsertRequest = new MiddleInsertRequest();
  659. middleInsertRequest.UserIds = request.UserIds;
  660. middleInsertRequest.UserMiddles = request.UserMiddles;
  661. middleInsertRequest.FolderType = middle.FolderType;
  662. if (request.UserMiddles.Count > 0)
  663. {
  664. //删除原有的数据
  665. await _userMiddleService.DeleteAsync(middle.Id, middle.FolderType);
  666. //await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  667. //查询用户
  668. // var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, middle.UserId);
  669. // middleInsertRequest.UserIds = users.Select(n => n.Id).ToList();
  670. }
  671. await InsertFolderUsers(middleInsertRequest, request.MiddleId);
  672. }
  673. middle.RoleId = request.RoleId;
  674. middle.FolderName = request.FolderName;
  675. await _middleRepository.UpdateAsync(middle);
  676. //修改子集权限
  677. if (middle.ParentId == 0)
  678. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.RoleId), request.RoleId).Where(nameof(Entity.Middle.Middle.MiddleSonId), middle.Id));
  679. return true;
  680. }
  681. /// <summary>
  682. /// 修改共享文件夹下的所有文件夹属性
  683. /// </summary>
  684. /// <param name="request"></param>
  685. /// <returns></returns>
  686. public async Task<bool> UpdateChildrenMiddleFolder(MiddleUpdateFolderRoleRequest request)
  687. {
  688. //获取下级数据
  689. var middles = await _middleRepository.GetMiddleChildrenAsync(request.MiddleId);
  690. if (middles.Count() == 0)
  691. return true;
  692. foreach (var item in middles)
  693. {
  694. if (request.UserMiddles.Count > 0)
  695. {
  696. var middleInsertRequest = new MiddleInsertRequest();
  697. middleInsertRequest.UserIds = request.UserIds;
  698. middleInsertRequest.UserMiddles = request.UserMiddles;
  699. //删除原有的数据
  700. await _userMiddleService.DeleteAsync(item.Id, item.FolderType);
  701. await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  702. //查询用户
  703. var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, item.UserId);
  704. middleInsertRequest.UserIds = users.Select(n => n.Id).ToList();
  705. //插入共享成员
  706. await InsertFolderUsers(middleInsertRequest, request.MiddleId);
  707. item.RoleId = request.RoleId;
  708. item.FolderName = request.FolderName;
  709. //修改
  710. await _middleRepository.UpdateAsync(item);
  711. request.MiddleId = item.Id;
  712. //修改下级权限和共享范围人
  713. await UpdateChildrenMiddleFolder(request);
  714. }
  715. }
  716. return true;
  717. }
  718. /// <summary>
  719. /// 根据文件夹ID获取文件夹信息
  720. /// </summary>
  721. /// <param name="middleId"></param>
  722. /// <returns></returns>
  723. public async Task<MiddleFolderInfoResult> GetFolderInfo(int middleId)
  724. {
  725. if (middleId == 0)
  726. throw new Common.Exceptions.BusinessException("文件夹不存在");
  727. var result = new MiddleFolderInfoResult();
  728. var middle = await _middleRepository.GetMiddleAsync(middleId);
  729. result.Id = middle.Id;
  730. result.FolderName = middle.FolderName;
  731. result.FolderType = middle.FolderType == 3 ? 12 : 13;
  732. result.UserId = middle.UserId;
  733. result.RoleId = middle.RoleId;
  734. result.FolderUsers = await _folderUserRepository.GetAllAsync(middleId);
  735. //获取共享人员
  736. if (result.RoleId == 3)
  737. {
  738. var sourceId = middle.Id;
  739. if (middle.ParentId > 0)
  740. sourceId = middle.MiddleSonId;
  741. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, sourceId);
  742. result.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  743. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), middle.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  744. // result.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  745. }
  746. result.UserMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, middleId);
  747. return result;
  748. }
  749. /// <summary>
  750. /// 获取默认的共享文件夹范围
  751. /// </summary>
  752. /// <param name="userId"></param>
  753. /// <returns></returns>
  754. public async Task<MiddleDefaultResult> GetEnjoyDefaultAsync(int userId, int folderType)
  755. {
  756. // var middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.UserId), userId).WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 1, 3 }).Where(nameof(Entity.Middle.Middle.IsDefault), true));
  757. // var result = new MiddleDefaultResult();
  758. // result.IsDefault = middle != null;
  759. // result.FolderName = middle == null ? "" : middle.FolderName;
  760. // result.MiddleId = middle == null ? 0 : middle.Id;
  761. var recordFolder = await recordFolderRepository.GetAsync(folderType, userId);
  762. var result = new MiddleDefaultResult();
  763. //获取笔记默认
  764. if (recordFolder.Id == 0 && folderType == 21)
  765. {
  766. var middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode()).Where(nameof(Entity.Middle.Middle.AttributeValue), 2).Where(nameof(Entity.Middle.Middle.IsSystemDefault), true).Where(nameof(Entity.Middle.Middle.UserId), userId));
  767. result.IsDefault = middle != null ? middle.IsSystemDefault : false;
  768. result.FolderName = middle != null ? middle.FolderName : "";
  769. result.FolderType = middle != null ? middle.FolderType : 0;
  770. result.MiddleId = middle == null ? middle.Id : 0;
  771. return result;
  772. }
  773. result = new MiddleDefaultResult();
  774. result.IsDefault = recordFolder != null;
  775. result.FolderName = recordFolder == null ? "" : recordFolder.FolderName;
  776. result.FolderType = recordFolder == null ? 0 : recordFolder.FolderType;
  777. result.MiddleId = recordFolder == null ? 0 : recordFolder.FolderId;
  778. return result;
  779. }
  780. /// <summary>
  781. /// 获取话题 笔记共享范围文件夹
  782. /// </summary>
  783. /// <param name="request"></param>
  784. /// <returns></returns>
  785. public async Task<List<MiddleSearchFolderResult>> SearchNoteFolderAsync(MiddleSearchFolderRequest request)
  786. {
  787. string sqlStr = string.Empty;
  788. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  789. sqlStr += $" and FolderName like '%{request.KeyWord}%'";
  790. string sql = $@"SELECT
  791. *
  792. FROM
  793. tede_middle
  794. WHERE
  795. FolderType ={request.TypeId} AND AttributeValue = 2 {sqlStr}
  796. AND UserId = {request.UserId}
  797. AND RoleId IN (1 , 3)
  798. AND IsDelete = 0
  799. AND ParentId ={request.ParentId}
  800. ORDER BY IsSystemDefault DESC,AttributeValue desc , IsTop DESC , Sort DESC , CreatedDate DESC";
  801. var database = new Database(DatabaseType.MySql, ConfigHelper.GetValue("Database:ConnectionString"));
  802. var connection = database.GetConnection();
  803. var middles =await connection.QueryAsync<Entity.Middle.Middle>(sql);
  804. // var query = Q.NewQuery();
  805. // if (request.ParentId >= 0)
  806. // query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId);
  807. // query.Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  808. // .Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId)
  809. // .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  810. // .Where(nameof(Entity.Middle.Middle.IsDelete), false);
  811. // if (request.FolderIds.Count > 0)
  812. // query.WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds);
  813. // query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int>() { 1, 3 });
  814. // if (!string.IsNullOrWhiteSpace(request.KeyWord))
  815. // query.WhereLike(nameof(Entity.Middle.Middle.FolderName), $"%{request.KeyWord}%");
  816. // var orderByDesc = new string[] { nameof(Entity.Middle.Middle.IsSystemDefault), nameof(Entity.Middle.Middle.AttributeValue), nameof(Entity.Middle.Middle.IsTop), nameof(Entity.Middle.Middle.Sort) };
  817. // var middles = await _middleRepository.FindAsync(query.OrderByDesc(orderByDesc));
  818. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  819. foreach (var item in middles)
  820. {
  821. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  822. {
  823. Name = item.FolderName,
  824. Id = item.Id,
  825. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  826. RoleId = item.RoleId,
  827. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  828. IsTop = item.IsTop,
  829. FileCount = await _middleRepository.CountAsync(Q.Where(nameof(Entity.Middle.Middle.ParentId), item.Id).Where(nameof(Entity.Middle.Middle.IsDelete), false)),
  830. IsSystemDefault = item.IsSystemDefault
  831. };
  832. if (item.RoleId == 3)
  833. {
  834. var sourceId = item.Id;
  835. if (item.ParentId != 0)
  836. sourceId = item.MiddleSonId;
  837. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  838. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  839. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  840. //middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  841. }
  842. result.Add(middleSearchFolderResult);
  843. }
  844. return result;
  845. }
  846. /// <summary>
  847. /// 获取话题最近使用的文件夹
  848. /// </summary>
  849. /// <param name="request"></param>
  850. /// <returns></returns>
  851. public async Task<List<MiddleSearchFolderResult>> GetLatelyNoteFolderAsync(int userId)
  852. {
  853. //获取用户最近发布的话题
  854. var folderIds = await _noteRepository.GetLatelyFolderIdAsync(userId);
  855. var query = Q.NewQuery();
  856. query.Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  857. .Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode())
  858. .Where(nameof(Entity.Middle.Middle.UserId), userId)
  859. .Where(nameof(Entity.Middle.Middle.IsDelete), false)
  860. .WhereIn(nameof(Entity.Middle.Middle.Id), folderIds);
  861. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int>() { 1, 3 });
  862. var middles = await _middleRepository.FindAsync(query.OrderByDesc(nameof(Entity.Middle.Middle.CreatedDate)));
  863. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  864. foreach (var item in middles)
  865. {
  866. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  867. {
  868. Name = item.FolderName,
  869. Id = item.Id,
  870. IsDisable = false,
  871. RoleId = item.RoleId,
  872. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  873. IsTop = item.IsTop
  874. };
  875. if (item.RoleId == 3)
  876. {
  877. var sourceId = item.Id;
  878. if (item.ParentId != 0)
  879. sourceId = item.MiddleSonId;
  880. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  881. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  882. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  883. //middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  884. }
  885. result.Add(middleSearchFolderResult);
  886. }
  887. return result;
  888. }
  889. /// <summary> =-
  890. /// 删除全部
  891. /// </summary>
  892. /// <param name="folderType"></param>
  893. /// <param name="userId"></param>
  894. /// <returns></returns>
  895. public async Task<bool> DeleteAllAsync(int folderType, int userId)
  896. {
  897. return await _middleRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.Middle.FolderType), folderType).Where(nameof(Entity.Middle.Middle.UserId), userId).Where(nameof(Entity.Middle.Middle.IsDelete), true));
  898. }
  899. }
  900. }