App.vue 7.4 KB

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