UNPKG

tdesign-vue

Version:
107 lines (98 loc) 3.06 kB
/** * tdesign v1.12.1 * (c) 2025 tdesign * @license MIT */ 'use strict'; var toString = require('./dep-e1cc6f64.js'); var _baseClone = require('./dep-b0b39c86.js'); var _baseGet = require('./dep-e1bd36c1.js'); var last = require('./dep-6a3ffcb1.js'); var _baseSlice = require('./dep-051ce30d.js'); var _initCloneObject = require('./dep-403352a7.js'); var isPlainObject = require('./dep-e6ed4b1f.js'); var _flatRest = require('./dep-7ead4ee1.js'); /** * Gets the parent value at `path` of `object`. * * @private * @param {Object} object The object to query. * @param {Array} path The path to get the parent value of. * @returns {*} Returns the parent value. */ function parent(object, path) { return path.length < 2 ? object : _baseGet.baseGet(object, _baseSlice.baseSlice(path, 0, -1)); } /** * The base implementation of `_.unset`. * * @private * @param {Object} object The object to modify. * @param {Array|string} path The property path to unset. * @returns {boolean} Returns `true` if the property is deleted, else `false`. */ function baseUnset(object, path) { path = _baseGet.castPath(path, object); object = parent(object, path); return object == null || delete object[_baseGet.toKey(last.last(path))]; } /** * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain * objects. * * @private * @param {*} value The value to inspect. * @param {string} key The key of the property to inspect. * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`. */ function customOmitClone(value) { return isPlainObject.isPlainObject(value) ? undefined : value; } /** Used to compose bitmasks for cloning. */ var CLONE_DEEP_FLAG = 1, CLONE_FLAT_FLAG = 2, CLONE_SYMBOLS_FLAG = 4; /** * The opposite of `_.pick`; this method creates an object composed of the * own and inherited enumerable property paths of `object` that are not omitted. * * **Note:** This method is considerably slower than `_.pick`. * * @static * @since 0.1.0 * @memberOf _ * @category Object * @param {Object} object The source object. * @param {...(string|string[])} [paths] The property paths to omit. * @returns {Object} Returns the new object. * @example * * var object = { 'a': 1, 'b': '2', 'c': 3 }; * * _.omit(object, ['a', 'c']); * // => { 'b': '2' } */ var omit = _flatRest.flatRest(function (object, paths) { var result = {}; if (object == null) { return result; } var isDeep = false; paths = toString.arrayMap(paths, function (path) { path = _baseGet.castPath(path, object); isDeep || (isDeep = path.length > 1); return path; }); _initCloneObject.copyObject(object, _baseClone.getAllKeysIn(object), result); if (isDeep) { result = _baseClone.baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone); } var length = paths.length; while (length--) { baseUnset(result, paths[length]); } return result; }); var omit$1 = omit; exports.omit = omit$1; //# sourceMappingURL=dep-e7151b6f.js.map