sgj
2026-03-17 e2eb6557cef6b7848c4d77961706abb0b3896380
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("入库通知单审批");
        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("出库通知单审批");
        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
@@ -168,16 +176,37 @@
    /**
     *
     * 根据出入库通知单启动审批工单
     *
     * @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 (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());
@@ -192,9 +221,7 @@
        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 +246,7 @@
    /**
     * 获取待处理工单
     *
     * @return 处理结果
     */
    public BaseResp todoByProcess(WorkOrderProcess process) {
@@ -238,7 +266,6 @@
            return BaseResp.error("当前工单已处理,请刷新页面重试!!");
        }
        //判断是不是指定处理人
        SysUser user = ContextUtil.getLoginUser();
        if (StringUtils.isNotEmpty(work.getAssigneeId())) {
@@ -257,7 +284,6 @@
        WorkOrderConf conf = confService.selectById(work.getConfId());
        if (null == conf) return BaseResp.error("当前工单未配置流程");
        //添加记录
        process.setId(ContextUtil.UUID());
        process.setCreateTime(new Date());
@@ -267,7 +293,7 @@
        WorkNode nextNode = this.getNextNode(work.getNode(), conf);
        log.info("工单审批:{},当前节点:{},下一节点:{}", work.getTitle(), work.getNode(), nextNode);
        log.info("工单审批:{},执行动作:{},当前节点:{},下一节点:{}", work.getTitle(), action, work.getNode(), nextNode);
        //通过操作
        if ("pass".equals(action)) {
@@ -280,6 +306,10 @@
                work.setAssigneeId(process.getAssigneeId());
                work.setNode(nextNode.getCode());
                orderService.complete(work);
            } else {
                work.setNode(nextNode.getCode());
                work.setStatus(WorkStatus.STATUS_30.getCode());
                orderService.updateData(work);
            }
            //增加审批记录
@@ -290,11 +320,29 @@
        //拒绝操作
        if ("refuse".equals(action)) {
            process.setAction("拒绝");
            process.setNode(WorkNode.NODE_END.getCode());
            process.setNode(work.getNode());
            work.setStatus(WorkStatus.STATUS_60.getCode());
            orderService.complete(work);
            //增加审批记录
            orderProcessService.addData(process, true);
            return BaseResp.success();
        }
        //异常处理
        if ("error".equals(action)) {
            process.setAction("异常处理");
            process.setNode(work.getNode());
            work.setStatus(WorkStatus.STATUS_50.getCode());
//            work.setAssigneeName(process.getAssigneeName());
//            work.setAssigneeId(process.getAssigneeId());
            orderService.complete(work);
            //增加审批记录
            orderProcessService.addData(process, true);