Compare commits
21 Commits
b741df884e
...
main
Author | SHA1 | Date | |
---|---|---|---|
b0a58be284 | |||
4cac9f2107 | |||
6fa33e8a2a | |||
1a34c770c8 | |||
36a979547b | |||
ef045c1265 | |||
|
7d189e0c06 | ||
87e64585b0 | |||
e8d7c816d0 | |||
2ae3788d3c | |||
c0e90900c4 | |||
5f89952f3f | |||
02d11a58d5 | |||
f9f5c95a7b | |||
b39dfffa5e | |||
2a53d23139 | |||
f989a2e1be | |||
7c457fd1f7 | |||
2a412d38c2 | |||
fb1c550768 | |||
|
0600a8f119 |
8
PKGBUILD
8
PKGBUILD
@@ -1,7 +1,7 @@
|
|||||||
# Maintainer: TROM <contact@tromsite.com>
|
# Maintainer: TROM <contact@tromsite.com>
|
||||||
pkgname=tromjaro-fixes
|
pkgname=tromjaro-fixes
|
||||||
pkgver=1.9
|
pkgver=3
|
||||||
pkgrel=1
|
pkgrel=2
|
||||||
pkgdesc="Various fixes for TROMjaro OS"
|
pkgdesc="Various fixes for TROMjaro OS"
|
||||||
arch=(any)
|
arch=(any)
|
||||||
url=""
|
url=""
|
||||||
@@ -10,9 +10,9 @@ depends=('xfce4-appfinder'
|
|||||||
'xdotool'
|
'xdotool'
|
||||||
'rsync'
|
'rsync'
|
||||||
'inotify-tools'
|
'inotify-tools'
|
||||||
|
'qt6gtk2-tromjaro'
|
||||||
'qt5gtk2'
|
'qt5gtk2'
|
||||||
'qt6gtk2-git'
|
'yad')
|
||||||
'qqc2-desktop-style')
|
|
||||||
conflicts=('qt5-styleplugins')
|
conflicts=('qt5-styleplugins')
|
||||||
provides=('tromjaro-fixes')
|
provides=('tromjaro-fixes')
|
||||||
backup=()
|
backup=()
|
||||||
|
@@ -1,4 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
|
||||||
|
# This script will sync your XFCE theme & font to work systemwide and in
|
||||||
|
# a consistent manner accross different apps. It also improves
|
||||||
|
# the highDPI scaling to give you a better experience.
|
||||||
|
|
||||||
# Exit out if the same script is already running in the background
|
# Exit out if the same script is already running in the background
|
||||||
pidof -sq -o %PPID -x "$(basename "$0")" && exit
|
pidof -sq -o %PPID -x "$(basename "$0")" && exit
|
||||||
@@ -16,6 +21,25 @@ mkdir -p "$flatpak_themes_dir" "$config_dir" ||
|
|||||||
[ "$(xfconf-query -c xsettings -p /Xfce/SyncThemes)" != 'true' ] &&
|
[ "$(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 -n -t bool -s true
|
||||||
|
|
||||||
|
# Make sure ~/.profile is sourced inside ~/.bash_profile and ~/.zprofile
|
||||||
|
source_profile() {
|
||||||
|
for file in "$HOME/.bash_profile" "$HOME/.zprofile"; do
|
||||||
|
# Continue looping if it is already sourced
|
||||||
|
grep -Exq '\s*(.*&& )?\. "?\$HOME"?/\.profile"?\s*' "$file" ||
|
||||||
|
grep -Exq "\s*(.*&& )?\. ~/\.profile\s*" "$file" && continue
|
||||||
|
# If not then source it
|
||||||
|
if grep -q '\S' "$file"; then
|
||||||
|
# shellcheck disable=SC2015
|
||||||
|
tail -n1 "$file" | grep -qx '\s*' &&
|
||||||
|
local -r begin='' || local -r begin='\n'
|
||||||
|
printf '%b[ -f "$HOME/.profile" ] && . "$HOME/.profile"\n' "$begin" >> "$file"
|
||||||
|
else
|
||||||
|
echo '[ -f "$HOME/.profile" ] && . "$HOME/.profile"' > "$file"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
source_profile
|
||||||
|
|
||||||
xdg_directory_lookup() {
|
xdg_directory_lookup() {
|
||||||
# Go through each item in $XDG_DATA_DIRS and find the subdirectory $1
|
# Go through each item in $XDG_DATA_DIRS and find the subdirectory $1
|
||||||
while read -r dir; do
|
while read -r dir; do
|
||||||
@@ -43,7 +67,7 @@ profile_set_variable() {
|
|||||||
# Set the variable to the correct value under a comment mentioning this script
|
# Set the variable to the correct value under a comment mentioning this script
|
||||||
if grep -xq '\s*#\s*Values set by the fix-theming script\s*' "$profile"; then
|
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"
|
sed -i "/^\s*#\s*Values set by the fix-theming script\s*$/a export $1=$2" "$profile"
|
||||||
elif grep -q '\s' "$profile"; then
|
elif grep -q '\S' "$profile"; then
|
||||||
# shellcheck disable=SC2015
|
# shellcheck disable=SC2015
|
||||||
tail -n1 "$profile" | grep -qx '\s*' &&
|
tail -n1 "$profile" | grep -qx '\s*' &&
|
||||||
local -r begin='' || local -r begin='\n'
|
local -r begin='' || local -r begin='\n'
|
||||||
@@ -71,22 +95,27 @@ set_xfwm_theme() {
|
|||||||
|
|
||||||
# Use the highDPI variant of the XFWM theme
|
# Use the highDPI variant of the XFWM theme
|
||||||
use_hdpi_theme_variant() {
|
use_hdpi_theme_variant() {
|
||||||
local -r current_xfwm_theme=$(xfconf-query -c xfwm4 -p /general/theme)
|
# shellcheck disable=SC2015
|
||||||
|
[ -n "$1" ] && local -r xfwm_theme="$1" ||
|
||||||
|
local -r xfwm_theme=$(xfconf-query -c xfwm4 -p /general/theme)
|
||||||
|
|
||||||
for variant in xhdpi hdpi; do
|
for variant in xhdpi hdpi; do
|
||||||
# If this variant of the theme is already enabled then break out of the loop
|
# If this variant of the theme is already enabled then break out of the loop
|
||||||
[ "${current_xfwm_theme##*-}" = "$variant" ] && break
|
[ "${xfwm_theme##*-}" = "$variant" ] && break
|
||||||
|
|
||||||
# Store the name for this variant of the theme in highDPI_theme variable
|
# Store the name for this variant of the theme in highDPI_theme variable
|
||||||
local -r highDPI_theme=$current_xfwm_theme-$variant
|
local highDPI_theme=$xfwm_theme-$variant
|
||||||
|
|
||||||
if theme_exists "$highDPI_theme"; then
|
if theme_exists "$highDPI_theme"; then
|
||||||
set_xfwm_theme "$highDPI_theme"
|
set_xfwm_theme "$highDPI_theme"
|
||||||
[ "$1" != 'disable_notification' ] &&
|
[ -z "$1" ] &&
|
||||||
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"
|
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
|
break
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
if ! theme_exists "$highDPI_theme"; then
|
||||||
|
[ -n "$1" ] && theme_exists "$1" && set_xfwm_theme "$1"
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Use the normal variant of the XFWM theme
|
# Use the normal variant of the XFWM theme
|
||||||
@@ -98,7 +127,7 @@ use_normal_theme_variant() {
|
|||||||
[ "${current_xfwm_theme##*-}" != "$variant" ] && continue
|
[ "${current_xfwm_theme##*-}" != "$variant" ] && continue
|
||||||
|
|
||||||
# Store the name for the normal variant of this theme in normal_theme variable
|
# Store the name for the normal variant of this theme in normal_theme variable
|
||||||
local -r normal_theme=${current_xfwm_theme%-"$variant"}
|
local normal_theme=${current_xfwm_theme%-"$variant"}
|
||||||
|
|
||||||
if theme_exists "$normal_theme"; then
|
if theme_exists "$normal_theme"; then
|
||||||
set_xfwm_theme "$normal_theme"
|
set_xfwm_theme "$normal_theme"
|
||||||
@@ -156,10 +185,12 @@ sync_theme() {
|
|||||||
|
|
||||||
# Apply the current theme for XFWM unless it's initial_sync on system reboot
|
# Apply the current theme for XFWM unless it's initial_sync on system reboot
|
||||||
if [ "$1" != 'initial_sync' ]; then
|
if [ "$1" != 'initial_sync' ]; then
|
||||||
set_xfwm_theme "$current_theme"
|
|
||||||
|
|
||||||
# Use the highDPI variant of the XFWM theme if the current_window_scaling factor is 2
|
# 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'
|
if [ "$current_window_scaling" -eq '2' ]; then
|
||||||
|
use_hdpi_theme_variant "$current_theme"
|
||||||
|
else
|
||||||
|
set_xfwm_theme "$current_theme"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Cleanup flatpak_themes_dir and remove ~/.config/gtk-4.0
|
# Cleanup flatpak_themes_dir and remove ~/.config/gtk-4.0
|
||||||
@@ -187,7 +218,8 @@ sync_font() {
|
|||||||
sync_theme 'initial_sync'
|
sync_theme 'initial_sync'
|
||||||
sync_font
|
sync_font
|
||||||
|
|
||||||
# Monitor when the user changes their system theme/icons/font in XFCE and sync them as needed
|
# Monitor when the user changes their system theme, font or
|
||||||
|
# DPI setting in XFCE and sync them as needed
|
||||||
while read -r line; do
|
while read -r line; do
|
||||||
case "$line" in
|
case "$line" in
|
||||||
'set: /Net/ThemeName') sync_theme ;;
|
'set: /Net/ThemeName') sync_theme ;;
|
||||||
|
Reference in New Issue
Block a user