mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-14 16:47:25 +00:00
1d2774283f
Update StatusRoundButton colours to support a "tertiary" style (background and icon color overlay), as well as tertiary hover colour. Fix the modal header close button so that it more closely matches the design. Replace the buttons in the onboarding modals with StatusRoundButtons were possible.
143 lines
4.3 KiB
QML
143 lines
4.3 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
|
|
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: "#60000000"
|
|
}
|
|
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: {
|
|
var idx = !!title ? 0 : 1
|
|
return children[idx] && children[idx].height
|
|
}
|
|
anchors.top: parent.top
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
|
|
anchors.topMargin: 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: 24
|
|
visible: !!title
|
|
verticalAlignment: Text.AlignVCenter
|
|
}
|
|
}
|
|
|
|
Rectangle {
|
|
id: closeButton
|
|
property bool hovered: false
|
|
height: 32
|
|
width: 32
|
|
anchors.top: headerContent.top
|
|
anchors.topMargin: -4
|
|
anchors.right: headerContent.right
|
|
anchors.rightMargin: -4
|
|
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
|
|
}
|
|
|
|
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.children[0]
|
|
anchors.bottom: parent.bottom
|
|
anchors.bottomMargin: 75
|
|
}
|
|
|
|
Item {
|
|
id: footerContent
|
|
visible: !!children[0]
|
|
height: children[0] && children[0].height
|
|
width: parent.width
|
|
anchors.top: separator2.bottom
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.bottom: parent.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.bottomMargin: Style.current.padding
|
|
anchors.rightMargin: Style.current.padding
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
}
|