后台书写病历相关/前端基础目录搭建
This commit is contained in:
@@ -108,6 +108,8 @@ public class MybatisPlusConfig {
|
|||||||
"cli_procedure_performer",
|
"cli_procedure_performer",
|
||||||
"doc_emr",
|
"doc_emr",
|
||||||
"doc_emr_template",
|
"doc_emr_template",
|
||||||
|
"doc_emr_detail",
|
||||||
|
"doc_emr_dict",
|
||||||
"fin_claim",
|
"fin_claim",
|
||||||
"fin_claim_response",
|
"fin_claim_response",
|
||||||
"fin_contract",
|
"fin_contract",
|
||||||
|
|||||||
@@ -0,0 +1,157 @@
|
|||||||
|
/*
|
||||||
|
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||||
|
*/
|
||||||
|
package com.openhis.web.emr.controller;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
import org.springframework.beans.BeanUtils;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson2.JSONObject;
|
||||||
|
import com.alibaba.fastjson2.TypeReference;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
|
import com.core.common.core.domain.R;
|
||||||
|
import com.openhis.document.domain.Emr;
|
||||||
|
import com.openhis.document.domain.EmrDetail;
|
||||||
|
import com.openhis.document.domain.EmrDict;
|
||||||
|
import com.openhis.document.domain.EmrTemplate;
|
||||||
|
import com.openhis.document.service.IEmrDetailService;
|
||||||
|
import com.openhis.document.service.IEmrDictService;
|
||||||
|
import com.openhis.document.service.IEmrService;
|
||||||
|
import com.openhis.document.service.IEmrTemplateService;
|
||||||
|
import com.openhis.web.emr.dto.EmrTemplateDto;
|
||||||
|
import com.openhis.web.emr.dto.PatientEmrDto;
|
||||||
|
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历controller
|
||||||
|
*
|
||||||
|
* @author ZhangYC
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/doc-emr")
|
||||||
|
@Slf4j
|
||||||
|
public class PatientEmrController {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private IEmrService emrService;
|
||||||
|
@Autowired
|
||||||
|
private IEmrTemplateService emrTemplateService;
|
||||||
|
@Autowired
|
||||||
|
private IEmrDetailService emrDetailService;
|
||||||
|
@Autowired
|
||||||
|
private IEmrDictService emrDictService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 添加病人病历信息
|
||||||
|
*
|
||||||
|
* @param patientEmrDto 电子病历信息dto
|
||||||
|
* @return 操作结果
|
||||||
|
*/
|
||||||
|
@PostMapping("/emr")
|
||||||
|
public R<?> addPatientEmr(@Validated @RequestBody PatientEmrDto patientEmrDto) {
|
||||||
|
Emr emr = new Emr();
|
||||||
|
BeanUtils.copyProperties(patientEmrDto, emr);
|
||||||
|
String contextStr = patientEmrDto.getContextJson().toString();
|
||||||
|
boolean saveSuccess = emrService.save(emr.setContextJson(contextStr));
|
||||||
|
if (!saveSuccess) {
|
||||||
|
return R.fail();
|
||||||
|
}
|
||||||
|
// 获取电子病历字典表中全部key,用来判断病历JSON串中是否有需要加入到病历详情表的字段
|
||||||
|
List<String> emrDictList = emrDictService.list(new LambdaQueryWrapper<EmrDict>().select(EmrDict::getEmrKey))
|
||||||
|
.stream().map(EmrDict::getEmrKey).collect(Collectors.toList());
|
||||||
|
Map<String, String> emrContextMap =
|
||||||
|
JSONObject.parseObject(contextStr, new TypeReference<Map<String, String>>() {});
|
||||||
|
List<EmrDetail> emrDetailList = new ArrayList<>();
|
||||||
|
// 遍历病历内容map
|
||||||
|
for (Map.Entry<String, String> entry : emrContextMap.entrySet()) {
|
||||||
|
EmrDetail emrDetail = new EmrDetail();
|
||||||
|
emrDetail.setEmrId(emr.getId());
|
||||||
|
if (!emrDictList.isEmpty() && emrDictList.contains(entry.getKey())) {
|
||||||
|
emrDetail.setEmrKey(entry.getKey());
|
||||||
|
emrDetail.setEmrValue(entry.getValue());
|
||||||
|
}
|
||||||
|
emrDetailList.add(emrDetail);
|
||||||
|
}
|
||||||
|
boolean save = emrDetailService.saveBatch(emrDetailList);
|
||||||
|
return save ? R.ok() : R.fail();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取患者历史病历
|
||||||
|
*
|
||||||
|
* @param patientEmrDto 查询条件
|
||||||
|
* @param pageNo 当前页码
|
||||||
|
* @param pageSize 查询条数
|
||||||
|
* @return 分页数据列表
|
||||||
|
*/
|
||||||
|
@GetMapping("/emr-page")
|
||||||
|
public R<?> getPatientEmrHistory(PatientEmrDto patientEmrDto,
|
||||||
|
@RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo,
|
||||||
|
@RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) {
|
||||||
|
|
||||||
|
// 根据患者id 获取历史病历列表
|
||||||
|
Page<Emr> emrPage = emrService.page(new Page<>(pageNo, pageSize),
|
||||||
|
new LambdaQueryWrapper<Emr>().eq(Emr::getPatientId, patientEmrDto.getPatientId()));
|
||||||
|
|
||||||
|
return R.ok(emrPage);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 保存病历模板
|
||||||
|
*
|
||||||
|
* @param emrTemplateDto 病历模板信息
|
||||||
|
* @return 操作结果
|
||||||
|
*/
|
||||||
|
@PostMapping("emr-template")
|
||||||
|
public R<?> addEmrTemplate(@RequestBody @Validated EmrTemplateDto emrTemplateDto) {
|
||||||
|
EmrTemplate emrTemplate = new EmrTemplate();
|
||||||
|
BeanUtils.copyProperties(emrTemplateDto, emrTemplate);
|
||||||
|
return emrTemplateService.save(emrTemplate) ? R.ok() : R.fail();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取电子病历模板列表
|
||||||
|
*
|
||||||
|
* @param emrTemplateDto 查询参数
|
||||||
|
* @param pageNo 当前页码
|
||||||
|
* @param pageSize 查询条数
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@GetMapping("emr-template-page")
|
||||||
|
public R<?> getEmrTemplate(EmrTemplateDto emrTemplateDto,
|
||||||
|
@RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo,
|
||||||
|
@RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) {
|
||||||
|
|
||||||
|
LambdaQueryWrapper<EmrTemplate> queryWrapper = new LambdaQueryWrapper<>();
|
||||||
|
queryWrapper.like(EmrTemplate::getTemplateName, emrTemplateDto.getTemplateName())
|
||||||
|
.eq(EmrTemplate::getUseScopeCode, emrTemplateDto.getUseScopeCode())
|
||||||
|
.eq(EmrTemplate::getUserId, emrTemplateDto.getUserId());
|
||||||
|
Page<EmrTemplate> emrTemplatePage = emrTemplateService.page(new Page<>(pageNo, pageSize), queryWrapper);
|
||||||
|
|
||||||
|
return R.ok(emrTemplatePage);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除病历模板
|
||||||
|
*
|
||||||
|
* @param id 模板id
|
||||||
|
* @return 操作结果
|
||||||
|
*/
|
||||||
|
@DeleteMapping("emr-template")
|
||||||
|
public R<?> deleteEmrTemplate(@RequestParam Long id) {
|
||||||
|
|
||||||
|
return emrTemplateService.removeById(id) ? R.ok() : R.fail();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||||
|
*/
|
||||||
|
package com.openhis.web.emr.dto;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotBlank;
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历模板Dto
|
||||||
|
*
|
||||||
|
* @author ZhangYC
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@Accessors(chain = true)
|
||||||
|
public class EmrTemplateDto implements Serializable {
|
||||||
|
|
||||||
|
/** 模板名称 */
|
||||||
|
@NotBlank
|
||||||
|
private String templateName;
|
||||||
|
|
||||||
|
/** 模板类型 */
|
||||||
|
private String templateTypeEnum;
|
||||||
|
|
||||||
|
/** 使用范围 */
|
||||||
|
@NotBlank
|
||||||
|
private String useScopeCode;
|
||||||
|
|
||||||
|
/** 个人/科室ID */
|
||||||
|
private Long userId;
|
||||||
|
|
||||||
|
/** 病历内容 */
|
||||||
|
private String contextJson;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,43 @@
|
|||||||
|
/*
|
||||||
|
* Copyright ©2023 CJB-CNIT Team. All rights reserved
|
||||||
|
*/
|
||||||
|
package com.openhis.web.emr.dto;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson2.JSONObject;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病人电子病历信息
|
||||||
|
*
|
||||||
|
* @author ZhangYC
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Accessors(chain = true)
|
||||||
|
public class PatientEmrDto implements Serializable {
|
||||||
|
|
||||||
|
/** 患者ID */
|
||||||
|
@NotNull
|
||||||
|
private Long patientId;
|
||||||
|
|
||||||
|
/** 就诊ID */
|
||||||
|
@NotNull
|
||||||
|
private Long encounterId;
|
||||||
|
|
||||||
|
/** 病历信息 */
|
||||||
|
private JSONObject contextJson;
|
||||||
|
|
||||||
|
/** 病历状态 */
|
||||||
|
private String emrStatus;
|
||||||
|
|
||||||
|
/** 记录人 */
|
||||||
|
@NotNull
|
||||||
|
private Long recordId;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,47 @@
|
|||||||
|
package com.openhis.document.domain;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
|
||||||
|
import com.core.common.core.domain.HisBaseEntity;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历信息Entity实体
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@TableName("doc_emr")
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@EqualsAndHashCode(callSuper = false)
|
||||||
|
public class Emr extends HisBaseEntity {
|
||||||
|
|
||||||
|
/** ID */
|
||||||
|
@TableId(type = IdType.ASSIGN_ID)
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/** 患者ID */
|
||||||
|
private Long patientId;
|
||||||
|
|
||||||
|
/** 就诊ID */
|
||||||
|
private Long encounterId;
|
||||||
|
|
||||||
|
/** 病历信息 */
|
||||||
|
private String contextJson;
|
||||||
|
|
||||||
|
/** 病历状态 */
|
||||||
|
private String emrEnum;
|
||||||
|
|
||||||
|
/** 记录人 */
|
||||||
|
private Long recordId;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,40 @@
|
|||||||
|
package com.openhis.document.domain;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
|
||||||
|
import com.core.common.core.domain.HisBaseEntity;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历详情Entity实体
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@TableName("doc_emr_detail")
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@EqualsAndHashCode(callSuper = false)
|
||||||
|
public class EmrDetail extends HisBaseEntity {
|
||||||
|
|
||||||
|
/** ID */
|
||||||
|
@TableId(type = IdType.ASSIGN_ID)
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/** 病历ID */
|
||||||
|
private Long emrId;
|
||||||
|
|
||||||
|
/** 病历内容key */
|
||||||
|
private String emrKey;
|
||||||
|
|
||||||
|
/** 病历内容value */
|
||||||
|
private String emrValue;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,37 @@
|
|||||||
|
package com.openhis.document.domain;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
|
||||||
|
import com.core.common.core.domain.HisBaseEntity;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历字典Entity实体
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@TableName("doc_emr_dict")
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@EqualsAndHashCode(callSuper = false)
|
||||||
|
public class EmrDict extends HisBaseEntity {
|
||||||
|
|
||||||
|
/** ID */
|
||||||
|
@TableId(type = IdType.ASSIGN_ID)
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/** 病历内容code */
|
||||||
|
private String emrKey;
|
||||||
|
|
||||||
|
/** 病历内容value */
|
||||||
|
private String emrValue;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,46 @@
|
|||||||
|
package com.openhis.document.domain;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
|
||||||
|
import com.core.common.core.domain.HisBaseEntity;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历模板Entity实体
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@TableName("doc_emr_template")
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@EqualsAndHashCode(callSuper = false)
|
||||||
|
public class EmrTemplate extends HisBaseEntity {
|
||||||
|
|
||||||
|
/** ID */
|
||||||
|
@TableId(type = IdType.ASSIGN_ID)
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/** 模板名称 */
|
||||||
|
private String templateName;
|
||||||
|
|
||||||
|
/** 模板类型 */
|
||||||
|
private String templateCode;
|
||||||
|
|
||||||
|
/** 使用范围 */
|
||||||
|
private String useScopeCode;
|
||||||
|
|
||||||
|
/** 个人/科室ID */
|
||||||
|
private Long userId;
|
||||||
|
|
||||||
|
/** 病历内容 */
|
||||||
|
private String contextJson;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package com.openhis.document.mapper;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.openhis.document.domain.EmrDetail;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历详情Mapper接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@Repository
|
||||||
|
public interface EmrDetailMapper extends BaseMapper<EmrDetail> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package com.openhis.document.mapper;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.openhis.document.domain.EmrDict;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历字典Mapper接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@Repository
|
||||||
|
public interface EmrDictMapper extends BaseMapper<EmrDict> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package com.openhis.document.mapper;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.openhis.document.domain.Emr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历信息Mapper接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Repository
|
||||||
|
public interface EmrMapper extends BaseMapper<Emr> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package com.openhis.document.mapper;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.openhis.document.domain.EmrTemplate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历模板Mapper接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Repository
|
||||||
|
public interface EmrTemplateMapper extends BaseMapper<EmrTemplate> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,14 @@
|
|||||||
|
package com.openhis.document.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.openhis.document.domain.EmrDetail;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历详情Service接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
public interface IEmrDetailService extends IService<EmrDetail> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,14 @@
|
|||||||
|
package com.openhis.document.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.openhis.document.domain.EmrDict;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历字典Service接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
public interface IEmrDictService extends IService<EmrDict> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,14 @@
|
|||||||
|
package com.openhis.document.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.openhis.document.domain.Emr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历信息Service接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
public interface IEmrService extends IService<Emr> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,14 @@
|
|||||||
|
package com.openhis.document.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.openhis.document.domain.EmrTemplate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历模板Service接口
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
public interface IEmrTemplateService extends IService<EmrTemplate> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
package com.openhis.document.service.impl;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.openhis.document.domain.EmrDetail;
|
||||||
|
import com.openhis.document.mapper.EmrDetailMapper;
|
||||||
|
import com.openhis.document.service.IEmrDetailService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历详情Service业务层处理
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class EmrDetailServiceImpl extends ServiceImpl<EmrDetailMapper, EmrDetail> implements IEmrDetailService {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
package com.openhis.document.service.impl;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.openhis.document.domain.EmrDict;
|
||||||
|
import com.openhis.document.mapper.EmrDictMapper;
|
||||||
|
import com.openhis.document.service.IEmrDictService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 电子病历字典Service业务层处理
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-22
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class EmrDictServiceImpl extends ServiceImpl<EmrDictMapper, EmrDict> implements IEmrDictService {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
package com.openhis.document.service.impl;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.openhis.document.domain.Emr;
|
||||||
|
import com.openhis.document.mapper.EmrMapper;
|
||||||
|
import com.openhis.document.service.IEmrService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历信息Service业务层处理
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class EmrServiceImpl extends ServiceImpl<EmrMapper, Emr> implements IEmrService {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
package com.openhis.document.service.impl;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.openhis.document.domain.EmrTemplate;
|
||||||
|
import com.openhis.document.mapper.EmrTemplateMapper;
|
||||||
|
import com.openhis.document.service.IEmrTemplateService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 病历模板Service业务层处理
|
||||||
|
*
|
||||||
|
* @author system
|
||||||
|
* @date 2025-02-21
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class EmrTemplateServiceImpl extends ServiceImpl<EmrTemplateMapper, EmrTemplate> implements IEmrTemplateService {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<!DOCTYPE mapper
|
||||||
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.openhis.document.mapper.EmrDetailMapper">
|
||||||
|
|
||||||
|
</mapper>
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<!DOCTYPE mapper
|
||||||
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.openhis.document.mapper.EmrDictMapper">
|
||||||
|
|
||||||
|
</mapper>
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<!DOCTYPE mapper
|
||||||
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.openhis.document.mapper.EmrMapper">
|
||||||
|
|
||||||
|
</mapper>
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<!DOCTYPE mapper
|
||||||
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.openhis.document.mapper.EmrTemplateMapper">
|
||||||
|
|
||||||
|
</mapper>
|
||||||
@@ -1,6 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="app-container">
|
<div class="app-container">
|
||||||
<el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch">
|
<el-form
|
||||||
|
:model="queryParams"
|
||||||
|
ref="queryRef"
|
||||||
|
:inline="true"
|
||||||
|
v-show="showSearch"
|
||||||
|
>
|
||||||
<el-form-item label="字典名称" prop="dictType">
|
<el-form-item label="字典名称" prop="dictType">
|
||||||
<el-select v-model="queryParams.dictType" style="width: 200px">
|
<el-select v-model="queryParams.dictType" style="width: 200px">
|
||||||
<el-option
|
<el-option
|
||||||
@@ -21,7 +26,12 @@
|
|||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="状态" prop="status">
|
<el-form-item label="状态" prop="status">
|
||||||
<el-select v-model="queryParams.status" placeholder="数据状态" clearable style="width: 200px">
|
<el-select
|
||||||
|
v-model="queryParams.status"
|
||||||
|
placeholder="数据状态"
|
||||||
|
clearable
|
||||||
|
style="width: 200px"
|
||||||
|
>
|
||||||
<el-option
|
<el-option
|
||||||
v-for="dict in sys_normal_disable"
|
v-for="dict in sys_normal_disable"
|
||||||
:key="dict.value"
|
:key="dict.value"
|
||||||
@@ -31,7 +41,9 @@
|
|||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
|
<el-button type="primary" icon="Search" @click="handleQuery">
|
||||||
|
搜索
|
||||||
|
</el-button>
|
||||||
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
@@ -44,7 +56,9 @@
|
|||||||
icon="Plus"
|
icon="Plus"
|
||||||
@click="handleAdd"
|
@click="handleAdd"
|
||||||
v-hasPermi="['system:dict:add']"
|
v-hasPermi="['system:dict:add']"
|
||||||
>新增</el-button>
|
>
|
||||||
|
新增
|
||||||
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button
|
<el-button
|
||||||
@@ -54,7 +68,9 @@
|
|||||||
:disabled="single"
|
:disabled="single"
|
||||||
@click="handleUpdate"
|
@click="handleUpdate"
|
||||||
v-hasPermi="['system:dict:edit']"
|
v-hasPermi="['system:dict:edit']"
|
||||||
>修改</el-button>
|
>
|
||||||
|
修改
|
||||||
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button
|
<el-button
|
||||||
@@ -64,7 +80,9 @@
|
|||||||
:disabled="multiple"
|
:disabled="multiple"
|
||||||
@click="handleDelete"
|
@click="handleDelete"
|
||||||
v-hasPermi="['system:dict:remove']"
|
v-hasPermi="['system:dict:remove']"
|
||||||
>删除</el-button>
|
>
|
||||||
|
删除
|
||||||
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button
|
<el-button
|
||||||
@@ -73,26 +91,45 @@
|
|||||||
icon="Download"
|
icon="Download"
|
||||||
@click="handleExport"
|
@click="handleExport"
|
||||||
v-hasPermi="['system:dict:export']"
|
v-hasPermi="['system:dict:export']"
|
||||||
>导出</el-button>
|
>
|
||||||
|
导出
|
||||||
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button
|
<el-button type="warning" plain icon="Close" @click="handleClose">
|
||||||
type="warning"
|
关闭
|
||||||
plain
|
</el-button>
|
||||||
icon="Close"
|
|
||||||
@click="handleClose"
|
|
||||||
>关闭</el-button>
|
|
||||||
</el-col>
|
</el-col>
|
||||||
<right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
|
<right-toolbar
|
||||||
|
v-model:showSearch="showSearch"
|
||||||
|
@queryTable="getList"
|
||||||
|
></right-toolbar>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
<el-table v-loading="loading" :data="dataList" @selection-change="handleSelectionChange">
|
<el-table
|
||||||
|
v-loading="loading"
|
||||||
|
:data="dataList"
|
||||||
|
@selection-change="handleSelectionChange"
|
||||||
|
>
|
||||||
<el-table-column type="selection" width="55" align="center" />
|
<el-table-column type="selection" width="55" align="center" />
|
||||||
<el-table-column label="字典编码" align="center" prop="dictCode" />
|
<el-table-column label="字典编码" align="center" prop="dictCode" />
|
||||||
<el-table-column label="字典标签" align="center" prop="dictLabel">
|
<el-table-column label="字典标签" align="center" prop="dictLabel">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<span v-if="(scope.row.listClass == '' || scope.row.listClass == 'default') && (scope.row.cssClass == '' || scope.row.cssClass == null)">{{ scope.row.dictLabel }}</span>
|
<span
|
||||||
<el-tag v-else :type="scope.row.listClass == 'primary' ? '' : scope.row.listClass" :class="scope.row.cssClass">{{ scope.row.dictLabel }}</el-tag>
|
v-if="
|
||||||
|
(scope.row.listClass == '' || scope.row.listClass == 'default') &&
|
||||||
|
(scope.row.cssClass == '' || scope.row.cssClass == null)
|
||||||
|
"
|
||||||
|
>
|
||||||
|
{{ scope.row.dictLabel }}
|
||||||
|
</span>
|
||||||
|
<el-tag
|
||||||
|
v-else
|
||||||
|
:type="scope.row.listClass == 'primary' ? '' : scope.row.listClass"
|
||||||
|
:class="scope.row.cssClass"
|
||||||
|
>
|
||||||
|
{{ scope.row.dictLabel }}
|
||||||
|
</el-tag>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="字典键值" align="center" prop="dictValue" />
|
<el-table-column label="字典键值" align="center" prop="dictValue" />
|
||||||
@@ -102,16 +139,47 @@
|
|||||||
<dict-tag :options="sys_normal_disable" :value="scope.row.status" />
|
<dict-tag :options="sys_normal_disable" :value="scope.row.status" />
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true" />
|
<el-table-column
|
||||||
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
|
label="备注"
|
||||||
|
align="center"
|
||||||
|
prop="remark"
|
||||||
|
:show-overflow-tooltip="true"
|
||||||
|
/>
|
||||||
|
<el-table-column
|
||||||
|
label="创建时间"
|
||||||
|
align="center"
|
||||||
|
prop="createTime"
|
||||||
|
width="180"
|
||||||
|
>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<span>{{ parseTime(scope.row.createTime) }}</span>
|
<span>{{ parseTime(scope.row.createTime) }}</span>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="操作" align="center" width="160" class-name="small-padding fixed-width">
|
<el-table-column
|
||||||
|
label="操作"
|
||||||
|
align="center"
|
||||||
|
width="160"
|
||||||
|
class-name="small-padding fixed-width"
|
||||||
|
>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['system:dict:edit']">修改</el-button>
|
<el-button
|
||||||
<el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['system:dict:remove']">删除</el-button>
|
link
|
||||||
|
type="primary"
|
||||||
|
icon="Edit"
|
||||||
|
@click="handleUpdate(scope.row)"
|
||||||
|
v-hasPermi="['system:dict:edit']"
|
||||||
|
>
|
||||||
|
修改
|
||||||
|
</el-button>
|
||||||
|
<el-button
|
||||||
|
link
|
||||||
|
type="primary"
|
||||||
|
icon="Delete"
|
||||||
|
@click="handleDelete(scope.row)"
|
||||||
|
v-hasPermi="['system:dict:remove']"
|
||||||
|
>
|
||||||
|
删除
|
||||||
|
</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
@@ -140,7 +208,11 @@
|
|||||||
<el-input v-model="form.cssClass" placeholder="请输入样式属性" />
|
<el-input v-model="form.cssClass" placeholder="请输入样式属性" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="显示排序" prop="dictSort">
|
<el-form-item label="显示排序" prop="dictSort">
|
||||||
<el-input-number v-model="form.dictSort" controls-position="right" :min="0" />
|
<el-input-number
|
||||||
|
v-model="form.dictSort"
|
||||||
|
controls-position="right"
|
||||||
|
:min="0"
|
||||||
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="回显样式" prop="listClass">
|
<el-form-item label="回显样式" prop="listClass">
|
||||||
<el-select v-model="form.listClass">
|
<el-select v-model="form.listClass">
|
||||||
@@ -158,11 +230,17 @@
|
|||||||
v-for="dict in sys_normal_disable"
|
v-for="dict in sys_normal_disable"
|
||||||
:key="dict.value"
|
:key="dict.value"
|
||||||
:label="dict.value"
|
:label="dict.value"
|
||||||
>{{ dict.label }}</el-radio>
|
>
|
||||||
|
{{ dict.label }}
|
||||||
|
</el-radio>
|
||||||
</el-radio-group>
|
</el-radio-group>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="备注" prop="remark">
|
<el-form-item label="备注" prop="remark">
|
||||||
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
|
<el-input
|
||||||
|
v-model="form.remark"
|
||||||
|
type="textarea"
|
||||||
|
placeholder="请输入内容"
|
||||||
|
></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
@@ -176,9 +254,18 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup name="Data">
|
<script setup name="Data">
|
||||||
import useDictStore from '@/store/modules/dict'
|
import {
|
||||||
import { optionselect as getDictOptionselect, getType } from "@/api/system/dict/type";
|
addData,
|
||||||
import { listData, getData, delData, addData, updateData } from "@/api/system/dict/data";
|
delData,
|
||||||
|
getData,
|
||||||
|
listData,
|
||||||
|
updateData,
|
||||||
|
} from "@/api/system/dict/data";
|
||||||
|
import {
|
||||||
|
optionselect as getDictOptionselect,
|
||||||
|
getType,
|
||||||
|
} from "@/api/system/dict/type";
|
||||||
|
import useDictStore from "@/store/modules/dict";
|
||||||
|
|
||||||
const { proxy } = getCurrentInstance();
|
const { proxy } = getCurrentInstance();
|
||||||
const { sys_normal_disable } = proxy.useDict("sys_normal_disable");
|
const { sys_normal_disable } = proxy.useDict("sys_normal_disable");
|
||||||
@@ -202,7 +289,7 @@ const listClassOptions = ref([
|
|||||||
{ value: "success", label: "成功" },
|
{ value: "success", label: "成功" },
|
||||||
{ value: "info", label: "信息" },
|
{ value: "info", label: "信息" },
|
||||||
{ value: "warning", label: "警告" },
|
{ value: "warning", label: "警告" },
|
||||||
{ value: "danger", label: "危险" }
|
{ value: "danger", label: "危险" },
|
||||||
]);
|
]);
|
||||||
|
|
||||||
const data = reactive({
|
const data = reactive({
|
||||||
@@ -212,20 +299,26 @@ const data = reactive({
|
|||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
dictType: undefined,
|
dictType: undefined,
|
||||||
dictLabel: undefined,
|
dictLabel: undefined,
|
||||||
status: undefined
|
status: undefined,
|
||||||
},
|
},
|
||||||
rules: {
|
rules: {
|
||||||
dictLabel: [{ required: true, message: "数据标签不能为空", trigger: "blur" }],
|
dictLabel: [
|
||||||
dictValue: [{ required: true, message: "数据键值不能为空", trigger: "blur" }],
|
{ required: true, message: "数据标签不能为空", trigger: "blur" },
|
||||||
dictSort: [{ required: true, message: "数据顺序不能为空", trigger: "blur" }]
|
],
|
||||||
}
|
dictValue: [
|
||||||
|
{ required: true, message: "数据键值不能为空", trigger: "blur" },
|
||||||
|
],
|
||||||
|
dictSort: [
|
||||||
|
{ required: true, message: "数据顺序不能为空", trigger: "blur" },
|
||||||
|
],
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const { queryParams, form, rules } = toRefs(data);
|
const { queryParams, form, rules } = toRefs(data);
|
||||||
|
|
||||||
/** 查询字典类型详细 */
|
/** 查询字典类型详细 */
|
||||||
function getTypes(dictId) {
|
function getTypes(dictId) {
|
||||||
getType(dictId).then(response => {
|
getType(dictId).then((response) => {
|
||||||
queryParams.value.dictType = response.data.dictType;
|
queryParams.value.dictType = response.data.dictType;
|
||||||
defaultDictType.value = response.data.dictType;
|
defaultDictType.value = response.data.dictType;
|
||||||
getList();
|
getList();
|
||||||
@@ -234,14 +327,14 @@ function getTypes(dictId) {
|
|||||||
|
|
||||||
/** 查询字典类型列表 */
|
/** 查询字典类型列表 */
|
||||||
function getTypeList() {
|
function getTypeList() {
|
||||||
getDictOptionselect().then(response => {
|
getDictOptionselect().then((response) => {
|
||||||
typeOptions.value = response.data;
|
typeOptions.value = response.data;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
/** 查询字典数据列表 */
|
/** 查询字典数据列表 */
|
||||||
function getList() {
|
function getList() {
|
||||||
loading.value = true;
|
loading.value = true;
|
||||||
listData(queryParams.value).then(response => {
|
listData(queryParams.value).then((response) => {
|
||||||
dataList.value = response.rows;
|
dataList.value = response.rows;
|
||||||
total.value = response.total;
|
total.value = response.total;
|
||||||
loading.value = false;
|
loading.value = false;
|
||||||
@@ -262,7 +355,7 @@ function reset() {
|
|||||||
listClass: "default",
|
listClass: "default",
|
||||||
dictSort: 0,
|
dictSort: 0,
|
||||||
status: "0",
|
status: "0",
|
||||||
remark: undefined
|
remark: undefined,
|
||||||
};
|
};
|
||||||
proxy.resetForm("dataRef");
|
proxy.resetForm("dataRef");
|
||||||
}
|
}
|
||||||
@@ -291,7 +384,7 @@ function handleAdd() {
|
|||||||
}
|
}
|
||||||
/** 多选框选中数据 */
|
/** 多选框选中数据 */
|
||||||
function handleSelectionChange(selection) {
|
function handleSelectionChange(selection) {
|
||||||
ids.value = selection.map(item => item.dictCode);
|
ids.value = selection.map((item) => item.dictCode);
|
||||||
single.value = selection.length != 1;
|
single.value = selection.length != 1;
|
||||||
multiple.value = !selection.length;
|
multiple.value = !selection.length;
|
||||||
}
|
}
|
||||||
@@ -299,7 +392,7 @@ function handleSelectionChange(selection) {
|
|||||||
function handleUpdate(row) {
|
function handleUpdate(row) {
|
||||||
reset();
|
reset();
|
||||||
const dictCode = row.dictCode || ids.value;
|
const dictCode = row.dictCode || ids.value;
|
||||||
getData(dictCode).then(response => {
|
getData(dictCode).then((response) => {
|
||||||
form.value = response.data;
|
form.value = response.data;
|
||||||
open.value = true;
|
open.value = true;
|
||||||
title.value = "修改字典数据";
|
title.value = "修改字典数据";
|
||||||
@@ -307,17 +400,17 @@ function handleUpdate(row) {
|
|||||||
}
|
}
|
||||||
/** 提交按钮 */
|
/** 提交按钮 */
|
||||||
function submitForm() {
|
function submitForm() {
|
||||||
proxy.$refs["dataRef"].validate(valid => {
|
proxy.$refs["dataRef"].validate((valid) => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
if (form.value.dictCode != undefined) {
|
if (form.value.dictCode != undefined) {
|
||||||
updateData(form.value).then(response => {
|
updateData(form.value).then((response) => {
|
||||||
useDictStore().removeDict(queryParams.value.dictType);
|
useDictStore().removeDict(queryParams.value.dictType);
|
||||||
proxy.$modal.msgSuccess("修改成功");
|
proxy.$modal.msgSuccess("修改成功");
|
||||||
open.value = false;
|
open.value = false;
|
||||||
getList();
|
getList();
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
addData(form.value).then(response => {
|
addData(form.value).then((response) => {
|
||||||
useDictStore().removeDict(queryParams.value.dictType);
|
useDictStore().removeDict(queryParams.value.dictType);
|
||||||
proxy.$modal.msgSuccess("新增成功");
|
proxy.$modal.msgSuccess("新增成功");
|
||||||
open.value = false;
|
open.value = false;
|
||||||
@@ -330,19 +423,27 @@ function submitForm() {
|
|||||||
/** 删除按钮操作 */
|
/** 删除按钮操作 */
|
||||||
function handleDelete(row) {
|
function handleDelete(row) {
|
||||||
const dictCodes = row.dictCode || ids.value;
|
const dictCodes = row.dictCode || ids.value;
|
||||||
proxy.$modal.confirm('是否确认删除字典编码为"' + dictCodes + '"的数据项?').then(function() {
|
proxy.$modal
|
||||||
|
.confirm('是否确认删除字典编码为"' + dictCodes + '"的数据项?')
|
||||||
|
.then(function () {
|
||||||
return delData(dictCodes);
|
return delData(dictCodes);
|
||||||
}).then(() => {
|
})
|
||||||
|
.then(() => {
|
||||||
getList();
|
getList();
|
||||||
proxy.$modal.msgSuccess("删除成功");
|
proxy.$modal.msgSuccess("删除成功");
|
||||||
useDictStore().removeDict(queryParams.value.dictType);
|
useDictStore().removeDict(queryParams.value.dictType);
|
||||||
}).catch(() => {});
|
})
|
||||||
|
.catch(() => {});
|
||||||
}
|
}
|
||||||
/** 导出按钮操作 */
|
/** 导出按钮操作 */
|
||||||
function handleExport() {
|
function handleExport() {
|
||||||
proxy.download("system/dict/data/export", {
|
proxy.download(
|
||||||
...queryParams.value
|
"system/dict/data/export",
|
||||||
}, `dict_data_${new Date().getTime()}.xlsx`);
|
{
|
||||||
|
...queryParams.value,
|
||||||
|
},
|
||||||
|
`dict_data_${new Date().getTime()}.xlsx`
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
getTypes(route.params && route.params.dictId);
|
getTypes(route.params && route.params.dictId);
|
||||||
|
|||||||
1
openhis-ui/src/views/flowable/expression/index.html
Normal file
1
openhis-ui/src/views/flowable/expression/index.html
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<p>اللغة العربية</p>
|
||||||
Reference in New Issue
Block a user