Files
mes-ui-d2/src/store/modules/d2admin/modules/db.js
liyang 7c97a2ed0d db
Former-commit-id: 9f32760c2d5d596dfc7d9ecb1dd3f99bc61215d0 [formerly 9f32760c2d5d596dfc7d9ecb1dd3f99bc61215d0 [formerly 9f32760c2d5d596dfc7d9ecb1dd3f99bc61215d0 [formerly 9f32760c2d5d596dfc7d9ecb1dd3f99bc61215d0 [formerly 44e078233f2b9068249242a4f0d22da3b9f9d245 [formerly 81fcc38ee29c1ccadcbf36e89808a51bc740b109]]]]]
Former-commit-id: 88c21c763a38b1c96cd1559dcd216974afc02982
Former-commit-id: d8ee29045146a021c9cd4142d5eebc68c30247a7
Former-commit-id: e17ce19dcf1661329479f6bcb5da1b99ea9be644 [formerly 3d003c11b1146d68e5afae500b842015d6e74fae]
Former-commit-id: 6ac226c6a31c71caa1f956a942ef279edc835e81
Former-commit-id: 97da1683261d845bea6b51970921bc451635d181
Former-commit-id: 7abd67bfa7ea8d91a3d99c382dadefdc26c80bcd
Former-commit-id: 1c2f4d95e8553b1545d7343be38b52148228a7a6
Former-commit-id: a701b5faf7299f58f46fd2dbe5484274872497f7
2018-08-09 23:39:51 +08:00

139 lines
4.2 KiB
JavaScript

import db from '@/libs/db.js'
import util from '@/libs/util.js'
/**
* @description 检查路径是否存在 不存在的话初始化
* @param {Object} param dbName {String} 数据库名称
* @param {Object} param path {String} 路径
* @param {Object} param validator {Function} 数据校验钩子 返回 true 表示验证通过
* @param {Object} param defaultValue {*} 初始化默认值
*/
function pathInit ({
dbName = 'db',
path = '',
validator = () => true,
defaultValue = ''
}) {
const sys = db.get(dbName)
const value = sys.get(path).value()
if (!(value && validator(value))) {
sys
.set(path, defaultValue)
.write()
}
return sys.get(path)
}
/**
* @description 检查路径下是否有当前用户的档案
* @param {Object} param dbName {String} 数据库名称
* @param {Object} param path {String} 路径
*/
function isRowExistByUser ({
dbName = 'sys',
path = ''
}) {
const sys = db.get(dbName)
const row = sys
.get(path)
.find({
uuid: util.cookies.get('uuid')
})
// 返回可以操作的 row 或者布尔值 false
// 外部判断返回值的时候建议使用 if (!isRowExistByUser({}))
if (row.value()) {
return row
} else {
return false
}
}
export default {
namespaced: true,
mutations: {
/**
* @description 将数据存储到指定位置 | 路径不存在会自动初始化 [不区分用户]
* @description 效果类似于 dbName.path = value
* @param {Object} state vuex state
* @param {Object} param dbName {String} 数据库名称
* @param {Object} param path {String} 存储路径
* @param {Object} param value {*} 需要存储的值
*/
set (state, { dbName = 'db', path = '', value = '' }) {
db
.get(dbName)
.set(path, value)
.write()
},
/**
* @description 将数据 push 到指定位置 | 路径不存在会自动初始化 [不区分用户]
* @description 效果类似于 dbName.path.push(value)
* @param {Object} state vuex state
* @param {Object} param dbName {String} 数据库名称
* @param {Object} param path {String} 存储路径
* @param {Object} param value {*} 需要存储的值
*/
push (state, { dbName = 'db', path = '', value = '' }) {
pathInit({
dbName,
path,
validator: value => Array.isArray(value),
defaultValue: []
})
.push(value)
.write()
},
/**
* @description 将数据存储到指定位置 | 路径不存在会自动初始化 [区分用户]
* @description 效果类似于 dbName.path[user] = value
* @param {Object} state vuex state
* @param {Object} param dbName {String} 数据库名称
* @param {Object} param path {String} 存储路径
* @param {Object} param value {*} 需要存储的值
*/
setByUser (state, {
dbName = 'db',
path = '',
value = ''
}) {
// 得到路径在数据库中的对象 没有初始化会自动初始化
// ByUser 类型的默认值设置为数组
// 以后数组的每一项是一个用户的存档
const currentPath = pathInit({ dbName, path, defaultValue: [] })
// 得到当前用户在数据库此路径下的存档
const row = isRowExistByUser({ dbName, path })
// 合并 or 追加
if (!row) {
currentPath.push({
uuid: util.cookies.get('uuid'),
value
}).write()
} else {
row.assign({ value }).write()
}
}
},
actions: {
/**
* @description 获取数据 [区分用户]
* @description 效果类似于 dbName.path[user] || defaultValue
* @param {Object} state vuex state
* @param {Object} param dbName {String} 数据库名称
* @param {Object} param path {String} 存储路径
* @param {Object} param defaultValue {*} 取值失败的默认值
*/
getByUser (context, {
dbName = 'db',
path = '',
defaultValue = ''
}) {
return new Promise((resolve, reject) => {
// 得到当前用户在数据库此路径下的存档
const row = isRowExistByUser({ path })
// 返回存档或者默认值
resolve(!row ? defaultValue : row.value().value)
})
}
}
}