package org.springblade.modules.article.controller; import com.alibaba.fastjson.JSON; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import lombok.AllArgsConstructor; import org.apache.commons.lang3.StringUtils; import org.springblade.core.mp.support.Condition; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.Func; import org.springblade.modules.article.entity.Article; import org.springblade.modules.article.service.ArticleService; import org.springblade.modules.article.vo.ArticleVO; import org.springframework.web.bind.annotation.*; import javax.validation.Valid; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * @author zhongrj * @title 资讯控制层 */ @RestController @AllArgsConstructor @RequestMapping("/blade-article/article") @Api(value = "通知", tags = "通知") public class ArticleController { private final ArticleService articleService; /** * 查询资讯分页信息 * @param article 资讯对象 * @param query 查询参数 * @return */ @GetMapping("/pageWeb") public R> pageWeb(ArticleVO article, Query query) { return R.data(articleService.selectArticlePage(Condition.getPage(query), article)); } /** * 查询资讯分页信息-app * @param article 资讯对象 * @param query 查询参数 * @return */ @GetMapping("/page") public R> page(ArticleVO article, Query query) { return R.data(articleService.selectArticlePageByApp(Condition.getPage(query), article)); } /** * 敏感词预警 * @param article 资讯对象 * @param query 查询参数 * @return */ @GetMapping("/pageWords") public R> pageWords(ArticleVO article, Query query) { return R.data(articleService.pageWords(Condition.getPage(query), article)); } /** * 查询资讯分页信息(角色权限) * @param article 资讯对象 * @param query 查询参数 * @return */ @GetMapping("/pageDate") public R> pageDate(ArticleVO article, Query query) { return R.data(articleService.pageDate(Condition.getPage(query), article)); } @GetMapping("/pageCollectList") public R> pageCollectList(ArticleVO article, Query query) { return R.data(articleService.pageCollectList(Condition.getPage(query), article)); } /** * 查询资讯分页信息(角色权限)附带点赞评论数 * @param article 资讯对象 * @param query 查询参数 * @return */ @GetMapping("/pageLikes") public R> pageLikes(ArticleVO article, Query query) { return R.data(articleService.pageLikes(Condition.getPage(query), article)); } /** * 查询已收藏的资讯 */ @GetMapping("/pageCollect") public R> pageCollect(ArticleVO article, Query query) { return R.data(articleService.pageCollect(Condition.getPage(query), article)); } /** * 资讯详情 * * @param article 资讯查询对象 */ @GetMapping("/detail") @ApiOperationSupport(order = 1) @ApiOperation(value = "详情", notes = "传入articleoy") public R
detail(ArticleVO article) { ArticleVO detail = articleService.getArticleOne(article); UpdateWrapper
objectUpdateWrapper = new UpdateWrapper<>(); objectUpdateWrapper.setSql("view_number = view_number + 1"); objectUpdateWrapper.eq("id", article.getId()); articleService.update(null, objectUpdateWrapper); List> lists = new ArrayList<>(); if (StringUtils.isNotBlank(detail.getArticleRange())) { lists = (List>) JSON.parse(detail.getArticleRange()); } detail.setArticleList(lists); return R.data(detail); } /** * 新增资讯信息 * * @param article 资讯对象 */ @PostMapping("/save") @ApiOperationSupport(order = 4) @ApiOperation(value = "新增", notes = "传入article") public R save(@Valid Article article) { return R.status(articleService.save(article)); } /** * 修改资讯信息 * @param article 资讯对象 */ @PostMapping("/update") @ApiOperationSupport(order = 5) @ApiOperation(value = "修改", notes = "传入article") public R update(@Valid @RequestBody Article article) { return R.status(articleService.updateById(article)); } /** * 新增或修改资讯信息 * * @param article 资讯对象信息 */ @PostMapping("/submit") public R submit(@RequestBody ArticleVO article) { if (null == article.getId()) { if (null == article.getCreateTime()) { article.setCreateTime(new Date()); } } article.setUpdateTime(new Date()); return R.status(articleService.saveOrUpdate(article)); } /** * 删除资讯信息 * @param ids 资讯主键id,id集合 */ @PostMapping("/remove") @ApiOperationSupport(order = 8) @ApiOperation(value = "删除", notes = "传入ids") public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) { return R.status(articleService.removeByIds(Func.toLongList(ids))); } /** * 批量修改评论区状态 */ @PostMapping("/upcomment") public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids, String type) { String[] split = ids.split(","); String strArrays = ""; for (int i = 0; i < split.length; i++) { strArrays += "'" + split[i] + "',"; } String code = strArrays.substring(0, strArrays.length() - 1); return R.status(articleService.upcomment(code, type)); } /** * 查询个人资讯 * @param article * @param query * @return */ @GetMapping("/selectArticleG") public R> selectArticleG(ArticleVO article, Query query) { return R.data(articleService.selectArticleG(Condition.getPage(query), article)); } /** * 通知公告表浏览数量加一 */ @PostMapping("/addNumber") @ApiOperationSupport(order = 8) @ApiOperation(value = "添加浏览数量", notes = "传入notice") public R addNumber(@Valid @RequestBody Article notice) { UpdateWrapper
objectUpdateWrapper = new UpdateWrapper<>(); objectUpdateWrapper.setSql("view_number = view_number + 1"); objectUpdateWrapper.eq("id",notice.getId()); return R.status(articleService.update(null ,objectUpdateWrapper)); } }