package com.kidgrow.oprationcenter.controller; import com.kidgrow.common.controller.BaseController; import com.kidgrow.common.model.PageResult; import com.kidgrow.common.model.ResultBody; import com.kidgrow.common.utils.ExcelUtil; import com.kidgrow.oprationcenter.model.HospitalScreening; import com.kidgrow.oprationcenter.model.ScreeningHospitalDataExcel; import com.kidgrow.oprationcenter.service.IHospitalScreeningService; 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.collections4.MapUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.validation.BindingResult; import org.springframework.validation.ObjectError; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; import java.io.IOException; import java.util.ArrayList; import java.util.List; import java.util.Map; /** * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020
* * @Description: 筛查医院信息表-未完待续 * @Project: 运营中心 * @CreateDate: Created in 2020-04-02 18:25:34
* @Author: liuke * @version: 1.0 */ @Slf4j @RestController @RequestMapping("/hospitalscreening") @Api(tags = "筛查医院信息表-未完待续") public class HospitalScreeningController extends BaseController { @Autowired private IHospitalScreeningService hospitalScreeningService; /** * 列表 */ @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 hospitalScreeningService.findList(params); } /** * 查询 */ @ApiOperation(value = "查询") @GetMapping("/{id}") public ResultBody findById(@PathVariable Long id) { HospitalScreening model = hospitalScreeningService.getById(id); return ResultBody.ok().data(model).msg("查询成功"); } /** * 根据HospitalScreening当做查询条件进行查询 */ @ApiOperation(value = "根据HospitalScreening当做查询条件进行查询") @PostMapping("/query") public ResultBody findByObject(@RequestBody HospitalScreening hospitalScreening) { HospitalScreening model = hospitalScreeningService.findByObject(hospitalScreening); return ResultBody.ok().data(model).msg("查询成功"); } /** * 新增or更新 */ @ApiOperation(value = "保存") @PostMapping public ResultBody save(@Valid @RequestBody HospitalScreening hospitalScreening, BindingResult bindingResult) { List errMsg = new ArrayList<>(); if (bindingResult.hasErrors()) { for (ObjectError error : bindingResult.getAllErrors()) { errMsg.add(error.getDefaultMessage()); } return ResultBody.failed().msg(errMsg.toString()); } else { if (hospitalScreening.getId() == null) { HospitalScreening hs = new HospitalScreening(); hs.setHospitalId(hospitalScreening.getHospitalId()); hs.setDepartmentId(hospitalScreening.getDepartmentId()); HospitalScreening byObject = hospitalScreeningService.findByObject(hs); if (byObject != null) { return ResultBody.failed().msg("该医院已添加"); } } boolean v = hospitalScreeningService.saveOrUpdate(hospitalScreening); //更新redis hospitalScreeningService.updateRedisById(hospitalScreening); if (v) { return ResultBody.ok().data(hospitalScreening).msg("保存成功"); } else { return ResultBody.failed().msg("保存失败"); } } } /** * 删除 */ @ApiOperation(value = "删除") @DeleteMapping("/{id}") public ResultBody delete(@PathVariable Long id) { boolean v = hospitalScreeningService.removeById(id); if (v) { return ResultBody.ok().msg("删除成功"); } else { return ResultBody.failed().msg("删除失败"); } } /** * 修改状态 * * @param params * @return */ @ApiOperation(value = "修改反馈数据状态") @GetMapping("/updateEnabled") public ResultBody updateEnabled(@RequestParam Map params) { if (params.size() == 0) { return ResultBody.failed().msg("参数异常!"); } return hospitalScreeningService.updateEnabled(params); } /** * 查询 */ @ApiOperation(value = "查询") @GetMapping("/findByName") public ResultBody findByName(@RequestParam String hospitalName) { if (!hospitalName.isEmpty()) { return ResultBody.ok().data(hospitalScreeningService.findByName(hospitalName).getData()).msg("查询成功"); } else { return ResultBody.ok().data(null).msg(""); } } @ApiOperation(value = "导出") @PostMapping("/export") public void export(@RequestParam Map params, HttpServletResponse response) throws IOException { List list = hospitalScreeningService.export(params); //导出操作 if (list != null && list.size() > 0) { String name = MapUtils.getString(params, "hospitalName"); ExcelUtil.exportExcel(list, null, name, ScreeningHospitalDataExcel.class, name, response); } } }