From df55bbefb4b39dbfd259daf4a37c8b25e8c6e8ce Mon Sep 17 00:00:00 2001
From: zjh <1084500556@qq.com>
Date: 星期六, 11 一月 2025 10:45:16 +0800
Subject: [PATCH] zjh20250111

---
 ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjAdviceController.java |  226 +++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 157 insertions(+), 69 deletions(-)

diff --git a/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjAdviceController.java b/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjAdviceController.java
index 8ee6169..f733795 100644
--- a/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjAdviceController.java
+++ b/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjAdviceController.java
@@ -1,19 +1,20 @@
 package com.ltkj.web.controller.system;
 
 import java.nio.channels.NonReadableChannelException;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.stream.Collectors;
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletResponse;
 
+import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ltkj.common.annotation.Excel;
+import com.ltkj.common.core.domain.entity.SysDept;
+import com.ltkj.common.utils.StringUtils;
 import com.ltkj.common.utils.poi.ExcelUtil;
+import com.ltkj.framework.config.UserHoder;
 import com.ltkj.hosp.domain.TjAdvice;
 import com.ltkj.hosp.domain.TjAdviceKjbq;
 import com.ltkj.hosp.domain.TjProject;
@@ -22,10 +23,12 @@
 import com.ltkj.hosp.service.ITjProjectService;
 import com.ltkj.hosp.service.TjAdviceKjbqService;
 import com.ltkj.hosp.service.TjUserAdviceService;
+import com.ltkj.system.service.ISysDeptService;
 import com.ltkj.system.service.ISysUserService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import io.swagger.annotations.ApiParam;
+import jodd.util.StringUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.*;
@@ -53,10 +56,13 @@
     private TjUserAdviceService userAdviceService;
     @Autowired
     private ISysUserService userService;
+    @Autowired
+    private ISysDeptService sysDeptService;
 
     @PostMapping("/addTjAdviceKjbq")
     @ApiOperation(value = "鏂板浣撴寤鸿蹇嵎鏍囩鎺ュ彛")
     public AjaxResult addTjAdviceKjbq(@RequestBody TjAdviceKjbq adviceKjbq) {
+
         return AjaxResult.success(kjbqService.save(adviceKjbq));
     }
 
@@ -74,7 +80,7 @@
 
     @PostMapping("/updateQybzTjAdviceKjbqById")
     @ApiOperation(value = "淇敼浣撴寤鸿蹇嵎鏍囩鍚敤鐘舵�佹帴鍙�")
-    public AjaxResult updateQybzTjAdviceKjbqById(@RequestParam int qybz,@RequestParam Long id) {
+    public AjaxResult updateQybzTjAdviceKjbqById(@RequestParam int qybz, @RequestParam Long id) {
         TjAdviceKjbq kjbq = kjbqService.getById(id);
         kjbq.setQyzt(String.valueOf(qybz));
         return AjaxResult.success(kjbqService.updateById(kjbq));
@@ -82,22 +88,22 @@
 
     @GetMapping("/getTjAdviceKjbqByFl")
     @ApiOperation(value = "鏍规嵁鏍囩鍒嗙被鏌ヨ浣撴寤鸿蹇嵎鏍囩鎺ュ彛")
-    public AjaxResult getTjAdviceKjbqByFl(@RequestParam(required = false)@ApiParam(value = "鐢ㄦ埛id  浼犲綋鍓嶇櫥褰曚汉  瓒呯鐧诲綍鏃朵笉浼� 涓簄ull") String userId,
-                                          @RequestParam(required = false)@ApiParam(value = "鍚敤鐘舵�� 0鍚敤 1鍋滅敤")  Integer qyzt,
+    public AjaxResult getTjAdviceKjbqByFl(@RequestParam(required = false) @ApiParam(value = "鐢ㄦ埛id  浼犲綋鍓嶇櫥褰曚汉  瓒呯鐧诲綍鏃朵笉浼� 涓簄ull") String userId,
+                                          @RequestParam(required = false) @ApiParam(value = "鍚敤鐘舵�� 0鍚敤 1鍋滅敤") Integer qyzt,
                                           @ApiParam(value = "椤电爜鏁�(榛樿1)") @RequestParam(defaultValue = "1") Integer page,
                                           @ApiParam(value = "鏄剧ず鏉℃暟(榛樿10)") @RequestParam(defaultValue = "10") Integer pageSize) {
         LambdaQueryWrapper<TjAdviceKjbq> wq = new LambdaQueryWrapper<>();
-        Page<TjAdviceKjbq> page1=new Page<>(page,pageSize);
-        if (null != userId && !userId.equals("")) {
+        Page<TjAdviceKjbq> page1 = new Page<>(page, pageSize);
+        if (null != userId && !StringUtils.isBlank(userId)) {
             wq.eq(TjAdviceKjbq::getUserId, userId);
         }
         if (null != qyzt) {
-            wq.eq(TjAdviceKjbq::getQyzt,qyzt);
+            wq.eq(TjAdviceKjbq::getQyzt, qyzt);
         }
         Page<TjAdviceKjbq> kjbqPage = kjbqService.page(page1, wq);
-        if(null !=kjbqPage.getRecords() && kjbqPage.getRecords().size()>0){
+        if (null != kjbqPage.getRecords() && !kjbqPage.getRecords().isEmpty()) {
             for (TjAdviceKjbq record : kjbqPage.getRecords()) {
-                if(null !=record.getUserId()){
+                if (null != record.getUserId()) {
                     record.setUserName(userService.getById(record.getUserId()).getNickName());
                 }
 
@@ -109,46 +115,87 @@
 
     @GetMapping("/getKjTjAdviceKjbqBySex")
     @ApiOperation(value = "鏍规嵁浣撴浜烘�у埆鍜屾槸鍚︿负鎬绘鏌ヨ浣撴寤鸿鎺ュ彛")
-    public AjaxResult getKjTjAdviceKjbqBySex(@RequestParam String sex, @RequestParam @ApiParam(value = "0甯歌鍖荤敓 1鎬绘") String isZj,
+    public AjaxResult getKjTjAdviceKjbqBySex(@RequestParam String sex, @RequestParam @ApiParam(value = "1甯歌鍖荤敓 0鎬绘") String isZj,
+                                             @RequestParam(required = false) @ApiParam(value ="寤鸿鍐呭") String jynr,
                                              @ApiParam(value = "椤电爜鏁�(榛樿1)") @RequestParam(defaultValue = "1") Integer page,
                                              @ApiParam(value = "鏄剧ず鏉℃暟(榛樿10)") @RequestParam(defaultValue = "10") Integer pageSize) {
         LambdaQueryWrapper<TjAdvice> wq = new LambdaQueryWrapper<>();
-        Page<TjAdvice> page1=new Page<>(page,pageSize);
-        wq.eq(TjAdvice::getAdSex, sex);
+        Page<TjAdvice> page1 = new Page<>(page, pageSize);
+//        wq.eq(TjAdvice::getAdSex, sex).or().isNull(TjAdvice::getAdSex);
         wq.eq(TjAdvice::getIsZj, isZj);
+        if(StringUtil.isNotBlank(jynr)) wq.like(TjAdvice::getAdvice,jynr);
+        wq.and(i -> i.eq(TjAdvice::getAdSex, sex).or().isNull(TjAdvice::getAdSex));
         Page<TjAdvice> kjbqPage = tjAdviceService.page(page1, wq);
         return AjaxResult.success(kjbqPage);
     }
 
 
-
-
     @GetMapping("/getCyTjAdviceKjbqBySex")
     @ApiOperation(value = "鏍规嵁褰撳墠鐧诲綍浜篿d鑾峰彇甯哥敤寤鸿")
-    public AjaxResult getCyTjAdviceKjbqBySex(@RequestParam String sex,@RequestParam @ApiParam(value = "鐢ㄦ埛id 浼犲綋鍓嶇櫥褰曚汉") Long userId,
+    public AjaxResult getCyTjAdviceKjbqBySex(@RequestParam String sex, @RequestParam @ApiParam(value = "鐢ㄦ埛id 浼犲綋鍓嶇櫥褰曚汉") Long userId,
                                              @ApiParam(value = "椤电爜鏁�(榛樿1)") @RequestParam(defaultValue = "1") Integer page,
                                              @ApiParam(value = "鏄剧ず鏉℃暟(榛樿10)") @RequestParam(defaultValue = "10") Integer pageSize) {
         LambdaQueryWrapper<TjAdvice> wq = new LambdaQueryWrapper<>();
-        Page<TjAdvice> page1=new Page<>(page,pageSize);
-        wq.eq(TjAdvice::getAdSex, sex);
+        Page<TjAdvice> page1 = new Page<>(page, pageSize);
+//        wq.eq(TjAdvice::getAdSex,sex).or().eq(TjAdvice::getAdSex,"2");
         if (null != userId) {
-            LambdaQueryWrapper<TjUserAdvice> wq0=new LambdaQueryWrapper<>();
-            wq0.eq(TjUserAdvice::getUserId,userId);
+            LambdaQueryWrapper<TjUserAdvice> wq0 = new LambdaQueryWrapper<>();
+            wq0.eq(TjUserAdvice::getUserId, userId);
             List<TjUserAdvice> list = userAdviceService.list(wq0);
-            if(null !=list && list.size()>0){
+            if (null != list && list.size() > 0) {
                 List<Long> longs = list.stream().map(TjUserAdvice::getAdviceId).collect(Collectors.toList());
-                wq.in(TjAdvice::getId, longs);
-                Page<TjAdvice> kjbqPage = tjAdviceService.page(page1, wq);
+                wq.in(TjAdvice::getId,longs);
+                wq.last("and (ad_sex=1 OR ad_sex=2)");
+                Page<TjAdvice> kjbqPage = tjAdviceService.page(page1,wq);
                 return AjaxResult.success(kjbqPage);
             }
-
         }
         return AjaxResult.success("璇ョ敤鎴锋殏鏃舵病鏈夊父鐢ㄥ缓璁�!");
     }
 
 
+    @GetMapping("/addCyTjAdviceByUserId")
+    @ApiOperation(value = "娣诲姞褰撳墠鐧诲綍浜哄父鐢ㄥ缓璁帴鍙�")
+    public AjaxResult addCyTjAdviceByUserId(@RequestParam @ApiParam(value = "鎵�閫夊缓璁富閿甶d鏁扮粍") List<Long> adviceIds) {
+        String userId = UserHoder.getLoginUser().getUserId();
+        if (null != adviceIds && adviceIds.size() > 0) {
+            for (Long id : adviceIds) {
+                TjUserAdvice tjUserAdvice = userAdviceService.getTjUserAdviceByUserId(Long.valueOf(userId), id);
+                if (null == tjUserAdvice) {
+                    TjUserAdvice userAdvice = new TjUserAdvice();
+                    userAdvice.setAdviceId(id);
+                    userAdvice.setUserId(Long.valueOf(userId));
+                    userAdviceService.save(userAdvice);
+                }
+            }
+            return AjaxResult.success("娣诲姞鎴愬姛!");
+        }
+        return AjaxResult.success("璇烽�夋嫨鎮ㄨ娣诲姞鐨勫缓璁�!");
+    }
 
 
+    @PostMapping("/addCyTjAdvice")
+    @ApiOperation(value = "娣诲姞甯哥敤寤鸿鎺ュ彛")
+    public AjaxResult addCyTjAdvice(@RequestBody TjAdvice adviceId) {
+        String userId = UserHoder.getLoginUser().getUserId();
+        if (null != adviceId) {
+            if (tjAdviceService.save(adviceId)) {
+                TjUserAdvice tjUserAdvice = userAdviceService.getTjUserAdviceByUserId(Long.valueOf(userId),adviceId.getId());
+                if (null == tjUserAdvice) {
+                    TjUserAdvice userAdvice = new TjUserAdvice();
+                    userAdvice.setAdviceId(adviceId.getId());
+                    userAdvice.setUserId(Long.valueOf(userId));
+                    userAdviceService.save(userAdvice);
+                }
+            }
+            return AjaxResult.success("鎿嶄綔鎴愬姛!");
+        }
+        return AjaxResult.success("璇烽�夋嫨鎮ㄨ娣诲姞鐨勫缓璁�!");
+    }
+
+
+
+//    ================/**/==================================================================================================================================
     /**
      * 鏌ヨadvice鍒楄〃
      */
@@ -156,48 +203,79 @@
     @GetMapping("/list")
     @ApiOperation(value = "浣撴寤鸿鍒楄〃鏌ヨ")
     public AjaxResult list(@RequestParam(required = false) @ApiParam(value = "椤圭洰鍚�") String proName,
+                           @ApiParam(value = "鏍囬") @RequestParam(required = false) String bt,
+                           @ApiParam(value = "寤鸿") @RequestParam(required = false) String nr,
                            @ApiParam(value = "椤电爜鏁�(榛樿1)") @RequestParam(defaultValue = "1") Integer page,
-                           @ApiParam(value = "鏄剧ず鏉℃暟(榛樿10)") @RequestParam(defaultValue = "10") Integer pageSize) {
-        Page<TjAdvice> page1 = new Page<>(page, pageSize);
-        Map<String, Object> map = new HashMap<>();
-        List<TjAdvice> list = null;
-        long total = 0;
-        if (null != proName) {
-            LambdaQueryWrapper<TjProject> wq = new LambdaQueryWrapper<>();
-            list = new ArrayList<>();
-            wq.like(TjProject::getProName, proName);
-            List<TjProject> projectList = tjProjectService.list(wq);
-            if (null != projectList && projectList.size() > 0) {
-                for (TjProject project : projectList) {
-                    LambdaQueryWrapper<TjAdvice> wqq = new LambdaQueryWrapper<>();
-                    wqq.eq(TjAdvice::getProId, project.getProId());
-                    IPage<TjAdvice> adviceList = tjAdviceService.page(page1, wqq);
-                    if (null != adviceList.getRecords() && adviceList.getRecords().size() > 0) {
-                        for (TjAdvice record : adviceList.getRecords()) {
-                            record.setProName(project.getProName());
-                        }
-                        list.addAll(adviceList.getRecords());
-                    }
-                    total = adviceList.getTotal();
-                }
-            }
-            map.put("list", list);
-            map.put("total", total);
-            return AjaxResult.success(map);
-        }
-        Page<TjAdvice> page2 = tjAdviceService.page(page1);
-        list = page2.getRecords();
-        if (null != list && list.size() > 0) {
-            for (TjAdvice advice : list) {
-                TjProject tjProject = tjProjectService.getById(advice.getProId());
-                if (null != tjProject) {
-                    advice.setProName(tjProject.getProName());
-                }
-            }
-        }
-        map.put("list", list);
-        map.put("total", page2.getTotal());
-        return AjaxResult.success(map);
+                           @ApiParam(value = "鏄剧ず鏉℃暟(榛樿10)") @RequestParam(defaultValue = "10") Integer pageSize,
+                           @RequestParam(required = false)String deptId) {
+//        LambdaQueryWrapper<SysDept> wrapper = new LambdaQueryWrapper<>();
+//        wrapper.eq(SysDept::getParentId, 0);
+//        SysDept sysDept = sysDeptService.getOne(wrapper);
+//        Page<TjAdvice> page1 = new Page<>(page, pageSize);
+//        Map<String, Object> map = new HashMap<>();
+//        List<TjAdvice> list = null;
+//        long total = 0;
+//        if (null != proName) {
+//            LambdaQueryWrapper<TjProject> wq = new LambdaQueryWrapper<>();
+//            list = new ArrayList<>();
+//            wq.like(TjProject::getProName, proName);
+//            List<TjProject> projectList = tjProjectService.list(wq);
+//            if (null != projectList && !projectList.isEmpty()) {
+//                for (TjProject project : projectList) {
+//                    LambdaQueryWrapper<TjAdvice> wqq = new LambdaQueryWrapper<>();
+//                    wqq.eq(TjAdvice::getProId, project.getProId());
+//                    if (!deptId.equals(String.valueOf(sysDept.getDeptId()))) {
+//                        wqq.eq(TjAdvice::getDept_id, deptId);
+//                    }
+//                    IPage<TjAdvice> adviceList = tjAdviceService.page(page1, wqq);
+//                    if (null != adviceList.getRecords() && !adviceList.getRecords().isEmpty()) {
+//                        for (TjAdvice record : adviceList.getRecords()) {
+//                            record.setProName(project.getProName());
+//                            String kjbq = record.getKjbq();
+//                            if(null !=kjbq && !kjbq.isEmpty()){
+//                                String[] split = kjbq.split(",");
+//                                record.setKjbqz(Arrays.asList(split));
+//                            }
+//                        }
+//                        list.addAll(adviceList.getRecords());
+//                    }
+//                    total = adviceList.getTotal();
+//                }
+//            }
+//            map.put("list", list);
+//            map.put("total", total);
+//            List<TjAdvice> list1 =  tjAdviceService.selectList(proName,deptId,(page -1) * pageSize,pageSize);
+//            return AjaxResult.success(map);
+//        }
+//        LambdaQueryWrapper<TjAdvice> wq=new LambdaQueryWrapper<>();
+//        if(!StringUtil.isBlank(bt)) wq.like(TjAdvice::getTitle,bt);
+//        if(!StringUtil.isBlank(nr)) wq.like(TjAdvice::getAdvice,nr);
+//        if (!deptId.equals(String.valueOf(sysDept.getDeptId()))) {
+//            wq.eq(TjAdvice::getDept_id, deptId);
+//        }
+//        Page<TjAdvice> page2 = tjAdviceService.page(page1,wq);
+//        list = page2.getRecords();
+//        if (null != list && !list.isEmpty()) {
+//            for (TjAdvice advice : list) {
+//                TjProject tjProject = tjProjectService.getById(advice.getProId());
+//                if (null != tjProject) {
+//                    advice.setProName(tjProject.getProName());
+//                }
+//                String kjbq = advice.getKjbq();
+//                if(null !=kjbq && !kjbq.equals("")){
+//                    String[] split = kjbq.split(",");
+//                    advice.setKjbqz(Arrays.asList(split));
+//                }
+//            }
+//        }
+//        map.put("list", list);
+//        map.put("total", page2.getTotal());
+        List<TjAdvice> tjAdvices = tjAdviceService.selectList(proName, deptId, (page - 1) * pageSize, pageSize,bt,nr);
+        Integer count = tjAdviceService.selectListCount(proName, deptId,bt,nr);
+        HashMap<String, Object> hashMap = new HashMap<>();
+        hashMap.put("list",tjAdvices);
+        hashMap.put("total",count);
+        return AjaxResult.success(hashMap);
     }
 
     /**
@@ -217,8 +295,17 @@
      */
 //    @PreAuthorize("@ss.hasPermi('advice:advice:query')")
     @GetMapping(value = "/{id}")
+    @ApiOperation(value = "鏍规嵁涓婚敭id鑾峰彇advice璇︾粏淇℃伅")
     public AjaxResult getInfo(@PathVariable("id") Long id) {
-        return AjaxResult.success(tjAdviceService.selectTjAdviceById(id));
+        TjAdvice advice = tjAdviceService.getById(id);
+        if(null !=advice){
+            String kjbq = advice.getKjbq();
+            if(null !=kjbq && !kjbq.equals("")){
+                String[] split = kjbq.split(",");
+                advice.setKjbqz(Arrays.asList(split));
+            }
+        }
+        return AjaxResult.success(advice);
     }
 
     /**
@@ -227,8 +314,9 @@
 //    @PreAuthorize("@ss.hasPermi('advice:advice:add')")
     @Log(title = "advice", businessType = BusinessType.INSERT)
     @PostMapping
+    @ApiOperation(value = "鏂板浣撴寤鸿鎺ュ彛")
     public AjaxResult add(@RequestBody TjAdvice tjAdvice) {
-        return AjaxResult.success(tjAdviceService.insertTjAdvice(tjAdvice));
+        return AjaxResult.success(tjAdviceService.save(tjAdvice));
     }
 
     /**

--
Gitblit v1.8.0