|
|
<template> <div> <!--组件主体--> <div style="display: flex"> <div :style="'width:' + (window.pageWidth - 110 - 20) + 'px;'"> <!--查询条件--> <div style="position: absolute;top:28px;left:140px;display: flex;"> <div v-show="checkPagePriv(pagePriv.privs, '查找')"> <PatientRegisterEditQuery /> </div> <div style="display: flex;margin-left: 5px;"> <div v-show="checkPagePriv(pagePriv.privs, '读身份证')"> <el-button @click="peopleIcCard" class="commonbutton">读身份证</el-button> </div> <div style="margin-left: 5px;" v-show="checkPagePriv(pagePriv.privs, '拍照')"> <el-button type="primary" class="commonbutton" @click="photoGrah" icon="el-icon-camera">拍照</el-button> </div> </div> </div> <div> <el-form ref="form" :model="form" label-width="80px" :rules="rules" size="medium"> <el-row> <el-col :span="5"> <el-form-item label="单位名称" prop="customerOrgName"> <el-input placeholder="请选择单位" v-model="form.customerOrgName" size="small" disabled> <el-button slot="append" icon="el-icon-search" @click="dialogOrg = true" style="font-size: 20px;" :disabled="(form.completeFlag == '3' || isDoctor != '1') ? true : false"></el-button> </el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="条码号" prop="patientRegisterNo"> <el-input v-model="form.patientRegisterNo" disabled size="small"></el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="档案号" prop="patientNo"> <el-input v-model="form.patientNo" disabled size="small"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="体检次数" prop="medicalTimes"> <el-input v-model="form.medicalTimes" disabled size="small"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="性别" prop="sexId" label-width="50px"> <el-select v-model="form.sexId" placeholder="请选择" size="small" filterable :style="'width:' + Math.floor((window.pageWidth - 630) / 8) + 'px;'"> <el-option v-for="item in dict.sex" :key="item.id" :label="item.displayName" :value="item.id"> </el-option> </el-select> </el-form-item> </el-col> <el-col :span="3"> </el-col> </el-row> <el-row> <el-col :span="5"> <el-form-item label="姓名" prop="patientName"> <el-input id="patientName" v-model="form.patientName" @change="Query(form.patientName)" size="small" autocomplete="off"></el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="身份证号" prop="idNo"> <el-input v-model="form.idNo" placeholder="身份证号" @change="changeIdNo" size="small"></el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="出生日期" prop="birthDate"> <!-- <input type="date" v-model="form.birthDate" size="small" :style="'border-radius: 4px;border: 1px solid #DCDFE6;height: 32px;line-height: 32px;padding-left: 2px;width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'"/> --> <el-date-picker v-model="form.birthDate" type="date" format="yyyy-MM-dd" value-format="yyyy-MM-dd" placeholder="出生日期" :style="'width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'" @change="changeBirthDate" prefix-icon="" size="small" /> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="年龄" prop="age"> <el-input v-model="form.age" size="small" @change="changeAge"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="婚姻" prop="maritalStatusId" label-width="50px"> <el-select v-model="form.maritalStatusId" placeholder="请选择" size="small" filterable :style="'width:' + Math.floor((window.pageWidth - 630) / 8) + 'px;'"> <el-option v-for="item in dict.maritalStatus" :key="item.id" :label="item.displayName" :value="item.id"> </el-option> </el-select> </el-form-item> </el-col> <el-col :span="3" /> </el-row> <el-row> <el-col :span="5"> <el-form-item label="手机号" prop="mobileTelephone"> <el-input v-model="form.mobileTelephone" size="small"></el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="电话" prop="telephone"> <el-input v-model="form.telephone" size="small"></el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="邮箱" prop="email"> <el-input v-model="form.email" size="small"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="邮编" prop="postalCode"> <el-input v-model="form.postalCode" size="small"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="籍贯" prop="birthPlaceId" label-width="50px"> <el-select v-model="form.birthPlaceId" placeholder="请选择" filterable clearable :style="'width:' + Math.floor((window.pageWidth - 630) / 8) + 'px;'" size="small"> <el-option v-for="item in dict.birthPlace" :key="item.id" :label="item.displayName" :value="item.id" /> </el-select> </el-form-item> </el-col> <el-col :span="3" /> </el-row> <el-row> <el-col :span="10"> <el-form-item label="地址" prop="address"> <el-input v-model="form.address" size="small"></el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="人员类别" prop="personnelTypeId"> <el-select v-model="form.personnelTypeId" placeholder="请选择" filterable clearable :style="'width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'" size="small"> <el-option v-for="item in dict.personnelType" :key="item.id" :label="item.displayName" :value="item.id" /> </el-select> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="性激素期" prop="sexHormoneTermId"> <el-select v-model="form.sexHormoneTermId" placeholder="请选择" filterable clearable size="small" :disabled="isComplete"> <el-option v-for="item in dict.sexHormoneTerm" :key="item.id" :label="item.displayName" :value="item.id"> </el-option> </el-select> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="民族" prop="nationId" label-width="50px"> <el-select v-model="form.nationId" placeholder="请选择" filterable clearable default-first-option :filter-method="filterMethod" :style="'width:' + Math.floor((window.pageWidth - 630) / 8) + 'px;'" size="small"> <el-option v-for="item in nation" :key="item.id" :label="item.displayName" :value="item.id" /> </el-select> </el-form-item> </el-col> <el-col :span="3" /> </el-row> <el-row> <el-col :span="5"> <el-form-item label="体检类别" prop="medicalTypeId"> <el-select v-model="form.medicalTypeId" placeholder="请选择" filterable clearable :style="'width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'" size="small"> <el-option v-for="item in dict.medicalType" :key="item.id" :label="item.displayName" :value="item.id" /> </el-select> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="工卡号" prop="jobCardNo"> <el-input v-model="form.jobCardNo" size="small"></el-input> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="体检卡号" prop="medicalCardNo"> <el-input v-model="form.medicalCardNo" size="small"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="职务" prop="jobPost"> <el-input v-model="form.jobPost" size="small"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="职称" prop="jobTitle" label-width="50px"> <el-input v-model="form.jobTitle" size="small" :style="'width:' + Math.floor((window.pageWidth - 630) / 8) + 'px;'" /> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="介绍人" prop="salesman"> <el-input v-model="form.salesman" size="small"></el-input> </el-form-item> </el-col> </el-row> <el-row> <el-col :span="5"> <el-form-item label="体检中心" prop="medicalCenterId"> <el-select v-model="form.medicalCenterId" placeholder="请选择" filterable :disabled="peisid ? true : false" size="small" :style="'width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'"> <el-option v-for="item in dict.organization" :key="item.id" :label="item.displayName" :value="item.id"> </el-option> </el-select> </el-form-item> </el-col> <el-col :span="4"> <el-form-item label="单位体检次数" prop="isVip" label-width="110px"> <el-select :class="form.customerOrgId == dict.personOrgId ? '' : 'enterToTab'" v-model="form.customerOrgRegisterId" placeholder="次数" size="small" :disabled="form.customerOrgId == dict.personOrgId || form.completeFlag == '3'" :style="'width:' + Math.floor((window.pageWidth - 654) / 6) + 'px;'" @change="changeMedicalTimes" value-key="id"> <el-option v-for="item in customerOrgRegisterList" :key="item.id" :label="item.medicalTimes" :value="item.id" :disabled="item.isComplete == 'Y'" /> </el-select> </el-form-item> </el-col> <el-col :span="4"> <el-form-item label="门诊号" prop="hisPatientId"> <el-input v-model="form.hisPatientId" size="small" disabled /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="电话随访" prop="isPhoneFollow"> <!-- <el-radio v-model="form.isPhoneFollow" label="Y">是</el-radio> <el-radio v-model="form.isPhoneFollow" label="N">否</el-radio> --> <el-checkbox v-model="form.isPhoneFollow" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="VIP" prop="isVip" label-width="50px"> <!-- <el-radio v-model="form.isVip" label="Y">是</el-radio> <el-radio v-model="form.isVip" label="N">否</el-radio> --> <el-checkbox v-model="form.isVip" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="隐藏姓名" prop="isNameHide"> <!-- <el-radio v-model="form.isNameHide" label="Y">是</el-radio> <el-radio v-model="form.isNameHide" label="N">否</el-radio> --> <el-checkbox v-model="form.isNameHide" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="锁住" prop="isLock" label-width="50px"> <!-- <el-radio v-model="form.isLock" label="Y">是</el-radio> <el-radio v-model="form.isLock" label="N">否</el-radio> --> <el-checkbox v-model="form.isLock" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="体检开始" prop="isMedicalStart"> <el-select v-model="form.isMedicalStart" placeholder="请选择" disabled size="small"> <el-option label="是" value="Y" /> <el-option label="否" value="N" /> </el-select> </el-form-item> </el-col> </el-row> <el-row> <el-col :span="5"> <el-form-item label="分组" prop="customerOrgGroupId"> <el-select v-model="form.customerOrgGroupId" placeholder="请选择" filterable clearable @change="changeCustomerOrgGroupId" :disabled="displayGroup" :style="'width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'" size="small"> <el-option v-for="item in patientRegister.customerOrgGroup" :key="item.id" :label="item.displayName" :value="item.id" /> </el-select> </el-form-item> </el-col> <el-col :span="5"> <el-form-item label="套餐" prop="medicalPackageId"> <el-select v-model="form.medicalPackageId" placeholder="请选择" filterable clearable @change="changeMedicalPackageId" :disabled="displayPackage" :style="'width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'" size="small"> <el-option v-for="item in dict.medicalPackage" :key="item.id" :label="item.displayName" :value="item.id" /> </el-select> </el-form-item> </el-col> <el-col :span="11"> <el-form-item label="备注" prop="remark"> <el-input v-model="form.remark" type="textarea" :rows="1" placeholder="请输入备注" size="small"></el-input> </el-form-item> </el-col> <el-col :span="3"> <el-form-item label="状态" prop="completeFlag" label-width="50px"> <el-select v-model="form.completeFlag" placeholder="请选择" :disabled="(form.completeFlag == '2' || form.completeFlag == '3') ? true : false" size="small"> <div v-if="form.completeFlag == '2' || form.completeFlag == '3'"> <el-option v-for="item in dict.completeFlag" :key="item.id" :label="item.displayName" :value="item.id"> </el-option> </div> <div v-else> <el-option label="预登记" value="0" /> <el-option label="正式登记" value="1" /> </div> </el-select> </el-form-item> </el-col> </el-row> <!--青藏公司 start--> <el-row v-if="LocalConfig.patientRegister.edit == 'qztl'"> <el-col :span="4"> <el-form-item label="高原/健康"> <el-select v-model="form.qztlType" placeholder="请选择"> <el-option v-for="item in dict.qztlType" :key="item.id" :label="item.displayName" :value="item.id" /> </el-select> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="普速"> <el-checkbox v-model="form.qztlIsCw" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="从业"> <el-checkbox v-model="form.qztlIsCy" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="高铁"> <el-checkbox v-model="form.qztlIsGt" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="行车"> <el-checkbox v-model="form.qztlIsMain" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="职害"> <el-checkbox v-model="form.qztlIsWh" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="复检"> <el-checkbox v-model="form.qztlIsFj" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="导入"> <el-checkbox v-model="form.isQztlImport" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="2"> <el-form-item label="上传"> <el-checkbox v-model="form.uploadQztlFlag" true-label="Y" false-label="N" /> </el-form-item> </el-col> <el-col :span="4"> <el-form-item label="计划" prop="planuserid"> <el-input v-model="form.planuserid" size="small" /> </el-form-item> </el-col> </el-row> <!--青藏公司 end--> <el-row> <el-col :span="6"> <el-form-item label="创建人员"> <el-input v-model="form.creatorName" disabled size="small"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item label="创建时间"> <el-input :value="form.creationTime ? moment(form.creationTime).format('yyyy-MM-DD') : '' " disabled size="small"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item label="修改人员"> <el-input v-model="form.lastModifierName" disabled size="small"></el-input> </el-form-item> </el-col> <el-col :span="6"> <el-form-item label="修改时间"> <el-input :value="form.lastModificationTime ? moment(form.lastModificationTime).format('yyyy-MM-DD') : '' " disabled size="small"></el-input> </el-form-item> </el-col> </el-row> </el-form> <el-image :style="'position: absolute;top:70px;right:' + (100 + Math.floor((window.pageWidth - 680) / 24)) + 'px; width: 130px; height: 140px;'" :src="peoplePhoto"> <div slot="placeholder" class="image-slot"> 加载中<span class="dot">...</span> </div> </el-image> </div> <!--人员登记组合项目明细 register_check_asbitem--> <div> <PatientRegisterItem :prForm="form" :prAsbOpraOpts="prAsbOpraOpts" :refreshFormId="refreshFormId" /> </div> </div> <div style="margin-left: 10px;">
<div v-show="checkPagePriv(pagePriv.privs, '新增')"> <el-button type="primary" class="commonbutton" @click="btnAdd">新增</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '复制新增')" class="btn"> <el-button type="primary" class="commonbutton" @click="rdCopy">复制新增</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '保存')" class="btn"> <el-button type="success" class="commonbutton" @click="btnSubmit('form', true)">保存</el-button> </div>
<div v-show="checkPagePriv(pagePriv.privs, '检验单申请')" class="btn"> <el-button type="primary" class="commonbutton" @click="lisRequest">检验单申请</el-button> </div>
<div v-show="checkPagePriv(pagePriv.privs, '条码打印')" class="btn"> <el-button type="primary" class="commonbutton" @click="labelPrint(false)" :disabled="printing">条码打印</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '条码补打')" class="btn"> <el-button type="danger" class="commonbutton" @click="reLisRequest">条码补打</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '指引单打印')" class="btn"> <el-button type="primary" class="commonbutton" @click="guidePrint('0001', false)" :disabled="printing">指引单打印</el-button> </div> <!-- <div v-show="checkPagePriv(pagePriv.privs, '指引单预览')" class="btn"> <el-button type="primary" class="commonbutton" @click="guidePrint('0001', true)">指引单预览</el-button> </div> --> <div v-show="checkPagePriv(pagePriv.privs, '手动合并项目')" class="btn"> <el-button type="danger" class="commonbutton" @click="reMergeAsbitem">手动合并项目</el-button> </div>
<div v-show="checkPagePriv(pagePriv.privs, '全个人支付')" style="margin-top: 30px;"> <el-button type="primary" class="commonbutton" @click="btnPayTypeFlag('0')">全个人支付</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '全单位支付')" class="btn"> <el-button type="primary" class="commonbutton" @click="btnPayTypeFlag('1')">全单位支付</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '全免费')" class="btn"> <el-button type="primary" class="commonbutton" @click="btnPayTypeFlag('2')">全免费</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '收费')" class="btn"> <el-button type="success" class="commonbutton" @click="toCharge(form)" :disabled="!form.id">收费</el-button> </div> <div v-show="checkPagePriv(pagePriv.privs, '收费申请')" class="btn"> <el-button type="success" class="commonbutton" @click="chargeRequest(form)" :disabled="!form.id">收费申请</el-button> </div> <!-- <div class="btn"> <el-button type="success" class="commonbutton" @click="btnTest">test</el-button> </div> --> </div> </div>
<!--组件弹窗--> <div> <!-- 人员档案列表 --> <el-dialog title="人员档案列表" :visible.sync="dialogVisible" width="800px" :show-close="false" :close-on-click-modal="false" :append-to-body="true"> <el-table :data="patientList" border width="800" height="480" row-key="id" size="small" class="el-table__body-wrapper tbody" highlight-current-row @row-click="rowick" @row-dblclick="patientDblclick" ref="patientList"> <el-table-column type="index" width="30" /> <el-table-column prop="patientNo" label="档案号" /> <el-table-column prop="lastTime" label="末次体检" width="100"> <template slot-scope="scope"> <div v-if="scope.row.lastTime"> {{ moment(scope.row.lastTime).format("yyyy-MM-DD") }} </div> </template> </el-table-column> <el-table-column prop="medicalTimes" label="体检次数" /> <el-table-column prop="displayName" label="姓名" /> <el-table-column prop="sexId" label="性别"> <template slot-scope="scope"> <div> {{ dddw(dict.sex, "id", scope.row.sexId, "displayName") }} </div> </template> </el-table-column> <el-table-column prop="maritalStatusId" label="婚姻"> <template slot-scope="scope"> <div> {{ dddw(dict.maritalStatus, "id", scope.row.maritalStatusId, "displayName") }} </div> </template> </el-table-column> <el-table-column prop="birthDate" label="出生日期" width="100"> <template slot-scope="scope"> <div v-if="scope.row.birthDate"> {{ moment(scope.row.birthDate).format("yyyy-MM-DD") }} </div> </template> </el-table-column> <el-table-column prop="nationId" label="民族"> <template slot-scope="scope"> <div> {{ dddw(dict.nation, "id", scope.row.nationId, "displayName") }} </div> </template> </el-table-column> <el-table-column prop="idNo" label="身份证号" /> <el-table-column prop="telephone" label="电话" /> <el-table-column prop="mobileTelephone" label="手机号" /> </el-table> <span slot="footer" class="dialog-footer"> <el-button class="commonbutton" @click="dialogVisible = false" style="width:90px;">取消</el-button> <el-button class="commonbutton" type="primary" @click="choosePatient" style="width:90px;">确定</el-button> </span> </el-dialog>
<el-dialog title="选择单位" :visible.sync="dialogOrg" width="800px" :close-on-click-modal="false" :append-to-body="true"> <div style="height: 320px;"> <el-cascader v-model="form.customerOrgId" :options="patientRegister.customerOrgTreeAll" style="width:400px;" filterable popper-class="example" :show-all-levels="false" :props="{ checkStrictly: true, expandTrigger: 'hover', ...customerOrg.treeprops, }" size="small"> </el-cascader> </div> <span slot="footer" class="dialog-footer"> <el-button type="primary" @click="btnOkOrg">确定</el-button> <el-button @click="dialogOrg = false">关闭</el-button> </span> </el-dialog>
<!-- 拍照(openCamera) 网页模式,已废弃 <el-dialog title="拍照" :visible.sync="patientRegister.cameraVisble" width="400" height="600" :close-on-click-modal="false" :append-to-body="true"> <Camera :id="form.id" /> </el-dialog> --> <!-- 检验条码补打 --> <el-dialog title="检验条码补打" :visible.sync="patientRegister.lisRequestVisble" width="600px" height="400" :show-close="false" :close-on-click-modal="false" :append-to-body="true"> <LisRequest :id="form.id" :brushTimes="brushTimes" /> </el-dialog>
<!-- 手动合并项目 --> <el-dialog title="手动合并项目" :visible.sync="patientRegister.mergeAsbitemVisble" width="600px" height="400" :show-close="false" :close-on-click-modal="false" :append-to-body="true"> <MergeAsbitem :id="form.id" :medicalCenterId="form.medicalCenterId" :brushTimes="brushTimes" /> </el-dialog>
<!-- 收费 --> <el-dialog title="" :visible.sync="dialogWin.charge" :close-on-click-modal="false" :append-to-body="true" fullscreen @close="closeDialogCharge"> <div style="margin-top: -30px;"> <Charge :patientRegisterNo="chargePatientRegisterNo" /> </div> </el-dialog>
<!-- 收费申请 --> <el-dialog title="收费申请" :visible.sync="dialogWin.AsbChargeRequest" width="800px" :show-close="false" :close-on-click-modal="false" :append-to-body="true" @close="closeDialogCharge"> <AsbChargeRequest :patientRegister="form" /> </el-dialog> </div> </div></template><script>import moment from "moment";import { mapState, mapActions } from "vuex";import { getapi, postapi, putapi, deletapi } from "@/api/api";import { getTreeNode } from "../../utlis/tree"
import { getPagePriv, checkPagePriv, objCopy, setNull, dddw, checkIDCode, parseID, birthdayToAge, ageToBirthday, deepCopy, arrayFilter, arrayReduce, parsIcCardtoLocal, arrayExistObj} from "../../utlis/proFunc";import { getTreePids } from "../../utlis/tree";import { photoParse, savePeoplePhoto, } from "../../utlis/proApi";import Camera from "./Camera.vue";import PatientRegisterItem from "./PatientRegisterItem.vue";import LisRequest from "./LisRequest.vue";import MergeAsbitem from "./MergeAsbitem.vue";import AsbChargeRequest from "./AsbChargeRequest.vue";import Charge from "../../views/charge/charge.vue";import PatientRegisterEditQuery from "../../components/patientRegister/PatientRegisterEditQuery.vue";
export default { components: { Camera, LisRequest, MergeAsbitem, PatientRegisterItem, Charge, AsbChargeRequest, PatientRegisterEditQuery }, // isDoctor: '0:标准人员登记/1:医生诊台登记(可修改单位)'
props: ['isDoctor', 'patientRegisterId', 'editTimes', 'refreshRegister', 'refFuncSetData'], data() { return {
pagePriv: { routeUrlorPageName: 'PatientRegisterEdit', //当前页面归属路由或归属页面权限名称
privs: [] // 页面权限
}, LocalConfig: { patientRegister: { editMode: 'standard', //standard/qztl 人员登记组件版本
editHeight: 0, // 相较与标准版,选组合项目组件,减少高度
immediateToHisCharge: true, // 人员登记保存后,立即发送收费申请
printGuideLabel: ["guide", "pacs", "lis"], // 保存后打印指引单与条码
}, }, brushTimes: 0,
peisid: null, peoplePhoto: '', preCustomerOrgId: '', // 上一个人的体检单位,只是在本组件点新增时才用到
form: { registerManType: 'customer', //登记人员类型,客服:customer 医生:doctor 支持在医生诊台处理登记人员
id: "", //id
photo: '', //照片
patientId: "00000000-0000-0000-0000-000000000000", //档案号ID 选择了档案就传档案号,未选就传00000-0000...
patientNo: "", //档案号
customerOrgId: ["00000000-0000-0000-0000-000000000001"], //单位编号 默认个人
customerOrgParentId: "00000000-0000-0000-0000-000000000001", customerOrgName: "个人体检", customerOrgRegisterId: "00000000-0000-0000-0000-000000000001", //默认单位体检次数
customerOrgGroupId: null, //分组
medicalPackageId: null, //套餐
patientName: "", //姓名
birthDate: null, //日期型
sexId: "U", //性别 默认未知U
age: null, //年龄
jobCardNo: "", //工卡号
medicalCardNo: "", //体检卡号
maritalStatusId: "9", //婚姻状况 默认未知
medicalTypeId: null, //体检类别
personnelTypeId: null, //人员类别
jobPost: "", //职务
jobTitle: "", //职称
salesman: "", //介绍人
sexHormoneTermId: null, //性激素期限
isNameHide: "N", //隐藏姓名
isPhoneFollow: "N", //电话随访
isVip: "N", //vip客户
remark: "", //
isLock: "N", //是否锁住
completeFlag: "1", //完成标志 0:预登记,1:正式登记(未检),2:部份已检,3:已总检 【创建编辑时不操作】
isMedicalStart: "N", //体检开始标志 【创建编辑时不操作】
patientRegisterNo: "", //条码号 【创建编辑时不操作】
medicalTimes: 1, //条码号 【创建编辑时不操作】
medicalCenterId: null, //体检中心
address: "", //地址
email: "", //email
idNo: "", //身份证号
telephone: "", //电话
mobileTelephone: "", //手机号
nationId: null, //民族编号
birthPlaceId: null, //籍惯(出生地)
postalCode: "", //邮编
creatorId: null, creationTime: "", lastModificationTime: "", lastModifierId: null, isMaxMedicalTimes: 'N', medicalStartDate: null, hisPatientId: '', //对接 hisid
registerCheckAsbitems: [], //所选组合项目明细
qztlType: '0', // 高原/健康
qztlIsCw: 'N', // 普速
qztlIsCy: 'N', // 从业
qztlIsGt: 'N', // 高铁
qztlIsMain: 'N', // 行车
qztlIsWh: 'N', // 职害
qztlIsFj: 'N', // 复检
isQztlImport: 'N', // 导入
uploadQztlFlag: 'N', // 上传
planuserid: '', // 计划人
}, //单位 记录 目前新增与更新是一致
formInit: {}, //表单初始化
customerOrgRegisterList: [], //单位体检次数列表
defaultNull: [ "customerOrgId", "customerOrgGroupId", "medicalPackageId", "birthDate", "age", "maritalStatusId", "medicalTypeId", "personnelTypeId", "sexHormoneTermId", "medicalCenterId", "nationId", "birthPlaceId", ], //一般uuid字段为空时,需设置为null值
rules: { customerOrgId: [ { required: true, message: "请填写单位", trigger: "blur" }, ], patientName: [ { required: true, message: "请填写姓名", trigger: "blur" }, ], medicalCenterId: [ { required: true, message: "请填写体检中心", trigger: "blur" }, ], },
dialogVisible: false, patientList: [], //人员列表(用于判断人员多次体检)
patientChoosed: {}, //查重选中的人员
registerVisible: false, patientRegisters: [], registerChoosed: {},
dialogCamera: false, //拍照组件
chargePatientRegisterNo: '', //对哪个条码客户收费
//人员登记,组合项目明细操作相关参数
prAsbOpraOpts: { formId: '', //form.id为空时,明细保存取此formId
copyNew: 0, //触发复制新增
payTypeFlag: '', //触发调整支付方式
prAsbSave: 0, //触发组合项目明细保存
prAsbQuery: 0,//触发组合项目明细查询,比如收费后,刷新收费状态
prAsbGroup: 0, //触发分组更换
prAsbPackage: 0, //触发套餐更换
}, nation: [], //
dialogOrg: false,
printing: false, // 是否打印中,控制一次只能有一个任务
}; },
created() { //获取用户当前页面的权限
let userPriv = window.sessionStorage.getItem('userPriv') if (userPriv) this.pagePriv.privs = deepCopy(getPagePriv(this.pagePriv.routeUrlorPageName))
try { let LocalConfig = JSON.parse(window.localStorage.getItem('LocalConfig')) if (LocalConfig && LocalConfig.patientRegister) { if (LocalConfig.patientRegister.edit) this.LocalConfig.patientRegister.edit = LocalConfig.patientRegister.edit if (LocalConfig.patientRegister.editHeight) this.LocalConfig.patientRegister.editHeight = LocalConfig.patientRegister.editHeight if (LocalConfig.patientRegister.immediateToHisCharge) this.LocalConfig.patientRegister.immediateToHisCharge = LocalConfig.patientRegister.immediateToHisCharge if (LocalConfig.patientRegister.printGuideLabel) this.LocalConfig.patientRegister.printGuideLabel = deepCopy(LocalConfig.patientRegister.printGuideLabel) } } catch (error) { console.log("window.localStorage.getItem('LocalConfig')", error) }
this.formInit = deepCopy(this.form)
// 初始化字典数据
this.dictInit() },
//挂载完成
mounted() { this.initFormData(this.dataTransOpts.tableS.patient_register.id) // 表单中 回车 代替 tab
this.enterToTab(); },
computed: { ...mapState(["window", "dialogWin", "dataTransOpts", "dict", "patientRegister", "customerOrg", "projPriv"]),
//是否总检(已总检则不允许修改套餐与分组)
isComplete() { return this.form.completeFlag == '3' ? true : false; },
// 套餐 disabled 如完成体检亦不允许编辑
displayPackage() { let isPersonOrgId = true if (!this.isComplete) { if (!this.form.customerOrgId) return false if (typeof this.form.customerOrgId == 'string') { if (this.form.customerOrgId == this.dict.personOrgId) isPersonOrgId = false } else { if (this.form.customerOrgId[this.form.customerOrgId.length - 1] == this.dict.personOrgId) isPersonOrgId = false } } return isPersonOrgId },
// 分组 disabled 如完成体检亦不允许编辑
displayGroup() { let isPersonOrgId = true if (!this.isComplete) { if (!this.form.customerOrgId) return isPersonOrgId if (typeof this.form.customerOrgId == 'string') { if (this.form.customerOrgId != this.dict.personOrgId) isPersonOrgId = false } else { if (this.form.customerOrgId[this.form.customerOrgId.length - 1] != this.dict.personOrgId) isPersonOrgId = false } } return isPersonOrgId }, }, methods: { ...mapActions(['getPatientRegisterAbs']), dddw, moment, checkPagePriv,
btnTest() { // console.log('form', this.form)
}, //数据初始化
dictInit() { //性别(仅档案用)
getapi("/api/app/sex").then((res) => { if (res.code == 1) { this.dict.sex = res.data; } });
//适用性别
getapi("/api/app/for-sex").then((res) => { if (res.code == 1) { this.dict.forSex = res.data; } });
//体检中心
getapi("/api/app/organization-units/organization-unit-by-is-peis").then( (res) => { if (res.code == 1) { this.dict.organization = res.data; } } );
//体检单位
// getapi("/api/app/customer-org/in-filter").then((res) => {
// if (res.code == 1) {
// this.dict.customerOrg = res.data;
// }
// });
//体检类别
getapi("/api/app/medical-type/in-filter").then((res) => { if (res.code == 1) { this.dict.medicalType = res.data; } });
//人员类别
getapi("/api/app/personnel-type/in-filter").then((res) => { if (res.code == 1) { this.dict.personnelType = res.data; } });
//婚姻状况
getapi("/api/app/MaritalStatus/GetMaritalStatusList").then((res) => { if (res.code == 1) { this.dict.maritalStatus = res.data; } });
//性激素期
getapi("/api/app/sex-hormone-term/in-filter").then((res) => { if (res.code == 1) { this.dict.sexHormoneTerm = res.data; } });
//民族
getapi("/api/app/nation/in-filter").then((res) => { if (res.code != -1) { this.dict.nation = res.data; this.nation = deepCopy(res.data) } });
//籍惯 ,出生地
getapi("/api/app/birth-place/in-filter").then((res) => { if (res.code == 1) { this.dict.birthPlace = res.data; } });
//套餐
postapi("/api/app/medicalpackage/GetBasicList", {}).then((res) => { if (res.code == 1) { this.dict.medicalPackage = res.data; } });
//支付方式
getapi("/api/app/pay-mode").then((res) => { if (res.code == 1) { this.dict.payMode = res.data; } });
//项目类别 树结构
// getapi("/api/app/item-type/by-code-all").then((res) => {
// if (res.code != -1) {
// this.dict.itemTypeTree = res.data;
// tcdate(this.dict.itemTypeTree);
// }
// });
// postapi("/api/app/asbitem/GetBasicList",{isFilterActive:'Y'}).then((res) => {
// if (res.code != -1) {
// this.dict.asbItemAll = res.data;
// }
// });
// // console.log("dict", this.dict);
},
// 确定选中企业
btnOkOrg() { let customerOrgId = '' this.changeCustomerOrgId(this.form.customerOrgId) if (Array.isArray(this.form.customerOrgId)) { this.form.customerOrgParentId = this.form.customerOrgId[0] customerOrgId = this.form.customerOrgId[this.form.customerOrgId.length - 1] } else { this.form.customerOrgParentId = this.form.customerOrgId customerOrgId = this.form.customerOrgId } let node = getTreeNode(this.patientRegister.customerOrgTreeAll, "treeChildren", "id", customerOrgId) if (node) this.form.customerOrgName = node.displayName
this.dialogOrg = false },
// 获取登记信息 初始form表单数据
async initFormData(patientRegisterId) { this.peisid = window.sessionStorage.getItem('peisid'); let customerOrgId, customerOrgName, customerOrgParentId if (this.patientRegister.query.customerOrgId) { customerOrgParentId = this.patientRegister.query.CustomerOrgParentId customerOrgId = this.patientRegister.query.customerOrgId customerOrgName = this.patientRegister.query.customerOrgName } else { customerOrgParentId = this.form.customerOrgParentId customerOrgId = this.form.customerOrgId customerOrgName = this.form.customerOrgName } this.preCustomerOrgId = this.patientRegister.query.customerOrgId if (!patientRegisterId) { //添加
this.peoplePhoto = '' // 清掉照片
objCopy(this.formInit, this.form); this.form.registerCheckAsbitems = [] this.form.medicalCenterId = this.peisid; //体检中收
this.form.customerOrgId = customerOrgId //体检单位
this.form.customerOrgParentId = customerOrgParentId //体检父单位
this.form.customerOrgName = customerOrgName this.handleFormData() } else { // let res = await getapi(`/api/app/patient-register/${patientRegisterId}`)
postapi('/api/app/patientregister/getinfoorpatient', { patientRegisterId }).then(res => { if (res.code > -1) { // this.form = res.data 这种方式,会造成 checkbox 值变化不响应,故取消
this.form = res.data this.handleFormData() } }) } },
handleFormData() { this.getPeoplePhoto(this.form.photo)
// this.dataTransOpts.refresh.register_check_asbitem.D++ //触发所选组合项目刷新 (取消这种触发,减少交互)
this.dataTransOpts.tableM.register_check_asbitem = this.form.registerCheckAsbitems this.dataTransOpts.tableM.register_check_asbitem.forEach(e => { e.standTotal = e.amount * e.standardPrice e.total = e.amount * e.chargePrice });
// 单位/个人 的分组与套餐处理
this.changeCustomerOrgId(this.form.customerOrgId)
this.dataTransOpts.refresh.register_check_asbitem.OnlyRefreshAsbitem++ },
//快速选择组合项目时,调整可按拼间简码及简称查找
filterMethod(keyWords) { //// console.log('filterMethod',this.asbItemQuick)
if (keyWords) { this.nation = []; this.dict.nation.forEach(item => { if (item.displayName.toLowerCase().indexOf(keyWords.toLowerCase()) > - 1 || item.simpleCode.toLowerCase().indexOf(keyWords.toLowerCase()) > - 1) { this.nation.push(item); } }); } else { this.nation = deepCopy(this.dict.nation); } },
//选择单位
async changeCustomerOrgId(v) { console.log('changeCustomerOrgId', v, this.form.customerOrgParentId) let customerOrgId = "", customerOrgParentId = "" if (Array.isArray(v) && v.length > 0) { customerOrgId = v[v.length - 1] customerOrgParentId = v[0] } else { customerOrgId = v // 后台顶级单位ID未获取正确(再获取一次)
let pids = getTreePids(this.patientRegister.customerOrgTreeAll, "treeChildren", "parentId", "id", customerOrgId) if (Array.isArray(pids) && pids.length > 0) { if (pids.length == 1) { customerOrgParentId = customerOrgId } else { customerOrgParentId = pids[1] } } } this.preCustomerOrgId = customerOrgId // let customerOrgParentId = await this.getParentCustomerOrgId(customerOrgId)
if (customerOrgParentId) { if (customerOrgParentId == this.dict.personOrgId) { this.form.customerOrgRegisterId = "00000000-0000-0000-0000-000000000001" } else { // 获取体检次数字典库
this.getCustomerOrgRegisterList(customerOrgParentId) }
// 需要触发 修改 分组/套餐 顶级ID 没有变时,不改变套餐与分组
if (customerOrgParentId != this.form.customerOrgParentId) { this.form.customerOrgGroupId = null this.form.medicalPackageId = null // 清除套餐分组标识
this.dataTransOpts.tableM.register_check_asbitem.forEach(e => { e.isBelongGroupPackage = 'N' });
if (customerOrgParentId == this.dict.personOrgId) { this.patientRegister.customerOrgGroup = [] }
if (this.form.customerOrgParentId == this.dict.personOrgId) { this.changeMedicalPackageId() } else { this.changeCustomerOrgGroupId() } } } },
// 获取顶级单位ID
async getParentCustomerOrgId(customerOrgId) { let customerOrgParentId = null if (!customerOrgId) return customerOrgParentId if (typeof customerOrgId == 'string') { try { let res = await getapi(`/api/app/customer-org/parent/${customerOrgId}`) if (res.code != -1) customerOrgParentId = res.data } catch (error) { // console.log('获取顶级单位ID出错:', error)
} } else if (customerOrgId.length > 0) { customerOrgParentId = customerOrgId[0] } return customerOrgParentId },
//获取单位体检次数
getCustomerOrgRegisterList(customerOrgParentId) { //获取单位体检次数信息
getapi(`/api/app/customerorgregister/getlistincustomerorgid?CustomerOrgId=${customerOrgParentId}`) .then(res => { if (res.code > - 1) { // console.log('获取单位体检次数', this.form.customerOrgRegisterId, res.data)
this.customerOrgRegisterList = res.data
if (!this.form.customerOrgRegisterId || this.form.customerOrgRegisterId == "00000000-0000-0000-0000-000000000001") { let customerOrgRegisterList = arrayFilter(res.data, 'isComplete', 'N') //不显示已完成的体检次数
if (customerOrgRegisterList.length > 0) { this.form.customerOrgRegisterId = customerOrgRegisterList[customerOrgRegisterList.length - 1].id } } // /api/app/customerorggroup/getlistinfilter?CustomerOrgRegisterId=${this.form.customerOrgRegisterId}
this.patientRegister.customerOrgGroup = [] if (this.form.customerOrgRegisterId && this.form.customerOrgRegisterId != '00000000-0000-0000-0000-000000000001') return postapi('/api/app/CustomerOrgGroup/GetListForPatentRegisterByFilter', { customerOrgRegisterId: this.form.customerOrgRegisterId }) //获取单位分组
} }).then(res => { if (res && res.code != -1) { this.patientRegister.customerOrgGroup = res.data; } }) },
//读取身份证信息
peopleIcCard() { if (!this.$peisAPI) { this.$message.info({ showClose: true, message: "此功能,需要在壳客户端才可运行!" }) return } this.$peisAPI.peopleIcCard().then(res => { // console.log('peopleIcCard', res)
let lres = JSON.parse(res) if (lres.code >= -1) { let idNos = parsIcCardtoLocal(lres.data, this.dict.sex, this.dict.nation) this.form.patientName = idNos.Name this.form.birthDate = idNos.birthDate this.form.sexId = idNos.sexId this.form.age = idNos.age this.form.nationId = idNos.nationId this.form.idNo = idNos.IDCode this.form.address = idNos.Address this.peoplePhoto = 'data:image/bmp;base64,' + idNos.Photo // this.patientRegister.photo = 'data:image/bmp;base64,' + idNos.Photo
this.changeIdNo() // 触发身份证查询档案号
} else { this.$message.error({ showClose: true, message: `${lres.message}` }) } }) },
//修改单位体检次数
changeMedicalTimes() {
this.form.customerOrgGroupId = null this.changeCustomerOrgGroupId()
//获取体检次数下的分组
this.getCustomerOrgGroup(this.form.customerOrgRegisterId) },
//移除旧分组或套餐的组合项目
removeGroupPackageAsb() { let body = { registerAsbitemIds: [] } let registerAsbitemIds = [] let chargeComplete = ''
//体检基本信息未保存时,删除所有所选项目
if (!this.form.id) { this.patientRegister.patientRegisterAbs = []; return body; }
//删除已选 分组或套餐的组合项目 ,如已收费或 已检时,将 groupPackageId 置为null
for (let i = 0; i < this.patientRegister.patientRegisterAbs.length; i++) { if (!this.patientRegister.patientRegisterAbs[i].id) { this.patientRegister.patientRegisterAbs.splice(i, 1) i-- continue } if (this.patientRegister.patientRegisterAbs[i].isCharge == 'Y' || this.patientRegister.patientRegisterAbs[i].checkCompleteFlag != '0') { chargeComplete += this.patientRegister.patientRegisterAbs[i].asbitemName + ',' this.patientRegister.patientRegisterAbs[i].groupPackageId = null } else { //数据库有,才添加到待删除的数组中
if (this.patientRegister.patientRegisterAbs[i].id) { registerAsbitemIds.push(this.patientRegister.patientRegisterAbs[i].id) } this.patientRegister.patientRegisterAbs.splice(i, 1) i-- } }
if (chargeComplete) { this.$message.info({ showClose: true, message: `所选项目:${chargeComplete}已收费或已检,不可删除!` }); }
body = { registerAsbitemIds };
return body;
},
//添加新套餐/分组的组合项目
addGroupPackageAsb(groupPackageAsb, typeFlag, groupPackageId) {
let payTypeFlag = '0'; //默认个人支付
let lfind = -1
if (this.form.customerOrgId != this.dict.personOrgId) payTypeFlag = '1' //单位支付
for (let i = 0; i < groupPackageAsb.length; i++) { lfind = arrayExistObj(this.patientRegister.patientRegisterAbs, 'asbitemId', groupPackageAsb[i].id) if (lfind > - 1) { this.patientRegister.patientRegisterAbs[lfind].groupPackageId = groupPackageId //editCount++
continue } let pojo = { asbitemId: groupPackageAsb[i].id, asbitemName: groupPackageAsb[i].displayName, patientRegisterId: this.form.id, standardPrice: groupPackageAsb[i].price, chargePrice: typeFlag == 'group' ? groupPackageAsb[i].customerOrgGroupDetailPrice : groupPackageAsb[i].price, payTypeFlag, discount: typeFlag == 'group' ? groupPackageAsb[i].discount : 100, isCharge: "N", amount: typeFlag == 'group' ? groupPackageAsb[i].customerOrgGroupDetailAmount : 1, groupPackageId: groupPackageId } this.patientRegister.patientRegisterAbs.push(pojo) } },
//获取体检次数下的分组
getCustomerOrgGroup(customerOrgRegisterId) { this.patientRegister.customerOrgGroup = [] // /api/app/customerorggroup/getlistinfilter?CustomerOrgRegisterId=${customerOrgRegisterId}`
postapi('/api/app/CustomerOrgGroup/GetListForPatentRegisterByFilter', { customerOrgRegisterId }).then(res => { if (res.code != - 1) { this.patientRegister.customerOrgGroup = res.data; } }) },
//修改出生日期
changeBirthDate() { this.form.age = birthdayToAge(this.form.birthDate) },
//修改出生日期
changeAge() { this.form.birthDate = ageToBirthday(this.form.age) },
//修改身份证,生成年龄、出生、性别
changeIdNo() { if (!this.form.idNo) return this.Query(this.form.idNo) let ret = parseID(this.form.idNo) // console.log('changeIdNo',ret)
if (ret.age != -1) { this.form.birthDate = new Date(ret.birthday) this.form.age = ret.age this.form.sexId = ret.sex } },
// //分组改变时触发
changeCustomerOrgGroupId() { this.prAsbOpraOpts.prAsbGroup++ },
// //套餐改变时触发
changeMedicalPackageId() { this.prAsbOpraOpts.prAsbPackage++ },
//根据姓名,身份证号 查询档案信息,用于判断人员多次体检
Query(param) { this.patientChoosed = { id: '' } // 清空之前的选择
//编辑的时候不查重
if (this.form.id || !param) return;
//// console.log(`/api/app/patient/in-filter?Filter=${param}`)
let body = { filter: param, maxResultCount: 500 }
this.patientList = []
postapi('/api/app/patient/getlistinfilter', body).then((res) => { if (res.code > -1) { // console.log("查重 ", res); //有数据才显示
if (res.data && res.data.length > 0) { this.patientList = res.data; this.dialogVisible = true; } } });
},
//列表选中
rowick(row) { this.patientChoosed = row; },
patientDblclick(row) { this.patientChoosed = row; this.choosePatient() },
//确定选择人员
choosePatient() { if (!this.patientChoosed.id) { this.$message.warning({ showClose: true, message: '请选择人员档案信息' }) return; }
this.dialogVisible = false;
this.form.patientId = this.patientChoosed.id; this.form.patientNo = this.patientChoosed.patientNo; this.form.medicalTimes = this.patientChoosed.medicalTimes + 1; // 考滤录入有值,档案却无值
if (this.patientChoosed.displayName) this.form.patientName = this.patientChoosed.displayName; if (this.patientChoosed.sexId) this.form.sexId = this.patientChoosed.sexId; if (this.patientChoosed.birthDate) this.form.birthDate = new Date(this.patientChoosed.birthDate); if (this.patientChoosed.nationId) this.form.nationId = this.patientChoosed.nationId; if (this.patientChoosed.idNo) this.form.idNo = this.patientChoosed.idNo;
if (!this.form.maritalStatusId) this.form.maritalStatusId = this.patientChoosed.maritalStatusId; if (!this.form.telephone) this.form.telephone = this.patientChoosed.telephone; if (!this.form.mobileTelephone) this.form.mobileTelephone = this.patientChoosed.mobileTelephone;
if (this.form.birthDate) { this.form.age = birthdayToAge(this.form.birthDate) }
if (this.form.idNo) { let ret = parseID(this.form.idNo) this.form.birthDate = new Date(ret.birthday) this.form.age = ret.age this.form.sexId = ret.sex }
},
registerRowClick(row) { this.registerChoosed = row; }, registerRowDblclick(row) { this.registerChoosed = row; this.chooseRegister() },
chooseRegister() { if (!this.registerChoosed) { alert("请选中人员登记信息"); return; }
objCopy(this.registerChoosed, this.form) // this.patientRegister.patientRegisterId = this.registerChoosed.id
// this.patientRegister.photo = this.registerChoosed.photo
// this.getPatientRegisterAbs(this.registerChoosed.id)
this.dataTransOpts.tableS.patient_register.id = this.registerChoosed.id setTimeout(() => { this.dataTransOpts.refresh.register_check_asbitem.M++ }, 20);
this.registerVisible = false
},
// 组装基本信息保存的参数体
madePrBody() { //赋值
let body = deepCopy(this.form); // // console.log('this.form',this.form)
// console.log('body',this.form,body)
if (this.form.birthDate) { try { body.birthDate = moment(new Date(this.form.birthDate)).format("yyyy-MM-DD") } catch (error) { // this.form.birthDate != "Invalid date"
body.birthDate = null } } else { body.birthDate = null } if (body.birthDate == "Invalid date") body.birthDate = null if (isNaN(body.age)) { body.age = null } else { body.age = Number(body.age) } // // console.log('body',body)
// Invalid date
delete body.registerManType; delete body.patientRegisterNo; delete body.medicalTimes; // delete body.completeFlag;
delete body.isMedicalStart; delete body.patientNo; delete body.creatorId; delete body.creationTime; delete body.lastModificationTime; delete body.lastModifierId; delete body.isVipBox; delete body.isNameHideBox; delete body.isPhoneFollowBox; delete body.isLockBox; delete body.photo;
// if(this.form.registerManType == 'customer') delete body.medicalStartDate;
if (this.form.id) delete body.medicalStartDate;
setNull(body, this.defaultNull);
if (typeof this.form.customerOrgId == 'object') { if (this.form.customerOrgId.length > 0) body.customerOrgId = this.form.customerOrgId[this.form.customerOrgId.length - 1] }
//日期转换 日期控件增加格式
// // console.log("body.birthDate", body.birthDate);
// if (body.birthDate) {
// body.birthDate = moment(new Date(body.birthDate)).format(
// "yyyy-MM-DD"
// );
// }
return body },
//提交
btnSubmit(formName, msgTip) { this.$refs[formName].validate((valid, fields) => { // console.log('fields', fields)
if (!valid) { this.$message.warning({ showClose: true, message: fields[Object.keys(fields)[0]][0].message }); return false }
if (this.form.customerOrgId != this.dict.personOrgId) { if (!this.form.customerOrgRegisterId) { this.$message.warning({ showClose: true, message: "请填写单位体检次数!" }); return false } }
if (this.form.idNo && checkIDCode(this.form.idNo) == false) { this.$message.warning({ showClose: true, message: "身份证号填写不合法!" }); return false } let body = this.madePrBody() // console.log('madePrBody',body)
body.registerCheckAsbitems = deepCopy(this.dataTransOpts.tableM.register_check_asbitem)
if (this.form.id) { // 更新时,先保存明细,再更新主表
// this.prAsbOpraOpts.prAsbSave++ //触发组合项目保存
body.patientRegisterId = body.id; } else { delete body.id; } // // console.log(`/api/patientregister/createreturninfo`, body);
postapi(`/api/PatientRegister/CreatePatientRegister`, body) .then(async (res) => { if (res.code > -1) { objCopy(res.data, this.form) // 日期类型复制会有问题(记得要特殊处理)
this.dataTransOpts.tableS.patient_register = deepCopy(res.data)
delete this.dataTransOpts.tableS.patient_register.registerCheckAsbitems
// 保存成功赋 id 值等
this.dataTransOpts.tableM.register_check_asbitem = res.data.registerCheckAsbitems
//一般读身份证照片时,会出现这种情况
if (this.peoplePhoto && this.peoplePhoto.indexOf("data:image") > -1) await savePeoplePhoto(res.data.id, this.peoplePhoto);
// 保存即发送收费申请
if (this.LocalConfig.patientRegister.immediateToHisCharge) { await this.immediateToHisCharge(this.form.id) }
// 新增保存时,提示是否打条码 (预登记一般不打条码)
if (!body.id && this.form.completeFlag != '0') { if (Array.isArray(this.LocalConfig.patientRegister.printGuideLabel) && this.LocalConfig.patientRegister.printGuideLabel.length > 0) { this.$confirm("是否打印 指引单、检验条码及 Pacs 条码?", "提示", { confirmButtonText: "是", cancelButtonText: "否", type: "warning", }) .then(async () => { try { if(this.LocalConfig.patientRegister.printGuideLabel.indexOf('guide') > -1) await this.guidePrint('0001', false) await this.labelPrint(false) } catch (error) { // this.$message.info({ showClose: true, message: error });
console.log(error) } }) .catch((err) => { // if (err == "cancel") {
// this.$message.info({ showClose: true, message: "已取消操作" });
// }
}); } } } } );
}); },
// 人员新增
btnAdd() { this.dataTransOpts.tableS.patient_register.id = '' this.dataTransOpts.refresh.patient_register.S++ },
//将现有的数据,复制并展现,但未保存
rdCopy() { if (!this.form.id) { this.$message.info({ showClose: true, message: "该信息尚未保存,不可执行此操作!" }); return; } this.dataTransOpts.tableS.patient_register.id = '' this.peoplePhoto = '/pic/Photo.jpg' this.patientRegister.patientRegisterId = ''; this.form.id = ''; this.form.patientId = '00000000-0000-0000-0000-000000000000'; this.form.patientRegisterNo = ''; this.form.patientNo = ''; this.form.medicalTimes = 1; this.form.patientName = ''; this.form.photo = ''; this.form.completeFlag = '1'; //
// this.patientRegister.patientRegisterAbs.forEach(e => {
// e.id = '';
// e.patientRegisterId = '';
// e.isCharge = 'N';
// e.checkCompleteFlag = '0'
// e.isLock = 'N'
// });
// 触发明细项目复制
// setTimeout(() => {
// this.prAsbOpraOpts.copyNew++
// }, 10);
this.dataTransOpts.tableM.register_check_asbitem.forEach(e => { delete e.id e.patientRegisterId = '' e.isCharge = 'N' e.isLock = 'N' }); // // console.log('this.patientRegister.patientRegisterAbs',this.patientRegister.patientRegisterAbs)
this.$message.info({ showClose: true, message: "操作成功,请记得点保存" });
},
//删除
del() { deletapi( `/api/app/customer-org/${this.customerOrg.customerOrgRd.id}` ).then((res) => { // console.log("删除 操作成功");
this.setData({ key: "customerOrg.customerOrgRd", value: { id: "" } }); this.getCustomerOrgTree(); }); },
//拍照(已废弃)
// openCamera() {
// if (!this.form.id) {
// alert("请先保存人员信息");
// return;
// }
// this.patientRegister.cameraVisble = true;
// },
//拍照(调壳程序)
photoGrah() { if (!this.form.id) { alert("请先保存人员信息"); return; } if (!this.$peisAPI) { this.$message.info({ showClose: true, message: "此功能,需要在壳客户端才可运行!" }) return } this.$peisAPI.photoGrah() .then(res => { // console.log('this.$peisAPI.photoGrah 原始返回结果', res)
let lres = JSON.parse(res) if (lres.code > -1) { let uploadPhoto = { patientRegisterId: this.form.id, photo: lres.data.Photo, }; this.peoplePhoto = `data:image/${lres.data.PhotoFormat == 'jpg' ? 'jpeg' : lres.data.PhotoFormat};base64,${lres.data.Photo}` // this.patientRegister.photo = `data:image/${lres.data.PhotoFormat == 'jpg' ? 'jpeg' : lres.data.PhotoFormat};base64,${lres.data.Photo}`
return postapi(`/api/app/patient-register/up-load-img`, uploadPhoto) } else { this.$message.error({ showClose: true, message: "上传照片错误" + lres.code }) } }).then(res => { if (res && res.code > -1) { let body = { patientRegisterId: this.form.id, photo: res.data, }; // console.log(body);
return postapi(`/api/app/patient-register/update-photo`, body); } }).then(res => { if (res && res.code > -1) { //// console.log('拍照',res.data)
this.patientRegister.patientRegisterRd.photo = res.data.photo // console.log("操作成功");
} }).catch(err => { // console.log('this.$peisAPI.photoGrah', err)
this.$message.error({ showClose: true, message: `照片操作错误 ${err}` }) }) },
getPeoplePhoto(photo) { this.peoplePhoto = photoParse(photo) },
// 打印指引单(isPreview)
async guidePrint(ReportCode, isPreview) { if (!this.form.id) { this.$message.info({ showClose: true, message: "人员信息尚未保存,不可执行此操作!" }); return; } if(this.form.completeFlag == '0'){ this.$message.info({ showClose: true, message: "预登记人员,不可执行此操作!" }); return; } if (!this.$peisAPI) { this.$message.info({ showClose: true, message: "此功能,需要在壳客户端才可运行!" }) return }
let token = window.sessionStorage.getItem('token'); let user = window.sessionStorage.getItem('user'); let toOutShell = { ReportCode, token, isBuildImage: 'N', IsUploadPdf: 'N', preViewCanPrint: 'N', BusinessCode: this.form.id, Parameters: [ { Name: 'printer', Value: user }, { Name: 'hisLog', Value: 'pic/hisLog.jpg' }, { Name: 'pageFooter', Value: 'pic/peisQrCode.jpg' }, ], }; console.log('this.$peisAPI.print', JSON.stringify(toOutShell)) this.printing = true if (isPreview) { /* postapi(`/api/app/printreport/getpatientregisterguidereport?PatientRegisterId=${this.form.id}`) .then((res) => { if (res.code != -1) { toOutShell.ReportTable = res.data; // console.log('JSON.stringify(toOutShell)', JSON.stringify(toOutShell));
return this.$peisAPI.printPre(JSON.stringify(toOutShell)); } }) .catch(err => { this.$message.warning({ showClose: true, message: err}); }); */ try { let lres = await this.$peisAPI.printPre(JSON.stringify(toOutShell)) if (JSON.parse(lres).code < 0) { this.$message.warning({ showClose: true, message: JSON.parse(lres).message }); } } catch (error) { this.$message.warning({ showClose: true, message: `${error}` }); } } else { try { let lres = await this.$peisAPI.print(JSON.stringify(toOutShell)) if (JSON.parse(lres).code < 0) { this.$message.warning({ showClose: true, message: JSON.parse(lres).message }); this.printing = false return } postapi('/api/app/patientregister/updatepatientregisterguideprinttimesmany', [this.form.id]).then(res => { if (res && res.code > -1) { let lfind = arrayExistObj(this.patientRegister.prList, 'id', this.form.id) if (lfind > -1) { if (this.patientRegister.prList[lfind].guidePrintTimes) { this.patientRegister.prList[lfind].guidePrintTimes = Number(this.patientRegister.prList[lfind].guidePrintTimes) + 1; } else { this.patientRegister.prList[lfind].guidePrintTimes = 1; } } } }) } catch (error) { this.$message.warning({ showClose: true, message: `${error}` }); } } this.printing = false },
//检验申请
async lisRequest() { this.$message.warning({ showClose: true, message: '此功能已合并到条码打印' }); /* let isPrintLisRequest = false let res = null if (this.form.id.length < 1) { this.$message.info({ showClose: true, message: "人员信息尚未保存,不可执行此操作!"}); return; }
try { res = await postapi(`/api/app/lisrequest/setlisrequest?PatientRegisterId=${this.form.id}`); // console.log(`/api/app/lisrequest/setlisrequest?PatientRegisterId=${this.form.id}`, res)
} catch (error) { return; } if (res.code > -1) { // this.$message.info("发送检验申请成功!");
isPrintLisRequest = true; }
//重复申请,重打
if (res.code == -1 && res.message.indexOf('已申请') > -1) { isPrintLisRequest = true; }
if (!isPrintLisRequest) return;
try { await this.$confirm("是否打印检验申请单?", "提示", { confirmButtonText: "是", cancelButtonText: "否", type: "info", showClose: false, closeOnClickModal: false, closeOnPressEscape: false, }); } catch (error) { return; } //打印检验申请单
this.lisPrint('0003', false); */ },
//条码打印(lis + pacs)
async labelPrint(isPreview) { if (!this.form.id) { this.$message.info({ showClose: true, message: "人员信息尚未保存,不可执行此操作!" }); return; } if(this.form.completeFlag == '0'){ this.$message.info({ showClose: true, message: "预登记人员,不可执行此操作!" }); return; } if (!this.$peisAPI) { this.$message.info({ showClose: true, message: "此功能,需要在壳客户端才可运行!" }) return } let token = window.sessionStorage.getItem('token'); let user = window.sessionStorage.getItem('user'); let toOutShell = { token, // ReportCode,
IsMoreLabel: 'Y', isBuildImage: 'N', IsUploadPdf: 'N', BusinessCode: this.form.id, Parameters: [ { Name: 'printer', Value: user }, { Name: 'hisLog', Value: 'pic/hisLog.jpg' }, ], };
this.printing = true try { // lis条码打印
if(this.LocalConfig.patientRegister.printGuideLabel.indexOf('lis') > -1) await this.lisPrint('0002', isPreview, toOutShell)
// pacs条码打印
if(this.LocalConfig.patientRegister.printGuideLabel.indexOf('pacs') > -1) await this.pacsPrint('0004', isPreview, toOutShell)
} catch (error) { console.log(error) }
this.printing = false
},
// lis条码打印
async lisPrint(ReportCode, isPreview, toOutShell) { toOutShell.ReportCode = ReportCode console.log('this.$peisAPI.print', JSON.stringify(toOutShell)) if (isPreview) { try { let lres = await this.$peisAPI.printPre(JSON.stringify(toOutShell)) if (JSON.parse(lres).code < 0) { this.$message.warning({ showClose: true, message: JSON.parse(lres).message }); } } catch (error) { this.$message.warning({ showClose: true, message: `${error}` }); } } else { try { let lres = await this.$peisAPI.print(JSON.stringify(toOutShell)) if (JSON.parse(lres).code < 0) { this.$message.warning({ showClose: true, message: JSON.parse(lres).message }); return } postapi('/api/app/lisrequest/updatelisrequestisprint', { operateType: 1, patientRegisterId: this.form.id }) .then(res => { if (res && res.code < 0) { this.$message.error({ showClose: true, message: `更新条码打印状态失败,原因:${res.message}` }); } }) } catch (error) { this.$message.warning({ showClose: true, message: error }); } } },
//pacs条码打印
pacsPrint(ReportCode, isPreview, toOutShell) { toOutShell.ReportCode = ReportCode console.log('this.$peisAPI.print', JSON.stringify(toOutShell)) if (isPreview) { this.$peisAPI.printPre(JSON.stringify(toOutShell)) .then(res => { if (JSON.parse(res).code < 0) { this.$message.warning({ showClose: true, message: JSON.parse(res).message }); } }) .catch((err) => { // console.log('打印pacs条码错误', err)
this.$message.warning({ showClose: true, message: `${err}` }); }); } else {
this.$peisAPI.print(JSON.stringify(toOutShell)) .then(res => { if (JSON.parse(res).code < 0) { this.$message.warning({ showClose: true, message: JSON.parse(res).message }); } else { return postapi("/api/app/lisrequest/updatelisrequestisprint", { operateType: 1, patientRegisterId: this.form.id, }); } }) .then(res => { if (res && res.code < 0) { this.$message.error({ showClose: true, message: `${res.message}` }); } }) .catch((err) => { // console.log('打印pacs条码错误', err)
this.$message.error({ showClose: true, message: `${err}` }); }); } },
//补打条码
reLisRequest() { if (this.form.id.length < 1) { this.$message.info({ showClose: true, message: "人员信息尚未保存,不可执行此操作!" }); return; } this.brushTimes++; this.patientRegister.lisRequestVisble = true; },
//手动合并项目
reMergeAsbitem() { if (this.form.id.length < 1) { this.$message.info({ showClose: true, message: "人员信息尚未保存,不可执行此操作!" }); return; } this.brushTimes++; this.patientRegister.mergeAsbitemVisble = true; },
btnPayTypeFlag(payTypeFlag) { this.dataTransOpts.tableM.register_check_asbitem.forEach(e => { if (e.isCharge == 'N') e.payTypeFlag = payTypeFlag }); },
async getAsb(id) { let err = '' try { let res = await getapi(`/api/app/registerasbitem/getlistinpatientregisterid?PatientRegisterId=${id}`) if (res.code > -1) { this.dataTransOpts.tableM.register_check_asbitem = res.data } else { err = res.message } } catch (error) { err = `${error}` } return err },
async toCharge(form) {
if (!form.patientRegisterNo) { this.$message.warning({ showClose: true, message: "请先保存人员信息!" }) return } if (form.completeFlag == '0') { this.$message.warning({ showClose: true, message: "预登记的人员不可执行此操作!" }) return }
let err = await this.getAsb(form.id) if (err) { this.$message.error(err) return }
let chargeMoney = Number(0) //支付方式,比如是0自费、2免费、1单位支付
this.dataTransOpts.tableM.register_check_asbitem.forEach(e => { if (e.payTypeFlag == '0') chargeMoney += Number(e.total) }); if (chargeMoney == 0) { this.$message.warning({ showClose: true, message: '没有可收费或退费的记录!' }) return }
//多次重复点击时,刷新处理
this.chargePatientRegisterNo = form.patientRegisterNo this.dataTransOpts.refresh.charge.S++ this.dialogWin.charge = true
},
// 收费申请
async chargeRequest(form) { if (!form.id) { this.$message.warning({ showClose: true, message: "请先保存人员信息!" }) return } if (form.completeFlag == '0') { this.$message.warning({ showClose: true, message: "预登记的人员不可执行此操作!" }) return }
let err = await this.getAsb(form.id) if (err) { this.$message.error(err) return }
let chargeMoney = Number(0) //支付方式,比如是0自费、2免费、1单位支付
this.dataTransOpts.tableM.register_check_asbitem.forEach(e => { if (e.payTypeFlag == '0') chargeMoney += Number(e.total) }); if (chargeMoney == 0) { this.$message.warning({ showClose: true, message: '没有可收费或退费的记录!' }) return }
// 显示
this.dataTransOpts.refresh.charge.S++ this.dialogWin.AsbChargeRequest = true
},
// 保存立即发送收费申请
async immediateToHisCharge(patientRegisterId) { try { let res = await postapi('/api/app/registerasbitem/GetCanChargeAsbitemsByPatientRegisterId', { patientRegisterId }) if (!(res.code > -1 && res.data.length > 0)) return
let body = { patientRegisterId, registerCheckAsbitems: [] }
res.data.forEach(e => { body.registerCheckAsbitems.push({ registerCheckAsbitemId: e.registerCheckAsbitemId }) });
let resCharge = await postapi("/api/app/ChargeRequest/Create", body) if (resCharge.code > -1) { this.dataTransOpts.refresh.patient_register.S++ } } catch (error) { this.$message.error({ showClose: true, message: `${error}` }) } },
//关闭收费窗口时,刷新收费状态信息
closeDialogCharge() { // this.prAsbOpraOpts.prAsbQuery++
this.dataTransOpts.refresh.patient_register.S++ // this.dataTransOpts.refresh.register_check_asbitem.D++
},
// 新增保存基本信息产生新的ID,等明细保存后,再更新表单form.id
refreshFormId() { // console.log('refreshFormId', this.prAsbOpraOpts.formId)
this.form.id = this.prAsbOpraOpts.formId this.prAsbOpraOpts.formId = '' //清空
/**/ // this.patientRegister.prList.push(res.data); //列表添加记录
this.patientRegister.patientRegisterId = this.form.id; objCopy(this.form, this.patientRegister.patientRegisterRd);
//this.patientRegister.query.times++; 不在触发列表查询(换成局部刷新)放在窗口关闭事件中去
// let curRow = deepCopy(this.patientRegister.patientRegisterRd)
// curRow.index = this.patientRegister.prList.length
// this.patientRegister.prList.push(curRow)
},
//回车替代tab键
enterToTab() { this.$nextTick(() => { let inputs = document.querySelectorAll("form input"); //用数组可以读取多个标签的元素 //.inline-input
//// console.log('inputs',inputs);
// 为每个输入框添加键盘事件监听器
inputs.forEach((input, i) => {
input.addEventListener('keydown', (event) => {
// 如果按下的是回车键
// // console.log('data-ismultiline',input.getAttribute('data-ismultiline'));
if (event.keyCode === 13) { // 阻止回车键的默认行为(换行)
event.preventDefault();
// 如果是身份证,则计算出生与年龄
let placeholder = input.getAttribute('placeholder') if (placeholder == '身份证号') this.changeIdNo()
// 跳至下一个输入框
for (let j = i + 1; j < inputs.length; j++) { if (inputs[j].getAttribute('disabled') != "disabled") { inputs[j].focus(); break; } } } }); }); }); },
},
//监听事件
watch: { //人员ID未切换换时 也可以强制刷新数据
"dataTransOpts.refresh.patient_register.S": { // immediate: true,
async handler(newVal, oldVal) { // console.log(`watch 人员登记 newVal:${newVal} oldVal:${oldVal} registerCheckId: ${this.dataTransOpts.tableS.patient_register.id}`);
if (newVal != oldVal) await this.initFormData(this.dataTransOpts.tableS.patient_register.id) } },
//拍照触发
// "form.photo"(newVal, oldVal) {
// //// console.log('patientRegister.patientRegisterRd.id newVal:',newVal,' oldVal:',oldVal)
// if (newVal != oldVal) {
// this.getPeoplePhoto(newVal)
// }
// },
//修改单位触发
// "form.customerOrgId": {
// // immediate:true,
// // // deep:true,
// handler(newVal, oldVal) {
// //// console.log('patientRegister.patientRegisterRd.id newVal:',newVal,' oldVal:',oldVal)
// if (newVal != oldVal) {
// this.changeCustomerOrgId(newVal)
// }
// }
// },
// 从体检人员登记列表 点登记,触发
// 清空查询条件
"dataTransOpts.plus.clearPatientRegisterQuery": { // immediate: true,
handler(newVal, oldVal) { // console.log('从体检人员登记列表 点登记,触发', newVal, oldVal)
if (newVal != oldVal) { this.preCustomerOrgId = this.patientRegister.query.customerOrgId // console.log('this.preCustomerOrgId', this.preCustomerOrgId)
} } },
},};</script><style scoped>::v-deep .el-icon-search:before { color: #00F;}
.btn { margin-top: 5px;}
.commonbutton { width: 100px;}
.query { margin-left: 10px;}
.querySpan { margin-right: 2px;}</style>
|