monero-gui/components/TitleBar.qml

442 lines
16 KiB
QML
Raw Normal View History

2024-01-27 19:12:09 +00:00
// Copyright (c) 2014-2024, The Monero Project
2015-04-01 08:56:05 +00:00
//
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without modification, are
// permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice, this list of
// conditions and the following disclaimer.
//
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
// of conditions and the following disclaimer in the documentation and/or other
// materials provided with the distribution.
//
// 3. Neither the name of the copyright holder nor the names of its contributors may be
// used to endorse or promote products derived from this software without specific
// prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2019-04-11 01:17:29 +00:00
import QtQuick 2.9
import QtQuick.Window 2.0
2019-04-11 01:17:29 +00:00
import QtGraphicalEffects 1.0
import QtQuick.Layouts 1.2
2019-04-11 01:17:29 +00:00
import FontAwesome 1.0
import "." as MoneroComponents
import "effects/" as MoneroEffects
2018-04-21 19:59:31 +00:00
2019-04-11 01:17:29 +00:00
Rectangle {
id: root
property int mouseX: 0
2018-04-21 19:59:31 +00:00
property bool customDecorations: persistentSettings.customDecorations
2019-04-11 01:17:29 +00:00
property bool showMinimizeButton: true
property bool showMaximizeButton: true
2018-04-21 19:59:31 +00:00
property bool showCloseButton: true
2019-09-04 23:31:41 +00:00
property string walletName: ""
2019-04-11 01:17:29 +00:00
height: {
2019-09-05 22:11:12 +00:00
if(!persistentSettings.customDecorations) return 0;
2019-04-25 19:09:23 +00:00
return 50;
2019-04-11 01:17:29 +00:00
}
z: 1
color: "transparent"
2018-04-21 19:59:31 +00:00
signal closeClicked
signal maximizeClicked
signal minimizeClicked
2019-04-11 01:17:29 +00:00
signal languageClicked
2019-09-16 21:59:54 +00:00
signal closeWalletClicked
signal lockWalletClicked
2019-04-11 01:17:29 +00:00
state: "default"
states: [
State {
name: "default";
2019-09-16 21:59:54 +00:00
PropertyChanges { target: btnCloseWallet; visible: true}
PropertyChanges { target: btnLockWallet; visible: true}
2019-04-11 01:17:29 +00:00
PropertyChanges { target: btnLanguageToggle; visible: true}
}, State {
// show only theme switcher and window controls
name: "essentials";
2019-09-16 21:59:54 +00:00
PropertyChanges { target: btnCloseWallet; visible: false}
PropertyChanges { target: btnLockWallet; visible: false}
2019-04-11 01:17:29 +00:00
PropertyChanges { target: btnLanguageToggle; visible: false}
2018-12-08 15:55:29 +00:00
}
2019-04-11 01:17:29 +00:00
]
MoneroEffects.GradientBackground {
anchors.fill: parent
duration: 300
fallBackColor: MoneroComponents.Style.middlePanelBackgroundColor
initialStartColor: MoneroComponents.Style.titleBarBackgroundGradientStart
initialStopColor: MoneroComponents.Style.titleBarBackgroundGradientStop
blackColorStart: MoneroComponents.Style._b_titleBarBackgroundGradientStart
blackColorStop: MoneroComponents.Style._b_titleBarBackgroundGradientStop
whiteColorStart: MoneroComponents.Style._w_titleBarBackgroundGradientStart
whiteColorStop: MoneroComponents.Style._w_titleBarBackgroundGradientStop
start: Qt.point(width, 0)
end: Qt.point(0, 0)
2018-04-21 19:59:31 +00:00
}
2019-01-14 00:02:44 +00:00
RowLayout {
2018-04-21 19:59:31 +00:00
z: parent.z + 2
2019-04-11 01:17:29 +00:00
spacing: 0
anchors.fill: parent
2014-07-19 14:07:40 +00:00
// lock wallet
Rectangle {
id: btnLockWallet
color: "transparent"
Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height
Text {
text: FontAwesome.lock
font.family: FontAwesome.fontFamilySolid
font.pixelSize: 16
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
opacity: 0.75
}
MoneroComponents.Tooltip {
id: btnLockWalletTooltip
anchors.fill: parent
text: qsTr("Lock this wallet") + translationManager.emptyString
}
MouseArea {
anchors.fill: parent
hoverEnabled: true
cursorShape: Qt.PointingHandCursor
onEntered: {
parent.color = MoneroComponents.Style.titleBarButtonHoverColor
btnLockWalletTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnLockWalletTooltip.tooltipPopup.close()
}
onClicked: root.lockWalletClicked(leftPanel.visible)
}
}
2019-04-11 01:17:29 +00:00
// collapse sidebar
2019-01-14 00:02:44 +00:00
Rectangle {
2019-09-16 21:59:54 +00:00
id: btnCloseWallet
2019-04-11 01:17:29 +00:00
color: "transparent"
Layout.preferredWidth: parent.height
2019-01-14 00:02:44 +00:00
Layout.preferredHeight: parent.height
2019-09-16 21:59:54 +00:00
Text {
text: FontAwesome.signOutAlt
font.family: FontAwesome.fontFamilySolid
font.pixelSize: 16
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
2019-04-11 01:17:29 +00:00
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
opacity: 0.75
2019-01-14 00:02:44 +00:00
}
MoneroComponents.Tooltip {
id: btnCloseWalletTooltip
anchors.fill: parent
text: qsTr("Close this wallet and return to main menu") + translationManager.emptyString
}
2019-01-14 00:02:44 +00:00
MouseArea {
anchors.fill: parent
2019-04-11 01:17:29 +00:00
hoverEnabled: true
2019-01-14 00:02:44 +00:00
cursorShape: Qt.PointingHandCursor
onEntered: {
parent.color = MoneroComponents.Style.titleBarButtonHoverColor
btnCloseWalletTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnCloseWalletTooltip.tooltipPopup.close()
}
2019-09-16 21:59:54 +00:00
onClicked: root.closeWalletClicked(leftPanel.visible)
2019-01-14 00:02:44 +00:00
}
2014-07-19 14:07:40 +00:00
}
2019-01-14 00:02:44 +00:00
// language selection
Rectangle {
2019-04-11 01:17:29 +00:00
id: btnLanguageToggle
color: "transparent"
Layout.preferredWidth: parent.height
2019-01-14 00:02:44 +00:00
Layout.preferredHeight: parent.height
2019-04-11 01:17:29 +00:00
Text {
text: FontAwesome.globe
font.family: FontAwesome.fontFamilySolid
2019-04-25 19:09:23 +00:00
font.pixelSize: 16
2019-04-11 01:17:29 +00:00
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
2019-04-11 01:17:29 +00:00
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
opacity: 0.75
2019-01-14 00:02:44 +00:00
}
MoneroComponents.Tooltip {
id: btnLanguageToggleTooltip
anchors.fill: parent
text: qsTr("Change language") + translationManager.emptyString
}
2019-01-14 00:02:44 +00:00
MouseArea {
2019-04-11 01:17:29 +00:00
anchors.fill: parent
2019-01-14 00:02:44 +00:00
hoverEnabled: true
2019-04-11 01:17:29 +00:00
cursorShape: Qt.PointingHandCursor
onEntered: {
parent.color = MoneroComponents.Style.titleBarButtonHoverColor
btnLanguageToggleTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnLanguageToggleTooltip.tooltipPopup.close()
}
2019-04-11 01:17:29 +00:00
onClicked: root.languageClicked()
}
}
// switch theme
Rectangle {
color: "transparent"
Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height
Text {
text: FontAwesome.moonO
font.family: MoneroComponents.Style.blackTheme ? FontAwesome.fontFamilySolid : FontAwesome.fontFamily
font.styleName: MoneroComponents.Style.blackTheme ? "Solid" : "Regular"
font.pixelSize: 15
2019-04-11 01:17:29 +00:00
color: MoneroComponents.Style.defaultFontColor
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
opacity: 0.75
}
MoneroComponents.Tooltip {
id: btnSwitchThemeTooltip
anchors.fill: parent
text: MoneroComponents.Style.blackTheme ? qsTr("Switch to light theme") : qsTr("Switch to dark theme") + translationManager.emptyString
}
2019-04-11 01:17:29 +00:00
MouseArea {
2019-01-14 00:02:44 +00:00
anchors.fill: parent
2019-04-11 01:17:29 +00:00
hoverEnabled: true
2019-01-14 00:02:44 +00:00
cursorShape: Qt.PointingHandCursor
onEntered: {
parent.color = MoneroComponents.Style.titleBarButtonHoverColor
btnSwitchThemeTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnSwitchThemeTooltip.tooltipPopup.close()
}
2019-01-14 00:02:44 +00:00
onClicked: {
2019-04-11 01:17:29 +00:00
MoneroComponents.Style.blackTheme = !MoneroComponents.Style.blackTheme;
2019-01-14 00:02:44 +00:00
}
2014-07-19 14:07:40 +00:00
}
}
2019-04-11 01:17:29 +00:00
Item {
// make dummy space when hiding buttons when titlebar
// state is 'essentials' in order for the
// monero logo to still be centered
Layout.preferredWidth: parent.height * 2 // amount of buttons we hide
Layout.preferredHeight: parent.height
visible: root.state == "essentials"
}
// monero logo
Item {
2019-09-04 23:31:41 +00:00
visible: walletName.length === 0
2019-04-11 01:17:29 +00:00
Layout.fillWidth: true
Layout.preferredHeight: parent.height
2019-04-11 01:17:29 +00:00
Image {
id: imgLogo
width: 125
height: 28
anchors.horizontalCenter: parent.horizontalCenter
anchors.verticalCenter: parent.verticalCenter
source: MoneroComponents.Style.titleBarLogoSource
visible: {
if(!isOpenGL) return true;
if(!MoneroComponents.Style.blackTheme) return true;
return false;
}
}
Colorize {
visible: isOpenGL && MoneroComponents.Style.blackTheme
anchors.fill: imgLogo
source: imgLogo
saturation: 0.0
}
}
2019-09-04 23:31:41 +00:00
Item {
visible: walletName.length > 0
Layout.fillWidth: true
Layout.preferredHeight: parent.height
MoneroComponents.TextPlain {
font.pixelSize: 20
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
width: parent.width
height: parent.height
elide: Text.ElideRight
text: walletName
}
}
2019-04-11 01:17:29 +00:00
// minimize
Rectangle {
2017-12-24 20:52:29 +00:00
color: "transparent"
2019-04-11 01:17:29 +00:00
visible: root.showMinimizeButton
Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height
2019-04-11 01:17:29 +00:00
MoneroEffects.ImageMask {
anchors.bottom: parent.bottom
anchors.bottomMargin: 18
anchors.horizontalCenter: parent.horizontalCenter
height: 3
width: 15
image: MoneroComponents.Style.titleBarMinimizeSource
color: MoneroComponents.Style.defaultFontColor
fontAwesomeFallbackIcon: FontAwesome.minus
fontAwesomeFallbackSize: 18
fontAwesomeFallbackOpacity: MoneroComponents.Style.blackTheme ? 0.8 : 0.6
opacity: 0.75
}
MouseArea {
anchors.fill: parent
2017-12-24 20:52:29 +00:00
hoverEnabled: true
cursorShape: Qt.PointingHandCursor
2019-04-11 01:17:29 +00:00
onEntered: parent.color = MoneroComponents.Style.titleBarButtonHoverColor
onExited: parent.color = "transparent"
onClicked: root.minimizeClicked();
}
}
2019-04-11 01:17:29 +00:00
// maximize
Rectangle {
2019-04-11 01:17:29 +00:00
id: test
visible: root.showMaximizeButton
color: "transparent"
Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height
Image {
2019-04-11 01:17:29 +00:00
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
source: MoneroComponents.Style.titleBarFullscreenSource
sourceSize.width: 16
sourceSize.height: 16
smooth: true
mipmap: true
opacity: 0.75
rotation: appWindow.visibility === Window.FullScreen ? 180 : 0
}
MouseArea {
2019-04-11 01:17:29 +00:00
id: buttonArea
anchors.fill: parent
2017-12-24 20:52:29 +00:00
hoverEnabled: true
cursorShape: Qt.PointingHandCursor
2019-04-11 01:17:29 +00:00
onEntered: parent.color = MoneroComponents.Style.titleBarButtonHoverColor
onExited: parent.color = "transparent"
onClicked: root.maximizeClicked();
}
}
2019-04-11 01:17:29 +00:00
// close
Rectangle {
2019-04-11 01:17:29 +00:00
visible: root.showCloseButton
color: "transparent"
Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height
2019-04-11 01:17:29 +00:00
MoneroEffects.ImageMask {
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
2017-11-15 22:51:22 +00:00
height: 16
2019-04-11 01:17:29 +00:00
width: 16
image: MoneroComponents.Style.titleBarCloseSource
color: MoneroComponents.Style.defaultFontColor
2020-04-10 11:55:25 +00:00
fontAwesomeFallbackIcon: FontAwesome.times
fontAwesomeFallbackSize: 21
2019-04-11 01:17:29 +00:00
fontAwesomeFallbackOpacity: MoneroComponents.Style.blackTheme ? 0.8 : 0.6
opacity: 0.75
}
MouseArea {
anchors.fill: parent
2017-12-24 20:52:29 +00:00
hoverEnabled: true
cursorShape: Qt.PointingHandCursor
2019-04-11 01:17:29 +00:00
onEntered: parent.color = MoneroComponents.Style.titleBarButtonHoverColor
onExited: parent.color = "transparent"
onClicked: root.closeClicked();
}
}
}
2018-04-21 19:59:31 +00:00
Rectangle {
2019-04-11 01:17:29 +00:00
z: parent.z + 3
2018-04-21 19:59:31 +00:00
anchors.bottom: parent.bottom
anchors.left: parent.left
2019-04-11 01:17:29 +00:00
anchors.right: parent.right
height: MoneroComponents.Style.blackTheme ? 1 : 1
color: MoneroComponents.Style.titleBarBackgroundBorderColor
MoneroEffects.ColorTransition {
targetObj: parent
blackColor: MoneroComponents.Style._b_titleBarBackgroundBorderColor
whiteColor: MoneroComponents.Style._w_titleBarBackgroundBorderColor
}
2018-04-21 19:59:31 +00:00
}
2019-04-11 01:17:29 +00:00
MouseArea {
enabled: persistentSettings.customDecorations
property var previousPosition
anchors.fill: parent
propagateComposedEvents: true
onPressed: previousPosition = globalCursor.getPosition()
onDoubleClicked: root.maximizeClicked()
2019-04-11 01:17:29 +00:00
onPositionChanged: {
if (pressedButtons == Qt.LeftButton) {
var pos = globalCursor.getPosition()
var dx = pos.x - previousPosition.x
var dy = pos.y - previousPosition.y
appWindow.x += dx
appWindow.y += dy
previousPosition = pos
}
}
2018-04-21 19:59:31 +00:00
}
}