Skip to main content

Exercise reminder overlay for Claude Code thinking time

Project description

vibe-wellness

PyPI Publish macOS python

中文

I vibe-code 8+ hours a day. Hours disappear, my back hurts, I forget to drink water. Sound familiar?

Your AI pair programmer doesn't need to stretch. You do.

demo

vibe-wellness is a native macOS overlay that hooks directly into Claude Code to remind you to move, stretch, and hydrate — inside your workflow, not as notifications you'll ignore.

  • 3-second countdown with exercise name
  • Animated stick figure GIF showing the exercise
  • Progress bar + auto-dismiss after 30 seconds (or click to dismiss)

30-second setup

One-liner:

curl -fsSL https://raw.githubusercontent.com/odysa/vibe-wellness/main/install.sh | bash

Or with uv:

uvx vibe-wellness

Both methods will:

  1. Install vibe-wellness via uv tool install
  2. Run the interactive setup wizard (language, interval, exercises, hook)
  3. Create a hook script at ~/.claude/hooks/vibe-wellness/show.sh
  4. Register the hook in ~/.claude/settings.json

Re-configure

Run vibe-wellness again to change settings.

Exercises

Key English 中文
kegels Kegels 提肛
drink_water Drink Water 喝水
squats Squats 深蹲
wall_pushups Wall Push-ups 靠墙俯卧撑
neck_rolls Neck Rolls 颈椎运动

All exercises include animated stick figure GIFs.

Configuration

Edit ~/.config/vibe-wellness/config.json:

{
  "lang": "zh",
  "interval": 15
}
Key Default Description
lang "auto" "en", "zh", or "auto" (detect system)
interval 15 Minutes between exercise reminders
duration 30 Overlay display time in seconds
opacity 0.95 Window opacity (0.0 - 1.0)
exercises (built-in) Custom exercise list
sedentary.enabled true Enable sedentary reminder
sedentary.interval 30 Minutes between sedentary alerts

Custom exercises

Exercises merge with defaults by key:

{
  "exercises": [
    { "key": "stretching", "name": { "en": "Stretch", "zh": "拉伸" } }
  ]
}

Custom GIFs

Drop {key}.gif in ~/.config/vibe-wellness/gifs/ to override any exercise animation.

Uninstall

vibe-wellness --uninstall

How it works

~/.claude/settings.json          Hook triggers on UserPromptSubmit/Stop/Notification
  -> ~/.claude/hooks/vibe-wellness/show.sh
    -> ~/.local/bin/vibe-wellness --show
      -> checks interval + single-instance lock
      -> spawns overlay (tkinter, borderless, always-on-top)
vibe_wellness/
  cli.py          Entry point
  installer.py    Interactive setup wizard (TUI)
  show.py         Single-instance guard + interval check
  ui.py           Overlay window (tkinter + CoreGraphics + ObjC runtime)
  config.py       Config loading, i18n, language detection
  uninstall.py    Clean removal
  config.json     Default exercises
  gifs/           Bundled exercise GIFs

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_wellness-0.4.6.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

vibe_wellness-0.4.6-py3-none-any.whl (188.7 kB view details)

Uploaded Python 3

File details

Details for the file vibe_wellness-0.4.6.tar.gz.

File metadata

  • Download URL: vibe_wellness-0.4.6.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for vibe_wellness-0.4.6.tar.gz
Algorithm Hash digest
SHA256 350d838baa8b7a5cff9fd3a3a2189f7867caa79036c188f393db9b2c056a6125
MD5 7f004e323d4064ab85bd9e756f2e956b
BLAKE2b-256 0d336a20e969dffbc0f2e880b36cc07d8cf7acb48ed0b15ed404081d661c5590

See more details on using hashes here.

Provenance

The following attestation bundles were made for vibe_wellness-0.4.6.tar.gz:

Publisher: publish.yml on odysa/vibe-wellness

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_wellness-0.4.6-py3-none-any.whl.

File metadata

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

File hashes

Hashes for vibe_wellness-0.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 788ad6db224445ecdb831e1b7b9697f9a206bcd5ac085b76f0080babf65fd99a
MD5 c6eb0737a10deadc6e25ffa15237a5c5
BLAKE2b-256 7ccfee192a1f7ee3410b3a2d3f9869c6dd1fe08efa738a1c1213b56e9fb08b55

See more details on using hashes here.

Provenance

The following attestation bundles were made for vibe_wellness-0.4.6-py3-none-any.whl:

Publisher: publish.yml on odysa/vibe-wellness

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