sgj
2026-03-12 533c9a4e44b06c90df7434a38e0da26e10cdac46
fzzy-igdss-core/src/main/java/com/fzzy/work/service/BizWorkService.java
@@ -2,6 +2,7 @@
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;
@@ -18,7 +19,9 @@
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.text.DecimalFormat;
import java.util.Date;
import java.util.List;
/**
 * @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
@@ -168,16 +176,30 @@
    /**
     *
     * 根据出入库通知单启动审批工单
     *
     * @param data 出入库工单数据
     * @return 响应结果
     */
    public BaseResp startByBackMoney(PledgeContract data, WorkOrderConf conf) {
    public BaseResp startByBackMoney(PledgeContract data, WorkOrderConf conf, List<PledgeReminders> remindersList) {
        if (null == conf) conf = confService.getByDeptId(data.getPledgeDept(), WorkBizType.TYPE_10);
        if (Constant.YN_N.equals(conf.getValTag())) return BaseResp.error("流程未启用");
        //创建工单
        StringBuilder description = new StringBuilder("当前合同<" + data.getName() + ">下");
        if (!remindersList.isEmpty()) {
            Double sumMoneyNum = 0.0;
            DecimalFormat df = new DecimalFormat("0.00");
            for (PledgeReminders reminders : remindersList) {
                description.append(",仓库<").append(reminders.getDepotName()).append(">,质押物<").append(reminders.getFoodVarietyName()).append(">库存量为").append(df.format(reminders.getStorageReal())).append("kg,单价").append(reminders.getFoodPrice()).append("元,");
                sumMoneyNum += reminders.getStorageReal() * reminders.getFoodPrice();
            }
            description.append("库存量总金额为").append(df.format(sumMoneyNum)).append("元,达到合同待还款金额的110%,请提醒企业进款还款");
        } else {
            description.append("质押仓库<").append(data.getDepotNames()).append(">库存量金额高于待还款金额,需要进行还款");
        }
        WorkOrder work = new WorkOrder();
        work.setId(ContextUtil.generateOrderId("WARN"));
        work.setBizType(WorkBizType.TYPE_50.getCode());
@@ -192,9 +214,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 +239,7 @@
    /**
     * 获取待处理工单
     *
     * @return 处理结果
     */
    public BaseResp todoByProcess(WorkOrderProcess process) {
@@ -238,7 +259,6 @@
            return BaseResp.error("当前工单已处理,请刷新页面重试!!");
        }
        //判断是不是指定处理人
        SysUser user = ContextUtil.getLoginUser();
        if (StringUtils.isNotEmpty(work.getAssigneeId())) {
@@ -256,7 +276,6 @@
        //获取配置信息
        WorkOrderConf conf = confService.selectById(work.getConfId());
        if (null == conf) return BaseResp.error("当前工单未配置流程");
        //添加记录
        process.setId(ContextUtil.UUID());
@@ -280,7 +299,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 +318,7 @@
            work.setStatus(WorkStatus.STATUS_60.getCode());
            orderService.complete(work);
            //增加审批记录
            orderProcessService.addData(process, true);
@@ -314,7 +333,6 @@
//            work.setAssigneeName(process.getAssigneeName());
//            work.setAssigneeId(process.getAssigneeId());
            orderService.complete(work);