mirror of
https://github.com/danbulant/dots-hyprland
synced 2026-05-24 12:22:09 +00:00
253 lines
9.2 KiB
QML
253 lines
9.2 KiB
QML
import "root:/"
|
|
import "root:/services"
|
|
import "root:/modules/common"
|
|
import "root:/modules/common/widgets"
|
|
import "root:/modules/common/functions/string_utils.js" as StringUtils
|
|
import "root:/modules/common/functions/file_utils.js" as FileUtils
|
|
import "./quickToggles/"
|
|
import "root:/services/"
|
|
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
import QtQuick.Effects
|
|
import Qt5Compat.GraphicalEffects
|
|
import Quickshell.Io
|
|
import Quickshell
|
|
import Quickshell.Widgets
|
|
import Quickshell.Wayland
|
|
import Quickshell.Hyprland
|
|
|
|
Scope {
|
|
id: root
|
|
property int sidebarWidth: Appearance.sizes.sidebarWidth
|
|
property int sidebarPadding: 15
|
|
property string settingsQmlPath: Quickshell.configPath("settings.qml")
|
|
|
|
PanelWindow {
|
|
id: sidebarRoot
|
|
visible: GlobalStates.sidebarRightOpen
|
|
|
|
function hide() {
|
|
GlobalStates.sidebarRightOpen = false
|
|
}
|
|
|
|
exclusiveZone: 0
|
|
implicitWidth: sidebarWidth
|
|
WlrLayershell.namespace: "quickshell:sidebarRight"
|
|
// Hyprland 0.49: Focus is always exclusive and setting this breaks mouse focus grab
|
|
// WlrLayershell.keyboardFocus: WlrKeyboardFocus.Exclusive
|
|
color: "transparent"
|
|
|
|
anchors {
|
|
top: true
|
|
right: true
|
|
bottom: true
|
|
}
|
|
|
|
HyprlandFocusGrab {
|
|
id: grab
|
|
windows: [ sidebarRoot ]
|
|
active: GlobalStates.sidebarRightOpen
|
|
onCleared: () => {
|
|
if (!active) sidebarRoot.hide()
|
|
}
|
|
}
|
|
|
|
Loader {
|
|
id: sidebarContentLoader
|
|
active: GlobalStates.sidebarRightOpen
|
|
anchors {
|
|
top: parent.top
|
|
bottom: parent.bottom
|
|
right: parent.right
|
|
left: parent.left
|
|
topMargin: Appearance.sizes.hyprlandGapsOut
|
|
rightMargin: Appearance.sizes.hyprlandGapsOut
|
|
bottomMargin: Appearance.sizes.hyprlandGapsOut
|
|
leftMargin: Appearance.sizes.elevationMargin
|
|
}
|
|
width: sidebarWidth - Appearance.sizes.hyprlandGapsOut - Appearance.sizes.elevationMargin
|
|
height: parent.height - Appearance.sizes.hyprlandGapsOut * 2
|
|
|
|
focus: GlobalStates.sidebarRightOpen
|
|
Keys.onPressed: (event) => {
|
|
if (event.key === Qt.Key_Escape) {
|
|
sidebarRoot.hide();
|
|
}
|
|
}
|
|
|
|
sourceComponent: Item {
|
|
implicitHeight: sidebarRightBackground.implicitHeight
|
|
implicitWidth: sidebarRightBackground.implicitWidth
|
|
|
|
StyledRectangularShadow {
|
|
target: sidebarRightBackground
|
|
}
|
|
Rectangle {
|
|
id: sidebarRightBackground
|
|
|
|
anchors.fill: parent
|
|
implicitHeight: parent.height - Appearance.sizes.hyprlandGapsOut * 2
|
|
implicitWidth: sidebarWidth - Appearance.sizes.hyprlandGapsOut * 2
|
|
color: Appearance.colors.colLayer0
|
|
border.width: 1
|
|
border.color: Appearance.m3colors.m3outlineVariant
|
|
radius: Appearance.rounding.screenRounding - Appearance.sizes.hyprlandGapsOut + 1
|
|
|
|
ColumnLayout {
|
|
spacing: sidebarPadding
|
|
anchors.fill: parent
|
|
anchors.margins: sidebarPadding
|
|
|
|
RowLayout {
|
|
Layout.fillHeight: false
|
|
spacing: 10
|
|
Layout.margins: 10
|
|
Layout.topMargin: 5
|
|
Layout.bottomMargin: 0
|
|
|
|
Item {
|
|
implicitWidth: distroIcon.width
|
|
implicitHeight: distroIcon.height
|
|
CustomIcon {
|
|
id: distroIcon
|
|
width: 25
|
|
height: 25
|
|
source: SystemInfo.distroIcon
|
|
}
|
|
ColorOverlay {
|
|
anchors.fill: distroIcon
|
|
source: distroIcon
|
|
color: Appearance.colors.colOnLayer0
|
|
}
|
|
}
|
|
|
|
StyledText {
|
|
font.pixelSize: Appearance.font.pixelSize.normal
|
|
color: Appearance.colors.colOnLayer0
|
|
text: StringUtils.format(Translation.tr("Uptime: {0}"), DateTime.uptime)
|
|
textFormat: Text.MarkdownText
|
|
}
|
|
|
|
Item {
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
ButtonGroup {
|
|
QuickToggleButton {
|
|
toggled: false
|
|
buttonIcon: "restart_alt"
|
|
onClicked: {
|
|
Hyprland.dispatch("reload")
|
|
Quickshell.reload(true)
|
|
}
|
|
StyledToolTip {
|
|
content: Translation.tr("Reload Hyprland & Quickshell")
|
|
}
|
|
}
|
|
QuickToggleButton {
|
|
toggled: false
|
|
buttonIcon: "settings"
|
|
onClicked: {
|
|
Hyprland.dispatch("global quickshell:sidebarRightClose")
|
|
Quickshell.execDetached(["qs", "-p", root.settingsQmlPath])
|
|
}
|
|
StyledToolTip {
|
|
content: Translation.tr("Settings")
|
|
}
|
|
}
|
|
QuickToggleButton {
|
|
toggled: false
|
|
buttonIcon: "power_settings_new"
|
|
onClicked: {
|
|
Hyprland.dispatch("global quickshell:sessionOpen")
|
|
}
|
|
StyledToolTip {
|
|
content: Translation.tr("Session")
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
ButtonGroup {
|
|
Layout.alignment: Qt.AlignHCenter
|
|
spacing: 5
|
|
padding: 5
|
|
color: Appearance.colors.colLayer1
|
|
|
|
NetworkToggle {}
|
|
BluetoothToggle {}
|
|
NightLight {}
|
|
GameMode {}
|
|
IdleInhibitor {}
|
|
CloudflareWarp {}
|
|
}
|
|
|
|
// Center widget group
|
|
CenterWidgetGroup {
|
|
focus: sidebarRoot.visible
|
|
Layout.alignment: Qt.AlignHCenter
|
|
Layout.fillHeight: true
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
BottomWidgetGroup {
|
|
Layout.alignment: Qt.AlignHCenter
|
|
Layout.fillHeight: false
|
|
Layout.fillWidth: true
|
|
Layout.preferredHeight: implicitHeight
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
|
|
IpcHandler {
|
|
target: "sidebarRight"
|
|
|
|
function toggle(): void {
|
|
GlobalStates.sidebarRightOpen = !GlobalStates.sidebarRightOpen;
|
|
if(GlobalStates.sidebarRightOpen) Notifications.timeoutAll();
|
|
}
|
|
|
|
function close(): void {
|
|
GlobalStates.sidebarRightOpen = false;
|
|
}
|
|
|
|
function open(): void {
|
|
GlobalStates.sidebarRightOpen = true;
|
|
Notifications.timeoutAll();
|
|
}
|
|
}
|
|
|
|
GlobalShortcut {
|
|
name: "sidebarRightToggle"
|
|
description: Translation.tr("Toggles right sidebar on press")
|
|
|
|
onPressed: {
|
|
GlobalStates.sidebarRightOpen = !GlobalStates.sidebarRightOpen;
|
|
if(GlobalStates.sidebarRightOpen) Notifications.timeoutAll();
|
|
}
|
|
}
|
|
GlobalShortcut {
|
|
name: "sidebarRightOpen"
|
|
description: Translation.tr("Opens right sidebar on press")
|
|
|
|
onPressed: {
|
|
GlobalStates.sidebarRightOpen = true;
|
|
Notifications.timeoutAll();
|
|
}
|
|
}
|
|
GlobalShortcut {
|
|
name: "sidebarRightClose"
|
|
description: Translation.tr("Closes right sidebar on press")
|
|
|
|
onPressed: {
|
|
GlobalStates.sidebarRightOpen = false;
|
|
}
|
|
}
|
|
|
|
}
|