package com.iailab.module.ansteel.coking.service.impl; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.iailab.framework.common.util.date.DateUtils; import com.iailab.framework.common.util.object.ConvertUtils; import com.iailab.module.ansteel.coking.dao.CokingOverviewDao; import com.iailab.module.ansteel.coking.dto.CokingOverviewDTO; import com.iailab.module.ansteel.coking.entity.CokingOverviewEntity; import com.iailab.module.ansteel.coking.service.CokingOverviewService; import com.iailab.module.ansteel.common.enums.ProcessTypeEnum; import com.iailab.module.ansteel.common.enums.SubProcessTypeEnum; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Service; import javax.annotation.Resource; import java.util.*; @Slf4j @Service public class CokingOverviewServiceImpl implements CokingOverviewService { @Resource private CokingOverviewDao cokingOverviewDao; @Override public Map> list(Map params) { Map> result = new HashMap<>(2); String processType = (String) params.get("processType"); if (StringUtils.isBlank(processType)) { return result; } String clock = (String) params.get("clock"); String month; if (StringUtils.isBlank(clock)) { Calendar calendar = Calendar.getInstance(); calendar.add(Calendar.DAY_OF_YEAR, -1); clock = DateUtils.format(calendar.getTime(), "yyyy-MM-dd"); month = DateUtils.format(calendar.getTime(), "yyyy-MM"); }else { Date parse = DateUtils.parse(clock, "yyyy-MM-dd"); month = DateUtils.format(parse, "yyyy-MM"); } // 天数据 QueryWrapper queryWrapperDay = new QueryWrapper<>(); queryWrapperDay.eq("process_type", processType); queryWrapperDay.eq("clock", clock); List dayList = cokingOverviewDao.selectList(queryWrapperDay); List dayDTOList = ConvertUtils.sourceToTarget(dayList, CokingOverviewDTO.class); String processName = ProcessTypeEnum.getEumByCode(processType).getProcess(); dayDTOList.forEach(e -> { e.setProcessTypeName(processName); e.setSubProcessTypeName(SubProcessTypeEnum.getEumByCode(e.getSubProcessType()).getProcess()); }); result.put("day", dayDTOList); // 月数据 QueryWrapper queryWrapperMonth = new QueryWrapper<>(); queryWrapperMonth.eq("process_type", processType); queryWrapperMonth.like("clock", month); queryWrapperMonth.select("sub_process_type","SUM(steam_p) as steam_p","SUM(dj_steam_p) as dj_steam_p","SUM(steam_c) as steam_c","SUM(steam_only_c) as steam_only_c","SUM(steam_v) as steam_v","SUM(gas_p) as gas_p","SUM(gas_c) as gas_c","SUM(power_c) as power_c","SUM(power_only_c) as power_only_c","SUM(power_c_standard) as power_c_standard","SUM(idle_time) as idle_time","SUM(bfg_c) as bfg_c","SUM(cog_p) as cog_p","SUM(cog_c) as cog_c","SUM(bfg_only_c) as bfg_only_c","SUM(cog_only_c) as cog_only_c") .groupBy("sub_process_type"); List monthList = cokingOverviewDao.selectList(queryWrapperMonth); monthList.forEach(e -> e.setClock(month)); List monthDTOList = ConvertUtils.sourceToTarget(monthList, CokingOverviewDTO.class); monthDTOList.forEach(e -> { e.setProcessTypeName(processName); e.setSubProcessTypeName(SubProcessTypeEnum.getEumByCode(e.getSubProcessType()).getProcess()); }); result.put("month", monthDTOList); return result; } @Override public void insert(List result) { cokingOverviewDao.insert(result); } }