TitleBar/MerchantTitleBar/StandardDialog: use fontAwesome on maximize, restore & close icons; main: fontawesome fallback for resize area

This commit is contained in:
rating89us 2021-06-20 14:30:37 +02:00 committed by rating89us
parent 51828babbb
commit 55b3b6f8c2
13 changed files with 154 additions and 113 deletions

View file

@ -32,6 +32,7 @@ import QtQuick.Dialogs 1.2
import QtQuick.Layouts 1.1 import QtQuick.Layouts 1.1
import QtQuick.Controls.Styles 1.4 import QtQuick.Controls.Styles 1.4
import QtQuick.Window 2.0 import QtQuick.Window 2.0
import FontAwesome 1.0
import "../components" as MoneroComponents import "../components" as MoneroComponents
import "effects/" as MoneroEffects import "effects/" as MoneroEffects
@ -199,24 +200,34 @@ Rectangle {
height: 48 height: 48
color: "transparent" color: "transparent"
MoneroEffects.ImageMask { Text {
anchors.centerIn: parent text: FontAwesome.times
width: 16 font.family:FontAwesome.fontFamilySolid
height: 16 font.pixelSize: 19
image: MoneroComponents.Style.titleBarCloseSource color: closeButtonMouseArea.containsMouse ? MoneroComponents.Style.dimmedFontColor : MoneroComponents.Style.defaultFontColor
color: MoneroComponents.Style.defaultFontColor font.styleName: "Solid"
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
opacity: 0.75 opacity: 0.75
} }
MouseArea { MoneroComponents.Tooltip {
id: btnCloseStandardDialogTooltip
anchors.fill: parent anchors.fill: parent
text: qsTr("Close") + translationManager.emptyString
}
MouseArea {
id: closeButtonMouseArea
anchors.fill: parent
hoverEnabled: true
onClicked: { onClicked: {
root.close() root.close()
root.rejected() root.rejected()
} }
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: closeButton.color = "#262626"; onEntered: btnCloseStandardDialogTooltip.tooltipPopup.open()
onExited: closeButton.color = "transparent"; onExited: btnCloseStandardDialogTooltip.tooltipPopup.close()
} }
} }

View file

@ -54,9 +54,6 @@ QtObject {
property string titleBarBackgroundGradientStop: blackTheme ? _b_titleBarBackgroundGradientStop : _w_titleBarBackgroundGradientStop property string titleBarBackgroundGradientStop: blackTheme ? _b_titleBarBackgroundGradientStop : _w_titleBarBackgroundGradientStop
property string titleBarBackgroundBorderColor: blackTheme ? _b_titleBarBackgroundBorderColor : _w_titleBarBackgroundBorderColor property string titleBarBackgroundBorderColor: blackTheme ? _b_titleBarBackgroundBorderColor : _w_titleBarBackgroundBorderColor
property string titleBarLogoSource: blackTheme ? _b_titleBarLogoSource : _w_titleBarLogoSource property string titleBarLogoSource: blackTheme ? _b_titleBarLogoSource : _w_titleBarLogoSource
property string titleBarMinimizeSource: blackTheme ? _b_titleBarMinimizeSource : _w_titleBarMinimizeSource
property string titleBarFullscreenSource: blackTheme ? _b_titleBarFullscreenSource : _w_titleBarFullscreenSource
property string titleBarCloseSource: blackTheme ? _b_titleBarCloseSource : _w_titleBarCloseSource
property string titleBarButtonHoverColor: blackTheme ? _b_titleBarButtonHoverColor : _w_titleBarButtonHoverColor property string titleBarButtonHoverColor: blackTheme ? _b_titleBarButtonHoverColor : _w_titleBarButtonHoverColor
property string wizardBackgroundGradientStart: blackTheme ? _b_wizardBackgroundGradientStart : _w_wizardBackgroundGradientStart property string wizardBackgroundGradientStart: blackTheme ? _b_wizardBackgroundGradientStart : _w_wizardBackgroundGradientStart
@ -111,9 +108,6 @@ QtObject {
property string _b_titleBarBackgroundGradientStop: "#191919" property string _b_titleBarBackgroundGradientStop: "#191919"
property string _b_titleBarBackgroundBorderColor: "#2f2f2f" property string _b_titleBarBackgroundBorderColor: "#2f2f2f"
property string _b_titleBarLogoSource: "qrc:///images/titlebarLogo.png" property string _b_titleBarLogoSource: "qrc:///images/titlebarLogo.png"
property string _b_titleBarMinimizeSource: "qrc:///images/minimize.svg"
property string _b_titleBarFullscreenSource: "qrc:///images/fullscreen.svg"
property string _b_titleBarCloseSource: "qrc:///images/close.svg"
property string _b_titleBarButtonHoverColor: "#10FFFFFF" property string _b_titleBarButtonHoverColor: "#10FFFFFF"
property string _b_wizardBackgroundGradientStart: "#1e1e1e" property string _b_wizardBackgroundGradientStart: "#1e1e1e"
@ -168,9 +162,6 @@ QtObject {
property string _w_titleBarBackgroundGradientStop: "#FBFBFB" property string _w_titleBarBackgroundGradientStop: "#FBFBFB"
property string _w_titleBarBackgroundBorderColor: "#DEDEDE" property string _w_titleBarBackgroundBorderColor: "#DEDEDE"
property string _w_titleBarLogoSource: "qrc:///images/themes/white/titlebarLogo.png" property string _w_titleBarLogoSource: "qrc:///images/themes/white/titlebarLogo.png"
property string _w_titleBarMinimizeSource: "qrc:///images/themes/white/minimize.svg"
property string _w_titleBarFullscreenSource: "qrc:///images/themes/white/fullscreen.svg"
property string _w_titleBarCloseSource: "qrc:///images/themes/white/close.svg"
property string _w_titleBarButtonHoverColor: "#11000000" property string _w_titleBarButtonHoverColor: "#11000000"
property string _w_wizardBackgroundGradientStart: "white" property string _w_wizardBackgroundGradientStart: "white"

View file

@ -118,6 +118,7 @@ Rectangle {
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
visible: middlePanel.state !== "Merchant" && !informationPopup.visible && !confirmationDialog.visible
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: { onEntered: {
@ -158,6 +159,7 @@ Rectangle {
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
visible: middlePanel.state !== "Merchant" && !informationPopup.visible && !confirmationDialog.visible
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: { onEntered: {
@ -197,6 +199,7 @@ Rectangle {
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
visible: middlePanel.state !== "Merchant" && !informationPopup.visible && !confirmationDialog.visible
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: { onEntered: {
@ -275,26 +278,36 @@ Rectangle {
Layout.preferredWidth: parent.height Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height Layout.preferredHeight: parent.height
MoneroEffects.ImageMask { Text {
anchors.bottom: parent.bottom text: FontAwesome.windowMinimize
anchors.bottomMargin: 18 font.family:FontAwesome.fontFamilySolid
anchors.horizontalCenter: parent.horizontalCenter font.pixelSize: 16
height: 3
width: 15
image: MoneroComponents.Style.titleBarMinimizeSource
color: MoneroComponents.Style.defaultFontColor color: MoneroComponents.Style.defaultFontColor
fontAwesomeFallbackIcon: FontAwesome.minus font.styleName: "Solid"
fontAwesomeFallbackSize: 18 anchors.verticalCenter: parent.verticalCenter
fontAwesomeFallbackOpacity: MoneroComponents.Style.blackTheme ? 0.8 : 0.6 anchors.horizontalCenter: parent.horizontalCenter
opacity: 0.75 opacity: 0.75
} }
MoneroComponents.Tooltip {
id: btnMinimizeWindowTooltip
anchors.fill: parent
text: qsTr("Minimize") + translationManager.emptyString
}
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
visible: !informationPopup.visible && !confirmationDialog.visible
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: parent.color = MoneroComponents.Style.titleBarButtonHoverColor onEntered: {
onExited: parent.color = "transparent" parent.color = MoneroComponents.Style.titleBarButtonHoverColor
btnMinimizeWindowTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnMinimizeWindowTooltip.tooltipPopup.close()
}
onClicked: root.minimizeClicked(); onClicked: root.minimizeClicked();
} }
} }
@ -307,25 +320,37 @@ Rectangle {
Layout.preferredWidth: parent.height Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height Layout.preferredHeight: parent.height
Image { Text {
text: appWindow.visibility == Window.Maximized ? FontAwesome.windowRestore : FontAwesome.windowMaximize
font.family:FontAwesome.fontFamilySolid
font.pixelSize: 16
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
source: MoneroComponents.Style.titleBarFullscreenSource
sourceSize.width: 16
sourceSize.height: 16
smooth: true
mipmap: true
opacity: 0.75 opacity: 0.75
rotation: appWindow.visibility === Window.FullScreen ? 180 : 0 }
MoneroComponents.Tooltip {
id: btnMaximizeRestoreTooltip
anchors.fill: parent
text: appWindow.visibility == Window.Maximized ? qsTr("Restore") : qsTr("Maximize") + translationManager.emptyString
} }
MouseArea { MouseArea {
id: buttonArea id: buttonArea
anchors.fill: parent anchors.fill: parent
visible: !informationPopup.visible && !confirmationDialog.visible
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: parent.color = MoneroComponents.Style.titleBarButtonHoverColor onEntered: {
onExited: parent.color = "transparent" parent.color = MoneroComponents.Style.titleBarButtonHoverColor
btnMaximizeRestoreTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnMaximizeRestoreTooltip.tooltipPopup.close()
}
onClicked: root.maximizeClicked(); onClicked: root.maximizeClicked();
} }
} }
@ -337,25 +362,35 @@ Rectangle {
Layout.preferredWidth: parent.height Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height Layout.preferredHeight: parent.height
MoneroEffects.ImageMask { Text {
text: FontAwesome.times
font.family:FontAwesome.fontFamilySolid
font.pixelSize: 19
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
height: 16
width: 16
image: MoneroComponents.Style.titleBarCloseSource
color: MoneroComponents.Style.defaultFontColor
fontAwesomeFallbackIcon: FontAwesome.times
fontAwesomeFallbackSize: 21
fontAwesomeFallbackOpacity: MoneroComponents.Style.blackTheme ? 0.8 : 0.6
opacity: 0.75 opacity: 0.75
} }
MoneroComponents.Tooltip {
id: btnCloseWindowTooltip
anchors.fill: parent
text: qsTr("Close Monero GUI") + translationManager.emptyString
}
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: parent.color = MoneroComponents.Style.titleBarButtonHoverColor onEntered: {
onExited: parent.color = "transparent" parent.color = MoneroComponents.Style.titleBarButtonHoverColor
btnCloseWindowTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnCloseWindowTooltip.tooltipPopup.close()
}
onClicked: root.closeClicked(); onClicked: root.closeClicked();
} }
} }

View file

@ -42,6 +42,7 @@ Object {
property string edit : "\uf044" property string edit : "\uf044"
property string ellipsisH : "\uf141" property string ellipsisH : "\uf141"
property string exclamationCircle : "\uf06a" property string exclamationCircle : "\uf06a"
property string expandAlt : "\uf424"
property string eye : "\uf06e" property string eye : "\uf06e"
property string eyeSlash : "\uf070" property string eyeSlash : "\uf070"
property string folderOpen : "\uf07c" property string folderOpen : "\uf07c"

View file

@ -1,5 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16">
<g fill="none" fill-rule="evenodd" stroke="#FFF" stroke-linecap="round" stroke-width="1.85" opacity="1">
<path d="M1 1l14 14M15 1L1 15"/>
</g>
</svg>

Before

Width:  |  Height:  |  Size: 250 B

View file

@ -1,6 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 18 18">
<g fill="none" fill-rule="evenodd" stroke="#FFF" stroke-width="1.636" opacity="1">
<rect width="16.364" height="16.364" x=".818" y=".818" rx="1.636"/>
<rect width="16.364" height="3.273" x=".818" y=".818" fill="#FFF" rx="1.636"/>
</g>
</svg>

Before

Width:  |  Height:  |  Size: 350 B

View file

@ -1,3 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" width="18" height="4" viewBox="0 0 18 4">
<rect width="16" height="2" x="899" y="31" fill="#FFF" fill-rule="evenodd" stroke="#FFF" stroke-width="2" opacity="1" rx="1" transform="translate(-898 -30)"/>
</svg>

Before

Width:  |  Height:  |  Size: 252 B

View file

@ -1,6 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16">
<g fill="none" fill-rule="evenodd" opacity="1">
<path fill="none" d="M-10-10h36v36h-36z" opacity="1"/>
<path stroke="#000" stroke-linecap="round" stroke-width="1.5" d="M1 1l14 14M15 1L1 15"/>
</g>
</svg>

Before

Width:  |  Height:  |  Size: 312 B

View file

@ -1,7 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 18 18">
<g fill="none" fill-rule="evenodd" opacity="1" transform="translate(-9 -9)">
<path fill="none" d="M0 0h36v36H0z" opacity="1"/>
<rect width="16" height="16" x="10" y="10" stroke="#000" stroke-width="1.5" rx="1.5"/>
<path fill="#FFF" stroke="#000" stroke-width="1.5" d="M11 10h14a1 1 0 0 1 1 1v2H10v-2a1 1 0 0 1 1-1z"/>
</g>
</svg>

Before

Width:  |  Height:  |  Size: 446 B

View file

@ -1,3 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="2" viewBox="0 0 16 2">
<rect width="16" height="2" x="10" y="25" fill="#000" fill-rule="evenodd" opacity="1" rx="1" transform="translate(-10 -25)"/>
</svg>

Before

Width:  |  Height:  |  Size: 219 B

View file

@ -1737,13 +1737,13 @@ ApplicationWindow {
name: "wizard" name: "wizard"
PropertyChanges { target: middlePanel; visible: false } PropertyChanges { target: middlePanel; visible: false }
PropertyChanges { target: wizard; visible: true } PropertyChanges { target: wizard; visible: true }
PropertyChanges { target: resizeArea; visible: true } PropertyChanges { target: resizeArea; visible: appWindow.visibility !== Window.Maximized }
PropertyChanges { target: titleBar; state: "essentials" } PropertyChanges { target: titleBar; state: "essentials" }
}, State { }, State {
name: "normal" name: "normal"
PropertyChanges { target: middlePanel; visible: true } PropertyChanges { target: middlePanel; visible: true }
PropertyChanges { target: wizard; visible: false } PropertyChanges { target: wizard; visible: false }
PropertyChanges { target: resizeArea; visible: true } PropertyChanges { target: resizeArea; visible: appWindow.visibility !== Window.Maximized }
PropertyChanges { target: titleBar; state: "default" } PropertyChanges { target: titleBar; state: "default" }
} }
] ]
@ -1854,11 +1854,14 @@ ApplicationWindow {
MoneroEffects.ImageMask { MoneroEffects.ImageMask {
anchors.centerIn: parent anchors.centerIn: parent
visible: persistentSettings.customDecorations visible: persistentSettings.customDecorations && appWindow.visibility !== Window.Maximized
image: "qrc:///images/resize.png" image: "qrc:///images/resize.png"
color: MoneroComponents.Style.defaultFontColor color: MoneroComponents.Style.defaultFontColor
width: 12 width: 12
height: 12 height: 12
fontAwesomeFallbackIcon: FontAwesome.expandAlt
fontAwesomeFallbackSize: 18
fontAwesomeFallbackOpacity: MoneroComponents.Style.blackTheme ? 0.8 : 0.6
opacity: (parent.containsMouse || parent.pressed) ? 0.5 : 1.0 opacity: (parent.containsMouse || parent.pressed) ? 0.5 : 1.0
} }

View file

@ -96,23 +96,35 @@ Rectangle {
Layout.preferredWidth: parent.height Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height Layout.preferredHeight: parent.height
MoneroEffects.ImageMask { Text {
anchors.bottom: parent.bottom text: FontAwesome.windowMinimize
anchors.bottomMargin: 18 font.family:FontAwesome.fontFamilySolid
font.pixelSize: 16
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
height: 3
width: 15
image: MoneroComponents.Style.titleBarMinimizeSource
color: "white"
opacity: 0.75 opacity: 0.75
} }
MoneroComponents.Tooltip {
id: btnMinimizeWindowTooltip
anchors.fill: parent
text: qsTr("Minimize") + translationManager.emptyString
}
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: parent.color = "#44FFFFFF" onEntered: {
onExited: parent.color = "transparent" parent.color = "#44FFFFFF"
btnMinimizeWindowTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnMinimizeWindowTooltip.tooltipPopup.close()
}
onClicked: root.minimizeClicked(); onClicked: root.minimizeClicked();
} }
} }
@ -125,16 +137,21 @@ Rectangle {
Layout.preferredWidth: parent.height Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height Layout.preferredHeight: parent.height
Image { Text {
text: appWindow.visibility == Window.Maximized ? FontAwesome.windowRestore : FontAwesome.windowMaximize
font.family:FontAwesome.fontFamilySolid
font.pixelSize: 16
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
source: MoneroComponents.Style._b_titleBarFullscreenSource
sourceSize.width: 16
sourceSize.height: 16
smooth: true
mipmap: true
opacity: 0.75 opacity: 0.75
rotation: appWindow.visibility === Window.FullScreen ? 180 : 0 }
MoneroComponents.Tooltip {
id: btnMaximizeRestoreTooltip
anchors.fill: parent
text: appWindow.visibility == Window.Maximized ? qsTr("Restore") : qsTr("Maximize") + translationManager.emptyString
} }
MouseArea { MouseArea {
@ -142,8 +159,14 @@ Rectangle {
anchors.fill: parent anchors.fill: parent
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: parent.color = "#44FFFFFF" onEntered: {
onExited: parent.color = "transparent" parent.color = "#44FFFFFF"
btnMaximizeRestoreTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnMaximizeRestoreTooltip.tooltipPopup.close()
}
onClicked: root.maximizeClicked(); onClicked: root.maximizeClicked();
} }
} }
@ -155,22 +178,35 @@ Rectangle {
Layout.preferredWidth: parent.height Layout.preferredWidth: parent.height
Layout.preferredHeight: parent.height Layout.preferredHeight: parent.height
MoneroEffects.ImageMask { Text {
text: FontAwesome.times
font.family:FontAwesome.fontFamilySolid
font.pixelSize: 19
color: MoneroComponents.Style.defaultFontColor
font.styleName: "Solid"
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
height: 16
width: 16
image: MoneroComponents.Style._b_titleBarCloseSource
color: "white"
opacity: 0.75 opacity: 0.75
} }
MoneroComponents.Tooltip {
id: btnCloseWindowTooltip
anchors.fill: parent
text: qsTr("Close Monero GUI") + translationManager.emptyString
}
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
hoverEnabled: true hoverEnabled: true
cursorShape: Qt.PointingHandCursor cursorShape: Qt.PointingHandCursor
onEntered: parent.color = "#44FFFFFF" onEntered: {
onExited: parent.color = "transparent" parent.color = "#44FFFFFF"
btnCloseWindowTooltip.tooltipPopup.open()
}
onExited: {
parent.color = "transparent"
btnCloseWindowTooltip.tooltipPopup.close()
}
onClicked: root.closeClicked(); onClicked: root.closeClicked();
} }
} }

View file

@ -232,12 +232,6 @@
<file>images/middlePanelShadow.png</file> <file>images/middlePanelShadow.png</file>
<file>images/themes/white/titlebarLogo@2x.png</file> <file>images/themes/white/titlebarLogo@2x.png</file>
<file>images/themes/white/titlebarLogo.png</file> <file>images/themes/white/titlebarLogo.png</file>
<file>images/fullscreen.svg</file>
<file>images/close.svg</file>
<file>images/minimize.svg</file>
<file>images/themes/white/close.svg</file>
<file>images/themes/white/fullscreen.svg</file>
<file>images/themes/white/minimize.svg</file>
<file>components/effects/ColorTransition.qml</file> <file>components/effects/ColorTransition.qml</file>
<file>components/effects/GradientBackground.qml</file> <file>components/effects/GradientBackground.qml</file>
<file>images/check-white.svg</file> <file>images/check-white.svg</file>