wuxw
2022-11-02 554c335b81bd9bd8a4e5326829128c9bd427250d
service-store/src/main/java/com/java110/store/cmd/scheduleClasses/UpdateScheduleClassesCmd.java
@@ -15,6 +15,7 @@
 */
package com.java110.store.cmd.scheduleClasses;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.java110.core.annotation.Java110Cmd;
import com.java110.core.annotation.Java110Transactional;
@@ -22,11 +23,17 @@
import com.java110.core.event.cmd.Cmd;
import com.java110.core.event.cmd.CmdEvent;
import com.java110.core.factory.GenerateCodeFactory;
import com.java110.dto.scheduleClassesDay.ScheduleClassesDayDto;
import com.java110.intf.store.IScheduleClassesDayV1InnerServiceSMO;
import com.java110.intf.store.IScheduleClassesTimeV1InnerServiceSMO;
import com.java110.intf.store.IScheduleClassesV1InnerServiceSMO;
import com.java110.po.scheduleClasses.ScheduleClassesPo;
import com.java110.po.scheduleClassesDay.ScheduleClassesDayPo;
import com.java110.po.scheduleClassesTime.ScheduleClassesTimePo;
import com.java110.utils.exception.CmdException;
import com.java110.utils.util.Assert;
import com.java110.utils.util.BeanConvertUtil;
import com.java110.utils.util.StringUtil;
import com.java110.vo.ResultVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.slf4j.Logger;
@@ -52,10 +59,47 @@
    @Autowired
    private IScheduleClassesV1InnerServiceSMO scheduleClassesV1InnerServiceSMOImpl;
    @Autowired
    private IScheduleClassesDayV1InnerServiceSMO scheduleClassesDayV1InnerServiceSMOImpl;
    @Autowired
    private IScheduleClassesTimeV1InnerServiceSMO scheduleClassesTimeV1InnerServiceSMOImpl;
    @Override
    public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
        Assert.hasKeyAndValue(reqJson, "scheduleId", "scheduleId不能为空");
        Assert.hasKeyAndValue(reqJson, "name", "请求报文中未包含name");
        Assert.hasKeyAndValue(reqJson, "scheduleType", "请求报文中未包含scheduleType");
        Assert.hasKeyAndValue(reqJson, "scheduleCycle", "请求报文中未包含scheduleCycle");
        if(!reqJson.containsKey("days")){
            throw new CmdException("未包含天");
        }
        JSONArray days = reqJson.getJSONArray("days");
        if(days.size() <1){
            throw new CmdException("未包含天");
        }
        JSONObject day = null;
        JSONArray times = null;
        for(int dayIndex = 0 ; dayIndex < days.size(); dayIndex++){
            day = days.getJSONObject(dayIndex);
            if(ScheduleClassesDayDto.WORKDAY_NO.equals(day.getString("workday"))){
                continue;
            }
            if(!day.containsKey("times")){
                throw new CmdException("未包时间");
            }
            times = day.getJSONArray("times");
            if(times.size() <1){
                throw new CmdException("未包时间");
            }
        }
    }
    @Override
@@ -69,6 +113,55 @@
            throw new CmdException("更新数据失败");
        }
        ScheduleClassesDayPo scheduleClassesDayPo = new ScheduleClassesDayPo();
        scheduleClassesDayPo.setScheduleId(scheduleClassesPo.getScheduleId());
        flag = scheduleClassesDayV1InnerServiceSMOImpl.deleteScheduleClassesDay(scheduleClassesDayPo);
        if (flag < 1) {
            throw new CmdException("更新数据失败");
        }
        ScheduleClassesTimePo scheduleClassesTimePo = new ScheduleClassesTimePo();
        scheduleClassesTimePo.setScheduleId(scheduleClassesPo.getScheduleId());
        flag = scheduleClassesTimeV1InnerServiceSMOImpl.deleteScheduleClassesTime(scheduleClassesTimePo);
        if (flag < 1) {
            throw new CmdException("更新数据失败");
        }
        JSONArray days = reqJson.getJSONArray("days");
        JSONObject day = null;
        JSONObject time = null;
        JSONArray times = null;
        for(int dayIndex = 0 ; dayIndex < days.size(); dayIndex++){
            day = days.getJSONObject(dayIndex);
            scheduleClassesDayPo = new ScheduleClassesDayPo();
            scheduleClassesDayPo.setDayId(GenerateCodeFactory.getGeneratorId("11"));
            scheduleClassesDayPo.setDay(day.getString("day"));
            scheduleClassesDayPo.setScheduleId(scheduleClassesPo.getScheduleId());
            scheduleClassesDayPo.setWeekFlag(StringUtil.isEmpty(day.getString("weekFlag"))?"1":day.getString("weekFlag"));
            scheduleClassesDayPo.setWorkday(day.getString("workday"));
            flag = scheduleClassesDayV1InnerServiceSMOImpl.saveScheduleClassesDay(scheduleClassesDayPo);
            if (flag < 1) {
                throw new CmdException("保存数据失败");
            }
            times = day.getJSONArray("times");
            for(int timeIndex = 0 ;timeIndex < times.size();timeIndex++){
                time = times.getJSONObject(timeIndex);
                scheduleClassesTimePo = new ScheduleClassesTimePo();
                scheduleClassesTimePo.setDayId(scheduleClassesDayPo.getDayId());
                scheduleClassesTimePo.setEndTime(time.getString("endTime"));
                scheduleClassesTimePo.setScheduleId(scheduleClassesPo.getScheduleId());
                scheduleClassesTimePo.setStartTime(time.getString("startTime"));
                scheduleClassesTimePo.setTimeId(GenerateCodeFactory.getGeneratorId("11"));
                flag = scheduleClassesTimeV1InnerServiceSMOImpl.saveScheduleClassesTime(scheduleClassesTimePo);
                if (flag < 1) {
                    throw new CmdException("保存数据失败");
                }
            }
        }
        cmdDataFlowContext.setResponseEntity(ResultVo.success());
    }
}