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
*
* @Description: 医生的数据需求
* @Project: 用户中心
* @CreateDate: Created in 2020-04-01 09:37:04
* @Author: liuke
* @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 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 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 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 params, HttpServletResponse response) throws IOException {
List result = dataNeedService.findListExportByParam(params);
//导出操作
ExcelUtil.exportExcel(result, null, "数据需求", DataNeedExcel.class, "DataNeed", response);
return ResultBody.ok().msg("导出数据成功");
}
}