linphone-desktop/tests/ui/modules/Common/Form/ActionButton.qml
2016-12-28 14:23:52 +01:00

72 lines
1.7 KiB
QML

import QtQuick 2.7
import QtQuick.Controls 2.0
import Common 1.0
// =============================================================================
// An animated (or not) button with image(s).
// =============================================================================
Item {
id: wrappedButton
// ---------------------------------------------------------------------------
property bool enabled: true
property bool useStates: true
property int iconSize // Optionnal.
readonly property alias hovered: button.hovered
// If `useStates` = true, the used icons are:
// `icon`_pressed, `icon`_hovered and `icon`_normal.
property string icon
// ---------------------------------------------------------------------------
signal clicked
// ---------------------------------------------------------------------------
function _getIcon () {
if (!useStates) {
return wrappedButton.icon
}
if (!wrappedButton.enabled) {
return wrappedButton.icon + '_disabled'
}
return wrappedButton.icon + (
button.down
? '_pressed'
: (button.hovered ? '_hovered' : '_normal')
)
}
// ---------------------------------------------------------------------------
height: iconSize || parent.iconSize || parent.height
width: iconSize || parent.iconSize || parent.height
Button {
id: button
anchors.fill: parent
background: Rectangle {
color: 'transparent'
}
hoverEnabled: true
onClicked: wrappedButton.enabled && wrappedButton.clicked()
Icon {
id: icon
anchors.centerIn: parent
icon: _getIcon()
iconSize: parent.iconSize || (
parent.width > parent.height ? parent.height : parent.width
)
}
}
}