| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- package com.xjrsoft.module.base.controller;
- import cn.dev33.satoken.annotation.SaCheckPermission;
- import cn.dev33.satoken.stp.StpUtil;
- import cn.hutool.core.bean.BeanUtil;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.baomidou.mybatisplus.core.metadata.IPage;
- import com.github.yulichang.wrapper.MPJLambdaWrapper;
- import com.xjrsoft.common.annotation.XjrLog;
- import com.xjrsoft.common.model.result.RT;
- import com.xjrsoft.common.page.ConventPage;
- import com.xjrsoft.common.page.PageOutput;
- import com.xjrsoft.common.utils.VoToColumnUtil;
- import com.xjrsoft.module.base.dto.AddBaseClassDynamicsDto;
- import com.xjrsoft.module.base.dto.BaseClassDynamicsPageDto;
- import com.xjrsoft.module.base.dto.BaseClassDynamicsRelationPageDto;
- import com.xjrsoft.module.base.dto.UpdateBaseClassDynamicsDto;
- import com.xjrsoft.module.base.entity.BaseClassDynamics;
- import com.xjrsoft.module.base.entity.BaseClassDynamicsRelation;
- import com.xjrsoft.module.base.service.IBaseClassDynamicsService;
- import com.xjrsoft.module.base.vo.BaseClassDynamicsPageVo;
- import com.xjrsoft.module.base.vo.BaseClassDynamicsRelationPageVo;
- import com.xjrsoft.module.base.vo.BaseClassDynamicsVo;
- import com.xjrsoft.module.organization.entity.User;
- import com.xjrsoft.module.organization.service.IUserService;
- import com.xjrsoft.module.student.entity.BaseStudent;
- import com.xjrsoft.module.system.entity.File;
- import com.xjrsoft.module.system.service.IFileService;
- import io.swagger.annotations.Api;
- import io.swagger.annotations.ApiOperation;
- import lombok.AllArgsConstructor;
- import org.springframework.web.bind.annotation.DeleteMapping;
- 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.RequestBody;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RequestParam;
- import org.springframework.web.bind.annotation.RestController;
- import javax.validation.Valid;
- import java.time.LocalDateTime;
- import java.util.Date;
- import java.util.List;
- /**
- * @title: 班级动态表
- * @Author dzx
- * @Date: 2024-09-04
- * @Version 1.0
- */
- @RestController
- @RequestMapping("/base" + "/baseClassDynamics")
- @Api(value = "/base" + "/baseClassDynamics", tags = "班级动态表代码")
- @AllArgsConstructor
- public class BaseClassDynamicsController {
- private final IBaseClassDynamicsService baseClassDynamicsService;
- private final IUserService userService;
- private final IFileService fileService;
- @GetMapping(value = "/page")
- @ApiOperation(value = "班级动态表列表(分页)")
- @SaCheckPermission("baseclassdynamics:page")
- @XjrLog(value = "班级动态表列表(分页)")
- public RT<PageOutput<BaseClassDynamicsPageVo>> page(@Valid BaseClassDynamicsPageDto dto) {
- long userId = StpUtil.getLoginIdAsLong();
- MPJLambdaWrapper<BaseClassDynamics> queryWrapper = new MPJLambdaWrapper<>();
- queryWrapper
- .select(BaseClassDynamics::getId)
- .select(BaseClassDynamics.class, x -> VoToColumnUtil.fieldsToColumns(BaseClassDynamicsPageVo.class).contains(x.getProperty()))
- .innerJoin(BaseClassDynamicsRelation.class, BaseClassDynamicsRelation::getBaseClassDynamicsId, BaseClassDynamics::getId)
- .eq(BaseClassDynamicsRelation::getUserId, userId)
- .orderByDesc(BaseClassDynamics::getId)
- ;
- if(dto.getStartDate() != null && dto.getEndDate() != null){
- queryWrapper.between(BaseClassDynamics::getCreateDate, dto.getStartDate().atStartOfDay(), dto.getEndDate().atTime(23,59,59));
- }
- IPage<BaseClassDynamics> page = baseClassDynamicsService.page(ConventPage.getPage(dto), queryWrapper);
- PageOutput<BaseClassDynamicsPageVo> pageOutput = ConventPage.getPageOutput(page, BaseClassDynamicsPageVo.class);
- return RT.ok(pageOutput);
- }
- @GetMapping(value = "/reader-page")
- @ApiOperation(value = "班级动态读者信息(分页)")
- @SaCheckPermission("baseclassdynamics:readerpage")
- @XjrLog(value = "班级动态读者信息(分页)")
- public RT<PageOutput<BaseClassDynamicsRelationPageVo>> page(@Valid BaseClassDynamicsRelationPageDto dto) {
- MPJLambdaWrapper<User> queryWrapper = new MPJLambdaWrapper<>();
- queryWrapper
- .select(User::getId)
- .select(User.class, x -> VoToColumnUtil.fieldsToColumns(User.class).contains(x.getProperty()))
- .select(BaseClassDynamicsRelation::getReadDate)
- .select(BaseClassDynamicsRelation::getReadMark)
- .innerJoin(BaseClassDynamicsRelation.class, BaseClassDynamicsRelation::getUserId, User::getId)
- .innerJoin(BaseStudent.class, BaseStudent::getUserId, User::getId)
- .eq(dto.getReadMark() != null, BaseClassDynamicsRelation::getReadMark, dto.getReadMark())
- .eq(BaseClassDynamicsRelation::getBaseClassDynamicsId, dto.getBaseClassDynamicsId())
- ;
- IPage<BaseClassDynamicsRelationPageVo> page = userService.selectJoinListPage(ConventPage.getPage(dto), BaseClassDynamicsRelationPageVo.class, queryWrapper);
- PageOutput<BaseClassDynamicsRelationPageVo> pageOutput = ConventPage.getPageOutput(page, BaseClassDynamicsRelationPageVo.class);
- return RT.ok(pageOutput);
- }
- @GetMapping(value = "/release-page")
- @ApiOperation(value = "班主任发布列表(分页)")
- @SaCheckPermission("baseclassdynamics:releasepage")
- @XjrLog(value = "班主任发布列表(分页)")
- public RT<PageOutput<BaseClassDynamicsPageVo>> releasePage(@Valid BaseClassDynamicsPageDto dto) {
- long userId = StpUtil.getLoginIdAsLong();
- LambdaQueryWrapper<BaseClassDynamics> queryWrapper = new LambdaQueryWrapper<>();
- queryWrapper
- .orderByDesc(BaseClassDynamics::getId)
- .select(BaseClassDynamics.class, x -> VoToColumnUtil.fieldsToColumns(BaseClassDynamicsPageVo.class).contains(x.getProperty()))
- .eq(BaseClassDynamics::getCreateUserId, userId);
- if(dto.getStartDate() != null && dto.getEndDate() != null){
- queryWrapper.between(BaseClassDynamics::getCreateDate, dto.getStartDate().atStartOfDay(), dto.getEndDate().atTime(23,59,59));
- }
- IPage<BaseClassDynamics> page = baseClassDynamicsService.page(ConventPage.getPage(dto), queryWrapper);
- PageOutput<BaseClassDynamicsPageVo> pageOutput = ConventPage.getPageOutput(page, BaseClassDynamicsPageVo.class);
- return RT.ok(pageOutput);
- }
- @GetMapping(value = "/info")
- @ApiOperation(value = "根据id查询班级动态表信息")
- @SaCheckPermission("baseclassdynamics:info")
- @XjrLog(value = "根据id查询班级动态表信息", saveResponseData = true)
- public RT<BaseClassDynamicsVo> info(@RequestParam Long id) {
- BaseClassDynamics baseClassDynamics = baseClassDynamicsService.getById(id);
- if (baseClassDynamics == null) {
- return RT.error("找不到此数据!");
- }
- BaseClassDynamicsVo dynamicsVo = BeanUtil.toBean(baseClassDynamics, BaseClassDynamicsVo.class);
- User user = userService.getById(baseClassDynamics.getCreateUserId());
- dynamicsVo.setCreateUserName(user.getName());
- if (dynamicsVo.getFolderId() != null) {
- File file = fileService.getOne(new QueryWrapper<File>().lambda().eq(File::getFolderId, dynamicsVo.getFolderId()));
- if (file != null) {
- dynamicsVo.setFileUrl(file.getFileUrl());
- }
- }
- baseClassDynamicsService.read(id);
- return RT.ok(dynamicsVo);
- }
- @PostMapping
- @ApiOperation(value = "新增班级动态表")
- @SaCheckPermission("baseclassdynamics:add")
- @XjrLog(value = "新增班级动态表", saveResponseData = true)
- public RT<Boolean> add(@Valid @RequestBody AddBaseClassDynamicsDto dto) {
- Boolean isSuccess = baseClassDynamicsService.add(dto);
- return RT.ok(isSuccess);
- }
- @PutMapping
- @ApiOperation(value = "修改班级动态表")
- @SaCheckPermission("baseclassdynamics:edit")
- @XjrLog(value = "修改班级动态表", saveResponseData = true)
- public RT<Boolean> update(@Valid @RequestBody UpdateBaseClassDynamicsDto dto) {
- BaseClassDynamics baseClassDynamics = BeanUtil.toBean(dto, BaseClassDynamics.class);
- baseClassDynamics.setModifyDate(new Date());
- return RT.ok(baseClassDynamicsService.updateById(baseClassDynamics));
- }
- @DeleteMapping
- @ApiOperation(value = "删除班级动态表")
- @SaCheckPermission("baseclassdynamics:delete")
- @XjrLog(value = "删除班级动态表", saveResponseData = true)
- public RT<Boolean> delete(@Valid @RequestBody List<Long> ids) {
- return RT.ok(baseClassDynamicsService.removeBatchByIds(ids));
- }
- }
|