obsidian-dev-utils 45.2.0 → 45.3.1
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 +10 -0
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/obsidian/Commands/AbstractFileCommandBase.cjs +38 -7
- package/dist/lib/cjs/obsidian/Commands/AbstractFileCommandBase.d.cts +30 -2
- package/dist/lib/cjs/obsidian/Commands/FileCommandBase.cjs +61 -30
- package/dist/lib/cjs/obsidian/Commands/FileCommandBase.d.cts +55 -27
- package/dist/lib/cjs/obsidian/Commands/FolderCommandBase.cjs +52 -21
- package/dist/lib/cjs/obsidian/Commands/FolderCommandBase.d.cts +48 -20
- package/dist/lib/cjs/obsidian/SettingEx.cjs +14 -2
- package/dist/lib/cjs/obsidian/SettingEx.d.cts +1 -0
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/obsidian/Commands/AbstractFileCommandBase.d.mts +30 -2
- package/dist/lib/esm/obsidian/Commands/AbstractFileCommandBase.mjs +37 -7
- package/dist/lib/esm/obsidian/Commands/FileCommandBase.d.mts +55 -27
- package/dist/lib/esm/obsidian/Commands/FileCommandBase.mjs +60 -30
- package/dist/lib/esm/obsidian/Commands/FolderCommandBase.d.mts +48 -20
- package/dist/lib/esm/obsidian/Commands/FolderCommandBase.mjs +51 -21
- package/dist/lib/esm/obsidian/SettingEx.d.mts +1 -0
- package/dist/lib/esm/obsidian/SettingEx.mjs +18 -3
- package/package.json +1 -1
|
@@ -6,6 +6,61 @@
|
|
|
6
6
|
import type { Plugin, TAbstractFile, WorkspaceLeaf } from 'obsidian';
|
|
7
7
|
import { TFile } from 'obsidian';
|
|
8
8
|
import { AbstractFileCommandBase, AbstractFileCommandInvocationBase, AbstractFilesCommandInvocationBase } from './AbstractFileCommandBase.mjs';
|
|
9
|
+
/**
|
|
10
|
+
* Base class for file command invocations.
|
|
11
|
+
*
|
|
12
|
+
* @typeParam TPlugin - The type of the plugin that the command belongs to.
|
|
13
|
+
*/
|
|
14
|
+
export declare abstract class FileCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {
|
|
15
|
+
/**
|
|
16
|
+
* Gets the file that the command invocation belongs to.
|
|
17
|
+
*
|
|
18
|
+
* @returns The file that the command invocation belongs to.
|
|
19
|
+
* @throws If the abstract file is not a file.
|
|
20
|
+
*/
|
|
21
|
+
protected get file(): TFile;
|
|
22
|
+
/**
|
|
23
|
+
* Creates a new file command invocation.
|
|
24
|
+
*
|
|
25
|
+
* @param plugin - The plugin that the command invocation belongs to.
|
|
26
|
+
* @param file - The file to invoke the command for.
|
|
27
|
+
*/
|
|
28
|
+
constructor(plugin: TPlugin, file: null | TFile);
|
|
29
|
+
/**
|
|
30
|
+
* Checks if the command can execute.
|
|
31
|
+
*
|
|
32
|
+
* @returns Whether the command can execute.
|
|
33
|
+
*/
|
|
34
|
+
protected canExecute(): boolean;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Base class for array-delegating file command invocations.
|
|
38
|
+
*
|
|
39
|
+
* @typeParam TPlugin - The type of the plugin that the command belongs to.
|
|
40
|
+
*/
|
|
41
|
+
export declare class ArrayDelegatingFileCommandInvocation<TPlugin extends Plugin> extends FileCommandInvocationBase<TPlugin> {
|
|
42
|
+
private readonly createCommandInvocationForFiles;
|
|
43
|
+
/**
|
|
44
|
+
* Creates a new array-delegating file command invocation.
|
|
45
|
+
*
|
|
46
|
+
* @param plugin - The plugin that the command invocation belongs to.
|
|
47
|
+
* @param file - The file to invoke the command for.
|
|
48
|
+
* @param createCommandInvocationForFiles - The function to create a command invocation for files.
|
|
49
|
+
*/
|
|
50
|
+
constructor(plugin: TPlugin, file: null | TFile, createCommandInvocationForFiles: (files: TFile[]) => FilesCommandInvocationBase<TPlugin>);
|
|
51
|
+
/**
|
|
52
|
+
* Checks if the command can execute.
|
|
53
|
+
*
|
|
54
|
+
* @returns Whether the command can execute.
|
|
55
|
+
*/
|
|
56
|
+
protected canExecute(): boolean;
|
|
57
|
+
/**
|
|
58
|
+
* Executes the command.
|
|
59
|
+
*
|
|
60
|
+
* @returns A promise that resolves when the command has been executed.
|
|
61
|
+
*/
|
|
62
|
+
protected execute(): Promise<void>;
|
|
63
|
+
}
|
|
9
64
|
/**
|
|
10
65
|
* Base class for file commands.
|
|
11
66
|
*
|
|
@@ -84,33 +139,6 @@ export declare abstract class FileCommandBase<TPlugin extends Plugin = Plugin> e
|
|
|
84
139
|
*/
|
|
85
140
|
protected shouldAddToFilesMenu(_files: TFile[], _source: string, _leaf?: WorkspaceLeaf): boolean;
|
|
86
141
|
}
|
|
87
|
-
/**
|
|
88
|
-
* Base class for file command invocations.
|
|
89
|
-
*
|
|
90
|
-
* @typeParam TPlugin - The type of the plugin that the command belongs to.
|
|
91
|
-
*/
|
|
92
|
-
export declare abstract class FileCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {
|
|
93
|
-
/**
|
|
94
|
-
* Gets the file that the command invocation belongs to.
|
|
95
|
-
*
|
|
96
|
-
* @returns The file that the command invocation belongs to.
|
|
97
|
-
* @throws If the abstract file is not a file.
|
|
98
|
-
*/
|
|
99
|
-
protected get file(): TFile;
|
|
100
|
-
/**
|
|
101
|
-
* Creates a new file command invocation.
|
|
102
|
-
*
|
|
103
|
-
* @param plugin - The plugin that the command invocation belongs to.
|
|
104
|
-
* @param file - The file to invoke the command for.
|
|
105
|
-
*/
|
|
106
|
-
constructor(plugin: TPlugin, file: null | TFile);
|
|
107
|
-
/**
|
|
108
|
-
* Checks if the command can execute.
|
|
109
|
-
*
|
|
110
|
-
* @returns Whether the command can execute.
|
|
111
|
-
*/
|
|
112
|
-
protected canExecute(): boolean;
|
|
113
|
-
}
|
|
114
142
|
/**
|
|
115
143
|
* Base class for files command invocations.
|
|
116
144
|
*
|
|
@@ -31,6 +31,63 @@ import {
|
|
|
31
31
|
AbstractFileCommandInvocationBase,
|
|
32
32
|
AbstractFilesCommandInvocationBase
|
|
33
33
|
} from "./AbstractFileCommandBase.mjs";
|
|
34
|
+
class FileCommandInvocationBase extends AbstractFileCommandInvocationBase {
|
|
35
|
+
/**
|
|
36
|
+
* Gets the file that the command invocation belongs to.
|
|
37
|
+
*
|
|
38
|
+
* @returns The file that the command invocation belongs to.
|
|
39
|
+
* @throws If the abstract file is not a file.
|
|
40
|
+
*/
|
|
41
|
+
get file() {
|
|
42
|
+
return asFile(this._abstractFile);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Creates a new file command invocation.
|
|
46
|
+
*
|
|
47
|
+
* @param plugin - The plugin that the command invocation belongs to.
|
|
48
|
+
* @param file - The file to invoke the command for.
|
|
49
|
+
*/
|
|
50
|
+
constructor(plugin, file) {
|
|
51
|
+
super(plugin, file);
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Checks if the command can execute.
|
|
55
|
+
*
|
|
56
|
+
* @returns Whether the command can execute.
|
|
57
|
+
*/
|
|
58
|
+
canExecute() {
|
|
59
|
+
return super.canExecute() && !!this._abstractFile;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
class ArrayDelegatingFileCommandInvocation extends FileCommandInvocationBase {
|
|
63
|
+
/**
|
|
64
|
+
* Creates a new array-delegating file command invocation.
|
|
65
|
+
*
|
|
66
|
+
* @param plugin - The plugin that the command invocation belongs to.
|
|
67
|
+
* @param file - The file to invoke the command for.
|
|
68
|
+
* @param createCommandInvocationForFiles - The function to create a command invocation for files.
|
|
69
|
+
*/
|
|
70
|
+
constructor(plugin, file, createCommandInvocationForFiles) {
|
|
71
|
+
super(plugin, file);
|
|
72
|
+
this.createCommandInvocationForFiles = createCommandInvocationForFiles;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Checks if the command can execute.
|
|
76
|
+
*
|
|
77
|
+
* @returns Whether the command can execute.
|
|
78
|
+
*/
|
|
79
|
+
canExecute() {
|
|
80
|
+
return super.canExecute() && this.createCommandInvocationForFiles([this.file]).invoke(true);
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Executes the command.
|
|
84
|
+
*
|
|
85
|
+
* @returns A promise that resolves when the command has been executed.
|
|
86
|
+
*/
|
|
87
|
+
async execute() {
|
|
88
|
+
await this.createCommandInvocationForFiles([this.file]).invokeAsync(false);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
34
91
|
class FileCommandBase extends AbstractFileCommandBase {
|
|
35
92
|
/**
|
|
36
93
|
* Creates a new abstract file command invocation.
|
|
@@ -119,34 +176,6 @@ class FileCommandBase extends AbstractFileCommandBase {
|
|
|
119
176
|
return false;
|
|
120
177
|
}
|
|
121
178
|
}
|
|
122
|
-
class FileCommandInvocationBase extends AbstractFileCommandInvocationBase {
|
|
123
|
-
/**
|
|
124
|
-
* Gets the file that the command invocation belongs to.
|
|
125
|
-
*
|
|
126
|
-
* @returns The file that the command invocation belongs to.
|
|
127
|
-
* @throws If the abstract file is not a file.
|
|
128
|
-
*/
|
|
129
|
-
get file() {
|
|
130
|
-
return asFile(this._abstractFile);
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* Creates a new file command invocation.
|
|
134
|
-
*
|
|
135
|
-
* @param plugin - The plugin that the command invocation belongs to.
|
|
136
|
-
* @param file - The file to invoke the command for.
|
|
137
|
-
*/
|
|
138
|
-
constructor(plugin, file) {
|
|
139
|
-
super(plugin, file);
|
|
140
|
-
}
|
|
141
|
-
/**
|
|
142
|
-
* Checks if the command can execute.
|
|
143
|
-
*
|
|
144
|
-
* @returns Whether the command can execute.
|
|
145
|
-
*/
|
|
146
|
-
canExecute() {
|
|
147
|
-
return super.canExecute() && !!this._abstractFile;
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
179
|
class FilesCommandInvocationBase extends AbstractFilesCommandInvocationBase {
|
|
151
180
|
/**
|
|
152
181
|
* Creates a new files command invocation.
|
|
@@ -177,7 +206,7 @@ class SequentialFilesCommandInvocationBase extends FilesCommandInvocationBase {
|
|
|
177
206
|
* @returns Whether the command can execute.
|
|
178
207
|
*/
|
|
179
208
|
canExecute() {
|
|
180
|
-
return super.canExecute() && this.files.every((file) => this.createCommandInvocationForFile(file).invoke(true));
|
|
209
|
+
return super.canExecute() && this.files.length > 0 && this.files.every((file) => this.createCommandInvocationForFile(file).invoke(true));
|
|
181
210
|
}
|
|
182
211
|
/**
|
|
183
212
|
* Executes the command.
|
|
@@ -191,9 +220,10 @@ class SequentialFilesCommandInvocationBase extends FilesCommandInvocationBase {
|
|
|
191
220
|
}
|
|
192
221
|
}
|
|
193
222
|
export {
|
|
223
|
+
ArrayDelegatingFileCommandInvocation,
|
|
194
224
|
FileCommandBase,
|
|
195
225
|
FileCommandInvocationBase,
|
|
196
226
|
FilesCommandInvocationBase,
|
|
197
227
|
SequentialFilesCommandInvocationBase
|
|
198
228
|
};
|
|
199
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Commands/FileCommandBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base classes for file commands.\n */\n\nimport type {\n  Plugin,\n  TAbstractFile,\n  WorkspaceLeaf\n} from 'obsidian';\n\nimport { TFile } from 'obsidian';\n\nimport {\n  asArrayOfFiles,\n  asFile,\n  asFileOrNull,\n  isFile\n} from '../FileSystem.ts';\nimport {\n  AbstractFileCommandBase,\n  AbstractFileCommandInvocationBase,\n  AbstractFilesCommandInvocationBase\n} from './AbstractFileCommandBase.ts';\n\n/**\n * Base class for file commands.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FileCommandBase<TPlugin extends Plugin = Plugin> extends AbstractFileCommandBase<TPlugin> {\n  /**\n   * Creates a new abstract file command invocation.\n   *\n   * @param abstractFile - The abstract file to invoke the command for.\n   * @returns The command invocation.\n   */\n  protected override createCommandInvocation(abstractFile?: TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForAbstractFile(abstractFile ?? this.app.workspace.getActiveFile());\n  }\n\n  /**\n   * Creates a new abstract file command invocation for an abstract file.\n   *\n   * @param abstractFile - The abstract file to invoke the command for. If `null`, the active file is used.\n   * @returns The command invocation.\n   */\n  protected override createCommandInvocationForAbstractFile(abstractFile: null | TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFile(asFileOrNull(abstractFile));\n  }\n\n  /**\n   * Creates a new abstract files command invocation for abstract files.\n   *\n   * @param abstractFiles - The abstract files to invoke the command for.\n   * @returns A new abstract files command invocation.\n   */\n  protected override createCommandInvocationForAbstractFiles(abstractFiles: TAbstractFile[]): AbstractFilesCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFiles(asArrayOfFiles(abstractFiles));\n  }\n\n  /**\n   * Creates a new file command invocation for a file.\n   *\n   * @param file - The file to invoke the command for.\n   * @returns A new file command invocation.\n   */\n  protected abstract createCommandInvocationForFile(file: null | TFile): FileCommandInvocationBase<TPlugin>;\n\n  /**\n   * Creates a new files command invocation for files.\n   *\n   * @param files - The files to invoke the command for.\n   * @returns A new files command invocation.\n   */\n  protected createCommandInvocationForFiles(files: TFile[]): FilesCommandInvocationBase<TPlugin> {\n    return new SequentialFilesCommandInvocationBase(this.plugin, files, this.createCommandInvocationForFile.bind(this));\n  }\n\n  /**\n   * Checks if the command should be added to the abstract file menu.\n   *\n   * @param abstractFile - The abstract file to check.\n   * @param source - The source of the abstract file.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract file menu.\n   */\n  protected override shouldAddToAbstractFileMenu(abstractFile: TAbstractFile, source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!isFile(abstractFile)) {\n      return false;\n    }\n    return this.shouldAddToFileMenu(abstractFile, source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the abstract files menu.\n   *\n   * @param abstractFiles - The abstract files to check.\n   * @param source - The source of the abstract files.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract files menu.\n   */\n  protected override shouldAddToAbstractFilesMenu(abstractFiles: TAbstractFile[], source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!abstractFiles.every((abstractFile) => isFile(abstractFile))) {\n      return false;\n    }\n    return this.shouldAddToFilesMenu(asArrayOfFiles(abstractFiles), source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the file menu.\n   *\n   * @param _file - The file to check.\n   * @param _source - The source of the file.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the file menu.\n   */\n  protected shouldAddToFileMenu(_file: TFile, _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n\n  /**\n   * Checks if the command should be added to the files menu.\n   *\n   * @param _files - The files to check.\n   * @param _source - The source of the files.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the files menu.\n   */\n  protected shouldAddToFilesMenu(_files: TFile[], _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n}\n\n/**\n * Base class for file command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FileCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {\n  /**\n   * Gets the file that the command invocation belongs to.\n   *\n   * @returns The file that the command invocation belongs to.\n   * @throws If the abstract file is not a file.\n   */\n  protected get file(): TFile {\n    return asFile(this._abstractFile);\n  }\n\n  /**\n   * Creates a new file command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param file - The file to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, file: null | TFile) {\n    super(plugin, file);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && !!this._abstractFile;\n  }\n}\n\n/**\n * Base class for files command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FilesCommandInvocationBase<TPlugin extends Plugin> extends AbstractFilesCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new files command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param files - The files to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, public readonly files: TFile[]) {\n    super(plugin, files);\n  }\n}\n\n/**\n * Base class for sequential files command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class SequentialFilesCommandInvocationBase<TPlugin extends Plugin> extends FilesCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new sequential files command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param files - The files to invoke the command for.\n   * @param createCommandInvocationForFile - The function to create a command invocation for a file.\n   */\n  public constructor(plugin: TPlugin, files: TFile[], private readonly createCommandInvocationForFile: (file: TFile) => FileCommandInvocationBase<TPlugin>) {\n    super(plugin, files);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && this.files.every((file) => this.createCommandInvocationForFile(file).invoke(true));\n  }\n\n  /**\n   * Executes the command.\n   *\n   * @returns A promise that resolves when the command has been executed.\n   */\n  protected override async execute(): Promise<void> {\n    for (const file of this.files) {\n      await this.createCommandInvocationForFile(file).invokeAsync(false);\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
229
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Commands/FileCommandBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base classes for file commands.\n */\n\nimport type {\n  Plugin,\n  TAbstractFile,\n  WorkspaceLeaf\n} from 'obsidian';\n\nimport { TFile } from 'obsidian';\n\nimport {\n  asArrayOfFiles,\n  asFile,\n  asFileOrNull,\n  isFile\n} from '../FileSystem.ts';\nimport {\n  AbstractFileCommandBase,\n  AbstractFileCommandInvocationBase,\n  AbstractFilesCommandInvocationBase\n} from './AbstractFileCommandBase.ts';\n\n/**\n * Base class for file command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FileCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {\n  /**\n   * Gets the file that the command invocation belongs to.\n   *\n   * @returns The file that the command invocation belongs to.\n   * @throws If the abstract file is not a file.\n   */\n  protected get file(): TFile {\n    return asFile(this._abstractFile);\n  }\n\n  /**\n   * Creates a new file command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param file - The file to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, file: null | TFile) {\n    super(plugin, file);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && !!this._abstractFile;\n  }\n}\n\n/**\n * Base class for array-delegating file command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class ArrayDelegatingFileCommandInvocation<TPlugin extends Plugin> extends FileCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new array-delegating file command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param file - The file to invoke the command for.\n   * @param createCommandInvocationForFiles - The function to create a command invocation for files.\n   */\n  public constructor(\n    plugin: TPlugin,\n    file: null | TFile,\n    private readonly createCommandInvocationForFiles: (files: TFile[]) => FilesCommandInvocationBase<TPlugin>\n  ) {\n    super(plugin, file);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && this.createCommandInvocationForFiles([this.file]).invoke(true);\n  }\n\n  /**\n   * Executes the command.\n   *\n   * @returns A promise that resolves when the command has been executed.\n   */\n  protected override async execute(): Promise<void> {\n    await this.createCommandInvocationForFiles([this.file]).invokeAsync(false);\n  }\n}\n\n/**\n * Base class for file commands.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FileCommandBase<TPlugin extends Plugin = Plugin> extends AbstractFileCommandBase<TPlugin> {\n  /**\n   * Creates a new abstract file command invocation.\n   *\n   * @param abstractFile - The abstract file to invoke the command for.\n   * @returns The command invocation.\n   */\n  protected override createCommandInvocation(abstractFile?: TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForAbstractFile(abstractFile ?? this.app.workspace.getActiveFile());\n  }\n\n  /**\n   * Creates a new abstract file command invocation for an abstract file.\n   *\n   * @param abstractFile - The abstract file to invoke the command for. If `null`, the active file is used.\n   * @returns The command invocation.\n   */\n  protected override createCommandInvocationForAbstractFile(abstractFile: null | TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFile(asFileOrNull(abstractFile));\n  }\n\n  /**\n   * Creates a new abstract files command invocation for abstract files.\n   *\n   * @param abstractFiles - The abstract files to invoke the command for.\n   * @returns A new abstract files command invocation.\n   */\n  protected override createCommandInvocationForAbstractFiles(abstractFiles: TAbstractFile[]): AbstractFilesCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFiles(asArrayOfFiles(abstractFiles));\n  }\n\n  /**\n   * Creates a new file command invocation for a file.\n   *\n   * @param file - The file to invoke the command for.\n   * @returns A new file command invocation.\n   */\n  protected abstract createCommandInvocationForFile(file: null | TFile): FileCommandInvocationBase<TPlugin>;\n\n  /**\n   * Creates a new files command invocation for files.\n   *\n   * @param files - The files to invoke the command for.\n   * @returns A new files command invocation.\n   */\n  protected createCommandInvocationForFiles(files: TFile[]): FilesCommandInvocationBase<TPlugin> {\n    return new SequentialFilesCommandInvocationBase(this.plugin, files, this.createCommandInvocationForFile.bind(this));\n  }\n\n  /**\n   * Checks if the command should be added to the abstract file menu.\n   *\n   * @param abstractFile - The abstract file to check.\n   * @param source - The source of the abstract file.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract file menu.\n   */\n  protected override shouldAddToAbstractFileMenu(abstractFile: TAbstractFile, source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!isFile(abstractFile)) {\n      return false;\n    }\n    return this.shouldAddToFileMenu(abstractFile, source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the abstract files menu.\n   *\n   * @param abstractFiles - The abstract files to check.\n   * @param source - The source of the abstract files.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract files menu.\n   */\n  protected override shouldAddToAbstractFilesMenu(abstractFiles: TAbstractFile[], source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!abstractFiles.every((abstractFile) => isFile(abstractFile))) {\n      return false;\n    }\n    return this.shouldAddToFilesMenu(asArrayOfFiles(abstractFiles), source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the file menu.\n   *\n   * @param _file - The file to check.\n   * @param _source - The source of the file.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the file menu.\n   */\n  protected shouldAddToFileMenu(_file: TFile, _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n\n  /**\n   * Checks if the command should be added to the files menu.\n   *\n   * @param _files - The files to check.\n   * @param _source - The source of the files.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the files menu.\n   */\n  protected shouldAddToFilesMenu(_files: TFile[], _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n}\n\n/**\n * Base class for files command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FilesCommandInvocationBase<TPlugin extends Plugin> extends AbstractFilesCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new files command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param files - The files to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, public readonly files: TFile[]) {\n    super(plugin, files);\n  }\n}\n\n/**\n * Base class for sequential files command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class SequentialFilesCommandInvocationBase<TPlugin extends Plugin> extends FilesCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new sequential files command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param files - The files to invoke the command for.\n   * @param createCommandInvocationForFile - The function to create a command invocation for a file.\n   */\n  public constructor(plugin: TPlugin, files: TFile[], private readonly createCommandInvocationForFile: (file: TFile) => FileCommandInvocationBase<TPlugin>) {\n    super(plugin, files);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && this.files.length > 0 && this.files.every((file) => this.createCommandInvocationForFile(file).invoke(true));\n  }\n\n  /**\n   * Executes the command.\n   *\n   * @returns A promise that resolves when the command has been executed.\n   */\n  protected override async execute(): Promise<void> {\n    for (const file of this.files) {\n      await this.createCommandInvocationForFile(file).invokeAsync(false);\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -6,6 +6,54 @@
|
|
|
6
6
|
import type { Plugin, TAbstractFile, WorkspaceLeaf } from 'obsidian';
|
|
7
7
|
import { TFolder } from 'obsidian';
|
|
8
8
|
import { AbstractFileCommandBase, AbstractFileCommandInvocationBase, AbstractFilesCommandInvocationBase } from './AbstractFileCommandBase.mjs';
|
|
9
|
+
/**
|
|
10
|
+
* Base class for folder command invocations.
|
|
11
|
+
*
|
|
12
|
+
* @typeParam TPlugin - The type of the plugin that the command belongs to.
|
|
13
|
+
*/
|
|
14
|
+
export declare abstract class FolderCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {
|
|
15
|
+
/**
|
|
16
|
+
* Gets the folder that the command invocation belongs to.
|
|
17
|
+
*
|
|
18
|
+
* @returns The folder that the command invocation belongs to.
|
|
19
|
+
* @throws If the abstract file is not a folder.
|
|
20
|
+
*/
|
|
21
|
+
protected get folder(): TFolder;
|
|
22
|
+
/**
|
|
23
|
+
* Checks if the command can execute.
|
|
24
|
+
*
|
|
25
|
+
* @returns Whether the command can execute.
|
|
26
|
+
*/
|
|
27
|
+
protected canExecute(): boolean;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Base class for array-delegating file command invocations.
|
|
31
|
+
*
|
|
32
|
+
* @typeParam TPlugin - The type of the plugin that the command belongs to.
|
|
33
|
+
*/
|
|
34
|
+
export declare class ArrayDelegatingFolderCommandInvocation<TPlugin extends Plugin> extends FolderCommandInvocationBase<TPlugin> {
|
|
35
|
+
private readonly createCommandInvocationForFiles;
|
|
36
|
+
/**
|
|
37
|
+
* Creates a new array-delegating folder command invocation.
|
|
38
|
+
*
|
|
39
|
+
* @param plugin - The plugin that the command invocation belongs to.
|
|
40
|
+
* @param folder - The file to invoke the command for.
|
|
41
|
+
* @param createCommandInvocationForFiles - The function to create a command invocation for files.
|
|
42
|
+
*/
|
|
43
|
+
constructor(plugin: TPlugin, folder: null | TFolder, createCommandInvocationForFiles: (folders: TFolder[]) => FoldersCommandInvocationBase<TPlugin>);
|
|
44
|
+
/**
|
|
45
|
+
* Checks if the command can execute.
|
|
46
|
+
*
|
|
47
|
+
* @returns Whether the command can execute.
|
|
48
|
+
*/
|
|
49
|
+
protected canExecute(): boolean;
|
|
50
|
+
/**
|
|
51
|
+
* Executes the command.
|
|
52
|
+
*
|
|
53
|
+
* @returns A promise that resolves when the command has been executed.
|
|
54
|
+
*/
|
|
55
|
+
protected execute(): Promise<void>;
|
|
56
|
+
}
|
|
9
57
|
/**
|
|
10
58
|
* Base class for folder commands.
|
|
11
59
|
*
|
|
@@ -84,26 +132,6 @@ export declare abstract class FolderCommandBase<TPlugin extends Plugin = Plugin>
|
|
|
84
132
|
*/
|
|
85
133
|
protected shouldAddToFoldersMenu(_folders: TFolder[], _source: string, _leaf?: WorkspaceLeaf): boolean;
|
|
86
134
|
}
|
|
87
|
-
/**
|
|
88
|
-
* Base class for folder command invocations.
|
|
89
|
-
*
|
|
90
|
-
* @typeParam TPlugin - The type of the plugin that the command belongs to.
|
|
91
|
-
*/
|
|
92
|
-
export declare abstract class FolderCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {
|
|
93
|
-
/**
|
|
94
|
-
* Gets the folder that the command invocation belongs to.
|
|
95
|
-
*
|
|
96
|
-
* @returns The folder that the command invocation belongs to.
|
|
97
|
-
* @throws If the abstract file is not a folder.
|
|
98
|
-
*/
|
|
99
|
-
protected get folder(): TFolder;
|
|
100
|
-
/**
|
|
101
|
-
* Checks if the command can execute.
|
|
102
|
-
*
|
|
103
|
-
* @returns Whether the command can execute.
|
|
104
|
-
*/
|
|
105
|
-
protected canExecute(): boolean;
|
|
106
|
-
}
|
|
107
135
|
/**
|
|
108
136
|
* Base class for folders command invocations.
|
|
109
137
|
*
|
|
@@ -31,6 +31,54 @@ import {
|
|
|
31
31
|
AbstractFileCommandInvocationBase,
|
|
32
32
|
AbstractFilesCommandInvocationBase
|
|
33
33
|
} from "./AbstractFileCommandBase.mjs";
|
|
34
|
+
class FolderCommandInvocationBase extends AbstractFileCommandInvocationBase {
|
|
35
|
+
/**
|
|
36
|
+
* Gets the folder that the command invocation belongs to.
|
|
37
|
+
*
|
|
38
|
+
* @returns The folder that the command invocation belongs to.
|
|
39
|
+
* @throws If the abstract file is not a folder.
|
|
40
|
+
*/
|
|
41
|
+
get folder() {
|
|
42
|
+
return asFolder(this._abstractFile);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Checks if the command can execute.
|
|
46
|
+
*
|
|
47
|
+
* @returns Whether the command can execute.
|
|
48
|
+
*/
|
|
49
|
+
canExecute() {
|
|
50
|
+
return super.canExecute() && !!this.folder;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
class ArrayDelegatingFolderCommandInvocation extends FolderCommandInvocationBase {
|
|
54
|
+
/**
|
|
55
|
+
* Creates a new array-delegating folder command invocation.
|
|
56
|
+
*
|
|
57
|
+
* @param plugin - The plugin that the command invocation belongs to.
|
|
58
|
+
* @param folder - The file to invoke the command for.
|
|
59
|
+
* @param createCommandInvocationForFiles - The function to create a command invocation for files.
|
|
60
|
+
*/
|
|
61
|
+
constructor(plugin, folder, createCommandInvocationForFiles) {
|
|
62
|
+
super(plugin, folder);
|
|
63
|
+
this.createCommandInvocationForFiles = createCommandInvocationForFiles;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Checks if the command can execute.
|
|
67
|
+
*
|
|
68
|
+
* @returns Whether the command can execute.
|
|
69
|
+
*/
|
|
70
|
+
canExecute() {
|
|
71
|
+
return super.canExecute() && this.createCommandInvocationForFiles([this.folder]).invoke(true);
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Executes the command.
|
|
75
|
+
*
|
|
76
|
+
* @returns A promise that resolves when the command has been executed.
|
|
77
|
+
*/
|
|
78
|
+
async execute() {
|
|
79
|
+
await this.createCommandInvocationForFiles([this.folder]).invokeAsync(false);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
34
82
|
class FolderCommandBase extends AbstractFileCommandBase {
|
|
35
83
|
/**
|
|
36
84
|
* Creates a new abstract file command invocation.
|
|
@@ -120,25 +168,6 @@ class FolderCommandBase extends AbstractFileCommandBase {
|
|
|
120
168
|
return false;
|
|
121
169
|
}
|
|
122
170
|
}
|
|
123
|
-
class FolderCommandInvocationBase extends AbstractFileCommandInvocationBase {
|
|
124
|
-
/**
|
|
125
|
-
* Gets the folder that the command invocation belongs to.
|
|
126
|
-
*
|
|
127
|
-
* @returns The folder that the command invocation belongs to.
|
|
128
|
-
* @throws If the abstract file is not a folder.
|
|
129
|
-
*/
|
|
130
|
-
get folder() {
|
|
131
|
-
return asFolder(this._abstractFile);
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* Checks if the command can execute.
|
|
135
|
-
*
|
|
136
|
-
* @returns Whether the command can execute.
|
|
137
|
-
*/
|
|
138
|
-
canExecute() {
|
|
139
|
-
return super.canExecute() && !!this.folder;
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
171
|
class FoldersCommandInvocationBase extends AbstractFilesCommandInvocationBase {
|
|
143
172
|
/**
|
|
144
173
|
* Creates a new folders command invocation.
|
|
@@ -169,7 +198,7 @@ class SequentialFoldersCommandInvocationBase extends FoldersCommandInvocationBas
|
|
|
169
198
|
* @returns Whether the command can execute.
|
|
170
199
|
*/
|
|
171
200
|
canExecute() {
|
|
172
|
-
return super.canExecute() && this.folders.every((folder) => this.createCommandInvocationForFolder(folder).invoke(true));
|
|
201
|
+
return super.canExecute() && this.folders.length > 0 && this.folders.every((folder) => this.createCommandInvocationForFolder(folder).invoke(true));
|
|
173
202
|
}
|
|
174
203
|
/**
|
|
175
204
|
* Executes the command.
|
|
@@ -183,9 +212,10 @@ class SequentialFoldersCommandInvocationBase extends FoldersCommandInvocationBas
|
|
|
183
212
|
}
|
|
184
213
|
}
|
|
185
214
|
export {
|
|
215
|
+
ArrayDelegatingFolderCommandInvocation,
|
|
186
216
|
FolderCommandBase,
|
|
187
217
|
FolderCommandInvocationBase,
|
|
188
218
|
FoldersCommandInvocationBase,
|
|
189
219
|
SequentialFoldersCommandInvocationBase
|
|
190
220
|
};
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Commands/FolderCommandBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base classes for folder commands.\n */\n\nimport type {\n  Plugin,\n  TAbstractFile,\n  WorkspaceLeaf\n} from 'obsidian';\n\nimport { TFolder } from 'obsidian';\n\nimport {\n  asArrayOfFolders,\n  asFolder,\n  asFolderOrNull,\n  isFolder\n} from '../FileSystem.ts';\nimport {\n  AbstractFileCommandBase,\n  AbstractFileCommandInvocationBase,\n  AbstractFilesCommandInvocationBase\n} from './AbstractFileCommandBase.ts';\n\n/**\n * Base class for folder commands.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FolderCommandBase<TPlugin extends Plugin = Plugin> extends AbstractFileCommandBase<TPlugin> {\n  /**\n   * Creates a new abstract file command invocation.\n   *\n   * @param abstractFile - The abstract file to invoke the command for.\n   * @returns A new abstract file command invocation.\n   */\n  protected override createCommandInvocation(abstractFile?: TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    const folder = asFolderOrNull(abstractFile ?? null) ?? this.app.workspace.getActiveFile()?.parent ?? null;\n    return this.createCommandInvocationForFolder(folder);\n  }\n\n  /**\n   * Creates a new abstract file command invocation for an abstract file.\n   *\n   * @param abstractFile - The abstract file to invoke the command for.\n   * @returns A new abstract file command invocation.\n   */\n  protected override createCommandInvocationForAbstractFile(abstractFile: null | TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFolder(asFolderOrNull(abstractFile));\n  }\n\n  /**\n   * Creates a new abstract files command invocation for abstract files.\n   *\n   * @param abstractFiles - The abstract files to invoke the command for.\n   * @returns A new abstract files command invocation.\n   */\n  protected override createCommandInvocationForAbstractFiles(abstractFiles: TAbstractFile[]): AbstractFilesCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFolders(asArrayOfFolders(abstractFiles));\n  }\n\n  /**\n   * Creates a new abstract file command invocation for a folder.\n   *\n   * @param folder - The folder to invoke the command for.\n   * @returns A new folder command invocation.\n   */\n  protected abstract createCommandInvocationForFolder(folder: null | TFolder): FolderCommandInvocationBase<TPlugin>;\n\n  /**\n   * Creates a new folders command invocation for folders.\n   *\n   * @param folders - The folders to invoke the command for.\n   * @returns A new folders command invocation.\n   */\n  protected createCommandInvocationForFolders(folders: TFolder[]): FoldersCommandInvocationBase<TPlugin> {\n    return new SequentialFoldersCommandInvocationBase(this.plugin, folders, this.createCommandInvocationForFolder.bind(this));\n  }\n\n  /**\n   * Checks if the command should be added to the abstract file menu.\n   *\n   * @param abstractFile - The abstract file to check.\n   * @param source - The source of the abstract file.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract file menu.\n   */\n  protected override shouldAddToAbstractFileMenu(abstractFile: TAbstractFile, source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!isFolder(abstractFile)) {\n      return false;\n    }\n    return this.shouldAddToFolderMenu(abstractFile, source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the abstract files menu.\n   *\n   * @param abstractFiles - The abstract files to check.\n   * @param source - The source of the abstract files.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract files menu.\n   */\n  protected override shouldAddToAbstractFilesMenu(abstractFiles: TAbstractFile[], source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!abstractFiles.every((abstractFile) => isFolder(abstractFile))) {\n      return false;\n    }\n    return this.shouldAddToFoldersMenu(asArrayOfFolders(abstractFiles), source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the folder menu.\n   *\n   * @param _folder - The folder to check.\n   * @param _source - The source of the folder.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the folder menu.\n   */\n  protected shouldAddToFolderMenu(_folder: TFolder, _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n\n  /**\n   * Checks if the command should be added to the folders menu.\n   *\n   * @param _folders - The folders to check.\n   * @param _source - The source of the folders.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the folders menu.\n   */\n  protected shouldAddToFoldersMenu(_folders: TFolder[], _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n}\n\n/**\n * Base class for folder command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FolderCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {\n  /**\n   * Gets the folder that the command invocation belongs to.\n   *\n   * @returns The folder that the command invocation belongs to.\n   * @throws If the abstract file is not a folder.\n   */\n  protected get folder(): TFolder {\n    return asFolder(this._abstractFile);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && !!this.folder;\n  }\n}\n\n/**\n * Base class for folders command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FoldersCommandInvocationBase<TPlugin extends Plugin> extends AbstractFilesCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new folders command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param folders - The folders to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, public readonly folders: TFolder[]) {\n    super(plugin, folders);\n  }\n}\n\n/**\n * Base class for sequential folders command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class SequentialFoldersCommandInvocationBase<TPlugin extends Plugin> extends FoldersCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new sequential folders command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param folders - The folders to invoke the command for.\n   * @param createCommandInvocationForFolder - The function to create a command invocation for a folder.\n   */\n  public constructor(\n    plugin: TPlugin,\n    folders: TFolder[],\n    private readonly createCommandInvocationForFolder: (folder: TFolder) => FolderCommandInvocationBase<TPlugin>\n  ) {\n    super(plugin, folders);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && this.folders.every((folder) => this.createCommandInvocationForFolder(folder).invoke(true));\n  }\n\n  /**\n   * Executes the command.\n   *\n   * @returns A promise that resolves when the command has been executed.\n   */\n  protected override async execute(): Promise<void> {\n    for (const folder of this.folders) {\n      await this.createCommandInvocationForFolder(folder).invokeAsync(false);\n    }\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAYA,SAAS,eAAe;AAExB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAOA,MAAe,0BAA2D,wBAAiC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAO7F,wBAAwB,cAA0E;AACnH,UAAM,SAAS,eAAe,gBAAgB,IAAI,KAAK,KAAK,IAAI,UAAU,cAAc,GAAG,UAAU;AACrG,WAAO,KAAK,iCAAiC,MAAM;AAAA,EACrD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQmB,uCAAuC,cAAgF;AACxI,WAAO,KAAK,iCAAiC,eAAe,YAAY,CAAC;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQmB,wCAAwC,eAA6E;AACtI,WAAO,KAAK,kCAAkC,iBAAiB,aAAa,CAAC;AAAA,EAC/E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAgBU,kCAAkC,SAA2D;AACrG,WAAO,IAAI,uCAAuC,KAAK,QAAQ,SAAS,KAAK,iCAAiC,KAAK,IAAI,CAAC;AAAA,EAC1H;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUmB,4BAA4B,cAA6B,QAAgB,MAA+B;AACzH,QAAI,CAAC,SAAS,YAAY,GAAG;AAC3B,aAAO;AAAA,IACT;AACA,WAAO,KAAK,sBAAsB,cAAc,QAAQ,IAAI;AAAA,EAC9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUmB,6BAA6B,eAAgC,QAAgB,MAA+B;AAC7H,QAAI,CAAC,cAAc,MAAM,CAAC,iBAAiB,SAAS,YAAY,CAAC,GAAG;AAClE,aAAO;AAAA,IACT;AACA,WAAO,KAAK,uBAAuB,iBAAiB,aAAa,GAAG,QAAQ,IAAI;AAAA,EAClF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUU,sBAAsB,SAAkB,SAAiB,OAAgC;AACjG,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUU,uBAAuB,UAAqB,SAAiB,OAAgC;AACrG,WAAO;AAAA,EACT;AACF;AAOO,MAAe,oCAA4D,kCAA2C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAO3H,IAAc,SAAkB;AAC9B,WAAO,SAAS,KAAK,aAAa;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOmB,aAAsB;AACvC,WAAO,MAAM,WAAW,KAAK,CAAC,CAAC,KAAK;AAAA,EACtC;AACF;AAOO,MAAe,qCAA6D,mCAA4C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOtH,YAAY,QAAiC,SAAoB;AACtE,UAAM,QAAQ,OAAO;AAD6B;AAAA,EAEpD;AACF;AAOO,MAAM,+CAAuE,6BAAsC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQjH,YACL,QACA,SACiB,kCACjB;AACA,UAAM,QAAQ,OAAO;AAFJ;AAAA,EAGnB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOmB,aAAsB;AACvC,WAAO,MAAM,WAAW,KAAK,KAAK,QAAQ,MAAM,CAAC,WAAW,KAAK,iCAAiC,MAAM,EAAE,OAAO,IAAI,CAAC;AAAA,EACxH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAyB,UAAyB;AAChD,eAAW,UAAU,KAAK,SAAS;AACjC,YAAM,KAAK,iCAAiC,MAAM,EAAE,YAAY,KAAK;AAAA,IACvE;AAAA,EACF;AACF;",
  "names": []
}

|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Commands/FolderCommandBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base classes for folder commands.\n */\n\nimport type {\n  Plugin,\n  TAbstractFile,\n  WorkspaceLeaf\n} from 'obsidian';\n\nimport { TFolder } from 'obsidian';\n\nimport {\n  asArrayOfFolders,\n  asFolder,\n  asFolderOrNull,\n  isFolder\n} from '../FileSystem.ts';\nimport {\n  AbstractFileCommandBase,\n  AbstractFileCommandInvocationBase,\n  AbstractFilesCommandInvocationBase\n} from './AbstractFileCommandBase.ts';\n\n/**\n * Base class for folder command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FolderCommandInvocationBase<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {\n  /**\n   * Gets the folder that the command invocation belongs to.\n   *\n   * @returns The folder that the command invocation belongs to.\n   * @throws If the abstract file is not a folder.\n   */\n  protected get folder(): TFolder {\n    return asFolder(this._abstractFile);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && !!this.folder;\n  }\n}\n\n/**\n * Base class for array-delegating file command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class ArrayDelegatingFolderCommandInvocation<TPlugin extends Plugin> extends FolderCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new array-delegating folder command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param folder - The file to invoke the command for.\n   * @param createCommandInvocationForFiles - The function to create a command invocation for files.\n   */\n  public constructor(\n    plugin: TPlugin,\n    folder: null | TFolder,\n    private readonly createCommandInvocationForFiles: (folders: TFolder[]) => FoldersCommandInvocationBase<TPlugin>\n  ) {\n    super(plugin, folder);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && this.createCommandInvocationForFiles([this.folder]).invoke(true);\n  }\n\n  /**\n   * Executes the command.\n   *\n   * @returns A promise that resolves when the command has been executed.\n   */\n  protected override async execute(): Promise<void> {\n    await this.createCommandInvocationForFiles([this.folder]).invokeAsync(false);\n  }\n}\n\n/**\n * Base class for folder commands.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FolderCommandBase<TPlugin extends Plugin = Plugin> extends AbstractFileCommandBase<TPlugin> {\n  /**\n   * Creates a new abstract file command invocation.\n   *\n   * @param abstractFile - The abstract file to invoke the command for.\n   * @returns A new abstract file command invocation.\n   */\n  protected override createCommandInvocation(abstractFile?: TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    const folder = asFolderOrNull(abstractFile ?? null) ?? this.app.workspace.getActiveFile()?.parent ?? null;\n    return this.createCommandInvocationForFolder(folder);\n  }\n\n  /**\n   * Creates a new abstract file command invocation for an abstract file.\n   *\n   * @param abstractFile - The abstract file to invoke the command for.\n   * @returns A new abstract file command invocation.\n   */\n  protected override createCommandInvocationForAbstractFile(abstractFile: null | TAbstractFile): AbstractFileCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFolder(asFolderOrNull(abstractFile));\n  }\n\n  /**\n   * Creates a new abstract files command invocation for abstract files.\n   *\n   * @param abstractFiles - The abstract files to invoke the command for.\n   * @returns A new abstract files command invocation.\n   */\n  protected override createCommandInvocationForAbstractFiles(abstractFiles: TAbstractFile[]): AbstractFilesCommandInvocationBase<TPlugin> {\n    return this.createCommandInvocationForFolders(asArrayOfFolders(abstractFiles));\n  }\n\n  /**\n   * Creates a new abstract file command invocation for a folder.\n   *\n   * @param folder - The folder to invoke the command for.\n   * @returns A new folder command invocation.\n   */\n  protected abstract createCommandInvocationForFolder(folder: null | TFolder): FolderCommandInvocationBase<TPlugin>;\n\n  /**\n   * Creates a new folders command invocation for folders.\n   *\n   * @param folders - The folders to invoke the command for.\n   * @returns A new folders command invocation.\n   */\n  protected createCommandInvocationForFolders(folders: TFolder[]): FoldersCommandInvocationBase<TPlugin> {\n    return new SequentialFoldersCommandInvocationBase(this.plugin, folders, this.createCommandInvocationForFolder.bind(this));\n  }\n\n  /**\n   * Checks if the command should be added to the abstract file menu.\n   *\n   * @param abstractFile - The abstract file to check.\n   * @param source - The source of the abstract file.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract file menu.\n   */\n  protected override shouldAddToAbstractFileMenu(abstractFile: TAbstractFile, source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!isFolder(abstractFile)) {\n      return false;\n    }\n    return this.shouldAddToFolderMenu(abstractFile, source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the abstract files menu.\n   *\n   * @param abstractFiles - The abstract files to check.\n   * @param source - The source of the abstract files.\n   * @param leaf - The leaf to check.\n   * @returns Whether the command should be added to the abstract files menu.\n   */\n  protected override shouldAddToAbstractFilesMenu(abstractFiles: TAbstractFile[], source: string, leaf?: WorkspaceLeaf): boolean {\n    if (!abstractFiles.every((abstractFile) => isFolder(abstractFile))) {\n      return false;\n    }\n    return this.shouldAddToFoldersMenu(asArrayOfFolders(abstractFiles), source, leaf);\n  }\n\n  /**\n   * Checks if the command should be added to the folder menu.\n   *\n   * @param _folder - The folder to check.\n   * @param _source - The source of the folder.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the folder menu.\n   */\n  protected shouldAddToFolderMenu(_folder: TFolder, _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n\n  /**\n   * Checks if the command should be added to the folders menu.\n   *\n   * @param _folders - The folders to check.\n   * @param _source - The source of the folders.\n   * @param _leaf - The leaf to check.\n   * @returns Whether the command should be added to the folders menu.\n   */\n  protected shouldAddToFoldersMenu(_folders: TFolder[], _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\n  }\n}\n\n/**\n * Base class for folders command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class FoldersCommandInvocationBase<TPlugin extends Plugin> extends AbstractFilesCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new folders command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param folders - The folders to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, public readonly folders: TFolder[]) {\n    super(plugin, folders);\n  }\n}\n\n/**\n * Base class for sequential folders command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class SequentialFoldersCommandInvocationBase<TPlugin extends Plugin> extends FoldersCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new sequential folders command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param folders - The folders to invoke the command for.\n   * @param createCommandInvocationForFolder - The function to create a command invocation for a folder.\n   */\n  public constructor(\n    plugin: TPlugin,\n    folders: TFolder[],\n    private readonly createCommandInvocationForFolder: (folder: TFolder) => FolderCommandInvocationBase<TPlugin>\n  ) {\n    super(plugin, folders);\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  protected override canExecute(): boolean {\n    return super.canExecute() && this.folders.length > 0 && this.folders.every((folder) => this.createCommandInvocationForFolder(folder).invoke(true));\n  }\n\n  /**\n   * Executes the command.\n   *\n   * @returns A promise that resolves when the command has been executed.\n   */\n  protected override async execute(): Promise<void> {\n    for (const folder of this.folders) {\n      await this.createCommandInvocationForFolder(folder).invokeAsync(false);\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -19,7 +19,10 @@ if you want to view the source, please visit the github repository of this plugi
|
|
|
19
19
|
globalThis.process = browserProcess;
|
|
20
20
|
})();
|
|
21
21
|
|
|
22
|
-
import {
|
|
22
|
+
import {
|
|
23
|
+
requireApiVersion,
|
|
24
|
+
Setting
|
|
25
|
+
} from "obsidian";
|
|
23
26
|
import { CheckboxComponent } from "./Components/SettingComponents/CheckboxComponent.mjs";
|
|
24
27
|
import { CodeHighlighterComponent } from "./Components/SettingComponents/CodeHighlighterComponent.mjs";
|
|
25
28
|
import { DateComponent } from "./Components/SettingComponents/DateComponent.mjs";
|
|
@@ -68,7 +71,7 @@ class SettingEx extends Setting {
|
|
|
68
71
|
* @returns The setting instance.
|
|
69
72
|
*/
|
|
70
73
|
addComponentClass(componentClass, cb) {
|
|
71
|
-
return this.
|
|
74
|
+
return this.addComponentSafe((el) => {
|
|
72
75
|
const component = new componentClass(el);
|
|
73
76
|
cb(component);
|
|
74
77
|
return component;
|
|
@@ -236,8 +239,20 @@ class SettingEx extends Setting {
|
|
|
236
239
|
addWeek(cb) {
|
|
237
240
|
return this.addComponentClass(WeekComponent, cb);
|
|
238
241
|
}
|
|
242
|
+
addComponentSafe(cb) {
|
|
243
|
+
if (requireApiVersion("1.11.0")) {
|
|
244
|
+
return this.addComponent((el) => {
|
|
245
|
+
if (!requireApiVersion("0.16.0")) {
|
|
246
|
+
return cb(el);
|
|
247
|
+
}
|
|
248
|
+
return cb(el);
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
this.components.push(cb(this.controlEl));
|
|
252
|
+
return this;
|
|
253
|
+
}
|
|
239
254
|
}
|
|
240
255
|
export {
|
|
241
256
|
SettingEx
|
|
242
257
|
};
|
|
243
|
-
//# 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 { CodeHighlighterComponent } from './Components/SettingComponents/CodeHighlighterComponent.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 { PasswordComponent } from './Components/SettingComponents/PasswordComponent.ts';\nimport { TelephoneComponent } from './Components/SettingComponents/TelephoneComponent.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: (checkbox: CheckboxComponent) => void): this {\n    return this.addComponentClass(CheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a {@link CodeHighlighterComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addCodeHighlighter(cb: (codeHighlighter: CodeHighlighterComponent) => void): this {\n    return this.addComponentClass(CodeHighlighterComponent, 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 addComponentClass<T extends BaseComponent>(componentClass: new (containerEl: HTMLElement) => T, cb: (component: T) => void): this {\n    return this.addComponent<T>((el) => {\n      const component = new componentClass(el);\n      cb(component);\n      return component;\n    });\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: (date: DateComponent) => void): this {\n    return this.addComponentClass(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: (dateTime: DateTimeComponent) => void): this {\n    return this.addComponentClass(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: (email: EmailComponent) => void): this {\n    return this.addComponentClass(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: (file: FileComponent) => void): this {\n    return this.addComponentClass(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: (month: MonthComponent) => void): this {\n    return this.addComponentClass(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: (multipleDropdown: MultipleDropdownComponent) => void): this {\n    return this.addComponentClass(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: (multipleEmail: MultipleEmailComponent) => void): this {\n    return this.addComponentClass(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: (multipleFile: MultipleFileComponent) => void): this {\n    return this.addComponentClass(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: (multipleText: MultipleTextComponent) => void): this {\n    return this.addComponentClass(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: (number: NumberComponent) => void): this {\n    return this.addComponentClass(NumberComponent, cb);\n  }\n\n  /**\n   * Adds a {@link PasswordComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addPassword(cb: (password: PasswordComponent) => void): this {\n    return this.addComponentClass(PasswordComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TelephoneComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTelephone(cb: (telephone: TelephoneComponent) => void): this {\n    return this.addComponentClass(TelephoneComponent, 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: (time: TimeComponent) => void): this {\n    return this.addComponentClass(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: (triStateCheckbox: TriStateCheckboxComponent) => void): this {\n    return this.addComponentClass(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: (typedDropdown: TypedDropdownComponent<T>) => void): this {\n    return this.addComponentClass(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: (typedMultipleDropdown: TypedMultipleDropdownComponent<T>) => void): this {\n    return this.addComponentClass(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: (url: UrlComponent) => void): this {\n    return this.addComponentClass(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: (week: WeekComponent) => void): this {\n    return this.addComponentClass(WeekComponent, cb);\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
258
|
+
//# 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 {\n  requireApiVersion,\n  Setting\n} from 'obsidian';\n\nimport { CheckboxComponent } from './Components/SettingComponents/CheckboxComponent.ts';\nimport { CodeHighlighterComponent } from './Components/SettingComponents/CodeHighlighterComponent.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 { PasswordComponent } from './Components/SettingComponents/PasswordComponent.ts';\nimport { TelephoneComponent } from './Components/SettingComponents/TelephoneComponent.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: (checkbox: CheckboxComponent) => void): this {\n    return this.addComponentClass(CheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a {@link CodeHighlighterComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addCodeHighlighter(cb: (codeHighlighter: CodeHighlighterComponent) => void): this {\n    return this.addComponentClass(CodeHighlighterComponent, 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 addComponentClass<T extends BaseComponent>(componentClass: new (containerEl: HTMLElement) => T, cb: (component: T) => void): this {\n    return this.addComponentSafe((el) => {\n      const component = new componentClass(el);\n      cb(component);\n      return component;\n    });\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: (date: DateComponent) => void): this {\n    return this.addComponentClass(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: (dateTime: DateTimeComponent) => void): this {\n    return this.addComponentClass(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: (email: EmailComponent) => void): this {\n    return this.addComponentClass(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: (file: FileComponent) => void): this {\n    return this.addComponentClass(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: (month: MonthComponent) => void): this {\n    return this.addComponentClass(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: (multipleDropdown: MultipleDropdownComponent) => void): this {\n    return this.addComponentClass(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: (multipleEmail: MultipleEmailComponent) => void): this {\n    return this.addComponentClass(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: (multipleFile: MultipleFileComponent) => void): this {\n    return this.addComponentClass(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: (multipleText: MultipleTextComponent) => void): this {\n    return this.addComponentClass(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: (number: NumberComponent) => void): this {\n    return this.addComponentClass(NumberComponent, cb);\n  }\n\n  /**\n   * Adds a {@link PasswordComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addPassword(cb: (password: PasswordComponent) => void): this {\n    return this.addComponentClass(PasswordComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TelephoneComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTelephone(cb: (telephone: TelephoneComponent) => void): this {\n    return this.addComponentClass(TelephoneComponent, 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: (time: TimeComponent) => void): this {\n    return this.addComponentClass(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: (triStateCheckbox: TriStateCheckboxComponent) => void): this {\n    return this.addComponentClass(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: (typedDropdown: TypedDropdownComponent<T>) => void): this {\n    return this.addComponentClass(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: (typedMultipleDropdown: TypedMultipleDropdownComponent<T>) => void): this {\n    return this.addComponentClass(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: (url: UrlComponent) => void): this {\n    return this.addComponentClass(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: (week: WeekComponent) => void): this {\n    return this.addComponentClass(WeekComponent, cb);\n  }\n\n  private addComponentSafe(cb: (el: HTMLElement) => BaseComponent): this {\n    if (requireApiVersion('1.11.0')) {\n      return this.addComponent((el) => {\n        if (!requireApiVersion('0.16.0')) {\n          return cb(el);\n        }\n        return cb(el);\n      });\n    }\n\n    this.components.push(cb(this.controlEl));\n    return this;\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|