From 72aaf45389cd09c206ee1b90f0c7f5bf59782930 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期三, 22 十月 2025 18:27:49 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TSysProductIntroductionController.java | 214 +++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 212 insertions(+), 2 deletions(-)
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TSysProductIntroductionController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TSysProductIntroductionController.java
index c14d574..cc4b1c9 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TSysProductIntroductionController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TSysProductIntroductionController.java
@@ -1,8 +1,31 @@
package com.ruoyi.web.controller.api;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.ruoyi.common.annotation.Log;
+import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.common.constant.Constants;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.redis.RedisCache;
+import com.ruoyi.common.enums.BusinessType;
+import com.ruoyi.framework.web.service.TokenService;
+import com.ruoyi.system.model.TSysActivity;
+import com.ruoyi.system.model.TSysEducationalInfo;
+import com.ruoyi.system.model.TSysLive;
+import com.ruoyi.system.model.TSysProductIntroduction;
+import com.ruoyi.system.query.TSysProductIntroductionQuery;
+import com.ruoyi.system.service.TSysActivityService;
+import com.ruoyi.system.service.TSysEducationalInfoService;
+import com.ruoyi.system.service.TSysLiveService;
+import com.ruoyi.system.service.TSysProductIntroductionService;
+import com.ruoyi.system.vo.TSysProductIntroductionVO;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.*;
/**
* <p>
@@ -12,9 +35,196 @@
* @author xiaochen
* @since 2025-08-20
*/
+@Api(tags = "产品介绍")
@RestController
@RequestMapping("/t-sys-product-introduction")
public class TSysProductIntroductionController {
+ private final TSysProductIntroductionService sysProductIntroductionService;
+ private final TokenService tokenService;
+ private final RedisCache redisCache;
+ private final TSysEducationalInfoService sysEducationalInfoService;
+ private final TSysActivityService sysActivityService;
+ private final TSysLiveService sysLiveService;
+ @Autowired
+ public TSysProductIntroductionController(TSysProductIntroductionService sysProductIntroductionService, TokenService tokenService, RedisCache redisCache, TSysEducationalInfoService sysEducationalInfoService, TSysActivityService sysActivityService, TSysLiveService sysLiveService) {
+ this.sysProductIntroductionService = sysProductIntroductionService;
+ this.tokenService = tokenService;
+ this.redisCache = redisCache;
+ this.sysEducationalInfoService = sysEducationalInfoService;
+ this.sysActivityService = sysActivityService;
+ this.sysLiveService = sysLiveService;
+ }
+
+ /**
+ * 获取产品介绍管理列表
+ */
+ @ApiOperation(value = "获取产品介绍分页列表")
+ @PostMapping(value = "/pageList")
+ public R<PageInfo<TSysProductIntroductionVO>> pageList(@RequestBody TSysProductIntroductionQuery query) {
+ Integer roleType = tokenService.getLoginUser().getUser().getRoleType();
+ Long userId = tokenService.getLoginUser().getUserId();
+ if(roleType == 5){
+ query.setRoleType(roleType);
+ query.setUserId(userId);
+ }
+ return R.ok(sysProductIntroductionService.pageList(query));
+ }
+
+ /**
+ * 获取产品介绍管理列表
+ */
+ @ApiOperation(value = "获取产品介绍列表")
+ @PostMapping(value = "/list")
+ public R<List<TSysProductIntroduction>> list() {
+ return R.ok(sysProductIntroductionService.list(Wrappers.lambdaQuery(TSysProductIntroduction.class).orderByDesc(TSysProductIntroduction::getCreateTime)));
+ }
+
+ /**
+ * 获取产品介绍管理列表
+ */
+ @ApiOperation(value = "获取产品介绍列表-banner使用")
+ @PostMapping(value = "/listBanner")
+ public R<List<TSysProductIntroduction>> listBanner() {
+ return R.ok(sysProductIntroductionService.list(Wrappers.lambdaQuery(TSysProductIntroduction.class)
+ .eq(TSysProductIntroduction::getStatus,1)
+ .eq(TSysProductIntroduction::getShowType,1)
+ .orderByDesc(TSysProductIntroduction::getCreateTime)));
+ }
+
+ /**
+ * 添加产品介绍管理
+ */
+ @Log(title = "产品介绍信息-新增产品介绍", businessType = BusinessType.INSERT)
+ @ApiOperation(value = "添加产品介绍")
+ @PostMapping(value = "/add")
+ public R<Boolean> add(@Validated @RequestBody TSysProductIntroduction dto) {
+ return R.ok(sysProductIntroductionService.save(dto));
+ }
+
+ /**
+ * 修改产品介绍
+ */
+ @Log(title = "产品介绍信息-修改产品介绍", businessType = BusinessType.UPDATE)
+ @ApiOperation(value = "修改产品介绍")
+ @PostMapping(value = "/update")
+ public R<Boolean> update(@Validated @RequestBody TSysProductIntroduction dto) {
+ return R.ok(sysProductIntroductionService.updateById(dto));
+ }
+
+ /**
+ * 查看产品介绍详情
+ */
+ @ApiOperation(value = "查看产品介绍详情")
+ @GetMapping(value = "/getDetailById")
+ public R<TSysProductIntroduction> getDetailById(@RequestParam String id) {
+ TSysProductIntroduction sysProductIntroduction = sysProductIntroductionService.getById(id);
+ // 查询次数自增 使用数据库原子更新操作
+ sysProductIntroductionService.update(
+ Wrappers.<TSysProductIntroduction>lambdaUpdate()
+ .setSql("click_count = click_count + 1")
+ .eq(TSysProductIntroduction::getId, id)
+ );
+ // 如果是诊所
+ Integer roleType = tokenService.getLoginUser().getUser().getRoleType();
+ if(roleType == 5){
+ Long userId = tokenService.getLoginUser().getUserId();
+ Set<Long> clickCount = new HashSet<>();
+ clickCount.add(userId);
+ redisCache.setCacheSet(Constants.SYS_PRODUCT_CLICK_COUNT+id,clickCount);
+ }
+ return R.ok(sysProductIntroduction);
+ }
+
+ /**
+ * 删除产品介绍
+ */
+ @Log(title = "产品介绍信息-删除产品介绍", businessType = BusinessType.DELETE)
+ @ApiOperation(value = "删除产品介绍")
+ @DeleteMapping(value = "/deleteById")
+ public R<Boolean> deleteById(@RequestParam String id) {
+ return R.ok(sysProductIntroductionService.removeById(id));
+ }
+
+ /**
+ * 批量删除产品介绍
+ */
+ @Log(title = "产品介绍信息-删除产品介绍", businessType = BusinessType.DELETE)
+ @ApiOperation(value = "批量删除产品介绍")
+ @DeleteMapping(value = "/deleteByIds")
+ public R<Boolean> deleteByIds(@RequestBody List<String> ids) {
+ return R.ok(sysProductIntroductionService.removeByIds(ids));
+ }
+
+ /**
+ * 产品介绍上下架
+ */
+ @Log(title = "产品介绍信息-上下架", businessType = BusinessType.UPDATE)
+ @ApiOperation(value = "产品介绍信息上下架")
+ @PutMapping(value = "/upAndDown")
+ public R<String> upAndDown(@RequestParam(value = "id") String id,
+ @RequestParam(value = "status")Integer status) {
+ sysProductIntroductionService.update(Wrappers.<TSysProductIntroduction>lambdaUpdate()
+ .set(TSysProductIntroduction::getStatus,status)
+ .eq(TSysProductIntroduction::getId,id));
+ return R.ok();
+ }
+
+ /**
+ * 热门推荐统计数量
+ */
+ @ApiOperation(value = "热门推荐统计数量")
+ @GetMapping(value = "/recommendationsCount")
+ public R<Map<String,Integer>> recommendationsCount() {
+
+ Long userId = tokenService.getLoginUser().getUserId();
+ // 查询教育资讯
+ List<TSysEducationalInfo> sysEducationalInfos = sysEducationalInfoService.list(Wrappers.<TSysEducationalInfo>lambdaQuery()
+ .eq(TSysEducationalInfo::getStatus, 1));
+ int educationalCount = sysEducationalInfos.size();
+ for (TSysEducationalInfo sysEducationalInfo : sysEducationalInfos) {
+ Set<Long> userIds = redisCache.getCacheSet(Constants.SYS_EDUCATION_CLICK_COUNT+sysEducationalInfo.getId());
+ if(userIds.contains(userId)){
+ educationalCount = educationalCount - 1;
+ }
+ }
+ // 查询产品介绍
+ List<TSysProductIntroduction> sysProductIntroductions = sysProductIntroductionService.list(Wrappers.lambdaQuery(TSysProductIntroduction.class)
+ .eq(TSysProductIntroduction::getStatus, 1));
+ int productCount = sysProductIntroductions.size();
+ for (TSysProductIntroduction sysProductIntroduction : sysProductIntroductions) {
+ Set<Long> userIds = redisCache.getCacheSet(Constants.SYS_PRODUCT_CLICK_COUNT+sysProductIntroduction.getId());
+ if(userIds.contains(userId)){
+ productCount = productCount - 1;
+ }
+ }
+ // 查询热门活动
+ List<TSysActivity> sysActivities = sysActivityService.list(Wrappers.lambdaQuery(TSysActivity.class)
+ .eq(TSysActivity::getStatus, 1));
+ int activityCount = sysActivities.size();
+ for (TSysActivity sysActivity : sysActivities) {
+ Set<Long> userIds = redisCache.getCacheSet(Constants.SYS_ACTIVITY_CLICK_COUNT+sysActivity.getId());
+ if(userIds.contains(userId)){
+ activityCount = activityCount - 1;
+ }
+ }
+ // 查询直播
+ List<TSysLive> sysLives = sysLiveService.list();
+ int liveCount = sysLives.size();
+ for (TSysLive sysLive : sysLives) {
+ Set<Long> userIds = redisCache.getCacheSet(Constants.SYS_LIVE_CLICK_COUNT+sysLive.getId());
+ if(userIds.contains(userId)){
+ liveCount = liveCount - 1;
+ }
+ }
+
+ Map<String,Integer> map = new HashMap<>();
+ map.put("educationalCount",educationalCount);
+ map.put("productCount",productCount);
+ map.put("activityCount",activityCount);
+ map.put("liveCount",liveCount);
+ return R.ok(map);
+ }
+
}
--
Gitblit v1.7.1