2023-01-16 15:45:55 +00:00
# SilverBullet
2022-10-10 12:50:21 +00:00
2023-01-16 15:45:55 +00:00
SilverBullet is an extensible, open source **personal knowledge
2022-10-10 12:50:21 +00:00
platform**. At its core it’ s a clean markdown-based writing/note taking
application that stores your _pages_ (notes) as plain markdown files in a folder
referred to as a _space_ . Pages can be cross-linked using the
`[[link to other page]]` syntax. This makes it a simple tool for
[Personal Knowledge Management ](https://en.wikipedia.org/wiki/Personal_knowledge_management ).
However, once you leverage its various extensions (called _plugs_ ) it can feel
more like a _knowledge platform_ , allowing you to annotate, combine and query
your accumulated knowledge in creative ways specific to you.
2022-04-21 12:05:22 +00:00
2022-11-18 15:59:55 +00:00
< img src = "https://github.com/silverbulletmd/silverbullet/raw/main/website/silverbullet-pwa.png" height = "400" / > < img src = "https://github.com/silverbulletmd/silverbullet/raw/main/website/silverbullet-ios.png" height = "400" / >
2022-08-01 10:07:02 +00:00
2023-05-26 12:04:40 +00:00
SilverBullet is implemented as an offline-first PWA: it syncs all your content into the client (browser) and performs most processing there, allowing full offline operation after first load.
2022-10-10 12:50:21 +00:00
For more in-depth information, an interactive demo, and links to more
2023-01-16 15:45:55 +00:00
background, check out the [SilverBullet website ](https://silverbullet.md )
2022-10-10 12:50:21 +00:00
(published from this repo’ s `website/` folder).
2022-04-21 13:04:37 +00:00
2022-07-23 18:45:42 +00:00
Or checkout these two videos:
2022-06-28 12:41:21 +00:00
2023-01-16 15:45:55 +00:00
- [A Tour of some of SilverBullet’ s features ](https://youtu.be/VemS-cqAD5k ) —
2022-10-10 12:50:21 +00:00
spoiler alert: it’ s cool.
- [A look the SilverBullet architecture ](https://youtu.be/mXCGau05p5o ) — spoiler
alert: it’ s plugs all the way down.
2022-06-28 12:14:15 +00:00
## Features
2022-10-10 13:09:56 +00:00
2023-01-16 15:45:55 +00:00
- **Free and open source**. SilverBullet is MIT licensed.
- **The truth is in the markdown.** SilverBullet doesn’ t use proprietary file
2022-10-10 13:09:56 +00:00
formats. It keeps its data as plain markdown files on disk. While SB uses a
database for indexing and caching some indexes, all of that can be rebuilt
from its markdown source at any time. If SB would ever go away, you can still
read your pages with any text editor.
- **One single, distraction free mode.** SB doesn’ t have a separate view and
edit mode. It doesn’ t have a “focus mode.” You’ re always in focused edit mode,
why wouldn’ t you?
- **Keyboard oriented**. You can use SB fully using the keyboard, typin’ the
keys.
- **Extend it your way**. SB is highly extensible with
2023-07-03 20:52:19 +00:00
[plugs ](https://silverbullet.md/🔌%20Plugs ), and you can customize it to your
2022-10-10 13:09:56 +00:00
liking and your workflows.
2022-06-28 12:19:31 +00:00
2023-01-16 15:45:55 +00:00
## Installing SilverBullet
Check out the [official website ](https://silverbullet.md )
2022-10-24 14:10:24 +00:00
## Troubleshooting
2023-01-16 15:45:55 +00:00
If you upgraded to the new Deno-based SilverBullet from an old version, you may
2022-10-24 14:10:24 +00:00
have to use the `silverbullet fix <pages-path>` command to flush out your old
database and plugs. Plugs will likely need to be updated.
2023-01-16 15:45:55 +00:00
## Developing SilverBullet
2022-09-24 12:38:58 +00:00
2022-09-24 18:07:23 +00:00
[![Open in Gitpod ](https://gitpod.io/button/open-in-gitpod.svg )](https://gitpod.io/#https://github.com/silverbulletmd/silverbullet)
2022-09-24 12:38:58 +00:00
2023-01-16 15:45:55 +00:00
SilverBullet is written in [TypeScript ](https://www.typescriptlang.org/ ) and
2022-10-10 12:50:21 +00:00
built on top of the excellent [CodeMirror 6 ](https://codemirror.net/ ) editor
2022-12-08 19:02:43 +00:00
component. Additional UI is built using [Preact ](https://preactjs.com ).
[ESBuild ]([https://parceljs.org/](https://esbuild.github.io )) is used to build both the front-end and
back-end bundles. The server backend runs as a HTTP server on Deno using and is written using [Oak ](https://oakserver.github.io/oak/ ).
2022-07-10 14:56:52 +00:00
2022-10-10 12:50:21 +00:00
To prepare the initial web and plug build run:
2022-04-21 13:04:37 +00:00
```shell
2022-10-10 12:50:21 +00:00
deno task build
2022-04-21 13:04:37 +00:00
```
2022-10-24 14:10:24 +00:00
To symlink `silverbullet` to your locally checked-out version, run:
2022-10-12 09:47:13 +00:00
```shell
deno task install
```
2022-10-10 12:50:21 +00:00
You can then run the server in “watch mode” (automatically restarting when you
change source files) with:
2022-06-28 12:14:15 +00:00
2022-07-23 18:45:42 +00:00
```shell
2022-10-23 07:06:12 +00:00
deno task watch-server < PATH-TO-YOUR-SPACE >
2022-07-23 18:45:42 +00:00
```
2022-04-21 13:04:37 +00:00
2022-10-10 12:50:21 +00:00
After this initial build, it's convenient to run three commands in parallel (in
separate terminals):
2022-04-21 12:05:22 +00:00
```shell
2022-10-10 12:50:21 +00:00
deno task watch-web
2022-10-23 07:06:12 +00:00
deno task watch-server < PATH-TO-YOUR-SPACE >
2022-10-10 12:50:21 +00:00
deno task watch-plugs
2022-04-21 12:05:22 +00:00
```
2022-07-23 18:45:42 +00:00
2023-04-18 18:56:47 +00:00
To typecheck the entire codebase (recommended before submitting PR):
```shell
deno task check
```
To run unit tests:
```shell
deno task test
```
2022-07-23 18:45:42 +00:00
## Feedback
2022-09-05 14:37:30 +00:00
2022-10-10 12:50:21 +00:00
If you (hypothetically) find bugs or have feature requests, post them in
[our issue tracker ](https://github.com/silverbulletmd/silverbullet/issues ).
Would you like to contribute?
[Check out the code ](https://github.com/silverbulletmd/silverbullet ), and the
issue tracker as well for ideas on what to work on.