|
|
|
<template>
|
|
|
|
<div id="operation-record" style=" background: #fff; padding: 10px 20px 50px 20px;page-break-after:always">
|
|
|
|
<div v-if="!onlyRead" class="btnBox">
|
|
|
|
<el-button v-print="'#eyesFunc'" size="small" @click="handleSaveTable">打印</el-button>
|
|
|
|
<el-button type="primary" size="small" @click="handleSaveTable">保存</el-button>
|
|
|
|
<el-button type="danger" size="small" @click="handleDelete">删除</el-button>
|
|
|
|
</div>
|
|
|
|
<div id="eyesFunc" style="width: 840px;padding-right: 8px" class="printBox">
|
|
|
|
<div class="flex j-c">
|
|
|
|
<img width="450" src="@/assets/img/xianganlogo.png">
|
|
|
|
</div>
|
|
|
|
<p style="color:#000000;font-size:32px;margin:16px 0;text-align:center;">
|
|
|
|
双眼视功能检查报告单
|
|
|
|
</p>
|
|
|
|
<div style="display: flex;justify-content: space-around">
|
|
|
|
<span class="bold">登记号:<el-input v-model="formData.patientId" style="width: 120px" size="small" clearable placeholder="" /></span>
|
|
|
|
<span class="bold">姓名:<el-input v-model="formData.patientName" style="width: 120px" size="small" clearable placeholder="" /></span>
|
|
|
|
<span class="bold">性别:<el-input v-model="formData.patientSex" style="width: 120px" size="small" clearable placeholder="" /></span>
|
|
|
|
<span class="bold">年龄:<el-input v-model="formData.patientAge" style="width: 120px" size="small" clearable placeholder="" /></span>
|
|
|
|
</div>
|
|
|
|
<div class="operation-record-table eyesTable">
|
|
|
|
<el-table :data="tableData" :span-method="objectSpanMethod" border style="width: 100%; margin-top: 20px">
|
|
|
|
<el-table-column label="" width="200" align="center" :resizable="false">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<div v-if="scope.row.name == '1'">
|
|
|
|
<div class="width-120 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">OS:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">X</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-else-if="scope.row.name == '集合近点(NPC)'">
|
|
|
|
<p>{{ scope.row.name }}</p>
|
|
|
|
<div style="border-top: 1px solid #D9D9D9;display: flex;flex-wrap: wrap;margin: 3px 0">
|
|
|
|
<div v-for="(item,index) in npcList" :key="index" class="check" style="margin-left: 8px;font-size: 14px" @click="item.isSelect = !item.isSelect">
|
|
|
|
<input type="checkbox" :checked="item.isSelect">
|
|
|
|
<div>{{ item.name }}</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-else-if="scope.row.name == '梯度性AC/A'">
|
|
|
|
<p>{{ scope.row.name }}</p>
|
|
|
|
<div style="border-top: 1px solid #D9D9D9;display: flex;flex-wrap: wrap;margin: 3px 0">
|
|
|
|
<div v-for="(item,index) in acaList" :key="index" class="check" style="margin-left: 8px;font-size: 14px" @click="item.isSelect = !item.isSelect">
|
|
|
|
<input type="checkbox" :checked="item.isSelect">
|
|
|
|
<div>{{ item.name }}</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-else-if="scope.row.name == '调节幅度(AMP)'">
|
|
|
|
<p>{{ scope.row.name }}</p>
|
|
|
|
<div style="border-top: 1px solid #D9D9D9;display: flex;flex-wrap: wrap;margin: 3px 0">
|
|
|
|
<div v-for="(item,index) in ampList" :key="index" class="check" style="margin-left: 8px;font-size: 14px" @click="item.isSelect = !item.isSelect">
|
|
|
|
<input type="checkbox" :checked="item.isSelect">
|
|
|
|
<div>{{ item.name }}</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-else-if="scope.row.name == 'FV'">
|
|
|
|
<div class="width-180 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.fvYuanBi" placeholder="">
|
|
|
|
<template slot="prepend">远BO:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvYuanBi" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvYuanBi" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<!-- <div v-else-if="scope.row.name == '建议'">-->
|
|
|
|
<!-- <div class="width-180" style="text-align: left">-->
|
|
|
|
<!-- <el-input v-model="formData.jianYi" placeholder="" style="width: 640px">-->
|
|
|
|
<!-- <template slot="prepend">建议:</template>-->
|
|
|
|
<!-- </el-input>-->
|
|
|
|
<!-- </div>-->
|
|
|
|
<!-- </div>-->
|
|
|
|
<div v-else-if="scope.row.name == '签名'" style="display: flex;justify-content: space-between">
|
|
|
|
<div class="width-180" style="text-align: left">
|
|
|
|
<span style="display: inline-block;margin-top: 16px">视光师:</span>
|
|
|
|
<img v-if="formData.ygsSign" :src="formData.ygsSign" alt="" style="width: 80px;height: 50px;border-style:none;">
|
|
|
|
</div>
|
|
|
|
<div class="width-180" style="text-align: left;margin-top: 12px">
|
|
|
|
<el-input v-model="formData.ysSign" placeholder="">
|
|
|
|
<template slot="prepend">医师:</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
<div class="width-180" style="text-align: left;margin-top: 12px">
|
|
|
|
日期:<el-date-picker
|
|
|
|
v-model="formData.riQi"
|
|
|
|
type="date"
|
|
|
|
placeholder="选择日期"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<p v-else>{{ scope.row.name }}</p>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="" width="" :resizable="false" prop="type">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<div v-if="scope.row.name == '1'">
|
|
|
|
<div class="width-120 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.qgztOdVa" placeholder="">
|
|
|
|
<template slot="prepend">VA:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">X</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '屈光状态'">
|
|
|
|
<div class="width-120 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.qgztOd" placeholder="">
|
|
|
|
<template slot="prepend">OD:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">X</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '交替遮盖试验(CT)'">
|
|
|
|
<div class="center">
|
|
|
|
<p style="display: flex;justify-content: space-around" /><p>远:</p>
|
|
|
|
<el-select v-model="formData.ctYuan" placeholder="" clearable style="display: inline-block;width: 100px">
|
|
|
|
<el-option
|
|
|
|
v-for="item in ctList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
<p>近:</p>
|
|
|
|
<el-select v-model="formData.ctYuan" placeholder="" clearable style="display: inline-block;width: 100px">
|
|
|
|
<el-option
|
|
|
|
v-for="item in ctList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '集合近点(NPC)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.npcPld" placeholder="">
|
|
|
|
<template slot="prepend">破裂点:</template>
|
|
|
|
<template slot="append">CM</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == 'Worth-4-dot'">
|
|
|
|
<div class="center">
|
|
|
|
<!-- <el-input v-model="formData.worth1" placeholder="" style="width: 100px" />-->
|
|
|
|
<el-select v-model="formData.worth1" placeholder="" clearable style="display: inline-block;width: 100px" @change="selectWorth($event, 'od')">
|
|
|
|
<el-option
|
|
|
|
v-for="item in worthList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
@D(
|
|
|
|
<el-input v-model="formData.worth2" placeholder="" style="width: 100px" />
|
|
|
|
)
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '立体视(stereo)'">
|
|
|
|
<div class="center">
|
|
|
|
<span>RDD(远):</span>
|
|
|
|
<el-select v-model="formData.stereoRdd" placeholder="" clearable style="display: inline-block;width: 100px" @change="selectWorth($event, 'od')">
|
|
|
|
<el-option
|
|
|
|
v-for="item in stereoList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '眼位'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.ywFar" placeholder="">
|
|
|
|
<template slot="prepend">远:</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '梯度性AC/A'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.aca1" placeholder="" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '融像性聚散(FV)'">
|
|
|
|
<div class="width-180 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.fvJinBi" placeholder="">
|
|
|
|
<template slot="prepend">远BI:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvJinBi" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvJinBi" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == 'FV'">
|
|
|
|
<div class="width-180 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.fvYuanBo" placeholder="">
|
|
|
|
<template slot="prepend">近BO:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvYuanBo" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvYuanBo" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '相对调节(RA)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.raNar" placeholder="">
|
|
|
|
<template slot="prepend">NRA:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '调节幅度(AMP)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<div>
|
|
|
|
<el-input v-model="formData.ampOd" placeholder="">
|
|
|
|
<template slot="prepend">OD:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
<el-input v-model="formData.ampOs" placeholder="">
|
|
|
|
<template slot="prepend">OS:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '调节灵活度(AF)'">
|
|
|
|
<div class="center">
|
|
|
|
<div>
|
|
|
|
<el-input v-model="formData.afOd" placeholder="" style="width: 120px">
|
|
|
|
<template slot="prepend">OD:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-select v-model="formData.afOd" placeholder="" clearable style="display: inline-block;width: 100px;margin-left: 8px" @change="selectWorth($event, 'od')">
|
|
|
|
<el-option
|
|
|
|
v-for="item in afList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
</div>
|
|
|
|
<el-input v-model="formData.afOs" placeholder="" style="width: 120px">
|
|
|
|
<template slot="prepend">OS:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-select v-model="formData.afOs" placeholder="" clearable style="display: inline-block;width: 100px;margin-left: 8px" @change="selectWorth($event, 'od')">
|
|
|
|
<el-option
|
|
|
|
v-for="item in afList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '调节反应(FCC)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<div>
|
|
|
|
<el-input v-model="formData.fccOd" placeholder="">
|
|
|
|
<template slot="prepend">OD:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
<el-input v-model="formData.fccOs" placeholder="">
|
|
|
|
<template slot="prepend">OS:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '初步诊断'">
|
|
|
|
<div>
|
|
|
|
<div style="display:flex;margin-bottom: 8px">
|
|
|
|
<div class="check" style="margin-left: 0" @click="formData.cbzdCheck=!formData.cbzdCheck">
|
|
|
|
<input type="checkbox" :checked="formData.cbzdCheck">正常
|
|
|
|
</div>
|
|
|
|
<!-- <div class="check" style="margin-left: 16px" @click="formData.cbzdCheck=!formData.cbzdCheck">-->
|
|
|
|
<!-- <input type="checkbox" :checked="!formData.cbzdCheck">异常-->
|
|
|
|
<!-- </div>-->
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<div style="display: flex">
|
|
|
|
<div style="width: 160px;">聚散功能异常:</div>
|
|
|
|
<div style="width: 100%;display: flex;flex-wrap: wrap;">
|
|
|
|
<div v-for="(item,index) in dispersionList" :key="index" class="check" style="margin-left: 22px;font-size: 14px" @click="item.isSelect = !item.isSelect">
|
|
|
|
<input type="checkbox" :checked="item.isSelect">
|
|
|
|
<div>{{ item.name }}</div>
|
|
|
|
</div>
|
|
|
|
<!-- <el-select v-model="formData.cbzdJsgnyc" multiple placeholder="请选择" style="width: 100%">-->
|
|
|
|
<!-- <el-option-->
|
|
|
|
<!-- v-for="item in dispersionList"-->
|
|
|
|
<!-- :key="item.id"-->
|
|
|
|
<!-- :label="item.name"-->
|
|
|
|
<!-- :value="item.name"-->
|
|
|
|
<!-- />-->
|
|
|
|
<!-- </el-select>-->
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div style="display: flex">
|
|
|
|
<div style="width: 160px;">调节功能异常:</div>
|
|
|
|
<div style="width: 100%;display: flex;flex-wrap: wrap;">
|
|
|
|
<div v-for="(item,index) in regulatoryList" :key="index" class="check" style="margin-left: 22px;font-size: 14px" @click="item.isSelect = !item.isSelect">
|
|
|
|
<input type="checkbox" :checked="item.isSelect">
|
|
|
|
<div>{{ item.name }}</div>
|
|
|
|
</div>
|
|
|
|
<!-- <el-select v-model="formData.cbzdTjgnyc" multiple placeholder="请选择" style="width: 100%">-->
|
|
|
|
<!-- <el-option-->
|
|
|
|
<!-- v-for="item in scope.row.b"-->
|
|
|
|
<!-- :key="item.id"-->
|
|
|
|
<!-- :label="item.name"-->
|
|
|
|
<!-- :value="item.name"-->
|
|
|
|
<!-- />-->
|
|
|
|
<!-- </el-select>-->
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div style="display: flex">
|
|
|
|
<span style="width: 160px;">斜视:</span>
|
|
|
|
<div style="width: 100%;display: flex;flex-wrap: wrap;">
|
|
|
|
<div v-for="(item,index) in strabismusList" :key="index" class="check" style="margin-left: 22px;font-size: 14px" @click="item.isSelect = !item.isSelect">
|
|
|
|
<input type="checkbox" :checked="item.isSelect">
|
|
|
|
<div>{{ item.name }}</div>
|
|
|
|
</div>
|
|
|
|
<!-- <el-select v-model="formData.cbzdXs" multiple placeholder="请选择" style="width: 100%">-->
|
|
|
|
<!-- <el-option-->
|
|
|
|
<!-- v-for="item in scope.row.c"-->
|
|
|
|
<!-- :key="item.id"-->
|
|
|
|
<!-- :label="item.name"-->
|
|
|
|
<!-- :value="item.name"-->
|
|
|
|
<!-- />-->
|
|
|
|
<!-- </el-select>-->
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '建议'">
|
|
|
|
<div class="center" style="text-align: left">
|
|
|
|
<el-input v-model="formData.jianYi" type="textarea" :autosize="{ minRows: 3, maxRows: 3}" placeholder="" style="width: 100%" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="" width="" :resizable="false">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<div v-if="scope.row.name == '屈光状态'">
|
|
|
|
<div class="width-120 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.qgztOsVa" placeholder="">
|
|
|
|
<template slot="prepend">VA:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.qgztOs" placeholder="">
|
|
|
|
<template slot="prepend">X</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '交替遮盖试验(CT)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.ctYqyd" placeholder="">
|
|
|
|
<template slot="prepend">眼球运动:</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '集合近点(NPC)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.npcHfd" placeholder="">
|
|
|
|
<template slot="prepend">恢复点:</template>
|
|
|
|
<template slot="append">CM</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == 'Worth-4-dot'">
|
|
|
|
<div class="center">
|
|
|
|
<el-select v-model="formData.worth3" placeholder="" clearable style="display: inline-block;width: 100px" @change="selectWorth($event, 'os')">
|
|
|
|
<el-option
|
|
|
|
v-for="item in worthList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
@N(
|
|
|
|
<el-input v-model="formData.worth4" placeholder="" style="width: 100px" />
|
|
|
|
)
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '立体视(stereo)'">
|
|
|
|
<div class="center">
|
|
|
|
<span>TNO(近):</span>
|
|
|
|
<el-select v-model="formData.stereoTno" placeholder="" clearable style="display: inline-block;width: 100px" @change="selectWorth($event, 'od')">
|
|
|
|
<el-option
|
|
|
|
v-for="item in stereoList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '眼位'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.ywJin" placeholder="">
|
|
|
|
<template slot="prepend">近:</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '梯度性AC/A'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.aca2" placeholder="">
|
|
|
|
<template slot="prepend">计算性AC/A:</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '融像性聚散(FV)'">
|
|
|
|
<div class="width-180 center" style="display: flex">
|
|
|
|
<el-input v-model="formData.fvJinBo" placeholder="">
|
|
|
|
<template slot="prepend">近BI:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvJinBo" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
<el-input v-model="formData.fvJinBo" placeholder="">
|
|
|
|
<template slot="prepend">/</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '相对调节(RA)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.raPra" placeholder="">
|
|
|
|
<template slot="prepend">PRA:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '调节幅度(AMP)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.ampOu" placeholder="">
|
|
|
|
<template slot="prepend">OU:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '调节灵活度(AF)'">
|
|
|
|
<div class="center">
|
|
|
|
<el-input v-model="formData.afOu" placeholder="" style="width: 120px">
|
|
|
|
<template slot="prepend">OU:</template>
|
|
|
|
</el-input>
|
|
|
|
<el-select v-model="formData.afOd" placeholder="" clearable style="display: inline-block;width: 100px;margin-left: 8px" @change="selectWorth($event, 'od')">
|
|
|
|
<el-option
|
|
|
|
v-for="item in afList"
|
|
|
|
:key="item.id"
|
|
|
|
:label="item.name"
|
|
|
|
:value="item.name"
|
|
|
|
/>
|
|
|
|
</el-select>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="scope.row.name == '调节反应(FCC)'">
|
|
|
|
<div class="width-180 center">
|
|
|
|
<el-input v-model="formData.fccOu" placeholder="">
|
|
|
|
<template slot="prepend">OU:</template>
|
|
|
|
<template slot="append">D</template>
|
|
|
|
</el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
</el-table>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<script>
|
|
|
|
export default {
|
|
|
|
props: {
|
|
|
|
patientId: {
|
|
|
|
type: String,
|
|
|
|
default: ''
|
|
|
|
},
|
|
|
|
onlyRead: {
|
|
|
|
type: Boolean,
|
|
|
|
default: false
|
|
|
|
},
|
|
|
|
caseId: {
|
|
|
|
type: String,
|
|
|
|
default: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
formData: {
|
|
|
|
patientId: '',
|
|
|
|
patientName: '',
|
|
|
|
patientSex: '',
|
|
|
|
patientAge: '',
|
|
|
|
// 屈光状态
|
|
|
|
qgztOs: '',
|
|
|
|
qgztOd: '',
|
|
|
|
qgztOsVa: '',
|
|
|
|
qgztOdVa: '',
|
|
|
|
// 交替遮盖实验
|
|
|
|
ctYuan: '',
|
|
|
|
jtzgsyFront: '',
|
|
|
|
ctYqyd: '正常',
|
|
|
|
// 集合近点
|
|
|
|
npcPld: '',
|
|
|
|
npcHfd: '',
|
|
|
|
// worth-4-dot
|
|
|
|
worth1: '',
|
|
|
|
worth2: '',
|
|
|
|
worth3: '',
|
|
|
|
worth4: '',
|
|
|
|
// 立体视
|
|
|
|
stereoRdd: '',
|
|
|
|
stereoTno: '',
|
|
|
|
// 眼位
|
|
|
|
ywYuan: '',
|
|
|
|
ywJin: '',
|
|
|
|
// 梯度性AC/A
|
|
|
|
aca1: '',
|
|
|
|
aca2: '',
|
|
|
|
// 融像性聚散
|
|
|
|
fvJinBi: '',
|
|
|
|
fvJinBo: '',
|
|
|
|
fvYuanBi: '',
|
|
|
|
fvYuanBo: '',
|
|
|
|
// 相对调节
|
|
|
|
raNar: '',
|
|
|
|
raPra: '',
|
|
|
|
// 调节幅度
|
|
|
|
ampOd: '',
|
|
|
|
ampOs: '',
|
|
|
|
ampOu: '',
|
|
|
|
// 调节灵活度
|
|
|
|
afOd: '',
|
|
|
|
afOs: '',
|
|
|
|
afOu: '',
|
|
|
|
// 调节反应
|
|
|
|
fccOd: '',
|
|
|
|
fccOs: '',
|
|
|
|
fccOu: '',
|
|
|
|
// 初步诊断
|
|
|
|
cbzdCheck: false,
|
|
|
|
cbzdJsgnyc: [],
|
|
|
|
cbzdTjgnyc: [],
|
|
|
|
cbzdXs: [],
|
|
|
|
// 建议
|
|
|
|
jianYi: '',
|
|
|
|
// 签名
|
|
|
|
ygsSign: '',
|
|
|
|
ysSign: '',
|
|
|
|
riQi: ''
|
|
|
|
},
|
|
|
|
ctList: [
|
|
|
|
{
|
|
|
|
name: '正位',
|
|
|
|
id: '1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '外->中',
|
|
|
|
id: '2'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '内->中',
|
|
|
|
id: '3'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
worthList: [
|
|
|
|
{
|
|
|
|
name: '5个',
|
|
|
|
id: '1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '4个',
|
|
|
|
id: '2'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '3个',
|
|
|
|
id: '3'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '2个',
|
|
|
|
id: '4'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
npcList: [
|
|
|
|
{
|
|
|
|
name: '笔灯',
|
|
|
|
isSelect: true
|
|
|
|
}, {
|
|
|
|
name: '调节视标',
|
|
|
|
isSelect: false
|
|
|
|
}
|
|
|
|
],
|
|
|
|
acaList: [
|
|
|
|
{
|
|
|
|
name: '+1.00',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '-1.00',
|
|
|
|
isSelect: true
|
|
|
|
}
|
|
|
|
],
|
|
|
|
ampList: [
|
|
|
|
{
|
|
|
|
name: '负镜法',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '移近法',
|
|
|
|
isSelect: false
|
|
|
|
}
|
|
|
|
],
|
|
|
|
afList: [
|
|
|
|
{
|
|
|
|
name: 'cpm (+)',
|
|
|
|
id: '1'
|
|
|
|
}, {
|
|
|
|
name: 'cpm (-)',
|
|
|
|
id: '2'
|
|
|
|
}, {
|
|
|
|
name: 'cpm',
|
|
|
|
id: '3'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
stereoList: [
|
|
|
|
{
|
|
|
|
name: '400“',
|
|
|
|
id: '1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '200“',
|
|
|
|
id: '2'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '100“',
|
|
|
|
id: '3'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '60“',
|
|
|
|
id: '4'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '无',
|
|
|
|
id: '5'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
dispersionList: [
|
|
|
|
{
|
|
|
|
name: '集合不足',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '集合过度',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '散开不足',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '散开过度',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '内隐科',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '外隐科',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '假性集合不足',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '融像性聚散功能异常',
|
|
|
|
isSelect: false
|
|
|
|
}
|
|
|
|
],
|
|
|
|
regulatoryList: [
|
|
|
|
{
|
|
|
|
name: '调节灵敏度下降',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '调节不能持久',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '调节不足',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '调节过度',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '调节麻痹',
|
|
|
|
isSelect: false
|
|
|
|
}
|
|
|
|
],
|
|
|
|
strabismusList: [
|
|
|
|
{
|
|
|
|
name: '内斜视',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '外斜视',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '间歇性外斜视',
|
|
|
|
isSelect: false
|
|
|
|
}, {
|
|
|
|
name: '垂直斜',
|
|
|
|
isSelect: false
|
|
|
|
}
|
|
|
|
],
|
|
|
|
tableData: [
|
|
|
|
{
|
|
|
|
name: '屈光状态',
|
|
|
|
type: ''
|
|
|
|
}, {
|
|
|
|
name: '1',
|
|
|
|
type: ''
|
|
|
|
}, {
|
|
|
|
name: '交替遮盖试验(CT)',
|
|
|
|
type: ''
|
|
|
|
}, {
|
|
|
|
name: '集合近点(NPC)',
|
|
|
|
a: '',
|
|
|
|
b: '',
|
|
|
|
type: ''
|
|
|
|
}, {
|
|
|
|
name: 'Worth-4-dot',
|
|
|
|
a: '',
|
|
|
|
b: '',
|
|
|
|
c: '',
|
|
|
|
d: '',
|
|
|
|
type: ''
|
|
|
|
}, {
|
|
|
|
name: '立体视(stereo)',
|
|
|
|
a: '',
|
|
|
|
b: ''
|
|
|
|
}, {
|
|
|
|
name: '眼位',
|
|
|
|
a: '',
|
|
|
|
b: ''
|
|
|
|
}, {
|
|
|
|
name: '梯度性AC/A',
|
|
|
|
a: '',
|
|
|
|
b: ''
|
|
|
|
}, {
|
|
|
|
name: '融像性聚散(FV)',
|
|
|
|
a: '',
|
|
|
|
b: ''
|
|
|
|
}, {
|
|
|
|
name: 'FV',
|
|
|
|
a: '',
|
|
|
|
b: '',
|
|
|
|
type: ''
|
|
|
|
}, {
|
|
|
|
name: '相对调节(RA)',
|
|
|
|
a: '',
|
|
|
|
b: ''
|
|
|
|
}, {
|
|
|
|
name: '调节幅度(AMP)',
|
|
|
|
a: '',
|
|
|
|
b: '',
|
|
|
|
c: ''
|
|
|
|
}, {
|
|
|
|
name: '调节灵活度(AF)',
|
|
|
|
a: '',
|
|
|
|
b: '',
|
|
|
|
c: ''
|
|
|
|
}, {
|
|
|
|
name: '调节反应(FCC)',
|
|
|
|
a: '',
|
|
|
|
b: '',
|
|
|
|
c: ''
|
|
|
|
}, {
|
|
|
|
name: '初步诊断'
|
|
|
|
}, {
|
|
|
|
name: '建议',
|
|
|
|
value: ''
|
|
|
|
}, {
|
|
|
|
name: '签名',
|
|
|
|
a: '',
|
|
|
|
b: '',
|
|
|
|
c: ''
|
|
|
|
}]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
caseId(val) {
|
|
|
|
if (val) {
|
|
|
|
this.getSysgnjc()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
this.getPatientData()
|
|
|
|
this.getSysgnjc()
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
// 获取签名
|
|
|
|
setSign() {
|
|
|
|
const userData = JSON.parse(window.localStorage.getItem('qg-userData'))
|
|
|
|
const date = this.$moment().format('YYYY-MM-DD')
|
|
|
|
const mzName = window.localStorage.getItem('mzDoctorName')
|
|
|
|
this.formData.ygsSign = userData.signImgBase
|
|
|
|
this.formData.ysSign = mzName
|
|
|
|
this.formData.riQi = date
|
|
|
|
},
|
|
|
|
getSysgnjc() {
|
|
|
|
this.$http.get('/sysgnjc/getSysgnjc', { params: {
|
|
|
|
caseId: this.caseId,
|
|
|
|
patientId: this.patientId
|
|
|
|
}}).then(data => {
|
|
|
|
const form = data.data.data
|
|
|
|
form.cbzdCheck = form.cbzdCheck ? JSON.parse(form.cbzdCheck) : true
|
|
|
|
form.cbzdJsgnyc = form.cbzdJsgnyc ? form.cbzdJsgnyc.split(',') : []
|
|
|
|
form.cbzdTjgnyc = form.cbzdTjgnyc ? form.cbzdTjgnyc.split(',') : []
|
|
|
|
form.cbzdXs = form.cbzdXs ? form.cbzdXs.split(',') : []
|
|
|
|
this.formData = form
|
|
|
|
if (!this.formData.id) {
|
|
|
|
form.ctYqyd = '正常'
|
|
|
|
form.worth1 = form.worth3 = '4个'
|
|
|
|
form.worth2 = form.worth4 = '融像'
|
|
|
|
form.stereoRdd = form.stereoTno = '60“'
|
|
|
|
this.setSign()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
selectWorth(val, type) {
|
|
|
|
if (val === '5个') {
|
|
|
|
type === 'od' ? this.formData.worth2 = '复视' : this.formData.worth4 = '复视'
|
|
|
|
} else if (val === '4个') {
|
|
|
|
type === 'od' ? this.formData.worth2 = '融像' : this.formData.worth4 = '融像'
|
|
|
|
} else if (val === '3个') {
|
|
|
|
type === 'od' ? this.formData.worth2 = '右眼抑制' : this.formData.worth4 = '右眼抑制'
|
|
|
|
} else if (val === '2个') {
|
|
|
|
type === 'od' ? this.formData.worth2 = '左眼抑制' : this.formData.worth4 = '左眼抑制'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 获取患者信息
|
|
|
|
async getPatientData() {
|
|
|
|
const { data: res } = await this.$http.get(
|
|
|
|
'/patient/view/getPatientData',
|
|
|
|
{
|
|
|
|
params: {
|
|
|
|
patientId: this.patientId
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
if (res.code === 0) {
|
|
|
|
this.formData.patientId = res.data.patientId
|
|
|
|
this.formData.patientAge = res.data.patientAge
|
|
|
|
this.formData.patientSex = res.data.patientSex
|
|
|
|
this.formData.patientName = res.data.patientName
|
|
|
|
} else {
|
|
|
|
this.$message.error(res.msg)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 保存
|
|
|
|
async handleSaveTable() {
|
|
|
|
const data = JSON.parse(JSON.stringify(this.formData))
|
|
|
|
data.cbzdJsgnyc = data.cbzdJsgnyc.length ? data.cbzdJsgnyc.join(',') : ''
|
|
|
|
data.cbzdTjgnyc = data.cbzdTjgnyc.length ? data.cbzdTjgnyc.join(',') : ''
|
|
|
|
data.cbzdXs = data.cbzdXs.length ? data.cbzdXs.join(',') : ''
|
|
|
|
const params = {
|
|
|
|
caseId: this.caseId,
|
|
|
|
...data
|
|
|
|
}
|
|
|
|
const { data: res } = await this.$http.post('/sysgnjc/saveSysgnjc', params)
|
|
|
|
if (res.code === 0) {
|
|
|
|
this.$message.success('保存成功')
|
|
|
|
} else {
|
|
|
|
this.$message.error(res.msg)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 删除
|
|
|
|
handleDelete() {
|
|
|
|
this.$emit('del')
|
|
|
|
},
|
|
|
|
objectSpanMethod({ row, column, rowIndex, columnIndex }) {
|
|
|
|
if (columnIndex === 0) {
|
|
|
|
if (rowIndex === 0 || rowIndex === 8) {
|
|
|
|
return {
|
|
|
|
rowspan: 2,
|
|
|
|
colspan: 1
|
|
|
|
}
|
|
|
|
} else if (rowIndex === 16) {
|
|
|
|
return {
|
|
|
|
rowspan: 1,
|
|
|
|
colspan: 3
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (rowIndex === 14 || rowIndex === 15) {
|
|
|
|
if (columnIndex === 1) {
|
|
|
|
return {
|
|
|
|
rowspan: 1,
|
|
|
|
colspan: 2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
#eyesFunc{
|
|
|
|
::v-deep .el-input__inner {
|
|
|
|
border: none;
|
|
|
|
line-height: 26px !important;
|
|
|
|
text-align: center;
|
|
|
|
border-bottom: 1px solid #ccc;
|
|
|
|
border-radius: 0;
|
|
|
|
padding: 0;
|
|
|
|
}
|
|
|
|
::v-deep .el-input-group--prepend .el-input__inner{
|
|
|
|
height: 26px !important;
|
|
|
|
}
|
|
|
|
.eyesTable{
|
|
|
|
::v-deep .el-table__cell{
|
|
|
|
padding: 5px 0 !important;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.flex{
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
.j-c{
|
|
|
|
justify-content: center;
|
|
|
|
}
|
|
|
|
.check {
|
|
|
|
cursor: pointer;
|
|
|
|
user-select: none;
|
|
|
|
display: flex;
|
|
|
|
margin-left: 15px;
|
|
|
|
input{
|
|
|
|
-webkit-appearance: checkbox !important;
|
|
|
|
margin-right: 5px !important;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.bold{
|
|
|
|
font-weight: 700;
|
|
|
|
}
|
|
|
|
.printBox{
|
|
|
|
.el-table tr{
|
|
|
|
page-break-inside: avoid;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#operation-record {
|
|
|
|
height: 100%;
|
|
|
|
overflow: auto;
|
|
|
|
|
|
|
|
.operation-record-table {
|
|
|
|
width: 100%;
|
|
|
|
.operation-text {
|
|
|
|
font-weight: 700;
|
|
|
|
}
|
|
|
|
.text {
|
|
|
|
font-weight: 700;
|
|
|
|
}
|
|
|
|
.sign {
|
|
|
|
cursor: pointer;
|
|
|
|
color: #46a1ff;
|
|
|
|
font-weight: 400;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.center {
|
|
|
|
text-align: center;
|
|
|
|
}
|
|
|
|
.left {
|
|
|
|
text-align: left;
|
|
|
|
}
|
|
|
|
.width-50 {
|
|
|
|
.el-input {
|
|
|
|
width: 50px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.width-70 {
|
|
|
|
.el-input {
|
|
|
|
width: 70px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.width-100 {
|
|
|
|
.el-input {
|
|
|
|
width: 100px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.width-120 {
|
|
|
|
.el-input {
|
|
|
|
width: 120px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.width-180 {
|
|
|
|
.el-input {
|
|
|
|
width: 180px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
<style lang="scss">
|
|
|
|
#operation-record{
|
|
|
|
.el-input-group__append, .el-input-group__prepend{
|
|
|
|
padding: 0 5px !important;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|