obsidian-dev-utils 13.3.2 → 13.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +10 -0
- package/dist/lib/Object.cjs +28 -5
- package/dist/lib/Object.d.ts +10 -0
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
package/dist/lib/Object.cjs
CHANGED
@@ -139,8 +139,10 @@ function toJson(value, options = {}) {
|
|
139
139
|
const DEFAULT_OPTIONS = {
|
140
140
|
functionHandlingMode: "exclude" /* Exclude */,
|
141
141
|
maxDepth: -1,
|
142
|
+
shouldCatchToJSONErrors: false,
|
142
143
|
shouldHandleCircularReferences: false,
|
143
144
|
shouldHandleUndefined: false,
|
145
|
+
shouldSortKeys: false,
|
144
146
|
space: 2
|
145
147
|
};
|
146
148
|
const fullOptions = { ...DEFAULT_OPTIONS, ...options };
|
@@ -151,7 +153,7 @@ function toJson(value, options = {}) {
|
|
151
153
|
const functionTexts = [];
|
152
154
|
const objectDepthMap = /* @__PURE__ */ new WeakMap();
|
153
155
|
const usedObjects = /* @__PURE__ */ new WeakSet();
|
154
|
-
const replacer = (
|
156
|
+
const replacer = (key, value2) => {
|
155
157
|
if (value2 === null) {
|
156
158
|
return null;
|
157
159
|
}
|
@@ -166,14 +168,14 @@ function toJson(value, options = {}) {
|
|
166
168
|
return void 0;
|
167
169
|
}
|
168
170
|
const index = functionTexts.length;
|
169
|
-
const functionText = fullOptions.functionHandlingMode === "full" /* Full */ ? value2.toString() : `function ${value2.name || "anonymous"}()`;
|
171
|
+
const functionText = fullOptions.functionHandlingMode === "full" /* Full */ ? value2.toString() : `function ${value2.name || "anonymous"}() { /* ... */ }`;
|
170
172
|
functionTexts.push(functionText);
|
171
173
|
return `__FUNCTION__${index.toString()}`;
|
172
174
|
}
|
173
175
|
if (typeof value2 === "object") {
|
174
176
|
if (fullOptions.shouldHandleCircularReferences) {
|
175
177
|
if (usedObjects.has(value2)) {
|
176
|
-
return "
|
178
|
+
return "__CIRCULAR_REFERENCE__";
|
177
179
|
}
|
178
180
|
usedObjects.add(value2);
|
179
181
|
}
|
@@ -183,7 +185,22 @@ function toJson(value, options = {}) {
|
|
183
185
|
objectDepthMap.set(value2, 0);
|
184
186
|
}
|
185
187
|
if (depth > maxDepth) {
|
186
|
-
return "
|
188
|
+
return "__MAX_DEPTH_LIMIT_REACHED__";
|
189
|
+
}
|
190
|
+
const toJSON = value2.toJSON;
|
191
|
+
if (typeof toJSON === "function") {
|
192
|
+
try {
|
193
|
+
value2 = toJSON.call(value2);
|
194
|
+
if (value2 && typeof value2 === "object") {
|
195
|
+
objectDepthMap.set(value2, depth);
|
196
|
+
}
|
197
|
+
return replacer(key, value2);
|
198
|
+
} catch (error) {
|
199
|
+
if (fullOptions.shouldCatchToJSONErrors) {
|
200
|
+
return "__TO_JSON_FAILED__";
|
201
|
+
}
|
202
|
+
throw error;
|
203
|
+
}
|
187
204
|
}
|
188
205
|
for (const property of Object.values(value2)) {
|
189
206
|
if (!property || typeof property !== "object") {
|
@@ -191,12 +208,18 @@ function toJson(value, options = {}) {
|
|
191
208
|
}
|
192
209
|
objectDepthMap.set(property, depth + 1);
|
193
210
|
}
|
211
|
+
if (fullOptions.shouldSortKeys) {
|
212
|
+
return Object.fromEntries(Object.entries(value2).sort(([key1], [key2]) => key1.localeCompare(key2)));
|
213
|
+
}
|
194
214
|
}
|
195
215
|
return value2;
|
196
216
|
};
|
197
217
|
let json = JSON.stringify(value, replacer, fullOptions.space) ?? "undefined";
|
198
218
|
json = (0, import_String.replaceAll)(json, /"__FUNCTION__(\d+)"/g, (_, indexStr) => functionTexts[parseInt(indexStr)] ?? (0, import_Error.throwExpression)(new Error(`Function with index ${indexStr} not found`)));
|
199
219
|
json = (0, import_String.replaceAll)(json, '"__UNDEFINED__"', "undefined");
|
220
|
+
json = (0, import_String.replaceAll)(json, '"__MAX_DEPTH_LIMIT_REACHED__"', "{ /* ... */ }");
|
221
|
+
json = (0, import_String.replaceAll)(json, '"__CIRCULAR_REFERENCE__"', "{ /* CIRCULAR REFERENCE */ }");
|
222
|
+
json = (0, import_String.replaceAll)(json, '"__TO_JSON_FAILED__"', "{ /* toJSON() failed */ }");
|
200
223
|
return json;
|
201
224
|
}
|
202
225
|
function _assignWithNonEnumerableProperties(target, ...sources) {
|
@@ -225,4 +248,4 @@ function _assignWithNonEnumerableProperties(target, ...sources) {
|
|
225
248
|
setNestedPropertyValue,
|
226
249
|
toJson
|
227
250
|
});
|
228
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Object.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Object\n * Contains utility functions for Objects.\n */\n\nimport type { UndefinedOnPartialDeep } from 'type-fest';\n\nimport { throwExpression } from './Error.ts';\nimport { replaceAll } from './String.ts';\n\n/**\n * Specifies how functions should be handled in the JSON output.\n   */\nexport enum FunctionHandlingMode {\n  /**\n   * Excludes functions from the JSON output.\n   */\n  Exclude = 'exclude',\n  /**\n   * Includes the full function definition in the JSON output.\n   */\n  Full = 'full',\n  /**\n   * Includes only the function name in the JSON output.\n   */\n  NameOnly = 'nameOnly'\n}\n\n/**\n * Options for converting an object to JSON.\n */\nexport interface ToJsonOptions {\n  /**\n   * Specifies how functions should be handled in the JSON output (default: `exclude`).\n   */\n  functionHandlingMode: FunctionHandlingMode;\n  /**\n   * Specifies the maximum depth of nested objects to include in the JSON output.\n   * Use `-1` for no limit.\n   * Defaults to `-1`.\n   */\n  maxDepth: number;\n  /**\n   * Specifies whether to handle circular references in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleCircularReferences: boolean;\n  /**\n   * Specifies whether to handle undefined values in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleUndefined: boolean;\n  /**\n   * Specifies the indentation of the JSON output. This can be a number of spaces or a string. Defaults to `2`.\n   */\n  space: number | string;\n}\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source - The source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U>(target: T, source: U): T & U;\n\n/**\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V>(target: T, source1: U, source2: V): T & U & V;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @param source3 - The third source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V, W>(target: T, source1: U, source2: V, source3: W): T & U & V & W;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param sources - The source objects to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  return _assignWithNonEnumerableProperties(target, ...sources);\n}\n\n/**\n * Clones an object, including non-enumerable properties.\n *\n * @param obj - The object to clone.\n * @returns A new object with the same properties as the original object, including non-enumerable properties.\n */\nexport function cloneWithNonEnumerableProperties<T extends object>(obj: T): T {\n  return Object.create(getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj)) as T;\n}\n\n/**\n * Compares two values to determine if they are deeply equal.\n *\n * @param a - The first value to compare.\n * @param b - The second value to compare.\n * @returns `true` if the values are deeply equal, otherwise `false`.\n */\nexport function deepEqual(a: unknown, b: unknown): boolean {\n  if (a === b) {\n    return true;\n  }\n\n  if (typeof a !== 'object' || typeof b !== 'object' || a === null || b === null) {\n    return false;\n  }\n\n  const keysA = Object.keys(a);\n  const keysB = Object.keys(b);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  const aRecord = a as Record<string, unknown>;\n  const bRecord = b as Record<string, unknown>;\n\n  for (const key of keysA) {\n    if (!keysB.includes(key) || !deepEqual(aRecord[key], bRecord[key])) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * Deletes multiple properties from an object.\n *\n * @param obj - The object to delete the properties from.\n * @param propertyNames - The names of the properties to delete.\n * @returns `true` if any of the properties were present, otherwise `false`.\n */\nexport function deleteProperties(obj: Record<string, unknown>, propertyNames: string[]): boolean {\n  let ans = false;\n\n  for (const propertyName of propertyNames) {\n    ans = deleteProperty(obj, propertyName) || ans;\n  }\n\n  return ans;\n}\n\n/**\n * Deletes a property from an object.\n *\n * @param obj - The object to delete the property from.\n * @param propertyName - The name of the property to delete.\n * @returns `true` if the property was present, otherwise `false`.\n */\nexport function deleteProperty(obj: Record<string, unknown>, propertyName: string): boolean {\n  if (!Object.prototype.hasOwnProperty.call(obj, propertyName)) {\n    return false;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n  delete obj[propertyName];\n  return true;\n}\n\n/**\n * Gets the value of a nested property from an object.\n *\n * @param obj - The object to get the nested property value from.\n * @param path - The path to the nested property.\n * @returns The value of the nested property.\n */\nexport function getNestedPropertyValue(obj: Record<string, unknown>, path: string): unknown {\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split('.');\n  for (const key of keys) {\n    if (node === undefined) {\n      return undefined;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  return node;\n}\n\n/**\n * Gets the prototype of the specified object.\n *\n * @typeParam T - The type of the object.\n * @param instance - The object instance to retrieve the prototype of.\n * @returns The prototype of the object.\n */\nexport function getPrototypeOf<T>(instance: T): T {\n  if (instance === undefined || instance === null) {\n    return instance;\n  }\n  return Object.getPrototypeOf(instance) as T;\n}\n\n/**\n * Retrieves the name of a property of a given type `T`.\n *\n * @typeParam T - The type of the object containing the property.\n * @param name - The name of the property as a string.\n * @returns The name of the property.\n */\nexport function nameof<T>(name: Extract<keyof T, string>): string {\n  return name;\n}\n\n/**\n * Normalizes optional properties to allow `undefined` assignment in strict mode.\n *\n * This utility provides a workaround for the `exactOptionalPropertyTypes` TypeScript flag,\n * which prohibits directly assigning `undefined` to optional properties when the type\n * explicitly omits `undefined`.\n *\n * Example:\n * ```typescript\n * // With `exactOptionalPropertyTypes: true`\n * const x: { prop?: string } = { prop: undefined }; // Compiler error\n *\n * // Using this utility:\n * const y: { prop?: string } = normalizeOptionalProperties<{ prop?: string }>({ prop: undefined }); // Works\n * ```\n *\n * @typeParam T - The target type with optional properties to normalize.\n * @param obj - The object to normalize, allowing explicit `undefined` for optional properties.\n * @returns The normalized object, compatible with `exactOptionalPropertyTypes`.\n */\nexport function normalizeOptionalProperties<T>(obj: UndefinedOnPartialDeep<T>): T {\n  return obj as T;\n}\n\n/**\n * Sets the value of a nested property in an object.\n *\n * @param obj - The object to set the nested property value in.\n * @param path - The path to the nested property.\n * @param value - The value to set.\n */\nexport function setNestedPropertyValue(obj: Record<string, unknown>, path: string, value: unknown): void {\n  const error = new Error(`Property path ${path} not found`);\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split('.');\n  for (const key of keys.slice(0, -1)) {\n    if (node === undefined) {\n      throw error;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  const lastKey = keys.at(-1);\n  if (node === undefined || lastKey === undefined) {\n    throw error;\n  }\n\n  node[lastKey] = value;\n}\n\n/**\n * Converts a given value to a JSON string.\n *\n * @param value - The value to be converted to JSON. This can be of any type.\n * @param options - Options for customizing the JSON conversion process.\n * @returns The JSON string representation of the input value.\n */\nexport function toJson(value: unknown, options: Partial<ToJsonOptions> = {}): string {\n  const DEFAULT_OPTIONS: ToJsonOptions = {\n    functionHandlingMode: FunctionHandlingMode.Exclude,\n    maxDepth: -1,\n    shouldHandleCircularReferences: false,\n    shouldHandleUndefined: false,\n    space: 2\n  };\n\n  const fullOptions = { ...DEFAULT_OPTIONS, ...options };\n\n  const maxDepth = fullOptions.maxDepth === -1 ? Infinity : fullOptions.maxDepth;\n\n  if (value === undefined) {\n    return 'undefined';\n  }\n\n  const functionTexts: string[] = [];\n  const objectDepthMap = new WeakMap<object, number>();\n  const usedObjects = new WeakSet<object>();\n\n  const replacer = (_key: string, value: unknown): JSONValueF<unknown> | undefined => {\n    if (value === null) {\n      return null;\n    }\n    if (value === undefined) {\n      if (fullOptions.shouldHandleUndefined) {\n        return '__UNDEFINED__';\n      }\n      return undefined;\n    }\n    if (typeof value === 'function') {\n      if (fullOptions.functionHandlingMode === FunctionHandlingMode.Exclude) {\n        return undefined;\n      }\n      const index = functionTexts.length;\n      const functionText = fullOptions.functionHandlingMode === FunctionHandlingMode.Full ? value.toString() : `function ${value.name || 'anonymous'}()`;\n      functionTexts.push(functionText);\n      return `__FUNCTION__${index.toString()}`;\n    }\n    if (typeof value === 'object') {\n      if (fullOptions.shouldHandleCircularReferences) {\n        if (usedObjects.has(value)) {\n          return '[Circular Reference]';\n        }\n        usedObjects.add(value);\n      }\n\n      let depth = objectDepthMap.get(value);\n      if (depth === undefined) {\n        depth = 0;\n        objectDepthMap.set(value, 0);\n      }\n\n      if (depth > maxDepth) {\n        return '[...]';\n      }\n\n      for (const property of Object.values(value)) {\n        if (!property || typeof property !== 'object') {\n          continue;\n        }\n        objectDepthMap.set(property, depth + 1);\n      }\n    }\n\n    return value as JSONValueF<unknown>;\n  };\n\n  let json = JSON.stringify(value, replacer, fullOptions.space) ?? 'undefined';\n  json = replaceAll(json, /\"__FUNCTION__(\\d+)\"/g, (_, indexStr) => functionTexts[parseInt(indexStr)] ?? throwExpression(new Error(`Function with index ${indexStr} not found`)));\n  json = replaceAll(json, '\"__UNDEFINED__\"', 'undefined');\n  return json;\n}\n\nfunction _assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  for (const source of sources) {\n    Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n  }\n\n  const sourcePrototypes = (sources.map((source) => getPrototypeOf(source)) as (null | object)[]).filter<null | object>((proto) => !!proto) as object[];\n\n  if (sourcePrototypes.length > 0) {\n    const targetPrototype = _assignWithNonEnumerableProperties({}, getPrototypeOf(target), ...sourcePrototypes);\n    Object.setPrototypeOf(target, targetPrototype);\n  }\n\n  return target;\n}\n"],
  "mappings": "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",
  "names": ["FunctionHandlingMode", "value"]
}

|
251
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Object.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Object\n * Contains utility functions for Objects.\n */\n\nimport type { UndefinedOnPartialDeep } from 'type-fest';\n\nimport { throwExpression } from './Error.ts';\nimport { replaceAll } from './String.ts';\n\n/**\n * Specifies how functions should be handled in the JSON output.\n   */\nexport enum FunctionHandlingMode {\n  /**\n   * Excludes functions from the JSON output.\n   */\n  Exclude = 'exclude',\n  /**\n   * Includes the full function definition in the JSON output.\n   */\n  Full = 'full',\n  /**\n   * Includes only the function name in the JSON output.\n   */\n  NameOnly = 'nameOnly'\n}\n\n/**\n * Options for converting an object to JSON.\n */\nexport interface ToJsonOptions {\n  /**\n   * Specifies how functions should be handled in the JSON output (default: `exclude`).\n   */\n  functionHandlingMode: FunctionHandlingMode;\n  /**\n   * Specifies the maximum depth of nested objects to include in the JSON output.\n   * Use `-1` for no limit.\n   * Defaults to `-1`.\n   */\n  maxDepth: number;\n  /**\n   * Specifies whether to catch errors in `toJSON()` and replace them with a placeholder.\n   * Defaults to `false`.\n   */\n  shouldCatchToJSONErrors: boolean;\n  /**\n   * Specifies whether to handle circular references in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleCircularReferences: boolean;\n  /**\n   * Specifies whether to handle undefined values in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleUndefined: boolean;\n  /**\n   * Specifies whether to sort the keys of the JSON output.\n   * Defaults to `false`.\n   */\n  shouldSortKeys: boolean;\n  /**\n   * Specifies the indentation of the JSON output. This can be a number of spaces or a string. Defaults to `2`.\n   */\n  space: number | string;\n}\n\ninterface ObjectWithToJSON {\n  toJSON(): unknown;\n}\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source - The source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U>(target: T, source: U): T & U;\n\n/**\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V>(target: T, source1: U, source2: V): T & U & V;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param source1 - The first source object to assign properties from.\n * @param source2 - The second source object to assign properties from.\n * @param source3 - The third source object to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties<T extends object, U, V, W>(target: T, source1: U, source2: V, source3: W): T & U & V & W;\n\n/**\n * Assigns properties from one or more source objects to a target object, including non-enumerable properties.\n *\n * @param target - The target object to assign properties to.\n * @param sources - The source objects to assign properties from.\n * @returns The target object with the assigned properties.\n */\nexport function assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  return _assignWithNonEnumerableProperties(target, ...sources);\n}\n\n/**\n * Clones an object, including non-enumerable properties.\n *\n * @param obj - The object to clone.\n * @returns A new object with the same properties as the original object, including non-enumerable properties.\n */\nexport function cloneWithNonEnumerableProperties<T extends object>(obj: T): T {\n  return Object.create(getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj)) as T;\n}\n\n/**\n * Compares two values to determine if they are deeply equal.\n *\n * @param a - The first value to compare.\n * @param b - The second value to compare.\n * @returns `true` if the values are deeply equal, otherwise `false`.\n */\nexport function deepEqual(a: unknown, b: unknown): boolean {\n  if (a === b) {\n    return true;\n  }\n\n  if (typeof a !== 'object' || typeof b !== 'object' || a === null || b === null) {\n    return false;\n  }\n\n  const keysA = Object.keys(a);\n  const keysB = Object.keys(b);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  const aRecord = a as Record<string, unknown>;\n  const bRecord = b as Record<string, unknown>;\n\n  for (const key of keysA) {\n    if (!keysB.includes(key) || !deepEqual(aRecord[key], bRecord[key])) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * Deletes multiple properties from an object.\n *\n * @param obj - The object to delete the properties from.\n * @param propertyNames - The names of the properties to delete.\n * @returns `true` if any of the properties were present, otherwise `false`.\n */\nexport function deleteProperties(obj: Record<string, unknown>, propertyNames: string[]): boolean {\n  let ans = false;\n\n  for (const propertyName of propertyNames) {\n    ans = deleteProperty(obj, propertyName) || ans;\n  }\n\n  return ans;\n}\n\n/**\n * Deletes a property from an object.\n *\n * @param obj - The object to delete the property from.\n * @param propertyName - The name of the property to delete.\n * @returns `true` if the property was present, otherwise `false`.\n */\nexport function deleteProperty(obj: Record<string, unknown>, propertyName: string): boolean {\n  if (!Object.prototype.hasOwnProperty.call(obj, propertyName)) {\n    return false;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n  delete obj[propertyName];\n  return true;\n}\n\n/**\n * Gets the value of a nested property from an object.\n *\n * @param obj - The object to get the nested property value from.\n * @param path - The path to the nested property.\n * @returns The value of the nested property.\n */\nexport function getNestedPropertyValue(obj: Record<string, unknown>, path: string): unknown {\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split('.');\n  for (const key of keys) {\n    if (node === undefined) {\n      return undefined;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  return node;\n}\n\n/**\n * Gets the prototype of the specified object.\n *\n * @typeParam T - The type of the object.\n * @param instance - The object instance to retrieve the prototype of.\n * @returns The prototype of the object.\n */\nexport function getPrototypeOf<T>(instance: T): T {\n  if (instance === undefined || instance === null) {\n    return instance;\n  }\n  return Object.getPrototypeOf(instance) as T;\n}\n\n/**\n * Retrieves the name of a property of a given type `T`.\n *\n * @typeParam T - The type of the object containing the property.\n * @param name - The name of the property as a string.\n * @returns The name of the property.\n */\nexport function nameof<T>(name: Extract<keyof T, string>): string {\n  return name;\n}\n\n/**\n * Normalizes optional properties to allow `undefined` assignment in strict mode.\n *\n * This utility provides a workaround for the `exactOptionalPropertyTypes` TypeScript flag,\n * which prohibits directly assigning `undefined` to optional properties when the type\n * explicitly omits `undefined`.\n *\n * Example:\n * ```typescript\n * // With `exactOptionalPropertyTypes: true`\n * const x: { prop?: string } = { prop: undefined }; // Compiler error\n *\n * // Using this utility:\n * const y: { prop?: string } = normalizeOptionalProperties<{ prop?: string }>({ prop: undefined }); // Works\n * ```\n *\n * @typeParam T - The target type with optional properties to normalize.\n * @param obj - The object to normalize, allowing explicit `undefined` for optional properties.\n * @returns The normalized object, compatible with `exactOptionalPropertyTypes`.\n */\nexport function normalizeOptionalProperties<T>(obj: UndefinedOnPartialDeep<T>): T {\n  return obj as T;\n}\n\n/**\n * Sets the value of a nested property in an object.\n *\n * @param obj - The object to set the nested property value in.\n * @param path - The path to the nested property.\n * @param value - The value to set.\n */\nexport function setNestedPropertyValue(obj: Record<string, unknown>, path: string, value: unknown): void {\n  const error = new Error(`Property path ${path} not found`);\n  let node: Record<string, unknown> | undefined = obj;\n  const keys = path.split('.');\n  for (const key of keys.slice(0, -1)) {\n    if (node === undefined) {\n      throw error;\n    }\n    node = node[key] as Record<string, unknown> | undefined;\n  }\n\n  const lastKey = keys.at(-1);\n  if (node === undefined || lastKey === undefined) {\n    throw error;\n  }\n\n  node[lastKey] = value;\n}\n\n/**\n * Converts a given value to a JSON string.\n *\n * @param value - The value to be converted to JSON. This can be of any type.\n * @param options - Options for customizing the JSON conversion process.\n * @returns The JSON string representation of the input value.\n */\nexport function toJson(value: unknown, options: Partial<ToJsonOptions> = {}): string {\n  const DEFAULT_OPTIONS: ToJsonOptions = {\n    functionHandlingMode: FunctionHandlingMode.Exclude,\n    maxDepth: -1,\n    shouldCatchToJSONErrors: false,\n    shouldHandleCircularReferences: false,\n    shouldHandleUndefined: false,\n    shouldSortKeys: false,\n    space: 2\n  };\n\n  const fullOptions = { ...DEFAULT_OPTIONS, ...options };\n\n  const maxDepth = fullOptions.maxDepth === -1 ? Infinity : fullOptions.maxDepth;\n\n  if (value === undefined) {\n    return 'undefined';\n  }\n\n  const functionTexts: string[] = [];\n  const objectDepthMap = new WeakMap<object, number>();\n  const usedObjects = new WeakSet<object>();\n\n  const replacer = (key: string, value: unknown): JSONValueF<unknown> | undefined => {\n    if (value === null) {\n      return null;\n    }\n    if (value === undefined) {\n      if (fullOptions.shouldHandleUndefined) {\n        return '__UNDEFINED__';\n      }\n      return undefined;\n    }\n    if (typeof value === 'function') {\n      if (fullOptions.functionHandlingMode === FunctionHandlingMode.Exclude) {\n        return undefined;\n      }\n      const index = functionTexts.length;\n      const functionText = fullOptions.functionHandlingMode === FunctionHandlingMode.Full ? value.toString() : `function ${value.name || 'anonymous'}() { /* ... */ }`;\n      functionTexts.push(functionText);\n      return `__FUNCTION__${index.toString()}`;\n    }\n    if (typeof value === 'object') {\n      if (fullOptions.shouldHandleCircularReferences) {\n        if (usedObjects.has(value)) {\n          return '__CIRCULAR_REFERENCE__';\n        }\n        usedObjects.add(value);\n      }\n\n      let depth = objectDepthMap.get(value);\n      if (depth === undefined) {\n        depth = 0;\n        objectDepthMap.set(value, 0);\n      }\n\n      if (depth > maxDepth) {\n        return '__MAX_DEPTH_LIMIT_REACHED__';\n      }\n\n      const toJSON = (value as Partial<ObjectWithToJSON>).toJSON;\n      if (typeof toJSON === 'function') {\n        try {\n          value = toJSON.call(value);\n          if (value && typeof value === 'object') {\n            objectDepthMap.set(value, depth);\n          }\n          return replacer(key, value);\n        } catch (error) {\n          if (fullOptions.shouldCatchToJSONErrors) {\n            return '__TO_JSON_FAILED__';\n          }\n          throw error;\n        }\n      }\n\n      for (const property of Object.values(value)) {\n        if (!property || typeof property !== 'object') {\n          continue;\n        }\n        objectDepthMap.set(property, depth + 1);\n      }\n\n      if (fullOptions.shouldSortKeys) {\n        return Object.fromEntries(Object.entries(value).sort(([key1], [key2]) => key1.localeCompare(key2)));\n      }\n    }\n\n    return value as JSONValueF<unknown>;\n  };\n\n  let json = JSON.stringify(value, replacer, fullOptions.space) ?? 'undefined';\n  json = replaceAll(json, /\"__FUNCTION__(\\d+)\"/g, (_, indexStr) => functionTexts[parseInt(indexStr)] ?? throwExpression(new Error(`Function with index ${indexStr} not found`)));\n  json = replaceAll(json, '\"__UNDEFINED__\"', 'undefined');\n  json = replaceAll(json, '\"__MAX_DEPTH_LIMIT_REACHED__\"', '{ /* ... */ }');\n  json = replaceAll(json, '\"__CIRCULAR_REFERENCE__\"', '{ /* CIRCULAR REFERENCE */ }');\n  json = replaceAll(json, '\"__TO_JSON_FAILED__\"', '{ /* toJSON() failed */ }');\n  return json;\n}\n\nfunction _assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  for (const source of sources) {\n    Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n  }\n\n  const sourcePrototypes = (sources.map((source) => getPrototypeOf(source)) as (null | object)[]).filter<null | object>((proto) => !!proto) as object[];\n\n  if (sourcePrototypes.length > 0) {\n    const targetPrototype = _assignWithNonEnumerableProperties({}, getPrototypeOf(target), ...sourcePrototypes);\n    Object.setPrototypeOf(target, targetPrototype);\n  }\n\n  return target;\n}\n"],
  "mappings": "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",
  "names": ["FunctionHandlingMode", "value"]
}

|
package/dist/lib/Object.d.ts
CHANGED
@@ -34,6 +34,11 @@ export interface ToJsonOptions {
|
|
34
34
|
* Defaults to `-1`.
|
35
35
|
*/
|
36
36
|
maxDepth: number;
|
37
|
+
/**
|
38
|
+
* Specifies whether to catch errors in `toJSON()` and replace them with a placeholder.
|
39
|
+
* Defaults to `false`.
|
40
|
+
*/
|
41
|
+
shouldCatchToJSONErrors: boolean;
|
37
42
|
/**
|
38
43
|
* Specifies whether to handle circular references in the JSON output.
|
39
44
|
* Defaults to `false`.
|
@@ -44,6 +49,11 @@ export interface ToJsonOptions {
|
|
44
49
|
* Defaults to `false`.
|
45
50
|
*/
|
46
51
|
shouldHandleUndefined: boolean;
|
52
|
+
/**
|
53
|
+
* Specifies whether to sort the keys of the JSON output.
|
54
|
+
* Defaults to `false`.
|
55
|
+
*/
|
56
|
+
shouldSortKeys: boolean;
|
47
57
|
/**
|
48
58
|
* Specifies the indentation of the JSON output. This can be a number of spaces or a string. Defaults to `2`.
|
49
59
|
*/
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "obsidian-dev-utils",
|
3
|
-
"version": "13.
|
3
|
+
"version": "13.5.0",
|
4
4
|
"description": "This is the collection of useful functions that you can use for your Obsidian plugin development",
|
5
5
|
"main": "./dist/lib/index.cjs",
|
6
6
|
"types": "./dist/lib/index.d.ts",
|
@@ -72,7 +72,7 @@
|
|
72
72
|
"monkey-around": "^3.0.0",
|
73
73
|
"npm-run-all": "^4.1.5",
|
74
74
|
"obsidian": "^1.7.2",
|
75
|
-
"obsidian-typings": "^2.14.
|
75
|
+
"obsidian-typings": "^2.14.3",
|
76
76
|
"path-browserify": "^1.0.1",
|
77
77
|
"preact": "^10.25.4",
|
78
78
|
"remark": "^15.0.1",
|