From c58ada7f49aac20b06ea2ebda2cb5c006decf122 Mon Sep 17 00:00:00 2001
From: liukangdong <898885815@qq.com>
Date: 星期五, 10 五月 2024 17:01:55 +0800
Subject: [PATCH] Merge branch 'master' of http://139.186.142.91:10010/r/productDev/dmvisit

---
 admin/src/views/meeting/rooms.vue |  236 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 236 insertions(+), 0 deletions(-)

diff --git a/admin/src/views/meeting/rooms.vue b/admin/src/views/meeting/rooms.vue
new file mode 100644
index 0000000..a8ef660
--- /dev/null
+++ b/admin/src/views/meeting/rooms.vue
@@ -0,0 +1,236 @@
+<template>
+  <TableLayout :permissions="['business:rooms: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="sysList">
+        <el-select
+          v-model="searchForm.sysList"
+          filterable
+          clearable
+          multiple
+          placeholder="閫夋嫨閮ㄩ棬鎴愬憳"
+        >
+          <el-option
+            v-for="item in userList"
+            :key="item.id"
+            :value="item.id"
+            :label="item.department?`${item.department.name}-${item.realname}`:item.realname"
+            ></el-option>
+            <!-- :label="`${item.department.name}-${item.realname}`" -->
+          <!-- <el-option :key="1" :value="1" label="绂佺敤" /> -->
+        </el-select>
+      </el-form-item>
+
+      <section>
+        <el-button type="primary" @click="search">鎼滅储</el-button>
+        <!-- <el-button type="primary" :loading="isWorking.export" v-permissions="['business:rooms: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:rooms:create']">
+        <li><el-button type="primary" @click="$refs.operaRoomsWindow.open('鏂板缓浼氳瀹�')" v-permissions="['business:rooms:create']">鏂板缓</el-button></li>
+        <!-- <li><el-button @click="deleteByIdInBatch" v-permissions="['business:rooms:delete']">鍒犻櫎</el-button></li> -->
+      </ul>
+      <el-table
+        v-loading="isWorking.search"
+        :data="tableData.list"
+        stripe
+        border
+        @selection-change="handleSelectionChange"
+      >
+        <!-- <el-table-column type="selection" width="55"></el-table-column> -->
+        <el-table-column prop="name" label="浼氳瀹ゅ悕绉�" align="center" min-width="120px" show-overflow-tooltip>
+          <template slot-scope="{row}">
+            <span class="long-title-style">{{ row.name }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column prop="startTime" label="寮�鏀炬椂闂�" align="center" min-width="120px">
+          <template slot-scope="{row}">
+            {{ `${row.startTime}-${row.endTime}` }}
+          </template>
+        </el-table-column>
+        <el-table-column prop="intervalTime" label="绮掑害锛堝垎閽燂級" align="center" min-width="100px"></el-table-column>
+        <el-table-column prop="limitNum" label="瀹圭撼浜烘暟" align="center" min-width="100px"></el-table-column>
+        <el-table-column prop="limitNum" label="绠$悊鍛�" min-width="140px" align="center" show-overflow-tooltip>
+          <template slot-scope="{row}">
+            <span class="long-title-style">{{ row.sysList.map(item => item.realName).join(',') }}</span>
+
+            <!-- <ul>
+              <li v-for="sys in row.sysList" :key="sys.id">{{sys.realName}}</li>
+            </ul> -->
+          </template>
+        </el-table-column>
+        <el-table-column prop="limitNum" label="鍙�夋湇鍔¢」" align="center" min-width="140px" show-overflow-tooltip>
+          <template slot-scope="{row}">
+            <div class="long-title-style">{{ row.projectList.map(item => item.projectName).join('|') }}</div>
+
+          </template>
+        </el-table-column>
+        <el-table-column prop="status" label="鐘舵��" align="center" min-width="100px">
+          <template slot-scope="{row}">
+            <el-switch
+              v-model="row.status"
+              active-color="#13ce66"
+              inactive-color="#999"
+              :active-value="0"
+              :inactive-value="1"
+              @change="changeStatus(row)"
+            ></el-switch>
+          </template>
+        </el-table-column>
+        <el-table-column prop="createDate" label="鍒涘缓鏃堕棿"  align="center" min-width="140px"></el-table-column>
+        <!-- <el-table-column prop="editor" label="鏇存柊浜虹紪鐮�" min-width="100px"></el-table-column>
+        <el-table-column prop="editDate" label="鏇存柊鏃堕棿" min-width="100px"></el-table-column>
+        <el-table-column prop="isdeleted" label="鏄惁鍒犻櫎0鍚� 1鏄�" min-width="100px"></el-table-column>
+        <el-table-column prop="remark" label="澶囨敞" min-width="100px"></el-table-column>
+        <el-table-column prop="imgurl" label="浼氳瀹ゅ浘鐗�" min-width="100px"></el-table-column>
+        <el-table-column prop="tips" label="浣跨敤椤荤煡" min-width="100px"></el-table-column>
+        <el-table-column prop="status" label="鐘舵�� 0鍚敤 1绂佺敤" min-width="100px"></el-table-column> -->
+        <el-table-column
+          v-if="containPermissions(['business:rooms:update', 'business:rooms:delete'])"
+          label="鎿嶄綔"
+          min-width="120"
+          fixed="right"
+        >
+          <template slot-scope="{row}">
+            <el-button type="text" @click="$refs.operaRoomsWindow.open('缂栬緫浼氳瀹�', row)" v-permissions="['business:rooms:update']">缂栬緫</el-button>
+            <el-button type="text" @click="deleteById(row)" v-permissions="['business:rooms:delete']">鍒犻櫎</el-button>
+          </template>
+        </el-table-column>
+      </el-table>
+      <pagination
+        @size-change="handleSizeChange"
+        @current-change="handlePageChange"
+        :pagination="tableData.pagination"
+      ></pagination>
+    </template>
+    <!-- 鏂板缓/淇敼 -->
+    <OperaRoomsWindow ref="operaRoomsWindow" @success="handlePageChange"/>
+    <!-- <selectMember ref="selectMember" @done=""/> -->
+  </TableLayout>
+</template>
+
+<script>
+import BaseTable from '@/components/base/BaseTable'
+import TableLayout from '@/layouts/TableLayout'
+import Pagination from '@/components/common/Pagination'
+import OperaRoomsWindow from '@/views/meeting/components/OperaRoomsWindow'
+import { fetchList as userList } from '@/api/system/user'
+// import selectMember from '@/components/meeting/selectMember'
+import { updateStatusById } from '@/api/meeting/rooms'
+export default {
+  name: 'Rooms',
+  extends: BaseTable,
+  components: { TableLayout, Pagination, OperaRoomsWindow },
+  data () {
+    return {
+      userList: [],
+      // 鎼滅储
+      searchForm: {
+        id: '',
+        creator: '',
+        createDate: '',
+        editor: '',
+        editDate: '',
+        isdeleted: '',
+        name: '',
+        remark: '',
+        startTime: '',
+        endTime: '',
+        limitNum: '',
+        imgurl: '',
+        tips: '',
+        status: '',
+        intervalTime: '',
+        sysList: []
+      }
+    }
+  },
+  provide() {
+    return {
+      userList: () => this.userList
+    }
+  },
+  created () {
+    this.config({
+      module: '浼氳瀹や俊鎭〃',
+      api: '/meeting/rooms',
+      'field.id': 'id',
+      'field.main': 'id'
+    })
+    userList({
+      page: 1,
+      capacity: 9999,
+      model: { realname: this.filterText },
+    })
+      .then(res => {
+        this.userList = res.records
+      })
+    this.search()
+  },
+  methods: {
+     // 椤电爜鍙樻洿澶勭悊
+    handlePageChange (pageIndex) {
+      this.__checkApi()
+      this.tableData.pagination.pageIndex = pageIndex || this.tableData.pagination.pageIndex
+      this.isWorking.search = true
+      let sysList = [...this.searchForm.sysList]
+      sysList = sysList.map(item => {
+        return {userId: item}
+      })
+      console.log(sysList);
+      this.api.fetchList({
+        page: this.tableData.pagination.pageIndex,
+        capacity: this.tableData.pagination.pageSize,
+        model: {
+          ...this.searchForm,
+          sysList
+        },
+        sorts: this.tableData.sorts
+      })
+        .then(data => {
+          this.tableData.list = data.records
+          this.tableData.pagination.total = data.total
+        })
+        .catch(e => {
+          this.$tip.apiFailed(e)
+        })
+        .finally(() => {
+          this.isWorking.search = false
+        })
+    },
+    // selectMemberAction() {
+    //   console.log('21212');
+    //   this.$refs.selectMember.open('閫夋嫨绠$悊鍛�')
+    // },
+    changeStatus(item) {
+      updateStatusById({
+        id: item.id,
+        status: item.status
+      })
+        .then(() => {
+          this.$message.success('淇敼鎴愬姛')
+
+        })
+        .catch(e => {
+          this.$message.error(e)
+        })
+        .finally(() => {
+          this.handlePageChange()
+        })
+    }
+  },
+}
+</script>
+
+<style scoped>
+::v-deep .el-input.is-disabled .el-input__inner {
+  background-color: #fff !important;
+  cursor: pointer;
+}
+</style>

--
Gitblit v1.9.3