From f3813129107882ab77531a1d5f056824c401ca37 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期一, 13 十月 2025 11:11:55 +0800
Subject: [PATCH] 采购相关问题

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TSysProductIntroductionController.java |  136 ++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 134 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..cb12276 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,27 @@
 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.TSysProductIntroduction;
+import com.ruoyi.system.query.TSysProductIntroductionQuery;
+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.HashSet;
+import java.util.List;
+import java.util.Set;
 
 /**
  * <p>
@@ -12,9 +31,122 @@
  * @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;
+    @Autowired
+    public TSysProductIntroductionController(TSysProductIntroductionService sysProductIntroductionService, TokenService tokenService, RedisCache redisCache) {
+        this.sysProductIntroductionService = sysProductIntroductionService;
+        this.tokenService = tokenService;
+        this.redisCache = redisCache;
+    }
+
+    /**
+     * 获取产品介绍管理列表
+     */
+    @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)));
+    }
+
+    /**
+     * 添加产品介绍管理
+     */
+    @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();
+    }
+    
 }
 

--
Gitblit v1.7.1