Skip to content

Latest commit

 

History

History
58 lines (40 loc) · 3.08 KB

README.md

File metadata and controls

58 lines (40 loc) · 3.08 KB

Readwise daily reviews, now in Obsidian

This is a beta plugin adding features to the Readwise x Obsidian integration.

Motivation

I use both Readwise (https://readwise.io/) and Obsidian (https://obsidian.md) regularly. When reviewing my daily highlights in Readwise, I'd sometimes want to connect the highlight to something in my Obsidian vault.

Since my vault already has all of my Readwise highlights—and since I personally have each highlight exported as one block (a callout)—this plugin is mostly a matter of finding the block corresponding to some highlight.

How it works

This requires a paid subscription to Readwise.

The plugin assumes that the official Readwise integration for Obsidian is installed. We use the official plugin's data for both (1) your Readwise API token and (2) the filename to book ID mapping.

We register a new command, "Add daily review highlights to current note." This gets your Readwise daily review from the API, attempts to locate each highlight in the vault, and presents them in a modal.

Screenshot of the modal with each of the review's highlight.

Sharp edges

We read your Readwise API token from the official plugin's data. I don't know whether this is explicitly forbidden—the developer policy makes no mention of this—but it's at minimum questionable (and undocumented). That said, I built the plugin for my personal use; the plugin makes no attempt to hide this; the command is gated by a user action; and we only make read/GET requests.

Since the request volume is so low and the user is fully in-control, we don't make any attempt to cache responses or rate limit the requests.

The plugin assumes that highlights are stored and formatted the way that my vault stores and formats them. Specifically:

  • Each highlight is wrapped in a callout
  • The callout has a block reference ID, the string rw plus the highlight ID (e.g., rw0041401448)
  • You use [[Markdown links]] and not [wiki](links).

The plugin will ignore (silently or gracefully, depending on your perspective) highlights that it can't find (because the file was deleted, because there are multiple files with the book's name, etc.).

Tools and development

This project uses:

  • bun as a package manager
  • vite as a bundler (because bun doesn't support CJS bundling)
  • biome for linting and formatting
  • hot-reload for simpler development

To develop the project:

  • Clone this repo.
  • Install bun, if needed.
  • Install dependencies with bun install.
  • Start the development server with bun dev.
  • Format and lint (with autofixes) with bun fix.

Releases

I have not released this plugin and don't plan to. If you're interested in using this plugin, please install it via the excellent and community-maintained BRAT

Issues, PRs, and discussions are welcome.