Focus macOS apps with keyboard shortcuts.
Project description
flick - focus apps with keyboard shortcuts
Is Emacs the only app you use? The only app installed on your Mac? Of course it is.
But if you're one of the few lost souls who uses multiple apps, plural? Who don't use Emacs to call their mothers and change flat tires?
flick is for you.
flick focuses macOS apps with keyboard shortcuts. It makes switching apps really fast.
Press key. Focus app. That's it.
The cursor is also, optionally, warped to the center of the newly focused window. Reduces mouse travel. Handy. (pun intended)
Flicks wraps pyobjc. It's fast - sub 70ms per flick.
Installation
pip install flick
Requires macOS and Python3.
How to use it
Once installed, run the command flick. You can background it with:
flick &
Then click 🎯 in the macOS menu bar to create shortcuts.
To add a flick shortcut, click Add App Shortcut. Then enter the name
of the app, like emacs. App names are case insensitive.
Add all your commonly used apps and voila: switch apps 10x faster.
How it works
flick listens for global keyboard shortcuts. When a keyboard shortcut
fires, flick:
-
Finds the app that matches the app name string. Eg:
chromefor Google Chrome,emacsEmacs (😉),slackfor Slack, etc. App names are case-insensitive substrings;emacsmatchesEmacs,emacs,emacs-29, etc. -
Picks the most recently used window. If the app has multiple windows, the window used most recently is focused. flick continuously tracks when windows are focused after startup with macOS's Accessibility API. If flick was just started and is thus without a history of focused windows, the app's main window is focused by default.
-
Centers the cursor in the
(x,y)center of the focused window. That way you move the mouse less. You lazy bones.
Permissions
flick uses the macOS Accessibility API and requires permission on first
run. To otherwise grant flick its needed permissions, go to System
Settings → Privacy & Security → Accessibility and enable the terminal
(or whatever parent app) you used to run flick.
Usage
flick # start the daemon
flick -h # show help
flick --version # show version
Development
For local development:
- Check out this repo.
- Modify flick.py.
- Run flick.py.
- Have fun.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file flick-0.1.1.tar.gz.
File metadata
- Download URL: flick-0.1.1.tar.gz
- Upload date:
- Size: 16.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.7.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
53509c40c932a515e28dbfe1981bbb0ad26a99ba6a66eb53a72db7b7929d8842
|
|
| MD5 |
0d0291deb3cfa118eb1a23efc7238f6b
|
|
| BLAKE2b-256 |
419fed52cabc9adbd82847ad99d8a42dbf8edeee814f18d033d4e8e2f4aaf850
|
File details
Details for the file flick-0.1.1-py3-none-any.whl.
File metadata
- Download URL: flick-0.1.1-py3-none-any.whl
- Upload date:
- Size: 17.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.7.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7116e45fa4b66ff5ba881ae18d1c1dd457601f4777c98a2c93cfaee7204002ae
|
|
| MD5 |
1f409c637e1a2e2983ea784f036cd595
|
|
| BLAKE2b-256 |
ddee5bb435de320b096829d14d8dec7924cfe15ae0a090bbb3d591f2969684ff
|