MiddleService.cs 53 KB

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