package com.ltkj.web.controller.system;
|
|
import java.util.ArrayList;
|
import java.util.HashMap;
|
import java.util.List;
|
import java.util.Map;
|
import java.util.stream.Collectors;
|
import javax.annotation.Resource;
|
import javax.servlet.http.HttpServletResponse;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.ltkj.common.core.redis.RedisCache;
|
import com.ltkj.framework.config.MatchUtils;
|
import com.ltkj.hosp.domain.TjCustomer;
|
import com.ltkj.hosp.domain.TjOtherCheck;
|
import com.ltkj.hosp.domain.TjXdPicture;
|
import com.ltkj.hosp.service.ITjCustomerService;
|
import com.ltkj.hosp.service.ITjOtherCheckService;
|
import com.ltkj.hosp.service.ITjProjectService;
|
import com.ltkj.hosp.service.TjAsyncService;
|
import com.ltkj.system.service.ISysConfigService;
|
import io.swagger.annotations.Api;
|
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiParam;
|
import org.springframework.security.access.prepost.PreAuthorize;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.web.bind.annotation.*;
|
import com.ltkj.common.annotation.Log;
|
import com.ltkj.common.core.controller.BaseController;
|
import com.ltkj.common.core.domain.AjaxResult;
|
import com.ltkj.common.enums.BusinessType;
|
import com.ltkj.common.utils.poi.ExcelUtil;
|
import com.ltkj.common.core.page.TableDataInfo;
|
|
/**
|
* 体检其他检测Controller
|
*
|
* @author ltkj
|
* @date 2023-04-14
|
*/
|
@RestController
|
@RequestMapping("/system/check")
|
@Api(tags = "其他测试值接口")
|
public class TjOtherCheckController extends BaseController {
|
@Resource
|
private ITjOtherCheckService tjOtherCheckService;
|
@Resource
|
private ITjCustomerService customerService;
|
@Autowired
|
private ISysConfigService configService;
|
|
/**
|
* 查询体检其他检测列表
|
*/
|
//@PreAuthorize("@ss.hasPermi('system:check:list')")
|
@GetMapping("/list")
|
@ApiOperation(value = "查询体检其他检测列表")
|
public TableDataInfo list(TjOtherCheck tjOtherCheck) {
|
startPage();
|
List<TjOtherCheck> list = tjOtherCheckService.selectTjOtherCheckList(tjOtherCheck);
|
return getDataTable(list);
|
}
|
|
|
@GetMapping("/getList")
|
@ApiOperation(value = "查询体检其他检测列表(非生成)")
|
public AjaxResult getList(@RequestParam(required = false) @ApiParam(value = "体检号") String tjNum,
|
@RequestParam(required = false) @ApiParam(value = "客户姓名") String name,
|
@ApiParam(value = "页码数(默认1)") @RequestParam(defaultValue = "1") Integer pageNum,
|
@ApiParam(value = "显示条数(默认10)") @RequestParam(defaultValue = "10") Integer pageSize) {
|
LambdaQueryWrapper<TjOtherCheck> wq=new LambdaQueryWrapper<>();
|
if(null !=tjNum)wq.eq(TjOtherCheck::getTjNum,tjNum);
|
if(null !=name)wq.like(TjOtherCheck::getCusName,name);
|
wq.orderByDesc(TjOtherCheck::getCreateTime);
|
List<TjOtherCheck> list = tjOtherCheckService.list(wq);
|
List<Map<String,Object>> arrayList=new ArrayList<>();
|
if(null !=list && list.size()>0){
|
Map<String, List<TjOtherCheck>> stringListMap = list.stream().collect(Collectors.groupingBy(TjOtherCheck::getCusId));
|
for (Map.Entry<String, List<TjOtherCheck>> entry : stringListMap.entrySet()) {
|
Map<String,Object>map=new HashMap<>();
|
TjCustomer customer = customerService.getById(entry.getKey());
|
customer.setCusName(MatchUtils.hideCusName(customer.getCusName()));
|
customer.setCusPhone(MatchUtils.hidePhoneNum(customer.getCusPhone()));
|
customer.setCusIdcard(MatchUtils.hideIdCardNum(customer.getCusIdcard()));
|
customer.setTjNumber(entry.getValue().get(0).getTjNum());
|
map.put("list",entry.getValue());
|
map.put("customer",customer);
|
map.put("picturePath",configService.selectConfigByKey("TjOtherCheck"));
|
arrayList.add(map);
|
}
|
}
|
List<Map<String, Object>> collect =null;
|
Map<String,Object>map=new HashMap<>();
|
if(arrayList.size()>0){
|
collect = arrayList.stream().skip((long) (pageNum - 1) * pageSize).limit(pageSize).collect(Collectors.toList());
|
}
|
map.put("list",collect);
|
map.put("total",arrayList.size());
|
return AjaxResult.success(map);
|
}
|
|
/**
|
* 导出体检其他检测列表
|
*/
|
//@PreAuthorize("@ss.hasPermi('system:check:export')")
|
@Log(title = "体检其他检测", businessType = BusinessType.EXPORT)
|
@PostMapping("/export")
|
@ApiOperation(value = "导出体检其他检测列表")
|
public void export(HttpServletResponse response, TjOtherCheck tjOtherCheck) {
|
List<TjOtherCheck> list = tjOtherCheckService.selectTjOtherCheckList(tjOtherCheck);
|
ExcelUtil<TjOtherCheck> util = new ExcelUtil<>(TjOtherCheck.class);
|
util.exportExcel(response, list, "体检其他检测数据");
|
}
|
|
/**
|
* 获取体检其他检测详细信息
|
*/
|
//@PreAuthorize("@ss.hasPermi('system:check:query')")
|
@GetMapping(value = "/{id}")
|
@ApiOperation(value = "获取体检其他检测详细信息")
|
public AjaxResult getInfo(@PathVariable("id") String id) {
|
return success(tjOtherCheckService.selectTjOtherCheckById(id));
|
}
|
|
/**
|
* 新增体检其他检测
|
*/
|
//@PreAuthorize("@ss.hasPermi('system:check:add')")
|
@Log(title = "体检其他检测", businessType = BusinessType.INSERT)
|
@PostMapping
|
@ApiOperation(value = "新增体检其他检测")
|
public AjaxResult add(@RequestBody TjOtherCheck tjOtherCheck) {
|
return toAjax(tjOtherCheckService.insertTjOtherCheck(tjOtherCheck));
|
}
|
|
/**
|
* 修改体检其他检测
|
*/
|
//@PreAuthorize("@ss.hasPermi('system:check:edit')")
|
@Log(title = "体检其他检测", businessType = BusinessType.UPDATE)
|
@PutMapping
|
@ApiOperation(value = "修改体检其他检测")
|
public AjaxResult edit(@RequestBody TjOtherCheck tjOtherCheck) {
|
return toAjax(tjOtherCheckService.updateTjOtherCheck(tjOtherCheck));
|
}
|
|
/**
|
* 删除体检其他检测
|
*/
|
//@PreAuthorize("@ss.hasPermi('system:check:remove')")
|
@Log(title = "体检其他检测", businessType = BusinessType.DELETE)
|
@DeleteMapping("/{ids}")
|
@ApiOperation(value = "删除体检其他检测")
|
public AjaxResult remove(@PathVariable String[] ids) {
|
return toAjax(tjOtherCheckService.deleteTjOtherCheckByIds(ids));
|
}
|
}
|