加上35051 销售出库上传医保

和3507 删除单据
hlfyyy
qiuyt 4 weeks ago
parent bedafc8a75
commit ccba15f941

@ -326,4 +326,12 @@ public interface BaseHttpClient {
* @return * @return
*/ */
BaseResponse sendGoodsB002(SendGoodsB002Request sendGoodsB002Request); BaseResponse sendGoodsB002(SendGoodsB002Request sendGoodsB002Request);
/**
*
* @param postOrderMedicalDeleteRequest
* @return
*/
BaseResponse orderMedicalDelete(PostOrderMedicalDeleteRequest postOrderMedicalDeleteRequest);
} }

@ -351,6 +351,10 @@ public abstract class CommonHttpClient implements BaseHttpClient {
return null; return null;
} }
@Override
public BaseResponse orderMedicalDelete(PostOrderMedicalDeleteRequest postOrderMedicalDeleteRequest) {
return null;
}

@ -99,7 +99,8 @@ public class HlfyyyClient extends CommonHttpClient {
private final String[] buyType_3506 = {}; private final String[] buyType_3506 = {};
private final String[] buyType_35051 = {"SC72249388338364","SC72197936495755"}; private final String[] buyType_35051 = {"SC72197936495755"};
@Value("${DSF_XML_SQL_TYPE:MySql}") @Value("${DSF_XML_SQL_TYPE:MySql}")
private String defXmlSqlType; private String defXmlSqlType;
@Resource @Resource
@ -1711,7 +1712,7 @@ public class HlfyyyClient extends CommonHttpClient {
} else if (matchBusType(busType, buyType_3506)) { } else if (matchBusType(busType, buyType_3506)) {
optionUploadCollectOrder3506(ioCollectOrder); optionUploadCollectOrder3506(ioCollectOrder);
} else if (matchBusType(busType, buyType_35051)) { } else if (matchBusType(busType, buyType_35051)) {
optionUploadCollectOrder35051(ioCollectOrder); return optionUploadCollectOrder35051(ioCollectOrder);
} else { } else {
return ResultVOUtils.error(500, "上传类型都未对上请检查单据类型"); return ResultVOUtils.error(500, "上传类型都未对上请检查单据类型");
} }
@ -2037,90 +2038,142 @@ public class HlfyyyClient extends CommonHttpClient {
} }
public BaseResponse optionUploadCollectOrder35051(IoCollectOrder ioCollectOrder) { public BaseResponse optionUploadCollectOrder35051(IoCollectOrder ioCollectOrder) {
List<CollectOrderBizResponse> bizList = ioCollectOrder.getCollectOrderBizResponseList();
String stoout_no = StringUtils.isBlank(ioCollectOrder.getBackupOrderRemark1()) ? ioCollectOrder.getBackupOrderRemark2() : ioCollectOrder.getBackupOrderRemark1(); if (CollUtil.isNotEmpty(bizList)) {
List<VInsurNationGoodsPhysic> vInsurNationGoodsPhysics = goodsPhysicMapper.selectList(new LambdaQueryWrapper<VInsurNationGoodsPhysic>().eq(VInsurNationGoodsPhysic::getSTOOUT_NO, stoout_no));
if (CollUtil.isNotEmpty(vInsurNationGoodsPhysics)) {
List<CollectOrderBizResponse> collectOrderBizResponseList = ioCollectOrder.getCollectOrderBizResponseList();
List<Xsck35051Request> xsck35051Requests = new ArrayList<>(); List<Xsck35051Request> xsck35051Requests = new ArrayList<>();
for (CollectOrderBizResponse collectOrderBizResponse : collectOrderBizResponseList) { for (CollectOrderBizResponse item : bizList) {
BasicUdirelEntity basicUdirelEntity = basicUdirelDao.selectById(collectOrderBizResponse.getRelId()); BasicUdirelEntity basicUdirelEntity = basicUdirelDao.selectById(item.getRelId());
String itemCode = basicUdirelEntity.getMainId(); String itemCode = basicUdirelEntity.getMainId();
for (VInsurNationGoodsPhysic vInsurNationGoodsPhysic : vInsurNationGoodsPhysics) { // for (CollectOrderBizResponse item : collectOrderBizResponseList) {
if (vInsurNationGoodsPhysic.getFIXMEDINS_HILIST_ID().equals(itemCode)) { // if (item.getYbbm().equals(itemCode)) {
String[] codes = collectOrderBizResponse.getFinishUdiCode().split(","); String[] codes = item.getFinishUdiCode().split(",");
String nameCode = item.getNameCode();
BasicProductsEntity basicProductsEntity = basicProductsDao.selectOne(
new QueryWrapper<BasicProductsEntity>().eq("nameCode", nameCode).last("limit 1")
);
if (Objects.isNull(basicProductsEntity)) {
return ResultVOUtils.error(500, "产品为空请检查");
}
Integer packLevel = Integer.valueOf(basicProductsEntity.getPackLevel());
List<DrugInfoRequest> drugTraceList = new ArrayList<>(); List<DrugInfoRequest> drugTraceList = new ArrayList<>();
List<String> codeList = new ArrayList<>();
// 遍历fruits数组 // 遍历fruits数组
for (String code : codes) { for (String code : codes) {
if (StrUtil.isNotBlank(code)) { if (StrUtil.isNotBlank(code)) {
List<RelCodeDetail> relCodeDetailList = relCodeDetailService.getAllNext(code); List<RelCodeDetail> relCodeDetailList = relCodeDetailService.getAllNext(code);
if (relCodeDetailList != null && relCodeDetailList.size() > 0) { if (relCodeDetailList != null && relCodeDetailList.size() > 0) {
for (RelCodeDetail relCodeDetail : relCodeDetailList) { for (RelCodeDetail relCodeDetail : relCodeDetailList) {
DrugInfoRequest request = new DrugInfoRequest(); codeList.add(relCodeDetail.getCurCode());
request.setDrug_trac_codg(relCodeDetail.getCurCode());
drugTraceList.add(request);
}
} }
} }
// 级别为2的产品码不可能只有一个
if (packLevel > 1 && codeList.size() < 2) {
return ResultVOUtils.error(500, "大包装码关联关系拉取不到请检查" + code);
}
}
}
Set<String> set = new HashSet(codeList);
for (String code : set) {
DrugInfoRequest request = new DrugInfoRequest();
request.setDrug_trac_codg(code);
drugTraceList.add(request);
}
if (CollUtil.isEmpty(drugTraceList)) {
return ResultVOUtils.error(500, "单据要传的码为空请检查");
} }
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String formattedDate = sdf.format(ioCollectOrder.getBillTime());
//todo 处方药标志先写死 后面要商量怎么获得
String rxFlag ="1";
log.error("optionUploadCollectOrder35051===item==="+item);
Xsck35051Request xsck35051Request = Xsck35051Request.builder() Xsck35051Request xsck35051Request = Xsck35051Request.builder()
.med_list_codg(vInsurNationGoodsPhysic.getMED_LIST_CODG()) .med_list_codg(item.getYbbm())
.fixmedins_hilist_id(vInsurNationGoodsPhysic.getFIXMEDINS_HILIST_ID()) .fixmedins_hilist_id(item.getNameCode())
.fixmedins_hilist_name(vInsurNationGoodsPhysic.getFIXMEDINS_HILIST_NAME()) .fixmedins_hilist_name(item.getCpmctymc())
.fixmedins_bchno(vInsurNationGoodsPhysic.getFIXMEDINS_BCHNO()) .fixmedins_bchno(item.getOrderIdFk())
.prsc_dr_cert_type(vInsurNationGoodsPhysic.getPRSC_DR_CERT_TYPE()) .prsc_dr_cert_type(null)
.prsc_dr_certno(vInsurNationGoodsPhysic.getPRSC_DR_CERTNO()) .prsc_dr_certno(null)
.prsc_dr_name(vInsurNationGoodsPhysic.getPRSC_DR_NAME()) .prsc_dr_name(null)
.phar_cert_type(vInsurNationGoodsPhysic.getPHAR_CERT_TYPE()) .phar_cert_type(null)
.phar_certno(vInsurNationGoodsPhysic.getPHAR_CERTNO()) .phar_certno(null)
.phar_name(vInsurNationGoodsPhysic.getPHAR_NAME()) .phar_name(null)
.phar_prac_cert_no(vInsurNationGoodsPhysic.getPHAR_PRAC_CERT_NO()) .phar_prac_cert_no(null)
.hi_feesetl_type(vInsurNationGoodsPhysic.getHI_FEESETL_TYPE()) .hi_feesetl_type(null)
.setl_id(vInsurNationGoodsPhysic.getSETL_ID()) .setl_id(null)
.mdtrt_sn(vInsurNationGoodsPhysic.getMDTRT_SN()) .mdtrt_sn(null)
.psn_no(vInsurNationGoodsPhysic.getPSN_NO()) .psn_no(null)
.psn_cert_type(vInsurNationGoodsPhysic.getPSN_CERT_TYPE()) .psn_cert_type(null)
.certno(vInsurNationGoodsPhysic.getCERTNO()) .certno(null)
.psn_name(vInsurNationGoodsPhysic.getPSN_NAME()) .psn_name(null)
.manu_lotnum(vInsurNationGoodsPhysic.getMANU_LOTNUM()) .manu_lotnum(item.getBatchNo())
.manu_date(vInsurNationGoodsPhysic.getMANU_DATE()) .manu_date(DateUtil.timeTransition(item.getProductDate()))
.expy_end(vInsurNationGoodsPhysic.getEXPY_END()) .expy_end(DateUtil.timeTransition(item.getExpireDate()))
.rx_flag(vInsurNationGoodsPhysic.getRX_FLAG()) .rx_flag(rxFlag)
.trdn_flag(vInsurNationGoodsPhysic.getTRDN_FLAG()) .trdn_flag(item.getTrdnFlag())
.finl_trns_pric(vInsurNationGoodsPhysic.getFINL_TRNS_PRIC()) .finl_trns_pric(null)
.rxno(vInsurNationGoodsPhysic.getRXNO()) .rxno(null)
.rx_circ_flag(vInsurNationGoodsPhysic.getRX_CIRC_FLAG()) .rx_circ_flag(null)
.rtal_docno(vInsurNationGoodsPhysic.getRTAL_DOCNO()) .rtal_docno(null)
.stoout_no(vInsurNationGoodsPhysic.getSTOOUT_NO()) .stoout_no(null)
.bchno(vInsurNationGoodsPhysic.getBCHNO()) .bchno(null)
.drug_prod_barc(vInsurNationGoodsPhysic.getRUG_PROD_BARC()) .drug_prod_barc(null)
.shelf_posi(vInsurNationGoodsPhysic.getSHELF_POSI()) .shelf_posi(null)
.sel_retn_cnt(vInsurNationGoodsPhysic.getSEL_RETN_CNT()) .sel_retn_cnt(item.getCount())
.sel_retn_time(vInsurNationGoodsPhysic.getSEL_RETN_TIME()) .sel_retn_time(formattedDate)
.sel_retn_opter_name(vInsurNationGoodsPhysic.getSEL_RETN_OPTER_NAME()) .sel_retn_opter_name(ioCollectOrder.getCreateUser())
.memo(vInsurNationGoodsPhysic.getMEMO()) .memo(null)
.mdtrt_setl_type(vInsurNationGoodsPhysic.getMDTRT_SETL_TYPE()) .mdtrt_setl_type(null)
.drugtracinfo(drugTraceList).build(); .drugtracinfo(drugTraceList).build();
xsck35051Requests.add(xsck35051Request); xsck35051Requests.add(xsck35051Request);
} // }
} // }
} }
BaseXsck35051Request baseXsck35051Request = new BaseXsck35051Request(); BaseXsck35051Request baseXsck35051Request = new BaseXsck35051Request();
baseXsck35051Request.setSelinfoDetail(xsck35051Requests); baseXsck35051Request.setSelinfoDetail(xsck35051Requests);
String jsonStr = JSONUtil.toJsonStr(baseXsck35051Request); String jsonStr = JSONUtil.toJsonStr(baseXsck35051Request);
JSONObject dataJson = JSONObject.parseObject(jsonStr); JSONObject dataJson = JSONObject.parseObject(jsonStr);
return ybClient.ybPost("35051", dataJson); return ybClient.ybPost("35051", dataJson);
} else { } else {
return ResultVOUtils.error(500, "医保视图数据查不到,请核实"); return ResultVOUtils.error(500, "上传医保数据为空请核实");
}
} }
@Override
public BaseResponse orderMedicalDelete(PostOrderMedicalDeleteRequest postOrderMedicalDeleteRequest) {
List<Xsck3507Request> xsck35057Requests = new ArrayList<>();
String invDataType=null;
if (matchBusType(postOrderMedicalDeleteRequest.getBusType(), buyType_3501)) {
invDataType="1";
} else if (matchBusType(postOrderMedicalDeleteRequest.getBusType(), buyType_3502)) {
invDataType="2";
} else if (matchBusType(postOrderMedicalDeleteRequest.getBusType(), buyType_3505)) {
invDataType="4";
} else if (matchBusType(postOrderMedicalDeleteRequest.getBusType(), buyType_3506)) {
invDataType="4";
} else if (matchBusType(postOrderMedicalDeleteRequest.getBusType(), buyType_35051)) {
invDataType="4";
}
Xsck3507Request xsck3507Request = Xsck3507Request.builder()
.med_list_codg(postOrderMedicalDeleteRequest.getBillNo())
.inv_data_type(invDataType).build();
xsck35057Requests.add(xsck3507Request);
BaseXsck3507Request baseXsck3507Request = new BaseXsck3507Request();
baseXsck3507Request.setGoodDetail(xsck35057Requests);
String jsonStr = JSONUtil.toJsonStr(baseXsck3507Request);
JSONObject dataJson = JSONObject.parseObject(jsonStr);
return ybClient.ybPost("3507A", dataJson);
} }
public void optionUploadCollectOrder3501(IoCollectOrder ioCollectOrder) { public void optionUploadCollectOrder3501(IoCollectOrder ioCollectOrder) {
List<IoCollectOrderBiz> bizList = ioCollectOrder.getBizList(); List<IoCollectOrderBiz> bizList = ioCollectOrder.getBizList();
if (CollUtil.isNotEmpty(bizList)) { if (CollUtil.isNotEmpty(bizList)) {
@ -2227,7 +2280,7 @@ public class HlfyyyClient extends CommonHttpClient {
.inv_chg_type("108") .inv_chg_type("108")
.fixmedins_hilist_id(item.getThrCode()) .fixmedins_hilist_id(item.getThrCode())
.fixmedins_hilist_name(item.getCpmctymc()) .fixmedins_hilist_name(item.getCpmctymc())
.fixmedins_bchno("0000") .fixmedins_bchno(item.getOrderIdFk())
.pric("0") .pric("0")
.cnt(item.getActCount()) .cnt(item.getActCount())
.rx_flag("1") .rx_flag("1")

@ -8,6 +8,7 @@ import com.glxp.mipsdl.req.ctqyy.FilterThrHslbRequest;
import com.glxp.mipsdl.req.ctqyy.GetSickPrescribeRequest; import com.glxp.mipsdl.req.ctqyy.GetSickPrescribeRequest;
import com.glxp.mipsdl.req.ctqyy.GetSickRequest; import com.glxp.mipsdl.req.ctqyy.GetSickRequest;
import com.glxp.mipsdl.req.post.PostCollectOrderRequest; import com.glxp.mipsdl.req.post.PostCollectOrderRequest;
import com.glxp.mipsdl.req.post.PostOrderMedicalDeleteRequest;
import com.glxp.mipsdl.req.post.PostRelProductRequest; import com.glxp.mipsdl.req.post.PostRelProductRequest;
import com.glxp.mipsdl.req.pzh.USignRequest; import com.glxp.mipsdl.req.pzh.USignRequest;
import com.glxp.mipsdl.res.BaseResponse; import com.glxp.mipsdl.res.BaseResponse;
@ -364,4 +365,16 @@ public class UdiWmsController {
public BaseResponse getBuyType() { public BaseResponse getBuyType() {
return ClientProcessor.getHttpClient().getBuyType(); return ClientProcessor.getHttpClient().getBuyType();
} }
/**
*
*
* @param postOrderMedicalDeleteRequest
* @return
*/
@PostMapping("/udiwms/erp/orderMedicalDelete")
public BaseResponse orderMedicalDelete(@RequestBody PostOrderMedicalDeleteRequest postOrderMedicalDeleteRequest) {
return ClientProcessor.getHttpClient().orderMedicalDelete(postOrderMedicalDeleteRequest);
}
} }

@ -1,5 +1,6 @@
package com.glxp.mipsdl.entity.inout; package com.glxp.mipsdl.entity.inout;
import com.baomidou.mybatisplus.annotation.TableField;
import lombok.Data; import lombok.Data;
import java.util.Date; import java.util.Date;
@ -127,4 +128,6 @@ public class CollectOrderBizResponse {
private Integer autoResCount; private Integer autoResCount;
private String replaceCode; private String replaceCode;
private String trdnFlag;
} }

@ -213,5 +213,6 @@ public class IoCollectOrder implements Serializable {
@TableField(exist = false) @TableField(exist = false)
private List<IoCollectOrderBiz> bizList; private List<IoCollectOrderBiz> bizList;
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
} }

@ -0,0 +1,14 @@
package com.glxp.mipsdl.req.post;
import lombok.Data;
@Data
public class PostOrderMedicalDeleteRequest {
private String thirdSys;
private String billNo;
private String busType;
}

@ -0,0 +1,10 @@
package com.glxp.mipsdl.req.yb;
import lombok.Data;
import java.util.List;
@Data
public class BaseXsck3507Request {
private List<Xsck3507Request> goodDetail;
}

@ -0,0 +1,33 @@
package com.glxp.mipsdl.req.yb;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
*
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class Xsck3507Request {
/**
*
*/
private String med_list_codg;
/**
* 1-2-3-4-
*/
private String inv_data_type;
}

@ -86,7 +86,7 @@ public class YbClient {
){ ){
if(apiNo.equals("3505A") && "成功".equals(resp.getErrMsg())){ if((apiNo.equals("3505A") || apiNo.equals("35051")) && "成功".equals(resp.getErrMsg())){
return ResultVOUtils.success("【" + apiNo + "】上传医保成功"); return ResultVOUtils.success("【" + apiNo + "】上传医保成功");
}else if(apiNo.equals("3502A") && org.apache.commons.lang3.StringUtils.isEmpty(resp.getErrMsg())){ }else if(apiNo.equals("3502A") && org.apache.commons.lang3.StringUtils.isEmpty(resp.getErrMsg())){

@ -9,6 +9,8 @@ import lombok.extern.slf4j.Slf4j;
import java.lang.management.ManagementFactory; import java.lang.management.ManagementFactory;
import java.text.DateFormat; import java.text.DateFormat;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.util.*; import java.util.*;
@Slf4j @Slf4j
@ -482,4 +484,19 @@ public class DateUtil {
String formattedDate = sdf.format(date); String formattedDate = sdf.format(date);
return formattedDate; return formattedDate;
} }
public static String timeTransition(String input) {
if(StrUtil.isEmpty(input)){
return null;
}
// 定义输入日期的格式
DateTimeFormatter inputFormatter = DateTimeFormatter.ofPattern("yyMMdd");
// 定义输出日期的格式
DateTimeFormatter outputFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
// 将输入字符串解析为 LocalDate 对象
LocalDate date = LocalDate.parse(input, inputFormatter);
// 将 LocalDate 对象格式化为目标字符串
String output = date.format(outputFormatter);
return output;
}
} }

Loading…
Cancel
Save