Blame view

ant-design-vue-jeecg/src/components/tools/UserMenu.vue 10.6 KB
1
<template>
2
  <div class="user-wrapper" :class="theme">
3
4
5
6
7
    <!-- update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航 -->
    <!-- update-begin author:sunjianlei date:20191@20 for: 解决全局样式冲突的问题 -->
    <span class="action" @click="showClick">
      <a-icon type="search"></a-icon>
    </span>
8
9
    <!-- update-begin author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框 -->
    <component :is="searchMenuComp" v-show="searchMenuVisible || isMobile()" class="borders" :visible="searchMenuVisible" title="搜索菜单" :footer="null" @cancel="searchMenuVisible=false">
10
11
12
13
14
15
16
      <a-select
        class="search-input"
        showSearch
        :showArrow="false"
        placeholder="搜索菜单"
        optionFilterProp="children"
        :filterOption="filterOption"
17
18
19
        :open="isMobile()?true:null"
        :getPopupContainer="(node) => node.parentNode"
        :style="isMobile()?{width: '100%',marginBottom:'50px'}:{}"
20
21
22
        @change="searchMethods"
        @blur="hiddenClick"
      >
23
        <a-select-option v-for="(site,index) in searchMenuOptions" :key="index" :value="site.id">{{site.meta.title}}</a-select-option>
24
      </a-select>
25
26
27
    </component>
    <!-- update-end author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框 -->
    <!-- update-end author:sunjianlei date:20191220 for: 解决全局样式冲突的问题 -->
28
    <!-- update_end  author:zhaoxin date:20191129 for: 做头部菜单栏导航 -->
29
    <span class="action">
30
      <a class="logout_title" target="_blank" href="http://doc.jeecg.com">
31
32
        <a-icon type="question-circle-o"></a-icon>
      </a>
33
34
35
    </span>
    <header-notice class="action"/>
    <a-dropdown>
36
      <span class="action action-full ant-dropdown-link user-dropdown-menu">
37
        <a-avatar class="avatar" size="small" :src="getAvatar()"/>
38
        <span v-if="isDesktop()">欢迎您,{{ nickname() }}</span>
39
40
41
42
43
44
45
46
47
      </span>
      <a-menu slot="overlay" class="user-dropdown-menu-wrapper">
        <a-menu-item key="0">
          <router-link :to="{ name: 'account-center' }">
            <a-icon type="user"/>
            <span>个人中心</span>
          </router-link>
        </a-menu-item>
        <a-menu-item key="1">
48
          <router-link :to="{ name: 'account-settings-base' }">
49
50
51
52
            <a-icon type="setting"/>
            <span>账户设置</span>
          </router-link>
        </a-menu-item>
53
54
55
56
57
        <a-menu-item key="3"  @click="systemSetting">
           <a-icon type="tool"/>
           <span>系统设置</span>
        </a-menu-item>
        <a-menu-item key="4" @click="updatePassword">
58
59
60
          <a-icon type="setting"/>
          <span>密码修改</span>
        </a-menu-item>
61
        <a-menu-item key="5" @click="updateCurrentDepart">
62
63
64
          <a-icon type="cluster"/>
          <span>切换部门</span>
        </a-menu-item>
65
66
67
68
        <a-menu-item key="6" @click="clearCache">
          <a-icon type="sync"/>
          <span>清理缓存</span>
        </a-menu-item>
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
       <!-- <a-menu-item key="2" disabled>
          <a-icon type="setting"/>
          <span>测试</span>
        </a-menu-item>
        <a-menu-divider/>
        <a-menu-item key="3">
          <a href="javascript:;" @click="handleLogout">
            <a-icon type="logout"/>
            <span>退出登录</span>
          </a>
        </a-menu-item>-->
      </a-menu>
    </a-dropdown>
    <span class="action">
      <a class="logout_title" href="javascript:;" @click="handleLogout">
        <a-icon type="logout"/>
85
        <span v-if="isDesktop()">&nbsp;退出登录</span>
86
87
      </a>
    </span>
88
    <user-password ref="userPassword"></user-password>
89
    <depart-select ref="departSelect" :closable="true" title="部门切换"></depart-select>
90
    <setting-drawer ref="settingDrawer" :closable="true" title="系统设置"></setting-drawer>
91
92
93
94
95
  </div>
</template>

<script>
  import HeaderNotice from './HeaderNotice'
96
  import UserPassword from './UserPassword'
97
  import SettingDrawer from "@/components/setting/SettingDrawer";
98
  import DepartSelect from './DepartSelect'
99
  import { mapActions, mapGetters,mapState } from 'vuex'
100
  import { mixinDevice } from '@/utils/mixin.js'
101
102
103
  import { getFileAccessHttpUrl,getAction } from "@/api/manage"
  import Vue from 'vue'
  import { UI_CACHE_DB_DICT_DATA } from "@/store/mutation-types"
104
105
106
  export default {
    name: "UserMenu",
107
    mixins: [mixinDevice],
108
109
    data(){
      return{
110
111
112
113
114
        // update-begin author:sunjianlei date:20200219 for: 头部菜单搜索规范命名 --------------
        searchMenuOptions:[],
        searchMenuComp: 'span',
        searchMenuVisible: false,
        // update-begin author:sunjianlei date:20200219 for: 头部菜单搜索规范命名 --------------
115
116
      }
    },
117
    components: {
118
      HeaderNotice,
119
      UserPassword,
120
121
      DepartSelect,
      SettingDrawer
122
    },
123
124
125
126
127
128
129
    props: {
      theme: {
        type: String,
        required: false,
        default: 'dark'
      }
    },
130
131
132
133
    /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
    created() {
      let lists = []
      this.searchMenus(lists,this.permissionMenuList)
134
      this.searchMenuOptions=[...lists]
135
    },
136
137
138
139
140
141
142
143
144
    mounted() {
      //如果是单点登录模式
      if (process.env.VUE_APP_SSO == 'true') {
        let depart = this.userInfo().orgCode
        if (!depart) {
          this.updateCurrentDepart()
        }
      }
    },
145
146
147
148
149
150
151
152
    computed: {
      ...mapState({
        // 后台菜单
        permissionMenuList: state => state.user.permissionList

      })
    },
    /* update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
153
154
155
156
157
158
159
160
161
162
163
    watch: {
      // update-begin author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框
      device: {
        immediate: true,
        handler() {
          this.searchMenuVisible = false
          this.searchMenuComp = this.isMobile() ? 'a-modal' : 'span'
        },
      },
      // update-end author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框
    },
164
    methods: {
165
      /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
166
167
      showClick() {
        this.searchMenuVisible = true
168
169
170
171
172
      },
      hiddenClick(){
        this.shows = false
      },
      /* update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
173
      ...mapActions(["Logout"]),
174
      ...mapGetters(["nickname", "avatar","userInfo"]),
175
      getAvatar(){
176
        return getFileAccessHttpUrl(this.avatar())
177
178
179
180
181
182
183
184
185
      },
      handleLogout() {
        const that = this

        this.$confirm({
          title: '提示',
          content: '真的要注销登录吗 ?',
          onOk() {
            return that.Logout({}).then(() => {
186
187
              // update-begin author:wangshuai date:20200601 for: 退出登录跳转登录页面
              that.$router.push({ path: '/user/login' });
188
              window.location.reload()
189
              // update-end author:wangshuai date:20200601 for: 退出登录跳转登录页面
190
191
192
193
194
195
196
197
198
199
200
            }).catch(err => {
              that.$message.error({
                title: '错误',
                description: err.message
              })
            })
          },
          onCancel() {
          },
        });
      },
201
202
203
204
      updatePassword(){
        let username = this.userInfo().username
        this.$refs.userPassword.show(username)
      },
205
206
      updateCurrentDepart(){
        this.$refs.departSelect.show()
207
208
209
      },
      systemSetting(){
        this.$refs.settingDrawer.showDrawer()
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
      },
      /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
      searchMenus(arr,menus){
        for(let i of menus){
          if(!i.hidden && "layouts/RouteView"!==i.component){
           arr.push(i)
          }
          if(i.children&& i.children.length>0){
            this.searchMenus(arr,i.children)
          }
        }
      },
      filterOption(input, option) {
        return option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0
      },
225
226
227
      // update_begin author:sunjianlei date:20191230 for: 解决外部链接打开失败的问题
      searchMethods(value) {
        let route = this.searchMenuOptions.filter(item => item.id === value)[0]
228
229
        //update-begin-author:taoyan date:20210528 for: 【菜单问题】配置一个iframe地址的菜单,内部打开,在搜索菜单上打开却新开了一个窗口
        if (route.meta.internalOrExternal === true) {
230
231
          window.open(route.meta.url, '_blank')
        } else {
232
233
234
235
236
          if(route.component.includes('layouts/IframePageView')){
            this.$router.push(route)
          }else{
            this.$router.push({ path: route.path })
          }
237
        }
238
        //update-end-author:taoyan date:20210528 for: 【菜单问题】配置一个iframe地址的菜单,内部打开,在搜索菜单上打开却新开了一个窗口
239
        this.searchMenuVisible = false
240
      },
241
      // update_end author:sunjianlei date:20191230 for: 解决外部链接打开失败的问题
242
      /*update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
      /*update_begin author:liushaoqian date:20200507 for: 刷新缓存*/
      clearCache(){
        getAction("sys/dict/refleshCache").then((res) => {
          if (res.success) {
            //重新加载缓存
            getAction("sys/dict/queryAllDictItems").then((res) => {
              if (res.success) {
                Vue.ls.remove(UI_CACHE_DB_DICT_DATA)
                Vue.ls.set(UI_CACHE_DB_DICT_DATA, res.result, 7 * 24 * 60 * 60 * 1000)
              }
            })
            this.$message.success("刷新缓存完成!");
          }
        }).catch(e=>{
          this.$message.warn("刷新缓存失败!");
          console.log("刷新失败",e)
        })
      }
      /*update_end author:liushaoqian date:20200507 for: 刷新缓存*/
262
263
264
265
    }
  }
</script>
266
<style lang="less" scoped>
267
268
269
270
  /* update_begin author:zhaoxin date:20191129 for: 让搜索框颜色能随主题颜色变换*/
  /* update-begin author:sunjianlei date:20191220 for: 解决全局样式冲突问题 */
  .user-wrapper .search-input {
    width: 180px;
271
    color: inherit;
272
273
    /deep/ .ant-select-selection {
274
275
276
277
278
      background-color: inherit;
      border: 0;
      border-bottom: 1px solid white;
      &__placeholder, &__field__placeholder {
        color: inherit;
279
      }
280
    }
281
282
283
284
285
  }
  /* update-end author:sunjianlei date:20191220 for: 解决全局样式冲突问题 */
  /* update_end author:zhaoxin date:20191129 for: 让搜索框颜色能随主题颜色变换*/
</style>
286
<style scoped>
287
288
289
  .logout_title {
    color: inherit;
    text-decoration: none;
290
291
  }
</style>