UNPKG

@aplus-frontend/antdv

Version:

Vue basic component library maintained based on ant-design-vue

80 lines (79 loc) 3.02 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.cloneByNamePathList = cloneByNamePathList; exports.containsNamePath = containsNamePath; exports.getNamePath = getNamePath; exports.getValue = getValue; exports.matchNamePath = matchNamePath; exports.setValue = setValue; exports.setValues = setValues; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _typeUtil = require("./typeUtil"); var _get = _interopRequireDefault(require("../../vc-util/get")); var _set = _interopRequireDefault(require("../../vc-util/set")); /** * Convert name to internal supported format. * This function should keep since we still thinking if need support like `a.b.c` format. * 'a' => ['a'] * 123 => [123] * ['a', 123] => ['a', 123] */ function getNamePath(path) { return (0, _typeUtil.toArray)(path); } function getValue(store, namePath) { const value = (0, _get.default)(store, namePath); return value; } function setValue(store, namePath, value) { let removeIfUndefined = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; const newStore = (0, _set.default)(store, namePath, value, removeIfUndefined); return newStore; } function containsNamePath(namePathList, namePath) { return namePathList && namePathList.some(path => matchNamePath(path, namePath)); } function isObject(obj) { return typeof obj === 'object' && obj !== null && Object.getPrototypeOf(obj) === Object.prototype; } /** * Copy values into store and return a new values object * ({ a: 1, b: { c: 2 } }, { a: 4, b: { d: 5 } }) => { a: 4, b: { c: 2, d: 5 } } */ function internalSetValues(store, values) { const newStore = Array.isArray(store) ? [...store] : (0, _extends2.default)({}, store); if (!values) { return newStore; } Object.keys(values).forEach(key => { const prevValue = newStore[key]; const value = values[key]; // If both are object (but target is not array), we use recursion to set deep value const recursive = isObject(prevValue) && isObject(value); newStore[key] = recursive ? internalSetValues(prevValue, value || {}) : value; }); return newStore; } function setValues(store) { for (var _len = arguments.length, restValues = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { restValues[_key - 1] = arguments[_key]; } return restValues.reduce((current, newStore) => internalSetValues(current, newStore), store); } function cloneByNamePathList(store, namePathList) { let newStore = {}; namePathList.forEach(namePath => { const value = getValue(store, namePath); newStore = setValue(newStore, namePath, value); }); return newStore; } function matchNamePath(namePath, changedNamePath) { if (!namePath || !changedNamePath || namePath.length !== changedNamePath.length) { return false; } return namePath.every((nameUnit, i) => changedNamePath[i] === nameUnit); }