
- added auto-selection of the first available protocol when changing the server on the PageShare page
146 lines
3.5 KiB
QML
146 lines
3.5 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
import Qt5Compat.GraphicalEffects
|
|
|
|
import "TextTypes"
|
|
|
|
RadioButton {
|
|
id: root
|
|
|
|
property int textMaximumLineCount: 2
|
|
property int textElide: Qt.ElideRight
|
|
property string descriptionText
|
|
|
|
property string hoveredColor: Qt.rgba(1, 1, 1, 0.05)
|
|
property string defaultColor: Qt.rgba(1, 1, 1, 0)
|
|
property string disabledColor: Qt.rgba(1, 1, 1, 0)
|
|
property string selectedColor: Qt.rgba(1, 1, 1, 0)
|
|
|
|
property string textColor: "#D7D8DB"
|
|
property string selectedTextColor: "#FBB26A"
|
|
|
|
property string imageSource
|
|
property bool showImage
|
|
|
|
hoverEnabled: true
|
|
|
|
indicator: Rectangle {
|
|
id: background
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
implicitWidth: 56
|
|
implicitHeight: 56
|
|
radius: 16
|
|
|
|
color: {
|
|
if (root.enabled) {
|
|
if (root.hovered) {
|
|
return hoveredColor
|
|
} else if (root.checked) {
|
|
return selectedColor
|
|
}
|
|
return defaultColor
|
|
} else {
|
|
return disabledColor
|
|
}
|
|
}
|
|
|
|
Behavior on color {
|
|
PropertyAnimation { duration: 200 }
|
|
}
|
|
|
|
Image {
|
|
source: {
|
|
if (showImage) {
|
|
return imageSource
|
|
} else if (root.pressed) {
|
|
return "qrc:/images/controls/radio-button-inner-circle-pressed.png"
|
|
} else if (root.checked) {
|
|
return "qrc:/images/controls/radio-button-inner-circle.png"
|
|
}
|
|
|
|
return ""
|
|
}
|
|
|
|
anchors.centerIn: parent
|
|
|
|
width: 24
|
|
height: 24
|
|
}
|
|
|
|
Image {
|
|
source: {
|
|
if (showImage) {
|
|
return ""
|
|
} else if (root.pressed || root.checked) {
|
|
return "qrc:/images/controls/radio-button-pressed.svg"
|
|
} else {
|
|
return "qrc:/images/controls/radio-button.svg"
|
|
}
|
|
}
|
|
|
|
anchors.centerIn: parent
|
|
|
|
width: 24
|
|
height: 24
|
|
}
|
|
}
|
|
|
|
contentItem: Item {
|
|
implicitWidth: content.implicitWidth
|
|
implicitHeight: content.implicitHeight
|
|
|
|
anchors.fill: parent
|
|
anchors.leftMargin: 8 + background.width
|
|
|
|
ColumnLayout {
|
|
id: content
|
|
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
spacing: 4
|
|
|
|
ListItemTitleType {
|
|
text: root.text
|
|
maximumLineCount: root.textMaximumLineCount
|
|
elide: root.textElide
|
|
|
|
color: {
|
|
if (root.checked) {
|
|
return selectedTextColor
|
|
}
|
|
return textColor
|
|
}
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Behavior on color {
|
|
PropertyAnimation { duration: 200 }
|
|
}
|
|
}
|
|
|
|
CaptionTextType {
|
|
id: description
|
|
|
|
color: "#878B91"
|
|
text: root.descriptionText
|
|
|
|
visible: root.descriptionText !== ""
|
|
|
|
Layout.fillWidth: true
|
|
}
|
|
}
|
|
}
|
|
|
|
MouseArea {
|
|
anchors.fill: root
|
|
cursorShape: Qt.PointingHandCursor
|
|
enabled: false
|
|
}
|
|
}
|
|
|
|
|