Compare commits

..

No commits in common. "a38d064439f978f19f2b5d460f313228dc0c9294" and "53674bd7a36b38331af7c21f97bf2f3cad287171" have entirely different histories.

2 changed files with 106 additions and 162 deletions

View File

@ -17,74 +17,40 @@
# will be ignored. # will be ignored.
follow = mouse follow = mouse
### Geometry ### # The geometry of the window:
# [{width}]x{height}[+/-{x}+/-{y}]
# The geometry of the message window.
# The height is measured in number of notifications everything else
# in pixels. If the width is omitted but the height is given
# ("-geometry x2"), the message window expands over the whole screen
# (dmenu-like). If width is 0, the window expands to the longest
# message displayed. A positive x is measured from the left, a
# negative from the right side of the screen. Y is measured from
# the top and down respectively.
# The width can be negative. In this case the actual width is the
# screen width minus the width defined in within the geometry option.
geometry = "500x0-30+20"
# dynamic width from 0 to 300 # Show how many messages are currently hidden (because of geometry).
# width = (0, 300)
# constant width of 300
width = 500
# The maximum height of a single notification, excluding the frame.
height = 100
# Position the notification in the top right corner
origin = bottom-right
# Offset from the origin
offset = 5x5
# Scale factor. It is auto-detected if value is 0.
scale = 0
# Maximum number of notification (0 means no limit)
notification_limit = 20
### Progress bar ###
# Turn on the progress bar. It appears when a progress hint is passed with
# for example dunstify -h int:value:12
progress_bar = true
# Set the progress bar height. This includes the frame, so make sure
# it's at least twice as big as the frame width.
progress_bar_height = 10
# Set the frame width of the progress bar
progress_bar_frame_width = 1
# Set the minimum width for the progress bar
progress_bar_min_width = 150
# Set the maximum width for the progress bar
progress_bar_max_width = 300
# Corner radius for the progress bar. 0 disables rounded corners.
progress_bar_corner_radius = 0
# Define which corners to round when drawing the progress bar. If progress_bar_corner_radius
# is set to 0 this option will be ignored.
progress_bar_corners = all
# Corner radius for the icon image.
icon_corner_radius = 0
# Define which corners to round when drawing the icon image. If icon_corner_radius
# is set to 0 this option will be ignored.
icon_corners = all
# Show how many messages are currently hidden (because of
# notification_limit).
indicate_hidden = yes indicate_hidden = yes
# Shrink window if it's smaller than the width. Will be ignored if
# width is 0.
shrink = yes
# The transparency of the window. Range: [0; 100]. # The transparency of the window. Range: [0; 100].
# This option will only work if a compositing window manager is # This option will only work if a compositing window manager is
# present (e.g. xcompmgr, compiz, etc.). (X11 only) # present (e.g. xcompmgr, compiz, etc.).
transparency = 0 transparency = 0
# The height of the entire notification. If the height is smaller
# than the font height and padding combined, it will be raised
# to the font height and padding.
notification_height = 0
# Draw a line of "separator_height" pixel height between two # Draw a line of "separator_height" pixel height between two
# notifications. # notifications.
# Set to 0 to disable. # Set to 0 to disable.
# If gap_size is greater than 0, this setting will be ignored.
separator_height = 2 separator_height = 2
# Padding between text and separator. # Padding between text and separator.
@ -93,22 +59,13 @@
# Horizontal padding. # Horizontal padding.
horizontal_padding = 8 horizontal_padding = 8
# Padding between text and icon.
text_icon_padding = 0
# Defines width in pixels of frame around the notification window. # Defines width in pixels of frame around the notification window.
# Set to 0 to disable. # Set to 0 to disable.
frame_width = 3 frame_width = 2
# Defines color of the frame around the notification window. # Defines color of the frame around the notification window.
frame_color = "#aaaaaa" frame_color = "#aaaaaa"
# Size of gap to display between notifications - requires a compositor.
# If value is greater than 0, separator_height will be ignored and a border
# of size frame_width will be drawn around each notification instead.
# Click events on gaps do not currently propagate to applications below.
gap_size = 0
# Define a color for the separator. # Define a color for the separator.
# possible values are: # possible values are:
# * auto: dunst tries to find a color fitting to the background; # * auto: dunst tries to find a color fitting to the background;
@ -117,12 +74,7 @@
# * anything else will be interpreted as a X color. # * anything else will be interpreted as a X color.
separator_color = auto separator_color = auto
# Sort type. # Sort messages by urgency.
# possible values are:
# * id: sort by id
# * urgency_ascending: sort by urgency (low then normal then critical)
# * urgency_descending: sort by urgency (critical then normal then low)
# * update: sort by update (most recent always at the top)
sort = yes sort = yes
# Don't remove messages, if the user is idle (no mouse or keyboard input) # Don't remove messages, if the user is idle (no mouse or keyboard input)
@ -148,7 +100,7 @@
# <u>underline</u> # <u>underline</u>
# #
# For a complete reference see # For a complete reference see
# <https://docs.gtk.org/Pango/pango_markup.html>. # <https://developer.gnome.org/pango/stable/pango-Markup.html>.
# #
# strip: This setting is provided for compatibility with some broken # strip: This setting is provided for compatibility with some broken
# clients that send markup even though it's not enabled on the # clients that send markup even though it's not enabled on the
@ -178,7 +130,7 @@
# Alignment of message text. # Alignment of message text.
# Possible values are "left", "center" and "right". # Possible values are "left", "center" and "right".
alignment = left alignment = center
# Vertical alignment of message text and icon. # Vertical alignment of message text and icon.
# Possible values are "top", "center" and "bottom". # Possible values are "top", "center" and "bottom".
@ -189,7 +141,11 @@
# Set to -1 to disable. # Set to -1 to disable.
show_age_threshold = 60 show_age_threshold = 60
# Specify where to make an ellipsis in long lines. # Split notifications into multiple lines if they don't fit into
# geometry.
word_wrap = yes
# When word_wrap is set to no, specify where to make an ellipsis in long lines.
# Possible values are "start", "middle" and "end". # Possible values are "start", "middle" and "end".
ellipsize = middle ellipsize = middle
@ -207,28 +163,19 @@
### Icons ### ### Icons ###
# Recursive icon lookup. You can set a single theme, instead of having to # Align icons left/right/off
# define all lookup paths.
enable_recursive_icon_lookup = true
# Set icon theme (only used for recursive icon lookup)
icon_theme = "Surfn"
# You can also set multiple icon themes, with the leftmost one being used first.
# icon_theme = "Adwaita, breeze"
# Align icons left/right/top/off
icon_position = left icon_position = left
# Scale small icons up to this size, set to 0 to disable. Helpful # Scale small icons up to this size, set to 0 to disable. Helpful
# for e.g. small files or high-dpi screens. In case of conflict, # for e.g. small files or high-dpi screens. In case of conflict,
# max_icon_size takes precedence over this. # max_icon_size takes precedence over this.
#min_icon_size = 32 min_icon_size = 0
# Scale larger icons down to this size, set to 0 to disable # Scale larger icons down to this size, set to 0 to disable
max_icon_size = 32 max_icon_size = 32
# Paths to default icons (only necessary when not using recursive icon lookup) # Paths to default icons.
#icon_path = /usr/share/icons/gnome/16x16/status/:/usr/share/icons/gnome/16x16/devices/ icon_path = /usr/share/icons/Surfn/24/status/:/usr/share/icons/Surfn/24/devices/
### History ### ### History ###
@ -245,30 +192,37 @@
dmenu = /usr/bin/dmenu -p dunst: dmenu = /usr/bin/dmenu -p dunst:
# Browser for opening urls in context menu. # Browser for opening urls in context menu.
browser = /usr/bin/xdg-open browser = /usr/bin/firefox -new-tab
# Always run rule-defined scripts, even if the notification is suppressed # Always run rule-defined scripts, even if the notification is suppressed
always_run_script = true always_run_script = true
# Define the title of the windows spawned by dunst (X11 only) # Define the title of the windows spawned by dunst
#title = Dunst title = Dunst
# Define the class of the windows spawned by dunst (X11 only) # Define the class of the windows spawned by dunst
#class = Dunst class = Dunst
# Print a notification on startup.
# This is mainly for error detection, since dbus (re-)starts dunst
# automatically after a crash.
startup_notification = false
# Manage dunst's desire for talking
# Can be one of the following values:
# crit: Critical features. Dunst aborts
# warn: Only non-fatal warnings
# mesg: Important Messages
# info: all unimportant stuff
# debug: all less than unimportant stuff
verbosity = mesg
# Define the corner radius of the notification window # Define the corner radius of the notification window
# in pixel size. If the radius is 0, you have no rounded # in pixel size. If the radius is 0, you have no rounded
# corners. # corners.
# The radius will be automatically lowered if it exceeds half of the # The radius will be automatically lowered if it exceeds half of the
# notification height to avoid clipping text and/or icons. # notification height to avoid clipping text and/or icons.
corner_radius = 15 corner_radius = 10
# Define which corners to round when drawing the window. If the corner radius
# is set to 0 this option will be ignored.
#
# Comma-separated list of the corners. The accepted corner values are bottom-right,
# bottom-left, top-right, top-left, top, bottom, left, right or all.
corners = all
# Ignore the dbus closeNotification message. # Ignore the dbus closeNotification message.
# Useful to enforce the timeout set by dunst configuration. Without this # Useful to enforce the timeout set by dunst configuration. Without this
@ -276,16 +230,6 @@
# user defined timeout. # user defined timeout.
ignore_dbusclose = false ignore_dbusclose = false
### Wayland ###
# These settings are Wayland-specific. They have no effect when using X11
# Uncomment this if you want to let notifications appear under fullscreen
# applications (default: overlay)
layer = top
# Set this to true to use X11 output on Wayland.
#force_xwayland = false
### Legacy ### Legacy
# Use the Xinerama extension instead of RandR for multi-monitor support. # Use the Xinerama extension instead of RandR for multi-monitor support.
@ -296,37 +240,54 @@
# By enabling this setting dunst will not be able to detect when a monitor # By enabling this setting dunst will not be able to detect when a monitor
# is connected or disconnected which might break follow mode if the screen # is connected or disconnected which might break follow mode if the screen
# layout changes. # layout changes.
#force_xinerama = false force_xinerama = false
### mouse ### mouse
# Defines list of actions for each mouse event # Defines list of actions for each mouse event
# Possible values are: # Possible values are:
# * none: Don't do anything. # * none: Don't do anything.
# * do_action: Invoke the action determined by the action_name rule. If there is no # * do_action: If the notification has exactly one action, or one is marked as default,
# such action, open the context menu. # invoke it. If there are multiple and no default, open the context menu.
# * open_url: If the notification has exactly one url, open it. If there are multiple
# ones, open the context menu.
# * close_current: Close current notification. # * close_current: Close current notification.
# * close_all: Close all notifications. # * close_all: Close all notifications.
# * context: Open context menu for the notification.
# * context_all: Open context menu for all notifications.
# These values can be strung together for each mouse event, and # These values can be strung together for each mouse event, and
# will be executed in sequence. # will be executed in sequence.
mouse_left_click = close_current mouse_left_click = close_current
mouse_middle_click = close_all mouse_middle_click = close_all
mouse_right_click = do_action,open_url mouse_right_click = do_action
# Experimental features that may or may not work correctly. Do not expect them # Experimental features that may or may not work correctly. Do not expect them
# to have a consistent behaviour across releases. # to have a consistent behaviour across releases.
#[experimental] [experimental]
# Calculate the dpi to use on a per-monitor basis. # Calculate the dpi to use on a per-monitor basis.
# If this setting is enabled the Xft.dpi value will be ignored and instead # If this setting is enabled the Xft.dpi value will be ignored and instead
# dunst will attempt to calculate an appropriate dpi value for each monitor # dunst will attempt to calculate an appropriate dpi value for each monitor
# using the resolution and physical size. This might be useful in setups # using the resolution and physical size. This might be useful in setups
# where there are multiple screens with very different dpi values. # where there are multiple screens with very different dpi values.
#per_monitor_dpi = false per_monitor_dpi = false
[shortcuts]
# Shortcuts are specified as [modifier+][modifier+]...key
# Available modifiers are "ctrl", "mod1" (the alt-key), "mod2",
# "mod3" and "mod4" (windows-key).
# Xev might be helpful to find names for keys.
# Close notification.
#close = ctrl+space
# Close all notifications.
#close_all = ctrl+shift+space
# Redisplay last message(s).
# On the US keyboard layout "grave" is normally above TAB and left
# of "1". Make sure this key actually exists on your keyboard layout,
# e.g. check output of 'xmodmap -pke'
#history = ctrl+grave
# Context menu.
#context = ctrl+shift+period
[urgency_low] [urgency_low]
# IMPORTANT: colors have to be defined in quotation marks. # IMPORTANT: colors have to be defined in quotation marks.
@ -335,23 +296,21 @@
foreground = "#aaaaaa" foreground = "#aaaaaa"
timeout = 5 timeout = 5
# Icon for notifications with low urgency, uncomment to enable # Icon for notifications with low urgency, uncomment to enable
#default_icon = /path/to/icon #icon = /path/to/icon
[urgency_normal] [urgency_normal]
background = "#333333" background = "#333333"
foreground = "#ffffff" foreground = "#ffffff"
timeout = 10 timeout = 10
override_pause_level = 30
# Icon for notifications with normal urgency, uncomment to enable # Icon for notifications with normal urgency, uncomment to enable
#default_icon = /path/to/icon #icon = /path/to/icon
[urgency_critical] [urgency_critical]
background = "#555555" background = "#555555"
foreground = "#ffffff" foreground = "#ffffff"
timeout = 0 timeout = 0
override_pause_level = 60
# Icon for notifications with critical urgency, uncomment to enable # Icon for notifications with critical urgency, uncomment to enable
#default_icon = /path/to/icon #icon = /path/to/icon
# Every section that isn't one of the above is interpreted as a rules to # Every section that isn't one of the above is interpreted as a rules to
# override settings for certain messages. # override settings for certain messages.
@ -376,18 +335,8 @@
# new_icon # new_icon
# set_stack_tag # set_stack_tag
# set_transient # set_transient
# set_category
# timeout # timeout
# urgency # urgency
# icon_position
# skip_display
# history_ignore
# action_name
# word_wrap
# ellipsize
# alignment
# hide_text
# override_pause_level
# #
# Shell-like globbing will get expanded. # Shell-like globbing will get expanded.
# #
@ -395,10 +344,6 @@
# GLib based applications export their desktop-entry name. In comparison to the appname, # GLib based applications export their desktop-entry name. In comparison to the appname,
# the desktop-entry won't get localized. # the desktop-entry won't get localized.
# #
# You can also allow a notification to appear even when paused. Notification will appear whenever notification's override_pause_level >= dunst's paused level.
# This can be used to set partial pause modes, where more urgent notifications get through, but less urgent stay paused. To do that, you can override the following in the rules:
# override_pause_level = X
# SCRIPTING # SCRIPTING
# You can specify a script that gets run when the rule matches by # You can specify a script that gets run when the rule matches by
# setting the "script" option. # setting the "script" option.
@ -406,6 +351,8 @@
# script appname summary body icon urgency # script appname summary body icon urgency
# where urgency can be "LOW", "NORMAL" or "CRITICAL". # where urgency can be "LOW", "NORMAL" or "CRITICAL".
# #
# NOTE: if you don't want a notification to be displayed, set the format
# to "".
# NOTE: It might be helpful to run dunst -print in a terminal in order # NOTE: It might be helpful to run dunst -print in a terminal in order
# to find fitting options for rules. # to find fitting options for rules.
@ -433,6 +380,9 @@
# msg_urgency = critical # msg_urgency = critical
# fullscreen = show # fullscreen = show
[fullscreen_show]
fullscreen = show
#[espeak] #[espeak]
# summary = "*" # summary = "*"
# script = dunst_espeak.sh # script = dunst_espeak.sh
@ -444,7 +394,7 @@
#[ignore] #[ignore]
# # This notification will not be displayed # # This notification will not be displayed
# summary = "foobar" # summary = "foobar"
# skip_display = true # format = ""
#[history-ignore] #[history-ignore]
# # This notification will not be saved in history # # This notification will not be saved in history
@ -479,7 +429,6 @@
#[stack-volumes] #[stack-volumes]
# appname = "some_volume_notifiers" # appname = "some_volume_notifiers"
# set_stack_tag = "volume" # set_stack_tag = "volume"
#
[dunstify] [dunstify]
appname = "dunstify" appname = "dunstify"
@ -494,13 +443,11 @@
[volume-script] [volume-script]
appname = "volume-script" appname = "volume-script"
format = "<b>%s</b>\n%b" format = "<b>%s</b>\n%b"
timeout = 1 timeout = 5
script = "$HOME/scripts/dunst/dunst-notification-sound.sh" script = "$HOME/scripts/dunst/dunst-notification-sound.sh"
[backlight-script] [backlight-script]
appname = "backlight-script" appname = "backlight-script"
format = "<b>%s</b>\n%b" format = "<b>%s</b>\n%b"
timeout = 1 timeout = 5
script = "$HOME/scripts/dunst/dunst-notification-sound.sh" script = "$HOME/scripts/dunst/dunst-notification-sound.sh"
# vim: ft=cfg

View File

@ -16,37 +16,34 @@ is_mute() {
} }
send_notification() { send_notification() {
volume=$(get_volume)
# Make the bar with the special character ─ (it's not dash -) # Make the bar with the special character ─ (it's not dash -)
# https://en.wikipedia.org/wiki/Box-drawing_character # https://en.wikipedia.org/wiki/Box-drawing_character
#bar=$(seq -s "─" $(($volume / 5)) | sed 's/[0-9]//g') bar=$(seq -s "─" $(($volume / 5)) | sed 's/[0-9]//g')
# Send the notification # Send the notification
#dunstify -i audio-volume-high -r 2593 -a volume-script "$volume $bar " dunstify -i audio-volume-high -r 2593 -a volume-script "$volume $bar "
dunstify -i audio-volume-high -a volume-script -h int:value:$volume "Volume"
} }
volume=$(get_volume)
case $1 in case $1 in
up) up)
send_notification
# Set the volume on (if it was muted) # Set the volume on (if it was muted)
amixer -D pipewire set Master on >/dev/null amixer -D pulse set Master on >/dev/null
# Up the volume (+ 5%) # Up the volume (+ 5%)
amixer -D pipewire sset Master 5%+ >/dev/null amixer -D pulse sset Master 5%+ >/dev/null
send_notification
;; ;;
down) down)
amixer -D pulse set Master on >/dev/null
amixer -D pulse sset Master 5%- >/dev/null
send_notification send_notification
amixer -D pipewire set Master on >/dev/null
amixer -D pipewire sset Master 5%- >/dev/null
;; ;;
mute) mute)
# Toggle mute
amixer -D pulse set Master 1+ toggle >/dev/null
if is_mute; then if is_mute; then
dunstify -i audio-volume-muted -a volume-script -h int:value:$volume "Mute" dunstify -i audio-volume-muted -r 2593 -u normal "Mute"
else else
send_notification send_notification
fi fi
# Toggle mute
amixer -D pipewire set Master 1+ toggle >/dev/null
;; ;;
esac esac