From 19f170a41e2200eed6a23402b00d7da20b38f42d Mon Sep 17 00:00:00 2001
From: jiazx0107 <jiazx0107@163.com>
Date: 星期四, 15 一月 2026 18:37:00 +0800
Subject: [PATCH] 更新入库通知单逻辑

---
 fzzy-igdss-core/src/main/java/com/fzzy/igds/service/InoutNoticeService.java |  287 +++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 257 insertions(+), 30 deletions(-)

diff --git a/fzzy-igdss-core/src/main/java/com/fzzy/igds/service/InoutNoticeService.java b/fzzy-igdss-core/src/main/java/com/fzzy/igds/service/InoutNoticeService.java
index cd30cbe..04312f6 100644
--- a/fzzy-igdss-core/src/main/java/com/fzzy/igds/service/InoutNoticeService.java
+++ b/fzzy-igdss-core/src/main/java/com/fzzy/igds/service/InoutNoticeService.java
@@ -3,21 +3,28 @@
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.fzzy.igds.constant.AuditStatus;
 import com.fzzy.igds.constant.Constant;
-import com.fzzy.igds.data.NoticeDto;
-import com.fzzy.igds.data.NoticeParam;
+import com.fzzy.igds.constant.InoutConstant;
+import com.fzzy.igds.data.*;
+import com.fzzy.igds.domain.*;
 import com.fzzy.igds.mapper.InoutNoticeInMapper;
 import com.fzzy.igds.mapper.InoutNoticeOutMapper;
-import com.fzzy.igds.domain.InoutNoticeIn;
-import com.fzzy.igds.domain.InoutNoticeOut;
 import com.fzzy.igds.utils.ContextUtil;
+import com.fzzy.work.data.WorkBizType;
+import com.fzzy.work.domain.WorkOrderConf;
+import com.fzzy.work.service.BizWorkService;
 import com.ruoyi.common.utils.StringUtils;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.time.DateFormatUtils;
 import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import org.springframework.transaction.annotation.Transactional;
+
 import javax.annotation.Resource;
 import java.util.Date;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
 
 /**
  * @Description 鍑哄叆搴撻�氱煡鍗晄ervice灞傦紝鍖呭惈鍏ュ簱閫氱煡鍗曞拰鍑哄簱閫氱煡鍗�
@@ -32,8 +39,18 @@
     private InoutNoticeInMapper noticeInMapper;
     @Resource
     private InoutNoticeOutMapper noticeOutMapper;
+    @Resource
+    private DepotService depotService;
+    @Resource
+    private CoreDeptService coreDeptService;
+    @Resource
+    private PledgeContractService pledgeContractService;
+
+    @Resource
+    private BizWorkService workService;
 
     /*----------------------鍏ュ簱閫氱煡鍗曚俊鎭�-------------------------*/
+
     /**
      * 鍒嗛〉鏌ヨ鏁版嵁
      * @param page
@@ -42,19 +59,19 @@
     public void pageQueryIn(Page<InoutNoticeIn> page, NoticeParam param) {
         QueryWrapper<InoutNoticeIn> queryWrapper = new QueryWrapper<>();
 
-        if(null == param) {
+        if (null == param) {
             param = new NoticeParam();
         }
         param.setCompanyId(ContextUtil.getCompanyId());
 
         queryWrapper.eq("company_id", param.getCompanyId());
-        if(StringUtils.isNotBlank(param.getCustomerName())){
+        if (StringUtils.isNotBlank(param.getCustomerName())) {
             queryWrapper.like("customer_name", param.getCustomerName());
         }
-        if(StringUtils.isNotBlank(param.getFoodVariety())){
+        if (StringUtils.isNotBlank(param.getFoodVariety())) {
             queryWrapper.like("food_variety", param.getFoodVariety());
         }
-        if(StringUtils.isNotBlank(param.getCompleteStatus())){
+        if (StringUtils.isNotBlank(param.getCompleteStatus())) {
             queryWrapper.like("complete_status", param.getCompleteStatus());
         }
 
@@ -68,20 +85,20 @@
     public List<InoutNoticeIn> getNoticeIn(NoticeParam param) {
 
         QueryWrapper<InoutNoticeIn> queryWrapper = new QueryWrapper<>();
-        if(StringUtils.isNotBlank(param.getCompanyId())){
+        if (StringUtils.isNotBlank(param.getCompanyId())) {
             queryWrapper.eq("company_id", param.getCompanyId());
         }
-        if(StringUtils.isNotBlank(param.getDeptId())){
+        if (StringUtils.isNotBlank(param.getDeptId())) {
             queryWrapper.eq("dept_id", param.getDeptId());
         }
-        if(StringUtils.isNotBlank(param.getCompleteStatus())){
+        if (StringUtils.isNotBlank(param.getCompleteStatus())) {
             queryWrapper.eq("complete_status", param.getCompleteStatus());
         }
-        if(StringUtils.isNotBlank(param.getKey())){
+        if (StringUtils.isNotBlank(param.getKey())) {
             queryWrapper.like("name", param.getKey());
         }
         queryWrapper.orderByDesc("create_time");
-        
+
         return noticeInMapper.selectList(queryWrapper);
     }
 
@@ -118,22 +135,88 @@
      * @param data
      * @return
      */
-    public String saveOrUpdateIn(InoutNoticeIn data) {
+    @Transactional(rollbackFor = Exception.class)
+    public BaseResp saveOrUpdateIn(InoutNoticeIn data) {
+
+        //濡傛灉鏄簱鍖鸿嚜寤洪�氱煡鍗�
+        if (InoutConstant.NOTICE_IN_TYPE_10.equals(data.getType())) {
+            //鑾峰彇璐ㄦ娂鍚堝悓鏁版嵁
+            PledgeContract pledge = this.getPledgeByDepotId(data);
+            if (null != pledge && pledge.getStatus().equals(Constant.YN_N)) {
+                return BaseResp.error("褰撳墠浠撳簱鏈夋湭瑙e帇鐨勮川鎶煎悎鍚岋紝璐ㄦ娂鍚堝悓=" + pledge.getName());
+            }
+        }
+
+        //濡傛灉璐ㄦ娂閫氱煡鍗�
+        if (InoutConstant.NOTICE_IN_TYPE_20.equals(data.getType())) {
+            //1.楠岃瘉閾惰鏄惁濉啓锛屾湭濉啓锛屽垯涓嶅厑璁镐繚瀛�
+            if (StringUtils.isEmpty(data.getBankId())) {
+                return BaseResp.error("璐ㄦ娂閾惰涓嶈兘涓虹┖锛�");
+            }
+            //2.楠岃瘉閾惰鍜屼粨搴撶殑瀵瑰簲鍏崇郴鏄惁姝g‘锛屼笉姝g‘鍒欎笉鍏佽淇濆瓨
+            PledgeContract pledge = this.getPledgeByDepotIdAndBankId(data);
+            if (null == pledge) {
+                return BaseResp.error("鏈幏鍙栧埌褰撳墠搴撳尯銆佷粨搴撳拰閾惰涔嬮棿鐨勮川鎶间俊鎭紒");
+            }
+        }
+
+        //淇敼鍜屾彁浜ゆ槸涓や釜閫昏緫鍒ゆ柇
         if (null == data.getUpdateBy()) {
-            data.setUpdateBy(ContextUtil.getLoginUserName());
-            data.setUpdateTime(new Date());
-            data.setCreateBy(ContextUtil.getLoginUserName());
-            data.setCreateTime(new Date());
-            data.setAuditStatus(AuditStatus.STATUS_10.getCode());
-            data.setCompleteStatus(Constant.COMPLETE_STATUS_NONE);
-            noticeInMapper.insert(data);
+            return this.saveInAddStartWork(data);
         } else {
             data.setUpdateBy(ContextUtil.getLoginUserName());
             data.setUpdateTime(new Date());
             noticeInMapper.updateById(data);
+            return BaseResp.success();
+        }
+    }
+
+    private BaseResp saveInAddStartWork(InoutNoticeIn data) {
+        //鏁版嵁淇濆瓨
+        data.setUpdateBy(ContextUtil.getLoginUserName());
+        data.setUpdateTime(new Date());
+        data.setCreateBy(ContextUtil.getLoginUserName());
+        data.setCreateTime(new Date());
+        data.setAuditStatus(AuditStatus.STATUS_10.getCode());
+        data.setCompleteStatus(Constant.COMPLETE_STATUS_NONE);
+
+        //鎵ц娴佺▼
+        WorkOrderConf conf = workService.getConfByDeptId(data.getDeptId(), WorkBizType.TYPE_10);
+        //娴佺▼涓嶅惎鐢�
+        if (null == conf || Constant.YN_N.equals(conf.getValTag())) {
+            data.setAuditStatus(AuditStatus.STATUS_20.getCode());
+            data.setAuditDate(data.getCreateTime());
+        } else {
+            BaseResp resp = workService.startByNoticeIn(data, conf);
+            log.info("---------鍚姩宸ュ崟娴佺▼------{}", resp);
         }
 
-        return null;
+        noticeInMapper.insert(data);
+
+        return BaseResp.success();
+    }
+
+
+    /**
+     * 鍒ゆ柇褰撳墠浠撳簱鏄惁鍦ㄨ川鎶煎悎鍚屼腑鏈В鍘�
+     * @param data 褰撳墠鏁版嵁
+     * @return true-鍦ㄨ川鎶煎悎鍚屼腑鏈В鍘嬶紝false-鍦ㄨ川鎶煎悎鍚屼腑宸茶В鍘�
+     */
+    private PledgeContract getPledgeByDepotId(InoutNoticeIn data) {
+        IgdsBaseParam param = new IgdsBaseParam();
+        param.setCompanyId(data.getCompanyId());
+        param.setDeptId(data.getDeptId());
+        param.setDepotId(data.getDepotId());
+        return pledgeContractService.getByDepotId(param);
+    }
+
+    private PledgeContract getPledgeByDepotIdAndBankId(InoutNoticeIn data) {
+        IgdsBaseParam param = new IgdsBaseParam();
+        param.setCompanyId(data.getCompanyId());
+        param.setDeptId(data.getDeptId());
+        param.setDepotId(data.getDepotId());
+        param.setBankId(data.getBankId());
+        return pledgeContractService.getByDepotId(param);
     }
 
     /**
@@ -148,6 +231,7 @@
     }
 
     /*----------------------鍑哄簱閫氱煡鍗曚俊鎭�-------------------------*/
+
     /**
      * 鍒嗛〉鏌ヨ鏁版嵁
      * @param page
@@ -156,19 +240,19 @@
     public void pageQueryOut(Page<InoutNoticeOut> page, NoticeParam param) {
         QueryWrapper<InoutNoticeOut> queryWrapper = new QueryWrapper<>();
 
-        if(null == param) {
+        if (null == param) {
             param = new NoticeParam();
         }
         param.setCompanyId(ContextUtil.getCompanyId());
 
         queryWrapper.eq("company_id", param.getCompanyId());
-        if(StringUtils.isNotBlank(param.getCustomerName())){
+        if (StringUtils.isNotBlank(param.getCustomerName())) {
             queryWrapper.like("customer_name", param.getCustomerName());
         }
-        if(StringUtils.isNotBlank(param.getFoodVariety())){
+        if (StringUtils.isNotBlank(param.getFoodVariety())) {
             queryWrapper.like("food_variety", param.getFoodVariety());
         }
-        if(StringUtils.isNotBlank(param.getCompleteStatus())){
+        if (StringUtils.isNotBlank(param.getCompleteStatus())) {
             queryWrapper.like("complete_status", param.getCompleteStatus());
         }
 
@@ -181,16 +265,16 @@
      */
     public List<InoutNoticeOut> getNoticeOut(NoticeParam param) {
         QueryWrapper<InoutNoticeOut> queryWrapper = new QueryWrapper<>();
-        if(StringUtils.isNotBlank(param.getCompanyId())){
+        if (StringUtils.isNotBlank(param.getCompanyId())) {
             queryWrapper.eq("company_id", param.getCompanyId());
         }
-        if(StringUtils.isNotBlank(param.getDeptId())){
+        if (StringUtils.isNotBlank(param.getDeptId())) {
             queryWrapper.eq("dept_id", param.getDeptId());
         }
-        if(StringUtils.isNotBlank(param.getCompleteStatus())){
+        if (StringUtils.isNotBlank(param.getCompleteStatus())) {
             queryWrapper.eq("complete_status", param.getCompleteStatus());
         }
-        if(StringUtils.isNotBlank(param.getKey())){
+        if (StringUtils.isNotBlank(param.getKey())) {
             queryWrapper.like("name", param.getKey());
         }
         queryWrapper.orderByDesc("create_time");
@@ -232,6 +316,43 @@
      * @return
      */
     public String saveOrUpdateOut(InoutNoticeOut data) {
+        //濡傛灉鍑哄簱閫氱煡鍗曠被鍨嬩负搴撳尯閫氱煡鍗曪紝楠岃瘉浠撳簱鏄惁鏄湭瑙e帇寰椾粨搴擄紝鏄垯涓嶅厑璁镐繚瀛�
+        //鑾峰彇鎵�鏈夎川鎶煎悎鍚屾暟鎹�
+        List<PledgeContract> pledgeContracts = pledgeContractService.listAll(null);
+        if ("10".equals(data.getType())) {
+            //鍦ㄨ川鎶煎悎鍚屾壘鍒版湭瑙e帇锛屼笖璐ㄦ娂浠撳簱鍖呭惈褰撳墠浠撳簱鐨勬暟鎹�
+            for (PledgeContract pledgeContract : pledgeContracts) {
+                if (pledgeContract.getDepotIds().contains(data.getDepotId())) {
+                    if (pledgeContract.getStatus().equals(Constant.YN_N)) {
+                        return "鍑哄簱浠撳簱鏈В鍘嬶紝鏃犳硶淇濆瓨锛�";
+                    }
+                }
+            }
+        }
+        //濡傛灉鍑哄簱閫氱煡鍗曠被鍨嬩负鐩戠閫氱煡鍗�
+        if ("20".equals(data.getType())) {
+            //1.楠岃瘉閾惰鏄惁濉啓锛屾湭濉啓锛屽垯涓嶅厑璁镐繚瀛�
+            if (StringUtils.isEmpty(data.getBankId())) {
+                return "鐩戠潱閾惰涓嶈兘涓虹┖锛�";
+
+            }
+            //2.楠岃瘉閾惰鍜屼粨搴撶殑瀵瑰簲鍏崇郴鏄惁姝g‘锛屼笉姝g‘鍒欎笉鍏佽淇濆瓨
+            //鍦ㄨ川鎶煎悎鍚屾壘鍒版湭瑙e帇锛屼笖璐ㄦ娂浠撳簱鍖呭惈褰撳墠浠撳簱鐨� 閾惰-浠撳簱锛堣川鎶煎悎鍚屽叧绯伙級
+            Map<String, PledgeContract> bankDepotMap = new HashMap<>();
+            for (PledgeContract pledgeContract : pledgeContracts) {
+                if (pledgeContract.getDepotIds().contains(data.getDepotId())) {
+                    if (pledgeContract.getStatus().equals(Constant.YN_N)) {
+                        bankDepotMap.put(pledgeContract.getPledgeBank(), pledgeContract);
+                    }
+                }
+            }
+            //鍦╩ap涓鎵惧尮閰嶉摱琛岀殑鏁版嵁锛屽鏋滄病鏈夊尮閰嶇殑鏁版嵁锛屽垯涓嶅厑璁镐繚瀛�
+            if (!bankDepotMap.containsKey(data.getBankId())) {
+                return "鏈壘鍒板搴旂殑璐ㄦ娂鍚堝悓锛岃妫�鏌ョ洃鐫i摱琛屾垨鑰呭嚭搴撲粨搴撳~鍐欐槸鍚︽纭紒";
+
+            }
+        }
+
         if (null == data.getUpdateBy()) {
             data.setUpdateBy(ContextUtil.getLoginUserName());
             data.setUpdateTime(new Date());
@@ -381,4 +502,110 @@
         return null;
     }
 
+    /**
+     *
+     * @param param
+     * @return
+     */
+    public ExportWordParam handleInData(ExportWordParam param) {
+
+        InoutNoticeIn notice = this.getNoticeInOne(param.getBizId());
+
+        //杞崲涓烘ā鏉块渶瑕佺殑map鏁版嵁婧�
+        Map<String, Object> map = new HashMap();
+
+        map.put("serId", notice.getId());
+        map.put("name", notice.getName());
+
+        String type = "";
+        if ("10".equals(notice.getType())) {
+            type = "搴撳尯閫氱煡鍗�";
+        }
+        if ("20".equals(notice.getType())) {
+            type = "鐩戠閫氱煡鍗�";
+        }
+        map.put("type", type);
+
+        map.put("customerName", notice.getCustomerName());
+
+        String unitName = "";
+        Dept dept = coreDeptService.getDeptById(notice.getUnitName());
+        if (dept != null) {
+            unitName = dept.getKqmc();
+        }
+        map.put("unitName", unitName);
+
+        Depot depot = depotService.getCacheDepot(notice.getCompanyId(), notice.getDepotId());
+        String depotId = "";
+        if (dept != null) {
+            depotId = depot.getName();
+        }
+        map.put("depotId", depotId);
+
+        map.put("year", notice.getYear());
+        map.put("targetNumber", notice.getTargetNumber());
+        map.put("completeNumber", notice.getCompleteNumber());
+        map.put("completeStatus", notice.getCompleteStatus());
+        map.put("contract", notice.getContract());
+        map.put("remark", notice.getRemark());
+        map.put("createUser", notice.getCreateBy());
+        map.put("createTime", DateFormatUtils.format(notice.getCreateTime(), "yyyy-MM-dd HH:mm:ss"));
+
+        param.setDataMap(map);
+        return param;
+    }
+
+    /**
+     *
+     * @param param
+     * @return
+     */
+    public ExportWordParam handleOutData(ExportWordParam param) {
+
+        InoutNoticeOut notice = this.getNoticeOutOne(param.getBizId());
+
+        //杞崲涓烘ā鏉块渶瑕佺殑map鏁版嵁婧�
+        Map<String, Object> map = new HashMap();
+
+        map.put("serId", notice.getId());
+        map.put("name", notice.getName());
+
+        String type = "";
+        if ("10".equals(notice.getType())) {
+            type = "搴撳尯閫氱煡鍗�";
+        }
+        if ("20".equals(notice.getType())) {
+            type = "鐩戠閫氱煡鍗�";
+        }
+        map.put("type", type);
+
+        map.put("customerName", notice.getCustomerName());
+
+        String unitName = "";
+        Dept dept = coreDeptService.getDeptById(notice.getUnitName());
+        if (dept != null) {
+            unitName = dept.getKqmc();
+        }
+        map.put("unitName", unitName);
+
+        Depot depot = depotService.getCacheDepot(notice.getCompanyId(), notice.getDepotId());
+        String depotId = "";
+        if (dept != null) {
+            depotId = depot.getName();
+        }
+        map.put("depotId", depotId);
+
+        map.put("year", notice.getYear());
+        map.put("targetNumber", notice.getTargetNumber());
+        map.put("completeNumber", notice.getCompleteNumber());
+        map.put("completeStatus", notice.getCompleteStatus());
+        map.put("contract", notice.getContract());
+        map.put("remark", notice.getRemark());
+        map.put("createUser", notice.getCreateBy());
+        map.put("createTime", DateFormatUtils.format(notice.getCreateTime(), "yyyy-MM-dd HH:mm:ss"));
+
+        param.setDataMap(map);
+        return param;
+    }
+
 }

--
Gitblit v1.9.3