2020-08-25 11:00:03 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQml 2.14
|
2020-10-19 16:26:16 -04:00
|
|
|
import QtGraphicalEffects 1.13
|
2020-08-25 11:00:03 +02:00
|
|
|
import "../../imports"
|
|
|
|
import "../../shared"
|
|
|
|
|
|
|
|
Button {
|
|
|
|
property string type: "primary"
|
|
|
|
property string size: "large"
|
2020-09-11 10:50:22 -04:00
|
|
|
property string state: "default"
|
2021-01-14 00:26:30 +04:00
|
|
|
property color color: type === "warn" ? Style.current.danger : Style.current.buttonForegroundColor
|
2021-01-25 19:51:37 +04:00
|
|
|
property color bgColor: type === "warn" ? Style.current.buttonWarnBackgroundColor : Style.current.buttonBackgroundColor
|
2021-01-11 15:59:05 -05:00
|
|
|
property color borderColor: color
|
2021-01-25 19:51:37 +04:00
|
|
|
property color bgHoverColor: bgColor !== Style.current.transparent ? Qt.darker(control.bgColor, 1.1) :
|
|
|
|
type === "warn" ? Style.current.buttonWarnBackgroundColor : Style.current.buttonBackgroundColor
|
2020-12-29 12:10:22 -05:00
|
|
|
property bool disableColorOverlay: false
|
2021-01-11 15:59:05 -05:00
|
|
|
property bool showBorder: false
|
2020-10-19 16:26:16 -04:00
|
|
|
property int iconRotation: 0
|
2020-08-25 11:00:03 +02:00
|
|
|
|
|
|
|
id: control
|
|
|
|
font.pixelSize: size === "small" ? 13 : 15
|
|
|
|
font.weight: Font.Medium
|
2020-12-04 11:31:08 +01:00
|
|
|
implicitHeight: flat ? 32 : (size === "small" ? 38 : 44)
|
|
|
|
implicitWidth: buttonLabel.implicitWidth + (flat ? 3* Style.current.halfPadding : 2 * Style.current.padding) +
|
2020-10-19 16:26:16 -04:00
|
|
|
(iconLoader.active ? iconLoader.width : 0)
|
2020-08-25 11:00:03 +02:00
|
|
|
enabled: state === "default"
|
|
|
|
|
|
|
|
contentItem: Item {
|
2020-12-04 11:31:08 +01:00
|
|
|
id: content
|
2020-08-25 11:00:03 +02:00
|
|
|
anchors.fill: parent
|
2020-12-04 11:31:08 +01:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2020-10-19 16:26:16 -04:00
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: iconLoader
|
2020-10-26 10:21:41 -04:00
|
|
|
active: !!control.icon && !!control.icon.source.toString()
|
2020-10-19 16:26:16 -04:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.halfPadding
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
|
|
|
sourceComponent: SVGImage {
|
|
|
|
id: iconImg
|
|
|
|
source: control.icon.source
|
|
|
|
height: control.icon.height
|
|
|
|
width: control.icon.width
|
|
|
|
fillMode: Image.PreserveAspectFit
|
|
|
|
rotation: control.iconRotation
|
|
|
|
|
|
|
|
ColorOverlay {
|
2020-12-29 12:10:22 -05:00
|
|
|
enabled: !control.disableColorOverlay
|
2020-10-19 16:26:16 -04:00
|
|
|
anchors.fill: iconImg
|
|
|
|
source: iconImg
|
2020-12-29 12:10:22 -05:00
|
|
|
color: control.disableColorOverlay ? "transparent" : buttonLabel.color
|
2020-10-19 16:26:16 -04:00
|
|
|
antialiasing: true
|
|
|
|
smooth: true
|
|
|
|
rotation: control.iconRotation
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-25 11:00:03 +02:00
|
|
|
Text {
|
|
|
|
id: buttonLabel
|
|
|
|
text: control.text
|
|
|
|
font: control.font
|
|
|
|
horizontalAlignment: Text.AlignHCenter
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
2020-10-21 14:47:42 -04:00
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.right: iconLoader.active ? undefined : parent.right
|
|
|
|
anchors.left: iconLoader.active ? iconLoader.right : parent.left
|
|
|
|
anchors.leftMargin: iconLoader.active ? Style.current.smallPadding : 0
|
2020-12-04 11:31:08 +01:00
|
|
|
color: !enabled ? Style.current.buttonDisabledForegroundColor :
|
2021-01-14 00:26:30 +04:00
|
|
|
(type !== "warn" && (hovered || highlighted)) ? Style.current.blue : control.color
|
2020-09-05 21:18:50 -04:00
|
|
|
visible: !loadingIndicator.active
|
2020-08-25 11:00:03 +02:00
|
|
|
}
|
|
|
|
|
2020-09-05 21:18:50 -04:00
|
|
|
|
|
|
|
Component {
|
|
|
|
id: loadingComponent
|
2020-09-11 10:50:22 -04:00
|
|
|
LoadingImage {}
|
2020-09-05 21:18:50 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
2020-08-25 11:00:03 +02:00
|
|
|
id: loadingIndicator
|
2020-09-05 21:18:50 -04:00
|
|
|
active: control.state === "pending"
|
|
|
|
sourceComponent: loadingComponent
|
2020-08-25 11:00:03 +02:00
|
|
|
height: loadingIndicator.visible ?
|
|
|
|
control.size === "large" ?
|
|
|
|
23 : 17
|
|
|
|
: 0
|
|
|
|
width: loadingIndicator.height
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
background: Rectangle {
|
|
|
|
radius: Style.current.radius
|
|
|
|
anchors.fill: parent
|
2021-01-11 15:59:05 -05:00
|
|
|
border.width: flat || showBorder ? 1 : 0
|
|
|
|
border.color: hovered || showBorder ? control.borderColor : Style.current.transparent
|
2020-08-25 11:00:03 +02:00
|
|
|
color: {
|
2020-12-04 11:31:08 +01:00
|
|
|
if (flat) {
|
|
|
|
return "transparent"
|
|
|
|
}
|
2020-08-25 11:00:03 +02:00
|
|
|
if (type === "secondary") {
|
2020-10-29 15:02:32 -04:00
|
|
|
return hovered ? control.bgColor : "transparent"
|
2020-08-25 11:00:03 +02:00
|
|
|
}
|
2021-01-25 19:51:37 +04:00
|
|
|
return !enabled ? (control.bgColor === Style.current.transparent ? control.bgColor : Style.current.buttonDisabledBackgroundColor) :
|
|
|
|
(hovered ? control.bgHoverColor : control.bgColor)
|
2020-08-25 11:00:03 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
anchors.fill: parent
|
|
|
|
onPressed: mouse.accepted = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|