UNPKG

@aws/pdk

Version:

All documentation is located at: https://aws.github.io/aws-pdk

110 lines 13.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.cloneDeep = cloneDeep; exports.isEmpty = isEmpty; exports.asUndefinedIfEmpty = asUndefinedIfEmpty; exports.deepMerge = deepMerge; /*! Copyright [Amazon.com](http://amazon.com/), Inc. or its affiliates. All Rights Reserved. SPDX-License-Identifier: Apache-2.0 */ const util_1 = require("projen/lib/util"); /** * Utility to deeply clone a value * @param value Value to clone * @returns Cloned value */ function cloneDeep(value) { return JSON.parse(JSON.stringify(value)); } /** Indicates if value is considered empty */ function isEmpty(value) { if (value == null) return true; if (typeof value === "boolean") { return false; } if (typeof value === "string") { return value.length === 0; } if (Array.isArray(value)) { return value.length === 0; } if ((0, util_1.isObject)(value)) { return Object.keys(value).length === 0; } return false; } /** Replace empty value with undefined */ function asUndefinedIfEmpty(value) { if (isEmpty(value)) return undefined; return value; } /** * Recursively merge objects together into a new object with extends support for appending arrays. * * This is a clone of [projen/lib/util#deepMerge](https://github.com/projen/projen/blob/55ac3657a270285db63e1a6008b3848b36775626/src/util.ts#L218-L281) * with added functionality to support appending arrays. * * @see [projen/lib/util#deepMerge](https://github.com/projen/projen/blob/55ac3657a270285db63e1a6008b3848b36775626/src/util.ts#L218-L281) */ function deepMerge(objects, options) { const append = options?.append ?? false; const destructive = options?.destructive ?? false; objects = objects.map(cloneDeep); if (append === false) return (0, util_1.deepMerge)(objects, destructive); function mergeOne(target, source) { for (const key of Object.keys(source)) { const value = source[key]; if ((0, util_1.isObject)(value)) { // if the value at the target is not an object, override it with an // object so we can continue the recursion if (typeof target[key] !== "object") { target[key] = value; } if (Array.isArray(value)) { if (Array.isArray(target[key])) { target[key].push(...value); } else { target[key] = value; } } mergeOne(target[key], value); // if the result of the merge is an empty object, it's because the // eventual value we assigned is `undefined`, and there are no // sibling concrete values alongside, so we can delete this tree. const output = target[key]; if (typeof output === "object" && Object.keys(output).length === 0 && destructive) { delete target[key]; } } else if (value === undefined && destructive) { delete target[key]; } else if (Array.isArray(value)) { if (Array.isArray(target[key])) { // Append to existing array target[key].push(...value); } else { // Override with array value target[key] = value; } } else if (typeof value !== "undefined") { target[key] = value; } } } const others = objects.filter((x) => x != null); if (others.length === 0) { return {}; } const into = others.splice(0, 1)[0]; others.forEach((other) => mergeOne(into, other)); return into; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["common.ts"],"names":[],"mappings":"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","sourcesContent":["/*! Copyright [Amazon.com](http://amazon.com/), Inc. or its affiliates. All Rights Reserved.\nSPDX-License-Identifier: Apache-2.0 */\nimport { Obj, deepMerge as _deepMerge, isObject } from \"projen/lib/util\";\n\n/**\n * Utility to deeply clone a value\n * @param value Value to clone\n * @returns Cloned value\n */\nexport function cloneDeep(value: any): any {\n  return JSON.parse(JSON.stringify(value));\n}\n\n/** Indicates if value is considered empty */\nexport function isEmpty(value: any): boolean {\n  if (value == null) return true;\n  if (typeof value === \"boolean\") {\n    return false;\n  }\n  if (typeof value === \"string\") {\n    return value.length === 0;\n  }\n  if (Array.isArray(value)) {\n    return value.length === 0;\n  }\n  if (isObject(value)) {\n    return Object.keys(value).length === 0;\n  }\n  return false;\n}\n\n/** Replace empty value with undefined */\nexport function asUndefinedIfEmpty(value: any): any | undefined {\n  if (isEmpty(value)) return undefined;\n  return value;\n}\n\n/** Options for deep merge function */\nexport interface DeepMergeOptions {\n  /**\n   * Append array values\n   * @default false\n   */\n  readonly append?: boolean;\n  /**\n   * `undefined`s will cause a value to be deleted if destructive is enabled.\n   * @default false\n   */\n  readonly destructive?: boolean;\n}\n\n/**\n * Recursively merge objects together into a new object with extends support for appending arrays.\n *\n * This is a clone of [projen/lib/util#deepMerge](https://github.com/projen/projen/blob/55ac3657a270285db63e1a6008b3848b36775626/src/util.ts#L218-L281)\n * with added functionality to support appending arrays.\n *\n * @see [projen/lib/util#deepMerge](https://github.com/projen/projen/blob/55ac3657a270285db63e1a6008b3848b36775626/src/util.ts#L218-L281)\n */\nexport function deepMerge(\n  objects: Array<Obj<any>>,\n  options?: DeepMergeOptions\n): Obj<any> {\n  const append = options?.append ?? false;\n  const destructive = options?.destructive ?? false;\n\n  objects = objects.map(cloneDeep);\n\n  if (append === false) return _deepMerge(objects, destructive);\n\n  function mergeOne(target: any, source: any) {\n    for (const key of Object.keys(source)) {\n      const value = source[key];\n      if (isObject(value)) {\n        // if the value at the target is not an object, override it with an\n        // object so we can continue the recursion\n        if (typeof target[key] !== \"object\") {\n          target[key] = value;\n        }\n        if (Array.isArray(value)) {\n          if (Array.isArray(target[key])) {\n            target[key].push(...value);\n          } else {\n            target[key] = value;\n          }\n        }\n        mergeOne(target[key], value);\n        // if the result of the merge is an empty object, it's because the\n        // eventual value we assigned is `undefined`, and there are no\n        // sibling concrete values alongside, so we can delete this tree.\n        const output = target[key];\n        if (\n          typeof output === \"object\" &&\n          Object.keys(output).length === 0 &&\n          destructive\n        ) {\n          delete target[key];\n        }\n      } else if (value === undefined && destructive) {\n        delete target[key];\n      } else if (Array.isArray(value)) {\n        if (Array.isArray(target[key])) {\n          // Append to existing array\n          target[key].push(...value);\n        } else {\n          // Override with array value\n          target[key] = value;\n        }\n      } else if (typeof value !== \"undefined\") {\n        target[key] = value;\n      }\n    }\n  }\n  const others = objects.filter((x) => x != null);\n  if (others.length === 0) {\n    return {};\n  }\n  const into = others.splice(0, 1)[0];\n  others.forEach((other) => mergeOne(into, other));\n  return into;\n}\n"]}