From 66b84de58e3efae14c1e258ee716e02ad9557497 Mon Sep 17 00:00:00 2001 From: doum <doum> Date: 星期四, 09 十月 2025 08:48:50 +0800 Subject: [PATCH] 最新版本541200007 --- admin/src/views/vehicle/cars.vue | 310 ++++++++++++++++++++++++++++++++------------------- 1 files changed, 194 insertions(+), 116 deletions(-) diff --git a/admin/src/views/vehicle/cars.vue b/admin/src/views/vehicle/cars.vue index bdd6b22..9c026c5 100644 --- a/admin/src/views/vehicle/cars.vue +++ b/admin/src/views/vehicle/cars.vue @@ -1,113 +1,135 @@ <template> - <TableLayout :permissions="['business:member:query']"> - <!-- 鎼滅储琛ㄥ崟 --> - <el-form ref="searchForm" slot="search-form" :model="searchForm" label-width="100px" inline> - <el-form-item label="" prop="code" title="杞︾墝鍙�"> - <el-input v-model="searchForm.code" clearable placeholder="杞︾墝鍙�" @keypress.enter.native="search"></el-input> - </el-form-item> - <el-form-item label="" prop="memberName" title="杞︿富濮撳悕/鎵嬫満鍙�"> - <el-input v-model="searchForm.memberName" clearable placeholder="杞︿富濮撳悕/鎵嬫満鍙�" @keypress.enter.native="search"></el-input> - </el-form-item> - <el-form-item label="" prop="companyName" title="杞︿富閮ㄩ棬鍚嶇О"> - <el-input v-model="searchForm.companyName" clearable placeholder="杞︿富閮ㄩ棬鍚嶇О" @keypress.enter.native="search"></el-input> - </el-form-item> - <el-form-item label="" prop="authStatus" title="鏄惁鎺堟潈"> - <el-select v-model="searchForm.authStatus" @change="search" clearable placeholder="鏄惁鎺堟潈"> - <el-option label="宸叉巿鏉�" value="1"></el-option> - <el-option label="鏈巿鏉�" value="0"></el-option> - </el-select> - </el-form-item> - <el-form-item label="" prop="type" title="杞﹁締绫诲瀷"> - <el-select v-model="searchForm.type" @change="search" clearable placeholder="杞﹁締绫诲瀷"> - <el-option label="瀹夋嘲鍏姟杞�" value="0"></el-option> - <el-option label="瀹夋嘲鑷湁鐗╂祦杞�" value="1"></el-option> - <el-option label="鍏朵粬" value="2"></el-option> + <TableLayout :permissions="['business:member:query']"> + <!-- 鎼滅储琛ㄥ崟 --> + <div ref="QueryFormRef" slot="search-form"> + <el-form ref="searchForm" :model="searchForm" label-width="100px" inline> + <el-form-item label="" prop="code" title="杞︾墝鍙�"> + <el-input v-model="searchForm.code" clearable placeholder="杞︾墝鍙�" @keypress.enter.native="search"></el-input> + </el-form-item> + <el-form-item label="" prop="memberName" title="杞︿富淇℃伅"> + <el-input v-model="searchForm.memberName" clearable placeholder="杞︿富淇℃伅" + @keypress.enter.native="search"></el-input> + </el-form-item> + <el-form-item label="" prop="catePName" title="鍒嗙被鍚嶇О"> + <el-cascader v-model="searchForm.cateIds" @change="changeSel" placeholder="璇烽�夋嫨鍒嗙被" clearable + :options="cateList" :props="{ + label: 'name', + value: 'id', + children: 'childCategoryList', + checkStrictly: true + }"></el-cascader> + </el-form-item> + <el-form-item label="" prop="companyName" title="杞︿富缁勭粐鍚嶇О"> + <el-input v-model="searchForm.companyName" clearable placeholder="杞︿富缁勭粐鍚嶇О" + @keypress.enter.native="search"></el-input> + </el-form-item> + <el-form-item label="" prop="authStatus" title="鏄惁鎺堟潈"> + <el-select v-model="searchForm.authStatus" @change="search" clearable placeholder="鏄惁鎺堟潈"> + <el-option label="宸叉巿鏉�" value="1"></el-option> + <el-option label="鏈巿鏉�" value="0"></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> - <!-- 琛ㄦ牸鍜屽垎椤� --> - <template v-slot:table-wrap> - <ul class="toolbar" v-permissions="['business:cars:create', 'business:parkBook:create']"> - <li><el-button type="primary" @click="$refs.operaCarsWindow.open('鏂板缓杞﹁締')" icon="el-icon-plus" v-permissions="['business:cars:create']">鏂板缓</el-button></li> - <li><el-button type="primary" @click="startEmpowerBatch" icon="el-icon-plus" v-permissions="['business:parkbook:create']">涓嬪彂鎺堟潈</el-button></li> - </ul> - <el-table - 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="code" label="杞︾墝鍙�" min-width="100px"></el-table-column> - <el-table-column label="杞﹁締绫诲瀷" min-width="100px"> - <template slot-scope="{row}"> - <span v-if="row.type == 0" >瀹夋嘲鍏姟杞�</span> - <span v-if="row.type == 1">瀹夋嘲鑷湁鐗╂祦杞�</span> - <span v-if="row.type == 2" >鍏朵粬</span> - </template> - </el-table-column> - <el-table-column prop="memberName" label="杞︿富濮撳悕" min-width="100px"></el-table-column> - <el-table-column prop="memberPhone" label="杞︿富鎵嬫満鍙�" min-width="100px"></el-table-column> - <el-table-column prop="companyName" label="杞︿富缁勭粐" min-width="200px"></el-table-column> - <el-table-column label="鏄惁鎺堟潈" align="center" min-width="100px"> - <template slot-scope="{row}"> - <span v-if="row.authStatus == 1" style="color: green">鏄�</span> - <span v-else style="color: red">鍚�</span> - </template> - </el-table-column> - <el-table-column prop="parksName" align="center" label="宸叉巿鏉冨仠杞﹀満" min-width="200px"> - <template slot-scope="{row}"> - <div v-if="row.parkBookList && row.parkBookList.length" > - <span v-for="item in row.parkBookList" :key="item.id" style="display: block"> - <span :style="(item.hkStatus== 0?'color:#2080f7':(item.hkStatus== 1?'color:green':(item.hkStatus== 2?'color:red':'')))">銆恵{item.hkStatus== 0?'绛夊緟涓嬪彂':(item.hkStatus== 1?'涓嬪彂鎴愬姛':(item.hkStatus== 2?'涓嬪彂澶辫触':''))}}銆� </span>{{item.parksName}} - </span> - </div> - <span v-if="row.parkBookList ==null ||row.parkBookList.length ==0">-</span> - </template> - </el-table-column> - <el-table-column label="涓嬪彂鏈夋晥鏈�" align="center" min-width="170px"> - <template slot-scope="{row}"> - <div v-if="row.authStatus !=null && row.authStatus == 1 && row.parkBookList!=null && row.parkBookList.length>0"> - <div v-if="!row.startTime || !row.endTime">闀挎湡鏈夋晥</div> - <div v-else> - <span style="color: green">璧凤細{{row.startTime}}</span><br/> - <span style="color: red">姝細{{row.endTime}}</span> - </div> - </div> - <div v-else >-</div> - </template> - </el-table-column> - <el-table-column prop="editorName" label="鎿嶄綔浜�" min-width="100px"></el-table-column> - <el-table-column prop="editDate" label="鎿嶄綔鏃堕棿" min-width="140px"></el-table-column> - <el-table-column - v-if="containPermissions(['business:member:update', 'business:member:delete','business:empower:create'])" - label="鎿嶄綔" - min-width="200" - align="center" - fixed="right" - > - <template slot-scope="{row}"> - <el-button type="text" icon="el-icon-edit" @click="$refs.operaCarsWindow.open('缂栬緫杞﹁締淇℃伅',row)" v-permissions="['business:cars:update']">缂栬緫</el-button> - <el-button type="text" icon="el-icon-edit" @click="$refs.operaCarAuthWindow.open('涓嬪彂鎺堟潈',[row.id],[row.code])" v-permissions="['business:parkbook:create']">涓嬪彂鎺堟潈</el-button> - <el-button type="text" icon="el-icon-delete" @click="deleteById(row)" style="color: red" v-permissions="['business:empower:delete']">鍒犻櫎</el-button> - </template> - </el-table-column> - </el-table> - <pagination - @size-change="handleSizeChange" - @current-change="handlePageChange" - :pagination="tableData.pagination" - > - </pagination> - </template> - <!-- 鏂板缓/淇敼 --> - <OperaCarAuthWindow ref="operaCarAuthWindow" @success="handlePageChange"/> - <OperaCarsWindow ref="operaCarsWindow" @success="handlePageChange"/> - </TableLayout> + </el-form-item> +<!-- <el-form-item label="" prop="type" title="涓氬姟绫诲瀷"> + <el-select v-model="searchForm.type" @change="search" clearable 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> + </section> + </el-form> + </div> + + <!-- 琛ㄦ牸鍜屽垎椤� --> + <template v-slot:table-wrap> + <ul class="toolbar" + v-permissions="['business:cars:create', 'business:cars:exportExcel', 'business:parkBook:create']"> + <li><el-button type="primary" @click="handleEdit" icon="el-icon-plus" + v-permissions="['business:cars:create']">鏂板缓</el-button></li> + <li><el-button type="primary" @click="$refs.OperaCarsImportWindowRef.open('杞﹁締瀵煎叆', searchForm.companyType)" + v-permissions="['business:cars:create']">杞﹁締瀵煎叆</el-button> + </li> + <li><el-button type="primary" @click="exportExcel" v-permissions="['business:cars:exportExcel']">瀵煎嚭</el-button> + </li> + <li><el-button type="primary" @click="startEmpowerBatch" icon="el-icon-plus" + v-permissions="['business:parkbook:create']">涓嬪彂鎺堟潈</el-button></li> + </ul> + <el-table :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="code" label="杞︾墝鍙�" fixed="left" min-width="100px"></el-table-column> + <el-table-column prop="memberName" label="杞︿富濮撳悕" min-width="100px"></el-table-column> + <el-table-column prop="memberPhone" label="杞︿富鎵嬫満鍙�" min-width="100px"></el-table-column> + <el-table-column prop="catePName" label="涓�绾у垎绫�" min-width="120px"></el-table-column> + <el-table-column prop="cateName" label="浜岀骇鍒嗙被" min-width="120px"></el-table-column> + <el-table-column prop="companyName" label="杞︿富缁勭粐" min-width="200px"></el-table-column> + <el-table-column label="鏄惁鎺堟潈" align="center" min-width="100px"> + <template slot-scope="{row}"> + <span v-if="row.authStatus == 1" style="color: green">鏄�</span> + <span v-else style="color: red">鍚�</span> + </template> + </el-table-column> + <el-table-column prop="parksName" align="center" label="宸叉巿鏉冨仠杞﹀満" min-width="200px"> + <template slot-scope="{row}"> + <div v-if="row.parkBookList && row.parkBookList.length"> + <span v-for="item in row.parkBookList" :key="item.id" style="display: block"> + <span + :style="(item.hkStatus == 0 ? 'color:#2080f7' : (item.hkStatus == 1 ? 'color:green' : (item.hkStatus == 2 ? 'color:red' : '')))">銆恵{ + item.hkStatus == + 0 ? '绛夊緟涓嬪彂' : (item.hkStatus == 1 ? '涓嬪彂鎴愬姛' : (item.hkStatus == 2 ? '涓嬪彂澶辫触' : '')) }}銆� </span>{{ + item.parksName }} + </span> + </div> + <span v-if="row.parkBookList == null || row.parkBookList.length == 0">-</span> + </template> + </el-table-column> + <el-table-column label="涓嬪彂鏈夋晥鏈�" align="center" min-width="170px"> + <template slot-scope="{row}"> + <div + v-if="row.authStatus != null && row.authStatus == 1 && row.parkBookList != null && row.parkBookList.length > 0"> + <div v-if="!row.startTime || !row.endTime">闀挎湡鏈夋晥</div> + <div v-else> + <span style="color: green">璧凤細{{ row.startTime }}</span><br /> + <span style="color: red">姝細{{ row.endTime }}</span> + </div> + </div> + <div v-else>-</div> + </template> + </el-table-column> +<!-- <el-table-column label="澶囨敞" min-width="120px"> + <template slot-scope="{row}"> + <span v-if="row.type == 0">瀹夋嘲鍏姟杞�</span> + <span v-if="row.type == 1">瀹夋嘲鑷湁鐗╂祦杞�</span> + <span v-if="row.type == 2">鍏朵粬</span> + </template> + </el-table-column>--> + <el-table-column prop="editorName" label="鎿嶄綔浜�" min-width="100px"></el-table-column> + <el-table-column prop="editDate" label="鎿嶄綔鏃堕棿" min-width="140px"></el-table-column> + <el-table-column + v-if="containPermissions(['business:member:update', 'business:member:delete', 'business:empower:create'])" + label="鎿嶄綔" min-width="200" align="center"> + <template slot-scope="{row}"> + <el-button type="text" icon="el-icon-edit" @click="handleEdit(row)" + v-permissions="['business:cars:update']">缂栬緫</el-button> + <el-button type="text" icon="el-icon-edit" + @click="$refs.operaCarAuthWindow.open('涓嬪彂鎺堟潈', [row.id], [row.code])" + v-permissions="['business:parkbook:create']">涓嬪彂鎺堟潈</el-button> + <el-button type="text" icon="el-icon-delete" @click="deleteById(row)" style="color: red" + v-permissions="['business:empower:delete']">鍒犻櫎</el-button> + </template> + </el-table-column> + </el-table> + <pagination @size-change="handleSizeChange" @current-change="handlePageChange" :pagination="tableData.pagination"> + </pagination> + </template> + <!-- 鏂板缓/淇敼 --> + <OperaCarAuthWindow ref="operaCarAuthWindow" @success="handlePageChange" /> + <OperaCarsImportWindow ref="OperaCarsImportWindowRef" @success="handlePageChange" /> + <OperaCarsWindow v-if="isShowEdit" ref="operaCarsWindow" @close="isShowEdit = false" @success="handlePageChange" /> + </TableLayout> </template> <script> @@ -116,24 +138,32 @@ import Pagination from '@/components/common/Pagination' import OperaCarsWindow from '@/components/business/OperaCarsWindow' import OperaCarAuthWindow from '@/components/business/OperaCarAuthWindow' -import { sync } from '@/api/business/cars' +import OperaCarsImportWindow from './components/OperaCarsImportWindow' +import { fetchList } from '@/api/business/category.js' export default { name: 'Cars', extends: BaseTable, - components: { TableLayout, Pagination, OperaCarsWindow,OperaCarAuthWindow }, - data () { + components: { TableLayout, Pagination, OperaCarsWindow, OperaCarAuthWindow, OperaCarsImportWindow }, + data() { return { // 鎼滅储 searchForm: { code: '', memberName: '', companyName: '', - type:null, - authStatus:null - } + cateIds: [], + catePId: '', + cateId: '', + type: null, + authStatus: null, + ids: '' + }, + isShowEdit: false, + cateList: [], + selIdsList: [] } }, - created () { + created() { this.config({ module: '杞﹁締淇℃伅琛�', api: '/business/cars', @@ -141,10 +171,58 @@ 'field.main': 'id' }) this.search() + this.getCate() + }, + mounted() { + this.$nextTick(() => { + this.tableHeight = document.body.scrollHeight - this.$refs.QueryFormRef.offsetHeight - 300 + }) }, methods: { + // handleSelectionChange(e) { + // this.searchForm.ids = e.map(i => i.id).join(',') + // }, + changeSel(e) { + console.log(e) + if (e && e.length == 1) { + this.$set(this.searchForm, 'catePId', e[0]) + this.$set(this.searchForm, 'cateId', '') + } else if (e && e.length == 2) { + this.$set(this.searchForm, 'catePId', e[0]) + this.$set(this.searchForm, 'cateId', e[1]) + } else { + this.$set(this.searchForm, 'catePId', '') + this.$set(this.searchForm, 'cateId', '') + } + this.search() + }, + getCate() { + fetchList({ + model: {type:1}, + capacity: 1000, + page: 1, + }).then(res => { + this.cateList = res.records || [] + + }) + }, + handleEdit(row) { + this.isShowEdit = true + let str = row && row.id ? '缂栬緫杞﹁締' : '鏂板缓杞﹁締' + this.$nextTick(() => { + this.$refs.operaCarsWindow.open(str, row) + if (row && row.id) { + // let form = { ...row, cateId: [] } + let form = { ...row } + // if (row.catePId) { form.cateId.push(row.catePId) } + // if (row.cateId) { form.cateId.push(row.cateId) } + this.$refs.operaCarsWindow.form = form + this.$refs.operaCarsWindow.loadMember() + } + }) + }, // 鍚屾淇℃伅 - startEmpowerBatch () { + startEmpowerBatch() { if (this.tableData.selectedRows.length === 0) { this.$tip.warning('璇疯嚦灏戦�夋嫨涓�鏉℃暟鎹�') return -- Gitblit v1.9.3