doum
2025-09-08 863ec3280a6376c39a51144e1731c548300539ca
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
package com.doumee.api.business;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.doumee.api.BaseController;
import com.doumee.core.annotation.excel.ExcelExporter;
import com.doumee.core.annotation.pr.PreventRepeat;
import com.doumee.core.model.ApiResponse;
import com.doumee.core.model.PageWrap;
import com.doumee.core.model.PageData;
import com.doumee.core.utils.Constants;
import com.doumee.core.utils.DateUtil;
import com.doumee.dao.business.model.Declares;
import com.doumee.dao.business.model.Project;
import com.doumee.service.business.ProjectService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.apache.shiro.authz.annotation.RequiresPermissions;    
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletResponse;
 
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;
 
/**
 * @author 江蹄蹄
 * @date 2023/02/15 08:55
 */
@Api(tags = "项目信息表")
@RestController
@RequestMapping("/business/project")
public class ProjectController extends BaseController {
 
    @Autowired
    private ProjectService projectService;
 
    @PreventRepeat
    @ApiOperation("新建")
    @PostMapping("/create")
    @RequiresPermissions("business:project:create")
    public ApiResponse create(@RequestBody Project project) {
        return ApiResponse.success(projectService.create(project));
    }
 
    @ApiOperation("根据ID删除")
    @GetMapping("/delete/{id}")
    @RequiresPermissions("business:project:delete")
    public ApiResponse deleteById(@PathVariable Integer id) {
        projectService.deleteById(id);
        return ApiResponse.success(null);
    }
 
    @ApiOperation("批量删除")
    @GetMapping("/delete/batch")
    @RequiresPermissions("business:project:delete")
    public ApiResponse deleteByIdInBatch(@RequestParam String ids) {
        String [] idArray = ids.split(",");
        List<Integer> idList = new ArrayList<>();
        for (String id : idArray) {
            idList.add(Integer.valueOf(id));
        }
        projectService.deleteByIdInBatch(idList);
        return ApiResponse.success(null);
    }
 
    @ApiOperation("根据ID修改")
    @PostMapping("/updateById")
    @RequiresPermissions("business:project:update")
    public ApiResponse updateById(@RequestBody Project project) {
        projectService.updateById(project);
        return ApiResponse.success(null);
    }
    @ApiOperation("分配市局子账号")
    @PostMapping("/distributeSjChild")
    @RequiresPermissions("business:project:distributeSjChild")
    public ApiResponse distributeSjChild(@RequestBody Project project) {
        projectService.distributeSjChild(project);
        return ApiResponse.success(null);
    }
 
    @ApiOperation("分页查询")
    @PostMapping("/page")
    @RequiresPermissions("business:project:query")
    public ApiResponse<PageData<Project>> findPage (@RequestBody PageWrap<Project> pageWrap) {
        return ApiResponse.success(projectService.findPage(pageWrap));
    }
    @ApiOperation("已报名项目分页查询")
    @PostMapping("/pageDeclared")
     @RequiresPermissions("business:project:query")
    public ApiResponse<PageData<Declares>> pageDeclared (@RequestBody PageWrap<Project> pageWrap) {
        return ApiResponse.success(projectService.pageDeclared(pageWrap));
    }
 
 
 
    @ApiOperation("导出Excel")
    @PostMapping("/exportExcel")
     @RequiresPermissions("business:project:exportExcel")
    public void exportExcel (@RequestBody PageWrap<Project> pageWrap, HttpServletResponse response) {
        ExcelExporter.build(Project.class).export(projectService.findPage(pageWrap).getRecords(), "项目信息表", response);
    }
 
    @ApiOperation("根据ID查询")
    @GetMapping("/{id}")
    @RequiresPermissions("business:project:query")
    public ApiResponse<Project> findById(@PathVariable Integer id) {
        return ApiResponse.success(projectService.findById(id));
    }
 
    /**
     * 删除子账号关联项目
     * @param project
     */
    @ApiOperation("删除子账号关联项目")
    @PostMapping("/updateSJchildIdById")
    @RequiresPermissions("business:project:update")
    public ApiResponse updateSJchildIdById(@RequestBody Project project){
        projectService.updateSJchildIdById(project);
        return ApiResponse.success(null);
    }
 
    /**
     * 条件查询
     *
     * @return List<Project>
     */
    @ApiOperation("市局关联项目")
    @PostMapping("/findSJProjectList")
    public ApiResponse<List<Project>> findSJProjectList(){
//        Project project = new Project();
//        project.setSjId(getLoginUser().getId());
 
//        QueryWrapper<Project> wrapper = new QueryWrapper<>();
//        wrapper.lambda()
//                .eq(Project::getSjId,getLoginUser().getId())
////                .eq(Project::getCityId,getLoginUser().getCityId())
//                .eq(Project::getIsdeleted, Constants.ZERO)
//                .le(Project::getStartDate, LocalDateTime.now())
//                .ge(Project::getEndDate,LocalDateTime.now());
 
        Project p =new Project();
        p.setSjId(getLoginUser().getId());
        p.setIsdeleted(Constants.ZERO);
        List<Project> list = projectService.findList(p);
        return ApiResponse.success(list);
    }
}