fix(PinnedMessagesPopup): Pinned messages cover rounded corners of modal

similar to the profile dialog, we need to add an opacity mask in front of
the contentItem to ensure the rounded corners at the bottom are preserved
when we have no margins/padding inside the popup

Fixes #7759
This commit is contained in:
Lukáš Tinkl 2022-11-22 12:25:39 +01:00 committed by Lukáš Tinkl
parent 6acd816381
commit 8767f37bad
1 changed files with 20 additions and 8 deletions

View File

@ -2,6 +2,7 @@ import QtQuick 2.14
import QtQuick.Controls 2.14 import QtQuick.Controls 2.14
import QtQuick.Layouts 1.14 import QtQuick.Layouts 1.14
import QtQml.Models 2.14 import QtQml.Models 2.14
import QtGraphicalEffects 1.14
import StatusQ.Core 0.1 import StatusQ.Core 0.1
import StatusQ.Controls 0.1 import StatusQ.Controls 0.1
@ -25,16 +26,12 @@ StatusDialog {
padding: 0 padding: 0
title: root.messageToPin ? qsTr("Pin limit reached") : qsTr("Pinned messages") title: root.messageToPin ? qsTr("Pin limit reached") : qsTr("Pinned messages")
subtitle: root.messageToPin ? qsTr("Unpin a previous message first")
header: StatusDialogHeader {
visible: root.title
headline.title: root.title
headline.subtitle: root.messageToPin ? qsTr("Unpin a previous message first")
: qsTr("%n message(s)", "", pinnedMessageListView.count) : qsTr("%n message(s)", "", pinnedMessageListView.count)
actions.closeButton.onClicked: root.close()
}
contentItem: ColumnLayout { contentItem: ColumnLayout {
id: column
StatusBaseText { StatusBaseText {
visible: pinnedMessageListView.count === 0 visible: pinnedMessageListView.count === 0
text: qsTr("Pinned messages will appear here.") text: qsTr("Pinned messages will appear here.")
@ -143,6 +140,21 @@ StatusDialog {
root.messageStore.messageModule.jumpToMessage(messageId) root.messageStore.messageModule.jumpToMessage(messageId)
} }
} }
layer.enabled: root.visible
layer.effect: OpacityMask {
maskSource: Rectangle {
width: column.width
height: column.height
radius: background.radius
Rectangle {
width: parent.width
height: parent.radius
anchors.top: parent.top
}
}
}
} }
footer: StatusDialogFooter { footer: StatusDialogFooter {