obsidian-dev-utils 24.2.1-beta.3 → 24.2.1-beta.5
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 +19 -0
- package/README.md +3 -3
- package/dist/lib/cjs/AsyncEvents.cjs +8 -1
- package/dist/lib/cjs/AsyncEvents.d.cts +10 -8
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/obsidian/Components/AsyncEventsComponent.cjs +53 -0
- package/dist/lib/cjs/obsidian/Components/AsyncEventsComponent.d.cts +25 -0
- package/dist/lib/cjs/obsidian/Components/SettingComponents/CheckboxComponent.cjs +109 -0
- package/dist/lib/cjs/obsidian/Components/{CheckboxComponent.d.cts → SettingComponents/CheckboxComponent.d.cts} +1 -1
- package/dist/lib/cjs/obsidian/Components/{DateComponent.cjs → SettingComponents/DateComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/{DateTimeComponent.cjs → SettingComponents/DateTimeComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/{EmailComponent.cjs → SettingComponents/EmailComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/{FileComponent.cjs → SettingComponents/FileComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/{MonthComponent.cjs → SettingComponents/MonthComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleDropdownComponent.cjs +122 -0
- package/dist/lib/cjs/obsidian/Components/{MultipleDropdownComponent.d.cts → SettingComponents/MultipleDropdownComponent.d.cts} +5 -5
- package/dist/lib/cjs/obsidian/Components/{MultipleEmailComponent.cjs → SettingComponents/MultipleEmailComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/{MultipleEmailComponent.d.cts → SettingComponents/MultipleEmailComponent.d.cts} +3 -3
- package/dist/lib/cjs/obsidian/Components/{MultipleFileComponent.cjs → SettingComponents/MultipleFileComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/{MultipleFileComponent.d.cts → SettingComponents/MultipleFileComponent.d.cts} +4 -4
- package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleTextComponent.cjs +135 -0
- package/dist/lib/cjs/obsidian/Components/{MultipleTextComponent.d.cts → SettingComponents/MultipleTextComponent.d.cts} +6 -6
- package/dist/lib/cjs/obsidian/Components/{NumberComponent.cjs → SettingComponents/NumberComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/SettingComponents/TextBasedComponent.cjs +65 -0
- package/dist/lib/cjs/obsidian/Components/SettingComponents/TimeComponent.cjs +74 -0
- package/dist/lib/cjs/obsidian/Components/SettingComponents/TriStateCheckboxComponent.cjs +110 -0
- package/dist/lib/cjs/obsidian/Components/{TriStateCheckboxComponent.d.cts → SettingComponents/TriStateCheckboxComponent.d.cts} +1 -1
- package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedDropdownComponent.cjs +128 -0
- package/dist/lib/cjs/obsidian/Components/{TypedDropdownComponent.d.cts → SettingComponents/TypedDropdownComponent.d.cts} +1 -1
- package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.cjs +130 -0
- package/dist/lib/cjs/obsidian/Components/{TypedMultipleDropdownComponent.d.cts → SettingComponents/TypedMultipleDropdownComponent.d.cts} +5 -5
- package/dist/lib/cjs/obsidian/Components/{TypedRangeTextComponent.cjs → SettingComponents/TypedRangeTextComponent.cjs} +1 -1
- package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedTextComponent.cjs +155 -0
- package/dist/lib/cjs/obsidian/Components/{TypedTextComponent.d.cts → SettingComponents/TypedTextComponent.d.cts} +2 -2
- package/dist/lib/cjs/obsidian/Components/{UrlComponent.cjs → SettingComponents/UrlComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/{ValidatorComponent.cjs → SettingComponents/ValidatorComponent.cjs} +1 -1
- package/dist/lib/cjs/obsidian/Components/{ValidatorComponent.d.cts → SettingComponents/ValidatorComponent.d.cts} +1 -1
- package/dist/lib/cjs/obsidian/Components/{ValueComponentWithChangeTracking.cjs → SettingComponents/ValueComponentWithChangeTracking.cjs} +1 -1
- package/dist/lib/cjs/obsidian/Components/{WeekComponent.cjs → SettingComponents/WeekComponent.cjs} +2 -2
- package/dist/lib/cjs/obsidian/Components/SettingComponents/index.cjs +109 -0
- package/dist/lib/cjs/obsidian/Components/SettingComponents/index.d.cts +22 -0
- package/dist/lib/cjs/obsidian/Components/index.cjs +7 -67
- package/dist/lib/cjs/obsidian/Components/index.d.cts +2 -22
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +25 -31
- package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +15 -23
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +18 -5
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +21 -1
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +61 -12
- package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.d.cts +18 -5
- package/dist/lib/cjs/obsidian/SettingEx.cjs +18 -18
- package/dist/lib/cjs/obsidian/SettingEx.d.cts +17 -17
- package/dist/lib/esm/AsyncEvents.d.mts +10 -8
- package/dist/lib/esm/AsyncEvents.mjs +8 -1
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/obsidian/Components/AsyncEventsComponent.d.mts +25 -0
- package/dist/lib/esm/obsidian/Components/AsyncEventsComponent.mjs +28 -0
- package/dist/lib/esm/obsidian/Components/{CheckboxComponent.d.mts → SettingComponents/CheckboxComponent.d.mts} +1 -1
- package/dist/lib/esm/obsidian/Components/SettingComponents/CheckboxComponent.mjs +85 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/DateComponent.mjs +43 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/DateTimeComponent.mjs +43 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/EmailComponent.mjs +32 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/FileComponent.mjs +48 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/MonthComponent.mjs +51 -0
- package/dist/lib/esm/obsidian/Components/{MultipleDropdownComponent.d.mts → SettingComponents/MultipleDropdownComponent.d.mts} +5 -5
- package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleDropdownComponent.mjs +101 -0
- package/dist/lib/esm/obsidian/Components/{MultipleEmailComponent.d.mts → SettingComponents/MultipleEmailComponent.d.mts} +3 -3
- package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleEmailComponent.mjs +42 -0
- package/dist/lib/esm/obsidian/Components/{MultipleFileComponent.d.mts → SettingComponents/MultipleFileComponent.d.mts} +4 -4
- package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleFileComponent.mjs +49 -0
- package/dist/lib/esm/obsidian/Components/{MultipleTextComponent.d.mts → SettingComponents/MultipleTextComponent.d.mts} +6 -6
- package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleTextComponent.mjs +114 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/NumberComponent.mjs +32 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/TextBasedComponent.mjs +41 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/TimeComponent.mjs +53 -0
- package/dist/lib/esm/obsidian/Components/{TriStateCheckboxComponent.d.mts → SettingComponents/TriStateCheckboxComponent.d.mts} +1 -1
- package/dist/lib/esm/obsidian/Components/SettingComponents/TriStateCheckboxComponent.mjs +86 -0
- package/dist/lib/esm/obsidian/Components/{TypedDropdownComponent.d.mts → SettingComponents/TypedDropdownComponent.d.mts} +1 -1
- package/dist/lib/esm/obsidian/Components/SettingComponents/TypedDropdownComponent.mjs +107 -0
- package/dist/lib/esm/obsidian/Components/{TypedMultipleDropdownComponent.d.mts → SettingComponents/TypedMultipleDropdownComponent.d.mts} +5 -5
- package/dist/lib/esm/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.mjs +106 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/TypedRangeTextComponent.mjs +44 -0
- package/dist/lib/esm/obsidian/Components/{TypedTextComponent.d.mts → SettingComponents/TypedTextComponent.d.mts} +2 -2
- package/dist/lib/esm/obsidian/Components/SettingComponents/TypedTextComponent.mjs +134 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/UrlComponent.mjs +32 -0
- package/dist/lib/esm/obsidian/Components/{ValidatorComponent.d.mts → SettingComponents/ValidatorComponent.d.mts} +1 -1
- package/dist/lib/esm/obsidian/Components/SettingComponents/ValidatorComponent.mjs +47 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/WeekComponent.mjs +51 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/index.d.mts +22 -0
- package/dist/lib/esm/obsidian/Components/SettingComponents/index.mjs +54 -0
- package/dist/lib/esm/obsidian/Components/index.d.mts +2 -22
- package/dist/lib/esm/obsidian/Components/index.mjs +5 -45
- package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +15 -23
- package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +25 -31
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +21 -1
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +18 -5
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.d.mts +18 -5
- package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +65 -13
- package/dist/lib/esm/obsidian/SettingEx.d.mts +17 -17
- package/dist/lib/esm/obsidian/SettingEx.mjs +18 -18
- package/obsidian/Components/AsyncEventsComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/CheckboxComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/DateComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/DateTimeComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/EmailComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/FileComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/MonthComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/MultipleDropdownComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/MultipleEmailComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/MultipleFileComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/MultipleTextComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/NumberComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/TextBasedComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/TimeComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/TriStateCheckboxComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/TypedDropdownComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/TypedRangeTextComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/TypedTextComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/UrlComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/ValidatorComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/ValueComponentWithChangeTracking/package.json +6 -0
- package/obsidian/Components/SettingComponents/WeekComponent/package.json +6 -0
- package/obsidian/Components/SettingComponents/index/package.json +6 -0
- package/obsidian/Components/SettingComponents/package.json +6 -0
- package/package.json +21 -1
- package/dist/lib/cjs/obsidian/Components/CheckboxComponent.cjs +0 -109
- package/dist/lib/cjs/obsidian/Components/MultipleDropdownComponent.cjs +0 -122
- package/dist/lib/cjs/obsidian/Components/MultipleTextComponent.cjs +0 -135
- package/dist/lib/cjs/obsidian/Components/TextBasedComponent.cjs +0 -65
- package/dist/lib/cjs/obsidian/Components/TimeComponent.cjs +0 -74
- package/dist/lib/cjs/obsidian/Components/TriStateCheckboxComponent.cjs +0 -110
- package/dist/lib/cjs/obsidian/Components/TypedDropdownComponent.cjs +0 -128
- package/dist/lib/cjs/obsidian/Components/TypedMultipleDropdownComponent.cjs +0 -130
- package/dist/lib/cjs/obsidian/Components/TypedTextComponent.cjs +0 -155
- package/dist/lib/esm/obsidian/Components/CheckboxComponent.mjs +0 -85
- package/dist/lib/esm/obsidian/Components/DateComponent.mjs +0 -43
- package/dist/lib/esm/obsidian/Components/DateTimeComponent.mjs +0 -43
- package/dist/lib/esm/obsidian/Components/EmailComponent.mjs +0 -32
- package/dist/lib/esm/obsidian/Components/FileComponent.mjs +0 -48
- package/dist/lib/esm/obsidian/Components/MonthComponent.mjs +0 -51
- package/dist/lib/esm/obsidian/Components/MultipleDropdownComponent.mjs +0 -101
- package/dist/lib/esm/obsidian/Components/MultipleEmailComponent.mjs +0 -42
- package/dist/lib/esm/obsidian/Components/MultipleFileComponent.mjs +0 -49
- package/dist/lib/esm/obsidian/Components/MultipleTextComponent.mjs +0 -114
- package/dist/lib/esm/obsidian/Components/NumberComponent.mjs +0 -32
- package/dist/lib/esm/obsidian/Components/TextBasedComponent.mjs +0 -41
- package/dist/lib/esm/obsidian/Components/TimeComponent.mjs +0 -53
- package/dist/lib/esm/obsidian/Components/TriStateCheckboxComponent.mjs +0 -86
- package/dist/lib/esm/obsidian/Components/TypedDropdownComponent.mjs +0 -107
- package/dist/lib/esm/obsidian/Components/TypedMultipleDropdownComponent.mjs +0 -106
- package/dist/lib/esm/obsidian/Components/TypedRangeTextComponent.mjs +0 -44
- package/dist/lib/esm/obsidian/Components/TypedTextComponent.mjs +0 -134
- package/dist/lib/esm/obsidian/Components/UrlComponent.mjs +0 -32
- package/dist/lib/esm/obsidian/Components/ValidatorComponent.mjs +0 -47
- package/dist/lib/esm/obsidian/Components/WeekComponent.mjs +0 -51
- package/obsidian/Components/CheckboxComponent/package.json +0 -6
- package/obsidian/Components/DateComponent/package.json +0 -6
- package/obsidian/Components/DateTimeComponent/package.json +0 -6
- package/obsidian/Components/EmailComponent/package.json +0 -6
- package/obsidian/Components/FileComponent/package.json +0 -6
- package/obsidian/Components/MonthComponent/package.json +0 -6
- package/obsidian/Components/MultipleDropdownComponent/package.json +0 -6
- package/obsidian/Components/MultipleEmailComponent/package.json +0 -6
- package/obsidian/Components/MultipleFileComponent/package.json +0 -6
- package/obsidian/Components/MultipleTextComponent/package.json +0 -6
- package/obsidian/Components/NumberComponent/package.json +0 -6
- package/obsidian/Components/TextBasedComponent/package.json +0 -6
- package/obsidian/Components/TimeComponent/package.json +0 -6
- package/obsidian/Components/TriStateCheckboxComponent/package.json +0 -6
- package/obsidian/Components/TypedDropdownComponent/package.json +0 -6
- package/obsidian/Components/TypedMultipleDropdownComponent/package.json +0 -6
- package/obsidian/Components/TypedRangeTextComponent/package.json +0 -6
- package/obsidian/Components/TypedTextComponent/package.json +0 -6
- package/obsidian/Components/UrlComponent/package.json +0 -6
- package/obsidian/Components/ValidatorComponent/package.json +0 -6
- package/obsidian/Components/ValueComponentWithChangeTracking/package.json +0 -6
- package/obsidian/Components/WeekComponent/package.json +0 -6
- /package/dist/lib/cjs/obsidian/Components/{DateComponent.d.cts → SettingComponents/DateComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{DateTimeComponent.d.cts → SettingComponents/DateTimeComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{EmailComponent.d.cts → SettingComponents/EmailComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{FileComponent.d.cts → SettingComponents/FileComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{MonthComponent.d.cts → SettingComponents/MonthComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{NumberComponent.d.cts → SettingComponents/NumberComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{TextBasedComponent.d.cts → SettingComponents/TextBasedComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{TimeComponent.d.cts → SettingComponents/TimeComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{TypedRangeTextComponent.d.cts → SettingComponents/TypedRangeTextComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{UrlComponent.d.cts → SettingComponents/UrlComponent.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{ValueComponentWithChangeTracking.d.cts → SettingComponents/ValueComponentWithChangeTracking.d.cts} +0 -0
- /package/dist/lib/cjs/obsidian/Components/{WeekComponent.d.cts → SettingComponents/WeekComponent.d.cts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{DateComponent.d.mts → SettingComponents/DateComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{DateTimeComponent.d.mts → SettingComponents/DateTimeComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{EmailComponent.d.mts → SettingComponents/EmailComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{FileComponent.d.mts → SettingComponents/FileComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{MonthComponent.d.mts → SettingComponents/MonthComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{NumberComponent.d.mts → SettingComponents/NumberComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{TextBasedComponent.d.mts → SettingComponents/TextBasedComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{TimeComponent.d.mts → SettingComponents/TimeComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{TypedRangeTextComponent.d.mts → SettingComponents/TypedRangeTextComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{UrlComponent.d.mts → SettingComponents/UrlComponent.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{ValueComponentWithChangeTracking.d.mts → SettingComponents/ValueComponentWithChangeTracking.d.mts} +0 -0
- /package/dist/lib/esm/obsidian/Components/{ValueComponentWithChangeTracking.mjs → SettingComponents/ValueComponentWithChangeTracking.mjs} +0 -0
- /package/dist/lib/esm/obsidian/Components/{WeekComponent.d.mts → SettingComponents/WeekComponent.d.mts} +0 -0
@@ -0,0 +1,22 @@
|
|
1
|
+
export * as CheckboxComponent from './CheckboxComponent.mjs';
|
2
|
+
export * as DateComponent from './DateComponent.mjs';
|
3
|
+
export * as DateTimeComponent from './DateTimeComponent.mjs';
|
4
|
+
export * as EmailComponent from './EmailComponent.mjs';
|
5
|
+
export * as FileComponent from './FileComponent.mjs';
|
6
|
+
export * as MonthComponent from './MonthComponent.mjs';
|
7
|
+
export * as MultipleDropdownComponent from './MultipleDropdownComponent.mjs';
|
8
|
+
export * as MultipleEmailComponent from './MultipleEmailComponent.mjs';
|
9
|
+
export * as MultipleFileComponent from './MultipleFileComponent.mjs';
|
10
|
+
export * as MultipleTextComponent from './MultipleTextComponent.mjs';
|
11
|
+
export * as NumberComponent from './NumberComponent.mjs';
|
12
|
+
export * as TextBasedComponent from './TextBasedComponent.mjs';
|
13
|
+
export * as TimeComponent from './TimeComponent.mjs';
|
14
|
+
export * as TriStateCheckboxComponent from './TriStateCheckboxComponent.mjs';
|
15
|
+
export * as TypedDropdownComponent from './TypedDropdownComponent.mjs';
|
16
|
+
export * as TypedMultipleDropdownComponent from './TypedMultipleDropdownComponent.mjs';
|
17
|
+
export * as TypedRangeTextComponent from './TypedRangeTextComponent.mjs';
|
18
|
+
export * as TypedTextComponent from './TypedTextComponent.mjs';
|
19
|
+
export * as UrlComponent from './UrlComponent.mjs';
|
20
|
+
export * as ValidatorComponent from './ValidatorComponent.mjs';
|
21
|
+
export * as ValueComponentWithChangeTracking from './ValueComponentWithChangeTracking.mjs';
|
22
|
+
export * as WeekComponent from './WeekComponent.mjs';
|
@@ -0,0 +1,54 @@
|
|
1
|
+
/*
|
2
|
+
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
|
3
|
+
if you want to view the source, please visit the github repository of this plugin
|
4
|
+
*/
|
5
|
+
|
6
|
+
(function initEsm(){if(globalThis.process){return}const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};globalThis.process=browserProcess})();
|
7
|
+
|
8
|
+
import * as CheckboxComponent from "./CheckboxComponent.mjs";
|
9
|
+
import * as DateComponent from "./DateComponent.mjs";
|
10
|
+
import * as DateTimeComponent from "./DateTimeComponent.mjs";
|
11
|
+
import * as EmailComponent from "./EmailComponent.mjs";
|
12
|
+
import * as FileComponent from "./FileComponent.mjs";
|
13
|
+
import * as MonthComponent from "./MonthComponent.mjs";
|
14
|
+
import * as MultipleDropdownComponent from "./MultipleDropdownComponent.mjs";
|
15
|
+
import * as MultipleEmailComponent from "./MultipleEmailComponent.mjs";
|
16
|
+
import * as MultipleFileComponent from "./MultipleFileComponent.mjs";
|
17
|
+
import * as MultipleTextComponent from "./MultipleTextComponent.mjs";
|
18
|
+
import * as NumberComponent from "./NumberComponent.mjs";
|
19
|
+
import * as TextBasedComponent from "./TextBasedComponent.mjs";
|
20
|
+
import * as TimeComponent from "./TimeComponent.mjs";
|
21
|
+
import * as TriStateCheckboxComponent from "./TriStateCheckboxComponent.mjs";
|
22
|
+
import * as TypedDropdownComponent from "./TypedDropdownComponent.mjs";
|
23
|
+
import * as TypedMultipleDropdownComponent from "./TypedMultipleDropdownComponent.mjs";
|
24
|
+
import * as TypedRangeTextComponent from "./TypedRangeTextComponent.mjs";
|
25
|
+
import * as TypedTextComponent from "./TypedTextComponent.mjs";
|
26
|
+
import * as UrlComponent from "./UrlComponent.mjs";
|
27
|
+
import * as ValidatorComponent from "./ValidatorComponent.mjs";
|
28
|
+
import * as ValueComponentWithChangeTracking from "./ValueComponentWithChangeTracking.mjs";
|
29
|
+
import * as WeekComponent from "./WeekComponent.mjs";
|
30
|
+
export {
|
31
|
+
CheckboxComponent,
|
32
|
+
DateComponent,
|
33
|
+
DateTimeComponent,
|
34
|
+
EmailComponent,
|
35
|
+
FileComponent,
|
36
|
+
MonthComponent,
|
37
|
+
MultipleDropdownComponent,
|
38
|
+
MultipleEmailComponent,
|
39
|
+
MultipleFileComponent,
|
40
|
+
MultipleTextComponent,
|
41
|
+
NumberComponent,
|
42
|
+
TextBasedComponent,
|
43
|
+
TimeComponent,
|
44
|
+
TriStateCheckboxComponent,
|
45
|
+
TypedDropdownComponent,
|
46
|
+
TypedMultipleDropdownComponent,
|
47
|
+
TypedRangeTextComponent,
|
48
|
+
TypedTextComponent,
|
49
|
+
UrlComponent,
|
50
|
+
ValidatorComponent,
|
51
|
+
ValueComponentWithChangeTracking,
|
52
|
+
WeekComponent
|
53
|
+
};
|
54
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL0NvbXBvbmVudHMvU2V0dGluZ0NvbXBvbmVudHMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qIFRISVMgSVMgQSBHRU5FUkFURUQvQlVORExFRCBGSUxFIEJZIEJVSUxEIFNDUklQVCAqL1xuXG5leHBvcnQgKiBhcyBDaGVja2JveENvbXBvbmVudCBmcm9tICcuL0NoZWNrYm94Q29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIERhdGVDb21wb25lbnQgZnJvbSAnLi9EYXRlQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIERhdGVUaW1lQ29tcG9uZW50IGZyb20gJy4vRGF0ZVRpbWVDb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgRW1haWxDb21wb25lbnQgZnJvbSAnLi9FbWFpbENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBGaWxlQ29tcG9uZW50IGZyb20gJy4vRmlsZUNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBNb250aENvbXBvbmVudCBmcm9tICcuL01vbnRoQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIE11bHRpcGxlRHJvcGRvd25Db21wb25lbnQgZnJvbSAnLi9NdWx0aXBsZURyb3Bkb3duQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIE11bHRpcGxlRW1haWxDb21wb25lbnQgZnJvbSAnLi9NdWx0aXBsZUVtYWlsQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIE11bHRpcGxlRmlsZUNvbXBvbmVudCBmcm9tICcuL011bHRpcGxlRmlsZUNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBNdWx0aXBsZVRleHRDb21wb25lbnQgZnJvbSAnLi9NdWx0aXBsZVRleHRDb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgTnVtYmVyQ29tcG9uZW50IGZyb20gJy4vTnVtYmVyQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIFRleHRCYXNlZENvbXBvbmVudCBmcm9tICcuL1RleHRCYXNlZENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUaW1lQ29tcG9uZW50IGZyb20gJy4vVGltZUNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUcmlTdGF0ZUNoZWNrYm94Q29tcG9uZW50IGZyb20gJy4vVHJpU3RhdGVDaGVja2JveENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUeXBlZERyb3Bkb3duQ29tcG9uZW50IGZyb20gJy4vVHlwZWREcm9wZG93bkNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUeXBlZE11bHRpcGxlRHJvcGRvd25Db21wb25lbnQgZnJvbSAnLi9UeXBlZE11bHRpcGxlRHJvcGRvd25Db21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgVHlwZWRSYW5nZVRleHRDb21wb25lbnQgZnJvbSAnLi9UeXBlZFJhbmdlVGV4dENvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBUeXBlZFRleHRDb21wb25lbnQgZnJvbSAnLi9UeXBlZFRleHRDb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgVXJsQ29tcG9uZW50IGZyb20gJy4vVXJsQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIFZhbGlkYXRvckNvbXBvbmVudCBmcm9tICcuL1ZhbGlkYXRvckNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBWYWx1ZUNvbXBvbmVudFdpdGhDaGFuZ2VUcmFja2luZyBmcm9tICcuL1ZhbHVlQ29tcG9uZW50V2l0aENoYW5nZVRyYWNraW5nLnRzJztcbmV4cG9ydCAqIGFzIFdlZWtDb21wb25lbnQgZnJvbSAnLi9XZWVrQ29tcG9uZW50LnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7QUFFQSxZQUFZLHVCQUF1QjtBQUNuQyxZQUFZLG1CQUFtQjtBQUMvQixZQUFZLHVCQUF1QjtBQUNuQyxZQUFZLG9CQUFvQjtBQUNoQyxZQUFZLG1CQUFtQjtBQUMvQixZQUFZLG9CQUFvQjtBQUNoQyxZQUFZLCtCQUErQjtBQUMzQyxZQUFZLDRCQUE0QjtBQUN4QyxZQUFZLDJCQUEyQjtBQUN2QyxZQUFZLDJCQUEyQjtBQUN2QyxZQUFZLHFCQUFxQjtBQUNqQyxZQUFZLHdCQUF3QjtBQUNwQyxZQUFZLG1CQUFtQjtBQUMvQixZQUFZLCtCQUErQjtBQUMzQyxZQUFZLDRCQUE0QjtBQUN4QyxZQUFZLG9DQUFvQztBQUNoRCxZQUFZLDZCQUE2QjtBQUN6QyxZQUFZLHdCQUF3QjtBQUNwQyxZQUFZLGtCQUFrQjtBQUM5QixZQUFZLHdCQUF3QjtBQUNwQyxZQUFZLHNDQUFzQztBQUNsRCxZQUFZLG1CQUFtQjsiLAogICJuYW1lcyI6IFtdCn0K
|
@@ -1,22 +1,2 @@
|
|
1
|
-
export * as
|
2
|
-
export * as
|
3
|
-
export * as DateTimeComponent from './DateTimeComponent.mjs';
|
4
|
-
export * as EmailComponent from './EmailComponent.mjs';
|
5
|
-
export * as FileComponent from './FileComponent.mjs';
|
6
|
-
export * as MonthComponent from './MonthComponent.mjs';
|
7
|
-
export * as MultipleDropdownComponent from './MultipleDropdownComponent.mjs';
|
8
|
-
export * as MultipleEmailComponent from './MultipleEmailComponent.mjs';
|
9
|
-
export * as MultipleFileComponent from './MultipleFileComponent.mjs';
|
10
|
-
export * as MultipleTextComponent from './MultipleTextComponent.mjs';
|
11
|
-
export * as NumberComponent from './NumberComponent.mjs';
|
12
|
-
export * as TextBasedComponent from './TextBasedComponent.mjs';
|
13
|
-
export * as TimeComponent from './TimeComponent.mjs';
|
14
|
-
export * as TriStateCheckboxComponent from './TriStateCheckboxComponent.mjs';
|
15
|
-
export * as TypedDropdownComponent from './TypedDropdownComponent.mjs';
|
16
|
-
export * as TypedMultipleDropdownComponent from './TypedMultipleDropdownComponent.mjs';
|
17
|
-
export * as TypedRangeTextComponent from './TypedRangeTextComponent.mjs';
|
18
|
-
export * as TypedTextComponent from './TypedTextComponent.mjs';
|
19
|
-
export * as UrlComponent from './UrlComponent.mjs';
|
20
|
-
export * as ValidatorComponent from './ValidatorComponent.mjs';
|
21
|
-
export * as ValueComponentWithChangeTracking from './ValueComponentWithChangeTracking.mjs';
|
22
|
-
export * as WeekComponent from './WeekComponent.mjs';
|
1
|
+
export * as AsyncEventsComponent from './AsyncEventsComponent.mjs';
|
2
|
+
export * as SettingComponents from './SettingComponents/index.mjs';
|
@@ -5,50 +5,10 @@ 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
|
-
import * as
|
9
|
-
import * as
|
10
|
-
import * as DateTimeComponent from "./DateTimeComponent.mjs";
|
11
|
-
import * as EmailComponent from "./EmailComponent.mjs";
|
12
|
-
import * as FileComponent from "./FileComponent.mjs";
|
13
|
-
import * as MonthComponent from "./MonthComponent.mjs";
|
14
|
-
import * as MultipleDropdownComponent from "./MultipleDropdownComponent.mjs";
|
15
|
-
import * as MultipleEmailComponent from "./MultipleEmailComponent.mjs";
|
16
|
-
import * as MultipleFileComponent from "./MultipleFileComponent.mjs";
|
17
|
-
import * as MultipleTextComponent from "./MultipleTextComponent.mjs";
|
18
|
-
import * as NumberComponent from "./NumberComponent.mjs";
|
19
|
-
import * as TextBasedComponent from "./TextBasedComponent.mjs";
|
20
|
-
import * as TimeComponent from "./TimeComponent.mjs";
|
21
|
-
import * as TriStateCheckboxComponent from "./TriStateCheckboxComponent.mjs";
|
22
|
-
import * as TypedDropdownComponent from "./TypedDropdownComponent.mjs";
|
23
|
-
import * as TypedMultipleDropdownComponent from "./TypedMultipleDropdownComponent.mjs";
|
24
|
-
import * as TypedRangeTextComponent from "./TypedRangeTextComponent.mjs";
|
25
|
-
import * as TypedTextComponent from "./TypedTextComponent.mjs";
|
26
|
-
import * as UrlComponent from "./UrlComponent.mjs";
|
27
|
-
import * as ValidatorComponent from "./ValidatorComponent.mjs";
|
28
|
-
import * as ValueComponentWithChangeTracking from "./ValueComponentWithChangeTracking.mjs";
|
29
|
-
import * as WeekComponent from "./WeekComponent.mjs";
|
8
|
+
import * as AsyncEventsComponent from "./AsyncEventsComponent.mjs";
|
9
|
+
import * as SettingComponents from "./SettingComponents/index.mjs";
|
30
10
|
export {
|
31
|
-
|
32
|
-
|
33
|
-
DateTimeComponent,
|
34
|
-
EmailComponent,
|
35
|
-
FileComponent,
|
36
|
-
MonthComponent,
|
37
|
-
MultipleDropdownComponent,
|
38
|
-
MultipleEmailComponent,
|
39
|
-
MultipleFileComponent,
|
40
|
-
MultipleTextComponent,
|
41
|
-
NumberComponent,
|
42
|
-
TextBasedComponent,
|
43
|
-
TimeComponent,
|
44
|
-
TriStateCheckboxComponent,
|
45
|
-
TypedDropdownComponent,
|
46
|
-
TypedMultipleDropdownComponent,
|
47
|
-
TypedRangeTextComponent,
|
48
|
-
TypedTextComponent,
|
49
|
-
UrlComponent,
|
50
|
-
ValidatorComponent,
|
51
|
-
ValueComponentWithChangeTracking,
|
52
|
-
WeekComponent
|
11
|
+
AsyncEventsComponent,
|
12
|
+
SettingComponents
|
53
13
|
};
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
14
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL0NvbXBvbmVudHMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qIFRISVMgSVMgQSBHRU5FUkFURUQvQlVORExFRCBGSUxFIEJZIEJVSUxEIFNDUklQVCAqL1xuXG5leHBvcnQgKiBhcyBBc3luY0V2ZW50c0NvbXBvbmVudCBmcm9tICcuL0FzeW5jRXZlbnRzQ29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIFNldHRpbmdDb21wb25lbnRzIGZyb20gJy4vU2V0dGluZ0NvbXBvbmVudHMvaW5kZXgudHMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7OztBQUVBLFlBQVksMEJBQTBCO0FBQ3RDLFlBQVksdUJBQXVCOyIsCiAgIm5hbWVzIjogW10KfQo=
|
@@ -9,7 +9,6 @@
|
|
9
9
|
*/
|
10
10
|
import type { ReadonlyDeep } from 'type-fest';
|
11
11
|
import { Plugin as ObsidianPlugin } from 'obsidian';
|
12
|
-
import type { AsyncEventRef } from '../../AsyncEvents.mjs';
|
13
12
|
import type { ExtractPluginSettings, ExtractPluginSettingsManager, ExtractPluginSettingsTab, ExtractReadonlyPluginSettingsWrapper, PluginTypesBase } from './PluginTypesBase.mjs';
|
14
13
|
import { AsyncEvents } from '../../AsyncEvents.mjs';
|
15
14
|
type LifecycleEventName = 'layoutReady' | 'load' | 'unload';
|
@@ -70,30 +69,8 @@ export declare abstract class PluginBase<PluginTypes extends PluginTypesBase> ex
|
|
70
69
|
* Called when the plugin is loaded
|
71
70
|
*/
|
72
71
|
onload(): Promise<void>;
|
73
|
-
/**
|
74
|
-
* Called when the plugin settings are loaded or reloaded.
|
75
|
-
*
|
76
|
-
* @param _loadedSettings - The loaded settings wrapper.
|
77
|
-
* @param _isInitialLoad - Whether the settings are being loaded for the first time.
|
78
|
-
*/
|
79
|
-
onLoadSettings(_loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _isInitialLoad: boolean): Promise<void>;
|
80
|
-
/**
|
81
|
-
* Called when the plugin settings are saved.
|
82
|
-
*
|
83
|
-
* @param _newSettings - The new settings.
|
84
|
-
* @param _oldSettings - The old settings.
|
85
|
-
* @param _context - The context.
|
86
|
-
*/
|
87
|
-
onSaveSettings(_newSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _oldSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _context: unknown): Promise<void>;
|
88
72
|
/** */
|
89
73
|
onunload(): void;
|
90
|
-
/**
|
91
|
-
* Registers an async event.
|
92
|
-
* Unregisters the event when the plugin is unloaded.
|
93
|
-
*
|
94
|
-
* @param eventRef - The event reference.
|
95
|
-
*/
|
96
|
-
registerAsyncEvent(eventRef: AsyncEventRef): void;
|
97
74
|
/**
|
98
75
|
* Waits for a lifecycle event to be triggered.
|
99
76
|
*
|
@@ -128,6 +105,21 @@ export declare abstract class PluginBase<PluginTypes extends PluginTypesBase> ex
|
|
128
105
|
* This method can be overridden by subclasses to perform actions once the plugin is loaded.
|
129
106
|
*/
|
130
107
|
protected onloadImpl(): Promise<void>;
|
108
|
+
/**
|
109
|
+
* Called when the plugin settings are loaded or reloaded.
|
110
|
+
*
|
111
|
+
* @param _loadedSettings - The loaded settings wrapper.
|
112
|
+
* @param _isInitialLoad - Whether the settings are being loaded for the first time.
|
113
|
+
*/
|
114
|
+
protected onLoadSettings(_loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _isInitialLoad: boolean): Promise<void>;
|
115
|
+
/**
|
116
|
+
* Called when the plugin settings are saved.
|
117
|
+
*
|
118
|
+
* @param _newSettings - The new settings.
|
119
|
+
* @param _oldSettings - The old settings.
|
120
|
+
* @param _context - The context.
|
121
|
+
*/
|
122
|
+
protected onSaveSettings(_newSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _oldSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _context: unknown): Promise<void>;
|
131
123
|
/**
|
132
124
|
* Called when the plugin is unloaded.
|
133
125
|
*/
|
@@ -18,6 +18,7 @@ import { AsyncEvents } from "../../AsyncEvents.mjs";
|
|
18
18
|
import { getDebugger } from "../../Debug.mjs";
|
19
19
|
import { registerAsyncErrorEventHandler } from "../../Error.mjs";
|
20
20
|
import { noopAsync } from "../../Function.mjs";
|
21
|
+
import { registerAsyncEvent } from "../Components/AsyncEventsComponent.mjs";
|
21
22
|
import { initPluginContext } from "./PluginContext.mjs";
|
22
23
|
class PluginBase extends ObsidianPlugin {
|
23
24
|
events = new AsyncEvents();
|
@@ -96,25 +97,6 @@ class PluginBase extends ObsidianPlugin {
|
|
96
97
|
await this.onloadImpl();
|
97
98
|
invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));
|
98
99
|
}
|
99
|
-
/**
|
100
|
-
* Called when the plugin settings are loaded or reloaded.
|
101
|
-
*
|
102
|
-
* @param _loadedSettings - The loaded settings wrapper.
|
103
|
-
* @param _isInitialLoad - Whether the settings are being loaded for the first time.
|
104
|
-
*/
|
105
|
-
async onLoadSettings(_loadedSettings, _isInitialLoad) {
|
106
|
-
await noopAsync();
|
107
|
-
}
|
108
|
-
/**
|
109
|
-
* Called when the plugin settings are saved.
|
110
|
-
*
|
111
|
-
* @param _newSettings - The new settings.
|
112
|
-
* @param _oldSettings - The old settings.
|
113
|
-
* @param _context - The context.
|
114
|
-
*/
|
115
|
-
async onSaveSettings(_newSettings, _oldSettings, _context) {
|
116
|
-
await noopAsync();
|
117
|
-
}
|
118
100
|
/** */
|
119
101
|
onunload() {
|
120
102
|
super.onunload();
|
@@ -126,17 +108,6 @@ class PluginBase extends ObsidianPlugin {
|
|
126
108
|
}
|
127
109
|
});
|
128
110
|
}
|
129
|
-
/**
|
130
|
-
* Registers an async event.
|
131
|
-
* Unregisters the event when the plugin is unloaded.
|
132
|
-
*
|
133
|
-
* @param eventRef - The event reference.
|
134
|
-
*/
|
135
|
-
registerAsyncEvent(eventRef) {
|
136
|
-
this.register(() => {
|
137
|
-
eventRef.asyncEvents.offref(eventRef);
|
138
|
-
});
|
139
|
-
}
|
140
111
|
/**
|
141
112
|
* Waits for a lifecycle event to be triggered.
|
142
113
|
*
|
@@ -191,6 +162,10 @@ class PluginBase extends ObsidianPlugin {
|
|
191
162
|
this.showNotice("An unhandled error occurred. Please check the console for more information.");
|
192
163
|
}));
|
193
164
|
this._settingsManager = this.createSettingsManager();
|
165
|
+
if (this._settingsManager) {
|
166
|
+
registerAsyncEvent(this, this._settingsManager.on("loadSettings", this.onLoadSettings.bind(this)));
|
167
|
+
registerAsyncEvent(this, this._settingsManager.on("saveSettings", this.onSaveSettings.bind(this)));
|
168
|
+
}
|
194
169
|
await this._settingsManager?.loadFromFile(true);
|
195
170
|
this._settingsTab = this.createPluginSettingsTab();
|
196
171
|
if (this._settingsTab) {
|
@@ -202,6 +177,25 @@ class PluginBase extends ObsidianPlugin {
|
|
202
177
|
abortController.abort();
|
203
178
|
});
|
204
179
|
}
|
180
|
+
/**
|
181
|
+
* Called when the plugin settings are loaded or reloaded.
|
182
|
+
*
|
183
|
+
* @param _loadedSettings - The loaded settings wrapper.
|
184
|
+
* @param _isInitialLoad - Whether the settings are being loaded for the first time.
|
185
|
+
*/
|
186
|
+
async onLoadSettings(_loadedSettings, _isInitialLoad) {
|
187
|
+
await noopAsync();
|
188
|
+
}
|
189
|
+
/**
|
190
|
+
* Called when the plugin settings are saved.
|
191
|
+
*
|
192
|
+
* @param _newSettings - The new settings.
|
193
|
+
* @param _oldSettings - The old settings.
|
194
|
+
* @param _context - The context.
|
195
|
+
*/
|
196
|
+
async onSaveSettings(_newSettings, _oldSettings, _context) {
|
197
|
+
await noopAsync();
|
198
|
+
}
|
205
199
|
/**
|
206
200
|
* Called when the plugin is unloaded.
|
207
201
|
*/
|
@@ -239,4 +233,4 @@ ${message}`);
|
|
239
233
|
export {
|
240
234
|
PluginBase
|
241
235
|
};
|
242
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base class for Obsidian plugins providing utility methods for settings management, error handling, and notifications.\n *\n * This class simplifies the process of managing plugin settings, displaying notifications, and handling errors.\n * Subclasses should implement methods to create default settings and settings tabs, and complete plugin-specific\n * loading tasks.\n */\n\nimport type { ReadonlyDeep } from 'type-fest';\n\nimport {\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type { AsyncEventRef } from '../../AsyncEvents.ts';\nimport type {\n  ExtractPluginSettings,\n  ExtractPluginSettingsManager,\n  ExtractPluginSettingsTab,\n  ExtractReadonlyPluginSettingsWrapper,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely,\n  invokeAsyncSafelyAfterDelay\n} from '../../Async.ts';\nimport { AsyncEvents } from '../../AsyncEvents.ts';\nimport { getDebugger } from '../../Debug.ts';\nimport { registerAsyncErrorEventHandler } from '../../Error.ts';\nimport { noopAsync } from '../../Function.ts';\nimport { initPluginContext } from './PluginContext.ts';\n\ntype LifecycleEventName = 'layoutReady' | 'load' | 'unload';\n\n/**\n * Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginBase<PluginTypes extends PluginTypesBase> extends ObsidianPlugin {\n  public readonly events = new AsyncEvents();\n\n  /**\n   * Gets the AbortSignal used for aborting long-running operations.\n   *\n   * @returns The abort signal.\n   */\n  public get abortSignal(): AbortSignal {\n    return this._abortSignal;\n  }\n\n  /**\n   * Gets the readonly plugin settings.\n   *\n   * @returns The readonly plugin settings.\n   */\n  public get settings(): ReadonlyDeep<ExtractPluginSettings<PluginTypes>> {\n    return this.settingsManager.settingsWrapper.safeSettings as ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n  }\n\n  /**\n   * Gets the plugin settings manager.\n   *\n   * @returns The plugin settings manager.\n   */\n  public get settingsManager(): ExtractPluginSettingsManager<PluginTypes> {\n    if (!this._settingsManager) {\n      throw new Error('Settings manager not defined');\n    }\n\n    return this._settingsManager;\n  }\n\n  /**\n   * Gets the plugin settings tab.\n   *\n   * @returns The plugin settings tab.\n   */\n  public get settingsTab(): ExtractPluginSettingsTab<PluginTypes> {\n    if (!this._settingsTab) {\n      throw new Error('Settings tab not defined');\n    }\n\n    return this._settingsTab;\n  }\n\n  private _abortSignal!: AbortSignal;\n  private _settingsManager: ExtractPluginSettingsManager<PluginTypes> | null = null;\n  private _settingsTab: ExtractPluginSettingsTab<PluginTypes> | null = null;\n  private lifecycleEventNames = new Set<LifecycleEventName>();\n  private notice?: Notice;\n\n  /**\n   * Logs a message to the console.\n   *\n   * Use instead of `console.debug()`.\n   *\n   * Those messages are not shown by default, but they can be shown by enabling `your-plugin-id` debugger namespace.\n   *\n   * @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging} for more information.\n   *\n   * @param message - The message to log.\n   * @param args - The arguments to log.\n   */\n  public consoleDebug(message: string, ...args: unknown[]): void {\n    // Skip the `consoleDebug()` call itself\n    const FRAMES_TO_SKIP = 1;\n    const _debugger = getDebugger(this.manifest.id, FRAMES_TO_SKIP);\n    _debugger(message, ...args);\n  }\n\n  /**\n   * Called when the external settings change.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this._settingsManager?.loadFromFile(false);\n  }\n\n  /**\n   * Called when the plugin is loaded\n   */\n  public override async onload(): Promise<void> {\n    await super.onload();\n    await this.onloadImpl();\n    invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));\n  }\n\n  /**\n   * Called when the plugin settings are loaded or reloaded.\n   *\n   * @param _loadedSettings - The loaded settings wrapper.\n   * @param _isInitialLoad - Whether the settings are being loaded for the first time.\n   */\n  public async onLoadSettings(_loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _isInitialLoad: boolean): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings are saved.\n   *\n   * @param _newSettings - The new settings.\n   * @param _oldSettings - The old settings.\n   * @param _context - The context.\n   */\n  public async onSaveSettings(\n    _newSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n    _oldSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n    _context: unknown\n  ): Promise<void> {\n    await noopAsync();\n  }\n\n  /** */\n  public override onunload(): void {\n    super.onunload();\n    invokeAsyncSafely(async () => {\n      try {\n        await this.onunloadImpl();\n      } finally {\n        await this.triggerLifecycleEvent('unload');\n      }\n    });\n  }\n\n  /**\n   * Registers an async event.\n   * Unregisters the event when the plugin is unloaded.\n   *\n   * @param eventRef - The event reference.\n   */\n  public registerAsyncEvent(eventRef: AsyncEventRef): void {\n    this.register(() => {\n      eventRef.asyncEvents.offref(eventRef);\n    });\n  }\n\n  /**\n   * Waits for a lifecycle event to be triggered.\n   *\n   * If you `await` this method during lifecycle event, it might cause a deadlock.\n   *\n   * Consider wrapping this call with {@link invokeAsyncSafely}.\n   *\n   * @param name - The name of the event.\n   * @returns A {@link Promise} that resolves when the event is triggered.\n   */\n  public async waitForLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    if (this.lifecycleEventNames.has(name)) {\n      return;\n    }\n\n    await new Promise<void>((resolve) => {\n      this.events.once(name, () => {\n        resolve();\n      });\n    });\n  }\n\n  /**\n   * Creates a plugin settings tab.\n   *\n   * @returns The settings tab or null if not applicable.\n   */\n  protected createPluginSettingsTab(): ExtractPluginSettingsTab<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Creates the plugin settings manager. This method must be implemented by subclasses.\n   *\n   * @returns The plugin settings manager.\n   */\n  protected createSettingsManager(): ExtractPluginSettingsManager<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Called when the layout is ready. This method can be overridden by subclasses to perform actions once\n   * the layout is ready.\n   */\n  protected async onLayoutReady(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Executed when the plugin is loaded.\n   *\n   * This method can be overridden by subclasses to perform actions once the plugin is loaded.\n   */\n  protected async onloadImpl(): Promise<void> {\n    initPluginContext(this.app, this.manifest.id);\n\n    this.register(registerAsyncErrorEventHandler(() => {\n      this.showNotice('An unhandled error occurred. Please check the console for more information.');\n    }));\n\n    this._settingsManager = this.createSettingsManager();\n\n    await this._settingsManager?.loadFromFile(true);\n    this._settingsTab = this.createPluginSettingsTab();\n    if (this._settingsTab) {\n      this.addSettingTab(this._settingsTab);\n    }\n\n    const abortController = new AbortController();\n    this._abortSignal = abortController.signal;\n    this.register(() => {\n      abortController.abort();\n    });\n  }\n\n  /**\n   * Called when the plugin is unloaded.\n   */\n  protected async onunloadImpl(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Displays a notice message to the user.\n   *\n   * @param message - The message to display.\n   */\n  protected showNotice(message: string): void {\n    if (this.notice) {\n      this.notice.hide();\n    }\n\n    this.notice = new Notice(`${this.manifest.name}\\n${message}`);\n  }\n\n  private async afterLoad(): Promise<void> {\n    await this.triggerLifecycleEvent('load');\n    this.app.workspace.onLayoutReady(convertAsyncToSync(this.onLayoutReadyBase.bind(this)));\n  }\n\n  private async onLayoutReadyBase(): Promise<void> {\n    try {\n      await this.onLayoutReady();\n    } finally {\n      await this.triggerLifecycleEvent('layoutReady');\n    }\n  }\n\n  private async triggerLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    this.lifecycleEventNames.add(name);\n    await this.events.triggerAsync(name);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
236
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base class for Obsidian plugins providing utility methods for settings management, error handling, and notifications.\n *\n * This class simplifies the process of managing plugin settings, displaying notifications, and handling errors.\n * Subclasses should implement methods to create default settings and settings tabs, and complete plugin-specific\n * loading tasks.\n */\n\nimport type { ReadonlyDeep } from 'type-fest';\n\nimport {\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type {\n  ExtractPluginSettings,\n  ExtractPluginSettingsManager,\n  ExtractPluginSettingsTab,\n  ExtractReadonlyPluginSettingsWrapper,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely,\n  invokeAsyncSafelyAfterDelay\n} from '../../Async.ts';\nimport { AsyncEvents } from '../../AsyncEvents.ts';\nimport { getDebugger } from '../../Debug.ts';\nimport { registerAsyncErrorEventHandler } from '../../Error.ts';\nimport { noopAsync } from '../../Function.ts';\nimport { registerAsyncEvent } from '../Components/AsyncEventsComponent.ts';\nimport { initPluginContext } from './PluginContext.ts';\n\ntype LifecycleEventName = 'layoutReady' | 'load' | 'unload';\n\n/**\n * Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginBase<PluginTypes extends PluginTypesBase> extends ObsidianPlugin {\n  public readonly events = new AsyncEvents();\n\n  /**\n   * Gets the AbortSignal used for aborting long-running operations.\n   *\n   * @returns The abort signal.\n   */\n  public get abortSignal(): AbortSignal {\n    return this._abortSignal;\n  }\n\n  /**\n   * Gets the readonly plugin settings.\n   *\n   * @returns The readonly plugin settings.\n   */\n  public get settings(): ReadonlyDeep<ExtractPluginSettings<PluginTypes>> {\n    return this.settingsManager.settingsWrapper.safeSettings as ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n  }\n\n  /**\n   * Gets the plugin settings manager.\n   *\n   * @returns The plugin settings manager.\n   */\n  public get settingsManager(): ExtractPluginSettingsManager<PluginTypes> {\n    if (!this._settingsManager) {\n      throw new Error('Settings manager not defined');\n    }\n\n    return this._settingsManager;\n  }\n\n  /**\n   * Gets the plugin settings tab.\n   *\n   * @returns The plugin settings tab.\n   */\n  public get settingsTab(): ExtractPluginSettingsTab<PluginTypes> {\n    if (!this._settingsTab) {\n      throw new Error('Settings tab not defined');\n    }\n\n    return this._settingsTab;\n  }\n\n  private _abortSignal!: AbortSignal;\n  private _settingsManager: ExtractPluginSettingsManager<PluginTypes> | null = null;\n  private _settingsTab: ExtractPluginSettingsTab<PluginTypes> | null = null;\n  private lifecycleEventNames = new Set<LifecycleEventName>();\n  private notice?: Notice;\n\n  /**\n   * Logs a message to the console.\n   *\n   * Use instead of `console.debug()`.\n   *\n   * Those messages are not shown by default, but they can be shown by enabling `your-plugin-id` debugger namespace.\n   *\n   * @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging} for more information.\n   *\n   * @param message - The message to log.\n   * @param args - The arguments to log.\n   */\n  public consoleDebug(message: string, ...args: unknown[]): void {\n    // Skip the `consoleDebug()` call itself\n    const FRAMES_TO_SKIP = 1;\n    const _debugger = getDebugger(this.manifest.id, FRAMES_TO_SKIP);\n    _debugger(message, ...args);\n  }\n\n  /**\n   * Called when the external settings change.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this._settingsManager?.loadFromFile(false);\n  }\n\n  /**\n   * Called when the plugin is loaded\n   */\n  public override async onload(): Promise<void> {\n    await super.onload();\n    await this.onloadImpl();\n    invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));\n  }\n\n  /** */\n  public override onunload(): void {\n    super.onunload();\n    invokeAsyncSafely(async () => {\n      try {\n        await this.onunloadImpl();\n      } finally {\n        await this.triggerLifecycleEvent('unload');\n      }\n    });\n  }\n\n  /**\n   * Waits for a lifecycle event to be triggered.\n   *\n   * If you `await` this method during lifecycle event, it might cause a deadlock.\n   *\n   * Consider wrapping this call with {@link invokeAsyncSafely}.\n   *\n   * @param name - The name of the event.\n   * @returns A {@link Promise} that resolves when the event is triggered.\n   */\n  public async waitForLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    if (this.lifecycleEventNames.has(name)) {\n      return;\n    }\n\n    await new Promise<void>((resolve) => {\n      this.events.once(name, () => {\n        resolve();\n      });\n    });\n  }\n\n  /**\n   * Creates a plugin settings tab.\n   *\n   * @returns The settings tab or null if not applicable.\n   */\n  protected createPluginSettingsTab(): ExtractPluginSettingsTab<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Creates the plugin settings manager. This method must be implemented by subclasses.\n   *\n   * @returns The plugin settings manager.\n   */\n  protected createSettingsManager(): ExtractPluginSettingsManager<PluginTypes> | null {\n    return null;\n  }\n\n  /**\n   * Called when the layout is ready. This method can be overridden by subclasses to perform actions once\n   * the layout is ready.\n   */\n  protected async onLayoutReady(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Executed when the plugin is loaded.\n   *\n   * This method can be overridden by subclasses to perform actions once the plugin is loaded.\n   */\n  protected async onloadImpl(): Promise<void> {\n    initPluginContext(this.app, this.manifest.id);\n\n    this.register(registerAsyncErrorEventHandler(() => {\n      this.showNotice('An unhandled error occurred. Please check the console for more information.');\n    }));\n\n    this._settingsManager = this.createSettingsManager();\n    if (this._settingsManager) {\n      registerAsyncEvent(this, this._settingsManager.on('loadSettings', this.onLoadSettings.bind(this)));\n      registerAsyncEvent(this, this._settingsManager.on('saveSettings', this.onSaveSettings.bind(this)));\n    }\n\n    await this._settingsManager?.loadFromFile(true);\n    this._settingsTab = this.createPluginSettingsTab();\n    if (this._settingsTab) {\n      this.addSettingTab(this._settingsTab);\n    }\n\n    const abortController = new AbortController();\n    this._abortSignal = abortController.signal;\n    this.register(() => {\n      abortController.abort();\n    });\n  }\n\n  /**\n   * Called when the plugin settings are loaded or reloaded.\n   *\n   * @param _loadedSettings - The loaded settings wrapper.\n   * @param _isInitialLoad - Whether the settings are being loaded for the first time.\n   */\n  protected async onLoadSettings(_loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _isInitialLoad: boolean): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings are saved.\n   *\n   * @param _newSettings - The new settings.\n   * @param _oldSettings - The old settings.\n   * @param _context - The context.\n   */\n  protected async onSaveSettings(\n    _newSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n    _oldSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n    _context: unknown\n  ): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin is unloaded.\n   */\n  protected async onunloadImpl(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Displays a notice message to the user.\n   *\n   * @param message - The message to display.\n   */\n  protected showNotice(message: string): void {\n    if (this.notice) {\n      this.notice.hide();\n    }\n\n    this.notice = new Notice(`${this.manifest.name}\\n${message}`);\n  }\n\n  private async afterLoad(): Promise<void> {\n    await this.triggerLifecycleEvent('load');\n    this.app.workspace.onLayoutReady(convertAsyncToSync(this.onLayoutReadyBase.bind(this)));\n  }\n\n  private async onLayoutReadyBase(): Promise<void> {\n    try {\n      await this.onLayoutReady();\n    } finally {\n      await this.triggerLifecycleEvent('layoutReady');\n    }\n  }\n\n  private async triggerLifecycleEvent(name: LifecycleEventName): Promise<void> {\n    this.lifecycleEventNames.add(name);\n    await this.events.triggerAsync(name);\n  }\n}\n"],
  "mappings": ";;;;;;;AAYA;AAAA,EACE;AAAA,EACA,UAAU;AAAA,OACL;AAUP;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,mBAAmB;AAC5B,SAAS,mBAAmB;AAC5B,SAAS,sCAAsC;AAC/C,SAAS,iBAAiB;AAC1B,SAAS,0BAA0B;AACnC,SAAS,yBAAyB;AAS3B,MAAe,mBAAwD,eAAe;AAAA,EAC3E,SAAS,IAAI,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOzC,IAAW,cAA2B;AACpC,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,WAA6D;AACtE,WAAO,KAAK,gBAAgB,gBAAgB;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,kBAA6D;AACtE,QAAI,CAAC,KAAK,kBAAkB;AAC1B,YAAM,IAAI,MAAM,8BAA8B;AAAA,IAChD;AAEA,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,cAAqD;AAC9D,QAAI,CAAC,KAAK,cAAc;AACtB,YAAM,IAAI,MAAM,0BAA0B;AAAA,IAC5C;AAEA,WAAO,KAAK;AAAA,EACd;AAAA,EAEQ;AAAA,EACA,mBAAqE;AAAA,EACrE,eAA6D;AAAA,EAC7D,sBAAsB,oBAAI,IAAwB;AAAA,EAClD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcD,aAAa,YAAoB,MAAuB;AAE7D,UAAM,iBAAiB;AACvB,UAAM,YAAY,YAAY,KAAK,SAAS,IAAI,cAAc;AAC9D,cAAU,SAAS,GAAG,IAAI;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,2BAA0C;AAC9D,UAAM,MAAM,2BAA2B;AACvC,UAAM,KAAK,kBAAkB,aAAa,KAAK;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,SAAwB;AAC5C,UAAM,MAAM,OAAO;AACnB,UAAM,KAAK,WAAW;AACtB,gCAA4B,KAAK,UAAU,KAAK,IAAI,CAAC;AAAA,EACvD;AAAA;AAAA,EAGgB,WAAiB;AAC/B,UAAM,SAAS;AACf,sBAAkB,YAAY;AAC5B,UAAI;AACF,cAAM,KAAK,aAAa;AAAA,MAC1B,UAAE;AACA,cAAM,KAAK,sBAAsB,QAAQ;AAAA,MAC3C;AAAA,IACF,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,MAAa,sBAAsB,MAAyC;AAC1E,QAAI,KAAK,oBAAoB,IAAI,IAAI,GAAG;AACtC;AAAA,IACF;AAEA,UAAM,IAAI,QAAc,CAAC,YAAY;AACnC,WAAK,OAAO,KAAK,MAAM,MAAM;AAC3B,gBAAQ;AAAA,MACV,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,0BAAwE;AAChF,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,wBAA0E;AAClF,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAgB,gBAA+B;AAC7C,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAgB,aAA4B;AAC1C,sBAAkB,KAAK,KAAK,KAAK,SAAS,EAAE;AAE5C,SAAK,SAAS,+BAA+B,MAAM;AACjD,WAAK,WAAW,6EAA6E;AAAA,IAC/F,CAAC,CAAC;AAEF,SAAK,mBAAmB,KAAK,sBAAsB;AACnD,QAAI,KAAK,kBAAkB;AACzB,yBAAmB,MAAM,KAAK,iBAAiB,GAAG,gBAAgB,KAAK,eAAe,KAAK,IAAI,CAAC,CAAC;AACjG,yBAAmB,MAAM,KAAK,iBAAiB,GAAG,gBAAgB,KAAK,eAAe,KAAK,IAAI,CAAC,CAAC;AAAA,IACnG;AAEA,UAAM,KAAK,kBAAkB,aAAa,IAAI;AAC9C,SAAK,eAAe,KAAK,wBAAwB;AACjD,QAAI,KAAK,cAAc;AACrB,WAAK,cAAc,KAAK,YAAY;AAAA,IACtC;AAEA,UAAM,kBAAkB,IAAI,gBAAgB;AAC5C,SAAK,eAAe,gBAAgB;AACpC,SAAK,SAAS,MAAM;AAClB,sBAAgB,MAAM;AAAA,IACxB,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAgB,eAAe,iBAAoE,gBAAwC;AACzI,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAgB,eACd,cACA,cACA,UACe;AACf,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAgB,eAA8B;AAC5C,UAAM,UAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,WAAW,SAAuB;AAC1C,QAAI,KAAK,QAAQ;AACf,WAAK,OAAO,KAAK;AAAA,IACnB;AAEA,SAAK,SAAS,IAAI,OAAO,GAAG,KAAK,SAAS,IAAI;AAAA,EAAK,OAAO,EAAE;AAAA,EAC9D;AAAA,EAEA,MAAc,YAA2B;AACvC,UAAM,KAAK,sBAAsB,MAAM;AACvC,SAAK,IAAI,UAAU,cAAc,mBAAmB,KAAK,kBAAkB,KAAK,IAAI,CAAC,CAAC;AAAA,EACxF;AAAA,EAEA,MAAc,oBAAmC;AAC/C,QAAI;AACF,YAAM,KAAK,cAAc;AAAA,IAC3B,UAAE;AACA,YAAM,KAAK,sBAAsB,aAAa;AAAA,IAChD;AAAA,EACF;AAAA,EAEA,MAAc,sBAAsB,MAAyC;AAC3E,SAAK,oBAAoB,IAAI,IAAI;AACjC,UAAM,KAAK,OAAO,aAAa,IAAI;AAAA,EACrC;AACF;",
  "names": []
}

|
@@ -5,10 +5,12 @@
|
|
5
5
|
*/
|
6
6
|
import type { App } from 'obsidian';
|
7
7
|
import type { Promisable, ReadonlyDeep } from 'type-fest';
|
8
|
+
import type { AsyncEventRef } from '../../AsyncEvents.mjs';
|
8
9
|
import type { GenericObject } from '../../Object.mjs';
|
9
10
|
import type { Transformer } from '../../Transformers/Transformer.mjs';
|
10
11
|
import type { MaybeReturn, StringKeys } from '../../Type.mjs';
|
11
12
|
import type { ExtractPlugin, ExtractPluginSettings, ExtractPluginSettingsPropertyNames, ExtractReadonlyPluginSettingsWrapper, PluginTypesBase } from './PluginTypesBase.mjs';
|
13
|
+
import { AsyncEvents } from '../../AsyncEvents.mjs';
|
12
14
|
type ValidationResult<PluginSettings extends object> = Partial<Record<StringKeys<PluginSettings>, string>>;
|
13
15
|
type Validator<PluginSettings extends object, PropertyName extends StringKeys<PluginSettings> = StringKeys<PluginSettings>> = (value: PluginSettings[PropertyName], settings: PluginSettings) => Promisable<MaybeReturn<string>>;
|
14
16
|
/**
|
@@ -16,7 +18,7 @@ type Validator<PluginSettings extends object, PropertyName extends StringKeys<Pl
|
|
16
18
|
*
|
17
19
|
* @typeParam PluginTypes - Plugin-specific types.
|
18
20
|
*/
|
19
|
-
export declare abstract class PluginSettingsManagerBase<PluginTypes extends PluginTypesBase> {
|
21
|
+
export declare abstract class PluginSettingsManagerBase<PluginTypes extends PluginTypesBase> extends AsyncEvents {
|
20
22
|
readonly plugin: ExtractPlugin<PluginTypes>;
|
21
23
|
readonly app: App;
|
22
24
|
readonly defaultSettings: ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;
|
@@ -67,6 +69,24 @@ export declare abstract class PluginSettingsManagerBase<PluginTypes extends Plug
|
|
67
69
|
* @returns A {@link Promise} that resolves when the settings are loaded.
|
68
70
|
*/
|
69
71
|
loadFromFile(isInitialLoad: boolean): Promise<void>;
|
72
|
+
/**
|
73
|
+
* Subscribes to the `loadSettings` event.
|
74
|
+
*
|
75
|
+
* @param name - Always `loadSettings`.
|
76
|
+
* @param callback - The callback to call when the event is triggered.
|
77
|
+
* @param thisArg - The context passed as `this` to the `callback`.
|
78
|
+
* @returns A reference to the event listener.
|
79
|
+
*/
|
80
|
+
on(name: 'loadSettings', callback: (loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, isInitialLoad: boolean) => Promisable<void>, thisArg?: unknown): AsyncEventRef;
|
81
|
+
/**
|
82
|
+
* Subscribes to the `saveSettings` event.
|
83
|
+
*
|
84
|
+
* @param name - Always `saveSettings`.
|
85
|
+
* @param callback - The callback to call when the event is triggered.
|
86
|
+
* @param thisArg - The context passed as `this` to the `callback`.
|
87
|
+
* @returns A reference to the event listener.
|
88
|
+
*/
|
89
|
+
on(name: 'saveSettings', callback: (newSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, oldSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, context: unknown) => Promisable<void>, thisArg?: unknown): AsyncEventRef;
|
70
90
|
/**
|
71
91
|
* Saves the new plugin settings.
|
72
92
|
*
|
@@ -5,6 +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
|
+
import { AsyncEvents } from "../../AsyncEvents.mjs";
|
8
9
|
import {
|
9
10
|
noop,
|
10
11
|
noopAsync
|
@@ -22,13 +23,14 @@ const defaultTransformer = new GroupTransformer([
|
|
22
23
|
new DateTransformer(),
|
23
24
|
new DurationTransformer()
|
24
25
|
]);
|
25
|
-
class PluginSettingsManagerBase {
|
26
|
+
class PluginSettingsManagerBase extends AsyncEvents {
|
26
27
|
/**
|
27
28
|
* Creates a new plugin settings manager.
|
28
29
|
*
|
29
30
|
* @param plugin - The plugin.
|
30
31
|
*/
|
31
32
|
constructor(plugin) {
|
33
|
+
super();
|
32
34
|
this.plugin = plugin;
|
33
35
|
this.app = plugin.app;
|
34
36
|
this.defaultSettings = this.createDefaultSettings();
|
@@ -117,7 +119,18 @@ class PluginSettingsManagerBase {
|
|
117
119
|
if (!deepEqual(newRecord, data)) {
|
118
120
|
await this.saveToFileImpl();
|
119
121
|
}
|
120
|
-
await this.
|
122
|
+
await this.triggerAsync("loadSettings", this.currentSettingsWrapper, isInitialLoad);
|
123
|
+
}
|
124
|
+
/**
|
125
|
+
* Subscribes to an event.
|
126
|
+
*
|
127
|
+
* @param name - The name of the event.
|
128
|
+
* @param callback - The callback to call when the event is triggered.
|
129
|
+
* @param thisArg - The context passed as `this` to the `callback`.
|
130
|
+
* @returns A reference to the event listener.
|
131
|
+
*/
|
132
|
+
on(name, callback, thisArg) {
|
133
|
+
return super.on(name, callback, thisArg);
|
121
134
|
}
|
122
135
|
/**
|
123
136
|
* Saves the new plugin settings.
|
@@ -130,7 +143,7 @@ class PluginSettingsManagerBase {
|
|
130
143
|
return;
|
131
144
|
}
|
132
145
|
await this.saveToFileImpl();
|
133
|
-
await this.
|
146
|
+
await this.triggerAsync("saveSettings", this.currentSettingsWrapper, this.lastSavedSettingsWrapper, context);
|
134
147
|
this.lastSavedSettingsWrapper = await this.cloneSettingsWrapper(this.currentSettingsWrapper);
|
135
148
|
}
|
136
149
|
/**
|
@@ -265,7 +278,7 @@ class PluginSettingsManagerBase {
|
|
265
278
|
return settings;
|
266
279
|
}
|
267
280
|
async saveToFileImpl() {
|
268
|
-
await this.plugin.saveData(await this.settingsToRawRecord(this.currentSettingsWrapper));
|
281
|
+
await this.plugin.saveData(await this.settingsToRawRecord(this.currentSettingsWrapper.settings));
|
269
282
|
}
|
270
283
|
setPropertyImpl(propertyName, value, validationMessage) {
|
271
284
|
this.currentSettingsWrapper.settings[propertyName] = value;
|
@@ -284,4 +297,4 @@ class PluginSettingsManagerBase {
|
|
284
297
|
export {
|
285
298
|
PluginSettingsManagerBase
|
286
299
|
};
|
287
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsManagerBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Plugin settings manager base class.\n */\n\nimport type { App } from 'obsidian';\nimport type {\n  Promisable,\n  ReadonlyDeep\n} from 'type-fest';\n\nimport type { GenericObject } from '../../Object.ts';\nimport type { Transformer } from '../../Transformers/Transformer.ts';\nimport type {\n  MaybeReturn,\n  StringKeys\n} from '../../Type.ts';\nimport type { PluginSettingsWrapper } from './PluginSettingsWrapper.ts';\nimport type {\n  ExtractPlugin,\n  ExtractPluginSettings,\n  ExtractPluginSettingsPropertyNames,\n  ExtractPluginSettingsPropertyValues,\n  ExtractPluginSettingsWrapper,\n  ExtractReadonlyPluginSettingsWrapper,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  noop,\n  noopAsync\n} from '../../Function.ts';\nimport {\n  deepEqual,\n  getAllKeys\n} from '../../Object.ts';\nimport { DateTransformer } from '../../Transformers/DateTransformer.ts';\nimport { DurationTransformer } from '../../Transformers/DurationTransformer.ts';\nimport { GroupTransformer } from '../../Transformers/GroupTransformer.ts';\nimport { SkipPrivatePropertyTransformer } from '../../Transformers/SkipPrivatePropertyTransformer.ts';\n\nconst defaultTransformer = new GroupTransformer([\n  new SkipPrivatePropertyTransformer(),\n  new DateTransformer(),\n  new DurationTransformer()\n]);\n\ntype ValidationResult<PluginSettings extends object> = Partial<Record<StringKeys<PluginSettings>, string>>;\n\ntype Validator<PluginSettings extends object, PropertyName extends StringKeys<PluginSettings> = StringKeys<PluginSettings>> = (\n  value: PluginSettings[PropertyName],\n  settings: PluginSettings\n) => Promisable<MaybeReturn<string>>;\n\n/**\n * Base class for managing plugin settings.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginSettingsManagerBase<PluginTypes extends PluginTypesBase> {\n  public readonly app: App;\n\n  public readonly defaultSettings: ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n\n  /**\n   * Gets the current settings wrapper.\n   *\n   * @returns The current settings wrapper.\n   */\n  public get settingsWrapper(): ExtractReadonlyPluginSettingsWrapper<PluginTypes> {\n    return this.currentSettingsWrapper as ExtractReadonlyPluginSettingsWrapper<PluginTypes>;\n  }\n\n  private currentSettingsWrapper: ExtractPluginSettingsWrapper<PluginTypes>;\n\n  private lastSavedSettingsWrapper: ExtractPluginSettingsWrapper<PluginTypes>;\n  private readonly propertyNames: ExtractPluginSettingsPropertyNames<PluginTypes>[];\n  private readonly validators = new Map<ExtractPluginSettingsPropertyNames<PluginTypes>, Validator<ExtractPluginSettings<PluginTypes>>>();\n  /**\n   * Creates a new plugin settings manager.\n   *\n   * @param plugin - The plugin.\n   */\n  public constructor(public readonly plugin: ExtractPlugin<PluginTypes>) {\n    this.app = plugin.app;\n    this.defaultSettings = this.createDefaultSettings() as ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n    this.currentSettingsWrapper = this.createDefaultSettingsWrapper();\n    this.lastSavedSettingsWrapper = this.createDefaultSettingsWrapper();\n    this.propertyNames = getAllKeys(this.currentSettingsWrapper.settings);\n    this.registerValidators();\n  }\n\n  /**\n   * Edits the plugin settings and saves them.\n   *\n   * @param settingsEditor - The editor.\n   * @param context - The context.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async editAndSave(settingsEditor: (settings: ExtractPluginSettings<PluginTypes>) => Promisable<void>, context?: unknown): Promise<void> {\n    await this.edit(settingsEditor);\n    await this.saveToFile(context);\n  }\n\n  /**\n   * Ensures the settings are safe.\n   *\n   * It runs validation for each property and sets the default value if the validation fails.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves when the settings are safe.\n   */\n  public async ensureSafe(settings: ExtractPluginSettings<PluginTypes>): Promise<void> {\n    const validationResult = await this.validate(settings);\n    for (const propertyName of this.propertyNames) {\n      if (validationResult[propertyName]) {\n        settings[propertyName] = this.defaultSettings[propertyName];\n      }\n    }\n  }\n\n  /**\n   * Gets a safe copy of the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the safe copy of the settings.\n   */\n  public async getSafeCopy(settings: ExtractPluginSettings<PluginTypes>): Promise<ExtractPluginSettings<PluginTypes>> {\n    const safeSettings = await this.cloneSettings(settings);\n    await this.ensureSafe(safeSettings);\n    return safeSettings;\n  }\n\n  /**\n   * Loads the plugin settings from the file.\n   *\n   * @param isInitialLoad - Whether the settings are being loaded for the first time.\n   * @returns A {@link Promise} that resolves when the settings are loaded.\n   */\n  public async loadFromFile(isInitialLoad: boolean): Promise<void> {\n    const data = await this.plugin.loadData() as unknown;\n    this.lastSavedSettingsWrapper = this.createDefaultSettingsWrapper();\n    this.currentSettingsWrapper = this.createDefaultSettingsWrapper();\n\n    if (data === undefined || data === null) {\n      return;\n    }\n\n    if (typeof data !== 'object') {\n      console.error(`Invalid settings from data.json. Expected Object, got: ${typeof data}`);\n      return;\n    }\n\n    const rawRecord = data as GenericObject;\n    const parsedSettings = await this.rawRecordToSettings(rawRecord);\n    const validationResult = await this.validate(parsedSettings);\n\n    for (const propertyName of this.propertyNames) {\n      this.setPropertyImpl(propertyName, parsedSettings[propertyName], validationResult[propertyName]);\n    }\n\n    this.lastSavedSettingsWrapper = await this.cloneSettingsWrapper(this.currentSettingsWrapper);\n\n    const newRecord = await this.settingsToRawRecord(this.currentSettingsWrapper.settings);\n\n    if (!deepEqual(newRecord, data)) {\n      await this.saveToFileImpl();\n    }\n\n    await this.plugin.onLoadSettings(this.currentSettingsWrapper, isInitialLoad);\n  }\n\n  /**\n   * Saves the new plugin settings.\n   *\n   * @param context - The context of the save to file operation.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async saveToFile(context?: unknown): Promise<void> {\n    if (deepEqual(this.lastSavedSettingsWrapper.settings, this.currentSettingsWrapper.settings)) {\n      return;\n    }\n\n    await this.saveToFileImpl();\n    await this.plugin.onSaveSettings(this.currentSettingsWrapper, this.lastSavedSettingsWrapper, context);\n    this.lastSavedSettingsWrapper = await this.cloneSettingsWrapper(this.currentSettingsWrapper);\n  }\n\n  /**\n   * Sets the value of a property.\n   *\n   * @typeParam PropertyName - The name of the property.\n   * @param propertyName - The name of the property.\n   * @param value - The value to set.\n   * @returns A {@link Promise} that resolves to the validation message.\n   */\n  public async setProperty<PropertyName extends ExtractPluginSettingsPropertyNames<PluginTypes>>(\n    propertyName: PropertyName,\n    value: ExtractPluginSettings<PluginTypes>[PropertyName]\n  ): Promise<string> {\n    await this.edit((settings) => {\n      settings[propertyName] = value;\n    });\n    return this.currentSettingsWrapper.validationMessages[propertyName];\n  }\n\n  /**\n   * Validates the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the validation result.\n   */\n  public async validate(settings: ExtractPluginSettings<PluginTypes>): Promise<ValidationResult<ExtractPluginSettings<PluginTypes>>> {\n    const result: ValidationResult<ExtractPluginSettings<PluginTypes>> = {};\n    for (const [propertyName, validator] of this.validators.entries()) {\n      const validationMessage = await validator(settings[propertyName], settings);\n      if (validationMessage) {\n        result[propertyName] = validationMessage;\n      }\n    }\n\n    return result;\n  }\n\n  protected abstract createDefaultSettings(): ExtractPluginSettings<PluginTypes>;\n\n  /**\n   * Gets the transformer.\n   *\n   * @returns The transformer.\n   */\n  protected getTransformer(): Transformer {\n    return defaultTransformer;\n  }\n\n  /**\n   * Called when the plugin settings are loaded.\n   *\n   * @param _record - The record.\n   */\n  protected async onLoadRecord(_record: GenericObject): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings are saving.\n   *\n   * @param _record - The record.\n   */\n  protected async onSavingRecord(_record: GenericObject): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Registers a validator for a property.\n   *\n   * @param propertyName - The name of the property.\n   * @param validator - The validator.\n   */\n  protected registerValidator<PropertyName extends ExtractPluginSettingsPropertyNames<PluginTypes>>(\n    propertyName: PropertyName,\n    validator: Validator<ExtractPluginSettings<PluginTypes>, PropertyName>\n  ): void {\n    this.validators.set(propertyName, validator as Validator<ExtractPluginSettings<PluginTypes>>);\n  }\n\n  /**\n   * Registers the validators.\n   *\n   * This method can be overridden by subclasses to register validators for properties.\n   */\n  protected registerValidators(): void {\n    noop();\n  }\n\n  private async cloneSettings(settings: ExtractPluginSettings<PluginTypes>): Promise<ExtractPluginSettings<PluginTypes>> {\n    const record = await this.settingsToRawRecord(settings);\n    const json = JSON.stringify(record);\n    const cloneRecord = JSON.parse(json) as GenericObject;\n    return await this.rawRecordToSettings(cloneRecord);\n  }\n\n  private async cloneSettingsWrapper(\n    settingsWrapper: PluginSettingsWrapper<ExtractPluginSettings<PluginTypes>>\n  ): Promise<PluginSettingsWrapper<ExtractPluginSettings<PluginTypes>>> {\n    return {\n      safeSettings: await this.cloneSettings(settingsWrapper.safeSettings),\n      settings: await this.cloneSettings(settingsWrapper.settings),\n      validationMessages: { ...settingsWrapper.validationMessages }\n    };\n  }\n\n  private createDefaultSettingsWrapper(): PluginSettingsWrapper<ExtractPluginSettings<PluginTypes>> {\n    return {\n      safeSettings: this.createDefaultSettings(),\n      settings: this.createDefaultSettings(),\n      validationMessages: {} as Record<ExtractPluginSettingsPropertyNames<PluginTypes>, string>\n    };\n  }\n\n  private async edit(settingsEditor: (settings: ExtractPluginSettings<PluginTypes>) => Promisable<void>): Promise<void> {\n    try {\n      await settingsEditor(this.currentSettingsWrapper.settings);\n    } finally {\n      const validationResult = await this.validate(this.currentSettingsWrapper.settings);\n      for (const propertyName of this.propertyNames) {\n        const validationMessage = validationResult[propertyName] ?? '';\n        this.currentSettingsWrapper.validationMessages[propertyName] = validationMessage;\n        this.currentSettingsWrapper.safeSettings[propertyName] = validationMessage\n          ? this.defaultSettings[propertyName]\n          : this.currentSettingsWrapper.settings[propertyName];\n      }\n    }\n  }\n\n  private isValidPropertyName(prop: unknown): prop is ExtractPluginSettingsPropertyNames<PluginTypes> {\n    if (typeof prop !== 'string') {\n      return false;\n    }\n\n    return (this.propertyNames as string[]).includes(prop);\n  }\n\n  private async rawRecordToSettings(rawRecord: GenericObject): Promise<ExtractPluginSettings<PluginTypes>> {\n    await this.onLoadRecord(rawRecord);\n\n    const settings = this.createDefaultSettings();\n\n    for (const [propertyName, value] of Object.entries(rawRecord)) {\n      if (!this.isValidPropertyName(propertyName)) {\n        console.warn(`Unknown property: ${propertyName}`);\n        continue;\n      }\n\n      if (typeof value !== typeof this.defaultSettings[propertyName]) {\n        console.warn(\n          'Possible invalid value type. It might lead to an unexpected behavior of the plugin. There is also a chance it is a false-negative warning, as we are unable to determine the exact type of the value in runtime.',\n          {\n            defaultValue: this.defaultSettings[propertyName],\n            propertyName,\n            value\n          }\n        );\n      }\n\n      settings[propertyName] = value as ExtractPluginSettingsPropertyValues<PluginTypes>;\n    }\n\n    return settings;\n  }\n\n  private async saveToFileImpl(): Promise<void> {\n    await this.plugin.saveData(await this.settingsToRawRecord(this.currentSettingsWrapper));\n  }\n\n  private setPropertyImpl(\n    propertyName: ExtractPluginSettingsPropertyNames<PluginTypes>,\n    value: ExtractPluginSettingsPropertyValues<PluginTypes>,\n    validationMessage?: string\n  ): void {\n    this.currentSettingsWrapper.settings[propertyName] = value;\n    this.currentSettingsWrapper.validationMessages[propertyName] = validationMessage ?? '';\n    this.currentSettingsWrapper.safeSettings[propertyName] = validationMessage ? this.defaultSettings[propertyName] : value;\n  }\n\n  private async settingsToRawRecord(settings: ExtractPluginSettings<PluginTypes>): Promise<GenericObject> {\n    const rawRecord: GenericObject = {};\n\n    for (const propertyName of this.propertyNames) {\n      rawRecord[propertyName] = settings[propertyName];\n    }\n\n    await this.onSavingRecord(rawRecord);\n\n    return this.getTransformer().transformObjectRecursively(rawRecord);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
300
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsManagerBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Plugin settings manager base class.\n */\n\nimport type { App } from 'obsidian';\nimport type {\n  Promisable,\n  ReadonlyDeep\n} from 'type-fest';\n\nimport type { AsyncEventRef } from '../../AsyncEvents.ts';\nimport type { GenericObject } from '../../Object.ts';\nimport type { Transformer } from '../../Transformers/Transformer.ts';\nimport type {\n  MaybeReturn,\n  StringKeys\n} from '../../Type.ts';\nimport type { PluginSettingsWrapper } from './PluginSettingsWrapper.ts';\nimport type {\n  ExtractPlugin,\n  ExtractPluginSettings,\n  ExtractPluginSettingsPropertyNames,\n  ExtractPluginSettingsPropertyValues,\n  ExtractPluginSettingsWrapper,\n  ExtractReadonlyPluginSettingsWrapper,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport { AsyncEvents } from '../../AsyncEvents.ts';\nimport {\n  noop,\n  noopAsync\n} from '../../Function.ts';\nimport {\n  deepEqual,\n  getAllKeys\n} from '../../Object.ts';\nimport { DateTransformer } from '../../Transformers/DateTransformer.ts';\nimport { DurationTransformer } from '../../Transformers/DurationTransformer.ts';\nimport { GroupTransformer } from '../../Transformers/GroupTransformer.ts';\nimport { SkipPrivatePropertyTransformer } from '../../Transformers/SkipPrivatePropertyTransformer.ts';\n\nconst defaultTransformer = new GroupTransformer([\n  new SkipPrivatePropertyTransformer(),\n  new DateTransformer(),\n  new DurationTransformer()\n]);\n\ntype ValidationResult<PluginSettings extends object> = Partial<Record<StringKeys<PluginSettings>, string>>;\n\ntype Validator<PluginSettings extends object, PropertyName extends StringKeys<PluginSettings> = StringKeys<PluginSettings>> = (\n  value: PluginSettings[PropertyName],\n  settings: PluginSettings\n) => Promisable<MaybeReturn<string>>;\n\n/**\n * Base class for managing plugin settings.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginSettingsManagerBase<PluginTypes extends PluginTypesBase> extends AsyncEvents {\n  public readonly app: App;\n\n  public readonly defaultSettings: ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n\n  /**\n   * Gets the current settings wrapper.\n   *\n   * @returns The current settings wrapper.\n   */\n  public get settingsWrapper(): ExtractReadonlyPluginSettingsWrapper<PluginTypes> {\n    return this.currentSettingsWrapper as ExtractReadonlyPluginSettingsWrapper<PluginTypes>;\n  }\n\n  private currentSettingsWrapper: ExtractPluginSettingsWrapper<PluginTypes>;\n\n  private lastSavedSettingsWrapper: ExtractPluginSettingsWrapper<PluginTypes>;\n  private readonly propertyNames: ExtractPluginSettingsPropertyNames<PluginTypes>[];\n  private readonly validators = new Map<ExtractPluginSettingsPropertyNames<PluginTypes>, Validator<ExtractPluginSettings<PluginTypes>>>();\n  /**\n   * Creates a new plugin settings manager.\n   *\n   * @param plugin - The plugin.\n   */\n  public constructor(public readonly plugin: ExtractPlugin<PluginTypes>) {\n    super();\n    this.app = plugin.app;\n    this.defaultSettings = this.createDefaultSettings() as ReadonlyDeep<ExtractPluginSettings<PluginTypes>>;\n    this.currentSettingsWrapper = this.createDefaultSettingsWrapper();\n    this.lastSavedSettingsWrapper = this.createDefaultSettingsWrapper();\n    this.propertyNames = getAllKeys(this.currentSettingsWrapper.settings);\n    this.registerValidators();\n  }\n\n  /**\n   * Edits the plugin settings and saves them.\n   *\n   * @param settingsEditor - The editor.\n   * @param context - The context.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async editAndSave(settingsEditor: (settings: ExtractPluginSettings<PluginTypes>) => Promisable<void>, context?: unknown): Promise<void> {\n    await this.edit(settingsEditor);\n    await this.saveToFile(context);\n  }\n\n  /**\n   * Ensures the settings are safe.\n   *\n   * It runs validation for each property and sets the default value if the validation fails.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves when the settings are safe.\n   */\n  public async ensureSafe(settings: ExtractPluginSettings<PluginTypes>): Promise<void> {\n    const validationResult = await this.validate(settings);\n    for (const propertyName of this.propertyNames) {\n      if (validationResult[propertyName]) {\n        settings[propertyName] = this.defaultSettings[propertyName];\n      }\n    }\n  }\n\n  /**\n   * Gets a safe copy of the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the safe copy of the settings.\n   */\n  public async getSafeCopy(settings: ExtractPluginSettings<PluginTypes>): Promise<ExtractPluginSettings<PluginTypes>> {\n    const safeSettings = await this.cloneSettings(settings);\n    await this.ensureSafe(safeSettings);\n    return safeSettings;\n  }\n\n  /**\n   * Loads the plugin settings from the file.\n   *\n   * @param isInitialLoad - Whether the settings are being loaded for the first time.\n   * @returns A {@link Promise} that resolves when the settings are loaded.\n   */\n  public async loadFromFile(isInitialLoad: boolean): Promise<void> {\n    const data = await this.plugin.loadData() as unknown;\n    this.lastSavedSettingsWrapper = this.createDefaultSettingsWrapper();\n    this.currentSettingsWrapper = this.createDefaultSettingsWrapper();\n\n    if (data === undefined || data === null) {\n      return;\n    }\n\n    if (typeof data !== 'object') {\n      console.error(`Invalid settings from data.json. Expected Object, got: ${typeof data}`);\n      return;\n    }\n\n    const rawRecord = data as GenericObject;\n    const parsedSettings = await this.rawRecordToSettings(rawRecord);\n    const validationResult = await this.validate(parsedSettings);\n\n    for (const propertyName of this.propertyNames) {\n      this.setPropertyImpl(propertyName, parsedSettings[propertyName], validationResult[propertyName]);\n    }\n\n    this.lastSavedSettingsWrapper = await this.cloneSettingsWrapper(this.currentSettingsWrapper);\n\n    const newRecord = await this.settingsToRawRecord(this.currentSettingsWrapper.settings);\n\n    if (!deepEqual(newRecord, data)) {\n      await this.saveToFileImpl();\n    }\n\n    await this.triggerAsync('loadSettings', this.currentSettingsWrapper, isInitialLoad);\n  }\n\n  /**\n   * Subscribes to the `loadSettings` event.\n   *\n   * @param name - Always `loadSettings`.\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  public override on(\n    name: 'loadSettings',\n    callback: (\n      loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n      isInitialLoad: boolean\n    ) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef;\n  /**\n   * Subscribes to the `saveSettings` event.\n   *\n   * @param name - Always `saveSettings`.\n   * @param callback - The callback 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  public override on(\n    name: 'saveSettings',\n    callback: (\n      newSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n      oldSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n      context: unknown\n    ) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef;\n  /**\n   * Subscribes to an event.\n   *\n   * @param name - The name of the event.\n   * @param callback - The callback 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  public override on<Args extends unknown[]>(\n    name: string,\n    callback: (...args: Args) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef {\n    return super.on(name, callback, thisArg);\n  }\n\n  /**\n   * Saves the new plugin settings.\n   *\n   * @param context - The context of the save to file operation.\n   * @returns A {@link Promise} that resolves when the settings are saved.\n   */\n  public async saveToFile(context?: unknown): Promise<void> {\n    if (deepEqual(this.lastSavedSettingsWrapper.settings, this.currentSettingsWrapper.settings)) {\n      return;\n    }\n\n    await this.saveToFileImpl();\n    await this.triggerAsync('saveSettings', this.currentSettingsWrapper, this.lastSavedSettingsWrapper, context);\n    this.lastSavedSettingsWrapper = await this.cloneSettingsWrapper(this.currentSettingsWrapper);\n  }\n\n  /**\n   * Sets the value of a property.\n   *\n   * @typeParam PropertyName - The name of the property.\n   * @param propertyName - The name of the property.\n   * @param value - The value to set.\n   * @returns A {@link Promise} that resolves to the validation message.\n   */\n  public async setProperty<PropertyName extends ExtractPluginSettingsPropertyNames<PluginTypes>>(\n    propertyName: PropertyName,\n    value: ExtractPluginSettings<PluginTypes>[PropertyName]\n  ): Promise<string> {\n    await this.edit((settings) => {\n      settings[propertyName] = value;\n    });\n    return this.currentSettingsWrapper.validationMessages[propertyName];\n  }\n\n  /**\n   * Validates the settings.\n   *\n   * @param settings - The settings.\n   * @returns A {@link Promise} that resolves to the validation result.\n   */\n  public async validate(settings: ExtractPluginSettings<PluginTypes>): Promise<ValidationResult<ExtractPluginSettings<PluginTypes>>> {\n    const result: ValidationResult<ExtractPluginSettings<PluginTypes>> = {};\n    for (const [propertyName, validator] of this.validators.entries()) {\n      const validationMessage = await validator(settings[propertyName], settings);\n      if (validationMessage) {\n        result[propertyName] = validationMessage;\n      }\n    }\n\n    return result;\n  }\n\n  protected abstract createDefaultSettings(): ExtractPluginSettings<PluginTypes>;\n\n  /**\n   * Gets the transformer.\n   *\n   * @returns The transformer.\n   */\n  protected getTransformer(): Transformer {\n    return defaultTransformer;\n  }\n\n  /**\n   * Called when the plugin settings are loaded.\n   *\n   * @param _record - The record.\n   */\n  protected async onLoadRecord(_record: GenericObject): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called when the plugin settings are saving.\n   *\n   * @param _record - The record.\n   */\n  protected async onSavingRecord(_record: GenericObject): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Registers a validator for a property.\n   *\n   * @param propertyName - The name of the property.\n   * @param validator - The validator.\n   */\n  protected registerValidator<PropertyName extends ExtractPluginSettingsPropertyNames<PluginTypes>>(\n    propertyName: PropertyName,\n    validator: Validator<ExtractPluginSettings<PluginTypes>, PropertyName>\n  ): void {\n    this.validators.set(propertyName, validator as Validator<ExtractPluginSettings<PluginTypes>>);\n  }\n\n  /**\n   * Registers the validators.\n   *\n   * This method can be overridden by subclasses to register validators for properties.\n   */\n  protected registerValidators(): void {\n    noop();\n  }\n\n  private async cloneSettings(settings: ExtractPluginSettings<PluginTypes>): Promise<ExtractPluginSettings<PluginTypes>> {\n    const record = await this.settingsToRawRecord(settings);\n    const json = JSON.stringify(record);\n    const cloneRecord = JSON.parse(json) as GenericObject;\n    return await this.rawRecordToSettings(cloneRecord);\n  }\n\n  private async cloneSettingsWrapper(\n    settingsWrapper: PluginSettingsWrapper<ExtractPluginSettings<PluginTypes>>\n  ): Promise<PluginSettingsWrapper<ExtractPluginSettings<PluginTypes>>> {\n    return {\n      safeSettings: await this.cloneSettings(settingsWrapper.safeSettings),\n      settings: await this.cloneSettings(settingsWrapper.settings),\n      validationMessages: { ...settingsWrapper.validationMessages }\n    };\n  }\n\n  private createDefaultSettingsWrapper(): PluginSettingsWrapper<ExtractPluginSettings<PluginTypes>> {\n    return {\n      safeSettings: this.createDefaultSettings(),\n      settings: this.createDefaultSettings(),\n      validationMessages: {} as Record<ExtractPluginSettingsPropertyNames<PluginTypes>, string>\n    };\n  }\n\n  private async edit(settingsEditor: (settings: ExtractPluginSettings<PluginTypes>) => Promisable<void>): Promise<void> {\n    try {\n      await settingsEditor(this.currentSettingsWrapper.settings);\n    } finally {\n      const validationResult = await this.validate(this.currentSettingsWrapper.settings);\n      for (const propertyName of this.propertyNames) {\n        const validationMessage = validationResult[propertyName] ?? '';\n        this.currentSettingsWrapper.validationMessages[propertyName] = validationMessage;\n        this.currentSettingsWrapper.safeSettings[propertyName] = validationMessage\n          ? this.defaultSettings[propertyName]\n          : this.currentSettingsWrapper.settings[propertyName];\n      }\n    }\n  }\n\n  private isValidPropertyName(prop: unknown): prop is ExtractPluginSettingsPropertyNames<PluginTypes> {\n    if (typeof prop !== 'string') {\n      return false;\n    }\n\n    return (this.propertyNames as string[]).includes(prop);\n  }\n\n  private async rawRecordToSettings(rawRecord: GenericObject): Promise<ExtractPluginSettings<PluginTypes>> {\n    await this.onLoadRecord(rawRecord);\n\n    const settings = this.createDefaultSettings();\n\n    for (const [propertyName, value] of Object.entries(rawRecord)) {\n      if (!this.isValidPropertyName(propertyName)) {\n        console.warn(`Unknown property: ${propertyName}`);\n        continue;\n      }\n\n      if (typeof value !== typeof this.defaultSettings[propertyName]) {\n        console.warn(\n          'Possible invalid value type. It might lead to an unexpected behavior of the plugin. There is also a chance it is a false-negative warning, as we are unable to determine the exact type of the value in runtime.',\n          {\n            defaultValue: this.defaultSettings[propertyName],\n            propertyName,\n            value\n          }\n        );\n      }\n\n      settings[propertyName] = value as ExtractPluginSettingsPropertyValues<PluginTypes>;\n    }\n\n    return settings;\n  }\n\n  private async saveToFileImpl(): Promise<void> {\n    await this.plugin.saveData(await this.settingsToRawRecord(this.currentSettingsWrapper.settings));\n  }\n\n  private setPropertyImpl(\n    propertyName: ExtractPluginSettingsPropertyNames<PluginTypes>,\n    value: ExtractPluginSettingsPropertyValues<PluginTypes>,\n    validationMessage?: string\n  ): void {\n    this.currentSettingsWrapper.settings[propertyName] = value;\n    this.currentSettingsWrapper.validationMessages[propertyName] = validationMessage ?? '';\n    this.currentSettingsWrapper.safeSettings[propertyName] = validationMessage ? this.defaultSettings[propertyName] : value;\n  }\n\n  private async settingsToRawRecord(settings: ExtractPluginSettings<PluginTypes>): Promise<GenericObject> {\n    const rawRecord: GenericObject = {};\n\n    for (const propertyName of this.propertyNames) {\n      rawRecord[propertyName] = settings[propertyName];\n    }\n\n    await this.onSavingRecord(rawRecord);\n\n    return this.getTransformer().transformObjectRecursively(rawRecord);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|