Files
mind-map/web/src/store.js
2024-01-19 16:29:50 +08:00

89 lines
2.0 KiB
JavaScript

import Vue from 'vue'
import Vuex from 'vuex'
import exampleData from 'simple-mind-map/example/exampleData'
import { storeLocalConfig } from '@/api'
Vue.use(Vuex)
const store = new Vuex.Store({
state: {
mindMapData: null, // 思维导图数据
isHandleLocalFile: false, // 是否操作的是本地文件
localConfig: {
// 本地配置
isZenMode: false, // 是否是禅模式
// 是否开启节点富文本
openNodeRichText: true,
// 鼠标行为
useLeftKeySelectionRightKeyDrag: false,
// 是否显示滚动条
isShowScrollbar: false,
// 是否开启手绘风格
isUseHandDrawnLikeStyle: false
},
activeSidebar: '', // 当前显示的侧边栏
isDark: false, // 是否是暗黑模式
isOutlineEdit: false, // 是否是大纲编辑模式
isReadonly: false // 是否只读
},
mutations: {
// 设置思维导图数据
setMindMapData(state, data) {
state.mindMapData = data
},
// 设置操作本地文件标志位
setIsHandleLocalFile(state, data) {
state.isHandleLocalFile = data
},
// 设置本地配置
setLocalConfig(state, data) {
state.localConfig = {
...state.localConfig,
...data
}
storeLocalConfig(state.localConfig)
},
// 设置当前显示的侧边栏
setActiveSidebar(state, data) {
state.activeSidebar = data
},
// 设置暗黑模式
setIsDark(state, data) {
state.isDark = data
},
// 设置大纲编辑模式
setIsOutlineEdit(state, data) {
state.isOutlineEdit = data
},
// 设置是否只读
setIsReadonly(state, data) {
state.isReadonly = data
}
},
actions: {
// 设置初始思维导图数据
getUserMindMapData(ctx) {
try {
let { data } = {
data: {
data: {
mindMapData: exampleData
}
}
}
ctx.commit('setMindMapData', data.data)
} catch (error) {
console.log(error)
}
}
}
})
export default store