This is a sample plugin for Obsidian (https://obsidian.md).
This project uses TypeScript to provide type checking and documentation. The repo depends on the latest plugin API (obsidian.d.ts) in TypeScript Definition format, which contains TSDoc comments describing what it does.
This sample plugin demonstrates some of the basic functionality the plugin API can do.
Quick starting guide for new plugin devs:
.obsidian/plugins/your-plugin-name folder.bun install in the command line under your repo folder.bun run dev to compile your plugin from src/main.ts to main.js (watch mode).src/main.ts (or create new .ts / .svelte files). Those changes should be automatically compiled into main.js.bun update in the command line under your repo folder.manifest.json with your new version number, such as 1.0.1, and the minimum Obsidian version required for your latest release.versions.json file with "new-plugin-version": "minimum-obsidian-version" so older versions of Obsidian can download an older version of your plugin that's compatible.v. See here for an example: https://github.com/obsidianmd/obsidian-sample-plugin/releasesmanifest.json, main.js, styles.css as binary attachments. Note: The manifest.json file must be in two places, first the root path of your repository and also in the release.You can simplify the version bump process by running
npm version patch,npm version minorornpm version majorafter updatingminAppVersionmanually inmanifest.json. The command will bump version inmanifest.jsonandpackage.json, and add the entry for the new version toversions.json
README.md file in the root of your repo.node --version).bun install to install dependencies.bun run dev to start compilation in watch mode.bun run check to run format:check, lint:check, svelte-check, and build.bun run format to format the repo with Prettier.bun run format:check to verify formatting (CI-style).main.js, styles.css, manifest.json to your vault VaultFolder/.obsidian/plugins/your-plugin-id/.bun run lint or bun run lint:check.You can include funding URLs where people who use your plugin can financially support it.
The simple way is to set the fundingUrl field to your link in your manifest.json file:
{
"fundingUrl": "https://buymeacoffee.com"
}
If you have multiple URLs, you can also do:
{
"fundingUrl": {
"Buy Me a Coffee": "https://buymeacoffee.com",
"GitHub Sponsor": "https://github.com/sponsors",
"Patreon": "https://www.patreon.com/"
}
}