From 9ab109b9ee96e7ff2bf2b935a044aee5842a3ddc Mon Sep 17 00:00:00 2001 From: doum <doum> Date: 星期日, 28 九月 2025 10:08:09 +0800 Subject: [PATCH] 最新版本541200007 --- admin/src/views/business/platformEvent.vue | 213 ++++++++++++++++++++++++++-------------------------- 1 files changed, 107 insertions(+), 106 deletions(-) diff --git a/admin/src/views/business/platformEvent.vue b/admin/src/views/business/platformEvent.vue index 2d61009..438a834 100644 --- a/admin/src/views/business/platformEvent.vue +++ b/admin/src/views/business/platformEvent.vue @@ -1,96 +1,85 @@ <template> - <TableLayout :permissions="['business:platformevent:query']"> - <!-- 鎼滅储琛ㄥ崟 --> - <el-form ref="searchForm" slot="search-form" :model="searchForm" label-width="100px" inline> - <el-form-item label="" prop="platformName"> - <el-input v-model="searchForm.platformName" placeholder="璇疯緭鍏ユ湀鍙板悕绉�" @keypress.enter.native="search"></el-input> - </el-form-item> - <el-form-item label="" prop="channelName"> - <el-input v-model="searchForm.channelName" placeholder="璇疯緭鍏ョ洃鎺х偣鍚嶇О" @keypress.enter.native="search"></el-input> - </el-form-item> - <el-form-item label="" prop="plateNo"> - <el-input v-model="searchForm.plateNo" placeholder="璇疯緭鍏ヨ溅鐗屽彿" @keypress.enter.native="search"></el-input> - </el-form-item> - <el-form-item label="" prop="eventType"> - <el-select v-model="searchForm.motionStatus" placeholder="璇烽�夋嫨杩涘嚭绫诲瀷"> - <el-option label="绂诲紑" value="leave"></el-option> - <el-option label="杩涘叆" value="enter"></el-option> - </el-select> - </el-form-item> - <el-form-item label="璧锋鏃堕棿" prop="startDate"> - <el-date-picker - @change="seleTime" - v-model="time" - type="datetimerange" - format="yyyy-MM-dd HH:mm:ss" - value-format="yyyy-MM-dd HH:mm:ss" - range-separator="鑷�" - start-placeholder="寮�濮嬫椂闂�" - end-placeholder="缁撴潫鏃堕棿"> - </el-date-picker> - </el-form-item> - <el-radio-group v-model="searchForm.radio" size="small" @input="changeRadio"> - <el-radio-button label="0">褰撳ぉ</el-radio-button> - <el-radio-button label="1">杩�7澶�</el-radio-button> - <el-radio-button label="2">杩�30澶�</el-radio-button> - </el-radio-group> - <section> - <el-button type="primary" @click="search">鎼滅储</el-button> - <el-button @click="reset">閲嶇疆</el-button> - </section> - </el-form> - <!-- 琛ㄦ牸鍜屽垎椤� --> - <template v-slot:table-wrap> - <el-table - v-loading="isWorking.search" - :data="tableData.list" - stripe - > - <el-table-column prop="platformName" label="鏈堝彴鍚嶇О" min-width="180px"></el-table-column> - <el-table-column prop="channelName" label="鐩戞帶鐐瑰悕绉�" min-width="180px"></el-table-column> - <el-table-column prop="plateNo" label="杞︾墝鍙�" min-width="180px"></el-table-column> - <el-table-column label="杞﹁締杩涘嚭绫诲瀷" min-width="180px"> - <template slot-scope="{row}"> - <span v-if="row.motionStatus == 'enter'">杩涘叆span> - <span v-if="row.motionStatus == 'leave'">绂诲紑</span> - <span v-if="row.motionStatus != 'leave' && row.motionStatus != 'enter'">{{ row.motionStatus }}</span> - </template> - </el-table-column> - <el-table-column label="鍓嶅悗鏍囪瘑" min-width="180px"> - <template slot-scope="{row}"> - <span v-if="row.stockStatus == 'rear'">杞﹀熬</span> - <span v-if="row.stockStatus == 'front'">杞﹀ご</span> - <span v-if="row.stockStatus != 'rear' && row.stockStatus != 'front'">{{ row.stockStatus }}</span> - </template> - </el-table-column> - <el-table-column prop="stockStatus" label="杞﹂棬鐘舵��" min-width="180px"></el-table-column> - <el-table-column label="杞﹂棬鐘舵��" min-width="100px"> - <template slot-scope="{row}"> - <span v-if="row.vehicleDoorStatus == 'open'">寮�闂�</span> - <span v-if="row.vehicleDoorStatus == 'close'">鍏抽棬</span> - <span v-if="row.vehicleDoorStatus != 'open' && row.vehicleDoorStatus != 'close'">{{ row.vehicleDoorStatus }}</span> - </template> - </el-table-column> - <el-table-column prop="deviceId" label="璁惧缂栫爜" min-width="150px"></el-table-column> - <el-table-column prop="ipAddress" label="IP鍦板潃" min-width="100px"></el-table-column> - <el-table-column prop="portNo" label="绔彛" min-width="100px"></el-table-column> - <el-table-column fixed="right" label="鎶撴媿鍥�" min-width="100px"> - <template slot-scope="{row}"> - <el-image v-if="row.backgroundImageDown" style="width: 60px; height: 60px" :src="row.backgroundImageDown" - :preview-src-list="[row.backgroundImageDown]"> - </el-image> - </template> - </el-table-column> - <el-table-column prop="createDate" label="鍒涘缓鏃堕棿" min-width="100px"></el-table-column> - </el-table> - <pagination - @size-change="handleSizeChange" - @current-change="handlePageChange" - :pagination="tableData.pagination" - > - </pagination> - </template> - </TableLayout> + <TableLayout :permissions="['business:platformevent:query']"> + <!-- 鎼滅储琛ㄥ崟 --> + <div slot="search-form" ref="QueryFormRef"> + <el-form ref="searchForm" :model="searchForm" label-width="100px" inline> + <el-form-item label="" prop="platformName"> + <el-input v-model="searchForm.platformName" placeholder="璇疯緭鍏ユ湀鍙板悕绉�" @keypress.enter.native="search"></el-input> + </el-form-item> + <el-form-item label="" prop="channelName"> + <el-input v-model="searchForm.channelName" placeholder="璇疯緭鍏ョ洃鎺х偣鍚嶇О" @keypress.enter.native="search"></el-input> + </el-form-item> + <el-form-item label="" prop="plateNo"> + <el-input v-model="searchForm.plateNo" placeholder="璇疯緭鍏ヨ溅鐗屽彿" @keypress.enter.native="search"></el-input> + </el-form-item> + <el-form-item label="" prop="motionStatus"> + <el-select v-model="searchForm.motionStatus" placeholder="璇烽�夋嫨杩涘嚭绫诲瀷"> + <el-option label="绂诲紑" value="leave"></el-option> + <el-option label="杩涘叆" value="enter"></el-option> + </el-select> + </el-form-item> + <el-form-item label="" prop="startDate"> + <el-date-picker @change="changeDate" v-model="searchForm.startDate" type="datetime" + format="yyyy-MM-dd HH:mm:ss" value-format="yyyy-MM-dd HH:mm:ss" placeholder="寮�濮嬫椂闂�" /> + <el-date-picker @change="changeDate" v-model="searchForm.endDate" type="datetime" format="yyyy-MM-dd HH:mm:ss" + value-format="yyyy-MM-dd HH:mm:ss" placeholder="寮�濮嬫椂闂�" /> + </el-form-item> + <el-radio-group v-model="searchForm.radio" size="small" @input="changeRadio"> + <el-radio-button label="0">褰撳ぉ</el-radio-button> + <el-radio-button label="1">杩�7澶�</el-radio-button> + <el-radio-button label="2">杩�30澶�</el-radio-button> + </el-radio-group> + <section> + <el-button type="primary" @click="search">鎼滅储</el-button> + <el-button @click="reset">閲嶇疆</el-button> + </section> + </el-form> + </div> + + <!-- 琛ㄦ牸鍜屽垎椤� --> + <template v-slot:table-wrap> + <el-table v-loading="isWorking.search" :max-height="tableHeight" :data="tableData.list" stripe> + <el-table-column prop="platformName" label="鏈堝彴鍚嶇О" min-width="150px"></el-table-column> + <el-table-column prop="channelName" label="鐩戞帶鐐瑰悕绉�" min-width="150px"></el-table-column> + <el-table-column prop="plateNo" label="杞︾墝鍙�" min-width="100px"></el-table-column> + <el-table-column label="杩涘嚭绫诲瀷" min-width="90px"> + <template slot-scope="{row}"> + <span v-if="row.motionStatus == 'enter'">杩涘叆</span> + <span v-if="row.motionStatus == 'leave'">绂诲紑</span> + <span v-if="row.motionStatus != 'leave' && row.motionStatus != 'enter'">{{ row.motionStatus }}</span> + </template> + </el-table-column> + <el-table-column label="鍓嶅悗鏍囪瘑" min-width="90px"> + <template slot-scope="{row}"> + <span v-if="row.stockStatus == 'rear'">杞﹀熬</span> + <span v-if="row.stockStatus == 'front'">杞﹀ご</span> + <span v-if="row.stockStatus != 'rear' && row.stockStatus != 'front'">{{ row.stockStatus }}</span> + </template> + </el-table-column> + <el-table-column label="杞﹂棬鐘舵��" min-width="100px"> + <template slot-scope="{row}"> + <span v-if="row.vehicleDoorStatus == 'open'">寮�闂�</span> + <span v-if="row.vehicleDoorStatus == 'close'">鍏抽棬</span> + <span v-if="row.vehicleDoorStatus != 'open' && row.vehicleDoorStatus != 'close'">{{ row.vehicleDoorStatus + }}</span> + </template> + </el-table-column> + <el-table-column prop="srcIndex" label="璁惧缂栫爜" min-width="260px"></el-table-column> + <el-table-column prop="ipAddress" label="IP鍦板潃" min-width="100px"></el-table-column> + <el-table-column prop="portNo" label="绔彛" min-width="80px"></el-table-column> + <el-table-column fixed="right" label="鎶撴媿鍥�" min-width="100px"> + <template slot-scope="{row}"> + <el-image v-if="row.backgroundImageDown" style="width: 60px; height: 60px" :src="row.backgroundImageDown" + :preview-src-list="[row.backgroundImageDown]"> + </el-image> + </template> + </el-table-column> + <el-table-column prop="createDate" label="鍒涘缓鏃堕棿" min-width="160px"></el-table-column> + </el-table> + <pagination @size-change="handleSizeChange" @current-change="handlePageChange" :pagination="tableData.pagination"> + </pagination> + </template> + </TableLayout> </template> <script> @@ -102,7 +91,7 @@ name: 'platformEvent', extends: BaseTable, components: { TableLayout, Pagination }, - data () { + data() { return { // 鎼滅储 searchForm: { @@ -117,7 +106,7 @@ time: [] } }, - created () { + created() { this.config({ module: '鏈堝彴杞﹁締鐘舵�佷簨浠朵氦浜掕褰�', api: '/business/platformEvent', @@ -126,34 +115,46 @@ }) this.changeRadio('0') }, + mounted() { + this.$nextTick(() => { + this.tableHeight = document.body.scrollHeight - this.$refs.QueryFormRef.offsetHeight - 260 + }) + }, methods: { - changeRadio (e) { + changeDate(e) { + if ((this.searchForm.startDate && this.searchForm.endDate) && this.searchForm.startDate > this.searchForm.endDate) { + this.searchForm.endDate = this.searchForm.startDate + this.search() + return this.$message.error('寮�濮嬫椂闂翠笉鑳藉ぇ浜庣粨鏉熸椂闂�') + }else{ + this.search() + } + }, + changeRadio(e) { if (e === '0') { this.searchForm.startDate = timeForMat(0)[0] this.searchForm.endDate = timeForMat(0)[1] - this.time = timeForMat(0) + // this.time = timeForMat(0) } else if (e === '1') { this.searchForm.startDate = timeForMat(6)[0] this.searchForm.endDate = timeForMat(6)[1] - this.time = timeForMat(6) + // this.time = timeForMat(6) } else if (e === '2') { this.searchForm.startDate = timeForMat(29)[0] this.searchForm.endDate = timeForMat(29)[1] - this.time = timeForMat(29) + // this.time = timeForMat(29) + } + if ((this.searchForm.startDate && this.searchForm.endDate) && this.searchForm.startDate > this.searchForm.endDate) { + this.searchForm.startDate = this.searchForm.endDate + return this.$message.error('寮�濮嬫椂闂翠笉鑳藉ぇ浜庣粨鏉熸椂闂�') } this.search() }, - seleTime (e) { - this.searchForm.startDate = e[0] - this.searchForm.endDate = e[1] - this.searchForm.radio = null - this.search() - }, - reset () { + reset() { this.$refs.searchForm.resetFields() this.searchForm.startDate = '' this.searchForm.endDate = '' - this.time = [] + this.searchForm.radio = '' this.search() } } -- Gitblit v1.9.3