obsidian-dev-utils 24.0.2-beta.1 → 24.0.2-beta.2
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 +11 -0
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/obsidian/App.cjs +6 -1
- package/dist/lib/cjs/obsidian/App.d.cts +5 -0
- package/dist/lib/cjs/obsidian/Components/CheckboxComponent.cjs +11 -1
- package/dist/lib/cjs/obsidian/Components/CheckboxComponent.d.cts +10 -0
- package/dist/lib/cjs/obsidian/Components/TriStateCheckboxComponent.cjs +11 -1
- package/dist/lib/cjs/obsidian/Components/TriStateCheckboxComponent.d.cts +10 -0
- package/dist/lib/cjs/obsidian/Modals/ModalBase.cjs +8 -1
- package/dist/lib/cjs/obsidian/Modals/ModalBase.d.cts +7 -0
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +23 -5
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +20 -2
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +113 -15
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +102 -8
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +39 -2
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.d.cts +23 -0
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/obsidian/App.d.mts +5 -0
- package/dist/lib/esm/obsidian/App.mjs +6 -1
- package/dist/lib/esm/obsidian/Components/CheckboxComponent.d.mts +10 -0
- package/dist/lib/esm/obsidian/Components/CheckboxComponent.mjs +11 -1
- package/dist/lib/esm/obsidian/Components/TriStateCheckboxComponent.d.mts +10 -0
- package/dist/lib/esm/obsidian/Components/TriStateCheckboxComponent.mjs +11 -1
- package/dist/lib/esm/obsidian/Modals/ModalBase.d.mts +7 -0
- package/dist/lib/esm/obsidian/Modals/ModalBase.mjs +8 -1
- package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +20 -2
- package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +23 -5
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +102 -8
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +113 -15
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.d.mts +23 -0
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +39 -2
- package/package.json +1 -1
@@ -37,12 +37,22 @@ class PluginBase extends ObsidianPlugin {
|
|
37
37
|
get settings() {
|
38
38
|
return this.settingsManager.safeSettings;
|
39
39
|
}
|
40
|
+
/**
|
41
|
+
* Gets the plugin settings manager.
|
42
|
+
*
|
43
|
+
* @returns The plugin settings manager.
|
44
|
+
*/
|
40
45
|
get settingsManager() {
|
41
46
|
if (!this._settingsManager) {
|
42
47
|
throw new Error("Settings manager not defined");
|
43
48
|
}
|
44
49
|
return this._settingsManager;
|
45
50
|
}
|
51
|
+
/**
|
52
|
+
* Gets the plugin settings tab.
|
53
|
+
*
|
54
|
+
* @returns The plugin settings tab.
|
55
|
+
*/
|
46
56
|
get settingsTab() {
|
47
57
|
if (!this._settingsTab) {
|
48
58
|
throw new Error("Settings tab not defined");
|
@@ -76,7 +86,7 @@ class PluginBase extends ObsidianPlugin {
|
|
76
86
|
*/
|
77
87
|
async onExternalSettingsChange() {
|
78
88
|
await super.onExternalSettingsChange?.();
|
79
|
-
await this._settingsManager?.loadFromFile();
|
89
|
+
await this._settingsManager?.loadFromFile(false);
|
80
90
|
}
|
81
91
|
/**
|
82
92
|
* Called when the plugin is loaded
|
@@ -90,8 +100,9 @@ class PluginBase extends ObsidianPlugin {
|
|
90
100
|
* Called when the plugin settings are loaded or reloaded.
|
91
101
|
*
|
92
102
|
* @param _settings - The settings.
|
103
|
+
* @param _isInitialLoad - Whether the settings are being loaded for the first time.
|
93
104
|
*/
|
94
|
-
async onLoadSettings(_settings) {
|
105
|
+
async onLoadSettings(_settings, _isInitialLoad) {
|
95
106
|
await noopAsync();
|
96
107
|
}
|
97
108
|
/**
|
@@ -99,10 +110,12 @@ class PluginBase extends ObsidianPlugin {
|
|
99
110
|
*
|
100
111
|
* @param _newSettings - The new settings.
|
101
112
|
* @param _oldSettings - The old settings.
|
113
|
+
* @param _context - The context.
|
102
114
|
*/
|
103
|
-
async onSaveSettings(_newSettings, _oldSettings) {
|
115
|
+
async onSaveSettings(_newSettings, _oldSettings, _context) {
|
104
116
|
await noopAsync();
|
105
117
|
}
|
118
|
+
/** */
|
106
119
|
onunload() {
|
107
120
|
super.onunload();
|
108
121
|
invokeAsyncSafely(async () => {
|
@@ -167,13 +180,18 @@ class PluginBase extends ObsidianPlugin {
|
|
167
180
|
async onLayoutReady() {
|
168
181
|
await noopAsync();
|
169
182
|
}
|
183
|
+
/**
|
184
|
+
* Executed when the plugin is loaded.
|
185
|
+
*
|
186
|
+
* This method can be overridden by subclasses to perform actions once the plugin is loaded.
|
187
|
+
*/
|
170
188
|
async onloadImpl() {
|
171
189
|
initPluginContext(this.app, this.manifest.id);
|
172
190
|
this.register(registerAsyncErrorEventHandler(() => {
|
173
191
|
this.showNotice("An unhandled error occurred. Please check the console for more information.");
|
174
192
|
}));
|
175
193
|
this._settingsManager = this.createSettingsManager();
|
176
|
-
await this.
|
194
|
+
await this._settingsManager?.loadFromFile(true);
|
177
195
|
this._settingsTab = this.createPluginSettingsTab();
|
178
196
|
if (this._settingsTab) {
|
179
197
|
this.addSettingTab(this._settingsTab);
|
@@ -221,4 +239,4 @@ ${message}`);
|
|
221
239
|
export {
|
222
240
|
PluginBase
|
223
241
|
};
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base class for Obsidian plugins providing utility methods for settings management, error handling, and notifications.\n *\n * This class simplifies the process of managing plugin settings, displaying notifications, and handling errors.\n * Subclasses should implement methods to create default settings and settings tabs, and complete plugin-specific\n * loading tasks.\n */\n\nimport type { ReadonlyDeep } from 'type-fest';\n\nimport {\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type { AsyncEventRef } from '../../AsyncEvents.ts';\nimport type {\n  ExtractPluginSettings,\n  ExtractPluginSettingsManager,\n  ExtractPluginSettingsTab,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely,\n  invokeAsyncSafelyAfterDelay\n} from '../../Async.ts';\nimport { AsyncEvents } from '../../AsyncEvents.ts';\nimport { getDebugger } from '../../Debug.ts';\nimport { registerAsyncErrorEventHandler } from '../../Error.ts';\nimport { noopAsync } from '../../Function.ts';\nimport { initPluginContext } from './PluginContext.ts';\n\ntype LifecycleEventName = 'layoutReady' | 'load' | 'unload';\n\n/**\n * Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginBase<PluginTypes extends PluginTypesBase> extends ObsidianPlugin {\n  public readonly events = new AsyncEvents();\n\n  /**\n   * Gets the AbortSignal used for aborting long-running operations.\n   *\n   * @returns The abort signal.\n   */\n  public get abortSignal(): AbortSignal {\n    return this._abortSignal;\n  }\n\n  /**\n   * Gets the readonly plugin settings.\n   *\n   * @returns The readonly plugin settings.\n   */\n  public get settings(): ReadonlyDeep<ExtractPluginSettings<PluginTypes>> {\n    return this.settingsManager.safeSettings as ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n  }\n\n  public get settingsManager(): ExtractPluginSettingsManager<PluginTypes> {\n    if (!this._settingsManager) {\n      throw new Error('Settings manager not defined');\n    }\n\n    return this._settingsManager;\n  }\n\n  public get settingsTab(): ExtractPluginSettingsTab<PluginTypes> {\n    if (!this._settingsTab) {\n      throw new Error('Settings tab not defined');\n    }\n\n    return this._settingsTab;\n  }\n\n  private _abortSignal!: AbortSignal;\n  private _settingsManager: ExtractPluginSettingsManager<PluginTypes> | null = null;\n  private _settingsTab: ExtractPluginSettingsTab<PluginTypes> | null = null;\n  private lifecycleEventNames = new Set<LifecycleEventName>();\n  private notice?: Notice;\n\n  /**\n   * Logs a message to the console.\n   *\n   * Use instead of `console.debug()`.\n   *\n   * Those messages are not shown by default, but they can be shown by enabling `your-plugin-id` debugger namespace.\n   *\n   * @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging} for more information.\n   *\n   * @param message - The message to log.\n   * @param args - The arguments to log.\n   */\n  public consoleDebug(message: string, ...args: unknown[]): void {\n    // Skip the `consoleDebug()` call itself\n    const FRAMES_TO_SKIP = 1;\n    const _debugger = getDebugger(this.manifest.id, FRAMES_TO_SKIP);\n    _debugger(message, ...args);\n  }\n\n  /**\n   * Called when the external settings change.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this._settingsManager?.loadFromFile();\n  }\n\n  /**\n   * Called when the plugin is loaded\n   */\n  public override async onload(): Promise<void> {\n    await super.onload();\n    await this.onloadImpl();\n    invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));\n  }\n\n  /**\n   * Called when the plugin settings are loaded or reloaded.\n   *\n   * @param _settings - The settings.\n   */\n  public async onLoadSettings(_settings: ExtractPluginSettings<PluginTypes>): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings are saved.\n   *\n   * @param _newSettings - The new settings.\n   * @param _oldSettings - The old settings.\n   */\n  public async onSaveSettings(_newSettings: ExtractPluginSettings<PluginTypes>, _oldSettings: ExtractPluginSettings<PluginTypes>): Promise<void> {\n    await noopAsync();\n  }\n\n  public override onunload(): void {\n    super.onunload();\n    invokeAsyncSafely(async () => {\n      try {\n        await this.onunloadImpl();\n      } finally {\n        await this.triggerLifecycleEvent('unload');\n      }\n    });\n  }\n\n  /**\n   * Registers an async event.\n   * Unregisters the event when the plugin is unloaded.\n   *\n   * @param eventRef - The event reference.\n   */\n  public registerAsyncEvent(eventRef: AsyncEventRef): void {\n    this.register(() => {\n      eventRef.asyncEvents.offref(eventRef);\n    });\n  }\n\n  /**\n   * Waits for a lifecycle event to be triggered.\n   *\n   * If you `await` this method during lifecycle event, it might cause a deadlock.\n   *\n   * Consider wrapping this call with {@link invokeAsyncSafely}.\n   *\n   * @param name - The name of the event.\n   * @returns A {@link Promise} that resolves when the event is triggered.\n   */\n  public async waitForLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    if (this.lifecycleEventNames.has(name)) {\n      return;\n    }\n\n    await new Promise<void>((resolve) => {\n      this.events.once(name, () => {\n        resolve();\n      });\n    });\n  }\n\n  /**\n   * Creates a plugin settings tab.\n   *\n   * @returns The settings tab or null if not applicable.\n   */\n  protected createPluginSettingsTab(): ExtractPluginSettingsTab<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Creates the plugin settings manager. This method must be implemented by subclasses.\n   *\n   * @returns The plugin settings manager.\n   */\n  protected createSettingsManager(): ExtractPluginSettingsManager<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Called when the layout is ready. This method can be overridden by subclasses to perform actions once\n   * the layout is ready.\n   */\n  protected async onLayoutReady(): Promise<void> {\n    await noopAsync();\n  }\n\n  protected async onloadImpl(): Promise<void> {\n    initPluginContext(this.app, this.manifest.id);\n\n    this.register(registerAsyncErrorEventHandler(() => {\n      this.showNotice('An unhandled error occurred. Please check the console for more information.');\n    }));\n\n    this._settingsManager = this.createSettingsManager();\n\n    await this.onExternalSettingsChange();\n    this._settingsTab = this.createPluginSettingsTab();\n    if (this._settingsTab) {\n      this.addSettingTab(this._settingsTab);\n    }\n\n    const abortController = new AbortController();\n    this._abortSignal = abortController.signal;\n    this.register(() => {\n      abortController.abort();\n    });\n  }\n\n  /**\n   * Called when the plugin is unloaded.\n   */\n  protected async onunloadImpl(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Displays a notice message to the user.\n   *\n   * @param message - The message to display.\n   */\n  protected showNotice(message: string): void {\n    if (this.notice) {\n      this.notice.hide();\n    }\n\n    this.notice = new Notice(`${this.manifest.name}\\n${message}`);\n  }\n\n  private async afterLoad(): Promise<void> {\n    await this.triggerLifecycleEvent('load');\n    this.app.workspace.onLayoutReady(convertAsyncToSync(this.onLayoutReadyBase.bind(this)));\n  }\n\n  private async onLayoutReadyBase(): Promise<void> {\n    try {\n      await this.onLayoutReady();\n    } finally {\n      await this.triggerLifecycleEvent('layoutReady');\n    }\n  }\n\n  private async triggerLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    this.lifecycleEventNames.add(name);\n    await this.events.triggerAsync(name);\n  }\n}\n"],
  "mappings": ";;;;;;;AAYA;AAAA,EACE;AAAA,EACA,UAAU;AAAA,OACL;AAUP;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,mBAAmB;AAC5B,SAAS,mBAAmB;AAC5B,SAAS,sCAAsC;AAC/C,SAAS,iBAAiB;AAC1B,SAAS,yBAAyB;AAS3B,MAAe,mBAAwD,eAAe;AAAA,EAC3E,SAAS,IAAI,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOzC,IAAW,cAA2B;AACpC,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,WAA6D;AACtE,WAAO,KAAK,gBAAgB;AAAA,EAC9B;AAAA,EAEA,IAAW,kBAA6D;AACtE,QAAI,CAAC,KAAK,kBAAkB;AAC1B,YAAM,IAAI,MAAM,8BAA8B;AAAA,IAChD;AAEA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAW,cAAqD;AAC9D,QAAI,CAAC,KAAK,cAAc;AACtB,YAAM,IAAI,MAAM,0BAA0B;AAAA,IAC5C;AAEA,WAAO,KAAK;AAAA,EACd;AAAA,EAEQ;AAAA,EACA,mBAAqE;AAAA,EACrE,eAA6D;AAAA,EAC7D,sBAAsB,oBAAI,IAAwB;AAAA,EAClD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcD,aAAa,YAAoB,MAAuB;AAE7D,UAAM,iBAAiB;AACvB,UAAM,YAAY,YAAY,KAAK,SAAS,IAAI,cAAc;AAC9D,cAAU,SAAS,GAAG,IAAI;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,2BAA0C;AAC9D,UAAM,MAAM,2BAA2B;AACvC,UAAM,KAAK,kBAAkB,aAAa;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,SAAwB;AAC5C,UAAM,MAAM,OAAO;AACnB,UAAM,KAAK,WAAW;AACtB,gCAA4B,KAAK,UAAU,KAAK,IAAI,CAAC;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAa,eAAe,WAA8D;AACxF,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAa,eAAe,cAAkD,cAAiE;AAC7I,UAAM,UAAU;AAAA,EAClB;AAAA,EAEgB,WAAiB;AAC/B,UAAM,SAAS;AACf,sBAAkB,YAAY;AAC5B,UAAI;AACF,cAAM,KAAK,aAAa;AAAA,MAC1B,UAAE;AACA,cAAM,KAAK,sBAAsB,QAAQ;AAAA,MAC3C;AAAA,IACF,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,mBAAmB,UAA+B;AACvD,SAAK,SAAS,MAAM;AAClB,eAAS,YAAY,OAAO,QAAQ;AAAA,IACtC,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,MAAa,sBAAsB,MAAyC;AAC1E,QAAI,KAAK,oBAAoB,IAAI,IAAI,GAAG;AACtC;AAAA,IACF;AAEA,UAAM,IAAI,QAAc,CAAC,YAAY;AACnC,WAAK,OAAO,KAAK,MAAM,MAAM;AAC3B,gBAAQ;AAAA,MACV,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,0BAAwE;AAChF,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,wBAA0E;AAClF,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAgB,gBAA+B;AAC7C,UAAM,UAAU;AAAA,EAClB;AAAA,EAEA,MAAgB,aAA4B;AAC1C,sBAAkB,KAAK,KAAK,KAAK,SAAS,EAAE;AAE5C,SAAK,SAAS,+BAA+B,MAAM;AACjD,WAAK,WAAW,6EAA6E;AAAA,IAC/F,CAAC,CAAC;AAEF,SAAK,mBAAmB,KAAK,sBAAsB;AAEnD,UAAM,KAAK,yBAAyB;AACpC,SAAK,eAAe,KAAK,wBAAwB;AACjD,QAAI,KAAK,cAAc;AACrB,WAAK,cAAc,KAAK,YAAY;AAAA,IACtC;AAEA,UAAM,kBAAkB,IAAI,gBAAgB;AAC5C,SAAK,eAAe,gBAAgB;AACpC,SAAK,SAAS,MAAM;AAClB,sBAAgB,MAAM;AAAA,IACxB,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA,EAKA,MAAgB,eAA8B;AAC5C,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,WAAW,SAAuB;AAC1C,QAAI,KAAK,QAAQ;AACf,WAAK,OAAO,KAAK;AAAA,IACnB;AAEA,SAAK,SAAS,IAAI,OAAO,GAAG,KAAK,SAAS,IAAI;AAAA,EAAK,OAAO,EAAE;AAAA,EAC9D;AAAA,EAEA,MAAc,YAA2B;AACvC,UAAM,KAAK,sBAAsB,MAAM;AACvC,SAAK,IAAI,UAAU,cAAc,mBAAmB,KAAK,kBAAkB,KAAK,IAAI,CAAC,CAAC;AAAA,EACxF;AAAA,EAEA,MAAc,oBAAmC;AAC/C,QAAI;AACF,YAAM,KAAK,cAAc;AAAA,IAC3B,UAAE;AACA,YAAM,KAAK,sBAAsB,aAAa;AAAA,IAChD;AAAA,EACF;AAAA,EAEA,MAAc,sBAAsB,MAAyC;AAC3E,SAAK,oBAAoB,IAAI,IAAI;AACjC,UAAM,KAAK,OAAO,aAAa,IAAI;AAAA,EACrC;AACF;",
  "names": []
}

|
242
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base class for Obsidian plugins providing utility methods for settings management, error handling, and notifications.\n *\n * This class simplifies the process of managing plugin settings, displaying notifications, and handling errors.\n * Subclasses should implement methods to create default settings and settings tabs, and complete plugin-specific\n * loading tasks.\n */\n\nimport type { ReadonlyDeep } from 'type-fest';\n\nimport {\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type { AsyncEventRef } from '../../AsyncEvents.ts';\nimport type {\n  ExtractPluginSettings,\n  ExtractPluginSettingsManager,\n  ExtractPluginSettingsTab,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely,\n  invokeAsyncSafelyAfterDelay\n} from '../../Async.ts';\nimport { AsyncEvents } from '../../AsyncEvents.ts';\nimport { getDebugger } from '../../Debug.ts';\nimport { registerAsyncErrorEventHandler } from '../../Error.ts';\nimport { noopAsync } from '../../Function.ts';\nimport { initPluginContext } from './PluginContext.ts';\n\ntype LifecycleEventName = 'layoutReady' | 'load' | 'unload';\n\n/**\n * Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginBase<PluginTypes extends PluginTypesBase> extends ObsidianPlugin {\n  public readonly events = new AsyncEvents();\n\n  /**\n   * Gets the AbortSignal used for aborting long-running operations.\n   *\n   * @returns The abort signal.\n   */\n  public get abortSignal(): AbortSignal {\n    return this._abortSignal;\n  }\n\n  /**\n   * Gets the readonly plugin settings.\n   *\n   * @returns The readonly plugin settings.\n   */\n  public get settings(): ReadonlyDeep<ExtractPluginSettings<PluginTypes>> {\n    return this.settingsManager.safeSettings as ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n  }\n\n  /**\n   * Gets the plugin settings manager.\n   *\n   * @returns The plugin settings manager.\n   */\n  public get settingsManager(): ExtractPluginSettingsManager<PluginTypes> {\n    if (!this._settingsManager) {\n      throw new Error('Settings manager not defined');\n    }\n\n    return this._settingsManager;\n  }\n\n  /**\n   * Gets the plugin settings tab.\n   *\n   * @returns The plugin settings tab.\n   */\n  public get settingsTab(): ExtractPluginSettingsTab<PluginTypes> {\n    if (!this._settingsTab) {\n      throw new Error('Settings tab not defined');\n    }\n\n    return this._settingsTab;\n  }\n\n  private _abortSignal!: AbortSignal;\n  private _settingsManager: ExtractPluginSettingsManager<PluginTypes> | null = null;\n  private _settingsTab: ExtractPluginSettingsTab<PluginTypes> | null = null;\n  private lifecycleEventNames = new Set<LifecycleEventName>();\n  private notice?: Notice;\n\n  /**\n   * Logs a message to the console.\n   *\n   * Use instead of `console.debug()`.\n   *\n   * Those messages are not shown by default, but they can be shown by enabling `your-plugin-id` debugger namespace.\n   *\n   * @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging} for more information.\n   *\n   * @param message - The message to log.\n   * @param args - The arguments to log.\n   */\n  public consoleDebug(message: string, ...args: unknown[]): void {\n    // Skip the `consoleDebug()` call itself\n    const FRAMES_TO_SKIP = 1;\n    const _debugger = getDebugger(this.manifest.id, FRAMES_TO_SKIP);\n    _debugger(message, ...args);\n  }\n\n  /**\n   * Called when the external settings change.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this._settingsManager?.loadFromFile(false);\n  }\n\n  /**\n   * Called when the plugin is loaded\n   */\n  public override async onload(): Promise<void> {\n    await super.onload();\n    await this.onloadImpl();\n    invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));\n  }\n\n  /**\n   * Called when the plugin settings are loaded or reloaded.\n   *\n   * @param _settings - The settings.\n   * @param _isInitialLoad - Whether the settings are being loaded for the first time.\n   */\n  public async onLoadSettings(_settings: ExtractPluginSettings<PluginTypes>, _isInitialLoad: boolean): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings are saved.\n   *\n   * @param _newSettings - The new settings.\n   * @param _oldSettings - The old settings.\n   * @param _context - The context.\n   */\n  public async onSaveSettings(\n    _newSettings: ExtractPluginSettings<PluginTypes>,\n    _oldSettings: ExtractPluginSettings<PluginTypes>,\n    _context: unknown\n  ): Promise<void> {\n    await noopAsync();\n  }\n\n  /** */\n  public override onunload(): void {\n    super.onunload();\n    invokeAsyncSafely(async () => {\n      try {\n        await this.onunloadImpl();\n      } finally {\n        await this.triggerLifecycleEvent('unload');\n      }\n    });\n  }\n\n  /**\n   * Registers an async event.\n   * Unregisters the event when the plugin is unloaded.\n   *\n   * @param eventRef - The event reference.\n   */\n  public registerAsyncEvent(eventRef: AsyncEventRef): void {\n    this.register(() => {\n      eventRef.asyncEvents.offref(eventRef);\n    });\n  }\n\n  /**\n   * Waits for a lifecycle event to be triggered.\n   *\n   * If you `await` this method during lifecycle event, it might cause a deadlock.\n   *\n   * Consider wrapping this call with {@link invokeAsyncSafely}.\n   *\n   * @param name - The name of the event.\n   * @returns A {@link Promise} that resolves when the event is triggered.\n   */\n  public async waitForLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    if (this.lifecycleEventNames.has(name)) {\n      return;\n    }\n\n    await new Promise<void>((resolve) => {\n      this.events.once(name, () => {\n        resolve();\n      });\n    });\n  }\n\n  /**\n   * Creates a plugin settings tab.\n   *\n   * @returns The settings tab or null if not applicable.\n   */\n  protected createPluginSettingsTab(): ExtractPluginSettingsTab<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Creates the plugin settings manager. This method must be implemented by subclasses.\n   *\n   * @returns The plugin settings manager.\n   */\n  protected createSettingsManager(): ExtractPluginSettingsManager<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Called when the layout is ready. This method can be overridden by subclasses to perform actions once\n   * the layout is ready.\n   */\n  protected async onLayoutReady(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Executed when the plugin is loaded.\n   *\n   * This method can be overridden by subclasses to perform actions once the plugin is loaded.\n   */\n  protected async onloadImpl(): Promise<void> {\n    initPluginContext(this.app, this.manifest.id);\n\n    this.register(registerAsyncErrorEventHandler(() => {\n      this.showNotice('An unhandled error occurred. Please check the console for more information.');\n    }));\n\n    this._settingsManager = this.createSettingsManager();\n\n    await this._settingsManager?.loadFromFile(true);\n    this._settingsTab = this.createPluginSettingsTab();\n    if (this._settingsTab) {\n      this.addSettingTab(this._settingsTab);\n    }\n\n    const abortController = new AbortController();\n    this._abortSignal = abortController.signal;\n    this.register(() => {\n      abortController.abort();\n    });\n  }\n\n  /**\n   * Called when the plugin is unloaded.\n   */\n  protected async onunloadImpl(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Displays a notice message to the user.\n   *\n   * @param message - The message to display.\n   */\n  protected showNotice(message: string): void {\n    if (this.notice) {\n      this.notice.hide();\n    }\n\n    this.notice = new Notice(`${this.manifest.name}\\n${message}`);\n  }\n\n  private async afterLoad(): Promise<void> {\n    await this.triggerLifecycleEvent('load');\n    this.app.workspace.onLayoutReady(convertAsyncToSync(this.onLayoutReadyBase.bind(this)));\n  }\n\n  private async onLayoutReadyBase(): Promise<void> {\n    try {\n      await this.onLayoutReady();\n    } finally {\n      await this.triggerLifecycleEvent('layoutReady');\n    }\n  }\n\n  private async triggerLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    this.lifecycleEventNames.add(name);\n    await this.events.triggerAsync(name);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
@@ -8,6 +8,7 @@ import type { Promisable, ReadonlyDeep } from 'type-fest';
|
|
8
8
|
import type { Transformer } from '../../Transformers/Transformer.mjs';
|
9
9
|
import type { MaybeReturn, StringKeys } from '../../Type.mjs';
|
10
10
|
import type { ExtractPlugin, ExtractPluginSettings, PluginTypesBase } from './PluginTypesBase.mjs';
|
11
|
+
type PropertySetter = (value: unknown) => void;
|
11
12
|
type Validator<T> = (value: T) => Promisable<MaybeReturn<string>>;
|
12
13
|
/**
|
13
14
|
* Base class for managing plugin settings.
|
@@ -18,20 +19,50 @@ export declare abstract class PluginSettingsManagerBase<PluginTypes extends Plug
|
|
18
19
|
readonly plugin: ExtractPlugin<PluginTypes>;
|
19
20
|
readonly app: App;
|
20
21
|
readonly safeSettings: ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;
|
21
|
-
private currentSettings;
|
22
|
-
private properties;
|
23
|
-
private validators;
|
22
|
+
private readonly currentSettings;
|
23
|
+
private readonly properties;
|
24
|
+
private readonly validators;
|
25
|
+
/**
|
26
|
+
* Creates a new plugin settings manager.
|
27
|
+
*
|
28
|
+
* @param plugin - The plugin.
|
29
|
+
*/
|
24
30
|
constructor(plugin: ExtractPlugin<PluginTypes>);
|
25
|
-
|
31
|
+
/**
|
32
|
+
* Edits the plugin settings and saves them.
|
33
|
+
*
|
34
|
+
* @param editor - The editor.
|
35
|
+
* @param context - The context.
|
36
|
+
* @returns A {@link Promise} that resolves when the settings are saved.
|
37
|
+
*/
|
38
|
+
editAndSave(editor: (settings: ExtractPluginSettings<PluginTypes>) => Promisable<void>, context?: unknown): Promise<void>;
|
39
|
+
/**
|
40
|
+
* Gets a property of the plugin settings.
|
41
|
+
*
|
42
|
+
* @param propertyName - The name of the property.
|
43
|
+
* @returns The property.
|
44
|
+
*/
|
26
45
|
getProperty<PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>>(propertyName: PropertyName): PluginSettingsProperty<ExtractPluginSettings<PluginTypes>[PropertyName]>;
|
27
|
-
|
46
|
+
/**
|
47
|
+
* Loads the plugin settings from the file.
|
48
|
+
*
|
49
|
+
* @param isInitialLoad - Whether the settings are being loaded for the first time.
|
50
|
+
* @returns A {@link Promise} that resolves when the settings are loaded.
|
51
|
+
*/
|
52
|
+
loadFromFile(isInitialLoad: boolean): Promise<void>;
|
28
53
|
/**
|
29
54
|
* Saves the new plugin settings.
|
30
55
|
*
|
56
|
+
* @param context - The context of the save to file operation.
|
31
57
|
* @returns A {@link Promise} that resolves when the settings are saved.
|
32
58
|
*/
|
33
|
-
saveToFile(): Promise<void>;
|
59
|
+
saveToFile(context?: unknown): Promise<void>;
|
34
60
|
protected abstract createDefaultSettings(): ExtractPluginSettings<PluginTypes>;
|
61
|
+
/**
|
62
|
+
* Gets the transformer.
|
63
|
+
*
|
64
|
+
* @returns The transformer.
|
65
|
+
*/
|
35
66
|
protected getTransformer(): Transformer;
|
36
67
|
/**
|
37
68
|
* Called when the plugin settings are loaded.
|
@@ -45,7 +76,18 @@ export declare abstract class PluginSettingsManagerBase<PluginTypes extends Plug
|
|
45
76
|
* @param _record - The record.
|
46
77
|
*/
|
47
78
|
protected onSavingRecord(_record: Record<string, unknown>): Promise<void>;
|
79
|
+
/**
|
80
|
+
* Registers a validator for a property.
|
81
|
+
*
|
82
|
+
* @param propertyName - The name of the property.
|
83
|
+
* @param validator - The validator.
|
84
|
+
*/
|
48
85
|
protected registerValidator<PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>>(propertyName: PropertyName, validator: Validator<ExtractPluginSettings<PluginTypes>[PropertyName]>): void;
|
86
|
+
/**
|
87
|
+
* Registers the validators.
|
88
|
+
*
|
89
|
+
* This method can be overridden by subclasses to register validators for properties.
|
90
|
+
*/
|
49
91
|
protected registerValidators(): void;
|
50
92
|
private getSavedSettings;
|
51
93
|
private prepareRecordToSave;
|
@@ -60,19 +102,71 @@ export declare class PluginSettingsProperty<T> {
|
|
60
102
|
private readonly propertyName;
|
61
103
|
readonly defaultValue: T;
|
62
104
|
private readonly validator;
|
105
|
+
private readonly propertySetter;
|
106
|
+
/**
|
107
|
+
* The current value of the property.
|
108
|
+
*
|
109
|
+
* @returns The current value.
|
110
|
+
*/
|
63
111
|
get currentValue(): T;
|
112
|
+
/**
|
113
|
+
* The last saved value of the property.
|
114
|
+
*
|
115
|
+
* @returns The last saved value.
|
116
|
+
*/
|
64
117
|
get lastSavedValue(): T;
|
118
|
+
/**
|
119
|
+
* The safe value of the property.
|
120
|
+
*
|
121
|
+
* @returns The safe value.
|
122
|
+
*/
|
65
123
|
get safeValue(): T;
|
124
|
+
/**
|
125
|
+
* The validation message of the property.
|
126
|
+
*
|
127
|
+
* @returns The validation message.
|
128
|
+
*/
|
66
129
|
get validationMessage(): string;
|
67
130
|
private _currentValue;
|
68
131
|
private _lastSavedValue;
|
69
132
|
private _validationMessage;
|
70
|
-
|
133
|
+
/**
|
134
|
+
* Creates a new plugin settings property.
|
135
|
+
*
|
136
|
+
* @param propertyName - The name of the property.
|
137
|
+
* @param defaultValue - The default value of the property.
|
138
|
+
* @param validator - The validator of the property.
|
139
|
+
* @param propertySetter - The property setter of the property.
|
140
|
+
*/
|
141
|
+
constructor(propertyName: string, defaultValue: T, validator: Validator<T>, propertySetter: PropertySetter);
|
142
|
+
/**
|
143
|
+
* Resets the current value of the property to the default value.
|
144
|
+
*/
|
71
145
|
reset(): void;
|
146
|
+
/**
|
147
|
+
* Saves the current value of the property.
|
148
|
+
*
|
149
|
+
* @returns `true` if the value was changed, `false` otherwise.
|
150
|
+
*/
|
72
151
|
save(): boolean;
|
152
|
+
/**
|
153
|
+
* Sets the validation message of the property.
|
154
|
+
*
|
155
|
+
* @param validationMessage - The validation message.
|
156
|
+
*/
|
73
157
|
setValidationMessage(validationMessage: string): void;
|
158
|
+
/**
|
159
|
+
* Sets the current value of the property.
|
160
|
+
*
|
161
|
+
* @param value - The value to set.
|
162
|
+
*/
|
74
163
|
setValue(value: T): void;
|
75
|
-
|
164
|
+
/**
|
165
|
+
* Validates the current value of the property.
|
166
|
+
*
|
167
|
+
* @returns A {@link Promise} that resolves when the validation is complete.
|
168
|
+
*/
|
169
|
+
validate(): Promise<void>;
|
76
170
|
private showWarning;
|
77
171
|
}
|
78
172
|
export {};
|