mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-15 09:04:45 +00:00
106 lines
3.0 KiB
QML
106 lines
3.0 KiB
QML
import QtQuick 2.13
|
|
import QtQuick.Controls 2.13
|
|
|
|
import utils 1.0
|
|
import "../"
|
|
import "../panels"
|
|
import "../controls"
|
|
|
|
// TODO: replace with StatusQ components
|
|
Item {
|
|
id: root
|
|
height: control.height
|
|
width: control.width + copyToClipBoardBtn.width + Style.current.smallPadding
|
|
property bool hovered: false
|
|
property string address: ""
|
|
property bool expanded: false
|
|
property int addressWidth
|
|
property int originalButtonWidth
|
|
property var store
|
|
|
|
Button {
|
|
id: control
|
|
width: root.addressWidth
|
|
leftPadding: 8
|
|
rightPadding: 8
|
|
contentItem: StyledText {
|
|
id: addressText
|
|
text: root.address
|
|
font.pixelSize: 13
|
|
font.family: Style.current.monoFont.name
|
|
color: Style.current.secondaryText
|
|
elide: Text.ElideMiddle
|
|
horizontalAlignment: Text.AlignHCenter
|
|
}
|
|
|
|
background: Rectangle {
|
|
color: root.hovered ? Style.current.backgroundHover : "transparent"
|
|
radius: Style.current.radius
|
|
}
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
cursorShape: Qt.PointingHandCursor
|
|
onClicked: {
|
|
if (root.expanded) {
|
|
control.width = root.originalButtonWidth
|
|
this.width = control.width
|
|
} else {
|
|
root.originalButtonWidth = root.addressWidth
|
|
control.width = control.maxWidth > 0 ?
|
|
Math.min(addressText.implicitWidth, control.maxWidth) :
|
|
addressText.implicitWidth + control.leftPadding + control.rightPadding
|
|
}
|
|
this.width = control.width
|
|
root.expanded = !root.expanded
|
|
}
|
|
}
|
|
}
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
cursorShape: Qt.PointingHandCursor
|
|
hoverEnabled: true
|
|
propagateComposedEvents: true
|
|
onPressed: mouse.accepted = false
|
|
onEntered: {
|
|
if (!root.hovered) {
|
|
root.hovered = true
|
|
}
|
|
}
|
|
onExited: {
|
|
if (root.hovered) {
|
|
root.hovered = false
|
|
}
|
|
}
|
|
}
|
|
|
|
CopyToClipBoardButton {
|
|
id: copyToClipBoardBtn
|
|
visible: root.hovered
|
|
anchors.left: control.right
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
color: Style.current.transparent
|
|
textToCopy: root.address
|
|
onCopyClicked: root.store.copyToClipboard(textToCopy)
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
propagateComposedEvents: true
|
|
onPressed: mouse.accepted = false
|
|
cursorShape: Qt.PointingHandCursor
|
|
hoverEnabled: true
|
|
onEntered: {
|
|
if (!root.hovered) {
|
|
root.hovered = true
|
|
}
|
|
}
|
|
onExited: {
|
|
if (root.hovered) {
|
|
root.hovered = false
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|