import Cookies from 'js-cookie' import { constantRoutes } from '@/router' const app = { state: { sidebar: { opened: Cookies.get('sidebarStatus') ? !!+Cookies.get('sidebarStatus') : true, withoutAnimation: false }, routes:[], device: 'desktop', language: Cookies.get('language') || 'en', size: Cookies.get('size') || 'medium' }, mutations: { TOGGLE_SIDEBAR: state => { state.sidebar.opened = !state.sidebar.opened state.sidebar.withoutAnimation = false if (state.sidebar.opened) { Cookies.set('sidebarStatus', 1) } else { Cookies.set('sidebarStatus', 0) } }, CLOSE_SIDEBAR: (state, withoutAnimation) => { Cookies.set('sidebarStatus', 0) state.sidebar.opened = false state.sidebar.withoutAnimation = withoutAnimation }, TOGGLE_DEVICE: (state, device) => { state.device = device }, SET_LANGUAGE: (state, language) => { state.language = language Cookies.set('language', language) }, SET_SIZE: (state, size) => { state.size = size Cookies.set('size', size) }, SET_ROUTES: (state, routes) => { state.addRoutes = routes state.routes = routes }, }, actions: { GenerateRoutes({ commit }, data) { return new Promise(resolve => { // const { roles } = data commit('SET_ROUTES', constantRoutes) resolve(constantRoutes) }) }, toggleSideBar({ commit }) { commit('TOGGLE_SIDEBAR') }, closeSideBar({ commit }, { withoutAnimation }) { commit('CLOSE_SIDEBAR', withoutAnimation) }, toggleDevice({ commit }, device) { commit('TOGGLE_DEVICE', device) }, setLanguage({ commit }, language) { commit('SET_LANGUAGE', language) }, setSize({ commit }, size) { commit('SET_SIZE', size) } } } export default app