EmployeeConfigInfoServiceImpl.java 15.5 KB
package com.bsth.service.schedule.impl;

import com.bsth.entity.Personnel;
import com.bsth.entity.schedule.EmployeeConfigInfo;
import com.bsth.entity.schedule.rule.ScheduleRule1Flat;
import com.bsth.entity.sys.CompanyAuthority;
import com.bsth.entity.sys.Module;
import com.bsth.repository.PersonnelRepository;
import com.bsth.service.schedule.EmployeeConfigInfoService;
import com.bsth.service.schedule.EmployeeService;
import com.bsth.service.schedule.ScheduleRule1FlatService;
import com.bsth.service.schedule.exception.ScheduleException;
import com.bsth.service.schedule.utils.DataToolsFile;
import com.bsth.service.schedule.utils.DataToolsService;
import com.bsth.service.sys.ModuleService;
import com.bsth.util.DateUtils;
import org.apache.commons.lang3.time.DateFormatUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.ResultSetExtractor;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils;

import java.io.File;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.*;

/**
 * Created by xu on 16/5/10.
 */
@Service
public class EmployeeConfigInfoServiceImpl extends BServiceImpl<EmployeeConfigInfo, Long> implements EmployeeConfigInfoService {
    @Autowired
    private ScheduleRule1FlatService scheduleRule1FlatService;
    @Autowired
    private EmployeeService employeeService;

    @Autowired
    private PersonnelRepository personnelRepository;

    @Autowired
    @Qualifier(value = "employeeConfig_dataTool")
    private DataToolsService dataToolsService;

    @Autowired
    private JdbcTemplate jdbcTemplate;

    @Override
    public DataToolsFile uploadFile(String filename, byte[] filedata) throws ScheduleException {
        return dataToolsService.uploadFile(filename, filedata);
    }

    @Override
    public void importData(File file, Map<String, Object> params) throws ScheduleException {
        dataToolsService.importData(file, params);
    }

    @Override
    public DataToolsFile exportData(Map<String, Object> params) throws ScheduleException {
        return dataToolsService.exportData(params);
    }

    @Override
    public Long getMaxDbbm(Integer xlId) {
        String sql = "select max(dbbm + 0) as maxdbbm from bsth_c_s_ecinfo where xl = ?";

        Long maxBM = jdbcTemplate.query(sql, new ResultSetExtractor<Long>() {
            @Override
            public Long extractData(ResultSet rs) throws SQLException, DataAccessException {
                if (rs.next()) {
                    return rs.getLong("maxdbbm");
                } else {
                    return 0L;
                }

            }
        }, xlId);

        return maxBM + 1;
    }

    @Transactional
    @Override
    public void validate_jsy_destroy(EmployeeConfigInfo employeeConfigInfo) throws ScheduleException {
        Personnel jsy = this.personnelRepository.findById(employeeConfigInfo.getJsy().getId()).get();
        if (jsy.getDestroy() != null && jsy.getDestroy() == 1) {
            throw new ScheduleException("当前驾驶员已经停用!");
        }
    }
    @Transactional
    @Override
    public void validate_spy_destroy(EmployeeConfigInfo employeeConfigInfo) throws ScheduleException {
        Personnel spy = this.personnelRepository.findById(employeeConfigInfo.getSpy().getId()).get();
        if (spy.getDestroy() != null && spy.getDestroy() == 1) {
            throw new ScheduleException("当前售票员已经停用!");
        }
    }

    @Transactional
    @Override
    public void validate_jsy(EmployeeConfigInfo employeeConfigInfo) throws ScheduleException {
        // 驾驶员不能重复配置
        Map<String, Object> param = new HashMap<>();
        if (employeeConfigInfo.getId() != null) {
            param.put("id_ne", employeeConfigInfo.getId());
        }

        if (employeeConfigInfo.getXl() == null ||
                employeeConfigInfo.getXl().getId() == null ||
                employeeConfigInfo.getXl().getName() == null) {
            throw new ScheduleException("线路未选择");
        } else {
//            param.put("xl.id_eq", employeeConfigInfo.getXl().getId());
            param.put("isCancel_eq", false);
            if (employeeConfigInfo.getJsy() == null || employeeConfigInfo.getJsy().getId() == null) {
                throw new ScheduleException("驾驶员未选择");
            } else {
                param.put("jsy.id_eq", employeeConfigInfo.getJsy().getId());
                List<EmployeeConfigInfo> employeeConfigInfos = list(param);
                if (!CollectionUtils.isEmpty(list(param))) {
                    throw new ScheduleException("驾驶员已经配置在" + employeeConfigInfos.get(0).getXl().getName() + "线路中!");
                }
            }
        }
    }

    @Transactional
    @Override
    public void validate_jsy_config(EmployeeConfigInfo employeeConfigInfo) throws ScheduleException {
        Map<String, Object> param = new HashMap<>();
        param.put("xl.id_eq", employeeConfigInfo.getXl().getId());
        param.put("jsy.id_eq", employeeConfigInfo.getJsy().getId());
        List<EmployeeConfigInfo> employeeConfigInfos = list(param);
        if (CollectionUtils.isEmpty(employeeConfigInfos)) {
            throw new ScheduleException("驾驶员没有配置在当前线路中,不属于当前线路!");
        }
    }

    @Override
    public void validate_jsy_gs(EmployeeConfigInfo employeeConfigInfo, List<CompanyAuthority> companyAuthorityList) throws ScheduleException {
        if (CollectionUtils.isEmpty(companyAuthorityList)) {
            throw new ScheduleException("当前用户没有公司权限!");
        }

        boolean isFind = false;
        Personnel personnel = employeeService.findById(employeeConfigInfo.getJsy().getId());
        for (CompanyAuthority companyAuthority : companyAuthorityList) {
            if (companyAuthority.getCompanyCode().equals(personnel.getCompanyCode())) {
                isFind = true;
                break;
            }
        }
        if (!isFind) {
            throw new ScheduleException("当前驾驶员不在用户所属公司中!");
        }
    }

    @Override
    public void validate_jsy_fgs(EmployeeConfigInfo employeeConfigInfo, List<CompanyAuthority> companyAuthorityList) throws ScheduleException {
        if (CollectionUtils.isEmpty(companyAuthorityList)) {
            throw new ScheduleException("当前用户没有分公司权限!");
        }

        boolean isFind = false;
        Personnel personnel = employeeService.findById(employeeConfigInfo.getJsy().getId());
        for (CompanyAuthority companyAuthority : companyAuthorityList) {
            if (companyAuthority.getCompanyCode().equals(personnel.getCompanyCode())) {
                isFind = true;
                break;
            }
        }
        if (!isFind) {
            // 如果没有公司权限,验证通过
            return;
        }

        isFind = false;
        for (CompanyAuthority companyAuthority : companyAuthorityList) {
            if (companyAuthority.getCompanyCode().equals(personnel.getCompanyCode()) &&
                    companyAuthority.getSubCompanyCode().equals(personnel.getBrancheCompanyCode())) {
                isFind = true;
                break;
            }
        }
        if (!isFind) {
            throw new ScheduleException("当前驾驶员不在用户所属分公司中!");
        }
    }

    @Transactional
    @Override
    public void validate_spy(EmployeeConfigInfo employeeConfigInfo) throws ScheduleException {
        // 售票员不能重复配置
        Map<String, Object> param = new HashMap<>();
        if (employeeConfigInfo.getId() != null) {
            param.put("id_ne", employeeConfigInfo.getId());
        }

        if (employeeConfigInfo.getXl() == null ||
                employeeConfigInfo.getXl().getId() == null ||
                employeeConfigInfo.getXl().getName() == null) {
            throw new ScheduleException("线路未选择");
        } else {
//            param.put("xl.id_eq", employeeConfigInfo.getXl().getId());
            if (employeeConfigInfo.getSpy() == null || employeeConfigInfo.getSpy().getId() == null) {
                throw new ScheduleException("售票员未选择");
            } else {
                param.put("spy.id_eq", employeeConfigInfo.getSpy().getId());
                List<EmployeeConfigInfo> employeeConfigInfos = list(param);
                if (!CollectionUtils.isEmpty(list(param))) {
                    throw new ScheduleException("售票员已经配置在" + employeeConfigInfos.get(0).getXl().getName() + "线路中!");
                }
            }
        }
    }

    @Override
    public void validate_spy_gs(EmployeeConfigInfo employeeConfigInfo, List<CompanyAuthority> companyAuthorityList) throws ScheduleException {
        if (CollectionUtils.isEmpty(companyAuthorityList)) {
            throw new ScheduleException("当前用户没有公司权限!");
        }

        boolean isFind = false;
        Personnel personnel = employeeService.findById(employeeConfigInfo.getSpy().getId());
        for (CompanyAuthority companyAuthority : companyAuthorityList) {
            if (companyAuthority.getCompanyCode().equals(personnel.getCompanyCode())) {
                isFind = true;
                break;
            }
        }
        if (!isFind) {
            throw new ScheduleException("当前售票员不在用户所属公司中!");
        }
    }

    @Override
    public void validate_spy_fgs(EmployeeConfigInfo employeeConfigInfo, List<CompanyAuthority> companyAuthorityList) throws ScheduleException {
        if (CollectionUtils.isEmpty(companyAuthorityList)) {
            throw new ScheduleException("当前用户没有分公司权限!");
        }

        boolean isFind = false;
        Personnel personnel = employeeService.findById(employeeConfigInfo.getSpy().getId());
        for (CompanyAuthority companyAuthority : companyAuthorityList) {
            if (companyAuthority.getCompanyCode().equals(personnel.getCompanyCode())) {
                isFind = true;
                break;
            }
        }
        if (!isFind) {
            // 如果没有公司权限,验证通过
            return;
        }

        isFind = false;
        for (CompanyAuthority companyAuthority : companyAuthorityList) {
            if (companyAuthority.getCompanyCode().equals(personnel.getCompanyCode()) &&
                    companyAuthority.getSubCompanyCode().equals(personnel.getBrancheCompanyCode())) {
                isFind = true;
                break;
            }
        }
        if (!isFind) {
            throw new ScheduleException("当前售票员不在用户所属分公司中!");
        }
    }

    @Transactional
    @Override
    public void validate_spy_config(EmployeeConfigInfo employeeConfigInfo) throws ScheduleException {
        Map<String, Object> param = new HashMap<>();
        param.put("xl.id_eq", employeeConfigInfo.getXl().getId());
        param.put("spy.id_eq", employeeConfigInfo.getSpy().getId());
        List<EmployeeConfigInfo> employeeConfigInfos = list(param);
        if (CollectionUtils.isEmpty(employeeConfigInfos)) {
            throw new ScheduleException("售票员没有配置在当前线路中,不属于当前线路!");
        }
    }

    @Autowired
    private ModuleService moduleService;
    @Transactional
    @Override
    public List<String> validate_get_destory_info() {
        // 1、查找当前用户是否有运营计划管理,没有的话不分析是否有停用人鱼信息
        List<Module> moduleList = this.moduleService.findByCurrentUser();
        boolean hasPlanModule = false;
        for (Module module : moduleList) {
            if ("运营计划管理".equals(module.getName())) {
                hasPlanModule = true;
                break;
            }
        }
        if (!hasPlanModule) {
            return null;
        }

        // 2、计算从当前时间开始的排班计划中是否有停用人员
        String sql =
                "select distinct " +
                "plan.xl_name xlName " +
                ", plan.schedule_date scheduleDate " +
                "from bsth_c_s_sp_info plan " +
                "left join bsth_c_personnel jsy on jsy.id = plan.j " +
                "left join bsth_c_personnel spy on spy.id = plan.s " +
                "where plan.schedule_date >= ? " +
                "and (jsy.destroy = 1 || spy.destroy = 1) " +
                "group by plan.xl_name, plan.schedule_date " +
                "order by plan.xl_name, plan.schedule_date ";

//        String sql =
//                "select distinct " +
//                "pinfo.xl_name xlName " +
//                ", pinfo.schedule_date scheduleDate " +
//                "from " +
//                "(" +
//                "select plan.xl_name, plan.schedule_date " +
//                "from bsth_c_s_sp_info plan " +
//                "left join bsth_c_personnel jsy on plan.j = jsy.id " +
//                "left join bsth_c_personnel spy on plan.s = spy.id " +
//                "where schedule_date >= ? " +
//                "and (jsy.destroy = 1 || spy.destroy = 1) " +
//                "order by plan.xl_name asc, plan.schedule_date asc " +
//                ") pinfo " +
//                "group by pinfo.xl_name, pinfo.schedule_date ";


        Date currentDate = new Date(DateUtils.getTimestamp());
        System.out.println(currentDate);
        String info_format = "线路[%s][%s]排班中有人员已经停用,请及时处理!";
        List<String> infoList = this.jdbcTemplate.query(sql, new Object[] {currentDate}, new RowMapper<String>() {
            @Override
            public String mapRow(ResultSet resultSet, int i) throws SQLException {
                String xlName = resultSet.getString("xlName");
                Date scheduleDate = new Date(resultSet.getDate("scheduleDate").getTime());
                return String.format(info_format, xlName, DateFormatUtils.format(scheduleDate, "yyyy年MM月dd日"));
            }
        });

        return infoList;
    }

    @Transactional
    @Override
    public void delete(Long aLong) throws ScheduleException {
        toggleCancel(aLong);
    }

    @Transactional
    @Override
    public void toggleCancel(Long id) throws ScheduleException {
        EmployeeConfigInfo employeeConfigInfo = findById(id);
        Map<String, Object> param = new HashMap<>();
        if (employeeConfigInfo.getIsCancel()) {
            validate_jsy(employeeConfigInfo);
            if (employeeConfigInfo.getSpy() != null) {
                validate_spy(employeeConfigInfo);
            }
            employeeConfigInfo.setIsCancel(false);
        } else {
            param.clear();
            param.put("xl.id_eq", employeeConfigInfo.getXl().getId());
            List<ScheduleRule1Flat> scheduleRule1Flats = (List<ScheduleRule1Flat>) scheduleRule1FlatService.list(param);
            List<String> ryConfigIds = new ArrayList<>();
            for (ScheduleRule1Flat scheduleRule1Flat : scheduleRule1Flats) {
                ryConfigIds.addAll(Arrays.asList(scheduleRule1Flat.getRyConfigIds().split(",")));
            }

            if (ryConfigIds.contains(String.valueOf(id))) {
                throw new ScheduleException("人员配置已被规则使用,不能作废,请先修改规则!");
            } else {
                employeeConfigInfo.setIsCancel(true);
            }
        }
    }

}