派生自 projectDept/qhighschool

EricsHu
2022-12-05 068fc7f2e81178e55fa191a13709af64b1a163f6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
package com.qxueyou.scc.school.service.impl;
 
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
 
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
 
import com.qxueyou.scc.base.model.Result;
import com.qxueyou.scc.base.service.impl.CommonAppService;
import com.qxueyou.scc.base.util.CollectionUtils;
import com.qxueyou.scc.base.util.TraceUtils;
import com.qxueyou.scc.school.model.SchTerm;
import com.qxueyou.scc.school.model.SchTermReDay;
import com.qxueyou.scc.school.service.ISchoolTermService;
 
@Service
public class SchoolTermService extends CommonAppService implements ISchoolTermService {    
    
    @Override
    public Result insertSchoolTerm(SchTerm schTerm,String schoolDayId) {
 
        // 验证
        Result resultFlag = judgeTime(schTerm);
        if(StringUtils.isNotBlank(resultFlag.getMsg())){
            return resultFlag;
        }
        
        if(StringUtils.isNotBlank(schTerm.getTermId())){
            SchTerm schTermNew = read(SchTerm.class, schTerm.getTermId());
            schTermNew.setName(schTerm.getName());
            schTermNew.setEndTime(schTerm.getEndTime());
            schTermNew.setStartTime(schTerm.getStartTime());
            schTermNew.setSchoolYearId(schTerm.getSchoolYearId());
            schTermNew.setTermOrder(schTerm.getTermOrder());
            TraceUtils.setUpdateTrace(schTermNew);
            this.save(schTermNew);
        }else{
            TraceUtils.setCreateTrace(schTerm);
            this.save(schTerm);
        }
        
        String hql = " from SchTermReDay where termId=?";
        
        SchTermReDay re = findUnique(hql, CollectionUtils.newList(schTerm.getTermId()), SchTermReDay.class);
        
        if(re==null){
            re = new SchTermReDay();
            TraceUtils.setCreateTrace(re);
            re.setSchoolDayId(schoolDayId);
            re.setDeleteFlag(false);
            re.setTermId(schTerm.getTermId());
            this.save(re);
        }else{
            re.setSchoolDayId(schoolDayId);
            TraceUtils.setUpdateTrace(re);
            save(re);
        }
        
        return new Result(true);
        
    }
 
    /**
     * 判断选择的时间不能包含已添加学年的开始时间至结束时间
     * time
     * @return
     */
    public Result judgeTime( SchTerm schTerm) {
        // 返回结果
        Result resultFlag = new Result(true);
        List<SchTerm> schTermLst = setPublic(schTerm.getTermId(),schTerm.getSchoolYearId());
        
        // 验证
        for (int i = 0; i < schTermLst.size(); i++) {
            boolean flagStart = schTermLst.get(i).getStartTime().before(schTerm.getStartTime());
            boolean flagend = schTermLst.get(i).getEndTime().before(schTerm.getEndTime());
            
            if(flagStart == false && flagend == true){ // 选择的时间包含开始时间和结束时间
                resultFlag = new Result(true,"选择的学期时间不能包含已添加的学期时间");
                break;
            }
        }
        
        return resultFlag;
    }
 
    /**
     * 开始时间的回调函数
     * schSchoolYear :startTime
     * @return
     */
    @Override
    public Result startCallback(String termId,String startTime,String shoolYearId) {
 
        return callback(termId, startTime, shoolYearId);
    }
    
    /**
     * 结束时间的回调函数
     * schSchoolYear :endTime
     * @return
     */
    @Override
    public Result endCallback(String termId,String endTime,String shoolYearId) {
 
        return callback(termId, endTime, shoolYearId);
    }
    
    /**
     * 判断选择的时间不能在已添加学年的开始时间和结束时间之间
     * time
     * @return
     */
    public Result callback(String schTermId, String startEndTime,String schShoolYearId) {
 
        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");//小写的mm表示的是分钟  
        Date time = null;
        try {
            time = sdf.parse(startEndTime);
        } catch (ParseException e) {
            e.printStackTrace();
        }
        
        // 返回结果
        Result resultFlag = new Result(true);
        List<SchTerm> schTermLst = setPublic(schTermId,schShoolYearId);
        
        if(schTermLst.isEmpty()){
            return resultFlag;
        }
        
        for (int i = 0; i < schTermLst.size(); i++) {
            boolean flagStart = schTermLst.get(i).getStartTime().before(time);
            boolean flagEnd = schTermLst.get(i).getEndTime().before(time);
            
            if(flagStart == true && flagEnd == false){ // 选择的时间在开始时间之后结束时间之前
                resultFlag = new Result(true,"当前学年已设置该时间的学期");
                break;
            }
        }
        
        return resultFlag;
    }
    
    public List<SchTerm> setPublic(String schTermId,String schShoolYearId) {
 
        // 获取当前学年的所有学期
        String hql = "from SchTerm where deleteFlag is false and schoolYearId = ? order by endTime desc";
        List<SchTerm> schTermList = find(hql, CollectionUtils.newList(schShoolYearId), SchTerm.class);
        
        // 编辑页面过滤当前学年
        List<SchTerm> schTermLst = new ArrayList<SchTerm>();
        if(StringUtils.isNotBlank(schTermId)){
            for (SchTerm schTerm : schTermList) {
                if(!schTerm.getTermId().equals(schTermId)){
                    schTermLst.add(schTerm);
                }
            }
            return schTermLst;
        }else{
            return schTermList;
        }
    }
    
    @Override
    public Result deleteSchoolTerm(String[] termIds) {
 
        String hql = "update SchTerm set deleteFlag = true where termId = ? ";
        return bulkUpdateInLoop(hql, termIds);
        
    }
    
 
}