obsidian-dev-utils 17.10.1 → 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 (150) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/lib/Async.mjs +154 -0
  3. package/dist/lib/Blob.mjs +81 -0
  4. package/dist/lib/CssClass.mjs +32 -0
  5. package/dist/lib/Debug.mjs +137 -0
  6. package/dist/lib/DebugController.mjs +8 -0
  7. package/dist/lib/Enum.mjs +26 -0
  8. package/dist/lib/Error.mjs +82 -0
  9. package/dist/lib/Function.mjs +28 -0
  10. package/dist/lib/HTMLElement.mjs +65 -0
  11. package/dist/lib/Library.cjs +1 -1
  12. package/dist/lib/Library.mjs +16 -0
  13. package/dist/lib/Object.cjs +1 -1
  14. package/dist/lib/Object.d.ts +16 -0
  15. package/dist/lib/Object.mjs +273 -0
  16. package/dist/lib/Path.mjs +76 -0
  17. package/dist/lib/RegExp.mjs +23 -0
  18. package/dist/lib/String.mjs +119 -0
  19. package/dist/lib/Transformers/DateTransformer.cjs +71 -0
  20. package/dist/lib/Transformers/DateTransformer.d.ts +35 -0
  21. package/dist/lib/Transformers/DateTransformer.mjs +47 -0
  22. package/dist/lib/Transformers/GroupTransformer.cjs +118 -0
  23. package/dist/lib/Transformers/GroupTransformer.d.ts +65 -0
  24. package/dist/lib/Transformers/GroupTransformer.mjs +94 -0
  25. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.cjs +69 -0
  26. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.d.ts +32 -0
  27. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.mjs +45 -0
  28. package/dist/lib/Transformers/Transformer.cjs +107 -0
  29. package/dist/lib/Transformers/Transformer.d.ts +67 -0
  30. package/dist/lib/Transformers/Transformer.mjs +83 -0
  31. package/dist/lib/Transformers/TypedTransformer.cjs +38 -0
  32. package/dist/lib/Transformers/TypedTransformer.d.ts +37 -0
  33. package/dist/lib/Transformers/TypedTransformer.mjs +14 -0
  34. package/dist/lib/Transformers/index.cjs +58 -0
  35. package/dist/lib/Transformers/index.d.ts +5 -0
  36. package/dist/lib/Transformers/index.mjs +20 -0
  37. package/dist/lib/ValueProvider.mjs +20 -0
  38. package/dist/lib/codemirror/StateFieldSpec.mjs +8 -0
  39. package/dist/lib/codemirror/index.mjs +12 -0
  40. package/dist/lib/index.cjs +4 -4
  41. package/dist/lib/index.d.ts +1 -1
  42. package/dist/lib/index.mjs +50 -0
  43. package/dist/lib/obsidian/App.mjs +33 -0
  44. package/dist/lib/obsidian/AttachmentPath.mjs +82 -0
  45. package/dist/lib/obsidian/Backlink.mjs +88 -0
  46. package/dist/lib/obsidian/Callout.mjs +71 -0
  47. package/dist/lib/obsidian/Components/DateComponent.mjs +43 -0
  48. package/dist/lib/obsidian/Components/DateTimeComponent.mjs +43 -0
  49. package/dist/lib/obsidian/Components/EmailComponent.mjs +32 -0
  50. package/dist/lib/obsidian/Components/FileComponent.mjs +48 -0
  51. package/dist/lib/obsidian/Components/MonthComponent.mjs +51 -0
  52. package/dist/lib/obsidian/Components/MultipleDropdownComponent.mjs +88 -0
  53. package/dist/lib/obsidian/Components/MultipleEmailComponent.mjs +42 -0
  54. package/dist/lib/obsidian/Components/MultipleFileComponent.mjs +49 -0
  55. package/dist/lib/obsidian/Components/NumberComponent.mjs +32 -0
  56. package/dist/lib/obsidian/Components/TimeComponent.mjs +53 -0
  57. package/dist/lib/obsidian/Components/TypedRangeTextComponent.mjs +44 -0
  58. package/dist/lib/obsidian/Components/TypedTextComponent.mjs +107 -0
  59. package/dist/lib/obsidian/Components/UrlComponent.mjs +32 -0
  60. package/dist/lib/obsidian/Components/ValidatorComponent.mjs +52 -0
  61. package/dist/lib/obsidian/Components/ValueComponentWithChangeTracking.mjs +9 -0
  62. package/dist/lib/obsidian/Components/WeekComponent.mjs +51 -0
  63. package/dist/lib/obsidian/Components/index.mjs +42 -0
  64. package/dist/lib/obsidian/Dataview.mjs +232 -0
  65. package/dist/lib/obsidian/DataviewLink.mjs +27 -0
  66. package/dist/lib/obsidian/FileChange.mjs +123 -0
  67. package/dist/lib/obsidian/FileManager.mjs +66 -0
  68. package/dist/lib/obsidian/FileSystem.mjs +197 -0
  69. package/dist/lib/obsidian/Frontmatter.mjs +32 -0
  70. package/dist/lib/obsidian/Link.mjs +415 -0
  71. package/dist/lib/obsidian/Logger.mjs +45 -0
  72. package/dist/lib/obsidian/Loop.mjs +39 -0
  73. package/dist/lib/obsidian/Markdown.mjs +40 -0
  74. package/dist/lib/obsidian/MarkdownCodeBlockProcessor.mjs +44 -0
  75. package/dist/lib/obsidian/MarkdownView.mjs +21 -0
  76. package/dist/lib/obsidian/MetadataCache.mjs +219 -0
  77. package/dist/lib/obsidian/Modals/Alert.mjs +52 -0
  78. package/dist/lib/obsidian/Modals/Confirm.mjs +65 -0
  79. package/dist/lib/obsidian/Modals/Prompt.mjs +98 -0
  80. package/dist/lib/obsidian/Modals/SelectItem.mjs +51 -0
  81. package/dist/lib/obsidian/Modals/index.mjs +18 -0
  82. package/dist/lib/obsidian/ObsidianSettings.mjs +18 -0
  83. package/dist/lib/obsidian/Pdf.mjs +42 -0
  84. package/dist/lib/obsidian/Plugin/EmptySettings.mjs +14 -0
  85. package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.mjs +35 -0
  86. package/dist/lib/obsidian/Plugin/Plugin.mjs +28 -0
  87. package/dist/lib/obsidian/Plugin/PluginBase.mjs +148 -0
  88. package/dist/lib/obsidian/Plugin/PluginContext.mjs +45 -0
  89. package/dist/lib/obsidian/Plugin/PluginId.mjs +23 -0
  90. package/dist/lib/obsidian/Plugin/PluginSettingsBase.cjs +13 -9
  91. package/dist/lib/obsidian/Plugin/PluginSettingsBase.mjs +63 -0
  92. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.cjs +1 -1
  93. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.d.ts +1 -1
  94. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.mjs +101 -0
  95. package/dist/lib/obsidian/Plugin/index.mjs +26 -0
  96. package/dist/lib/obsidian/Queue.mjs +50 -0
  97. package/dist/lib/obsidian/Reference.mjs +45 -0
  98. package/dist/lib/obsidian/RenameDeleteHandler.mjs +436 -0
  99. package/dist/lib/obsidian/ResourceUrl.mjs +19 -0
  100. package/dist/lib/obsidian/SettingEx.mjs +148 -0
  101. package/dist/lib/obsidian/Vault.mjs +248 -0
  102. package/dist/lib/obsidian/VaultEx.mjs +71 -0
  103. package/dist/lib/obsidian/index.mjs +68 -0
  104. package/dist/lib/scripts/CliUtils.mjs +135 -0
  105. package/dist/lib/scripts/CodeGenerator.mjs +19 -0
  106. package/dist/lib/scripts/ESLint/ESLint.cjs +2 -2
  107. package/dist/lib/scripts/ESLint/ESLint.mjs +68 -0
  108. package/dist/lib/scripts/ESLint/eslint.config.mjs +287 -0
  109. package/dist/lib/scripts/ESLint/index.mjs +14 -0
  110. package/dist/lib/scripts/Exec.mjs +98 -0
  111. package/dist/lib/scripts/Fs.mjs +64 -0
  112. package/dist/lib/scripts/JSON.mjs +60 -0
  113. package/dist/lib/scripts/NodeModules.mjs +62 -0
  114. package/dist/lib/scripts/Npm.mjs +106 -0
  115. package/dist/lib/scripts/NpmPublish.mjs +21 -0
  116. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.cjs +5 -1
  117. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.d.ts +8 -0
  118. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.mjs +44 -0
  119. package/dist/lib/scripts/Root.mjs +66 -0
  120. package/dist/lib/scripts/build.mjs +60 -0
  121. package/dist/lib/scripts/cli.cjs +2 -2
  122. package/dist/lib/scripts/cli.mjs +65 -0
  123. package/dist/lib/scripts/esbuild/Dependency.cjs +2 -2
  124. package/dist/lib/scripts/esbuild/Dependency.mjs +95 -0
  125. package/dist/lib/scripts/esbuild/ObsidianPluginBuilder.mjs +149 -0
  126. package/dist/lib/scripts/esbuild/changeExtensionPlugin.cjs +67 -0
  127. package/dist/lib/scripts/esbuild/changeExtensionPlugin.d.ts +12 -0
  128. package/dist/lib/scripts/esbuild/changeExtensionPlugin.mjs +43 -0
  129. package/dist/lib/scripts/esbuild/copyToObsidianPluginsFolderPlugin.mjs +50 -0
  130. package/dist/lib/scripts/esbuild/fixEsmPlugin.mjs +25 -0
  131. package/dist/lib/scripts/esbuild/fixSourceMapsPlugin.mjs +55 -0
  132. package/dist/lib/scripts/esbuild/index.cjs +4 -4
  133. package/dist/lib/scripts/esbuild/index.d.ts +1 -1
  134. package/dist/lib/scripts/esbuild/index.mjs +28 -0
  135. package/dist/lib/scripts/esbuild/preprocessPlugin.cjs +4 -4
  136. package/dist/lib/scripts/esbuild/preprocessPlugin.d.ts +2 -1
  137. package/dist/lib/scripts/esbuild/preprocessPlugin.mjs +112 -0
  138. package/dist/lib/scripts/esbuild/renameCssPlugin.mjs +31 -0
  139. package/dist/lib/scripts/esbuild/svelteWrapperPlugin.mjs +41 -0
  140. package/dist/lib/scripts/format.cjs +2 -2
  141. package/dist/lib/scripts/format.mjs +41 -0
  142. package/dist/lib/scripts/index.mjs +44 -0
  143. package/dist/lib/scripts/spellcheck.mjs +15 -0
  144. package/dist/lib/scripts/version.mjs +361 -0
  145. package/dist/lib/url.mjs +25 -0
  146. package/package.json +161 -173
  147. package/dist/lib/@types.cjs +0 -24
  148. package/dist/lib/@types.d.ts +0 -20
  149. package/dist/lib/scripts/esbuild/renameToCjsPlugin.cjs +0 -60
  150. package/dist/lib/scripts/esbuild/renameToCjsPlugin.d.ts +0 -14
@@ -0,0 +1,197 @@
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 {
9
+ App,
10
+ normalizePath,
11
+ TAbstractFile,
12
+ TFile,
13
+ TFolder,
14
+ Vault
15
+ } from "obsidian";
16
+ import {
17
+ createTFileInstance,
18
+ createTFolderInstance,
19
+ parentFolderPath
20
+ } from "obsidian-typings/implementations";
21
+ import {
22
+ extname,
23
+ resolve
24
+ } from "../Path.mjs";
25
+ import { trimEnd } from "../String.mjs";
26
+ const MARKDOWN_FILE_EXTENSION = "md";
27
+ const CANVAS_FILE_EXTENSION = "canvas";
28
+ function checkExtension(app, pathOrFile, extension) {
29
+ if (isFile(pathOrFile)) {
30
+ return pathOrFile.extension === extension;
31
+ }
32
+ if (typeof pathOrFile === "string") {
33
+ const file = getFileOrNull(app, pathOrFile);
34
+ if (file) {
35
+ return file.extension === extension;
36
+ }
37
+ return extname(pathOrFile).slice(1) === extension;
38
+ }
39
+ return false;
40
+ }
41
+ function getAbstractFile(app, pathOrFile, isCaseInsensitive) {
42
+ const file = getAbstractFileOrNull(app, pathOrFile, isCaseInsensitive);
43
+ if (!file) {
44
+ throw new Error(`Abstract file not found: ${pathOrFile}`);
45
+ }
46
+ return file;
47
+ }
48
+ function getAbstractFileOrNull(app, pathOrFile, isCaseInsensitive) {
49
+ if (pathOrFile === null) {
50
+ return null;
51
+ }
52
+ if (isAbstractFile(pathOrFile)) {
53
+ return pathOrFile;
54
+ }
55
+ const file = getFileInternal(app, pathOrFile, isCaseInsensitive);
56
+ if (file) {
57
+ return file;
58
+ }
59
+ const resolvedPath = getResolvedPath(pathOrFile);
60
+ if (resolvedPath === pathOrFile) {
61
+ return null;
62
+ }
63
+ return getFileInternal(app, resolvedPath, isCaseInsensitive);
64
+ }
65
+ function getFile(app, pathOrFile, shouldIncludeNonExisting, isCaseInsensitive) {
66
+ let file = getFileOrNull(app, pathOrFile, isCaseInsensitive);
67
+ if (!file) {
68
+ if (shouldIncludeNonExisting) {
69
+ file = createTFileInstance(app, pathOrFile);
70
+ } else {
71
+ throw new Error(`File not found: ${pathOrFile}`);
72
+ }
73
+ }
74
+ return file;
75
+ }
76
+ function getFileOrNull(app, pathOrFile, isCaseInsensitive) {
77
+ const file = getAbstractFileOrNull(app, pathOrFile, isCaseInsensitive);
78
+ if (isFile(file)) {
79
+ return file;
80
+ }
81
+ return null;
82
+ }
83
+ function getFolder(app, pathOrFolder, shouldIncludeNonExisting, isCaseInsensitive) {
84
+ let folder = getFolderOrNull(app, pathOrFolder, isCaseInsensitive);
85
+ if (!folder) {
86
+ if (shouldIncludeNonExisting) {
87
+ folder = createTFolderInstance(app, pathOrFolder);
88
+ } else {
89
+ throw new Error(`Folder not found: ${pathOrFolder}`);
90
+ }
91
+ }
92
+ return folder;
93
+ }
94
+ function getFolderOrNull(app, pathOrFolder, isCaseInsensitive) {
95
+ const folder = getAbstractFileOrNull(app, pathOrFolder, isCaseInsensitive);
96
+ if (isFolder(folder)) {
97
+ return folder;
98
+ }
99
+ return null;
100
+ }
101
+ function getMarkdownFiles(app, pathOrFolder, isRecursive) {
102
+ const folder = getFolder(app, pathOrFolder);
103
+ let markdownFiles = [];
104
+ if (isRecursive) {
105
+ Vault.recurseChildren(folder, (abstractFile) => {
106
+ if (isMarkdownFile(app, abstractFile)) {
107
+ markdownFiles.push(abstractFile);
108
+ }
109
+ });
110
+ } else {
111
+ markdownFiles = folder.children.filter((file) => isMarkdownFile(app, file));
112
+ }
113
+ markdownFiles = markdownFiles.sort((a, b) => a.path.localeCompare(b.path));
114
+ return markdownFiles;
115
+ }
116
+ async function getOrCreateFile(app, path) {
117
+ const file = getFileOrNull(app, path);
118
+ if (file) {
119
+ return file;
120
+ }
121
+ const folderPath = parentFolderPath(path);
122
+ await getOrCreateFolder(app, folderPath);
123
+ return await app.vault.create(path, "");
124
+ }
125
+ async function getOrCreateFolder(app, path) {
126
+ const folder = getFolderOrNull(app, path);
127
+ if (folder) {
128
+ return folder;
129
+ }
130
+ return await app.vault.createFolder(path);
131
+ }
132
+ function getPath(app, pathOrFile) {
133
+ if (isAbstractFile(pathOrFile)) {
134
+ return pathOrFile.path;
135
+ }
136
+ const file = getAbstractFileOrNull(app, pathOrFile);
137
+ if (file) {
138
+ return file.path;
139
+ }
140
+ return getResolvedPath(pathOrFile);
141
+ }
142
+ function isAbstractFile(file) {
143
+ return file instanceof TAbstractFile;
144
+ }
145
+ function isCanvasFile(app, pathOrFile) {
146
+ return checkExtension(app, pathOrFile, CANVAS_FILE_EXTENSION);
147
+ }
148
+ function isFile(file) {
149
+ return file instanceof TFile;
150
+ }
151
+ function isFolder(file) {
152
+ return file instanceof TFolder;
153
+ }
154
+ function isMarkdownFile(app, pathOrFile) {
155
+ return checkExtension(app, pathOrFile, MARKDOWN_FILE_EXTENSION);
156
+ }
157
+ function isNote(app, pathOrFile) {
158
+ return isMarkdownFile(app, pathOrFile) || isCanvasFile(app, pathOrFile);
159
+ }
160
+ function trimMarkdownExtension(app, file) {
161
+ if (!isMarkdownFile(app, file)) {
162
+ return file.path;
163
+ }
164
+ return trimEnd(file.path, `.${MARKDOWN_FILE_EXTENSION}`);
165
+ }
166
+ function getFileInternal(app, path, isCaseInsensitive) {
167
+ if (isCaseInsensitive) {
168
+ return app.vault.getAbstractFileByPathInsensitive(path);
169
+ }
170
+ return app.vault.getAbstractFileByPath(path);
171
+ }
172
+ function getResolvedPath(path) {
173
+ return normalizePath(resolve("/", path));
174
+ }
175
+ export {
176
+ CANVAS_FILE_EXTENSION,
177
+ MARKDOWN_FILE_EXTENSION,
178
+ checkExtension,
179
+ getAbstractFile,
180
+ getAbstractFileOrNull,
181
+ getFile,
182
+ getFileOrNull,
183
+ getFolder,
184
+ getFolderOrNull,
185
+ getMarkdownFiles,
186
+ getOrCreateFile,
187
+ getOrCreateFolder,
188
+ getPath,
189
+ isAbstractFile,
190
+ isCanvasFile,
191
+ isFile,
192
+ isFolder,
193
+ isMarkdownFile,
194
+ isNote,
195
+ trimMarkdownExtension
196
+ };
197
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/FileSystem.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation FileSystem\n * This module provides utility functions for working with TAbstractFile, TFile, and TFolder instances in Obsidian.\n */\n\nimport {\n  App,\n  normalizePath,\n  TAbstractFile,\n  TFile,\n  TFolder,\n  Vault\n} from 'obsidian';\nimport {\n  createTFileInstance,\n  createTFolderInstance,\n  parentFolderPath\n} from 'obsidian-typings/implementations';\n\nimport {\n  extname,\n  resolve\n} from '../Path.ts';\nimport { trimEnd } from '../String.ts';\n\n/**\n * The file extension for Markdown files.\n */\nexport const MARKDOWN_FILE_EXTENSION = 'md';\n\n/**\n * Represents the file extension for canvas files.\n */\nexport const CANVAS_FILE_EXTENSION = 'canvas';\n\n/**\n * Represents a path or an instance of TAbstractFile.\n */\nexport type PathOrAbstractFile = string | TAbstractFile;\n\n/**\n * Represents a path or a file.\n */\nexport type PathOrFile = string | TFile;\n\n/**\n * Represents a path or an instance of TFolder.\n */\nexport type PathOrFolder = string | TFolder;\n\n/**\n * Checks if the given path or file has the specified extension.\n *\n * @param app - The Obsidian App instance.\n * @param pathOrFile - The path or abstract file to check.\n * @param extension - The extension to compare against.\n * @returns Returns `true` if the path or file has the specified extension, `false` otherwise.\n */\nexport function checkExtension(app: App, pathOrFile: null | PathOrAbstractFile, extension: string): boolean {\n  if (isFile(pathOrFile)) {\n    return pathOrFile.extension === extension;\n  }\n\n  if (typeof pathOrFile === 'string') {\n    const file = getFileOrNull(app, pathOrFile);\n    if (file) {\n      return file.extension === extension;\n    }\n\n    return extname(pathOrFile).slice(1) === extension;\n  }\n\n  return false;\n}\n\n/**\n * Retrieves the TAbstractFile object for the given path or abstract file.\n *\n * @param app - The App instance.\n * @param pathOrFile - The path or abstract file to retrieve the TAbstractFile for.\n * @param isCaseInsensitive - Specifies whether to perform a case-insensitive search. Default is `false`.\n * @returns The TAbstractFile object.\n * @throws Error if the abstract file is not found.\n */\nexport function getAbstractFile(app: App, pathOrFile: PathOrAbstractFile, isCaseInsensitive?: boolean): TAbstractFile {\n  const file = getAbstractFileOrNull(app, pathOrFile, isCaseInsensitive);\n  if (!file) {\n    throw new Error(`Abstract file not found: ${pathOrFile as string}`);\n  }\n\n  return file;\n}\n\n/**\n * Retrieves an instance of TAbstractFile or null based on the provided path or abstract file.\n *\n * @param app - The application instance.\n * @param pathOrFile - The path or abstract file to retrieve.\n * @param isCaseInsensitive - Specifies whether to perform a case-insensitive search. Default is `false`.\n * @returns The instance of TAbstractFile if found, otherwise null.\n */\nexport function getAbstractFileOrNull(app: App, pathOrFile: null | PathOrAbstractFile, isCaseInsensitive?: boolean): null | TAbstractFile {\n  if (pathOrFile === null) {\n    return null;\n  }\n\n  if (isAbstractFile(pathOrFile)) {\n    return pathOrFile;\n  }\n\n  const file = getFileInternal(app, pathOrFile, isCaseInsensitive);\n\n  if (file) {\n    return file;\n  }\n\n  const resolvedPath = getResolvedPath(pathOrFile);\n\n  if (resolvedPath === pathOrFile) {\n    return null;\n  }\n\n  return getFileInternal(app, resolvedPath, isCaseInsensitive);\n}\n\n/**\n * Retrieves a TFile object based on the provided path or file.\n *\n * @param app - The Obsidian App instance.\n * @param pathOrFile - The path or file to retrieve the TFile object for.\n * @param shouldIncludeNonExisting - Whether to include a non-existing file.\n *  If `true`, a new TFile object is created for the provided path.\n *  If `false`, an error is thrown if the file is not found.\n * @param isCaseInsensitive - Specifies whether to perform a case-insensitive search. Default is `false`.\n * @returns The TFile object corresponding to the provided path or file.\n * @throws Error if the file is not found.\n */\nexport function getFile(app: App, pathOrFile: PathOrFile, shouldIncludeNonExisting?: boolean, isCaseInsensitive?: boolean): TFile {\n  let file = getFileOrNull(app, pathOrFile, isCaseInsensitive);\n  if (!file) {\n    if (shouldIncludeNonExisting) {\n      file = createTFileInstance(app, pathOrFile as string);\n    } else {\n      throw new Error(`File not found: ${pathOrFile as string}`);\n    }\n  }\n\n  return file;\n}\n\n/**\n * Retrieves a TFile object based on the provided path or file.\n * If the provided argument is already a TFile object, it is returned as is.\n * Otherwise, the function uses the app's vault to retrieve the TFile object by its path.\n * @param app - The Obsidian App instance.\n * @param pathOrFile - The path or TFile object.\n * @param isCaseInsensitive - Specifies whether to perform a case-insensitive search. Default is `false`.\n * @returns The TFile object if found, otherwise null.\n */\nexport function getFileOrNull(app: App, pathOrFile: null | PathOrFile, isCaseInsensitive?: boolean): null | TFile {\n  const file = getAbstractFileOrNull(app, pathOrFile, isCaseInsensitive);\n  if (isFile(file)) {\n    return file;\n  }\n  return null;\n}\n\n/**\n * Retrieves a TFolder object based on the provided app and pathOrFolder.\n *\n * @param app - The Obsidian app instance.\n * @param pathOrFolder - The path or folder identifier.\n * @param shouldIncludeNonExisting - Whether to allow the folder to not exist.\n *  If `true`, a new TFolder object is created for the provided path.\n *  If `false`, an error is thrown if the folder is not found.\n * @param isCaseInsensitive - Specifies whether to perform a case-insensitive search. Default is `false`.\n * @returns The retrieved TFolder object.\n * @throws If the folder is not found.\n */\nexport function getFolder(app: App, pathOrFolder: PathOrFolder, shouldIncludeNonExisting?: boolean, isCaseInsensitive?: boolean): TFolder {\n  let folder = getFolderOrNull(app, pathOrFolder, isCaseInsensitive);\n  if (!folder) {\n    if (shouldIncludeNonExisting) {\n      folder = createTFolderInstance(app, pathOrFolder as string);\n    } else {\n      throw new Error(`Folder not found: ${pathOrFolder as string}`);\n    }\n  }\n\n  return folder;\n}\n\n/**\n * Retrieves a TFolder object or null based on the provided path or folder.\n *\n * @param app - The Obsidian application instance.\n * @param pathOrFolder - The path or folder to retrieve the TFolder from.\n * @param isCaseInsensitive - Specifies whether to perform a case-insensitive search. Default is `false`.\n * @returns The TFolder object if found, otherwise null.\n */\nexport function getFolderOrNull(app: App, pathOrFolder: null | PathOrFolder, isCaseInsensitive?: boolean): null | TFolder {\n  const folder = getAbstractFileOrNull(app, pathOrFolder, isCaseInsensitive);\n  if (isFolder(folder)) {\n    return folder;\n  }\n  return null;\n}\n\n/**\n * Retrieves an array of TFile objects representing the markdown files within a specified folder or path.\n *\n * @param app - The Obsidian App instance.\n * @param pathOrFolder - The path or folder to retrieve the markdown files from.\n * @param isRecursive - Optional. Specifies whether to recursively search for markdown files within subfolders. Default is false.\n * @returns An array of TFile objects representing the markdown files.\n */\nexport function getMarkdownFiles(app: App, pathOrFolder: PathOrFolder, isRecursive?: boolean): TFile[] {\n  const folder = getFolder(app, pathOrFolder);\n\n  let markdownFiles: TFile[] = [];\n\n  if (isRecursive) {\n    Vault.recurseChildren(folder, (abstractFile) => {\n      if (isMarkdownFile(app, abstractFile)) {\n        markdownFiles.push(abstractFile as TFile);\n      }\n    });\n  } else {\n    markdownFiles = folder.children.filter((file) => isMarkdownFile(app, file)) as TFile[];\n  }\n\n  markdownFiles = markdownFiles.sort((a, b) => a.path.localeCompare(b.path));\n  return markdownFiles;\n}\n\n/**\n * Retrieves the TFile object for the given path or creates a new one if it does not exist.\n *\n * @param app - The Obsidian App instance.\n * @param path - The path of the file to retrieve or create.\n * @returns The TFile object representing the file\n */\nexport async function getOrCreateFile(app: App, path: string): Promise<TFile> {\n  const file = getFileOrNull(app, path);\n  if (file) {\n    return file;\n  }\n\n  const folderPath = parentFolderPath(path);\n  await getOrCreateFolder(app, folderPath);\n\n  return await app.vault.create(path, '');\n}\n\n/**\n * Retrieves the TFolder object for the given path or creates a new one if it does not exist.\n *\n * @param app - The Obsidian App instance.\n * @param path - The path of the folder to retrieve or create.\n * @returns The TFolder object representing the folder.\n */\nexport async function getOrCreateFolder(app: App, path: string): Promise<TFolder> {\n  const folder = getFolderOrNull(app, path);\n  if (folder) {\n    return folder;\n  }\n\n  return await app.vault.createFolder(path);\n}\n\n/**\n * Returns the path of the given `pathOrFile`.\n *\n * @param app - The Obsidian App instance.\n * @param pathOrFile - The path or abstract file.\n * @returns The path of the `pathOrFile`.\n */\nexport function getPath(app: App, pathOrFile: PathOrAbstractFile): string {\n  if (isAbstractFile(pathOrFile)) {\n    return pathOrFile.path;\n  }\n\n  const file = getAbstractFileOrNull(app, pathOrFile);\n  if (file) {\n    return file.path;\n  }\n\n  return getResolvedPath(pathOrFile);\n}\n\n/**\n * Checks if the given file is an instance of TAbstractFile.\n *\n * @param file - The file to check.\n * @returns A boolean indicating whether the file is an instance of TAbstractFile.\n */\nexport function isAbstractFile(file: unknown): file is TAbstractFile {\n  return file instanceof TAbstractFile;\n}\n\n/**\n * Checks if the given file is a canvas file.\n *\n * @param app - The Obsidian App instance.\n * @param pathOrFile - The path or file to check.\n * @returns A boolean indicating whether the file is a canvas file or not.\n */\nexport function isCanvasFile(app: App, pathOrFile: null | PathOrAbstractFile): boolean {\n  return checkExtension(app, pathOrFile, CANVAS_FILE_EXTENSION);\n}\n\n/**\n * Checks if the given file is an instance of TFile.\n *\n * @param file - The file to check.\n * @returns A boolean indicating whether the file is an instance of TFile.\n */\nexport function isFile(file: unknown): file is TFile {\n  return file instanceof TFile;\n}\n\n/**\n * Checks if the given file is a folder.\n *\n * @param file - The file to check.\n * @returns `true` if the file is a folder, `false` otherwise.\n */\nexport function isFolder(file: unknown): file is TFolder {\n  return file instanceof TFolder;\n}\n\n/**\n * Checks if the given file is a Markdown file.\n *\n * @param app - The Obsidian App instance.\n * @param pathOrFile - The path or file to check.\n * @returns A boolean indicating whether the file is a Markdown file.\n */\nexport function isMarkdownFile(app: App, pathOrFile: null | PathOrAbstractFile): boolean {\n  return checkExtension(app, pathOrFile, MARKDOWN_FILE_EXTENSION);\n}\n\n/**\n * Checks if the given file is a note.\n *\n * @param app - The Obsidian App instance.\n * @param pathOrFile - The path or file to check.\n * @returns A boolean indicating whether the file is a note.\n */\nexport function isNote(app: App, pathOrFile: null | PathOrAbstractFile): boolean {\n  return isMarkdownFile(app, pathOrFile) || isCanvasFile(app, pathOrFile);\n}\n\n/**\n * Trims the markdown extension from the file path if the file is a markdown file.\n * If the file is not a markdown file, the original file path is returned.\n *\n * @param app - The Obsidian App instance.\n * @param file - The file to trim the markdown extension from.\n * @returns The file path with the markdown extension trimmed.\n */\nexport function trimMarkdownExtension(app: App, file: TAbstractFile): string {\n  if (!isMarkdownFile(app, file)) {\n    return file.path;\n  }\n\n  return trimEnd(file.path, `.${MARKDOWN_FILE_EXTENSION}`);\n}\n\nfunction getFileInternal(app: App, path: string, isCaseInsensitive?: boolean): null | TAbstractFile {\n  if (isCaseInsensitive) {\n    return app.vault.getAbstractFileByPathInsensitive(path);\n  }\n\n  return app.vault.getAbstractFileByPath(path) as null | TFile;\n}\n\nfunction getResolvedPath(path: string): string {\n  return normalizePath(resolve('/', path));\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,32 @@
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 {
9
+ getFrontMatterInfo,
10
+ parseYaml,
11
+ stringifyYaml
12
+ } from "obsidian";
13
+ import { insertAt } from "../String.mjs";
14
+ function parseFrontmatter(content) {
15
+ const frontmatterInfo = getFrontMatterInfo(content);
16
+ return parseYaml(frontmatterInfo.frontmatter) ?? {};
17
+ }
18
+ function setFrontmatter(content, newFrontmatter) {
19
+ const frontmatterInfo = getFrontMatterInfo(content);
20
+ if (Object.keys(newFrontmatter).length === 0) {
21
+ return content.slice(frontmatterInfo.contentStart);
22
+ }
23
+ const newFrontmatterStr = stringifyYaml(newFrontmatter);
24
+ return frontmatterInfo.exists ? insertAt(content, newFrontmatterStr, frontmatterInfo.from, frontmatterInfo.to) : `---
25
+ ${newFrontmatterStr}---
26
+ ${content}`;
27
+ }
28
+ export {
29
+ parseFrontmatter,
30
+ setFrontmatter
31
+ };
32
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL0Zyb250bWF0dGVyLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBGcm9udG1hdHRlclxuICogVGhpcyBtb2R1bGUgcHJvdmlkZXMgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIHByb2Nlc3NpbmcgYW5kIG1hbmFnaW5nIFlBTUwgZnJvbnQgbWF0dGVyIGluIE9ic2lkaWFuIG5vdGVzLlxuICovXG5cbmltcG9ydCB7XG4gIGdldEZyb250TWF0dGVySW5mbyxcbiAgcGFyc2VZYW1sLFxuICBzdHJpbmdpZnlZYW1sXG59IGZyb20gJ29ic2lkaWFuJztcblxuaW1wb3J0IHsgaW5zZXJ0QXQgfSBmcm9tICcuLi9TdHJpbmcudHMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIGNvbWJpbmVkIGZyb250IG1hdHRlciBvZiBhIGRvY3VtZW50LlxuICogSXQgaXMgYSB1bmlvbiBvZiBjdXN0b20gZnJvbnQgbWF0dGVyLCBPYnNpZGlhbiBmcm9udCBtYXR0ZXIsIGFuZCBhZGRpdGlvbmFsIHByb3BlcnRpZXMuXG4gKiBAdHlwZVBhcmFtIEN1c3RvbUZyb250bWF0dGVyIC0gVGhlIHR5cGUgb2YgY3VzdG9tIGZyb250IG1hdHRlci5cbiAqL1xuZXhwb3J0IHR5cGUgQ29tYmluZWRGcm9udG1hdHRlcjxDdXN0b21Gcm9udG1hdHRlcj4gPSBDdXN0b21Gcm9udG1hdHRlciAmIE9ic2lkaWFuRnJvbnRtYXR0ZXIgJiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSBmcm9udCBtYXR0ZXIgb2YgYW4gT2JzaWRpYW4gZmlsZS5cbiAqIEBzZWUge0BsaW5rIGh0dHBzOi8vaGVscC5vYnNpZGlhbi5tZC9FZGl0aW5nK2FuZCtmb3JtYXR0aW5nL1Byb3BlcnRpZXMjRGVmYXVsdCtwcm9wZXJ0aWVzfVxuICovXG5leHBvcnQgaW50ZXJmYWNlIE9ic2lkaWFuRnJvbnRtYXR0ZXIge1xuICAvKipcbiAgICogQW4gYXJyYXkgb2YgYWxpYXNlcyBmb3IgdGhlIG5vdGUuXG4gICAqL1xuICBhbGlhc2VzPzogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIEFuIGFycmF5IG9mIENTUyBjbGFzc2VzIHRvIGFwcGx5IHRvIHRoZSBub3RlLlxuICAgKi9cbiAgY3NzY2xhc3Nlcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBBbiBhcnJheSBvZiB0YWdzIGZvciB0aGUgbm90ZS5cbiAgICovXG4gIHRhZ3M/OiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSBmcm9udCBtYXR0ZXIgZm9yIHB1Ymxpc2hpbmcgaW4gT2JzaWRpYW4uXG4gKiBAc2VlIHtAbGluayBodHRwczovL2hlbHAub2JzaWRpYW4ubWQvRWRpdGluZythbmQrZm9ybWF0dGluZy9Qcm9wZXJ0aWVzI1Byb3BlcnRpZXMrZm9yK09ic2lkaWFuK1B1Ymxpc2h9XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgT2JzaWRpYW5QdWJsaXNoRnJvbnRtYXR0ZXIge1xuICAvKipcbiAgICogVGhlIGNvdmVyIGltYWdlIGZvciB0aGUgbm90ZS5cbiAgICovXG4gIGNvdmVyPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgZGVzY3JpcHRpb24gZm9yIHRoZSBub3RlLlxuICAgKi9cbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBpbWFnZSBmb3IgdGhlIG5vdGUuXG4gICAqL1xuICBpbWFnZT86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHBlcm1hbmVudCBsaW5rIGZvciB0aGUgbm90ZS5cbiAgICovXG4gIHBlcm1hbGluaz86IHN0cmluZztcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgbm90ZSBpcyBwdWJsaXNoZWQuXG4gICAqL1xuICBwdWJsaXNoPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBQYXJzZXMgdGhlIGZyb250IG1hdHRlciBvZiBhIGdpdmVuIGNvbnRlbnQgc3RyaW5nLlxuICpcbiAqIEBwYXJhbSBjb250ZW50IC0gVGhlIGNvbnRlbnQgc3RyaW5nIHRvIHBhcnNlLlxuICogQHJldHVybnMgVGhlIHBhcnNlZCBmcm9udCBtYXR0ZXIuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZUZyb250bWF0dGVyPEN1c3RvbUZyb250bWF0dGVyID0gdW5rbm93bj4oY29udGVudDogc3RyaW5nKTogQ29tYmluZWRGcm9udG1hdHRlcjxDdXN0b21Gcm9udG1hdHRlcj4ge1xuICBjb25zdCBmcm9udG1hdHRlckluZm8gPSBnZXRGcm9udE1hdHRlckluZm8oY29udGVudCk7XG4gIHJldHVybiAocGFyc2VZYW1sKGZyb250bWF0dGVySW5mby5mcm9udG1hdHRlcikgPz8ge30pIGFzIENvbWJpbmVkRnJvbnRtYXR0ZXI8Q3VzdG9tRnJvbnRtYXR0ZXI+O1xufVxuXG4vKipcbiAqIFNldHMgdGhlIGZyb250IG1hdHRlciBvZiBhIGdpdmVuIGNvbnRlbnQgc3RyaW5nLlxuICpcbiAqIEBwYXJhbSBjb250ZW50IC0gVGhlIGNvbnRlbnQgc3RyaW5nIHRvIHNldCB0aGUgZnJvbnQgbWF0dGVyIGluLlxuICogQHBhcmFtIG5ld0Zyb250bWF0dGVyIC0gVGhlIG5ldyBmcm9udCBtYXR0ZXIgdG8gc2V0LlxuICogQHJldHVybnMgVGhlIG5ldyBjb250ZW50IHN0cmluZyB3aXRoIHRoZSBmcm9udCBtYXR0ZXIgc2V0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gc2V0RnJvbnRtYXR0ZXIoY29udGVudDogc3RyaW5nLCBuZXdGcm9udG1hdHRlcjogb2JqZWN0KTogc3RyaW5nIHtcbiAgY29uc3QgZnJvbnRtYXR0ZXJJbmZvID0gZ2V0RnJvbnRNYXR0ZXJJbmZvKGNvbnRlbnQpO1xuICBpZiAoT2JqZWN0LmtleXMobmV3RnJvbnRtYXR0ZXIpLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBjb250ZW50LnNsaWNlKGZyb250bWF0dGVySW5mby5jb250ZW50U3RhcnQpO1xuICB9XG5cbiAgY29uc3QgbmV3RnJvbnRtYXR0ZXJTdHIgPSBzdHJpbmdpZnlZYW1sKG5ld0Zyb250bWF0dGVyKTtcblxuICByZXR1cm4gZnJvbnRtYXR0ZXJJbmZvLmV4aXN0c1xuICAgID8gaW5zZXJ0QXQoY29udGVudCwgbmV3RnJvbnRtYXR0ZXJTdHIsIGZyb250bWF0dGVySW5mby5mcm9tLCBmcm9udG1hdHRlckluZm8udG8pXG4gICAgOiBgLS0tXFxuJHtuZXdGcm9udG1hdHRlclN0cn0tLS1cXG4ke2NvbnRlbnR9YDtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7QUFLQTtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFFUCxTQUFTLGdCQUFnQjtBQW1FbEIsU0FBUyxpQkFBOEMsU0FBeUQ7QUFDckgsUUFBTSxrQkFBa0IsbUJBQW1CLE9BQU87QUFDbEQsU0FBUSxVQUFVLGdCQUFnQixXQUFXLEtBQUssQ0FBQztBQUNyRDtBQVNPLFNBQVMsZUFBZSxTQUFpQixnQkFBZ0M7QUFDOUUsUUFBTSxrQkFBa0IsbUJBQW1CLE9BQU87QUFDbEQsTUFBSSxPQUFPLEtBQUssY0FBYyxFQUFFLFdBQVcsR0FBRztBQUM1QyxXQUFPLFFBQVEsTUFBTSxnQkFBZ0IsWUFBWTtBQUFBLEVBQ25EO0FBRUEsUUFBTSxvQkFBb0IsY0FBYyxjQUFjO0FBRXRELFNBQU8sZ0JBQWdCLFNBQ25CLFNBQVMsU0FBUyxtQkFBbUIsZ0JBQWdCLE1BQU0sZ0JBQWdCLEVBQUUsSUFDN0U7QUFBQSxFQUFRLGlCQUFpQjtBQUFBLEVBQVEsT0FBTztBQUM5QzsiLAogICJuYW1lcyI6IFtdCn0K