obsidian-dev-utils 2.17.1 → 2.18.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +4 -0
- package/dist/lib/obsidian/Link.cjs +11 -8
- package/dist/lib/obsidian/Link.d.ts +32 -0
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
@@ -26,6 +26,7 @@ __export(Link_exports, {
|
|
26
26
|
editLinks: () => editLinks,
|
27
27
|
extractLinkFile: () => extractLinkFile,
|
28
28
|
generateMarkdownLink: () => generateMarkdownLink,
|
29
|
+
getAlias: () => getAlias,
|
29
30
|
splitSubpath: () => splitSubpath,
|
30
31
|
updateLink: () => updateLink,
|
31
32
|
updateLinksInFile: () => updateLinksInFile
|
@@ -128,13 +129,14 @@ function updateLink(options) {
|
|
128
129
|
});
|
129
130
|
return newLink;
|
130
131
|
}
|
131
|
-
function getAlias({
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
132
|
+
function getAlias(options) {
|
133
|
+
const {
|
134
|
+
app,
|
135
|
+
displayText,
|
136
|
+
file: pathOrFile,
|
137
|
+
otherPaths,
|
138
|
+
sourcePath
|
139
|
+
} = options;
|
138
140
|
const file = (0, import_TFile.getFile)(app, pathOrFile);
|
139
141
|
if (!displayText) {
|
140
142
|
return void 0;
|
@@ -220,8 +222,9 @@ async function editLinks(app, pathOrFile, linkConverter, retryOptions = {}) {
|
|
220
222
|
editLinks,
|
221
223
|
extractLinkFile,
|
222
224
|
generateMarkdownLink,
|
225
|
+
getAlias,
|
223
226
|
splitSubpath,
|
224
227
|
updateLink,
|
225
228
|
updateLinksInFile
|
226
229
|
});
|
227
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Link.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Link\n * This module provides utilities for handling and updating links within Obsidian vaults. It includes\n * functions to split paths, update links in files, and generate markdown links with various options.\n * The functions integrate with Obsidian's API to ensure that links are managed correctly within the vault.\n **/\n\nimport {\n  normalizePath,\n  type App,\n  type ReferenceCache,\n  type TFile\n} from \"obsidian\";\nimport {\n  getAllLinks,\n  getCacheSafe\n} from \"./MetadataCache.ts\";\nimport {\n  applyFileChanges,\n  type FileChange\n} from \"./Vault.ts\";\nimport { createTFileInstance } from \"obsidian-typings/implementations\";\nimport {\n  basename,\n  extname\n} from \"../Path.ts\";\nimport { normalize } from \"../String.ts\";\nimport {\n  getFile,\n  type PathOrFile\n} from \"./TFile.ts\";\nimport { getPath } from \"./TAbstractFile.ts\";\nimport {\n  type MaybePromise,\n  type RetryOptions\n} from \"../Async.ts\";\n\ntype SplitSubpathResult = {\n  linkPath: string;\n  subpath: string | undefined;\n};\n\n/**\n * Splits a link into its link path and subpath.\n *\n * @param link - The link to split.\n * @returns An object containing the link path and subpath.\n */\nexport function splitSubpath(link: string): SplitSubpathResult {\n  const SUBPATH_SEPARATOR = \"#\";\n  const [linkPath = \"\", subpath] = normalize(link).split(SUBPATH_SEPARATOR);\n  return {\n    linkPath,\n    subpath: subpath ? SUBPATH_SEPARATOR + subpath : undefined\n  };\n}\n\n/**\n * Options for updating links in a file.\n */\ntype UpdateLinksInFileOptions = {\n  /**\n   * The obsidian app instance.\n   */\n  app: App;\n\n  /**\n   * The file to update the links in.\n   */\n  pathOrFile: PathOrFile;\n\n  /**\n   * The old path of the file.\n   */\n  oldPathOrFile: PathOrFile;\n\n  /**\n   * A map of old and new paths for renaming links.\n   */\n  renameMap: Map<string, string>;\n\n  /**\n   * Whether to force the links to be in Markdown format.\n   */\n  forceMarkdownLinks?: boolean | undefined;\n\n  /**\n   * Whether to update only embedded links.\n   */\n  embedOnlyLinks?: boolean | undefined;\n};\n\n/**\n * Updates the links in a file based on the provided parameters.\n *\n * @param options - The options for updating the links.\n * @returns - A promise that resolves when the links are updated.\n */\nexport async function updateLinksInFile(options: UpdateLinksInFileOptions): Promise<void> {\n  const {\n    app,\n    pathOrFile,\n    oldPathOrFile,\n    renameMap,\n    forceMarkdownLinks,\n    embedOnlyLinks\n  } = options;\n  await editLinks(app, pathOrFile, (link) => {\n    const isEmbedLink = link.original.startsWith(\"!\");\n    if (embedOnlyLinks !== undefined && embedOnlyLinks !== isEmbedLink) {\n      return;\n    }\n    return convertLink(app, link, pathOrFile, oldPathOrFile, renameMap, forceMarkdownLinks);\n  });\n}\n\n/**\n * Converts a link to a new path.\n *\n * @param app - The Obsidian application instance.\n * @param link - The reference cache for the link.\n * @param source - The source file.\n * @param oldPathOrFile - The old path of the link.\n * @param renameMap - A map of old paths to new paths for renaming.\n * @param forceMarkdownLinks - Optional flag to force markdown links.\n * @returns The converted link.\n */\nfunction convertLink(app: App, link: ReferenceCache, source: PathOrFile, oldPathOrFile: PathOrFile, renameMap: Map<string, string>, forceMarkdownLinks?: boolean): string {\n  oldPathOrFile ??= getPath(source);\n  return updateLink({\n    app,\n    link,\n    pathOrFile: extractLinkFile(app, link, oldPathOrFile),\n    oldPathOrFile,\n    sourcePathOrFile: source,\n    renameMap,\n    forceMarkdownLinks\n  });\n}\n\n/**\n * Extracts the file associated with a link.\n *\n * @param app - The Obsidian application instance.\n * @param link - The reference cache for the link.\n * @param oldPathOrFile - The old path of the file.\n * @returns The file associated with the link, or null if not found.\n */\nexport function extractLinkFile(app: App, link: ReferenceCache, oldPathOrFile: PathOrFile): TFile | null {\n  const { linkPath } = splitSubpath(link.link);\n  return app.metadataCache.getFirstLinkpathDest(linkPath, getPath(oldPathOrFile));\n}\n\ntype UpdateLinkOptions = {\n  /**\n   * The Obsidian app instance.\n   */\n  app: App,\n\n  /**\n   * The reference cache for the link.\n   */\n  link: ReferenceCache,\n\n  /**\n   * The file associated with the link.\n   */\n  pathOrFile: PathOrFile | null,\n\n  /**\n   * The old path of the file.\n   */\n  oldPathOrFile: PathOrFile,\n\n  /**\n   * The source file containing the link.\n   */\n  sourcePathOrFile: PathOrFile,\n\n  /**\n   * A map of old and new file paths.\n   */\n  renameMap: Map<string, string>,\n\n  /**\n   * Whether to force markdown links.\n   */\n  forceMarkdownLinks?: boolean | undefined\n};\n\n/**\n * Updates a link based on the provided parameters.\n *\n * @param options - The options for updating the link.\n * @returns The updated link.\n */\nexport function updateLink(options: UpdateLinkOptions): string {\n  const {\n    app,\n    link,\n    pathOrFile,\n    oldPathOrFile,\n    sourcePathOrFile: source,\n    renameMap,\n    forceMarkdownLinks\n  } = options;\n  if (!pathOrFile) {\n    return link.original;\n  }\n  let file = getFile(app, pathOrFile);\n  const sourcePath = getPath(source);\n  const oldPath = getPath(oldPathOrFile);\n  const isEmbed = link.original.startsWith(\"!\");\n  const isWikilink =\n    link.original.includes(\"[[\") && forceMarkdownLinks !== true;\n  const { subpath } = splitSubpath(link.link);\n\n  const newPath = renameMap.get(file.path);\n  const alias = getAlias({\n    app,\n    displayText: link.displayText,\n    file: pathOrFile,\n    otherPaths: [oldPath, newPath],\n    sourcePath\n  });\n\n  if (newPath) {\n    file = createTFileInstance(app.vault, newPath);\n  }\n\n  const newLink = generateMarkdownLink({\n    app,\n    pathOrFile: file,\n    sourcePathOrFile: sourcePath,\n    subpath,\n    alias,\n    isEmbed,\n    isWikilink\n  });\n  return newLink;\n}\n\nfunction getAlias({\n  app,\n  displayText,\n  file: pathOrFile,\n  otherPaths,\n  sourcePath\n}: {\n  app: App,\n  displayText: string | undefined,\n  file: PathOrFile,\n  otherPaths: (string | undefined)[]\n  sourcePath: string\n}): string | undefined {\n\n  const file = getFile(app, pathOrFile);\n\n  if (!displayText) {\n    return undefined;\n  }\n\n  const cleanDisplayText = normalizePath(displayText.split(\" > \")[0]!).replace(/\\.\\//g, \"\");\n\n  for (const path of [file.path, ...otherPaths]) {\n    if (!path) {\n      continue;\n    }\n    const extension = extname(path);\n    const fileNameWithExtension = basename(path);\n    const fileNameWithoutExtension = basename(path, extension);\n    if (cleanDisplayText === path || cleanDisplayText === fileNameWithExtension || cleanDisplayText === fileNameWithoutExtension) {\n      return undefined;\n    }\n  }\n\n  for (const omitMdExtension of [true, false]) {\n    const linkText = app.metadataCache.fileToLinktext(file, sourcePath, omitMdExtension);\n    if (cleanDisplayText === linkText) {\n      return undefined;\n    }\n  }\n\n  return displayText;\n}\n\n/**\n * Options for generating a markdown link.\n */\ntype GenerateMarkdownLinkOptions = {\n  /**\n   * The Obsidian app instance.\n   */\n  app: App,\n\n  /**\n   * The file to link to.\n   */\n  pathOrFile: PathOrFile,\n\n  /**\n   * The source path of the link.\n   */\n  sourcePathOrFile: PathOrFile,\n\n  /**\n   * The subpath of the link.\n   */\n  subpath?: string | undefined,\n\n  /**\n   * The alias for the link.\n   */\n  alias?: string | undefined,\n\n  /**\n   * Indicates if the link should be embedded.\n   */\n  isEmbed?: boolean | undefined,\n\n  /**\n   * Indicates if the link should be a wikilink.\n   */\n  isWikilink?: boolean | undefined,\n\n  /**\n   * Indicates if the link should be relative.\n   */\n  isRelative?: boolean | undefined\n};\n\n/**\n * Generates a markdown link based on the provided parameters.\n *\n * @param options - The options for generating the markdown link.\n * @returns The generated markdown link.\n */\nexport function generateMarkdownLink(options: GenerateMarkdownLinkOptions): string {\n  const {\n    app,\n    pathOrFile,\n    sourcePathOrFile,\n    subpath,\n    alias,\n    isEmbed,\n    isWikilink,\n    isRelative\n  } = options;\n  const file = getFile(app, pathOrFile);\n  const useMarkdownLinks = app.vault.getConfig(\"useMarkdownLinks\");\n  const newLinkFormat = app.vault.getConfig(\"newLinkFormat\");\n  if (isWikilink !== undefined) {\n    app.vault.setConfig(\"useMarkdownLinks\", !isWikilink);\n  }\n\n  if (isRelative === true) {\n    app.vault.setConfig(\"newLinkFormat\", \"relative\");\n  }\n\n  let link = app.fileManager.generateMarkdownLink(file, getPath(sourcePathOrFile), subpath, alias);\n\n  app.vault.setConfig(\"useMarkdownLinks\", useMarkdownLinks);\n  app.vault.setConfig(\"newLinkFormat\", newLinkFormat);\n\n  const isLinkEmbed = link.startsWith(\"!\");\n\n  if (isEmbed !== undefined && isEmbed !== isLinkEmbed) {\n    if (isEmbed) {\n      link = \"!\" + link;\n    } else {\n      link = link.slice(1);\n      link = link.replace(\"[]\", `[${alias || file.basename}]`);\n    }\n  }\n\n  return link;\n}\n\n/**\n * Edits the links in the specified file or path using the provided link converter function.\n *\n * @param app - The Obsidian application instance.\n * @param pathOrFile - The path or file to edit the links in.\n * @param linkConverter - The function that converts each link.\n * @param retryOptions - Optional options for retrying the operation.\n * @returns A promise that resolves when the links have been edited.\n */\nexport async function editLinks(\n  app: App,\n  pathOrFile: PathOrFile,\n  linkConverter: (link: ReferenceCache) => MaybePromise<string | void>,\n  retryOptions: Partial<RetryOptions> = {}): Promise<void> {\n  return await applyFileChanges(app, pathOrFile, async () => {\n    const cache = await getCacheSafe(app, pathOrFile);\n    if (!cache) {\n      return [];\n    }\n\n    const changes: FileChange[] = [];\n\n    for (const link of getAllLinks(cache)) {\n      const newContent = await linkConverter(link);\n      if (newContent === undefined) {\n        continue;\n      }\n\n      changes.push({\n        startIndex: link.position.start.offset,\n        endIndex: link.position.end.offset,\n        oldContent: link.original,\n        newContent\n      });\n    }\n\n    return changes;\n  }, retryOptions);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAaA,sBAKO;AACP,2BAGO;AACP,mBAGO;AACP,6BAAoC;AACpC,kBAGO;AACP,oBAA0B;AAC1B,mBAGO;AACP,2BAAwB;AACxB,mBAGO;AAzCP,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI,QAAQ,UAAU,EAAE,cAAc,UAAU,GAAG;AAC7G,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAiDO,SAAS,aAAa,MAAkC;AAC7D,QAAM,oBAAoB;AAC1B,QAAM,CAAC,WAAW,IAAI,OAAO,QAAI,yBAAU,IAAI,EAAE,MAAM,iBAAiB;AACxE,SAAO;AAAA,IACL;AAAA,IACA,SAAS,UAAU,oBAAoB,UAAU;AAAA,EACnD;AACF;AA2CA,eAAsB,kBAAkB,SAAkD;AACxF,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AACJ,QAAM,UAAU,KAAK,YAAY,CAAC,SAAS;AACzC,UAAM,cAAc,KAAK,SAAS,WAAW,GAAG;AAChD,QAAI,mBAAmB,UAAa,mBAAmB,aAAa;AAClE;AAAA,IACF;AACA,WAAO,YAAY,KAAK,MAAM,YAAY,eAAe,WAAW,kBAAkB;AAAA,EACxF,CAAC;AACH;AAaA,SAAS,YAAY,KAAU,MAAsB,QAAoB,eAA2B,WAAgC,oBAAsC;AACxK,wBAAkB,8BAAQ,MAAM;AAChC,SAAO,WAAW;AAAA,IAChB;AAAA,IACA;AAAA,IACA,YAAY,gBAAgB,KAAK,MAAM,aAAa;AAAA,IACpD;AAAA,IACA,kBAAkB;AAAA,IAClB;AAAA,IACA;AAAA,EACF,CAAC;AACH;AAUO,SAAS,gBAAgB,KAAU,MAAsB,eAAyC;AACvG,QAAM,EAAE,SAAS,IAAI,aAAa,KAAK,IAAI;AAC3C,SAAO,IAAI,cAAc,qBAAqB,cAAU,8BAAQ,aAAa,CAAC;AAChF;AA6CO,SAAS,WAAW,SAAoC;AAC7D,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,kBAAkB;AAAA,IAClB;AAAA,IACA;AAAA,EACF,IAAI;AACJ,MAAI,CAAC,YAAY;AACf,WAAO,KAAK;AAAA,EACd;AACA,MAAI,WAAO,sBAAQ,KAAK,UAAU;AAClC,QAAM,iBAAa,8BAAQ,MAAM;AACjC,QAAM,cAAU,8BAAQ,aAAa;AACrC,QAAM,UAAU,KAAK,SAAS,WAAW,GAAG;AAC5C,QAAM,aACJ,KAAK,SAAS,SAAS,IAAI,KAAK,uBAAuB;AACzD,QAAM,EAAE,QAAQ,IAAI,aAAa,KAAK,IAAI;AAE1C,QAAM,UAAU,UAAU,IAAI,KAAK,IAAI;AACvC,QAAM,QAAQ,SAAS;AAAA,IACrB;AAAA,IACA,aAAa,KAAK;AAAA,IAClB,MAAM;AAAA,IACN,YAAY,CAAC,SAAS,OAAO;AAAA,IAC7B;AAAA,EACF,CAAC;AAED,MAAI,SAAS;AACX,eAAO,4CAAoB,IAAI,OAAO,OAAO;AAAA,EAC/C;AAEA,QAAM,UAAU,qBAAqB;AAAA,IACnC;AAAA,IACA,YAAY;AAAA,IACZ,kBAAkB;AAAA,IAClB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AACD,SAAO;AACT;AAEA,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN;AAAA,EACA;AACF,GAMuB;AAErB,QAAM,WAAO,sBAAQ,KAAK,UAAU;AAEpC,MAAI,CAAC,aAAa;AAChB,WAAO;AAAA,EACT;AAEA,QAAM,uBAAmB,+BAAc,YAAY,MAAM,KAAK,EAAE,CAAC,CAAE,EAAE,QAAQ,SAAS,EAAE;AAExF,aAAW,QAAQ,CAAC,KAAK,MAAM,GAAG,UAAU,GAAG;AAC7C,QAAI,CAAC,MAAM;AACT;AAAA,IACF;AACA,UAAM,gBAAY,qBAAQ,IAAI;AAC9B,UAAM,4BAAwB,sBAAS,IAAI;AAC3C,UAAM,+BAA2B,sBAAS,MAAM,SAAS;AACzD,QAAI,qBAAqB,QAAQ,qBAAqB,yBAAyB,qBAAqB,0BAA0B;AAC5H,aAAO;AAAA,IACT;AAAA,EACF;AAEA,aAAW,mBAAmB,CAAC,MAAM,KAAK,GAAG;AAC3C,UAAM,WAAW,IAAI,cAAc,eAAe,MAAM,YAAY,eAAe;AACnF,QAAI,qBAAqB,UAAU;AACjC,aAAO;AAAA,IACT;AAAA,EACF;AAEA,SAAO;AACT;AAqDO,SAAS,qBAAqB,SAA8C;AACjF,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AACJ,QAAM,WAAO,sBAAQ,KAAK,UAAU;AACpC,QAAM,mBAAmB,IAAI,MAAM,UAAU,kBAAkB;AAC/D,QAAM,gBAAgB,IAAI,MAAM,UAAU,eAAe;AACzD,MAAI,eAAe,QAAW;AAC5B,QAAI,MAAM,UAAU,oBAAoB,CAAC,UAAU;AAAA,EACrD;AAEA,MAAI,eAAe,MAAM;AACvB,QAAI,MAAM,UAAU,iBAAiB,UAAU;AAAA,EACjD;AAEA,MAAI,OAAO,IAAI,YAAY,qBAAqB,UAAM,8BAAQ,gBAAgB,GAAG,SAAS,KAAK;AAE/F,MAAI,MAAM,UAAU,oBAAoB,gBAAgB;AACxD,MAAI,MAAM,UAAU,iBAAiB,aAAa;AAElD,QAAM,cAAc,KAAK,WAAW,GAAG;AAEvC,MAAI,YAAY,UAAa,YAAY,aAAa;AACpD,QAAI,SAAS;AACX,aAAO,MAAM;AAAA,IACf,OAAO;AACL,aAAO,KAAK,MAAM,CAAC;AACnB,aAAO,KAAK,QAAQ,MAAM,IAAI,SAAS,KAAK,QAAQ,GAAG;AAAA,IACzD;AAAA,EACF;AAEA,SAAO;AACT;AAWA,eAAsB,UACpB,KACA,YACA,eACA,eAAsC,CAAC,GAAkB;AACzD,SAAO,UAAM,+BAAiB,KAAK,YAAY,YAAY;AACzD,UAAM,QAAQ,UAAM,mCAAa,KAAK,UAAU;AAChD,QAAI,CAAC,OAAO;AACV,aAAO,CAAC;AAAA,IACV;AAEA,UAAM,UAAwB,CAAC;AAE/B,eAAW,YAAQ,kCAAY,KAAK,GAAG;AACrC,YAAM,aAAa,MAAM,cAAc,IAAI;AAC3C,UAAI,eAAe,QAAW;AAC5B;AAAA,MACF;AAEA,cAAQ,KAAK;AAAA,QACX,YAAY,KAAK,SAAS,MAAM;AAAA,QAChC,UAAU,KAAK,SAAS,IAAI;AAAA,QAC5B,YAAY,KAAK;AAAA,QACjB;AAAA,MACF,CAAC;AAAA,IACH;AAEA,WAAO;AAAA,EACT,GAAG,YAAY;AACjB;",
  "names": []
}

|
230
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Link.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Link\n * This module provides utilities for handling and updating links within Obsidian vaults. It includes\n * functions to split paths, update links in files, and generate markdown links with various options.\n * The functions integrate with Obsidian's API to ensure that links are managed correctly within the vault.\n **/\n\nimport {\n  normalizePath,\n  type App,\n  type ReferenceCache,\n  type TFile\n} from \"obsidian\";\nimport {\n  getAllLinks,\n  getCacheSafe\n} from \"./MetadataCache.ts\";\nimport {\n  applyFileChanges,\n  type FileChange\n} from \"./Vault.ts\";\nimport { createTFileInstance } from \"obsidian-typings/implementations\";\nimport {\n  basename,\n  extname\n} from \"../Path.ts\";\nimport { normalize } from \"../String.ts\";\nimport {\n  getFile,\n  type PathOrFile\n} from \"./TFile.ts\";\nimport { getPath } from \"./TAbstractFile.ts\";\nimport {\n  type MaybePromise,\n  type RetryOptions\n} from \"../Async.ts\";\n\ntype SplitSubpathResult = {\n  linkPath: string;\n  subpath: string | undefined;\n};\n\n/**\n * Splits a link into its link path and subpath.\n *\n * @param link - The link to split.\n * @returns An object containing the link path and subpath.\n */\nexport function splitSubpath(link: string): SplitSubpathResult {\n  const SUBPATH_SEPARATOR = \"#\";\n  const [linkPath = \"\", subpath] = normalize(link).split(SUBPATH_SEPARATOR);\n  return {\n    linkPath,\n    subpath: subpath ? SUBPATH_SEPARATOR + subpath : undefined\n  };\n}\n\n/**\n * Options for updating links in a file.\n */\ntype UpdateLinksInFileOptions = {\n  /**\n   * The obsidian app instance.\n   */\n  app: App;\n\n  /**\n   * The file to update the links in.\n   */\n  pathOrFile: PathOrFile;\n\n  /**\n   * The old path of the file.\n   */\n  oldPathOrFile: PathOrFile;\n\n  /**\n   * A map of old and new paths for renaming links.\n   */\n  renameMap: Map<string, string>;\n\n  /**\n   * Whether to force the links to be in Markdown format.\n   */\n  forceMarkdownLinks?: boolean | undefined;\n\n  /**\n   * Whether to update only embedded links.\n   */\n  embedOnlyLinks?: boolean | undefined;\n};\n\n/**\n * Updates the links in a file based on the provided parameters.\n *\n * @param options - The options for updating the links.\n * @returns - A promise that resolves when the links are updated.\n */\nexport async function updateLinksInFile(options: UpdateLinksInFileOptions): Promise<void> {\n  const {\n    app,\n    pathOrFile,\n    oldPathOrFile,\n    renameMap,\n    forceMarkdownLinks,\n    embedOnlyLinks\n  } = options;\n  await editLinks(app, pathOrFile, (link) => {\n    const isEmbedLink = link.original.startsWith(\"!\");\n    if (embedOnlyLinks !== undefined && embedOnlyLinks !== isEmbedLink) {\n      return;\n    }\n    return convertLink(app, link, pathOrFile, oldPathOrFile, renameMap, forceMarkdownLinks);\n  });\n}\n\n/**\n * Converts a link to a new path.\n *\n * @param app - The Obsidian application instance.\n * @param link - The reference cache for the link.\n * @param source - The source file.\n * @param oldPathOrFile - The old path of the link.\n * @param renameMap - A map of old paths to new paths for renaming.\n * @param forceMarkdownLinks - Optional flag to force markdown links.\n * @returns The converted link.\n */\nfunction convertLink(app: App, link: ReferenceCache, source: PathOrFile, oldPathOrFile: PathOrFile, renameMap: Map<string, string>, forceMarkdownLinks?: boolean): string {\n  oldPathOrFile ??= getPath(source);\n  return updateLink({\n    app,\n    link,\n    pathOrFile: extractLinkFile(app, link, oldPathOrFile),\n    oldPathOrFile,\n    sourcePathOrFile: source,\n    renameMap,\n    forceMarkdownLinks\n  });\n}\n\n/**\n * Extracts the file associated with a link.\n *\n * @param app - The Obsidian application instance.\n * @param link - The reference cache for the link.\n * @param oldPathOrFile - The old path of the file.\n * @returns The file associated with the link, or null if not found.\n */\nexport function extractLinkFile(app: App, link: ReferenceCache, oldPathOrFile: PathOrFile): TFile | null {\n  const { linkPath } = splitSubpath(link.link);\n  return app.metadataCache.getFirstLinkpathDest(linkPath, getPath(oldPathOrFile));\n}\n\ntype UpdateLinkOptions = {\n  /**\n   * The Obsidian app instance.\n   */\n  app: App,\n\n  /**\n   * The reference cache for the link.\n   */\n  link: ReferenceCache,\n\n  /**\n   * The file associated with the link.\n   */\n  pathOrFile: PathOrFile | null,\n\n  /**\n   * The old path of the file.\n   */\n  oldPathOrFile: PathOrFile,\n\n  /**\n   * The source file containing the link.\n   */\n  sourcePathOrFile: PathOrFile,\n\n  /**\n   * A map of old and new file paths.\n   */\n  renameMap: Map<string, string>,\n\n  /**\n   * Whether to force markdown links.\n   */\n  forceMarkdownLinks?: boolean | undefined\n};\n\n/**\n * Updates a link based on the provided parameters.\n *\n * @param options - The options for updating the link.\n * @returns The updated link.\n */\nexport function updateLink(options: UpdateLinkOptions): string {\n  const {\n    app,\n    link,\n    pathOrFile,\n    oldPathOrFile,\n    sourcePathOrFile: source,\n    renameMap,\n    forceMarkdownLinks\n  } = options;\n  if (!pathOrFile) {\n    return link.original;\n  }\n  let file = getFile(app, pathOrFile);\n  const sourcePath = getPath(source);\n  const oldPath = getPath(oldPathOrFile);\n  const isEmbed = link.original.startsWith(\"!\");\n  const isWikilink =\n    link.original.includes(\"[[\") && forceMarkdownLinks !== true;\n  const { subpath } = splitSubpath(link.link);\n\n  const newPath = renameMap.get(file.path);\n  const alias = getAlias({\n    app,\n    displayText: link.displayText,\n    file: pathOrFile,\n    otherPaths: [oldPath, newPath],\n    sourcePath\n  });\n\n  if (newPath) {\n    file = createTFileInstance(app.vault, newPath);\n  }\n\n  const newLink = generateMarkdownLink({\n    app,\n    pathOrFile: file,\n    sourcePathOrFile: sourcePath,\n    subpath,\n    alias,\n    isEmbed,\n    isWikilink\n  });\n  return newLink;\n}\n\n/**\n * Options for getting the alias of a link.\n */\ntype GetAliasOptions = {\n  /**\n   * The Obsidian app instance.\n   */\n  app: App;\n\n  /**\n   * The display text of the link.\n   */\n  displayText: string | undefined;\n\n  /**\n   * The path or file of the link.\n   */\n  file: PathOrFile;\n\n  /**\n   * Other paths associated with the link.\n   */\n  otherPaths: (string | undefined)[];\n\n  /**\n   * The source path of the link.\n   */\n  sourcePath: string;\n};\n\n\n/**\n * Retrieves the alias for a given link.\n *\n * @param options - The options for retrieving the alias.\n * @returns The alias of the link, or undefined if should be default.\n */\nexport function getAlias(options: GetAliasOptions): string | undefined {\n  const {\n    app,\n    displayText,\n    file: pathOrFile,\n    otherPaths,\n    sourcePath\n  } = options;\n  const file = getFile(app, pathOrFile);\n\n  if (!displayText) {\n    return undefined;\n  }\n\n  const cleanDisplayText = normalizePath(displayText.split(\" > \")[0]!).replace(/\\.\\//g, \"\");\n\n  for (const path of [file.path, ...otherPaths]) {\n    if (!path) {\n      continue;\n    }\n    const extension = extname(path);\n    const fileNameWithExtension = basename(path);\n    const fileNameWithoutExtension = basename(path, extension);\n    if (cleanDisplayText === path || cleanDisplayText === fileNameWithExtension || cleanDisplayText === fileNameWithoutExtension) {\n      return undefined;\n    }\n  }\n\n  for (const omitMdExtension of [true, false]) {\n    const linkText = app.metadataCache.fileToLinktext(file, sourcePath, omitMdExtension);\n    if (cleanDisplayText === linkText) {\n      return undefined;\n    }\n  }\n\n  return displayText;\n}\n\n/**\n * Options for generating a markdown link.\n */\ntype GenerateMarkdownLinkOptions = {\n  /**\n   * The Obsidian app instance.\n   */\n  app: App,\n\n  /**\n   * The file to link to.\n   */\n  pathOrFile: PathOrFile,\n\n  /**\n   * The source path of the link.\n   */\n  sourcePathOrFile: PathOrFile,\n\n  /**\n   * The subpath of the link.\n   */\n  subpath?: string | undefined,\n\n  /**\n   * The alias for the link.\n   */\n  alias?: string | undefined,\n\n  /**\n   * Indicates if the link should be embedded.\n   */\n  isEmbed?: boolean | undefined,\n\n  /**\n   * Indicates if the link should be a wikilink.\n   */\n  isWikilink?: boolean | undefined,\n\n  /**\n   * Indicates if the link should be relative.\n   */\n  isRelative?: boolean | undefined\n};\n\n/**\n * Generates a markdown link based on the provided parameters.\n *\n * @param options - The options for generating the markdown link.\n * @returns The generated markdown link.\n */\nexport function generateMarkdownLink(options: GenerateMarkdownLinkOptions): string {\n  const {\n    app,\n    pathOrFile,\n    sourcePathOrFile,\n    subpath,\n    alias,\n    isEmbed,\n    isWikilink,\n    isRelative\n  } = options;\n  const file = getFile(app, pathOrFile);\n  const useMarkdownLinks = app.vault.getConfig(\"useMarkdownLinks\");\n  const newLinkFormat = app.vault.getConfig(\"newLinkFormat\");\n  if (isWikilink !== undefined) {\n    app.vault.setConfig(\"useMarkdownLinks\", !isWikilink);\n  }\n\n  if (isRelative === true) {\n    app.vault.setConfig(\"newLinkFormat\", \"relative\");\n  }\n\n  let link = app.fileManager.generateMarkdownLink(file, getPath(sourcePathOrFile), subpath, alias);\n\n  app.vault.setConfig(\"useMarkdownLinks\", useMarkdownLinks);\n  app.vault.setConfig(\"newLinkFormat\", newLinkFormat);\n\n  const isLinkEmbed = link.startsWith(\"!\");\n\n  if (isEmbed !== undefined && isEmbed !== isLinkEmbed) {\n    if (isEmbed) {\n      link = \"!\" + link;\n    } else {\n      link = link.slice(1);\n      link = link.replace(\"[]\", `[${alias || file.basename}]`);\n    }\n  }\n\n  return link;\n}\n\n/**\n * Edits the links in the specified file or path using the provided link converter function.\n *\n * @param app - The Obsidian application instance.\n * @param pathOrFile - The path or file to edit the links in.\n * @param linkConverter - The function that converts each link.\n * @param retryOptions - Optional options for retrying the operation.\n * @returns A promise that resolves when the links have been edited.\n */\nexport async function editLinks(\n  app: App,\n  pathOrFile: PathOrFile,\n  linkConverter: (link: ReferenceCache) => MaybePromise<string | void>,\n  retryOptions: Partial<RetryOptions> = {}): Promise<void> {\n  return await applyFileChanges(app, pathOrFile, async () => {\n    const cache = await getCacheSafe(app, pathOrFile);\n    if (!cache) {\n      return [];\n    }\n\n    const changes: FileChange[] = [];\n\n    for (const link of getAllLinks(cache)) {\n      const newContent = await linkConverter(link);\n      if (newContent === undefined) {\n        continue;\n      }\n\n      changes.push({\n        startIndex: link.position.start.offset,\n        endIndex: link.position.end.offset,\n        oldContent: link.original,\n        newContent\n      });\n    }\n\n    return changes;\n  }, retryOptions);\n}\n"],
  "mappings": "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",
  "names": []
}

|
@@ -100,6 +100,38 @@ type UpdateLinkOptions = {
|
|
100
100
|
* @returns The updated link.
|
101
101
|
*/
|
102
102
|
export declare function updateLink(options: UpdateLinkOptions): string;
|
103
|
+
/**
|
104
|
+
* Options for getting the alias of a link.
|
105
|
+
*/
|
106
|
+
type GetAliasOptions = {
|
107
|
+
/**
|
108
|
+
* The Obsidian app instance.
|
109
|
+
*/
|
110
|
+
app: App;
|
111
|
+
/**
|
112
|
+
* The display text of the link.
|
113
|
+
*/
|
114
|
+
displayText: string | undefined;
|
115
|
+
/**
|
116
|
+
* The path or file of the link.
|
117
|
+
*/
|
118
|
+
file: PathOrFile;
|
119
|
+
/**
|
120
|
+
* Other paths associated with the link.
|
121
|
+
*/
|
122
|
+
otherPaths: (string | undefined)[];
|
123
|
+
/**
|
124
|
+
* The source path of the link.
|
125
|
+
*/
|
126
|
+
sourcePath: string;
|
127
|
+
};
|
128
|
+
/**
|
129
|
+
* Retrieves the alias for a given link.
|
130
|
+
*
|
131
|
+
* @param options - The options for retrieving the alias.
|
132
|
+
* @returns The alias of the link, or undefined if should be default.
|
133
|
+
*/
|
134
|
+
export declare function getAlias(options: GetAliasOptions): string | undefined;
|
103
135
|
/**
|
104
136
|
* Options for generating a markdown link.
|
105
137
|
*/
|
package/package.json
CHANGED