obsidian-typings 2.3.4 → 2.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -41,9 +41,24 @@ __export(implementations_exports, {
41
41
  });
42
42
  module.exports = __toCommonJS(implementations_exports);
43
43
 
44
- // src/obsidian/implementations/PathUtils.ts
45
- function parentFolderPath(path) {
46
- return path.replace(/\/?[^\/]*$/, "") || "/";
44
+ // src/obsidian/implementations/TypeGuards/isReferenceCache.ts
45
+ function isReferenceCache(reference) {
46
+ return !!reference.position;
47
+ }
48
+
49
+ // src/obsidian/implementations/TypeGuards/isEmbedCache.ts
50
+ function isEmbedCache(reference) {
51
+ return isReferenceCache(reference) && reference.original[0] === "!";
52
+ }
53
+
54
+ // src/obsidian/implementations/TypeGuards/isFrontmatterLinkCache.ts
55
+ function isFrontmatterLinkCache(reference) {
56
+ return !!reference.key;
57
+ }
58
+
59
+ // src/obsidian/implementations/TypeGuards/isLinkCache.ts
60
+ function isLinkCache(reference) {
61
+ return isReferenceCache(reference) && reference.original[0] !== "!";
47
62
  }
48
63
 
49
64
  // src/obsidian/implementations/Constructors/constructTFolder.ts
@@ -52,6 +67,37 @@ function constructTFolder(vault, path) {
52
67
  return new import_obsidian.TFolder(vault, path);
53
68
  }
54
69
 
70
+ // src/obsidian/implementations/Constructors/constructInternalPlugins.ts
71
+ function constructInternalPlugins(app) {
72
+ return new app.internalPlugins.constructor(app);
73
+ }
74
+
75
+ // src/obsidian/implementations/Constructors/constructInternalPlugin.ts
76
+ function constructInternalPlugin(app, instance, internalPlugins) {
77
+ const anyPlugin = Object.values(app.internalPlugins.plugins)[0];
78
+ if (!anyPlugin) {
79
+ throw new Error("No internal plugin found");
80
+ }
81
+ return new anyPlugin.constructor(app, instance, internalPlugins);
82
+ }
83
+
84
+ // src/obsidian/implementations/Constructors/constructApp.ts
85
+ var import_obsidian2 = require("obsidian");
86
+ function constructApp(adapter, appId) {
87
+ return new import_obsidian2.App(adapter, appId);
88
+ }
89
+
90
+ // src/obsidian/implementations/Constructors/constructTFile.ts
91
+ var import_obsidian3 = require("obsidian");
92
+ function constructTFile(vault, path) {
93
+ return new import_obsidian3.TFile(vault, path);
94
+ }
95
+
96
+ // src/obsidian/implementations/PathUtils.ts
97
+ function parentFolderPath(path) {
98
+ return path.replace(/\/?[^\/]*$/, "") || "/";
99
+ }
100
+
55
101
  // src/obsidian/implementations/createTFolderInstance.ts
56
102
  function createTFolderInstance(vault, path) {
57
103
  let folder = vault.getFolderByPath(path);
@@ -143,12 +189,6 @@ var InternalPluginName = {
143
189
  ZkPrefixer: "zk-prefixer"
144
190
  };
145
191
 
146
- // src/obsidian/implementations/Constructors/constructTFile.ts
147
- var import_obsidian2 = require("obsidian");
148
- function constructTFile(vault, path) {
149
- return new import_obsidian2.TFile(vault, path);
150
- }
151
-
152
192
  // src/obsidian/implementations/createTFileInstance.ts
153
193
  function createTFileInstance(vault, path) {
154
194
  let file = vault.getFileByPath(path);
@@ -160,44 +200,4 @@ function createTFileInstance(vault, path) {
160
200
  file.deleted = true;
161
201
  return file;
162
202
  }
163
-
164
- // src/obsidian/implementations/TypeGuards/isReferenceCache.ts
165
- function isReferenceCache(reference) {
166
- return !!reference.position;
167
- }
168
-
169
- // src/obsidian/implementations/TypeGuards/isEmbedCache.ts
170
- function isEmbedCache(reference) {
171
- return isReferenceCache(reference) && reference.original[0] === "!";
172
- }
173
-
174
- // src/obsidian/implementations/TypeGuards/isFrontmatterLinkCache.ts
175
- function isFrontmatterLinkCache(reference) {
176
- return !!reference.key;
177
- }
178
-
179
- // src/obsidian/implementations/TypeGuards/isLinkCache.ts
180
- function isLinkCache(reference) {
181
- return isReferenceCache(reference) && reference.original[0] !== "!";
182
- }
183
-
184
- // src/obsidian/implementations/Constructors/constructInternalPlugins.ts
185
- function constructInternalPlugins(app) {
186
- return new app.internalPlugins.constructor(app);
187
- }
188
-
189
- // src/obsidian/implementations/Constructors/constructInternalPlugin.ts
190
- function constructInternalPlugin(app, instance, internalPlugins) {
191
- const anyPlugin = Object.values(app.internalPlugins.plugins)[0];
192
- if (!anyPlugin) {
193
- throw new Error("No internal plugin found");
194
- }
195
- return new anyPlugin.constructor(app, instance, internalPlugins);
196
- }
197
-
198
- // src/obsidian/implementations/Constructors/constructApp.ts
199
- var import_obsidian3 = require("obsidian");
200
- function constructApp(adapter, appId) {
201
- return new import_obsidian3.App(adapter, appId);
202
- }
203
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/obsidian/implementations/index.ts", "../src/obsidian/implementations/PathUtils.ts", "../src/obsidian/implementations/Constructors/constructTFolder.ts", "../src/obsidian/implementations/createTFolderInstance.ts", "../src/obsidian/implementations/CustomArrayDictImpl.ts", "../src/obsidian/implementations/InternalPluginName.ts", "../src/obsidian/implementations/Constructors/constructTFile.ts", "../src/obsidian/implementations/createTFileInstance.ts", "../src/obsidian/implementations/TypeGuards/isReferenceCache.ts", "../src/obsidian/implementations/TypeGuards/isEmbedCache.ts", "../src/obsidian/implementations/TypeGuards/isFrontmatterLinkCache.ts", "../src/obsidian/implementations/TypeGuards/isLinkCache.ts", "../src/obsidian/implementations/Constructors/constructInternalPlugins.ts", "../src/obsidian/implementations/Constructors/constructInternalPlugin.ts", "../src/obsidian/implementations/Constructors/constructApp.ts"],
  "sourcesContent": ["/* THIS IS A GENERATED/BUNDLED FILE BY BUILD SCRIPT */\n\nexport * from './PathUtils.js';\nexport * from './createTFolderInstance.js';\nexport * from './CustomArrayDictImpl.js';\nexport * from './InternalPluginName.js';\nexport * from './createTFileInstance.js';\nexport * from './TypeGuards/isEmbedCache.js';\nexport * from './TypeGuards/isFrontmatterLinkCache.js';\nexport * from './TypeGuards/isReferenceCache.js';\nexport * from './TypeGuards/isLinkCache.js';\nexport * from './Constructors/constructTFolder.js';\nexport * from './Constructors/constructInternalPlugins.js';\nexport * from './Constructors/constructInternalPlugin.js';\nexport * from './Constructors/constructApp.js';\nexport * from './Constructors/constructTFile.js';\nimport '../../index.js';\n", "export function parentFolderPath(path: string): string {\n    return path.replace(/\\/?[^\\/]*$/, '') || '/';\n}\n", "import {\n    TFolder,\n    type Vault\n} from 'obsidian';\n\ntype TFolderConstructor = new(vault: Vault, path: string) => TFolder;\n\n/**\n * Constructs a new TFolder instance.\n *\n * @param vault - The vault to which the folder belongs.\n * @param path - The path of the folder.\n * @returns The constructed TFolder instance.\n */\nexport function constructTFolder(vault: Vault, path: string): TFolder {\n    return new (TFolder as TFolderConstructor)(vault, path);\n}\n", "import {\n    TFolder,\n    type Vault\n} from 'obsidian';\nimport { constructTFolder } from './Constructors/constructTFolder.ts';\nimport { parentFolderPath } from './PathUtils.ts';\n\n/**\n * Creates and properly initializes the instance of TFolder even the underlying folder does not exist.\n * This doesn't create the missing folder on the file system.\n */\nexport function createTFolderInstance(vault: Vault, path: string): TFolder {\n    let folder = vault.getFolderByPath(path);\n    if (folder) {\n        return folder;\n    }\n\n    folder = constructTFolder(vault, path);\n    folder.parent = createTFolderInstance(vault, parentFolderPath(path));\n    folder.deleted = true;\n    return folder;\n}\n", "import type { CustomArrayDict } from '../internals/CustomArrayDict.js';\n\nexport class CustomArrayDictImpl<T> implements CustomArrayDict<T> {\n    public data: Map<string, T[]> = new Map();\n\n    public add(key: string, value: T): void {\n        let values = this.get(key);\n        if (!values) {\n            values = [];\n            this.data.set(key, values);\n        }\n\n        if (!values.includes(value)) {\n            values.push(value);\n        }\n    }\n\n    public remove(key: string, value: T): void {\n        const values = this.get(key);\n        if (!values) {\n            return;\n        }\n        values.remove(value);\n\n        if (values.length === 0) {\n            this.clear(key);\n        }\n    }\n\n    public get(key: string): T[] | null {\n        return this.data.get(key) || null;\n    }\n\n    public keys(): string[] {\n        return Array.from(this.data.keys());\n    }\n\n    public clear(key: string): void {\n        this.data.delete(key);\n    }\n\n    public clearAll(): void {\n        this.data.clear();\n    }\n\n    public contains(key: string, value: T): boolean {\n        return !!this.get(key)?.contains(value);\n    }\n\n    public count(): number {\n        let ans = 0;\n        for (const key in this.keys()) {\n            ans += this.get(key)?.length ?? 0;\n        }\n\n        return ans;\n    }\n}\n", "export const InternalPluginName = {\n    AudioRecorder: 'audio-recorder',\n    Backlink: 'backlink',\n    Bookmarks: 'bookmarks',\n    Canvas: 'canvas',\n    CommandPalette: 'command-palette',\n    DailyNotes: 'daily-notes',\n    EditorStatus: 'editor-status',\n    FileExplorer: 'file-explorer',\n    FileRecovery: 'file-recovery',\n    GlobalSearch: 'global-search',\n    Graph: 'graph',\n    MarkdownImporter: 'markdown-importer',\n    NoteComposer: 'note-composer',\n    OutgoingLink: 'outgoing-link',\n    Outline: 'outline',\n    PagePreview: 'page-preview',\n    Properties: 'properties',\n    Publish: 'publish',\n    RandomNote: 'random-note',\n    SlashCommand: 'slash-command',\n    Slides: 'slides',\n    Switcher: 'switcher',\n    Sync: 'sync',\n    TagPane: 'tag-pane',\n    Templates: 'templates',\n    WordCount: 'word-count',\n    Workspaces: 'workspaces',\n    ZkPrefixer: 'zk-prefixer'\n} as const;\n", "import {\n    TFile,\n    type Vault\n} from 'obsidian';\n\ntype TFileConstructor = new(vault: Vault, path: string) => TFile;\n\n/**\n * Constructs a new TFile instance.\n *\n * @param vault - The vault to which the file belongs.\n * @param path - The path of the file.\n * @returns The constructed TFile instance.\n */\nexport function constructTFile(vault: Vault, path: string): TFile {\n    return new (TFile as TFileConstructor)(vault, path);\n}\n", "import {\n    TFile,\n    type Vault\n} from 'obsidian';\nimport { constructTFile } from './Constructors/constructTFile.ts';\nimport { createTFolderInstance } from './createTFolderInstance.ts';\nimport { parentFolderPath } from './PathUtils.ts';\n\n/**\n * Creates and properly initializes the instance of TFile even the underlying file does not exist.\n * This doesn't create the missing file on the file system.\n */\nexport function createTFileInstance(vault: Vault, path: string): TFile {\n    let file = vault.getFileByPath(path);\n    if (file) {\n        return file;\n    }\n\n    file = constructTFile(vault, path);\n    file.parent = createTFolderInstance(vault, parentFolderPath(path));\n    file.deleted = true;\n    return file;\n}\n", "import type {\n    Reference,\n    ReferenceCache\n} from 'obsidian';\n\nexport function isReferenceCache(reference: Reference): reference is ReferenceCache {\n    return !!(reference as Partial<ReferenceCache>).position;\n}\n", "import type {\n    EmbedCache,\n    Reference\n} from 'obsidian';\nimport { isReferenceCache } from './isReferenceCache.ts';\n\nexport function isEmbedCache(reference: Reference): reference is EmbedCache {\n    return isReferenceCache(reference) && reference.original[0] === '!';\n}\n", "import type {\n    FrontmatterLinkCache,\n    Reference\n} from 'obsidian';\n\nexport function isFrontmatterLinkCache(reference: Reference): reference is FrontmatterLinkCache {\n    return !!(reference as Partial<FrontmatterLinkCache>).key;\n}\n", "import type {\n    LinkCache,\n    Reference\n} from 'obsidian';\nimport { isReferenceCache } from './isReferenceCache.ts';\n\nexport function isLinkCache(reference: Reference): reference is LinkCache {\n    return isReferenceCache(reference) && reference.original[0] !== '!';\n}\n", "import type { App } from 'obsidian';\nimport type { InternalPlugins } from '../../internals/InternalPlugin/InternalPlugins.js';\n\ntype InternalPluginsConstructor = new(app: App) => InternalPlugins;\n\n/**\n * Constructs a new InternalPlugins instance.\n *\n * @param app - The app instance.\n * @returns The constructed InternalPlugins instance.\n */\nexport function constructInternalPlugins(app: App): InternalPlugins {\n    return new (app.internalPlugins.constructor as InternalPluginsConstructor)(app);\n}\n", "import type { App } from 'obsidian';\nimport type { InternalPlugin } from '../../internals/InternalPlugin/InternalPlugin.js';\nimport type { InternalPlugins } from '../../internals/InternalPlugin/InternalPlugins.js';\n\ntype InternalPluginConstructor<Instance> = new(\n    app: App,\n    instance: Instance,\n    internalPlugins: InternalPlugins\n) => InternalPlugin<Instance>;\n\n/**\n * Constructs a new InternalPlugin instance.\n *\n * @param app - The app instance.\n * @param instance - The instance of the plugin.\n * @param internalPlugins - The internal plugins instance.\n * @returns The constructed InternalPlugin instance.\n */\nexport function constructInternalPlugin<Instance>(\n    app: App,\n    instance: Instance,\n    internalPlugins: InternalPlugins\n): InternalPlugin<Instance> {\n    const anyPlugin = Object.values(app.internalPlugins.plugins)[0];\n    if (!anyPlugin) {\n        throw new Error('No internal plugin found');\n    }\n    return new (anyPlugin.constructor as InternalPluginConstructor<Instance>)(app, instance, internalPlugins);\n}\n", "import {\n    App,\n    type DataAdapter\n} from 'obsidian';\n\ntype AppConstructor = new(adapter: DataAdapter, appId: string) => App;\n\n/**\n * Constructs a new App instance.\n *\n * @param adapter - The data adapter to use.\n * @param appId - The ID of the app.\n * @returns The constructed App instance.\n */\nexport function constructApp(adapter: DataAdapter, appId: string): App {\n    return new (App as AppConstructor)(adapter, appId);\n}\n"],
  "mappings": "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",
  "names": ["import_obsidian", "import_obsidian"]
}

203
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/obsidian/implementations/index.ts", "../src/obsidian/implementations/TypeGuards/isReferenceCache.ts", "../src/obsidian/implementations/TypeGuards/isEmbedCache.ts", "../src/obsidian/implementations/TypeGuards/isFrontmatterLinkCache.ts", "../src/obsidian/implementations/TypeGuards/isLinkCache.ts", "../src/obsidian/implementations/Constructors/constructTFolder.ts", "../src/obsidian/implementations/Constructors/constructInternalPlugins.ts", "../src/obsidian/implementations/Constructors/constructInternalPlugin.ts", "../src/obsidian/implementations/Constructors/constructApp.ts", "../src/obsidian/implementations/Constructors/constructTFile.ts", "../src/obsidian/implementations/PathUtils.ts", "../src/obsidian/implementations/createTFolderInstance.ts", "../src/obsidian/implementations/CustomArrayDictImpl.ts", "../src/obsidian/implementations/InternalPluginName.ts", "../src/obsidian/implementations/createTFileInstance.ts"],
  "sourcesContent": ["/* THIS IS A GENERATED/BUNDLED FILE BY BUILD SCRIPT */\n\nexport * from './TypeGuards/isEmbedCache.js';\nexport * from './TypeGuards/isFrontmatterLinkCache.js';\nexport * from './TypeGuards/isReferenceCache.js';\nexport * from './TypeGuards/isLinkCache.js';\nexport * from './Constructors/constructTFolder.js';\nexport * from './Constructors/constructInternalPlugins.js';\nexport * from './Constructors/constructInternalPlugin.js';\nexport * from './Constructors/constructApp.js';\nexport * from './Constructors/constructTFile.js';\nexport * from './PathUtils.js';\nexport * from './createTFolderInstance.js';\nexport * from './CustomArrayDictImpl.js';\nexport * from './InternalPluginName.js';\nexport * from './createTFileInstance.js';\nimport '../../index.js';\n", "import type {\n    Reference,\n    ReferenceCache\n} from 'obsidian';\n\nexport function isReferenceCache(reference: Reference): reference is ReferenceCache {\n    return !!(reference as Partial<ReferenceCache>).position;\n}\n", "import type {\n    EmbedCache,\n    Reference\n} from 'obsidian';\nimport { isReferenceCache } from './isReferenceCache.ts';\n\nexport function isEmbedCache(reference: Reference): reference is EmbedCache {\n    return isReferenceCache(reference) && reference.original[0] === '!';\n}\n", "import type {\n    FrontmatterLinkCache,\n    Reference\n} from 'obsidian';\n\nexport function isFrontmatterLinkCache(reference: Reference): reference is FrontmatterLinkCache {\n    return !!(reference as Partial<FrontmatterLinkCache>).key;\n}\n", "import type {\n    LinkCache,\n    Reference\n} from 'obsidian';\nimport { isReferenceCache } from './isReferenceCache.ts';\n\nexport function isLinkCache(reference: Reference): reference is LinkCache {\n    return isReferenceCache(reference) && reference.original[0] !== '!';\n}\n", "import {\n    TFolder,\n    type Vault\n} from 'obsidian';\n\ntype TFolderConstructor = new(vault: Vault, path: string) => TFolder;\n\n/**\n * Constructs a new TFolder instance.\n *\n * @param vault - The vault to which the folder belongs.\n * @param path - The path of the folder.\n * @returns The constructed TFolder instance.\n */\nexport function constructTFolder(vault: Vault, path: string): TFolder {\n    return new (TFolder as TFolderConstructor)(vault, path);\n}\n", "import type { App } from 'obsidian';\nimport type { InternalPlugins } from '../../internals/InternalPlugin/InternalPlugins.js';\n\ntype InternalPluginsConstructor = new(app: App) => InternalPlugins;\n\n/**\n * Constructs a new InternalPlugins instance.\n *\n * @param app - The app instance.\n * @returns The constructed InternalPlugins instance.\n */\nexport function constructInternalPlugins(app: App): InternalPlugins {\n    return new (app.internalPlugins.constructor as InternalPluginsConstructor)(app);\n}\n", "import type { App } from 'obsidian';\nimport type { InternalPlugin } from '../../internals/InternalPlugin/InternalPlugin.js';\nimport type { InternalPlugins } from '../../internals/InternalPlugin/InternalPlugins.js';\n\ntype InternalPluginConstructor<Instance> = new(\n    app: App,\n    instance: Instance,\n    internalPlugins: InternalPlugins\n) => InternalPlugin<Instance>;\n\n/**\n * Constructs a new InternalPlugin instance.\n *\n * @param app - The app instance.\n * @param instance - The instance of the plugin.\n * @param internalPlugins - The internal plugins instance.\n * @returns The constructed InternalPlugin instance.\n */\nexport function constructInternalPlugin<Instance>(\n    app: App,\n    instance: Instance,\n    internalPlugins: InternalPlugins\n): InternalPlugin<Instance> {\n    const anyPlugin = Object.values(app.internalPlugins.plugins)[0];\n    if (!anyPlugin) {\n        throw new Error('No internal plugin found');\n    }\n    return new (anyPlugin.constructor as InternalPluginConstructor<Instance>)(app, instance, internalPlugins);\n}\n", "import {\n    App,\n    type DataAdapter\n} from 'obsidian';\n\ntype AppConstructor = new(adapter: DataAdapter, appId: string) => App;\n\n/**\n * Constructs a new App instance.\n *\n * @param adapter - The data adapter to use.\n * @param appId - The ID of the app.\n * @returns The constructed App instance.\n */\nexport function constructApp(adapter: DataAdapter, appId: string): App {\n    return new (App as AppConstructor)(adapter, appId);\n}\n", "import {\n    TFile,\n    type Vault\n} from 'obsidian';\n\ntype TFileConstructor = new(vault: Vault, path: string) => TFile;\n\n/**\n * Constructs a new TFile instance.\n *\n * @param vault - The vault to which the file belongs.\n * @param path - The path of the file.\n * @returns The constructed TFile instance.\n */\nexport function constructTFile(vault: Vault, path: string): TFile {\n    return new (TFile as TFileConstructor)(vault, path);\n}\n", "export function parentFolderPath(path: string): string {\n    return path.replace(/\\/?[^\\/]*$/, '') || '/';\n}\n", "import {\n    TFolder,\n    type Vault\n} from 'obsidian';\nimport { constructTFolder } from './Constructors/constructTFolder.ts';\nimport { parentFolderPath } from './PathUtils.ts';\n\n/**\n * Creates and properly initializes the instance of TFolder even the underlying folder does not exist.\n * This doesn't create the missing folder on the file system.\n */\nexport function createTFolderInstance(vault: Vault, path: string): TFolder {\n    let folder = vault.getFolderByPath(path);\n    if (folder) {\n        return folder;\n    }\n\n    folder = constructTFolder(vault, path);\n    folder.parent = createTFolderInstance(vault, parentFolderPath(path));\n    folder.deleted = true;\n    return folder;\n}\n", "import type { CustomArrayDict } from '../internals/CustomArrayDict.js';\n\nexport class CustomArrayDictImpl<T> implements CustomArrayDict<T> {\n    public data: Map<string, T[]> = new Map();\n\n    public add(key: string, value: T): void {\n        let values = this.get(key);\n        if (!values) {\n            values = [];\n            this.data.set(key, values);\n        }\n\n        if (!values.includes(value)) {\n            values.push(value);\n        }\n    }\n\n    public remove(key: string, value: T): void {\n        const values = this.get(key);\n        if (!values) {\n            return;\n        }\n        values.remove(value);\n\n        if (values.length === 0) {\n            this.clear(key);\n        }\n    }\n\n    public get(key: string): T[] | null {\n        return this.data.get(key) || null;\n    }\n\n    public keys(): string[] {\n        return Array.from(this.data.keys());\n    }\n\n    public clear(key: string): void {\n        this.data.delete(key);\n    }\n\n    public clearAll(): void {\n        this.data.clear();\n    }\n\n    public contains(key: string, value: T): boolean {\n        return !!this.get(key)?.contains(value);\n    }\n\n    public count(): number {\n        let ans = 0;\n        for (const key in this.keys()) {\n            ans += this.get(key)?.length ?? 0;\n        }\n\n        return ans;\n    }\n}\n", "export const InternalPluginName = {\n    AudioRecorder: 'audio-recorder',\n    Backlink: 'backlink',\n    Bookmarks: 'bookmarks',\n    Canvas: 'canvas',\n    CommandPalette: 'command-palette',\n    DailyNotes: 'daily-notes',\n    EditorStatus: 'editor-status',\n    FileExplorer: 'file-explorer',\n    FileRecovery: 'file-recovery',\n    GlobalSearch: 'global-search',\n    Graph: 'graph',\n    MarkdownImporter: 'markdown-importer',\n    NoteComposer: 'note-composer',\n    OutgoingLink: 'outgoing-link',\n    Outline: 'outline',\n    PagePreview: 'page-preview',\n    Properties: 'properties',\n    Publish: 'publish',\n    RandomNote: 'random-note',\n    SlashCommand: 'slash-command',\n    Slides: 'slides',\n    Switcher: 'switcher',\n    Sync: 'sync',\n    TagPane: 'tag-pane',\n    Templates: 'templates',\n    WordCount: 'word-count',\n    Workspaces: 'workspaces',\n    ZkPrefixer: 'zk-prefixer'\n} as const;\n", "import {\n    TFile,\n    type Vault\n} from 'obsidian';\nimport { constructTFile } from './Constructors/constructTFile.ts';\nimport { createTFolderInstance } from './createTFolderInstance.ts';\nimport { parentFolderPath } from './PathUtils.ts';\n\n/**\n * Creates and properly initializes the instance of TFile even the underlying file does not exist.\n * This doesn't create the missing file on the file system.\n */\nexport function createTFileInstance(vault: Vault, path: string): TFile {\n    let file = vault.getFileByPath(path);\n    if (file) {\n        return file;\n    }\n\n    file = constructTFile(vault, path);\n    file.parent = createTFolderInstance(vault, parentFolderPath(path));\n    file.deleted = true;\n    return file;\n}\n"],
  "mappings": "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",
  "names": ["import_obsidian", "import_obsidian"]
}

@@ -4,73 +4,8 @@ import { Extension } from '@codemirror/state';
4
4
  import { EditorView, ViewUpdate } from '@codemirror/view';
5
5
  import { App, CachedMetadata, CloseableComponent, Command, Component, DataAdapter, Debouncer, Editor, EditorPosition, EditorRange, EditorSuggest, EmbedCache, Events, FileStats, FileView, FrontmatterLinkCache, HoverLinkSource, HoverPopover, IconName, ItemView, KeymapInfo, LinkCache, Loc, MarkdownFileInfo, MarkdownView, Menu, Modal, PaneType, Plugin as Plugin$1, PluginManifest, PluginSettingTab, Reference, ReferenceCache, Scope, SearchComponent, SearchResult, SettingTab, SplitDirection, TAbstractFile, TFile, TFolder, TextFileView, Vault, View, ViewCreator, ViewState, Workspace, WorkspaceLeaf, WorkspaceTabs } from 'obsidian';
6
6
 
7
- export declare function parentFolderPath(path: string): string;
8
7
  export type StyleModule = {};
9
8
  export type StyleSpec = {};
10
- /**
11
- * Creates and properly initializes the instance of TFolder even the underlying folder does not exist.
12
- * This doesn't create the missing folder on the file system.
13
- */
14
- export declare function createTFolderInstance(vault: Vault, path: string): TFolder;
15
- /** @todo Documentation incomplete */
16
- /** @public */
17
- export interface CustomArrayDict<T> {
18
- data: Map<string, T[]>;
19
- add(key: string, value: T): void;
20
- clear(key: string): void;
21
- clearAll(): void;
22
- contains(key: string, value: T): boolean;
23
- count(): number;
24
- get(key: string): T[] | null;
25
- keys(): string[];
26
- remove(key: string, value: T): void;
27
- }
28
- export declare class CustomArrayDictImpl<T> implements CustomArrayDict<T> {
29
- data: Map<string, T[]>;
30
- add(key: string, value: T): void;
31
- remove(key: string, value: T): void;
32
- get(key: string): T[] | null;
33
- keys(): string[];
34
- clear(key: string): void;
35
- clearAll(): void;
36
- contains(key: string, value: T): boolean;
37
- count(): number;
38
- }
39
- export declare const InternalPluginName: {
40
- readonly AudioRecorder: "audio-recorder";
41
- readonly Backlink: "backlink";
42
- readonly Bookmarks: "bookmarks";
43
- readonly Canvas: "canvas";
44
- readonly CommandPalette: "command-palette";
45
- readonly DailyNotes: "daily-notes";
46
- readonly EditorStatus: "editor-status";
47
- readonly FileExplorer: "file-explorer";
48
- readonly FileRecovery: "file-recovery";
49
- readonly GlobalSearch: "global-search";
50
- readonly Graph: "graph";
51
- readonly MarkdownImporter: "markdown-importer";
52
- readonly NoteComposer: "note-composer";
53
- readonly OutgoingLink: "outgoing-link";
54
- readonly Outline: "outline";
55
- readonly PagePreview: "page-preview";
56
- readonly Properties: "properties";
57
- readonly Publish: "publish";
58
- readonly RandomNote: "random-note";
59
- readonly SlashCommand: "slash-command";
60
- readonly Slides: "slides";
61
- readonly Switcher: "switcher";
62
- readonly Sync: "sync";
63
- readonly TagPane: "tag-pane";
64
- readonly Templates: "templates";
65
- readonly WordCount: "word-count";
66
- readonly Workspaces: "workspaces";
67
- readonly ZkPrefixer: "zk-prefixer";
68
- };
69
- /**
70
- * Creates and properly initializes the instance of TFile even the underlying file does not exist.
71
- * This doesn't create the missing file on the file system.
72
- */
73
- export declare function createTFileInstance(vault: Vault, path: string): TFile;
74
9
  export declare function isEmbedCache(reference: Reference): reference is EmbedCache;
75
10
  export declare function isFrontmatterLinkCache(reference: Reference): reference is FrontmatterLinkCache;
76
11
  export declare function isReferenceCache(reference: Reference): reference is ReferenceCache;
@@ -164,6 +99,9 @@ export interface InfoFileView extends FileView {
164
99
  /** @todo Documentation incomplete */
165
100
  /** @public */
166
101
  export interface BacklinkView extends InfoFileView {
102
+ backlink: {
103
+ recomputeBacklink: (backlinkFile: TFile) => void;
104
+ };
167
105
  /**
168
106
  * Get the current view type
169
107
  */
@@ -464,7 +402,7 @@ export interface GraphPluginInstance extends InternalPluginInstance<GraphPlugin>
464
402
  defaultOn: boolean;
465
403
  plugin: GraphPlugin;
466
404
  }
467
- declare const InternalPluginName$1: {
405
+ declare const InternalPluginName: {
468
406
  readonly AudioRecorder: "audio-recorder";
469
407
  readonly Backlink: "backlink";
470
408
  readonly Bookmarks: "bookmarks";
@@ -635,68 +573,68 @@ export interface ZkPrefixerPluginInstance extends InternalPluginInstance<ZkPrefi
635
573
  }
636
574
  /** @public */
637
575
  export type InternalPluginNameInstancesMapping = {
638
- [InternalPluginName$1.AudioRecorder]: AudioRecorderPluginInstance;
639
- [InternalPluginName$1.Backlink]: BacklinkPluginInstance;
640
- [InternalPluginName$1.Bookmarks]: BookmarksPluginInstance;
641
- [InternalPluginName$1.Canvas]: CanvasPluginInstance;
642
- [InternalPluginName$1.CommandPalette]: CommandPalettePluginInstance;
643
- [InternalPluginName$1.DailyNotes]: DailyNotesPluginInstance;
644
- [InternalPluginName$1.EditorStatus]: EditorStatusPluginInstance;
645
- [InternalPluginName$1.FileExplorer]: FileExplorerPluginInstance;
646
- [InternalPluginName$1.FileRecovery]: FileRecoveryPluginInstance;
647
- [InternalPluginName$1.GlobalSearch]: GlobalSearchPluginInstance;
648
- [InternalPluginName$1.Graph]: GraphPluginInstance;
649
- [InternalPluginName$1.MarkdownImporter]: MarkdownImporterPluginInstance;
650
- [InternalPluginName$1.NoteComposer]: NoteComposerPluginInstance;
651
- [InternalPluginName$1.OutgoingLink]: OutgoingLinkPluginInstance;
652
- [InternalPluginName$1.Outline]: OutlinePluginInstance;
653
- [InternalPluginName$1.PagePreview]: PagePreviewPluginInstance;
654
- [InternalPluginName$1.Properties]: PropertiesPluginInstance;
655
- [InternalPluginName$1.Publish]: PublishPluginInstance;
656
- [InternalPluginName$1.RandomNote]: RandomNotePluginInstance;
657
- [InternalPluginName$1.SlashCommand]: SlashCommandPluginInstance;
658
- [InternalPluginName$1.Slides]: SlidesPluginInstance;
659
- [InternalPluginName$1.Switcher]: SwitcherPluginInstance;
660
- [InternalPluginName$1.Sync]: SyncPluginInstance;
661
- [InternalPluginName$1.TagPane]: TagPanePluginInstance;
662
- [InternalPluginName$1.Templates]: TemplatesPluginInstance;
663
- [InternalPluginName$1.WordCount]: WordCountPluginInstance;
664
- [InternalPluginName$1.Workspaces]: WorkspacesPluginInstance;
665
- [InternalPluginName$1.ZkPrefixer]: ZkPrefixerPluginInstance;
576
+ [InternalPluginName.AudioRecorder]: AudioRecorderPluginInstance;
577
+ [InternalPluginName.Backlink]: BacklinkPluginInstance;
578
+ [InternalPluginName.Bookmarks]: BookmarksPluginInstance;
579
+ [InternalPluginName.Canvas]: CanvasPluginInstance;
580
+ [InternalPluginName.CommandPalette]: CommandPalettePluginInstance;
581
+ [InternalPluginName.DailyNotes]: DailyNotesPluginInstance;
582
+ [InternalPluginName.EditorStatus]: EditorStatusPluginInstance;
583
+ [InternalPluginName.FileExplorer]: FileExplorerPluginInstance;
584
+ [InternalPluginName.FileRecovery]: FileRecoveryPluginInstance;
585
+ [InternalPluginName.GlobalSearch]: GlobalSearchPluginInstance;
586
+ [InternalPluginName.Graph]: GraphPluginInstance;
587
+ [InternalPluginName.MarkdownImporter]: MarkdownImporterPluginInstance;
588
+ [InternalPluginName.NoteComposer]: NoteComposerPluginInstance;
589
+ [InternalPluginName.OutgoingLink]: OutgoingLinkPluginInstance;
590
+ [InternalPluginName.Outline]: OutlinePluginInstance;
591
+ [InternalPluginName.PagePreview]: PagePreviewPluginInstance;
592
+ [InternalPluginName.Properties]: PropertiesPluginInstance;
593
+ [InternalPluginName.Publish]: PublishPluginInstance;
594
+ [InternalPluginName.RandomNote]: RandomNotePluginInstance;
595
+ [InternalPluginName.SlashCommand]: SlashCommandPluginInstance;
596
+ [InternalPluginName.Slides]: SlidesPluginInstance;
597
+ [InternalPluginName.Switcher]: SwitcherPluginInstance;
598
+ [InternalPluginName.Sync]: SyncPluginInstance;
599
+ [InternalPluginName.TagPane]: TagPanePluginInstance;
600
+ [InternalPluginName.Templates]: TemplatesPluginInstance;
601
+ [InternalPluginName.WordCount]: WordCountPluginInstance;
602
+ [InternalPluginName.Workspaces]: WorkspacesPluginInstance;
603
+ [InternalPluginName.ZkPrefixer]: ZkPrefixerPluginInstance;
666
604
  };
667
605
  /** @public */
668
606
  export type InternalPluginNamePluginsMapping = {
669
- [InternalPluginName$1.AudioRecorder]: AudioRecorderPlugin;
670
- [InternalPluginName$1.Backlink]: BacklinkPlugin;
671
- [InternalPluginName$1.Bookmarks]: BookmarksPlugin;
672
- [InternalPluginName$1.Canvas]: CanvasPlugin;
673
- [InternalPluginName$1.CommandPalette]: CommandPalettePlugin;
674
- [InternalPluginName$1.DailyNotes]: DailyNotesPlugin;
675
- [InternalPluginName$1.EditorStatus]: EditorStatusPlugin;
676
- [InternalPluginName$1.FileExplorer]: FileExplorerPlugin;
677
- [InternalPluginName$1.FileRecovery]: FileRecoveryPlugin;
678
- [InternalPluginName$1.GlobalSearch]: GlobalSearchPlugin;
679
- [InternalPluginName$1.Graph]: GraphPlugin;
680
- [InternalPluginName$1.MarkdownImporter]: MarkdownImporterPlugin;
681
- [InternalPluginName$1.NoteComposer]: NoteComposerPlugin;
682
- [InternalPluginName$1.OutgoingLink]: OutgoingLinkPlugin;
683
- [InternalPluginName$1.Outline]: OutlinePlugin;
684
- [InternalPluginName$1.PagePreview]: PagePreviewPlugin;
685
- [InternalPluginName$1.Properties]: PropertiesPlugin;
686
- [InternalPluginName$1.Publish]: PublishPlugin;
687
- [InternalPluginName$1.RandomNote]: RandomNotePlugin;
688
- [InternalPluginName$1.SlashCommand]: SlashCommandPlugin;
689
- [InternalPluginName$1.Slides]: SlidesPlugin;
690
- [InternalPluginName$1.Switcher]: SwitcherPlugin;
691
- [InternalPluginName$1.Sync]: SyncPlugin;
692
- [InternalPluginName$1.TagPane]: TagPanePlugin;
693
- [InternalPluginName$1.Templates]: TemplatesPlugin;
694
- [InternalPluginName$1.WordCount]: WordCountPlugin;
695
- [InternalPluginName$1.Workspaces]: WorkspacesPlugin;
696
- [InternalPluginName$1.ZkPrefixer]: ZkPrefixerPlugin;
607
+ [InternalPluginName.AudioRecorder]: AudioRecorderPlugin;
608
+ [InternalPluginName.Backlink]: BacklinkPlugin;
609
+ [InternalPluginName.Bookmarks]: BookmarksPlugin;
610
+ [InternalPluginName.Canvas]: CanvasPlugin;
611
+ [InternalPluginName.CommandPalette]: CommandPalettePlugin;
612
+ [InternalPluginName.DailyNotes]: DailyNotesPlugin;
613
+ [InternalPluginName.EditorStatus]: EditorStatusPlugin;
614
+ [InternalPluginName.FileExplorer]: FileExplorerPlugin;
615
+ [InternalPluginName.FileRecovery]: FileRecoveryPlugin;
616
+ [InternalPluginName.GlobalSearch]: GlobalSearchPlugin;
617
+ [InternalPluginName.Graph]: GraphPlugin;
618
+ [InternalPluginName.MarkdownImporter]: MarkdownImporterPlugin;
619
+ [InternalPluginName.NoteComposer]: NoteComposerPlugin;
620
+ [InternalPluginName.OutgoingLink]: OutgoingLinkPlugin;
621
+ [InternalPluginName.Outline]: OutlinePlugin;
622
+ [InternalPluginName.PagePreview]: PagePreviewPlugin;
623
+ [InternalPluginName.Properties]: PropertiesPlugin;
624
+ [InternalPluginName.Publish]: PublishPlugin;
625
+ [InternalPluginName.RandomNote]: RandomNotePlugin;
626
+ [InternalPluginName.SlashCommand]: SlashCommandPlugin;
627
+ [InternalPluginName.Slides]: SlidesPlugin;
628
+ [InternalPluginName.Switcher]: SwitcherPlugin;
629
+ [InternalPluginName.Sync]: SyncPlugin;
630
+ [InternalPluginName.TagPane]: TagPanePlugin;
631
+ [InternalPluginName.Templates]: TemplatesPlugin;
632
+ [InternalPluginName.WordCount]: WordCountPlugin;
633
+ [InternalPluginName.Workspaces]: WorkspacesPlugin;
634
+ [InternalPluginName.ZkPrefixer]: ZkPrefixerPlugin;
697
635
  };
698
636
  /** @public */
699
- export type InternalPluginNameType = (typeof InternalPluginName$1)[keyof typeof InternalPluginName$1];
637
+ export type InternalPluginNameType = (typeof InternalPluginName)[keyof typeof InternalPluginName];
700
638
  /** @public */
701
639
  export interface InternalPluginsConfigRecord extends Record<InternalPluginNameType, boolean> {
702
640
  }
@@ -778,6 +716,71 @@ export declare function constructApp(adapter: DataAdapter, appId: string): App;
778
716
  * @returns The constructed TFile instance.
779
717
  */
780
718
  export declare function constructTFile(vault: Vault, path: string): TFile;
719
+ export declare function parentFolderPath(path: string): string;
720
+ /**
721
+ * Creates and properly initializes the instance of TFolder even the underlying folder does not exist.
722
+ * This doesn't create the missing folder on the file system.
723
+ */
724
+ export declare function createTFolderInstance(vault: Vault, path: string): TFolder;
725
+ /** @todo Documentation incomplete */
726
+ /** @public */
727
+ export interface CustomArrayDict<T> {
728
+ data: Map<string, T[]>;
729
+ add(key: string, value: T): void;
730
+ clear(key: string): void;
731
+ clearAll(): void;
732
+ contains(key: string, value: T): boolean;
733
+ count(): number;
734
+ get(key: string): T[] | null;
735
+ keys(): string[];
736
+ remove(key: string, value: T): void;
737
+ }
738
+ export declare class CustomArrayDictImpl<T> implements CustomArrayDict<T> {
739
+ data: Map<string, T[]>;
740
+ add(key: string, value: T): void;
741
+ remove(key: string, value: T): void;
742
+ get(key: string): T[] | null;
743
+ keys(): string[];
744
+ clear(key: string): void;
745
+ clearAll(): void;
746
+ contains(key: string, value: T): boolean;
747
+ count(): number;
748
+ }
749
+ declare const InternalPluginName$1: {
750
+ readonly AudioRecorder: "audio-recorder";
751
+ readonly Backlink: "backlink";
752
+ readonly Bookmarks: "bookmarks";
753
+ readonly Canvas: "canvas";
754
+ readonly CommandPalette: "command-palette";
755
+ readonly DailyNotes: "daily-notes";
756
+ readonly EditorStatus: "editor-status";
757
+ readonly FileExplorer: "file-explorer";
758
+ readonly FileRecovery: "file-recovery";
759
+ readonly GlobalSearch: "global-search";
760
+ readonly Graph: "graph";
761
+ readonly MarkdownImporter: "markdown-importer";
762
+ readonly NoteComposer: "note-composer";
763
+ readonly OutgoingLink: "outgoing-link";
764
+ readonly Outline: "outline";
765
+ readonly PagePreview: "page-preview";
766
+ readonly Properties: "properties";
767
+ readonly Publish: "publish";
768
+ readonly RandomNote: "random-note";
769
+ readonly SlashCommand: "slash-command";
770
+ readonly Slides: "slides";
771
+ readonly Switcher: "switcher";
772
+ readonly Sync: "sync";
773
+ readonly TagPane: "tag-pane";
774
+ readonly Templates: "templates";
775
+ readonly WordCount: "word-count";
776
+ readonly Workspaces: "workspaces";
777
+ readonly ZkPrefixer: "zk-prefixer";
778
+ };
779
+ /**
780
+ * Creates and properly initializes the instance of TFile even the underlying file does not exist.
781
+ * This doesn't create the missing file on the file system.
782
+ */
783
+ export declare function createTFileInstance(vault: Vault, path: string): TFile;
781
784
  /** @public */
782
785
  export interface EditorViewState {
783
786
  printing: boolean;
@@ -3896,4 +3899,8 @@ export interface SerializedWorkspaceSidedock extends SerializedWorkspaceItem {
3896
3899
  width: number;
3897
3900
  }
3898
3901
 
3902
+ export {
3903
+ InternalPluginName$1 as InternalPluginName,
3904
+ };
3905
+
3899
3906
  export {};
@@ -5068,6 +5068,42 @@
5068
5068
  "name": "BacklinkView",
5069
5069
  "preserveMemberOrder": false,
5070
5070
  "members": [
5071
+ {
5072
+ "kind": "PropertySignature",
5073
+ "canonicalReference": "obsidian-typings!BacklinkView#backlink:member",
5074
+ "docComment": "",
5075
+ "excerptTokens": [
5076
+ {
5077
+ "kind": "Content",
5078
+ "text": "backlink: "
5079
+ },
5080
+ {
5081
+ "kind": "Content",
5082
+ "text": "{\n recomputeBacklink: (backlinkFile: "
5083
+ },
5084
+ {
5085
+ "kind": "Reference",
5086
+ "text": "TFile",
5087
+ "canonicalReference": "obsidian!TFile:class"
5088
+ },
5089
+ {
5090
+ "kind": "Content",
5091
+ "text": ") => void;\n }"
5092
+ },
5093
+ {
5094
+ "kind": "Content",
5095
+ "text": ";"
5096
+ }
5097
+ ],
5098
+ "isReadonly": false,
5099
+ "isOptional": false,
5100
+ "releaseTag": "Public",
5101
+ "name": "backlink",
5102
+ "propertyTypeTokenRange": {
5103
+ "startIndex": 1,
5104
+ "endIndex": 4
5105
+ }
5106
+ },
5071
5107
  {
5072
5108
  "kind": "MethodSignature",
5073
5109
  "canonicalReference": "obsidian-typings!BacklinkView#getViewType:member(1)",
package/dist/types.d.ts CHANGED
@@ -1541,6 +1541,9 @@ export interface InfoFileView extends FileView {
1541
1541
  /** @todo Documentation incomplete */
1542
1542
  /** @public */
1543
1543
  export interface BacklinkView extends InfoFileView {
1544
+ backlink: {
1545
+ recomputeBacklink: (backlinkFile: TFile) => void;
1546
+ };
1544
1547
  /**
1545
1548
  * Get the current view type
1546
1549
  */
@@ -6250,7 +6253,7 @@ declare module "obsidian" {
6250
6253
  /** @internal Update file cache entry and sync to indexedDB */
6251
6254
  saveFileCache(path: string, entry: FileCacheEntry): void;
6252
6255
  /** @internal Update metadata cache entry and sync to indexedDB */
6253
- saveMetaCache(path: string, entry: CachedMetadata): void;
6256
+ saveMetaCache(hash: string, entry: CachedMetadata): void;
6254
6257
  /** @internal Show a notice that the cache is being rebuilt */
6255
6258
  showIndexingNotice(): void;
6256
6259
  /** @internal Re-resolve all links for changed path */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "obsidian-typings",
3
- "version": "2.3.4",
3
+ "version": "2.4.0",
4
4
  "description": "Extended type definitions for the Obsidian API (https://obsidian.md)",
5
5
  "main": "",
6
6
  "module": "",