Improvements to notification formatting and options
This commit is contained in:
parent
7b6d59479a
commit
cac8315195
2 changed files with 26 additions and 10 deletions
|
@ -1,5 +1,7 @@
|
||||||
export AUTO_NOTIFY_VERSION="0.3.0"
|
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
|
# Threshold in seconds for when to automatically show a notification
|
||||||
export AUTO_NOTIFY_THRESHOLD=10
|
export AUTO_NOTIFY_THRESHOLD=10
|
||||||
# List of commands/programs to ignore sending notifications for
|
# List of commands/programs to ignore sending notifications for
|
||||||
|
@ -10,16 +12,23 @@ export AUTO_NOTIFY_IGNORE=(
|
||||||
function _auto_notify_message() {
|
function _auto_notify_message() {
|
||||||
local command="$1"
|
local command="$1"
|
||||||
local elapsed="$2"
|
local elapsed="$2"
|
||||||
|
local exit_code="$3"
|
||||||
local platform="$(uname)"
|
local platform="$(uname)"
|
||||||
# Run using echo -e in order to make sure notify-send picks up new line
|
# 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
|
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
|
elif [[ "$platform" == "Darwin" ]]; then
|
||||||
# We need to escape quotes since we are passing a script into a command
|
# We need to escape quotes since we are passing a script into a command
|
||||||
text="${text//\"/\\\"}"
|
text="${text//\"/\\\"}"
|
||||||
osascript -e "display notification \"$text\" with title \"Command Completed\""
|
title="${title//\"/\\\"}"
|
||||||
|
osascript -e "display notification \"$text\" with title \"$title\""
|
||||||
else
|
else
|
||||||
printf "Unknown platform for sending notifications: $platform\n"
|
printf "Unknown platform for sending notifications: $platform\n"
|
||||||
printf "Please post an issue on gitub.com/MichaelAquilina/zsh-auto-notify/issues/\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() {
|
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
|
if [[ -z "$AUTO_COMMAND" && -z "$AUTO_COMMAND_START" ]]; then
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
@ -53,7 +65,7 @@ function _auto_notify_send() {
|
||||||
let "elapsed = current - AUTO_COMMAND_START"
|
let "elapsed = current - AUTO_COMMAND_START"
|
||||||
|
|
||||||
if [[ $elapsed -gt $AUTO_NOTIFY_THRESHOLD ]]; then
|
if [[ $elapsed -gt $AUTO_NOTIFY_THRESHOLD ]]; then
|
||||||
_auto_notify_message "$AUTO_COMMAND" "$elapsed"
|
_auto_notify_message "$AUTO_COMMAND" "$elapsed" "$exit_code"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,9 @@
|
||||||
load "../auto-notify.plugin.zsh"
|
load "../auto-notify.plugin.zsh"
|
||||||
|
|
||||||
function notify-send {
|
function notify-send {
|
||||||
echo - "Notification: $@"
|
echo - "Notification Title: $1"
|
||||||
|
echo - "Notification Body: $2"
|
||||||
|
echo - "${@:3}"
|
||||||
}
|
}
|
||||||
|
|
||||||
function uname {
|
function uname {
|
||||||
|
@ -83,8 +85,10 @@
|
||||||
run _auto_notify_send
|
run _auto_notify_send
|
||||||
|
|
||||||
assert $state equals 0
|
assert $state equals 0
|
||||||
assert "$lines[1]" same_as 'Notification: "f bar -r" has completed'
|
assert "$lines[1]" same_as 'Notification Title: "f bar -r" Completed'
|
||||||
assert "$lines[2]" same_as "(Total time: 20 seconds)"
|
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' {
|
@test 'auto-notify-send sends notification on MacOSX' {
|
||||||
|
@ -97,14 +101,14 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
function osascript {
|
function osascript {
|
||||||
echo - $@
|
echo - "${@}"
|
||||||
}
|
}
|
||||||
|
|
||||||
run _auto_notify_send
|
run _auto_notify_send
|
||||||
|
|
||||||
assert $state equals 0
|
assert $state equals 0
|
||||||
assert "$lines[1]" same_as '-e display notification "\"f bar -r\" has completed'
|
assert "$lines[1]" same_as '-e display notification "Total time: 20 seconds'
|
||||||
assert "$lines[2]" same_as '(Total time: 20 seconds)" with title "Command Completed"'
|
assert "$lines[2]" same_as 'Exit code: 0" with title "\"f bar -r\" Completed"'
|
||||||
}
|
}
|
||||||
|
|
||||||
@test 'auto-notify-send sends warning on unsupported platform' {
|
@test 'auto-notify-send sends warning on unsupported platform' {
|
||||||
|
|
Loading…
Add table
Reference in a new issue