From 1bff9afb2dfda9824c3956c4a491a1b2261ad306 Mon Sep 17 00:00:00 2001
From: lkk <364857242@qq.com>
Date: 星期日, 27 四月 2025 14:37:54 +0800
Subject: [PATCH] 1

---
 src/views/picture/picture/index.vue |  459 +++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 346 insertions(+), 113 deletions(-)

diff --git a/src/views/picture/picture/index.vue b/src/views/picture/picture/index.vue
index dd30464..e182a8b 100644
--- a/src/views/picture/picture/index.vue
+++ b/src/views/picture/picture/index.vue
@@ -1,50 +1,164 @@
 <template>
   <div class="app-container">
-    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
-      <el-form-item label="浣撴鍙�" prop="tjNumber">
-        <el-input ref="inputName" v-model="queryParams.tjNumber" placeholder="璇疯緭鍏ヤ綋妫�鍙�" clearable
-          @keyup.enter.native="handleQuery" @blur="hb" style="width: 170px" />
-      </el-form-item>
+    <el-form
+      :model="queryParams"
+      ref="queryForm"
+      size="small"
+      :inline="true"
+      label-width="68px"
+    >
       <el-form-item label="濮撳悕" prop="name">
-        <el-input v-model="queryParams.name" placeholder="璇疯緭鍏ュ鍚�" clearable @keyup.enter.native="handleQuery"
-          style="width: 110px" />
+        <el-input
+          v-model="queryParams.name"
+          placeholder="璇疯緭鍏ュ鍚�"
+          clearable
+          @keyup.enter.native="handleQuery"
+          style="width: 110px"
+        />
       </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-select>
+      <el-form-item label="浣撴鍙�" prop="tjNumber">
+        <el-input
+          ref="inputName"
+          v-model="queryParams.tjNumber"
+          placeholder="璇疯緭鍏ヤ綋妫�鍙�"
+          clearable
+          @keyup.enter.native="handleQuery"
+          @blur="hb"
+          style="width: 170px"
+        />
       </el-form-item>
       <el-form-item label="椤圭洰" prop="tcm">
-        <el-input v-model="queryParams.tcm" placeholder="璇疯緭鍏ラ」鐩�" clearable @keyup.enter.native="handleQuery"
-          style="width: 170px" />
+        <el-input
+          v-model="queryParams.tcm"
+          placeholder="璇疯緭鍏ラ」鐩�"
+          clearable
+          @keyup.enter.native="handleQuery"
+          style="width: 170px"
+        />
       </el-form-item>
-      <el-form-item label="鐧昏鏃堕棿" prop="createTimeList">
-        <el-date-picker v-model="createTimeList" 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
+        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" icon="el-icon-search" size="mini" @click="handleQuery"
-          style="margin-right: 15px">鎼滅储</el-button>
-        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">閲嶇疆</el-button>
+        <el-button
+          type="primary"
+          icon="el-icon-search"
+          size="mini"
+          @click="handleQuery"
+          style="margin-right: 15px"
+          >鎼滅储</el-button
+        >
+        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
+          >閲嶇疆</el-button
+        >
+        <el-button
+          type="primary"
+          size="mini"
+          @click="toggleCollapse"
+          style="margin-right: 15px"
+          v-show="isCollapsed == 0"
+          >楂樼骇鎼滅储
+        </el-button>
+        <!-- 灞曞紑鏇村绛涢�夐」 -->
+        <el-button
+          type="primary"
+          size="mini"
+          @click="toggleCollapse3"
+          style="margin-right: 15px"
+          v-show="isCollapsed == 1"
+          >楂樼骇鎼滅储
+        </el-button>
+        <!-- 鏀惰捣鏇村绛涢�夐」 -->
       </el-form-item>
+
+      <el-row v-show="isCollapsed == 1" :gutter="20">
+        <el-col :span="8">
+          <el-form-item style="margin-left: 22px;"
+            label="鐧昏鏃堕棿"
+            prop="createTimeList"
+            v-show="isCollapsed == 1"
+          >
+            <el-date-picker
+              v-model="createTimeList"
+              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-col>
+      </el-row>
     </el-form>
 
-    <el-radio-group v-model="checkStatus" @input="radioChange" style="margin: 10px 15px">
+    <el-radio-group
+      v-model="checkStatus"
+      @input="radioChange"
+      style="margin: 10px 15px"
+    >
       <el-radio-button label="0">鏈</el-radio-button>
       <el-radio-button label="1">宸叉</el-radio-button>
     </el-radio-group>
 
-    <div style="width: 100%; margin-left: 10px; display: flex">
-      <div style="width: 36%; margin-right: 30px">
-        <el-table  v-loading="loading" ref="tb" :data="pictureList" highlight-current-row
-          :row-class-name="tableRowClassName" @current-change="handleCurrentChange" border height="520px">
+    <el-row :gutter="20">
+      <el-col :span="11">
+        <el-table
+          v-loading="loading"
+          ref="tb"
+          :data="pictureList"
+          highlight-current-row
+          :row-class-name="tableRowClassName"
+          @current-change="handleCurrentChange"
+          border
+          height="520px"
+        >
+          <!-- <el-table-column type="selection" width="55" /> -->
           <!--  @selection-change="handleSelectionChange" -->
-          <el-table-column label="浣撴鍙�" align="center" prop="tjNumber" min-width="160" />
-          <el-table-column label="濮撳悕" align="center" prop="cusName" min-width="80" />
-          <el-table-column label="鎬у埆" align="center" prop="cusSex" min-width="50">
+          <el-table-column
+            label="浣撴鍙�"
+            align="center"
+            prop="tjNumber"
+            min-width="160"
+          />
+          <el-table-column
+            label="濮撳悕"
+            align="center"
+            prop="cusName"
+            min-width="80"
+          />
+          <el-table-column
+            label="鎬у埆"
+            align="center"
+            prop="cusSex"
+            min-width="50"
+          >
             <template slot-scope="scope">
               <span v-if="scope.row.cusSex == '0'">鐢�</span>
               <span v-if="scope.row.cusSex == '1'">濂�</span>
@@ -57,35 +171,103 @@
             <!-- <dict-tag :options="dict.type.sys_user_sex" :value="scope.row.cusSex " /> -->
             <!-- </template> -->
           </el-table-column>
-          <el-table-column label="鎵嬫満鍙�" align="center" prop="cusPhone" min-width="100" />
-          <el-table-column label="濂楅鍚�" align="center" prop="tcm" min-width="100" />
-          <el-table-column label="鐧昏鏃堕棿" align="center" prop="tjTime" min-width="120" />
-          <el-table-column label="瀹℃牳鐘舵��" align="center" prop="confirmStatus" min-width="80">
+          <el-table-column
+            label="鎵嬫満鍙�"
+            align="center"
+            prop="cusPhone"
+            min-width="100"
+          />
+          <el-table-column
+            label="濂楅鍚�"
+            align="center"
+            prop="tcm"
+            min-width="100"
+          />
+          <el-table-column
+            label="鐧昏鏃堕棿"
+            align="center"
+            prop="tjTime"
+            min-width="120"
+          />
+          <el-table-column
+            label="瀹℃牳鐘舵��"
+            align="center"
+            prop="confirmStatus"
+            min-width="80"
+          >
             <template slot-scope="scope">
-              <span :style="{
-                color:
-                  scope.row.confirmStatus == '301' ? '#0CB618' : '#EA1B29',
-              }" v-if="scope.row.confirmStatus == '301'">宸查�氳繃</span>
-              <span :style="{
-                color:
-                  scope.row.confirmStatus == '301' ? '#0CB618' : '#EA1B29',
-              }" v-if="scope.row.confirmStatus == '299'">宸查┏鍥�</span>
+              <span
+                :style="{
+                  color:
+                    scope.row.confirmStatus == '301' ? '#0CB618' : '#EA1B29',
+                }"
+                v-if="scope.row.confirmStatus == '301'"
+                >宸查�氳繃</span
+              >
+              <span
+                :style="{
+                  color:
+                    scope.row.confirmStatus == '301' ? '#0CB618' : '#EA1B29',
+                }"
+                v-if="scope.row.confirmStatus == '299'"
+                >宸查┏鍥�</span
+              >
             </template>
           </el-table-column>
         </el-table>
-      </div>
 
-      <div id="table"  style="width: 44%; height: 610px">
-        <el-table v-loading="loading" ref="mu" :data="tableList"   :row-class-name="tableRowClassName"   @header-click="handleHeaderClick"  
-          highlight-current-row @selection-change="handleChange" border style="height: 400px">
+        <div class="pag">
+          <div class="pag1">
+            <pagination
+              v-show="total > 0"
+              :total="total"
+              :page.sync="queryParams.page"
+              :limit.sync="queryParams.pageSize"
+              @pagination="submitForm"
+            />
+          </div>
+        </div>
+      </el-col>
+      <el-col :span="11">
+        <el-table
+          v-loading="loading"
+          ref="mu"
+          :data="tableList"
+          :row-class-name="tableRowClassName"
+          @header-click="handleHeaderClick"
+          highlight-current-row
+          @selection-change="handleChange"
+          border
+          style="height: 400px"
+        >
           <el-table-column type="selection" width="50" align="center">
-          
           </el-table-column>
-          <el-table-column label="绉戝" align="center" prop="deptName" min-width="100" :show-overflow-tooltip="true" />
-          <el-table-column label="椤圭洰" align="center" prop="proName" min-width="150" :show-overflow-tooltip="true" />
-          <el-table-column label="鐘舵��" align="center" prop="type" :show-overflow-tooltip="true" min-width="100">
+          <el-table-column
+            label="绉戝"
+            align="center"
+            prop="deptName"
+            min-width="100"
+            :show-overflow-tooltip="true"
+          />
+          <el-table-column
+            label="椤圭洰"
+            align="center"
+            prop="proName"
+            min-width="150"
+            :show-overflow-tooltip="true"
+          />
+          <el-table-column
+            label="鐘舵��"
+            align="center"
+            prop="type"
+            :show-overflow-tooltip="true"
+            min-width="100"
+          >
             <template slot-scope="scope">
-              <span v-if="scope.row.type == '0'" :style="type == 0 ? { color: 'red' } : { color: '#409EFF' }">
+              <span
+                v-if="scope.row.type == '0'"
+                :style="type == 0 ? { color: 'red' } : { color: '#409EFF' }"
+              >
                 {{ type == 0 ? "鏈� 妫�" : "鍦� 妫�" }}
               </span>
               <span v-if="scope.row.type == '1'">宸插畬鎴�</span>
@@ -93,7 +275,12 @@
               <span v-if="scope.row.type == '3'">寤舵湡</span>
             </template>
           </el-table-column>
-          <el-table-column label="妫�鏌ユ椂闂�" align="center" prop="bcupdateTime" min-width="160" />
+          <el-table-column
+            label="妫�鏌ユ椂闂�"
+            align="center"
+            prop="bcupdateTime"
+            min-width="160"
+          />
           <!-- <el-table-column label="鎿嶄綔" align="center" min-width="120px">
             <template slot-scope="scope">
               <el-button
@@ -123,43 +310,63 @@
           <el-table-column label="椤圭洰缁撴灉" align="center" prop="proResult" /> -->
         </el-table>
         <div style="margin-top: 10px">
-          <el-form :model="form" ref="queryForm" size="small" :inline="false" label-width="68px">
+          <el-form
+            :model="form"
+            ref="queryForm"
+            size="small"
+            :inline="false"
+            label-width="68px"
+          >
             <el-form-item label="妫�鏌ユ墍瑙�" prop="proResult">
-              <el-input v-model="form.proResult" clearable type="textarea" @focus="submiepilog" />
+              <el-input
+                v-model="form.proResult"
+                clearable
+                type="textarea"
+                @focus="submiepilog"
+              />
             </el-form-item>
             <el-form-item label="妫�鏌ョ粨璁�" prop="conclusion">
-              <el-input v-model="form.conclusion" clearable type="textarea" @focus="submiepilog" />
+              <el-input
+                v-model="form.conclusion"
+                clearable
+                type="textarea"
+                @focus="submiepilog"
+              />
             </el-form-item>
             <el-form-item>
-              <el-button type="primary" icon="el-icon-picture" size="mini" @click="tupian">鍥剧墖</el-button>
-              <el-button type="primary" icon="el-icon-search" size="mini" @click="submito">鎻愪氦</el-button>
+              <el-button
+                type="primary"
+                icon="el-icon-picture"
+                size="mini"
+                @click="tupian"
+                >鍥剧墖</el-button
+              >
+              <el-button
+                type="primary"
+                icon="el-icon-search"
+                size="mini"
+                @click="submito"
+                >鎻愪氦</el-button
+              >
             </el-form-item>
           </el-form>
         </div>
-
-        <!-- <div style="display:flex;margin:15px 0px;width: 100%;">
-                    <div style="width: 100%;display:flex;">
-                        <el-button type="primary" class="default-button-style" size="small"
-                            @click="submiepilog">缁撴灉缁撹</el-button>
-                        <el-button type="primary" icon="el-icon-s-claim" size="mini" @click="submito">鎻愪氦</el-button>
-
-                    </div>
-                </div> -->
-      </div>
-    </div>
+      </el-col>
+    </el-row>
 
     <el-dialog title="鎻愮ず" :visible.sync="dialogVisible" width="60%">
       <!-- :before-close="handleClose" -->
       <img src="../../../assets/logo/logo.png" alt="" />
     </el-dialog>
 
-    <div style="margin-right: 58%">
-      <pagination v-show="total > 0" :total="total" :page.sync="queryParams.page" :limit.sync="queryParams.pageSize"
-        @pagination="submitForm" />
-    </div>
-
-    <Public ref="aaa" :check-status="checkStatus" :pro-result="form.proResult" :conclusion="form.conclusion"
-      @add="handleChanges" :project-list="projectList" />
+    <Public
+      ref="aaa"
+      :check-status="checkStatus"
+      :pro-result="form.proResult"
+      :conclusion="form.conclusion"
+      @add="handleChanges"
+      :project-list="projectList"
+    />
     <!--  :last-desc="form.conclusion" -->
   </div>
 </template>
@@ -213,6 +420,7 @@
       // 閫変腑鏁扮粍
       ids: [],
       CheckBox: {},
+      isCollapsed: 0, // 榛樿涓烘姌鍙犵姸鎬�
       // 闈炲崟涓鐢�
       single: true,
       // 闈炲涓鐢�
@@ -356,7 +564,6 @@
         this.queryParams.endTime = null;
       }
       /*  getYxJcList(this.queryParams).then((response) => {
-        // console.log(response.data.customers, 666);
 
         if (response.data) {
           this.pictureList = response.data.customers;
@@ -372,15 +579,12 @@
           this.$refs.tb.clearSelection();
         }
         this.total = response.data.total;
-        console.log(response.data.total, 88);
 
         this.loading = false;
       }); */
 
       getCompany(this.queryParams).then((response) => {
         this.CompanyList = response.data;
-        // console.log(this.CompanyList, 555);
-
         this.loading = false;
       });
     },
@@ -422,9 +626,7 @@
     },
 
     handleRowClick(row, column, event) {
-      // console.log(row, 2323);
       this.name = row.proName;
-      // console.log(this.name, 99999);
     },
     // 浣撴鍏徃鎷奸煶鎼滅储
     getRemoteData(query) {
@@ -438,6 +640,8 @@
     radioChange(value) {
       this.loading = true;
       this.queryParams.checkStatus = value;
+      this.form.proResult = "";
+      this.form.conclusion = "";
       getYxJcList(this.queryParams).then((res) => {
         if (res.code == 200) {
           this.loading = false;
@@ -461,7 +665,6 @@
 
       
       getYxJcXx(tjNumber).then((res) => {
-        console.log(res, 222);
         this.tableList = res.data;
         this.loading = false;
       }); */
@@ -481,7 +684,6 @@
       this.resetForm("form");
     },
     hb() {
-      // console.log(this.queryParams.tjNum);
       if (this.queryParams.tjNumber != null) {
         // this.handleQuery();
         this.submitForm();
@@ -524,14 +726,13 @@
     // 閫夋鏁版嵁
     searchSelect(val) {
       this.CheckBox = val;
-      // console.log(this.CheckBox, 9999);
     },
 
     handleHeaderClick(column, event) {
-      if (column.type === 'selection') {
+      if (column.type === "selection") {
         // 鏌ユ壘鍏ㄩ�夋骞堕殣钘�
-        const checkbox = event.target.closest('.el-checkbox');
-        if (checkbox) checkbox.style.display = 'none';
+        const checkbox = event.target.closest(".el-checkbox");
+        if (checkbox) checkbox.style.display = "none";
       }
     },
     /** 鎼滅储鎸夐挳鎿嶄綔 */
@@ -561,6 +762,20 @@
       this.loading = true;
     },
 
+    toggleCollapse3() {
+      // this.isCollapsed = !this.isCollapsed; // 鐐瑰嚮鎸夐挳鏃跺垏鎹sCollapsed鐨勫��
+      this.isCollapsed = 0;
+      this.$nextTick(() => {
+        this.$refs.inputName.focus();
+      });
+    },
+    toggleCollapse() {
+      this.isCollapsed = 1; // 鐐瑰嚮鎸夐挳鏃跺垏鎹sCollapsed鐨勫��
+      this.$nextTick(() => {
+        this.$refs.inputName.focus();
+      });
+    },
+
     tableRowClassName({ row, rowIndex }) {
       for (let i = 0; i < this.selectList.length; i++) {
         if (row === this.selectList[i]) {
@@ -576,19 +791,33 @@
         this.tableList = [];
         return;
       }
-
-      let tjNumber = val.tjNumber;
       this.selectedTjNumber = val.tjNumber;
-      this.loading = true;
+      this.changtjNumber(val.tjNumber);
+    },
 
+    changtjNumber(val) {
+      console.log(8989);
+      let tjNumber = val;
+      this.loading = true;
       getYxJcXx(tjNumber).then((res) => {
         this.tableList = res.data;
         this.loading = false;
         this.$nextTick(() => {
-          const headerCheckbox = this.$refs.mu.$el.querySelector('.el-table__header .el-checkbox');
-        if (headerCheckbox) headerCheckbox.style.display = 'none';
-    
-          if (this.tableList.length > 0) {
+          const headerCheckbox = this.$refs.mu.$el.querySelector(
+            ".el-table__header .el-checkbox"
+          );
+          if (headerCheckbox) headerCheckbox.style.display = "none";
+          if (this.queryParams.checkStatus == 0) {
+            if (this.tableList.length > 0) {
+              this.tableList.forEach((item, index) => {
+                if (item.type == 0) {
+                  const firstRow = item;
+                  this.$refs.mu.toggleRowSelection(firstRow, true);
+                  this.handleChange([firstRow]);
+                }
+              });
+            }
+          } else {
             const firstRow = this.tableList[0];
             this.$refs.mu.toggleRowSelection(firstRow, true);
             this.handleChange([firstRow]);
@@ -723,16 +952,12 @@
         const proId = selection[0].proId;
 
         // 鉁� 纭繚 selectedRow 瀛樺湪涓旀湁 tjNumber
-        if (this.selectedRow && this.selectedRow.tjNumber) {
-          const tjNumber = this.selectedRow.tjNumber;
-          getYxJcXxJg(tjNumber, proId).then((res) => {
-            this.form.proResult = res.data.jcsj;
-            this.form.conclusion = res.data.jcjl;
-            this.$refs.aaa.updateData(res.data.jcsj, res.data.jcjl);
-          });
-        } else {
-          console.warn("selectedRow 鏈噯澶囧ソ锛岃烦杩囨帴鍙h皟鐢�");
-        }
+        const tjNumber = this.selectedTjNumber;
+        getYxJcXxJg(tjNumber, proId).then((res) => {
+          this.form.proResult = res.data.jcsj;
+          this.form.conclusion = res.data.jcjl;
+          this.$refs.aaa.updateData(res.data.jcsj, res.data.jcjl);
+        });
 
         // 鉁� 鍚屾椂鏇存柊 selectedRow
         this.selectedRow = selection[0];
@@ -740,13 +965,11 @@
     },
 
     /* handleChange(selection) {
-      // console.log(selection, 123);
       if (selection && selection.length > 0) {
         const proId = selection[0].proId;
         const tjNumber = this.selectedRow.tjNumber;
         this.selectedRow = selection[0];
         getYxJcXxJg(tjNumber, proId).then((res) => {
-          console.log(res, 333);
           this.form.proResult = res.data.jcsj;
           this.form.conclusion = res.data.jcjl;
         });
@@ -768,10 +991,8 @@
       this.dialogVisible = true;
     },
 
-   
     // 纭畾鎸夐挳
     submito() {
-      console.log(111112225)
       /* if (this.dataobj) {
         if (this.form.proResult) {
           this.dataobj.proResult = this.form.proResult;
@@ -809,10 +1030,19 @@
         jcjl: jcjl, // 浼犻�掓鏌ョ粨璁�
       })
         .then((response) => {
-          this.submitForm();
-
           this.form.proResult = "";
           this.form.conclusion = "";
+          if (this.tableList.length == 1) {
+            this.submitForm();
+          } else {
+            this.tableList.forEach((item, index) => {
+              if (item.type == 0) {
+                this.changtjNumber(this.selectedTjNumber);
+              } else {
+                this.submitForm();
+              }
+            });
+          }
         })
         .catch((error) => {
           console.error("鎻愪氦澶辫触", error);
@@ -820,10 +1050,10 @@
     },
 
     //鍒犻櫎鎸夐挳
-    handleDelete() { },
+    handleDelete() {},
 
     // 瀵煎嚭
-    handleExport() { },
+    handleExport() {},
   },
 };
 </script>
@@ -891,4 +1121,7 @@
   float: left;
   position: relative;
 }
-</style>
\ No newline at end of file
+.el-input--small {
+  font-size: 13px;
+}
+</style>

--
Gitblit v1.8.0