obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
96 lines (93 loc) • 15.1 kB
JavaScript
/*
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
if you want to view the source, please visit the github repository of this plugin
*/
(function initCjs(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;const originalRequire=require;if(originalRequire&&!originalRequire.__isPatched){require=Object.assign(id=>requirePatched(id),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>{const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};return browserProcess},"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&"default"in module?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id){const module=originalRequire?.(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})();
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var AttachmentPath_exports = {};
__export(AttachmentPath_exports, {
getAttachmentFilePath: () => getAttachmentFilePath,
getAttachmentFolderPath: () => getAttachmentFolderPath,
getAvailablePathForAttachments: () => getAvailablePathForAttachments,
hasOwnAttachmentFolder: () => hasOwnAttachmentFolder
});
module.exports = __toCommonJS(AttachmentPath_exports);
var import_implementations = require('obsidian-typings/implementations');
var import_Path = require('../Path.cjs');
var import_String = require('../String.cjs');
var import_FileSystem = require('./FileSystem.cjs');
async function getAttachmentFilePath(app, attachmentPathOrFile, notePathOrFile) {
const attachmentPath = (0, import_FileSystem.getPath)(app, attachmentPathOrFile);
const notePath = (0, import_FileSystem.getPath)(app, notePathOrFile);
const note = (0, import_FileSystem.getFile)(app, notePath, true);
const ext = (0, import_Path.extname)(attachmentPath);
const fileName = (0, import_Path.basename)(attachmentPath, ext);
const internalFn = app.vault.getAvailablePathForAttachments;
if (internalFn.isExtended) {
return internalFn(fileName, ext.slice(1), note, true);
}
return await getAvailablePathForAttachments(app, fileName, ext.slice(1), note, true);
}
async function getAttachmentFolderPath(app, notePathOrFile) {
return (0, import_implementations.parentFolderPath)(await getAttachmentFilePath(app, "DUMMY_FILE.pdf", notePathOrFile));
}
async function getAvailablePathForAttachments(app, attachmentFileName, attachmentExtension, noteFile, shouldSkipMissingAttachmentFolderCreation) {
let attachmentFolderPath = app.vault.getConfig("attachmentFolderPath");
const isCurrentFolder = attachmentFolderPath === "." || attachmentFolderPath === "./";
let relativePath = null;
if (attachmentFolderPath.startsWith("./")) {
relativePath = (0, import_String.trimStart)(attachmentFolderPath, "./");
}
if (isCurrentFolder) {
attachmentFolderPath = noteFile ? noteFile.parent?.path ?? "" : "";
} else if (relativePath) {
attachmentFolderPath = (noteFile ? noteFile.parent?.getParentPrefix() ?? "" : "") + relativePath;
}
attachmentFolderPath = (0, import_String.normalize)(normalizeSlashes(attachmentFolderPath));
attachmentFileName = (0, import_String.normalize)(normalizeSlashes(attachmentFileName));
let folder = (0, import_FileSystem.getFolderOrNull)(app, attachmentFolderPath, true);
if (!folder && relativePath) {
if (shouldSkipMissingAttachmentFolderCreation) {
folder = (0, import_FileSystem.getFolder)(app, attachmentFolderPath, true);
} else {
folder = await app.vault.createFolder(attachmentFolderPath);
}
}
const prefix = folder?.getParentPrefix() ?? "";
return app.vault.getAvailablePath(prefix + attachmentFileName, attachmentExtension);
}
async function hasOwnAttachmentFolder(app, path) {
const attachmentFolderPath = await getAttachmentFolderPath(app, path);
const dummyAttachmentFolderPath = await getAttachmentFolderPath(app, (0, import_Path.join)((0, import_Path.dirname)(path), "DUMMY_FILE.md"));
return attachmentFolderPath !== dummyAttachmentFolderPath;
}
function normalizeSlashes(path) {
path = (0, import_String.replaceAll)(path, /(?:[\\/])+/g, "/");
path = (0, import_String.replaceAll)(path, /^\/+|\/+$/g, "");
return path || "/";
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
getAttachmentFilePath,
getAttachmentFolderPath,
getAvailablePathForAttachments,
hasOwnAttachmentFolder
});
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/AttachmentPath.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Provides utility functions for working with attachment paths.\n */\n\nimport type {\n  App,\n  TFile\n} from 'obsidian';\n\nimport { parentFolderPath } from 'obsidian-typings/implementations';\n\nimport type { PathOrFile } from './FileSystem.ts';\n\nimport {\n  basename,\n  dirname,\n  extname,\n  join\n} from '../Path.ts';\nimport {\n  normalize,\n  replaceAll,\n  trimStart\n} from '../String.ts';\nimport {\n  getFile,\n  getFolder,\n  getFolderOrNull,\n  getPath\n} from './FileSystem.ts';\n\n/**\n * Is overridden wrapper.\n */\nexport interface ExtendedWrapper {\n  /**\n   * Is extended.\n   */\n  isExtended: true;\n}\n\n/**\n * Get available path for attachments function.\n */\nexport type GetAvailablePathForAttachmentsExtendedFn = (\n  attachmentFileName: string,\n  attachmentExtension: string,\n  noteFile: null | TFile,\n  shouldSkipMissingAttachmentFolderCreation?: boolean\n) => Promise<string>;\n\n/**\n * Retrieves the file path for an attachment within a note.\n *\n * @param app - The Obsidian application instance.\n * @param attachmentPathOrFile - The path of the attachment.\n * @param notePathOrFile - The path of the note.\n * @returns A {@link Promise} that resolves to the file path of the attachment.\n */\nexport async function getAttachmentFilePath(app: App, attachmentPathOrFile: PathOrFile, notePathOrFile: PathOrFile): Promise<string> {\n  const attachmentPath = getPath(app, attachmentPathOrFile);\n  const notePath = getPath(app, notePathOrFile);\n  const note = getFile(app, notePath, true);\n  const ext = extname(attachmentPath);\n  const fileName = basename(attachmentPath, ext);\n\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  const internalFn = app.vault.getAvailablePathForAttachments;\n  if ((internalFn as Partial<ExtendedWrapper>).isExtended) {\n    return (internalFn as GetAvailablePathForAttachmentsExtendedFn)(fileName, ext.slice(1), note, true);\n  }\n\n  return await getAvailablePathForAttachments(app, fileName, ext.slice(1), note, true);\n}\n\n/**\n * Retrieves the attachment folder path for a given note.\n *\n * @param app - The Obsidian application instance.\n * @param notePathOrFile - The path of the note.\n * @returns A {@link Promise} that resolves to the attachment folder path.\n */\nexport async function getAttachmentFolderPath(app: App, notePathOrFile: PathOrFile): Promise<string> {\n  return parentFolderPath(await getAttachmentFilePath(app, 'DUMMY_FILE.pdf', notePathOrFile));\n}\n\n/**\n * Retrieves the available path for attachments.\n *\n * @param app - The Obsidian application instance.\n * @param attachmentFileName - File name of the attachment.\n * @param attachmentExtension - Extension of the attachment.\n * @param noteFile - The file to attach to.\n * @param shouldSkipMissingAttachmentFolderCreation - Should missing attachment folder creation be skipped?\n * @returns A {@link Promise} that resolves to the available path for attachments.\n */\nexport async function getAvailablePathForAttachments(\n  app: App,\n  attachmentFileName: string,\n  attachmentExtension: string,\n  noteFile: null | TFile,\n  shouldSkipMissingAttachmentFolderCreation: boolean\n): Promise<string> {\n  let attachmentFolderPath = app.vault.getConfig('attachmentFolderPath') as string;\n  const isCurrentFolder = attachmentFolderPath === '.' || attachmentFolderPath === './';\n  let relativePath = null;\n\n  if (attachmentFolderPath.startsWith('./')) {\n    relativePath = trimStart(attachmentFolderPath, './');\n  }\n\n  if (isCurrentFolder) {\n    attachmentFolderPath = noteFile ? noteFile.parent?.path ?? '' : '';\n  } else if (relativePath) {\n    attachmentFolderPath = (noteFile ? noteFile.parent?.getParentPrefix() ?? '' : '') + relativePath;\n  }\n\n  attachmentFolderPath = normalize(normalizeSlashes(attachmentFolderPath));\n  attachmentFileName = normalize(normalizeSlashes(attachmentFileName));\n\n  let folder = getFolderOrNull(app, attachmentFolderPath, true);\n\n  if (!folder && relativePath) {\n    if (shouldSkipMissingAttachmentFolderCreation) {\n      folder = getFolder(app, attachmentFolderPath, true);\n    } else {\n      folder = await app.vault.createFolder(attachmentFolderPath);\n    }\n  }\n\n  const prefix = folder?.getParentPrefix() ?? '';\n  return app.vault.getAvailablePath(prefix + attachmentFileName, attachmentExtension);\n}\n\n/**\n * Checks if a note has its own attachment folder.\n *\n * @param app - The Obsidian application instance.\n * @param path - The path of the note.\n * @returns A {@link Promise} that resolves to a boolean indicating whether the note has its own attachment folder.\n */\nexport async function hasOwnAttachmentFolder(app: App, path: string): Promise<boolean> {\n  const attachmentFolderPath = await getAttachmentFolderPath(app, path);\n  const dummyAttachmentFolderPath = await getAttachmentFolderPath(app, join(dirname(path), 'DUMMY_FILE.md'));\n  return attachmentFolderPath !== dummyAttachmentFolderPath;\n}\n\n/**\n * Normalizes a path by combining multiple slashes into a single slash and removing leading and trailing slashes.\n *\n * @param path - Path to normalize.\n * @returns The normalized path.\n */\nfunction normalizeSlashes(path: string): string {\n  path = replaceAll(path, /(?:[\\\\/])+/g, '/');\n  path = replaceAll(path, /^\\/+|\\/+$/g, '');\n  return path || '/';\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,6BAAiC;AAIjC,kBAKO;AACP,oBAIO;AACP,wBAKO;AA8BP,eAAsB,sBAAsB,KAAU,sBAAkC,gBAA6C;AACnI,QAAM,qBAAiB,2BAAQ,KAAK,oBAAoB;AACxD,QAAM,eAAW,2BAAQ,KAAK,cAAc;AAC5C,QAAM,WAAO,2BAAQ,KAAK,UAAU,IAAI;AACxC,QAAM,UAAM,qBAAQ,cAAc;AAClC,QAAM,eAAW,sBAAS,gBAAgB,GAAG;AAG7C,QAAM,aAAa,IAAI,MAAM;AAC7B,MAAK,WAAwC,YAAY;AACvD,WAAQ,WAAwD,UAAU,IAAI,MAAM,CAAC,GAAG,MAAM,IAAI;AAAA,EACpG;AAEA,SAAO,MAAM,+BAA+B,KAAK,UAAU,IAAI,MAAM,CAAC,GAAG,MAAM,IAAI;AACrF;AASA,eAAsB,wBAAwB,KAAU,gBAA6C;AACnG,aAAO,yCAAiB,MAAM,sBAAsB,KAAK,kBAAkB,cAAc,CAAC;AAC5F;AAYA,eAAsB,+BACpB,KACA,oBACA,qBACA,UACA,2CACiB;AACjB,MAAI,uBAAuB,IAAI,MAAM,UAAU,sBAAsB;AACrE,QAAM,kBAAkB,yBAAyB,OAAO,yBAAyB;AACjF,MAAI,eAAe;AAEnB,MAAI,qBAAqB,WAAW,IAAI,GAAG;AACzC,uBAAe,yBAAU,sBAAsB,IAAI;AAAA,EACrD;AAEA,MAAI,iBAAiB;AACnB,2BAAuB,WAAW,SAAS,QAAQ,QAAQ,KAAK;AAAA,EAClE,WAAW,cAAc;AACvB,4BAAwB,WAAW,SAAS,QAAQ,gBAAgB,KAAK,KAAK,MAAM;AAAA,EACtF;AAEA,6BAAuB,yBAAU,iBAAiB,oBAAoB,CAAC;AACvE,2BAAqB,yBAAU,iBAAiB,kBAAkB,CAAC;AAEnE,MAAI,aAAS,mCAAgB,KAAK,sBAAsB,IAAI;AAE5D,MAAI,CAAC,UAAU,cAAc;AAC3B,QAAI,2CAA2C;AAC7C,mBAAS,6BAAU,KAAK,sBAAsB,IAAI;AAAA,IACpD,OAAO;AACL,eAAS,MAAM,IAAI,MAAM,aAAa,oBAAoB;AAAA,IAC5D;AAAA,EACF;AAEA,QAAM,SAAS,QAAQ,gBAAgB,KAAK;AAC5C,SAAO,IAAI,MAAM,iBAAiB,SAAS,oBAAoB,mBAAmB;AACpF;AASA,eAAsB,uBAAuB,KAAU,MAAgC;AACrF,QAAM,uBAAuB,MAAM,wBAAwB,KAAK,IAAI;AACpE,QAAM,4BAA4B,MAAM,wBAAwB,SAAK,sBAAK,qBAAQ,IAAI,GAAG,eAAe,CAAC;AACzG,SAAO,yBAAyB;AAClC;AAQA,SAAS,iBAAiB,MAAsB;AAC9C,aAAO,0BAAW,MAAM,eAAe,GAAG;AAC1C,aAAO,0BAAW,MAAM,cAAc,EAAE;AACxC,SAAO,QAAQ;AACjB;",
  "names": []
}
