index.vue 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <template>
  2. <el-container class="hc-layout-main">
  3. <el-aside class="hc-layout-aside" width="200px">
  4. <hc-body class="hc-layout-aside-body">
  5. <div class="hc-layout-aside-logo hc-flex-center h-[46px]">
  6. <img :src="logoPng" alt="logo" class="w-[26px]">
  7. <span class="ml-[6px] text-[22px] font-bold">数据分析系统</span>
  8. <hc-upload-bar />
  9. </div>
  10. <div class="hc-layout-aside-menu">
  11. <MenuBar :cur="menuBarKey" :datas="menuBarData" @change="menuBarChange" />
  12. </div>
  13. <div class="hc-layout-aside-user">
  14. <UserInfoBar @load="userInfoLoad" />
  15. </div>
  16. </hc-body>
  17. </el-aside>
  18. <el-main class="hc-layout-page">
  19. <hc-body id="hc-main-box">
  20. <router-view />
  21. </hc-body>
  22. </el-main>
  23. </el-container>
  24. </template>
  25. <script setup>
  26. import { onMounted, ref } from 'vue'
  27. //import { useAppStore } from '~src/store'
  28. import { useRoute, useRouter } from 'vue-router'
  29. import { getMenuData } from '~src/router/routers'
  30. //logo文件
  31. import logoPng from '~src/assets/logo/logo.png'
  32. //初始组合式
  33. const router = useRouter()
  34. const useRoutes = useRoute()
  35. //const store = useAppStore()
  36. //子组件
  37. import MenuBar from './modules/MenuBar.vue'
  38. import UserInfoBar from './modules/UserInfoBar.vue'
  39. //菜单数据
  40. const menuBarKey = ref(useRoutes.name)
  41. //const menuBarData = ref(store.menus)
  42. const menuBarData = ref([])
  43. //渲染完成
  44. onMounted(async () => {
  45. menuBarData.value = await getMenuData()
  46. })
  47. //菜单被点击
  48. const menuBarChange = ({ code }) => {
  49. menuBarKey.value = code
  50. router.push({ name: code })
  51. }
  52. //用户信息
  53. const userInfoLoad = ({ user_id }) => {
  54. console.log('用户信息', user_id)
  55. }
  56. </script>
  57. <style lang="scss">
  58. @import "./index.scss";
  59. </style>