postdischarge-ui/src/views/manage/newSigning/index.vue
2024-04-16 14:55:41 +08:00

355 lines
16 KiB
Vue

<template>
<div class="app-container">
<div class="header">
<div class="btns">
<el-button @click="goback">取消</el-button>
<el-button type="primary" @click="signupload">签约</el-button>
</div>
<el-descriptions title="签约详情" class="descriptions">
</el-descriptions>
<el-descriptions title="患者信息" style="padding:0 30px">
<el-descriptions-item label="患者姓名">{{ $route.query.patientName }}</el-descriptions-item>
<el-descriptions-item label="性别">{{ $route.query.sex == 'MALE' ? '男' : '' }}{{
$route.query.sex == 'FEMALE' ? '女' : '' }}</el-descriptions-item>
<!-- <el-descriptions-item label="年龄">{{ $route.query.age }}</el-descriptions-item> -->
<el-descriptions-item label="电话">{{ $route.query.patientPhone }}</el-descriptions-item>
<el-descriptions-item label="就诊方式">{{
$route.query.visitMethod == 'OUTPATIENT_SERVICE' ? '门诊' : $route.query.visitMethod ==
'BE_IN_HOSPITAL' ?
'住院' : ''
}}
</el-descriptions-item>
<el-descriptions-item label="诊断">{{ $route.query.signDiagnosis }}</el-descriptions-item>
<el-descriptions-item label="住院/门诊号">{{ $route.query.inHospitalNumber }}</el-descriptions-item>
<el-descriptions-item label="医院">{{ $route.query.hospitalAgencyName }}</el-descriptions-item>
<el-descriptions-item label="科室">{{ $route.query.departmentName }}</el-descriptions-item>
<!-- <el-descriptions-item label="出院/门诊时间">{{ $route.query.patientName }}</el-descriptions-item> -->
<!-- <el-descriptions-item label="注册时间">{{ $route.query.patientName }}</el-descriptions-item> -->
</el-descriptions>
<el-descriptions title="健康管理师信息" style="padding:20px 30px 10px" class="descriptions">
</el-descriptions>
<el-form :model="form" :rules="rules" ref="form" label-width="110px" class="demo-ruleForm" :inline="true"
style="padding-left:40px">
<el-form-item label="健康管理师" prop="healthManageId">
<el-select v-model="form.record.healthManageId" filterable placeholder="请选择健康管理师"
style="width:300px" clearable>
<el-option v-for="item in attendingPhysicianlist" :key="item.userId" :label="item.nickName"
:value="item.userId">
</el-option>
</el-select>
</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="110px" class="demo-ruleForm"
:inline="true" style="padding-left:40px">
<el-form-item label="选择服务包" prop="servicePackageId">
<el-select v-model="signPackage.servicePackageId" filterable placeholder="请选择服务包" clearable
@change="tappackage">
<el-option v-for="item in packagelist" :key="item.id" :label="item.packageName"
:value="item.id">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="服务包缴费状态" prop="packagePaymentStatus" label-width="130px">
<el-select v-model="signPackage.packagePaymentStatus" filterable placeholder="请选择服务包" clearable>
<el-option label="已缴费" value="PAID">
</el-option>
<el-option label="未缴费" value="UNPAID_FEES">
</el-option>
</el-select>
</el-form-item>
</el-form>
<el-form :model="signPackage" :rules="rules" ref="signPackage" label-width="80px" class="demo-ruleForm"
:inline="true" style="padding-left:40px">
<el-form-item label="签约期限" prop="" label-width="110px">
<div>
<el-input v-model="signPackage.packageTerm" style="width:130px" disabled
placeholder="请输入签约周期"></el-input>
<el-select v-model="signPackage.packageTermUnit" style="width:110px" placeholder="周期单位"
disabled>
<el-option label="年" value="年">年</el-option>
<el-option label="月" value="月">月</el-option>
<el-option label="日" value="日">日</el-option>
</el-select>
</div>
</el-form-item>
<el-form-item label="服务时长" prop="packageName">
<el-date-picker v-model="signPackage.serviceStartTime" type="date" disabled placeholder="开始日期"
style="width:150px">
</el-date-picker>
<el-input v-model="signPackage.serviceEndTime" style="width:150px" disabled
placeholder="结束日期"></el-input>
</el-form-item>
<el-form-item label="服务包价格(元)" prop="" label-width="120px">
<el-input v-model="signPackage.packagePrice" style="width:150px" disabled
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="route" :rules="rules" ref="route" label-width="110px" class="demo-ruleForm" :inline="true"
style="padding-left:40px">
<el-form-item label="专病管理路径" prop="routeId">
<specialDiseaseRoute @on-template="ontemplate" v-if="signPackage.servicePackageId">
</specialDiseaseRoute>
<el-button size="small" @click="noservicePackageId" v-else
style="width: 200px;font-size:14px;color:#C0C4CC;text-align:left">
请选择专病管理路径</el-button>
</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="110px" class="demo-ruleForm" :inline="true"
style="padding-left:40px">
<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:208px">
<el-option v-for="dict in dict.type.hardware_type" :key="dict.value" :label="dict.label"
:value="dict.value" />
</el-select>
</el-form-item>
<el-form-item label="SN码" :prop="`devices[${index}].snCode`" :rules="rules.devices.snCode">
<el-input v-model="item.snCode" placeholder="请输入设备SN码"></el-input>
</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>
<el-upload :action="upload.url" list-type="picture-card" style="margin-left:70px" :data="upload.data"
ref="upload" :on-preview="handlePictureCardPreview" :on-remove="handleRemove" :headers="upload.headers"
:on-success="handleSuccess" :auto-upload="false">
<i class="el-icon-plus"></i>
</el-upload>
</div>
</div>
</template>
<script>
import {
addsign
} from '@/api/manage/newSigning.js'
import {
servicepackageinfo
} from '@/api/manage/signRecord.js'
import { getToken } from '@/utils/auth'
import { obtainendtime } from "@/utils/obtainendtime";
import specialDiseaseRoute from '../components/specialDiseaseRoute'
import { usergetList } from "@/api/unitconfig/patientConfiguration";
export default {
components: { specialDiseaseRoute },
dicts: ['hardware_type'],
name: "newSigning",
data() {
return {
signPackage: {
packageName: undefined,
packagePrice: undefined,
serviceCycle: undefined,
serviceStartTime: undefined,
serviceEndTime: '',
packagePaymentStatus: '',
},
route: {
routeId: undefined,
routeName: ''
},
form: {
signCategory: 'sign',
record: {
patientId: undefined,
patientPhone: undefined,
healthManageId: "",
healthManageName: ""
},
devices: [
{
snCode: undefined,
hardwareType: undefined,
}
],
informeds: []
},
rules: {
packagePaymentStatus: [
{ required: true, message: '缴费状态不能为空', trigger: 'change' }
],
servicePackageId: [
{ required: true, message: '请选择服务包', trigger: 'change' }
],
routeId: [
{ required: true, message: '请选择专病管理路径', trigger: 'change' }
],
devices: {
snCode: [
{ required: true, message: '请输入SN码', trigger: 'change' }
],
hardwareType: [
{ required: true, message: '请选择硬件类型', trigger: 'change' }
],
},
},
upload: {
data: {
type: 'signInformedFileUrl'
},
headers: {
Authorization: 'Bearer ' + getToken(),
},
url: process.env.VUE_APP_BASE_API + '/manage/file/uploadFile'
},
packagelist: [],
attendingPhysicianlist: [],
};
},
created() {
this.form.record = this.$route.query
this.signPackage.packagePaymentStatus = this.form.record.paymentStatus
servicepackageinfo({ departmentId: this.$route.query.departmentId }).then(res => {
this.packagelist = res.data
})
this.usergetListinfo();
},
methods: {
//主治医生
usergetListinfo() {
usergetList({
agencyId: this.$route.query.hospitalAgencyId,
postName: 'HEALTH_MANAGE_MASTER'
}).then(res => {
this.attendingPhysicianlist = res.data
})
},
ontemplate(item) {
this.route.routeId = item.routeId
this.route.routeName = item.routeName
},
tappackage(id) {
let item = this.packagelist.find(e => e.id == id)
this.signPackage = { ...this.signPackage, ...item }
let datetime = new Date();
let year = datetime.getFullYear();
let month = datetime.getMonth() + 1;
let day = datetime.getDate();
month >= 1 && month <= 9 ? (month = "0" + month) : "";
day >= 0 && day <= 9 ? (day = "0" + day) : "";
this.signPackage.serviceStartTime = `${year}-${month}-${day}`
this.signPackage.serviceEndTime = obtainendtime(this.signPackage.serviceStartTime, item)
},
//签约
signupload() {
const files = this.$refs.upload.uploadFiles
if (files.length > 0) {
this.$refs.upload.submit();
} else {
this.uploadsave();
}
},
uploadsave() {
if (this.signPackage.servicePackageId && this.packagelist?.length > 0) {
this.signPackage.packageName = this.packagelist.find(e => e.id == this.signPackage.servicePackageId).packageName
}
if (this.form.record.healthManageId && this.attendingPhysicianlist?.length > 0) {
this.form.record.healthManageName = this.attendingPhysicianlist.find(e => e.userId == this.form.record.healthManageId).nickName
}
this.form.signPackage = this.signPackage
this.form.route = this.route
addsign(this.form).then(res => {
this.$confirm('签约成功, 是否返回上一页?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'success'
}).then(() => {
this.$store.dispatch('tagsView/delView', this.$route).then(({ visitedViews }) => {
this.$router.push({
path: "/patient/signRecord",
});
})
}).catch(() => {
this.$modal.msgSuccess("签约成功");
});
})
},
//文件上传完成
handleSuccess(response, file, fileList) {
this.form.informeds = []
fileList.forEach(e => {
this.form.informeds.push({
informedFilePath: e.response.imgUrl,
})
})
this.uploadsave();
},
//新增硬件
addhardware() {
this.form.devices.push({
snCode: '',
hardwareType: '',
})
},
delhardware(index) {
this.form.devices.splice(index, 1);
},
handleRemove(file, fileList) {
console.log(file, fileList);
},
handlePictureCardPreview(file) {
},
goback() {
this.$store.dispatch('tagsView/delView', this.$route).then(({ visitedViews }) => {
this.$router.push({
path: "/patient/signRecord",
});
})
},
noservicePackageId() {
this.$message.error('请先选择服务包!!');
},
}
};
</script>
<style lang="scss" scoped>
.app-container {
padding: 14px 0 0;
background-color: #F2F3F5 !important;
width: 100%;
.descriptions {
padding: 20px 20px 10px;
}
.descriptions {
::v-deep .el-descriptions-item__label.has-colon::after {
display: none;
}
}
.header {
background-color: #fff;
width: 98%;
margin: 0 auto;
border-radius: 8px;
}
.btns {
position: absolute;
top: 30px;
right: 30px;
}
.addbtn {
margin-right: 100px;
float: right;
transform: translateY(-200%);
}
}
</style>