新增tab对象简化页签操作
This commit is contained in:
parent
e41dd8a0f1
commit
d1eacc1d1c
@ -152,31 +152,24 @@ export default {
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
refreshSelectedTag(view) {
|
refreshSelectedTag(view) {
|
||||||
this.$store.dispatch('tagsView/delCachedView', view).then(() => {
|
this.$tab.refreshPage(view);
|
||||||
const { fullPath } = view
|
|
||||||
this.$nextTick(() => {
|
|
||||||
this.$router.replace({
|
|
||||||
path: '/redirect' + fullPath
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
},
|
},
|
||||||
closeSelectedTag(view) {
|
closeSelectedTag(view) {
|
||||||
this.$store.dispatch('tagsView/delView', view).then(({ visitedViews }) => {
|
this.$tab.closePage(view).then(({ visitedViews }) => {
|
||||||
if (this.isActive(view)) {
|
if (this.isActive(view)) {
|
||||||
this.toLastView(visitedViews, view)
|
this.toLastView(visitedViews, view)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
closeRightTags() {
|
closeRightTags() {
|
||||||
this.$store.dispatch('tagsView/delRightTags', this.selectedTag).then(visitedViews => {
|
this.$tab.closeRightPage(this.selectedTag).then(visitedViews => {
|
||||||
if (!visitedViews.find(i => i.fullPath === this.$route.fullPath)) {
|
if (!visitedViews.find(i => i.fullPath === this.$route.fullPath)) {
|
||||||
this.toLastView(visitedViews)
|
this.toLastView(visitedViews)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
closeLeftTags() {
|
closeLeftTags() {
|
||||||
this.$store.dispatch('tagsView/delLeftTags', this.selectedTag).then(visitedViews => {
|
this.$tab.closeLeftPage(this.selectedTag).then(visitedViews => {
|
||||||
if (!visitedViews.find(i => i.fullPath === this.$route.fullPath)) {
|
if (!visitedViews.find(i => i.fullPath === this.$route.fullPath)) {
|
||||||
this.toLastView(visitedViews)
|
this.toLastView(visitedViews)
|
||||||
}
|
}
|
||||||
@ -184,12 +177,12 @@ export default {
|
|||||||
},
|
},
|
||||||
closeOthersTags() {
|
closeOthersTags() {
|
||||||
this.$router.push(this.selectedTag).catch(()=>{});
|
this.$router.push(this.selectedTag).catch(()=>{});
|
||||||
this.$store.dispatch('tagsView/delOthersViews', this.selectedTag).then(() => {
|
this.$tab.closeOtherPage(this.selectedTag).then(() => {
|
||||||
this.moveToCurrentTag()
|
this.moveToCurrentTag()
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
closeAllTags(view) {
|
closeAllTags(view) {
|
||||||
this.$store.dispatch('tagsView/delAllViews').then(({ visitedViews }) => {
|
this.$tab.closeAllPage().then(({ visitedViews }) => {
|
||||||
if (this.affixTags.some(tag => tag.path === this.$route.path)) {
|
if (this.affixTags.some(tag => tag.path === this.$route.path)) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import tab from './tab'
|
||||||
import auth from './auth'
|
import auth from './auth'
|
||||||
import cache from './cache'
|
import cache from './cache'
|
||||||
import modal from './modal'
|
import modal from './modal'
|
||||||
@ -5,6 +6,8 @@ import download from './download'
|
|||||||
|
|
||||||
export default {
|
export default {
|
||||||
install(Vue) {
|
install(Vue) {
|
||||||
|
// 页签操作
|
||||||
|
Vue.prototype.$tab = tab
|
||||||
// 认证对象
|
// 认证对象
|
||||||
Vue.prototype.$auth = auth
|
Vue.prototype.$auth = auth
|
||||||
// 缓存对象
|
// 缓存对象
|
||||||
|
68
ruoyi-ui/src/plugins/tab.js
Normal file
68
ruoyi-ui/src/plugins/tab.js
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
import store from '@/store'
|
||||||
|
import router from '@/router';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
// 刷新当前tab页签
|
||||||
|
refreshPage(obj) {
|
||||||
|
const { path, matched } = router.currentRoute;
|
||||||
|
if (obj === undefined) {
|
||||||
|
matched.forEach((m) => {
|
||||||
|
if (m.components && m.components.default && m.components.default.name) {
|
||||||
|
if (!['Layout', 'ParentView'].includes(m.components.default.name)) {
|
||||||
|
obj = { name: m.components.default.name, path: path };
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return store.dispatch('tagsView/delCachedView', obj).then(() => {
|
||||||
|
const { path } = obj
|
||||||
|
router.replace({
|
||||||
|
path: '/redirect' + path
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
},
|
||||||
|
// 关闭当前tab页签,打开新页签
|
||||||
|
closeOpenPage(obj) {
|
||||||
|
store.dispatch("tagsView/delView", router.currentRoute);
|
||||||
|
if (obj !== undefined) {
|
||||||
|
return router.push(obj);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 关闭指定tab页签
|
||||||
|
closePage(obj) {
|
||||||
|
if (obj === undefined) {
|
||||||
|
return store.dispatch('tagsView/delView', router.currentRoute).then(({ lastPath }) => {
|
||||||
|
return router.push(lastPath || '/');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return store.dispatch('tagsView/delView', obj);
|
||||||
|
},
|
||||||
|
// 关闭所有tab页签
|
||||||
|
closeAllPage() {
|
||||||
|
return store.dispatch('tagsView/delAllViews');
|
||||||
|
},
|
||||||
|
// 关闭左侧tab页签
|
||||||
|
closeLeftPage(obj) {
|
||||||
|
return store.dispatch('tagsView/delLeftTags', obj || router.currentRoute);
|
||||||
|
},
|
||||||
|
// 关闭右侧tab页签
|
||||||
|
closeRightPage(obj) {
|
||||||
|
return store.dispatch('tagsView/delRightTags', obj || router.currentRoute);
|
||||||
|
},
|
||||||
|
// 关闭其他tab页签
|
||||||
|
closeOtherPage(obj) {
|
||||||
|
return store.dispatch('tagsView/delOthersViews', obj || router.currentRoute);
|
||||||
|
},
|
||||||
|
// 添加tab页签
|
||||||
|
addPage(title, url) {
|
||||||
|
var obj = { path: url, meta: { title: title } }
|
||||||
|
store.dispatch('tagsView/addView', obj);
|
||||||
|
return router.push(url);
|
||||||
|
},
|
||||||
|
// 修改tab页签
|
||||||
|
updatePage(obj) {
|
||||||
|
return store.dispatch('tagsView/updateVisitedView', obj);
|
||||||
|
}
|
||||||
|
}
|
@ -14,7 +14,7 @@ const mutations = {
|
|||||||
},
|
},
|
||||||
ADD_CACHED_VIEW: (state, view) => {
|
ADD_CACHED_VIEW: (state, view) => {
|
||||||
if (state.cachedViews.includes(view.name)) return
|
if (state.cachedViews.includes(view.name)) return
|
||||||
if (!view.meta.noCache) {
|
if (view.meta && !view.meta.noCache) {
|
||||||
state.cachedViews.push(view.name)
|
state.cachedViews.push(view.name)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -245,8 +245,8 @@ export default {
|
|||||||
},
|
},
|
||||||
// 返回按钮
|
// 返回按钮
|
||||||
handleClose() {
|
handleClose() {
|
||||||
this.$store.dispatch("tagsView/delView", this.$route);
|
const obj = { path: "/monitor/job" };
|
||||||
this.$router.push({ path: "/monitor/job" });
|
this.$tab.closeOpenPage(obj);
|
||||||
},
|
},
|
||||||
/** 搜索按钮操作 */
|
/** 搜索按钮操作 */
|
||||||
handleQuery() {
|
handleQuery() {
|
||||||
|
@ -79,6 +79,15 @@
|
|||||||
v-hasPermi="['system:dict:export']"
|
v-hasPermi="['system:dict:export']"
|
||||||
>导出</el-button>
|
>导出</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
|
<el-col :span="1.5">
|
||||||
|
<el-button
|
||||||
|
type="warning"
|
||||||
|
plain
|
||||||
|
icon="el-icon-close"
|
||||||
|
size="mini"
|
||||||
|
@click="handleClose"
|
||||||
|
>关闭</el-button>
|
||||||
|
</el-col>
|
||||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
@ -316,6 +325,11 @@ export default {
|
|||||||
this.queryParams.pageNum = 1;
|
this.queryParams.pageNum = 1;
|
||||||
this.getList();
|
this.getList();
|
||||||
},
|
},
|
||||||
|
// 返回按钮
|
||||||
|
handleClose() {
|
||||||
|
const obj = { path: "/system/dict" };
|
||||||
|
this.$tab.closeOpenPage(obj);
|
||||||
|
},
|
||||||
/** 重置按钮操作 */
|
/** 重置按钮操作 */
|
||||||
resetQuery() {
|
resetQuery() {
|
||||||
this.resetForm("queryForm");
|
this.resetForm("queryForm");
|
||||||
|
@ -153,8 +153,8 @@ export default {
|
|||||||
},
|
},
|
||||||
// 返回按钮
|
// 返回按钮
|
||||||
handleClose() {
|
handleClose() {
|
||||||
this.$store.dispatch("tagsView/delView", this.$route);
|
const obj = { path: "/system/role" };
|
||||||
this.$router.push({ path: "/system/role" });
|
this.$tab.closeOpenPage(obj);
|
||||||
},
|
},
|
||||||
/** 搜索按钮操作 */
|
/** 搜索按钮操作 */
|
||||||
handleQuery() {
|
handleQuery() {
|
||||||
|
@ -109,8 +109,8 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 关闭按钮 */
|
/** 关闭按钮 */
|
||||||
close() {
|
close() {
|
||||||
this.$store.dispatch("tagsView/delView", this.$route);
|
const obj = { path: "/system/user" };
|
||||||
this.$router.push({ path: "/system/user" });
|
this.$tab.closeOpenPage(obj);
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -64,8 +64,7 @@ export default {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
close() {
|
close() {
|
||||||
this.$store.dispatch("tagsView/delView", this.$route);
|
this.$tab.closePage();
|
||||||
this.$router.push({ path: "/index" });
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -68,8 +68,7 @@ export default {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
close() {
|
close() {
|
||||||
this.$store.dispatch("tagsView/delView", this.$route);
|
this.$tab.closePage();
|
||||||
this.$router.push({ path: "/index" });
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -211,8 +211,8 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 关闭按钮 */
|
/** 关闭按钮 */
|
||||||
close() {
|
close() {
|
||||||
this.$store.dispatch("tagsView/delView", this.$route);
|
const obj = { path: "/tool/gen", query: { t: Date.now(), pageNum: this.$route.query.pageNum } };
|
||||||
this.$router.push({ path: "/tool/gen", query: { t: Date.now(), pageNum: this.$route.query.pageNum } })
|
this.$tab.closeOpenPage(obj);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user