mirror of
https://github.com/nextcloud/desktop.git
synced 2024-12-21 05:13:04 +03:00
373a001774
Signed-off-by: Claudio Cambra <claudio.cambra@nextcloud.com>
211 lines
8.5 KiB
QML
211 lines
8.5 KiB
QML
import QtQml 2.15
|
|
import QtQuick 2.15
|
|
import QtQuick.Controls 2.3
|
|
import QtQuick.Layouts 1.2
|
|
import Style 1.0
|
|
import QtGraphicalEffects 1.15
|
|
import com.nextcloud.desktopclient 1.0
|
|
|
|
RowLayout {
|
|
id: root
|
|
|
|
property variant activityData: {{}}
|
|
|
|
property color activityTextTitleColor: Style.ncTextColor
|
|
|
|
property bool showDismissButton: false
|
|
|
|
property bool childHovered: fileDetailsButton.hovered || dismissActionButton.hovered
|
|
|
|
property int iconSize: Style.trayListItemIconSize
|
|
|
|
signal dismissButtonClicked()
|
|
|
|
spacing: Style.trayHorizontalMargin
|
|
|
|
Item {
|
|
id: thumbnailItem
|
|
Layout.alignment: Qt.AlignVCenter | Qt.AlignHCenter
|
|
Layout.preferredWidth: root.iconSize
|
|
Layout.preferredHeight: model.thumbnail && model.thumbnail.isMimeTypeIcon ? root.iconSize * 0.9 : root.iconSize
|
|
readonly property int imageWidth: width * (1 - Style.thumbnailImageSizeReduction)
|
|
readonly property int imageHeight: height * (1 - Style.thumbnailImageSizeReduction)
|
|
readonly property int thumbnailRadius: model.thumbnail && model.thumbnail.isUserAvatar ? width / 2 : 3
|
|
|
|
Loader {
|
|
id: thumbnailImageLoader
|
|
anchors.fill: parent
|
|
active: model.thumbnail !== undefined
|
|
|
|
sourceComponent: Item {
|
|
anchors.fill: parent
|
|
readonly property int paintedWidth: model.thumbnail.isMimeTypeIcon ? thumbnailImage.paintedWidth * 0.8 : thumbnailImage.paintedWidth
|
|
readonly property int paintedHeight: model.thumbnail.isMimeTypeIcon ? thumbnailImage.paintedHeight * 0.55 : thumbnailImage.paintedHeight
|
|
|
|
Image {
|
|
id: thumbnailImage
|
|
width: thumbnailItem.imageWidth
|
|
height: thumbnailItem.imageHeight
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.left: parent.left
|
|
cache: true
|
|
fillMode: Image.PreserveAspectFit
|
|
source: model.thumbnail.source
|
|
visible: false
|
|
sourceSize.height: 64
|
|
sourceSize.width: 64
|
|
}
|
|
|
|
Rectangle {
|
|
id: mask
|
|
color: "white"
|
|
radius: thumbnailItem.thumbnailRadius
|
|
anchors.fill: thumbnailImage
|
|
visible: false
|
|
width: thumbnailImage.paintedWidth
|
|
height: thumbnailImage.paintedHeight
|
|
}
|
|
|
|
OpacityMask {
|
|
anchors.fill: thumbnailImage
|
|
source: thumbnailImage
|
|
maskSource: mask
|
|
visible: model.thumbnail !== undefined
|
|
}
|
|
}
|
|
}
|
|
|
|
Image {
|
|
id: activityIcon
|
|
width: model.thumbnail !== undefined ? parent.width * 0.4 : thumbnailItem.imageWidth
|
|
height: model.thumbnail !== undefined ? width : width * 0.9
|
|
|
|
// Prevent bad access into unloaded item properties
|
|
readonly property int thumbnailPaintedWidth: thumbnailImageLoader.item ? thumbnailImageLoader.item.paintedWidth : 0
|
|
readonly property int thumbnailPaintedHeight: thumbnailImageLoader.item ? thumbnailImageLoader.item.paintedHeight : 0
|
|
|
|
readonly property int negativeLeftMargin: -((width / 2) +
|
|
((width - paintedWidth) / 2) +
|
|
((thumbnailImageLoader.width - thumbnailItem.imageWidth) / 2) +
|
|
((thumbnailImageLoader.width - thumbnailPaintedWidth) / 2) +
|
|
(thumbnailItem.thumbnailRadius / 4))
|
|
readonly property int negativeTopMargin: -((height / 2) +
|
|
((height - paintedHeight) / 2) +
|
|
((thumbnailImageLoader.height - thumbnailItem.imageHeight) / 4) +
|
|
((thumbnailImageLoader.height - thumbnailPaintedHeight) / 4) +
|
|
(thumbnailItem.thumbnailRadius / 4))
|
|
|
|
anchors.verticalCenter: if(model.thumbnail === undefined) parent.verticalCenter
|
|
anchors.left: model.thumbnail === undefined ? parent.left : thumbnailImageLoader.right
|
|
anchors.leftMargin: if(model.thumbnail !== undefined) negativeLeftMargin
|
|
anchors.top: if(model.thumbnail !== undefined) thumbnailImageLoader.bottom
|
|
anchors.topMargin: if(model.thumbnail !== undefined) negativeTopMargin
|
|
|
|
cache: true
|
|
fillMode: Image.PreserveAspectFit
|
|
source: Theme.darkMode ? model.darkIcon : model.lightIcon
|
|
sourceSize.height: 64
|
|
sourceSize.width: 64
|
|
mipmap: true // Addresses grainy downscale
|
|
}
|
|
}
|
|
|
|
Column {
|
|
id: activityTextColumn
|
|
|
|
Layout.topMargin: Style.activityContentSpace
|
|
Layout.fillWidth: true
|
|
Layout.alignment: Qt.AlignLeft | Qt.AlignVCenter
|
|
|
|
spacing: Style.activityContentSpace
|
|
|
|
EnforcedPlainTextLabel {
|
|
id: activityTextTitle
|
|
text: (root.activityData.type === "Activity" || root.activityData.type === "Notification") ? root.activityData.subject : root.activityData.message
|
|
height: (text === "") ? 0 : implicitHeight
|
|
width: parent.width
|
|
elide: Text.ElideRight
|
|
wrapMode: Text.Wrap
|
|
maximumLineCount: 2
|
|
font.pixelSize: Style.topLinePixelSize
|
|
color: Style.ncTextColor
|
|
visible: text !== ""
|
|
}
|
|
|
|
EnforcedPlainTextLabel {
|
|
id: activityTextInfo
|
|
text: (root.activityData.type === "Sync") ? root.activityData.displayPath
|
|
: (root.activityData.type === "File") ? root.activityData.subject
|
|
: (root.activityData.type === "Notification") ? root.activityData.message
|
|
: ""
|
|
height: (text === "") ? 0 : implicitHeight
|
|
width: parent.width
|
|
elide: Text.ElideRight
|
|
wrapMode: Text.Wrap
|
|
maximumLineCount: 2
|
|
font.pixelSize: Style.subLinePixelSize
|
|
color: Style.ncTextColor
|
|
visible: text !== ""
|
|
}
|
|
|
|
EnforcedPlainTextLabel {
|
|
id: activityTextDateTime
|
|
text: root.activityData.dateTime
|
|
height: (text === "") ? 0 : implicitHeight
|
|
width: parent.width
|
|
elide: Text.ElideRight
|
|
wrapMode: Text.Wrap
|
|
maximumLineCount: 2
|
|
font.pixelSize: Style.subLinePixelSize
|
|
color: Style.ncSecondaryTextColor
|
|
visible: text !== ""
|
|
}
|
|
|
|
EnforcedPlainTextLabel {
|
|
id: talkReplyMessageSent
|
|
text: root.activityData.messageSent
|
|
height: (text === "") ? 0 : implicitHeight
|
|
width: parent.width
|
|
elide: Text.ElideRight
|
|
wrapMode: Text.Wrap
|
|
maximumLineCount: 2
|
|
font.pixelSize: Style.topLinePixelSize
|
|
color: Style.ncSecondaryTextColor
|
|
visible: text !== ""
|
|
}
|
|
}
|
|
|
|
CustomButton {
|
|
id: dismissActionButton
|
|
|
|
Layout.preferredWidth: Style.trayListItemIconSize
|
|
Layout.preferredHeight: Style.trayListItemIconSize
|
|
|
|
visible: root.showDismissButton && !fileDetailsButton.visible
|
|
|
|
imageSource: "image://svgimage-custom-color/clear.svg" + "/" + Style.ncTextColor
|
|
imageSourceHover: "image://svgimage-custom-color/clear.svg" + "/" + UserModel.currentUser.headerTextColor
|
|
|
|
toolTipText: qsTr("Dismiss")
|
|
|
|
bgColor: Style.menuBorder
|
|
|
|
onClicked: root.dismissButtonClicked()
|
|
}
|
|
|
|
CustomButton {
|
|
id: fileDetailsButton
|
|
|
|
Layout.preferredWidth: Style.trayListItemIconSize
|
|
Layout.preferredHeight: Style.trayListItemIconSize
|
|
|
|
imageSource: "image://svgimage-custom-color/more.svg" + "/" + Style.adjustedCurrentUserHeaderColor
|
|
imageSourceHover: "image://svgimage-custom-color/more.svg" + "/" + Style.currentUserHeaderTextColor
|
|
toolTipText: qsTr("Open file details")
|
|
bgColor: Style.currentUserHeaderColor
|
|
|
|
visible: model.showFileDetails
|
|
|
|
onClicked: Systray.presentShareViewInTray(model.openablePath)
|
|
}
|
|
}
|