MiddleService.cs 52 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000
  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. var middleIds = request.MiddleIds;
  288. //获取
  289. await _middleRepository.GetAllMiddleChildrenByParentIdAsync(request.MiddleIds, middleIds);
  290. request.MiddleIds = middleIds;
  291. //查询middle
  292. var middles = await _middleRepository.FindAsync(Q.WhereIn(nameof(Entity.Middle.Middle.Id), request.MiddleIds));
  293. var ids = middles.Select(n => n.MiddleId).ToList();
  294. //收藏
  295. if (request.FolderType == AllTypeConst.Collect.GetHashCode())
  296. {
  297. //查询收藏
  298. var collections = await _collectionRepository.GetAllAsync(Q.WhereIn(nameof(Entity.Collection.Id), ids));
  299. foreach (var item in collections)
  300. {
  301. var analyzeRequest = new AnalyzeRequest();
  302. analyzeRequest.AnalyzeType = 3;
  303. analyzeRequest.SourceId = item.CollectionDataId;
  304. analyzeRequest.UserId = item.UserId;
  305. //删除文章收藏
  306. if (item.CollectionType == AllTypeConst.Article.GetHashCode())
  307. {
  308. analyzeRequest.TypeValue = item.CollectionType;
  309. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  310. if (analyze != null)
  311. await _analyzeRepository.DeleteAsync(analyze.Id);
  312. }
  313. //删除话题收藏
  314. if (item.CollectionType == AllTypeConst.Topic.GetHashCode())
  315. {
  316. analyzeRequest.TypeValue = item.CollectionType;
  317. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  318. if (analyze != null)
  319. await _analyzeRepository.DeleteAsync(analyze.Id);
  320. }
  321. //删除笔记收藏
  322. if (item.CollectionType == AllTypeConst.Note.GetHashCode())
  323. {
  324. analyzeRequest.TypeValue = item.CollectionType;
  325. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  326. if (analyze != null)
  327. await _analyzeRepository.DeleteAsync(analyze.Id);
  328. }
  329. //删除通知收藏
  330. if (item.CollectionType == AllTypeConst.Notice.GetHashCode())
  331. {
  332. analyzeRequest.TypeValue = item.CollectionType;
  333. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  334. if (analyze != null)
  335. await _analyzeRepository.DeleteAsync(analyze.Id);
  336. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true));
  337. }
  338. //删除站内信收藏
  339. if (item.CollectionType == AllTypeConst.Missive.GetHashCode())
  340. {
  341. analyzeRequest.TypeValue = item.CollectionType;
  342. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  343. if (analyze != null)
  344. await _analyzeRepository.DeleteAsync(analyze.Id);
  345. await _addresseeRepository.UpdateAsync(Q.Where(nameof(Entity.Addressee.UserId), request.UserId).WhereIn(nameof(Entity.Addressee.SourceId), ids).Set(nameof(Entity.Addressee.IsDelete), true));
  346. }
  347. //删除收藏会议
  348. if (item.CollectionType == AllTypeConst.Meeting.GetHashCode())
  349. {
  350. analyzeRequest.TypeValue = item.CollectionType;
  351. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  352. if (analyze != null)
  353. await _analyzeRepository.DeleteAsync(analyze.Id);
  354. }
  355. //收藏笔记文件夹
  356. if (item.CollectionType == AllTypeConst.NoteFolder.GetHashCode() || item.CollectionType == AllTypeConst.CollectFolder.GetHashCode())
  357. {
  358. analyzeRequest.TypeValue = item.CollectionType;
  359. var analyze = await analyzeService.GetAnalyzeAsync(analyzeRequest);
  360. if (analyze != null)
  361. await _analyzeRepository.DeleteAsync(analyze.Id);
  362. }
  363. }
  364. //删除收藏
  365. request.IsDelete = true;
  366. //删除
  367. await _collectionRepository.RecursionDeleteAsync(request.MiddleIds);
  368. }
  369. //删除笔记
  370. if (request.FolderType == AllTypeConst.Note.GetHashCode())
  371. {
  372. await _noteRepository.UpdateAsync(Q.WhereIn(nameof(Entity.Note.Note.Id), ids).Set(nameof(Entity.Note.Note.IsDelete), true));
  373. //删除默认共享文件夹
  374. await recordFolderRepository.DeleteAsync(request.FolderType, request.UserId, request.MiddleIds);
  375. }
  376. //小组
  377. if (request.FolderType == AllTypeConst.Group.GetHashCode())
  378. await _groupRepository.DeleteAsync(Q.WhereIn(nameof(Entity.Group.Id), ids));
  379. //删除收件箱
  380. if (request.FolderType == AllTypeConst.Inbox.GetHashCode())
  381. {
  382. 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));
  383. }
  384. if (request.FolderType == AllTypeConst.Inbox.GetHashCode())
  385. {
  386. foreach (var item in middles)
  387. {
  388. if (item.AttributeValue == 2)
  389. {
  390. //永久删除文件夹
  391. await _middleRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.Middle.Id), item.Id));
  392. //修改文件夹下级数据
  393. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.IsDelete), 1).Where(nameof(Entity.Middle.Middle.ParentId), item.Id));
  394. }
  395. }
  396. }
  397. //删除信源以及文件夹
  398. if (request.FolderType == AllTypeConst.Wechat.GetHashCode())
  399. {
  400. foreach (var middle in middles)
  401. {
  402. //判断是否文件夹
  403. if (middle.AttributeValue == 2)
  404. 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()));
  405. }
  406. }
  407. await _middleRepository.DeleteAsync(request);
  408. transactionScope.Complete();
  409. }
  410. catch (Exception ex)
  411. {
  412. throw new BusinessException(ex.Message);
  413. }
  414. return true;
  415. }
  416. public async Task<bool> RecoverDeleteAsync(NoticeDeRequest request)
  417. {
  418. return await _middleRepository.RecoverDeleteAsync(request);
  419. }
  420. /// <summary>
  421. /// 移动到
  422. /// </summary>
  423. /// <param name="request"></param>
  424. /// <returns></returns>
  425. public async Task<bool> SetMove(MiddleMoveRequest request)
  426. {
  427. if (request.ParentId == 0 && request.TypeId == -AllTypeConst.Note.GetHashCode())
  428. request.Ids = await _middleRepository.GetMiddleIsFolderAsync(request.Ids);
  429. try
  430. {
  431. using (var transactionScope = new TransactionScope())
  432. {
  433. var middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.ParentId));
  434. if (request.ParentId > 0 && middle != null)
  435. {
  436. //获取父级子集集合
  437. var ids = await _middleRepository.GetAllMiddleChildrenByParentIdAsync(request.Ids.ToList(), request.Ids.ToList());
  438. //修改
  439. 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));
  440. //修改共享
  441. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.MiddleSonId), middle.MiddleSonId).WhereIn(nameof(Entity.Middle.Middle.Id), ids));
  442. }
  443. if (request.ParentId == 0)
  444. {
  445. middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.Ids.First()));
  446. if (middle.RoleId == 3)
  447. {
  448. /// <summary>
  449. /// 获取共享人员
  450. /// </summary>
  451. /// <returns></returns>
  452. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, middle.MiddleSonId);
  453. foreach (var id in request.Ids)
  454. {
  455. var userMiddleInRequest = new List<UserMiddleInRequest>();
  456. foreach (var userMiddle in userMiddles)
  457. {
  458. userMiddleInRequest.Add(new UserMiddleInRequest
  459. {
  460. MiddleType = userMiddle.MiddleType,
  461. SourceType = userMiddle.SourceType,
  462. SourceId = userMiddle.SourceId,
  463. SourceName = userMiddle.SourceName,
  464. DataSourceId = id,
  465. SourceTypeValue = userMiddle.SourceTypeValue
  466. });
  467. }
  468. //添加共享人员
  469. await _userMiddleService.AddUserMiddleAsync(userMiddleInRequest);
  470. }
  471. }
  472. //修改
  473. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.ParentId), request.ParentId).WhereIn(nameof(Entity.Middle.Middle.Id), request.Ids));
  474. foreach (var item in request.Ids)
  475. {
  476. var ids = await _middleRepository.GetAllMiddleChildrenByParentIdAsync(new List<int> { item }, new List<int> { });
  477. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.MiddleSonId), item).WhereIn(nameof(Entity.Middle.Middle.Id), ids));
  478. }
  479. }
  480. transactionScope.Complete();
  481. }
  482. }
  483. catch
  484. {
  485. return false;
  486. }
  487. return true;
  488. }
  489. /// <summary>
  490. /// 恢复全部
  491. /// </summary>
  492. /// <param name="folderType"></param>
  493. /// <returns></returns>
  494. public async Task<bool> RecoverAllAsync(int folderType, int userId)
  495. {
  496. 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));
  497. }
  498. /// <summary>
  499. /// 修改文件夹名称
  500. /// </summary>
  501. /// <param name="request"></param>
  502. /// <returns></returns>
  503. public async Task<bool> UpdateFolderNameAsync(MiddleFolderNameRequest request)
  504. {
  505. var middle = await _middleRepository.GetMiddleAsync(request.Id);
  506. if (middle == null)
  507. throw new BusinessException("文件夹不存在");
  508. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  509. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  510. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  511. .Where(nameof(Entity.Middle.Middle.FolderType), middle.FolderType)
  512. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  513. .Where(nameof(Entity.Middle.Middle.IsDelete), false));
  514. if (oldMiddle != null && oldMiddle.Id != middle.Id)
  515. throw new BusinessException("文件夹名称重复,请重新命名!");
  516. return await _middleRepository.UpdateFolderNameAsync(request);
  517. }
  518. /// <summary>
  519. /// 查询文件夹
  520. /// </summary>
  521. /// <param name="request"></param>
  522. /// <returns></returns>
  523. public async Task<List<MiddleSearchFolderResult>> SearchFolderAsync(MiddleSearchFolderRequest request)
  524. {
  525. var query = Q.NewQuery();
  526. query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId)
  527. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2);
  528. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  529. query.Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode());
  530. else
  531. query.Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId);
  532. query.Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  533. .Where(nameof(Entity.Middle.Middle.IsDelete), false);
  534. if (request.FolderIds != null && request.FolderIds.Count > 0)
  535. query.WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds);
  536. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  537. query.WhereLike(nameof(Entity.Middle.Middle.FolderName), $"%{request.KeyWord}%");
  538. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  539. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 1, 3 });
  540. if (request.TypeId == AllTypeConst.Note.GetHashCode())
  541. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 2 });
  542. 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)));
  543. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  544. foreach (var item in middles)
  545. {
  546. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  547. {
  548. Name = item.FolderName,
  549. Id = item.Id,
  550. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  551. RoleId = item.RoleId,
  552. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  553. IsTop = item.IsTop,
  554. IsSystemDefault = item.IsSystemDefault
  555. };
  556. if (item.RoleId == 3)
  557. {
  558. var sourceId = item.Id;
  559. if (item.ParentId != 0)
  560. sourceId = item.MiddleSonId;
  561. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  562. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  563. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  564. }
  565. result.Add(middleSearchFolderResult);
  566. }
  567. return result;
  568. }
  569. /// <summary>
  570. /// 查询文件夹包含父级
  571. /// </summary>
  572. /// <param name="request"></param>
  573. /// <returns></returns>
  574. public async Task<MiddleSearchFolderByParendIsResult> SearchFolderAndParentIdAsync(MiddleSearchFolderRequest request)
  575. {
  576. var query = Q.NewQuery();
  577. query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId)
  578. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2);
  579. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  580. query.Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode());
  581. else
  582. query.Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId);
  583. query.Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  584. .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  585. .Where(nameof(Entity.Middle.Middle.IsDelete), false).WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds);
  586. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  587. query.WhereLike(nameof(Entity.Middle.Middle.FolderName), $"%{request.KeyWord}%");
  588. if (request.TypeId == -AllTypeConst.Note.GetHashCode())
  589. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 1, 3 });
  590. if (request.TypeId == AllTypeConst.Note.GetHashCode())
  591. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int> { 2 });
  592. var middles = await _middleRepository.FindAsync(query.OrderByDesc(nameof(Entity.Middle.Middle.IsTop), nameof(Entity.Middle.Middle.Sort), nameof(Entity.Middle.Middle.LastModifiedDate)));
  593. var middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), request.ParentId));
  594. var result = new MiddleSearchFolderByParendIsResult() { Name = middle == null ? "" : middle.FolderName };
  595. if (middle != null && middle.ParentId > 0)
  596. {
  597. middle = await _middleRepository.GetMiddleAsync(Q.Where(nameof(Entity.Middle.Middle.Id), middle.ParentId));
  598. result.Id = middle == null ? 0 : middle.Id;
  599. result.Name = middle == null ? "" : middle.FolderName;
  600. }
  601. result.Item = new List<MiddleSearchFolderResult>();
  602. foreach (var item in middles)
  603. {
  604. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  605. {
  606. Name = item.FolderName,
  607. Id = item.Id,
  608. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  609. RoleId = item.RoleId,
  610. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  611. IsTop = item.IsTop
  612. };
  613. if (item.RoleId == 3)
  614. {
  615. var sourceId = item.Id;
  616. if (item.ParentId != 0)
  617. sourceId = item.MiddleSonId;
  618. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  619. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  620. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  621. }
  622. result.Item.Add(middleSearchFolderResult);
  623. }
  624. return result;
  625. }
  626. /// <summary>
  627. /// 修改权限
  628. /// </summary>
  629. /// <param name="request"></param>
  630. /// <returns></returns>
  631. public async Task<bool> UpdateFolderRoleAsync(MiddleUpdateFolderRoleRequest request)
  632. {
  633. var middle = await _middleRepository.GetMiddleAsync(request.MiddleId);
  634. if (middle == null)
  635. throw new BusinessException("文件夹不存在");
  636. var oldMiddle = await _middleRepository.GetMiddleAsync(Q
  637. .Where(nameof(Entity.Middle.Middle.UserId), middle.UserId)
  638. .Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  639. .Where(nameof(Entity.Middle.Middle.FolderType), middle.FolderType)
  640. .Where(nameof(Entity.Middle.Middle.FolderName), request.FolderName)
  641. .Where(nameof(Entity.Middle.Middle.ParentId), middle.ParentId).Where(nameof(Entity.Middle.Middle.IsDelete), false));
  642. if (string.IsNullOrEmpty(request.FolderName))
  643. throw new BusinessException("文件名称未填写");
  644. if (oldMiddle != null && oldMiddle.Id != middle.Id)
  645. throw new BusinessException("文件夹名称重复,请重新命名!");
  646. if (middle.RoleId == 3)
  647. {
  648. if (request.RoleId != 3)
  649. {
  650. //删除共享用户
  651. await _folderUserRepository.DeleteAsync(Q.Where(nameof(Entity.Middle.FolderUser.MiddleId), middle.Id));
  652. //删除
  653. await _userMiddleService.DeleteAsync(middle.Id, middle.FolderType);
  654. }
  655. }
  656. if (request.RoleId == 3 && middle.ParentId == 0)
  657. {
  658. if (request.UserIds.Count == 0 && request.UserMiddles.Count == 0)
  659. throw new BusinessException("共享成员必须");
  660. //添加人员
  661. await _folderUserRepository.DeleteAsync(Q.Where(nameof(FolderUser.MiddleId), request.MiddleId));
  662. var middleInsertRequest = new MiddleInsertRequest();
  663. middleInsertRequest.UserIds = request.UserIds;
  664. middleInsertRequest.UserMiddles = request.UserMiddles;
  665. middleInsertRequest.FolderType = middle.FolderType;
  666. if (request.UserMiddles.Count > 0)
  667. {
  668. //删除原有的数据
  669. await _userMiddleService.DeleteAsync(middle.Id, middle.FolderType);
  670. //await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  671. //查询用户
  672. // var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, middle.UserId);
  673. // middleInsertRequest.UserIds = users.Select(n => n.Id).ToList();
  674. }
  675. await InsertFolderUsers(middleInsertRequest, request.MiddleId);
  676. }
  677. middle.RoleId = request.RoleId;
  678. middle.FolderName = request.FolderName;
  679. await _middleRepository.UpdateAsync(middle);
  680. //修改子集权限
  681. if (middle.ParentId == 0)
  682. await _middleRepository.UpdateAsync(Q.Set(nameof(Entity.Middle.Middle.RoleId), request.RoleId).Where(nameof(Entity.Middle.Middle.MiddleSonId), middle.Id));
  683. return true;
  684. }
  685. /// <summary>
  686. /// 修改共享文件夹下的所有文件夹属性
  687. /// </summary>
  688. /// <param name="request"></param>
  689. /// <returns></returns>
  690. public async Task<bool> UpdateChildrenMiddleFolder(MiddleUpdateFolderRoleRequest request)
  691. {
  692. //获取下级数据
  693. var middles = await _middleRepository.GetMiddleChildrenAsync(request.MiddleId);
  694. if (middles.Count() == 0)
  695. return true;
  696. foreach (var item in middles)
  697. {
  698. if (request.UserMiddles.Count > 0)
  699. {
  700. var middleInsertRequest = new MiddleInsertRequest();
  701. middleInsertRequest.UserIds = request.UserIds;
  702. middleInsertRequest.UserMiddles = request.UserMiddles;
  703. //删除原有的数据
  704. await _userMiddleService.DeleteAsync(item.Id, item.FolderType);
  705. await _userMiddleService.AddUserMiddleAsync(request.UserMiddles);
  706. //查询用户
  707. var users = await _userMiddleService.FindUsersAsync(request.UserMiddles, item.UserId);
  708. middleInsertRequest.UserIds = users.Select(n => n.Id).ToList();
  709. //插入共享成员
  710. await InsertFolderUsers(middleInsertRequest, request.MiddleId);
  711. item.RoleId = request.RoleId;
  712. item.FolderName = request.FolderName;
  713. //修改
  714. await _middleRepository.UpdateAsync(item);
  715. request.MiddleId = item.Id;
  716. //修改下级权限和共享范围人
  717. await UpdateChildrenMiddleFolder(request);
  718. }
  719. }
  720. return true;
  721. }
  722. /// <summary>
  723. /// 根据文件夹ID获取文件夹信息
  724. /// </summary>
  725. /// <param name="middleId"></param>
  726. /// <returns></returns>
  727. public async Task<MiddleFolderInfoResult> GetFolderInfo(int middleId)
  728. {
  729. if (middleId == 0)
  730. throw new Common.Exceptions.BusinessException("文件夹不存在");
  731. var result = new MiddleFolderInfoResult();
  732. var middle = await _middleRepository.GetMiddleAsync(middleId);
  733. result.Id = middle.Id;
  734. result.FolderName = middle.FolderName;
  735. result.FolderType = middle.FolderType == 3 ? 12 : 13;
  736. result.UserId = middle.UserId;
  737. result.RoleId = middle.RoleId;
  738. result.FolderUsers = await _folderUserRepository.GetAllAsync(middleId);
  739. //获取共享人员
  740. if (result.RoleId == 3)
  741. {
  742. var sourceId = middle.Id;
  743. if (middle.ParentId > 0)
  744. sourceId = middle.MiddleSonId;
  745. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, sourceId);
  746. result.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  747. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), middle.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  748. // result.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  749. }
  750. result.UserMiddles = await _userMiddleService.FindUserMiddlesAsync(middle.FolderType, middleId);
  751. return result;
  752. }
  753. /// <summary>
  754. /// 获取默认的共享文件夹范围
  755. /// </summary>
  756. /// <param name="userId"></param>
  757. /// <returns></returns>
  758. public async Task<MiddleDefaultResult> GetEnjoyDefaultAsync(int userId, int folderType)
  759. {
  760. // 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));
  761. // var result = new MiddleDefaultResult();
  762. // result.IsDefault = middle != null;
  763. // result.FolderName = middle == null ? "" : middle.FolderName;
  764. // result.MiddleId = middle == null ? 0 : middle.Id;
  765. var recordFolder = await recordFolderRepository.GetAsync(folderType, userId);
  766. var result = new MiddleDefaultResult();
  767. //获取笔记默认
  768. if (recordFolder.Id == 0 && folderType == 21)
  769. {
  770. 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));
  771. result.IsDefault = middle != null ? middle.IsSystemDefault : false;
  772. result.FolderName = middle != null ? middle.FolderName : "";
  773. result.FolderType = middle != null ? middle.FolderType : 0;
  774. result.MiddleId = middle == null ? middle.Id : 0;
  775. return result;
  776. }
  777. result = new MiddleDefaultResult();
  778. result.IsDefault = recordFolder != null;
  779. result.FolderName = recordFolder == null ? "" : recordFolder.FolderName;
  780. result.FolderType = recordFolder == null ? 0 : recordFolder.FolderType;
  781. result.MiddleId = recordFolder == null ? 0 : recordFolder.FolderId;
  782. return result;
  783. }
  784. /// <summary>
  785. /// 获取话题 笔记共享范围文件夹
  786. /// </summary>
  787. /// <param name="request"></param>
  788. /// <returns></returns>
  789. public async Task<List<MiddleSearchFolderResult>> SearchNoteFolderAsync(MiddleSearchFolderRequest request)
  790. {
  791. string sqlStr = string.Empty;
  792. if (!string.IsNullOrWhiteSpace(request.KeyWord))
  793. sqlStr += $" and FolderName like '%{request.KeyWord}%'";
  794. string sql = $@"SELECT
  795. *
  796. FROM
  797. tede_middle
  798. WHERE
  799. FolderType ={request.TypeId} AND AttributeValue = 2 {sqlStr}
  800. AND UserId = {request.UserId}
  801. AND RoleId IN (1 , 3)
  802. AND IsDelete = 0
  803. AND ParentId ={request.ParentId}
  804. ORDER BY IsSystemDefault DESC,AttributeValue desc , IsTop DESC , Sort DESC , CreatedDate DESC";
  805. var database = new Database(DatabaseType.MySql, ConfigHelper.GetValue("Database:ConnectionString"));
  806. var connection = database.GetConnection();
  807. var middles = await connection.QueryAsync<Entity.Middle.Middle>(sql);
  808. // var query = Q.NewQuery();
  809. // if (request.ParentId >= 0)
  810. // query.Where(nameof(Entity.Middle.Middle.ParentId), request.ParentId);
  811. // query.Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  812. // .Where(nameof(Entity.Middle.Middle.FolderType), request.TypeId)
  813. // .Where(nameof(Entity.Middle.Middle.UserId), request.UserId)
  814. // .Where(nameof(Entity.Middle.Middle.IsDelete), false);
  815. // if (request.FolderIds.Count > 0)
  816. // query.WhereNotIn(nameof(Entity.Middle.Middle.Id), request.FolderIds);
  817. // query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int>() { 1, 3 });
  818. // if (!string.IsNullOrWhiteSpace(request.KeyWord))
  819. // query.WhereLike(nameof(Entity.Middle.Middle.FolderName), $"%{request.KeyWord}%");
  820. // var orderByDesc = new string[] { nameof(Entity.Middle.Middle.IsSystemDefault), nameof(Entity.Middle.Middle.AttributeValue), nameof(Entity.Middle.Middle.IsTop), nameof(Entity.Middle.Middle.Sort) };
  821. // var middles = await _middleRepository.FindAsync(query.OrderByDesc(orderByDesc));
  822. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  823. foreach (var item in middles)
  824. {
  825. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  826. {
  827. Name = item.FolderName,
  828. Id = item.Id,
  829. IsDisable = request.FolderIds.Any(n => n.Equals(item.Id)),
  830. RoleId = item.RoleId,
  831. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  832. IsTop = item.IsTop,
  833. FileCount = await _middleRepository.CountAsync(Q.Where(nameof(Entity.Middle.Middle.ParentId), item.Id).Where(nameof(Entity.Middle.Middle.IsDelete), false)),
  834. IsSystemDefault = item.IsSystemDefault
  835. };
  836. if (item.RoleId == 3)
  837. {
  838. var sourceId = item.Id;
  839. if (item.ParentId != 0)
  840. sourceId = item.MiddleSonId;
  841. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  842. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  843. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  844. //middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  845. }
  846. result.Add(middleSearchFolderResult);
  847. }
  848. return result;
  849. }
  850. /// <summary>
  851. /// 获取话题最近使用的文件夹
  852. /// </summary>
  853. /// <param name="request"></param>
  854. /// <returns></returns>
  855. public async Task<List<MiddleSearchFolderResult>> GetLatelyTopicFolderAsync(int userId)
  856. {
  857. //获取用户最近发布的话题
  858. var folderIds = await _noteRepository.GetLatelyFolderIdAsync(userId, true);
  859. var query = Q.NewQuery();
  860. query.Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  861. .Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode())
  862. .Where(nameof(Entity.Middle.Middle.UserId), userId)
  863. .Where(nameof(Entity.Middle.Middle.IsDelete), false)
  864. .WhereIn(nameof(Entity.Middle.Middle.Id), folderIds);
  865. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int>() { 1, 3 });
  866. var models = await _middleRepository.FindAsync(query.OrderByDesc(nameof(Entity.Middle.Middle.CreatedDate)));
  867. var middles = new List<Entity.Middle.Middle>();
  868. foreach (var folderId in folderIds.Distinct())
  869. {
  870. foreach (var item in models)
  871. {
  872. if (item.Id == folderId)
  873. {
  874. middles.Add(item);
  875. break;
  876. }
  877. }
  878. }
  879. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  880. foreach (var item in middles)
  881. {
  882. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  883. {
  884. Name = item.FolderName,
  885. Id = item.Id,
  886. IsDisable = false,
  887. RoleId = item.RoleId,
  888. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  889. IsTop = item.IsTop
  890. };
  891. if (item.RoleId == 3)
  892. {
  893. var sourceId = item.Id;
  894. if (item.ParentId != 0)
  895. sourceId = item.MiddleSonId;
  896. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  897. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  898. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  899. //middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  900. }
  901. result.Add(middleSearchFolderResult);
  902. }
  903. return result;
  904. }
  905. /// <summary>
  906. /// 获取笔记最近使用的文件夹
  907. /// </summary>
  908. /// <param name="request"></param>
  909. /// <returns></returns>
  910. public async Task<List<MiddleSearchFolderResult>> GetLatelyNoteFolderAsync(int userId)
  911. {
  912. //获取用户最近发布的话题
  913. var folderIds = await _noteRepository.GetLatelyFolderIdAsync(userId, false);
  914. var query = Q.NewQuery();
  915. query.Where(nameof(Entity.Middle.Middle.AttributeValue), 2)
  916. .Where(nameof(Entity.Middle.Middle.FolderType), AllTypeConst.Note.GetHashCode())
  917. .Where(nameof(Entity.Middle.Middle.UserId), userId)
  918. .Where(nameof(Entity.Middle.Middle.IsDelete), false)
  919. .WhereIn(nameof(Entity.Middle.Middle.Id), folderIds);
  920. query.WhereIn(nameof(Entity.Middle.Middle.RoleId), new List<int>() { 2 });
  921. var models = await _middleRepository.FindAsync(query.OrderByDesc(nameof(Entity.Middle.Middle.CreatedDate)));
  922. var middles = new List<Entity.Middle.Middle>();
  923. foreach (var folderId in folderIds.Distinct())
  924. {
  925. foreach (var item in models)
  926. {
  927. if (item.Id == folderId)
  928. {
  929. middles.Add(item);
  930. break;
  931. }
  932. }
  933. }
  934. List<MiddleSearchFolderResult> result = new List<MiddleSearchFolderResult>();
  935. foreach (var item in middles)
  936. {
  937. MiddleSearchFolderResult middleSearchFolderResult = new MiddleSearchFolderResult
  938. {
  939. Name = item.FolderName,
  940. Id = item.Id,
  941. IsDisable = false,
  942. RoleId = item.RoleId,
  943. IsFolder = await _middleRepository.IsFolderAsync(item.Id),
  944. IsTop = item.IsTop
  945. };
  946. if (item.RoleId == 3)
  947. {
  948. var sourceId = item.Id;
  949. if (item.ParentId != 0)
  950. sourceId = item.MiddleSonId;
  951. var userMiddles = await _userMiddleService.FindUserMiddlesAsync(item.FolderType, sourceId);
  952. // var folderUsers = await _folderUserRepository.GetAllAsync(Q.Where(nameof(FolderUser.MiddleId), item.Id).OrderByDesc(nameof(FolderUser.CreatedDate)).Take(10));
  953. middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(userMiddles.Select(n => n.SourceName), "、");
  954. //middleSearchFolderResult.EnjoyUser = StringUtils.ObjectCollectionToString(folderUsers.Select(n => n.UserName), "、");
  955. }
  956. result.Add(middleSearchFolderResult);
  957. }
  958. return result;
  959. }
  960. /// <summary> =-
  961. /// 删除全部
  962. /// </summary>
  963. /// <param name="folderType"></param>
  964. /// <param name="userId"></param>
  965. /// <returns></returns>
  966. public async Task<bool> DeleteAllAsync(int folderType, int userId)
  967. {
  968. 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));
  969. }
  970. }
  971. }