82 lines
1.8 KiB
QML
82 lines
1.8 KiB
QML
import QtQuick
|
|
import QtQuick.Layouts
|
|
import qs.Components
|
|
import qs.Config
|
|
import qs.Helpers
|
|
|
|
Item {
|
|
id: root
|
|
|
|
readonly property bool highlighted: SettingsHighlight.highlightedSetting === name
|
|
required property string name
|
|
required property var object
|
|
required property string setting
|
|
|
|
function formattedValue(): string {
|
|
const value = root.object[root.setting];
|
|
|
|
if (value === null || value === undefined)
|
|
return "";
|
|
|
|
return String(value);
|
|
}
|
|
|
|
Layout.fillWidth: true
|
|
Layout.preferredHeight: row.implicitHeight + Appearance.padding.smaller * 2
|
|
|
|
Rectangle {
|
|
anchors.fill: parent
|
|
anchors.margins: -Appearance.padding.smaller
|
|
color: DynamicColors.palette.m3primaryContainer
|
|
opacity: root.highlighted ? 0.5 : 0
|
|
radius: Appearance.rounding.small
|
|
|
|
Behavior on opacity {
|
|
Anim {
|
|
duration: Appearance.anim.durations.normal
|
|
}
|
|
}
|
|
}
|
|
|
|
RowLayout {
|
|
id: row
|
|
|
|
anchors.left: parent.left
|
|
anchors.margins: Appearance.padding.small
|
|
anchors.right: parent.right
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
CustomText {
|
|
id: text
|
|
|
|
Layout.alignment: Qt.AlignLeft
|
|
Layout.fillWidth: true
|
|
font.pointSize: Appearance.font.size.larger
|
|
text: root.name
|
|
}
|
|
|
|
CustomRect {
|
|
id: rect
|
|
|
|
Layout.preferredHeight: 33
|
|
Layout.preferredWidth: Math.max(Math.min(textField.contentWidth + Appearance.padding.large * 2, 550), 50)
|
|
color: DynamicColors.tPalette.m3surfaceContainerHigh
|
|
radius: Appearance.rounding.full
|
|
|
|
CustomTextField {
|
|
id: textField
|
|
|
|
anchors.centerIn: parent
|
|
horizontalAlignment: Text.AlignHCenter
|
|
implicitWidth: Math.min(contentWidth + Appearance.padding.normal * 2, 550)
|
|
text: root.formattedValue()
|
|
|
|
onEditingFinished: {
|
|
root.object[root.setting] = textField.text;
|
|
Config.save();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|