obsidian-dev-utils 24.1.1 → 24.2.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 +7 -0
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/Object.cjs +1 -1
- package/dist/lib/cjs/Object.d.cts +6 -2
- package/dist/lib/cjs/ScriptUtils/esbuild/preprocessPlugin.cjs +1 -1
- package/dist/lib/cjs/Transformers/Transformer.cjs +1 -1
- package/dist/lib/cjs/Transformers/Transformer.d.cts +2 -1
- package/dist/lib/cjs/Type.cjs +1 -1
- package/dist/lib/cjs/Type.d.cts +6 -0
- package/dist/lib/cjs/obsidian/App.cjs +1 -1
- package/dist/lib/cjs/obsidian/FileChange.cjs +1 -1
- package/dist/lib/cjs/obsidian/Frontmatter.cjs +1 -1
- package/dist/lib/cjs/obsidian/Frontmatter.d.cts +2 -1
- package/dist/lib/cjs/obsidian/Link.cjs +1 -1
- package/dist/lib/cjs/obsidian/MonkeyAround.cjs +1 -1
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +50 -23
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +30 -19
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +1 -1
- package/dist/lib/cjs/obsidian/Plugin/PluginTypesBase.cjs +1 -1
- package/dist/lib/cjs/obsidian/Plugin/PluginTypesBase.d.cts +13 -0
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/Object.d.mts +6 -2
- package/dist/lib/esm/Object.mjs +1 -1
- package/dist/lib/esm/ScriptUtils/esbuild/preprocessPlugin.mjs +1 -1
- package/dist/lib/esm/Transformers/Transformer.d.mts +2 -1
- package/dist/lib/esm/Transformers/Transformer.mjs +1 -1
- package/dist/lib/esm/Type.d.mts +6 -0
- package/dist/lib/esm/obsidian/App.mjs +1 -1
- package/dist/lib/esm/obsidian/FileChange.mjs +1 -1
- package/dist/lib/esm/obsidian/Frontmatter.d.mts +2 -1
- package/dist/lib/esm/obsidian/Frontmatter.mjs +1 -1
- package/dist/lib/esm/obsidian/Link.mjs +1 -1
- package/dist/lib/esm/obsidian/MonkeyAround.mjs +1 -1
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +30 -19
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +50 -23
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +1 -1
- package/dist/lib/esm/obsidian/Plugin/PluginTypesBase.d.mts +13 -0
- package/package.json +5 -5
@@ -5,11 +5,11 @@
|
|
5
5
|
*/
|
6
6
|
import type { App } from 'obsidian';
|
7
7
|
import type { Promisable, ReadonlyDeep } from 'type-fest';
|
8
|
+
import type { GenericObject } from '../../Object.cjs';
|
8
9
|
import type { Transformer } from '../../Transformers/Transformer.cjs';
|
9
10
|
import type { MaybeReturn, StringKeys } from '../../Type.cjs';
|
10
|
-
import type { ExtractPlugin, ExtractPluginSettings, PluginTypesBase } from './PluginTypesBase.cjs';
|
11
|
-
type
|
12
|
-
type Validator<T> = (value: T) => Promisable<MaybeReturn<string>>;
|
11
|
+
import type { ExtractPlugin, ExtractPluginSettings, ExtractPluginSettingsPropertyNames, PluginTypesBase } from './PluginTypesBase.cjs';
|
12
|
+
type Validator<PluginSettings extends object, PropertyName extends StringKeys<PluginSettings> = StringKeys<PluginSettings>> = (value: PluginSettings[PropertyName], settings: PluginSettings) => Promisable<MaybeReturn<string>>;
|
13
13
|
/**
|
14
14
|
* Base class for managing plugin settings.
|
15
15
|
*
|
@@ -36,13 +36,22 @@ export declare abstract class PluginSettingsManagerBase<PluginTypes extends Plug
|
|
36
36
|
* @returns A {@link Promise} that resolves when the settings are saved.
|
37
37
|
*/
|
38
38
|
editAndSave(editor: (settings: ExtractPluginSettings<PluginTypes>) => Promisable<void>, context?: unknown): Promise<void>;
|
39
|
+
/**
|
40
|
+
* Ensures the settings are safe.
|
41
|
+
*
|
42
|
+
* It runs validation for each property and sets the default value if the validation fails.
|
43
|
+
*
|
44
|
+
* @param settings - The settings.
|
45
|
+
* @returns A {@link Promise} that resolves when the settings are safe.
|
46
|
+
*/
|
47
|
+
ensureSafe(settings: ExtractPluginSettings<PluginTypes>): Promise<void>;
|
39
48
|
/**
|
40
49
|
* Gets a property of the plugin settings.
|
41
50
|
*
|
42
51
|
* @param propertyName - The name of the property.
|
43
52
|
* @returns The property.
|
44
53
|
*/
|
45
|
-
getProperty<PropertyName extends
|
54
|
+
getProperty<PropertyName extends ExtractPluginSettingsPropertyNames<PluginTypes>>(propertyName: PropertyName): PluginSettingsProperty<ExtractPluginSettings<PluginTypes>, PropertyName>;
|
46
55
|
/**
|
47
56
|
* Loads the plugin settings from the file.
|
48
57
|
*
|
@@ -69,20 +78,20 @@ export declare abstract class PluginSettingsManagerBase<PluginTypes extends Plug
|
|
69
78
|
*
|
70
79
|
* @param _record - The record.
|
71
80
|
*/
|
72
|
-
protected onLoadRecord(_record:
|
81
|
+
protected onLoadRecord(_record: GenericObject): Promise<void>;
|
73
82
|
/**
|
74
83
|
* Called when the plugin settings are saving.
|
75
84
|
*
|
76
85
|
* @param _record - The record.
|
77
86
|
*/
|
78
|
-
protected onSavingRecord(_record:
|
87
|
+
protected onSavingRecord(_record: GenericObject): Promise<void>;
|
79
88
|
/**
|
80
89
|
* Registers a validator for a property.
|
81
90
|
*
|
82
91
|
* @param propertyName - The name of the property.
|
83
92
|
* @param validator - The validator.
|
84
93
|
*/
|
85
|
-
protected registerValidator<PropertyName extends
|
94
|
+
protected registerValidator<PropertyName extends ExtractPluginSettingsPropertyNames<PluginTypes>>(propertyName: PropertyName, validator: Validator<ExtractPluginSettings<PluginTypes>, PropertyName>): void;
|
86
95
|
/**
|
87
96
|
* Registers the validators.
|
88
97
|
*
|
@@ -98,29 +107,29 @@ export declare abstract class PluginSettingsManagerBase<PluginTypes extends Plug
|
|
98
107
|
*
|
99
108
|
* @typeParam T - The type of the property.
|
100
109
|
*/
|
101
|
-
export declare class PluginSettingsProperty<
|
110
|
+
export declare class PluginSettingsProperty<PluginSettings extends object, PropertyName extends StringKeys<PluginSettings> = StringKeys<PluginSettings>> {
|
102
111
|
private readonly propertyName;
|
103
|
-
readonly
|
112
|
+
private readonly currentSettings;
|
104
113
|
private readonly validator;
|
105
|
-
|
114
|
+
readonly defaultValue: typeof this.PropertyType;
|
106
115
|
/**
|
107
116
|
* The current value of the property.
|
108
117
|
*
|
109
118
|
* @returns The current value.
|
110
119
|
*/
|
111
|
-
get currentValue():
|
120
|
+
get currentValue(): typeof this.PropertyType;
|
112
121
|
/**
|
113
122
|
* The last saved value of the property.
|
114
123
|
*
|
115
124
|
* @returns The last saved value.
|
116
125
|
*/
|
117
|
-
get lastSavedValue():
|
126
|
+
get lastSavedValue(): typeof this.PropertyType;
|
118
127
|
/**
|
119
128
|
* The safe value of the property.
|
120
129
|
*
|
121
130
|
* @returns The safe value.
|
122
131
|
*/
|
123
|
-
get safeValue():
|
132
|
+
get safeValue(): typeof this.PropertyType;
|
124
133
|
/**
|
125
134
|
* The validation message of the property.
|
126
135
|
*
|
@@ -130,15 +139,16 @@ export declare class PluginSettingsProperty<T> {
|
|
130
139
|
private _currentValue;
|
131
140
|
private _lastSavedValue;
|
132
141
|
private _validationMessage;
|
142
|
+
private PropertyType;
|
143
|
+
private get currentSettingsRecord();
|
133
144
|
/**
|
134
145
|
* Creates a new plugin settings property.
|
135
146
|
*
|
136
147
|
* @param propertyName - The name of the property.
|
137
|
-
* @param
|
148
|
+
* @param currentSettings - The current settings.
|
138
149
|
* @param validator - The validator of the property.
|
139
|
-
* @param propertySetter - The property setter of the property.
|
140
150
|
*/
|
141
|
-
constructor(propertyName:
|
151
|
+
constructor(propertyName: StringKeys<PluginSettings>, currentSettings: PluginSettings, validator: Validator<PluginSettings, PropertyName>);
|
142
152
|
/**
|
143
153
|
* Resets the current value of the property to the default value.
|
144
154
|
*/
|
@@ -160,13 +170,14 @@ export declare class PluginSettingsProperty<T> {
|
|
160
170
|
*
|
161
171
|
* @param value - The value to set.
|
162
172
|
*/
|
163
|
-
setValue(value:
|
173
|
+
setValue(value: typeof this.PropertyType): void;
|
164
174
|
/**
|
165
175
|
* Validates the current value of the property.
|
166
176
|
*
|
167
|
-
* @
|
177
|
+
* @param settings - The settings to validate. If not provided, the current settings will be used.
|
178
|
+
* @returns A {@link Promise} that resolves to the validation message.
|
168
179
|
*/
|
169
|
-
validate(): Promise<
|
180
|
+
validate(settings?: PluginSettings): Promise<string>;
|
170
181
|
private showWarning;
|
171
182
|
}
|
172
183
|
export {};
|
@@ -165,4 +165,4 @@ class PluginSettingsTabBase extends import_obsidian.PluginSettingTab {
|
|
165
165
|
0 && (module.exports = {
|
166
166
|
PluginSettingsTabBase
|
167
167
|
});
|
168
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsTabBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a base class for creating plugin setting tabs in Obsidian.\n * It provides a utility method to bind value components to plugin settings and handle changes.\n */\n\nimport type { Debouncer } from 'obsidian';\nimport type {\n  ConditionalKeys,\n  Promisable\n} from 'type-fest';\n\nimport {\n  debounce,\n  PluginSettingTab,\n  setTooltip\n} from 'obsidian';\n\nimport type { StringKeys } from '../../Type.ts';\nimport type { ValueComponentWithChangeTracking } from '../Components/ValueComponentWithChangeTracking.ts';\nimport type { ValidationMessageHolder } from '../ValidationMessage.ts';\nimport type { PluginSettingsProperty } from './PluginSettingsManagerBase.ts';\nimport type {\n  ExtractPlugin,\n  ExtractPluginSettings,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../Async.ts';\nimport { CssClass } from '../../CssClass.ts';\nimport { noop } from '../../Function.ts';\nimport { getTextBasedComponentValue } from '../Components/TextBasedComponent.ts';\nimport { getValidatorComponent } from '../Components/ValidatorComponent.ts';\nimport { isValidationMessageHolder } from '../ValidationMessage.ts';\nimport { getPluginId } from './PluginId.ts';\n\n/**\n * Options for binding a value component to a plugin setting.\n */\nexport interface BindOptions<T> {\n  /**\n   * A callback function that is called when the value of the component changes.\n   */\n  onChanged?(newValue: T | undefined, oldValue: T): Promisable<void>;\n\n  /**\n   * Whether to reset the setting when the component value is empty. Default is `true`.\n   * Applicable only to text-based components.\n   */\n  shouldResetSettingWhenComponentIsEmpty?: boolean;\n\n  /**\n   * Whether to show the validation message when the component value is invalid. Default is `true`.\n   */\n  shouldShowValidationMessage?: boolean;\n}\n\n/**\n * Extended options for binding a value component to a plugin setting.\n */\nexport interface BindOptionsExtended<\n  PluginSettings extends object,\n  UIValue,\n  PropertyName extends StringKeys<PluginSettings>\n> extends BindOptions<PluginSettings[PropertyName]> {\n  /**\n   * Converts the UI component's value back to the plugin settings value.\n   *\n   * @param uiValue - The value of the UI component.\n   * @returns The value to set on the plugin settings.\n   */\n  componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[PropertyName] | ValidationMessageHolder;\n\n  /**\n   * Converts the plugin settings value to the value used by the UI component.\n   *\n   * @param pluginSettingsValue - The value of the property in the plugin settings.\n   * @returns The value to set on the UI component.\n   */\n  pluginSettingsToComponentValueConverter: (pluginSettingsValue: PluginSettings[PropertyName]) => UIValue;\n}\n\n/**\n * Base class for creating plugin settings tabs in Obsidian.\n * Provides a method for binding value components to plugin settings and handling changes.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginSettingsTabBase<PluginTypes extends PluginTypesBase> extends PluginSettingTab {\n  /**\n   * Whether the plugin settings tab is open.\n   *\n   * @returns Whether the plugin settings tab is open.\n   */\n  public get isOpen(): boolean {\n    return this._isOpen;\n  }\n\n  /**\n   * The debounce timeout for saving settings.\n   *\n   * @returns The debounce timeout for saving settings.\n   */\n  protected get saveSettingsDebounceTimeoutInMilliseconds(): number {\n    const DEFAULT = 2_000;\n    return DEFAULT;\n  }\n\n  private _isOpen = false;\n\n  private saveSettingsDebounced: Debouncer<[], void>;\n\n  /**\n   * Creates a new plugin settings tab.\n   *\n   * @param plugin - The plugin.\n   */\n  public constructor(public override plugin: ExtractPlugin<PluginTypes>) {\n    super(plugin.app, plugin);\n    this.containerEl.addClass(CssClass.LibraryName, getPluginId(), CssClass.PluginSettingsTab);\n    this.saveSettingsDebounced = debounce(convertAsyncToSync(() => this.plugin.settingsManager.saveToFile()), this.saveSettingsDebounceTimeoutInMilliseconds);\n  }\n\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: ConditionalKeys<ExtractPluginSettings<PluginTypes>, UIValue>,\n    options?: BindOptions<UIValue>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options: BindOptionsExtended<ExtractPluginSettings<PluginTypes>, UIValue, PropertyName>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options?: BindOptions<ExtractPluginSettings<PluginTypes>[PropertyName]>\n  ): TValueComponent {\n    type PluginSettings = ExtractPluginSettings<PluginTypes>;\n    type PropertyType = PluginSettings[PropertyName];\n    const DEFAULT_OPTIONS: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = {\n      componentToPluginSettingsValueConverter: (value: UIValue): PropertyType => value as PropertyType,\n      onChanged: noop,\n      pluginSettingsToComponentValueConverter: (value: PropertyType): UIValue => value as UIValue,\n      shouldResetSettingWhenComponentIsEmpty: true,\n      shouldShowValidationMessage: true\n    };\n\n    const optionsExt: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = { ...DEFAULT_OPTIONS, ...options };\n\n    const validatorElement = getValidatorComponent(valueComponent)?.validatorEl;\n\n    const property = this.plugin.settingsManager.getProperty(propertyName) as PluginSettingsProperty<PropertyType>;\n\n    const value = property.currentValue;\n\n    const textBasedComponent = getTextBasedComponentValue(valueComponent);\n    textBasedComponent?.setPlaceholderValue(optionsExt.pluginSettingsToComponentValueConverter(property.defaultValue));\n\n    if (property.currentValue === property.defaultValue && textBasedComponent && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n      textBasedComponent.empty();\n    } else {\n      valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(value));\n    }\n\n    valueComponent.onChange(async (uiValue) => {\n      const oldValue = property.currentValue;\n      let newValue: PropertyType | undefined = undefined;\n      if (textBasedComponent?.isEmpty() && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n        property.reset();\n        newValue = property.defaultValue;\n      } else {\n        const convertedValue = optionsExt.componentToPluginSettingsValueConverter(uiValue);\n        if (isValidationMessageHolder(convertedValue)) {\n          property.setValidationMessage(convertedValue.validationMessage);\n        } else {\n          property.setValue(convertedValue);\n          await property.validate();\n          newValue = convertedValue;\n        }\n      }\n      updateValidatorElement();\n      if (newValue !== undefined) {\n        await optionsExt.onChanged(newValue, oldValue);\n      }\n      this.saveSettingsDebounced();\n    });\n\n    validatorElement?.addEventListener('focus', updateValidatorElement);\n    validatorElement?.addEventListener('blur', updateValidatorElement);\n\n    updateValidatorElement();\n    return valueComponent;\n\n    function updateValidatorElement(): void {\n      if (!validatorElement) {\n        return;\n      }\n\n      if (!property.validationMessage) {\n        validatorElement.setCustomValidity('');\n        validatorElement.checkValidity();\n        property.setValidationMessage(validatorElement.validationMessage);\n      }\n\n      validatorElement.setCustomValidity(property.validationMessage);\n      setTooltip(validatorElement, property.validationMessage);\n      if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {\n        validatorElement.reportValidity();\n      }\n    }\n  }\n\n  /**\n   * Renders the plugin settings tab.\n   */\n  public override display(): void {\n    this._isOpen = true;\n  }\n\n  /**\n   * Hides the plugin settings tab.\n   */\n  public override hide(): void {\n    super.hide();\n    this._isOpen = false;\n    this.saveSettingsDebounced.cancel();\n    invokeAsyncSafely(() => this.plugin.settingsManager.saveToFile());\n  }\n\n  /**\n   * Shows the plugin settings tab.\n   */\n  public show(): void {\n    this.app.setting.openTab(this);\n  }\n}\n"],
  "mappings": "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",
  "names": ["value"]
}

|
168
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsTabBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a base class for creating plugin setting tabs in Obsidian.\n * It provides a utility method to bind value components to plugin settings and handle changes.\n */\n\nimport type { Debouncer } from 'obsidian';\nimport type {\n  ConditionalKeys,\n  Promisable\n} from 'type-fest';\n\nimport {\n  debounce,\n  PluginSettingTab,\n  setTooltip\n} from 'obsidian';\n\nimport type { StringKeys } from '../../Type.ts';\nimport type { ValueComponentWithChangeTracking } from '../Components/ValueComponentWithChangeTracking.ts';\nimport type { ValidationMessageHolder } from '../ValidationMessage.ts';\nimport type { PluginSettingsProperty } from './PluginSettingsManagerBase.ts';\nimport type {\n  ExtractPlugin,\n  ExtractPluginSettings,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../Async.ts';\nimport { CssClass } from '../../CssClass.ts';\nimport { noop } from '../../Function.ts';\nimport { getTextBasedComponentValue } from '../Components/TextBasedComponent.ts';\nimport { getValidatorComponent } from '../Components/ValidatorComponent.ts';\nimport { isValidationMessageHolder } from '../ValidationMessage.ts';\nimport { getPluginId } from './PluginId.ts';\n\n/**\n * Options for binding a value component to a plugin setting.\n */\nexport interface BindOptions<T> {\n  /**\n   * A callback function that is called when the value of the component changes.\n   */\n  onChanged?(newValue: T | undefined, oldValue: T): Promisable<void>;\n\n  /**\n   * Whether to reset the setting when the component value is empty. Default is `true`.\n   * Applicable only to text-based components.\n   */\n  shouldResetSettingWhenComponentIsEmpty?: boolean;\n\n  /**\n   * Whether to show the validation message when the component value is invalid. Default is `true`.\n   */\n  shouldShowValidationMessage?: boolean;\n}\n\n/**\n * Extended options for binding a value component to a plugin setting.\n */\nexport interface BindOptionsExtended<\n  PluginSettings extends object,\n  UIValue,\n  PropertyName extends StringKeys<PluginSettings>\n> extends BindOptions<PluginSettings[PropertyName]> {\n  /**\n   * Converts the UI component's value back to the plugin settings value.\n   *\n   * @param uiValue - The value of the UI component.\n   * @returns The value to set on the plugin settings.\n   */\n  componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[PropertyName] | ValidationMessageHolder;\n\n  /**\n   * Converts the plugin settings value to the value used by the UI component.\n   *\n   * @param pluginSettingsValue - The value of the property in the plugin settings.\n   * @returns The value to set on the UI component.\n   */\n  pluginSettingsToComponentValueConverter: (pluginSettingsValue: PluginSettings[PropertyName]) => UIValue;\n}\n\n/**\n * Base class for creating plugin settings tabs in Obsidian.\n * Provides a method for binding value components to plugin settings and handling changes.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginSettingsTabBase<PluginTypes extends PluginTypesBase> extends PluginSettingTab {\n  /**\n   * Whether the plugin settings tab is open.\n   *\n   * @returns Whether the plugin settings tab is open.\n   */\n  public get isOpen(): boolean {\n    return this._isOpen;\n  }\n\n  /**\n   * The debounce timeout for saving settings.\n   *\n   * @returns The debounce timeout for saving settings.\n   */\n  protected get saveSettingsDebounceTimeoutInMilliseconds(): number {\n    const DEFAULT = 2_000;\n    return DEFAULT;\n  }\n\n  private _isOpen = false;\n\n  private saveSettingsDebounced: Debouncer<[], void>;\n\n  /**\n   * Creates a new plugin settings tab.\n   *\n   * @param plugin - The plugin.\n   */\n  public constructor(public override plugin: ExtractPlugin<PluginTypes>) {\n    super(plugin.app, plugin);\n    this.containerEl.addClass(CssClass.LibraryName, getPluginId(), CssClass.PluginSettingsTab);\n    this.saveSettingsDebounced = debounce(convertAsyncToSync(() => this.plugin.settingsManager.saveToFile()), this.saveSettingsDebounceTimeoutInMilliseconds);\n  }\n\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: ConditionalKeys<ExtractPluginSettings<PluginTypes>, UIValue>,\n    options?: BindOptions<UIValue>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options: BindOptionsExtended<ExtractPluginSettings<PluginTypes>, UIValue, PropertyName>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options?: BindOptions<ExtractPluginSettings<PluginTypes>[PropertyName]>\n  ): TValueComponent {\n    type PluginSettings = ExtractPluginSettings<PluginTypes>;\n    type PropertyType = PluginSettings[PropertyName];\n    const DEFAULT_OPTIONS: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = {\n      componentToPluginSettingsValueConverter: (value: UIValue): PropertyType => value as PropertyType,\n      onChanged: noop,\n      pluginSettingsToComponentValueConverter: (value: PropertyType): UIValue => value as UIValue,\n      shouldResetSettingWhenComponentIsEmpty: true,\n      shouldShowValidationMessage: true\n    };\n\n    const optionsExt: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = { ...DEFAULT_OPTIONS, ...options };\n\n    const validatorElement = getValidatorComponent(valueComponent)?.validatorEl;\n\n    const property = this.plugin.settingsManager.getProperty(propertyName) as PluginSettingsProperty<PluginSettings, PropertyName>;\n\n    const value = property.currentValue;\n\n    const textBasedComponent = getTextBasedComponentValue(valueComponent);\n    textBasedComponent?.setPlaceholderValue(optionsExt.pluginSettingsToComponentValueConverter(property.defaultValue));\n\n    if (property.currentValue === property.defaultValue && textBasedComponent && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n      textBasedComponent.empty();\n    } else {\n      valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(value));\n    }\n\n    valueComponent.onChange(async (uiValue) => {\n      const oldValue = property.currentValue;\n      let newValue: PropertyType | undefined = undefined;\n      if (textBasedComponent?.isEmpty() && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n        property.reset();\n        newValue = property.defaultValue;\n      } else {\n        const convertedValue = optionsExt.componentToPluginSettingsValueConverter(uiValue);\n        if (isValidationMessageHolder(convertedValue)) {\n          property.setValidationMessage(convertedValue.validationMessage);\n        } else {\n          property.setValue(convertedValue);\n          await property.validate();\n          newValue = convertedValue;\n        }\n      }\n      updateValidatorElement();\n      if (newValue !== undefined) {\n        await optionsExt.onChanged(newValue, oldValue);\n      }\n      this.saveSettingsDebounced();\n    });\n\n    validatorElement?.addEventListener('focus', updateValidatorElement);\n    validatorElement?.addEventListener('blur', updateValidatorElement);\n\n    updateValidatorElement();\n    return valueComponent;\n\n    function updateValidatorElement(): void {\n      if (!validatorElement) {\n        return;\n      }\n\n      if (!property.validationMessage) {\n        validatorElement.setCustomValidity('');\n        validatorElement.checkValidity();\n        property.setValidationMessage(validatorElement.validationMessage);\n      }\n\n      validatorElement.setCustomValidity(property.validationMessage);\n      setTooltip(validatorElement, property.validationMessage);\n      if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {\n        validatorElement.reportValidity();\n      }\n    }\n  }\n\n  /**\n   * Renders the plugin settings tab.\n   */\n  public override display(): void {\n    this._isOpen = true;\n  }\n\n  /**\n   * Hides the plugin settings tab.\n   */\n  public override hide(): void {\n    super.hide();\n    this._isOpen = false;\n    this.saveSettingsDebounced.cancel();\n    invokeAsyncSafely(() => this.plugin.settingsManager.saveToFile());\n  }\n\n  /**\n   * Shows the plugin settings tab.\n   */\n  public show(): void {\n    this.app.setting.openTab(this);\n  }\n}\n"],
  "mappings": "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",
  "names": ["value"]
}

|
@@ -21,4 +21,4 @@ var __copyProps = (to, from, except, desc) => {
|
|
21
21
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
22
22
|
var PluginTypesBase_exports = {};
|
23
23
|
module.exports = __toCommonJS(PluginTypesBase_exports);
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
24
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL1BsdWdpbi9QbHVnaW5UeXBlc0Jhc2UudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uXG4gKlxuICogVHlwZXMgaGVscGVycyBmb3IgcGx1Z2luIHR5cGVzLlxuICovXG5cbmltcG9ydCB0eXBlIHtcbiAgUHJvcGVydHlWYWx1ZXMsXG4gIFN0cmluZ0tleXNcbn0gZnJvbSAnLi4vLi4vVHlwZS50cyc7XG5pbXBvcnQgdHlwZSB7IFBsdWdpbkJhc2UgfSBmcm9tICcuL1BsdWdpbkJhc2UudHMnO1xuaW1wb3J0IHR5cGUgeyBQbHVnaW5TZXR0aW5nc01hbmFnZXJCYXNlIH0gZnJvbSAnLi9QbHVnaW5TZXR0aW5nc01hbmFnZXJCYXNlLnRzJztcbmltcG9ydCB0eXBlIHsgUGx1Z2luU2V0dGluZ3NUYWJCYXNlIH0gZnJvbSAnLi9QbHVnaW5TZXR0aW5nc1RhYkJhc2UudHMnO1xuXG4vKipcbiAqIEV4dHJhY3RzIHRoZSBwbHVnaW4gZnJvbSB0aGUgcGx1Z2luIHR5cGVzLlxuICpcbiAqIEB0eXBlUGFyYW0gUGx1Z2luVHlwZXMgLSBUaGUgcGx1Z2luIHR5cGVzLlxuICovXG5leHBvcnQgdHlwZSBFeHRyYWN0UGx1Z2luPFBsdWdpblR5cGVzIGV4dGVuZHMgUGx1Z2luVHlwZXNCYXNlPiA9IFBsdWdpblR5cGVzWydwbHVnaW4nXTtcblxuLyoqXG4gKiBFeHRyYWN0cyB0aGUgcGx1Z2luIHNldHRpbmdzIGZyb20gdGhlIHBsdWdpbiB0eXBlcy5cbiAqXG4gKiBAdHlwZVBhcmFtIFBsdWdpblR5cGVzIC0gVGhlIHBsdWdpbiB0eXBlcy5cbiAqL1xuZXhwb3J0IHR5cGUgRXh0cmFjdFBsdWdpblNldHRpbmdzPFBsdWdpblR5cGVzIGV4dGVuZHMgUGx1Z2luVHlwZXNCYXNlPiA9IFBsdWdpblR5cGVzWydwbHVnaW5TZXR0aW5ncyddO1xuXG4vKipcbiAqIEV4dHJhY3RzIHRoZSBwbHVnaW4gc2V0dGluZ3MgbWFuYWdlciBmcm9tIHRoZSBwbHVnaW4gdHlwZXMuXG4gKlxuICogQHR5cGVQYXJhbSBQbHVnaW5UeXBlcyAtIFRoZSBwbHVnaW4gdHlwZXMuXG4gKi9cbmV4cG9ydCB0eXBlIEV4dHJhY3RQbHVnaW5TZXR0aW5nc01hbmFnZXI8UGx1Z2luVHlwZXMgZXh0ZW5kcyBQbHVnaW5UeXBlc0Jhc2U+ID0gUGx1Z2luVHlwZXNbJ3BsdWdpblNldHRpbmdzTWFuYWdlciddO1xuXG4vKipcbiAqIEV4dHJhY3RzIHRoZSBwbHVnaW4gc2V0dGluZ3MgcHJvcGVydHkgbmFtZXMgZnJvbSB0aGUgcGx1Z2luIHR5cGVzLlxuICpcbiAqIEB0eXBlUGFyYW0gUGx1Z2luVHlwZXMgLSBUaGUgcGx1Z2luIHR5cGVzLlxuICovXG5leHBvcnQgdHlwZSBFeHRyYWN0UGx1Z2luU2V0dGluZ3NQcm9wZXJ0eU5hbWVzPFBsdWdpblR5cGVzIGV4dGVuZHMgUGx1Z2luVHlwZXNCYXNlPiA9IFN0cmluZ0tleXM8RXh0cmFjdFBsdWdpblNldHRpbmdzPFBsdWdpblR5cGVzPj47XG5cbi8qKlxuICogRXh0cmFjdHMgdGhlIHBsdWdpbiBzZXR0aW5ncyBwcm9wZXJ0eSB2YWx1ZXMgZnJvbSB0aGUgcGx1Z2luIHR5cGVzLlxuICpcbiAqIEB0eXBlUGFyYW0gUGx1Z2luVHlwZXMgLSBUaGUgcGx1Z2luIHR5cGVzLlxuICovXG5leHBvcnQgdHlwZSBFeHRyYWN0UGx1Z2luU2V0dGluZ3NQcm9wZXJ0eVZhbHVlczxQbHVnaW5UeXBlcyBleHRlbmRzIFBsdWdpblR5cGVzQmFzZT4gPSBQcm9wZXJ0eVZhbHVlczxFeHRyYWN0UGx1Z2luU2V0dGluZ3M8UGx1Z2luVHlwZXM+PjtcblxuLyoqXG4gKiBFeHRyYWN0cyB0aGUgcGx1Z2luIHNldHRpbmdzIHRhYiBmcm9tIHRoZSBwbHVnaW4gdHlwZXMuXG4gKlxuICogQHR5cGVQYXJhbSBQbHVnaW5UeXBlcyAtIFRoZSBwbHVnaW4gdHlwZXMuXG4gKi9cbmV4cG9ydCB0eXBlIEV4dHJhY3RQbHVnaW5TZXR0aW5nc1RhYjxQbHVnaW5UeXBlcyBleHRlbmRzIFBsdWdpblR5cGVzQmFzZT4gPSBQbHVnaW5UeXBlc1sncGx1Z2luU2V0dGluZ3NUYWInXTtcblxuLyoqXG4gKiBUaGUgYmFzZSB0eXBlIGZvciBwbHVnaW4gdHlwZXMuXG4gKlxuICogVGhlIGludGVyZmFjZSBpcyB1c2VkIG9ubHkgZm9yIHR5cGUgaW5mZXJlbmNlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBsdWdpblR5cGVzQmFzZSB7XG4gIC8qKlxuICAgKiBUaGUgcGx1Z2luLlxuICAgKi9cbiAgcGx1Z2luOiBQbHVnaW5CYXNlPFBsdWdpblR5cGVzQmFzZT47XG4gIC8qKlxuICAgKiBUaGUgcGx1Z2luIHNldHRpbmdzLlxuICAgKi9cbiAgcGx1Z2luU2V0dGluZ3M6IG9iamVjdDtcbiAgLyoqXG4gICAqIFRoZSBwbHVnaW4gc2V0dGluZ3MgbWFuYWdlci5cbiAgICovXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gIHBsdWdpblNldHRpbmdzTWFuYWdlcjogUGx1Z2luU2V0dGluZ3NNYW5hZ2VyQmFzZTxhbnk+O1xuICAvKipcbiAgICogVGhlIHBsdWdpbiBzZXR0aW5ncyB0YWIuXG4gICAqL1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICBwbHVnaW5TZXR0aW5nc1RhYjogUGx1Z2luU2V0dGluZ3NUYWJCYXNlPGFueT47XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBOyIsCiAgIm5hbWVzIjogW10KfQo=
|
@@ -3,6 +3,7 @@
|
|
3
3
|
*
|
4
4
|
* Types helpers for plugin types.
|
5
5
|
*/
|
6
|
+
import type { PropertyValues, StringKeys } from '../../Type.cjs';
|
6
7
|
import type { PluginBase } from './PluginBase.cjs';
|
7
8
|
import type { PluginSettingsManagerBase } from './PluginSettingsManagerBase.cjs';
|
8
9
|
import type { PluginSettingsTabBase } from './PluginSettingsTabBase.cjs';
|
@@ -24,6 +25,18 @@ export type ExtractPluginSettings<PluginTypes extends PluginTypesBase> = PluginT
|
|
24
25
|
* @typeParam PluginTypes - The plugin types.
|
25
26
|
*/
|
26
27
|
export type ExtractPluginSettingsManager<PluginTypes extends PluginTypesBase> = PluginTypes['pluginSettingsManager'];
|
28
|
+
/**
|
29
|
+
* Extracts the plugin settings property names from the plugin types.
|
30
|
+
*
|
31
|
+
* @typeParam PluginTypes - The plugin types.
|
32
|
+
*/
|
33
|
+
export type ExtractPluginSettingsPropertyNames<PluginTypes extends PluginTypesBase> = StringKeys<ExtractPluginSettings<PluginTypes>>;
|
34
|
+
/**
|
35
|
+
* Extracts the plugin settings property values from the plugin types.
|
36
|
+
*
|
37
|
+
* @typeParam PluginTypes - The plugin types.
|
38
|
+
*/
|
39
|
+
export type ExtractPluginSettingsPropertyValues<PluginTypes extends PluginTypesBase> = PropertyValues<ExtractPluginSettings<PluginTypes>>;
|
27
40
|
/**
|
28
41
|
* Extracts the plugin settings tab from the plugin types.
|
29
42
|
*
|
package/dist/lib/esm/Library.mjs
CHANGED
@@ -5,7 +5,7 @@ if you want to view the source, please visit the github repository of this plugi
|
|
5
5
|
|
6
6
|
(function initEsm(){if(globalThis.process){return}const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};globalThis.process=browserProcess})();
|
7
7
|
|
8
|
-
const LIBRARY_VERSION = "24.
|
8
|
+
const LIBRARY_VERSION = "24.2.0";
|
9
9
|
const LIBRARY_NAME = "obsidian-dev-utils";
|
10
10
|
const LIBRARY_STYLES = ".obsidian-dev-utils input[type=url] {\n height: var(--input-height);\n}\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=url],\n.obsidian-dev-utils input[type=week] {\n -webkit-app-region: no-drag;\n background: var(--background-modifier-form-field);\n border: var(--input-border-width) solid var(--background-modifier-border);\n color: var(--text-normal);\n font-family: inherit;\n padding: var(--size-4-1) var(--size-4-2);\n font-size: var(--font-ui-small);\n border-radius: var(--input-radius);\n outline: none;\n}\n@media (hover: hover) {\n .obsidian-dev-utils input[type=month]:hover,\n .obsidian-dev-utils input[type=time]:hover,\n .obsidian-dev-utils input[type=url]:hover,\n .obsidian-dev-utils input[type=week]:hover {\n border-color: var(--background-modifier-border-hover);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n }\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus {\n border-color: var(--background-modifier-border-focus);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus, .obsidian-dev-utils input[type=month]:focus-visible,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=time]:focus-visible,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=url]:focus-visible,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus,\n.obsidian-dev-utils input[type=week]:focus-visible {\n box-shadow: 0 0 0 2px var(--background-modifier-border-focus);\n}\n.obsidian-dev-utils input[type=month]::placeholder,\n.obsidian-dev-utils input[type=time]::placeholder,\n.obsidian-dev-utils input[type=url]::placeholder,\n.obsidian-dev-utils input[type=week]::placeholder {\n color: var(--text-faint);\n}\n.mod-rtl input[type=month],\n.mod-rtl input[type=time],\n.mod-rtl input[type=week],\n.is-rtl input[type=month],\n.is-rtl input[type=time],\n.is-rtl input[type=week],\n.rtl input[type=month],\n.rtl input[type=time],\n.rtl input[type=week] {\n direction: rtl;\n}\n.mod-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.rtl input[type=month]::-webkit-calendar-picker-indicator,\n.rtl input[type=time]::-webkit-calendar-picker-indicator,\n.rtl input[type=week]::-webkit-calendar-picker-indicator {\n right: var(--size-4-1);\n left: auto;\n}\n\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=week] {\n font-variant-numeric: tabular-nums;\n position: relative;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-text {\n color: var(--text-faint);\n padding-inline-end: 0;\n}\n.obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n position: absolute;\n left: var(--size-4-1);\n right: auto;\n opacity: 0.5;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:focus {\n background-color: var(--text-selection);\n color: var(--text-normal);\n cursor: text;\n}\n.mod-rtl .obsidian-dev-utils input[type=month], .is-rtl .obsidian-dev-utils input[type=month], .rtl .obsidian-dev-utils input[type=month],\n.mod-rtl .obsidian-dev-utils input[type=time],\n.is-rtl .obsidian-dev-utils input[type=time],\n.rtl .obsidian-dev-utils input[type=time],\n.mod-rtl .obsidian-dev-utils input[type=week],\n.is-rtl .obsidian-dev-utils input[type=week],\n.rtl .obsidian-dev-utils input[type=week] {\n direction: rtl;\n}\n.mod-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .is-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n left: auto;\n right: var(--size-4-1);\n}\n\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=month],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=time],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=week] {\n padding-inline-start: var(--size-4-6);\n}\n\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator {\n margin-inline-start: 0;\n}\n\n.obsidian-dev-utils.modal-container .ok-button {\n margin-right: 10px;\n margin-top: 20px;\n}\n\n.obsidian-dev-utils .multiple-dropdown-component select,\n.obsidian-dev-utils .multiple-dropdown-component select:focus,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown {\n height: auto;\n padding-top: 3px;\n}\n.obsidian-dev-utils .multiple-dropdown-component select option:checked,\n.obsidian-dev-utils .multiple-dropdown-component select:focus option:checked,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown option:checked {\n background-color: #1967d2;\n color: #fff;\n}\n\n.obsidian-dev-utils.prompt-modal .text-box {\n width: 100%;\n}\n\n.obsidian-dev-utils.tri-state-checkbox-component input[type=checkbox]:indeterminate {\n appearance: checkbox;\n}\n\n.obsidian-dev-utils :invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf-8,%7B%22version%22:3,%22sourceRoot%22:%22%22,%22sources%22:%5B%22../src/styles/input.scss%22,%22../src/styles/input-time.scss%22,%22../src/styles/modal-container.scss%22,%22../src/styles/multiple-dropdown-component.scss%22,%22../src/styles/prompt-modal.scss%22,%22../src/styles/tri-state-checkbox-component.scss%22,%22../src/styles/validation.scss%22%5D,%22names%22:%5B%5D,%22mappings%22:%22AACE;EACE;;AAGF;AAAA;AAAA;AAAA;EAIE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;AAAA;AAAA;AAAA;IACE;IACA,YACE;;;AAMR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA,YACE;;AAIJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAGF;AAAA;AAAA;AAAA;EACE;;AASE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AC5DV;AAAA;AAAA;EAGE;EACA;;AAEA;AAAA;AAAA;EACE;EACA;;AAGF;AAAA;AAAA;EACE;EACA;EACA;EACA;;AAMA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA;EACA;;AAIK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGP;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AAKF;AAAA;AAAA;EACE;;;AAMJ;EACE;;;AChDF;EACE;EACA;;;ACFF;AAAA;AAAA;EAGE;EACA;;AAEA;AAAA;AAAA;EACE;EACA;;;ACRJ;EACE;;;ACDF;EACE;;;ACFJ;EACE%22,%22file%22:%22styles.css%22,%22sourcesContent%22:%5B%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='url'%5D%20%7B%5Cn%20%20%20%20height:%20var(--input-height)%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='url'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20-webkit-app-region:%20no-drag;%5Cn%20%20%20%20background:%20var(--background-modifier-form-field);%5Cn%20%20%20%20border:%20var(--input-border-width)%20solid%20var(--background-modifier-border);%5Cn%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20font-family:%20inherit;%5Cn%20%20%20%20padding:%20var(--size-4-1)%20var(--size-4-2);%5Cn%20%20%20%20font-size:%20var(--font-ui-small);%5Cn%20%20%20%20border-radius:%20var(--input-radius);%5Cn%20%20%20%20outline:%20none;%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20@media%20(hover:%20hover)%20%7B%5Cn%20%20%20%20%20%20%20%20&:hover%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20border-color:%20var(--background-modifier-border-hover);%5Cn%20%20%20%20%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20border-color:%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus,%5Cn%20%20%20%20&:focus-visible%20%7B%5Cn%20%20%20%20%20%20box-shadow:%200%200%200%202px%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::placeholder%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20@at-root%20%7B%5Cn%20%20%20%20.mod-rtl,%5Cn%20%20%20%20.is-rtl,%5Cn%20%20%20%20.rtl%20%7B%5Cn%20%20%20%20%20%20&%20%7B%5Cn%20%20%20%20%20%20%20%20input%5Btype='month'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='time'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20font-variant-numeric:%20tabular-nums;%5Cn%20%20%20%20position:%20relative;%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-text%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%20%20padding-inline-end:%200;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20position:%20absolute;%5Cn%20%20%20%20%20%20left:%20var(--size-4-1);%5Cn%20%20%20%20%20%20right:%20auto;%5Cn%20%20%20%20%20%20opacity:%200.5;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-month-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-day-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-year-field%20%7B%5Cn%20%20%20%20%20%20&:active,%5Cn%20%20%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20var(--text-selection);%5Cn%20%20%20%20%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20%20%20%20%20cursor:%20text;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20.mod-rtl%20&,%5Cn%20%20%20%20%20%20.is-rtl%20&,%5Cn%20%20%20%20%20%20.rtl%20&%20%7B%5Cn%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20body:not(.is-ios):not(.is-android)%20&%20%7B%5Cn%20%20%20%20%20%20%20%20padding-inline-start:%20var(--size-4-6);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='time'%5D%20%7B%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20margin-inline-start:%200;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.modal-container%20%7B%5Cn%20%20%20%20.ok-button%20%7B%5Cn%20%20%20%20%20%20margin-right:%2010px;%5Cn%20%20%20%20%20%20margin-top:%2020px;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20.multiple-dropdown-component%20%7B%5Cn%20%20%20%20select,%5Cn%20%20%20%20select:focus,%5Cn%20%20%20%20.dropdown%20%7B%5Cn%20%20%20%20%20%20height:%20auto;%5Cn%20%20%20%20%20%20padding-top:%203px;%5Cn%5Cn%20%20%20%20%20%20option:checked%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20%231967d2;%5Cn%20%20%20%20%20%20%20%20color:%20%23fff;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.prompt-modal%20%7B%5Cn%20%20%20%20.text-box%20%7B%5Cn%20%20%20%20%20%20width:%20100%25;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cr%5Cn%20%20&.tri-state-checkbox-component%20%7B%5Cr%5Cn%20%20%20%20input%5Btype='checkbox'%5D:indeterminate%20%7B%5Cr%5Cn%20%20%20%20%20%20appearance:%20checkbox;%5Cr%5Cn%20%20%20%20%7D%5Cr%5Cn%20%20%7D%5Cr%5Cn%7D%5Cr%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20:invalid%20%7B%5Cn%20%20%20%20box-shadow:%200%200%200%202px%20var(--text-error);%5Cn%20%20%7D%5Cn%7D%5Cn%22%5D%7D */\n";
|
11
11
|
export {
|
@@ -75,6 +75,10 @@ interface TokenSubstitutions {
|
|
75
75
|
maxDepthLimitReached: string;
|
76
76
|
toJSONFailed: string;
|
77
77
|
}
|
78
|
+
/**
|
79
|
+
* A type that represents a generic object.
|
80
|
+
*/
|
81
|
+
export type GenericObject = Record<string, unknown>;
|
78
82
|
/**
|
79
83
|
* Assigns properties from one or more source objects to a target object, including non-enumerable properties.
|
80
84
|
*
|
@@ -155,7 +159,7 @@ export declare function getAllKeys<T extends object>(obj: T): StringKeys<T>[];
|
|
155
159
|
* @param path - The path to the nested property.
|
156
160
|
* @returns The value of the nested property.
|
157
161
|
*/
|
158
|
-
export declare function getNestedPropertyValue(obj:
|
162
|
+
export declare function getNestedPropertyValue(obj: GenericObject, path: string): unknown;
|
159
163
|
/**
|
160
164
|
* Gets the prototype of the specified object.
|
161
165
|
*
|
@@ -200,7 +204,7 @@ export declare function normalizeOptionalProperties<T>(obj: UndefinedOnPartialDe
|
|
200
204
|
* @param path - The path to the nested property.
|
201
205
|
* @param value - The value to set.
|
202
206
|
*/
|
203
|
-
export declare function setNestedPropertyValue(obj:
|
207
|
+
export declare function setNestedPropertyValue(obj: GenericObject, path: string, value: unknown): void;
|
204
208
|
/**
|
205
209
|
* Converts a given value to a JSON string.
|
206
210
|
*
|
package/dist/lib/esm/Object.mjs
CHANGED
@@ -316,4 +316,4 @@ export {
|
|
316
316
|
setNestedPropertyValue,
|
317
317
|
toJson
|
318
318
|
};
|
319
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Object.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for Objects.\n */\n\nimport type { UndefinedOnPartialDeep } from 'type-fest';\n\nimport type {\n  MaybeReturn,\n  StringKeys\n} from './Type.ts';\n\nimport {\n  errorToString,\n  throwExpression\n} 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\nenum TokenSubstitutionKey {\n  CircularReference = 'CircularReference',\n  Function = 'Function',\n  MaxDepthLimitReached = 'MaxDepthLimitReached',\n  MaxDepthLimitReachedArray = 'MaxDepthLimitReachedArray',\n  ToJSONFailed = 'ToJSONFailed',\n  Undefined = 'Undefined'\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 errors in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleErrors: 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   * Specifies the substitutions to use in the JSON output.\n   */\n  tokenSubstitutions: Partial<TokenSubstitutions>;\n}\n\ninterface ApplySubstitutionsOptions {\n  functionTexts: string[];\n  index: number;\n  key: TokenSubstitutionKey;\n  substitutions: TokenSubstitutions;\n}\n\ninterface JSONSerializable {\n  toJSON(...args: unknown[]): unknown;\n}\n\ninterface TokenSubstitutions {\n  circularReference: string;\n  maxDepthLimitReached: string;\n  toJSONFailed: string;\n}\n\nconst KEY_SEPARATOR = '.';\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 = getAllKeys(a);\n  const keysB = getAllKeys(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 * @typeParam T - The type of the object.\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<T extends object>(obj: T, propertyNames: (keyof T)[]): 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 * @typeParam T - The type of the object.\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<T extends object>(obj: T, propertyName: keyof T): boolean {\n  if (!Object.hasOwn(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 all entries of an object.\n *\n * @param obj - The object to get the entries of.\n * @returns An array of all entries of the object.\n */\nexport function getAllEntries<T extends object>(obj: T): [StringKeys<T>, T[StringKeys<T>]][] {\n  return getAllKeys(obj).map((key) => [key, obj[key]]);\n}\n\n/**\n * Gets all keys of an object.\n * Includes fields and properties.\n *\n * @param obj - The object to get the keys of.\n * @returns An array of all keys of the object.\n */\nexport function getAllKeys<T extends object>(obj: T): StringKeys<T>[] {\n  const keys: StringKeys<T>[] = [];\n  let current: null | object = obj;\n  while (current) {\n    const descriptors = Object.getOwnPropertyDescriptors(current) as Record<string, PropertyDescriptor>;\n    for (const [key, descriptor] of Object.entries(descriptors)) {\n      if (key === '__proto__') {\n        continue;\n      }\n\n      if (typeof descriptor.value === 'function') {\n        continue;\n      }\n\n      const hasGetter = typeof descriptor.get === 'function';\n      const hasSetter = typeof descriptor.set === 'function';\n      if (hasGetter || hasSetter) {\n        if (hasGetter && hasSetter) {\n          keys.push(key as StringKeys<T>);\n        }\n        continue;\n      }\n\n      if (descriptor.enumerable && descriptor.writable) {\n        keys.push(key as StringKeys<T>);\n      }\n    }\n\n    current = Object.getPrototypeOf(current) as null | object;\n  }\n  return keys.sort();\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(KEY_SEPARATOR);\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(KEY_SEPARATOR);\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: { tokenSubstitutions: TokenSubstitutions } & ToJsonOptions = {\n    functionHandlingMode: FunctionHandlingMode.Exclude,\n    maxDepth: -1,\n    shouldCatchToJSONErrors: false,\n    shouldHandleCircularReferences: false,\n    shouldHandleErrors: false,\n    shouldHandleUndefined: false,\n    shouldSortKeys: false,\n    // eslint-disable-next-line no-magic-numbers\n    space: 2,\n    tokenSubstitutions: {\n      circularReference: makeObjectTokenSubstitution(TokenSubstitutionKey.CircularReference),\n      maxDepthLimitReached: makeObjectTokenSubstitution(TokenSubstitutionKey.MaxDepthLimitReached),\n      toJSONFailed: makeObjectTokenSubstitution(TokenSubstitutionKey.ToJSONFailed)\n    }\n  };\n\n  const fullOptions = {\n    ...DEFAULT_OPTIONS,\n    ...options,\n    tokenSubstitutions: {\n      ...DEFAULT_OPTIONS.tokenSubstitutions,\n      ...options.tokenSubstitutions\n    }\n  };\n\n  if (fullOptions.maxDepth === -1) {\n    fullOptions.maxDepth = Infinity;\n  }\n\n  const functionTexts: string[] = [];\n  const usedObjects = new WeakSet<object>();\n\n  const plainObject = toPlainObject(value, '', 0, true, fullOptions, functionTexts, usedObjects);\n  let json = JSON.stringify(plainObject, null, fullOptions.space) ?? '';\n  json = replaceAll(json, /\"\\[\\[(?<Key>[A-Za-z]+)(?<Index>\\d*)\\]\\]\"/g, (_, key, indexStr) =>\n    applySubstitutions({\n      functionTexts,\n      index: indexStr ? parseInt(indexStr, 10) : 0,\n      key: key as TokenSubstitutionKey,\n      substitutions: fullOptions.tokenSubstitutions\n    }));\n  return json;\n}\n\nfunction _assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  for (const source of sources) {\n    const descriptors = Object.getOwnPropertyDescriptors(source);\n\n    for (const [key, descriptor] of Object.entries(descriptors)) {\n      try {\n        // Avoid redefining read-only properties (especially `prototype`)\n        if (\n          key === 'prototype'\n          || (Object.getOwnPropertyDescriptor(target, key)?.writable === false\n            && !Object.getOwnPropertyDescriptor(target, key)?.configurable)\n        ) {\n          continue;\n        }\n\n        Object.defineProperty(target, key, descriptor);\n      } catch {\n        // Silently ignore if defineProperty fails\n      }\n    }\n  }\n\n  const sourcePrototypes = sources\n    .map((source) => getPrototypeOf<object | undefined>(source))\n    .filter((proto): proto is object => !!proto);\n\n  if (sourcePrototypes.length > 0) {\n    const targetPrototype = _assignWithNonEnumerableProperties({}, getPrototypeOf(target), ...sourcePrototypes);\n\n    try {\n      Object.setPrototypeOf(target, targetPrototype);\n    } catch {\n      // Silently ignore if setPrototypeOf fails\n    }\n  }\n\n  return target;\n}\n\nfunction applySubstitutions(options: ApplySubstitutionsOptions): MaybeReturn<string> {\n  switch (options.key) {\n    case TokenSubstitutionKey.CircularReference:\n      return options.substitutions.circularReference;\n    case TokenSubstitutionKey.Function:\n      return options.functionTexts[options.index] ?? throwExpression(new Error(`Function with index ${options.index.toString()} not found`));\n    case TokenSubstitutionKey.MaxDepthLimitReached:\n      return options.substitutions.maxDepthLimitReached;\n    case TokenSubstitutionKey.MaxDepthLimitReachedArray:\n      return `Array(${options.index.toString()})`;\n    case TokenSubstitutionKey.ToJSONFailed:\n      return options.substitutions.toJSONFailed;\n    case TokenSubstitutionKey.Undefined:\n      return 'undefined';\n    default:\n      break;\n  }\n}\n\nfunction handleArray(\n  value: unknown[],\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReachedArray, value.length);\n  }\n\n  return value.map((item, index) => toPlainObject(item, index.toString(), depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects));\n}\n\nfunction handleCircularReference(value: object, key: string, fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.shouldHandleCircularReferences) {\n    return makePlaceholder(TokenSubstitutionKey.CircularReference);\n  }\n  const valueConstructorName = value.constructor.name || 'Object';\n  throw new TypeError(`Converting circular structure to JSON\n--> starting at object with constructor '${valueConstructorName}'\n--- property '${key}' closes the circle`);\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction handleFunction(value: Function, functionTexts: string[], fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.functionHandlingMode === FunctionHandlingMode.Exclude) {\n    return undefined;\n  }\n  const index = functionTexts.length;\n  const functionText = fullOptions.functionHandlingMode === FunctionHandlingMode.Full\n    ? value.toString()\n    : `function ${value.name || 'anonymous'}() { /* ... */ }`;\n  functionTexts.push(functionText);\n  return makePlaceholder(TokenSubstitutionKey.Function, index);\n}\n\nfunction handleObject(\n  value: object,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (usedObjects.has(value)) {\n    return handleCircularReference(value, key, fullOptions);\n  }\n\n  usedObjects.add(value);\n\n  if (canUseToJSON) {\n    const toJSONResult = tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObjects);\n    if (toJSONResult !== undefined) {\n      return toJSONResult;\n    }\n  }\n\n  if (Array.isArray(value)) {\n    return handleArray(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n  }\n\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReached);\n  }\n\n  if (value instanceof Error && fullOptions.shouldHandleErrors) {\n    return errorToString(value);\n  }\n\n  return handlePlainObject(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction handlePlainObject(\n  value: object,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const entries = Object.entries(value);\n  if (fullOptions.shouldSortKeys) {\n    entries.sort(([key1], [key2]) => key1.localeCompare(key2));\n  }\n\n  return Object.fromEntries(\n    entries.map(([key2, value2]) => [\n      key2,\n      toPlainObject(value2, key2, depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects)\n    ])\n  );\n}\n\nfunction makeObjectTokenSubstitution(key: TokenSubstitutionKey): string {\n  return `{ \"[[${key}]]\": null }`;\n}\n\nfunction makePlaceholder(key: TokenSubstitutionKey, index?: number): string {\n  return `[[${key}${index?.toString() ?? ''}]]`;\n}\n\nfunction toPlainObject(\n  value: unknown,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (value === undefined) {\n    return (depth === 0 || fullOptions.shouldHandleUndefined)\n      ? makePlaceholder(TokenSubstitutionKey.Undefined)\n      : undefined;\n  }\n\n  if (typeof value === 'function') {\n    return handleFunction(value, functionTexts, fullOptions);\n  }\n\n  if (typeof value !== 'object' || value === null) {\n    return value;\n  }\n\n  return handleObject(value, key, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction tryHandleToJSON(\n  value: object,\n  key: string,\n  depth: number,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const toJSON = (value as Partial<JSONSerializable>).toJSON;\n  if (typeof toJSON === 'function') {\n    try {\n      const newValue = toJSON.call(value, key);\n      return toPlainObject(newValue, key, depth, false, fullOptions, functionTexts, usedObjects);\n    } catch (e) {\n      if (fullOptions.shouldCatchToJSONErrors) {\n        return makePlaceholder(TokenSubstitutionKey.ToJSONFailed);\n      }\n      throw e;\n    }\n  }\n  return undefined;\n}\n"],
  "mappings": "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",
  "names": ["FunctionHandlingMode"]
}

|
319
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Object.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for Objects.\n */\n\nimport type { UndefinedOnPartialDeep } from 'type-fest';\n\nimport type {\n  MaybeReturn,\n  StringKeys\n} from './Type.ts';\n\nimport {\n  errorToString,\n  throwExpression\n} 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\nenum TokenSubstitutionKey {\n  CircularReference = 'CircularReference',\n  Function = 'Function',\n  MaxDepthLimitReached = 'MaxDepthLimitReached',\n  MaxDepthLimitReachedArray = 'MaxDepthLimitReachedArray',\n  ToJSONFailed = 'ToJSONFailed',\n  Undefined = 'Undefined'\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 errors in the JSON output.\n   * Defaults to `false`.\n   */\n  shouldHandleErrors: 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   * Specifies the substitutions to use in the JSON output.\n   */\n  tokenSubstitutions: Partial<TokenSubstitutions>;\n}\n\ninterface ApplySubstitutionsOptions {\n  functionTexts: string[];\n  index: number;\n  key: TokenSubstitutionKey;\n  substitutions: TokenSubstitutions;\n}\n\ninterface JSONSerializable {\n  toJSON(...args: unknown[]): unknown;\n}\n\ninterface TokenSubstitutions {\n  circularReference: string;\n  maxDepthLimitReached: string;\n  toJSONFailed: string;\n}\n\nconst KEY_SEPARATOR = '.';\n\n/**\n * A type that represents a generic object.\n */\nexport type GenericObject = Record<string, unknown>;\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 = getAllKeys(a);\n  const keysB = getAllKeys(b);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  const aRecord = a as GenericObject;\n  const bRecord = b as GenericObject;\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 * @typeParam T - The type of the object.\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<T extends object>(obj: T, propertyNames: (keyof T)[]): 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 * @typeParam T - The type of the object.\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<T extends object>(obj: T, propertyName: keyof T): boolean {\n  if (!Object.hasOwn(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 all entries of an object.\n *\n * @param obj - The object to get the entries of.\n * @returns An array of all entries of the object.\n */\nexport function getAllEntries<T extends object>(obj: T): [StringKeys<T>, T[StringKeys<T>]][] {\n  return getAllKeys(obj).map((key) => [key, obj[key]]);\n}\n\n/**\n * Gets all keys of an object.\n * Includes fields and properties.\n *\n * @param obj - The object to get the keys of.\n * @returns An array of all keys of the object.\n */\nexport function getAllKeys<T extends object>(obj: T): StringKeys<T>[] {\n  const keys: StringKeys<T>[] = [];\n  let current: null | object = obj;\n  while (current) {\n    const descriptors = Object.getOwnPropertyDescriptors(current) as Record<string, PropertyDescriptor>;\n    for (const [key, descriptor] of Object.entries(descriptors)) {\n      if (key === '__proto__') {\n        continue;\n      }\n\n      if (typeof descriptor.value === 'function') {\n        continue;\n      }\n\n      const hasGetter = typeof descriptor.get === 'function';\n      const hasSetter = typeof descriptor.set === 'function';\n      if (hasGetter || hasSetter) {\n        if (hasGetter && hasSetter) {\n          keys.push(key as StringKeys<T>);\n        }\n        continue;\n      }\n\n      if (descriptor.enumerable && descriptor.writable) {\n        keys.push(key as StringKeys<T>);\n      }\n    }\n\n    current = Object.getPrototypeOf(current) as null | object;\n  }\n  return keys.sort();\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: GenericObject, path: string): unknown {\n  let node: GenericObject | undefined = obj;\n  const keys = path.split(KEY_SEPARATOR);\n  for (const key of keys) {\n    if (node === undefined) {\n      return undefined;\n    }\n    node = node[key] as GenericObject | 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: GenericObject, path: string, value: unknown): void {\n  const error = new Error(`Property path ${path} not found`);\n  let node: GenericObject | undefined = obj;\n  const keys = path.split(KEY_SEPARATOR);\n  for (const key of keys.slice(0, -1)) {\n    if (node === undefined) {\n      throw error;\n    }\n    node = node[key] as GenericObject | 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: { tokenSubstitutions: TokenSubstitutions } & ToJsonOptions = {\n    functionHandlingMode: FunctionHandlingMode.Exclude,\n    maxDepth: -1,\n    shouldCatchToJSONErrors: false,\n    shouldHandleCircularReferences: false,\n    shouldHandleErrors: false,\n    shouldHandleUndefined: false,\n    shouldSortKeys: false,\n    // eslint-disable-next-line no-magic-numbers\n    space: 2,\n    tokenSubstitutions: {\n      circularReference: makeObjectTokenSubstitution(TokenSubstitutionKey.CircularReference),\n      maxDepthLimitReached: makeObjectTokenSubstitution(TokenSubstitutionKey.MaxDepthLimitReached),\n      toJSONFailed: makeObjectTokenSubstitution(TokenSubstitutionKey.ToJSONFailed)\n    }\n  };\n\n  const fullOptions = {\n    ...DEFAULT_OPTIONS,\n    ...options,\n    tokenSubstitutions: {\n      ...DEFAULT_OPTIONS.tokenSubstitutions,\n      ...options.tokenSubstitutions\n    }\n  };\n\n  if (fullOptions.maxDepth === -1) {\n    fullOptions.maxDepth = Infinity;\n  }\n\n  const functionTexts: string[] = [];\n  const usedObjects = new WeakSet<object>();\n\n  const plainObject = toPlainObject(value, '', 0, true, fullOptions, functionTexts, usedObjects);\n  let json = JSON.stringify(plainObject, null, fullOptions.space) ?? '';\n  json = replaceAll(json, /\"\\[\\[(?<Key>[A-Za-z]+)(?<Index>\\d*)\\]\\]\"/g, (_, key, indexStr) =>\n    applySubstitutions({\n      functionTexts,\n      index: indexStr ? parseInt(indexStr, 10) : 0,\n      key: key as TokenSubstitutionKey,\n      substitutions: fullOptions.tokenSubstitutions\n    }));\n  return json;\n}\n\nfunction _assignWithNonEnumerableProperties(target: object, ...sources: object[]): object {\n  for (const source of sources) {\n    const descriptors = Object.getOwnPropertyDescriptors(source);\n\n    for (const [key, descriptor] of Object.entries(descriptors)) {\n      try {\n        // Avoid redefining read-only properties (especially `prototype`)\n        if (\n          key === 'prototype'\n          || (Object.getOwnPropertyDescriptor(target, key)?.writable === false\n            && !Object.getOwnPropertyDescriptor(target, key)?.configurable)\n        ) {\n          continue;\n        }\n\n        Object.defineProperty(target, key, descriptor);\n      } catch {\n        // Silently ignore if defineProperty fails\n      }\n    }\n  }\n\n  const sourcePrototypes = sources\n    .map((source) => getPrototypeOf<object | undefined>(source))\n    .filter((proto): proto is object => !!proto);\n\n  if (sourcePrototypes.length > 0) {\n    const targetPrototype = _assignWithNonEnumerableProperties({}, getPrototypeOf(target), ...sourcePrototypes);\n\n    try {\n      Object.setPrototypeOf(target, targetPrototype);\n    } catch {\n      // Silently ignore if setPrototypeOf fails\n    }\n  }\n\n  return target;\n}\n\nfunction applySubstitutions(options: ApplySubstitutionsOptions): MaybeReturn<string> {\n  switch (options.key) {\n    case TokenSubstitutionKey.CircularReference:\n      return options.substitutions.circularReference;\n    case TokenSubstitutionKey.Function:\n      return options.functionTexts[options.index] ?? throwExpression(new Error(`Function with index ${options.index.toString()} not found`));\n    case TokenSubstitutionKey.MaxDepthLimitReached:\n      return options.substitutions.maxDepthLimitReached;\n    case TokenSubstitutionKey.MaxDepthLimitReachedArray:\n      return `Array(${options.index.toString()})`;\n    case TokenSubstitutionKey.ToJSONFailed:\n      return options.substitutions.toJSONFailed;\n    case TokenSubstitutionKey.Undefined:\n      return 'undefined';\n    default:\n      break;\n  }\n}\n\nfunction handleArray(\n  value: unknown[],\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReachedArray, value.length);\n  }\n\n  return value.map((item, index) => toPlainObject(item, index.toString(), depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects));\n}\n\nfunction handleCircularReference(value: object, key: string, fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.shouldHandleCircularReferences) {\n    return makePlaceholder(TokenSubstitutionKey.CircularReference);\n  }\n  const valueConstructorName = value.constructor.name || 'Object';\n  throw new TypeError(`Converting circular structure to JSON\n--> starting at object with constructor '${valueConstructorName}'\n--- property '${key}' closes the circle`);\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction handleFunction(value: Function, functionTexts: string[], fullOptions: ToJsonOptions): unknown {\n  if (fullOptions.functionHandlingMode === FunctionHandlingMode.Exclude) {\n    return undefined;\n  }\n  const index = functionTexts.length;\n  const functionText = fullOptions.functionHandlingMode === FunctionHandlingMode.Full\n    ? value.toString()\n    : `function ${value.name || 'anonymous'}() { /* ... */ }`;\n  functionTexts.push(functionText);\n  return makePlaceholder(TokenSubstitutionKey.Function, index);\n}\n\nfunction handleObject(\n  value: object,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (usedObjects.has(value)) {\n    return handleCircularReference(value, key, fullOptions);\n  }\n\n  usedObjects.add(value);\n\n  if (canUseToJSON) {\n    const toJSONResult = tryHandleToJSON(value, key, depth, fullOptions, functionTexts, usedObjects);\n    if (toJSONResult !== undefined) {\n      return toJSONResult;\n    }\n  }\n\n  if (Array.isArray(value)) {\n    return handleArray(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n  }\n\n  if (depth > fullOptions.maxDepth) {\n    return makePlaceholder(TokenSubstitutionKey.MaxDepthLimitReached);\n  }\n\n  if (value instanceof Error && fullOptions.shouldHandleErrors) {\n    return errorToString(value);\n  }\n\n  return handlePlainObject(value, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction handlePlainObject(\n  value: object,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const entries = Object.entries(value);\n  if (fullOptions.shouldSortKeys) {\n    entries.sort(([key1], [key2]) => key1.localeCompare(key2));\n  }\n\n  return Object.fromEntries(\n    entries.map(([key2, value2]) => [\n      key2,\n      toPlainObject(value2, key2, depth + 1, canUseToJSON, fullOptions, functionTexts, usedObjects)\n    ])\n  );\n}\n\nfunction makeObjectTokenSubstitution(key: TokenSubstitutionKey): string {\n  return `{ \"[[${key}]]\": null }`;\n}\n\nfunction makePlaceholder(key: TokenSubstitutionKey, index?: number): string {\n  return `[[${key}${index?.toString() ?? ''}]]`;\n}\n\nfunction toPlainObject(\n  value: unknown,\n  key: string,\n  depth: number,\n  canUseToJSON: boolean,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  if (value === undefined) {\n    return (depth === 0 || fullOptions.shouldHandleUndefined)\n      ? makePlaceholder(TokenSubstitutionKey.Undefined)\n      : undefined;\n  }\n\n  if (typeof value === 'function') {\n    return handleFunction(value, functionTexts, fullOptions);\n  }\n\n  if (typeof value !== 'object' || value === null) {\n    return value;\n  }\n\n  return handleObject(value, key, depth, canUseToJSON, fullOptions, functionTexts, usedObjects);\n}\n\nfunction tryHandleToJSON(\n  value: object,\n  key: string,\n  depth: number,\n  fullOptions: ToJsonOptions,\n  functionTexts: string[],\n  usedObjects: WeakSet<object>\n): unknown {\n  const toJSON = (value as Partial<JSONSerializable>).toJSON;\n  if (typeof toJSON === 'function') {\n    try {\n      const newValue = toJSON.call(value, key);\n      return toPlainObject(newValue, key, depth, false, fullOptions, functionTexts, usedObjects);\n    } catch (e) {\n      if (fullOptions.shouldCatchToJSONErrors) {\n        return makePlaceholder(TokenSubstitutionKey.ToJSONFailed);\n      }\n      throw e;\n    }\n  }\n  return undefined;\n}\n"],
  "mappings": "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",
  "names": ["FunctionHandlingMode"]
}

|
@@ -125,4 +125,4 @@ function initEsm() {
|
|
125
125
|
export {
|
126
126
|
preprocessPlugin
|
127
127
|
};
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/ScriptUtils/esbuild/preprocessPlugin.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a custom esbuild plugin that preprocesses JavaScript and TypeScript files.\n * The preprocessing includes replacing `import(dot)meta(dot)url` with a Node.js-compatible alternative,\n * ensuring compatibility with Obsidian's plugin system, and adding a basic `process` object for environments\n * where `process` is not available (like mobile or web environments).\n *\n * @remarks\n * We cannot use `.` instead of `(dot)` in the above description because the file itself is preprocessed with the same rule.\n */\n\nimport type { Plugin } from 'esbuild';\n\nimport {\n  FunctionHandlingMode,\n  toJson\n} from '../../Object.ts';\nimport {\n  makeValidVariableName,\n  replaceAll\n} from '../../String.ts';\nimport { readFile } from '../NodeModules.ts';\n\ninterface BrowserProcess extends Partial<NodeJS.Process> {\n  browser: boolean;\n}\n\ninterface EsmModule {\n  __esModule: boolean;\n  default: unknown;\n}\n\ninterface RequirePatched extends NodeJS.Require {\n  __isPatched: boolean;\n}\n\n/**\n * Creates an esbuild plugin that preprocesses JavaScript and TypeScript files.\n *\n * This plugin performs the following tasks:\n * - Replaces instances of `import(dot)meta(dot)url` with a Node.js-compatible `__filename` alternative.\n * - Modifies the `sourceMappingURL` comment to ensure compatibility with Obsidian's plugin system.\n * - Adds a basic `process` object to the global scope if `process` is referenced but not defined.\n *\n * @param isEsm - Whether the build is for an ESM format.\n * @returns An esbuild `Plugin` object that handles the preprocessing.\n */\nexport function preprocessPlugin(isEsm?: boolean): Plugin {\n  const replacements = isEsm\n    ? {}\n    : {\n      [replaceAll('import(dot)meta(dot)url', '(dot)', '.')]: (): string => {\n        if (typeof __filename === 'string') {\n          const localRequire = require;\n          const url = localRequire('node:url') as typeof import('node:url');\n          return url.pathToFileURL(__filename).href;\n        }\n\n        if (typeof window !== 'undefined') {\n          return window.location.href;\n        }\n\n        // Fallback to an empty string if the environment is unknown\n        return '';\n      }\n    };\n\n  return {\n    name: 'preprocess',\n    setup(build): void {\n      build.initialOptions.define ??= {};\n\n      for (const key of Object.keys(replacements)) {\n        build.initialOptions.define[key] = `__${makeValidVariableName(key)}`;\n      }\n\n      build.initialOptions.banner ??= {};\n      build.initialOptions.banner['js'] ??= '';\n      build.initialOptions.banner['js'] += `\\n(${(isEsm ? initEsm : initCjs).toString()})();\\n`;\n\n      build.onLoad({ filter: /\\.(?:js|ts|cjs|mjs|cts|mts)$/ }, async (args) => {\n        let contents = await readFile(args.path, 'utf-8');\n\n        for (const [key, value] of Object.entries(replacements)) {\n          const variable = `__${makeValidVariableName(key)}`;\n          if (!contents.includes(key)) {\n            continue;\n          }\n          const valueStr = typeof value === 'function' ? `(${value.toString()})()` : toJson(value, { functionHandlingMode: FunctionHandlingMode.Full });\n          if (contents.includes(`var ${variable}`)) {\n            continue;\n          }\n          contents = `var ${variable} = globalThis['${key}'] ?? ${valueStr};\\n${contents}`;\n        }\n\n        // HACK: The ${''} part is used to ensure Obsidian loads the plugin properly,\n        // Otherwise, it stops loading after the first line of the sourceMappingURL comment.\n        // eslint-disable-next-line no-template-curly-in-string\n        contents = replaceAll(contents, /`\\r?\\n\\/\\/# sourceMappingURL/g, '`\\n//#${\\'\\'} sourceMappingURL');\n\n        return {\n          contents,\n          loader: 'ts'\n        };\n      });\n    }\n  };\n}\n\nfunction initCjs(): void {\n  const globalThisRecord = globalThis as unknown as Record<string, unknown>;\n  globalThisRecord['__name'] ??= name;\n  const originalRequire = require as (NodeJS.Require & Partial<RequirePatched> | undefined);\n  if (originalRequire && !originalRequire.__isPatched) {\n    require = Object.assign(\n      (id: string) => requirePatched(id),\n      originalRequire,\n      {\n        __isPatched: true\n      }\n    ) as RequirePatched;\n  }\n\n  const newFuncs: Record<string, () => unknown> = {\n    __extractDefault: () => extractDefault,\n    process: () => {\n      const browserProcess: BrowserProcess = {\n        browser: true,\n        cwd: () => '/',\n        env: {},\n        platform: 'android'\n      };\n      return browserProcess;\n    }\n  };\n\n  for (const key of Object.keys(newFuncs)) {\n    globalThisRecord[key] ??= newFuncs[key]?.();\n  }\n\n  function name(obj: unknown): unknown {\n    return obj;\n  }\n\n  function extractDefault(module: Partial<EsmModule> | undefined): unknown {\n    return module && module.__esModule && module.default ? module.default : module;\n  }\n\n  function requirePatched(id: string): unknown {\n    const module = originalRequire?.(id) as (Partial<EsmModule> | undefined);\n    if (module) {\n      return extractDefault(module);\n    }\n\n    if (id === 'process' || id === 'node:process') {\n      console.error(`Module not found: ${id}. Fake process object is returned instead.`);\n      return globalThis.process;\n    }\n\n    console.error(`Module not found: ${id}. Empty object is returned instead.`);\n    return {};\n  }\n}\n\nfunction initEsm(): void {\n  if ((globalThis.process as NodeJS.Process | undefined)) {\n    return;\n  }\n\n  const browserProcess: BrowserProcess = {\n    browser: true,\n    cwd: () => '/',\n    env: {},\n    platform: 'android'\n  };\n  globalThis.process = browserProcess as NodeJS.Process;\n}\n"],
  "mappings": "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",
  "names": []
}

|
128
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/ScriptUtils/esbuild/preprocessPlugin.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a custom esbuild plugin that preprocesses JavaScript and TypeScript files.\n * The preprocessing includes replacing `import(dot)meta(dot)url` with a Node.js-compatible alternative,\n * ensuring compatibility with Obsidian's plugin system, and adding a basic `process` object for environments\n * where `process` is not available (like mobile or web environments).\n *\n * @remarks\n * We cannot use `.` instead of `(dot)` in the above description because the file itself is preprocessed with the same rule.\n */\n\nimport type { Plugin } from 'esbuild';\n\nimport type { GenericObject } from '../../Object.ts';\n\nimport {\n  FunctionHandlingMode,\n  toJson\n} from '../../Object.ts';\nimport {\n  makeValidVariableName,\n  replaceAll\n} from '../../String.ts';\nimport { readFile } from '../NodeModules.ts';\n\ninterface BrowserProcess extends Partial<NodeJS.Process> {\n  browser: boolean;\n}\n\ninterface EsmModule {\n  __esModule: boolean;\n  default: unknown;\n}\n\ninterface RequirePatched extends NodeJS.Require {\n  __isPatched: boolean;\n}\n\n/**\n * Creates an esbuild plugin that preprocesses JavaScript and TypeScript files.\n *\n * This plugin performs the following tasks:\n * - Replaces instances of `import(dot)meta(dot)url` with a Node.js-compatible `__filename` alternative.\n * - Modifies the `sourceMappingURL` comment to ensure compatibility with Obsidian's plugin system.\n * - Adds a basic `process` object to the global scope if `process` is referenced but not defined.\n *\n * @param isEsm - Whether the build is for an ESM format.\n * @returns An esbuild `Plugin` object that handles the preprocessing.\n */\nexport function preprocessPlugin(isEsm?: boolean): Plugin {\n  const replacements = isEsm\n    ? {}\n    : {\n      [replaceAll('import(dot)meta(dot)url', '(dot)', '.')]: (): string => {\n        if (typeof __filename === 'string') {\n          const localRequire = require;\n          const url = localRequire('node:url') as typeof import('node:url');\n          return url.pathToFileURL(__filename).href;\n        }\n\n        if (typeof window !== 'undefined') {\n          return window.location.href;\n        }\n\n        // Fallback to an empty string if the environment is unknown\n        return '';\n      }\n    };\n\n  return {\n    name: 'preprocess',\n    setup(build): void {\n      build.initialOptions.define ??= {};\n\n      for (const key of Object.keys(replacements)) {\n        build.initialOptions.define[key] = `__${makeValidVariableName(key)}`;\n      }\n\n      build.initialOptions.banner ??= {};\n      build.initialOptions.banner['js'] ??= '';\n      build.initialOptions.banner['js'] += `\\n(${(isEsm ? initEsm : initCjs).toString()})();\\n`;\n\n      build.onLoad({ filter: /\\.(?:js|ts|cjs|mjs|cts|mts)$/ }, async (args) => {\n        let contents = await readFile(args.path, 'utf-8');\n\n        for (const [key, value] of Object.entries(replacements)) {\n          const variable = `__${makeValidVariableName(key)}`;\n          if (!contents.includes(key)) {\n            continue;\n          }\n          const valueStr = typeof value === 'function' ? `(${value.toString()})()` : toJson(value, { functionHandlingMode: FunctionHandlingMode.Full });\n          if (contents.includes(`var ${variable}`)) {\n            continue;\n          }\n          contents = `var ${variable} = globalThis['${key}'] ?? ${valueStr};\\n${contents}`;\n        }\n\n        // HACK: The ${''} part is used to ensure Obsidian loads the plugin properly,\n        // Otherwise, it stops loading after the first line of the sourceMappingURL comment.\n        // eslint-disable-next-line no-template-curly-in-string\n        contents = replaceAll(contents, /`\\r?\\n\\/\\/# sourceMappingURL/g, '`\\n//#${\\'\\'} sourceMappingURL');\n\n        return {\n          contents,\n          loader: 'ts'\n        };\n      });\n    }\n  };\n}\n\nfunction initCjs(): void {\n  const globalThisRecord = globalThis as unknown as GenericObject;\n  globalThisRecord['__name'] ??= name;\n  const originalRequire = require as (NodeJS.Require & Partial<RequirePatched> | undefined);\n  if (originalRequire && !originalRequire.__isPatched) {\n    require = Object.assign(\n      (id: string) => requirePatched(id),\n      originalRequire,\n      {\n        __isPatched: true\n      }\n    ) as RequirePatched;\n  }\n\n  const newFuncs: Record<string, () => unknown> = {\n    __extractDefault: () => extractDefault,\n    process: () => {\n      const browserProcess: BrowserProcess = {\n        browser: true,\n        cwd: () => '/',\n        env: {},\n        platform: 'android'\n      };\n      return browserProcess;\n    }\n  };\n\n  for (const key of Object.keys(newFuncs)) {\n    globalThisRecord[key] ??= newFuncs[key]?.();\n  }\n\n  function name(obj: unknown): unknown {\n    return obj;\n  }\n\n  function extractDefault(module: Partial<EsmModule> | undefined): unknown {\n    return module && module.__esModule && module.default ? module.default : module;\n  }\n\n  function requirePatched(id: string): unknown {\n    const module = originalRequire?.(id) as (Partial<EsmModule> | undefined);\n    if (module) {\n      return extractDefault(module);\n    }\n\n    if (id === 'process' || id === 'node:process') {\n      console.error(`Module not found: ${id}. Fake process object is returned instead.`);\n      return globalThis.process;\n    }\n\n    console.error(`Module not found: ${id}. Empty object is returned instead.`);\n    return {};\n  }\n}\n\nfunction initEsm(): void {\n  if ((globalThis.process as NodeJS.Process | undefined)) {\n    return;\n  }\n\n  const browserProcess: BrowserProcess = {\n    browser: true,\n    cwd: () => '/',\n    env: {},\n    platform: 'android'\n  };\n  globalThis.process = browserProcess as NodeJS.Process;\n}\n"],
  "mappings": "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",
  "names": []
}

|
@@ -3,6 +3,7 @@
|
|
3
3
|
*
|
4
4
|
* A base class for transformers.
|
5
5
|
*/
|
6
|
+
import type { GenericObject } from '../Object.mjs';
|
6
7
|
/**
|
7
8
|
* A base class for transformers.
|
8
9
|
*/
|
@@ -32,7 +33,7 @@ export declare abstract class Transformer {
|
|
32
33
|
* @param value - The value to transform.
|
33
34
|
* @returns The transformed value.
|
34
35
|
*/
|
35
|
-
transformObjectRecursively(value: object):
|
36
|
+
transformObjectRecursively(value: object): GenericObject;
|
36
37
|
/**
|
37
38
|
* Transforms the given value.
|
38
39
|
*
|