@newdash/newdash
Version:
javascript/typescript utility library
45 lines (44 loc) • 1.37 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const baseClone_1 = __importDefault(require("./.internal/baseClone"));
/** Used to compose bitmasks for cloning. */
const CLONE_DEEP_FLAG = 1;
const CLONE_SYMBOLS_FLAG = 4;
/**
* This method is like `cloneWith` except that it recursively clones `value`.
* The customizer is invoked with up to four arguments
* (value [, index|key, object, stack]).
*
* @since 5.3.0
* @category Lang
* @param value The value to recursively clone.
* @param customizer The function to customize cloning.
* @returns Returns the deep cloned value.
* @see cloneWith
* @example
*
* ```js
* function customizer(value) {
* if (isElement(value)) {
* return value.cloneNode(true)
* }
* }
*
* const el = cloneDeepWith(document.body, customizer)
*
* console.log(el === document.body)
* // => false
* console.log(el.nodeName)
* // => 'BODY'
* console.log(el.childNodes.length)
* // => 20
* ```
*/
function cloneDeepWith(value, customizer) {
customizer = typeof customizer === "function" ? customizer : undefined;
return (0, baseClone_1.default)(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer);
}
exports.default = cloneDeepWith;