index.js 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. import Vue from 'vue'
  2. import Vuex from 'vuex'
  3. import getters from './getters'
  4. import app from './modules/app'
  5. import settings from './modules/settings'
  6. import user from './modules/user'
  7. import { login, loginERP, logout, getInfo } from '@/api/user'
  8. import { getToken, setToken, removeToken } from '@/utils/auth'
  9. import router from '../router/index'
  10. /* Layout */
  11. import Layout from '@/layout'
  12. Vue.use(Vuex)
  13. const getDefaultState = () => {
  14. return {
  15. token: getToken(),
  16. name: '',
  17. avatar: '',
  18. routes: []
  19. }
  20. }
  21. const state = getDefaultState()
  22. const mutations = {
  23. RESET_STATE: (state) => {
  24. Object.assign(state, getDefaultState())
  25. },
  26. // SET_TOKEN: (state, token) => {
  27. // state.token = token
  28. // },
  29. // SET_NAME: (state, name) => {
  30. // state.name = name
  31. // },
  32. // SET_AVATAR: (state, avatar) => {
  33. // state.avatar = avatar
  34. // },
  35. SET_TOKEN: (state, token) => {
  36. state.token = token
  37. },
  38. SET_NAME: (state, name) => {
  39. state.name = name
  40. },
  41. SET_AVATAR: (state, avatar) => {
  42. state.avatar = avatar
  43. },
  44. SET_ROLES: (state, roles) => {
  45. state.roles = roles
  46. },
  47. SET_PERMISSIONS: (state, permissions) => {
  48. state.permissions = permissions
  49. },
  50. // 移除用户
  51. REMOVE: (state) => {
  52. state.name = ''
  53. state.addRoutes = []
  54. //退出后,改变还原静态路由
  55. removeArrayData(constantRoutes)
  56. },
  57. ADD_ROUTES: (state, routes) => {
  58. state.addRoutes = routes
  59. routes.forEach((i, index) => {
  60. // 从第3+index个位置插入
  61. // constantRoutes.splice(3 + index, 0, i)
  62. })
  63. },
  64. SET_MENULIST: (state, menuList) => {
  65. state.menuList = menuList
  66. }
  67. }
  68. const actions = {
  69. // user login
  70. login({ commit }, userInfo) {
  71. const { username, password, code, uuid } = userInfo
  72. return new Promise((resolve, reject) => {
  73. login({ username: username.trim(), passWord: password, code: code, uuid: uuid }).then(response => {
  74. if (response.status == "SUCCESS") {
  75. commit('SET_TOKEN', response.data)
  76. setToken(response.data)
  77. resolve(response.data)
  78. } else {
  79. reject(response.msg)
  80. }
  81. }).catch(error => {
  82. reject(error)
  83. })
  84. })
  85. },
  86. // 登录PER
  87. LoginERP({ commit }, userInfo) {
  88. return new Promise((resolve, reject) => {
  89. loginERP({username:userInfo.username,password:userInfo.password}).then(response => {
  90. if (response.status == "SUCCESS") {
  91. setToken(response.data)
  92. commit('SET_TOKEN', response.data)
  93. resolve()
  94. }else{
  95. reject(response.msg)
  96. }
  97. }).catch(error => {
  98. reject(error)
  99. })
  100. })
  101. },
  102. // get user info
  103. getInfo() {
  104. return new Promise((resolve, reject) => {
  105. getInfo().then(response => {
  106. let data = response.data
  107. var arrayList = [];
  108. for (let i = 0; i < data.length; i++) {
  109. arrayList.push({
  110. path: (data[i].path).slice(1, 8),
  111. component: Layout,
  112. redirect: (data[i].path).slice(1, 8),
  113. name: data[i].name,
  114. meta: {
  115. title: data[i].meta.title,
  116. icon: data[i].meta.icon
  117. },
  118. children: []
  119. })
  120. for (let j = 0; j < data[i].children.length; j++) {
  121. var new_response = data[i].children[j].meta
  122. //var url = (data[i].children[j].path).slice(8, -2)
  123. var url = data[i].children[j].path
  124. arrayList[i].children.push({
  125. path: url,
  126. name: new_response.title,
  127. component: (resolve) => require([`@/views${data[i].children[j].path}`], resolve),
  128. meta: {
  129. title: new_response.title,
  130. icon: new_response.icon
  131. }
  132. })
  133. }
  134. }
  135. var header = [
  136. {
  137. path: '/index',
  138. component: () =>
  139. import ('@/views/index/index'),
  140. hidden: true,
  141. },
  142. {
  143. path: '/',
  144. component: Layout,
  145. redirect: '/index',
  146. children: [{
  147. path: 'index',
  148. name: 'index',
  149. component: () =>
  150. import ('@/views/index/index'),
  151. meta: { title: '首页', icon: 'home' }
  152. }]
  153. },
  154. ]
  155. // 404 page must be placed at the end !!!
  156. let footer = {
  157. path: '*',
  158. redirect: '/404',
  159. hidden: true
  160. }
  161. header[2] = arrayList[0]
  162. arrayList.unshift(header[1])
  163. arrayList.unshift(header[0])
  164. arrayList.push(footer)
  165. router.options.routes = arrayList
  166. state.app.routes = router.options.routes
  167. router.addRoutes(arrayList)
  168. }).catch(error => {
  169. reject(error)
  170. })
  171. })
  172. },
  173. // user logout
  174. logout({ commit, state }) {
  175. return new Promise((resolve, reject) => {
  176. logout().then((response) => {
  177. removeToken() // must remove token first
  178. // resetRouter()
  179. commit('RESET_STATE')
  180. commit('SET_TOKEN', '')
  181. commit('SET_ROLES', [])
  182. commit('SET_PERMISSIONS', [])
  183. removeToken()
  184. resolve()
  185. }).catch(error => {
  186. reject(error)
  187. })
  188. })
  189. },
  190. // remove token
  191. resetToken({ commit }) {
  192. return new Promise(resolve => {
  193. removeToken() // must remove token first
  194. commit('RESET_STATE')
  195. resolve()
  196. })
  197. }
  198. }
  199. const store = new Vuex.Store({
  200. modules: {
  201. app,
  202. settings,
  203. user
  204. },
  205. getters,
  206. actions,
  207. state,
  208. mutations,
  209. router
  210. })
  211. export default store