zeitlings / alfred-workflows

Collected Alfred Workflows & Proof of Concept
MIT License
164 stars 5 forks source link
alfred alfred-workflow automation converter devonthink dictionary filesystem macos ocr pdf pdf-compression text-recognition window-switcher


Collected Workflows

This is a collection of smaller workflows, experiments, and demonstrations of interesting concepts for writing automations with the Alfred App.

__Some workflows live in their own repository:__ - [µBib | Citations, BibTeX, and Research](https://github.com/zeitlings/ubib) - [Quill | Text processing utility](https://github.com/zeitlings/alfred-quill) - [Ayai · GPT Nexus (preview)](https://github.com/zeitlings/ayai-gpt-nexus) - [DEVONthink 3 Portal](https://github.com/zeitlings/alfred-devonthink) - [Logseq Workflow](https://github.com/zeitlings/alfred-logseq) - [Ollama Workflow](https://github.com/zeitlings/alfred-ollama) - [Default Browser](https://github.com/zeitlings/alfred-set-default-browser/) - [Unified Search](https://github.com/zeitlings/alfred-unified-search) - [Calendar++](https://github.com/zeitlings/alfred-calendar)

Buy Me a Coffee at ko-fi.com


Table of Contents


1. Workflows

1.1. Duden Workflow

Download button for workflow: Duden workflow

Search, navigate and view information from duden.de German spelling dictionary.

Credits: SwiftSoup


1.2. What Unicode character is this?

Download button for workflow: What Unicode character is this? Swift source code button for workflow: What Unicode character is this?

The What Unicode character is this? workflow tells you which unicode character it is. Given a character or string, you will get the unicode code points, the scalar names and general categories.

Example

Modifiers

Inverse

Given a hex value either raw or in any of the above formattings will return its corresponding unicode character.


1.3. Roman Numeral Converter

Download button for workflow: Roman Numeral Converter Swift source code button for workflow: Roman Numeral Converter

Convert Roman numerals to decimal and vice versa. Accepts Arabic numbers in the range 1 to 3999.

1.4. DEVONthink ←→ PDF Expert

Download button for workflow: DEVONthink to PDF Expert

Get either the DEVONthink 3 reference URL from PDF Expert, that is the x-devonthink-item page link for the active document opened in PDF Expert, the selection link if you have text selected, or the annotation link if your selection intersects an annotation and checking for annotations is enabled.

The PDF, of course, has to live in one of your open DEVONthink databases.

Expected result A
x-devonthink-item://1D7FA99A-AAFF-4883-9853-F0666A650400?page=6
Expected result B
x-devonthink-item://1D7FA99A-AAFF-4883-9853-F0666A650400?page=6&start=66&length=9&search=selection
Expected result C
x-devonthink-item://1D7FA99A-AAFF-4883-9853-F0666A650400?page=6&annotation=Squiggly&x=212&y=406

Known issues

https://user-images.githubusercontent.com/25689591/218268102-3c07c799-4906-4d2b-9e55-38691f6b0a34.mp4

1.5. Define Word - A Better Dictionary

Download button for workflow: Define Word - A Better Dictionary

Customizable Dictionary with Quicklook Preview - and Dark Mode.

shift or cmd+Y to preview the dictionary entry
ctrl to see the dictionary associated with the entry
cmd + ⏎ to paste a word to the frontmost application (spell checker)
cmd+C to copy the dictionary entry's plain text to the clipboard
cmd+L to view the plain text as Large Type

You can define dictionaries for lookups, set the font size of the previews, or manually select a dictionary to use. The previews reflect the global appearance, i.e. they have a dark mode. The workflow also includes a preset for looking up synonyms of a word and a convenient keyboard shortcut for quick lookups. To use the workflow as a multilingual spell checker, you can use the cmd modifier when actioning the entry to paste the word to the frontmost application.

1.6. AlfredOCR

No external dependencies are required to perform the OCR.

1.6.1 Alfred OCR Light

Download button for workflow: Alfred OCR Light Swift source code button for workflow: Alfred OCR Light

The workflow allows you to copy text from images using optical character recognition. Take a snapshot with your mouse or trackpad and the recognized text is automatically copied to the clipboard.
You can also extract text from images sent to the workflow's File Action.

1.6.2 Alfred OCR+

Download button for workflow: Alfred OCR+

The workflow allows you to copy text from images, or to convert PDF files into searchable PDF documents using optical character recognition, and to apply compression to PDF documents.

1 / Snapshot
Take a snapshot with your mouse or trackpad and the recognized text is automatically copied to the clipboard.

2 / PDF Document

1.7. Favorites

Download button for workflow: Favorites

Add files and folders to your list of favorites by using the workflow's Universal Action. Quickly find them again by activating the workflow with the Keyword (default: fav) or by setting a hotkey of your choice.

1.8. New File

Download button for workflow: New File

The workflow allows you to quickly create new files in the Finder.

If the post-haste behavior is enabled, new files are created the same way as folders are when you use the shortcut (default: ⌥+⇧+N). Otherwise you will be prompted with the input mask where you can configure the file name and type.

The workflow will pick up on your location in the Finder and create the new file there. If you use the keyword, the most recently used Finder window will be selected as the destination. If no Finder window is currently open, the file will be created in the configurable fallback location.

Bonus: In addition to all plain-text type files, the workflow can also quickly create docx, doc, odt, rtf and rtfd documents and Xcode playgrounds.

Creating a new file

If auto-suggest is enabled, press TAB to accept and expand the suggested filename. (new in v1.2.0)

1.9. Keyboard Brightness

Download button for workflow: Keyboard Brightness Swift source code button for workflow: Keyboard Brightness

Adjust the keyboard backlight brightness either by using the keyword or by setting up custom shortcuts.

When using the keyword

  • type > or + to increase the brightness
  • type < or - to decrease the brightness

1.10. GIF from Video

Download button for workflow: GIF from Video

The workflow allows you to convert video of popular formats to animated GIFs. To do this, it uses ffmpeg as a dependency.

Usage

Either send a video to the workflow's File Action or invoke the workflow using the keyword and search for the video file you want to convert. Then select the image size you want the resulting GIF to have from the list to start the conversion.

1.11. Bluetooth Device Battery

Download button for workflow: Bluetooth Device Battery Swift source code button for workflow: Bluetooth Device Battery

View the battery charge status of connected Bluetooth devices
(macOS 13.0+). Install Apple's SF Pro font to see the icons.

1.12. QResolve

Download button for workflow: QResolve Swift source code button for workflow: QResolve

Resolve and open links from QR codes

Usage

A / Take a snapshot of the QR code you want to open the link to

B / Send an image containing the QR code to the workflow's File Action

1.13. GIF from Images

Download button for workflow: GIF from Images

The workflow allows you to convert a series of still images into animated GIFs. For this, it uses ImageMagick as a dependency.

Usage

Send a series of still images to the workflow's File Action to create an animated GIF. The smallest image determines the dimensions of the result. All source images are assumed to be of the same file type, e.g. jpg or png.

1.14 Extract Keywords

Download button for workflow: Extract Keywords

Extract keywords and keyphrases from articles, books or other documents with YAKE!

Usage

Dependencies

The workflow relies on Python3 to install the YAKE standalone.

YAKE!

pdftotext

1.15 Color Picker

Download button for workflow: Color Picker Swift source code button for workflow: Color Picker

Pick a color to get its hex, rgba, hsl representation or NSColor initializer.

Usage

Activate the Color Sampler with the keyword (default: cp) and pick the desired color.

Color History

To review previously picked colors, activate the workflow with the keyword preceded by a colon (default: :cp).

1.16 PDF to Text

Download button for workflow: PDF to Text

Extract text from PDF documents.

Usage

Extract the entire text from one or more PDFs by sending them to the workflow's File Action or locate a PDF with the File Filter by using the keyword (default: pdftotext). To extract the text from specific pages of a single document, use the modifier. The result will be exported as a plain text document.

File Filter

File Action

Specifying the Pages

Press to return to the view where you can set the start and end pages.

Dependencies

1.17 PDF Split

Download button for workflow: PDF Split

Easily extract a specific page range from an existing PDF document and create a new PDF file with the selected pages.

Usage

Either invoke the workflow by using the keyword (default: pdfsplit) and locate a PDF, or send a PDF to the workflow's File Action. Specify the start and end pages of the range you want to be extracted. The specified first and last page can be previewed by pressing the modifier.

Specifying the Pages

Press to return to the view where you can set the start and end pages.

Dependencies

1.18 PDF Compress

Download button for workflow: PDF Compress

Compress PDF documents.

Usage

Either invoke the workflow by using the keyword (default: pdfcompress) and locate a PDF, or send a PDF to the workflow's "Compress PDF Document" File Action.

A compression preset can be selected by pressing before proceeding with .

File Filter

File Action

Compression Presets

The result will be a compressed document in the same location as the source PDF file.

Dependencies

1.19 Scratchpad

Download button for workflow: Scratchpad

Quickly access up to 9 scratchpads for spontaneous note-taking.
🟡 🟠 🔴 🟣 🔵 🟢

Usage

Press the keyboard shortcut to open the scratchpad that was last used.
Press the keyboard shortcut again or to dismiss the scratchpad without saving.

In Editing Mode

In Markdown Mode

Press the secondary keyboard shortcut or enter the workflow's keyword (default: pad) to view all scratchpads and to search their contents.

Notes:
¹ Changes are also saved when previewing and when switching the active pad.
² When searching for a pad containing a keyword, the first matching line will be used as subtitle. Press ⌘L to view the matched line as Large Type.

1.20 Window Navigator

Download button for workflow: Window Navigator Swift source code button for workflow: Window Navigator Objective-C source code button for workflow: Window Navigator

Navigate to any window of the currently focused application or any application across all desktops, or switch windows within the current desktop space.

[!NOTE] macOS 15 deprecates an API that Window Navigator uses to retrieve window information. Already compiled executables will continue to work as expected, but compilation will fail if you try to run the workflow for the first time with macOS 15. I'm investigating a solution to this problem.

Usage

  1. Search the windows of the active app globally using the Navigator keyword.
  2. Search app windows in the current desktop space using the Switcher keyword.
  3. Search all visible windows of all apps globally using the Global keyword.
    • to navigate to the selected window.
    • to close the selected window.
    • to quit the owning application.

1. Navigator

2. Switcher

3. Global

1.21 Fuzzy Search

Download button for workflow: Fuzzy Search

Limited scope fuzzy search.
  • use fzf for classic matching
  • use fzf-abbrev for initial character matching

1.22 PDF to Table

Download button for workflow: PDF to Table

Extract tables from PDF documents as CSV.

Usage

Extract tables from PDFs via the Universal Action and export them as CSV.

Dependencies

1.23 PDF to Docx

Download button for workflow: PDF to Docx

Convert PDFs to Word documents.

Setup

Usage

Convert PDFs to Word documents (docx) via the Universal Action.


2. Proof of Concept & Demos

2.1. Extended Hotkeys

Modifier Palettes & Double Tap Hotkeys. Proof of concept and demo implementation of modifier palettes to invoke actions on consecutive keystrokes in Alfred.

Modifier Palette example behavior.

Double-Tap Hotkey example behavior

Details

The core idea is to inject environment variables into the workflow configuration and to modify them with some delay.

Disclaimer: Alfred may crash if you get the timing of the keystrokes just right. This is due to a data race where the same variable ("gate") is accessed and modified by different threads at the same time. Also, for the double-tap hotkeys, there is some "bleed" into the other hotkeys with the way it is set up in the demo. Tapping a, then b, will also trigger b, instead of having to tap b twice.


2.2. Permission Handler

An example of how to handle permissions gracefully for your executables. (For now, take a look at the Duden Workflow that implements the permission handler).

2.3. GUI Input Experiment

Run a graphical prompt and read the input. Proof of concept for using NSWindow and SwiftUI components to get user input through a graphical prompt and then use it in the Alfred app - or on the command line.

2.4. Heads-up Display

Demo for displaying notifications on a heads-up display.
The script takes two arguments: