Compare commits

...

5 Commits

11 changed files with 142 additions and 50 deletions

View File

@ -1,6 +1,6 @@
# Maintainer: TROM <contact@tromsite.com> # Maintainer: TROM <contact@tromsite.com>
pkgname=tromjaro-fixes pkgname=tromjaro-fixes
pkgver=1.1.1 pkgver=1.2.0
pkgrel=1 pkgrel=1
pkgdesc="Various fixes for TROMjaro OS" pkgdesc="Various fixes for TROMjaro OS"
arch=(any) arch=(any)
@ -12,9 +12,10 @@ depends=('xfce4-appfinder'
provides=('tromjaro-fixes') provides=('tromjaro-fixes')
backup=() backup=()
options=(!strip) options=(!strip)
install='fixes-package.install'
prepare() { prepare() {
cp -R ../bin ../flatpak-overrides ../alpm-hooks . cp -R ../bin ../flatpak-overrides ../alpm-hooks ../systemd .
} }
package() { package() {
@ -30,4 +31,9 @@ package() {
# copy flatpak overrides # copy flatpak overrides
install -d ${pkgdir}/var/lib/flatpak/overrides install -d ${pkgdir}/var/lib/flatpak/overrides
install -Dm644 ${srcdir}/flatpak-overrides/* ${pkgdir}/var/lib/flatpak/overrides install -Dm644 ${srcdir}/flatpak-overrides/* ${pkgdir}/var/lib/flatpak/overrides
# copy systemd units
install -d ${pkgdir}/usr/lib/systemd/user
install -Dm644 ${srcdir}/systemd/services/* ${pkgdir}/usr/lib/systemd/user
install -Dm644 ${srcdir}/systemd/timers/* ${pkgdir}/usr/lib/systemd/user
} }

View File

@ -1,7 +1,4 @@
#!/bin/sh #!/bin/sh
while :; do rm -r ~/.themes/* 2> /dev/null
rm -r ~/.themes/* 2> /dev/null rsync -av --progress /usr/share/themes/* ~/.themes/ --exclude Windowck
rsync -av --progress /usr/share/themes/* ~/.themes/ --exclude Windowck rsync -av --progress ~/.local/share/themes/* ~/.themes/ --exclude Windowck-dark
rsync -av --progress ~/.local/share/themes/* ~/.themes/ --exclude Windowck-dark
sleep 600
done

View File

@ -11,7 +11,6 @@ sync_theme() {
# Apply the current theme with gsettings # Apply the current theme with gsettings
gsettings set org.gnome.desktop.interface gtk-theme "$theme" gsettings set org.gnome.desktop.interface gtk-theme "$theme"
} }
sync_icon_theme() { sync_icon_theme() {
# Get the current icon theme # Get the current icon theme
icon_theme=$(xfconf-query -c xsettings -p /Net/IconThemeName) icon_theme=$(xfconf-query -c xsettings -p /Net/IconThemeName)
@ -20,25 +19,21 @@ sync_icon_theme() {
sed -i "s/^icon_theme=.*$/icon_theme=$icon_theme/" "$HOME"/.config/qt6ct/qt6ct.conf sed -i "s/^icon_theme=.*$/icon_theme=$icon_theme/" "$HOME"/.config/qt6ct/qt6ct.conf
} }
while :; do # Get the current system theme
# Get the current system theme theme_new=$(xfconf-query -c xsettings -p /Net/ThemeName)
theme_new=$(xfconf-query -c xsettings -p /Net/ThemeName) # Get the current icon theme
# Get the current icon theme icon_theme_new=$(xfconf-query -c xsettings -p /Net/IconThemeName)
icon_theme_new=$(xfconf-query -c xsettings -p /Net/IconThemeName) # Get the current font name
# Get the current font name font_new=$(xfconf-query -c xsettings -p /Gtk/FontName)
font_new=$(xfconf-query -c xsettings -p /Gtk/FontName)
# Run sync_theme if the new system theme doesn't match the previous one # Run sync_theme if the new system theme doesn't match the previous one
[ "$theme_new" != "$theme_prev" ] && sync_theme [ "$theme_new" != "$theme_prev" ] && sync_theme
# Run sync_icon_theme if the new icon theme doesn't match the previous one # Run sync_icon_theme if the new icon theme doesn't match the previous one
[ "$icon_theme_new" != "$icon_theme_prev" ] && sync_icon_theme [ "$icon_theme_new" != "$icon_theme_prev" ] && sync_icon_theme
# If the new font doesn't match the previous one, apply the new font for the title of xfce windows # If the new font doesn't match the previous one, apply the new font for the title of xfce windows
[ "$font_new" != "$font_prev" ] && xfconf-query -c xfwm4 -p /general/title_font -n -t string -s "$font_new" [ "$font_new" != "$font_prev" ] && xfconf-query -c xfwm4 -p /general/title_font -n -t string -s "$font_new"
# The new values become the previous values # The new values become the previous values
theme_prev=$theme_new theme_prev=$theme_new
icon_theme_prev=$icon_theme_new icon_theme_prev=$icon_theme_new
font_prev=$font_new font_prev=$font_new
sleep 3
done

View File

@ -66,24 +66,21 @@ fixfiles() {
done done
} }
while :; do user_new=$(ls -ad "$user"/*.desktop 2>/dev/null)
user_new=$(ls -ad "$user"/*.desktop 2>/dev/null) flatpak_local_new=$(ls -ad "$flatpak_local"/*.desktop 2>/dev/null)
flatpak_local_new=$(ls -ad "$flatpak_local"/*.desktop 2>/dev/null) flatpak_global_new=$(ls -ad "$flatpak_global"/*.desktop 2>/dev/null)
flatpak_global_new=$(ls -ad "$flatpak_global"/*.desktop 2>/dev/null) pacman_local_new=$(ls -ad "$pacman_local"/*.desktop 2>/dev/null)
pacman_local_new=$(ls -ad "$pacman_local"/*.desktop 2>/dev/null) pacman_global_new=$(ls -ad "$pacman_global"/*.desktop 2>/dev/null)
pacman_global_new=$(ls -ad "$pacman_global"/*.desktop 2>/dev/null) snap_new=$(ls -ad "$snap"/*.desktop 2>/dev/null)
snap_new=$(ls -ad "$snap"/*.desktop 2>/dev/null) [ "$user_new" != "$user_old" ] && detectfiles
[ "$user_new" != "$user_old" ] && detectfiles [ "$flatpak_local_new" != "$flatpak_local_old" ] ||
[ "$flatpak_local_new" != "$flatpak_local_old" ] || [ "$flatpak_global_new" != "$flatpak_global_old" ] ||
[ "$flatpak_global_new" != "$flatpak_global_old" ] || [ "$pacman_local_new" != "$pacman_local_old" ] ||
[ "$pacman_local_new" != "$pacman_local_old" ] || [ "$pacman_global_new" != "$pacman_global_old" ] ||
[ "$pacman_global_new" != "$pacman_global_old" ] || [ "$snap_new" != "$snap_old" ] && fixfiles
[ "$snap_new" != "$snap_old" ] && fixfiles user_old=$user_new
user_old=$user_new flatpak_local_old=$flatpak_local_new
flatpak_local_old=$flatpak_local_new flatpak_global_old=$flatpak_global_new
flatpak_global_old=$flatpak_global_new pacman_local_old=$pacman_local_new
pacman_local_old=$pacman_local_new pacman_global_old=$pacman_global_new
pacman_global_old=$pacman_global_new snap_old=$snap_new
snap_old=$snap_new
sleep 5
done

14
fixes-package.install Normal file
View File

@ -0,0 +1,14 @@
post_install() {
find /usr/lib/systemd/user/ -name "fix-*.timer" -type f -printf "%f\0" | xargs -0 systemctl --global enable
echo "Warning: A restart is required to take effect"
}
post_upgrade() {
find /usr/lib/systemd/user/ -name "fix-*.timer" -type f -printf "%f\0" | xargs -0 systemctl --global enable
echo "Warning: A restart is required to take effect"
}
pre_remove() {
find /usr/lib/systemd/user/ -name "fix-*.timer" -type f -printf "%f\0" | xargs -0 systemctl --global disable
echo "Warning: A restart is required to take effect"
}

View File

@ -0,0 +1,13 @@
# This service unit is for fix-flatpaks-theming script
#
[Unit]
Description=Fix flatpak theming script
Wants=fix-flatpaks-theming.timer
[Service]
Type=oneshot
ExecStart=/usr/bin/fix-flatpaks-theming
[Install]
WantedBy=default.target

View File

@ -0,0 +1,13 @@
# This service unit is for fix-theming script
#
[Unit]
Description=Fix theming script
Wants=fix-theming.timer
[Service]
Type=oneshot
ExecStart=/usr/bin/fix-theming
[Install]
WantedBy=default.target

View File

@ -0,0 +1,13 @@
# This service unit is for fix-tweaked-desktop-files script
#
[Unit]
Description=Fix tweaked desktop files script
Wants=fix-tweaked-desktop-files.timer
[Service]
Type=oneshot
ExecStart=/usr/bin/fix-tweaked-desktop-files
[Install]
WantedBy=default.target

View File

@ -0,0 +1,14 @@
# This timer unit is for fix-flatpaks-theming service unit
#
[Unit]
Description=Run fix flatpaks theming script every 600 seconds
Requires=fix-flatpaks-theming.service
[Timer]
Unit=fix-flatpaks-theming.service
OnBootSec=1
OnUnitActiveSec=600
[Install]
WantedBy=timers.target

View File

@ -0,0 +1,15 @@
# This timer unit is for fix-theming service unit
#
[Unit]
Description=Run fix theming script every 3 seconds
Requires=fix-theming.service
[Timer]
Unit=fix-theming.service
OnBootSec=1
OnUnitActiveSec=3
AccuracySec=1us
[Install]
WantedBy=timers.target

View File

@ -0,0 +1,15 @@
# This timer unit is for fix-tweaked-desktop-files service unit
#
[Unit]
Description=Run fix tweaked desktop files script every 5 seconds
Requires=fix-tweaked-desktop-files.service
[Timer]
Unit=fix-tweaked-desktop-files.service
OnBootSec=1
OnUnitActiveSec=5
AccuracySec=1us
[Install]
WantedBy=timers.target