obsidian-typings 2.0.0 → 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,37 @@
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
+
9
+ ## 2.1.3
10
+
11
+ - Added _initial_ typings for following views:
12
+ - `AllPropertiesView`
13
+ - `AudioView`
14
+ - `BacklinkView`
15
+ - `BookmarksView`
16
+ - `BrowserHistoryView`
17
+ - `BrowserView`
18
+ - `CanvasView`
19
+ - `EmptyView`
20
+ - `FilePropertiesView`
21
+ - `GraphView`
22
+ - `ImageView`
23
+ - `InfoFileView`
24
+ - `LocalGraphView`
25
+ - `OutgoingLinkView`
26
+ - `OutlineView`
27
+ - `PdfView`
28
+ - `ReleaseNotesView`
29
+ - `SearchView`
30
+ - `TagView`
31
+ - `UnknownView`
32
+ - `VideoView`
33
+ - Add typings for `queue` method on `FileManager`
34
+
3
35
  ## 2.0.0
4
36
 
5
37
  - Split up typings codebase into separate files
package/README.md CHANGED
@@ -144,6 +144,7 @@ this.app.internalPlugins.getEnabledPluginById(InternalPluginName.FileExplorer);
144
144
  If you need to extend the typings provided by this package, add the following to any `.d.ts` file in your project:
145
145
 
146
146
  ```ts
147
+ export {}; // This is a very essential line. If you don't have any other top-level `import/export` statements, those typings will work not as expected.
147
148
  declare module "obsidian-typings" {
148
149
  interface PluginsPluginsRecord {
149
150
  myPlugin: MyPlugin;
@@ -184,11 +185,11 @@ With these scary disclaimers out of the way, hopefully these typings will help y
184
185
 
185
186
  ## Migration
186
187
 
187
- If you were using a `1.x.x` version of this package, you may need to follow the [Migration guide](MIGRATION.md) after updating to `2.0.0` or newer.
188
+ If you were using a `1.x.x` version of this package, you may need to follow the [Migration guide](https://github.com/Fevol/obsidian-typings/blob/main/MIGRATION.md) after updating to `2.0.0` or newer.
188
189
 
189
190
 
190
191
  ## Contributing
191
192
 
192
193
  Feel free to start typing any part of the Obsidian API that is not yet typed, or fixing/adding additional descriptions to existing typings. If you are unsure about anything, don't hesitate to open an issue.
193
194
 
194
- A brief tutorial is available on how you can get started with adding new typings, or fixing existing ones, see: [CONTRIBUTING.md](CONTRIBUTING.md).
195
+ A brief tutorial is available on how you can get started with adding new typings, or fixing existing ones, see: [CONTRIBUTING.md](https://github.com/Fevol/obsidian-typings/blob/main/CONTRIBUTING.md).
@@ -0,0 +1,37 @@
1
+ {
2
+ "$schema": "https://developer.microsoft.com/json-schemas/api-extractor/v7/api-extractor.schema.json",
3
+ "mainEntryPointFilePath": "src/index.d.ts",
4
+ "bundledPackages": [],
5
+ "compiler": {
6
+ },
7
+ "apiReport": {
8
+ "enabled": false
9
+ },
10
+ "docModel": {
11
+ "enabled": true,
12
+ "apiJsonFilePath": "dist/obsidian-typings.api.json"
13
+ },
14
+ "dtsRollup": {
15
+ "enabled": false
16
+ },
17
+ "tsdocMetadata": {
18
+ "enabled": false
19
+ },
20
+ "messages": {
21
+ "compilerMessageReporting": {
22
+ "default": {
23
+ "logLevel": "warning"
24
+ }
25
+ },
26
+ "extractorMessageReporting": {
27
+ "default": {
28
+ "logLevel": "warning"
29
+ }
30
+ },
31
+ "tsdocMessageReporting": {
32
+ "default": {
33
+ "logLevel": "warning"
34
+ }
35
+ }
36
+ }
37
+ }
@@ -21,57 +21,61 @@ var __copyProps = (to, from, except, desc) => {
21
21
  };
22
22
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
23
23
 
24
- // src/implementations/index.ts
24
+ // src/obsidian/implementations/index.ts
25
25
  var implementations_exports = {};
26
26
  __export(implementations_exports, {
27
27
  CustomArrayDictImpl: () => CustomArrayDictImpl,
28
28
  InternalPluginName: () => InternalPluginName,
29
- createTFile: () => createTFile,
30
- createTFolder: () => createTFolder
29
+ createTFileInstance: () => createTFileInstance,
30
+ createTFolderInstance: () => createTFolderInstance
31
31
  });
32
32
  module.exports = __toCommonJS(implementations_exports);
33
33
 
34
- // src/implementations/createTFile.ts
34
+ // src/obsidian/implementations/createTFolderInstance.ts
35
35
  var import_obsidian = require("obsidian");
36
- function createTFile(vault, path) {
37
- let file = vault.getFileByPath(path);
38
- if (file) {
39
- return file;
40
- }
41
- file = new import_obsidian.TFile(vault, path);
42
- file.parent = createTFolder(vault, vault.adapter.path.dirname(path));
43
- return file;
44
- }
45
-
46
- // src/implementations/createTFolder.ts
47
- var import_obsidian2 = require("obsidian");
48
- function createTFolder(vault, path) {
36
+ function createTFolderInstance(vault, path) {
49
37
  let folder = vault.getFolderByPath(path);
50
38
  if (folder) {
51
39
  return folder;
52
40
  }
53
- folder = new import_obsidian2.TFolder(vault, path);
54
- folder.parent = createTFolder(vault, vault.adapter.path.dirname(path));
41
+ folder = new import_obsidian.TFolder(vault, path);
42
+ folder.parent = createTFolderInstance(vault, vault.adapter.path.dirname(path));
55
43
  return folder;
56
44
  }
57
45
 
58
- // src/implementations/CustomArrayDictImpl.ts
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
+ }
57
+
58
+ // src/obsidian/implementations/CustomArrayDictImpl.ts
59
59
  var CustomArrayDictImpl = class {
60
60
  data = {};
61
61
  add(key, value) {
62
- if (!this.data.hasOwnProperty(key))
62
+ if (!this.data.hasOwnProperty(key)) {
63
63
  this.data[key] = [];
64
+ }
64
65
  const values = this.data[key];
65
- if (!values.includes(value))
66
+ if (!values.includes(value)) {
66
67
  values.push(value);
68
+ }
67
69
  }
68
70
  remove(key, value) {
69
71
  const values = this.data[key];
70
- if (!values)
72
+ if (!values) {
71
73
  return;
74
+ }
72
75
  values.remove(value);
73
- if (values.length === 0)
76
+ if (values.length === 0) {
74
77
  delete this.data[key];
78
+ }
75
79
  }
76
80
  removeKey(key) {
77
81
  delete this.data[key];
@@ -95,14 +99,15 @@ var CustomArrayDictImpl = class {
95
99
  count() {
96
100
  let ans = 0;
97
101
  for (const key in this.data) {
98
- if (this.data.hasOwnProperty(key))
102
+ if (this.data.hasOwnProperty(key)) {
99
103
  ans += this.data[key].length;
104
+ }
100
105
  }
101
106
  return ans;
102
107
  }
103
108
  };
104
109
 
105
- // src/implementations/InternalPluginName.ts
110
+ // src/obsidian/implementations/InternalPluginName.ts
106
111
  var InternalPluginName = {
107
112
  AudioRecorder: "audio-recorder",
108
113
  Backlink: "backlink",
@@ -134,4 +139,4 @@ var InternalPluginName = {
134
139
  Workspaces: "workspaces",
135
140
  ZkPrefixer: "zk-prefixer"
136
141
  };
137
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/implementations/index.ts", "../src/implementations/createTFile.ts", "../src/implementations/createTFolder.ts", "../src/implementations/CustomArrayDictImpl.ts", "../src/implementations/InternalPluginName.ts"],
  "sourcesContent": ["export { createTFile } from \"./createTFile.ts\";\nexport { createTFolder } from \"./createTFolder.ts\";\nexport * from \"./CustomArrayDictImpl.ts\";\nexport * from \"./InternalPluginName.ts\";\n", "import {\n    TFile,\n    type Vault\n} from \"obsidian\";\nimport { createTFolder } from \"./index.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 createTFile(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 = createTFolder(vault, vault.adapter.path.dirname(path));\n    return file;\n}\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 createTFolder(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 = createTFolder(vault, vault.adapter.path.dirname(path));\n    return folder;\n}\n", "import type {\n    CustomArrayDict,\n    CustomArrayDictDataRecord\n} from \"../obsidian/types.d.ts\";\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        const values = this.data[key]!;\n\n        if (!values.includes(value))\n            values.push(value);\n    }\n\n    public remove(key: string, value: T): void {\n        const values = this.data[key];\n        if (!values)\n            return;\n        values.remove(value);\n\n        if (values.length === 0)\n            delete this.data[key];\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        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": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,sBAGO;AASA,SAAS,YAAY,OAAc,MAAqB;AAC3D,MAAI,OAAO,MAAM,cAAc,IAAI;AACnC,MAAI,MAAM;AACN,WAAO;AAAA,EACX;AAEA,SAAO,IAAK,sBAA2B,OAAO,IAAI;AAClD,OAAK,SAAS,cAAc,OAAO,MAAM,QAAQ,KAAK,QAAQ,IAAI,CAAC;AACnE,SAAO;AACX;;;ACrBA,IAAAA,mBAGO;AAQA,SAAS,cAAc,OAAc,MAAuB;AAC/D,MAAI,SAAS,MAAM,gBAAgB,IAAI;AACvC,MAAI,QAAQ;AACR,WAAO;AAAA,EACX;AAEA,WAAS,IAAK,yBAA+B,OAAO,IAAI;AACxD,SAAO,SAAS,cAAc,OAAO,MAAM,QAAQ,KAAK,QAAQ,IAAI,CAAC;AACrE,SAAO;AACX;;;ACfO,IAAM,sBAAN,MAA2D;AAAA,EACvD,OAAqC,CAAC;AAAA,EAEtC,IAAI,KAAa,OAAgB;AACpC,QAAI,CAAE,KAAK,KAAK,eAAe,GAAG;AAC9B,WAAK,KAAK,GAAG,IAAI,CAAC;AAEtB,UAAM,SAAS,KAAK,KAAK,GAAG;AAE5B,QAAI,CAAC,OAAO,SAAS,KAAK;AACtB,aAAO,KAAK,KAAK;AAAA,EACzB;AAAA,EAEO,OAAO,KAAa,OAAgB;AACvC,UAAM,SAAS,KAAK,KAAK,GAAG;AAC5B,QAAI,CAAC;AACD;AACJ,WAAO,OAAO,KAAK;AAEnB,QAAI,OAAO,WAAW;AAClB,aAAO,KAAK,KAAK,GAAG;AAAA,EAC5B;AAAA,EAEO,UAAU,KAAmB;AAChC,WAAO,KAAK,KAAK,GAAG;AAAA,EACxB;AAAA,EAEO,IAAI,KAAyB;AAChC,WAAO,KAAK,KAAK,eAAe,GAAG,IAAI,KAAK,KAAK,GAAG,IAAK;AAAA,EAC7D;AAAA,EAEO,OAAiB;AACpB,WAAO,OAAO,KAAK,KAAK,IAAI;AAAA,EAChC;AAAA,EAEO,MAAM,KAAmB;AAC5B,WAAO,KAAK,KAAK,GAAG;AAAA,EACxB;AAAA,EAEO,WAAiB;AACpB,SAAK,OAAO,CAAC;AAAA,EACjB;AAAA,EAEO,SAAS,KAAa,OAAmB;AAC5C,UAAM,SAAS,KAAK,KAAK,GAAG;AAC5B,WAAO,UAAU,OAAO,SAAS,KAAK,KAAK;AAAA,EAC/C;AAAA,EAEO,QAAgB;AACnB,QAAI,MAAM;AACV,eAAW,OAAO,KAAK,MAAM;AACzB,UAAI,KAAK,KAAK,eAAe,GAAG;AAC5B,eAAO,KAAK,KAAK,GAAG,EAAG;AAAA,IAC/B;AAEA,WAAO;AAAA,EACX;AACJ;;;AC9DO,IAAM,qBAAqB;AAAA,EAC9B,eAAe;AAAA,EACf,UAAU;AAAA,EACV,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,gBAAgB;AAAA,EAChB,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,cAAc;AAAA,EACd,cAAc;AAAA,EACd,cAAc;AAAA,EACd,OAAO;AAAA,EACP,kBAAkB;AAAA,EAClB,cAAc;AAAA,EACd,cAAc;AAAA,EACd,SAAS;AAAA,EACT,aAAa;AAAA,EACb,YAAY;AAAA,EACZ,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,UAAU;AAAA,EACV,MAAM;AAAA,EACN,SAAS;AAAA,EACT,WAAW;AAAA,EACX,WAAW;AAAA,EACX,YAAY;AAAA,EACZ,YAAY;AAChB;",
  "names": ["import_obsidian"]
}

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"]
}

@@ -5,16 +5,45 @@ import * as fsPromises from 'node:fs/promises';
5
5
  import * as path from 'node:path';
6
6
  import { TAbstractFile, TFile, TFolder, Vault } from 'obsidian';
7
7
 
8
- /**
9
- * Creates and properly initializes the instance of TFile even the underlying file does not exist.
10
- * This doesn't create the missing file on the file system.
11
- */
12
- export declare function createTFile(vault: Vault, path: string): TFile;
13
8
  /**
14
9
  * Creates and properly initializes the instance of TFolder even the underlying folder does not exist.
15
10
  * This doesn't create the missing folder on the file system.
16
11
  */
17
- export declare function createTFolder(vault: Vault, path: string): TFolder;
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
+ }
18
47
  export declare const InternalPluginName: {
19
48
  readonly AudioRecorder: "audio-recorder";
20
49
  readonly Backlink: "backlink";
@@ -46,73 +75,77 @@ export declare const InternalPluginName: {
46
75
  readonly Workspaces: "workspaces";
47
76
  readonly ZkPrefixer: "zk-prefixer";
48
77
  };
78
+ /** @public */
79
+ export interface AppVaultConfigHotkeysRecord extends Record<string, string> {
80
+ }
81
+ /** @public */
49
82
  export interface AppVaultConfig {
50
83
  /**
51
- * Appearance > Accent color
84
+ * Appearance \> Accent color
52
85
  */
53
86
  accentColor: "" | string;
54
87
  /**
55
- * Files & Links > Automatically update internal links
88
+ * Files & Links \> Automatically update internal links
56
89
  */
57
90
  alwaysUpdateLinks?: false | boolean;
58
91
  /**
59
- * Files & Links > Attachment folder path
92
+ * Files & Links \> Attachment folder path
60
93
  */
61
94
  attachmentFolderPath?: "/" | string;
62
95
  /**
63
- * Editor > Auto convert HTML
96
+ * Editor \> Auto convert HTML
64
97
  */
65
98
  autoConvertHtml?: true | boolean;
66
99
  /**
67
- * Editor > Auto pair brackets
100
+ * Editor \> Auto pair brackets
68
101
  */
69
102
  autoPairBrackets?: true | boolean;
70
103
  /**
71
- * Editor > Auto pair Markdown syntax
104
+ * Editor \> Auto pair Markdown syntax
72
105
  */
73
106
  autoPairMarkdown?: true | boolean;
74
107
  /**
75
- * Appearance > Font size
108
+ * Appearance \> Font size
76
109
  */
77
110
  baseFontSize?: 16 | number;
78
111
  /**
79
- * Appearance > Quick font size adjustment
112
+ * Appearance \> Quick font size adjustment
80
113
  */
81
114
  baseFontSizeAction?: true | boolean;
82
115
  /**
83
- * Community Plugins > Browse > Sort order
116
+ * Community Plugins \> Browse \> Sort order
84
117
  */
85
118
  communityPluginSortOrder: "download" | "update" | "release" | "alphabetical";
86
119
  /**
87
- * Themes > Browse > Sort order
120
+ * Themes \> Browse \> Sort order
88
121
  */
89
122
  communityThemeSortOrder: "download" | "update" | "release" | "alphabetical";
90
123
  /**
91
- * Appearance > Theme
124
+ * Appearance \> Theme
92
125
  *
93
126
  * @remark is the default Obsidian theme
94
127
  */
95
128
  cssTheme?: "" | string;
96
129
  /**
97
- * Editor > Default view for new tabs
130
+ * Editor \> Default view for new tabs
98
131
  */
99
132
  defaultViewMode?: "source" | "preview";
100
133
  emacsyKeys?: true | boolean;
101
134
  /**
102
- * Appearance > CSS snippets
135
+ * Appearance \> CSS snippets
103
136
  */
104
137
  enabledCssSnippets?: string[];
105
138
  fileSortOrder?: "alphabetical";
106
139
  /**
107
- * Editor > Always focus new tabs
140
+ * Editor \> Always focus new tabs
108
141
  */
109
142
  focusNewTab?: true | boolean;
110
143
  /**
111
- * Editor > Fold heading
144
+ * Editor \> Fold heading
112
145
  */
113
146
  foldHeading?: true | boolean;
114
147
  /**
115
- * Editor > Fold indent
148
+ * Editor \> Fold indent
116
149
  */
117
150
  foldIndent?: true | boolean;
118
151
  /**
@@ -122,38 +155,38 @@ export interface AppVaultConfig {
122
155
  */
123
156
  hotkeys?: AppVaultConfigHotkeysRecord;
124
157
  /**
125
- * Appearance > Interface font
158
+ * Appearance \> Interface font
126
159
  */
127
160
  interfaceFontFamily?: "" | string;
128
161
  /**
129
- * Editor > Use legacy editor
162
+ * Editor \> Use legacy editor
130
163
  */
131
164
  legacyEditor?: false | boolean;
132
165
  livePreview?: true | boolean;
133
166
  /**
134
- * Mobile > Configure mobile Quick Action
167
+ * Mobile \> Configure mobile Quick Action
135
168
  */
136
169
  mobilePullAction?: "command-palette:open" | string;
137
170
  mobileQuickRibbonItem?: "" | string;
138
171
  /**
139
- * Mobile > Manage toolbar options
172
+ * Mobile \> Manage toolbar options
140
173
  */
141
174
  mobileToolbarCommands?: string[];
142
175
  monospaceFontFamily?: "" | string;
143
176
  /**
144
- * Appearance > Native menus
177
+ * Appearance \> Native menus
145
178
  */
146
179
  nativeMenus?: null | boolean;
147
180
  /**
148
- * Files & Links > Default location for new notes | 'folder' > Folder to create new notes in
181
+ * Files & Links \> Default location for new notes | 'folder' \> Folder to create new notes in
149
182
  */
150
183
  newFileFolderPath?: "/" | string;
151
184
  /**
152
- * Files & Links > Default location for new notes
185
+ * Files & Links \> Default location for new notes
153
186
  */
154
187
  newFileLocation?: "root" | "current" | "folder";
155
188
  /**
156
- * Files & Links > New link format
189
+ * Files & Links \> New link format
157
190
  */
158
191
  newLinkFormat?: "shortest" | "relative" | "absolute";
159
192
  /**
@@ -166,127 +199,115 @@ export interface AppVaultConfig {
166
199
  downscalePercent: 100 | number;
167
200
  };
168
201
  /**
169
- * Files & Links > Confirm line deletion
202
+ * Files & Links \> Confirm line deletion
170
203
  */
171
204
  promptDelete?: true | boolean;
172
205
  /**
173
- * Editor > Properties in document
206
+ * Editor \> Properties in document
174
207
  */
175
208
  propertiesInDocument?: "visible" | "hidden" | "source";
176
209
  /**
177
- * Editor > Readable line length
210
+ * Editor \> Readable line length
178
211
  */
179
212
  readableLineLength?: true | boolean;
180
213
  /**
181
- * Editor > Right-to-left (RTL)
214
+ * Editor \> Right-to-left (RTL)
182
215
  */
183
216
  rightToLeft?: false | boolean;
184
217
  /** @deprecated Removed as of version 1.4.3 */
185
218
  showFrontmatter?: false | boolean;
186
219
  /**
187
- * Editor > Show indentation guides
220
+ * Editor \> Show indentation guides
188
221
  */
189
222
  showIndentGuide?: true | boolean;
190
223
  /**
191
- * Editor > Show inline title
224
+ * Editor \> Show inline title
192
225
  */
193
226
  showInlineTitle?: true | boolean;
194
227
  /**
195
- * Editor > Show line numbers
228
+ * Editor \> Show line numbers
196
229
  */
197
230
  showLineNumber?: false | boolean;
198
231
  /**
199
- * Appearance > Show ribbon
232
+ * Appearance \> Show ribbon
200
233
  */
201
234
  showRibbon?: true | boolean;
202
235
  /**
203
- * Files & Links > Detect all file extensions
236
+ * Files & Links \> Detect all file extensions
204
237
  */
205
238
  showUnsupportedFiles?: false | boolean;
206
239
  /**
207
- * Appearance > Show tab title bar
240
+ * Appearance \> Show tab title bar
208
241
  */
209
242
  showViewHeader?: false | boolean;
210
243
  /**
211
- * Editor > Smart indent lists
244
+ * Editor \> Smart indent lists
212
245
  */
213
246
  smartIndentList?: true | boolean;
214
247
  /**
215
- * Editor > Spellcheck
248
+ * Editor \> Spellcheck
216
249
  */
217
250
  spellcheck?: false | boolean;
218
- /** @deprecated */
251
+ /** @deprecated Deprecated @todo */
219
252
  spellcheckDictionary?: [
220
253
  ] | string[];
221
254
  /**
222
- * Editor > Spellcheck languages
255
+ * Editor \> Spellcheck languages
223
256
  */
224
257
  spellcheckLanguages?: null | string[];
225
258
  /**
226
- * Editor > Strict line breaks
259
+ * Editor \> Strict line breaks
227
260
  */
228
261
  strictLineBreaks?: false | boolean;
229
262
  /**
230
- * Editor > Tab indent size
263
+ * Editor \> Tab indent size
231
264
  */
232
265
  tabSize?: 4 | number;
233
266
  /**
234
- * Appearance > Text font
267
+ * Appearance \> Text font
235
268
  */
236
269
  textFontFamily?: "" | string;
237
270
  /**
238
- * Appearance > Base color scheme
271
+ * Appearance \> Base color scheme
239
272
  *
240
273
  * @remark Not be confused with cssTheme, this setting is for the light/dark mode
241
274
  * @remark moonstone is light theme, "obsidian" is dark theme
242
275
  */
243
276
  theme?: "moonstone" | "obsidian";
244
277
  /**
245
- * Appearance > Translucent window
278
+ * Appearance \> Translucent window
246
279
  */
247
280
  translucency?: false | boolean;
248
281
  /**
249
- * Files & Links > Deleted files
282
+ * Files & Links \> Deleted files
250
283
  */
251
284
  trashOption?: "system" | "local" | "none";
252
285
  /** @deprecated Probably left-over code from old properties type storage */
253
286
  types: object;
254
287
  /**
255
- * Files & Links > Use [[Wikilinks]]
288
+ * Files & Links \> Use [[Wikilinks]]
256
289
  */
257
290
  useMarkdownLinks?: false | boolean;
258
291
  /**
259
- * Files & Links > Excluded files
292
+ * Files & Links \> Excluded files
260
293
  */
261
294
  userIgnoreFilters?: null | string[];
262
295
  /**
263
- * Editor > Indent using tabs
296
+ * Editor \> Indent using tabs
264
297
  */
265
298
  useTab?: true | boolean;
266
299
  /**
267
- * Editor > Vim key bindings
300
+ * Editor \> Vim key bindings
268
301
  */
269
302
  vimMode?: false | boolean;
270
303
  }
271
- export interface AppVaultConfigHotkeysRecord extends Record<string, string> {
272
- }
273
304
  /** @todo Documentation incomplete */
305
+ /** @public */
274
306
  export type ConfigItem = "accentColor" | "alwaysUpdateLinks" | "attachmentFolderPath" | "autoConvertHtml" | "autoPairBrackets" | "autoPairMarkdown" | "baseFontSize" | "baseFontSizeAction" | "cssTheme" | "defaultViewMode" | "emacsyKeys" | "enabledCssSnippets" | "fileSortOrder" | "focusNewTab" | "foldHeading" | "foldIndent" | "hotkeys" | "interfaceFontFamily" | "legacyEditor" | "livePreview" | "mobilePullAction" | "mobileQuickRibbonItem" | "mobileToolbarCommands" | "monospaceFontFamily" | "nativeMenus" | "newFileFolderPath" | "newFileLocation" | "newLinkFormat" | "pdfExportSettings" | "promptDelete" | "propertiesInDocument" | "readableLineLength" | "rightToLeft" | "showIndentGuide" | "showInlineTitle" | "showLineNumber" | "showUnsupportedFiles" | "showViewHeader" | "showRibbon" | "smartIndentList" | "spellcheck" | "spellcheckLanguages" | "strictLineBreaks" | "tabSize" | "textFontFamily" | "theme" | "translucency" | "trashOption" | "types" | "useMarkdownLinks" | "useTab" | "userIgnoreFilters" | "vimMode";
275
- /** @todo Documentation incomplete */
276
- export interface CustomArrayDict<T> {
277
- data: CustomArrayDictDataRecord<T>;
278
- add(key: string, value: T): void;
279
- clear(key: string): void;
280
- clearAll(): void;
281
- contains(key: string, value: T): boolean;
282
- count(): number;
283
- get(key: string): T[] | null;
284
- keys(): string[];
285
- remove(key: string, value: T): void;
286
- removeKey(key: string): void;
287
- }
288
- export interface CustomArrayDictDataRecord<T> extends Record<string, T[]> {
307
+ /** @public */
308
+ export interface VaultFileMapRecord extends Record<string, TAbstractFile> {
289
309
  }
310
+ /** @public */
290
311
  export interface FileEntry {
291
312
  /**
292
313
  * Creation time (if file)
@@ -311,26 +332,14 @@ export interface FileEntry {
311
332
  */
312
333
  type: "file" | "folder";
313
334
  }
335
+ /** @public */
314
336
  export interface DataAdapterFilesRecord extends Record<string, FileEntry> {
315
337
  }
338
+ /** @public */
316
339
  export interface DataAdapterWatchersRecord extends Record<string, {
317
340
  resolvedPath: string;
318
341
  watcher: unknown;
319
342
  }> {
320
343
  }
321
- export interface VaultFileMapRecord extends Record<string, TAbstractFile> {
322
- }
323
- export declare class CustomArrayDictImpl<T> implements CustomArrayDict<T> {
324
- data: CustomArrayDictDataRecord<T>;
325
- add(key: string, value: T): void;
326
- remove(key: string, value: T): void;
327
- removeKey(key: string): void;
328
- get(key: string): T[] | null;
329
- keys(): string[];
330
- clear(key: string): void;
331
- clearAll(): void;
332
- contains(key: string, value: T): boolean;
333
- count(): number;
334
- }
335
344
 
336
345
  export {};