Type definitions for the latest Obsidian API (https://obsidian.md)
npm install obsidianmanifest.json
id the ID of your plugin.
name the display name of your plugin.
author the plugin author's name.
version the version of your plugin.
minAppVersion the minimum required Obsidian version for your plugin.
description the long description of your plugin.
isDesktopOnly whether your plugin uses NodeJS or Electron APIs.
authorUrl (optional) a URL to your own website.
fundingUrl (optional) a link for users to donation to show appreciation and support plugin development.
main.js
require('obsidian')
require('fs') or require('electron')
Plugin
App, the global object that owns everything else. You can access this via this.app inside your plugin. The App interface provides accessors for the following interfaces.
Vault, the interface that lets you interact with files and folders in the vault.
Workspace, the interface that lets you interact with panes on the screen.
MetadataCache, the interface that contains cached metadata about each markdown file, including headings, links, embeds, tags, and blocks.
Plugin, you can:
this.addRibbonIcon.
this.addStatusBarItem.
this.addCommand.
this.addSettingTab.
this.registerView.
this.loadData and this.saveData.
App and Workspace, please use this.registerEvent, which will automatically detach your event handler when your plugin unloads:
this.registerEvent(app.on('event-name', callback));
`
If you register DOM events for elements that persist on the page after your plugin unloads, such as window or document events, please use this.registerDomEvent:
`
this.registerDomEvent(element, 'click', callback);
`
If you use setInterval, please use this.registerInterval:
`
this.registerInterval(setInterval(callback, 1000));
``