2024-03-04 16:47:22 +08:00
|
|
|
<template>
|
|
|
|
|
<div class="app-container">
|
|
|
|
|
<div class="interval">
|
2024-03-05 14:23:43 +08:00
|
|
|
<div class="package-item">
|
|
|
|
|
<div class="time">{{ list.signTime }}
|
|
|
|
|
</div>
|
|
|
|
|
<div class="name">
|
|
|
|
|
{{ list.packageName }}
|
|
|
|
|
</div>
|
|
|
|
|
<el-tag v-if="list.serviceStatus == 'INTENTIONAL_SIGNING'" class="type" size="mini">意向签约</el-tag>
|
|
|
|
|
<el-tag v-if="list.serviceStatus == 'SERVICE_CENTER'" class="type" size="mini">服务中</el-tag>
|
|
|
|
|
<el-tag v-if="list.serviceStatus == 'SERVICE_END'" class="type" size="mini">服务结束</el-tag>
|
|
|
|
|
</div>
|
2024-03-04 16:47:22 +08:00
|
|
|
</div>
|
|
|
|
|
<div class="header">
|
|
|
|
|
<div class="btns">
|
2024-03-05 14:23:43 +08:00
|
|
|
<el-button @click="goback">取消</el-button>
|
2024-03-04 16:47:22 +08:00
|
|
|
<el-button type="primary" @click="signupload">签约</el-button>
|
|
|
|
|
</div>
|
|
|
|
|
<el-descriptions title="服务包续约详情" class="descriptions">
|
|
|
|
|
</el-descriptions>
|
|
|
|
|
<el-descriptions title="患者信息" style="padding:0 30px">
|
2024-03-05 14:23:43 +08:00
|
|
|
<el-descriptions-item label="患者姓名">{{ list.patientName }}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="性别">{{ list.sex == 'MALE' ? '男' : '' }}{{
|
|
|
|
|
list.sex == 'FEMALE' ? '女' : '' }}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="年龄">{{ list.age }}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="电话">{{ list.patientPhone }}</el-descriptions-item>
|
2024-03-04 16:47:22 +08:00
|
|
|
<el-descriptions-item label="就诊方式">{{
|
2024-03-05 14:23:43 +08:00
|
|
|
list.visitMethod == 'OUTPATIENT_SERVICE' ? '门诊' : list.visitMethod ==
|
|
|
|
|
'BE_IN_HOSPITAL' ?
|
|
|
|
|
'住院' : ''
|
2024-03-04 16:47:22 +08:00
|
|
|
}}
|
|
|
|
|
</el-descriptions-item>
|
2024-03-05 14:23:43 +08:00
|
|
|
<el-descriptions-item label="诊断">{{ list.signDiagnosis }}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="住院/门诊号">{{ list.inHospitalNumber }}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="医院">{{ list.hospitalAgencyName }}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="科室">{{ list.departmentName }}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="服务包缴费状态">{{ list.packagePaymentStatus == 'PAID' ? '已缴费' : '' }}
|
|
|
|
|
{{ list.packagePaymentStatus == 'UNPAID_FEES' ? '未缴费' : '' }}
|
2024-03-04 16:47:22 +08:00
|
|
|
</el-descriptions-item>
|
2024-03-05 14:23:43 +08:00
|
|
|
<!-- <el-descriptions-item label="出院/门诊时间">{{ list.patientName }}</el-descriptions-item> -->
|
|
|
|
|
<!-- <el-descriptions-item label="注册时间">{{ list.patientName }}</el-descriptions-item> -->
|
2024-03-04 16:47:22 +08:00
|
|
|
</el-descriptions>
|
2024-03-19 15:40:58 +08:00
|
|
|
<el-descriptions title="健康管理师信息" style="padding:20px 30px 10px" class="descriptions">
|
|
|
|
|
</el-descriptions>
|
|
|
|
|
<el-form :model="signPackage" :rules="rules" ref="signPackage" label-width="100px" class="demo-ruleForm"
|
|
|
|
|
:inline="true" style="padding-left:40px">
|
|
|
|
|
<el-form-item label="健康管理师" prop="healthManageId">
|
|
|
|
|
<el-input v-model="signPackage.healthManageId"></el-input>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
2024-03-04 16:47:22 +08:00
|
|
|
<el-descriptions title="服务包信息" style="padding:20px 30px 10px" class="descriptions">
|
|
|
|
|
</el-descriptions>
|
2024-03-05 14:23:43 +08:00
|
|
|
<el-form :model="signPackage" :rules="rules" ref="signPackage" label-width="100px" class="demo-ruleForm"
|
|
|
|
|
:inline="true" style="padding-left:40px">
|
2024-03-19 15:40:58 +08:00
|
|
|
<el-form-item label="选择服务包" prop="packageId">
|
|
|
|
|
<el-input v-model="signPackage.packageId"></el-input>
|
2024-03-04 16:47:22 +08:00
|
|
|
</el-form-item>
|
2024-03-05 14:23:43 +08:00
|
|
|
</el-form>
|
|
|
|
|
<el-form :model="signPackage" :rules="rules" ref="signPackage" label-width="80px" class="demo-ruleForm"
|
|
|
|
|
:inline="true" style="padding-left:40px">
|
2024-03-19 15:40:58 +08:00
|
|
|
<el-form-item label="签约期限" prop="" label-width="100px">
|
|
|
|
|
<div>
|
|
|
|
|
<el-input v-model="signPackage.packageTerm" style="width:130px"
|
|
|
|
|
placeholder="请输入签约周期"></el-input>
|
|
|
|
|
<el-select v-model="signPackage.packageTermUnit" style="width:110px" placeholder="周期单位">
|
|
|
|
|
<el-option label="年" value="年">年</el-option>
|
|
|
|
|
<el-option label="月" value="月">月</el-option>
|
|
|
|
|
<el-option label="日" value="日">日</el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</div>
|
2024-03-04 16:47:22 +08:00
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="服务时长" prop="packageName">
|
2024-03-19 15:40:58 +08:00
|
|
|
<el-date-picker v-model="signPackage.serviceStartTime" :picker-options="pickerOptions" type="date"
|
|
|
|
|
placeholder="选择日期" style="width:150px">
|
|
|
|
|
</el-date-picker>
|
2024-03-04 16:47:22 +08:00
|
|
|
至
|
2024-03-19 15:40:58 +08:00
|
|
|
<el-input v-model="signPackage.serviceEndTime" style="width:150px" disabled></el-input>
|
2024-03-04 16:47:22 +08:00
|
|
|
</el-form-item>
|
2024-03-05 14:23:43 +08:00
|
|
|
<el-form-item label="服务包价格(元)" prop="" label-width="120px">
|
2024-03-19 15:40:58 +08:00
|
|
|
<el-input v-model="signPackage.packagePrice" style="width:100px"
|
|
|
|
|
oninput="if(value.indexOf('.')>0){value=value.slice(0,value.indexOf('.')+3)} if(value.length>7){value=value.slice(0,7)}"
|
|
|
|
|
min="0" placeholder="小数点后两位(元)"></el-input>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
|
|
|
|
<el-descriptions title="专病管理信息" style="padding:20px 30px 10px" class="descriptions">
|
|
|
|
|
</el-descriptions>
|
|
|
|
|
<el-form :model="signPackage" :rules="rules" ref="signPackage" label-width="100px" class="demo-ruleForm"
|
|
|
|
|
:inline="true" style="padding-left:40px">
|
|
|
|
|
<el-form-item label="专病管理路径" prop="routeId">
|
|
|
|
|
<el-input v-model="signPackage.routeId"></el-input>
|
2024-03-04 16:47:22 +08:00
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
|
|
|
|
<el-descriptions title="硬件信息" style="padding:20px 30px 10px" class="descriptions">
|
|
|
|
|
</el-descriptions>
|
|
|
|
|
<el-form :model="form" :rules="rules" ref="form" label-width="100px" class="demo-ruleForm" :inline="true"
|
|
|
|
|
style="padding-left:40px">
|
2024-03-05 14:23:43 +08:00
|
|
|
<div v-for="(item, index) in form.devices" :key="index">
|
|
|
|
|
<el-form-item label="硬件类型" :prop="`devices[${index}].hardwareType`"
|
|
|
|
|
:rules="rules.devices.hardwareType">
|
|
|
|
|
<el-select v-model="item.hardwareType" placeholder="请选择硬件类型" clearable style="width:200px">
|
2024-03-04 16:47:22 +08:00
|
|
|
<el-option v-for="dict in dict.type.hardware_type" :key="dict.value" :label="dict.label"
|
|
|
|
|
:value="dict.value" />
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
2024-03-05 14:23:43 +08:00
|
|
|
<el-form-item label="SN码" :prop="`devices[${index}].snCode`" :rules="rules.devices.snCode">
|
|
|
|
|
<el-input v-model="item.snCode" placeholder="请输入设备SN码" style="width:200px"></el-input>
|
2024-03-04 16:47:22 +08:00
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item>
|
|
|
|
|
<el-button size="mini" @click="delhardware(index)">删除</el-button>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</div>
|
|
|
|
|
<el-button class="addbtn" type="primary" size="mini" @click="addhardware">新增硬件</el-button>
|
|
|
|
|
</el-form>
|
|
|
|
|
<el-descriptions title="知情同意书" style="padding:20px 30px 10px" class="descriptions">
|
|
|
|
|
</el-descriptions>
|
2024-03-05 14:23:43 +08:00
|
|
|
<el-upload :action="upload.url" style="margin-left:70px" :data="upload.data" ref="upload"
|
|
|
|
|
:on-preview="handlePictureCardPreview" :on-remove="handleRemove" :headers="upload.headers"
|
|
|
|
|
:on-success="handleSuccess" :auto-upload="false" list-type="picture-card">
|
2024-03-04 16:47:22 +08:00
|
|
|
<i class="el-icon-plus"></i>
|
|
|
|
|
</el-upload>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
2024-03-05 14:23:43 +08:00
|
|
|
|
2024-03-04 16:47:22 +08:00
|
|
|
<script>
|
2024-03-05 14:23:43 +08:00
|
|
|
import {
|
|
|
|
|
getByRecordId
|
|
|
|
|
} from '@/api/manage/continueSigning.js'
|
2024-03-04 16:47:22 +08:00
|
|
|
import {
|
|
|
|
|
addsign
|
|
|
|
|
} from '@/api/manage/newSigning.js'
|
2024-03-05 14:23:43 +08:00
|
|
|
import { getAge } from "@/utils/age";
|
|
|
|
|
import { getToken } from '@/utils/auth'
|
2024-03-04 16:47:22 +08:00
|
|
|
export default {
|
|
|
|
|
dicts: ['hardware_type'],
|
|
|
|
|
name: "newSigning",
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
2024-03-05 14:23:43 +08:00
|
|
|
signPackage: {
|
2024-03-19 15:40:58 +08:00
|
|
|
packageName: undefined,
|
|
|
|
|
packagePrice: undefined,
|
|
|
|
|
serviceCycle: undefined,
|
|
|
|
|
serviceStartTime: undefined,
|
|
|
|
|
serviceEndTime: '',
|
|
|
|
|
},
|
|
|
|
|
pickerOptions: {
|
|
|
|
|
disabledDate: (time) => {
|
|
|
|
|
if (this.signPackage.serviceEndTime != "") {
|
|
|
|
|
return time.getTime() > new Date(this.signPackage.serviceEndTime).getTime();
|
|
|
|
|
}
|
|
|
|
|
},
|
2024-03-05 14:23:43 +08:00
|
|
|
},
|
2024-03-19 15:40:58 +08:00
|
|
|
list: {},
|
2024-03-04 16:47:22 +08:00
|
|
|
form: {
|
2024-03-05 14:23:43 +08:00
|
|
|
record: {
|
|
|
|
|
patientId: undefined,
|
|
|
|
|
patientPhone: undefined,
|
|
|
|
|
},
|
|
|
|
|
devices: [
|
2024-03-04 16:47:22 +08:00
|
|
|
{
|
2024-03-05 14:23:43 +08:00
|
|
|
snCode: undefined,
|
|
|
|
|
hardwareType: undefined,
|
2024-03-04 16:47:22 +08:00
|
|
|
}
|
|
|
|
|
],
|
2024-03-05 14:23:43 +08:00
|
|
|
informeds: []
|
2024-03-04 16:47:22 +08:00
|
|
|
},
|
|
|
|
|
rules: {
|
2024-03-19 15:40:58 +08:00
|
|
|
packageId: [
|
2024-03-04 16:47:22 +08:00
|
|
|
{ required: true, message: '请选择服务包', trigger: 'change' }
|
|
|
|
|
],
|
2024-03-05 14:23:43 +08:00
|
|
|
devices: {
|
2024-03-04 16:47:22 +08:00
|
|
|
snCode: [
|
|
|
|
|
{ required: true, message: '请输入SN码', trigger: 'change' }
|
|
|
|
|
],
|
|
|
|
|
hardwareType: [
|
|
|
|
|
{ required: true, message: '请选择硬件类型', trigger: 'change' }
|
|
|
|
|
],
|
|
|
|
|
},
|
2024-03-05 14:23:43 +08:00
|
|
|
},
|
|
|
|
|
upload: {
|
|
|
|
|
data: {
|
|
|
|
|
type: 'signInformedFileUrl'
|
|
|
|
|
},
|
|
|
|
|
headers: {
|
|
|
|
|
Authorization: 'Bearer ' + getToken(),
|
|
|
|
|
},
|
|
|
|
|
url: process.env.VUE_APP_BASE_API + '/manage/file/uploadFile'
|
|
|
|
|
},
|
2024-03-04 16:47:22 +08:00
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
created() {
|
2024-03-05 14:23:43 +08:00
|
|
|
this.info();
|
2024-03-04 16:47:22 +08:00
|
|
|
},
|
|
|
|
|
methods: {
|
2024-03-05 14:23:43 +08:00
|
|
|
//签约详情
|
|
|
|
|
info() {
|
|
|
|
|
getByRecordId(this.$route.query.patientSignRecordId).then(res => {
|
|
|
|
|
this.list = res.data
|
|
|
|
|
this.signPackage.packageName = this.list.packageName
|
|
|
|
|
this.signPackage.serviceCycle = this.list.serviceCycle
|
|
|
|
|
this.signPackage.serviceStartTime = this.list.serviceStartTime
|
|
|
|
|
this.signPackage.serviceEndTime = this.list.serviceEndTime
|
|
|
|
|
this.signPackage.packagePrice = this.list.packagePrice
|
|
|
|
|
this.form.devices = this.list.signDevices
|
2024-03-05 15:44:20 +08:00
|
|
|
this.form.record = this.list
|
2024-03-05 14:23:43 +08:00
|
|
|
this.list.age = this.list.birthDate ? getAge(this.list.birthDate) : ''
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
//续约
|
2024-03-04 16:47:22 +08:00
|
|
|
signupload() {
|
2024-03-19 15:40:58 +08:00
|
|
|
const files = this.$refs.upload.uploadFiles
|
|
|
|
|
if (files.length > 0) {
|
|
|
|
|
this.$refs.upload.submit();
|
|
|
|
|
} else {
|
|
|
|
|
this.uploadsave();
|
|
|
|
|
}
|
|
|
|
|
console.log(this.signPackage)
|
2024-03-05 14:23:43 +08:00
|
|
|
},
|
|
|
|
|
//文件上传完成
|
|
|
|
|
handleSuccess(response, file, fileList) {
|
|
|
|
|
this.form.informeds = []
|
|
|
|
|
fileList.forEach(e => {
|
|
|
|
|
this.form.informeds.push({
|
|
|
|
|
informedFilePath: e.response.imgUrl,
|
|
|
|
|
})
|
2024-03-19 15:40:58 +08:00
|
|
|
this.uploadsave();
|
2024-03-05 14:23:43 +08:00
|
|
|
})
|
2024-03-19 15:40:58 +08:00
|
|
|
},
|
|
|
|
|
uploadsave() {
|
2024-03-05 14:23:43 +08:00
|
|
|
this.form.signPackage = this.signPackage
|
2024-03-04 16:47:22 +08:00
|
|
|
addsign(this.form).then(res => {
|
2024-03-05 14:23:43 +08:00
|
|
|
this.$confirm('签约成功, 是否返回上一页?', '提示', {
|
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
|
type: 'success'
|
|
|
|
|
}).then(() => {
|
|
|
|
|
this.$router.go(-1);
|
|
|
|
|
}).catch(() => {
|
|
|
|
|
this.$modal.msgSuccess("签约成功");
|
|
|
|
|
});
|
2024-03-04 16:47:22 +08:00
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
//新增硬件
|
|
|
|
|
addhardware() {
|
2024-03-05 14:23:43 +08:00
|
|
|
this.form.devices.push({
|
2024-03-04 16:47:22 +08:00
|
|
|
snCode: '',
|
|
|
|
|
hardwareType: '',
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
delhardware(index) {
|
2024-03-05 14:23:43 +08:00
|
|
|
this.form.devices.splice(index, 1);
|
2024-03-04 16:47:22 +08:00
|
|
|
},
|
|
|
|
|
handleRemove(file, fileList) {
|
|
|
|
|
console.log(file, fileList);
|
|
|
|
|
},
|
2024-03-05 14:23:43 +08:00
|
|
|
handlePictureCardPreview(file) { },
|
|
|
|
|
goback() {
|
|
|
|
|
this.$router.go(-1);
|
|
|
|
|
},
|
2024-03-04 16:47:22 +08:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
</script>
|
2024-03-05 14:23:43 +08:00
|
|
|
|
2024-03-04 16:47:22 +08:00
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
.app-container {
|
|
|
|
|
padding: 14px 0 0;
|
|
|
|
|
background-color: #F2F3F5 !important;
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
|
|
|
|
.descriptions {
|
|
|
|
|
padding: 20px 20px 10px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.descriptions {
|
|
|
|
|
::v-deep .el-descriptions-item__label.has-colon::after {
|
|
|
|
|
display: none;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.interval {
|
2024-03-05 14:23:43 +08:00
|
|
|
width: 20%;
|
2024-03-04 16:47:22 +08:00
|
|
|
background-color: #fff;
|
|
|
|
|
border-radius: 8px 0 0 8px;
|
|
|
|
|
border-right: 1px solid #e5e5e5;
|
2024-03-05 14:23:43 +08:00
|
|
|
|
|
|
|
|
.package-item {
|
|
|
|
|
border-left: 2px solid #1890ff;
|
|
|
|
|
background-color: #D2E9FC;
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 120px;
|
|
|
|
|
position: relative;
|
|
|
|
|
padding: 25px 14px;
|
|
|
|
|
|
|
|
|
|
.type {
|
|
|
|
|
position: absolute;
|
|
|
|
|
right: 10px;
|
|
|
|
|
top: 20px;
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.name {
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
height: 40px;
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.time {
|
|
|
|
|
line-height: 20px;
|
|
|
|
|
height: 20px;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-03-04 16:47:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.header {
|
|
|
|
|
background-color: #fff;
|
2024-03-05 14:23:43 +08:00
|
|
|
width: 78%;
|
2024-03-04 16:47:22 +08:00
|
|
|
border-radius: 0 8px 8px 0;
|
|
|
|
|
position: relative;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btns {
|
|
|
|
|
position: absolute;
|
|
|
|
|
top: 30px;
|
|
|
|
|
right: 30px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.addbtn {
|
|
|
|
|
margin-right: 100px;
|
|
|
|
|
float: right;
|
|
|
|
|
transform: translateY(-200%);
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-03-05 14:23:43 +08:00
|
|
|
</style>
|