Compare commits
3 commits
c5ac7fe773
...
0f7dbb8041
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0f7dbb8041 | ||
|
|
a0ccdc231b | ||
|
|
1d350e35d6 |
3 changed files with 43 additions and 59 deletions
|
|
@ -1,70 +1,42 @@
|
||||||
pragma ComponentBehavior: Bound
|
import qs.components
|
||||||
|
|
||||||
import qs.config
|
import qs.config
|
||||||
import qs.constants
|
import qs.constants
|
||||||
import qs.widgets
|
|
||||||
import QtQuick
|
import QtQuick
|
||||||
import Quickshell.Hyprland
|
import Quickshell.Hyprland
|
||||||
|
|
||||||
Loader {
|
StyledIconButton {
|
||||||
id: root
|
id: root
|
||||||
required property HyprlandWorkspace modelData
|
|
||||||
|
|
||||||
active: modelData.id > 0
|
required property HyprlandWorkspace workspace
|
||||||
|
|
||||||
sourceComponent: workspace
|
text: Icons.triangle
|
||||||
property Component workspace: StyledButton {
|
font.bold: true
|
||||||
id: clickable
|
font.pixelSize: 17
|
||||||
|
padding: 8
|
||||||
|
|
||||||
onClicked: root.modelData.activate()
|
onClicked: root.workspace.activate()
|
||||||
|
|
||||||
content: Text {
|
states: [
|
||||||
id: icon
|
State {
|
||||||
|
name: "focused"
|
||||||
font.family: Theme.lucide.font.family
|
when: root.workspace.focused
|
||||||
font.pixelSize: Dimensions.workspace.iconSize
|
PropertyChanges {
|
||||||
font.bold: true
|
root {
|
||||||
text: Icons.triangle
|
rotation: 180
|
||||||
|
color: root.hovered ? Theme.palette.basecontent : Theme.palette.primary
|
||||||
color: Theme.palette.basecontent
|
|
||||||
|
|
||||||
states: [
|
|
||||||
State {
|
|
||||||
name: "focused"
|
|
||||||
when: root.modelData.focused
|
|
||||||
PropertyChanges {
|
|
||||||
icon {
|
|
||||||
rotation: 180
|
|
||||||
color: clickable.hovered ? Theme.palette.basecontent : Theme.palette.primary
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
State {
|
|
||||||
name: "active"
|
|
||||||
when: root.modelData.active
|
|
||||||
PropertyChanges {
|
|
||||||
icon {
|
|
||||||
text: Icons.triangleDashed
|
|
||||||
rotation: 180
|
|
||||||
color: clickable.hovered ? Theme.palette.basecontent : Theme.palette.primary
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
]
|
}
|
||||||
|
},
|
||||||
transitions: Transition {
|
State {
|
||||||
reversible: true
|
name: "active"
|
||||||
ParallelAnimation {
|
when: root.workspace.active
|
||||||
RotationAnimation {
|
PropertyChanges {
|
||||||
duration: 200
|
root {
|
||||||
easing.type: Easing.InOutCubic
|
text: Icons.triangleDashed
|
||||||
}
|
rotation: 180
|
||||||
ColorAnimation {
|
color: root.hovered ? Theme.palette.basecontent : Theme.palette.primary
|
||||||
duration: 200
|
|
||||||
easing.type: Easing.OutCubic
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
pragma ComponentBehavior: Bound
|
||||||
|
|
||||||
import qs.config
|
import qs.config
|
||||||
import QtQuick
|
import QtQuick
|
||||||
import QtQuick.Layouts
|
import QtQuick.Layouts
|
||||||
|
|
@ -12,6 +14,16 @@ RowLayout {
|
||||||
|
|
||||||
model: Hyprland.workspaces
|
model: Hyprland.workspaces
|
||||||
|
|
||||||
Workspace {}
|
Loader {
|
||||||
|
id: loader
|
||||||
|
required property HyprlandWorkspace modelData
|
||||||
|
|
||||||
|
active: modelData.id > 0
|
||||||
|
|
||||||
|
sourceComponent: workspace
|
||||||
|
property Component workspace: Workspace {
|
||||||
|
workspace: loader.modelData
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,20 +1,20 @@
|
||||||
pragma ComponentBehavior: Bound
|
pragma ComponentBehavior: Bound
|
||||||
|
|
||||||
import qs.widgets
|
import qs.components
|
||||||
import QtQuick
|
import QtQuick
|
||||||
import Quickshell
|
import Quickshell
|
||||||
import Quickshell.Services.SystemTray
|
import Quickshell.Services.SystemTray
|
||||||
import Quickshell.Widgets
|
import Quickshell.Widgets
|
||||||
import "menu/"
|
import "menu/"
|
||||||
|
|
||||||
StyledButton {
|
StyledIconButton {
|
||||||
id: root
|
id: root
|
||||||
|
|
||||||
property SystemTrayItem trayItem
|
property SystemTrayItem trayItem
|
||||||
|
|
||||||
onClicked: menu.toggle()
|
onClicked: menu.toggle()
|
||||||
|
|
||||||
content: IconImage {
|
contentItem: IconImage {
|
||||||
id: icon
|
id: icon
|
||||||
asynchronous: true
|
asynchronous: true
|
||||||
implicitSize: 18
|
implicitSize: 18
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue