obsidian-dev-utils 44.3.0 → 45.0.1
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 +10 -0
- package/dist/lib/cjs/Async.cjs +54 -33
- package/dist/lib/cjs/Async.d.cts +92 -10
- package/dist/lib/cjs/Library.cjs +1 -1
- package/dist/lib/cjs/obsidian/AsyncWithNotice.cjs +190 -0
- package/dist/lib/cjs/obsidian/AsyncWithNotice.d.cts +74 -0
- package/dist/lib/cjs/obsidian/Callout.cjs +9 -2
- package/dist/lib/cjs/obsidian/Dataview.cjs +2 -2
- package/dist/lib/cjs/obsidian/Logger.cjs +3 -3
- package/dist/lib/cjs/obsidian/MetadataCache.cjs +46 -41
- package/dist/lib/cjs/obsidian/Queue.cjs +35 -17
- package/dist/lib/cjs/obsidian/Queue.d.cts +62 -12
- package/dist/lib/cjs/obsidian/RenameDeleteHandler.cjs +38 -27
- package/dist/lib/cjs/obsidian/Vault.cjs +46 -66
- package/dist/lib/cjs/obsidian/Vault.d.cts +0 -8
- package/dist/lib/cjs/obsidian/i18n/locales/en.cjs +28 -2
- package/dist/lib/cjs/obsidian/i18n/locales/en.d.cts +26 -0
- package/dist/lib/cjs/obsidian/i18n/locales/translationsMap.d.cts +26 -0
- package/dist/lib/cjs/obsidian/index.cjs +4 -1
- package/dist/lib/cjs/obsidian/index.d.cts +1 -0
- package/dist/lib/esm/Async.d.mts +92 -10
- package/dist/lib/esm/Async.mjs +54 -33
- package/dist/lib/esm/Library.mjs +1 -1
- package/dist/lib/esm/obsidian/AsyncWithNotice.d.mts +74 -0
- package/dist/lib/esm/obsidian/AsyncWithNotice.mjs +86 -0
- package/dist/lib/esm/obsidian/Callout.mjs +9 -2
- package/dist/lib/esm/obsidian/Dataview.mjs +2 -2
- package/dist/lib/esm/obsidian/Logger.mjs +3 -3
- package/dist/lib/esm/obsidian/MetadataCache.mjs +47 -41
- package/dist/lib/esm/obsidian/Queue.d.mts +62 -12
- package/dist/lib/esm/obsidian/Queue.mjs +36 -19
- package/dist/lib/esm/obsidian/RenameDeleteHandler.mjs +38 -27
- package/dist/lib/esm/obsidian/Vault.d.mts +0 -8
- package/dist/lib/esm/obsidian/Vault.mjs +47 -70
- package/dist/lib/esm/obsidian/i18n/locales/en.d.mts +26 -0
- package/dist/lib/esm/obsidian/i18n/locales/en.mjs +28 -2
- package/dist/lib/esm/obsidian/i18n/locales/translationsMap.d.mts +26 -0
- package/dist/lib/esm/obsidian/index.d.mts +1 -0
- package/dist/lib/esm/obsidian/index.mjs +3 -1
- package/obsidian/AsyncWithNotice/package.json +6 -0
- package/package.json +7 -7
|
@@ -141,13 +141,14 @@ module.exports = __toCommonJS(Vault_exports);
|
|
|
141
141
|
var import_obsidian = require('obsidian');
|
|
142
142
|
var import_implementations = require('obsidian-typings/implementations');
|
|
143
143
|
var import_AbortController = require('../AbortController.cjs');
|
|
144
|
-
var import_Async = require('../Async.cjs');
|
|
145
144
|
var import_Debug = require('../Debug.cjs');
|
|
146
145
|
var import_Function = require('../Function.cjs');
|
|
147
146
|
var import_Path = require('../Path.cjs');
|
|
148
147
|
var import_ValueProvider = require('../ValueProvider.cjs');
|
|
148
|
+
var import_AsyncWithNotice = require('./AsyncWithNotice.cjs');
|
|
149
149
|
var import_Editor = require('./Editor.cjs');
|
|
150
150
|
var import_FileSystem = require('./FileSystem.cjs');
|
|
151
|
+
var import_i18n = require('./i18n/i18n.cjs');
|
|
151
152
|
async function copySafe(app, oldPathOrFile, newPath) {
|
|
152
153
|
const file = (0, import_FileSystem.getFile)(app, oldPathOrFile);
|
|
153
154
|
const newFolderPath = (0, import_implementations.parentFolderPath)(newPath);
|
|
@@ -273,38 +274,15 @@ async function listSafe(app, pathOrFolder) {
|
|
|
273
274
|
}
|
|
274
275
|
async function process(app, pathOrFile, newContentProvider, options = {}) {
|
|
275
276
|
const DEFAULT_RETRY_OPTIONS = {
|
|
276
|
-
// eslint-disable-next-line no-magic-numbers -- Default values.
|
|
277
|
-
noticeDelayInMilliseconds: 200,
|
|
278
277
|
shouldFailOnMissingFile: true,
|
|
279
278
|
shouldLockEditorWhileProcessing: true,
|
|
280
|
-
|
|
279
|
+
// eslint-disable-next-line no-magic-numbers -- Default value.
|
|
280
|
+
timeoutInMilliseconds: 500
|
|
281
281
|
};
|
|
282
282
|
const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...options };
|
|
283
283
|
const abortController = new AbortController();
|
|
284
284
|
fullOptions.abortSignal = (0, import_AbortController.abortSignalAny)(fullOptions.abortSignal, abortController.signal);
|
|
285
|
-
let isProcessing = true;
|
|
286
|
-
let notice = null;
|
|
287
285
|
const path = (0, import_FileSystem.getPath)(app, pathOrFile);
|
|
288
|
-
if (fullOptions.shouldShowNoticeWhileProcessing) {
|
|
289
|
-
window.setTimeout(() => {
|
|
290
|
-
if (!isProcessing) {
|
|
291
|
-
return;
|
|
292
|
-
}
|
|
293
|
-
notice = new import_obsidian.Notice(
|
|
294
|
-
createFragment((f) => {
|
|
295
|
-
f.appendText(`Processing file ${path}...`);
|
|
296
|
-
f.createEl("br");
|
|
297
|
-
const button = f.createEl("button", {
|
|
298
|
-
text: "Cancel"
|
|
299
|
-
});
|
|
300
|
-
button.addEventListener("click", () => {
|
|
301
|
-
abortController.abort();
|
|
302
|
-
});
|
|
303
|
-
}),
|
|
304
|
-
0
|
|
305
|
-
);
|
|
306
|
-
}, fullOptions.noticeDelayInMilliseconds);
|
|
307
|
-
}
|
|
308
286
|
let activeLeafChangeEventRef = null;
|
|
309
287
|
if (fullOptions.shouldLockEditorWhileProcessing) {
|
|
310
288
|
for (const leaf of app.workspace.getLeavesOfType(import_implementations.ViewType.Markdown)) {
|
|
@@ -319,50 +297,52 @@ async function process(app, pathOrFile, newContentProvider, options = {}) {
|
|
|
319
297
|
});
|
|
320
298
|
}
|
|
321
299
|
try {
|
|
322
|
-
await (0,
|
|
323
|
-
abortSignal
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
if (oldContent === null) {
|
|
327
|
-
return handleMissingFile();
|
|
328
|
-
}
|
|
329
|
-
const newContent = await (0, import_ValueProvider.resolveValue)(newContentProvider, abortSignal, oldContent);
|
|
330
|
-
abortSignal.throwIfAborted();
|
|
331
|
-
if (newContent === null) {
|
|
332
|
-
return false;
|
|
333
|
-
}
|
|
334
|
-
let isSuccess = true;
|
|
335
|
-
const doesFileExist = await invokeFileActionSafe(app, pathOrFile, async (file) => {
|
|
300
|
+
await (0, import_AsyncWithNotice.retryWithTimeoutNotice)({
|
|
301
|
+
async operationFn(abortSignal) {
|
|
302
|
+
abortSignal.throwIfAborted();
|
|
303
|
+
const oldContent = await readSafe(app, pathOrFile);
|
|
336
304
|
abortSignal.throwIfAborted();
|
|
337
|
-
|
|
305
|
+
if (oldContent === null) {
|
|
306
|
+
return handleMissingFile();
|
|
307
|
+
}
|
|
308
|
+
const newContent = await (0, import_ValueProvider.resolveValue)(newContentProvider, abortSignal, oldContent);
|
|
309
|
+
abortSignal.throwIfAborted();
|
|
310
|
+
if (newContent === null) {
|
|
311
|
+
return false;
|
|
312
|
+
}
|
|
313
|
+
let isSuccess = true;
|
|
314
|
+
const doesFileExist = await invokeFileActionSafe(app, pathOrFile, async (file) => {
|
|
315
|
+
abortSignal.throwIfAborted();
|
|
316
|
+
await app.vault.process(file, (content) => {
|
|
317
|
+
abortSignal.throwIfAborted();
|
|
318
|
+
if (content !== oldContent) {
|
|
319
|
+
(0, import_Debug.getLibDebugger)("Vault:process")("Content has changed since it was read. Retrying...", {
|
|
320
|
+
actualContent: content,
|
|
321
|
+
expectedContent: oldContent,
|
|
322
|
+
path: file.path
|
|
323
|
+
});
|
|
324
|
+
isSuccess = false;
|
|
325
|
+
return content;
|
|
326
|
+
}
|
|
327
|
+
return newContent;
|
|
328
|
+
});
|
|
338
329
|
abortSignal.throwIfAborted();
|
|
339
|
-
if (content !== oldContent) {
|
|
340
|
-
(0, import_Debug.getLibDebugger)("Vault:process")("Content has changed since it was read. Retrying...", {
|
|
341
|
-
actualContent: content,
|
|
342
|
-
expectedContent: oldContent,
|
|
343
|
-
path: file.path
|
|
344
|
-
});
|
|
345
|
-
isSuccess = false;
|
|
346
|
-
return content;
|
|
347
|
-
}
|
|
348
|
-
return newContent;
|
|
349
330
|
});
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
if (!doesFileExist) {
|
|
353
|
-
return handleMissingFile();
|
|
354
|
-
}
|
|
355
|
-
return isSuccess;
|
|
356
|
-
function handleMissingFile() {
|
|
357
|
-
if (fullOptions.shouldFailOnMissingFile) {
|
|
358
|
-
throw new Error(`File '${path}' not found`);
|
|
331
|
+
if (!doesFileExist) {
|
|
332
|
+
return handleMissingFile();
|
|
359
333
|
}
|
|
360
|
-
return
|
|
361
|
-
|
|
362
|
-
|
|
334
|
+
return isSuccess;
|
|
335
|
+
function handleMissingFile() {
|
|
336
|
+
if (fullOptions.shouldFailOnMissingFile) {
|
|
337
|
+
throw new Error(`File '${path}' not found`);
|
|
338
|
+
}
|
|
339
|
+
return true;
|
|
340
|
+
}
|
|
341
|
+
},
|
|
342
|
+
operationName: (0, import_i18n.t)(($) => $.obsidianDevUtils.vault.processFile, { filePath: path }),
|
|
343
|
+
retryOptions: fullOptions
|
|
344
|
+
});
|
|
363
345
|
} finally {
|
|
364
|
-
isProcessing = false;
|
|
365
|
-
notice?.hide();
|
|
366
346
|
activeLeafChangeEventRef?.e.offref(activeLeafChangeEventRef);
|
|
367
347
|
for (const leaf of app.workspace.getLeavesOfType(import_implementations.ViewType.Markdown)) {
|
|
368
348
|
if (leaf.view instanceof import_obsidian.MarkdownView && leaf.view.file?.path === path) {
|
|
@@ -445,4 +425,4 @@ async function invokeFileActionSafe(app, pathOrFile, fileAction) {
|
|
|
445
425
|
renameSafe,
|
|
446
426
|
saveNote
|
|
447
427
|
});
|
|
448
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/Vault.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module provides utility functions for working with the Obsidian Vault.\n */\n\nimport type {\n  App,\n  EventRef,\n  ListedFiles,\n  TFile,\n  TFolder\n} from 'obsidian';\n\nimport {\n  MarkdownView,\n  Notice\n} from 'obsidian';\nimport {\n  parentFolderPath,\n  ViewType\n} from 'obsidian-typings/implementations';\n\nimport type { RetryOptions } from '../Async.ts';\nimport type { ValueProvider } from '../ValueProvider.ts';\nimport type {\n  PathOrFile,\n  PathOrFolder\n} from './FileSystem.ts';\n\nimport { abortSignalAny } from '../AbortController.ts';\nimport { retryWithTimeout } from '../Async.ts';\nimport { getLibDebugger } from '../Debug.ts';\nimport { noopAsync } from '../Function.ts';\nimport {\n  basename,\n  dirname,\n  extname,\n  join\n} from '../Path.ts';\nimport { resolveValue } from '../ValueProvider.ts';\nimport {\n  lockEditor,\n  unlockEditor\n} from './Editor.ts';\nimport {\n  getFile,\n  getFileOrNull,\n  getFolder,\n  getFolderOrNull,\n  getPath,\n  isFile,\n  isMarkdownFile,\n  isNote\n} from './FileSystem.ts';\n\n/**\n * Options for {@link process}.\n */\nexport interface ProcessOptions extends RetryOptions {\n  /**\n   * The delay in milliseconds before showing the process notice. Applicable only if {@link shouldShowNoticeWhileProcessing} is `true`. Default is `200`.\n   */\n  noticeDelayInMilliseconds?: number;\n\n  /**\n   * Whether to fail if the file is missing or deleted. Default is `true`.\n   */\n  shouldFailOnMissingFile?: boolean;\n\n  /**\n   * Whether to lock the editor while processing the file. Applicable only for markdown files. Default is `true`.\n   */\n  shouldLockEditorWhileProcessing?: boolean;\n\n  /**\n   * Whether to show a notice while processing the file. Default is `true`.\n   */\n  shouldShowNoticeWhileProcessing?: boolean;\n}\n\n/**\n * Copies a file safely in the vault.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to copy.\n * @param newPath - The new path to copy the file to.\n * @returns A {@link Promise} that resolves to the new path of the copied file.\n */\nexport async function copySafe(app: App, oldPathOrFile: PathOrFile, newPath: string): Promise<string> {\n  const file = getFile(app, oldPathOrFile);\n\n  const newFolderPath = parentFolderPath(newPath);\n  await createFolderSafe(app, newFolderPath);\n\n  const newAvailablePath = getAvailablePath(app, newPath);\n\n  try {\n    await app.vault.copy(file, newAvailablePath);\n  } catch (e) {\n    if (!await app.vault.exists(newAvailablePath)) {\n      throw e;\n    }\n  }\n\n  return newAvailablePath;\n}\n\n/**\n * Creates a folder safely in the specified path.\n *\n * @param app - The application instance.\n * @param path - The path of the folder to create.\n * @returns A {@link Promise} that resolves to a boolean indicating whether the folder was created.\n * @throws If an error occurs while creating the folder and it still doesn't exist.\n */\nexport async function createFolderSafe(app: App, path: string): Promise<boolean> {\n  if (await app.vault.adapter.exists(path)) {\n    return false;\n  }\n\n  try {\n    await app.vault.createFolder(path);\n    return true;\n  } catch (e) {\n    if (!await app.vault.exists(path)) {\n      throw e;\n    }\n    return true;\n  }\n}\n\n/**\n * Creates a temporary file in the vault with parent folders if needed.\n *\n * @param app - The application instance.\n * @param path - The path of the file to create.\n * @returns A {@link Promise} that resolves to a function that can be called to delete the temporary file and all its created parents.\n */\nexport async function createTempFile(app: App, path: string): Promise<() => Promise<void>> {\n  let file = getFileOrNull(app, path);\n  if (file) {\n    return noopAsync;\n  }\n\n  const folderCleanup = await createTempFolder(app, parentFolderPath(path));\n\n  try {\n    await app.vault.create(path, '');\n  } catch (e) {\n    if (!await app.vault.exists(path)) {\n      throw e;\n    }\n  }\n\n  return async () => {\n    file = getFile(app, path);\n    if (!file.deleted) {\n      await app.fileManager.trashFile(file);\n    }\n    await folderCleanup();\n  };\n}\n\n/**\n * Creates a temporary folder in the vault with parent folders if needed.\n *\n * @param app - The application instance.\n * @param path - The path of the folder to create.\n * @returns A {@link Promise} that resolves to a function that can be called to delete the temporary folder and all its created parents.\n */\nexport async function createTempFolder(app: App, path: string): Promise<() => Promise<void>> {\n  let folder = getFolderOrNull(app, path);\n  if (folder) {\n    return noopAsync;\n  }\n\n  const folderPath = parentFolderPath(path);\n  await createTempFolder(app, folderPath);\n\n  const folderCleanup = await createTempFolder(app, parentFolderPath(path));\n\n  await createFolderSafe(app, path);\n\n  return async () => {\n    folder = getFolder(app, path);\n    if (!folder.deleted) {\n      await app.fileManager.trashFile(folder);\n    }\n    await folderCleanup();\n  };\n}\n\n/**\n * Gets an available path for a file in the vault.\n *\n * @param app - The application instance.\n * @param path - The path of the file to get an available path for.\n * @returns The available path for the file.\n */\nexport function getAvailablePath(app: App, path: string): string {\n  const ext = extname(path);\n  return app.vault.getAvailablePath(join(dirname(path), basename(path, ext)), ext.slice(1));\n}\n\n/**\n * Retrieves an array of Markdown files from the app's vault and sorts them alphabetically by their file path.\n *\n * @param app - The Obsidian app instance.\n * @returns An array of Markdown files sorted by file path.\n */\nexport function getMarkdownFilesSorted(app: App): TFile[] {\n  return app.vault.getMarkdownFiles().sort((a, b) => a.path.localeCompare(b.path));\n}\n\n/**\n * Retrieves an array of all note files from the app's vault and sorts them alphabetically by their file path.\n *\n * @param app - The Obsidian app instance.\n * @returns An array of all note files in the vault sorted by file path.\n */\nexport function getNoteFilesSorted(app: App): TFile[] {\n  return app.vault.getAllLoadedFiles().filter((file) => isFile(file) && isNote(app, file)).sort((a, b) => a.path.localeCompare(b.path)) as TFile[];\n}\n\n/**\n * Gets a safe rename path for a file.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to rename.\n * @param newPath - The new path to rename the file to.\n * @returns The safe rename path for the file.\n */\nexport function getSafeRenamePath(app: App, oldPathOrFile: PathOrFile, newPath: string): string {\n  const oldPath = getPath(app, oldPathOrFile);\n\n  if (app.vault.adapter.insensitive) {\n    let folderPath = dirname(newPath);\n    let nonExistingPath = basename(newPath);\n    let folder: null | TFolder;\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- There is no elegant way to perform infinite loops.\n    while (true) {\n      folder = getFolderOrNull(app, folderPath, true);\n      if (folder) {\n        break;\n      }\n      nonExistingPath = join(basename(folderPath), nonExistingPath);\n      folderPath = dirname(folderPath);\n    }\n    newPath = join(folder.getParentPrefix(), nonExistingPath);\n  }\n\n  if (oldPath.toLowerCase() === newPath.toLowerCase()) {\n    return newPath;\n  }\n\n  return getAvailablePath(app, newPath);\n}\n\n/**\n * Invokes a function with the file system lock.\n *\n * @param app - The application instance.\n * @param pathOrFile - The path or file to execute the function with the file system lock of.\n * @param fn - The function to execute.\n */\nexport async function invokeWithFileSystemLock(app: App, pathOrFile: PathOrFile, fn: (content: string) => void): Promise<void> {\n  const file = getFile(app, pathOrFile);\n  await app.vault.process(file, (content) => {\n    fn(content);\n    return content;\n  });\n}\n\n/**\n * Checks if a folder is empty.\n *\n * @param app - The application instance.\n * @param pathOrFolder - The path or folder to check.\n * @returns A {@link Promise} that resolves to a boolean indicating whether the folder is empty.\n */\nexport async function isEmptyFolder(app: App, pathOrFolder: PathOrFolder): Promise<boolean> {\n  const listedFiles = await listSafe(app, getPath(app, pathOrFolder));\n  return listedFiles.files.length === 0 && listedFiles.folders.length === 0;\n}\n\n/**\n * Safely lists the files and folders at the specified path in the vault.\n *\n * @param app - The Obsidian application instance.\n * @param pathOrFolder - The path or folder to list.\n * @returns A {@link Promise} that resolves to a {@link ListedFiles} object containing the listed files and folders.\n */\nexport async function listSafe(app: App, pathOrFolder: PathOrFolder): Promise<ListedFiles> {\n  const path = getPath(app, pathOrFolder);\n  const EMPTY = { files: [], folders: [] };\n\n  if ((await app.vault.adapter.stat(path))?.type !== 'folder') {\n    return EMPTY;\n  }\n\n  try {\n    return await app.vault.adapter.list(path);\n  } catch (e) {\n    if (await app.vault.exists(path)) {\n      throw e;\n    }\n    return EMPTY;\n  }\n}\n\n/**\n * Processes a file with retry logic, updating its content based on a provided value or function.\n *\n * @param app - The application instance, typically used for accessing the vault.\n * @param pathOrFile - The path or file to be processed. It can be a string representing the path or a file object.\n * @param newContentProvider - A value provider that returns the new content based on the old content of the file.\n * It can be a string or a function that takes the old content as an argument and returns the new content.\n * If function is provided, it should return `null` if the process should be retried.\n * @param options - Optional options for processing/retrying the operation.\n *\n * @returns A {@link Promise} that resolves once the process is complete.\n *\n * @throws Will throw an error if the process fails after the specified number of retries or timeout.\n */\nexport async function process(\n  app: App,\n  pathOrFile: PathOrFile,\n  newContentProvider: ValueProvider<null | string, [string]>,\n  options: ProcessOptions = {}\n): Promise<void> {\n  const DEFAULT_RETRY_OPTIONS = {\n    // eslint-disable-next-line no-magic-numbers -- Default values.\n    noticeDelayInMilliseconds: 200,\n    shouldFailOnMissingFile: true,\n    shouldLockEditorWhileProcessing: true,\n    shouldShowNoticeWhileProcessing: true\n  };\n  const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...options };\n  const abortController = new AbortController();\n  fullOptions.abortSignal = abortSignalAny(fullOptions.abortSignal, abortController.signal);\n  let isProcessing = true;\n  let notice: Notice | null = null;\n  const path = getPath(app, pathOrFile);\n\n  if (fullOptions.shouldShowNoticeWhileProcessing) {\n    window.setTimeout(() => {\n      if (!isProcessing) {\n        return;\n      }\n      notice = new Notice(\n        createFragment((f) => {\n          f.appendText(`Processing file ${path}...`);\n          f.createEl('br');\n          const button = f.createEl('button', {\n            text: 'Cancel'\n          });\n          button.addEventListener('click', () => {\n            abortController.abort();\n          });\n        }),\n        0\n      );\n    }, fullOptions.noticeDelayInMilliseconds);\n  }\n\n  let activeLeafChangeEventRef: EventRef | null = null;\n\n  if (fullOptions.shouldLockEditorWhileProcessing) {\n    for (const leaf of app.workspace.getLeavesOfType(ViewType.Markdown)) {\n      if (leaf.view instanceof MarkdownView && leaf.view.file?.path === path) {\n        lockEditor(leaf.view.editor);\n      }\n    }\n\n    activeLeafChangeEventRef = app.workspace.on('active-leaf-change', (leaf) => {\n      if (leaf?.view instanceof MarkdownView && leaf.view.file?.path === path) {\n        lockEditor(leaf.view.editor);\n      }\n    });\n  }\n\n  try {\n    await retryWithTimeout(async (abortSignal) => {\n      abortSignal.throwIfAborted();\n\n      const oldContent = await readSafe(app, pathOrFile);\n      abortSignal.throwIfAborted();\n\n      if (oldContent === null) {\n        return handleMissingFile();\n      }\n\n      const newContent = await resolveValue(newContentProvider, abortSignal, oldContent);\n      abortSignal.throwIfAborted();\n\n      if (newContent === null) {\n        return false;\n      }\n\n      let isSuccess = true;\n      const doesFileExist = await invokeFileActionSafe(app, pathOrFile, async (file) => {\n        abortSignal.throwIfAborted();\n        await app.vault.process(file, (content) => {\n          abortSignal.throwIfAborted();\n          if (content !== oldContent) {\n            getLibDebugger('Vault:process')('Content has changed since it was read. Retrying...', {\n              actualContent: content,\n              expectedContent: oldContent,\n              path: file.path\n            });\n            isSuccess = false;\n            return content;\n          }\n\n          return newContent;\n        });\n\n        abortSignal.throwIfAborted();\n      });\n\n      if (!doesFileExist) {\n        return handleMissingFile();\n      }\n\n      return isSuccess;\n\n      function handleMissingFile(): boolean {\n        if (fullOptions.shouldFailOnMissingFile) {\n          throw new Error(`File '${path}' not found`);\n        }\n        return true;\n      }\n    }, fullOptions);\n  } finally {\n    isProcessing = false;\n    (notice as Notice | null)?.hide();\n    activeLeafChangeEventRef?.e.offref(activeLeafChangeEventRef);\n    for (const leaf of app.workspace.getLeavesOfType(ViewType.Markdown)) {\n      if (leaf.view instanceof MarkdownView && leaf.view.file?.path === path) {\n        unlockEditor(leaf.view.editor);\n      }\n    }\n  }\n}\n\n/**\n * Reads the content of a file safely from the vault.\n *\n * It covers the case when the file was removed during the reading.\n *\n * @param app - The application instance.\n * @param pathOrFile - The path or file to read.\n * @returns A {@link Promise} that resolves to the content of the file or `null` if the file is missing or deleted.\n */\nexport async function readSafe(app: App, pathOrFile: PathOrFile): Promise<null | string> {\n  let content: null | string = null;\n  await invokeFileActionSafe(app, pathOrFile, async (file) => {\n    await saveNote(app, file);\n    content = await app.vault.read(file);\n  });\n  return content;\n}\n\n/**\n * Renames a file safely in the vault.\n * If the new path already exists, the file will be renamed to an available path.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to rename.\n * @param newPath - The new path to rename the file to.\n * @returns A {@link Promise} that resolves to the new path of the file.\n */\nexport async function renameSafe(app: App, oldPathOrFile: PathOrFile, newPath: string): Promise<string> {\n  const oldFile = getFile(app, oldPathOrFile, false, true);\n\n  const newAvailablePath = getSafeRenamePath(app, oldPathOrFile, newPath);\n\n  if (oldFile.path.toLowerCase() === newAvailablePath.toLowerCase()) {\n    if (oldFile.path !== newPath) {\n      await app.vault.rename(oldFile, newAvailablePath);\n    }\n    return newAvailablePath;\n  }\n\n  const newFolderPath = parentFolderPath(newAvailablePath);\n  await createFolderSafe(app, newFolderPath);\n\n  try {\n    await app.vault.rename(oldFile, newAvailablePath);\n  } catch (e) {\n    if (!await app.vault.exists(newAvailablePath) || await app.vault.exists(oldFile.path)) {\n      throw e;\n    }\n  }\n\n  return newAvailablePath;\n}\n\n/**\n * Saves the specified note in the Obsidian app.\n *\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The note to be saved.\n * @returns A {@link Promise} that resolves when the note is saved.\n */\nexport async function saveNote(app: App, pathOrFile: PathOrFile): Promise<void> {\n  if (!isMarkdownFile(app, pathOrFile)) {\n    return;\n  }\n\n  const path = getPath(app, pathOrFile);\n\n  for (const leaf of app.workspace.getLeavesOfType(ViewType.Markdown)) {\n    if (leaf.view instanceof MarkdownView && leaf.view.file?.path === path && leaf.view.dirty) {\n      await leaf.view.save();\n    }\n  }\n}\n\nasync function invokeFileActionSafe(app: App, pathOrFile: PathOrFile, fileAction: (file: TFile) => Promise<void>): Promise<boolean> {\n  const path = getPath(app, pathOrFile);\n  let file = getFileOrNull(app, path);\n  if (!file || file.deleted) {\n    return false;\n  }\n  try {\n    await fileAction(file);\n    return true;\n  } catch (e) {\n    file = getFileOrNull(app, path);\n    if (!file || file.deleted) {\n      return false;\n    }\n    throw e;\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,sBAGO;AACP,6BAGO;AASP,6BAA+B;AAC/B,mBAAiC;AACjC,mBAA+B;AAC/B,sBAA0B;AAC1B,kBAKO;AACP,2BAA6B;AAC7B,oBAGO;AACP,wBASO;AAmCP,eAAsB,SAAS,KAAU,eAA2B,SAAkC;AACpG,QAAM,WAAO,2BAAQ,KAAK,aAAa;AAEvC,QAAM,oBAAgB,yCAAiB,OAAO;AAC9C,QAAM,iBAAiB,KAAK,aAAa;AAEzC,QAAM,mBAAmB,iBAAiB,KAAK,OAAO;AAEtD,MAAI;AACF,UAAM,IAAI,MAAM,KAAK,MAAM,gBAAgB;AAAA,EAC7C,SAAS,GAAG;AACV,QAAI,CAAC,MAAM,IAAI,MAAM,OAAO,gBAAgB,GAAG;AAC7C,YAAM;AAAA,IACR;AAAA,EACF;AAEA,SAAO;AACT;AAUA,eAAsB,iBAAiB,KAAU,MAAgC;AAC/E,MAAI,MAAM,IAAI,MAAM,QAAQ,OAAO,IAAI,GAAG;AACxC,WAAO;AAAA,EACT;AAEA,MAAI;AACF,UAAM,IAAI,MAAM,aAAa,IAAI;AACjC,WAAO;AAAA,EACT,SAAS,GAAG;AACV,QAAI,CAAC,MAAM,IAAI,MAAM,OAAO,IAAI,GAAG;AACjC,YAAM;AAAA,IACR;AACA,WAAO;AAAA,EACT;AACF;AASA,eAAsB,eAAe,KAAU,MAA4C;AACzF,MAAI,WAAO,iCAAc,KAAK,IAAI;AAClC,MAAI,MAAM;AACR,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB,MAAM,iBAAiB,SAAK,yCAAiB,IAAI,CAAC;AAExE,MAAI;AACF,UAAM,IAAI,MAAM,OAAO,MAAM,EAAE;AAAA,EACjC,SAAS,GAAG;AACV,QAAI,CAAC,MAAM,IAAI,MAAM,OAAO,IAAI,GAAG;AACjC,YAAM;AAAA,IACR;AAAA,EACF;AAEA,SAAO,YAAY;AACjB,eAAO,2BAAQ,KAAK,IAAI;AACxB,QAAI,CAAC,KAAK,SAAS;AACjB,YAAM,IAAI,YAAY,UAAU,IAAI;AAAA,IACtC;AACA,UAAM,cAAc;AAAA,EACtB;AACF;AASA,eAAsB,iBAAiB,KAAU,MAA4C;AAC3F,MAAI,aAAS,mCAAgB,KAAK,IAAI;AACtC,MAAI,QAAQ;AACV,WAAO;AAAA,EACT;AAEA,QAAM,iBAAa,yCAAiB,IAAI;AACxC,QAAM,iBAAiB,KAAK,UAAU;AAEtC,QAAM,gBAAgB,MAAM,iBAAiB,SAAK,yCAAiB,IAAI,CAAC;AAExE,QAAM,iBAAiB,KAAK,IAAI;AAEhC,SAAO,YAAY;AACjB,iBAAS,6BAAU,KAAK,IAAI;AAC5B,QAAI,CAAC,OAAO,SAAS;AACnB,YAAM,IAAI,YAAY,UAAU,MAAM;AAAA,IACxC;AACA,UAAM,cAAc;AAAA,EACtB;AACF;AASO,SAAS,iBAAiB,KAAU,MAAsB;AAC/D,QAAM,UAAM,qBAAQ,IAAI;AACxB,SAAO,IAAI,MAAM,qBAAiB,sBAAK,qBAAQ,IAAI,OAAG,sBAAS,MAAM,GAAG,CAAC,GAAG,IAAI,MAAM,CAAC,CAAC;AAC1F;AAQO,SAAS,uBAAuB,KAAmB;AACxD,SAAO,IAAI,MAAM,iBAAiB,EAAE,KAAK,CAAC,GAAG,MAAM,EAAE,KAAK,cAAc,EAAE,IAAI,CAAC;AACjF;AAQO,SAAS,mBAAmB,KAAmB;AACpD,SAAO,IAAI,MAAM,kBAAkB,EAAE,OAAO,CAAC,aAAS,0BAAO,IAAI,SAAK,0BAAO,KAAK,IAAI,CAAC,EAAE,KAAK,CAAC,GAAG,MAAM,EAAE,KAAK,cAAc,EAAE,IAAI,CAAC;AACtI;AAUO,SAAS,kBAAkB,KAAU,eAA2B,SAAyB;AAC9F,QAAM,cAAU,2BAAQ,KAAK,aAAa;AAE1C,MAAI,IAAI,MAAM,QAAQ,aAAa;AACjC,QAAI,iBAAa,qBAAQ,OAAO;AAChC,QAAI,sBAAkB,sBAAS,OAAO;AACtC,QAAI;AAEJ,WAAO,MAAM;AACX,mBAAS,mCAAgB,KAAK,YAAY,IAAI;AAC9C,UAAI,QAAQ;AACV;AAAA,MACF;AACA,4BAAkB,sBAAK,sBAAS,UAAU,GAAG,eAAe;AAC5D,uBAAa,qBAAQ,UAAU;AAAA,IACjC;AACA,kBAAU,kBAAK,OAAO,gBAAgB,GAAG,eAAe;AAAA,EAC1D;AAEA,MAAI,QAAQ,YAAY,MAAM,QAAQ,YAAY,GAAG;AACnD,WAAO;AAAA,EACT;AAEA,SAAO,iBAAiB,KAAK,OAAO;AACtC;AASA,eAAsB,yBAAyB,KAAU,YAAwB,IAA8C;AAC7H,QAAM,WAAO,2BAAQ,KAAK,UAAU;AACpC,QAAM,IAAI,MAAM,QAAQ,MAAM,CAAC,YAAY;AACzC,OAAG,OAAO;AACV,WAAO;AAAA,EACT,CAAC;AACH;AASA,eAAsB,cAAc,KAAU,cAA8C;AAC1F,QAAM,cAAc,MAAM,SAAS,SAAK,2BAAQ,KAAK,YAAY,CAAC;AAClE,SAAO,YAAY,MAAM,WAAW,KAAK,YAAY,QAAQ,WAAW;AAC1E;AASA,eAAsB,SAAS,KAAU,cAAkD;AACzF,QAAM,WAAO,2BAAQ,KAAK,YAAY;AACtC,QAAM,QAAQ,EAAE,OAAO,CAAC,GAAG,SAAS,CAAC,EAAE;AAEvC,OAAK,MAAM,IAAI,MAAM,QAAQ,KAAK,IAAI,IAAI,SAAS,UAAU;AAC3D,WAAO;AAAA,EACT;AAEA,MAAI;AACF,WAAO,MAAM,IAAI,MAAM,QAAQ,KAAK,IAAI;AAAA,EAC1C,SAAS,GAAG;AACV,QAAI,MAAM,IAAI,MAAM,OAAO,IAAI,GAAG;AAChC,YAAM;AAAA,IACR;AACA,WAAO;AAAA,EACT;AACF;AAgBA,eAAsB,QACpB,KACA,YACA,oBACA,UAA0B,CAAC,GACZ;AACf,QAAM,wBAAwB;AAAA;AAAA,IAE5B,2BAA2B;AAAA,IAC3B,yBAAyB;AAAA,IACzB,iCAAiC;AAAA,IACjC,iCAAiC;AAAA,EACnC;AACA,QAAM,cAAc,EAAE,GAAG,uBAAuB,GAAG,QAAQ;AAC3D,QAAM,kBAAkB,IAAI,gBAAgB;AAC5C,cAAY,kBAAc,uCAAe,YAAY,aAAa,gBAAgB,MAAM;AACxF,MAAI,eAAe;AACnB,MAAI,SAAwB;AAC5B,QAAM,WAAO,2BAAQ,KAAK,UAAU;AAEpC,MAAI,YAAY,iCAAiC;AAC/C,WAAO,WAAW,MAAM;AACtB,UAAI,CAAC,cAAc;AACjB;AAAA,MACF;AACA,eAAS,IAAI;AAAA,QACX,eAAe,CAAC,MAAM;AACpB,YAAE,WAAW,mBAAmB,IAAI,KAAK;AACzC,YAAE,SAAS,IAAI;AACf,gBAAM,SAAS,EAAE,SAAS,UAAU;AAAA,YAClC,MAAM;AAAA,UACR,CAAC;AACD,iBAAO,iBAAiB,SAAS,MAAM;AACrC,4BAAgB,MAAM;AAAA,UACxB,CAAC;AAAA,QACH,CAAC;AAAA,QACD;AAAA,MACF;AAAA,IACF,GAAG,YAAY,yBAAyB;AAAA,EAC1C;AAEA,MAAI,2BAA4C;AAEhD,MAAI,YAAY,iCAAiC;AAC/C,eAAW,QAAQ,IAAI,UAAU,gBAAgB,gCAAS,QAAQ,GAAG;AACnE,UAAI,KAAK,gBAAgB,gCAAgB,KAAK,KAAK,MAAM,SAAS,MAAM;AACtE,sCAAW,KAAK,KAAK,MAAM;AAAA,MAC7B;AAAA,IACF;AAEA,+BAA2B,IAAI,UAAU,GAAG,sBAAsB,CAAC,SAAS;AAC1E,UAAI,MAAM,gBAAgB,gCAAgB,KAAK,KAAK,MAAM,SAAS,MAAM;AACvE,sCAAW,KAAK,KAAK,MAAM;AAAA,MAC7B;AAAA,IACF,CAAC;AAAA,EACH;AAEA,MAAI;AACF,cAAM,+BAAiB,OAAO,gBAAgB;AAC5C,kBAAY,eAAe;AAE3B,YAAM,aAAa,MAAM,SAAS,KAAK,UAAU;AACjD,kBAAY,eAAe;AAE3B,UAAI,eAAe,MAAM;AACvB,eAAO,kBAAkB;AAAA,MAC3B;AAEA,YAAM,aAAa,UAAM,mCAAa,oBAAoB,aAAa,UAAU;AACjF,kBAAY,eAAe;AAE3B,UAAI,eAAe,MAAM;AACvB,eAAO;AAAA,MACT;AAEA,UAAI,YAAY;AAChB,YAAM,gBAAgB,MAAM,qBAAqB,KAAK,YAAY,OAAO,SAAS;AAChF,oBAAY,eAAe;AAC3B,cAAM,IAAI,MAAM,QAAQ,MAAM,CAAC,YAAY;AACzC,sBAAY,eAAe;AAC3B,cAAI,YAAY,YAAY;AAC1B,6CAAe,eAAe,EAAE,sDAAsD;AAAA,cACpF,eAAe;AAAA,cACf,iBAAiB;AAAA,cACjB,MAAM,KAAK;AAAA,YACb,CAAC;AACD,wBAAY;AACZ,mBAAO;AAAA,UACT;AAEA,iBAAO;AAAA,QACT,CAAC;AAED,oBAAY,eAAe;AAAA,MAC7B,CAAC;AAED,UAAI,CAAC,eAAe;AAClB,eAAO,kBAAkB;AAAA,MAC3B;AAEA,aAAO;AAEP,eAAS,oBAA6B;AACpC,YAAI,YAAY,yBAAyB;AACvC,gBAAM,IAAI,MAAM,SAAS,IAAI,aAAa;AAAA,QAC5C;AACA,eAAO;AAAA,MACT;AAAA,IACF,GAAG,WAAW;AAAA,EAChB,UAAE;AACA,mBAAe;AACf,IAAC,QAA0B,KAAK;AAChC,8BAA0B,EAAE,OAAO,wBAAwB;AAC3D,eAAW,QAAQ,IAAI,UAAU,gBAAgB,gCAAS,QAAQ,GAAG;AACnE,UAAI,KAAK,gBAAgB,gCAAgB,KAAK,KAAK,MAAM,SAAS,MAAM;AACtE,wCAAa,KAAK,KAAK,MAAM;AAAA,MAC/B;AAAA,IACF;AAAA,EACF;AACF;AAWA,eAAsB,SAAS,KAAU,YAAgD;AACvF,MAAI,UAAyB;AAC7B,QAAM,qBAAqB,KAAK,YAAY,OAAO,SAAS;AAC1D,UAAM,SAAS,KAAK,IAAI;AACxB,cAAU,MAAM,IAAI,MAAM,KAAK,IAAI;AAAA,EACrC,CAAC;AACD,SAAO;AACT;AAWA,eAAsB,WAAW,KAAU,eAA2B,SAAkC;AACtG,QAAM,cAAU,2BAAQ,KAAK,eAAe,OAAO,IAAI;AAEvD,QAAM,mBAAmB,kBAAkB,KAAK,eAAe,OAAO;AAEtE,MAAI,QAAQ,KAAK,YAAY,MAAM,iBAAiB,YAAY,GAAG;AACjE,QAAI,QAAQ,SAAS,SAAS;AAC5B,YAAM,IAAI,MAAM,OAAO,SAAS,gBAAgB;AAAA,IAClD;AACA,WAAO;AAAA,EACT;AAEA,QAAM,oBAAgB,yCAAiB,gBAAgB;AACvD,QAAM,iBAAiB,KAAK,aAAa;AAEzC,MAAI;AACF,UAAM,IAAI,MAAM,OAAO,SAAS,gBAAgB;AAAA,EAClD,SAAS,GAAG;AACV,QAAI,CAAC,MAAM,IAAI,MAAM,OAAO,gBAAgB,KAAK,MAAM,IAAI,MAAM,OAAO,QAAQ,IAAI,GAAG;AACrF,YAAM;AAAA,IACR;AAAA,EACF;AAEA,SAAO;AACT;AASA,eAAsB,SAAS,KAAU,YAAuC;AAC9E,MAAI,KAAC,kCAAe,KAAK,UAAU,GAAG;AACpC;AAAA,EACF;AAEA,QAAM,WAAO,2BAAQ,KAAK,UAAU;AAEpC,aAAW,QAAQ,IAAI,UAAU,gBAAgB,gCAAS,QAAQ,GAAG;AACnE,QAAI,KAAK,gBAAgB,gCAAgB,KAAK,KAAK,MAAM,SAAS,QAAQ,KAAK,KAAK,OAAO;AACzF,YAAM,KAAK,KAAK,KAAK;AAAA,IACvB;AAAA,EACF;AACF;AAEA,eAAe,qBAAqB,KAAU,YAAwB,YAA8D;AAClI,QAAM,WAAO,2BAAQ,KAAK,UAAU;AACpC,MAAI,WAAO,iCAAc,KAAK,IAAI;AAClC,MAAI,CAAC,QAAQ,KAAK,SAAS;AACzB,WAAO;AAAA,EACT;AACA,MAAI;AACF,UAAM,WAAW,IAAI;AACrB,WAAO;AAAA,EACT,SAAS,GAAG;AACV,eAAO,iCAAc,KAAK,IAAI;AAC9B,QAAI,CAAC,QAAQ,KAAK,SAAS;AACzB,aAAO;AAAA,IACT;AACA,UAAM;AAAA,EACR;AACF;",
  "names": []
}

|
|
428
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/Vault.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module provides utility functions for working with the Obsidian Vault.\n */\n\nimport type {\n  App,\n  EventRef,\n  ListedFiles,\n  TFile,\n  TFolder\n} from 'obsidian';\n\nimport { MarkdownView } from 'obsidian';\nimport {\n  parentFolderPath,\n  ViewType\n} from 'obsidian-typings/implementations';\n\nimport type { RetryOptions } from '../Async.ts';\nimport type { ValueProvider } from '../ValueProvider.ts';\nimport type {\n  PathOrFile,\n  PathOrFolder\n} from './FileSystem.ts';\n\nimport { abortSignalAny } from '../AbortController.ts';\nimport { getLibDebugger } from '../Debug.ts';\nimport { noopAsync } from '../Function.ts';\nimport {\n  basename,\n  dirname,\n  extname,\n  join\n} from '../Path.ts';\nimport { resolveValue } from '../ValueProvider.ts';\nimport { retryWithTimeoutNotice } from './AsyncWithNotice.ts';\nimport {\n  lockEditor,\n  unlockEditor\n} from './Editor.ts';\nimport {\n  getFile,\n  getFileOrNull,\n  getFolder,\n  getFolderOrNull,\n  getPath,\n  isFile,\n  isMarkdownFile,\n  isNote\n} from './FileSystem.ts';\nimport { t } from './i18n/i18n.ts';\n\n/**\n * Options for {@link process}.\n */\nexport interface ProcessOptions extends RetryOptions {\n  /**\n   * Whether to fail if the file is missing or deleted. Default is `true`.\n   */\n  shouldFailOnMissingFile?: boolean;\n\n  /**\n   * Whether to lock the editor while processing the file. Applicable only for markdown files. Default is `true`.\n   */\n  shouldLockEditorWhileProcessing?: boolean;\n}\n\n/**\n * Copies a file safely in the vault.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to copy.\n * @param newPath - The new path to copy the file to.\n * @returns A {@link Promise} that resolves to the new path of the copied file.\n */\nexport async function copySafe(app: App, oldPathOrFile: PathOrFile, newPath: string): Promise<string> {\n  const file = getFile(app, oldPathOrFile);\n\n  const newFolderPath = parentFolderPath(newPath);\n  await createFolderSafe(app, newFolderPath);\n\n  const newAvailablePath = getAvailablePath(app, newPath);\n\n  try {\n    await app.vault.copy(file, newAvailablePath);\n  } catch (e) {\n    if (!await app.vault.exists(newAvailablePath)) {\n      throw e;\n    }\n  }\n\n  return newAvailablePath;\n}\n\n/**\n * Creates a folder safely in the specified path.\n *\n * @param app - The application instance.\n * @param path - The path of the folder to create.\n * @returns A {@link Promise} that resolves to a boolean indicating whether the folder was created.\n * @throws If an error occurs while creating the folder and it still doesn't exist.\n */\nexport async function createFolderSafe(app: App, path: string): Promise<boolean> {\n  if (await app.vault.adapter.exists(path)) {\n    return false;\n  }\n\n  try {\n    await app.vault.createFolder(path);\n    return true;\n  } catch (e) {\n    if (!await app.vault.exists(path)) {\n      throw e;\n    }\n    return true;\n  }\n}\n\n/**\n * Creates a temporary file in the vault with parent folders if needed.\n *\n * @param app - The application instance.\n * @param path - The path of the file to create.\n * @returns A {@link Promise} that resolves to a function that can be called to delete the temporary file and all its created parents.\n */\nexport async function createTempFile(app: App, path: string): Promise<() => Promise<void>> {\n  let file = getFileOrNull(app, path);\n  if (file) {\n    return noopAsync;\n  }\n\n  const folderCleanup = await createTempFolder(app, parentFolderPath(path));\n\n  try {\n    await app.vault.create(path, '');\n  } catch (e) {\n    if (!await app.vault.exists(path)) {\n      throw e;\n    }\n  }\n\n  return async () => {\n    file = getFile(app, path);\n    if (!file.deleted) {\n      await app.fileManager.trashFile(file);\n    }\n    await folderCleanup();\n  };\n}\n\n/**\n * Creates a temporary folder in the vault with parent folders if needed.\n *\n * @param app - The application instance.\n * @param path - The path of the folder to create.\n * @returns A {@link Promise} that resolves to a function that can be called to delete the temporary folder and all its created parents.\n */\nexport async function createTempFolder(app: App, path: string): Promise<() => Promise<void>> {\n  let folder = getFolderOrNull(app, path);\n  if (folder) {\n    return noopAsync;\n  }\n\n  const folderPath = parentFolderPath(path);\n  await createTempFolder(app, folderPath);\n\n  const folderCleanup = await createTempFolder(app, parentFolderPath(path));\n\n  await createFolderSafe(app, path);\n\n  return async () => {\n    folder = getFolder(app, path);\n    if (!folder.deleted) {\n      await app.fileManager.trashFile(folder);\n    }\n    await folderCleanup();\n  };\n}\n\n/**\n * Gets an available path for a file in the vault.\n *\n * @param app - The application instance.\n * @param path - The path of the file to get an available path for.\n * @returns The available path for the file.\n */\nexport function getAvailablePath(app: App, path: string): string {\n  const ext = extname(path);\n  return app.vault.getAvailablePath(join(dirname(path), basename(path, ext)), ext.slice(1));\n}\n\n/**\n * Retrieves an array of Markdown files from the app's vault and sorts them alphabetically by their file path.\n *\n * @param app - The Obsidian app instance.\n * @returns An array of Markdown files sorted by file path.\n */\nexport function getMarkdownFilesSorted(app: App): TFile[] {\n  return app.vault.getMarkdownFiles().sort((a, b) => a.path.localeCompare(b.path));\n}\n\n/**\n * Retrieves an array of all note files from the app's vault and sorts them alphabetically by their file path.\n *\n * @param app - The Obsidian app instance.\n * @returns An array of all note files in the vault sorted by file path.\n */\nexport function getNoteFilesSorted(app: App): TFile[] {\n  return app.vault.getAllLoadedFiles().filter((file) => isFile(file) && isNote(app, file)).sort((a, b) => a.path.localeCompare(b.path)) as TFile[];\n}\n\n/**\n * Gets a safe rename path for a file.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to rename.\n * @param newPath - The new path to rename the file to.\n * @returns The safe rename path for the file.\n */\nexport function getSafeRenamePath(app: App, oldPathOrFile: PathOrFile, newPath: string): string {\n  const oldPath = getPath(app, oldPathOrFile);\n\n  if (app.vault.adapter.insensitive) {\n    let folderPath = dirname(newPath);\n    let nonExistingPath = basename(newPath);\n    let folder: null | TFolder;\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- There is no elegant way to perform infinite loops.\n    while (true) {\n      folder = getFolderOrNull(app, folderPath, true);\n      if (folder) {\n        break;\n      }\n      nonExistingPath = join(basename(folderPath), nonExistingPath);\n      folderPath = dirname(folderPath);\n    }\n    newPath = join(folder.getParentPrefix(), nonExistingPath);\n  }\n\n  if (oldPath.toLowerCase() === newPath.toLowerCase()) {\n    return newPath;\n  }\n\n  return getAvailablePath(app, newPath);\n}\n\n/**\n * Invokes a function with the file system lock.\n *\n * @param app - The application instance.\n * @param pathOrFile - The path or file to execute the function with the file system lock of.\n * @param fn - The function to execute.\n */\nexport async function invokeWithFileSystemLock(app: App, pathOrFile: PathOrFile, fn: (content: string) => void): Promise<void> {\n  const file = getFile(app, pathOrFile);\n  await app.vault.process(file, (content) => {\n    fn(content);\n    return content;\n  });\n}\n\n/**\n * Checks if a folder is empty.\n *\n * @param app - The application instance.\n * @param pathOrFolder - The path or folder to check.\n * @returns A {@link Promise} that resolves to a boolean indicating whether the folder is empty.\n */\nexport async function isEmptyFolder(app: App, pathOrFolder: PathOrFolder): Promise<boolean> {\n  const listedFiles = await listSafe(app, getPath(app, pathOrFolder));\n  return listedFiles.files.length === 0 && listedFiles.folders.length === 0;\n}\n\n/**\n * Safely lists the files and folders at the specified path in the vault.\n *\n * @param app - The Obsidian application instance.\n * @param pathOrFolder - The path or folder to list.\n * @returns A {@link Promise} that resolves to a {@link ListedFiles} object containing the listed files and folders.\n */\nexport async function listSafe(app: App, pathOrFolder: PathOrFolder): Promise<ListedFiles> {\n  const path = getPath(app, pathOrFolder);\n  const EMPTY = { files: [], folders: [] };\n\n  if ((await app.vault.adapter.stat(path))?.type !== 'folder') {\n    return EMPTY;\n  }\n\n  try {\n    return await app.vault.adapter.list(path);\n  } catch (e) {\n    if (await app.vault.exists(path)) {\n      throw e;\n    }\n    return EMPTY;\n  }\n}\n\n/**\n * Processes a file with retry logic, updating its content based on a provided value or function.\n *\n * @param app - The application instance, typically used for accessing the vault.\n * @param pathOrFile - The path or file to be processed. It can be a string representing the path or a file object.\n * @param newContentProvider - A value provider that returns the new content based on the old content of the file.\n * It can be a string or a function that takes the old content as an argument and returns the new content.\n * If function is provided, it should return `null` if the process should be retried.\n * @param options - Optional options for processing/retrying the operation.\n *\n * @returns A {@link Promise} that resolves once the process is complete.\n *\n * @throws Will throw an error if the process fails after the specified number of retries or timeout.\n */\nexport async function process(\n  app: App,\n  pathOrFile: PathOrFile,\n  newContentProvider: ValueProvider<null | string, [string]>,\n  options: ProcessOptions = {}\n): Promise<void> {\n  const DEFAULT_RETRY_OPTIONS = {\n    shouldFailOnMissingFile: true,\n    shouldLockEditorWhileProcessing: true,\n    // eslint-disable-next-line no-magic-numbers -- Default value.\n    timeoutInMilliseconds: 500\n  };\n  const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...options };\n  const abortController = new AbortController();\n  fullOptions.abortSignal = abortSignalAny(fullOptions.abortSignal, abortController.signal);\n  const path = getPath(app, pathOrFile);\n\n  let activeLeafChangeEventRef: EventRef | null = null;\n\n  if (fullOptions.shouldLockEditorWhileProcessing) {\n    for (const leaf of app.workspace.getLeavesOfType(ViewType.Markdown)) {\n      if (leaf.view instanceof MarkdownView && leaf.view.file?.path === path) {\n        lockEditor(leaf.view.editor);\n      }\n    }\n\n    activeLeafChangeEventRef = app.workspace.on('active-leaf-change', (leaf) => {\n      if (leaf?.view instanceof MarkdownView && leaf.view.file?.path === path) {\n        lockEditor(leaf.view.editor);\n      }\n    });\n  }\n\n  try {\n    await retryWithTimeoutNotice({\n      async operationFn(abortSignal) {\n        abortSignal.throwIfAborted();\n\n        const oldContent = await readSafe(app, pathOrFile);\n        abortSignal.throwIfAborted();\n\n        if (oldContent === null) {\n          return handleMissingFile();\n        }\n\n        const newContent = await resolveValue(newContentProvider, abortSignal, oldContent);\n        abortSignal.throwIfAborted();\n\n        if (newContent === null) {\n          return false;\n        }\n\n        let isSuccess = true;\n        const doesFileExist = await invokeFileActionSafe(app, pathOrFile, async (file) => {\n          abortSignal.throwIfAborted();\n          await app.vault.process(file, (content) => {\n            abortSignal.throwIfAborted();\n            if (content !== oldContent) {\n              getLibDebugger('Vault:process')('Content has changed since it was read. Retrying...', {\n                actualContent: content,\n                expectedContent: oldContent,\n                path: file.path\n              });\n              isSuccess = false;\n              return content;\n            }\n\n            return newContent;\n          });\n\n          abortSignal.throwIfAborted();\n        });\n\n        if (!doesFileExist) {\n          return handleMissingFile();\n        }\n\n        return isSuccess;\n\n        function handleMissingFile(): boolean {\n          if (fullOptions.shouldFailOnMissingFile) {\n            throw new Error(`File '${path}' not found`);\n          }\n          return true;\n        }\n      },\n      operationName: t(($) => $.obsidianDevUtils.vault.processFile, { filePath: path }),\n      retryOptions: fullOptions\n    });\n  } finally {\n    activeLeafChangeEventRef?.e.offref(activeLeafChangeEventRef);\n    for (const leaf of app.workspace.getLeavesOfType(ViewType.Markdown)) {\n      if (leaf.view instanceof MarkdownView && leaf.view.file?.path === path) {\n        unlockEditor(leaf.view.editor);\n      }\n    }\n  }\n}\n\n/**\n * Reads the content of a file safely from the vault.\n *\n * It covers the case when the file was removed during the reading.\n *\n * @param app - The application instance.\n * @param pathOrFile - The path or file to read.\n * @returns A {@link Promise} that resolves to the content of the file or `null` if the file is missing or deleted.\n */\nexport async function readSafe(app: App, pathOrFile: PathOrFile): Promise<null | string> {\n  let content: null | string = null;\n  await invokeFileActionSafe(app, pathOrFile, async (file) => {\n    await saveNote(app, file);\n    content = await app.vault.read(file);\n  });\n  return content;\n}\n\n/**\n * Renames a file safely in the vault.\n * If the new path already exists, the file will be renamed to an available path.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to rename.\n * @param newPath - The new path to rename the file to.\n * @returns A {@link Promise} that resolves to the new path of the file.\n */\nexport async function renameSafe(app: App, oldPathOrFile: PathOrFile, newPath: string): Promise<string> {\n  const oldFile = getFile(app, oldPathOrFile, false, true);\n\n  const newAvailablePath = getSafeRenamePath(app, oldPathOrFile, newPath);\n\n  if (oldFile.path.toLowerCase() === newAvailablePath.toLowerCase()) {\n    if (oldFile.path !== newPath) {\n      await app.vault.rename(oldFile, newAvailablePath);\n    }\n    return newAvailablePath;\n  }\n\n  const newFolderPath = parentFolderPath(newAvailablePath);\n  await createFolderSafe(app, newFolderPath);\n\n  try {\n    await app.vault.rename(oldFile, newAvailablePath);\n  } catch (e) {\n    if (!await app.vault.exists(newAvailablePath) || await app.vault.exists(oldFile.path)) {\n      throw e;\n    }\n  }\n\n  return newAvailablePath;\n}\n\n/**\n * Saves the specified note in the Obsidian app.\n *\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The note to be saved.\n * @returns A {@link Promise} that resolves when the note is saved.\n */\nexport async function saveNote(app: App, pathOrFile: PathOrFile): Promise<void> {\n  if (!isMarkdownFile(app, pathOrFile)) {\n    return;\n  }\n\n  const path = getPath(app, pathOrFile);\n\n  for (const leaf of app.workspace.getLeavesOfType(ViewType.Markdown)) {\n    if (leaf.view instanceof MarkdownView && leaf.view.file?.path === path && leaf.view.dirty) {\n      await leaf.view.save();\n    }\n  }\n}\n\nasync function invokeFileActionSafe(app: App, pathOrFile: PathOrFile, fileAction: (file: TFile) => Promise<void>): Promise<boolean> {\n  const path = getPath(app, pathOrFile);\n  let file = getFileOrNull(app, path);\n  if (!file || file.deleted) {\n    return false;\n  }\n  try {\n    await fileAction(file);\n    return true;\n  } catch (e) {\n    file = getFileOrNull(app, path);\n    if (!file || file.deleted) {\n      return false;\n    }\n    throw e;\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -11,10 +11,6 @@ import type { PathOrFile, PathOrFolder } from './FileSystem.cjs';
|
|
|
11
11
|
* Options for {@link process}.
|
|
12
12
|
*/
|
|
13
13
|
export interface ProcessOptions extends RetryOptions {
|
|
14
|
-
/**
|
|
15
|
-
* The delay in milliseconds before showing the process notice. Applicable only if {@link shouldShowNoticeWhileProcessing} is `true`. Default is `200`.
|
|
16
|
-
*/
|
|
17
|
-
noticeDelayInMilliseconds?: number;
|
|
18
14
|
/**
|
|
19
15
|
* Whether to fail if the file is missing or deleted. Default is `true`.
|
|
20
16
|
*/
|
|
@@ -23,10 +19,6 @@ export interface ProcessOptions extends RetryOptions {
|
|
|
23
19
|
* Whether to lock the editor while processing the file. Applicable only for markdown files. Default is `true`.
|
|
24
20
|
*/
|
|
25
21
|
shouldLockEditorWhileProcessing?: boolean;
|
|
26
|
-
/**
|
|
27
|
-
* Whether to show a notice while processing the file. Default is `true`.
|
|
28
|
-
*/
|
|
29
|
-
shouldShowNoticeWhileProcessing?: boolean;
|
|
30
22
|
}
|
|
31
23
|
/**
|
|
32
24
|
* Copies a file safely in the vault.
|
|
@@ -126,17 +126,43 @@ __export(en_exports, {
|
|
|
126
126
|
module.exports = __toCommonJS(en_exports);
|
|
127
127
|
const en = {
|
|
128
128
|
obsidianDevUtils: {
|
|
129
|
+
asyncWithNotice: {
|
|
130
|
+
milliseconds: "milliseconds...",
|
|
131
|
+
operation: "Operation:",
|
|
132
|
+
runningFor: "Running for",
|
|
133
|
+
terminateOperation: "You can terminate the operation by clicking the button below, but be aware it might leave the vault in an inconsistent state.",
|
|
134
|
+
timedOut: "The operation timed out after {{duration}} milliseconds."
|
|
135
|
+
},
|
|
129
136
|
buttons: {
|
|
130
137
|
cancel: "Cancel",
|
|
131
138
|
ok: "OK"
|
|
132
139
|
},
|
|
140
|
+
callout: {
|
|
141
|
+
loadContent: "Load content for callout"
|
|
142
|
+
},
|
|
133
143
|
dataview: {
|
|
134
144
|
itemsPerPage: "Items per page:",
|
|
135
|
-
jumpToPage: "Jump to page:"
|
|
145
|
+
jumpToPage: "Jump to page:",
|
|
146
|
+
pageHeader: "Page {{pageNumber}} of {{totalPages}}, Total items: {{totalItems}}"
|
|
147
|
+
},
|
|
148
|
+
metadataCache: {
|
|
149
|
+
getBacklinksForFilePath: "Get backlinks for {{filePath}}"
|
|
136
150
|
},
|
|
137
151
|
notices: {
|
|
138
152
|
attachmentIsStillUsed: "Attachment {{attachmentPath}} is still used by other notes. It will not be deleted.",
|
|
139
153
|
unhandledError: "An unhandled error occurred. Please check the console for more information."
|
|
154
|
+
},
|
|
155
|
+
queue: {
|
|
156
|
+
flushQueue: "Flush queue"
|
|
157
|
+
},
|
|
158
|
+
renameDeleteHandler: {
|
|
159
|
+
handleDelete: "Handle delete: {{filePath}}",
|
|
160
|
+
handleOrphanedRenames: "Handle orphaned renames",
|
|
161
|
+
handleRename: "Handle rename: {{oldPath}} -> {{newPath}}",
|
|
162
|
+
updatedLinks: "Updated {{linksCount}} links in {{filesCount}} files."
|
|
163
|
+
},
|
|
164
|
+
vault: {
|
|
165
|
+
processFile: "Process file {{filePath}}"
|
|
140
166
|
}
|
|
141
167
|
}
|
|
142
168
|
};
|
|
@@ -144,4 +170,4 @@ const en = {
|
|
|
144
170
|
0 && (module.exports = {
|
|
145
171
|
en
|
|
146
172
|
});
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL2kxOG4vbG9jYWxlcy9lbi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBUaGlzIGZpbGUgZGVmaW5lcyB0aGUgRW5nbGlzaCB0cmFuc2xhdGlvbnMgZm9yIHRoZSBgaTE4bmAgbW9kdWxlLlxuICovXG5cbi8qKlxuICogVGhlIEVuZ2xpc2ggdHJhbnNsYXRpb25zLlxuICovXG5leHBvcnQgY29uc3QgZW4gPSB7XG4gIG9ic2lkaWFuRGV2VXRpbHM6IHtcbiAgICBhc3luY1dpdGhOb3RpY2U6IHtcbiAgICAgIG1pbGxpc2Vjb25kczogJ21pbGxpc2Vjb25kcy4uLicsXG4gICAgICBvcGVyYXRpb246ICdPcGVyYXRpb246JyxcbiAgICAgIHJ1bm5pbmdGb3I6ICdSdW5uaW5nIGZvcicsXG4gICAgICB0ZXJtaW5hdGVPcGVyYXRpb246ICdZb3UgY2FuIHRlcm1pbmF0ZSB0aGUgb3BlcmF0aW9uIGJ5IGNsaWNraW5nIHRoZSBidXR0b24gYmVsb3csIGJ1dCBiZSBhd2FyZSBpdCBtaWdodCBsZWF2ZSB0aGUgdmF1bHQgaW4gYW4gaW5jb25zaXN0ZW50IHN0YXRlLicsXG4gICAgICB0aW1lZE91dDogJ1RoZSBvcGVyYXRpb24gdGltZWQgb3V0IGFmdGVyIHt7ZHVyYXRpb259fSBtaWxsaXNlY29uZHMuJ1xuICAgIH0sXG4gICAgYnV0dG9uczoge1xuICAgICAgY2FuY2VsOiAnQ2FuY2VsJyxcbiAgICAgIG9rOiAnT0snXG4gICAgfSxcbiAgICBjYWxsb3V0OiB7XG4gICAgICBsb2FkQ29udGVudDogJ0xvYWQgY29udGVudCBmb3IgY2FsbG91dCdcbiAgICB9LFxuICAgIGRhdGF2aWV3OiB7XG4gICAgICBpdGVtc1BlclBhZ2U6ICdJdGVtcyBwZXIgcGFnZTonLFxuICAgICAganVtcFRvUGFnZTogJ0p1bXAgdG8gcGFnZTonLFxuICAgICAgcGFnZUhlYWRlcjogJ1BhZ2Uge3twYWdlTnVtYmVyfX0gb2Yge3t0b3RhbFBhZ2VzfX0sIFRvdGFsIGl0ZW1zOiB7e3RvdGFsSXRlbXN9fSdcbiAgICB9LFxuICAgIG1ldGFkYXRhQ2FjaGU6IHtcbiAgICAgIGdldEJhY2tsaW5rc0ZvckZpbGVQYXRoOiAnR2V0IGJhY2tsaW5rcyBmb3Ige3tmaWxlUGF0aH19J1xuICAgIH0sXG4gICAgbm90aWNlczoge1xuICAgICAgYXR0YWNobWVudElzU3RpbGxVc2VkOiAnQXR0YWNobWVudCB7e2F0dGFjaG1lbnRQYXRofX0gaXMgc3RpbGwgdXNlZCBieSBvdGhlciBub3Rlcy4gSXQgd2lsbCBub3QgYmUgZGVsZXRlZC4nLFxuICAgICAgdW5oYW5kbGVkRXJyb3I6ICdBbiB1bmhhbmRsZWQgZXJyb3Igb2NjdXJyZWQuIFBsZWFzZSBjaGVjayB0aGUgY29uc29sZSBmb3IgbW9yZSBpbmZvcm1hdGlvbi4nXG4gICAgfSxcbiAgICBxdWV1ZToge1xuICAgICAgZmx1c2hRdWV1ZTogJ0ZsdXNoIHF1ZXVlJ1xuICAgIH0sXG4gICAgcmVuYW1lRGVsZXRlSGFuZGxlcjoge1xuICAgICAgaGFuZGxlRGVsZXRlOiAnSGFuZGxlIGRlbGV0ZToge3tmaWxlUGF0aH19JyxcbiAgICAgIGhhbmRsZU9ycGhhbmVkUmVuYW1lczogJ0hhbmRsZSBvcnBoYW5lZCByZW5hbWVzJyxcbiAgICAgIGhhbmRsZVJlbmFtZTogJ0hhbmRsZSByZW5hbWU6IHt7b2xkUGF0aH19IC0+IHt7bmV3UGF0aH19JyxcbiAgICAgIHVwZGF0ZWRMaW5rczogJ1VwZGF0ZWQge3tsaW5rc0NvdW50fX0gbGlua3MgaW4ge3tmaWxlc0NvdW50fX0gZmlsZXMuJ1xuICAgIH0sXG4gICAgdmF1bHQ6IHtcbiAgICAgIHByb2Nlc3NGaWxlOiAnUHJvY2VzcyBmaWxlIHt7ZmlsZVBhdGh9fSdcbiAgICB9XG4gIH1cbn0gYXMgY29uc3Q7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVNPLE1BQU0sS0FBSztBQUFBLEVBQ2hCLGtCQUFrQjtBQUFBLElBQ2hCLGlCQUFpQjtBQUFBLE1BQ2YsY0FBYztBQUFBLE1BQ2QsV0FBVztBQUFBLE1BQ1gsWUFBWTtBQUFBLE1BQ1osb0JBQW9CO0FBQUEsTUFDcEIsVUFBVTtBQUFBLElBQ1o7QUFBQSxJQUNBLFNBQVM7QUFBQSxNQUNQLFFBQVE7QUFBQSxNQUNSLElBQUk7QUFBQSxJQUNOO0FBQUEsSUFDQSxTQUFTO0FBQUEsTUFDUCxhQUFhO0FBQUEsSUFDZjtBQUFBLElBQ0EsVUFBVTtBQUFBLE1BQ1IsY0FBYztBQUFBLE1BQ2QsWUFBWTtBQUFBLE1BQ1osWUFBWTtBQUFBLElBQ2Q7QUFBQSxJQUNBLGVBQWU7QUFBQSxNQUNiLHlCQUF5QjtBQUFBLElBQzNCO0FBQUEsSUFDQSxTQUFTO0FBQUEsTUFDUCx1QkFBdUI7QUFBQSxNQUN2QixnQkFBZ0I7QUFBQSxJQUNsQjtBQUFBLElBQ0EsT0FBTztBQUFBLE1BQ0wsWUFBWTtBQUFBLElBQ2Q7QUFBQSxJQUNBLHFCQUFxQjtBQUFBLE1BQ25CLGNBQWM7QUFBQSxNQUNkLHVCQUF1QjtBQUFBLE1BQ3ZCLGNBQWM7QUFBQSxNQUNkLGNBQWM7QUFBQSxJQUNoQjtBQUFBLElBQ0EsT0FBTztBQUFBLE1BQ0wsYUFBYTtBQUFBLElBQ2Y7QUFBQSxFQUNGO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
|
@@ -8,17 +8,43 @@
|
|
|
8
8
|
*/
|
|
9
9
|
export declare const en: {
|
|
10
10
|
readonly obsidianDevUtils: {
|
|
11
|
+
readonly asyncWithNotice: {
|
|
12
|
+
readonly milliseconds: "milliseconds...";
|
|
13
|
+
readonly operation: "Operation:";
|
|
14
|
+
readonly runningFor: "Running for";
|
|
15
|
+
readonly terminateOperation: "You can terminate the operation by clicking the button below, but be aware it might leave the vault in an inconsistent state.";
|
|
16
|
+
readonly timedOut: "The operation timed out after {{duration}} milliseconds.";
|
|
17
|
+
};
|
|
11
18
|
readonly buttons: {
|
|
12
19
|
readonly cancel: "Cancel";
|
|
13
20
|
readonly ok: "OK";
|
|
14
21
|
};
|
|
22
|
+
readonly callout: {
|
|
23
|
+
readonly loadContent: "Load content for callout";
|
|
24
|
+
};
|
|
15
25
|
readonly dataview: {
|
|
16
26
|
readonly itemsPerPage: "Items per page:";
|
|
17
27
|
readonly jumpToPage: "Jump to page:";
|
|
28
|
+
readonly pageHeader: "Page {{pageNumber}} of {{totalPages}}, Total items: {{totalItems}}";
|
|
29
|
+
};
|
|
30
|
+
readonly metadataCache: {
|
|
31
|
+
readonly getBacklinksForFilePath: "Get backlinks for {{filePath}}";
|
|
18
32
|
};
|
|
19
33
|
readonly notices: {
|
|
20
34
|
readonly attachmentIsStillUsed: "Attachment {{attachmentPath}} is still used by other notes. It will not be deleted.";
|
|
21
35
|
readonly unhandledError: "An unhandled error occurred. Please check the console for more information.";
|
|
22
36
|
};
|
|
37
|
+
readonly queue: {
|
|
38
|
+
readonly flushQueue: "Flush queue";
|
|
39
|
+
};
|
|
40
|
+
readonly renameDeleteHandler: {
|
|
41
|
+
readonly handleDelete: "Handle delete: {{filePath}}";
|
|
42
|
+
readonly handleOrphanedRenames: "Handle orphaned renames";
|
|
43
|
+
readonly handleRename: "Handle rename: {{oldPath}} -> {{newPath}}";
|
|
44
|
+
readonly updatedLinks: "Updated {{linksCount}} links in {{filesCount}} files.";
|
|
45
|
+
};
|
|
46
|
+
readonly vault: {
|
|
47
|
+
readonly processFile: "Process file {{filePath}}";
|
|
48
|
+
};
|
|
23
49
|
};
|
|
24
50
|
};
|
|
@@ -12,18 +12,44 @@ export declare const DEFAULT_LANGUAGE: keyof typeof translationsMapImpl;
|
|
|
12
12
|
declare const translationsMapImpl: {
|
|
13
13
|
readonly en: {
|
|
14
14
|
readonly obsidianDevUtils: {
|
|
15
|
+
readonly asyncWithNotice: {
|
|
16
|
+
readonly milliseconds: "milliseconds...";
|
|
17
|
+
readonly operation: "Operation:";
|
|
18
|
+
readonly runningFor: "Running for";
|
|
19
|
+
readonly terminateOperation: "You can terminate the operation by clicking the button below, but be aware it might leave the vault in an inconsistent state.";
|
|
20
|
+
readonly timedOut: "The operation timed out after {{duration}} milliseconds.";
|
|
21
|
+
};
|
|
15
22
|
readonly buttons: {
|
|
16
23
|
readonly cancel: "Cancel";
|
|
17
24
|
readonly ok: "OK";
|
|
18
25
|
};
|
|
26
|
+
readonly callout: {
|
|
27
|
+
readonly loadContent: "Load content for callout";
|
|
28
|
+
};
|
|
19
29
|
readonly dataview: {
|
|
20
30
|
readonly itemsPerPage: "Items per page:";
|
|
21
31
|
readonly jumpToPage: "Jump to page:";
|
|
32
|
+
readonly pageHeader: "Page {{pageNumber}} of {{totalPages}}, Total items: {{totalItems}}";
|
|
33
|
+
};
|
|
34
|
+
readonly metadataCache: {
|
|
35
|
+
readonly getBacklinksForFilePath: "Get backlinks for {{filePath}}";
|
|
22
36
|
};
|
|
23
37
|
readonly notices: {
|
|
24
38
|
readonly attachmentIsStillUsed: "Attachment {{attachmentPath}} is still used by other notes. It will not be deleted.";
|
|
25
39
|
readonly unhandledError: "An unhandled error occurred. Please check the console for more information.";
|
|
26
40
|
};
|
|
41
|
+
readonly queue: {
|
|
42
|
+
readonly flushQueue: "Flush queue";
|
|
43
|
+
};
|
|
44
|
+
readonly renameDeleteHandler: {
|
|
45
|
+
readonly handleDelete: "Handle delete: {{filePath}}";
|
|
46
|
+
readonly handleOrphanedRenames: "Handle orphaned renames";
|
|
47
|
+
readonly handleRename: "Handle rename: {{oldPath}} -> {{newPath}}";
|
|
48
|
+
readonly updatedLinks: "Updated {{linksCount}} links in {{filesCount}} files.";
|
|
49
|
+
};
|
|
50
|
+
readonly vault: {
|
|
51
|
+
readonly processFile: "Process file {{filePath}}";
|
|
52
|
+
};
|
|
27
53
|
};
|
|
28
54
|
};
|
|
29
55
|
};
|
|
@@ -132,6 +132,7 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
132
132
|
var obsidian_exports = {};
|
|
133
133
|
__export(obsidian_exports, {
|
|
134
134
|
App: () => App,
|
|
135
|
+
AsyncWithNotice: () => AsyncWithNotice,
|
|
135
136
|
AttachmentPath: () => AttachmentPath,
|
|
136
137
|
Backlink: () => Backlink,
|
|
137
138
|
Callout: () => Callout,
|
|
@@ -172,6 +173,7 @@ __export(obsidian_exports, {
|
|
|
172
173
|
});
|
|
173
174
|
module.exports = __toCommonJS(obsidian_exports);
|
|
174
175
|
var App = __toESM(__extractDefault(require('./App.cjs')), 1);
|
|
176
|
+
var AsyncWithNotice = __toESM(__extractDefault(require('./AsyncWithNotice.cjs')), 1);
|
|
175
177
|
var AttachmentPath = __toESM(__extractDefault(require('./AttachmentPath.cjs')), 1);
|
|
176
178
|
var Backlink = __toESM(__extractDefault(require('./Backlink.cjs')), 1);
|
|
177
179
|
var Callout = __toESM(__extractDefault(require('./Callout.cjs')), 1);
|
|
@@ -212,6 +214,7 @@ var Workspace = __toESM(__extractDefault(require('./Workspace.cjs')), 1);
|
|
|
212
214
|
// Annotate the CommonJS export names for ESM import in node:
|
|
213
215
|
0 && (module.exports = {
|
|
214
216
|
App,
|
|
217
|
+
AsyncWithNotice,
|
|
215
218
|
AttachmentPath,
|
|
216
219
|
Backlink,
|
|
217
220
|
Callout,
|
|
@@ -250,4 +253,4 @@ var Workspace = __toESM(__extractDefault(require('./Workspace.cjs')), 1);
|
|
|
250
253
|
Workspace,
|
|
251
254
|
i18n
|
|
252
255
|
});
|
|
253
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
256
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgQXBwIGZyb20gJy4vQXBwLnRzJztcbmV4cG9ydCAqIGFzIEFzeW5jV2l0aE5vdGljZSBmcm9tICcuL0FzeW5jV2l0aE5vdGljZS50cyc7XG5leHBvcnQgKiBhcyBBdHRhY2htZW50UGF0aCBmcm9tICcuL0F0dGFjaG1lbnRQYXRoLnRzJztcbmV4cG9ydCAqIGFzIEJhY2tsaW5rIGZyb20gJy4vQmFja2xpbmsudHMnO1xuZXhwb3J0ICogYXMgQ2FsbG91dCBmcm9tICcuL0NhbGxvdXQudHMnO1xuZXhwb3J0ICogYXMgQ29kZUJsb2NrTWFya2Rvd25JbmZvcm1hdGlvbiBmcm9tICcuL0NvZGVCbG9ja01hcmtkb3duSW5mb3JtYXRpb24udHMnO1xuZXhwb3J0ICogYXMgQ29tbWFuZHMgZnJvbSAnLi9Db21tYW5kcy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBDb21wb25lbnRzIGZyb20gJy4vQ29tcG9uZW50cy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBEYXRhdmlldyBmcm9tICcuL0RhdGF2aWV3LnRzJztcbmV4cG9ydCAqIGFzIERhdGF2aWV3TGluayBmcm9tICcuL0RhdGF2aWV3TGluay50cyc7XG5leHBvcnQgKiBhcyBFZGl0b3IgZnJvbSAnLi9FZGl0b3IudHMnO1xuZXhwb3J0ICogYXMgRmlsZUNoYW5nZSBmcm9tICcuL0ZpbGVDaGFuZ2UudHMnO1xuZXhwb3J0ICogYXMgRmlsZU1hbmFnZXIgZnJvbSAnLi9GaWxlTWFuYWdlci50cyc7XG5leHBvcnQgKiBhcyBGaWxlU3lzdGVtIGZyb20gJy4vRmlsZVN5c3RlbS50cyc7XG5leHBvcnQgKiBhcyBGcm9udG1hdHRlciBmcm9tICcuL0Zyb250bWF0dGVyLnRzJztcbmV4cG9ydCAqIGFzIEZyb250bWF0dGVyTGlua0NhY2hlV2l0aE9mZnNldHMgZnJvbSAnLi9Gcm9udG1hdHRlckxpbmtDYWNoZVdpdGhPZmZzZXRzLnRzJztcbmV4cG9ydCAqIGFzIGkxOG4gZnJvbSAnLi9pMThuL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIExpbmsgZnJvbSAnLi9MaW5rLnRzJztcbmV4cG9ydCAqIGFzIExvZ2dlciBmcm9tICcuL0xvZ2dlci50cyc7XG5leHBvcnQgKiBhcyBMb29wIGZyb20gJy4vTG9vcC50cyc7XG5leHBvcnQgKiBhcyBNYXJrZG93biBmcm9tICcuL01hcmtkb3duLnRzJztcbmV4cG9ydCAqIGFzIE1hcmtkb3duQ29kZUJsb2NrUHJvY2Vzc29yIGZyb20gJy4vTWFya2Rvd25Db2RlQmxvY2tQcm9jZXNzb3IudHMnO1xuZXhwb3J0ICogYXMgTWFya2Rvd25WaWV3IGZyb20gJy4vTWFya2Rvd25WaWV3LnRzJztcbmV4cG9ydCAqIGFzIE1ldGFkYXRhQ2FjaGUgZnJvbSAnLi9NZXRhZGF0YUNhY2hlLnRzJztcbmV4cG9ydCAqIGFzIE1vZGFscyBmcm9tICcuL01vZGFscy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBNb25rZXlBcm91bmQgZnJvbSAnLi9Nb25rZXlBcm91bmQudHMnO1xuZXhwb3J0ICogYXMgT2JzaWRpYW5TZXR0aW5ncyBmcm9tICcuL09ic2lkaWFuU2V0dGluZ3MudHMnO1xuZXhwb3J0ICogYXMgUGRmIGZyb20gJy4vUGRmLnRzJztcbmV4cG9ydCAqIGFzIFBsdWdpbiBmcm9tICcuL1BsdWdpbi9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBRdWV1ZSBmcm9tICcuL1F1ZXVlLnRzJztcbmV4cG9ydCAqIGFzIFJlYWN0IGZyb20gJy4vUmVhY3QvaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgUmVmZXJlbmNlIGZyb20gJy4vUmVmZXJlbmNlLnRzJztcbmV4cG9ydCAqIGFzIFJlbmFtZURlbGV0ZUhhbmRsZXIgZnJvbSAnLi9SZW5hbWVEZWxldGVIYW5kbGVyLnRzJztcbmV4cG9ydCAqIGFzIFJlc291cmNlVXJsIGZyb20gJy4vUmVzb3VyY2VVcmwudHMnO1xuZXhwb3J0ICogYXMgU2V0dGluZ0V4IGZyb20gJy4vU2V0dGluZ0V4LnRzJztcbmV4cG9ydCAqIGFzIFZhbGlkYXRpb24gZnJvbSAnLi9WYWxpZGF0aW9uLnRzJztcbmV4cG9ydCAqIGFzIFZhdWx0IGZyb20gJy4vVmF1bHQudHMnO1xuZXhwb3J0ICogYXMgVmF1bHRFeCBmcm9tICcuL1ZhdWx0RXgudHMnO1xuZXhwb3J0ICogYXMgV29ya3NwYWNlIGZyb20gJy4vV29ya3NwYWNlLnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFFQSxVQUFxQjtBQUNyQixzQkFBaUM7QUFDakMscUJBQWdDO0FBQ2hDLGVBQTBCO0FBQzFCLGNBQXlCO0FBQ3pCLG1DQUE4QztBQUM5QyxlQUEwQjtBQUMxQixpQkFBNEI7QUFDNUIsZUFBMEI7QUFDMUIsbUJBQThCO0FBQzlCLGFBQXdCO0FBQ3hCLGlCQUE0QjtBQUM1QixrQkFBNkI7QUFDN0IsaUJBQTRCO0FBQzVCLGtCQUE2QjtBQUM3QixzQ0FBaUQ7QUFDakQsV0FBc0I7QUFDdEIsV0FBc0I7QUFDdEIsYUFBd0I7QUFDeEIsV0FBc0I7QUFDdEIsZUFBMEI7QUFDMUIsaUNBQTRDO0FBQzVDLG1CQUE4QjtBQUM5QixvQkFBK0I7QUFDL0IsYUFBd0I7QUFDeEIsbUJBQThCO0FBQzlCLHVCQUFrQztBQUNsQyxVQUFxQjtBQUNyQixhQUF3QjtBQUN4QixZQUF1QjtBQUN2QixZQUF1QjtBQUN2QixnQkFBMkI7QUFDM0IsMEJBQXFDO0FBQ3JDLGtCQUE2QjtBQUM3QixnQkFBMkI7QUFDM0IsaUJBQTRCO0FBQzVCLFlBQXVCO0FBQ3ZCLGNBQXlCO0FBQ3pCLGdCQUEyQjsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/lib/esm/Async.d.mts
CHANGED
|
@@ -142,6 +142,93 @@ export declare function promiseAllAsyncFnsSequentially<T>(asyncFns: (() => Promi
|
|
|
142
142
|
* @returns A {@link Promise} that resolves with an array of the results of the promises.
|
|
143
143
|
*/
|
|
144
144
|
export declare function promiseAllSequentially<T>(promises: Promisable<T>[]): Promise<T[]>;
|
|
145
|
+
/**
|
|
146
|
+
* Options for {@link retryWithTimeout}.
|
|
147
|
+
*/
|
|
148
|
+
export interface RetryWithTimeoutOptions {
|
|
149
|
+
/**
|
|
150
|
+
* The function to handle the timeout.
|
|
151
|
+
*
|
|
152
|
+
* @param context - The timeout context.
|
|
153
|
+
*/
|
|
154
|
+
onTimeout?(this: void, context: TimeoutContext): void;
|
|
155
|
+
/**
|
|
156
|
+
* The function to execute.
|
|
157
|
+
*
|
|
158
|
+
* @param abortSignal - The abort signal to listen to.
|
|
159
|
+
* @returns The result of the function.
|
|
160
|
+
*/
|
|
161
|
+
operationFn(this: void, abortSignal: AbortSignal): Promisable<boolean>;
|
|
162
|
+
/**
|
|
163
|
+
* The name of the operation.
|
|
164
|
+
*/
|
|
165
|
+
operationName?: string;
|
|
166
|
+
/**
|
|
167
|
+
* The retry options.
|
|
168
|
+
*/
|
|
169
|
+
retryOptions?: RetryOptions;
|
|
170
|
+
/**
|
|
171
|
+
* The stack trace of the source function.
|
|
172
|
+
*/
|
|
173
|
+
stackTrace?: string;
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Options for {@link runWithTimeout}.
|
|
177
|
+
*/
|
|
178
|
+
export interface RunWithTimeoutOptions<Result> {
|
|
179
|
+
/**
|
|
180
|
+
* The context of the function.
|
|
181
|
+
*/
|
|
182
|
+
context?: unknown;
|
|
183
|
+
/**
|
|
184
|
+
* The function to handle the timeout.
|
|
185
|
+
*
|
|
186
|
+
* @param context - The timeout context.
|
|
187
|
+
*/
|
|
188
|
+
onTimeout?(this: void, context: TimeoutContext): void;
|
|
189
|
+
/**
|
|
190
|
+
* The operation function to execute.
|
|
191
|
+
*
|
|
192
|
+
* @param abortSignal - The abort signal to listen to.
|
|
193
|
+
* @returns The result of the function.
|
|
194
|
+
*/
|
|
195
|
+
operationFn(this: void, abortSignal: AbortSignal): Promisable<Result>;
|
|
196
|
+
/**
|
|
197
|
+
* The name of the operation.
|
|
198
|
+
*/
|
|
199
|
+
operationName?: string;
|
|
200
|
+
/**
|
|
201
|
+
* The stack trace of the source function.
|
|
202
|
+
*/
|
|
203
|
+
stackTrace?: string | undefined;
|
|
204
|
+
/**
|
|
205
|
+
* The maximum time to wait in milliseconds.
|
|
206
|
+
*/
|
|
207
|
+
timeoutInMilliseconds: number;
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* Context provided to the timeout handler.
|
|
211
|
+
*/
|
|
212
|
+
export interface TimeoutContext {
|
|
213
|
+
/**
|
|
214
|
+
* The duration in milliseconds since the operation started.
|
|
215
|
+
*/
|
|
216
|
+
duration: number;
|
|
217
|
+
/**
|
|
218
|
+
* Registers a callback to be invoked when the operation completes.
|
|
219
|
+
*
|
|
220
|
+
* @param callback - The function to call when the operation completes.
|
|
221
|
+
*/
|
|
222
|
+
onOperationCompleted(callback: () => void): void;
|
|
223
|
+
/**
|
|
224
|
+
* The name of the operation.
|
|
225
|
+
*/
|
|
226
|
+
operationName: string;
|
|
227
|
+
/**
|
|
228
|
+
* Terminates the operation that timed out.
|
|
229
|
+
*/
|
|
230
|
+
terminateOperation(): void;
|
|
231
|
+
}
|
|
145
232
|
/**
|
|
146
233
|
* Marks an error to terminate retry logic.
|
|
147
234
|
*
|
|
@@ -175,25 +262,20 @@ export declare function requestAnimationFrameAsync(): Promise<void>;
|
|
|
175
262
|
/**
|
|
176
263
|
* Retries the provided function until it returns true or the timeout is reached.
|
|
177
264
|
*
|
|
178
|
-
* @param
|
|
179
|
-
* @param retryOptions - Optional parameters to configure the retry behavior.
|
|
180
|
-
* @param stackTrace - Optional stack trace.
|
|
265
|
+
* @param options - The options for the function.
|
|
181
266
|
* @returns A {@link Promise} that resolves when the function returns true or rejects when the timeout is reached.
|
|
182
267
|
*/
|
|
183
|
-
export declare function retryWithTimeout(
|
|
268
|
+
export declare function retryWithTimeout(options: RetryWithTimeoutOptions): Promise<void>;
|
|
184
269
|
/**
|
|
185
270
|
* Executes a function with a timeout. If the function does not complete within the specified time, it is considered to have timed out.
|
|
186
271
|
*
|
|
187
272
|
* If `DEBUG=obsidian-dev-utils:Async:runWithTimeout` is set, the execution is not terminated after the timeout and the function is allowed to run indefinitely.
|
|
188
273
|
*
|
|
189
|
-
* @typeParam
|
|
190
|
-
* @param
|
|
191
|
-
* @param fn - The function to execute.
|
|
192
|
-
* @param context - The context of the function.
|
|
193
|
-
* @param stackTrace - The stack trace of the source function.
|
|
274
|
+
* @typeParam Result - The type of the result from the asynchronous function.
|
|
275
|
+
* @param options - The options for the function.
|
|
194
276
|
* @returns A {@link Promise} that resolves with the result of the asynchronous function or rejects if it times out.
|
|
195
277
|
*/
|
|
196
|
-
export declare function runWithTimeout<Result>(
|
|
278
|
+
export declare function runWithTimeout<Result>(options: RunWithTimeoutOptions<Result>): Promise<Result>;
|
|
197
279
|
/**
|
|
198
280
|
* Gets the next set immediate.
|
|
199
281
|
*
|