package com.zhongzheng.controller.course; import java.util.List; import java.util.Arrays; import com.zhongzheng.modules.course.bo.*; import com.zhongzheng.modules.course.service.ICourseService; import com.zhongzheng.modules.course.vo.CourseVo; import com.zhongzheng.modules.user.service.IUserStudyRecordService; import lombok.RequiredArgsConstructor; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.PutMapping; import org.springframework.web.bind.annotation.DeleteMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import com.zhongzheng.common.annotation.Log; import com.zhongzheng.common.core.controller.BaseController; import com.zhongzheng.common.core.domain.AjaxResult; import com.zhongzheng.common.enums.BusinessType; import com.zhongzheng.common.utils.poi.ExcelUtil; import com.zhongzheng.common.core.page.TableDataInfo; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; /** * 课程Controller * * @author hjl * @date 2021-10-09 */ @Api(value = "课程控制器", tags = {"课程管理"}) @RequiredArgsConstructor(onConstructor_ = @Autowired) @RestController @RequestMapping("/course") public class CourseController extends BaseController { private final ICourseService iCourseService; private final IUserStudyRecordService iUserStudyRecordService; /** * 查询课程列表 */ @ApiOperation("查询课程列表") @PreAuthorize("@ss.hasPermi('system:course:list')") @GetMapping("/list") public TableDataInfo list(CourseQueryBo bo) { startPage(); List list = iCourseService.selectList(bo); return getDataTable(list); } /** * 导出课程列表 */ /* @ApiOperation("导出课程列表") @PreAuthorize("@ss.hasPermi('system:course:export')") @Log(title = "课程", businessType = BusinessType.EXPORT) @GetMapping("/export") public AjaxResult export(CourseQueryBo bo) { List list = iCourseService.queryList(bo); ExcelUtil util = new ExcelUtil(CourseVo.class); return util.exportExcel(list, "课程"); }*/ /** * 获取课程详细信息 */ @ApiOperation("获取课程详细信息") @PreAuthorize("@ss.hasPermi('system:course:query')") @GetMapping("/{courseId}") public AjaxResult getInfo(@PathVariable("courseId" ) Long courseId) { return AjaxResult.success(iCourseService.selectById(courseId)); } /** * 新增课程 */ @ApiOperation("新增课程") @PreAuthorize("@ss.hasPermi('system:course:add')") @Log(title = "课程", businessType = BusinessType.INSERT) @PostMapping() public AjaxResult add(@RequestBody CourseAddBo bo) { return AjaxResult.success(iCourseService.insertByAddBo(bo)); } /** * 修改课程 */ @ApiOperation("修改课程") @PreAuthorize("@ss.hasPermi('system:course:edit')") @Log(title = "课程", businessType = BusinessType.UPDATE) @PostMapping("/edit") public AjaxResult edit(@RequestBody CourseEditBo bo) { return toAjax(iCourseService.updateByEditBo(bo) ? 1 : 0); } /** * 课程统计报表 */ @ApiOperation("课程统计报表") @GetMapping("/statement") public TableDataInfo getCourseStatement(CourseStatementBo bo) { TableDataInfo list = iUserStudyRecordService.getCourseStatement(bo); return list; } /** * 课程详情统计 */ @ApiOperation("课程详情统计") @GetMapping("/detail/statistics") public TableDataInfo getCourseDetailStatistics(CourseSectionDetailBo bo) { startPage(); List list = iUserStudyRecordService.getCourseDetailStatistics(bo); return getDataTable(list); } /** * 删除课程 */ /* @ApiOperation("删除课程") @PreAuthorize("@ss.hasPermi('system:course:remove')") @Log(title = "课程" , businessType = BusinessType.DELETE) @DeleteMapping("/{courseIds}") public AjaxResult remove(@PathVariable Long[] courseIds) { return toAjax(iCourseService.deleteWithValidByIds(Arrays.asList(courseIds), true) ? 1 : 0); }*/ }