You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							1937 lines
						
					
					
						
							73 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							1937 lines
						
					
					
						
							73 KiB
						
					
					
				
								<template>
							 | 
						|
								  <div>
							 | 
						|
								    <div style="display: flex">
							 | 
						|
								      <div :style="'width:' + (window.pageWidth - 110 - 20) + 'px;'">
							 | 
						|
								        <!--查询条件-->
							 | 
						|
								        <div style="position: absolute;top:30px;left:180px;display: flex; flex-wrap: wrap; height:60px;">
							 | 
						|
								          <div class="query">
							 | 
						|
								            <span class="querySpan">查找:  条码号</span>
							 | 
						|
								            <el-input placeholder="条码号" v-model="query.patientRegisterNo" size="small" 
							 | 
						|
								              clearable style="width: 140px" @change="quickQuery('patientRegisterNo')"/>
							 | 
						|
								          </div>
							 | 
						|
								          <div class="query">
							 | 
						|
								            <span class="querySpan">档案号</span>
							 | 
						|
								            <el-input placeholder="档案号" v-model="query.patientNo" size="small" 
							 | 
						|
								              clearable style="width: 100px" @change="quickQuery('patientNo')" />
							 | 
						|
								          </div>
							 | 
						|
								          <div class="query">
							 | 
						|
								            <span class="querySpan">姓名</span>
							 | 
						|
								            <el-input placeholder="姓名" v-model="query.patientName" size="small" 
							 | 
						|
								              clearable style="width: 80px" @change="quickQuery('patientName')" />
							 | 
						|
								          </div>
							 | 
						|
								          <div class="query">
							 | 
						|
								            <span class="querySpan">手机号</span>
							 | 
						|
								            <el-input placeholder="预约手机号" v-model="query.tel" size="small" 
							 | 
						|
								              clearable style="width: 120px" @change="quickQuery('tel')" />
							 | 
						|
								          </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="customerOrgId">
							 | 
						|
								                  <el-cascader v-model="form.customerOrgId" :options="patientRegister.customerOrgTreeAll"
							 | 
						|
								                    :style="'width:' + Math.floor((window.pageWidth - 510) / 4.8) + 'px;'" filterable=""
							 | 
						|
								                    :props="{ checkStrictly: true, expandTrigger: 'hover', ...customerOrg.treeprops, }" 
							 | 
						|
								                    :show-all-levels="false" :disabled="(form.id || form.registerManType == 'customer') ? true:false" size="small">
							 | 
						|
								                  </el-cascader>
							 | 
						|
								                </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" class="enterToTab" 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 class="enterToTab" v-model="form.idNo" @change="changeIdNo" size="small"></el-input>
							 | 
						|
								                </el-form-item>
							 | 
						|
								              </el-col>
							 | 
						|
								              <el-col :span="5">
							 | 
						|
								                <el-form-item label="出生日期" prop="birthDate">
							 | 
						|
								                  <!-- 
							 | 
						|
								                  <input type="date" class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" v-model="form.sexHormoneTermId" placeholder="请选择" filterable clearable size="small">
							 | 
						|
								                    <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 class="enterToTab" v-model="form.nationId" placeholder="请选择" filterable clearable
							 | 
						|
								                    :style="'width:' + Math.floor((window.pageWidth - 630) / 8) + 'px;'" size="small">
							 | 
						|
								                    <el-option v-for="item in dict.nation" :key="item.nationId" :label="item.displayName"
							 | 
						|
								                      :value="item.nationId" />
							 | 
						|
								                  </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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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 class="enterToTab" 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="organizationUnitId">
							 | 
						|
								                  <el-select v-model="form.organizationUnitId" 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="5">
							 | 
						|
								                <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"
							 | 
						|
								                    :style="'width:' + Math.floor((window.pageWidth - 654) / 4.8) + 'px;'" @change="changeMedicalTimes"
							 | 
						|
								                    value-key="id">
							 | 
						|
								                    <el-option v-for="item in customerOrgRegisterList" :key="item.id" :label="item.medicalTimes"
							 | 
						|
								                      :value="item.id" />
							 | 
						|
								                  </el-select>
							 | 
						|
								                </el-form-item>
							 | 
						|
								              </el-col>
							 | 
						|
								              <el-col :span="3">
							 | 
						|
								                <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.isPhoneFollowBox" @change="changeBox('isPhoneFollow')" />
							 | 
						|
								                </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.isVipBox" @change="changeBox('isVip')" />
							 | 
						|
								                </el-form-item>
							 | 
						|
								              </el-col>
							 | 
						|
								              <el-col :span="3">
							 | 
						|
								                <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.isNameHideBox" @change="changeBox('isNameHide')" />
							 | 
						|
								                </el-form-item>
							 | 
						|
								              </el-col>
							 | 
						|
								              <el-col :span="3">
							 | 
						|
								                <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.isLockBox" @change="changeBox('isLock')" />
							 | 
						|
								                </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 class="enterToTab" 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 class="enterToTab" 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>
							 | 
						|
								            <el-row>
							 | 
						|
								              <el-col :span="6">
							 | 
						|
								                <el-form-item label="创建人员">
							 | 
						|
								                  <el-input v-model="form.creatorId" 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.lastModifierId" 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:50px;right:' + (100 + Math.floor((window.pageWidth - 750) / 24)) + 'px; width: 150px; height: 160px;'"
							 | 
						|
								            :src="peoplePhoto">
							 | 
						|
								            <div slot="placeholder" class="image-slot">
							 | 
						|
								              加载中<span class="dot">...</span>
							 | 
						|
								            </div>
							 | 
						|
								          </el-image>
							 | 
						|
								        </div>
							 | 
						|
								        <!--人员登记组合项目明细-->
							 | 
						|
								        <div>
							 | 
						|
								          <PatientRegisterItem :prForm="form" :prAsbOpraOpts="prAsbOpraOpts" :triggerHeadSave="triggerHeadSave" :refreshFormId="refreshFormId"/>
							 | 
						|
								        </div>
							 | 
						|
								      </div>
							 | 
						|
								      <div style="margin-left: 10px;">        
							 | 
						|
								        <div>
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="photoGrah" icon="el-icon-camera">拍照</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button @click="peopleIcCard" class="btnClass">读身份证</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="rdCopy">复制新增</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="success" class="btnClass" @click="btnSubmit('form', true)">保存</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="lisRequest">检验单申请</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="lisPrint('0002', false)">条码打印</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="danger" class="btnClass" @click="reLisRequest">条码补打</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="guidePrint('0001', false)">指引单打印</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="guidePrint('0001', true)">指引单预览</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="danger" class="btnClass" @click="reMergeAsbitem">手动合并项目</el-button>
							 | 
						|
								        </div>
							 | 
						|
								
							 | 
						|
								        <div style="margin-top: 30px;">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="prAsbOpraOpts.payTypeFlag = '0'">全个人支付</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="prAsbOpraOpts.payTypeFlag = '1'">全单位支付</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="primary" class="btnClass" @click="prAsbOpraOpts.payTypeFlag = '2'">全赠送</el-button>
							 | 
						|
								        </div>
							 | 
						|
								        <div class="btn">
							 | 
						|
								          <el-button type="success" class="btnClass" @click="toCharge(form.patientRegisterNo)">收费</el-button>
							 | 
						|
								        </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" 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 @click="dialogVisible = false" style="width:90px;">取消</el-button>
							 | 
						|
								        <el-button type="primary" @click="choosePatient" style="width:90px;">确定</el-button>
							 | 
						|
								      </span>
							 | 
						|
								    </el-dialog>
							 | 
						|
								
							 | 
						|
								    <!-- 体检人员记录列表 -->
							 | 
						|
								    <el-dialog title="体检人员列表" :visible.sync="registerVisible" width="800px" :show-close="false" :close-on-click-modal="false"
							 | 
						|
								      :append-to-body="true">
							 | 
						|
								      <el-table :data="patientRegisters" border width="800" height="480" highlight-current-row
							 | 
						|
								        @row-click="registerRowClick" size="small"> 
							 | 
						|
								        <el-table-column prop="completeFlag" label="体检进度">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div>{{ dddw(dict.completeFlag, "id", scope.row.completeFlag, "displayName") }}</div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="guidePrintTimes" label="打印" width="50">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <i class="el-icon-printer" v-if="scope.row.guidePrintTimes > 0" style="font-size: 24px;color: green;"></i>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="isLock" label="锁住">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div>{{ scope.row.isLock == "Y" ? "是" : "否" }}</div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="customerOrgParentName" label="单位" width="180">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div>{{ scope.row.customerOrgParentName ? scope.row.customerOrgParentName : scope.row.customerOrgName }}</div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="customerOrgName" label="部门" width="180">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div>{{ scope.row.customerOrgParentName ? scope.row.customerOrgName : "" }}</div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="patientName" 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="age" label="年龄" />
							 | 
						|
								        <el-table-column prop="patientRegisterNo" label="条码号" width="150" />
							 | 
						|
								        <el-table-column prop="patientNo" label="档案号" />
							 | 
						|
								        <el-table-column prop="medicalTimes" label="体检次数"></el-table-column>
							 | 
						|
								        <el-table-column label="分组/套餐" width="150">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div v-if="scope.row.medicalPackageId !== dict.personOrgId && scope.row.customerOrgId === dict.personOrgId">
							 | 
						|
								              {{ dddw(dict.medicalPackage, "id", scope.row.medicalPackageId, "displayName") }}
							 | 
						|
								            </div>
							 | 
						|
								            <div v-if="scope.row.medicalPackageId !== dict.personOrgId && scope.row.customerOrgId !== dict.personOrgId">
							 | 
						|
								              {{ dddw(dict.customerOrgGroupAll, "id", scope.row.customerOrgGroupId, "displayName") }}
							 | 
						|
								            </div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="nationId" label="民族">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div>
							 | 
						|
								              {{ dddw(dict.nation, "nationId", scope.row.nationId, "displayName") }}
							 | 
						|
								            </div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="idNo" label="身份证" width="150" />
							 | 
						|
								        <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="email" label="邮箱" width="180" />
							 | 
						|
								        <el-table-column prop="mobileTelephone" label="手机" width="100" />
							 | 
						|
								        <el-table-column prop="telephone" label="电话" width="100" />
							 | 
						|
								        <el-table-column prop="address" label="地址" width="300" />
							 | 
						|
								        <el-table-column prop="medicalCardNo" label="体检卡号" />
							 | 
						|
								        <el-table-column prop="jobCardNo" label="工卡号" />
							 | 
						|
								        <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="medicalTypeId" label="体检类别">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div v-if="scope.row.medicalTypeId !== dict.personOrgId">
							 | 
						|
								              {{ dddw(dict.medicalType, "id", scope.row.medicalTypeId, "displayName") }}
							 | 
						|
								            </div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="personnelTypeId" label="人员类别">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div v-if="scope.row.personnelTypeId !== dict.personOrgId">
							 | 
						|
								              {{ dddw(dict.personnelType, "id", scope.row.personnelTypeId, "displayName") }}
							 | 
						|
								            </div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="jobPost" label="职务" />
							 | 
						|
								        <el-table-column prop="jobTitle" label="职称" />
							 | 
						|
								        <el-table-column prop="salesman" label="介绍人" />
							 | 
						|
								        <el-table-column prop="isVip" label="是否VIP">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div>{{ scope.row.isVip == "Y" ? "是" : "否" }}</div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="creatorName" label="登记人" />
							 | 
						|
								        <el-table-column prop="creationTime" label="登记日期" width="100">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div v-if="scope.row.creationTime">{{ moment(scope.row.creationTime).format("yyyy-MM-DD") }}</div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								        <el-table-column prop="isUpload" label="是否上传">
							 | 
						|
								          <template slot-scope="scope">
							 | 
						|
								            <div>{{ scope.row.isUpload == "Y" ? "是" : "否" }}</div>
							 | 
						|
								          </template>
							 | 
						|
								        </el-table-column>
							 | 
						|
								
							 | 
						|
								        <!--
							 | 
						|
								        "sexHormoneTermId": "00000000-0000-0000-0000-000000000000",
							 | 
						|
								        "interposeMeasure": null,
							 | 
						|
								        "medicalConclusionId": "00000000-0000-0000-0000-000000000000",
							 | 
						|
								        "reportPrintTimes": 0,        
							 | 
						|
								        "isMedicalStart": "N",
							 | 
						|
								        "medicalStartDate": "6/28/2023",
							 | 
						|
								        "isRecoverGuide": "N",
							 | 
						|
								        "summaryDate": "",
							 | 
						|
								        "summaryDoctor": null,
							 | 
						|
								        "isAudit": "N",
							 | 
						|
								        "auditDoctor": null,
							 | 
						|
								        "auditDate": "",        
							 | 
						|
								        "isNameHide": "N",
							 | 
						|
								        "isPhoneFollow": "N",
							 | 
						|
								        "thirdInfo": null,
							 | 
						|
								        "guidePrintTimes": null,
							 | 
						|
								        "remark": null,
							 | 
						|
								        "organizationUnitId": "00000000-0000-0000-0000-000000000000",
							 | 
						|
								        "customerOrgRegisterId": "00000000-0000-0000-0000-000000000000",
							 | 
						|
								        "lastModifierName": "",
							 | 
						|
								        "lastModificationTime": null,
							 | 
						|
								        "lastModifierId": null,
							 | 
						|
								        "creatorId": null,
							 | 
						|
								        "id": "3a0c196d-a6d0-37fe-5c32-4806bdc4530f"
							 | 
						|
								        -->
							 | 
						|
								      </el-table>
							 | 
						|
								      <span slot="footer" class="dialog-footer">
							 | 
						|
								        <el-button @click="registerVisible = false" style="width:90px;">取消</el-button>
							 | 
						|
								        <el-button type="primary" @click="chooseRegister" style="width:90px;">确定</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" :organizationUnitId="form.organizationUnitId" :brushTimes="brushTimes" />
							 | 
						|
								    </el-dialog>
							 | 
						|
								
							 | 
						|
								    <!-- 收费 -->
							 | 
						|
								    <el-dialog title="" :visible.sync="chargeVisible" :close-on-click-modal="false"
							 | 
						|
								      :append-to-body="true" fullscreen @close="closeDialogCharge">
							 | 
						|
								      <div style="margin-top: -30px;">
							 | 
						|
								        <Charge :patientRegisterNo="chargePatientRegisterNo"/>
							 | 
						|
								      </div>
							 | 
						|
								    </el-dialog>
							 | 
						|
								  </div>
							 | 
						|
								</template>
							 | 
						|
								<script>
							 | 
						|
								import moment from "moment";
							 | 
						|
								import { mapState, mapActions } from "vuex";
							 | 
						|
								import { getapi, postapi, putapi, deletapi } from "@/api/api";
							 | 
						|
								import mm from "../../utlis/mm";
							 | 
						|
								import { getKeyDown } from '../../utlis/getKeyDown'
							 | 
						|
								import { objCopy, setNull, dddw,checkIDCode, parseID, birthdayToAge,ageToBirthday, deepCopy, arrayFilter, arrayReduce,parsIcCardtoLocal, photoParse, savePeoplePhoto, arrayExistObj } from "../../utlis/proFunc";
							 | 
						|
								import Camera from "./Camera.vue";
							 | 
						|
								import PatientRegisterItem from "./PatientRegisterItem.vue";
							 | 
						|
								import LisRequest from "./LisRequest.vue";
							 | 
						|
								import MergeAsbitem from "./MergeAsbitem.vue";
							 | 
						|
								import Charge from "../../views/charge/charge.vue";
							 | 
						|
								
							 | 
						|
								export default {
							 | 
						|
								  components: {
							 | 
						|
								    Camera,
							 | 
						|
								    LisRequest,
							 | 
						|
								    MergeAsbitem,
							 | 
						|
								    PatientRegisterItem,
							 | 
						|
								    Charge,
							 | 
						|
								  },
							 | 
						|
								  props: ['formInitData', 'editTimes','refreshRegister'],
							 | 
						|
								  data() {
							 | 
						|
								    return {
							 | 
						|
								      apiurl: mm.apiurl,
							 | 
						|
								      brushTimes: 0,
							 | 
						|
								      
							 | 
						|
								      peisid: null,
							 | 
						|
								      peoplePhoto: '',
							 | 
						|
								      query: {
							 | 
						|
								        patientRegisterNo: '',
							 | 
						|
								        patientNo: '',
							 | 
						|
								        patientName: '',
							 | 
						|
								        tel: ''
							 | 
						|
								      },
							 | 
						|
								      form: {
							 | 
						|
								        registerManType:'customer', //登记人员类型,客服:customer 医生:doctor 支持在医生诊台处理登记人员
							 | 
						|
								        id: "", //id
							 | 
						|
								        photo:'', //照片
							 | 
						|
								        patientId: "00000000-0000-0000-0000-000000000000", //档案号ID 选择了档案就传档案号,未选就传00000-0000...
							 | 
						|
								        patientNo: "", //档案号
							 | 
						|
								        customerOrgId: ["00000000-0000-0000-0000-000000000000"], //单位编号 默认个人 
							 | 
						|
								        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, //条码号 【创建编辑时不操作】
							 | 
						|
								        organizationUnitId: null, //体检中心
							 | 
						|
								        address: "", //地址
							 | 
						|
								        email: "", //email
							 | 
						|
								        idNo: "", //身份证号
							 | 
						|
								        telephone: "", //电话
							 | 
						|
								        mobileTelephone: "", //手机号
							 | 
						|
								        nationId: null, //民族编号
							 | 
						|
								        birthPlaceId: null, //籍惯(出生地)
							 | 
						|
								        postalCode: "", //邮编
							 | 
						|
								        creatorId: null,
							 | 
						|
								        creationTime: "",
							 | 
						|
								        lastModificationTime: "",
							 | 
						|
								        lastModifierId: null,
							 | 
						|
								        isVipBox: false, //vip客户
							 | 
						|
								        isNameHideBox: false, //隐藏姓名
							 | 
						|
								        isPhoneFollowBox: false, //电话随访
							 | 
						|
								        isLockBox: false, //是否锁住
							 | 
						|
								        customerOrgRegisterId: null,
							 | 
						|
								        isMaxMedicalTimes: 'N',
							 | 
						|
								        medicalStartDate:null
							 | 
						|
								      }, //单位 记录 目前新增与更新是一致
							 | 
						|
								      customerOrgRegisterList: [], //单位体检次数列表
							 | 
						|
								      defaultNull: [
							 | 
						|
								        "customerOrgId",
							 | 
						|
								        "customerOrgGroupId",
							 | 
						|
								        "medicalPackageId",
							 | 
						|
								        "birthDate",
							 | 
						|
								        "age",
							 | 
						|
								        "maritalStatusId",
							 | 
						|
								        "medicalTypeId",
							 | 
						|
								        "personnelTypeId",
							 | 
						|
								        "sexHormoneTermId",
							 | 
						|
								        "organizationUnitId",
							 | 
						|
								        "nationId",
							 | 
						|
								        "birthPlaceId",
							 | 
						|
								      ], //一般uuid字段为空时,需设置为null值
							 | 
						|
								
							 | 
						|
								      rules: {
							 | 
						|
								        customerOrgId:[
							 | 
						|
								          { required: true, message: "请填写单位", trigger: "blur" },
							 | 
						|
								        ],
							 | 
						|
								        patientName: [
							 | 
						|
								          { required: true, message: "请填写姓名", trigger: "blur" },
							 | 
						|
								        ],
							 | 
						|
								        organizationUnitId: [
							 | 
						|
								          { required: true, message: "请填写体检中心", trigger: "blur" },
							 | 
						|
								        ],
							 | 
						|
								      },
							 | 
						|
								
							 | 
						|
								      dialogVisible: false,
							 | 
						|
								      patientList: [], //人员列表(用于判断人员多次体检)
							 | 
						|
								      patientChoosed: {}, //查重选中的人员
							 | 
						|
								
							 | 
						|
								      registerVisible:false,
							 | 
						|
								      patientRegisters:[],
							 | 
						|
								      registerChoosed:{},
							 | 
						|
								
							 | 
						|
								      dialogCamera: false, //拍照组件
							 | 
						|
								
							 | 
						|
								      chargeVisible:false, //用于收费
							 | 
						|
								      chargePatientRegisterNo:'',  //对哪个条码客户收费 
							 | 
						|
								
							 | 
						|
								      //人员登记,组合项目明细操作相关参数
							 | 
						|
								      prAsbOpraOpts:{
							 | 
						|
								        formId:'',      //form.id为空时,明细保存取此formId
							 | 
						|
								        copyNew:0,      //触发复制新增
							 | 
						|
								        payTypeFlag:'', //触发调整支付方式
							 | 
						|
								        prAsbSave:0, //触发组合项目明细保存
							 | 
						|
								        prAsbQuery:0,//触发组合项目明细查询,比如收费后,刷新收费状态
							 | 
						|
								        prAsbGroup:0, //触发分组更换
							 | 
						|
								        prAsbPackage:0, //触发套餐更换
							 | 
						|
								      },
							 | 
						|
								    };
							 | 
						|
								  },
							 | 
						|
								
							 | 
						|
								  created() {
							 | 
						|
								    // 初始化字典数据
							 | 
						|
								    this.dictInit()
							 | 
						|
								    getKeyDown('enterToTab')
							 | 
						|
								  },
							 | 
						|
								
							 | 
						|
								  //挂载完成
							 | 
						|
								  mounted() {
							 | 
						|
								    this.enterToTab();
							 | 
						|
								  },
							 | 
						|
								
							 | 
						|
								  computed: {
							 | 
						|
								    ...mapState(["window", "dict", "patientRegister", "customerOrg", "projPriv"]),
							 | 
						|
								
							 | 
						|
								    displayPackage(){
							 | 
						|
								      
							 | 
						|
								      let isPersonOrgId = true
							 | 
						|
								      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
							 | 
						|
								      
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    displayGroup(){      
							 | 
						|
								      let isPersonOrgId = true
							 | 
						|
								      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,
							 | 
						|
								
							 | 
						|
								    //数据初始化
							 | 
						|
								    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.items;
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								      //体检类别
							 | 
						|
								      getapi("/api/app/medical-type/in-filter").then((res) => {
							 | 
						|
								        if (res.code == 1) {
							 | 
						|
								          this.dict.medicalType = res.data.items;
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								      //人员类别
							 | 
						|
								      getapi("/api/app/personnel-type/in-filter").then((res) => {
							 | 
						|
								        if (res.code == 1) {
							 | 
						|
								          this.dict.personnelType = res.data.items;
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								      //婚姻状况
							 | 
						|
								      getapi("/api/app/marital-statuses").then((res) => {
							 | 
						|
								        if (res.code == 1) {
							 | 
						|
								          this.dict.maritalStatus = res.data.items;
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								      //性激素期
							 | 
						|
								      getapi("/api/app/sex-hormone-term/in-filter").then((res) => {
							 | 
						|
								        if (res.code == 1) {
							 | 
						|
								          this.dict.sexHormoneTerm = res.data.items;
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								      //民族
							 | 
						|
								      getapi("/api/app/nation/in-filter").then((res) => {
							 | 
						|
								        if (res.code != -1) {
							 | 
						|
								          this.dict.nation = res.data;
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								      //籍惯 ,出生地
							 | 
						|
								      getapi("/api/app/birth-place/in-filter").then((res) => {
							 | 
						|
								        if (res.code == 1) {
							 | 
						|
								          this.dict.birthPlace = res.data.items;
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								      //套餐
							 | 
						|
								      postapi("/api/app/medicalpackage/getmedicalpackagelist",{}).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/getasbitemlist",{isFilterActive:'Y'}).then((res) => {
							 | 
						|
								      //   if (res.code != -1) {
							 | 
						|
								      //     this.dict.asbItemAll = res.data;
							 | 
						|
								      //   }
							 | 
						|
								      // });
							 | 
						|
								
							 | 
						|
								      console.log("dict", this.dict);
							 | 
						|
								    },
							 | 
						|
								    
							 | 
						|
								    //初始form表单数据
							 | 
						|
								    async initFormData(){
							 | 
						|
								      objCopy(this.formInitData, this.form);
							 | 
						|
								      this.peisid = window.sessionStorage.getItem('peisid');
							 | 
						|
								      if (!this.form.id) {
							 | 
						|
								        this.form.organizationUnitId = this.peisid;
							 | 
						|
								      }
							 | 
						|
								      this.initBox();
							 | 
						|
								      this.getPeoplePhoto(this.form.photo)
							 | 
						|
								
							 | 
						|
								      // 单位/个人 的分组与套餐处理
							 | 
						|
								      await this.changeCustomerOrgId(this.form.customerOrgId)
							 | 
						|
								      
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //选择单位
							 | 
						|
								    async changeCustomerOrgId(v){
							 | 
						|
								      let  customerOrgParentId = await this.getParentCustomerOrgId(v)
							 | 
						|
								      if(customerOrgParentId){
							 | 
						|
								        if (customerOrgParentId == this.dict.personOrgId) {          
							 | 
						|
								          this.form.customerOrgRegisterId = null
							 | 
						|
								          this.form.customerOrgGroupId = null
							 | 
						|
								          this.patientRegister.customerOrgGroup = []          
							 | 
						|
								        }else{
							 | 
						|
								          this.form.medicalPackageId = null
							 | 
						|
								          //获取单位体检次数
							 | 
						|
								          this.getCustomerOrgRegisterList(customerOrgParentId)
							 | 
						|
								        }
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    // 获取顶级单位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/${this.form.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){
							 | 
						|
								          this.customerOrgRegisterList = arrayFilter(res.data, 'isComplete', 'N')  //不显示已完成的体检次数
							 | 
						|
								          if(this.customerOrgRegisterList.length > 0){
							 | 
						|
								            this.form.customerOrgRegisterId = this.customerOrgRegisterList[this.customerOrgRegisterList.length - 1].id
							 | 
						|
								            return getapi(`/api/app/customerorggroup/getlistinfilter?CustomerOrgRegisterId=${this.form.customerOrgRegisterId}`) //获取单位分组
							 | 
						|
								          }
							 | 
						|
								        }
							 | 
						|
								      }).then(res =>{
							 | 
						|
								        if(res.code != -1){
							 | 
						|
								          this.patientRegister.customerOrgGroup = res.data.items;
							 | 
						|
								        }
							 | 
						|
								      })     
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //快速查找个人数据
							 | 
						|
								    quickQuery(type) {
							 | 
						|
								      let url1 = '/api/app/patientregister/getpatientregisterorpatient'
							 | 
						|
								      let body={}
							 | 
						|
								      let url2 = '/api/app/patientregister/getlistinfilter'
							 | 
						|
								      
							 | 
						|
								      switch (type) {
							 | 
						|
								        case 'patientNo':
							 | 
						|
								          if(!this.query.patientNo) return;  
							 | 
						|
								          body = {
							 | 
						|
								            sType:2,
							 | 
						|
								            patientNo:this.query.patientNo
							 | 
						|
								          }
							 | 
						|
								          this.getpatientregisterorpatient(url1,body)
							 | 
						|
								          break;
							 | 
						|
								        case 'patientRegisterNo':  
							 | 
						|
								          if(!this.query.patientRegisterNo) return;       
							 | 
						|
								          body = {
							 | 
						|
								            sType:1,
							 | 
						|
								            patientRegisterNo:this.query.patientRegisterNo
							 | 
						|
								          }
							 | 
						|
								          this.getpatientregisterorpatient(url1,body)
							 | 
						|
								          break;
							 | 
						|
								        case 'tel':
							 | 
						|
								          if(!this.query.tel) return;
							 | 
						|
								          body = {
							 | 
						|
								            phone:this.query.tel
							 | 
						|
								          }
							 | 
						|
								          this.getlistinfilter(url2,body);
							 | 
						|
								          break;
							 | 
						|
								        case 'patientName':
							 | 
						|
								          if(!this.query.patientName) return;
							 | 
						|
								          body = {
							 | 
						|
								            patientName:this.query.patientName
							 | 
						|
								          }
							 | 
						|
								          this.getlistinfilter(url2,body);
							 | 
						|
								          break;
							 | 
						|
								        default:
							 | 
						|
								          return;
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //按流水号或档案号查客户信息
							 | 
						|
								    getpatientregisterorpatient(url,body){
							 | 
						|
								      postapi(url,body)
							 | 
						|
								        .then((res) => {
							 | 
						|
								          console.log('getpatientregisterorpatient', res)
							 | 
						|
								          if (res.code == 1) {            
							 | 
						|
								            objCopy(res.data, this.form)
							 | 
						|
								            this.patientRegister.patientRegisterId = res.data.id
							 | 
						|
								            this.patientRegister.photo = res.data.photo
							 | 
						|
								            this.getPatientRegisterAbs(res.data.id)
							 | 
						|
								          }else if(res.code == 0){
							 | 
						|
								            this.$message.info("未找到相关信息")            
							 | 
						|
								          } 
							 | 
						|
								        });
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //按手机号或姓名查找客户信息
							 | 
						|
								    getlistinfilter(url,body){
							 | 
						|
								      postapi(url, body)
							 | 
						|
								        .then((res) => {
							 | 
						|
								          if (res.code != -1) {
							 | 
						|
								            if(res.data.items.length == 0){
							 | 
						|
								              this.$message.info("未找到相关信息")
							 | 
						|
								            }else if(res.data.items.length == 1){
							 | 
						|
								              objCopy(res.data.items[0], this.form)
							 | 
						|
								              objCopy(res.data.items[0], this.patientRegister.patientRegisterRd)              
							 | 
						|
								              this.patientRegister.patientRegisterId = res.data.items[0].id
							 | 
						|
								              this.patientRegister.photo = res.data.items[0].photo
							 | 
						|
								              this.getPatientRegisterAbs(res.data.items[0].id)
							 | 
						|
								            }else{
							 | 
						|
								              //显示列表,供选择
							 | 
						|
								              this.patientRegisters = res.data.items
							 | 
						|
								              this.registerVisible = true
							 | 
						|
								            }            
							 | 
						|
								          }          
							 | 
						|
								        });
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //读取身份证信息
							 | 
						|
								    peopleIcCard() {
							 | 
						|
								      if(!this.$peisAPI) {
							 | 
						|
								        this.$message.info("此功能,需要在壳客户端才可运行!")
							 | 
						|
								        return       
							 | 
						|
								      }
							 | 
						|
								      this.$peisAPI.peopleIcCard().then(res => {
							 | 
						|
								        console.log('peopleIcCard',res)
							 | 
						|
								        let lres = JSON.parse(res)
							 | 
						|
								        if (lres.code >= 0) {          
							 | 
						|
								          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.patientRegister.photo = 'data:image/bmp;base64,' + idNos.Photo
							 | 
						|
								        }
							 | 
						|
								      })
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //获取单位体检次数列表,并默认赋最后一次体检次数
							 | 
						|
								    // async getCustomerOrgRegisterList() {
							 | 
						|
								    //   this.customerOrgRegisterList = []
							 | 
						|
								    //   if (this.form.customerOrgId == this.dict.personOrgId) {
							 | 
						|
								    //     this.form.customerOrgRegisterId = null
							 | 
						|
								    //     return
							 | 
						|
								    //   }
							 | 
						|
								    //   try {
							 | 
						|
								    //     let res = await getapi(`/api/app/customer-org/parent/${this.form.customerOrgId}`);
							 | 
						|
								    //     let res1 = await getapi(`/api/app/customerorgregister/getlistincustomerorgid?CustomerOrgId=${res.data}`);
							 | 
						|
								    //     this.customerOrgRegisterList = arrayFilter(res1.data, 'isComplete', 'N')
							 | 
						|
								        
							 | 
						|
								    //     //要把已完成体检的次数去掉 (查询时不能触发保存)
							 | 
						|
								    //     // if (this.customerOrgRegisterList.length > 0) {
							 | 
						|
								    //     //   this.form.customerOrgRegisterId = this.customerOrgRegisterList[this.customerOrgRegisterList.length - 1].id
							 | 
						|
								    //     //   //this.changeCustomerOrgGroupId()
							 | 
						|
								    //     //   this.changeMedicalTimes()
							 | 
						|
								    //     // }
							 | 
						|
								
							 | 
						|
								    //   } catch (error) {
							 | 
						|
								    //     console.log(error)
							 | 
						|
								    //   }
							 | 
						|
								    // },
							 | 
						|
								
							 | 
						|
								    //修改单位体检次数
							 | 
						|
								    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({ type: "info", 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 = []
							 | 
						|
								      getapi(`/api/app/customerorggroup/getlistinfilter?CustomerOrgRegisterId=${customerOrgRegisterId}`).then(res => {
							 | 
						|
								        if (res.code != - 1) {
							 | 
						|
								          this.patientRegister.customerOrgGroup = res.data.items;
							 | 
						|
								        }
							 | 
						|
								      })
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //修改出生日期
							 | 
						|
								    changeBirthDate() {
							 | 
						|
								      this.form.age = birthdayToAge(this.form.birthDate)
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //修改出生日期
							 | 
						|
								    changeAge() {
							 | 
						|
								      this.form.birthDate = ageToBirthday(this.form.age)
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //修改身份证,生成年龄、出生、性别
							 | 
						|
								    changeIdNo() {
							 | 
						|
								      this.Query(this.form.idNo)
							 | 
						|
								      let ret = parseID(this.form.idNo)
							 | 
						|
								      if (ret.age != -1) {
							 | 
						|
								        this.form.birthDate = new Date(ret.birthday)
							 | 
						|
								        this.form.age = ret.age
							 | 
						|
								        this.form.sexId = ret.sex
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    // //分组改变时触发
							 | 
						|
								    changeCustomerOrgGroupId() {
							 | 
						|
								      // this.patientRegister.customerOrgGroupChange++;      
							 | 
						|
								      // if (this.form.id) this.btnSubmit('form', false);
							 | 
						|
								      // this.getGroupPackageAsb('group',this.form.customerOrgGroupId)
							 | 
						|
								      this.prAsbOpraOpts.prAsbGroup++
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    // //套餐改变时触发
							 | 
						|
								    changeMedicalPackageId() {
							 | 
						|
								      // this.patientRegister.medicalPackageChange++;
							 | 
						|
								      // if (this.form.id) this.btnSubmit('form', false);
							 | 
						|
								      // this.getGroupPackageAsb('package',this.form.medicalPackageId)
							 | 
						|
								      this.prAsbOpraOpts.prAsbPackage++
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //根据姓名,身份证号 查询档案信息,用于判断人员多次体检
							 | 
						|
								    Query(param) {
							 | 
						|
								      //编辑的时候不查重
							 | 
						|
								      if (this.form.id || !param) return;
							 | 
						|
								
							 | 
						|
								      //console.log(`/api/app/patient/in-filter?Filter=${param}`)
							 | 
						|
								      let body = {
							 | 
						|
								        filter:param,
							 | 
						|
								        maxResultCount:500
							 | 
						|
								      }
							 | 
						|
								      
							 | 
						|
								      postapi('/api/app/patient/getlistinfilter',body).then((res) => {
							 | 
						|
								        if (res.code != -1) {
							 | 
						|
								          console.log("查重 ", res); //有数据才显示
							 | 
						|
								          if (res.data.items && res.data.items.length > 0) {
							 | 
						|
								            this.patientList = res.data.items;
							 | 
						|
								            this.dialogVisible = true;
							 | 
						|
								          }
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //列表选中
							 | 
						|
								    rowick(row) {
							 | 
						|
								      this.patientChoosed = row;
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //确定选择人员
							 | 
						|
								    choosePatient() {
							 | 
						|
								      if (!this.patientChoosed) {
							 | 
						|
								        alert("请选中人员档案信息");
							 | 
						|
								        return;
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      this.dialogVisible = false;
							 | 
						|
								
							 | 
						|
								      this.form.patientId = this.patientChoosed.id;
							 | 
						|
								      this.form.patientName = this.patientChoosed.displayName;
							 | 
						|
								      this.form.sexId = this.patientChoosed.sexId;
							 | 
						|
								      this.form.maritalStatusId = this.patientChoosed.maritalStatusId;
							 | 
						|
								      this.form.birthDate = new Date(this.patientChoosed.birthDate);
							 | 
						|
								      this.form.nationId = this.patientChoosed.nationId;
							 | 
						|
								      this.form.idNo = this.patientChoosed.idNo;
							 | 
						|
								      this.form.telephone = this.patientChoosed.telephone;
							 | 
						|
								      this.form.mobileTelephone = this.patientChoosed.mobileTelephone;
							 | 
						|
								      this.form.patientNo = this.patientChoosed.patientNo;
							 | 
						|
								      this.form.medicalTimes = this.patientChoosed.medicalTimes + 1;
							 | 
						|
								
							 | 
						|
								      if (this.form.birthDate) {
							 | 
						|
								        this.form.age = birthdayToAge(this.form.birthDate)
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      if (this.form.idNo) {
							 | 
						|
								        let ret = parseID(this.form.idNo)
							 | 
						|
								
							 | 
						|
								        if (!this.form.birthDate) this.form.birthDate = new Date(ret.birthday)
							 | 
						|
								        if (!this.form.age) this.form.age = ret.age
							 | 
						|
								        if (!this.form.sexId) this.form.age = ret.sex
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    registerRowClick(row){
							 | 
						|
								      this.registerChoosed = row;
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    chooseRegister(){
							 | 
						|
								      if (!this.registerChoosed) {
							 | 
						|
								        alert("请选中人员档案信息");
							 | 
						|
								        return;
							 | 
						|
								      }
							 | 
						|
								       
							 | 
						|
								      objCopy(this.registerChoosed, this.form)
							 | 
						|
								      this.patientRegister.patientRegisterId = this.registerChoosed.id
							 | 
						|
								      this.patientRegister.photo = this.registerChoosed.photo
							 | 
						|
								      this.registerVisible = false
							 | 
						|
								      this.getPatientRegisterAbs(this.registerChoosed.id)
							 | 
						|
								    },
							 | 
						|
								  
							 | 
						|
								    changeBox(type) {
							 | 
						|
								      //赋值
							 | 
						|
								      if (this.form[type + 'Box']) {
							 | 
						|
								        this.form[type] = 'Y';
							 | 
						|
								      } else {
							 | 
						|
								        this.form[type] = 'N';
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    initBox() {
							 | 
						|
								      if (this.form.isVip == 'Y') {
							 | 
						|
								        this.form.isVipBox = true;
							 | 
						|
								      } else {
							 | 
						|
								        this.form.isVipBox = false;
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      if (this.form.isNameHide == 'Y') {
							 | 
						|
								        this.form.isNameHideBox = true;
							 | 
						|
								      } else {
							 | 
						|
								        this.form.isNameHideBox = false;
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      if (this.form.isPhoneFollow == 'Y') {
							 | 
						|
								        this.form.isPhoneFollowBox = true;
							 | 
						|
								      } else {
							 | 
						|
								        this.form.isPhoneFollowBox = false;
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      if (this.form.isLock == 'Y') {
							 | 
						|
								        this.form.isLockBox = true;
							 | 
						|
								      } else {
							 | 
						|
								        this.form.isLockBox = false;
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      if (!this.form.id) {
							 | 
						|
								        this.form.organizationUnitId = this.peisid;
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    // 组装基本信息保存的参数体
							 | 
						|
								    madePrBody(){
							 | 
						|
								      //赋值
							 | 
						|
								      let body = deepCopy(this.form);
							 | 
						|
								
							 | 
						|
								      if (this.form.birthDate && this.form.birthDate != "Invalid date") {
							 | 
						|
								        body.birthDate = moment(this.form.birthDate).format("yyyy-MM-DD")
							 | 
						|
								      }else{
							 | 
						|
								        body.birthDate = null
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      delete body.registerManType;
							 | 
						|
								      delete body.id;
							 | 
						|
								      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(fields[Object.keys(fields)[0]][0].message);
							 | 
						|
								          return false
							 | 
						|
								        }
							 | 
						|
								
							 | 
						|
								        if(this.form.customerOrgId != this.dict.personOrgId){
							 | 
						|
								          if(!this.form.customerOrgRegisterId){
							 | 
						|
								            this.$message.warning("请填写单位体检次数!");
							 | 
						|
								            return false
							 | 
						|
								          }
							 | 
						|
								        }
							 | 
						|
								
							 | 
						|
								        if(this.form.idNo && checkIDCode(this.form.idNo) == false){
							 | 
						|
								          this.$message.warning("身份证号填写不合法!");
							 | 
						|
								          return false
							 | 
						|
								        }        
							 | 
						|
								                
							 | 
						|
								        
							 | 
						|
								
							 | 
						|
								        if (this.form.id){
							 | 
						|
								          // 更新时,先保存明细,再更新主表
							 | 
						|
								          this.prAsbOpraOpts.prAsbSave++  //触发组合项目保存
							 | 
						|
								        }else {
							 | 
						|
								          let body = this.madePrBody()
							 | 
						|
								          //id为空则新增
							 | 
						|
								          console.log(`/api/patientregister/createreturninfo`, body);
							 | 
						|
								          postapi(`/api/patientregister/createreturninfo`, body).then(
							 | 
						|
								            (res) => {
							 | 
						|
								              if (res.code == 1) {
							 | 
						|
								                //console.log('res',res)
							 | 
						|
								                if (msgTip) this.$message.success("操作成功");
							 | 
						|
								
							 | 
						|
								                //触发已选组合项目保存
							 | 
						|
								                this.prAsbOpraOpts.formId = res.data.id
							 | 
						|
								                let temp = Object.assign({},res.data,{id:''})
							 | 
						|
								                objCopy(temp,this.form)
							 | 
						|
								
							 | 
						|
								                // 稍作延时,否则 this.prAsbOpraOpts.formId 尚未更新
							 | 
						|
								                setTimeout(() =>{
							 | 
						|
								                  this.prAsbOpraOpts.prAsbSave++
							 | 
						|
								                },100)
							 | 
						|
								
							 | 
						|
								                this.refreshRegister(Object.assign({},res.data))
							 | 
						|
								
							 | 
						|
								                //一般读身份证照片时,会出现这种情况
							 | 
						|
								                if (this.patientRegister.photo.indexOf("data:image") > -1) savePeoplePhoto(res.data.id, this.patientRegister.photo);
							 | 
						|
								              }
							 | 
						|
								            }
							 | 
						|
								          );
							 | 
						|
								        }
							 | 
						|
								        
							 | 
						|
								      });
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //将现有的数据,复制并展现,但未保存
							 | 
						|
								    rdCopy() {
							 | 
						|
								      if (!this.form.id) {
							 | 
						|
								        this.$message.info("该信息尚未保存,不可执行此操作!");
							 | 
						|
								        return;
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      this.patientRegister.photo = '/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.patientRegister.patientRegisterAbs.forEach(e => {
							 | 
						|
								      //   e.id = '';
							 | 
						|
								      //   e.patientRegisterId = '';
							 | 
						|
								      //   e.isCharge = 'N';
							 | 
						|
								      //   e.checkCompleteFlag = '0'
							 | 
						|
								      //   e.isLock = 'N'
							 | 
						|
								      // });
							 | 
						|
								      // 触发明细项目复制
							 | 
						|
								      setTimeout(() => {
							 | 
						|
								        this.prAsbOpraOpts.copyNew++
							 | 
						|
								      }, 100);
							 | 
						|
								
							 | 
						|
								      // console.log('this.patientRegister.patientRegisterAbs',this.patientRegister.patientRegisterAbs)
							 | 
						|
								      this.$message.info("操作成功,请记得点保存");
							 | 
						|
								      this
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //删除
							 | 
						|
								    del() {
							 | 
						|
								      deletapi(
							 | 
						|
								        `/api/app/customer-org/${this.customerOrg.customerOrgRd.id}`
							 | 
						|
								      ).then((res) => {
							 | 
						|
								        this.$message.success("删除 操作成功");
							 | 
						|
								        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("此功能,需要在壳客户端才可运行!")
							 | 
						|
								        return       
							 | 
						|
								      }
							 | 
						|
								      this.$peisAPI.photoGrah()
							 | 
						|
								        .then(res => {
							 | 
						|
								          console.log(res)
							 | 
						|
								          //alert(res)
							 | 
						|
								          let lres = JSON.parse(res)
							 | 
						|
								          if (lres.code && lres.code.toLowerCase() == 'success') {
							 | 
						|
								            let uploadPhoto = {
							 | 
						|
								              patientRegisterId: this.form.id,
							 | 
						|
								              photo: lres.Photo,
							 | 
						|
								            };
							 | 
						|
								            this.patientRegister.photo = `data:image/${lres.PhotoFormat};base64,${lres.Photo}`
							 | 
						|
								            return postapi(`/api/app/patient-register/up-load-img`, uploadPhoto)
							 | 
						|
								          } else {
							 | 
						|
								            this.$message.error("上传照片错误" + lres.code)
							 | 
						|
								          }
							 | 
						|
								        }).then(res => {
							 | 
						|
								          if (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.code != -1) {
							 | 
						|
								            //console.log('拍照',res.data)
							 | 
						|
								            this.patientRegister.patientRegisterRd.photo = res.data.photo
							 | 
						|
								            this.$message.success("操作成功");
							 | 
						|
								          }
							 | 
						|
								        }).catch(err => {
							 | 
						|
								          console.log('this.$peisAPI.photoGrah', err)
							 | 
						|
								        })
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    getPeoplePhoto(photo) {
							 | 
						|
								      this.peoplePhoto = photoParse(photo)
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    // 打印指引单(isPreview)
							 | 
						|
								    async guidePrint(ReportCode, isPreview) {
							 | 
						|
								      if (this.form.id.length < 1) {
							 | 
						|
								        this.$message.info("人员信息尚未保存,不可执行此操作!");
							 | 
						|
								        return;
							 | 
						|
								      }
							 | 
						|
								      if(!this.$peisAPI) {
							 | 
						|
								        this.$message.info("此功能,需要在壳客户端才可运行!")
							 | 
						|
								        return       
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      let token = window.sessionStorage.getItem('token');
							 | 
						|
								      let user = window.sessionStorage.getItem('user');
							 | 
						|
								      let toOutShell = {
							 | 
						|
								        ReportCode, token,
							 | 
						|
								        preViewCanPrint: 'N',
							 | 
						|
								        Parameters: [
							 | 
						|
								          { Name: 'printer', Value: user },
							 | 
						|
								          { Name: 'hisLog', Value: 'pic/hisLog.jpg' },
							 | 
						|
								        ],
							 | 
						|
								      };
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								      if (isPreview) {
							 | 
						|
								        //
							 | 
						|
								        //this.multipleSelection.forEach((item,index) =>{
							 | 
						|
								        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(err);
							 | 
						|
								          });
							 | 
						|
								        // });
							 | 
						|
								      } else {
							 | 
						|
								
							 | 
						|
								        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.print(JSON.stringify(toOutShell));
							 | 
						|
								            }
							 | 
						|
								          })
							 | 
						|
								          .then(res => {
							 | 
						|
								            //console.log('this.$peisAPI.print',res)
							 | 
						|
								            if (JSON.parse(res).code >= 0) {
							 | 
						|
								              //更新打印次数
							 | 
						|
								              return postapi('/api/app/patientregister/updatepatientregisterguideprinttimesmany', [this.form.id])
							 | 
						|
								            }
							 | 
						|
								          })
							 | 
						|
								          .then(res => {
							 | 
						|
								            if (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(err => {
							 | 
						|
								            this.$message.warning(err);
							 | 
						|
								          });
							 | 
						|
								
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //检验申请
							 | 
						|
								    async lisRequest() {
							 | 
						|
								      let isPrintLisRequest = false
							 | 
						|
								      let res = null
							 | 
						|
								      if (this.form.id.length < 1) {
							 | 
						|
								        this.$message.info("人员信息尚未保存,不可执行此操作!");
							 | 
						|
								        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);
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //条码打印
							 | 
						|
								    lisPrint(ReportCode, isPreview) {
							 | 
						|
								      if (this.form.id.length < 1) {
							 | 
						|
								        this.$message.info("人员信息尚未保存,不可执行此操作!");
							 | 
						|
								        return;
							 | 
						|
								      }
							 | 
						|
								      if(!this.$peisAPI) {
							 | 
						|
								        this.$message.info("此功能,需要在壳客户端才可运行!")
							 | 
						|
								        return       
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      let token = window.sessionStorage.getItem('token');
							 | 
						|
								      let user = window.sessionStorage.getItem('user');
							 | 
						|
								      let toOutShell = {
							 | 
						|
								        ReportCode, token,
							 | 
						|
								        Parameters: [
							 | 
						|
								          { Name: 'printer', Value: user },
							 | 
						|
								          { Name: 'hisLog', Value: 'pic/hisLog.jpg' },
							 | 
						|
								        ],
							 | 
						|
								      };
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								      if (isPreview) {
							 | 
						|
								        //http://140.143.162.39:9529/api/app/printreport/getlisrequestreport?PatientRegisterId=3a0d2e90-da68-3746-6775-bf17e5f9b295
							 | 
						|
								        //this.multipleSelection.forEach((item,index) =>{
							 | 
						|
								        postapi(`/api/app/printreport/getlisrequestreport?PatientRegisterId=${this.form.id}`)
							 | 
						|
								          .then((res) => {
							 | 
						|
								            if (res.code != -1) {
							 | 
						|
								              toOutShell.ReportTable = { lisRequest: res.data };
							 | 
						|
								              console.log('JSON.stringify(toOutShell)', JSON.stringify(toOutShell));
							 | 
						|
								              return this.$peisAPI.printPre(JSON.stringify(toOutShell));
							 | 
						|
								            }
							 | 
						|
								          })
							 | 
						|
								          .catch(err => {
							 | 
						|
								            this.$message.warning(err);
							 | 
						|
								          });
							 | 
						|
								        // });
							 | 
						|
								      } else {
							 | 
						|
								
							 | 
						|
								        postapi(`/api/app/printreport/getlisrequestreport?PatientRegisterId=${this.form.id}`)
							 | 
						|
								          .then((res) => {
							 | 
						|
								            if (res.code != -1) {
							 | 
						|
								              toOutShell.ReportTable = { lisRequest: res.data };
							 | 
						|
								              console.log('JSON.stringify(toOutShell)', JSON.stringify(toOutShell));
							 | 
						|
								              return this.$peisAPI.print(JSON.stringify(toOutShell));
							 | 
						|
								            }
							 | 
						|
								          })
							 | 
						|
								          .then(res => {
							 | 
						|
								            if (res.code != -1) {
							 | 
						|
								              //更新打印状态  /api/app/lisrequest/updatelisrequestisprint
							 | 
						|
								              // {
							 | 
						|
								              //   "operateType": 0,  操作类型(1.按PatientRegisterId 2.按LisRequestId)
							 | 
						|
								              //   "patientRegisterId": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
							 | 
						|
								              //   "lisRequestId": "3fa85f64-5717-4562-b3fc-2c963f66afa6"
							 | 
						|
								              // }
							 | 
						|
								              return postapi('/api/app/lisrequest/updatelisrequestisprint', { operateType: 1, patientRegisterId: this.form.id })
							 | 
						|
								            }
							 | 
						|
								          })
							 | 
						|
								          .catch(err => {
							 | 
						|
								            this.$message.warning(err);
							 | 
						|
								          });
							 | 
						|
								
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //补打条码
							 | 
						|
								    reLisRequest() {
							 | 
						|
								      if (this.form.id.length < 1) {
							 | 
						|
								        this.$message.info("人员信息尚未保存,不可执行此操作!");
							 | 
						|
								        return;
							 | 
						|
								      }
							 | 
						|
								      this.brushTimes++;
							 | 
						|
								      this.patientRegister.lisRequestVisble = true;
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //手动合并项目
							 | 
						|
								    reMergeAsbitem() {
							 | 
						|
								      if (this.form.id.length < 1) {
							 | 
						|
								        this.$message.info("人员信息尚未保存,不可执行此操作!");
							 | 
						|
								        return;
							 | 
						|
								      }
							 | 
						|
								      this.brushTimes++;
							 | 
						|
								      this.patientRegister.mergeAsbitemVisble = true;
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    toCharge(patientRegisterNo) {
							 | 
						|
								      if(!patientRegisterNo){
							 | 
						|
								        this.$message.warning("请先保存人员信息!")
							 | 
						|
								        return
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      //多次重复点击时,刷新处理
							 | 
						|
								      this.chargePatientRegisterNo = ''
							 | 
						|
								      setTimeout(() => { 
							 | 
						|
								        this.chargePatientRegisterNo = patientRegisterNo
							 | 
						|
								      }, 100)
							 | 
						|
								            
							 | 
						|
								      //this.$router.push({ path: "/charge" });
							 | 
						|
								      this.chargeVisible = true
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //关闭收费窗口时,刷新收费状态信息
							 | 
						|
								    closeDialogCharge(){
							 | 
						|
								      // this.getPatientRegisterAbs(this.form.id)
							 | 
						|
								      this.prAsbOpraOpts.prAsbQuery++
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //触发人员信息保存(更新)
							 | 
						|
								    triggerHeadSave(){
							 | 
						|
								      //id不为空则编辑 api/patientregister/updatepatientregister
							 | 
						|
								      let body = this.madePrBody()
							 | 
						|
								      // console.log(`/api/patientregister/updatepatientregister?PatientRegisterId=${this.form.id}`, body);
							 | 
						|
								      postapi(`/api/patientregister/updatepatientregister?PatientRegisterId=${this.form.id}`, body).then((res) => {
							 | 
						|
								        if (res.code != -1) {
							 | 
						|
								          this.$message.success("操作成功");
							 | 
						|
								          //一般读身份证照片时,会出现这种情况
							 | 
						|
								          if (this.patientRegister.photo.indexOf("data:image") > -1) savePeoplePhoto(this.form.id, this.patientRegister.photo);
							 | 
						|
								          objCopy(this.form, this.patientRegister.patientRegisterRd);
							 | 
						|
								
							 | 
						|
								          this.refreshRegister(Object.assign({},this.form))
							 | 
						|
								        }
							 | 
						|
								      });
							 | 
						|
								      
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    // 新增保存基本信息产生新的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();   
							 | 
						|
								              
							 | 
						|
								              // 跳至下一个输入框
							 | 
						|
								              for(let j=i+1; j<inputs.length;j++){
							 | 
						|
								                if(inputs[j].getAttribute('disabled') != "disabled" ){
							 | 
						|
								                  inputs[j].focus();
							 | 
						|
								                  break;
							 | 
						|
								                }
							 | 
						|
								              }              
							 | 
						|
								            }
							 | 
						|
								          });
							 | 
						|
								        });
							 | 
						|
								      });
							 | 
						|
								    }, 
							 | 
						|
								
							 | 
						|
								  },
							 | 
						|
								
							 | 
						|
								  //监听事件
							 | 
						|
								  watch: {
							 | 
						|
								
							 | 
						|
								    "formInitData.id":{
							 | 
						|
								      immediate:true,
							 | 
						|
								      // deep:true,
							 | 
						|
								      handler(newVal, oldVal) {
							 | 
						|
								        console.log('watch:formInitData.id:',newVal,' oldVal:',oldVal)
							 | 
						|
								        if (newVal != oldVal) {
							 | 
						|
								          this.initFormData()
							 | 
						|
								        }
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //新增或编辑
							 | 
						|
								    "editTimes"(newVal, oldVal) {
							 | 
						|
								      console.log('editTimes newVal:',newVal,' oldVal:',oldVal)
							 | 
						|
								      if (newVal != oldVal) {
							 | 
						|
								        this.initFormData()
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //拍照触发
							 | 
						|
								    "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)
							 | 
						|
								        }
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								  },
							 | 
						|
								};
							 | 
						|
								</script>
							 | 
						|
								<style scoped>
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								.btn {
							 | 
						|
								  margin-top: 5px;
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								.btnClass {
							 | 
						|
								  width: 100px;
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								.query {
							 | 
						|
								  margin-left: 10px;
							 | 
						|
								}
							 | 
						|
								.querySpan {
							 | 
						|
								  margin-right: 2px;
							 | 
						|
								}
							 | 
						|
								</style>
							 |