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.
Files changed (202) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/README.md +3 -3
  3. package/dist/lib/cjs/AsyncEvents.cjs +8 -1
  4. package/dist/lib/cjs/AsyncEvents.d.cts +10 -8
  5. package/dist/lib/cjs/Library.cjs +1 -1
  6. package/dist/lib/cjs/obsidian/Components/AsyncEventsComponent.cjs +53 -0
  7. package/dist/lib/cjs/obsidian/Components/AsyncEventsComponent.d.cts +25 -0
  8. package/dist/lib/cjs/obsidian/Components/SettingComponents/CheckboxComponent.cjs +109 -0
  9. package/dist/lib/cjs/obsidian/Components/{CheckboxComponent.d.cts → SettingComponents/CheckboxComponent.d.cts} +1 -1
  10. package/dist/lib/cjs/obsidian/Components/{DateComponent.cjs → SettingComponents/DateComponent.cjs} +2 -2
  11. package/dist/lib/cjs/obsidian/Components/{DateTimeComponent.cjs → SettingComponents/DateTimeComponent.cjs} +2 -2
  12. package/dist/lib/cjs/obsidian/Components/{EmailComponent.cjs → SettingComponents/EmailComponent.cjs} +2 -2
  13. package/dist/lib/cjs/obsidian/Components/{FileComponent.cjs → SettingComponents/FileComponent.cjs} +2 -2
  14. package/dist/lib/cjs/obsidian/Components/{MonthComponent.cjs → SettingComponents/MonthComponent.cjs} +2 -2
  15. package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleDropdownComponent.cjs +122 -0
  16. package/dist/lib/cjs/obsidian/Components/{MultipleDropdownComponent.d.cts → SettingComponents/MultipleDropdownComponent.d.cts} +5 -5
  17. package/dist/lib/cjs/obsidian/Components/{MultipleEmailComponent.cjs → SettingComponents/MultipleEmailComponent.cjs} +2 -2
  18. package/dist/lib/cjs/obsidian/Components/{MultipleEmailComponent.d.cts → SettingComponents/MultipleEmailComponent.d.cts} +3 -3
  19. package/dist/lib/cjs/obsidian/Components/{MultipleFileComponent.cjs → SettingComponents/MultipleFileComponent.cjs} +2 -2
  20. package/dist/lib/cjs/obsidian/Components/{MultipleFileComponent.d.cts → SettingComponents/MultipleFileComponent.d.cts} +4 -4
  21. package/dist/lib/cjs/obsidian/Components/SettingComponents/MultipleTextComponent.cjs +135 -0
  22. package/dist/lib/cjs/obsidian/Components/{MultipleTextComponent.d.cts → SettingComponents/MultipleTextComponent.d.cts} +6 -6
  23. package/dist/lib/cjs/obsidian/Components/{NumberComponent.cjs → SettingComponents/NumberComponent.cjs} +2 -2
  24. package/dist/lib/cjs/obsidian/Components/SettingComponents/TextBasedComponent.cjs +65 -0
  25. package/dist/lib/cjs/obsidian/Components/SettingComponents/TimeComponent.cjs +74 -0
  26. package/dist/lib/cjs/obsidian/Components/SettingComponents/TriStateCheckboxComponent.cjs +110 -0
  27. package/dist/lib/cjs/obsidian/Components/{TriStateCheckboxComponent.d.cts → SettingComponents/TriStateCheckboxComponent.d.cts} +1 -1
  28. package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedDropdownComponent.cjs +128 -0
  29. package/dist/lib/cjs/obsidian/Components/{TypedDropdownComponent.d.cts → SettingComponents/TypedDropdownComponent.d.cts} +1 -1
  30. package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.cjs +130 -0
  31. package/dist/lib/cjs/obsidian/Components/{TypedMultipleDropdownComponent.d.cts → SettingComponents/TypedMultipleDropdownComponent.d.cts} +5 -5
  32. package/dist/lib/cjs/obsidian/Components/{TypedRangeTextComponent.cjs → SettingComponents/TypedRangeTextComponent.cjs} +1 -1
  33. package/dist/lib/cjs/obsidian/Components/SettingComponents/TypedTextComponent.cjs +155 -0
  34. package/dist/lib/cjs/obsidian/Components/{TypedTextComponent.d.cts → SettingComponents/TypedTextComponent.d.cts} +2 -2
  35. package/dist/lib/cjs/obsidian/Components/{UrlComponent.cjs → SettingComponents/UrlComponent.cjs} +2 -2
  36. package/dist/lib/cjs/obsidian/Components/{ValidatorComponent.cjs → SettingComponents/ValidatorComponent.cjs} +1 -1
  37. package/dist/lib/cjs/obsidian/Components/{ValidatorComponent.d.cts → SettingComponents/ValidatorComponent.d.cts} +1 -1
  38. package/dist/lib/cjs/obsidian/Components/{ValueComponentWithChangeTracking.cjs → SettingComponents/ValueComponentWithChangeTracking.cjs} +1 -1
  39. package/dist/lib/cjs/obsidian/Components/{WeekComponent.cjs → SettingComponents/WeekComponent.cjs} +2 -2
  40. package/dist/lib/cjs/obsidian/Components/SettingComponents/index.cjs +109 -0
  41. package/dist/lib/cjs/obsidian/Components/SettingComponents/index.d.cts +22 -0
  42. package/dist/lib/cjs/obsidian/Components/index.cjs +7 -67
  43. package/dist/lib/cjs/obsidian/Components/index.d.cts +2 -22
  44. package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +25 -31
  45. package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +15 -23
  46. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +18 -5
  47. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +21 -1
  48. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +61 -12
  49. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.d.cts +18 -5
  50. package/dist/lib/cjs/obsidian/SettingEx.cjs +18 -18
  51. package/dist/lib/cjs/obsidian/SettingEx.d.cts +17 -17
  52. package/dist/lib/esm/AsyncEvents.d.mts +10 -8
  53. package/dist/lib/esm/AsyncEvents.mjs +8 -1
  54. package/dist/lib/esm/Library.mjs +1 -1
  55. package/dist/lib/esm/obsidian/Components/AsyncEventsComponent.d.mts +25 -0
  56. package/dist/lib/esm/obsidian/Components/AsyncEventsComponent.mjs +28 -0
  57. package/dist/lib/esm/obsidian/Components/{CheckboxComponent.d.mts → SettingComponents/CheckboxComponent.d.mts} +1 -1
  58. package/dist/lib/esm/obsidian/Components/SettingComponents/CheckboxComponent.mjs +85 -0
  59. package/dist/lib/esm/obsidian/Components/SettingComponents/DateComponent.mjs +43 -0
  60. package/dist/lib/esm/obsidian/Components/SettingComponents/DateTimeComponent.mjs +43 -0
  61. package/dist/lib/esm/obsidian/Components/SettingComponents/EmailComponent.mjs +32 -0
  62. package/dist/lib/esm/obsidian/Components/SettingComponents/FileComponent.mjs +48 -0
  63. package/dist/lib/esm/obsidian/Components/SettingComponents/MonthComponent.mjs +51 -0
  64. package/dist/lib/esm/obsidian/Components/{MultipleDropdownComponent.d.mts → SettingComponents/MultipleDropdownComponent.d.mts} +5 -5
  65. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleDropdownComponent.mjs +101 -0
  66. package/dist/lib/esm/obsidian/Components/{MultipleEmailComponent.d.mts → SettingComponents/MultipleEmailComponent.d.mts} +3 -3
  67. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleEmailComponent.mjs +42 -0
  68. package/dist/lib/esm/obsidian/Components/{MultipleFileComponent.d.mts → SettingComponents/MultipleFileComponent.d.mts} +4 -4
  69. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleFileComponent.mjs +49 -0
  70. package/dist/lib/esm/obsidian/Components/{MultipleTextComponent.d.mts → SettingComponents/MultipleTextComponent.d.mts} +6 -6
  71. package/dist/lib/esm/obsidian/Components/SettingComponents/MultipleTextComponent.mjs +114 -0
  72. package/dist/lib/esm/obsidian/Components/SettingComponents/NumberComponent.mjs +32 -0
  73. package/dist/lib/esm/obsidian/Components/SettingComponents/TextBasedComponent.mjs +41 -0
  74. package/dist/lib/esm/obsidian/Components/SettingComponents/TimeComponent.mjs +53 -0
  75. package/dist/lib/esm/obsidian/Components/{TriStateCheckboxComponent.d.mts → SettingComponents/TriStateCheckboxComponent.d.mts} +1 -1
  76. package/dist/lib/esm/obsidian/Components/SettingComponents/TriStateCheckboxComponent.mjs +86 -0
  77. package/dist/lib/esm/obsidian/Components/{TypedDropdownComponent.d.mts → SettingComponents/TypedDropdownComponent.d.mts} +1 -1
  78. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedDropdownComponent.mjs +107 -0
  79. package/dist/lib/esm/obsidian/Components/{TypedMultipleDropdownComponent.d.mts → SettingComponents/TypedMultipleDropdownComponent.d.mts} +5 -5
  80. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.mjs +106 -0
  81. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedRangeTextComponent.mjs +44 -0
  82. package/dist/lib/esm/obsidian/Components/{TypedTextComponent.d.mts → SettingComponents/TypedTextComponent.d.mts} +2 -2
  83. package/dist/lib/esm/obsidian/Components/SettingComponents/TypedTextComponent.mjs +134 -0
  84. package/dist/lib/esm/obsidian/Components/SettingComponents/UrlComponent.mjs +32 -0
  85. package/dist/lib/esm/obsidian/Components/{ValidatorComponent.d.mts → SettingComponents/ValidatorComponent.d.mts} +1 -1
  86. package/dist/lib/esm/obsidian/Components/SettingComponents/ValidatorComponent.mjs +47 -0
  87. package/dist/lib/esm/obsidian/Components/SettingComponents/WeekComponent.mjs +51 -0
  88. package/dist/lib/esm/obsidian/Components/SettingComponents/index.d.mts +22 -0
  89. package/dist/lib/esm/obsidian/Components/SettingComponents/index.mjs +54 -0
  90. package/dist/lib/esm/obsidian/Components/index.d.mts +2 -22
  91. package/dist/lib/esm/obsidian/Components/index.mjs +5 -45
  92. package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +15 -23
  93. package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +25 -31
  94. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +21 -1
  95. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +18 -5
  96. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.d.mts +18 -5
  97. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +65 -13
  98. package/dist/lib/esm/obsidian/SettingEx.d.mts +17 -17
  99. package/dist/lib/esm/obsidian/SettingEx.mjs +18 -18
  100. package/obsidian/Components/AsyncEventsComponent/package.json +6 -0
  101. package/obsidian/Components/SettingComponents/CheckboxComponent/package.json +6 -0
  102. package/obsidian/Components/SettingComponents/DateComponent/package.json +6 -0
  103. package/obsidian/Components/SettingComponents/DateTimeComponent/package.json +6 -0
  104. package/obsidian/Components/SettingComponents/EmailComponent/package.json +6 -0
  105. package/obsidian/Components/SettingComponents/FileComponent/package.json +6 -0
  106. package/obsidian/Components/SettingComponents/MonthComponent/package.json +6 -0
  107. package/obsidian/Components/SettingComponents/MultipleDropdownComponent/package.json +6 -0
  108. package/obsidian/Components/SettingComponents/MultipleEmailComponent/package.json +6 -0
  109. package/obsidian/Components/SettingComponents/MultipleFileComponent/package.json +6 -0
  110. package/obsidian/Components/SettingComponents/MultipleTextComponent/package.json +6 -0
  111. package/obsidian/Components/SettingComponents/NumberComponent/package.json +6 -0
  112. package/obsidian/Components/SettingComponents/TextBasedComponent/package.json +6 -0
  113. package/obsidian/Components/SettingComponents/TimeComponent/package.json +6 -0
  114. package/obsidian/Components/SettingComponents/TriStateCheckboxComponent/package.json +6 -0
  115. package/obsidian/Components/SettingComponents/TypedDropdownComponent/package.json +6 -0
  116. package/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent/package.json +6 -0
  117. package/obsidian/Components/SettingComponents/TypedRangeTextComponent/package.json +6 -0
  118. package/obsidian/Components/SettingComponents/TypedTextComponent/package.json +6 -0
  119. package/obsidian/Components/SettingComponents/UrlComponent/package.json +6 -0
  120. package/obsidian/Components/SettingComponents/ValidatorComponent/package.json +6 -0
  121. package/obsidian/Components/SettingComponents/ValueComponentWithChangeTracking/package.json +6 -0
  122. package/obsidian/Components/SettingComponents/WeekComponent/package.json +6 -0
  123. package/obsidian/Components/SettingComponents/index/package.json +6 -0
  124. package/obsidian/Components/SettingComponents/package.json +6 -0
  125. package/package.json +21 -1
  126. package/dist/lib/cjs/obsidian/Components/CheckboxComponent.cjs +0 -109
  127. package/dist/lib/cjs/obsidian/Components/MultipleDropdownComponent.cjs +0 -122
  128. package/dist/lib/cjs/obsidian/Components/MultipleTextComponent.cjs +0 -135
  129. package/dist/lib/cjs/obsidian/Components/TextBasedComponent.cjs +0 -65
  130. package/dist/lib/cjs/obsidian/Components/TimeComponent.cjs +0 -74
  131. package/dist/lib/cjs/obsidian/Components/TriStateCheckboxComponent.cjs +0 -110
  132. package/dist/lib/cjs/obsidian/Components/TypedDropdownComponent.cjs +0 -128
  133. package/dist/lib/cjs/obsidian/Components/TypedMultipleDropdownComponent.cjs +0 -130
  134. package/dist/lib/cjs/obsidian/Components/TypedTextComponent.cjs +0 -155
  135. package/dist/lib/esm/obsidian/Components/CheckboxComponent.mjs +0 -85
  136. package/dist/lib/esm/obsidian/Components/DateComponent.mjs +0 -43
  137. package/dist/lib/esm/obsidian/Components/DateTimeComponent.mjs +0 -43
  138. package/dist/lib/esm/obsidian/Components/EmailComponent.mjs +0 -32
  139. package/dist/lib/esm/obsidian/Components/FileComponent.mjs +0 -48
  140. package/dist/lib/esm/obsidian/Components/MonthComponent.mjs +0 -51
  141. package/dist/lib/esm/obsidian/Components/MultipleDropdownComponent.mjs +0 -101
  142. package/dist/lib/esm/obsidian/Components/MultipleEmailComponent.mjs +0 -42
  143. package/dist/lib/esm/obsidian/Components/MultipleFileComponent.mjs +0 -49
  144. package/dist/lib/esm/obsidian/Components/MultipleTextComponent.mjs +0 -114
  145. package/dist/lib/esm/obsidian/Components/NumberComponent.mjs +0 -32
  146. package/dist/lib/esm/obsidian/Components/TextBasedComponent.mjs +0 -41
  147. package/dist/lib/esm/obsidian/Components/TimeComponent.mjs +0 -53
  148. package/dist/lib/esm/obsidian/Components/TriStateCheckboxComponent.mjs +0 -86
  149. package/dist/lib/esm/obsidian/Components/TypedDropdownComponent.mjs +0 -107
  150. package/dist/lib/esm/obsidian/Components/TypedMultipleDropdownComponent.mjs +0 -106
  151. package/dist/lib/esm/obsidian/Components/TypedRangeTextComponent.mjs +0 -44
  152. package/dist/lib/esm/obsidian/Components/TypedTextComponent.mjs +0 -134
  153. package/dist/lib/esm/obsidian/Components/UrlComponent.mjs +0 -32
  154. package/dist/lib/esm/obsidian/Components/ValidatorComponent.mjs +0 -47
  155. package/dist/lib/esm/obsidian/Components/WeekComponent.mjs +0 -51
  156. package/obsidian/Components/CheckboxComponent/package.json +0 -6
  157. package/obsidian/Components/DateComponent/package.json +0 -6
  158. package/obsidian/Components/DateTimeComponent/package.json +0 -6
  159. package/obsidian/Components/EmailComponent/package.json +0 -6
  160. package/obsidian/Components/FileComponent/package.json +0 -6
  161. package/obsidian/Components/MonthComponent/package.json +0 -6
  162. package/obsidian/Components/MultipleDropdownComponent/package.json +0 -6
  163. package/obsidian/Components/MultipleEmailComponent/package.json +0 -6
  164. package/obsidian/Components/MultipleFileComponent/package.json +0 -6
  165. package/obsidian/Components/MultipleTextComponent/package.json +0 -6
  166. package/obsidian/Components/NumberComponent/package.json +0 -6
  167. package/obsidian/Components/TextBasedComponent/package.json +0 -6
  168. package/obsidian/Components/TimeComponent/package.json +0 -6
  169. package/obsidian/Components/TriStateCheckboxComponent/package.json +0 -6
  170. package/obsidian/Components/TypedDropdownComponent/package.json +0 -6
  171. package/obsidian/Components/TypedMultipleDropdownComponent/package.json +0 -6
  172. package/obsidian/Components/TypedRangeTextComponent/package.json +0 -6
  173. package/obsidian/Components/TypedTextComponent/package.json +0 -6
  174. package/obsidian/Components/UrlComponent/package.json +0 -6
  175. package/obsidian/Components/ValidatorComponent/package.json +0 -6
  176. package/obsidian/Components/ValueComponentWithChangeTracking/package.json +0 -6
  177. package/obsidian/Components/WeekComponent/package.json +0 -6
  178. /package/dist/lib/cjs/obsidian/Components/{DateComponent.d.cts → SettingComponents/DateComponent.d.cts} +0 -0
  179. /package/dist/lib/cjs/obsidian/Components/{DateTimeComponent.d.cts → SettingComponents/DateTimeComponent.d.cts} +0 -0
  180. /package/dist/lib/cjs/obsidian/Components/{EmailComponent.d.cts → SettingComponents/EmailComponent.d.cts} +0 -0
  181. /package/dist/lib/cjs/obsidian/Components/{FileComponent.d.cts → SettingComponents/FileComponent.d.cts} +0 -0
  182. /package/dist/lib/cjs/obsidian/Components/{MonthComponent.d.cts → SettingComponents/MonthComponent.d.cts} +0 -0
  183. /package/dist/lib/cjs/obsidian/Components/{NumberComponent.d.cts → SettingComponents/NumberComponent.d.cts} +0 -0
  184. /package/dist/lib/cjs/obsidian/Components/{TextBasedComponent.d.cts → SettingComponents/TextBasedComponent.d.cts} +0 -0
  185. /package/dist/lib/cjs/obsidian/Components/{TimeComponent.d.cts → SettingComponents/TimeComponent.d.cts} +0 -0
  186. /package/dist/lib/cjs/obsidian/Components/{TypedRangeTextComponent.d.cts → SettingComponents/TypedRangeTextComponent.d.cts} +0 -0
  187. /package/dist/lib/cjs/obsidian/Components/{UrlComponent.d.cts → SettingComponents/UrlComponent.d.cts} +0 -0
  188. /package/dist/lib/cjs/obsidian/Components/{ValueComponentWithChangeTracking.d.cts → SettingComponents/ValueComponentWithChangeTracking.d.cts} +0 -0
  189. /package/dist/lib/cjs/obsidian/Components/{WeekComponent.d.cts → SettingComponents/WeekComponent.d.cts} +0 -0
  190. /package/dist/lib/esm/obsidian/Components/{DateComponent.d.mts → SettingComponents/DateComponent.d.mts} +0 -0
  191. /package/dist/lib/esm/obsidian/Components/{DateTimeComponent.d.mts → SettingComponents/DateTimeComponent.d.mts} +0 -0
  192. /package/dist/lib/esm/obsidian/Components/{EmailComponent.d.mts → SettingComponents/EmailComponent.d.mts} +0 -0
  193. /package/dist/lib/esm/obsidian/Components/{FileComponent.d.mts → SettingComponents/FileComponent.d.mts} +0 -0
  194. /package/dist/lib/esm/obsidian/Components/{MonthComponent.d.mts → SettingComponents/MonthComponent.d.mts} +0 -0
  195. /package/dist/lib/esm/obsidian/Components/{NumberComponent.d.mts → SettingComponents/NumberComponent.d.mts} +0 -0
  196. /package/dist/lib/esm/obsidian/Components/{TextBasedComponent.d.mts → SettingComponents/TextBasedComponent.d.mts} +0 -0
  197. /package/dist/lib/esm/obsidian/Components/{TimeComponent.d.mts → SettingComponents/TimeComponent.d.mts} +0 -0
  198. /package/dist/lib/esm/obsidian/Components/{TypedRangeTextComponent.d.mts → SettingComponents/TypedRangeTextComponent.d.mts} +0 -0
  199. /package/dist/lib/esm/obsidian/Components/{UrlComponent.d.mts → SettingComponents/UrlComponent.d.mts} +0 -0
  200. /package/dist/lib/esm/obsidian/Components/{ValueComponentWithChangeTracking.d.mts → SettingComponents/ValueComponentWithChangeTracking.d.mts} +0 -0
  201. /package/dist/lib/esm/obsidian/Components/{ValueComponentWithChangeTracking.mjs → SettingComponents/ValueComponentWithChangeTracking.mjs} +0 -0
  202. /package/dist/lib/esm/obsidian/Components/{WeekComponent.d.mts → SettingComponents/WeekComponent.d.mts} +0 -0
@@ -4,12 +4,12 @@
4
4
  * This module defines a base class for creating plugin setting tabs in Obsidian.
5
5
  * It provides a utility method to bind value components to plugin settings and handle changes.
6
6
  */
7
- import type { ConditionalKeys, Promisable } from 'type-fest';
7
+ import type { ConditionalKeys, Promisable, ReadonlyDeep } from 'type-fest';
8
8
  import { PluginSettingTab } from 'obsidian';
9
9
  import type { StringKeys } from '../../Type.mjs';
10
- import type { ValueComponentWithChangeTracking } from '../Components/ValueComponentWithChangeTracking.mjs';
10
+ import type { ValueComponentWithChangeTracking } from '../Components/SettingComponents/ValueComponentWithChangeTracking.mjs';
11
11
  import type { ValidationMessageHolder } from '../ValidationMessage.mjs';
12
- import type { ExtractPlugin, ExtractPluginSettings, PluginTypesBase } from './PluginTypesBase.mjs';
12
+ import type { ExtractPlugin, ExtractPluginSettings, ExtractReadonlyPluginSettingsWrapper, PluginTypesBase } from './PluginTypesBase.mjs';
13
13
  /**
14
14
  * Options for binding a value component to a plugin setting.
15
15
  */
@@ -17,7 +17,7 @@ export interface BindOptions<T> {
17
17
  /**
18
18
  * A callback function that is called when the value of the component changes.
19
19
  */
20
- onChanged?(newValue: T | undefined, oldValue: T): Promisable<void>;
20
+ onChanged?(newValue: ReadonlyDeep<T>, oldValue: ReadonlyDeep<T>): Promisable<void>;
21
21
  /**
22
22
  * Whether to reset the setting when the component value is empty. Default is `true`.
23
23
  * Applicable only to text-based components.
@@ -45,7 +45,7 @@ export interface BindOptionsExtended<PluginSettings extends object, UIValue, Pro
45
45
  * @param pluginSettingsValue - The value of the property in the plugin settings.
46
46
  * @returns The value to set on the UI component.
47
47
  */
48
- pluginSettingsToComponentValueConverter: (pluginSettingsValue: PluginSettings[PropertyName]) => UIValue;
48
+ pluginSettingsToComponentValueConverter: (pluginSettingsValue: ReadonlyDeep<PluginSettings[PropertyName]>) => UIValue;
49
49
  }
50
50
  /**
51
51
  * Base class for creating plugin settings tabs in Obsidian.
@@ -68,6 +68,8 @@ export declare abstract class PluginSettingsTabBase<PluginTypes extends PluginTy
68
68
  */
69
69
  protected get saveSettingsDebounceTimeoutInMilliseconds(): number;
70
70
  private _isOpen;
71
+ private readonly asyncEvents;
72
+ private readonly asyncEventsComponent;
71
73
  private saveSettingsDebounced;
72
74
  private get pluginSettings();
73
75
  /**
@@ -111,4 +113,15 @@ export declare abstract class PluginSettingsTabBase<PluginTypes extends PluginTy
111
113
  * Shows the plugin settings tab.
112
114
  */
113
115
  show(): void;
116
+ /**
117
+ * Called when the plugin settings are loaded.
118
+ *
119
+ * @param _loadedSettings - The loaded settings.
120
+ * @param _isInitialLoad - Whether the settings are being loaded for the first time.
121
+ * @returns A {@link Promise} that resolves when the settings are loaded.
122
+ */
123
+ protected onLoadSettings(_loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _isInitialLoad: boolean): Promise<void>;
124
+ private on;
125
+ private onSaveSettings;
126
+ private refresh;
114
127
  }
@@ -14,12 +14,18 @@ import {
14
14
  convertAsyncToSync,
15
15
  invokeAsyncSafely
16
16
  } from "../../Async.mjs";
17
+ import { AsyncEvents } from "../../AsyncEvents.mjs";
17
18
  import { CssClass } from "../../CssClass.mjs";
18
- import { noop } from "../../Function.mjs";
19
- import { getTextBasedComponentValue } from "../Components/TextBasedComponent.mjs";
20
- import { getValidatorComponent } from "../Components/ValidatorComponent.mjs";
19
+ import {
20
+ noop,
21
+ noopAsync
22
+ } from "../../Function.mjs";
23
+ import { AsyncEventsComponent } from "../Components/AsyncEventsComponent.mjs";
24
+ import { getTextBasedComponentValue } from "../Components/SettingComponents/TextBasedComponent.mjs";
25
+ import { getValidatorComponent } from "../Components/SettingComponents/ValidatorComponent.mjs";
21
26
  import { isValidationMessageHolder } from "../ValidationMessage.mjs";
22
27
  import { getPluginId } from "./PluginId.mjs";
28
+ const PLUGIN_SETTINGS_TAB_SYMBOL = Symbol("pluginSettingsTab");
23
29
  class PluginSettingsTabBase extends PluginSettingTab {
24
30
  /**
25
31
  * Creates a new plugin settings tab.
@@ -30,7 +36,12 @@ class PluginSettingsTabBase extends PluginSettingTab {
30
36
  super(plugin.app, plugin);
31
37
  this.plugin = plugin;
32
38
  this.containerEl.addClass(CssClass.LibraryName, getPluginId(), CssClass.PluginSettingsTab);
33
- this.saveSettingsDebounced = debounce(convertAsyncToSync(() => this.plugin.settingsManager.saveToFile()), this.saveSettingsDebounceTimeoutInMilliseconds);
39
+ this.saveSettingsDebounced = debounce(
40
+ convertAsyncToSync(() => this.plugin.settingsManager.saveToFile(PLUGIN_SETTINGS_TAB_SYMBOL)),
41
+ this.saveSettingsDebounceTimeoutInMilliseconds
42
+ );
43
+ this.asyncEventsComponent = new AsyncEventsComponent();
44
+ this.asyncEvents = new AsyncEvents();
34
45
  }
35
46
  /**
36
47
  * Whether the plugin settings tab is open.
@@ -50,6 +61,8 @@ class PluginSettingsTabBase extends PluginSettingTab {
50
61
  return DEFAULT;
51
62
  }
52
63
  _isOpen = false;
64
+ asyncEvents;
65
+ asyncEventsComponent;
53
66
  saveSettingsDebounced;
54
67
  get pluginSettings() {
55
68
  return this.plugin.settingsManager.settingsWrapper.settings;
@@ -67,22 +80,28 @@ class PluginSettingsTabBase extends PluginSettingTab {
67
80
  */
68
81
  bind(valueComponent, propertyName, options) {
69
82
  const DEFAULT_OPTIONS = {
70
- componentToPluginSettingsValueConverter: (value2) => value2,
83
+ componentToPluginSettingsValueConverter: (value) => value,
71
84
  onChanged: noop,
72
- pluginSettingsToComponentValueConverter: (value2) => value2,
85
+ pluginSettingsToComponentValueConverter: (value) => value,
73
86
  shouldResetSettingWhenComponentIsEmpty: true,
74
87
  shouldShowValidationMessage: true
75
88
  };
76
89
  const optionsExt = { ...DEFAULT_OPTIONS, ...options };
77
90
  const validatorElement = getValidatorComponent(valueComponent)?.validatorEl;
78
91
  const textBasedComponent = getTextBasedComponentValue(valueComponent);
79
- const value = this.pluginSettings[propertyName];
92
+ const readonlyValue = this.pluginSettings[propertyName];
80
93
  const defaultValue = this.plugin.settingsManager.defaultSettings[propertyName];
81
- textBasedComponent?.setPlaceholderValue(optionsExt.pluginSettingsToComponentValueConverter(value));
82
- if (value === defaultValue && textBasedComponent && optionsExt.shouldResetSettingWhenComponentIsEmpty) {
94
+ textBasedComponent?.setPlaceholderValue(optionsExt.pluginSettingsToComponentValueConverter(defaultValue));
95
+ this.asyncEventsComponent.registerAsyncEvent(this.on("validationMessageChanged", (anotherPropertyName, validationMessage) => {
96
+ if (propertyName !== anotherPropertyName) {
97
+ return;
98
+ }
99
+ updateValidatorElement(validationMessage);
100
+ }));
101
+ if (readonlyValue === defaultValue && textBasedComponent && optionsExt.shouldResetSettingWhenComponentIsEmpty) {
83
102
  textBasedComponent.empty();
84
103
  } else {
85
- valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(value));
104
+ valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(readonlyValue));
86
105
  }
87
106
  valueComponent.onChange(async (uiValue) => {
88
107
  const oldValue = this.pluginSettings[propertyName];
@@ -137,15 +156,21 @@ class PluginSettingsTabBase extends PluginSettingTab {
137
156
  */
138
157
  display() {
139
158
  this._isOpen = true;
159
+ this.asyncEventsComponent.load();
160
+ this.asyncEventsComponent.registerAsyncEvent(this.plugin.settingsManager.on("loadSettings", this.onLoadSettings.bind(this)));
161
+ this.asyncEventsComponent.registerAsyncEvent(this.plugin.settingsManager.on("saveSettings", this.onSaveSettings.bind(this)));
140
162
  }
141
163
  /**
142
164
  * Hides the plugin settings tab.
143
165
  */
144
166
  hide() {
145
167
  super.hide();
146
- this._isOpen = false;
147
168
  this.saveSettingsDebounced.cancel();
148
- invokeAsyncSafely(() => this.plugin.settingsManager.saveToFile());
169
+ this.containerEl.empty();
170
+ this._isOpen = false;
171
+ this.asyncEventsComponent.unload();
172
+ this.asyncEventsComponent.load();
173
+ invokeAsyncSafely(() => this.plugin.settingsManager.saveToFile(PLUGIN_SETTINGS_TAB_SYMBOL));
149
174
  }
150
175
  /**
151
176
  * Shows the plugin settings tab.
@@ -153,8 +178,35 @@ class PluginSettingsTabBase extends PluginSettingTab {
153
178
  show() {
154
179
  this.app.setting.openTab(this);
155
180
  }
181
+ /**
182
+ * Called when the plugin settings are loaded.
183
+ *
184
+ * @param _loadedSettings - The loaded settings.
185
+ * @param _isInitialLoad - Whether the settings are being loaded for the first time.
186
+ * @returns A {@link Promise} that resolves when the settings are loaded.
187
+ */
188
+ async onLoadSettings(_loadedSettings, _isInitialLoad) {
189
+ this.refresh();
190
+ await noopAsync();
191
+ }
192
+ on(name, callback, thisArg) {
193
+ return this.asyncEvents.on(name, callback, thisArg);
194
+ }
195
+ async onSaveSettings(newSettings, _oldSettings, context) {
196
+ if (context === PLUGIN_SETTINGS_TAB_SYMBOL) {
197
+ for (const [propertyName, validationMessage] of Object.entries(newSettings.validationMessages)) {
198
+ await this.asyncEvents.triggerAsync("validationMessageChanged", propertyName, validationMessage);
199
+ }
200
+ return;
201
+ }
202
+ this.refresh();
203
+ }
204
+ refresh() {
205
+ this.containerEl.empty();
206
+ this.display();
207
+ }
156
208
  }
157
209
  export {
158
210
  PluginSettingsTabBase
159
211
  };
160
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsTabBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a base class for creating plugin setting tabs in Obsidian.\n * It provides a utility method to bind value components to plugin settings and handle changes.\n */\n\nimport type { Debouncer } from 'obsidian';\nimport type {\n  ConditionalKeys,\n  Promisable\n} from 'type-fest';\n\nimport {\n  debounce,\n  PluginSettingTab,\n  setTooltip\n} from 'obsidian';\n\nimport type { StringKeys } from '../../Type.ts';\nimport type { ValueComponentWithChangeTracking } from '../Components/ValueComponentWithChangeTracking.ts';\nimport type { ValidationMessageHolder } from '../ValidationMessage.ts';\nimport type {\n  ExtractPlugin,\n  ExtractPluginSettings,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../Async.ts';\nimport { CssClass } from '../../CssClass.ts';\nimport { noop } from '../../Function.ts';\nimport { getTextBasedComponentValue } from '../Components/TextBasedComponent.ts';\nimport { getValidatorComponent } from '../Components/ValidatorComponent.ts';\nimport { isValidationMessageHolder } from '../ValidationMessage.ts';\nimport { getPluginId } from './PluginId.ts';\n\n/**\n * Options for binding a value component to a plugin setting.\n */\nexport interface BindOptions<T> {\n  /**\n   * A callback function that is called when the value of the component changes.\n   */\n  onChanged?(newValue: T | undefined, oldValue: T): Promisable<void>;\n\n  /**\n   * Whether to reset the setting when the component value is empty. Default is `true`.\n   * Applicable only to text-based components.\n   */\n  shouldResetSettingWhenComponentIsEmpty?: boolean;\n\n  /**\n   * Whether to show the validation message when the component value is invalid. Default is `true`.\n   */\n  shouldShowValidationMessage?: boolean;\n}\n\n/**\n * Extended options for binding a value component to a plugin setting.\n */\nexport interface BindOptionsExtended<\n  PluginSettings extends object,\n  UIValue,\n  PropertyName extends StringKeys<PluginSettings>\n> extends BindOptions<PluginSettings[PropertyName]> {\n  /**\n   * Converts the UI component's value back to the plugin settings value.\n   *\n   * @param uiValue - The value of the UI component.\n   * @returns The value to set on the plugin settings.\n   */\n  componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[PropertyName] | ValidationMessageHolder;\n\n  /**\n   * Converts the plugin settings value to the value used by the UI component.\n   *\n   * @param pluginSettingsValue - The value of the property in the plugin settings.\n   * @returns The value to set on the UI component.\n   */\n  pluginSettingsToComponentValueConverter: (pluginSettingsValue: PluginSettings[PropertyName]) => UIValue;\n}\n\n/**\n * Base class for creating plugin settings tabs in Obsidian.\n * Provides a method for binding value components to plugin settings and handling changes.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginSettingsTabBase<PluginTypes extends PluginTypesBase> extends PluginSettingTab {\n  /**\n   * Whether the plugin settings tab is open.\n   *\n   * @returns Whether the plugin settings tab is open.\n   */\n  public get isOpen(): boolean {\n    return this._isOpen;\n  }\n\n  /**\n   * The debounce timeout for saving settings.\n   *\n   * @returns The debounce timeout for saving settings.\n   */\n  protected get saveSettingsDebounceTimeoutInMilliseconds(): number {\n    const DEFAULT = 2_000;\n    return DEFAULT;\n  }\n\n  private _isOpen = false;\n\n  private saveSettingsDebounced: Debouncer<[], void>;\n\n  private get pluginSettings(): ExtractPluginSettings<PluginTypes> {\n    return this.plugin.settingsManager.settingsWrapper.settings as ExtractPluginSettings<PluginTypes>;\n  }\n\n  /**\n   * Creates a new plugin settings tab.\n   *\n   * @param plugin - The plugin.\n   */\n  public constructor(public override plugin: ExtractPlugin<PluginTypes>) {\n    super(plugin.app, plugin);\n    this.containerEl.addClass(CssClass.LibraryName, getPluginId(), CssClass.PluginSettingsTab);\n    this.saveSettingsDebounced = debounce(convertAsyncToSync(() => this.plugin.settingsManager.saveToFile()), this.saveSettingsDebounceTimeoutInMilliseconds);\n  }\n\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: ConditionalKeys<ExtractPluginSettings<PluginTypes>, UIValue>,\n    options?: BindOptions<UIValue>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options: BindOptionsExtended<ExtractPluginSettings<PluginTypes>, UIValue, PropertyName>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options?: BindOptions<ExtractPluginSettings<PluginTypes>[PropertyName]>\n  ): TValueComponent {\n    type PluginSettings = ExtractPluginSettings<PluginTypes>;\n    type PropertyType = PluginSettings[PropertyName];\n    const DEFAULT_OPTIONS: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = {\n      componentToPluginSettingsValueConverter: (value: UIValue): PropertyType => value as PropertyType,\n      onChanged: noop,\n      pluginSettingsToComponentValueConverter: (value: PropertyType): UIValue => value as UIValue,\n      shouldResetSettingWhenComponentIsEmpty: true,\n      shouldShowValidationMessage: true\n    };\n\n    const optionsExt: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = { ...DEFAULT_OPTIONS, ...options };\n\n    const validatorElement = getValidatorComponent(valueComponent)?.validatorEl;\n\n    const textBasedComponent = getTextBasedComponentValue(valueComponent);\n\n    const value = this.pluginSettings[propertyName] as PropertyType;\n    const defaultValue = (this.plugin.settingsManager.defaultSettings as PluginSettings)[propertyName] as PropertyType;\n    textBasedComponent?.setPlaceholderValue(optionsExt.pluginSettingsToComponentValueConverter(value));\n\n    if (value === defaultValue && textBasedComponent && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n      textBasedComponent.empty();\n    } else {\n      valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(value));\n    }\n\n    valueComponent.onChange(async (uiValue) => {\n      const oldValue = this.pluginSettings[propertyName];\n      let newValue: PropertyType | undefined = undefined;\n      let validationMessage: string;\n      if (textBasedComponent?.isEmpty() && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n        newValue = defaultValue;\n        validationMessage = '';\n      } else {\n        const convertedValue = optionsExt.componentToPluginSettingsValueConverter(uiValue);\n        if (isValidationMessageHolder(convertedValue)) {\n          validationMessage = convertedValue.validationMessage;\n        } else {\n          newValue = convertedValue;\n          validationMessage = await this.plugin.settingsManager.setProperty(propertyName, newValue);\n        }\n      }\n      updateValidatorElement(validationMessage);\n      if (newValue !== undefined) {\n        await optionsExt.onChanged(newValue, oldValue);\n      }\n      this.saveSettingsDebounced();\n    });\n\n    validatorElement?.addEventListener('focus', () => {\n      updateValidatorElement();\n    });\n    validatorElement?.addEventListener('blur', () => {\n      updateValidatorElement();\n    });\n\n    updateValidatorElement();\n    return valueComponent;\n\n    function updateValidatorElement(validationMessage?: string): void {\n      if (!validatorElement) {\n        return;\n      }\n\n      if (validationMessage === '') {\n        validatorElement.setCustomValidity('');\n        validatorElement.checkValidity();\n        validationMessage = validatorElement.validationMessage;\n      }\n\n      if (validationMessage !== undefined) {\n        validatorElement.setCustomValidity(validationMessage);\n        setTooltip(validatorElement, validationMessage);\n      }\n      if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {\n        validatorElement.reportValidity();\n      }\n    }\n  }\n\n  /**\n   * Renders the plugin settings tab.\n   */\n  public override display(): void {\n    this._isOpen = true;\n  }\n\n  /**\n   * Hides the plugin settings tab.\n   */\n  public override hide(): void {\n    super.hide();\n    this._isOpen = false;\n    this.saveSettingsDebounced.cancel();\n    invokeAsyncSafely(() => this.plugin.settingsManager.saveToFile());\n  }\n\n  /**\n   * Shows the plugin settings tab.\n   */\n  public show(): void {\n    this.app.setting.openTab(this);\n  }\n}\n"],
  "mappings": "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",
  "names": ["value"]
}

212
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Plugin/PluginSettingsTabBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a base class for creating plugin setting tabs in Obsidian.\n * It provides a utility method to bind value components to plugin settings and handle changes.\n */\n\nimport type { Debouncer } from 'obsidian';\nimport type {\n  ConditionalKeys,\n  Promisable,\n  ReadonlyDeep\n} from 'type-fest';\n\nimport {\n  debounce,\n  PluginSettingTab,\n  setTooltip\n} from 'obsidian';\n\nimport type { AsyncEventRef } from '../../AsyncEvents.ts';\nimport type { StringKeys } from '../../Type.ts';\nimport type { ValueComponentWithChangeTracking } from '../Components/SettingComponents/ValueComponentWithChangeTracking.ts';\nimport type { ValidationMessageHolder } from '../ValidationMessage.ts';\nimport type {\n  ExtractPlugin,\n  ExtractPluginSettings,\n  ExtractReadonlyPluginSettingsWrapper,\n  PluginTypesBase\n} from './PluginTypesBase.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../Async.ts';\nimport { AsyncEvents } from '../../AsyncEvents.ts';\nimport { CssClass } from '../../CssClass.ts';\nimport {\n  noop,\n  noopAsync\n} from '../../Function.ts';\nimport { AsyncEventsComponent } from '../Components/AsyncEventsComponent.ts';\nimport { getTextBasedComponentValue } from '../Components/SettingComponents/TextBasedComponent.ts';\nimport { getValidatorComponent } from '../Components/SettingComponents/ValidatorComponent.ts';\nimport { isValidationMessageHolder } from '../ValidationMessage.ts';\nimport { getPluginId } from './PluginId.ts';\n\nconst PLUGIN_SETTINGS_TAB_SYMBOL = Symbol('pluginSettingsTab');\n\n/**\n * Options for binding a value component to a plugin setting.\n */\nexport interface BindOptions<T> {\n  /**\n   * A callback function that is called when the value of the component changes.\n   */\n  onChanged?(newValue: ReadonlyDeep<T>, oldValue: ReadonlyDeep<T>): Promisable<void>;\n\n  /**\n   * Whether to reset the setting when the component value is empty. Default is `true`.\n   * Applicable only to text-based components.\n   */\n  shouldResetSettingWhenComponentIsEmpty?: boolean;\n\n  /**\n   * Whether to show the validation message when the component value is invalid. Default is `true`.\n   */\n  shouldShowValidationMessage?: boolean;\n}\n\n/**\n * Extended options for binding a value component to a plugin setting.\n */\nexport interface BindOptionsExtended<\n  PluginSettings extends object,\n  UIValue,\n  PropertyName extends StringKeys<PluginSettings>\n> extends BindOptions<PluginSettings[PropertyName]> {\n  /**\n   * Converts the UI component's value back to the plugin settings value.\n   *\n   * @param uiValue - The value of the UI component.\n   * @returns The value to set on the plugin settings.\n   */\n  componentToPluginSettingsValueConverter: (uiValue: UIValue) => PluginSettings[PropertyName] | ValidationMessageHolder;\n\n  /**\n   * Converts the plugin settings value to the value used by the UI component.\n   *\n   * @param pluginSettingsValue - The value of the property in the plugin settings.\n   * @returns The value to set on the UI component.\n   */\n  pluginSettingsToComponentValueConverter: (pluginSettingsValue: ReadonlyDeep<PluginSettings[PropertyName]>) => UIValue;\n}\n\n/**\n * Base class for creating plugin settings tabs in Obsidian.\n * Provides a method for binding value components to plugin settings and handling changes.\n *\n * @typeParam PluginTypes - Plugin-specific types.\n */\nexport abstract class PluginSettingsTabBase<PluginTypes extends PluginTypesBase> extends PluginSettingTab {\n  /**\n   * Whether the plugin settings tab is open.\n   *\n   * @returns Whether the plugin settings tab is open.\n   */\n  public get isOpen(): boolean {\n    return this._isOpen;\n  }\n\n  /**\n   * The debounce timeout for saving settings.\n   *\n   * @returns The debounce timeout for saving settings.\n   */\n  protected get saveSettingsDebounceTimeoutInMilliseconds(): number {\n    const DEFAULT = 2_000;\n    return DEFAULT;\n  }\n\n  private _isOpen = false;\n  private readonly asyncEvents: AsyncEvents;\n  private readonly asyncEventsComponent: AsyncEventsComponent;\n  private saveSettingsDebounced: Debouncer<[], void>;\n\n  private get pluginSettings(): ExtractPluginSettings<PluginTypes> {\n    return this.plugin.settingsManager.settingsWrapper.settings as ExtractPluginSettings<PluginTypes>;\n  }\n\n  /**\n   * Creates a new plugin settings tab.\n   *\n   * @param plugin - The plugin.\n   */\n  public constructor(public override plugin: ExtractPlugin<PluginTypes>) {\n    super(plugin.app, plugin);\n    this.containerEl.addClass(CssClass.LibraryName, getPluginId(), CssClass.PluginSettingsTab);\n    this.saveSettingsDebounced = debounce(\n      convertAsyncToSync(() => this.plugin.settingsManager.saveToFile(PLUGIN_SETTINGS_TAB_SYMBOL)),\n      this.saveSettingsDebounceTimeoutInMilliseconds\n    );\n    this.asyncEventsComponent = new AsyncEventsComponent();\n    this.asyncEvents = new AsyncEvents();\n  }\n\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: ConditionalKeys<ExtractPluginSettings<PluginTypes>, UIValue>,\n    options?: BindOptions<UIValue>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options: BindOptionsExtended<ExtractPluginSettings<PluginTypes>, UIValue, PropertyName>\n  ): TValueComponent;\n  /**\n   * Binds a value component to a plugin setting.\n   *\n   * @typeParam UIValue - The type of the value of the UI component.\n   * @typeParam TValueComponent - The type of the value component.\n   * @typeParam PropertyName - The property name of the plugin settings to bind to.\n   * @param valueComponent - The value component to bind.\n   * @param propertyName - The property name of the plugin settings to bind to.\n   * @param options - The options for binding the value component.\n   * @returns The value component.\n   */\n  public bind<\n    UIValue,\n    TValueComponent,\n    PropertyName extends StringKeys<ExtractPluginSettings<PluginTypes>>\n  >(\n    valueComponent: TValueComponent & ValueComponentWithChangeTracking<UIValue>,\n    propertyName: PropertyName,\n    options?: BindOptions<ExtractPluginSettings<PluginTypes>[PropertyName]>\n  ): TValueComponent {\n    type PluginSettings = ExtractPluginSettings<PluginTypes>;\n    type PropertyType = PluginSettings[PropertyName];\n    const DEFAULT_OPTIONS: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = {\n      componentToPluginSettingsValueConverter: (value: UIValue): PropertyType => value as PropertyType,\n      onChanged: noop,\n      pluginSettingsToComponentValueConverter: (value: ReadonlyDeep<PropertyType>): UIValue => value as UIValue,\n      shouldResetSettingWhenComponentIsEmpty: true,\n      shouldShowValidationMessage: true\n    };\n\n    const optionsExt: Required<BindOptionsExtended<PluginSettings, UIValue, PropertyName>> = { ...DEFAULT_OPTIONS, ...options };\n\n    const validatorElement = getValidatorComponent(valueComponent)?.validatorEl;\n\n    const textBasedComponent = getTextBasedComponentValue(valueComponent);\n\n    const readonlyValue = this.pluginSettings[propertyName] as ReadonlyDeep<PropertyType>;\n    const defaultValue = (this.plugin.settingsManager.defaultSettings as PluginSettings)[propertyName] as PropertyType;\n    textBasedComponent?.setPlaceholderValue(optionsExt.pluginSettingsToComponentValueConverter(defaultValue as ReadonlyDeep<PropertyType>));\n\n    this.asyncEventsComponent.registerAsyncEvent(this.on('validationMessageChanged', (anotherPropertyName, validationMessage) => {\n      if (propertyName !== anotherPropertyName) {\n        return;\n      }\n\n      updateValidatorElement(validationMessage);\n    }));\n\n    if (readonlyValue === defaultValue && textBasedComponent && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n      textBasedComponent.empty();\n    } else {\n      valueComponent.setValue(optionsExt.pluginSettingsToComponentValueConverter(readonlyValue));\n    }\n\n    valueComponent.onChange(async (uiValue) => {\n      const oldValue = this.pluginSettings[propertyName];\n      let newValue: PropertyType | undefined = undefined;\n      let validationMessage: string;\n      if (textBasedComponent?.isEmpty() && optionsExt.shouldResetSettingWhenComponentIsEmpty) {\n        newValue = defaultValue;\n        validationMessage = '';\n      } else {\n        const convertedValue = optionsExt.componentToPluginSettingsValueConverter(uiValue);\n        if (isValidationMessageHolder(convertedValue)) {\n          validationMessage = convertedValue.validationMessage;\n        } else {\n          newValue = convertedValue;\n          validationMessage = await this.plugin.settingsManager.setProperty(propertyName, newValue);\n        }\n      }\n      updateValidatorElement(validationMessage);\n      if (newValue !== undefined) {\n        await optionsExt.onChanged(newValue as ReadonlyDeep<PropertyType>, oldValue as ReadonlyDeep<PropertyType>);\n      }\n      this.saveSettingsDebounced();\n    });\n\n    validatorElement?.addEventListener('focus', () => {\n      updateValidatorElement();\n    });\n    validatorElement?.addEventListener('blur', () => {\n      updateValidatorElement();\n    });\n\n    updateValidatorElement();\n    return valueComponent;\n\n    function updateValidatorElement(validationMessage?: string): void {\n      if (!validatorElement) {\n        return;\n      }\n\n      if (validationMessage === '') {\n        validatorElement.setCustomValidity('');\n        validatorElement.checkValidity();\n        validationMessage = validatorElement.validationMessage;\n      }\n\n      if (validationMessage !== undefined) {\n        validatorElement.setCustomValidity(validationMessage);\n        setTooltip(validatorElement, validationMessage);\n      }\n      if (validatorElement.isActiveElement() && optionsExt.shouldShowValidationMessage) {\n        validatorElement.reportValidity();\n      }\n    }\n  }\n\n  /**\n   * Renders the plugin settings tab.\n   */\n  public override display(): void {\n    this._isOpen = true;\n    this.asyncEventsComponent.load();\n    this.asyncEventsComponent.registerAsyncEvent(this.plugin.settingsManager.on('loadSettings', this.onLoadSettings.bind(this)));\n    this.asyncEventsComponent.registerAsyncEvent(this.plugin.settingsManager.on('saveSettings', this.onSaveSettings.bind(this)));\n  }\n\n  /**\n   * Hides the plugin settings tab.\n   */\n  public override hide(): void {\n    super.hide();\n    this.saveSettingsDebounced.cancel();\n    this.containerEl.empty();\n    this._isOpen = false;\n    this.asyncEventsComponent.unload();\n    this.asyncEventsComponent.load();\n    invokeAsyncSafely(() => this.plugin.settingsManager.saveToFile(PLUGIN_SETTINGS_TAB_SYMBOL));\n  }\n\n  /**\n   * Shows the plugin settings tab.\n   */\n  public show(): void {\n    this.app.setting.openTab(this);\n  }\n\n  /**\n   * Called when the plugin settings are loaded.\n   *\n   * @param _loadedSettings - The loaded settings.\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  protected async onLoadSettings(_loadedSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>, _isInitialLoad: boolean): Promise<void> {\n    this.refresh();\n    await noopAsync();\n  }\n\n  private on(\n    name: 'validationMessageChanged',\n    callback: (\n      propertyName: string,\n      validationMessage: string\n    ) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef;\n  private on<Args extends unknown[]>(\n    name: string,\n    callback: (...args: Args) => Promisable<void>,\n    thisArg?: unknown\n  ): AsyncEventRef {\n    return this.asyncEvents.on(name, callback, thisArg);\n  }\n\n  private async onSaveSettings(\n    newSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n    _oldSettings: ExtractReadonlyPluginSettingsWrapper<PluginTypes>,\n    context: unknown\n  ): Promise<void> {\n    if (context === PLUGIN_SETTINGS_TAB_SYMBOL) {\n      for (const [propertyName, validationMessage] of Object.entries(newSettings.validationMessages as Record<string, string>)) {\n        await this.asyncEvents.triggerAsync('validationMessageChanged', propertyName, validationMessage);\n      }\n      return;\n    }\n\n    this.refresh();\n  }\n\n  private refresh(): void {\n    this.containerEl.empty();\n    this.display();\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -5,23 +5,23 @@
5
5
  */
6
6
  import type { BaseComponent } from 'obsidian';
7
7
  import { Setting } from 'obsidian';
8
- import { CheckboxComponent } from './Components/CheckboxComponent.mjs';
9
- import { DateComponent } from './Components/DateComponent.mjs';
10
- import { DateTimeComponent } from './Components/DateTimeComponent.mjs';
11
- import { EmailComponent } from './Components/EmailComponent.mjs';
12
- import { FileComponent } from './Components/FileComponent.mjs';
13
- import { MonthComponent } from './Components/MonthComponent.mjs';
14
- import { MultipleDropdownComponent } from './Components/MultipleDropdownComponent.mjs';
15
- import { MultipleEmailComponent } from './Components/MultipleEmailComponent.mjs';
16
- import { MultipleFileComponent } from './Components/MultipleFileComponent.mjs';
17
- import { MultipleTextComponent } from './Components/MultipleTextComponent.mjs';
18
- import { NumberComponent } from './Components/NumberComponent.mjs';
19
- import { TimeComponent } from './Components/TimeComponent.mjs';
20
- import { TriStateCheckboxComponent } from './Components/TriStateCheckboxComponent.mjs';
21
- import { TypedDropdownComponent } from './Components/TypedDropdownComponent.mjs';
22
- import { TypedMultipleDropdownComponent } from './Components/TypedMultipleDropdownComponent.mjs';
23
- import { UrlComponent } from './Components/UrlComponent.mjs';
24
- import { WeekComponent } from './Components/WeekComponent.mjs';
8
+ import { CheckboxComponent } from './Components/SettingComponents/CheckboxComponent.mjs';
9
+ import { DateComponent } from './Components/SettingComponents/DateComponent.mjs';
10
+ import { DateTimeComponent } from './Components/SettingComponents/DateTimeComponent.mjs';
11
+ import { EmailComponent } from './Components/SettingComponents/EmailComponent.mjs';
12
+ import { FileComponent } from './Components/SettingComponents/FileComponent.mjs';
13
+ import { MonthComponent } from './Components/SettingComponents/MonthComponent.mjs';
14
+ import { MultipleDropdownComponent } from './Components/SettingComponents/MultipleDropdownComponent.mjs';
15
+ import { MultipleEmailComponent } from './Components/SettingComponents/MultipleEmailComponent.mjs';
16
+ import { MultipleFileComponent } from './Components/SettingComponents/MultipleFileComponent.mjs';
17
+ import { MultipleTextComponent } from './Components/SettingComponents/MultipleTextComponent.mjs';
18
+ import { NumberComponent } from './Components/SettingComponents/NumberComponent.mjs';
19
+ import { TimeComponent } from './Components/SettingComponents/TimeComponent.mjs';
20
+ import { TriStateCheckboxComponent } from './Components/SettingComponents/TriStateCheckboxComponent.mjs';
21
+ import { TypedDropdownComponent } from './Components/SettingComponents/TypedDropdownComponent.mjs';
22
+ import { TypedMultipleDropdownComponent } from './Components/SettingComponents/TypedMultipleDropdownComponent.mjs';
23
+ import { UrlComponent } from './Components/SettingComponents/UrlComponent.mjs';
24
+ import { WeekComponent } from './Components/SettingComponents/WeekComponent.mjs';
25
25
  /**
26
26
  * Extends the Setting class with additional methods for adding components.
27
27
  */
@@ -6,23 +6,23 @@ if you want to view the source, please visit the github repository of this plugi
6
6
  (function initEsm(){if(globalThis.process){return}const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};globalThis.process=browserProcess})();
7
7
 
8
8
  import { Setting } from "obsidian";
9
- import { CheckboxComponent } from "./Components/CheckboxComponent.mjs";
10
- import { DateComponent } from "./Components/DateComponent.mjs";
11
- import { DateTimeComponent } from "./Components/DateTimeComponent.mjs";
12
- import { EmailComponent } from "./Components/EmailComponent.mjs";
13
- import { FileComponent } from "./Components/FileComponent.mjs";
14
- import { MonthComponent } from "./Components/MonthComponent.mjs";
15
- import { MultipleDropdownComponent } from "./Components/MultipleDropdownComponent.mjs";
16
- import { MultipleEmailComponent } from "./Components/MultipleEmailComponent.mjs";
17
- import { MultipleFileComponent } from "./Components/MultipleFileComponent.mjs";
18
- import { MultipleTextComponent } from "./Components/MultipleTextComponent.mjs";
19
- import { NumberComponent } from "./Components/NumberComponent.mjs";
20
- import { TimeComponent } from "./Components/TimeComponent.mjs";
21
- import { TriStateCheckboxComponent } from "./Components/TriStateCheckboxComponent.mjs";
22
- import { TypedDropdownComponent } from "./Components/TypedDropdownComponent.mjs";
23
- import { TypedMultipleDropdownComponent } from "./Components/TypedMultipleDropdownComponent.mjs";
24
- import { UrlComponent } from "./Components/UrlComponent.mjs";
25
- import { WeekComponent } from "./Components/WeekComponent.mjs";
9
+ import { CheckboxComponent } from "./Components/SettingComponents/CheckboxComponent.mjs";
10
+ import { DateComponent } from "./Components/SettingComponents/DateComponent.mjs";
11
+ import { DateTimeComponent } from "./Components/SettingComponents/DateTimeComponent.mjs";
12
+ import { EmailComponent } from "./Components/SettingComponents/EmailComponent.mjs";
13
+ import { FileComponent } from "./Components/SettingComponents/FileComponent.mjs";
14
+ import { MonthComponent } from "./Components/SettingComponents/MonthComponent.mjs";
15
+ import { MultipleDropdownComponent } from "./Components/SettingComponents/MultipleDropdownComponent.mjs";
16
+ import { MultipleEmailComponent } from "./Components/SettingComponents/MultipleEmailComponent.mjs";
17
+ import { MultipleFileComponent } from "./Components/SettingComponents/MultipleFileComponent.mjs";
18
+ import { MultipleTextComponent } from "./Components/SettingComponents/MultipleTextComponent.mjs";
19
+ import { NumberComponent } from "./Components/SettingComponents/NumberComponent.mjs";
20
+ import { TimeComponent } from "./Components/SettingComponents/TimeComponent.mjs";
21
+ import { TriStateCheckboxComponent } from "./Components/SettingComponents/TriStateCheckboxComponent.mjs";
22
+ import { TypedDropdownComponent } from "./Components/SettingComponents/TypedDropdownComponent.mjs";
23
+ import { TypedMultipleDropdownComponent } from "./Components/SettingComponents/TypedMultipleDropdownComponent.mjs";
24
+ import { UrlComponent } from "./Components/SettingComponents/UrlComponent.mjs";
25
+ import { WeekComponent } from "./Components/SettingComponents/WeekComponent.mjs";
26
26
  class SettingEx extends Setting {
27
27
  /**
28
28
  * Adds a {@link CheckboxComponent} to the setting.
@@ -195,4 +195,4 @@ class SettingEx extends Setting {
195
195
  export {
196
196
  SettingEx
197
197
  };
198
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/SettingEx.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Extends the Setting class with additional methods for adding components.\n */\n\nimport type { BaseComponent } from 'obsidian';\n\nimport { Setting } from 'obsidian';\n\nimport { CheckboxComponent } from './Components/CheckboxComponent.ts';\nimport { DateComponent } from './Components/DateComponent.ts';\nimport { DateTimeComponent } from './Components/DateTimeComponent.ts';\nimport { EmailComponent } from './Components/EmailComponent.ts';\nimport { FileComponent } from './Components/FileComponent.ts';\nimport { MonthComponent } from './Components/MonthComponent.ts';\nimport { MultipleDropdownComponent } from './Components/MultipleDropdownComponent.ts';\nimport { MultipleEmailComponent } from './Components/MultipleEmailComponent.ts';\nimport { MultipleFileComponent } from './Components/MultipleFileComponent.ts';\nimport { MultipleTextComponent } from './Components/MultipleTextComponent.ts';\nimport { NumberComponent } from './Components/NumberComponent.ts';\nimport { TimeComponent } from './Components/TimeComponent.ts';\nimport { TriStateCheckboxComponent } from './Components/TriStateCheckboxComponent.ts';\nimport { TypedDropdownComponent } from './Components/TypedDropdownComponent.ts';\nimport { TypedMultipleDropdownComponent } from './Components/TypedMultipleDropdownComponent.ts';\nimport { UrlComponent } from './Components/UrlComponent.ts';\nimport { WeekComponent } from './Components/WeekComponent.ts';\n\n/**\n * Extends the Setting class with additional methods for adding components.\n */\nexport class SettingEx extends Setting {\n  /**\n   * Adds a {@link CheckboxComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addCheckbox(cb: (component: CheckboxComponent) => void): this {\n    return this.addComponent(CheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a component to the setting.\n   *\n   * @typeParam T - The type of the component to add.\n   * @param componentClass - The class of the component to add.\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addComponent<T extends BaseComponent>(componentClass: new (containerEl: HTMLElement) => T, cb: (component: T) => void): this {\n    const component = new componentClass(this.controlEl);\n    this.components.push(component);\n    cb(component);\n    return this;\n  }\n\n  /**\n   * Adds a {@link DateComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDate(cb: (component: DateComponent) => void): this {\n    return this.addComponent(DateComponent, cb);\n  }\n\n  /**\n   * Adds a {@link DateTimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDateTime(cb: (component: DateTimeComponent) => void): this {\n    return this.addComponent(DateTimeComponent, cb);\n  }\n\n  /**\n   * Adds an {@link EmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addEmail(cb: (component: EmailComponent) => void): this {\n    return this.addComponent(EmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link FileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addFile(cb: (component: FileComponent) => void): this {\n    return this.addComponent(FileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MonthComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMonth(cb: (component: MonthComponent) => void): this {\n    return this.addComponent(MonthComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleDropdown(cb: (component: MultipleDropdownComponent) => void): this {\n    return this.addComponent(MultipleDropdownComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleEmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleEmail(cb: (component: MultipleEmailComponent) => void): this {\n    return this.addComponent(MultipleEmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleFileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleFile(cb: (component: MultipleFileComponent) => void): this {\n    return this.addComponent(MultipleFileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleTextComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleText(cb: (component: MultipleTextComponent) => void): this {\n    return this.addComponent(MultipleTextComponent, cb);\n  }\n\n  /**\n   * Adds a {@link NumberComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addNumber(cb: (component: NumberComponent) => void): this {\n    return this.addComponent(NumberComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTime(cb: (component: TimeComponent) => void): this {\n    return this.addComponent(TimeComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TriStateCheckboxComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTriStateCheckbox(cb: (component: TriStateCheckboxComponent) => void): this {\n    return this.addComponent(TriStateCheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TypedDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTypedDropdown<T>(cb: (component: TypedDropdownComponent<T>) => void): this {\n    return this.addComponent(TypedDropdownComponent<T>, cb);\n  }\n\n  /**\n   * Adds a {@link TypedMultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTypedMultipleDropdown<T>(cb: (component: TypedMultipleDropdownComponent<T>) => void): this {\n    return this.addComponent(TypedMultipleDropdownComponent<T>, cb);\n  }\n\n  /**\n   * Adds an {@link UrlComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addUrl(cb: (component: UrlComponent) => void): this {\n    return this.addComponent(UrlComponent, cb);\n  }\n\n  /**\n   * Adds a {@link WeekComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addWeek(cb: (component: WeekComponent) => void): this {\n    return this.addComponent(WeekComponent, cb);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

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

@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../dist/lib/cjs/obsidian/Components/AsyncEventsComponent.cjs",
3
+ "module": "../../../dist/lib/esm/obsidian/Components/AsyncEventsComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../dist/lib/cjs/obsidian/Components/AsyncEventsComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/CheckboxComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/CheckboxComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/CheckboxComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/DateComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/DateComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/DateComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/DateTimeComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/DateTimeComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/DateTimeComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/EmailComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/EmailComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/EmailComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/FileComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/FileComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/FileComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MonthComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/MonthComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MonthComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleDropdownComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/MultipleDropdownComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleDropdownComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleEmailComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/MultipleEmailComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleEmailComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleFileComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/MultipleFileComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleFileComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleTextComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/MultipleTextComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/MultipleTextComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/NumberComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/NumberComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/NumberComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TextBasedComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/TextBasedComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TextBasedComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TimeComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/TimeComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TimeComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TriStateCheckboxComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/TriStateCheckboxComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TriStateCheckboxComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedDropdownComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/TypedDropdownComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedDropdownComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedMultipleDropdownComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedRangeTextComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/TypedRangeTextComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedRangeTextComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedTextComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/TypedTextComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/TypedTextComponent.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/UrlComponent.cjs",
3
+ "module": "../../../../dist/lib/esm/obsidian/Components/SettingComponents/UrlComponent.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/obsidian/Components/SettingComponents/UrlComponent.d.cts"
6
+ }