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.
1201 lines
35 KiB
1201 lines
35 KiB
1 month ago
|
import {
|
||
|
setupDevtoolsPlugin
|
||
|
} from "./chunk-V6ULMDHA.js";
|
||
|
import {
|
||
|
computed,
|
||
|
effectScope,
|
||
|
inject,
|
||
|
reactive,
|
||
|
watch
|
||
|
} from "./chunk-SBKZIOJ7.js";
|
||
|
import "./chunk-4YJPEX7N.js";
|
||
|
|
||
|
// node_modules/vuex/dist/vuex.esm-bundler.js
|
||
|
var storeKey = "store";
|
||
|
function useStore(key) {
|
||
|
if (key === void 0)
|
||
|
key = null;
|
||
|
return inject(key !== null ? key : storeKey);
|
||
|
}
|
||
|
function find(list, f) {
|
||
|
return list.filter(f)[0];
|
||
|
}
|
||
|
function deepCopy(obj, cache) {
|
||
|
if (cache === void 0)
|
||
|
cache = [];
|
||
|
if (obj === null || typeof obj !== "object") {
|
||
|
return obj;
|
||
|
}
|
||
|
var hit = find(cache, function(c) {
|
||
|
return c.original === obj;
|
||
|
});
|
||
|
if (hit) {
|
||
|
return hit.copy;
|
||
|
}
|
||
|
var copy = Array.isArray(obj) ? [] : {};
|
||
|
cache.push({
|
||
|
original: obj,
|
||
|
copy
|
||
|
});
|
||
|
Object.keys(obj).forEach(function(key) {
|
||
|
copy[key] = deepCopy(obj[key], cache);
|
||
|
});
|
||
|
return copy;
|
||
|
}
|
||
|
function forEachValue(obj, fn) {
|
||
|
Object.keys(obj).forEach(function(key) {
|
||
|
return fn(obj[key], key);
|
||
|
});
|
||
|
}
|
||
|
function isObject(obj) {
|
||
|
return obj !== null && typeof obj === "object";
|
||
|
}
|
||
|
function isPromise(val) {
|
||
|
return val && typeof val.then === "function";
|
||
|
}
|
||
|
function assert(condition, msg) {
|
||
|
if (!condition) {
|
||
|
throw new Error("[vuex] " + msg);
|
||
|
}
|
||
|
}
|
||
|
function partial(fn, arg) {
|
||
|
return function() {
|
||
|
return fn(arg);
|
||
|
};
|
||
|
}
|
||
|
function genericSubscribe(fn, subs, options) {
|
||
|
if (subs.indexOf(fn) < 0) {
|
||
|
options && options.prepend ? subs.unshift(fn) : subs.push(fn);
|
||
|
}
|
||
|
return function() {
|
||
|
var i = subs.indexOf(fn);
|
||
|
if (i > -1) {
|
||
|
subs.splice(i, 1);
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
function resetStore(store, hot) {
|
||
|
store._actions = Object.create(null);
|
||
|
store._mutations = Object.create(null);
|
||
|
store._wrappedGetters = Object.create(null);
|
||
|
store._modulesNamespaceMap = Object.create(null);
|
||
|
var state = store.state;
|
||
|
installModule(store, state, [], store._modules.root, true);
|
||
|
resetStoreState(store, state, hot);
|
||
|
}
|
||
|
function resetStoreState(store, state, hot) {
|
||
|
var oldState = store._state;
|
||
|
var oldScope = store._scope;
|
||
|
store.getters = {};
|
||
|
store._makeLocalGettersCache = Object.create(null);
|
||
|
var wrappedGetters = store._wrappedGetters;
|
||
|
var computedObj = {};
|
||
|
var computedCache = {};
|
||
|
var scope = effectScope(true);
|
||
|
scope.run(function() {
|
||
|
forEachValue(wrappedGetters, function(fn, key) {
|
||
|
computedObj[key] = partial(fn, store);
|
||
|
computedCache[key] = computed(function() {
|
||
|
return computedObj[key]();
|
||
|
});
|
||
|
Object.defineProperty(store.getters, key, {
|
||
|
get: function() {
|
||
|
return computedCache[key].value;
|
||
|
},
|
||
|
enumerable: true
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
store._state = reactive({
|
||
|
data: state
|
||
|
});
|
||
|
store._scope = scope;
|
||
|
if (store.strict) {
|
||
|
enableStrictMode(store);
|
||
|
}
|
||
|
if (oldState) {
|
||
|
if (hot) {
|
||
|
store._withCommit(function() {
|
||
|
oldState.data = null;
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
if (oldScope) {
|
||
|
oldScope.stop();
|
||
|
}
|
||
|
}
|
||
|
function installModule(store, rootState, path, module, hot) {
|
||
|
var isRoot = !path.length;
|
||
|
var namespace = store._modules.getNamespace(path);
|
||
|
if (module.namespaced) {
|
||
|
if (store._modulesNamespaceMap[namespace] && true) {
|
||
|
console.error("[vuex] duplicate namespace " + namespace + " for the namespaced module " + path.join("/"));
|
||
|
}
|
||
|
store._modulesNamespaceMap[namespace] = module;
|
||
|
}
|
||
|
if (!isRoot && !hot) {
|
||
|
var parentState = getNestedState(rootState, path.slice(0, -1));
|
||
|
var moduleName = path[path.length - 1];
|
||
|
store._withCommit(function() {
|
||
|
if (true) {
|
||
|
if (moduleName in parentState) {
|
||
|
console.warn('[vuex] state field "' + moduleName + '" was overridden by a module with the same name at "' + path.join(".") + '"');
|
||
|
}
|
||
|
}
|
||
|
parentState[moduleName] = module.state;
|
||
|
});
|
||
|
}
|
||
|
var local = module.context = makeLocalContext(store, namespace, path);
|
||
|
module.forEachMutation(function(mutation, key) {
|
||
|
var namespacedType = namespace + key;
|
||
|
registerMutation(store, namespacedType, mutation, local);
|
||
|
});
|
||
|
module.forEachAction(function(action, key) {
|
||
|
var type = action.root ? key : namespace + key;
|
||
|
var handler = action.handler || action;
|
||
|
registerAction(store, type, handler, local);
|
||
|
});
|
||
|
module.forEachGetter(function(getter, key) {
|
||
|
var namespacedType = namespace + key;
|
||
|
registerGetter(store, namespacedType, getter, local);
|
||
|
});
|
||
|
module.forEachChild(function(child, key) {
|
||
|
installModule(store, rootState, path.concat(key), child, hot);
|
||
|
});
|
||
|
}
|
||
|
function makeLocalContext(store, namespace, path) {
|
||
|
var noNamespace = namespace === "";
|
||
|
var local = {
|
||
|
dispatch: noNamespace ? store.dispatch : function(_type, _payload, _options) {
|
||
|
var args = unifyObjectStyle(_type, _payload, _options);
|
||
|
var payload = args.payload;
|
||
|
var options = args.options;
|
||
|
var type = args.type;
|
||
|
if (!options || !options.root) {
|
||
|
type = namespace + type;
|
||
|
if (!store._actions[type]) {
|
||
|
console.error("[vuex] unknown local action type: " + args.type + ", global type: " + type);
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
return store.dispatch(type, payload);
|
||
|
},
|
||
|
commit: noNamespace ? store.commit : function(_type, _payload, _options) {
|
||
|
var args = unifyObjectStyle(_type, _payload, _options);
|
||
|
var payload = args.payload;
|
||
|
var options = args.options;
|
||
|
var type = args.type;
|
||
|
if (!options || !options.root) {
|
||
|
type = namespace + type;
|
||
|
if (!store._mutations[type]) {
|
||
|
console.error("[vuex] unknown local mutation type: " + args.type + ", global type: " + type);
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
store.commit(type, payload, options);
|
||
|
}
|
||
|
};
|
||
|
Object.defineProperties(local, {
|
||
|
getters: {
|
||
|
get: noNamespace ? function() {
|
||
|
return store.getters;
|
||
|
} : function() {
|
||
|
return makeLocalGetters(store, namespace);
|
||
|
}
|
||
|
},
|
||
|
state: {
|
||
|
get: function() {
|
||
|
return getNestedState(store.state, path);
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
return local;
|
||
|
}
|
||
|
function makeLocalGetters(store, namespace) {
|
||
|
if (!store._makeLocalGettersCache[namespace]) {
|
||
|
var gettersProxy = {};
|
||
|
var splitPos = namespace.length;
|
||
|
Object.keys(store.getters).forEach(function(type) {
|
||
|
if (type.slice(0, splitPos) !== namespace) {
|
||
|
return;
|
||
|
}
|
||
|
var localType = type.slice(splitPos);
|
||
|
Object.defineProperty(gettersProxy, localType, {
|
||
|
get: function() {
|
||
|
return store.getters[type];
|
||
|
},
|
||
|
enumerable: true
|
||
|
});
|
||
|
});
|
||
|
store._makeLocalGettersCache[namespace] = gettersProxy;
|
||
|
}
|
||
|
return store._makeLocalGettersCache[namespace];
|
||
|
}
|
||
|
function registerMutation(store, type, handler, local) {
|
||
|
var entry = store._mutations[type] || (store._mutations[type] = []);
|
||
|
entry.push(function wrappedMutationHandler(payload) {
|
||
|
handler.call(store, local.state, payload);
|
||
|
});
|
||
|
}
|
||
|
function registerAction(store, type, handler, local) {
|
||
|
var entry = store._actions[type] || (store._actions[type] = []);
|
||
|
entry.push(function wrappedActionHandler(payload) {
|
||
|
var res = handler.call(store, {
|
||
|
dispatch: local.dispatch,
|
||
|
commit: local.commit,
|
||
|
getters: local.getters,
|
||
|
state: local.state,
|
||
|
rootGetters: store.getters,
|
||
|
rootState: store.state
|
||
|
}, payload);
|
||
|
if (!isPromise(res)) {
|
||
|
res = Promise.resolve(res);
|
||
|
}
|
||
|
if (store._devtoolHook) {
|
||
|
return res.catch(function(err) {
|
||
|
store._devtoolHook.emit("vuex:error", err);
|
||
|
throw err;
|
||
|
});
|
||
|
} else {
|
||
|
return res;
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
function registerGetter(store, type, rawGetter, local) {
|
||
|
if (store._wrappedGetters[type]) {
|
||
|
if (true) {
|
||
|
console.error("[vuex] duplicate getter key: " + type);
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
store._wrappedGetters[type] = function wrappedGetter(store2) {
|
||
|
return rawGetter(local.state, local.getters, store2.state, store2.getters);
|
||
|
};
|
||
|
}
|
||
|
function enableStrictMode(store) {
|
||
|
watch(function() {
|
||
|
return store._state.data;
|
||
|
}, function() {
|
||
|
if (true) {
|
||
|
assert(store._committing, "do not mutate vuex store state outside mutation handlers.");
|
||
|
}
|
||
|
}, { deep: true, flush: "sync" });
|
||
|
}
|
||
|
function getNestedState(state, path) {
|
||
|
return path.reduce(function(state2, key) {
|
||
|
return state2[key];
|
||
|
}, state);
|
||
|
}
|
||
|
function unifyObjectStyle(type, payload, options) {
|
||
|
if (isObject(type) && type.type) {
|
||
|
options = payload;
|
||
|
payload = type;
|
||
|
type = type.type;
|
||
|
}
|
||
|
if (true) {
|
||
|
assert(typeof type === "string", "expects string as the type, but found " + typeof type + ".");
|
||
|
}
|
||
|
return { type, payload, options };
|
||
|
}
|
||
|
var LABEL_VUEX_BINDINGS = "vuex bindings";
|
||
|
var MUTATIONS_LAYER_ID = "vuex:mutations";
|
||
|
var ACTIONS_LAYER_ID = "vuex:actions";
|
||
|
var INSPECTOR_ID = "vuex";
|
||
|
var actionId = 0;
|
||
|
function addDevtools(app, store) {
|
||
|
setupDevtoolsPlugin({
|
||
|
id: "org.vuejs.vuex",
|
||
|
app,
|
||
|
label: "Vuex",
|
||
|
homepage: "https://next.vuex.vuejs.org/",
|
||
|
logo: "https://vuejs.org/images/icons/favicon-96x96.png",
|
||
|
packageName: "vuex",
|
||
|
componentStateTypes: [LABEL_VUEX_BINDINGS]
|
||
|
}, function(api) {
|
||
|
api.addTimelineLayer({
|
||
|
id: MUTATIONS_LAYER_ID,
|
||
|
label: "Vuex Mutations",
|
||
|
color: COLOR_LIME_500
|
||
|
});
|
||
|
api.addTimelineLayer({
|
||
|
id: ACTIONS_LAYER_ID,
|
||
|
label: "Vuex Actions",
|
||
|
color: COLOR_LIME_500
|
||
|
});
|
||
|
api.addInspector({
|
||
|
id: INSPECTOR_ID,
|
||
|
label: "Vuex",
|
||
|
icon: "storage",
|
||
|
treeFilterPlaceholder: "Filter stores..."
|
||
|
});
|
||
|
api.on.getInspectorTree(function(payload) {
|
||
|
if (payload.app === app && payload.inspectorId === INSPECTOR_ID) {
|
||
|
if (payload.filter) {
|
||
|
var nodes = [];
|
||
|
flattenStoreForInspectorTree(nodes, store._modules.root, payload.filter, "");
|
||
|
payload.rootNodes = nodes;
|
||
|
} else {
|
||
|
payload.rootNodes = [
|
||
|
formatStoreForInspectorTree(store._modules.root, "")
|
||
|
];
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
api.on.getInspectorState(function(payload) {
|
||
|
if (payload.app === app && payload.inspectorId === INSPECTOR_ID) {
|
||
|
var modulePath = payload.nodeId;
|
||
|
makeLocalGetters(store, modulePath);
|
||
|
payload.state = formatStoreForInspectorState(getStoreModule(store._modules, modulePath), modulePath === "root" ? store.getters : store._makeLocalGettersCache, modulePath);
|
||
|
}
|
||
|
});
|
||
|
api.on.editInspectorState(function(payload) {
|
||
|
if (payload.app === app && payload.inspectorId === INSPECTOR_ID) {
|
||
|
var modulePath = payload.nodeId;
|
||
|
var path = payload.path;
|
||
|
if (modulePath !== "root") {
|
||
|
path = modulePath.split("/").filter(Boolean).concat(path);
|
||
|
}
|
||
|
store._withCommit(function() {
|
||
|
payload.set(store._state.data, path, payload.state.value);
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
store.subscribe(function(mutation, state) {
|
||
|
var data = {};
|
||
|
if (mutation.payload) {
|
||
|
data.payload = mutation.payload;
|
||
|
}
|
||
|
data.state = state;
|
||
|
api.notifyComponentUpdate();
|
||
|
api.sendInspectorTree(INSPECTOR_ID);
|
||
|
api.sendInspectorState(INSPECTOR_ID);
|
||
|
api.addTimelineEvent({
|
||
|
layerId: MUTATIONS_LAYER_ID,
|
||
|
event: {
|
||
|
time: Date.now(),
|
||
|
title: mutation.type,
|
||
|
data
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
store.subscribeAction({
|
||
|
before: function(action, state) {
|
||
|
var data = {};
|
||
|
if (action.payload) {
|
||
|
data.payload = action.payload;
|
||
|
}
|
||
|
action._id = actionId++;
|
||
|
action._time = Date.now();
|
||
|
data.state = state;
|
||
|
api.addTimelineEvent({
|
||
|
layerId: ACTIONS_LAYER_ID,
|
||
|
event: {
|
||
|
time: action._time,
|
||
|
title: action.type,
|
||
|
groupId: action._id,
|
||
|
subtitle: "start",
|
||
|
data
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
after: function(action, state) {
|
||
|
var data = {};
|
||
|
var duration = Date.now() - action._time;
|
||
|
data.duration = {
|
||
|
_custom: {
|
||
|
type: "duration",
|
||
|
display: duration + "ms",
|
||
|
tooltip: "Action duration",
|
||
|
value: duration
|
||
|
}
|
||
|
};
|
||
|
if (action.payload) {
|
||
|
data.payload = action.payload;
|
||
|
}
|
||
|
data.state = state;
|
||
|
api.addTimelineEvent({
|
||
|
layerId: ACTIONS_LAYER_ID,
|
||
|
event: {
|
||
|
time: Date.now(),
|
||
|
title: action.type,
|
||
|
groupId: action._id,
|
||
|
subtitle: "end",
|
||
|
data
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
var COLOR_LIME_500 = 8702998;
|
||
|
var COLOR_DARK = 6710886;
|
||
|
var COLOR_WHITE = 16777215;
|
||
|
var TAG_NAMESPACED = {
|
||
|
label: "namespaced",
|
||
|
textColor: COLOR_WHITE,
|
||
|
backgroundColor: COLOR_DARK
|
||
|
};
|
||
|
function extractNameFromPath(path) {
|
||
|
return path && path !== "root" ? path.split("/").slice(-2, -1)[0] : "Root";
|
||
|
}
|
||
|
function formatStoreForInspectorTree(module, path) {
|
||
|
return {
|
||
|
id: path || "root",
|
||
|
label: extractNameFromPath(path),
|
||
|
tags: module.namespaced ? [TAG_NAMESPACED] : [],
|
||
|
children: Object.keys(module._children).map(function(moduleName) {
|
||
|
return formatStoreForInspectorTree(module._children[moduleName], path + moduleName + "/");
|
||
|
})
|
||
|
};
|
||
|
}
|
||
|
function flattenStoreForInspectorTree(result, module, filter, path) {
|
||
|
if (path.includes(filter)) {
|
||
|
result.push({
|
||
|
id: path || "root",
|
||
|
label: path.endsWith("/") ? path.slice(0, path.length - 1) : path || "Root",
|
||
|
tags: module.namespaced ? [TAG_NAMESPACED] : []
|
||
|
});
|
||
|
}
|
||
|
Object.keys(module._children).forEach(function(moduleName) {
|
||
|
flattenStoreForInspectorTree(result, module._children[moduleName], filter, path + moduleName + "/");
|
||
|
});
|
||
|
}
|
||
|
function formatStoreForInspectorState(module, getters, path) {
|
||
|
getters = path === "root" ? getters : getters[path];
|
||
|
var gettersKeys = Object.keys(getters);
|
||
|
var storeState = {
|
||
|
state: Object.keys(module.state).map(function(key) {
|
||
|
return {
|
||
|
key,
|
||
|
editable: true,
|
||
|
value: module.state[key]
|
||
|
};
|
||
|
})
|
||
|
};
|
||
|
if (gettersKeys.length) {
|
||
|
var tree = transformPathsToObjectTree(getters);
|
||
|
storeState.getters = Object.keys(tree).map(function(key) {
|
||
|
return {
|
||
|
key: key.endsWith("/") ? extractNameFromPath(key) : key,
|
||
|
editable: false,
|
||
|
value: canThrow(function() {
|
||
|
return tree[key];
|
||
|
})
|
||
|
};
|
||
|
});
|
||
|
}
|
||
|
return storeState;
|
||
|
}
|
||
|
function transformPathsToObjectTree(getters) {
|
||
|
var result = {};
|
||
|
Object.keys(getters).forEach(function(key) {
|
||
|
var path = key.split("/");
|
||
|
if (path.length > 1) {
|
||
|
var target = result;
|
||
|
var leafKey = path.pop();
|
||
|
path.forEach(function(p) {
|
||
|
if (!target[p]) {
|
||
|
target[p] = {
|
||
|
_custom: {
|
||
|
value: {},
|
||
|
display: p,
|
||
|
tooltip: "Module",
|
||
|
abstract: true
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
target = target[p]._custom.value;
|
||
|
});
|
||
|
target[leafKey] = canThrow(function() {
|
||
|
return getters[key];
|
||
|
});
|
||
|
} else {
|
||
|
result[key] = canThrow(function() {
|
||
|
return getters[key];
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
return result;
|
||
|
}
|
||
|
function getStoreModule(moduleMap, path) {
|
||
|
var names = path.split("/").filter(function(n) {
|
||
|
return n;
|
||
|
});
|
||
|
return names.reduce(function(module, moduleName, i) {
|
||
|
var child = module[moduleName];
|
||
|
if (!child) {
|
||
|
throw new Error('Missing module "' + moduleName + '" for path "' + path + '".');
|
||
|
}
|
||
|
return i === names.length - 1 ? child : child._children;
|
||
|
}, path === "root" ? moduleMap : moduleMap.root._children);
|
||
|
}
|
||
|
function canThrow(cb) {
|
||
|
try {
|
||
|
return cb();
|
||
|
} catch (e) {
|
||
|
return e;
|
||
|
}
|
||
|
}
|
||
|
var Module = function Module2(rawModule, runtime) {
|
||
|
this.runtime = runtime;
|
||
|
this._children = Object.create(null);
|
||
|
this._rawModule = rawModule;
|
||
|
var rawState = rawModule.state;
|
||
|
this.state = (typeof rawState === "function" ? rawState() : rawState) || {};
|
||
|
};
|
||
|
var prototypeAccessors$1 = { namespaced: { configurable: true } };
|
||
|
prototypeAccessors$1.namespaced.get = function() {
|
||
|
return !!this._rawModule.namespaced;
|
||
|
};
|
||
|
Module.prototype.addChild = function addChild(key, module) {
|
||
|
this._children[key] = module;
|
||
|
};
|
||
|
Module.prototype.removeChild = function removeChild(key) {
|
||
|
delete this._children[key];
|
||
|
};
|
||
|
Module.prototype.getChild = function getChild(key) {
|
||
|
return this._children[key];
|
||
|
};
|
||
|
Module.prototype.hasChild = function hasChild(key) {
|
||
|
return key in this._children;
|
||
|
};
|
||
|
Module.prototype.update = function update(rawModule) {
|
||
|
this._rawModule.namespaced = rawModule.namespaced;
|
||
|
if (rawModule.actions) {
|
||
|
this._rawModule.actions = rawModule.actions;
|
||
|
}
|
||
|
if (rawModule.mutations) {
|
||
|
this._rawModule.mutations = rawModule.mutations;
|
||
|
}
|
||
|
if (rawModule.getters) {
|
||
|
this._rawModule.getters = rawModule.getters;
|
||
|
}
|
||
|
};
|
||
|
Module.prototype.forEachChild = function forEachChild(fn) {
|
||
|
forEachValue(this._children, fn);
|
||
|
};
|
||
|
Module.prototype.forEachGetter = function forEachGetter(fn) {
|
||
|
if (this._rawModule.getters) {
|
||
|
forEachValue(this._rawModule.getters, fn);
|
||
|
}
|
||
|
};
|
||
|
Module.prototype.forEachAction = function forEachAction(fn) {
|
||
|
if (this._rawModule.actions) {
|
||
|
forEachValue(this._rawModule.actions, fn);
|
||
|
}
|
||
|
};
|
||
|
Module.prototype.forEachMutation = function forEachMutation(fn) {
|
||
|
if (this._rawModule.mutations) {
|
||
|
forEachValue(this._rawModule.mutations, fn);
|
||
|
}
|
||
|
};
|
||
|
Object.defineProperties(Module.prototype, prototypeAccessors$1);
|
||
|
var ModuleCollection = function ModuleCollection2(rawRootModule) {
|
||
|
this.register([], rawRootModule, false);
|
||
|
};
|
||
|
ModuleCollection.prototype.get = function get(path) {
|
||
|
return path.reduce(function(module, key) {
|
||
|
return module.getChild(key);
|
||
|
}, this.root);
|
||
|
};
|
||
|
ModuleCollection.prototype.getNamespace = function getNamespace(path) {
|
||
|
var module = this.root;
|
||
|
return path.reduce(function(namespace, key) {
|
||
|
module = module.getChild(key);
|
||
|
return namespace + (module.namespaced ? key + "/" : "");
|
||
|
}, "");
|
||
|
};
|
||
|
ModuleCollection.prototype.update = function update$1(rawRootModule) {
|
||
|
update2([], this.root, rawRootModule);
|
||
|
};
|
||
|
ModuleCollection.prototype.register = function register(path, rawModule, runtime) {
|
||
|
var this$1$1 = this;
|
||
|
if (runtime === void 0)
|
||
|
runtime = true;
|
||
|
if (true) {
|
||
|
assertRawModule(path, rawModule);
|
||
|
}
|
||
|
var newModule = new Module(rawModule, runtime);
|
||
|
if (path.length === 0) {
|
||
|
this.root = newModule;
|
||
|
} else {
|
||
|
var parent = this.get(path.slice(0, -1));
|
||
|
parent.addChild(path[path.length - 1], newModule);
|
||
|
}
|
||
|
if (rawModule.modules) {
|
||
|
forEachValue(rawModule.modules, function(rawChildModule, key) {
|
||
|
this$1$1.register(path.concat(key), rawChildModule, runtime);
|
||
|
});
|
||
|
}
|
||
|
};
|
||
|
ModuleCollection.prototype.unregister = function unregister(path) {
|
||
|
var parent = this.get(path.slice(0, -1));
|
||
|
var key = path[path.length - 1];
|
||
|
var child = parent.getChild(key);
|
||
|
if (!child) {
|
||
|
if (true) {
|
||
|
console.warn("[vuex] trying to unregister module '" + key + "', which is not registered");
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
if (!child.runtime) {
|
||
|
return;
|
||
|
}
|
||
|
parent.removeChild(key);
|
||
|
};
|
||
|
ModuleCollection.prototype.isRegistered = function isRegistered(path) {
|
||
|
var parent = this.get(path.slice(0, -1));
|
||
|
var key = path[path.length - 1];
|
||
|
if (parent) {
|
||
|
return parent.hasChild(key);
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
function update2(path, targetModule, newModule) {
|
||
|
if (true) {
|
||
|
assertRawModule(path, newModule);
|
||
|
}
|
||
|
targetModule.update(newModule);
|
||
|
if (newModule.modules) {
|
||
|
for (var key in newModule.modules) {
|
||
|
if (!targetModule.getChild(key)) {
|
||
|
if (true) {
|
||
|
console.warn("[vuex] trying to add a new module '" + key + "' on hot reloading, manual reload is needed");
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
update2(path.concat(key), targetModule.getChild(key), newModule.modules[key]);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
var functionAssert = {
|
||
|
assert: function(value) {
|
||
|
return typeof value === "function";
|
||
|
},
|
||
|
expected: "function"
|
||
|
};
|
||
|
var objectAssert = {
|
||
|
assert: function(value) {
|
||
|
return typeof value === "function" || typeof value === "object" && typeof value.handler === "function";
|
||
|
},
|
||
|
expected: 'function or object with "handler" function'
|
||
|
};
|
||
|
var assertTypes = {
|
||
|
getters: functionAssert,
|
||
|
mutations: functionAssert,
|
||
|
actions: objectAssert
|
||
|
};
|
||
|
function assertRawModule(path, rawModule) {
|
||
|
Object.keys(assertTypes).forEach(function(key) {
|
||
|
if (!rawModule[key]) {
|
||
|
return;
|
||
|
}
|
||
|
var assertOptions = assertTypes[key];
|
||
|
forEachValue(rawModule[key], function(value, type) {
|
||
|
assert(assertOptions.assert(value), makeAssertionMessage(path, key, type, value, assertOptions.expected));
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
function makeAssertionMessage(path, key, type, value, expected) {
|
||
|
var buf = key + " should be " + expected + ' but "' + key + "." + type + '"';
|
||
|
if (path.length > 0) {
|
||
|
buf += ' in module "' + path.join(".") + '"';
|
||
|
}
|
||
|
buf += " is " + JSON.stringify(value) + ".";
|
||
|
return buf;
|
||
|
}
|
||
|
function createStore(options) {
|
||
|
return new Store(options);
|
||
|
}
|
||
|
var Store = function Store2(options) {
|
||
|
var this$1$1 = this;
|
||
|
if (options === void 0)
|
||
|
options = {};
|
||
|
if (true) {
|
||
|
assert(typeof Promise !== "undefined", "vuex requires a Promise polyfill in this browser.");
|
||
|
assert(this instanceof Store2, "store must be called with the new operator.");
|
||
|
}
|
||
|
var plugins = options.plugins;
|
||
|
if (plugins === void 0)
|
||
|
plugins = [];
|
||
|
var strict = options.strict;
|
||
|
if (strict === void 0)
|
||
|
strict = false;
|
||
|
var devtools = options.devtools;
|
||
|
this._committing = false;
|
||
|
this._actions = Object.create(null);
|
||
|
this._actionSubscribers = [];
|
||
|
this._mutations = Object.create(null);
|
||
|
this._wrappedGetters = Object.create(null);
|
||
|
this._modules = new ModuleCollection(options);
|
||
|
this._modulesNamespaceMap = Object.create(null);
|
||
|
this._subscribers = [];
|
||
|
this._makeLocalGettersCache = Object.create(null);
|
||
|
this._scope = null;
|
||
|
this._devtools = devtools;
|
||
|
var store = this;
|
||
|
var ref = this;
|
||
|
var dispatch2 = ref.dispatch;
|
||
|
var commit2 = ref.commit;
|
||
|
this.dispatch = function boundDispatch(type, payload) {
|
||
|
return dispatch2.call(store, type, payload);
|
||
|
};
|
||
|
this.commit = function boundCommit(type, payload, options2) {
|
||
|
return commit2.call(store, type, payload, options2);
|
||
|
};
|
||
|
this.strict = strict;
|
||
|
var state = this._modules.root.state;
|
||
|
installModule(this, state, [], this._modules.root);
|
||
|
resetStoreState(this, state);
|
||
|
plugins.forEach(function(plugin) {
|
||
|
return plugin(this$1$1);
|
||
|
});
|
||
|
};
|
||
|
var prototypeAccessors = { state: { configurable: true } };
|
||
|
Store.prototype.install = function install(app, injectKey) {
|
||
|
app.provide(injectKey || storeKey, this);
|
||
|
app.config.globalProperties.$store = this;
|
||
|
var useDevtools = this._devtools !== void 0 ? this._devtools : true;
|
||
|
if (useDevtools) {
|
||
|
addDevtools(app, this);
|
||
|
}
|
||
|
};
|
||
|
prototypeAccessors.state.get = function() {
|
||
|
return this._state.data;
|
||
|
};
|
||
|
prototypeAccessors.state.set = function(v) {
|
||
|
if (true) {
|
||
|
assert(false, "use store.replaceState() to explicit replace store state.");
|
||
|
}
|
||
|
};
|
||
|
Store.prototype.commit = function commit(_type, _payload, _options) {
|
||
|
var this$1$1 = this;
|
||
|
var ref = unifyObjectStyle(_type, _payload, _options);
|
||
|
var type = ref.type;
|
||
|
var payload = ref.payload;
|
||
|
var options = ref.options;
|
||
|
var mutation = { type, payload };
|
||
|
var entry = this._mutations[type];
|
||
|
if (!entry) {
|
||
|
if (true) {
|
||
|
console.error("[vuex] unknown mutation type: " + type);
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
this._withCommit(function() {
|
||
|
entry.forEach(function commitIterator(handler) {
|
||
|
handler(payload);
|
||
|
});
|
||
|
});
|
||
|
this._subscribers.slice().forEach(function(sub) {
|
||
|
return sub(mutation, this$1$1.state);
|
||
|
});
|
||
|
if (options && options.silent) {
|
||
|
console.warn("[vuex] mutation type: " + type + ". Silent option has been removed. Use the filter functionality in the vue-devtools");
|
||
|
}
|
||
|
};
|
||
|
Store.prototype.dispatch = function dispatch(_type, _payload) {
|
||
|
var this$1$1 = this;
|
||
|
var ref = unifyObjectStyle(_type, _payload);
|
||
|
var type = ref.type;
|
||
|
var payload = ref.payload;
|
||
|
var action = { type, payload };
|
||
|
var entry = this._actions[type];
|
||
|
if (!entry) {
|
||
|
if (true) {
|
||
|
console.error("[vuex] unknown action type: " + type);
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
try {
|
||
|
this._actionSubscribers.slice().filter(function(sub) {
|
||
|
return sub.before;
|
||
|
}).forEach(function(sub) {
|
||
|
return sub.before(action, this$1$1.state);
|
||
|
});
|
||
|
} catch (e) {
|
||
|
if (true) {
|
||
|
console.warn("[vuex] error in before action subscribers: ");
|
||
|
console.error(e);
|
||
|
}
|
||
|
}
|
||
|
var result = entry.length > 1 ? Promise.all(entry.map(function(handler) {
|
||
|
return handler(payload);
|
||
|
})) : entry[0](payload);
|
||
|
return new Promise(function(resolve, reject) {
|
||
|
result.then(function(res) {
|
||
|
try {
|
||
|
this$1$1._actionSubscribers.filter(function(sub) {
|
||
|
return sub.after;
|
||
|
}).forEach(function(sub) {
|
||
|
return sub.after(action, this$1$1.state);
|
||
|
});
|
||
|
} catch (e) {
|
||
|
if (true) {
|
||
|
console.warn("[vuex] error in after action subscribers: ");
|
||
|
console.error(e);
|
||
|
}
|
||
|
}
|
||
|
resolve(res);
|
||
|
}, function(error) {
|
||
|
try {
|
||
|
this$1$1._actionSubscribers.filter(function(sub) {
|
||
|
return sub.error;
|
||
|
}).forEach(function(sub) {
|
||
|
return sub.error(action, this$1$1.state, error);
|
||
|
});
|
||
|
} catch (e) {
|
||
|
if (true) {
|
||
|
console.warn("[vuex] error in error action subscribers: ");
|
||
|
console.error(e);
|
||
|
}
|
||
|
}
|
||
|
reject(error);
|
||
|
});
|
||
|
});
|
||
|
};
|
||
|
Store.prototype.subscribe = function subscribe(fn, options) {
|
||
|
return genericSubscribe(fn, this._subscribers, options);
|
||
|
};
|
||
|
Store.prototype.subscribeAction = function subscribeAction(fn, options) {
|
||
|
var subs = typeof fn === "function" ? { before: fn } : fn;
|
||
|
return genericSubscribe(subs, this._actionSubscribers, options);
|
||
|
};
|
||
|
Store.prototype.watch = function watch$1(getter, cb, options) {
|
||
|
var this$1$1 = this;
|
||
|
if (true) {
|
||
|
assert(typeof getter === "function", "store.watch only accepts a function.");
|
||
|
}
|
||
|
return watch(function() {
|
||
|
return getter(this$1$1.state, this$1$1.getters);
|
||
|
}, cb, Object.assign({}, options));
|
||
|
};
|
||
|
Store.prototype.replaceState = function replaceState(state) {
|
||
|
var this$1$1 = this;
|
||
|
this._withCommit(function() {
|
||
|
this$1$1._state.data = state;
|
||
|
});
|
||
|
};
|
||
|
Store.prototype.registerModule = function registerModule(path, rawModule, options) {
|
||
|
if (options === void 0)
|
||
|
options = {};
|
||
|
if (typeof path === "string") {
|
||
|
path = [path];
|
||
|
}
|
||
|
if (true) {
|
||
|
assert(Array.isArray(path), "module path must be a string or an Array.");
|
||
|
assert(path.length > 0, "cannot register the root module by using registerModule.");
|
||
|
}
|
||
|
this._modules.register(path, rawModule);
|
||
|
installModule(this, this.state, path, this._modules.get(path), options.preserveState);
|
||
|
resetStoreState(this, this.state);
|
||
|
};
|
||
|
Store.prototype.unregisterModule = function unregisterModule(path) {
|
||
|
var this$1$1 = this;
|
||
|
if (typeof path === "string") {
|
||
|
path = [path];
|
||
|
}
|
||
|
if (true) {
|
||
|
assert(Array.isArray(path), "module path must be a string or an Array.");
|
||
|
}
|
||
|
this._modules.unregister(path);
|
||
|
this._withCommit(function() {
|
||
|
var parentState = getNestedState(this$1$1.state, path.slice(0, -1));
|
||
|
delete parentState[path[path.length - 1]];
|
||
|
});
|
||
|
resetStore(this);
|
||
|
};
|
||
|
Store.prototype.hasModule = function hasModule(path) {
|
||
|
if (typeof path === "string") {
|
||
|
path = [path];
|
||
|
}
|
||
|
if (true) {
|
||
|
assert(Array.isArray(path), "module path must be a string or an Array.");
|
||
|
}
|
||
|
return this._modules.isRegistered(path);
|
||
|
};
|
||
|
Store.prototype.hotUpdate = function hotUpdate(newOptions) {
|
||
|
this._modules.update(newOptions);
|
||
|
resetStore(this, true);
|
||
|
};
|
||
|
Store.prototype._withCommit = function _withCommit(fn) {
|
||
|
var committing = this._committing;
|
||
|
this._committing = true;
|
||
|
fn();
|
||
|
this._committing = committing;
|
||
|
};
|
||
|
Object.defineProperties(Store.prototype, prototypeAccessors);
|
||
|
var mapState = normalizeNamespace(function(namespace, states) {
|
||
|
var res = {};
|
||
|
if (!isValidMap(states)) {
|
||
|
console.error("[vuex] mapState: mapper parameter must be either an Array or an Object");
|
||
|
}
|
||
|
normalizeMap(states).forEach(function(ref) {
|
||
|
var key = ref.key;
|
||
|
var val = ref.val;
|
||
|
res[key] = function mappedState() {
|
||
|
var state = this.$store.state;
|
||
|
var getters = this.$store.getters;
|
||
|
if (namespace) {
|
||
|
var module = getModuleByNamespace(this.$store, "mapState", namespace);
|
||
|
if (!module) {
|
||
|
return;
|
||
|
}
|
||
|
state = module.context.state;
|
||
|
getters = module.context.getters;
|
||
|
}
|
||
|
return typeof val === "function" ? val.call(this, state, getters) : state[val];
|
||
|
};
|
||
|
res[key].vuex = true;
|
||
|
});
|
||
|
return res;
|
||
|
});
|
||
|
var mapMutations = normalizeNamespace(function(namespace, mutations) {
|
||
|
var res = {};
|
||
|
if (!isValidMap(mutations)) {
|
||
|
console.error("[vuex] mapMutations: mapper parameter must be either an Array or an Object");
|
||
|
}
|
||
|
normalizeMap(mutations).forEach(function(ref) {
|
||
|
var key = ref.key;
|
||
|
var val = ref.val;
|
||
|
res[key] = function mappedMutation() {
|
||
|
var args = [], len = arguments.length;
|
||
|
while (len--)
|
||
|
args[len] = arguments[len];
|
||
|
var commit2 = this.$store.commit;
|
||
|
if (namespace) {
|
||
|
var module = getModuleByNamespace(this.$store, "mapMutations", namespace);
|
||
|
if (!module) {
|
||
|
return;
|
||
|
}
|
||
|
commit2 = module.context.commit;
|
||
|
}
|
||
|
return typeof val === "function" ? val.apply(this, [commit2].concat(args)) : commit2.apply(this.$store, [val].concat(args));
|
||
|
};
|
||
|
});
|
||
|
return res;
|
||
|
});
|
||
|
var mapGetters = normalizeNamespace(function(namespace, getters) {
|
||
|
var res = {};
|
||
|
if (!isValidMap(getters)) {
|
||
|
console.error("[vuex] mapGetters: mapper parameter must be either an Array or an Object");
|
||
|
}
|
||
|
normalizeMap(getters).forEach(function(ref) {
|
||
|
var key = ref.key;
|
||
|
var val = ref.val;
|
||
|
val = namespace + val;
|
||
|
res[key] = function mappedGetter() {
|
||
|
if (namespace && !getModuleByNamespace(this.$store, "mapGetters", namespace)) {
|
||
|
return;
|
||
|
}
|
||
|
if (!(val in this.$store.getters)) {
|
||
|
console.error("[vuex] unknown getter: " + val);
|
||
|
return;
|
||
|
}
|
||
|
return this.$store.getters[val];
|
||
|
};
|
||
|
res[key].vuex = true;
|
||
|
});
|
||
|
return res;
|
||
|
});
|
||
|
var mapActions = normalizeNamespace(function(namespace, actions) {
|
||
|
var res = {};
|
||
|
if (!isValidMap(actions)) {
|
||
|
console.error("[vuex] mapActions: mapper parameter must be either an Array or an Object");
|
||
|
}
|
||
|
normalizeMap(actions).forEach(function(ref) {
|
||
|
var key = ref.key;
|
||
|
var val = ref.val;
|
||
|
res[key] = function mappedAction() {
|
||
|
var args = [], len = arguments.length;
|
||
|
while (len--)
|
||
|
args[len] = arguments[len];
|
||
|
var dispatch2 = this.$store.dispatch;
|
||
|
if (namespace) {
|
||
|
var module = getModuleByNamespace(this.$store, "mapActions", namespace);
|
||
|
if (!module) {
|
||
|
return;
|
||
|
}
|
||
|
dispatch2 = module.context.dispatch;
|
||
|
}
|
||
|
return typeof val === "function" ? val.apply(this, [dispatch2].concat(args)) : dispatch2.apply(this.$store, [val].concat(args));
|
||
|
};
|
||
|
});
|
||
|
return res;
|
||
|
});
|
||
|
var createNamespacedHelpers = function(namespace) {
|
||
|
return {
|
||
|
mapState: mapState.bind(null, namespace),
|
||
|
mapGetters: mapGetters.bind(null, namespace),
|
||
|
mapMutations: mapMutations.bind(null, namespace),
|
||
|
mapActions: mapActions.bind(null, namespace)
|
||
|
};
|
||
|
};
|
||
|
function normalizeMap(map) {
|
||
|
if (!isValidMap(map)) {
|
||
|
return [];
|
||
|
}
|
||
|
return Array.isArray(map) ? map.map(function(key) {
|
||
|
return { key, val: key };
|
||
|
}) : Object.keys(map).map(function(key) {
|
||
|
return { key, val: map[key] };
|
||
|
});
|
||
|
}
|
||
|
function isValidMap(map) {
|
||
|
return Array.isArray(map) || isObject(map);
|
||
|
}
|
||
|
function normalizeNamespace(fn) {
|
||
|
return function(namespace, map) {
|
||
|
if (typeof namespace !== "string") {
|
||
|
map = namespace;
|
||
|
namespace = "";
|
||
|
} else if (namespace.charAt(namespace.length - 1) !== "/") {
|
||
|
namespace += "/";
|
||
|
}
|
||
|
return fn(namespace, map);
|
||
|
};
|
||
|
}
|
||
|
function getModuleByNamespace(store, helper, namespace) {
|
||
|
var module = store._modulesNamespaceMap[namespace];
|
||
|
if (!module) {
|
||
|
console.error("[vuex] module namespace not found in " + helper + "(): " + namespace);
|
||
|
}
|
||
|
return module;
|
||
|
}
|
||
|
function createLogger(ref) {
|
||
|
if (ref === void 0)
|
||
|
ref = {};
|
||
|
var collapsed = ref.collapsed;
|
||
|
if (collapsed === void 0)
|
||
|
collapsed = true;
|
||
|
var filter = ref.filter;
|
||
|
if (filter === void 0)
|
||
|
filter = function(mutation, stateBefore, stateAfter) {
|
||
|
return true;
|
||
|
};
|
||
|
var transformer = ref.transformer;
|
||
|
if (transformer === void 0)
|
||
|
transformer = function(state) {
|
||
|
return state;
|
||
|
};
|
||
|
var mutationTransformer = ref.mutationTransformer;
|
||
|
if (mutationTransformer === void 0)
|
||
|
mutationTransformer = function(mut) {
|
||
|
return mut;
|
||
|
};
|
||
|
var actionFilter = ref.actionFilter;
|
||
|
if (actionFilter === void 0)
|
||
|
actionFilter = function(action, state) {
|
||
|
return true;
|
||
|
};
|
||
|
var actionTransformer = ref.actionTransformer;
|
||
|
if (actionTransformer === void 0)
|
||
|
actionTransformer = function(act) {
|
||
|
return act;
|
||
|
};
|
||
|
var logMutations = ref.logMutations;
|
||
|
if (logMutations === void 0)
|
||
|
logMutations = true;
|
||
|
var logActions = ref.logActions;
|
||
|
if (logActions === void 0)
|
||
|
logActions = true;
|
||
|
var logger = ref.logger;
|
||
|
if (logger === void 0)
|
||
|
logger = console;
|
||
|
return function(store) {
|
||
|
var prevState = deepCopy(store.state);
|
||
|
if (typeof logger === "undefined") {
|
||
|
return;
|
||
|
}
|
||
|
if (logMutations) {
|
||
|
store.subscribe(function(mutation, state) {
|
||
|
var nextState = deepCopy(state);
|
||
|
if (filter(mutation, prevState, nextState)) {
|
||
|
var formattedTime = getFormattedTime();
|
||
|
var formattedMutation = mutationTransformer(mutation);
|
||
|
var message = "mutation " + mutation.type + formattedTime;
|
||
|
startMessage(logger, message, collapsed);
|
||
|
logger.log("%c prev state", "color: #9E9E9E; font-weight: bold", transformer(prevState));
|
||
|
logger.log("%c mutation", "color: #03A9F4; font-weight: bold", formattedMutation);
|
||
|
logger.log("%c next state", "color: #4CAF50; font-weight: bold", transformer(nextState));
|
||
|
endMessage(logger);
|
||
|
}
|
||
|
prevState = nextState;
|
||
|
});
|
||
|
}
|
||
|
if (logActions) {
|
||
|
store.subscribeAction(function(action, state) {
|
||
|
if (actionFilter(action, state)) {
|
||
|
var formattedTime = getFormattedTime();
|
||
|
var formattedAction = actionTransformer(action);
|
||
|
var message = "action " + action.type + formattedTime;
|
||
|
startMessage(logger, message, collapsed);
|
||
|
logger.log("%c action", "color: #03A9F4; font-weight: bold", formattedAction);
|
||
|
endMessage(logger);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
function startMessage(logger, message, collapsed) {
|
||
|
var startMessage2 = collapsed ? logger.groupCollapsed : logger.group;
|
||
|
try {
|
||
|
startMessage2.call(logger, message);
|
||
|
} catch (e) {
|
||
|
logger.log(message);
|
||
|
}
|
||
|
}
|
||
|
function endMessage(logger) {
|
||
|
try {
|
||
|
logger.groupEnd();
|
||
|
} catch (e) {
|
||
|
logger.log("\u2014\u2014 log end \u2014\u2014");
|
||
|
}
|
||
|
}
|
||
|
function getFormattedTime() {
|
||
|
var time = new Date();
|
||
|
return " @ " + pad(time.getHours(), 2) + ":" + pad(time.getMinutes(), 2) + ":" + pad(time.getSeconds(), 2) + "." + pad(time.getMilliseconds(), 3);
|
||
|
}
|
||
|
function repeat(str, times) {
|
||
|
return new Array(times + 1).join(str);
|
||
|
}
|
||
|
function pad(num, maxLength) {
|
||
|
return repeat("0", maxLength - num.toString().length) + num;
|
||
|
}
|
||
|
var index = {
|
||
|
version: "4.1.0",
|
||
|
Store,
|
||
|
storeKey,
|
||
|
createStore,
|
||
|
useStore,
|
||
|
mapState,
|
||
|
mapMutations,
|
||
|
mapGetters,
|
||
|
mapActions,
|
||
|
createNamespacedHelpers,
|
||
|
createLogger
|
||
|
};
|
||
|
var vuex_esm_bundler_default = index;
|
||
|
|
||
|
// dep:vuex
|
||
|
var vuex_default = vuex_esm_bundler_default;
|
||
|
export {
|
||
|
Store,
|
||
|
createLogger,
|
||
|
createNamespacedHelpers,
|
||
|
createStore,
|
||
|
vuex_default as default,
|
||
|
mapActions,
|
||
|
mapGetters,
|
||
|
mapMutations,
|
||
|
mapState,
|
||
|
storeKey,
|
||
|
useStore
|
||
|
};
|
||
|
/*!
|
||
|
* vuex v4.1.0
|
||
|
* (c) 2022 Evan You
|
||
|
* @license MIT
|
||
|
*/
|
||
|
//# sourceMappingURL=vuex.js.map
|