2021-01-11 23:50:26 +01:00
|
|
|
import "./ui"
|
2021-01-12 15:03:39 +01:00
|
|
|
import QtQuick 2.3
|
2019-11-03 02:09:36 +01:00
|
|
|
import QtQuick.Controls 2.3
|
2021-02-14 01:28:28 +01:00
|
|
|
import im.nheko 1.0 // for cursor shape
|
2019-11-03 02:09:36 +01:00
|
|
|
|
2020-05-06 03:40:24 +02:00
|
|
|
AbstractButton {
|
2020-10-08 21:11:21 +02:00
|
|
|
id: button
|
|
|
|
|
2021-01-17 01:55:50 +01:00
|
|
|
property alias cursor: mouseArea.cursorShape
|
2020-10-08 21:11:21 +02:00
|
|
|
property string image: undefined
|
|
|
|
property color highlightColor: colors.highlight
|
|
|
|
property color buttonTextColor: colors.buttonText
|
2021-01-16 16:02:55 +01:00
|
|
|
property bool changeColorOnHover: true
|
2020-10-08 21:11:21 +02:00
|
|
|
|
2020-11-25 17:38:06 +01:00
|
|
|
focusPolicy: Qt.NoFocus
|
2020-10-08 21:11:21 +02:00
|
|
|
width: 16
|
|
|
|
height: 16
|
|
|
|
|
|
|
|
Image {
|
|
|
|
id: buttonImg
|
|
|
|
|
|
|
|
// Workaround, can't get icon.source working for now...
|
|
|
|
anchors.fill: parent
|
2021-01-16 17:52:58 +01:00
|
|
|
source: image != "" ? ("image://colorimage/" + image + "?" + ((button.hovered && changeColorOnHover) ? highlightColor : buttonTextColor)) : ""
|
2020-10-08 21:11:21 +02:00
|
|
|
}
|
|
|
|
|
2021-02-14 01:28:28 +01:00
|
|
|
CursorShape {
|
2020-10-08 21:11:21 +02:00
|
|
|
id: mouseArea
|
|
|
|
|
|
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
}
|
|
|
|
|
2021-01-11 23:50:26 +01:00
|
|
|
Ripple {
|
|
|
|
color: Qt.rgba(buttonTextColor.r, buttonTextColor.g, buttonTextColor.b, 0.5)
|
|
|
|
clip: false
|
|
|
|
rippleTarget: button
|
|
|
|
}
|
|
|
|
|
2019-11-03 02:09:36 +01:00
|
|
|
}
|