From cf69b541f8ef1ac4fae24bd99b0259b7af035490 Mon Sep 17 00:00:00 2001 From: MrShi <1878285526@qq.com> Date: 星期二, 21 十月 2025 10:16:12 +0800 Subject: [PATCH] 优化 --- admin/src/views/platform/platform.vue | 161 ++++++++++++++++++++++++++++++++++------------------- 1 files changed, 103 insertions(+), 58 deletions(-) diff --git a/admin/src/views/platform/platform.vue b/admin/src/views/platform/platform.vue index 19d6d74..3446e39 100644 --- a/admin/src/views/platform/platform.vue +++ b/admin/src/views/platform/platform.vue @@ -1,66 +1,97 @@ <template> <TableLayout :permissions="['business:platform:query']"> <!-- 鎼滅储琛ㄥ崟 --> - <SearchFormCollapse slot="search-form" :need-more="false"> - <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> - <section> + <div ref="QueryFormRef" slot="search-form"> + <SearchFormCollapse :need-more="false"> + <el-form ref="searchForm" :model="searchForm" label-width="100px" inline> + <el-form-item label="" prop="name"> + <el-input v-model="searchForm.name" clearable placeholder="璇疯緭鍏ユ湀鍙板悕绉�" + @keypress.enter.native="search"></el-input> + </el-form-item> + <el-form-item label="" prop="groupId"> + <el-select v-model="searchForm.groupId" placeholder="璇烽�夋嫨鏈堝彴鍒嗙粍" @change="search" clearable> + <el-option v-for="item in groupList" :key="item.id" :label="item.name" :value="item.id"> + </el-option> + </el-select> + </el-form-item> + <el-form-item label="" prop="type"> + <el-select v-model="searchForm.type" placeholder="璇烽�夋嫨鏈堝彴绫诲瀷" @change="search" clearable> + <el-option label="鏁存墭鐩�" :value="0"></el-option> + <el-option label="鏁d欢" :value="1"></el-option> + </el-select> + </el-form-item> + <!-- <section> --> <el-button type="primary" @click="search">鎼滅储</el-button> <el-button @click="reset">閲嶇疆</el-button> - </section> - </el-form> - </SearchFormCollapse> + <!-- </section> --> + </el-form> + </SearchFormCollapse> + </div> <!-- 琛ㄦ牸鍜屽垎椤� --> <template v-slot:table-wrap> <ul class="toolbar" v-permissions="['business:hksync:platforms']"> - <li><el-button type="primary" :loading="working" @click="syncData" icon="el-icon-plus" v-permissions="['business:hksync:platforms']">鍚屾</el-button></li> - <li><el-button type="primary" :loading="working1" @click="syncStatus" icon="el-icon-plus" v-permissions="['business:hksync:platforms']">鍚屾鐘舵��</el-button></li> + <li><el-button type="primary" :loading="working" @click="syncData" icon="el-icon-plus" + v-permissions="['business:hksync:platforms']">鍚屾</el-button></li> + <li><el-button type="primary" :loading="working1" @click="syncStatus" icon="el-icon-plus" + v-permissions="['business:hksync:platforms']">鍚屾瀹炴椂鐘舵��</el-button></li> </ul> <el-table - v-loading="isWorking.search" - :data="tableData.list" - stripe - @selection-change="handleSelectionChange" - > + :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="hkId" label="鏈堝彴缂栫爜" min-width="100px"></el-table-column> - <el-table-column prop="groupName" label="鎵�灞炴湀鍙扮粍" min-width="100px"></el-table-column> - <el-table-column prop="workingNum" label="鍚屾椂鍙彿杞﹁締鏁�" min-width="100px"></el-table-column> - <el-table-column prop="alermTime" label="鍋滅暀瓒呮椂鎶ヨ鏃堕棿(鍒嗛挓锛�" min-width="100px"> - <template scope="{row}">{{row.alermTime?(row.alermTime/60):'-'}}</template> + <el-table-column prop="name" label="鏈堝彴鍚嶇О" fixed min-width="100px"></el-table-column> + <el-table-column prop="code" label="鏈堝彴缂栫爜" fixed min-width="100px"></el-table-column> + <el-table-column prop="type" label="鏈堝彴绫诲瀷" min-width="100px"> + <template scope="{row}"> + <span v-if="row.type == 0" class="green">鏁存墭鐩�</span> + <span v-else-if="row.type == 1" class="red">鏁d欢</span> + <span v-else class="grey">-</span> + </template> </el-table-column> - <el-table-column prop="waitCallTime" label="浣滀笟瓒呮椂鎶ヨ鏃堕棿(鍒嗛挓锛�" min-width="100px"> - <template scope="{row}"> {{row.waitCallTime?(row.alermTime/60):'-'}}</template> + <el-table-column prop="groupName" label="鎵�灞炴湀鍙扮粍" fixed min-width="150px"></el-table-column> + <el-table-column prop="sortnum" label="鎺掑簭鐮�" min-width="90px"></el-table-column> + <el-table-column prop="workingNum" label="鍚屾椂鍙彿鏁伴噺" min-width="120px"></el-table-column> + <el-table-column prop="callReadyNum" label="鍚屾椂鍑嗗鏁伴噺" min-width="120px"></el-table-column> + <el-table-column prop="stayTimeoutAlarmTime" label="鍋滅暀瓒呮椂鎶ヨ鏃堕棿(鍒嗛挓锛�" min-width="180px"> + <template scope="{row}">{{ row.stayTimeoutAlarmTime ? (row.stayTimeoutAlarmTime) : '-' }}</template> </el-table-column> - <el-table-column prop="workRate" label="鏈堝彴浣滀笟鏁堢巼(涓囧彧/灏忔椂)" min-width="100px"></el-table-column> - <el-table-column prop="status" label="鐘舵��" min-width="100px"></el-table-column> - <el-table-column prop="broadcastName" label="鍏宠仈骞挎挱" min-width="100px"></el-table-column> - <el-table-column prop="ledName" label="鍏宠仈LED" min-width="100px"></el-table-column> - <el-table-column prop="hkDate" label="鍚屾鏃堕棿" min-width="100px"></el-table-column> - <el-table-column - v-if="containPermissions(['business:platform:update', 'business:platform:delete'])" - label="鎿嶄綔" - min-width="120" - fixed="right" - > + <el-table-column prop="workTimeoutAlarmTime" label="浣滀笟瓒呮椂鎶ヨ鏃堕棿(鍒嗛挓锛�" min-width="180px"> + <template scope="{row}"> {{ row.workTimeoutAlarmTime ? (row.workTimeoutAlarmTime) : '-' }}</template> + </el-table-column> + <el-table-column prop="workRate" label="鏈堝彴浣滀笟鏁堢巼(涓囨敮/灏忔椂)" min-width="180px"></el-table-column> + <!-- <el-table-column prop="platformStatus" label="鏈堝彴鐘舵��" min-width="100px"> + <template scope="{row}"> + <span v-if="row.platformStatus == 0">鏃犺溅</span> + <span v-if="row.platformStatus == 1">鏈夎溅</span> + <span v-if="row.platformStatus == 2">瓒呮椂鍋滈潬</span> + <span v-if="row.platformStatus == 3">閿欒鍋滈潬</span> + </template> + </el-table-column> --> + <el-table-column prop="broadcastNames" label="鍏宠仈骞挎挱" min-width="100px"></el-table-column> + <el-table-column prop="ledNames" label="鍏宠仈LED" min-width="100px"></el-table-column> + <el-table-column prop="ledContent" label="LED绌洪棽鏂囨" min-width="180px"></el-table-column> + <el-table-column prop="hkDate" label="鍚屾鏃堕棿" min-width="150px"></el-table-column> + <el-table-column label="鏈堝彴鐘舵��" fixed="right" width="100px"> <template slot-scope="{row}"> - <el-button type="text" @click="$refs.operaPlatformWindow.open('缂栬緫鏈堝彴淇℃伅琛�', row)" icon="el-icon-edit" v-permissions="['business:platform:update']">缂栬緫</el-button> - <el-button type="text" @click="deleteById(row)" icon="el-icon-delete" v-permissions="['business:platform:delete']">鍒犻櫎</el-button> + <el-switch @change="changeStatus($event, row)" v-model="row.status" active-color="#13ce66" + inactive-color="#ff4949" :active-value="0" :inactive-value="1"> + </el-switch> + </template> + </el-table-column> + <el-table-column v-if="containPermissions(['business:platform:update', 'business:platform:delete'])" label="鎿嶄綔" + min-width="120" fixed="right"> + <template slot-scope="{row}"> + <el-button type="text" @click="$refs.operaPlatformWindow.open('缂栬緫鏈堝彴淇℃伅琛�', row)" icon="el-icon-edit" + v-permissions="['business:platform:update']">缂栬緫</el-button> + <!-- <el-button type="text" @click="deleteById(row)" icon="el-icon-delete" + v-permissions="['business:platform:delete']">鍒犻櫎</el-button> --> </template> </el-table-column> </el-table> - <pagination - @size-change="handleSizeChange" - @current-change="handlePageChange" - :pagination="tableData.pagination" - > + <pagination @size-change="handleSizeChange" @current-change="handlePageChange" :pagination="tableData.pagination"> </pagination> </template> <!-- 鏂板缓/淇敼 --> - <OperaPlatformWindow ref="operaPlatformWindow" @success="handlePageChange"/> + <OperaPlatformWindow ref="operaPlatformWindow" @success="handlePageChange" /> </TableLayout> </template> @@ -70,23 +101,25 @@ import SearchFormCollapse from '@/components/common/SearchFormCollapse' import Pagination from '@/components/common/Pagination' import OperaPlatformWindow from '@/components/business/OperaPlatformWindow' -import { syncDevices, updateEntranceById } from '@/api/business/device' -import { syncPlatforms } from '@/api/platform/platform' +import { allList } from '@/api/platform/platformGroup' export default { name: 'Platform', extends: BaseTable, components: { SearchFormCollapse, TableLayout, Pagination, OperaPlatformWindow }, - data () { + data() { return { + groupList: [], // 鎼滅储 working: false, working1: false, searchForm: { - name: '' + name: '', + type:null, + groupId: null } } }, - created () { + created() { this.config({ module: '鏈堝彴淇℃伅琛�', api: '/platform/platform', @@ -94,15 +127,27 @@ 'field.main': 'id' }) this.search() + this.loadGroupList() + }, + mounted() { + this.$nextTick(() => { + this.tableHeight = document.body.scrollHeight - this.$refs.QueryFormRef.offsetHeight - 300 + }) }, methods: { - changeManufature (e, row) { - updateEntranceById({ + loadGroupList() { + allList({}) + .then(res => { + this.groupList = res || [] + }) + }, + changeStatus(e, row) { + this.api.updateStatusById({ id: row.id, - isEntrance: e + status: e }) }, - syncData () { + syncData() { this.$dialog.actionConfirm('鎿嶄綔纭鎻愰啋', '鎮ㄧ‘璁ゅ悓姝ュ叏閮ㄤ俊鎭悧锛�') .then(() => { this.isWorking.working = true @@ -112,31 +157,31 @@ this.search() }) .catch(e => { - this.$tip.apiFailed(e) + // this.$tip.apiFailed(e) }) .finally(() => { this.isWorking.working = false }) }) - .catch(() => {}) + .catch(() => { }) }, - syncStatus () { + syncStatus() { this.$dialog.actionConfirm('鎿嶄綔纭鎻愰啋', '鎮ㄧ‘璁ゅ悓姝ュ叏閮ㄤ俊鎭悧锛�') .then(() => { this.isWorking.working = true - this.api.syncPlatforms({}) + this.api.syncPlatformStatus({}) .then(res => { this.$tip.apiSuccess(res || '鍚屾鎴愬姛') this.search() }) .catch(e => { - this.$tip.apiFailed(e) + // this.$tip.apiFailed(e) }) .finally(() => { this.isWorking.working = false }) }) - .catch(() => {}) + .catch(() => { }) } } } -- Gitblit v1.9.3