qx
2025-06-10 bbc36385d79a9153f33dfd54e2a6f6384bb399ca
Merge branch 'master' of http://101.42.27.146:5001/r/ltkj_peisweb
3个文件已修改
2789 ■■■■ 已修改文件
src/api/doctor/checkAll.js 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/doctor/check/index.vue 226 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/doctor/checkAll/index.vue 2554 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/doctor/checkAll.js
@@ -156,3 +156,12 @@
    data: data
  })
}
// 修改标题内容
export function addOrder1(dataList) {
  return request({
    url: '/check/newaddOrderYcXmJyByTjh',
    method: 'post',
    data: dataList
  })
}
src/views/doctor/check/index.vue
@@ -280,10 +280,16 @@
                      ></el-input>
                    </template>
                  </el-table-column>
                  <el-table-column prop="exceptionDesc" label="异常" width="55px" align="center">
                  <!-- <el-table-column prop="exceptionDesc" label="异常" width="55px" align="center">
                    <template slot-scope="scope">
                      <el-checkbox v-model="scope.row.exceptionDesc" @change="changDesc(scope.row)"
                        :disabled="scope.row.project.sfcyyc === 1"></el-checkbox>
                    </template>
                  </el-table-column> -->
                   <el-table-column prop="exceptionDesc" label="异常" width="55px" align="center">
                    <template slot-scope="scope">
                      <el-checkbox v-model="scope.row.exceptionDesc" @change="changDesc(scope.row)"
                        :disabled="scope.row.project.sfcyyc === 1 || scope.row.project.proName === 'BMI'"></el-checkbox>
                    </template>
                  </el-table-column>
                  <el-table-column label="规则" width="70">
@@ -293,7 +299,12 @@
                  </el-table-column>
                  <el-table-column prop="project.proMetering" label="单位" width="55">
                  </el-table-column>
                  <el-table-column prop="project.proScope" label="参考范围" width="70">
                  <el-table-column label="参考范围" width="70">
                     <template slot-scope="scope">
                      {{ scope.row.project.proScope }}
                    </template>
                  </el-table-column>
                  <el-table-column prop="conclusion" label="结果结论" width="200">
                    <template slot-scope="scope">
@@ -880,16 +891,28 @@
      return '';
    },
    // 实时更新 BMI 并验证输入
    vale(value, row) {
      if (row.project.proName === '身高' || row.project.proName === '体重') {
        // 输入验证
        if (!/^\d*\.?\d*$/.test(value) || parseFloat(value) <= 0) {
          this.$message.error('请输入有效的正数');
          row.proResult = ''; // 清空无效输入
          return;
        }
    getBMIStatus(row) {
      const bmi = parseFloat(row.proResult);
      if (isNaN(bmi) || !row.proResult) return ''; // 处理无效或空的BMI值
      if (bmi > 28) {
        row.exceptionDesc = true; // 自动勾选异常复选框
        row.conclusion = '偏高'; // 设置结论
        return '偏高';
      }
      if (bmi < 12) {
        row.exceptionDesc = true; // 自动勾选异常复选框
        row.conclusion = '偏低'; // 设置结论
        return '偏低';
      }
      row.exceptionDesc = false; // 正常范围内取消勾选
      row.conclusion = '正常'; // 设置结论
      return '正常';
    },
    // 实时更新 BMI 并验证输入
     vale(value, row) {
      console.log(3333)
      if (row.project.proName === '身高' || row.project.proName === '体重') {
        const heightRow = this.proParentList.sons.find(
          item => item.project.proName === '身高'
        );
@@ -900,27 +923,156 @@
          item => item.project.proName === 'BMI'
        );
        if (!heightRow || !weightRow || !bmiRow) {
          return;
        if (heightRow && weightRow && bmiRow) {
          const height = row.project.proName === '身高' ? value : heightRow.proResult;
          const weight = row.project.proName === '体重' ? value : weightRow.proResult;
          const bmi = this.calculateBMI(height, weight);
          bmiRow.proResult = bmi || ''; // 实时更新BMI值
          this.getBMIStatus(bmiRow); // 检查BMI状态并更新异常复选框
        }
      }
        const height = row.project.proName === '身高' ? value : heightRow.proResult;
        const weight = row.project.proName === '体重' ? value : weightRow.proResult;
        if (!height || !weight) {
          this.$message.warning('请填写身高和体重以计算 BMI');
          bmiRow.proResult = '';
          return;
        }
        const bmi = this.calculateBMI(height, weight);
        bmiRow.proResult = bmi || ''; // 实时更新 BMI
      // 现有的规则检查逻辑保持不变
      this.focusrow = row;
      this.proResult = row;
      const pattern3 = new RegExp("[0-9]+");
      if (row.proResult) { }
      if (pattern3.test(row.proResult)) {
        let data = {
          proId: this.focusrow.proId,
          cusId: this.tableAll.cusId,
          tjNum: this.tableAll.tjNumber,
          keyNum: this.proResult.proResult,
        };
        AutoGetRule(data).then((res) => {
          this.focusrow.conclusion = "";
          if (res.data) {
            this.autorule = res.data;
            this.focusrow.rulesList = res.data;
            if (row.project.sfcyyc == 1) {
              return;
            } else {
              if (res.data.length > 0) {
                const conditions = ["正常", "未见异常", "阴性", "未见明显异常"];
                this.focusrow.exceptionDesc = !conditions.some((condition) =>
                  this.autorule[0].bz.includes(condition)
                );
              } else {
                this.focusrow.exceptionDesc = false;
              }
            }
            if (this.autorule.length !== 0 && (this.autorule[0] || this.autorule[0].nr)) {
              this.focusrow.proAdvice = this.autorule[0].nr;
            }
            this.autorule.forEach((item) => {
              this.focusrow.conclusion += this.focusrow.conclusion ? item.bz : item.bz;
            });
          }
        });
      }
    },
    /*  vale(value, row) {
        if (row.project.proName === '身高' || row.project.proName === '体重') {
          // 输入验证
          if (!/^\d*\.?\d*$/.test(value) || parseFloat(value) <= 0) {
            this.$message.error('请输入有效的正数');
            row.proResult = ''; // 清空无效输入
            return;
          }
          const heightRow = this.proParentList.sons.find(
            item => item.project.proName === '身高'
          );
          const weightRow = this.proParentList.sons.find(
            item => item.project.proName === '体重'
          );
          const bmiRow = this.proParentList.sons.find(
            item => item.project.proName === 'BMI'
          );
          if (!heightRow || !weightRow || !bmiRow) {
            return;
          }
          const height = row.project.proName === '身高' ? value : heightRow.proResult;
          const weight = row.project.proName === '体重' ? value : weightRow.proResult;
          if (!height || !weight) {
            this.$message.warning('请填写身高和体重以计算 BMI');
            bmiRow.proResult = '';
            return;
          }
          const bmi = this.calculateBMI(height, weight);
          bmiRow.proResult = bmi || ''; // 实时更新 BMI
        }
      },
 */
    // 输入确认时更新 BMI
    handleInputConfirm(row, params) {
    handleInputConfirm(row) {
      if (row.proResult) {
        if (row.project.proName === '身高' || row.project.proName === '体重') {
          const heightRow = this.proParentList.sons.find(
            item => item.project.proName === '身高'
          );
          const weightRow = this.proParentList.sons.find(
            item => item.project.proName === '体重'
          );
          const bmiRow = this.proParentList.sons.find(
            item => item.project.proName === 'BMI'
          );
          if (heightRow && weightRow && bmiRow) {
            const height = heightRow.proResult;
            const weight = weightRow.proResult;
            const bmi = this.calculateBMI(height, weight);
            bmiRow.proResult = bmi || '';
            this.getBMIStatus(bmiRow); // 检查BMI状态并更新异常复选框
          }
        }
      }
      // 现有的规则检查逻辑保持不变
      this.focusrow = row;
      this.proResult = row;
      const pattern3 = new RegExp("[0-9]+");
      if (pattern3.test(row.proResult)) {
        let data = {
          proId: this.focusrow.proId,
          cusId: this.tableAll.cusId,
          tjNum: this.tableAll.tjNumber,
          keyNum: this.proResult.proResult,
        };
        AutoGetRule(data).then((res) => {
          this.focusrow.conclusion = "";
          if (res.data) {
            this.autorule = res.data;
            this.focusrow.rulesList = res.data;
            if (row.project.sfcyyc == 1) {
              return;
            } else {
              if (res.data.length > 0) {
                const conditions = ["正常", "未见异常", "阴性", "未见明显异常"];
                this.focusrow.exceptionDesc = !conditions.some((condition) =>
                  this.autorule[0].bz.includes(condition)
                );
              } else {
                this.focusrow.exceptionDesc = false;
              }
            }
            if (this.autorule.length !== 0 && (this.autorule[0] || this.autorule[0].nr)) {
              this.focusrow.proAdvice = this.autorule[0].nr;
            }
            this.autorule.forEach((item) => {
              this.focusrow.conclusion += this.focusrow.conclusion ? item.bz : item.bz;
            });
          }
        });
      }
      this.rows.push(row);
    },
    /* handleInputConfirm(row, params) {
      console.log(row, params, 55555);
      // 如果有 params 且为空,取消异常状态并清空相关字段
      if (params && params.length === 0) {
@@ -945,21 +1097,13 @@
            item => item.project.proName === 'BMI'
          );
          if (!heightRow || !weightRow || !bmiRow) {
            return;
           if (heightRow && weightRow && bmiRow) {
            const height = heightRow.proResult;
            const weight = weightRow.proResult;
            const bmi = this.calculateBMI(height, weight);
            bmiRow.proResult = bmi || '';
            this.getBMIStatus(bmiRow); // 检查BMI状态并更新异常复选框
          }
          const height = heightRow.proResult;
          const weight = weightRow.proResult;
          if (!height || !weight) {
            this.$message.warning('请填写身高和体重以计算 BMI');
            bmiRow.proResult = '';
            return;
          }
          const bmi = this.calculateBMI(height, weight);
          bmiRow.proResult = bmi || '';
        }
        this.focusrow = row;
@@ -1037,7 +1181,7 @@
        this.rows.push(row);
        console.log(this.rows, row);
      }
    },
    }, */
    // 初始化数据时计算 BMI
    getParentIdsss() {
src/views/doctor/checkAll/index.vue
@@ -1,47 +1,127 @@
<template>
  <div class="mainbox">
    <el-form :model="queryParams" ref="tableList" :inline="true" label-width="76px" style="margin-top: 10px">
    <el-form
      :model="queryParams"
      ref="tableList"
      :inline="true"
      label-width="76px"
      style="margin-top: 10px"
    >
      <el-form-item label="姓名" prop="name">
        <el-input v-model="queryParams.name" style="width: 120px" placeholder="请输入姓名" clearable
          @keyup.enter.native="submitForm"></el-input>
        <el-input
          v-model="queryParams.name"
          style="width: 120px"
          placeholder="请输入姓名"
          clearable
          @keyup.enter.native="submitForm"
        ></el-input>
      </el-form-item>
      <el-form-item label="体检号" prop="tjNumber">
        <el-input ref="inputName" v-model="queryParams.tjNumber" style="width: 180px" placeholder="请输入体检号" clearable
          @keyup.enter.native="submitForm" @blur="hb"></el-input>
        <el-input
          ref="inputName"
          v-model="queryParams.tjNumber"
          style="width: 180px"
          placeholder="请输入体检号"
          clearable
          @keyup.enter.native="submitForm"
          @blur="hb"
        ></el-input>
      </el-form-item>
      <el-form-item label="体检时间" prop="tjTime">
        <el-date-picker v-model="startTime" type="datetimerange" align="right" :picker-options="pickerOptions"
          style="width: 310px" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:00:00']"
          format="yyyy-MM-dd HH:mm" value-format="yyyy-MM-dd HH:mm" @change="dateChangebirthday1">
        <el-date-picker
          v-model="startTime"
          type="datetimerange"
          align="right"
          :picker-options="pickerOptions"
          style="width: 310px"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
          :default-time="['00:00:00', '23:00:00']"
          format="yyyy-MM-dd HH:mm"
          value-format="yyyy-MM-dd HH:mm"
          @change="dateChangebirthday1"
        >
        </el-date-picker>
      </el-form-item>
      <el-form-item label="单位名称" prop="tjCompName" style="margin-left: 20px">
        <el-select :remote-method="getRemoteData" v-model="queryParams.tjCompName" value-key="drugManufacturerId"
          style="width: 180px" remote filterable placeholder="请选择单位名称" clearable @change="searchSelect">
          <el-option v-for="dict in CompanyList" :key="dict.drugManufacturerId" :label="dict.cnName" :value="dict" />
      <el-form-item
        label="单位名称"
        prop="tjCompName"
        style="margin-left: 20px"
      >
        <el-select
          :remote-method="getRemoteData"
          v-model="queryParams.tjCompName"
          value-key="drugManufacturerId"
          style="width: 180px"
          remote
          filterable
          placeholder="请选择单位名称"
          clearable
          @change="searchSelect"
        >
          <el-option
            v-for="dict in CompanyList"
            :key="dict.drugManufacturerId"
            :label="dict.cnName"
            :value="dict"
          />
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" size="mini" @click="submitForm" style="margin-right: 15px">搜索</el-button>
        <el-button
          type="primary"
          size="mini"
          @click="submitForm"
          style="margin-right: 15px"
          >搜索</el-button
        >
        <el-button size="mini" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>
    <el-radio-group v-model="tjStatus" @input="radioChange" style="margin-left: 20px">
    <el-radio-group
      v-model="tjStatus"
      @input="radioChange"
      style="margin-left: 20px"
    >
      <el-radio-button label="0">未审核</el-radio-button>
      <el-radio-button label="1">已审核</el-radio-button>
    </el-radio-group>
    <template>
      <el-table v-loading="loading" :data="checkList" ref="table" border style="margin: 20px; width: 98%"
        @current-change="handleCurrentChange">
      <el-table
        v-loading="loading"
        :data="checkList"
        ref="table"
        border
        style="margin: 20px; width: 98%"
        @current-change="handleCurrentChange"
      >
        <!-- <template slot="empty">数据正在加载中</template> -->
        <el-table-column label="体检号" align="center" prop="tjNumber" :show-overflow-tooltip="true" width="160px"
          fixed="left" />
        <el-table-column label="姓名" align="center" prop="cusName" :show-overflow-tooltip="true" width="100px"
          fixed="left" />
        <el-table-column
          label="体检号"
          align="center"
          prop="tjNumber"
          :show-overflow-tooltip="true"
          width="160px"
          fixed="left"
        />
        <el-table-column
          label="姓名"
          align="center"
          prop="cusName"
          :show-overflow-tooltip="true"
          width="100px"
          fixed="left"
        />
        <el-table-column label="性别" align="center" prop="cusSex" :show-overflow-tooltip="true" width="55px">
        <el-table-column
          label="性别"
          align="center"
          prop="cusSex"
          :show-overflow-tooltip="true"
          width="55px"
        >
          <template slot-scope="scope">
            <span v-if="scope.row.cusSex == '0'">男</span>
            <span v-if="scope.row.cusSex == '1'">女</span>
@@ -49,8 +129,20 @@
            <span v-if="scope.row.cusSex == '9'">未说明性别</span>
          </template>
        </el-table-column>
        <el-table-column label="出生日期" align="center" prop="cusBrithday" :show-overflow-tooltip="true" width="110px" />
        <el-table-column label="电话" align="center" prop="cusPhone" :show-overflow-tooltip="true" width="130px" />
        <el-table-column
          label="出生日期"
          align="center"
          prop="cusBrithday"
          :show-overflow-tooltip="true"
          width="110px"
        />
        <el-table-column
          label="电话"
          align="center"
          prop="cusPhone"
          :show-overflow-tooltip="true"
          width="130px"
        />
        <!-- <el-table-column
          label="体检时间"
@@ -59,721 +151,1442 @@
          :show-overflow-tooltip="true"
          width="110px"
        /> -->
        <el-table-column v-if="tjStatus === '1'" label="审核时间" align="center" prop="shsj" :show-overflow-tooltip="true"
          width="180px" />
        <el-table-column v-if="tjStatus === '0'" label="完成时间" align="center" prop="finishTime"
          :show-overflow-tooltip="true" width="160px" />
        <el-table-column label="套餐名称" align="center" prop="pacName" :show-overflow-tooltip="true" width="160px" />
        <el-table-column label="状态" align="center" prop="tjStatus" :show-overflow-tooltip="true" width="120px">
        <el-table-column
          v-if="tjStatus === '1'"
          label="审核时间"
          align="center"
          prop="shsj"
          :show-overflow-tooltip="true"
          width="180px"
        />
        <el-table-column
          v-if="tjStatus === '0'"
          label="完成时间"
          align="center"
          prop="finishTime"
          :show-overflow-tooltip="true"
          width="160px"
        />
        <el-table-column
          label="套餐名称"
          align="center"
          prop="pacName"
          :show-overflow-tooltip="true"
          width="160px"
        />
        <el-table-column
          label="状态"
          align="center"
          prop="tjStatus"
          :show-overflow-tooltip="true"
          width="120px"
        >
          <template slot-scope="scope">
            <span>{{ scope.row.tjStatus == "1" ? "已审核" : "未审核" }}</span>
          </template>
        </el-table-column>
        <el-table-column label="单位名称" align="center" prop="tjCompName" :show-overflow-tooltip="true" />
        <el-table-column
          label="单位名称"
          align="center"
          prop="tjCompName"
          :show-overflow-tooltip="true"
        />
        <el-table-column label="体检类别" align="center" prop="tjCategory">
          <template slot-scope="scope">
            <dict-tag :options="dict.type.dict_tjtype" :value="scope.row.tjCategory" />
            <dict-tag
              :options="dict.type.dict_tjtype"
              :value="scope.row.tjCategory"
            />
          </template>
        </el-table-column>
        <el-table-column label="操作" align="center" width="120px" fixed="right">
        <el-table-column
          label="操作"
          align="center"
          width="120px"
          fixed="right"
        >
          <template slot-scope="scope">
            <el-button fixed="right" title="详情" type="text" size="mini" @click.stop="handleClick(scope.row)"
              icon="el-icon-document-copy"></el-button>
            <el-button fixed="right" title="同步" type="text" size="mini" @click.stop="tongbu(scope.row)"
              v-if="scope.row.tjStatus != '1'" icon="el-icon-upload2"></el-button>
            <el-button fixed="right" title="处方" type="text" size="mini" @click.stop="rowClick(scope.row)"
              icon="el-icon-edit-outline"></el-button>
            <el-button
              fixed="right"
              title="详情"
              type="text"
              size="mini"
              @click.stop="handleClick(scope.row)"
              icon="el-icon-document-copy"
            ></el-button>
            <el-button
              fixed="right"
              title="同步"
              type="text"
              size="mini"
              @click.stop="tongbu(scope.row)"
              v-if="scope.row.tjStatus != '1'"
              icon="el-icon-upload2"
            ></el-button>
            <el-button
              fixed="right"
              title="处方"
              type="text"
              size="mini"
              @click.stop="rowClick(scope.row)"
              icon="el-icon-edit-outline"
            ></el-button>
            <!-- <el-button type="text" size="mini" @click="generate(scope.row)" v-if="scope.row.tjStatus=='1'">生成</el-button> -->
            <el-button type="text" size="mini" @click.stop="viewReport(scope.row)" v-if="scope.row.tjStatus == '1'"
              title="预览" icon="el-icon-view"></el-button>
            <el-button type="text" size="mini" v-if="scope.row.tjStatus == '1'" title="撤销"
              @click.stop="getRevoke(scope.row)" icon="el-icon-refresh-left"></el-button>
            <el-button
              type="text"
              size="mini"
              @click.stop="viewReport(scope.row)"
              v-if="scope.row.tjStatus == '1'"
              title="预览"
              icon="el-icon-view"
            ></el-button>
            <el-button
              type="text"
              size="mini"
              v-if="scope.row.tjStatus == '1'"
              title="撤销"
              @click.stop="getRevoke(scope.row)"
              icon="el-icon-refresh-left"
            ></el-button>
          </template>
        </el-table-column>
      </el-table>
      <div class="pag">
        <div class="pag1">
          <pagination v-show="total > 0" :total="total" :page.sync="queryParams.page" :limit.sync="queryParams.pageSize"
            @pagination="submitForm" />
          <pagination
            v-show="total > 0"
            :total="total"
            :page.sync="queryParams.page"
            :limit.sync="queryParams.pageSize"
            @pagination="submitForm"
          />
        </div>
      </div>
    </template>
    <!-- 点击弹出框   show-close="true"-->
    <el-drawer custom-class="tanchu" :visible.sync="drawer" :before-close="handleClose" :with-header="false"
      size="100%">
      <div class="top">
        <table style="
            width: 100%;
            margin: 10px 10px;
            border: 1px solid #dfe6ec;
            border-collapse: collapse;
          " cellspacing="4">
          <caption style="background-color: #f8f8f9; font-size: 18px">
            {{
              tableAll.cusName
            }}的体检资料
          </caption>
          <tr style="
    <el-drawer
      custom-class="tanchu"
      :visible.sync="drawer"
      :before-close="handleClose"
      :with-header="false"
      size="100%"
      :show-close="true"
    >
      <div
        v-loading="isLoading"
        element-loading-text="正在加载数据,请稍候..."
        element-loading-spinner="el-icon-loading"
        element-loading-background="rgba(255, 255, 255, 0.8)"
        style="height: 100%; padding: 20px; position: relative"
      >
        <div class="top">
          <table
            style="
              width: 100%;
              margin: 10px 10px;
              border: 1px solid #dfe6ec;
              border-collapse: collapse;
              height: 36px;
            ">
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              姓名:
            </td>
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              {{ tableAll.cusName }}
            </td>
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              性别:{{
                tableAll.cusSex == 0
                  ? "男"
                  : tableAll.cusSex == 1
            "
            cellspacing="4"
          >
            <caption style="background-color: #f8f8f9; font-size: 18px">
              {{
                tableAll.cusName
              }}的体检资料
            </caption>
            <tr
              style="
                border: 1px solid #dfe6ec;
                border-collapse: collapse;
                height: 36px;
              "
            >
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                姓名:
              </td>
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                {{ tableAll.cusName }}
              </td>
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                性别:{{
                  tableAll.cusSex == 0
                    ? "男"
                    : tableAll.cusSex == 1
                    ? "女"
                    : "未知"
              }}
            </td>
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              年龄:{{ tableAll.age }}
            </td>
          </tr>
          <tr style="
              border: 1px solid #dfe6ec;
              border-collapse: collapse;
              height: 36px;
            ">
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              体检单号:
            </td>
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              {{ tableAll.tjNumber }}
            </td>
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              体检时间:
            </td>
            <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
              {{ tableAll.tjTime }}
            </td>
          </tr>
        </table>
        <i class="el-icon-close" @click="guanbi"></i>
      </div>
      <div style="margin-right: 10px; display: flex" class="btnbox">
        <div class="btn1" v-if="msgtuwen == 'y' || msgtuwen == 'Y'">
          <el-button @click="Graphicreport()" type="primary">
            <span class="vertical-text">图文报告</span>
          </el-button>
        </div>
        <div class="btn1">
          <el-button @click="historicalreport()" type="primary"><span class="vertical-text">历史报告</span></el-button>
        </div>
        <div v-if="tableAll.tjCategory == '02'" class="btn1">
          <el-button @click="medicalhistory()" type="primary"><span class="vertical-text">职业病史</span></el-button>
        </div>
        <div class="btn1" v-if="msgjianqian == 'y' || msgjianqian == 'Y'">
          <el-button @click="jianqian()" type="primary"><span class="vertical-text">检前问诊</span></el-button>
                }}
              </td>
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                年龄:{{ tableAll.age }}
              </td>
            </tr>
            <tr
              style="
                border: 1px solid #dfe6ec;
                border-collapse: collapse;
                height: 36px;
              "
            >
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                体检单号:
              </td>
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                {{ tableAll.tjNumber }}
              </td>
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                体检时间:
              </td>
              <td style="border: 1px solid #dfe6ec; border-collapse: collapse">
                {{ tableAll.tjTime }}
              </td>
            </tr>
          </table>
          <i class="el-icon-close" @click="guanbi"></i>
        </div>
        <div class="btn1">
          <el-button @click="xiangmuqingkuang()" type="primary"><span class="vertical-text">项目情况</span></el-button>
        <div style="margin-right: 10px; display: flex" class="btnbox">
          <div class="btn1" v-if="msgtuwen == 'y' || msgtuwen == 'Y'">
            <el-button @click="Graphicreport()" type="primary">
              <span class="vertical-text">图文报告</span>
            </el-button>
          </div>
          <div class="btn1">
            <el-button @click="historicalreport()" type="primary"
              ><span class="vertical-text">历史报告</span></el-button
            >
          </div>
          <div v-if="tableAll.tjCategory == '02'" class="btn1">
            <el-button @click="medicalhistory()" type="primary"
              ><span class="vertical-text">职业病史</span></el-button
            >
          </div>
          <div class="btn1" v-if="msgjianqian == 'y' || msgjianqian == 'Y'">
            <el-button @click="jianqian()" type="primary"
              ><span class="vertical-text">检前问诊</span></el-button
            >
          </div>
          <div class="btn1">
            <el-button @click="xiangmuqingkuang()" type="primary"
              ><span class="vertical-text">项目情况</span></el-button
            >
          </div>
          <div class="btn1">
            <el-button @click="yichangjieguo()" type="primary"
              ><span class="vertical-text">异常结果</span></el-button
            >
          </div>
          <div class="btn1">
            <el-button @click="fuchaxiangmu()" type="primary"
              ><span class="vertical-text">复查项目</span></el-button
            >
          </div>
        </div>
        <div class="btn1">
          <el-button @click="yichangjieguo()" type="primary"><span class="vertical-text">异常结果</span></el-button>
        </div>
        <div class="btn1">
          <el-button @click="fuchaxiangmu()" type="primary"><span class="vertical-text">复查项目</span></el-button>
        </div>
      </div>
      <div class="box">
        <div class="left-container">
          <div class="left">
            <div v-for="(item, index) in changedate" :key="index">
              <div style="
                  text-align: center;
                  background-color: #aad8df;
                  margin-top: 10px;
                ">
                {{ item.parent || "" }}
              </div>
              <div v-if="item.xmlb == '0'">
                <el-table :data="item.sons" border style="width: 100%" :row-style="changRed"
                  :header-cell-style="{ background: '#aad8df' }">
                  <el-table-column align="center" label="检测项目" width="464">
                    <template slot-scope="scope">
                      <div>{{ scope.row.proName }}</div>
                    </template>
                  </el-table-column>
                  <el-table-column align="center" prop="proResult" label="检测结果" width="180">
                  </el-table-column>
                  <el-table-column align="center" prop="" label="单位">
                    <template slot-scope="scope">
                      <div v-if="scope.row.project != null">
                        {{ scope.row.standard.company || "" }}
                      </div>
                      <div v-else>{{ scope.row.proAdvice }}</div>
                    </template>
                  </el-table-column>
                  <el-table-column align="center" prop="conclusion" label="异常" width="180"></el-table-column>
                  <el-table-column align="center" prop="" label=" 参考范围">
                    <template slot-scope="scope">
                      <div v-if="scope.row.project != null">
                        {{
                          scope.row.standard.tjStandardGtValue ||
                          "/" + "-" + scope.row.standard.tjStandardLtValue ||
                          "/"
                        }}
                      </div>
                      <div v-else>{{ scope.row.stanId || "/" }}</div>
                    </template>
                  </el-table-column>
                </el-table>
                <table style="width: 100%" v-if="tjproject != '1'">
                  <tr style="border: 1px solid #dfe6ec; border-collapse: collapse">
                    <td style="
        <div class="box">
          <div class="left-container">
            <div class="left">
              <div v-for="(item, index) in changedate" :key="index">
                <div
                  style="
                    text-align: center;
                    background-color: #aad8df;
                    margin-top: 10px;
                  "
                >
                  {{ item.parent || "" }}
                </div>
                <div v-if="item.xmlb == '0'">
                  <el-table
                    :data="item.sons"
                    border
                    style="width: 100%"
                    :row-style="changRed"
                    :header-cell-style="{ background: '#aad8df' }"
                  >
                    <el-table-column
                      align="center"
                      label="检测项目"
                      width="464"
                    >
                      <template slot-scope="scope">
                        <div>{{ scope.row.proName }}</div>
                      </template>
                    </el-table-column>
                    <el-table-column
                      align="center"
                      prop="proResult"
                      label="检测结果"
                      width="180"
                    >
                    </el-table-column>
                    <el-table-column align="center" prop="" label="单位">
                      <template slot-scope="scope">
                        <div v-if="scope.row.project != null">
                          {{ scope.row.standard.company || "" }}
                        </div>
                        <div v-else>{{ scope.row.proAdvice }}</div>
                      </template>
                    </el-table-column>
                    <el-table-column
                      align="center"
                      prop="conclusion"
                      label="异常"
                      width="180"
                    ></el-table-column>
                    <el-table-column align="center" prop="" label=" 参考范围">
                      <template slot-scope="scope">
                        <div v-if="scope.row.project != null">
                          {{
                            scope.row.standard.tjStandardGtValue ||
                            "/" + "-" + scope.row.standard.tjStandardLtValue ||
                            "/"
                          }}
                        </div>
                        <div v-else>{{ scope.row.stanId || "/" }}</div>
                      </template>
                    </el-table-column>
                  </el-table>
                  <table style="width: 100%" v-if="tjproject != '1'">
                    <tr
                      style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                        width: 7%;
                      ">
                      小结:
                    </td>
                    <td style="border: 1px solid #dfe6ec; width: 45%">
                      <el-input v-model="item.remark" disabled></el-input>
                    </td>
                    <td style="
                      "
                    >
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                          width: 7%;
                        "
                      >
                        小结:
                      </td>
                      <td style="border: 1px solid #dfe6ec; width: 45%">
                        <el-input v-model="item.remark" disabled></el-input>
                      </td>
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                          width: 15%;
                        "
                      >
                        主检医师:
                      </td>
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                        "
                        colspan="2"
                      >
                        {{ item.doctorName }}
                      </td>
                    </tr>
                    <tr
                      style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                        width: 15%;
                      ">
                      主检医师:
                    </td>
                    <td style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                      " colspan="2">
                      {{ item.doctorName }}
                    </td>
                  </tr>
                  <tr style="
                      border: 1px solid #dfe6ec;
                      border-collapse: collapse;
                      width: 200px;
                    ">
                    <td style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                        width: 240px;
                      ">
                      备注:
                    </td>
                    <td style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                      " colspan="3">
                      <el-input type="textarea" autosize placeholder="请输入内容" v-model="changedate[index].remark"
                        v-on:input="change" style="width: 100%">
                      </el-input>
                      <!-- <textarea
                        width: 200px;
                      "
                    >
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                          width: 240px;
                        "
                      >
                        备注:
                      </td>
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                        "
                        colspan="3"
                      >
                        <el-input
                          type="textarea"
                          autosize
                          placeholder="请输入内容"
                          v-model="changedate[index].remark"
                          v-on:input="change"
                          style="width: 100%"
                        >
                        </el-input>
                        <!-- <textarea
                        placeholder="请输入内容"
                        :autosize="{ minRows: 2 }"
                        style="width: 100%; height: 240px; resize: none"
                        v-model="changedate[index].remark"
                        v-on:input="change"
                      ></textarea> -->
                    </td>
                  </tr>
                </table>
              </div>
              <div v-else>
                <table style="width: 100%" v-if="tjproject != '1'">
                  <tr style="border: 1px solid #dfe6ec">
                    <td style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                        width: 15%;
                        height: auto;
                      ">
                      检查所见:
                    </td>
                    <td style="border: 1px solid #dfe6ec; height: auto" colspan="2">
                      <el-input type="textarea" autosize placeholder="请输入内容" v-model="item.jgbx" style="width: 100%">
                      </el-input>
                      <!-- <textarea
                      </td>
                    </tr>
                  </table>
                </div>
                <div v-else>
                  <table style="width: 100%" v-if="tjproject != '1'">
                    <tr style="border: 1px solid #dfe6ec">
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                          width: 15%;
                          height: auto;
                        "
                      >
                        检查所见:
                      </td>
                      <td
                        style="border: 1px solid #dfe6ec; height: auto"
                        colspan="2"
                      >
                        <el-input
                          type="textarea"
                          autosize
                          placeholder="请输入内容"
                          v-model="item.jgbx"
                          style="width: 100%"
                        >
                        </el-input>
                        <!-- <textarea
                        placeholder="请输入内容"
                        :autosize="{ minRows: 3}"
                        style="width: 100%; height: auto; resize: none"
                        v-model="item.jgbx"
                      ></textarea> -->
                    </td>
                  </tr>
                  <tr style="border: 1px solid #dfe6ec; border-collapse: collapse">
                    <td style="
                      </td>
                    </tr>
                    <tr
                      style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                        width: 15%;
                      ">
                      检查提示:
                    </td>
                    <td style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                      " colspan="2">
                      <el-input type="textarea" autosize placeholder="请输入内容" v-model="item.remark" style="width: 100%">
                      </el-input>
                      <!-- <textarea
                      "
                    >
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                          width: 15%;
                        "
                      >
                        检查提示:
                      </td>
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                        "
                        colspan="2"
                      >
                        <el-input
                          type="textarea"
                          autosize
                          placeholder="请输入内容"
                          v-model="item.remark"
                          style="width: 100%"
                        >
                        </el-input>
                        <!-- <textarea
      
                        placeholder="请输入内容"
                        style="width: 100%;  resize: none"
                        v-model="item.remark"
                      ></textarea> -->
                    </td>
                  </tr>
                  <tr style="
                      border: 1px solid #dfe6ec;
                      border-collapse: collapse;
                      width: 200px;
                    ">
                    <td style="
                      </td>
                    </tr>
                    <tr
                      style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                        width: 15%;
                      ">
                      主检医师:
                    </td>
                    <td style="
                        border: 1px solid #dfe6ec;
                        border-collapse: collapse;
                      " colspan="2">
                      {{ item.doctorName }}
                    </td>
                  </tr>
                </table>
                        width: 200px;
                      "
                    >
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                          width: 15%;
                        "
                      >
                        主检医师:
                      </td>
                      <td
                        style="
                          border: 1px solid #dfe6ec;
                          border-collapse: collapse;
                        "
                        colspan="2"
                      >
                        {{ item.doctorName }}
                      </td>
                    </tr>
                  </table>
                </div>
              </div>
            </div>
            <div style="margin: 0 0px 10px 15px" v-if="tjproject != '1'">
              <el-button type="primary" @click="propoChange">快捷建议</el-button>
              <el-button type="primary" @click="proposalChange">生成建议</el-button>
            </div>
              <div style="margin: 0 0px 10px 15px" v-if="tjproject != '1'">
                <el-button type="primary" @click="propoChange"
                  >快捷建议</el-button
                >
                <el-button type="primary" @click="proposalChange"
                  >生成建议</el-button
                >
              </div>
            <el-form ref="numberValidateForm" label-width="80px" class="demo-ruleForm" v-if="tjproject != '1'">
              <el-form-item label="总检建议">
                <el-input type="textarea" placeholder="请输入内容" v-model="textarea1" :rows="3" style="width: 96%">
                </el-input>
              </el-form-item>
            </el-form>
            <div slot="footer" class="dialog-footers">
              <el-button type="primary" @click.stop="guanbi">取消</el-button>
              <el-button v-if="tjproject == '0' && (msgkcf == 'y' || msgkcf == 'Y')" type="primary"
                @click.stop="rowClick" icon="el-icon-edit-outline">开处方</el-button>
              <div v-if="tjproject == '0'">
                <el-button type="primary" @click="determine" :disabled="isdisabled">提交并生成报告</el-button>
              <el-form
                ref="numberValidateForm"
                label-width="80px"
                class="demo-ruleForm"
                v-if="tjproject != '1'"
              >
                <el-form-item label="总检建议">
                  <el-input
                    type="textarea"
                    placeholder="请输入内容"
                    v-model="textarea1"
                    :rows="3"
                    style="width: 96%"
                  >
                  </el-input>
                </el-form-item>
              </el-form>
              <div slot="footer" class="dialog-footers">
                <el-button type="primary" @click.stop="guanbi">取消</el-button>
                <el-button
                  v-if="tjproject == '0' && (msgkcf == 'y' || msgkcf == 'Y')"
                  type="primary"
                  @click.stop="rowClick"
                  icon="el-icon-edit-outline"
                  >开处方</el-button
                >
                <div v-if="tjproject == '0'">
                  <el-button
                    type="primary"
                    @click="determine"
                    :disabled="isdisabled"
                    >提交并生成报告</el-button
                  >
                </div>
              </div>
            </div>
          </div>
        </div>
        <div class="rightbox">
          <div class="right">
            <template v-if="status1 == 0">
              <div v-for="(item, index) in yichangList" :key="index">
                <div style="
                    text-align: center;
                    background-color: #67c23a;
                    margin-top: 10px;
                  ">
                  {{ item.proName || "" }}
                </div>
                <template v-if="item.jyjc == '0'">
                  <el-table :stripe="true" :row-style="red" :data="item.sone" border style="width: 100%"
                    :header-cell-style="{ background: '#67C23A' }" :expand-row-keys="expends" :row-key="getRowKeys">
                    <el-table-column type="expand">
                      <template slot-scope="props">
                        <div style="padding: 10px">
                          <!-- 内容区域 -->
                          <div v-if="
                            props.row.advices && props.row.advices.length > 0
                          ">
                            <div v-for="(jianyi, index1) in props.row.advices" :key="index1"
                              style="margin-bottom: 10px">
          <div class="rightbox">
            <div class="right">
              <template v-if="status1 == 0">
                <div v-for="(item, index) in yichangList" :key="index">
                  <div
                    style="
                      text-align: center;
                      background-color: #67c23a;
                      margin-top: 10px;
                    "
                  >
                    {{ item.proName || "" }}
                  </div>
                  <template v-if="item.jyjc == '0'">
                    <el-table
                      :stripe="true"
                      :row-style="red"
                      :data="item.sone"
                      border
                      style="width: 100%"
                      :header-cell-style="{ background: '#67C23A' }"
                      :expand-row-keys="expends"
                      :row-key="getRowKeys"
                    >
                      <el-table-column type="expand">
                        <template slot-scope="props">
                          <div style="padding: 10px">
                            <!-- 内容区域 -->
                            <div
                              v-if="
                                props.row.advices &&
                                props.row.advices.length > 0
                              "
                            >
                              <div
                                v-for="(jianyi, index1) in props.row.advices"
                                :key="index1"
                                style="margin-bottom: 10px"
                              >
                                <div>
                                  标题:
                                  <el-input
                                    v-model="jianyi.bt"
                                    size="small"
                                    type="textarea"
                                    autosize
                                  ></el-input>
                                </div>
                                <div>
                                  内容:
                                  <el-input
                                    v-model="jianyi.nr"
                                    size="small"
                                    type="textarea"
                                    autosize
                                  ></el-input>
                                </div>
                              </div>
                            </div>
                            <!-- 如果 advices 为空时,渲染空的输入框 -->
                            <div v-else>
                              <div>
                                标题:
                                <el-input v-model="jianyi.bt" size="small" type="textarea" autosize></el-input>
                                <el-input
                                  v-model="emptyAdvice.bt"
                                  size="small"
                                  type="textarea"
                                  autosize
                                ></el-input>
                              </div>
                              <div>
                                内容:
                                <el-input v-model="jianyi.nr" size="small" type="textarea" autosize></el-input>
                                <el-input
                                  v-model="emptyAdvice.nr"
                                  size="small"
                                  type="textarea"
                                  autosize
                                ></el-input>
                              </div>
                            </div>
                          </div>
                          <!-- 如果 advices 为空时,渲染空的输入框 -->
                          <div v-else>
                            <div>
                              标题:
                              <el-input v-model="emptyAdvice.bt" size="small" type="textarea" autosize></el-input>
                            </div>
                            <div>
                              内容:
                              <el-input v-model="emptyAdvice.nr" size="small" type="textarea" autosize></el-input>
                            <div style="margin-top: 10px">
                              <el-button
                                @click="shanchu(props.row)"
                                type="danger"
                                size="small"
                                >删除</el-button
                              >
                            </div>
                          </div>
                        </template>
                      </el-table-column>
                          <div style="margin-top: 10px">
                            <el-button @click="shanchu(props.row)" type="danger" size="small">删除</el-button>
                          </div>
                        </div>
                      </template>
                    </el-table-column>
                      <el-table-column
                        align="center"
                        label="检测项目"
                        :show-overflow-tooltip="true"
                        width="353"
                      >
                        <template slot-scope="scope">
                          <div>{{ scope.row.proName }}</div>
                        </template>
                      </el-table-column>
                      <el-table-column
                        align="center"
                        prop="proResult"
                        label="检测结果"
                        width="85"
                      >
                      </el-table-column>
                    <el-table-column align="center" label="检测项目" :show-overflow-tooltip="true" width="353">
                      <template slot-scope="scope">
                        <div>{{ scope.row.proName }}</div>
                      </template>
                    </el-table-column>
                    <el-table-column align="center" prop="proResult" label="检测结果" width="85">
                    </el-table-column>
                      <el-table-column
                        align="center"
                        prop="stanId"
                        label=" 参考范围"
                        width="117"
                      >
                      </el-table-column>
                    <el-table-column align="center" prop="stanId" label=" 参考范围" width="117">
                    </el-table-column>
                      <el-table-column
                        align="center"
                        prop="proAdvice"
                        label="单位"
                        width="78"
                      >
                      </el-table-column>
                    </el-table>
                  </template>
                  <template v-if="item.jyjc == '1'">
                    <el-table
                      :stripe="true"
                      :row-style="red"
                      :data="item.sone"
                      border
                      style="width: 100%"
                      :header-cell-style="{ background: '#67C23A' }"
                      :expand-row-keys="expends"
                      :row-key="getRowKeys"
                    >
                      <el-table-column type="expand">
                        <template slot-scope="props">
                          <div style="padding: 10px">
                            <!-- 内容区域 -->
                            <div
                              v-if="
                                props.row.advices &&
                                props.row.advices.length > 0
                              "
                            >
                              <div
                                v-for="(jianyi, index1) in props.row.advices"
                                :key="index1"
                                style="margin-bottom: 10px"
                              >
                                <div>
                                  标题:
                                  <el-input
                                    v-model="jianyi.bt"
                                    size="small"
                                    type="textarea"
                                    autosize
                                  ></el-input>
                                </div>
                                <div>
                                  内容:
                                  <el-input
                                    v-model="jianyi.nr"
                                    size="small"
                                    type="textarea"
                                    autosize
                                  ></el-input>
                                </div>
                              </div>
                            </div>
                    <el-table-column align="center" prop="proAdvice" label="单位" width="78">
                    </el-table-column>
                  </el-table>
                </template>
                <template v-if="item.jyjc == '1'">
                  <el-table :stripe="true" :row-style="red" :data="item.sone" border style="width: 100%"
                    :header-cell-style="{ background: '#67C23A' }" :expand-row-keys="expends" :row-key="getRowKeys">
                    <el-table-column type="expand">
                      <template slot-scope="props">
                        <div style="padding: 10px">
                          <!-- 内容区域 -->
                          <div v-if="
                            props.row.advices && props.row.advices.length > 0
                          ">
                            <div v-for="(jianyi, index1) in props.row.advices" :key="index1"
                              style="margin-bottom: 10px">
                            <!-- 如果 advices 为空时,渲染空的输入框 -->
                            <div v-else>
                              <div>
                                标题:
                                <el-input v-model="jianyi.bt" size="small" type="textarea" autosize></el-input>
                                <el-input
                                  v-model="emptyAdvice.bt"
                                  size="small"
                                  type="textarea"
                                  autosize
                                ></el-input>
                              </div>
                              <div>
                                内容:
                                <el-input v-model="jianyi.nr" size="small" type="textarea" autosize></el-input>
                                <el-input
                                  v-model="emptyAdvice.nr"
                                  size="small"
                                  type="textarea"
                                  autosize
                                ></el-input>
                              </div>
                            </div>
                          </div>
                          <!-- 如果 advices 为空时,渲染空的输入框 -->
                          <div v-else>
                            <div>
                              标题:
                              <el-input v-model="emptyAdvice.bt" size="small" type="textarea" autosize></el-input>
                            </div>
                            <div>
                              内容:
                              <el-input v-model="emptyAdvice.nr" size="small" type="textarea" autosize></el-input>
                            <div style="margin-top: 10px">
                              <el-button
                                @click="shanchu(props.row)"
                                type="danger"
                                size="small"
                                >删除</el-button
                              >
                            </div>
                          </div>
                        </template>
                      </el-table-column>
                          <div style="margin-top: 10px">
                            <el-button @click="shanchu(props.row)" type="danger" size="small">删除</el-button>
                          </div>
                        </div>
                      </template>
                      <el-table-column
                        align="center"
                        label="检测项目"
                        width="232"
                        :show-overflow-tooltip="true"
                      >
                        <template slot-scope="scope">
                          <div>{{ scope.row.proName }}</div>
                        </template>
                      </el-table-column>
                      <el-table-column
                        align="center"
                        prop="proResult"
                        label="检测结果"
                        width="403"
                      >
                      </el-table-column>
                    </el-table>
                  </template>
                </div>
              </template>
              <template v-if="status1 == 1">
                <div>
                  <div
                    style="
                      text-align: center;
                      background-color: #e6a23c;
                      margin-top: 10px;
                    "
                  >
                    项目检查情况
                  </div>
                  <el-table
                    :row-style="redxiangmu"
                    :data="statusList"
                    style="width: 100%"
                    :header-cell-style="{ background: '#e6a23c' }"
                  >
                    <el-table-column
                      align="center"
                      label="部门"
                      width="144"
                      prop="deptName"
                    >
                    </el-table-column>
                    <el-table-column
                      align="center"
                      prop="proName"
                      label="项目"
                      width="260"
                    >
                    </el-table-column>
                    <el-table-column align="center" label="检测项目" width="232" :show-overflow-tooltip="true">
                    <el-table-column
                      label="状态"
                      align="center"
                      prop="type"
                      :show-overflow-tooltip="true"
                      width="120"
                    >
                      <template slot-scope="scope">
                        <div>{{ scope.row.proName }}</div>
                        <span v-if="scope.row.type == '0'">未审核</span>
                        <span v-if="scope.row.type == '1'">已审核</span>
                        <span v-if="scope.row.type == '2'">弃检</span>
                        <span v-if="scope.row.type == '3'">延期</span>
                      </template>
                    </el-table-column>
                    <el-table-column align="center" prop="proResult" label="检测结果" width="403">
                    <el-table-column
                      label="检查时间"
                      align="center"
                      prop="bcupdateTime"
                      width="160"
                    />
                  </el-table>
                </div>
              </template>
              <template v-if="status1 == 2">
                <div>
                  <div style="text-align: center; margin-top: 10px">
                    复查项目
                  </div>
                  <div style="display: flex; margin: 15px">
                    <span
                      slot="label"
                      style="
                        display: inline-block;
                        border-bottom: 2px solid blue;
                        font-size: 0.8vw;
                      "
                      @click="handleQuery"
                    >
                      项目选择
                    </span>
                    <div v-if="xmChange.length > 0" style="display: flex">
                      <div style="margin: 0 40px; font-size: 0.8vw">
                        项目名称:{{ xmChange[0].proName || "" }}
                      </div>
                      <div style="margin: 0 40px; font-size: 0.8vw">
                        价格:{{ xmChange[0].price || "" }}
                      </div>
                    </div>
                    <div v-else style="display: flex">
                      <div style="margin: 0 40px; font-size: 0.8vw">
                        项目名称:{{}}
                      </div>
                      <div style="margin: 0 40px; font-size: 0.8vw">
                        价格:{{}}
                      </div>
                    </div>
                    <el-button
                      type="primary"
                      size="mini"
                      @click="handleaddClick()"
                      >添加</el-button
                    >
                  </div>
                  <el-table
                    :row-style="redxiangmu"
                    :data="fcList"
                    style="width: 100%"
                  >
                    <el-table-column
                      type="selection"
                      width="40"
                      align="center"
                    />
                    <el-table-column label="序号" align="center" prop="newID" />
                    <el-table-column
                      label="名称"
                      align="center"
                      prop="proName"
                      width="100px"
                    />
                    <el-table-column label="价格" align="center" prop="price" />
                    <el-table-column
                      label="科室"
                      align="center"
                      prop="deptName"
                    />
                    <el-table-column label="操作" align="center" width="130px">
                      <template slot-scope="scope">
                        <el-button
                          type="primary"
                          size="mini"
                          @click="handledeleteClick(scope.row)"
                          >删除</el-button
                        >
                      </template>
                    </el-table-column>
                  </el-table>
                </template>
              </div>
            </template>
            <template v-if="status1 == 1">
              <div>
                <div style="
                    text-align: center;
                    background-color: #e6a23c;
                    margin-top: 10px;
                  ">
                  项目检查情况
                </div>
                <el-table :row-style="redxiangmu" :data="statusList" style="width: 100%"
                  :header-cell-style="{ background: '#e6a23c' }">
                  <el-table-column align="center" label="部门" width="144" prop="deptName">
                  </el-table-column>
                  <el-table-column align="center" prop="proName" label="项目" width="260">
                  </el-table-column>
              </template>
              <template v-if="status1 == 3">
                <div class="hist3">
                  <span class="txt">问诊信息</span>
                  <el-form
                    ref="form"
                    :model="formobj"
                    label-width="100px"
                    :inline="true"
                    size="mini"
                  >
                    <el-collapse class="coll" v-model="activeName" accordion>
                      <el-collapse-item
                        class="coll"
                        title="基本信息"
                        name="1"
                        style="width: 100%; font-weight: 600"
                      >
                        <div style="width: 100%">
                          <el-form-item label="姓名" prop="cusName">
                            <el-input
                              disabled
                              v-model="formobj.cusName"
                              placeholder="请输入姓名"
                            />
                          </el-form-item>
                          <el-form-item label="职业" prop="work">
                            <el-select
                              filterable
                              v-model="formobj.work"
                              placeholder="请选择职业"
                              clearable
                              style="width: 150px"
                              disabled
                            >
                              <el-option
                                v-for="dict in dict.type.tj_work"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                              />
                            </el-select>
                          </el-form-item>
                          <el-form-item label="工作状态" prop="workStatus">
                            <el-select
                              disabled
                              filterable
                              v-model="formobj.workStatus"
                              placeholder="请选择工作状态"
                              clearable
                              style="width: 150px"
                            >
                              <el-option
                                v-for="dict in dict.type.tj_work_status"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                              />
                            </el-select>
                          </el-form-item>
                          <el-form-item label="接触毒物" prop="contactPoison">
                            <el-input
                              disabled
                              type="textarea"
                              rows="4"
                              v-model="formobj.contactPoison"
                              placeholder="请输入接触毒物"
                              style="width: 700px"
                            />
                          </el-form-item>
                          <el-form-item label="既往病史" prop="medicalHistory">
                            <el-input
                              disabled
                              type="textarea"
                              rows="4"
                              v-model="formobj.medicalHistory"
                              placeholder="请输入既往病史"
                              style="width: 700px"
                            />
                          </el-form-item>
                        </div>
                      </el-collapse-item>
                      <el-collapse-item title="月经史" name="2" v-show="sex">
                        <div style="width: 100%">
                          <el-form-item label="初潮(岁)" prop="chuchao">
                            <el-input
                              v-model="formobj.chuchao"
                              style="width: 70px"
                              disabled
                            />
                          </el-form-item>
                          <el-form-item label="经期" prop="jingqi">
                            <el-input
                              v-model="formobj.jingqi"
                              disabled
                              style="width: 70px"
                            />天
                          </el-form-item>
                          <el-form-item label="周期" prop="zhouqi">
                            <el-input
                              v-model="formobj.zhouqi"
                              disabled
                              style="width: 70px"
                            />天
                          </el-form-item>
                          <el-form-item label="末次月经" prop="mociage">
                            <el-input
                              v-model="formobj.mociage"
                              disabled
                              style="width: 100px"
                            />
                          </el-form-item>
                        </div>
                      </el-collapse-item>
                      <el-collapse-item title="生育史" name="3" v-show="sex">
                        <div style="width: 100%">
                          <el-form-item label="现有子女(人)" prop="zinv">
                            <el-input
                              v-model="formobj.zinv"
                              style="width: 70px"
                              disabled
                            />
                          </el-form-item>
                          <el-form-item label="流产(次)" prop="liuchan">
                            <el-input
                              v-model="formobj.liuchan"
                              style="width: 70px"
                              disabled
                            />
                          </el-form-item>
                          <el-form-item label="早产(次)" prop="zaochan">
                            <el-input
                              v-model="formobj.zaochan"
                              style="width: 70px"
                              disabled
                            />
                          </el-form-item>
                          <el-form-item label="死产(次)" prop="sichan">
                            <el-input
                              v-model="formobj.sichan"
                              style="width: 70px"
                              disabled
                            />
                          </el-form-item>
                          <el-form-item label="异常胎(次)" prop="yichangtai">
                            <el-input
                              v-model="formobj.yichangtai"
                              style="width: 70px"
                              disabled
                            />
                          </el-form-item>
                        </div>
                      </el-collapse-item>
                      <el-collapse-item title="烟酒史" name="4">
                        <div style="width: 100%">
                          <el-form-item label="是否吸烟" prop="xiyan">
                            <!-- <el-input v-model="form.xiyanpinlv" placeholder="请输入吸烟频率" /> -->
                            <el-select
                              disabled
                              filterable
                              v-model="formobj.xiyan"
                              placeholder="请选择是否吸烟"
                              clearable
                              style="width: 150px"
                            >
                              <el-option
                                v-for="dict in dict.type.tj_smoking_pinlv"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                              />
                            </el-select>
                          </el-form-item>
                          <el-form-item label="吸烟频率" prop="xiyanpinlv">
                            <el-input
                              v-model="formobj.xiyanpinlv"
                              disabled
                              style="width: 70px"
                            />支/天
                          </el-form-item>
                          <el-form-item label="吸烟时间" prop="xiyanyear">
                            <el-input
                              v-model="formobj.xiyanyear"
                              disabled
                              style="width: 70px"
                            />年 </el-form-item
                          ><br />
                          <el-form-item label="是否饮酒" prop="yinjiu">
                            <!-- <el-input v-model="form.yinjiupinlv" placeholder="请输入饮酒频率" /> -->
                            <el-select
                              filterable
                              v-model="formobj.yinjiu"
                              disabled
                              placeholder="请选择是否饮酒"
                              clearable
                              style="width: 150px"
                            >
                              <el-option
                                v-for="dict in dict.type.tj_smoking_pinlv"
                                :key="dict.value"
                                :label="dict.label"
                                :value="dict.value"
                              />
                            </el-select>
                          </el-form-item>
                          <el-form-item label="饮酒频率" prop="yinjiupinlv">
                            <el-input
                              v-model="formobj.yinjiupinlv"
                              disabled
                              style="width: 70px"
                            />ml/天
                          </el-form-item>
                          <el-form-item label="饮酒时间" prop="yinjiuyear">
                            <el-input
                              v-model="formobj.yinjiuyear"
                              disabled
                              style="width: 70px"
                            />年
                          </el-form-item>
                          <el-form-item label="其他" prop="qita">
                            <el-input
                              v-model="formobj.qita"
                              placeholder="请输入其他"
                              disabled
                              type="textarea"
                              style="width: 600px"
                              rows="2"
                            />
                          </el-form-item>
                        </div>
                      </el-collapse-item>
                      <el-collapse-item title="急慢性职业病史信息" name="5">
                        <div style="width: 100%">
                          <el-table
                            border
                            :data="formobj.tjAskHistorysList"
                            ref="tjAskHistorys"
                            style="width: 98%"
                          >
                            <el-table-column
                              type="selection"
                              width="40"
                              align="center"
                            />
                            <el-table-column
                              label="疾病名称"
                              prop="diseaseName"
                            >
                              <template slot-scope="scope">
                                <el-input
                                  size="mini"
                                  disabled
                                  v-model="scope.row.diseaseName"
                                  placeholder="请输入疾病名称"
                                />
                              </template>
                            </el-table-column>
                            <el-table-column
                              label="诊断日期"
                              prop="diseaseData"
                            >
                              <template slot-scope="scope">
                                <el-date-picker
                                  size="mini"
                                  v-model="scope.row.diseaseData"
                                  align="right"
                                  type="date"
                                  placeholder="选择日期"
                                  :picker-options="pickerOptions"
                                  style="width: 130px"
                                  value-format="yyyy-MM-dd"
                                >
                                </el-date-picker>
                              </template>
                            </el-table-column>
                            <el-table-column
                              label="诊断单位"
                              prop="diseaseCompany"
                            >
                              <template slot-scope="scope">
                                <el-input
                                  size="mini"
                                  disabled
                                  v-model="scope.row.diseaseCompany"
                                  placeholder="请输入诊断单位"
                                />
                              </template>
                            </el-table-column>
                            <el-table-column label="是否痊愈" prop="isOk">
                              <template slot-scope="scope">
                                <!-- <el-input v-model="scope.row.isOk" placeholder="请输入是否痊愈" /> -->
                                <el-select
                                  disabled
                                  filterable
                                  size="mini"
                                  v-model="scope.row.isOk"
                                  placeholder="请选择是否痊愈"
                                  clearable
                                >
                                  <el-option
                                    v-for="dict in dict.type.sys_yes_no"
                                    :key="dict.value"
                                    :label="dict.label"
                                    :value="dict.value"
                                  />
                                </el-select>
                              </template>
                            </el-table-column>
                            <el-table-column label="备注" prop="remark">
                              <template slot-scope="scope">
                                <el-input
                                  disabled
                                  size="mini"
                                  v-model="scope.row.remark"
                                  placeholder="请输入备注"
                                />
                              </template>
                            </el-table-column>
                          </el-table>
                        </div>
                      </el-collapse-item>
                  <el-table-column label="状态" align="center" prop="type" :show-overflow-tooltip="true" width="120">
                    <template slot-scope="scope">
                      <span v-if="scope.row.type == '0'">未审核</span>
                      <span v-if="scope.row.type == '1'">已审核</span>
                      <span v-if="scope.row.type == '2'">弃检</span>
                      <span v-if="scope.row.type == '3'">延期</span>
                    </template>
                  </el-table-column>
                  <el-table-column label="检查时间" align="center" prop="bcupdateTime" width="160" />
                </el-table>
              </div>
            </template>
            <template v-if="status1 == 2">
              <div>
                <div style="text-align: center; margin-top: 10px;">
                  复查项目
                      <el-collapse-item title="职业史" name="7">
                        <div style="width: 100%">
                          <el-table
                            border
                            :data="formobj.workLogs"
                            style="width: 98%"
                          >
                            <el-table-column
                              type="selection"
                              width="40"
                              align="center"
                            />
                            <el-table-column label="开始时间" prop="beginTime">
                              <template slot-scope="scope">
                                <el-date-picker
                                  size="mini"
                                  v-model="scope.row.beginTime"
                                  align="right"
                                  type="date"
                                  placeholder="选择日期"
                                  :picker-options="pickerOptions"
                                  style="width: 130px"
                                  value-format="yyyy-MM-dd"
                                >
                                </el-date-picker>
                              </template>
                            </el-table-column>
                            <el-table-column label="结束时间" prop="endTime">
                              <template slot-scope="scope">
                                <el-date-picker
                                  size="mini"
                                  disabled
                                  v-model="scope.row.endTime"
                                  align="right"
                                  type="date"
                                  placeholder="选择日期"
                                  :picker-options="pickerOptions"
                                  style="width: 130px"
                                  value-format="yyyy-MM-dd"
                                >
                                </el-date-picker>
                              </template>
                            </el-table-column>
                            <el-table-column
                              label="工作单位"
                              prop="workCompany"
                            >
                              <template slot-scope="scope">
                                <el-input
                                  size="mini"
                                  disabled
                                  v-model="scope.row.workCompany"
                                  placeholder="请输入工作单位"
                                />
                              </template>
                            </el-table-column>
                            <el-table-column label="部门" prop="workDept">
                              <template slot-scope="scope">
                                <el-input
                                  disabled
                                  size="mini"
                                  v-model="scope.row.workDept"
                                  placeholder="请输入部门"
                                />
                              </template>
                            </el-table-column>
                            <el-table-column label="工种" prop="workType">
                              <template slot-scope="scope">
                                <el-input
                                  disabled
                                  size="mini"
                                  v-model="scope.row.workType"
                                  placeholder="请输入工种"
                                />
                              </template>
                            </el-table-column>
                            <el-table-column
                              label="有害因素"
                              prop="harmTypeLogs"
                            >
                              <template slot-scope="scope">
                                <!-- <el-input v-model="scope.row.isOk" placeholder="请输入是否痊愈" /> -->
                                <el-select
                                  filterable
                                  disabled
                                  size="mini"
                                  v-model="scope.row.harmTypeLogs"
                                  multiple
                                  placeholder="请选择有害因素"
                                  clearable
                                >
                                  <el-option
                                    v-for="dict in harmTypeList"
                                    :key="dict.aid"
                                    :label="dict.harmtype"
                                    :value="dict.aid"
                                  />
                                </el-select>
                              </template>
                            </el-table-column>
                            <el-table-column label="防护措施" prop="fangHu">
                              <template slot-scope="scope">
                                <el-input
                                  disabled
                                  size="mini"
                                  v-model="scope.row.fangHu"
                                  placeholder="请输入防护措施"
                                />
                              </template>
                            </el-table-column>
                          </el-table>
                        </div>
                      </el-collapse-item>
                    </el-collapse>
                  </el-form>
                </div>
                <div style="display: flex;margin:15px ;">
                  <span slot="label" style="display: inline-block; border-bottom: 2px solid blue;font-size: 0.8vw;"
                    @click="handleQuery">
                    项目选择
                  </span>
                  <div v-if="xmChange.length > 0" style="display: flex;">
                    <div style="margin:0 40px;font-size: 0.8vw;">项目名称:{{ xmChange[0].proName || "" }}</div>
                    <div style="margin:0 40px ;font-size: 0.8vw;">价格:{{ xmChange[0].price || "" }}</div>
                  </div>
                  <div v-else style="display: flex;">
                    <div style="margin:0 40px;font-size: 0.8vw;">项目名称:{{ }}</div>
                    <div style="margin:0 40px ;font-size: 0.8vw;">价格:{{ }}</div>
                  </div>
                  <el-button type="primary" size="mini" @click="handleaddClick()">添加</el-button>
                </div>
                <el-table :row-style="redxiangmu" :data="fcList" style="width: 100%">
                  <el-table-column type="selection" width="40" align="center" />
                  <el-table-column label="序号" align="center" prop="newID" />
                  <el-table-column label="名称" align="center" prop="proName" width="100px" />
                  <el-table-column label="价格" align="center" prop="price" />
                  <el-table-column label="科室" align="center" prop="deptName" />
                  <el-table-column label="操作" align="center" width="130px">
                    <template slot-scope="scope">
                      <el-button type="primary" size="mini" @click="handledeleteClick(scope.row)">删除</el-button>
                    </template>
                  </el-table-column>
                </el-table>
              </div>
            </template>
            <template v-if="status1 == 3">
              <div class="hist3" >
        <span class="txt">问诊信息</span>
        <el-form ref="form" :model="formobj" label-width="100px" :inline="true" size="mini">
          <el-collapse class="coll" v-model="activeName" accordion>
            <el-collapse-item class="coll" title="基本信息" name="1" style="width: 100%; font-weight: 600">
              <div style="width: 100%">
                <el-form-item label="姓名" prop="cusName">
                  <el-input disabled v-model="formobj.cusName" placeholder="请输入姓名" />
                </el-form-item>
                <el-form-item label="职业" prop="work">
                  <el-select filterable v-model="formobj.work" placeholder="请选择职业" clearable style="width: 150px"
                    disabled>
                    <el-option v-for="dict in dict.type.tj_work" :key="dict.value" :label="dict.label"
                      :value="dict.value" />
                  </el-select>
                </el-form-item>
                <el-form-item label="工作状态" prop="workStatus">
                  <el-select disabled filterable v-model="formobj.workStatus" placeholder="请选择工作状态" clearable
                    style="width: 150px">
                    <el-option v-for="dict in dict.type.tj_work_status" :key="dict.value" :label="dict.label"
                      :value="dict.value" />
                  </el-select>
                </el-form-item>
                <el-form-item label="接触毒物" prop="contactPoison">
                  <el-input disabled type="textarea" rows="4" v-model="formobj.contactPoison" placeholder="请输入接触毒物"
                    style="width: 700px" />
                </el-form-item>
                <el-form-item label="既往病史" prop="medicalHistory">
                  <el-input disabled type="textarea" rows="4" v-model="formobj.medicalHistory" placeholder="请输入既往病史"
                    style="width: 700px" />
                </el-form-item>
              </div>
            </el-collapse-item>
            <el-collapse-item title="月经史" name="2" v-show="sex">
              <div style="width: 100%">
                <el-form-item label="初潮(岁)" prop="chuchao">
                  <el-input v-model="formobj.chuchao" style="width: 70px" disabled />
                </el-form-item>
                <el-form-item label="经期" prop="jingqi">
                  <el-input v-model="formobj.jingqi" disabled style="width: 70px" />天
                </el-form-item>
                <el-form-item label="周期" prop="zhouqi">
                  <el-input v-model="formobj.zhouqi" disabled style="width: 70px" />天
                </el-form-item>
                <el-form-item label="末次月经" prop="mociage">
                  <el-input v-model="formobj.mociage" disabled style="width: 100px" />
                </el-form-item>
              </div>
            </el-collapse-item>
            <el-collapse-item title="生育史" name="3" v-show="sex">
              <div style="width: 100%">
                <el-form-item label="现有子女(人)" prop="zinv">
                  <el-input v-model="formobj.zinv" style="width: 70px" disabled />
                </el-form-item>
                <el-form-item label="流产(次)" prop="liuchan">
                  <el-input v-model="formobj.liuchan" style="width: 70px" disabled />
                </el-form-item>
                <el-form-item label="早产(次)" prop="zaochan">
                  <el-input v-model="formobj.zaochan" style="width: 70px" disabled />
                </el-form-item>
                <el-form-item label="死产(次)" prop="sichan">
                  <el-input v-model="formobj.sichan" style="width: 70px" disabled />
                </el-form-item>
                <el-form-item label="异常胎(次)" prop="yichangtai">
                  <el-input v-model="formobj.yichangtai" style="width: 70px" disabled />
                </el-form-item>
              </div>
            </el-collapse-item>
            <el-collapse-item title="烟酒史" name="4">
              <div style="width: 100%">
                <el-form-item label="是否吸烟" prop="xiyan">
                  <!-- <el-input v-model="form.xiyanpinlv" placeholder="请输入吸烟频率" /> -->
                  <el-select disabled filterable v-model="formobj.xiyan" placeholder="请选择是否吸烟" clearable
                    style="width: 150px">
                    <el-option v-for="dict in dict.type.tj_smoking_pinlv" :key="dict.value" :label="dict.label"
                      :value="dict.value" />
                  </el-select>
                </el-form-item>
                <el-form-item label="吸烟频率" prop="xiyanpinlv">
                  <el-input v-model="formobj.xiyanpinlv" disabled style="width: 70px" />支/天
                </el-form-item>
                <el-form-item label="吸烟时间" prop="xiyanyear">
                  <el-input v-model="formobj.xiyanyear" disabled style="width: 70px" />年 </el-form-item><br />
                <el-form-item label="是否饮酒" prop="yinjiu">
                  <!-- <el-input v-model="form.yinjiupinlv" placeholder="请输入饮酒频率" /> -->
                  <el-select filterable v-model="formobj.yinjiu" disabled placeholder="请选择是否饮酒" clearable
                    style="width: 150px">
                    <el-option v-for="dict in dict.type.tj_smoking_pinlv" :key="dict.value" :label="dict.label"
                      :value="dict.value" />
                  </el-select>
                </el-form-item>
                <el-form-item label="饮酒频率" prop="yinjiupinlv">
                  <el-input v-model="formobj.yinjiupinlv" disabled style="width: 70px" />ml/天
                </el-form-item>
                <el-form-item label="饮酒时间" prop="yinjiuyear">
                  <el-input v-model="formobj.yinjiuyear" disabled style="width: 70px" />年
                </el-form-item>
                <el-form-item label="其他" prop="qita">
                  <el-input v-model="formobj.qita" placeholder="请输入其他" disabled type="textarea" style="width: 600px"
                    rows="2" />
                </el-form-item>
              </div>
            </el-collapse-item>
            <el-collapse-item title="急慢性职业病史信息" name="5">
              <div style="width: 100%">
                <el-table border :data="formobj.tjAskHistorysList" ref="tjAskHistorys" style="width: 98%">
                  <el-table-column type="selection" width="40" align="center" />
                  <el-table-column label="疾病名称" prop="diseaseName">
                    <template slot-scope="scope">
                      <el-input size="mini" disabled v-model="scope.row.diseaseName" placeholder="请输入疾病名称" />
                    </template>
                  </el-table-column>
                  <el-table-column label="诊断日期" prop="diseaseData">
                    <template slot-scope="scope">
                      <el-date-picker size="mini" v-model="scope.row.diseaseData" align="right" type="date"
                        placeholder="选择日期" :picker-options="pickerOptions" style="width: 130px"
                        value-format="yyyy-MM-dd">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="诊断单位" prop="diseaseCompany">
                    <template slot-scope="scope">
                      <el-input size="mini" disabled v-model="scope.row.diseaseCompany" placeholder="请输入诊断单位" />
                    </template>
                  </el-table-column>
                  <el-table-column label="是否痊愈" prop="isOk">
                    <template slot-scope="scope">
                      <!-- <el-input v-model="scope.row.isOk" placeholder="请输入是否痊愈" /> -->
                      <el-select disabled filterable size="mini" v-model="scope.row.isOk" placeholder="请选择是否痊愈"
                        clearable>
                        <el-option v-for="dict in dict.type.sys_yes_no" :key="dict.value" :label="dict.label"
                          :value="dict.value" />
                      </el-select>
                    </template>
                  </el-table-column>
                  <el-table-column label="备注" prop="remark">
                    <template slot-scope="scope">
                      <el-input disabled size="mini" v-model="scope.row.remark" placeholder="请输入备注" />
                    </template>
                  </el-table-column>
                </el-table>
              </div>
            </el-collapse-item>
            <el-collapse-item title="职业史" name="7">
              <div style="width: 100%">
                <el-table border :data="formobj.workLogs" style="width: 98%">
                  <el-table-column type="selection" width="40" align="center" />
                  <el-table-column label="开始时间" prop="beginTime">
                    <template slot-scope="scope">
                      <el-date-picker size="mini" v-model="scope.row.beginTime" align="right" type="date"
                        placeholder="选择日期" :picker-options="pickerOptions" style="width: 130px"
                        value-format="yyyy-MM-dd">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="结束时间" prop="endTime">
                    <template slot-scope="scope">
                      <el-date-picker size="mini" disabled v-model="scope.row.endTime" align="right" type="date"
                        placeholder="选择日期" :picker-options="pickerOptions" style="width: 130px"
                        value-format="yyyy-MM-dd">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="工作单位" prop="workCompany">
                    <template slot-scope="scope">
                      <el-input size="mini" disabled v-model="scope.row.workCompany" placeholder="请输入工作单位" />
                    </template>
                  </el-table-column>
                  <el-table-column label="部门" prop="workDept">
                    <template slot-scope="scope">
                      <el-input disabled size="mini" v-model="scope.row.workDept" placeholder="请输入部门" />
                    </template>
                  </el-table-column>
                  <el-table-column label="工种" prop="workType">
                    <template slot-scope="scope">
                      <el-input disabled size="mini" v-model="scope.row.workType" placeholder="请输入工种" />
                    </template>
                  </el-table-column>
                  <el-table-column label="有害因素" prop="harmTypeLogs">
                    <template slot-scope="scope">
                      <!-- <el-input v-model="scope.row.isOk" placeholder="请输入是否痊愈" /> -->
                      <el-select filterable disabled size="mini" v-model="scope.row.harmTypeLogs" multiple
                        placeholder="请选择有害因素" clearable>
                        <el-option v-for="dict in harmTypeList" :key="dict.aid" :label="dict.harmtype"
                          :value="dict.aid" />
                      </el-select>
                    </template>
                  </el-table-column>
                  <el-table-column label="防护措施" prop="fangHu">
                    <template slot-scope="scope">
                      <el-input disabled size="mini" v-model="scope.row.fangHu" placeholder="请输入防护措施" />
                    </template>
                  </el-table-column>
                </el-table>
              </div>
            </el-collapse-item>
          </el-collapse>
        </el-form>
      </div>
            </template>
              </template>
              <el-button
                type="primary"
                @click="addnew"
                :disabled="isdisabled"
                style="margin-top: 20px"
                >新增</el-button
              >
            </div>
          </div>
        </div>
      </div>
    </el-drawer>
     <el-dialog title="新增异常结果" :visible.sync="addNewDialogVisible" width="900px" class="custom-dialog">
      <el-form :model="newItem" ref="newItemForm" label-width="100px" class="custom-form">
        <el-form-item label="项目分类" prop="parentName">
          <el-select v-model="newItem.parentName" placeholder="请选择项目分类" clearable filterable
            @change="handleCategoryChange">
            <el-option v-for="item in projectCategories" :key="item.proId" :label="item.proName"
              :value="item.proName" />
          </el-select>
        </el-form-item>
        <el-form-item label="检测项目" prop="jcxm">
          <el-input v-model="newItem.jcxm" placeholder="请输入检测项目或从分类选择" clearable></el-input>
        </el-form-item>
        <el-form-item label="检测结果" prop="jcjg">
          <el-input v-model="newItem.jcjg" placeholder="请输入检测结果" clearable></el-input>
        </el-form-item>
        <el-form-item label="参考范围" prop="ckfw">
          <el-input v-model="newItem.ckfw" placeholder="请输入参考范围" clearable></el-input>
        </el-form-item>
        <el-form-item label="单位" prop="dw">
          <el-input v-model="newItem.dw" placeholder="请输入单位" clearable></el-input>
        </el-form-item>
        <!-- 动态建议组 -->
        <div v-for="(advice, index) in newItem.map" :key="index" class="advice-group">
          <el-form-item label="建议标题" :prop="'map.' + index + '.bt'">
            <el-input v-model="advice.bt" placeholder="请输入建议标题" clearable @focus="tan($event)"></el-input>
          </el-form-item>
          <el-form-item label="建议内容" :prop="'map.' + index + '.nr'">
            <el-input v-model="advice.nr" type="textarea" rows="3" placeholder="请输入建议内容" resize="none"
              @focus="tan($event)"></el-input>
          </el-form-item>
          <el-button v-if="index > 0" type="danger" size="small" @click="removeAdvice(index)"
            style="margin-left: 100px; margin-bottom: 10px;">删除</el-button>
        </div>
        <el-form-item>
          <el-button type="primary" size="small" @click="addAdvice" style="margin-left: 100px;">添加建议</el-button>
        </el-form-item>
      </el-form>
      <span slot="footer" class="dialog-footer">
        <el-button @click="addNewDialogVisible = false">取消</el-button>
        <el-button type="primary" @click="submitNewItem">确定</el-button>
      </span>
    </el-dialog>
     <el-dialog title="快捷建议选择" :visible.sync="showjianyi" width="1000px" class="custom-dialog"
      :before-close="handleCloseAdviceDialog">
      <!-- 搜索区域 -->
      <div style="margin-bottom: 15px;">
        <el-form :inline="true" @submit.native.prevent>
          <el-form-item label="建议名称">
            <el-input v-model="queryParams1.zyzd" placeholder="请输入建议名称进行筛选" clearable style="width: 200px"
              @input="filterAdvices(true)" @keyup.enter.native="filterAdvices(true)" />
          </el-form-item>
        </el-form>
      </div>
      <!-- 建议表格 -->
      <el-table v-loading="adviceLoading" :data="advicerulesList" ref="adviceTable" border highlight-current-row
        @current-change="handleCurrentChangeAdvice" style="max-height: 400px; overflow-y: auto;"
        :empty-text="adviceEmptyText">
        <el-table-column label="科室" prop="ks" width="100" align="center" />
        <el-table-column label="建议名称" prop="jymc" align="center" />
        <el-table-column label="建议内容" prop="jynr" align="center" />
      </el-table>
      <!-- 分页 -->
      <div class="pag">
        <div class="pag2">
          <pagination v-show="total1 > 0" :total="total1" :page.sync="queryParams1.pageNum"
            :limit.sync="queryParams1.pageSize" @pagination="filterAdvices(false)" />
        </div>
      </div>
      <!-- 底部按钮 -->
      <span slot="footer" class="dialog-footer">
        <el-button @click="cancelAdviceDialog">取消</el-button>
        <el-button type="primary" @click="applySelectedAdvice" :disabled="!selectedAdvice">确定</el-button>
      </span>
    </el-dialog>
    <el-dialog :visible.sync="xmopen" width="800px" append-to-body>
      <div style="margin: 20px;">
        <el-table :data="datasList" ref="elTable" v-loading="loading" @selection-change="handlexmChange" border
          height="320px">
      <div style="margin: 20px">
        <el-table
          :data="datasList"
          ref="elTable"
          v-loading="loading"
          @selection-change="handlexmChange"
          border
          height="320px"
        >
          <el-table-column type="selection" width="40" align="center" />
          <el-table-column label="名称" align="center" prop="proName" width="100px" />
          <el-table-column
            label="名称"
            align="center"
            prop="proName"
            width="100px"
          />
          <el-table-column label="价格" align="center" prop="price" />
          <el-table-column label="科室" align="center" prop="deptName" />
        </el-table>
@@ -784,29 +1597,58 @@
        <el-button @click="cancels">取 消</el-button>
      </div>
    </el-dialog>
    <el-dialog title="PDF 预览" :visible.sync="dialogVisible" :close-on-click-modal="false" width="50%">
    <el-dialog
      title="PDF 预览"
      :visible.sync="dialogVisible"
      :close-on-click-modal="false"
      width="50%"
    >
      <div class="main">
        <iframe id="printIframe" :src="url" frameborder="0" style="width: 100%; height: 100%"></iframe>
        <iframe
          id="printIframe"
          :src="url"
          frameborder="0"
          style="width: 100%; height: 100%"
        ></iframe>
      </div>
    </el-dialog>
    <el-dialog title="提示" :visible.sync="jianqians" width="1000px" :before-close="handleClose1">
      <jianqianwenzhen :jianqianwenzhendata="jianqianwenzhendata" v-if="flags"></jianqianwenzhen>
    <el-dialog
      title="提示"
      :visible.sync="jianqians"
      width="1000px"
      :before-close="handleClose1"
    >
      <jianqianwenzhen
        :jianqianwenzhendata="jianqianwenzhendata"
        v-if="flags"
      ></jianqianwenzhen>
      <span slot="footer" class="dialog-footer">
        <el-button @click="jianqians = false">取 消</el-button>
      </span>
    </el-dialog>
    <Packages ref="bbb" :baogao="baogao" />
    <Prescription ref="Pre" :preObj="preObj" />
    <proposal ref="proposal" :cusobj="cusobj" :tjNumber="tjNumber" @event1="eventchange($event)" />
    <proposal
      ref="proposal"
      :cusobj="cusobj"
      :tjNumber="tjNumber"
      @event1="eventchange($event)"
    />
    <createproposal ref="createproposal" :creatobj="creatobj" />
    <el-dialog title="常用建议维护" :visible.sync="propdialog" width="500px" append-to-body>
    <el-dialog
      title="常用建议维护"
      :visible.sync="propdialog"
      width="500px"
      append-to-body
    >
    </el-dialog>
  </div>
</template>
<script>
import _ from 'lodash';
import jianqianwenzhen from "@/components/jianqianwenzhen";
import Packages from "@/components/Packages";
import Prescription from "@/components/Prescription";
@@ -824,8 +1666,10 @@
  gettoPdf,
  getModified,
  isPdfOrJimu,
  addOrder,UpdFcPro,
  getFcList
  addOrder,
  addOrder1,
  UpdFcPro,
  getFcList,
} from "@/api/doctor/checkAll";
import { getInfoById } from "@/api/hosp/history";
import { getInfo } from "@/api/login";
@@ -839,8 +1683,8 @@
import { getTjYxjcList } from "@/api/system/package";
import { getNewDateList } from "@/api/hosp/order";
import { getconfigKey } from "@/api/login";
import { listAdvicerules } from "@/api/hosp/advicerules";
import moment from "moment";
import { get } from "sortablejs";
export default {
  components: {
@@ -879,8 +1723,10 @@
      fcList: [],
      xmopen: false,
      datasList: [],
      advicerulesList: [],
      jianqianwenzhendata: [],
      jianqians: false,
      adviceLoading: false,
      sex: true,
      activeName: "1",
      remarks: "",
@@ -890,7 +1736,27 @@
      proIds: "",
      cusobj: {},
      xiaojie: "",
      selectedAdvice: null,
      isdisabled: false,
      showjianyi: false,
      addNewDialogVisible: false,
      adviceEmptyText: '暂无数据',
      total1: 0,
      adviceCache: new Map(),
      queryParams1: {
        pageNum: 1,
        pageSize: 10,
        zyzd: '',
      },
       newItem: {
        parentName: '',
        jcxm: '',
        jcjg: '',
        ckfw: '',
        dw: '',
        map: [{ bt: '', nr: '' }]
      },
      projectCategories: [],
      src: "",
      url: "",
      userId: "",
@@ -949,6 +1815,8 @@
      selectLettercurrent: " ",
      // 抽屉打开方式
      drawer: false,
      isLoading: false,
      xmopen: false,
      tableAll: {},
      tjNumber: "",
      // 全部小结
@@ -1020,6 +1888,127 @@
    });
  },
  methods: {
    tan(event) {
      this.activeAdviceIndex = event.target.closest('.advice-group')
        ? Array.from(event.target.closest('.el-form').querySelectorAll('.advice-group'))
          .indexOf(event.target.closest('.advice-group'))
        : 0;
      this.queryParams1.pageNum = 1;
      this.queryParams1.pageSize = 10;
      this.queryParams1.zyzd = '';
      this.selectedAdvice = null;
      this.advicerulesList = [];
      this.total1 = 0;
      this.adviceCache.clear();
      this.filterAdvices();
      this.showjianyi = true;
    },
    // 筛选快捷建议(防抖 800ms,带缓存和加载状态)
    filterAdvices: _.debounce(function (resetPage = false) {
      if (resetPage) {
        this.queryParams1.pageNum = 1;
      }
      const cacheKey = `${this.queryParams1.zyzd || ''}_${this.queryParams1.pageNum}_${this.queryParams1.pageSize}`;
      if (this.adviceCache.has(cacheKey)) {
        const cachedData = this.adviceCache.get(cacheKey);
        this.advicerulesList = cachedData.rows;
        this.total1 = cachedData.total;
        this.adviceEmptyText = this.advicerulesList.length === 0 ? '暂无匹配的建议' : '暂无数据';
        return;
      }
      this.adviceLoading = true;
      this.adviceEmptyText = '加载中...';
      listAdvicerules(this.queryParams1)
        .then((response) => {
          this.advicerulesList = response.rows || [];
          this.total1 = response.total || 0;
          this.adviceCache.set(cacheKey, {
            rows: this.advicerulesList,
            total: this.total1,
          });
          this.adviceEmptyText = this.advicerulesList.length === 0 ? '暂无匹配的建议' : '暂无数据';
        })
        .catch((error) => {
          console.error('筛选快捷建议失败:', error);
          this.advicerulesList = [];
          this.total1 = 0;
          this.adviceEmptyText = '加载失败,请稍后重试';
          this.$message.error('加载建议失败,请检查网络后重试');
        })
        .finally(() => {
          this.adviceLoading = false;
        });
    }, 800),
     handleCurrentChangeAdvice(currentRow) {
      this.selectedAdvice = currentRow;
    },
    submitFormxm() {
      this.xmopen = false;
    },
    cancels() {
      this.xmopen = false;
      this.xmChange = [];
    },
    handleCategoryChange(value) {
      if (value) {
        this.newItem.jcxm = value;
      }
    },
    applySelectedAdvice() {
      if (this.selectedAdvice) {
        this.$set(this.newItem.map, this.activeAdviceIndex, {
          bt: this.selectedAdvice.jymc,
          nr: this.selectedAdvice.jynr,
        });
        this.showjianyi = false;
        this.selectedAdvice = null;
      } else {
        this.$message.warning('请先选择一条建议');
      }
    },
    handleCloseAdviceDialog(done) {
      if (this.selectedAdvice) {
        this.$confirm('您已选择一条建议,确定要关闭吗?', '提示', {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning',
        })
          .then(() => {
            this.cancelAdviceDialog();
            done();
          })
          .catch(() => { });
      } else {
        this.cancelAdviceDialog();
        done();
      }
    },
    cancelAdviceDialog() {
      this.showjianyi = false;
      this.selectedAdvice = null;
      this.queryParams1.zyzd = '';
      this.queryParams1.pageNum = 1;
      this.advicerulesList = [];
      this.total1 = 0;
      this.adviceCache.clear();
    },
    setTime() {
      //设置定时器
      this.clearTimeSet = setInterval(() => {
@@ -1168,18 +2157,18 @@
      this.status1 = 2;
      let data = {
        tjNum: this.tjNumber,
        type: 1
        type: 1,
      };
      getFcList(data)
        .then((res) => {
          this.fcList = res.data;
          this.fcList.forEach((item,index) => {
          this.fcList.forEach((item, index) => {
            item.newID = index + 1;
          })
          });
        })
        .catch((error) => {
          console.error('获取复查项目失败:', error);
          this.$message.error('获取复查项目失败');
          console.error("获取复查项目失败:", error);
          this.$message.error("获取复查项目失败");
        })
        .finally(() => {
          this.loading = false;
@@ -1187,101 +2176,117 @@
    },
    handleQuery() {
      this.xmopen = true
      this.xmopen = true;
      let data = {
        tjNum: this.tjNumber,
        type: 0
      }
      getFcList(data).then(res => {
        this.datasList = res.data
      })
        type: 0,
      };
      getFcList(data).then((res) => {
        this.datasList = res.data;
      });
    },
    handleaddClick() {
      console.log(this.xmChange)
      console.log(this.xmChange);
      let data = {
        orderId: this.xmChange[0].orderId,
        data: [{
          proId: this.xmChange[0].proId,
          type: 1
        }]
      }
      UpdFcPro(data).then(res => {
        data: [
          {
            proId: this.xmChange[0].proId,
            type: 1,
          },
        ],
      };
      UpdFcPro(data).then((res) => {
        if (res.code == 200) {
          this.xmChange = []
          this.fuchaxiangmu()
          this.xmChange = [];
          this.fuchaxiangmu();
        }
      })
      });
    },
    handledeleteClick(row) {
      let data = {
        orderId: row.orderId,
        data: [{
          proId: row.proId,
          type: 0
        }]
      }
      UpdFcPro(data).then(res => {
        data: [
          {
            proId: row.proId,
            type: 0,
          },
        ],
      };
      UpdFcPro(data).then((res) => {
        if (res.code == 200) {
          this.fuchaxiangmu()
          this.fuchaxiangmu();
        }
      })
      });
    },
    handlexmChange(selection) {
      this.xmChange = []
      this.xmChange = selection
      this.xmChange = [];
      this.xmChange = selection;
      if (selection.length > 1) {
        let del_row = selection.shift();
        this.$refs.elTable.toggleRowSelection(del_row, false); //设置这一行取消选中
      }
    },
    submitFormxm() {
      this.xmopen = false
      this.xmopen = false;
    },
    cancels() {
      this.xmopen = false
      this.xmChange = []
      this.xmopen = false;
      this.xmChange = [];
    },
    guanbi() {
      this.drawer = false;
    },
    yichangjieguo() {
      this.isLoading = true;
      this.status1 = 0;
      let _this = this;
      yichang({
        tjNum: this.tjNumber,
      }).then((res) => {
        this.yichangList = res.data;
      })
        .then((res) => {
          this.isLoading = false;
          this.yichangList = res.data;
        // console.log(this.yichangList, 3232);
        this.getExpends();
          // console.log(this.yichangList, 3232);
          this.getExpends();
        this.yichangList.forEach((item) => {
          item.sone.forEach((soneItem) => {
            if (
              !Array.isArray(soneItem.advices) ||
              soneItem.advices.length === 0
            ) {
              // 如果 advices 是空,设置默认值
              soneItem.advices = [
                {
                  bt: "",
                  nr: "",
                },
              ];
            }
          this.yichangList.forEach((item) => {
            item.sone.forEach((soneItem) => {
              if (
                !Array.isArray(soneItem.advices) ||
                soneItem.advices.length === 0
              ) {
                // 如果 advices 是空,设置默认值
                soneItem.advices = [
                  {
                    bt: "",
                    nr: "",
                  },
                ];
              }
            });
          });
          if (!this.yichangList) {
            _this.$message({
              type: "warning ",
              message: "暂无异常报告",
            });
          }
        })
        .catch((error) => {
          this.isLoading = false;
          console.error("获取异常结果失败:", error);
          this.$message.error("获取异常结果失败");
        })
        .finally(() => {
          this.isLoading = false;
          this.loading = false;
        });
        if (!this.yichangList) {
          _this.$message({
            type: "warning ",
            message: "暂无异常报告",
          });
        }
      });
    },
    getdate() {
      getNewDateList().then((res) => {
@@ -1760,8 +2765,10 @@
                };
                getModifiedState(data).then((res) => {
                  this.MsgId = res.msg;
                  this.isLoading = true;
                  this.drawer = true;
                  getupdateCheckType(this.tjNumber).then((response) => {
                    this.isLoading = false;
                    this.changedate = response.data;
                    if (this.changedate) {
                      this.changedate.forEach((item) => {
@@ -1823,8 +2830,10 @@
                    };
                    getforceIn(data).then((res) => {
                      this.MsgId = res.msg;
                      this.isLoading = true;
                      this.drawer = true;
                      getupdateCheckType(this.tjNumber).then((response) => {
                        this.isLoading = false;
                        this.changedate = response.data;
                        if (this.changedate) {
                          for (let i = 0; i < this.changedate.length; i++) {
@@ -1950,6 +2959,71 @@
      });
    },
    addAdvice() {
      this.newItem.map.push({ bt: '', nr: '' });
    },
     removeAdvice(index) {
      if (this.newItem.map.length > 1) {
        this.newItem.map.splice(index, 1);
      } else {
        this.$message.warning('至少保留一组建议');
      }
    },
    submitNewItem() {
      const data = {
        tjh: this.tableAll.tjNumber,
        parentName: this.newItem.parentName,
        jcxm: this.newItem.jcxm,
        jcjg: this.newItem.jcjg,
        ckfw: this.newItem.ckfw,
        dw: this.newItem.dw,
        map: this.newItem.map,
        jyjc: this.newItem.ckfw ? "0" : "1"
      };
      addOrder1(data).then((res) => {
        if (res.code === 200) {
          this.$message.success('新增异常结果成功');
          this.addNewDialogVisible = false;
          this.yichangjieguo();
        } else {
          this.$message.error('新增失败');
        }
      }).catch((error) => {
        console.error('新增异常结果失败:', error);
        this.$message.error('新增异常结果失败');
      });
    },
     addnew() {
      this.newItem = {
        parentName: '',
        jcxm: '',
        jcjg: '',
        ckfw: '',
        dw: '',
        map: [{ bt: '', nr: '' }]
      };
      this.addNewDialogVisible = true;
      cSWebGetPro(this.tjNumber).then((res) => {
        if (res.data && Array.isArray(res.data)) {
          this.projectCategories = res.data;
        } else {
          this.$message.warning('未获取到项目分类数据');
          this.projectCategories = [];
        }
      }).catch((error) => {
        console.error('获取项目分类失败:', error);
        this.$message.error('获取项目分类失败');
        this.projectCategories = [];
      });
    },
    cancel() {
      this.propdialog = false;
    },
@@ -1990,7 +3064,7 @@
              state: 1,
              id: this.MsgId,
            };
            getfiedState(data).then((res) => { });
            getfiedState(data).then((res) => {});
            this.submitForm();
          });
      } else {
@@ -2022,7 +3096,7 @@
    //     });
    //   }
    // },
    change(vale) { },
    change(vale) {},
    // determine() {
    //   let tjNumber = this.tableAll.tjNumber;
@@ -2298,38 +3372,38 @@
}
/* 每个按钮的位置和动画延迟 */
.btnbox>div:nth-child(1) {
.btnbox > div:nth-child(1) {
  top: 20%;
  /* 第一个按钮的位置 */
  animation-delay: 0s;
  /* 无延迟 */
}
.btnbox>div:nth-child(2) {
.btnbox > div:nth-child(2) {
  top: 30%;
  /* 第二个按钮的位置 */
  animation-delay: 0.2s;
}
.btnbox>div:nth-child(3) {
.btnbox > div:nth-child(3) {
  top: 40%;
  /* 第三个按钮的位置 */
  animation-delay: 0.4s;
}
.btnbox>div:nth-child(4) {
.btnbox > div:nth-child(4) {
  top: 50%;
  /* 第四个按钮的位置 */
  animation-delay: 0.6s;
}
.btnbox>div:nth-child(5) {
.btnbox > div:nth-child(5) {
  top: 60%;
  /* 第五个按钮的位置 */
  animation-delay: 0.8s;
}
.btnbox>div:nth-child(6) {
.btnbox > div:nth-child(6) {
  top: 70%;
  /* 第六个按钮的位置 */
  animation-delay: 1s;
@@ -2508,6 +3582,58 @@
  }
}
.pag2 {
  width: auto;
  /* 移除固定宽度,让分页器根据内容自适应 */
  min-width: 750px;
  /* 设置最小宽度,确保分页器不会太窄 */
  text-align: center;
  /* 确保分页器内部元素居中 */
}
.custom-dialog {
  ::v-deep .el-dialog__header {
    padding: 15px 20px;
    background-color: #f5f7fa;
    border-bottom: 1px solid #e8ecef;
  }
  ::v-deep .el-dialog__title {
    font-size: 18px;
    color: #303133;
    font-weight: 600;
  }
  ::v-deep .el-dialog__body {
    padding: 20px; // 增加内边距
    background-color: #fff;
  }
  ::v-deep .el-dialog__footer {
    padding: 10px 20px;
    border-top: 1px solid #e8ecef;
    text-align: right;
  }
  .custom-form {
    .advice-group {
      border: 1px solid #e8ecef;
      border-radius: 4px;
      padding: 10px;
      margin-bottom: 15px;
      background-color: #f9fbfc;
      .el-form-item {
        margin-bottom: 15px;
      }
      .el-button {
        margin-top: 5px;
      }
    }
  }
}
.kong {
  box-shadow: none;
}