Merge pull request #1 from ferrreo/active-program-icon
feat: add toggle for showing active window icon in title bar
This commit is contained in:
commit
8a07aeab2c
4 changed files with 214 additions and 122 deletions
|
|
@ -2,67 +2,108 @@ import QtQuick
|
||||||
import Quickshell
|
import Quickshell
|
||||||
import qs.Components
|
import qs.Components
|
||||||
import qs.Settings
|
import qs.Settings
|
||||||
|
import Quickshell.Wayland
|
||||||
|
|
||||||
Item {
|
Item {
|
||||||
id: activeWindowWrapper
|
id: activeWindowWrapper
|
||||||
width: parent.width
|
width: parent.width
|
||||||
property int fullHeight: activeWindowTitleContainer.height
|
property int fullHeight: activeWindowTitleContainer.height
|
||||||
|
|
||||||
y: panel.activeWindowVisible ? barBackground.height : barBackground.height - fullHeight
|
y: panel.activeWindowVisible ? barBackground.height : barBackground.height - fullHeight
|
||||||
height: panel.activeWindowVisible ? fullHeight : 1
|
height: panel.activeWindowVisible ? fullHeight : 1
|
||||||
opacity: panel.activeWindowVisible ? 1 : 0
|
opacity: panel.activeWindowVisible ? 1 : 0
|
||||||
clip: true
|
clip: true
|
||||||
|
|
||||||
Behavior on height { NumberAnimation { duration: 300; easing.type: Easing.OutQuad } }
|
function getIcon() {
|
||||||
Behavior on y { NumberAnimation { duration: 300; easing.type: Easing.OutQuad } }
|
var icon = Quickshell.iconPath(ToplevelManager.activeToplevel.appId.toLowerCase(), true);
|
||||||
Behavior on opacity { NumberAnimation { duration: 250 } }
|
if (!icon) {
|
||||||
|
icon = Quickshell.iconPath(ToplevelManager.activeToplevel.appId, true);
|
||||||
|
}
|
||||||
|
if (!icon) {
|
||||||
|
icon = Quickshell.iconPath(ToplevelManager.activeToplevel.title, true);
|
||||||
|
}
|
||||||
|
if (!icon) {
|
||||||
|
icon = Quickshell.iconPath(ToplevelManager.activeToplevel.title.toLowerCase(), "application-x-executable");
|
||||||
|
}
|
||||||
|
|
||||||
Rectangle {
|
return icon;
|
||||||
id: activeWindowTitleContainer
|
}
|
||||||
color: Theme.backgroundPrimary
|
|
||||||
bottomLeftRadius: Math.max(0, width / 2)
|
|
||||||
bottomRightRadius: Math.max(0, width / 2)
|
|
||||||
|
|
||||||
width: Math.min(barBackground.width - 200, activeWindowTitle.implicitWidth + 24)
|
Behavior on height {
|
||||||
height: activeWindowTitle.implicitHeight + 12
|
NumberAnimation {
|
||||||
|
duration: 300
|
||||||
|
easing.type: Easing.OutQuad
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Behavior on y {
|
||||||
|
NumberAnimation {
|
||||||
|
duration: 300
|
||||||
|
easing.type: Easing.OutQuad
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Behavior on opacity {
|
||||||
|
NumberAnimation {
|
||||||
|
duration: 250
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
anchors.top: parent.top
|
Rectangle {
|
||||||
anchors.horizontalCenter: parent.horizontalCenter
|
id: activeWindowTitleContainer
|
||||||
|
color: Theme.backgroundPrimary
|
||||||
|
bottomLeftRadius: Math.max(0, width / 2)
|
||||||
|
bottomRightRadius: Math.max(0, width / 2)
|
||||||
|
|
||||||
Text {
|
width: Math.min(barBackground.width - 200, activeWindowTitle.implicitWidth + (Settings.showActiveWindowIcon ? 28 : 22))
|
||||||
id: activeWindowTitle
|
height: activeWindowTitle.implicitHeight + 12
|
||||||
text: panel.displayedWindowTitle && panel.displayedWindowTitle.length > 60
|
|
||||||
? panel.displayedWindowTitle.substring(0, 60) + "..."
|
|
||||||
: panel.displayedWindowTitle
|
|
||||||
font.family: Theme.fontFamily
|
|
||||||
font.pixelSize: Theme.fontSizeCaption
|
|
||||||
color: Theme.textSecondary
|
|
||||||
elide: Text.ElideRight
|
|
||||||
horizontalAlignment: Text.AlignHCenter
|
|
||||||
verticalAlignment: Text.AlignVCenter
|
|
||||||
anchors.fill: parent
|
|
||||||
anchors.margins: 6
|
|
||||||
maximumLineCount: 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Corners {
|
anchors.top: parent.top
|
||||||
id: activeCornerRight
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
position: "bottomleft"
|
|
||||||
size: 1.1
|
Image {
|
||||||
fillColor: Theme.backgroundPrimary
|
id: icon
|
||||||
offsetX: activeWindowTitleContainer.x + activeWindowTitleContainer.width - 33
|
width: 10
|
||||||
offsetY: 0
|
height: 10
|
||||||
anchors.top: activeWindowTitleContainer.top
|
anchors.left: parent.left
|
||||||
}
|
anchors.leftMargin: 6
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
source: ToplevelManager.activeToplevel ? getIcon() : ""
|
||||||
|
visible: Settings.showActiveWindowIcon
|
||||||
|
}
|
||||||
|
|
||||||
|
Text {
|
||||||
|
id: activeWindowTitle
|
||||||
|
text: panel.displayedWindowTitle && panel.displayedWindowTitle.length > 60 ? panel.displayedWindowTitle.substring(0, 60) + "..." : panel.displayedWindowTitle
|
||||||
|
font.pixelSize: 12
|
||||||
|
color: Theme.textSecondary
|
||||||
|
elide: Text.ElideRight
|
||||||
|
anchors.right: parent.right
|
||||||
|
anchors.rightMargin: 6
|
||||||
|
horizontalAlignment: Settings.showActiveWindowIcon ? Text.AlignRight : Text.AlignHCenter
|
||||||
|
verticalAlignment: Text.AlignVCenter
|
||||||
|
anchors.fill: parent
|
||||||
|
|
||||||
|
maximumLineCount: 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Corners {
|
||||||
|
id: activeCornerRight
|
||||||
|
position: "bottomleft"
|
||||||
|
size: 1.1
|
||||||
|
fillColor: Theme.backgroundPrimary
|
||||||
|
offsetX: activeWindowTitleContainer.x + activeWindowTitleContainer.width - 33
|
||||||
|
offsetY: 0
|
||||||
|
anchors.top: activeWindowTitleContainer.top
|
||||||
|
}
|
||||||
|
|
||||||
|
Corners {
|
||||||
|
id: activeCornerLeft
|
||||||
|
position: "bottomright"
|
||||||
|
size: 1.1
|
||||||
|
fillColor: Theme.backgroundPrimary
|
||||||
|
anchors.top: activeWindowTitleContainer.top
|
||||||
|
x: activeWindowTitleContainer.x + 33 - width
|
||||||
|
offsetY: 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Corners {
|
|
||||||
id: activeCornerLeft
|
|
||||||
position: "bottomright"
|
|
||||||
size: 1.1
|
|
||||||
fillColor: Theme.backgroundPrimary
|
|
||||||
anchors.top: activeWindowTitleContainer.top
|
|
||||||
x: activeWindowTitleContainer.x + 33 - width
|
|
||||||
offsetY: 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -9,7 +9,7 @@ QtObject {
|
||||||
property string wallpaperFolder: "/home/lysec/nixos/assets/wallpapers" // Default path, make persistent
|
property string wallpaperFolder: "/home/lysec/nixos/assets/wallpapers" // Default path, make persistent
|
||||||
property string currentWallpaper: ""
|
property string currentWallpaper: ""
|
||||||
property string videoPath: "~/Videos/" // Default path, make persistent
|
property string videoPath: "~/Videos/" // Default path, make persistent
|
||||||
|
property bool showActiveWindowIcon
|
||||||
// Settings persistence
|
// Settings persistence
|
||||||
property var settings: Qt.createQmlObject('import QtCore; Settings { category: "Quickshell" }', this, "settings")
|
property var settings: Qt.createQmlObject('import QtCore; Settings { category: "Quickshell" }', this, "settings")
|
||||||
|
|
||||||
|
|
@ -18,15 +18,14 @@ QtObject {
|
||||||
}
|
}
|
||||||
|
|
||||||
function loadSettings() {
|
function loadSettings() {
|
||||||
let wc = settings.value("weatherCity", "Dinslaken");
|
weatherCity = settings.value("weatherCity", weatherCity)
|
||||||
weatherCity = (wc !== undefined && wc !== null) ? wc : "Dinslaken";
|
profileImage = settings.value("profileImage", profileImage)
|
||||||
let pi = settings.value("profileImage", "https://cdn.discordapp.com/avatars/158005126638993408/de403f05fd7f74bb17e01a9b066a30fa?size=64");
|
|
||||||
profileImage = (pi !== undefined && pi !== null) ? pi : "https://cdn.discordapp.com/avatars/158005126638993408/de403f05fd7f74bb17e01a9b066a30fa?size=64";
|
|
||||||
let tempUnit = settings.value("weatherTempUnit", "celsius")
|
let tempUnit = settings.value("weatherTempUnit", "celsius")
|
||||||
useFahrenheit = (tempUnit === "fahrenheit")
|
useFahrenheit = (tempUnit === "fahrenheit")
|
||||||
wallpaperFolder = settings.value("wallpaperFolder", "/home/lysec/nixos/assets/wallpapers")
|
wallpaperFolder = settings.value("wallpaperFolder", wallpaperFolder)
|
||||||
currentWallpaper = settings.value("currentWallpaper", "")
|
currentWallpaper = settings.value("currentWallpaper", currentWallpaper)
|
||||||
videoPath = settings.value("videoPath", "/home/lysec/Videos")
|
videoPath = settings.value("videoPath", videoPath)
|
||||||
|
showActiveWindowIcon = settings.value("showActiveWindowIcon", showActiveWindowIcon)
|
||||||
console.log("Loaded profileImage:", profileImage)
|
console.log("Loaded profileImage:", profileImage)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -37,6 +36,7 @@ QtObject {
|
||||||
settings.setValue("wallpaperFolder", wallpaperFolder)
|
settings.setValue("wallpaperFolder", wallpaperFolder)
|
||||||
settings.setValue("currentWallpaper", currentWallpaper)
|
settings.setValue("currentWallpaper", currentWallpaper)
|
||||||
settings.setValue("videoPath", videoPath)
|
settings.setValue("videoPath", videoPath)
|
||||||
|
settings.setValue("showActiveWindowIcon", showActiveWindowIcon)
|
||||||
settings.sync()
|
settings.sync()
|
||||||
console.log("Saving profileImage:", profileImage)
|
console.log("Saving profileImage:", profileImage)
|
||||||
}
|
}
|
||||||
|
|
@ -45,4 +45,4 @@ QtObject {
|
||||||
// onWeatherCityChanged: saveSettings()
|
// onWeatherCityChanged: saveSettings()
|
||||||
// onProfileImageChanged: saveSettings()
|
// onProfileImageChanged: saveSettings()
|
||||||
// onUseFahrenheitChanged: saveSettings()
|
// onUseFahrenheitChanged: saveSettings()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,12 +7,14 @@ import qs.Settings
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: profileSettingsCard
|
id: profileSettingsCard
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: 140
|
Layout.preferredHeight: 200
|
||||||
color: Theme.surface
|
color: Theme.surface
|
||||||
radius: 18
|
radius: 18
|
||||||
border.color: "transparent"
|
border.color: "transparent"
|
||||||
border.width: 0
|
border.width: 0
|
||||||
Layout.bottomMargin: 16
|
Layout.bottomMargin: 16
|
||||||
|
property bool showActiveWindowIcon: false
|
||||||
|
signal showAWIconChanged(bool showActiveWindowIcon)
|
||||||
|
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
|
|
@ -27,14 +29,13 @@ Rectangle {
|
||||||
Text {
|
Text {
|
||||||
text: "person"
|
text: "person"
|
||||||
font.family: "Material Symbols Outlined"
|
font.family: "Material Symbols Outlined"
|
||||||
font.pixelSize: Theme.fontSizeBody
|
font.pixelSize: 20
|
||||||
color: Theme.accentPrimary
|
color: Theme.accentPrimary
|
||||||
}
|
}
|
||||||
|
|
||||||
Text {
|
Text {
|
||||||
text: "Profile Image"
|
text: "Profile Image"
|
||||||
font.family: Theme.fontFamily
|
font.pixelSize: 16
|
||||||
font.pixelSize: Theme.fontSizeBody
|
|
||||||
font.bold: true
|
font.bold: true
|
||||||
color: Theme.textPrimary
|
color: Theme.textPrimary
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
|
|
@ -83,7 +84,7 @@ Rectangle {
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
text: "person"
|
text: "person"
|
||||||
font.family: "Material Symbols Outlined"
|
font.family: "Material Symbols Outlined"
|
||||||
font.pixelSize: Theme.fontSizeBody
|
font.pixelSize: 18
|
||||||
color: Theme.accentPrimary
|
color: Theme.accentPrimary
|
||||||
visible: Settings.profileImage === ""
|
visible: Settings.profileImage === ""
|
||||||
}
|
}
|
||||||
|
|
@ -92,7 +93,7 @@ Rectangle {
|
||||||
// Text input styled exactly like weather city
|
// Text input styled exactly like weather city
|
||||||
Rectangle {
|
Rectangle {
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: 40
|
Layout.preferredHeight: 36
|
||||||
radius: 8
|
radius: 8
|
||||||
color: Theme.surfaceVariant
|
color: Theme.surfaceVariant
|
||||||
border.color: profileImageInput.activeFocus ? Theme.accentPrimary : Theme.outline
|
border.color: profileImageInput.activeFocus ? Theme.accentPrimary : Theme.outline
|
||||||
|
|
@ -100,17 +101,10 @@ Rectangle {
|
||||||
|
|
||||||
TextInput {
|
TextInput {
|
||||||
id: profileImageInput
|
id: profileImageInput
|
||||||
anchors.left: parent.left
|
anchors.fill: parent
|
||||||
anchors.right: parent.right
|
anchors.margins: 12
|
||||||
anchors.top: parent.top
|
|
||||||
anchors.bottom: parent.bottom
|
|
||||||
anchors.leftMargin: 12
|
|
||||||
anchors.rightMargin: 12
|
|
||||||
anchors.topMargin: 6
|
|
||||||
anchors.bottomMargin: 6
|
|
||||||
text: Settings.profileImage
|
text: Settings.profileImage
|
||||||
font.family: Theme.fontFamily
|
font.pixelSize: 13
|
||||||
font.pixelSize: Theme.fontSizeSmall
|
|
||||||
color: Theme.textPrimary
|
color: Theme.textPrimary
|
||||||
verticalAlignment: TextInput.AlignVCenter
|
verticalAlignment: TextInput.AlignVCenter
|
||||||
clip: true
|
clip: true
|
||||||
|
|
@ -132,6 +126,58 @@ Rectangle {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Show Active Window Icon Setting
|
||||||
|
RowLayout {
|
||||||
|
spacing: 8
|
||||||
|
Layout.fillWidth: true
|
||||||
|
|
||||||
|
Text {
|
||||||
|
text: "Show Active Window Icon"
|
||||||
|
font.pixelSize: 13
|
||||||
|
font.bold: true
|
||||||
|
color: Theme.textPrimary
|
||||||
|
}
|
||||||
|
|
||||||
|
Item {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
}
|
||||||
|
|
||||||
|
// Custom Material 3 Switch
|
||||||
|
Rectangle {
|
||||||
|
id: customSwitch
|
||||||
|
width: 52
|
||||||
|
height: 32
|
||||||
|
radius: 16
|
||||||
|
color: Theme.accentPrimary
|
||||||
|
border.color: Theme.accentPrimary
|
||||||
|
border.width: 2
|
||||||
|
|
||||||
|
Rectangle {
|
||||||
|
id: thumb
|
||||||
|
width: 28
|
||||||
|
height: 28
|
||||||
|
radius: 14
|
||||||
|
color: Theme.surface
|
||||||
|
border.color: Theme.outline
|
||||||
|
border.width: 1
|
||||||
|
y: 2
|
||||||
|
x: showActiveWindowIcon ? customSwitch.width - width - 2 : 2
|
||||||
|
|
||||||
|
Behavior on x {
|
||||||
|
NumberAnimation { duration: 200; easing.type: Easing.OutCubic }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
MouseArea {
|
||||||
|
anchors.fill: parent
|
||||||
|
onClicked: {
|
||||||
|
showAWIconChanged(!showActiveWindowIcon)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Video Path Input Row
|
// Video Path Input Row
|
||||||
RowLayout {
|
RowLayout {
|
||||||
spacing: 8
|
spacing: 8
|
||||||
|
|
@ -139,15 +185,14 @@ Rectangle {
|
||||||
|
|
||||||
Text {
|
Text {
|
||||||
text: "Video Path"
|
text: "Video Path"
|
||||||
font.family: Theme.fontFamily
|
font.pixelSize: 14
|
||||||
font.pixelSize: Theme.fontSizeSmall
|
|
||||||
color: Theme.textPrimary
|
color: Theme.textPrimary
|
||||||
Layout.alignment: Qt.AlignVCenter
|
Layout.alignment: Qt.AlignVCenter
|
||||||
}
|
}
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: 40
|
Layout.preferredHeight: 36
|
||||||
radius: 8
|
radius: 8
|
||||||
color: Theme.surfaceVariant
|
color: Theme.surfaceVariant
|
||||||
border.color: videoPathInput.activeFocus ? Theme.accentPrimary : Theme.outline
|
border.color: videoPathInput.activeFocus ? Theme.accentPrimary : Theme.outline
|
||||||
|
|
@ -155,17 +200,10 @@ Rectangle {
|
||||||
|
|
||||||
TextInput {
|
TextInput {
|
||||||
id: videoPathInput
|
id: videoPathInput
|
||||||
anchors.left: parent.left
|
anchors.fill: parent
|
||||||
anchors.right: parent.right
|
anchors.margins: 12
|
||||||
anchors.top: parent.top
|
|
||||||
anchors.bottom: parent.bottom
|
|
||||||
anchors.leftMargin: 12
|
|
||||||
anchors.rightMargin: 12
|
|
||||||
anchors.topMargin: 6
|
|
||||||
anchors.bottomMargin: 6
|
|
||||||
text: Settings.videoPath !== undefined ? Settings.videoPath : ""
|
text: Settings.videoPath !== undefined ? Settings.videoPath : ""
|
||||||
font.family: Theme.fontFamily
|
font.pixelSize: 13
|
||||||
font.pixelSize: Theme.fontSizeSmall
|
|
||||||
color: Theme.textPrimary
|
color: Theme.textPrimary
|
||||||
verticalAlignment: TextInput.AlignVCenter
|
verticalAlignment: TextInput.AlignVCenter
|
||||||
clip: true
|
clip: true
|
||||||
|
|
@ -184,4 +222,4 @@ Rectangle {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -20,12 +20,12 @@ PanelWindow {
|
||||||
//border.width: 1
|
//border.width: 1
|
||||||
WlrLayershell.keyboardFocus: visible ? WlrKeyboardFocus.OnDemand : WlrKeyboardFocus.None
|
WlrLayershell.keyboardFocus: visible ? WlrKeyboardFocus.OnDemand : WlrKeyboardFocus.None
|
||||||
|
|
||||||
|
|
||||||
// Local properties for editing (not saved until apply)
|
// Local properties for editing (not saved until apply)
|
||||||
property string tempWeatherCity: (Settings.weatherCity !== undefined && Settings.weatherCity !== null) ? Settings.weatherCity : ""
|
property string tempWeatherCity: (Settings.weatherCity !== undefined && Settings.weatherCity !== null) ? Settings.weatherCity : ""
|
||||||
property bool tempUseFahrenheit: Settings.useFahrenheit
|
property bool tempUseFahrenheit: Settings.useFahrenheit
|
||||||
property string tempProfileImage: (Settings.profileImage !== undefined && Settings.profileImage !== null) ? Settings.profileImage : ""
|
property string tempProfileImage: (Settings.profileImage !== undefined && Settings.profileImage !== null) ? Settings.profileImage : ""
|
||||||
property string tempWallpaperFolder: (Settings.wallpaperFolder !== undefined && Settings.wallpaperFolder !== null) ? Settings.wallpaperFolder : ""
|
property string tempWallpaperFolder: (Settings.wallpaperFolder !== undefined && Settings.wallpaperFolder !== null) ? Settings.wallpaperFolder : ""
|
||||||
|
property bool tempShowActiveWindowIcon: Settings.showActiveWindowIcon
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
|
|
@ -55,7 +55,6 @@ PanelWindow {
|
||||||
}
|
}
|
||||||
Text {
|
Text {
|
||||||
text: "Settings"
|
text: "Settings"
|
||||||
font.family: Theme.fontFamily
|
|
||||||
font.pixelSize: 26
|
font.pixelSize: 26
|
||||||
font.bold: true
|
font.bold: true
|
||||||
color: Theme.textPrimary
|
color: Theme.textPrimary
|
||||||
|
|
@ -117,21 +116,32 @@ PanelWindow {
|
||||||
WeatherSettings {
|
WeatherSettings {
|
||||||
weatherCity: (typeof tempWeatherCity !== 'undefined' && tempWeatherCity !== null) ? tempWeatherCity : ""
|
weatherCity: (typeof tempWeatherCity !== 'undefined' && tempWeatherCity !== null) ? tempWeatherCity : ""
|
||||||
useFahrenheit: tempUseFahrenheit
|
useFahrenheit: tempUseFahrenheit
|
||||||
onCityChanged: function(city) { tempWeatherCity = city }
|
onCityChanged: function (city) {
|
||||||
onTemperatureUnitChanged: function(useFahrenheit) { tempUseFahrenheit = useFahrenheit }
|
tempWeatherCity = city;
|
||||||
|
}
|
||||||
|
onTemperatureUnitChanged: function (useFahrenheit) {
|
||||||
|
tempUseFahrenheit = useFahrenheit;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CollapsibleCategory {
|
CollapsibleCategory {
|
||||||
title: "System"
|
title: "System"
|
||||||
expanded: false
|
expanded: false
|
||||||
ProfileSettings { }
|
ProfileSettings {
|
||||||
|
showActiveWindowIcon: tempShowActiveWindowIcon
|
||||||
|
onShowAWIconChanged: function (showActiveWindowIcon) {
|
||||||
|
tempShowActiveWindowIcon = showActiveWindowIcon;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
CollapsibleCategory {
|
CollapsibleCategory {
|
||||||
title: "Wallpaper"
|
title: "Wallpaper"
|
||||||
expanded: false
|
expanded: false
|
||||||
WallpaperSettings {
|
WallpaperSettings {
|
||||||
wallpaperFolder: (typeof tempWallpaperFolder !== 'undefined' && tempWallpaperFolder !== null) ? tempWallpaperFolder : ""
|
wallpaperFolder: (typeof tempWallpaperFolder !== 'undefined' && tempWallpaperFolder !== null) ? tempWallpaperFolder : ""
|
||||||
onWallpaperFolderEdited: function(folder) { tempWallpaperFolder = folder }
|
onWallpaperFolderEdited: function (folder) {
|
||||||
|
tempWallpaperFolder = folder;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -150,7 +160,6 @@ PanelWindow {
|
||||||
Text {
|
Text {
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
text: "Apply Changes"
|
text: "Apply Changes"
|
||||||
font.family: Theme.fontFamily
|
|
||||||
font.pixelSize: 17
|
font.pixelSize: 17
|
||||||
font.bold: true
|
font.bold: true
|
||||||
color: applyButtonArea.containsMouse ? Theme.onAccent : Theme.onAccent
|
color: applyButtonArea.containsMouse ? Theme.onAccent : Theme.onAccent
|
||||||
|
|
@ -160,15 +169,16 @@ PanelWindow {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
hoverEnabled: true
|
hoverEnabled: true
|
||||||
onClicked: {
|
onClicked: {
|
||||||
Settings.weatherCity = (typeof tempWeatherCity !== 'undefined' && tempWeatherCity !== null) ? tempWeatherCity : ""
|
Settings.weatherCity = (typeof tempWeatherCity !== 'undefined' && tempWeatherCity !== null) ? tempWeatherCity : "";
|
||||||
Settings.useFahrenheit = tempUseFahrenheit
|
Settings.useFahrenheit = tempUseFahrenheit;
|
||||||
Settings.profileImage = (typeof tempProfileImage !== 'undefined' && tempProfileImage !== null) ? tempProfileImage : ""
|
Settings.profileImage = (typeof tempProfileImage !== 'undefined' && tempProfileImage !== null) ? tempProfileImage : "";
|
||||||
Settings.wallpaperFolder = (typeof tempWallpaperFolder !== 'undefined' && tempWallpaperFolder !== null) ? tempWallpaperFolder : ""
|
Settings.wallpaperFolder = (typeof tempWallpaperFolder !== 'undefined' && tempWallpaperFolder !== null) ? tempWallpaperFolder : "";
|
||||||
Settings.saveSettings()
|
Settings.showActiveWindowIcon = tempShowActiveWindowIcon;
|
||||||
|
Settings.saveSettings();
|
||||||
if (typeof weather !== 'undefined' && weather) {
|
if (typeof weather !== 'undefined' && weather) {
|
||||||
weather.fetchCityWeather()
|
weather.fetchCityWeather();
|
||||||
}
|
}
|
||||||
settingsModal.closeSettings()
|
settingsModal.closeSettings();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -177,19 +187,21 @@ PanelWindow {
|
||||||
|
|
||||||
// Function to open the modal and initialize temp values
|
// Function to open the modal and initialize temp values
|
||||||
function openSettings() {
|
function openSettings() {
|
||||||
tempWeatherCity = (Settings.weatherCity !== undefined && Settings.weatherCity !== null) ? Settings.weatherCity : ""
|
tempWeatherCity = (Settings.weatherCity !== undefined && Settings.weatherCity !== null) ? Settings.weatherCity : "";
|
||||||
tempUseFahrenheit = Settings.useFahrenheit
|
tempUseFahrenheit = Settings.useFahrenheit;
|
||||||
tempProfileImage = (Settings.profileImage !== undefined && Settings.profileImage !== null) ? Settings.profileImage : ""
|
tempShowActiveWindowIcon = Settings.showActiveWindowIcon;
|
||||||
tempWallpaperFolder = (Settings.wallpaperFolder !== undefined && Settings.wallpaperFolder !== null) ? Settings.wallpaperFolder : ""
|
tempProfileImage = (Settings.profileImage !== undefined && Settings.profileImage !== null) ? Settings.profileImage : "";
|
||||||
if (tempWallpaperFolder === undefined || tempWallpaperFolder === null) tempWallpaperFolder = ""
|
tempWallpaperFolder = (Settings.wallpaperFolder !== undefined && Settings.wallpaperFolder !== null) ? Settings.wallpaperFolder : "";
|
||||||
visible = true
|
if (tempWallpaperFolder === undefined || tempWallpaperFolder === null)
|
||||||
|
tempWallpaperFolder = "";
|
||||||
|
visible = true;
|
||||||
// Force focus on the text input after a short delay
|
// Force focus on the text input after a short delay
|
||||||
focusTimer.start()
|
focusTimer.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Function to close the modal and release focus
|
// Function to close the modal and release focus
|
||||||
function closeSettings() {
|
function closeSettings() {
|
||||||
visible = false
|
visible = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
Timer {
|
Timer {
|
||||||
|
|
@ -197,16 +209,17 @@ PanelWindow {
|
||||||
interval: 100
|
interval: 100
|
||||||
repeat: false
|
repeat: false
|
||||||
onTriggered: {
|
onTriggered: {
|
||||||
if (visible) {
|
if (visible)
|
||||||
// Focus will be handled by the individual components
|
// Focus will be handled by the individual components
|
||||||
}
|
{}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Release focus when modal becomes invisible
|
// Release focus when modal becomes invisible
|
||||||
onVisibleChanged: {
|
onVisibleChanged: {
|
||||||
if (!visible) {
|
if (!visible)
|
||||||
// Focus will be handled by the individual components
|
// Focus will be handled by the individual components
|
||||||
}
|
{}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue