added CardType component
- added transition for BasicButtonType
This commit is contained in:
parent
8e61d77497
commit
167d57408d
4 changed files with 142 additions and 1 deletions
|
|
@ -173,5 +173,6 @@
|
||||||
<file>images/controls/arrow-right.svg</file>
|
<file>images/controls/arrow-right.svg</file>
|
||||||
<file>images/controls/chevron-right.svg</file>
|
<file>images/controls/chevron-right.svg</file>
|
||||||
<file>ui/qml/Controls2/ImageButtonType.qml</file>
|
<file>ui/qml/Controls2/ImageButtonType.qml</file>
|
||||||
|
<file>ui/qml/Controls2/CardType.qml</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|
|
||||||
|
|
@ -35,6 +35,10 @@ Button {
|
||||||
}
|
}
|
||||||
border.color: borderColor
|
border.color: borderColor
|
||||||
border.width: borderWidth
|
border.width: borderWidth
|
||||||
|
|
||||||
|
Behavior on color {
|
||||||
|
PropertyAnimation { duration: 200 }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MouseArea {
|
MouseArea {
|
||||||
|
|
|
||||||
118
client/ui/qml/Controls2/CardType.qml
Normal file
118
client/ui/qml/Controls2/CardType.qml
Normal file
|
|
@ -0,0 +1,118 @@
|
||||||
|
import QtQuick
|
||||||
|
import QtQuick.Controls
|
||||||
|
import QtQuick.Layouts
|
||||||
|
|
||||||
|
RadioButton {
|
||||||
|
id: root
|
||||||
|
|
||||||
|
property string headerText
|
||||||
|
property string bodyText
|
||||||
|
property string footerText
|
||||||
|
|
||||||
|
property string hoveredColor: Qt.rgba(255, 255, 255, 0)
|
||||||
|
property string defaultColor: Qt.rgba(255, 255, 255, 0.05)
|
||||||
|
property string disabledColor: Qt.rgba(255, 255, 255, 0)
|
||||||
|
property string pressedColor: Qt.rgba(255, 255, 255, 0.05)
|
||||||
|
|
||||||
|
property string textColor: "#0E0E11"
|
||||||
|
|
||||||
|
property string pressedBorderColor: Qt.rgba(251, 178, 106, 0.3)
|
||||||
|
property string hoveredBorderColor: Qt.rgba(251, 178, 106, 1)
|
||||||
|
property int borderWidth: 0
|
||||||
|
|
||||||
|
implicitWidth: content.implicitWidth
|
||||||
|
implicitHeight: content.implicitHeight
|
||||||
|
|
||||||
|
hoverEnabled: true
|
||||||
|
|
||||||
|
indicator: Rectangle {
|
||||||
|
anchors.fill: parent
|
||||||
|
radius: 16
|
||||||
|
|
||||||
|
color: {
|
||||||
|
if (root.enabled) {
|
||||||
|
if(root.checked) {
|
||||||
|
return pressedColor
|
||||||
|
}
|
||||||
|
return hovered ? hoveredColor : defaultColor
|
||||||
|
} else {
|
||||||
|
return disabledColor
|
||||||
|
}
|
||||||
|
}
|
||||||
|
border.color: {
|
||||||
|
if (root.enabled) {
|
||||||
|
if(root.checked) {
|
||||||
|
return pressedBorderColor
|
||||||
|
}
|
||||||
|
return hovered ? hoveredBorderColor : defaultColor
|
||||||
|
} else {
|
||||||
|
return disabledColor
|
||||||
|
}
|
||||||
|
}
|
||||||
|
border.width: {
|
||||||
|
if (root.enabled) {
|
||||||
|
if(root.checked) {
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
return hovered ? 1 : 0
|
||||||
|
} else {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Behavior on color {
|
||||||
|
PropertyAnimation { duration: 200 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ColumnLayout {
|
||||||
|
id: content
|
||||||
|
anchors.fill: parent
|
||||||
|
spacing: 16
|
||||||
|
|
||||||
|
Text {
|
||||||
|
text: root.headerText
|
||||||
|
color: "#878b91"
|
||||||
|
font.pixelSize: 25
|
||||||
|
font.weight: 700
|
||||||
|
font.family: "PT Root UI VF"
|
||||||
|
|
||||||
|
height: 30
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: 16
|
||||||
|
Layout.leftMargin: 16
|
||||||
|
Layout.topMargin: 16
|
||||||
|
}
|
||||||
|
|
||||||
|
Text {
|
||||||
|
text: root.bodyText
|
||||||
|
wrapMode: Text.WordWrap
|
||||||
|
color: "#878b91"
|
||||||
|
font.pixelSize: 16
|
||||||
|
font.weight: 400
|
||||||
|
font.family: "PT Root UI VF"
|
||||||
|
|
||||||
|
height: 24
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: 16
|
||||||
|
Layout.leftMargin: 16
|
||||||
|
Layout.bottomMargin: root.footerText !== "" ? 0 : 16
|
||||||
|
}
|
||||||
|
|
||||||
|
Text {
|
||||||
|
text: root.footerText
|
||||||
|
visible: root.footerText !== ""
|
||||||
|
enabled: root.footerText !== ""
|
||||||
|
color: "#878b91"
|
||||||
|
font.pixelSize: 13
|
||||||
|
font.weight: 400
|
||||||
|
font.family: "PT Root UI VF"
|
||||||
|
|
||||||
|
height: 16
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: 16
|
||||||
|
Layout.leftMargin: 16
|
||||||
|
Layout.bottomMargin: 16
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -46,7 +46,7 @@ PageBase {
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.topMargin: 10
|
Layout.topMargin: 10
|
||||||
|
|
||||||
defaultColor: "#0E0E11"
|
defaultColor: "transparent"
|
||||||
hoveredColor: Qt.rgba(255, 255, 255, 0.08)
|
hoveredColor: Qt.rgba(255, 255, 255, 0.08)
|
||||||
pressedColor: Qt.rgba(255, 255, 255, 0.12)
|
pressedColor: Qt.rgba(255, 255, 255, 0.12)
|
||||||
disabledColor: "#878B91"
|
disabledColor: "#878B91"
|
||||||
|
|
@ -99,6 +99,24 @@ PageBase {
|
||||||
height: 1
|
height: 1
|
||||||
color: "#2C2D30"
|
color: "#2C2D30"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CardType {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.topMargin: 10
|
||||||
|
|
||||||
|
headerText: "Высокий"
|
||||||
|
bodyText: "Многие иностранные сайты и VPN-провайдеры заблокированы"
|
||||||
|
footerText: "футер"
|
||||||
|
}
|
||||||
|
|
||||||
|
CardType {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.topMargin: 10
|
||||||
|
|
||||||
|
headerText: "Высокий"
|
||||||
|
bodyText: "Многие иностранные сайты и VPN-провайдеры заблокированы"
|
||||||
|
footerText: "футер"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue