瀏覽代碼

Merge branch 'master' of http://git.dayaedu.com/yonge/mec

# Conflicts:
#	mec-biz/src/main/resources/config/mybatis/CourseScheduleMapper.xml
zouxuan 5 年之前
父節點
當前提交
98686b55d8
共有 55 個文件被更改,包括 1760 次插入617 次删除
  1. 3 0
      cms/src/main/resources/config/mybatis/SysNewsInformationMapper.xml
  2. 2 2
      mec-auth/mec-auth-api/src/main/java/com/ym/mec/auth/api/entity/SysRole.java
  3. 29 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/dao/CourseScheduleDao.java
  4. 12 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/dao/CourseScheduleTeacherSalaryDao.java
  5. 1 1
      mec-biz/src/main/java/com/ym/mec/biz/dal/dao/MusicGroupSubjectGoodsGroupDao.java
  6. 1 1
      mec-biz/src/main/java/com/ym/mec/biz/dal/dao/MusicGroupSubjectPlanDao.java
  7. 66 59
      mec-biz/src/main/java/com/ym/mec/biz/dal/dao/StudentRegistrationDao.java
  8. 18 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/dao/VipGroupDao.java
  9. 11 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupCourseSchduleRecordDto.java
  10. 44 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupManageDetailDto.java
  11. 58 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupSalaryBaseInfo.java
  12. 73 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupSalaryDto.java
  13. 3 3
      mec-biz/src/main/java/com/ym/mec/biz/dal/entity/ClassGroup.java
  14. 11 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/entity/MusicGroupStudentFee.java
  15. 1 1
      mec-biz/src/main/java/com/ym/mec/biz/dal/entity/MusicGroupSubjectPlan.java
  16. 3 3
      mec-biz/src/main/java/com/ym/mec/biz/dal/entity/StudentRegistration.java
  17. 11 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/entity/VipGroup.java
  18. 4 1
      mec-biz/src/main/java/com/ym/mec/biz/dal/enums/VipGroupStatusEnum.java
  19. 35 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/page/CourseScheduleQueryInfo.java
  20. 57 0
      mec-biz/src/main/java/com/ym/mec/biz/dal/page/VipGroupSalaryQueryInfo.java
  21. 1 1
      mec-biz/src/main/java/com/ym/mec/biz/service/ClassGroupService.java
  22. 20 4
      mec-biz/src/main/java/com/ym/mec/biz/service/ContractService.java
  23. 18 0
      mec-biz/src/main/java/com/ym/mec/biz/service/CourseScheduleService.java
  24. 1 1
      mec-biz/src/main/java/com/ym/mec/biz/service/MusicGroupSubjectGoodsGroupService.java
  25. 2 2
      mec-biz/src/main/java/com/ym/mec/biz/service/MusicGroupSubjectPlanService.java
  26. 76 70
      mec-biz/src/main/java/com/ym/mec/biz/service/StudentRegistrationService.java
  27. 22 5
      mec-biz/src/main/java/com/ym/mec/biz/service/VipGroupService.java
  28. 1 1
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/ClassGroupServiceImpl.java
  29. 262 38
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/ContractServiceImpl.java
  30. 49 0
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/CourseScheduleServiceImpl.java
  31. 5 0
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/DemoGroupServiceImpl.java
  32. 1 1
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/MusicGroupSubjectGoodsGroupServiceImpl.java
  33. 2 2
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/MusicGroupSubjectPlanServiceImpl.java
  34. 17 7
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/StudentRegistrationServiceImpl.java
  35. 88 12
      mec-biz/src/main/java/com/ym/mec/biz/service/impl/VipGroupServiceImpl.java
  36. 39 39
      mec-biz/src/main/resources/config/contracts/courses.ftl
  37. 14 14
      mec-biz/src/main/resources/config/contracts/goods.ftl
  38. 202 216
      mec-biz/src/main/resources/config/contracts/register.ftl
  39. 61 7
      mec-biz/src/main/resources/config/mybatis/CourseScheduleMapper.xml
  40. 42 1
      mec-biz/src/main/resources/config/mybatis/CourseScheduleTeacherSalaryMapper.xml
  41. 1 1
      mec-biz/src/main/resources/config/mybatis/DemoGroupMapper.xml
  42. 6 2
      mec-biz/src/main/resources/config/mybatis/MusicGroupStudentFeeMapper.xml
  43. 4 0
      mec-biz/src/main/resources/config/mybatis/StudentRegistrationMapper.xml
  44. 45 9
      mec-biz/src/main/resources/config/mybatis/VipGroupMapper.xml
  45. 3 1
      mec-education/src/main/java/com/ym/mec/education/EducationApplication.java
  46. 42 5
      mec-education/src/main/java/com/ym/mec/education/controller/CourseScheduleController.java
  47. 0 38
      mec-education/src/main/java/com/ym/mec/education/controller/UserController.java
  48. 2 1
      mec-education/src/main/java/com/ym/mec/education/service/impl/SysMessageServiceImpl.java
  49. 53 49
      mec-education/src/main/java/com/ym/mec/education/service/impl/TeacherServiceImpl.java
  50. 1 1
      mec-education/src/main/resources/application.yml
  51. 30 0
      mec-student/src/main/java/com/ym/mec/student/controller/ContractsController.java
  52. 32 15
      mec-student/src/main/java/com/ym/mec/student/controller/MusicGroupController.java
  53. 131 0
      mec-util/src/main/java/com/ym/mec/util/money/MoneyUtil.java
  54. 1 1
      mec-web/src/main/java/com/ym/mec/web/controller/ClassGroupController.java
  55. 43 2
      mec-web/src/main/java/com/ym/mec/web/controller/VipGroupManageController.java

+ 3 - 0
cms/src/main/resources/config/mybatis/SysNewsInformationMapper.xml

@@ -29,6 +29,9 @@
 			<if test="title != null">
 				and title_ like '%' #{title} '%'
 			</if>
+			<if test="search != null">
+				and title_ like '%' #{search} '%'
+			</if>
 		</where>
 	</sql>
 	

+ 2 - 2
mec-auth/mec-auth-api/src/main/java/com/ym/mec/auth/api/entity/SysRole.java

@@ -1,11 +1,11 @@
 package com.ym.mec.auth.api.entity;
 
-import com.ym.mec.auth.api.enums.YesOrNoEnum;
 import io.swagger.annotations.ApiModelProperty;
-import org.apache.commons.lang3.builder.ToStringBuilder;
 
 import java.util.List;
 
+import org.apache.commons.lang3.builder.ToStringBuilder;
+
 /**
  * 对应数据库表(sys_role):
  */

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

@@ -47,6 +47,15 @@ public interface CourseScheduleDao extends BaseDAO<Long, CourseSchedule> {
 
     /**
      * @Author: Joburgess
+     * @Date: 2019/10/11
+     * @params [courseScheduleId]
+     * @return java.util.List<java.lang.String>
+     * @describe 获取课程签到学生姓名
+     */
+    List<String> findStudentNamesByCourseSchedule(Long courseScheduleId);
+
+    /**
+     * @Author: Joburgess
      * @Date: 2019/9/17
      * 根据日期获取老师当日排课信息
      */
@@ -55,6 +64,16 @@ public interface CourseScheduleDao extends BaseDAO<Long, CourseSchedule> {
 
     /**
      * @Author: Joburgess
+     * @Date: 2019/10/11
+     * @params [params]
+     * @return java.util.List<com.ym.mec.biz.dal.dto.CourseScheduleDto>
+     * @describe 根据
+     */
+    List<CourseScheduleDto> getCourseSchedulesWithDate(Map<String,Object> params);
+    int countCourseSchedulesWithDate(Map<String,Object> params);
+
+    /**
+     * @Author: Joburgess
      * @Date: 2019/9/17
      * 根据乐团ID删除排课
      */
@@ -87,6 +106,16 @@ public interface CourseScheduleDao extends BaseDAO<Long, CourseSchedule> {
 
     /**
      * @Author: Joburgess
+     * @Date: 2019/10/11
+     * @params [month, organId]
+     * @return java.util.List<java.util.Date>
+     * @describe 获取当月有课的日期
+     */
+    List<Date> getCourseScheduleDate(@Param("month") Date month,
+                                     @Param("organId") Long organId);
+
+    /**
+     * @Author: Joburgess
      * @Date: 2019/9/23
      * 统计教师在一天内有时间重复的课数
      */

+ 12 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/dao/CourseScheduleTeacherSalaryDao.java

@@ -1,9 +1,11 @@
 package com.ym.mec.biz.dal.dao;
 
+import com.ym.mec.biz.dal.dto.VipGroupSalaryDto;
 import com.ym.mec.biz.dal.entity.CourseScheduleTeacherSalary;
 import com.ym.mec.common.dal.BaseDAO;
 
 import java.util.List;
+import java.util.Map;
 
 public interface CourseScheduleTeacherSalaryDao extends BaseDAO<Long, CourseScheduleTeacherSalary> {
 
@@ -15,5 +17,15 @@ public interface CourseScheduleTeacherSalaryDao extends BaseDAO<Long, CourseSche
      * @describe 批量插入
      */
     int batchInsert(List<CourseScheduleTeacherSalary> courseScheduleTeacherSalaries);
+
+    /**
+     * @Author: Joburgess
+     * @Date: 2019/10/11
+     * @params [params]
+     * @return java.util.List<com.ym.mec.biz.dal.dto.VipGroupSalaryDto>
+     * @describe 获取vip课财务记录
+     */
+    List<VipGroupSalaryDto> findVipGroupSalarys(Map<String,Object> params);
+    int countVipGroupSalarys(Map<String,Object> params);
 	
 }

+ 1 - 1
mec-biz/src/main/java/com/ym/mec/biz/dal/dao/MusicGroupSubjectGoodsGroupDao.java

@@ -22,7 +22,7 @@ public interface MusicGroupSubjectGoodsGroupDao extends BaseDAO<Long, MusicGroup
      * @param subId
      * @return
      */
-    List<MusicGroupSubjectGoodsGroup> findGoodsGroup(@Param("musicGroupId") Integer musicGroupId, @Param("subId") Integer subId);
+    List<MusicGroupSubjectGoodsGroup> findGoodsGroup(@Param("musicGroupId") String musicGroupId, @Param("subId") Integer subId);
 
 
     /**

+ 1 - 1
mec-biz/src/main/java/com/ym/mec/biz/dal/dao/MusicGroupSubjectPlanDao.java

@@ -24,5 +24,5 @@ public interface MusicGroupSubjectPlanDao extends BaseDAO<Integer, MusicGroupSub
      * @param subjectId
      * @return
      */
-    MusicGroupSubjectPlan getMusicOneSubjectClassPlan(@Param("musicGroupId") int musicGroupId, @Param("subjectId") int subjectId);
+    MusicGroupSubjectPlan getMusicOneSubjectClassPlan(@Param("musicGroupId") String musicGroupId, @Param("subjectId") int subjectId);
 }

+ 66 - 59
mec-biz/src/main/java/com/ym/mec/biz/dal/dao/StudentRegistrationDao.java

@@ -13,70 +13,77 @@ import java.util.Map;
 
 public interface StudentRegistrationDao extends BaseDAO<Long, StudentRegistration> {
 
-    /**
-     * 获取乐团学员报名详情
-     *
-     * @param params
-     * @return
-     */
-    List<StudentApplyDetailDto> queryStudentDetailPage(Map<String, Object> params);
+	/**
+	 * 获取乐团学员报名详情
+	 *
+	 * @param params
+	 * @return
+	 */
+	List<StudentApplyDetailDto> queryStudentDetailPage(Map<String, Object> params);
 
-    /**
-     * 获取乐团学员报名详情条数
-     *
-     * @param params
-     * @return
-     */
-    int queryStudentDetailCount(Map<String, Object> params);
+	/**
+	 * 获取乐团学员报名详情条数
+	 *
+	 * @param params
+	 * @return
+	 */
+	int queryStudentDetailCount(Map<String, Object> params);
 
-    /**
-     * 根据乐团编号和声部获取缴费学员人数
-     *
-     * @param musicGroupId
-     * @param subjectId
-     * @return
-     */
-    Integer countPayNum(@Param("musicGroupId") Integer musicGroupId, @Param("subjectId") Integer subjectId);
+	/**
+	 * 根据乐团编号和声部获取缴费学员人数
+	 *
+	 * @param musicGroupId
+	 * @param subjectId
+	 * @return
+	 */
+	Integer countPayNum(@Param("musicGroupId") Integer musicGroupId, @Param("subjectId") Integer subjectId);
 
-    /**
-     * 学生报名缴费金额详情
-     *
-     * @param studentId
-     * @param musicGroupId
-     * @return
-     */
-    StudentFeeDto queryFeeDetail(Integer studentId, String musicGroupId);
+	/**
+	 * 学生报名缴费金额详情
+	 *
+	 * @param studentId
+	 * @param musicGroupId
+	 * @return
+	 */
+	StudentFeeDto queryFeeDetail(Integer studentId, String musicGroupId);
 
+	/**
+	 * 获取乐团声部未分配的班级的学生
+	 *
+	 * @param musicGroupId    乐团id
+	 * @param actualSubjectId 科目id
+	 * @return
+	 */
+	List<StudentRegistration> getNoClassStuBySubjectId(@Param("musicGroupId") Integer musicGroupId, @Param("actualSubjectId") Integer actualSubjectId);
 
-    /**
-     * 获取乐团声部未分配的班级的学生
-     *
-     * @param musicGroupId    乐团id
-     * @param actualSubjectId 科目id
-     * @return
-     */
-    List<StudentRegistration> getNoClassStuBySubjectId(@Param("musicGroupId") Integer musicGroupId, @Param("actualSubjectId") Integer actualSubjectId);
+	/**
+	 * 获取乐团声部未分配学生数
+	 *
+	 * @param musicGroupId
+	 * @param actualSubjectId
+	 * @return
+	 */
+	Integer getNoClassStuCountBySubjectId(@Param("musicGroupId") Integer musicGroupId, @Param("actualSubjectId") Integer actualSubjectId);
 
-    /**
-     * 获取乐团声部未分配学生数
-     *
-     * @param musicGroupId
-     * @param actualSubjectId
-     * @return
-     */
-    Integer getNoClassStuCountBySubjectId(@Param("musicGroupId") Integer musicGroupId, @Param("actualSubjectId") Integer actualSubjectId);
+	/**
+	 * 根据乐团id和user_id 更新
+	 * @param studentRegistration
+	 * @return
+	 */
+	Integer updateByUserIdAndMusicGroupId(@Param("studentRegistration") StudentRegistration studentRegistration);
 
-    /**
-     * 根据乐团id和user_id 更新
-     * @param studentRegistration
-     * @return
-     */
-    Integer updateByUserIdAndMusicGroupId(@Param("studentRegistration") StudentRegistration studentRegistration);
-    
-    /**
-     * 查询学生信息
-     * @param userId
-     * @return
-     */
-    StudentInfo queryStudentInfo(Integer userId);
+	/**
+	 * 查询学生信息
+	 * @param userId
+	 * @return
+	 */
+	StudentInfo queryStudentInfo(Integer userId);
+
+	/**
+	 * 查询用户指定乐团的报名信息
+	 * @param userId 用户编号
+	 * @param musicGroupId 乐团编号
+	 * @return
+	 */
+	StudentRegistration queryByUserIdAndMusicGroupId(@Param("userId") Integer userId, @Param("musicGroupId") String musicGroupId);
 }

+ 18 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/dao/VipGroupDao.java

@@ -105,6 +105,24 @@ public interface VipGroupDao extends BaseDAO<Long, VipGroup> {
 
 	/**
 	 * @Author: Joburgess
+	 * @Date: 2019/10/11
+	 * @params [vipGroupId]
+	 * @return com.ym.mec.biz.dal.dto.VipGroupSalaryBaseInfo
+	 * @describe 获取vip课财务基本信息
+	 */
+	VipGroupSalaryBaseInfo getVipGroupSalaryInfo(Long vipGroupId);
+
+	/**
+	 * @Author: Joburgess
+	 * @Date: 2019/10/11
+	 * @params [vipGroupId]
+	 * @return int
+	 * @describe 统计扣费笔数
+	 */
+	int countVipGroupDeductionNum(Long vipGroupId);
+
+	/**
+	 * @Author: Joburgess
 	 * @Date: 2019/10/3
 	 * @params [params]
 	 * @return java.util.List<com.ym.mec.biz.dal.entity.CourseSchedule>

+ 11 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupCourseSchduleRecordDto.java

@@ -28,6 +28,17 @@ public class VipGroupCourseSchduleRecordDto {
     @ApiModelProperty(value = "结算状态")
     private YesOrNoEnum isSalary;
 
+    @ApiModelProperty(value = "上课人数")
+    private Integer attendanceNum;
+
+    public Integer getAttendanceNum() {
+        return attendanceNum;
+    }
+
+    public void setAttendanceNum(Integer attendanceNum) {
+        this.attendanceNum = attendanceNum;
+    }
+
     public Long getId() {
         return id;
     }

+ 44 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupManageDetailDto.java

@@ -15,12 +15,56 @@ public class VipGroupManageDetailDto extends VipGroup {
     @ApiModelProperty(value = "最新课次",required = false)
     private Integer latestClassTime;
 
+    @ApiModelProperty(value = "科目名称")
+    private String subjectName;
+
+    @ApiModelProperty(value = "科目编号列表")
+    private String subjectIdList;
+
+    @ApiModelProperty(value = "课程形式")
+    private String categoryName;
+
     @ApiModelProperty(value = "学生数量", required = false)
     private Integer studentNum;
 
     @ApiModelProperty(value = "小课学院",required = false)
     private List<SysUser> students;
 
+    @ApiModelProperty(value = "教学点名称")
+    private String teacherSchoolName;
+
+    public String getTeacherSchoolName() {
+        return teacherSchoolName;
+    }
+
+    public void setTeacherSchoolName(String teacherSchoolName) {
+        this.teacherSchoolName = teacherSchoolName;
+    }
+
+    public String getCategoryName() {
+        return categoryName;
+    }
+
+    public void setCategoryName(String categoryName) {
+        this.categoryName = categoryName;
+    }
+
+    public String getSubjectIdList() {
+        return subjectIdList;
+    }
+
+    public void setSubjectIdList(String subjectIdList) {
+        this.subjectIdList = subjectIdList;
+    }
+
+    public String getSubjectName() {
+        return subjectName;
+    }
+
+    public void setSubjectName(String subjectName) {
+        this.subjectName = subjectName;
+    }
+
     public Integer getLatestClassTime() {
         return latestClassTime;
     }

+ 58 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupSalaryBaseInfo.java

@@ -0,0 +1,58 @@
+package com.ym.mec.biz.dal.dto;
+
+import io.swagger.annotations.ApiModelProperty;
+import org.codehaus.jackson.annotate.JsonIgnore;
+
+import java.math.BigDecimal;
+
+/**
+ * @Author Joburgess
+ * @Date 2019/10/11
+ */
+public class VipGroupSalaryBaseInfo {
+
+    @ApiModelProperty(value = "预计课酬总额")
+    @JsonIgnore
+    private BigDecimal expectTotalSalary;
+
+    @ApiModelProperty(value = "扣费笔数")
+    private Integer feeDeductionNum;
+
+    @ApiModelProperty(value = "扣费总额")
+    private BigDecimal totalFeeDeduction;
+
+    @ApiModelProperty(value = "课酬总额")
+    private BigDecimal totalSalary;
+
+    public BigDecimal getExpectTotalSalary() {
+        return expectTotalSalary;
+    }
+
+    public void setExpectTotalSalary(BigDecimal expectTotalSalary) {
+        this.expectTotalSalary = expectTotalSalary;
+    }
+
+    public Integer getFeeDeductionNum() {
+        return feeDeductionNum;
+    }
+
+    public void setFeeDeductionNum(Integer feeDeductionNum) {
+        this.feeDeductionNum = feeDeductionNum;
+    }
+
+    public BigDecimal getTotalFeeDeduction() {
+        return totalFeeDeduction;
+    }
+
+    public void setTotalFeeDeduction(BigDecimal totalFeeDeduction) {
+        this.totalFeeDeduction = totalFeeDeduction;
+    }
+
+    public BigDecimal getTotalSalary() {
+        return totalSalary;
+    }
+
+    public void setTotalSalary(BigDecimal totalSalary) {
+        this.totalSalary = totalSalary;
+    }
+}

+ 73 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/dto/VipGroupSalaryDto.java

@@ -0,0 +1,73 @@
+package com.ym.mec.biz.dal.dto;
+
+import com.ym.mec.biz.dal.entity.CourseScheduleTeacherSalary;
+import com.ym.mec.biz.dal.enums.TeachModeEnum;
+import com.ym.mec.biz.dal.enums.YesOrNoEnum;
+import io.swagger.annotations.ApiModelProperty;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * @Author Joburgess
+ * @Date 2019/10/11
+ */
+public class VipGroupSalaryDto extends CourseScheduleTeacherSalary {
+
+    @ApiModelProperty(value = "课程编号")
+    private Long courseScheduleId;
+
+    @ApiModelProperty(value = "上课日期")
+    private java.util.Date classDate;
+
+    @ApiModelProperty(value = "教学形式")
+    private TeachModeEnum teachMode;
+
+    @ApiModelProperty(value = "扣除费用")
+    private BigDecimal deductionFee;
+
+    @ApiModelProperty(value = "是否已结算")
+    private YesOrNoEnum isSalary;
+
+    public YesOrNoEnum getIsSalary() {
+        return isSalary;
+    }
+
+    public void setIsSalary(YesOrNoEnum isSalary) {
+        this.isSalary = isSalary;
+    }
+
+    public BigDecimal getDeductionFee() {
+        return deductionFee;
+    }
+
+    public void setDeductionFee(BigDecimal deductionFee) {
+        this.deductionFee = deductionFee;
+    }
+
+    @Override
+    public Long getCourseScheduleId() {
+        return courseScheduleId;
+    }
+
+    @Override
+    public void setCourseScheduleId(Long courseScheduleId) {
+        this.courseScheduleId = courseScheduleId;
+    }
+
+    public Date getClassDate() {
+        return classDate;
+    }
+
+    public void setClassDate(Date classDate) {
+        this.classDate = classDate;
+    }
+
+    public TeachModeEnum getTeachMode() {
+        return teachMode;
+    }
+
+    public void setTeachMode(TeachModeEnum teachMode) {
+        this.teachMode = teachMode;
+    }
+}

+ 3 - 3
mec-biz/src/main/java/com/ym/mec/biz/dal/entity/ClassGroup.java

@@ -18,7 +18,7 @@ public class ClassGroup {
 
 	/**  */
 	@ApiModelProperty(value = "乐团编号", required = true)
-	private Integer musicGroupId;
+	private String musicGroupId;
 
 	/**  */
 	@ApiModelProperty(value = "上课模式", required = true)
@@ -113,11 +113,11 @@ public class ClassGroup {
 		return this.id;
 	}
 
-	public void setMusicGroupId(Integer musicGroupId) {
+	public void setMusicGroupId(String musicGroupId) {
 		this.musicGroupId = musicGroupId;
 	}
 
-	public Integer getMusicGroupId() {
+	public String getMusicGroupId() {
 		return this.musicGroupId;
 	}
 

+ 11 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/entity/MusicGroupStudentFee.java

@@ -21,6 +21,9 @@ public class MusicGroupStudentFee {
 	/**  */
 	@ApiModelProperty(value = "用户编号", required = false)
 	private Integer userId;
+	
+	@ApiModelProperty(value = "声部编号", required = false)
+	private Integer subjectId;
 
 	/** 课程费用 */
 	@ApiModelProperty(value = "课程费用", required = false)
@@ -83,6 +86,14 @@ public class MusicGroupStudentFee {
 		return this.userId;
 	}
 
+	public Integer getSubjectId() {
+		return subjectId;
+	}
+
+	public void setSubjectId(Integer subjectId) {
+		this.subjectId = subjectId;
+	}
+
 	public BigDecimal getCourseFee() {
 		return courseFee;
 	}

+ 1 - 1
mec-biz/src/main/java/com/ym/mec/biz/dal/entity/MusicGroupSubjectPlan.java

@@ -50,7 +50,7 @@ public class MusicGroupSubjectPlan {
 	
 	/** 保证金(只有租赁才有) */
 	@ApiModelProperty(value = "保证金(只有租赁才有)",required = false)
-	private BigDecimal depositFee;
+	private BigDecimal depositFee = new BigDecimal(0);
 	
 	/**  */
 	private java.util.Date createTime;

+ 3 - 3
mec-biz/src/main/java/com/ym/mec/biz/dal/entity/StudentRegistration.java

@@ -42,7 +42,7 @@ public class StudentRegistration {
      * 所属乐团(对应 music_group 表id)
      */
     @ApiModelProperty(value = "所属乐团(对应 music_group 表id)", required = true)
-    private Integer musicGroupId;
+    private String musicGroupId;
 
     /**
      * 当前所在年级
@@ -169,11 +169,11 @@ public class StudentRegistration {
         return this.userId;
     }
 
-    public void setMusicGroupId(Integer musicGroupId) {
+    public void setMusicGroupId(String musicGroupId) {
         this.musicGroupId = musicGroupId;
     }
 
-    public Integer getMusicGroupId() {
+    public String getMusicGroupId() {
         return this.musicGroupId;
     }
 

+ 11 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/entity/VipGroup.java

@@ -81,6 +81,9 @@ public class VipGroup {
 	@ApiModelProperty("活动方案编号")
 	private Long vipGroupActivityId;
 
+	@ApiModelProperty(value = "活动方案名称")
+	private String vipGroupActivityName;
+
 	@ApiModelProperty(value = "课程状态")
 	private VipGroupStatusEnum status;
 
@@ -96,6 +99,14 @@ public class VipGroup {
 	@ApiModelProperty(value = "赠送课时类型")
 	private TeachModeEnum giveTeachMode;
 
+	public String getVipGroupActivityName() {
+		return vipGroupActivityName;
+	}
+
+	public void setVipGroupActivityName(String vipGroupActivityName) {
+		this.vipGroupActivityName = vipGroupActivityName;
+	}
+
 	public String getUserName() {
 		return userName;
 	}

+ 4 - 1
mec-biz/src/main/java/com/ym/mec/biz/dal/enums/VipGroupStatusEnum.java

@@ -8,7 +8,10 @@ import com.ym.mec.common.enums.BaseEnum;
  */
 public enum  VipGroupStatusEnum implements BaseEnum<Integer, VipGroupStatusEnum> {
 
-    NOT_START(0, "未开始"), APPLYING(1, "报名中"), FINISH(2, "报名已结束"), CANCEL(3, "取消");
+    NOT_START(0, "未开始"),
+    APPLYING(1, "报名中"),
+    FINISH(2, "报名已结束"),
+    CANCEL(3, "取消");
 
     private Integer code;
 

+ 35 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/page/CourseScheduleQueryInfo.java

@@ -0,0 +1,35 @@
+package com.ym.mec.biz.dal.page;
+
+import com.ym.mec.common.page.QueryInfo;
+import io.swagger.annotations.ApiModelProperty;
+
+import java.util.Date;
+
+/**
+ * @Author Joburgess
+ * @Date 2019/10/11
+ */
+public class CourseScheduleQueryInfo extends QueryInfo {
+
+    @ApiModelProperty(value = "部门编号")
+    private Long organId;
+
+    @ApiModelProperty(value = "上课日期")
+    private Date date;
+
+    public Long getOrganId() {
+        return organId;
+    }
+
+    public void setOrganId(Long organId) {
+        this.organId = organId;
+    }
+
+    public Date getDate() {
+        return date;
+    }
+
+    public void setDate(Date date) {
+        this.date = date;
+    }
+}

+ 57 - 0
mec-biz/src/main/java/com/ym/mec/biz/dal/page/VipGroupSalaryQueryInfo.java

@@ -0,0 +1,57 @@
+package com.ym.mec.biz.dal.page;
+
+import com.ym.mec.common.page.QueryInfo;
+import io.swagger.annotations.ApiModelProperty;
+
+import java.util.Date;
+
+/**
+ * @Author Joburgess
+ * @Date 2019/10/11
+ */
+public class VipGroupSalaryQueryInfo extends QueryInfo {
+
+    @ApiModelProperty(value = "vip课编号")
+    private Long vipGroupId;
+
+    @ApiModelProperty(value = "部门编号")
+    private Long organId;
+
+    @ApiModelProperty(value = "开始时间")
+    private Date startTime;
+
+    @ApiModelProperty(value = "结束时间")
+    private Date endTime;
+
+    public Long getVipGroupId() {
+        return vipGroupId;
+    }
+
+    public void setVipGroupId(Long vipGroupId) {
+        this.vipGroupId = vipGroupId;
+    }
+
+    public Long getOrganId() {
+        return organId;
+    }
+
+    public void setOrganId(Long organId) {
+        this.organId = organId;
+    }
+
+    public Date getStartTime() {
+        return startTime;
+    }
+
+    public void setStartTime(Date startTime) {
+        this.startTime = startTime;
+    }
+
+    public Date getEndTime() {
+        return endTime;
+    }
+
+    public void setEndTime(Date endTime) {
+        this.endTime = endTime;
+    }
+}

+ 1 - 1
mec-biz/src/main/java/com/ym/mec/biz/service/ClassGroupService.java

@@ -71,7 +71,7 @@ public interface ClassGroupService extends BaseService<Integer, ClassGroup> {
      * @return
      * @throws Exception
      */
-    ClassGroup addMixClassGroup(int musicGroupId, String name, String classGroupIds) throws Exception;
+    ClassGroup addMixClassGroup(String musicGroupId, String name, String classGroupIds) throws Exception;
 
     /**
      * 跟班级ids查询班级信息

+ 20 - 4
mec-biz/src/main/java/com/ym/mec/biz/service/ContractService.java

@@ -24,7 +24,7 @@ public interface ContractService {
 	String queryRegisterContract(Integer userId);
 
 	/**
-	 * 传递课程协议
+	 * 传递乐团课程协议
 	 * @param userId
 	 * @param musicGroupId
 	 * @return
@@ -32,12 +32,28 @@ public interface ContractService {
 	boolean transferMusicGroupCoursesContract(Integer userId, String musicGroupId);
 
 	/**
-	 * 查询课程协议
+	 * 查询乐团课程协议
 	 * @param userId
-	 * @param musicGroupId
+	 * @param vipGroupId
+	 * @return
+	 */
+	String queryMusicGroupCoursesContract(Integer userId, String vipGroupId);
+
+	/**
+	 * 传递VIP课程协议
+	 * @param userId
+	 * @param vipGroupId
+	 * @return
+	 */
+	boolean transferVipGroupCoursesContract(Integer userId, Long vipGroupId);
+
+	/**
+	 * 查询VIP课程协议
+	 * @param userId
+	 * @param vipGroupId
 	 * @return
 	 */
-	String queryMusicGroupCoursesContract(Integer userId, String musicGroupId);
+	String queryVipGroupCoursesContract(Integer userId, Long vipGroupId);
 
 	/**
 	 * 传递商品协议

+ 18 - 0
mec-biz/src/main/java/com/ym/mec/biz/service/CourseScheduleService.java

@@ -5,7 +5,9 @@ import com.ym.mec.biz.dal.dto.CourseScheduleDto;
 import com.ym.mec.biz.dal.dto.TeacherAttendanceDto;
 import com.ym.mec.biz.dal.entity.CourseSchedule;
 import com.ym.mec.biz.dal.entity.CourseScheduleComplaints;
+import com.ym.mec.biz.dal.page.CourseScheduleQueryInfo;
 import com.ym.mec.biz.dal.page.StudentCourseScheduleRecordQueryInfo;
+import com.ym.mec.common.page.PageInfo;
 import com.ym.mec.common.service.BaseService;
 
 import java.util.Date;
@@ -59,6 +61,13 @@ public interface CourseScheduleService extends BaseService<Long, CourseSchedule>
     /**
      * @Author: Joburgess
      * @Date: 2019/9/17
+     * 根据日期获取当日排课信息
+     */
+    PageInfo getCourseSchedulesWithDateByEdu(CourseScheduleQueryInfo queryInfo);
+
+    /**
+     * @Author: Joburgess
+     * @Date: 2019/9/17
      * 根据月份获取乐团在该月有课的日期
      */
     List<Date> getCourseScheduleDateByMonth(Long musicGroupID, Date month);
@@ -79,6 +88,15 @@ public interface CourseScheduleService extends BaseService<Long, CourseSchedule>
 
     /**
      * @Author: Joburgess
+     * @Date: 2019/10/11
+     * @params [month]
+     * @return java.util.List<java.util.Date>
+     * @describe 获取
+     */
+    List<Date> getCourseScheduleDates(Date month);
+
+    /**
+     * @Author: Joburgess
      * @Date: 2019/9/23
      * 课时调整
      */

+ 1 - 1
mec-biz/src/main/java/com/ym/mec/biz/service/MusicGroupSubjectGoodsGroupService.java

@@ -13,7 +13,7 @@ public interface MusicGroupSubjectGoodsGroupService extends BaseService<Long, Mu
      * @param subId
      * @return
      */
-    List<MusicGroupSubjectGoodsGroup> findGoodsGroup(Integer musicGroupId, Integer subId);
+    List<MusicGroupSubjectGoodsGroup> findGoodsGroup(String musicGroupId, Integer subId);
 
 
     /**

+ 2 - 2
mec-biz/src/main/java/com/ym/mec/biz/service/MusicGroupSubjectPlanService.java

@@ -24,7 +24,7 @@ public interface MusicGroupSubjectPlanService extends BaseService<Integer, Music
      * @param musicGroupId
      * @return
      */
-    MusicGroupSubjectPlan getMusicOneSubjectClassPlan(int musicGroupId, int subjectId);
+    MusicGroupSubjectPlan getMusicOneSubjectClassPlan(String musicGroupId, int subjectId);
 
     /**
      * 获取乐团声部报名缴费商品信息
@@ -33,7 +33,7 @@ public interface MusicGroupSubjectPlanService extends BaseService<Integer, Music
      * @param subjectId
      * @return
      */
-    MusicGroupSubjectGoodsAndInfoDto getSubjectGoodsAndInfo(Integer musicGroupId, Integer subjectId);
+    MusicGroupSubjectGoodsAndInfoDto getSubjectGoodsAndInfo(String musicGroupId, Integer subjectId);
 
     /**
      * 乐团报名基本信息

+ 76 - 70
mec-biz/src/main/java/com/ym/mec/biz/service/StudentRegistrationService.java

@@ -16,83 +16,89 @@ import com.ym.mec.common.service.BaseService;
 
 public interface StudentRegistrationService extends BaseService<Long, StudentRegistration> {
 
-    /**
-     * 获取乐团学员报名详情
-     *
-     * @param queryInfo
-     * @return
-     */
-    PageInfo<StudentApplyDetailDto> queryStudentDetailPage(StudentRegistrationQueryInfo queryInfo);
+	/**
+	 * 获取乐团学员报名详情
+	 *
+	 * @param queryInfo
+	 * @return
+	 */
+	PageInfo<StudentApplyDetailDto> queryStudentDetailPage(StudentRegistrationQueryInfo queryInfo);
 
-    /**
-     * 批量调剂
-     *
-     * @param userId
-     * @param subId
-     * @return
-     */
-    boolean batchUpdateSubject(String userId, Integer subId);
+	/**
+	 * 批量调剂
+	 *
+	 * @param userId
+	 * @param subId
+	 * @return
+	 */
+	boolean batchUpdateSubject(String userId, Integer subId);
 
-    /**
-     * 学生报名缴费金额详情
-     *
-     * @param studentId
-     * @param musicGroupId
-     * @return
-     */
-    StudentFeeDto queryFeeDetail(Integer studentId, String musicGroupId);
+	/**
+	 * 学生报名缴费金额详情
+	 *
+	 * @param studentId
+	 * @param musicGroupId
+	 * @return
+	 */
+	StudentFeeDto queryFeeDetail(Integer studentId, String musicGroupId);
 
-    /**
-     * 获取未分配的班级的学生
-     *
-     * @param musicGroupId    乐团id
-     * @param actualSubjectId 科目id
-     * @return
-     */
-    List<StudentRegistration> getNoClassStuBySubjectId(Integer musicGroupId, Integer actualSubjectId);
+	/**
+	 * 获取未分配的班级的学生
+	 *
+	 * @param musicGroupId    乐团id
+	 * @param actualSubjectId 科目id
+	 * @return
+	 */
+	List<StudentRegistration> getNoClassStuBySubjectId(Integer musicGroupId, Integer actualSubjectId);
 
-    /**
-     * 获取乐团声部未分配学生统计
-     *
-     * @param musicGroupId
-     * @param actualSubjectId
-     * @return
-     */
-    Integer getNoClassStuCountBySubjectId(Integer musicGroupId, Integer actualSubjectId);
+	/**
+	 * 获取乐团声部未分配学生统计
+	 *
+	 * @param musicGroupId
+	 * @param actualSubjectId
+	 * @return
+	 */
+	Integer getNoClassStuCountBySubjectId(Integer musicGroupId, Integer actualSubjectId);
 
+	/**
+	 * 根据user_id 和 乐团id更新
+	 *
+	 * @param studentRegistration
+	 * @return
+	 */
+	Integer updateByUserIdAndMusicGroupId(StudentRegistration studentRegistration);
 
-    /**
-     * 根据user_id 和 乐团id更新
-     *
-     * @param studentRegistration
-     * @return
-     */
-    Integer updateByUserIdAndMusicGroupId(StudentRegistration studentRegistration);
+	/**
+	 * 添加学生报名信息
+	 * @param studentRegistration
+	 * @return
+	 */
+	StudentRegistration addStudent(StudentRegistration studentRegistration);
 
-    /**
-     * 添加学生报名信息
-     * @param studentRegistration
-     * @return
-     */
-    StudentRegistration addStudent(StudentRegistration studentRegistration);
-    
-    /**
-     * 查询学生信息
-     * @param userId
-     * @return
-     */
-    StudentInfo queryStudentInfo(Integer userId);
+	/**
+	 * 查询学生信息
+	 * @param userId
+	 * @return
+	 */
+	StudentInfo queryStudentInfo(Integer userId);
 
+	/**
+	 * 学生注册缴费订单
+	 * @param userId
+	 * @param amount
+	 * @param courseFee
+	 * @param goodsGroups
+	 * @param goodsList
+	 * @return
+	 */
+	StudentPaymentOrder addOrder(Integer userId, BigDecimal amount, String orderNo, String paymentChannel, BigDecimal courseFee,
+			List<MusicGroupSubjectGoodsGroup> goodsGroups, List<Goods> goodsList, List<Goods> otherGoodsList, String musicGroupId);
 
-    /**
-     * 学生注册缴费订单
-     * @param userId
-     * @param amount
-     * @param courseFee
-     * @param goodsGroups
-     * @param goodsList
-     * @return
-     */
-    StudentPaymentOrder addOrder(Integer userId,BigDecimal amount,String orderNo,String paymentChannel,BigDecimal courseFee, List<MusicGroupSubjectGoodsGroup> goodsGroups, List<Goods> goodsList, List<Goods> otherGoodsList,String musicGroupId);
-
+	/**
+	 * 查询用户指定乐团的报名信息
+	 * @param userId 用户编号
+	 * @param musicGroupId 乐团编号
+	 * @return
+	 */
+	StudentRegistration queryByUserIdAndMusicGroupId(Integer userId, String musicGroupId);
 }

+ 22 - 5
mec-biz/src/main/java/com/ym/mec/biz/service/VipGroupService.java

@@ -3,14 +3,13 @@ package com.ym.mec.biz.service;
 import com.ym.mec.biz.dal.dto.*;
 import com.ym.mec.biz.dal.entity.StudentApplyRefunds;
 import com.ym.mec.biz.dal.entity.VipGroup;
-import com.ym.mec.biz.dal.page.StudentVipGroupQueryInfo;
-import com.ym.mec.biz.dal.page.VipGroupAttendanceQueryInfo;
-import com.ym.mec.biz.dal.page.VipGroupQueryInfo;
-import com.ym.mec.biz.dal.page.VipGroupTeachingRecordQueryInfo;
+import com.ym.mec.biz.dal.page.*;
 import com.ym.mec.common.page.PageInfo;
 import com.ym.mec.common.service.BaseService;
 
 import java.math.BigDecimal;
+import java.util.List;
+import java.util.Map;
 
 public interface VipGroupService extends BaseService<Long, VipGroup> {
 
@@ -48,7 +47,7 @@ public interface VipGroupService extends BaseService<Long, VipGroup> {
      * @return com.ym.mec.common.page.PageInfo
      * @describe 获取vip课教学记录
      */
-    PageInfo findVipGroupTeachingRecord(VipGroupTeachingRecordQueryInfo queryInfo);
+    Map<String, Object> findVipGroupTeachingRecord(VipGroupTeachingRecordQueryInfo queryInfo);
 
     /**
      * @Author: Joburgess
@@ -149,4 +148,22 @@ public interface VipGroupService extends BaseService<Long, VipGroup> {
      */
     void applyRefundAudit(StudentApplyRefunds studentApplyRefunds);
 
+    /**
+     * @Author: Joburgess
+     * @Date: 2019/10/11
+     * @params [queryInfo]
+     * @return com.ym.mec.common.page.PageInfo
+     * @describe vip财务记录
+     */
+    Map<String, Object> findVipGroupSalarys(VipGroupSalaryQueryInfo queryInfo);
+
+    /**
+     * @Author: Joburgess
+     * @Date: 2019/10/11
+     * @params [courseScheduleId]
+     * @return java.util.List<java.lang.String>
+     * @describe 获取上课签到学员
+     */
+    List<String> findVipGroupAttendanceStudents(Long courseScheduleId);
+
 }

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

@@ -131,7 +131,7 @@ public class ClassGroupServiceImpl extends BaseServiceImpl<Integer, ClassGroup>
 
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public ClassGroup addMixClassGroup(int musicGroupId, String name, String classGroupIds) throws Exception {
+    public ClassGroup addMixClassGroup(String musicGroupId, String name, String classGroupIds) throws Exception {
         Date date;
         date = new Date();
 

+ 262 - 38
mec-biz/src/main/java/com/ym/mec/biz/service/impl/ContractServiceImpl.java

@@ -8,6 +8,7 @@ import java.util.Date;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
+import java.util.stream.Collectors;
 
 import org.apache.commons.io.FileUtils;
 import org.apache.commons.lang.StringUtils;
@@ -17,23 +18,31 @@ import org.springframework.stereotype.Service;
 
 import com.ym.mec.auth.api.client.SysUserFeignService;
 import com.ym.mec.auth.api.entity.SysUser;
+import com.ym.mec.biz.dal.dao.MusicGroupPaymentCalenderDao;
 import com.ym.mec.biz.dal.dto.StudentInfo;
 import com.ym.mec.biz.dal.entity.Goods;
+import com.ym.mec.biz.dal.entity.MusicGroupPaymentCalender;
+import com.ym.mec.biz.dal.entity.MusicGroupSubjectPlan;
+import com.ym.mec.biz.dal.entity.StudentRegistration;
 import com.ym.mec.biz.dal.entity.Subject;
 import com.ym.mec.biz.dal.entity.SysUserContracts;
 import com.ym.mec.biz.dal.entity.SysUserContracts.ContractType;
 import com.ym.mec.biz.dal.entity.SysUserTsign;
+import com.ym.mec.biz.dal.entity.VipGroup;
 import com.ym.mec.biz.dal.enums.OrderDetailTypeEnum;
 import com.ym.mec.biz.service.ContractService;
+import com.ym.mec.biz.service.MusicGroupSubjectPlanService;
 import com.ym.mec.biz.service.StudentPaymentOrderService;
 import com.ym.mec.biz.service.StudentRegistrationService;
 import com.ym.mec.biz.service.SubjectService;
 import com.ym.mec.biz.service.SysUserContractsService;
 import com.ym.mec.biz.service.SysUserTsignService;
+import com.ym.mec.biz.service.VipGroupService;
 import com.ym.mec.common.exception.BizException;
 import com.ym.mec.thirdparty.eseal.ESealPlugin;
 import com.ym.mec.thirdparty.storage.StoragePlugin;
 import com.ym.mec.util.freemarker.FreemarkerTemplateEngine;
+import com.ym.mec.util.money.MoneyUtil;
 import com.ym.mec.util.pdf.PDFUtil;
 
 @Service
@@ -47,13 +56,22 @@ public class ContractServiceImpl implements ContractService {
 
 	@Autowired
 	private SysUserContractsService sysUserContractsService;
-	
+
 	@Autowired
 	private StudentRegistrationService studentRegistrationService;
-	
+
 	@Autowired
 	private StudentPaymentOrderService studentPaymentOrderService;
-	
+
+	@Autowired
+	private MusicGroupSubjectPlanService musicGroupSubjectPlanService;
+
+	@Autowired
+	private MusicGroupPaymentCalenderDao musicGroupPaymentCalenderDao;
+
+	@Autowired
+	private VipGroupService vipGroupService;
+
 	@Autowired
 	private SubjectService subjectService;
 
@@ -110,7 +128,10 @@ public class ContractServiceImpl implements ContractService {
 
 		// 合成freemarker
 		String srcPdfPath = contractBaseDir + "/register/" + userId + ".pdf";
-		File debtFile = new File(contractBaseDir);
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
 		if (!debtFile.exists()) {
 			debtFile.mkdirs();
 		}
@@ -120,11 +141,11 @@ public class ContractServiceImpl implements ContractService {
 
 		Map<String, Object> params = new HashMap<String, Object>();
 
-		templateEngine.render(params, "register.ftl", new File(srcPdfPath));
+		templateEngine.render(params, "register.ftl", srcFile);
 
 		// 生成借款协议PDF
 		try {
-			PDFUtil.renderToPDFByData(ContractServiceImpl.class.getResource("/").getFile(), FileUtils.readFileToString(new File(srcPdfPath)), srcPdfPath,
+			PDFUtil.renderToPDFByData(ContractServiceImpl.class.getResource("/").getFile(), FileUtils.readFileToString(srcFile), srcPdfPath,
 					"config/fonts/simsun.ttc");
 		} catch (IOException e) {
 			throw new BizException("生成pdf协议失败", e);
@@ -135,7 +156,7 @@ public class ContractServiceImpl implements ContractService {
 		Date date = new Date();
 		// 上传到oss
 		String dateStrOss = dateFormatOss.format(date);
-		String pdfFilePath = storagePlugin.uploadFile(dateStrOss, new File(srcPdfPath));
+		String pdfFilePath = storagePlugin.uploadFile(dateStrOss, srcFile);
 
 		SysUserContracts sysUserContracts = new SysUserContracts();
 		sysUserContracts.setCreateTime(date);
@@ -145,7 +166,7 @@ public class ContractServiceImpl implements ContractService {
 
 		sysUserContractsService.insert(sysUserContracts);
 
-		FileUtils.deleteQuietly(new File(srcPdfPath));
+		FileUtils.deleteQuietly(srcFile);
 
 		return true;
 	}
@@ -155,7 +176,10 @@ public class ContractServiceImpl implements ContractService {
 
 		// 合成freemarker
 		String srcPdfPath = contractBaseDir + "/register/" + userId + ".pdf";
-		File debtFile = new File(contractBaseDir);
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
 		if (!debtFile.exists()) {
 			debtFile.mkdirs();
 		}
@@ -165,15 +189,15 @@ public class ContractServiceImpl implements ContractService {
 
 		Map<String, Object> params = new HashMap<String, Object>();
 
-		templateEngine.render(params, "register.ftl", new File(srcPdfPath));
+		templateEngine.render(params, "register.ftl", srcFile);
 
 		String result = "";
 		try {
-			result = FileUtils.readFileToString(new File(srcPdfPath));
+			result = FileUtils.readFileToString(srcFile);
 		} catch (IOException e) {
 			throw new BizException("读取注册协议出错", e);
 		}
-		FileUtils.deleteQuietly(new File(srcPdfPath));
+		FileUtils.deleteQuietly(srcFile);
 
 		return result;
 	}
@@ -188,7 +212,10 @@ public class ContractServiceImpl implements ContractService {
 
 		// 合成freemarker
 		String srcPdfPath = contractBaseDir + "/courses/" + userId + ".pdf";
-		File debtFile = new File(contractBaseDir);
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
 		if (!debtFile.exists()) {
 			debtFile.mkdirs();
 		}
@@ -197,16 +224,40 @@ public class ContractServiceImpl implements ContractService {
 		templateEngine.setClassForTemplateLoading(ContractServiceImpl.class, "/config/contracts/");
 
 		Map<String, Object> params = new HashMap<String, Object>();
-		
-		//查询参数信息
+
+		// 查询参数信息
 		StudentInfo studentInfo = studentRegistrationService.queryStudentInfo(userId);
 		params.put("studentInfo", studentInfo);
 
-		templateEngine.render(params, "courses.ftl", new File(srcPdfPath));
+		// 课程类型
+		params.put("classesType", "乐团团课");
+
+		// 课程费用
+		StudentRegistration studentRegistration = studentRegistrationService.queryByUserIdAndMusicGroupId(userId, musicGroupId);
+		if (studentRegistration == null) {
+			throw new BizException("用户 报名信息不存在");
+		}
+		MusicGroupSubjectPlan musicGroupSubjectPlan = musicGroupSubjectPlanService.getMusicOneSubjectClassPlan(musicGroupId,
+				studentRegistration.getActualSubjectId());
+		if (musicGroupSubjectPlan == null) {
+			throw new BizException("声部课程费用设置找不到");
+		}
+		params.put("courseFee", musicGroupSubjectPlan.getFee().doubleValue());
+
+		// 收费形式
+		List<MusicGroupPaymentCalender> calenders = musicGroupPaymentCalenderDao.findByMusicGroupId(musicGroupId);
+
+		if (calenders == null || calenders.size() == 0) {
+			params.put("paymentcalender", "一次性");
+		} else {
+			params.put("paymentcalender", calenders.stream().map(cal -> cal.getPaymentMonth().toString()).collect(Collectors.joining(",")));
+		}
+
+		templateEngine.render(params, "courses.ftl", srcFile);
 
 		// 生成借款协议PDF
 		try {
-			PDFUtil.renderToPDFByData(ContractServiceImpl.class.getResource("/").getFile(), FileUtils.readFileToString(new File(srcPdfPath)), srcPdfPath,
+			PDFUtil.renderToPDFByData(ContractServiceImpl.class.getResource("/").getFile(), FileUtils.readFileToString(srcFile), srcPdfPath,
 					"config/fonts/simsun.ttc");
 		} catch (IOException e) {
 			throw new BizException("生成pdf协议失败", e);
@@ -217,7 +268,7 @@ public class ContractServiceImpl implements ContractService {
 		Date date = new Date();
 		// 上传到oss
 		String dateStrOss = dateFormatOss.format(date);
-		String pdfFilePath = storagePlugin.uploadFile(dateStrOss, new File(srcPdfPath));
+		String pdfFilePath = storagePlugin.uploadFile(dateStrOss, srcFile);
 
 		SysUserContracts sysUserContracts = new SysUserContracts();
 		sysUserContracts.setCreateTime(date);
@@ -227,7 +278,7 @@ public class ContractServiceImpl implements ContractService {
 
 		sysUserContractsService.insert(sysUserContracts);
 
-		FileUtils.deleteQuietly(new File(srcPdfPath));
+		FileUtils.deleteQuietly(srcFile);
 
 		return true;
 	}
@@ -237,7 +288,10 @@ public class ContractServiceImpl implements ContractService {
 
 		// 合成freemarker
 		String srcPdfPath = contractBaseDir + "/courses/" + userId + ".pdf";
-		File debtFile = new File(contractBaseDir);
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
 		if (!debtFile.exists()) {
 			debtFile.mkdirs();
 		}
@@ -246,15 +300,39 @@ public class ContractServiceImpl implements ContractService {
 		templateEngine.setClassForTemplateLoading(ContractServiceImpl.class, "/config/contracts/");
 
 		Map<String, Object> params = new HashMap<String, Object>();
-		
+
 		StudentInfo studentInfo = studentRegistrationService.queryStudentInfo(userId);
 		params.put("studentInfo", studentInfo);
 
-		templateEngine.render(params, "courses.ftl", new File(srcPdfPath));
+		// 课程类型
+		params.put("classesType", "乐团团课");
+
+		// 课程费用
+		StudentRegistration studentRegistration = studentRegistrationService.queryByUserIdAndMusicGroupId(userId, musicGroupId);
+		if (studentRegistration == null) {
+			throw new BizException("用户 报名信息不存在");
+		}
+		MusicGroupSubjectPlan musicGroupSubjectPlan = musicGroupSubjectPlanService.getMusicOneSubjectClassPlan(musicGroupId,
+				studentRegistration.getActualSubjectId());
+		if (musicGroupSubjectPlan == null) {
+			throw new BizException("声部课程费用设置找不到");
+		}
+		params.put("courseFee", musicGroupSubjectPlan.getFee().doubleValue());
+
+		// 收费形式
+		List<MusicGroupPaymentCalender> calenders = musicGroupPaymentCalenderDao.findByMusicGroupId(musicGroupId);
+
+		if (calenders == null || calenders.size() == 0) {
+			params.put("paymentcalender", "一次性");
+		} else {
+			params.put("paymentcalender", calenders.stream().map(cal -> cal.getPaymentMonth().toString()).collect(Collectors.joining(",")));
+		}
+
+		templateEngine.render(params, "courses.ftl", srcFile);
 
 		String result = "";
 		try {
-			result = FileUtils.readFileToString(new File(srcPdfPath));
+			result = FileUtils.readFileToString(srcFile);
 		} catch (IOException e) {
 			throw new BizException("读取课程协议出错", e);
 		}
@@ -264,6 +342,123 @@ public class ContractServiceImpl implements ContractService {
 	}
 
 	@Override
+	public boolean transferVipGroupCoursesContract(Integer userId, Long vipGroupId) {
+		SysUserTsign sysUserTsign = sysUserTsignService.get(userId);
+
+		if (sysUserTsign == null) {
+			return false;
+		}
+
+		// 合成freemarker
+		String srcPdfPath = contractBaseDir + "/courses/" + userId + ".pdf";
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
+		if (!debtFile.exists()) {
+			debtFile.mkdirs();
+		}
+
+		FreemarkerTemplateEngine templateEngine = FreemarkerTemplateEngine.getInstance();
+		templateEngine.setClassForTemplateLoading(ContractServiceImpl.class, "/config/contracts/");
+
+		Map<String, Object> params = new HashMap<String, Object>();
+
+		// 查询参数信息
+		StudentInfo studentInfo = studentRegistrationService.queryStudentInfo(userId);
+		params.put("studentInfo", studentInfo);
+
+		// 课程类型
+		params.put("classesType", "VIP课");
+
+		// 课程费用
+		VipGroup vipGroup = vipGroupService.get(vipGroupId);
+		if (vipGroup == null) {
+			throw new BizException("VIP课找不到");
+		}
+		params.put("courseFee", vipGroup.getTotalPrice().doubleValue());
+
+		// 收费形式
+		params.put("paymentcalender", "一次性");
+
+		templateEngine.render(params, "courses.ftl", srcFile);
+
+		// 生成借款协议PDF
+		try {
+			PDFUtil.renderToPDFByData(ContractServiceImpl.class.getResource("/").getFile(), FileUtils.readFileToString(srcFile), srcPdfPath,
+					"config/fonts/simsun.ttc");
+		} catch (IOException e) {
+			throw new BizException("生成pdf协议失败", e);
+		}
+
+		eSealPlugin.userSign(sysUserTsign.getAccountId(), sysUserTsign.getSealData(), srcPdfPath, srcPdfPath);
+
+		Date date = new Date();
+		// 上传到oss
+		String dateStrOss = dateFormatOss.format(date);
+		String pdfFilePath = storagePlugin.uploadFile(dateStrOss, srcFile);
+
+		SysUserContracts sysUserContracts = new SysUserContracts();
+		sysUserContracts.setCreateTime(date);
+		sysUserContracts.setType(ContractType.REGISTER);
+		sysUserContracts.setUrl(pdfFilePath);
+		sysUserContracts.setUserId(userId);
+
+		sysUserContractsService.insert(sysUserContracts);
+
+		FileUtils.deleteQuietly(srcFile);
+
+		return true;
+	}
+
+	@Override
+	public String queryVipGroupCoursesContract(Integer userId, Long vipGroupId) {
+
+		// 合成freemarker
+		String srcPdfPath = contractBaseDir + "/courses/" + userId + ".pdf";
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
+		if (!debtFile.exists()) {
+			debtFile.mkdirs();
+		}
+
+		FreemarkerTemplateEngine templateEngine = FreemarkerTemplateEngine.getInstance();
+		templateEngine.setClassForTemplateLoading(ContractServiceImpl.class, "/config/contracts/");
+
+		Map<String, Object> params = new HashMap<String, Object>();
+
+		StudentInfo studentInfo = studentRegistrationService.queryStudentInfo(userId);
+		params.put("studentInfo", studentInfo);
+
+		// 课程类型
+		params.put("classesType", "VIP课");
+
+		// 课程费用
+		VipGroup vipGroup = vipGroupService.get(vipGroupId);
+		if (vipGroup == null) {
+			throw new BizException("VIP课找不到");
+		}
+		params.put("courseFee", vipGroup.getTotalPrice().doubleValue());
+
+		// 收费形式
+		params.put("paymentcalender", "一次性");
+
+		templateEngine.render(params, "courses.ftl", srcFile);
+
+		String result = "";
+		try {
+			result = FileUtils.readFileToString(srcFile);
+		} catch (IOException e) {
+			throw new BizException("读取课程协议出错", e);
+		}
+		FileUtils.deleteQuietly(srcFile);
+
+		return result;
+	}
+
+	@Override
 	public boolean transferGoodsContract(Integer userId, String musicGroupId) {
 		SysUserTsign sysUserTsign = sysUserTsignService.get(userId);
 
@@ -273,7 +468,10 @@ public class ContractServiceImpl implements ContractService {
 
 		// 合成freemarker
 		String srcPdfPath = contractBaseDir + "/goods/" + userId + ".pdf";
-		File debtFile = new File(contractBaseDir);
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
 		if (!debtFile.exists()) {
 			debtFile.mkdirs();
 		}
@@ -282,23 +480,32 @@ public class ContractServiceImpl implements ContractService {
 		templateEngine.setClassForTemplateLoading(ContractServiceImpl.class, "/config/contracts/");
 
 		Map<String, Object> params = new HashMap<String, Object>();
-		
-		//查询参数信息
+
+		// 查询参数信息
 		StudentInfo studentInfo = studentRegistrationService.queryStudentInfo(userId);
 		
-		Subject subject = subjectService.get(studentInfo.getSubject().getId());
+		int subjectId = studentInfo.getSubject().getId();
+
+		Subject subject = subjectService.get(subjectId);
 		studentInfo.setSubject(subject);
-		
+
 		params.put("studentInfo", studentInfo);
-		
+
 		List<Goods> goodsList = studentPaymentOrderService.queryApplyGoodsList(musicGroupId, OrderDetailTypeEnum.MUSICAL);
 		params.put("goodsList", goodsList);
+		
+		MusicGroupSubjectPlan musicGroupSubjectPlan =musicGroupSubjectPlanService.getMusicOneSubjectClassPlan(musicGroupId, subjectId);
+		if (musicGroupSubjectPlan == null) {
+			throw new BizException("声部课程费用设置找不到");
+		}
+		params.put("depositFee", musicGroupSubjectPlan.getDepositFee().doubleValue());
+		params.put("depositFeeFmt", MoneyUtil.toChinese(musicGroupSubjectPlan.getDepositFee().toString()));
 
-		templateEngine.render(params, "goods.ftl", new File(srcPdfPath));
+		templateEngine.render(params, "goods.ftl", srcFile);
 
 		// 生成借款协议PDF
 		try {
-			PDFUtil.renderToPDFByData(ContractServiceImpl.class.getResource("/").getFile(), FileUtils.readFileToString(new File(srcPdfPath)), srcPdfPath,
+			PDFUtil.renderToPDFByData(ContractServiceImpl.class.getResource("/").getFile(), FileUtils.readFileToString(srcFile), srcPdfPath,
 					"config/fonts/simsun.ttc");
 		} catch (IOException e) {
 			throw new BizException("生成pdf协议失败", e);
@@ -309,7 +516,7 @@ public class ContractServiceImpl implements ContractService {
 		Date date = new Date();
 		// 上传到oss
 		String dateStrOss = dateFormatOss.format(date);
-		String pdfFilePath = storagePlugin.uploadFile(dateStrOss, new File(srcPdfPath));
+		String pdfFilePath = storagePlugin.uploadFile(dateStrOss, srcFile);
 
 		SysUserContracts sysUserContracts = new SysUserContracts();
 		sysUserContracts.setCreateTime(date);
@@ -319,7 +526,7 @@ public class ContractServiceImpl implements ContractService {
 
 		sysUserContractsService.insert(sysUserContracts);
 
-		FileUtils.deleteQuietly(new File(srcPdfPath));
+		FileUtils.deleteQuietly(srcFile);
 
 		return true;
 	}
@@ -329,7 +536,10 @@ public class ContractServiceImpl implements ContractService {
 
 		// 合成freemarker
 		String srcPdfPath = contractBaseDir + "/goods/" + userId + ".pdf";
-		File debtFile = new File(contractBaseDir);
+
+		File srcFile = new File(srcPdfPath);
+
+		File debtFile = new File(srcFile.getParent());
 		if (!debtFile.exists()) {
 			debtFile.mkdirs();
 		}
@@ -339,21 +549,35 @@ public class ContractServiceImpl implements ContractService {
 
 		Map<String, Object> params = new HashMap<String, Object>();
 
+		// 查询参数信息
 		StudentInfo studentInfo = studentRegistrationService.queryStudentInfo(userId);
-		params.put("studentInfo", studentInfo);
 		
+		int subjectId = studentInfo.getSubject().getId();
+
+		Subject subject = subjectService.get(subjectId);
+		studentInfo.setSubject(subject);
+
+		params.put("studentInfo", studentInfo);
+
 		List<Goods> goodsList = studentPaymentOrderService.queryApplyGoodsList(musicGroupId, OrderDetailTypeEnum.MUSICAL);
 		params.put("goodsList", goodsList);
+		
+		MusicGroupSubjectPlan musicGroupSubjectPlan =musicGroupSubjectPlanService.getMusicOneSubjectClassPlan(musicGroupId, subjectId);
+		if (musicGroupSubjectPlan == null) {
+			throw new BizException("声部课程费用设置找不到");
+		}
+		params.put("depositFee", musicGroupSubjectPlan.getDepositFee().doubleValue());
+		params.put("depositFeeFmt", MoneyUtil.toChinese(musicGroupSubjectPlan.getDepositFee().toString()));
 
-		templateEngine.render(params, "goods.ftl", new File(srcPdfPath));
+		templateEngine.render(params, "goods.ftl", srcFile);
 
 		String result = "";
 		try {
-			result = FileUtils.readFileToString(new File(srcPdfPath));
+			result = FileUtils.readFileToString(srcFile);
 		} catch (IOException e) {
 			throw new BizException("读取商品协议出错", e);
 		}
-		FileUtils.deleteQuietly(new File(srcPdfPath));
+		FileUtils.deleteQuietly(srcFile);
 
 		return result;
 	}

+ 49 - 0
mec-biz/src/main/java/com/ym/mec/biz/service/impl/CourseScheduleServiceImpl.java

@@ -15,6 +15,7 @@ import com.ym.mec.biz.dal.entity.SysConfig;
 import com.ym.mec.biz.dal.enums.AuditStatusEnum;
 import com.ym.mec.biz.dal.enums.ParamEnum;
 import com.ym.mec.biz.dal.enums.YesOrNoEnum;
+import com.ym.mec.biz.dal.page.CourseScheduleQueryInfo;
 import com.ym.mec.biz.dal.page.StudentCourseScheduleRecordQueryInfo;
 import com.ym.mec.biz.service.CourseScheduleService;
 import com.ym.mec.common.dal.BaseDAO;
@@ -120,12 +121,24 @@ public class CourseScheduleServiceImpl extends BaseServiceImpl<Long, CourseSched
 	}
 
 	@Override
+	public List<Date> getCourseScheduleDates(Date month) {
+		SysUser user = sysUserFeignService.queryUserInfo();
+		if(null==user){
+			throw new BizException("请登录");
+		}
+		return courseScheduleDao.getCourseScheduleDate(month,user.getOrganId().longValue());
+	}
+
+	@Override
 	public Map getStudentCourseSchedulesWithDate(Date classDate) {
 		if(Objects.isNull(classDate)){
 			throw new BizException("请选择上课日期!");
 		}
 
 		SysUser user = sysUserFeignService.queryUserInfo();
+		if(null==user){
+			throw new BizException("请登录");
+		}
 		SysConfig vip_appeal_days_range = sysConfigDao.findByParamName("vip_appeal_days_range");
 		Map<String,Object> result=new HashMap<>();
 		result.put("vipAppealDaysRange",vip_appeal_days_range.getParanValue());
@@ -134,8 +147,44 @@ public class CourseScheduleServiceImpl extends BaseServiceImpl<Long, CourseSched
 	}
 
 	@Override
+	public PageInfo getCourseSchedulesWithDateByEdu(CourseScheduleQueryInfo queryInfo) {
+		SysUser user = sysUserFeignService.queryUserInfo();
+		if(null==user){
+			throw new BizException("请登录");
+		}
+		queryInfo.setOrganId(user.getOrganId().longValue());
+		PageInfo pageInfo = new PageInfo<>(queryInfo.getPage(), queryInfo.getRows());
+
+		if(Objects.isNull(queryInfo.getDate())){
+			queryInfo.setDate(new Date());
+		}
+
+		Map<String, Object> params = new HashMap<String, Object>();
+		MapUtil.populateMap(params, queryInfo);
+
+		List dataList = null;
+		int count = courseScheduleDao.countCourseSchedulesWithDate(params);
+		if (count > 0) {
+			pageInfo.setTotal(count);
+			params.put("offset", pageInfo.getOffset());
+			dataList = courseScheduleDao.getCourseSchedulesWithDate(params);
+		}
+		if (count == 0) {
+			dataList = new ArrayList<>();
+		}
+		pageInfo.setRows(dataList);
+		return pageInfo;
+	}
+
+	@Override
 	public List<CourseScheduleDto> getTeacherCourseSchedulesWithDate(Date classDate) {
+		if(Objects.isNull(classDate)){
+			throw new BizException("请选择上课日期!");
+		}
 		SysUser user = sysUserFeignService.queryUserInfo();
+		if(null==user){
+			throw new BizException("请登录");
+		}
 		return courseScheduleDao.getTeacherCourseSchedulesWithDate(classDate,user.getId().longValue());
 	}
 

+ 5 - 0
mec-biz/src/main/java/com/ym/mec/biz/service/impl/DemoGroupServiceImpl.java

@@ -109,6 +109,11 @@ public class DemoGroupServiceImpl extends BaseServiceImpl<Long, DemoGroup>  impl
 	public void createCourseScheduleAndUpdateOrganId(Long demoGroupId,Long coursePlanId){
 		DemoGroup demoGroup=demoGroupDao.get(demoGroupId);
 
+		DemoGroupCoursesPlan demoGroupCoursesPlan1 = demoGroupCoursesPlanDao.get(coursePlanId);
+		if(demoGroupCoursesPlan1.getStatus()==YesOrNoEnum.YES){
+			throw new BizException("该时段课程已被预约");
+		}
+
 		SysUser user = sysUserFeignService.queryUserInfo();
 
 		//创建班级

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

@@ -23,7 +23,7 @@ public class MusicGroupSubjectGoodsGroupServiceImpl extends BaseServiceImpl<Long
 	}
 
 	@Override
-    public List<MusicGroupSubjectGoodsGroup> findGoodsGroup(Integer musicGroupId, Integer subId) {
+    public List<MusicGroupSubjectGoodsGroup> findGoodsGroup(String musicGroupId, Integer subId) {
         return musicGroupSubjectGoodsGroupDao.findGoodsGroup(musicGroupId, subId);
     }
 

+ 2 - 2
mec-biz/src/main/java/com/ym/mec/biz/service/impl/MusicGroupSubjectPlanServiceImpl.java

@@ -53,12 +53,12 @@ public class MusicGroupSubjectPlanServiceImpl extends BaseServiceImpl<Integer, M
     }
 
     @Override
-    public MusicGroupSubjectPlan getMusicOneSubjectClassPlan(int musicGroupId, int subjectId) {
+    public MusicGroupSubjectPlan getMusicOneSubjectClassPlan(String musicGroupId, int subjectId) {
         return musicGroupSubjectPlanDao.getMusicOneSubjectClassPlan(musicGroupId, subjectId);
     }
 
     @Override
-    public MusicGroupSubjectGoodsAndInfoDto getSubjectGoodsAndInfo(Integer musicGroupId, Integer subjectId) {
+    public MusicGroupSubjectGoodsAndInfoDto getSubjectGoodsAndInfo(String musicGroupId, Integer subjectId) {
         MusicGroup musicGroup = musicGroupService.get(musicGroupId.toString());
 
         //课程形态

+ 17 - 7
mec-biz/src/main/java/com/ym/mec/biz/service/impl/StudentRegistrationServiceImpl.java

@@ -9,13 +9,6 @@ import java.util.Map;
 
 import javax.annotation.Resource;
 
-import com.ym.mec.biz.dal.dto.VipGroupBuyParamsDto;
-import com.ym.mec.biz.dal.entity.*;
-import com.ym.mec.biz.dal.enums.*;
-import com.ym.mec.biz.service.StudentPaymentOrderDetailService;
-import com.ym.mec.biz.service.StudentPaymentOrderService;
-import com.ym.mec.common.exception.BizException;
-import org.apache.commons.lang.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -28,7 +21,19 @@ import com.ym.mec.biz.dal.dao.StudentRegistrationDao;
 import com.ym.mec.biz.dal.dto.StudentApplyDetailDto;
 import com.ym.mec.biz.dal.dto.StudentFeeDto;
 import com.ym.mec.biz.dal.dto.StudentInfo;
+import com.ym.mec.biz.dal.entity.Goods;
+import com.ym.mec.biz.dal.entity.MusicGroupSubjectGoodsGroup;
+import com.ym.mec.biz.dal.entity.StudentPaymentOrder;
+import com.ym.mec.biz.dal.entity.StudentPaymentOrderDetail;
+import com.ym.mec.biz.dal.entity.StudentRegistration;
+import com.ym.mec.biz.dal.enums.DealStatusEnum;
+import com.ym.mec.biz.dal.enums.GoodsType;
+import com.ym.mec.biz.dal.enums.OrderDetailTypeEnum;
+import com.ym.mec.biz.dal.enums.OrderTypeEnum;
+import com.ym.mec.biz.dal.enums.YesOrNoEnum;
 import com.ym.mec.biz.dal.page.StudentRegistrationQueryInfo;
+import com.ym.mec.biz.service.StudentPaymentOrderDetailService;
+import com.ym.mec.biz.service.StudentPaymentOrderService;
 import com.ym.mec.biz.service.StudentRegistrationService;
 import com.ym.mec.common.dal.BaseDAO;
 import com.ym.mec.common.page.PageInfo;
@@ -217,4 +222,9 @@ public class StudentRegistrationServiceImpl extends BaseServiceImpl<Long, Studen
         return studentPaymentOrder;
     }
 
+	@Override
+	public StudentRegistration queryByUserIdAndMusicGroupId(Integer userId, String musicGroupId) {
+		return studentRegistrationDao.queryByUserIdAndMusicGroupId(userId, musicGroupId);
+	}
+
 }

+ 88 - 12
mec-biz/src/main/java/com/ym/mec/biz/service/impl/VipGroupServiceImpl.java

@@ -7,10 +7,7 @@ import com.ym.mec.biz.dal.dao.*;
 import com.ym.mec.biz.dal.dto.*;
 import com.ym.mec.biz.dal.entity.*;
 import com.ym.mec.biz.dal.enums.*;
-import com.ym.mec.biz.dal.page.StudentVipGroupQueryInfo;
-import com.ym.mec.biz.dal.page.VipGroupAttendanceQueryInfo;
-import com.ym.mec.biz.dal.page.VipGroupQueryInfo;
-import com.ym.mec.biz.dal.page.VipGroupTeachingRecordQueryInfo;
+import com.ym.mec.biz.dal.page.*;
 import com.ym.mec.biz.service.CourseScheduleService;
 import com.ym.mec.biz.service.SysUserCashAccountService;
 import com.ym.mec.biz.service.VipGroupService;
@@ -22,7 +19,6 @@ import com.ym.mec.common.page.PageInfo;
 import com.ym.mec.common.service.impl.BaseServiceImpl;
 import com.ym.mec.im.ImFeignService;
 import com.ym.mec.util.collection.MapUtil;
-
 import org.apache.commons.lang.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -46,6 +42,8 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
 	@Autowired
 	private CourseScheduleService courseScheduleService;
 	@Autowired
+	private CourseScheduleDao courseScheduleDao;
+	@Autowired
 	private VipGroupDefaultClassesUnitPriceDao vipGroupDefaultClassesUnitPriceDao;
 	@Autowired
 	private VipGroupActivityDao vipGroupActivityDao;
@@ -75,6 +73,8 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
 	private CourseScheduleTeacherSalaryDao courseScheduleTeacherSalaryDao;
     @Autowired
 	private ImFeignService imFeignService;
+    @Autowired
+	private SubjectDao subjectDao;
 
 	@Override
 	public BaseDAO<Long, VipGroup> getDAO() {
@@ -104,8 +104,7 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
         //获取活动信息
         VipGroupActivity vipGroupActivity = vipGroupActivityDao.get(vipGroup.getVipGroupApplyBaseInfo().getVipGroupActivityId().intValue());
 		VipGroupSalarySettlementDto vipGroupSalarySettlementDto = JSON.parseObject(vipGroupActivity.getSalarySettlementJson(), VipGroupSalarySettlementDto.class);
-
-
+		
 		//生成vip课信息
 		VipGroupApplyBaseInfoDto vipGroupApplyBaseInfoDto=vipGroup.getVipGroupApplyBaseInfo();
 		vipGroupApplyBaseInfoDto.setTotalPrice(countVipGroupPredictFee(vipGroupApplyBaseInfoDto,
@@ -306,15 +305,17 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
 	@Override
 	public PageInfo findVipGroups(VipGroupQueryInfo queryInfo) {
 		PageInfo pageInfo = new PageInfo<>(queryInfo.getPage(), queryInfo.getRows());
-		Map<String, Object> params = new HashMap<String, Object>();
+		Map<String, Object> params = new HashMap<>();
 		MapUtil.populateMap(params, queryInfo);
 
-		List dataList = null;
+		List<VipGroup> dataList = null;
 		int count = vipGroupDao.countVipGroupByOrgan(params);
 		if (count > 0) {
 			pageInfo.setTotal(count);
 			params.put("offset", pageInfo.getOffset());
 			dataList = vipGroupDao.findAllByOrgan(params);
+			List<Long> vipGroupIds = dataList.stream().map(vipGroup -> vipGroup.getId()).collect(Collectors.toList());
+
 		}
 		if (count == 0) {
 			dataList = new ArrayList<>();
@@ -324,9 +325,12 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
 	}
 
 	@Override
-	public PageInfo findVipGroupTeachingRecord(VipGroupTeachingRecordQueryInfo queryInfo) {
+	public Map<String, Object> findVipGroupTeachingRecord(VipGroupTeachingRecordQueryInfo queryInfo) {
+		if(Objects.isNull(queryInfo.getVipGroupId())){
+			throw new BizException("请指定vip课程!");
+		}
 		PageInfo pageInfo = new PageInfo<>(queryInfo.getPage(), queryInfo.getRows());
-		Map<String, Object> params = new HashMap<String, Object>();
+		Map<String, Object> params = new HashMap<>();
 		MapUtil.populateMap(params, queryInfo);
 
 		List dataList = null;
@@ -340,7 +344,13 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
 			dataList = new ArrayList<>();
 		}
 		pageInfo.setRows(dataList);
-		return pageInfo;
+		TeachingRecordBaseInfo classTimes = vipGroupDao.getClassTimes(queryInfo.getVipGroupId());
+		classTimes.setIsSalaryNum(vipGroupDao.countIsSalaryNum(queryInfo.getVipGroupId()));
+		classTimes.setComplaintsNum(vipGroupDao.countComplaintsNum(queryInfo.getVipGroupId()));
+		Map<String,Object> result=new HashMap<>();
+		result.put("pageInfo",pageInfo);
+		result.put("baseInfo",classTimes);
+		return result;
 	}
 
 	@Override
@@ -373,7 +383,11 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
 
 	@Override
 	public VipGroupManageDetailDto getVipGroupDetail(Long vipGroupId) {
+		if(Objects.isNull(vipGroupId)){
+			throw new BizException("请指定vip课程");
+		}
 		VipGroupManageDetailDto vipGroupBaseInfo = vipGroupDao.getVipGroupBaseInfo(vipGroupId);
+		vipGroupBaseInfo.setSubjectName(StringUtils.join(subjectDao.findBySubIds(vipGroupBaseInfo.getSubjectIdList()),","));
 		return vipGroupBaseInfo;
 	}
 
@@ -600,4 +614,66 @@ public class VipGroupServiceImpl extends BaseServiceImpl<Long, VipGroup> impleme
 				throw new BizException("审核状态错误!");
 		}
 	}
+
+	@Override
+	public Map<String, Object> findVipGroupSalarys(VipGroupSalaryQueryInfo queryInfo) {
+
+    	if(Objects.isNull(queryInfo.getVipGroupId())){
+    		throw new BizException("请指定vip课程!");
+		}
+
+		PageInfo pageInfo = new PageInfo<>(queryInfo.getPage(), queryInfo.getRows());
+		Map<String, Object> params = new HashMap<String, Object>();
+		MapUtil.populateMap(params, queryInfo);
+
+		List<VipGroupSalaryDto> dataList = null;
+		int count = courseScheduleTeacherSalaryDao.countVipGroupSalarys(params);
+		if (count > 0) {
+			pageInfo.setTotal(count);
+			params.put("offset", pageInfo.getOffset());
+			dataList = courseScheduleTeacherSalaryDao.findVipGroupSalarys(params);
+			dataList.forEach(vipGroupSalaryDto -> {
+				if(Objects.isNull(vipGroupSalaryDto.getExpectSalary())){
+					vipGroupSalaryDto.setExpectSalary(new BigDecimal(0));
+				}
+				if(Objects.isNull(vipGroupSalaryDto.getActualSalary())){
+					vipGroupSalaryDto.setActualSalary(new BigDecimal(0));
+					vipGroupSalaryDto.setIsSalary(YesOrNoEnum.NO);
+				}else{
+					vipGroupSalaryDto.setIsSalary(YesOrNoEnum.YES);
+				}
+				vipGroupSalaryDto.setDeductionFee(vipGroupSalaryDto.getExpectSalary().subtract(vipGroupSalaryDto.getActualSalary()));
+			});
+		}
+		if (count == 0) {
+			dataList = new ArrayList<>();
+		}
+		pageInfo.setRows(dataList);
+
+		VipGroupSalaryBaseInfo vipGroupSalaryBaseInfo = vipGroupDao.getVipGroupSalaryInfo(queryInfo.getVipGroupId());
+		if(Objects.isNull(vipGroupSalaryBaseInfo)){
+			vipGroupSalaryBaseInfo=new VipGroupSalaryBaseInfo();
+		}
+		if(Objects.isNull(vipGroupSalaryBaseInfo.getExpectTotalSalary())){
+			vipGroupSalaryBaseInfo.setExpectTotalSalary(new BigDecimal(0));
+		}
+		if(Objects.isNull(vipGroupSalaryBaseInfo.getTotalSalary())){
+			vipGroupSalaryBaseInfo.setTotalSalary(new BigDecimal(0));
+		}
+		vipGroupSalaryBaseInfo.setTotalFeeDeduction(vipGroupSalaryBaseInfo.getExpectTotalSalary().subtract(vipGroupSalaryBaseInfo.getTotalSalary()));
+		vipGroupSalaryBaseInfo.setFeeDeductionNum(vipGroupDao.countVipGroupDeductionNum(queryInfo.getVipGroupId()));
+
+		Map<String,Object> result=new HashMap<>();
+		result.put("pageInfo",pageInfo);
+		result.put("baseInfo",vipGroupSalaryBaseInfo);
+		return result;
+	}
+
+	@Override
+	public List<String> findVipGroupAttendanceStudents(Long courseScheduleId) {
+    	if(Objects.isNull(courseScheduleId)){
+    		throw new BizException("请指定课程");
+		}
+		return courseScheduleDao.findStudentNamesByCourseSchedule(courseScheduleId);
+	}
 }

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

@@ -8,7 +8,7 @@
     <meta http-equiv="Cache-Control" content="no-cache" />
     <meta http-equiv="Expires" content="0" />
     <title>课程服务协议</title>
-    <style type="text/css">
+    <style>
         body { margin: 0; }
         header {
             height: .40rem;
@@ -74,89 +74,89 @@
 </head>
 <body style="font-family:'SimSun'">
     <div class="container">
-        <h1>课程服务协议</h1>
+        <h1>课程服务协议</h1>
         <!-- 甲方:深圳大雅乐盟网络教育股份有限公司 <br/> -->
-        甲方:深圳大雅乐盟网络教育股份有限公司 <br/>
+       甲方:深圳大雅乐盟网络教育股份有限公司 <br/>
         <div style="display: flex;">乙方:
             <div style="flex: 1 auto;">
                 <div class="iInfo">
-                    <span>家长姓名 ${studentInfo.realName}</span>
-                    <span>电话: ${studentInfo.phone}</span>
+                    <span>家长姓名 ${studentInfo.realName!}</span>
+                    <span>电话: ${studentInfo.phone!}</span>
                 </div>
                 <div class="iInfo">
-                    <span>身份证号:${studentInfo.idCardNo}</span>
+                    <span>身份证号:${studentInfo.idCardNo!}</span>
                 </div>
                 <div class="iInfo">
-                    <span>学生姓名:${studentInfo.name}</span>
-                    <span>所在班级:${studentInfo.grade} ${studentInfo.clazz}</span>
+                    <span>学生姓名:${studentInfo.name!}</span>
+                    <span>所在班级:${studentInfo.grade!} ${studentInfo.clazz!}</span>
                 </div>
                 <div class="iInfo">
-                    <span>所在声部:${studentInfo.subject.name}</span>
+                    <span>所在声部:${studentInfo.subject.name!}</span>
                 </div>
             </div>
-        </div>  
+        </div>
+            (本协议中“乙方“指学员及家长;”乙方学员“仅指参加甲方课程的学员;”乙方家长“仅指乙方学员的法定监护人。)
+        </div>
         为进一步提升器乐教学质量和服务品质,保证学员学习进度,明确培训各方的权责,经甲、乙双方协商一致,特订立本协议,以便共同遵守。
 
         <h2>一、课程信息</h2>
         
         <div class="iInfoContent">
-            <span>授课内容:{{proto}}</span>
-            <span>授课形式:{{proto}}</span>
-            <span>课次数量:{{proto}}</span>
-            <span>缴费金额:{{proto}}</span>
+            <span>授课类别:${classesType}</span>
+            <span>课程费用:${courseFee?string("0.00")}</span>
+            <span>收费形式:${paymentcalender}</span>
         </div>
 
         <h2>二、行为规范</h2>
-        乙方在选择甲方各类提高课程并签署本协议时视为乙方已经仔细阅读并同意遵守如下事项:
+        乙方学员在应服从甲方的管理,遵守甲方的制度。
         <h3>1.报名</h3>
         1.1无论是否源自指导老师或教务老师的建议,乙方选择参加甲方的课程,包括对授课形式、授课内容的选择,均为乙方自主意愿的表达及独立自主的选择。<br/>
-        1.2乙方应在所选课程开始前完成相应课程缴费,并完成报名手续。
+        1.2乙方应在所选课程开始前完成相应课程缴费,并完成报名手续。<br />
+        1.3甲方所有收费,均向乙方开具加盖公司印章的收款凭据,乙方务必妥善保管。
         <h3>2.上课</h3>
-        2.1乙方应按时到达甲方指定上课地点,作好课前准备;如发生迟到、或因自身原因早退等情况的,为避免影响老师后续课程的正常进行,授课老师除完成原定时间安排的授课外,将不再提供额外延长课时。<br/>
-        2.2乙方(含学员,下同)不得携带任何食品进入教室,所有进食应在课前完成;进入教室后,不得大声喧哗、追逐嬉戏,应当听从授课老师的安排;乙方应爱护公共财产和教学设施,严禁在桌椅上刻、划、涂、写等不文明行为;乙方未经授课老师同意,不得擅自使用教室内的乐器、音响、电视、空调等器材、设施,如造成此类器材、设施损坏的,乙方应照价赔偿。<br/>
-        2.3未经授课老师同意,乙方家长不得进入课堂,以免影响老师和学员上课;为保证训练质量及进度,学员应保证按照指导老师或教务老师所提出的要求在家练习,遇到专业问题应及时向指导老师请教,非专业问题可随时向教务老师反映。<br/>
-        2.4乙方家长应教育及监督学员务必注意个人安全,妥善保管个人财物,对于非甲方原因造成的人身安全事故或财物损失,由责任人自行承担
-        <h3>3.请假、休会及扣费</h3>
-        3.1基于教学进度和质量保证,本课程对于课程的延续性有严格要求,因此乙方应尽量避免请假。<br/>
-        3.2一对一课程有特殊情况需要请假的,应提前24小时以上以书面形式告知对应的授课老师,以便及时调整时间安排;一对多课程,不接受任何个人单独请假,如果集体请假,应提前24小时以上以书面形式告知对应的授课老师,未按本协议约定请假则当次课程视同已经教授,系统将自动结算课时并扣除相应费用。乙方请假后,应尽快预约补课时间完成补课。<br/>
-        3.3一对一课程以及一对二课程,乙方如遇特殊情况时,可向甲方或授课老师】申请办理临时休课。乙方可在6个月内申请复学,超过6个月未申请复课的,甲方有权按自动退会处理。一对二课程申请临时休课的,还需征得同组学员同意后方可申请休课。<br/>
+        2.1乙方学员应按时到达甲方指定上课地点,作好课前准备;如发生迟到、早退或因其他乙方原因未能按时上课的,视为乙方学员放弃该次课程,为避免影响老师后续课程的正常进行,授课老师除完成原定时间安排的授课外,将不再提供额外延长课时,也不会因乙方学员缺席而暂停教学课程。<br/>
+        2.2乙方学员不得携带任何食品进入教室,所有进食应在课前完成;进入教室后,不得大声喧哗、追逐嬉戏,应当听从授课老师的安排;乙方学员应爱护公共财产和教学设施,严禁在桌椅上刻、划、涂、写等不文明行为;乙方学员未经授课老师同意,不得擅自使用教室内的乐器、音响、电视、空调等器材、设施,如造成此类器材、设施损坏的,乙方应照价赔偿。<br/>
+        2.3乙方家长应教育及监督乙方学员务必注意个人安全,妥善保管个人财物,对于非甲方原因造成的人身安全事故或财物损失,由乙方自行承担。<br/>
+        2.4乙方违反上述规定给乐团或乐团其他成员造成任何不良影响的,乙方应尽力弥补并消除该不良影响
+        <h3>3.请假及其处理</h3>
+        3.1基于教学进度和质量保证,本课程对于课程的延续性有严格要求,因此乙方学员应尽量参加课程,无特殊情况则应避免请假。<br/>
+        3.2 VIP课程学员如有特殊情况需要请假的,应提前24小时以上以书面形式告知对应的授课老师,以便及时调整时间安排;VIP学员如遇特殊情况需要长期请假时,还可向□甲方/□授课老师申请办理临时休会。学员可在6个月内申请复学,超过6个月未申请复学的,甲方有权按自动退会处理。VIP课程为一对二课程的,其中一位学员申请临时休会的,还需征得同组另一位学员的同意后方可申请休会。<br/>
+        3.3鉴于团课的特殊性,甲方/乐团不接受团课学员个人单独请假,但如果因学校特殊安排等情形需要团课学员们集体请假的,乙方应提前24小时以上以书面形式告知对应的授课老师并同时提供学校的通知文件,否则当次课程视同已经教授完毕,系统将自动记录并结算课时并扣除相应课程费用。<br/>
         3.4每期课程相对应的有效期,乙方应在有效期内完成课程,10次课一期的,自交费之日起4个月内有效;20次课一期的,自交费之日起8个月内有效;40次课一期的,自交费之日起16个月内有效。如果由于指导老师请假等原因造成课程不能如期完成的,课程有效期将顺延;如课程超出有效期限,乙方所缴纳的课程费用将自动扣除逾期未完成的课时后自动清零。
-
         <h2>三、退费</h2>
-        1、一对一课程开课后,乙方要求退费的,乙方应在课程有效期内提出申请,甲方扣除报名费及未授课部分对应学费的20%后,将余款(不计息,下同)退还给乙方;如果乙方报名时享受打折优惠的,甲方先按照原价计算当期已上课时学费,再扣除报名费及未授课部分学费的20%后,将余款退还给乙方。<br/>
-        2、一对二课程开课后,乙方要求退费的,乙方应在课程有效期内提出申请,甲方扣除报名费及未授课部分的学费30%后,将余款退还给乙方;如果乙方报名时享受了打折优惠的,甲方先按照原价计算当期已上课时学费,再扣除报名费及未授课部分学费的30%后,将余款退还给乙方。<br/>
-        3、除一对一课程以及一对二课程之外的其他课程,课程开课后,甲方不接受任何原因的退款申请。<br/>
-        4、甲方所有收费,均向乙方开具加盖公司印章的收款凭据,乙方务必妥善保管,乙方按照本协议约定退费时,应向甲方出具该收费凭据原件方可办理。
-
+        1、VIP课程项下的一对一课程开课后,乙方要求退费的,乙方应在课程有效期内提出申请,甲方扣除报名费及未授课部分对应学费的20%后,将余款(不计息,下同)退还给乙方;如果乙方报名时享受打折优惠的,甲方先按照原价计算当期已上课时学费,再扣除报名费及未授课部分学费的20%后,将余款退还给乙方。<br/>
+        2、VIP课程项下的一对二课程开课后,乙方要求退费的,乙方应在课程有效期内提出申请,甲方扣除报名费及未授课部分的学费30%后,将余款退还给乙方;如果乙方报名时享受了打折优惠的,甲方先按照原价计算当期已上课时学费,再扣除报名费及未授课部分学费的30%后,将余款退还给乙方。<br/>
+        3、由于团课的特殊性,一旦课程开课后,除本协议另有约定外,甲方不接受任何原因的退费申请,如有特殊情况,请联系分部协商解决。
         <h2>四、违约责任</h2>
         1、当事人一方不履行合同义务或者履行合同义务不符合约定的,均构成违约,守约方有权以书面通知的方式要求违约方纠正其违约行为并采取及时、有效的补救措施消除违约后果,并赔偿守约方因违约方之违约行为而遭致的损失。若违约方在收到守约方的上述通知后5日内未纠正其违约行为的,守约方有权在做出书面通知的情况下,单方解除本协议,违约方应赔偿守约方因此遭致的全部损失。<br/>
         2、乙方应始终维护甲方的知识产权以及品牌形象,本协议期间以及本协议因任何原因失效、被撤销、解除或终止后,均不得直接或间接通过任何公众媒体(包括但不限于传统大众媒体,以及微信、微博、博客、直播平台等社交平台)发表损害甲方(包括但不限于其产品、服务及甲方授课老师)声誉的言论或实施任何类似行为,否则乙方应赔偿甲方因此遭受的全部损失。
+
         <h2>五、保密条款</h2>
         1、双方对本协议的条款、本协议的签订及履行情况以及通过签订和履行本协议而获知的对方及对方关联公司的任何信息均负有保密义务。任何一方不得以任何形式透露给第三方(有关法律法规要求和甲乙双方的法律、会计顾问、授权雇员除外),也不得擅自使用。<br/>
-        2、本保密义务期限不受本协议期限的限制。本协议失效、被撤销、解除或终止等任何情况下,双方均应遵守本保密义务。<br/>
+        2、本保密义务期限不受本协议期限的限制。本协议失效、被撤销、解除或终止等任何情况下,双方均应遵守本保密义务。
 
         <h2>六、不可抗力</h2>
         1、一方遇到不可抗力事件(指甲乙双方无法控制、无法预见或即使预见也无法避免的事件,该事件妨碍、影响或延误任何一方履行本协议的全部或部分义务,该事件包括但不限于自然灾害(如水灾、地震等)、火灾、政府行为、法律或政策变化(含学校合作变化)、战争或其他任何类似事件)时,受影响方应当立即书面通知对方,并告知该不可抗力事件对本协议可能产生的影响,并在该不可抗力事件发生后5日内向对方提供该事件的详细信息及由有关机构出具的解释受影响方因此无法履行本协议项下全部或部分义务的相关证明。<br/>
         2、由于上述不可抗力事件致使受影响方无法履行或无法按时履行本协议项下全部或部分义务的,双方于彼此间均不承担违约责任,但双方应在相互信任的基础上协商解决,尽力减少不可抗力事件对本协议的影响,并采取合理方式进行调整(包括但不限于另行签订补充协议等),尽量避免损失的扩大。<br/>
-        3、不可抗力事件消失或结束后,除双方另行协商一致外,受到不可抗力影响的一方应当立即采取措施继续履行本协议,如不可抗力事件持续30日以上的,则任何一方有权以书面通知对方的方式单方解除本协议。<br/>
-
+        3、不可抗力事件消失或结束后,除双方另行协商一致外,受到不可抗力影响的一方应当立即采取措施继续履行本协议,如不可抗力事件持续30日以上的,则任何一方有权以书面通知对方的方式单方解除本协议。
+        
         <h2>七、适用法律及争议解决方式</h2>
         1、本协议的订立、效力、履行、解释及争议解决均适用中华人民共和国法律。<br/>
-        2、因履行本协议发生的一切争议,甲乙双方应友好协商解决;如双方在发生争议后30日内无法通过协商解决时,任何一方有权向甲方所在地有管辖权的人民法院提起诉讼解决。<br/>
-
+        2、因履行本协议发生的一切争议,甲乙双方应友好协商解决;如双方在发生争议后30日内无法通过协商解决时,任何一方有权向甲方所在地有管辖权的人民法院提起诉讼解决。
+        
         <h2>八、其他</h2>
-        1、乙方同意,甲方有权在乙方学习和活动期间对其拍摄照片、视频,甲方对所拍摄的照片、视频有永久免费使用权。<br/>
+        1、乙方同意,甲方有权在乙方学习、上课、排练和活动期间对其拍摄照片、视频,甲方对所拍摄的照片、视频享有著作权,乙方同意甲方可合理使用该等照片、视频。<br/>
         2、未经甲方事先书面同意,乙方不得将本课程转让给乙方以外的任何第三方。<br/>
         3、双方确认并同意,本协议的电子版本与纸质版本具有同等法律效力。双方发生争议时,电子合同打印件可作为证据提交。双方通过网络以在线方式签订本协议的 ,则以乙方点击“确认”或“同意”等相关按钮或以电子签名的方式作为对合同内容的同意、确认以及本协议的签署;如双方签订纸质版本协议的,则本协议壹式贰份,甲方盖公章或合同专用章并且乙方签字作为有效签署方式,并且双方各执壹份,每份具有同等法律效力。<br/>
         4、本协议自双方按照本协议约定方式签署之日起生效,有效期至双方履行完本协议约定的全部义务时止。<br/>
         5、本协议未尽事宜或对本协议的任何修改、补充,有双方另行协商后以签订补充协议的方式解决,补充协议与本协议具有同等法律效力;双方没有约定也没有协商一致的,遵照相关法律法规规定执行。<br/>
-        6、双方因履行本协议而相互发出或者提供的所有通知、文件、资料,均以本协议中所列明的电话、APP推送消息送达,乙方如果变更电话号码的,应当自变更后1日内通知甲方且获得甲方确认,甲方通过电话、APP方式无法联系乙方或者甲方认为必要时,甲方也可以通过特快专递至乙方住址的方式向乙方发出上述任何通知、文件、资料等,并在甲方寄出特快专递后第5日视为送达成功。<br/>
-
+        6、双方因履行本协议而相互发出或者提供的所有通知、文件、资料,均以本协议中所列明的电话、APP推送消息送达,乙方如果变更电话号码的,应当自变更后1日内通知甲方且获得甲方确认,甲方通过电话、APP方式无法联系乙方或者甲方认为必要时,甲方也可以通过特快专递至乙方住址的方式向乙方发出上述任何通知、文件、资料等,并在甲方寄出特快专递后第5日视为送达成功。
+        
         <div class="signature">
             <div class="sign">甲方签章:深圳大雅乐盟网络教育股份有限公司
                 <span>日期:${.now?string("yyyy年MM月dd日")}</span>
             </div>
-            <div class="sign">乙方签字:{{proto}}
+            <div class="sign">乙方签字:${studentInfo.realName!}
                 <span>日期:${.now?string("yyyy年MM月dd日")} </span>
             </div>
         </div>

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

@@ -1,5 +1,5 @@
-<!DOCTYPE html>
-<html lang="en" style="font-size: 100px;">
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" lang="en" style="font-size: 100px;">
 <head>
     <meta charset="utf-8" />
     <meta http-equiv="X-UA-Compatible" content="IE=edge" />
@@ -79,30 +79,30 @@
         <div style="display: flex;">乙方:
             <div style="flex: 1 auto;">
                 <div class="iInfo">
-                    <span>家长姓名 ${studentInfo.realName}</span>
-                    <span>电话: ${studentInfo.phone}</span>
+                    <span>家长姓名 ${studentInfo.realName!}</span>
+                    <span>电话: ${studentInfo.phone!}</span>
                 </div>
                 <div class="iInfo">
-                    <span>身份证号:${studentInfo.idCardNo}</span>
+                    <span>身份证号:${studentInfo.idCardNo!}</span>
                 </div>
                 <div class="iInfo">
-                    <span>学生姓名:${studentInfo.name}</span>
-                    <span>所在班级:${studentInfo.grade} ${studentInfo.clazz}</span>
+                    <span>学生姓名:${studentInfo.name!}</span>
+                    <span>所在班级:${studentInfo.grade!} ${studentInfo.clazz!}</span>
                 </div>
                 <div class="iInfo">
-                    <span>所在声部:${studentInfo.subject.name}</span>
+                    <span>所在声部:${studentInfo.subject.name!}</span>
                 </div>
             </div>
         </div>                     
         
-        为了促进学校乐团健康、持续发展,让更多的学生在校园拥有良好的器乐学习机会,甲方基于公益普惠的原则,决定提供价值${goodsList[0].marketPrice?string("#.##")}元的KEY品牌全新乐器供乙方在学校乐团期间免费使用。现根据《中华人民共和国合同法》等法律法规规定,为明确甲乙双方权利义务,经协商一致,就乙方借用乐器事宜达成如下协议:
+        为了促进学校乐团健康、持续发展,让更多的学生在校园拥有良好的器乐学习机会,甲方基于公益普惠的原则,决定提供价值${goodsList[0].marketPrice?string("0.00")}元的KEY品牌全新乐器供乙方在学校乐团期间免费使用。现根据《中华人民共和国合同法》等法律法规规定,为明确甲乙双方权利义务,经协商一致,就乙方借用乐器事宜达成如下协议:
         <h2>一、甲方权利与义务:</h2>
-        1、乙方所借用的乐器为甲方资产,乐器所有权归属甲方所有,甲方有权在必要时向乙方收回借用乐器并退还押金。<br/>
-        2、甲方所提供乐器为全新的KEY品牌乐器。在乙方签订本协议、交纳乐器使用押金后,甲方即将乐器交付给乙方供其在学校乐团期间免费使用。<br/>
+1、乙方所借用的乐器为甲方资产,乐器所有权归属甲方所有,甲方有权在必要时向乙方收回借用乐器并退还押金。<br/>
+2、甲方所提供乐器为全新的KEY品牌乐器。在乙方签订本协议、交纳乐器使用押金后,甲方即将乐器交付给乙方供其在学校乐团期间免费使用。<br/>
         3、乙方归还乐器时,双方当面当场验收,经甲方维修技师检验确认乐器无人为损坏、可正常使用后,甲方在七个工作日内全额不计息退还乙方已交纳的押金。<br/>
         4、如乙方已购买甲方乐器保养服务,甲方需在乙方借用期间协助乙方处理乐器维修和保养问题。
         <h2>二、乙方权利与义务:</h2>
-        1、乙方在签订本协议、交纳乐器使用押金¥{{proto}}元(大写人民币{{proto}}元整)后,享有所借用乐器在学校乐团期间的免费使用权。乙方应当爱惜乐器并妥善保管,不得将该乐器转租、借用、出售、典当、质押或抵押,也不得将乐器交于非专业人士使用。乐器借用政策,每位团员仅可享受一次,退团后再次加入乐团的,将无法享受乐器借用政策。<br/>
+        1、乙方在签订本协议、交纳乐器使用押金¥${depositFee?string("0.00")}元(大写人民币${depositFeeFmt})后,享有所借用乐器在学校乐团期间的免费使用权。乙方应当爱惜乐器并妥善保管,不得将该乐器转租、借用、出售、典当、质押或抵押,也不得将乐器交于非专业人士使用。乐器借用政策,每位团员仅可享受一次,退团后再次加入乐团的,将无法享受乐器借用政策。<br/>
         2、乐器日常维护由乙方自行完成,每次练习完毕后需按老师要求对乐器进行擦拭并装箱保管。如因人为原因(包括但不限于磕、碰、摔等)造成乐器损坏的,乙方需自行承担维修费用;如因非甲方原因导致乐器无法正常使用(正常使用磨损除外)或乐器毁损、灭失、遗失的,乙方须按本协议中明示的乐器团购价格进行赔付。<br/>
         3、当乙方决定不再继续乐团学习时,应在退团之日起1日内将其借用的乐器归还甲方,双方当面当场验收,经甲方维修技师检验确认乐器无人为损坏、可正常使用后,乙方可按照本协议约定获得已交纳的押金;经甲方维修技师检验,乐器存在损坏的,乙方应承担相应的维修费用,如乐器已经无法正常使用的,乙方须按本协议中明示的乐器团购价格进行赔付,甲方有权从应退还乙方的押金中先行扣除维修费用、赔付费用,如甲方扣除押金后仍然不足以弥补维修费用、赔付费用的,甲方有权继续要求乙方支付剩余费用。<br/>
         4、乙方终止乐团学习2个月内,仍未将乐器归还给甲方的,则视为乙方违约,乙方所交押金甲方有权不予退还,同时乙方须按乐器团购价格进行赔付。
@@ -113,7 +113,7 @@
         </div>
         <div class="iInfo">
             <span>型号:${goodsList[0].specification}</span>
-            <span>团购价格:${goodsList[0].groupPurchasePrice?string("#.##")}</span>
+            <span>团购价格:${goodsList[0].groupPurchasePrice?string("0.00")}</span>
         </div>
 
         <h2>四、违约责任</h2>  
@@ -138,7 +138,7 @@
             <div class="sign">甲方签章:深圳大雅乐盟网络教育股份有限公司
                 <span>日期:${.now?string("yyyy年MM月dd日")}</span>
             </div>
-            <div class="sign">乙方签字:${studentInfo.realName}
+            <div class="sign">乙方签字:${studentInfo.realName!}
                 <span>日期:${.now?string("yyyy年MM月dd日")} </span>
             </div>
         </div>

+ 202 - 216
mec-biz/src/main/resources/config/contracts/register.ftl

@@ -1,222 +1,208 @@
 <!DOCTYPE html>
 <html lang="en" style="font-size: 100px;">
 <head>
-    <meta charset="utf-8" />
-    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
-    <meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no, viewport-fit=cover" />
-    <meta http-equiv="Pragma" content="no-cache" />
-    <meta http-equiv="Cache-Control" content="no-cache" />
-    <meta http-equiv="Expires" content="0" />
-    <title>APP用户注册及乐团注册服务协议</title>
-    <style type="text/css">
-        body { margin: 0; }
-        header {
-            height: .40rem;
-            line-height: .40rem;
-            color: #000;
-            font-size: .17rem;
-            background: #fff;
-            box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.07);
-            text-align: center;
-        }
-        header .back {
-            width: .2rem;
-            height: .2rem;
-            position: absolute;
-            left: .12rem;
-            top: .1rem;
-        }
-        .container {
-            padding: .22rem .2rem .3rem;
-            font-size: .14rem;
-        }
-        h1 {
-            font-size: .16rem;
-            text-align: center;
-        }
-        h2 {
-            font-size: .16rem;
-            font-weight: bold;
-            padding-top: .15rem;
-        }
-        h3 {
-            font-size: .14rem;
-            font-weight: bold;
-        }
-        .signature {
-            display: flex;
-            padding-top: .5rem;
-        }
-        .signature .sign {
-            flex: 1;
-            position: relative;
-        }
-        .signature span {
-            display: block;
-        }
-        .signature .cachet {
-            position: absolute;
-            top: -.6rem;
-            left: 0;
-            width: 1.5rem;
-            height: 1.5rem;
-        }
-        .iInfo {
-            display: flex;
-        }
-        .iInfo span {
-            flex: 1;
-        }
-        .iInfoContent, .iInfoContent span {
-            display: block;
-        }
-    </style>
+<meta charset="utf-8" />
+<meta http-equiv="X-UA-Compatible" content="IE=edge" />
+<meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no, viewport-fit=cover" />
+<meta http-equiv="Pragma" content="no-cache" />
+<meta http-equiv="Cache-Control" content="no-cache" />
+<meta http-equiv="Expires" content="0" />
+<title>APP用户注册及乐团注册服务协议</title>
+<style>
+body { margin: 0; }
+header {
+height: .40rem;
+line-height: .40rem;
+color: #000;
+font-size: .17rem;
+background: #fff;
+box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.07);
+text-align: center;
+}
+header .back {
+width: .2rem;
+height: .2rem;
+position: absolute;
+left: .12rem;
+top: .1rem;
+}
+.container {
+padding: .22rem .2rem .3rem;
+font-size: .14rem;
+}
+h1 {
+font-size: .16rem;
+text-align: center;
+}
+h2 {
+font-size: .16rem;
+font-weight: bold;
+padding-top: .15rem;
+}
+h3 {
+font-size: .14rem;
+font-weight: bold;
+}
+.signature {
+display: flex;
+padding-top: .5rem;
+}
+.signature .sign {
+flex: 1;
+position: relative;
+}
+.signature span {
+display: block;
+}
+.signature .cachet {
+position: absolute;
+top: -.6rem;
+left: 0;
+width: 1.5rem;
+height: 1.5rem;
+}
+.iInfo {
+display: flex;
+}
+.iInfo span {
+flex: 1;
+}
+.iInfoContent, .iInfoContent span {
+display: block;
+}
+</style>
 </head>
-<body style="font-family:'SimSun'">
-    <div class="container">
-        <h1>《APP用户注册及乐团注册服务协议》</h1>
-
-        欢迎用户使用{{proto}}(下称“本软件”),请用户在使用本软件前仔细阅读本协议。如用户不同意本协议任何条款,请勿在本软件注册账号或使用大雅乐盟基于本软件提供的服务(下称“本服务”)。用户点击“注册”、“登录”或“同意”等按钮或使用本服务后,本协议即构成大雅乐盟与用户之间具有约束力的法律文件。
-        <h2>一、提示</h2>
-        1. 用户在使用本软件或本服务前,应当认真阅读本协议。请用户务必审慎阅读、充分理解各条款内容,特别是免除或者限制责任的条款、法律适用和争议解决条款。免除或者限制责任的条款将以粗体下划线标识,用户应重点阅读,并自行选择接受或不接受。如用户对本协议有任何疑问,可联系大雅乐盟。<br/>
-        2. 当用户按照注册页面提示填写信息、阅读并同意本协议且完成全部注册程序,或登录本软件,或使用本服务后,即表示用户已充分阅读、理解并接受本协议的全部内容,并与大雅乐盟达成一致,成为大雅乐盟的用户。阅读本协议的过程中,如果用户不同意或不接受本协议任何条款,用户应立即停止注册、登录本软件或使用本服务。<br/>
-        3. 大雅乐盟可以随时更新本协议的各项条款,包括但不限于增加新的服务类型或功能,更新后的协议条款一经大雅乐盟在本软件公布或更新即生效并代替原来的协议条款,大雅乐盟不会另行通知用户,用户可以及时关注并阅读大雅乐盟更新的本协议最新版本;用户继续使用本软件或本服务的,视为用户接受本协议的最新更新版本;用户不接受本协议最新版本的,应立即停止使用本软件或本服务。<br/>
-        4. 特别提醒:未满18周岁的用户应在法定监护人的陪同下阅读后,并且应在法定监护人的同意和指导下注册和/或使用本软件及本服务。
-        <h2>二、关于本软件及本服务的重要提示</h2>
-        1. 用户使用本服务需要下载本软件的客户端版本,本软件的客户端版本提供包括但不限于 iOS、Android等多个应用版本,用户必须选择与所安装终端设备相匹配的软件版本。 用户可以直接从大雅乐盟的网站上获取本软件,也可以从得到大雅乐盟授权的第三方获取。如果用户从未经大雅乐盟授权的第三方获取本软件或与本软件名称相同的安装程序,大雅乐盟无法保证该软件能够正常使用,并对因此给用户造成的损失不予负责。下载安装程序后,用户需要按照该程序提示的步骤正确安装。<br/>
-        2. 为了改善用户体验、完善服务内容,大雅乐盟将不断努力开发新的服务,并为用户不时提供软件更新(这些更新可能会采取软件替换、修改、功能强化、版本升级等形式)。大雅乐盟有权不经向用户特别通知而对本软件进行更新,或者对本软件的部分功能效果进行改变或限制。新版本发布后,旧版本的软件可能无法使用。大雅乐盟无法保证旧版本软件继续可用及相应的客户服务,请用户随时核对并下载最新版本。<br/>
-        3. 用户理解并同意:为了向用户提供有效的服务,本软件会利用用户终端设备的处理器和带宽等资源,用户使用本软件时,需要接入互联网、移动互联网,此时可能产生数据流量的费用,用户需自行向运营商了解相关资费信息,并自行承担接入互联网、移动互联网所需的费用(包括但不限于上网费、通讯费)以及使用本软件及本服务必需的设备(包括但不限于电脑、手机等移动终端设备)。<br/>
-        4. 大雅乐盟给予用户一项个人的、不可转让及非排他性的许可,以使用本软件。用户可以为非商业目的在单一台终端设备上安装、使用、显示、运行本软件。用户不得为商业运营目的安装、使用、运行本软件,不可以对该软件或者该软件运行过程中释放到任何计算机终端内存中的数据及该软件运行过程中客户端与服务器端的交互数据进行复制、更改、修改、挂接运行或创作任何衍生作品,形式包括但不限于使用插件、外挂或非经授权的第三方工具/服务接入本软件和相关系统。<br/>
-        5. 本协议其他条款未明示授权的其他一切权利仍由大雅乐盟保留,用户在行使这些权利时须另外取得大雅乐盟的书面许可。大雅乐盟如果未行使前述任何权利,并不构成对该权利的放弃。
-        
-        <h2>三、服务内容</h2> 
-        1. 大雅乐盟:即{{proto}}。<br/>
-        2. 本服务是基于互联网及移动互联网,通过本软件向用户提供【直播教学、录播教学、智能打分、学员管理等】功能服务。大雅乐盟以乐团为单位对用户进行管理,用户注册本软件即视为用户同意参加乐团,遵守乐团的各项制度和管理。用户在使用本软件或本服务过程中发生任何问题的,可以与大雅乐盟乐团老师联系和处理。具体内容及具体规则以用户与大雅乐盟签署的协议及/或本软件公示的内容为准。<br/>
-        3. 服务功能介绍:<br/>
-        直播教学:{{proto}}<br/>
-        录播教学:{{proto}}<br/>
-        智能打分:{{proto}}<br/>
-        学员管理:{{proto}}<br/>
-        4. 本软件规则包括但不限于大雅乐盟通过官网、本软件等途径发布的全部规则、细则、解读、说明公告等。<br/>
-        5. 服务费用<br/>
-        5.1 用户使用本软件或本服务的费用以用户与大雅乐盟签署的协议及/或本软件公示的内容为准。<br/>
-        6. 乐团管理<br/>
-        6.1大雅乐盟有权对用户进行管理,制定乐团各项制度,对用户在乐团的日常行为进行管理。<br/>
-        
-        <h2>四、用户账户注册、使用与管理</h2>  
-        1. 用户资格<br/>
-        用户开始使用本软件或本服务前,应当具备中华人民共和国法律规定的与用户行为相对应的民事行为能力,否则用户的法定监护人应依照法律规定承担因此而导致的一切后果。<br/>
-        2. 账户说明<br/>
-        用户使用本软件时,应当注册账户,注册时可以使用{{proto}},用户应当提供并填写真实、合法、准确、完整的资料和信息,并在相关信息变更时在1个工作日内在本软件更新。因用户提供或填写的资料、信息不符合上述要求而导致的任何问题及后果,应由用户自行承担,大雅乐盟不对此承担任何责任。当用户按照注册页面提示填写信息、阅读并同意本协议且完成全部注册程序后,用户可获得本软件账户并成为本软件用户。<br/>
-        3. 账户安全规范<br/>
-        3.1 用户的账户由用户自行设置、保管。建议用户务必保管好用户的账户及密码,当用户每次使用完本软件时,应以正确步骤离开本软件。用户了解并同意,确保用户账户及密码的机密安全是用户的责任。用户将对利用该账户及密码所进行的一切行动及言论负完全的责任,并同意以下事项:<br/>
-        3.1.1 用户主动泄露账户、密码或遭受他人攻击、诈骗等行为导致的损失及后果,均由用户自行承担;<br/>
-        3.1.2 用户的账户只限用户本人使用,未经大雅乐盟事先书面同意,不得将账户提供、转让、许可、出售给任何第三方;<br/>
-        3.1.3 擅自使用他人账户及密码的,大雅乐盟及其合法授权主体有权追究实际使用人的法律责任;<br/>
-        3.1.4 用户应当设置符合本软件要求的密码,并妥善保管和保护密码,不得随意告诉他人,并定期更新密码。大雅乐盟同时还建议用户通过使用复杂密码等方式,不要使用过于简单的词语或数字,以保证用户的账号、密码安全;<br/>
-        3.1.5 如发现任何未经授权使用用户账户访问和/或使用本软件或其他可能导致用户账户遭窃、遗失的情况,建议用户立即通知大雅乐盟。<br/>
-        3.2 大雅乐盟有权基于单方独立判断,在其认为可能发生危害交易安全等情形时,不经通知而先行暂停、中断或终止向用户提供本协议项下的全部或部分用户服务,并将注册资料移除或删除,且无需对用户或任何第三方承担任何责任。前述情形包括但不限于:<br/>
-        3.2.1 大雅乐盟发现异常交易或有理由认为存在违法违规情形时;<br/>
-        3.2.2 大雅乐盟认为用户账户被冒用或其他大雅乐盟认为有风险的其他情形。<br/>
-        4. 用户忘记或丢失账户、密码时,可以按照本软件的申诉途径凭初始注册资料找回账户,但大雅乐盟并不承诺用户忘记或丢失账户后一定能通过申诉途径找回该账户。本软件的账户或密码找回/重设机制仅负责识别用户在申诉申请上所填资料与系统记录资料的一致性,而无法识别申诉人是否系真正账户使用权人。用户因忘记或丢失账户或密码而遭致任何法律责任或损失的,用户应自行承担全部法律责任及损失,大雅乐盟不对此承担任何责任。<br/>
-        5. 用户理解并同意,本软件同大多数互联网软件一样,可能会受多种因素影响,包括但不限于用户原因、网络服务质量、社会环境等;也可能会受各种安全问题的侵扰,包括但不限于他人非法利用用户资料,进行现实中的骚扰;用户下载安装的其他软件或访问的其他网站中可能含有病毒、木马程序或其他恶意程序,威胁用户的终端设备信息和数据安全,继而影响本软件的正常使用等。因此,用户应加强信息安全及个人信息的保护意识,注意密码保护,以免遭受损失。<br/>
-        
-        <h2>五、服务使用规则</h2>
-        1. 用户使用本软件或本服务时,不得实施下列行为:<br/>
-        1.1使用本软件或本服务的过程中出现下列情形:<br/>
-        1.1.1破坏宪法所确定的基本原则的;<br/>
-        1.1.2危害国家安全、泄露国家秘密、颠覆国家政权、破坏国家统一的;<br/>
-        1.1.3损害国家荣誉和利益的;<br/>
-        1.1.4煽动民族仇恨、民族歧视,破坏民族团结的;<br/>
-        1.1.5破坏国家宗教政策,宣扬邪教和封建迷信的;<br/>
-        1.1.6散布谣言,扰乱社会秩序,破坏社会稳定的;<br/>
-        1.1.7散布淫秽、色情、赌博、暴力、凶杀、恐怖或者教唆犯罪的;<br/>
-        1.1.8侮辱或者诽谤他人,侵害他人合法权益的;<br/>
-        1.1.9含有法律法规、行政规章所禁止的其他内容的;<br/>
-        1.2 发布、传送、传播、储存侵害他人合法权利(包括但不限于名誉权、肖像权、知识产权、商业秘密等)的内容;<br/>
-        1.3 发布、传送、传播、储存与他人隐私、个人信息或资料有关的内容;<br/>
-        1.4 发布、传送、传播虚假、骚扰、营销、广告、诱导分享等相关的内容;<br/>
-        1.5 违反法律法规或干扰、破坏大雅乐盟、本软件的正常运营的其他内容。<br/>
-        2. 未经大雅乐盟事先书面同意,用户使用本软件时不得有下列行为:<br/>
-        2.1 以创建相同、类似或竞争服务为目的访问本软件或使用本服务;<br/>
-        2.2 删除、遮掩、修改本软件及其副本上关于著作权的声明;<br/>
-        2.3 对本软件或本服务(包括但不限于服务或其内容中的广告或赞助内容)进行任何形式的许可、出售、租赁、转让、发行或做其他商业用途;<br/>
-        2.4 通过修改或伪造软件运行中的指令、数据,或者增加、删减、变动软件的功能或运行效果,或者将用于上述用途的软件、方法进行运营或向公众传播,无论是否基于商业目的;<br/>
-        2.5 通过非大雅乐盟开发、授权的第三方软件、插件、外挂、系统,登录或使用本软件或本服务;<br/>
-        2.6 自行或者授权他人、第三方软件对本软件及其组件、模块、数据进行干扰,或在本软件或利用本服务上传或发布病毒、蠕虫、恶意代码、故意破坏或改变系统或数据的软件;<br/>
-        2.7 其他未经大雅乐盟明示授权的行为。<br/>
-        3. 用户内容是指用户上传、提供信息和资料或以其他方式使用本软件与本服务时产生的所有内容(包括但不限于用户信息、资料、图片或其他内容),用户是用户内容的唯一的责任人,应当承担因用户内容披露而导致的用户或任何第三方被识别的风险。<br/>
-        4. 用户充分了解并同意,用户必须为自己注册账号下的一切行为负责,包括用户所发表的任何内容以及由此产生的任何后果。用户应对本服务中的内容自行加以判断,并承担因使用内容而引起的所有风险,包括因对内容的正确性、完整性或实用性的依赖而产生的风险。大雅乐盟无法且不会对因前述风险而导致的任何损失或损害承担责任。<br/>
-        5. 用户应服从大雅乐盟乐团的管理,用户在乐团出现下列情形的,大雅乐盟有权对用户作出警告,用户收到警告后仍然不遵守大雅乐盟的管理制度的,大雅乐盟有权对用户作出退团等处分:<br/>
-        5.1上课、排练时不遵守纪律,影响乐团其他团员的正常上课、排练;<br/>
-        5.2不服从乐团老师的管理和指导;<br/>
-        5.3一个学期内发生两次及以上缺席乐团上课、排练行为;<br/>
-        5.4一个学期内发生两次及以上未按老师要求回传视频作业的情形;<br/>
-        5.5连续{{proto}}天不练习,影响乐团团员和乐团的整体水平的。<br/>
-        6. 用户在每次参加乐团排练、训练时,应按专业老师要求带齐训练所需乐器、教材乐谱、乐谱本、铅笔及乐器护理等学习用品,并提前10分钟到达排练场地,做好准备工作;始终保持排练、训练场地的清洁卫生;如遇到特殊情况无法参加乐团排练、训练时,应提前一天向乐团老师请假。<br/>
-        7. 因用户个人原因未能按时上课的,视为该用户放弃该次上课,学校乐团声部训练不因用户请假而停止整个声部课教学,如用户因此给乐团造成任何不良影响的,用户应尽力弥补并消除该不良影响。<br/>
-        8. 用户应保证每日练习时间不少于20分钟,并按专业老师要求通过本软件回传周视频作业。<br/>
-        9. 退团:用户如因自身原因拟退出乐团的,应向学校申请退团,并获得学校的同意退团批准,再经用户家长确认后,方可退团。<br/>
-
-        
-        <h2>六、第三方链接及服务</h2>
-        1. 本软件或本服务可能保留有第三方网站或网址的链接,访问这些链接将由用户自己做出决定,大雅乐盟并不就这些链接上所提供的任何信息、数据、观点、图片、陈述或建议的准确性、完整性、充分性和可靠性提供承诺或保证。大雅乐盟没有审查过任何第三方网站,对这些网站及其内容不进行控制,也不负任何责任。如果用户决定访问任何与本站链接的第三方网站,其可能带来的结果和风险全部由用户自己承担。<br/>
-        2. 用户在使用本软件中第三方提供的产品或服务时,除遵守本协议约定外,还应遵守第三方的用户协议。大雅乐盟和第三方对可能出现的纠纷在法律规定和约定的范围内各自承担责任。因用户使用本软件或要求大雅乐盟提供特定服务时,本软件可能会调用第三方系统或者通过第三方支持用户的使用或访问,使用或访问的结果由该第三方提供(包括但不限于第三方通过公众账号提供的服务,或通过开放平台接入的内容等),大雅乐盟不保证通过第三方提供服务及内容的安全性、准确性、有效性及其他不确定的风险,由此若引发的任何争议及损害,与大雅乐盟无关,大雅乐盟不承担任何责任。<br/>
-        3. 用户已知晓并同意大雅乐盟提供本服务(无论是免费服务还是有偿服务)还可能基于第三方如合作单位(包括但不限于电信运营商)提供的技术支持等服务获得。如果因第三方提供的服务给用户增加任何成本或造成任何损失的,大雅乐盟会协助用户与第三方进行沟通和处理,如因此发生维修、更换等费用的,应由用户自行承担,大雅乐盟不对此承担任何法律责任和赔偿责任。<br/>
-        
-        <h2>七、知识产权的保护以及保密</h2>
-        1. 大雅乐盟的商标、商号、Logo、图形及其组合,以及大雅乐盟的其他标识、产品和服务名称均为大雅乐盟或大雅乐盟关联公司所有,未经大雅乐盟书面授权,任何人不得以任何方式展示、使用或作其他处理,也不得向任何第三方表明或让其误认为其有权展示、使用或作其他处理。<br/>
-        2. 大雅乐盟提供的培训、课程相关的全部内容(包括但不限于培训课程设置、培训课件、教材等)的知识产权均归大雅乐盟单独和完整所有。用户应当保护大雅乐盟的知识产权,只能用于自身学习之目的,未经大雅乐盟事先书面同意,不得擅自将培训课程相关的任何内容进行复制、复印、影音、拍摄或进行摘要等措施后以转让、出售、赠与或其他任何形式提供给任何第三方,否则大雅乐盟有权追究其法律责任。<br/>
-        3. 大雅乐盟为提供服务而使用的任何软件(包括但不限于软件中所含的任何图象、照片、动画、录像、录音、音乐、文字和附加程序、随附的帮助材料)的一切权利均属于该软件的著作权人,未经该软件的著作权人许可,用户不得对该软件进行反向工程(reverse engineer)、反向编译(decompile)或反汇编(disassemble)。<br/>
-        4. 用户已经了解并同意:在大雅乐盟提供的所有服务器上的数据(包括但不限于虚拟物品等)全部归大雅乐盟所有。在不影响用户正常接收服务的情况下,大雅乐盟有权决定保留或不保留服务器上的全部或部分数据。<br/>
-        5. 用户已经了解并同意:大雅乐盟有权将本协议项下大雅乐盟所有的知识产权授权第三方使用,在变更产品运营商时,大雅乐盟可以将其运营的产品或服务以及与该在产品或服务相关的归大雅乐盟所有的知识产权转让给新的产品运营商。<br/>
-        6. 用户使用大雅乐盟提供的本软件或本服务期间获取的文件、资料、表格等信息,包括但不限于有关合作资料、营销资料等,无论是口头、书面的或是电子文件形式的,均属大雅乐盟的商业秘密,用户必须对这些商业秘密严格遵守保密义务,不得向外透露,也不得使用这些商业秘密为自己或他人谋取利益。<br/>
-        
-        <h2>八、违约条款</h2>
-        1. 用户违反本协议约定时即构成违约情形,大雅乐盟有权要求用户采取及时的补救措施,消除违约后果,并有权终止本协议。如用户的违约行为使大雅乐盟及/或关联公司遭受损失(包括自身的直接经济损失、商誉损失及对外支付的赔偿金、和解款、律师费、诉讼费等间接经济损失)的,用户应赔偿大雅乐盟及/或关联公司的上述全部损失。<br/>
-        2. 用户理解并同意,如用户的行为导致第三方向大雅乐盟及/或关联公司主张权利或任何索赔、要求或损失的,大雅乐盟及/或关联公司在对第三人承担赔偿义务后可向用户追偿与此相关的全部损失。<br/>
-        
-        <h2>九、协议终止</h2>
-        1. 用户有权通过以下任一方式终止本协议:<br/>
-        1.1用户自行注销用户的账户的;<br/>
-        1.2用户按照本协议约定方式退出乐团的;<br/>
-        1.3 变更事项生效或服务协议更新时,用户停止使用并明示不愿接受变更事项或明示不愿接受更新后的服务协议的;<br/>
-        1.4 用户明示不愿继续使用本软件或本服务,且符合本协议终止条件的。<br/>
-        2. 出现以下情况时,大雅乐盟可以终止本协议:<br/>
-        2.1 用户违反本协议约定的,大雅乐盟依据违约条款终止本协议,或对用户处以退团处分的;<br/>
-        2.2 用户的账户被大雅乐盟依据本协议进行注销等清理的;<br/>
-        2.3 用户在使用本软件或本服务时存在侵犯他人合法权益或其他严重违法违规行为的;<br/>
-        2.4 不可抗力导致本协议不能履行的(“不可抗力”是指双方不可预见、或可以预见但不能避免并或克服的客观情况,该事件妨碍、影响或延误任何一方根据合同履行其全部或部分义务。该事件包括但不限于政府行为、法律或规定的发布或修订,自然灾害、战争、网络堵塞或中断、黑客袭击或任何其他类似事件),且该不可抗力持续30天以上的;<br/>
-        2.5 根据相关法律法规规定大雅乐盟应当终止服务或大雅乐盟认为需终止服务的其他情形。<br/>
-        3. 协议终止后的处理<br/>
-        本协议终止后,除法律有明确规定外,大雅乐盟无义务向用户或用户指定的第三方披露用户账户中的任何信息。<br/>
-
-        <h2>十、责任限制</h2>
-        1. 用户使用本软件或本服务的风险应由用户自行承担,大雅乐盟对本软件不作任何类型的担保,不论是明示的、默示的保证和条件,包括但不限于本软件的适销性、适用性、无病毒、无疏忽或无技术瑕疵问题、所有权和无侵权的明示或默示担保和条件,对在任何情况下因使用或不能使用本软件所产生的直接、间接、偶然、特殊及后续的损害及风险,大雅乐盟不承担任何责任。<br/>
-        2. 用户明确理解和同意,大雅乐盟不对因下述任一情况而导致的损害赔偿承担责任,包括但不限于利润、商誉、使用、数据等方面的损失或其它无形损失的损害赔偿:<br/>
-        1.1 大雅乐盟向用户免费提供的任何产品或者服务;<br/>
-        1.2 大雅乐盟向用户赠送的任何产品或者服务;<br/>
-        1.3 对于用户使用本软件上可能涉及由第三方所有、控制或者运营的网站或平台提供的服务及其导致的风险;<br/>
-        1.4 因用户的过错导致的任何损失,该过错包括但不限于:决策失误、操作不当、遗忘或泄露密码、密码被他人破解、用户使用的计算机系统被第三方侵入、用户向大雅乐盟发送的指令信息不明确或存在歧义、用户下载非法或不明程序、用户委托他人代理交易时他人恶意或不当操作而造成的损失;<br/>
-        1.5 信息网络设备连接故障,电脑、通讯或其他系统出现故障,不能进行数据传输、保存的;<br/>
-        1.6 本软件或其服务器停机维护期间;<br/>
-        1.7 不可抗力因素导致的任何损失;<br/>
-        1.8 大雅乐盟依据本协议约定终止协议时。<br/>
-        3. 用户理解并同意,因大雅乐盟过错导致用户不能享受相应服务,大雅乐盟承担相应责任的最高限额不超过用户实际支付的当次服务费用总额。<br/>
-        4. 大雅乐盟努力保障用户的知情权,如主动中断或终止部分或全部网络服务,应提前90日在大雅乐盟服务平台以公告通知、app推送等方式通知。<br/>
-         
-        <h2>十一、隐私权保护政策</h2>
-        用户及用户的监护人同意,大雅乐盟向用户提供本服务时,会收集、使用必要的用户个人信息,包括但不限于用户姓名、性别、年龄、学校、班级、联系方式、用户监护人的姓名及联系方式等,并将收集到的信息用于提供本服务必需的目的和场景。大雅乐盟不会收集与提供本服务无关的用户个人信息,具体隐私权保护政策详见大雅乐盟或本软件公示的《隐私政策》。<br/>
-         
-        <h2>十二、争议解决及适用法律</h2>
-        1. 本协议及其修订的有效性、履行、解释及争议解决,均适用中华人民共和国大陆地区法律。<br/>
-        2. 用户与大雅乐盟之间就本协议发生的任何纠纷或争议,首先应友好协商解决,协商不成的,应将纠纷或争议提交至大雅乐盟所在地有管辖权的法院管辖。<br/>
-
-        <h2>十三、其他</h2>
-        1. 如本协议中的任何条款无论因何种原因导致全部或部分无效或不具有执行力的,则该条款应视为自始不存在且不影响本协议其他条款的效力,此时该条款可被新的条款所取代,以保证最大限度地接近双方意图、确保本协议要求的经济目的,以及实现原有条款的意图。<br/>
-        2. 本协议中的标题仅为方便而设,本身并无实际涵义,不能作为本协议涵义解释的依据。<br/>
-        3. 如用户对本软件、本服务或本协议内容有任何疑问、意见或建议,用户可联系大雅乐盟,联系电话:{{proto}},大雅乐盟将及时回复用户的请求。<br/>
-
-    </div>
+<body>
+<div class="container">
+<h1>《APP用户注册及乐团注册服务协议》</h1>
+<p>欢迎用户使用{{proto}}(下称“本软件”),请用户在使用本软件前仔细阅读本协议。如用户不同意本协议任何条款,请勿在本软件注册账号或使用大雅乐盟基于本软件提供的服务(下称“本服务”)。用户点击“注册”、“登录”或“同意”等按钮或使用本服务后,本协议即构成大雅乐盟与用户之间具有约束力的法律文件。</p>
+<h2>一、提示</h2>
+<p>1. 用户在使用本软件或本服务前,应当认真阅读本协议。请用户务必审慎阅读、充分理解各条款内容,特别是免除或者限制责任的条款、法律适用和争议解决条款。免除或者限制责任的条款将以粗体下划线标识,用户应重点阅读,并自行选择接受或不接受。如用户对本协议有任何疑问,可联系大雅乐盟。</p>
+<p>2. 当用户按照注册页面提示填写信息、阅读并同意本协议且完成全部注册程序,或登录本软件,或使用本服务后,即表示用户已充分阅读、理解并接受本协议的全部内容,并与大雅乐盟达成一致,成为大雅乐盟的用户。阅读本协议的过程中,如果用户不同意或不接受本协议任何条款,用户应立即停止注册、登录本软件或使用本服务。</p>
+<p>3. 大雅乐盟可以随时更新本协议的各项条款,包括但不限于增加新的服务类型或功能,更新后的协议条款一经大雅乐盟在本软件公布或更新即生效并代替原来的协议条款,大雅乐盟不会另行通知用户,用户可以及时关注并阅读大雅乐盟更新的本协议最新版本;用户继续使用本软件或本服务的,视为用户接受本协议的最新更新版本;用户不接受本协议最新版本的,应立即停止使用本软件或本服务。</p>
+<p>4. 特别提醒:未满18周岁的用户应在法定监护人的陪同下阅读后,并且应在法定监护人的同意和指导下注册和/或使用本软件及本服务。
+<h2>二、关于本软件及本服务的重要提示</h2>
+<p>1. 用户使用本服务需要下载本软件的客户端版本,本软件的客户端版本提供包括但不限于 iOS、Android等多个应用版本,用户必须选择与所安装终端设备相匹配的软件版本。 用户可以直接从大雅乐盟的网站上获取本软件,也可以从得到大雅乐盟授权的第三方获取。如果用户从未经大雅乐盟授权的第三方获取本软件或与本软件名称相同的安装程序,大雅乐盟无法保证该软件能够正常使用,并对因此给用户造成的损失不予负责。下载安装程序后,用户需要按照该程序提示的步骤正确安装。</p>
+<p>2. 为了改善用户体验、完善服务内容,大雅乐盟将不断努力开发新的服务,并为用户不时提供软件更新(这些更新可能会采取软件替换、修改、功能强化、版本升级等形式)。大雅乐盟有权不经向用户特别通知而对本软件进行更新,或者对本软件的部分功能效果进行改变或限制。新版本发布后,旧版本的软件可能无法使用。大雅乐盟无法保证旧版本软件继续可用及相应的客户服务,请用户随时核对并下载最新版本。</p>
+<p>3. 用户理解并同意:为了向用户提供有效的服务,本软件会利用用户终端设备的处理器和带宽等资源,用户使用本软件时,需要接入互联网、移动互联网,此时可能产生数据流量的费用,用户需自行向运营商了解相关资费信息,并自行承担接入互联网、移动互联网所需的费用(包括但不限于上网费、通讯费)以及使用本软件及本服务必需的设备(包括但不限于电脑、手机等移动终端设备)。</p>
+<p>4. 大雅乐盟给予用户一项个人的、不可转让及非排他性的许可,以使用本软件。用户可以为非商业目的在单一台终端设备上安装、使用、显示、运行本软件。用户不得为商业运营目的安装、使用、运行本软件,不可以对该软件或者该软件运行过程中释放到任何计算机终端内存中的数据及该软件运行过程中客户端与服务器端的交互数据进行复制、更改、修改、挂接运行或创作任何衍生作品,形式包括但不限于使用插件、外挂或非经授权的第三方工具/服务接入本软件和相关系统。</p>
+<p>5. 本协议其他条款未明示授权的其他一切权利仍由大雅乐盟保留,用户在行使这些权利时须另外取得大雅乐盟的书面许可。大雅乐盟如果未行使前述任何权利,并不构成对该权利的放弃。
+<h2>三、服务内容</h2> 
+<p>1. 大雅乐盟:即{{proto}}。</p>
+<p>2. 本服务是基于互联网及移动互联网,通过本软件向用户提供【直播教学、录播教学、智能打分、学员管理等】功能服务。大雅乐盟以乐团为单位对用户进行管理,用户注册本软件即视为用户同意参加乐团,遵守乐团的各项制度和管理。用户在使用本软件或本服务过程中发生任何问题的,可以与大雅乐盟乐团老师联系和处理。具体内容及具体规则以用户与大雅乐盟签署的协议及/或本软件公示的内容为准。</p>
+<p>3. 服务功能介绍:</p>
+<p>直播教学:{{proto}}</p>
+<p>录播教学:{{proto}}</p>
+<p>智能打分:{{proto}}</p>
+<p>学员管理:{{proto}}</p>
+<p>4. 本软件规则包括但不限于大雅乐盟通过官网、本软件等途径发布的全部规则、细则、解读、说明公告等。</p>
+<p>5. 服务费用</p>
+<p>5.1 用户使用本软件或本服务的费用以用户与大雅乐盟签署的协议及/或本软件公示的内容为准。</p>
+<p>6. 乐团管理</p>
+<p>6.1大雅乐盟有权对用户进行管理,制定乐团各项制度,对用户在乐团的日常行为进行管理。</p>
+<h2>四、用户账户注册、使用与管理</h2>  
+<p>1. 用户资格</p>
+<p>用户开始使用本软件或本服务前,应当具备中华人民共和国法律规定的与用户行为相对应的民事行为能力,否则用户的法定监护人应依照法律规定承担因此而导致的一切后果。</p>
+<p>2. 账户说明</p>
+<p>用户使用本软件时,应当注册账户,注册时可以使用{{proto}},用户应当提供并填写真实、合法、准确、完整的资料和信息,并在相关信息变更时在1个工作日内在本软件更新。因用户提供或填写的资料、信息不符合上述要求而导致的任何问题及后果,应由用户自行承担,大雅乐盟不对此承担任何责任。当用户按照注册页面提示填写信息、阅读并同意本协议且完成全部注册程序后,用户可获得本软件账户并成为本软件用户。</p>
+<p>3. 账户安全规范</p>
+<p>3.1 用户的账户由用户自行设置、保管。建议用户务必保管好用户的账户及密码,当用户每次使用完本软件时,应以正确步骤离开本软件。用户了解并同意,确保用户账户及密码的机密安全是用户的责任。用户将对利用该账户及密码所进行的一切行动及言论负完全的责任,并同意以下事项:</p>
+<p>3.1.1 用户主动泄露账户、密码或遭受他人攻击、诈骗等行为导致的损失及后果,均由用户自行承担;</p>
+<p>3.1.2 用户的账户只限用户本人使用,未经大雅乐盟事先书面同意,不得将账户提供、转让、许可、出售给任何第三方;</p>
+<p>3.1.3 擅自使用他人账户及密码的,大雅乐盟及其合法授权主体有权追究实际使用人的法律责任;</p>
+<p>3.1.4 用户应当设置符合本软件要求的密码,并妥善保管和保护密码,不得随意告诉他人,并定期更新密码。大雅乐盟同时还建议用户通过使用复杂密码等方式,不要使用过于简单的词语或数字,以保证用户的账号、密码安全;</p>
+<p>3.1.5 如发现任何未经授权使用用户账户访问和/或使用本软件或其他可能导致用户账户遭窃、遗失的情况,建议用户立即通知大雅乐盟。</p>
+<p>3.2 大雅乐盟有权基于单方独立判断,在其认为可能发生危害交易安全等情形时,不经通知而先行暂停、中断或终止向用户提供本协议项下的全部或部分用户服务,并将注册资料移除或删除,且无需对用户或任何第三方承担任何责任。前述情形包括但不限于:</p>
+<p>3.2.1 大雅乐盟发现异常交易或有理由认为存在违法违规情形时;</p>
+<p>3.2.2 大雅乐盟认为用户账户被冒用或其他大雅乐盟认为有风险的其他情形。</p>
+<p>4. 用户忘记或丢失账户、密码时,可以按照本软件的申诉途径凭初始注册资料找回账户,但大雅乐盟并不承诺用户忘记或丢失账户后一定能通过申诉途径找回该账户。本软件的账户或密码找回/重设机制仅负责识别用户在申诉申请上所填资料与系统记录资料的一致性,而无法识别申诉人是否系真正账户使用权人。用户因忘记或丢失账户或密码而遭致任何法律责任或损失的,用户应自行承担全部法律责任及损失,大雅乐盟不对此承担任何责任。</p>
+<p>5. 用户理解并同意,本软件同大多数互联网软件一样,可能会受多种因素影响,包括但不限于用户原因、网络服务质量、社会环境等;也可能会受各种安全问题的侵扰,包括但不限于他人非法利用用户资料,进行现实中的骚扰;用户下载安装的其他软件或访问的其他网站中可能含有病毒、木马程序或其他恶意程序,威胁用户的终端设备信息和数据安全,继而影响本软件的正常使用等。因此,用户应加强信息安全及个人信息的保护意识,注意密码保护,以免遭受损失。</p>
+<h2>五、服务使用规则</h2>
+<p>1. 用户使用本软件或本服务时,不得实施下列行为:</p>
+<p>1.1使用本软件或本服务的过程中出现下列情形:</p>
+<p>1.1.1破坏宪法所确定的基本原则的;</p>
+<p>1.1.2危害国家安全、泄露国家秘密、颠覆国家政权、破坏国家统一的;</p>
+<p>1.1.3损害国家荣誉和利益的;</p>
+<p>1.1.4煽动民族仇恨、民族歧视,破坏民族团结的;</p>
+<p>1.1.5破坏国家宗教政策,宣扬邪教和封建迷信的;</p>
+<p>1.1.6散布谣言,扰乱社会秩序,破坏社会稳定的;</p>
+<p>1.1.7散布淫秽、色情、赌博、暴力、凶杀、恐怖或者教唆犯罪的;</p>
+<p>1.1.8侮辱或者诽谤他人,侵害他人合法权益的;</p>
+<p>1.1.9含有法律法规、行政规章所禁止的其他内容的;</p>
+<p>1.2 发布、传送、传播、储存侵害他人合法权利(包括但不限于名誉权、肖像权、知识产权、商业秘密等)的内容;</p>
+<p>1.3 发布、传送、传播、储存与他人隐私、个人信息或资料有关的内容;</p>
+<p>1.4 发布、传送、传播虚假、骚扰、营销、广告、诱导分享等相关的内容;</p>
+<p>1.5 违反法律法规或干扰、破坏大雅乐盟、本软件的正常运营的其他内容。</p>
+<p>2. 未经大雅乐盟事先书面同意,用户使用本软件时不得有下列行为:</p>
+<p>2.1 以创建相同、类似或竞争服务为目的访问本软件或使用本服务;</p>
+<p>2.2 删除、遮掩、修改本软件及其副本上关于著作权的声明;</p>
+<p>2.3 对本软件或本服务(包括但不限于服务或其内容中的广告或赞助内容)进行任何形式的许可、出售、租赁、转让、发行或做其他商业用途;</p>
+<p>2.4 通过修改或伪造软件运行中的指令、数据,或者增加、删减、变动软件的功能或运行效果,或者将用于上述用途的软件、方法进行运营或向公众传播,无论是否基于商业目的;</p>
+<p>2.5 通过非大雅乐盟开发、授权的第三方软件、插件、外挂、系统,登录或使用本软件或本服务;</p>
+<p>2.6 自行或者授权他人、第三方软件对本软件及其组件、模块、数据进行干扰,或在本软件或利用本服务上传或发布病毒、蠕虫、恶意代码、故意破坏或改变系统或数据的软件;</p>
+<p>2.7 其他未经大雅乐盟明示授权的行为。</p>
+<p>3. 用户内容是指用户上传、提供信息和资料或以其他方式使用本软件与本服务时产生的所有内容(包括但不限于用户信息、资料、图片或其他内容),用户是用户内容的唯一的责任人,应当承担因用户内容披露而导致的用户或任何第三方被识别的风险。</p>
+<p>4. 用户充分了解并同意,用户必须为自己注册账号下的一切行为负责,包括用户所发表的任何内容以及由此产生的任何后果。用户应对本服务中的内容自行加以判断,并承担因使用内容而引起的所有风险,包括因对内容的正确性、完整性或实用性的依赖而产生的风险。大雅乐盟无法且不会对因前述风险而导致的任何损失或损害承担责任。</p>
+<p>5. 用户应服从大雅乐盟乐团的管理,用户在乐团出现下列情形的,大雅乐盟有权对用户作出警告,用户收到警告后仍然不遵守大雅乐盟的管理制度的,大雅乐盟有权对用户作出退团等处分:</p>
+<p>5.1上课、排练时不遵守纪律,影响乐团其他团员的正常上课、排练;</p>
+<p>5.2不服从乐团老师的管理和指导;</p>
+<p>5.3一个学期内发生两次及以上缺席乐团上课、排练行为;</p>
+<p>5.4一个学期内发生两次及以上未按老师要求回传视频作业的情形;</p>
+<p>5.5连续{{proto}}天不练习,影响乐团团员和乐团的整体水平的。</p>
+<p>6. 用户在每次参加乐团排练、训练时,应按专业老师要求带齐训练所需乐器、教材乐谱、乐谱本、铅笔及乐器护理等学习用品,并提前10分钟到达排练场地,做好准备工作;始终保持排练、训练场地的清洁卫生;如遇到特殊情况无法参加乐团排练、训练时,应提前一天向乐团老师请假。</p>
+<p>7. 因用户个人原因未能按时上课的,视为该用户放弃该次上课,学校乐团声部训练不因用户请假而停止整个声部课教学,如用户因此给乐团造成任何不良影响的,用户应尽力弥补并消除该不良影响。</p>
+<p>8. 用户应保证每日练习时间不少于20分钟,并按专业老师要求通过本软件回传周视频作业。</p>
+<p>9. 退团:用户如因自身原因拟退出乐团的,应向学校申请退团,并获得学校的同意退团批准,再经用户家长确认后,方可退团。</p>
+<h2>六、第三方链接及服务</h2>
+<p>1. 本软件或本服务可能保留有第三方网站或网址的链接,访问这些链接将由用户自己做出决定,大雅乐盟并不就这些链接上所提供的任何信息、数据、观点、图片、陈述或建议的准确性、完整性、充分性和可靠性提供承诺或保证。大雅乐盟没有审查过任何第三方网站,对这些网站及其内容不进行控制,也不负任何责任。如果用户决定访问任何与本站链接的第三方网站,其可能带来的结果和风险全部由用户自己承担。</p>
+<p>2. 用户在使用本软件中第三方提供的产品或服务时,除遵守本协议约定外,还应遵守第三方的用户协议。大雅乐盟和第三方对可能出现的纠纷在法律规定和约定的范围内各自承担责任。因用户使用本软件或要求大雅乐盟提供特定服务时,本软件可能会调用第三方系统或者通过第三方支持用户的使用或访问,使用或访问的结果由该第三方提供(包括但不限于第三方通过公众账号提供的服务,或通过开放平台接入的内容等),大雅乐盟不保证通过第三方提供服务及内容的安全性、准确性、有效性及其他不确定的风险,由此若引发的任何争议及损害,与大雅乐盟无关,大雅乐盟不承担任何责任。</p>
+<p>3. 用户已知晓并同意大雅乐盟提供本服务(无论是免费服务还是有偿服务)还可能基于第三方如合作单位(包括但不限于电信运营商)提供的技术支持等服务获得。如果因第三方提供的服务给用户增加任何成本或造成任何损失的,大雅乐盟会协助用户与第三方进行沟通和处理,如因此发生维修、更换等费用的,应由用户自行承担,大雅乐盟不对此承担任何法律责任和赔偿责任。</p>
+<h2>七、知识产权的保护以及保密</h2>
+<p>1. 大雅乐盟的商标、商号、Logo、图形及其组合,以及大雅乐盟的其他标识、产品和服务名称均为大雅乐盟或大雅乐盟关联公司所有,未经大雅乐盟书面授权,任何人不得以任何方式展示、使用或作其他处理,也不得向任何第三方表明或让其误认为其有权展示、使用或作其他处理。</p>
+<p>2. 大雅乐盟提供的培训、课程相关的全部内容(包括但不限于培训课程设置、培训课件、教材等)的知识产权均归大雅乐盟单独和完整所有。用户应当保护大雅乐盟的知识产权,只能用于自身学习之目的,未经大雅乐盟事先书面同意,不得擅自将培训课程相关的任何内容进行复制、复印、影音、拍摄或进行摘要等措施后以转让、出售、赠与或其他任何形式提供给任何第三方,否则大雅乐盟有权追究其法律责任。</p>
+<p>3. 大雅乐盟为提供服务而使用的任何软件(包括但不限于软件中所含的任何图象、照片、动画、录像、录音、音乐、文字和附加程序、随附的帮助材料)的一切权利均属于该软件的著作权人,未经该软件的著作权人许可,用户不得对该软件进行反向工程(reverse engineer)、反向编译(decompile)或反汇编(disassemble)。</p>
+<p>4. 用户已经了解并同意:在大雅乐盟提供的所有服务器上的数据(包括但不限于虚拟物品等)全部归大雅乐盟所有。在不影响用户正常接收服务的情况下,大雅乐盟有权决定保留或不保留服务器上的全部或部分数据。</p>
+<p>5. 用户已经了解并同意:大雅乐盟有权将本协议项下大雅乐盟所有的知识产权授权第三方使用,在变更产品运营商时,大雅乐盟可以将其运营的产品或服务以及与该在产品或服务相关的归大雅乐盟所有的知识产权转让给新的产品运营商。</p>
+<p>6. 用户使用大雅乐盟提供的本软件或本服务期间获取的文件、资料、表格等信息,包括但不限于有关合作资料、营销资料等,无论是口头、书面的或是电子文件形式的,均属大雅乐盟的商业秘密,用户必须对这些商业秘密严格遵守保密义务,不得向外透露,也不得使用这些商业秘密为自己或他人谋取利益。</p>
+<h2>八、违约条款</h2>
+<p>1. 用户违反本协议约定时即构成违约情形,大雅乐盟有权要求用户采取及时的补救措施,消除违约后果,并有权终止本协议。如用户的违约行为使大雅乐盟及/或关联公司遭受损失(包括自身的直接经济损失、商誉损失及对外支付的赔偿金、和解款、律师费、诉讼费等间接经济损失)的,用户应赔偿大雅乐盟及/或关联公司的上述全部损失。</p>
+<p>2. 用户理解并同意,如用户的行为导致第三方向大雅乐盟及/或关联公司主张权利或任何索赔、要求或损失的,大雅乐盟及/或关联公司在对第三人承担赔偿义务后可向用户追偿与此相关的全部损失。</p>
+<h2>九、协议终止</h2>
+<p>1. 用户有权通过以下任一方式终止本协议:</p>
+<p>1.1用户自行注销用户的账户的;</p>
+<p>1.2用户按照本协议约定方式退出乐团的;</p>
+<p>1.3 变更事项生效或服务协议更新时,用户停止使用并明示不愿接受变更事项或明示不愿接受更新后的服务协议的;</p>
+<p>1.4 用户明示不愿继续使用本软件或本服务,且符合本协议终止条件的。</p>
+<p>2. 出现以下情况时,大雅乐盟可以终止本协议:</p>
+<p>2.1 用户违反本协议约定的,大雅乐盟依据违约条款终止本协议,或对用户处以退团处分的;</p>
+<p>2.2 用户的账户被大雅乐盟依据本协议进行注销等清理的;</p>
+<p>2.3 用户在使用本软件或本服务时存在侵犯他人合法权益或其他严重违法违规行为的;</p>
+<p>2.4 不可抗力导致本协议不能履行的(“不可抗力”是指双方不可预见、或可以预见但不能避免并或克服的客观情况,该事件妨碍、影响或延误任何一方根据合同履行其全部或部分义务。该事件包括但不限于政府行为、法律或规定的发布或修订,自然灾害、战争、网络堵塞或中断、黑客袭击或任何其他类似事件),且该不可抗力持续30天以上的;</p>
+<p>2.5 根据相关法律法规规定大雅乐盟应当终止服务或大雅乐盟认为需终止服务的其他情形。</p>
+<p>3. 协议终止后的处理</p>
+<p>本协议终止后,除法律有明确规定外,大雅乐盟无义务向用户或用户指定的第三方披露用户账户中的任何信息。</p>
+<h2>十、责任限制</h2>
+<p>1. 用户使用本软件或本服务的风险应由用户自行承担,大雅乐盟对本软件不作任何类型的担保,不论是明示的、默示的保证和条件,包括但不限于本软件的适销性、适用性、无病毒、无疏忽或无技术瑕疵问题、所有权和无侵权的明示或默示担保和条件,对在任何情况下因使用或不能使用本软件所产生的直接、间接、偶然、特殊及后续的损害及风险,大雅乐盟不承担任何责任。</p>
+<p>2. 用户明确理解和同意,大雅乐盟不对因下述任一情况而导致的损害赔偿承担责任,包括但不限于利润、商誉、使用、数据等方面的损失或其它无形损失的损害赔偿:</p>
+<p>2.1 大雅乐盟向用户免费提供的任何产品或者服务;</p>
+<p>2.2 大雅乐盟向用户赠送的任何产品或者服务;</p>
+<p>2.3 对于用户使用本软件上可能涉及由第三方所有、控制或者运营的网站或平台提供的服务及其导致的风险;</p>
+<p>2.4 因用户的过错导致的任何损失,该过错包括但不限于:决策失误、操作不当、遗忘或泄露密码、密码被他人破解、用户使用的计算机系统被第三方侵入、用户向大雅乐盟发送的指令信息不明确或存在歧义、用户下载非法或不明程序、用户委托他人代理交易时他人恶意或不当操作而造成的损失;</p>
+<p>2.5 信息网络设备连接故障,电脑、通讯或其他系统出现故障,不能进行数据传输、保存的;</p>
+<p>2.6 本软件或其服务器停机维护期间;</p>
+<p>2.7 不可抗力因素导致的任何损失;</p>
+<p>2.8 大雅乐盟依据本协议约定终止协议时。</p>
+<p>3. 用户理解并同意,因大雅乐盟过错导致用户不能享受相应服务,大雅乐盟承担相应责任的最高限额不超过用户实际支付的当次服务费用总额。</p>
+<p>4. 大雅乐盟努力保障用户的知情权,如主动中断或终止部分或全部网络服务,应提前90日在大雅乐盟服务平台以公告通知、app推送等方式通知。</p>
+<h2>十一、隐私权保护政策</h2>
+<p>用户及用户的监护人同意,大雅乐盟向用户提供本服务时,会收集、使用必要的用户个人信息,包括但不限于用户姓名、性别、年龄、学校、班级、联系方式、用户监护人的姓名及联系方式等,并将收集到的信息用于提供本服务必需的目的和场景。大雅乐盟不会收集与提供本服务无关的用户个人信息,具体隐私权保护政策详见大雅乐盟或本软件公示的《隐私政策》。</p>
+<h2>十二、争议解决及适用法律</h2>
+<p>1. 本协议及其修订的有效性、履行、解释及争议解决,均适用中华人民共和国大陆地区法律。</p>
+<p>2. 用户与大雅乐盟之间就本协议发生的任何纠纷或争议,首先应友好协商解决,协商不成的,应将纠纷或争议提交至大雅乐盟所在地有管辖权的法院管辖。</p>
+<h2>十三、其他</h2>
+<p>1. 如本协议中的任何条款无论因何种原因导致全部或部分无效或不具有执行力的,则该条款应视为自始不存在且不影响本协议其他条款的效力,此时该条款可被新的条款所取代,以保证最大限度地接近双方意图、确保本协议要求的经济目的,以及实现原有条款的意图。</p>
+<p>2. 本协议中的标题仅为方便而设,本身并无实际涵义,不能作为本协议涵义解释的依据。</p>
+<p>3. 如用户对本软件、本服务或本协议内容有任何疑问、意见或建议,用户可联系大雅乐盟,联系电话:{{proto}},大雅乐盟将及时回复用户的请求。</p>
+</div>
 </body>
 </html>

+ 61 - 7
mec-biz/src/main/resources/config/mybatis/CourseScheduleMapper.xml

@@ -32,7 +32,6 @@
         <result column="sign_out_status_" property="signOutStatus"/>
         <result column="seal_class_id_" property="sealClassId"/>
         <result column="teach_mode_" property="teachMode" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
-        <result column="paran_value_" property="vipAppealDaysRange"/>
     </resultMap>
 
     <resultMap type="com.ym.mec.biz.dal.entity.StudentCourseScheduleRecordDto" id="studentCourseScheduleRecord">
@@ -230,14 +229,40 @@
 
     <select id="getCourseSchedulesWithDate" resultMap="courseScheduleDto">
         SELECT
-            cg.*,
+            cg.id_ seal_class_id_,
+            cs.name_,
             cs.type_,
+            cs.id_,
             cs.class_date_,
-            cs.start_class_time_
+            CONCAT(cs.class_date_,' ',cs.start_class_time_) start_class_time_,
+            CONCAT(cs.class_date_,' ',cs.end_class_time_) end_class_time_,
+            cs.status_,
+	        su.username_ teacher_name_,
+	        ta.status_ attendance_status_
         FROM
-            course_schedule cs
-        LEFT JOIN class_group cg ON cs.class_group_id_=cg.id_
-        WHERE cs.class_date_=DATE_FORMAT(#{classDate},'%Y%m%d')
+            music_group mg
+            LEFT JOIN class_group cg ON mg.id_ = cg.music_group_id_
+            LEFT JOIN course_schedule cs ON cg.id_ = cs.class_group_id_
+            LEFT JOIN sys_user su ON cs.teacher_id_=su.id_
+	        LEFT JOIN teacher_attendance ta ON cs.id_=ta.class_group_id_ AND ta.teacher_id_=cs.teacher_id_
+        WHERE
+            mg.organ_id_ = #{organId}
+            AND cs.id_ IS NOT NULL
+            AND cs.class_date_ = DATE_FORMAT(#{classDate},'%Y%m%d')
+        <include refid="global.limit"/>
+    </select>
+
+    <select id="countCourseSchedulesWithDate" resultType="int">
+        SELECT
+        count(*)
+        FROM
+        music_group mg
+        LEFT JOIN class_group cg ON mg.id_ = cg.music_group_id_
+        LEFT JOIN course_schedule cs ON cg.id_ = cs.class_group_id_
+        WHERE
+        mg.organ_id_ = #{organId}
+        AND cs.id_ IS NOT NULL
+        AND cs.class_date_ = DATE_FORMAT(#{classDate},'%Y%m%d')
     </select>
 
     <select id="getStudentCourseSchedulesWithDate" resultMap="courseScheduleDto">
@@ -275,7 +300,7 @@
 	        s.name_ school_name_,
 	        cg.teach_mode_,
 	        ta.sign_in_status_ sign_in_status_,
-	        ta.sign_out_status_ sign_out_status_,
+	        ta.sign_out_status_ sign_out_status_
         FROM
             course_schedule cs
             LEFT JOIN sys_user su ON cs.teacher_id_=su.id_
@@ -421,6 +446,26 @@
         GROUP BY
         cs.class_date_
     </select>
+
+    <select id="getCourseScheduleDate" resultType="java.util.Date">
+        SELECT
+            cs.class_date_
+        FROM
+            music_group mg
+            LEFT JOIN class_group cg ON mg.id_ = cg.music_group_id_
+            LEFT JOIN course_schedule cs ON cg.id_ = cs.class_group_id_
+        WHERE
+            mg.organ_id_ = 1 AND cs.id_ IS NOT NULL
+            <if test="month==null">
+                AND DATE_FORMAT( NOW(), '%Y%m' ) = DATE_FORMAT( cs.class_date_, '%Y%m' )
+            </if>
+            <if test="month!=null">
+                AND DATE_FORMAT( #{month}, '%Y%m' ) = DATE_FORMAT( cs.class_date_, '%Y%m' )
+            </if>
+        GROUP BY
+            cs.class_date_
+    </select>
+
     <select id="findClassSubjects" resultType="string">
         SELECT
             CONCAT(cg.id_,'-',IF(GROUP_CONCAT(s.name_) IS NULL,'',GROUP_CONCAT(s.name_)))
@@ -526,4 +571,13 @@
         WHERE
             cs.id_=#{courseScheduleId}
     </select>
+
+    <select id="findStudentNamesByCourseSchedule" resultType="string">
+        SELECT
+            su.username_
+        FROM
+            student_attendance sa
+            LEFT JOIN sys_user su ON sa.user_id_=su.id_
+            WHERE sa.course_schedule_id_=#{courseScheduleId}
+    </select>
 </mapper>

+ 42 - 1
mec-biz/src/main/resources/config/mybatis/CourseScheduleTeacherSalaryMapper.xml

@@ -9,7 +9,7 @@
 	<resultMap type="com.ym.mec.biz.dal.entity.CourseScheduleTeacherSalary" id="CourseScheduleTeacherSalary">
 		<result column="id_" property="id" />
 		<result column="course_schedule_id_" property="courseScheduleId" />
-		<result column="teacher_role_" property="teacherRole" />
+		<result column="teacher_role_" property="teacherRole" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
 		<result column="user_id_" property="userId" />
 		<result column="expect_salary_" property="expectSalary" />
 		<result column="create_time_" property="createTime" />
@@ -96,4 +96,45 @@ create_time_ = #{createTime},
 	<select id="queryCount" resultType="int">
 		SELECT COUNT(*) FROM course_schedule_teacher_salary
 	</select>
+
+	<resultMap id="VipGroupSalaryDto" type="com.ym.mec.biz.dal.dto.VipGroupSalaryDto" extends="CourseScheduleTeacherSalary">
+		<result column="course_schedule_id_" property="courseScheduleId" />
+		<result column="class_date_" property="classDate" />
+		<result column="teach_mode_" property="teachMode" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler" />
+	</resultMap>
+
+	<sql id="vipGroupSalaryQueryCondition">
+		<where>
+			vg.id_=#{vipGroupId} AND FIND_IN_SET(#{organId},vg.organ_id_list_)
+			<if test="startTime!=null and endTime!=null">
+				AND (cs.class_date_ BETWEEN #{startTime} AND #{endTime})
+			</if>
+		</where>
+	</sql>
+
+	<select id="findVipGroupSalarys" resultMap="VipGroupSalaryDto">
+		SELECT
+
+			cs.id_ course_schedule_id_,
+			CONCAT(cs.class_date_," ",cs.start_class_time_) class_date_,
+			cs.teach_mode_,
+			csts.*
+		FROM
+			vip_group vg
+			LEFT JOIN vip_group_class_group_mapper vgcgm ON vg.id_ = vgcgm.vip_group_id_
+			LEFT JOIN course_schedule cs ON vgcgm.class_group_id_ = cs.class_group_id_
+			LEFT JOIN course_schedule_teacher_salary csts ON cs.id_ = csts.course_schedule_id_
+			<include refid="vipGroupSalaryQueryCondition"/>
+		ORDER BY id_
+		<include refid="global.limit"/>
+	</select>
+	<select id="countVipGroupSalarys" resultType="int">
+		SELECT
+			COUNT(*)
+		FROM
+			vip_group vg
+			LEFT JOIN vip_group_class_group_mapper vgcgm ON vg.id_ = vgcgm.vip_group_id_
+			LEFT JOIN course_schedule cs ON vgcgm.class_group_id_ = cs.class_group_id_
+		<include refid="vipGroupSalaryQueryCondition"/>
+	</select>
 </mapper>

+ 1 - 1
mec-biz/src/main/resources/config/mybatis/DemoGroupMapper.xml

@@ -159,7 +159,7 @@ create_time_ = #{createTime},
 				AND dgcp.start_time_=#{startTime}
 			</if>
 			<if test="startTime!=null and endTime!=null">
-				AND dgcp.start_time_&gt;=#{startTime} AND dgcp.start_time_ &lt;= #{endTime}
+				AND (CONCAT(dgcp.course_date_,' ',dgcp.start_time_) BETWEEN #{startTime} AND #{endTime})
 			</if>
 		</where>
 	</sql>

+ 6 - 2
mec-biz/src/main/resources/config/mybatis/MusicGroupStudentFeeMapper.xml

@@ -10,6 +10,7 @@
         <result column="id_" property="id"/>
         <result column="music_group_id_" property="musicGroupId"/>
         <result column="user_id_" property="userId"/>
+        <result column="subject_id_" property="subjectId"/>
         <result column="course_fee_" property="courseFee"/>
         <result column="next_payment_date_" property="nextPaymentDate"/>
         <result column="latest_paid_time_" property="latestPaidTime"/>
@@ -31,8 +32,8 @@
     <!-- 向数据库增加一条记录 -->
     <insert id="insert" parameterType="com.ym.mec.biz.dal.entity.MusicGroupStudentFee" useGeneratedKeys="true"
             keyColumn="id" keyProperty="id">
-		INSERT INTO music_group_student_fee_ (id_,music_group_id_,user_id_,course_fee_,create_time_,update_time_,next_payment_date_,latest_paid_time_,continuous_absenteeism_times_)
-		VALUES(#{id},#{musicGroupId},#{userId},#{courseFee},now(),now(),#{nextPaymentDate},#{latestPaidTime},#{continuousAbsenteeismTimes})
+		INSERT INTO music_group_student_fee_ (id_,music_group_id_,user_id_,course_fee_,create_time_,update_time_,next_payment_date_,latest_paid_time_,continuous_absenteeism_times_,subject_id_)
+		VALUES(#{id},#{musicGroupId},#{userId},#{courseFee},now(),now(),#{nextPaymentDate},#{latestPaidTime},#{continuousAbsenteeismTimes},#{subjectId})
 	</insert>
 
     <!-- 根据主键查询一条记录 -->
@@ -42,6 +43,9 @@
             <if test="userId != null">
                 user_id_ = #{userId},
             </if>
+            <if test="subjectId != null">
+                subject_id_ = #{subjectId},
+            </if>
             <if test="updateTime != null">
                 update_time_ = #{updateTime},
             </if>

+ 4 - 0
mec-biz/src/main/resources/config/mybatis/StudentRegistrationMapper.xml

@@ -252,4 +252,8 @@
     <select id="queryStudentInfo" resultMap="StudentInfo">
         SELECT u.*,sr.name_,sr.current_class_,sr.current_grade_,sr.actual_subject_id_ FROM sys_user u left join student_registration  sr on u.id_ = sr.user_id_ where u.id_ = #{userId} order by sr.create_time_ desc limit 0,1
     </select>
+    
+    <select id="queryByUserIdAndMusicGroupId" resultMap="StudentRegistration" parameterType="map">
+    	select * from student_registration where music_group_id_ = #{musicGroupId} and user_id_ = #{userId}
+    </select>
 </mapper>

+ 45 - 9
mec-biz/src/main/resources/config/mybatis/VipGroupMapper.xml

@@ -22,6 +22,7 @@
         <result column="audit_status_" property="auditStatus" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
         <result column="organ_id_list_" property="organIdList"/>
         <result column="vip_group_activity_id_" property="vipGroupActivityId"/>
+        <result column="vip_group_activity_name_" property="vipGroupActivityName"/>
         <result column="status_" property="status" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
         <result column="online_classes_unit_price_" property="onlineClassesUnitPrice"/>
         <result column="offline_classes_unit_price_" property="offlineClassesUnitPrice"/>
@@ -38,11 +39,14 @@
 
     <resultMap id="vipGroupManageDetailDto" type="com.ym.mec.biz.dal.dto.VipGroupManageDetailDto" extends="VipGroup">
         <result property="studentNum" column="student_num_"/>
+        <result property="subjectIdList" column="subject_id_list_"/>
         <result property="latestClassTime" column="current_class_times_"/>
-        <collection property="students" ofType="com.ym.mec.auth.api.entity.SysUser" column="user_id_">
-            <result property="id" column="user_id_"/>
-            <result property="username" column="username_"/>
-        </collection>
+        <result property="categoryName" column="category_name_"/>
+        <result column="teacher_school_name_" property="teacherSchoolName"/>
+        <!--<collection property="students" ofType="com.ym.mec.auth.api.entity.SysUser" column="student_id_">-->
+            <!--<result property="id" column="student_id_"/>-->
+            <!--<result property="username" column="username_"/>-->
+        <!--</collection>-->
     </resultMap>
 
     <resultMap id="studentVipGroupDetailDto" type="com.ym.mec.biz.dal.dto.StudentVipGroupDetailDto" extends="studentVipGroup">
@@ -103,6 +107,7 @@
     <select id="findAllByOrgan" resultMap="VipGroup">
 		SELECT
             vg.*,
+            vga.name_ vip_group_activity_name_,
             su.username_,
             cg.student_num_,
             cg.total_class_times_,
@@ -112,6 +117,7 @@
             LEFT JOIN sys_user su ON vg.user_id_=su.id_
             LEFT JOIN vip_group_class_group_mapper vgcgm ON vg.id_=vgcgm.vip_group_id_
             LEFT JOIN class_group cg ON vgcgm.class_group_id_=cg.id_
+            LEFT JOIN vip_group_activity vga ON vg.vip_group_activity_id_=vga.id_
         <include refid="vipGroupQueryCondition"/>
         ORDER BY vg.id_
         <include refid="global.limit"/>
@@ -273,17 +279,23 @@
     <select id="getVipGroupBaseInfo" resultMap="vipGroupManageDetailDto">
         SELECT
             vg.*,
+            vga.name_ vip_group_activity_name_,
+            su.username_,
             cg.student_num_,
+            cg.subject_id_list_,
+            cg.total_class_times_,
             cg.current_class_times_,
-            su.*
+            vgc.name_ category_name_,
+            s.name_ teacher_school_name_
         FROM
             vip_group vg
+            LEFT JOIN sys_user su ON vg.user_id_=su.id_
             LEFT JOIN vip_group_class_group_mapper vgcgm ON vg.id_=vgcgm.vip_group_id_
             LEFT JOIN class_group cg ON vgcgm.class_group_id_=cg.id_
-            LEFT JOIN class_group_student_mapper cgsm ON vgcgm.class_group_id_=cgsm.class_group_id_
-            LEFT JOIN sys_user su ON cgsm.user_id_=su.id_
-        WHERE vg.id_=1
-        ORDER BY vg.id_ DESC
+            LEFT JOIN vip_group_activity vga ON vg.vip_group_activity_id_=vga.id_
+            LEFT JOIN vip_group_category vgc ON vg.vip_group_category_id_=vgc.id_
+            LEFT JOIN school s ON vg.teacher_school_id_=s.id_
+        WHERE vg.id_=#{vipGroupId}
     </select>
 
     <sql id="vipGroupAttendanceQueryCondition">
@@ -396,6 +408,8 @@
         <result column="status_" property="status" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
         <result column="teach_mode_" property="teachMode" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
         <result column="give_teach_mode_" property="giveTeachMode" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
+        <result column="is_salary_" property="isSalary" typeHandler="com.ym.mec.common.dal.CustomEnumTypeHandler"/>
+        <result column="student_num_" property="attendanceNum"/>
     </resultMap>
 
     <sql id="teachingRecordQueryCondition">
@@ -419,6 +433,7 @@
             CONCAT(cs.class_date_,' ',cs.start_class_time_) start_class_time_,
             cs.status_,
             cs.teach_mode_,
+            cs.student_num_,
             csts.actual_salary_ IS NOT NULL is_salary_
         FROM
             vip_group_class_group_mapper vgcgm
@@ -465,4 +480,25 @@
         WHERE vgcgm.vip_group_id_=#{vipGroupId} AND csc.course_schedule_id_ IS NOT NULL
 
     </select>
+    <select id="getVipGroupSalaryInfo" resultType="com.ym.mec.biz.dal.dto.VipGroupSalaryBaseInfo">
+        SELECT
+             SUM(csts.expect_salary_) expectTotalSalary,
+             SUM(csts.actual_salary_) totalSalary
+        FROM
+            vip_group vg
+            LEFT JOIN vip_group_class_group_mapper vgcgm ON vg.id_=vgcgm.vip_group_id_
+            LEFT JOIN course_schedule cs ON vgcgm.class_group_id_=cs.class_group_id_
+            LEFT JOIN course_schedule_teacher_salary csts ON cs.id_=csts.course_schedule_id_
+        WHERE vg.id_=#{vipGroupId} AND cs.id_!=NULL AND csts.settlement_time_!=NULL
+    </select>
+    <select id="countVipGroupDeductionNum" resultType="int">
+        SELECT
+             COUNT(csts.id_)
+        FROM
+            vip_group vg
+            LEFT JOIN vip_group_class_group_mapper vgcgm ON vg.id_=vgcgm.vip_group_id_
+            LEFT JOIN course_schedule cs ON vgcgm.class_group_id_=cs.class_group_id_
+            LEFT JOIN course_schedule_teacher_salary csts ON cs.id_=csts.course_schedule_id_
+        WHERE vg.id_=#{vipGroupId} AND cs.id_!=NULL AND csts.settlement_time_!=NULL AND csts.actual_salary_&lt;csts.expect_salary_
+    </select>
 </mapper>

+ 3 - 1
mec-education/src/main/java/com/ym/mec/education/EducationApplication.java

@@ -5,6 +5,7 @@ import org.springframework.boot.SpringApplication;
 import org.springframework.boot.autoconfigure.SpringBootApplication;
 import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
 import org.springframework.cloud.client.loadbalancer.LoadBalanced;
+import org.springframework.cloud.openfeign.EnableFeignClients;
 import org.springframework.context.annotation.Bean;
 import org.springframework.context.annotation.ComponentScan;
 import org.springframework.context.annotation.Configuration;
@@ -12,9 +13,10 @@ import org.springframework.web.client.RestTemplate;
 
 import com.spring4all.swagger.EnableSwagger2Doc;
 
-@MapperScan({"com.ym.mec.education.mapper", "com.ym.mec.biz.dal.dao"})
+@MapperScan({"com.ym.mec.education.mapper", "com.ym.mec.biz.dal.dao","com.ym.mec.biz.config.mybatis"})
 @SpringBootApplication
 @EnableDiscoveryClient
+@EnableFeignClients("com.ym.mec")
 @ComponentScan(basePackages = {"com.ym.mec", "org.snaker"})
 @Configuration
 @EnableSwagger2Doc

+ 42 - 5
mec-education/src/main/java/com/ym/mec/education/controller/CourseScheduleController.java

@@ -1,21 +1,24 @@
 package com.ym.mec.education.controller;
 
+import com.ym.mec.biz.dal.dto.ClassDateAdjustDto;
+import com.ym.mec.biz.dal.page.CourseScheduleQueryInfo;
+import com.ym.mec.biz.service.CourseScheduleService;
 import com.ym.mec.education.base.BaseResponse;
 import com.ym.mec.education.base.PageResponse;
-import com.ym.mec.education.entity.CourseSchedule;
 import com.ym.mec.education.req.ClassGroupReq;
 import com.ym.mec.education.req.CourseScheduleReq;
 import com.ym.mec.education.resp.CourseScheduleResp;
 import com.ym.mec.education.service.ICourseScheduleService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import io.swagger.annotations.ApiParam;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.validation.annotation.Validated;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestBody;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.Date;
+import java.util.Objects;
 
 /**
  * @program: mec
@@ -31,6 +34,8 @@ public class CourseScheduleController {
 
     @Autowired
     private ICourseScheduleService courseScheduleService;
+    @Autowired
+    private CourseScheduleService scheduleService;
 
     @PostMapping("/list")
     @ApiOperation("课表列表")
@@ -57,4 +62,36 @@ public class CourseScheduleController {
         return courseScheduleService.courseInfo(courseScheduleReq);
     }
 
+    @ApiOperation(value = "根据月份获取乐团在该月有课的日期")
+    @GetMapping("/getCourseScheduleDateByMonth")
+    public Object getCourseScheduleDateByMonth(@ApiParam(value = "月份", required = true) @RequestParam Date month) {
+        return BaseResponse.success(scheduleService.getCourseScheduleDates(month));
+    }
+
+    @ApiOperation(value = "根据日期获取当日排课")
+    @GetMapping("/getCourseSchedulesWithDate")
+    public Object getCourseSchedulesWithDate(CourseScheduleQueryInfo queryInfo) {
+        return BaseResponse.success(scheduleService.getCourseSchedulesWithDateByEdu(queryInfo));
+    }
+
+    @ApiOperation(value = "课时调整")
+    @PostMapping(value = "/classStartDateAdjust")
+    public Object classStartDateAdjust(ClassDateAdjustDto classDateAdjustDto){
+        if(Objects.isNull(classDateAdjustDto.getId())){
+            return BaseResponse.errorParam();
+        }
+        scheduleService.classStartDateAdjust(classDateAdjustDto);
+        return BaseResponse.success(null);
+    }
+
+    @ApiOperation(value = "课时交换")
+    @GetMapping(value = "/courseSwap")
+    public Object courseSwap(Long courseScheduleId1,Long courseScheduleId2){
+        if(Objects.isNull(courseScheduleId1)||Objects.isNull(courseScheduleId2)){
+            return BaseResponse.errorParam();
+        }
+        scheduleService.courseSwap(courseScheduleId1,courseScheduleId2);
+        return BaseResponse.success(null);
+    }
+
 }

+ 0 - 38
mec-education/src/main/java/com/ym/mec/education/controller/UserController.java

@@ -1,38 +0,0 @@
-package com.ym.mec.education.controller;
-
-import javax.annotation.Resource;
-
-import com.alibaba.fastjson.JSONObject;
-import com.ym.mec.auth.api.client.SysUserFeignService;
-import com.ym.mec.education.base.BaseResponse;
-import com.ym.mec.education.service.ISubjectService;
-
-import io.swagger.annotations.Api;
-import io.swagger.annotations.ApiOperation;
-
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestBody;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
-
-/**
- * @program: mec
- * @description: 声部
- * @author: xw
- * @create: 2019-10-01 11:25
- */
-@RestController
-@RequestMapping("api/user")
-@Api(tags = "用户")
-public class UserController {
-
-    @Autowired
-    private SysUserFeignService sysUserFeignService;
-
-    @PostMapping("/detail")
-    @ApiOperation("个人明细")
-    public BaseResponse list() {
-        return BaseResponse.success(sysUserFeignService.queryUserInfo());
-    }
-}

+ 2 - 1
mec-education/src/main/java/com/ym/mec/education/service/impl/SysMessageServiceImpl.java

@@ -21,6 +21,7 @@ import org.snaker.engine.access.QueryFilter;
 import org.snaker.engine.entity.Task;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import javax.annotation.Resource;
 import java.util.List;
 import java.util.Objects;
 import java.util.Optional;
@@ -36,7 +37,7 @@ import java.util.Optional;
 @Service("ISysMessageService")
 public class SysMessageServiceImpl extends ServiceImpl<SysMessageMapper, SysMessage> implements ISysMessageService {
 
-    @Autowired
+    @Resource
     private SysUserFeignService userFeign;
     @Autowired
     private IQueryService taskQueryService;

+ 53 - 49
mec-education/src/main/java/com/ym/mec/education/service/impl/TeacherServiceImpl.java

@@ -17,11 +17,11 @@ import com.ym.mec.education.resp.TeacherResp;
 import com.ym.mec.education.resp.VipGroupClassResp;
 import com.ym.mec.education.service.*;
 import com.ym.mec.education.utils.DateUtil;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.util.CollectionUtils;
-import org.springframework.util.StringUtils;
 import java.util.*;
 import java.util.concurrent.atomic.AtomicReference;
 import java.util.stream.Collectors;
@@ -82,60 +82,64 @@ public class TeacherServiceImpl extends ServiceImpl<TeacherMapper, Teacher> impl
     public PageResponse teacherList(TeacherReq req) {
         PageResponse response = new PageResponse();
         QueryWrapper<SysUser> userQueryWrapper = new QueryWrapper<>();
-        List<SysUser> userList = null;
-        if (req != null && StringUtils.isEmpty(req.getName())) {
+        if (Objects.isNull(req.getUserId())) {
+            return PageResponse.errorParam();
+        }
+        Teacher teacher = getById(req.getUserId());
+        if (Objects.isNull(teacher)) {
+            return PageResponse.noDataExists();
+        }
+        if (req != null && StringUtils.isNotBlank(req.getName())) {
             userQueryWrapper.like("real_name_", req.getName());
-            userList = sysUserService.list(userQueryWrapper);
         }
+        List<SysUser> userList = sysUserService.list(userQueryWrapper);
         QueryWrapper<Teacher> queryWrapper = new QueryWrapper<>();
-        List<Integer> userIds = null;
+        List<TeacherResp> teacherRespList = new ArrayList<>();
+        List<Integer> userIds;
+        IPage<Teacher> teacherIPage = new Page<>();
         if (!CollectionUtils.isEmpty(userList)) {
             userIds = userList.stream().map(SysUser::getId).collect(Collectors.toList());
             queryWrapper.in("id_", userIds);
-        }
-
-
-        IPage<Teacher> page = new Page(req.getPageNo() == null ? 1 : req.getPageNo(), req.getPageSize() == null ? 10 : req.getPageSize());
-        IPage<Teacher> teacherIPage = this.page(page, queryWrapper);
-
-        List<Teacher> teacherList = teacherIPage.getRecords();
-        List<TeacherResp> teacherRespList = new ArrayList<>();
-        if (!CollectionUtils.isEmpty(teacherList)) {
-            teacherList.forEach(e -> {
-                TeacherResp teacherResp = new TeacherResp();
-                String ids[] = e.getSubjectId().split(",");
-                List<String> stringB = Arrays.asList(ids);
-                QueryWrapper<Subject> queryWrapperSub = new QueryWrapper<>();
-                queryWrapperSub.in("id_", stringB);
-                List<Subject> subjectList = subjectService.list(queryWrapperSub);
-                if (!CollectionUtils.isEmpty(subjectList)) {
-                    List<String> subName = subjectList.stream().map(Subject::getName).collect(Collectors.toList());
-                    teacherResp.setSubjectName(subName);
-                }
-                teacherResp.setUserId(e.getId());
-                SysUser sysUser = sysUserService.getById(e.getId());
-                if (sysUser != null) {
-                    teacherResp.setAvatar(sysUser.getAvatar());
-                    teacherResp.setName(sysUser.getRealName());
-                }
-                QueryWrapper<ClassGroupTeacherMapper> queryWrapper1 = new QueryWrapper<>();
-                queryWrapper1.eq("user_id_", e.getId());
-                List<ClassGroupTeacherMapper> classGroupTeacherMappers = classGroupTeacherMapperService.list(queryWrapper1);
-                if (!CollectionUtils.isEmpty(classGroupTeacherMappers)) {
-                    List<Integer> classId = classGroupTeacherMappers.stream().map(ClassGroupTeacherMapper::getClassGroupId).collect(Collectors.toList());
-                    QueryWrapper<ClassGroup> groupQueryWrapper = new QueryWrapper<>();
-                    groupQueryWrapper.eq("id_", classId);
-                    List<ClassGroup> classGroups = classGroupService.list(groupQueryWrapper);
-                    if (!CollectionUtils.isEmpty(classGroups)) {
-                        List<String> className = classGroups.stream().map(ClassGroup::getName).collect(Collectors.toList());
-
-                        teacherResp.setClassName(className);
+            Optional.ofNullable(teacher.getOrganId()).ifPresent(organId ->
+                queryWrapper.lambda().eq(Teacher::getOrganId, organId));
+            IPage<Teacher> page = new Page(req.getPageNo() == null ? 1 : req.getPageNo(), req.getPageSize() == null ? 10 : req.getPageSize());
+            teacherIPage = this.page(page, queryWrapper);
+            List<Teacher> teacherList = teacherIPage.getRecords();
+            if (!CollectionUtils.isEmpty(teacherList)) {
+                teacherList.forEach(e -> {
+                    TeacherResp teacherResp = new TeacherResp();
+                    String ids[] = e.getSubjectId().split(",");
+                    List<String> stringB = Arrays.asList(ids);
+                    QueryWrapper<Subject> queryWrapperSub = new QueryWrapper<>();
+                    queryWrapperSub.in("id_", stringB);
+                    List<Subject> subjectList = subjectService.list(queryWrapperSub);
+                    if (!CollectionUtils.isEmpty(subjectList)) {
+                        List<String> subName = subjectList.stream().map(Subject::getName).collect(Collectors.toList());
+                        teacherResp.setSubjectName(subName);
                     }
-                }
-
-                teacherRespList.add(teacherResp);
-            });
-
+                    teacherResp.setUserId(e.getId());
+                    SysUser sysUser = sysUserService.getById(e.getId());
+                    if (sysUser != null) {
+                        teacherResp.setAvatar(sysUser.getAvatar());
+                        teacherResp.setName(sysUser.getRealName());
+                    }
+                    QueryWrapper<ClassGroupTeacherMapper> queryWrapper1 = new QueryWrapper<>();
+                    queryWrapper1.eq("user_id_", e.getId());
+                    List<ClassGroupTeacherMapper> classGroupTeacherMappers = classGroupTeacherMapperService.list(queryWrapper1);
+                    if (!CollectionUtils.isEmpty(classGroupTeacherMappers)) {
+                        List<Integer> classId = classGroupTeacherMappers.stream().map(ClassGroupTeacherMapper::getClassGroupId).collect(Collectors.toList());
+                        QueryWrapper<ClassGroup> groupQueryWrapper = new QueryWrapper<>();
+                        groupQueryWrapper.eq("id_", classId);
+                        List<ClassGroup> classGroups = classGroupService.list(groupQueryWrapper);
+                        if (!CollectionUtils.isEmpty(classGroups)) {
+                            List<String> className = classGroups.stream().map(ClassGroup::getName).collect(Collectors.toList());
+
+                            teacherResp.setClassName(className);
+                        }
+                    }
+                    teacherRespList.add(teacherResp);
+                });
+            }
         }
         response.setReturnCode(ReturnCodeEnum.CODE_200.getCode());
         response.setMessage(ReturnCodeEnum.CODE_200.getValue());
@@ -325,7 +329,7 @@ public class TeacherServiceImpl extends ServiceImpl<TeacherMapper, Teacher> impl
         Page<CourseSchedule> courseSchedulePage = new Page<CourseSchedule>(req.getPageNo(), req.getPageSize());
         QueryWrapper<CourseSchedule> courseScheduleQueryWrapper = new QueryWrapper<>();
         courseScheduleQueryWrapper.lambda().eq(CourseSchedule::getTeacherId, req.getUserId())
-        .eq(Objects.nonNull(req.getDate()), CourseSchedule::getClassDate, req.getDate());
+            .eq(Objects.nonNull(req.getDate()), CourseSchedule::getClassDate, req.getDate());
         IPage<CourseSchedule> page = courseScheduleService.page(courseSchedulePage, courseScheduleQueryWrapper);
         BeanUtils.copyProperties(page, pageResult);
         if (!CollectionUtils.isEmpty(page.getRecords())) {

+ 1 - 1
mec-education/src/main/resources/application.yml

@@ -51,7 +51,7 @@ spring:
       min-idle: 0
 
 mybatis-plus:
-  mapper-locations: classpath*:mapper/*.xml
+  mapper-locations: classpath*:mapper/*.xml,classpath*:config/mybatis/*.xml
   typeAliasesPackage : com.ym.mec.education.entity
   configuration:
     log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

+ 30 - 0
mec-student/src/main/java/com/ym/mec/student/controller/ContractsController.java

@@ -34,4 +34,34 @@ public class ContractsController extends BaseController {
 		return succeed(contractService.queryRegisterContract(sysUser.getId()));
 	}
 
+	@ApiOperation("查询商品协议")
+	@GetMapping(value = "queryGoodsContract")
+	public Object queryGoodsContract(String musicGroupId) {
+		SysUser sysUser = sysUserFeignService.queryUserInfo();
+		if (sysUser == null) {
+			return failed("获取用户信息失败");
+		}
+		return succeed(contractService.queryGoodsContract(sysUser.getId(), musicGroupId));
+	}
+
+	@ApiOperation("查询乐团课程协议")
+	@GetMapping(value = "queryMusicGroupCoursesContract")
+	public Object queryMusicGroupCoursesContract(String musicGroupId) {
+		SysUser sysUser = sysUserFeignService.queryUserInfo();
+		if (sysUser == null) {
+			return failed("获取用户信息失败");
+		}
+		return succeed(contractService.queryMusicGroupCoursesContract(sysUser.getId(), musicGroupId));
+	}
+
+	@ApiOperation("查询VIP课程协议")
+	@GetMapping(value = "queryVipGroupCoursesContract")
+	public Object queryVipGroupCoursesContract(Long vipGroupId) {
+		SysUser sysUser = sysUserFeignService.queryUserInfo();
+		if (sysUser == null) {
+			return failed("获取用户信息失败");
+		}
+		return succeed(contractService.queryVipGroupCoursesContract(sysUser.getId(), vipGroupId));
+	}
+
 }

+ 32 - 15
mec-student/src/main/java/com/ym/mec/student/controller/MusicGroupController.java

@@ -1,29 +1,46 @@
 package com.ym.mec.student.controller;
 
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
+import io.swagger.annotations.ApiOperation;
+
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Map;
+
+import javax.annotation.Resource;
+
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpStatus;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
 import com.ym.mec.auth.api.client.SysUserFeignService;
 import com.ym.mec.auth.api.entity.SysUser;
 import com.ym.mec.biz.dal.dto.MusicGroupSubjectGoodsAndInfoDto;
 import com.ym.mec.biz.dal.dto.RegisterPayDto;
-import com.ym.mec.biz.dal.entity.*;
+import com.ym.mec.biz.dal.entity.Goods;
+import com.ym.mec.biz.dal.entity.MusicGroupSubjectGoodsGroup;
+import com.ym.mec.biz.dal.entity.MusicGroupSubjectPlan;
+import com.ym.mec.biz.dal.entity.StudentPaymentOrder;
+import com.ym.mec.biz.dal.entity.StudentRegistration;
 import com.ym.mec.biz.dal.enums.DealStatusEnum;
 import com.ym.mec.biz.dal.enums.GoodsType;
 import com.ym.mec.biz.dal.enums.KitGroupPurchaseTypeEnum;
-import com.ym.mec.biz.dal.enums.OrderTypeEnum;
-import com.ym.mec.biz.service.*;
+import com.ym.mec.biz.service.GoodsService;
+import com.ym.mec.biz.service.MusicGroupService;
+import com.ym.mec.biz.service.MusicGroupSubjectGoodsGroupService;
+import com.ym.mec.biz.service.MusicGroupSubjectPlanService;
+import com.ym.mec.biz.service.PayService;
+import com.ym.mec.biz.service.StudentPaymentOrderService;
+import com.ym.mec.biz.service.StudentRegistrationService;
 import com.ym.mec.common.controller.BaseController;
 import com.ym.mec.common.entity.HttpResponseResult;
 import com.ym.mec.util.string.IdWorker;
-import io.swagger.annotations.Api;
-import io.swagger.annotations.ApiImplicitParam;
-import io.swagger.annotations.ApiImplicitParams;
-import io.swagger.annotations.ApiOperation;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpStatus;
-import org.springframework.web.bind.annotation.*;
-
-import javax.annotation.Resource;
-import java.math.BigDecimal;
-import java.util.*;
 
 @RequestMapping("musicGroup")
 @Api(tags = "乐团服务")
@@ -82,7 +99,7 @@ public class MusicGroupController extends BaseController {
     @GetMapping("/getSubjectGoodsAndInfo")
     @ApiImplicitParams({@ApiImplicitParam(name = "musicGroupId", value = "乐团编号", required = true, dataType = "Integer"),
             @ApiImplicitParam(name = "subjectId", value = "声部编号", required = true, dataType = "Integer")})
-    public HttpResponseResult getSubjectGoodsAndInfo(Integer musicGroupId, Integer subjectId) {
+    public HttpResponseResult getSubjectGoodsAndInfo(String musicGroupId, Integer subjectId) {
         SysUser sysUser = sysUserFeignService.queryUserInfo();
         MusicGroupSubjectGoodsAndInfoDto subjectGoodsAndInfo = musicGroupSubjectPlanService.getSubjectGoodsAndInfo(musicGroupId, subjectId);
         return succeed(subjectGoodsAndInfo);

+ 131 - 0
mec-util/src/main/java/com/ym/mec/util/money/MoneyUtil.java

@@ -0,0 +1,131 @@
+package com.ym.mec.util.money;
+
+public class MoneyUtil {  
+    /** 大写数字 */  
+    private static final String[] NUMBERS = { "零", "壹", "贰", "叁", "肆", "伍",  
+            "陆", "柒", "捌", "玖" };  
+  
+    /** 整数部分的单位 */  
+    private static final String[] IUNIT = { "元", "拾", "佰", "仟", "万", "拾", "佰",  
+            "仟", "亿", "拾", "佰", "仟", "万", "拾", "佰", "仟" };  
+  
+    /** 小数部分的单位 */  
+    private static final String[] DUNIT = { "角", "分", "厘" };  
+  
+    /** 
+     * 得到大写金额。 
+     */  
+    public static String toChinese(String str) {  
+        str = str.replaceAll(",", "");// 去掉","  
+        String integerStr;// 整数部分数字  
+        String decimalStr;// 小数部分数字  
+        // 初始化:分离整数部分和小数部分  
+        if (str.indexOf(".") > 0) {  
+            integerStr = str.substring(0, str.indexOf("."));  
+            decimalStr = str.substring(str.indexOf(".") + 1);  
+        } else if (str.indexOf(".") == 0) {  
+            integerStr = "";  
+            decimalStr = str.substring(1);  
+        } else {  
+            integerStr = str;  
+            decimalStr = "";  
+        }  
+        // integerStr去掉首0,不必去掉decimalStr的尾0(超出部分舍去)  
+        if (!integerStr.equals("")) {  
+            integerStr = Long.toString(Long.parseLong(integerStr));  
+            if (integerStr.equals("0")) {  
+                integerStr = "";  
+            }  
+        }  
+        // overflow超出处理能力,直接返回  
+        if (integerStr.length() > IUNIT.length) {  
+            System.out.println(str + ":超出处理能力");  
+            return str;  
+        }  
+  
+        int[] integers = toArray(integerStr);// 整数部分数字  
+        boolean isMust5 = isMust5(integerStr);// 设置万单位  
+        int[] decimals = toArray(decimalStr);// 小数部分数字  
+        return getChineseInteger(integers, isMust5)  
+                + getChineseDecimal(decimals);  
+    }  
+  
+    /** 
+     * 整数部分和小数部分转换为数组,从高位至低位 
+     */  
+    private static int[] toArray(String number) {  
+        int[] array = new int[number.length()];  
+        for (int i = 0; i < number.length(); i++) {  
+            array[i] = Integer.parseInt(number.substring(i, i + 1));  
+        }  
+        return array;  
+    }  
+  
+    /** 
+     * 得到中文金额的整数部分。 
+     */
+    private static String getChineseInteger(int[] integers, boolean isMust5) {  
+        StringBuffer chineseInteger = new StringBuffer("");  
+        int length = integers.length;  
+        for (int i = 0; i < length; i++) {  
+            // 0出现在关键位置:1234(万)5678(亿)9012(万)3456(元)  
+            // 特殊情况:10(拾元、壹拾元、壹拾万元、拾万元)  
+            String key = "";  
+            if (integers[i] == 0) {  
+                if ((length - i) == 13)// 万(亿)(必填)  
+                    key = IUNIT[4];  
+                else if ((length - i) == 9)// 亿(必填)  
+                    key = IUNIT[8];  
+                else if ((length - i) == 5 && isMust5)// 万(不必填)  
+                    key = IUNIT[4];  
+                else if ((length - i) == 1)// 元(必填)  
+                    key = IUNIT[0];  
+                // 0遇非0时补零,不包含最后一位  
+                if ((length - i) > 1 && integers[i + 1] != 0)  
+                    key += NUMBERS[0];  
+            }  
+            chineseInteger.append(integers[i] == 0 ? key  
+                    : (NUMBERS[integers[i]] + IUNIT[length - i - 1]));  
+        }  
+        return chineseInteger.toString();  
+    }  
+  
+    /** 
+     * 得到中文金额的小数部分。 
+     */  
+    private static String getChineseDecimal(int[] decimals) {  
+        StringBuffer chineseDecimal = new StringBuffer("");  
+        for (int i = 0; i < decimals.length; i++) {  
+            // 舍去3位小数之后的  
+            if (i == 3)  
+                break;  
+            chineseDecimal.append(decimals[i] == 0 ? ""  
+                    : (NUMBERS[decimals[i]] + DUNIT[i]));  
+        }  
+        return chineseDecimal.toString();  
+    }  
+  
+    /** 
+     * 判断第5位数字的单位"万"是否应加。 
+     */  
+    private static boolean isMust5(String integerStr) {  
+        int length = integerStr.length();  
+        if (length > 4) {  
+            String subInteger = "";  
+            if (length > 8) {  
+                // 取得从低位数,第5到第8位的字串  
+                subInteger = integerStr.substring(length - 8, length - 4);  
+            } else {  
+                subInteger = integerStr.substring(0, length - 4);  
+            }  
+            return Integer.parseInt(subInteger) > 0;  
+        } else {  
+            return false;  
+        }  
+    }  
+  
+    public static void main(String[] args) {  
+        System.out.println(MoneyUtil.toChinese("500100001.23"));  
+    }  
+  
+}  

+ 1 - 1
mec-web/src/main/java/com/ym/mec/web/controller/ClassGroupController.java

@@ -35,7 +35,7 @@ public class ClassGroupController extends BaseController {
 
     @ApiOperation(value = "新增合奏班")
     @PostMapping("/addMixClass")
-    public Object addMixClass(@ApiParam(value = "乐团编号", required = true) @RequestParam Integer musicGroupId,
+    public Object addMixClass(@ApiParam(value = "乐团编号", required = true) @RequestParam String musicGroupId,
                               @ApiParam(value = "班级名称", required = true) String name,
                               @ApiParam(value = "班级编号,号分割", required = true) String classGroupIds) throws Exception {
         return succeed(classGroupService.addMixClassGroup(musicGroupId, name, classGroupIds));

+ 43 - 2
mec-web/src/main/java/com/ym/mec/web/controller/VipGroupManageController.java

@@ -1,21 +1,26 @@
 package com.ym.mec.web.controller;
 
+import com.ym.mec.biz.dal.dto.ClassDateAdjustDto;
 import com.ym.mec.biz.dal.dto.VipGroupApplyDto;
 import com.ym.mec.biz.dal.entity.StudentApplyRefunds;
 import com.ym.mec.biz.dal.entity.VipGroup;
 import com.ym.mec.biz.dal.page.VipGroupAttendanceQueryInfo;
 import com.ym.mec.biz.dal.page.VipGroupQueryInfo;
+import com.ym.mec.biz.dal.page.VipGroupSalaryQueryInfo;
 import com.ym.mec.biz.dal.page.VipGroupTeachingRecordQueryInfo;
+import com.ym.mec.biz.service.CourseScheduleService;
 import com.ym.mec.biz.service.VipGroupService;
 import com.ym.mec.common.controller.BaseController;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpStatus;
 import org.springframework.web.bind.annotation.*;
 
 import java.math.BigDecimal;
 import java.util.HashMap;
 import java.util.Map;
+import java.util.Objects;
 
 /**
  * @Author Joburgess
@@ -28,6 +33,8 @@ public class VipGroupManageController extends BaseController {
 
     @Autowired
     private VipGroupService vipGroupService;
+    @Autowired
+    private CourseScheduleService scheduleService;
 
     @ApiOperation(value = "vip课申请")
     @PostMapping("/vipGroupApply")
@@ -49,8 +56,8 @@ public class VipGroupManageController extends BaseController {
     }
 
     @ApiOperation(value = "vip课详情")
-    @GetMapping("/getVipGroupDetail/{vipGroupId}")
-    public Object getVipGroupDetail(@PathVariable("vipGroupId") Long vipGroupId){
+    @GetMapping("/getVipGroupDetail")
+    public Object getVipGroupDetail(Long vipGroupId){
         return succeed(vipGroupService.getVipGroupDetail(vipGroupId));
     }
 
@@ -95,4 +102,38 @@ public class VipGroupManageController extends BaseController {
         return succeed(results);
     }
 
+    @ApiOperation(value = "停止vip课")
+    @PostMapping("/stopVipGroup")
+    public Object stopVipGroup(Long vipGroupId){
+        if(Objects.isNull(vipGroupId)){
+            return failed(HttpStatus.FORBIDDEN,"请指定vip课");
+        }
+
+        //停止vip课逻辑
+
+        return succeed();
+    }
+
+    @ApiOperation(value = "获取vip课财务信息")
+    @GetMapping("/findVipGroupSalarys")
+    public Object findVipGroupSalarys(VipGroupSalaryQueryInfo queryInfo){
+        return succeed(vipGroupService.findVipGroupSalarys(queryInfo));
+    }
+
+    @ApiOperation(value = "获取当前课程上课学员")
+    @GetMapping("/findVipGroupAttendanceStudents")
+    public Object findVipGroupStudents(Long courseScheduleId){
+        return succeed(vipGroupService.findVipGroupAttendanceStudents(courseScheduleId));
+    }
+
+    @ApiOperation(value = "课时调整")
+    @PostMapping(value = "/classStartDateAdjust")
+    public Object classStartDateAdjust(ClassDateAdjustDto classDateAdjustDto){
+        if(Objects.isNull(classDateAdjustDto.getId())){
+            return failed(HttpStatus.FORBIDDEN, "请指定课程!");
+        }
+        scheduleService.classStartDateAdjust(classDateAdjustDto);
+        return succeed();
+    }
+
 }