|
|
@@ -0,0 +1,123 @@
|
|
|
+package com.xjrsoft.module.student.controller;
|
|
|
+
|
|
|
+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.xjrsoft.common.annotation.XjrLog;
|
|
|
+import com.xjrsoft.common.constant.GlobalConstant;
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.StringPool;
|
|
|
+import com.xjrsoft.common.model.result.R;
|
|
|
+import com.xjrsoft.common.page.ConventPage;
|
|
|
+import com.xjrsoft.common.page.PageOutput;
|
|
|
+import com.xjrsoft.common.model.result.RT;
|
|
|
+import com.xjrsoft.common.utils.TreeUtil;
|
|
|
+import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
+import com.xjrsoft.module.organization.dto.DepartmentTreeDto;
|
|
|
+import com.xjrsoft.module.organization.entity.Department;
|
|
|
+import com.xjrsoft.module.organization.vo.DepartmentTreeVo;
|
|
|
+import com.xjrsoft.module.student.dto.AddCadreDeptDto;
|
|
|
+import com.xjrsoft.module.student.dto.CadreDeptTreeDto;
|
|
|
+import com.xjrsoft.module.student.dto.UpdateCadreDeptDto;
|
|
|
+import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
|
+
|
|
|
+import com.xjrsoft.module.student.dto.CadreDeptPageDto;
|
|
|
+import com.xjrsoft.module.student.entity.CadreDept;
|
|
|
+import com.xjrsoft.module.student.service.ICadreDeptService;
|
|
|
+import com.xjrsoft.module.student.vo.CadreDeptPageVo;
|
|
|
+
|
|
|
+import com.xjrsoft.module.student.vo.CadreDeptTreeVo;
|
|
|
+import com.xjrsoft.module.student.vo.CadreDeptVo;
|
|
|
+import io.swagger.annotations.Api;
|
|
|
+import io.swagger.annotations.ApiOperation;
|
|
|
+import lombok.AllArgsConstructor;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+
|
|
|
+import javax.validation.Valid;
|
|
|
+import javax.validation.constraints.NotNull;
|
|
|
+import java.util.List;
|
|
|
+
|
|
|
+/**
|
|
|
+* @title: 干部部门
|
|
|
+* @Author szs
|
|
|
+* @Date: 2023-12-20
|
|
|
+* @Version 1.0
|
|
|
+*/
|
|
|
+@RestController
|
|
|
+@RequestMapping("/student" + "/cadreDept")
|
|
|
+@Api(value = "/student" + "/cadreDept",tags = "干部部门代码")
|
|
|
+@AllArgsConstructor
|
|
|
+public class CadreDeptController {
|
|
|
+
|
|
|
+
|
|
|
+ private final ICadreDeptService cadreDeptService;
|
|
|
+
|
|
|
+ @GetMapping(value = "/page")
|
|
|
+ @ApiOperation(value="干部部门列表(分页)")
|
|
|
+ @SaCheckPermission("cadredept:detail")
|
|
|
+ public RT<PageOutput<CadreDeptPageVo>> page(@Valid CadreDeptPageDto dto){
|
|
|
+
|
|
|
+ LambdaQueryWrapper<CadreDept> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
+ queryWrapper
|
|
|
+ .orderByDesc(CadreDept::getId)
|
|
|
+ .select(CadreDept.class,x -> VoToColumnUtil.fieldsToColumns(CadreDeptPageVo.class).contains(x.getProperty()));
|
|
|
+ IPage<CadreDept> page = cadreDeptService.page(ConventPage.getPage(dto), queryWrapper);
|
|
|
+ PageOutput<CadreDeptPageVo> pageOutput = ConventPage.getPageOutput(page, CadreDeptPageVo.class);
|
|
|
+ return RT.ok(pageOutput);
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping(value = "/tree")
|
|
|
+ @ApiOperation(value = "干部部门树")
|
|
|
+ @SaCheckPermission("cadredept:detail")
|
|
|
+ public RT<List<CadreDeptTreeVo>> tree(CadreDeptTreeDto dto) {
|
|
|
+
|
|
|
+ List<CadreDept> list = cadreDeptService.list(Wrappers.<CadreDept>lambdaQuery()
|
|
|
+ .select(CadreDept.class, x -> VoToColumnUtil.fieldsToColumns(CadreDeptTreeVo.class).contains(x.getProperty())));
|
|
|
+
|
|
|
+ List<CadreDeptTreeVo> voList = BeanUtil.copyToList(list, CadreDeptTreeVo.class);
|
|
|
+ List<CadreDeptTreeVo> treeVoList = TreeUtil.build(voList);
|
|
|
+ return RT.ok(treeVoList);
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping(value = "/info")
|
|
|
+ @ApiOperation(value="根据id查询干部部门信息")
|
|
|
+ @SaCheckPermission("cadredept:detail")
|
|
|
+ public RT<CadreDeptVo> info(@RequestParam Long id){
|
|
|
+ CadreDept cadreDept = cadreDeptService.getById(id);
|
|
|
+ if (cadreDept == null) {
|
|
|
+ return RT.error("找不到此数据!");
|
|
|
+ }
|
|
|
+ return RT.ok(BeanUtil.toBean(cadreDept, CadreDeptVo.class));
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ @PostMapping
|
|
|
+ @ApiOperation(value = "新增干部部门")
|
|
|
+ @SaCheckPermission("cadredept:add")
|
|
|
+ public RT<Boolean> add(@Valid @RequestBody AddCadreDeptDto dto){
|
|
|
+ CadreDept cadreDept = BeanUtil.toBean(dto, CadreDept.class);
|
|
|
+ boolean isSuccess = cadreDeptService.save(cadreDept);
|
|
|
+ return RT.ok(isSuccess);
|
|
|
+ }
|
|
|
+
|
|
|
+ @PutMapping
|
|
|
+ @ApiOperation(value = "修改干部部门")
|
|
|
+ @SaCheckPermission("cadredept:edit")
|
|
|
+ public RT<Boolean> update(@Valid @RequestBody UpdateCadreDeptDto dto){
|
|
|
+
|
|
|
+ CadreDept cadreDept = BeanUtil.toBean(dto, CadreDept.class);
|
|
|
+ return RT.ok(cadreDeptService.updateById(cadreDept));
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ @DeleteMapping
|
|
|
+ @ApiOperation(value = "删除干部部门")
|
|
|
+ @SaCheckPermission("cadredept:delete")
|
|
|
+ public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
|
|
|
+ return RT.ok(cadreDeptService.removeBatchByIds(ids));
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+}
|