From c3aaf28f7316cce12eec007a9f85a96cbcddeec2 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期三, 07 五月 2025 10:34:20 +0800
Subject: [PATCH] 最新版本541200007

---
 admin/src/views/business/visits.vue |  316 ++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 217 insertions(+), 99 deletions(-)

diff --git a/admin/src/views/business/visits.vue b/admin/src/views/business/visits.vue
index db138a5..00d7881 100644
--- a/admin/src/views/business/visits.vue
+++ b/admin/src/views/business/visits.vue
@@ -1,100 +1,119 @@
 <template>
-    <TableLayout :permissions="['business:visits:query']">
-        <!-- 鎼滅储琛ㄥ崟 -->
-        <el-form ref="searchForm" slot="search-form" :model="searchForm" label-width="100px" inline>
-            <el-form-item label="濮撳悕/鎵嬫満鍙�" prop="name">
-                <el-input v-model="searchForm.name" placeholder="璇疯緭鍏ュ鍚�/鎵嬫満鍙�" @keypress.enter.native="search"></el-input>
-            </el-form-item>
-            <el-form-item label="韬唤璇佸彿" prop="idcardNo">
-                <el-input v-model="searchForm.idcardNo" placeholder="璇疯緭鍏ヨ韩浠借瘉鍙�" @keypress.enter.native="search"></el-input>
-            </el-form-item>
-            <el-form-item label="鍏徃鍚嶇О" prop="companyName">
-                <el-input v-model="searchForm.companyName" placeholder="璇疯緭鍏ュ叕鍙稿悕绉�" @keypress.enter.native="search"></el-input>
-            </el-form-item>
-            <el-form-item label="瀹℃壒鐘舵��" prop="status">
-                <el-select v-model="searchForm.status" placeholder="璇烽�夋嫨">
-                    <el-option label="寰呭鏍�" value="0"></el-option>
-                    <el-option label="宸叉彁浜RP瀹℃壒" value="1"></el-option>
-                    <el-option label="瀹℃牳閫氳繃" value="2"></el-option>
-                    <el-option label="瀹℃牳涓嶉�氳繃" value="3"></el-option>
-                    <el-option label="鍙栨秷" value="4"></el-option>
-                    <el-option label="涓嬪彂鎴愬姛" value="5"></el-option>
-                    <el-option label="涓嬪彂澶辫触" value="6"></el-option>
-                </el-select>
-            </el-form-item>
-            <section>
-                <el-button type="primary" @click="search">鎼滅储</el-button>
-<!--                <el-button type="primary" :loading="isWorking.export" v-permissions="['business:visits:exportExcel']" @click="exportExcel">瀵煎嚭</el-button>-->
-                <el-button @click="reset">閲嶇疆</el-button>
-            </section>
-        </el-form>
-        <!-- 琛ㄦ牸鍜屽垎椤� -->
-        <template v-slot:table-wrap>
-<!--            <ul class="toolbar" v-permissions="['business:visits:create', 'business:visits:delete']">-->
-<!--                <li><el-button type="primary" @click="$refs.operaVisitsWindow.open('鏂板缓璁垮鐢宠淇℃伅琛�')" icon="el-icon-plus" v-permissions="['business:visits:create']">鏂板缓</el-button></li>-->
-<!--                <li><el-button @click="deleteByIdInBatch" icon="el-icon-delete" v-permissions="['business:visits:delete']">鍒犻櫎</el-button></li>-->
-<!--            </ul>-->
-            <el-table
-                v-loading="isWorking.search"
-                :data="tableData.list"
-                stripe
-                @selection-change="handleSelectionChange"
-            >
-                <el-table-column type="selection" width="55"></el-table-column>
-                <el-table-column prop="name" label="璁垮濮撳悕" min-width="100px"></el-table-column>
-                <el-table-column prop="phone" label="鎵嬫満鍙�" min-width="100px"></el-table-column>
-                <el-table-column prop="companyName" label="鍏徃鍚嶇О" min-width="100px"></el-table-column>
-                <el-table-column prop="receptMemberName" label="琚浜�" min-width="100px"></el-table-column>
-                <el-table-column prop="reason" label="鎷滆浜嬬敱" min-width="100px"></el-table-column>
-                <el-table-column label="鎷滆鏃堕棿" min-width="170px">
-                    <template slot-scope="{row}">
-                        <span>璧凤細{{row.starttime}}</span><br/>
-                        <span>姝細{{row.endtime}}</span>
-                    </template>
-                </el-table-column>
-                <el-table-column label="闅忚浜哄憳" min-width="100px">
-                    <template slot-scope="{row}">
-                        <span>{{row.memberNum}}</span>
-                    </template>
-                </el-table-column>
-                <el-table-column label="闅忚杞﹁締" min-width="100px">
-                    <template slot-scope="{row}">
-                        <span v-if="row.carNos">{{row.carNos.split(',').length}}</span>
-                    </template>
-                </el-table-column>
-                <el-table-column prop="status" fixed="right" label="鐘舵��" min-width="100px">
-                    <template slot-scope="{row}">
-                        <span style="color: rgba(245, 154, 35, 0.996);" v-if="row.status === 0">寰呭鏍�</span>
-                        <span v-if="row.status === 1">宸叉彁浜RP瀹℃壒</span>
-                        <span v-if="row.status === 2">瀹℃牳閫氳繃</span>
-                        <span style="color: red;" v-if="row.status === 3">瀹℃牳涓嶉�氳繃</span>
-                        <span v-if="row.status === 4">鍙栨秷</span>
-                        <span v-if="row.status === 5">涓嬪彂鎴愬姛</span>
-                        <span v-if="row.status === 6">涓嬪彂澶辫触</span>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    v-if="containPermissions(['business:visits:update', 'business:visits:delete'])"
-                    label="鎿嶄綔"
-                    min-width="100"
-                    fixed="right"
-                >
-                    <template slot-scope="{row}">
-                        <el-button type="text" @click="$refs.OperaVisitsDesWindow.open('璇︽儏', row.id)" v-permissions="['business:visits:update']">鏌ョ湅璇︽儏</el-button>
-<!--                        <el-button type="text" @click="deleteById(row)" icon="el-icon-delete" v-permissions="['business:visits:delete']">鏌ヨ瀹℃壒缁撴灉</el-button>-->
-                    </template>
-                </el-table-column>
-            </el-table>
-            <pagination
-                @size-change="handleSizeChange"
-                @current-change="handlePageChange"
-                :pagination="tableData.pagination"
-            >
-            </pagination>
-            <!--      璇︽儏      -->
-            <OperaVisitsDesWindow ref="OperaVisitsDesWindow" />
-        </template>
-    </TableLayout>
+  <TableLayout :permissions="['business:visits:query']">
+    <!-- 鎼滅储琛ㄥ崟 -->
+    <div slot="search-form" ref="QueryFormRef">
+      <el-form ref="searchForm" :model="searchForm" label-width="100px" inline>
+        <el-form-item label="濮撳悕/鎵嬫満鍙�" prop="name">
+          <el-input v-model="searchForm.name" placeholder="璇疯緭鍏ュ鍚�/鎵嬫満鍙�" @keypress.enter.native="search"></el-input>
+        </el-form-item>
+        <el-form-item label="韬唤璇佸彿" prop="idcardNo">
+          <el-input v-model="searchForm.idcardNo" placeholder="璇疯緭鍏ヨ韩浠借瘉鍙�" @keypress.enter.native="search"></el-input>
+        </el-form-item>
+        <el-form-item label="璁垮鍗曚綅" prop="companyName">
+          <el-input v-model="searchForm.companyName" placeholder="璇疯緭鍏ヨ瀹㈠崟浣�" @keypress.enter.native="search"></el-input>
+        </el-form-item>
+        <el-form-item label="璧峰鏃堕棿" prop="date">
+          <el-date-picker
+            v-model="searchForm.date"
+            type="daterange"
+            @change="changeDate"
+            value-format="yyyy-MM-dd"
+            range-separator="鑷�"
+            start-placeholder="寮�濮嬫棩鏈�"
+            end-placeholder="缁撴潫鏃ユ湡">
+          </el-date-picker>
+        </el-form-item>
+        <el-form-item label="瀹℃壒鐘舵��" prop="status">
+          <el-select v-model="searchForm.status" placeholder="璇烽�夋嫨">
+            <el-option label="寰呮彁浜ゅ鎵�" value="0"></el-option>
+            <el-option label="瀹℃壒涓�" value="1"></el-option>
+            <el-option label="瀹℃牳閫氳繃" value="2"></el-option>
+            <el-option label="瀹℃壒椹冲洖" value="3"></el-option>
+            <el-option label="鍙栨秷" value="4"></el-option>
+            <el-option label="涓嬪彂鎴愬姛" value="5"></el-option>
+            <el-option label="涓嬪彂澶辫触" value="6"></el-option>
+            <el-option label="鎷滆涓�" value="7"></el-option>
+            <el-option label="宸茬绂�" value="8"></el-option>
+            <el-option label="宸插け鏁�" value="9"></el-option>
+          </el-select>
+        </el-form-item>
+        <section>
+          <el-button type="primary" @click="search">鎼滅储</el-button>
+          <!--                <el-button type="primary" :loading="isWorking.export" v-permissions="['business:visits:exportExcel']" @click="exportExcel">瀵煎嚭</el-button>-->
+          <el-button @click="reset">閲嶇疆</el-button>
+        </section>
+      </el-form>
+    </div>
+
+    <!-- 琛ㄦ牸鍜屽垎椤� -->
+    <template v-slot:table-wrap>
+      <ul class="toolbar" v-permissions="['business:visits:create', 'business:visits:exportExcel']">
+        <li><el-button type="primary" @click="handleEdit()" icon="el-icon-plus"
+            v-permissions="['business:visits:create']">鏂板缓</el-button></li>
+        <li><el-button type="primary" :loading="isWorking.export" @click="exportExcel"
+            v-permissions="['business:visits:exportExcel']">瀵煎嚭</el-button></li>
+      </ul>
+      <el-table :max-height="tableHeightNew" v-loading="isWorking.search" :data="tableData.list" stripe
+        @selection-change="handleSelectionChange">
+        <el-table-column type="selection" width="55"></el-table-column>
+        <el-table-column prop="name" label="璁垮濮撳悕" min-width="100px"></el-table-column>
+        <el-table-column prop="phone" label="鎵嬫満鍙�" min-width="100px"></el-table-column>
+        <el-table-column prop="companyName" label="璁垮鍗曚綅" min-width="100px"></el-table-column>
+        <el-table-column prop="receptMemberName" label="琚浜�" min-width="100px"></el-table-column>
+        <el-table-column prop="reason" label="鎷滆浜嬬敱" min-width="100px"></el-table-column>
+        <el-table-column label="鎷滆鏃堕棿" min-width="170px">
+          <template slot-scope="{row}">
+            <span>璧凤細{{ row.starttime }}</span><br />
+            <span>姝細{{ row.endtime }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="鏂藉伐浜哄憳" min-width="100px">
+          <template slot-scope="{row}">
+            <span v-if="row.type == 0">鍚�</span>
+            <span v-if="row.type == 1">鏄�</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="闅忚杞﹁締" min-width="100px">
+          <template slot-scope="{row}">
+            <span>{{ row.carNos }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column prop="status" fixed="right" label="鐘舵��" min-width="100px">
+          <template slot-scope="{row}">
+            <span style="color: rgba(245, 154, 35, 0.996);" v-if="row.status === 0">寰呮彁浜ゅ鎵�</span>
+            <span v-if="row.status === 1" style="color: rgba(245, 154, 35, 0.996);">瀹℃壒涓�</span>
+            <span v-if="row.status === 2" style="color: rgba(245, 154, 35, 0.996);">瀹℃牳閫氳繃</span>
+            <span style="color: gray;" v-if="row.status === 3">瀹℃壒椹冲洖</span>
+            <span v-if="row.status === 4" style="color: gray">鍙栨秷</span>
+            <span v-if="row.status === 5" style="color: green">涓嬪彂鎴愬姛</span>
+            <span v-if="row.status === 6" style="color: gray">涓嬪彂澶辫触</span>
+            <span v-if="row.status === 7" style="color: green">鎷滆涓�</span>
+            <span v-if="row.status === 8" style="color: red">宸茬绂�</span>
+            <span v-if="row.status === 9" style="color: gray">宸插け鏁�</span>
+          </template>
+        </el-table-column>
+        <el-table-column prop="remark" label="涓嬪彂澶囨敞" min-width="100px"></el-table-column>
+        <el-table-column prop="createDate" label="鍒涘缓鏃堕棿" min-width="170px"></el-table-column>
+        <el-table-column   label="鎿嶄綔"
+          min-width="200" fixed="right">
+          <template slot-scope="{row}">
+            <el-button type="text" @click="handleDetail(row)" icon="el-icon-view">璇︽儏</el-button>
+            <el-button type="text" @click="resend(row.id)" v-permissions="['business:visits:update']" icon="el-icon-edit" v-if="row.status == 6">閲嶆柊涓嬪彂</el-button>
+            <el-button type="text" @click="cancel(row.id)"   v-permissions="['business:visits:cancel']"  v-if="(row.status == 0 || row.status == 1 || row.status == 2|| row.status == 5)"  icon="el-icon-delete" style="color: red"  >鍙栨秷棰勭害</el-button>
+            <el-button type="text" @click="departure(row.id)" icon="el-icon-delete" style="color: red" v-if="row.status == 7">绂诲満</el-button>
+            <el-button  type="text"  icon="el-icon-delete" @click="deleteById(row)" style="color: red" v-permissions="['business:visits:delete']">鍒犻櫎</el-button>
+          </template>
+        </el-table-column>
+      </el-table>
+      <pagination @size-change="handleSizeChange" @current-change="handlePageChange" :pagination="tableData.pagination">
+      </pagination>
+      <!--      璇︽儏      -->
+      <!-- <OperaVisitsDesWindow ref="OperaVisitsDesWindow" /> -->
+      <TaskDetail v-if="isShowDetail" ref="DetailRef" />
+      <!-- 鏂板缓 -->
+      <OperaVisitsWindow @close="isShowEdit = false" @success="search" v-if="isShowEdit" ref="operaVisitsWindowRef" />
+    </template>
+  </TableLayout>
 </template>
 
 <script>
@@ -102,20 +121,33 @@
 import TableLayout from '@/layouts/TableLayout'
 import Pagination from '@/components/common/Pagination'
 import OperaVisitsDesWindow from '@/components/business/OperaVisitsDesWindow'
+import OperaVisitsWindow from '@/components/business/operaVisitsWindow'
+import TaskDetail from '@/views/task/visSubDetail.vue'
+import {mapState} from "vuex";
+
 export default {
   name: 'Visits',
   extends: BaseTable,
-  components: { TableLayout, Pagination, OperaVisitsDesWindow },
-  data () {
+  components: { TableLayout, Pagination, TaskDetail, OperaVisitsWindow },
+  data() {
     return {
+      isShowEdit: false,
+      isShowDetail: false,
       // 鎼滅储
       searchForm: {
         name: '',
         companyName: '',
         idcardNo: '',
-        status: ''
+        status: '',
+        type: 0,
+        queryStarttime: '',
+        queryEndtime: '',
+        date: []
       }
     }
+  },
+  computed: {
+    ...mapState(['userInfo'])
   },
   created () {
     this.config({
@@ -125,6 +157,92 @@
       'field.main': 'id'
     })
     this.search()
+  },
+  mounted() {
+    this.$nextTick(() => {
+      this.tableHeight = document.body.scrollHeight - this.$refs.QueryFormRef.offsetHeight - 300
+    })
+  },
+  methods: {
+    // 鎼滅储妗嗛噸缃�
+    reset () {
+      this.$refs.searchForm.resetFields()
+      this.searchForm.queryStarttime = ''
+      this.searchForm.queryEndtime = ''
+      this.search()
+    },
+    changeDate(e) {
+      if (e) {
+        this.searchForm.queryStarttime = e[0]
+        this.searchForm.queryEndtime = e[1]
+      } else {
+        this.searchForm.queryStarttime = ''
+        this.searchForm.queryEndtime = ''
+      }
+      this.search()
+    },
+    handleDetail(row) {
+      this.isShowDetail = true
+      console.log('row', row)
+      this.$nextTick(() => {
+        this.$refs.DetailRef.id = row.id
+        this.$refs.DetailRef.type = 0
+        this.$refs.DetailRef.getDetail()
+        this.$refs.DetailRef.isShowModal = true
+      })
+    },
+    handleEdit() {
+      this.isShowEdit = true
+      this.$nextTick(() => {
+        this.$refs.operaVisitsWindowRef.isShowModal = true
+      })
+    },
+    departure(id) {
+      this.$confirm('纭畾杩涜绂诲満鎿嶄綔鍚楋紝璇ユ搷浣滀笉鍙�嗚璋ㄦ厧鎿嶄綔, 鏄惁缁х画?', '鎻愮ず', {
+        confirmButtonText: '纭畾',
+        cancelButtonText: '鍙栨秷',
+        type: 'warning'
+      }).then(() => {
+        this.api.level(id)
+          .then(res => {
+            this.$message.success('鎿嶄綔鎴愬姛')
+            this.page = 1
+            this.search()
+          })
+      }).catch(() => {
+
+      })
+    },
+    cancel( id) {
+      this.$confirm('纭畾鍙栨秷棰勭害鍚�, 鏄惁缁х画?', '鎻愮ず', {
+        confirmButtonText: '纭畾',
+        cancelButtonText: '鍙栨秷',
+        type: 'warning'
+      }).then(() => {
+        this.api.visitsCancel(id)
+          .then(res => {
+            this.page = 1
+            this.search()
+          })
+      }).catch(() => {
+
+      })
+    },
+    resend(id) {
+      this.$confirm('纭畾灏濊瘯閲嶆柊鍙戣捣棰勭害鍚�, 鏄惁缁х画?', '鎻愮ず', {
+        confirmButtonText: '纭畾',
+        cancelButtonText: '鍙栨秷',
+        type: 'warning'
+      }).then(() => {
+        this.api.visitResend(id)
+          .then(res => {
+            this.page = 1
+            this.search()
+          })
+      }).catch(() => {
+
+      })
+    }
   }
 }
 </script>

--
Gitblit v1.9.3