obsidian-dev-utils 22.1.1-beta.23 → 22.1.1-beta.24
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 +12 -0
- package/dist/lib/cjs/AsyncEvents.cjs +1 -1
- package/dist/lib/cjs/AsyncEvents.d.cts +2 -2
- package/dist/lib/cjs/CssClass.cjs +5 -1
- package/dist/lib/cjs/CssClass.d.cts +16 -0
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/obsidian/Components/CheckboxComponent.cjs +96 -0
- package/dist/lib/cjs/obsidian/Components/CheckboxComponent.d.cts +51 -0
- package/dist/lib/cjs/obsidian/Components/MultipleDropdownComponent.cjs +2 -2
- package/dist/lib/cjs/obsidian/Components/MultipleTextComponent.cjs +2 -2
- package/dist/lib/cjs/obsidian/Components/TextBasedComponent.cjs +1 -1
- package/dist/lib/cjs/obsidian/Components/TextBasedComponent.d.cts +3 -0
- package/dist/lib/cjs/obsidian/Components/TriStateCheckboxComponent.cjs +97 -0
- package/dist/lib/cjs/obsidian/Components/TriStateCheckboxComponent.d.cts +51 -0
- package/dist/lib/cjs/obsidian/Components/TypedDropdownComponent.cjs +127 -0
- package/dist/lib/cjs/obsidian/Components/TypedDropdownComponent.d.cts +71 -0
- package/dist/lib/cjs/obsidian/Components/TypedMultipleDropdownComponent.cjs +129 -0
- package/dist/lib/cjs/obsidian/Components/TypedMultipleDropdownComponent.d.cts +76 -0
- package/dist/lib/cjs/obsidian/Components/TypedRangeTextComponent.cjs +1 -1
- package/dist/lib/cjs/obsidian/Components/TypedRangeTextComponent.d.cts +2 -0
- package/dist/lib/cjs/obsidian/Components/TypedTextComponent.cjs +2 -2
- package/dist/lib/cjs/obsidian/Components/TypedTextComponent.d.cts +2 -0
- package/dist/lib/cjs/obsidian/Components/ValueComponentWithChangeTracking.cjs +1 -1
- package/dist/lib/cjs/obsidian/Components/ValueComponentWithChangeTracking.d.cts +2 -0
- package/dist/lib/cjs/obsidian/Components/index.cjs +13 -1
- package/dist/lib/cjs/obsidian/Components/index.d.cts +4 -0
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +21 -19
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +11 -9
- package/dist/lib/cjs/obsidian/SettingEx.cjs +41 -1
- package/dist/lib/cjs/obsidian/SettingEx.d.cts +33 -1
- package/dist/lib/esm/AsyncEvents.d.mts +2 -2
- package/dist/lib/esm/AsyncEvents.mjs +1 -1
- package/dist/lib/esm/CssClass.d.mts +16 -0
- package/dist/lib/esm/CssClass.mjs +5 -1
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/obsidian/Components/CheckboxComponent.d.mts +51 -0
- package/dist/lib/esm/obsidian/Components/CheckboxComponent.mjs +72 -0
- package/dist/lib/esm/obsidian/Components/MultipleDropdownComponent.mjs +2 -2
- package/dist/lib/esm/obsidian/Components/MultipleTextComponent.mjs +2 -2
- package/dist/lib/esm/obsidian/Components/TextBasedComponent.d.mts +3 -0
- package/dist/lib/esm/obsidian/Components/TextBasedComponent.mjs +1 -1
- package/dist/lib/esm/obsidian/Components/TriStateCheckboxComponent.d.mts +51 -0
- package/dist/lib/esm/obsidian/Components/TriStateCheckboxComponent.mjs +73 -0
- package/dist/lib/esm/obsidian/Components/TypedDropdownComponent.d.mts +71 -0
- package/dist/lib/esm/obsidian/Components/TypedDropdownComponent.mjs +106 -0
- package/dist/lib/esm/obsidian/Components/TypedMultipleDropdownComponent.d.mts +76 -0
- package/dist/lib/esm/obsidian/Components/TypedMultipleDropdownComponent.mjs +108 -0
- package/dist/lib/esm/obsidian/Components/TypedRangeTextComponent.d.mts +2 -0
- package/dist/lib/esm/obsidian/Components/TypedRangeTextComponent.mjs +1 -1
- package/dist/lib/esm/obsidian/Components/TypedTextComponent.d.mts +2 -0
- package/dist/lib/esm/obsidian/Components/TypedTextComponent.mjs +2 -2
- package/dist/lib/esm/obsidian/Components/ValueComponentWithChangeTracking.d.mts +2 -0
- package/dist/lib/esm/obsidian/Components/index.d.mts +4 -0
- package/dist/lib/esm/obsidian/Components/index.mjs +9 -1
- package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +11 -9
- package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +21 -19
- package/dist/lib/esm/obsidian/SettingEx.d.mts +33 -1
- package/dist/lib/esm/obsidian/SettingEx.mjs +41 -1
- package/obsidian/Components/CheckboxComponent/package.json +6 -0
- package/obsidian/Components/TriStateCheckboxComponent/package.json +6 -0
- package/obsidian/Components/TypedDropdownComponent/package.json +6 -0
- package/obsidian/Components/TypedMultipleDropdownComponent/package.json +6 -0
- package/package.json +1 -1
@@ -35,6 +35,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
35
35
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
36
36
|
var Components_exports = {};
|
37
37
|
__export(Components_exports, {
|
38
|
+
CheckboxComponent: () => CheckboxComponent,
|
38
39
|
DateComponent: () => DateComponent,
|
39
40
|
DateTimeComponent: () => DateTimeComponent,
|
40
41
|
EmailComponent: () => EmailComponent,
|
@@ -47,6 +48,9 @@ __export(Components_exports, {
|
|
47
48
|
NumberComponent: () => NumberComponent,
|
48
49
|
TextBasedComponent: () => TextBasedComponent,
|
49
50
|
TimeComponent: () => TimeComponent,
|
51
|
+
TriStateCheckboxComponent: () => TriStateCheckboxComponent,
|
52
|
+
TypedDropdownComponent: () => TypedDropdownComponent,
|
53
|
+
TypedMultipleDropdownComponent: () => TypedMultipleDropdownComponent,
|
50
54
|
TypedRangeTextComponent: () => TypedRangeTextComponent,
|
51
55
|
TypedTextComponent: () => TypedTextComponent,
|
52
56
|
UrlComponent: () => UrlComponent,
|
@@ -55,6 +59,7 @@ __export(Components_exports, {
|
|
55
59
|
WeekComponent: () => WeekComponent
|
56
60
|
});
|
57
61
|
module.exports = __toCommonJS(Components_exports);
|
62
|
+
var CheckboxComponent = __toESM(__extractDefault(require('./CheckboxComponent.cjs')), 1);
|
58
63
|
var DateComponent = __toESM(__extractDefault(require('./DateComponent.cjs')), 1);
|
59
64
|
var DateTimeComponent = __toESM(__extractDefault(require('./DateTimeComponent.cjs')), 1);
|
60
65
|
var EmailComponent = __toESM(__extractDefault(require('./EmailComponent.cjs')), 1);
|
@@ -67,6 +72,9 @@ var MultipleTextComponent = __toESM(__extractDefault(require('./MultipleTextComp
|
|
67
72
|
var NumberComponent = __toESM(__extractDefault(require('./NumberComponent.cjs')), 1);
|
68
73
|
var TextBasedComponent = __toESM(__extractDefault(require('./TextBasedComponent.cjs')), 1);
|
69
74
|
var TimeComponent = __toESM(__extractDefault(require('./TimeComponent.cjs')), 1);
|
75
|
+
var TriStateCheckboxComponent = __toESM(__extractDefault(require('./TriStateCheckboxComponent.cjs')), 1);
|
76
|
+
var TypedDropdownComponent = __toESM(__extractDefault(require('./TypedDropdownComponent.cjs')), 1);
|
77
|
+
var TypedMultipleDropdownComponent = __toESM(__extractDefault(require('./TypedMultipleDropdownComponent.cjs')), 1);
|
70
78
|
var TypedRangeTextComponent = __toESM(__extractDefault(require('./TypedRangeTextComponent.cjs')), 1);
|
71
79
|
var TypedTextComponent = __toESM(__extractDefault(require('./TypedTextComponent.cjs')), 1);
|
72
80
|
var UrlComponent = __toESM(__extractDefault(require('./UrlComponent.cjs')), 1);
|
@@ -75,6 +83,7 @@ var ValueComponentWithChangeTracking = __toESM(__extractDefault(require('./Value
|
|
75
83
|
var WeekComponent = __toESM(__extractDefault(require('./WeekComponent.cjs')), 1);
|
76
84
|
// Annotate the CommonJS export names for ESM import in node:
|
77
85
|
0 && (module.exports = {
|
86
|
+
CheckboxComponent,
|
78
87
|
DateComponent,
|
79
88
|
DateTimeComponent,
|
80
89
|
EmailComponent,
|
@@ -87,6 +96,9 @@ var WeekComponent = __toESM(__extractDefault(require('./WeekComponent.cjs')), 1)
|
|
87
96
|
NumberComponent,
|
88
97
|
TextBasedComponent,
|
89
98
|
TimeComponent,
|
99
|
+
TriStateCheckboxComponent,
|
100
|
+
TypedDropdownComponent,
|
101
|
+
TypedMultipleDropdownComponent,
|
90
102
|
TypedRangeTextComponent,
|
91
103
|
TypedTextComponent,
|
92
104
|
UrlComponent,
|
@@ -94,4 +106,4 @@ var WeekComponent = __toESM(__extractDefault(require('./WeekComponent.cjs')), 1)
|
|
94
106
|
ValueComponentWithChangeTracking,
|
95
107
|
WeekComponent
|
96
108
|
});
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
109
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL0NvbXBvbmVudHMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qIFRISVMgSVMgQSBHRU5FUkFURUQvQlVORExFRCBGSUxFIEJZIEJVSUxEIFNDUklQVCAqL1xuXG5leHBvcnQgKiBhcyBDaGVja2JveENvbXBvbmVudCBmcm9tICcuL0NoZWNrYm94Q29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIERhdGVDb21wb25lbnQgZnJvbSAnLi9EYXRlQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIERhdGVUaW1lQ29tcG9uZW50IGZyb20gJy4vRGF0ZVRpbWVDb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgRW1haWxDb21wb25lbnQgZnJvbSAnLi9FbWFpbENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBGaWxlQ29tcG9uZW50IGZyb20gJy4vRmlsZUNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBNb250aENvbXBvbmVudCBmcm9tICcuL01vbnRoQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIE11bHRpcGxlRHJvcGRvd25Db21wb25lbnQgZnJvbSAnLi9NdWx0aXBsZURyb3Bkb3duQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIE11bHRpcGxlRW1haWxDb21wb25lbnQgZnJvbSAnLi9NdWx0aXBsZUVtYWlsQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIE11bHRpcGxlRmlsZUNvbXBvbmVudCBmcm9tICcuL011bHRpcGxlRmlsZUNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBNdWx0aXBsZVRleHRDb21wb25lbnQgZnJvbSAnLi9NdWx0aXBsZVRleHRDb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgTnVtYmVyQ29tcG9uZW50IGZyb20gJy4vTnVtYmVyQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIFRleHRCYXNlZENvbXBvbmVudCBmcm9tICcuL1RleHRCYXNlZENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUaW1lQ29tcG9uZW50IGZyb20gJy4vVGltZUNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUcmlTdGF0ZUNoZWNrYm94Q29tcG9uZW50IGZyb20gJy4vVHJpU3RhdGVDaGVja2JveENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUeXBlZERyb3Bkb3duQ29tcG9uZW50IGZyb20gJy4vVHlwZWREcm9wZG93bkNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUeXBlZE11bHRpcGxlRHJvcGRvd25Db21wb25lbnQgZnJvbSAnLi9UeXBlZE11bHRpcGxlRHJvcGRvd25Db21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgVHlwZWRSYW5nZVRleHRDb21wb25lbnQgZnJvbSAnLi9UeXBlZFJhbmdlVGV4dENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUeXBlZFRleHRDb21wb25lbnQgZnJvbSAnLi9UeXBlZFRleHRDb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgVXJsQ29tcG9uZW50IGZyb20gJy4vVXJsQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIFZhbGlkYXRvckNvbXBvbmVudCBmcm9tICcuL1ZhbGlkYXRvckNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBWYWx1ZUNvbXBvbmVudFdpdGhDaGFuZ2VUcmFja2luZyBmcm9tICcuL1ZhbHVlQ29tcG9uZW50V2l0aENoYW5nZVRyYWNraW5nLnRzJztcbmV4cG9ydCAqIGFzIFdlZWtDb21wb25lbnQgZnJvbSAnLi9XZWVrQ29tcG9uZW50LnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUVBLHdCQUFtQztBQUNuQyxvQkFBK0I7QUFDL0Isd0JBQW1DO0FBQ25DLHFCQUFnQztBQUNoQyxvQkFBK0I7QUFDL0IscUJBQWdDO0FBQ2hDLGdDQUEyQztBQUMzQyw2QkFBd0M7QUFDeEMsNEJBQXVDO0FBQ3ZDLDRCQUF1QztBQUN2QyxzQkFBaUM7QUFDakMseUJBQW9DO0FBQ3BDLG9CQUErQjtBQUMvQixnQ0FBMkM7QUFDM0MsNkJBQXdDO0FBQ3hDLHFDQUFnRDtBQUNoRCw4QkFBeUM7QUFDekMseUJBQW9DO0FBQ3BDLG1CQUE4QjtBQUM5Qix5QkFBb0M7QUFDcEMsdUNBQWtEO0FBQ2xELG9CQUErQjsiLAogICJuYW1lcyI6IFtdCn0K
|
@@ -1,3 +1,4 @@
|
|
1
|
+
export * as CheckboxComponent from './CheckboxComponent.cjs';
|
1
2
|
export * as DateComponent from './DateComponent.cjs';
|
2
3
|
export * as DateTimeComponent from './DateTimeComponent.cjs';
|
3
4
|
export * as EmailComponent from './EmailComponent.cjs';
|
@@ -10,6 +11,9 @@ export * as MultipleTextComponent from './MultipleTextComponent.cjs';
|
|
10
11
|
export * as NumberComponent from './NumberComponent.cjs';
|
11
12
|
export * as TextBasedComponent from './TextBasedComponent.cjs';
|
12
13
|
export * as TimeComponent from './TimeComponent.cjs';
|
14
|
+
export * as TriStateCheckboxComponent from './TriStateCheckboxComponent.cjs';
|
15
|
+
export * as TypedDropdownComponent from './TypedDropdownComponent.cjs';
|
16
|
+
export * as TypedMultipleDropdownComponent from './TypedMultipleDropdownComponent.cjs';
|
13
17
|
export * as TypedRangeTextComponent from './TypedRangeTextComponent.cjs';
|
14
18
|
export * as TypedTextComponent from './TypedTextComponent.cjs';
|
15
19
|
export * as UrlComponent from './UrlComponent.cjs';
|
@@ -87,24 +87,6 @@ class PluginBase extends import_obsidian.Plugin {
|
|
87
87
|
async onExternalSettingsChange() {
|
88
88
|
await this.settingsManager.loadFromFile();
|
89
89
|
}
|
90
|
-
/**
|
91
|
-
* Adds a lifecycle event listener.
|
92
|
-
* If the event has already occurred, the callback will be called immediately.
|
93
|
-
*
|
94
|
-
* @param name - The name of the event.
|
95
|
-
* @param callback - The callback to call when the event is triggered.
|
96
|
-
* @returns A {@link Promise} that resolves when the callback is executed.
|
97
|
-
*/
|
98
|
-
async onLifecycleEvent(name, callback) {
|
99
|
-
if (!this.lifecycleEventNames.has(name)) {
|
100
|
-
await new Promise((resolve) => {
|
101
|
-
this.events.once(name, () => {
|
102
|
-
resolve();
|
103
|
-
});
|
104
|
-
});
|
105
|
-
}
|
106
|
-
await callback();
|
107
|
-
}
|
108
90
|
/**
|
109
91
|
* Called when the plugin is loaded
|
110
92
|
*/
|
@@ -166,6 +148,26 @@ class PluginBase extends import_obsidian.Plugin {
|
|
166
148
|
eventRef.asyncEvents.offref(eventRef);
|
167
149
|
});
|
168
150
|
}
|
151
|
+
/**
|
152
|
+
* Waits for a lifecycle event to be triggered.
|
153
|
+
*
|
154
|
+
* If you `await` this method during lifecycle event, it might cause a deadlock.
|
155
|
+
*
|
156
|
+
* Consider wrapping this call with {@link invokeAsyncSafely}.
|
157
|
+
*
|
158
|
+
* @param name - The name of the event.
|
159
|
+
* @returns A {@link Promise} that resolves when the event is triggered.
|
160
|
+
*/
|
161
|
+
async waitForLifecycleEvent(name) {
|
162
|
+
if (this.lifecycleEventNames.has(name)) {
|
163
|
+
return;
|
164
|
+
}
|
165
|
+
await new Promise((resolve) => {
|
166
|
+
this.events.once(name, () => {
|
167
|
+
resolve();
|
168
|
+
});
|
169
|
+
});
|
170
|
+
}
|
169
171
|
/**
|
170
172
|
* Creates a plugin settings tab.
|
171
173
|
*
|
@@ -221,4 +223,4 @@ ${message}`);
|
|
221
223
|
0 && (module.exports = {
|
222
224
|
PluginBase
|
223
225
|
});
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation PluginBase\n * Base class for Obsidian plugins providing utility methods for settings management, error handling, and notifications.\n *\n * This class simplifies the process of managing plugin settings, displaying notifications, and handling errors.\n * Subclasses should implement methods to create default settings and settings tabs, and complete plugin-specific\n * loading tasks.\n */\n\nimport type { PluginSettingTab } from 'obsidian';\nimport type {\n  Promisable,\n  ReadonlyDeep\n} from 'type-fest';\n\nimport {\n  Notice,\n  Plugin\n} from 'obsidian';\n\nimport type { AsyncEventRef } from '../../AsyncEvents.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../Async.ts';\nimport { AsyncEvents } from '../../AsyncEvents.ts';\nimport { getDebugger } from '../../Debug.ts';\nimport { registerAsyncErrorEventHandler } from '../../Error.ts';\nimport { noop } from '../../Function.ts';\nimport { initPluginContext } from './PluginContext.ts';\nimport { PluginSettingsManagerBase } from './PluginSettingsManagerBase.ts';\n\ntype LifecycleEventName = 'layoutReady' | 'loadComplete' | 'unload';\n\n/**\n * Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.\n *\n * @typeParam PluginSettings - The type representing the plugin settings object.\n */\nexport abstract class PluginBase<PluginSettings extends object = object> extends Plugin {\n  /**\n   * @deprecated Used only for type inference. Don't use it directly.\n   */\n  declare public __pluginSettingsType: PluginSettings;\n\n  public readonly events = new AsyncEvents();\n\n  /**\n   * Gets the AbortSignal used for aborting long-running operations.\n   *\n   * @returns The abort signal.\n   */\n  public get abortSignal(): AbortSignal {\n    return this._abortSignal;\n  }\n\n  /**\n   * Gets the readonly plugin settings.\n   *\n   * @returns The readonly plugin settings.\n   */\n  public get settings(): ReadonlyDeep<PluginSettings> {\n    return this.settingsManager.safeSettings;\n  }\n\n  public get settingsManager(): PluginSettingsManagerBase<PluginSettings> {\n    if (!this._settingsManager) {\n      throw new Error('Settings manager not defined');\n    }\n\n    return this._settingsManager;\n  }\n\n  private _abortSignal!: AbortSignal;\n  private _settingsManager: null | PluginSettingsManagerBase<PluginSettings> = null;\n  private lifecycleEventNames = new Set<LifecycleEventName>();\n  private notice?: Notice;\n\n  /**\n   * Logs a message to the console.\n   *\n   * Use instead of `console.debug()`.\n   *\n   * Those messages are not shown by default, but they can be shown by enabling `your-plugin-id` debugger namespace.\n   *\n   * @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging} for more information.\n   *\n   * @param message - The message to log.\n   * @param args - The arguments to log.\n   */\n  public consoleDebug(message: string, ...args: unknown[]): void {\n    // Skip the `consoleDebug()` call itself\n    const FRAMES_TO_SKIP = 1;\n    const _debugger = getDebugger(this.manifest.id, FRAMES_TO_SKIP);\n    _debugger(message, ...args);\n  }\n\n  /**\n   * Called when the external settings change.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await this.settingsManager.loadFromFile();\n  }\n\n  /**\n   * Adds a lifecycle event listener.\n   * If the event has already occurred, the callback will be called immediately.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback to call when the event is triggered.\n   * @returns A {@link Promise} that resolves when the callback is executed.\n   */\n  public async onLifecycleEvent(name: LifecycleEventName, callback: () => Promisable<unknown>): Promise<void> {\n    if (!this.lifecycleEventNames.has(name)) {\n      await new Promise<void>((resolve) => {\n        this.events.once(name, () => {\n          resolve();\n        });\n      });\n    }\n\n    await callback();\n  }\n\n  /**\n   * Called when the plugin is loaded\n   */\n  public override async onload(): Promise<void> {\n    initPluginContext(this.app, this.manifest.id);\n\n    this.register(registerAsyncErrorEventHandler(() => {\n      this.showNotice('An unhandled error occurred. Please check the console for more information.');\n    }));\n\n    this._settingsManager = this.createSettingsManager();\n\n    await this.onExternalSettingsChange();\n    const pluginSettingsTab = this.createPluginSettingsTab();\n    if (pluginSettingsTab) {\n      this.addSettingTab(pluginSettingsTab);\n    }\n\n    const abortController = new AbortController();\n    this._abortSignal = abortController.signal;\n    this.register(() => {\n      abortController.abort();\n    });\n    await this.onloadComplete();\n    await this.triggerLifecycleEvent('loadComplete');\n    setTimeout(() => {\n      this.app.workspace.onLayoutReady(convertAsyncToSync(async () => {\n        await this.onLayoutReady();\n        await this.triggerLifecycleEvent('layoutReady');\n      }));\n    }, 0);\n  }\n\n  /**\n   * Called when the plugin settings are loaded or reloaded.\n   *\n   * @param _settings - The settings.\n   * @returns A {@link Promise} or `void` indicating the completion of the save process\n   */\n  public onLoadSettings(_settings: PluginSettings): Promisable<void> {\n    noop();\n  }\n\n  /**\n   * Called when the plugin settings are saved.\n   *\n   * @param _newSettings - The new settings.\n   * @param _oldSettings - The old settings.\n   * @returns A {@link Promise} or `void` indicating the completion of the save process\n   */\n  public onSaveSettings(_newSettings: PluginSettings, _oldSettings: PluginSettings): Promisable<void> {\n    noop();\n  }\n\n  public override onunload(): void {\n    invokeAsyncSafely(() => this.triggerLifecycleEvent('unload'));\n  }\n\n  /**\n   * Registers an async event.\n   * Unregisters the event when the plugin is unloaded.\n   *\n   * @param eventRef - The event reference.\n   */\n  public registerAsyncEvent(eventRef: AsyncEventRef): void {\n    this.register(() => {\n      eventRef.asyncEvents.offref(eventRef);\n    });\n  }\n\n  /**\n   * Creates a plugin settings tab.\n   *\n   * @returns The settings tab or null if not applicable.\n   */\n  protected createPluginSettingsTab(): null | PluginSettingTab {\n    return null;\n  }\n\n  /**\n   * Creates the plugin settings manager. This method must be implemented by subclasses.\n   *\n   * @returns The plugin settings manager.\n   */\n  protected createSettingsManager(): null | PluginSettingsManagerBase<PluginSettings> {\n    return null;\n  }\n\n  /**\n   * Called when the layout is ready. This method can be overridden by subclasses to perform actions once\n   * the layout is ready.\n   *\n   * @returns A {@link Promise} or `void` indicating the completion of the layout setup.\n   */\n  protected onLayoutReady(): Promisable<void> {\n    noop();\n  }\n\n  /**\n   * Called when the plugin loading is complete. This method must be implemented by subclasses to perform\n   * any additional setup required after loading is complete.\n   *\n   * @returns A {@link Promise} or `void` indicating the completion of the load process.\n   */\n  protected onloadComplete(): Promisable<void> {\n    noop();\n  }\n\n  /**\n   * Displays a notice message to the user.\n   *\n   * @param message - The message to display.\n   */\n  protected showNotice(message: string): void {\n    if (this.notice) {\n      this.notice.hide();\n    }\n\n    this.notice = new Notice(`${this.manifest.name}\\n${message}`);\n  }\n\n  private async triggerLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    this.lifecycleEventNames.add(name);\n    await this.events.triggerAsync(name);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

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

|
@@ -58,15 +58,6 @@ export declare abstract class PluginBase<PluginSettings extends object = object>
|
|
58
58
|
* Called when the external settings change.
|
59
59
|
*/
|
60
60
|
onExternalSettingsChange(): Promise<void>;
|
61
|
-
/**
|
62
|
-
* Adds a lifecycle event listener.
|
63
|
-
* If the event has already occurred, the callback will be called immediately.
|
64
|
-
*
|
65
|
-
* @param name - The name of the event.
|
66
|
-
* @param callback - The callback to call when the event is triggered.
|
67
|
-
* @returns A {@link Promise} that resolves when the callback is executed.
|
68
|
-
*/
|
69
|
-
onLifecycleEvent(name: LifecycleEventName, callback: () => Promisable<unknown>): Promise<void>;
|
70
61
|
/**
|
71
62
|
* Called when the plugin is loaded
|
72
63
|
*/
|
@@ -94,6 +85,17 @@ export declare abstract class PluginBase<PluginSettings extends object = object>
|
|
94
85
|
* @param eventRef - The event reference.
|
95
86
|
*/
|
96
87
|
registerAsyncEvent(eventRef: AsyncEventRef): void;
|
88
|
+
/**
|
89
|
+
* Waits for a lifecycle event to be triggered.
|
90
|
+
*
|
91
|
+
* If you `await` this method during lifecycle event, it might cause a deadlock.
|
92
|
+
*
|
93
|
+
* Consider wrapping this call with {@link invokeAsyncSafely}.
|
94
|
+
*
|
95
|
+
* @param name - The name of the event.
|
96
|
+
* @returns A {@link Promise} that resolves when the event is triggered.
|
97
|
+
*/
|
98
|
+
waitForLifecycleEvent(name: LifecycleEventName): Promise<void>;
|
97
99
|
/**
|
98
100
|
* Creates a plugin settings tab.
|
99
101
|
*
|
@@ -29,6 +29,7 @@ __export(SettingEx_exports, {
|
|
29
29
|
});
|
30
30
|
module.exports = __toCommonJS(SettingEx_exports);
|
31
31
|
var import_obsidian = require('obsidian');
|
32
|
+
var import_CheckboxComponent = require('./Components/CheckboxComponent.cjs');
|
32
33
|
var import_DateComponent = require('./Components/DateComponent.cjs');
|
33
34
|
var import_DateTimeComponent = require('./Components/DateTimeComponent.cjs');
|
34
35
|
var import_EmailComponent = require('./Components/EmailComponent.cjs');
|
@@ -40,9 +41,21 @@ var import_MultipleFileComponent = require('./Components/MultipleFileComponent.c
|
|
40
41
|
var import_MultipleTextComponent = require('./Components/MultipleTextComponent.cjs');
|
41
42
|
var import_NumberComponent = require('./Components/NumberComponent.cjs');
|
42
43
|
var import_TimeComponent = require('./Components/TimeComponent.cjs');
|
44
|
+
var import_TriStateCheckboxComponent = require('./Components/TriStateCheckboxComponent.cjs');
|
45
|
+
var import_TypedDropdownComponent = require('./Components/TypedDropdownComponent.cjs');
|
46
|
+
var import_TypedMultipleDropdownComponent = require('./Components/TypedMultipleDropdownComponent.cjs');
|
43
47
|
var import_UrlComponent = require('./Components/UrlComponent.cjs');
|
44
48
|
var import_WeekComponent = require('./Components/WeekComponent.cjs');
|
45
49
|
class SettingEx extends import_obsidian.Setting {
|
50
|
+
/**
|
51
|
+
* Adds a {@link CheckboxComponent} to the setting.
|
52
|
+
*
|
53
|
+
* @param cb - The callback to call with the component.
|
54
|
+
* @returns The setting instance.
|
55
|
+
*/
|
56
|
+
addCheckbox(cb) {
|
57
|
+
return this.addComponent(import_CheckboxComponent.CheckboxComponent, cb);
|
58
|
+
}
|
46
59
|
/**
|
47
60
|
* Adds a component to the setting.
|
48
61
|
*
|
@@ -156,6 +169,33 @@ class SettingEx extends import_obsidian.Setting {
|
|
156
169
|
addTime(cb) {
|
157
170
|
return this.addComponent(import_TimeComponent.TimeComponent, cb);
|
158
171
|
}
|
172
|
+
/**
|
173
|
+
* Adds a {@link TriStateCheckboxComponent} to the setting.
|
174
|
+
*
|
175
|
+
* @param cb - The callback to call with the component.
|
176
|
+
* @returns The setting instance.
|
177
|
+
*/
|
178
|
+
addTriStateCheckbox(cb) {
|
179
|
+
return this.addComponent(import_TriStateCheckboxComponent.TriStateCheckboxComponent, cb);
|
180
|
+
}
|
181
|
+
/**
|
182
|
+
* Adds a {@link TypedDropdownComponent} to the setting.
|
183
|
+
*
|
184
|
+
* @param cb - The callback to call with the component.
|
185
|
+
* @returns The setting instance.
|
186
|
+
*/
|
187
|
+
addTypedDropdown(cb) {
|
188
|
+
return this.addComponent(import_TypedDropdownComponent.TypedDropdownComponent, cb);
|
189
|
+
}
|
190
|
+
/**
|
191
|
+
* Adds a {@link TypedMultipleDropdownComponent} to the setting.
|
192
|
+
*
|
193
|
+
* @param cb - The callback to call with the component.
|
194
|
+
* @returns The setting instance.
|
195
|
+
*/
|
196
|
+
addTypedMultipleDropdown(cb) {
|
197
|
+
return this.addComponent(import_TypedMultipleDropdownComponent.TypedMultipleDropdownComponent, cb);
|
198
|
+
}
|
159
199
|
/**
|
160
200
|
* Adds an {@link UrlComponent} to the setting.
|
161
201
|
*
|
@@ -179,4 +219,4 @@ class SettingEx extends import_obsidian.Setting {
|
|
179
219
|
0 && (module.exports = {
|
180
220
|
SettingEx
|
181
221
|
});
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/SettingEx.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation SettingEx\n * Extends the Setting class with additional methods for adding components.\n */\n\nimport type { BaseComponent } from 'obsidian';\n\nimport { Setting } from 'obsidian';\n\nimport { DateComponent } from './Components/DateComponent.ts';\nimport { DateTimeComponent } from './Components/DateTimeComponent.ts';\nimport { EmailComponent } from './Components/EmailComponent.ts';\nimport { FileComponent } from './Components/FileComponent.ts';\nimport { MonthComponent } from './Components/MonthComponent.ts';\nimport { MultipleDropdownComponent } from './Components/MultipleDropdownComponent.ts';\nimport { MultipleEmailComponent } from './Components/MultipleEmailComponent.ts';\nimport { MultipleFileComponent } from './Components/MultipleFileComponent.ts';\nimport { MultipleTextComponent } from './Components/MultipleTextComponent.ts';\nimport { NumberComponent } from './Components/NumberComponent.ts';\nimport { TimeComponent } from './Components/TimeComponent.ts';\nimport { UrlComponent } from './Components/UrlComponent.ts';\nimport { WeekComponent } from './Components/WeekComponent.ts';\n\n/**\n * Extends the Setting class with additional methods for adding components.\n */\nexport class SettingEx extends Setting {\n  /**\n   * Adds a component to the setting.\n   *\n   * @typeParam T - The type of the component to add.\n   * @param componentClass - The class of the component to add.\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addComponent<T extends BaseComponent>(componentClass: new (controlEl: HTMLElement) => T, cb: (component: T) => void): this {\n    const component = new componentClass(this.controlEl);\n    this.components.push(component);\n    cb(component);\n    return this;\n  }\n\n  /**\n   * Adds a {@link DateComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDate(cb: (component: DateComponent) => void): this {\n    return this.addComponent(DateComponent, cb);\n  }\n\n  /**\n   * Adds a {@link DateTimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDateTime(cb: (component: DateTimeComponent) => void): this {\n    return this.addComponent(DateTimeComponent, cb);\n  }\n\n  /**\n   * Adds an {@link EmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addEmail(cb: (component: EmailComponent) => void): this {\n    return this.addComponent(EmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link FileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addFile(cb: (component: FileComponent) => void): this {\n    return this.addComponent(FileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MonthComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMonth(cb: (component: MonthComponent) => void): this {\n    return this.addComponent(MonthComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleDropdown(cb: (component: MultipleDropdownComponent) => void): this {\n    return this.addComponent(MultipleDropdownComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleEmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleEmail(cb: (component: MultipleEmailComponent) => void): this {\n    return this.addComponent(MultipleEmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleFileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleFile(cb: (component: MultipleFileComponent) => void): this {\n    return this.addComponent(MultipleFileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleTextComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleText(cb: (component: MultipleTextComponent) => void): this {\n    return this.addComponent(MultipleTextComponent, cb);\n  }\n\n  /**\n   * Adds a {@link NumberComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addNumber(cb: (component: NumberComponent) => void): this {\n    return this.addComponent(NumberComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTime(cb: (component: TimeComponent) => void): this {\n    return this.addComponent(TimeComponent, cb);\n  }\n\n  /**\n   * Adds an {@link UrlComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addUrl(cb: (component: UrlComponent) => void): this {\n    return this.addComponent(UrlComponent, cb);\n  }\n\n  /**\n   * Adds a {@link WeekComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addWeek(cb: (component: WeekComponent) => void): this {\n    return this.addComponent(WeekComponent, cb);\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA,sBAAwB;AAExB,2BAA8B;AAC9B,+BAAkC;AAClC,4BAA+B;AAC/B,2BAA8B;AAC9B,4BAA+B;AAC/B,uCAA0C;AAC1C,oCAAuC;AACvC,mCAAsC;AACtC,mCAAsC;AACtC,6BAAgC;AAChC,2BAA8B;AAC9B,0BAA6B;AAC7B,2BAA8B;AAKvB,MAAM,kBAAkB,wBAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAS9B,aAAsC,gBAAmD,IAAkC;AAChI,UAAM,YAAY,IAAI,eAAe,KAAK,SAAS;AACnD,SAAK,WAAW,KAAK,SAAS;AAC9B,OAAG,SAAS;AACZ,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,oCAAe,EAAE;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,YAAY,IAAkD;AACnE,WAAO,KAAK,aAAa,4CAAmB,EAAE;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,SAAS,IAA+C;AAC7D,WAAO,KAAK,aAAa,sCAAgB,EAAE;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,oCAAe,EAAE;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,SAAS,IAA+C;AAC7D,WAAO,KAAK,aAAa,sCAAgB,EAAE;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,oBAAoB,IAA0D;AACnF,WAAO,KAAK,aAAa,4DAA2B,EAAE;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,iBAAiB,IAAuD;AAC7E,WAAO,KAAK,aAAa,sDAAwB,EAAE;AAAA,EACrD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,gBAAgB,IAAsD;AAC3E,WAAO,KAAK,aAAa,oDAAuB,EAAE;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,gBAAgB,IAAsD;AAC3E,WAAO,KAAK,aAAa,oDAAuB,EAAE;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAU,IAAgD;AAC/D,WAAO,KAAK,aAAa,wCAAiB,EAAE;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,oCAAe,EAAE;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,OAAO,IAA6C;AACzD,WAAO,KAAK,aAAa,kCAAc,EAAE;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,oCAAe,EAAE;AAAA,EAC5C;AACF;",
  "names": []
}

|
222
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/SettingEx.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation SettingEx\n * Extends the Setting class with additional methods for adding components.\n */\n\nimport type { BaseComponent } from 'obsidian';\n\nimport { Setting } from 'obsidian';\n\nimport { CheckboxComponent } from './Components/CheckboxComponent.ts';\nimport { DateComponent } from './Components/DateComponent.ts';\nimport { DateTimeComponent } from './Components/DateTimeComponent.ts';\nimport { EmailComponent } from './Components/EmailComponent.ts';\nimport { FileComponent } from './Components/FileComponent.ts';\nimport { MonthComponent } from './Components/MonthComponent.ts';\nimport { MultipleDropdownComponent } from './Components/MultipleDropdownComponent.ts';\nimport { MultipleEmailComponent } from './Components/MultipleEmailComponent.ts';\nimport { MultipleFileComponent } from './Components/MultipleFileComponent.ts';\nimport { MultipleTextComponent } from './Components/MultipleTextComponent.ts';\nimport { NumberComponent } from './Components/NumberComponent.ts';\nimport { TimeComponent } from './Components/TimeComponent.ts';\nimport { TriStateCheckboxComponent } from './Components/TriStateCheckboxComponent.ts';\nimport { TypedDropdownComponent } from './Components/TypedDropdownComponent.ts';\nimport { TypedMultipleDropdownComponent } from './Components/TypedMultipleDropdownComponent.ts';\nimport { UrlComponent } from './Components/UrlComponent.ts';\nimport { WeekComponent } from './Components/WeekComponent.ts';\n\n/**\n * Extends the Setting class with additional methods for adding components.\n */\nexport class SettingEx extends Setting {\n  /**\n   * Adds a {@link CheckboxComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addCheckbox(cb: (component: CheckboxComponent) => void): this {\n    return this.addComponent(CheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a component to the setting.\n   *\n   * @typeParam T - The type of the component to add.\n   * @param componentClass - The class of the component to add.\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addComponent<T extends BaseComponent>(componentClass: new (containerEl: HTMLElement) => T, cb: (component: T) => void): this {\n    const component = new componentClass(this.controlEl);\n    this.components.push(component);\n    cb(component);\n    return this;\n  }\n\n  /**\n   * Adds a {@link DateComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDate(cb: (component: DateComponent) => void): this {\n    return this.addComponent(DateComponent, cb);\n  }\n\n  /**\n   * Adds a {@link DateTimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDateTime(cb: (component: DateTimeComponent) => void): this {\n    return this.addComponent(DateTimeComponent, cb);\n  }\n\n  /**\n   * Adds an {@link EmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addEmail(cb: (component: EmailComponent) => void): this {\n    return this.addComponent(EmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link FileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addFile(cb: (component: FileComponent) => void): this {\n    return this.addComponent(FileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MonthComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMonth(cb: (component: MonthComponent) => void): this {\n    return this.addComponent(MonthComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleDropdown(cb: (component: MultipleDropdownComponent) => void): this {\n    return this.addComponent(MultipleDropdownComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleEmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleEmail(cb: (component: MultipleEmailComponent) => void): this {\n    return this.addComponent(MultipleEmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleFileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleFile(cb: (component: MultipleFileComponent) => void): this {\n    return this.addComponent(MultipleFileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleTextComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleText(cb: (component: MultipleTextComponent) => void): this {\n    return this.addComponent(MultipleTextComponent, cb);\n  }\n\n  /**\n   * Adds a {@link NumberComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addNumber(cb: (component: NumberComponent) => void): this {\n    return this.addComponent(NumberComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTime(cb: (component: TimeComponent) => void): this {\n    return this.addComponent(TimeComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TriStateCheckboxComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTriStateCheckbox(cb: (component: TriStateCheckboxComponent) => void): this {\n    return this.addComponent(TriStateCheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TypedDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTypedDropdown<T>(cb: (component: TypedDropdownComponent<T>) => void): this {\n    return this.addComponent(TypedDropdownComponent<T>, cb);\n  }\n\n  /**\n   * Adds a {@link TypedMultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTypedMultipleDropdown<T>(cb: (component: TypedMultipleDropdownComponent<T>) => void): this {\n    return this.addComponent(TypedMultipleDropdownComponent<T>, cb);\n  }\n\n  /**\n   * Adds an {@link UrlComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addUrl(cb: (component: UrlComponent) => void): this {\n    return this.addComponent(UrlComponent, cb);\n  }\n\n  /**\n   * Adds a {@link WeekComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addWeek(cb: (component: WeekComponent) => void): this {\n    return this.addComponent(WeekComponent, cb);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
@@ -4,6 +4,7 @@
|
|
4
4
|
*/
|
5
5
|
import type { BaseComponent } from 'obsidian';
|
6
6
|
import { Setting } from 'obsidian';
|
7
|
+
import { CheckboxComponent } from './Components/CheckboxComponent.cjs';
|
7
8
|
import { DateComponent } from './Components/DateComponent.cjs';
|
8
9
|
import { DateTimeComponent } from './Components/DateTimeComponent.cjs';
|
9
10
|
import { EmailComponent } from './Components/EmailComponent.cjs';
|
@@ -15,12 +16,22 @@ import { MultipleFileComponent } from './Components/MultipleFileComponent.cjs';
|
|
15
16
|
import { MultipleTextComponent } from './Components/MultipleTextComponent.cjs';
|
16
17
|
import { NumberComponent } from './Components/NumberComponent.cjs';
|
17
18
|
import { TimeComponent } from './Components/TimeComponent.cjs';
|
19
|
+
import { TriStateCheckboxComponent } from './Components/TriStateCheckboxComponent.cjs';
|
20
|
+
import { TypedDropdownComponent } from './Components/TypedDropdownComponent.cjs';
|
21
|
+
import { TypedMultipleDropdownComponent } from './Components/TypedMultipleDropdownComponent.cjs';
|
18
22
|
import { UrlComponent } from './Components/UrlComponent.cjs';
|
19
23
|
import { WeekComponent } from './Components/WeekComponent.cjs';
|
20
24
|
/**
|
21
25
|
* Extends the Setting class with additional methods for adding components.
|
22
26
|
*/
|
23
27
|
export declare class SettingEx extends Setting {
|
28
|
+
/**
|
29
|
+
* Adds a {@link CheckboxComponent} to the setting.
|
30
|
+
*
|
31
|
+
* @param cb - The callback to call with the component.
|
32
|
+
* @returns The setting instance.
|
33
|
+
*/
|
34
|
+
addCheckbox(cb: (component: CheckboxComponent) => void): this;
|
24
35
|
/**
|
25
36
|
* Adds a component to the setting.
|
26
37
|
*
|
@@ -29,7 +40,7 @@ export declare class SettingEx extends Setting {
|
|
29
40
|
* @param cb - The callback to call with the component.
|
30
41
|
* @returns The setting instance.
|
31
42
|
*/
|
32
|
-
addComponent<T extends BaseComponent>(componentClass: new (
|
43
|
+
addComponent<T extends BaseComponent>(componentClass: new (containerEl: HTMLElement) => T, cb: (component: T) => void): this;
|
33
44
|
/**
|
34
45
|
* Adds a {@link DateComponent} to the setting.
|
35
46
|
*
|
@@ -107,6 +118,27 @@ export declare class SettingEx extends Setting {
|
|
107
118
|
* @returns The setting instance.
|
108
119
|
*/
|
109
120
|
addTime(cb: (component: TimeComponent) => void): this;
|
121
|
+
/**
|
122
|
+
* Adds a {@link TriStateCheckboxComponent} to the setting.
|
123
|
+
*
|
124
|
+
* @param cb - The callback to call with the component.
|
125
|
+
* @returns The setting instance.
|
126
|
+
*/
|
127
|
+
addTriStateCheckbox(cb: (component: TriStateCheckboxComponent) => void): this;
|
128
|
+
/**
|
129
|
+
* Adds a {@link TypedDropdownComponent} to the setting.
|
130
|
+
*
|
131
|
+
* @param cb - The callback to call with the component.
|
132
|
+
* @returns The setting instance.
|
133
|
+
*/
|
134
|
+
addTypedDropdown<T>(cb: (component: TypedDropdownComponent<T>) => void): this;
|
135
|
+
/**
|
136
|
+
* Adds a {@link TypedMultipleDropdownComponent} to the setting.
|
137
|
+
*
|
138
|
+
* @param cb - The callback to call with the component.
|
139
|
+
* @returns The setting instance.
|
140
|
+
*/
|
141
|
+
addTypedMultipleDropdown<T>(cb: (component: TypedMultipleDropdownComponent<T>) => void): this;
|
110
142
|
/**
|
111
143
|
* Adds an {@link UrlComponent} to the setting.
|
112
144
|
*
|
@@ -70,7 +70,7 @@ export declare class AsyncEvents {
|
|
70
70
|
*
|
71
71
|
* @public
|
72
72
|
*/
|
73
|
-
on(name: string, callback: (...args: unknown[]) => Promisable<
|
73
|
+
on(name: string, callback: (...args: unknown[]) => Promisable<void>, thisArg?: unknown): AsyncEventRef;
|
74
74
|
/**
|
75
75
|
* Add an event listener that will be triggered only once.
|
76
76
|
*
|
@@ -89,7 +89,7 @@ export declare class AsyncEvents {
|
|
89
89
|
*
|
90
90
|
* @public
|
91
91
|
*/
|
92
|
-
once(name: string, callback: (...args: unknown[]) => Promisable<
|
92
|
+
once(name: string, callback: (...args: unknown[]) => Promisable<void>, thisArg?: unknown): AsyncEventRef;
|
93
93
|
/**
|
94
94
|
* Trigger an event, executing all the listeners in order even if some of them throw an error.
|
95
95
|
*
|
@@ -189,4 +189,4 @@ class AsyncEvents {
|
|
189
189
|
export {
|
190
190
|
AsyncEvents
|
191
191
|
};
|
192
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/AsyncEvents.ts"],
  "sourcesContent": ["import type { Promisable } from 'type-fest';\n\nimport { filterInPlace } from './Array.ts';\n\n/**\n * Async event reference.\n */\nexport interface AsyncEventRef {\n  /**\n   * The event emitter.\n   */\n  asyncEvents: AsyncEvents;\n\n  /**\n   * The callback to call when the event is triggered.\n   */\n  callback: (...args: unknown[]) => Promisable<unknown>;\n\n  /**\n   * The name of the event.\n   */\n  name: string;\n\n  /**\n   * The context passed as `this` to the `callback`.\n   */\n  thisArg: unknown;\n}\n\n/**\n * Async event emitter implementation\n */\nexport class AsyncEvents {\n  private eventRefsMap = new Map<string, AsyncEventRef[]>();\n\n  /**\n   * Remove an event listener.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback to remove.\n   *\n   * @example\n   * ```ts\n   * events.off('my-event', myListener);\n   * ```\n   *\n   * @public\n   */\n  public off(name: string, callback: (...args: unknown[]) => Promisable<unknown>): void {\n    const eventRefs = this.eventRefsMap.get(name);\n    if (!eventRefs) {\n      return;\n    }\n\n    filterInPlace(eventRefs, (eventRef) => eventRef.callback !== callback);\n    if (eventRefs.length === 0) {\n      this.eventRefsMap.delete(name);\n    }\n  }\n\n  /**\n   * Remove an event listener by reference.\n   *\n   * @param eventRef - The reference to the event listener.\n   *\n   * @example\n   * ```ts\n   * events.offref(myRef);\n   * ```\n   *\n   * @public\n   */\n  public offref(eventRef: AsyncEventRef): void {\n    const eventRefs = this.eventRefsMap.get(eventRef.name);\n    if (!eventRefs) {\n      return;\n    }\n\n    filterInPlace(eventRefs, (storedEventRef) => storedEventRef !== eventRef);\n    if (eventRefs.length === 0) {\n      this.eventRefsMap.delete(eventRef.name);\n    }\n  }\n\n  /**\n   * Add an event listener.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback to call when the event is triggered.\n   * @param thisArg - The context passed as `this` to the `callback`.\n   * @returns A reference to the event listener.\n   *\n   * @example\n   * ```ts\n   * events.on('my-event', async (arg1, arg2) => {\n   *     await sleep(100);\n   *     console.log(arg1, arg2);\n   * });\n   * ```\n   *\n   * @public\n   */\n  public on(name: string, callback: (...args: unknown[]) => Promisable<unknown>, thisArg?: unknown): AsyncEventRef {\n    let eventRefs = this.eventRefsMap.get(name);\n    if (!eventRefs) {\n      eventRefs = [];\n      this.eventRefsMap.set(name, eventRefs);\n    }\n\n    const eventRef: AsyncEventRef = {\n      asyncEvents: this,\n      callback,\n      name,\n      thisArg\n    };\n    eventRefs.push(eventRef);\n    return eventRef;\n  }\n\n  /**\n   * Add an event listener that will be triggered only once.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback to call when the event is triggered.\n   * @param thisArg - The context passed as `this` to the `callback`.\n   * @returns A reference to the event listener.\n   *\n   * @example\n   * ```ts\n   * events.once('my-event', async (arg1, arg2) => {\n   *     await sleep(100);\n   *     console.log(arg1, arg2);\n   * });\n   * ```\n   *\n   * @public\n   */\n  public once(name: string, callback: (...args: unknown[]) => Promisable<unknown>, thisArg?: unknown): AsyncEventRef {\n    const originalEventRef = this.on(name, callback, thisArg);\n    const cleanupEventRef = this.on(name, () => {\n      this.offref(originalEventRef);\n      this.offref(cleanupEventRef);\n    });\n    return originalEventRef;\n  }\n\n  /**\n   * Trigger an event, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param name - The name of the event.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @example\n   * ```ts\n   * events.trigger('my-event', 'arg1', 'arg2');\n   * ```\n   *\n   * @public\n   */\n  public trigger(name: string, ...args: unknown[]): void {\n    const eventRefs = this.eventRefsMap.get(name) ?? [];\n    for (const eventRef of eventRefs.slice()) {\n      this.tryTrigger(eventRef, args);\n    }\n  }\n\n  /**\n   * Trigger an event asynchronously, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param name - The name of the event.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @public\n   */\n  public async triggerAsync(name: string, ...args: unknown[]): Promise<void> {\n    const eventRefs = this.eventRefsMap.get(name) ?? [];\n    for (const eventRef of eventRefs.slice()) {\n      await this.tryTriggerAsync(eventRef, args);\n    }\n  }\n\n  /**\n   * Try to trigger an event, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param eventRef - The event reference.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @example\n   * ```ts\n   * events.tryTrigger(myRef, ['arg1', 'arg2']);\n   * ```\n   *\n   * @public\n   */\n  public tryTrigger(eventRef: AsyncEventRef, args: unknown[]): void {\n    try {\n      eventRef.callback.apply(eventRef.thisArg, args);\n    } catch (e) {\n      setTimeout(() => {\n        throw e;\n      }, 0);\n    }\n  }\n\n  /**\n   * Try to trigger an event asynchronously, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param eventRef - The event reference.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @public\n   */\n  public async tryTriggerAsync(eventRef: AsyncEventRef, args: unknown[]): Promise<void> {\n    try {\n      const result = eventRef.callback.call(eventRef.thisArg, ...args);\n      await (result as Promise<void>);\n    } catch (e) {\n      setTimeout(() => {\n        throw e;\n      }, 0);\n    }\n  }\n}\n\n/*\n\nVar fs = (function () {\n        return (\n          (e.prototype.offref = function (e) {\n          }),\n          (e.prototype.trigger = function (e) {\n            for (var t = [], n = 1; n < arguments.length; n++)\n              t[n - 1] = arguments[n];\n            var r = this._[e];\n            if (r) {\n              r = r.slice();\n              for (var a = 0; a < r.length; a++) this.tryTrigger(r[a], t);\n            }\n          }),\n          (e.prototype.tryTrigger = function (e, t) {\n            try {\n              e.fn.apply(e.ctx, t);\n            } catch (e) {\n              setTimeout(function () {\n                throw e;\n              }, 0);\n            }\n          }),\n          e\n        );\n      })();\n*/\n"],
  "mappings": ";;;;;;;AAEA,SAAS,qBAAqB;AA8BvB,MAAM,YAAY;AAAA,EACf,eAAe,oBAAI,IAA6B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAejD,IAAI,MAAc,UAA6D;AACpF,UAAM,YAAY,KAAK,aAAa,IAAI,IAAI;AAC5C,QAAI,CAAC,WAAW;AACd;AAAA,IACF;AAEA,kBAAc,WAAW,CAAC,aAAa,SAAS,aAAa,QAAQ;AACrE,QAAI,UAAU,WAAW,GAAG;AAC1B,WAAK,aAAa,OAAO,IAAI;AAAA,IAC/B;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcO,OAAO,UAA+B;AAC3C,UAAM,YAAY,KAAK,aAAa,IAAI,SAAS,IAAI;AACrD,QAAI,CAAC,WAAW;AACd;AAAA,IACF;AAEA,kBAAc,WAAW,CAAC,mBAAmB,mBAAmB,QAAQ;AACxE,QAAI,UAAU,WAAW,GAAG;AAC1B,WAAK,aAAa,OAAO,SAAS,IAAI;AAAA,IACxC;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAoBO,GAAG,MAAc,UAAuD,SAAkC;AAC/G,QAAI,YAAY,KAAK,aAAa,IAAI,IAAI;AAC1C,QAAI,CAAC,WAAW;AACd,kBAAY,CAAC;AACb,WAAK,aAAa,IAAI,MAAM,SAAS;AAAA,IACvC;AAEA,UAAM,WAA0B;AAAA,MAC9B,aAAa;AAAA,MACb;AAAA,MACA;AAAA,MACA;AAAA,IACF;AACA,cAAU,KAAK,QAAQ;AACvB,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAoBO,KAAK,MAAc,UAAuD,SAAkC;AACjH,UAAM,mBAAmB,KAAK,GAAG,MAAM,UAAU,OAAO;AACxD,UAAM,kBAAkB,KAAK,GAAG,MAAM,MAAM;AAC1C,WAAK,OAAO,gBAAgB;AAC5B,WAAK,OAAO,eAAe;AAAA,IAC7B,CAAC;AACD,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeO,QAAQ,SAAiB,MAAuB;AACrD,UAAM,YAAY,KAAK,aAAa,IAAI,IAAI,KAAK,CAAC;AAClD,eAAW,YAAY,UAAU,MAAM,GAAG;AACxC,WAAK,WAAW,UAAU,IAAI;AAAA,IAChC;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAa,aAAa,SAAiB,MAAgC;AACzE,UAAM,YAAY,KAAK,aAAa,IAAI,IAAI,KAAK,CAAC;AAClD,eAAW,YAAY,UAAU,MAAM,GAAG;AACxC,YAAM,KAAK,gBAAgB,UAAU,IAAI;AAAA,IAC3C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeO,WAAW,UAAyB,MAAuB;AAChE,QAAI;AACF,eAAS,SAAS,MAAM,SAAS,SAAS,IAAI;AAAA,IAChD,SAAS,GAAG;AACV,iBAAW,MAAM;AACf,cAAM;AAAA,MACR,GAAG,CAAC;AAAA,IACN;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAa,gBAAgB,UAAyB,MAAgC;AACpF,QAAI;AACF,YAAM,SAAS,SAAS,SAAS,KAAK,SAAS,SAAS,GAAG,IAAI;AAC/D,YAAO;AAAA,IACT,SAAS,GAAG;AACV,iBAAW,MAAM;AACf,cAAM;AAAA,MACR,GAAG,CAAC;AAAA,IACN;AAAA,EACF;AACF;",
  "names": []
}

|
192
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/AsyncEvents.ts"],
  "sourcesContent": ["import type { Promisable } from 'type-fest';\n\nimport { filterInPlace } from './Array.ts';\n\n/**\n * Async event reference.\n */\nexport interface AsyncEventRef {\n  /**\n   * The event emitter.\n   */\n  asyncEvents: AsyncEvents;\n\n  /**\n   * The callback to call when the event is triggered.\n   */\n  callback: (...args: unknown[]) => Promisable<unknown>;\n\n  /**\n   * The name of the event.\n   */\n  name: string;\n\n  /**\n   * The context passed as `this` to the `callback`.\n   */\n  thisArg: unknown;\n}\n\n/**\n * Async event emitter implementation\n */\nexport class AsyncEvents {\n  private eventRefsMap = new Map<string, AsyncEventRef[]>();\n\n  /**\n   * Remove an event listener.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback to remove.\n   *\n   * @example\n   * ```ts\n   * events.off('my-event', myListener);\n   * ```\n   *\n   * @public\n   */\n  public off(name: string, callback: (...args: unknown[]) => Promisable<unknown>): void {\n    const eventRefs = this.eventRefsMap.get(name);\n    if (!eventRefs) {\n      return;\n    }\n\n    filterInPlace(eventRefs, (eventRef) => eventRef.callback !== callback);\n    if (eventRefs.length === 0) {\n      this.eventRefsMap.delete(name);\n    }\n  }\n\n  /**\n   * Remove an event listener by reference.\n   *\n   * @param eventRef - The reference to the event listener.\n   *\n   * @example\n   * ```ts\n   * events.offref(myRef);\n   * ```\n   *\n   * @public\n   */\n  public offref(eventRef: AsyncEventRef): void {\n    const eventRefs = this.eventRefsMap.get(eventRef.name);\n    if (!eventRefs) {\n      return;\n    }\n\n    filterInPlace(eventRefs, (storedEventRef) => storedEventRef !== eventRef);\n    if (eventRefs.length === 0) {\n      this.eventRefsMap.delete(eventRef.name);\n    }\n  }\n\n  /**\n   * Add an event listener.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback to call when the event is triggered.\n   * @param thisArg - The context passed as `this` to the `callback`.\n   * @returns A reference to the event listener.\n   *\n   * @example\n   * ```ts\n   * events.on('my-event', async (arg1, arg2) => {\n   *     await sleep(100);\n   *     console.log(arg1, arg2);\n   * });\n   * ```\n   *\n   * @public\n   */\n  public on(name: string, callback: (...args: unknown[]) => Promisable<void>, thisArg?: unknown): AsyncEventRef {\n    let eventRefs = this.eventRefsMap.get(name);\n    if (!eventRefs) {\n      eventRefs = [];\n      this.eventRefsMap.set(name, eventRefs);\n    }\n\n    const eventRef: AsyncEventRef = {\n      asyncEvents: this,\n      callback,\n      name,\n      thisArg\n    };\n    eventRefs.push(eventRef);\n    return eventRef;\n  }\n\n  /**\n   * Add an event listener that will be triggered only once.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback to call when the event is triggered.\n   * @param thisArg - The context passed as `this` to the `callback`.\n   * @returns A reference to the event listener.\n   *\n   * @example\n   * ```ts\n   * events.once('my-event', async (arg1, arg2) => {\n   *     await sleep(100);\n   *     console.log(arg1, arg2);\n   * });\n   * ```\n   *\n   * @public\n   */\n  public once(name: string, callback: (...args: unknown[]) => Promisable<void>, thisArg?: unknown): AsyncEventRef {\n    const originalEventRef = this.on(name, callback, thisArg);\n    const cleanupEventRef = this.on(name, () => {\n      this.offref(originalEventRef);\n      this.offref(cleanupEventRef);\n    });\n    return originalEventRef;\n  }\n\n  /**\n   * Trigger an event, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param name - The name of the event.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @example\n   * ```ts\n   * events.trigger('my-event', 'arg1', 'arg2');\n   * ```\n   *\n   * @public\n   */\n  public trigger(name: string, ...args: unknown[]): void {\n    const eventRefs = this.eventRefsMap.get(name) ?? [];\n    for (const eventRef of eventRefs.slice()) {\n      this.tryTrigger(eventRef, args);\n    }\n  }\n\n  /**\n   * Trigger an event asynchronously, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param name - The name of the event.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @public\n   */\n  public async triggerAsync(name: string, ...args: unknown[]): Promise<void> {\n    const eventRefs = this.eventRefsMap.get(name) ?? [];\n    for (const eventRef of eventRefs.slice()) {\n      await this.tryTriggerAsync(eventRef, args);\n    }\n  }\n\n  /**\n   * Try to trigger an event, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param eventRef - The event reference.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @example\n   * ```ts\n   * events.tryTrigger(myRef, ['arg1', 'arg2']);\n   * ```\n   *\n   * @public\n   */\n  public tryTrigger(eventRef: AsyncEventRef, args: unknown[]): void {\n    try {\n      eventRef.callback.apply(eventRef.thisArg, args);\n    } catch (e) {\n      setTimeout(() => {\n        throw e;\n      }, 0);\n    }\n  }\n\n  /**\n   * Try to trigger an event asynchronously, executing all the listeners in order even if some of them throw an error.\n   *\n   * @param eventRef - The event reference.\n   * @param args - The data to pass to the event listeners.\n   *\n   * @public\n   */\n  public async tryTriggerAsync(eventRef: AsyncEventRef, args: unknown[]): Promise<void> {\n    try {\n      const result = eventRef.callback.call(eventRef.thisArg, ...args);\n      await (result as Promise<void>);\n    } catch (e) {\n      setTimeout(() => {\n        throw e;\n      }, 0);\n    }\n  }\n}\n\n/*\n\nVar fs = (function () {\n        return (\n          (e.prototype.offref = function (e) {\n          }),\n          (e.prototype.trigger = function (e) {\n            for (var t = [], n = 1; n < arguments.length; n++)\n              t[n - 1] = arguments[n];\n            var r = this._[e];\n            if (r) {\n              r = r.slice();\n              for (var a = 0; a < r.length; a++) this.tryTrigger(r[a], t);\n            }\n          }),\n          (e.prototype.tryTrigger = function (e, t) {\n            try {\n              e.fn.apply(e.ctx, t);\n            } catch (e) {\n              setTimeout(function () {\n                throw e;\n              }, 0);\n            }\n          }),\n          e\n        );\n      })();\n*/\n"],
  "mappings": "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",
  "names": []
}

|
@@ -14,6 +14,10 @@ export declare enum CssClass {
|
|
14
14
|
* The CSS class for the cancel button.
|
15
15
|
*/
|
16
16
|
CancelButton = "cancel-button",
|
17
|
+
/**
|
18
|
+
* The CSS class for the checkbox component.
|
19
|
+
*/
|
20
|
+
CheckboxComponent = "checkbox-component",
|
17
21
|
/**
|
18
22
|
* The CSS class for the confirm modal.
|
19
23
|
*/
|
@@ -86,6 +90,18 @@ export declare enum CssClass {
|
|
86
90
|
* The CSS class for the time component.
|
87
91
|
*/
|
88
92
|
TimeComponent = "time-component",
|
93
|
+
/**
|
94
|
+
* The CSS class for the tri-state checkbox component.
|
95
|
+
*/
|
96
|
+
TriStateCheckboxComponent = "tri-state-checkbox-component",
|
97
|
+
/**
|
98
|
+
* The CSS class for the typed dropdown component.
|
99
|
+
*/
|
100
|
+
TypedDropdownComponent = "typed-dropdown-component",
|
101
|
+
/**
|
102
|
+
* The CSS class for the typed multiple dropdown component.
|
103
|
+
*/
|
104
|
+
TypedMultipleDropdownComponent = "typed-multiple-dropdown-component",
|
89
105
|
/**
|
90
106
|
* The CSS class for the url component.
|
91
107
|
*/
|
@@ -8,6 +8,7 @@ if you want to view the source, please visit the github repository of this plugi
|
|
8
8
|
var CssClass = /* @__PURE__ */ ((CssClass2) => {
|
9
9
|
CssClass2["AlertModal"] = "alert-modal";
|
10
10
|
CssClass2["CancelButton"] = "cancel-button";
|
11
|
+
CssClass2["CheckboxComponent"] = "checkbox-component";
|
11
12
|
CssClass2["ConfirmModal"] = "confirm-modal";
|
12
13
|
CssClass2["DateComponent"] = "date-component";
|
13
14
|
CssClass2["DateTimeComponent"] = "datetime-component";
|
@@ -26,6 +27,9 @@ var CssClass = /* @__PURE__ */ ((CssClass2) => {
|
|
26
27
|
CssClass2["SelectItemModal"] = "select-item-modal";
|
27
28
|
CssClass2["TextBox"] = "text-box";
|
28
29
|
CssClass2["TimeComponent"] = "time-component";
|
30
|
+
CssClass2["TriStateCheckboxComponent"] = "tri-state-checkbox-component";
|
31
|
+
CssClass2["TypedDropdownComponent"] = "typed-dropdown-component";
|
32
|
+
CssClass2["TypedMultipleDropdownComponent"] = "typed-multiple-dropdown-component";
|
29
33
|
CssClass2["UrlComponent"] = "url-component";
|
30
34
|
CssClass2["WeekComponent"] = "week-component";
|
31
35
|
return CssClass2;
|
@@ -33,4 +37,4 @@ var CssClass = /* @__PURE__ */ ((CssClass2) => {
|
|
33
37
|
export {
|
34
38
|
CssClass
|
35
39
|
};
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
40
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL0Nzc0NsYXNzLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBDc3NDbGFzc1xuICogQ1NTIGNsYXNzZXMgdXNlZCBieSB0aGUgYG9ic2lkaWFuLWRldi11dGlsc2AgbGlicmFyeS5cbiAqL1xuXG4vKipcbiAqIENTUyBjbGFzc2VzIHVzZWQgYnkgdGhlIGBvYnNpZGlhbi1kZXYtdXRpbHNgIGxpYnJhcnkuXG4gKi9cbmV4cG9ydCBlbnVtIENzc0NsYXNzIHtcbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBhbGVydCBtb2RhbC5cbiAgICovXG4gIEFsZXJ0TW9kYWwgPSAnYWxlcnQtbW9kYWwnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgY2FuY2VsIGJ1dHRvbi5cbiAgICovXG4gIENhbmNlbEJ1dHRvbiA9ICdjYW5jZWwtYnV0dG9uJyxcblxuICAvKipcbiAgICogVGhlIENTUyBjbGFzcyBmb3IgdGhlIGNoZWNrYm94IGNvbXBvbmVudC5cbiAgICovXG4gIENoZWNrYm94Q29tcG9uZW50ID0gJ2NoZWNrYm94LWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBjb25maXJtIG1vZGFsLlxuICAgKi9cbiAgQ29uZmlybU1vZGFsID0gJ2NvbmZpcm0tbW9kYWwnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgZGF0ZSBjb21wb25lbnQuXG4gICAqL1xuICBEYXRlQ29tcG9uZW50ID0gJ2RhdGUtY29tcG9uZW50JyxcblxuICAvKipcbiAgICogVGhlIENTUyBjbGFzcyBmb3IgdGhlIGRhdGUgYW5kIHRpbWUgY29tcG9uZW50LlxuICAgKi9cbiAgRGF0ZVRpbWVDb21wb25lbnQgPSAnZGF0ZXRpbWUtY29tcG9uZW50JyxcblxuICAvKipcbiAgICogVGhlIENTUyBjbGFzcyBmb3IgdGhlIGVtYWlsIGNvbXBvbmVudC5cbiAgICovXG4gIEVtYWlsQ29tcG9uZW50ID0gJ2VtYWlsLWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBmaWxlIGNvbXBvbmVudC5cbiAgICovXG4gIEZpbGVDb21wb25lbnQgPSAnZmlsZS1jb21wb25lbnQnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgbGlicmFyeSBuYW1lLlxuICAgKi9cbiAgTGlicmFyeU5hbWUgPSAnb2JzaWRpYW4tZGV2LXV0aWxzJyxcblxuICAvKipcbiAgICogVGhlIENTUyBjbGFzcyBmb3IgdGhlIG1vbnRoIGNvbXBvbmVudC5cbiAgICovXG4gIE1vbnRoQ29tcG9uZW50ID0gJ21vbnRoLWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBtdWx0aXBsZSBkcm9wZG93biBjb21wb25lbnQuXG4gICAqL1xuICBNdWx0aXBsZURyb3Bkb3duQ29tcG9uZW50ID0gJ211bHRpcGxlLWRyb3Bkb3duLWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBtdWx0aXBsZSBlbWFpbCBjb21wb25lbnQuXG4gICAqL1xuICBNdWx0aXBsZUVtYWlsQ29tcG9uZW50ID0gJ211bHRpcGxlLWVtYWlsLWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBtdWx0aXBsZSBmaWxlIGNvbXBvbmVudC5cbiAgICovXG4gIE11bHRpcGxlRmlsZUNvbXBvbmVudCA9ICdtdWx0aXBsZS1maWxlLWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBtdWx0aXBsZSB0ZXh0IGNvbXBvbmVudC5cbiAgICovXG4gIE11bHRpcGxlVGV4dENvbXBvbmVudCA9ICdtdWx0aXBsZS10ZXh0LWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBudW1iZXIgY29tcG9uZW50LlxuICAgKi9cbiAgTnVtYmVyQ29tcG9uZW50ID0gJ251bWJlci1jb21wb25lbnQnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgb2sgYnV0dG9uLlxuICAgKi9cbiAgT2tCdXR0b24gPSAnb2stYnV0dG9uJyxcblxuICAvKipcbiAgICogVGhlIENTUyBjbGFzcyBmb3IgdGhlIHBsdWdpbiBzZXR0aW5ncyB0YWIuXG4gICAqL1xuICBQbHVnaW5TZXR0aW5nc1RhYiA9ICdwbHVnaW4tc2V0dGluZ3MtdGFiJyxcblxuICAvKipcbiAgICogVGhlIENTUyBjbGFzcyBmb3IgdGhlIHByb21wdCBtb2RhbC5cbiAgICovXG4gIFByb21wdE1vZGFsID0gJ3Byb21wdC1tb2RhbCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSBzZWxlY3QgaXRlbSBtb2RhbC5cbiAgICovXG4gIFNlbGVjdEl0ZW1Nb2RhbCA9ICdzZWxlY3QtaXRlbS1tb2RhbCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSB0ZXh0IGJveC5cbiAgICovXG4gIFRleHRCb3ggPSAndGV4dC1ib3gnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgdGltZSBjb21wb25lbnQuXG4gICAqL1xuICBUaW1lQ29tcG9uZW50ID0gJ3RpbWUtY29tcG9uZW50JyxcblxuICAvKipcbiAgICogVGhlIENTUyBjbGFzcyBmb3IgdGhlIHRyaS1zdGF0ZSBjaGVja2JveCBjb21wb25lbnQuXG4gICAqL1xuICBUcmlTdGF0ZUNoZWNrYm94Q29tcG9uZW50ID0gJ3RyaS1zdGF0ZS1jaGVja2JveC1jb21wb25lbnQnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgdHlwZWQgZHJvcGRvd24gY29tcG9uZW50LlxuICAgKi9cbiAgVHlwZWREcm9wZG93bkNvbXBvbmVudCA9ICd0eXBlZC1kcm9wZG93bi1jb21wb25lbnQnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgdHlwZWQgbXVsdGlwbGUgZHJvcGRvd24gY29tcG9uZW50LlxuICAgKi9cbiAgVHlwZWRNdWx0aXBsZURyb3Bkb3duQ29tcG9uZW50ID0gJ3R5cGVkLW11bHRpcGxlLWRyb3Bkb3duLWNvbXBvbmVudCcsXG5cbiAgLyoqXG4gICAqIFRoZSBDU1MgY2xhc3MgZm9yIHRoZSB1cmwgY29tcG9uZW50LlxuICAgKi9cbiAgVXJsQ29tcG9uZW50ID0gJ3VybC1jb21wb25lbnQnLFxuXG4gIC8qKlxuICAgKiBUaGUgQ1NTIGNsYXNzIGZvciB0aGUgd2VlayBjb21wb25lbnQuXG4gICAqL1xuICBXZWVrQ29tcG9uZW50ID0gJ3dlZWstY29tcG9uZW50J1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7OztBQVFPLElBQUssV0FBTCxrQkFBS0EsY0FBTDtBQUlMLEVBQUFBLFVBQUEsZ0JBQWE7QUFLYixFQUFBQSxVQUFBLGtCQUFlO0FBS2YsRUFBQUEsVUFBQSx1QkFBb0I7QUFLcEIsRUFBQUEsVUFBQSxrQkFBZTtBQUtmLEVBQUFBLFVBQUEsbUJBQWdCO0FBS2hCLEVBQUFBLFVBQUEsdUJBQW9CO0FBS3BCLEVBQUFBLFVBQUEsb0JBQWlCO0FBS2pCLEVBQUFBLFVBQUEsbUJBQWdCO0FBS2hCLEVBQUFBLFVBQUEsaUJBQWM7QUFLZCxFQUFBQSxVQUFBLG9CQUFpQjtBQUtqQixFQUFBQSxVQUFBLCtCQUE0QjtBQUs1QixFQUFBQSxVQUFBLDRCQUF5QjtBQUt6QixFQUFBQSxVQUFBLDJCQUF3QjtBQUt4QixFQUFBQSxVQUFBLDJCQUF3QjtBQUt4QixFQUFBQSxVQUFBLHFCQUFrQjtBQUtsQixFQUFBQSxVQUFBLGNBQVc7QUFLWCxFQUFBQSxVQUFBLHVCQUFvQjtBQUtwQixFQUFBQSxVQUFBLGlCQUFjO0FBS2QsRUFBQUEsVUFBQSxxQkFBa0I7QUFLbEIsRUFBQUEsVUFBQSxhQUFVO0FBS1YsRUFBQUEsVUFBQSxtQkFBZ0I7QUFLaEIsRUFBQUEsVUFBQSwrQkFBNEI7QUFLNUIsRUFBQUEsVUFBQSw0QkFBeUI7QUFLekIsRUFBQUEsVUFBQSxvQ0FBaUM7QUFLakMsRUFBQUEsVUFBQSxrQkFBZTtBQUtmLEVBQUFBLFVBQUEsbUJBQWdCO0FBaklOLFNBQUFBO0FBQUEsR0FBQTsiLAogICJuYW1lcyI6IFsiQ3NzQ2xhc3MiXQp9Cg==
|
package/dist/lib/esm/Library.mjs
CHANGED
@@ -5,7 +5,7 @@ if you want to view the source, please visit the github repository of this plugi
|
|
5
5
|
|
6
6
|
(function initEsm(){if(globalThis.process){return}const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};globalThis.process=browserProcess})();
|
7
7
|
|
8
|
-
const LIBRARY_VERSION = "22.1.1-beta.
|
8
|
+
const LIBRARY_VERSION = "22.1.1-beta.24";
|
9
9
|
const LIBRARY_NAME = "obsidian-dev-utils";
|
10
10
|
const LIBRARY_STYLES = ".obsidian-dev-utils input[type=url] {\n height: var(--input-height);\n}\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=url],\n.obsidian-dev-utils input[type=week] {\n -webkit-app-region: no-drag;\n background: var(--background-modifier-form-field);\n border: var(--input-border-width) solid var(--background-modifier-border);\n color: var(--text-normal);\n font-family: inherit;\n padding: var(--size-4-1) var(--size-4-2);\n font-size: var(--font-ui-small);\n border-radius: var(--input-radius);\n outline: none;\n}\n@media (hover: hover) {\n .obsidian-dev-utils input[type=month]:hover,\n .obsidian-dev-utils input[type=time]:hover,\n .obsidian-dev-utils input[type=url]:hover,\n .obsidian-dev-utils input[type=week]:hover {\n border-color: var(--background-modifier-border-hover);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n }\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus {\n border-color: var(--background-modifier-border-focus);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus, .obsidian-dev-utils input[type=month]:focus-visible,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=time]:focus-visible,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=url]:focus-visible,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus,\n.obsidian-dev-utils input[type=week]:focus-visible {\n box-shadow: 0 0 0 2px var(--background-modifier-border-focus);\n}\n.obsidian-dev-utils input[type=month]::placeholder,\n.obsidian-dev-utils input[type=time]::placeholder,\n.obsidian-dev-utils input[type=url]::placeholder,\n.obsidian-dev-utils input[type=week]::placeholder {\n color: var(--text-faint);\n}\n.mod-rtl input[type=month],\n.mod-rtl input[type=time],\n.mod-rtl input[type=week],\n.is-rtl input[type=month],\n.is-rtl input[type=time],\n.is-rtl input[type=week],\n.rtl input[type=month],\n.rtl input[type=time],\n.rtl input[type=week] {\n direction: rtl;\n}\n.mod-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.rtl input[type=month]::-webkit-calendar-picker-indicator,\n.rtl input[type=time]::-webkit-calendar-picker-indicator,\n.rtl input[type=week]::-webkit-calendar-picker-indicator {\n right: var(--size-4-1);\n left: auto;\n}\n\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=week] {\n font-variant-numeric: tabular-nums;\n position: relative;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-text {\n color: var(--text-faint);\n padding-inline-end: 0;\n}\n.obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n position: absolute;\n left: var(--size-4-1);\n right: auto;\n opacity: 0.5;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:focus {\n background-color: var(--text-selection);\n color: var(--text-normal);\n cursor: text;\n}\n.mod-rtl .obsidian-dev-utils input[type=month], .is-rtl .obsidian-dev-utils input[type=month], .rtl .obsidian-dev-utils input[type=month],\n.mod-rtl .obsidian-dev-utils input[type=time],\n.is-rtl .obsidian-dev-utils input[type=time],\n.rtl .obsidian-dev-utils input[type=time],\n.mod-rtl .obsidian-dev-utils input[type=week],\n.is-rtl .obsidian-dev-utils input[type=week],\n.rtl .obsidian-dev-utils input[type=week] {\n direction: rtl;\n}\n.mod-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .is-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n left: auto;\n right: var(--size-4-1);\n}\n\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=month],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=time],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=week] {\n padding-inline-start: var(--size-4-6);\n}\n\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator {\n margin-inline-start: 0;\n}\n\n.obsidian-dev-utils.modal-container .ok-button {\n margin-right: 10px;\n margin-top: 20px;\n}\n\n.obsidian-dev-utils .multiple-dropdown-component select,\n.obsidian-dev-utils .multiple-dropdown-component select:focus,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown {\n height: auto;\n}\n.obsidian-dev-utils .multiple-dropdown-component select option:checked,\n.obsidian-dev-utils .multiple-dropdown-component select:focus option:checked,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown option:checked {\n background-color: #1967d2;\n color: #fff;\n}\n\n.obsidian-dev-utils.prompt-modal .text-box {\n width: 100%;\n}\n\n.obsidian-dev-utils :invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf-8,%7B%22version%22:3,%22sourceRoot%22:%22%22,%22sources%22:%5B%22../src/styles/input.scss%22,%22../src/styles/input-time.scss%22,%22../src/styles/modal-container.scss%22,%22../src/styles/multiple-dropdown-component.scss%22,%22../src/styles/prompt-modal.scss%22,%22../src/styles/validation.scss%22%5D,%22names%22:%5B%5D,%22mappings%22:%22AACE;EACE;;AAGF;AAAA;AAAA;AAAA;EAIE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;AAAA;AAAA;AAAA;IACE;IACA,YACE;;;AAMR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA,YACE;;AAIJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAGF;AAAA;AAAA;AAAA;EACE;;AASE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AC5DV;AAAA;AAAA;EAGE;EACA;;AAEA;AAAA;AAAA;EACE;EACA;;AAGF;AAAA;AAAA;EACE;EACA;EACA;EACA;;AAMA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA;EACA;;AAIK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGP;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AAKF;AAAA;AAAA;EACE;;;AAMJ;EACE;;;AChDF;EACE;EACA;;;ACFF;AAAA;AAAA;EAGE;;AAEA;AAAA;AAAA;EACE;EACA;;;ACPJ;EACE;;;ACFJ;EACE%22,%22file%22:%22styles.css%22,%22sourcesContent%22:%5B%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='url'%5D%20%7B%5Cn%20%20%20%20height:%20var(--input-height)%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='url'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20-webkit-app-region:%20no-drag;%5Cn%20%20%20%20background:%20var(--background-modifier-form-field);%5Cn%20%20%20%20border:%20var(--input-border-width)%20solid%20var(--background-modifier-border);%5Cn%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20font-family:%20inherit;%5Cn%20%20%20%20padding:%20var(--size-4-1)%20var(--size-4-2);%5Cn%20%20%20%20font-size:%20var(--font-ui-small);%5Cn%20%20%20%20border-radius:%20var(--input-radius);%5Cn%20%20%20%20outline:%20none;%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20@media%20(hover:%20hover)%20%7B%5Cn%20%20%20%20%20%20%20%20&:hover%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20border-color:%20var(--background-modifier-border-hover);%5Cn%20%20%20%20%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20border-color:%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus,%5Cn%20%20%20%20&:focus-visible%20%7B%5Cn%20%20%20%20%20%20box-shadow:%200%200%200%202px%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::placeholder%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20@at-root%20%7B%5Cn%20%20%20%20.mod-rtl,%5Cn%20%20%20%20.is-rtl,%5Cn%20%20%20%20.rtl%20%7B%5Cn%20%20%20%20%20%20&%20%7B%5Cn%20%20%20%20%20%20%20%20input%5Btype='month'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='time'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20font-variant-numeric:%20tabular-nums;%5Cn%20%20%20%20position:%20relative;%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-text%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%20%20padding-inline-end:%200;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20position:%20absolute;%5Cn%20%20%20%20%20%20left:%20var(--size-4-1);%5Cn%20%20%20%20%20%20right:%20auto;%5Cn%20%20%20%20%20%20opacity:%200.5;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-month-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-day-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-year-field%20%7B%5Cn%20%20%20%20%20%20&:active,%5Cn%20%20%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20var(--text-selection);%5Cn%20%20%20%20%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20%20%20%20%20cursor:%20text;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20.mod-rtl%20&,%5Cn%20%20%20%20%20%20.is-rtl%20&,%5Cn%20%20%20%20%20%20.rtl%20&%20%7B%5Cn%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20body:not(.is-ios):not(.is-android)%20&%20%7B%5Cn%20%20%20%20%20%20%20%20padding-inline-start:%20var(--size-4-6);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='time'%5D%20%7B%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20margin-inline-start:%200;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.modal-container%20%7B%5Cn%20%20%20%20.ok-button%20%7B%5Cn%20%20%20%20%20%20margin-right:%2010px;%5Cn%20%20%20%20%20%20margin-top:%2020px;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20.multiple-dropdown-component%20%7B%5Cn%20%20%20%20select,%5Cn%20%20%20%20select:focus,%5Cn%20%20%20%20.dropdown%20%7B%5Cn%20%20%20%20%20%20height:%20auto;%5Cn%5Cn%20%20%20%20%20%20option:checked%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20%231967d2;%5Cn%20%20%20%20%20%20%20%20color:%20%23fff;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.prompt-modal%20%7B%5Cn%20%20%20%20.text-box%20%7B%5Cn%20%20%20%20%20%20width:%20100%25;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20:invalid%20%7B%5Cn%20%20%20%20box-shadow:%200%200%200%202px%20var(--text-error);%5Cn%20%20%7D%5Cn%7D%5Cn%22%5D%7D */\n";
|
11
11
|
export {
|