From b62578f8b43f15be89b3d14f463f11aed03e6fb9 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期四, 09 五月 2024 18:57:25 +0800
Subject: [PATCH] 最新版本

---
 admin/src/views/business/internalMember.vue |  107 +++++++++++++++++++++++++++++++++++------------------
 1 files changed, 70 insertions(+), 37 deletions(-)

diff --git a/admin/src/views/business/internalMember.vue b/admin/src/views/business/internalMember.vue
index 73143de..a192b7c 100644
--- a/admin/src/views/business/internalMember.vue
+++ b/admin/src/views/business/internalMember.vue
@@ -24,6 +24,13 @@
                     <el-option label="鎷夐粦/鍐荤粨" value="2"></el-option>
                 </el-select>
             </el-form-item>
+            <el-form-item label="" prop="hkStatus">
+                <el-select v-model="searchForm.hkStatus" @keypress.enter.native="search" placeholder="娴峰悍鍚屾鐘舵��">
+                    <el-option label="寰呭悓姝�" value="0"></el-option>
+                    <el-option label="鍚屾鎴愬姛" value="1"></el-option>
+                    <el-option label="鍚屾澶辫触" value="2"></el-option>
+                </el-select>
+            </el-form-item>
             <section>
                 <el-button type="primary" @click="search">鎼滅储</el-button>
                 <el-button @click="reset">閲嶇疆</el-button>
@@ -32,14 +39,14 @@
         <template v-slot:menu>
             <div style="width: 100%; height: 50px; background: rgba(242, 242, 242, 1); line-height: 50px; text-align: center; font-size: 14px;">浼佷笟缁勭粐鏋舵瀯</div>
             <div style="width: 100%; height: calc(100vh - 170px); overflow-y: scroll;">
-                <Tree :list="companyTree" :defaultProps="{name: 'name', status: 'status', children: 'childList', id: 'erpId'}" @callback="callback" />
+                <Tree :list="companyTree" :defaultProps="{name: 'name', status: 'fsStatus', children: 'childList', id: 'id'}" @callback="callback" />
             </div>
         </template>
         <!-- 琛ㄦ牸鍜屽垎椤� -->
         <template v-slot:table-wrap>
-            <ul class="toolbar" v-permissions="['business:member:delete']">
-                <li><el-button type="primary">闂ㄧ鎺堟潈</el-button></li>
-                <li><el-button type="primary" v-permissions="['business:member:sync']"  @click="synchronous()">鍚屾</el-button></li>
+            <ul class="toolbar" v-permissions="['business:member:delete','business:member:sync']">
+<!--                <li><el-button type="primary">闂ㄧ鎺堟潈</el-button></li>-->
+                <li><el-button type="primary" v-permissions="['business:member:sync']" :loading="loading" @click="synchronous()">鍚屾</el-button></li>
                 <li><el-button @click="deleteByIdInBatch" icon="el-icon-delete" v-permissions="['business:member:delete']">鍒犻櫎</el-button></li>
             </ul>
             <el-table
@@ -53,24 +60,32 @@
                 <el-table-column prop="phone" label="鎵嬫満鍙�" min-width="100px"></el-table-column>
                 <el-table-column label="鎬у埆" min-width="100px">
                     <template slot-scope="{row}">
-                        <span v-if="row.sex === 1">鐢�</span>
-                        <span v-if="row.sex === 2">濂�</span>
+                        <span v-if="row.sex == 1">鐢�</span>
+                        <span v-if="row.sex == 2">濂�</span>
                     </template>
                 </el-table-column>
               <el-table-column prop="companyName" label="鎵�灞為儴闂�" min-width="100px"></el-table-column>
                 <el-table-column prop="status" label="鐘舵��" min-width="100px">
                     <template slot-scope="{row}">
-                        <span v-if="row.status === 0">姝e父</span>
-                        <span v-if="row.status === 1">绂佺敤</span>
-                        <span v-if="row.status === 2">鎷夐粦/鍐荤粨</span>
+                        <span v-if="row.status == 0" style="color: green">姝e父</span>
+                        <span v-if="row.status == 1" style="color: red">绂佺敤</span>
+                        <span v-if="row.status == 2" style="color: red">鎷夐粦/鍐荤粨</span>
                     </template>
                 </el-table-column>
                 <el-table-column prop="code" label="宸ュ彿" min-width="100px"></el-table-column>
                 <el-table-column label="鍙嫓璁�" min-width="100px">
                     <template slot-scope="{row}">
-                        <span v-if="row.canVisit === '0'">鍚�</span>
-                        <span v-if="row.canVisit === '1'">鏄�</span>
+                        <span v-if="row.canVisit != 1">鍚�</span>
+                        <span v-if="row.canVisit == 1">鏄�</span>
                     </template>
+                </el-table-column>
+                <el-table-column label="娴峰悍鍚屾鐘舵��" min-width="100px">
+                 <template slot-scope="{row}">
+                        <span v-if="row.hkStatus == 0" style="color: #435EBE">寰呭悓姝�</span>
+                        <span v-if="row.hkStatus == 1" style="color: green">鍚屾鎴愬姛</span>
+                        <span v-if="row.hkStatus == 2" style="color: red">鍚屾澶辫触</span>
+                        <span v-if="row.hkStatus == 3" style="color: red">涓嶇鍚堜笅鍙戞潯浠�</span>
+                </template>
                 </el-table-column>
                 <el-table-column label="闂ㄧ瑙掕壊" min-width="100px">
                     <template slot-scope="{row}">
@@ -80,7 +95,8 @@
                 <el-table-column fixed="right" label="浜鸿劯淇℃伅" min-width="100px">
                     <template slot-scope="{row}">
                         <el-image
-                            style="width: 100px; height: 100px"
+                            v-if="row.faceImg"
+                            style="width: 60px; height: 60px"
                             :src="row.faceImg"
                             :preview-src-list="[row.faceImg]">
                         </el-image>
@@ -88,24 +104,19 @@
                 </el-table-column>
                 <el-table-column fixed="right" label="鍗$墖淇℃伅" min-width="100px">
                     <template slot-scope="{row}">
-                        <el-image
-                            style="width: 100px; height: 100px"
-                            :src="row.faceImg"
-                            :preview-src-list="[row.faceImg]">
-                        </el-image>
+                        <el-button @click="$refs.cardOpeningRecord.open('寮�鍗¤褰�', row.id)" type="text">{{row.memberCardCount || '0'}}</el-button>
                     </template>
                 </el-table-column>
-<!--                <el-table-column-->
-<!--                    v-if="containPermissions(['business:member:update', 'business:member:delete'])"-->
-<!--                    label="鎿嶄綔"-->
-<!--                    min-width="120"-->
-<!--                    fixed="right"-->
-<!--                >-->
-<!--                    <template slot-scope="{row}">-->
-<!--                        <el-button type="text" @click="$refs.operaMemberWindow.open('缂栬緫浜哄憳淇℃伅琛�', row)" icon="el-icon-edit" v-permissions="['business:member:update']">缂栬緫</el-button>-->
-<!--                        <el-button type="text" @click="deleteById(row)" icon="el-icon-delete" v-permissions="['business:member:delete']">鍒犻櫎</el-button>-->
-<!--                    </template>-->
-<!--                </el-table-column>-->
+                <el-table-column
+                    v-if="containPermissions(['business:member:update', 'business:member:delete','business:empower:create'])"
+                    label="鎿嶄綔"
+                    min-width="120"
+                    fixed="right"
+                >
+                    <template slot-scope="{row}">
+                        <el-button type="text" @click="empower(row.id)" v-permissions="['business:empower:create']">閲嶆柊鎺堟潈</el-button>
+                    </template>
+                </el-table-column>
             </el-table>
             <pagination
                 @size-change="handleSizeChange"
@@ -113,6 +124,8 @@
                 :pagination="tableData.pagination"
             >
             </pagination>
+            <!--    鏌ョ湅浜哄憳寮�鍗¤褰�    -->
+            <cardOpeningRecord ref="cardOpeningRecord" @success="handlePageChange" />
         </template>
     </TableLayout1>
 </template>
@@ -121,13 +134,14 @@
 import BaseTable from '@/components/base/BaseTable'
 import TableLayout1 from '@/layouts/TableLayout1'
 import Pagination from '@/components/common/Pagination'
+import cardOpeningRecord from '@/components/business/cardOpeningRecord'
 import Tree from '@/components/common/Tree'
 import { fetchList } from '@/api/business/company'
-import { memberSync } from '@/api/business/member'
+import { memberSync, roleAuth } from '@/api/business/member'
 export default {
   name: 'internalMember',
   extends: BaseTable,
-  components: { TableLayout1, Pagination, Tree },
+  components: { TableLayout1, Pagination, Tree, cardOpeningRecord },
   data () {
     return {
       TreeList: [],
@@ -135,6 +149,7 @@
       searchForm: {
         name: '',
         status: '',
+        hkStatus: '',
         canVisit: '',
         keyword: '',
         type: 2,
@@ -142,6 +157,7 @@
         companyId: '',
         hasFace: ''
       },
+      loading:false,
       companyTree: []
     }
   },
@@ -156,20 +172,38 @@
     this.getfindCompanyTreePage()
   },
   methods: {
+    empower(id) {
+      var that = this
+      this.$confirm('纭畾閲嶆柊鎺堟潈鍚�?', '鎻愮ず', {
+        confirmButtonText: '纭畾',
+        cancelButtonText: '鍙栨秷',
+        type: 'warning'
+      }).then(() => {
+        roleAuth(id)
+          .then(res => {
+            that.search()
+          })
+      }).catch(() => {
+
+      });
+    },
     // 鑾峰彇缁勭粐鏍�
     getfindCompanyTreePage () {
       fetchList(1)
         .then(res => {
-          this.companyTree = res
-          // this.searchForm.erpOrgId = res[0].erpId
-          this.search()
+          if (res && res.length > 0) {
+            res[0].fsStatus = 1
+            this.companyTree = res
+            // this.searchForm.erpOrgId = res[0].erpId
+            this.search()
+          }
         })
     },
     // 鍚屾淇℃伅
     async synchronous () {
-      this.$dialog.actionConfirm('鎿嶄綔纭鎻愰啋', '鎮ㄧ‘璁ゅ悓姝ュ叏閮ㄤ俊鎭悧锛�')
+      this.$dialog.actionConfirm('璇ユ搷浣滈檷瑙﹀彂鍏ㄥ憳淇℃伅鏇存柊鍜岄噸鏂颁笅鍙戯紒璇疯皑鎱庢搷浣�', '鎮ㄧ‘璁ゅ叏閲忓悓姝ュ唴閮ㄤ汉鍛樹俊鎭悧锛�')
         .then(() => {
-          this.isWorking.delete = true
+          this.loading = true
           memberSync({})
             .then(res => {
               this.$tip.apiSuccess(res || '鍚屾鎴愬姛')
@@ -179,13 +213,12 @@
               this.$tip.apiFailed(e)
             })
             .finally(() => {
-              this.isWorking.delete = false
+              this.loading = false
             })
         })
         .catch(() => {})
     },
     callback (row) {
-      console.log(row)
       this.searchForm.erpOrgId = row.erpId
       this.searchForm.companyId = row.id
       this.search()

--
Gitblit v1.9.3