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