obsidian-typings 2.1.3 → 2.2.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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # Changelog
2
2
 
3
+ ## 2.2.0
4
+ - Added typings for `LinkUpdateHandler` for `inProgressUpdates` and `runAsyncLinkUpdate` (`FileManager`)
5
+ - Added typings for `onChange` method (`Vault`)
6
+ - Fix first parameter type of `exists` (`Vault`)
7
+ - Fix optionality of `getAvailablePathForAttachments` (`Vault`)
8
+
3
9
  ## 2.1.3
4
10
 
5
11
  - Added _initial_ typings for following views:
@@ -43,38 +43,17 @@ function createTFolderInstance(vault, path) {
43
43
  return folder;
44
44
  }
45
45
 
46
- // src/obsidian/implementations/InternalPluginName.ts
47
- var InternalPluginName = {
48
- AudioRecorder: "audio-recorder",
49
- Backlink: "backlink",
50
- Bookmarks: "bookmarks",
51
- Canvas: "canvas",
52
- CommandPalette: "command-palette",
53
- DailyNotes: "daily-notes",
54
- EditorStatus: "editor-status",
55
- FileExplorer: "file-explorer",
56
- FileRecovery: "file-recovery",
57
- GlobalSearch: "global-search",
58
- Graph: "graph",
59
- MarkdownImporter: "markdown-importer",
60
- NoteComposer: "note-composer",
61
- OutgoingLink: "outgoing-link",
62
- Outline: "outline",
63
- PagePreview: "page-preview",
64
- Properties: "properties",
65
- Publish: "publish",
66
- RandomNote: "random-note",
67
- SlashCommand: "slash-command",
68
- Slides: "slides",
69
- Starred: "starred",
70
- Switcher: "switcher",
71
- Sync: "sync",
72
- TagPane: "tag-pane",
73
- Templates: "templates",
74
- WordCount: "word-count",
75
- Workspaces: "workspaces",
76
- ZkPrefixer: "zk-prefixer"
77
- };
46
+ // src/obsidian/implementations/createTFileInstance.ts
47
+ var import_obsidian2 = require("obsidian");
48
+ function createTFileInstance(vault, path) {
49
+ let file = vault.getFileByPath(path);
50
+ if (file) {
51
+ return file;
52
+ }
53
+ file = new import_obsidian2.TFile(vault, path);
54
+ file.parent = createTFolderInstance(vault, vault.adapter.path.dirname(path));
55
+ return file;
56
+ }
78
57
 
79
58
  // src/obsidian/implementations/CustomArrayDictImpl.ts
80
59
  var CustomArrayDictImpl = class {
@@ -128,15 +107,36 @@ var CustomArrayDictImpl = class {
128
107
  }
129
108
  };
130
109
 
131
- // src/obsidian/implementations/createTFileInstance.ts
132
- var import_obsidian2 = require("obsidian");
133
- function createTFileInstance(vault, path) {
134
- let file = vault.getFileByPath(path);
135
- if (file) {
136
- return file;
137
- }
138
- file = new import_obsidian2.TFile(vault, path);
139
- file.parent = createTFolderInstance(vault, vault.adapter.path.dirname(path));
140
- return file;
141
- }
142
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/obsidian/implementations/index.ts", "../src/obsidian/implementations/createTFolderInstance.ts", "../src/obsidian/implementations/InternalPluginName.ts", "../src/obsidian/implementations/CustomArrayDictImpl.ts", "../src/obsidian/implementations/createTFileInstance.ts"],
  "sourcesContent": ["/* THIS IS A GENERATED/BUNDLED FILE BY BUILD SCRIPT */\n\nexport * from \"./createTFolderInstance.js\";\nexport * from \"./InternalPluginName.js\";\nexport * from \"./CustomArrayDictImpl.js\";\nexport * from \"./createTFileInstance.js\";\nimport \"../../index.js\";\n", "import {\n    TFolder,\n    type Vault\n} from \"obsidian\";\n\ntype TFolderConstructor = { new(vault: Vault, path: string): TFolder };\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 = new (TFolder as TFolderConstructor)(vault, path);\n    folder.parent = createTFolderInstance(vault, vault.adapter.path.dirname(path));\n    return folder;\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    Starred: \"starred\",\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 type { CustomArrayDict } from \"../internals/CustomArrayDict/CustomArrayDict.js\";\nimport type { CustomArrayDictDataRecord } from \"../internals/CustomArrayDict/CustomArrayDictDataRecord.js\";\n\nexport class CustomArrayDictImpl<T> implements CustomArrayDict<T> {\n    public data: CustomArrayDictDataRecord<T> = {};\n\n    public add(key: string, value: T): void {\n        if (!(this.data.hasOwnProperty(key))) {\n            this.data[key] = [] as T[];\n        }\n\n        const values = this.data[key]!;\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.data[key];\n        if (!values) {\n            return;\n        }\n        values.remove(value);\n\n        if (values.length === 0) {\n            delete this.data[key];\n        }\n    }\n\n    public removeKey(key: string): void {\n        delete this.data[key];\n    }\n\n    public get(key: string): T[] | null {\n        return this.data.hasOwnProperty(key) ? this.data[key]! : null;\n    }\n\n    public keys(): string[] {\n        return Object.keys(this.data);\n    }\n\n    public clear(key: string): void {\n        delete this.data[key];\n    }\n\n    public clearAll(): void {\n        this.data = {};\n    }\n\n    public contains(key: string, value: T): boolean {\n        const values = this.data[key];\n        return values && values.contains(value) || false;\n    }\n\n    public count(): number {\n        let ans = 0;\n        for (const key in this.data) {\n            if (this.data.hasOwnProperty(key)) {\n                ans += this.data[key]!.length;\n            }\n        }\n\n        return ans;\n    }\n}\n", "import {\n    TFile,\n    type Vault\n} from \"obsidian\";\nimport { createTFolderInstance } from \"./createTFolderInstance.ts\";\n\ntype TFileConstructor = { new(vault: Vault, path: string): TFile };\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 = new (TFile as TFileConstructor)(vault, path);\n    file.parent = createTFolderInstance(vault, vault.adapter.path.dirname(path));\n    return file;\n}\n"],
  "mappings": "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",
  "names": ["import_obsidian"]
}

110
+ // src/obsidian/implementations/InternalPluginName.ts
111
+ var InternalPluginName = {
112
+ AudioRecorder: "audio-recorder",
113
+ Backlink: "backlink",
114
+ Bookmarks: "bookmarks",
115
+ Canvas: "canvas",
116
+ CommandPalette: "command-palette",
117
+ DailyNotes: "daily-notes",
118
+ EditorStatus: "editor-status",
119
+ FileExplorer: "file-explorer",
120
+ FileRecovery: "file-recovery",
121
+ GlobalSearch: "global-search",
122
+ Graph: "graph",
123
+ MarkdownImporter: "markdown-importer",
124
+ NoteComposer: "note-composer",
125
+ OutgoingLink: "outgoing-link",
126
+ Outline: "outline",
127
+ PagePreview: "page-preview",
128
+ Properties: "properties",
129
+ Publish: "publish",
130
+ RandomNote: "random-note",
131
+ SlashCommand: "slash-command",
132
+ Slides: "slides",
133
+ Starred: "starred",
134
+ Switcher: "switcher",
135
+ Sync: "sync",
136
+ TagPane: "tag-pane",
137
+ Templates: "templates",
138
+ WordCount: "word-count",
139
+ Workspaces: "workspaces",
140
+ ZkPrefixer: "zk-prefixer"
141
+ };
142
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/obsidian/implementations/index.ts", "../src/obsidian/implementations/createTFolderInstance.ts", "../src/obsidian/implementations/createTFileInstance.ts", "../src/obsidian/implementations/CustomArrayDictImpl.ts", "../src/obsidian/implementations/InternalPluginName.ts"],
  "sourcesContent": ["/* THIS IS A GENERATED/BUNDLED FILE BY BUILD SCRIPT */\n\nexport * from \"./createTFolderInstance.js\";\nexport * from \"./createTFileInstance.js\";\nexport * from \"./CustomArrayDictImpl.js\";\nexport * from \"./InternalPluginName.js\";\nimport \"../../index.js\";\n", "import {\n    TFolder,\n    type Vault\n} from \"obsidian\";\n\ntype TFolderConstructor = { new(vault: Vault, path: string): TFolder };\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 = new (TFolder as TFolderConstructor)(vault, path);\n    folder.parent = createTFolderInstance(vault, vault.adapter.path.dirname(path));\n    return folder;\n}\n", "import {\n    TFile,\n    type Vault\n} from \"obsidian\";\nimport { createTFolderInstance } from \"./createTFolderInstance.ts\";\n\ntype TFileConstructor = { new(vault: Vault, path: string): TFile };\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 = new (TFile as TFileConstructor)(vault, path);\n    file.parent = createTFolderInstance(vault, vault.adapter.path.dirname(path));\n    return file;\n}\n", "import type { CustomArrayDict } from \"../internals/CustomArrayDict/CustomArrayDict.js\";\nimport type { CustomArrayDictDataRecord } from \"../internals/CustomArrayDict/CustomArrayDictDataRecord.js\";\n\nexport class CustomArrayDictImpl<T> implements CustomArrayDict<T> {\n    public data: CustomArrayDictDataRecord<T> = {};\n\n    public add(key: string, value: T): void {\n        if (!(this.data.hasOwnProperty(key))) {\n            this.data[key] = [] as T[];\n        }\n\n        const values = this.data[key]!;\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.data[key];\n        if (!values) {\n            return;\n        }\n        values.remove(value);\n\n        if (values.length === 0) {\n            delete this.data[key];\n        }\n    }\n\n    public removeKey(key: string): void {\n        delete this.data[key];\n    }\n\n    public get(key: string): T[] | null {\n        return this.data.hasOwnProperty(key) ? this.data[key]! : null;\n    }\n\n    public keys(): string[] {\n        return Object.keys(this.data);\n    }\n\n    public clear(key: string): void {\n        delete this.data[key];\n    }\n\n    public clearAll(): void {\n        this.data = {};\n    }\n\n    public contains(key: string, value: T): boolean {\n        const values = this.data[key];\n        return values && values.contains(value) || false;\n    }\n\n    public count(): number {\n        let ans = 0;\n        for (const key in this.data) {\n            if (this.data.hasOwnProperty(key)) {\n                ans += this.data[key]!.length;\n            }\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    Starred: \"starred\",\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"],
  "mappings": "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",
  "names": ["import_obsidian"]
}

@@ -10,6 +10,40 @@ import { TAbstractFile, TFile, TFolder, Vault } from 'obsidian';
10
10
  * This doesn't create the missing folder on the file system.
11
11
  */
12
12
  export declare function createTFolderInstance(vault: Vault, path: string): TFolder;
13
+ /**
14
+ * Creates and properly initializes the instance of TFile even the underlying file does not exist.
15
+ * This doesn't create the missing file on the file system.
16
+ */
17
+ export declare function createTFileInstance(vault: Vault, path: string): TFile;
18
+ /** @public */
19
+ export interface CustomArrayDictDataRecord<T> extends Record<string, T[]> {
20
+ }
21
+ /** @todo Documentation incomplete */
22
+ /** @public */
23
+ export interface CustomArrayDict<T> {
24
+ data: CustomArrayDictDataRecord<T>;
25
+ add(key: string, value: T): void;
26
+ clear(key: string): void;
27
+ clearAll(): void;
28
+ contains(key: string, value: T): boolean;
29
+ count(): number;
30
+ get(key: string): T[] | null;
31
+ keys(): string[];
32
+ remove(key: string, value: T): void;
33
+ removeKey(key: string): void;
34
+ }
35
+ export declare class CustomArrayDictImpl<T> implements CustomArrayDict<T> {
36
+ data: CustomArrayDictDataRecord<T>;
37
+ add(key: string, value: T): void;
38
+ remove(key: string, value: T): void;
39
+ removeKey(key: string): void;
40
+ get(key: string): T[] | null;
41
+ keys(): string[];
42
+ clear(key: string): void;
43
+ clearAll(): void;
44
+ contains(key: string, value: T): boolean;
45
+ count(): number;
46
+ }
13
47
  export declare const InternalPluginName: {
14
48
  readonly AudioRecorder: "audio-recorder";
15
49
  readonly Backlink: "backlink";
@@ -42,40 +76,6 @@ export declare const InternalPluginName: {
42
76
  readonly ZkPrefixer: "zk-prefixer";
43
77
  };
44
78
  /** @public */
45
- export interface CustomArrayDictDataRecord<T> extends Record<string, T[]> {
46
- }
47
- /** @todo Documentation incomplete */
48
- /** @public */
49
- export interface CustomArrayDict<T> {
50
- data: CustomArrayDictDataRecord<T>;
51
- add(key: string, value: T): void;
52
- clear(key: string): void;
53
- clearAll(): void;
54
- contains(key: string, value: T): boolean;
55
- count(): number;
56
- get(key: string): T[] | null;
57
- keys(): string[];
58
- remove(key: string, value: T): void;
59
- removeKey(key: string): void;
60
- }
61
- export declare class CustomArrayDictImpl<T> implements CustomArrayDict<T> {
62
- data: CustomArrayDictDataRecord<T>;
63
- add(key: string, value: T): void;
64
- remove(key: string, value: T): void;
65
- removeKey(key: string): void;
66
- get(key: string): T[] | null;
67
- keys(): string[];
68
- clear(key: string): void;
69
- clearAll(): void;
70
- contains(key: string, value: T): boolean;
71
- count(): number;
72
- }
73
- /**
74
- * Creates and properly initializes the instance of TFile even the underlying file does not exist.
75
- * This doesn't create the missing file on the file system.
76
- */
77
- export declare function createTFileInstance(vault: Vault, path: string): TFile;
78
- /** @public */
79
79
  export interface AppVaultConfigHotkeysRecord extends Record<string, string> {
80
80
  }
81
81
  /** @public */
@@ -22829,6 +22829,50 @@
22829
22829
  ],
22830
22830
  "extendsTokenRanges": []
22831
22831
  },
22832
+ {
22833
+ "kind": "TypeAlias",
22834
+ "canonicalReference": "obsidian-typings!LinkUpdateHandler:type",
22835
+ "docComment": "",
22836
+ "excerptTokens": [
22837
+ {
22838
+ "kind": "Content",
22839
+ "text": "export type LinkUpdateHandler = "
22840
+ },
22841
+ {
22842
+ "kind": "Content",
22843
+ "text": "(link: "
22844
+ },
22845
+ {
22846
+ "kind": "Reference",
22847
+ "text": "LinkUpdate",
22848
+ "canonicalReference": "obsidian-typings!LinkUpdate:interface"
22849
+ },
22850
+ {
22851
+ "kind": "Content",
22852
+ "text": ") => void | "
22853
+ },
22854
+ {
22855
+ "kind": "Reference",
22856
+ "text": "Promise",
22857
+ "canonicalReference": "!Promise:interface"
22858
+ },
22859
+ {
22860
+ "kind": "Content",
22861
+ "text": "<void>"
22862
+ },
22863
+ {
22864
+ "kind": "Content",
22865
+ "text": ";"
22866
+ }
22867
+ ],
22868
+ "fileUrlPath": "src/obsidian/internals/LinkUpdate/LinkUpdateHandler.d.ts",
22869
+ "releaseTag": "Public",
22870
+ "name": "LinkUpdateHandler",
22871
+ "typeTokenRange": {
22872
+ "startIndex": 1,
22873
+ "endIndex": 6
22874
+ }
22875
+ },
22832
22876
  {
22833
22877
  "kind": "Interface",
22834
22878
  "canonicalReference": "obsidian-typings!LinkUpdater:interface",