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 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.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 eslinteslint main.tssrc, you can use eslint with this command to analyze all files in that folder:eslint .\src\