NewsController.java 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. package com.xjrsoft.module.oa.controller;
  2. import cn.dev33.satoken.stp.StpUtil;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import cn.hutool.core.util.ObjectUtil;
  5. import cn.hutool.core.util.StrUtil;
  6. import com.baomidou.mybatisplus.core.conditions.Wrapper;
  7. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  8. import com.baomidou.mybatisplus.core.metadata.IPage;
  9. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  10. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  11. import com.xjrsoft.common.constant.GlobalConstant;
  12. import com.xjrsoft.common.enums.DeleteMark;
  13. import com.xjrsoft.common.model.result.RT;
  14. import com.xjrsoft.common.page.ConventPage;
  15. import com.xjrsoft.common.page.PageOutput;
  16. import com.xjrsoft.common.utils.VoToColumnUtil;
  17. import com.xjrsoft.module.oa.dto.*;
  18. import com.xjrsoft.module.oa.entity.News;
  19. import com.xjrsoft.module.oa.entity.NewsAppendix;
  20. import com.xjrsoft.module.oa.entity.NewsRelation;
  21. import com.xjrsoft.module.oa.entity.NewsRelationConfig;
  22. import com.xjrsoft.module.oa.service.INewsAppendixService;
  23. import com.xjrsoft.module.oa.service.INewsRelationConfigService;
  24. import com.xjrsoft.module.oa.service.INewsRelationService;
  25. import com.xjrsoft.module.oa.service.INewsService;
  26. import com.xjrsoft.module.oa.vo.*;
  27. import com.xjrsoft.module.system.entity.File;
  28. import com.xjrsoft.module.teacher.entity.XjrUser;
  29. import io.swagger.annotations.Api;
  30. import io.swagger.annotations.ApiOperation;
  31. import lombok.AllArgsConstructor;
  32. import org.apache.commons.lang3.BooleanUtils;
  33. import org.springframework.web.bind.annotation.*;
  34. import java.time.LocalDateTime;
  35. import java.util.ArrayList;
  36. import java.util.List;
  37. /**
  38. * <p>
  39. * 新闻中心表 前端控制器
  40. * </p>
  41. *
  42. * @author zlf
  43. * @since 2022-06-16
  44. */
  45. @RestController
  46. @RequestMapping(GlobalConstant.OA_MODULE_PREFIX + "/news")
  47. @Api(value = GlobalConstant.OA_MODULE_PREFIX + "/news", tags = "新闻公告")
  48. @AllArgsConstructor
  49. public class NewsController {
  50. private INewsService newsService;
  51. private INewsRelationService newsRelationService;
  52. private INewsAppendixService newsAppendixService;
  53. private INewsRelationConfigService newsRelationConfigService;
  54. @GetMapping
  55. @ApiOperation(value = "获取新闻分页")
  56. public RT<PageOutput<NewsPageVo>> page(NewsPageDto dto) {
  57. Wrapper<News> wrapper = Wrappers.<News>query().lambda()
  58. .eq(News::getTypeId, dto.getType())
  59. .like(StrUtil.isNotBlank(dto.getKeyword()), News::getFullHead, dto.getKeyword())
  60. .select(News.class, x -> VoToColumnUtil.fieldsToColumns(NewsPageVo.class).contains(x.getProperty()))
  61. .orderByDesc(News::getSendEndDate);
  62. IPage<News> page = newsService.page(ConventPage.getPage(dto), wrapper);
  63. PageOutput<NewsPageVo> pageOutput = ConventPage.getPageOutput(page, NewsPageVo.class);
  64. return RT.ok(pageOutput);
  65. }
  66. @GetMapping("/manage-box")
  67. @ApiOperation(value = "获取管理新闻分页")
  68. public RT<PageOutput<NewsPageVo>> manageBox(NewsPageDto dto) {
  69. IPage<NewsPageVo> page = newsService.manageBox(dto);
  70. PageOutput<NewsPageVo> pageOutput = ConventPage.getPageOutput(page, NewsPageVo.class);
  71. return RT.ok(pageOutput);
  72. }
  73. @GetMapping("/receipt-box")
  74. @ApiOperation(value = "获取接受新闻分页")
  75. public RT<PageOutput<NewsPageVo>> receiptBox(NewsPageDto dto) {
  76. IPage<NewsPageVo> page = newsService.receiptBox(dto);
  77. PageOutput<NewsPageVo> pageOutput = ConventPage.getPageOutput(page, NewsPageVo.class);
  78. return RT.ok(pageOutput);
  79. }
  80. @PostMapping
  81. @ApiOperation(value = "新增新闻")
  82. public RT<Boolean> add(@RequestBody AddNewsDto addNewsDto) {
  83. return RT.ok(newsService.add(addNewsDto));
  84. }
  85. @GetMapping(value = "/info")
  86. @ApiOperation(value = "新闻详情")
  87. public RT<NewsVo> info(@RequestParam Long id, @RequestParam(required = false) Boolean isRead) {
  88. News news = newsService.getById(id);
  89. if (news == null) {
  90. RT.error("找不到此新闻!");
  91. }
  92. LambdaQueryWrapper<NewsRelation> queryWrapper = new LambdaQueryWrapper<>();
  93. queryWrapper
  94. .eq(NewsRelation::getNewsId , id)
  95. .select(NewsRelation.class, x -> VoToColumnUtil.fieldsToColumns(NewsRelation.class).contains(x.getProperty()));
  96. List<NewsRelationVo> newsRelationVoList = new ArrayList<>();
  97. if(ObjectUtil.isNotNull(news.getCreateUserId()) && StpUtil.getLoginIdAsLong() == news.getCreateUserId()){
  98. List<NewsRelation> newsRelationList = newsRelationService.list(queryWrapper);
  99. newsRelationList.stream().forEach(element -> {
  100. // 对元素进行操作
  101. NewsRelationVo newsRelationVo = BeanUtil.toBean(element, NewsRelationVo.class);
  102. newsRelationVoList.add(newsRelationVo);
  103. });
  104. }else{
  105. queryWrapper.eq(NewsRelation::getUserId , StpUtil.getLoginIdAsLong());
  106. NewsRelation newsRelation = newsRelationService.getOne(queryWrapper);
  107. NewsRelationVo newsRelationVo = BeanUtil.toBean(newsRelation, NewsRelationVo.class);
  108. newsRelationVoList.add(newsRelationVo);
  109. }
  110. NewsVo newsVo = BeanUtil.toBean(news, NewsVo.class);
  111. newsVo.setRelationList(newsRelationVoList);
  112. if (BooleanUtils.isTrue(isRead)) {
  113. // NewsRelation newsRelation = new NewsRelation();
  114. // newsRelation.setNewsId(id);
  115. // newsRelation.setUserId(StpUtil.getLoginIdAsLong());
  116. // newsRelationService.remove(Wrappers.<NewsRelation>query().lambda()
  117. // .eq(NewsRelation::getUserId, StpUtil.getLoginIdAsLong())
  118. // .eq(NewsRelation::getNewsId, id));
  119. // newsRelationService.save(newsRelation);
  120. }
  121. // List<NewsRelationVo> newsRelationVoList = newsRelationService.selectJoinList(NewsRelationVo.class,
  122. // new MPJLambdaWrapper<NewsRelation>()
  123. // .eq(NewsRelation::getNewsId, id)
  124. // .select(NewsRelation::getId)
  125. // .select(NewsRelation.class, x -> VoToColumnUtil.fieldsToColumns(NewsRelationVo.class).contains(x.getProperty()))
  126. // .leftJoin(XjrUser.class, XjrUser::getId, NewsRelation::getUserId, ext -> ext.selectAs(XjrUser::getName, NewsRelationVo::getUserName)));
  127. // if (newsRelationVoList.size() > 0) {
  128. // newsVo.setRelationList(newsRelationVoList);
  129. // }
  130. List<NewsAppendixVo> newsAppendixVoList = newsAppendixService.selectJoinList(NewsAppendixVo.class,
  131. new MPJLambdaWrapper<NewsAppendix>().eq(NewsAppendix::getNewsId, id)
  132. .select(NewsRelation::getId)
  133. .select(NewsAppendix.class, x -> VoToColumnUtil.fieldsToColumns(NewsAppendixVo.class).contains(x.getProperty()))
  134. .leftJoin(File.class, File::getId, NewsAppendix::getFileId, ext -> ext.selectAs(File::getFileName, NewsAppendixVo::getFileName)
  135. .selectAs(File::getFolderId, NewsAppendixVo::getFolderId)
  136. .selectAs(File::getFileUrl, NewsAppendixVo::getFileUrl))
  137. );
  138. if (newsAppendixVoList.size() > 0) {
  139. newsVo.setAppendixList(newsAppendixVoList);
  140. }
  141. return RT.ok(newsVo);
  142. }
  143. @PutMapping
  144. @ApiOperation(value = "修改新闻")
  145. public RT<Boolean> update(@RequestBody UpdateNewsDto updateNewsDto) {
  146. //News news = BeanUtil.toBean(updateNewsDto, News.class);
  147. return RT.ok(newsService.update(updateNewsDto));
  148. }
  149. @DeleteMapping
  150. @ApiOperation(value = "删除新闻")
  151. public RT<Boolean> delete(@RequestBody List<Long> ids) {
  152. return RT.ok(newsService.delete(ids));
  153. }
  154. @PutMapping("/change-status")
  155. @ApiOperation(value = "发布或下架新闻")
  156. public RT<Boolean> changeStatus(@RequestBody ChangeNewsDto changeNewsDto) throws Exception {
  157. News xjrNews = newsService.getById(changeNewsDto.getId());
  158. if (changeNewsDto.getStatus() == null || xjrNews == null) {
  159. throw new Exception("参数异常");
  160. }
  161. if (changeNewsDto.getStatus().equals(xjrNews.getStatus())) {
  162. if (changeNewsDto.getStatus() == 2) {
  163. throw new Exception("新闻已发布!!!");
  164. } else if (changeNewsDto.getStatus() == 3) {
  165. throw new Exception("新闻已下架!!!");
  166. }
  167. }
  168. //将原来的修改enabled_mark改为修改status
  169. xjrNews.setStatus(changeNewsDto.getStatus());
  170. if(xjrNews.getStatus() == 2){
  171. newsService.SendMessage(xjrNews.getId());
  172. }
  173. return RT.ok(newsService.updateById(xjrNews));
  174. }
  175. @PutMapping("/read")
  176. @ApiOperation(value = "读新闻")
  177. public RT<Boolean> read(@RequestBody List<Long> ids) {
  178. List<NewsRelation> toSaveList = newsRelationService.list(
  179. Wrappers.<NewsRelation>query().lambda()
  180. .in(NewsRelation::getNewsId, ids)
  181. .eq(NewsRelation::getUserId, StpUtil.getLoginIdAsLong()));
  182. for (NewsRelation newsRelation : toSaveList) {
  183. newsRelation.setReadMark(1);
  184. newsRelation.setReadDate(LocalDateTime.now());
  185. }
  186. // newsRelationService.remove(Wrappers.<NewsRelation>query().lambda()
  187. // .in(NewsRelation::getNewsId, ids)
  188. // .eq(NewsRelation::getUserId, StpUtil.getLoginIdAsLong()));
  189. return RT.ok(newsRelationService.updateBatchById(toSaveList));
  190. }
  191. @PutMapping("/reply")
  192. @ApiOperation(value = "新闻回复")
  193. public RT<Boolean> reply(@RequestBody NewsReplyDto newsReplyDto) {
  194. NewsRelation newsRelation = newsRelationService.getOne(
  195. Wrappers.<NewsRelation>query().lambda()
  196. .eq(NewsRelation::getNewsId, newsReplyDto.getId())
  197. .eq(NewsRelation::getUserId, StpUtil.getLoginIdAsLong()));
  198. if (newsRelation == null) {
  199. newsRelation = new NewsRelation();
  200. newsRelation.setNewsId(newsReplyDto.getId());
  201. newsRelation.setUserId(StpUtil.getLoginIdAsLong());
  202. newsRelation.setReadMark(1);
  203. newsRelation.setReadDate(LocalDateTime.now());
  204. newsRelation.setReplyContent(newsReplyDto.getReplyContent());
  205. return RT.ok(newsRelationService.save(newsRelation));
  206. }
  207. if (newsRelation.getReadMark() == null || newsRelation.getReadMark() == 0) {
  208. newsRelation.setReadMark(1);
  209. newsRelation.setReadDate(LocalDateTime.now());
  210. }
  211. newsRelation.setReplyContent(newsReplyDto.getReplyContent());
  212. return RT.ok(newsRelationService.updateById(newsRelation));
  213. }
  214. @GetMapping("/page-relation")
  215. @ApiOperation(value = "获取新闻阅读权限分页")
  216. public RT<PageOutput<NewsRelationVo>> pageRelation(NewsRelationPageDto dto) {
  217. IPage<NewsRelationVo> page = newsRelationService.selectJoinListPage(ConventPage.getPage(dto), NewsRelationVo.class,
  218. new MPJLambdaWrapper<NewsRelation>()
  219. .eq(NewsRelation::getNewsId, dto.getNewsId())
  220. .eq(ObjectUtil.isNotEmpty(dto.getReadMark()) && dto.getReadMark() > 0, NewsRelation::getReadMark, dto.getReadMark() == 1 ? 0 : 1)
  221. .isNull(ObjectUtil.isNotEmpty(dto.getReplyMark()) && dto.getReplyMark() == 1, NewsRelation::getReplyContent)
  222. .isNotNull(ObjectUtil.isNotEmpty(dto.getReplyMark()) && dto.getReplyMark() == 2, NewsRelation::getReplyContent)
  223. .select(NewsRelation::getId)
  224. .select(NewsRelation.class, x -> VoToColumnUtil.fieldsToColumns(NewsRelationVo.class).contains(x.getProperty()))
  225. .leftJoin(XjrUser.class, XjrUser::getId, NewsRelation::getUserId, ext -> ext.selectAs(XjrUser::getName, NewsRelationVo::getUserName))
  226. );
  227. PageOutput<NewsRelationVo> pageOutput = ConventPage.getPageOutput(page);
  228. return RT.ok(pageOutput);
  229. }
  230. @GetMapping("/page-relation-config")
  231. @ApiOperation(value = "获取新闻权限分页")
  232. public RT<PageOutput<NewsRelationConfigVo>> pageRelationConfig(NewsRelationPageDto dto) {
  233. Wrapper<NewsRelationConfig> wrapper = Wrappers.<NewsRelationConfig>query().lambda()
  234. .eq(NewsRelationConfig::getNewsId, dto.getNewsId())
  235. .select(NewsRelationConfig.class, x -> VoToColumnUtil.fieldsToColumns(NewsRelationConfigVo.class).contains(x.getProperty()));
  236. IPage<NewsRelationConfig> page = newsRelationConfigService.page(ConventPage.getPage(dto), wrapper);
  237. PageOutput<NewsRelationConfigVo> pageOutput = ConventPage.getPageOutput(page, NewsRelationConfigVo.class);
  238. return RT.ok(pageOutput);
  239. }
  240. @GetMapping("/count-relation")
  241. @ApiOperation(value = "新闻阅读权限统计")
  242. public RT<Long[]> countRelation(@RequestParam Long id) {
  243. Long total = newsRelationService.count(Wrappers.<NewsRelation>query().lambda().eq(NewsRelation::getNewsId, id));
  244. Long notRead = newsRelationService.count(Wrappers.<NewsRelation>query().lambda().eq(NewsRelation::getNewsId, id).eq(NewsRelation::getReadMark, 0));
  245. Long isRead = newsRelationService.count(Wrappers.<NewsRelation>query().lambda().eq(NewsRelation::getNewsId, id).eq(NewsRelation::getReadMark, 1));
  246. Long isReply = newsRelationService.count(Wrappers.<NewsRelation>query().lambda().eq(NewsRelation::getNewsId, id).isNull(NewsRelation::getReplyContent));
  247. Long notReply = newsRelationService.count(Wrappers.<NewsRelation>query().lambda().eq(NewsRelation::getNewsId, id).isNotNull(NewsRelation::getReplyContent));
  248. Long[] arrayRefVar = {total, notRead, isRead, isReply, notReply};
  249. return RT.ok(arrayRefVar);
  250. }
  251. @PutMapping("/update-relation")
  252. @ApiOperation(value = "设置新闻阅读权限")
  253. public RT<Boolean> updateRelation(@RequestBody UpdateNewsRelationDto updateRelationDto) {
  254. return RT.ok(newsService.updateRelation(updateRelationDto));
  255. }
  256. @DeleteMapping("/delete-relation")
  257. @ApiOperation(value = "删除新闻阅读权限")
  258. public RT<Boolean> deleteRelation(@RequestBody DeleteNewsRelationDto deleteNewsRelationDto) {
  259. return RT.ok(newsService.deleteRelation(deleteNewsRelationDto));
  260. }
  261. @GetMapping("/count-type")
  262. @ApiOperation(value = "未读类型统计")
  263. public RT<List<NewsCountTypeVo>> countType() {
  264. List<NewsCountTypeVo> newsCountTypeVoList = new ArrayList<>();
  265. Integer typeIds[] = {1, 2, 3};
  266. for (Integer typeId : typeIds) {
  267. Long totalType = newsRelationService.count(Wrappers.<NewsRelation>query().lambda().eq(NewsRelation::getUserId, StpUtil.getLoginIdAsLong()).eq(NewsRelation::getReadMark, 0).in(NewsRelation::getNewsId, "SELECT id from xjr_oa_news where type_id=" + typeId));
  268. NewsCountTypeVo newsCountTypeVo = new NewsCountTypeVo();
  269. newsCountTypeVo.setTypeId(typeId);
  270. newsCountTypeVo.setTotal(totalType);
  271. News news = new News();
  272. if(typeId == 1){
  273. news = newsService.getOne(Wrappers.<News>query().lambda().eq(News::getTypeId, typeId).orderByDesc(News::getReleaseTime).last("limit 1"));
  274. }
  275. if(typeId == 2){
  276. news = newsService.selectJoinOne(News.class,
  277. new MPJLambdaWrapper<News>()
  278. .disableSubLogicDel()
  279. .eq(News::getTypeId, typeId)
  280. .eq(NewsRelation::getUserId, StpUtil.getLoginIdAsLong())
  281. .orderByDesc(News::getReleaseTime)
  282. .last("limit 1")
  283. .innerJoin(NewsRelation.class, NewsRelation::getNewsId, News::getId));
  284. }
  285. if (news != null) {
  286. newsCountTypeVo.setTime(news.getReleaseTime());
  287. newsCountTypeVo.setTitle(news.getBriefHead());
  288. }
  289. newsCountTypeVoList.add(newsCountTypeVo);
  290. }
  291. return RT.ok(newsCountTypeVoList);
  292. }
  293. @GetMapping("/send-message")
  294. @ApiOperation(value = "发送消息")
  295. public RT<Boolean> sendMessage(@RequestParam Long id) {
  296. return RT.ok(newsService.SendMessage(id));
  297. }
  298. @GetMapping("/unread-count")
  299. @ApiOperation(value = "获取登录人未读消息数量")
  300. public RT<Integer> unreadCount() {
  301. Integer count = newsService.selectJoinCount(
  302. new MPJLambdaWrapper<News>()
  303. .eq(NewsRelation::getReadMark, 0)
  304. .eq(NewsRelation::getUserId, StpUtil.getLoginIdAsLong())
  305. .eq(News::getDeleteMark, DeleteMark.NODELETE.getCode())
  306. .innerJoin(NewsRelation.class, NewsRelation::getNewsId, News::getId)
  307. );
  308. return RT.ok(count);
  309. }
  310. }