Home

Awesome

polypomo - a polybar pomodoro widget

Usage

Download or clone this repository, then in polybar add:

; In your bar configuration add
modules-right = <other-modules> polypomo <other-modules>

; and add a polypomo module
[module/polypomo]
type = custom/script

exec = /path/to/polypomo
tail = true

label = %output%
click-left = /path/to/polypomo toggle
click-right = /path/to/polypomo end
click-middle = /path/to/polypomo lock
scroll-up = /path/to/polypomo time +60
scroll-down = /path/to/polypomo time -60

font-0 = fixed:pixelsize=10;1
font-1 = Noto Emoji:scale=15:antialias=false;0

In order to prevent accidental changes to the timer, polypomo starts in locked mode.
Middle click the widget or run polypomo lock to toggle locked state.
You can then scroll-up/down to change time.

If you wish to permanently change the default times start polypomo with --worktime seconds and --breaktime seconds.

if you want your work sessions to be logged, start polypomo with --saveto followed by the path to your database, polypomo will then create a table called sessions and store the date, start and stop time of each work session.

There isn't much else in terms of configuration but if the syntax above is confusing please refer to the polybar configuration wiki page.

Limitations

polypomo is designed to work as a single widget in your polybar.
Running multiple polypomo instances is not a supported configuration but some workarounds are possible.

Fonts

In order to display the icons as shown in the screenshots below, you need to configure a font that includes the Unicode glyphs U+1F345 (🍅) and U+1F3D6 (🏖). The example above uses the font Noto Emoji from the Noto family of fonts.

About pomodoro technique

While polypomo implements the active -> break -> active pattern it doesn't enforce the longer break after a given number of active sprees.
This is left at the discretion of the user.

Optional dependencies

polypomo makes use of notify-send to send a notification when the timer reaches zero.

Screenshots

pomodoro timer
break timer

License

polypomo is licensed under the MIT license

Troubleshooting

If you are finding that polypomo doesn't start or error messages are visible in polybar, try the following:

  1. Remove polypomo from polybar's configuration
  2. Ensure no polypomo process is active on your system
  3. Open two terminals/consoles and navigate to the polypomo repository
  4. On the first terminal run ./polypomo. You should see some output appearing.
  5. On the second terminal issue one of the polypomo commands listed above. For instance ./polypomo toggle. The output in terminal one should change accordingly.

If an error appears in either case, please submit a bug report with the full output and the steps to reproduce the problem.

To stop polypomo on the first terminal run ./polypomo exit in the second terminal or simply hit Ctrl + C to abort the process.

Received exit request...

If this message appears repeatedly in polybar, you may be running multiple instances of polypomo simultaneously and they are forcing each other to exit. Reconfigure polybar to run only one polypomo instance or see the Limitations section above for possible workarounds.

Alternatively, stop polybar and run the above troubleshooting steps. If manually running polypomo with the two terminal setup works, review your polybar configuration to ensure only one instance of polypomo is launched.