From 931e45f5f78494c7af4cab75053da49b57f22fbe Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期一, 13 十月 2025 14:31:43 +0800
Subject: [PATCH] 定时自动叫号 与 WMS获取车辆是否在园接口开发

---
 server/system_service/src/main/java/com/doumee/service/system/impl/NoticesServiceImpl.java |   99 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 89 insertions(+), 10 deletions(-)

diff --git a/server/system_service/src/main/java/com/doumee/service/system/impl/NoticesServiceImpl.java b/server/system_service/src/main/java/com/doumee/service/system/impl/NoticesServiceImpl.java
index 6eaf6f6..cb2fa8b 100644
--- a/server/system_service/src/main/java/com/doumee/service/system/impl/NoticesServiceImpl.java
+++ b/server/system_service/src/main/java/com/doumee/service/system/impl/NoticesServiceImpl.java
@@ -4,21 +4,24 @@
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
-import com.doumee.core.model.LoginUserInfo;
-import com.doumee.core.model.PageData;
-import com.doumee.core.model.PageWrap;
+import com.doumee.core.constants.ResponseStatus;
+import com.doumee.core.exception.BusinessException;
+import com.doumee.service.business.third.model.PageData;
+import com.doumee.service.business.third.model.PageWrap;
 import com.doumee.core.utils.Constants;
 import com.doumee.core.utils.Utils;
+import com.doumee.dao.system.dto.NoticesDTO;
 import com.doumee.dao.system.join.NoticesJoinMapper;
 import com.doumee.dao.system.model.Notices;
 import com.doumee.service.system.NoticesService;
 import com.github.xiaoymin.knife4j.core.util.CollectionUtils;
 import com.github.yulichang.wrapper.MPJLambdaWrapper;
-import org.apache.shiro.SecurityUtils;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import java.util.List;
+import java.util.Objects;
 
 /**
  * 绯荤粺娑堟伅淇℃伅琛⊿ervice瀹炵幇
@@ -93,9 +96,6 @@
         IPage<Notices> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
         MPJLambdaWrapper<Notices> queryWrapper = new MPJLambdaWrapper<>();
         Utils.MP.blankToNull(pageWrap.getModel());
-        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
-
-
         queryWrapper.selectAll(Notices.class);
         if (pageWrap.getModel().getIsdeleted() != null) {
             queryWrapper.eq(Notices::getIsdeleted, pageWrap.getModel().getIsdeleted());
@@ -118,7 +118,6 @@
         if (pageWrap.getModel().getReaded() != null) {
             queryWrapper.eq(Notices::getReaded, pageWrap.getModel().getReaded());
         }
-
         if(CollectionUtils.isNotEmpty(pageWrap.getSorts())){
             for(PageWrap.SortData sortData: pageWrap.getSorts()) {
                 if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
@@ -130,9 +129,7 @@
         }else{
             queryWrapper.orderByDesc(Notices::getCreateDate);
         }
-
         PageData<Notices> pageData = PageData.from(noticesMapper.selectJoinPage(page,Notices.class, queryWrapper));
-
         return pageData;
     }
 
@@ -142,7 +139,89 @@
         return noticesMapper.selectCount(wrapper);
     }
 
+    @Override
+    public PageData<Notices> taskCanterPage(PageWrap<NoticesDTO> pageWrap) {
+        IPage<Notices> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
+        MPJLambdaWrapper<Notices> queryWrapper = new MPJLambdaWrapper<>();
+        Utils.MP.blankToNull(pageWrap.getModel());
+        queryWrapper.selectAll(Notices.class);
+        NoticesDTO noticesDTO = pageWrap.getModel();
+        if(Objects.isNull(noticesDTO)
+            || Objects.isNull(noticesDTO.getMemberId())
+            || Objects.isNull(noticesDTO.getQueryType())){
+                queryWrapper.eq("1","2");
+        }
+        if(noticesDTO.getQueryType().equals(Constants.ZERO)){
+            queryWrapper.eq(Notices::getStatus,Constants.ZERO);
+            queryWrapper.eq(Notices::getSendacopy,Constants.ZERO);
+            queryWrapper.eq(Notices::getParam2,Constants.ZERO);
+            queryWrapper.eq(Notices::getUserId, noticesDTO.getMemberId());
+        } else if(noticesDTO.getQueryType().equals(Constants.ONE)){
+            queryWrapper.eq(Notices::getStatus,Constants.ONE);
+            queryWrapper.eq(Notices::getSendacopy,Constants.ZERO);
+            queryWrapper.eq(Notices::getParam4,noticesDTO.getMemberId());
+        } else if(noticesDTO.getQueryType().equals(Constants.TWO)){
+            queryWrapper.eq(Notices::getParam3, noticesDTO.getMemberId());
+        } else if (noticesDTO.getQueryType().equals(Constants.THREE)) {
+            queryWrapper.eq(Notices::getUserId, noticesDTO.getMemberId());
+            queryWrapper.eq(Notices::getSendacopy,Constants.ONE);
+            if(Objects.nonNull(noticesDTO.getNoRead())&&Constants.equalsInteger(noticesDTO.getNoRead(),Constants.ONE)){
+                queryWrapper.eq(Notices::getReaded,Constants.ZERO);
+            }
+        }else{
+            queryWrapper.eq("1","2");
+        }
+        queryWrapper.ge(noticesDTO.getStartDate() != null, Notices::getCreateDate, Utils.Date.getStart(noticesDTO.getStartDate() ));
+        queryWrapper.le(noticesDTO.getEndDate() != null,  Notices::getCreateDate, Utils.Date.getEnd(noticesDTO.getEndDate() ));
+        queryWrapper.eq(Objects.nonNull(noticesDTO.getType()),Notices::getType,noticesDTO.getType());
+//        queryWrapper.eq(Objects.nonNull(noticesDTO.getMemberId()),Notices::getUserId,noticesDTO.getMemberId());
+        queryWrapper.like(StringUtils.isNotBlank(noticesDTO.getTitle()),Notices::getTitle,noticesDTO.getTitle());
+        queryWrapper.orderByDesc(Notices::getCreateDate);
+        PageData<Notices> pageData = PageData.from(noticesMapper.selectJoinPage(page,Notices.class, queryWrapper));
+        if(noticesDTO.getQueryType().equals(Constants.ZERO)){
+            for (Notices notices:pageData.getRecords()) {
+                notices.setInfo("寰呮垜澶勭悊");
+            }
+        }
+        return pageData;
+    }
 
 
+    /**
+     * 鏍囪宸茶
+     * @param noticesId
+     */
+    @Override
+    public void signReadById(Integer noticesId){
+        if(Objects.isNull(noticesId)){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        Notices notices = noticesMapper.selectById(noticesId);
+        if(Objects.isNull(notices)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(Constants.equalsInteger(Constants.ZERO,notices.getReaded())){
+            noticesMapper.update(null,new UpdateWrapper<Notices>().lambda()
+                    .set(Notices::getReaded,Constants.ONE).eq(Notices::getId,noticesId));
+        }
+//        if(Constants.equalsInteger(notices.getSendacopy(),Constants.ONE)){
+//
+//        }else{
+//            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炴妱閫佹暟鎹�,鏃犳硶杩涜鏍囪");
+//        }
+    }
+
+    /**
+     * 鎵归噺鏍囪宸茶
+     * @param memberId
+     */
+    @Override
+    public void signRead(Integer memberId) {
+        noticesMapper.update(null, new UpdateWrapper<Notices>().lambda()
+                .set(Notices::getReaded, Constants.ONE)
+                .eq(Notices::getSendacopy,Constants.ONE)
+                .eq(Notices::getReaded,Constants.ZERO)
+                .eq(Notices::getUserId, memberId));
+    }
 
 }

--
Gitblit v1.9.3