obsidian-dev-utils 58.0.1 → 59.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.
- package/CHANGELOG.md +4 -0
- package/dist/lib/cjs/library.cjs +1 -1
- package/dist/lib/cjs/obsidian/command-handlers/command-handler-component.cjs +9 -10
- package/dist/lib/cjs/obsidian/command-handlers/command-handler-component.d.cts +8 -4
- package/dist/lib/cjs/obsidian/command-handlers/open-settings-command-handler.cjs +7 -8
- package/dist/lib/cjs/obsidian/command-handlers/open-settings-command-handler.d.cts +8 -4
- package/dist/lib/cjs/obsidian/components/setting-components/checkbox-component.cjs +2 -2
- package/dist/lib/cjs/obsidian/markdown.cjs +21 -13
- package/dist/lib/cjs/obsidian/modals/alert.cjs +11 -14
- package/dist/lib/cjs/obsidian/modals/alert.d.cts +3 -11
- package/dist/lib/cjs/obsidian/modals/confirm.cjs +14 -16
- package/dist/lib/cjs/obsidian/modals/modal.cjs +13 -9
- package/dist/lib/cjs/obsidian/modals/modal.d.cts +15 -8
- package/dist/lib/cjs/obsidian/modals/prompt.cjs +17 -18
- package/dist/lib/cjs/obsidian/plugin/components/plugin-context-component.cjs +11 -12
- package/dist/lib/cjs/obsidian/plugin/components/plugin-context-component.d.cts +9 -5
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-component.cjs +1 -1
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-component.d.cts +3 -3
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-tab-component.cjs +17 -10
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-tab-component.d.cts +8 -4
- package/dist/lib/cjs/obsidian/plugin/plugin-context.cjs +9 -3
- package/dist/lib/cjs/obsidian/plugin/plugin-context.d.cts +1 -1
- package/dist/lib/cjs/obsidian/plugin/plugin-settings-tab.cjs +2 -2
- package/dist/lib/cjs/obsidian/plugin/plugin.cjs +2 -2
- package/dist/lib/esm/library.mjs +1 -1
- package/dist/lib/esm/obsidian/command-handlers/command-handler-component.d.mts +8 -4
- package/dist/lib/esm/obsidian/command-handlers/command-handler-component.mjs +9 -10
- package/dist/lib/esm/obsidian/command-handlers/open-settings-command-handler.d.mts +8 -4
- package/dist/lib/esm/obsidian/command-handlers/open-settings-command-handler.mjs +7 -8
- package/dist/lib/esm/obsidian/components/setting-components/checkbox-component.mjs +2 -2
- package/dist/lib/esm/obsidian/markdown.mjs +21 -13
- package/dist/lib/esm/obsidian/modals/alert.d.mts +3 -11
- package/dist/lib/esm/obsidian/modals/alert.mjs +12 -14
- package/dist/lib/esm/obsidian/modals/confirm.mjs +15 -16
- package/dist/lib/esm/obsidian/modals/modal.d.mts +15 -8
- package/dist/lib/esm/obsidian/modals/modal.mjs +12 -9
- package/dist/lib/esm/obsidian/modals/prompt.mjs +18 -18
- package/dist/lib/esm/obsidian/plugin/components/plugin-context-component.d.mts +9 -5
- package/dist/lib/esm/obsidian/plugin/components/plugin-context-component.mjs +11 -12
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-component.d.mts +3 -3
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-component.mjs +1 -1
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-tab-component.d.mts +8 -4
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-tab-component.mjs +17 -10
- package/dist/lib/esm/obsidian/plugin/plugin-context.d.mts +1 -1
- package/dist/lib/esm/obsidian/plugin/plugin-context.mjs +9 -3
- package/dist/lib/esm/obsidian/plugin/plugin-settings-tab.mjs +2 -2
- package/dist/lib/esm/obsidian/plugin/plugin.mjs +2 -2
- package/package.json +1 -1
|
@@ -13,30 +13,37 @@ export interface ModalParamsBase {
|
|
|
13
13
|
/**
|
|
14
14
|
* An Obsidian app instance.
|
|
15
15
|
*/
|
|
16
|
-
app: App;
|
|
16
|
+
readonly app: App;
|
|
17
17
|
/**
|
|
18
18
|
* A CSS class to apply to the modal.
|
|
19
19
|
*/
|
|
20
|
-
|
|
20
|
+
readonly cssClasses?: string[];
|
|
21
21
|
}
|
|
22
22
|
/**
|
|
23
23
|
* A base class for displaying modals in Obsidian.
|
|
24
24
|
*/
|
|
25
|
-
export declare abstract class ModalBase<Value
|
|
26
|
-
protected resolve: PromiseResolve<Value>;
|
|
25
|
+
export declare abstract class ModalBase<Value> extends Modal {
|
|
26
|
+
protected readonly resolve: PromiseResolve<Value>;
|
|
27
27
|
/**
|
|
28
28
|
* Creates a new modal.
|
|
29
29
|
*
|
|
30
|
-
* @param
|
|
30
|
+
* @param params - The options.
|
|
31
31
|
* @param resolve - The resolve function.
|
|
32
|
-
* @param modalCssClass - The modal CSS class.
|
|
33
32
|
*/
|
|
34
|
-
constructor(
|
|
33
|
+
constructor(params: ModalParamsBase, resolve: PromiseResolve<Value>);
|
|
35
34
|
}
|
|
35
|
+
/**
|
|
36
|
+
* Adds a CSS class to the modal parameters.
|
|
37
|
+
*
|
|
38
|
+
* @param params - The modal parameters.
|
|
39
|
+
* @param cssClass - The CSS class to add.
|
|
40
|
+
* @returns The modal parameters with the CSS class added.
|
|
41
|
+
*/
|
|
42
|
+
export declare function addCssClass(params: ModalParamsBase, cssClass: string): ModalParamsBase;
|
|
36
43
|
/**
|
|
37
44
|
* Displays a modal in Obsidian.
|
|
38
45
|
*
|
|
39
46
|
* @param modalCreator - A function that creates a modal.
|
|
40
47
|
* @returns A {@link Promise} that resolves when the modal is closed.
|
|
41
48
|
*/
|
|
42
|
-
export declare function showModal<
|
|
49
|
+
export declare function showModal<Value>(modalCreator: (resolve: PromiseResolve<Value>) => Modal): Promise<Value>;
|
|
@@ -135,21 +135,20 @@ var import_function = require('../../function.cjs');
|
|
|
135
135
|
var import_i18n = require('../i18n/i18n.cjs');
|
|
136
136
|
var import_modal = require('./modal.cjs');
|
|
137
137
|
class PromptModal extends import_modal.ModalBase {
|
|
138
|
+
cancelButtonText;
|
|
138
139
|
isOkClicked = false;
|
|
139
|
-
|
|
140
|
+
okButtonText;
|
|
141
|
+
placeholder;
|
|
142
|
+
title;
|
|
140
143
|
value;
|
|
144
|
+
valueValidator;
|
|
141
145
|
constructor(params, resolve) {
|
|
142
|
-
super(
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
placeholder: "",
|
|
149
|
-
title: "",
|
|
150
|
-
valueValidator: import_function.noop
|
|
151
|
-
};
|
|
152
|
-
this.params = { ...DEFAULT_OPTIONS, ...params };
|
|
146
|
+
super((0, import_modal.addCssClass)(params, import_css_class.CssClass.PromptModal), resolve);
|
|
147
|
+
this.cancelButtonText = params.cancelButtonText ?? (0, import_i18n.t)(($) => $.obsidianDevUtils.buttons.cancel);
|
|
148
|
+
this.okButtonText = params.okButtonText ?? (0, import_i18n.t)(($) => $.obsidianDevUtils.buttons.ok);
|
|
149
|
+
this.placeholder = params.placeholder ?? "";
|
|
150
|
+
this.title = params.title ?? "";
|
|
151
|
+
this.valueValidator = params.valueValidator ?? import_function.noop;
|
|
153
152
|
this.value = params.defaultValue ?? "";
|
|
154
153
|
}
|
|
155
154
|
onClose() {
|
|
@@ -158,17 +157,17 @@ class PromptModal extends import_modal.ModalBase {
|
|
|
158
157
|
}
|
|
159
158
|
onOpen() {
|
|
160
159
|
super.onOpen();
|
|
161
|
-
this.titleEl.setText(this.
|
|
160
|
+
this.titleEl.setText(this.title);
|
|
162
161
|
const textComponent = new import_obsidian.TextComponent(this.contentEl);
|
|
163
162
|
const inputEl = textComponent.inputEl;
|
|
164
163
|
const validate = async () => {
|
|
165
|
-
const errorMessage = await this.
|
|
164
|
+
const errorMessage = await this.valueValidator(inputEl.value);
|
|
166
165
|
inputEl.setCustomValidity(errorMessage ?? "");
|
|
167
166
|
inputEl.reportValidity();
|
|
168
167
|
};
|
|
169
168
|
textComponent.setValue(this.value);
|
|
170
169
|
textComponent.inputEl.select();
|
|
171
|
-
textComponent.setPlaceholder(this.
|
|
170
|
+
textComponent.setPlaceholder(this.placeholder);
|
|
172
171
|
inputEl.addClass(import_css_class.CssClass.TextBox);
|
|
173
172
|
textComponent.onChange((newValue) => {
|
|
174
173
|
this.value = newValue;
|
|
@@ -184,14 +183,14 @@ class PromptModal extends import_modal.ModalBase {
|
|
|
184
183
|
inputEl.addEventListener("focus", (0, import_async.convertAsyncToSync)(validate));
|
|
185
184
|
(0, import_async.invokeAsyncSafely)(validate);
|
|
186
185
|
const okButton = new import_obsidian.ButtonComponent(this.contentEl);
|
|
187
|
-
okButton.setButtonText(this.
|
|
186
|
+
okButton.setButtonText(this.okButtonText);
|
|
188
187
|
okButton.setCta();
|
|
189
188
|
okButton.onClick((event) => {
|
|
190
189
|
this.handleOk(event, textComponent);
|
|
191
190
|
});
|
|
192
191
|
okButton.setClass(import_css_class.CssClass.OkButton);
|
|
193
192
|
const cancelButton = new import_obsidian.ButtonComponent(this.contentEl);
|
|
194
|
-
cancelButton.setButtonText(this.
|
|
193
|
+
cancelButton.setButtonText(this.cancelButtonText);
|
|
195
194
|
cancelButton.onClick(this.close.bind(this));
|
|
196
195
|
cancelButton.setClass(import_css_class.CssClass.CancelButton);
|
|
197
196
|
}
|
|
@@ -211,4 +210,4 @@ async function prompt(params) {
|
|
|
211
210
|
0 && (module.exports = {
|
|
212
211
|
prompt
|
|
213
212
|
});
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/modals/prompt.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Utility for displaying a prompt modal in Obsidian.\n *\n * This module exports a function to display a modal that prompts the user for input. The modal includes \"OK\" and \"Cancel\" buttons.\n */\n\nimport type { App } from 'obsidian';\nimport type { Promisable } from 'type-fest';\n\nimport {\n  ButtonComponent,\n  TextComponent\n} from 'obsidian';\n\nimport type { PromiseResolve } from '../../async.ts';\nimport type { MaybeReturn } from '../../type.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../async.ts';\nimport { CssClass } from '../../css-class.ts';\nimport { noop } from '../../function.ts';\nimport { t } from '../i18n/i18n.ts';\nimport {\n  addCssClass,\n  ModalBase,\n  showModal\n} from './modal.ts';\n\n/**\n * Options for {@link prompt}.\n */\nexport interface PromptParams {\n  /**\n   * An Obsidian app instance.\n   */\n  readonly app: App;\n\n  /**\n   * A text for the \"Cancel\" button.\n   */\n  readonly cancelButtonText?: string;\n\n  /**\n   * A default value to pre-fill the input field.\n   */\n  readonly defaultValue?: string;\n\n  /**\n   * A text for the \"OK\" button.\n   */\n  readonly okButtonText?: string;\n\n  /**\n   * A placeholder text for the input field.\n   */\n  readonly placeholder?: string;\n\n  /**\n   * A title of the modal.\n   */\n  readonly title?: DocumentFragment | string;\n\n  /**\n   * A function to validate the input value.\n   *\n   * @param value - The input value to validate.\n   * @returns an error message if the value is invalid, or `null` if the value is valid.\n   */\n  readonly valueValidator?: (value: string) => Promisable<MaybeReturn<string>>;\n}\n\nclass PromptModal extends ModalBase<null | string> {\n  private readonly cancelButtonText: string;\n  private isOkClicked = false;\n  private readonly okButtonText: string;\n  private readonly placeholder: string;\n  private readonly title: DocumentFragment | string;\n  private value: string;\n  private readonly valueValidator: (value: string) => Promisable<MaybeReturn<string>>;\n\n  public constructor(params: PromptParams, resolve: PromiseResolve<null | string>) {\n    super(addCssClass(params, CssClass.PromptModal), resolve);\n    this.cancelButtonText = params.cancelButtonText ?? t(($) => $.obsidianDevUtils.buttons.cancel);\n    this.okButtonText = params.okButtonText ?? t(($) => $.obsidianDevUtils.buttons.ok);\n    this.placeholder = params.placeholder ?? '';\n    this.title = params.title ?? '';\n    this.valueValidator = params.valueValidator ?? noop;\n    this.value = params.defaultValue ?? '';\n  }\n\n  public override onClose(): void {\n    super.onClose();\n    this.resolve(this.isOkClicked ? this.value : null);\n  }\n\n  public override onOpen(): void {\n    super.onOpen();\n    this.titleEl.setText(this.title);\n    const textComponent = new TextComponent(this.contentEl);\n    const inputEl = textComponent.inputEl;\n\n    const validate = async (): Promise<void> => {\n      const errorMessage = await this.valueValidator(inputEl.value) as string | undefined;\n      inputEl.setCustomValidity(errorMessage ?? '');\n      inputEl.reportValidity();\n    };\n\n    textComponent.setValue(this.value);\n    textComponent.inputEl.select();\n    textComponent.setPlaceholder(this.placeholder);\n    inputEl.addClass(CssClass.TextBox);\n    textComponent.onChange((newValue) => {\n      this.value = newValue;\n    });\n    inputEl.addEventListener('keydown', (event: KeyboardEvent) => {\n      if (event.key === 'Enter') {\n        this.handleOk(event, textComponent);\n      } else if (event.key === 'Escape') {\n        this.close();\n      }\n    });\n    inputEl.addEventListener('input', convertAsyncToSync(validate));\n    inputEl.addEventListener('focus', convertAsyncToSync(validate));\n    invokeAsyncSafely(validate);\n    const okButton = new ButtonComponent(this.contentEl);\n    okButton.setButtonText(this.okButtonText);\n    okButton.setCta();\n    okButton.onClick((event) => {\n      this.handleOk(event, textComponent);\n    });\n    okButton.setClass(CssClass.OkButton);\n    const cancelButton = new ButtonComponent(this.contentEl);\n    cancelButton.setButtonText(this.cancelButtonText);\n    cancelButton.onClick(this.close.bind(this));\n    cancelButton.setClass(CssClass.CancelButton);\n  }\n\n  private handleOk(event: Event, textComponent: TextComponent): void {\n    event.preventDefault();\n    if (!textComponent.inputEl.checkValidity()) {\n      return;\n    }\n\n    this.isOkClicked = true;\n    this.close();\n  }\n}\n\n/**\n * Displays a prompt modal in Obsidian to get user input.\n *\n * @param params - The parameters for the prompt modal.\n * @returns A {@link Promise} that resolves with the user input or `null` if the prompt was cancelled.\n */\nexport async function prompt(params: PromptParams): Promise<null | string> {\n  return await showModal<null | string>((resolve) => new PromptModal(params, resolve));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,sBAGO;AAKP,mBAGO;AACP,uBAAyB;AACzB,sBAAqB;AACrB,kBAAkB;AAClB,mBAIO;AA6CP,MAAM,oBAAoB,uBAAyB;AAAA,EAChC;AAAA,EACT,cAAc;AAAA,EACL;AAAA,EACA;AAAA,EACA;AAAA,EACT;AAAA,EACS;AAAA,EAEV,YAAY,QAAsB,SAAwC;AAC/E,cAAM,0BAAY,QAAQ,0BAAS,WAAW,GAAG,OAAO;AACxD,SAAK,mBAAmB,OAAO,wBAAoB,eAAE,CAAC,MAAM,EAAE,iBAAiB,QAAQ,MAAM;AAC7F,SAAK,eAAe,OAAO,oBAAgB,eAAE,CAAC,MAAM,EAAE,iBAAiB,QAAQ,EAAE;AACjF,SAAK,cAAc,OAAO,eAAe;AACzC,SAAK,QAAQ,OAAO,SAAS;AAC7B,SAAK,iBAAiB,OAAO,kBAAkB;AAC/C,SAAK,QAAQ,OAAO,gBAAgB;AAAA,EACtC;AAAA,EAEgB,UAAgB;AAC9B,UAAM,QAAQ;AACd,SAAK,QAAQ,KAAK,cAAc,KAAK,QAAQ,IAAI;AAAA,EACnD;AAAA,EAEgB,SAAe;AAC7B,UAAM,OAAO;AACb,SAAK,QAAQ,QAAQ,KAAK,KAAK;AAC/B,UAAM,gBAAgB,IAAI,8BAAc,KAAK,SAAS;AACtD,UAAM,UAAU,cAAc;AAE9B,UAAM,WAAW,YAA2B;AAC1C,YAAM,eAAe,MAAM,KAAK,eAAe,QAAQ,KAAK;AAC5D,cAAQ,kBAAkB,gBAAgB,EAAE;AAC5C,cAAQ,eAAe;AAAA,IACzB;AAEA,kBAAc,SAAS,KAAK,KAAK;AACjC,kBAAc,QAAQ,OAAO;AAC7B,kBAAc,eAAe,KAAK,WAAW;AAC7C,YAAQ,SAAS,0BAAS,OAAO;AACjC,kBAAc,SAAS,CAAC,aAAa;AACnC,WAAK,QAAQ;AAAA,IACf,CAAC;AACD,YAAQ,iBAAiB,WAAW,CAAC,UAAyB;AAC5D,UAAI,MAAM,QAAQ,SAAS;AACzB,aAAK,SAAS,OAAO,aAAa;AAAA,MACpC,WAAW,MAAM,QAAQ,UAAU;AACjC,aAAK,MAAM;AAAA,MACb;AAAA,IACF,CAAC;AACD,YAAQ,iBAAiB,aAAS,iCAAmB,QAAQ,CAAC;AAC9D,YAAQ,iBAAiB,aAAS,iCAAmB,QAAQ,CAAC;AAC9D,wCAAkB,QAAQ;AAC1B,UAAM,WAAW,IAAI,gCAAgB,KAAK,SAAS;AACnD,aAAS,cAAc,KAAK,YAAY;AACxC,aAAS,OAAO;AAChB,aAAS,QAAQ,CAAC,UAAU;AAC1B,WAAK,SAAS,OAAO,aAAa;AAAA,IACpC,CAAC;AACD,aAAS,SAAS,0BAAS,QAAQ;AACnC,UAAM,eAAe,IAAI,gCAAgB,KAAK,SAAS;AACvD,iBAAa,cAAc,KAAK,gBAAgB;AAChD,iBAAa,QAAQ,KAAK,MAAM,KAAK,IAAI,CAAC;AAC1C,iBAAa,SAAS,0BAAS,YAAY;AAAA,EAC7C;AAAA,EAEQ,SAAS,OAAc,eAAoC;AACjE,UAAM,eAAe;AACrB,QAAI,CAAC,cAAc,QAAQ,cAAc,GAAG;AAC1C;AAAA,IACF;AAEA,SAAK,cAAc;AACnB,SAAK,MAAM;AAAA,EACb;AACF;AAQA,eAAsB,OAAO,QAA8C;AACzE,SAAO,UAAM,wBAAyB,CAAC,YAAY,IAAI,YAAY,QAAQ,OAAO,CAAC;AACrF;",
  "names": []
}

|
|
@@ -133,22 +133,21 @@ var import_all_windows_event_handler = require('../../components/all-windows-eve
|
|
|
133
133
|
var import_plugin_context = require('../plugin-context.cjs');
|
|
134
134
|
class PluginContextComponent extends import_obsidian.Component {
|
|
135
135
|
/**
|
|
136
|
-
*
|
|
137
|
-
*
|
|
138
|
-
* @param app - The Obsidian app instance.
|
|
139
|
-
* @param pluginId - The plugin ID.
|
|
136
|
+
* The singleton key for the {@link PluginContextComponent} class.
|
|
140
137
|
*/
|
|
141
|
-
|
|
142
|
-
super();
|
|
143
|
-
this.app = app;
|
|
144
|
-
this.pluginId = pluginId;
|
|
145
|
-
}
|
|
138
|
+
static COMPONENT_KEY = Symbol(PluginContextComponent.name);
|
|
146
139
|
app;
|
|
147
140
|
pluginId;
|
|
148
141
|
/**
|
|
149
|
-
*
|
|
142
|
+
* Creates a new plugin context component.
|
|
143
|
+
*
|
|
144
|
+
* @param params - The constructor parameters.
|
|
150
145
|
*/
|
|
151
|
-
|
|
146
|
+
constructor(params) {
|
|
147
|
+
super();
|
|
148
|
+
this.app = params.app;
|
|
149
|
+
this.pluginId = params.pluginId;
|
|
150
|
+
}
|
|
152
151
|
/**
|
|
153
152
|
* Initializes the plugin context and debug controller.
|
|
154
153
|
*/
|
|
@@ -163,4 +162,4 @@ class PluginContextComponent extends import_obsidian.Component {
|
|
|
163
162
|
0 && (module.exports = {
|
|
164
163
|
PluginContextComponent
|
|
165
164
|
});
|
|
166
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9jb21wb25lbnRzL3BsdWdpbi1jb250ZXh0LWNvbXBvbmVudC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAZmlsZVxuICpcbiAqIENvbXBvbmVudCB0aGF0IGluaXRpYWxpemVzIHRoZSBwbHVnaW4gY29udGV4dCwgZGVidWcgY29udHJvbGxlciwgYW5kIGxpYnJhcnkgc3R5bGVzLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQXBwIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdvYnNpZGlhbic7XG5cbmltcG9ydCB7IEFsbFdpbmRvd3NFdmVudEhhbmRsZXIgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL2FsbC13aW5kb3dzLWV2ZW50LWhhbmRsZXIudHMnO1xuaW1wb3J0IHtcbiAgaW5pdERlYnVnQ29udHJvbGxlcixcbiAgaW5pdFBsdWdpbkNvbnRleHRcbn0gZnJvbSAnLi4vcGx1Z2luLWNvbnRleHQudHMnO1xuXG5pbnRlcmZhY2UgUGx1Z2luQ29udGV4dENvbXBvbmVudENvbnN0cnVjdG9yUGFyYW1zIHtcbiAgcmVhZG9ubHkgYXBwOiBBcHA7XG4gIHJlYWRvbmx5IHBsdWdpbklkOiBzdHJpbmc7XG59XG5cbi8qKlxuICogSW5pdGlhbGl6ZXMgcGx1Z2luIGNvbnRleHQgKHBsdWdpbiBJRCwgZGVidWcgY29udHJvbGxlciwgbGlicmFyeSBzdHlsZXMpIG9uIGxvYWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBQbHVnaW5Db250ZXh0Q29tcG9uZW50IGV4dGVuZHMgQ29tcG9uZW50IHtcbiAgLyoqXG4gICAqIFRoZSBzaW5nbGV0b24ga2V5IGZvciB0aGUge0BsaW5rIFBsdWdpbkNvbnRleHRDb21wb25lbnR9IGNsYXNzLlxuICAgKi9cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBDT01QT05FTlRfS0VZID0gU3ltYm9sKFBsdWdpbkNvbnRleHRDb21wb25lbnQubmFtZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgYXBwOiBBcHA7XG4gIHByaXZhdGUgcmVhZG9ubHkgcGx1Z2luSWQ6IHN0cmluZztcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBwbHVnaW4gY29udGV4dCBjb21wb25lbnQuXG4gICAqXG4gICAqIEBwYXJhbSBwYXJhbXMgLSBUaGUgY29uc3RydWN0b3IgcGFyYW1ldGVycy5cbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihwYXJhbXM6IFBsdWdpbkNvbnRleHRDb21wb25lbnRDb25zdHJ1Y3RvclBhcmFtcykge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5hcHAgPSBwYXJhbXMuYXBwO1xuICAgIHRoaXMucGx1Z2luSWQgPSBwYXJhbXMucGx1Z2luSWQ7XG4gIH1cblxuICAvKipcbiAgICogSW5pdGlhbGl6ZXMgdGhlIHBsdWdpbiBjb250ZXh0IGFuZCBkZWJ1ZyBjb250cm9sbGVyLlxuICAgKi9cbiAgcHVibGljIG92ZXJyaWRlIG9ubG9hZCgpOiB2b2lkIHtcbiAgICBpbml0UGx1Z2luQ29udGV4dCh0aGlzLmFwcCwgdGhpcy5wbHVnaW5JZCk7XG4gICAgbmV3IEFsbFdpbmRvd3NFdmVudEhhbmRsZXIodGhpcy5hcHAsIHRoaXMpLnJlZ2lzdGVyQWxsV2luZG93c0hhbmRsZXIoKHdpbikgPT4ge1xuICAgICAgaW5pdERlYnVnQ29udHJvbGxlcih3aW4sIHRoaXMpO1xuICAgIH0pO1xuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFRQSxzQkFBMEI7QUFFMUIsdUNBQXVDO0FBQ3ZDLDRCQUdPO0FBVUEsTUFBTSwrQkFBK0IsMEJBQVU7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQUlwRCxPQUF1QixnQkFBZ0IsT0FBTyx1QkFBdUIsSUFBSTtBQUFBLEVBQ3hEO0FBQUEsRUFDQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQU9WLFlBQVksUUFBaUQ7QUFDbEUsVUFBTTtBQUNOLFNBQUssTUFBTSxPQUFPO0FBQ2xCLFNBQUssV0FBVyxPQUFPO0FBQUEsRUFDekI7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQUtnQixTQUFlO0FBQzdCLGlEQUFrQixLQUFLLEtBQUssS0FBSyxRQUFRO0FBQ3pDLFFBQUksd0RBQXVCLEtBQUssS0FBSyxJQUFJLEVBQUUsMEJBQTBCLENBQUMsUUFBUTtBQUM1RSxxREFBb0IsS0FBSyxJQUFJO0FBQUEsSUFDL0IsQ0FBQztBQUFBLEVBQ0g7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -5,25 +5,29 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import type { App } from 'obsidian';
|
|
7
7
|
import { Component } from 'obsidian';
|
|
8
|
+
interface PluginContextComponentConstructorParams {
|
|
9
|
+
readonly app: App;
|
|
10
|
+
readonly pluginId: string;
|
|
11
|
+
}
|
|
8
12
|
/**
|
|
9
13
|
* Initializes plugin context (plugin ID, debug controller, library styles) on load.
|
|
10
14
|
*/
|
|
11
15
|
export declare class PluginContextComponent extends Component {
|
|
12
|
-
private readonly app;
|
|
13
|
-
private readonly pluginId;
|
|
14
16
|
/**
|
|
15
17
|
* The singleton key for the {@link PluginContextComponent} class.
|
|
16
18
|
*/
|
|
17
19
|
static readonly COMPONENT_KEY: unique symbol;
|
|
20
|
+
private readonly app;
|
|
21
|
+
private readonly pluginId;
|
|
18
22
|
/**
|
|
19
23
|
* Creates a new plugin context component.
|
|
20
24
|
*
|
|
21
|
-
* @param
|
|
22
|
-
* @param pluginId - The plugin ID.
|
|
25
|
+
* @param params - The constructor parameters.
|
|
23
26
|
*/
|
|
24
|
-
constructor(
|
|
27
|
+
constructor(params: PluginContextComponentConstructorParams);
|
|
25
28
|
/**
|
|
26
29
|
* Initializes the plugin context and debug controller.
|
|
27
30
|
*/
|
|
28
31
|
onload(): void;
|
|
29
32
|
}
|
|
33
|
+
export {};
|
|
@@ -560,4 +560,4 @@ class EmptyPluginSettingsComponent extends PluginSettingsComponentBase {
|
|
|
560
560
|
EmptyPluginSettingsComponent,
|
|
561
561
|
PluginSettingsComponentBase
|
|
562
562
|
});
|
|
563
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/obsidian/plugin/components/plugin-settings-component.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Component that manages plugin settings: data, persistence, validation, and events.\n *\n * This is the single public-facing settings API for plugin authors.\n * All settings logic (load, save, validate, transform, clone) is handled directly\n * by this component \u2014 no separate manager class is needed.\n */\n\nimport type {\n  Promisable,\n  ReadonlyDeep\n} from 'type-fest';\n\nimport type { AsyncEventRef } from '../../../async-events.ts';\nimport type { Transformer } from '../../../transformers/transformer.ts';\nimport type { GenericObject } from '../../../type-guards.ts';\nimport type {\n  MaybeReturn,\n  StringKeys\n} from '../../../type.ts';\n\nimport { AsyncEvents } from '../../../async-events.ts';\nimport { getLibDebugger } from '../../../debug.ts';\nimport {\n  noop,\n  noopAsync\n} from '../../../function.ts';\nimport {\n  castTo,\n  deepEqual,\n  getAllKeys\n} from '../../../object-utils.ts';\nimport { DateTransformer } from '../../../transformers/date-transformer.ts';\nimport { DurationTransformer } from '../../../transformers/duration-transformer.ts';\nimport { GroupTransformer } from '../../../transformers/group-transformer.ts';\nimport { MapTransformer } from '../../../transformers/map-transformer.ts';\nimport { SetTransformer } from '../../../transformers/set-transformer.ts';\nimport { SkipPrivatePropertyTransformer } from '../../../transformers/skip-private-property-transformer.ts';\nimport { TwoWayMapTransformer } from '../../../transformers/two-way-map-transformer.ts';\nimport { AsyncComponentBase } from '../../components/async-component.ts';\nimport { registerAsyncEvent } from '../../components/async-events-component.ts';\n\nconst defaultTransformer = new GroupTransformer([\n  new SkipPrivatePropertyTransformer(),\n  new DateTransformer(),\n  new DurationTransformer(),\n  new MapTransformer(),\n  new SetTransformer(),\n  new TwoWayMapTransformer()\n]);\n\n/**\n * Params for creating a {@link PluginSettingsComponentBase}.\n */\nexport interface PluginSettingsComponentParams {\n  /**\n   * A function to load data from the plugin's data file.\n   *\n   * @returns The loaded data.\n   */\n  readonly loadData: () => Promise<unknown>;\n\n  /**\n   * A function to save data to the plugin's data file.\n   *\n   * @param data - The data to save.\n   */\n  readonly saveData: (data: unknown) => Promise<void>;\n}\n\n/**\n * A snapshot of plugin settings state, including raw input values, effective (validated) values,\n * and per-property validation messages.\n *\n * @typeParam PluginSettings - The type of the plugin settings.\n */\nexport interface PluginSettingsState<PluginSettings extends object> {\n  /**\n   * The effective settings values used by the plugin. Invalid properties are replaced with defaults.\n   */\n  effectiveValues: PluginSettings;\n\n  /**\n   * The raw input values as entered by the user. May contain invalid values.\n   */\n  inputValues: PluginSettings;\n\n  /**\n   * Per-property validation messages. Empty string means valid.\n   */\n  validationMessages: Record<StringKeys<PluginSettings>, string>;\n}\n\n/**\n * Readonly version of {@link PluginSettings}.\n *\n * @typeParam PluginSettings - The type of the plugin settings.\n */\nexport type ReadonlyPluginSettings<PluginSettings extends object> = ReadonlyDeep<PluginSettings>;\n\n/**\n * Readonly version of {@link PluginSettingsState} for use in event callbacks and public getters.\n *\n * @typeParam PluginSettings - The type of the plugin settings.\n */\nexport type ReadonlyPluginSettingsState<PluginSettings extends object> = ReadonlyDeep<PluginSettingsState<PluginSettings>>;\n\n/**\n * A validator function for a settings property.\n *\n * @typeParam PluginSettings - The plugin settings type.\n * @typeParam PropertyName - The property name.\n */\nexport type SettingsValidator<PluginSettings extends object, PropertyName extends StringKeys<PluginSettings> = StringKeys<PluginSettings>> = (\n  value: PluginSettings[PropertyName],\n  settings: PluginSettings\n) => Promisable<MaybeReturn<string>>;\n\ntype PropertyNames<PluginSettings extends object> = StringKeys<PluginSettings>;\n\ntype PropertyValues<PluginSettings extends object> = PluginSettings[PropertyNames<PluginSettings>];\n\ntype ValidationResult<PluginSettings extends object> = Partial<Record<StringKeys<PluginSettings>, string>>;\n\n/**\n * Base class for plugin settings components.\n *\n * Manages settings data, persistence, validation, and events.\n * Plugin authors extend this class and implement {@link createDefaultSettings}.\n *\n * @typeParam PluginSettings - The plugin settings type.\n */\nexport abstract class PluginSettingsComponentBase<PluginSettings extends object> extends AsyncComponentBase {\n  /**\n   * Component key for {@link registerComponent} replacement.\n   */\n  public static readonly COMPONENT_KEY = Symbol(PluginSettingsComponentBase.name);\n\n  /**\n   * Gets the readonly default settings.\n   *\n   * @returns The default settings (as a readonly object).\n   */\n  public readonly defaultSettings: ReadonlyDeep<PluginSettings>;\n\n  /**\n   * Gets the readonly effective settings (validated, with defaults substituted for invalid values).\n   *\n   * @returns The readonly effective settings.\n   */\n  public get settings(): ReadonlyDeep<PluginSettings> {\n    return this.settingsState.effectiveValues;\n  }\n\n  /**\n   * Gets the current settings state snapshot.\n   *\n   * @returns The current settings state.\n   */\n  public get settingsState(): ReadonlyPluginSettingsState<PluginSettings> {\n    return this.currentState as ReadonlyPluginSettingsState<PluginSettings>;\n  }\n\n  private readonly asyncEvents = new AsyncEvents();\n  private currentState: PluginSettingsState<PluginSettings>;\n  private lastSavedState: PluginSettingsState<PluginSettings>;\n  private readonly legacySettingsConverters: ((record: GenericObject) => void)[] = [];\n  private readonly loadDataFn: () => Promise<unknown>;\n  private readonly propertyNames: PropertyNames<PluginSettings>[];\n  private readonly saveDataFn: (data: unknown) => Promise<void>;\n  private readonly validators = new Map<PropertyNames<PluginSettings>, SettingsValidator<PluginSettings>>();\n\n  /**\n   * Creates a new plugin settings component.\n   *\n   * @param params - The params for loading/saving data.\n   */\n  public constructor(params: PluginSettingsComponentParams) {\n    super();\n    this.loadDataFn = params.loadData.bind(params);\n    this.saveDataFn = params.saveData.bind(params);\n    this.defaultSettings = this.createDefaultSettings() as ReadonlyDeep<PluginSettings>;\n    this.currentState = this.createDefaultState();\n    this.lastSavedState = this.createDefaultState();\n    this.propertyNames = getAllKeys(this.currentState.inputValues);\n    this.registerValidators();\n    this.registerLegacySettingsConverters();\n  }\n\n  /**\n   * Edits the plugin settings and saves them.\n   *\n   * @param settingsEditor - The editor.\n   * @param context - The context.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async editAndSave(settingsEditor: (settings: PluginSettings) => Promisable<void>, context?: unknown): Promise<void> {\n    await this.edit(settingsEditor);\n    await this.saveToFile(context);\n  }\n\n  /**\n   * Ensures the settings are safe.\n   *\n   * It runs validation for each property and sets the default value if the validation fails.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves when the settings are safe.\n   */\n  public async ensureSafe(settings: PluginSettings): Promise<void> {\n    const validationResult = await this.validate(settings);\n    const defaults = this.defaultSettings as PluginSettings;\n    for (const propertyName of this.propertyNames) {\n      if (validationResult[propertyName]) {\n        settings[propertyName] = defaults[propertyName];\n      }\n    }\n  }\n\n  /**\n   * Gets a safe copy of the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the safe copy of the settings.\n   */\n  public async getSafeCopy(settings: PluginSettings): Promise<PluginSettings> {\n    const safeSettings = await this.cloneSettings(settings);\n    await this.ensureSafe(safeSettings);\n    return safeSettings;\n  }\n\n  /**\n   * Loads the plugin settings from the file.\n   *\n   * @param isInitialLoad - Whether the settings are being loaded for the first time.\n   * @returns A {@link Promise} that resolves when the settings are loaded.\n   */\n  public async loadFromFile(isInitialLoad: boolean): Promise<void> {\n    const data = await this.loadDataFn();\n    this.lastSavedState = this.createDefaultState();\n    this.currentState = this.createDefaultState();\n\n    try {\n      if (data === undefined || data === null) {\n        return;\n      }\n\n      if (typeof data !== 'object') {\n        console.error(`Invalid settings from data.json. Expected Object, got: ${typeof data}`);\n        return;\n      }\n\n      const rawRecord = data as GenericObject;\n      const parsedSettings = await this.rawRecordToSettings(rawRecord);\n      const validationResult = await this.validate(parsedSettings);\n\n      for (const propertyName of this.propertyNames) {\n        this.setPropertyImpl(propertyName, parsedSettings[propertyName], validationResult[propertyName]);\n      }\n\n      this.lastSavedState = await this.cloneState(this.currentState);\n\n      const newRecord = await this.settingsToRawRecord(this.currentState.inputValues);\n\n      if (!deepEqual(newRecord, data)) {\n        await this.saveToFileImpl();\n      }\n    } finally {\n      await this.asyncEvents.triggerAsync('loadSettings', this.currentState, isInitialLoad);\n    }\n  }\n\n  /**\n   * Subscribes to the `loadSettings` event.\n   *\n   * @param name - Always `loadSettings`.\n   * @param callback - The callback.\n   * @param thisArg - The `this` context.\n   * @returns A reference to the event listener.\n   */\n  public on(\n    name: 'loadSettings',\n    callback: (\n      loadedState: ReadonlyPluginSettingsState<PluginSettings>,\n      isInitialLoad: boolean\n    ) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef;\n  /**\n   * Subscribes to the `saveSettings` event.\n   *\n   * @param name - Always `saveSettings`.\n   * @param callback - The callback.\n   * @param thisArg - The `this` context.\n   * @returns A reference to the event listener.\n   */\n  public on(\n    name: 'saveSettings',\n    callback: (\n      newState: ReadonlyPluginSettingsState<PluginSettings>,\n      oldState: ReadonlyPluginSettingsState<PluginSettings>,\n      context: unknown\n    ) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef;\n  /**\n   * Subscribes to an event.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback.\n   * @param thisArg - The `this` context.\n   * @returns A reference to the event listener.\n   */\n  public on<Args extends unknown[]>(\n    name: string,\n    callback: (...args: Args) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef {\n    return this.asyncEvents.on(name, callback, thisArg);\n  }\n\n  /**\n   * Called when the external settings change.\n   *\n   * @returns A {@link Promise} that resolves when the settings are reloaded.\n   */\n  public async onExternalSettingsChange(): Promise<void> {\n    await this.loadFromFile(false);\n  }\n\n  /**\n   * Loads settings from file and registers event handlers.\n   */\n  public override async onload(): Promise<void> {\n    registerAsyncEvent(this, this.on('loadSettings', this.onLoadSettings.bind(this)));\n    registerAsyncEvent(this, this.on('saveSettings', this.onSaveSettings.bind(this)));\n    await this.loadFromFile(true);\n  }\n\n  /**\n   * Registers a legacy settings converter.\n   *\n   * @typeParam LegacySettings - The legacy settings class.\n   * @param legacySettingsClass - The legacy settings class.\n   * @param converter - The converter.\n   */\n  public registerLegacySettingsConverter<LegacySettings extends object>(\n    legacySettingsClass: new () => LegacySettings,\n    converter: (legacySettings: Partial<LegacySettings> & Partial<PluginSettings>) => void\n  ): void {\n    const that = this;\n    this.legacySettingsConverters.push(legacySettingsConverter);\n\n    function legacySettingsConverter(record: GenericObject): void {\n      const legacySettingsKeys = new Set<string>(Object.keys(new legacySettingsClass()));\n      const pluginSettingKeys = new Set<string>(that.propertyNames);\n      const legacySettings = record as Partial<LegacySettings> & Partial<PluginSettings>;\n      converter(legacySettings);\n      for (const key of Object.keys(legacySettings)) {\n        if (pluginSettingKeys.has(key)) {\n          continue;\n        }\n\n        if (!legacySettingsKeys.has(key)) {\n          continue;\n        }\n\n        // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- We have no other way to delete the property.\n        delete record[key];\n      }\n    }\n  }\n\n  /**\n   * Registers a validator for a property.\n   *\n   * @param propertyName - The name of the property.\n   * @param validator - The validator.\n   */\n  public registerValidator<PropertyName extends PropertyNames<PluginSettings>>(\n    propertyName: PropertyName,\n    validator: SettingsValidator<PluginSettings, PropertyName>\n  ): void {\n    this.validators.set(propertyName, validator as SettingsValidator<PluginSettings>);\n  }\n\n  /**\n   * Revalidates the settings.\n   *\n   * @returns The validation messages.\n   */\n  public async revalidate(): Promise<Record<PropertyNames<PluginSettings>, string>> {\n    await this.edit(noop);\n    return this.currentState.validationMessages;\n  }\n\n  /**\n   * Saves the new plugin settings.\n   *\n   * @param context - The context of the save to file operation.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async saveToFile(context?: unknown): Promise<void> {\n    if (deepEqual(this.lastSavedState.inputValues, this.currentState.inputValues)) {\n      return;\n    }\n\n    await this.saveToFileImpl();\n    await this.asyncEvents.triggerAsync('saveSettings', this.currentState, this.lastSavedState, context);\n    this.lastSavedState = await this.cloneState(this.currentState);\n  }\n\n  /**\n   * Sets the value of a property.\n   *\n   * @typeParam PropertyName - The name of the property.\n   * @param propertyName - The name of the property.\n   * @param value - The value to set.\n   * @returns A {@link Promise} that resolves to the validation message.\n   */\n  public async setProperty<PropertyName extends PropertyNames<PluginSettings>>(\n    propertyName: PropertyName,\n    value: PluginSettings[PropertyName]\n  ): Promise<string> {\n    await this.edit((settings) => {\n      settings[propertyName] = value;\n    });\n    return this.currentState.validationMessages[propertyName];\n  }\n\n  /**\n   * Validates the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the validation result.\n   */\n  public async validate(settings: PluginSettings): Promise<ValidationResult<PluginSettings>> {\n    const result: ValidationResult<PluginSettings> = {};\n    for (const [propertyName, validator] of this.validators.entries()) {\n      const validationMessage = await validator(settings[propertyName], settings);\n      if (validationMessage) {\n        result[propertyName] = validationMessage;\n      }\n    }\n\n    return result;\n  }\n\n  /**\n   * Creates the default settings. Must be implemented by subclasses.\n   *\n   * @returns The default settings.\n   */\n  protected abstract createDefaultSettings(): PluginSettings;\n\n  /**\n   * Gets the transformer.\n   *\n   * @returns The transformer.\n   */\n  protected getTransformer(): Transformer {\n    return defaultTransformer;\n  }\n\n  /**\n   * Called when the plugin settings record is loaded from disk.\n   *\n   * @param record - The record.\n   */\n  protected async onLoadRecord(record: GenericObject): Promise<void> {\n    for (const converter of this.legacySettingsConverters) {\n      converter(record);\n    }\n    await Promise.resolve();\n  }\n\n  /**\n   * Called when settings are loaded or reloaded.\n   *\n   * @param _loadedState - The loaded settings state.\n   * @param _isInitialLoad - Whether this is the initial load.\n   */\n  protected async onLoadSettings(\n    _loadedState: ReadonlyPluginSettingsState<PluginSettings>,\n    _isInitialLoad: boolean\n  ): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when settings are saved.\n   *\n   * @param _newState - The new settings state.\n   * @param _oldState - The old settings state.\n   * @param _context - The save context.\n   */\n  protected async onSaveSettings(\n    _newState: ReadonlyPluginSettingsState<PluginSettings>,\n    _oldState: ReadonlyPluginSettingsState<PluginSettings>,\n    _context: unknown\n  ): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings record is about to be saved to disk.\n   *\n   * @param _record - The record.\n   */\n  protected async onSavingRecord(_record: GenericObject): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Registers the legacy settings converters.\n   * Override to register legacy settings converters.\n   */\n  protected registerLegacySettingsConverters(): void {\n    noop();\n  }\n\n  /**\n   * Registers the validators.\n   * Override to register validators for properties.\n   */\n  protected registerValidators(): void {\n    noop();\n  }\n\n  private async cloneSettings(settings: PluginSettings): Promise<PluginSettings> {\n    const record = await this.settingsToRawRecord(settings);\n    const json = JSON.stringify(record);\n    const cloneRecord = JSON.parse(json) as GenericObject;\n    return await this.rawRecordToSettings(cloneRecord);\n  }\n\n  private async cloneState(\n    state: PluginSettingsState<PluginSettings>\n  ): Promise<PluginSettingsState<PluginSettings>> {\n    return {\n      effectiveValues: await this.cloneSettings(state.effectiveValues),\n      inputValues: await this.cloneSettings(state.inputValues),\n      validationMessages: { ...state.validationMessages }\n    };\n  }\n\n  private createDefaultState(): PluginSettingsState<PluginSettings> {\n    return {\n      effectiveValues: this.createDefaultSettings(),\n      inputValues: this.createDefaultSettings(),\n      validationMessages: castTo<Record<PropertyNames<PluginSettings>, string>>({})\n    };\n  }\n\n  private async edit(settingsEditor: (settings: PluginSettings) => Promisable<void>): Promise<void> {\n    try {\n      await settingsEditor(this.currentState.inputValues);\n    } finally {\n      const validationResult = await this.validate(this.currentState.inputValues);\n      for (const propertyName of this.propertyNames) {\n        const validationMessage = validationResult[propertyName] ?? '';\n        this.currentState.validationMessages[propertyName] = validationMessage;\n        const defaults = this.defaultSettings as PluginSettings;\n        this.currentState.effectiveValues[propertyName] = validationMessage\n          ? defaults[propertyName]\n          : this.currentState.inputValues[propertyName];\n      }\n    }\n  }\n\n  private isValidPropertyName(prop: unknown): prop is PropertyNames<PluginSettings> {\n    if (typeof prop !== 'string') {\n      return false;\n    }\n\n    return (this.propertyNames as string[]).includes(prop);\n  }\n\n  private async rawRecordToSettings(rawRecord: GenericObject): Promise<PluginSettings> {\n    rawRecord = this.getTransformer().transformObjectRecursively(rawRecord);\n    await this.onLoadRecord(rawRecord);\n\n    const settings = this.createDefaultSettings();\n    const defaults = this.defaultSettings as PluginSettings;\n\n    for (const [propertyName, value] of Object.entries(rawRecord)) {\n      if (!this.isValidPropertyName(propertyName)) {\n        getLibDebugger('PluginSettingsComponentBase:rawRecordToSettings')(`Unknown property: ${propertyName}`);\n        continue;\n      }\n\n      if (typeof value !== typeof defaults[propertyName]) {\n        getLibDebugger('PluginSettingsComponentBase:rawRecordToSettings')(\n          'Possible invalid value type. It might lead to an unexpected behavior of the plugin. There is also a chance it is a false-negative warning, as we are unable to determine the exact type of the value in runtime.',\n          {\n            defaultValue: defaults[propertyName],\n            propertyName,\n            value\n          }\n        );\n      }\n\n      settings[propertyName] = value as PropertyValues<PluginSettings>;\n    }\n\n    return settings;\n  }\n\n  private async saveToFileImpl(): Promise<void> {\n    await this.saveDataFn(await this.settingsToRawRecord(this.currentState.inputValues));\n  }\n\n  private setPropertyImpl(\n    propertyName: PropertyNames<PluginSettings>,\n    value: PropertyValues<PluginSettings>,\n    validationMessage?: string\n  ): void {\n    const defaults = this.defaultSettings as PluginSettings;\n    this.currentState.inputValues[propertyName] = value;\n    this.currentState.validationMessages[propertyName] = validationMessage ?? '';\n    this.currentState.effectiveValues[propertyName] = validationMessage ? defaults[propertyName] : value;\n  }\n\n  private async settingsToRawRecord(settings: PluginSettings): Promise<GenericObject> {\n    const rawRecord: GenericObject = {};\n\n    for (const propertyName of this.propertyNames) {\n      rawRecord[propertyName] = settings[propertyName];\n    }\n\n    await this.onSavingRecord(rawRecord);\n\n    return this.getTransformer().transformObjectRecursively(rawRecord);\n  }\n}\n\n/**\n * A no-op settings component for plugins without settings.\n */\nexport class EmptyPluginSettingsComponent extends PluginSettingsComponentBase<object> {\n  /**\n   * Creates a new empty plugin settings component.\n   *\n   * @param params - The params. Uses no-op load/save by default.\n   */\n  public constructor(params?: PluginSettingsComponentParams) {\n    super(\n      params ?? {\n        loadData: async (): Promise<object> => {\n          await noopAsync();\n          return {};\n        },\n        saveData: noopAsync\n      }\n    );\n  }\n\n  /**\n   * Creates empty default settings.\n   *\n   * @returns An empty object.\n   */\n  protected override createDefaultSettings(): object {\n    return {};\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
563
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/obsidian/plugin/components/plugin-settings-component.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Component that manages plugin settings: data, persistence, validation, and events.\n *\n * This is the single public-facing settings API for plugin authors.\n * All settings logic (load, save, validate, transform, clone) is handled directly\n * by this component \u2014 no separate manager class is needed.\n */\n\nimport type {\n  Promisable,\n  ReadonlyDeep\n} from 'type-fest';\n\nimport type { AsyncEventRef } from '../../../async-events.ts';\nimport type { Transformer } from '../../../transformers/transformer.ts';\nimport type { GenericObject } from '../../../type-guards.ts';\nimport type {\n  MaybeReturn,\n  StringKeys\n} from '../../../type.ts';\n\nimport { AsyncEvents } from '../../../async-events.ts';\nimport { getLibDebugger } from '../../../debug.ts';\nimport {\n  noop,\n  noopAsync\n} from '../../../function.ts';\nimport {\n  castTo,\n  deepEqual,\n  getAllKeys\n} from '../../../object-utils.ts';\nimport { DateTransformer } from '../../../transformers/date-transformer.ts';\nimport { DurationTransformer } from '../../../transformers/duration-transformer.ts';\nimport { GroupTransformer } from '../../../transformers/group-transformer.ts';\nimport { MapTransformer } from '../../../transformers/map-transformer.ts';\nimport { SetTransformer } from '../../../transformers/set-transformer.ts';\nimport { SkipPrivatePropertyTransformer } from '../../../transformers/skip-private-property-transformer.ts';\nimport { TwoWayMapTransformer } from '../../../transformers/two-way-map-transformer.ts';\nimport { AsyncComponentBase } from '../../components/async-component.ts';\nimport { registerAsyncEvent } from '../../components/async-events-component.ts';\n\nconst defaultTransformer = new GroupTransformer([\n  new SkipPrivatePropertyTransformer(),\n  new DateTransformer(),\n  new DurationTransformer(),\n  new MapTransformer(),\n  new SetTransformer(),\n  new TwoWayMapTransformer()\n]);\n\n/**\n * Params for creating a {@link PluginSettingsComponentBase}.\n */\nexport interface PluginSettingsComponentConstructorParams {\n  /**\n   * A function to load data from the plugin's data file.\n   *\n   * @returns The loaded data.\n   */\n  readonly loadData: () => Promise<unknown>;\n\n  /**\n   * A function to save data to the plugin's data file.\n   *\n   * @param data - The data to save.\n   */\n  readonly saveData: (data: unknown) => Promise<void>;\n}\n\n/**\n * A snapshot of plugin settings state, including raw input values, effective (validated) values,\n * and per-property validation messages.\n *\n * @typeParam PluginSettings - The type of the plugin settings.\n */\nexport interface PluginSettingsState<PluginSettings extends object> {\n  /**\n   * The effective settings values used by the plugin. Invalid properties are replaced with defaults.\n   */\n  effectiveValues: PluginSettings;\n\n  /**\n   * The raw input values as entered by the user. May contain invalid values.\n   */\n  inputValues: PluginSettings;\n\n  /**\n   * Per-property validation messages. Empty string means valid.\n   */\n  validationMessages: Record<StringKeys<PluginSettings>, string>;\n}\n\n/**\n * Readonly version of {@link PluginSettings}.\n *\n * @typeParam PluginSettings - The type of the plugin settings.\n */\nexport type ReadonlyPluginSettings<PluginSettings extends object> = ReadonlyDeep<PluginSettings>;\n\n/**\n * Readonly version of {@link PluginSettingsState} for use in event callbacks and public getters.\n *\n * @typeParam PluginSettings - The type of the plugin settings.\n */\nexport type ReadonlyPluginSettingsState<PluginSettings extends object> = ReadonlyDeep<PluginSettingsState<PluginSettings>>;\n\n/**\n * A validator function for a settings property.\n *\n * @typeParam PluginSettings - The plugin settings type.\n * @typeParam PropertyName - The property name.\n */\nexport type SettingsValidator<PluginSettings extends object, PropertyName extends StringKeys<PluginSettings> = StringKeys<PluginSettings>> = (\n  value: PluginSettings[PropertyName],\n  settings: PluginSettings\n) => Promisable<MaybeReturn<string>>;\n\ntype PropertyNames<PluginSettings extends object> = StringKeys<PluginSettings>;\n\ntype PropertyValues<PluginSettings extends object> = PluginSettings[PropertyNames<PluginSettings>];\n\ntype ValidationResult<PluginSettings extends object> = Partial<Record<StringKeys<PluginSettings>, string>>;\n\n/**\n * Base class for plugin settings components.\n *\n * Manages settings data, persistence, validation, and events.\n * Plugin authors extend this class and implement {@link createDefaultSettings}.\n *\n * @typeParam PluginSettings - The plugin settings type.\n */\nexport abstract class PluginSettingsComponentBase<PluginSettings extends object> extends AsyncComponentBase {\n  /**\n   * Component key for {@link registerComponent} replacement.\n   */\n  public static readonly COMPONENT_KEY = Symbol(PluginSettingsComponentBase.name);\n\n  /**\n   * Gets the readonly default settings.\n   *\n   * @returns The default settings (as a readonly object).\n   */\n  public readonly defaultSettings: ReadonlyDeep<PluginSettings>;\n\n  /**\n   * Gets the readonly effective settings (validated, with defaults substituted for invalid values).\n   *\n   * @returns The readonly effective settings.\n   */\n  public get settings(): ReadonlyDeep<PluginSettings> {\n    return this.settingsState.effectiveValues;\n  }\n\n  /**\n   * Gets the current settings state snapshot.\n   *\n   * @returns The current settings state.\n   */\n  public get settingsState(): ReadonlyPluginSettingsState<PluginSettings> {\n    return this.currentState as ReadonlyPluginSettingsState<PluginSettings>;\n  }\n\n  private readonly asyncEvents = new AsyncEvents();\n  private currentState: PluginSettingsState<PluginSettings>;\n  private lastSavedState: PluginSettingsState<PluginSettings>;\n  private readonly legacySettingsConverters: ((record: GenericObject) => void)[] = [];\n  private readonly loadDataFn: () => Promise<unknown>;\n  private readonly propertyNames: PropertyNames<PluginSettings>[];\n  private readonly saveDataFn: (data: unknown) => Promise<void>;\n  private readonly validators = new Map<PropertyNames<PluginSettings>, SettingsValidator<PluginSettings>>();\n\n  /**\n   * Creates a new plugin settings component.\n   *\n   * @param params - The params for loading/saving data.\n   */\n  public constructor(params: PluginSettingsComponentConstructorParams) {\n    super();\n    this.loadDataFn = params.loadData.bind(params);\n    this.saveDataFn = params.saveData.bind(params);\n    this.defaultSettings = this.createDefaultSettings() as ReadonlyDeep<PluginSettings>;\n    this.currentState = this.createDefaultState();\n    this.lastSavedState = this.createDefaultState();\n    this.propertyNames = getAllKeys(this.currentState.inputValues);\n    this.registerValidators();\n    this.registerLegacySettingsConverters();\n  }\n\n  /**\n   * Edits the plugin settings and saves them.\n   *\n   * @param settingsEditor - The editor.\n   * @param context - The context.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async editAndSave(settingsEditor: (settings: PluginSettings) => Promisable<void>, context?: unknown): Promise<void> {\n    await this.edit(settingsEditor);\n    await this.saveToFile(context);\n  }\n\n  /**\n   * Ensures the settings are safe.\n   *\n   * It runs validation for each property and sets the default value if the validation fails.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves when the settings are safe.\n   */\n  public async ensureSafe(settings: PluginSettings): Promise<void> {\n    const validationResult = await this.validate(settings);\n    const defaults = this.defaultSettings as PluginSettings;\n    for (const propertyName of this.propertyNames) {\n      if (validationResult[propertyName]) {\n        settings[propertyName] = defaults[propertyName];\n      }\n    }\n  }\n\n  /**\n   * Gets a safe copy of the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the safe copy of the settings.\n   */\n  public async getSafeCopy(settings: PluginSettings): Promise<PluginSettings> {\n    const safeSettings = await this.cloneSettings(settings);\n    await this.ensureSafe(safeSettings);\n    return safeSettings;\n  }\n\n  /**\n   * Loads the plugin settings from the file.\n   *\n   * @param isInitialLoad - Whether the settings are being loaded for the first time.\n   * @returns A {@link Promise} that resolves when the settings are loaded.\n   */\n  public async loadFromFile(isInitialLoad: boolean): Promise<void> {\n    const data = await this.loadDataFn();\n    this.lastSavedState = this.createDefaultState();\n    this.currentState = this.createDefaultState();\n\n    try {\n      if (data === undefined || data === null) {\n        return;\n      }\n\n      if (typeof data !== 'object') {\n        console.error(`Invalid settings from data.json. Expected Object, got: ${typeof data}`);\n        return;\n      }\n\n      const rawRecord = data as GenericObject;\n      const parsedSettings = await this.rawRecordToSettings(rawRecord);\n      const validationResult = await this.validate(parsedSettings);\n\n      for (const propertyName of this.propertyNames) {\n        this.setPropertyImpl(propertyName, parsedSettings[propertyName], validationResult[propertyName]);\n      }\n\n      this.lastSavedState = await this.cloneState(this.currentState);\n\n      const newRecord = await this.settingsToRawRecord(this.currentState.inputValues);\n\n      if (!deepEqual(newRecord, data)) {\n        await this.saveToFileImpl();\n      }\n    } finally {\n      await this.asyncEvents.triggerAsync('loadSettings', this.currentState, isInitialLoad);\n    }\n  }\n\n  /**\n   * Subscribes to the `loadSettings` event.\n   *\n   * @param name - Always `loadSettings`.\n   * @param callback - The callback.\n   * @param thisArg - The `this` context.\n   * @returns A reference to the event listener.\n   */\n  public on(\n    name: 'loadSettings',\n    callback: (\n      loadedState: ReadonlyPluginSettingsState<PluginSettings>,\n      isInitialLoad: boolean\n    ) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef;\n  /**\n   * Subscribes to the `saveSettings` event.\n   *\n   * @param name - Always `saveSettings`.\n   * @param callback - The callback.\n   * @param thisArg - The `this` context.\n   * @returns A reference to the event listener.\n   */\n  public on(\n    name: 'saveSettings',\n    callback: (\n      newState: ReadonlyPluginSettingsState<PluginSettings>,\n      oldState: ReadonlyPluginSettingsState<PluginSettings>,\n      context: unknown\n    ) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef;\n  /**\n   * Subscribes to an event.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback.\n   * @param thisArg - The `this` context.\n   * @returns A reference to the event listener.\n   */\n  public on<Args extends unknown[]>(\n    name: string,\n    callback: (...args: Args) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef {\n    return this.asyncEvents.on(name, callback, thisArg);\n  }\n\n  /**\n   * Called when the external settings change.\n   *\n   * @returns A {@link Promise} that resolves when the settings are reloaded.\n   */\n  public async onExternalSettingsChange(): Promise<void> {\n    await this.loadFromFile(false);\n  }\n\n  /**\n   * Loads settings from file and registers event handlers.\n   */\n  public override async onload(): Promise<void> {\n    registerAsyncEvent(this, this.on('loadSettings', this.onLoadSettings.bind(this)));\n    registerAsyncEvent(this, this.on('saveSettings', this.onSaveSettings.bind(this)));\n    await this.loadFromFile(true);\n  }\n\n  /**\n   * Registers a legacy settings converter.\n   *\n   * @typeParam LegacySettings - The legacy settings class.\n   * @param legacySettingsClass - The legacy settings class.\n   * @param converter - The converter.\n   */\n  public registerLegacySettingsConverter<LegacySettings extends object>(\n    legacySettingsClass: new () => LegacySettings,\n    converter: (legacySettings: Partial<LegacySettings> & Partial<PluginSettings>) => void\n  ): void {\n    const that = this;\n    this.legacySettingsConverters.push(legacySettingsConverter);\n\n    function legacySettingsConverter(record: GenericObject): void {\n      const legacySettingsKeys = new Set<string>(Object.keys(new legacySettingsClass()));\n      const pluginSettingKeys = new Set<string>(that.propertyNames);\n      const legacySettings = record as Partial<LegacySettings> & Partial<PluginSettings>;\n      converter(legacySettings);\n      for (const key of Object.keys(legacySettings)) {\n        if (pluginSettingKeys.has(key)) {\n          continue;\n        }\n\n        if (!legacySettingsKeys.has(key)) {\n          continue;\n        }\n\n        // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- We have no other way to delete the property.\n        delete record[key];\n      }\n    }\n  }\n\n  /**\n   * Registers a validator for a property.\n   *\n   * @param propertyName - The name of the property.\n   * @param validator - The validator.\n   */\n  public registerValidator<PropertyName extends PropertyNames<PluginSettings>>(\n    propertyName: PropertyName,\n    validator: SettingsValidator<PluginSettings, PropertyName>\n  ): void {\n    this.validators.set(propertyName, validator as SettingsValidator<PluginSettings>);\n  }\n\n  /**\n   * Revalidates the settings.\n   *\n   * @returns The validation messages.\n   */\n  public async revalidate(): Promise<Record<PropertyNames<PluginSettings>, string>> {\n    await this.edit(noop);\n    return this.currentState.validationMessages;\n  }\n\n  /**\n   * Saves the new plugin settings.\n   *\n   * @param context - The context of the save to file operation.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async saveToFile(context?: unknown): Promise<void> {\n    if (deepEqual(this.lastSavedState.inputValues, this.currentState.inputValues)) {\n      return;\n    }\n\n    await this.saveToFileImpl();\n    await this.asyncEvents.triggerAsync('saveSettings', this.currentState, this.lastSavedState, context);\n    this.lastSavedState = await this.cloneState(this.currentState);\n  }\n\n  /**\n   * Sets the value of a property.\n   *\n   * @typeParam PropertyName - The name of the property.\n   * @param propertyName - The name of the property.\n   * @param value - The value to set.\n   * @returns A {@link Promise} that resolves to the validation message.\n   */\n  public async setProperty<PropertyName extends PropertyNames<PluginSettings>>(\n    propertyName: PropertyName,\n    value: PluginSettings[PropertyName]\n  ): Promise<string> {\n    await this.edit((settings) => {\n      settings[propertyName] = value;\n    });\n    return this.currentState.validationMessages[propertyName];\n  }\n\n  /**\n   * Validates the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the validation result.\n   */\n  public async validate(settings: PluginSettings): Promise<ValidationResult<PluginSettings>> {\n    const result: ValidationResult<PluginSettings> = {};\n    for (const [propertyName, validator] of this.validators.entries()) {\n      const validationMessage = await validator(settings[propertyName], settings);\n      if (validationMessage) {\n        result[propertyName] = validationMessage;\n      }\n    }\n\n    return result;\n  }\n\n  /**\n   * Creates the default settings. Must be implemented by subclasses.\n   *\n   * @returns The default settings.\n   */\n  protected abstract createDefaultSettings(): PluginSettings;\n\n  /**\n   * Gets the transformer.\n   *\n   * @returns The transformer.\n   */\n  protected getTransformer(): Transformer {\n    return defaultTransformer;\n  }\n\n  /**\n   * Called when the plugin settings record is loaded from disk.\n   *\n   * @param record - The record.\n   */\n  protected async onLoadRecord(record: GenericObject): Promise<void> {\n    for (const converter of this.legacySettingsConverters) {\n      converter(record);\n    }\n    await Promise.resolve();\n  }\n\n  /**\n   * Called when settings are loaded or reloaded.\n   *\n   * @param _loadedState - The loaded settings state.\n   * @param _isInitialLoad - Whether this is the initial load.\n   */\n  protected async onLoadSettings(\n    _loadedState: ReadonlyPluginSettingsState<PluginSettings>,\n    _isInitialLoad: boolean\n  ): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when settings are saved.\n   *\n   * @param _newState - The new settings state.\n   * @param _oldState - The old settings state.\n   * @param _context - The save context.\n   */\n  protected async onSaveSettings(\n    _newState: ReadonlyPluginSettingsState<PluginSettings>,\n    _oldState: ReadonlyPluginSettingsState<PluginSettings>,\n    _context: unknown\n  ): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings record is about to be saved to disk.\n   *\n   * @param _record - The record.\n   */\n  protected async onSavingRecord(_record: GenericObject): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Registers the legacy settings converters.\n   * Override to register legacy settings converters.\n   */\n  protected registerLegacySettingsConverters(): void {\n    noop();\n  }\n\n  /**\n   * Registers the validators.\n   * Override to register validators for properties.\n   */\n  protected registerValidators(): void {\n    noop();\n  }\n\n  private async cloneSettings(settings: PluginSettings): Promise<PluginSettings> {\n    const record = await this.settingsToRawRecord(settings);\n    const json = JSON.stringify(record);\n    const cloneRecord = JSON.parse(json) as GenericObject;\n    return await this.rawRecordToSettings(cloneRecord);\n  }\n\n  private async cloneState(\n    state: PluginSettingsState<PluginSettings>\n  ): Promise<PluginSettingsState<PluginSettings>> {\n    return {\n      effectiveValues: await this.cloneSettings(state.effectiveValues),\n      inputValues: await this.cloneSettings(state.inputValues),\n      validationMessages: { ...state.validationMessages }\n    };\n  }\n\n  private createDefaultState(): PluginSettingsState<PluginSettings> {\n    return {\n      effectiveValues: this.createDefaultSettings(),\n      inputValues: this.createDefaultSettings(),\n      validationMessages: castTo<Record<PropertyNames<PluginSettings>, string>>({})\n    };\n  }\n\n  private async edit(settingsEditor: (settings: PluginSettings) => Promisable<void>): Promise<void> {\n    try {\n      await settingsEditor(this.currentState.inputValues);\n    } finally {\n      const validationResult = await this.validate(this.currentState.inputValues);\n      for (const propertyName of this.propertyNames) {\n        const validationMessage = validationResult[propertyName] ?? '';\n        this.currentState.validationMessages[propertyName] = validationMessage;\n        const defaults = this.defaultSettings as PluginSettings;\n        this.currentState.effectiveValues[propertyName] = validationMessage\n          ? defaults[propertyName]\n          : this.currentState.inputValues[propertyName];\n      }\n    }\n  }\n\n  private isValidPropertyName(prop: unknown): prop is PropertyNames<PluginSettings> {\n    if (typeof prop !== 'string') {\n      return false;\n    }\n\n    return (this.propertyNames as string[]).includes(prop);\n  }\n\n  private async rawRecordToSettings(rawRecord: GenericObject): Promise<PluginSettings> {\n    rawRecord = this.getTransformer().transformObjectRecursively(rawRecord);\n    await this.onLoadRecord(rawRecord);\n\n    const settings = this.createDefaultSettings();\n    const defaults = this.defaultSettings as PluginSettings;\n\n    for (const [propertyName, value] of Object.entries(rawRecord)) {\n      if (!this.isValidPropertyName(propertyName)) {\n        getLibDebugger('PluginSettingsComponentBase:rawRecordToSettings')(`Unknown property: ${propertyName}`);\n        continue;\n      }\n\n      if (typeof value !== typeof defaults[propertyName]) {\n        getLibDebugger('PluginSettingsComponentBase:rawRecordToSettings')(\n          'Possible invalid value type. It might lead to an unexpected behavior of the plugin. There is also a chance it is a false-negative warning, as we are unable to determine the exact type of the value in runtime.',\n          {\n            defaultValue: defaults[propertyName],\n            propertyName,\n            value\n          }\n        );\n      }\n\n      settings[propertyName] = value as PropertyValues<PluginSettings>;\n    }\n\n    return settings;\n  }\n\n  private async saveToFileImpl(): Promise<void> {\n    await this.saveDataFn(await this.settingsToRawRecord(this.currentState.inputValues));\n  }\n\n  private setPropertyImpl(\n    propertyName: PropertyNames<PluginSettings>,\n    value: PropertyValues<PluginSettings>,\n    validationMessage?: string\n  ): void {\n    const defaults = this.defaultSettings as PluginSettings;\n    this.currentState.inputValues[propertyName] = value;\n    this.currentState.validationMessages[propertyName] = validationMessage ?? '';\n    this.currentState.effectiveValues[propertyName] = validationMessage ? defaults[propertyName] : value;\n  }\n\n  private async settingsToRawRecord(settings: PluginSettings): Promise<GenericObject> {\n    const rawRecord: GenericObject = {};\n\n    for (const propertyName of this.propertyNames) {\n      rawRecord[propertyName] = settings[propertyName];\n    }\n\n    await this.onSavingRecord(rawRecord);\n\n    return this.getTransformer().transformObjectRecursively(rawRecord);\n  }\n}\n\n/**\n * A no-op settings component for plugins without settings.\n */\nexport class EmptyPluginSettingsComponent extends PluginSettingsComponentBase<object> {\n  /**\n   * Creates a new empty plugin settings component.\n   *\n   * @param params - The params. Uses no-op load/save by default.\n   */\n  public constructor(params?: PluginSettingsComponentConstructorParams) {\n    super(\n      params ?? {\n        loadData: async (): Promise<object> => {\n          await noopAsync();\n          return {};\n        },\n        saveData: noopAsync\n      }\n    );\n  }\n\n  /**\n   * Creates empty default settings.\n   *\n   * @returns An empty object.\n   */\n  protected override createDefaultSettings(): object {\n    return {};\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -16,7 +16,7 @@ import { AsyncComponentBase } from '../../components/async-component.cjs';
|
|
|
16
16
|
/**
|
|
17
17
|
* Params for creating a {@link PluginSettingsComponentBase}.
|
|
18
18
|
*/
|
|
19
|
-
export interface
|
|
19
|
+
export interface PluginSettingsComponentConstructorParams {
|
|
20
20
|
/**
|
|
21
21
|
* A function to load data from the plugin's data file.
|
|
22
22
|
*
|
|
@@ -115,7 +115,7 @@ export declare abstract class PluginSettingsComponentBase<PluginSettings extends
|
|
|
115
115
|
*
|
|
116
116
|
* @param params - The params for loading/saving data.
|
|
117
117
|
*/
|
|
118
|
-
constructor(params:
|
|
118
|
+
constructor(params: PluginSettingsComponentConstructorParams);
|
|
119
119
|
/**
|
|
120
120
|
* Edits the plugin settings and saves them.
|
|
121
121
|
*
|
|
@@ -287,7 +287,7 @@ export declare class EmptyPluginSettingsComponent extends PluginSettingsComponen
|
|
|
287
287
|
*
|
|
288
288
|
* @param params - The params. Uses no-op load/save by default.
|
|
289
289
|
*/
|
|
290
|
-
constructor(params?:
|
|
290
|
+
constructor(params?: PluginSettingsComponentConstructorParams);
|
|
291
291
|
/**
|
|
292
292
|
* Creates empty default settings.
|
|
293
293
|
*
|
|
@@ -132,29 +132,36 @@ var import_obsidian = require('obsidian');
|
|
|
132
132
|
var import_command_handler_component = require('../../command-handlers/command-handler-component.cjs');
|
|
133
133
|
var import_open_settings_command_handler = require('../../command-handlers/open-settings-command-handler.cjs');
|
|
134
134
|
class PluginSettingsTabComponent extends import_obsidian.Component {
|
|
135
|
+
plugin;
|
|
136
|
+
pluginSettingsTab;
|
|
135
137
|
/**
|
|
136
138
|
* Creates a new plugin settings tab component.
|
|
137
139
|
*
|
|
138
|
-
* @param
|
|
139
|
-
* @param settingsTab - The settings tab to register.
|
|
140
|
+
* @param params - The plugin settings tab component constructor parameters.
|
|
140
141
|
*/
|
|
141
|
-
constructor(
|
|
142
|
+
constructor(params) {
|
|
142
143
|
super();
|
|
143
|
-
this.plugin = plugin;
|
|
144
|
-
this.
|
|
144
|
+
this.plugin = params.plugin;
|
|
145
|
+
this.pluginSettingsTab = params.pluginSettingsTab;
|
|
145
146
|
}
|
|
146
|
-
plugin;
|
|
147
|
-
settingsTab;
|
|
148
147
|
/**
|
|
149
148
|
* Registers the settings tab and an "Open Settings" command with Obsidian.
|
|
150
149
|
*/
|
|
151
150
|
onload() {
|
|
152
|
-
this.plugin.addSettingTab(this.
|
|
153
|
-
this.addChild(
|
|
151
|
+
this.plugin.addSettingTab(this.pluginSettingsTab);
|
|
152
|
+
this.addChild(
|
|
153
|
+
new import_command_handler_component.CommandHandlerComponent({
|
|
154
|
+
commandHandler: new import_open_settings_command_handler.OpenSettingsCommandHandler({
|
|
155
|
+
pluginName: this.plugin.manifest.name,
|
|
156
|
+
pluginSettingsTab: this.pluginSettingsTab
|
|
157
|
+
}),
|
|
158
|
+
plugin: this.plugin
|
|
159
|
+
})
|
|
160
|
+
);
|
|
154
161
|
}
|
|
155
162
|
}
|
|
156
163
|
// Annotate the CommonJS export names for ESM import in node:
|
|
157
164
|
0 && (module.exports = {
|
|
158
165
|
PluginSettingsTabComponent
|
|
159
166
|
});
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9jb21wb25lbnRzL3BsdWdpbi1zZXR0aW5ncy10YWItY29tcG9uZW50LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBmaWxlXG4gKlxuICogQ29tcG9uZW50IHRoYXQgcmVnaXN0ZXJzIGEgcGx1Z2luIHNldHRpbmdzIHRhYiB3aXRoIE9ic2lkaWFuLlxuICogQWxzbyByZWdpc3RlcnMgYW4gXCJPcGVuIFNldHRpbmdzXCIgY29tbWFuZCBhdXRvbWF0aWNhbGx5LlxuICovXG5cbmltcG9ydCB0eXBlIHsgUGx1Z2luIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdvYnNpZGlhbic7XG5cbmltcG9ydCB0eXBlIHsgUGx1Z2luU2V0dGluZ3NUYWJCYXNlIH0gZnJvbSAnLi4vcGx1Z2luLXNldHRpbmdzLXRhYi50cyc7XG5cbmltcG9ydCB7IENvbW1hbmRIYW5kbGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tbWFuZC1oYW5kbGVycy9jb21tYW5kLWhhbmRsZXItY29tcG9uZW50LnRzJztcbmltcG9ydCB7IE9wZW5TZXR0aW5nc0NvbW1hbmRIYW5kbGVyIH0gZnJvbSAnLi4vLi4vY29tbWFuZC1oYW5kbGVycy9vcGVuLXNldHRpbmdzLWNvbW1hbmQtaGFuZGxlci50cyc7XG5cbmludGVyZmFjZSBQbHVnaW5TZXR0aW5nc1RhYkNvbXBvbmVudENvbnN0cnVjdG9yUGFyYW1zIHtcbiAgcmVhZG9ubHkgcGx1Z2luOiBQbHVnaW47XG4gIHJlYWRvbmx5IHBsdWdpblNldHRpbmdzVGFiOiBQbHVnaW5TZXR0aW5nc1RhYkJhc2U8b2JqZWN0Pjtcbn1cblxuLyoqXG4gKiBXcmFwcyBhIHtAbGluayBQbHVnaW5TZXR0aW5nc1RhYkJhc2V9IGFuZCByZWdpc3RlcnMgaXQgd2l0aCBPYnNpZGlhbiBvbiBsb2FkLlxuICogQWxzbyByZWdpc3RlcnMgYW4gXCJPcGVuIFNldHRpbmdzXCIgY29tbWFuZCB0byBvcGVuIHRoZSBzZXR0aW5ncyB0YWIgZnJvbSB0aGUgY29tbWFuZCBwYWxldHRlLlxuICovXG5leHBvcnQgY2xhc3MgUGx1Z2luU2V0dGluZ3NUYWJDb21wb25lbnQgZXh0ZW5kcyBDb21wb25lbnQge1xuICBwcml2YXRlIHJlYWRvbmx5IHBsdWdpbjogUGx1Z2luO1xuICBwcml2YXRlIHJlYWRvbmx5IHBsdWdpblNldHRpbmdzVGFiOiBQbHVnaW5TZXR0aW5nc1RhYkJhc2U8b2JqZWN0PjtcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBwbHVnaW4gc2V0dGluZ3MgdGFiIGNvbXBvbmVudC5cbiAgICpcbiAgICogQHBhcmFtIHBhcmFtcyAtIFRoZSBwbHVnaW4gc2V0dGluZ3MgdGFiIGNvbXBvbmVudCBjb25zdHJ1Y3RvciBwYXJhbWV0ZXJzLlxuICAgKi9cbiAgcHVibGljIGNvbnN0cnVjdG9yKHBhcmFtczogUGx1Z2luU2V0dGluZ3NUYWJDb21wb25lbnRDb25zdHJ1Y3RvclBhcmFtcykge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5wbHVnaW4gPSBwYXJhbXMucGx1Z2luO1xuICAgIHRoaXMucGx1Z2luU2V0dGluZ3NUYWIgPSBwYXJhbXMucGx1Z2luU2V0dGluZ3NUYWI7XG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXJzIHRoZSBzZXR0aW5ncyB0YWIgYW5kIGFuIFwiT3BlbiBTZXR0aW5nc1wiIGNvbW1hbmQgd2l0aCBPYnNpZGlhbi5cbiAgICovXG4gIHB1YmxpYyBvdmVycmlkZSBvbmxvYWQoKTogdm9pZCB7XG4gICAgdGhpcy5wbHVnaW4uYWRkU2V0dGluZ1RhYih0aGlzLnBsdWdpblNldHRpbmdzVGFiKTtcbiAgICB0aGlzLmFkZENoaWxkKFxuICAgICAgbmV3IENvbW1hbmRIYW5kbGVyQ29tcG9uZW50KHtcbiAgICAgICAgY29tbWFuZEhhbmRsZXI6IG5ldyBPcGVuU2V0dGluZ3NDb21tYW5kSGFuZGxlcih7XG4gICAgICAgICAgcGx1Z2luTmFtZTogdGhpcy5wbHVnaW4ubWFuaWZlc3QubmFtZSxcbiAgICAgICAgICBwbHVnaW5TZXR0aW5nc1RhYjogdGhpcy5wbHVnaW5TZXR0aW5nc1RhYlxuICAgICAgICB9KSxcbiAgICAgICAgcGx1Z2luOiB0aGlzLnBsdWdpblxuICAgICAgfSlcbiAgICApO1xuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFTQSxzQkFBMEI7QUFJMUIsdUNBQXdDO0FBQ3hDLDJDQUEyQztBQVdwQyxNQUFNLG1DQUFtQywwQkFBVTtBQUFBLEVBQ3ZDO0FBQUEsRUFDQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQU9WLFlBQVksUUFBcUQ7QUFDdEUsVUFBTTtBQUNOLFNBQUssU0FBUyxPQUFPO0FBQ3JCLFNBQUssb0JBQW9CLE9BQU87QUFBQSxFQUNsQztBQUFBO0FBQUE7QUFBQTtBQUFBLEVBS2dCLFNBQWU7QUFDN0IsU0FBSyxPQUFPLGNBQWMsS0FBSyxpQkFBaUI7QUFDaEQsU0FBSztBQUFBLE1BQ0gsSUFBSSx5REFBd0I7QUFBQSxRQUMxQixnQkFBZ0IsSUFBSSxnRUFBMkI7QUFBQSxVQUM3QyxZQUFZLEtBQUssT0FBTyxTQUFTO0FBQUEsVUFDakMsbUJBQW1CLEtBQUs7QUFBQSxRQUMxQixDQUFDO0FBQUEsUUFDRCxRQUFRLEtBQUs7QUFBQSxNQUNmLENBQUM7QUFBQSxJQUNIO0FBQUEsRUFDRjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -7,22 +7,26 @@
|
|
|
7
7
|
import type { Plugin } from 'obsidian';
|
|
8
8
|
import { Component } from 'obsidian';
|
|
9
9
|
import type { PluginSettingsTabBase } from '../plugin-settings-tab.cjs';
|
|
10
|
+
interface PluginSettingsTabComponentConstructorParams {
|
|
11
|
+
readonly plugin: Plugin;
|
|
12
|
+
readonly pluginSettingsTab: PluginSettingsTabBase<object>;
|
|
13
|
+
}
|
|
10
14
|
/**
|
|
11
15
|
* Wraps a {@link PluginSettingsTabBase} and registers it with Obsidian on load.
|
|
12
16
|
* Also registers an "Open Settings" command to open the settings tab from the command palette.
|
|
13
17
|
*/
|
|
14
18
|
export declare class PluginSettingsTabComponent extends Component {
|
|
15
19
|
private readonly plugin;
|
|
16
|
-
readonly
|
|
20
|
+
private readonly pluginSettingsTab;
|
|
17
21
|
/**
|
|
18
22
|
* Creates a new plugin settings tab component.
|
|
19
23
|
*
|
|
20
|
-
* @param
|
|
21
|
-
* @param settingsTab - The settings tab to register.
|
|
24
|
+
* @param params - The plugin settings tab component constructor parameters.
|
|
22
25
|
*/
|
|
23
|
-
constructor(
|
|
26
|
+
constructor(params: PluginSettingsTabComponentConstructorParams);
|
|
24
27
|
/**
|
|
25
28
|
* Registers the settings tab and an "Open Settings" command with Obsidian.
|
|
26
29
|
*/
|
|
27
30
|
onload(): void;
|
|
28
31
|
}
|
|
32
|
+
export {};
|
|
@@ -137,8 +137,14 @@ var import_library = require('../../library.cjs');
|
|
|
137
137
|
var import_app = require('../app.cjs');
|
|
138
138
|
var import_plugin_id = require('./plugin-id.cjs');
|
|
139
139
|
const STYLES_ID = `${import_library.LIBRARY_NAME}-styles`;
|
|
140
|
-
function addPluginCssClasses(el,
|
|
141
|
-
|
|
140
|
+
function addPluginCssClasses(el, cssClasses) {
|
|
141
|
+
const cssClassesArr = [import_css_class.CssClass.LibraryName, (0, import_plugin_id.getPluginId)()];
|
|
142
|
+
if (Array.isArray(cssClasses)) {
|
|
143
|
+
cssClassesArr.push(...cssClasses);
|
|
144
|
+
} else if (typeof cssClasses === "string") {
|
|
145
|
+
cssClassesArr.push(cssClasses);
|
|
146
|
+
}
|
|
147
|
+
el.addClass(...cssClassesArr);
|
|
142
148
|
}
|
|
143
149
|
function initDebugController(win, component) {
|
|
144
150
|
const pluginContextWindow = win;
|
|
@@ -173,4 +179,4 @@ function initPluginContext(app, pluginId) {
|
|
|
173
179
|
initDebugController,
|
|
174
180
|
initPluginContext
|
|
175
181
|
});
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9wbHVnaW4tY29udGV4dC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAZmlsZVxuICpcbiAqIEluaXRpYWxpemVzIHRoZSBwbHVnaW4gY29udGV4dCBhbmQgc2V0cyB1cCB0aGUgcGx1Z2luIElELlxuICovXG5cbmltcG9ydCB0eXBlIHtcbiAgQXBwLFxuICBDb21wb25lbnRcbn0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgeyBjb21wYXJlVmVyc2lvbnMgfSBmcm9tICdjb21wYXJlLXZlcnNpb25zJztcblxuaW1wb3J0IHR5cGUgeyBEZWJ1Z0NvbnRyb2xsZXIgfSBmcm9tICcuLi8uLi9kZWJ1Zy1jb250cm9sbGVyLnRzJztcblxuaW1wb3J0IHsgQ3NzQ2xhc3MgfSBmcm9tICcuLi8uLi9jc3MtY2xhc3MudHMnO1xuaW1wb3J0IHtcbiAgZ2V0RGVidWdDb250cm9sbGVyLFxuICBzaG93SW5pdGlhbERlYnVnTWVzc2FnZVxufSBmcm9tICcuLi8uLi9kZWJ1Zy50cyc7XG5pbXBvcnQge1xuICBMSUJSQVJZX05BTUUsXG4gIExJQlJBUllfU1RZTEVTLFxuICBMSUJSQVJZX1ZFUlNJT05cbn0gZnJvbSAnLi4vLi4vbGlicmFyeS50cyc7XG5pbXBvcnQgeyBnZXRPYnNpZGlhbkRldlV0aWxzU3RhdGUgfSBmcm9tICcuLi9hcHAudHMnO1xuaW1wb3J0IHtcbiAgZ2V0UGx1Z2luSWQsXG4gIHNldFBsdWdpbklkXG59IGZyb20gJy4vcGx1Z2luLWlkLnRzJztcblxuaW50ZXJmYWNlIFBsdWdpbkNvbnRleHRXaW5kb3cge1xuICBERUJVRzogRGVidWdDb250cm9sbGVyIHwgdW5kZWZpbmVkO1xufVxuXG5jb25zdCBTVFlMRVNfSUQgPSBgJHtMSUJSQVJZX05BTUV9LXN0eWxlc2A7XG5cbi8qKlxuICogU2V0cyB0aGUgQ1NTIGNsYXNzIG9mIGFuIGVsZW1lbnQuXG4gKlxuICogQHBhcmFtIGVsIC0gVGhlIGVsZW1lbnQgdG8gc2V0IHRoZSBDU1MgY2xhc3Mgb2YuXG4gKiBAcGFyYW0gY3NzQ2xhc3NlcyAtIFRoZSBDU1MgY2xhc3NlcyB0byBzZXQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhZGRQbHVnaW5Dc3NDbGFzc2VzKGVsOiBIVE1MRWxlbWVudCwgY3NzQ2xhc3Nlcz86IHN0cmluZyB8IHN0cmluZ1tdKTogdm9pZCB7XG4gIGNvbnN0IGNzc0NsYXNzZXNBcnIgPSBbQ3NzQ2xhc3MuTGlicmFyeU5hbWUsIGdldFBsdWdpbklkKCldO1xuICBpZiAoQXJyYXkuaXNBcnJheShjc3NDbGFzc2VzKSkge1xuICAgIGNzc0NsYXNzZXNBcnIucHVzaCguLi5jc3NDbGFzc2VzKTtcbiAgfSBlbHNlIGlmICh0eXBlb2YgY3NzQ2xhc3NlcyA9PT0gJ3N0cmluZycpIHtcbiAgICBjc3NDbGFzc2VzQXJyLnB1c2goY3NzQ2xhc3Nlcyk7XG4gIH1cbiAgZWwuYWRkQ2xhc3MoLi4uY3NzQ2xhc3Nlc0Fycik7XG59XG5cbi8qKlxuICogSW5pdGlhbGl6ZXMgdGhlIGRlYnVnIGNvbnRyb2xsZXIuXG4gKlxuICogQHBhcmFtIHdpbiAtIFRoZSB3aW5kb3cgdG8gaW5pdGlhbGl6ZSB0aGUgZGVidWcgY29udHJvbGxlciBmb3IuXG4gKiBAcGFyYW0gY29tcG9uZW50IC0gVGhlIGNvbXBvbmVudCB0byByZWdpc3RlciBjbGVhbnVwIG9uLlxuICovXG5leHBvcnQgZnVuY3Rpb24gaW5pdERlYnVnQ29udHJvbGxlcih3aW46IFdpbmRvdywgY29tcG9uZW50OiBDb21wb25lbnQpOiB2b2lkIHtcbiAgY29uc3QgcGx1Z2luQ29udGV4dFdpbmRvdyA9IHdpbiBhcyBQYXJ0aWFsPFBsdWdpbkNvbnRleHRXaW5kb3c+O1xuICBjb25zdCBvbGREZWJ1ZyA9IHBsdWdpbkNvbnRleHRXaW5kb3cuREVCVUc7XG4gIGNvbnN0IG5ld0RlYnVnID0gZ2V0RGVidWdDb250cm9sbGVyKCk7XG4gIHBsdWdpbkNvbnRleHRXaW5kb3cuREVCVUcgPSBuZXdEZWJ1ZztcblxuICBjb21wb25lbnQucmVnaXN0ZXIoKCkgPT4ge1xuICAgIGlmIChwbHVnaW5Db250ZXh0V2luZG93LkRFQlVHID09PSBuZXdEZWJ1Zykge1xuICAgICAgcGx1Z2luQ29udGV4dFdpbmRvdy5ERUJVRyA9IG9sZERlYnVnO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogSW5pdGlhbGl6ZXMgdGhlIHBsdWdpbiBjb250ZXh0LlxuICpcbiAqIEBwYXJhbSBhcHAgLSBUaGUgT2JzaWRpYW4gYXBwIGluc3RhbmNlLlxuICogQHBhcmFtIHBsdWdpbklkIC0gVGhlIHBsdWdpbiBJRC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluaXRQbHVnaW5Db250ZXh0KGFwcDogQXBwLCBwbHVnaW5JZDogc3RyaW5nKTogdm9pZCB7XG4gIHNldFBsdWdpbklkKHBsdWdpbklkKTtcbiAgc2hvd0luaXRpYWxEZWJ1Z01lc3NhZ2UocGx1Z2luSWQpO1xuXG4gIGNvbnN0IGxhc3RMaWJyYXJ5VmVyc2lvbldyYXBwZXIgPSBnZXRPYnNpZGlhbkRldlV0aWxzU3RhdGUoYXBwLCAnbGFzdExpYnJhcnlWZXJzaW9uJywgJzAuMC4wJyk7XG4gIGlmIChjb21wYXJlVmVyc2lvbnMoTElCUkFSWV9WRVJTSU9OLCBsYXN0TGlicmFyeVZlcnNpb25XcmFwcGVyLnZhbHVlKSA8PSAwKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgbGFzdExpYnJhcnlWZXJzaW9uV3JhcHBlci52YWx1ZSA9IExJQlJBUllfVkVSU0lPTjtcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgb2JzaWRpYW5tZC9wcmVmZXItYWN0aXZlLWRvYyAtLSBOZWVkIHRvIGFjY2VzcyBkb2N1bWVudC5cbiAgZG9jdW1lbnQuaGVhZC5xdWVyeVNlbGVjdG9yKGAjJHtTVFlMRVNfSUR9YCk/LnJlbW92ZSgpO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgb2JzaWRpYW5tZC9uby1mb3JiaWRkZW4tZWxlbWVudHMsIG9ic2lkaWFubWQvcHJlZmVyLWFjdGl2ZS1kb2MgLS0gV2UgbmVlZCB0byBjcmVhdGUgYSBzdHlsZSBlbGVtZW50IHRvIGFwcGx5IHRoZSBsaWJyYXJ5IHN0eWxlcy5cbiAgZG9jdW1lbnQuaGVhZC5jcmVhdGVFbCgnc3R5bGUnLCB7XG4gICAgYXR0cjoge1xuICAgICAgaWQ6IFNUWUxFU19JRFxuICAgIH0sXG4gICAgdGV4dDogTElCUkFSWV9TVFlMRVNcbiAgfSk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBV0EsOEJBQWdDO0FBSWhDLHVCQUF5QjtBQUN6QixtQkFHTztBQUNQLHFCQUlPO0FBQ1AsaUJBQXlDO0FBQ3pDLHVCQUdPO0FBTVAsTUFBTSxZQUFZLEdBQUcsMkJBQVk7QUFRMUIsU0FBUyxvQkFBb0IsSUFBaUIsWUFBc0M7QUFDekYsUUFBTSxnQkFBZ0IsQ0FBQywwQkFBUyxpQkFBYSw4QkFBWSxDQUFDO0FBQzFELE1BQUksTUFBTSxRQUFRLFVBQVUsR0FBRztBQUM3QixrQkFBYyxLQUFLLEdBQUcsVUFBVTtBQUFBLEVBQ2xDLFdBQVcsT0FBTyxlQUFlLFVBQVU7QUFDekMsa0JBQWMsS0FBSyxVQUFVO0FBQUEsRUFDL0I7QUFDQSxLQUFHLFNBQVMsR0FBRyxhQUFhO0FBQzlCO0FBUU8sU0FBUyxvQkFBb0IsS0FBYSxXQUE0QjtBQUMzRSxRQUFNLHNCQUFzQjtBQUM1QixRQUFNLFdBQVcsb0JBQW9CO0FBQ3JDLFFBQU0sZUFBVyxpQ0FBbUI7QUFDcEMsc0JBQW9CLFFBQVE7QUFFNUIsWUFBVSxTQUFTLE1BQU07QUFDdkIsUUFBSSxvQkFBb0IsVUFBVSxVQUFVO0FBQzFDLDBCQUFvQixRQUFRO0FBQUEsSUFDOUI7QUFBQSxFQUNGLENBQUM7QUFDSDtBQVFPLFNBQVMsa0JBQWtCLEtBQVUsVUFBd0I7QUFDbEUsb0NBQVksUUFBUTtBQUNwQiw0Q0FBd0IsUUFBUTtBQUVoQyxRQUFNLGdDQUE0QixxQ0FBeUIsS0FBSyxzQkFBc0IsT0FBTztBQUM3RixVQUFJLHlDQUFnQixnQ0FBaUIsMEJBQTBCLEtBQUssS0FBSyxHQUFHO0FBQzFFO0FBQUEsRUFDRjtBQUVBLDRCQUEwQixRQUFRO0FBR2xDLFdBQVMsS0FBSyxjQUFjLElBQUksU0FBUyxFQUFFLEdBQUcsT0FBTztBQUVyRCxXQUFTLEtBQUssU0FBUyxTQUFTO0FBQUEsSUFDOUIsTUFBTTtBQUFBLE1BQ0osSUFBSTtBQUFBLElBQ047QUFBQSxJQUNBLE1BQU07QUFBQSxFQUNSLENBQUM7QUFDSDsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -10,7 +10,7 @@ import type { App, Component } from 'obsidian';
|
|
|
10
10
|
* @param el - The element to set the CSS class of.
|
|
11
11
|
* @param cssClasses - The CSS classes to set.
|
|
12
12
|
*/
|
|
13
|
-
export declare function addPluginCssClasses(el: HTMLElement,
|
|
13
|
+
export declare function addPluginCssClasses(el: HTMLElement, cssClasses?: string | string[]): void;
|
|
14
14
|
/**
|
|
15
15
|
* Initializes the debug controller.
|
|
16
16
|
*
|