import ncc from '@/utils/ncc' import { getLanguage } from '@/lang/index' const state = { sidebar: { opened: ncc.storageGet('sidebarStatus') ? !!+ncc.storageGet('sidebarStatus') : true, withoutAnimation: false }, device: 'desktop', language: getLanguage(), size: ncc.storageGet('size') || 'medium' } const mutations = { TOGGLE_SIDEBAR: state => { state.sidebar.opened = !state.sidebar.opened state.sidebar.withoutAnimation = false if (state.sidebar.opened) { ncc.storageSet({ sidebarStatus: 1 }) } else { ncc.storageSet({ sidebarStatus: 0 }) } }, CLOSE_SIDEBAR: (state, withoutAnimation) => { ncc.storageSet({ sidebarStatus: 0 }) state.sidebar.opened = false state.sidebar.withoutAnimation = withoutAnimation }, TOGGLE_DEVICE: (state, device) => { state.device = device }, SET_LANGUAGE: (state, language) => { state.language = language ncc.storageSet({ language }) }, SET_SIZE: (state, size) => { state.size = size ncc.storageSet({ size }) } } const actions = { 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 { namespaced: true, state, mutations, actions }