import qs.Commons import qs.Services import qs.Widgets import QtQuick import QtQuick.Controls import QtQuick.Layouts NIconButton { id: root sizeMultiplier: 0.8 readonly property real scaling: ScalingService.scale(screen) colorBg: Color.mSurfaceVariant colorFg: Color.mOnSurface colorBorder: Color.transparent colorBorderHover: Color.transparent // Enhanced icon states with better visual feedback icon: { if (ArchUpdaterService.busy) return "sync" if (ArchUpdaterService.updatePackages.length > 0) { // Show different icons based on update count const count = ArchUpdaterService.updatePackages.length if (count > 50) return "system_update_alt" // Many updates if (count > 10) return "system_update" // Moderate updates return "system_update" // Few updates } return "task_alt" } // Enhanced tooltip with more information tooltipText: { if (ArchUpdaterService.busy) return "Checking for updates…"; var count = ArchUpdaterService.updatePackages.length; if (count === 0) return "System is up to date ✓"; var header = count === 1 ? "One package can be upgraded:" : (count + " packages can be upgraded:"); var list = ArchUpdaterService.updatePackages || []; var s = ""; var limit = Math.min(list.length, 8); // Reduced to 8 for better readability for (var i = 0; i < limit; ++i) { var p = list[i]; s += (i ? "\n" : "") + (p.name + ": " + p.oldVersion + " → " + p.newVersion); } if (list.length > 8) s += "\n… and " + (list.length - 8) + " more"; return header + "\n\n" + s + "\n\nClick to update system"; } // Enhanced click behavior with confirmation onClicked: { if (ArchUpdaterService.busy) return; if (ArchUpdaterService.updatePackages.length > 0) { // Show confirmation dialog for updates PanelService.updatePanel.toggle(screen); } else { // Just refresh if no updates available ArchUpdaterService.doPoll(); } } }