11
WXL
2024-02-20 4fbeee3784d4be5483ed7ec9e00a875d66bc9ed0
src/views/project/donationdetails/index.vue
@@ -3,7 +3,7 @@
    <div class="left-course">
      <div class="postfilx">
        <div class="title">工作进程</div>
        <div style="height: 666px;">
        <div>
          <el-steps direction="vertical" :active="workflow">
            <el-step title="潜在捐献" icon="el-icon-user">
              <template slot="description" v-if="Processdata.donatebaseinfo.createtime">
@@ -618,8 +618,8 @@
            <el-col :span="12">
              <el-form-item label="签字亲属" prop="kinshipconfirmationsign">
                <el-checkbox-group v-model="organdecision">
                  <el-checkbox v-for="item in kinshiplist" :label="item">
                    {{ item }}
                  <el-checkbox v-for="item in kinshiplist" :key="item" :label="item">
                    {{ item == "子女" ? item + "(人)" : item }}
                  </el-checkbox>
                </el-checkbox-group>
              </el-form-item>
@@ -635,13 +635,14 @@
              </el-form-item>
            </el-col>
          </el-row>
          <el-row></el-form-item><el-form-item label-width="100px" label="捐献决定">
          <el-row>
            <el-form-item label-width="100px" label="捐献决定">
              <el-checkbox-group v-model="organdecision">
                <el-checkbox v-for="item in organlist" :label="item">
                  {{ item }}
                <el-checkbox v-for="item in organselection" :key="item" :label="item">{{ item }}
                </el-checkbox>
              </el-checkbox-group>
            </el-form-item></el-row>
            </el-form-item>
          </el-row>
          <el-row>
            <!-- <el-col :span="18">
              <el-form-item align="left" label="捐献决定">
@@ -739,8 +740,7 @@
                <el-date-picker clearable size="small" v-model="ethicform.conclusiontime" type="date"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择结论时间">
                </el-date-picker>
              </el-form-item>
            </el-col></el-row>
              </el-form-item> </el-col></el-row>
        </el-form>
        <div class="dialog-footer" style="min-height: 500px; margin: 20px 0; ">
          <el-button v-show="!showTerminationBtn" type="primary" @click="Savethedetails">保存</el-button>
@@ -756,12 +756,12 @@
        </div>
      </div>
      <!-- 器官分配 -->
      <div class="boxdiv" v-show="actives == 4 || actives == 5 || actives == 6">
        <el-form ref="allocationform" :model="allocationform" :rules="allocationrules" label-position="right">
      <div class="boxdiv" v-show="actives == 4">
        <el-form ref="allocateddata" :model="allocateddata" :rules="allocationrules" label-position="right">
          <el-row>
            <el-col>
              <el-form-item label-width="100px" label="选择器官">
                <el-checkbox-group v-model="organalForm.organname">
              <el-form-item label-width="100px" label="分配器官">
                <el-checkbox-group v-model="organList.organallocated">
                  <el-checkbox v-for="dict in dict.type.sys_Organ" :key="dict.value" :label="dict.value"
                    @change="changeorganState(dict.value)">
                    {{ dict.label }}
@@ -773,153 +773,63 @@
          <el-row>
            <el-col>
              <el-form-item>
                <el-table v-loading="loading" border :data="allocationform">
                  <el-table-column label="器官名称" align="center" width="100" prop="organname" />
                  <el-table-column label="器官编号" align="center" width="100" prop="organno" />
                  <el-table-column label="系统编号" align="center" width="120" prop="ageunit" v-if="actives == 4">
                <el-table v-loading="loading" border :data="allocateddata">
                  <el-table-column label="器官名称" align="center" width="110" prop="organname">
                    <template slot-scope="scope">
                      <el-input :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " v-model="scope.row.ageunit" placeholder="系统编号" />
                      <el-input v-model="scope.row.organname" placeholder="器官名称" :disabled="scope.row.organno != 'C01'" />
                    </template>
                  </el-table-column>
                  <el-table-column label="接收时间" align="center" width="200" prop="applicanttime" v-if="actives == 4">
                  <el-table-column label="器官编号" align="center" width="90" prop="organno" />
                  <el-table-column label="系统编号" align="center" width="120" prop="caseno">
                    <template slot-scope="scope">
                      <el-date-picker :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " clearable size="small" style="width: 100%" v-model="scope.row.applicanttime" type="datetime"
                        value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择接收时间">
                      <el-input v-model="scope.row.caseno" placeholder="系统编号" />
                    </template>
                  </el-table-column>
                  <el-table-column label="接收时间" align="center" width="200" prop="applicanttime">
                    <template slot-scope="scope">
                      <el-date-picker clearable size="small" style="width: 100%" v-model="scope.row.applicanttime"
                        type="datetime" value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择接收时间">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="受体姓名" align="center" width="120" prop="name" v-if="actives == 4">
                  <el-table-column label="受体姓名" align="center" width="120" prop="name">
                    <template slot-scope="scope">
                      <el-input :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " v-model="scope.row.name" placeholder="受体姓名" />
                      <el-input v-model="scope.row.name" placeholder="受体姓名" />
                    </template>
                  </el-table-column>
                  <!--
              <el-table-column label="证件类型" align="center" width="150" prop="idcardtype" v-if="actives == 4">
              <el-table-column label="证件类型" align="center" width="150" prop="idcardtype">
                <template slot-scope="scope">
                  <el-select :disabled="scope.row.allocationstatus == 2 ||
                    scope.row.organstate == 2 ||
                    scope.row.transplantstate == 2
                    " v-model="scope.row.idcardtype" placeholder="移植人证件类型">
                  <el-select v-model="scope.row.idcardtype" placeholder="移植人证件类型">
                    <el-option v-for="dict in dict.type.sys_IDType" :key="dict.value" :label="dict.label"
                      :value="parseInt(dict.value)"></el-option>
                  </el-select>
                </template>
              </el-table-column>
              <el-table-column label="证件号码" align="center" width="200" prop="idcardno" v-if="actives == 4">
              <el-table-column label="证件号码" align="center" width="200" prop="idcardno">
                <template slot-scope="scope">
                  <el-input :disabled="scope.row.allocationstatus == 2 ||
                    scope.row.organstate == 2 ||
                    scope.row.transplantstate == 2
                    " v-model="scope.row.idcardno" placeholder="证件号码" />
                  <el-input v-model="scope.row.idcardno" placeholder="证件号码" />
                </template>
              </el-table-column>
              -->
                  <el-table-column label="分配状态" align="center" width="150" prop="allocationstatus" v-if="actives == 4">
              </el-table-column>
                  <el-table-column label="分配状态" align="center" width="150" prop="allocationstatus">
                    <template slot-scope="scope">
                      <el-select v-model="scope.row.allocationstatus" placeholder="请选择器官状态">
                        <el-option v-for="dict in allocationstatuslist" :key="dict.value" :label="dict.label"
                          :value="dict.value"></el-option>
                      </el-select>
                    </template>
                  </el-table-column>
                  <el-table-column prop="reallocationreason" label="重分配说明" align="center" v-if="actives == 4">
                  </el-table-column>
                -->
                  <el-table-column prop="reallocationreason" label="说明" align="center">
                    <template slot-scope="scope">
                      <el-input clearable v-model="scope.row.reallocationreason" placeholder="请输入重分配说明" />
                      <el-input type="textarea" clearable v-model="scope.row.reallocationreason" placeholder="请输入说明" />
                    </template>
                  </el-table-column>
                  <el-table-column label="获取医师" align="center" width="120" prop="organgetdoct" v-if="actives == 5">
                    <template slot-scope="scope">
                      <el-input :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " v-model="scope.row.organgetdoct" placeholder="医师姓名" />
                    </template>
                  </el-table-column>
                  <el-table-column label="获取时间" align="center" width="200" prop="organgettime" v-if="actives == 5">
                    <template slot-scope="scope">
                      <el-date-picker :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " clearable size="small" style="width: 100%" v-model="scope.row.organgettime" type="datetime"
                        value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择获取时间">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="获取组织" align="center" prop="gainhospitalno" v-if="actives == 5">
                    <template slot-scope="scope">
                      <org-selecter :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " ref="tranHosSelect" :org-type="'4'" v-model="scope.row.gainhospitalno" style="width: 100%" />
                    </template>
                  </el-table-column>
                  <!--
              <el-table-column label="获取状态" align="center" width="150" prop="organstate" v-if="actives == 5">
                <template slot-scope="scope">
                  <el-select v-model="scope.row.organstate" placeholder="请选择器官状态">
                    <el-option v-for="dict in organstatelist" :key="dict.value" :label="dict.label"
                      :value="dict.value"></el-option>
                  </el-select>
                </template>
              </el-table-column>
              -->
                  <el-table-column label="移植医院" align="center" width="230" prop="transplanthospitalname"
                    v-if="actives == 6">
                    <template slot-scope="scope">
                      <org-selecter :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " ref="tranHosSelect" :org-type="'4'" v-model="scope.row.transplanthospitalno"
                        style="width: 100%" />
                    </template>
                  </el-table-column>
                  <el-table-column label="移植负责人" align="center" width="120" prop="transplantdoct" v-if="actives == 6">
                    <template slot-scope="scope">
                      <el-input :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " v-model="scope.row.transplantdoct" placeholder="医师姓名" />
                    </template>
                  </el-table-column>
                  <el-table-column label="移植时间" align="center" width="200" prop="transplanttime" v-if="actives == 6">
                    <template slot-scope="scope">
                      <el-date-picker :disabled="scope.row.allocationstatus == 2 ||
                        scope.row.organstate == 2 ||
                        scope.row.transplantstate == 2
                        " clearable size="small" style="width: 100%" v-model="scope.row.transplanttime" type="datetime"
                        value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择移植时间">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="移植状态" align="center" width="150" prop="transplantstate" v-if="actives == 6">
                    <template slot-scope="scope">
                      <el-select v-model="scope.row.transplantstate" placeholder="请选择器官状态">
                        <el-option v-for="dict in transplantstatelist" :key="dict.value" :label="dict.label"
                          :value="dict.value"></el-option>
                      </el-select>
                    </template>
                  </el-table-column>
                  <el-table-column prop="abandonreason" label="弃用原因" align="center" v-if="actives == 6">
                    <template slot-scope="scope">
                      <el-input clearable v-model="scope.row.abandonreason" placeholder="请输入弃用原因" />
                    </template>
                  </el-table-column>
                  <el-table-column label="操作" width="200" align="center" class-name="small-padding fixed-width"
                  <el-table-column label="操作" align="center" width="100" class-name="small-padding fixed-width"
                    v-if="actives == 4">
                    <template slot-scope="scope">
                      <el-button size="mini" type="text" icon="el-icon-copy-document"
                        @click="deldistribution(scope.row)">删除</el-button>
                      <el-button size="mini" type="text" icon="el-icon-copy-document"
                        @click="redistribution(scope.row)">重新分配</el-button>
                        @click="redistribution(scope.row)">重分配</el-button>
                    </template>
                  </el-table-column>
                </el-table>
@@ -955,120 +865,160 @@
          </el-row>
          <el-row> </el-row>
          <el-row>
            <el-col :span="2">
              <el-form-item align="left" label="死亡判定:" />
            </el-col>
            <el-col :span="10">
              <el-form-item align="left" label="医生一" prop="deathjudgedocto">
            <el-col :span="6">
              <el-form-item align="left" label="死亡判定:医生一" label-width="140px" prop="deathjudgedocto">
                <el-input v-model="witnessform.deathjudgedocto" placeholder="判定医生姓名" />
              </el-form-item>
            </el-col>
            <el-col :span="10">
              <el-form-item align="left" label="医生二" prop="deathjudgedoctt">
            <el-col :span="6">
              <el-form-item align="left" label="医生二" label-width="120px" prop="deathjudgedoctt">
                <el-input v-model="witnessform.deathjudgedoctt" placeholder="判定医生姓名" />
              </el-form-item>
            </el-col>
          </el-row>
          <el-row><el-col :span="2"><el-form-item align="left" label="" /> </el-col>
            <el-col :span="10">
              <el-form-item align="left" label="死亡时间" prop="deathtime">
            <el-col :span="6">
              <el-form-item align="left" label="死亡时间" label-width="120px" prop="deathtime">
                <el-date-picker clearable v-model="witnessform.deathtime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择死亡时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="10">
              <el-form-item align="left" label="死亡原因" prop="deathreason">
            <el-col :span="6">
              <el-form-item align="left" label="死亡原因" label-width="120px" prop="deathreason">
                <el-input v-model="witnessform.deathreason" placeholder="请输入死亡原因" />
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="2">
              <el-form-item align="left" label="手术:" />
            </el-col>
            <el-col :span="10">
              <el-form-item align="left" label="开始时间" prop="operationbegtime">
            <el-col :span="6">
              <el-form-item align="left" label="手术:开始时间" label-width="140px" prop="operationbegtime">
                <el-date-picker clearable v-model="witnessform.operationbegtime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择手术开始时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="10">
              <el-form-item align="left" label="结束时间" prop="operationendtime">
            <el-col :span="6">
              <el-form-item align="left" label="结束时间" label-width="120px" prop="operationendtime">
                <el-date-picker clearable v-model="witnessform.operationendtime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择手术结束时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row><el-col :span="2"><el-form-item align="left" label="腹主动脉:" />
            </el-col>
            <el-col :span="10">
              <el-form-item label="插管时间" align="left" prop="abdominalaortacannulatime">
          <el-row>
            <el-col :span="6">
              <el-form-item label="腹主动脉:插管时间" align="left" label-width="140px" prop="abdominalaortacannulatime">
                <el-date-picker clearable v-model="witnessform.abdominalaortacannulatime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择腹主动脉插管时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="10">
              <el-form-item label="灌注时间" align="left" prop="abdominalaortaperfusiontime">
            <el-col :span="6">
              <el-form-item label="灌注时间" align="left" label-width="120px" prop="abdominalaortaperfusiontime">
                <el-date-picker clearable v-model="witnessform.abdominalaortaperfusiontime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择腹主动脉灌注时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row><el-col :span="2"><el-form-item align="left" label="门静脉:" />
            </el-col>
            <el-col :span="10">
              <el-form-item label="插管时间" align="left" prop="portalveincannulatime">
            <el-col :span="6">
              <el-form-item label="门静脉:插管时间" align="left" label-width="140px" prop="portalveincannulatime">
                <el-date-picker clearable v-model="witnessform.portalveincannulatime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择门静脉脉插管时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="10">
              <el-form-item label="灌注时间" align="left" prop="portalveinperfusiontime">
            <el-col :span="6">
              <el-form-item label="灌注时间" align="left" label-width="120px" prop="portalveinperfusiontime">
                <el-date-picker clearable v-model="witnessform.portalveinperfusiontime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择门静脉灌注时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row><el-col :span="2"><el-form-item align="left" label="肺动脉:" />
            </el-col>
            <el-col :span="10">
              <el-form-item label="插管时间" align="left" prop="pulmonaryarterycannulatime">
          <el-row>
            <el-col :span="6">
              <el-form-item label="肺动脉:插管时间" align="left" label-width="140px" prop="pulmonaryarterycannulatime">
                <el-date-picker clearable v-model="witnessform.pulmonaryarterycannulatime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择门静脉插管时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="10">
              <el-form-item label="灌注时间" align="left" prop="pulmonaryarteryperfusiontime">
            <el-col :span="6">
              <el-form-item label="灌注时间" align="left" label-width="120px" prop="pulmonaryarteryperfusiontime">
                <el-date-picker clearable v-model="witnessform.pulmonaryarteryperfusiontime" type="datetime"
                  value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择门静脉灌注时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row><el-col :span="2"><el-form-item align="left" label="主动脉:" />
            </el-col>
            <el-col :span="10">
              <el-form-item label="灌注时间" align="left" prop="aortacannulatime">
            <el-col :span="6">
              <el-form-item label="主动脉:灌注时间" align="left" label-width="140px" prop="aortacannulatime">
                <el-date-picker clearable v-model="witnessform.aortacannulatime" type="datetime"
                  value-format="yyyy-MM-dd  HH:mm:ss" placeholder="选择主动脉灌注时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="10">
              <el-form-item label="灌注时间" align="left" prop="aortaperfusiontime">
            <el-col :span="6">
              <el-form-item label="灌注时间" align="left" label-width="120px" prop="aortaperfusiontime">
                <el-date-picker clearable v-model="witnessform.aortaperfusiontime" type="datetime"
                  value-format="yyyy-MM-dd  HH:mm:ss" placeholder="选择主动脉灌注时间">
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col>
              <el-form-item label-width="100px" label="获取器官">
                <el-checkbox-group v-model="organList.organprocured">
                  <el-checkbox v-for="dict in dict.type.sys_Organ" :key="dict.value" :label="dict.value"
                    @change="changeorganprocured(dict.value)">
                    {{ dict.label }}
                  </el-checkbox>
                </el-checkbox-group>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col>
              <el-form-item>
                <el-table v-loading="loading" border :data="procureddata">
                  <el-table-column label="器官名称" align="center" width="110" prop="organname">
                    <template slot-scope="scope">
                      <el-input v-model="scope.row.organname" placeholder="器官名称" :disabled="scope.row.organno != 'C01'" />
                    </template>
                  </el-table-column>
                  <el-table-column label="器官编号" align="center" width="90" prop="organno" />
                  <el-table-column label="器官离体时间" align="center" width="200" prop="organgettime">
                    <template slot-scope="scope">
                      <el-date-picker clearable size="small" style="width: 100%" v-model="scope.row.organgettime"
                        type="datetime" value-format="yyyy-MM-dd HH:mm:ss" placeholder="请输入器官离体时间">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="获取医院" align="center" width="230" prop="gainhospitalno">
                    <template slot-scope="scope">
                      <div class="elldiv">
                        <org-selecter ref="tranHosSelect" :org-type="'4'" v-model="scope.row.gainhospitalno" />
                      </div>
                    </template>
                  </el-table-column>
                  <el-table-column label="获取医师" align="center" width="120" prop="organgetdoct">
                    <template slot-scope="scope">
                      <el-input v-model="scope.row.organgetdoct" placeholder="请输入医师姓名" />
                    </template>
                  </el-table-column>
                  <el-table-column label="获取状态" align="center" width="150" prop="organstate">
                    <template slot-scope="scope">
                      <el-select v-model="scope.row.organstate" placeholder="请选择器官状态">
                        <el-option v-for="dict in organstatelist" :key="dict.value" :label="dict.label"
                          :value="dict.value"></el-option>
                      </el-select>
                    </template>
                  </el-table-column>
                  <el-table-column label="说明" align="center" prop="notgetreason">
                    <template slot-scope="scope">
                      <el-input type="textarea" clearable v-model="scope.row.notgetreason" placeholder="请输入未获取说明" />
                    </template>
                  </el-table-column>
                </el-table>
              </el-form-item>
            </el-col>
          </el-row>
@@ -1136,6 +1086,64 @@
        <el-form ref="accomplishform" :model="accomplishform" :rules="accomplishrules" label-width="100px"
          label-position="right">
          <el-row>
            <el-col>
              <el-form-item label-width="100px" label="移植器官">
                <el-checkbox-group v-model="organList.organtransplant">
                  <el-checkbox v-for="dict in dict.type.sys_Organ" :key="dict.value" :label="dict.value"
                    @change="changeorgantransplant(dict.value)">
                    {{ dict.label }}
                  </el-checkbox>
                </el-checkbox-group>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col>
              <el-form-item>
                <el-table v-loading="loading" border :data="transplantdata">
                  <el-table-column label="器官名称" align="center" width="110" prop="organname">
                    <template slot-scope="scope">
                      <el-input v-model="scope.row.organname" placeholder="器官名称" :disabled="scope.row.organno != 'C01'" />
                    </template>
                  </el-table-column>
                  <el-table-column label="器官编号" align="center" width="90" prop="organno" />
                  <el-table-column label="移植医院" align="center" width="220" prop="transplanthospitalname"
                    v-if="actives == 6">
                    <template slot-scope="scope">
                      <org-selecter ref="tranHosSelect" :org-type="'4'" v-model="scope.row.transplanthospitalno"
                        style="width: 100%" />
                    </template>
                  </el-table-column>
                  <el-table-column label="移植负责人" align="center" width="120" prop="transplantdoct">
                    <template slot-scope="scope">
                      <el-input v-model="scope.row.transplantdoct" placeholder="医师姓名" />
                    </template>
                  </el-table-column>
                  <el-table-column label="移植时间" align="center" width="200" prop="transplanttime">
                    <template slot-scope="scope">
                      <el-date-picker clearable size="small" style="width: 100%" v-model="scope.row.transplanttime"
                        type="datetime" value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择移植时间">
                      </el-date-picker>
                    </template>
                  </el-table-column>
                  <el-table-column label="移植状态" align="center" width="150" prop="transplantstate">
                    <template slot-scope="scope">
                      <el-select v-model="scope.row.transplantstate" placeholder="请选择器官状态">
                        <el-option v-for="dict in transplantstatelist" :key="dict.value" :label="dict.label"
                          :value="dict.value"></el-option>
                      </el-select>
                    </template>
                  </el-table-column>
                  <el-table-column prop="abandonreason" label="说明" align="center">
                    <template slot-scope="scope">
                      <el-input type="textarea" clearable v-model="scope.row.abandonreason" placeholder="请输入弃用说明" />
                    </template>
                  </el-table-column>
                </el-table>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="6">
              <el-form-item align="left" label="遗体捐献" prop="isbodydonation">
                <el-radio-group v-model="accomplishform.isbodydonation">
@@ -1186,7 +1194,6 @@
              </el-form-item>
            </el-col>
          </el-row>
          </el-row>
        </el-form>
        <div class="dialog-footer">
          <el-button v-show="!showTerminationBtn" type="primary" @click="Savethedetails">保存</el-button>
@@ -1199,10 +1206,6 @@
      <!-- 完结流程 -->
      <div class="boxdiv" v-show="actives > 6">
        <div style="display:flex; line-height: 100px; justify-content: center;">
          <!-- <el-image
            style="width: 100px; height: 100px"
            :src="require('@/assets/images/wanc.png')"
          ></el-image> -->
          <div style="padding: 20px 0; margin: 0 30px">
            <img style="width: 60px; height: 60px" src="@/assets/images/wanc.png" class="user-avatar" />
          </div>
@@ -1219,21 +1222,20 @@
          >文件指导目录</el-button
        >
      </div> -->
      <el-tabs style="margin-top: 20px;" v-model="activeName" type="card" @tab-click="handleClick">
        <el-tab-pane :label="activetele" :name="1"> </el-tab-pane>
      <el-tabs style="margin-top: 20px;" v-model="activeName" type="card">
        <el-tab-pane :label="activetele" name="1"> </el-tab-pane>
      </el-tabs>
      <div class="pdfimg">
        <div class="box-pdf">
          <div>
            <el-upload size="mini" class="upload-demo" :action="uploadFileUrl" :file-list="fileList"
              :show-file-list="false" multiple drag :headers="headers" :on-success="(response, file, fileList) =>
                uploadSccess(response, file, fileList)
                " :on-preview="downFile" :disabled="operationType == 'detail'" :on-error="handleUploadError"
              :on-remove="remove" accept="image/*,.pdf">
                  uploadSccess(response, file, fileList)
                " :on-preview="downFile" :on-error="handleUploadError" :on-remove="remove" accept="image/*,.pdf">
              <i class="el-icon-upload"></i>
              <div class="el-upload__text">
                将发票文件拖到此处,或
                <em><el-button :disabled="operationType == 'detail'" size="small" type="primary">点击上传</el-button></em>
                <em><el-button size="small" type="primary">点击上传</el-button></em>
              </div>
            </el-upload>
            <el-table :data="fileListto" @row-click="downFile" style="width: 100%" height="400">
@@ -1322,7 +1324,7 @@
  getEthicalreviewopinions,
  addEthicalreviewopinions,
  updateEthicalreviewopinions,
  listnewEthicalreviewopinions,
  listnewEthicalreviewopinions
} from "@/api/project/ethicalreviewopinions";
import {
  addDonateflowchart,
@@ -1333,7 +1335,8 @@
  listDonateorgan,
  addDonateorgan,
  delDonateorgan,
  updateDonateorgan
  updateDonateorgan,
  saveDonateorgan
} from "@/api/project/donateorgan";
import {
  listOrganallocation,
@@ -1344,12 +1347,19 @@
  addDonationwitness,
  updateDonationwitness,
  getDonationwitness,
  getByInfoId
  getByInfoId,
  listDonationwitnessorgan,
  saveDonationwitnessorgan,
  delDonationwitnessorgan
} from "@/api/project/donationwitness";
import {
  listnewDonatecompletioninfo,
  listDonatecompletioninfo,
  addDonatecompletioninfo,
  updateDonatecompletioninfo
  updateDonatecompletioninfo,
  listDonatecomporgan,
  saveDonatecomporgan,
  delDonatecomporgan
} from "@/api/project/donatecompletioninfo";
import Li_area_select from "@/components/Address";
import OrgSelecter from "@/views/project/components/orgselect";
@@ -1371,6 +1381,7 @@
      infoid: 736,
      drawer: false,
      form: {},
      activeName: "",
      tableDatafile: [
        {
          name: "王小虎",
@@ -1388,35 +1399,50 @@
      },
      organdecision: [],
      ethicform: {
        infoid: null,
        infoid: null
      },
      kinshiplist: ["配偶", "父亲", "母亲", "子女", "受托人"],
      organlist: [
      organselection: [
        "肝脏",
        "双肾脏",
        "心脏",
        "肺脏",
        "腺体",
        "胰腺",
        "小肠",
        "双眼组织",
        "遗体",
        "其他"
      ],
      //选择器官表单
      organList: {
        //分配列表
        organallocated: [],
        //获取列表
        organprocured: [],
        //完成列表
        organtransplant: []
      },
      //器官状态
      allocationstatuslist: [
        { value: 1, label: "已分配" },
        { value: 2, label: "作废" }
        { value: 2, label: "重分配" }
      ],
      organstatelist: [
        { value: "1", label: "已获取" },
        { value: "2", label: "弃用" }
        { value: "2", label: "回纳" }
      ],
      transplantstatelist: [
        { value: 1, label: "已移植" },
        { value: 2, label: "库存" },
        { value: 3, label: "弃用" }
      ],
      allocationform: [],
      //器官数据
      allocateddata: [],
      procureddata: [],
      transplantdata: [],
      witnessform: {
        infoid: null
      },
@@ -1432,12 +1458,9 @@
      //   保存、终止按钮确认
      showSaveBtn: true,
      showTerminationBtn: 0, //终止状态 0-未终止 1-已终止
      //选择器官表单
      organalForm: {
        //器官列表
        organname: []
      },
      Processdata: {}, //流程数据
      // 流程数据:donatebaseinfo[createtime,updatetime]、medicalevaluation、relativesconfirmation、donateflowcharts、donateorgansService、donationwitness、donatecompletioninfo
      Processdata: {},
      //省市区默认值设置,可为空
      searchAddress: {
        sheng: "",
@@ -1564,6 +1587,8 @@
      allocationrules: {},
      witnessrules: {},
      accomplishrules: {},
      //报告人列表
      reporters: [],
      //附件列表
      annexfilesList: [], //附件展示列
@@ -1582,6 +1607,7 @@
      headers: {
        Authorization: "Bearer " + getToken()
      },
      ICDtoken: getToken(),
      // 网络请求头
      Networkheader: null,
      //票据文件
@@ -1596,12 +1622,25 @@
  },
  created() {
    this.Getnetworkheader();
    this.infoid = this.$route.query.id;
  },
  mounted() {
    // this.id = this.$route.query.id;
    this.Getbasicinformation();
    this.listDonateannex();
    //获取报告人列表:专职人员
    listReportname("zzry").then(res => {
      this.reporters = res.data;
    });
    //获取协调员列
    listReportname("xty1").then(res => {
      this.coordinatorlist1 = res.data;
    });
    //获取负责人列
    listReportname("fzr").then(res => {
      this.leaderlist = res.data;
    });
  },
  methods: {
@@ -1609,18 +1648,9 @@
    Getbasicinformation() {
      // 左侧流程数据
      getDonatebaseinfoflow(this.infoid).then(res => {
        console.log(res.data);
        this.Processdata = res.data;
      });
      //获取协调员列
      listReportname("xty1").then(res => {
        this.coordinatorlist1 = res.data;
      });
      //获取负责人列
      listReportname("fzr").then(res => {
        this.leaderlist = res.data;
      });
      // 表单数据
      getDonatebaseinfo(this.infoid).then(response => {
        this.form = response.data;
@@ -1709,7 +1739,7 @@
        if (this.ethicform.infoid) {
          return;
        }
        //listDonateflowchart(searchParam).then(response => {
        //listDonateflowchart(searchParam).then(response => {
        listEthicalreviewopinions(searchParam).then(response => {
          if (response.code == 200 && response.rows.length) {
            this.ethicform = response.rows[0];
@@ -1717,37 +1747,45 @@
            console.log("伦理审查数据为空");
          }
        });
      } else if (this.actives == 4 && !this.allocationform[0]) {
        listDonateorgan(searchParam).then(response => {
          if (response.code == 200) {
            if (response.rows[0]) {
              this.allocationform = response.rows;
      } else if (this.actives == 4 && !this.allocateddata[0]) {
        listDonateorgan(searchParam).then(res => {
          if (res.code == 200) {
            if (res.rows[0]) {
              this.allocateddata = res.rows;
            }
            this.organalForm.organname = [];
            for (let i = 0; i < response.rows.length; i++) {
              this.organalForm.organname.push(response.rows[i].organno);
            this.organList.organallocated = [];
            for (let i = 0; i < res.rows.length; i++) {
              this.organList.organallocated.push(this.allocateddata[i].organno);
            }
          } else {
            // this.$modal.msgError(
            //   "获取器官分配信息失败:" + JSON.stringify(response)
            //   "获取器官分配信息失败:" + JSON.stringify(res)
            // );
          }
        });
      } else if (this.actives == 5 && !this.witnessform.infoid) {
        // 不存在时获取器官信息
        if (!this.allocationform[0]) {
          listDonateorgan(searchParam).then(resall => {
            if (resall.code == 200) {
              if (resall.rows[0]) {
                this.allocationform = resall.rows;
              }
            } else {
              // this.$modal.msgError(
              //   "器官列表获取失败:" + JSON.stringify(resall)
              // );
            }
          });
        if (this.witnessform.infoid) {
          return;
        }
        listDonationwitnessorgan(searchParam).then(res => {
          if (res.code == 200) {
            if (res.rows[0]) {
              this.procureddata = res.rows;
              this.procureddata.infoid = this.infoid;
            }
            this.organList.organprocured = [];
            for (let i = 0; i < this.procureddata.length; i++) {
              this.organList.organprocured.push(this.procureddata[i].organno);
            }
          } else {
            // this.$modal.msgError(
            //   "器官列表获取失败:" + JSON.stringify(resall)
            // );
          }
        });
        // 获取当前见证信息
        getByInfoId(searchParam.infoid).then(response => {
          if (response.code == 200) {
@@ -1764,19 +1802,24 @@
      } else if (this.actives == 6) {
        this.annexfilesList = this.registerlist;
        this.activetele = "完成登记";
        if (this.allocationform.infoid) {
        if (this.accomplishform.infoid) {
          return;
        }
        // 不存在时获取器官
        let accpre = {
          id: searchParam.infoid
        };
        // 不存在时获取器官
        if (!this.allocationform[0]) {
          listDonateorgan(searchParam).then(resall => {
            if (resall.code == 200) {
              if (resall.rows[0]) {
                this.allocationform = resall.rows;
                this.allocationform.infoid = this.infoid;
        if (!this.organList.organtransplant[0]) {
          listDonatecomporgan(searchParam).then(res => {
            if (res.code == 200) {
              if (res.rows[0]) {
                this.transplantdata = res.rows;
                this.transplantdata.infoid = this.infoid;
              }
              for (let i = 0; i < this.transplantdata.length; i++) {
                this.organList.organtransplant.push(
                  this.transplantdata[i].organno
                );
              }
            } else {
              // this.$modal.msgError(
@@ -1786,7 +1829,8 @@
          });
        }
        // 获取完成登记信息
        listnewDonatecompletioninfo(accpre).then(response => {
        // listnewDonatecompletioninfo(accpre).then(response => {
        listDonatecompletioninfo(accpre).then(response => {
          if (response.code == 200 && response.rows.length) {
            this.accomplishform = response.rows[0];
            this.accomplishform.infoid = this.infoid;
@@ -1851,6 +1895,15 @@
            this.form.redorganname = this.form.redorganno;
          }
          //案例时间更新成获取时间
          if (this.actives == 5) {
            this.$refs["witnessform"].validate(valid1 => {
              this.$refs["form"].validate(valid2 => {
                this.form.donatetime = this.witnessform.operationbegtime;
              });
            });
          }
          if (this.form.id != null) {
            if (this.form.workflow == 0) {
              this.form.workflow = 1;
@@ -1858,20 +1911,18 @@
            updateDonatebaseinfo(this.form).then(response => {
              this.$modal.msgSuccess("保存成功");
              Modifydonationattachment(this.donatelist).then(res => {
                console.log(res);
              });
              this.Getbasicinformation();
              // this.Processvalidation();
              this.open = false;
            });
          } else {
            this.form.workflow = 1;
            this.form.workflow = 0;
            this.form.recordstate = 0;
            addDonatebaseinfo(this.form).then(response => {
              if (response.code == 200) {
                this.$modal.msgSuccess("新增成功");
                Modifydonationattachment(this.donatelist).then(res => {
                  console.log(res);
                });
                this.Getbasicinformation();
                // this.Processvalidation();
@@ -1928,14 +1979,13 @@
        this.$refs["ethicform"].validate(valid => {
          if (valid) {
            if (this.ethicform.id != null) {
              // updateDonateflowchart(this.ethicform).then(response => {
              updateEthicalreviewopinions(this.ethicform).then(response => {
              // updateDonateflowchart(this.ethicform).then(response => {
              updateEthicalreviewopinions(this.ethicform).then(res => {
                this.$modal.msgSuccess("伦理审查信息修改成功");
              });
            } else {
              //addDonateflowchart(this.ethicform).then(response => {
              addEthicalreviewopinions(this.ethicform).then(response => {
              //addDonateflowchart(this.ethicform).then(response => {
              addEthicalreviewopinions(this.ethicform).then(res => {
                this.$modal.msgSuccess("伦理审查信息新增成功");
              });
            }
@@ -1943,25 +1993,34 @@
          }
        });
      } else if (this.actives == 4) {
        this.allocationform.infoid = this.infoid;
        this.$refs["allocationform"].validate(valid => {
          if (valid) {
            let arrallo = [];
            this.allocationform.map(item => {
              if (item.id) {
                item.applicanttime = formatDate(item.applicanttime);
                updateDonateorgan(item).then(response => { });
              } else {
                arrallo.push(item);
              }
            });
            if (arrallo.length) {
              addOrganallocation(arrallo).then(response => {
                this.$modal.msgSuccess("器官捐献信息新增成功");
              });
        this.procureddata.infoid = this.infoid;
        this.$refs["allocateddata"].validate(valid => {
          /**
          let rows = [];
          this.allocateddata.map(item => {
            if (item.id) {
              item.applicanttime = formatDate(item.applicanttime);
              updateDonateorgan(item).then(response => { });
            } else {
              item.infoid=this.infoid;
              rows.push(item);
            }
            this.Processvalidation();
          });
          if (rows.length) {
            addOrganallocation(rows).then(res => {
              this.$modal.msgSuccess("器官捐献信息新增成功");
            });
          }
           */
          this.allocateddata.map(item => {
            item.applicanttime = formatDate(item.applicanttime);
          });
          saveDonateorgan(this.allocateddata).then(res => {
            if (res == 200) {
              this.$modal.msgSuccess("器官捐献分配信息保存成功!");
            }
          });
          this.Processvalidation();
        });
      } else if (this.actives == 5) {
        this.witnessform.infoid = this.infoid;
@@ -1983,29 +2042,26 @@
              coordinatedusernametIndex
            ].reportName;
          }
          console.log("juanxian");
          if (valid) {
            // 保存器官分配表数据
            let arrallo = [];
            this.allocationform.map(item => {
              if (item.id) {
                item.applicanttime = formatDate(item.applicanttime);
                updateDonateorgan(item).then(response => { });
              } else {
                arrallo.push(item);
              }
            });
            if (this.witnessform.id != null) {
              console.log(456);
              updateDonationwitness(this.witnessform).then(response => {
                this.$modal.msgSuccess("获取见证信息修改成功");
              });
            } else {
              console.log(123);
              addDonationwitness(this.witnessform).then(response => {
                this.$modal.msgSuccess("获取见证信息新增成功");
              });
            }
            //保存器官获取表数据
            this.procureddata.infoid = this.infoid;
            saveDonationwitnessorgan(this.procureddata).then(res => {
              if (res == 200) {
                this.$modal.msgSuccess("捐献器官获取信息保存成功!");
              }
            });
            this.form.donationcategory = this.witnessform.donationcategory;
            this.Processvalidation();
          }
@@ -2014,19 +2070,16 @@
        this.accomplishform.infoid = this.infoid;
        this.$refs["accomplishform"].validate(valid => {
          if (valid) {
            // 保存器官分配表数据
            let arrallo = [];
            this.allocationform.map(item => {
              if (item.id) {
                item.applicanttime = formatDate(item.applicanttime);
                updateDonateorgan(item).then(response => { });
              } else {
                arrallo.push(item);
            // 保存捐献器官移植信息
            this.transplantdata.infoid = this.infoid;
            saveDonatecomporgan(this.transplantdata).then(res => {
              if (res == 200) {
                this.$modal.msgSuccess("捐献器官获取信息保存成功!");
              }
            });
            // 保存确认信息
            if (this.accomplishform.dcid) {
              console.log(this.accomplishform);
            if (this.accomplishform.id) {
              updateDonatecompletioninfo(this.accomplishform).then(response => {
                this.$modal.msgSuccess("完成登记信息修改成功");
              });
@@ -2035,6 +2088,7 @@
                this.$modal.msgSuccess("完成登记成功");
              });
            }
            this.Processvalidation();
          }
        });
@@ -2043,8 +2097,7 @@
    // 切换tab
    on_click(e) {
      // if (e != "" || e != null) {
      console.log(this.form.workflow);
      console.log(e);
      let asdx = this.form.workflow + 1;
      if (asdx >= e) {
        this.actives = e;
@@ -2056,63 +2109,215 @@
    },
    // 器官分配栏目控制
    changeorganState(value) {
      let organIndex = this.allocationform.findIndex(
      let selectedIndex = this.organList.organallocated.findIndex(
        item => item == value
      );
      let organIndex = this.allocateddata.findIndex(
        item => item.organno == value
      );
      if (organIndex == -1) {
        //获取器官名称
        let temporganname = "";
        for (let i = 0; i < this.dict.type.sys_Organ.length; i++) {
          if (value == this.dict.type.sys_Organ[i].value) {
            temporganname = this.dict.type.sys_Organ[i].label;
            break;
      console.log(
        "selectedIndex:" + selectedIndex + ",organIndex:" + organIndex
      );
      if (selectedIndex == -1) {
        //取消选择
        if (organIndex != -1) {
          if (this.allocateddata[organIndex].id > 0) {
            this.$confirm(
              "删除器官分配数据后将不法恢复,您确认删除该条记录吗?",
              "提示",
              {
                confirmButtonText: "确定",
                cancelButtonText: "取消",
                type: "warning"
              }
            )
              .then(() => {
                this.loading = true;
                delDonateorgan(this.allocateddata[organIndex].id).then(res => {
                  this.allocateddata.splice(organIndex, 1);
                  this.loading = false;
                  this.$modal.msgSuccess(
                    "删除成功,如果需要增加该器官,请重新选择器官!"
                  );
                });
              })
              .catch(() => {
                this.organList.organallocated.push(value);
              });
          } else {
            //新记录直接删除
            this.allocateddata.splice(organIndex, 1);
          }
        }
        if (temporganname != "") {
          this.allocationform.push({
            organname: temporganname,
            organno: value,
            id: null,
            infoid: this.infoid,
            donorno: this.form.donorno,
            transplanthospitalname: null,
            transplanthospitalno: null,
            organstate: 0
          });
        }
      } else {
        this.$confirm("是否确认删除器官分配记录", "提示", {
          confirmButtonText: "确定",
          cancelButtonText: "取消",
          type: "warning"
        })
          .then(() => {
            if (organIndex != -1) {
              let tempOrgan = this.allocationform[organIndex];
              console.log(tempOrgan);
              if (tempOrgan.organstate != 1 && tempOrgan.id > 0) {
                this.$modal.msgWarning("只有未分配器官可进行删除!");
                this.organalForm.organname.push(value);
                return;
              }
              if (tempOrgan.id > 0) {
                //查找器官表记录,判断器官状态
                this.loading = true;
                delDonateorgan(tempOrgan.id).then(delLocationRes => {
                  this.loading = false;
                  this.$modal.msgSuccess("删除成功");
                });
              } else {
                this.allocationform.splice(organIndex, 1);
              }
        //选择新器官
        if (organIndex == -1) {
          //添加器官记录
          let temporganname = "";
          for (let i = 0; i < this.dict.type.sys_Organ.length; i++) {
            if (value == this.dict.type.sys_Organ[i].value) {
              temporganname = this.dict.type.sys_Organ[i].label;
              break;
            }
          })
          .catch(() => { });
          }
          if (temporganname != "") {
            this.allocateddata.push({
              organname: temporganname,
              organno: value,
              id: null,
              infoid: this.infoid,
              donorno: this.form.donorno,
              organstate: 1
            });
          }
        } else {
          this.$modal.msgWarning("该器官已经分配,请勿重复选择!");
        }
      }
    },
    // 器官获取选择控制
    changeorganprocured(value) {
      let selectedIndex = this.organList.organprocured.findIndex(
        item => item == value
      );
      let organIndex = this.procureddata.findIndex(
        item => item.organno == value
      );
      console.log(
        "selectedIndex:" + selectedIndex + ",organIndex:" + organIndex
      );
      if (selectedIndex == -1) {
        //取消选择
        if (organIndex != -1) {
          if (this.procureddata[organIndex].id > 0) {
            this.$confirm(
              "删除器官分配数据后将不法恢复,您确认删除该条记录吗?",
              "提示",
              {
                confirmButtonText: "确定",
                cancelButtonText: "取消",
                type: "warning"
              }
            )
              .then(() => {
                this.loading = true;
                delDonationwitnessorgan(this.procureddata[organIndex].id).then(
                  res => {
                    this.procureddata.splice(organIndex, 1);
                    this.loading = false;
                    this.$modal.msgSuccess(
                      "删除成功,如果需要增加该器官,请重新选择器官!"
                    );
                  }
                );
              })
              .catch(() => {
                this.organList.organprocured.push(value);
              });
          } else {
            //新记录直接删除
            this.procureddata.splice(organIndex, 1);
          }
        }
      } else {
        //选择新器官
        if (organIndex == -1) {
          //添加器官记录
          let temporganname = "";
          for (let i = 0; i < this.dict.type.sys_Organ.length; i++) {
            if (value == this.dict.type.sys_Organ[i].value) {
              temporganname = this.dict.type.sys_Organ[i].label;
              break;
            }
          }
          if (temporganname != "") {
            this.procureddata.push({
              organname: temporganname,
              organno: value,
              id: null,
              infoid: this.infoid,
              donorno: this.form.donorno,
              organstate: "1"
            });
          }
        } else {
          this.$modal.msgWarning("该器官已经分配,请勿重复选择!");
        }
      }
    },
    // 器官移植选择控制
    changeorgantransplant(value) {
      let selectedIndex = this.organList.organtransplant.findIndex(
        item => item == value
      );
      let organIndex = this.transplantdata.findIndex(
        item => item.organno == value
      );
      console.log(
        "selectedIndex:" + selectedIndex + ",organIndex:" + organIndex
      );
      if (selectedIndex == -1) {
        //取消选择
        if (organIndex != -1) {
          if (this.transplantdata[organIndex].id > 0) {
            this.$confirm(
              "删除器官数据后将不法恢复,您确认删除该条记录吗?",
              "提示",
              {
                confirmButtonText: "确定",
                cancelButtonText: "取消",
                type: "warning"
              }
            )
              .then(() => {
                this.loading = true;
                delDonatecomporgan(this.transplantdata[organIndex].id).then(
                  res => {
                    this.transplantdata.splice(organIndex, 1);
                    this.loading = false;
                    this.$modal.msgSuccess(
                      "删除成功,如果需要增加该器官,请重新选择器官!"
                    );
                  }
                );
              })
              .catch(() => {
                this.organList.organtransplant.push(value);
              });
          } else {
            //新记录直接删除
            this.transplantdata.splice(organIndex, 1);
          }
        }
      } else {
        //选择新器官
        if (organIndex == -1) {
          //添加器官记录
          let temporganname = "";
          for (let i = 0; i < this.dict.type.sys_Organ.length; i++) {
            if (value == this.dict.type.sys_Organ[i].value) {
              temporganname = this.dict.type.sys_Organ[i].label;
              break;
            }
          }
          if (temporganname != "") {
            this.transplantdata.push({
              organname: temporganname,
              organno: value,
              id: null,
              infoid: this.infoid,
              donorno: this.form.donorno,
              organstate: 1
            });
          }
        } else {
          this.$modal.msgWarning("该器官已经选择,请勿重复选择!");
        }
      }
    },
    // 前进步骤
    makeastepforward() {
      console.log(this.actives);
      if (this.actives <= 6) {
        this.actives++;
        this.GetAttacheddata();
@@ -2122,8 +2327,7 @@
    },
    // 更改进程效验
    Processvalidation() {
      console.log(this.form.workflow);
      console.log(this.actives);
      if (this.form.workflow + 1 == this.actives || this.actives == 6) {
        if (this.form.workflow <= 6) {
          this.form.workflow++;
@@ -2134,7 +2338,6 @@
      } else if (this.form.workflow > this.actives) {
        // this.submitForm();
        Modifydonationattachment(this.donatelist).then(res => {
          console.log(res);
        });
        this.listDonateannex();
        this.GetAttacheddata();
@@ -2143,7 +2346,6 @@
        // this.$modal.msgWarning("请先完成前部步骤");
        return;
      }
      console.log(this.form.workflow);
    },
    // 上报审核
    Reportforreview() { },
@@ -2193,7 +2395,6 @@
          },
          {}
        );
        console.log(groupedArr);
      });
    },
    // 附件修改数据转存封装
@@ -2211,10 +2412,8 @@
        this.registerlist = arr;
      }
      // 删除时修改主列delFlag
      console.log(delvalue);
      const index = this.donatelist.indexOf(delvalue);
      console.log(index);
      if (index !== -1) {
      if (index != -1) {
        if (delvalue.id) {
          this.donatelist[index].delFlag = 1;
          console.log("修改老数据后", this.donatelist);
@@ -2240,46 +2439,91 @@
    // 上传成功
    uploadSccess(response, file, fileList) {
      this.rbDetails;
      const config = {
        headers: { Authorization: "Bearer " + this.ICDtoken }
      };
      const pdfimg = this.Networkheader + "/prod-api" + response.fileName;
      console.log(this.Networkheader);
      //获取票据信息位置
      if (response.code == 200) {
        // this.form.filename = file.raw.name;
        this.previewpdf = true;
        fetch(pdfimg, config)
          .then(response => response.blob())
          .then(blob => {
            // 将获取的数据流转换为URL
            this.pdfimg = URL.createObjectURL(blob);
            this.pdfimgsrcList.push(URL.createObjectURL(blob));
            this.pdftitle = "共" + this.pdfimgsrcList.length + "项";
            let addvalue = {
              annexname: file.name,
              annexurl: URL.createObjectURL(blob),
              delFlag: 0,
              infoid: this.infoid,
              annexfilestype: this.actives
            };
            this.fileListto.push(addvalue);
          })
          .catch(error => {
            console.error("Error loading image", error);
            return;
          });
        this.$modal.msgSuccess(response.msg);
        let addvalue = {
        console.log(this.fileListto, "新增后");
        if (!this.annexfilesList) {
          this.annexfilesList = [];
        }
        let addvalues = {
          annexname: file.name,
          annexurl: response.fileName,
          delFlag: 0,
          infoid: this.infoid,
          annexfilestype: this.actives
        };
        this.fileListto.push(addvalue);
        this.Newconversion(this.fileListto, "", addvalue);
        this.pdfimgsrcList.push(
          this.Networkheader + "/prod-api" + response.fileName
        );
        console.log(this.pdfimgsrcList);
        this.pdftitle = "共" + this.pdfimgsrcList.length + "项";
        this.pdfimg = this.Networkheader + "/prod-api" + response.fileName;
        this.annexfilesList = this.fileListto;
        this.annexfilesList.push(addvalues);
        this.Newconversion(this.annexfilesList, "", addvalues);
      } else {
        console.log(response.msg);
      }
    },
    // 点击票据
    // 文件弹窗触发
    Filepopup(index, rows, row) {
      const config = {
        headers: { Authorization: "Bearer " + this.ICDtoken }
      };
      this.fileListto = [];
      this.pdfimgsrcList = [];
      this.pdfimg = '';
      this.atpresent = index;
      this.pdfVisible = true;
      if (this.annexfilesList.length) {
        this.previewpdf = true;
        this.fileListto = this.annexfilesList;
        console.log(this.fileListto);
        this.pdfimg =
          this.Networkheader + "/prod-api" + this.fileListto[0].annexurl;
        this.fileListto.forEach(item => {
          this.pdfimgsrcList.push(
            this.Networkheader + "/prod-api" + item.annexurl
          );
        this.annexfilesList.forEach((value, indexson) => {
          const pdfimg = this.Networkheader + "/prod-api" + value.annexurl;
          fetch(pdfimg, config)
            .then(response => response.blob())
            .then(blob => {
              // 将获取的数据流转换为URL
              this.fileListto.push({
                annexname: value.annexname,
                annexurl: URL.createObjectURL(blob),
                delFlag: 0,
                infoid: this.infoid,
                annexfilestype: this.actives
              });
              if (this.fileListto.length == 1) {
                this.pdfimg = URL.createObjectURL(blob);
              }
              this.pdfimgsrcList.push(URL.createObjectURL(blob));
            })
            .catch(error => {
              console.error("Error loading image", error);
              return;
            });
        });
        this.previewpdf = true;
      } else {
        this.fileListto = [];
        this.pdfimg = "";
@@ -2291,8 +2535,8 @@
    downFile(item) {
      console.log(item, "点击文件拿item");
      this.pdftitle =
        "共" + this.pdfimgsrcList.length + "项,当前选中" + item.name;
      let name = item.name.split(".");
        "共" + this.pdfimgsrcList.length + "项,当前选中" + item.annexname;
      let name = item.annexname.split(".");
      if (name[1] == "pdf") {
        this.$modal.msgWarning("当前文件暂不支持预览");
        this.previewpdf = false;
@@ -2300,10 +2544,9 @@
      } else if (name[1] == "jpg" || "png") {
        this.previewpdf = true;
        if (item.annexurl) {
          this.pdfimg = this.Networkheader + "/prod-api" + item.annexurl;
          this.pdfimg = item.annexurl;
        } else {
          this.pdfimg =
            this.Networkheader + "/prod-api" + item.response.annexurl;
          this.pdfimg = "";
        }
      } else {
        this.hintitle = "当前文件暂不支持预览";
@@ -2317,15 +2560,22 @@
    },
    // 点击删除
    deletedowfile(row) {
      const indexlist = this.getIndexInArray(
        this.pdfimgsrcList,
        this.Networkheader + "/prod-api" + row.annexurl
      );
      let indexvalue = "";
      const indexlist = this.getIndexInArray(this.pdfimgsrcList, row.annexurl);
      this.pdfimgsrcList.splice(indexlist, 1);
      const index = this.getIndexInArray(this.fileListto, row);
      this.Newconversion(this.fileListto, this.fileListto[index], "");
      this.fileListto.splice(index, 1);
      console.log(index);
      indexvalue = this.annexfilesList.find((item, index) => {
        return item.annexname == row.annexname;
      });
      console.log(indexvalue, "删除索引");
      this.annexfilesList.splice(indexvalue, 1);
      this.Newconversion(
        this.annexfilesList,
        indexvalue,
        ""
      );
    },
    // 点击上移
    moveupdowfile(row) {
@@ -2342,8 +2592,59 @@
    },
    filterTag(value, row) {
      return row.tag === value;
    },
    //身份证校验赋值
    updateMessage() {
      try {
        const reg = /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/;
        if (reg.test(this.form.idcardno)) {
          // 身份证号码是否合法
          var org_birthday = this.form.idcardno.substring(6, 14);
          var org_gender = this.form.idcardno.substring(16, 17);
          var sex = org_gender % 2 == 1 ? 1 : 2;
          var birthday =
            org_birthday.substring(0, 4) +
            "-" +
            org_birthday.substring(4, 6) +
            "-" +
            org_birthday.substring(6, 8);
          var birthdays = new Date(birthday.replace(/-/g, "/"));
          let d = new Date();
          let age =
            d.getFullYear() -
            birthdays.getFullYear() -
            (d.getMonth() < birthdays.getMonth() ||
              (d.getMonth() == birthdays.getMonth() &&
                d.getDate() < birthdays.getDate())
              ? 1
              : 0);
          // 赋值给表格
          this.form.sex = sex;
          this.form.birthday = birthday;
          this.form.age = age;
        } else {
        }
      } catch { }
    },
    //重新分配器官
    redistribution(row) {
      console.log("redistribution", row);
      row.reallocationreason =
        "已重新分配,原分配信息(姓名:" +
        row.name +
        "、系统编号:" +
        row.caseno +
        "、接收时间:" +
        row.applicanttime +
        ")";
      row.name = null;
      row.caseno = null;
      row.applicanttime = null;
    }
  },
  dicts: [
    "sys_nation",
    "sys_occupation",
@@ -2392,10 +2693,10 @@
      margin: 20px 10px;
      padding: 10px;
      margin-top: 0;
      z-index: 999;
      position: -webkit-sticky;
      position: fixed;
      top: 50;
      // z-index: 999;
      // position: -webkit-sticky;
      // position: fixed;
      // top: 50;
    }
    .title {
@@ -2485,4 +2786,10 @@
::v-deep .el-step__description.is-finish {
  color: #22a2c3;
}
:v-deep .el-select {
  display: inline-block;
  position: relative;
  width: 80%;
}
</style>