# Foam **Foam** is a personal knowledge management and sharing system inspired by [Roam Research](https://roamresearch.com/), built on [Visual Studio Code](https://code.visualstudio.com/) and [GitHub](https://github.com/). You can use **Foam** for organising your research, keeping re-discoverable notes, writing long-form content and, optionally, publishing it to the web. **Foam** is free, open source, and extremely extensible to suit your personal workflow. You own the information you create with Foam, and you're free to share it, and collaborate on it with anyone you want.

New! Join Foam community Discord for users and contributors!

Star Use this template
## Table of Contents - [Foam](#foam) - [Table of Contents](#table-of-contents) - [How do I use Foam?](#how-do-i-use-foam) - [What's in a Foam?](#whats-in-a-foam) - [Getting started](#getting-started) - [Features](#features) - [Call To Adventure](#call-to-adventure) - [Thanks and attribution](#thanks-and-attribution) - [License](#license) ## How do I use Foam? **Foam** is a tool that supports creating relationships between thoughts and information to help you think better. ![Foam kitchen sink, showing a few of the key features](assets/images/foam-features-dark-mode-demo.png) Whether you want to build a [Second Brain](https://www.buildingasecondbrain.com/) or a [Zettelkasten](https://zettelkasten.de/posts/overview/), write a book, or just get better at long-term learning, **Foam** can help you organise your thoughts if you follow these simple rules: 1. Create a single **Foam** workspace for all your knowledge and research following the [Getting started](#getting-started) guide. 2. Write your thoughts in markdown documents (I like to call them **Bubbles**, but that might be more than a little twee). These documents should be atomic: Put things that belong together into a single document, and limit its content to that single topic. ([source](https://zettelkasten.de/posts/overview/#principles)) 3. Use Foam's shortcuts and autocompletions to link your thoughts together with `[[wiki-links]]`, and navigate between them to explore your knowledge graph. 4. Get an overview of your **Foam** workspace using a [[graph-visualisation]] (⚠️ WIP), and discover relationships between your thoughts with the use of [[backlinking]]. Foam is a like a bathtub: _What you get out of it depends on what you put into it._ ## What's in a Foam? Like the soapy suds it's named after, **Foam** is mostly air. 1. The editing experience of **Foam** is powered by VS Code, enhanced by workspace settings that glue together [[recommended-extensions]] and preferences optimised for writing and navigating information. 2. To back up, collaborate on and share your content between devices, Foam pairs well with [GitHub](http://github.com/). 3. To publish your content, you can set it up to publish to [GitHub Pages](https://pages.github.com/), or to any website hosting platform like [Netlify](http://netlify.com/) or [Vercel](https://vercel.com). > **Fun fact**: This documentation was researched, written and published using **Foam**. ## Getting started > ⚠️ Foam is still in preview. Expect the experience to be a little rough. These instructions assume you have a GitHub account, and you have Visual Studio Code installed. 1. Use the [foam-template project](https://github.com/foambubble/foam-template) to generate a new repository. If you're logged into GitHub, you can just hit this button: Use this template *If you want to keep your thoughts to yourself, remember to set the repository private, or if you don't want to use GitHub to host your workspace at all, choose [**Download as ZIP**](https://github.com/foambubble/foam-template/archive/master.zip) instead of **Use this template**.* 2. [Clone the repository locally](https://help.github.com/en/github/creating-cloning-and-archiving-repositories/cloning-a-repository) and open it in VS Code. *Open the repository as a folder using the `File > Open...` menu item. In VS Code, "open workspace" refers to [multi-root workspaces](https://code.visualstudio.com/docs/editor/multi-root-workspaces).* 3. When prompted to install recommended extensions, click **Install all** (or **Show Recommendations** if you want to review and install them one by one) After setting up the repository, open `.vscode/settings.json` and edit, add or remove any settings you'd like for your Foam workspace. To learn more about how to use **Foam**, read the [[recipes]]. Getting stuck in the setup? Read the [[frequently-asked-questions]]. Check our [issues on GitHub](http://github.com/foambubble/foam/issues) if you get stuck on something, and create a new one if something doesn't seem right! ## Features **Foam** doesn't have features in the traditional sense. Out of the box, you have access to all features of VS Code and all the [[recommended-extensions]] you choose to install, but it's up to you to discover what you can do with it! ![Short video of Foam in use](assets/images/foam-navigation-demo.gif) Head over to [[recipes]] for some useful patterns and ideas! ## Call To Adventure The goal of **Foam** is to be your personal companion on your quest for knowledge. It's currently about "10% ready" relative to all the features I've thought of, but I've only thought of ~1% of the features it could have, and I'm excited to learn from others. I am using it as my personal thinking tool. By making it public, I hope to learn from others not only how to improve Foam, but also to improve how I learn and manage information. If that sounds like something you're interested in, I'd love to have you along on the journey. - Read about our [[principles]] to understand Foam's philosophy and direction - Read the [[contribution-guide]] guide to learn how to participate. - Feel free to open [GitHub issues](https://github.com/foambubble/foam/issues) to give me feedback and ideas for new features. ## Thanks and attribution

Jani Eväkallio

💻 📖

Joe Previte

💻 📖

Riccardo

💻 📖

Janne Ojanaho

💻 📖

Paul Shen

📖

coffenbacher

📖

Mathieu Dutour

📖

Michael Hansen

📖

David Nadlinger

📖

Fernando

📖

Juan Gonzalez

📖

Louie Christie

📖

Sandro

📖

Simon Knott

📖

Steven

📖

Tim

📖

Saurav Khdoolia

📖

Ankit Tiwari

📖 ⚠️ 💻

Ayush Baweja

📖

TaiChi-IO

📖

Juan F Gonzalez

📖

Sanket Dasgupta

📖 💻

Nicholas Stafie

📖

Francis Hamel

💻

digiguru

💻 📖

CHIRAG SINGHAL

💻

Jonathan Carter

📖

Julian Elve

📖

Thomas Koppelaar

💬 💻 📓

Akshay

💻

John Lindquist

📖

Ashwin Ramaswami

📖

Claudio Canales

📖

vitaly-pevgonen

📖

Dmitry Shemetov

📖

hooncp

📖

Martin Laws

📖

Sean K Smith

💻

Kevin Neely

📖

Arief Rahmansyah

📖

Vishesh Handa

📖

Hitesh Kumar

📖

Spencer Woo

📖

ingalless

💻 📖

José Duarte

💻 📖

Yenly

📖

hikerpig

💻

Sigfried Gold

📖

Tristan Sokol

💻

Danil Rodin

📖

Scott Williams

📖

jackiexiao

📖

John B Nelson

📖

Asif Mehedi

📖

Tan Li

💻

Shauna Gordon

📖

Mike Cluck

💻

Brandon Pugh

💻

Max Davitt

📖

Brian Anglin

📖

elswork

📖

léon h

💻

Nikhil Nygaard

📖

Mark Dixon

💻

Joel James

💻

Hashiguchi Ryo

📖

Michael Overmeyer

💻

Derrick Qin

📖

Omar López

📖

Robin King

💻
**Foam** was inspired by [Roam Research](https://roamresearch.com/) and the [Zettelkasten methodology](https://zettelkasten.de/posts/overview) **Foam** wouldn't be possible without [Visual Studio Code](https://code.visualstudio.com/) and [GitHub](https://github.com/), and relies heavily on our fantastic open source [[recommended-extensions]] and all their contributors! ## License Foam is licensed under the [MIT license](license). [//begin]: # "Autogenerated link references for markdown compatibility" [graph-visualisation]: features/graph-visualisation.md "Graph Visualisation" [backlinking]: features/backlinking.md "Backlinking" [recommended-extensions]: recommended-extensions.md "Recommended Extensions" [recipes]: recipes/recipes.md "Recipes" [frequently-asked-questions]: frequently-asked-questions.md "Frequently Asked Questions" [principles]: principles.md "Principles" [contribution-guide]: contribution-guide.md "Contribution Guide" [//end]: # "Autogenerated link references"