feat(demo): add route multi tabs show

添加同一路由演示多个不同参数的tab

close: #817
This commit is contained in:
无木 2021-06-26 21:25:11 +08:00
parent 61d4efd55a
commit 0e414ba3c1
5 changed files with 91 additions and 3 deletions

View File

@ -163,7 +163,7 @@ export default {
moduleName: 'System management',
account: 'Account management',
account_detail: 'Account detail',
password: 'Change password',
dept: 'Department management',

View File

@ -157,6 +157,7 @@ export default {
system: {
moduleName: '系统管理',
account: '账号管理',
account_detail: '账号详情',
password: '修改密码',
dept: '部门管理',
menu: '菜单管理',

View File

@ -18,10 +18,21 @@ const system: AppRouteModule = {
name: 'AccountManagement',
meta: {
title: t('routes.demo.system.account'),
ignoreKeepAlive: true,
ignoreKeepAlive: false,
},
component: () => import('/@/views/demo/system/account/index.vue'),
},
{
path: 'account_detail/:id',
name: 'AccountDetail',
meta: {
title: t('routes.demo.system.account_detail'),
ignoreKeepAlive: true,
showMenu: false,
currentActiveMenu: '/system/account',
},
component: () => import('/@/views/demo/system/account/AccountDetail.vue'),
},
{
path: 'role',
name: 'RoleManagement',

View File

@ -0,0 +1,62 @@
<template>
<PageWrapper
:title="`用户` + userId + `的资料`"
content="这是用户资料详情页面。本页面仅用于演示相同路由在tab中打开多个页面并且显示不同的数据"
contentBackground
@back="goBack"
>
<template #extra>
<a-button type="danger"> 禁用账号 </a-button>
<a-button type="primary"> 修改密码 </a-button>
</template>
<template #footer>
<a-tabs default-active-key="detail" v-model:activeKey="currentKey">
<a-tab-pane key="detail" tab="用户资料" />
<a-tab-pane key="logs" tab="操作日志" />
</a-tabs>
</template>
<div class="pt-4 m-4 desc-wrap">
<template v-if="currentKey == 'detail'">
<div v-for="i in 10" :key="i">这是用户{{ userId }}资料Tab</div>
</template>
<template v-if="currentKey == 'logs'">
<div v-for="i in 10" :key="i">这是用户{{ userId }}操作日志Tab</div>
</template>
</div>
</PageWrapper>
</template>
<script>
import { defineComponent, ref } from 'vue';
import { useRoute } from 'vue-router';
import { PageWrapper } from '/@/components/Page';
import { useGo } from '/@/hooks/web/usePage';
import { useTabs } from '/@/hooks/web/useTabs';
import { Tabs } from 'ant-design-vue';
export default defineComponent({
name: 'AccountDetail',
components: { PageWrapper, ATabs: Tabs, ATabPane: Tabs.TabPane },
setup() {
const route = useRoute();
const go = useGo();
// ID
const userId = ref(route.params?.id);
const currentKey = ref('detail');
const { setTitle } = useTabs();
// TODO
// userId
// Tab
setTitle('详情:用户' + userId.value);
//
function goBack() {
//
go('/system/account');
}
return { userId, currentKey, goBack };
},
});
</script>
<style></style>

View File

@ -8,13 +8,20 @@
<template #action="{ record }">
<TableAction
:actions="[
{
icon: 'clarity:eye-show-solid',
title: '查看用户详情',
onClick: handleView.bind(null, record),
},
{
icon: 'clarity:note-edit-line',
title: '编辑用户资料',
onClick: handleEdit.bind(null, record),
},
{
icon: 'ant-design:delete-outlined',
color: 'error',
title: '删除此账号',
popConfirm: {
title: '是否确认删除',
confirm: handleDelete.bind(null, record),
@ -39,11 +46,13 @@
import AccountModal from './AccountModal.vue';
import { columns, searchFormSchema } from './account.data';
import { useGo } from '/@/hooks/web/usePage';
export default defineComponent({
name: 'AccountManagement',
components: { BasicTable, PageWrapper, DeptTree, AccountModal, TableAction },
setup() {
const go = useGo();
const [registerModal, { openModal }] = useModal();
const [registerTable, { reload, updateTableDataRecord }] = useTable({
title: '账号列表',
@ -58,7 +67,7 @@
showTableSetting: true,
bordered: true,
actionColumn: {
width: 80,
width: 120,
title: '操作',
dataIndex: 'action',
slots: { customRender: 'action' },
@ -98,6 +107,10 @@
reload({ searchInfo: { deptId } });
}
function handleView(record: Recordable) {
go('/system/account_detail/' + record.id);
}
return {
registerTable,
registerModal,
@ -106,6 +119,7 @@
handleDelete,
handleSuccess,
handleSelect,
handleView,
};
},
});