代码提交 费用定价修改
This commit is contained in:
@@ -0,0 +1,42 @@
|
||||
/*
|
||||
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||
*/
|
||||
package com.core.common.enums;
|
||||
|
||||
/**
|
||||
* 定价类型
|
||||
*
|
||||
* @author zxy
|
||||
* @date 2025-02-21
|
||||
*/
|
||||
public enum DefinitionTypeEnum {
|
||||
|
||||
/**
|
||||
* 药品
|
||||
*/
|
||||
MEDICATION("1", "药品"),
|
||||
/**
|
||||
* 耗材
|
||||
*/
|
||||
DEVICE("2", "耗材"),
|
||||
/**
|
||||
* 手术
|
||||
*/
|
||||
ACTIVITY("3", "手术");
|
||||
|
||||
private final String code;
|
||||
private final String info;
|
||||
|
||||
DefinitionTypeEnum(String code, String info) {
|
||||
this.code = code;
|
||||
this.info = info;
|
||||
}
|
||||
|
||||
public String getCode() {
|
||||
return code;
|
||||
}
|
||||
|
||||
public String getInfo() {
|
||||
return info;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,197 @@
|
||||
/*
|
||||
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||
*/
|
||||
package com.openhis.web.datadictionary.assembler;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.function.Function;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.openhis.administration.domain.ChargeItemDefApp;
|
||||
import com.openhis.administration.domain.ChargeItemDefinition;
|
||||
import com.openhis.administration.domain.DeviceDefinition;
|
||||
import com.openhis.medication.domain.MedicationDefinition;
|
||||
import com.openhis.web.datadictionary.dto.ChargeItemDefPageDto;
|
||||
import com.openhis.web.datadictionary.dto.ItemDefSearchParam;
|
||||
import com.openhis.workflow.domain.ActivityDefinition;
|
||||
|
||||
/**
|
||||
* 费用定价dto转换器
|
||||
*
|
||||
* @author zxy
|
||||
* @date 2025-02-21
|
||||
*/
|
||||
public class ItemDefinitionAssembler {
|
||||
// /**
|
||||
// * 装配【费用定价分页列表DTO】分页 药品
|
||||
// *
|
||||
// * @param chargeItemDefinitionPage 【费用定价管理Entity实体】分页
|
||||
// * @param chargeItemDefAppList 【费用定价管理子表Entity实体】列表
|
||||
// * @param medicationDefinitionList【药品定义管理Entity实体】列表
|
||||
// * @return 【费用定价分页列表DTO】分页
|
||||
// */
|
||||
// public static Page<ChargeItemDefPageDto> assembleMedDefinitionDto(
|
||||
// Page<ChargeItemDefinition> chargeItemDefinitionPage, List<ChargeItemDefApp> chargeItemDefAppList,
|
||||
// List<MedicationDefinition> medicationDefinitionList, ItemDefSearchParam itemDefSearchParam) {
|
||||
//
|
||||
// // 将查询到的【药品基本信息管理】列表,作成以ID为Key的Map
|
||||
// Map<Long, MedicationDefinition> medicationDefinitionMap = medicationDefinitionList.stream()
|
||||
// .collect(Collectors.toMap(MedicationDefinition::getId, Function.identity()));
|
||||
//
|
||||
// // 将查询到的【患者管理】列表,作成以ID为Key的Map
|
||||
// Map<Long, ChargeItemDefApp> chargeItemDefAppMap =
|
||||
// chargeItemDefAppList.stream().collect(Collectors.toMap(ChargeItemDefApp::getId, Function.identity()));
|
||||
//
|
||||
// // 定义【入库单据分页列表DTO】的分页,传入【页码】、【行数】、及上面分页的【总数】
|
||||
// Page<ChargeItemDefPageDto> returnPage = new Page<>(chargeItemDefinitionPage.getCurrent(),
|
||||
// chargeItemDefinitionPage.getSize(), chargeItemDefinitionPage.getTotal());
|
||||
//
|
||||
// // 将【供应申请管理】的分页转化为返回【入库单据分页列表DTO】的分页
|
||||
// returnPage.setRecords(chargeItemDefinitionPage.getRecords().stream().map(entity -> {
|
||||
// // 定义【入库单据分页列表DTO】
|
||||
// ChargeItemDefPageDto dto = new ChargeItemDefPageDto();
|
||||
// ChargeItemDefApp chargeItemDefApp =
|
||||
// chargeItemDefAppMap.getOrDefault(entity.getInstanceId(), new ChargeItemDefApp());
|
||||
// MedicationDefinition medicationDefinition =
|
||||
// medicationDefinitionMap.getOrDefault(entity.getInstanceId(), new MedicationDefinition());
|
||||
// // 从主表COPY需要的字段
|
||||
// dto.setId(entity.getId());
|
||||
// dto.setConditionLotnumber(chargeItemDefApp.getConditionLotnumber());
|
||||
// dto.setPyCode(medicationDefinition.getPyCode());
|
||||
// dto.setTypeEnum(medicationDefinition.getCategoryCode());
|
||||
// return dto;
|
||||
// }).collect(Collectors.toList()));
|
||||
// // 模糊查询项目名称/项目编码/助记码
|
||||
// if (itemDefSearchParam.getSearchKey() != null) {
|
||||
// returnPage.setRecords(returnPage.getRecords().stream()
|
||||
// .filter(e -> e.getChargeName().contains(itemDefSearchParam.getSearchKey())
|
||||
// || e.getTitle().contains(itemDefSearchParam.getSearchKey())
|
||||
// || e.getPyCode().contains(itemDefSearchParam.getSearchKey()))
|
||||
// .collect(Collectors.toList()));
|
||||
// }
|
||||
// // 精确查询收费项目
|
||||
// if (itemDefSearchParam.getChargeItem() != null) {
|
||||
// returnPage.setRecords(returnPage.getRecords().stream()
|
||||
// .filter(e -> e.getTypeEnum().equals(itemDefSearchParam.getChargeItem())).collect(Collectors.toList()));
|
||||
// }
|
||||
//
|
||||
// // 返回【入库单据分页列表DTO】分页
|
||||
// return returnPage;
|
||||
// }
|
||||
//
|
||||
// /**
|
||||
// * 装配【费用定价分页列表DTO】分页 器具
|
||||
// *
|
||||
// * @param chargeItemDefinitionPage 【费用定价管理Entity实体】分页
|
||||
// * @param chargeItemDefAppList 【费用定价管理子表Entity实体】列表
|
||||
// * @param medicationDefinitionList【药品定义管理Entity实体】列表
|
||||
// * @return 【费用定价分页列表DTO】分页
|
||||
// */
|
||||
// public static Page<ChargeItemDefPageDto> assembleDevDefinitionDto(
|
||||
// Page<ChargeItemDefinition> chargeItemDefinitionPage, List<ChargeItemDefApp> chargeItemDefAppList,
|
||||
// List<DeviceDefinition> medicationDefinitionList, ItemDefSearchParam itemDefSearchParam) {
|
||||
//
|
||||
// // 将查询到的【药品基本信息管理】列表,作成以ID为Key的Map
|
||||
// Map<Long, DeviceDefinition> deviceDefinitionMap =
|
||||
// medicationDefinitionList.stream().collect(Collectors.toMap(DeviceDefinition::getId, Function.identity()));
|
||||
//
|
||||
// // 将查询到的【患者管理】列表,作成以ID为Key的Map
|
||||
// Map<Long, ChargeItemDefApp> chargeItemDefAppMap =
|
||||
// chargeItemDefAppList.stream().collect(Collectors.toMap(ChargeItemDefApp::getId, Function.identity()));
|
||||
//
|
||||
// // 定义【入库单据分页列表DTO】的分页,传入【页码】、【行数】、及上面分页的【总数】
|
||||
// Page<ChargeItemDefPageDto> returnPage = new Page<>(chargeItemDefinitionPage.getCurrent(),
|
||||
// chargeItemDefinitionPage.getSize(), chargeItemDefinitionPage.getTotal());
|
||||
//
|
||||
// // 将【供应申请管理】的分页转化为返回【入库单据分页列表DTO】的分页
|
||||
// returnPage.setRecords(chargeItemDefinitionPage.getRecords().stream().map(entity -> {
|
||||
// // 定义【入库单据分页列表DTO】
|
||||
// ChargeItemDefPageDto dto = new ChargeItemDefPageDto();
|
||||
// ChargeItemDefApp chargeItemDefApp =
|
||||
// chargeItemDefAppMap.getOrDefault(entity.getInstanceId(), new ChargeItemDefApp());
|
||||
// DeviceDefinition deviceDefinition =
|
||||
// deviceDefinitionMap.getOrDefault(entity.getInstanceId(), new DeviceDefinition());
|
||||
// // 从主表COPY需要的字段
|
||||
// dto.setId(entity.getId());
|
||||
// dto.setConditionLotnumber(chargeItemDefApp.getConditionLotnumber());
|
||||
// dto.setPyCode(deviceDefinition.getPyCode());
|
||||
// dto.setTypeEnum(deviceDefinition.getDeviceClass());
|
||||
// return dto;
|
||||
// }).collect(Collectors.toList()));
|
||||
// // 模糊查询项目名称/项目编码/助记码
|
||||
// if (itemDefSearchParam.getSearchKey() != null) {
|
||||
// returnPage.setRecords(returnPage.getRecords().stream()
|
||||
// .filter(e -> e.getChargeName().contains(itemDefSearchParam.getSearchKey())
|
||||
// || e.getTitle().contains(itemDefSearchParam.getSearchKey())
|
||||
// || e.getPyCode().contains(itemDefSearchParam.getSearchKey()))
|
||||
// .collect(Collectors.toList()));
|
||||
// }
|
||||
// // 精确查询收费项目
|
||||
// if (itemDefSearchParam.getChargeItem() != null) {
|
||||
// returnPage.setRecords(returnPage.getRecords().stream()
|
||||
// .filter(e -> e.getTypeEnum().equals(itemDefSearchParam.getChargeItem())).collect(Collectors.toList()));
|
||||
// }
|
||||
//
|
||||
// // 返回【入库单据分页列表DTO】分页
|
||||
// return returnPage;
|
||||
// }
|
||||
//
|
||||
// /**
|
||||
// * 装配【费用定价分页列表DTO】分页 诊疗
|
||||
// *
|
||||
// * @param chargeItemDefinitionPage 【费用定价管理Entity实体】分页
|
||||
// * @param chargeItemDefAppList 【费用定价管理子表Entity实体】列表
|
||||
// * @param medicationDefinitionList【药品定义管理Entity实体】列表
|
||||
// * @return 【费用定价分页列表DTO】分页
|
||||
// */
|
||||
// public static Page<ChargeItemDefPageDto> assembleProDefinitionDto(
|
||||
// Page<ChargeItemDefinition> chargeItemDefinitionPage, List<ChargeItemDefApp> chargeItemDefAppList,
|
||||
// List<ActivityDefinition> medicationDefinitionList, ItemDefSearchParam itemDefSearchParam) {
|
||||
//
|
||||
// // 将查询到的【药品基本信息管理】列表,作成以ID为Key的Map
|
||||
// Map<Long, ActivityDefinition> activityDefinitionMap =
|
||||
// medicationDefinitionList.stream().collect(Collectors.toMap(ActivityDefinition::getId, Function.identity()));
|
||||
//
|
||||
// // 将查询到的【患者管理】列表,作成以ID为Key的Map
|
||||
// Map<Long, ChargeItemDefApp> chargeItemDefAppMap =
|
||||
// chargeItemDefAppList.stream().collect(Collectors.toMap(ChargeItemDefApp::getId, Function.identity()));
|
||||
//
|
||||
// // 定义【入库单据分页列表DTO】的分页,传入【页码】、【行数】、及上面分页的【总数】
|
||||
// Page<ChargeItemDefPageDto> returnPage = new Page<>(chargeItemDefinitionPage.getCurrent(),
|
||||
// chargeItemDefinitionPage.getSize(), chargeItemDefinitionPage.getTotal());
|
||||
//
|
||||
// // 将【供应申请管理】的分页转化为返回【入库单据分页列表DTO】的分页
|
||||
// returnPage.setRecords(chargeItemDefinitionPage.getRecords().stream().map(entity -> {
|
||||
// // 定义【入库单据分页列表DTO】
|
||||
// ChargeItemDefPageDto dto = new ChargeItemDefPageDto();
|
||||
// ChargeItemDefApp chargeItemDefApp =
|
||||
// chargeItemDefAppMap.getOrDefault(entity.getInstanceId(), new ChargeItemDefApp());
|
||||
// ActivityDefinition deviceDefinition =
|
||||
// activityDefinitionMap.getOrDefault(entity.getInstanceId(), new ActivityDefinition());
|
||||
// // 从主表COPY需要的字段
|
||||
// dto.setId(entity.getId());
|
||||
// dto.setConditionLotnumber(chargeItemDefApp.getConditionLotnumber());
|
||||
// dto.setPyCode(deviceDefinition.getPyCode());
|
||||
// dto.setTypeEnum(deviceDefinition.getTypeEnum().toString());
|
||||
// return dto;
|
||||
// }).collect(Collectors.toList()));
|
||||
// // 模糊查询项目名称/项目编码/助记码
|
||||
// if (itemDefSearchParam.getSearchKey() != null) {
|
||||
// returnPage.setRecords(returnPage.getRecords().stream()
|
||||
// .filter(e -> e.getChargeName().contains(itemDefSearchParam.getSearchKey())
|
||||
// || e.getTitle().contains(itemDefSearchParam.getSearchKey())
|
||||
// || e.getPyCode().contains(itemDefSearchParam.getSearchKey()))
|
||||
// .collect(Collectors.toList()));
|
||||
// }
|
||||
// // 精确查询收费项目
|
||||
// if (itemDefSearchParam.getChargeItem() != null) {
|
||||
// returnPage.setRecords(returnPage.getRecords().stream()
|
||||
// .filter(e -> e.getTypeEnum().equals(itemDefSearchParam.getChargeItem())).collect(Collectors.toList()));
|
||||
// }
|
||||
//
|
||||
// // 返回【入库单据分页列表DTO】分页
|
||||
// return returnPage;
|
||||
// }
|
||||
}
|
||||
@@ -55,7 +55,7 @@ public class DiseaseManagementController {
|
||||
void AddDisease(DiseaseInDto diseaseInDto) {
|
||||
ConditionDefinition conditionDefinition = new ConditionDefinition();
|
||||
BeanUtils.copyProperties(diseaseInDto,conditionDefinition);
|
||||
iConditionDefinitionService.AddDisease(conditionDefinition);
|
||||
// iConditionDefinitionService.AddDisease(conditionDefinition);
|
||||
}
|
||||
|
||||
// 新增医保病种目录
|
||||
|
||||
@@ -0,0 +1,200 @@
|
||||
/*
|
||||
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||
*/
|
||||
package com.openhis.web.datadictionary.controller;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.core.common.core.domain.R;
|
||||
import com.core.common.enums.DefinitionTypeEnum;
|
||||
import com.core.common.utils.MessageUtils;
|
||||
import com.core.common.utils.bean.BeanUtils;
|
||||
import com.openhis.administration.domain.ChargeItemDefApp;
|
||||
import com.openhis.administration.domain.ChargeItemDefinition;
|
||||
import com.openhis.administration.service.IChargeItemDefAppService;
|
||||
import com.openhis.administration.service.IChargeItemDefinitionService;
|
||||
import com.openhis.administration.service.IDeviceDefinitionService;
|
||||
import com.openhis.common.constant.PromptMsgConstant;
|
||||
import com.openhis.medication.service.IMedicationDefinitionService;
|
||||
import com.openhis.web.datadictionary.dto.ChargeItemDefPageDto;
|
||||
import com.openhis.web.datadictionary.dto.ItemDefSearchParam;
|
||||
import com.openhis.web.datadictionary.dto.ItemDefinitionDto;
|
||||
import com.openhis.web.datadictionary.mapper.ChargeItemDefSearchMapper;
|
||||
import com.openhis.workflow.service.IActivityDefinitionService;
|
||||
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
|
||||
/**
|
||||
* 项目定价
|
||||
*
|
||||
* @author zxy
|
||||
* @date 2025-02-21
|
||||
*/
|
||||
@RestController
|
||||
@RequestMapping("/dict-manager/definition")
|
||||
@Slf4j
|
||||
public class ItemDefinitionController {
|
||||
|
||||
@Autowired(required = false)
|
||||
private IChargeItemDefinitionService chargeItemDefinitionService;
|
||||
@Autowired(required = false)
|
||||
private IChargeItemDefAppService chargeItemDefAppService;
|
||||
@Autowired(required = false)
|
||||
private ChargeItemDefSearchMapper chargeItemDefSearchMapper;
|
||||
@Autowired(required = false)
|
||||
private IMedicationDefinitionService medicationDefinitionService;
|
||||
@Autowired(required = false)
|
||||
private IDeviceDefinitionService deviceDefinitionService;
|
||||
@Autowired(required = false)
|
||||
private IActivityDefinitionService activityDefinitionService;
|
||||
|
||||
/**
|
||||
* 项目定价列表
|
||||
*
|
||||
* @param itemDefSearchParam 查询条件
|
||||
* @param pageNo 当前页码
|
||||
* @param pageSize 查询条数
|
||||
* @param request 请求数据
|
||||
* @return 项目定价列表
|
||||
*/
|
||||
@GetMapping(value = "/item-definition-page")
|
||||
public R<?> getDefinitionPage(ItemDefSearchParam itemDefSearchParam,
|
||||
@RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo,
|
||||
@RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest request) {
|
||||
// region
|
||||
/// todo: 代码未测试
|
||||
// 获取定价查询条件
|
||||
// ChargeItemDefinition chargeItemDefinition = new ChargeItemDefinition();
|
||||
// BeanUtils.copyProperties(itemDefSearchParam, chargeItemDefinition);
|
||||
|
||||
// ====================================================================================
|
||||
|
||||
// 查询【费用定价管理】分页列表
|
||||
// Page<ChargeItemDefinition> chargeItemDefinitionPage =
|
||||
// chargeItemDefinitionMapper.getPage(itemDefSearchParam, pageNo, pageSize);
|
||||
// if (chargeItemDefinitionPage.getRecords() != null) {
|
||||
// List<ChargeItemDefApp> chargeItemDefAppList = chargeItemDefAppService.listByIds(chargeItemDefinitionPage
|
||||
// .getRecords().stream().filter(e -> e.getInstanceTable().equals("adm_charge_item_def_app"))
|
||||
// .map(ChargeItemDefinition::getInstanceId).collect(Collectors.toList()));
|
||||
// // 通过 DefinitionType 区分药品定价/器具定价/手术定价
|
||||
// if (DefinitionTypeEnum.MEDICATION.getCode().equals(itemDefSearchParam.getDefinitionType())) {
|
||||
// // 获取药品定价列表
|
||||
// List<MedicationDefinition> medicationList =
|
||||
// medicationDefinitionService.listByIds(chargeItemDefinitionPage.getRecords().stream()
|
||||
// .filter(e -> e.getInstanceTable().equals("med_medication_definition"))
|
||||
// .map(ChargeItemDefinition::getInstanceId).collect(Collectors.toList()));
|
||||
//
|
||||
// return R.ok(ItemDefinitionAssembler.assembleMedDefinitionDto(chargeItemDefinitionPage,
|
||||
// chargeItemDefAppList, medicationList, itemDefSearchParam));
|
||||
// } else if (DefinitionTypeEnum.DEVICE.getCode().equals(itemDefSearchParam.getDefinitionType())) {
|
||||
// // 获取器具定价列表
|
||||
// List<DeviceDefinition> deviceDefinitionList = deviceDefinitionService.listByIds(chargeItemDefinitionPage
|
||||
// .getRecords().stream().filter(e -> e.getInstanceTable().equals("adm_device_definition"))
|
||||
// .map(ChargeItemDefinition::getInstanceId).collect(Collectors.toList()));
|
||||
//
|
||||
// return R.ok(ItemDefinitionAssembler.assembleDevDefinitionDto(chargeItemDefinitionPage,
|
||||
// chargeItemDefAppList, deviceDefinitionList, itemDefSearchParam));
|
||||
// } else if (DefinitionTypeEnum.ACTIVITY.getCode().equals(itemDefSearchParam.getDefinitionType())) {
|
||||
// List<ActivityDefinition> activityDefinitionList =
|
||||
// activityDefinitionService.listByIds(chargeItemDefinitionPage.getRecords().stream()
|
||||
// .filter(e -> e.getInstanceTable().equals("wor_activity_definition"))
|
||||
// .map(ChargeItemDefinition::getInstanceId).collect(Collectors.toList()));
|
||||
//
|
||||
// return R.ok(ItemDefinitionAssembler.assembleProDefinitionDto(chargeItemDefinitionPage,
|
||||
// chargeItemDefAppList, activityDefinitionList, itemDefSearchParam));
|
||||
// } else {
|
||||
// return R.ok(new Page<ChargeItemDefPageDto>());
|
||||
// }
|
||||
// } else {
|
||||
// return R.ok(new Page<ChargeItemDefPageDto>());
|
||||
// }
|
||||
// endregion
|
||||
|
||||
IPage<ChargeItemDefPageDto> chargeItemDefinitionPage = new Page<>();
|
||||
List<ChargeItemDefPageDto> chargeItemDefinitionList;
|
||||
|
||||
// TODO: 待测试
|
||||
// 跳过的数量
|
||||
int skipCount = 0;
|
||||
if (pageNo > 0) {
|
||||
skipCount = (pageNo - 1) * pageSize;
|
||||
}
|
||||
// 通过 DefinitionType 区分药品定价/器具定价/手术定价
|
||||
if (DefinitionTypeEnum.MEDICATION.getCode().equals(itemDefSearchParam.getDefinitionType())) {
|
||||
chargeItemDefinitionList =
|
||||
chargeItemDefSearchMapper.getMedList(itemDefSearchParam, pageNo, pageSize, skipCount);
|
||||
chargeItemDefinitionPage.setSize(pageSize);
|
||||
chargeItemDefinitionPage.setCurrent(pageNo);
|
||||
if (chargeItemDefinitionList.size() > 0) {
|
||||
chargeItemDefinitionPage.setTotal(chargeItemDefinitionList.get(0).getTotalCount());
|
||||
chargeItemDefinitionPage.setRecords(chargeItemDefinitionList);
|
||||
} else {
|
||||
chargeItemDefinitionPage.setTotal(0);
|
||||
chargeItemDefinitionPage.setRecords(new ArrayList<>());
|
||||
}
|
||||
return R.ok(chargeItemDefinitionPage);
|
||||
} else if (DefinitionTypeEnum.DEVICE.getCode().equals(itemDefSearchParam.getDefinitionType())) {
|
||||
chargeItemDefinitionList =
|
||||
chargeItemDefSearchMapper.getDevList(itemDefSearchParam, pageNo, pageSize, skipCount);
|
||||
chargeItemDefinitionPage.setSize(pageSize);
|
||||
chargeItemDefinitionPage.setCurrent(pageNo);
|
||||
if (chargeItemDefinitionList.size() > 0) {
|
||||
chargeItemDefinitionPage.setTotal(chargeItemDefinitionList.get(0).getTotalCount());
|
||||
chargeItemDefinitionPage.setRecords(chargeItemDefinitionList);
|
||||
} else {
|
||||
chargeItemDefinitionPage.setTotal(0);
|
||||
chargeItemDefinitionPage.setRecords(new ArrayList<>());
|
||||
}
|
||||
return R.ok(chargeItemDefinitionPage);
|
||||
} else if (DefinitionTypeEnum.ACTIVITY.getCode().equals(itemDefSearchParam.getDefinitionType())) {
|
||||
chargeItemDefinitionList =
|
||||
chargeItemDefSearchMapper.getActList(itemDefSearchParam, pageNo, pageSize, skipCount);
|
||||
chargeItemDefinitionPage.setSize(pageSize);
|
||||
chargeItemDefinitionPage.setCurrent(pageNo);
|
||||
if (chargeItemDefinitionList.size() > 0) {
|
||||
chargeItemDefinitionPage.setTotal(chargeItemDefinitionList.get(0).getTotalCount());
|
||||
chargeItemDefinitionPage.setRecords(chargeItemDefinitionList);
|
||||
} else {
|
||||
chargeItemDefinitionPage.setTotal(0);
|
||||
chargeItemDefinitionPage.setRecords(new ArrayList<>());
|
||||
}
|
||||
return R.ok(chargeItemDefinitionPage);
|
||||
} else {
|
||||
return R.ok();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改项目定价
|
||||
*
|
||||
* @param itemDefinitionDto 修改内容
|
||||
* @return 修改结果
|
||||
*/
|
||||
@PutMapping(value = "/item-definition")
|
||||
public R<?> edit(@Validated @RequestBody ItemDefinitionDto itemDefinitionDto) {
|
||||
// 更新adm_charge_item_definition信息
|
||||
ChargeItemDefinition chargeItemDefinition = new ChargeItemDefinition();
|
||||
BeanUtils.copyProperties(itemDefinitionDto, chargeItemDefinition);
|
||||
if (!chargeItemDefinitionService.updateById(chargeItemDefinition)) {
|
||||
return R.fail();
|
||||
}
|
||||
|
||||
// 更新收费项目adm_charge_item_def_app
|
||||
ChargeItemDefApp chargeItemDefApp = new ChargeItemDefApp();
|
||||
BeanUtils.copyProperties(itemDefinitionDto, chargeItemDefApp);
|
||||
chargeItemDefApp.setDefinitionId(itemDefinitionDto.getId());
|
||||
chargeItemDefApp.setId(itemDefinitionDto.getItemId());
|
||||
return chargeItemDefAppService.updateChargeItemDefApp(chargeItemDefApp)
|
||||
? R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00002, new Object[] {"费用定价"}))
|
||||
: R.fail(PromptMsgConstant.Common.M00007, null);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,90 @@
|
||||
/*
|
||||
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||
*/
|
||||
package com.openhis.web.datadictionary.dto;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.Date;
|
||||
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
/**
|
||||
* 费用定价分页Dto
|
||||
*
|
||||
* @author zxy
|
||||
* @date 2025-02-21
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
public class ChargeItemDefPageDto {
|
||||
|
||||
/** ID */
|
||||
private Long id;
|
||||
|
||||
/** 费用定价子表主键 */
|
||||
private Long itemId;
|
||||
|
||||
/** 名称 */
|
||||
private String chargeName;
|
||||
|
||||
/** 项目编号 */
|
||||
private String itemNo;
|
||||
|
||||
/** 规格 */
|
||||
private String totalVolume;
|
||||
|
||||
/** 状态 */
|
||||
private Integer statusEnum;
|
||||
|
||||
/** 单位 */
|
||||
private String unitCode;
|
||||
|
||||
/** 拆零比 */
|
||||
private BigDecimal partPercent;
|
||||
|
||||
/** 指导价 */
|
||||
private BigDecimal conditionYbCode;
|
||||
|
||||
/** 批次号 */
|
||||
private String conditionLotnumber;
|
||||
|
||||
/** 价格 */
|
||||
private BigDecimal price;
|
||||
|
||||
/** 有效时间开始 */
|
||||
private Date effectiveStart;
|
||||
|
||||
/** 有效时间结束 */
|
||||
private Date effectiveEnd;
|
||||
|
||||
/** 拆零最小单位 */
|
||||
private String partMinUnitCode;
|
||||
|
||||
/** 拆零指导价 */
|
||||
private BigDecimal partConditionPrice;
|
||||
|
||||
/** 拆零价格 */
|
||||
private BigDecimal partPrice;
|
||||
|
||||
/** 条件价格 */
|
||||
private BigDecimal amount;
|
||||
|
||||
/** 调价说明 */
|
||||
private String description;
|
||||
|
||||
/** 优先级 */
|
||||
private Integer priority;
|
||||
|
||||
/** 条件规则 */
|
||||
private Integer conditionRuleId;
|
||||
|
||||
/** 创建时间 */
|
||||
private Date createTime;
|
||||
|
||||
/** 调价时间 */
|
||||
private Date updateTime;
|
||||
|
||||
/** 总条数 */
|
||||
private Integer totalCount;
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
/*
|
||||
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||
*/
|
||||
package com.openhis.web.datadictionary.dto;
|
||||
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
/**
|
||||
* 项目定价查询dto
|
||||
*
|
||||
* @author zxy
|
||||
* @date 2025-02-21
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
public class ItemDefSearchParam {
|
||||
|
||||
/** 定价类型 */
|
||||
private String DefinitionType;
|
||||
/** 定价项目 */
|
||||
private String chargeItem;
|
||||
/** 模糊搜索条件 */
|
||||
private String searchKey;
|
||||
/** 状态 */
|
||||
private Integer statusEnum;
|
||||
}
|
||||
@@ -0,0 +1,96 @@
|
||||
/*
|
||||
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||
*/
|
||||
package com.openhis.web.datadictionary.dto;
|
||||
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.Date;
|
||||
|
||||
/**
|
||||
* 收费项目保存dto
|
||||
*
|
||||
* @author zxy
|
||||
* @date 2025-02-21
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
public class ItemDefinitionDto {
|
||||
|
||||
/** ID */
|
||||
private Long id;
|
||||
|
||||
/** 子表ID */
|
||||
private Long itemId;
|
||||
|
||||
/** 名称 */
|
||||
private String chargeName;
|
||||
|
||||
/** 标题 */
|
||||
private String title;
|
||||
|
||||
/** 状态 */
|
||||
private Integer statusEnum;
|
||||
|
||||
/** 机构编码 */
|
||||
private String orgCode;
|
||||
|
||||
/** 描述 */
|
||||
private String description;
|
||||
|
||||
/** 代码 */
|
||||
private String instanceTable;
|
||||
|
||||
/** 关联项目 */
|
||||
private Long instanceId;
|
||||
|
||||
/** 有效时间开始 */
|
||||
private Date effectiveStart;
|
||||
|
||||
/** 有效时间结束 */
|
||||
private Date effectiveEnd;
|
||||
|
||||
/** 财务类别 */
|
||||
private String typeCode;
|
||||
|
||||
/** 医保类别 */
|
||||
private Integer ybType;
|
||||
|
||||
/** 是否使用详细价格规则 */
|
||||
private Integer conditionFlag;
|
||||
|
||||
/** 基础价格 */
|
||||
private BigDecimal price;
|
||||
|
||||
/** 条件规则 */
|
||||
private Long conditionRuleId;
|
||||
|
||||
/** 批次号 */
|
||||
private String conditionLotnumber;
|
||||
|
||||
/** 医保相关价格 */
|
||||
private String conditionYbCode;
|
||||
|
||||
/** 采购售卖条件 */
|
||||
private String conditionInoutCode;
|
||||
|
||||
/** 条件类型 */
|
||||
private String conditionUnitCode;
|
||||
|
||||
/** 条件 */
|
||||
private String conditionCode;
|
||||
|
||||
/** 优先级 */
|
||||
private Integer priority;
|
||||
|
||||
/** 价格 */
|
||||
private BigDecimal amount;
|
||||
|
||||
/** 名称拼音码 */
|
||||
private String pyCode;
|
||||
|
||||
/** 类型 */
|
||||
private String typeEnum;
|
||||
}
|
||||
@@ -0,0 +1,57 @@
|
||||
package com.openhis.web.datadictionary.mapper;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.ibatis.annotations.Param;
|
||||
import org.springframework.stereotype.Repository;
|
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||
import com.openhis.administration.domain.ChargeItemDefinition;
|
||||
import com.openhis.web.datadictionary.dto.ChargeItemDefPageDto;
|
||||
import com.openhis.web.datadictionary.dto.ItemDefSearchParam;
|
||||
|
||||
/**
|
||||
* 费用定价管理Mapper接口
|
||||
*
|
||||
* @author system
|
||||
* @date 2025-02-20
|
||||
*/
|
||||
@Repository
|
||||
public interface ChargeItemDefSearchMapper extends BaseMapper<ChargeItemDefinition> {
|
||||
|
||||
/**
|
||||
* 药品费用定价分页查询
|
||||
*
|
||||
* @param itemDefSearchParam 查询条件
|
||||
* @param pageNo 页码
|
||||
* @param pageSize 页面大小
|
||||
* @param skipCount 跳过条数
|
||||
* @return 分页查询
|
||||
*/
|
||||
List<ChargeItemDefPageDto> getMedList(@Param("itemDefSearchParam") ItemDefSearchParam itemDefSearchParam,
|
||||
@Param("pageNo") Integer pageNo, @Param("pageSize") Integer pageSize, @Param("skipCount") Integer skipCount);
|
||||
|
||||
/**
|
||||
* 器具费用定价分页查询
|
||||
*
|
||||
* @param itemDefSearchParam 查询条件
|
||||
* @param pageNo 页码
|
||||
* @param pageSize 页面大小
|
||||
* @param skipCount 跳过条数
|
||||
* @return 分页查询
|
||||
*/
|
||||
List<ChargeItemDefPageDto> getDevList(@Param("itemDefSearchParam") ItemDefSearchParam itemDefSearchParam,
|
||||
@Param("pageNo") Integer pageNo, @Param("pageSize") Integer pageSize, @Param("skipCount") int skipCount);
|
||||
|
||||
/**
|
||||
* 活动费用定价分页查询
|
||||
*
|
||||
* @param itemDefSearchParam 查询条件
|
||||
* @param pageNo 页码
|
||||
* @param pageSize 页面大小
|
||||
* @param skipCount 跳过条数
|
||||
* @return 分页查询
|
||||
*/
|
||||
List<ChargeItemDefPageDto> getActList(@Param("itemDefSearchParam") ItemDefSearchParam itemDefSearchParam,
|
||||
@Param("pageNo") Integer pageNo, @Param("pageSize") Integer pageSize, @Param("skipCount") int skipCount);
|
||||
}
|
||||
@@ -0,0 +1,238 @@
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<!DOCTYPE mapper
|
||||
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="com.openhis.web.datadictionary.mapper.ChargeItemDefSearchMapper">
|
||||
|
||||
<select id="getMedList" resultType="com.openhis.web.datadictionary.dto.ChargeItemDefPageDto">
|
||||
SELECT
|
||||
T5.id,
|
||||
T5.charge_name,
|
||||
T5.status_enum,
|
||||
T5.description,
|
||||
T5.effective_start,
|
||||
T5.effective_end,
|
||||
T5.instance_table,
|
||||
T5.price,
|
||||
T5.create_time,
|
||||
T5.update_time,
|
||||
T5.item_id,
|
||||
T5.condition_rule_id,
|
||||
T5.condition_lotnumber,
|
||||
T5.condition_yb_code,
|
||||
T5.priority,
|
||||
T5.amount,
|
||||
T5.item_no,
|
||||
T5.py_str,
|
||||
T5.wb_str,
|
||||
T5.unit_code,
|
||||
T5.category_code,
|
||||
T5.total_volume,
|
||||
T5.lot_number,
|
||||
COUNT(1) OVER() AS TOTAL_COUNT
|
||||
FROM (
|
||||
SELECT
|
||||
T1.id,
|
||||
T1.charge_name,
|
||||
T1.status_enum,
|
||||
T1.description,
|
||||
T1.effective_start,
|
||||
T1.effective_end,
|
||||
T1.instance_table,
|
||||
T1.price,
|
||||
T1.create_time,
|
||||
T1.update_time,
|
||||
T2.id AS item_id,
|
||||
T2.condition_rule_id,
|
||||
T2.condition_lotnumber,
|
||||
T2.condition_yb_code,
|
||||
T2.priority,
|
||||
T2.amount,
|
||||
T3.bus_no AS item_no,
|
||||
T3.py_str,
|
||||
T3.wb_str,
|
||||
T3.unit_code,
|
||||
T3.category_code,
|
||||
T4.total_volume,
|
||||
T4.lot_number
|
||||
FROM
|
||||
adm_charge_item_definition T1
|
||||
LEFT JOIN adm_charge_item_def_app T2
|
||||
ON T1.id = T2.definition_id
|
||||
LEFT JOIN med_medication_definition T3
|
||||
ON T1.instance_id = T3.id
|
||||
LEFT JOIN med_medication T4
|
||||
ON T3.id = T4.medication_def_id) T5
|
||||
<where>
|
||||
T5.instance_table = 'med_medication_definition'
|
||||
<if test="itemDefSearchParam.getSearchKey() != null">
|
||||
AND T5.charge_name LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
OR T5.code LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
OR T5.py_code LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
</if>
|
||||
<if test="itemDefSearchParam.getStatusEnum() != null">
|
||||
AND T5.status_enum = #{itemDefSearchParam.statusEnum}
|
||||
</if>
|
||||
<if test="itemDefSearchParam.getCategoryCode() != null">
|
||||
AND T5.category_code = #{itemDefSearchParam.chargeItem}
|
||||
</if>
|
||||
</where>
|
||||
ORDER BY T5.create_time DESC
|
||||
<!-- 拼接页码 -->
|
||||
<if test="skipCount != null and pageSize != null and pageSize > 0">
|
||||
LIMIT #{pageSize} OFFSET #{skipCount}
|
||||
</if>
|
||||
</select>
|
||||
|
||||
<select id="getDevList" resultType="com.openhis.web.datadictionary.dto.ChargeItemDefPageDto">
|
||||
SELECT
|
||||
T5.id,
|
||||
T5.charge_name,
|
||||
T5.status_enum,
|
||||
T5.description,
|
||||
T5.effective_start,
|
||||
T5.effective_end,
|
||||
T5.instance_table,
|
||||
T5.price,
|
||||
T5.create_time,
|
||||
T5.update_time,
|
||||
T5.item_id,
|
||||
T5.condition_rule_id,
|
||||
T5.condition_lotnumber,
|
||||
T5.condition_yb_code,
|
||||
T5.priority,
|
||||
T5.amount,
|
||||
T5.item_no,
|
||||
T5.py_code,
|
||||
T5.wb_code,
|
||||
T5.unit_code,
|
||||
T5.category_code,
|
||||
T5.lot_number,
|
||||
COUNT(1) OVER() AS TOTAL_COUNT
|
||||
FROM (
|
||||
SELECT
|
||||
T1.id,
|
||||
T1.charge_name,
|
||||
T1.status_enum,
|
||||
T1.description,
|
||||
T1.effective_start,
|
||||
T1.effective_end,
|
||||
T1.instance_table,
|
||||
T1.price,
|
||||
T1.create_time,
|
||||
T1.update_time,
|
||||
T2.id AS item_id,
|
||||
T2.condition_rule_id,
|
||||
T2.condition_lotnumber,
|
||||
T2.condition_yb_code,
|
||||
T2.priority,
|
||||
T2.amount,
|
||||
T3.code AS item_no,
|
||||
T3.py_code,
|
||||
T3.wb_code,
|
||||
T3.unit_code AS unit_code,
|
||||
T3.device_class AS category_code,
|
||||
T4.lot_number
|
||||
FROM
|
||||
adm_charge_item_definition T1
|
||||
LEFT JOIN adm_charge_item_def_app T2
|
||||
ON T1.id = T2.definition_id
|
||||
LEFT JOIN adm_device_definition T3
|
||||
ON T1.instance_id = T3.id
|
||||
LEFT JOIN adm_device T4
|
||||
ON T3.id = T4.def_id) T5
|
||||
<where>
|
||||
T5.instance_table = 'adm_device_definition'
|
||||
<if test="itemDefSearchParam.getSearchKey() != null">
|
||||
AND T5.charge_name LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
OR T5.code LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
OR T5.py_code LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
</if>
|
||||
<if test="itemDefSearchParam.getStatusEnum() != null">
|
||||
AND T5.status_enum = #{itemDefSearchParam.statusEnum}
|
||||
</if>
|
||||
<if test="itemDefSearchParam.getCategoryCode() != null">
|
||||
AND T5.category_code = #{itemDefSearchParam.chargeItem}
|
||||
</if>
|
||||
</where>
|
||||
ORDER BY T5.create_time DESC
|
||||
<!-- 拼接页码 -->
|
||||
<if test="skipCount != null and pageSize != null and pageSize > 0">
|
||||
LIMIT #{pageSize} OFFSET #{skipCount}
|
||||
</if>
|
||||
</select>
|
||||
|
||||
<select id="getActList" resultType="com.openhis.web.datadictionary.dto.ChargeItemDefPageDto">
|
||||
SELECT
|
||||
T5.id,
|
||||
T5.charge_name,
|
||||
T5.status_enum,
|
||||
T5.description,
|
||||
T5.effective_start,
|
||||
T5.effective_end,
|
||||
T5.instance_table,
|
||||
T5.price,
|
||||
T5.create_time,
|
||||
T5.update_time,
|
||||
T5.item_id,
|
||||
T5.condition_rule_id,
|
||||
T5.condition_lotnumber,
|
||||
T5.condition_yb_code,
|
||||
T5.priority,
|
||||
T5.amount,
|
||||
T5.item_no,
|
||||
T5.py_code,
|
||||
T5.wb_code,
|
||||
T5.unit_code,
|
||||
T5.category_code,
|
||||
COUNT(1) OVER() AS TOTAL_COUNT
|
||||
FROM (
|
||||
SELECT
|
||||
T1.id,
|
||||
T1.charge_name,
|
||||
T1.status_enum,
|
||||
T1.description,
|
||||
T1.effective_start,
|
||||
T1.effective_end,
|
||||
T1.instance_table,
|
||||
T1.price,
|
||||
T1.create_time,
|
||||
T1.update_time,
|
||||
T2.id AS item_id,
|
||||
T2.condition_rule_id,
|
||||
T2.condition_lotnumber,
|
||||
T2.condition_yb_code,
|
||||
T2.priority,
|
||||
T2.amount,
|
||||
T3.code AS item_no,
|
||||
T3.py_code,
|
||||
T3.wb_code,
|
||||
T3.permitted_unit AS unit_code,
|
||||
T3.type_enum AS category_code
|
||||
FROM
|
||||
adm_charge_item_definition T1
|
||||
LEFT JOIN adm_charge_item_def_app T2
|
||||
ON T1.id = T2.definition_id
|
||||
LEFT JOIN wor_activity_definition T3
|
||||
ON T1.instance_id = T3.id) T5
|
||||
<where>
|
||||
T5.instance_table = 'wor_activity_definition'
|
||||
<if test="itemDefSearchParam.getSearchKey() != null">
|
||||
AND T5.charge_name LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
OR T5.code LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
OR T5.py_code LIKE CONCAT('%', #{itemDefSearchParam.searchKey}, '%')
|
||||
</if>
|
||||
<if test="itemDefSearchParam.getStatusEnum() != null">
|
||||
AND T5.status_enum = #{itemDefSearchParam.statusEnum}
|
||||
</if>
|
||||
<if test="itemDefSearchParam.getCategoryCode() != null">
|
||||
AND T5.category_code = #{itemDefSearchParam.chargeItem}
|
||||
</if>
|
||||
</where>
|
||||
ORDER BY T5.create_time DESC
|
||||
<!-- 拼接页码 -->
|
||||
<if test="skipCount != null and pageSize != null and pageSize > 0">
|
||||
LIMIT #{pageSize} OFFSET #{skipCount}
|
||||
</if>
|
||||
</select>
|
||||
</mapper>
|
||||
@@ -11,4 +11,27 @@ import com.openhis.administration.domain.ChargeItemDefApp;
|
||||
*/
|
||||
public interface IChargeItemDefAppService extends IService<ChargeItemDefApp> {
|
||||
|
||||
/**
|
||||
* 更新项目定价
|
||||
*
|
||||
* @param chargeItemDefApp 更新内容
|
||||
* @return 更新结果
|
||||
*/
|
||||
boolean updateChargeItemDefApp(ChargeItemDefApp chargeItemDefApp);
|
||||
|
||||
/**
|
||||
* 新增费用定价
|
||||
*
|
||||
* @param chargeItemDefApp 新增内容
|
||||
* @return 新增结果
|
||||
*/
|
||||
boolean addChargeItemDefApp(ChargeItemDefApp chargeItemDefApp);
|
||||
|
||||
/**
|
||||
* 删除费用定价
|
||||
*
|
||||
* @param id 费用定价id
|
||||
* @return 新增结果
|
||||
*/
|
||||
boolean deleteChargeItemDefApp(Long id);
|
||||
}
|
||||
@@ -1,5 +1,6 @@
|
||||
package com.openhis.administration.service;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import com.openhis.administration.domain.ChargeItemDefinition;
|
||||
|
||||
@@ -11,4 +12,29 @@ import com.openhis.administration.domain.ChargeItemDefinition;
|
||||
*/
|
||||
public interface IChargeItemDefinitionService extends IService<ChargeItemDefinition> {
|
||||
|
||||
/**
|
||||
* 获取定价分页列表
|
||||
*
|
||||
* @param chargeItemDefinition 定价查询条件
|
||||
* @param pageNo 页码
|
||||
* @param pageSize 页面大小
|
||||
* @return 定价分页列表
|
||||
*/
|
||||
Page<ChargeItemDefinition> getPage(ChargeItemDefinition chargeItemDefinition, Integer pageNo, Integer pageSize);
|
||||
|
||||
/**
|
||||
* 新增费用定价
|
||||
*
|
||||
* @param chargeItemDefinition 新增内容
|
||||
* @return 新增结果
|
||||
*/
|
||||
boolean addChargeItemDefinition(ChargeItemDefinition chargeItemDefinition);
|
||||
|
||||
/**
|
||||
* 删除费用定价
|
||||
*
|
||||
* @param id 费用定价id
|
||||
* @return 新增结果
|
||||
*/
|
||||
boolean deleteChargeItemDefinition(Long id);
|
||||
}
|
||||
@@ -14,6 +14,58 @@ import com.openhis.administration.service.IChargeItemDefAppService;
|
||||
* @date 2025-02-20
|
||||
*/
|
||||
@Service
|
||||
public class ChargeItemDefAppServiceImpl extends ServiceImpl<ChargeItemDefAppMapper, ChargeItemDefApp> implements IChargeItemDefAppService {
|
||||
public class ChargeItemDefAppServiceImpl extends ServiceImpl<ChargeItemDefAppMapper, ChargeItemDefApp>
|
||||
implements IChargeItemDefAppService {
|
||||
|
||||
/**
|
||||
* 更新项目定价
|
||||
*
|
||||
* @param chargeItemDefApp 更新内容
|
||||
* @return 更新结果
|
||||
*/
|
||||
@Override
|
||||
public boolean updateChargeItemDefApp(ChargeItemDefApp chargeItemDefApp) {
|
||||
// 更新样例 一切以实际为主
|
||||
if (chargeItemDefApp.getId() != null) {
|
||||
// 获取更新前收费项目,避免更新导致数据库崩溃
|
||||
if (baseMapper.selectById(chargeItemDefApp.getId()) == null) {
|
||||
return false;
|
||||
} else {
|
||||
return baseMapper.updateById(chargeItemDefApp) > 0;
|
||||
}
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增费用定价
|
||||
*
|
||||
* @param chargeItemDefApp 新增内容
|
||||
* @return 新增结果
|
||||
*/
|
||||
@Override
|
||||
public boolean addChargeItemDefApp(ChargeItemDefApp chargeItemDefApp) {
|
||||
//此判断是为了避免插入时主键重复
|
||||
if (chargeItemDefApp.getId() != null) {
|
||||
return false;
|
||||
} else {
|
||||
return baseMapper.insert(chargeItemDefApp) > 0;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除费用定价
|
||||
*
|
||||
* @param id 费用定价id
|
||||
* @return 新增结果
|
||||
*/
|
||||
@Override
|
||||
public boolean deleteChargeItemDefApp(Long id) {
|
||||
if (baseMapper.selectById(id) == null) {
|
||||
return false;
|
||||
} else {
|
||||
return baseMapper.deleteById(id) > 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -2,10 +2,13 @@ package com.openhis.administration.service.impl;
|
||||
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import com.openhis.administration.domain.ChargeItemDefinition;
|
||||
import com.openhis.administration.mapper.ChargeItemDefinitionMapper;
|
||||
import com.openhis.administration.service.IChargeItemDefinitionService;
|
||||
import com.openhis.common.enums.DelFlag;
|
||||
|
||||
/**
|
||||
* 费用定价管理Service业务层处理
|
||||
@@ -14,6 +17,60 @@ import com.openhis.administration.service.IChargeItemDefinitionService;
|
||||
* @date 2025-02-20
|
||||
*/
|
||||
@Service
|
||||
public class ChargeItemDefinitionServiceImpl extends ServiceImpl<ChargeItemDefinitionMapper, ChargeItemDefinition> implements IChargeItemDefinitionService {
|
||||
public class ChargeItemDefinitionServiceImpl extends ServiceImpl<ChargeItemDefinitionMapper, ChargeItemDefinition>
|
||||
implements IChargeItemDefinitionService {
|
||||
|
||||
/**
|
||||
* 获取分页列表
|
||||
*
|
||||
* @param chargeItemDefinition 查询条件
|
||||
* @param pageNo 页码
|
||||
* @param pageSize 页面大小
|
||||
* @return 分页列表
|
||||
*/
|
||||
@Override
|
||||
public Page<ChargeItemDefinition> getPage(ChargeItemDefinition chargeItemDefinition, Integer pageNo,
|
||||
Integer pageSize) {
|
||||
|
||||
LambdaQueryWrapper<ChargeItemDefinition> queryWrapper = new LambdaQueryWrapper<>();
|
||||
queryWrapper.eq(ChargeItemDefinition::getDeleteFlag, DelFlag.NO.getValue());
|
||||
|
||||
//拼接查询条件
|
||||
if (chargeItemDefinition.getStatusEnum() != null) {
|
||||
queryWrapper.eq(ChargeItemDefinition::getStatusEnum, chargeItemDefinition.getStatusEnum());
|
||||
}
|
||||
|
||||
return baseMapper.selectPage(new Page<>(pageNo, pageSize), queryWrapper);
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增费用定价
|
||||
*
|
||||
* @param chargeItemDefinition 新增内容
|
||||
* @return 新增结果
|
||||
*/
|
||||
@Override
|
||||
public boolean addChargeItemDefinition(ChargeItemDefinition chargeItemDefinition) {
|
||||
//此判断是为了避免插入时主键重复
|
||||
if (chargeItemDefinition.getId() != null) {
|
||||
return false;
|
||||
} else {
|
||||
return baseMapper.insert(chargeItemDefinition) > 0;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除费用定价
|
||||
*
|
||||
* @param id 费用定价id
|
||||
* @return 新增结果
|
||||
*/
|
||||
@Override
|
||||
public boolean deleteChargeItemDefinition(Long id) {
|
||||
if (baseMapper.selectById(id) == null) {
|
||||
return false;
|
||||
} else {
|
||||
return baseMapper.deleteById(id) > 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user