writerp-777150 downloadsA professional writing environment with Focus Mode, Writing Binder, Sprint Timer, WordPress publishing, Folder Sidebar Explorer, and more.
Version 2.2.1 · Desktop only
Writing Studio turns Obsidian into a dedicated environment for serious nonfiction work — from your first research notes to a finished, exported manuscript. It bundles a project binder, writing modes, focus and typography tools, sprint timer, progress tracking, manuscript export, and WordPress publishing into a single plugin.
The Launcher is your home base in Writing Studio — a sidebar panel that shows your active project, progress toward your goals, and one-click access to every major feature.
By default it opens automatically when Obsidian loads. To disable this, turn off Open on startup in Settings → General.
To open manually: Click the feather ribbon icon, or assign a hotkey to Open launcher in Settings → Hotkeys.
The Launcher includes:
Projects group a set of documents (binder items) and act as the scope for export, statistics, and the word count goal banner.
To create a project: Use the command New writing project from the command palette, or click + New in the Launcher panel.
To switch projects: Use the Launcher panel or the project selector at the top of the Binder panel.
Each project stores:
Project templates available at creation:
| Template | Structure created |
|---|---|
| Blank | Empty — build your own structure |
| Book | Front Matter, Part 1 / Chapter 1, Back Matter |
| Article series | Series folder, Article 1 placeholder, series metadata |
| Blog collection | Date-organized folder, first post placeholder |
| Journal article | Title Page, Abstract, Keywords, Introduction, Literature Review, Methodology, Findings / Analysis, Discussion, Conclusion, References, Appendices |
| Magazine article | Pitch / Query Notes, Headline & Deck, Lede, Nut Graf, Body, Quotes & Sources, Kicker, Fact-Check Notes, Author Bio |
Keeping a book-length manuscript organized means knowing at a glance which chapters are drafted, which are in progress, and how each contributes to your total word count. The Binder is a sidebar panel that shows all of that for your active project.
Each document shows its title, type (Chapter, Section, Article, Note), status (Draft, In Progress, Complete), and live word count. Documents can be reordered by drag-and-drop and toggled in or out of export.
To open: Use the command Open binder from the command palette, or assign a hotkey in Settings → Hotkeys.
Adding a file to a project:
Adding files copied directly to the project folder:
If you copied or moved files into the project folder outside of Obsidian and they do not appear in the binder, use the Add files copied to this folder button in the binder toolbar (immediately to the right of the + document button). The plugin scans the project folder, lists any files not yet in the binder, and lets you select which ones to add before making any changes.
The Compile Preview opens a split pane showing all binder documents for the active project concatenated in order, rendered as a finished manuscript.
To open: Use the command Preview compiled manuscript from the command palette, or click the Preview manuscript button in the Launcher panel.
Three modes shape how the editor behaves. The current mode is always shown in the status bar. Click the mode pill in the status bar to switch modes.
| Mode | Purpose |
|---|---|
| Draft | Distraction-free drafting; spell-check and formatting hints suppressed |
| Edit | Revision pass; full editor tooling active |
| Review | Read-only style; ideal for a final proofread |
| None | Normal Obsidian behavior |
To switch modes:
The active mode persists across Obsidian restarts.
Focus Mode dims everything in the editor except the paragraph or sentence you are currently writing, reducing visual noise and keeping attention on the active thought.
To toggle: Assign a hotkey to Toggle focus mode in Settings → Hotkeys, or use the toggle in the Launcher panel. Press Escape to exit.
Settings (Settings → Focus mode):
| Setting | Description |
|---|---|
| Focus unit | Highlight at the paragraph or sentence (line) level |
| Dim opacity | How opaque the dimmed text appears (10–50%) |
| Font size override | Override the editor font size while focused; 0 = use theme default |
| Auto-hide sidebars | Collapse left and right sidebars when Focus Mode activates |
| Typewriter scroll | Keep the active line vertically centered as you type |
Typography Mode applies a consistent, reader-friendly text treatment to the editor: a curated font, constrained line length, controlled line height, and optional letter spacing.
To toggle: Assign a hotkey to Toggle typography mode in Settings → Hotkeys, or use the toggle in the Launcher panel.
To change the font while Typography Mode is active: Right-click inside the editor and choose Typography font → under Writing studio options. A font picker menu appears with all available fonts; the active font is shown with a checkmark. Selecting a font applies it immediately and saves the setting.
Note on fonts: Typography fonts are loaded from Google Fonts and require an internet connection the first time each font is used. After the initial load they are cached and work offline.
Settings (Settings → Typography):
| Setting | Description |
|---|---|
| Font family | Choose from the curated font list or enter a custom font name |
| Custom font name | Used when Custom font name… is selected above |
| Max line length | Characters per line (55–80); constrains the editor column width |
| Font size | Editor font size in pixels |
| Line height | Multiplier; default 1.7 |
| Letter spacing | CSS letter-spacing value (e.g. normal, 0.02em) |
| Persist across sessions | Keep Typography Mode active when Obsidian reopens |
Available fonts:
| Option | Font |
|---|---|
| Monospaced | iA Writer Mono (falls back to Roboto Mono / Courier New) |
| Serif | iA Writer Duo Serif (falls back to Georgia) |
| Sans-serif | iA Writer Quattro (falls back to system sans-serif) |
| Cormorant Garamond | Elegant display serif |
| Crimson Text | Classic book serif |
| EB Garamond | Traditional Garamond revival |
| Libre Baskerville | Readable web serif |
| Libre Caslon Text | Clean slab serif |
| Literata | Designed for long-form reading |
| Lora | Contemporary calligraphic serif |
| Inter | Modern humanist sans-serif |
| Lato | Friendly rounded sans-serif |
| Source Sans 3 | Clean UI sans-serif |
| Custom font name… | Use any font installed on your system |
The Sprint Timer runs a timed writing session. A countdown appears in the status bar and in a floating overlay. When the sprint ends, a summary modal shows words written, duration, and words-per-minute. The session is logged to sprint history and optionally appended to your Daily Note.
To start a sprint: Use the command Start writing sprint from the command palette, assign a hotkey in Settings → Hotkeys, or use the sprint quick-start buttons in the Launcher panel.
The sprint modal lets you set:
Settings (Settings → Sprint & goals):
| Setting | Description |
|---|---|
| Default sprint duration | Starting value in the sprint modal (minutes) |
| Default daily word goal | Target used in the Writing Dashboard and Launcher |
| Sound notifications | Play a tone when the sprint ends |
| Sprint history retention | Days to keep sprint records before purging |
| Inline goal banner | Show a progress bar below the editor toolbar when a document has a word count goal set |
A per-document word count goal can be set and tracked inline.
To set a goal:
When a goal is set and Inline goal banner is enabled, a progress bar appears below the editor toolbar showing current words, goal, and percentage. It updates in real time as you type.
The status bar shows a (+N) delta next to the current file's word count, indicating how many words you have added since opening that file this session. The Launcher's Today card also shows a cumulative session total across all files opened during the current Obsidian session. Both counts reset when Obsidian restarts.
When an active project has a total word count goal set, a dedicated status bar item shows {current} / {goal} project words. This updates automatically as you write. Set a project goal in the Project modal when creating or editing a project.
The Writing Dashboard shows session statistics (words written, sprints completed, time), sprint history, daily progress toward your goal, and per-project word counts with reading time.
To open: Use the command Open writing dashboard from the command palette, or click the Writing dashboard button in the Launcher panel.
The Targets Dashboard lets you assign word count goals to individual documents in the active project's binder and track progress across the whole project at a glance. Goals can be edited inline in the table. Rows are sortable and filterable by status.
To open: Use the command Open targets dashboard, click the Targets dashboard button in the Launcher panel, or assign a hotkey in Settings → Hotkeys.
The Writing Log is a sidebar panel that shows your writing history at a glance.
To open: Use the command Open writing log from the command palette, or click the Writing log button in the Launcher panel.
The Writing Log shows:
When Append to daily note is enabled (Settings → Writing log), a summary of each completed sprint is also appended to today's Daily Note.
When your draft is ready, the Export Engine converts it to a finished file in your chosen format — no reformatting required.
Supported formats: Manuscript (HTML) · PDF · Word (.docx) · RTF · HTML · Markdown · EPUB
To export:
Manuscript format
The Manuscript format produces a self-contained HTML file formatted to industry-standard manuscript conventions:
· · ·No external tools are required for manuscript export.
Settings (Settings → Export):
| Setting | Description |
|---|---|
| Default export format | Pre-selected format in the export modal |
| Default paper size | Letter (US) or A4 |
| Export font | Font name used in PDF/DOCX output (e.g. Georgia) |
| Export font size | Point size for PDF/DOCX output |
| Pandoc path | Full path to the pandoc binary if it is not on your system PATH |
| EPUB language | BCP 47 language tag (e.g. en, fr, de) |
| EPUB include cover | Generate a text cover page when no cover image is provided |
Requirement: Pandoc must be installed for PDF, DOCX, RTF, HTML, and EPUB export. Download from pandoc.org. For PDF export, a LaTeX distribution (e.g. TeX Live or MiKTeX) is also required. Manuscript (HTML) export does not require Pandoc.
Publish your finished draft directly to WordPress without leaving Obsidian. The modal lets you choose the target site, set the post title, status, categories, tags, excerpt, and an optional scheduled publication date.
To publish:
Setting up a site (Settings → WordPress):
https://yourblog.com), and your WordPress username.Per-site options:
| Setting | Description |
|---|---|
| Default post status | Draft · Pending Review · Published |
| Wikilink handling | Strip removes [[...]] syntax, leaving plain text · Convert turns wikilinks into URLs |
The Folder Sidebar Explorer opens a navigable folder tree in a sidebar panel. You can browse subfolders, search by name or file content, sort the listing, preview files inline, and insert copied text directly into the active editor.
To open:
Browsing and navigation:
| Feature | How to use |
|---|---|
| Browse into a subfolder | Click the folder |
| Preview a Markdown file | Click the file — renders inline |
| Preview an image | Click the file — displayed inline |
| Preview audio | Click the file — player appears inline |
| Other file types | Click the file — an Open in editor button appears |
| Go back | Click ← back, or press Backspace when the list has keyboard focus |
| Return to root folder | Click ⌂ root |
| Keyboard navigation | Tab to focus the list, then ↑ / ↓ to move, Enter to open, Backspace to go back |
| Breadcrumb navigation | Click any segment in the breadcrumb trail to jump directly to that folder |
Search:
A search bar appears at the top of the folder list. Type your query and press Enter to run the search.
.md and .txt files).Sort:
A sort dropdown sits next to the search bar. Options:
| Option | Description |
|---|---|
| Folders ↑ A-Z | Folders first, then files, both alphabetical (default) |
| Folders ↑ Z-A | Folders first, then files, both reverse-alphabetical |
| Name A-Z | All items alphabetical, folders and files mixed |
| Name Z-A | All items reverse-alphabetical, mixed |
| Newest first | Sort by last-modified date, newest at top |
| Oldest first | Sort by last-modified date, oldest at top |
Copy content to the editor:
When a Markdown file is open in preview mode, its text is selectable. To insert a passage into the active editor:
The preview is read-only — you cannot edit the file from the sidebar.
Hover tooltips:
Hover over any file or folder in the list to see an information card:
| Item type | Information shown |
|---|---|
| Markdown / text file | Last modified date and time · File size · Word count (frontmatter excluded) |
| Image / audio / other file | Last modified date and time · File size |
| Folder | Total file count · Subfolder count |
The word count updates asynchronously from Obsidian's file cache and appears within a moment of hover.
Writing Studio automatically manages YAML frontmatter in your documents when Frontmatter auto-update is enabled. On every save it updates:
word-count — current word countmodified — last-modified dateThe word-count-goal frontmatter field is read by the inline goal banner and the Word Count Goal modal.
Writing Studio adds items to Obsidian's right-click context menus. All Writing Studio items are grouped together under the heading Writing studio options to distinguish them from other plugins and Obsidian's built-in options.
| Option | Action |
|---|---|
| Export this document | Open the export modal for the current file |
| Publish to WordPress | Open the WordPress publish modal for the current file |
| Set word count goal | Set a word count target for the current document |
| Switch writing mode → | Open a mode-switcher menu (Draft / Edit / Review / None) |
| Typography font → | Open a font picker menu to change the typography font (visible only when Typography Mode is active) |
| Option | Action |
|---|---|
| Add to writing project | Open a project picker and add the file to the selected project |
| Option | Action |
|---|---|
| Open in sidebar explorer | Open the folder in the Folder Sidebar Explorer panel |
No default hotkeys are assigned. All commands can be given a hotkey in Settings → Hotkeys.
| Command | Description |
|---|---|
| Open launcher | Open the launcher sidebar panel |
| Open binder | Open the writing binder sidebar panel |
| Open writing log | Open the daily writing log panel |
| Toggle focus mode | Enable or disable focus mode |
| Toggle typography mode | Enable or disable typography mode |
| Switch to draft mode | Activate draft writing mode |
| Switch to edit mode | Activate edit writing mode |
| Switch to review mode | Activate review writing mode |
| Start writing sprint | Open the sprint timer modal |
| Export document | Export the current document |
| Export project | Export the full project |
| Preview compiled manuscript | Open the compile preview pane |
| Publish to wordpress | Publish the current document to WordPress |
| New writing project | Create a new writing project |
| Open writing dashboard | Open the statistics dashboard |
| Open targets dashboard | Open the word count targets panel |
| Set word count goal | Set a per-document word count goal |
| Open folder in sidebar explorer | Search and open a vault folder in the sidebar |
| Add files copied to project folder | Scan the active project folder for files not in the binder and import selected files |
Open via Settings → Writing Studio.
| Tab | What it controls |
|---|---|
| General | Open on startup, default project folder, author name, document type, frontmatter auto-update |
| Focus mode | Focus unit, dim opacity, font override, sidebar behavior, typewriter scroll |
| Typography | Font family, custom font name, line length, font size, line height, letter spacing, persistence |
| Sprint & goals | Sprint duration, daily goal, sound notifications, history retention, inline banner |
| Export | Format, paper size, font, font size, Pandoc path, EPUB language, EPUB cover |
| Writing log | Append sprint summaries to Daily Note |
| WordPress | Site credentials, default post status, wikilink handling |
Writing Studio adds a single icon to the Obsidian ribbon.
| Icon | Action |
|---|---|
| Feather | Open the Writing Studio Launcher panel |
All other features are accessible from the Launcher panel, the command palette, context menus, or assigned hotkeys.
main.js, manifest.json, and styles.css from the latest GitHub release.<vault>/.obsidian/plugins/obsidian-writing-studio/ if it does not exist.Building from source: Clone the repository, run
npm install, thennpm run build. Copy the three output files as above.
Most features work out of the box. A few require additional software for specific functions, noted below.
| Requirement | When needed |
|---|---|
| Obsidian 1.7.2 or later | Always |
| Desktop (Windows, macOS, Linux) | Always — this plugin does not run on mobile |
| Internet connection | First use of each Typography Mode font (cached after that) |
| Pandoc | Export to PDF, DOCX, RTF, HTML, EPUB |
| LaTeX (TeX Live / MiKTeX) | Export to PDF only |
| WordPress 5.6+ with REST API enabled | WordPress publishing |
| WordPress Application Password | WordPress publishing |
If something isn't working, please open an issue on GitHub:
Include the following when you report:
Feature requests are welcome in the same place — please label them as [Feature Request] in the issue title.
Every push and pull request is scanned automatically:
| Tool | What it checks |
|---|---|
| CodeQL | Static analysis for security vulnerabilities (XSS, injection, unsafe patterns) in TypeScript/JavaScript source |
| OpenSSF Scorecard | Supply-chain security posture: dependency hygiene, branch protection, signed releases, and more |
ESLint (eslint-plugin-obsidianmd) |
Obsidian plugin guideline compliance — fails on any warning or error |
Results are published to the Security tab of this repository (GitHub code scanning).
For local development, a pre-commit hook runs ESLint (blocking) and a pre-push hook runs a full CodeQL scan (blocks the push if any HIGH or CRITICAL findings are present). Install the CodeQL CLI to enable local scanning (winget install GitHub.CodeQL on Windows).