This is a fork of the Obsidian sample plugin that contains all dev dependencies necessary to use Svelte with your Obsidian plugin. To get started, fork the master
branch of this repo.
This repo also contains a tutorial vault for getting started with Svelte in Obsidian. You can start by checking out the workshop-start
branch and opening the svelte-tutorial-vault
folder as an Obsidian vault.
This workshop was part of the Obsidian October 2022 event. If you missed it, you can watch the recording of the workshop here: link coming soon
Quick starting guide for new plugin devs:
.obsidian/plugins/your-plugin-name
folder.npm i
in the command line under your repo folder.npm run dev
to compile your plugin from main.ts
to main.js
.main.ts
(or create new .ts
files). Those changes should be automatically compiled into main.js
.npm 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 minor
ornpm version major
after updatingminAppVersion
manually inmanifest.json
. The command will bump version inmanifest.json
andpackage.json
, and add the entry for the new version toversions.json
README.md
file in the root of your repo.npm i
or yarn
to install dependenciesnpm run dev
to start compilation in watch mode.main.js
, styles.css
, manifest.json
to your vault VaultFolder/.obsidian/plugins/your-plugin-id/
.npm install -g eslint
eslint main.ts
src
, you can use eslint with this command to analyze all files in that folder:eslint .\src\