2021-07-21 13:11:27 +00:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import "../../../../imports"
|
|
|
|
import "../../../../shared"
|
|
|
|
import "../../../../shared/status"
|
|
|
|
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
property var buttonGroup
|
2021-07-22 15:03:59 +00:00
|
|
|
//% "TODO"
|
|
|
|
property string btnText: qsTrId("todo")
|
2021-07-21 13:11:27 +00:00
|
|
|
property bool hovered: false
|
|
|
|
property bool checkedByDefault: false
|
|
|
|
|
|
|
|
signal checked()
|
|
|
|
signal toggled(bool checked)
|
|
|
|
|
|
|
|
function click(){
|
|
|
|
radioBtn.toggle()
|
|
|
|
}
|
|
|
|
|
|
|
|
id: root
|
|
|
|
border.color: hovered || radioBtn.checked ? Style.current.primary : Style.current.border
|
|
|
|
border.width: 1
|
|
|
|
color: Style.current.transparent
|
|
|
|
width: 130
|
|
|
|
height: 120
|
|
|
|
clip: true
|
|
|
|
radius: Style.current.radius
|
|
|
|
|
|
|
|
StatusRadioButton {
|
|
|
|
id: radioBtn
|
|
|
|
ButtonGroup.group: buttonGroup
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: 14
|
|
|
|
checked: root.checkedByDefault
|
|
|
|
onCheckedChanged: {
|
|
|
|
if (checked) {
|
|
|
|
root.checked()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: txt
|
|
|
|
text: btnText
|
|
|
|
font.pixelSize: 15
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.top: radioBtn.bottom
|
|
|
|
anchors.topMargin: 6
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
id: mouseArea
|
|
|
|
anchors.fill: parent
|
|
|
|
hoverEnabled: true
|
|
|
|
onEntered: root.hovered = true
|
|
|
|
onExited: root.hovered = false
|
|
|
|
onClicked: {
|
|
|
|
radioBtn.toggle()
|
|
|
|
root.toggled(radioBtn.checked)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|