mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-10 22:36:24 +00:00
79338f76be
In the recent past we've improved our `ModalPopup` to allow for a bit more control when it comes to rendering a modal footer section with call-to-action items. The footer section is rendered when there's `footerContent` and when the height of the footer content is > 0. This means it's possible to also hide the footer content section from the modal, even when there's footer content children. However, there's a separator rendered whenver the footer is visible, regardless of its height. This results in undesired behaviour when rendering footer children of height 0. To avoid this, this commit adjust the condition so that the separator is only rendered when the footer visible AND the height of it is > 0.
148 lines
4.6 KiB
QML
148 lines
4.6 KiB
QML
import QtQuick 2.13
|
|
import QtQuick.Controls 2.13
|
|
import QtQuick.Layouts 1.13
|
|
import QtGraphicalEffects 1.13
|
|
import "../imports"
|
|
|
|
Popup {
|
|
property string title
|
|
property bool noTopMargin: false
|
|
default property alias content: popupContent.children
|
|
property alias contentWrapper: popupContent
|
|
property alias header: headerContent.children
|
|
|
|
id: popup
|
|
modal: true
|
|
property alias footer: footerContent.children
|
|
|
|
Overlay.modal: Rectangle {
|
|
color: Qt.rgba(0, 0, 0, 0.4)
|
|
}
|
|
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutside
|
|
parent: Overlay.overlay
|
|
x: Math.round(((parent ? parent.width : 0) - width) / 2)
|
|
y: Math.round(((parent ? parent.height : 0) - height) / 2)
|
|
width: 480
|
|
height: 510 // TODO find a way to make this dynamic
|
|
background: Rectangle {
|
|
color: Style.current.background
|
|
radius: 8
|
|
}
|
|
padding: 0
|
|
contentItem: Item {
|
|
|
|
Item {
|
|
id: headerContent
|
|
height: {
|
|
const count = children.length
|
|
let h = 0
|
|
for (let i = 0; i < count; i++) {
|
|
h += children[i] ? children[i].height : 0
|
|
}
|
|
return h
|
|
}
|
|
anchors.top: parent.top
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
|
|
anchors.topMargin: popup.noTopMargin ? 0 : Style.current.padding
|
|
anchors.bottomMargin: Style.current.padding
|
|
anchors.rightMargin: Style.current.padding
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
StyledText {
|
|
text: title
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.left: parent.left
|
|
font.bold: true
|
|
font.pixelSize: 17
|
|
height: visible ? 24 : 0
|
|
visible: !!title
|
|
verticalAlignment: Text.AlignVCenter
|
|
}
|
|
}
|
|
|
|
Rectangle {
|
|
id: closeButton
|
|
property bool hovered: false
|
|
height: 32
|
|
width: 32
|
|
anchors.top: parent.top
|
|
anchors.topMargin: 12
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: 12
|
|
radius: 8
|
|
color: hovered ? Style.current.backgroundHover : Style.current.transparent
|
|
|
|
SVGImage {
|
|
id: closeModalImg
|
|
source: "./img/close.svg"
|
|
width: 11
|
|
height: 11
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
}
|
|
ColorOverlay {
|
|
anchors.fill: closeModalImg
|
|
source: closeModalImg
|
|
color: Style.current.textColor
|
|
}
|
|
|
|
MouseArea {
|
|
id: closeModalMouseArea
|
|
cursorShape: Qt.PointingHandCursor
|
|
anchors.fill: parent
|
|
hoverEnabled: true
|
|
onExited: {
|
|
closeButton.hovered = false
|
|
}
|
|
onEntered: {
|
|
closeButton.hovered = true
|
|
}
|
|
onClicked: {
|
|
popup.close()
|
|
}
|
|
}
|
|
}
|
|
|
|
Separator {
|
|
id: separator
|
|
anchors.top: headerContent.bottom
|
|
anchors.topMargin: visible ? Style.current.padding : 0
|
|
visible: title.length > 0
|
|
}
|
|
|
|
Item {
|
|
id: popupContent
|
|
anchors.top: separator.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.bottom: separator2.top
|
|
anchors.bottomMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.padding
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: Style.current.padding
|
|
}
|
|
|
|
Separator {
|
|
id: separator2
|
|
visible: footerContent.visible && footerContent.height > 0
|
|
anchors.bottom: footerContent.top
|
|
anchors.bottomMargin: visible ? Style.current.padding : 0
|
|
}
|
|
|
|
Item {
|
|
id: footerContent
|
|
visible: children.length > 0
|
|
height: visible ? children[0] && children[0].height : 0
|
|
width: parent.width
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.bottom: parent.bottom
|
|
anchors.bottomMargin: visible ? Style.current.padding : 0
|
|
anchors.rightMargin: visible ? Style.current.padding : 0
|
|
anchors.leftMargin: visible ? Style.current.padding : 0
|
|
}
|
|
}
|
|
}
|