obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
331 lines (317 loc) • 26.9 kB
JavaScript
/*
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
if you want to view the source, please visit the github repository of this plugin
*/
(function initCjs() {
const globalThisRecord = globalThis;
globalThisRecord['__name'] ??= name;
const originalRequire = require;
if (originalRequire && !originalRequire.__isPatched) {
// eslint-disable-next-line no-global-assign, no-implicit-globals -- We need to patch the `require()` function.
require = Object.assign(
(id) => requirePatched(id),
originalRequire,
{
__isPatched: true
}
);
}
const newFuncs = {
__extractDefault() {
return extractDefault;
},
process() {
const browserProcess = {
browser: true,
cwd() {
return '/';
},
env: {},
platform: 'android'
};
return browserProcess;
}
};
for (const key of Object.keys(newFuncs)) {
globalThisRecord[key] ??= newFuncs[key]?.();
}
function name(obj) {
return obj;
}
function extractDefault(module) {
return module && module.__esModule && 'default' in module ? module.default : module;
}
const OBSIDIAN_BUILT_IN_MODULE_NAMES = [
'obsidian',
'@codemirror/autocomplete',
'@codemirror/collab',
'@codemirror/commands',
'@codemirror/language',
'@codemirror/lint',
'@codemirror/search',
'@codemirror/state',
'@codemirror/text',
'@codemirror/view',
'@lezer/common',
'@lezer/lr',
'@lezer/highlight'];
const DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES = [
'@codemirror/closebrackets',
'@codemirror/comment',
'@codemirror/fold',
'@codemirror/gutter',
'@codemirror/highlight',
'@codemirror/history',
'@codemirror/matchbrackets',
'@codemirror/panel',
'@codemirror/rangeset',
'@codemirror/rectangular-selection',
'@codemirror/stream-parser',
'@codemirror/tooltip'];
function requirePatched(id) {
if (OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id) || DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id)) {
return originalRequire?.(id);
}
// eslint-disable-next-line @typescript-eslint/no-deprecated, @typescript-eslint/no-unnecessary-condition -- We need access to app here which might not be available yet.
if (globalThis?.app?.isMobile) {
if (id === 'process' || id === 'node:process') {
console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Fake process object is returned instead.`);
return globalThis.process;
}
} else {
const module = originalRequire?.(id);
if (module) {
return extractDefault(module);
}
}
console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Empty object is returned instead.`);
return {};
}
})();
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var FileCommandBase_exports = {};
__export(FileCommandBase_exports, {
ArrayDelegatingFileCommandInvocation: () => ArrayDelegatingFileCommandInvocation,
FileCommandBase: () => FileCommandBase,
FileCommandInvocationBase: () => FileCommandInvocationBase,
FilesCommandInvocationBase: () => FilesCommandInvocationBase,
SequentialFilesCommandInvocationBase: () => SequentialFilesCommandInvocationBase
});
module.exports = __toCommonJS(FileCommandBase_exports);
var import_obsidian = require('obsidian');
var import_FileSystem = require('../FileSystem.cjs');
var import_AbstractFileCommandBase = require('./AbstractFileCommandBase.cjs');
class FileCommandInvocationBase extends import_AbstractFileCommandBase.AbstractFileCommandInvocationBase {
/**
* Gets the file that the command invocation belongs to.
*
* @returns The file that the command invocation belongs to.
* @throws If the abstract file is not a file.
*/
get file() {
return (0, import_FileSystem.asFile)(this._abstractFile);
}
/**
* Creates a new file command invocation.
*
* @param plugin - The plugin that the command invocation belongs to.
* @param file - The file to invoke the command for.
*/
constructor(plugin, file) {
super(plugin, file);
}
/**
* Checks if the command can execute.
*
* @returns Whether the command can execute.
*/
canExecute() {
return super.canExecute() && !!this._abstractFile;
}
}
class ArrayDelegatingFileCommandInvocation extends FileCommandInvocationBase {
/**
* Creates a new array-delegating file command invocation.
*
* @param plugin - The plugin that the command invocation belongs to.
* @param file - The file to invoke the command for.
* @param createCommandInvocationForFiles - The function to create a command invocation for files.
*/
constructor(plugin, file, createCommandInvocationForFiles) {
super(plugin, file);
this.createCommandInvocationForFiles = createCommandInvocationForFiles;
}
/**
* Checks if the command can execute.
*
* @returns Whether the command can execute.
*/
canExecute() {
return super.canExecute() && this.createCommandInvocationForFiles([this.file]).invoke(true);
}
/**
* Executes the command.
*
* @returns A promise that resolves when the command has been executed.
*/
async execute() {
await this.createCommandInvocationForFiles([this.file]).invokeAsync(false);
}
}
class FileCommandBase extends import_AbstractFileCommandBase.AbstractFileCommandBase {
/**
* Creates a new abstract file command invocation.
*
* @param abstractFile - The abstract file to invoke the command for.
* @returns The command invocation.
*/
createCommandInvocation(abstractFile) {
return this.createCommandInvocationForAbstractFile(abstractFile ?? this.app.workspace.getActiveFile());
}
/**
* Creates a new abstract file command invocation for an abstract file.
*
* @param abstractFile - The abstract file to invoke the command for. If `null`, the active file is used.
* @returns The command invocation.
*/
createCommandInvocationForAbstractFile(abstractFile) {
return this.createCommandInvocationForFile((0, import_FileSystem.asFileOrNull)(abstractFile));
}
/**
* Creates a new abstract files command invocation for abstract files.
*
* @param abstractFiles - The abstract files to invoke the command for.
* @returns A new abstract files command invocation.
*/
createCommandInvocationForAbstractFiles(abstractFiles) {
return this.createCommandInvocationForFiles((0, import_FileSystem.asArrayOfFiles)(abstractFiles));
}
/**
* Creates a new files command invocation for files.
*
* @param files - The files to invoke the command for.
* @returns A new files command invocation.
*/
createCommandInvocationForFiles(files) {
return new SequentialFilesCommandInvocationBase(this.plugin, files, this.createCommandInvocationForFile.bind(this));
}
/**
* Checks if the command should be added to the abstract file menu.
*
* @param abstractFile - The abstract file to check.
* @param source - The source of the abstract file.
* @param leaf - The leaf to check.
* @returns Whether the command should be added to the abstract file menu.
*/
shouldAddToAbstractFileMenu(abstractFile, source, leaf) {
if (!(0, import_FileSystem.isFile)(abstractFile)) {
return false;
}
return this.shouldAddToFileMenu(abstractFile, source, leaf);
}
/**
* Checks if the command should be added to the abstract files menu.
*
* @param abstractFiles - The abstract files to check.
* @param source - The source of the abstract files.
* @param leaf - The leaf to check.
* @returns Whether the command should be added to the abstract files menu.
*/
shouldAddToAbstractFilesMenu(abstractFiles, source, leaf) {
if (!abstractFiles.every((abstractFile) => (0, import_FileSystem.isFile)(abstractFile))) {
return false;
}
return this.shouldAddToFilesMenu((0, import_FileSystem.asArrayOfFiles)(abstractFiles), source, leaf);
}
/**
* Checks if the command should be added to the file menu.
*
* @param _file - The file to check.
* @param _source - The source of the file.
* @param _leaf - The leaf to check.
* @returns Whether the command should be added to the file menu.
*/
shouldAddToFileMenu(_file, _source, _leaf) {
return false;
}
/**
* Checks if the command should be added to the files menu.
*
* @param _files - The files to check.
* @param _source - The source of the files.
* @param _leaf - The leaf to check.
* @returns Whether the command should be added to the files menu.
*/
shouldAddToFilesMenu(_files, _source, _leaf) {
return false;
}
}
class FilesCommandInvocationBase extends import_AbstractFileCommandBase.AbstractFilesCommandInvocationBase {
/**
* Creates a new files command invocation.
*
* @param plugin - The plugin that the command invocation belongs to.
* @param files - The files to invoke the command for.
*/
constructor(plugin, files) {
super(plugin, files);
this.files = files;
}
}
class SequentialFilesCommandInvocationBase extends FilesCommandInvocationBase {
/**
* Creates a new sequential files command invocation.
*
* @param plugin - The plugin that the command invocation belongs to.
* @param files - The files to invoke the command for.
* @param createCommandInvocationForFile - The function to create a command invocation for a file.
*/
constructor(plugin, files, createCommandInvocationForFile) {
super(plugin, files);
this.createCommandInvocationForFile = createCommandInvocationForFile;
}
/**
* Checks if the command can execute.
*
* @returns Whether the command can execute.
*/
canExecute() {
return super.canExecute() && this.files.length > 0 && this.files.every((file) => this.createCommandInvocationForFile(file).invoke(true));
}
/**
* Executes the command.
*
* @returns A promise that resolves when the command has been executed.
*/
async execute() {
for (const file of this.files) {
await this.createCommandInvocationForFile(file).invokeAsync(false);
}
}
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
ArrayDelegatingFileCommandInvocation,
FileCommandBase,
FileCommandInvocationBase,
FilesCommandInvocationBase,
SequentialFilesCommandInvocationBase
});
//# 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": []
}
