merge
This commit is contained in:
commit
7f1dcb1c6b
@ -14,9 +14,9 @@ Variants {
|
|||||||
aboveWindows: true
|
aboveWindows: true
|
||||||
screen: modelData
|
screen: modelData
|
||||||
margins {
|
margins {
|
||||||
top: Settings.config.margins
|
top: Settings.config.floating ? Settings.config.margins : 0
|
||||||
left: Settings.config.margins
|
left: Settings.config.floating ? Settings.config.margins : 0
|
||||||
right: Settings.config.margins
|
right: Settings.config.floating ? Settings.config.margins : 0
|
||||||
}
|
}
|
||||||
|
|
||||||
anchors {
|
anchors {
|
||||||
@ -29,8 +29,8 @@ Variants {
|
|||||||
id: container
|
id: container
|
||||||
implicitHeight: Settings.config.barHeight
|
implicitHeight: Settings.config.barHeight
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
color: Colors.surface
|
color: Qt.rgba(Colors.surface.r, Colors.surface.g, Colors.surface.b, Settings.config.translucency)
|
||||||
radius: implicitHeight / 2
|
radius: Settings.config.floating ? Settings.config.barHeight / 2 : 0
|
||||||
|
|
||||||
Row {
|
Row {
|
||||||
id: leftStuff
|
id: leftStuff
|
||||||
@ -60,6 +60,7 @@ Variants {
|
|||||||
Volume {}
|
Volume {}
|
||||||
Battery {}
|
Battery {}
|
||||||
SysTray {}
|
SysTray {}
|
||||||
|
SettingsIcon {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -15,7 +15,7 @@ Loader {
|
|||||||
sourceComponent: Rectangle {
|
sourceComponent: Rectangle {
|
||||||
id: container
|
id: container
|
||||||
radius: implicitHeight / 2
|
radius: implicitHeight / 2
|
||||||
color: clickHandler.containsMouse ? Colors.secondaryContainer : Colors.primaryContainer
|
color: clickHandler.containsMouse ? Colors.primary : Colors.surfaceContainer
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
implicitWidth: root.implicitWidth + 20
|
implicitWidth: root.implicitWidth + 20
|
||||||
implicitHeight: Settings.config.barHeight - 10
|
implicitHeight: Settings.config.barHeight - 10
|
||||||
|
|||||||
@ -8,7 +8,7 @@ import qs.reusables
|
|||||||
Rectangle {
|
Rectangle {
|
||||||
id: container
|
id: container
|
||||||
radius: implicitHeight / 2
|
radius: implicitHeight / 2
|
||||||
color: formatSwitch.containsMouse ? Colors.secondaryContainer : Colors.primaryContainer
|
color: formatSwitch.containsMouse ? Colors.primaryContainer : Colors.surfaceContainer
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
implicitHeight: Settings.config.barHeight - 10
|
implicitHeight: Settings.config.barHeight - 10
|
||||||
implicitWidth: root.implicitWidth + 20
|
implicitWidth: root.implicitWidth + 20
|
||||||
|
|||||||
@ -8,7 +8,7 @@ Rectangle {
|
|||||||
id: container
|
id: container
|
||||||
visible: root.spotify != null
|
visible: root.spotify != null
|
||||||
radius: implicitHeight / 2
|
radius: implicitHeight / 2
|
||||||
color: clickHandler.containsMouse ? Colors.secondaryContainer : Colors.primaryContainer
|
color: clickHandler.containsMouse ? Colors.primaryContainer : Colors.surfaceContainer
|
||||||
implicitWidth: root.implicitWidth + 20
|
implicitWidth: root.implicitWidth + 20
|
||||||
implicitHeight: Settings.config.barHeight - 10
|
implicitHeight: Settings.config.barHeight - 10
|
||||||
Item {
|
Item {
|
||||||
|
|||||||
29
modules/bar/SettingsIcon.qml
Normal file
29
modules/bar/SettingsIcon.qml
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
import QtQuick
|
||||||
|
import qs.modules.widgets.settingsapp
|
||||||
|
import qs.settings
|
||||||
|
import qs.reusables
|
||||||
|
import qs
|
||||||
|
|
||||||
|
Rectangle {
|
||||||
|
id: root
|
||||||
|
radius: implicitHeight / 2
|
||||||
|
color: pavuArea.containsMouse ? Colors.primaryContainer : Colors.surfaceContainer
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
implicitWidth: volumeIcon.implicitWidth + 5
|
||||||
|
implicitHeight: Settings.config.barHeight - 10
|
||||||
|
CustomIcon {
|
||||||
|
id: volumeIcon
|
||||||
|
anchors.centerIn: parent
|
||||||
|
text: "settings"
|
||||||
|
}
|
||||||
|
MouseArea {
|
||||||
|
id: pavuArea
|
||||||
|
anchors.fill: root
|
||||||
|
onClicked: {
|
||||||
|
Settings.config.settingsShown = true;
|
||||||
|
}
|
||||||
|
acceptedButtons: Qt.LeftButton
|
||||||
|
cursorShape: Qt.PointingHandCursor
|
||||||
|
hoverEnabled: true
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -3,12 +3,11 @@ import Quickshell.Wayland
|
|||||||
import qs
|
import qs
|
||||||
import qs.settings
|
import qs.settings
|
||||||
import qs.reusables
|
import qs.reusables
|
||||||
import QtQuick.Dialogs
|
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: container
|
id: container
|
||||||
radius: implicitHeight / 2
|
radius: implicitHeight / 2
|
||||||
color: Colors.primaryContainer
|
color: Colors.surfaceContainer
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
implicitWidth: root.implicitWidth
|
implicitWidth: root.implicitWidth
|
||||||
implicitHeight: Settings.config.barHeight - 10
|
implicitHeight: Settings.config.barHeight - 10
|
||||||
@ -24,29 +23,5 @@ Rectangle {
|
|||||||
text: root.activeWindow ? root.activeWindow.activated ? root.activeWindow.appId : "Desktop" : "Desktop"
|
text: root.activeWindow ? root.activeWindow.activated ? root.activeWindow.appId : "Desktop" : "Desktop"
|
||||||
elide: Text.ElideRight
|
elide: Text.ElideRight
|
||||||
}
|
}
|
||||||
MouseArea {
|
|
||||||
id: fontOpener
|
|
||||||
FontDialog {
|
|
||||||
id: fontPicker
|
|
||||||
title: "qs-fontpicker"
|
|
||||||
flags: FontDialog.NoButtons | FontDialog.MonospacedFonts
|
|
||||||
|
|
||||||
onAccepted: {
|
|
||||||
Settings.config.font = selectedFont.family;
|
|
||||||
Settings.config.fontSize = selectedFont.pointSize;
|
|
||||||
}
|
|
||||||
onSelectedFontChanged: {
|
|
||||||
Settings.config.font = selectedFont.family;
|
|
||||||
Settings.config.fontSize = selectedFont.pointSize;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
anchors.fill: parent
|
|
||||||
acceptedButtons: Qt.LeftButton
|
|
||||||
cursorShape: Qt.PointingHandCursor
|
|
||||||
onClicked: {
|
|
||||||
fontPicker.open();
|
|
||||||
console.log(fontPicker.selectedFont.family);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -9,7 +9,7 @@ import qs
|
|||||||
Rectangle {
|
Rectangle {
|
||||||
id: container
|
id: container
|
||||||
radius: implicitHeight / 2
|
radius: implicitHeight / 2
|
||||||
color: pavuArea.containsMouse ? Colors.secondaryContainer : Colors.primaryContainer
|
color: pavuArea.containsMouse ? Colors.primaryContainer : Colors.surfaceContainer
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
implicitWidth: root.implicitWidth + 20
|
implicitWidth: root.implicitWidth + 20
|
||||||
implicitHeight: Settings.config.barHeight - 10
|
implicitHeight: Settings.config.barHeight - 10
|
||||||
|
|||||||
@ -5,10 +5,13 @@ import qs
|
|||||||
import qs.settings
|
import qs.settings
|
||||||
import qs.reusables
|
import qs.reusables
|
||||||
|
|
||||||
Item {
|
Rectangle {
|
||||||
id: root
|
id: root
|
||||||
implicitWidth: workspaceRow.implicitWidth
|
color: Colors.surfaceContainer
|
||||||
implicitHeight: workspaceRow.implicitHeight
|
|
||||||
|
implicitWidth: workspaceRow.implicitWidth + 10
|
||||||
|
implicitHeight: Settings.config.barHeight - 10
|
||||||
|
radius: Settings.config.barHeight / 2
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
property var screen: screen
|
property var screen: screen
|
||||||
Row {
|
Row {
|
||||||
@ -43,7 +46,8 @@ Item {
|
|||||||
CustomText {
|
CustomText {
|
||||||
anchors.centerIn: workspaceNumber
|
anchors.centerIn: workspaceNumber
|
||||||
text: parent.modelData.id
|
text: parent.modelData.id
|
||||||
color: workspaceNumber.modelData.focused ? Colors.onSecondaryContainerColor : Colors.surfaceVariant
|
color: Colors.onSurfaceColor
|
||||||
|
opacity: workspaceNumber.modelData.focused ? 1 : 0.5
|
||||||
}
|
}
|
||||||
MouseArea {
|
MouseArea {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
|
|||||||
@ -17,7 +17,7 @@ Variants {
|
|||||||
bottom: true
|
bottom: true
|
||||||
}
|
}
|
||||||
margins {
|
margins {
|
||||||
top: Settings.config.barHeight + Settings.config.margins + 10
|
top: Settings.config.floating ? Settings.config.barHeight + Settings.config.margins + 10 : Settings.config.barHeight + 10
|
||||||
right: 10
|
right: 10
|
||||||
left: 10
|
left: 10
|
||||||
}
|
}
|
||||||
|
|||||||
224
modules/overlays/ScreenCorners.qml
Normal file
224
modules/overlays/ScreenCorners.qml
Normal file
@ -0,0 +1,224 @@
|
|||||||
|
import QtQuick
|
||||||
|
import QtQuick.Shapes
|
||||||
|
import qs
|
||||||
|
import qs.settings
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ScreenCorners - Shape component for rendering screen corners
|
||||||
|
*
|
||||||
|
* Renders concave corners at the screen edges to create a rounded screen effect.
|
||||||
|
* Self-contained Shape component (no shadows).
|
||||||
|
*/
|
||||||
|
Item {
|
||||||
|
id: root
|
||||||
|
|
||||||
|
anchors.fill: parent
|
||||||
|
|
||||||
|
// Wrapper with layer caching to reduce GPU tessellation overhead
|
||||||
|
Item {
|
||||||
|
anchors.fill: parent
|
||||||
|
|
||||||
|
// Cache the Shape to a texture to prevent continuous re-tessellation
|
||||||
|
layer.enabled: true
|
||||||
|
|
||||||
|
Shape {
|
||||||
|
id: cornersShape
|
||||||
|
|
||||||
|
anchors.fill: parent
|
||||||
|
preferredRendererType: Shape.CurveRenderer
|
||||||
|
enabled: false // Disable mouse input
|
||||||
|
|
||||||
|
ShapePath {
|
||||||
|
id: cornersPath
|
||||||
|
|
||||||
|
// Corner configuration
|
||||||
|
readonly property color cornerColor: Qt.rgba(Colors.surface.r, Colors.surface.g, Colors.surface.b, Settings.config.translucency)
|
||||||
|
readonly property real cornerRadius: Settings.config.screenCornerRadius
|
||||||
|
readonly property real cornerSize: Settings.config.screenCornerRadius
|
||||||
|
|
||||||
|
// Determine margins based on bar position
|
||||||
|
readonly property real topMargin: Settings.config.floating ? 0 : Settings.config.barHeight
|
||||||
|
readonly property real bottomMargin: 0
|
||||||
|
readonly property real leftMargin: 0
|
||||||
|
readonly property real rightMargin: 0
|
||||||
|
|
||||||
|
// Screen dimensions
|
||||||
|
readonly property real screenWidth: cornersShape.width
|
||||||
|
readonly property real screenHeight: cornersShape.height
|
||||||
|
|
||||||
|
// Only show screen corners if enabled and appropriate conditions are met
|
||||||
|
readonly property bool shouldShow: Settings.config.showScreenCorners
|
||||||
|
|
||||||
|
// ShapePath configuration
|
||||||
|
strokeWidth: -1 // No stroke, fill only
|
||||||
|
fillColor: shouldShow ? cornerColor : "transparent"
|
||||||
|
|
||||||
|
// Smooth color animation (disabled during theme transitions to sync with Color.qml)
|
||||||
|
|
||||||
|
// ========== PATH DEFINITION ==========
|
||||||
|
// Draws 4 separate corner squares at screen edges
|
||||||
|
// Each corner square has a concave arc on the inner diagonal
|
||||||
|
|
||||||
|
// ========== TOP-LEFT CORNER ==========
|
||||||
|
// Arc is at the bottom-right of this square (inner diagonal)
|
||||||
|
// Start at top-left screen corner
|
||||||
|
startX: leftMargin
|
||||||
|
startY: topMargin
|
||||||
|
|
||||||
|
// Top edge (moving right)
|
||||||
|
PathLine {
|
||||||
|
relativeX: cornersPath.cornerSize
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Right edge (moving down toward arc)
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: cornersPath.cornerSize - cornersPath.cornerRadius
|
||||||
|
}
|
||||||
|
|
||||||
|
// Concave arc (bottom-right corner of square, curving inward toward screen center)
|
||||||
|
PathArc {
|
||||||
|
relativeX: -cornersPath.cornerRadius
|
||||||
|
relativeY: cornersPath.cornerRadius
|
||||||
|
radiusX: cornersPath.cornerRadius
|
||||||
|
radiusY: cornersPath.cornerRadius
|
||||||
|
direction: PathArc.Counterclockwise
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bottom edge (moving left)
|
||||||
|
PathLine {
|
||||||
|
relativeX: -(cornersPath.cornerSize - cornersPath.cornerRadius)
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Left edge (moving up) - closes back to start
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: -cornersPath.cornerSize
|
||||||
|
}
|
||||||
|
|
||||||
|
// ========== TOP-RIGHT CORNER ==========
|
||||||
|
// Arc is at the bottom-left of this square (inner diagonal)
|
||||||
|
PathMove {
|
||||||
|
x: cornersPath.screenWidth - cornersPath.rightMargin - cornersPath.cornerSize
|
||||||
|
y: cornersPath.topMargin
|
||||||
|
}
|
||||||
|
|
||||||
|
// Top edge (moving right)
|
||||||
|
PathLine {
|
||||||
|
relativeX: cornersPath.cornerSize
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Right edge (moving down)
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: cornersPath.cornerSize
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bottom edge (moving left toward arc)
|
||||||
|
PathLine {
|
||||||
|
relativeX: -(cornersPath.cornerSize - cornersPath.cornerRadius)
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Concave arc (bottom-left corner of square, curving inward toward screen center)
|
||||||
|
PathArc {
|
||||||
|
relativeX: -cornersPath.cornerRadius
|
||||||
|
relativeY: -cornersPath.cornerRadius
|
||||||
|
radiusX: cornersPath.cornerRadius
|
||||||
|
radiusY: cornersPath.cornerRadius
|
||||||
|
direction: PathArc.Counterclockwise
|
||||||
|
}
|
||||||
|
|
||||||
|
// Left edge (moving up) - closes back to start
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: -(cornersPath.cornerSize - cornersPath.cornerRadius)
|
||||||
|
}
|
||||||
|
|
||||||
|
// ========== BOTTOM-LEFT CORNER ==========
|
||||||
|
// Arc is at the top-right of this square (inner diagonal)
|
||||||
|
PathMove {
|
||||||
|
x: cornersPath.leftMargin
|
||||||
|
y: cornersPath.screenHeight - cornersPath.bottomMargin - cornersPath.cornerSize
|
||||||
|
}
|
||||||
|
|
||||||
|
// Top edge (moving right toward arc)
|
||||||
|
PathLine {
|
||||||
|
relativeX: cornersPath.cornerSize - cornersPath.cornerRadius
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Concave arc (top-right corner of square, curving inward toward screen center)
|
||||||
|
PathArc {
|
||||||
|
relativeX: cornersPath.cornerRadius
|
||||||
|
relativeY: cornersPath.cornerRadius
|
||||||
|
radiusX: cornersPath.cornerRadius
|
||||||
|
radiusY: cornersPath.cornerRadius
|
||||||
|
direction: PathArc.Counterclockwise
|
||||||
|
}
|
||||||
|
|
||||||
|
// Right edge (moving down)
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: cornersPath.cornerSize - cornersPath.cornerRadius
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bottom edge (moving left)
|
||||||
|
PathLine {
|
||||||
|
relativeX: -cornersPath.cornerSize
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Left edge (moving up) - closes back to start
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: -cornersPath.cornerSize
|
||||||
|
}
|
||||||
|
|
||||||
|
// ========== BOTTOM-RIGHT CORNER ==========
|
||||||
|
// Arc is at the top-left of this square (inner diagonal)
|
||||||
|
// Start at bottom-right of square (different from other corners!)
|
||||||
|
PathMove {
|
||||||
|
x: cornersPath.screenWidth - cornersPath.rightMargin
|
||||||
|
y: cornersPath.screenHeight - cornersPath.bottomMargin
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bottom edge (moving left)
|
||||||
|
PathLine {
|
||||||
|
relativeX: -cornersPath.cornerSize
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Left edge (moving up toward arc)
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: -(cornersPath.cornerSize - cornersPath.cornerRadius)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Concave arc (top-left corner of square, curving inward toward screen center)
|
||||||
|
PathArc {
|
||||||
|
relativeX: cornersPath.cornerRadius
|
||||||
|
relativeY: -cornersPath.cornerRadius
|
||||||
|
radiusX: cornersPath.cornerRadius
|
||||||
|
radiusY: cornersPath.cornerRadius
|
||||||
|
direction: PathArc.Counterclockwise
|
||||||
|
}
|
||||||
|
|
||||||
|
// Top edge (moving right)
|
||||||
|
PathLine {
|
||||||
|
relativeX: cornersPath.cornerSize - cornersPath.cornerRadius
|
||||||
|
relativeY: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Right edge (moving down) - closes back to start
|
||||||
|
PathLine {
|
||||||
|
relativeX: 0
|
||||||
|
relativeY: cornersPath.cornerSize
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -27,5 +27,6 @@ Variants {
|
|||||||
fillMode: Image.Stretch
|
fillMode: Image.Stretch
|
||||||
source: Settings.config.currentWall
|
source: Settings.config.currentWall
|
||||||
}
|
}
|
||||||
|
ScreenCorners {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,14 +0,0 @@
|
|||||||
|
|
||||||
|
|
||||||
import QtQuick
|
|
||||||
import qs
|
|
||||||
import qs.reusables
|
|
||||||
|
|
||||||
Item {
|
|
||||||
id: root
|
|
||||||
implicitWidth: 300
|
|
||||||
implicitHeight: 300
|
|
||||||
CustomText {
|
|
||||||
text: "I am the Appearance page"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
80
modules/widgets/settingsapp/Appearance.qml
Normal file
80
modules/widgets/settingsapp/Appearance.qml
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
import QtQuick
|
||||||
|
import qs
|
||||||
|
import qs.reusables
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import qs.settings
|
||||||
|
import Quickshell.Widgets
|
||||||
|
import QtQuick.Controls
|
||||||
|
import QtQuick.Dialogs
|
||||||
|
|
||||||
|
ClippingWrapperRectangle {
|
||||||
|
id: root
|
||||||
|
FontDialog {
|
||||||
|
id: fontPicker
|
||||||
|
title: "qs-fontpicker"
|
||||||
|
flags: FontDialog.NoButtons | FontDialog.MonospacedFonts
|
||||||
|
|
||||||
|
onAccepted: {
|
||||||
|
Settings.config.font = selectedFont.family;
|
||||||
|
Settings.config.fontSize = selectedFont.pointSize;
|
||||||
|
}
|
||||||
|
onSelectedFontChanged: {
|
||||||
|
Settings.config.font = selectedFont.family;
|
||||||
|
Settings.config.fontSize = selectedFont.pointSize;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
anchors.centerIn: parent
|
||||||
|
clip: true
|
||||||
|
color: Colors.surfaceContainerLow
|
||||||
|
radius: 12
|
||||||
|
margin: 20
|
||||||
|
|
||||||
|
ColumnLayout {
|
||||||
|
id: verticalLayout
|
||||||
|
Rectangle {
|
||||||
|
id: fontWrapper
|
||||||
|
radius: 14
|
||||||
|
color: Colors.surfaceContainerHigh
|
||||||
|
implicitHeight: fontLayout.implicitHeight + 10
|
||||||
|
implicitWidth: fontLayout.implicitWidth + 10
|
||||||
|
RowLayout {
|
||||||
|
id: fontLayout
|
||||||
|
anchors.right: parent.right
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
clip: true
|
||||||
|
spacing: 10
|
||||||
|
CustomText {
|
||||||
|
id: fontText
|
||||||
|
font.bold: true
|
||||||
|
text: "current font: " + Settings.config.font
|
||||||
|
}
|
||||||
|
Rectangle {
|
||||||
|
id: fontSelector
|
||||||
|
Layout.rightMargin: 5
|
||||||
|
implicitWidth: fontSelectorText.implicitWidth + 20
|
||||||
|
implicitHeight: 20
|
||||||
|
color: Colors.surfaceContainerHigh
|
||||||
|
border.width: 2
|
||||||
|
border.color: Colors.outline
|
||||||
|
radius: 12
|
||||||
|
CustomText {
|
||||||
|
id: fontSelectorText
|
||||||
|
anchors.centerIn: parent
|
||||||
|
text: "Pick Font"
|
||||||
|
}
|
||||||
|
MouseArea {
|
||||||
|
id: fontPickerOpener
|
||||||
|
anchors.fill: parent
|
||||||
|
acceptedButtons: Qt.LeftButton
|
||||||
|
cursorShape: Qt.PointingHandCursor
|
||||||
|
onClicked: fontPicker.open()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Item {
|
||||||
|
id: spring
|
||||||
|
Layout.fillHeight: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -10,6 +10,10 @@ import qs.reusables
|
|||||||
|
|
||||||
FloatingWindow {
|
FloatingWindow {
|
||||||
id: root
|
id: root
|
||||||
|
visible: Settings.config.settingsShown
|
||||||
|
onClosed: {
|
||||||
|
Settings.config.settingsShown = false;
|
||||||
|
}
|
||||||
color: Colors.surface
|
color: Colors.surface
|
||||||
title: "qs-settings"
|
title: "qs-settings"
|
||||||
implicitWidth: 800
|
implicitWidth: 800
|
||||||
@ -35,13 +39,16 @@ FloatingWindow {
|
|||||||
}
|
}
|
||||||
RowLayout {
|
RowLayout {
|
||||||
id: windowLayout
|
id: windowLayout
|
||||||
|
clip: true
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
|
spacing: 10
|
||||||
|
|
||||||
ClippingWrapperRectangle {
|
ClippingWrapperRectangle {
|
||||||
id: pageWrapper
|
id: pageWrapper
|
||||||
Layout.margins: 20
|
Layout.margins: 20
|
||||||
Layout.fillHeight: true
|
Layout.fillHeight: true
|
||||||
Layout.preferredWidth: 200
|
Layout.preferredWidth: 200
|
||||||
|
Layout.rightMargin: 0
|
||||||
margin: 20
|
margin: 20
|
||||||
color: Colors.surfaceContainerLow
|
color: Colors.surfaceContainerLow
|
||||||
radius: 12
|
radius: 12
|
||||||
@ -54,7 +61,7 @@ FloatingWindow {
|
|||||||
id: pageDelegate
|
id: pageDelegate
|
||||||
Rectangle {
|
Rectangle {
|
||||||
radius: 24
|
radius: 24
|
||||||
color: ListView.isCurrentItem ? Colors.surfaceContainerHighest : "transparent"
|
color: ListView.isCurrentItem ? Colors.surfaceContainerHigh : "transparent"
|
||||||
implicitHeight: 30
|
implicitHeight: 30
|
||||||
implicitWidth: pageWrapper.width - 50
|
implicitWidth: pageWrapper.width - 50
|
||||||
required property var modelData
|
required property var modelData
|
||||||
@ -82,6 +89,7 @@ FloatingWindow {
|
|||||||
}
|
}
|
||||||
Loader {
|
Loader {
|
||||||
id: contentLoader
|
id: contentLoader
|
||||||
|
Layout.leftMargin: 0
|
||||||
Layout.fillHeight: true
|
Layout.fillHeight: true
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.margins: 20
|
Layout.margins: 20
|
||||||
@ -8,7 +8,7 @@ ClippingWrapperRectangle {
|
|||||||
id: root
|
id: root
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
clip: true
|
clip: true
|
||||||
color: Colors.surfaceContainerHighest
|
color: Colors.surfaceContainerLow
|
||||||
radius: 12
|
radius: 12
|
||||||
margin: 20
|
margin: 20
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
@ -16,7 +16,7 @@ ClippingWrapperRectangle {
|
|||||||
spacing: 0
|
spacing: 0
|
||||||
anchors.top: parent.top
|
anchors.top: parent.top
|
||||||
CustomText {
|
CustomText {
|
||||||
|
topPadding: 10
|
||||||
text: "Welcome!"
|
text: "Welcome!"
|
||||||
font.pixelSize: 24
|
font.pixelSize: 24
|
||||||
font.bold: true
|
font.bold: true
|
||||||
@ -23,7 +23,7 @@ FloatingWindow {
|
|||||||
}
|
}
|
||||||
Process {
|
Process {
|
||||||
id: wallustRunner
|
id: wallustRunner
|
||||||
property string cmd: "matugen image " + Settings.config.currentWall + " -t scheme-neutral"
|
property string cmd: "matugen image " + Settings.config.currentWall
|
||||||
command: ["sh", "-c", cmd]
|
command: ["sh", "-c", cmd]
|
||||||
}
|
}
|
||||||
GlobalShortcut {
|
GlobalShortcut {
|
||||||
@ -46,9 +46,10 @@ FloatingWindow {
|
|||||||
Layout.bottomMargin: 0
|
Layout.bottomMargin: 0
|
||||||
radius: 14
|
radius: 14
|
||||||
implicitHeight: 30
|
implicitHeight: 30
|
||||||
color: Colors.onPrimaryColor
|
color: Colors.surfaceContainerLow
|
||||||
CustomText {
|
CustomText {
|
||||||
id: titleText
|
id: titleText
|
||||||
|
font.bold: true
|
||||||
anchors.centerIn: textWrapper
|
anchors.centerIn: textWrapper
|
||||||
text: "Wallpapers in " + Settings.config.wallDir
|
text: "Wallpapers in " + Settings.config.wallDir
|
||||||
}
|
}
|
||||||
@ -64,6 +65,7 @@ FloatingWindow {
|
|||||||
color: Colors.surfaceContainerLow
|
color: Colors.surfaceContainerLow
|
||||||
GridView {
|
GridView {
|
||||||
id: gridRoot
|
id: gridRoot
|
||||||
|
anchors.margins: 20
|
||||||
property var columns: Math.floor(gridRoot.width / cellWidth)
|
property var columns: Math.floor(gridRoot.width / cellWidth)
|
||||||
property var usedWidth: columns * cellWidth
|
property var usedWidth: columns * cellWidth
|
||||||
property var emptySpace: width - usedWidth
|
property var emptySpace: width - usedWidth
|
||||||
@ -78,7 +80,6 @@ FloatingWindow {
|
|||||||
anchors.fill: innerWindow
|
anchors.fill: innerWindow
|
||||||
anchors.centerIn: innerWindow
|
anchors.centerIn: innerWindow
|
||||||
leftMargin: emptySpace / 2
|
leftMargin: emptySpace / 2
|
||||||
topMargin: 20
|
|
||||||
model: folderModel
|
model: folderModel
|
||||||
delegate: fileDelegate
|
delegate: fileDelegate
|
||||||
FolderListModel {
|
FolderListModel {
|
||||||
@ -96,6 +97,7 @@ FloatingWindow {
|
|||||||
id: imageRounder
|
id: imageRounder
|
||||||
implicitHeight: 80
|
implicitHeight: 80
|
||||||
implicitWidth: 120
|
implicitWidth: 120
|
||||||
|
color: "transparent"
|
||||||
required property string filePath
|
required property string filePath
|
||||||
radius: 12
|
radius: 12
|
||||||
child: Image {
|
child: Image {
|
||||||
@ -112,7 +114,7 @@ FloatingWindow {
|
|||||||
onClicked: {
|
onClicked: {
|
||||||
Settings.config.currentWall = imageRounder.filePath;
|
Settings.config.currentWall = imageRounder.filePath;
|
||||||
if (Settings.config.generateScheme) {
|
if (Settings.config.generateScheme) {
|
||||||
wallustRunner.startDetached();
|
wallustRunner.running = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -7,34 +7,34 @@ import Quickshell.Io
|
|||||||
Singleton {
|
Singleton {
|
||||||
id: root
|
id: root
|
||||||
property alias config: settingsAdapter
|
property alias config: settingsAdapter
|
||||||
property alias currentWall: settingsAdapter.currentWall
|
onConfigChanged: settingsView.writeAdapter()
|
||||||
onConfigChanged: {
|
|
||||||
console.log('config change detected, writing adapter');
|
|
||||||
settingsView.writeAdapter();
|
|
||||||
}
|
|
||||||
|
|
||||||
FileView {
|
FileView {
|
||||||
id: settingsView
|
id: settingsView
|
||||||
|
|
||||||
|
path: "/home/lucy/.config/qs.json"
|
||||||
|
watchChanges: true
|
||||||
onAdapterUpdated: writeAdapter()
|
onAdapterUpdated: writeAdapter()
|
||||||
path: "/home/lucy/.config/quickshell/settings/config.json"
|
onFileChanged: reload()
|
||||||
watchChanges: false
|
|
||||||
|
|
||||||
adapter: JsonAdapter {
|
adapter: JsonAdapter {
|
||||||
id: settingsAdapter
|
id: settingsAdapter
|
||||||
property var margins: 10
|
property var margins: 20
|
||||||
property var currentWall: ""
|
property var currentWall: ""
|
||||||
property var barHeight: 28
|
property var barHeight: 30
|
||||||
property var font: ""
|
property var font: ""
|
||||||
property var fontSize: 14
|
property var fontSize: 14
|
||||||
property var rounding: 10
|
property var rounding: 10
|
||||||
property var wallDir: "file:///home/lucy/.walls/"
|
property var wallDir: "file:///home/lucy/.walls/"
|
||||||
property bool floating: true
|
property bool floating: false
|
||||||
property int paddingTop: 10
|
property int paddingTop: 10
|
||||||
property int paddingSides: 10
|
property int paddingSides: 10
|
||||||
property var generateScheme: true
|
property var generateScheme: true
|
||||||
property bool wallSwitcherShown: false
|
property bool wallSwitcherShown: false
|
||||||
property int fontWeight: 500
|
property int fontWeight: 600
|
||||||
|
property bool showScreenCorners: true
|
||||||
|
property int screenCornerRadius: 10
|
||||||
|
property double translucency: 1
|
||||||
|
property bool blackScreenCorners: true
|
||||||
|
property bool settingsShown: true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -6,13 +6,14 @@ import qs.modules.bar
|
|||||||
import qs.modules.overlays
|
import qs.modules.overlays
|
||||||
import qs.modules.notifications
|
import qs.modules.notifications
|
||||||
import qs.modules.widgets.wallswitcher
|
import qs.modules.widgets.wallswitcher
|
||||||
import qs.modules.widgets.SettingsApp
|
import qs.modules.widgets.settingsapp
|
||||||
|
|
||||||
ShellRoot {
|
ShellRoot {
|
||||||
id: root
|
id: root
|
||||||
Ipc {}
|
Wallpaper {}
|
||||||
Bar {}
|
Bar {}
|
||||||
Notification {}
|
Notification {}
|
||||||
Wallpaper {}
|
|
||||||
WallSwitcher {}
|
WallSwitcher {}
|
||||||
|
Ipc {}
|
||||||
|
MainWindow {}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user