113 lines
3.1 KiB
QML
113 lines
3.1 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
|
|
import Style 1.0
|
|
|
|
import "TextTypes"
|
|
|
|
RadioButton {
|
|
id: root
|
|
|
|
property string hoveredColor: AmneziaStyle.color.barelyTranslucentWhite
|
|
property string defaultColor: AmneziaStyle.color.transparent
|
|
property string checkedColor: AmneziaStyle.color.transparent
|
|
property string disabledColor: AmneziaStyle.color.transparent
|
|
|
|
property string textColor: AmneziaStyle.color.paleGray
|
|
property string textDisabledColor: AmneziaStyle.color.mutedGray
|
|
|
|
property string pressedBorderColor: AmneziaStyle.color.charcoalGray
|
|
property string checkedBorderColor: AmneziaStyle.color.goldenApricot
|
|
property string defaultBodredColor: AmneziaStyle.color.transparent
|
|
property string checkedDisabledBorderColor: AmneziaStyle.color.mutedBrown
|
|
property string borderFocusedColor: AmneziaStyle.color.paleGray
|
|
property int borderWidth: 0
|
|
|
|
implicitWidth: content.implicitWidth
|
|
implicitHeight: content.implicitHeight
|
|
|
|
indicator: Rectangle {
|
|
anchors.fill: parent
|
|
radius: 16
|
|
|
|
color: {
|
|
if (root.enabled) {
|
|
if (root.hovered) {
|
|
return root.hoveredColor
|
|
} else if (root.checked) {
|
|
return root.checkedColor
|
|
}
|
|
return root.defaultColor
|
|
} else {
|
|
return root.disabledColor
|
|
}
|
|
}
|
|
|
|
border.color: {
|
|
if (root.enabled) {
|
|
if (root.pressed) {
|
|
return root.pressedBorderColor
|
|
} else if (root.checked) {
|
|
return root.checkedBorderColor
|
|
} else if (root.activeFocus) {
|
|
return root.borderFocusedColor
|
|
}
|
|
return root.defaultBodredColor
|
|
} else {
|
|
if (root.checked) {
|
|
return root.checkedDisabledBorderColor
|
|
}
|
|
return root.defaultBodredColor
|
|
}
|
|
}
|
|
|
|
border.width: {
|
|
if(root.checked || root.activeFocus) {
|
|
return 1
|
|
}
|
|
return root.pressed ? 1 : 0
|
|
}
|
|
|
|
Behavior on color {
|
|
PropertyAnimation { duration: 200 }
|
|
}
|
|
Behavior on border.color {
|
|
PropertyAnimation { duration: 200 }
|
|
}
|
|
}
|
|
|
|
ColumnLayout {
|
|
id: content
|
|
anchors.fill: parent
|
|
spacing: 0
|
|
|
|
ButtonTextType {
|
|
text: root.text
|
|
color: root.enabled ? root.textColor : root.textDisabledColor
|
|
|
|
Layout.fillWidth: true
|
|
Layout.rightMargin: 24
|
|
Layout.leftMargin: 24
|
|
Layout.topMargin: 12
|
|
Layout.bottomMargin: 12
|
|
|
|
horizontalAlignment: Qt.AlignHCenter
|
|
verticalAlignment: Qt.AlignVCenter
|
|
}
|
|
}
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
cursorShape: Qt.PointingHandCursor
|
|
enabled: false
|
|
}
|
|
|
|
Keys.onEnterPressed: {
|
|
this.clicked()
|
|
}
|
|
|
|
Keys.onReturnPressed: {
|
|
this.clicked()
|
|
}
|
|
}
|