Files
en-edu/enlish-vue/src/layouts/components/Sidebar.vue
lbw fe7128dd4e feat(layout): 为多页面添加侧边栏布局组件
- 在admid页面和class页面包裹el-container,插入Sidebar侧边栏组件
- 在LearningPlan和PlanTTS页面同样新增侧边栏布局
- 重构Header组件样式,采用fluent风格透明卡片和按钮样式
- 增加main.css中panel-shell的样式定义以支持新布局视觉效果
- 优化部分按钮及菜单交互样式,提升整体一致性与视觉体验
2026-01-04 11:10:29 +08:00

51 lines
1.5 KiB
Vue

<template>
<div class="h-full p-2">
<div class="h-full panel-shell">
<el-menu router :default-active="activePath" class="h-full rounded-xl bg-transparent" :collapse="false">
<el-menu-item index="/">
<span>班级列表</span>
</el-menu-item>
<el-menu-item index="/learningplan">
<span>学案</span>
</el-menu-item>
<el-menu-item index="/uploadpng">
<span>上传图片</span>
</el-menu-item>
</el-menu>
</div>
</div>
</template>
<script setup>
import { computed } from 'vue'
import { useRoute } from 'vue-router'
import router from '@/router'
const route = useRoute()
const activePath = computed(() => route.path)
const allRoutes = router.getRoutes()
const menuItems = computed(() => {
return allRoutes
.filter(r => r.meta && r.meta.title)
.filter(r => !r.path.includes(':'))
.filter(r => r.path !== '/login')
.map(r => ({ path: r.path, title: r.meta.title }))
.sort((a, b) => a.title.localeCompare(b.title, 'zh-CN'))
})
</script>
<style scoped>
/* Fluent 2 气质的轻盈质感:柔和玻璃、圆角、细描边 */
.el-menu {
--el-menu-bg-color: transparent;
--el-menu-hover-bg-color: rgba(255, 255, 255, 0.35);
--el-menu-active-color: #2563eb;
}
.el-menu-item {
border-radius: 10px;
transition: all 0.2s ease;
}
.el-menu-item:hover {
backdrop-filter: saturate(1.2);
}
</style>