UserMenu.vue 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <template>
  2. <div class="user-wrapper">
  3. <span class="action">
  4. <a-icon type="question-circle-o"></a-icon>
  5. </span>
  6. <header-notice class="action"/>
  7. <a-dropdown>
  8. <span class="action ant-dropdown-link user-dropdown-menu">
  9. <a-avatar class="avatar" size="small" :src="avatar()"/>
  10. <span>{{ nickname() }}</span>
  11. </span>
  12. <a-menu slot="overlay" class="user-dropdown-menu-wrapper">
  13. <a-menu-item key="0">
  14. <router-link :to="{ name: 'center' }">
  15. <a-icon type="user"/>
  16. <span>个人中心</span>
  17. </router-link>
  18. </a-menu-item>
  19. <a-menu-item key="1">
  20. <router-link :to="{ name: 'settings' }">
  21. <a-icon type="setting"/>
  22. <span>账户设置</span>
  23. </router-link>
  24. </a-menu-item>
  25. <a-menu-item key="2" disabled>
  26. <a-icon type="setting"/>
  27. <span>测试</span>
  28. </a-menu-item>
  29. <a-menu-divider/>
  30. <a-menu-item key="3">
  31. <a href="javascript:;" @click="handleLogout">
  32. <a-icon type="logout"/>
  33. <span>退出登录</span>
  34. </a>
  35. </a-menu-item>
  36. </a-menu>
  37. </a-dropdown>
  38. </div>
  39. </template>
  40. <script>
  41. import HeaderNotice from './HeaderNotice'
  42. import { mapActions, mapGetters } from 'vuex'
  43. export default {
  44. name: "UserMenu",
  45. components: {
  46. HeaderNotice
  47. },
  48. methods: {
  49. ...mapActions(["Logout"]),
  50. ...mapGetters(["nickname", "avatar"]),
  51. handleLogout() {
  52. const that = this
  53. this.$confirm({
  54. title: '提示',
  55. content: '真的要注销登录吗 ?',
  56. onOk() {
  57. return that.Logout({}).then(() => {
  58. window.location.reload()
  59. }).catch(err => {
  60. that.$message.error({
  61. title: '错误',
  62. description: err.message
  63. })
  64. })
  65. },
  66. onCancel() {
  67. },
  68. });
  69. },
  70. }
  71. }
  72. </script>
  73. <style scoped>
  74. </style>