obsidian-dev-utils 57.0.2 → 58.0.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.
Files changed (29) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/dist/lib/cjs/library.cjs +1 -1
  3. package/dist/lib/cjs/obsidian/components/async-component.cjs +28 -11
  4. package/dist/lib/cjs/obsidian/components/async-component.d.cts +14 -0
  5. package/dist/lib/cjs/obsidian/plugin/components/index.cjs +4 -4
  6. package/dist/lib/cjs/obsidian/plugin/components/index.d.cts +1 -1
  7. package/dist/lib/cjs/obsidian/plugin/components/layout-ready-component.cjs +124 -0
  8. package/dist/lib/cjs/obsidian/plugin/components/layout-ready-component.d.cts +18 -0
  9. package/dist/lib/cjs/obsidian/plugin/plugin.cjs +47 -81
  10. package/dist/lib/cjs/obsidian/plugin/plugin.d.cts +13 -51
  11. package/dist/lib/cjs/strict-proxy.cjs +15 -4
  12. package/dist/lib/cjs/strict-proxy.d.cts +12 -0
  13. package/dist/lib/esm/library.mjs +1 -1
  14. package/dist/lib/esm/obsidian/components/async-component.d.mts +14 -0
  15. package/dist/lib/esm/obsidian/components/async-component.mjs +25 -10
  16. package/dist/lib/esm/obsidian/plugin/components/index.d.mts +1 -1
  17. package/dist/lib/esm/obsidian/plugin/components/index.mjs +3 -3
  18. package/dist/lib/esm/obsidian/plugin/components/layout-ready-component.d.mts +18 -0
  19. package/dist/lib/esm/obsidian/plugin/components/layout-ready-component.mjs +24 -0
  20. package/dist/lib/esm/obsidian/plugin/plugin.d.mts +13 -51
  21. package/dist/lib/esm/obsidian/plugin/plugin.mjs +48 -85
  22. package/dist/lib/esm/strict-proxy.d.mts +12 -0
  23. package/dist/lib/esm/strict-proxy.mjs +14 -4
  24. package/obsidian/Plugin/components/{lifecycle-events-component → layout-ready-component}/package.json +3 -3
  25. package/package.json +3 -3
  26. package/dist/lib/cjs/obsidian/plugin/components/lifecycle-events-component.cjs +0 -211
  27. package/dist/lib/cjs/obsidian/plugin/components/lifecycle-events-component.d.cts +0 -63
  28. package/dist/lib/esm/obsidian/plugin/components/lifecycle-events-component.d.mts +0 -63
  29. package/dist/lib/esm/obsidian/plugin/components/lifecycle-events-component.mjs +0 -106
@@ -26,17 +26,14 @@ import {
26
26
  Notice,
27
27
  Plugin as ObsidianPlugin
28
28
  } from "obsidian";
29
- import {
30
- convertAsyncToSync,
31
- invokeAsyncSafelyAfterDelay
32
- } from "../../async.mjs";
29
+ import { invokeAsyncSafelyAfterDelay } from "../../async.mjs";
33
30
  import { printError } from "../../error.mjs";
34
- import { noopAsync } from "../../function.mjs";
31
+ import { bypassStrictProxy } from "../../strict-proxy.mjs";
32
+ import { loadChildrenFirstAsync } from "../components/async-component.mjs";
35
33
  import { AbortSignalComponent } from "./components/abort-signal-component.mjs";
36
34
  import { AsyncErrorHandlerComponent } from "./components/async-error-handler-component.mjs";
37
35
  import { ConsoleDebugComponent } from "./components/console-debug-component.mjs";
38
36
  import { I18nComponent } from "./components/i18n-component.mjs";
39
- import { LifecycleEventsComponent } from "./components/lifecycle-events-component.mjs";
40
37
  import { PluginContextComponent } from "./components/plugin-context-component.mjs";
41
38
  import { PluginNoticeComponent } from "./components/plugin-notice-component.mjs";
42
39
  import { EmptyPluginSettingsComponent } from "./components/plugin-settings-component.mjs";
@@ -49,10 +46,6 @@ class PluginBase extends ObsidianPlugin {
49
46
  * The console debug component. Provides namespaced debug logging.
50
47
  */
51
48
  consoleDebugComponent;
52
- /**
53
- * The lifecycle events component. Provides load, layoutReady, and unload events.
54
- */
55
- lifecycleEventsComponent;
56
49
  /**
57
50
  * The notice component. Displays notices to the user.
58
51
  */
@@ -61,7 +54,6 @@ class PluginBase extends ObsidianPlugin {
61
54
  * The settings component. Manages plugin settings lifecycle.
62
55
  */
63
56
  settingsComponent;
64
- preloadComponents = [];
65
57
  singletonComponents = /* @__PURE__ */ new Map();
66
58
  /**
67
59
  * Creates a new PluginBase.
@@ -71,95 +63,66 @@ class PluginBase extends ObsidianPlugin {
71
63
  */
72
64
  constructor(app, manifest) {
73
65
  super(app, manifest);
74
- this.registerComponent({ component: new PluginContextComponent(app, manifest.id), shouldPreload: true });
75
- this.registerComponent({ component: new I18nComponent(), shouldPreload: true });
76
- this.noticeComponent = this.registerComponent({ component: new PluginNoticeComponent(manifest.name) });
77
- this.registerComponent({ component: new AsyncErrorHandlerComponent(this.noticeComponent) });
78
- this.abortSignalComponent = this.registerComponent({ component: new AbortSignalComponent(manifest.id) });
79
- this.consoleDebugComponent = this.registerComponent({ component: new ConsoleDebugComponent(manifest.id) });
80
- this.lifecycleEventsComponent = this.registerComponent({ component: new LifecycleEventsComponent(app) });
81
- this.settingsComponent = this.registerComponent({ component: new EmptyPluginSettingsComponent(), shouldPreload: true });
82
- }
83
- /**
84
- * Called when the external settings change.
85
- *
86
- * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.
87
- */
88
- async onExternalSettingsChange() {
89
- await super.onExternalSettingsChange?.();
90
- await this.settingsComponent.onExternalSettingsChange();
91
- }
92
- /**
93
- * Called when the plugin is loaded. Force-loads components that must be ready
94
- * before plugin logic, then calls `onloadImpl()`.
95
- *
96
- * Usually, you don't need to override this method. Override {@link onloadImpl} instead.
97
- */
98
- async onload() {
99
- await super.onload();
100
- for (const component of this.preloadComponents) {
101
- await component.load();
102
- }
103
- await this.onloadImpl();
104
- invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));
105
- }
106
- /**
107
- * Called when the layout is ready.
108
- */
109
- async onLayoutReady() {
110
- await noopAsync();
111
- }
112
- /**
113
- * Called after all pre-load components are initialized. Override this to add plugin-specific logic.
114
- *
115
- * @remarks It is important to call `super.onloadImpl()` in overridden method.
116
- */
117
- async onloadImpl() {
118
- await noopAsync();
66
+ this.addChild(new PluginContextComponent(app, manifest.id));
67
+ this.addChild(new I18nComponent());
68
+ this.noticeComponent = this.addChild(new PluginNoticeComponent(manifest.name));
69
+ this.addChild(new AsyncErrorHandlerComponent(this.noticeComponent));
70
+ this.abortSignalComponent = this.addChild(new AbortSignalComponent(manifest.id));
71
+ this.consoleDebugComponent = this.addChild(new ConsoleDebugComponent(manifest.id));
72
+ this.settingsComponent = this.addChild(new EmptyPluginSettingsComponent());
119
73
  }
120
74
  /**
121
- * Registers a component with the plugin.
75
+ * Adds a component to the plugin.
122
76
  *
123
77
  * If the component's class defines a static `COMPONENT_KEY` symbol, it is treated as a singleton —
124
- * registering another component with the same key replaces the previous one.
78
+ * adding another component with the same key replaces the previous one.
125
79
  * Components without a `COMPONENT_KEY` are multi-instance and simply added.
126
80
  *
127
81
  * @typeParam T - The component type.
128
- * @param params - The registration params.
129
- * @returns The registered component.
82
+ * @param component - The component to add.
83
+ * @returns The added component.
130
84
  */
131
- registerComponent(params) {
132
- const singletonKey = params.component.constructor.COMPONENT_KEY;
85
+ addChild(component) {
86
+ if (this._loaded) {
87
+ return super.addChild(component);
88
+ }
89
+ const singletonKey = component.constructor.COMPONENT_KEY;
133
90
  if (singletonKey) {
134
91
  const oldComponent = this.singletonComponents.get(singletonKey);
135
92
  if (oldComponent) {
136
93
  this.removeChild(oldComponent);
137
- const preloadIndex = this.preloadComponents.indexOf(oldComponent);
138
- if (preloadIndex !== -1) {
139
- this.preloadComponents.splice(preloadIndex, 1);
140
- }
141
94
  }
142
- this.singletonComponents.set(singletonKey, params.component);
143
- }
144
- this.addChild(params.component);
145
- if (params.shouldPreload) {
146
- this.preloadComponents.push(params.component);
95
+ this.singletonComponents.set(singletonKey, component);
147
96
  }
148
- return params.component;
97
+ return super.addChild(component);
149
98
  }
150
- async afterLoad() {
151
- if (this.abortSignalComponent.abortSignal.aborted) {
152
- return;
153
- }
154
- await this.lifecycleEventsComponent.triggerLifecycleEvent("load");
155
- this.app.workspace.onLayoutReady(convertAsyncToSync(this.onLayoutReadyBase.bind(this)));
99
+ /**
100
+ * Loads the plugin and its components.
101
+ */
102
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises -- Obsidian's load() handles async returns at runtime.
103
+ async load() {
104
+ await loadChildrenFirstAsync(this);
105
+ this.app.workspace.onLayoutReady(() => {
106
+ invokeAsyncSafelyAfterDelay(
107
+ async () => {
108
+ for (const child of this._children) {
109
+ await bypassStrictProxy(child).onLayoutReady?.();
110
+ }
111
+ },
112
+ 0,
113
+ void 0,
114
+ this.abortSignalComponent.abortSignal
115
+ );
116
+ });
156
117
  }
157
- async onLayoutReadyBase() {
158
- try {
159
- await this.onLayoutReady();
160
- } finally {
161
- await this.lifecycleEventsComponent.triggerLifecycleEvent("layoutReady");
162
- }
118
+ /**
119
+ * Called when the external settings change.
120
+ *
121
+ * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.
122
+ */
123
+ async onExternalSettingsChange() {
124
+ await super.onExternalSettingsChange?.();
125
+ await this.settingsComponent.onExternalSettingsChange();
163
126
  }
164
127
  }
165
128
  async function reloadPlugin(plugin) {
@@ -178,4 +141,4 @@ export {
178
141
  reloadPlugin,
179
142
  showErrorAndDisablePlugin
180
143
  };
181
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/plugin/plugin.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Base class for Obsidian plugins using a component-based architecture.\n *\n * PluginBase registers universal components (context, i18n, error handling, abort signal, lifecycle events, debug).\n * Subclasses add their own components via {@link registerComponent} in their constructor.\n * Any universal component can be replaced by calling {@link registerComponent} with a new instance of the same class.\n */\n\nimport type {\n  App,\n  PluginManifest\n} from 'obsidian';\nimport type { Promisable } from 'type-fest';\n\nimport {\n  Component,\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type { PluginSettingsComponentBase } from './components/plugin-settings-component.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafelyAfterDelay\n} from '../../async.ts';\nimport { printError } from '../../error.ts';\nimport { noopAsync } from '../../function.ts';\nimport { AbortSignalComponent } from './components/abort-signal-component.ts';\nimport { AsyncErrorHandlerComponent } from './components/async-error-handler-component.ts';\nimport { ConsoleDebugComponent } from './components/console-debug-component.ts';\nimport { I18nComponent } from './components/i18n-component.ts';\nimport { LifecycleEventsComponent } from './components/lifecycle-events-component.ts';\nimport { PluginContextComponent } from './components/plugin-context-component.ts';\nimport { PluginNoticeComponent } from './components/plugin-notice-component.ts';\nimport { EmptyPluginSettingsComponent } from './components/plugin-settings-component.ts';\n\n/**\n * Params for {@link PluginBase.registerComponent}.\n *\n * @typeParam T - The component type.\n */\nexport interface RegisterComponentParams<T extends Component = Component> {\n  /**\n   * The component to register.\n   */\n  readonly component: T;\n\n  /**\n   * Whether this component should be loaded before the plugin's `onloadImpl()` runs.\n   * Components marked with this flag are force-loaded during `onload()`, ensuring they are\n   * fully initialized before plugin logic executes.\n   */\n  readonly shouldPreload?: boolean;\n}\n\ninterface ComponentClassWithKey {\n  COMPONENT_KEY: symbol;\n}\n\n/**\n * Base class for creating Obsidian plugins with a component-based architecture.\n *\n * Registers universal components automatically. Subclasses add or replace components\n * via {@link registerComponent} in their constructor.\n */\nexport abstract class PluginBase extends ObsidianPlugin {\n  /**\n   * The abort signal component. Aborted when the plugin is unloaded.\n   */\n  protected readonly abortSignalComponent: AbortSignalComponent;\n\n  /**\n   * The console debug component. Provides namespaced debug logging.\n   */\n  protected readonly consoleDebugComponent: ConsoleDebugComponent;\n\n  /**\n   * The lifecycle events component. Provides load, layoutReady, and unload events.\n   */\n  protected readonly lifecycleEventsComponent: LifecycleEventsComponent;\n\n  /**\n   * The notice component. Displays notices to the user.\n   */\n  protected readonly noticeComponent: PluginNoticeComponent;\n\n  /**\n   * The settings component. Manages plugin settings lifecycle.\n   */\n  protected readonly settingsComponent: PluginSettingsComponentBase<object>;\n\n  private readonly preloadComponents: Component[] = [];\n  private readonly singletonComponents = new Map<symbol, Component>();\n\n  /**\n   * Creates a new PluginBase.\n   *\n   * @param app - The Obsidian app instance.\n   * @param manifest - The plugin manifest.\n   */\n  public constructor(app: App, manifest: PluginManifest) {\n    super(app, manifest);\n\n    this.registerComponent({ component: new PluginContextComponent(app, manifest.id), shouldPreload: true });\n    this.registerComponent({ component: new I18nComponent(), shouldPreload: true });\n    this.noticeComponent = this.registerComponent({ component: new PluginNoticeComponent(manifest.name) });\n    this.registerComponent({ component: new AsyncErrorHandlerComponent(this.noticeComponent) });\n    this.abortSignalComponent = this.registerComponent({ component: new AbortSignalComponent(manifest.id) });\n    this.consoleDebugComponent = this.registerComponent({ component: new ConsoleDebugComponent(manifest.id) });\n    this.lifecycleEventsComponent = this.registerComponent({ component: new LifecycleEventsComponent(app) });\n    this.settingsComponent = this.registerComponent({ component: new EmptyPluginSettingsComponent(), shouldPreload: true });\n  }\n\n  /**\n   * Called when the external settings change.\n   *\n   * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this.settingsComponent.onExternalSettingsChange();\n  }\n\n  /**\n   * Called when the plugin is loaded. Force-loads components that must be ready\n   * before plugin logic, then calls `onloadImpl()`.\n   *\n   * Usually, you don't need to override this method. Override {@link onloadImpl} instead.\n   */\n  public override async onload(): Promise<void> {\n    await super.onload();\n\n    for (const component of this.preloadComponents) {\n      // eslint-disable-next-line @typescript-eslint/no-confusing-void-expression -- Component.load() returns void|Promise at runtime despite void typing.\n      await (component.load() as Promisable<void>);\n    }\n\n    await this.onloadImpl();\n    invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));\n  }\n\n  /**\n   * Called when the layout is ready.\n   */\n  protected async onLayoutReady(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called after all pre-load components are initialized. Override this to add plugin-specific logic.\n   *\n   * @remarks It is important to call `super.onloadImpl()` in overridden method.\n   */\n  protected async onloadImpl(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Registers a component with the plugin.\n   *\n   * If the component's class defines a static `COMPONENT_KEY` symbol, it is treated as a singleton \u2014\n   * registering another component with the same key replaces the previous one.\n   * Components without a `COMPONENT_KEY` are multi-instance and simply added.\n   *\n   * @typeParam T - The component type.\n   * @param params - The registration params.\n   * @returns The registered component.\n   */\n  protected registerComponent<T extends Component>(params: RegisterComponentParams<T>): T {\n    const singletonKey = (params.component.constructor as Partial<ComponentClassWithKey>).COMPONENT_KEY;\n\n    if (singletonKey) {\n      const oldComponent = this.singletonComponents.get(singletonKey);\n      if (oldComponent) {\n        this.removeChild(oldComponent);\n        const preloadIndex = this.preloadComponents.indexOf(oldComponent);\n        if (preloadIndex !== -1) {\n          this.preloadComponents.splice(preloadIndex, 1);\n        }\n      }\n      this.singletonComponents.set(singletonKey, params.component);\n    }\n\n    this.addChild(params.component);\n\n    if (params.shouldPreload) {\n      this.preloadComponents.push(params.component);\n    }\n\n    return params.component;\n  }\n\n  private async afterLoad(): Promise<void> {\n    if (this.abortSignalComponent.abortSignal.aborted) {\n      return;\n    }\n    await this.lifecycleEventsComponent.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.lifecycleEventsComponent.triggerLifecycleEvent('layoutReady');\n    }\n  }\n}\n\n/**\n * Reloads the specified plugin by disabling and then re-enabling it.\n *\n * @param plugin - The plugin to reload.\n * @returns A {@link Promise} that resolves when the plugin is reloaded.\n */\nexport async function reloadPlugin(plugin: ObsidianPlugin): Promise<void> {\n  const plugins = plugin.app.plugins;\n  const pluginId = plugin.manifest.id;\n  await plugins.disablePlugin(pluginId);\n  await plugins.enablePlugin(pluginId);\n}\n\n/**\n * Displays an error message as a notice, logs it to the console, and disables the specified plugin.\n *\n * @param plugin - The plugin to disable.\n * @param message - The error message to display and log.\n * @returns A {@link Promise} that resolves when the plugin is disabled.\n */\nexport async function showErrorAndDisablePlugin(plugin: ObsidianPlugin, message: string): Promise<void> {\n  new Notice(message);\n  printError(new Error(message));\n  await plugin.app.plugins.disablePlugin(plugin.manifest.id);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;AAgBA;AAAA,EACE;AAAA,EACA;AAAA,EACA,UAAU;AAAA,OACL;AAIP;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,kBAAkB;AAC3B,SAAS,iBAAiB;AAC1B,SAAS,4BAA4B;AACrC,SAAS,kCAAkC;AAC3C,SAAS,6BAA6B;AACtC,SAAS,qBAAqB;AAC9B,SAAS,gCAAgC;AACzC,SAAS,8BAA8B;AACvC,SAAS,6BAA6B;AACtC,SAAS,oCAAoC;AA+BtC,MAAe,mBAAmB,eAAe;AAAA;AAAA;AAAA;AAAA,EAInC;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA,EAEF,oBAAiC,CAAC;AAAA,EAClC,sBAAsB,oBAAI,IAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ3D,YAAY,KAAU,UAA0B;AACrD,UAAM,KAAK,QAAQ;AAEnB,SAAK,kBAAkB,EAAE,WAAW,IAAI,uBAAuB,KAAK,SAAS,EAAE,GAAG,eAAe,KAAK,CAAC;AACvG,SAAK,kBAAkB,EAAE,WAAW,IAAI,cAAc,GAAG,eAAe,KAAK,CAAC;AAC9E,SAAK,kBAAkB,KAAK,kBAAkB,EAAE,WAAW,IAAI,sBAAsB,SAAS,IAAI,EAAE,CAAC;AACrG,SAAK,kBAAkB,EAAE,WAAW,IAAI,2BAA2B,KAAK,eAAe,EAAE,CAAC;AAC1F,SAAK,uBAAuB,KAAK,kBAAkB,EAAE,WAAW,IAAI,qBAAqB,SAAS,EAAE,EAAE,CAAC;AACvG,SAAK,wBAAwB,KAAK,kBAAkB,EAAE,WAAW,IAAI,sBAAsB,SAAS,EAAE,EAAE,CAAC;AACzG,SAAK,2BAA2B,KAAK,kBAAkB,EAAE,WAAW,IAAI,yBAAyB,GAAG,EAAE,CAAC;AACvG,SAAK,oBAAoB,KAAK,kBAAkB,EAAE,WAAW,IAAI,6BAA6B,GAAG,eAAe,KAAK,CAAC;AAAA,EACxH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAsB,2BAA0C;AAC9D,UAAM,MAAM,2BAA2B;AACvC,UAAM,KAAK,kBAAkB,yBAAyB;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAsB,SAAwB;AAC5C,UAAM,MAAM,OAAO;AAEnB,eAAW,aAAa,KAAK,mBAAmB;AAE9C,YAAO,UAAU,KAAK;AAAA,IACxB;AAEA,UAAM,KAAK,WAAW;AACtB,gCAA4B,KAAK,UAAU,KAAK,IAAI,CAAC;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAgB,gBAA+B;AAC7C,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAgB,aAA4B;AAC1C,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaU,kBAAuC,QAAuC;AACtF,UAAM,eAAgB,OAAO,UAAU,YAA+C;AAEtF,QAAI,cAAc;AAChB,YAAM,eAAe,KAAK,oBAAoB,IAAI,YAAY;AAC9D,UAAI,cAAc;AAChB,aAAK,YAAY,YAAY;AAC7B,cAAM,eAAe,KAAK,kBAAkB,QAAQ,YAAY;AAChE,YAAI,iBAAiB,IAAI;AACvB,eAAK,kBAAkB,OAAO,cAAc,CAAC;AAAA,QAC/C;AAAA,MACF;AACA,WAAK,oBAAoB,IAAI,cAAc,OAAO,SAAS;AAAA,IAC7D;AAEA,SAAK,SAAS,OAAO,SAAS;AAE9B,QAAI,OAAO,eAAe;AACxB,WAAK,kBAAkB,KAAK,OAAO,SAAS;AAAA,IAC9C;AAEA,WAAO,OAAO;AAAA,EAChB;AAAA,EAEA,MAAc,YAA2B;AACvC,QAAI,KAAK,qBAAqB,YAAY,SAAS;AACjD;AAAA,IACF;AACA,UAAM,KAAK,yBAAyB,sBAAsB,MAAM;AAChE,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,yBAAyB,sBAAsB,aAAa;AAAA,IACzE;AAAA,EACF;AACF;AAQA,eAAsB,aAAa,QAAuC;AACxE,QAAM,UAAU,OAAO,IAAI;AAC3B,QAAM,WAAW,OAAO,SAAS;AACjC,QAAM,QAAQ,cAAc,QAAQ;AACpC,QAAM,QAAQ,aAAa,QAAQ;AACrC;AASA,eAAsB,0BAA0B,QAAwB,SAAgC;AACtG,MAAI,OAAO,OAAO;AAClB,aAAW,IAAI,MAAM,OAAO,CAAC;AAC7B,QAAM,OAAO,IAAI,QAAQ,cAAc,OAAO,SAAS,EAAE;AAC3D;",
  "names": []
}

144
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/plugin/plugin.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Base class for Obsidian plugins using a component-based architecture.\n *\n * PluginBase registers universal components (context, i18n, error handling, abort signal, lifecycle events, debug).\n * Subclasses add their own components via {@link registerComponent} in their constructor.\n * Any universal component can be replaced by calling {@link registerComponent} with a new instance of the same class.\n */\n\nimport type {\n  App,\n  PluginManifest\n} from 'obsidian';\n\nimport {\n  Component,\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type { LayoutReadyComponent } from './components/layout-ready-component.ts';\nimport type { PluginSettingsComponentBase } from './components/plugin-settings-component.ts';\n\nimport { invokeAsyncSafelyAfterDelay } from '../../async.ts';\nimport { printError } from '../../error.ts';\nimport { bypassStrictProxy } from '../../strict-proxy.ts';\nimport { loadChildrenFirstAsync } from '../components/async-component.ts';\nimport { AbortSignalComponent } from './components/abort-signal-component.ts';\nimport { AsyncErrorHandlerComponent } from './components/async-error-handler-component.ts';\nimport { ConsoleDebugComponent } from './components/console-debug-component.ts';\nimport { I18nComponent } from './components/i18n-component.ts';\nimport { PluginContextComponent } from './components/plugin-context-component.ts';\nimport { PluginNoticeComponent } from './components/plugin-notice-component.ts';\nimport { EmptyPluginSettingsComponent } from './components/plugin-settings-component.ts';\n\ninterface ComponentClassWithKey {\n  COMPONENT_KEY: symbol;\n}\n\n/**\n * Base class for creating Obsidian plugins with a component-based architecture.\n *\n * Registers universal components automatically. Subclasses add or replace components\n * via {@link registerComponent} in their constructor.\n */\nexport abstract class PluginBase extends ObsidianPlugin {\n  /**\n   * The abort signal component. Aborted when the plugin is unloaded.\n   */\n  protected readonly abortSignalComponent: AbortSignalComponent;\n\n  /**\n   * The console debug component. Provides namespaced debug logging.\n   */\n  protected readonly consoleDebugComponent: ConsoleDebugComponent;\n\n  /**\n   * The notice component. Displays notices to the user.\n   */\n  protected readonly noticeComponent: PluginNoticeComponent;\n\n  /**\n   * The settings component. Manages plugin settings lifecycle.\n   */\n  protected readonly settingsComponent: PluginSettingsComponentBase<object>;\n\n  private readonly singletonComponents = new Map<symbol, Component>();\n\n  /**\n   * Creates a new PluginBase.\n   *\n   * @param app - The Obsidian app instance.\n   * @param manifest - The plugin manifest.\n   */\n  public constructor(app: App, manifest: PluginManifest) {\n    super(app, manifest);\n\n    this.addChild(new PluginContextComponent(app, manifest.id));\n    this.addChild(new I18nComponent());\n    this.noticeComponent = this.addChild(new PluginNoticeComponent(manifest.name));\n    this.addChild(new AsyncErrorHandlerComponent(this.noticeComponent));\n    this.abortSignalComponent = this.addChild(new AbortSignalComponent(manifest.id));\n    this.consoleDebugComponent = this.addChild(new ConsoleDebugComponent(manifest.id));\n    this.settingsComponent = this.addChild(new EmptyPluginSettingsComponent());\n  }\n\n  /**\n   * Adds a component to the plugin.\n   *\n   * If the component's class defines a static `COMPONENT_KEY` symbol, it is treated as a singleton \u2014\n   * adding another component with the same key replaces the previous one.\n   * Components without a `COMPONENT_KEY` are multi-instance and simply added.\n   *\n   * @typeParam T - The component type.\n   * @param component - The component to add.\n   * @returns The added component.\n   */\n  public override addChild<T extends Component>(component: T): T {\n    if (this._loaded) {\n      return super.addChild(component);\n    }\n\n    const singletonKey = (component.constructor as Partial<ComponentClassWithKey>).COMPONENT_KEY;\n\n    if (singletonKey) {\n      const oldComponent = this.singletonComponents.get(singletonKey);\n      if (oldComponent) {\n        this.removeChild(oldComponent);\n      }\n      this.singletonComponents.set(singletonKey, component);\n    }\n\n    return super.addChild(component);\n  }\n\n  /**\n   * Loads the plugin and its components.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-misused-promises -- Obsidian's load() handles async returns at runtime.\n  public override async load(): Promise<void> {\n    await loadChildrenFirstAsync(this);\n    this.app.workspace.onLayoutReady(() => {\n      invokeAsyncSafelyAfterDelay(\n        async () => {\n          for (const child of this._children) {\n            await (bypassStrictProxy(child) as Partial<LayoutReadyComponent>).onLayoutReady?.();\n          }\n        },\n        0,\n        undefined,\n        this.abortSignalComponent.abortSignal\n      );\n    });\n  }\n\n  /**\n   * Called when the external settings change.\n   *\n   * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this.settingsComponent.onExternalSettingsChange();\n  }\n}\n\n/**\n * Reloads the specified plugin by disabling and then re-enabling it.\n *\n * @param plugin - The plugin to reload.\n * @returns A {@link Promise} that resolves when the plugin is reloaded.\n */\nexport async function reloadPlugin(plugin: ObsidianPlugin): Promise<void> {\n  const plugins = plugin.app.plugins;\n  const pluginId = plugin.manifest.id;\n  await plugins.disablePlugin(pluginId);\n  await plugins.enablePlugin(pluginId);\n}\n\n/**\n * Displays an error message as a notice, logs it to the console, and disables the specified plugin.\n *\n * @param plugin - The plugin to disable.\n * @param message - The error message to display and log.\n * @returns A {@link Promise} that resolves when the plugin is disabled.\n */\nexport async function showErrorAndDisablePlugin(plugin: ObsidianPlugin, message: string): Promise<void> {\n  new Notice(message);\n  printError(new Error(message));\n  await plugin.app.plugins.disablePlugin(plugin.manifest.id);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;AAeA;AAAA,EACE;AAAA,EACA;AAAA,EACA,UAAU;AAAA,OACL;AAKP,SAAS,mCAAmC;AAC5C,SAAS,kBAAkB;AAC3B,SAAS,yBAAyB;AAClC,SAAS,8BAA8B;AACvC,SAAS,4BAA4B;AACrC,SAAS,kCAAkC;AAC3C,SAAS,6BAA6B;AACtC,SAAS,qBAAqB;AAC9B,SAAS,8BAA8B;AACvC,SAAS,6BAA6B;AACtC,SAAS,oCAAoC;AAYtC,MAAe,mBAAmB,eAAe;AAAA;AAAA;AAAA;AAAA,EAInC;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA,EAEF,sBAAsB,oBAAI,IAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ3D,YAAY,KAAU,UAA0B;AACrD,UAAM,KAAK,QAAQ;AAEnB,SAAK,SAAS,IAAI,uBAAuB,KAAK,SAAS,EAAE,CAAC;AAC1D,SAAK,SAAS,IAAI,cAAc,CAAC;AACjC,SAAK,kBAAkB,KAAK,SAAS,IAAI,sBAAsB,SAAS,IAAI,CAAC;AAC7E,SAAK,SAAS,IAAI,2BAA2B,KAAK,eAAe,CAAC;AAClE,SAAK,uBAAuB,KAAK,SAAS,IAAI,qBAAqB,SAAS,EAAE,CAAC;AAC/E,SAAK,wBAAwB,KAAK,SAAS,IAAI,sBAAsB,SAAS,EAAE,CAAC;AACjF,SAAK,oBAAoB,KAAK,SAAS,IAAI,6BAA6B,CAAC;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAagB,SAA8B,WAAiB;AAC7D,QAAI,KAAK,SAAS;AAChB,aAAO,MAAM,SAAS,SAAS;AAAA,IACjC;AAEA,UAAM,eAAgB,UAAU,YAA+C;AAE/E,QAAI,cAAc;AAChB,YAAM,eAAe,KAAK,oBAAoB,IAAI,YAAY;AAC9D,UAAI,cAAc;AAChB,aAAK,YAAY,YAAY;AAAA,MAC/B;AACA,WAAK,oBAAoB,IAAI,cAAc,SAAS;AAAA,IACtD;AAEA,WAAO,MAAM,SAAS,SAAS;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAsB,OAAsB;AAC1C,UAAM,uBAAuB,IAAI;AACjC,SAAK,IAAI,UAAU,cAAc,MAAM;AACrC;AAAA,QACE,YAAY;AACV,qBAAW,SAAS,KAAK,WAAW;AAClC,kBAAO,kBAAkB,KAAK,EAAoC,gBAAgB;AAAA,UACpF;AAAA,QACF;AAAA,QACA;AAAA,QACA;AAAA,QACA,KAAK,qBAAqB;AAAA,MAC5B;AAAA,IACF,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAsB,2BAA0C;AAC9D,UAAM,MAAM,2BAA2B;AACvC,UAAM,KAAK,kBAAkB,yBAAyB;AAAA,EACxD;AACF;AAQA,eAAsB,aAAa,QAAuC;AACxE,QAAM,UAAU,OAAO,IAAI;AAC3B,QAAM,WAAW,OAAO,SAAS;AACjC,QAAM,QAAQ,cAAc,QAAQ;AACpC,QAAM,QAAQ,aAAa,QAAQ;AACrC;AASA,eAAsB,0BAA0B,QAAwB,SAAgC;AACtG,MAAI,OAAO,OAAO;AAClB,aAAW,IAAI,MAAM,OAAO,CAAC;AAC7B,QAAM,OAAO,IAAI,QAAQ,cAAc,OAAO,SAAS,EAAE;AAC3D;",
  "names": []
}

@@ -8,6 +8,18 @@
8
8
  * `obsidian-test-mocks/src/internal/strict-proxy.ts`.
9
9
  */
10
10
  import type { PartialDeep } from 'type-fest';
11
+ /**
12
+ * Bypasses strict proxy to access the underlying object.
13
+ *
14
+ * If the object is wrapped in a strict proxy, returns the unwrapped target.
15
+ * Otherwise, returns the object as-is. This allows safely accessing
16
+ * optional properties without triggering the proxy's error on missing props.
17
+ *
18
+ * @typeParam T - The object type.
19
+ * @param obj - The object to bypass.
20
+ * @returns The unwrapped object.
21
+ */
22
+ export declare function bypassStrictProxy<T>(obj: T): T;
11
23
  /**
12
24
  * Creates a strictly-typed mock object from a partial implementation.
13
25
  * Uses a `Proxy` that throws a descriptive error when any unmocked
@@ -21,7 +21,7 @@ if you want to view the source, please visit the github repository of this plugi
21
21
  globalThis.process = browserProcess;
22
22
  })();
23
23
 
24
- const STRICT_PROXY_MARKER = /* @__PURE__ */ Symbol("strictProxy");
24
+ const STRICT_PROXY_TARGET_SYMBOL = /* @__PURE__ */ Symbol.for("strictProxyTarget");
25
25
  const PASSTHROUGH_PROPS = /* @__PURE__ */ new Set([
26
26
  Symbol.iterator,
27
27
  Symbol.toPrimitive,
@@ -29,6 +29,15 @@ const PASSTHROUGH_PROPS = /* @__PURE__ */ new Set([
29
29
  "then",
30
30
  "toJSON"
31
31
  ]);
32
+ function bypassStrictProxy(obj) {
33
+ if (!isObjectLike(obj)) {
34
+ return obj;
35
+ }
36
+ if (!(STRICT_PROXY_TARGET_SYMBOL in obj)) {
37
+ return obj;
38
+ }
39
+ return obj[STRICT_PROXY_TARGET_SYMBOL];
40
+ }
32
41
  function strictProxy(partial) {
33
42
  return wrapProxy(partial);
34
43
  }
@@ -42,10 +51,10 @@ function wrapProxy(value) {
42
51
  if (!isObjectLike(value)) {
43
52
  return value;
44
53
  }
45
- if (STRICT_PROXY_MARKER in value) {
54
+ if (STRICT_PROXY_TARGET_SYMBOL in value) {
46
55
  return value;
47
56
  }
48
- Object.defineProperty(value, STRICT_PROXY_MARKER, { value: true });
57
+ Object.defineProperty(value, STRICT_PROXY_TARGET_SYMBOL, { value });
49
58
  const proxiedChildren = /* @__PURE__ */ new Map();
50
59
  return new Proxy(value, {
51
60
  get(target, prop, receiver) {
@@ -69,6 +78,7 @@ function wrapProxy(value) {
69
78
  });
70
79
  }
71
80
  export {
81
+ bypassStrictProxy,
72
82
  strictProxy
73
83
  };
74
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3N0cmljdC1wcm94eS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAZmlsZVxuICpcbiAqIFN0cmljdGx5LXR5cGVkIG1vY2sgb2JqZWN0IGZhY3RvcnkgdmlhIGBQcm94eWAuIFRocm93cyBhIGRlc2NyaXB0aXZlIGVycm9yXG4gKiB3aGVuIGFueSB1bm1vY2tlZCBwcm9wZXJ0eSBpcyBhY2Nlc3NlZCwgcHJldmVudGluZyBzaWxlbnQgYHVuZGVmaW5lZGAgcmV0dXJucy5cbiAqXG4gKiBUaGUgcHJveHkgaW1wbGVtZW50YXRpb24gbWlycm9ycyB0aGUgZGVzaWduIG9mXG4gKiBgb2JzaWRpYW4tdGVzdC1tb2Nrcy9zcmMvaW50ZXJuYWwvc3RyaWN0LXByb3h5LnRzYC5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBhcnRpYWxEZWVwIH0gZnJvbSAndHlwZS1mZXN0JztcblxuY29uc3QgU1RSSUNUX1BST1hZX01BUktFUiA9IFN5bWJvbCgnc3RyaWN0UHJveHknKTtcblxuY29uc3QgUEFTU1RIUk9VR0hfUFJPUFMgPSBuZXcgU2V0PHN0cmluZyB8IHN5bWJvbD4oW1xuICBTeW1ib2wuaXRlcmF0b3IsXG4gIFN5bWJvbC50b1ByaW1pdGl2ZSxcbiAgU3ltYm9sLnRvU3RyaW5nVGFnLFxuICAndGhlbicsXG4gICd0b0pTT04nXG5dKTtcblxuLyoqXG4gKiBDcmVhdGVzIGEgc3RyaWN0bHktdHlwZWQgbW9jayBvYmplY3QgZnJvbSBhIHBhcnRpYWwgaW1wbGVtZW50YXRpb24uXG4gKiBVc2VzIGEgYFByb3h5YCB0aGF0IHRocm93cyBhIGRlc2NyaXB0aXZlIGVycm9yIHdoZW4gYW55IHVubW9ja2VkXG4gKiBwcm9wZXJ0eSBpcyBhY2Nlc3NlZCwgcHJldmVudGluZyBzaWxlbnQgYHVuZGVmaW5lZGAgcmV0dXJucy5cbiAqXG4gKiAtIElkZW1wb3RlbnQ6IGRvdWJsZS13cmFwcGluZyBpcyBhIG5vLW9wLlxuICogLSBQYXNzdGhyb3VnaCBmb3Igd2VsbC1rbm93biBwcm9wcyAoYHRoZW5gLCBgdG9KU09OYCwgYFN5bWJvbC5pdGVyYXRvcmAsIGV0Yy4pLlxuICogLSBSZWN1cnNpdmUgcHJveHlpbmcgb2YgbmVzdGVkIHBsYWluIG9iamVjdHMuXG4gKlxuICogQHBhcmFtIHBhcnRpYWwgLSBBIHBhcnRpYWwgb2JqZWN0IGNvbnRhaW5pbmcgb25seSB0aGUgbW9ja2VkIG1lbWJlcnMuXG4gKiBAcmV0dXJucyBBIHByb3h5IHR5cGVkIGFzIGBUYCB0aGF0IHRocm93cyBvbiB1bm1vY2tlZCBwcm9wZXJ0eSBhY2Nlc3MuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzdHJpY3RQcm94eTxUPihwYXJ0aWFsOiBQYXJ0aWFsRGVlcDxUPik6IFQge1xuICByZXR1cm4gd3JhcFByb3h5PFQ+KHBhcnRpYWwpO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiBhIHZhbHVlIGlzIGFuIG9iamVjdC1saWtlIHZhbHVlIChub3QgbnVsbCkuXG4gKlxuICogQHBhcmFtIHZhbHVlIC0gVGhlIHZhbHVlIHRvIGNoZWNrLlxuICogQHJldHVybnMgV2hldGhlciB0aGUgdmFsdWUgaXMgb2JqZWN0LWxpa2UuXG4gKi9cbmZ1bmN0aW9uIGlzT2JqZWN0TGlrZSh2YWx1ZTogdW5rbm93bik6IHZhbHVlIGlzIG9iamVjdCB7XG4gIHJldHVybiB2YWx1ZSAhPT0gbnVsbCAmJiB0eXBlb2YgdmFsdWUgPT09ICdvYmplY3QnO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiBhIHZhbHVlIGlzIGEgcGxhaW4gb2JqZWN0IChub3QgYSBjbGFzcyBpbnN0YW5jZSwgYXJyYXksIG51bGwsIGV0Yy4pLlxuICpcbiAqIEBwYXJhbSB2YWx1ZSAtIFRoZSB2YWx1ZSB0byBjaGVjay5cbiAqIEByZXR1cm5zIFdoZXRoZXIgdGhlIHZhbHVlIGlzIGEgcGxhaW4gb2JqZWN0LlxuICovXG5mdW5jdGlvbiBpc1BsYWluT2JqZWN0KHZhbHVlOiB1bmtub3duKTogdmFsdWUgaXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4ge1xuICByZXR1cm4gaXNPYmplY3RMaWtlKHZhbHVlKSAmJiBPYmplY3QuZ2V0UHJvdG90eXBlT2YodmFsdWUpID09PSBPYmplY3QucHJvdG90eXBlO1xufVxuXG4vKipcbiAqIFdyYXBzIGEgdmFsdWUgaW4gYSBzdHJpY3QgcHJveHkuIElkZW1wb3RlbnQgXHUyMDE0IGRvdWJsZS13cmFwcGluZyBpcyBhIG5vLW9wLlxuICpcbiAqIEBwYXJhbSB2YWx1ZSAtIFRoZSB2YWx1ZSB0byB3cmFwLlxuICogQHJldHVybnMgVGhlIHByb3hpZWQgdmFsdWUgdHlwZWQgYXMgYFRgLlxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVubmVjZXNzYXJ5LXR5cGUtcGFyYW1ldGVycyAtLSBUIHByb3ZpZGVzIHJldHVybiB0eXBlIGluZmVyZW5jZSBhdCBjYWxsIHNpdGVzLlxuZnVuY3Rpb24gd3JhcFByb3h5PFQ+KHZhbHVlOiB1bmtub3duKTogVCB7XG4gIGlmICghaXNPYmplY3RMaWtlKHZhbHVlKSkge1xuICAgIHJldHVybiB2YWx1ZSBhcyBUO1xuICB9XG5cbiAgaWYgKFNUUklDVF9QUk9YWV9NQVJLRVIgaW4gdmFsdWUpIHtcbiAgICByZXR1cm4gdmFsdWUgYXMgVDtcbiAgfVxuICBPYmplY3QuZGVmaW5lUHJvcGVydHkodmFsdWUsIFNUUklDVF9QUk9YWV9NQVJLRVIsIHsgdmFsdWU6IHRydWUgfSk7XG5cbiAgY29uc3QgcHJveGllZENoaWxkcmVuID0gbmV3IE1hcDxzdHJpbmcgfCBzeW1ib2w+KCk7XG5cbiAgcmV0dXJuIG5ldyBQcm94eSh2YWx1ZSwge1xuICAgIGdldCh0YXJnZXQsIHByb3AsIHJlY2VpdmVyKTogdW5rbm93biB7XG4gICAgICBpZiAocHJvcCBpbiB0YXJnZXQpIHtcbiAgICAgICAgaWYgKHByb3hpZWRDaGlsZHJlbi5oYXMocHJvcCkpIHtcbiAgICAgICAgICByZXR1cm4gcHJveGllZENoaWxkcmVuLmdldChwcm9wKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHZhbDogdW5rbm93biA9IFJlZmxlY3QuZ2V0KHRhcmdldCwgcHJvcCwgcmVjZWl2ZXIpO1xuICAgICAgICBpZiAoaXNQbGFpbk9iamVjdCh2YWwpKSB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gd3JhcFByb3h5PHVua25vd24+KHZhbCk7XG4gICAgICAgICAgcHJveGllZENoaWxkcmVuLnNldChwcm9wLCByZXN1bHQpO1xuICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHZhbDtcbiAgICAgIH1cblxuICAgICAgaWYgKHR5cGVvZiBwcm9wID09PSAnc3ltYm9sJyB8fCBQQVNTVEhST1VHSF9QUk9QUy5oYXMocHJvcCkpIHtcbiAgICAgICAgcmV0dXJuIFJlZmxlY3QuZ2V0KHRhcmdldCwgcHJvcCwgcmVjZWl2ZXIpO1xuICAgICAgfVxuXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVubW9ja2VkIHByb3BlcnR5IFwiJHtwcm9wfVwiIHdhcyBhY2Nlc3NlZCBvbiBtb2NrIG9iamVjdGApO1xuICAgIH1cbiAgfSkgYXMgVDtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBWUEsTUFBTSxzQkFBc0IsdUJBQU8sYUFBYTtBQUVoRCxNQUFNLG9CQUFvQixvQkFBSSxJQUFxQjtBQUFBLEVBQ2pELE9BQU87QUFBQSxFQUNQLE9BQU87QUFBQSxFQUNQLE9BQU87QUFBQSxFQUNQO0FBQUEsRUFDQTtBQUNGLENBQUM7QUFjTSxTQUFTLFlBQWUsU0FBNEI7QUFDekQsU0FBTyxVQUFhLE9BQU87QUFDN0I7QUFRQSxTQUFTLGFBQWEsT0FBaUM7QUFDckQsU0FBTyxVQUFVLFFBQVEsT0FBTyxVQUFVO0FBQzVDO0FBUUEsU0FBUyxjQUFjLE9BQWtEO0FBQ3ZFLFNBQU8sYUFBYSxLQUFLLEtBQUssT0FBTyxlQUFlLEtBQUssTUFBTSxPQUFPO0FBQ3hFO0FBU0EsU0FBUyxVQUFhLE9BQW1CO0FBQ3ZDLE1BQUksQ0FBQyxhQUFhLEtBQUssR0FBRztBQUN4QixXQUFPO0FBQUEsRUFDVDtBQUVBLE1BQUksdUJBQXVCLE9BQU87QUFDaEMsV0FBTztBQUFBLEVBQ1Q7QUFDQSxTQUFPLGVBQWUsT0FBTyxxQkFBcUIsRUFBRSxPQUFPLEtBQUssQ0FBQztBQUVqRSxRQUFNLGtCQUFrQixvQkFBSSxJQUFxQjtBQUVqRCxTQUFPLElBQUksTUFBTSxPQUFPO0FBQUEsSUFDdEIsSUFBSSxRQUFRLE1BQU0sVUFBbUI7QUFDbkMsVUFBSSxRQUFRLFFBQVE7QUFDbEIsWUFBSSxnQkFBZ0IsSUFBSSxJQUFJLEdBQUc7QUFDN0IsaUJBQU8sZ0JBQWdCLElBQUksSUFBSTtBQUFBLFFBQ2pDO0FBRUEsY0FBTSxNQUFlLFFBQVEsSUFBSSxRQUFRLE1BQU0sUUFBUTtBQUN2RCxZQUFJLGNBQWMsR0FBRyxHQUFHO0FBQ3RCLGdCQUFNLFNBQVMsVUFBbUIsR0FBRztBQUNyQywwQkFBZ0IsSUFBSSxNQUFNLE1BQU07QUFDaEMsaUJBQU87QUFBQSxRQUNUO0FBQ0EsZUFBTztBQUFBLE1BQ1Q7QUFFQSxVQUFJLE9BQU8sU0FBUyxZQUFZLGtCQUFrQixJQUFJLElBQUksR0FBRztBQUMzRCxlQUFPLFFBQVEsSUFBSSxRQUFRLE1BQU0sUUFBUTtBQUFBLE1BQzNDO0FBRUEsWUFBTSxJQUFJLE1BQU0sc0JBQXNCLElBQUksK0JBQStCO0FBQUEsSUFDM0U7QUFBQSxFQUNGLENBQUM7QUFDSDsiLAogICJuYW1lcyI6IFtdCn0K
84
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3N0cmljdC1wcm94eS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAZmlsZVxuICpcbiAqIFN0cmljdGx5LXR5cGVkIG1vY2sgb2JqZWN0IGZhY3RvcnkgdmlhIGBQcm94eWAuIFRocm93cyBhIGRlc2NyaXB0aXZlIGVycm9yXG4gKiB3aGVuIGFueSB1bm1vY2tlZCBwcm9wZXJ0eSBpcyBhY2Nlc3NlZCwgcHJldmVudGluZyBzaWxlbnQgYHVuZGVmaW5lZGAgcmV0dXJucy5cbiAqXG4gKiBUaGUgcHJveHkgaW1wbGVtZW50YXRpb24gbWlycm9ycyB0aGUgZGVzaWduIG9mXG4gKiBgb2JzaWRpYW4tdGVzdC1tb2Nrcy9zcmMvaW50ZXJuYWwvc3RyaWN0LXByb3h5LnRzYC5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBhcnRpYWxEZWVwIH0gZnJvbSAndHlwZS1mZXN0JztcblxuY29uc3QgU1RSSUNUX1BST1hZX1RBUkdFVF9TWU1CT0wgPSBTeW1ib2wuZm9yKCdzdHJpY3RQcm94eVRhcmdldCcpO1xuXG5jb25zdCBQQVNTVEhST1VHSF9QUk9QUyA9IG5ldyBTZXQ8c3RyaW5nIHwgc3ltYm9sPihbXG4gIFN5bWJvbC5pdGVyYXRvcixcbiAgU3ltYm9sLnRvUHJpbWl0aXZlLFxuICBTeW1ib2wudG9TdHJpbmdUYWcsXG4gICd0aGVuJyxcbiAgJ3RvSlNPTidcbl0pO1xuXG4vKipcbiAqIEJ5cGFzc2VzIHN0cmljdCBwcm94eSB0byBhY2Nlc3MgdGhlIHVuZGVybHlpbmcgb2JqZWN0LlxuICpcbiAqIElmIHRoZSBvYmplY3QgaXMgd3JhcHBlZCBpbiBhIHN0cmljdCBwcm94eSwgcmV0dXJucyB0aGUgdW53cmFwcGVkIHRhcmdldC5cbiAqIE90aGVyd2lzZSwgcmV0dXJucyB0aGUgb2JqZWN0IGFzLWlzLiBUaGlzIGFsbG93cyBzYWZlbHkgYWNjZXNzaW5nXG4gKiBvcHRpb25hbCBwcm9wZXJ0aWVzIHdpdGhvdXQgdHJpZ2dlcmluZyB0aGUgcHJveHkncyBlcnJvciBvbiBtaXNzaW5nIHByb3BzLlxuICpcbiAqIEB0eXBlUGFyYW0gVCAtIFRoZSBvYmplY3QgdHlwZS5cbiAqIEBwYXJhbSBvYmogLSBUaGUgb2JqZWN0IHRvIGJ5cGFzcy5cbiAqIEByZXR1cm5zIFRoZSB1bndyYXBwZWQgb2JqZWN0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gYnlwYXNzU3RyaWN0UHJveHk8VD4ob2JqOiBUKTogVCB7XG4gIGlmICghaXNPYmplY3RMaWtlKG9iaikpIHtcbiAgICByZXR1cm4gb2JqO1xuICB9XG4gIGlmICghKFNUUklDVF9QUk9YWV9UQVJHRVRfU1lNQk9MIGluIG9iaikpIHtcbiAgICByZXR1cm4gb2JqO1xuICB9XG4gIHJldHVybiBvYmpbU1RSSUNUX1BST1hZX1RBUkdFVF9TWU1CT0xdIGFzIFQ7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIHN0cmljdGx5LXR5cGVkIG1vY2sgb2JqZWN0IGZyb20gYSBwYXJ0aWFsIGltcGxlbWVudGF0aW9uLlxuICogVXNlcyBhIGBQcm94eWAgdGhhdCB0aHJvd3MgYSBkZXNjcmlwdGl2ZSBlcnJvciB3aGVuIGFueSB1bm1vY2tlZFxuICogcHJvcGVydHkgaXMgYWNjZXNzZWQsIHByZXZlbnRpbmcgc2lsZW50IGB1bmRlZmluZWRgIHJldHVybnMuXG4gKlxuICogLSBJZGVtcG90ZW50OiBkb3VibGUtd3JhcHBpbmcgaXMgYSBuby1vcC5cbiAqIC0gUGFzc3Rocm91Z2ggZm9yIHdlbGwta25vd24gcHJvcHMgKGB0aGVuYCwgYHRvSlNPTmAsIGBTeW1ib2wuaXRlcmF0b3JgLCBldGMuKS5cbiAqIC0gUmVjdXJzaXZlIHByb3h5aW5nIG9mIG5lc3RlZCBwbGFpbiBvYmplY3RzLlxuICpcbiAqIEBwYXJhbSBwYXJ0aWFsIC0gQSBwYXJ0aWFsIG9iamVjdCBjb250YWluaW5nIG9ubHkgdGhlIG1vY2tlZCBtZW1iZXJzLlxuICogQHJldHVybnMgQSBwcm94eSB0eXBlZCBhcyBgVGAgdGhhdCB0aHJvd3Mgb24gdW5tb2NrZWQgcHJvcGVydHkgYWNjZXNzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gc3RyaWN0UHJveHk8VD4ocGFydGlhbDogUGFydGlhbERlZXA8VD4pOiBUIHtcbiAgcmV0dXJuIHdyYXBQcm94eTxUPihwYXJ0aWFsKTtcbn1cblxuLyoqXG4gKiBDaGVja3MgaWYgYSB2YWx1ZSBpcyBhbiBvYmplY3QtbGlrZSB2YWx1ZSAobm90IG51bGwpLlxuICpcbiAqIEBwYXJhbSB2YWx1ZSAtIFRoZSB2YWx1ZSB0byBjaGVjay5cbiAqIEByZXR1cm5zIFdoZXRoZXIgdGhlIHZhbHVlIGlzIG9iamVjdC1saWtlLlxuICovXG5mdW5jdGlvbiBpc09iamVjdExpa2UodmFsdWU6IHVua25vd24pOiB2YWx1ZSBpcyBvYmplY3Qge1xuICByZXR1cm4gdmFsdWUgIT09IG51bGwgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0Jztcbn1cblxuLyoqXG4gKiBDaGVja3MgaWYgYSB2YWx1ZSBpcyBhIHBsYWluIG9iamVjdCAobm90IGEgY2xhc3MgaW5zdGFuY2UsIGFycmF5LCBudWxsLCBldGMuKS5cbiAqXG4gKiBAcGFyYW0gdmFsdWUgLSBUaGUgdmFsdWUgdG8gY2hlY2suXG4gKiBAcmV0dXJucyBXaGV0aGVyIHRoZSB2YWx1ZSBpcyBhIHBsYWluIG9iamVjdC5cbiAqL1xuZnVuY3Rpb24gaXNQbGFpbk9iamVjdCh2YWx1ZTogdW5rbm93bik6IHZhbHVlIGlzIFJlY29yZDxzdHJpbmcsIHVua25vd24+IHtcbiAgcmV0dXJuIGlzT2JqZWN0TGlrZSh2YWx1ZSkgJiYgT2JqZWN0LmdldFByb3RvdHlwZU9mKHZhbHVlKSA9PT0gT2JqZWN0LnByb3RvdHlwZTtcbn1cblxuLyoqXG4gKiBXcmFwcyBhIHZhbHVlIGluIGEgc3RyaWN0IHByb3h5LiBJZGVtcG90ZW50IFx1MjAxNCBkb3VibGUtd3JhcHBpbmcgaXMgYSBuby1vcC5cbiAqXG4gKiBAcGFyYW0gdmFsdWUgLSBUaGUgdmFsdWUgdG8gd3JhcC5cbiAqIEByZXR1cm5zIFRoZSBwcm94aWVkIHZhbHVlIHR5cGVkIGFzIGBUYC5cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bm5lY2Vzc2FyeS10eXBlLXBhcmFtZXRlcnMgLS0gVCBwcm92aWRlcyByZXR1cm4gdHlwZSBpbmZlcmVuY2UgYXQgY2FsbCBzaXRlcy5cbmZ1bmN0aW9uIHdyYXBQcm94eTxUPih2YWx1ZTogdW5rbm93bik6IFQge1xuICBpZiAoIWlzT2JqZWN0TGlrZSh2YWx1ZSkpIHtcbiAgICByZXR1cm4gdmFsdWUgYXMgVDtcbiAgfVxuXG4gIGlmIChTVFJJQ1RfUFJPWFlfVEFSR0VUX1NZTUJPTCBpbiB2YWx1ZSkge1xuICAgIHJldHVybiB2YWx1ZSBhcyBUO1xuICB9XG4gIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh2YWx1ZSwgU1RSSUNUX1BST1hZX1RBUkdFVF9TWU1CT0wsIHsgdmFsdWUgfSk7XG5cbiAgY29uc3QgcHJveGllZENoaWxkcmVuID0gbmV3IE1hcDxzdHJpbmcgfCBzeW1ib2w+KCk7XG5cbiAgcmV0dXJuIG5ldyBQcm94eSh2YWx1ZSwge1xuICAgIGdldCh0YXJnZXQsIHByb3AsIHJlY2VpdmVyKTogdW5rbm93biB7XG4gICAgICBpZiAocHJvcCBpbiB0YXJnZXQpIHtcbiAgICAgICAgaWYgKHByb3hpZWRDaGlsZHJlbi5oYXMocHJvcCkpIHtcbiAgICAgICAgICByZXR1cm4gcHJveGllZENoaWxkcmVuLmdldChwcm9wKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHZhbDogdW5rbm93biA9IFJlZmxlY3QuZ2V0KHRhcmdldCwgcHJvcCwgcmVjZWl2ZXIpO1xuICAgICAgICBpZiAoaXNQbGFpbk9iamVjdCh2YWwpKSB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gd3JhcFByb3h5PHVua25vd24+KHZhbCk7XG4gICAgICAgICAgcHJveGllZENoaWxkcmVuLnNldChwcm9wLCByZXN1bHQpO1xuICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHZhbDtcbiAgICAgIH1cblxuICAgICAgaWYgKHR5cGVvZiBwcm9wID09PSAnc3ltYm9sJyB8fCBQQVNTVEhST1VHSF9QUk9QUy5oYXMocHJvcCkpIHtcbiAgICAgICAgcmV0dXJuIFJlZmxlY3QuZ2V0KHRhcmdldCwgcHJvcCwgcmVjZWl2ZXIpO1xuICAgICAgfVxuXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVubW9ja2VkIHByb3BlcnR5IFwiJHtwcm9wfVwiIHdhcyBhY2Nlc3NlZCBvbiBtb2NrIG9iamVjdGApO1xuICAgIH1cbiAgfSkgYXMgVDtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBWUEsTUFBTSw2QkFBNkIsdUJBQU8sSUFBSSxtQkFBbUI7QUFFakUsTUFBTSxvQkFBb0Isb0JBQUksSUFBcUI7QUFBQSxFQUNqRCxPQUFPO0FBQUEsRUFDUCxPQUFPO0FBQUEsRUFDUCxPQUFPO0FBQUEsRUFDUDtBQUFBLEVBQ0E7QUFDRixDQUFDO0FBYU0sU0FBUyxrQkFBcUIsS0FBVztBQUM5QyxNQUFJLENBQUMsYUFBYSxHQUFHLEdBQUc7QUFDdEIsV0FBTztBQUFBLEVBQ1Q7QUFDQSxNQUFJLEVBQUUsOEJBQThCLE1BQU07QUFDeEMsV0FBTztBQUFBLEVBQ1Q7QUFDQSxTQUFPLElBQUksMEJBQTBCO0FBQ3ZDO0FBY08sU0FBUyxZQUFlLFNBQTRCO0FBQ3pELFNBQU8sVUFBYSxPQUFPO0FBQzdCO0FBUUEsU0FBUyxhQUFhLE9BQWlDO0FBQ3JELFNBQU8sVUFBVSxRQUFRLE9BQU8sVUFBVTtBQUM1QztBQVFBLFNBQVMsY0FBYyxPQUFrRDtBQUN2RSxTQUFPLGFBQWEsS0FBSyxLQUFLLE9BQU8sZUFBZSxLQUFLLE1BQU0sT0FBTztBQUN4RTtBQVNBLFNBQVMsVUFBYSxPQUFtQjtBQUN2QyxNQUFJLENBQUMsYUFBYSxLQUFLLEdBQUc7QUFDeEIsV0FBTztBQUFBLEVBQ1Q7QUFFQSxNQUFJLDhCQUE4QixPQUFPO0FBQ3ZDLFdBQU87QUFBQSxFQUNUO0FBQ0EsU0FBTyxlQUFlLE9BQU8sNEJBQTRCLEVBQUUsTUFBTSxDQUFDO0FBRWxFLFFBQU0sa0JBQWtCLG9CQUFJLElBQXFCO0FBRWpELFNBQU8sSUFBSSxNQUFNLE9BQU87QUFBQSxJQUN0QixJQUFJLFFBQVEsTUFBTSxVQUFtQjtBQUNuQyxVQUFJLFFBQVEsUUFBUTtBQUNsQixZQUFJLGdCQUFnQixJQUFJLElBQUksR0FBRztBQUM3QixpQkFBTyxnQkFBZ0IsSUFBSSxJQUFJO0FBQUEsUUFDakM7QUFFQSxjQUFNLE1BQWUsUUFBUSxJQUFJLFFBQVEsTUFBTSxRQUFRO0FBQ3ZELFlBQUksY0FBYyxHQUFHLEdBQUc7QUFDdEIsZ0JBQU0sU0FBUyxVQUFtQixHQUFHO0FBQ3JDLDBCQUFnQixJQUFJLE1BQU0sTUFBTTtBQUNoQyxpQkFBTztBQUFBLFFBQ1Q7QUFDQSxlQUFPO0FBQUEsTUFDVDtBQUVBLFVBQUksT0FBTyxTQUFTLFlBQVksa0JBQWtCLElBQUksSUFBSSxHQUFHO0FBQzNELGVBQU8sUUFBUSxJQUFJLFFBQVEsTUFBTSxRQUFRO0FBQUEsTUFDM0M7QUFFQSxZQUFNLElBQUksTUFBTSxzQkFBc0IsSUFBSSwrQkFBK0I7QUFBQSxJQUMzRTtBQUFBLEVBQ0YsQ0FBQztBQUNIOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,6 +1,6 @@
1
1
  {
2
- "main": "../../../../dist/lib/cjs/obsidian/plugin/components/lifecycle-events-component.cjs",
3
- "module": "../../../../dist/lib/esm/obsidian/plugin/components/lifecycle-events-component.mjs",
2
+ "main": "../../../../dist/lib/cjs/obsidian/plugin/components/layout-ready-component.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/plugin/components/layout-ready-component.mjs",
4
4
  "type": "module",
5
- "types": "../../../../dist/lib/cjs/obsidian/plugin/components/lifecycle-events-component.d.cts"
5
+ "types": "../../../../dist/lib/cjs/obsidian/plugin/components/layout-ready-component.d.cts"
6
6
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "obsidian-dev-utils",
3
- "version": "57.0.2",
3
+ "version": "58.0.0",
4
4
  "description": "This is the collection of useful functions that you can use for your Obsidian plugin development",
5
5
  "keywords": [
6
6
  "obsidian"
@@ -717,7 +717,7 @@
717
717
  "monkey-around": "latest",
718
718
  "npm-run-all2": "latest",
719
719
  "obsidian": "latest",
720
- "obsidian-integration-testing": "latest",
720
+ "obsidian-integration-testing": "^1.2.0",
721
721
  "obsidian-typings": "obsidian-public-latest",
722
722
  "path-browserify": "latest",
723
723
  "postcss": "latest",
@@ -753,7 +753,7 @@
753
753
  "jsdom": "latest",
754
754
  "moment": "latest",
755
755
  "nano-staged": "latest",
756
- "obsidian-test-mocks": "latest",
756
+ "obsidian-test-mocks": "^1.1.1",
757
757
  "patch-package": "latest",
758
758
  "vitest": "latest",
759
759
  "yaml": "latest"
@@ -1,211 +0,0 @@
1
- /*
2
- THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
- if you want to view the source, please visit the github repository of this plugin
4
- */
5
-
6
- (function initCjs() {
7
- // eslint-disable-next-line obsidianmd/no-global-this -- Actively use globalThis.
8
- const globalThisRecord = globalThis;
9
- globalThisRecord['__name'] ??= name;
10
- const originalRequire = require;
11
- if (originalRequire && !originalRequire.__isPatched) {
12
- // eslint-disable-next-line no-global-assign, no-implicit-globals -- We need to patch the `require()` function.
13
- require = Object.assign(
14
- (id) => requirePatched(id),
15
- originalRequire,
16
- {
17
- __isPatched: true
18
- }
19
- );
20
- }
21
-
22
- const newFuncs = {
23
- __extractDefault() {
24
- return extractDefault;
25
- },
26
- process() {
27
- const browserProcess = {
28
- browser: true,
29
- cwd() {
30
- return '/';
31
- },
32
- env: {},
33
- platform: 'android'
34
- };
35
- return browserProcess;
36
- }
37
- };
38
-
39
- for (const key of Object.keys(newFuncs)) {
40
- globalThisRecord[key] ??= newFuncs[key]?.();
41
- }
42
-
43
- function name(obj) {
44
- return obj;
45
- }
46
-
47
- function extractDefault(module) {
48
- return module && module.__esModule && 'default' in module ? module.default : module;
49
- }
50
-
51
- const OBSIDIAN_BUILT_IN_MODULE_NAMES = [
52
- 'obsidian',
53
- '@codemirror/autocomplete',
54
- '@codemirror/collab',
55
- '@codemirror/commands',
56
- '@codemirror/language',
57
- '@codemirror/lint',
58
- '@codemirror/search',
59
- '@codemirror/state',
60
- '@codemirror/text',
61
- '@codemirror/view',
62
- '@lezer/common',
63
- '@lezer/lr',
64
- '@lezer/highlight'];
65
-
66
-
67
- const DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES = [
68
- '@codemirror/closebrackets',
69
- '@codemirror/comment',
70
- '@codemirror/fold',
71
- '@codemirror/gutter',
72
- '@codemirror/highlight',
73
- '@codemirror/history',
74
- '@codemirror/matchbrackets',
75
- '@codemirror/panel',
76
- '@codemirror/rangeset',
77
- '@codemirror/rectangular-selection',
78
- '@codemirror/stream-parser',
79
- '@codemirror/tooltip'];
80
-
81
-
82
- function requirePatched(id) {
83
- if (OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id) || DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id)) {
84
- return originalRequire?.(id);
85
- }
86
-
87
- // eslint-disable-next-line @typescript-eslint/no-deprecated, obsidianmd/no-global-this -- Need access to app. Actively use globalThis.
88
- if (globalThis.app.isMobile) {
89
- if (id === 'process' || id === 'node:process') {
90
- // eslint-disable-next-line no-console -- Valid usage.
91
- console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Fake process object is returned instead.`);
92
- // eslint-disable-next-line obsidianmd/no-global-this -- Actively use globalThis.
93
- return globalThis.process;
94
- }
95
- } else {
96
- const module = originalRequire?.(id);
97
- if (module) {
98
- return extractDefault(module);
99
- }
100
- }
101
-
102
- // eslint-disable-next-line no-console -- Valid usage.
103
- console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Empty object is returned instead.`);
104
- return {};
105
- }
106
- })();
107
-
108
- "use strict";
109
- var __defProp = Object.defineProperty;
110
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
111
- var __getOwnPropNames = Object.getOwnPropertyNames;
112
- var __hasOwnProp = Object.prototype.hasOwnProperty;
113
- var __export = (target, all) => {
114
- for (var name in all)
115
- __defProp(target, name, { get: all[name], enumerable: true });
116
- };
117
- var __copyProps = (to, from, except, desc) => {
118
- if (from && typeof from === "object" || typeof from === "function") {
119
- for (let key of __getOwnPropNames(from))
120
- if (!__hasOwnProp.call(to, key) && key !== except)
121
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
122
- }
123
- return to;
124
- };
125
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
126
- var lifecycle_events_component_exports = {};
127
- __export(lifecycle_events_component_exports, {
128
- LifecycleEventsComponent: () => LifecycleEventsComponent
129
- });
130
- module.exports = __toCommonJS(lifecycle_events_component_exports);
131
- var import_async_events = require('../../../async-events.cjs');
132
- var import_async = require('../../../async.cjs');
133
- var import_async_component = require('../../components/async-component.cjs');
134
- class LifecycleEventsComponent extends import_async_component.AsyncComponentBase {
135
- /**
136
- * Creates a new lifecycle events component.
137
- *
138
- * @param app - The Obsidian app instance.
139
- */
140
- constructor(app) {
141
- super();
142
- this.app = app;
143
- }
144
- app;
145
- /**
146
- * The singleton key for the {@link LifecycleEventsComponent} class.
147
- */
148
- static COMPONENT_KEY = Symbol(LifecycleEventsComponent.name);
149
- /**
150
- * The async events instance.
151
- */
152
- events = new import_async_events.AsyncEvents();
153
- triggeredEvents = /* @__PURE__ */ new Set();
154
- /**
155
- * Triggers load and registers layoutReady callback.
156
- */
157
- async onload() {
158
- await this.triggerLifecycleEvent("load");
159
- this.app.workspace.onLayoutReady((0, import_async.convertAsyncToSync)(async () => {
160
- await this.triggerLifecycleEvent("layoutReady");
161
- }));
162
- }
163
- /**
164
- * Triggers the unload lifecycle event.
165
- */
166
- onunload() {
167
- (0, import_async.invokeAsyncSafely)(async () => {
168
- await this.triggerLifecycleEvent("unload");
169
- });
170
- }
171
- /**
172
- * Registers a callback to be executed when a lifecycle event is triggered.
173
- *
174
- * @param name - The name of the event.
175
- * @param callback - The callback to execute.
176
- */
177
- async registerForLifecycleEvent(name, callback) {
178
- await this.waitForLifecycleEvent(name);
179
- await callback();
180
- }
181
- /**
182
- * Triggers a lifecycle event.
183
- *
184
- * @param name - The name of the lifecycle event to trigger.
185
- */
186
- async triggerLifecycleEvent(name) {
187
- this.triggeredEvents.add(name);
188
- await this.events.triggerAsync(name);
189
- }
190
- /**
191
- * Waits for a lifecycle event to be triggered.
192
- *
193
- * @param name - The name of the event.
194
- * @returns A {@link Promise} that resolves when the event is triggered.
195
- */
196
- async waitForLifecycleEvent(name) {
197
- if (this.triggeredEvents.has(name)) {
198
- return;
199
- }
200
- await new Promise((resolve) => {
201
- this.events.once(name, () => {
202
- resolve();
203
- });
204
- });
205
- }
206
- }
207
- // Annotate the CommonJS export names for ESM import in node:
208
- 0 && (module.exports = {
209
- LifecycleEventsComponent
210
- });
211
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9jb21wb25lbnRzL2xpZmVjeWNsZS1ldmVudHMtY29tcG9uZW50LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBmaWxlXG4gKlxuICogQ29tcG9uZW50IHRoYXQgbWFuYWdlcyBwbHVnaW4gbGlmZWN5Y2xlIGV2ZW50cyAobG9hZCwgbGF5b3V0UmVhZHksIHVubG9hZCkuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBBcHAgfSBmcm9tICdvYnNpZGlhbic7XG5cbmltcG9ydCB7IEFzeW5jRXZlbnRzIH0gZnJvbSAnLi4vLi4vLi4vYXN5bmMtZXZlbnRzLnRzJztcbmltcG9ydCB7XG4gIGNvbnZlcnRBc3luY1RvU3luYyxcbiAgaW52b2tlQXN5bmNTYWZlbHlcbn0gZnJvbSAnLi4vLi4vLi4vYXN5bmMudHMnO1xuaW1wb3J0IHsgQXN5bmNDb21wb25lbnRCYXNlIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9hc3luYy1jb21wb25lbnQudHMnO1xuXG4vKipcbiAqIFRoZSBuYW1lIG9mIGEgbGlmZWN5Y2xlIGV2ZW50LlxuICovXG5leHBvcnQgdHlwZSBMaWZlY3ljbGVFdmVudE5hbWUgPSAnbGF5b3V0UmVhZHknIHwgJ2xvYWQnIHwgJ3VubG9hZCc7XG5cbi8qKlxuICogTWFuYWdlcyBwbHVnaW4gbGlmZWN5Y2xlIGV2ZW50czogYGxvYWRgLCBgbGF5b3V0UmVhZHlgLCBhbmQgYHVubG9hZGAuXG4gKlxuICogQ29tcG9uZW50cyBjYW4gd2FpdCBmb3Igb3IgcmVnaXN0ZXIgY2FsbGJhY2tzIGZvciB0aGVzZSBldmVudHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBMaWZlY3ljbGVFdmVudHNDb21wb25lbnQgZXh0ZW5kcyBBc3luY0NvbXBvbmVudEJhc2Uge1xuICAvKipcbiAgICogVGhlIHNpbmdsZXRvbiBrZXkgZm9yIHRoZSB7QGxpbmsgTGlmZWN5Y2xlRXZlbnRzQ29tcG9uZW50fSBjbGFzcy5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgQ09NUE9ORU5UX0tFWSA9IFN5bWJvbChMaWZlY3ljbGVFdmVudHNDb21wb25lbnQubmFtZSk7XG5cbiAgLyoqXG4gICAqIFRoZSBhc3luYyBldmVudHMgaW5zdGFuY2UuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZXZlbnRzID0gbmV3IEFzeW5jRXZlbnRzKCk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSB0cmlnZ2VyZWRFdmVudHMgPSBuZXcgU2V0PExpZmVjeWNsZUV2ZW50TmFtZT4oKTtcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBsaWZlY3ljbGUgZXZlbnRzIGNvbXBvbmVudC5cbiAgICpcbiAgICogQHBhcmFtIGFwcCAtIFRoZSBPYnNpZGlhbiBhcHAgaW5zdGFuY2UuXG4gICAqL1xuICBwdWJsaWMgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBhcHA6IEFwcCkge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICAvKipcbiAgICogVHJpZ2dlcnMgbG9hZCBhbmQgcmVnaXN0ZXJzIGxheW91dFJlYWR5IGNhbGxiYWNrLlxuICAgKi9cbiAgcHVibGljIG92ZXJyaWRlIGFzeW5jIG9ubG9hZCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCB0aGlzLnRyaWdnZXJMaWZlY3ljbGVFdmVudCgnbG9hZCcpO1xuICAgIHRoaXMuYXBwLndvcmtzcGFjZS5vbkxheW91dFJlYWR5KGNvbnZlcnRBc3luY1RvU3luYyhhc3luYyAoKSA9PiB7XG4gICAgICBhd2FpdCB0aGlzLnRyaWdnZXJMaWZlY3ljbGVFdmVudCgnbGF5b3V0UmVhZHknKTtcbiAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogVHJpZ2dlcnMgdGhlIHVubG9hZCBsaWZlY3ljbGUgZXZlbnQuXG4gICAqL1xuICBwdWJsaWMgb3ZlcnJpZGUgb251bmxvYWQoKTogdm9pZCB7XG4gICAgaW52b2tlQXN5bmNTYWZlbHkoYXN5bmMgKCkgPT4ge1xuICAgICAgYXdhaXQgdGhpcy50cmlnZ2VyTGlmZWN5Y2xlRXZlbnQoJ3VubG9hZCcpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlZ2lzdGVycyBhIGNhbGxiYWNrIHRvIGJlIGV4ZWN1dGVkIHdoZW4gYSBsaWZlY3ljbGUgZXZlbnQgaXMgdHJpZ2dlcmVkLlxuICAgKlxuICAgKiBAcGFyYW0gbmFtZSAtIFRoZSBuYW1lIG9mIHRoZSBldmVudC5cbiAgICogQHBhcmFtIGNhbGxiYWNrIC0gVGhlIGNhbGxiYWNrIHRvIGV4ZWN1dGUuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgcmVnaXN0ZXJGb3JMaWZlY3ljbGVFdmVudChuYW1lOiBMaWZlY3ljbGVFdmVudE5hbWUsIGNhbGxiYWNrOiAoKSA9PiBQcm9taXNlPHZvaWQ+KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgdGhpcy53YWl0Rm9yTGlmZWN5Y2xlRXZlbnQobmFtZSk7XG4gICAgYXdhaXQgY2FsbGJhY2soKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUcmlnZ2VycyBhIGxpZmVjeWNsZSBldmVudC5cbiAgICpcbiAgICogQHBhcmFtIG5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgbGlmZWN5Y2xlIGV2ZW50IHRvIHRyaWdnZXIuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgdHJpZ2dlckxpZmVjeWNsZUV2ZW50KG5hbWU6IExpZmVjeWNsZUV2ZW50TmFtZSk6IFByb21pc2U8dm9pZD4ge1xuICAgIHRoaXMudHJpZ2dlcmVkRXZlbnRzLmFkZChuYW1lKTtcbiAgICBhd2FpdCB0aGlzLmV2ZW50cy50cmlnZ2VyQXN5bmMobmFtZSk7XG4gIH1cblxuICAvKipcbiAgICogV2FpdHMgZm9yIGEgbGlmZWN5Y2xlIGV2ZW50IHRvIGJlIHRyaWdnZXJlZC5cbiAgICpcbiAgICogQHBhcmFtIG5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgZXZlbnQuXG4gICAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgZXZlbnQgaXMgdHJpZ2dlcmVkLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIHdhaXRGb3JMaWZlY3ljbGVFdmVudChuYW1lOiBMaWZlY3ljbGVFdmVudE5hbWUpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAodGhpcy50cmlnZ2VyZWRFdmVudHMuaGFzKG5hbWUpKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgYXdhaXQgbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUpID0+IHtcbiAgICAgIHRoaXMuZXZlbnRzLm9uY2UobmFtZSwgKCkgPT4ge1xuICAgICAgICByZXNvbHZlKCk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBUUEsMEJBQTRCO0FBQzVCLG1CQUdPO0FBQ1AsNkJBQW1DO0FBWTVCLE1BQU0saUNBQWlDLDBDQUFtQjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQWtCeEQsWUFBNkIsS0FBVTtBQUM1QyxVQUFNO0FBRDRCO0FBQUEsRUFFcEM7QUFBQSxFQUZvQztBQUFBO0FBQUE7QUFBQTtBQUFBLEVBZHBDLE9BQXVCLGdCQUFnQixPQUFPLHlCQUF5QixJQUFJO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFLM0QsU0FBUyxJQUFJLGdDQUFZO0FBQUEsRUFFeEIsa0JBQWtCLG9CQUFJLElBQXdCO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFjL0QsTUFBc0IsU0FBd0I7QUFDNUMsVUFBTSxLQUFLLHNCQUFzQixNQUFNO0FBQ3ZDLFNBQUssSUFBSSxVQUFVLGtCQUFjLGlDQUFtQixZQUFZO0FBQzlELFlBQU0sS0FBSyxzQkFBc0IsYUFBYTtBQUFBLElBQ2hELENBQUMsQ0FBQztBQUFBLEVBQ0o7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQUtnQixXQUFpQjtBQUMvQix3Q0FBa0IsWUFBWTtBQUM1QixZQUFNLEtBQUssc0JBQXNCLFFBQVE7QUFBQSxJQUMzQyxDQUFDO0FBQUEsRUFDSDtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBUUEsTUFBYSwwQkFBMEIsTUFBMEIsVUFBOEM7QUFDN0csVUFBTSxLQUFLLHNCQUFzQixJQUFJO0FBQ3JDLFVBQU0sU0FBUztBQUFBLEVBQ2pCO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBT0EsTUFBYSxzQkFBc0IsTUFBeUM7QUFDMUUsU0FBSyxnQkFBZ0IsSUFBSSxJQUFJO0FBQzdCLFVBQU0sS0FBSyxPQUFPLGFBQWEsSUFBSTtBQUFBLEVBQ3JDO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFRQSxNQUFhLHNCQUFzQixNQUF5QztBQUMxRSxRQUFJLEtBQUssZ0JBQWdCLElBQUksSUFBSSxHQUFHO0FBQ2xDO0FBQUEsSUFDRjtBQUVBLFVBQU0sSUFBSSxRQUFjLENBQUMsWUFBWTtBQUNuQyxXQUFLLE9BQU8sS0FBSyxNQUFNLE1BQU07QUFDM0IsZ0JBQVE7QUFBQSxNQUNWLENBQUM7QUFBQSxJQUNILENBQUM7QUFBQSxFQUNIO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -1,63 +0,0 @@
1
- /**
2
- * @file
3
- *
4
- * Component that manages plugin lifecycle events (load, layoutReady, unload).
5
- */
6
- import type { App } from 'obsidian';
7
- import { AsyncEvents } from '../../../async-events.cjs';
8
- import { AsyncComponentBase } from '../../components/async-component.cjs';
9
- /**
10
- * The name of a lifecycle event.
11
- */
12
- export type LifecycleEventName = 'layoutReady' | 'load' | 'unload';
13
- /**
14
- * Manages plugin lifecycle events: `load`, `layoutReady`, and `unload`.
15
- *
16
- * Components can wait for or register callbacks for these events.
17
- */
18
- export declare class LifecycleEventsComponent extends AsyncComponentBase {
19
- private readonly app;
20
- /**
21
- * The singleton key for the {@link LifecycleEventsComponent} class.
22
- */
23
- static readonly COMPONENT_KEY: unique symbol;
24
- /**
25
- * The async events instance.
26
- */
27
- readonly events: AsyncEvents;
28
- private readonly triggeredEvents;
29
- /**
30
- * Creates a new lifecycle events component.
31
- *
32
- * @param app - The Obsidian app instance.
33
- */
34
- constructor(app: App);
35
- /**
36
- * Triggers load and registers layoutReady callback.
37
- */
38
- onload(): Promise<void>;
39
- /**
40
- * Triggers the unload lifecycle event.
41
- */
42
- onunload(): void;
43
- /**
44
- * Registers a callback to be executed when a lifecycle event is triggered.
45
- *
46
- * @param name - The name of the event.
47
- * @param callback - The callback to execute.
48
- */
49
- registerForLifecycleEvent(name: LifecycleEventName, callback: () => Promise<void>): Promise<void>;
50
- /**
51
- * Triggers a lifecycle event.
52
- *
53
- * @param name - The name of the lifecycle event to trigger.
54
- */
55
- triggerLifecycleEvent(name: LifecycleEventName): Promise<void>;
56
- /**
57
- * Waits for a lifecycle event to be triggered.
58
- *
59
- * @param name - The name of the event.
60
- * @returns A {@link Promise} that resolves when the event is triggered.
61
- */
62
- waitForLifecycleEvent(name: LifecycleEventName): Promise<void>;
63
- }