obsidian-dev-utils 17.10.0 → 17.10.2-beta.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.
Files changed (152) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/README.md +4 -2
  3. package/dist/lib/Async.mjs +154 -0
  4. package/dist/lib/Blob.mjs +81 -0
  5. package/dist/lib/CssClass.mjs +32 -0
  6. package/dist/lib/Debug.mjs +137 -0
  7. package/dist/lib/DebugController.mjs +8 -0
  8. package/dist/lib/Enum.mjs +26 -0
  9. package/dist/lib/Error.mjs +82 -0
  10. package/dist/lib/Function.mjs +28 -0
  11. package/dist/lib/HTMLElement.mjs +65 -0
  12. package/dist/lib/Library.cjs +2 -2
  13. package/dist/lib/Library.mjs +16 -0
  14. package/dist/lib/Object.cjs +1 -1
  15. package/dist/lib/Object.d.ts +16 -0
  16. package/dist/lib/Object.mjs +273 -0
  17. package/dist/lib/Path.mjs +76 -0
  18. package/dist/lib/RegExp.mjs +23 -0
  19. package/dist/lib/String.mjs +119 -0
  20. package/dist/lib/Transformers/DateTransformer.cjs +71 -0
  21. package/dist/lib/Transformers/DateTransformer.d.ts +35 -0
  22. package/dist/lib/Transformers/DateTransformer.mjs +47 -0
  23. package/dist/lib/Transformers/GroupTransformer.cjs +118 -0
  24. package/dist/lib/Transformers/GroupTransformer.d.ts +65 -0
  25. package/dist/lib/Transformers/GroupTransformer.mjs +94 -0
  26. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.cjs +69 -0
  27. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.d.ts +32 -0
  28. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.mjs +45 -0
  29. package/dist/lib/Transformers/Transformer.cjs +107 -0
  30. package/dist/lib/Transformers/Transformer.d.ts +67 -0
  31. package/dist/lib/Transformers/Transformer.mjs +83 -0
  32. package/dist/lib/Transformers/TypedTransformer.cjs +38 -0
  33. package/dist/lib/Transformers/TypedTransformer.d.ts +37 -0
  34. package/dist/lib/Transformers/TypedTransformer.mjs +14 -0
  35. package/dist/lib/Transformers/index.cjs +58 -0
  36. package/dist/lib/Transformers/index.d.ts +5 -0
  37. package/dist/lib/Transformers/index.mjs +20 -0
  38. package/dist/lib/ValueProvider.mjs +20 -0
  39. package/dist/lib/codemirror/StateFieldSpec.mjs +8 -0
  40. package/dist/lib/codemirror/index.mjs +12 -0
  41. package/dist/lib/index.cjs +4 -4
  42. package/dist/lib/index.d.ts +1 -1
  43. package/dist/lib/index.mjs +50 -0
  44. package/dist/lib/obsidian/App.mjs +33 -0
  45. package/dist/lib/obsidian/AttachmentPath.mjs +82 -0
  46. package/dist/lib/obsidian/Backlink.mjs +88 -0
  47. package/dist/lib/obsidian/Callout.mjs +71 -0
  48. package/dist/lib/obsidian/Components/DateComponent.mjs +43 -0
  49. package/dist/lib/obsidian/Components/DateTimeComponent.mjs +43 -0
  50. package/dist/lib/obsidian/Components/EmailComponent.mjs +32 -0
  51. package/dist/lib/obsidian/Components/FileComponent.mjs +48 -0
  52. package/dist/lib/obsidian/Components/MonthComponent.mjs +51 -0
  53. package/dist/lib/obsidian/Components/MultipleDropdownComponent.mjs +88 -0
  54. package/dist/lib/obsidian/Components/MultipleEmailComponent.mjs +42 -0
  55. package/dist/lib/obsidian/Components/MultipleFileComponent.mjs +49 -0
  56. package/dist/lib/obsidian/Components/NumberComponent.mjs +32 -0
  57. package/dist/lib/obsidian/Components/TimeComponent.mjs +53 -0
  58. package/dist/lib/obsidian/Components/TypedRangeTextComponent.mjs +44 -0
  59. package/dist/lib/obsidian/Components/TypedTextComponent.mjs +107 -0
  60. package/dist/lib/obsidian/Components/UrlComponent.mjs +32 -0
  61. package/dist/lib/obsidian/Components/ValidatorComponent.mjs +52 -0
  62. package/dist/lib/obsidian/Components/ValueComponentWithChangeTracking.mjs +9 -0
  63. package/dist/lib/obsidian/Components/WeekComponent.mjs +51 -0
  64. package/dist/lib/obsidian/Components/index.mjs +42 -0
  65. package/dist/lib/obsidian/Dataview.mjs +232 -0
  66. package/dist/lib/obsidian/DataviewLink.mjs +27 -0
  67. package/dist/lib/obsidian/FileChange.mjs +123 -0
  68. package/dist/lib/obsidian/FileManager.mjs +66 -0
  69. package/dist/lib/obsidian/FileSystem.mjs +197 -0
  70. package/dist/lib/obsidian/Frontmatter.mjs +32 -0
  71. package/dist/lib/obsidian/Link.mjs +415 -0
  72. package/dist/lib/obsidian/Logger.mjs +45 -0
  73. package/dist/lib/obsidian/Loop.mjs +39 -0
  74. package/dist/lib/obsidian/Markdown.mjs +40 -0
  75. package/dist/lib/obsidian/MarkdownCodeBlockProcessor.mjs +44 -0
  76. package/dist/lib/obsidian/MarkdownView.mjs +21 -0
  77. package/dist/lib/obsidian/MetadataCache.mjs +219 -0
  78. package/dist/lib/obsidian/Modals/Alert.mjs +52 -0
  79. package/dist/lib/obsidian/Modals/Confirm.mjs +65 -0
  80. package/dist/lib/obsidian/Modals/Prompt.mjs +98 -0
  81. package/dist/lib/obsidian/Modals/SelectItem.mjs +51 -0
  82. package/dist/lib/obsidian/Modals/index.mjs +18 -0
  83. package/dist/lib/obsidian/ObsidianSettings.mjs +18 -0
  84. package/dist/lib/obsidian/Pdf.mjs +42 -0
  85. package/dist/lib/obsidian/Plugin/EmptySettings.mjs +14 -0
  86. package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.mjs +35 -0
  87. package/dist/lib/obsidian/Plugin/Plugin.mjs +28 -0
  88. package/dist/lib/obsidian/Plugin/PluginBase.mjs +148 -0
  89. package/dist/lib/obsidian/Plugin/PluginContext.mjs +45 -0
  90. package/dist/lib/obsidian/Plugin/PluginId.mjs +23 -0
  91. package/dist/lib/obsidian/Plugin/PluginSettingsBase.cjs +13 -9
  92. package/dist/lib/obsidian/Plugin/PluginSettingsBase.mjs +63 -0
  93. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.cjs +1 -1
  94. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.d.ts +1 -1
  95. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.mjs +101 -0
  96. package/dist/lib/obsidian/Plugin/index.mjs +26 -0
  97. package/dist/lib/obsidian/Queue.mjs +50 -0
  98. package/dist/lib/obsidian/Reference.mjs +45 -0
  99. package/dist/lib/obsidian/RenameDeleteHandler.mjs +436 -0
  100. package/dist/lib/obsidian/ResourceUrl.mjs +19 -0
  101. package/dist/lib/obsidian/SettingEx.mjs +148 -0
  102. package/dist/lib/obsidian/Vault.mjs +248 -0
  103. package/dist/lib/obsidian/VaultEx.mjs +71 -0
  104. package/dist/lib/obsidian/index.mjs +68 -0
  105. package/dist/lib/scripts/CliUtils.mjs +135 -0
  106. package/dist/lib/scripts/CodeGenerator.mjs +19 -0
  107. package/dist/lib/scripts/ESLint/ESLint.cjs +2 -2
  108. package/dist/lib/scripts/ESLint/ESLint.mjs +68 -0
  109. package/dist/lib/scripts/ESLint/eslint.config.mjs +287 -0
  110. package/dist/lib/scripts/ESLint/index.mjs +14 -0
  111. package/dist/lib/scripts/Exec.mjs +98 -0
  112. package/dist/lib/scripts/Fs.mjs +64 -0
  113. package/dist/lib/scripts/JSON.mjs +60 -0
  114. package/dist/lib/scripts/NodeModules.mjs +62 -0
  115. package/dist/lib/scripts/Npm.mjs +106 -0
  116. package/dist/lib/scripts/NpmPublish.mjs +21 -0
  117. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.cjs +5 -1
  118. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.d.ts +8 -0
  119. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.mjs +44 -0
  120. package/dist/lib/scripts/Root.mjs +66 -0
  121. package/dist/lib/scripts/build.mjs +60 -0
  122. package/dist/lib/scripts/cli.cjs +2 -2
  123. package/dist/lib/scripts/cli.mjs +65 -0
  124. package/dist/lib/scripts/esbuild/Dependency.cjs +2 -2
  125. package/dist/lib/scripts/esbuild/Dependency.mjs +95 -0
  126. package/dist/lib/scripts/esbuild/ObsidianPluginBuilder.mjs +149 -0
  127. package/dist/lib/scripts/esbuild/changeExtensionPlugin.cjs +67 -0
  128. package/dist/lib/scripts/esbuild/changeExtensionPlugin.d.ts +12 -0
  129. package/dist/lib/scripts/esbuild/changeExtensionPlugin.mjs +43 -0
  130. package/dist/lib/scripts/esbuild/copyToObsidianPluginsFolderPlugin.mjs +50 -0
  131. package/dist/lib/scripts/esbuild/fixEsmPlugin.mjs +25 -0
  132. package/dist/lib/scripts/esbuild/fixSourceMapsPlugin.mjs +55 -0
  133. package/dist/lib/scripts/esbuild/index.cjs +4 -4
  134. package/dist/lib/scripts/esbuild/index.d.ts +1 -1
  135. package/dist/lib/scripts/esbuild/index.mjs +28 -0
  136. package/dist/lib/scripts/esbuild/preprocessPlugin.cjs +4 -4
  137. package/dist/lib/scripts/esbuild/preprocessPlugin.d.ts +2 -1
  138. package/dist/lib/scripts/esbuild/preprocessPlugin.mjs +112 -0
  139. package/dist/lib/scripts/esbuild/renameCssPlugin.mjs +31 -0
  140. package/dist/lib/scripts/esbuild/svelteWrapperPlugin.mjs +41 -0
  141. package/dist/lib/scripts/format.cjs +2 -2
  142. package/dist/lib/scripts/format.mjs +41 -0
  143. package/dist/lib/scripts/index.mjs +44 -0
  144. package/dist/lib/scripts/spellcheck.mjs +15 -0
  145. package/dist/lib/scripts/version.mjs +361 -0
  146. package/dist/lib/url.mjs +25 -0
  147. package/dist/styles.css +19 -56
  148. package/package.json +161 -173
  149. package/dist/lib/@types.cjs +0 -24
  150. package/dist/lib/@types.d.ts +0 -20
  151. package/dist/lib/scripts/esbuild/renameToCjsPlugin.cjs +0 -60
  152. package/dist/lib/scripts/esbuild/renameToCjsPlugin.d.ts +0 -14
@@ -0,0 +1,436 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"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&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){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")})()
7
+
8
+ import { around } from "monkey-around";
9
+ import {
10
+ App,
11
+ TFile,
12
+ Vault
13
+ } from "obsidian";
14
+ import { getLibDebugger } from "../Debug.mjs";
15
+ import { noopAsync } from "../Function.mjs";
16
+ import {
17
+ normalizeOptionalProperties,
18
+ toJson
19
+ } from "../Object.mjs";
20
+ import {
21
+ basename,
22
+ dirname,
23
+ extname,
24
+ join,
25
+ makeFileName,
26
+ relative
27
+ } from "../Path.mjs";
28
+ import { replaceAll } from "../String.mjs";
29
+ import { getObsidianDevUtilsState } from "./App.mjs";
30
+ import {
31
+ getAttachmentFolderPath,
32
+ hasOwnAttachmentFolder
33
+ } from "./AttachmentPath.mjs";
34
+ import {
35
+ getFile,
36
+ getFileOrNull,
37
+ getFolderOrNull,
38
+ isFile,
39
+ isMarkdownFile,
40
+ isNote
41
+ } from "./FileSystem.mjs";
42
+ import {
43
+ editLinks,
44
+ extractLinkFile,
45
+ updateLink,
46
+ updateLinksInFile
47
+ } from "./Link.mjs";
48
+ import {
49
+ getAllLinks,
50
+ getBacklinksForFileOrPath,
51
+ getBacklinksForFileSafe
52
+ } from "./MetadataCache.mjs";
53
+ import { addToQueue } from "./Queue.mjs";
54
+ import {
55
+ getSafeRenamePath,
56
+ renameSafe
57
+ } from "./Vault.mjs";
58
+ import {
59
+ deleteEmptyFolderHierarchy,
60
+ deleteSafe
61
+ } from "./VaultEx.mjs";
62
+ const deletedMetadataCacheMap = /* @__PURE__ */ new Map();
63
+ const handledRenames = /* @__PURE__ */ new Set();
64
+ const interruptedRenamesMap = /* @__PURE__ */ new Map();
65
+ function registerRenameDeleteHandlers(plugin, settingsBuilder) {
66
+ const renameDeleteHandlersMap = getRenameDeleteHandlersMap(plugin.app);
67
+ const pluginId = plugin.manifest.id;
68
+ renameDeleteHandlersMap.set(pluginId, settingsBuilder);
69
+ logRegisteredHandlers(plugin.app);
70
+ plugin.register(() => {
71
+ renameDeleteHandlersMap.delete(pluginId);
72
+ logRegisteredHandlers(plugin.app);
73
+ });
74
+ const app = plugin.app;
75
+ plugin.registerEvent(
76
+ app.vault.on("delete", (file) => {
77
+ handleDeleteIfEnabled(plugin, file);
78
+ })
79
+ );
80
+ plugin.registerEvent(
81
+ app.vault.on("rename", (file, oldPath) => {
82
+ handleRenameIfEnabled(plugin, file, oldPath);
83
+ })
84
+ );
85
+ plugin.registerEvent(
86
+ app.metadataCache.on("deleted", (file, prevCache) => {
87
+ handleMetadataDeletedIfEnabled(plugin, file, prevCache);
88
+ })
89
+ );
90
+ }
91
+ async function continueInterruptedRenames(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks) {
92
+ const interruptedRenames = interruptedRenamesMap.get(oldPath);
93
+ if (interruptedRenames) {
94
+ interruptedRenamesMap.delete(oldPath);
95
+ for (const interruptedRename of interruptedRenames) {
96
+ await handleRenameAsync(app, interruptedRename.oldPath, newPath, oldPathBacklinksMap, oldPathLinks, interruptedRename.combinedBacklinksMap);
97
+ }
98
+ }
99
+ }
100
+ async function fillRenameMap(app, oldPath, newPath, renameMap, oldPathLinks) {
101
+ renameMap.set(oldPath, newPath);
102
+ if (!isNote(app, oldPath)) {
103
+ return;
104
+ }
105
+ const settings = getSettings(app);
106
+ const oldAttachmentFolderPath = await getAttachmentFolderPath(app, oldPath);
107
+ const newAttachmentFolderPath = settings.shouldRenameAttachmentFolder ? await getAttachmentFolderPath(app, newPath) : oldAttachmentFolderPath;
108
+ const oldAttachmentFolder = getFolderOrNull(app, oldAttachmentFolderPath);
109
+ if (!oldAttachmentFolder) {
110
+ return;
111
+ }
112
+ if (oldAttachmentFolderPath === newAttachmentFolderPath && !settings.shouldRenameAttachmentFiles) {
113
+ return;
114
+ }
115
+ const oldAttachmentFiles = [];
116
+ if (await hasOwnAttachmentFolder(app, oldPath)) {
117
+ Vault.recurseChildren(oldAttachmentFolder, (oldAttachmentFile) => {
118
+ if (isFile(oldAttachmentFile)) {
119
+ oldAttachmentFiles.push(oldAttachmentFile);
120
+ }
121
+ });
122
+ } else {
123
+ for (const oldPathLink of oldPathLinks) {
124
+ const oldAttachmentFile = extractLinkFile(app, oldPathLink, oldPath);
125
+ if (!oldAttachmentFile) {
126
+ continue;
127
+ }
128
+ if (oldAttachmentFile.path.startsWith(oldAttachmentFolderPath)) {
129
+ const oldAttachmentBacklinks = await getBacklinksForFileSafe(app, oldAttachmentFile);
130
+ if (oldAttachmentBacklinks.keys().length === 1) {
131
+ oldAttachmentFiles.push(oldAttachmentFile);
132
+ }
133
+ }
134
+ }
135
+ }
136
+ const oldBasename = basename(oldPath, extname(oldPath));
137
+ const newBasename = basename(newPath, extname(newPath));
138
+ for (const oldAttachmentFile of oldAttachmentFiles) {
139
+ if (isNote(app, oldAttachmentFile)) {
140
+ continue;
141
+ }
142
+ const relativePath = relative(oldAttachmentFolderPath, oldAttachmentFile.path);
143
+ const newDir = join(newAttachmentFolderPath, dirname(relativePath));
144
+ const newChildBasename = settings.shouldRenameAttachmentFiles ? replaceAll(oldAttachmentFile.basename, oldBasename, newBasename) : oldAttachmentFile.basename;
145
+ let newChildPath = join(newDir, makeFileName(newChildBasename, oldAttachmentFile.extension));
146
+ if (oldAttachmentFile.path === newChildPath) {
147
+ continue;
148
+ }
149
+ if (settings.shouldDeleteConflictingAttachments) {
150
+ const newChildFile = getFileOrNull(app, newChildPath);
151
+ if (newChildFile) {
152
+ await app.fileManager.trashFile(newChildFile);
153
+ }
154
+ } else {
155
+ newChildPath = app.vault.getAvailablePath(join(newDir, newChildBasename), oldAttachmentFile.extension);
156
+ }
157
+ renameMap.set(oldAttachmentFile.path, newChildPath);
158
+ }
159
+ }
160
+ function getRenameDeleteHandlersMap(app) {
161
+ return getObsidianDevUtilsState(app, "renameDeleteHandlersMap", /* @__PURE__ */ new Map()).value;
162
+ }
163
+ function getSettings(app) {
164
+ const renameDeleteHandlersMap = getRenameDeleteHandlersMap(app);
165
+ const settingsBuilders = Array.from(renameDeleteHandlersMap.values()).reverse();
166
+ const settings = {};
167
+ for (const settingsBuilder of settingsBuilders) {
168
+ const newSettings = settingsBuilder();
169
+ settings.shouldDeleteConflictingAttachments ||= newSettings.shouldDeleteConflictingAttachments ?? false;
170
+ settings.shouldDeleteEmptyFolders ||= newSettings.shouldDeleteEmptyFolders ?? false;
171
+ settings.shouldHandleDeletions ||= newSettings.shouldHandleDeletions ?? false;
172
+ settings.shouldHandleRenames ||= newSettings.shouldHandleRenames ?? false;
173
+ settings.shouldRenameAttachmentFiles ||= newSettings.shouldRenameAttachmentFiles ?? false;
174
+ settings.shouldRenameAttachmentFolder ||= newSettings.shouldRenameAttachmentFolder ?? false;
175
+ settings.shouldUpdateFilenameAliases ||= newSettings.shouldUpdateFilenameAliases ?? false;
176
+ const isPathIgnored = settings.isPathIgnored;
177
+ settings.isPathIgnored = (path) => isPathIgnored?.(path) ?? newSettings.isPathIgnored?.(path) ?? false;
178
+ }
179
+ return settings;
180
+ }
181
+ async function handleCaseCollision(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks) {
182
+ if (!app.vault.adapter.insensitive || oldPath.toLowerCase() !== newPath.toLowerCase()) {
183
+ return false;
184
+ }
185
+ const tempPath = join(dirname(newPath), `__temp__${basename(newPath)}`);
186
+ await renameHandled(app, newPath, tempPath);
187
+ await handleRenameAsync(app, oldPath, tempPath, oldPathBacklinksMap, oldPathLinks);
188
+ await app.vault.rename(getFile(app, tempPath), newPath);
189
+ return true;
190
+ }
191
+ async function handleDelete(app, path) {
192
+ getLibDebugger("RenameDeleteHandler:handleDelete")(`Handle Delete ${path}`);
193
+ if (!isNote(app, path)) {
194
+ return;
195
+ }
196
+ const settings = getSettings(app);
197
+ if (!settings.shouldHandleDeletions) {
198
+ return;
199
+ }
200
+ if (settings.isPathIgnored?.(path)) {
201
+ return;
202
+ }
203
+ const cache = deletedMetadataCacheMap.get(path);
204
+ deletedMetadataCacheMap.delete(path);
205
+ if (cache) {
206
+ const links = getAllLinks(cache);
207
+ for (const link of links) {
208
+ const attachmentFile = extractLinkFile(app, link, path);
209
+ if (!attachmentFile) {
210
+ continue;
211
+ }
212
+ if (isNote(app, attachmentFile)) {
213
+ continue;
214
+ }
215
+ await deleteSafe(app, attachmentFile, path, settings.shouldDeleteEmptyFolders);
216
+ }
217
+ }
218
+ const attachmentFolderPath = await getAttachmentFolderPath(app, path);
219
+ const attachmentFolder = getFolderOrNull(app, attachmentFolderPath);
220
+ if (!attachmentFolder) {
221
+ return;
222
+ }
223
+ if (!await hasOwnAttachmentFolder(app, path)) {
224
+ return;
225
+ }
226
+ await deleteSafe(app, attachmentFolder, path, false, settings.shouldDeleteEmptyFolders);
227
+ }
228
+ function handleDeleteIfEnabled(plugin, file) {
229
+ const app = plugin.app;
230
+ if (!shouldInvokeHandler(plugin)) {
231
+ return;
232
+ }
233
+ const path = file.path;
234
+ addToQueue(app, () => handleDelete(app, path));
235
+ }
236
+ function handleMetadataDeleted(app, file, prevCache) {
237
+ const settings = getSettings(app);
238
+ if (settings.isPathIgnored?.(file.path)) {
239
+ return;
240
+ }
241
+ if (!settings.shouldHandleDeletions) {
242
+ return;
243
+ }
244
+ if (isMarkdownFile(app, file) && prevCache) {
245
+ deletedMetadataCacheMap.set(file.path, prevCache);
246
+ }
247
+ }
248
+ function handleMetadataDeletedIfEnabled(plugin, file, prevCache) {
249
+ if (!shouldInvokeHandler(plugin)) {
250
+ return;
251
+ }
252
+ handleMetadataDeleted(plugin.app, file, prevCache);
253
+ }
254
+ function handleRename(app, oldPath, newPath) {
255
+ const key = makeKey(oldPath, newPath);
256
+ getLibDebugger("RenameDeleteHandler:handleRename")(`Handle Rename ${key}`);
257
+ if (handledRenames.has(key)) {
258
+ handledRenames.delete(key);
259
+ return;
260
+ }
261
+ const settings = getSettings(app);
262
+ if (!settings.shouldHandleRenames || settings.isPathIgnored?.(oldPath) || settings.isPathIgnored?.(newPath)) {
263
+ return;
264
+ }
265
+ const cache = app.metadataCache.getCache(oldPath) ?? app.metadataCache.getCache(newPath);
266
+ const oldPathLinks = cache ? getAllLinks(cache) : [];
267
+ const oldPathBacklinksMap = getBacklinksForFileOrPath(app, oldPath).data;
268
+ addToQueue(app, () => handleRenameAsync(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks));
269
+ }
270
+ async function handleRenameAsync(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks, interruptedCombinedBacklinksMap) {
271
+ await continueInterruptedRenames(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks);
272
+ refreshLinks(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks);
273
+ if (await handleCaseCollision(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks)) {
274
+ return;
275
+ }
276
+ const restoreUpdateAllLinks = around(app.fileManager, {
277
+ updateAllLinks: () => noopAsync
278
+ });
279
+ try {
280
+ const renameMap = /* @__PURE__ */ new Map();
281
+ await fillRenameMap(app, oldPath, newPath, renameMap, oldPathLinks);
282
+ const combinedBacklinksMap = /* @__PURE__ */ new Map();
283
+ initBacklinksMap(oldPathBacklinksMap, renameMap, combinedBacklinksMap, oldPath);
284
+ for (const attachmentOldPath of renameMap.keys()) {
285
+ if (attachmentOldPath === oldPath) {
286
+ continue;
287
+ }
288
+ const attachmentOldPathBacklinksMap = (await getBacklinksForFileSafe(app, attachmentOldPath)).data;
289
+ initBacklinksMap(attachmentOldPathBacklinksMap, renameMap, combinedBacklinksMap, attachmentOldPath);
290
+ }
291
+ const parentFolders = /* @__PURE__ */ new Set();
292
+ for (const [oldAttachmentPath, newAttachmentPath] of renameMap.entries()) {
293
+ if (oldAttachmentPath === oldPath) {
294
+ continue;
295
+ }
296
+ const fixedNewAttachmentPath = await renameHandled(app, oldAttachmentPath, newAttachmentPath);
297
+ renameMap.set(oldAttachmentPath, fixedNewAttachmentPath);
298
+ parentFolders.add(dirname(oldAttachmentPath));
299
+ }
300
+ const settings = getSettings(app);
301
+ if (settings.shouldDeleteEmptyFolders) {
302
+ for (const parentFolder of parentFolders) {
303
+ await deleteEmptyFolderHierarchy(app, parentFolder);
304
+ }
305
+ }
306
+ for (const [newBacklinkPath, linkJsonToPathMap] of Array.from(combinedBacklinksMap.entries()).concat(
307
+ Array.from(interruptedCombinedBacklinksMap?.entries() ?? [])
308
+ )) {
309
+ await editLinks(app, newBacklinkPath, (link) => {
310
+ const oldAttachmentPath = linkJsonToPathMap.get(toJson(link));
311
+ if (!oldAttachmentPath) {
312
+ return;
313
+ }
314
+ const newAttachmentPath = renameMap.get(oldAttachmentPath);
315
+ if (!newAttachmentPath) {
316
+ return;
317
+ }
318
+ return updateLink(normalizeOptionalProperties({
319
+ app,
320
+ link,
321
+ newSourcePathOrFile: newBacklinkPath,
322
+ newTargetPathOrFile: newAttachmentPath,
323
+ oldTargetPathOrFile: oldAttachmentPath,
324
+ shouldUpdateFilenameAlias: settings.shouldUpdateFilenameAliases
325
+ }));
326
+ }, {
327
+ shouldFailOnMissingFile: false
328
+ });
329
+ }
330
+ if (isNote(app, newPath)) {
331
+ await updateLinksInFile(normalizeOptionalProperties({
332
+ app,
333
+ newSourcePathOrFile: newPath,
334
+ oldSourcePathOrFile: oldPath,
335
+ shouldFailOnMissingFile: false,
336
+ shouldUpdateFilenameAlias: settings.shouldUpdateFilenameAliases
337
+ }));
338
+ }
339
+ if (!getFileOrNull(app, newPath)) {
340
+ let interruptedRenames = interruptedRenamesMap.get(newPath);
341
+ if (!interruptedRenames) {
342
+ interruptedRenames = [];
343
+ interruptedRenamesMap.set(newPath, interruptedRenames);
344
+ }
345
+ interruptedRenames.push({
346
+ combinedBacklinksMap,
347
+ oldPath
348
+ });
349
+ }
350
+ } finally {
351
+ restoreUpdateAllLinks();
352
+ const orphanKeys = Array.from(handledRenames);
353
+ addToQueue(app, () => {
354
+ for (const key of orphanKeys) {
355
+ handledRenames.delete(key);
356
+ }
357
+ });
358
+ }
359
+ }
360
+ function handleRenameIfEnabled(plugin, file, oldPath) {
361
+ if (!shouldInvokeHandler(plugin)) {
362
+ return;
363
+ }
364
+ if (!isFile(file)) {
365
+ return;
366
+ }
367
+ const newPath = file.path;
368
+ handleRename(plugin.app, oldPath, newPath);
369
+ }
370
+ function initBacklinksMap(singleBacklinksMap, renameMap, combinedBacklinksMap, path) {
371
+ for (const [backlinkPath, links] of singleBacklinksMap.entries()) {
372
+ const newBacklinkPath = renameMap.get(backlinkPath) ?? backlinkPath;
373
+ const linkJsonToPathMap = combinedBacklinksMap.get(newBacklinkPath) ?? /* @__PURE__ */ new Map();
374
+ combinedBacklinksMap.set(newBacklinkPath, linkJsonToPathMap);
375
+ for (const link of links) {
376
+ linkJsonToPathMap.set(toJson(link), path);
377
+ }
378
+ }
379
+ }
380
+ function logRegisteredHandlers(app) {
381
+ const renameDeleteHandlersMap = getRenameDeleteHandlersMap(app);
382
+ getLibDebugger("RenameDeleteHandler:logRegisteredHandlers")(
383
+ `Plugins with registered rename/delete handlers: ${JSON.stringify(Array.from(renameDeleteHandlersMap.keys()))}`
384
+ );
385
+ }
386
+ function makeKey(oldPath, newPath) {
387
+ return `${oldPath} -> ${newPath}`;
388
+ }
389
+ function refreshLinks(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks) {
390
+ const cache = app.metadataCache.getCache(oldPath) ?? app.metadataCache.getCache(newPath);
391
+ const oldPathLinksRefreshed = cache ? getAllLinks(cache) : [];
392
+ const oldPathBacklinksMapRefreshed = getBacklinksForFileOrPath(app, oldPath).data;
393
+ for (const link of oldPathLinksRefreshed) {
394
+ if (oldPathLinks.includes(link)) {
395
+ continue;
396
+ }
397
+ oldPathLinks.push(link);
398
+ }
399
+ for (const [backlinkPath, refreshedLinks] of oldPathBacklinksMapRefreshed.entries()) {
400
+ let oldLinks = oldPathBacklinksMap.get(backlinkPath);
401
+ if (!oldLinks) {
402
+ oldLinks = [];
403
+ oldPathBacklinksMap.set(backlinkPath, oldLinks);
404
+ }
405
+ for (const link of refreshedLinks) {
406
+ if (oldLinks.includes(link)) {
407
+ continue;
408
+ }
409
+ oldLinks.push(link);
410
+ }
411
+ }
412
+ }
413
+ async function renameHandled(app, oldPath, newPath) {
414
+ newPath = getSafeRenamePath(app, oldPath, newPath);
415
+ if (oldPath === newPath) {
416
+ return newPath;
417
+ }
418
+ const key = makeKey(oldPath, newPath);
419
+ handledRenames.add(key);
420
+ newPath = await renameSafe(app, oldPath, newPath);
421
+ return newPath;
422
+ }
423
+ function shouldInvokeHandler(plugin) {
424
+ const app = plugin.app;
425
+ const pluginId = plugin.manifest.id;
426
+ const renameDeleteHandlerPluginIds = getRenameDeleteHandlersMap(app);
427
+ const mainPluginId = Array.from(renameDeleteHandlerPluginIds.keys())[0];
428
+ if (mainPluginId !== pluginId) {
429
+ return false;
430
+ }
431
+ return true;
432
+ }
433
+ export {
434
+ registerRenameDeleteHandlers
435
+ };
436
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/RenameDeleteHandler.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation RenameDeleteHandler\n * Contains utility functions for handling rename and delete events in Obsidian.\n */\n\nimport type {\n  CachedMetadata,\n  Plugin,\n  Reference,\n  TAbstractFile\n} from 'obsidian';\n\nimport { around } from 'monkey-around';\nimport {\n  App,\n  TFile,\n  Vault\n} from 'obsidian';\n\nimport type {\n  UpdateLinkOptions,\n  UpdateLinksInFileOptions\n} from './Link.ts';\n\nimport { getLibDebugger } from '../Debug.ts';\nimport { noopAsync } from '../Function.ts';\nimport {\n  normalizeOptionalProperties,\n  toJson\n} from '../Object.ts';\nimport {\n  basename,\n  dirname,\n  extname,\n  join,\n  makeFileName,\n  relative\n} from '../Path.ts';\nimport { replaceAll } from '../String.ts';\nimport { getObsidianDevUtilsState } from './App.ts';\nimport {\n  getAttachmentFolderPath,\n  hasOwnAttachmentFolder\n} from './AttachmentPath.ts';\nimport {\n  getFile,\n  getFileOrNull,\n  getFolderOrNull,\n  isFile,\n  isMarkdownFile,\n  isNote\n} from './FileSystem.ts';\nimport {\n  editLinks,\n  extractLinkFile,\n  updateLink,\n  updateLinksInFile\n} from './Link.ts';\nimport {\n  getAllLinks,\n  getBacklinksForFileOrPath,\n  getBacklinksForFileSafe\n} from './MetadataCache.ts';\nimport { addToQueue } from './Queue.ts';\nimport {\n  getSafeRenamePath,\n  renameSafe\n} from './Vault.ts';\nimport {\n  deleteEmptyFolderHierarchy,\n  deleteSafe\n} from './VaultEx.ts';\n\nconst deletedMetadataCacheMap = new Map<string, CachedMetadata>();\nconst handledRenames = new Set<string>();\nconst interruptedRenamesMap = new Map<string, InterruptedRename[]>();\n\n/**\n * Settings for the rename/delete handler.\n */\nexport interface RenameDeleteHandlerSettings {\n  /**\n   * Whether to ignore the path.\n   */\n  isPathIgnored(path: string): boolean;\n\n  /**\n   * Whether to delete conflicting attachments.\n   */\n  shouldDeleteConflictingAttachments: boolean;\n\n  /**\n   * Whether to delete empty folders.\n   */\n  shouldDeleteEmptyFolders: boolean;\n\n  /**\n   * Whether to handle deletions.\n   */\n  shouldHandleDeletions: boolean;\n\n  /**\n   * Whether to handle renames.\n   */\n  shouldHandleRenames: boolean;\n\n  /**\n   * Whether to rename attachment files when a note is renamed.\n   */\n  shouldRenameAttachmentFiles: boolean;\n\n  /**\n   * Whether to rename attachment folder when a note is renamed.\n   */\n  shouldRenameAttachmentFolder: boolean;\n\n  /**\n   * Whether to update filename aliases when a note is renamed.\n   */\n  shouldUpdateFilenameAliases: boolean;\n}\n\ninterface InterruptedRename {\n  combinedBacklinksMap: Map<string, Map<string, string>>;\n  oldPath: string;\n}\n\n/**\n * Registers the rename/delete handlers.\n * @param plugin - The plugin instance.\n * @param settingsBuilder - A function that returns the settings for the rename delete handler.\n * @returns void\n */\nexport function registerRenameDeleteHandlers(plugin: Plugin, settingsBuilder: () => Partial<RenameDeleteHandlerSettings>): void {\n  const renameDeleteHandlersMap = getRenameDeleteHandlersMap(plugin.app);\n  const pluginId = plugin.manifest.id;\n\n  renameDeleteHandlersMap.set(pluginId, settingsBuilder);\n  logRegisteredHandlers(plugin.app);\n\n  plugin.register(() => {\n    renameDeleteHandlersMap.delete(pluginId);\n    logRegisteredHandlers(plugin.app);\n  });\n\n  const app = plugin.app;\n  plugin.registerEvent(\n    app.vault.on('delete', (file) => {\n      handleDeleteIfEnabled(plugin, file);\n    })\n  );\n\n  plugin.registerEvent(\n    app.vault.on('rename', (file, oldPath) => {\n      handleRenameIfEnabled(plugin, file, oldPath);\n    })\n  );\n\n  plugin.registerEvent(\n    app.metadataCache.on('deleted', (file, prevCache) => {\n      handleMetadataDeletedIfEnabled(plugin, file, prevCache);\n    })\n  );\n}\n\nasync function continueInterruptedRenames(\n  app: App,\n  oldPath: string,\n  newPath: string,\n  oldPathBacklinksMap: Map<string, Reference[]>,\n  oldPathLinks: Reference[]\n): Promise<void> {\n  const interruptedRenames = interruptedRenamesMap.get(oldPath);\n  if (interruptedRenames) {\n    interruptedRenamesMap.delete(oldPath);\n    for (const interruptedRename of interruptedRenames) {\n      await handleRenameAsync(app, interruptedRename.oldPath, newPath, oldPathBacklinksMap, oldPathLinks, interruptedRename.combinedBacklinksMap);\n    }\n  }\n}\n\nasync function fillRenameMap(app: App, oldPath: string, newPath: string, renameMap: Map<string, string>, oldPathLinks: Reference[]): Promise<void> {\n  renameMap.set(oldPath, newPath);\n\n  if (!isNote(app, oldPath)) {\n    return;\n  }\n\n  const settings = getSettings(app);\n\n  const oldAttachmentFolderPath = await getAttachmentFolderPath(app, oldPath);\n  const newAttachmentFolderPath = settings.shouldRenameAttachmentFolder\n    ? await getAttachmentFolderPath(app, newPath)\n    : oldAttachmentFolderPath;\n\n  const oldAttachmentFolder = getFolderOrNull(app, oldAttachmentFolderPath);\n\n  if (!oldAttachmentFolder) {\n    return;\n  }\n\n  if (oldAttachmentFolderPath === newAttachmentFolderPath && !settings.shouldRenameAttachmentFiles) {\n    return;\n  }\n\n  const oldAttachmentFiles: TFile[] = [];\n\n  if (await hasOwnAttachmentFolder(app, oldPath)) {\n    Vault.recurseChildren(oldAttachmentFolder, (oldAttachmentFile) => {\n      if (isFile(oldAttachmentFile)) {\n        oldAttachmentFiles.push(oldAttachmentFile);\n      }\n    });\n  } else {\n    for (const oldPathLink of oldPathLinks) {\n      const oldAttachmentFile = extractLinkFile(app, oldPathLink, oldPath);\n      if (!oldAttachmentFile) {\n        continue;\n      }\n\n      if (oldAttachmentFile.path.startsWith(oldAttachmentFolderPath)) {\n        const oldAttachmentBacklinks = await getBacklinksForFileSafe(app, oldAttachmentFile);\n        if (oldAttachmentBacklinks.keys().length === 1) {\n          oldAttachmentFiles.push(oldAttachmentFile);\n        }\n      }\n    }\n  }\n\n  const oldBasename = basename(oldPath, extname(oldPath));\n  const newBasename = basename(newPath, extname(newPath));\n\n  for (const oldAttachmentFile of oldAttachmentFiles) {\n    if (isNote(app, oldAttachmentFile)) {\n      continue;\n    }\n    const relativePath = relative(oldAttachmentFolderPath, oldAttachmentFile.path);\n    const newDir = join(newAttachmentFolderPath, dirname(relativePath));\n    const newChildBasename = settings.shouldRenameAttachmentFiles\n      ? replaceAll(oldAttachmentFile.basename, oldBasename, newBasename)\n      : oldAttachmentFile.basename;\n    let newChildPath = join(newDir, makeFileName(newChildBasename, oldAttachmentFile.extension));\n\n    if (oldAttachmentFile.path === newChildPath) {\n      continue;\n    }\n\n    if (settings.shouldDeleteConflictingAttachments) {\n      const newChildFile = getFileOrNull(app, newChildPath);\n      if (newChildFile) {\n        await app.fileManager.trashFile(newChildFile);\n      }\n    } else {\n      newChildPath = app.vault.getAvailablePath(join(newDir, newChildBasename), oldAttachmentFile.extension);\n    }\n    renameMap.set(oldAttachmentFile.path, newChildPath);\n  }\n}\n\nfunction getRenameDeleteHandlersMap(app: App): Map<string, () => Partial<RenameDeleteHandlerSettings>> {\n  return getObsidianDevUtilsState(app, 'renameDeleteHandlersMap', new Map<string, () => Partial<RenameDeleteHandlerSettings>>()).value;\n}\n\nfunction getSettings(app: App): Partial<RenameDeleteHandlerSettings> {\n  const renameDeleteHandlersMap = getRenameDeleteHandlersMap(app);\n  const settingsBuilders = Array.from(renameDeleteHandlersMap.values()).reverse();\n\n  const settings: Partial<RenameDeleteHandlerSettings> = {};\n  for (const settingsBuilder of settingsBuilders) {\n    const newSettings = settingsBuilder();\n    settings.shouldDeleteConflictingAttachments ||= newSettings.shouldDeleteConflictingAttachments ?? false;\n    settings.shouldDeleteEmptyFolders ||= newSettings.shouldDeleteEmptyFolders ?? false;\n    settings.shouldHandleDeletions ||= newSettings.shouldHandleDeletions ?? false;\n    settings.shouldHandleRenames ||= newSettings.shouldHandleRenames ?? false;\n    settings.shouldRenameAttachmentFiles ||= newSettings.shouldRenameAttachmentFiles ?? false;\n    settings.shouldRenameAttachmentFolder ||= newSettings.shouldRenameAttachmentFolder ?? false;\n    settings.shouldUpdateFilenameAliases ||= newSettings.shouldUpdateFilenameAliases ?? false;\n    const isPathIgnored = settings.isPathIgnored;\n    settings.isPathIgnored = (path: string): boolean => isPathIgnored?.(path) ?? newSettings.isPathIgnored?.(path) ?? false;\n  }\n\n  return settings;\n}\n\nasync function handleCaseCollision(\n  app: App,\n  oldPath: string,\n  newPath: string,\n  oldPathBacklinksMap: Map<string, Reference[]>,\n  oldPathLinks: Reference[]\n): Promise<boolean> {\n  if (!app.vault.adapter.insensitive || oldPath.toLowerCase() !== newPath.toLowerCase()) {\n    return false;\n  }\n\n  const tempPath = join(dirname(newPath), `__temp__${basename(newPath)}`);\n  await renameHandled(app, newPath, tempPath);\n  await handleRenameAsync(app, oldPath, tempPath, oldPathBacklinksMap, oldPathLinks);\n  await app.vault.rename(getFile(app, tempPath), newPath);\n  return true;\n}\n\nasync function handleDelete(app: App, path: string): Promise<void> {\n  getLibDebugger('RenameDeleteHandler:handleDelete')(`Handle Delete ${path}`);\n  if (!isNote(app, path)) {\n    return;\n  }\n\n  const settings = getSettings(app);\n  if (!settings.shouldHandleDeletions) {\n    return;\n  }\n\n  if (settings.isPathIgnored?.(path)) {\n    return;\n  }\n\n  const cache = deletedMetadataCacheMap.get(path);\n  deletedMetadataCacheMap.delete(path);\n  if (cache) {\n    const links = getAllLinks(cache);\n\n    for (const link of links) {\n      const attachmentFile = extractLinkFile(app, link, path);\n      if (!attachmentFile) {\n        continue;\n      }\n\n      if (isNote(app, attachmentFile)) {\n        continue;\n      }\n\n      await deleteSafe(app, attachmentFile, path, settings.shouldDeleteEmptyFolders);\n    }\n  }\n\n  const attachmentFolderPath = await getAttachmentFolderPath(app, path);\n  const attachmentFolder = getFolderOrNull(app, attachmentFolderPath);\n\n  if (!attachmentFolder) {\n    return;\n  }\n\n  if (!(await hasOwnAttachmentFolder(app, path))) {\n    return;\n  }\n\n  await deleteSafe(app, attachmentFolder, path, false, settings.shouldDeleteEmptyFolders);\n}\n\nfunction handleDeleteIfEnabled(plugin: Plugin, file: TAbstractFile): void {\n  const app = plugin.app;\n  if (!shouldInvokeHandler(plugin)) {\n    return;\n  }\n  const path = file.path;\n  addToQueue(app, () => handleDelete(app, path));\n}\n\nfunction handleMetadataDeleted(app: App, file: TAbstractFile, prevCache: CachedMetadata | null): void {\n  const settings = getSettings(app);\n  if (settings.isPathIgnored?.(file.path)) {\n    return;\n  }\n\n  if (!settings.shouldHandleDeletions) {\n    return;\n  }\n  if (isMarkdownFile(app, file) && prevCache) {\n    deletedMetadataCacheMap.set(file.path, prevCache);\n  }\n}\n\nfunction handleMetadataDeletedIfEnabled(plugin: Plugin, file: TAbstractFile, prevCache: CachedMetadata | null): void {\n  if (!shouldInvokeHandler(plugin)) {\n    return;\n  }\n  handleMetadataDeleted(plugin.app, file, prevCache);\n}\n\nfunction handleRename(app: App, oldPath: string, newPath: string): void {\n  const key = makeKey(oldPath, newPath);\n  getLibDebugger('RenameDeleteHandler:handleRename')(`Handle Rename ${key}`);\n  if (handledRenames.has(key)) {\n    handledRenames.delete(key);\n    return;\n  }\n\n  const settings = getSettings(app);\n  if (!settings.shouldHandleRenames || settings.isPathIgnored?.(oldPath) || settings.isPathIgnored?.(newPath)) {\n    return;\n  }\n\n  const cache = app.metadataCache.getCache(oldPath) ?? app.metadataCache.getCache(newPath);\n  const oldPathLinks = cache ? getAllLinks(cache) : [];\n  const oldPathBacklinksMap = getBacklinksForFileOrPath(app, oldPath).data;\n  addToQueue(app, () => handleRenameAsync(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks));\n}\n\nasync function handleRenameAsync(\n  app: App,\n  oldPath: string,\n  newPath: string,\n  oldPathBacklinksMap: Map<string, Reference[]>,\n  oldPathLinks: Reference[],\n  interruptedCombinedBacklinksMap?: Map<string, Map<string, string>>\n): Promise<void> {\n  await continueInterruptedRenames(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks);\n  refreshLinks(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks);\n  if (await handleCaseCollision(app, oldPath, newPath, oldPathBacklinksMap, oldPathLinks)) {\n    return;\n  }\n\n  const restoreUpdateAllLinks = around(app.fileManager, {\n    updateAllLinks: () => noopAsync\n  });\n  try {\n    const renameMap = new Map<string, string>();\n    await fillRenameMap(app, oldPath, newPath, renameMap, oldPathLinks);\n\n    const combinedBacklinksMap = new Map<string, Map<string, string>>();\n    initBacklinksMap(oldPathBacklinksMap, renameMap, combinedBacklinksMap, oldPath);\n\n    for (const attachmentOldPath of renameMap.keys()) {\n      if (attachmentOldPath === oldPath) {\n        continue;\n      }\n      const attachmentOldPathBacklinksMap = (await getBacklinksForFileSafe(app, attachmentOldPath)).data;\n      initBacklinksMap(attachmentOldPathBacklinksMap, renameMap, combinedBacklinksMap, attachmentOldPath);\n    }\n\n    const parentFolders = new Set<string>();\n\n    for (const [oldAttachmentPath, newAttachmentPath] of renameMap.entries()) {\n      if (oldAttachmentPath === oldPath) {\n        continue;\n      }\n      const fixedNewAttachmentPath = await renameHandled(app, oldAttachmentPath, newAttachmentPath);\n      renameMap.set(oldAttachmentPath, fixedNewAttachmentPath);\n      parentFolders.add(dirname(oldAttachmentPath));\n    }\n\n    const settings = getSettings(app);\n    if (settings.shouldDeleteEmptyFolders) {\n      for (const parentFolder of parentFolders) {\n        await deleteEmptyFolderHierarchy(app, parentFolder);\n      }\n    }\n\n    for (\n      const [newBacklinkPath, linkJsonToPathMap] of Array.from(combinedBacklinksMap.entries()).concat(\n        Array.from(interruptedCombinedBacklinksMap?.entries() ?? [])\n      )\n    ) {\n      await editLinks(app, newBacklinkPath, (link) => {\n        const oldAttachmentPath = linkJsonToPathMap.get(toJson(link));\n        if (!oldAttachmentPath) {\n          return;\n        }\n\n        const newAttachmentPath = renameMap.get(oldAttachmentPath);\n        if (!newAttachmentPath) {\n          return;\n        }\n\n        return updateLink(normalizeOptionalProperties<UpdateLinkOptions>({\n          app,\n          link,\n          newSourcePathOrFile: newBacklinkPath,\n          newTargetPathOrFile: newAttachmentPath,\n          oldTargetPathOrFile: oldAttachmentPath,\n          shouldUpdateFilenameAlias: settings.shouldUpdateFilenameAliases\n        }));\n      }, {\n        shouldFailOnMissingFile: false\n      });\n    }\n\n    if (isNote(app, newPath)) {\n      await updateLinksInFile(normalizeOptionalProperties<UpdateLinksInFileOptions>({\n        app,\n        newSourcePathOrFile: newPath,\n        oldSourcePathOrFile: oldPath,\n        shouldFailOnMissingFile: false,\n        shouldUpdateFilenameAlias: settings.shouldUpdateFilenameAliases\n      }));\n    }\n\n    if (!getFileOrNull(app, newPath)) {\n      let interruptedRenames = interruptedRenamesMap.get(newPath);\n      if (!interruptedRenames) {\n        interruptedRenames = [];\n        interruptedRenamesMap.set(newPath, interruptedRenames);\n      }\n      interruptedRenames.push({\n        combinedBacklinksMap,\n        oldPath\n      });\n    }\n  } finally {\n    restoreUpdateAllLinks();\n    const orphanKeys = Array.from(handledRenames);\n    addToQueue(app, () => {\n      for (const key of orphanKeys) {\n        handledRenames.delete(key);\n      }\n    });\n  }\n}\n\nfunction handleRenameIfEnabled(plugin: Plugin, file: TAbstractFile, oldPath: string): void {\n  if (!shouldInvokeHandler(plugin)) {\n    return;\n  }\n  if (!isFile(file)) {\n    return;\n  }\n  const newPath = file.path;\n  handleRename(plugin.app, oldPath, newPath);\n}\n\nfunction initBacklinksMap(\n  singleBacklinksMap: Map<string, Reference[]>,\n  renameMap: Map<string, string>,\n  combinedBacklinksMap: Map<string, Map<string, string>>,\n  path: string\n): void {\n  for (const [backlinkPath, links] of singleBacklinksMap.entries()) {\n    const newBacklinkPath = renameMap.get(backlinkPath) ?? backlinkPath;\n    const linkJsonToPathMap = combinedBacklinksMap.get(newBacklinkPath) ?? new Map<string, string>();\n    combinedBacklinksMap.set(newBacklinkPath, linkJsonToPathMap);\n    for (const link of links) {\n      linkJsonToPathMap.set(toJson(link), path);\n    }\n  }\n}\n\nfunction logRegisteredHandlers(app: App): void {\n  const renameDeleteHandlersMap = getRenameDeleteHandlersMap(app);\n  getLibDebugger('RenameDeleteHandler:logRegisteredHandlers')(\n    `Plugins with registered rename/delete handlers: ${JSON.stringify(Array.from(renameDeleteHandlersMap.keys()))}`\n  );\n}\n\nfunction makeKey(oldPath: string, newPath: string): string {\n  return `${oldPath} -> ${newPath}`;\n}\n\nfunction refreshLinks(app: App, oldPath: string, newPath: string, oldPathBacklinksMap: Map<string, Reference[]>, oldPathLinks: Reference[]): void {\n  const cache = app.metadataCache.getCache(oldPath) ?? app.metadataCache.getCache(newPath);\n  const oldPathLinksRefreshed = cache ? getAllLinks(cache) : [];\n  const oldPathBacklinksMapRefreshed = getBacklinksForFileOrPath(app, oldPath).data;\n\n  for (const link of oldPathLinksRefreshed) {\n    if (oldPathLinks.includes(link)) {\n      continue;\n    }\n    oldPathLinks.push(link);\n  }\n\n  for (const [backlinkPath, refreshedLinks] of oldPathBacklinksMapRefreshed.entries()) {\n    let oldLinks = oldPathBacklinksMap.get(backlinkPath);\n    if (!oldLinks) {\n      oldLinks = [];\n      oldPathBacklinksMap.set(backlinkPath, oldLinks);\n    }\n\n    for (const link of refreshedLinks) {\n      if (oldLinks.includes(link)) {\n        continue;\n      }\n      oldLinks.push(link);\n    }\n  }\n}\n\nasync function renameHandled(app: App, oldPath: string, newPath: string): Promise<string> {\n  newPath = getSafeRenamePath(app, oldPath, newPath);\n  if (oldPath === newPath) {\n    return newPath;\n  }\n  const key = makeKey(oldPath, newPath);\n  handledRenames.add(key);\n  newPath = await renameSafe(app, oldPath, newPath);\n  return newPath;\n}\n\nfunction shouldInvokeHandler(plugin: Plugin): boolean {\n  const app = plugin.app;\n  const pluginId = plugin.manifest.id;\n\n  const renameDeleteHandlerPluginIds = getRenameDeleteHandlersMap(app);\n  const mainPluginId = Array.from(renameDeleteHandlerPluginIds.keys())[0];\n  if (mainPluginId !== pluginId) {\n    return false;\n  }\n  return true;\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,19 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"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&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){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")})()
7
+
8
+ import { Platform } from "obsidian";
9
+ import { toPosixPath } from "../Path.mjs";
10
+ function relativePathToResourceUrl(app, relativePath, notePath) {
11
+ const noteFullPath = toPosixPath(app.vault.adapter.getFullRealPath(notePath));
12
+ const noteUrl = `${Platform.resourcePathPrefix}${noteFullPath}`;
13
+ const relativeUrl = new URL(relativePath, noteUrl);
14
+ return relativeUrl.toString();
15
+ }
16
+ export {
17
+ relativePathToResourceUrl
18
+ };
19
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL1Jlc291cmNlVXJsLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBSZXNvdXJjZVVybFxuICogVGhpcyBtb2R1bGUgcHJvdmlkZXMgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIHdvcmtpbmcgd2l0aCByZXNvdXJjZSBVUkxzIGluIE9ic2lkaWFuLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQXBwIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgeyBQbGF0Zm9ybSB9IGZyb20gJ29ic2lkaWFuJztcblxuaW1wb3J0IHsgdG9Qb3NpeFBhdGggfSBmcm9tICcuLi9QYXRoLnRzJztcblxuLyoqXG4gKiBDb252ZXJ0cyBhIHJlbGF0aXZlIHBhdGggdG8gYSByZXNvdXJjZSBVUkwuXG4gKlxuICogQHBhcmFtIGFwcCAtIFRoZSBPYnNpZGlhbiBhcHBsaWNhdGlvbiBpbnN0YW5jZS5cbiAqIEBwYXJhbSByZWxhdGl2ZVBhdGggLSBUaGUgcmVsYXRpdmUgcGF0aCB0byB0aGUgcmVzb3VyY2UuXG4gKiBAcGFyYW0gbm90ZVBhdGggLSBUaGUgcGF0aCBvZiB0aGUgbm90ZS5cbiAqIEByZXR1cm5zIFRoZSByZXNvdXJjZSBVUkwuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZWxhdGl2ZVBhdGhUb1Jlc291cmNlVXJsKGFwcDogQXBwLCByZWxhdGl2ZVBhdGg6IHN0cmluZywgbm90ZVBhdGg6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IG5vdGVGdWxsUGF0aCA9IHRvUG9zaXhQYXRoKGFwcC52YXVsdC5hZGFwdGVyLmdldEZ1bGxSZWFsUGF0aChub3RlUGF0aCkpO1xuICBjb25zdCBub3RlVXJsID0gYCR7UGxhdGZvcm0ucmVzb3VyY2VQYXRoUHJlZml4fSR7bm90ZUZ1bGxQYXRofWA7XG4gIGNvbnN0IHJlbGF0aXZlVXJsID0gbmV3IFVSTChyZWxhdGl2ZVBhdGgsIG5vdGVVcmwpO1xuICByZXR1cm4gcmVsYXRpdmVVcmwudG9TdHJpbmcoKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7QUFPQSxTQUFTLGdCQUFnQjtBQUV6QixTQUFTLG1CQUFtQjtBQVVyQixTQUFTLDBCQUEwQixLQUFVLGNBQXNCLFVBQTBCO0FBQ2xHLFFBQU0sZUFBZSxZQUFZLElBQUksTUFBTSxRQUFRLGdCQUFnQixRQUFRLENBQUM7QUFDNUUsUUFBTSxVQUFVLEdBQUcsU0FBUyxrQkFBa0IsR0FBRyxZQUFZO0FBQzdELFFBQU0sY0FBYyxJQUFJLElBQUksY0FBYyxPQUFPO0FBQ2pELFNBQU8sWUFBWSxTQUFTO0FBQzlCOyIsCiAgIm5hbWVzIjogW10KfQo=