Blame view

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

        <!-- <a @click="downWord" style="height:59;line-height:59px;color: #d71345" v-if="manual === 'desktop'">  WMS操作手册</a> -->
肖超群 authored
86
87
88
89
90
91
92
93
94
95
96
        <!-- <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>-->
肖超群 authored
97
98
99
100
      </a-menu>
    </a-dropdown>
    <span class="action">
      <a class="logout_title" href="javascript:;" @click="handleLogout">
101
        <a-icon type="logout" />
肖超群 authored
102
103
104
105
106
107
108
109
110
111
        <span v-if="isDesktop()">&nbsp;退出登录</span>
      </a>
    </span>
    <user-password ref="userPassword"></user-password>
    <depart-select ref="departSelect" :closable="true" title="部门切换"></depart-select>
    <setting-drawer ref="settingDrawer" :closable="true" title="系统设置"></setting-drawer>
  </div>
</template>

<script>
肖超群 authored
112
113
import HeaderNotice from './HeaderNotice'
import UserPassword from './UserPassword'
114
import SettingDrawer from '@/components/setting/SettingDrawer'
肖超群 authored
115
import DepartSelect from './DepartSelect'
116
117
118
119
import { downLoad } from '@/api/api'
import { mapActions, mapGetters, mapState } from 'vuex'
import { mixinDevice } from '@/utils/mixin.js'
import { getFileAccessHttpUrl, getAction, downFile } from '@/api/manage'
肖超群 authored
120
import Vue from 'vue'
121
import { UI_CACHE_DB_DICT_DATA } from '@/store/mutation-types'
肖超群 authored
122
肖超群 authored
123
export default {
124
  name: 'UserMenu',
肖超群 authored
125
126
127
128
129
130
131
132
  mixins: [mixinDevice],
  data() {
    return {
      // update-begin author:sunjianlei date:20200219 for: 头部菜单搜索规范命名 --------------
      searchMenuOptions: [],
      searchMenuComp: 'span',
      searchMenuVisible: false,
      // update-begin author:sunjianlei date:20200219 for: 头部菜单搜索规范命名 --------------
133
134
135
      url: {
        downLoad: '/sys/common/downLoad'
      }
肖超群 authored
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
    }
  },
  components: {
    HeaderNotice,
    UserPassword,
    DepartSelect,
    SettingDrawer
  },
  props: {
    theme: {
      type: String,
      required: false,
      default: 'dark'
    }
  },
  /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
  created() {
    let lists = []
    this.searchMenus(lists, this.permissionMenuList)
    this.searchMenuOptions = [...lists]
  },
  mounted() {
    //如果是单点登录模式
    if (process.env.VUE_APP_SSO == 'true') {
      let depart = this.userInfo().orgCode
      if (!depart) {
        this.updateCurrentDepart()
肖超群 authored
163
      }
肖超群 authored
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
    }
  },
  computed: {
    ...mapState({
      // 后台菜单
      permissionMenuList: state => state.user.permissionList
    })
  },
  /* update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
  watch: {
    // update-begin author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框
    device: {
      immediate: true,
      handler() {
        this.searchMenuVisible = false
        this.searchMenuComp = this.isMobile() ? 'a-modal' : 'span'
180
181
      }
    }
肖超群 authored
182
183
184
    // update-end author:sunjianlei date:20200219 for: 菜单搜索改为动态组件,在手机端呈现出弹出框
  },
  methods: {
肖超群 authored
185
    /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
肖超群 authored
186
187
    showClick() {
      this.searchMenuVisible = true
肖超群 authored
188
    },
肖超群 authored
189
190
    hiddenClick() {
      this.shows = false
肖超群 authored
191
    },
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
    downWord() {
      var fileName = '华恒WMS4操作说明书.doc'
      return downFile(this.url.downLoad, fileName).then(data => {
        debugger
        this.$message.info('华恒WMS4操作说明书开始下载....')
        if (!data || data.size === 0) {
          this.$message.error('文件下载失败')
          return
        }
        if (typeof window.navigator.msSaveBlob !== 'undefined') {
          window.navigator.msSaveBlob(new Blob([data]), fileName)
        } else {
          let url = window.URL.createObjectURL(new Blob([data]))
          let link = document.createElement('a')
          link.style.display = 'none'
          link.href = url
          link.setAttribute('download', fileName)
          document.body.appendChild(link)
          link.click()
          document.body.removeChild(link) //下载完成移除元素
          window.URL.revokeObjectURL(url) //释放掉blob对象
        }
      })
    },
肖超群 authored
216
    /* update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
217
218
    ...mapActions(['Logout']),
    ...mapGetters(['nickname', 'avatar', 'userInfo']),
肖超群 authored
219
220
    getAvatar() {
      return getFileAccessHttpUrl(this.avatar())
肖超群 authored
221
    },
肖超群 authored
222
223
    handleLogout() {
      const that = this
肖超群 authored
224
肖超群 authored
225
226
227
228
      this.$confirm({
        title: '提示',
        content: '真的要注销登录吗 ?',
        onOk() {
229
230
231
232
233
234
235
236
237
238
239
240
241
          return that
            .Logout({})
            .then(() => {
              // update-begin author:scott date:20211223 for:【JTC-198】退出登录体验不好
              //that.$router.push({ path: '/user/login' });
              window.location.reload()
              // update-end author:scott date:20211223 for:【JTC-198】退出登录体验不好
            })
            .catch(err => {
              that.$message.error({
                title: '错误',
                description: err.message
              })
肖超群 authored
242
            })
肖超群 authored
243
        },
244
245
        onCancel() {}
      })
肖超群 authored
246
247
248
249
250
251
252
253
254
255
256
257
258
259
    },
    updatePassword() {
      let username = this.userInfo().username
      this.$refs.userPassword.show(username)
    },
    updateCurrentDepart() {
      this.$refs.departSelect.show()
    },
    systemSetting() {
      this.$refs.settingDrawer.showDrawer()
    },
    /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
    searchMenus(arr, menus) {
      for (let i of menus) {
260
        if (!i.hidden && 'layouts/RouteView' !== i.component) {
肖超群 authored
261
          arr.push(i)
肖超群 authored
262
        }
肖超群 authored
263
264
        if (i.children && i.children.length > 0) {
          this.searchMenus(arr, i.children)
肖超群 authored
265
266
        }
      }
肖超群 authored
267
268
269
270
271
272
273
274
275
276
277
    },
    filterOption(input, option) {
      return option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0
    },
    // update_begin author:sunjianlei date:20191230 for: 解决外部链接打开失败的问题
    searchMethods(value) {
      let route = this.searchMenuOptions.filter(item => item.id === value)[0]
      //update-begin-author:sunjianlei date:20220111 for: 【JTC-702】【菜单搜索】菜单搜索里点击跳转的菜单,无法将Token信息传递过去
      if (route.component.includes('layouts/IframePageView')) {
        this.$router.push(route)
      } else {
278
        this.$router.push({ path: route.path })
肖超群 authored
279
280
281
282
283
284
285
286
      }
      //update-end-author:sunjianlei date:20220111 for: 【JTC-702】【菜单搜索】菜单搜索里点击跳转的菜单,无法将Token信息传递过去
      this.searchMenuVisible = false
    },
    // update_end author:sunjianlei date:20191230 for: 解决外部链接打开失败的问题
    /*update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
    /*update_begin author:liushaoqian date:20200507 for: 刷新缓存*/
    clearCache() {
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
      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)
        })
肖超群 authored
304
    }
肖超群 authored
305
    /*update_end author:liushaoqian date:20200507 for: 刷新缓存*/
肖超群 authored
306
  }
肖超群 authored
307
}
肖超群 authored
308
309
310
</script>

<style lang="less" scoped>
肖超群 authored
311
312
313
314
315
/* update_begin author:zhaoxin date:20191129 for: 让搜索框颜色能随主题颜色变换*/
/* update-begin author:sunjianlei date:20191220 for: 解决全局样式冲突问题 */
.user-wrapper .search-input {
  width: 180px;
  color: inherit;
肖超群 authored
316
肖超群 authored
317
318
319
320
321
  /deep/ .ant-select-selection {
    background-color: inherit;
    border: 0;
    border-bottom: 1px solid white;
322
323
    &__placeholder,
    &__field__placeholder {
肖超群 authored
324
      color: inherit;
肖超群 authored
325
326
    }
  }
肖超群 authored
327
328
329
330
}

/* update-end author:sunjianlei date:20191220 for: 解决全局样式冲突问题 */
/* update_end author:zhaoxin date:20191129 for: 让搜索框颜色能随主题颜色变换*/
肖超群 authored
331
332
333
</style>

<style scoped>
肖超群 authored
334
335
336
337
.logout_title {
  color: inherit;
  text-decoration: none;
}
肖超群 authored
338
</style>