(as requested in ##226). Spacer: create variable width invisible rectangle BarWidgetSettingsDialog: add Spacer support BarWidgetRegistry: add Spacer
186 lines
4.7 KiB
QML
186 lines
4.7 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Effects
|
|
import QtQuick.Layouts
|
|
import qs.Commons
|
|
import qs.Widgets
|
|
import qs.Services
|
|
|
|
// Widget Settings Dialog Component
|
|
Popup {
|
|
id: settingsPopup
|
|
|
|
property int widgetIndex: -1
|
|
property var widgetData: null
|
|
property string widgetId: ""
|
|
|
|
// Center popup in parent
|
|
x: (parent.width - width) * 0.5
|
|
y: (parent.height - height) * 0.5
|
|
|
|
width: 420 * scaling
|
|
height: content.implicitHeight + padding * 2
|
|
padding: Style.marginXL * scaling
|
|
modal: true
|
|
|
|
background: Rectangle {
|
|
id: bgRect
|
|
color: Color.mSurface
|
|
radius: Style.radiusL * scaling
|
|
border.color: Color.mPrimary
|
|
border.width: Style.borderM * scaling
|
|
}
|
|
|
|
ColumnLayout {
|
|
id: content
|
|
width: parent.width
|
|
spacing: Style.marginM * scaling
|
|
|
|
// Title
|
|
RowLayout {
|
|
Layout.fillWidth: true
|
|
|
|
NText {
|
|
text: "Widget Settings: " + settingsPopup.widgetId
|
|
font.pointSize: Style.fontSizeL * scaling
|
|
font.weight: Style.fontWeightBold
|
|
color: Color.mPrimary
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
NIconButton {
|
|
icon: "close"
|
|
onClicked: settingsPopup.close()
|
|
}
|
|
}
|
|
|
|
// Separator
|
|
Rectangle {
|
|
Layout.fillWidth: true
|
|
Layout.preferredHeight: 1
|
|
color: Color.mOutline
|
|
}
|
|
|
|
// Settings based on widget type
|
|
Loader {
|
|
id: settingsLoader
|
|
Layout.fillWidth: true
|
|
sourceComponent: {
|
|
if (settingsPopup.widgetId === "CustomButton") {
|
|
return customButtonSettings
|
|
} else if (settingsPopup.widgetId === "Spacer") {
|
|
return spacerSettings
|
|
}
|
|
// Add more widget settings components here as needed
|
|
return null
|
|
}
|
|
}
|
|
|
|
// Action buttons
|
|
RowLayout {
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: Style.marginM * scaling
|
|
|
|
Item {
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
NButton {
|
|
text: "Cancel"
|
|
outlined: true
|
|
onClicked: settingsPopup.close()
|
|
}
|
|
|
|
NButton {
|
|
text: "Save"
|
|
onClicked: {
|
|
if (settingsLoader.item && settingsLoader.item.saveSettings) {
|
|
var newSettings = settingsLoader.item.saveSettings()
|
|
root.updateWidgetSettings(sectionId, settingsPopup.widgetIndex, newSettings)
|
|
settingsPopup.close()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// CustomButton settings component
|
|
Component {
|
|
id: customButtonSettings
|
|
|
|
ColumnLayout {
|
|
spacing: Style.marginM * scaling
|
|
|
|
function saveSettings() {
|
|
var settings = Object.assign({}, settingsPopup.widgetData)
|
|
settings.icon = iconInput.text
|
|
settings.leftClickExec = leftClickExecInput.text
|
|
settings.rightClickExec = rightClickExecInput.text
|
|
settings.middleClickExec = middleClickExecInput.text
|
|
return settings
|
|
}
|
|
|
|
// Icon setting
|
|
NTextInput {
|
|
id: iconInput
|
|
Layout.fillWidth: true
|
|
Layout.bottomMargin: Style.marginXL * scaling
|
|
label: "Icon Name"
|
|
description: "Use Material Icon names from the icon set."
|
|
text: settingsPopup.widgetData.icon || ""
|
|
placeholderText: "Enter icon name (e.g., favorite, home, settings)"
|
|
}
|
|
|
|
NTextInput {
|
|
id: leftClickExecInput
|
|
Layout.fillWidth: true
|
|
label: "Left Click Command"
|
|
description: "Command or application to run when left clicked."
|
|
text: settingsPopup.widgetData.leftClickExec || ""
|
|
placeholderText: "Enter command to execute (app or custom script)"
|
|
}
|
|
|
|
NTextInput {
|
|
id: rightClickExecInput
|
|
Layout.fillWidth: true
|
|
label: "Right Click Command"
|
|
description: "Command or application to run when right clicked."
|
|
text: settingsPopup.widgetData.rightClickExec || ""
|
|
placeholderText: "Enter command to execute (app or custom script)"
|
|
}
|
|
|
|
NTextInput {
|
|
id: middleClickExecInput
|
|
Layout.fillWidth: true
|
|
label: "Middle Click Command"
|
|
description: "Command or application to run when middle clicked."
|
|
text: settingsPopup.widgetData.middleClickExec || ""
|
|
placeholderText: "Enter command to execute (app or custom script)"
|
|
}
|
|
}
|
|
}
|
|
|
|
// Spacer settings component
|
|
Component {
|
|
id: spacerSettings
|
|
|
|
ColumnLayout {
|
|
spacing: Style.marginM * scaling
|
|
|
|
function saveSettings() {
|
|
var settings = Object.assign({}, settingsPopup.widgetData)
|
|
settings.width = parseInt(widthInput.text) || 20
|
|
return settings
|
|
}
|
|
|
|
NTextInput {
|
|
id: widthInput
|
|
Layout.fillWidth: true
|
|
label: "Width (pixels)"
|
|
description: "Width of the spacer in pixels."
|
|
text: settingsPopup.widgetData.width || "20"
|
|
placeholderText: "Enter width in pixels"
|
|
}
|
|
}
|
|
}
|
|
}
|