UNPKG

obsidian-dev-utils

Version:

This is the collection of useful functions that you can use for your Obsidian plugin development

361 lines (347 loc) 30.9 kB
/* 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 {}; } })(); "use strict"; 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 AbstractFileCommandBase_exports = {}; __export(AbstractFileCommandBase_exports, { AbstractFileCommandBase: () => AbstractFileCommandBase, AbstractFileCommandInvocationBase: () => AbstractFileCommandInvocationBase, AbstractFilesCommandInvocationBase: () => AbstractFilesCommandInvocationBase, ArrayDelegatingAbstractFileCommandInvocation: () => ArrayDelegatingAbstractFileCommandInvocation, SequentialAbstractFilesCommandInvocationBase: () => SequentialAbstractFilesCommandInvocationBase }); module.exports = __toCommonJS(AbstractFileCommandBase_exports); var import_CommandBase = require('./CommandBase.cjs'); var import_NonEditorCommandBase = require('./NonEditorCommandBase.cjs'); class AbstractFileCommandBase extends import_NonEditorCommandBase.NonEditorCommandBase { /** * The item name to use in the file menu. */ fileMenuItemName; /** * The section to use in the file menu. */ fileMenuSection; /** * The item name to use in the files menu. */ filesMenuItemName; /** * The section to use in the files menu. */ filesMenuSection; /** * Checks if the command can execute or executes it. * * @param checking - Is checking mode only. If `true`, only the check if the command can execute is performed. If `false`, the command is executed. * @returns Whether the command can execute. */ checkCallback(checking) { if (!this.shouldAddToCommandPalette()) { return false; } return super.checkCallback(checking); } /** * Registers the command. */ register() { super.register(); this.plugin.registerEvent(this.app.workspace.on("file-menu", this.handleAbstractFileMenu.bind(this))); this.plugin.registerEvent(this.app.workspace.on("files-menu", this.handleAbstractFilesMenu.bind(this))); } /** * Creates a new file command invocation. * * @param abstractFile - The abstract file to create the command invocation for. * @returns The command invocation. */ createCommandInvocation(abstractFile) { return this.createCommandInvocationForAbstractFile(abstractFile ?? this.app.workspace.getActiveFile()); } /** * Creates a new command invocation for abstract files. * * @param abstractFiles - The abstract files to create the command invocation for. * @returns The command invocation. */ createCommandInvocationForAbstractFiles(abstractFiles) { return new SequentialAbstractFilesCommandInvocationBase(this.plugin, abstractFiles, this.createCommandInvocationForAbstractFile.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) { return false; } /** * 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) { for (const abstractFile of abstractFiles) { if (!this.shouldAddToAbstractFileMenu(abstractFile, source, leaf)) { return false; } } return true; } /** * Checks if the command should be added to the command palette. * * @returns Whether the command should be added to the command palette. */ shouldAddToCommandPalette() { return true; } handleAbstractFileMenu(menu, abstractFile, source, leaf) { if (!this.shouldAddToAbstractFileMenu(abstractFile, source, leaf)) { return; } if (!this.createCommandInvocation(abstractFile).invoke(true)) { return; } menu.addItem((item) => { item.setTitle(this.fileMenuItemName ?? this.originalName).setIcon(this.icon).setSection(this.fileMenuSection ?? "").onClick(() => this.createCommandInvocation(abstractFile).invoke(false)); }); } handleAbstractFilesMenu(menu, abstractFiles, source, leaf) { if (!this.shouldAddToAbstractFilesMenu(abstractFiles, source, leaf)) { return; } if (!this.createCommandInvocationForAbstractFiles(abstractFiles).invoke(true)) { return; } menu.addItem((item) => { item.setTitle(this.filesMenuItemName ?? this.fileMenuItemName ?? this.originalName).setIcon(this.icon).setSection(this.filesMenuSection ?? this.fileMenuSection ?? "").onClick(() => this.createCommandInvocationForAbstractFiles(abstractFiles).invoke(false)); }); } } class AbstractFileCommandInvocationBase extends import_CommandBase.CommandInvocationBase { /** */ _abstractFile; /** * The abstract file to invoke the command for. * * @returns The abstract file to invoke the command for. * @throws If the abstract file is not set. */ get abstractFile() { if (!this._abstractFile) { throw new Error("Abstract file not set"); } return this._abstractFile; } /** * Creates a new abstract file command invocation. * * @param plugin - The plugin that the command belongs to. * @param abstractFile - The abstract file to invoke the command for. */ constructor(plugin, abstractFile) { super(plugin); this._abstractFile = abstractFile; } /** * Checks if the command can execute. * * @returns Whether the command can execute. */ canExecute() { return super.canExecute() && !!this._abstractFile; } } class AbstractFilesCommandInvocationBase extends import_CommandBase.CommandInvocationBase { /** * Creates a new abstract files command invocation. * * @param plugin - The plugin that the command belongs to. * @param abstractFiles - The abstract files to invoke the command for. */ constructor(plugin, abstractFiles) { super(plugin); this.abstractFiles = abstractFiles; } } class ArrayDelegatingAbstractFileCommandInvocation extends AbstractFileCommandInvocationBase { /** * Creates a new array-delegating abstract file command invocation. * * @param plugin - The plugin that the command invocation belongs to. * @param abstractFile - The abstract file to invoke the command for. * @param createCommandInvocationForFiles - The function to create a command invocation for files. */ constructor(plugin, abstractFile, createCommandInvocationForFiles) { super(plugin, abstractFile); this.createCommandInvocationForFiles = createCommandInvocationForFiles; } /** * Checks if the command can execute. * * @returns Whether the command can execute. */ canExecute() { return super.canExecute() && this.createCommandInvocationForFiles([this.abstractFile]).invoke(true); } /** * Executes the command. * * @returns A promise that resolves when the command has been executed. */ async execute() { await this.createCommandInvocationForFiles([this.abstractFile]).invokeAsync(false); } } class SequentialAbstractFilesCommandInvocationBase extends AbstractFilesCommandInvocationBase { /** * Creates a new sequential files command invocation. * * @param plugin - The plugin that the command invocation belongs to. * @param abstractFiles - The files to invoke the command for. * @param createCommandInvocationForFile - The function to create a command invocation for a file. */ constructor(plugin, abstractFiles, createCommandInvocationForFile) { super(plugin, abstractFiles); this.createCommandInvocationForFile = createCommandInvocationForFile; } /** * Checks if the command can execute. * * @returns Whether the command can execute. */ canExecute() { return super.canExecute() && this.abstractFiles.length > 0 && this.abstractFiles.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 abstractFile of this.abstractFiles) { await this.createCommandInvocationForFile(abstractFile).invokeAsync(false); } } } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { AbstractFileCommandBase, AbstractFileCommandInvocationBase, AbstractFilesCommandInvocationBase, ArrayDelegatingAbstractFileCommandInvocation, SequentialAbstractFilesCommandInvocationBase }); //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Commands/AbstractFileCommandBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base classes for abstract file commands.\n */\n\nimport type {\n  Menu,\n  Plugin,\n  TAbstractFile,\n  WorkspaceLeaf\n} from 'obsidian';\n\nimport { CommandInvocationBase } from './CommandBase.ts';\nimport { NonEditorCommandBase } from './NonEditorCommandBase.ts';\n\n/**\n * Base class for abstract file commands.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class AbstractFileCommandBase<TPlugin extends Plugin = Plugin> extends NonEditorCommandBase<TPlugin> {\n  /**\n   * The item name to use in the file menu.\n   */\n  protected readonly fileMenuItemName?: string;\n\n  /**\n   * The section to use in the file menu.\n   */\n  protected readonly fileMenuSection?: string;\n\n  /**\n   * The item name to use in the files menu.\n   */\n  protected readonly filesMenuItemName?: string;\n\n  /**\n   * The section to use in the files menu.\n   */\n  protected readonly filesMenuSection?: string;\n\n  /**\n   * Checks if the command can execute or executes it.\n   *\n   * @param checking - Is checking mode only. If `true`, only the check if the command can execute is performed. If `false`, the command is executed.\n   * @returns Whether the command can execute.\n   */\n  public override checkCallback(checking: boolean): boolean {\n    if (!this.shouldAddToCommandPalette()) {\n      return false;\n    }\n    return super.checkCallback(checking);\n  }\n\n  /**\n   * Registers the command.\n   */\n  public override register(): void {\n    super.register();\n    this.plugin.registerEvent(this.app.workspace.on('file-menu', this.handleAbstractFileMenu.bind(this)));\n    this.plugin.registerEvent(this.app.workspace.on('files-menu', this.handleAbstractFilesMenu.bind(this)));\n  }\n\n  /**\n   * Creates a new file command invocation.\n   *\n   * @param abstractFile - The abstract file to create the command invocation 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 command invocation for an abstract file.\n   *\n   * @param abstractFile - The abstract file to create the command invocation for.\n   * @returns The command invocation.\n   */\n  protected abstract createCommandInvocationForAbstractFile(abstractFile: null | TAbstractFile): AbstractFileCommandInvocationBase<TPlugin>;\n\n  /**\n   * Creates a new command invocation for abstract files.\n   *\n   * @param abstractFiles - The abstract files to create the command invocation for.\n   * @returns The command invocation.\n   */\n  protected createCommandInvocationForAbstractFiles(abstractFiles: TAbstractFile[]): AbstractFilesCommandInvocationBase<TPlugin> {\n    return new SequentialAbstractFilesCommandInvocationBase(this.plugin, abstractFiles, this.createCommandInvocationForAbstractFile.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 shouldAddToAbstractFileMenu(_abstractFile: TAbstractFile, _source: string, _leaf?: WorkspaceLeaf): boolean {\n    return false;\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 shouldAddToAbstractFilesMenu(abstractFiles: TAbstractFile[], source: string, leaf?: WorkspaceLeaf): boolean {\n    for (const abstractFile of abstractFiles) {\n      if (!this.shouldAddToAbstractFileMenu(abstractFile, source, leaf)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  /**\n   * Checks if the command should be added to the command palette.\n   *\n   * @returns Whether the command should be added to the command palette.\n   */\n  protected shouldAddToCommandPalette(): boolean {\n    return true;\n  }\n\n  private handleAbstractFileMenu(menu: Menu, abstractFile: TAbstractFile, source: string, leaf?: WorkspaceLeaf): void {\n    if (!this.shouldAddToAbstractFileMenu(abstractFile, source, leaf)) {\n      return;\n    }\n\n    if (!this.createCommandInvocation(abstractFile).invoke(true)) {\n      return;\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.fileMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(this.fileMenuSection ?? '')\n        .onClick(() => this.createCommandInvocation(abstractFile).invoke(false));\n    });\n  }\n\n  private handleAbstractFilesMenu(menu: Menu, abstractFiles: TAbstractFile[], source: string, leaf?: WorkspaceLeaf): void {\n    if (!this.shouldAddToAbstractFilesMenu(abstractFiles, source, leaf)) {\n      return;\n    }\n\n    if (!this.createCommandInvocationForAbstractFiles(abstractFiles).invoke(true)) {\n      return;\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.filesMenuItemName ?? this.fileMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(this.filesMenuSection ?? this.fileMenuSection ?? '')\n        .onClick(() => this.createCommandInvocationForAbstractFiles(abstractFiles).invoke(false));\n    });\n  }\n}\n\n/**\n * Base class for abstract file command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class AbstractFileCommandInvocationBase<TPlugin extends Plugin> extends CommandInvocationBase<TPlugin> {\n  /** */\n  protected readonly _abstractFile: null | TAbstractFile;\n\n  /**\n   * The abstract file to invoke the command for.\n   *\n   * @returns The abstract file to invoke the command for.\n   * @throws If the abstract file is not set.\n   */\n  protected get abstractFile(): TAbstractFile {\n    if (!this._abstractFile) {\n      throw new Error('Abstract file not set');\n    }\n    return this._abstractFile;\n  }\n\n  /**\n   * Creates a new abstract file command invocation.\n   *\n   * @param plugin - The plugin that the command belongs to.\n   * @param abstractFile - The abstract file to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, abstractFile: null | TAbstractFile) {\n    super(plugin);\n    this._abstractFile = 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._abstractFile;\n  }\n}\n\n/**\n * Base class for abstract files command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class AbstractFilesCommandInvocationBase<TPlugin extends Plugin> extends CommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new abstract files command invocation.\n   *\n   * @param plugin - The plugin that the command belongs to.\n   * @param abstractFiles - The abstract files to invoke the command for.\n   */\n  public constructor(plugin: TPlugin, public readonly abstractFiles: TAbstractFile[]) {\n    super(plugin);\n  }\n}\n\n/**\n * Base class for array-delegating abstract file command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class ArrayDelegatingAbstractFileCommandInvocation<TPlugin extends Plugin> extends AbstractFileCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new array-delegating abstract file command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param abstractFile - The abstract 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    abstractFile: null | TAbstractFile,\n    private readonly createCommandInvocationForFiles: (abstractFiles: TAbstractFile[]) => AbstractFilesCommandInvocationBase<TPlugin>\n  ) {\n    super(plugin, 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.createCommandInvocationForFiles([this.abstractFile]).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.abstractFile]).invokeAsync(false);\n  }\n}\n\n/**\n * Base class for sequential abstract files command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class SequentialAbstractFilesCommandInvocationBase<TPlugin extends Plugin> extends AbstractFilesCommandInvocationBase<TPlugin> {\n  /**\n   * Creates a new sequential files command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param abstractFiles - The files to invoke the command for.\n   * @param createCommandInvocationForFile - The function to create a command invocation for a file.\n   */\n  public constructor(\n    plugin: TPlugin,\n    abstractFiles: TAbstractFile[],\n    private readonly createCommandInvocationForFile: (abstractFile: TAbstractFile) => AbstractFileCommandInvocationBase<TPlugin>\n  ) {\n    super(plugin, abstractFiles);\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.abstractFiles.length > 0 && this.abstractFiles.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 abstractFile of this.abstractFiles) {\n      await this.createCommandInvocationForFile(abstractFile).invokeAsync(false);\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": []
}
