Browse Source

Merge remote-tracking branch 'origin/master'

Joburgess 5 years ago
parent
commit
9c3ff1285e

+ 2 - 2
mec-biz/src/main/java/com/ym/mec/biz/dal/dao/CourseScheduleDao.java

@@ -828,7 +828,7 @@ public interface CourseScheduleDao extends BaseDAO<Long, CourseSchedule> {
      * @param classGroupIds
      * @return
      */
-    List<Map<Integer, Integer>> countTotalNumByClassGroupId(@Param("classGroupIds") Set<Integer> classGroupIds, @Param("classDate") Date classDate);
+    List<Map<Integer, Long>> countTotalNumByClassGroupId(@Param("classGroupIds") Set<Integer> classGroupIds, @Param("classDate") Date classDate);
 
     /**
      * 根据班级编号count剩余课时
@@ -836,5 +836,5 @@ public interface CourseScheduleDao extends BaseDAO<Long, CourseSchedule> {
      * @param classDate
      * @return
      */
-    List<Map<Integer, Integer>> countCurrentNumByClassGroupId(@Param("classGroupIds") Set<Integer> classGroupIds, @Param("classDate") Date classDate);
+    List<Map<Integer, Long>> countCurrentNumByClassGroupId(@Param("classGroupIds") Set<Integer> classGroupIds, @Param("classDate") Date classDate);
 }

+ 6 - 1
mec-biz/src/main/java/com/ym/mec/biz/service/impl/ClassGroupServiceImpl.java

@@ -1782,7 +1782,8 @@ public class ClassGroupServiceImpl extends BaseServiceImpl<Integer, ClassGroup>
             params.put("offset", pageInfo.getOffset());
             dataList = classGroupDao.queryMusicGroupClassGroup(params);
             Set<Integer> classGroups = dataList.stream().map(e -> e.getClassGroupId()).collect(Collectors.toSet());
-//            courseScheduleDao.countTotalCourseNum(classGroups,"MUSIC");
+            Map<Integer, Long> totalNumMap = MapUtil.convertIntegerMap(courseScheduleDao.countTotalNumByClassGroupId(classGroups, null));
+            Map<Integer, Long> currentNumMap = MapUtil.convertIntegerMap(courseScheduleDao.countCurrentNumByClassGroupId(classGroups, null));
             String join = StringUtils.join(classGroups, ",");
             //获取主教老师
             Map<Integer, String> masterTeachers = JSONObject.parseObject(JSONObject.toJSONString(MapUtil.convertMybatisMap(classGroupDao.countStudentNum(join, "BISHOP"))), HashMap.class);
@@ -1793,6 +1794,10 @@ public class ClassGroupServiceImpl extends BaseServiceImpl<Integer, ClassGroup>
             //获取退班人数
             Map<Integer, Integer> quitNums = JSONObject.parseObject(JSONObject.toJSONString(MapUtil.convertIntegerMap(classGroupDao.countQuitNum(join))), HashMap.class);
             dataList.forEach(e -> {
+                Long aLong = totalNumMap.get(e.getClassGroupId());
+                e.setTotalClassTimes(aLong==null?0:aLong.intValue());
+                Long aLong1 = currentNumMap.get(e.getClassGroupId());
+                e.setCurrentClassTimes(aLong1==null?0:aLong1.intValue());
                 e.setMasterTeacher(masterTeachers.get(e.getClassGroupId()));
                 e.setSubTeacher(subTeachers.get(e.getClassGroupId()));
                 e.setStudyNum(studyNums.get(e.getClassGroupId()));

+ 3 - 1
mec-biz/src/main/resources/config/contracts/courses.ftl

@@ -92,6 +92,8 @@
                 </div>
                 <div class="iInfo">
                     <span>学生姓名:${studentInfo.name!}</span>
+                </div>
+                <div class="iInfo">
                     <span>所在班级:${studentInfo.grade!} ${studentInfo.clazz!}</span>
                 </div>
                 <div class="iInfo">
@@ -127,7 +129,7 @@
         2.4乙方违反上述规定给乐团或乐团其他成员造成任何不良影响的,乙方应尽力弥补并消除该不良影响。
         <h3>3.请假及其处理</h3>
         3.1基于教学进度和质量保证,本课程对于课程的延续性有严格要求,因此乙方学员应尽量参加课程,无特殊情况则应避免请假。<br/>
-        3.2 VIP课程学员如有特殊情况需要请假的,应提前24小时以上以书面形式告知对应的授课老师,以便及时调整时间安排;VIP学员如遇特殊情况需要长期请假时,还可向甲方/授课老师申请办理临时休会。学员可在6个月内申请复学,超过6个月未申请复学的,甲方有权按自动退会处理。VIP课程为一对二课程的,其中一位学员申请临时休会的,还需征得同组另一位学员的同意后方可申请休会。<br/>
+        3.2 VIP课程学员如有特殊情况需要请假的,应提前24小时以上以书面形式告知对应的授课老师,以便及时调整时间安排;VIP学员如遇特殊情况需要长期请假时,还可向甲方/授课老师申请办理临时休会。学员可在6个月内申请复学,超过6个月未申请复学的,甲方有权按自动退会处理。VIP课程为一对二课程的,其中一位学员申请临时休会的,还需征得同组另一位学员的同意后方可申请休会。<br/>
         3.3鉴于团课的特殊性,甲方/乐团不接受团课学员个人单独请假,但如果因学校特殊安排等情形需要团课学员们集体请假的,乙方应提前24小时以上以书面形式告知对应的授课老师并同时提供学校的通知文件,否则当次课程视同已经教授完毕,系统将自动记录并结算课时并扣除相应课程费用。<br/>
         3.4每期课程相对应的有效期,乙方应在有效期内完成课程,10次课一期的,自交费之日起4个月内有效;20次课一期的,自交费之日起8个月内有效;40次课一期的,自交费之日起16个月内有效。如果由于指导老师请假等原因造成课程不能如期完成的,课程有效期将顺延;如课程超出有效期限,乙方所缴纳的课程费用将自动扣除逾期未完成的课时后自动清零。
         <h2>三、退费</h2>

+ 2 - 0
mec-biz/src/main/resources/config/contracts/goods.ftl

@@ -91,6 +91,8 @@
                 </div>
                 <div class="iInfo">
                     <span>学生姓名:${studentInfo.name!}</span>
+                </div>
+                <div class="iInfo">
                     <span>所在班级:${studentInfo.grade!} ${studentInfo.clazz!}</span>
                 </div>
                 <div class="iInfo">

+ 4 - 2
mec-biz/src/main/resources/config/mybatis/CourseScheduleMapper.xml

@@ -1660,7 +1660,7 @@
         GROUP BY cs.music_group_id_
     </select>
     <select id="countTotalNumByClassGroupId" resultType="java.util.Map">
-        SELECT COUNT(cs.id_) FROM course_schedule cs
+        SELECT cs.class_group_id_ 'key',COUNT(cs.id_) 'value' FROM course_schedule cs
         WHERE cs.class_group_id_ IN
         <foreach collection="classGroupIds" item="item" separator="," open="(" close=")">
             #{item}
@@ -1668,9 +1668,10 @@
         <if test="classDate != null">
             AND cs.class_date_ = DATE_FORMAT(#{classDate}, '%Y%m%d')
         </if>
+        GROUP BY cs.class_group_id_
     </select>
     <select id="countCurrentNumByClassGroupId" resultType="java.util.Map">
-        SELECT COUNT(cs.id_) FROM course_schedule cs
+        SELECT cs.class_group_id_ 'key',COUNT(cs.id_) 'value' FROM course_schedule cs
         WHERE cs.class_group_id_ IN
         <foreach collection="classGroupIds" item="item" separator="," open="(" close=")">
             #{item}
@@ -1679,5 +1680,6 @@
             AND cs.class_date_ = DATE_FORMAT(#{classDate}, '%Y%m%d')
         </if>
         AND cs.status_ != 'NOT_START'
+        GROUP BY cs.class_group_id_
     </select>
 </mapper>