obsidian-typings 2.2.1-beta.2 → 2.2.1-beta.21
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/.gitattributes +1 -0
- package/README.md +1 -1
- package/dist/implementations.cjs +17 -5
- package/dist/implementations.d.ts +44 -51
- package/dist/obsidian-typings.api.json +25657 -15526
- package/dist/style-mod.d.cts +1 -1
- package/dist/types.d.ts +6403 -5572
- package/package.json +18 -8
package/.gitattributes
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
* text=auto eol=lf
|
package/README.md
CHANGED
|
@@ -92,7 +92,7 @@ Be aware that the typings currently only cover a subset of the full API: while m
|
|
|
92
92
|
```json
|
|
93
93
|
{
|
|
94
94
|
"compilerOptions": {
|
|
95
|
-
...
|
|
95
|
+
"...": "...",
|
|
96
96
|
"paths": {
|
|
97
97
|
"obsidian-typings/implementations": [
|
|
98
98
|
"./node_modules/obsidian-typings/dist/implementations.d.ts",
|
package/dist/implementations.cjs
CHANGED
|
@@ -27,31 +27,43 @@ __export(implementations_exports, {
|
|
|
27
27
|
CustomArrayDictImpl: () => CustomArrayDictImpl,
|
|
28
28
|
InternalPluginName: () => InternalPluginName,
|
|
29
29
|
createTFileInstance: () => createTFileInstance,
|
|
30
|
-
createTFolderInstance: () => createTFolderInstance
|
|
30
|
+
createTFolderInstance: () => createTFolderInstance,
|
|
31
|
+
parentFolderPath: () => parentFolderPath
|
|
31
32
|
});
|
|
32
33
|
module.exports = __toCommonJS(implementations_exports);
|
|
33
34
|
|
|
35
|
+
// src/obsidian/implementations/createTFileInstance.ts
|
|
36
|
+
var import_obsidian2 = require("obsidian");
|
|
37
|
+
|
|
34
38
|
// src/obsidian/implementations/createTFolderInstance.ts
|
|
35
39
|
var import_obsidian = require("obsidian");
|
|
40
|
+
|
|
41
|
+
// src/obsidian/implementations/PathUtils.ts
|
|
42
|
+
function parentFolderPath(path) {
|
|
43
|
+
return path.replace(/\/?[^\/]*$/, "") || "/";
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// src/obsidian/implementations/createTFolderInstance.ts
|
|
36
47
|
function createTFolderInstance(vault, path) {
|
|
37
48
|
let folder = vault.getFolderByPath(path);
|
|
38
49
|
if (folder) {
|
|
39
50
|
return folder;
|
|
40
51
|
}
|
|
41
52
|
folder = new import_obsidian.TFolder(vault, path);
|
|
42
|
-
folder.parent = createTFolderInstance(vault,
|
|
53
|
+
folder.parent = createTFolderInstance(vault, parentFolderPath(path));
|
|
54
|
+
folder.deleted = true;
|
|
43
55
|
return folder;
|
|
44
56
|
}
|
|
45
57
|
|
|
46
58
|
// src/obsidian/implementations/createTFileInstance.ts
|
|
47
|
-
var import_obsidian2 = require("obsidian");
|
|
48
59
|
function createTFileInstance(vault, path) {
|
|
49
60
|
let file = vault.getFileByPath(path);
|
|
50
61
|
if (file) {
|
|
51
62
|
return file;
|
|
52
63
|
}
|
|
53
64
|
file = new import_obsidian2.TFile(vault, path);
|
|
54
|
-
file.parent = createTFolderInstance(vault,
|
|
65
|
+
file.parent = createTFolderInstance(vault, parentFolderPath(path));
|
|
66
|
+
file.deleted = true;
|
|
55
67
|
return file;
|
|
56
68
|
}
|
|
57
69
|
|
|
@@ -139,4 +151,4 @@ var InternalPluginName = {
|
|
|
139
151
|
Workspaces: "workspaces",
|
|
140
152
|
ZkPrefixer: "zk-prefixer"
|
|
141
153
|
};
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/obsidian/implementations/index.ts", "../src/obsidian/implementations/createTFileInstance.ts", "../src/obsidian/implementations/createTFolderInstance.ts", "../src/obsidian/implementations/PathUtils.ts", "../src/obsidian/implementations/CustomArrayDictImpl.ts", "../src/obsidian/implementations/InternalPluginName.ts"],
  "sourcesContent": ["/* THIS IS A GENERATED/BUNDLED FILE BY BUILD SCRIPT */\n\nexport * from './createTFileInstance.js';\nexport * from './createTFolderInstance.js';\nexport * from './PathUtils.js';\nexport * from './CustomArrayDictImpl.js';\nexport * from './InternalPluginName.js';\nimport '../../index.js';\n", "import {\n    TFile,\n    type Vault\n} from 'obsidian';\nimport { createTFolderInstance } from './createTFolderInstance.ts';\nimport { parentFolderPath } from './PathUtils.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, parentFolderPath(path));\n    file.deleted = true;\n    return file;\n}\n", "import {\n    TFolder,\n    type Vault\n} from 'obsidian';\nimport { parentFolderPath } from './PathUtils.ts';\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, parentFolderPath(path));\n    folder.deleted = true;\n    return folder;\n}\n", "export function parentFolderPath(path: string): string {\n    return path.replace(/\\/?[^\\/]*$/, '') || '/';\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": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,IAAAA,mBAGO;;;ACHP,sBAGO;;;ACHA,SAAS,iBAAiB,MAAsB;AACnD,SAAO,KAAK,QAAQ,cAAc,EAAE,KAAK;AAC7C;;;ADUO,SAAS,sBAAsB,OAAc,MAAuB;AACvE,MAAI,SAAS,MAAM,gBAAgB,IAAI;AACvC,MAAI,QAAQ;AACR,WAAO;AAAA,EACX;AAEA,WAAS,IAAK,wBAA+B,OAAO,IAAI;AACxD,SAAO,SAAS,sBAAsB,OAAO,iBAAiB,IAAI,CAAC;AACnE,SAAO,UAAU;AACjB,SAAO;AACX;;;ADTO,SAAS,oBAAoB,OAAc,MAAqB;AACnE,MAAI,OAAO,MAAM,cAAc,IAAI;AACnC,MAAI,MAAM;AACN,WAAO;AAAA,EACX;AAEA,SAAO,IAAK,uBAA2B,OAAO,IAAI;AAClD,OAAK,SAAS,sBAAsB,OAAO,iBAAiB,IAAI,CAAC;AACjE,OAAK,UAAU;AACf,SAAO;AACX;;;AGpBO,IAAM,sBAAN,MAA2D;AAAA,EACvD,OAAqC,CAAC;AAAA,EAEtC,IAAI,KAAa,OAAgB;AACpC,QAAI,CAAE,KAAK,KAAK,eAAe,GAAG,GAAI;AAClC,WAAK,KAAK,GAAG,IAAI,CAAC;AAAA,IACtB;AAEA,UAAM,SAAS,KAAK,KAAK,GAAG;AAE5B,QAAI,CAAC,OAAO,SAAS,KAAK,GAAG;AACzB,aAAO,KAAK,KAAK;AAAA,IACrB;AAAA,EACJ;AAAA,EAEO,OAAO,KAAa,OAAgB;AACvC,UAAM,SAAS,KAAK,KAAK,GAAG;AAC5B,QAAI,CAAC,QAAQ;AACT;AAAA,IACJ;AACA,WAAO,OAAO,KAAK;AAEnB,QAAI,OAAO,WAAW,GAAG;AACrB,aAAO,KAAK,KAAK,GAAG;AAAA,IACxB;AAAA,EACJ;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,GAAG;AAC/B,eAAO,KAAK,KAAK,GAAG,EAAG;AAAA,MAC3B;AAAA,IACJ;AAEA,WAAO;AAAA,EACX;AACJ;;;ACjEO,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"]
}

|
|
@@ -1,20 +1,18 @@
|
|
|
1
1
|
// Generated by dts-bundle-generator v9.5.1
|
|
2
2
|
|
|
3
|
-
import * as fs from 'node:fs';
|
|
4
|
-
import * as fsPromises from 'node:fs/promises';
|
|
5
|
-
import * as path from 'node:path';
|
|
6
3
|
import { FileStats, TAbstractFile, TFile, TFolder, Vault } from 'obsidian';
|
|
7
4
|
|
|
8
|
-
/**
|
|
9
|
-
* Creates and properly initializes the instance of TFolder even the underlying folder does not exist.
|
|
10
|
-
* This doesn't create the missing folder on the file system.
|
|
11
|
-
*/
|
|
12
|
-
export declare function createTFolderInstance(vault: Vault, path: string): TFolder;
|
|
13
5
|
/**
|
|
14
6
|
* Creates and properly initializes the instance of TFile even the underlying file does not exist.
|
|
15
7
|
* This doesn't create the missing file on the file system.
|
|
16
8
|
*/
|
|
17
9
|
export declare function createTFileInstance(vault: Vault, path: string): TFile;
|
|
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
|
+
export declare function parentFolderPath(path: string): string;
|
|
18
16
|
/** @public */
|
|
19
17
|
export interface CustomArrayDictDataRecord<T> extends Record<string, T[]> {
|
|
20
18
|
}
|
|
@@ -76,6 +74,43 @@ export declare const InternalPluginName: {
|
|
|
76
74
|
readonly ZkPrefixer: "zk-prefixer";
|
|
77
75
|
};
|
|
78
76
|
/** @public */
|
|
77
|
+
export interface FileEntry extends Partial<FileStats> {
|
|
78
|
+
/**
|
|
79
|
+
* Full path to file or folder
|
|
80
|
+
*
|
|
81
|
+
* @remark Might be used for resolving symlinks
|
|
82
|
+
*/
|
|
83
|
+
realpath: string;
|
|
84
|
+
/**
|
|
85
|
+
* Type of entry
|
|
86
|
+
*/
|
|
87
|
+
type: "file" | "folder";
|
|
88
|
+
/**
|
|
89
|
+
* Name of file or folder
|
|
90
|
+
*/
|
|
91
|
+
name?: string;
|
|
92
|
+
/**
|
|
93
|
+
* URI of file or folder
|
|
94
|
+
*/
|
|
95
|
+
uri?: string;
|
|
96
|
+
}
|
|
97
|
+
/** @todo Documentation incomplete */
|
|
98
|
+
/** @public */
|
|
99
|
+
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";
|
|
100
|
+
/** @public */
|
|
101
|
+
export type FileSystemWatchHandler = (eventType: string, path: string, oldPath?: string, stats?: FileStats) => void;
|
|
102
|
+
/** @public */
|
|
103
|
+
export interface PromisedQueue {
|
|
104
|
+
promise: Promise<void>;
|
|
105
|
+
queue(next: () => void | Promise<void>): Promise<void>;
|
|
106
|
+
}
|
|
107
|
+
/** @public */
|
|
108
|
+
export interface VaultFileMapRecord extends Record<string, TAbstractFile> {
|
|
109
|
+
}
|
|
110
|
+
/** @public */
|
|
111
|
+
export interface DataAdapterFilesRecord extends Record<string, FileEntry> {
|
|
112
|
+
}
|
|
113
|
+
/** @public */
|
|
79
114
|
export interface AppVaultConfigHotkeysRecord extends Record<string, string> {
|
|
80
115
|
}
|
|
81
116
|
/** @public */
|
|
@@ -271,7 +306,7 @@ export interface AppVaultConfig {
|
|
|
271
306
|
* Appearance \> Base color scheme
|
|
272
307
|
*
|
|
273
308
|
* @remark Not be confused with cssTheme, this setting is for the light/dark mode
|
|
274
|
-
* @remark moonstone is light theme,
|
|
309
|
+
* @remark moonstone is light theme, 'obsidian' is dark theme
|
|
275
310
|
*/
|
|
276
311
|
theme?: "moonstone" | "obsidian";
|
|
277
312
|
/**
|
|
@@ -301,47 +336,5 @@ export interface AppVaultConfig {
|
|
|
301
336
|
*/
|
|
302
337
|
vimMode?: false | boolean;
|
|
303
338
|
}
|
|
304
|
-
/** @todo Documentation incomplete */
|
|
305
|
-
/** @public */
|
|
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";
|
|
307
|
-
/** @public */
|
|
308
|
-
export type FileSystemWatchHandler = (eventType: string, path: string, oldPath?: string, stats?: FileStats) => void;
|
|
309
|
-
/** @public */
|
|
310
|
-
export interface VaultFileMapRecord extends Record<string, TAbstractFile> {
|
|
311
|
-
}
|
|
312
|
-
/** @public */
|
|
313
|
-
export interface FileEntry {
|
|
314
|
-
/**
|
|
315
|
-
* Creation time (if file)
|
|
316
|
-
*/
|
|
317
|
-
ctime?: number;
|
|
318
|
-
/**
|
|
319
|
-
* Modification time (if file)
|
|
320
|
-
*/
|
|
321
|
-
mtime?: number;
|
|
322
|
-
/**
|
|
323
|
-
* Full path to file or folder
|
|
324
|
-
*
|
|
325
|
-
* @remark Might be used for resolving symlinks
|
|
326
|
-
*/
|
|
327
|
-
realpath: string;
|
|
328
|
-
/**
|
|
329
|
-
* Size in bytes (if file)
|
|
330
|
-
*/
|
|
331
|
-
size?: number;
|
|
332
|
-
/**
|
|
333
|
-
* Type of entry
|
|
334
|
-
*/
|
|
335
|
-
type: "file" | "folder";
|
|
336
|
-
}
|
|
337
|
-
/** @public */
|
|
338
|
-
export interface DataAdapterFilesRecord extends Record<string, FileEntry> {
|
|
339
|
-
}
|
|
340
|
-
/** @public */
|
|
341
|
-
export interface DataAdapterWatchersRecord extends Record<string, {
|
|
342
|
-
resolvedPath: string;
|
|
343
|
-
watcher: unknown;
|
|
344
|
-
}> {
|
|
345
|
-
}
|
|
346
339
|
|
|
347
340
|
export {};
|