2020-06-29 17:23:28 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
2021-02-18 14:07:23 -05:00
|
|
|
import QtGraphicalEffects 1.13
|
2021-09-28 18:04:06 +03:00
|
|
|
|
2021-10-14 22:30:51 +02:00
|
|
|
import StatusQ.Controls 0.1 as StatusQ
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-12-08 23:20:43 +02:00
|
|
|
import shared.stores 1.0
|
2021-10-14 22:30:51 +02:00
|
|
|
|
2021-10-14 15:39:12 +02:00
|
|
|
import "./"
|
2021-10-14 12:24:37 +02:00
|
|
|
import "../"
|
2020-06-29 17:23:28 +02:00
|
|
|
|
2021-10-14 12:24:37 +02:00
|
|
|
// TODO: Replace with StatusQ components
|
2020-06-29 17:23:28 +02:00
|
|
|
Rectangle {
|
|
|
|
id: copyToClipboardButton
|
|
|
|
height: 32
|
|
|
|
width: 32
|
|
|
|
radius: 8
|
2020-07-22 16:16:06 -04:00
|
|
|
color: Style.current.transparent
|
2020-06-29 17:23:28 +02:00
|
|
|
property var onClick: function() {}
|
2020-07-09 11:19:10 -04:00
|
|
|
property string textToCopy: ""
|
2021-03-25 15:37:55 -04:00
|
|
|
property bool tooltipUnder: false
|
2020-06-29 17:23:28 +02:00
|
|
|
|
2020-08-28 15:09:00 -04:00
|
|
|
Image {
|
2020-06-29 17:23:28 +02:00
|
|
|
width: 20
|
|
|
|
height: 20
|
2020-08-28 15:09:00 -04:00
|
|
|
sourceSize.width: width
|
|
|
|
sourceSize.height: height
|
2021-09-28 18:04:06 +03:00
|
|
|
source: Style.svg("copy-to-clipboard-icon")
|
2020-06-29 17:23:28 +02:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2021-02-18 14:07:23 -05:00
|
|
|
|
|
|
|
ColorOverlay {
|
|
|
|
anchors.fill: parent
|
|
|
|
antialiasing: true
|
|
|
|
source: parent
|
|
|
|
color: Style.current.primary
|
|
|
|
}
|
2020-06-29 17:23:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
anchors.fill: parent
|
|
|
|
hoverEnabled: true
|
|
|
|
onExited: {
|
2020-07-09 11:19:10 -04:00
|
|
|
parent.color = Style.current.transparent
|
2020-06-29 17:23:28 +02:00
|
|
|
}
|
|
|
|
onEntered:{
|
2021-01-19 16:34:07 +01:00
|
|
|
parent.color = Style.current.backgroundHover
|
2020-06-29 17:23:28 +02:00
|
|
|
}
|
2020-07-09 11:19:10 -04:00
|
|
|
onPressed: {
|
2021-01-19 16:34:07 +01:00
|
|
|
parent.color = Style.current.backgroundHover
|
2021-01-13 19:10:42 +04:00
|
|
|
if (!toolTip.visible) {
|
|
|
|
toolTip.visible = true
|
|
|
|
}
|
2020-07-09 11:19:10 -04:00
|
|
|
}
|
|
|
|
onReleased: {
|
2021-02-25 19:28:56 +04:00
|
|
|
parent.color = Style.current.backgroundHover
|
2020-07-09 11:19:10 -04:00
|
|
|
}
|
|
|
|
onClicked: {
|
|
|
|
if (textToCopy) {
|
2021-12-13 15:24:21 +01:00
|
|
|
// Not Refactored Yet
|
2021-12-08 23:20:43 +02:00
|
|
|
//RootStore.copyToClipboard(textToCopy)
|
2020-07-09 11:19:10 -04:00
|
|
|
}
|
|
|
|
onClick()
|
|
|
|
}
|
2020-06-29 17:23:28 +02:00
|
|
|
}
|
2021-01-12 18:56:17 +04:00
|
|
|
|
2021-10-14 22:30:51 +02:00
|
|
|
StatusQ.StatusToolTip {
|
2021-01-12 18:56:17 +04:00
|
|
|
id: toolTip
|
2021-02-18 11:36:05 -05:00
|
|
|
//% "Copied!"
|
|
|
|
text: qsTrId("copied-")
|
2021-10-14 22:30:51 +02:00
|
|
|
orientation: tooltipUnder ? StatusQ.StatusToolTip.Orientation.Bottom: StatusQ.StatusToolTip.Orientation.Top
|
2021-01-12 18:56:17 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
Timer {
|
|
|
|
id:hideTimer
|
2021-01-13 19:10:42 +04:00
|
|
|
interval: 2000
|
2021-01-12 18:56:17 +04:00
|
|
|
running: toolTip.visible
|
|
|
|
onTriggered: {
|
|
|
|
toolTip.visible = false;
|
|
|
|
}
|
|
|
|
}
|
2020-06-29 17:23:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|