index.vue 4.2 KB
Newer Older
V
vben 已提交
1 2
<template>
  <Dropdown placement="bottomLeft" :overlayClassName="`${prefixCls}-dropdown-overlay`">
V
vben 已提交
3
    <span :class="[prefixCls, `${prefixCls}--${theme}`]" class="flex">
V
vben 已提交
4
      <img :class="`${prefixCls}__header`" :src="headerImg" />
V
vben 已提交
5 6 7 8
      <span :class="`${prefixCls}__info hidden md:block`">
        <span :class="`${prefixCls}__name  `" class="truncate">
          {{ getUserInfo.realName }}
        </span>
V
vben 已提交
9 10 11 12 13
      </span>
    </span>

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

  import { defineComponent, computed } from 'vue';

  import { DOC_URL } from '/@/settings/siteSetting';

V
Vben 已提交
44
  import { useUserStore } from '/@/store/modules/user';
V
vben 已提交
45 46 47
  import { useHeaderSetting } from '/@/hooks/setting/useHeaderSetting';
  import { useI18n } from '/@/hooks/web/useI18n';
  import { useDesign } from '/@/hooks/web/useDesign';
48 49
  import { useModal } from '/@/components/Modal';

V
vben 已提交
50
  import headerImg from '/@/assets/images/header.jpg';
51 52 53 54
  import { propTypes } from '/@/utils/propTypes';
  import { openWindow } from '/@/utils';

  import { createAsyncComponent } from '/@/utils/factory/createAsyncComponent';
V
vben 已提交
55

56
  type MenuEvent = 'logout' | 'doc' | 'lock';
V
vben 已提交
57 58 59 60 61 62 63 64

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

      const getUserInfo = computed(() => {
V
Vben 已提交
77
        const { realName = '', desc } = userStore.getUserInfo || {};
V
vben 已提交
78 79 80
        return { realName, desc };
      });

81 82 83 84 85 86
      const [register, { openModal }] = useModal();

      function handleLock() {
        openModal(true);
      }

V
vben 已提交
87 88 89 90 91 92 93 94 95 96 97 98
      //  login out
      function handleLoginOut() {
        userStore.confirmLoginOut();
      }

      // open doc
      function openDoc() {
        openWindow(DOC_URL);
      }

      function handleMenuClick(e: { key: MenuEvent }) {
        switch (e.key) {
99
          case 'logout':
V
vben 已提交
100 101 102 103 104
            handleLoginOut();
            break;
          case 'doc':
            openDoc();
            break;
105 106 107
          case 'lock':
            handleLock();
            break;
V
vben 已提交
108 109 110 111 112 113 114 115 116
        }
      }

      return {
        prefixCls,
        t,
        getUserInfo,
        handleMenuClick,
        getShowDoc,
V
vben 已提交
117
        headerImg,
118
        register,
V
vben 已提交
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
      };
    },
  });
</script>
<style lang="less">
  @prefix-cls: ~'@{namespace}-header-user-dropdown';

  .@{prefix-cls} {
    height: @header-height;
    padding: 0 0 0 10px;
    padding-right: 10px;
    overflow: hidden;
    font-size: 12px;
    cursor: pointer;
    align-items: center;

    img {
V
Vben 已提交
136 137
      width: 24px;
      height: 24px;
V
vben 已提交
138 139 140 141 142 143 144 145 146 147 148 149 150
      margin-right: 12px;
    }

    &__header {
      border-radius: 50%;
    }

    &__name {
      font-size: 14px;
    }

    &--dark {
      &:hover {
V
Vben 已提交
151
        background-color: @header-dark-bg-hover-color;
V
vben 已提交
152 153 154 155
      }
    }

    &--light {
156 157 158
      &:hover {
        background-color: @header-light-bg-hover-color;
      }
V
Vben 已提交
159

V
vben 已提交
160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175
      .@{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>