ZQN
2024-09-04 820fde4dc19a0205ea4a48b8dd08979a8b212f30
project-enforce/src/main/java/com/project/enforce/service/impl/EnforceOrderServiceImpl.java
@@ -6,6 +6,7 @@
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.project.common.annotation.DataScope;
import com.project.common.core.domain.entity.SysUser;
import com.project.common.core.domain.model.DateRange;
import com.project.common.enums.OrderPre;
import com.project.common.exception.base.BaseException;
import com.project.common.utils.DateUtils;
@@ -19,6 +20,7 @@
import com.project.enforce.domain.bo.editBo.OrderResultBo;
import com.project.enforce.domain.bo.queryBo.EnforceOrderQueryBo;
import com.project.enforce.domain.bo.queryBo.OrderCheckedQueryBo;
import com.project.enforce.domain.vo.EnforceDistinctVo;
import com.project.enforce.domain.vo.EnforceEvaluateVo;
import com.project.enforce.domain.vo.EnforceOrderVo;
import com.project.enforce.domain.vo.OrderNodeVo;
@@ -34,6 +36,7 @@
import java.util.ArrayList;
import java.util.Collection;
import java.util.LinkedList;
import java.util.List;
/**
@@ -57,13 +60,15 @@
    /**
     * 通用列表-无权限
     * @param bo   参数
     * @param bo    参数
     * @return 列表
     */
    @Override
    public List<EnforceOrderVo> queryCommonList(EnforceOrderQueryBo bo)
    {
        QueryWrapper<EnforceOrder> qw = getQw(bo);
        List<EnforceOrder> list = this.list(qw);
        return Convert.toList(EnforceOrderVo.class , list);
    }
@@ -74,8 +79,59 @@
    }
    /**
     * 企业确认执法单
     * @param orderId    订单id
     * @return  结果
     */
    @Override
    @Transactional
    public Boolean confirm(Long orderId)
    {
        EnforceOrder order = this.getById(orderId);
        if (order.getOrderStatus()!=4){
            throw new BaseException("请待执法部门上报结果后确认!");
        }
        order.setOrderStatus(5);
        order.setConfirmTime(DateUtils.getNowDate());
        return this.updateById(order);
    }
    @Override
    @Transactional
    public Integer executeEnforceOrderWarn()
    {
        List<EnforceOrder> updList = new LinkedList<>();
        //同一天重复执法
        List<EnforceDistinctVo> list =baseMapper.selectDistinctCheckDeptIdAndCompanyId();
        if (StringUtils.isNotEmpty(list)){
            for (EnforceDistinctVo distinctVo : list) {
                List<EnforceOrder> orderList = this.list(lq()
                        .eq(EnforceOrder::getCompanyId, distinctVo.getCompanyId())
                        .eq(EnforceOrder::getCheckDeptId, distinctVo.getCheckDeptId())
                        .like(EnforceOrder::getApplyTime, distinctVo.getApplyTimeStr())
                        .orderByDesc(EnforceOrder::getApplyTime)
                );
                if (StringUtils.isNotEmpty(orderList)){
                    List<EnforceOrder> enforceOrders = orderList.subList(0, orderList.size() - 1);
                    enforceOrders.forEach(order->{order.setWarnStatus(1);order.setWarnReason("同一天内对同一企业重复执法");});
                    updList.addAll(enforceOrders);
                }
            }
        }
        if (StringUtils.isNotEmpty(updList)){
            this.updateBatchById(updList);
        }
        return updList.size();
    }
    public static void main(String[] args) {
        DateRange todayRange = DateUtils.getTodayRange();
        System.out.println(todayRange);
    }
    /**
     * 企业执法单列表
     * @param bo   参数
     * @param bo    参数
     * @return 列表
     */
    @Override
@@ -89,7 +145,7 @@
    /**
     * 执法申请单列表
     * @param bo   参数
     * @param bo    参数
     * @return 列表
     */
    @Override
@@ -104,7 +160,7 @@
    /**
     * 执法执行单列表
     * @param bo   参数
     * @param bo    参数
     * @return 列表
     */
    @Override
@@ -118,7 +174,7 @@
    /**
     * 待审核列表
     * @param bo   参数
     * @param bo    参数
     * @return 列表
     */
    @Override
@@ -137,7 +193,7 @@
    /**
     * 审批记录列表
     * @param bo   参数
     * @param bo    参数
     * @return 列表
     */
    @Override
@@ -157,7 +213,7 @@
    {
        List<EnforceOrder> list = this.list(lq()
                .eq(EnforceOrder::getIsShow, 1)
                .eq(EnforceOrder::getOrderStatus, 4)
                .ge(EnforceOrder::getOrderStatus, 4)
        );
        return Convert.toList(EnforceOrderVo.class, list);
    }
@@ -293,7 +349,9 @@
        if (order.getExecuteTime()!=null){
            vos.add(new OrderNodeVo("结果上报",order.getExecuteUser(),order.getExecuteDeptName(),order.getExecuteTime(), null));
        }
        if (order.getConfirmTime()!=null){
            vos.add(new OrderNodeVo("企业确认",order.getCompanyUser(),order.getCompanyName(),order.getConfirmTime(), null));
        }
        return vos;
    }