package com.ruoyi.web.controller.smartor; import java.util.List; import com.ruoyi.common.config.RuoYiConfig; import com.ruoyi.common.utils.StringUtils; import com.ruoyi.common.utils.file.FileUtils; import com.smartor.domain.SvyLibScriptRes; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.http.MediaType; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.PutMapping; import org.springframework.web.bind.annotation.DeleteMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import com.ruoyi.common.annotation.Log; import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.enums.BusinessType; import com.smartor.domain.PatArchiveImport; import com.smartor.service.IPatArchiveImportService; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.common.core.page.TableDataInfo; import org.springframework.web.multipart.MultipartFile; /** * Excel导入患者档案Controller * * @author lihu * @date 2024-09-05 */ @Api("Excel导入患者档案") @RestController @RequestMapping("/smartor/import") public class PatArchiveImportController extends BaseController { @Autowired private IPatArchiveImportService patArchiveImportService; /** * 查询Excel导入患者档案列表 */ @ApiOperation("查询Excel导入患者档案列表") //@PreAuthorize("@ss.hasPermi('smartor:import:list')") @GetMapping("/list") public TableDataInfo list(PatArchiveImport patArchiveImport) { startPage(); List list = patArchiveImportService.selectPatArchiveImportList(patArchiveImport); return getDataTable(list); } /** * 获取Excel导入患者档案详细信息 */ @ApiOperation("获取Excel导入患者档案详细信息") //@PreAuthorize("@ss.hasPermi('smartor:import:query')") @GetMapping(value = "/getInfo/{id}") public AjaxResult getInfo(@PathVariable("id") Long id) { return success(patArchiveImportService.selectPatArchiveImportById(id)); } /** * 新增Excel导入患者档案 */ //@PreAuthorize("@ss.hasPermi('smartor:import:add')") @Log(title = "Excel导入患者档案", businessType = BusinessType.INSERT) @PostMapping("/add") public AjaxResult add(@RequestBody PatArchiveImport patArchiveImport) { return toAjax(patArchiveImportService.insertPatArchiveImport(patArchiveImport)); } /** * 修改Excel导入患者档案 */ @ApiOperation("修改Excel导入患者档案") //@PreAuthorize("@ss.hasPermi('smartor:import:edit')") @Log(title = "Excel导入患者档案", businessType = BusinessType.UPDATE) @PostMapping("/edit") public AjaxResult edit(@RequestBody PatArchiveImport patArchiveImport) { return toAjax(patArchiveImportService.updatePatArchiveImport(patArchiveImport)); } /** * 删除Excel导入患者档案 */ @ApiOperation("删除Excel导入患者档案") //@PreAuthorize("@ss.hasPermi('smartor:import:remove')") @Log(title = "Excel导入患者档案", businessType = BusinessType.DELETE) @GetMapping("/remove/{ids}") public AjaxResult remove(@PathVariable Long[] ids) { return toAjax(patArchiveImportService.deletePatArchiveImportByIds(ids)); } /** * 获取导入患者模板 * * @param response */ @ApiOperation("获取导入患者模板") @GetMapping("/getImportPatTemplate") public void getImportPatTemplate(HttpServletResponse response) { ExcelUtil util = new ExcelUtil(PatArchiveImport.class); util.importTemplateExcel(response, "导入患者"); } @GetMapping("/download") public void fileDownload(HttpServletResponse response) { try { String filePath = "D:\\import\\患者信息.xlsx"; response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE); FileUtils.setAttachmentResponseHeader(response, "患者信息.xlsx"); FileUtils.writeBytes(filePath, response.getOutputStream()); } catch (Exception e) { e.printStackTrace(); } } @ApiOperation("导入Excel患者信息") //@PreAuthorize("@ss.hasPermi('smartor:import:list')") @PostMapping("/importPatInfo") public TableDataInfo importPatInfo(MultipartFile multipartFile) { return getDataTable(patArchiveImportService.importPatInfo(multipartFile)); } }