Skip to main content

Add your description here

Project description

Vibe Reader

Read terminal output and code files on your eink device. Designed for comfortable reading during vibe coding sessions.

Features

Tmux Integration

  • Browse and view tmux session/window/pane output
  • 1000-line scrollback history capture (configurable)
  • Smart auto-scroll: Follow content end or freeze position
  • Visual scrollbar: Shows position in scrollback and viewport size

File Browser

  • Navigate directories and view file contents
  • Visual scrollbar showing file length and current position
  • Server-side syntax highlighting for code and Markdown (tables supported)

Configuration

  • Adjustable scrollback lines (100-10000)
  • Font size selection (12-20px)
  • Settings persist via localStorage

Eink-Optimized UI

  • High contrast, large fonts, no animations
  • Collapsible sidebar, compact window display
  • Page up/down buttons for manual scrolling
  • Single-page design that fits viewport

Quick Start

# Install dependencies
uv sync

# Start server via packaged entry point (restricts file browsing to current directory by default)
uv run vibe-reader

# Or run uvicorn directly (same behavior as above)
uv run uvicorn backend.main:app --host 0.0.0.0 --port 28000

# Optional: Set custom project root for file browser (works with either command)
VIBE_READER_ROOT=/path/to/project uv run vibe-reader

# Open on your eink device
# Navigate to: http://YOUR_SERVER_IP:28000

Usage

Tmux View

  • Click to toggle sidebar
  • Select session → window (→ pane if multiple)
  • Click Refresh to update content
  • Use Page ↑/↓ for manual scrolling
  • Toggle Auto↓ to enable/disable auto-scroll to end
  • Scrollbar shows your position in scrollback history

Files View

  • Enter path or browse directories
  • Click folders to navigate, files to view
  • Page ↑/↓ for scrolling
  • Scrollbar shows file length and current position
  • Security: File browsing is restricted to the project root (configurable via VIBE_READER_ROOT)
  • File size limit: Maximum 10MB per file

Config View

  • Adjust scrollback lines (100-10000, default 1000)
  • Change font size (12-20px, default 14px)
  • Set auto-refresh interval (0-60 seconds, default 5s)
  • Click Save Settings to persist changes

Technical Details

Backend: FastAPI + libtmux Frontend: Vanilla JS, eink-optimized CSS Package Manager: uv

Environment Variables

  • VIBE_READER_ROOT: Sets the root directory for file browsing (default: current working directory)
    • Files outside this directory cannot be accessed
    • Use this to restrict file browsing to a specific project

API Endpoints

Tmux:

  • GET /api/tmux/tree - List all sessions/windows/panes
  • GET /api/tmux/pane/{session}/{window}/{pane}?scrollback=1000 - Get pane content with configurable scrollback

Files:

  • GET /api/files?path=. - List directory contents (relative to project root)
  • GET /api/files/content?path=file.txt - Render file content (max 10MB) with fields path, render_mode, html, and metadata

Design Principles

  1. Eink-first: No animations, high contrast, instant updates
  2. Minimal overhead: Direct tmux capture, simple file operations
  3. Space-efficient: Every pixel counts on small eink screens
  4. Single-page: All content fits viewport, reduces refresh artifacts

Project Structure

vibe-reader/
   backend/
      main.py          # FastAPI app with router includes
      tmux.py          # Tmux endpoints
      files.py         # File browser endpoints
   frontend/
      index.html       # Single-page UI (Tmux/Files/Config views)
      styles.css       # Eink-optimized styles
      app.js           # Client logic with scrollbar management
   pyproject.toml       # uv configuration

Requirements

  • Python 3.13+
  • tmux (for tmux viewing feature)
  • Modern browser on eink device

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vibe_reader-0.1.9.tar.gz (40.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

vibe_reader-0.1.9-py3-none-any.whl (27.0 kB view details)

Uploaded Python 3

File details

Details for the file vibe_reader-0.1.9.tar.gz.

File metadata

  • Download URL: vibe_reader-0.1.9.tar.gz
  • Upload date:
  • Size: 40.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for vibe_reader-0.1.9.tar.gz
Algorithm Hash digest
SHA256 68a9217b205b80d62b0487743a101b849cf67b1c9c9e6260f917a503e3b00ade
MD5 2739bd216a24e932b247c5f9d04056b3
BLAKE2b-256 bf18a5ce0a911e415cc3e9b7ce5ffaedcec35cd9344cca5c2e7ec9965b9011fb

See more details on using hashes here.

Provenance

The following attestation bundles were made for vibe_reader-0.1.9.tar.gz:

Publisher: publish.yml on PsychArch/vibe-reader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file vibe_reader-0.1.9-py3-none-any.whl.

File metadata

  • Download URL: vibe_reader-0.1.9-py3-none-any.whl
  • Upload date:
  • Size: 27.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for vibe_reader-0.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 808473aa4f0b61cf2d2f45cfac4056a18a93482619c2ab0b26af0f190237646d
MD5 b84888a6bcaf25e68320ea2a403a4c3e
BLAKE2b-256 58bc3bfcb8955aac9ef734b461ff205b7838ac832e48c14e64c47917f5ff58a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for vibe_reader-0.1.9-py3-none-any.whl:

Publisher: publish.yml on PsychArch/vibe-reader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page