obsidian-typings 2.3.3 → 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;
@@ -2028,7 +2031,7 @@ export interface PropertyWidget<T> {
2028
2031
  * @todo Documentation incomplete
2029
2032
  */
2030
2033
  /** @public */
2031
- export type PropertyWidgetType = "aliases" | "checkbox" | "date" | "datetime" | "multitext" | "number" | "tags" | "text" | (string & any);
2034
+ export type PropertyWidgetType = "aliases" | "checkbox" | "date" | "datetime" | "multitext" | "number" | "tags" | "text" | string;
2032
2035
  /** @public */
2033
2036
  export interface MetadataTypeManagerPropertiesRecord extends Record<string, PropertyInfo> {
2034
2037
  }
@@ -2036,7 +2039,12 @@ export interface MetadataTypeManagerPropertiesRecord extends Record<string, Prop
2036
2039
  export interface MetadataTypeManagerRegisteredTypeWidgetsRecord extends Record<PropertyWidgetType, PropertyWidget<unknown>> {
2037
2040
  }
2038
2041
  /** @public */
2039
- export interface MetadataTypeManagerTypesRecord extends Record<string, PropertyWidgetType> {
2042
+ export interface PropertyWidgetEntry {
2043
+ name: string;
2044
+ type: PropertyWidgetType;
2045
+ }
2046
+ /** @public */
2047
+ export interface MetadataTypeManagerTypesRecord extends Record<string, PropertyWidgetEntry> {
2040
2048
  }
2041
2049
  /** @public */
2042
2050
  export interface MetadataTypeManager extends Events {
@@ -3891,4 +3899,8 @@ export interface SerializedWorkspaceSidedock extends SerializedWorkspaceItem {
3891
3899
  width: number;
3892
3900
  }
3893
3901
 
3902
+ export {
3903
+ InternalPluginName$1 as InternalPluginName,
3904
+ };
3905
+
3894
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)",
@@ -45566,8 +45602,8 @@
45566
45602
  },
45567
45603
  {
45568
45604
  "kind": "Reference",
45569
- "text": "PropertyWidgetType",
45570
- "canonicalReference": "obsidian-typings!PropertyWidgetType:type"
45605
+ "text": "PropertyWidgetEntry",
45606
+ "canonicalReference": "obsidian-typings!PropertyWidgetEntry:interface"
45571
45607
  },
45572
45608
  {
45573
45609
  "kind": "Content",
@@ -50702,6 +50738,79 @@
50702
50738
  ],
50703
50739
  "extendsTokenRanges": []
50704
50740
  },
50741
+ {
50742
+ "kind": "Interface",
50743
+ "canonicalReference": "obsidian-typings!PropertyWidgetEntry:interface",
50744
+ "docComment": "/**\n * @public\n */\n",
50745
+ "excerptTokens": [
50746
+ {
50747
+ "kind": "Content",
50748
+ "text": "export interface PropertyWidgetEntry "
50749
+ }
50750
+ ],
50751
+ "fileUrlPath": "src/obsidian/internals/PropertyWidgetEntry.d.ts",
50752
+ "releaseTag": "Public",
50753
+ "name": "PropertyWidgetEntry",
50754
+ "preserveMemberOrder": false,
50755
+ "members": [
50756
+ {
50757
+ "kind": "PropertySignature",
50758
+ "canonicalReference": "obsidian-typings!PropertyWidgetEntry#name:member",
50759
+ "docComment": "",
50760
+ "excerptTokens": [
50761
+ {
50762
+ "kind": "Content",
50763
+ "text": "name: "
50764
+ },
50765
+ {
50766
+ "kind": "Content",
50767
+ "text": "string"
50768
+ },
50769
+ {
50770
+ "kind": "Content",
50771
+ "text": ";"
50772
+ }
50773
+ ],
50774
+ "isReadonly": false,
50775
+ "isOptional": false,
50776
+ "releaseTag": "Public",
50777
+ "name": "name",
50778
+ "propertyTypeTokenRange": {
50779
+ "startIndex": 1,
50780
+ "endIndex": 2
50781
+ }
50782
+ },
50783
+ {
50784
+ "kind": "PropertySignature",
50785
+ "canonicalReference": "obsidian-typings!PropertyWidgetEntry#type:member",
50786
+ "docComment": "",
50787
+ "excerptTokens": [
50788
+ {
50789
+ "kind": "Content",
50790
+ "text": "type: "
50791
+ },
50792
+ {
50793
+ "kind": "Reference",
50794
+ "text": "PropertyWidgetType",
50795
+ "canonicalReference": "obsidian-typings!PropertyWidgetType:type"
50796
+ },
50797
+ {
50798
+ "kind": "Content",
50799
+ "text": ";"
50800
+ }
50801
+ ],
50802
+ "isReadonly": false,
50803
+ "isOptional": false,
50804
+ "releaseTag": "Public",
50805
+ "name": "type",
50806
+ "propertyTypeTokenRange": {
50807
+ "startIndex": 1,
50808
+ "endIndex": 2
50809
+ }
50810
+ }
50811
+ ],
50812
+ "extendsTokenRanges": []
50813
+ },
50705
50814
  {
50706
50815
  "kind": "TypeAlias",
50707
50816
  "canonicalReference": "obsidian-typings!PropertyWidgetType:type",
@@ -50713,7 +50822,7 @@
50713
50822
  },
50714
50823
  {
50715
50824
  "kind": "Content",
50716
- "text": "| 'aliases'\n | 'checkbox'\n | 'date'\n | 'datetime'\n | 'multitext'\n | 'number'\n | 'tags'\n | 'text'\n | (string & any)"
50825
+ "text": "| 'aliases'\n | 'checkbox'\n | 'date'\n | 'datetime'\n | 'multitext'\n | 'number'\n | 'tags'\n | 'text'\n | string"
50717
50826
  },
50718
50827
  {
50719
50828
  "kind": "Content",
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
  */
@@ -2483,7 +2486,7 @@ export interface PropertyWidget<T> {
2483
2486
  * @todo Documentation incomplete
2484
2487
  */
2485
2488
  /** @public */
2486
- export type PropertyWidgetType = "aliases" | "checkbox" | "date" | "datetime" | "multitext" | "number" | "tags" | "text" | (string & any);
2489
+ export type PropertyWidgetType = "aliases" | "checkbox" | "date" | "datetime" | "multitext" | "number" | "tags" | "text" | string;
2487
2490
  /** @public */
2488
2491
  export interface MetadataTypeManagerPropertiesRecord extends Record<string, PropertyInfo> {
2489
2492
  }
@@ -2491,7 +2494,12 @@ export interface MetadataTypeManagerPropertiesRecord extends Record<string, Prop
2491
2494
  export interface MetadataTypeManagerRegisteredTypeWidgetsRecord extends Record<PropertyWidgetType, PropertyWidget<unknown>> {
2492
2495
  }
2493
2496
  /** @public */
2494
- export interface MetadataTypeManagerTypesRecord extends Record<string, PropertyWidgetType> {
2497
+ export interface PropertyWidgetEntry {
2498
+ name: string;
2499
+ type: PropertyWidgetType;
2500
+ }
2501
+ /** @public */
2502
+ export interface MetadataTypeManagerTypesRecord extends Record<string, PropertyWidgetEntry> {
2495
2503
  }
2496
2504
  /** @public */
2497
2505
  export interface MetadataTypeManager extends Events {
@@ -6245,7 +6253,7 @@ declare module "obsidian" {
6245
6253
  /** @internal Update file cache entry and sync to indexedDB */
6246
6254
  saveFileCache(path: string, entry: FileCacheEntry): void;
6247
6255
  /** @internal Update metadata cache entry and sync to indexedDB */
6248
- saveMetaCache(path: string, entry: CachedMetadata): void;
6256
+ saveMetaCache(hash: string, entry: CachedMetadata): void;
6249
6257
  /** @internal Show a notice that the cache is being rebuilt */
6250
6258
  showIndexingNotice(): void;
6251
6259
  /** @internal Re-resolve all links for changed path */
@@ -7433,11 +7441,6 @@ declare global {
7433
7441
  */
7434
7442
  var wf: typeof Object.defineProperty;
7435
7443
  }
7436
- declare global {
7437
- interface DomElementInfo {
7438
- [eventName: `on${string}`]: EventListenerOrEventListenerObject;
7439
- }
7440
- }
7441
7444
  /** @public */
7442
7445
  export interface IFramedMarkdownEditor extends MarkdownScrollableEditView {
7443
7446
  /**
@@ -7809,6 +7812,11 @@ export interface FileSuggest<T> extends EditorSuggest<T> {
7809
7812
  */
7810
7813
  suggestManager: FileSuggestManager;
7811
7814
  }
7815
+ declare global {
7816
+ interface DomElementInfo {
7817
+ [eventName: `on${string}`]: EventListenerOrEventListenerObject;
7818
+ }
7819
+ }
7812
7820
  /** @todo Documentation incomplete */
7813
7821
  /** @public */
7814
7822
  export interface FilePropertiesView extends InfoFileView {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "obsidian-typings",
3
- "version": "2.3.3",
3
+ "version": "2.4.0",
4
4
  "description": "Extended type definitions for the Obsidian API (https://obsidian.md)",
5
5
  "main": "",
6
6
  "module": "",