Giter Club home page Giter Club logo

work-break's Introduction

work-break

Introduction

This balancer can track your work time and suggest resting time. It uses this graph by default, where the horizontal axis is for work time, and the vertical axis is for resting time. It passes through the Pomodoro Technique (25/5) and the 52/17 rule. The formula can be adjusted (see the configuration section below).

The more you work, the more rest you need per work minute. Sometimes, you have to start working without waiting until you have rested suggested time. In this case, this balancer accumulates strain by subtracting the actual rest time from the needed rest time and converting the result into work time back. It adds up to the following work on the next break.

This balancer sends you notifications on the following events:

  • Work lasted for 25 minutes (can be changed)
  • It lasted for 52 minutes (can be changed)
  • It lasted for the daily work time limit if it is configured
  • Break ended

The notification contains the current phase, strain and today work time, needed break, its end if it starts.

How to install

Compatibility

Windows 8+ (may require MS Visual C++ 2015, tested on Windows 10/11)

MacOS 10+ (tested on MacOS 11.7)

Linux/BSD: should work with many distributions (tested on Arch Linux)

Download a binary

Download a suitable binary from releases page.

Arch Linux based distributions

The app can be installed using the PKGBUILD work-break, available on the AUR. This can be built and installed using an AUR helper or by hand in the usual way.

With Cargo

You will need the Rust programming language (v1.59.0+) and its cargo package manager installed on your system. See the official documentation here.

Run this command to install the app (make sure that the cargo bin directory is in $PATH):

cargo install work-break

Configure a shortcut key or create a desktop icon to switch between work and rest time:

work-break

Configure the following command to launch the balancer on startup to get notifications (optional, but recommended):

work-break autorun

Configure a shortcut key or create a desktop icon to notify about the current status (optional):

work-break notify

To print the current status in CLI, you can use this (MacOS / Linux):

work-break status

Configuration

After the first app launch, you can change the app's configuration by editing the following configuration file:

Windows
%APPDATA%\work-break\config\default-config.toml
MacOS
~/Library/Application\ Support/rs.work-break/default-config.toml
Linux
~/.config/work-break/default-config.toml

or you can delete the file to get the defaults:

Defaults
coefficient_a = 0.00147884224225867
coefficient_b = 1.67098454496329
coefficient_c = 0
coefficient_d = 0

daily_work_time_limit = 0
work_days_start_at = 0

phase1_ends_at = 25
phase1_name = "Pomodoro"
phase2_ends_at = 52
phase2_name = "Efficiency"
phase3_name = "Injury"

The coefficients are used for the formula: break = a * (work ^ (b + d * today_work)) + c. Variables work, today_work and break represent in seconds. Consider setting coefficient_d to 0.00001528 to see how today work time can increase resting time.

daily_work_time_limit represents in minutes, sends you notification when today work time reaches the limit, zero turns the notification off.

work_days_start_at defines an hour when work days start at and count resets (from 0 to 23).

phase1_ends_at and phase2_ends_at define current strain's thresholds to send you notifications.

phase1_name, phase2_name, and phase3_name define phases' names to print in notifications.

Restart your system or ask the app to apply the changed configuration:

work-break reload

Troubleshooting

Windows 11: App does not run and its notifications do not appear. "Do not disturb" mode is off.

Look at how to restore PowerShell notifications

Similar projects

Bartib is a simple time tracker for the command line. It saves a log of all tracked activities as a plaintext file and allows you to create flexible reports.

work-break's People

Contributors

shadoysv avatar

Stargazers

 avatar  avatar

Watchers

 avatar

Forkers

pace-rs

work-break's Issues

Collab

Hey there,
I found your tool by chance while searching for pomodoro or something on crates.io.

I'm currently building https://github.com/pace-rs/pace because I felt my use case for tracking work and break times is not fulfilled by a lot of tools out there. I see that you also spend a lot of time thinking about time management techniques and I like what you did with work-break as it inspired me for some ideas for pace.

Doing the same work should be discouraged. Working together should be applauded.

Based on that, I wanted to ask if you feel like joining the cause and help to implement pace. :) There is a discord link in the repository, if you want to discuss further, would be happy to see you there.

Cheers,
Simon

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.