README file from
GithubObsidian Book Exporter
Write a book inside an Obsidian vault — one manifest note acts as the table of contents, each chapter / section is its own note. The plugin compiles the structure into a single manuscript and exports to EPUB and PDF via Pandoc.
Desktop only. Requires
pandocon$PATH(or configure the path in settings). For PDF, Typst is the recommended engine — single small binary, no LaTeX install needed. LaTeX engines (xelatex, tectonic) are still supported if you prefer.Configure an output folder before exporting. Settings → Book Exporter → Default output folder: an absolute filesystem path (e.g.
~/Downloads). The plugin refuses to export until this is set. Temp files live in the OS temp directory — never in your vault or plugin folder.
How it works
- Open any Markdown note that you want to use as the book manifest. Put book metadata in the frontmatter, structure the body with headings and bulleted wikilinks — no specific tag, folder, or filename required.
- Run Export current book to EPUB / PDF / all formats from the command palette.
The manifest contract
# H1is the book title (or usetitle:in frontmatter — that wins).- Every
## H2…###### H6is a section at that level. Sections nest by level. - Every bullet under a section that contains one or more
[[wikilinks]]contributes those links — in source order — to the section. The linked notes are inlined at that point in the manuscript. - Bullets without wikilinks are kept as part of the section's prose; text around a wikilink in a wikilink-bearing bullet is dropped (treated as author commentary).
- Anything else under a section (paragraphs, tables, blockquotes, code fences) is kept verbatim between the heading and the inlined notes. Lets you write
## Acknowledgmentswith just a paragraph and no links. - The structure is yours: parts → chapters → scenes, or chapters → sections, or just a flat list of chapters. The plugin doesn't care. When you mix two heading levels (parts + chapters), each new part starts on a fresh right-hand page in print, each new chapter on a new page.
- A standalone
---line in any note's body (or in the manifest's section prose) is converted to a hard page break. Use it to force a page break wherever the automatic chapter / part breaks aren't enough. (YAML frontmatter delimiters are stripped first;---inside a fenced code block is left alone.)
Example manifest
---
title: The Context Layer
authors: [Sébastien Dubois]
language: en
publisher: DeveloPassion
description: A book about turning notes into knowledge.
cover:
covers/the-context-layer.jpg # vault path, [[wikilink]], absolute path, or http(s) URL
# the frontmatter key (default `cover`) is configurable in settings
book_export:
formats: [epub, pdf]
pdf_engine: typst
page_break_per_chapter: true
sections_to_skip: [Related, References, Title Options, Target Audience]
output_dir: '~/Books/The Context Layer'
---
# The Context Layer
## Foreword
- [[Foreword]]
## Part I — The Problem
### Chapter 1 — Why Notes Fail
- [[Why Notes Fail]]
- [[The Cost of Forgetting]]
### Chapter 2 — The Cost
- [[The Cost]]
## Part II — The Solution
### Chapter 3 — Building Context
- [[Building Context]]
## Acknowledgements
- [[Acknowledgements]]
- [[About the Author]]
What gets cleaned up
When a linked note is inlined, the plugin:
- Strips its frontmatter.
- Removes configurable sections (default:
Related,References,Title Options,Target Audience) — case-insensitive heading match, fence-aware. The same list is applied to the manifest body before parsing, so authoring scaffolding (## Title Options,## Target Audience,## References,## Related) stays in the manifest but never reaches the export. - Drops the note's first
# H1(the section title in the manifest is authoritative). - Demotes remaining headings so they nest under the manifest section (offset =
parentLevel - 1, capped at H6). - Rewrites Obsidian-only syntax: callouts → fenced divs,
![[image]]→ standard Markdown images (copied to_resources/),[[Note]]→ display text,%% comments %%stripped.
Commands
Book Exporter: Export current book to EPUBBook Exporter: Export current book to PDFBook Exporter: Export current book to all formatsBook Exporter: Preview compiled manuscript (.md)Book Exporter: Validate current bookBook Exporter: Open exports folder
Installation
Community plugins (recommended)
- In Obsidian, go to Settings → Community plugins.
- Disable Restricted mode if it's enabled.
- Select Browse, search for Book Exporter, install it, then enable it.
You can also browse the catalog on the Obsidian Community website.
Manual installation
If the plugin isn't listed in the community catalog yet (or you want a specific version):
- Download
main.js,manifest.json, andstyles.cssfrom the latest release. - Copy them into
<Vault>/.obsidian/plugins/book-exporter/. - Reload Obsidian and enable Book Exporter in Settings → Community plugins.
BRAT (bleeding edge)
BRAT (Beta Reviewers Auto-update Tool) installs plugins straight from a GitHub repo and keeps them updated automatically. Use this if you want the latest commits — things might break.
- Install Obsidian42 - BRAT from Settings → Community plugins → Browse and enable it.
- Run BRAT: Add a beta plugin for testing from the command palette.
- Paste
https://github.com/dsebastien/obsidian-book-exporter. - Select the latest version and confirm.
- Enable Book Exporter in Settings → Community plugins.
Development setup
From source
git clone https://github.com/dsebastien/obsidian-book-exporter.git
cd obsidian-book-exporter
bun install
export OBSIDIAN_VAULT_LOCATION="/path/to/your/vault"
bun run dev
The dev build copies the plugin into <vault>/.obsidian/plugins/book-exporter/ automatically and writes a .hotreload marker for the Hot Reload plugin.
External tools
| Tool | Required for | Install |
|---|---|---|
| Pandoc ≥ 3.x | EPUB, PDF | https://pandoc.org/installing.html |
| Typst (recommended PDF engine) | https://typst.app — single binary | |
| xelatex / tectonic (alternative PDF engines) | only if you prefer LaTeX |
Status
Pre-release. Unstable. See documentation/plans/01-mvp.md for the design and documentation/history/ for the change log.
License
MIT. See LICENSE.