1
0
Workshop for the mind
Go to file
2022-10-19 11:30:22 +02:00
.github/workflows Fixes #93 #56 2022-10-17 16:28:58 +02:00
.vscode Migrate to Deno (#86) 2022-10-10 14:50:21 +02:00
common Rewrite listFiles to use std lib's "walk" + test 2022-10-19 11:30:22 +02:00
images New screenshots 2022-08-01 12:07:02 +02:00
plug-api Fixes #90: Re-enables full text search 2022-10-19 09:52:29 +02:00
plugos Rewrite listFiles to use std lib's "walk" + test 2022-10-19 11:30:22 +02:00
plugs Fixes #90: Re-enables full text search 2022-10-19 09:52:29 +02:00
scripts Refactor of asset bundles 2022-10-12 11:47:13 +02:00
server Fixes #90: Re-enables full text search 2022-10-19 09:52:29 +02:00
web Fixes #92: implements frontmatter syntax 2022-10-17 15:48:21 +02:00
website Fixes #93 #56 2022-10-17 16:28:58 +02:00
.env Update .env 2022-07-18 19:48:58 +02:00
.gitignore Migrate to Deno (#86) 2022-10-10 14:50:21 +02:00
.gitpod.Dockerfile Migrate to Deno (#86) 2022-10-10 14:50:21 +02:00
.gitpod.yml Added imports 2022-10-13 15:16:18 +02:00
build_plugs.sh Added imports 2022-10-13 15:16:18 +02:00
build.ts Fixes #92: implements frontmatter syntax 2022-10-17 15:48:21 +02:00
CHANGELOG.md Work on #10 theming 2022-08-02 14:40:04 +02:00
deno.jsonc Exclude running tests of forked deps 2022-10-19 09:55:00 +02:00
docker-compose.yaml create docker compose 2022-07-18 03:24:51 +02:00
Dockerfile Update Dockerfile 2022-07-18 19:48:19 +02:00
import_map.json Attempt to fix tests 2022-10-17 16:33:51 +02:00
LICENSE.md Refactor of asset bundles 2022-10-12 11:47:13 +02:00
netlify.toml Publish website with silverbullet-publish 2022-09-05 16:33:56 +02:00
README.md Refactor of asset bundles 2022-10-12 11:47:13 +02:00
test_deps.ts Migrate to Deno (#86) 2022-10-10 14:50:21 +02:00

Silver Bullet

Silver Bullet (SB) is an extensible, open source personal knowledge platform. At its core its 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. 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.

For more in-depth information, an interactive demo, and links to more background, check out the Silver Bullet website (published from this repos website/ folder).

Or checkout these two videos:

Features

  • Free and open source. Silver Bullet is MIT licensed.
  • The truth is in the markdown. Silver Bullet doesnt use proprietary file 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 doesnt have a separate view and edit mode. It doesnt have a “focus mode.” Youre always in focused edit mode, why wouldnt you?
  • Keyboard oriented. You can use SB fully using the keyboard, typin the keys.
  • Extend it your way. SB is highly extensible with plugs, and you can customize it to your liking and your workflows.

Installing Silver Bullet

Silver Bullet is built using Deno. To install it, you will need to have Deno installed (tested on 1.26 or later). If you have homebrew on a Mac, this is just a single brew install deno away.

To run Silver Bullet create a folder for your pages (it can be empty, or be an existing folder with .md files) and run the following command in your terminal:

deno run -A --unstable https://get.silverbullet.md <pages-path>

However, because this command is not super easy to remember, you may install it as well:

deno install -f --name silverbullet -A --unstable https://get.silverbullet.md

This will create a silverbullet (feel free to replace silverbullet in this command with whatever you like) alias in your ~/.deno/bin folder. Make sure this path is in your PATH environment variable.

This allows you to install Silver Bullet simply as follows:

silverbullet <pages-path>

By default, SB will bind to port 3000, to use a different port use the --port flag. By default SB doesnt offer any sort of authentication, to add basic password authentication, pass the --password flag.

Once downloaded and booted, SB will print out a URL to open SB in your browser (spoiler alert: by default this will be http://localhost:3000 ).

#protip: If you have a PWA enabled browser (like any browser based on Chromium) hit that little button right of the location bar to install SB, and give it its own window frame (sans location bar) and desktop/dock icon. At last the PWA has found its killer app.

Upgrading Silver Bullet

Simply run this:

deno cache --reload https://get.silverbullet.md

And restart Silver Bullet. You should be good to go.

Developing Silver Bullet

Open in Gitpod

Silver Bullet is written in TypeScript and built on top of the excellent CodeMirror 6 editor component. Additional UI is built using React.js. ParcelJS is used to build both the front-end and back-end bundles. The server backend runs as a HTTP server on node.js using express.

To prepare the initial web and plug build run:

deno task build

For convenience, you can install plugons-bundle and silverbullet into your ~/.deno/bin folder:

deno task install

You can then run the server in “watch mode” (automatically restarting when you change source files) with:

deno task watch-server -- <PATH-TO-YOUR-SPACE>

After this initial build, it's convenient to run three commands in parallel (in separate terminals):

deno task watch-web
deno task watch-server -- <PATH-TO-YOUR-SPACE>
deno task watch-plugs

Feedback

If you (hypothetically) find bugs or have feature requests, post them in our issue tracker. Would you like to contribute? Check out the code, and the issue tracker as well for ideas on what to work on.