chore(config): 添加项目配置文件和隐私协议

- 新增 .editorconfig 文件统一代码风格配置
- 新增 .env 环境变量配置文件
- 添加开发和生产环境的环境变量配置
- 配置 ESLint 忽略规则文件
- 设置代码检查配置文件 .eslintrc.js
- 添加 Git 忽略文件规则
- 创建 Prettier 格式化忽略规则
- 添加隐私政策和服务协议HTML文件
- 实现访问密钥编辑组件基础结构
This commit is contained in:
2026-02-07 16:33:13 +08:00
commit 92a6a32868
1384 changed files with 224513 additions and 0 deletions

67
src/router/index.ts Normal file
View File

@@ -0,0 +1,67 @@
/**
* 路由配置
*/
import NProgress from 'nprogress';
import type { _RouteLocationBase } from 'vue-router';
import { createRouter, createWebHistory } from 'vue-router';
import { WHITE_LIST, REDIRECT_PATH, LAYOUT_PATH } from '@/config/setting';
import { useUserStore } from '@/store/modules/user';
import { getToken } from '@/utils/token-util';
import { routes, getMenuRoutes } from './routes';
// import { useTenantStore } from '@/store/modules/tenant';
NProgress.configure({
speed: 200,
minimum: 0.02,
trickleSpeed: 200,
showSpinner: false
});
const router = createRouter({
routes,
history: createWebHistory(),
scrollBehavior() {
return { top: 0 };
}
});
/**
* 路由守卫
*/
router.beforeEach(async (to, from) => {
if (!from.path.includes(REDIRECT_PATH)) {
NProgress.start();
}
// 租户信息
// const tenantStore = useTenantStore();
// await tenantStore.fetchTenantInfo();
if (!getToken()) {
// 未登录跳转登录界面
if (!WHITE_LIST.includes(to.path)) {
return {
path: '/login',
query: to.path === LAYOUT_PATH ? {} : { from: to.path }
};
}
return;
}
// 注册动态路由
const userStore = useUserStore();
if (!userStore.menus) {
const { menus, homePath } = await userStore.fetchUserInfo();
if (menus) {
router.addRoute(getMenuRoutes(menus, homePath));
return { ...to, replace: true };
}
}
});
router.afterEach((to) => {
if (!to.path.includes(REDIRECT_PATH) && NProgress.isStarted()) {
setTimeout(() => {
NProgress.done(true);
}, 200);
}
});
export default router;

98
src/router/routes.ts Normal file
View File

@@ -0,0 +1,98 @@
import type { RouteRecordRaw } from 'vue-router';
import type { MenuItemType } from 'ele-admin-pro/es';
import { menuToRoutes, eachTreeData } from 'ele-admin-pro/es';
import { HOME_PATH, LAYOUT_PATH, REDIRECT_PATH } from '@/config/setting';
import EleLayout from '@/layout/index.vue';
import RedirectLayout from '@/components/RedirectLayout';
const modules = import.meta.glob('/src/views/**/index.vue');
/**
* 静态路由
*/
export const routes = [
{
path: '/login',
component: () => import('@/views/passport/login/index.vue'),
meta: { title: '登录' }
},
{
path: '/token-login',
component: () => import('@/views/passport/loginToken/index.vue'),
meta: { title: 'token登录' }
},
{
path: '/register',
component: () => import('@/views/passport/register/index.vue'),
meta: { title: '注册' }
},
// {
// path: '/forget',
// component: () => import('@/views/passport/forget/index.vue'),
// meta: { title: '忘记密码' }
// },
// {
// path: '/wx-work-login',
// component: () => import('@/views/passport/wx-work/index.vue'),
// meta: { title: '企业微信登录' }
// },
// {
// path: '/token-login',
// component: () => import('@/views/passport/token-login/index.vue'),
// meta: { title: '快捷登录' }
// },
// {
// path: '/cms/category/:id',
// component: () => import('@/views/cms/category/preview/index.vue'),
// meta: { title: '文章列表' }
// },
// {
// path: '/cms/article/:id',
// component: () => import('@/views/cms/article/preview/index.vue'),
// meta: { title: '文章详情' }
// },
// 404
{
path: '/:path(.*)*',
component: () => import('@/views/result/fail/index.vue')
}
];
/**
* 动态路由
* @param menus 菜单数据
* @param homePath 主页地址
*/
export function getMenuRoutes(menus?: MenuItemType[], homePath?: string) {
const routes: RouteRecordRaw[] = [
// 用于刷新的路由
{
path: REDIRECT_PATH + '/:path(.*)',
component: RedirectLayout,
meta: { hideFooter: true }
}
];
// 路由铺平处理
eachTreeData(menuToRoutes(menus, getComponent), (route) => {
routes.push(Object.assign({}, route, { children: void 0 }));
});
return {
path: LAYOUT_PATH,
component: EleLayout,
redirect: HOME_PATH ?? homePath,
children: routes
};
}
/**
* 解析路由组件
* @param component 组件名称
*/
function getComponent(component?: string) {
if (component) {
const module = modules[`/src/views/${component}.vue`];
if (!module) {
return modules[`/src/views/${component}/index.vue`];
}
return module;
}
}