You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
1.5 KiB
63 lines
1.5 KiB
import Cookies from 'js-cookie' |
|
|
|
const state = { |
|
sidebar: { |
|
opened: Cookies.get('sidebarStatus') ? !!+Cookies.get('sidebarStatus') : true, |
|
withoutAnimation: false, |
|
hide: false |
|
}, |
|
device: 'desktop', |
|
size: Cookies.get('size') || 'medium' |
|
} |
|
|
|
const 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_SIZE: (state, size) => { |
|
state.size = size |
|
Cookies.set('size', size) |
|
}, |
|
SET_SIDEBAR_HIDE: (state, status) => { |
|
state.sidebar.hide = status |
|
} |
|
} |
|
|
|
const actions = { |
|
toggleSideBar({ commit }) { |
|
commit('TOGGLE_SIDEBAR') |
|
}, |
|
closeSideBar({ commit }, { withoutAnimation }) { |
|
commit('CLOSE_SIDEBAR', withoutAnimation) |
|
}, |
|
toggleDevice({ commit }, device) { |
|
commit('TOGGLE_DEVICE', device) |
|
}, |
|
setSize({ commit }, size) { |
|
commit('SET_SIZE', size) |
|
}, |
|
toggleSideBarHide({ commit }, status) { |
|
commit('SET_SIDEBAR_HIDE', status) |
|
} |
|
} |
|
|
|
export default { |
|
namespaced: true, |
|
state, |
|
mutations, |
|
actions |
|
}
|
|
|