tydata-webview/src/router/index.js
2025-03-07 04:09:24 +08:00

284 lines
11 KiB
JavaScript

import { createRouter, createWebHistory } from "vue-router";
import NProgress from "nprogress";
import GlobalLayout from "@/layouts/GlobalLayout.vue";
import HomeLayout from "@/layouts/HomeLayout.vue";
import PageLayout from "@/layouts/PageLayout.vue";
import index from "@/views/index.vue";
import { useAgentStore } from "@/stores/agentStore";
import { storeToRefs } from "pinia";
const router = createRouter({
history: createWebHistory(import.meta.env.BASE_URL),
routes: [
{
path: "/",
component: GlobalLayout, // 使用 Layout 作为父组件
children: [
{
path: "",
component: HomeLayout, // 使用 Layout 作为父组件
children: [
{
path: "",
name: "index",
component: index,
},
{
path: "ai",
name: "ai",
component: () => import("@/views/Ai.vue"),
},
{
path: "agent",
name: "agent",
component: () => import("@/views/Agent.vue"),
},
{
path: "me",
name: "me",
component: () => import("@/views/Me.vue"),
},
],
},
{
path: "",
component: PageLayout,
children: [
{
path: "/historyQuery",
name: "history",
component: () => import("@/views/HistoryQuery.vue"),
meta: { title: "历史报告", requiresAuth: true },
},
{
path: "/help",
name: "help",
component: () => import("@/views/Help.vue"),
meta: { title: "帮助中心" },
},
{
path: "/service",
name: "service",
component: () => import("@/views/Service.vue"),
meta: { title: "客服" },
},
{
path: "/complaint",
name: "complaint",
component: () => import("@/views/Complaint.vue"),
meta: { title: "投诉" },
},
{
path: "/report",
name: "report",
component: () => import("@/views/Report.vue"),
meta: { title: "报告结果", requiresAuth: true },
},
{
path: "/example",
name: "example",
component: () => import("@/views/Example.vue"),
meta: { title: "示例报告" },
},
{
path: "/authorization",
name: "authorization",
component: () =>
import("@/views/Authorization.vue"),
meta: { title: "授权书" },
},
{
path: "/privacyPolicy",
name: "privacyPolicy",
component: () =>
import("@/views/PrivacyPolicy.vue"),
meta: { title: "隐私政策" },
},
{
path: "/userAgreement",
name: "userAgreement",
component: () =>
import("@/views/UserAgreement.vue"),
meta: { title: "用户协议" },
},
{
path: "/agentManageAgreement",
name: "agentManageAgreement",
component: () =>
import("@/views/AgentManageAgreement.vue"),
meta: { title: "代理管理协议" },
},
{
path: "/agentSerivceAgreement",
name: "agentSerivceAgreement",
component: () =>
import("@/views/AgentServiceAgreement.vue"),
meta: { title: "信息技术服务合同" },
},
{
path: "/inquire/:feature",
name: "inquire",
component: () => import("@/views/Inquire.vue"),
meta: { title: "查询报告" },
},
],
},
{
path: "agent",
component: PageLayout,
children: [
{
path: "promoteDetails",
name: "promoteDetails",
component: () =>
import("@/views/AgentPromoteDetails.vue"),
meta: {
title: "直推报告收益明细",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "rewardsDetails",
name: "rewardsDetails",
component: () =>
import("@/views/AgentRewardsDetails.vue"),
meta: {
title: "代理奖励收益明细",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "promote",
name: "promote",
component: () => import("@/views/Promote.vue"),
meta: {
title: "直推报告",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "invitation",
name: "invitation",
component: () => import("@/views/Invitation.vue"),
meta: {
title: "邀请下级",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "agentVip",
name: "agentVip",
component: () => import("@/views/AgentVip.vue"),
meta: {
title: "代理会员",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "vipConfig",
name: "agentVipConfig",
component: () =>
import("@/views/AgentVipConfig.vue"),
meta: {
title: "代理会员报告配置",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "withdraw",
name: "withdraw",
component: () => import("@/views/Withdraw.vue"),
meta: {
title: "提现",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "withdrawDetails",
name: "withdrawDetails",
component: () =>
import("@/views/WithdrawDetails.vue"),
meta: {
title: "提现记录",
requiresAuth: true,
requiresAgent: true,
},
},
{
path: "invitationAgentApply/self",
name: "invitationAgentApplySelf",
component: () =>
import("@/views/InvitationAgentApply.vue"),
meta: { title: "代理申请", requiresAuth: true },
},
],
},
],
},
{
path: "/login",
name: "login",
component: () => import("@/views/Login.vue"),
},
{
path: "/agent/promotionInquire/:linkIdentifier",
name: "promotionInquire",
component: () => import("@/views/PromotionInquire.vue"),
},
{
path: "/agent/invitationAgentApply/:linkIdentifier",
name: "invitationAgentApply",
component: () => import("@/views/InvitationAgentApply.vue"),
meta: { title: "代理申请" },
},
{
path: "/:pathMatch(.*)*",
name: "NotFound",
component: () => import("@/views/NotFound.vue"),
},
],
});
NProgress.configure({
easing: "ease", // 动画方式
speed: 500, // 递增进度条的速度(毫秒)
showSpinner: false, // 是否显示加载的圆圈
trickleSpeed: 200, // 自动递增间隔
minimum: 0.3, // 初始化最小百分比
});
// 路由导航守卫
router.beforeEach(async (to, from, next) => {
NProgress.start(); // 启动进度条
const isAuthenticated = localStorage.getItem("token");
const agentStore = useAgentStore();
const { isAgent, isLoaded } = storeToRefs(agentStore);
if (to.meta.requiresAuth && !isAuthenticated) {
next("/login");
} else if (to.meta.requiresAgent && !isAgent.value) {
if (!isLoaded.value) {
await agentStore.fetchAgentStatus();
}
if (!isAgent.value) {
next("/agent/invitationAgentApply/self");
} else {
next();
}
} else {
next();
}
});
router.afterEach(() => {
NProgress.done(); // 结束进度条
});
export default router;