obsidian-dev-utils 22.1.0 → 22.1.1-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +11 -0
- package/dist/lib/cjs/Async.cjs +2 -2
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/Object.cjs +1 -1
- package/dist/lib/cjs/Object.d.cts +6 -0
- package/dist/lib/cjs/codemirror/StateFieldSpec.cjs +1 -1
- package/dist/lib/cjs/codemirror/StateFieldSpec.d.cts +4 -4
- package/dist/lib/cjs/obsidian/Modals/Prompt.cjs +1 -1
- package/dist/lib/cjs/obsidian/Modals/Prompt.d.cts +1 -1
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +9 -35
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +10 -30
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +161 -0
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +41 -0
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +34 -48
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.d.cts +13 -32
- package/dist/lib/cjs/obsidian/Plugin/index.cjs +4 -7
- package/dist/lib/cjs/obsidian/Plugin/index.d.cts +1 -2
- package/dist/lib/cjs/obsidian/Vault.cjs +2 -2
- package/dist/lib/esm/Async.mjs +2 -2
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/Object.d.mts +6 -0
- package/dist/lib/esm/Object.mjs +1 -1
- package/dist/lib/esm/codemirror/StateFieldSpec.d.mts +4 -4
- package/dist/lib/esm/obsidian/Modals/Prompt.d.mts +1 -1
- package/dist/lib/esm/obsidian/Modals/Prompt.mjs +1 -1
- package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +10 -30
- package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +9 -35
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +41 -0
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +137 -0
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.d.mts +13 -32
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +35 -52
- package/dist/lib/esm/obsidian/Plugin/index.d.mts +1 -2
- package/dist/lib/esm/obsidian/Plugin/index.mjs +3 -5
- package/dist/lib/esm/obsidian/Vault.mjs +2 -2
- package/obsidian/Plugin/{PluginSettingsBase → PluginSettingsManagerBase}/package.json +3 -3
- package/package.json +7 -7
- package/dist/lib/cjs/obsidian/Plugin/EmptySettings.cjs +0 -38
- package/dist/lib/cjs/obsidian/Plugin/EmptySettings.d.cts +0 -14
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsBase.cjs +0 -92
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsBase.d.cts +0 -31
- package/dist/lib/esm/obsidian/Plugin/EmptySettings.d.mts +0 -14
- package/dist/lib/esm/obsidian/Plugin/EmptySettings.mjs +0 -14
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsBase.d.mts +0 -31
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsBase.mjs +0 -68
- package/obsidian/Plugin/EmptySettings/package.json +0 -6
@@ -9,14 +9,13 @@
|
|
9
9
|
import type { PluginSettingTab } from 'obsidian';
|
10
10
|
import type { Promisable, ReadonlyDeep } from 'type-fest';
|
11
11
|
import { Plugin } from 'obsidian';
|
12
|
-
import
|
13
|
-
import type { PluginSettingsBase } from './PluginSettingsBase.cjs';
|
12
|
+
import { PluginSettingsManagerBase } from './PluginSettingsManagerBase.cjs';
|
14
13
|
/**
|
15
14
|
* Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.
|
16
15
|
*
|
17
16
|
* @typeParam PluginSettings - The type representing the plugin settings object.
|
18
17
|
*/
|
19
|
-
export declare abstract class PluginBase<PluginSettings extends
|
18
|
+
export declare abstract class PluginBase<PluginSettings extends object = object> extends Plugin {
|
20
19
|
/**
|
21
20
|
* Gets the AbortSignal used for aborting long-running operations.
|
22
21
|
*
|
@@ -29,14 +28,9 @@ export declare abstract class PluginBase<PluginSettings extends PluginSettingsBa
|
|
29
28
|
* @returns The readonly plugin settings.
|
30
29
|
*/
|
31
30
|
get settings(): ReadonlyDeep<PluginSettings>;
|
32
|
-
|
33
|
-
* Gets a writable copy of the plugin settings.
|
34
|
-
*
|
35
|
-
* @returns A writable copy of the plugin settings.
|
36
|
-
*/
|
37
|
-
get settingsClone(): PluginSettings;
|
31
|
+
get settingsManager(): PluginSettingsManagerBase<PluginSettings>;
|
38
32
|
private _abortSignal;
|
39
|
-
private
|
33
|
+
private _settingsManager;
|
40
34
|
private notice?;
|
41
35
|
/**
|
42
36
|
* Logs a message to the console.
|
@@ -59,26 +53,18 @@ export declare abstract class PluginBase<PluginSettings extends PluginSettingsBa
|
|
59
53
|
* Called when the plugin is loaded
|
60
54
|
*/
|
61
55
|
onload(): Promise<void>;
|
62
|
-
/**
|
63
|
-
* Saves the new plugin settings.
|
64
|
-
*
|
65
|
-
* @param newSettings - The new settings to save.
|
66
|
-
* @returns A promise that resolves when the settings are saved.
|
67
|
-
*/
|
68
|
-
saveSettings(newSettings: PluginSettings): Promise<void>;
|
69
|
-
/**
|
70
|
-
* Creates the plugin settings. This method must be implemented by subclasses.
|
71
|
-
*
|
72
|
-
* @param data - The data to create the plugin settings from.
|
73
|
-
* @returns The plugin settings.
|
74
|
-
*/
|
75
|
-
protected abstract createPluginSettings(data: unknown): PluginSettings;
|
76
56
|
/**
|
77
57
|
* Creates a plugin settings tab. This method must be implemented by subclasses.
|
78
58
|
*
|
79
59
|
* @returns The settings tab or null if not applicable.
|
80
60
|
*/
|
81
61
|
protected abstract createPluginSettingsTab(): null | PluginSettingTab;
|
62
|
+
/**
|
63
|
+
* Creates the plugin settings manager. This method must be implemented by subclasses.
|
64
|
+
*
|
65
|
+
* @returns The plugin settings manager.
|
66
|
+
*/
|
67
|
+
protected abstract createSettingsManager(): PluginSettingsManagerBase<PluginSettings>;
|
82
68
|
/**
|
83
69
|
* Called when the layout is ready. This method can be overridden by subclasses to perform actions once
|
84
70
|
* the layout is ready.
|
@@ -99,10 +85,4 @@ export declare abstract class PluginBase<PluginSettings extends PluginSettingsBa
|
|
99
85
|
* @param message - The message to display.
|
100
86
|
*/
|
101
87
|
protected showNotice(message: string): void;
|
102
|
-
/**
|
103
|
-
* Loads the plugin settings from the saved data.
|
104
|
-
*
|
105
|
-
* @returns A promise that resolves when the settings are loaded.
|
106
|
-
*/
|
107
|
-
private loadSettings;
|
108
88
|
}
|
@@ -0,0 +1,161 @@
|
|
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(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;const originalRequire=require;if(originalRequire&&!originalRequire.__isPatched){require=Object.assign(id=>requirePatched(id),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>{const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};return browserProcess},"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id){const module=originalRequire?.(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})();
|
7
|
+
|
8
|
+
"use strict";
|
9
|
+
var __defProp = Object.defineProperty;
|
10
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
11
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
12
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
13
|
+
var __export = (target, all) => {
|
14
|
+
for (var name in all)
|
15
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
16
|
+
};
|
17
|
+
var __copyProps = (to, from, except, desc) => {
|
18
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
19
|
+
for (let key of __getOwnPropNames(from))
|
20
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
21
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
22
|
+
}
|
23
|
+
return to;
|
24
|
+
};
|
25
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
26
|
+
var PluginSettingsManagerBase_exports = {};
|
27
|
+
__export(PluginSettingsManagerBase_exports, {
|
28
|
+
PluginSettingsManagerBase: () => PluginSettingsManagerBase
|
29
|
+
});
|
30
|
+
module.exports = __toCommonJS(PluginSettingsManagerBase_exports);
|
31
|
+
var import_obsidian = require('obsidian');
|
32
|
+
var import_Function = require('../../Function.cjs');
|
33
|
+
var import_DateTransformer = require('../../Transformers/DateTransformer.cjs');
|
34
|
+
var import_DurationTransformer = require('../../Transformers/DurationTransformer.cjs');
|
35
|
+
var import_GroupTransformer = require('../../Transformers/GroupTransformer.cjs');
|
36
|
+
var import_SkipPrivatePropertyTransformer = require('../../Transformers/SkipPrivatePropertyTransformer.cjs');
|
37
|
+
const defaultTransformer = new import_GroupTransformer.GroupTransformer([
|
38
|
+
new import_SkipPrivatePropertyTransformer.SkipPrivatePropertyTransformer(),
|
39
|
+
new import_DateTransformer.DateTransformer(),
|
40
|
+
new import_DurationTransformer.DurationTransformer()
|
41
|
+
]);
|
42
|
+
class PluginSettingsProperty {
|
43
|
+
constructor(manager, property, defaultValue) {
|
44
|
+
this.manager = manager;
|
45
|
+
this.property = property;
|
46
|
+
this.defaultValue = defaultValue;
|
47
|
+
}
|
48
|
+
validationMessage = "";
|
49
|
+
value;
|
50
|
+
clear() {
|
51
|
+
this.value = void 0;
|
52
|
+
this.validationMessage = "";
|
53
|
+
}
|
54
|
+
get() {
|
55
|
+
return this.value ?? this.defaultValue;
|
56
|
+
}
|
57
|
+
getSafe() {
|
58
|
+
return this.validationMessage ? this.defaultValue : this.get();
|
59
|
+
}
|
60
|
+
async set(value) {
|
61
|
+
this.value = value;
|
62
|
+
if (this.value !== void 0) {
|
63
|
+
this.validationMessage = await this.manager.validate(this.property, this.value) ?? "";
|
64
|
+
}
|
65
|
+
}
|
66
|
+
}
|
67
|
+
class PropertiesMap extends Map {
|
68
|
+
getTyped(key) {
|
69
|
+
const property = super.get(key);
|
70
|
+
if (!property) {
|
71
|
+
throw new Error(`Property ${String(key)} not found`);
|
72
|
+
}
|
73
|
+
return property;
|
74
|
+
}
|
75
|
+
setTyped(key, value) {
|
76
|
+
return super.set(key, value);
|
77
|
+
}
|
78
|
+
}
|
79
|
+
class PluginSettingsManagerBase {
|
80
|
+
constructor(plugin) {
|
81
|
+
this.plugin = plugin;
|
82
|
+
const defaultSettings = this.createDefaultSettings();
|
83
|
+
this.properties = new PropertiesMap();
|
84
|
+
for (const key of Object.keys(defaultSettings)) {
|
85
|
+
this.properties.set(key, new PluginSettingsProperty(this, key, defaultSettings[key]));
|
86
|
+
}
|
87
|
+
this.safeSettings = new Proxy(defaultSettings, {
|
88
|
+
get: (_target, prop) => {
|
89
|
+
if (typeof prop !== "string") {
|
90
|
+
return void 0;
|
91
|
+
}
|
92
|
+
return this.properties.get(prop);
|
93
|
+
}
|
94
|
+
});
|
95
|
+
}
|
96
|
+
safeSettings;
|
97
|
+
properties;
|
98
|
+
getProperty(property) {
|
99
|
+
return this.properties.getTyped(property);
|
100
|
+
}
|
101
|
+
async loadFromFile() {
|
102
|
+
for (const property of this.properties.values()) {
|
103
|
+
property.clear();
|
104
|
+
}
|
105
|
+
const data = await this.plugin.loadData();
|
106
|
+
if (data === void 0 || data === null) {
|
107
|
+
return;
|
108
|
+
}
|
109
|
+
if (typeof data !== "object" || Array.isArray(data)) {
|
110
|
+
const type = Array.isArray(data) ? "Array" : typeof data;
|
111
|
+
console.error(`Invalid data type. Expected Object, got: ${type}`);
|
112
|
+
return;
|
113
|
+
}
|
114
|
+
let record = data;
|
115
|
+
record = this.getTransformer().transformObjectRecursively(record);
|
116
|
+
await this.prepareRecord(record);
|
117
|
+
for (const [key, value] of Object.entries(record)) {
|
118
|
+
const propertyObj = this.properties.get(key);
|
119
|
+
if (!propertyObj) {
|
120
|
+
console.warn(`Unknown property: ${key}`);
|
121
|
+
continue;
|
122
|
+
}
|
123
|
+
if (typeof value !== typeof propertyObj.defaultValue) {
|
124
|
+
console.warn(`Invalid value type. Expected ${typeof propertyObj.defaultValue}, got: ${typeof value}`);
|
125
|
+
continue;
|
126
|
+
}
|
127
|
+
await propertyObj.set(value);
|
128
|
+
}
|
129
|
+
}
|
130
|
+
/**
|
131
|
+
* Saves the new plugin settings.
|
132
|
+
*
|
133
|
+
* @returns A promise that resolves when the settings are saved.
|
134
|
+
*/
|
135
|
+
async saveToFile() {
|
136
|
+
const record = this.getTransformer().transformObjectRecursively(this.getSettings());
|
137
|
+
await this.plugin.saveData(record);
|
138
|
+
}
|
139
|
+
// eslint-disable-next-line @typescript-eslint/no-invalid-void-type
|
140
|
+
async validate(_property, _value) {
|
141
|
+
await (0, import_Function.noopAsync)();
|
142
|
+
}
|
143
|
+
getTransformer() {
|
144
|
+
return defaultTransformer;
|
145
|
+
}
|
146
|
+
async prepareRecord(_record) {
|
147
|
+
await (0, import_Function.noopAsync)();
|
148
|
+
}
|
149
|
+
getSettings() {
|
150
|
+
const settings = {};
|
151
|
+
for (const [key, property] of this.properties.entries()) {
|
152
|
+
settings[key] = property.get();
|
153
|
+
}
|
154
|
+
return settings;
|
155
|
+
}
|
156
|
+
}
|
157
|
+
// Annotate the CommonJS export names for ESM import in node:
|
158
|
+
0 && (module.exports = {
|
159
|
+
PluginSettingsManagerBase
|
160
|
+
});
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsManagerBase.ts"],
  "sourcesContent": ["import type { ReadonlyDeep } from 'type-fest';\n\nimport { Plugin } from 'obsidian';\n\nimport type { StringKeys } from '../../Object.ts';\nimport type { Transformer } from '../../Transformers/Transformer.ts';\n\nimport { noopAsync } from '../../Function.ts';\nimport { DateTransformer } from '../../Transformers/DateTransformer.ts';\nimport { DurationTransformer } from '../../Transformers/DurationTransformer.ts';\nimport { GroupTransformer } from '../../Transformers/GroupTransformer.ts';\nimport { SkipPrivatePropertyTransformer } from '../../Transformers/SkipPrivatePropertyTransformer.ts';\n\nconst defaultTransformer = new GroupTransformer([\n  new SkipPrivatePropertyTransformer(),\n  new DateTransformer(),\n  new DurationTransformer()\n]);\n\nclass PluginSettingsProperty<PluginSettings extends object, Property extends StringKeys<PluginSettings>> {\n  public validationMessage = '';\n  private value: PluginSettings[Property] | undefined;\n\n  public constructor(\n    private readonly manager: PluginSettingsManagerBase<PluginSettings>,\n    private readonly property: Property,\n    public readonly defaultValue: PluginSettings[Property]\n  ) {}\n\n  public clear(): void {\n    this.value = undefined;\n    this.validationMessage = '';\n  }\n\n  public get(): PluginSettings[Property] {\n    return this.value ?? this.defaultValue;\n  }\n\n  public getSafe(): PluginSettings[Property] {\n    return this.validationMessage ? this.defaultValue : this.get();\n  }\n\n  public async set(value: PluginSettings[Property] | undefined): Promise<void> {\n    this.value = value;\n    if (this.value !== undefined) {\n      this.validationMessage = (await this.manager.validate(this.property, this.value) as string | undefined) ?? '';\n    }\n  }\n}\n\nclass PropertiesMap<PluginSettings extends object> extends Map<string, PluginSettingsProperty<PluginSettings, StringKeys<PluginSettings>>> {\n  public getTyped<Property extends StringKeys<PluginSettings>>(key: Property): PluginSettingsProperty<PluginSettings, Property> {\n    const property = super.get(key);\n    if (!property) {\n      throw new Error(`Property ${String(key)} not found`);\n    }\n\n    return property as PluginSettingsProperty<PluginSettings, Property>;\n  }\n\n  public setTyped<Property extends StringKeys<PluginSettings>>(key: Property, value: PluginSettingsProperty<PluginSettings, Property>): this {\n    return super.set(key, value);\n  }\n}\n\n/**\n * Base class for managing plugin settings.\n *\n * @typeParam PluginSettings - The type representing the plugin settings object.\n */\nexport abstract class PluginSettingsManagerBase<PluginSettings extends object> {\n  public readonly safeSettings: ReadonlyDeep<PluginSettings>;\n\n  private properties: PropertiesMap<PluginSettings>;\n\n  public constructor(private plugin: Plugin) {\n    const defaultSettings = this.createDefaultSettings();\n    this.properties = new PropertiesMap<PluginSettings>();\n\n    for (const key of Object.keys(defaultSettings) as StringKeys<PluginSettings>[]) {\n      this.properties.set(key, new PluginSettingsProperty(this, key, defaultSettings[key]));\n    }\n\n    this.safeSettings = new Proxy(defaultSettings, {\n      get: (_target, prop): unknown => {\n        if (typeof prop !== 'string') {\n          return undefined;\n        }\n\n        return this.properties.get(prop);\n      }\n    }) as ReadonlyDeep<PluginSettings>;\n  }\n\n  public getProperty<Property extends StringKeys<PluginSettings>>(property: Property): PluginSettingsProperty<PluginSettings, Property> {\n    return this.properties.getTyped(property);\n  }\n\n  public async loadFromFile(): Promise<void> {\n    for (const property of this.properties.values()) {\n      property.clear();\n    }\n\n    const data = await this.plugin.loadData() as unknown;\n\n    if (data === undefined || data === null) {\n      return;\n    }\n\n    if (typeof data !== 'object' || Array.isArray(data)) {\n      const type = Array.isArray(data) ? 'Array' : typeof data;\n      console.error(`Invalid data type. Expected Object, got: ${type}`);\n      return;\n    }\n\n    let record = data as Record<string, unknown>;\n    record = this.getTransformer().transformObjectRecursively(record);\n    await this.prepareRecord(record);\n\n    for (const [key, value] of Object.entries(record)) {\n      const propertyObj = this.properties.get(key);\n      if (!propertyObj) {\n        console.warn(`Unknown property: ${key}`);\n        continue;\n      }\n\n      if (typeof value !== typeof propertyObj.defaultValue) {\n        console.warn(`Invalid value type. Expected ${typeof propertyObj.defaultValue}, got: ${typeof value}`);\n        continue;\n      }\n\n      await propertyObj.set(value as PluginSettings[StringKeys<PluginSettings>]);\n    }\n  }\n\n  /**\n   * Saves the new plugin settings.\n   *\n   * @returns A promise that resolves when the settings are saved.\n   */\n  public async saveToFile(): Promise<void> {\n    const record = this.getTransformer().transformObjectRecursively(this.getSettings());\n    await this.plugin.saveData(record);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  public async validate<Property extends StringKeys<PluginSettings>>(_property: Property, _value: PluginSettings[Property]): Promise<string | void> {\n    await noopAsync();\n  }\n\n  protected abstract createDefaultSettings(): PluginSettings;\n\n  protected getTransformer(): Transformer {\n    return defaultTransformer;\n  }\n\n  protected async prepareRecord(_record: Record<string, unknown>): Promise<void> {\n    await noopAsync();\n  }\n\n  private getSettings(): Record<StringKeys<PluginSettings>, unknown> {\n    const settings: Record<StringKeys<PluginSettings>, unknown> = {} as Record<StringKeys<PluginSettings>, unknown>;\n    for (const [key, property] of this.properties.entries()) {\n      settings[key as StringKeys<PluginSettings>] = property.get();\n    }\n\n    return settings;\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
@@ -0,0 +1,41 @@
|
|
1
|
+
import type { ReadonlyDeep } from 'type-fest';
|
2
|
+
import { Plugin } from 'obsidian';
|
3
|
+
import type { StringKeys } from '../../Object.cjs';
|
4
|
+
import type { Transformer } from '../../Transformers/Transformer.cjs';
|
5
|
+
declare class PluginSettingsProperty<PluginSettings extends object, Property extends StringKeys<PluginSettings>> {
|
6
|
+
private readonly manager;
|
7
|
+
private readonly property;
|
8
|
+
readonly defaultValue: PluginSettings[Property];
|
9
|
+
validationMessage: string;
|
10
|
+
private value;
|
11
|
+
constructor(manager: PluginSettingsManagerBase<PluginSettings>, property: Property, defaultValue: PluginSettings[Property]);
|
12
|
+
clear(): void;
|
13
|
+
get(): PluginSettings[Property];
|
14
|
+
getSafe(): PluginSettings[Property];
|
15
|
+
set(value: PluginSettings[Property] | undefined): Promise<void>;
|
16
|
+
}
|
17
|
+
/**
|
18
|
+
* Base class for managing plugin settings.
|
19
|
+
*
|
20
|
+
* @typeParam PluginSettings - The type representing the plugin settings object.
|
21
|
+
*/
|
22
|
+
export declare abstract class PluginSettingsManagerBase<PluginSettings extends object> {
|
23
|
+
private plugin;
|
24
|
+
readonly safeSettings: ReadonlyDeep<PluginSettings>;
|
25
|
+
private properties;
|
26
|
+
constructor(plugin: Plugin);
|
27
|
+
getProperty<Property extends StringKeys<PluginSettings>>(property: Property): PluginSettingsProperty<PluginSettings, Property>;
|
28
|
+
loadFromFile(): Promise<void>;
|
29
|
+
/**
|
30
|
+
* Saves the new plugin settings.
|
31
|
+
*
|
32
|
+
* @returns A promise that resolves when the settings are saved.
|
33
|
+
*/
|
34
|
+
saveToFile(): Promise<void>;
|
35
|
+
validate<Property extends StringKeys<PluginSettings>>(_property: Property, _value: PluginSettings[Property]): Promise<string | void>;
|
36
|
+
protected abstract createDefaultSettings(): PluginSettings;
|
37
|
+
protected getTransformer(): Transformer;
|
38
|
+
protected prepareRecord(_record: Record<string, unknown>): Promise<void>;
|
39
|
+
private getSettings;
|
40
|
+
}
|
41
|
+
export {};
|
@@ -40,7 +40,6 @@ class PluginSettingsTabBase extends import_obsidian.PluginSettingTab {
|
|
40
40
|
this.plugin = plugin;
|
41
41
|
this.containerEl.addClass(import_CssClass.CssClass.LibraryName, (0, import_PluginId.getPluginId)(), import_CssClass.CssClass.PluginSettingsTab);
|
42
42
|
}
|
43
|
-
validatorsMap = /* @__PURE__ */ new WeakMap();
|
44
43
|
/**
|
45
44
|
* Binds a value component to a plugin setting.
|
46
45
|
*
|
@@ -57,65 +56,52 @@ class PluginSettingsTabBase extends import_obsidian.PluginSettingTab {
|
|
57
56
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
|
58
57
|
componentToPluginSettingsValueConverter: (value) => value,
|
59
58
|
onChanged: import_Function.noop,
|
60
|
-
pluginSettings: void 0,
|
61
59
|
pluginSettingsToComponentValueConverter: (value) => value,
|
62
|
-
|
63
|
-
shouldShowValidationMessage: true,
|
64
|
-
valueValidator: import_Function.noop
|
60
|
+
shouldShowValidationMessage: true
|
65
61
|
};
|
66
62
|
const optionsExt = { ...DEFAULT_OPTIONS, ...options };
|
67
|
-
const pluginSettingsFn = () => optionsExt.pluginSettings ?? this.plugin.settingsClone;
|
68
63
|
const validatorElement = (0, import_ValidatorComponent.getValidatorComponent)(valueComponent)?.validatorEl;
|
69
|
-
const
|
70
|
-
|
71
|
-
|
72
|
-
if (
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
}
|
78
|
-
validatorElement.setCustomValidity(errorMessage);
|
79
|
-
validatorElement.title = errorMessage;
|
80
|
-
if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {
|
81
|
-
validatorElement.reportValidity();
|
82
|
-
}
|
83
|
-
}
|
84
|
-
return !errorMessage;
|
85
|
-
};
|
86
|
-
valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(pluginSettingsFn()[property])).onChange(async (uiValue) => {
|
87
|
-
if (!await validate(uiValue)) {
|
88
|
-
return;
|
89
|
-
}
|
90
|
-
const pluginSettings = pluginSettingsFn();
|
91
|
-
pluginSettings[property] = optionsExt.componentToPluginSettingsValueConverter(uiValue);
|
92
|
-
if (optionsExt.shouldAutoSave) {
|
93
|
-
await this.plugin.saveSettings(pluginSettings);
|
64
|
+
const propertyObj = this.plugin.settingsManager.getProperty(property);
|
65
|
+
valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(propertyObj.get())).onChange(async (uiValue) => {
|
66
|
+
const convertedValue = optionsExt.componentToPluginSettingsValueConverter(uiValue);
|
67
|
+
if (isValidationMessageHolder(convertedValue)) {
|
68
|
+
propertyObj.validationMessage = convertedValue.validationMessage;
|
69
|
+
await propertyObj.set(void 0);
|
70
|
+
} else {
|
71
|
+
await propertyObj.set(convertedValue);
|
94
72
|
}
|
95
73
|
await optionsExt.onChanged();
|
96
74
|
});
|
97
|
-
validatorElement?.addEventListener("focus",
|
98
|
-
validatorElement?.addEventListener("blur",
|
99
|
-
|
100
|
-
(0, import_Async.invokeAsyncSafely)(() => validate());
|
75
|
+
validatorElement?.addEventListener("focus", validate);
|
76
|
+
validatorElement?.addEventListener("blur", validate);
|
77
|
+
validate();
|
101
78
|
return valueComponent;
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
79
|
+
function validate() {
|
80
|
+
if (!validatorElement) {
|
81
|
+
return;
|
82
|
+
}
|
83
|
+
if (!propertyObj.validationMessage) {
|
84
|
+
validatorElement.setCustomValidity("");
|
85
|
+
validatorElement.checkValidity();
|
86
|
+
propertyObj.validationMessage = validatorElement.validationMessage;
|
87
|
+
}
|
88
|
+
validatorElement.setCustomValidity(propertyObj.validationMessage);
|
89
|
+
validatorElement.title = propertyObj.validationMessage;
|
90
|
+
if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {
|
91
|
+
validatorElement.reportValidity();
|
92
|
+
}
|
113
93
|
}
|
114
|
-
return true;
|
115
94
|
}
|
95
|
+
hide() {
|
96
|
+
super.hide();
|
97
|
+
(0, import_Async.invokeAsyncSafely)(() => this.plugin.settingsManager.saveToFile());
|
98
|
+
}
|
99
|
+
}
|
100
|
+
function isValidationMessageHolder(value) {
|
101
|
+
return !!value.validationMessage;
|
116
102
|
}
|
117
103
|
// Annotate the CommonJS export names for ESM import in node:
|
118
104
|
0 && (module.exports = {
|
119
105
|
PluginSettingsTabBase
|
120
106
|
});
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsTabBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation PluginSettingsTabBase\n * This module defines a base class for creating plugin setting tabs in Obsidian.\n * It provides a utility method to bind value components to plugin settings and handle changes.\n */\n\nimport type { BaseComponent } from 'obsidian';\nimport type {\n  ConditionalKeys,\n  Promisable\n} from 'type-fest';\n\nimport { PluginSettingTab } from 'obsidian';\n\nimport type { ValueComponentWithChangeTracking } from '../Components/ValueComponentWithChangeTracking.ts';\nimport type { PluginBase } from './PluginBase.ts';\nimport type { PluginSettingsBase } from './PluginSettingsBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../Async.ts';\nimport { CssClass } from '../../CssClass.ts';\nimport { noop } from '../../Function.ts';\nimport { getValidatorComponent } from '../Components/ValidatorComponent.ts';\nimport { getPluginId } from './PluginId.ts';\n\n/**\n * Options for binding a value component to a plugin setting.\n */\nexport interface BindOptions<PluginSettings, UIValue> {\n  /**\n   * A callback function that is called when the value of the component changes.\n   */\n  onChanged?: () => Promisable<void>;\n\n  /**\n   * The plugin settings object to bind the component to. Default is the plugin's current settings.\n   */\n  pluginSettings?: PluginSettings;\n\n  /**\n   * If true, saves the plugin settings automatically after the component value changes. Default is `true`.\n   */\n  shouldAutoSave?: boolean;\n\n  /**\n   * If true, shows the validation message when the component value is invalid. Default is `true`.\n   */\n  shouldShowValidationMessage?: boolean;\n\n  /**\n   * Validates the UI value before setting it on the plugin settings.\n   * @param uiValue - The value of the UI component.\n   * @returns An error message if the value is invalid, or `(empty string)` or `void` if it is valid.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  valueValidator?: (uiValue: UIValue) => Promisable<string | void>;\n}\n\n/**\n * Extended options for binding a value component to a plugin setting.\n */\nexport interface BindOptionsExtended<PluginSettings, UIValue, Property extends keyof PluginSettings> extends BindOptions<PluginSettings, UIValue> {\n  /**\n   * Converts the UI component's value back to the plugin settings value.\n   * @param uiValue - The value of the UI component.\n   * @returns The value to set on the plugin settings.\n   */\n  componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[Property];\n\n  /**\n   * Converts the plugin settings value to the value used by the UI component.\n   * @param pluginSettingsValue - The value of the property in the plugin settings.\n   * @returns The value to set on the UI component.\n   */\n  pluginSettingsToComponentValueConverter: (pluginSettingsValue: PluginSettings[Property]) => UIValue;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype ExtractPluginSettings<T extends PluginBase<any>> = PluginSettingsBase & T['settingsClone'];\n\n/**\n * Base class for creating plugin settings tabs in Obsidian.\n * Provides a method for binding value components to plugin settings and handling changes.\n *\n * @typeParam TPlugin - The type of the plugin that extends PluginBase.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport abstract class PluginSettingsTabBase<TPlugin extends PluginBase<any>> extends PluginSettingTab {\n  private validatorsMap = new WeakMap<BaseComponent, () => Promise<boolean>>();\n\n  public constructor(public override plugin: TPlugin) {\n    super(plugin.app, plugin);\n    this.containerEl.addClass(CssClass.LibraryName, getPluginId(), CssClass.PluginSettingsTab);\n  }\n\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @param valueComponent - The value component to bind.\n   * @param property - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    property: ConditionalKeys<ExtractPluginSettings<TPlugin>, UIValue>,\n    options?: BindOptions<ExtractPluginSettings<TPlugin>, UIValue>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam Property - The property of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param property - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    Property extends keyof ExtractPluginSettings<TPlugin>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    property: Property,\n    options: BindOptionsExtended<ExtractPluginSettings<TPlugin>, UIValue, Property>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam Property - The property of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param property - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    Property extends keyof ExtractPluginSettings<TPlugin>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    property: Property,\n    options?: BindOptions<ExtractPluginSettings<TPlugin>, UIValue>\n  ): TValueComponent {\n    type PluginSettings = ExtractPluginSettings<TPlugin>;\n    type PropertyType = PluginSettings[Property];\n    const DEFAULT_OPTIONS: Required<BindOptionsExtended<PluginSettings, UIValue, Property>> = {\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n      componentToPluginSettingsValueConverter: (value: UIValue): PropertyType => value as PropertyType,\n      onChanged: noop,\n      pluginSettings: undefined as PluginSettings,\n      pluginSettingsToComponentValueConverter: (value: PropertyType): UIValue => value as UIValue,\n      shouldAutoSave: true,\n      shouldShowValidationMessage: true,\n      valueValidator: noop\n    };\n\n    const optionsExt: Required<BindOptionsExtended<PluginSettings, UIValue, Property>> = { ...DEFAULT_OPTIONS, ...options };\n\n    // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n    const pluginSettingsFn = (): PluginSettings => optionsExt.pluginSettings ?? this.plugin.settingsClone;\n    const validatorElement = getValidatorComponent(valueComponent)?.validatorEl;\n\n    const validate = async (uiValue?: UIValue): Promise<boolean> => {\n      uiValue ??= valueComponent.getValue();\n      let errorMessage = await optionsExt.valueValidator(uiValue) as string | undefined;\n      if (validatorElement) {\n        if (!errorMessage) {\n          validatorElement.setCustomValidity('');\n          validatorElement.checkValidity();\n          errorMessage = validatorElement.validationMessage;\n        }\n\n        validatorElement.setCustomValidity(errorMessage);\n        validatorElement.title = errorMessage;\n        if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {\n          validatorElement.reportValidity();\n        }\n      }\n\n      return !errorMessage;\n    };\n\n    valueComponent\n      .setValue(optionsExt.pluginSettingsToComponentValueConverter(pluginSettingsFn()[property]))\n      .onChange(async (uiValue) => {\n        if (!await validate(uiValue)) {\n          return;\n        }\n        const pluginSettings = pluginSettingsFn();\n        pluginSettings[property] = optionsExt.componentToPluginSettingsValueConverter(uiValue);\n        if (optionsExt.shouldAutoSave) {\n          await this.plugin.saveSettings(pluginSettings);\n        }\n\n        await optionsExt.onChanged();\n      });\n\n    validatorElement?.addEventListener('focus', convertAsyncToSync(() => validate()));\n    validatorElement?.addEventListener('blur', convertAsyncToSync(() => validate()));\n    this.validatorsMap.set(valueComponent, () => validate());\n\n    invokeAsyncSafely(() => validate());\n    return valueComponent;\n  }\n\n  /**\n   * Revalidates the value component.\n   *\n   * @param baseComponent - The base component to revalidate.\n   * @returns A promise that resolves to a boolean indicating whether the value component is valid.\n   */\n  protected async revalidate(baseComponent: BaseComponent): Promise<boolean> {\n    const validator = this.validatorsMap.get(baseComponent);\n    if (validator) {\n      return await validator();\n    }\n\n    return true;\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,sBAAiC;AAMjC,mBAGO;AACP,sBAAyB;AACzB,sBAAqB;AACrB,gCAAsC;AACtC,sBAA4B;AAgErB,MAAe,8BAA+D,iCAAiB;AAAA,EAG7F,YAA4B,QAAiB;AAClD,UAAM,OAAO,KAAK,MAAM;AADS;AAEjC,SAAK,YAAY,SAAS,yBAAS,iBAAa,6BAAY,GAAG,yBAAS,iBAAiB;AAAA,EAC3F;AAAA,EALQ,gBAAgB,oBAAI,QAA+C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwDpE,KAKL,gBACA,UACA,SACiB;AAGjB,UAAM,kBAAoF;AAAA;AAAA,MAExF,yCAAyC,CAAC,UAAiC;AAAA,MAC3E,WAAW;AAAA,MACX,gBAAgB;AAAA,MAChB,yCAAyC,CAAC,UAAiC;AAAA,MAC3E,gBAAgB;AAAA,MAChB,6BAA6B;AAAA,MAC7B,gBAAgB;AAAA,IAClB;AAEA,UAAM,aAA+E,EAAE,GAAG,iBAAiB,GAAG,QAAQ;AAGtH,UAAM,mBAAmB,MAAsB,WAAW,kBAAkB,KAAK,OAAO;AACxF,UAAM,uBAAmB,iDAAsB,cAAc,GAAG;AAEhE,UAAM,WAAW,OAAO,YAAwC;AAC9D,kBAAY,eAAe,SAAS;AACpC,UAAI,eAAe,MAAM,WAAW,eAAe,OAAO;AAC1D,UAAI,kBAAkB;AACpB,YAAI,CAAC,cAAc;AACjB,2BAAiB,kBAAkB,EAAE;AACrC,2BAAiB,cAAc;AAC/B,yBAAe,iBAAiB;AAAA,QAClC;AAEA,yBAAiB,kBAAkB,YAAY;AAC/C,yBAAiB,QAAQ;AACzB,YAAI,iBAAiB,gBAAgB,KAAK,WAAW,6BAA6B;AAChF,2BAAiB,eAAe;AAAA,QAClC;AAAA,MACF;AAEA,aAAO,CAAC;AAAA,IACV;AAEA,mBACG,SAAS,WAAW,wCAAwC,iBAAiB,EAAE,QAAQ,CAAC,CAAC,EACzF,SAAS,OAAO,YAAY;AAC3B,UAAI,CAAC,MAAM,SAAS,OAAO,GAAG;AAC5B;AAAA,MACF;AACA,YAAM,iBAAiB,iBAAiB;AACxC,qBAAe,QAAQ,IAAI,WAAW,wCAAwC,OAAO;AACrF,UAAI,WAAW,gBAAgB;AAC7B,cAAM,KAAK,OAAO,aAAa,cAAc;AAAA,MAC/C;AAEA,YAAM,WAAW,UAAU;AAAA,IAC7B,CAAC;AAEH,sBAAkB,iBAAiB,aAAS,iCAAmB,MAAM,SAAS,CAAC,CAAC;AAChF,sBAAkB,iBAAiB,YAAQ,iCAAmB,MAAM,SAAS,CAAC,CAAC;AAC/E,SAAK,cAAc,IAAI,gBAAgB,MAAM,SAAS,CAAC;AAEvD,wCAAkB,MAAM,SAAS,CAAC;AAClC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAgB,WAAW,eAAgD;AACzE,UAAM,YAAY,KAAK,cAAc,IAAI,aAAa;AACtD,QAAI,WAAW;AACb,aAAO,MAAM,UAAU;AAAA,IACzB;AAEA,WAAO;AAAA,EACT;AACF;",
  "names": []
}

|
107
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsTabBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation PluginSettingsTabBase\n * This module defines a base class for creating plugin setting tabs in Obsidian.\n * It provides a utility method to bind value components to plugin settings and handle changes.\n */\n\nimport type {\n  ConditionalKeys,\n  Promisable,\n  WritableDeep\n} from 'type-fest';\n\nimport { PluginSettingTab } from 'obsidian';\n\nimport type { StringKeys } from '../../Object.ts';\nimport type { ValueComponentWithChangeTracking } from '../Components/ValueComponentWithChangeTracking.ts';\nimport type { PluginBase } from './PluginBase.ts';\n\nimport { invokeAsyncSafely } from '../../Async.ts';\nimport { CssClass } from '../../CssClass.ts';\nimport { noop } from '../../Function.ts';\nimport { getValidatorComponent } from '../Components/ValidatorComponent.ts';\nimport { getPluginId } from './PluginId.ts';\n\n/**\n * Options for binding a value component to a plugin setting.\n */\nexport interface BindOptions {\n  /**\n   * A callback function that is called when the value of the component changes.\n   */\n  onChanged?(): Promisable<void>;\n\n  /**\n   * If true, shows the validation message when the component value is invalid. Default is `true`.\n   */\n  shouldShowValidationMessage?: boolean;\n}\n\n/**\n * Extended options for binding a value component to a plugin setting.\n */\nexport interface BindOptionsExtended<PluginSettings extends object, UIValue, Property extends StringKeys<PluginSettings>> extends BindOptions {\n  /**\n   * Converts the UI component's value back to the plugin settings value.\n   * @param uiValue - The value of the UI component.\n   * @returns The value to set on the plugin settings.\n   */\n  componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[Property] | ValidationMessageHolder;\n\n  /**\n   * Converts the plugin settings value to the value used by the UI component.\n   * @param pluginSettingsValue - The value of the property in the plugin settings.\n   * @returns The value to set on the UI component.\n   */\n  pluginSettingsToComponentValueConverter: (pluginSettingsValue: PluginSettings[Property]) => UIValue;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype ExtractPluginSettings<T extends PluginBase<any>> = WritableDeep<T['settings']>;\n\ninterface ValidationMessageHolder {\n  validationMessage: string;\n}\n\n/**\n * Base class for creating plugin settings tabs in Obsidian.\n * Provides a method for binding value components to plugin settings and handling changes.\n *\n * @typeParam TPlugin - The type of the plugin that extends PluginBase.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport abstract class PluginSettingsTabBase<TPlugin extends PluginBase<any>> extends PluginSettingTab {\n  public constructor(public override plugin: TPlugin) {\n    super(plugin.app, plugin);\n    this.containerEl.addClass(CssClass.LibraryName, getPluginId(), CssClass.PluginSettingsTab);\n  }\n\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @param valueComponent - The value component to bind.\n   * @param property - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    property: ConditionalKeys<ExtractPluginSettings<TPlugin>, UIValue>,\n    options?: BindOptions\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam Property - The property of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param property - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    Property extends StringKeys<ExtractPluginSettings<TPlugin>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    property: Property,\n    options: BindOptionsExtended<ExtractPluginSettings<TPlugin>, UIValue, Property>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam Property - The property of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param property - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    Property extends StringKeys<ExtractPluginSettings<TPlugin>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    property: Property,\n    options?: BindOptions\n  ): TValueComponent {\n    type PluginSettings = ExtractPluginSettings<TPlugin>;\n    type PropertyType = PluginSettings[Property];\n    const DEFAULT_OPTIONS: Required<BindOptionsExtended<PluginSettings, UIValue, Property>> = {\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n      componentToPluginSettingsValueConverter: (value: UIValue): PropertyType => value as PropertyType,\n      onChanged: noop,\n      pluginSettingsToComponentValueConverter: (value: PropertyType): UIValue => value as UIValue,\n      shouldShowValidationMessage: true\n    };\n\n    const optionsExt: Required<BindOptionsExtended<PluginSettings, UIValue, Property>> = { ...DEFAULT_OPTIONS, ...options };\n\n    const validatorElement = getValidatorComponent(valueComponent)?.validatorEl;\n\n    const propertyObj = this.plugin.settingsManager.getProperty(property);\n\n    valueComponent\n      .setValue(optionsExt.pluginSettingsToComponentValueConverter(propertyObj.get() as PropertyType))\n      .onChange(async (uiValue) => {\n        const convertedValue = optionsExt.componentToPluginSettingsValueConverter(uiValue);\n        if (isValidationMessageHolder(convertedValue)) {\n          propertyObj.validationMessage = convertedValue.validationMessage;\n          await propertyObj.set(undefined);\n        } else {\n          await propertyObj.set(convertedValue);\n        }\n        await optionsExt.onChanged();\n      });\n\n    validatorElement?.addEventListener('focus', validate);\n    validatorElement?.addEventListener('blur', validate);\n\n    validate();\n    return valueComponent;\n\n    function validate(): void {\n      if (!validatorElement) {\n        return;\n      }\n\n      if (!propertyObj.validationMessage) {\n        validatorElement.setCustomValidity('');\n        validatorElement.checkValidity();\n        propertyObj.validationMessage = validatorElement.validationMessage;\n      }\n\n      validatorElement.setCustomValidity(propertyObj.validationMessage);\n      validatorElement.title = propertyObj.validationMessage;\n      if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {\n        validatorElement.reportValidity();\n      }\n    }\n  }\n\n  public override hide(): void {\n    super.hide();\n    invokeAsyncSafely(() => this.plugin.settingsManager.saveToFile());\n  }\n}\n\nfunction isValidationMessageHolder(value: unknown): value is ValidationMessageHolder {\n  return !!(value as Partial<ValidationMessageHolder>).validationMessage;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,sBAAiC;AAMjC,mBAAkC;AAClC,sBAAyB;AACzB,sBAAqB;AACrB,gCAAsC;AACtC,sBAA4B;AAkDrB,MAAe,8BAA+D,iCAAiB;AAAA,EAC7F,YAA4B,QAAiB;AAClD,UAAM,OAAO,KAAK,MAAM;AADS;AAEjC,SAAK,YAAY,SAAS,yBAAS,iBAAa,6BAAY,GAAG,yBAAS,iBAAiB;AAAA,EAC3F;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAmDO,KAKL,gBACA,UACA,SACiB;AAGjB,UAAM,kBAAoF;AAAA;AAAA,MAExF,yCAAyC,CAAC,UAAiC;AAAA,MAC3E,WAAW;AAAA,MACX,yCAAyC,CAAC,UAAiC;AAAA,MAC3E,6BAA6B;AAAA,IAC/B;AAEA,UAAM,aAA+E,EAAE,GAAG,iBAAiB,GAAG,QAAQ;AAEtH,UAAM,uBAAmB,iDAAsB,cAAc,GAAG;AAEhE,UAAM,cAAc,KAAK,OAAO,gBAAgB,YAAY,QAAQ;AAEpE,mBACG,SAAS,WAAW,wCAAwC,YAAY,IAAI,CAAiB,CAAC,EAC9F,SAAS,OAAO,YAAY;AAC3B,YAAM,iBAAiB,WAAW,wCAAwC,OAAO;AACjF,UAAI,0BAA0B,cAAc,GAAG;AAC7C,oBAAY,oBAAoB,eAAe;AAC/C,cAAM,YAAY,IAAI,MAAS;AAAA,MACjC,OAAO;AACL,cAAM,YAAY,IAAI,cAAc;AAAA,MACtC;AACA,YAAM,WAAW,UAAU;AAAA,IAC7B,CAAC;AAEH,sBAAkB,iBAAiB,SAAS,QAAQ;AACpD,sBAAkB,iBAAiB,QAAQ,QAAQ;AAEnD,aAAS;AACT,WAAO;AAEP,aAAS,WAAiB;AACxB,UAAI,CAAC,kBAAkB;AACrB;AAAA,MACF;AAEA,UAAI,CAAC,YAAY,mBAAmB;AAClC,yBAAiB,kBAAkB,EAAE;AACrC,yBAAiB,cAAc;AAC/B,oBAAY,oBAAoB,iBAAiB;AAAA,MACnD;AAEA,uBAAiB,kBAAkB,YAAY,iBAAiB;AAChE,uBAAiB,QAAQ,YAAY;AACrC,UAAI,iBAAiB,gBAAgB,KAAK,WAAW,6BAA6B;AAChF,yBAAiB,eAAe;AAAA,MAClC;AAAA,IACF;AAAA,EACF;AAAA,EAEgB,OAAa;AAC3B,UAAM,KAAK;AACX,wCAAkB,MAAM,KAAK,OAAO,gBAAgB,WAAW,CAAC;AAAA,EAClE;AACF;AAEA,SAAS,0BAA0B,OAAkD;AACnF,SAAO,CAAC,CAAE,MAA2C;AACvD;",
  "names": []
}

|
@@ -3,49 +3,34 @@
|
|
3
3
|
* This module defines a base class for creating plugin setting tabs in Obsidian.
|
4
4
|
* It provides a utility method to bind value components to plugin settings and handle changes.
|
5
5
|
*/
|
6
|
-
import type {
|
7
|
-
import type { ConditionalKeys, Promisable } from 'type-fest';
|
6
|
+
import type { ConditionalKeys, Promisable, WritableDeep } from 'type-fest';
|
8
7
|
import { PluginSettingTab } from 'obsidian';
|
8
|
+
import type { StringKeys } from '../../Object.cjs';
|
9
9
|
import type { ValueComponentWithChangeTracking } from '../Components/ValueComponentWithChangeTracking.cjs';
|
10
10
|
import type { PluginBase } from './PluginBase.cjs';
|
11
|
-
import type { PluginSettingsBase } from './PluginSettingsBase.cjs';
|
12
11
|
/**
|
13
12
|
* Options for binding a value component to a plugin setting.
|
14
13
|
*/
|
15
|
-
export interface BindOptions
|
14
|
+
export interface BindOptions {
|
16
15
|
/**
|
17
16
|
* A callback function that is called when the value of the component changes.
|
18
17
|
*/
|
19
|
-
onChanged
|
20
|
-
/**
|
21
|
-
* The plugin settings object to bind the component to. Default is the plugin's current settings.
|
22
|
-
*/
|
23
|
-
pluginSettings?: PluginSettings;
|
24
|
-
/**
|
25
|
-
* If true, saves the plugin settings automatically after the component value changes. Default is `true`.
|
26
|
-
*/
|
27
|
-
shouldAutoSave?: boolean;
|
18
|
+
onChanged?(): Promisable<void>;
|
28
19
|
/**
|
29
20
|
* If true, shows the validation message when the component value is invalid. Default is `true`.
|
30
21
|
*/
|
31
22
|
shouldShowValidationMessage?: boolean;
|
32
|
-
/**
|
33
|
-
* Validates the UI value before setting it on the plugin settings.
|
34
|
-
* @param uiValue - The value of the UI component.
|
35
|
-
* @returns An error message if the value is invalid, or `(empty string)` or `void` if it is valid.
|
36
|
-
*/
|
37
|
-
valueValidator?: (uiValue: UIValue) => Promisable<string | void>;
|
38
23
|
}
|
39
24
|
/**
|
40
25
|
* Extended options for binding a value component to a plugin setting.
|
41
26
|
*/
|
42
|
-
export interface BindOptionsExtended<PluginSettings, UIValue, Property extends
|
27
|
+
export interface BindOptionsExtended<PluginSettings extends object, UIValue, Property extends StringKeys<PluginSettings>> extends BindOptions {
|
43
28
|
/**
|
44
29
|
* Converts the UI component's value back to the plugin settings value.
|
45
30
|
* @param uiValue - The value of the UI component.
|
46
31
|
* @returns The value to set on the plugin settings.
|
47
32
|
*/
|
48
|
-
componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[Property];
|
33
|
+
componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[Property] | ValidationMessageHolder;
|
49
34
|
/**
|
50
35
|
* Converts the plugin settings value to the value used by the UI component.
|
51
36
|
* @param pluginSettingsValue - The value of the property in the plugin settings.
|
@@ -53,7 +38,10 @@ export interface BindOptionsExtended<PluginSettings, UIValue, Property extends k
|
|
53
38
|
*/
|
54
39
|
pluginSettingsToComponentValueConverter: (pluginSettingsValue: PluginSettings[Property]) => UIValue;
|
55
40
|
}
|
56
|
-
type ExtractPluginSettings<T extends PluginBase<any>> =
|
41
|
+
type ExtractPluginSettings<T extends PluginBase<any>> = WritableDeep<T['settings']>;
|
42
|
+
interface ValidationMessageHolder {
|
43
|
+
validationMessage: string;
|
44
|
+
}
|
57
45
|
/**
|
58
46
|
* Base class for creating plugin settings tabs in Obsidian.
|
59
47
|
* Provides a method for binding value components to plugin settings and handling changes.
|
@@ -62,7 +50,6 @@ type ExtractPluginSettings<T extends PluginBase<any>> = PluginSettingsBase & T['
|
|
62
50
|
*/
|
63
51
|
export declare abstract class PluginSettingsTabBase<TPlugin extends PluginBase<any>> extends PluginSettingTab {
|
64
52
|
plugin: TPlugin;
|
65
|
-
private validatorsMap;
|
66
53
|
constructor(plugin: TPlugin);
|
67
54
|
/**
|
68
55
|
* Binds a value component to a plugin setting.
|
@@ -74,7 +61,7 @@ export declare abstract class PluginSettingsTabBase<TPlugin extends PluginBase<a
|
|
74
61
|
* @param options - The options for binding the value component.
|
75
62
|
* @returns The value component.
|
76
63
|
*/
|
77
|
-
bind<UIValue, TValueComponent>(valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>, property: ConditionalKeys<ExtractPluginSettings<TPlugin>, UIValue>, options?: BindOptions
|
64
|
+
bind<UIValue, TValueComponent>(valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>, property: ConditionalKeys<ExtractPluginSettings<TPlugin>, UIValue>, options?: BindOptions): TValueComponent;
|
78
65
|
/**
|
79
66
|
* Binds a value component to a plugin setting.
|
80
67
|
*
|
@@ -86,13 +73,7 @@ export declare abstract class PluginSettingsTabBase<TPlugin extends PluginBase<a
|
|
86
73
|
* @param options - The options for binding the value component.
|
87
74
|
* @returns The value component.
|
88
75
|
*/
|
89
|
-
bind<UIValue, TValueComponent, Property extends
|
90
|
-
|
91
|
-
* Revalidates the value component.
|
92
|
-
*
|
93
|
-
* @param baseComponent - The base component to revalidate.
|
94
|
-
* @returns A promise that resolves to a boolean indicating whether the value component is valid.
|
95
|
-
*/
|
96
|
-
protected revalidate(baseComponent: BaseComponent): Promise<boolean>;
|
76
|
+
bind<UIValue, TValueComponent, Property extends StringKeys<ExtractPluginSettings<TPlugin>>>(valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>, property: Property, options: BindOptionsExtended<ExtractPluginSettings<TPlugin>, UIValue, Property>): TValueComponent;
|
77
|
+
hide(): void;
|
97
78
|
}
|
98
79
|
export {};
|
@@ -35,33 +35,30 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
35
35
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
36
36
|
var Plugin_exports = {};
|
37
37
|
__export(Plugin_exports, {
|
38
|
-
EmptySettings: () => EmptySettings,
|
39
38
|
ObsidianPluginRepoPaths: () => ObsidianPluginRepoPaths,
|
40
39
|
Plugin: () => Plugin,
|
41
40
|
PluginBase: () => PluginBase,
|
42
41
|
PluginContext: () => PluginContext,
|
43
42
|
PluginId: () => PluginId,
|
44
|
-
|
43
|
+
PluginSettingsManagerBase: () => PluginSettingsManagerBase,
|
45
44
|
PluginSettingsTabBase: () => PluginSettingsTabBase
|
46
45
|
});
|
47
46
|
module.exports = __toCommonJS(Plugin_exports);
|
48
|
-
var EmptySettings = __toESM(__extractDefault(require('./EmptySettings.cjs')), 1);
|
49
47
|
var ObsidianPluginRepoPaths = __toESM(__extractDefault(require('./ObsidianPluginRepoPaths.cjs')), 1);
|
50
48
|
var Plugin = __toESM(__extractDefault(require('./Plugin.cjs')), 1);
|
51
49
|
var PluginBase = __toESM(__extractDefault(require('./PluginBase.cjs')), 1);
|
52
50
|
var PluginContext = __toESM(__extractDefault(require('./PluginContext.cjs')), 1);
|
53
51
|
var PluginId = __toESM(__extractDefault(require('./PluginId.cjs')), 1);
|
54
|
-
var
|
52
|
+
var PluginSettingsManagerBase = __toESM(__extractDefault(require('./PluginSettingsManagerBase.cjs')), 1);
|
55
53
|
var PluginSettingsTabBase = __toESM(__extractDefault(require('./PluginSettingsTabBase.cjs')), 1);
|
56
54
|
// Annotate the CommonJS export names for ESM import in node:
|
57
55
|
0 && (module.exports = {
|
58
|
-
EmptySettings,
|
59
56
|
ObsidianPluginRepoPaths,
|
60
57
|
Plugin,
|
61
58
|
PluginBase,
|
62
59
|
PluginContext,
|
63
60
|
PluginId,
|
64
|
-
|
61
|
+
PluginSettingsManagerBase,
|
65
62
|
PluginSettingsTabBase
|
66
63
|
});
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
64
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL1BsdWdpbi9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovXG5cbmV4cG9ydCAqIGFzIE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzIGZyb20gJy4vT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMudHMnO1xuZXhwb3J0ICogYXMgUGx1Z2luIGZyb20gJy4vUGx1Z2luLnRzJztcbmV4cG9ydCAqIGFzIFBsdWdpbkJhc2UgZnJvbSAnLi9QbHVnaW5CYXNlLnRzJztcbmV4cG9ydCAqIGFzIFBsdWdpbkNvbnRleHQgZnJvbSAnLi9QbHVnaW5Db250ZXh0LnRzJztcbmV4cG9ydCAqIGFzIFBsdWdpbklkIGZyb20gJy4vUGx1Z2luSWQudHMnO1xuZXhwb3J0ICogYXMgUGx1Z2luU2V0dGluZ3NNYW5hZ2VyQmFzZSBmcm9tICcuL1BsdWdpblNldHRpbmdzTWFuYWdlckJhc2UudHMnO1xuZXhwb3J0ICogYXMgUGx1Z2luU2V0dGluZ3NUYWJCYXNlIGZyb20gJy4vUGx1Z2luU2V0dGluZ3NUYWJCYXNlLnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUVBLDhCQUF5QztBQUN6QyxhQUF3QjtBQUN4QixpQkFBNEI7QUFDNUIsb0JBQStCO0FBQy9CLGVBQTBCO0FBQzFCLGdDQUEyQztBQUMzQyw0QkFBdUM7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
@@ -1,8 +1,7 @@
|
|
1
|
-
export * as EmptySettings from './EmptySettings.cjs';
|
2
1
|
export * as ObsidianPluginRepoPaths from './ObsidianPluginRepoPaths.cjs';
|
3
2
|
export * as Plugin from './Plugin.cjs';
|
4
3
|
export * as PluginBase from './PluginBase.cjs';
|
5
4
|
export * as PluginContext from './PluginContext.cjs';
|
6
5
|
export * as PluginId from './PluginId.cjs';
|
7
|
-
export * as
|
6
|
+
export * as PluginSettingsManagerBase from './PluginSettingsManagerBase.cjs';
|
8
7
|
export * as PluginSettingsTabBase from './PluginSettingsTabBase.cjs';
|