123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- <script lang="ts" setup>
- import type { LoginAndRegisterParams } from '@vben/universal-ui';
- import { useRouter } from 'vue-router';
- import { useAccess } from '@vben/access';
- import { Button } from 'ant-design-vue';
- import { useAccessStore, useAppStore } from '#/store';
- defineOptions({ name: 'AccessBackend' });
- const { accessMode } = useAccess();
- const accessStore = useAccessStore();
- const appStore = useAppStore();
- const router = useRouter();
- function roleButtonType(role: string) {
- return accessStore.userRoles.includes(role) ? 'primary' : 'default';
- }
- async function changeAccount(role: string) {
- if (accessStore.userRoles.includes(role)) {
- return;
- }
- const accounts: Record<string, LoginAndRegisterParams> = {
- admin: {
- password: '123456',
- username: 'admin',
- },
- super: {
- password: '123456',
- username: 'vben',
- },
- user: {
- password: '123456',
- username: 'jack',
- },
- };
- const account = accounts[role];
- await appStore.resetAppState();
- await accessStore.authLogin(account, async () => {
- router.go(0);
- });
- }
- </script>
- <template>
- <div class="p-5">
- <div class="card-box p-5">
- <h1 class="text-xl font-semibold">前端页面访问权限演示</h1>
- <div class="text-foreground/80 mt-2">
- 切换不同的账号,观察左侧菜单变化。
- </div>
- </div>
- <template v-if="accessMode === 'frontend'">
- <div class="card-box mt-5 p-5 font-semibold">
- <div class="mb-3">
- <span class="text-lg">当前账号:</span>
- <span class="text-primary mx-4">
- {{ accessStore.userRoles }}
- </span>
- </div>
- <Button :type="roleButtonType('super')" @click="changeAccount('super')">
- 切换为 Super 账号
- </Button>
- <Button
- :type="roleButtonType('admin')"
- class="mx-4"
- @click="changeAccount('admin')"
- >
- 切换为 Admin 账号
- </Button>
- <Button :type="roleButtonType('user')" @click="changeAccount('user')">
- 切换为 User 账号
- </Button>
- </div>
- </template>
- </div>
- </template>
|