2016-07-20 11:06:35 +02:00
|
|
|
#!/usr/bin/env bash
|
2016-06-04 12:45:05 +02:00
|
|
|
#
|
|
|
|
# Behavior:
|
|
|
|
# Userscript for qutebrowser which adds a task to taskwarrior.
|
|
|
|
# If run as a command (:spawn --userscript taskadd), it creates a new task
|
|
|
|
# with the description equal to the current page title and annotates it with
|
|
|
|
# the current page url. Additional arguments are passed along so you can add
|
|
|
|
# mods to the task (e.g. priority, due date, tags).
|
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
# :spawn --userscript taskadd due:eod pri:H
|
|
|
|
#
|
|
|
|
# To enable passing along extra args, I suggest using a mapping like:
|
|
|
|
# :bind <somekey> set-cmd-text -s :spawn --userscript taskadd
|
|
|
|
#
|
|
|
|
# If run from hint mode, it uses the selected hint text as the description
|
|
|
|
# and the selected hint url as the annotation.
|
|
|
|
#
|
|
|
|
# Ryan Roden-Corrent (rcorre), 2016
|
|
|
|
# Any feedback is welcome!
|
|
|
|
#
|
|
|
|
# For more info on Taskwarrior, see http://taskwarrior.org/
|
|
|
|
|
|
|
|
# use either the current page title or the hint text as the task description
|
|
|
|
[[ $QUTE_MODE == 'hints' ]] && title=$QUTE_SELECTED_TEXT || title=$QUTE_TITLE
|
|
|
|
|
|
|
|
# try to add the task and grab the output
|
2017-12-02 19:23:55 +01:00
|
|
|
msg="$(task add "$title" "$*" 2>&1)"
|
2016-06-04 12:45:05 +02:00
|
|
|
|
|
|
|
if [[ $? == 0 ]]; then
|
|
|
|
# annotate the new task with the url, send the output back to the browser
|
2016-07-06 14:04:06 +02:00
|
|
|
task +LATEST annotate "$QUTE_URL"
|
2017-12-02 19:23:55 +01:00
|
|
|
echo "message-info '$msg'" >> "$QUTE_FIFO"
|
2016-06-04 12:45:05 +02:00
|
|
|
else
|
2017-12-02 19:23:55 +01:00
|
|
|
echo "message-error '$msg'" >> "$QUTE_FIFO"
|
2016-06-04 12:45:05 +02:00
|
|
|
fi
|