NewsController.java 16 KB

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