forked from kidgrow-microservices-platform

luliqiang
2020-12-31 6fb14149d62199cfcc0448c82eb2f51f9c5181de
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
149
150
151
152
153
154
155
package com.kidgrow.oprationcenter.controller;
 
import com.kidgrow.common.annotation.LoginUser;
import com.kidgrow.common.controller.BaseController;
import com.kidgrow.common.model.PageResult;
import com.kidgrow.common.model.ResultBody;
import com.kidgrow.common.model.SysUser;
import com.kidgrow.common.utils.ExcelUtil;
import com.kidgrow.oprationcenter.model.DataNeed;
import com.kidgrow.oprationcenter.service.IDataNeedService;
import com.kidgrow.oprationcenter.vo.DataNeedExcel;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections.MapUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.*;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.io.IOException;
import java.util.List;
import java.util.Map;
 
 
/**
 * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020<br>
 *
 * @Description: 医生的数据需求
 * @Project: 用户中心
 * @CreateDate: Created in 2020-04-01 09:37:04 <br>
 * @Author: <a href="4345453@kidgrow.com">liuke</a>
 * @version: 1.0
 */
@Slf4j
@RestController
@RequestMapping("/dataneed")
@Api(tags = "医生的数据需求")
public class DataNeedController extends BaseController {
    @Autowired
    private IDataNeedService dataNeedService;
 
    /**
     * 列表
     */
    @ApiOperation(value = "查询列表")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
            @ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
    })
    @GetMapping
    public PageResult list(@RequestParam Map<String, Object> params) {
        if (params.size() == 0) {
            params.put("page", 1);
            params.put("limit", 10);
        }
        return dataNeedService.findList(params);
    }
 
    /**
     * H端列表  需要医院和科室id
     */
    @ApiOperation(value = "H端列表,需要医院和科室id")
    @GetMapping("/hlist")
    public ResultBody list(@RequestParam Map<String, Object> params, @LoginUser(isFull = true) SysUser sysUser) {
        if (params.size() == 0) {
            params.put("page", 1);
            params.put("limit", 10);
        }
        if(MapUtils.getString(params,"page")==null){
            params.put("page", 1);
        }if(MapUtils.getString(params,"limit")==null){
            params.put("limit", 10);
        }
        return dataNeedService.FindAllByHId(params, sysUser);
    }
 
    /**
     * 查询
     */
    @ApiOperation(value = "查询")
    @GetMapping("/{id}")
    public ResultBody findById(@PathVariable Long id) {
        DataNeed model = dataNeedService.getById(id);
        return ResultBody.ok().data(model).msg("查询成功");
    }
 
    /**
     * 更新状态和文件地址
     */
    @ApiOperation(value = "更新状态和文件地址")
    @GetMapping("updateEnabled")
    public ResultBody updateEnabled(@RequestParam Map<String, Object> map) {
        return dataNeedService.updateEnabled(map);
    }
 
    /**
     * 更新使用状态
     */
    @ApiOperation(value = "更新使用状态")
    @GetMapping("updateDelete")
    public ResultBody updateDelete(@RequestParam Long id, @LoginUser(isFull = true) SysUser sysUser) {
        return dataNeedService.updateDelete(id, sysUser);
    }
 
    /**
     * 根据DataNeed当做查询条件进行查询
     */
    @ApiOperation(value = "根据DataNeed当做查询条件进行查询")
    @PostMapping("/query")
    public ResultBody findByObject(@RequestBody DataNeed dataNeed) {
        DataNeed model = dataNeedService.findByObject(dataNeed);
        return ResultBody.ok().data(model).msg("查询成功");
    }
 
    /**
     * 新增or更新
     */
    @ApiOperation(value = "保存")
    @PostMapping
    public ResultBody save(@Valid @RequestBody DataNeed dataNeed, BindingResult bindingResult) {
        if (bindingResult.hasErrors()) {
            return ResultBody.failed().msg(bindingResult.getFieldError().getDefaultMessage());
        } else {
            dataNeedService.saveOrUpdate(dataNeed);
            return ResultBody.ok().data(dataNeed).msg("保存成功");
        }
    }
    /**
     * 删除
     */
    @ApiOperation(value = "删除")
    @DeleteMapping("/{id}")
    public ResultBody delete(@PathVariable Long id) {
        dataNeedService.removeById(id);
        return ResultBody.ok().msg("删除成功");
    }
 
    /**
     * 导出excel
     *
     * @return
     */
    @PostMapping("/export")
    public ResultBody exportUser(@RequestParam Map<String, Object> params, HttpServletResponse response) throws IOException {
        List<DataNeedExcel> result = dataNeedService.findListExportByParam(params);
        //导出操作
        ExcelUtil.exportExcel(result, null, "数据需求", DataNeedExcel.class, "DataNeed", response);
        return ResultBody.ok().msg("导出数据成功");
    }
}