diff --git a/bin/periodic/fix-theming b/bin/periodic/fix-theming index 1ff352a..0fa5d19 100755 --- a/bin/periodic/fix-theming +++ b/bin/periodic/fix-theming @@ -4,21 +4,22 @@ pidof -sq -o %PPID -x "$(basename "$0")" && exit # Set the directory/file paths -flatpak_themes_dir="$HOME/.themes" -flatpak_icons_dir="$HOME/.icons" -profile="$HOME/.profile" +declare -r flatpak_themes_dir="$HOME/.themes" +declare -r flatpak_icons_dir="$HOME/.icons" +declare -r profile="$HOME/.profile" # Create flatpak icons & themes directories if they don't exist mkdir -p "$flatpak_themes_dir" "$flatpak_icons_dir" || { echo "failed to make directories $flatpak_themes_dir & $flatpak_icons_dir"; exit 1; } # Enable option for syncing the current theme with XFWM theme if not already enabled -[ "$(xfconf-query -c xsettings -p /Xfce/SyncThemes)" != 'true' ] && xfconf-query -c xsettings -p /Xfce/SyncThemes -n -t bool -s true +[ "$(xfconf-query -c xsettings -p /Xfce/SyncThemes)" != 'true' ] && + xfconf-query -c xsettings -p /Xfce/SyncThemes -n -t bool -s true xdg_directory_lookup() { # Go through each item in $XDG_DATA_DIRS and find the subdirectory $1 while read -r dir; do - subdir="${dir%/}/$1" + local subdir="${dir%/}/$1" if [ -d "$subdir" ]; then echo "$subdir" break @@ -26,10 +27,16 @@ xdg_directory_lookup() { done < <(printf '%s:%s\n' "$HOME/.local/share" "$XDG_DATA_DIRS" | tr ':' '\n') } +theme_exists() { + local -r theme_dir=$(xdg_directory_lookup "themes/$1") + [ -d "$theme_dir" ] +} + # Function for setting variables in ~/.profile profile_set_variable() { # Return if the variable is already set to the correct value grep -xq "\s*export\s\+$1=$2\s*" "$profile" && return + # If the variable is set to a different value then remove that line grep -q "^\s*export\s\+$1=" "$profile" && sed -i "/^\s*export\s\+$1=/d" "$profile" @@ -37,85 +44,109 @@ profile_set_variable() { if grep -xq '\s*#\s*Values set by the fix-theming script\s*' "$profile"; then sed -i "/^\s*#\s*Values set by the fix-theming script\s*$/a export $1=$2" "$profile" elif grep -q '\s' "$profile"; then - tail -n1 "$profile" | grep -qx '\s*' && begin='' || begin='\n' + # shellcheck disable=SC2015 + tail -n1 "$profile" | grep -qx '\s*' && + local -r begin='' || local -r begin='\n' printf '%b# Values set by the fix-theming script\nexport %s=%s\n' "$begin" "$1" "$2" >> "$profile" else printf '# Values set by the fix-theming script\nexport %s=%s\n' "$1" "$2" > "$profile" fi - # Set variable logout_required to true + logout_required='true' } +set_QT_scaling() { + for var in QT_SCALE_FACTOR QT_AUTO_SCREEN_SCALE_FACTOR QT_ENABLE_HIGHDPI_SCALING; do + profile_set_variable "$var" "$1" + done +} + +set_cursor_size() { + xfconf-query -c xsettings -p /Gtk/CursorThemeSize -s "$1" +} + +set_xfwm_theme() { + xfconf-query -c xfwm4 -p /general/theme -n -t string -s "$1" +} + +# Use the highDPI variant of the XFWM theme +use_hdpi_theme_variant() { + local -r current_xfwm_theme=$(xfconf-query -c xfwm4 -p /general/theme) + + for variant in xhdpi hdpi; do + # If this variant of the theme is already enabled then break out of the loop + [ "${current_xfwm_theme##*-}" = "$variant" ] && break + + # Store the name for this variant of the theme in highDPI_theme variable + local -r highDPI_theme=$current_xfwm_theme-$variant + + if theme_exists "$highDPI_theme"; then + set_xfwm_theme "$highDPI_theme" + [ "$1" != 'disable_notification' ] && + notify-send "XFWM theme changed to $highDPI_theme" "Changed to the highDPI variant of your chosen theme because you've enabled highDPI on your system" + break + fi + done +} + +# Use the normal variant of the XFWM theme +use_normal_theme_variant() { + local -r current_xfwm_theme=$(xfconf-query -c xfwm4 -p /general/theme) + + for variant in xhdpi hdpi; do + # Continue looping if this (highDPI) variant of the theme is not enabled + [ "${current_xfwm_theme##*-}" != "$variant" ] && continue + + # Store the name for the normal variant of this theme in normal_theme variable + local -r normal_theme=${current_xfwm_theme%-"$variant"} + + if theme_exists "$normal_theme"; then + set_xfwm_theme "$normal_theme" + notify-send "XFWM theme changed to $normal_theme" "Changed to the normal variant of your chosen theme because you've disabled highDPI on your system" + break + fi + done +} + +# Change XFWM theme, QT apps scaling, and mouse cursor size according to +# the user's current window scaling (highDPI setting) hdpi_theme_fix() { - # Get the current window scaling factor (highDPI setting) - current_scaling=$(xfconf-query -c xsettings -p /Gdk/WindowScalingFactor) - # Get the current XFWM theme - current_xfwm_theme=$(xfconf-query -c xfwm4 -p /general/theme) - # Get the current mouse cursor size - cursor_size=$(xfconf-query -c xsettings -p /Gtk/CursorThemeSize) + local -r current_window_scaling=$(xfconf-query -c xsettings -p /Gdk/WindowScalingFactor) + local -r current_cursor_size=$(xfconf-query -c xsettings -p /Gtk/CursorThemeSize) unset logout_required - if [ "$current_scaling" -eq '2' ]; then - # Increase mouse cursor size if it's equal to 25 - if [ "$cursor_size" -eq 25 ]; then - xfconf-query -c xsettings -p /Gtk/CursorThemeSize -s '45' + if [ "$current_window_scaling" -eq '2' ]; then + # Increase scaling for QT apps + set_QT_scaling 2 + # Use the highDPI variant of the XFWM theme + use_hdpi_theme_variant + if [ "$current_cursor_size" -eq 25 ]; then + set_cursor_size '45' notify-send 'Mouse cursor size increased to 45' "Changed to a larger mouse cursor because you've enabled highDPI on your system" fi - # Increase scaling for QT apps - for var in QT_SCALE_FACTOR QT_AUTO_SCREEN_SCALE_FACTOR QT_ENABLE_HIGHDPI_SCALING; do - profile_set_variable "$var" 2 - done - for variant in xhdpi hdpi; do - # If this variant of the theme is already enabled then break out of the loop - [ "${current_xfwm_theme##*-}" = "$variant" ] && break - # Store the name for this variant of the theme in highDPI_theme variable - highDPI_theme=$current_xfwm_theme-$variant - # Find the directory where highDPI_theme is stored - highDPI_theme_dir=$(xdg_directory_lookup "themes/$highDPI_theme") - # If this directory exists then change to that theme for XFWM - if [ -d "$highDPI_theme_dir" ]; then - xfconf-query -c xfwm4 -p /general/theme -n -t string -s "$highDPI_theme" - [ "$1" != 'no_hdpi_notification' ] && notify-send "XFWM theme changed to $highDPI_theme" "Changed to the highDPI variant of your chosen theme because you've enabled highDPI on your system" - break - fi - done else - # Decrease mouse cursor size if it's equal to 45 - if [ "$cursor_size" -eq 45 ]; then - xfconf-query -c xsettings -p /Gtk/CursorThemeSize -s '25' + # Decrease scaling for QT apps + set_QT_scaling 1 + # Use the normal variant of the XFWM theme + use_normal_theme_variant + if [ "$current_cursor_size" -eq 45 ]; then + set_cursor_size '25' notify-send 'Mouse cursor size decreased to 25' "Changed to a smaller mouse cursor because you've disabled highDPI on your system" fi - # Decrease scaling for QT apps - unset logout_required - for var in QT_SCALE_FACTOR QT_AUTO_SCREEN_SCALE_FACTOR QT_ENABLE_HIGHDPI_SCALING; do - profile_set_variable "$var" 1 - done - for variant in xhdpi hdpi; do - # Continue looping if this (highDPI) variant of the theme is not enabled - [ "${current_xfwm_theme##*-}" != "$variant" ] && continue - # Store the name for the normal variant of this theme in normal_theme variable - normal_theme=${current_xfwm_theme%-"$variant"} - # Find the directory where normal_theme is stored - normal_theme_dir=$(xdg_directory_lookup "themes/$normal_theme") - # If this directory exists then change to that theme for XFWM - if [ -d "$normal_theme_dir" ]; then - xfconf-query -c xfwm4 -p /general/theme -n -t string -s "$normal_theme" - notify-send "XFWM theme changed to $normal_theme" "Changed to the normal variant of your chosen theme because you've disabled highDPI on your system" - break - fi - done fi + # Show popup menu about logout if it's required [ "$logout_required" = 'true' ] && - [ "$1" != 'no_hdpi_notification' ] && - yad --image "dialog-question" --title "Alert" --buttons-layout=center --text-align=center --button=yad-yes:0 --button=yad-no:1 --text 'Logout is required in order to apply the DPI preferences to the QT apps.\nWould you like to logout now?' && + yad --image "dialog-question" --title "Alert" --buttons-layout=center --text-align=center --button=yad-yes:0 --button=yad-no:1 --text 'Logout is required in order to apply your DPI preferences to QT apps.\nWould you like to logout now?' && xfce4-session-logout --logout } sync_theme() { # Get the current system theme - current_theme=$(xfconf-query -c xsettings -p /Net/ThemeName) + local -r current_theme=$(xfconf-query -c xsettings -p /Net/ThemeName) + # Get the current window scaling factor (highDPI setting) + local -r current_window_scaling=$(xfconf-query -c xsettings -p /Gdk/WindowScalingFactor) # Apply the current theme with gsettings gsettings set org.gnome.desktop.interface gtk-theme "$current_theme" @@ -123,17 +154,19 @@ sync_theme() { # Apply the current theme for GTK and Libadwaita apps on flatpak flatpak override --user --env=GTK_THEME="$current_theme" - # Apply the current theme for XFWM - xfconf-query -c xfwm4 -p /general/theme -n -t string -s "$current_theme" + # Apply the current theme for XFWM unless it's initial_sync on system reboot + if [ "$1" != 'initial_sync' ]; then + set_xfwm_theme "$current_theme" - # Change XFWM theme and mouse cursor size according to the user's highDPI setting - hdpi_theme_fix 'no_hdpi_notification' + # Use the highDPI variant of the XFWM theme if the current_window_scaling factor is 2 + [ "$current_window_scaling" -eq '2' ] && use_hdpi_theme_variant 'disable_notification' + fi # Cleanup flatpak_themes_dir rm -rf "${flatpak_themes_dir:?}"/* # Find the directory where the current theme is stored - current_theme_dir=$(xdg_directory_lookup "themes/$current_theme") + local -r current_theme_dir=$(xdg_directory_lookup "themes/$current_theme") # Copy/sync current_theme_dir to flatpak_themes_dir [ -d "$current_theme_dir" ] && rsync -av --delete --progress "$current_theme_dir" "$flatpak_themes_dir" @@ -141,16 +174,16 @@ sync_theme() { sync_font() { # Get the current system font - font=$(xfconf-query -c xsettings -p /Gtk/FontName) - # Apply the same font for the title of xfce windows - xfconf-query -c xfwm4 -p /general/title_font -n -t string -s "$font" + local -r current_font=$(xfconf-query -c xsettings -p /Gtk/FontName) + # Apply the same font for the title of XFCE windows + xfconf-query -c xfwm4 -p /general/title_font -n -t string -s "$current_font" } # Initial synchronization -sync_theme +sync_theme 'initial_sync' sync_font -# Monitor when the user changes their system theme or icons or font in XFCE and sync them as needed +# Monitor when the user changes their system theme/icons/font in XFCE and sync them as needed while read -r line; do case "$line" in 'set: /Net/ThemeName') sync_theme ;;