2025-08-10 22:42:56 +08:00
|
|
|
import { createRouter, createWebHistory } from 'vue-router'
|
|
|
|
import type { RouteRecordRaw } from 'vue-router'
|
|
|
|
|
|
|
|
// 导入页面组件
|
|
|
|
import Home from '@/views/Home.vue'
|
|
|
|
import Courses from '@/views/Courses.vue'
|
|
|
|
import CourseDetail from '@/views/CourseDetail.vue'
|
|
|
|
import CourseDetailEnrolled from '@/views/CourseDetailEnrolled.vue'
|
2025-08-16 19:51:39 +08:00
|
|
|
import CourseExchanged from '@/views/CourseExchanged.vue'
|
2025-08-10 22:42:56 +08:00
|
|
|
import CourseStudy from '@/views/CourseStudy.vue'
|
|
|
|
import Learning from '@/views/Learning.vue'
|
|
|
|
import Profile from '@/views/Profile.vue'
|
|
|
|
|
|
|
|
import LearningPaths from '@/views/LearningPaths.vue'
|
|
|
|
import Faculty from '@/views/Faculty.vue'
|
|
|
|
import TeacherDetail from '@/views/TeacherDetail.vue'
|
|
|
|
import Resources from '@/views/Resources.vue'
|
|
|
|
import Activities from '@/views/Activities.vue'
|
|
|
|
import ActivityDetail from '@/views/ActivityDetail.vue'
|
|
|
|
import ActivityRegistration from '@/views/ActivityRegistration.vue'
|
|
|
|
import Exam from '@/views/Exam.vue'
|
|
|
|
import ExamNotice from '@/views/ExamNotice.vue'
|
|
|
|
import ExamSubmitted from '@/views/ExamSubmitted.vue'
|
|
|
|
import TestSections from '@/views/TestSections.vue'
|
|
|
|
import LocalVideoDemo from '@/views/LocalVideoDemo.vue'
|
2025-08-19 19:04:11 +08:00
|
|
|
import DPlayerTest from '@/views/DPlayerTest.vue'
|
2025-08-10 22:42:56 +08:00
|
|
|
import SpecialTraining from '@/views/SpecialTraining.vue'
|
|
|
|
import SpecialTrainingDetail from '@/views/SpecialTrainingDetail.vue'
|
|
|
|
import HelpCenter from '@/views/HelpCenter.vue'
|
2025-08-16 19:51:39 +08:00
|
|
|
import Practice from '@/views/Practice.vue'
|
|
|
|
import LearningCenter from '@/views/LearningCenter.vue'
|
2025-08-10 22:42:56 +08:00
|
|
|
|
|
|
|
const routes: RouteRecordRaw[] = [
|
|
|
|
{
|
|
|
|
path: '/help-center',
|
|
|
|
name: 'HelpCenter',
|
|
|
|
component: HelpCenter,
|
|
|
|
meta: {
|
|
|
|
title: '帮助中心'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/',
|
|
|
|
name: 'Home',
|
|
|
|
component: Home,
|
|
|
|
meta: {
|
|
|
|
title: '首页'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/courses',
|
|
|
|
name: 'Courses',
|
|
|
|
component: Courses,
|
|
|
|
meta: {
|
|
|
|
title: '课程列表'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/course/:id',
|
|
|
|
name: 'CourseDetail',
|
|
|
|
component: CourseDetail,
|
|
|
|
meta: {
|
|
|
|
title: '课程详情'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/course/:id/enrolled',
|
|
|
|
name: 'CourseDetailEnrolled',
|
|
|
|
component: CourseDetailEnrolled,
|
|
|
|
meta: {
|
|
|
|
title: '课程详情 - 已报名'
|
|
|
|
}
|
|
|
|
},
|
2025-08-16 19:51:39 +08:00
|
|
|
{
|
|
|
|
path: '/course/:id/exchanged',
|
|
|
|
name: 'CourseExchanged',
|
|
|
|
component: CourseExchanged,
|
|
|
|
meta: {
|
|
|
|
title: '课程兑换成功'
|
|
|
|
}
|
|
|
|
},
|
2025-08-10 22:42:56 +08:00
|
|
|
{
|
|
|
|
path: '/course/study/:id',
|
|
|
|
name: 'CourseStudy',
|
|
|
|
component: CourseStudy,
|
|
|
|
meta: {
|
|
|
|
title: '课程学习',
|
|
|
|
requiresAuth: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/learning/:id',
|
|
|
|
name: 'Learning',
|
|
|
|
component: Learning,
|
|
|
|
meta: {
|
|
|
|
title: '学习中心',
|
|
|
|
requiresAuth: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/profile',
|
|
|
|
name: 'Profile',
|
|
|
|
component: Profile,
|
|
|
|
meta: {
|
|
|
|
title: '个人中心',
|
|
|
|
requiresAuth: true
|
|
|
|
}
|
|
|
|
},
|
2025-08-16 19:51:39 +08:00
|
|
|
{
|
|
|
|
path: '/learning-center',
|
|
|
|
name: 'LearningCenter',
|
|
|
|
component: LearningCenter,
|
|
|
|
meta: {
|
|
|
|
title: '学习中心'
|
|
|
|
}
|
|
|
|
},
|
2025-08-10 22:42:56 +08:00
|
|
|
|
|
|
|
{
|
|
|
|
path: '/learning-paths',
|
|
|
|
name: 'LearningPaths',
|
|
|
|
component: LearningPaths,
|
|
|
|
meta: {
|
|
|
|
title: '学习路径'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/faculty',
|
|
|
|
name: 'Faculty',
|
|
|
|
component: Faculty,
|
|
|
|
meta: {
|
|
|
|
title: '师资力量'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/teacher/:id',
|
|
|
|
name: 'TeacherDetail',
|
|
|
|
component: TeacherDetail,
|
|
|
|
meta: {
|
|
|
|
title: '讲师详情'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/resources',
|
|
|
|
name: 'Resources',
|
|
|
|
component: Resources,
|
|
|
|
meta: {
|
|
|
|
title: '精选资源'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/special-training',
|
|
|
|
name: 'SpecialTraining',
|
|
|
|
component: SpecialTraining,
|
|
|
|
meta: {
|
|
|
|
title: '专题训练'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/special-training/:id',
|
|
|
|
name: 'SpecialTrainingDetail',
|
|
|
|
component: SpecialTrainingDetail,
|
|
|
|
meta: {
|
|
|
|
title: '专题训练详情'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/activities',
|
|
|
|
name: 'Activities',
|
|
|
|
component: Activities,
|
|
|
|
meta: {
|
|
|
|
title: '全部活动'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/activity/:id',
|
|
|
|
name: 'ActivityDetail',
|
|
|
|
component: ActivityDetail,
|
|
|
|
meta: {
|
|
|
|
title: '活动详情'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/activity/:id/register',
|
|
|
|
name: 'ActivityRegistration',
|
|
|
|
component: ActivityRegistration,
|
|
|
|
meta: {
|
|
|
|
title: '活动报名'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/course/:courseId/exam/:sectionId/notice',
|
|
|
|
name: 'ExamNotice',
|
|
|
|
component: ExamNotice,
|
|
|
|
meta: {
|
|
|
|
title: '考前须知'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/course/:courseId/exam/:sectionId',
|
|
|
|
name: 'Exam',
|
|
|
|
component: Exam,
|
|
|
|
meta: {
|
|
|
|
title: '在线考试'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/exam/submitted',
|
|
|
|
name: 'ExamSubmitted',
|
|
|
|
component: ExamSubmitted,
|
|
|
|
meta: {
|
|
|
|
title: '考试提交成功'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/ai',
|
|
|
|
name: 'AI',
|
|
|
|
component: () => import('@/views/Ai.vue'),
|
|
|
|
meta: {
|
|
|
|
title: 'AI'
|
|
|
|
}
|
|
|
|
},
|
2025-08-16 19:51:39 +08:00
|
|
|
{
|
2025-08-16 20:39:56 +08:00
|
|
|
path: '/ai-companion/:id?',
|
2025-08-16 19:51:39 +08:00
|
|
|
name: 'AICompanion',
|
|
|
|
component: () => import('@/views/AICompanion.vue'),
|
|
|
|
meta: {
|
|
|
|
title: 'AI伴学'
|
|
|
|
}
|
|
|
|
},
|
2025-08-10 22:42:56 +08:00
|
|
|
{
|
|
|
|
path: '/ai-demo',
|
|
|
|
name: 'AIDemo',
|
|
|
|
component: () => import('@/views/DetailView.vue'),
|
|
|
|
meta: {
|
|
|
|
title: 'AI演示'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/test-sections',
|
|
|
|
name: 'TestSections',
|
|
|
|
component: TestSections,
|
|
|
|
meta: {
|
|
|
|
title: '测试章节API'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/local-video-demo',
|
|
|
|
name: 'LocalVideoDemo',
|
|
|
|
component: LocalVideoDemo,
|
|
|
|
meta: {
|
|
|
|
title: '本地视频播放演示'
|
|
|
|
}
|
|
|
|
},
|
2025-08-19 19:04:11 +08:00
|
|
|
{
|
|
|
|
path: '/dplayer-test',
|
|
|
|
name: 'DPlayerTest',
|
|
|
|
component: DPlayerTest,
|
|
|
|
meta: {
|
|
|
|
title: 'DPlayer 测试页面'
|
|
|
|
}
|
|
|
|
},
|
2025-08-16 19:51:39 +08:00
|
|
|
{
|
|
|
|
path: '/course/:courseId/practice/:sectionId',
|
|
|
|
name: 'Practice',
|
|
|
|
component: Practice,
|
|
|
|
meta: {
|
|
|
|
title: '练习页面'
|
|
|
|
}
|
|
|
|
},
|
2025-08-10 22:42:56 +08:00
|
|
|
{
|
|
|
|
path: '/:pathMatch(.*)*',
|
|
|
|
name: 'NotFound',
|
|
|
|
component: () => import('@/views/NotFound.vue'),
|
|
|
|
meta: {
|
|
|
|
title: '页面未找到'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
const router = createRouter({
|
|
|
|
history: createWebHistory(),
|
|
|
|
routes,
|
|
|
|
scrollBehavior(_to, _from, savedPosition) {
|
|
|
|
if (savedPosition) {
|
|
|
|
return savedPosition
|
|
|
|
} else {
|
|
|
|
return { top: 0 }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
// 路由守卫
|
2025-08-16 22:48:10 +08:00
|
|
|
router.beforeEach((to, from, next) => {
|
2025-08-10 22:42:56 +08:00
|
|
|
// 设置页面标题
|
|
|
|
if (to.meta.title) {
|
|
|
|
document.title = `${to.meta.title} - 在线学习平台`
|
|
|
|
}
|
|
|
|
|
|
|
|
// 检查是否需要登录
|
|
|
|
if (to.meta.requiresAuth) {
|
|
|
|
// 检查用户登录状态
|
|
|
|
const token = localStorage.getItem('token')
|
|
|
|
if (!token) {
|
|
|
|
// 未登录时跳转到首页,用户可以通过模态框登录
|
|
|
|
next('/')
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-08-16 22:48:10 +08:00
|
|
|
// 特殊处理:检测从其他页面进入积分中心
|
|
|
|
if (to.name === 'LearningCenter') {
|
|
|
|
// 如果是从其他页面进入积分中心,设置自动刷新标记
|
|
|
|
if (from.name && from.name !== 'LearningCenter') {
|
|
|
|
sessionStorage.setItem('learningCenterNeedsRefresh', 'true');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 特殊处理:检测从其他页面进入帮助中心
|
|
|
|
if (to.name === 'HelpCenter') {
|
|
|
|
// 如果是从其他页面进入帮助中心,设置自动刷新标记
|
|
|
|
if (from.name && from.name !== 'HelpCenter') {
|
|
|
|
sessionStorage.setItem('helpCenterNeedsRefresh', 'true');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-08-18 12:03:30 +08:00
|
|
|
// 特殊处理:检测从其他页面进入已兑换页面
|
|
|
|
if (to.name === 'CourseExchanged') {
|
|
|
|
// 如果是从其他页面进入已兑换页面,设置自动刷新标记
|
|
|
|
if (from.name && from.name !== 'CourseExchanged') {
|
|
|
|
sessionStorage.setItem('refreshCourseExchanged', 'true');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 特殊处理:检测从其他页面进入个人中心
|
|
|
|
if (to.name === 'Profile') {
|
|
|
|
// 如果是从其他页面进入个人中心,设置自动刷新标记
|
|
|
|
if (from.name && from.name !== 'Profile') {
|
|
|
|
sessionStorage.setItem('refreshProfile', 'true');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-08-10 22:42:56 +08:00
|
|
|
next()
|
|
|
|
})
|
|
|
|
|
|
|
|
export default router
|