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
|
|
|
|
|
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
|
|
|
|
|
[plugs](https://silverbullet.md/🔌_Plugs), and you can customize it to your
|
|
|
|
|
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.
|