From cab914c578ca850a0010864f0c10c7a7da916d45 Mon Sep 17 00:00:00 2001 From: nidapeng <jp@doumee.com> Date: 星期一, 06 五月 2024 16:06:57 +0800 Subject: [PATCH] 最新版本 --- admin/src/views/business/internalCompany.vue | 87 ++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 80 insertions(+), 7 deletions(-) diff --git a/admin/src/views/business/internalCompany.vue b/admin/src/views/business/internalCompany.vue index 141cb20..b34143c 100644 --- a/admin/src/views/business/internalCompany.vue +++ b/admin/src/views/business/internalCompany.vue @@ -18,18 +18,18 @@ <template v-slot:table-wrap> <ul class="toolbar" v-permissions="['business:company:create', 'business:company:sync']"> <li><el-button type="primary" v-permissions="['business:company:create']" @click="$refs.OperaInternalCompanyWindow.open('鏂板缓浼佷笟',null,null)">鏂板缓</el-button></li> - <li><el-button @click="sort('top')" :loading="isWorking.sort" icon="el-icon-sort-up" v-permissions="['business:company:sort']">涓婄Щ</el-button></li> - <li><el-button @click="sort('bottom')" :loading="isWorking.sort" icon="el-icon-sort-down" v-permissions="['business:company:sort']">涓嬬Щ</el-button></li> + <li><el-button @click="sort('top')" :loading="sorting" icon="el-icon-sort-up" v-permissions="['business:company:sort']">涓婄Щ</el-button></li> + <li><el-button @click="sort('bottom')" :loading="sorting" icon="el-icon-sort-down" v-permissions="['business:company:sort']">涓嬬Щ</el-button></li> <!--<li><el-button type="primary" v-permissions="['business:company:sync']" :loading="loading" @click="synchronous()">鍚屾</el-button></li>--> </ul> <el-table v-loading="isWorking.search" :data="list" stripe - :tree-props="{children: 'childList'}" + :tree-props="{children: 'childList',hasChildren: 'hasChildren'}" row-key="id" - :expand-row-keys="[list && list.length > 0 ? list[0].id.toString() : '']" @selection-change="handleSelectionChange" + default-expand-all > <el-table-column type="selection" width="55"></el-table-column> <el-table-column prop="name" label="缁勭粐鍚嶇О" min-width="100px"></el-table-column> @@ -63,7 +63,7 @@ <script> import BaseTable from '@/components/base/BaseTable' import TableLayout from '@/layouts/TableLayout' -import { companySync } from '@/api/business/company' +import { companySync, sort } from '@/api/business/company' import OperaInternalCompanyWindow from '@/components/business/OperaInternalCompanyWindow' export default { name: 'internalCompany', @@ -72,7 +72,8 @@ data () { return { // 鎼滅储 - loading:false, + loading: false, + sorting: false, searchForm: { // type: 1 }, @@ -123,7 +124,79 @@ }) }) .catch(() => {}) - } + }, + // 鎺掑簭 + sort (direction) { + if (this.sorting) { + return + } + if (this.tableData.selectedRows.length === 0) { + this.$tip.warning('璇烽�夋嫨涓�鏉℃暟鎹�') + return + } + if (this.tableData.selectedRows.length > 1) { + this.$tip.warning('鎺掑簭鏃朵粎鍏佽閫夋嫨涓�鏉℃暟鎹�') + return + } + const menuId = this.tableData.selectedRows[0].id + // 鎵惧埌鑿滃崟鑼冨洿 + let menuPool + for (const rootMenu of this.list) { + console.log(this.list) + const parent = this.__findParent(menuId, rootMenu) + if (parent != null) { + menuPool = parent.children + } + } + menuPool = menuPool || this.list + const menuIndex = menuPool.findIndex(menu => menu.id === menuId) + // 涓婄Щ鏍¢獙 + if (direction === 'top' && menuIndex === 0) { + this.$tip.warning('鑿滃崟宸插埌椤堕儴') + return + } + // 涓嬬Щ鏍¢獙 + if (direction === 'bottom' && menuIndex === menuPool.length - 1) { + this.$tip.warning('鑿滃崟宸插埌搴曢儴') + return + } + this.sorting = true + sort({ + id: this.tableData.selectedRows[0].id, + direction + }) + .then(() => { + if (direction === 'top') { + menuPool.splice(menuIndex, 0, menuPool.splice(menuIndex - 1, 1)[0]) + } else { + menuPool.splice(menuIndex, 0, menuPool.splice(menuIndex + 1, 1)[0]) + } + }) + .catch(e => { + this.$tip.apiFailed(e) + }) + .finally(() => { + this.sorting = false + }) + }, + // 鏌ヨ鐖惰妭鐐� + __findParent (id, parent) { + if (parent.childList === 0) { + return + } + for (const menu of parent.childList) { + if (menu.id === id) { + return parent + } + if (menu.childList.length > 0) { + const m = this.__findParent(id, menu) + if (m != null) { + return m + } + } + } + return null + }, } } </script> -- Gitblit v1.9.3