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 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",
@@ -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, vault.adapter.path.dirname(path));
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, vault.adapter.path.dirname(path));
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,{
  "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"]
}

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": "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",
  "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, "obsidian" is dark 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 {};