Compare commits

..

8 Commits

Author SHA1 Message Date
Ranyunqiao
f84940fa5f 553 【住院护士站-医嘱校对】医嘱列表缺少“医嘱状态”显示列 2026-05-19 18:08:44 +08:00
e3db810972 Fix Bug #469: 根因+修复方案摘要 2026-05-19 18:08:44 +08:00
85e95420b7 Fix Bug #547: 执行科室配置保存时,冲突检测应跳过已被软删除科室的孤脏记录 — 根因:时间冲突校验未排除科室已删除的 OrganizationLocation 记录,导致已不存在的科室仍会阻断新配置保存
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-19 18:08:44 +08:00
206a0f4083 Fix Bug #478: 住院医生工作站检验申请详情「发往科室」显示为- — 根因:getLocationInfo 未对科室ID做类型归一化,recursionFun 中 item.id == targetDepartment 在类型不一致时匹配失败;修复:新增 normalizeOrgTreeIds 统一转 String,recursionFun 改用 String(item.id) === String(targetDepartment)
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-19 18:08:44 +08:00
5e9aaebc7a Fix Bug #552: 根因+修复方案摘要 2026-05-19 18:08:44 +08:00
f925731f6f bug550 2026-05-19 18:08:44 +08:00
Ranyunqiao
156a3f0f24 bug 443 444 445 478 494 521 2026-05-19 18:08:43 +08:00
85d254990f Fix Bug #552: 双击待保存医嘱编辑保存后不应自动添加空医嘱 — 根因:handleSaveSign 中自动添加空行的条件缺少 isAdding.value 判断,导致双击编辑已有待保存医嘱也会触发 handleAddPrescription()
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-19 14:05:56 +08:00
636 changed files with 24917 additions and 77342 deletions

View File

@@ -1,27 +0,0 @@
# Bug #556 Analysis
## Title
【门诊医生站-检验】新增检验申请单时就诊卡号/执行时间未自动回显,且项目列表冗余显示"套餐"文字
## Root Cause Analysis
### Issue 1: 就诊卡号未自动回显
- **Code**: `inspectionApplication.vue:886` - `formData.medicalrecordNumber = props.patientInfo.identifierNo || ''`
- **Root Cause**: Logic is correct but depends on `props.patientInfo.identifierNo` being populated. The watch on `props.patientInfo` (line 2074) triggers `initData()`. The card number field itself is correctly bound. This is likely a timing issue where the patient data loads before `identifierNo` is available, but the core code path is correct — no code change needed here beyond ensuring executeTime default doesn't block form rendering.
### Issue 2: 执行时间未默认填充当前系统时间
- **Code**: `inspectionApplication.vue:978` - `executeTime: null`
- **Root Cause**: In `initData()` (line 879-921), only `applyTime` is set via `startApplyTimeTimer()`. `formData.executeTime` is never assigned a default value. Similarly in `resetForm()` (line 1550), `executeTime` remains `null`.
- **Fix**: Add `formData.executeTime = formatDateTime(new Date())` in `initData()` and change `resetForm()` to use `executeTime: formatDateTime(new Date())`.
### Issue 3: 项目列表冗余显示"套餐"文字
- **Code**: `inspectionApplication.vue:1190` - Already fixed with `packageName` check. But `inspectionApplication.vue:2000` in `loadApplicationToForm()` still uses loose check: `item.feePackageId != null || item.itemName?.includes('套餐')`.
- **Fix**: Update `loadApplicationToForm()` line 2000 to match the stricter check: `item.feePackageId != null && item.feePackageId !== '' && item.feePackageId !== 'null' && item.packageName`.
## Files to Modify
- `openhis-ui-vue3/src/views/doctorstation/components/inspection/inspectionApplication.vue`
## Changes
1. `initData()`: Add `formData.executeTime = formatDateTime(new Date())` after line 899
2. `resetForm()`: Change `executeTime: null` to `executeTime: formatDateTime(new Date())` at line 1550
3. `loadApplicationToForm()`: Fix `isPackage` logic at line 2000

View File

@@ -1,53 +0,0 @@
# Bug #556 分析报告
## 问题描述
【门诊医生站-检验】新增检验申请单时:
1. 就诊卡号字段为空,未自动带出患者就诊卡号
2. 执行时间字段未自动填充,仅显示占位提示
3. 检验项目列表每条记录前均带"套餐"文字标签(冗余显示)
## 根因分析
### 问题1就诊卡号未自动回显
- 代码路径:`initData()``formData.medicalrecordNumber = props.patientInfo.identifierNo || ''`
- 数据绑定:`v-model="formData.medicalrecordNumber"`
- `props.patientInfo` 由父组件传入,字段 `identifierNo` 来自后端患者信息
- 当前逻辑本身正确,但需要增加兜底回读机制(已有 #406 的同步逻辑在 handleSave 中initData 也应覆盖)
- **结论**:代码路径正确,如果 identifierNo 为空则是父组件传参问题;已在 handleSave 中有同步逻辑initData 中已有逻辑。无需额外修复。
### 问题2执行时间未自动填充
- 根因:`formData.executeTime``formData` 初始化时line 978设为 `null`
- `initData()` 函数没有为 executeTime 设置默认值
- `resetForm()` 函数line 1550也将 executeTime 重置为 `null`
- 前端 datetime picker 在 `v-model``null` 时显示占位符 "选择执行时间"
- **修复方案**:在 `initData()` 中设置 `formData.executeTime = formatDateTime(new Date())`;在 `resetForm()` 中也同样设置默认值为当前时间
### 问题3项目列表冗余显示"套餐"文字
- 根因:`isPackage` 判定条件不一致
- `loadCategoryItems()` (line 1190): 使用 `item.feePackageId != null && ... && item.packageName` — ✅ 正确(同时检查 feePackageId 有效 + packageName 非空)
- `loadApplicationToForm()` (line 2000): 使用 `item.feePackageId != null || item.itemName?.includes('套餐')` — ❌ 错误
- `feePackageId != null` 单独判断会导致普通项目因 feePackageId 有值被误标为套餐
- `item.itemName?.includes('套餐')` 更是直接按名称文字判断,极不准确
- 影响位置:
- 检验项目选择区line 566`<el-tag v-if="item.isPackage">套餐</el-tag>`
- 已选项目列表line 617`<el-tag v-if="item.isPackage">套餐</el-tag>`
- 检验信息详情表格line 448`<el-tag v-if="scope.row.isPackage">套餐</el-tag>`
- **修复方案**:将 `loadApplicationToForm()` 中的 `isPackage` 判定统一为与 `loadCategoryItems()` 一致的逻辑
## 修复方案
### 修复1执行时间默认填充
- 文件:`inspectionApplication.vue`
- 位置:`initData()` 函数,在已有患者信息赋值后添加 `formData.executeTime = formatDateTime(new Date())`
- 位置:`resetForm()` 函数,将 `executeTime: null` 改为使用当前时间
### 修复2isPackage 判定统一
- 文件:`inspectionApplication.vue`
- 位置:`loadApplicationToForm()` 函数 line 2000
- 旧代码:`const isPackage = item.feePackageId != null || item.itemName?.includes('套餐')`
- 新代码:`const isPackage = item.feePackageId != null && item.feePackageId !== '' && item.feePackageId !== 'null' && item.packageName`
## 验收标准
1. 新增检验申请单时执行时间字段自动填充当前系统时间YYYY-MM-DD HH:mm:ss 格式)
2. 检验项目列表中,只有真正的套餐项目前显示"套餐"标签,普通项目不显示
3. 就诊卡号在有患者信息时正常显示

Submodule his-repo updated: 515ed84118...5de8a22418

View File

@@ -1,7 +1,6 @@
package com.core.framework.config; package com.core.framework.config;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer; import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
import org.mybatis.spring.annotation.MapperScan; import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.autoconfigure.jackson.Jackson2ObjectMapperBuilderCustomizer; import org.springframework.boot.autoconfigure.jackson.Jackson2ObjectMapperBuilderCustomizer;
@@ -35,9 +34,7 @@ public class ApplicationConfig {
// 设置日期格式为 yyyy/M/d HH:mm:ss支持多种格式反序列化 // 设置日期格式为 yyyy/M/d HH:mm:ss支持多种格式反序列化
builder.simpleDateFormat("yyyy/M/d HH:mm:ss"); builder.simpleDateFormat("yyyy/M/d HH:mm:ss");
// 添加JavaTimeModule支持用于LocalDateTime // 添加JavaTimeModule支持用于LocalDateTime
JavaTimeModule javaTimeModule = new JavaTimeModule(); builder.modules(new JavaTimeModule());
javaTimeModule.addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
builder.modules(javaTimeModule);
builder.serializerByType(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern("yyyy/M/d HH:mm:ss"))); builder.serializerByType(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern("yyyy/M/d HH:mm:ss")));
}; };
} }

View File

@@ -199,7 +199,7 @@ public class TicketAppServiceImpl implements ITicketAppService {
if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) { if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) {
dto.setStatus("已退号"); dto.setStatus("已退号");
} else { } else {
dto.setStatus("预约"); dto.setStatus("锁定");
} }
} else if (status == SlotStatus.BOOKED) { } else if (status == SlotStatus.BOOKED) {
if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) { if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) {
@@ -380,7 +380,7 @@ public class TicketAppServiceImpl implements ITicketAppService {
if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) { if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) {
dto.setStatus("已退号"); dto.setStatus("已退号");
} else { } else {
dto.setStatus("预约"); dto.setStatus("锁定");
} }
} else if (status == SlotStatus.BOOKED) { } else if (status == SlotStatus.BOOKED) {
if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) { if (OrderStatus.PATIENT_CANCELLED.getValue().equals(raw.getOrderStatus())) {

View File

@@ -169,9 +169,11 @@ public class OrganizationLocationAppServiceImpl implements IOrganizationLocation
if (DateTimeUtils.isOverlap(organizationLocation.getStartTime(), organizationLocation.getEndTime(), if (DateTimeUtils.isOverlap(organizationLocation.getStartTime(), organizationLocation.getEndTime(),
orgLoc.getStartTime(), orgLoc.getEndTime())) { orgLoc.getStartTime(), orgLoc.getEndTime())) {
Organization org = organizationService.getById(organizationLocation.getOrganizationId()); Organization org = organizationService.getById(organizationLocation.getOrganizationId());
String organizationName = org != null ? org.getName() : ("科室[" + organizationLocation.getOrganizationId() + "]已删除"); if (org == null) {
continue;
}
return R.fail("当前诊疗:" + activityName + CommonConstants.Common.DASH + orgLoc.getStartTime() return R.fail("当前诊疗:" + activityName + CommonConstants.Common.DASH + orgLoc.getStartTime()
+ CommonConstants.Common.DASH + orgLoc.getEndTime() + "" + organizationName + "时间冲突"); + CommonConstants.Common.DASH + orgLoc.getEndTime() + "" + org.getName() + "时间冲突");
} }
if (orgLocQueryDto.getId() != null) { if (orgLocQueryDto.getId() != null) {

View File

@@ -31,9 +31,4 @@ public class OrgLocQueryParam implements Serializable {
/** 发放类别 */ /** 发放类别 */
private String distributionCategoryCode; private String distributionCategoryCode;
/**
* 项目编码 | 药品:1 耗材:2
*/
private String itemCode;
} }

View File

@@ -215,10 +215,7 @@ public class SurgicalScheduleAppServiceImpl implements ISurgicalScheduleAppServi
if (surgery != null) { if (surgery != null) {
surgery.setStatusEnum(1); // 1 = 已排期 surgery.setStatusEnum(1); // 1 = 已排期
surgery.setUpdateTime(new Date()); surgery.setUpdateTime(new Date());
// Bug #558: 手术安排时同步写入手术室确认时间和确认人
surgery.setOperatingRoomConfirmTime(new Date());
surgery.setOperatingRoomConfirmUser(loginUser.getUsername());
// 填充缺失的申请科室和主刀医生名称 // 填充缺失的申请科室和主刀医生名称
fillSurgeryMissingNames(surgery); fillSurgeryMissingNames(surgery);

View File

@@ -36,7 +36,4 @@ public class PerformInfoDto {
/** 分组id */ /** 分组id */
@JsonSerialize(using = ToStringSerializer.class) @JsonSerialize(using = ToStringSerializer.class)
private Long groupId; private Long groupId;
/** 退回原因 */
private String backReason;
} }

View File

@@ -147,6 +147,6 @@ public interface IDoctorStationAdviceAppService {
*/ */
IPage<SurgeryItemDto> getSurgeryPage(Long organizationId, Integer pageNo, Integer pageSize, String searchKey); IPage<SurgeryItemDto> getSurgeryPage(Long organizationId, Integer pageNo, Integer pageSize, String searchKey);
IPage<SurgeryItemDto> getExaminationPage(Long organizationId, Integer pageNo, Integer pageSize, String searchKey, String categoryCode); IPage<SurgeryItemDto> getExaminationPage(Long organizationId, Integer pageNo, Integer pageSize, String searchKey);
} }

View File

@@ -63,21 +63,17 @@ public interface IDoctorStationEmrAppService {
* 获取待写病历列表 * 获取待写病历列表
* *
* @param doctorId 医生ID * @param doctorId 医生ID
* @param pageNo 当前页码 * @return 待写病历列表
* @param pageSize 每页条数
* @param patientName 患者姓名(可选)
* @return 待写病历分页数据
*/ */
R<?> getPendingEmrList(Long doctorId, Integer pageNo, Integer pageSize, String patientName); R<?> getPendingEmrList(Long doctorId);
/** /**
* 获取待写病历数量 * 获取待写病历数量
* *
* @param doctorId 医生ID * @param doctorId 医生ID
* @param patientName 患者姓名(可选)
* @return 待写病历数量 * @return 待写病历数量
*/ */
R<?> getPendingEmrCount(Long doctorId, String patientName); R<?> getPendingEmrCount(Long doctorId);
/** /**
* 检查患者是否需要写病历 * 检查患者是否需要写病历

View File

@@ -2205,10 +2205,6 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp
// 收费状态 // 收费状态
requestBaseDto.setChargeStatus_enumText( requestBaseDto.setChargeStatus_enumText(
EnumUtils.getInfoByValue(ChargeItemStatus.class, requestBaseDto.getChargeStatus())); EnumUtils.getInfoByValue(ChargeItemStatus.class, requestBaseDto.getChargeStatus()));
// 单位字典翻译失败时回退使用原始值(如手术申请硬编码了中文单位名)
if (StringUtils.isNotBlank(requestBaseDto.getUnitCode()) && StringUtils.isBlank(requestBaseDto.getUnitCode_dictText())) {
requestBaseDto.setUnitCode_dictText(requestBaseDto.getUnitCode());
}
} }
return R.ok(requestBaseInfo); return R.ok(requestBaseInfo);
} }
@@ -2570,13 +2566,12 @@ public class DoctorStationAdviceAppServiceImpl implements IDoctorStationAdviceAp
} }
@Override @Override
public IPage<SurgeryItemDto> getExaminationPage(Long organizationId, Integer pageNo, Integer pageSize, String searchKey, String categoryCode) { public IPage<SurgeryItemDto> getExaminationPage(Long organizationId, Integer pageNo, Integer pageSize, String searchKey) {
IPage<SurgeryItemDto> result = doctorStationAdviceAppMapper.getExaminationPage( IPage<SurgeryItemDto> result = doctorStationAdviceAppMapper.getExaminationPage(
new Page<>(pageNo, pageSize), new Page<>(pageNo, pageSize),
PublicationStatus.ACTIVE.getValue(), PublicationStatus.ACTIVE.getValue(),
organizationId, organizationId,
searchKey, searchKey);
categoryCode);
return result; return result;
} }

View File

@@ -29,7 +29,6 @@ import com.openhis.document.service.IEmrTemplateService;
import com.openhis.web.doctorstation.appservice.IDoctorStationEmrAppService; import com.openhis.web.doctorstation.appservice.IDoctorStationEmrAppService;
import com.openhis.web.doctorstation.dto.EmrTemplateDto; import com.openhis.web.doctorstation.dto.EmrTemplateDto;
import com.openhis.web.doctorstation.dto.PatientEmrDto; import com.openhis.web.doctorstation.dto.PatientEmrDto;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeanUtils; import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@@ -42,7 +41,6 @@ import java.util.stream.Collectors;
/** /**
* 医生站-电子病历 应用实现类 * 医生站-电子病历 应用实现类
*/ */
@Slf4j
@Service @Service
public class DoctorStationEmrAppServiceImpl implements IDoctorStationEmrAppService { public class DoctorStationEmrAppServiceImpl implements IDoctorStationEmrAppService {
@@ -62,7 +60,13 @@ public class DoctorStationEmrAppServiceImpl implements IDoctorStationEmrAppServi
IDocRecordService docRecordService; IDocRecordService docRecordService;
@Resource @Resource
private com.openhis.web.doctorstation.mapper.DoctorStationEmrAppMapper doctorStationEmrAppMapper; private EncounterMapper encounterMapper;
@Resource
private PatientMapper patientMapper;
@Resource
private com.openhis.administration.mapper.EncounterParticipantMapper encounterParticipantMapper;
/** /**
* 添加病人病历信息 * 添加病人病历信息
@@ -219,29 +223,52 @@ public class DoctorStationEmrAppServiceImpl implements IDoctorStationEmrAppServi
* @return 待写病历列表 * @return 待写病历列表
*/ */
@Override @Override
public R<?> getPendingEmrList(Long doctorId, Integer pageNo, Integer pageSize, String patientName) { public R<?> getPendingEmrList(Long doctorId) {
// 先查询总数 // 由于Encounter实体中没有jzPractitionerUserId字段我们需要通过关联查询来获取相关信息
Long total = doctorStationEmrAppMapper.getPendingEmrCount(doctorId, patientName); // 使用医生工作站的mapper来查询相关数据
// 这里我们直接使用医生工作站的查询逻辑
// 计算分页偏移量,再查询分页数据 // 查询当前医生负责的、状态为"就诊中"但还没有写病历的患者
int offset = (pageNo - 1) * pageSize; // 需要通过EncounterParticipant表来关联医生信息
List<Map<String, Object>> pageRows = doctorStationEmrAppMapper.getPendingEmrList(doctorId, patientName, pageSize, offset); List<Encounter> encounters = encounterMapper.selectList(
new LambdaQueryWrapper<Encounter>()
.eq(Encounter::getStatusEnum, EncounterStatus.IN_PROGRESS.getValue())
);
// 计算年龄列 // 过滤出由指定医生负责且还没有写病历的就诊记录
for (Map<String, Object> row : pageRows) { List<Map<String, Object>> pendingEmrs = new ArrayList<>();
Object birthDate = row.get("birthDate"); for (Encounter encounter : encounters) {
if (birthDate instanceof Date) { // 检查该就诊记录是否已经有病历
row.put("age", calculateAge((Date) birthDate)); Emr existingEmr = emrService.getOne(
} else { new LambdaQueryWrapper<Emr>().eq(Emr::getEncounterId, encounter.getId())
row.put("age", null); );
// 检查该就诊是否由指定医生负责
boolean isAssignedToDoctor = isEncounterAssignedToDoctor(encounter.getId(), doctorId);
if (existingEmr == null && isAssignedToDoctor) {
// 如果没有病历且由该医生负责,则添加到待写病历列表
Map<String, Object> pendingEmr = new java.util.HashMap<>();
// 获取患者信息
Patient patient = patientMapper.selectById(encounter.getPatientId());
pendingEmr.put("encounterId", encounter.getId());
pendingEmr.put("patientId", encounter.getPatientId());
pendingEmr.put("patientName", patient != null ? patient.getName() : "未知");
pendingEmr.put("gender", patient != null ? patient.getGenderEnum() : null);
// 使用出生日期计算年龄
pendingEmr.put("age", patient != null && patient.getBirthDate() != null ?
calculateAge(patient.getBirthDate()) : null);
// 使用创建时间作为挂号时间
pendingEmr.put("registerTime", encounter.getCreateTime());
pendingEmr.put("busNo", encounter.getBusNo()); // 病历号
pendingEmrs.add(pendingEmr);
} }
row.remove("birthDate");
} }
Map<String, Object> result = new java.util.HashMap<>(); return R.ok(pendingEmrs);
result.put("rows", pageRows);
result.put("total", total != null ? total : 0L);
return R.ok(result);
} }
/** /**
@@ -251,9 +278,14 @@ public class DoctorStationEmrAppServiceImpl implements IDoctorStationEmrAppServi
* @return 待写病历数量 * @return 待写病历数量
*/ */
@Override @Override
public R<?> getPendingEmrCount(Long doctorId, String patientName) { public R<?> getPendingEmrCount(Long doctorId) {
Long count = doctorStationEmrAppMapper.getPendingEmrCount(doctorId, patientName); // 获取待写病历列表,然后返回数量
return R.ok(count != null ? count.intValue() : 0); R<?> result = getPendingEmrList(doctorId);
if (result.getCode() == 200) {
List<?> pendingEmrs = (List<?>) result.getData();
return R.ok(pendingEmrs.size());
}
return R.ok(0);
} }
/** /**
@@ -274,6 +306,24 @@ public class DoctorStationEmrAppServiceImpl implements IDoctorStationEmrAppServi
return R.ok(needWrite); return R.ok(needWrite);
} }
/**
* 检查就诊是否分配给指定医生
*
* @param encounterId 就诊ID
* @param doctorId 医生ID
* @return 是否分配给指定医生
*/
private boolean isEncounterAssignedToDoctor(Long encounterId, Long doctorId) {
// 查询就诊参与者表,检查是否有指定医生的接诊记录
com.openhis.administration.domain.EncounterParticipant participant =
encounterParticipantMapper.selectOne(
new com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper<com.openhis.administration.domain.EncounterParticipant>()
.eq(com.openhis.administration.domain.EncounterParticipant::getEncounterId, encounterId)
.eq(com.openhis.administration.domain.EncounterParticipant::getPractitionerId, doctorId)
);
return participant != null;
}
/** /**
* 根据出生日期计算年龄 * 根据出生日期计算年龄

View File

@@ -77,10 +77,8 @@ public class DoctorStationAdviceController {
*/ */
@PostMapping(value = "/save-advice") @PostMapping(value = "/save-advice")
@RepeatSubmit(interval = 5000, message = "请勿重复提交医嘱,请稍候再试") @RepeatSubmit(interval = 5000, message = "请勿重复提交医嘱,请稍候再试")
public R<?> saveAdvice(@RequestBody AdviceSaveParam adviceSaveParam, public R<?> saveAdvice(@RequestBody AdviceSaveParam adviceSaveParam) {
@RequestParam(required = false, defaultValue = "1") String adviceOpType) { return iDoctorStationAdviceAppService.saveAdvice(adviceSaveParam, AdviceOpType.SAVE_ADVICE.getCode());
// 🔧 Bug #445 修复:使用前端传入的 adviceOpType 参数1=保存草稿2=签发),而非硬编码
return iDoctorStationAdviceAppService.saveAdvice(adviceSaveParam, adviceOpType);
} }
/** /**
@@ -228,9 +226,8 @@ public class DoctorStationAdviceController {
@RequestParam(value = "organizationId", required = false) Long organizationId, @RequestParam(value = "organizationId", required = false) Long organizationId,
@RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo,
@RequestParam(value = "pageSize", defaultValue = "500") Integer pageSize, @RequestParam(value = "pageSize", defaultValue = "500") Integer pageSize,
@RequestParam(value = "searchKey", defaultValue = "") String searchKey, @RequestParam(value = "searchKey", defaultValue = "") String searchKey) {
@RequestParam(value = "categoryCode", defaultValue = "23") String categoryCode) { return R.ok(iDoctorStationAdviceAppService.getExaminationPage(organizationId, pageNo, pageSize, searchKey));
return R.ok(iDoctorStationAdviceAppService.getExaminationPage(organizationId, pageNo, pageSize, searchKey, categoryCode));
} }
} }

View File

@@ -26,36 +26,34 @@ public class PendingEmrController {
* 获取待写病历列表 * 获取待写病历列表
* *
* @param doctorId 医生ID * @param doctorId 医生ID
* @param pageNo 当前页码 * @return 待写病历列表
* @param pageSize 每页条数
* @param patientName 患者姓名(可选)
* @return 待写病历分页数据
*/ */
@GetMapping("/pending-list") @GetMapping("/pending-list")
public R<?> getPendingEmrList(@RequestParam(required = false) Long doctorId, public R<?> getPendingEmrList(@RequestParam(required = false) Long doctorId) {
@RequestParam(defaultValue = "1") Integer pageNum, // 如果没有传递医生ID则使用当前登录用户ID
@RequestParam(defaultValue = "10") Integer pageSize,
@RequestParam(required = false) String patientName) {
if (doctorId == null) { if (doctorId == null) {
doctorId = com.core.common.utils.SecurityUtils.getLoginUser().getPractitionerId(); doctorId = com.core.common.utils.SecurityUtils.getLoginUser().getUserId();
} }
return iDoctorStationEmrAppService.getPendingEmrList(doctorId, pageNum, pageSize, patientName);
// 调用服务获取待写病历列表
return iDoctorStationEmrAppService.getPendingEmrList(doctorId);
} }
/** /**
* 获取待写病历数量 * 获取待写病历数量
* *
* @param doctorId 医生ID * @param doctorId 医生ID
* @param patientName 患者姓名(可选)
* @return 待写病历数量 * @return 待写病历数量
*/ */
@GetMapping("/pending-count") @GetMapping("/pending-count")
public R<?> getPendingEmrCount(@RequestParam(required = false) Long doctorId, public R<?> getPendingEmrCount(@RequestParam(required = false) Long doctorId) {
@RequestParam(required = false) String patientName) { // 如果没有传递医生ID则使用当前登录用户ID
if (doctorId == null) { if (doctorId == null) {
doctorId = com.core.common.utils.SecurityUtils.getLoginUser().getPractitionerId(); doctorId = com.core.common.utils.SecurityUtils.getLoginUser().getUserId();
} }
return iDoctorStationEmrAppService.getPendingEmrCount(doctorId, patientName);
// 调用服务获取待写病历数量
return iDoctorStationEmrAppService.getPendingEmrCount(doctorId);
} }
/** /**

View File

@@ -198,10 +198,8 @@ public class AdviceBaseDto {
/** /**
* 所属科室 * 所属科室
*/ */
@Dict(dictTable = "adm_organization", dictCode = "id", dictText = "name")
@JsonSerialize(using = ToStringSerializer.class) @JsonSerialize(using = ToStringSerializer.class)
private Long orgId; private Long orgId;
private String orgId_dictText;
/** /**
* 所在位置 * 所在位置

View File

@@ -8,10 +8,6 @@ import lombok.Data;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import java.math.BigDecimal; import java.math.BigDecimal;
import com.fasterxml.jackson.annotation.JsonFormat;
import org.springframework.format.annotation.DateTimeFormat;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonSetter; import com.fasterxml.jackson.annotation.JsonSetter;
import com.fasterxml.jackson.annotation.Nulls; import com.fasterxml.jackson.annotation.Nulls;
@@ -30,14 +26,6 @@ public class AdviceSaveDto {
/** 医嘱类型 */ /** 医嘱类型 */
private Integer adviceType; // 1:药品 , 2: 耗材 , 3:项目 private Integer adviceType; // 1:药品 , 2: 耗材 , 3:项目
/**
* 医嘱开始时间
*/
@JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date startTime;
/** /**
* 请求id * 请求id
*/ */

View File

@@ -63,18 +63,6 @@ public class PatientDetailsDto {
*/ */
private String address; private String address;
/** 地址省 */
private String addressProvince;
/** 地址市 */
private String addressCity;
/** 地址区 */
private String addressDistrict;
/** 地址街道 */
private String addressStreet;
/** /**
* 工作单位 * 工作单位
*/ */

View File

@@ -22,12 +22,6 @@ public class RequestBaseDto {
*/ */
private Integer adviceType; // 1:药品 , 2: 耗材 , 3:项目 private Integer adviceType; // 1:药品 , 2: 耗材 , 3:项目
/**
* 医嘱开始时间
*/
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss")
private Date startTime;
/** /**
* 唯一标识 * 唯一标识
*/ */
@@ -127,11 +121,6 @@ public class RequestBaseDto {
* 请求状态 * 请求状态
*/ */
private Integer statusEnum; private Integer statusEnum;
/**
* 退回原因
*/
private String reasonText;
private String statusEnum_enumText; private String statusEnum_enumText;
/** /**
@@ -249,15 +238,4 @@ public class RequestBaseDto {
@JsonSerialize(using = ToStringSerializer.class) @JsonSerialize(using = ToStringSerializer.class)
private Long patientId; private Long patientId;
/**
* 停嘱医生
*/
private String stopUserName;
/**
* 停嘱时间
*/
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss")
private Date stopTime;
} }

View File

@@ -203,7 +203,6 @@ public interface DoctorStationAdviceAppMapper {
IPage<SurgeryItemDto> getExaminationPage(@Param("page") Page<SurgeryItemDto> page, IPage<SurgeryItemDto> getExaminationPage(@Param("page") Page<SurgeryItemDto> page,
@Param("statusEnum") Integer statusEnum, @Param("statusEnum") Integer statusEnum,
@Param("organizationId") Long organizationId, @Param("organizationId") Long organizationId,
@Param("searchKey") String searchKey, @Param("searchKey") String searchKey);
@Param("categoryCode") String categoryCode);
} }

View File

@@ -1,22 +1,11 @@
package com.openhis.web.doctorstation.mapper; package com.openhis.web.doctorstation.mapper;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository; import org.springframework.stereotype.Repository;
import java.util.List;
import java.util.Map;
/** /**
* 医生站-电子病历 应用Mapper * 医生站-电子病历 应用Mapper
*/ */
@Repository @Repository
public interface DoctorStationEmrAppMapper { public interface DoctorStationEmrAppMapper {
List<Map<String, Object>> getPendingEmrList(@Param("doctorId") Long doctorId,
@Param("patientName") String patientName,
@Param("pageSize") Integer pageSize,
@Param("offset") Integer offset);
Long getPendingEmrCount(@Param("doctorId") Long doctorId,
@Param("patientName") String patientName);
} }

View File

@@ -178,24 +178,11 @@ public class AdviceProcessAppServiceImpl implements IAdviceProcessAppService {
inpatientAdviceParam.setEncounterIds(null); inpatientAdviceParam.setEncounterIds(null);
Integer exeStatus = inpatientAdviceParam.getExeStatus(); Integer exeStatus = inpatientAdviceParam.getExeStatus();
inpatientAdviceParam.setExeStatus(null); inpatientAdviceParam.setExeStatus(null);
// 提取requestStatus手动处理支持COMPLETED(3)和CHECK_VERIFIED(10)同时查询 // requestStatus由前端tab传入通过QueryWrapper自动添加到SQL外层WHERE过滤
Integer requestStatus = inpatientAdviceParam.getRequestStatus();
inpatientAdviceParam.setRequestStatus(null);
// 构建查询条件 // 构建查询条件
QueryWrapper<InpatientAdviceParam> queryWrapper QueryWrapper<InpatientAdviceParam> queryWrapper
= HisQueryUtils.buildQueryWrapper(inpatientAdviceParam, null, null, null); = HisQueryUtils.buildQueryWrapper(inpatientAdviceParam, null, null, null);
// 手动拼接requestStatus条件COMPLETED(3)时同时包含CHECK_VERIFIED(10)
// UNION查询外层列名为request_statusT1.status_enum AS request_status不是status_enum
if (requestStatus != null) {
if (RequestStatus.COMPLETED.getValue().equals(requestStatus)) {
queryWrapper.in("request_status",
RequestStatus.COMPLETED.getValue(), RequestStatus.CHECK_VERIFIED.getValue());
} else {
queryWrapper.eq("request_status", requestStatus);
}
}
// 手动拼接住院患者id条件 // 手动拼接住院患者id条件
if (encounterIds != null && !encounterIds.isEmpty()) { if (encounterIds != null && !encounterIds.isEmpty()) {
List<Long> encounterIdList List<Long> encounterIdList
@@ -328,29 +315,19 @@ public class AdviceProcessAppServiceImpl implements IAdviceProcessAppService {
Long practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); Long practitionerId = SecurityUtils.getLoginUser().getPractitionerId();
Date checkDate = new Date(); Date checkDate = new Date();
if (!serviceRequestList.isEmpty()) { if (!serviceRequestList.isEmpty()) {
List<Long> serviceReqIds = serviceRequestList.stream().map(PerformInfoDto::getRequestId).toList(); // 更新服务请求状态已完成
// 先查询服务请求,按 categoryEnum 分流:检查类(23)走 CHECK_VERIFIED其余走 COMPLETED serviceRequestService.updateCompleteRequestStatus(
List<ServiceRequest> allServiceRequests = serviceRequestService.listByIds(serviceReqIds); serviceRequestList.stream().map(PerformInfoDto::getRequestId).toList(), practitionerId, checkDate);
List<Long> checkReqIds = allServiceRequests.stream() List<ServiceRequest> serviceRequests = serviceRequestService
.filter(sr -> ActivityDefCategory.TEST.getValue().equals(sr.getCategoryEnum())) .listByIds(serviceRequestList.stream().map(PerformInfoDto::getRequestId).collect(Collectors.toList()));
.map(ServiceRequest::getId).toList(); for (ServiceRequest serviceRequest : serviceRequests) {
List<Long> otherReqIds = allServiceRequests.stream() // 判断医嘱类型
.filter(sr -> !ActivityDefCategory.TEST.getValue().equals(sr.getCategoryEnum()))
.map(ServiceRequest::getId).toList();
// 检查类 → 已校对CHECK_VERIFIED=10
if (!checkReqIds.isEmpty()) {
serviceRequestService.updateCheckVerifiedStatus(checkReqIds, practitionerId, checkDate);
}
// 其他类 → 已完成COMPLETED=3
if (!otherReqIds.isEmpty()) {
serviceRequestService.updateCompleteRequestStatus(otherReqIds, practitionerId, checkDate);
}
// 处理转科/出院等特殊医嘱
for (ServiceRequest serviceRequest : allServiceRequests) {
if (ActivityDefCategory.TRANSFER.getValue().equals(serviceRequest.getCategoryEnum())) { if (ActivityDefCategory.TRANSFER.getValue().equals(serviceRequest.getCategoryEnum())) {
// 更新患者状态 待转科
encounterService.updateEncounterStatus(serviceRequest.getEncounterId(), encounterService.updateEncounterStatus(serviceRequest.getEncounterId(),
EncounterZyStatus.PENDING_TRANSFER.getValue()); EncounterZyStatus.PENDING_TRANSFER.getValue());
} else if (ActivityDefCategory.DISCHARGE.getValue().equals(serviceRequest.getCategoryEnum())) { } else if (ActivityDefCategory.DISCHARGE.getValue().equals(serviceRequest.getCategoryEnum())) {
// 更新患者状态 待出院
encounterService.updateEncounterStatus(serviceRequest.getEncounterId(), encounterService.updateEncounterStatus(serviceRequest.getEncounterId(),
EncounterZyStatus.AWAITING_DISCHARGE.getValue()); EncounterZyStatus.AWAITING_DISCHARGE.getValue());
} }
@@ -382,24 +359,6 @@ public class AdviceProcessAppServiceImpl implements IAdviceProcessAppService {
medRequestList.add(item); medRequestList.add(item);
} }
} }
// 校验医嘱是否已执行,已执行的医嘱需要先取消执行后才能退回
List<Long> allRequestIds = performInfoList.stream().map(PerformInfoDto::getRequestId).toList();
List<Procedure> allProcedures = procedureService.list(
new LambdaQueryWrapper<Procedure>()
.in(Procedure::getRequestId, allRequestIds)
.eq(Procedure::getDeleteFlag, "0"));
Set<Long> executedIds = allProcedures.stream()
.filter(p -> EventStatus.COMPLETED.getValue().equals(p.getStatusEnum()))
.map(Procedure::getId)
.collect(Collectors.toSet());
Set<Long> cancelledRefundIds = allProcedures.stream()
.filter(p -> EventStatus.CANCEL.getValue().equals(p.getStatusEnum()) && p.getRefundId() != null)
.map(Procedure::getRefundId)
.collect(Collectors.toSet());
executedIds.removeAll(cancelledRefundIds);
if (!executedIds.isEmpty()) {
return R.fail("该医嘱已执行,请先取消执行后再退回");
}
// 校验药品医嘱是否已发药,已发药的医嘱不允许退回 // 校验药品医嘱是否已发药,已发药的医嘱不允许退回
if (!medRequestList.isEmpty()) { if (!medRequestList.isEmpty()) {
List<Long> medReqIds = medRequestList.stream().map(PerformInfoDto::getRequestId).toList(); List<Long> medReqIds = medRequestList.stream().map(PerformInfoDto::getRequestId).toList();
@@ -415,14 +374,13 @@ public class AdviceProcessAppServiceImpl implements IAdviceProcessAppService {
Date checkDate = new Date(); Date checkDate = new Date();
if (!serviceRequestList.isEmpty()) { if (!serviceRequestList.isEmpty()) {
// 更新服务请求状态待发送 // 更新服务请求状态待发送
String backReason = performInfoList.get(0).getBackReason();
serviceRequestService.updateDraftStatus( serviceRequestService.updateDraftStatus(
serviceRequestList.stream().map(PerformInfoDto::getRequestId).toList(), practitionerId, checkDate, backReason); serviceRequestList.stream().map(PerformInfoDto::getRequestId).toList(), practitionerId, checkDate);
} }
if (!medRequestList.isEmpty()) { if (!medRequestList.isEmpty()) {
// 更新药品请求状态待发送 // 更新药品请求状态待发送
medicationRequestService.updateDraftStatusBatch( medicationRequestService.updateDraftStatusBatch(
medRequestList.stream().map(PerformInfoDto::getRequestId).toList(), practitionerId, checkDate, backReason); medRequestList.stream().map(PerformInfoDto::getRequestId).toList(), practitionerId, checkDate);
} }
return R.ok(null, "退回成功"); return R.ok(null, "退回成功");
} }
@@ -466,15 +424,6 @@ public class AdviceProcessAppServiceImpl implements IAdviceProcessAppService {
List<ServiceRequestUseExe> actUseExeList = this.assemblyActivity(activityList); List<ServiceRequestUseExe> actUseExeList = this.assemblyActivity(activityList);
// 处理诊疗执行 // 处理诊疗执行
this.exeActivity(actUseExeList, exeDate); this.exeActivity(actUseExeList, exeDate);
// 检查类医嘱执行后,状态改为"待接收"PENDING_RECEIVE=11
List<Long> actReqIds = activityList.stream().map(AdviceExecuteDetailParam::getRequestId).toList();
List<ServiceRequest> executedReqs = serviceRequestService.listByIds(actReqIds);
List<Long> checkReqIds = executedReqs.stream()
.filter(sr -> ActivityDefCategory.TEST.getValue().equals(sr.getCategoryEnum()))
.map(ServiceRequest::getId).toList();
if (!checkReqIds.isEmpty()) {
serviceRequestService.updatePendingReceiveStatus(checkReqIds);
}
} }
return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"医嘱执行"})); return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"医嘱执行"}));
@@ -575,10 +524,7 @@ public class AdviceProcessAppServiceImpl implements IAdviceProcessAppService {
// 处理长期已发放的药品 // 处理长期已发放的药品
if (!longMedDispensedList.isEmpty()) { if (!longMedDispensedList.isEmpty()) {
// 生成退药单 // 生成退药单
this.creatRefundMedicationList(longMedDispensedList, procedureIdMap); this.creatRefundMedicationList(tempMedDispensedList, procedureIdMap);
// 药品退药请求状态变更(待退药)
medicationRequestService.updateCancelledStatusBatch(
longMedDispensedList.stream().map(MedicationDispense::getMedReqId).toList(), null, null);
} }
// 处理临时已发放药品 // 处理临时已发放药品
if (!tempMedDispensedList.isEmpty()) { if (!tempMedDispensedList.isEmpty()) {

View File

@@ -78,10 +78,12 @@ public class MedicineSummaryAppServiceImpl implements IMedicineSummaryAppService
.map(notPerformedReason -> new DispenseInitDto.NotPerformedReasonOption(notPerformedReason.getValue(), .map(notPerformedReason -> new DispenseInitDto.NotPerformedReasonOption(notPerformedReason.getValue(),
notPerformedReason.getInfo())) notPerformedReason.getInfo()))
.collect(Collectors.toList()); .collect(Collectors.toList());
// 发药状态(汇总单:待配药→已提交,已发放→已发药) // 发药状态
List<DispenseStatusOption> dispenseStatusOptions = new ArrayList<>(); List<DispenseStatusOption> dispenseStatusOptions = new ArrayList<>();
dispenseStatusOptions.add(new DispenseStatusOption(DispenseStatus.PREPARATION.getValue(), "已提交")); dispenseStatusOptions.add(new DispenseStatusOption(DispenseStatus.PREPARATION.getValue(),
dispenseStatusOptions.add(new DispenseStatusOption(DispenseStatus.COMPLETED.getValue(), "已发药")); DispenseStatus.PREPARATION.getInfo()));
dispenseStatusOptions.add(new DispenseStatusOption(DispenseStatus.COMPLETED.getValue(),
DispenseStatus.COMPLETED.getInfo()));
initDto.setNotPerformedReasonOptions(notPerformedReasonOptions).setDispenseStatusOptions(dispenseStatusOptions); initDto.setNotPerformedReasonOptions(notPerformedReasonOptions).setDispenseStatusOptions(dispenseStatusOptions);
return R.ok(initDto); return R.ok(initDto);
@@ -159,8 +161,8 @@ public class MedicineSummaryAppServiceImpl implements IMedicineSummaryAppService
new Page<>(pageNo, pageSize), queryWrapper, DispenseStatus.COMPLETED.getValue(), new Page<>(pageNo, pageSize), queryWrapper, DispenseStatus.COMPLETED.getValue(),
DispenseStatus.PREPARATION.getValue(), SupplyType.SUMMARY_DISPENSE.getValue()); DispenseStatus.PREPARATION.getValue(), SupplyType.SUMMARY_DISPENSE.getValue());
medicineSummaryFormPage.getRecords().forEach(e -> { medicineSummaryFormPage.getRecords().forEach(e -> {
// 发药状态(汇总单展示文案) // 发药状态
e.setStatusEnum_enumText(getSummaryFormStatusText(e.getStatusEnum())); e.setStatusEnum_enumText(EnumUtils.getInfoByValue(DispenseStatus.class, e.getStatusEnum()));
}); });
return R.ok(medicineSummaryFormPage); return R.ok(medicineSummaryFormPage);
} }
@@ -290,17 +292,4 @@ public class MedicineSummaryAppServiceImpl implements IMedicineSummaryAppService
} }
return R.ok(MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"取消"})); return R.ok(MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"取消"}));
} }
/**
* 汇总发药单状态展示文案(药品医嘱状态映射表:汇总申请→已提交,发药→已发药)
*/
private String getSummaryFormStatusText(Integer statusEnum) {
if (DispenseStatus.PREPARATION.getValue().equals(statusEnum)) {
return "已提交";
}
if (DispenseStatus.COMPLETED.getValue().equals(statusEnum)) {
return "已发药";
}
return EnumUtils.getInfoByValue(DispenseStatus.class, statusEnum);
}
} }

View File

@@ -86,12 +86,7 @@ public class OutpatientRecordServiceImpl implements IOutpatientRecordService {
// 处理就诊对象状态筛选 // 处理就诊对象状态筛选
if (outpatientRecordSearchParam.getSubjectStatusEnum() != null) { if (outpatientRecordSearchParam.getSubjectStatusEnum() != null) {
if (outpatientRecordSearchParam.getSubjectStatusEnum() == 0) { queryWrapper.eq("enc.status_enum", outpatientRecordSearchParam.getSubjectStatusEnum());
// 前端选择"无状态"(0)时,过滤 status_enum IS NULL 的记录
queryWrapper.isNull("enc.status_enum");
} else {
queryWrapper.eq("enc.status_enum", outpatientRecordSearchParam.getSubjectStatusEnum());
}
} }
// 处理医生姓名查询(支持模糊查询) // 处理医生姓名查询(支持模糊查询)

View File

@@ -133,13 +133,47 @@ public class PatientInformationServiceImpl implements IPatientInformationService
@Override @Override
public IPage<PatientBaseInfoDto> getPatientInfo(PatientBaseInfoDto patientBaseInfoDto, String searchKey, public IPage<PatientBaseInfoDto> getPatientInfo(PatientBaseInfoDto patientBaseInfoDto, String searchKey,
Integer pageNo, Integer pageSize, HttpServletRequest request) { Integer pageNo, Integer pageSize, HttpServletRequest request) {
// 构建基础查询条件 // 获取登录者信息
LoginUser loginUser = SecurityUtils.getLoginUser(); LoginUser loginUser = SecurityUtils.getLoginUser();
Long userId = loginUser.getUserId();
Integer tenantId = loginUser.getTenantId().intValue();
// 先构建基础查询条件
QueryWrapper<PatientBaseInfoDto> queryWrapper = HisQueryUtils.buildQueryWrapper( QueryWrapper<PatientBaseInfoDto> queryWrapper = HisQueryUtils.buildQueryWrapper(
patientBaseInfoDto, searchKey, new HashSet<>(Arrays.asList(CommonConstants.FieldName.Name, patientBaseInfoDto, searchKey, new HashSet<>(Arrays.asList(CommonConstants.FieldName.Name,
CommonConstants.FieldName.BusNo, CommonConstants.FieldName.PyStr, CommonConstants.FieldName.WbStr)), CommonConstants.FieldName.BusNo, CommonConstants.FieldName.PyStr, CommonConstants.FieldName.WbStr)),
request); request);
// 检查是否是精确ID查询从门诊挂号页面跳转时使用
boolean hasExactIdQuery = (patientBaseInfoDto.getId() != null);
// 只有非精确ID查询时才添加医生患者过滤条件
if (!hasExactIdQuery) {
// 查询当前用户对应的医生信息
LambdaQueryWrapper<com.openhis.administration.domain.Practitioner> practitionerQuery = new LambdaQueryWrapper<>();
practitionerQuery.eq(com.openhis.administration.domain.Practitioner::getUserId, userId);
// 使用list()避免TooManyResultsException异常然后取第一个记录
List<com.openhis.administration.domain.Practitioner> practitionerList = practitionerService.list(practitionerQuery);
com.openhis.administration.domain.Practitioner practitioner = practitionerList != null && !practitionerList.isEmpty() ? practitionerList.get(0) : null;
// 如果当前用户是医生,添加医生患者过滤条件
if (practitioner != null) {
// 查询该医生作为接诊医生ADMITTER, code="1"和挂号医生REGISTRATION_DOCTOR, code="12"的所有就诊记录的患者ID
List<Long> doctorPatientIds = patientManageMapper.getPatientIdsByPractitionerId(
practitioner.getId(),
Arrays.asList(ParticipantType.ADMITTER.getCode(), ParticipantType.REGISTRATION_DOCTOR.getCode()),
tenantId);
if (doctorPatientIds != null && !doctorPatientIds.isEmpty()) {
// 添加患者ID过滤条件 - 注意:这里使用列名而不是表别名
queryWrapper.in("id", doctorPatientIds);
} else {
// 如果没有相关患者,返回空结果
queryWrapper.eq("id", -1); // 设置一个不存在的ID
}
}
// 如果不是医生,查询所有患者
}
IPage<PatientBaseInfoDto> patientInformationPage IPage<PatientBaseInfoDto> patientInformationPage
= patientManageMapper.getPatientPage(new Page<>(pageNo, pageSize), queryWrapper); = patientManageMapper.getPatientPage(new Page<>(pageNo, pageSize), queryWrapper);

View File

@@ -69,12 +69,4 @@ public interface IAdviceManageAppService {
*/ */
R<?> stopRegAdvice(List<AdviceBatchOpParam> paramList); R<?> stopRegAdvice(List<AdviceBatchOpParam> paramList);
/**
* 住院医嘱取消停嘱(恢复)
*
* @param paramList 恢复参数
* @return 结果
*/
R<?> cancelStopRegAdvice(List<AdviceBatchOpParam> paramList);
} }

View File

@@ -18,7 +18,6 @@ import com.openhis.common.constant.PromptMsgConstant;
import com.openhis.common.enums.*; 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.MedicationDispense;
import com.openhis.medication.domain.MedicationRequest; import com.openhis.medication.domain.MedicationRequest;
import com.openhis.medication.service.IMedicationDispenseService; import com.openhis.medication.service.IMedicationDispenseService;
import com.openhis.medication.service.IMedicationRequestService; import com.openhis.medication.service.IMedicationRequestService;
@@ -416,7 +415,7 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
} }
// 保存时处理的字段属性 // 保存时处理的字段属性
if (is_save) { if (is_save) {
longMedicationRequest.setEffectiveDoseStart(regAdviceSaveDto.getStartTime() != null ? regAdviceSaveDto.getStartTime() : startTime); // 医嘱开始时间 longMedicationRequest.setEffectiveDoseStart(startTime); // 医嘱开始时间
longMedicationRequest longMedicationRequest
.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4)); .setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4));
longMedicationRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源 longMedicationRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源
@@ -504,7 +503,7 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
} }
// 保存时处理的字段属性 // 保存时处理的字段属性
if (is_save) { if (is_save) {
tempMedicationRequest.setEffectiveDoseStart(regAdviceSaveDto.getStartTime() != null ? regAdviceSaveDto.getStartTime() : startTime); // 医嘱开始时间 tempMedicationRequest.setEffectiveDoseStart(startTime); // 医嘱开始时间
tempMedicationRequest tempMedicationRequest
.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4)); .setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.MEDICATION_RES_NO.getPrefix(), 4));
tempMedicationRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源 tempMedicationRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源
@@ -616,7 +615,7 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
} }
// 保存时处理的字段属性 // 保存时处理的字段属性
if (is_save) { if (is_save) {
longServiceRequest.setOccurrenceStartTime(regAdviceSaveDto.getStartTime() != null ? regAdviceSaveDto.getStartTime() : startTime); // 医嘱开始时间 longServiceRequest.setOccurrenceStartTime(startTime); // 医嘱开始时间
longServiceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.SERVICE_RES_NO.getPrefix(), 4)); longServiceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.SERVICE_RES_NO.getPrefix(), 4));
longServiceRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源 longServiceRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源
longServiceRequest.setQuantity(new BigDecimal("1")); // 请求数量 | 诊疗的长期医嘱数量都是1 longServiceRequest.setQuantity(new BigDecimal("1")); // 请求数量 | 诊疗的长期医嘱数量都是1
@@ -667,7 +666,7 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
} }
// 保存时处理的字段属性 // 保存时处理的字段属性
if (is_save) { if (is_save) {
tempServiceRequest.setOccurrenceStartTime(regAdviceSaveDto.getStartTime() != null ? regAdviceSaveDto.getStartTime() : startTime); // 医嘱开始时间 tempServiceRequest.setOccurrenceStartTime(startTime); // 医嘱开始时间
tempServiceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.SERVICE_RES_NO.getPrefix(), 4)); tempServiceRequest.setBusNo(assignSeqUtil.getSeqByDay(AssignSeqEnum.SERVICE_RES_NO.getPrefix(), 4));
tempServiceRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源 tempServiceRequest.setGenerateSourceEnum(GenerateSource.DOCTOR_PRESCRIPTION.getValue()); // 生成来源
tempServiceRequest.setQuantity(regAdviceSaveDto.getQuantity()); // 请求数量 tempServiceRequest.setQuantity(regAdviceSaveDto.getQuantity()); // 请求数量
@@ -813,7 +812,7 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
deviceRequest.setPatientId(regAdviceSaveDto.getPatientId()); // 患者 deviceRequest.setPatientId(regAdviceSaveDto.getPatientId()); // 患者
deviceRequest.setRequesterId(regAdviceSaveDto.getPractitionerId()); // 开方医生 deviceRequest.setRequesterId(regAdviceSaveDto.getPractitionerId()); // 开方医生
deviceRequest.setOrgId(regAdviceSaveDto.getFounderOrgId()); // 开方人科室 deviceRequest.setOrgId(regAdviceSaveDto.getFounderOrgId()); // 开方人科室
deviceRequest.setReqAuthoredTime(regAdviceSaveDto.getStartTime() != null ? regAdviceSaveDto.getStartTime() : startTime); // 医嘱开始时间 deviceRequest.setReqAuthoredTime(startTime); // 医嘱开始时间
deviceRequest.setPerformLocation(regAdviceSaveDto.getLocationId()); // 发放科室 deviceRequest.setPerformLocation(regAdviceSaveDto.getLocationId()); // 发放科室
deviceRequest.setEncounterId(regAdviceSaveDto.getEncounterId()); // 就诊id deviceRequest.setEncounterId(regAdviceSaveDto.getEncounterId()); // 就诊id
deviceRequest.setPackageId(regAdviceSaveDto.getPackageId()); // 组套id deviceRequest.setPackageId(regAdviceSaveDto.getPackageId()); // 组套id
@@ -852,7 +851,7 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
deviceRequest.setPatientId(regAdviceSaveDto.getPatientId()); // 患者 deviceRequest.setPatientId(regAdviceSaveDto.getPatientId()); // 患者
deviceRequest.setRequesterId(regAdviceSaveDto.getPractitionerId()); // 开方医生 deviceRequest.setRequesterId(regAdviceSaveDto.getPractitionerId()); // 开方医生
deviceRequest.setOrgId(regAdviceSaveDto.getFounderOrgId()); // 开方人科室 deviceRequest.setOrgId(regAdviceSaveDto.getFounderOrgId()); // 开方人科室
deviceRequest.setReqAuthoredTime(regAdviceSaveDto.getStartTime() != null ? regAdviceSaveDto.getStartTime() : startTime); // 医嘱开始时间 deviceRequest.setReqAuthoredTime(startTime); // 医嘱开始时间
deviceRequest.setPerformLocation(regAdviceSaveDto.getLocationId()); // 发放科室 deviceRequest.setPerformLocation(regAdviceSaveDto.getLocationId()); // 发放科室
deviceRequest.setEncounterId(regAdviceSaveDto.getEncounterId()); // 就诊id deviceRequest.setEncounterId(regAdviceSaveDto.getEncounterId()); // 就诊id
deviceRequest.setPackageId(regAdviceSaveDto.getPackageId()); // 组套id deviceRequest.setPackageId(regAdviceSaveDto.getPackageId()); // 组套id
@@ -1044,14 +1043,8 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
*/ */
@Override @Override
public R<?> stopRegAdvice(List<AdviceBatchOpParam> paramList) { public R<?> stopRegAdvice(List<AdviceBatchOpParam> paramList) {
// 获取停嘱时间:优先从前端传入的 stopTime否则用当前时间 // 当前时间
Date stopTime = paramList.stream() Date date = new Date();
.map(AdviceBatchOpParam::getStopTime)
.filter(Objects::nonNull)
.findFirst()
.orElse(new Date());
// 获取当前操作用户昵称作为停嘱医生
String stopUserName = SecurityUtils.getNickName();
// 药品 // 药品
List<AdviceBatchOpParam> medicineList = paramList.stream() List<AdviceBatchOpParam> medicineList = paramList.stream()
.filter(e -> ItemType.MEDICINE.getValue().equals(e.getAdviceType())).collect(Collectors.toList()); .filter(e -> ItemType.MEDICINE.getValue().equals(e.getAdviceType())).collect(Collectors.toList());
@@ -1066,112 +1059,15 @@ public class AdviceManageAppServiceImpl implements IAdviceManageAppService {
= activityList.stream().map(AdviceBatchOpParam::getRequestId).collect(Collectors.toList()); = activityList.stream().map(AdviceBatchOpParam::getRequestId).collect(Collectors.toList());
if (!medicineRequestIds.isEmpty()) { if (!medicineRequestIds.isEmpty()) {
iMedicationRequestService.update(new LambdaUpdateWrapper<MedicationRequest>() iMedicationRequestService.update(new LambdaUpdateWrapper<MedicationRequest>()
.in(MedicationRequest::getId, medicineRequestIds) .in(MedicationRequest::getId, medicineRequestIds).set(MedicationRequest::getEffectiveDoseEnd, date)
.set(MedicationRequest::getEffectiveDoseEnd, stopTime) .set(MedicationRequest::getStatusEnum, RequestStatus.STOPPED.getValue()));
.set(MedicationRequest::getStatusEnum, RequestStatus.STOPPED.getValue())
.set(MedicationRequest::getUpdateBy, stopUserName));
} }
if (!activityRequestIds.isEmpty()) { if (!activityRequestIds.isEmpty()) {
iServiceRequestService.update(new LambdaUpdateWrapper<ServiceRequest>() iServiceRequestService.update(new LambdaUpdateWrapper<ServiceRequest>()
.in(ServiceRequest::getId, activityRequestIds) .in(ServiceRequest::getId, activityRequestIds).set(ServiceRequest::getOccurrenceEndTime, date)
.set(ServiceRequest::getOccurrenceEndTime, stopTime) .set(ServiceRequest::getStatusEnum, RequestStatus.STOPPED.getValue()));
.set(ServiceRequest::getStatusEnum, RequestStatus.STOPPED.getValue())
.set(ServiceRequest::getUpdateBy, stopUserName));
} }
return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"医嘱停止"})); return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"医嘱停止"}));
}
/**
* 住院医嘱取消停嘱(恢复)
*
* 核心业务逻辑:
* 1. 护士站校验:护士站尚未对该医嘱的停止进行"停止核对/确认"(即 dispense 状态未进入已发药/完成状态)
* 2. 药房端校验:药房尚未对该停嘱单进行退药接收/退费入库确认
* 3. 若校验通过,将医嘱状态复原为"已签发";清空停嘱时间与停嘱医生字段;
* 同时自动作废已生成的待发药退回/退药申请
*
* @param paramList 恢复参数
* @return 结果
*/
@Override
public R<?> cancelStopRegAdvice(List<AdviceBatchOpParam> paramList) {
// 药品
List<AdviceBatchOpParam> medicineList = paramList.stream()
.filter(e -> ItemType.MEDICINE.getValue().equals(e.getAdviceType())).collect(Collectors.toList());
List<Long> medicineRequestIds
= medicineList.stream().map(AdviceBatchOpParam::getRequestId).collect(Collectors.toList());
// 诊疗包含护理adviceType=26
List<AdviceBatchOpParam> activityList = paramList.stream()
.filter(e -> ItemType.ACTIVITY.getValue().equals(e.getAdviceType())
|| (e.getAdviceType() != null && e.getAdviceType() == 26))
.collect(Collectors.toList());
List<Long> activityRequestIds
= activityList.stream().map(AdviceBatchOpParam::getRequestId).collect(Collectors.toList());
// ============ 前置校验 ============
// 1. 护士站校验:查询药品发放记录,确认护士站是否已执行停止核对(发药)
if (!medicineRequestIds.isEmpty()) {
List<MedicationDispense> dispenseList = iMedicationDispenseService.selectByRequestIdList(medicineRequestIds);
for (MedicationDispense dispense : dispenseList) {
// 如果发放状态 >= COMPLETED(4),说明护士站已发药/已确认停止
if (dispense.getStatusEnum() != null && dispense.getStatusEnum() >= DispenseStatus.COMPLETED.getValue()
&& !DispenseStatus.ON_HOLD.getValue().equals(dispense.getStatusEnum())
&& !DispenseStatus.STOPPED.getValue().equals(dispense.getStatusEnum())
&& !DispenseStatus.CANCELLED.getValue().equals(dispense.getStatusEnum())) {
throw new ServiceException("护士站已确认停止该医嘱,无法取消停嘱!");
}
// 2. 药房端校验:如果已有退药/退费记录,说明药房已处理
if (DispenseStatus.RETURNED.getValue().equals(dispense.getStatusEnum())
|| DispenseStatus.REFUNDED.getValue().equals(dispense.getStatusEnum())
|| DispenseStatus.PART_REFUND.getValue().equals(dispense.getStatusEnum())) {
throw new ServiceException("药房已完成退药处理,无法取消停嘱!");
}
}
}
// ============ 执行恢复 ============
if (!medicineRequestIds.isEmpty()) {
// 恢复药品请求状态为"已发送"(ACTIVE=2),清空停嘱时间和更新人
iMedicationRequestService.update(new LambdaUpdateWrapper<MedicationRequest>()
.in(MedicationRequest::getId, medicineRequestIds)
.set(MedicationRequest::getStatusEnum, RequestStatus.ACTIVE.getValue())
.set(MedicationRequest::getEffectiveDoseEnd, null)
.set(MedicationRequest::getUpdateBy, null));
// 作废/删除与这些药品请求相关的待退药发放记录
List<MedicationDispense> relatedDispenseList = iMedicationDispenseService.selectByRequestIdList(medicineRequestIds);
for (MedicationDispense dispense : relatedDispenseList) {
if (DispenseStatus.PENDING_REFUND.getValue().equals(dispense.getStatusEnum())
|| DispenseStatus.CANCELLED.getValue().equals(dispense.getStatusEnum())
|| DispenseStatus.ON_HOLD.getValue().equals(dispense.getStatusEnum())) {
// 将待退药/暂停/撤回的记录标记为草稿,或删除
iMedicationDispenseService.update(new LambdaUpdateWrapper<MedicationDispense>()
.eq(MedicationDispense::getId, dispense.getId())
.set(MedicationDispense::getStatusEnum, DispenseStatus.DRAFT.getValue())
.set(MedicationDispense::getStatusChangedTime, new Date()));
}
// 如果 dispense 已处于 STOPPED(6) 状态,也恢复为草稿以重新触发配药流程
if (DispenseStatus.STOPPED.getValue().equals(dispense.getStatusEnum())) {
iMedicationDispenseService.update(new LambdaUpdateWrapper<MedicationDispense>()
.eq(MedicationDispense::getId, dispense.getId())
.set(MedicationDispense::getStatusEnum, DispenseStatus.PREPARATION.getValue())
.set(MedicationDispense::getStatusChangedTime, new Date()));
}
}
}
if (!activityRequestIds.isEmpty()) {
// 恢复诊疗请求状态为"已发送"(ACTIVE=2),清空停嘱时间和更新人
iServiceRequestService.update(new LambdaUpdateWrapper<ServiceRequest>()
.in(ServiceRequest::getId, activityRequestIds)
.set(ServiceRequest::getStatusEnum, RequestStatus.ACTIVE.getValue())
.set(ServiceRequest::getOccurrenceEndTime, null)
.set(ServiceRequest::getUpdateBy, null));
}
return R.ok(null, MessageUtils.createMessage(PromptMsgConstant.Common.M00004, new Object[]{"医嘱恢复"}));
} }
} }

View File

@@ -5,7 +5,6 @@ import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
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.enums.DelFlag;
import com.core.common.exception.ServiceException; import com.core.common.exception.ServiceException;
import com.core.common.utils.AssignSeqUtil; import com.core.common.utils.AssignSeqUtil;
import com.core.common.utils.MessageUtils; import com.core.common.utils.MessageUtils;
@@ -18,8 +17,6 @@ import com.openhis.common.constant.PromptMsgConstant;
import com.openhis.common.enums.*; import com.openhis.common.enums.*;
import com.openhis.document.domain.RequestForm; import com.openhis.document.domain.RequestForm;
import com.openhis.document.service.IRequestFormService; import com.openhis.document.service.IRequestFormService;
import com.openhis.lab.domain.Specimen;
import com.openhis.lab.service.ISpecimenService;
import com.openhis.web.doctorstation.dto.ActivityChildrenJsonParams; import com.openhis.web.doctorstation.dto.ActivityChildrenJsonParams;
import com.openhis.web.doctorstation.utils.AdviceUtils; import com.openhis.web.doctorstation.utils.AdviceUtils;
import com.openhis.web.regdoctorstation.appservice.IRequestFormManageAppService; import com.openhis.web.regdoctorstation.appservice.IRequestFormManageAppService;
@@ -70,39 +67,6 @@ public class RequestFormManageAppServiceImpl implements IRequestFormManageAppSer
@Resource @Resource
IActivityDefinitionService iActivityDefinitionService; IActivityDefinitionService iActivityDefinitionService;
@Resource
ISpecimenService iSpecimenService;
/**
* 校验当前用户是否有权操作该申请单(申请者本人或管理员)
*/
private R<?> validateRequestFormPermission(RequestForm requestForm) {
if (SecurityUtils.isAdmin(SecurityUtils.getUserId())) {
return null;
}
Long currentPractitionerId = SecurityUtils.getLoginUser().getPractitionerId();
Long requesterId = requestForm.getRequesterId();
if (currentPractitionerId == null || requesterId == null
|| !currentPractitionerId.equals(requesterId)) {
return R.fail("无操作权限,仅申请开立者或管理员可操作");
}
return null;
}
/**
* 校验关联医嘱是否已采证(存在已采集/已接收标本则不可撤回)
*/
private boolean hasCollectedSpecimen(List<Long> serviceRequestIds) {
if (serviceRequestIds == null || serviceRequestIds.isEmpty()) {
return false;
}
long count = iSpecimenService.count(
new LambdaQueryWrapper<Specimen>()
.in(Specimen::getServiceId, serviceRequestIds)
.ge(Specimen::getCollectionStatusEnum, SpecCollectStatus.COLLECTED.getValue()));
return count > 0;
}
/** /**
* 保存申请单 * 保存申请单
* *
@@ -155,13 +119,10 @@ public class RequestFormManageAppServiceImpl implements IRequestFormManageAppSer
return R.fail("无待签发的医嘱,该申请单不可编辑"); return R.fail("无待签发的医嘱,该申请单不可编辑");
} }
} else { } else {
// 根据申请单类型生成不同前缀的单 // 检查申请单JC检查+ Z住院标识+ yyMMdd日期+ 5位顺序
String dateStr = new java.text.SimpleDateFormat("yyMMdd").format(new Date()); String dateStr = new java.text.SimpleDateFormat("yyMMdd").format(new Date());
AssignSeqEnum seqEnum = ActivityDefCategory.PROCEDURE.getCode().equals(typeCode) int seq = assignSeqUtil.getSeqNoByDay(AssignSeqEnum.CHECK_APPLY_NO.getPrefix());
? AssignSeqEnum.SURGERY_APPLY_NO prescriptionNo = "JCZ" + dateStr + String.format("%05d", seq);
: AssignSeqEnum.CHECK_APPLY_NO;
int seq = assignSeqUtil.getSeqNoByDay(seqEnum.getPrefix());
prescriptionNo = seqEnum.getPrefix() + dateStr + String.format("%05d", seq);
} }
// 当前时间 // 当前时间
@@ -567,17 +528,12 @@ public class RequestFormManageAppServiceImpl implements IRequestFormManageAppSer
if (requestForm == null) { if (requestForm == null) {
return R.fail("申请单不存在"); return R.fail("申请单不存在");
} }
R<?> permissionResult = validateRequestFormPermission(requestForm);
if (permissionResult != null) {
return permissionResult;
}
String prescriptionNo = requestForm.getPrescriptionNo(); String prescriptionNo = requestForm.getPrescriptionNo();
// 查询该申请单下所有 ServiceRequest含子项 // 查询该申请单下所有 ServiceRequest含子项
List<ServiceRequest> serviceRequests = iServiceRequestService.list( List<ServiceRequest> serviceRequests = iServiceRequestService.list(
new LambdaQueryWrapper<ServiceRequest>() new LambdaQueryWrapper<ServiceRequest>()
.eq(ServiceRequest::getPrescriptionNo, prescriptionNo) .eq(ServiceRequest::getPrescriptionNo, prescriptionNo));
.eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode()));
if (serviceRequests == null || serviceRequests.isEmpty()) { if (serviceRequests == null || serviceRequests.isEmpty()) {
return R.fail("未找到关联的诊疗医嘱"); return R.fail("未找到关联的诊疗医嘱");
} }
@@ -607,7 +563,7 @@ public class RequestFormManageAppServiceImpl implements IRequestFormManageAppSer
// 4. 删除申请单 // 4. 删除申请单
iRequestFormService.removeById(requestFormId); iRequestFormService.removeById(requestFormId);
log.info("申请单删除成功requestFormId={}, prescriptionNo={}", requestFormId, prescriptionNo); log.info("申请单删除成功requestFormId={}, prescriptionNo={}", requestFormId, prescriptionNo);
return R.ok("删除成功"); return R.ok("删除成功");
} }
@@ -620,47 +576,32 @@ public class RequestFormManageAppServiceImpl implements IRequestFormManageAppSer
if (requestForm == null) { if (requestForm == null) {
return R.fail("申请单不存在"); return R.fail("申请单不存在");
} }
R<?> permissionResult = validateRequestFormPermission(requestForm);
if (permissionResult != null) {
return permissionResult;
}
String prescriptionNo = requestForm.getPrescriptionNo(); String prescriptionNo = requestForm.getPrescriptionNo();
// 查询该申请单下所有 ServiceRequest // 查询该申请单下所有 ServiceRequest
List<ServiceRequest> serviceRequests = iServiceRequestService.list( List<ServiceRequest> serviceRequests = iServiceRequestService.list(
new LambdaQueryWrapper<ServiceRequest>() new LambdaQueryWrapper<ServiceRequest>()
.eq(ServiceRequest::getPrescriptionNo, prescriptionNo) .eq(ServiceRequest::getPrescriptionNo, prescriptionNo));
.eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode()));
if (serviceRequests == null || serviceRequests.isEmpty()) { if (serviceRequests == null || serviceRequests.isEmpty()) {
return R.fail("未找到关联的诊疗医嘱"); return R.fail("未找到关联的诊疗医嘱");
} }
// 校验:只有已签发(status=2)的申请单可撤回
boolean allActive = serviceRequests.stream()
.allMatch(sr -> RequestStatus.ACTIVE.getValue().equals(sr.getStatusEnum()));
if (!allActive) {
return R.fail("只有已签发状态的申请单可撤回");
}
// 将所有 ServiceRequest 状态改回待签发(DRAFT=0)
List<Long> serviceRequestIds = serviceRequests.stream() List<Long> serviceRequestIds = serviceRequests.stream()
.map(ServiceRequest::getId).collect(Collectors.toList()); .map(ServiceRequest::getId).collect(Collectors.toList());
iServiceRequestService.update(
// 校验:标本已采集则不可撤回
if (hasCollectedSpecimen(serviceRequestIds)) {
return R.fail("标本已采集,无法撤回");
}
// 校验任一ServiceRequest为ACTIVE(status=2)即可撤回与SQL的EXISTS逻辑一致
boolean hasActive = serviceRequests.stream()
.anyMatch(sr -> RequestStatus.ACTIVE.getValue().equals(sr.getStatusEnum()));
if (!hasActive) {
return R.fail("只有已签发且未采证的申请单可撤回");
}
// 将所有已签发的 ServiceRequest 状态改回待签发,与申请单展示状态同步
boolean updated = iServiceRequestService.update(
new ServiceRequest().setStatusEnum(RequestStatus.DRAFT.getValue()), new ServiceRequest().setStatusEnum(RequestStatus.DRAFT.getValue()),
new LambdaUpdateWrapper<ServiceRequest>() new LambdaUpdateWrapper<ServiceRequest>()
.in(ServiceRequest::getId, serviceRequestIds) .in(ServiceRequest::getId, serviceRequestIds));
.eq(ServiceRequest::getStatusEnum, RequestStatus.ACTIVE.getValue()));
if (!updated) {
return R.fail("撤回失败,医嘱状态已变更,请刷新后重试");
}
log.info("申请单撤回成功requestFormId={}, prescriptionNo={}", requestFormId, prescriptionNo); log.info("申请单撤回成功requestFormId={}, prescriptionNo={}", requestFormId, prescriptionNo);
return R.ok("撤回成功"); return R.ok("撤回成功");
} }

View File

@@ -28,7 +28,6 @@ import java.util.Arrays;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.springframework.util.CollectionUtils;
import java.util.stream.Collectors; import java.util.stream.Collectors;
/** /**
@@ -162,7 +161,7 @@ public class SpecialAdviceAppServiceImpl implements ISpecialAdviceAppService {
adviceBaseDto.setAdviceDefinitionId(definitionId); // 医嘱定义id adviceBaseDto.setAdviceDefinitionId(definitionId); // 医嘱定义id
// 对应的诊疗医嘱信息 // 对应的诊疗医嘱信息
activityAdviceBaseDto = iDoctorStationAdviceAppService.getAdviceBaseInfo(adviceBaseDto, null, null, activityAdviceBaseDto = iDoctorStationAdviceAppService.getAdviceBaseInfo(adviceBaseDto, null, null,
null, null, 1, 1, null, List.of(3), null, null).getRecords().get(0); null, null, 1, 1, Whether.NO.getValue(), List.of(3), null, null).getRecords().get(0);
// 逻辑1---------------------直接新增 // 逻辑1---------------------直接新增
longServiceRequest.setStatusEnum(RequestStatus.DRAFT.getValue());// 请求状态 longServiceRequest.setStatusEnum(RequestStatus.DRAFT.getValue());// 请求状态
longServiceRequest.setOccurrenceStartTime(startTime); // 医嘱开始时间 longServiceRequest.setOccurrenceStartTime(startTime); // 医嘱开始时间
@@ -209,7 +208,7 @@ public class SpecialAdviceAppServiceImpl implements ISpecialAdviceAppService {
adviceBaseDto.setAdviceDefinitionId(definitionId); // 医嘱定义id adviceBaseDto.setAdviceDefinitionId(definitionId); // 医嘱定义id
// 对应的诊疗医嘱信息 // 对应的诊疗医嘱信息
activityAdviceBaseDto = iDoctorStationAdviceAppService activityAdviceBaseDto = iDoctorStationAdviceAppService
.getAdviceBaseInfo(adviceBaseDto, null, null, null, null, 1, 1, null, List.of(3), null, null) .getAdviceBaseInfo(adviceBaseDto, null, null, null, null, 1, 1, Whether.NO.getValue(), List.of(3), null, null)
.getRecords().get(0); .getRecords().get(0);
longServiceRequest.setStatusEnum(RequestStatus.DRAFT.getValue());// 请求状态 longServiceRequest.setStatusEnum(RequestStatus.DRAFT.getValue());// 请求状态
@@ -349,7 +348,7 @@ public class SpecialAdviceAppServiceImpl implements ISpecialAdviceAppService {
adviceBaseDto.setAdviceDefinitionId(transferOrganizationDefinitionId); // 医嘱定义id adviceBaseDto.setAdviceDefinitionId(transferOrganizationDefinitionId); // 医嘱定义id
// 转科的医嘱信息 // 转科的医嘱信息
AdviceBaseDto activityAdviceBaseDto = iDoctorStationAdviceAppService AdviceBaseDto activityAdviceBaseDto = iDoctorStationAdviceAppService
.getAdviceBaseInfo(adviceBaseDto, null, null, null, null, 1, 1, null, List.of(3), null, null) .getAdviceBaseInfo(adviceBaseDto, null, null, null, null, 1, 1, Whether.NO.getValue(), List.of(3), null, null)
.getRecords().get(0); .getRecords().get(0);
// 保存转科医嘱请求 // 保存转科医嘱请求
ServiceRequest serviceRequest = new ServiceRequest(); ServiceRequest serviceRequest = new ServiceRequest();
@@ -401,7 +400,7 @@ public class SpecialAdviceAppServiceImpl implements ISpecialAdviceAppService {
// 计划出院时间 // 计划出院时间
Date endTime = leaveHospitalParam.getEndTime(); Date endTime = leaveHospitalParam.getEndTime();
if (endTime == null) { if (endTime == null) {
endTime = new Date(); endTime = endTime;
} }
// 就诊id // 就诊id
Long encounterId = leaveHospitalParam.getEncounterId(); Long encounterId = leaveHospitalParam.getEncounterId();
@@ -430,12 +429,9 @@ public class SpecialAdviceAppServiceImpl implements ISpecialAdviceAppService {
} }
// 出院的医嘱信息 // 出院的医嘱信息
List<AdviceBaseDto> adviceList = iDoctorStationAdviceAppService.getAdviceBaseInfo(null, null, null, AdviceBaseDto activityAdviceBaseDto = iDoctorStationAdviceAppService.getAdviceBaseInfo(null, null, null,
List.of(transferOrganizationDefinitionId), null, 1, 1, null, List.of(3), null, null).getRecords(); List.of(transferOrganizationDefinitionId), null, 1, 1, Whether.NO.getValue(), List.of(3), null, null).getRecords()
if (CollectionUtils.isEmpty(adviceList)) { .get(0);
return R.fail("未找到出院医嘱定义数据,请确认诊疗目录中已配置出院医嘱");
}
AdviceBaseDto activityAdviceBaseDto = adviceList.get(0);
// 保存出院医嘱请求 // 保存出院医嘱请求
ServiceRequest serviceRequest = new ServiceRequest(); ServiceRequest serviceRequest = new ServiceRequest();
serviceRequest.setStatusEnum(RequestStatus.DRAFT.getValue());// 请求状态 serviceRequest.setStatusEnum(RequestStatus.DRAFT.getValue());// 请求状态

View File

@@ -143,15 +143,4 @@ public class AdviceManageController {
return iAdviceManageAppService.stopRegAdvice(paramList); return iAdviceManageAppService.stopRegAdvice(paramList);
} }
/**
* 住院医嘱取消停嘱(恢复)
*
* @param paramList 恢复参数
* @return 结果
*/
@PostMapping(value = "/cancel-stop-reg-advice")
public R<?> cancelStopRegAdvice(@RequestBody List<AdviceBatchOpParam> paramList) {
return iAdviceManageAppService.cancelStopRegAdvice(paramList);
}
} }

View File

@@ -143,23 +143,14 @@ public class RequestFormManageController {
* 查询手术申请单 * 查询手术申请单
* *
* @param encounterId 就诊id * @param encounterId 就诊id
* @param startDate 开始日期可选格式yyyy-MM-dd
* @param endDate 结束日期可选格式yyyy-MM-dd
* @param status 单据状态(可选)
* @param keyword 关键字(可选,申请单号/手术项目名称模糊匹配)
* @return 手术申请单 * @return 手术申请单
*/ */
@GetMapping(value = "/get-surgery") @GetMapping(value = "/get-surgery")
public R<?> getSurgeryRequestForm( public R<?> getSurgeryRequestForm(@RequestParam(required = false) Long encounterId) {
@RequestParam(required = false) Long encounterId,
@RequestParam(required = false) String startDate,
@RequestParam(required = false) String endDate,
@RequestParam(required = false) String status,
@RequestParam(required = false) String keyword) {
if (encounterId == null) { if (encounterId == null) {
return R.fail("就诊ID不能为空"); return R.fail("就诊ID不能为空");
} }
return R.ok(iRequestFormManageAppService.getRequestForm(encounterId, ActivityDefCategory.PROCEDURE.getCode(), startDate, endDate, status, keyword)); return R.ok(iRequestFormManageAppService.getRequestForm(encounterId, ActivityDefCategory.PROCEDURE.getCode()));
} }
/** /**
* 分页查询手术申请单全局不需要encounterId用于门诊手术安排查找弹窗 * 分页查询手术申请单全局不需要encounterId用于门诊手术安排查找弹窗
@@ -203,8 +194,8 @@ public class RequestFormManageController {
* @return 结果 * @return 结果
*/ */
@PostMapping(value = "/delete") @PostMapping(value = "/delete")
public R<?> deleteRequestForm(@RequestBody Map<String, Object> data) { public R<?> deleteRequestForm(@RequestBody Map<String, Long> data) {
return iRequestFormManageAppService.deleteRequestForm(parseLong(data.get("requestFormId"))); return iRequestFormManageAppService.deleteRequestForm(data.get("requestFormId"));
} }
/** /**
@@ -214,24 +205,7 @@ public class RequestFormManageController {
* @return 结果 * @return 结果
*/ */
@PostMapping(value = "/withdraw") @PostMapping(value = "/withdraw")
public R<?> withdrawRequestForm(@RequestBody Map<String, Object> data) { public R<?> withdrawRequestForm(@RequestBody Map<String, Long> data) {
return iRequestFormManageAppService.withdrawRequestForm(parseLong(data.get("requestFormId"))); return iRequestFormManageAppService.withdrawRequestForm(data.get("requestFormId"));
}
private Long parseLong(Object value) {
if (value == null) {
return null;
}
if (value instanceof Long) {
return (Long) value;
}
if (value instanceof Number) {
return ((Number) value).longValue();
}
try {
return Long.parseLong(value.toString());
} catch (NumberFormatException e) {
return null;
}
} }
} }

View File

@@ -1,13 +1,10 @@
package com.openhis.web.regdoctorstation.dto; package com.openhis.web.regdoctorstation.dto;
import com.fasterxml.jackson.annotation.JsonFormat;
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 lombok.Data; import lombok.Data;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import java.util.Date;
/** /**
* 医嘱批量操作参数类 * 医嘱批量操作参数类
*/ */
@@ -24,10 +21,4 @@ public class AdviceBatchOpParam {
@JsonSerialize(using = ToStringSerializer.class) @JsonSerialize(using = ToStringSerializer.class)
private Long requestId; private Long requestId;
/**
* 停嘱时间
*/
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss")
private Date stopTime;
} }

View File

@@ -31,8 +31,8 @@ public class HomeController {
HomeStatisticsDto statisticsDto = homeStatisticsService.getHomeStatistics(); HomeStatisticsDto statisticsDto = homeStatisticsService.getHomeStatistics();
// 获取待写病历数量 // 获取待写病历数量
Long practitionerId = SecurityUtils.getLoginUser().getPractitionerId(); Long userId = SecurityUtils.getLoginUser().getUserId();
R<?> pendingEmrCount = doctorStationEmrAppService.getPendingEmrCount(practitionerId, null); R<?> pendingEmrCount = doctorStationEmrAppService.getPendingEmrCount(userId);
// 将待写病历数量添加到统计数据中 // 将待写病历数量添加到统计数据中
statisticsDto.setPendingEmr((Integer) pendingEmrCount.getData()); statisticsDto.setPendingEmr((Integer) pendingEmrCount.getData());

View File

@@ -74,6 +74,7 @@ public class TriageQueueAppServiceImpl implements TriageQueueAppService {
.eq(TriageQueueItem::getTenantId, tenantId) .eq(TriageQueueItem::getTenantId, tenantId)
.eq(TriageQueueItem::getQueueDate, qd) .eq(TriageQueueItem::getQueueDate, qd)
.eq(TriageQueueItem::getDeleteFlag, "0") .eq(TriageQueueItem::getDeleteFlag, "0")
.ne(TriageQueueItem::getStatus, TriageQueueStatus.COMPLETED.getValue())
.orderByAsc(TriageQueueItem::getQueueOrder); .orderByAsc(TriageQueueItem::getQueueOrder);
// 如果指定了科室,按科室过滤;否则查询所有科室(全科模式) // 如果指定了科室,按科室过滤;否则查询所有科室(全科模式)
@@ -91,6 +92,14 @@ public class TriageQueueAppServiceImpl implements TriageQueueAppService {
} }
}); });
} }
// 双重保险:再次过滤掉 COMPLETED 状态的患者(防止数据库中有异常数据)
if (list != null && !list.isEmpty()) {
int beforeSize = list.size();
list = list.stream()
.filter(item -> !TriageQueueStatus.COMPLETED.getValue().equals(item.getStatus()))
.collect(java.util.stream.Collectors.toList());
}
return R.ok(list); return R.ok(list);
} }

View File

@@ -516,7 +516,6 @@
T1.patient_id AS patient_id, T1.patient_id AS patient_id,
'med_medication_definition' AS advice_table_name, 'med_medication_definition' AS advice_table_name,
T1.medication_id AS advice_definition_id T1.medication_id AS advice_definition_id
, T1.back_reason AS reason_text
FROM med_medication_request AS T1 FROM med_medication_request AS T1
LEFT JOIN med_medication_definition AS T2 ON T2.ID = T1.medication_id LEFT JOIN med_medication_definition AS T2 ON T2.ID = T1.medication_id
AND T2.delete_flag = '0' AND T2.delete_flag = '0'
@@ -578,7 +577,6 @@
T1.patient_id AS patient_id, T1.patient_id AS patient_id,
'med_medication_definition' AS advice_table_name, 'med_medication_definition' AS advice_table_name,
T3.ID AS advice_definition_id T3.ID AS advice_definition_id
, T2.back_reason AS reason_text
FROM adm_charge_item AS T1 FROM adm_charge_item AS T1
INNER JOIN med_medication_request AS T2 ON T2.ID = T1.service_id AND T2.delete_flag = '0' INNER JOIN med_medication_request AS T2 ON T2.ID = T1.service_id AND T2.delete_flag = '0'
LEFT JOIN med_medication_definition AS T3 ON T3.ID = T2.medication_id AND T3.delete_flag = '0' LEFT JOIN med_medication_definition AS T3 ON T3.ID = T2.medication_id AND T3.delete_flag = '0'
@@ -586,9 +584,6 @@
WHERE T1.delete_flag = '0' WHERE T1.delete_flag = '0'
AND T1.service_table = #{MED_MEDICATION_REQUEST} AND T1.service_table = #{MED_MEDICATION_REQUEST}
<if test="historyFlag == '0'.toString()"> <if test="historyFlag == '0'.toString()">
<if test="generateSourceEnum != null">
AND (T2.generate_source_enum IS NULL OR T2.generate_source_enum = #{generateSourceEnum})
</if>
AND T1.encounter_id = #{encounterId} AND T1.encounter_id = #{encounterId}
</if> </if>
<if test="historyFlag == '1'.toString()"> <if test="historyFlag == '1'.toString()">
@@ -642,7 +637,6 @@
CI.patient_id AS patient_id, CI.patient_id AS patient_id,
'adm_device_definition' AS advice_table_name, 'adm_device_definition' AS advice_table_name,
CI.product_id AS advice_definition_id CI.product_id AS advice_definition_id
, NULL AS reason_text
FROM adm_charge_item AS CI FROM adm_charge_item AS CI
LEFT JOIN adm_charge_item_definition CID ON CID.id = CI.definition_id AND CID.delete_flag = '0' LEFT JOIN adm_charge_item_definition CID ON CID.id = CI.definition_id AND CID.delete_flag = '0'
LEFT JOIN wor_device_request DR ON DR.id = CI.service_id AND DR.delete_flag = '0' LEFT JOIN wor_device_request DR ON DR.id = CI.service_id AND DR.delete_flag = '0'
@@ -697,7 +691,6 @@
T1.patient_id AS patient_id, T1.patient_id AS patient_id,
'adm_device_definition' AS advice_table_name, 'adm_device_definition' AS advice_table_name,
T1.device_def_id AS advice_definition_id T1.device_def_id AS advice_definition_id
, NULL AS reason_text
FROM wor_device_request AS T1 FROM wor_device_request AS T1
LEFT JOIN adm_device_definition AS T2 ON T2.ID = T1.device_def_id LEFT JOIN adm_device_definition AS T2 ON T2.ID = T1.device_def_id
AND T2.delete_flag = '0' AND T2.delete_flag = '0'
@@ -754,7 +747,6 @@
T1.patient_id AS patient_id, T1.patient_id AS patient_id,
'wor_activity_definition' AS advice_table_name, 'wor_activity_definition' AS advice_table_name,
T1.activity_id AS advice_definition_id T1.activity_id AS advice_definition_id
, T1.reason_text AS reason_text
FROM wor_service_request AS T1 FROM wor_service_request AS T1
LEFT JOIN wor_activity_definition AS T2 LEFT JOIN wor_activity_definition AS T2
ON T2.ID = T1.activity_id ON T2.ID = T1.activity_id
@@ -902,9 +894,10 @@
AND (t1.name ILIKE '%' || #{searchKey} || '%' OR t1.py_str ILIKE '%' || #{searchKey} || '%') AND (t1.name ILIKE '%' || #{searchKey} || '%' OR t1.py_str ILIKE '%' || #{searchKey} || '%')
</if> </if>
ORDER BY t1.ID, t1.name ASC, t2.ID ASC ORDER BY t1.ID, t1.name ASC, t2.ID ASC
LIMIT #{limit} OFFSET #{offset}
</select> </select>
<!-- 检查/检验项目专用分页查询:仅查指定 category_code + 定价,无库存/草稿库存/取药科室等无关逻辑 --> <!-- 检查项目专用分页查询:仅查检查(23) + 定价,无库存/草稿库存/取药科室等无关逻辑 -->
<select id="getExaminationPage" resultType="com.openhis.web.doctorstation.dto.SurgeryItemDto"> <select id="getExaminationPage" resultType="com.openhis.web.doctorstation.dto.SurgeryItemDto">
SELECT DISTINCT ON (t1.ID) SELECT DISTINCT ON (t1.ID)
t1.ID AS advice_definition_id, t1.ID AS advice_definition_id,
@@ -926,7 +919,7 @@
ON t3.id = t1.org_id ON t3.id = t1.org_id
AND t3.delete_flag = '0' AND t3.delete_flag = '0'
WHERE t1.delete_flag = '0' WHERE t1.delete_flag = '0'
AND t1.category_code = #{categoryCode} AND t1.category_code = '23'
<if test="searchKey != null and searchKey != ''"> <if test="searchKey != null and searchKey != ''">
AND (t1.name ILIKE '%' || #{searchKey} || '%' OR t1.py_str ILIKE '%' || #{searchKey} || '%') AND (t1.name ILIKE '%' || #{searchKey} || '%' OR t1.py_str ILIKE '%' || #{searchKey} || '%')
</if> </if>

View File

@@ -4,38 +4,4 @@
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.openhis.web.doctorstation.mapper.DoctorStationEmrAppMapper"> <mapper namespace="com.openhis.web.doctorstation.mapper.DoctorStationEmrAppMapper">
<select id="getPendingEmrList" resultType="java.util.HashMap"> </mapper>
SELECT e.id AS "encounterId",
e.patient_id AS "patientId",
p.name AS "patientName",
p.gender_enum AS "gender",
p.birth_date AS "birthDate",
e.create_time AS "registerTime",
e.bus_no AS "busNo"
FROM adm_encounter e
INNER JOIN adm_encounter_participant ep ON e.id = ep.encounter_id AND ep.practitioner_id = #{doctorId}
LEFT JOIN adm_patient p ON e.patient_id = p.id
LEFT JOIN doc_emr emr ON e.id = emr.encounter_id
WHERE e.status_enum = 2
AND emr.id IS NULL
<if test="patientName != null and patientName != ''">
AND p.name LIKE CONCAT('%', #{patientName}, '%')
</if>
ORDER BY e.create_time DESC
LIMIT #{pageSize} OFFSET #{offset}
</select>
<select id="getPendingEmrCount" resultType="java.lang.Long">
SELECT COUNT(*)
FROM adm_encounter e
INNER JOIN adm_encounter_participant ep ON e.id = ep.encounter_id AND ep.practitioner_id = #{doctorId}
LEFT JOIN adm_patient p ON e.patient_id = p.id
LEFT JOIN doc_emr emr ON e.id = emr.encounter_id
WHERE e.status_enum = 2
AND emr.id IS NULL
<if test="patientName != null and patientName != ''">
AND p.name LIKE CONCAT('%', #{patientName}, '%')
</if>
</select>
</mapper>

View File

@@ -11,10 +11,6 @@
p.birth_date, p.birth_date,
p.phone, p.phone,
p.address, p.address,
p.address_province,
p.address_city,
p.address_district,
p.address_street,
p.work_company, p.work_company,
p.nationality_code, p.nationality_code,
p.marital_status_enum, p.marital_status_enum,

View File

@@ -214,13 +214,10 @@
T1.dispense_per_duration AS dispense_per_duration, T1.dispense_per_duration AS dispense_per_duration,
T2.part_percent AS part_percent, T2.part_percent AS part_percent,
ccd.name AS condition_definition_name, ccd.name AS condition_definition_name,
T1.effective_dose_start AS start_time,
T1.therapy_enum AS therapyEnum, T1.therapy_enum AS therapyEnum,
T1.sort_number AS sort_number, T1.sort_number AS sort_number,
T1.based_on_id AS based_on_id, T1.based_on_id AS based_on_id,
T1.medication_id AS advice_definition_id T1.medication_id AS advice_definition_id
T1.effective_dose_end AS stop_time,
T1.update_by AS stop_user_name
FROM med_medication_request AS T1 FROM med_medication_request AS T1
LEFT JOIN med_medication_definition AS T2 ON T2.ID = T1.medication_id LEFT JOIN med_medication_definition AS T2 ON T2.ID = T1.medication_id
AND T2.delete_flag = '0' AND T2.delete_flag = '0'
@@ -272,11 +269,8 @@
'' AS condition_definition_name, '' AS condition_definition_name,
2 AS therapyEnum, 2 AS therapyEnum,
99 AS sort_number, 99 AS sort_number,
T1.req_authored_time AS start_time,
T1.based_on_id AS based_on_id, T1.based_on_id AS based_on_id,
T1.device_def_id AS advice_definition_id T1.device_def_id AS advice_definition_id
NULL AS stop_time,
'' AS stop_user_name
FROM wor_device_request AS T1 FROM wor_device_request AS T1
LEFT JOIN adm_device_definition AS T2 ON T2.ID = T1.device_def_id LEFT JOIN adm_device_definition AS T2 ON T2.ID = T1.device_def_id
AND T2.delete_flag = '0' AND T2.delete_flag = '0'
@@ -325,11 +319,8 @@
'' AS condition_definition_name, '' AS condition_definition_name,
COALESCE(T1.therapy_enum, 2) AS therapyEnum, COALESCE(T1.therapy_enum, 2) AS therapyEnum,
99 AS sort_number, 99 AS sort_number,
T1.occurrence_start_time AS start_time,
T1.based_on_id AS based_on_id, T1.based_on_id AS based_on_id,
T1.activity_id AS advice_definition_id T1.activity_id AS advice_definition_id
T1.occurrence_end_time AS stop_time,
T1.update_by AS stop_user_name
FROM wor_service_request AS T1 FROM wor_service_request AS T1
LEFT JOIN wor_activity_definition AS T2 LEFT JOIN wor_activity_definition AS T2
ON T2.ID = T1.activity_id ON T2.ID = T1.activity_id

View File

@@ -35,36 +35,21 @@
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0' WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 8 AND ws.status_enum = 8
) THEN 6 ) THEN 6
WHEN EXISTS (
SELECT 1 FROM wor_service_request ws
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 5
) THEN 7
WHEN EXISTS ( WHEN EXISTS (
SELECT 1 FROM wor_service_request ws SELECT 1 FROM wor_service_request ws
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0' WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 3 AND ws.status_enum = 3
) THEN 5 ) THEN 5
WHEN EXISTS (
SELECT 1 FROM wor_service_request ws
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 12
) THEN 4
WHEN EXISTS (
SELECT 1 FROM wor_service_request ws
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 11
) THEN 3
WHEN EXISTS (
SELECT 1 FROM wor_service_request ws
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 10
) THEN 2
WHEN EXISTS ( WHEN EXISTS (
SELECT 1 FROM wor_service_request ws SELECT 1 FROM wor_service_request ws
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0' WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 2 AND ws.status_enum = 2
) THEN 1 ) THEN 1
WHEN EXISTS (
SELECT 1 FROM wor_service_request ws
WHERE ws.prescription_no = drf.prescription_no AND ws.delete_flag = '0'
AND ws.status_enum = 5
) THEN 7
ELSE 0 ELSE 0
END AS computed_status END AS computed_status
FROM doc_request_form AS drf FROM doc_request_form AS drf

View File

@@ -274,10 +274,6 @@ public enum AssignSeqEnum {
* 检查申请单号(住院) * 检查申请单号(住院)
*/ */
CHECK_APPLY_NO("72", "检查申请单号", "JCZ"), CHECK_APPLY_NO("72", "检查申请单号", "JCZ"),
/**
* 手术申请单号(住院)
*/
SURGERY_APPLY_NO("73", "手术申请单号", "SSZ"),
/** /**
* b 病历文书 * b 病历文书
*/ */

View File

@@ -57,22 +57,7 @@ public enum RequestStatus implements HisEnumInterface {
/** /**
* 未知 * 未知
*/ */
UNKNOWN(9, "unknown", "未知"), UNKNOWN(9, "unknown", "未知");
/**
* 已校对(检查申请:护士校对通过)
*/
CHECK_VERIFIED(10, "check_verified", "已校对"),
/**
* 待接收(检查申请:等待医技科室接单)
*/
PENDING_RECEIVE(11, "pending_receive", "待接收"),
/**
* 已接收(检查申请:医技科室已接单)
*/
CHECK_RECEIVED(12, "check_received", "已接收");
@EnumValue @EnumValue
private final Integer value; private final Integer value;

View File

@@ -111,9 +111,6 @@ public class MedicationRequest extends HisBaseEntity {
/** 支持用药信息 */ /** 支持用药信息 */
private String supportInfo; private String supportInfo;
/** 退回原因 */
private String backReason;
/** 请求开始时间 */ /** 请求开始时间 */
private Date reqAuthoredTime; private Date reqAuthoredTime;

View File

@@ -30,7 +30,7 @@ public interface IMedicationRequestService extends IService<MedicationRequest> {
* @param practitionerId 校对人 * @param practitionerId 校对人
* @param checkDate 校对时间 * @param checkDate 校对时间
*/ */
void updateDraftStatusBatch(List<Long> requestIdList, Long practitionerId, Date checkDate, String backReason); void updateDraftStatusBatch(List<Long> requestIdList, Long practitionerId, Date checkDate);
/** /**
* 更新请求状态:取消 * 更新请求状态:取消

View File

@@ -44,7 +44,7 @@ public class MedicationRequestServiceImpl extends ServiceImpl<MedicationRequestM
* @param checkDate 校对时间 * @param checkDate 校对时间
*/ */
@Override @Override
public void updateDraftStatusBatch(List<Long> requestIdList, Long practitionerId, Date checkDate, String backReason) { public void updateDraftStatusBatch(List<Long> requestIdList, Long practitionerId, Date checkDate) {
LambdaUpdateWrapper<MedicationRequest> updateWrapper = LambdaUpdateWrapper<MedicationRequest> updateWrapper =
new LambdaUpdateWrapper<MedicationRequest>().in(MedicationRequest::getId, requestIdList) new LambdaUpdateWrapper<MedicationRequest>().in(MedicationRequest::getId, requestIdList)
.set(MedicationRequest::getStatusEnum, RequestStatus.DRAFT.getValue()); .set(MedicationRequest::getStatusEnum, RequestStatus.DRAFT.getValue());
@@ -54,9 +54,6 @@ public class MedicationRequestServiceImpl extends ServiceImpl<MedicationRequestM
if (checkDate != null) { if (checkDate != null) {
updateWrapper.set(MedicationRequest::getCheckTime, checkDate); updateWrapper.set(MedicationRequest::getCheckTime, checkDate);
} }
if (backReason != null) {
updateWrapper.set(MedicationRequest::getBackReason, backReason);
}
baseMapper.update(null, updateWrapper); baseMapper.update(null, updateWrapper);
} }
@@ -78,9 +75,6 @@ public class MedicationRequestServiceImpl extends ServiceImpl<MedicationRequestM
if (checkDate != null) { if (checkDate != null) {
updateWrapper.set(MedicationRequest::getCheckTime, checkDate); updateWrapper.set(MedicationRequest::getCheckTime, checkDate);
} }
if (backReason != null) {
updateWrapper.set(MedicationRequest::getBackReason, backReason);
}
baseMapper.update(null, updateWrapper); baseMapper.update(null, updateWrapper);
} }

View File

@@ -79,13 +79,11 @@ public class OpSchedule extends HisBaseEntity {
private String surgerySite; private String surgerySite;
/** 入院时间 */ /** 入院时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime admissionTime; private LocalDateTime admissionTime;
/** 入手术室时间 */ /** 入手术室时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime entryTime; private LocalDateTime entryTime;
/** 手术室编码 */ /** 手术室编码 */
@@ -144,23 +142,19 @@ public class OpSchedule extends HisBaseEntity {
private String assistant3Code; private String assistant3Code;
/** 手术开始时间 */ /** 手术开始时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime startTime; private LocalDateTime startTime;
/** 手术结束时间 */ /** 手术结束时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime endTime; private LocalDateTime endTime;
/** 麻醉开始时间 */ /** 麻醉开始时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime anesStart; private LocalDateTime anesStart;
/** 麻醉结束时间 */ /** 麻醉结束时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime anesEnd; private LocalDateTime anesEnd;
/** 手术状态 */ /** 手术状态 */

View File

@@ -39,22 +39,6 @@ public interface IServiceRequestService extends IService<ServiceRequest> {
*/ */
void updateCompleteRequestStatus(List<Long> serReqIdList, Long practitionerId, Date checkDate); void updateCompleteRequestStatus(List<Long> serReqIdList, Long practitionerId, Date checkDate);
/**
* 更新检查申请状态已校对护士校对检查申请后状态为CHECK_VERIFIED而非COMPLETED
*
* @param serReqIdList 服务请求id列表
* @param practitionerId 校对人
* @param checkDate 校对时间
*/
void updateCheckVerifiedStatus(List<Long> serReqIdList, Long practitionerId, Date checkDate);
/**
* 更新检查申请状态待接收护士执行检查申请后状态为PENDING_RECEIVE
*
* @param serReqIdList 服务请求id列表
*/
void updatePendingReceiveStatus(List<Long> serReqIdList);
/** /**
* 获取执行过的诊疗数据 * 获取执行过的诊疗数据
* *
@@ -109,7 +93,7 @@ public interface IServiceRequestService extends IService<ServiceRequest> {
* @param practitionerId 校对人 * @param practitionerId 校对人
* @param checkDate 校对时间 * @param checkDate 校对时间
*/ */
void updateDraftStatus(List<Long> serviceRequestIdList, Long practitionerId, Date checkDate, String backReason); void updateDraftStatus(List<Long> serviceRequestIdList, Long practitionerId, Date checkDate);
/** /**
* 更新服务状态:待发送 * 更新服务状态:待发送

View File

@@ -66,31 +66,6 @@ public class ServiceRequestServiceImpl extends ServiceImpl<ServiceRequestMapper,
.eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode())); .eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode()));
} }
/**
* 更新检查申请状态已校对护士校对检查申请后状态为CHECK_VERIFIED而非COMPLETED
*
* @param serReqIdList 服务请求id列表
*/
@Override
public void updateCheckVerifiedStatus(List<Long> serReqIdList, Long practitionerId, Date checkDate) {
baseMapper.update(new ServiceRequest().setStatusEnum(RequestStatus.CHECK_VERIFIED.getValue())
.setPerformerCheckId(SecurityUtils.getLoginUser().getPractitionerId()).setCheckTime(DateUtils.getNowDate()),
new LambdaUpdateWrapper<ServiceRequest>().in(ServiceRequest::getId, serReqIdList)
.eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode()));
}
/**
* 更新检查申请状态待接收护士执行检查申请后状态为PENDING_RECEIVE
*
* @param serReqIdList 服务请求id列表
*/
@Override
public void updatePendingReceiveStatus(List<Long> serReqIdList) {
baseMapper.update(new ServiceRequest().setStatusEnum(RequestStatus.PENDING_RECEIVE.getValue()),
new LambdaUpdateWrapper<ServiceRequest>().in(ServiceRequest::getId, serReqIdList)
.eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode()));
}
/** /**
* 获取执行过的诊疗数据 * 获取执行过的诊疗数据
* *
@@ -197,15 +172,9 @@ public class ServiceRequestServiceImpl extends ServiceImpl<ServiceRequestMapper,
* @param checkDate 校对时间 * @param checkDate 校对时间
*/ */
@Override @Override
public void updateDraftStatus(List<Long> serviceRequestIdList, Long practitionerId, Date checkDate, String backReason) { public void updateDraftStatus(List<Long> serviceRequestIdList, Long practitionerId, Date checkDate) {
ServiceRequest updateEntity = new ServiceRequest() baseMapper.update(new ServiceRequest().setStatusEnum(RequestStatus.DRAFT.getValue())
.setStatusEnum(RequestStatus.DRAFT.getValue()) .setPerformerCheckId(SecurityUtils.getLoginUser().getPractitionerId()).setCheckTime(DateUtils.getNowDate()),
.setPerformerCheckId(SecurityUtils.getLoginUser().getPractitionerId())
.setCheckTime(DateUtils.getNowDate());
if (backReason != null && !backReason.isEmpty()) {
updateEntity.setReasonText(backReason);
}
baseMapper.update(updateEntity,
new LambdaUpdateWrapper<ServiceRequest>().in(ServiceRequest::getId, serviceRequestIdList) new LambdaUpdateWrapper<ServiceRequest>().in(ServiceRequest::getId, serviceRequestIdList)
.eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode())); .eq(ServiceRequest::getDeleteFlag, DelFlag.NO.getCode()));
} }

View File

@@ -65,7 +65,7 @@
"typescript": "^5.9.3", "typescript": "^5.9.3",
"unplugin-auto-import": "0.17.1", "unplugin-auto-import": "0.17.1",
"unplugin-vue-setup-extend-plus": "1.0.0", "unplugin-vue-setup-extend-plus": "1.0.0",
"vite": "^5.0.4", "vite": "5.0.4",
"vite-plugin-compression": "0.5.1", "vite-plugin-compression": "0.5.1",
"vite-plugin-svg-icons": "2.0.1", "vite-plugin-svg-icons": "2.0.1",
"vite-plugin-vue-mcp": "^0.3.2", "vite-plugin-vue-mcp": "^0.3.2",
@@ -3093,6 +3093,41 @@
"url": "https://opencollective.com/vitest" "url": "https://opencollective.com/vitest"
} }
}, },
"node_modules/@vitest/mocker": {
"version": "4.1.2",
"resolved": "https://registry.npmmirror.com/@vitest/mocker/-/mocker-4.1.2.tgz",
"integrity": "sha512-Ize4iQtEALHDttPRCmN+FKqOl2vxTiNUhzobQFFt/BM1lRUTG7zRCLOykG/6Vo4E4hnUdfVLo5/eqKPukcWW7Q==",
"dev": true,
"dependencies": {
"@vitest/spy": "4.1.2",
"estree-walker": "^3.0.3",
"magic-string": "^0.30.21"
},
"funding": {
"url": "https://opencollective.com/vitest"
},
"peerDependencies": {
"msw": "^2.4.9",
"vite": "^6.0.0 || ^7.0.0 || ^8.0.0"
},
"peerDependenciesMeta": {
"msw": {
"optional": true
},
"vite": {
"optional": true
}
}
},
"node_modules/@vitest/mocker/node_modules/estree-walker": {
"version": "3.0.3",
"resolved": "https://registry.npmmirror.com/estree-walker/-/estree-walker-3.0.3.tgz",
"integrity": "sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==",
"dev": true,
"dependencies": {
"@types/estree": "^1.0.0"
}
},
"node_modules/@vitest/pretty-format": { "node_modules/@vitest/pretty-format": {
"version": "4.1.2", "version": "4.1.2",
"resolved": "https://registry.npmmirror.com/@vitest/pretty-format/-/pretty-format-4.1.2.tgz", "resolved": "https://registry.npmmirror.com/@vitest/pretty-format/-/pretty-format-4.1.2.tgz",
@@ -12636,10 +12671,9 @@
}, },
"node_modules/vite": { "node_modules/vite": {
"version": "5.0.4", "version": "5.0.4",
"resolved": "https://registry.npmjs.org/vite/-/vite-5.0.4.tgz", "resolved": "https://registry.npmmirror.com/vite/-/vite-5.0.4.tgz",
"integrity": "sha512-RzAr8LSvM8lmhB4tQ5OPcBhpjOZRZjuxv9zO5UcxeoY2bd3kP3Ticd40Qma9/BqZ8JS96Ll/jeBX9u+LJZrhVg==", "integrity": "sha512-RzAr8LSvM8lmhB4tQ5OPcBhpjOZRZjuxv9zO5UcxeoY2bd3kP3Ticd40Qma9/BqZ8JS96Ll/jeBX9u+LJZrhVg==",
"dev": true, "dev": true,
"license": "MIT",
"dependencies": { "dependencies": {
"esbuild": "^0.19.3", "esbuild": "^0.19.3",
"postcss": "^8.4.31", "postcss": "^8.4.31",
@@ -13302,33 +13336,6 @@
"node": ">=18" "node": ">=18"
} }
}, },
"node_modules/vitest/node_modules/@vitest/mocker": {
"version": "4.1.2",
"resolved": "https://registry.npmjs.org/@vitest/mocker/-/mocker-4.1.2.tgz",
"integrity": "sha512-Ize4iQtEALHDttPRCmN+FKqOl2vxTiNUhzobQFFt/BM1lRUTG7zRCLOykG/6Vo4E4hnUdfVLo5/eqKPukcWW7Q==",
"dev": true,
"license": "MIT",
"dependencies": {
"@vitest/spy": "4.1.2",
"estree-walker": "^3.0.3",
"magic-string": "^0.30.21"
},
"funding": {
"url": "https://opencollective.com/vitest"
},
"peerDependencies": {
"msw": "^2.4.9",
"vite": "^6.0.0 || ^7.0.0 || ^8.0.0"
},
"peerDependenciesMeta": {
"msw": {
"optional": true
},
"vite": {
"optional": true
}
}
},
"node_modules/vitest/node_modules/chokidar": { "node_modules/vitest/node_modules/chokidar": {
"version": "4.0.3", "version": "4.0.3",
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-4.0.3.tgz", "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-4.0.3.tgz",
@@ -13391,16 +13398,6 @@
"@esbuild/win32-x64": "0.27.7" "@esbuild/win32-x64": "0.27.7"
} }
}, },
"node_modules/vitest/node_modules/estree-walker": {
"version": "3.0.3",
"resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-3.0.3.tgz",
"integrity": "sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==",
"dev": true,
"license": "MIT",
"dependencies": {
"@types/estree": "^1.0.0"
}
},
"node_modules/vitest/node_modules/fsevents": { "node_modules/vitest/node_modules/fsevents": {
"version": "2.3.3", "version": "2.3.3",
"resolved": "https://registry.npmmirror.com/fsevents/-/fsevents-2.3.3.tgz", "resolved": "https://registry.npmmirror.com/fsevents/-/fsevents-2.3.3.tgz",

View File

@@ -83,11 +83,11 @@
"typescript": "^5.9.3", "typescript": "^5.9.3",
"unplugin-auto-import": "0.17.1", "unplugin-auto-import": "0.17.1",
"unplugin-vue-setup-extend-plus": "1.0.0", "unplugin-vue-setup-extend-plus": "1.0.0",
"vite": "^5.0.4", "vite": "5.0.4",
"vite-plugin-compression": "0.5.1", "vite-plugin-compression": "0.5.1",
"vite-plugin-svg-icons": "2.0.1", "vite-plugin-svg-icons": "2.0.1",
"vite-plugin-vue-mcp": "^0.3.2", "vite-plugin-vue-mcp": "^0.3.2",
"vitest": "^4.0.18", "vitest": "^4.0.18",
"vue-tsc": "^3.1.8" "vue-tsc": "^3.1.8"
} }
} }

View File

@@ -162,24 +162,6 @@ export function getG(svg, viewConfig) {
// 设置数据 // 设置数据
export function getData(allData) { export function getData(allData) {
const rowsData = allData.rows; // allData, '【全部数据】' const rowsData = allData.rows; // allData, '【全部数据】'
// 兼容旧数据:将旧 typeCode 映射到新 typeCode心率 004→014脉搏 005→002呼吸 006→001
const OLD_CODE_MAP = { '004': '014', '005': '002', '006': '001' };
rowsData.forEach(row => {
if (row.rowBOS) {
const prependItems = [];
row.rowBOS.forEach(item => {
const newCode = OLD_CODE_MAP[item.typeCode];
// 始终添加映射条目,用 unshift 插入数组头部
// 这样 getType 的 find() 优先匹配映射后的编码(如脉冲、呼吸)
// 即使存在同编码的旧条目(如血压舒张压用 002、收缩压用 001
// 映射后的脉搏(002)和呼吸(001)条目排在前面,确保图表正确渲染
if (newCode) {
prependItems.push({ ...item, typeCode: newCode });
}
});
row.rowBOS.unshift(...prependItems);
}
});
const infoData = allData.grParamBOS; const infoData = allData.grParamBOS;
const typesData = getTypeDatas(allData.types, allData.grParamBOS.beginDate); const typesData = getTypeDatas(allData.types, allData.grParamBOS.beginDate);
const selectOp = allData.selectOp; const selectOp = allData.selectOp;

View File

@@ -10,27 +10,15 @@
@click="clickAct" @click="clickAct"
> >
<div v-if="data.bedOperationalStatus==='U'"> <div v-if="data.bedOperationalStatus==='U'">
<img <img :src="emptyBed" class="pf_card_emptyBed_img">
:src="emptyBed" <div class="pf_card_emptyBed_text">{{ data.bedName }}</div>
class="pf_card_emptyBed_img"
>
<div class="pf_card_emptyBed_text">
{{ data.bedName }}
</div>
</div> </div>
<div v-else> <div v-else>
<div <div v-if="data.isDischarge" class="pf_card_discharge">
v-if="data.isDischarge"
class="pf_card_discharge"
>
<span style="margin-left: 6px"></span> <span style="margin-left: 6px"></span>
</div> </div>
<div class="pf_card_card"> <div class="pf_card_card">
<CardSign <CardSign :color="getBedBackColor(data.triageLevel)" :title="data.bedName" :tail="getDisplay(data.triageLevel)" />
:color="getBedBackColor(data.triageLevel)"
:title="data.bedName"
:tail="getDisplay(data.triageLevel)"
/>
</div> </div>
<div class="pf_card_nameSexAndAge"> <div class="pf_card_nameSexAndAge">
<span class="pf_card_name">{{ data.patientName }}</span> <span class="pf_card_name">{{ data.patientName }}</span>
@@ -40,48 +28,20 @@
<span style="margin-right: 16px">入室时间</span> <span style="margin-right: 16px">入室时间</span>
{{ moment(data.checkInWardTime).format('YYYY-MM-DD HH:mm') }} {{ moment(data.checkInWardTime).format('YYYY-MM-DD HH:mm') }}
</div> </div>
<div class="pf_card_noCode"> <div class="pf_card_noCode">{{ data.hisId }}</div>
{{ data.hisId }} <div class="pf_card_rescueTimeText">{{ rescueTimeText() }}</div>
</div> <div v-if="data.diag!==''" class="pf_card_diagnosis">
<div class="pf_card_rescueTimeText"> <div class="card-rectangle-text">{{ data.diag }}</div>
{{ rescueTimeText() }}
</div>
<div
v-if="data.diag!==''"
class="pf_card_diagnosis"
>
<div class="card-rectangle-text">
{{ data.diag }}
</div>
<span style="margin-left: 4px">(诊断)</span> <span style="margin-left: 4px">(诊断)</span>
</div> </div>
<div <div v-if="isNewSign()" class="card-rectangle"></div>
v-if="isNewSign()" <div v-if="is72HourSign()" class="card-rectangle2">超72H</div>
class="card-rectangle"
>
</div>
<div
v-if="is72HourSign()"
class="card-rectangle2"
>
超72H
</div>
<hr class="pf_card_line"> <hr class="pf_card_line">
<div class="pf_card_nursingMeasuresString"> <div class="pf_card_nursingMeasuresString">{{ getStringByCode(data.nursingMeasures, nursingMeasures) }}</div>
{{ getStringByCode(data.nursingMeasures, nursingMeasures) }} <div class="pf_card_specialArrangementString">{{ getStringByCode(data.specialArrangement, specialArrangementList) }}</div>
</div> <div v-if="false" class="pf_card_btn" @click="moreClick">更多</div>
<div class="pf_card_specialArrangementString">
{{ getStringByCode(data.specialArrangement, specialArrangementList) }}
</div>
<div
v-if="false"
class="pf_card_btn"
@click="moreClick"
>
更多
</div>
</div> </div>
</div> </div>
</template> </template>
<script> <script>

View File

@@ -6,7 +6,7 @@
:data="item" :data="item"
:bed-config="bedConfig" :bed-config="bedConfig"
@click="clickAct" @click="clickAct"
@more-click="moreClickAct" @moreClick="moreClickAct"
/> />
</div> </div>
</template> </template>

View File

@@ -1,19 +1,9 @@
<template> <template>
<div class="printCard"> <div class="printCard">
<div <div ref="refQr" style="float: left; margin: 30px 15px">
ref="refQr" <img :src="emptyBed" style="height: 120px" class="pf_card_emptyBed_img">
style="float: left; margin: 30px 15px"
>
<img
:src="emptyBed"
style="height: 120px"
class="pf_card_emptyBed_img"
>
</div> </div>
<div <div class="printView_content" style=" margin: 30px 0">
class="printView_content"
style=" margin: 30px 0"
>
<div> <div>
<span>床号</span> <span>床号</span>
<span>{{ printData.bedName }}</span> <span>{{ printData.bedName }}</span>

View File

@@ -1,9 +1,6 @@
<template> <template>
<div class="recordBill"> <div class="recordBill">
<div <div id="div1" class="printView_header">
id="div1"
class="printView_header"
>
<div style="text-align: center; height: 40px"> <div style="text-align: center; height: 40px">
护理交接班 护理交接班
</div> </div>
@@ -21,83 +18,35 @@
/> />
</div> </div>
</div> </div>
<div <div id="div2" class="printView_content">
id="div2" <table border="1" cellSpacing="0" width="98%" cellPadding="1" style=" border-collapse:collapse; font-size: 14px" bordercolor="#333333">
class="printView_content"
>
<table
border="1"
cellSpacing="0"
width="98%"
cellPadding="1"
style=" border-collapse:collapse; font-size: 14px"
bordercolor="#333333"
>
<thead> <thead>
<TR> <TR>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 40px" align="center">类别</DIV>
style="width: 40px"
align="center"
>
类别
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 50px" align="center">床号</DIV>
style="width: 50px"
align="center"
>
床号
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 60px" align="center">姓名</DIV>
style="width: 60px"
align="center"
>
姓名
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 90px" align="center">主诉</DIV>
style="width: 90px"
align="center"
>
主诉
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 90px" align="center">既往史</DIV>
style="width: 90px"
align="center"
>
既往史
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 90px" align="center">诊断</DIV>
style="width: 90px"
align="center"
>
诊断
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 155px" align="center">交接信息</DIV>
style="width: 155px"
align="center"
>
交接信息
</DIV>
</TD> </TD>
</TR> </TR>
</thead> </thead>
<tbody> <tbody>
<tr <tr v-for="item in printData.shiftRecordItems" :key="item.id">
v-for="item in printData.shiftRecordItems"
:key="item.id"
>
<td v-html="item.typeDisplay" /> <td v-html="item.typeDisplay" />
<td v-html="item.bedName" /> <td v-html="item.bedName" />
<td v-html="item.patientName" /> <td v-html="item.patientName" />

View File

@@ -1,9 +1,6 @@
<template> <template>
<div class="recordBill"> <div class="recordBill">
<div <div :id="'exeSheetTitle' + printData.id" class="printView_header">
:id="'exeSheetTitle' + printData.id"
class="printView_header"
>
<div style="text-align: center; height: 60px"> <div style="text-align: center; height: 60px">
{{ userStore.hospitalName }}医嘱执行单 {{ userStore.hospitalName }}医嘱执行单
</div> </div>
@@ -19,119 +16,51 @@
<span style="display: inline-block; width: 140px">性别{{!printData.patientInfo.gender? '':printData.patientInfo.gender.display}}</span> <span style="display: inline-block; width: 140px">性别{{!printData.patientInfo.gender? '':printData.patientInfo.gender.display}}</span>
</div>--> </div>-->
</div> </div>
<div <div :id="'exeSheet' + printData.id" class="printView_content">
:id="'exeSheet' + printData.id" <table border="1" cellSpacing="0" width="97%" cellPadding="1" style=" border-collapse:collapse; font-size: 13px" bordercolor="#333333">
class="printView_content"
>
<table
border="1"
cellSpacing="0"
width="97%"
cellPadding="1"
style=" border-collapse:collapse; font-size: 13px"
bordercolor="#333333"
>
<thead> <thead>
<TR> <TR>
<TD rowspan="1"> <TD rowspan="1">
<DIV style="width: 65px;text-align: center"> <DIV style="width: 65px;text-align: center">医嘱日期</DIV>
医嘱日期
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 120px" align="center">医嘱</DIV>
style="width: 120px"
align="center"
>
医嘱
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 10px" align="center" />
style="width: 10px"
align="center"
/>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 70px" align="center">嘱托</DIV>
style="width: 70px"
align="center"
>
嘱托
</DIV>
</TD> </TD>
<TD rowspan="1"> <TD rowspan="1">
<DIV <DIV style="width: 60px" align="center">用量</DIV>
style="width: 60px"
align="center"
>
用量
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 40px" align="center">用法</DIV>
style="width: 40px"
align="center"
>
用法
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 40px" align="center">频次</DIV>
style="width: 40px"
align="center"
>
频次
</DIV>
</TD> </TD>
<TD rowspan="1"> <TD rowspan="1">
<DIV <DIV style="width: 65px" align="center">开立医生</DIV>
style="width: 65px"
align="center"
>
开立医生
</DIV>
</TD> </TD>
<TD rowspan="1"> <TD rowspan="1">
<DIV <DIV style="width: 65px" align="center">执行时间</DIV>
style="width: 65px"
align="center"
>
执行时间
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 65px" align="center">执行护士</DIV>
style="width: 65px"
align="center"
>
执行护士
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 55px" align="center">终止时间</DIV>
style="width: 55px"
align="center"
>
终止时间
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 55px" align="center">终止人</DIV>
style="width: 55px"
align="center"
>
终止人
</DIV>
</TD> </TD>
</TR> </TR>
</thead> </thead>
<tbody> <tbody>
<tr <tr v-for="item in printData.recordData" :key="item.id">
v-for="item in printData.recordData"
:key="item.id"
>
<td v-html="item.moTime" /> <td v-html="item.moTime" />
<td v-html="item.orderName" /> <td v-html="item.orderName" />
<td v-html="item.flag" /> <td v-html="item.flag" />
@@ -141,20 +70,12 @@
<td v-html="item.frequency" /> <td v-html="item.frequency" />
<td :id="item.id"> <td :id="item.id">
<span v-if="(item.docSignImage === ''||item.docSignImage === null)">{{ item.moDocName }}</span> <span v-if="(item.docSignImage === ''||item.docSignImage === null)">{{ item.moDocName }}</span>
<img <img v-if="(item.docSignImage !== ''&&item.docSignImage !== null)" :src="'data:image/png;base64,'+ item.docSignImage" style="height: 100%; width: 100%;object-fit: cover;">
v-if="(item.docSignImage !== ''&&item.docSignImage !== null)"
:src="'data:image/png;base64,'+ item.docSignImage"
style="height: 100%; width: 100%;object-fit: cover;"
>
</td> </td>
<td v-html="item.occurrence" /> <td v-html="item.occurrence" />
<td :id="item.id"> <td :id="item.id">
<span v-if="(item.perNurserSignImage === ''||item.perNurserSignImage === null)">{{ item.performName }}</span> <span v-if="(item.perNurserSignImage === ''||item.perNurserSignImage === null)">{{ item.performName }}</span>
<img <img v-if="(item.perNurserSignImage !== ''&&item.perNurserSignImage !== null)" :src="'data:image/png;base64,'+ item.perNurserSignImage" style="height: 100%; width: 100%;object-fit: cover;">
v-if="(item.perNurserSignImage !== ''&&item.perNurserSignImage !== null)"
:src="'data:image/png;base64,'+ item.perNurserSignImage"
style="height: 100%; width: 100%;object-fit: cover;"
>
</td> </td>
<td /> <td />
<td /> <td />
@@ -170,6 +91,10 @@ import { simplePrint, PRINT_TEMPLATE } from '@/utils/printUtils.js'
import useUserStore from '@/store/modules/user' import useUserStore from '@/store/modules/user'
export default { export default {
setup() {
const userStore = useUserStore();
return { userStore };
},
props: { props: {
printData: { printData: {
type: Object, type: Object,
@@ -178,10 +103,6 @@ export default {
} }
} }
}, },
setup() {
const userStore = useUserStore();
return { userStore };
},
data() { data() {
return {} return {}
}, },

View File

@@ -12,51 +12,23 @@
</div> </div>
</div> </div>
<div style="display: block; width: 120px; height: 60px; float:left; "> <div style="display: block; width: 120px; height: 60px; float:left; ">
<div <div :id="getId(printData.id)" style="float: left; margin: 5px;" />
:id="getId(printData.id)"
style="float: left; margin: 5px;"
/>
<span style="float: left; margin: 5px">{{ printData.priority }}</span> <span style="float: left; margin: 5px">{{ printData.priority }}</span>
</div> </div>
</div> </div>
<div :id="printData.id + 'div2'"> <div :id="printData.id + 'div2'">
<table <table border="1" cellSpacing="0" width="390px" cellPadding="1" style="margin-left: 8px; border-collapse:collapse; table-layout: fixed; font-size: 14px" bordercolor="#333333">
border="1"
cellSpacing="0"
width="390px"
cellPadding="1"
style="margin-left: 8px; border-collapse:collapse; table-layout: fixed; font-size: 14px"
bordercolor="#333333"
>
<thead> <thead>
<TR> <TR>
<Th <Th style="width: 160px" v-html="'药品名称'" />
style="width: 160px" <Th style="width: 75px" v-html="'用量'" />
v-html="'药品名称'" <Th style="width: 10px" v-html="''" />
/> <Th style="width: 50px" v-html="'频次'" />
<Th <Th style="width: 75px" v-html="'用法'" />
style="width: 75px"
v-html="'用量'"
/>
<Th
style="width: 10px"
v-html="''"
/>
<Th
style="width: 50px"
v-html="'频次'"
/>
<Th
style="width: 75px"
v-html="'用法'"
/>
</TR> </TR>
</thead> </thead>
<tbody> <tbody>
<tr <tr v-for="item in printData.orderDetail" :key="item.id">
v-for="item in printData.orderDetail"
:key="item.id"
>
<td v-html="item.orderName" /> <td v-html="item.orderName" />
<td v-html="item.doseOnce + item.doseUnit" /> <td v-html="item.doseOnce + item.doseUnit" />
<td v-html="item.flag" /> <td v-html="item.flag" />

View File

@@ -1,9 +1,6 @@
<template> <template>
<div class="recordBill"> <div class="recordBill">
<div <div id="div1" class="printView_header">
id="div1"
class="printView_header"
>
<div style="text-align: center; font-size: 20px; height: 40px"> <div style="text-align: center; font-size: 20px; height: 40px">
{{ userStore.hospitalName }}输液执行单 {{ userStore.hospitalName }}输液执行单
</div> </div>
@@ -16,88 +13,38 @@
<span style="margin-left: 18px">科室{{ printData.patientInfo.deptName }}</span> <span style="margin-left: 18px">科室{{ printData.patientInfo.deptName }}</span>
</div> </div>
</div> </div>
<div <div id="div2" class="printView_content">
id="div2" <table border="1" cellSpacing="0" cellPadding="1" style=" border-collapse:collapse; font-size: 14px" bordercolor="#333333">
class="printView_content"
>
<table
border="1"
cellSpacing="0"
cellPadding="1"
style=" border-collapse:collapse; font-size: 14px"
bordercolor="#333333"
>
<thead> <thead>
<TR style="height: 30px"> <TR style="height: 30px">
<TD rowspan="1"> <TD rowspan="1">
<DIV <DIV style="width: 35px" align="center">时间</DIV>
style="width: 35px"
align="center"
>
时间
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 280px" align="center">药品名称</DIV>
style="width: 280px"
align="center"
>
药品名称
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 10px" align="center" />
style="width: 10px"
align="center"
/>
</TD> </TD>
<TD rowspan="1"> <TD rowspan="1">
<DIV <DIV style="width: 55px" align="center">剂量</DIV>
style="width: 55px"
align="center"
>
剂量
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 30px" align="center">频次</DIV>
style="width: 30px"
align="center"
>
频次
</DIV>
</TD> </TD>
<TD colspan="1"> <TD colspan="1">
<DIV <DIV style="width: 55px" align="center">用法</DIV>
style="width: 55px"
align="center"
>
用法
</DIV>
</TD> </TD>
<TD rowspan="1"> <TD rowspan="1">
<DIV <DIV style="width: 70px" align="center">执行时间</DIV>
style="width: 70px"
align="center"
>
执行时间
</DIV>
</TD> </TD>
<TD rowspan="1"> <TD rowspan="1">
<DIV <DIV style="width: 55px" align="center">执行人</DIV>
style="width: 55px"
align="center"
>
执行人
</DIV>
</TD> </TD>
</TR> </TR>
</thead> </thead>
<tbody style=" border-collapse:collapse;"> <tbody style=" border-collapse:collapse;">
<tr <tr v-for="item in printData.recordData" :key="item.id">
v-for="item in printData.recordData"
:key="item.id"
>
<td v-html="item.moTime.substring(0,16)" /> <td v-html="item.moTime.substring(0,16)" />
<td v-html="item.orderName" /> <td v-html="item.orderName" />
<td v-html="item.flag" /> <td v-html="item.flag" />

View File

@@ -1,15 +1,9 @@
<template> <template>
<div> <div>
<div ref="print"> <div ref="print">
<div <div v-for="item in printData" :key="item.id">
v-for="item in printData"
:key="item.id"
>
<div class="myccs2"> <div class="myccs2">
<injectLabel <injectLabel :ref="item.id" :print-data="item" />
:ref="item.id"
:print-data="item"
/>
</div> </div>
</div> </div>
</div> </div>

View File

@@ -1,21 +1,10 @@
<template> <template>
<div> <div>
<div ref="print"> <div ref="print">
<div <div v-for="item in printData" :key="item.id">
v-for="item in printData"
:key="item.id"
>
<div class="myccs2"> <div class="myccs2">
<orderSheet <orderSheet v-if="!item.type" :ref="item.id" :print-data="item" />
v-if="!item.type" <exeOrderSheet v-if="item.type" :ref="item.id" :print-data="item" />
:ref="item.id"
:print-data="item"
/>
<exeOrderSheet
v-if="item.type"
:ref="item.id"
:print-data="item"
/>
</div> </div>
</div> </div>
</div> </div>

View File

@@ -1,10 +1,5 @@
<template> <template>
<Graphics <Graphics v-if="graphicsDataDone" :value="resInfo" print @done="printPage" />
v-if="graphicsDataDone"
:value="resInfo"
print
@done="printPage"
/>
</template> </template>
<script setup> <script setup>

View File

@@ -21,10 +21,7 @@
<span>分诊时间</span> <span>分诊时间</span>
<span>{{ printData.triageTime }}</span> <span>{{ printData.triageTime }}</span>
</div> </div>
<img <img ref="refQr" style="position: absolute; top: 10px; left: 100px" />
ref="refQr"
style="position: absolute; top: 10px; left: 100px"
>
</div> </div>
</template> </template>
<script> <script>
@@ -33,6 +30,10 @@ import useUserStore from '@/store/modules/user';
export default { export default {
name: 'TriageTicket', name: 'TriageTicket',
setup() {
const userStore = useUserStore();
return { userStore };
},
props: { props: {
printData: { printData: {
type: Object, type: Object,
@@ -47,10 +48,6 @@ export default {
}, },
}, },
}, },
setup() {
const userStore = useUserStore();
return { userStore };
},
data() { data() {
return {}; return {};
}, },

View File

@@ -2,10 +2,7 @@
<div> <div>
<div ref="print"> <div ref="print">
<div class="myccs2"> <div class="myccs2">
<triageTicketNew <triageTicketNew ref="printTriage" :print-data="printData" />
ref="printTriage"
:print-data="printData"
/>
</div> </div>
<!-- <div v-for="item in printData" :key="item.id">--> <!-- <div v-for="item in printData" :key="item.id">-->
<!-- <div class="myccs2">--> <!-- <div class="myccs2">-->

View File

@@ -6,9 +6,7 @@
<span style="font-weight: bolder; font-size: 18px; line-height: 36px">{{ printData.greenText }}</span> <span style="font-weight: bolder; font-size: 18px; line-height: 36px">{{ printData.greenText }}</span>
<span style="font-weight: bolder; font-size: 18px; line-height: 36px">分诊单</span> <span style="font-weight: bolder; font-size: 18px; line-height: 36px">分诊单</span>
</div> </div>
<div style="position: absolute; top: 135px; text-align: center; width: 300px"> <div style="position: absolute; top: 135px; text-align: center; width: 300px">{{ printData.hisId }}</div>
{{ printData.hisId }}
</div>
<div style="position: absolute; top: 155px; text-align: center; width: 300px"> <div style="position: absolute; top: 155px; text-align: center; width: 300px">
{{ printData.triageLevel }}{{ printData.dept }} {{ printData.triageLevel }}{{ printData.dept }}
</div> </div>
@@ -109,18 +107,10 @@
" "
/> />
<div style="margin-left: 15px"> <div style="margin-left: 15px">
<div style="font-size: 14px; margin-top: 15px; font-weight: bolder"> <div style="font-size: 14px; margin-top: 15px; font-weight: bolder">请仔细核对个人信息后进行挂号</div>
请仔细核对个人信息后进行挂号 <div style="margin-top: 5px; font-size: 14px">为了您家人和其他患者的健康</div>
</div> <div style="font-size: 14px">请您保持就诊秩序保持诊区安静</div>
<div style="margin-top: 5px; font-size: 14px"> <div style="font-size: 14px">祝您早日康复</div>
为了您家人和其他患者的健康
</div>
<div style="font-size: 14px">
请您保持就诊秩序保持诊区安静
</div>
<div style="font-size: 14px">
祝您早日康复
</div>
</div> </div>
</div> </div>
</div> </div>

View File

@@ -1,9 +1,6 @@
<template> <template>
<div class="printWrist"> <div class="printWrist">
<div <div id="div1" class="printView_content">
id="div1"
class="printView_content"
>
<div style="margin: 1px;font-size: 12px"> <div style="margin: 1px;font-size: 12px">
<span>姓名: </span> <span>姓名: </span>
<span>{{ printData.patientName }}</span> <span>{{ printData.patientName }}</span>
@@ -25,11 +22,7 @@
<span style="position: absolute; left: 140px">{{ printData.triageLevel }}</span> <span style="position: absolute; left: 140px">{{ printData.triageLevel }}</span>
</div> </div>
</div> </div>
<div <div id="qrcode" ref="refQr" style="padding-top: 1px" />
id="qrcode"
ref="refQr"
style="padding-top: 1px"
/>
</div> </div>
</template> </template>
<script> <script>

View File

@@ -1,21 +1,9 @@
<template> <template>
<el-breadcrumb <el-breadcrumb class="app-breadcrumb" separator="/">
class="app-breadcrumb"
separator="/"
>
<transition-group name="breadcrumb"> <transition-group name="breadcrumb">
<el-breadcrumb-item <el-breadcrumb-item v-for="(item,index) in levelList" :key="item.path">
v-for="(item,index) in levelList" <span v-if="item.redirect === 'noRedirect' || index == levelList.length - 1" class="no-redirect">{{ item.meta.title }}</span>
:key="item.path" <a v-else @click.prevent="handleLink(item)">{{ item.meta.title }}</a>
>
<span
v-if="item.redirect === 'noRedirect' || index == levelList.length - 1"
class="no-redirect"
>{{ item.meta.title }}</span>
<a
v-else
@click.prevent="handleLink(item)"
>{{ item.meta.title }}</a>
</el-breadcrumb-item> </el-breadcrumb-item>
</transition-group> </transition-group>
</el-breadcrumb> </el-breadcrumb>

View File

@@ -1,107 +1,55 @@
<template> <template>
<el-form> <el-form>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="1">
v-model="radioValue" 允许的通配符[, - * ? / L W]
:label="1" </el-radio>
> </el-form-item>
允许的通配符[, - * ? / L W]
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="2">
v-model="radioValue" 不指定
:label="2" </el-radio>
> </el-form-item>
不指定
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="3">
v-model="radioValue" 周期从
:label="3" <el-input-number v-model='cycle01' :min="1" :max="30" /> -
> <el-input-number v-model='cycle02' :min="cycle01 + 1" :max="31" />
周期从 </el-radio>
<el-input-number </el-form-item>
v-model="cycle01"
:min="1"
:max="30"
/> -
<el-input-number
v-model="cycle02"
:min="cycle01 + 1"
:max="31"
/>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="4">
v-model="radioValue"
:label="4" <el-input-number v-model='average01' :min="1" :max="30" /> 号开始
> <el-input-number v-model='average02' :min="1" :max="31 - average01" /> 日执行一次
</el-radio>
<el-input-number </el-form-item>
v-model="average01"
:min="1"
:max="30"
/> 号开始
<el-input-number
v-model="average02"
:min="1"
:max="31 - average01"
/> 日执行一次
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="5">
v-model="radioValue" 每月
:label="5" <el-input-number v-model='workday' :min="1" :max="31" /> 号最近的那个工作日
> </el-radio>
每月 </el-form-item>
<el-input-number
v-model="workday"
:min="1"
:max="31"
/> 号最近的那个工作日
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="6">
v-model="radioValue" 本月最后一天
:label="6" </el-radio>
> </el-form-item>
本月最后一天
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="7">
v-model="radioValue" 指定
:label="7" <el-select clearable v-model="checkboxList" placeholder="可多选" multiple :multiple-limit="10">
> <el-option v-for="item in 31" :key="item" :label="item" :value="item" />
指定 </el-select>
<el-select </el-radio>
v-model="checkboxList" </el-form-item>
clearable </el-form>
placeholder="可多选"
multiple
:multiple-limit="10"
>
<el-option
v-for="item in 31"
:key="item"
:label="item"
:value="item"
/>
</el-select>
</el-radio>
</el-form-item>
</el-form>
</template> </template>
<script setup> <script setup>
const emit = defineEmits(['update']) const emit = defineEmits(['update'])

View File

@@ -1,75 +1,36 @@
<template> <template>
<el-form> <el-form>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="1">
v-model="radioValue" 小时允许的通配符[, - * /]
:label="1" </el-radio>
> </el-form-item>
小时允许的通配符[, - * /]
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="2">
v-model="radioValue" 周期从
:label="2" <el-input-number v-model='cycle01' :min="0" :max="22" /> -
> <el-input-number v-model='cycle02' :min="cycle01 + 1" :max="23" />
周期从 </el-radio>
<el-input-number </el-form-item>
v-model="cycle01"
:min="0"
:max="22"
/> -
<el-input-number
v-model="cycle02"
:min="cycle01 + 1"
:max="23"
/>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="3">
v-model="radioValue"
:label="3" <el-input-number v-model='average01' :min="0" :max="22" /> 时开始
> <el-input-number v-model='average02' :min="1" :max="23 - average01" /> 小时执行一次
</el-radio>
<el-input-number </el-form-item>
v-model="average01"
:min="0"
:max="22"
/> 时开始
<el-input-number
v-model="average02"
:min="1"
:max="23 - average01"
/> 小时执行一次
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="4">
v-model="radioValue" 指定
:label="4" <el-select clearable v-model="checkboxList" placeholder="可多选" multiple :multiple-limit="10">
> <el-option v-for="item in 24" :key="item" :label="item - 1" :value="item - 1" />
指定 </el-select>
<el-select </el-radio>
v-model="checkboxList" </el-form-item>
clearable </el-form>
placeholder="可多选"
multiple
:multiple-limit="10"
>
<el-option
v-for="item in 24"
:key="item"
:label="item - 1"
:value="item - 1"
/>
</el-select>
</el-radio>
</el-form-item>
</el-form>
</template> </template>
<script setup> <script setup>

View File

@@ -1,211 +1,123 @@
<template> <template>
<div> <div>
<el-tabs type="border-card"> <el-tabs type="border-card">
<el-tab-pane <el-tab-pane label="秒" v-if="shouldHide('second')">
v-if="shouldHide('second')" <CrontabSecond
label="秒" @update="updateCrontabValue"
> :check="checkNumber"
<CrontabSecond :cron="crontabValueObj"
ref="cronsecond" ref="cronsecond"
:check="checkNumber" />
:cron="crontabValueObj" </el-tab-pane>
@update="updateCrontabValue"
/>
</el-tab-pane>
<el-tab-pane <el-tab-pane label="分钟" v-if="shouldHide('min')">
v-if="shouldHide('min')" <CrontabMin
label="分钟" @update="updateCrontabValue"
> :check="checkNumber"
<CrontabMin :cron="crontabValueObj"
ref="cronmin" ref="cronmin"
:check="checkNumber" />
:cron="crontabValueObj" </el-tab-pane>
@update="updateCrontabValue"
/>
</el-tab-pane>
<el-tab-pane <el-tab-pane label="小时" v-if="shouldHide('hour')">
v-if="shouldHide('hour')" <CrontabHour
label="小时" @update="updateCrontabValue"
> :check="checkNumber"
<CrontabHour :cron="crontabValueObj"
ref="cronhour" ref="cronhour"
:check="checkNumber" />
:cron="crontabValueObj" </el-tab-pane>
@update="updateCrontabValue"
/>
</el-tab-pane>
<el-tab-pane <el-tab-pane label="日" v-if="shouldHide('day')">
v-if="shouldHide('day')" <CrontabDay
label="日" @update="updateCrontabValue"
> :check="checkNumber"
<CrontabDay :cron="crontabValueObj"
ref="cronday" ref="cronday"
:check="checkNumber" />
:cron="crontabValueObj" </el-tab-pane>
@update="updateCrontabValue"
/>
</el-tab-pane>
<el-tab-pane <el-tab-pane label="月" v-if="shouldHide('month')">
v-if="shouldHide('month')" <CrontabMonth
label="月" @update="updateCrontabValue"
> :check="checkNumber"
<CrontabMonth :cron="crontabValueObj"
ref="cronmonth" ref="cronmonth"
:check="checkNumber" />
:cron="crontabValueObj" </el-tab-pane>
@update="updateCrontabValue"
/>
</el-tab-pane>
<el-tab-pane <el-tab-pane label="周" v-if="shouldHide('week')">
v-if="shouldHide('week')" <CrontabWeek
label="周" @update="updateCrontabValue"
> :check="checkNumber"
<CrontabWeek :cron="crontabValueObj"
ref="cronweek" ref="cronweek"
:check="checkNumber" />
:cron="crontabValueObj" </el-tab-pane>
@update="updateCrontabValue"
/>
</el-tab-pane>
<el-tab-pane <el-tab-pane label="年" v-if="shouldHide('year')">
v-if="shouldHide('year')" <CrontabYear
label="年" @update="updateCrontabValue"
> :check="checkNumber"
<CrontabYear :cron="crontabValueObj"
ref="cronyear" ref="cronyear"
:check="checkNumber" />
:cron="crontabValueObj" </el-tab-pane>
@update="updateCrontabValue" </el-tabs>
/>
</el-tab-pane>
</el-tabs>
<div class="popup-main"> <div class="popup-main">
<div class="popup-result"> <div class="popup-result">
<p class="title"> <p class="title">时间表达式</p>
时间表达式 <table>
</p> <thead>
<table> <th v-for="item of tabTitles" :key="item">{{item}}</th>
<thead> <th>Cron 表达式</th>
<th </thead>
v-for="item of tabTitles" <tbody>
:key="item" <td>
> <span v-if="crontabValueObj.second.length < 10">{{crontabValueObj.second}}</span>
{{ item }} <el-tooltip v-else :content="crontabValueObj.second" placement="top"><span>{{crontabValueObj.second}}</span></el-tooltip>
</th> </td>
<th>Cron 表达式</th> <td>
</thead> <span v-if="crontabValueObj.min.length < 10">{{crontabValueObj.min}}</span>
<tbody> <el-tooltip v-else :content="crontabValueObj.min" placement="top"><span>{{crontabValueObj.min}}</span></el-tooltip>
<td> </td>
<span v-if="crontabValueObj.second.length < 10">{{ crontabValueObj.second }}</span> <td>
<el-tooltip <span v-if="crontabValueObj.hour.length < 10">{{crontabValueObj.hour}}</span>
v-else <el-tooltip v-else :content="crontabValueObj.hour" placement="top"><span>{{crontabValueObj.hour}}</span></el-tooltip>
:content="crontabValueObj.second" </td>
placement="top" <td>
> <span v-if="crontabValueObj.day.length < 10">{{crontabValueObj.day}}</span>
<span>{{ crontabValueObj.second }}</span> <el-tooltip v-else :content="crontabValueObj.day" placement="top"><span>{{crontabValueObj.day}}</span></el-tooltip>
</el-tooltip> </td>
</td> <td>
<td> <span v-if="crontabValueObj.month.length < 10">{{crontabValueObj.month}}</span>
<span v-if="crontabValueObj.min.length < 10">{{ crontabValueObj.min }}</span> <el-tooltip v-else :content="crontabValueObj.month" placement="top"><span>{{crontabValueObj.month}}</span></el-tooltip>
<el-tooltip </td>
v-else <td>
:content="crontabValueObj.min" <span v-if="crontabValueObj.week.length < 10">{{crontabValueObj.week}}</span>
placement="top" <el-tooltip v-else :content="crontabValueObj.week" placement="top"><span>{{crontabValueObj.week}}</span></el-tooltip>
> </td>
<span>{{ crontabValueObj.min }}</span> <td>
</el-tooltip> <span v-if="crontabValueObj.year.length < 10">{{crontabValueObj.year}}</span>
</td> <el-tooltip v-else :content="crontabValueObj.year" placement="top"><span>{{crontabValueObj.year}}</span></el-tooltip>
<td> </td>
<span v-if="crontabValueObj.hour.length < 10">{{ crontabValueObj.hour }}</span> <td class="result">
<el-tooltip <span v-if="crontabValueString.length < 90">{{crontabValueString}}</span>
v-else <el-tooltip v-else :content="crontabValueString" placement="top"><span>{{crontabValueString}}</span></el-tooltip>
:content="crontabValueObj.hour" </td>
placement="top" </tbody>
> </table>
<span>{{ crontabValueObj.hour }}</span> </div>
</el-tooltip> <CrontabResult :ex="crontabValueString"></CrontabResult>
</td>
<td>
<span v-if="crontabValueObj.day.length < 10">{{ crontabValueObj.day }}</span>
<el-tooltip
v-else
:content="crontabValueObj.day"
placement="top"
>
<span>{{ crontabValueObj.day }}</span>
</el-tooltip>
</td>
<td>
<span v-if="crontabValueObj.month.length < 10">{{ crontabValueObj.month }}</span>
<el-tooltip
v-else
:content="crontabValueObj.month"
placement="top"
>
<span>{{ crontabValueObj.month }}</span>
</el-tooltip>
</td>
<td>
<span v-if="crontabValueObj.week.length < 10">{{ crontabValueObj.week }}</span>
<el-tooltip
v-else
:content="crontabValueObj.week"
placement="top"
>
<span>{{ crontabValueObj.week }}</span>
</el-tooltip>
</td>
<td>
<span v-if="crontabValueObj.year.length < 10">{{ crontabValueObj.year }}</span>
<el-tooltip
v-else
:content="crontabValueObj.year"
placement="top"
>
<span>{{ crontabValueObj.year }}</span>
</el-tooltip>
</td>
<td class="result">
<span v-if="crontabValueString.length < 90">{{ crontabValueString }}</span>
<el-tooltip
v-else
:content="crontabValueString"
placement="top"
>
<span>{{ crontabValueString }}</span>
</el-tooltip>
</td>
</tbody>
</table>
</div>
<CrontabResult :ex="crontabValueString" />
<div class="pop_btn"> <div class="pop_btn">
<el-button <el-button type="primary" @click="submitFill">确定</el-button>
type="primary" <el-button type="warning" @click="clearCron">重置</el-button>
@click="submitFill" <el-button @click="hidePopup">取消</el-button>
> </div>
确定 </div>
</el-button>
<el-button
type="warning"
@click="clearCron"
>
重置
</el-button>
<el-button @click="hidePopup">
取消
</el-button>
</div>
</div> </div>
</div>
</template> </template>
<script setup> <script setup>

View File

@@ -1,75 +1,36 @@
<template> <template>
<el-form> <el-form>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="1">
v-model="radioValue" 分钟允许的通配符[, - * /]
:label="1" </el-radio>
> </el-form-item>
分钟允许的通配符[, - * /]
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="2">
v-model="radioValue" 周期从
:label="2" <el-input-number v-model='cycle01' :min="0" :max="58" /> -
> <el-input-number v-model='cycle02' :min="cycle01 + 1" :max="59" /> 分钟
周期从 </el-radio>
<el-input-number </el-form-item>
v-model="cycle01"
:min="0"
:max="58"
/> -
<el-input-number
v-model="cycle02"
:min="cycle01 + 1"
:max="59"
/> 分钟
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="3">
v-model="radioValue"
:label="3" <el-input-number v-model='average01' :min="0" :max="58" /> 分钟开始
> <el-input-number v-model='average02' :min="1" :max="59 - average01" /> 分钟执行一次
</el-radio>
<el-input-number </el-form-item>
v-model="average01"
:min="0"
:max="58"
/> 分钟开始
<el-input-number
v-model="average02"
:min="1"
:max="59 - average01"
/> 分钟执行一次
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="4">
v-model="radioValue" 指定
:label="4" <el-select clearable v-model="checkboxList" placeholder="可多选" multiple :multiple-limit="10">
> <el-option v-for="item in 60" :key="item" :label="item - 1" :value="item - 1" />
指定 </el-select>
<el-select </el-radio>
v-model="checkboxList" </el-form-item>
clearable </el-form>
placeholder="可多选"
multiple
:multiple-limit="10"
>
<el-option
v-for="item in 60"
:key="item"
:label="item - 1"
:value="item - 1"
/>
</el-select>
</el-radio>
</el-form-item>
</el-form>
</template> </template>
<script setup> <script setup>
const emit = defineEmits(['update']) const emit = defineEmits(['update'])

View File

@@ -1,75 +1,36 @@
<template> <template>
<el-form> <el-form>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="1">
v-model="radioValue" 允许的通配符[, - * /]
:label="1" </el-radio>
> </el-form-item>
允许的通配符[, - * /]
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="2">
v-model="radioValue" 周期从
:label="2" <el-input-number v-model='cycle01' :min="1" :max="11" /> -
> <el-input-number v-model='cycle02' :min="cycle01 + 1" :max="12" />
周期从 </el-radio>
<el-input-number </el-form-item>
v-model="cycle01"
:min="1"
:max="11"
/> -
<el-input-number
v-model="cycle02"
:min="cycle01 + 1"
:max="12"
/>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="3">
v-model="radioValue"
:label="3" <el-input-number v-model='average01' :min="1" :max="11" /> 月开始
> <el-input-number v-model='average02' :min="1" :max="12 - average01" /> 月月执行一次
</el-radio>
<el-input-number </el-form-item>
v-model="average01"
:min="1"
:max="11"
/> 月开始
<el-input-number
v-model="average02"
:min="1"
:max="12 - average01"
/> 月月执行一次
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="4">
v-model="radioValue" 指定
:label="4" <el-select clearable v-model="checkboxList" placeholder="可多选" multiple :multiple-limit="8">
> <el-option v-for="item in monthList" :key="item.key" :label="item.value" :value="item.key" />
指定 </el-select>
<el-select </el-radio>
v-model="checkboxList" </el-form-item>
clearable </el-form>
placeholder="可多选"
multiple
:multiple-limit="8"
>
<el-option
v-for="item in monthList"
:key="item.key"
:label="item.value"
:value="item.key"
/>
</el-select>
</el-radio>
</el-form-item>
</el-form>
</template> </template>
<script setup> <script setup>

View File

@@ -1,22 +1,13 @@
<template> <template>
<div class="popup-result"> <div class="popup-result">
<p class="title"> <p class="title">最近5次运行时间</p>
最近5次运行时间 <ul class="popup-result-scroll">
</p> <template v-if='isShow'>
<ul class="popup-result-scroll"> <li v-for='item in resultList' :key="item">{{item}}</li>
<template v-if="isShow"> </template>
<li <li v-else>计算结果中...</li>
v-for="item in resultList" </ul>
:key="item" </div>
>
{{ item }}
</li>
</template>
<li v-else>
计算结果中...
</li>
</ul>
</div>
</template> </template>
<script setup> <script setup>

View File

@@ -1,75 +1,36 @@
<template> <template>
<el-form> <el-form>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="1">
v-model="radioValue" 允许的通配符[, - * /]
:label="1" </el-radio>
> </el-form-item>
允许的通配符[, - * /]
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="2">
v-model="radioValue" 周期从
:label="2" <el-input-number v-model='cycle01' :min="0" :max="58" /> -
> <el-input-number v-model='cycle02' :min="cycle01 + 1" :max="59" />
周期从 </el-radio>
<el-input-number </el-form-item>
v-model="cycle01"
:min="0"
:max="58"
/> -
<el-input-number
v-model="cycle02"
:min="cycle01 + 1"
:max="59"
/>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="3">
v-model="radioValue"
:label="3" <el-input-number v-model='average01' :min="0" :max="58" /> 秒开始
> <el-input-number v-model='average02' :min="1" :max="59 - average01" /> 秒执行一次
</el-radio>
<el-input-number </el-form-item>
v-model="average01"
:min="0"
:max="58"
/> 秒开始
<el-input-number
v-model="average02"
:min="1"
:max="59 - average01"
/> 秒执行一次
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="4">
v-model="radioValue" 指定
:label="4" <el-select clearable v-model="checkboxList" placeholder="可多选" multiple :multiple-limit="10">
> <el-option v-for="item in 60" :key="item" :label="item - 1" :value="item - 1" />
指定 </el-select>
<el-select </el-radio>
v-model="checkboxList" </el-form-item>
clearable </el-form>
placeholder="可多选"
multiple
:multiple-limit="10"
>
<el-option
v-for="item in 60"
:key="item"
:label="item - 1"
:value="item - 1"
/>
</el-select>
</el-radio>
</el-form-item>
</el-form>
</template> </template>
<script setup> <script setup>

View File

@@ -1,130 +1,71 @@
<template> <template>
<el-form> <el-form>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="1">
v-model="radioValue" 允许的通配符[, - * ? / L #]
:label="1" </el-radio>
> </el-form-item>
允许的通配符[, - * ? / L #]
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="2">
v-model="radioValue" 不指定
:label="2" </el-radio>
> </el-form-item>
不指定
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="3">
v-model="radioValue" 周期从
:label="3" <el-select clearable v-model="cycle01">
> <el-option
周期从 v-for="(item,index) of weekList"
<el-select :key="index"
v-model="cycle01" :label="item.value"
clearable :value="item.key"
> :disabled="item.key === 7"
<el-option >{{item.value}}</el-option>
v-for="(item,index) of weekList" </el-select>
:key="index" -
:label="item.value" <el-select clearable v-model="cycle02">
:value="item.key" <el-option
:disabled="item.key === 7" v-for="(item,index) of weekList"
> :key="index"
{{ item.value }} :label="item.value"
</el-option> :value="item.key"
</el-select> :disabled="item.key <= cycle01"
- >{{item.value}}</el-option>
<el-select </el-select>
v-model="cycle02" </el-radio>
clearable </el-form-item>
>
<el-option
v-for="(item,index) of weekList"
:key="index"
:label="item.value"
:value="item.key"
:disabled="item.key <= cycle01"
>
{{ item.value }}
</el-option>
</el-select>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="4">
v-model="radioValue"
:label="4" <el-input-number v-model='average01' :min="1" :max="4" /> 周的
> <el-select clearable v-model="average02">
<el-option v-for="item in weekList" :key="item.key" :label="item.value" :value="item.key" />
<el-input-number </el-select>
v-model="average01" </el-radio>
:min="1" </el-form-item>
:max="4"
/> 周的
<el-select
v-model="average02"
clearable
>
<el-option
v-for="item in weekList"
:key="item.key"
:label="item.value"
:value="item.key"
/>
</el-select>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="5">
v-model="radioValue" 本月最后一个
:label="5" <el-select clearable v-model="weekday">
> <el-option v-for="item in weekList" :key="item.key" :label="item.value" :value="item.key" />
本月最后一个 </el-select>
<el-select </el-radio>
v-model="weekday" </el-form-item>
clearable
>
<el-option
v-for="item in weekList"
:key="item.key"
:label="item.value"
:value="item.key"
/>
</el-select>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio v-model='radioValue' :label="6">
v-model="radioValue" 指定
:label="6" <el-select class="multiselect" clearable v-model="checkboxList" placeholder="可多选" multiple :multiple-limit="6">
> <el-option v-for="item in weekList" :key="item.key" :label="item.value" :value="item.key" />
指定 </el-select>
<el-select </el-radio>
v-model="checkboxList" </el-form-item>
class="multiselect"
clearable </el-form>
placeholder="可多选"
multiple
:multiple-limit="6"
>
<el-option
v-for="item in weekList"
:key="item.key"
:label="item.value"
:value="item.key"
/>
</el-select>
</el-radio>
</el-form-item>
</el-form>
</template> </template>
<script setup> <script setup>

View File

@@ -1,84 +1,43 @@
<template> <template>
<el-form> <el-form>
<el-form-item> <el-form-item>
<el-radio <el-radio :label="1" v-model='radioValue'>
v-model="radioValue" 不填允许的通配符[, - * /]
:label="1" </el-radio>
> </el-form-item>
不填允许的通配符[, - * /]
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio :label="2" v-model='radioValue'>
v-model="radioValue" 每年
:label="2" </el-radio>
> </el-form-item>
每年
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio :label="3" v-model='radioValue'>
v-model="radioValue" 周期从
:label="3" <el-input-number v-model='cycle01' :min='fullYear' :max="2098"/> -
> <el-input-number v-model='cycle02' :min="cycle01 ? cycle01 + 1 : fullYear + 1" :max="2099"/>
周期从 </el-radio>
<el-input-number </el-form-item>
v-model="cycle01"
:min="fullYear"
:max="2098"
/> -
<el-input-number
v-model="cycle02"
:min="cycle01 ? cycle01 + 1 : fullYear + 1"
:max="2099"
/>
</el-radio>
</el-form-item>
<el-form-item> <el-form-item>
<el-radio <el-radio :label="4" v-model='radioValue'>
v-model="radioValue"
:label="4" <el-input-number v-model='average01' :min='fullYear' :max="2098"/> 年开始
> <el-input-number v-model='average02' :min="1" :max="2099 - average01 || fullYear"/> 年执行一次
</el-radio>
<el-input-number
v-model="average01"
:min="fullYear"
:max="2098"
/> 年开始
<el-input-number
v-model="average02"
:min="1"
:max="2099 - average01 || fullYear"
/> 年执行一次
</el-radio>
</el-form-item>
<el-form-item> </el-form-item>
<el-radio
v-model="radioValue" <el-form-item>
:label="5" <el-radio :label="5" v-model='radioValue'>
> 指定
指定 <el-select clearable v-model="checkboxList" placeholder="可多选" multiple :multiple-limit="8">
<el-select <el-option v-for="item in 9" :key="item" :value="item - 1 + fullYear" :label="item -1 + fullYear" />
v-model="checkboxList" </el-select>
clearable </el-radio>
placeholder="可多选" </el-form-item>
multiple </el-form>
:multiple-limit="8"
>
<el-option
v-for="item in 9"
:key="item"
:value="item - 1 + fullYear"
:label="item -1 + fullYear"
/>
</el-select>
</el-radio>
</el-form-item>
</el-form>
</template> </template>
<script setup> <script setup>

View File

@@ -10,14 +10,12 @@
>{{ item.label + " " }}</span> >{{ item.label + " " }}</span>
<el-tag <el-tag
v-else v-else
:key="item.value + ''"
:disable-transitions="true" :disable-transitions="true"
:key="item.value + ''"
:index="index" :index="index"
:type="getValidTagType(item.elTagType)" :type="getValidTagType(item.elTagType)"
:class="item.elTagClass" :class="item.elTagClass"
> >{{ item.label + " " }}</el-tag>
{{ item.label + " " }}
</el-tag>
</template> </template>
</template> </template>
<template v-if="unmatch && showValue"> <template v-if="unmatch && showValue">

View File

@@ -1,33 +1,15 @@
<template> <template>
<div class="editor-container"> <div class="editor-container">
<div> <div>
<el-upload <el-upload :action="uploadUrl" :before-upload="handleBeforeUpload" :on-success="handleUploadSuccess"
v-if="type == 'url'" :on-error="handleUploadError" name="file" :show-file-list="false" :headers="headers" class="editor-img-uploader"
:action="uploadUrl" v-if="type == 'url'">
:before-upload="handleBeforeUpload" <i ref="uploadRef" class="editor-img-uploader"></i>
:on-success="handleUploadSuccess"
:on-error="handleUploadError"
name="file"
:show-file-list="false"
:headers="headers"
class="editor-img-uploader"
>
<i
ref="uploadRef"
class="editor-img-uploader"
/>
</el-upload> </el-upload>
</div> </div>
<div class="editor"> <div class="editor">
<quill-editor <quill-editor ref="quillEditorRef" :content="content" @update:content="content = $event" contentType="html"
ref="quillEditorRef" @textChange="(e) => $emit('update:modelValue', content)" :options="options" :style="styles" />
:content="content"
content-type="html"
:options="options"
:style="styles"
@update:content="content = $event"
@text-change="(e) => $emit('update:modelValue', content)"
/>
</div> </div>
</div> </div>
</template> </template>

View File

@@ -2,7 +2,6 @@
<div class="upload-file"> <div class="upload-file">
<el-upload <el-upload
multiple multiple
ref="fileUpload"
:action="uploadFileUrl" :action="uploadFileUrl"
:before-upload="handleBeforeUpload" :before-upload="handleBeforeUpload"
:file-list="fileList" :file-list="fileList"
@@ -13,52 +12,26 @@
:show-file-list="false" :show-file-list="false"
:headers="headers" :headers="headers"
class="upload-file-uploader" class="upload-file-uploader"
ref="fileUpload"
> >
<!-- 上传按钮 --> <!-- 上传按钮 -->
<el-button type="primary"> <el-button type="primary">选取文件</el-button>
选取文件
</el-button>
</el-upload> </el-upload>
<!-- 上传提示 --> <!-- 上传提示 -->
<div <div class="el-upload__tip" v-if="showTip">
v-if="showTip"
class="el-upload__tip"
>
请上传 请上传
<template v-if="fileSize"> <template v-if="fileSize"> 大小不超过 <b style="color: #f56c6c">{{ fileSize }}MB</b> </template>
大小不超过 <b style="color: #f56c6c">{{ fileSize }}MB</b> <template v-if="fileType"> 格式为 <b style="color: #f56c6c">{{ fileType.join("/") }}</b> </template>
</template>
<template v-if="fileType">
格式为 <b style="color: #f56c6c">{{ fileType.join("/") }}</b>
</template>
的文件 的文件
</div> </div>
<!-- 文件列表 --> <!-- 文件列表 -->
<transition-group <transition-group class="upload-file-list el-upload-list el-upload-list--text" name="el-fade-in-linear" tag="ul">
class="upload-file-list el-upload-list el-upload-list--text" <li :key="file.uid" class="el-upload-list__item ele-upload-list__item-content" v-for="(file, index) in fileList">
name="el-fade-in-linear" <el-link :href="`${baseUrl}${file.url}`" :underline="false" target="_blank">
tag="ul"
>
<li
v-for="(file, index) in fileList"
:key="file.uid"
class="el-upload-list__item ele-upload-list__item-content"
>
<el-link
:href="`${baseUrl}${file.url}`"
:underline="false"
target="_blank"
>
<span class="el-icon-document"> {{ getFileName(file.name) }} </span> <span class="el-icon-document"> {{ getFileName(file.name) }} </span>
</el-link> </el-link>
<div class="ele-upload-list__item-content-action"> <div class="ele-upload-list__item-content-action">
<el-link <el-link :underline="false" @click="handleDelete(index)" type="danger">删除</el-link>
:underline="false"
type="danger"
@click="handleDelete(index)"
>
删除
</el-link>
</div> </div>
</li> </li>
</transition-group> </transition-group>

View File

@@ -1,8 +1,5 @@
<template> <template>
<div <div style="padding: 0 15px;" @click="toggleClick">
style="padding: 0 15px;"
@click="toggleClick"
>
<svg <svg
:class="{'is-active':isActive}" :class="{'is-active':isActive}"
class="hamburger" class="hamburger"

View File

@@ -1,14 +1,6 @@
<template> <template>
<div <div :class="{ show: show }" class="header-search">
:class="{ show: show }" <svg-icon class-name="search-icon" icon-class="search" @click.stop="click" v-if="!show" />
class="header-search"
>
<svg-icon
v-if="!show"
class-name="search-icon"
icon-class="search"
@click.stop="click"
/>
<el-select <el-select
v-else v-else
ref="headerSearchSelectRef" ref="headerSearchSelectRef"

View File

@@ -8,24 +8,13 @@
@clear="filterIcons" @clear="filterIcons"
@input="filterIcons" @input="filterIcons"
> >
<template #suffix> <template #suffix><i class="el-icon-search el-input__icon" /></template>
<i class="el-icon-search el-input__icon" />
</template>
</el-input> </el-input>
<div class="icon-list"> <div class="icon-list">
<div class="list-container"> <div class="list-container">
<div <div v-for="(item, index) in iconList" class="icon-item-wrapper" :key="index" @click="selectedIcon(item)">
v-for="(item, index) in iconList"
:key="index"
class="icon-item-wrapper"
@click="selectedIcon(item)"
>
<div :class="['icon-item', { active: activeIcon === item }]"> <div :class="['icon-item', { active: activeIcon === item }]">
<svg-icon <svg-icon :icon-class="item" class-name="icon" style="height: 25px;width: 16px;"/>
:icon-class="item"
class-name="icon"
style="height: 25px;width: 16px;"
/>
<span>{{ item }}</span> <span>{{ item }}</span>
</div> </div>
</div> </div>

View File

@@ -1,7 +1,6 @@
<template> <template>
<div class="component-upload-image"> <div class="component-upload-image">
<el-upload <el-upload
ref="imageUpload"
multiple multiple
:action="uploadImgUrl" :action="uploadImgUrl"
list-type="picture-card" list-type="picture-card"
@@ -10,6 +9,7 @@
:limit="limit" :limit="limit"
:on-error="handleUploadError" :on-error="handleUploadError"
:on-exceed="handleExceed" :on-exceed="handleExceed"
ref="imageUpload"
:before-remove="handleDelete" :before-remove="handleDelete"
:show-file-list="true" :show-file-list="true"
:headers="headers" :headers="headers"
@@ -17,15 +17,10 @@
:on-preview="handlePictureCardPreview" :on-preview="handlePictureCardPreview"
:class="{ hide: fileList.length >= limit }" :class="{ hide: fileList.length >= limit }"
> >
<el-icon class="avatar-uploader-icon"> <el-icon class="avatar-uploader-icon"><plus /></el-icon>
<plus />
</el-icon>
</el-upload> </el-upload>
<!-- 上传提示 --> <!-- 上传提示 -->
<div <div class="el-upload__tip" v-if="showTip">
v-if="showTip"
class="el-upload__tip"
>
请上传 请上传
<template v-if="fileSize"> <template v-if="fileSize">
大小不超过 <b style="color: #f56c6c">{{ fileSize }}MB</b> 大小不超过 <b style="color: #f56c6c">{{ fileSize }}MB</b>
@@ -45,7 +40,7 @@
<img <img
:src="dialogImageUrl" :src="dialogImageUrl"
style="display: block; max-width: 100%; margin: 0 auto" style="display: block; max-width: 100%; margin: 0 auto"
> />
</el-dialog> </el-dialog>
</div> </div>
</template> </template>

View File

@@ -1,18 +1,12 @@
<template> <template>
<div class="page-container"> <div class="page-container">
<div <div v-if="$slots.header" class="page-header">
v-if="$slots.header"
class="page-header"
>
<slot name="header" /> <slot name="header" />
</div> </div>
<div class="page-content"> <div class="page-content">
<slot /> <slot />
</div> </div>
<div <div v-if="$slots.footer" class="page-footer">
v-if="$slots.footer"
class="page-footer"
>
<slot name="footer" /> <slot name="footer" />
</div> </div>
</div> </div>

View File

@@ -1,51 +1,20 @@
<template> <template>
<el-drawer <el-drawer v-model="noticeVisible" title="公告/通知" direction="rtl" size="400px" destroy-on-close>
v-model="noticeVisible" <el-empty v-if="noticeList.length === 0" description="暂无公告/通知" />
title="公告/通知" <div v-else class="notice-list">
direction="rtl" <div v-for="item in noticeList" :key="item.noticeId" class="notice-item" :class="{ 'is-read': isRead(item.noticeId), 'unread': !isRead(item.noticeId) }" @click="viewDetail(item)">
size="400px"
destroy-on-close
>
<el-empty
v-if="noticeList.length === 0"
description="暂无公告/通知"
/>
<div
v-else
class="notice-list"
>
<div
v-for="item in noticeList"
:key="item.noticeId"
class="notice-item"
:class="{ 'is-read': isRead(item.noticeId), 'unread': !isRead(item.noticeId) }"
@click="viewDetail(item)"
>
<div class="notice-title"> <div class="notice-title">
<span <span v-if="!isRead(item.noticeId)" class="unread-dot"></span>
v-if="!isRead(item.noticeId)"
class="unread-dot"
/>
{{ item.noticeTitle }} {{ item.noticeTitle }}
</div> </div>
<div class="notice-info"> <div class="notice-info">
<span class="notice-type"> <span class="notice-type">
<el-tag <el-tag :type="getNoticeTypeTagType(item.noticeType)" size="small">
:type="getNoticeTypeTagType(item.noticeType)"
size="small"
>
{{ getNoticeTypeText(item.noticeType) }} {{ getNoticeTypeText(item.noticeType) }}
</el-tag> </el-tag>
</span> </span>
<span <span class="notice-priority" v-if="item.priority">
v-if="item.priority" <el-tag :type="getPriorityTagType(item.priority)" size="small" effect="plain">
class="notice-priority"
>
<el-tag
:type="getPriorityTagType(item.priority)"
size="small"
effect="plain"
>
{{ getPriorityText(item.priority) }} {{ getPriorityText(item.priority) }}
</el-tag> </el-tag>
</span> </span>
@@ -55,41 +24,23 @@
</div> </div>
<!-- 公告/通知详情对话框 --> <!-- 公告/通知详情对话框 -->
<el-dialog <el-dialog v-model="detailVisible" :title="currentNotice.noticeTitle" width="800px" append-to-body>
v-model="detailVisible"
:title="currentNotice.noticeTitle"
width="800px"
append-to-body
>
<div class="notice-detail"> <div class="notice-detail">
<div class="detail-header"> <div class="detail-header">
<div class="detail-type"> <div class="detail-type">
<el-tag <el-tag :type="getNoticeTypeTagType(currentNotice.noticeType)" size="small">
:type="getNoticeTypeTagType(currentNotice.noticeType)"
size="small"
>
{{ getNoticeTypeText(currentNotice.noticeType) }} {{ getNoticeTypeText(currentNotice.noticeType) }}
</el-tag> </el-tag>
<el-tag <el-tag :type="getPriorityTagType(currentNotice.priority)" size="small" effect="plain" style="margin-left: 8px;">
:type="getPriorityTagType(currentNotice.priority)"
size="small"
effect="plain"
style="margin-left: 8px;"
>
{{ getPriorityText(currentNotice.priority) }} {{ getPriorityText(currentNotice.priority) }}
</el-tag> </el-tag>
</div> </div>
<span class="detail-time">{{ parseTime(currentNotice.createTime, '{y}-{m}-{d} {h}:{i}') }}</span> <span class="detail-time">{{ parseTime(currentNotice.createTime, '{y}-{m}-{d} {h}:{i}') }}</span>
</div> </div>
<div <div class="detail-content" v-html="currentNotice.noticeContent"></div>
class="detail-content"
v-html="currentNotice.noticeContent"
/>
</div> </div>
<template #footer> <template #footer>
<el-button @click="detailVisible = false"> <el-button @click="detailVisible = false">关闭</el-button>
关闭
</el-button>
</template> </template>
</el-dialog> </el-dialog>
</el-drawer> </el-drawer>

View File

@@ -13,12 +13,7 @@
<div class="notice-list"> <div class="notice-list">
<div class="notice-list-header"> <div class="notice-list-header">
<span class="notice-list-title">公告列表</span> <span class="notice-list-title">公告列表</span>
<el-button <el-button text type="primary" @click="markAllAsRead" v-if="unreadCount > 0">
v-if="unreadCount > 0"
text
type="primary"
@click="markAllAsRead"
>
全部标记为已读 全部标记为已读
</el-button> </el-button>
</div> </div>
@@ -31,10 +26,7 @@
@click="handleSelectNotice(notice)" @click="handleSelectNotice(notice)"
> >
<div class="notice-item-left"> <div class="notice-item-left">
<el-icon <el-icon class="notice-type-icon" :class="getNoticeTypeClass(notice.noticeType)">
class="notice-type-icon"
:class="getNoticeTypeClass(notice.noticeType)"
>
<component :is="getNoticeTypeIcon(notice.noticeType)" /> <component :is="getNoticeTypeIcon(notice.noticeType)" />
</el-icon> </el-icon>
<div class="notice-item-content"> <div class="notice-item-content">
@@ -47,14 +39,7 @@
{{ getPriorityText(notice.priority) }} {{ getPriorityText(notice.priority) }}
</el-tag> </el-tag>
<span class="notice-title-text">{{ notice.noticeTitle }}</span> <span class="notice-title-text">{{ notice.noticeTitle }}</span>
<el-tag <el-tag v-if="!notice.isRead" type="danger" size="small" effect="dark">未读</el-tag>
v-if="!notice.isRead"
type="danger"
size="small"
effect="dark"
>
未读
</el-tag>
</div> </div>
<div class="notice-meta"> <div class="notice-meta">
<span class="notice-date">{{ formatDate(notice.createTime) }}</span> <span class="notice-date">{{ formatDate(notice.createTime) }}</span>
@@ -62,77 +47,45 @@
</div> </div>
</div> </div>
</div> </div>
<el-icon <el-icon class="arrow-icon" v-if="activeNoticeId === notice.noticeId">
v-if="activeNoticeId === notice.noticeId"
class="arrow-icon"
>
<ArrowRight /> <ArrowRight />
</el-icon> </el-icon>
</div> </div>
<!-- 空状态 --> <!-- 空状态 -->
<div <div v-if="noticeList.length === 0" class="empty-state">
v-if="noticeList.length === 0" <el-empty description="暂无公告" :image-size="100" />
class="empty-state"
>
<el-empty
description="暂无公告"
:image-size="100"
/>
</div> </div>
</el-scrollbar> </el-scrollbar>
</div> </div>
<!-- 公告详情 --> <!-- 公告详情 -->
<div <div class="notice-detail" v-if="activeNotice">
v-if="activeNotice"
class="notice-detail"
>
<div class="notice-detail-header"> <div class="notice-detail-header">
<h3 class="notice-detail-title"> <h3 class="notice-detail-title">{{ activeNotice.noticeTitle }}</h3>
{{ activeNotice.noticeTitle }}
</h3>
<div class="notice-detail-meta"> <div class="notice-detail-meta">
<el-tag <el-tag :type="getPriorityTagType(activeNotice.priority)" size="small" effect="dark">
:type="getPriorityTagType(activeNotice.priority)"
size="small"
effect="dark"
>
{{ getPriorityText(activeNotice.priority) }} {{ getPriorityText(activeNotice.priority) }}
</el-tag> </el-tag>
<el-tag <el-tag :type="getNoticeTypeTagType(activeNotice.noticeType)" size="small">
:type="getNoticeTypeTagType(activeNotice.noticeType)"
size="small"
>
{{ getNoticeTypeText(activeNotice.noticeType) }} {{ getNoticeTypeText(activeNotice.noticeType) }}
</el-tag> </el-tag>
<span class="notice-detail-date">{{ formatFullDate(activeNotice.createTime) }}</span> <span class="notice-detail-date">{{ formatFullDate(activeNotice.createTime) }}</span>
</div> </div>
</div> </div>
<el-divider /> <el-divider />
<div <div class="notice-detail-body" v-html="activeNotice.noticeContent"></div>
class="notice-detail-body"
v-html="activeNotice.noticeContent"
/>
</div> </div>
<!-- 未选择状态 --> <!-- 未选择状态 -->
<div <div v-else class="no-selection">
v-else <el-empty description="请选择公告查看详情" :image-size="120" />
class="no-selection"
>
<el-empty
description="请选择公告查看详情"
:image-size="120"
/>
</div> </div>
</div> </div>
<template #footer> <template #footer>
<div class="dialog-footer"> <div class="dialog-footer">
<el-button @click="handleClose"> <el-button @click="handleClose">关闭</el-button>
关闭
</el-button>
</div> </div>
</template> </template>
</el-dialog> </el-dialog>

View File

@@ -21,10 +21,7 @@
@click="handleSelectNotice(notice)" @click="handleSelectNotice(notice)"
> >
<div class="notice-item-left"> <div class="notice-item-left">
<el-icon <el-icon class="notice-type-icon" :class="getNoticeTypeClass(notice.noticeType)">
class="notice-type-icon"
:class="getNoticeTypeClass(notice.noticeType)"
>
<component :is="getNoticeTypeIcon(notice.noticeType)" /> <component :is="getNoticeTypeIcon(notice.noticeType)" />
</el-icon> </el-icon>
<div class="notice-item-content"> <div class="notice-item-content">
@@ -37,14 +34,7 @@
{{ getPriorityText(notice.priority) }} {{ getPriorityText(notice.priority) }}
</el-tag> </el-tag>
<span class="notice-title-text">{{ notice.noticeTitle }}</span> <span class="notice-title-text">{{ notice.noticeTitle }}</span>
<el-tag <el-tag v-if="!notice.isRead" type="danger" size="small" effect="dark">未读</el-tag>
v-if="!notice.isRead"
type="danger"
size="small"
effect="dark"
>
未读
</el-tag>
</div> </div>
<div class="notice-meta"> <div class="notice-meta">
<span class="notice-date">{{ formatDate(notice.createTime) }}</span> <span class="notice-date">{{ formatDate(notice.createTime) }}</span>
@@ -52,10 +42,7 @@
</div> </div>
</div> </div>
</div> </div>
<el-icon <el-icon class="arrow-icon" v-if="activeNoticeId === notice.noticeId">
v-if="activeNoticeId === notice.noticeId"
class="arrow-icon"
>
<ArrowRight /> <ArrowRight />
</el-icon> </el-icon>
</div> </div>
@@ -63,63 +50,35 @@
</div> </div>
<!-- 公告详情 --> <!-- 公告详情 -->
<div <div class="notice-detail" v-if="activeNotice">
v-if="activeNotice"
class="notice-detail"
>
<div class="notice-detail-header"> <div class="notice-detail-header">
<h3 class="notice-detail-title"> <h3 class="notice-detail-title">{{ activeNotice.noticeTitle }}</h3>
{{ activeNotice.noticeTitle }}
</h3>
<div class="notice-detail-meta"> <div class="notice-detail-meta">
<el-tag <el-tag :type="getPriorityTagType(activeNotice.priority)" size="small" effect="dark">
:type="getPriorityTagType(activeNotice.priority)"
size="small"
effect="dark"
>
{{ getPriorityText(activeNotice.priority) }} {{ getPriorityText(activeNotice.priority) }}
</el-tag> </el-tag>
<el-tag <el-tag :type="getNoticeTypeTagType(activeNotice.noticeType)" size="small">
:type="getNoticeTypeTagType(activeNotice.noticeType)"
size="small"
>
{{ getNoticeTypeText(activeNotice.noticeType) }} {{ getNoticeTypeText(activeNotice.noticeType) }}
</el-tag> </el-tag>
<span class="notice-detail-date">{{ formatDate(activeNotice.createTime) }}</span> <span class="notice-detail-date">{{ formatDate(activeNotice.createTime) }}</span>
</div> </div>
</div> </div>
<el-divider /> <el-divider />
<div <div class="notice-detail-body" v-html="activeNotice.noticeContent"></div>
class="notice-detail-body"
v-html="activeNotice.noticeContent"
/>
</div> </div>
<!-- 空状态 --> <!-- 空状态 -->
<div <div v-else class="empty-state">
v-else <el-empty description="暂无公告" :image-size="120" />
class="empty-state"
>
<el-empty
description="暂无公告"
:image-size="120"
/>
</div> </div>
</div> </div>
<template #footer> <template #footer>
<div class="dialog-footer"> <div class="dialog-footer">
<el-button <el-button @click="markAllAsRead" v-if="unreadCount > 0" type="info">
v-if="unreadCount > 0"
type="info"
@click="markAllAsRead"
>
全部标记为已读 全部标记为已读
</el-button> </el-button>
<el-button <el-button type="primary" @click="handleClose">
type="primary"
@click="handleClose"
>
{{ hasUnread ? '稍后再看' : '知道了' }} {{ hasUnread ? '稍后再看' : '知道了' }}
</el-button> </el-button>
</div> </div>

View File

@@ -1,9 +1,6 @@
<template> <template>
<div> <div>
<svg-icon <svg-icon icon-class="question" @click="goto" />
icon-class="question"
@click="goto"
/>
</div> </div>
</template> </template>

View File

@@ -1,7 +1,7 @@
<template> <template>
<el-dialog <el-dialog
v-model="props.openDialog"
title="药品追溯码" title="药品追溯码"
v-model="props.openDialog"
width="842" width="842"
append-to-body append-to-body
destroy-on-close destroy-on-close
@@ -15,15 +15,13 @@
> >
<div> <div>
<div style="font-size: 16px"> <div style="font-size: 16px">
<div style="margin-bottom: 15px"> <div style="margin-bottom: 15px">药品名称 {{ props.ypName }}</div>
药品名称 {{ props.ypName }}
</div>
扫描追溯码 扫描追溯码
<el-input <el-input
ref="traceNoTempRef" ref="traceNoTempRef"
v-model="traceNoTemp"
type="textarea" type="textarea"
:rows="1" :rows="1"
v-model="traceNoTemp"
style="width: 180px; margin-right: 20px" style="width: 180px; margin-right: 20px"
@input="throttledGetList(traceNoTemp)" @input="throttledGetList(traceNoTemp)"
/> />
@@ -33,22 +31,8 @@
style="width: 180px; margin-right: 20px" style="width: 180px; margin-right: 20px"
@keyup.enter="handelTraceNo(traceNoInput)" @keyup.enter="handelTraceNo(traceNoInput)"
/> />
<el-button <el-button type="primary" plain icon="CircleClose" @click="handleReturn"> 撤回 </el-button>
type="primary" <el-button type="danger" plain icon="CircleClose" @click="handleClear"> 清除 </el-button>
plain
icon="CircleClose"
@click="handleReturn"
>
撤回
</el-button>
<el-button
type="danger"
plain
icon="CircleClose"
@click="handleClear"
>
清除
</el-button>
</div> </div>
<!-- <el-input <!-- <el-input
ref="inputRef" ref="inputRef"
@@ -85,10 +69,11 @@
<span style="margin-right: 6px"> <span style="margin-right: 6px">
[{{ index + 1 }}] [{{ index + 1 }}]
<template v-if="index < 9">&nbsp;</template> <template v-if="index < 9">&nbsp;</template>
<template v-else /> <template v-else></template>
{{ item }} {{ item }}
</span> </span>
<div <div
@click="removeTraceNo(index)"
style=" style="
display: flex; display: flex;
align-items: center; align-items: center;
@@ -99,12 +84,8 @@
border-radius: 50%; border-radius: 50%;
cursor: pointer; cursor: pointer;
" "
@click="removeTraceNo(index)"
> >
<el-icon <el-icon size="10" color="white">
size="10"
color="white"
>
<Close /> <Close />
</el-icon> </el-icon>
</div> </div>
@@ -117,15 +98,8 @@
</div> </div>
<template #footer> <template #footer>
<div class="dialog-footer"> <div class="dialog-footer">
<el-button <el-button type="primary" @click="submit"> </el-button>
type="primary" <el-button @click="cancel"> </el-button>
@click="submit"
>
</el-button>
<el-button @click="cancel">
</el-button>
</div> </div>
</template> </template>
</el-dialog> </el-dialog>

View File

@@ -6,11 +6,7 @@
trigger="manual" trigger="manual"
:width="width" :width="width"
> >
<slot <slot name="popover-content" :row="row" :index="index">
name="popover-content"
:row="row"
:index="index"
>
<div>列表内容</div> <div>列表内容</div>
</slot> </slot>
<template #reference> <template #reference>

View File

@@ -1,12 +1,9 @@
<template> <template>
<div <div :class="{ 'hidden': hidden }" class="pagination-container">
:class="{ 'hidden': hidden }"
class="pagination-container"
>
<el-pagination <el-pagination
:background="background"
v-model:current-page="currentPage" v-model:current-page="currentPage"
v-model:page-size="pageSize" v-model:page-size="pageSize"
:background="background"
:layout="layout" :layout="layout"
:page-sizes="pageSizes" :page-sizes="pageSizes"
:pager-count="pagerCount" :pager-count="pagerCount"

View File

@@ -1,3 +1,3 @@
<template> <template >
<router-view /> <router-view />
</template> </template>

View File

@@ -1,69 +1,21 @@
<template> <template>
<div <div class="top-right-btn" :style="style">
class="top-right-btn"
:style="style"
>
<el-row> <el-row>
<el-tooltip <el-tooltip class="item" effect="dark" :content="showSearch ? '隐藏搜索' : '显示搜索'" placement="top" v-if="search">
v-if="search" <el-button circle icon="Search" @click="toggleSearch()" />
class="item"
effect="dark"
:content="showSearch ? '隐藏搜索' : '显示搜索'"
placement="top"
>
<el-button
circle
icon="Search"
@click="toggleSearch()"
/>
</el-tooltip> </el-tooltip>
<el-tooltip <el-tooltip class="item" effect="dark" content="刷新" placement="top">
class="item" <el-button circle icon="Refresh" @click="refresh()" />
effect="dark"
content="刷新"
placement="top"
>
<el-button
circle
icon="Refresh"
@click="refresh()"
/>
</el-tooltip> </el-tooltip>
<el-tooltip <el-tooltip class="item" effect="dark" content="显隐列" placement="top" v-if="columns">
v-if="columns" <el-button circle icon="Menu" @click="showColumn()" v-if="showColumnsType == 'transfer'"/>
class="item" <el-dropdown trigger="click" :hide-on-click="false" style="padding-left: 12px" v-if="showColumnsType == 'checkbox'">
effect="dark" <el-button circle icon="Menu" />
content="显隐列"
placement="top"
>
<el-button
v-if="showColumnsType == 'transfer'"
circle
icon="Menu"
@click="showColumn()"
/>
<el-dropdown
v-if="showColumnsType == 'checkbox'"
trigger="click"
:hide-on-click="false"
style="padding-left: 12px"
>
<el-button
circle
icon="Menu"
/>
<template #dropdown> <template #dropdown>
<el-dropdown-menu> <el-dropdown-menu>
<template <template v-for="item in columns" :key="item.key">
v-for="item in columns"
:key="item.key"
>
<el-dropdown-item> <el-dropdown-item>
<el-checkbox <el-checkbox :checked="item.visible" @change="checkboxChange($event, item.label)" :label="item.label" />
:checked="item.visible"
:label="item.label"
@change="checkboxChange($event, item.label)"
/>
</el-dropdown-item> </el-dropdown-item>
</template> </template>
</el-dropdown-menu> </el-dropdown-menu>
@@ -71,17 +23,13 @@
</el-dropdown> </el-dropdown>
</el-tooltip> </el-tooltip>
</el-row> </el-row>
<el-dialog <el-dialog :title="title" v-model="open" append-to-body>
v-model="open"
:title="title"
append-to-body
>
<el-transfer <el-transfer
v-model="value"
:titles="['显示', '隐藏']" :titles="['显示', '隐藏']"
v-model="value"
:data="columns" :data="columns"
@change="dataChange" @change="dataChange"
/> ></el-transfer>
</el-dialog> </el-dialog>
</div> </div>
</template> </template>

View File

@@ -1,9 +1,6 @@
<template> <template>
<div> <div>
<svg-icon <svg-icon :icon-class="isFullscreen ? 'exit-fullscreen' : 'fullscreen'" @click="toggle" />
:icon-class="isFullscreen ? 'exit-fullscreen' : 'fullscreen'"
@click="toggle"
/>
</div> </div>
</template> </template>

View File

@@ -1,23 +1,12 @@
<template> <template>
<div> <div>
<el-dropdown <el-dropdown trigger="click" @command="handleSetSize">
trigger="click"
@command="handleSetSize"
>
<div class="size-icon--style"> <div class="size-icon--style">
<svg-icon <svg-icon class-name="size-icon" icon-class="size" />
class-name="size-icon"
icon-class="size"
/>
</div> </div>
<template #dropdown> <template #dropdown>
<el-dropdown-menu> <el-dropdown-menu>
<el-dropdown-item <el-dropdown-item v-for="item of sizeOptions" :key="item.value" :disabled="size === item.value" :command="item.value">
v-for="item of sizeOptions"
:key="item.value"
:disabled="size === item.value"
:command="item.value"
>
{{ item.label }} {{ item.label }}
</el-dropdown-item> </el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>

View File

@@ -1,12 +1,6 @@
<template> <template>
<svg <svg :class="svgClass" aria-hidden="true">
:class="svgClass" <use :xlink:href="iconName" :fill="color" />
aria-hidden="true"
>
<use
:xlink:href="iconName"
:fill="color"
/>
</svg> </svg>
</template> </template>

View File

@@ -1,22 +1,8 @@
<template> <template>
<div <div class="table-section" v-loading="loading">
v-loading="loading" <EditableTable ref="editableTableRef" v-bind="$attrs" class="editable-table">
class="table-section" <template v-for="(_, slotName) in $slots" :key="slotName" #[slotName]="slotProps">
> <slot :name="slotName" v-bind="slotProps" />
<EditableTable
ref="editableTableRef"
v-bind="$attrs"
class="editable-table"
>
<template
v-for="(_, slotName) in $slots"
:key="slotName"
#[slotName]="slotProps"
>
<slot
:name="slotName"
v-bind="slotProps"
/>
</template> </template>
</EditableTable> </EditableTable>
</div> </div>

View File

@@ -1,18 +1,8 @@
<template> <template>
<div class="form-section"> <div class="form-section">
<FormLayout <FormLayout ref="formLayoutRef" v-bind="$attrs">
ref="formLayoutRef" <template v-for="(_, slotName) in $slots" :key="slotName" #[slotName]="slotProps">
v-bind="$attrs" <slot :name="slotName" v-bind="slotProps" />
>
<template
v-for="(_, slotName) in $slots"
:key="slotName"
#[slotName]="slotProps"
>
<slot
:name="slotName"
v-bind="slotProps"
/>
</template> </template>
</FormLayout> </FormLayout>
</div> </div>

View File

@@ -8,12 +8,7 @@
@blur="handleBlur" @blur="handleBlur"
@change="handleChange" @change="handleChange"
> >
<template <template v-if="suffix" #suffix>{{ suffix }}</template>
v-if="suffix"
#suffix
>
{{ suffix }}
</template>
</el-input> </el-input>
</template> </template>

View File

@@ -5,10 +5,7 @@
<slot /> <slot />
</div> </div>
</template> </template>
<template <template v-if="$slots.footer" #footer>
v-if="$slots.footer"
#footer
>
<slot name="footer" /> <slot name="footer" />
</template> </template>
</Layout> </Layout>

View File

@@ -2,28 +2,20 @@
<el-menu <el-menu
:default-active="activeMenu" :default-active="activeMenu"
mode="horizontal" mode="horizontal"
:ellipsis="false"
@select="handleSelect" @select="handleSelect"
:ellipsis="false"
> >
<template v-for="(item, index) in topMenus"> <template v-for="(item, index) in topMenus">
<!-- 处理有子菜单的情况 --> <!-- 处理有子菜单的情况 -->
<template v-if="item.children && item.children.length > 0 && index < visibleNumber"> <template v-if="item.children && item.children.length > 0 && index < visibleNumber">
<el-sub-menu <el-sub-menu :style="{'--theme': theme}" :index="item.path" :key="index">
:key="index"
:style="{'--theme': theme}"
:index="item.path"
>
<template #title> <template #title>
<svg-icon <svg-icon
v-if="item.meta && item.meta.icon && item.meta.icon !== '#'" v-if="item.meta && item.meta.icon && item.meta.icon !== '#'"
:icon-class="item.meta.icon" :icon-class="item.meta.icon"/>
/>
{{ item.meta.title }} {{ item.meta.title }}
</template> </template>
<template <template v-for="(child, childIndex) in item.children" :key="childIndex">
v-for="(child, childIndex) in item.children"
:key="childIndex"
>
<el-menu-item :index="item.path + '/' + (child.path || '')"> <el-menu-item :index="item.path + '/' + (child.path || '')">
{{ child.meta.title }} {{ child.meta.title }}
</el-menu-item> </el-menu-item>
@@ -32,47 +24,29 @@
</template> </template>
<!-- 处理无子菜单的情况 --> <!-- 处理无子菜单的情况 -->
<template v-else-if="index < visibleNumber"> <template v-else-if="index < visibleNumber">
<el-menu-item <el-menu-item :style="{'--theme': theme}" :index="item.path" :key="index">
:key="index"
:style="{'--theme': theme}"
:index="item.path"
>
<svg-icon <svg-icon
v-if="item.meta && item.meta.icon && item.meta.icon !== '#'" v-if="item.meta && item.meta.icon && item.meta.icon !== '#'"
:icon-class="item.meta.icon" :icon-class="item.meta.icon"/>
/>
{{ item.meta.title }} {{ item.meta.title }}
</el-menu-item> </el-menu-item>
</template> </template>
</template> </template>
<!-- 顶部菜单超出数量折叠 --> <!-- 顶部菜单超出数量折叠 -->
<el-sub-menu <el-sub-menu :style="{'--theme': theme}" index="more" v-if="topMenus.length > visibleNumber">
v-if="topMenus.length > visibleNumber" <template #title>更多菜单</template>
:style="{'--theme': theme}" <template v-for="(item, index) in topMenus" :key="index">
index="more"
>
<template #title>
更多菜单
</template>
<template
v-for="(item, index) in topMenus"
:key="index"
>
<!-- 处理有子菜单的情况 --> <!-- 处理有子菜单的情况 -->
<template v-if="item.children && item.children.length > 0 && index >= visibleNumber"> <template v-if="item.children && item.children.length > 0 && index >= visibleNumber">
<el-sub-menu :index="item.path"> <el-sub-menu :index="item.path">
<template #title> <template #title>
<svg-icon <svg-icon
v-if="item.meta && item.meta.icon && item.meta.icon !== '#'" v-if="item.meta && item.meta.icon && item.meta.icon !== '#'"
:icon-class="item.meta.icon" :icon-class="item.meta.icon"/>
/>
{{ item.meta.title }} {{ item.meta.title }}
</template> </template>
<template <template v-for="(child, childIndex) in item.children" :key="childIndex">
v-for="(child, childIndex) in item.children"
:key="childIndex"
>
<el-menu-item :index="item.path + '/' + (child.path || '')"> <el-menu-item :index="item.path + '/' + (child.path || '')">
{{ child.meta.title }} {{ child.meta.title }}
</el-menu-item> </el-menu-item>
@@ -83,9 +57,8 @@
<template v-else-if="index >= visibleNumber"> <template v-else-if="index >= visibleNumber">
<el-menu-item :index="item.path"> <el-menu-item :index="item.path">
<svg-icon <svg-icon
v-if="item.meta && item.meta.icon && item.meta.icon !== '#'" v-if="item.meta && item.meta.icon && item.meta.icon !== '#'"
:icon-class="item.meta.icon" :icon-class="item.meta.icon"/>
/>
{{ item.meta.title }} {{ item.meta.title }}
</el-menu-item> </el-menu-item>
</template> </template>

View File

@@ -1,19 +1,16 @@
<template> <template>
<div class="el-tree-select"> <div class="el-tree-select">
<el-select <el-select
ref="treeSelect"
v-model="valueId"
style="width: 100%" style="width: 100%"
v-model="valueId"
ref="treeSelect"
:filterable="true" :filterable="true"
:clearable="true" :clearable="true"
@clear="clearHandle"
:filter-method="selectFilterData" :filter-method="selectFilterData"
:placeholder="placeholder" :placeholder="placeholder"
@clear="clearHandle"
> >
<el-option <el-option :value="valueId" :label="valueTitle">
:value="valueId"
:label="valueTitle"
>
<el-tree <el-tree
id="tree-option" id="tree-option"
ref="selectTree" ref="selectTree"
@@ -25,7 +22,7 @@
:default-expanded-keys="defaultExpandedKey" :default-expanded-keys="defaultExpandedKey"
:filter-node-method="filterNode" :filter-node-method="filterNode"
@node-click="handleNodeClick" @node-click="handleNodeClick"
/> ></el-tree>
</el-option> </el-option>
</el-select> </el-select>
</div> </div>

Some files were not shown because too many files have changed in this diff Show More