Improvements to notification formatting and options

This commit is contained in:
Michael Aquilina 2019-07-21 21:50:45 +01:00
parent 7b6d59479a
commit cac8315195
No known key found for this signature in database
GPG key ID: 636066730B056BD1
2 changed files with 26 additions and 10 deletions

View file

@ -1,5 +1,7 @@
export AUTO_NOTIFY_VERSION="0.3.0"
# Time it takes for a notification to expire
export AUTO_NOTIFY_EXPIRE_TIME=8000
# Threshold in seconds for when to automatically show a notification
export AUTO_NOTIFY_THRESHOLD=10
# List of commands/programs to ignore sending notifications for
@ -10,16 +12,23 @@ export AUTO_NOTIFY_IGNORE=(
function _auto_notify_message() {
local command="$1"
local elapsed="$2"
local exit_code="$3"
local platform="$(uname)"
# Run using echo -e in order to make sure notify-send picks up new line
local text="$(echo -e "\"$command\" has completed\n(Total time: $elapsed seconds)")"
local title="\"$command\" Completed"
local text="$(echo -e "Total time: $elapsed seconds\nExit code: $exit_code")"
if [[ "$platform" == "Linux" ]]; then
notify-send "$text"
local urgency="normal"
if [[ "$exit_code" != "0" ]]; then
urgency="critical"
fi
notify-send "$title" "$text" "--urgency=$urgency" "--expire-time=$AUTO_NOTIFY_EXPIRE_TIME"
elif [[ "$platform" == "Darwin" ]]; then
# We need to escape quotes since we are passing a script into a command
text="${text//\"/\\\"}"
osascript -e "display notification \"$text\" with title \"Command Completed\""
title="${title//\"/\\\"}"
osascript -e "display notification \"$text\" with title \"$title\""
else
printf "Unknown platform for sending notifications: $platform\n"
printf "Please post an issue on gitub.com/MichaelAquilina/zsh-auto-notify/issues/\n"
@ -44,6 +53,9 @@ function _is_auto_notify_ignored() {
}
function _auto_notify_send() {
# Immediately store the exit code before it goes away
local exit_code="$?"
if [[ -z "$AUTO_COMMAND" && -z "$AUTO_COMMAND_START" ]]; then
return
fi
@ -53,7 +65,7 @@ function _auto_notify_send() {
let "elapsed = current - AUTO_COMMAND_START"
if [[ $elapsed -gt $AUTO_NOTIFY_THRESHOLD ]]; then
_auto_notify_message "$AUTO_COMMAND" "$elapsed"
_auto_notify_message "$AUTO_COMMAND" "$elapsed" "$exit_code"
fi
fi

View file

@ -4,7 +4,9 @@
load "../auto-notify.plugin.zsh"
function notify-send {
echo - "Notification: $@"
echo - "Notification Title: $1"
echo - "Notification Body: $2"
echo - "${@:3}"
}
function uname {
@ -83,8 +85,10 @@
run _auto_notify_send
assert $state equals 0
assert "$lines[1]" same_as 'Notification: "f bar -r" has completed'
assert "$lines[2]" same_as "(Total time: 20 seconds)"
assert "$lines[1]" same_as 'Notification Title: "f bar -r" Completed'
assert "$lines[2]" same_as "Notification Body: Total time: 20 seconds"
assert "$lines[3]" same_as "Exit code: 0"
assert "$lines[4]" same_as "--urgency=normal --expire-time=8000"
}
@test 'auto-notify-send sends notification on MacOSX' {
@ -97,14 +101,14 @@
}
function osascript {
echo - $@
echo - "${@}"
}
run _auto_notify_send
assert $state equals 0
assert "$lines[1]" same_as '-e display notification "\"f bar -r\" has completed'
assert "$lines[2]" same_as '(Total time: 20 seconds)" with title "Command Completed"'
assert "$lines[1]" same_as '-e display notification "Total time: 20 seconds'
assert "$lines[2]" same_as 'Exit code: 0" with title "\"f bar -r\" Completed"'
}
@test 'auto-notify-send sends warning on unsupported platform' {