无码信息申报功能

dev_drug_dm
qiuyt 3 weeks ago
parent efede9e2cf
commit 67e6fdacae

@ -384,7 +384,7 @@
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.2.10</version>
<version>3.3.2</version>
</dependency>
<dependency>
<groupId>redis.clients</groupId>

@ -0,0 +1,107 @@
package com.glxp.api.controller.basic;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.ObjectUtil;
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.write.handler.WriteHandler;
import com.alibaba.excel.write.metadata.style.WriteCellStyle;
import com.alibaba.excel.write.metadata.style.WriteFont;
import com.alibaba.excel.write.style.HorizontalCellStyleStrategy;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.github.pagehelper.PageInfo;
import com.glxp.api.common.res.BaseResponse;
import com.glxp.api.common.util.ResultVOUtils;
import com.glxp.api.entity.basic.YbNotCode;
import com.glxp.api.req.dev.YbNotCodeQuery;
import com.glxp.api.res.PageSimpleResponse;
import com.glxp.api.res.basic.YbNotCodeResponse;
import com.glxp.api.service.basic.impl.YbNotCodeServiceImpl;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.ss.usermodel.BorderStyle;
import org.apache.poi.ss.usermodel.FillPatternType;
import org.apache.poi.ss.usermodel.IndexedColors;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.util.Date;
import java.util.List;
import java.util.Objects;
@Slf4j
@RestController
public class YbNotCodeController {
@Resource
YbNotCodeServiceImpl ybNotCodeService;
@PostMapping("/udispms/ybNotCode/page")
public BaseResponse page(@RequestBody YbNotCodeQuery query) {
List<YbNotCode> list = ybNotCodeService.pageList(query);
PageInfo pageInfo = new PageInfo<>(list);
PageSimpleResponse page = new PageSimpleResponse();
page.setTotal(pageInfo.getTotal());
page.setList(pageInfo.getList());
return ResultVOUtils.success(page);
}
@PostMapping("/udispms/ybNotCode/add")
public BaseResponse add(@RequestBody YbNotCode ybNotCode) {
return ResultVOUtils.success(ybNotCodeService.add(ybNotCode));
}
@PostMapping("/udispms/ybNotCode/update")
public BaseResponse update(@RequestBody YbNotCode ybNotCode) {
return ResultVOUtils.success(ybNotCodeService.update(ybNotCode));
}
@PostMapping("/udispms/ybNotCode/delete")
public BaseResponse delete(@RequestBody YbNotCode ybNotCode) {
return ResultVOUtils.success(ybNotCodeService.delete(ybNotCode));
}
@GetMapping("/udispms/ybNotCode/export")
public void export( YbNotCodeQuery query,HttpServletResponse response) throws IOException {
List<YbNotCode> list;
if(query.getExcelType() !=null && query.getExcelType() == 1
){
list = ybNotCodeService.pageList( query );
}else {
list = ybNotCodeService.list( new QueryWrapper<>());
}
List<YbNotCodeResponse> splitCodeEntities = BeanUtil.copyToList(list, YbNotCodeResponse.class);
response.setCharacterEncoding(StandardCharsets.UTF_8.name());
response.setHeader("content-Type", "application/vnd.ms-excel");
response.setHeader("Content-Disposition",
"attachment;filename=" + URLEncoder.encode("无码药品信息管理模板" + DateUtil.format(new Date(), "yyyy-MM-dd") + ".xlsx", StandardCharsets.UTF_8.name()));
// 定义表头样式
WriteCellStyle headWriteCellStyle = new WriteCellStyle();
// 设置表头背景颜色为淡蓝色
headWriteCellStyle.setFillForegroundColor(IndexedColors.LIGHT_YELLOW.getIndex()); // 淡蓝色对应的索引值
WriteFont headWriteFont = new WriteFont();
headWriteFont.setFontHeightInPoints((short) 11);
headWriteCellStyle.setWriteFont(headWriteFont);
// 定义内容样式
WriteCellStyle contentWriteCellStyle = new WriteCellStyle();
// 构建样式策略
HorizontalCellStyleStrategy horizontalCellStyleStrategy =
new HorizontalCellStyleStrategy(headWriteCellStyle, contentWriteCellStyle);
EasyExcel.write(response.getOutputStream(), YbNotCodeResponse.class).registerWriteHandler(horizontalCellStyleStrategy) .// 注册自定义样式处理器
sheet("无码药品申报导入").doWrite(splitCodeEntities);
}
}

@ -2,8 +2,13 @@ package com.glxp.api.dao.basic;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.glxp.api.entity.basic.YbNotCode;
import com.glxp.api.req.dev.YbNotCodeQuery;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
@Mapper
public interface YbNotCodeMapper extends BaseMapper<YbNotCode> {
}
List<YbNotCode> pageList(@Param("vo") YbNotCodeQuery ybNotCodeQuery);
}

@ -22,11 +22,13 @@ public class YbNotCode {
*
*/
@TableField(value = "organizationCode")
private String organizationcode;
private String organizationCode;
/**
* 1 5 6 7 0
*/
@TableField(value = "notCodeType")
private Integer notcodetype;
private Integer notCodeType;
@TableField(exist = false)
private String notCodeTypeName;
}

@ -0,0 +1,31 @@
package com.glxp.api.req.dev;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.glxp.api.util.page.ListPageRequest;
import lombok.Data;
@Data
public class YbNotCodeQuery extends ListPageRequest {
/**
*
*/
@TableId(value = "ybbm", type = IdType.INPUT)
private String ybbm;
/**
*
*/
@TableField(value = "organizationCode")
private String organizationCode;
/**
* 1 5 6 7 0
*/
@TableField(value = "notCodeType")
private Integer notCodeType;
private Integer excelType;
}

@ -0,0 +1,26 @@
package com.glxp.api.res.basic;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.annotation.write.style.HeadRowHeight;
import lombok.Data;
@Data
@HeadRowHeight(16) // 设置表头 高度 为 40
public class YbNotCodeResponse {
@ExcelProperty(value = "机构编码", index = 0)
@ColumnWidth(32)
private String ybbm;
@ExcelProperty(value = "国家医保目录编码", index = 1)
@ColumnWidth(28)
private String organizationCode;
@ExcelProperty(value = "无码类型(仅填数字即可)", index = 2)
@ColumnWidth(54)
private String notCodeType;
}

@ -0,0 +1,17 @@
package com.glxp.api.service;
import com.glxp.api.entity.basic.YbNotCode;
import com.baomidou.mybatisplus.extension.service.IService;
import com.glxp.api.req.dev.DeviceCheckQuery;
import com.glxp.api.req.dev.YbNotCodeQuery;
import java.util.List;
public interface YbNotCodeService extends IService<YbNotCode>{
List<YbNotCode> pageList(YbNotCodeQuery query);
Integer add(YbNotCode ybNotCode);
Integer update(YbNotCode ybNotCode);
Integer delete(YbNotCode ybNotCode);
Integer export(YbNotCode ybNotCode);
}

@ -1,8 +1,23 @@
package com.glxp.api.service.basic;
import com.github.pagehelper.PageHelper;
import com.glxp.api.common.res.BaseResponse;
import com.glxp.api.entity.basic.YbNotCode;
import com.baomidou.mybatisplus.extension.service.IService;
import com.glxp.api.req.dev.YbNotCodeQuery;
import org.springframework.http.ResponseEntity;
import java.util.List;
public interface YbNotCodeService extends IService<YbNotCode>{
List<YbNotCode> pageList(YbNotCodeQuery query);
Boolean add(YbNotCode ybNotCode);
Boolean update(YbNotCode ybNotCode);
Boolean delete(YbNotCode ybNotCode);
}

@ -1,12 +1,60 @@
package com.glxp.api.service.basic.impl;
import com.github.pagehelper.PageHelper;
import com.glxp.api.common.res.BaseResponse;
import com.glxp.api.common.util.ResultVOUtils;
import com.glxp.api.req.dev.YbNotCodeQuery;
import com.glxp.api.service.basic.YbNotCodeService;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.glxp.api.entity.basic.YbNotCode;
import com.glxp.api.dao.basic.YbNotCodeMapper;
import javax.annotation.Resource;
import java.io.IOException;
import java.util.List;
import org.springframework.http.HttpHeaders;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
@Service
public class YbNotCodeServiceImpl extends ServiceImpl<YbNotCodeMapper, YbNotCode> implements YbNotCodeService {
@Resource
private YbNotCodeMapper ybNotCodeMapper;
@Override
public List<YbNotCode> pageList(YbNotCodeQuery query) {
if (query.getPage() != null) {
PageHelper.startPage(query.getPage(), query.getLimit());
}
return ybNotCodeMapper.pageList(query);
}
@Override
public Boolean add(YbNotCode ybNotCode) {
return ybNotCodeMapper.insert(ybNotCode) > 0 ? true : false;
}
@Override
public Boolean update(YbNotCode ybNotCode) {
return ybNotCodeMapper.updateById(ybNotCode) > 0 ? true : false;
}
@Override
public Boolean delete(YbNotCode ybNotCode) {
return ybNotCodeMapper.deleteById(ybNotCode) > 0 ? true : false;
}
}

@ -12,4 +12,25 @@
<!--@mbg.generated-->
ybbm, organizationCode, notCodeType
</sql>
</mapper>
<select id="pageList" resultType="com.glxp.api.entity.basic.YbNotCode">
select *,CASE
WHEN notCodeType = 1 THEN '部分早期未赋予追溯码'
WHEN notCodeType = 5 THEN '最小包装无追溯码'
WHEN notCodeType = 6 THEN '无追溯码'
WHEN notCodeType = 7 THEN '其他原因'
WHEN notCodeType = 0 THEN '默认不是无码类型'
ELSE '默认不是无码类型'
END AS notCodeTypeName from yb_not_code
<where>
<if test="vo.ybbm!=null and vo.ybbm!=''">
and ybbm = #{vo.ybbm}
</if>
<if test="vo.organizationCode!=null and vo.organizationCode!=''">
and organizationCode = #{vo.organizationCode}
</if>
<if test="vo.notCodeType!=null and vo.notCodeType!=-1">
and notCodeType = #{vo.notCodeType}
</if>
</where>
</select>
</mapper>

@ -1353,15 +1353,13 @@ CALL Pro_Temp_ColumnWork('basic_udirel', 'notCodeType',
1);
CALL Pro_Temp_ColumnWork('basic_udirel', 'notCodeType',
' tinyint NULL DEFAULT b''0''COMMENT ''无码类型''',
1);
CALL Pro_Temp_ColumnWork('basic_udirel', 'drugSellingPrice',
' decimal(10, 2) DEFAULT NULL COMMENT ''药品售价''',
1);
CALL Pro_Temp_ColumnWork('basic_udirel', 'drugSellingPriceTime',
' datetime DEFAULT NULL COMMENT ''药品售价''',
' datetime DEFAULT NULL COMMENT ''售价开始时间''',
1);
CALL Pro_Temp_ColumnWork('basic_udirel', 'hangingNetType',
' tinyint DEFAULT NULL COMMENT ''是否挂网''',
@ -1371,6 +1369,6 @@ CALL Pro_Temp_ColumnWork('basic_udirel', 'hangingNetType',
CREATE TABLE IF NOT EXISTS `yb_not_code` (
`ybbm` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '国家医保目录编码',
`organizationCode` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '机构编码',
`notCodeType` tinyint DEFAULT NULL COMMENT '无码类型 1、部分早期未赋予追溯码 5、最小包装无追溯码 6、无追溯码 7、其他原因 0、默认不是无码类型',
`notCodeType` tinyint DEFAULT NULL COMMENT '无码类型 0、默认不是无码类型1、部分早期未赋予追溯码5、最小包装无追溯码6、无追溯码7、其他原因',
PRIMARY KEY (`ybbm`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='医保无码信息表';

Loading…
Cancel
Save