药品目录和器材目录更新
This commit is contained in:
		| @@ -4,6 +4,7 @@ import com.openhis.administration.domain.ChargeItemDefinition; | |||||||
| import com.openhis.administration.domain.DeviceDefinition; | import com.openhis.administration.domain.DeviceDefinition; | ||||||
| import com.openhis.medication.domain.MedicationDetail; | import com.openhis.medication.domain.MedicationDetail; | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageUpDto; | import com.openhis.web.datadictionary.dto.DeviceManageUpDto; | ||||||
|  | import com.openhis.web.datadictionary.dto.ItemUpFromDirectoryDto; | ||||||
| import com.openhis.web.datadictionary.dto.MedicationManageUpDto; | import com.openhis.web.datadictionary.dto.MedicationManageUpDto; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -15,12 +16,11 @@ import com.openhis.web.datadictionary.dto.MedicationManageUpDto; | |||||||
| public interface IItemDefinitionService { | public interface IItemDefinitionService { | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 添加药品的项目定价 |      * 添加药品/器材/诊疗的项目定价 | ||||||
|      * |      * | ||||||
|      * @param medicationManageUpDto 药品目录信息 |      * @param itemUpFromDirectoryDto 药品/器材/诊疗目录信息 | ||||||
|      * @param medicationDetail 药品信息 |  | ||||||
|      */ |      */ | ||||||
|     boolean addItem(MedicationManageUpDto medicationManageUpDto, MedicationDetail medicationDetail); |     boolean addItem(ItemUpFromDirectoryDto itemUpFromDirectoryDto); | ||||||
|  |  | ||||||
|  |  | ||||||
| //    /** | //    /** | ||||||
| @@ -29,8 +29,8 @@ public interface IItemDefinitionService { | |||||||
| //     * @param deviceManageUpDto 器材目录信息 | //     * @param deviceManageUpDto 器材目录信息 | ||||||
| //     * @param deviceDefinition 器材信息 | //     * @param deviceDefinition 器材信息 | ||||||
| //     */ | //     */ | ||||||
| //    boolean addItem(DeviceManageUpDto deviceManageUpDto, DeviceDefinition deviceDefinition); | //    boolean addItem(ItemUpFromDirectoryDto itemUpFromDirectoryDto, DeviceDefinition deviceDefinition); | ||||||
|  | // | ||||||
|     /** |     /** | ||||||
|      * 修改项目定价表 |      * 修改项目定价表 | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -13,10 +13,10 @@ import java.util.stream.Stream; | |||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
|  |  | ||||||
|  | import com.openhis.web.datadictionary.dto.*; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.PathVariable; |  | ||||||
| import org.springframework.web.bind.annotation.RequestBody; | import org.springframework.web.bind.annotation.RequestBody; | ||||||
| import org.springframework.web.bind.annotation.RequestParam; | import org.springframework.web.bind.annotation.RequestParam; | ||||||
|  |  | ||||||
| @@ -25,8 +25,11 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | |||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
|  | import com.core.common.core.domain.entity.SysDictData; | ||||||
| import com.core.common.utils.MessageUtils; | import com.core.common.utils.MessageUtils; | ||||||
|  | import com.core.common.utils.SecurityUtils; | ||||||
| import com.core.common.utils.bean.BeanUtils; | import com.core.common.utils.bean.BeanUtils; | ||||||
|  | import com.core.system.service.ISysDictTypeService; | ||||||
| import com.openhis.administration.domain.DeviceDefinition; | import com.openhis.administration.domain.DeviceDefinition; | ||||||
| import com.openhis.administration.domain.Organization; | import com.openhis.administration.domain.Organization; | ||||||
| import com.openhis.administration.mapper.DeviceDefinitionMapper; | import com.openhis.administration.mapper.DeviceDefinitionMapper; | ||||||
| @@ -34,20 +37,14 @@ import com.openhis.administration.service.IDeviceDefinitionService; | |||||||
| import com.openhis.administration.service.IOrganizationService; | import com.openhis.administration.service.IOrganizationService; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.CommonConstants; | ||||||
| import com.openhis.common.constant.PromptMsgConstant; | import com.openhis.common.constant.PromptMsgConstant; | ||||||
| import com.openhis.common.enums.DeviceCategory; |  | ||||||
| import com.openhis.common.enums.OrganizationType; | import com.openhis.common.enums.OrganizationType; | ||||||
| import com.openhis.common.enums.PublicationStatus; | import com.openhis.common.enums.PublicationStatus; | ||||||
| import com.openhis.common.enums.Whether; | import com.openhis.common.enums.Whether; | ||||||
| import com.openhis.common.utils.EnumUtils; | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisPageUtils; |  | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| import com.openhis.web.datadictionary.appservice.IDeviceManageAppService; | import com.openhis.web.datadictionary.appservice.IDeviceManageAppService; | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageDto; | import com.openhis.web.datadictionary.appservice.IItemDefinitionService; | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageInitDto; |  | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageSelParam; |  | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageUpDto; |  | ||||||
| import com.openhis.web.datadictionary.mapper.DeviceManageMapper; | import com.openhis.web.datadictionary.mapper.DeviceManageMapper; | ||||||
| import com.openhis.web.doctorstation.dto.AdviceBaseDto; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 器材目录 impl |  * 器材目录 impl | ||||||
| @@ -70,6 +67,12 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|     @Resource |     @Resource | ||||||
|     DeviceManageMapper deviceManageMapper; |     DeviceManageMapper deviceManageMapper; | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private ISysDictTypeService sysDictTypeService; | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private IItemDefinitionService itemDefinitionServic; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 器材目录初始化 |      * 器材目录初始化 | ||||||
|      * |      * | ||||||
| @@ -77,12 +80,15 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> getDeviceManageInit() { |     public R<?> getDeviceManageInit() { | ||||||
|  |  | ||||||
|         DeviceManageInitDto deviceManageInitDto = new DeviceManageInitDto(); |         DeviceManageInitDto deviceManageInitDto = new DeviceManageInitDto(); | ||||||
|  |  | ||||||
|         // 获取状态 |         // 获取状态 | ||||||
|         List<DeviceManageInitDto.statusEnumOption> statusEnumOptions = Stream.of(PublicationStatus.values()) |         List<DeviceManageInitDto.statusEnumOption> statusEnumOptions = Stream.of(PublicationStatus.values()) | ||||||
|             .map(status -> new DeviceManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) |             .map(status -> new DeviceManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) | ||||||
|             .collect(Collectors.toList()); |             .collect(Collectors.toList()); | ||||||
|         deviceManageInitDto.setStatusFlagOptions(statusEnumOptions); |         deviceManageInitDto.setStatusFlagOptions(statusEnumOptions); | ||||||
|  |  | ||||||
|         // 获取执行科室 |         // 获取执行科室 | ||||||
|         LambdaQueryWrapper<Organization> queryWrapper = new LambdaQueryWrapper<>(); |         LambdaQueryWrapper<Organization> queryWrapper = new LambdaQueryWrapper<>(); | ||||||
|         queryWrapper.eq(Organization::getTypeEnum, OrganizationType.HOSPITAL_DEPARTMENT); |         queryWrapper.eq(Organization::getTypeEnum, OrganizationType.HOSPITAL_DEPARTMENT); | ||||||
| @@ -91,11 +97,27 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|             .map(exeOrg -> new DeviceManageInitDto.exeOrganization(exeOrg.getId(), exeOrg.getName())) |             .map(exeOrg -> new DeviceManageInitDto.exeOrganization(exeOrg.getId(), exeOrg.getName())) | ||||||
|             .collect(Collectors.toList()); |             .collect(Collectors.toList()); | ||||||
|         deviceManageInitDto.setExeOrganizations(exeOrganizations); |         deviceManageInitDto.setExeOrganizations(exeOrganizations); | ||||||
|         // 获取分类 |         // // 从枚举中获取器材分类 | ||||||
|         List<DeviceManageInitDto.deviceCategory> deviceCategories = Stream.of(DeviceCategory.values()) |         // List<DeviceManageInitDto.deviceCategory> deviceCategories = Stream.of(DeviceCategory.values()) | ||||||
|             .map(category -> new DeviceManageInitDto.deviceCategory(category.getValue(), category.getInfo())) |         // .map(category -> new DeviceManageInitDto.deviceCategory(category.getValue(), category.getInfo())) | ||||||
|  |         // .collect(Collectors.toList()); | ||||||
|  |         // deviceManageInitDto.setDeviceCategories(deviceCategories); | ||||||
|  |  | ||||||
|  |         // 获取器材 | ||||||
|  |         List<SysDictData> devicelList = | ||||||
|  |             sysDictTypeService.selectDictDataByType(CommonConstants.DictName.DEVICE_CATEGORY_CODE); | ||||||
|  |         // 从字典中获取器材分类 | ||||||
|  |         List<DeviceManageInitDto.dictCategoryCode> deviceCategories = devicelList.stream() | ||||||
|  |             .map(category -> new DeviceManageInitDto.dictCategoryCode(category.getDictValue(), category.getDictLabel())) | ||||||
|             .collect(Collectors.toList()); |             .collect(Collectors.toList()); | ||||||
|         deviceManageInitDto.setDeviceCategories(deviceCategories); |         deviceManageInitDto.setDeviceCategories(deviceCategories); | ||||||
|  |  | ||||||
|  |         // 获取医保是否对码 | ||||||
|  |         List<DeviceManageInitDto.statusEnumOption> statusYBWeatherOption = Stream.of(Whether.values()) | ||||||
|  |             .map(status -> new DeviceManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) | ||||||
|  |             .collect(Collectors.toList()); | ||||||
|  |         deviceManageInitDto.setStatusYBWeatherOptions(statusYBWeatherOption); | ||||||
|  |  | ||||||
|         return R.ok(deviceManageInitDto); |         return R.ok(deviceManageInitDto); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -114,15 +136,16 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) { |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) { | ||||||
|  |  | ||||||
| //        // 构建查询条件 |         // // 构建查询条件 | ||||||
| //        QueryWrapper<DeviceDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper(deviceManageSelParam, searchKey, |         // QueryWrapper<DeviceDefinition> queryWrapper = HisQueryUtils.buildQueryWrapper(deviceManageSelParam, | ||||||
| //            new HashSet<>(Arrays.asList("bus_no", "name", "py_str", "wb_str")), request); |         // searchKey, | ||||||
| //        // 设置排序 |         // new HashSet<>(Arrays.asList("bus_no", "name", "py_str", "wb_str")), request); | ||||||
| //        queryWrapper.orderByAsc("bus_no"); |         // // 设置排序 | ||||||
| // |         // queryWrapper.orderByAsc("bus_no"); | ||||||
| //        // 分页查询 |         // | ||||||
| //        Page<DeviceManageDto> deviceManagePage = |         // // 分页查询 | ||||||
| //            HisPageUtils.selectPage(deviceDefinitionMapper, queryWrapper, pageNo, pageSize, DeviceManageDto.class); |         // Page<DeviceManageDto> deviceManagePage = | ||||||
|  |         // HisPageUtils.selectPage(deviceDefinitionMapper, queryWrapper, pageNo, pageSize, DeviceManageDto.class); | ||||||
|  |  | ||||||
|         // 构建查询条件 |         // 构建查询条件 | ||||||
|         QueryWrapper<DeviceManageDto> queryWrapper = HisQueryUtils.buildQueryWrapper(deviceManageSelParam, searchKey, |         QueryWrapper<DeviceManageDto> queryWrapper = HisQueryUtils.buildQueryWrapper(deviceManageSelParam, searchKey, | ||||||
| @@ -142,7 +165,7 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|             // 过敏标记枚举类回显赋值 |             // 过敏标记枚举类回显赋值 | ||||||
|             e.setAllergenFlag_enumText(EnumUtils.getInfoByValue(Whether.class, e.getAllergenFlag())); |             e.setAllergenFlag_enumText(EnumUtils.getInfoByValue(Whether.class, e.getAllergenFlag())); | ||||||
|             // 器材分类 |             // 器材分类 | ||||||
|             e.setCategoryEnum_enumText(EnumUtils.getInfoByValue(DeviceCategory.class, e.getCategoryEnum())); |             // e.setCategoryEnum_enumText(EnumUtils.getInfoByValue(DeviceCategory.class, e.getCategoryEnum())); | ||||||
|             // 器材状态 |             // 器材状态 | ||||||
|             e.setStatusEnum_enumText(EnumUtils.getInfoByValue(PublicationStatus.class, e.getStatusEnum())); |             e.setStatusEnum_enumText(EnumUtils.getInfoByValue(PublicationStatus.class, e.getStatusEnum())); | ||||||
|         }); |         }); | ||||||
| @@ -176,9 +199,13 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public R<?> getDeviceOne(@RequestParam Long id) { |     public R<?> getDeviceOne(@RequestParam Long id) { | ||||||
|  |  | ||||||
|  |         // 获取租户ID | ||||||
|  |         Integer tenantId = SecurityUtils.getLoginUser().getTenantId(); | ||||||
|         // 根据ID查询【器材目录】 |         // 根据ID查询【器材目录】 | ||||||
|         DeviceDefinition byId = deviceDefinitionService.getById(id); |         DeviceManageDto deviceManageDto = deviceManageMapper.getOne(id, tenantId); | ||||||
|         return R.ok(byId); |  | ||||||
|  |         return R.ok(deviceManageDto); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -196,7 +223,7 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|         for (Long detail : ids) { |         for (Long detail : ids) { | ||||||
|             DeviceDefinition deviceDefinition = new DeviceDefinition(); |             DeviceDefinition deviceDefinition = new DeviceDefinition(); | ||||||
|             deviceDefinition.setId(detail); |             deviceDefinition.setId(detail); | ||||||
|             deviceDefinition.setStatusEnum(PublicationStatus.RETIRED); |             deviceDefinition.setStatusEnum(PublicationStatus.RETIRED.getValue()); | ||||||
|             DeviceDefinitionList.add(deviceDefinition); |             DeviceDefinitionList.add(deviceDefinition); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -221,7 +248,7 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|         for (Long detail : ids) { |         for (Long detail : ids) { | ||||||
|             DeviceDefinition DeviceDefinition = new DeviceDefinition(); |             DeviceDefinition DeviceDefinition = new DeviceDefinition(); | ||||||
|             DeviceDefinition.setId(detail); |             DeviceDefinition.setId(detail); | ||||||
|             DeviceDefinition.setStatusEnum(PublicationStatus.ACTIVE); |             DeviceDefinition.setStatusEnum(PublicationStatus.ACTIVE.getValue()); | ||||||
|             DeviceDefinitionList.add(DeviceDefinition); |             DeviceDefinitionList.add(DeviceDefinition); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -243,9 +270,17 @@ public class DeviceManageAppServiceImpl implements IDeviceManageAppService { | |||||||
|         BeanUtils.copyProperties(deviceManageUpDto, deviceDefinition); |         BeanUtils.copyProperties(deviceManageUpDto, deviceDefinition); | ||||||
|  |  | ||||||
|         // 新增外来器材目录 |         // 新增外来器材目录 | ||||||
|         deviceDefinition.setStatusEnum(PublicationStatus.DRAFT); |         deviceDefinition.setStatusEnum(PublicationStatus.DRAFT.getValue()); | ||||||
|         return deviceDefinitionService.addDevice(deviceDefinition) |  | ||||||
|  |         if (deviceDefinitionService.addDevice(deviceDefinition)) { | ||||||
|  |             ItemUpFromDirectoryDto itemUpFromDirectoryDto =new ItemUpFromDirectoryDto(); | ||||||
|  |             BeanUtils.copyProperties(deviceManageUpDto, itemUpFromDirectoryDto); | ||||||
|  |  | ||||||
|  |             return itemDefinitionServic.addItem(itemUpFromDirectoryDto) | ||||||
|                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"器材目录"})) |                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"器材目录"})) | ||||||
|                 : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00008, null)); |                 : R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00008, null)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         return R.fail(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00008, null)); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,7 +4,12 @@ import java.util.ArrayList; | |||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||||
|  | import com.core.common.utils.SecurityUtils; | ||||||
|  | import com.core.common.utils.bean.BeanUtils; | ||||||
|  | import com.openhis.administration.domain.DeviceDefinition; | ||||||
| import com.openhis.common.enums.ConditionCode; | import com.openhis.common.enums.ConditionCode; | ||||||
|  | import com.openhis.web.datadictionary.dto.DeviceManageUpDto; | ||||||
|  | import com.openhis.web.datadictionary.dto.ItemUpFromDirectoryDto; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| @@ -38,55 +43,48 @@ public class ItemDefinitionServiceImpl implements IItemDefinitionService { | |||||||
|  |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 添加项目定价 |      * 添加药品/器材/诊疗的项目定价 | ||||||
|      * |      * | ||||||
|      * @param medicationManageUpDto 药品目录信息 |      * @param itemUpFromDirectoryDto 药品/器材/诊疗目录信息 | ||||||
|      * @param medicationDetail 药品信息 |  | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public boolean addItem(MedicationManageUpDto medicationManageUpDto, MedicationDetail medicationDetail) { |     public boolean addItem(ItemUpFromDirectoryDto itemUpFromDirectoryDto) { | ||||||
|  |  | ||||||
|  |  | ||||||
|         ChargeItemDefinition chargeItemDefinition = new ChargeItemDefinition(); |         ChargeItemDefinition chargeItemDefinition = new ChargeItemDefinition(); | ||||||
|         chargeItemDefinition.setChargeName(medicationDetail.getName()) |         BeanUtils.copyProperties(itemUpFromDirectoryDto, chargeItemDefinition); | ||||||
|             .setStatusEnum(PublicationStatus.ACTIVE.getValue()) |  | ||||||
|             .setInstanceTable(CommonConstants.TableName.MED_MEDICATION_DEFINITION) |  | ||||||
|             .setInstanceId(medicationDetail.getMedicationDefId()).setEffectiveStart(DateUtils.getNowDate()) |  | ||||||
|             // 机构ID |  | ||||||
|             // .setOrgId(SecurityUtils.getLoginUser().getOrgId()) |  | ||||||
|             .setOrgId(1l)// todo 没数据先写死 |  | ||||||
|             // 财务类别 |  | ||||||
|             .setTypeCode(medicationManageUpDto.getTypeCode()) |  | ||||||
|             // 医保类别 |  | ||||||
|             .setYbType(medicationManageUpDto.getYbType()).setConditionFlag(Whether.YES.getValue()) |  | ||||||
|             .setPrice(medicationManageUpDto.getRetailPrice()); |  | ||||||
|         boolean insertCIDSuccess = chargeItemDefinitionService.save(chargeItemDefinition); |         boolean insertCIDSuccess = chargeItemDefinitionService.save(chargeItemDefinition); | ||||||
|  |  | ||||||
|         if (insertCIDSuccess) { |         if (insertCIDSuccess) { | ||||||
|             List<ChargeItemDefDetail> shargeItemDefDetails = new ArrayList<>(); |             List<ChargeItemDefDetail> shargeItemDefDetails = new ArrayList<>(); | ||||||
|  |             //插入购入价 | ||||||
|             ChargeItemDefDetail chargeItemDefDetail1 = new ChargeItemDefDetail(); |             ChargeItemDefDetail chargeItemDefDetail1 = new ChargeItemDefDetail(); | ||||||
|             chargeItemDefDetail1.setDefinitionId(chargeItemDefinition.getId()) |             chargeItemDefDetail1.setDefinitionId(chargeItemDefinition.getId()) | ||||||
|                 // 条件:采购 |                 // 条件:采购 | ||||||
|                 .setConditionCode(ConditionCode.PROCUREMENT.getCode()) |                 .setConditionCode(ConditionCode.PROCUREMENT.getCode()) | ||||||
|                 // 购入价 |                 // 购入价 | ||||||
|                 .setAmount(medicationManageUpDto.getPurchasePrice()); |                 .setAmount(itemUpFromDirectoryDto.getPurchasePrice()); | ||||||
|  |             shargeItemDefDetails.add(chargeItemDefDetail1); | ||||||
|  |             //插入零售价 | ||||||
|             ChargeItemDefDetail chargeItemDefDetail2 = new ChargeItemDefDetail(); |             ChargeItemDefDetail chargeItemDefDetail2 = new ChargeItemDefDetail(); | ||||||
|             chargeItemDefDetail2.setDefinitionId(chargeItemDefinition.getId()) |             chargeItemDefDetail2.setDefinitionId(chargeItemDefinition.getId()) | ||||||
|                 // 条件:单位 |                 // 条件:单位 | ||||||
|                 .setConditionCode(ConditionCode.UNIT.getCode()) |                 .setConditionCode(ConditionCode.UNIT.getCode()) | ||||||
|                 //单位枚举 |                 //单位枚举 | ||||||
|                 .setConditionValue(medicationManageUpDto.getUnitCode()) |                 .setConditionValue(itemUpFromDirectoryDto.getUnitCode()) | ||||||
|                 // 零售价 |                 // 零售价 | ||||||
|                 .setAmount(medicationManageUpDto.getRetailPrice()); |                 .setAmount(itemUpFromDirectoryDto.getRetailPrice()); | ||||||
|  |  | ||||||
|             shargeItemDefDetails.add(chargeItemDefDetail2); |             shargeItemDefDetails.add(chargeItemDefDetail2); | ||||||
|  |  | ||||||
|  |             //插入最高零售价 | ||||||
|             ChargeItemDefDetail chargeItemDefDetail3 = new ChargeItemDefDetail(); |             ChargeItemDefDetail chargeItemDefDetail3 = new ChargeItemDefDetail(); | ||||||
|             chargeItemDefDetail3.setDefinitionId(chargeItemDefinition.getId()) |             chargeItemDefDetail3.setDefinitionId(chargeItemDefinition.getId()) | ||||||
|                 // 条件:限制 |                 // 条件:限制 | ||||||
|                 .setConditionCode(ConditionCode.LIMIT.getCode()) |                 .setConditionCode(ConditionCode.LIMIT.getCode()) | ||||||
|                 // 最高零售价 |                 // 最高零售价 | ||||||
|                 .setAmount(medicationManageUpDto.getMaximumRetailPrice()); |                 .setAmount(itemUpFromDirectoryDto.getMaximumRetailPrice()); | ||||||
|  |  | ||||||
|             shargeItemDefDetails.add(chargeItemDefDetail3); |             shargeItemDefDetails.add(chargeItemDefDetail3); | ||||||
|  |  | ||||||
| @@ -96,6 +94,7 @@ public class ItemDefinitionServiceImpl implements IItemDefinitionService { | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 修改项目定价表 |      * 修改项目定价表 | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -13,7 +13,8 @@ import java.util.stream.Stream; | |||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
| import javax.servlet.http.HttpServletResponse; | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
| import com.openhis.common.enums.*; | import com.core.common.utils.*; | ||||||
|  | import com.openhis.web.datadictionary.dto.*; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| @@ -25,9 +26,6 @@ import com.baomidou.mybatisplus.core.metadata.IPage; | |||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.core.common.core.domain.entity.SysDictData; | import com.core.common.core.domain.entity.SysDictData; | ||||||
| import com.core.common.utils.ChineseConvertUtils; |  | ||||||
| import com.core.common.utils.MessageUtils; |  | ||||||
| import com.core.common.utils.SecurityUtils; |  | ||||||
| import com.core.common.utils.bean.BeanUtils; | import com.core.common.utils.bean.BeanUtils; | ||||||
| import com.core.common.utils.poi.ExcelUtil; | import com.core.common.utils.poi.ExcelUtil; | ||||||
| import com.core.system.service.ISysDictTypeService; | import com.core.system.service.ISysDictTypeService; | ||||||
| @@ -36,6 +34,7 @@ import com.openhis.administration.domain.Supplier; | |||||||
| import com.openhis.administration.service.ISupplierService; | import com.openhis.administration.service.ISupplierService; | ||||||
| import com.openhis.common.constant.CommonConstants; | import com.openhis.common.constant.CommonConstants; | ||||||
| import com.openhis.common.constant.PromptMsgConstant; | import com.openhis.common.constant.PromptMsgConstant; | ||||||
|  | import com.openhis.common.enums.*; | ||||||
| import com.openhis.common.utils.EnumUtils; | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
| import com.openhis.medication.domain.Medication; | import com.openhis.medication.domain.Medication; | ||||||
| @@ -45,10 +44,6 @@ import com.openhis.medication.service.IMedicationDefinitionService; | |||||||
| import com.openhis.medication.service.IMedicationService; | import com.openhis.medication.service.IMedicationService; | ||||||
| import com.openhis.web.datadictionary.appservice.IItemDefinitionService; | import com.openhis.web.datadictionary.appservice.IItemDefinitionService; | ||||||
| import com.openhis.web.datadictionary.appservice.IMedicationManageAppService; | import com.openhis.web.datadictionary.appservice.IMedicationManageAppService; | ||||||
| import com.openhis.web.datadictionary.dto.MedicationManageDto; |  | ||||||
| import com.openhis.web.datadictionary.dto.MedicationManageInitDto; |  | ||||||
| import com.openhis.web.datadictionary.dto.MedicationManageUpDto; |  | ||||||
| import com.openhis.web.datadictionary.dto.MedicationSearchParam; |  | ||||||
| import com.openhis.web.datadictionary.mapper.MedicationManageSearchMapper; | import com.openhis.web.datadictionary.mapper.MedicationManageSearchMapper; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -77,6 +72,9 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|     @Autowired |     @Autowired | ||||||
|     private IItemDefinitionService itemDefinitionServic; |     private IItemDefinitionService itemDefinitionServic; | ||||||
|  |  | ||||||
|  |     @Autowired(required = false) | ||||||
|  |     AssignSeqUtil assignSeqUtil; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 药品目录初始化 |      * 药品目录初始化 | ||||||
|      * |      * | ||||||
| @@ -120,13 +118,14 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|             .map(status -> new MedicationManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) |             .map(status -> new MedicationManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) | ||||||
|             .collect(Collectors.toList()); |             .collect(Collectors.toList()); | ||||||
|  |  | ||||||
|         //拆分属性 |         // 拆分属性 | ||||||
|         List<MedicationManageInitDto.statusEnumOption> partAttributeEnumOptions = Stream.of(SplitPropertyCode.values()) |         List<MedicationManageInitDto.statusEnumOption> partAttributeEnumOptions = Stream.of(SplitPropertyCode.values()) | ||||||
|             .map(status -> new MedicationManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) |             .map(status -> new MedicationManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) | ||||||
|             .collect(Collectors.toList()); |             .collect(Collectors.toList()); | ||||||
|  |  | ||||||
|         //住院临时医嘱拆分属性的枚举 |         // 住院临时医嘱拆分属性的枚举 | ||||||
|         List<MedicationManageInitDto.statusEnumOption> tempOrderSplitPropertyOptions = Stream.of(TempOrderSplitPropertyCode.values()) |         List<MedicationManageInitDto.statusEnumOption> tempOrderSplitPropertyOptions = | ||||||
|  |             Stream.of(TempOrderSplitPropertyCode.values()) | ||||||
|                 .map(status -> new MedicationManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) |                 .map(status -> new MedicationManageInitDto.statusEnumOption(status.getValue(), status.getInfo())) | ||||||
|                 .collect(Collectors.toList()); |                 .collect(Collectors.toList()); | ||||||
|  |  | ||||||
| @@ -193,10 +192,12 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|             e.setAntibioticFlag_enumText(EnumUtils.getInfoByValue(Whether.class, e.getAntibioticFlag())); |             e.setAntibioticFlag_enumText(EnumUtils.getInfoByValue(Whether.class, e.getAntibioticFlag())); | ||||||
|             // 基药标识 |             // 基药标识 | ||||||
|             e.setBasicFlag_enumText(EnumUtils.getInfoByValue(Whether.class, e.getBasicFlag())); |             e.setBasicFlag_enumText(EnumUtils.getInfoByValue(Whether.class, e.getBasicFlag())); | ||||||
|             //拆分分属性 |             // 拆分分属性 | ||||||
|             e.setPartAttributeEnum_enumText(EnumUtils.getInfoByValue(SplitPropertyCode.class, e.getPartAttributeEnum())); |             e.setPartAttributeEnum_enumText( | ||||||
|             //住院临时医嘱拆分属性 |                 EnumUtils.getInfoByValue(SplitPropertyCode.class, e.getPartAttributeEnum())); | ||||||
|             e.setThoPartAttributeEnum_enumText(EnumUtils.getInfoByValue(TempOrderSplitPropertyCode.class, e.getThoPartAttributeEnum())); |             // 住院临时医嘱拆分属性 | ||||||
|  |             e.setThoPartAttributeEnum_enumText( | ||||||
|  |                 EnumUtils.getInfoByValue(TempOrderSplitPropertyCode.class, e.getThoPartAttributeEnum())); | ||||||
|             // // 活动标记 |             // // 活动标记 | ||||||
|             // e.setActiveFlag_enumText(EnumUtils.getInfoByValue(AccountStatus.class, e.getActiveFlag())); |             // e.setActiveFlag_enumText(EnumUtils.getInfoByValue(AccountStatus.class, e.getActiveFlag())); | ||||||
|  |  | ||||||
| @@ -323,6 +324,9 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|  |  | ||||||
|         MedicationDetail medicationDetail = new MedicationDetail(); |         MedicationDetail medicationDetail = new MedicationDetail(); | ||||||
|         BeanUtils.copyProperties(medicationManageUpDto, medicationDetail); |         BeanUtils.copyProperties(medicationManageUpDto, medicationDetail); | ||||||
|  |         // 使用10位数基础采番 | ||||||
|  |         String code = assignSeqUtil.getSeq(AssignSeqEnum.MEDICATION_NUM.getPrefix(),10); | ||||||
|  |         medicationDetail.setBusNo(code); | ||||||
|         // 拼音码 |         // 拼音码 | ||||||
|         medicationDetail.setPyStr(ChineseConvertUtils.toPinyinFirstLetter(medicationDetail.getName())); |         medicationDetail.setPyStr(ChineseConvertUtils.toPinyinFirstLetter(medicationDetail.getName())); | ||||||
|         medicationDetail |         medicationDetail | ||||||
| @@ -337,8 +341,19 @@ public class MedicationManageAppServiceImpl implements IMedicationManageAppServi | |||||||
|  |  | ||||||
|             // 新增子表外来药品目录 |             // 新增子表外来药品目录 | ||||||
|             boolean insertMedicationSuccess = medicationService.addMedication(medicationDetail); |             boolean insertMedicationSuccess = medicationService.addMedication(medicationDetail); | ||||||
|  |             ItemUpFromDirectoryDto itemUpFromDirectoryDto = new ItemUpFromDirectoryDto(); | ||||||
|  |             BeanUtils.copyProperties(medicationManageUpDto, itemUpFromDirectoryDto); | ||||||
|  |             itemUpFromDirectoryDto.setInstanceId(medicationDetail.getMedicationDefId()) | ||||||
|  |                 .setStatusEnum(PublicationStatus.ACTIVE.getValue()) | ||||||
|  |                 .setInstanceTable(CommonConstants.TableName.MED_MEDICATION_DEFINITION) | ||||||
|  |                 .setEffectiveStart(DateUtils.getNowDate()) | ||||||
|  |                 .setOrgId(SecurityUtils.getLoginUser().getOrgId()) | ||||||
|  |                 .setConditionFlag(Whether.YES.getValue()) | ||||||
|  |                 .setChargeName(medicationDetail.getName()) | ||||||
|  |                 .setPrice(medicationManageUpDto.getRetailPrice()); | ||||||
|  |  | ||||||
|             // 添加药品成功后,添加相应的条件价格表信息 |             // 添加药品成功后,添加相应的条件价格表信息 | ||||||
|             boolean insertItemDefinitionSuccess = itemDefinitionServic.addItem(medicationManageUpDto, medicationDetail); |             boolean insertItemDefinitionSuccess = itemDefinitionServic.addItem(itemUpFromDirectoryDto); | ||||||
|  |  | ||||||
|             return (insertMedicationSuccess && insertItemDefinitionSuccess) |             return (insertMedicationSuccess && insertItemDefinitionSuccess) | ||||||
|                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"药品目录"})) |                 ? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"药品目录"})) | ||||||
|   | |||||||
| @@ -37,11 +37,14 @@ public class DeviceManageDto { | |||||||
|     private String wbStr; |     private String wbStr; | ||||||
|  |  | ||||||
|     /** 器材分类 */ |     /** 器材分类 */ | ||||||
|     private Integer categoryEnum; |     @Dict(dictCode = "device_category_code") | ||||||
|     private String categoryEnum_enumText; |     private String categoryCode; | ||||||
|  |     private String categoryCode_dictText; | ||||||
|  |  | ||||||
|     /** 器材种类 */ |     /** 器材种类 */ | ||||||
|  |     @Dict(dictCode = "device_type_code") | ||||||
|     private String typeCode; |     private String typeCode; | ||||||
|  |     private String typeCode_dictText; | ||||||
|  |  | ||||||
|     /** 包装单位 */ |     /** 包装单位 */ | ||||||
|     private String unitCode; |     private String unitCode; | ||||||
| @@ -55,6 +58,18 @@ public class DeviceManageDto { | |||||||
|     /** 最小使用单位 */ |     /** 最小使用单位 */ | ||||||
|     private String minUnitCode; |     private String minUnitCode; | ||||||
|  |  | ||||||
|  |     /** 所属科室 */ | ||||||
|  |     @Dict(dictTable = "adm_organization", dictCode = "id", dictText = "name") | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long orgId; | ||||||
|  |     private String orgId_dictText; | ||||||
|  |  | ||||||
|  |     /** 所在位置 */ | ||||||
|  |     @Dict(dictTable = "adm_location", dictCode = "id", dictText = "name") | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long locationId; | ||||||
|  |     private String locationId_dictText; | ||||||
|  |  | ||||||
|     /** 产品型号 */ |     /** 产品型号 */ | ||||||
|     private String modelNumber; |     private String modelNumber; | ||||||
|  |  | ||||||
| @@ -63,7 +78,9 @@ public class DeviceManageDto { | |||||||
|     private String hvcmFlag_enumText; |     private String hvcmFlag_enumText; | ||||||
|  |  | ||||||
|     /** 销售单位 */ |     /** 销售单位 */ | ||||||
|  |     @Dict(dictCode = "unit_code") | ||||||
|     private String salesUnitCode; |     private String salesUnitCode; | ||||||
|  |     private String salesUnitCode_dictText; | ||||||
|  |  | ||||||
|     /** 批准文号 */ |     /** 批准文号 */ | ||||||
|     private String approvalNumber; |     private String approvalNumber; | ||||||
| @@ -84,6 +101,7 @@ public class DeviceManageDto { | |||||||
|     private String statusEnum_enumText; |     private String statusEnum_enumText; | ||||||
|  |  | ||||||
|     /** 生产厂家 */ |     /** 生产厂家 */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long manufacturerId; |     private Long manufacturerId; | ||||||
|  |  | ||||||
|     /** 生产厂商文本 */ |     /** 生产厂商文本 */ | ||||||
| @@ -101,12 +119,6 @@ public class DeviceManageDto { | |||||||
|     /** 适用范围 */ |     /** 适用范围 */ | ||||||
|     private String jurisdiction; |     private String jurisdiction; | ||||||
|  |  | ||||||
|     /** 执行科室 */ |  | ||||||
|     @Dict(dictTable = "adm_organization", dictCode = "id", dictText = "name") |  | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |  | ||||||
|     private Long ruleId; |  | ||||||
|     private String ruleId_dictText; |  | ||||||
|  |  | ||||||
|     /** 器材版本 */ |     /** 器材版本 */ | ||||||
|     private String version; |     private String version; | ||||||
|  |  | ||||||
| @@ -120,4 +132,10 @@ public class DeviceManageDto { | |||||||
|     /** 售价 */ |     /** 售价 */ | ||||||
|     private BigDecimal price; |     private BigDecimal price; | ||||||
|  |  | ||||||
|  |     /** 财务类别 */ | ||||||
|  |     private String itemTypeCode; | ||||||
|  |  | ||||||
|  |     /** 医保类别 */ | ||||||
|  |     private String ybType; | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,6 +3,8 @@ package com.openhis.web.datadictionary.dto; | |||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
| @@ -16,8 +18,12 @@ import lombok.experimental.Accessors; | |||||||
| @Accessors(chain = true) | @Accessors(chain = true) | ||||||
| public class DeviceManageInitDto { | public class DeviceManageInitDto { | ||||||
|     private List<statusEnumOption> statusFlagOptions; |     private List<statusEnumOption> statusFlagOptions; | ||||||
|     private List<deviceCategory> deviceCategories; |     private List<dictCategoryCode> deviceCategories; | ||||||
|     private List<exeOrganization> exeOrganizations; |     private List<exeOrganization> exeOrganizations; | ||||||
|  |     // 供应商 | ||||||
|  |     private List<supplierListOption> supplierListOptions; | ||||||
|  |     // 是/否 状态 | ||||||
|  |     private List<statusEnumOption> statusYBWeatherOptions; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 状态 |      * 状态 | ||||||
| @@ -48,6 +54,21 @@ public class DeviceManageInitDto { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 器材分类 | ||||||
|  |      */ | ||||||
|  |     @Data | ||||||
|  |     public static class dictCategoryCode { | ||||||
|  |         private String value; | ||||||
|  |         private String info; | ||||||
|  |         private List<dictCategoryCode> children = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |         public dictCategoryCode(String value, String info) { | ||||||
|  |             this.value = value; | ||||||
|  |             this.info = info; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 执行机构 |      * 执行机构 | ||||||
|      */ |      */ | ||||||
| @@ -61,4 +82,21 @@ public class DeviceManageInitDto { | |||||||
|             this.label = label; |             this.label = label; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 供应商 | ||||||
|  |      */ | ||||||
|  |     @Data | ||||||
|  |     public static class supplierListOption { | ||||||
|  |  | ||||||
|  |         @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |         private Long value; | ||||||
|  |         private String label; | ||||||
|  |  | ||||||
|  |         public supplierListOption(Long value, String label) { | ||||||
|  |             this.value = value; | ||||||
|  |             this.label = label; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ import lombok.experimental.Accessors; | |||||||
| public class DeviceManageSelParam { | public class DeviceManageSelParam { | ||||||
|  |  | ||||||
|     /** 器材分类 */ |     /** 器材分类 */ | ||||||
|     private Integer categoryEnum; |     private String categoryCode; | ||||||
|  |  | ||||||
|     /** 医保对码标记 */ |     /** 医保对码标记 */ | ||||||
|     private Integer ybMatchFlag; |     private Integer ybMatchFlag; | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ import javax.validation.constraints.NotNull; | |||||||
|  |  | ||||||
| import com.fasterxml.jackson.databind.annotation.JsonSerialize; | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
| import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
|  | import com.openhis.common.annotation.Dict; | ||||||
| import com.openhis.common.enums.DeviceCategory; | import com.openhis.common.enums.DeviceCategory; | ||||||
|  |  | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| @@ -43,10 +44,7 @@ public class DeviceManageUpDto { | |||||||
|  |  | ||||||
|     /** 器材分类 */ |     /** 器材分类 */ | ||||||
|     @NotNull(message = "器材分类不能为空") |     @NotNull(message = "器材分类不能为空") | ||||||
| //    private DeviceCategory categoryEnum; |     private String categoryCode; | ||||||
|     private Integer categoryEnum; |  | ||||||
|     private String categoryEnum_enumText; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** 器材种类 */ |     /** 器材种类 */ | ||||||
|     @NotBlank(message = "器材种类不能为空") |     @NotBlank(message = "器材种类不能为空") | ||||||
| @@ -68,12 +66,25 @@ public class DeviceManageUpDto { | |||||||
|     @NotBlank(message = "最小使用单位不能为空") |     @NotBlank(message = "最小使用单位不能为空") | ||||||
|     private String minUnitCode; |     private String minUnitCode; | ||||||
|  |  | ||||||
|  |     /** 所属科室 */ | ||||||
|  |     @NotBlank(message = "所属科室不能为空") | ||||||
|  |     @Dict(dictTable = "adm_organization", dictCode = "id", dictText = "name") | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long orgId; | ||||||
|  |     private String orgId_dictText; | ||||||
|  |  | ||||||
|  |     /** 所在位置 */ | ||||||
|  |     @NotBlank(message = "所在位置不能为空") | ||||||
|  |     @Dict(dictTable = "adm_location", dictCode = "id", dictText = "name") | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long locationId; | ||||||
|  |     private String locationId_dictText; | ||||||
|  |  | ||||||
|     /** 产品型号 */ |     /** 产品型号 */ | ||||||
|     @NotBlank(message = "产品型号不能为空") |     @NotBlank(message = "产品型号不能为空") | ||||||
|     private String modelNumber; |     private String modelNumber; | ||||||
|  |  | ||||||
|     /** 高值器材标志 */ |     /** 高值器材标志 */ | ||||||
|     // @NotNull(message = "高值器材标志不能为空") |  | ||||||
|     private Integer hvcmFlag; |     private Integer hvcmFlag; | ||||||
|  |  | ||||||
|     /** 销售单位 */ |     /** 销售单位 */ | ||||||
| @@ -85,21 +96,22 @@ public class DeviceManageUpDto { | |||||||
|     private String approvalNumber; |     private String approvalNumber; | ||||||
|  |  | ||||||
|     /** 医保标记 */ |     /** 医保标记 */ | ||||||
|     // @NotNull(message = "医保标记不能为空") |  | ||||||
|     private Integer ybFlag; |     private Integer ybFlag; | ||||||
|  |  | ||||||
|     /** 医保编码 */ |     /** 医保编码 */ | ||||||
|     private String ybNo; |     private String ybNo; | ||||||
|  |  | ||||||
|     /** 医保对码标记 */ |     /** 医保对码标记 */ | ||||||
|     // @NotNull(message = "医保对码标记不能为空") |  | ||||||
|     private Integer ybMatchFlag; |     private Integer ybMatchFlag; | ||||||
|  |  | ||||||
|     /** 生产厂家 */ |     /** 生产厂家 */ | ||||||
|     @NotNull(message = "生产厂家不能为空") |  | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long manufacturerId; |     private Long manufacturerId; | ||||||
|  |  | ||||||
|  |     /** 生产厂商文本 */ | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|  |     private Long manufacturerText; | ||||||
|  |  | ||||||
|     /** 供应商 */ |     /** 供应商 */ | ||||||
|     @NotNull(message = "供应商不能为空") |     @NotNull(message = "供应商不能为空") | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
| @@ -117,16 +129,6 @@ public class DeviceManageUpDto { | |||||||
|     @JsonSerialize(using = ToStringSerializer.class) |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long ruleId; |     private Long ruleId; | ||||||
|  |  | ||||||
|     /** 归属科室 */ |  | ||||||
|     @NotNull(message = "归属科室不能为空") |  | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |  | ||||||
|     private Long orgId; |  | ||||||
|  |  | ||||||
|     /** 所在位置 */ |  | ||||||
|     @NotNull(message = "所在位置不能为空") |  | ||||||
|     @JsonSerialize(using = ToStringSerializer.class) |  | ||||||
|     private Long locationId; |  | ||||||
|  |  | ||||||
|     /** 器材版本 */ |     /** 器材版本 */ | ||||||
|     private String version; |     private String version; | ||||||
|  |  | ||||||
| @@ -134,7 +136,6 @@ public class DeviceManageUpDto { | |||||||
|     private String substanceText; |     private String substanceText; | ||||||
|  |  | ||||||
|     /** 过敏标记 */ |     /** 过敏标记 */ | ||||||
|     // @NotNull(message = "过敏标记不能为空") |  | ||||||
|     private Integer allergenFlag; |     private Integer allergenFlag; | ||||||
|  |  | ||||||
|     /** 购入价 */ |     /** 购入价 */ | ||||||
| @@ -149,10 +150,13 @@ public class DeviceManageUpDto { | |||||||
|     @NotNull(message = "最高零售价不能为空") |     @NotNull(message = "最高零售价不能为空") | ||||||
|     private BigDecimal maximumRetailPrice; |     private BigDecimal maximumRetailPrice; | ||||||
|  |  | ||||||
|     /** 最小费用 */ |     /** 财务类别 */ | ||||||
|     private String minimalFee; |     @NotNull(message = "财务类别不能为空") | ||||||
|  |     private String itemTypeCode; | ||||||
|  |  | ||||||
|     /** 医保类别 */ |     /** 医保类别 */ | ||||||
|  |     @NotNull(message = "财务类别不能为空") | ||||||
|     private String ybType; |     private String ybType; | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -14,11 +14,12 @@ import lombok.experimental.Accessors; | |||||||
| @Data | @Data | ||||||
| @Accessors(chain = true) | @Accessors(chain = true) | ||||||
| public class DiagnosisTreatmentSelParam { | public class DiagnosisTreatmentSelParam { | ||||||
|  |  | ||||||
|     /** 目录类别 */ |     /** 目录类别 */ | ||||||
|     private Integer categoryEnum; |     private Integer categoryEnum; | ||||||
|  |  | ||||||
|     /** 类型 */ |     /** 类型 */ | ||||||
|     private String typeCode; |     private Integer typeEnum; | ||||||
|  |  | ||||||
|     /** 医保对码标记 */ |     /** 医保对码标记 */ | ||||||
|     private Integer ybMatchFlag; |     private Integer ybMatchFlag; | ||||||
|   | |||||||
| @@ -0,0 +1,74 @@ | |||||||
|  | package com.openhis.web.datadictionary.dto; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | import com.openhis.common.annotation.Dict; | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 从目录添加定价表信息用的Dto | ||||||
|  |  * | ||||||
|  |  * @author liuhr | ||||||
|  |  * @date 2025/3/28 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class ItemUpFromDirectoryDto { | ||||||
|  |  | ||||||
|  |     /** 药品单位 */ | ||||||
|  |     private String unitCode; | ||||||
|  |  | ||||||
|  |     /** 购入价 */ | ||||||
|  |     private BigDecimal purchasePrice; | ||||||
|  |  | ||||||
|  |     /** 零售价 */ | ||||||
|  |     private BigDecimal retailPrice; | ||||||
|  |  | ||||||
|  |     /** 最高零售价 */ | ||||||
|  |     private BigDecimal maximumRetailPrice; | ||||||
|  |  | ||||||
|  |     /** 名称 */ | ||||||
|  |     private String chargeName; | ||||||
|  |  | ||||||
|  |     /** 状态 */ | ||||||
|  |     private Integer statusEnum; | ||||||
|  |  | ||||||
|  |     /** 机构ID */ | ||||||
|  |     private Long orgId; | ||||||
|  |  | ||||||
|  |     /** 代码 */ | ||||||
|  |     private String instanceTable; | ||||||
|  |  | ||||||
|  |     /** 关联项目 */ | ||||||
|  |     private Long instanceId; | ||||||
|  |  | ||||||
|  |     /** 有效时间开始 */ | ||||||
|  |     private Date effectiveStart; | ||||||
|  |  | ||||||
|  |     /** 财务类别 */ | ||||||
|  |     private String typeCode; | ||||||
|  |  | ||||||
|  |     /** 医保类别 */ | ||||||
|  |     private String ybType; | ||||||
|  |  | ||||||
|  |     /** 是否使用详细价格规则 */ | ||||||
|  |     private Integer conditionFlag; | ||||||
|  |  | ||||||
|  |     /** 基础价格 */ | ||||||
|  |     private BigDecimal price; | ||||||
|  |  | ||||||
|  |     /** 费用定价主键ID */ | ||||||
|  |     private Long definitionId; | ||||||
|  |  | ||||||
|  |     /** 条件 */ | ||||||
|  |     private String conditionCode; | ||||||
|  |  | ||||||
|  |     /** 命中值 */ | ||||||
|  |     private String conditionValue; | ||||||
|  |  | ||||||
|  |     /** 价格 */ | ||||||
|  |     private BigDecimal amount; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -86,7 +86,6 @@ public class MedicationManageUpDto { | |||||||
|     private String definition; |     private String definition; | ||||||
|  |  | ||||||
|     /** 药品编号 */ |     /** 药品编号 */ | ||||||
|     @NotBlank(message = "药品编号不能为空") |  | ||||||
|     private String busNo; |     private String busNo; | ||||||
|  |  | ||||||
|     /** 药品名称 */ |     /** 药品名称 */ | ||||||
|   | |||||||
| @@ -5,6 +5,7 @@ import com.baomidou.mybatisplus.core.metadata.IPage; | |||||||
| import com.baomidou.mybatisplus.core.toolkit.Constants; | import com.baomidou.mybatisplus.core.toolkit.Constants; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.openhis.web.datadictionary.dto.DeviceManageDto; | import com.openhis.web.datadictionary.dto.DeviceManageDto; | ||||||
|  | import com.openhis.web.datadictionary.dto.MedicationManageDto; | ||||||
| import com.openhis.web.outpatientmanage.dto.OutpatientInfusionPatientDto; | import com.openhis.web.outpatientmanage.dto.OutpatientInfusionPatientDto; | ||||||
| import org.apache.ibatis.annotations.Param; | import org.apache.ibatis.annotations.Param; | ||||||
|  |  | ||||||
| @@ -27,4 +28,13 @@ public interface DeviceManageMapper { | |||||||
|         @Param("page") Page<DeviceManageDto> page, |         @Param("page") Page<DeviceManageDto> page, | ||||||
|         @Param(Constants.WRAPPER) QueryWrapper<DeviceManageDto> queryWrapper); |         @Param(Constants.WRAPPER) QueryWrapper<DeviceManageDto> queryWrapper); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 器材详情 | ||||||
|  |      * | ||||||
|  |      * @param id 器材ID | ||||||
|  |      * @param tenantId 租户 | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     DeviceManageDto getOne(@Param("id") Long id, @Param("tenantId") Integer tenantId); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -35,7 +35,11 @@ | |||||||
|         T3.substance_text, |         T3.substance_text, | ||||||
|         T3.allergen_flag, |         T3.allergen_flag, | ||||||
|         T3.tenant_id, |         T3.tenant_id, | ||||||
|         T3.price |         T3.item_type_code, | ||||||
|  |         T3.yb_type, | ||||||
|  |         T3.retail_price, | ||||||
|  |         T3.purchase_price, | ||||||
|  |         T3.maximum_retail_price | ||||||
|         FROM |         FROM | ||||||
|         ( |         ( | ||||||
|         SELECT |         SELECT | ||||||
| @@ -69,7 +73,23 @@ | |||||||
|             T1.substance_text, |             T1.substance_text, | ||||||
|             T1.allergen_flag, |             T1.allergen_flag, | ||||||
|             T1.tenant_id, |             T1.tenant_id, | ||||||
|             T2.price |             T2.type_code as item_type_code, | ||||||
|  |             T2.yb_type, | ||||||
|  |             T2.price as retail_price,--零售价, | ||||||
|  |             (   SELECT T4.amount | ||||||
|  |                 FROM adm_charge_item_definition T5 | ||||||
|  |                 LEFT JOIN  adm_charge_item_def_detail T4 ON  T4.definition_id = T5.id | ||||||
|  |                 WHERE   T4.condition_code = '2'--2:采购价 | ||||||
|  |                 AND T5.instance_id = T1.id | ||||||
|  |                 AND T5.instance_table = 'adm_device_definition' | ||||||
|  |             ) as purchase_price,--购入价 | ||||||
|  |             (   SELECT T4.amount | ||||||
|  |                 FROM adm_charge_item_definition T5 | ||||||
|  |                 LEFT JOIN  adm_charge_item_def_detail T4 ON  T4.definition_id = T5.id | ||||||
|  |                 WHERE   T4.condition_code = '4'--4:限制 | ||||||
|  |                 AND T5.instance_id = T1.id | ||||||
|  |                 AND T5.instance_table = 'adm_device_definition' | ||||||
|  |             ) as maximum_retail_price--最高零售价 | ||||||
|         FROM adm_device_definition T1 |         FROM adm_device_definition T1 | ||||||
|         LEFT JOIN adm_charge_item_definition T2 ON T1.id = T2.instance_id |         LEFT JOIN adm_charge_item_definition T2 ON T1.id = T2.instance_id | ||||||
|         <where> |         <where> | ||||||
| @@ -81,4 +101,69 @@ | |||||||
|         ${ew.customSqlSegment} |         ${ew.customSqlSegment} | ||||||
|  |  | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <select id="getOne" resultType="com.openhis.web.datadictionary.dto.DeviceManageDto"> | ||||||
|  |         SELECT | ||||||
|  |         T1.id, | ||||||
|  |         T1.bus_no, | ||||||
|  |         T1.name, | ||||||
|  |         T1.py_str, | ||||||
|  |         T1.wb_str, | ||||||
|  |         T1.category_code, | ||||||
|  |         T1.type_code, | ||||||
|  |         T1.unit_code, | ||||||
|  |         T1.size, | ||||||
|  |         T1.part_percent, | ||||||
|  |         T1.min_unit_code, | ||||||
|  |         T1.org_id, | ||||||
|  |         T1.location_id, | ||||||
|  |         T1.model_number, | ||||||
|  |         T1.hvcm_flag, | ||||||
|  |         T1.sales_unit_code, | ||||||
|  |         T1.approval_number, | ||||||
|  |         T1.yb_flag, | ||||||
|  |         T1.yb_no, | ||||||
|  |         T1.yb_match_flag, | ||||||
|  |         T1.status_enum, | ||||||
|  |         T1.manufacturer_id, | ||||||
|  |         T1.manufacturer_text, | ||||||
|  |         T1.supply_id, | ||||||
|  |         T1.description, | ||||||
|  |         T1.jurisdiction, | ||||||
|  |         T1.version, | ||||||
|  |         T1.substance_text, | ||||||
|  |         T1.allergen_flag, | ||||||
|  |         T1.tenant_id, | ||||||
|  |         T2.type_code as item_type_code, | ||||||
|  |         T2.yb_type, | ||||||
|  |         T2.price as retail_price,--零售价, | ||||||
|  |         (   SELECT T4.amount | ||||||
|  |         FROM adm_charge_item_definition T5 | ||||||
|  |         LEFT JOIN  adm_charge_item_def_detail T4 ON  T4.definition_id = T5.id | ||||||
|  |         WHERE   T4.condition_code = '2'--2:采购价 | ||||||
|  |         AND T5.instance_id = T1.id | ||||||
|  |         AND T5.instance_table = 'adm_device_definition' | ||||||
|  |         ) as purchase_price,--购入价 | ||||||
|  |         (   SELECT T4.amount | ||||||
|  |         FROM adm_charge_item_definition T5 | ||||||
|  |         LEFT JOIN  adm_charge_item_def_detail T4 ON  T4.definition_id = T5.id | ||||||
|  |         WHERE   T4.condition_code = '4'--4:限制 | ||||||
|  |         AND T5.instance_id = T1.id | ||||||
|  |         AND T5.instance_table = 'adm_device_definition' | ||||||
|  |         ) as maximum_retail_price--最高零售价 | ||||||
|  |         FROM adm_device_definition T1 | ||||||
|  |         LEFT JOIN adm_charge_item_definition T2 ON T1.id = T2.instance_id | ||||||
|  |         <where> | ||||||
|  |             T1.delete_flag = '0' | ||||||
|  |             AND  T2.instance_table = 'adm_device_definition' | ||||||
|  |  | ||||||
|  |             <if test="id!= null"> | ||||||
|  |                 AND T2.id = #{id} | ||||||
|  |             </if> | ||||||
|  |             <if test="tenantId!= null"> | ||||||
|  |                 AND T1.tenant_id = #{tenantId} | ||||||
|  |             </if> | ||||||
|  |         </where> | ||||||
|  |     </select> | ||||||
|  |  | ||||||
| </mapper> | </mapper> | ||||||
| @@ -153,12 +153,16 @@ | |||||||
|         FROM adm_charge_item_definition T5 |         FROM adm_charge_item_definition T5 | ||||||
|         LEFT JOIN  adm_charge_item_def_detail T7 ON  T7.definition_id = T5.id |         LEFT JOIN  adm_charge_item_def_detail T7 ON  T7.definition_id = T5.id | ||||||
|         WHERE   T7.condition_code = '2'--2:采购价 |         WHERE   T7.condition_code = '2'--2:采购价 | ||||||
|  |         AND T5.instance_id = T2.medication_def_id | ||||||
|  |         AND T5.instance_table = 'med_medication_definition' | ||||||
|         ) as purchase_price,--购入价 |         ) as purchase_price,--购入价 | ||||||
|         ( |         ( | ||||||
|         SELECT T7.amount |         SELECT T7.amount | ||||||
|         FROM adm_charge_item_definition T5 |         FROM adm_charge_item_definition T5 | ||||||
|         LEFT JOIN  adm_charge_item_def_detail T7 ON  T7.definition_id = T5.id |         LEFT JOIN  adm_charge_item_def_detail T7 ON  T7.definition_id = T5.id | ||||||
|         WHERE   T7.condition_code = '4'--4:限制 |         WHERE   T7.condition_code = '4'--4:限制 | ||||||
|  |         AND T5.instance_id = T2.medication_def_id | ||||||
|  |         AND T5.instance_table = 'med_medication_definition' | ||||||
|         ) as maximum_retail_price--最高零售价 |         ) as maximum_retail_price--最高零售价 | ||||||
|         FROM med_medication_definition T1 |         FROM med_medication_definition T1 | ||||||
|         LEFT JOIN med_medication T2 ON T1.id = T2.medication_def_id |         LEFT JOIN med_medication T2 ON T1.id = T2.medication_def_id | ||||||
|   | |||||||
| @@ -189,9 +189,13 @@ public class CommonConstants { | |||||||
|      */ |      */ | ||||||
|     public interface DictName { |     public interface DictName { | ||||||
|         /** |         /** | ||||||
|          * 药品分类 |          * 器材 | ||||||
|          */ |          */ | ||||||
|         String MED_CATEGORY_CODE = "med_category_code"; |         String MED_CATEGORY_CODE = "med_category_code"; | ||||||
|  |         /** | ||||||
|  |          * 药品分类 | ||||||
|  |          */ | ||||||
|  |         String DEVICE_CATEGORY_CODE = "device_category_code"; | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -49,7 +49,12 @@ public enum AssignSeqEnum { | |||||||
|     /** |     /** | ||||||
|      * 费用项目编码 |      * 费用项目编码 | ||||||
|      */ |      */ | ||||||
|     CHARGE_ITEM_NO("8", "费用项目编码", "CI"); |     CHARGE_ITEM_NO("8", "费用项目编码", "CI"), | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 药品项目编码 | ||||||
|  |      */ | ||||||
|  |     MEDICATION_NUM("8", "药品项目编码", "MD"); | ||||||
|  |  | ||||||
|     private final String code; |     private final String code; | ||||||
|     private final String info; |     private final String info; | ||||||
|   | |||||||
| @@ -87,7 +87,7 @@ public class DeviceDefinition extends HisBaseEntity { | |||||||
|     private Integer ybMatchFlag; |     private Integer ybMatchFlag; | ||||||
|  |  | ||||||
|     /** 状态 */ |     /** 状态 */ | ||||||
|     private PublicationStatus statusEnum; |     private Integer statusEnum; | ||||||
|  |  | ||||||
|     /** 生产厂家 */ |     /** 生产厂家 */ | ||||||
|     private Long manufacturerId; |     private Long manufacturerId; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 liuhongrui
					liuhongrui