obsidian-dev-utils 48.1.0 → 48.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/lib/cjs/AbortController.cjs +1 -1
  3. package/dist/lib/cjs/Async.cjs +1 -1
  4. package/dist/lib/cjs/Library.cjs +1 -1
  5. package/dist/lib/cjs/ObjectUtils.cjs +1 -1
  6. package/dist/lib/cjs/ScriptUtils/Exec.cjs +1 -1
  7. package/dist/lib/cjs/ScriptUtils/Fs.cjs +1 -1
  8. package/dist/lib/cjs/ScriptUtils/Root.cjs +1 -1
  9. package/dist/lib/cjs/obsidian/Commands/AbstractFileCommandBase.cjs +35 -35
  10. package/dist/lib/cjs/obsidian/Commands/AbstractFileCommandBase.d.cts +29 -29
  11. package/dist/lib/cjs/obsidian/Commands/EditorCommandBase.cjs +2 -1
  12. package/dist/lib/cjs/obsidian/Commands/NonEditorCommandBase.cjs +2 -1
  13. package/dist/lib/cjs/obsidian/RenameDeleteHandler.cjs +36 -36
  14. package/dist/lib/cjs/obsidian/i18n/i18n.cjs +6 -13
  15. package/dist/lib/esm/AbortController.mjs +1 -1
  16. package/dist/lib/esm/Async.mjs +1 -1
  17. package/dist/lib/esm/Library.mjs +1 -1
  18. package/dist/lib/esm/ObjectUtils.mjs +1 -1
  19. package/dist/lib/esm/ScriptUtils/Exec.mjs +1 -1
  20. package/dist/lib/esm/ScriptUtils/Fs.mjs +1 -1
  21. package/dist/lib/esm/ScriptUtils/Root.mjs +1 -1
  22. package/dist/lib/esm/obsidian/Commands/AbstractFileCommandBase.d.mts +29 -29
  23. package/dist/lib/esm/obsidian/Commands/AbstractFileCommandBase.mjs +35 -35
  24. package/dist/lib/esm/obsidian/Commands/EditorCommandBase.mjs +2 -1
  25. package/dist/lib/esm/obsidian/Commands/NonEditorCommandBase.mjs +2 -1
  26. package/dist/lib/esm/obsidian/RenameDeleteHandler.mjs +36 -36
  27. package/dist/lib/esm/obsidian/i18n/i18n.mjs +6 -2
  28. package/package.json +1 -1
@@ -178,4 +178,4 @@ function isStringResultOptions(options) {
178
178
  0 && (module.exports = {
179
179
  readdirPosix
180
180
  });
181
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/Fs.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for file system operations.\n */\n\nimport type {\n  Dirent,\n  ObjectEncodingOptions,\n  PathLike\n} from './NodeModules.ts';\n\nimport {\n  toPosixBuffer,\n  toPosixPath\n} from '../Path.ts';\nimport { readdir } from './NodeModules.ts';\n\n/**\n * Options for controlling the format of the result when returning buffers.\n *\n * `directory` is used instead of `folder` to preserve compatibility with `node:fs` module.\n */\nexport type BufferResultOptions = 'buffer' | {\n  /**\n   * Should be set to \"buffer\" to return buffers.\n   */\n  encoding: 'buffer';\n\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  recursive?: boolean;\n\n  /**\n   * Should be set to `false` to return buffers.\n   */\n  withFileTypes?: false;\n};\n\n/**\n * Options for controlling the format of the result when returning Dirent objects.\n */\nexport type DirentResultOptions = {\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  recursive?: boolean;\n\n  /**\n   * Should be set to `true` to return Dirent objects.\n   */\n  withFileTypes: true;\n} & ObjectEncodingOptions;\n\n/**\n * Options for controlling the format of the result when returning strings.\n */\nexport type StringResultOptions =\n  | {\n    /**\n     * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n     */\n    recursive?: boolean;\n\n    /**\n     * Should be set to `false` to return strings.\n     */\n    withFileTypes?: false;\n  } & ObjectEncodingOptions\n  | undefined;\n\n/**\n * Common options for controlling the format of the result.\n */\ninterface CommonOptions {\n  /**\n   * Encoding to use when returning strings.\n   */\n  encoding?: 'buffer' | NodeJS.BufferEncoding;\n\n  /**\n   * Set `true` to return Dirent objects or `false` to return strings or buffers.\n   */\n  withFileTypes?: boolean;\n}\n\n/**\n * Reads the contents of a directory and returns an array of strings with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. If not provided, returns strings.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths.\n */\nexport async function readdirPosix(path: PathLike, options?: StringResultOptions): Promise<string[]>;\n\n/**\n * Reads the contents of a directory and returns an array of buffers with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify \"buffer\" to return buffers.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted buffers.\n */\nexport async function readdirPosix(path: PathLike, options: BufferResultOptions): Promise<Buffer[]>;\n\n/**\n * Reads the contents of a directory and returns an array of Dirent objects with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify `withFileTypes: true` to return Dirent objects.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted Dirent objects.\n */\nexport async function readdirPosix(path: PathLike, options: DirentResultOptions): Promise<Dirent[]>;\n\n/**\n * Reads the contents of a directory and converts file paths or buffer results to POSIX format.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths, buffers, or Dirent objects.\n */\nexport async function readdirPosix(\n  path: PathLike,\n  options: BufferResultOptions | DirentResultOptions | StringResultOptions = {}\n): Promise<Buffer[] | Dirent[] | string[]> {\n  if (isStringResultOptions(options)) {\n    const paths = await readdir(path, options);\n    return paths.map(toPosixPath);\n  }\n\n  if (isBufferResultOptions(options)) {\n    const buffers = await readdir(path, options);\n    return buffers.map(toPosixBuffer);\n  }\n\n  const dirents = await readdir(path, options);\n  for (const dirent of dirents) {\n    dirent.name = toPosixPath(dirent.name);\n    dirent.parentPath = toPosixPath(dirent.parentPath);\n  }\n\n  return dirents;\n}\n\n/**\n * Type guard to check if the options are for returning buffers.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning buffers, otherwise `false`.\n */\nfunction isBufferResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is BufferResultOptions {\n  if (options === undefined) {\n    return false;\n  }\n\n  if (options === 'buffer') {\n    return true;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  if (commonOptions.encoding !== 'buffer') {\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Type guard to check if the options are for returning strings.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning strings, otherwise `false`.\n */\nfunction isStringResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is StringResultOptions {\n  if (options === undefined) {\n    return true;\n  }\n\n  if (options === 'buffer') {\n    return false;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.encoding === 'buffer') {\n    return false;\n  }\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  return true;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,kBAGO;AACP,yBAAwB;AAyGxB,eAAsB,aACpB,MACA,UAA2E,CAAC,GACnC;AACzC,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,QAAQ,UAAM,4BAAQ,MAAM,OAAO;AACzC,WAAO,MAAM,IAAI,uBAAW;AAAA,EAC9B;AAEA,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,UAAU,UAAM,4BAAQ,MAAM,OAAO;AAC3C,WAAO,QAAQ,IAAI,yBAAa;AAAA,EAClC;AAEA,QAAM,UAAU,UAAM,4BAAQ,MAAM,OAAO;AAC3C,aAAW,UAAU,SAAS;AAC5B,WAAO,WAAO,yBAAY,OAAO,IAAI;AACrC,WAAO,iBAAa,yBAAY,OAAO,UAAU;AAAA,EACnD;AAEA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,MAAI,YAAY,QAAW;AACzB,WAAO;AAAA,EACT;AAEA,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAEA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,MAAI,YAAY,QAAW;AACzB,WAAO;AAAA,EACT;AAEA,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAEA,SAAO;AACT;",
  "names": []
}

181
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/Fs.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for file system operations.\n */\n\nimport type {\n  Dirent,\n  ObjectEncodingOptions,\n  PathLike\n} from './NodeModules.ts';\n\nimport {\n  toPosixBuffer,\n  toPosixPath\n} from '../Path.ts';\nimport { readdir } from './NodeModules.ts';\n\n/**\n * Options for controlling the format of the result when returning buffers.\n *\n * `directory` is used instead of `folder` to preserve compatibility with `node:fs` module.\n */\nexport type BufferResultOptions = 'buffer' | {\n  /**\n   * Should be set to \"buffer\" to return buffers.\n   */\n  encoding: 'buffer';\n\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  recursive?: boolean;\n\n  /**\n   * Should be set to `false` to return buffers.\n   */\n  withFileTypes?: false;\n};\n\n/**\n * Options for controlling the format of the result when returning Dirent objects.\n */\nexport type DirentResultOptions = {\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  recursive?: boolean;\n\n  /**\n   * Should be set to `true` to return Dirent objects.\n   */\n  withFileTypes: true;\n} & ObjectEncodingOptions;\n\n/**\n * Options for controlling the format of the result when returning strings.\n */\nexport type StringResultOptions =\n  | {\n    /**\n     * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n     */\n    recursive?: boolean;\n\n    /**\n     * Should be set to `false` to return strings.\n     */\n    withFileTypes?: false;\n  } & ObjectEncodingOptions\n  | undefined;\n\n/**\n * Common options for controlling the format of the result.\n */\ninterface CommonOptions {\n  /**\n   * Encoding to use when returning strings.\n   */\n  encoding?: 'buffer' | NodeJS.BufferEncoding;\n\n  /**\n   * Set `true` to return Dirent objects or `false` to return strings or buffers.\n   */\n  withFileTypes?: boolean;\n}\n\n/**\n * Reads the contents of a directory and returns an array of strings with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. If not provided, returns strings.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths.\n */\nexport async function readdirPosix(path: PathLike, options?: StringResultOptions): Promise<string[]>;\n/**\n * Reads the contents of a directory and returns an array of buffers with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify \"buffer\" to return buffers.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted buffers.\n */\nexport async function readdirPosix(path: PathLike, options: BufferResultOptions): Promise<Buffer[]>;\n/**\n * Reads the contents of a directory and returns an array of Dirent objects with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify `withFileTypes: true` to return Dirent objects.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted Dirent objects.\n */\nexport async function readdirPosix(path: PathLike, options: DirentResultOptions): Promise<Dirent[]>;\n/**\n * Reads the contents of a directory and converts file paths or buffer results to POSIX format.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths, buffers, or Dirent objects.\n */\nexport async function readdirPosix(\n  path: PathLike,\n  options: BufferResultOptions | DirentResultOptions | StringResultOptions = {}\n): Promise<Buffer[] | Dirent[] | string[]> {\n  if (isStringResultOptions(options)) {\n    const paths = await readdir(path, options);\n    return paths.map(toPosixPath);\n  }\n\n  if (isBufferResultOptions(options)) {\n    const buffers = await readdir(path, options);\n    return buffers.map(toPosixBuffer);\n  }\n\n  const dirents = await readdir(path, options);\n  for (const dirent of dirents) {\n    dirent.name = toPosixPath(dirent.name);\n    dirent.parentPath = toPosixPath(dirent.parentPath);\n  }\n\n  return dirents;\n}\n\n/**\n * Type guard to check if the options are for returning buffers.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning buffers, otherwise `false`.\n */\nfunction isBufferResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is BufferResultOptions {\n  if (options === undefined) {\n    return false;\n  }\n\n  if (options === 'buffer') {\n    return true;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  if (commonOptions.encoding !== 'buffer') {\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Type guard to check if the options are for returning strings.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning strings, otherwise `false`.\n */\nfunction isStringResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is StringResultOptions {\n  if (options === undefined) {\n    return true;\n  }\n\n  if (options === 'buffer') {\n    return false;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.encoding === 'buffer') {\n    return false;\n  }\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  return true;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,kBAGO;AACP,yBAAwB;AAsGxB,eAAsB,aACpB,MACA,UAA2E,CAAC,GACnC;AACzC,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,QAAQ,UAAM,4BAAQ,MAAM,OAAO;AACzC,WAAO,MAAM,IAAI,uBAAW;AAAA,EAC9B;AAEA,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,UAAU,UAAM,4BAAQ,MAAM,OAAO;AAC3C,WAAO,QAAQ,IAAI,yBAAa;AAAA,EAClC;AAEA,QAAM,UAAU,UAAM,4BAAQ,MAAM,OAAO;AAC3C,aAAW,UAAU,SAAS;AAC5B,WAAO,WAAO,yBAAY,OAAO,IAAI;AACrC,WAAO,iBAAa,yBAAY,OAAO,UAAU;AAAA,EACnD;AAEA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,MAAI,YAAY,QAAW;AACzB,WAAO;AAAA,EACT;AAEA,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAEA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,MAAI,YAAY,QAAW;AACzB,WAAO;AAAA,EACT;AAEA,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAEA,SAAO;AACT;",
  "names": []
}

@@ -181,4 +181,4 @@ function toRelativeFromRoot(path, cwd) {
181
181
  resolvePathFromRootSafe,
182
182
  toRelativeFromRoot
183
183
  });
184
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/Root.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for executing commands from the root folder of a project,\n * resolving paths relative to the root.\n */\n\nimport type {\n  ExecOption,\n  ExecResult\n} from './Exec.ts';\n\nimport {\n  dirname,\n  join,\n  relative,\n  resolve,\n  toPosixPath\n} from '../Path.ts';\nimport { exec } from './Exec.ts';\nimport { existsSync } from './NodeModules.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\n\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function execFromRoot(command: string | string[], options?: { withDetails?: false } & ExecOption): Promise<string>;\n\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: { withDetails: true } & ExecOption): Promise<ExecResult>;\n\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: ExecOption = {}): Promise<ExecResult | string> {\n  let root = getRootFolder(options.cwd);\n\n  if (!root) {\n    if (options.shouldFailIfCalledFromOutsideRoot ?? true) {\n      throw new Error('Could not find root folder');\n    }\n\n    root = options.cwd ?? process.cwd();\n  }\n\n  if (options.shouldIncludeDetails) {\n    return exec(command, { ...options, cwd: root, shouldIncludeDetails: true });\n  }\n\n  return exec(command, { ...options, cwd: root, shouldIncludeDetails: false });\n}\n\n/**\n * Retrieves the root folder of the project.\n *\n * @param cwd - The current working folder to resolve from.\n * @returns The path to the root folder.\n * @throws If the root folder cannot be found.\n */\nexport function getRootFolder(cwd?: string): null | string {\n  let currentFolder = toPosixPath(cwd ?? process.cwd());\n  while (currentFolder !== ObsidianDevUtilsRepoPaths.CurrentFolder as string && currentFolder !== ObsidianDevUtilsRepoPaths.RootFolder as string) {\n    if (existsSync(join(currentFolder, ObsidianDevUtilsRepoPaths.PackageJson))) {\n      return toPosixPath(currentFolder);\n    }\n    currentFolder = dirname(currentFolder);\n  }\n\n  return null;\n}\n\n/**\n * Resolves a path relative to the root folder of the project.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working folder to resolve from.\n * @returns The resolved absolute path.\n */\nexport function resolvePathFromRoot(path: string, cwd?: string): null | string {\n  const rootFolder = getRootFolder(cwd);\n  if (!rootFolder) {\n    return null;\n  }\n\n  return resolve(rootFolder, path);\n}\n\n/**\n * Resolves a path relative to the root folder, returning the resolved path or the original path if it does not exist.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working folder to resolve from.\n * @returns The resolved path or the original path if it does not exist.\n */\nexport function resolvePathFromRootSafe(path: string, cwd?: string): string {\n  return resolvePathFromRoot(path, cwd) ?? path;\n}\n\n/**\n * Converts an absolute path to a relative path from the root folder of the project.\n *\n * @param path - The absolute path to convert.\n * @param cwd - The current working folder to resolve from.\n * @returns The relative path from the root folder.\n */\nexport function toRelativeFromRoot(path: string, cwd?: string): null | string {\n  const rootFolder = getRootFolder(cwd);\n  if (!rootFolder) {\n    return null;\n  }\n\n  path = toPosixPath(path);\n  return relative(rootFolder, path);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,kBAMO;AACP,kBAAqB;AACrB,yBAA2B;AAC3B,uCAA0C;AAyCnC,SAAS,aAAa,SAA4B,UAAsB,CAAC,GAAiC;AAC/G,MAAI,OAAO,cAAc,QAAQ,GAAG;AAEpC,MAAI,CAAC,MAAM;AACT,QAAI,QAAQ,qCAAqC,MAAM;AACrD,YAAM,IAAI,MAAM,4BAA4B;AAAA,IAC9C;AAEA,WAAO,QAAQ,OAAO,QAAQ,IAAI;AAAA,EACpC;AAEA,MAAI,QAAQ,sBAAsB;AAChC,eAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,KAAK,CAAC;AAAA,EAC5E;AAEA,aAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,MAAM,CAAC;AAC7E;AASO,SAAS,cAAc,KAA6B;AACzD,MAAI,oBAAgB,yBAAY,OAAO,QAAQ,IAAI,CAAC;AACpD,SAAO,kBAAkB,2DAA0B,iBAA2B,kBAAkB,2DAA0B,YAAsB;AAC9I,YAAI,mCAAW,kBAAK,eAAe,2DAA0B,WAAW,CAAC,GAAG;AAC1E,iBAAO,yBAAY,aAAa;AAAA,IAClC;AACA,wBAAgB,qBAAQ,aAAa;AAAA,EACvC;AAEA,SAAO;AACT;AASO,SAAS,oBAAoB,MAAc,KAA6B;AAC7E,QAAM,aAAa,cAAc,GAAG;AACpC,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,EACT;AAEA,aAAO,qBAAQ,YAAY,IAAI;AACjC;AASO,SAAS,wBAAwB,MAAc,KAAsB;AAC1E,SAAO,oBAAoB,MAAM,GAAG,KAAK;AAC3C;AASO,SAAS,mBAAmB,MAAc,KAA6B;AAC5E,QAAM,aAAa,cAAc,GAAG;AACpC,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,EACT;AAEA,aAAO,yBAAY,IAAI;AACvB,aAAO,sBAAS,YAAY,IAAI;AAClC;",
  "names": []
}

184
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/Root.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for executing commands from the root folder of a project,\n * resolving paths relative to the root.\n */\n\nimport type {\n  ExecOption,\n  ExecResult\n} from './Exec.ts';\n\nimport {\n  dirname,\n  join,\n  relative,\n  resolve,\n  toPosixPath\n} from '../Path.ts';\nimport { exec } from './Exec.ts';\nimport { existsSync } from './NodeModules.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\n\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function execFromRoot(command: string | string[], options?: { withDetails?: false } & ExecOption): Promise<string>;\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: { withDetails: true } & ExecOption): Promise<ExecResult>;\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: ExecOption = {}): Promise<ExecResult | string> {\n  let root = getRootFolder(options.cwd);\n\n  if (!root) {\n    if (options.shouldFailIfCalledFromOutsideRoot ?? true) {\n      throw new Error('Could not find root folder');\n    }\n\n    root = options.cwd ?? process.cwd();\n  }\n\n  if (options.shouldIncludeDetails) {\n    return exec(command, { ...options, cwd: root, shouldIncludeDetails: true });\n  }\n\n  return exec(command, { ...options, cwd: root, shouldIncludeDetails: false });\n}\n\n/**\n * Retrieves the root folder of the project.\n *\n * @param cwd - The current working folder to resolve from.\n * @returns The path to the root folder.\n * @throws If the root folder cannot be found.\n */\nexport function getRootFolder(cwd?: string): null | string {\n  let currentFolder = toPosixPath(cwd ?? process.cwd());\n  while (currentFolder !== ObsidianDevUtilsRepoPaths.CurrentFolder as string && currentFolder !== ObsidianDevUtilsRepoPaths.RootFolder as string) {\n    if (existsSync(join(currentFolder, ObsidianDevUtilsRepoPaths.PackageJson))) {\n      return toPosixPath(currentFolder);\n    }\n    currentFolder = dirname(currentFolder);\n  }\n\n  return null;\n}\n\n/**\n * Resolves a path relative to the root folder of the project.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working folder to resolve from.\n * @returns The resolved absolute path.\n */\nexport function resolvePathFromRoot(path: string, cwd?: string): null | string {\n  const rootFolder = getRootFolder(cwd);\n  if (!rootFolder) {\n    return null;\n  }\n\n  return resolve(rootFolder, path);\n}\n\n/**\n * Resolves a path relative to the root folder, returning the resolved path or the original path if it does not exist.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working folder to resolve from.\n * @returns The resolved path or the original path if it does not exist.\n */\nexport function resolvePathFromRootSafe(path: string, cwd?: string): string {\n  return resolvePathFromRoot(path, cwd) ?? path;\n}\n\n/**\n * Converts an absolute path to a relative path from the root folder of the project.\n *\n * @param path - The absolute path to convert.\n * @param cwd - The current working folder to resolve from.\n * @returns The relative path from the root folder.\n */\nexport function toRelativeFromRoot(path: string, cwd?: string): null | string {\n  const rootFolder = getRootFolder(cwd);\n  if (!rootFolder) {\n    return null;\n  }\n\n  path = toPosixPath(path);\n  return relative(rootFolder, path);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,kBAMO;AACP,kBAAqB;AACrB,yBAA2B;AAC3B,uCAA0C;AAuCnC,SAAS,aAAa,SAA4B,UAAsB,CAAC,GAAiC;AAC/G,MAAI,OAAO,cAAc,QAAQ,GAAG;AAEpC,MAAI,CAAC,MAAM;AACT,QAAI,QAAQ,qCAAqC,MAAM;AACrD,YAAM,IAAI,MAAM,4BAA4B;AAAA,IAC9C;AAEA,WAAO,QAAQ,OAAO,QAAQ,IAAI;AAAA,EACpC;AAEA,MAAI,QAAQ,sBAAsB;AAChC,eAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,KAAK,CAAC;AAAA,EAC5E;AAEA,aAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,MAAM,CAAC;AAC7E;AASO,SAAS,cAAc,KAA6B;AACzD,MAAI,oBAAgB,yBAAY,OAAO,QAAQ,IAAI,CAAC;AACpD,SAAO,kBAAkB,2DAA0B,iBAA2B,kBAAkB,2DAA0B,YAAsB;AAC9I,YAAI,mCAAW,kBAAK,eAAe,2DAA0B,WAAW,CAAC,GAAG;AAC1E,iBAAO,yBAAY,aAAa;AAAA,IAClC;AACA,wBAAgB,qBAAQ,aAAa;AAAA,EACvC;AAEA,SAAO;AACT;AASO,SAAS,oBAAoB,MAAc,KAA6B;AAC7E,QAAM,aAAa,cAAc,GAAG;AACpC,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,EACT;AAEA,aAAO,qBAAQ,YAAY,IAAI;AACjC;AASO,SAAS,wBAAwB,MAAc,KAAsB;AAC1E,SAAO,oBAAoB,MAAM,GAAG,KAAK;AAC3C;AASO,SAAS,mBAAmB,MAAc,KAA6B;AAC5E,QAAM,aAAa,cAAc,GAAG;AACpC,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,EACT;AAEA,aAAO,yBAAY,IAAI;AACvB,aAAO,sBAAS,YAAY,IAAI;AAClC;",
  "names": []
}

@@ -130,6 +130,40 @@ __export(AbstractFileCommandBase_exports, {
130
130
  module.exports = __toCommonJS(AbstractFileCommandBase_exports);
131
131
  var import_CommandBase = require('./CommandBase.cjs');
132
132
  var import_NonEditorCommandBase = require('./NonEditorCommandBase.cjs');
133
+ class AbstractFileCommandInvocationBase extends import_CommandBase.CommandInvocationBase {
134
+ /** */
135
+ _abstractFile;
136
+ /**
137
+ * The abstract file to invoke the command for.
138
+ *
139
+ * @returns The abstract file to invoke the command for.
140
+ * @throws If the abstract file is not set.
141
+ */
142
+ get abstractFile() {
143
+ if (!this._abstractFile) {
144
+ throw new Error("Abstract file not set");
145
+ }
146
+ return this._abstractFile;
147
+ }
148
+ /**
149
+ * Creates a new abstract file command invocation.
150
+ *
151
+ * @param plugin - The plugin that the command belongs to.
152
+ * @param abstractFile - The abstract file to invoke the command for.
153
+ */
154
+ constructor(plugin, abstractFile) {
155
+ super(plugin);
156
+ this._abstractFile = abstractFile;
157
+ }
158
+ /**
159
+ * Checks if the command can execute.
160
+ *
161
+ * @returns Whether the command can execute.
162
+ */
163
+ canExecute() {
164
+ return super.canExecute() && !!this._abstractFile;
165
+ }
166
+ }
133
167
  class AbstractFileCommandBase extends import_NonEditorCommandBase.NonEditorCommandBase {
134
168
  /**
135
169
  * Gets the item name to use in the file menu.
@@ -319,40 +353,6 @@ class AbstractFileCommandBase extends import_NonEditorCommandBase.NonEditorComma
319
353
  });
320
354
  }
321
355
  }
322
- class AbstractFileCommandInvocationBase extends import_CommandBase.CommandInvocationBase {
323
- /** */
324
- _abstractFile;
325
- /**
326
- * The abstract file to invoke the command for.
327
- *
328
- * @returns The abstract file to invoke the command for.
329
- * @throws If the abstract file is not set.
330
- */
331
- get abstractFile() {
332
- if (!this._abstractFile) {
333
- throw new Error("Abstract file not set");
334
- }
335
- return this._abstractFile;
336
- }
337
- /**
338
- * Creates a new abstract file command invocation.
339
- *
340
- * @param plugin - The plugin that the command belongs to.
341
- * @param abstractFile - The abstract file to invoke the command for.
342
- */
343
- constructor(plugin, abstractFile) {
344
- super(plugin);
345
- this._abstractFile = abstractFile;
346
- }
347
- /**
348
- * Checks if the command can execute.
349
- *
350
- * @returns Whether the command can execute.
351
- */
352
- canExecute() {
353
- return super.canExecute() && !!this._abstractFile;
354
- }
355
- }
356
356
  class AbstractFilesCommandInvocationBase extends import_CommandBase.CommandInvocationBase {
357
357
  /**
358
358
  * Creates a new abstract files command invocation.
@@ -433,4 +433,4 @@ class SequentialAbstractFilesCommandInvocationBase extends AbstractFilesCommandI
433
433
  ArrayDelegatingAbstractFileCommandInvocation,
434
434
  SequentialAbstractFilesCommandInvocationBase
435
435
  });
436
- //# 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  IconName,\n  Menu,\n  Plugin,\n  TAbstractFile,\n  WorkspaceLeaf\n} from 'obsidian';\n\nimport type { CommandBaseOptions } from './CommandBase.ts';\n\nimport { CommandInvocationBase } from './CommandBase.ts';\nimport { NonEditorCommandBase } from './NonEditorCommandBase.ts';\n\n/**\n * Options for creating an abstract file command.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport interface AbstractFileCommandBaseOptions<TPlugin extends Plugin> extends CommandBaseOptions<TPlugin> {\n  /**\n   * The item name to use in the file menu.\n   */\n  fileMenuItemName?: string | undefined;\n\n  /**\n   * The section to use in the file menu.\n   */\n  fileMenuSection?: string | undefined;\n\n  /**\n   * The icon to use in the file menu submenu.\n   */\n  fileMenuSubmenuIcon?: IconName | undefined;\n\n  /**\n   * The item name to use in the files menu.\n   */\n  filesMenuItemName?: string | undefined;\n\n  /**\n   * The section to use in the files menu.\n   */\n  filesMenuSection?: string | undefined;\n\n  /**\n   * The icon to use in the files menu submenu.\n   */\n  filesMenuSubmenuIcon?: IconName | undefined;\n\n  /**\n   * Whether to add the command to the submenu.\n   */\n  shouldAddCommandToSubmenu?: boolean | undefined;\n}\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   * Gets the item name to use in the file menu.\n   *\n   * @returns The item name to use in the file menu.\n   */\n  protected get fileMenuItemName(): string | undefined {\n    return this._fileMenuItemName;\n  }\n\n  /**\n   * Gets the section to use in the file menu.\n   *\n   * @returns The section to use in the file menu.\n   */\n  protected get fileMenuSection(): string | undefined {\n    return this._fileMenuSection;\n  }\n\n  /**\n   * Gets the icon to use in the file menu submenu.\n   *\n   * @returns The icon to use in the file menu submenu.\n   */\n  protected get fileMenuSubmenuIcon(): IconName | undefined {\n    return this._fileMenuSubmenuIcon;\n  }\n\n  /**\n   * Gets the item name to use in the files menu.\n   *\n   * @returns The item name to use in the files menu.\n   */\n  protected get filesMenuItemName(): string | undefined {\n    return this._filesMenuItemName;\n  }\n\n  /**\n   * Gets the section to use in the files menu.\n   *\n   * @returns The section to use in the files menu.\n   */\n  protected get filesMenuSection(): string | undefined {\n    return this._filesMenuSection;\n  }\n\n  /**\n   * Gets the icon to use in the files menu submenu.\n   *\n   * @returns The icon to use in the files menu submenu.\n   */\n  protected get filesMenuSubmenuIcon(): IconName | undefined {\n    return this._filesMenuSubmenuIcon;\n  }\n\n  /**\n   * Gets whether to add the command to the submenu.\n   *\n   * @returns Whether to add the command to the submenu.\n   */\n  protected get shouldAddCommandToSubmenu(): boolean | undefined {\n    return this._shouldAddCommandToSubmenu;\n  }\n\n  private readonly _fileMenuItemName?: string | undefined;\n  private readonly _fileMenuSection?: string | undefined;\n  private readonly _fileMenuSubmenuIcon?: IconName | undefined;\n  private readonly _filesMenuItemName?: string | undefined;\n  private readonly _filesMenuSection?: string | undefined;\n  private readonly _filesMenuSubmenuIcon?: IconName | undefined;\n  private readonly _shouldAddCommandToSubmenu?: boolean | undefined;\n\n  /**\n   * Creates a new abstract file command.\n   *\n   * @param options - The options for the abstract file command.\n   */\n  public constructor(options: AbstractFileCommandBaseOptions<TPlugin>) {\n    super(options);\n    this._fileMenuItemName = options.fileMenuItemName;\n    this._fileMenuSection = options.fileMenuSection;\n    this._fileMenuSubmenuIcon = options.fileMenuSubmenuIcon;\n    this._filesMenuItemName = options.filesMenuItemName;\n    this._filesMenuSection = options.filesMenuSection;\n    this._filesMenuSubmenuIcon = options.filesMenuSubmenuIcon;\n    this._shouldAddCommandToSubmenu = options.shouldAddCommandToSubmenu;\n  }\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    const fileMenuSection = this.fileMenuSection ?? this.plugin.manifest.name;\n    if (this.shouldAddCommandToSubmenu) {\n      menu.setSectionSubmenu(fileMenuSection, {\n        icon: this.fileMenuSubmenuIcon ?? '',\n        title: fileMenuSection\n      });\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.fileMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(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    const filesMenuSection = this.filesMenuSection ?? this.fileMenuSection ?? this.plugin.manifest.name;\n    if (this.shouldAddCommandToSubmenu) {\n      menu.setSectionSubmenu(filesMenuSection, {\n        icon: this.filesMenuSubmenuIcon ?? this.fileMenuSubmenuIcon ?? '',\n        title: filesMenuSection\n      });\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.filesMenuItemName ?? this.fileMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(filesMenuSection)\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": []
}

436
+ //# 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  IconName,\n  Menu,\n  Plugin,\n  TAbstractFile,\n  WorkspaceLeaf\n} from 'obsidian';\n\nimport type { CommandBaseOptions } from './CommandBase.ts';\n\nimport { CommandInvocationBase } from './CommandBase.ts';\nimport { NonEditorCommandBase } from './NonEditorCommandBase.ts';\n\n/**\n * Options for creating an abstract file command.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport interface AbstractFileCommandBaseOptions<TPlugin extends Plugin> extends CommandBaseOptions<TPlugin> {\n  /**\n   * The item name to use in the file menu.\n   */\n  fileMenuItemName?: string | undefined;\n\n  /**\n   * The section to use in the file menu.\n   */\n  fileMenuSection?: string | undefined;\n\n  /**\n   * The icon to use in the file menu submenu.\n   */\n  fileMenuSubmenuIcon?: IconName | undefined;\n\n  /**\n   * The item name to use in the files menu.\n   */\n  filesMenuItemName?: string | undefined;\n\n  /**\n   * The section to use in the files menu.\n   */\n  filesMenuSection?: string | undefined;\n\n  /**\n   * The icon to use in the files menu submenu.\n   */\n  filesMenuSubmenuIcon?: IconName | undefined;\n\n  /**\n   * Whether to add the command to the submenu.\n   */\n  shouldAddCommandToSubmenu?: boolean | undefined;\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 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   * Gets the item name to use in the file menu.\n   *\n   * @returns The item name to use in the file menu.\n   */\n  protected get fileMenuItemName(): string | undefined {\n    return this._fileMenuItemName;\n  }\n\n  /**\n   * Gets the section to use in the file menu.\n   *\n   * @returns The section to use in the file menu.\n   */\n  protected get fileMenuSection(): string | undefined {\n    return this._fileMenuSection;\n  }\n\n  /**\n   * Gets the icon to use in the file menu submenu.\n   *\n   * @returns The icon to use in the file menu submenu.\n   */\n  protected get fileMenuSubmenuIcon(): IconName | undefined {\n    return this._fileMenuSubmenuIcon;\n  }\n\n  /**\n   * Gets the item name to use in the files menu.\n   *\n   * @returns The item name to use in the files menu.\n   */\n  protected get filesMenuItemName(): string | undefined {\n    return this._filesMenuItemName;\n  }\n\n  /**\n   * Gets the section to use in the files menu.\n   *\n   * @returns The section to use in the files menu.\n   */\n  protected get filesMenuSection(): string | undefined {\n    return this._filesMenuSection;\n  }\n\n  /**\n   * Gets the icon to use in the files menu submenu.\n   *\n   * @returns The icon to use in the files menu submenu.\n   */\n  protected get filesMenuSubmenuIcon(): IconName | undefined {\n    return this._filesMenuSubmenuIcon;\n  }\n\n  /**\n   * Gets whether to add the command to the submenu.\n   *\n   * @returns Whether to add the command to the submenu.\n   */\n  protected get shouldAddCommandToSubmenu(): boolean | undefined {\n    return this._shouldAddCommandToSubmenu;\n  }\n\n  private readonly _fileMenuItemName?: string | undefined;\n  private readonly _fileMenuSection?: string | undefined;\n  private readonly _fileMenuSubmenuIcon?: IconName | undefined;\n  private readonly _filesMenuItemName?: string | undefined;\n  private readonly _filesMenuSection?: string | undefined;\n  private readonly _filesMenuSubmenuIcon?: IconName | undefined;\n  private readonly _shouldAddCommandToSubmenu?: boolean | undefined;\n\n  /**\n   * Creates a new abstract file command.\n   *\n   * @param options - The options for the abstract file command.\n   */\n  public constructor(options: AbstractFileCommandBaseOptions<TPlugin>) {\n    super(options);\n    this._fileMenuItemName = options.fileMenuItemName;\n    this._fileMenuSection = options.fileMenuSection;\n    this._fileMenuSubmenuIcon = options.fileMenuSubmenuIcon;\n    this._filesMenuItemName = options.filesMenuItemName;\n    this._filesMenuSection = options.filesMenuSection;\n    this._filesMenuSubmenuIcon = options.filesMenuSubmenuIcon;\n    this._shouldAddCommandToSubmenu = options.shouldAddCommandToSubmenu;\n  }\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    const fileMenuSection = this.fileMenuSection ?? this.plugin.manifest.name;\n    if (this.shouldAddCommandToSubmenu) {\n      menu.setSectionSubmenu(fileMenuSection, {\n        icon: this.fileMenuSubmenuIcon ?? '',\n        title: fileMenuSection\n      });\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.fileMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(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    const filesMenuSection = this.filesMenuSection ?? this.fileMenuSection ?? this.plugin.manifest.name;\n    if (this.shouldAddCommandToSubmenu) {\n      menu.setSectionSubmenu(filesMenuSection, {\n        icon: this.filesMenuSubmenuIcon ?? this.fileMenuSubmenuIcon ?? '',\n        title: filesMenuSection\n      });\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.filesMenuItemName ?? this.fileMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(filesMenuSection)\n        .onClick(() => this.createCommandInvocationForAbstractFiles(abstractFiles).invoke(false));\n    });\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": []
}

@@ -42,6 +42,35 @@ export interface AbstractFileCommandBaseOptions<TPlugin extends Plugin> extends
42
42
  */
43
43
  shouldAddCommandToSubmenu?: boolean | undefined;
44
44
  }
45
+ /**
46
+ * Base class for abstract file command invocations.
47
+ *
48
+ * @typeParam TPlugin - The type of the plugin that the command belongs to.
49
+ */
50
+ export declare abstract class AbstractFileCommandInvocationBase<TPlugin extends Plugin> extends CommandInvocationBase<TPlugin> {
51
+ /** */
52
+ protected readonly _abstractFile: null | TAbstractFile;
53
+ /**
54
+ * The abstract file to invoke the command for.
55
+ *
56
+ * @returns The abstract file to invoke the command for.
57
+ * @throws If the abstract file is not set.
58
+ */
59
+ protected get abstractFile(): TAbstractFile;
60
+ /**
61
+ * Creates a new abstract file command invocation.
62
+ *
63
+ * @param plugin - The plugin that the command belongs to.
64
+ * @param abstractFile - The abstract file to invoke the command for.
65
+ */
66
+ constructor(plugin: TPlugin, abstractFile: null | TAbstractFile);
67
+ /**
68
+ * Checks if the command can execute.
69
+ *
70
+ * @returns Whether the command can execute.
71
+ */
72
+ protected canExecute(): boolean;
73
+ }
45
74
  /**
46
75
  * Base class for abstract file commands.
47
76
  *
@@ -162,35 +191,6 @@ export declare abstract class AbstractFileCommandBase<TPlugin extends Plugin = P
162
191
  private handleAbstractFileMenu;
163
192
  private handleAbstractFilesMenu;
164
193
  }
165
- /**
166
- * Base class for abstract file command invocations.
167
- *
168
- * @typeParam TPlugin - The type of the plugin that the command belongs to.
169
- */
170
- export declare abstract class AbstractFileCommandInvocationBase<TPlugin extends Plugin> extends CommandInvocationBase<TPlugin> {
171
- /** */
172
- protected readonly _abstractFile: null | TAbstractFile;
173
- /**
174
- * The abstract file to invoke the command for.
175
- *
176
- * @returns The abstract file to invoke the command for.
177
- * @throws If the abstract file is not set.
178
- */
179
- protected get abstractFile(): TAbstractFile;
180
- /**
181
- * Creates a new abstract file command invocation.
182
- *
183
- * @param plugin - The plugin that the command belongs to.
184
- * @param abstractFile - The abstract file to invoke the command for.
185
- */
186
- constructor(plugin: TPlugin, abstractFile: null | TAbstractFile);
187
- /**
188
- * Checks if the command can execute.
189
- *
190
- * @returns Whether the command can execute.
191
- */
192
- protected canExecute(): boolean;
193
- }
194
194
  /**
195
195
  * Base class for abstract files command invocations.
196
196
  *
@@ -174,6 +174,7 @@ class EditorCommandBase extends import_CommandBase.CommandBase {
174
174
  this._editorMenuSection = options.editorMenuSection;
175
175
  this._editorMenuSubmenuIcon = options.editorMenuSubmenuIcon;
176
176
  this._shouldAddCommandToSubmenu = options.shouldAddCommandToSubmenu;
177
+ this.editorCheckCallback = this.editorCheckCallback.bind(this);
177
178
  }
178
179
  /**
179
180
  * Checks if the command can execute or executes it.
@@ -274,4 +275,4 @@ class EditorCommandInvocationBase extends import_CommandBase.CommandInvocationBa
274
275
  EditorCommandBase,
275
276
  EditorCommandInvocationBase
276
277
  });
277
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Commands/EditorCommandBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base classes for editor commands.\n */\n\nimport type {\n  Editor,\n  IconName,\n  MarkdownFileInfo,\n  Menu,\n  Plugin,\n  TFile\n} from 'obsidian';\n\nimport type { CommandBaseOptions } from './CommandBase.ts';\n\nimport {\n  CommandBase,\n  CommandInvocationBase\n} from './CommandBase.ts';\n\n/**\n * Options for creating an editor command.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport interface EditorCommandBaseOptions<TPlugin extends Plugin> extends CommandBaseOptions<TPlugin> {\n  /**\n   * The item name to use in the editor menu.\n   */\n  editorMenuItemName?: string | undefined;\n\n  /**\n   * The section to use in the editor menu.\n   */\n  editorMenuSection?: string | undefined;\n\n  /**\n   * The icon to use in the editor menu submenu.\n   */\n  editorMenuSubmenuIcon?: IconName | undefined;\n\n  /**\n   * Whether to add the command to the submenu.\n   */\n  shouldAddCommandToSubmenu?: boolean | undefined;\n}\n\n/**\n * Base class for editor commands.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class EditorCommandBase<TPlugin extends Plugin> extends CommandBase<TPlugin> {\n  /**\n   * Gets the item name to use in the editor menu.\n   *\n   * @returns The item name to use in the editor menu.\n   */\n  protected get editorMenuItemName(): string | undefined {\n    return this._editorMenuItemName;\n  }\n\n  /**\n   * Gets the section to use in the editor menu.\n   *\n   * @returns The section to use in the editor menu.\n   */\n  protected get editorMenuSection(): string | undefined {\n    return this._editorMenuSection;\n  }\n\n  /**\n   * Gets the icon to use in the editor menu submenu.\n   *\n   * @returns The icon to use in the editor menu submenu.\n   */\n  protected get editorMenuSubmenuIcon(): IconName | undefined {\n    return this._editorMenuSubmenuIcon;\n  }\n\n  /**\n   * Gets whether to add the command to the submenu.\n   *\n   * @returns Whether to add the command to the submenu.\n   */\n  protected get shouldAddCommandToSubmenu(): boolean | undefined {\n    return this._shouldAddCommandToSubmenu;\n  }\n\n  private readonly _editorMenuItemName?: string | undefined;\n  private readonly _editorMenuSection?: string | undefined;\n  private readonly _editorMenuSubmenuIcon?: IconName | undefined;\n  private readonly _shouldAddCommandToSubmenu?: boolean | undefined;\n\n  /**\n   * Creates a new editor command.\n   *\n   * @param options - The options for the editor command.\n   */\n  public constructor(options: EditorCommandBaseOptions<TPlugin>) {\n    super(options);\n    this._editorMenuItemName = options.editorMenuItemName;\n    this._editorMenuSection = options.editorMenuSection;\n    this._editorMenuSubmenuIcon = options.editorMenuSubmenuIcon;\n    this._shouldAddCommandToSubmenu = options.shouldAddCommandToSubmenu;\n  }\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   * @param editor - The editor to check.\n   * @param ctx - The context of the command.\n   * @returns Whether the command can execute.\n   */\n  public editorCheckCallback(checking: boolean, editor: Editor, ctx: MarkdownFileInfo): boolean {\n    if (!this.shouldAddToCommandPalette()) {\n      return false;\n    }\n    return this.createEditorCommandInvocation(editor, ctx).invoke(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('editor-menu', this.handleEditorMenu.bind(this)));\n  }\n\n  /**\n   * Creates a new editor command invocation.\n   *\n   * @param editor - The editor to create the command invocation for.\n   * @param ctx - The context of the command.\n   * @returns The command invocation.\n   */\n  protected abstract createEditorCommandInvocation(editor: Editor, ctx: MarkdownFileInfo): CommandInvocationBase;\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  /**\n   * Checks if the command should be added to the editor menu.\n   *\n   * @param _editor - The editor to check.\n   * @param _ctx - The context of the command.\n   * @returns Whether the command should be added to the editor menu.\n   */\n  protected shouldAddToEditorMenu(_editor: Editor, _ctx: MarkdownFileInfo): boolean {\n    return false;\n  }\n\n  private handleEditorMenu(menu: Menu, editor: Editor, ctx: MarkdownFileInfo): void {\n    if (!this.shouldAddToEditorMenu(editor, ctx)) {\n      return;\n    }\n\n    if (!this.createEditorCommandInvocation(editor, ctx).invoke(true)) {\n      return;\n    }\n\n    const editorMenuSection = this.editorMenuSection ?? this.plugin.manifest.name;\n    if (this.shouldAddCommandToSubmenu) {\n      menu.setSectionSubmenu(editorMenuSection, {\n        icon: this.editorMenuSubmenuIcon ?? '',\n        title: editorMenuSection\n      });\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.editorMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(editorMenuSection)\n        .onClick(() => this.createEditorCommandInvocation(editor, ctx).invoke(false));\n    });\n  }\n}\n\n/**\n * Base class for editor command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class EditorCommandInvocationBase<TPlugin extends Plugin> extends CommandInvocationBase<TPlugin> {\n  /**\n   * The file to invoke the command for.\n   *\n   * @returns The file to invoke the command for.\n   * @throws If the file is not set.\n   */\n  protected get file(): TFile {\n    if (!this._file) {\n      throw new Error('File not set');\n    }\n    return this._file;\n  }\n\n  private readonly _file: null | TFile;\n\n  /**\n   * Creates a new editor command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param editor - The editor to create the command invocation for.\n   * @param ctx - The context of the command.\n   */\n  public constructor(plugin: TPlugin, protected readonly editor: Editor, protected readonly ctx: MarkdownFileInfo) {\n    super(plugin);\n    this._file = ctx.file;\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  public override canExecute(): boolean {\n    return super.canExecute() && !!this._file;\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

278
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/Commands/EditorCommandBase.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Base classes for editor commands.\n */\n\nimport type {\n  Editor,\n  IconName,\n  MarkdownFileInfo,\n  Menu,\n  Plugin,\n  TFile\n} from 'obsidian';\n\nimport type { CommandBaseOptions } from './CommandBase.ts';\n\nimport {\n  CommandBase,\n  CommandInvocationBase\n} from './CommandBase.ts';\n\n/**\n * Options for creating an editor command.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport interface EditorCommandBaseOptions<TPlugin extends Plugin> extends CommandBaseOptions<TPlugin> {\n  /**\n   * The item name to use in the editor menu.\n   */\n  editorMenuItemName?: string | undefined;\n\n  /**\n   * The section to use in the editor menu.\n   */\n  editorMenuSection?: string | undefined;\n\n  /**\n   * The icon to use in the editor menu submenu.\n   */\n  editorMenuSubmenuIcon?: IconName | undefined;\n\n  /**\n   * Whether to add the command to the submenu.\n   */\n  shouldAddCommandToSubmenu?: boolean | undefined;\n}\n\n/**\n * Base class for editor commands.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport abstract class EditorCommandBase<TPlugin extends Plugin> extends CommandBase<TPlugin> {\n  /**\n   * Gets the item name to use in the editor menu.\n   *\n   * @returns The item name to use in the editor menu.\n   */\n  protected get editorMenuItemName(): string | undefined {\n    return this._editorMenuItemName;\n  }\n\n  /**\n   * Gets the section to use in the editor menu.\n   *\n   * @returns The section to use in the editor menu.\n   */\n  protected get editorMenuSection(): string | undefined {\n    return this._editorMenuSection;\n  }\n\n  /**\n   * Gets the icon to use in the editor menu submenu.\n   *\n   * @returns The icon to use in the editor menu submenu.\n   */\n  protected get editorMenuSubmenuIcon(): IconName | undefined {\n    return this._editorMenuSubmenuIcon;\n  }\n\n  /**\n   * Gets whether to add the command to the submenu.\n   *\n   * @returns Whether to add the command to the submenu.\n   */\n  protected get shouldAddCommandToSubmenu(): boolean | undefined {\n    return this._shouldAddCommandToSubmenu;\n  }\n\n  private readonly _editorMenuItemName?: string | undefined;\n  private readonly _editorMenuSection?: string | undefined;\n  private readonly _editorMenuSubmenuIcon?: IconName | undefined;\n  private readonly _shouldAddCommandToSubmenu?: boolean | undefined;\n\n  /**\n   * Creates a new editor command.\n   *\n   * @param options - The options for the editor command.\n   */\n  public constructor(options: EditorCommandBaseOptions<TPlugin>) {\n    super(options);\n    this._editorMenuItemName = options.editorMenuItemName;\n    this._editorMenuSection = options.editorMenuSection;\n    this._editorMenuSubmenuIcon = options.editorMenuSubmenuIcon;\n    this._shouldAddCommandToSubmenu = options.shouldAddCommandToSubmenu;\n\n    this.editorCheckCallback = this.editorCheckCallback.bind(this);\n  }\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   * @param editor - The editor to check.\n   * @param ctx - The context of the command.\n   * @returns Whether the command can execute.\n   */\n  public editorCheckCallback(checking: boolean, editor: Editor, ctx: MarkdownFileInfo): boolean {\n    if (!this.shouldAddToCommandPalette()) {\n      return false;\n    }\n    return this.createEditorCommandInvocation(editor, ctx).invoke(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('editor-menu', this.handleEditorMenu.bind(this)));\n  }\n\n  /**\n   * Creates a new editor command invocation.\n   *\n   * @param editor - The editor to create the command invocation for.\n   * @param ctx - The context of the command.\n   * @returns The command invocation.\n   */\n  protected abstract createEditorCommandInvocation(editor: Editor, ctx: MarkdownFileInfo): CommandInvocationBase;\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  /**\n   * Checks if the command should be added to the editor menu.\n   *\n   * @param _editor - The editor to check.\n   * @param _ctx - The context of the command.\n   * @returns Whether the command should be added to the editor menu.\n   */\n  protected shouldAddToEditorMenu(_editor: Editor, _ctx: MarkdownFileInfo): boolean {\n    return false;\n  }\n\n  private handleEditorMenu(menu: Menu, editor: Editor, ctx: MarkdownFileInfo): void {\n    if (!this.shouldAddToEditorMenu(editor, ctx)) {\n      return;\n    }\n\n    if (!this.createEditorCommandInvocation(editor, ctx).invoke(true)) {\n      return;\n    }\n\n    const editorMenuSection = this.editorMenuSection ?? this.plugin.manifest.name;\n    if (this.shouldAddCommandToSubmenu) {\n      menu.setSectionSubmenu(editorMenuSection, {\n        icon: this.editorMenuSubmenuIcon ?? '',\n        title: editorMenuSection\n      });\n    }\n\n    menu.addItem((item) => {\n      item\n        .setTitle(this.editorMenuItemName ?? this.originalName)\n        .setIcon(this.icon)\n        .setSection(editorMenuSection)\n        .onClick(() => this.createEditorCommandInvocation(editor, ctx).invoke(false));\n    });\n  }\n}\n\n/**\n * Base class for editor command invocations.\n *\n * @typeParam TPlugin - The type of the plugin that the command belongs to.\n */\nexport class EditorCommandInvocationBase<TPlugin extends Plugin> extends CommandInvocationBase<TPlugin> {\n  /**\n   * The file to invoke the command for.\n   *\n   * @returns The file to invoke the command for.\n   * @throws If the file is not set.\n   */\n  protected get file(): TFile {\n    if (!this._file) {\n      throw new Error('File not set');\n    }\n    return this._file;\n  }\n\n  private readonly _file: null | TFile;\n\n  /**\n   * Creates a new editor command invocation.\n   *\n   * @param plugin - The plugin that the command invocation belongs to.\n   * @param editor - The editor to create the command invocation for.\n   * @param ctx - The context of the command.\n   */\n  public constructor(plugin: TPlugin, protected readonly editor: Editor, protected readonly ctx: MarkdownFileInfo) {\n    super(plugin);\n    this._file = ctx.file;\n  }\n\n  /**\n   * Checks if the command can execute.\n   *\n   * @returns Whether the command can execute.\n   */\n  public override canExecute(): boolean {\n    return super.canExecute() && !!this._file;\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -133,6 +133,7 @@ class NonEditorCommandBase extends import_CommandBase.CommandBase {
133
133
  */
134
134
  constructor(options) {
135
135
  super(options);
136
+ this.checkCallback = this.checkCallback.bind(this);
136
137
  }
137
138
  /**
138
139
  * Checks if the command can execute or executes it.
@@ -148,4 +149,4 @@ class NonEditorCommandBase extends import_CommandBase.CommandBase {
148
149
  0 && (module.exports = {
149
150
  NonEditorCommandBase
150
151
  });
151
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL0NvbW1hbmRzL05vbkVkaXRvckNvbW1hbmRCYXNlLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIEJhc2UgY2xhc3NlcyBmb3Igbm9uLWVkaXRvciBjb21tYW5kcy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ29ic2lkaWFuJztcblxuaW1wb3J0IHR5cGUge1xuICBDb21tYW5kQmFzZU9wdGlvbnMsXG4gIENvbW1hbmRJbnZvY2F0aW9uQmFzZVxufSBmcm9tICcuL0NvbW1hbmRCYXNlLnRzJztcblxuaW1wb3J0IHsgQ29tbWFuZEJhc2UgfSBmcm9tICcuL0NvbW1hbmRCYXNlLnRzJztcblxuLyoqXG4gKiBCYXNlIGNsYXNzIGZvciBub24tZWRpdG9yIGNvbW1hbmRzLlxuICpcbiAqIEB0eXBlUGFyYW0gVFBsdWdpbiAtIFRoZSB0eXBlIG9mIHRoZSBwbHVnaW4gdGhhdCB0aGUgY29tbWFuZCBiZWxvbmdzIHRvLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTm9uRWRpdG9yQ29tbWFuZEJhc2U8VFBsdWdpbiBleHRlbmRzIFBsdWdpbj4gZXh0ZW5kcyBDb21tYW5kQmFzZTxUUGx1Z2luPiB7XG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IG5vbi1lZGl0b3IgY29tbWFuZC5cbiAgICpcbiAgICogQHBhcmFtIG9wdGlvbnMgLSBUaGUgb3B0aW9ucyBmb3IgdGhlIG5vbi1lZGl0b3IgY29tbWFuZC5cbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihvcHRpb25zOiBDb21tYW5kQmFzZU9wdGlvbnM8VFBsdWdpbj4pIHtcbiAgICBzdXBlcihvcHRpb25zKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3MgaWYgdGhlIGNvbW1hbmQgY2FuIGV4ZWN1dGUgb3IgZXhlY3V0ZXMgaXQuXG4gICAqXG4gICAqIEBwYXJhbSBjaGVja2luZyAtIElzIGNoZWNraW5nIG1vZGUgb25seS4gSWYgYHRydWVgLCBvbmx5IHRoZSBjaGVjayBpZiB0aGUgY29tbWFuZCBjYW4gZXhlY3V0ZSBpcyBwZXJmb3JtZWQuIElmIGBmYWxzZWAsIHRoZSBjb21tYW5kIGlzIGV4ZWN1dGVkLlxuICAgKiBAcmV0dXJucyBXaGV0aGVyIHRoZSBjb21tYW5kIGNhbiBleGVjdXRlLlxuICAgKi9cbiAgcHVibGljIGNoZWNrQ2FsbGJhY2soY2hlY2tpbmc6IGJvb2xlYW4pOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5jcmVhdGVDb21tYW5kSW52b2NhdGlvbigpLmludm9rZShjaGVja2luZyk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBjb21tYW5kIGludm9jYXRpb24uXG4gICAqXG4gICAqIEByZXR1cm5zIFRoZSBjb21tYW5kIGludm9jYXRpb24uXG4gICAqL1xuICBwcm90ZWN0ZWQgYWJzdHJhY3QgY3JlYXRlQ29tbWFuZEludm9jYXRpb24oKTogQ29tbWFuZEludm9jYXRpb25CYXNlO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFhQSx5QkFBNEI7QUFPckIsTUFBZSw2QkFBcUQsK0JBQXFCO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBTXZGLFlBQVksU0FBc0M7QUFDdkQsVUFBTSxPQUFPO0FBQUEsRUFDZjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBUU8sY0FBYyxVQUE0QjtBQUMvQyxXQUFPLEtBQUssd0JBQXdCLEVBQUUsT0FBTyxRQUFRO0FBQUEsRUFDdkQ7QUFRRjsiLAogICJuYW1lcyI6IFtdCn0K
152
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL0NvbW1hbmRzL05vbkVkaXRvckNvbW1hbmRCYXNlLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIEJhc2UgY2xhc3NlcyBmb3Igbm9uLWVkaXRvciBjb21tYW5kcy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ29ic2lkaWFuJztcblxuaW1wb3J0IHR5cGUge1xuICBDb21tYW5kQmFzZU9wdGlvbnMsXG4gIENvbW1hbmRJbnZvY2F0aW9uQmFzZVxufSBmcm9tICcuL0NvbW1hbmRCYXNlLnRzJztcblxuaW1wb3J0IHsgQ29tbWFuZEJhc2UgfSBmcm9tICcuL0NvbW1hbmRCYXNlLnRzJztcblxuLyoqXG4gKiBCYXNlIGNsYXNzIGZvciBub24tZWRpdG9yIGNvbW1hbmRzLlxuICpcbiAqIEB0eXBlUGFyYW0gVFBsdWdpbiAtIFRoZSB0eXBlIG9mIHRoZSBwbHVnaW4gdGhhdCB0aGUgY29tbWFuZCBiZWxvbmdzIHRvLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTm9uRWRpdG9yQ29tbWFuZEJhc2U8VFBsdWdpbiBleHRlbmRzIFBsdWdpbj4gZXh0ZW5kcyBDb21tYW5kQmFzZTxUUGx1Z2luPiB7XG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IG5vbi1lZGl0b3IgY29tbWFuZC5cbiAgICpcbiAgICogQHBhcmFtIG9wdGlvbnMgLSBUaGUgb3B0aW9ucyBmb3IgdGhlIG5vbi1lZGl0b3IgY29tbWFuZC5cbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihvcHRpb25zOiBDb21tYW5kQmFzZU9wdGlvbnM8VFBsdWdpbj4pIHtcbiAgICBzdXBlcihvcHRpb25zKTtcblxuICAgIHRoaXMuY2hlY2tDYWxsYmFjayA9IHRoaXMuY2hlY2tDYWxsYmFjay5iaW5kKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyBpZiB0aGUgY29tbWFuZCBjYW4gZXhlY3V0ZSBvciBleGVjdXRlcyBpdC5cbiAgICpcbiAgICogQHBhcmFtIGNoZWNraW5nIC0gSXMgY2hlY2tpbmcgbW9kZSBvbmx5LiBJZiBgdHJ1ZWAsIG9ubHkgdGhlIGNoZWNrIGlmIHRoZSBjb21tYW5kIGNhbiBleGVjdXRlIGlzIHBlcmZvcm1lZC4gSWYgYGZhbHNlYCwgdGhlIGNvbW1hbmQgaXMgZXhlY3V0ZWQuXG4gICAqIEByZXR1cm5zIFdoZXRoZXIgdGhlIGNvbW1hbmQgY2FuIGV4ZWN1dGUuXG4gICAqL1xuICBwdWJsaWMgY2hlY2tDYWxsYmFjayhjaGVja2luZzogYm9vbGVhbik6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmNyZWF0ZUNvbW1hbmRJbnZvY2F0aW9uKCkuaW52b2tlKGNoZWNraW5nKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IGNvbW1hbmQgaW52b2NhdGlvbi5cbiAgICpcbiAgICogQHJldHVybnMgVGhlIGNvbW1hbmQgaW52b2NhdGlvbi5cbiAgICovXG4gIHByb3RlY3RlZCBhYnN0cmFjdCBjcmVhdGVDb21tYW5kSW52b2NhdGlvbigpOiBDb21tYW5kSW52b2NhdGlvbkJhc2U7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQWFBLHlCQUE0QjtBQU9yQixNQUFlLDZCQUFxRCwrQkFBcUI7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFNdkYsWUFBWSxTQUFzQztBQUN2RCxVQUFNLE9BQU87QUFFYixTQUFLLGdCQUFnQixLQUFLLGNBQWMsS0FBSyxJQUFJO0FBQUEsRUFDbkQ7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQVFPLGNBQWMsVUFBNEI7QUFDL0MsV0FBTyxLQUFLLHdCQUF3QixFQUFFLE9BQU8sUUFBUTtBQUFBLEVBQ3ZEO0FBUUY7IiwKICAibmFtZXMiOiBbXQp9Cg==