App.vue 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. <template>
  2. <div id="app" :class="{'isHomePage': $route.path === '/' || $route.path === '/index',vipHomePage: $route.path === '/member'}">
  3. <ElConfigProvider :locale="langStore.elLocale">
  4. <el-container style="min-height: 100vh;">
  5. <el-header class="box_shadow_card">
  6. <div class="header-content">
  7. <div class="logo" @click="$router.push('/')">{{ $t('common.title') }}</div>
  8. <el-menu :default-active="activeIndex" ref="el_menu"
  9. mode="horizontal" :ellipsis="false" class="meauList">
  10. <el-menu-item index="1" @click="$router.push('/')">AI {{ $t('common.gongzuoliu') }}</el-menu-item>
  11. <!-- <el-menu-item index="2" @click="$router.push('/my-learning')">工作流交易</el-menu-item> -->
  12. <el-menu-item index="2" @click="goMyLearning">{{ $t('common.gongzuoliu_trade') }}</el-menu-item>
  13. <el-menu-item index="3" @click="$router.push('/learning-system')">{{ $t('route.learning_system') }}</el-menu-item>
  14. <el-menu-item index="4" @click=" goLearnNote">{{ $t('common.xuxibiji') }}</el-menu-item>
  15. <el-menu-item index="5" @click="$router.push('/mibi-shop')">{{ $t('route.mibiShop') }}</el-menu-item>
  16. <!-- <el-menu-item index="5" @click="$router.push('/my-learning')">米币商城</el-menu-item> -->
  17. </el-menu>
  18. <div class="header-right">
  19. <el-avatar :size="32" :src="appStore.userInfo?.userAvatar || appStore.avatarDefault" />
  20. <el-dropdown v-if="appStore.token">
  21. <span class="el-dropdown-link">
  22. {{ appStore.userInfo?.nickName || '用户' }}
  23. <el-icon class="el-icon--right">
  24. <arrow-down />
  25. </el-icon>
  26. </span>
  27. <template #dropdown>
  28. <el-dropdown-menu>
  29. <el-dropdown-item @click="handleLogout">{{ $t('common.logout') }}</el-dropdown-item>
  30. <el-dropdown-item @click="toPersonal">{{ $t('personalCenter.personalCenter') }}</el-dropdown-item>
  31. </el-dropdown-menu>
  32. </template>
  33. </el-dropdown>
  34. <!-- 打开登录弹框 -->
  35. <el-button type="text" @click="openLoginDialog" v-if="!appStore.token">{{ $t('common.login') }}</el-button>
  36. <LangSwitch />
  37. </div>
  38. </div>
  39. </el-header>
  40. <!-- 固定头部占位 -->
  41. <div style="height: 60px;"></div>
  42. <div class="header-bj" v-if="$route.path === '/member'"></div>
  43. <el-main class="container">
  44. <router-view />
  45. </el-main>
  46. <el-footer>
  47. <div class="footer-content" >
  48. <p>
  49. <span class="cursor-pointer" @click="router.push({name:'Agreement',query:{type:'service_agreement'}})">{{ $t('agreement.service_agreement') }}</span>
  50. <span class="gray999"> | </span>
  51. <span class="cursor-pointer" @click="router.push({name:'Agreement',query:{type:'privacy_policy'}})">{{ $t('agreement.privacy_policy') }}</span>
  52. <span class="gray999"> | </span>
  53. <span @click="openNewTab('https://beian.miit.gov.cn/')" class="cursor-pointer">粤ICP备2025364959号-1</span>
  54. <span class="gray999"> | </span>
  55. <span>广州暴米智能科技有限公司</span>
  56. </p>
  57. </div>
  58. </el-footer>
  59. </el-container>
  60. <!-- 登录弹框组件 -->
  61. <LoginDialog ref="loginDialogRef" @login-success="handleLoginSuccess" />
  62. </ElConfigProvider>
  63. </div>
  64. </template>
  65. <script setup>
  66. import { logout } from '@/api/auth.js'
  67. import LoginDialog from './components/LoginDialog.vue'
  68. import { computed,ref,onMounted, provide, watch, nextTick } from 'vue'
  69. import LangSwitch from './components/LangSwitch.vue'
  70. import { ElConfigProvider, ElMessage } from 'element-plus'
  71. import { useRoute, useRouter } from 'vue-router'
  72. import { openNewTab, isLogin } from '@/utils/util.js'
  73. // 在Pinia安装后再设置初始语言
  74. import { useLangStore } from '@/pinia/langStore'
  75. import { useAppStore } from '@/pinia/appStore'
  76. const langStore = useLangStore();
  77. const appStore = useAppStore();
  78. $i18n.global.locale.value = langStore.currentLang
  79. import { useI18n } from 'vue-i18n'
  80. const { t } = useI18n()
  81. // 动态更新页面标题
  82. langStore.updateDynamicTitle()
  83. const route = useRoute()
  84. const router = useRouter()
  85. const el_menu = ref(null);
  86. // 登录弹框引用
  87. const loginDialogRef = ref(null)
  88. //监听showLoginDialog变化
  89. watch(() => appStore.showLoginDialog, (newVal, oldVal) => {
  90. if(newVal){
  91. openLoginDialog();
  92. }
  93. })
  94. onMounted(() => {
  95. appStore.USERINFO();
  96. })
  97. // 打开登录弹框
  98. const openLoginDialog = () => {
  99. loginDialogRef.value?.open();
  100. }
  101. // 处理登录成功
  102. const handleLoginSuccess = () => {
  103. console.log('登录成功')
  104. // 可以在这里处理登录后的逻辑,比如更新用户信息、刷新页面等
  105. }
  106. //
  107. function goMyLearning() {
  108. router.push('/workflow-trade')
  109. };
  110. const goLearnNote = () => {
  111. if (!isLogin({ callback: openLoginDialog, t })) {
  112. el_menu.value.updateActiveIndex (activeIndex.value);
  113. return; // 如果未登录则不执行跳转,也不激活菜单
  114. }
  115. router.push('/learn-note');
  116. }
  117. // 将 activeIndex 改为响应式,并根据当前路由动态计算
  118. const activeIndex = computed(() => {
  119. console.log('route.path',route.path)
  120. if (route.path === '/index') return '1'
  121. if (route.path.startsWith('/workflow-trade')) {
  122. return '2'
  123. }
  124. if (route.path.startsWith('/learning-system')) {
  125. return '3'
  126. }
  127. if (route.path.startsWith('/learn-note')) {
  128. // 如果用户未登录,不应该显示此菜单为激活状态
  129. if (!appStore.token) return null; // 或者返回上一个有效菜单
  130. return '4';
  131. }
  132. if (route.path.startsWith('/mibi-shop')) {
  133. return '5'
  134. }
  135. if (route.path.startsWith('/personal-center')) {
  136. return null
  137. }
  138. return null // 默认返回首页
  139. });
  140. // 去个人中心
  141. const toPersonal = () => {
  142. router.push('/personal-center/wallet')
  143. };
  144. // 处理注销
  145. const handleLogout = () => {
  146. logout().then(() => {
  147. appStore.LOGOUT()
  148. ElMessage.success(t('login.logoutSuccess'))
  149. router.push('/')
  150. })
  151. };
  152. provide('openLoginDialog', openLoginDialog);
  153. </script>
  154. <style lang="scss">
  155. #app {
  156. font-family: Avenir, Helvetica, Arial, sans-serif;
  157. -webkit-font-smoothing: antialiased;
  158. -moz-osx-font-smoothing: grayscale;
  159. color: #2c3e50;
  160. &.isHomePage {
  161. background: url('@/assets/imgs/bg.png') no-repeat center center fixed;
  162. background-size: 100% 100%;
  163. }
  164. &.vipHomePage {
  165. background: #FBF4F0;
  166. }
  167. }
  168. .isHomePage{
  169. .el-header {
  170. background: url('@/assets/imgs/bg-header.png') no-repeat;
  171. background-size: 100% 100%;
  172. }
  173. }
  174. .vipHomePage {
  175. .el-header {
  176. background: rgba(255,255,255,0.5);
  177. }
  178. }
  179. .el-header {
  180. background: url('@/assets/imgs/bg-header_2.png') no-repeat;
  181. background-size: 100% 100%;
  182. color: #333;
  183. line-height: 60px;
  184. // border-bottom: 1px solid #eee;
  185. position: fixed;
  186. top: 0;
  187. left: 0;
  188. right: 0;
  189. z-index: 1000;
  190. padding: 0;
  191. .header-content {
  192. max-width: 1430px;
  193. width: 80%;
  194. min-width: 1430px;
  195. margin: 0 auto;
  196. display: flex;
  197. align-items: center;
  198. justify-content: space-between;
  199. .logo {
  200. min-width: 220px;
  201. font-size: 24px;
  202. font-weight: bold;
  203. cursor: pointer;
  204. }
  205. .meauList{
  206. &.el-menu{
  207. background-color: transparent;
  208. }
  209. .el-menu--horizontal.el-menu{
  210. border-bottom: none;
  211. }
  212. .el-menu-item{
  213. font-size: 16px;
  214. }
  215. }
  216. .header-right {
  217. margin-right: 30px;
  218. display: flex;
  219. align-items: center; /* 垂直居中 */
  220. gap: 10px;
  221. }
  222. }
  223. }
  224. .header-bj {
  225. top: 0;
  226. width: 100%;
  227. height: 463px;
  228. background: url('/src/assets/imgs/header-bj@2x.png') no-repeat;
  229. background-size: cover;
  230. position: fixed;
  231. }
  232. .el-footer {
  233. color: #666;
  234. text-align: center;
  235. padding: 20px 0;
  236. .footer-content {
  237. font-size: 14px;
  238. max-width: 1200px;
  239. margin: 0 auto;
  240. }
  241. }
  242. .el-main {
  243. padding: 0;
  244. }
  245. </style>