obsidian-typings 2.4.0 → 2.5.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,24 +41,9 @@ __export(implementations_exports, {
41
41
  });
42
42
  module.exports = __toCommonJS(implementations_exports);
43
43
 
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] !== "!";
44
+ // src/obsidian/implementations/PathUtils.ts
45
+ function parentFolderPath(path) {
46
+ return path.replace(/\/?[^\/]*$/, "") || "/";
62
47
  }
63
48
 
64
49
  // src/obsidian/implementations/Constructors/constructTFolder.ts
@@ -67,37 +52,6 @@ function constructTFolder(vault, path) {
67
52
  return new import_obsidian.TFolder(vault, path);
68
53
  }
69
54
 
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
-
101
55
  // src/obsidian/implementations/createTFolderInstance.ts
102
56
  function createTFolderInstance(vault, path) {
103
57
  let folder = vault.getFolderByPath(path);
@@ -189,6 +143,12 @@ var InternalPluginName = {
189
143
  ZkPrefixer: "zk-prefixer"
190
144
  };
191
145
 
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
+
192
152
  // src/obsidian/implementations/createTFileInstance.ts
193
153
  function createTFileInstance(vault, path) {
194
154
  let file = vault.getFileByPath(path);
@@ -200,4 +160,44 @@ function createTFileInstance(vault, path) {
200
160
  file.deleted = true;
201
161
  return file;
202
162
  }
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"]
}

163
+
164
+ // src/obsidian/implementations/Constructors/constructInternalPlugins.ts
165
+ function constructInternalPlugins(app) {
166
+ return new app.internalPlugins.constructor(app);
167
+ }
168
+
169
+ // src/obsidian/implementations/Constructors/constructInternalPlugin.ts
170
+ function constructInternalPlugin(app, instance, internalPlugins) {
171
+ const anyPlugin = Object.values(app.internalPlugins.plugins)[0];
172
+ if (!anyPlugin) {
173
+ throw new Error("No internal plugin found");
174
+ }
175
+ return new anyPlugin.constructor(app, instance, internalPlugins);
176
+ }
177
+
178
+ // src/obsidian/implementations/Constructors/constructApp.ts
179
+ var import_obsidian3 = require("obsidian");
180
+ function constructApp(adapter, appId) {
181
+ return new import_obsidian3.App(adapter, appId);
182
+ }
183
+
184
+ // src/obsidian/implementations/TypeGuards/isReferenceCache.ts
185
+ function isReferenceCache(reference) {
186
+ return !!reference.position;
187
+ }
188
+
189
+ // src/obsidian/implementations/TypeGuards/isEmbedCache.ts
190
+ function isEmbedCache(reference) {
191
+ return isReferenceCache(reference) && reference.original[0] === "!";
192
+ }
193
+
194
+ // src/obsidian/implementations/TypeGuards/isFrontmatterLinkCache.ts
195
+ function isFrontmatterLinkCache(reference) {
196
+ return !!reference.key;
197
+ }
198
+
199
+ // src/obsidian/implementations/TypeGuards/isLinkCache.ts
200
+ function isLinkCache(reference) {
201
+ return isReferenceCache(reference) && reference.original[0] !== "!";
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/Constructors/constructInternalPlugins.ts", "../src/obsidian/implementations/Constructors/constructInternalPlugin.ts", "../src/obsidian/implementations/Constructors/constructApp.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"],
  "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 './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 './TypeGuards/isEmbedCache.js';\nexport * from './TypeGuards/isFrontmatterLinkCache.js';\nexport * from './TypeGuards/isReferenceCache.js';\nexport * from './TypeGuards/isLinkCache.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 { 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 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"],
  "mappings": "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",
  "names": ["import_obsidian", "import_obsidian"]
}

@@ -4,12 +4,73 @@ 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;
7
8
  export type StyleModule = {};
8
9
  export type StyleSpec = {};
9
- export declare function isEmbedCache(reference: Reference): reference is EmbedCache;
10
- export declare function isFrontmatterLinkCache(reference: Reference): reference is FrontmatterLinkCache;
11
- export declare function isReferenceCache(reference: Reference): reference is ReferenceCache;
12
- export declare function isLinkCache(reference: Reference): reference is LinkCache;
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;
13
74
  /**
14
75
  * Constructs a new TFolder instance.
15
76
  *
@@ -67,6 +128,10 @@ export interface InternalPluginInstance<InternalPlugin> {
67
128
  description: string;
68
129
  id: string;
69
130
  name: string;
131
+ onDisable?: (app: App, plugin: InternalPlugin) => void;
132
+ onEnable?: (app: App, plugin: InternalPlugin) => Promise<void>;
133
+ onUserDisable?: (app: App) => void;
134
+ onUserEnable?: (app: App) => void;
70
135
  init(app: App, plugin: InternalPlugin): void;
71
136
  }
72
137
  /** @public */
@@ -402,7 +467,7 @@ export interface GraphPluginInstance extends InternalPluginInstance<GraphPlugin>
402
467
  defaultOn: boolean;
403
468
  plugin: GraphPlugin;
404
469
  }
405
- declare const InternalPluginName: {
470
+ declare const InternalPluginName$1: {
406
471
  readonly AudioRecorder: "audio-recorder";
407
472
  readonly Backlink: "backlink";
408
473
  readonly Bookmarks: "bookmarks";
@@ -573,68 +638,68 @@ export interface ZkPrefixerPluginInstance extends InternalPluginInstance<ZkPrefi
573
638
  }
574
639
  /** @public */
575
640
  export type InternalPluginNameInstancesMapping = {
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;
641
+ [InternalPluginName$1.AudioRecorder]: AudioRecorderPluginInstance;
642
+ [InternalPluginName$1.Backlink]: BacklinkPluginInstance;
643
+ [InternalPluginName$1.Bookmarks]: BookmarksPluginInstance;
644
+ [InternalPluginName$1.Canvas]: CanvasPluginInstance;
645
+ [InternalPluginName$1.CommandPalette]: CommandPalettePluginInstance;
646
+ [InternalPluginName$1.DailyNotes]: DailyNotesPluginInstance;
647
+ [InternalPluginName$1.EditorStatus]: EditorStatusPluginInstance;
648
+ [InternalPluginName$1.FileExplorer]: FileExplorerPluginInstance;
649
+ [InternalPluginName$1.FileRecovery]: FileRecoveryPluginInstance;
650
+ [InternalPluginName$1.GlobalSearch]: GlobalSearchPluginInstance;
651
+ [InternalPluginName$1.Graph]: GraphPluginInstance;
652
+ [InternalPluginName$1.MarkdownImporter]: MarkdownImporterPluginInstance;
653
+ [InternalPluginName$1.NoteComposer]: NoteComposerPluginInstance;
654
+ [InternalPluginName$1.OutgoingLink]: OutgoingLinkPluginInstance;
655
+ [InternalPluginName$1.Outline]: OutlinePluginInstance;
656
+ [InternalPluginName$1.PagePreview]: PagePreviewPluginInstance;
657
+ [InternalPluginName$1.Properties]: PropertiesPluginInstance;
658
+ [InternalPluginName$1.Publish]: PublishPluginInstance;
659
+ [InternalPluginName$1.RandomNote]: RandomNotePluginInstance;
660
+ [InternalPluginName$1.SlashCommand]: SlashCommandPluginInstance;
661
+ [InternalPluginName$1.Slides]: SlidesPluginInstance;
662
+ [InternalPluginName$1.Switcher]: SwitcherPluginInstance;
663
+ [InternalPluginName$1.Sync]: SyncPluginInstance;
664
+ [InternalPluginName$1.TagPane]: TagPanePluginInstance;
665
+ [InternalPluginName$1.Templates]: TemplatesPluginInstance;
666
+ [InternalPluginName$1.WordCount]: WordCountPluginInstance;
667
+ [InternalPluginName$1.Workspaces]: WorkspacesPluginInstance;
668
+ [InternalPluginName$1.ZkPrefixer]: ZkPrefixerPluginInstance;
604
669
  };
605
670
  /** @public */
606
671
  export type InternalPluginNamePluginsMapping = {
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;
672
+ [InternalPluginName$1.AudioRecorder]: AudioRecorderPlugin;
673
+ [InternalPluginName$1.Backlink]: BacklinkPlugin;
674
+ [InternalPluginName$1.Bookmarks]: BookmarksPlugin;
675
+ [InternalPluginName$1.Canvas]: CanvasPlugin;
676
+ [InternalPluginName$1.CommandPalette]: CommandPalettePlugin;
677
+ [InternalPluginName$1.DailyNotes]: DailyNotesPlugin;
678
+ [InternalPluginName$1.EditorStatus]: EditorStatusPlugin;
679
+ [InternalPluginName$1.FileExplorer]: FileExplorerPlugin;
680
+ [InternalPluginName$1.FileRecovery]: FileRecoveryPlugin;
681
+ [InternalPluginName$1.GlobalSearch]: GlobalSearchPlugin;
682
+ [InternalPluginName$1.Graph]: GraphPlugin;
683
+ [InternalPluginName$1.MarkdownImporter]: MarkdownImporterPlugin;
684
+ [InternalPluginName$1.NoteComposer]: NoteComposerPlugin;
685
+ [InternalPluginName$1.OutgoingLink]: OutgoingLinkPlugin;
686
+ [InternalPluginName$1.Outline]: OutlinePlugin;
687
+ [InternalPluginName$1.PagePreview]: PagePreviewPlugin;
688
+ [InternalPluginName$1.Properties]: PropertiesPlugin;
689
+ [InternalPluginName$1.Publish]: PublishPlugin;
690
+ [InternalPluginName$1.RandomNote]: RandomNotePlugin;
691
+ [InternalPluginName$1.SlashCommand]: SlashCommandPlugin;
692
+ [InternalPluginName$1.Slides]: SlidesPlugin;
693
+ [InternalPluginName$1.Switcher]: SwitcherPlugin;
694
+ [InternalPluginName$1.Sync]: SyncPlugin;
695
+ [InternalPluginName$1.TagPane]: TagPanePlugin;
696
+ [InternalPluginName$1.Templates]: TemplatesPlugin;
697
+ [InternalPluginName$1.WordCount]: WordCountPlugin;
698
+ [InternalPluginName$1.Workspaces]: WorkspacesPlugin;
699
+ [InternalPluginName$1.ZkPrefixer]: ZkPrefixerPlugin;
635
700
  };
636
701
  /** @public */
637
- export type InternalPluginNameType = (typeof InternalPluginName)[keyof typeof InternalPluginName];
702
+ export type InternalPluginNameType = (typeof InternalPluginName$1)[keyof typeof InternalPluginName$1];
638
703
  /** @public */
639
704
  export interface InternalPluginsConfigRecord extends Record<InternalPluginNameType, boolean> {
640
705
  }
@@ -716,71 +781,10 @@ export declare function constructApp(adapter: DataAdapter, appId: string): App;
716
781
  * @returns The constructed TFile instance.
717
782
  */
718
783
  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;
784
+ export declare function isEmbedCache(reference: Reference): reference is EmbedCache;
785
+ export declare function isFrontmatterLinkCache(reference: Reference): reference is FrontmatterLinkCache;
786
+ export declare function isReferenceCache(reference: Reference): reference is ReferenceCache;
787
+ export declare function isLinkCache(reference: Reference): reference is LinkCache;
784
788
  /** @public */
785
789
  export interface EditorViewState {
786
790
  printing: boolean;
@@ -3899,8 +3903,4 @@ export interface SerializedWorkspaceSidedock extends SerializedWorkspaceItem {
3899
3903
  width: number;
3900
3904
  }
3901
3905
 
3902
- export {
3903
- InternalPluginName$1 as InternalPluginName,
3904
- };
3905
-
3906
3906
  export {};
@@ -36726,6 +36726,159 @@
36726
36726
  "startIndex": 1,
36727
36727
  "endIndex": 2
36728
36728
  }
36729
+ },
36730
+ {
36731
+ "kind": "PropertySignature",
36732
+ "canonicalReference": "obsidian-typings!InternalPluginInstance#onDisable:member",
36733
+ "docComment": "",
36734
+ "excerptTokens": [
36735
+ {
36736
+ "kind": "Content",
36737
+ "text": "onDisable?: "
36738
+ },
36739
+ {
36740
+ "kind": "Content",
36741
+ "text": "(app: "
36742
+ },
36743
+ {
36744
+ "kind": "Reference",
36745
+ "text": "App",
36746
+ "canonicalReference": "obsidian-typings!~App"
36747
+ },
36748
+ {
36749
+ "kind": "Content",
36750
+ "text": ", plugin: InternalPlugin) => void"
36751
+ },
36752
+ {
36753
+ "kind": "Content",
36754
+ "text": ";"
36755
+ }
36756
+ ],
36757
+ "isReadonly": false,
36758
+ "isOptional": true,
36759
+ "releaseTag": "Public",
36760
+ "name": "onDisable",
36761
+ "propertyTypeTokenRange": {
36762
+ "startIndex": 1,
36763
+ "endIndex": 4
36764
+ }
36765
+ },
36766
+ {
36767
+ "kind": "PropertySignature",
36768
+ "canonicalReference": "obsidian-typings!InternalPluginInstance#onEnable:member",
36769
+ "docComment": "",
36770
+ "excerptTokens": [
36771
+ {
36772
+ "kind": "Content",
36773
+ "text": "onEnable?: "
36774
+ },
36775
+ {
36776
+ "kind": "Content",
36777
+ "text": "(app: "
36778
+ },
36779
+ {
36780
+ "kind": "Reference",
36781
+ "text": "App",
36782
+ "canonicalReference": "obsidian-typings!~App"
36783
+ },
36784
+ {
36785
+ "kind": "Content",
36786
+ "text": ", plugin: InternalPlugin) => "
36787
+ },
36788
+ {
36789
+ "kind": "Reference",
36790
+ "text": "Promise",
36791
+ "canonicalReference": "!Promise:interface"
36792
+ },
36793
+ {
36794
+ "kind": "Content",
36795
+ "text": "<void>"
36796
+ },
36797
+ {
36798
+ "kind": "Content",
36799
+ "text": ";"
36800
+ }
36801
+ ],
36802
+ "isReadonly": false,
36803
+ "isOptional": true,
36804
+ "releaseTag": "Public",
36805
+ "name": "onEnable",
36806
+ "propertyTypeTokenRange": {
36807
+ "startIndex": 1,
36808
+ "endIndex": 6
36809
+ }
36810
+ },
36811
+ {
36812
+ "kind": "PropertySignature",
36813
+ "canonicalReference": "obsidian-typings!InternalPluginInstance#onUserDisable:member",
36814
+ "docComment": "",
36815
+ "excerptTokens": [
36816
+ {
36817
+ "kind": "Content",
36818
+ "text": "onUserDisable?: "
36819
+ },
36820
+ {
36821
+ "kind": "Content",
36822
+ "text": "(app: "
36823
+ },
36824
+ {
36825
+ "kind": "Reference",
36826
+ "text": "App",
36827
+ "canonicalReference": "obsidian-typings!~App"
36828
+ },
36829
+ {
36830
+ "kind": "Content",
36831
+ "text": ") => void"
36832
+ },
36833
+ {
36834
+ "kind": "Content",
36835
+ "text": ";"
36836
+ }
36837
+ ],
36838
+ "isReadonly": false,
36839
+ "isOptional": true,
36840
+ "releaseTag": "Public",
36841
+ "name": "onUserDisable",
36842
+ "propertyTypeTokenRange": {
36843
+ "startIndex": 1,
36844
+ "endIndex": 4
36845
+ }
36846
+ },
36847
+ {
36848
+ "kind": "PropertySignature",
36849
+ "canonicalReference": "obsidian-typings!InternalPluginInstance#onUserEnable:member",
36850
+ "docComment": "",
36851
+ "excerptTokens": [
36852
+ {
36853
+ "kind": "Content",
36854
+ "text": "onUserEnable?: "
36855
+ },
36856
+ {
36857
+ "kind": "Content",
36858
+ "text": "(app: "
36859
+ },
36860
+ {
36861
+ "kind": "Reference",
36862
+ "text": "App",
36863
+ "canonicalReference": "obsidian-typings!~App"
36864
+ },
36865
+ {
36866
+ "kind": "Content",
36867
+ "text": ") => void"
36868
+ },
36869
+ {
36870
+ "kind": "Content",
36871
+ "text": ";"
36872
+ }
36873
+ ],
36874
+ "isReadonly": false,
36875
+ "isOptional": true,
36876
+ "releaseTag": "Public",
36877
+ "name": "onUserEnable",
36878
+ "propertyTypeTokenRange": {
36879
+ "startIndex": 1,
36880
+ "endIndex": 4
36881
+ }
36729
36882
  }
36730
36883
  ],
36731
36884
  "extendsTokenRanges": []
package/dist/types.d.ts CHANGED
@@ -1509,6 +1509,10 @@ export interface InternalPluginInstance<InternalPlugin> {
1509
1509
  description: string;
1510
1510
  id: string;
1511
1511
  name: string;
1512
+ onDisable?: (app: App, plugin: InternalPlugin) => void;
1513
+ onEnable?: (app: App, plugin: InternalPlugin) => Promise<void>;
1514
+ onUserDisable?: (app: App) => void;
1515
+ onUserEnable?: (app: App) => void;
1512
1516
  init(app: App, plugin: InternalPlugin): void;
1513
1517
  }
1514
1518
  /** @public */
@@ -7441,6 +7445,11 @@ declare global {
7441
7445
  */
7442
7446
  var wf: typeof Object.defineProperty;
7443
7447
  }
7448
+ declare global {
7449
+ interface DomElementInfo {
7450
+ [eventName: `on${string}`]: EventListenerOrEventListenerObject;
7451
+ }
7452
+ }
7444
7453
  /** @public */
7445
7454
  export interface IFramedMarkdownEditor extends MarkdownScrollableEditView {
7446
7455
  /**
@@ -7812,11 +7821,6 @@ export interface FileSuggest<T> extends EditorSuggest<T> {
7812
7821
  */
7813
7822
  suggestManager: FileSuggestManager;
7814
7823
  }
7815
- declare global {
7816
- interface DomElementInfo {
7817
- [eventName: `on${string}`]: EventListenerOrEventListenerObject;
7818
- }
7819
- }
7820
7824
  /** @todo Documentation incomplete */
7821
7825
  /** @public */
7822
7826
  export interface FilePropertiesView extends InfoFileView {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "obsidian-typings",
3
- "version": "2.4.0",
3
+ "version": "2.5.0",
4
4
  "description": "Extended type definitions for the Obsidian API (https://obsidian.md)",
5
5
  "main": "",
6
6
  "module": "",