SchedulePlanInfoServiceImpl.java 12.1 KB
package com.bsth.service.schedule.impl;

import com.bsth.common.ResponseCode;
import com.bsth.entity.schedule.SchedulePlanInfo;
import com.bsth.repository.schedule.SchedulePlanInfoRepository;
import com.bsth.service.schedule.SchedulePlanInfoService;
import com.bsth.util.ReportUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowCallbackHandler;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.*;

/**
 * Created by xu on 16/6/16.
 */
@Service
public class SchedulePlanInfoServiceImpl extends BServiceImpl<SchedulePlanInfo, Long> implements SchedulePlanInfoService {
    @Autowired
    private JdbcTemplate jdbcTemplate;

    @Override
    public SchedulePlanInfo save(SchedulePlanInfo schedulePlanInfo) {
        // 生成计划不是save,使用的是spring batch插入的
        // 这里是单独修改的时候,需要记录修改次数,用于标识被修改过

        Integer currentModifyCount = schedulePlanInfo.getModifyCount();
        schedulePlanInfo.setModifyCount(currentModifyCount == null ? 1 : ++ currentModifyCount);

        return super.save(schedulePlanInfo);
    }

    @Override
    public List<Date> findLastestPlanDate(Integer xlId) {
        String sql = "select max(schedule_date) as sd from bsth_c_s_sp_info " +
                "where xl = ?";

        final List<Date> ld = new ArrayList<>();

        jdbcTemplate.query(sql, new Object[]{xlId}, new RowCallbackHandler() {
            @Override
            public void processRow(ResultSet rs) throws SQLException {
                if (rs != null && rs.getDate("sd") != null) {
                    ld.add(new Date(rs.getDate("sd").getTime()));
                }
            }
        });

        return ld;

    }

    @Override
    public List<SchedulePlanGroupInfo> findSchedulePlanGroupInfo(Integer xlId, Date scheduleDate) {
        String sql = SchedulePlanGroupInfo.generateSelectSql();
        List<SchedulePlanGroupInfo> schedulePlanGroupInfos = jdbcTemplate.query(sql, new Object[]{xlId, scheduleDate}, new RowMapper<SchedulePlanGroupInfo>() {
            @Override
            public SchedulePlanGroupInfo mapRow(ResultSet resultSet, int i) throws SQLException {
                SchedulePlanGroupInfo schedulePlanGroupInfo = new SchedulePlanGroupInfo();
                schedulePlanGroupInfo.setFromResult(resultSet);
                return schedulePlanGroupInfo;
            }
        });

        // 排序
        Collections.sort(schedulePlanGroupInfos);

        return schedulePlanGroupInfos;
    }

    @Autowired
    private SchedulePlanInfoRepository schedulePlanInfoRepository;

    @Override
    public List<GroupInfo> findGroupInfo(Integer xlid, Date scheduleDate) {
        List<Object[]> groupInfos = schedulePlanInfoRepository.findGroupInfo(xlid, scheduleDate);
        List<GroupInfo> groupInfoList = new ArrayList<>();
        for (Object[] groupInfo : groupInfos) {
            groupInfoList.add(new GroupInfo(groupInfo));
        }
        return groupInfoList;
    }

    @Override
    @Transactional
    public int updateGroupInfo(GroupInfoUpdate groupInfoUpdate) {
        int type = groupInfoUpdate.getType();
        int result = 0;
        if (type == 1) {
            // 换车
            if (groupInfoUpdate.getUpdate().getClId() != groupInfoUpdate.getSrc().getClId()) {
                result = this.schedulePlanInfoRepository.updateGroupInfo_type_1(
                        groupInfoUpdate.getUpdate().getClId(),
                        groupInfoUpdate.getUpdate().getClZbh(),
                        groupInfoUpdate.getSrc().getXlId(),
                        groupInfoUpdate.getSrc().getScheduleDate(),
                        groupInfoUpdate.getSrc().getLpName()
                );
            }

        } else if (type == 2) {
            // 更改出场班次1的时间
            if (!groupInfoUpdate.getUpdate().getCcsj1().equals(groupInfoUpdate.getSrc().getCcsj1())) {
                result = this.schedulePlanInfoRepository.updateGroupInfo_type_2_4(
                        groupInfoUpdate.getUpdate().getCcsj1(),
                        groupInfoUpdate.getSrc().getXlId(),
                        groupInfoUpdate.getUpdate().getScheduleDate(),
                        groupInfoUpdate.getSrc().getLpName(),
                        groupInfoUpdate.getSrc().getCcsj1(),
                        "out",
                        groupInfoUpdate.getSrc().getFcno1()
                );
            }

        } else if (type == 3) {
            // 更改驾驶员1
            if (groupInfoUpdate.getUpdate().getJsy1Id() != groupInfoUpdate.getSrc().getJsy1Id()) {
                result = this.schedulePlanInfoRepository.updateGroupInfo_type_3_5_jsy(
                        groupInfoUpdate.getUpdate().getJsy1Id(),
                        groupInfoUpdate.getUpdate().getJsy1Gh(),
                        groupInfoUpdate.getUpdate().getJsy1Name(),
                        groupInfoUpdate.getSrc().getXlId(),
                        groupInfoUpdate.getSrc().getScheduleDate(),
                        groupInfoUpdate.getSrc().getLpName(),
                        groupInfoUpdate.getSrc().getJsy1Id()
                );
            }
            // 更改售票员1
            if (groupInfoUpdate.getUpdate().getSpy1Id() != groupInfoUpdate.getSrc().getSpy1Id()) {
                result = this.schedulePlanInfoRepository.updateGroupInfo_type_3_5_spy(
                        groupInfoUpdate.getUpdate().getSpy1Id(),
                        groupInfoUpdate.getUpdate().getSpy1Gh(),
                        groupInfoUpdate.getUpdate().getSpy1Name(),
                        groupInfoUpdate.getSrc().getXlId(),
                        groupInfoUpdate.getSrc().getScheduleDate(),
                        groupInfoUpdate.getSrc().getLpName(),
                        groupInfoUpdate.getSrc().getSpy1Id()
                );
            }

        } else if (type == 4) {
            // 更改出场班次2的时间
            if (!groupInfoUpdate.getUpdate().getCcsj2().equals(groupInfoUpdate.getSrc().getCcsj2())) {
                result = this.schedulePlanInfoRepository.updateGroupInfo_type_2_4(
                        groupInfoUpdate.getUpdate().getCcsj2(),
                        groupInfoUpdate.getSrc().getXlId(),
                        groupInfoUpdate.getUpdate().getScheduleDate(),
                        groupInfoUpdate.getSrc().getLpName(),
                        groupInfoUpdate.getSrc().getCcsj2(),
                        "out",
                        groupInfoUpdate.getSrc().getFcno2()
                );
            }

        } else if (type == 5) {
            // 更改驾驶员2
            if (groupInfoUpdate.getUpdate().getJsy2Id() != groupInfoUpdate.getSrc().getJsy2Id()) {
                result = this.schedulePlanInfoRepository.updateGroupInfo_type_3_5_jsy(
                        groupInfoUpdate.getUpdate().getJsy2Id(),
                        groupInfoUpdate.getUpdate().getJsy2Gh(),
                        groupInfoUpdate.getUpdate().getJsy2Name(),
                        groupInfoUpdate.getSrc().getXlId(),
                        groupInfoUpdate.getSrc().getScheduleDate(),
                        groupInfoUpdate.getSrc().getLpName(),
                        groupInfoUpdate.getSrc().getJsy2Id()
                );
            }
            // 更改售票员2
            if (groupInfoUpdate.getUpdate().getSpy2Id() != groupInfoUpdate.getSrc().getSpy2Id()) {
                result = this.schedulePlanInfoRepository.updateGroupInfo_type_3_5_spy(
                        groupInfoUpdate.getUpdate().getSpy2Id(),
                        groupInfoUpdate.getUpdate().getSpy2Gh(),
                        groupInfoUpdate.getUpdate().getSpy2Name(),
                        groupInfoUpdate.getSrc().getXlId(),
                        groupInfoUpdate.getSrc().getScheduleDate(),
                        groupInfoUpdate.getSrc().getLpName(),
                        groupInfoUpdate.getSrc().getSpy2Id()
                );
            }

        } else {
            throw new RuntimeException("未知的更新类型,type=" + type);
        }

        return result;
    }


    public  List<Map<String, Object>> infoexport(List<SchedulePlanInfoService.SchedulePlanGroupInfo> list){
        List<Map<String, Object>> lMap = new ArrayList<Map<String, Object>>();
        SimpleDateFormat sd = new SimpleDateFormat("yyyy-MM-dd");
        try {
            for (SchedulePlanInfoService.SchedulePlanGroupInfo t: list) {
                Map<String, Object> m = new HashMap<String, Object>();
                m.put("czr",t.getUpdateByName()+"  \n"+"创建日期:"+sd.format(t.getCreateDate())+"  \n"+"修改日期:"+sd.format(t.getUpdateDate()));
                m.put("xl",t.getXlName());
                m.put("rq",sd.format(t.getScheduleDate()));
                m.put("lp",t.getLpName());
                m.put("cl",exporttype(t.getClZbhs()));
                m.put("jcsj",exporttype(t.getJcsjs()));
                m.put("ccsj",exporttype(t.getCcsjs()));
                m.put("jsy",exporttypety(t.getJsyNames(),t.getJsyGhs()));
                m.put("spy",exporttypety(t.getSpyNames(),t.getSpyGhs()));
                m.put("ttInfoName",t.getTtInfoName());
                lMap.add(m);
            }

            SimpleDateFormat sdfMonth = new SimpleDateFormat("yyyy-MM-dd"),
                    sdfSimple = new SimpleDateFormat("yyyyMMdd");
            List<Iterator<?>> listI = new ArrayList<Iterator<?>>();
            Map<String, Object> m = new HashMap<String, Object>();
//			String by=map.get("by").toString();
            String xls="dailyreport.xls";
            String xlName = null;
            String dateTime = null;
            if(list != null){
                xlName = list.get(0).getXlName();
                dateTime =sd.format(list.get(0).getScheduleDate());
            }
 
            ReportUtils ee = new ReportUtils();
            try {
             
                listI.add(lMap.iterator());
                String path = this.getClass().getResource("/").getPath() + "static/pages/forms/";
                ee.excelReplace(listI, new Object[]{m}, path + "mould/"+xls,
                        path + "export/"+dateTime+"-"+xlName+"-调度值勤日报.xls");
            } catch (Exception e) {
                // TODO: handle exception
                e.printStackTrace();
            }
        }catch (Exception exp) {
            exp.printStackTrace();
        }
        return lMap;
    }

    public String exporttype(List<String> t){
        if(t.size() == 0) {
            return "";
        }else {
            if (t.size() > 1) {
                String y = "";
                for(int i = 0 ; i< t.size();i++) {
                    if(i == 0) {
                        y = y + t.get(i);
                    }else {
                        y = y + "  \n" + t.get(i);
                    }
                }
                return y;
            } else {
                return t.get(0);
            }
        }
    }
    public String exporttypety(List<String> x,List<String> y){
        if(x.size() == 0 || y.size() == 0){
            return "";
        }else {
            if(x.size() > 1 && y.size() >1){
                String k ="";
                for(int i = 0 ; i< x.size();i++) {
                    if(x.size() ==  y.size()){
                        if(x.size() -1  == i){
                            k = k + x.get(i) +"   "+y.get(i);
                        }else {
                            k = k + x.get(i) +"   "+y.get(i) + "  \n";
                        }
                    }
                }
                return k;
            }else {
                return  x.get(0) +"   "+y.get(0);
            }
        }
        
    }

}