# org-tempus `org-tempus` is an Emacs package to enhance Org's time tracking features by setting thresholds for session and daily clocked time, and sending notifications when they are reached. It optionally auto clocks in to or out of your tasks, and adjusts timestamps accordingly. ## Features - Thresholds for session and total daily clocked time. - Mode line integration. - Auto clocks in to a default task. - Auto clocks out when idle. - Supports different sources for detecting idleness: Emacs itself, Mutter (for GNOME), and freedesktop.org ScreenSaver. - Sends notifications to take a break after the session threshold is reached. - Sends notifications after a total daily time is reached. - Sends notifications when activity is detected, but no task is clocked in. - Optional integration with dconf. This is useful to display `org-tempus` values in GNOME's panel, for example. It can be used with extensions such as [simple-message](https://extensions.gnome.org/extension/5018/simple-message/). ## Example workflow - I start using my computer. `org-tempus` detects that the computer is not idle and auto clocks in to a default task. - After spending 15 minutes organizing my work, answering emails, etc., I manually clock in to another task. - After working 15 more minutes in this task, my session reaches a 30 minutes threshold, so `org-tempus` sends a notification to take a break. I stop using my computer and go for a short walk. - After 4 minutes of inactivity, `org-tempus` auto clocks out of the task, and adjusts the timestamp accordingly so it doesn't include the idle time. - Some minutes later I come back to my computer. `org-tempus` detects that my break was short, so it auto clocks me in to the last task, instead of the default. - (I repeat this pattern throughout the day) - After reaching 5 hours of focused work, `org-tempus` sends a notification to wrap up my tasks. With this workflow, I only have to manually clock in to the tasks I want to work on. I no longer need to clock out, or adjust timestamps manually if I forget to clock out when I stop using my computer. All thresholds are configurable. By default, `org-tempus` suggests work sessions of 30 minutes, and 5 hours of total work. ## Installation ```lisp (unless (package-installed-p 'org-tempus) (package-vc-install "https://github.com/rul/org-tempus.git")) (use-package org-tempus :init (org-tempus-mode 1)) ``` MELPA integration coming soon. ## Configuration `org-tempus` has many knobs. They are all documented, and can be checked out with `M-x customize-group` or `M-x apropos-variable`. These are the most relevant: - `org-tempus-session-threshold-minutes`: continuous session notification threshold. - `org-tempus-total-threshold-minutes`: total daily notification threshold. - `org-tempus-auto-clock-enabled`: master switch for auto clock in/out. It's off by default. - `org-tempus-auto-clock-default-task-id`: Org ID of the default task for auto clock-in. You can generate one by running `org-id-get-create` on a heading. - `org-tempus-idle-provider`: idle source (`emacs`, `mutter`, `freedesktop-screensaver`). - `org-tempus-notifications-enabled`: enable/disable notifications. - `org-tempus-dconf-path`: write mode line string to dconf (optional GNOME integration). An example minimal configuration could look like this: ```lisp (setq org-tempus-auto-clock-enabled t org-tempus-auto-clock-default-task-id "6fc9cfbc-0cf6-4c3f-87a9-cc49a7b6ea7b" org-tempus-idle-provider 'mutter org-tempus-dconf-path "/org/gnome/shell/extensions/simple-message/message" ) ``` ## Visual overview ### Mode line The mode line will show the session time (S), the total time (T), and the current task's total clocked time today. Clocked in When no task is clocked in, the mode line will show the total time (T), and the break time (B). Break Note: by default, `org-tempus` hides the stock Org mode line indicator and replaces it with its own entry. This is recommended, but you can toggle it off with `org-tempus-hide-org-mode-line-string` (and also control whether `org-tempus` is added to the global mode line via `org-tempus-add-to-global-mode-string`). ### Different face when thresholds are reached When thresholds are reached, the corresponding mode line section will change its color accordingly. Session threshold face Total time threshold face ### Legend off The legend provides reminders of what each number means: `S` for session. `T` for total time. After getting used to these numbers, you may want to toggle them off to save space in your mode line. Legend can be toggled off with `org-tempus-toggle-legend`. Legend off Legend off with break ### Notifications Notifications are sent when: - Session threshold is reached - Total time threshold is reached - Activity is detected but no task is clocked in.

Session notification Total time notification No task notification

Notifications can be toggled off with `org-tempus-toggle-notifications`. ### GNOME / dconf The optional integration with dconf allows for integration with GNOME's panel, so you can see your timers even if you aren't using Emacs. GNOME panel integration