2021-03-05 00:35:15 +01:00
|
|
|
// SPDX-FileCopyrightText: 2021 Nheko Contributors
|
2021-03-07 05:57:56 +01:00
|
|
|
//
|
2021-03-05 00:35:15 +01:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2021-01-12 15:03:39 +01:00
|
|
|
import QtQuick 2.6
|
|
|
|
import QtQuick.Controls 2.2
|
2020-06-24 16:24:22 +02:00
|
|
|
import im.nheko 1.0
|
|
|
|
|
2020-05-22 03:21:35 +02:00
|
|
|
// This class is for showing Reactions in the timeline row, not for
|
|
|
|
// adding new reactions via the emoji picker
|
2020-05-04 00:59:05 +02:00
|
|
|
Flow {
|
2020-10-08 21:11:21 +02:00
|
|
|
id: reactionFlow
|
|
|
|
|
|
|
|
// highlight colors for selfReactedEvent background
|
2021-05-13 08:23:56 +02:00
|
|
|
property real highlightHue: Nheko.colors.highlight.hslHue
|
|
|
|
property real highlightSat: Nheko.colors.highlight.hslSaturation
|
|
|
|
property real highlightLight: Nheko.colors.highlight.hslLightness
|
2020-10-08 21:11:21 +02:00
|
|
|
property string eventId
|
|
|
|
property alias reactions: repeater.model
|
|
|
|
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
spacing: 4
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: repeater
|
|
|
|
|
|
|
|
delegate: AbstractButton {
|
|
|
|
id: reaction
|
|
|
|
|
|
|
|
hoverEnabled: true
|
|
|
|
implicitWidth: contentItem.childrenRect.width + contentItem.leftPadding * 2
|
|
|
|
implicitHeight: contentItem.childrenRect.height
|
|
|
|
ToolTip.visible: hovered
|
|
|
|
ToolTip.text: modelData.users
|
|
|
|
onClicked: {
|
|
|
|
console.debug("Picked " + modelData.key + "in response to " + reactionFlow.eventId + ". selfReactedEvent: " + modelData.selfReactedEvent);
|
|
|
|
TimelineManager.queueReactionMessage(reactionFlow.eventId, modelData.key);
|
|
|
|
}
|
|
|
|
|
|
|
|
contentItem: Row {
|
|
|
|
anchors.centerIn: parent
|
|
|
|
spacing: reactionText.implicitHeight / 4
|
|
|
|
leftPadding: reactionText.implicitHeight / 2
|
|
|
|
rightPadding: reactionText.implicitHeight / 2
|
|
|
|
|
|
|
|
TextMetrics {
|
|
|
|
id: textMetrics
|
|
|
|
|
|
|
|
font.family: Settings.emojiFont
|
|
|
|
elide: Text.ElideRight
|
|
|
|
elideWidth: 150
|
|
|
|
text: modelData.key
|
|
|
|
}
|
|
|
|
|
|
|
|
Text {
|
|
|
|
id: reactionText
|
|
|
|
|
|
|
|
anchors.baseline: reactionCounter.baseline
|
|
|
|
text: textMetrics.elidedText + (textMetrics.elidedText == modelData.key ? "" : "…")
|
|
|
|
font.family: Settings.emojiFont
|
2021-05-13 08:23:56 +02:00
|
|
|
color: reaction.hovered ? Nheko.colors.highlight : Nheko.colors.text
|
2020-10-08 21:11:21 +02:00
|
|
|
maximumLineCount: 1
|
|
|
|
}
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: divider
|
|
|
|
|
|
|
|
height: Math.floor(reactionCounter.implicitHeight * 1.4)
|
|
|
|
width: 1
|
2021-05-13 08:23:56 +02:00
|
|
|
color: (reaction.hovered || modelData.selfReactedEvent !== '') ? Nheko.colors.highlight : Nheko.colors.text
|
2020-10-08 21:11:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Text {
|
|
|
|
id: reactionCounter
|
|
|
|
|
|
|
|
anchors.verticalCenter: divider.verticalCenter
|
|
|
|
text: modelData.count
|
|
|
|
font: reaction.font
|
2021-05-13 08:23:56 +02:00
|
|
|
color: reaction.hovered ? Nheko.colors.highlight : Nheko.colors.text
|
2020-10-08 21:11:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
background: Rectangle {
|
|
|
|
anchors.centerIn: parent
|
|
|
|
implicitWidth: reaction.implicitWidth
|
|
|
|
implicitHeight: reaction.implicitHeight
|
2021-05-13 08:23:56 +02:00
|
|
|
border.color: (reaction.hovered || modelData.selfReactedEvent !== '') ? Nheko.colors.highlight : Nheko.colors.text
|
|
|
|
color: modelData.selfReactedEvent !== '' ? Qt.hsla(highlightHue, highlightSat, highlightLight, 0.2) : Nheko.colors.window
|
2020-10-08 21:11:21 +02:00
|
|
|
border.width: 1
|
|
|
|
radius: reaction.height / 2
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-05-04 00:59:05 +02:00
|
|
|
|
2020-10-08 21:11:21 +02:00
|
|
|
}
|