Blame view

src/layouts/default/header/components/user-dropdown/index.vue 4.51 KB
vben authored
1
2
<template>
  <Dropdown placement="bottomLeft" :overlayClassName="`${prefixCls}-dropdown-overlay`">
vben authored
3
    <span :class="[prefixCls, `${prefixCls}--${theme}`]" class="flex">
sanmu authored
4
      <!-- <img :class="`${prefixCls}__header`" :src="getUserInfo.avatar" /> -->
vben authored
5
6
      <span :class="`${prefixCls}__info hidden md:block`">
        <span :class="`${prefixCls}__name  `" class="truncate">
sanmu authored
7
          {{ getUserInfo.nickName }}
vben authored
8
        </span>
vben authored
9
10
11
12
      </span>
    </span>

    <template #overlay>
13
      <Menu @click="handleMenuClick">
sanmu authored
14
        <!-- <MenuItem
15
16
          key="doc"
          :text="t('layout.header.dropdownItemDoc')"
17
          icon="ion:document-text-outline"
18
19
          v-if="getShowDoc"
        />
20
        <MenuDivider v-if="getShowDoc" />
vben authored
21
        <MenuItem
22
          v-if="getUseLockPage"
23
24
25
          key="lock"
          :text="t('layout.header.tooltipLock')"
          icon="ion:lock-closed-outline"
sanmu authored
26
        /> -->
27
        <MenuItem
28
          key="logout"
vben authored
29
          :text="t('layout.header.dropdownItemLoginOut')"
30
          icon="ion:power-outline"
vben authored
31
32
33
34
        />
      </Menu>
    </template>
  </Dropdown>
35
  <LockAction @register="register" />
vben authored
36
37
38
39
</template>
<script lang="ts">
  // components
  import { Dropdown, Menu } from 'ant-design-vue';
40
  import type { MenuInfo } from 'ant-design-vue/lib/menu/src/interface';
vben authored
41
42
43
44
45

  import { defineComponent, computed } from 'vue';

  import { DOC_URL } from '/@/settings/siteSetting';
Vben authored
46
  import { useUserStore } from '/@/store/modules/user';
vben authored
47
48
49
  import { useHeaderSetting } from '/@/hooks/setting/useHeaderSetting';
  import { useI18n } from '/@/hooks/web/useI18n';
  import { useDesign } from '/@/hooks/web/useDesign';
50
51
  import { useModal } from '/@/components/Modal';
vben authored
52
  import headerImg from '/@/assets/images/header.jpg';
53
54
55
56
  import { propTypes } from '/@/utils/propTypes';
  import { openWindow } from '/@/utils';

  import { createAsyncComponent } from '/@/utils/factory/createAsyncComponent';
vben authored
57
58
  type MenuEvent = 'logout' | 'doc' | 'lock';
vben authored
59
60
61
62
63
64
65
66

  export default defineComponent({
    name: 'UserDropdown',
    components: {
      Dropdown,
      Menu,
      MenuItem: createAsyncComponent(() => import('./DropMenuItem.vue')),
      MenuDivider: Menu.Divider,
67
      LockAction: createAsyncComponent(() => import('../lock/LockModal.vue')),
vben authored
68
69
70
71
72
73
74
    },
    props: {
      theme: propTypes.oneOf(['dark', 'light']),
    },
    setup() {
      const { prefixCls } = useDesign('header-user-dropdown');
      const { t } = useI18n();
75
      const { getShowDoc, getUseLockPage } = useHeaderSetting();
Vben authored
76
      const userStore = useUserStore();
vben authored
77
78

      const getUserInfo = computed(() => {
sanmu authored
79
80
81
82
83
84
85
        const { nickName = '', avatar, desc } = userStore.getUserInfo || {};
        console.log(
          '%c [  userStore.getUserInfo  ]-80',
          'font-size:13px; background:pink; color:#bf2c9f;',
          userStore.getUserInfo,
        );
        return { nickName, avatar: avatar || headerImg, desc };
vben authored
86
87
      });
88
89
90
91
92
93
      const [register, { openModal }] = useModal();

      function handleLock() {
        openModal(true);
      }
vben authored
94
95
96
97
98
99
100
101
102
103
      //  login out
      function handleLoginOut() {
        userStore.confirmLoginOut();
      }

      // open doc
      function openDoc() {
        openWindow(DOC_URL);
      }
104
105
      function handleMenuClick(e: MenuInfo) {
        switch (e.key as MenuEvent) {
106
107
108
109
110
111
112
113
114
115
116
          case 'logout':
            handleLoginOut();
            break;
          case 'doc':
            openDoc();
            break;
          case 'lock':
            handleLock();
            break;
        }
      }
vben authored
117
118
119
120
121

      return {
        prefixCls,
        t,
        getUserInfo,
122
        handleMenuClick,
vben authored
123
        getShowDoc,
124
        register,
125
        getUseLockPage,
vben authored
126
127
128
129
130
131
132
133
      };
    },
  });
</script>
<style lang="less">
  @prefix-cls: ~'@{namespace}-header-user-dropdown';

  .@{prefix-cls} {
vben authored
134
    align-items: center;
vben authored
135
136
137
138
139
140
141
142
    height: @header-height;
    padding: 0 0 0 10px;
    padding-right: 10px;
    overflow: hidden;
    font-size: 12px;
    cursor: pointer;

    img {
Vben authored
143
144
      width: 24px;
      height: 24px;
vben authored
145
146
147
148
149
150
151
152
153
154
155
156
157
      margin-right: 12px;
    }

    &__header {
      border-radius: 50%;
    }

    &__name {
      font-size: 14px;
    }

    &--dark {
      &:hover {
158
        background-color: @header-dark-bg-hover-color;
vben authored
159
160
161
162
      }
    }

    &--light {
163
164
165
      &:hover {
        background-color: @header-light-bg-hover-color;
      }
166
vben authored
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
      .@{prefix-cls}__name {
        color: @text-color-base;
      }

      .@{prefix-cls}__desc {
        color: @header-light-desc-color;
      }
    }

    &-dropdown-overlay {
      .ant-dropdown-menu-item {
        min-width: 160px;
      }
    }
  }
</style>