Collect all browser URLs, output to terminal, and archive to todoist. Useful for cleaning up your workspace at the end of the day, without loosing important urls.
Project description
Clean Workspace: Archive Web Browser Tabs
I love experimenting with productivity. One glitch I've found in my mind is I can easily get distracted by open tabs on my browser, especially if I'm trying to write or read something which I want to give my full attention to. I've found that if I close all my tabs (similar idea to shrinking context size), I can focus better on the task at hand. However, I don't want to lose any interesting tabs so I never actually do that.
This is utility to fix this issue. It closes all your tabs (in both Safari & Chrome), sends them to todoist with a specified project + label, and outputs the list to the terminal (mostly for debugging).
This has seemed to really help my mind and make it easy for me to find interesting things I've run into in the past.
Installation
pip install clean-workspace
TODOIST_API_KEY
has to exist in your shell environment for the tool to run. I recommend using direnv to do this. Add your todoist token to.envrc
anddirenv allow .
- Customize the url and domain blacklist
Usage
❯ clean-workspace --help
Usage: clean-workspace [OPTIONS]
Options:
--blacklist-domains PATH
--blacklist-urls PATH
--tab-description TEXT Description for tab
--todoist-label TEXT label in todoist for all created tasks [default:
web-archive]
--todoist-project TEXT project in todoist for all created tasks
[default: Learning]
--help Show this message and exit.
Development
poetry install
poetry run clean-workspace
Regex Entries
You can use regex matches in both the url and domain blacklist files. For example, if you want to blacklist all Zoom domains, you can use the following:
echo "/.*zoom\.us/" >> ~/.config/clean-workspace/blacklist-domains.txt
A regex entry starts & ends with /
, like sed
.
Collecting Tab Description Via AppleScript
Here's a quick script you can use to collect a description of what you were working on via applescript:
dialogResult=$(
osascript <<EOT
set dialogResult to display dialog "What were you working on yesterday?" buttons {"OK"} default button "OK" giving up after 300 default answer ""
return text returned of dialogResult
EOT
)
Here's a full example of using this with hyper-focus.
Inspiration
- https://gist.github.com/aleks-mariusz/cc27b21f2c5b91fbd285
- https://github.com/tominsam/shelf-python/blob/f357d9b147fa651034b71501edabf65f59d5befa/extractors/ComAppleSafari.py#L11
TODO
- Indicate in python config that this is macOS only in poetry config?
- move blacklist files into example area of repo
- look at previous tasks and see if links are contained there before including them again
- support google chrome canary
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for clean_workspace-0.4.5-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0436a800b9c82e323dcec02e9145d1576a7e8ea3e40d92cf80222dd5b232905d |
|
MD5 | a3c41bf25ec304bee8c40fee7a6f64ee |
|
BLAKE2b-256 | a64103bbb42a848d9f368897c8b5c2548c3f0586961efbaa8b3704b23ddd5c51 |