|
@@ -1,27 +1,38 @@
|
|
|
package com.xjrsoft.module.oa.controller;
|
|
|
|
|
|
+import cn.dev33.satoken.stp.StpUtil;
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
import cn.hutool.core.util.ObjectUtil;
|
|
|
import cn.hutool.core.util.StrUtil;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
|
|
import com.xjrsoft.common.constant.GlobalConstant;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.StringPool;
|
|
|
import com.xjrsoft.common.page.ConventPage;
|
|
|
import com.xjrsoft.common.page.PageOutput;
|
|
|
import com.xjrsoft.common.model.result.RT;
|
|
|
import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
+import com.xjrsoft.module.authority.vo.DataAuthListVo;
|
|
|
import com.xjrsoft.module.oa.dto.AddFileReceiveDto;
|
|
|
+import com.xjrsoft.module.oa.dto.FileReceivePullPageDto;
|
|
|
import com.xjrsoft.module.oa.dto.UpdateFileReceiveDto;
|
|
|
import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
|
|
|
|
-import com.xjrsoft.module.oa.dto.FileReceivePageDto;
|
|
|
import com.xjrsoft.module.oa.entity.FileReceive;
|
|
|
+import com.xjrsoft.module.oa.entity.Message;
|
|
|
+import com.xjrsoft.module.oa.entity.WfOaPull;
|
|
|
import com.xjrsoft.module.oa.service.IFileReceiveService;
|
|
|
-import com.xjrsoft.module.oa.vo.FileReceivePageVo;
|
|
|
|
|
|
-import com.xjrsoft.module.oa.vo.FileReceiveVo;
|
|
|
+import com.xjrsoft.module.oa.service.IWfOaPullService;
|
|
|
+import com.xjrsoft.module.oa.service.IWfOaPushService;
|
|
|
+import com.xjrsoft.module.oa.vo.FileReceivePullPageVo;
|
|
|
+import com.xjrsoft.module.oa.vo.FileReceivePullVo;
|
|
|
+import com.xjrsoft.module.organization.entity.User;
|
|
|
+import com.xjrsoft.module.system.entity.File;
|
|
|
+import com.xjrsoft.module.system.service.IFileService;
|
|
|
+import com.xjrsoft.module.teacher.entity.XjrUser;
|
|
|
import io.swagger.annotations.Api;
|
|
|
import io.swagger.annotations.ApiOperation;
|
|
|
import lombok.AllArgsConstructor;
|
|
@@ -32,71 +43,65 @@ import javax.validation.constraints.NotNull;
|
|
|
import java.util.List;
|
|
|
|
|
|
/**
|
|
|
-* @title: 文件接收管理
|
|
|
-* @Author fanxp
|
|
|
-* @Date: 2023-11-03
|
|
|
-* @Version 1.0
|
|
|
-*/
|
|
|
+ * @title: 文件接收管理
|
|
|
+ * @Author fanxp
|
|
|
+ * @Date: 2023-11-03
|
|
|
+ * @Version 1.0
|
|
|
+ */
|
|
|
@RestController
|
|
|
@RequestMapping("/oa" + "/filereceive")
|
|
|
-@Api(value = "/oa" + "/filereceive",tags = "文件接收管理代码")
|
|
|
+@Api(value = "/oa" + "/filereceive", tags = "文件接收管理代码")
|
|
|
@AllArgsConstructor
|
|
|
public class FileReceiveController {
|
|
|
|
|
|
|
|
|
private final IFileReceiveService fileReceiveService;
|
|
|
|
|
|
- @GetMapping(value = "/page")
|
|
|
- @ApiOperation(value="文件接收管理列表(分页)")
|
|
|
+ private final IWfOaPullService wfOaPullService;
|
|
|
+
|
|
|
+ private final IWfOaPushService wfOaPushService;
|
|
|
+
|
|
|
+ private final IFileService fileService;
|
|
|
+
|
|
|
+ @GetMapping(value = "/pullpage")
|
|
|
+ @ApiOperation(value = "收文查询(分页)")
|
|
|
@SaCheckPermission("filereceive:detail")
|
|
|
- public RT<PageOutput<FileReceivePageVo>> page(@Valid FileReceivePageDto dto){
|
|
|
+ public RT<PageOutput<FileReceivePullPageVo>> pullPage(@Valid FileReceivePullPageDto dto) {
|
|
|
+ //获取用户id
|
|
|
+ Long userId = StpUtil.getLoginIdAsLong();
|
|
|
|
|
|
- LambdaQueryWrapper<FileReceive> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
+ MPJLambdaWrapper<FileReceive> queryWrapper = new MPJLambdaWrapper<>();
|
|
|
queryWrapper
|
|
|
- .orderByDesc(FileReceive::getId)
|
|
|
- .select(FileReceive.class,x -> VoToColumnUtil.fieldsToColumns(FileReceivePageVo.class).contains(x.getProperty()));
|
|
|
- IPage<FileReceive> page = fileReceiveService.page(ConventPage.getPage(dto), queryWrapper);
|
|
|
- PageOutput<FileReceivePageVo> pageOutput = ConventPage.getPageOutput(page, FileReceivePageVo.class);
|
|
|
+ .innerJoin(WfOaPull.class, WfOaPull::getId, FileReceive::getDataId)
|
|
|
+ .leftJoin(XjrUser.class,XjrUser::getId,WfOaPull::getPersonName,ext -> ext.selectAs(XjrUser::getName, FileReceivePullPageVo::getUserName))
|
|
|
+ .eq(FileReceive::getFileType, 2)
|
|
|
+ .eq(FileReceive::getReceiverUserId, userId)
|
|
|
+ .select(WfOaPull::getId)
|
|
|
+ .select(WfOaPull.class, x -> VoToColumnUtil.fieldsToColumns(FileReceivePullPageVo.class).contains(x.getProperty()));
|
|
|
+
|
|
|
+ IPage<FileReceivePullPageVo> page = fileReceiveService.selectJoinListPage(ConventPage.getPage(dto),FileReceivePullPageVo.class, queryWrapper);
|
|
|
+ PageOutput<FileReceivePullPageVo> pageOutput = ConventPage.getPageOutput(page);
|
|
|
return RT.ok(pageOutput);
|
|
|
}
|
|
|
|
|
|
- @GetMapping(value = "/info")
|
|
|
- @ApiOperation(value="根据id查询文件接收管理信息")
|
|
|
+ @GetMapping(value = "/pullinfo")
|
|
|
+ @ApiOperation(value = "根据id查询文件接收管理信息")
|
|
|
@SaCheckPermission("filereceive:detail")
|
|
|
- public RT<FileReceiveVo> info(@RequestParam Long id){
|
|
|
- FileReceive fileReceive = fileReceiveService.getById(id);
|
|
|
+ public RT<FileReceivePullVo> pullInfo(@RequestParam Long id) {
|
|
|
+ MPJLambdaWrapper<WfOaPull> queryWrapper = new MPJLambdaWrapper<>();
|
|
|
+ queryWrapper
|
|
|
+ .leftJoin(XjrUser.class,XjrUser::getId,WfOaPull::getPersonName,ext -> ext.selectAs(XjrUser::getName, FileReceivePullPageVo::getUserName))
|
|
|
+ .eq(WfOaPull::getId, id)
|
|
|
+ .select(WfOaPull::getId)
|
|
|
+ .select(WfOaPull.class, x -> VoToColumnUtil.fieldsToColumns(FileReceivePullVo.class).contains(x.getProperty()));
|
|
|
+
|
|
|
+ FileReceivePullVo fileReceive = wfOaPullService.selectJoinOne(FileReceivePullVo.class,queryWrapper);
|
|
|
if (fileReceive == null) {
|
|
|
- return RT.error("找不到此数据!");
|
|
|
+ return RT.error("找不到此数据!");
|
|
|
}
|
|
|
- return RT.ok(BeanUtil.toBean(fileReceive, FileReceiveVo.class));
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- @PostMapping
|
|
|
- @ApiOperation(value = "新增文件接收管理")
|
|
|
- @SaCheckPermission("filereceive:add")
|
|
|
- public RT<Boolean> add(@Valid @RequestBody AddFileReceiveDto dto){
|
|
|
- FileReceive fileReceive = BeanUtil.toBean(dto, FileReceive.class);
|
|
|
- boolean isSuccess = fileReceiveService.save(fileReceive);
|
|
|
- return RT.ok(isSuccess);
|
|
|
- }
|
|
|
-
|
|
|
- @PutMapping
|
|
|
- @ApiOperation(value = "修改文件接收管理")
|
|
|
- @SaCheckPermission("filereceive:edit")
|
|
|
- public RT<Boolean> update(@Valid @RequestBody UpdateFileReceiveDto dto){
|
|
|
-
|
|
|
- FileReceive fileReceive = BeanUtil.toBean(dto, FileReceive.class);
|
|
|
- return RT.ok(fileReceiveService.updateById(fileReceive));
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- @DeleteMapping
|
|
|
- @ApiOperation(value = "删除文件接收管理")
|
|
|
- @SaCheckPermission("filereceive:delete")
|
|
|
- public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
|
|
|
- return RT.ok(fileReceiveService.removeBatchByIds(ids));
|
|
|
-
|
|
|
+ // 获取文件列表
|
|
|
+ fileReceive.setFileInfos(fileService.list(Wrappers.<File>query().lambda().eq(File::getFolderId,fileReceive.getFiles())));
|
|
|
+ return RT.ok(BeanUtil.toBean(fileReceive, FileReceivePullVo.class));
|
|
|
}
|
|
|
|
|
|
}
|