sgj
2026-03-20 5b6529bd37a7191b674a64c760dcb5f21ab534f1
fzzy-igdss-core/src/main/java/com/fzzy/work/service/BizWorkService.java
@@ -2,13 +2,14 @@
import com.fzzy.igds.constant.Constant;
import com.fzzy.igds.data.BaseResp;
import com.fzzy.igds.data.PledgeReminders;
import com.fzzy.igds.domain.InoutNoticeIn;
import com.fzzy.igds.domain.InoutNoticeOut;
import com.fzzy.igds.domain.PledgeContract;
import com.fzzy.igds.utils.ContextUtil;
import com.fzzy.work.data.WorkStatus;
import com.fzzy.work.data.WorkBizType;
import com.fzzy.work.data.WorkNode;
import com.fzzy.work.data.WorkStatus;
import com.fzzy.work.domain.WorkOrder;
import com.fzzy.work.domain.WorkOrderConf;
import com.fzzy.work.domain.WorkOrderProcess;
@@ -18,7 +19,9 @@
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.text.DecimalFormat;
import java.util.Date;
import java.util.Map;
/**
 * @Desc: 工单业务接口
@@ -28,6 +31,7 @@
@Slf4j
@Service
public class BizWorkService {
    @Resource
    private WorkOrderConfService confService;
    @Resource
@@ -38,8 +42,9 @@
    /**
     * 获取流程配置信息
     *
     * @param deptId 库区ID
     * @param type  业务类型
     * @param type   业务类型
     * @return 配置信息
     */
    public WorkOrderConf getConfByDeptId(String deptId, WorkBizType type) {
@@ -49,6 +54,7 @@
    /**
     *
     * 根据出入库通知单启动审批工单
     *
     * @param data 出入库工单数据
     * @return 响应结果
     */
@@ -69,7 +75,7 @@
        work.setDeptId(data.getDeptId());
        work.setCompanyId(data.getCompanyId());
        work.setUpdateTime(new Date());
        work.setTitle(data.getName()+"-审批");
        work.setTitle(data.getName() + "-审批");
        work.setConfId(conf.getId());
        work.setStatus(WorkStatus.STATUS_30.getCode());
        work.setReceiveTime(new Date());
@@ -95,6 +101,7 @@
    /**
     *
     * 根据出出库通知单启动审批工单
     *
     * @param data 出入库工单数据
     * @return 响应结果
     */
@@ -114,7 +121,7 @@
        work.setDeptId(data.getDeptId());
        work.setCompanyId(data.getCompanyId());
        work.setUpdateTime(new Date());
        work.setTitle(data.getName()+"-审批");
        work.setTitle(data.getName() + "-审批");
        work.setConfId(conf.getId());
        work.setStatus(WorkStatus.STATUS_30.getCode());
        work.setReceiveTime(new Date());
@@ -139,6 +146,7 @@
    /**
     * 根据当前节点获取下一个节点
     *
     * @param curNode
     * @param conf
     * @return
@@ -167,17 +175,40 @@
    /**
     *
     * 根据出入库通知单启动审批工单
     * 根据质押合同,启动还款提醒工单
     *
     * @param data 出入库工单数据
     * @return 响应结果
     */
    public BaseResp startByBackMoney(PledgeContract data, WorkOrderConf conf) {
    public BaseResp startByBackMoney(PledgeContract data, WorkOrderConf conf, Map<String,PledgeReminders> remindersMap) {
        if (null == conf) conf = confService.getByDeptId(data.getPledgeDept(), WorkBizType.TYPE_10);
        if (null == conf) {
            return BaseResp.error("未找到工单配置");
        }
        if (Constant.YN_N.equals(conf.getValTag())) return BaseResp.error("流程未启用");
//        Double sumMoneyNum = 0.0;
        DecimalFormat df = new DecimalFormat("0.00");
        double backMoney = data.getContractAmount() - data.getRepaidAmount();
        //创建工单
        StringBuilder description = new StringBuilder("合同<" + data.getName() + ">贷款余额:"+df.format(backMoney)+"元,");
        if (!remindersMap.isEmpty()){
            for (PledgeReminders reminders : remindersMap.values()) {
                description.append("当前<").append(reminders.getFoodVarietyName())
                        .append(">单价:").append(reminders.getFoodPrice()).append("元/KG,")
                        .append("剩余<").append(reminders.getFoodVarietyName())
                        .append(">库存:").append(df.format(reminders.getStorageReal())).append("KG,");
//                sumMoneyNum += reminders.getStorageReal() * reminders.getFoodPrice();
            }
            description.append("押品价值≤贷款余额的110%,请尽快提醒企业还款!");
        }else{
            description.append("质押仓库<").append(data.getDepotNames()).append(">押品价值≤贷款余额的110%,请尽快提醒企业还款!");
        }
        WorkOrder work = new WorkOrder();
        work.setId(ContextUtil.generateOrderId("WARN"));
        work.setBizType(WorkBizType.TYPE_50.getCode());
@@ -185,16 +216,14 @@
        work.setBankId(data.getPledgeBank());
        work.setBusinessUrl("com.fzzy.igds.PledgeContract-Detail.d");
        work.setCreateTime(new Date());
        work.setDeptId(data.getPledgeDept());
        work.setDeptId(conf.getDeptId());
        work.setCompanyId(data.getCompanyId());
        work.setUpdateTime(new Date());
        work.setTitle("质押合同还款提醒");
        work.setConfId(conf.getId());
        work.setStatus(WorkStatus.STATUS_30.getCode());
        work.setReceiveTime(new Date());
        work.setDescription("当前合同<" + data.getName() + ">下质押仓库<" + data.getDepotNames() + ">库存量金额低于待还款金额,需要进行还款!");
        work.setDescription(description.toString());
        work.setCreateBy("系统生成");
        work.setCreateById("sys");
        work.setUpdateBy("系统生成");
@@ -219,6 +248,7 @@
    /**
     * 获取待处理工单
     *
     * @return 处理结果
     */
    public BaseResp todoByProcess(WorkOrderProcess process) {
@@ -238,7 +268,6 @@
            return BaseResp.error("当前工单已处理,请刷新页面重试!!");
        }
        //判断是不是指定处理人
        SysUser user = ContextUtil.getLoginUser();
        if (StringUtils.isNotEmpty(work.getAssigneeId())) {
@@ -256,7 +285,6 @@
        //获取配置信息
        WorkOrderConf conf = confService.selectById(work.getConfId());
        if (null == conf) return BaseResp.error("当前工单未配置流程");
        //添加记录
        process.setId(ContextUtil.UUID());
@@ -280,7 +308,7 @@
                work.setAssigneeId(process.getAssigneeId());
                work.setNode(nextNode.getCode());
                orderService.complete(work);
            }else{
            } else {
                work.setNode(nextNode.getCode());
                work.setStatus(WorkStatus.STATUS_30.getCode());
                orderService.updateData(work);
@@ -299,7 +327,7 @@
            work.setStatus(WorkStatus.STATUS_60.getCode());
            orderService.complete(work);
            //增加审批记录
            orderProcessService.addData(process, true);
@@ -314,7 +342,6 @@
//            work.setAssigneeName(process.getAssigneeName());
//            work.setAssigneeId(process.getAssigneeId());
            orderService.complete(work);