mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-23 19:15:56 +00:00
Merge pull request #3026
4208b66
WizardModeSelection: optional 'Portable mode' feature support (xiphon)
This commit is contained in:
commit
40e108eb2b
7 changed files with 76 additions and 13 deletions
|
@ -109,6 +109,7 @@ Item {
|
|||
color: MoneroComponents.Style.defaultFontColor
|
||||
textFormat: Text.RichText
|
||||
wrapMode: Text.NoWrap
|
||||
visible: text != ""
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -81,6 +81,8 @@
|
|||
|
||||
#if defined(Q_OS_WIN)
|
||||
#include <QOpenGLContext>
|
||||
#elif defined(Q_OS_MACOS)
|
||||
#include "qt/macoshelper.h"
|
||||
#endif
|
||||
|
||||
#ifdef WITH_SCANNER
|
||||
|
@ -328,6 +330,10 @@ Verify update binary using 'shasum'-compatible (SHA256 algo) output signed by tw
|
|||
// start listening
|
||||
QTimer::singleShot(0, ipc, SLOT(bind()));
|
||||
|
||||
#if defined(Q_OS_MACOS)
|
||||
QDir::setCurrent(QDir(MacOSHelper::bundlePath() + QDir::separator() + "..").canonicalPath());
|
||||
#endif
|
||||
|
||||
// screen settings
|
||||
// Mobile is designed on 128dpi
|
||||
qreal ref_dpi = 128;
|
||||
|
|
|
@ -36,6 +36,7 @@ class MacOSHelper
|
|||
public:
|
||||
static bool isCapsLock();
|
||||
static bool openFolderAndSelectItem(const QUrl &path);
|
||||
static QString bundlePath();
|
||||
};
|
||||
|
||||
#endif //MACOSHELPER_H
|
||||
|
|
|
@ -55,3 +55,18 @@ bool MacOSHelper::openFolderAndSelectItem(const QUrl &path)
|
|||
[[NSWorkspace sharedWorkspace] activateFileViewerSelectingURLs:fileURLs];
|
||||
return true;
|
||||
}
|
||||
|
||||
QString MacOSHelper::bundlePath()
|
||||
{
|
||||
NSBundle *main = [NSBundle mainBundle];
|
||||
if (!main)
|
||||
{
|
||||
return {};
|
||||
}
|
||||
NSString *bundlePathString = [main bundlePath];
|
||||
if (!bundlePathString)
|
||||
{
|
||||
return {};
|
||||
}
|
||||
return QString::fromCFString(reinterpret_cast<const CFStringRef>(bundlePathString));
|
||||
}
|
||||
|
|
|
@ -245,4 +245,8 @@ Rectangle {
|
|||
Timer {
|
||||
id: versionTimer
|
||||
}
|
||||
|
||||
function onPageCompleted() {
|
||||
persistentSettings.setWritable(false);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -39,6 +39,8 @@ RowLayout {
|
|||
Layout.fillWidth: true
|
||||
Layout.bottomMargin: 10
|
||||
property alias imageIcon: icon.source
|
||||
property bool checkbox: false
|
||||
property alias checked: checkboxItem.checked
|
||||
property alias headerText: header.text
|
||||
property alias bodyText: body.text
|
||||
signal menuClicked();
|
||||
|
@ -48,16 +50,24 @@ RowLayout {
|
|||
Layout.preferredWidth: 70
|
||||
Layout.preferredHeight: 70
|
||||
|
||||
MoneroComponents.CheckBox {
|
||||
id: checkboxItem
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
toggleOnClick: false
|
||||
visible: rowlayout.checkbox
|
||||
}
|
||||
|
||||
Image {
|
||||
id: icon
|
||||
visible: !isOpenGL || MoneroComponents.Style.blackTheme
|
||||
visible: !rowlayout.checkbox && (!isOpenGL || MoneroComponents.Style.blackTheme)
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
source: ""
|
||||
}
|
||||
|
||||
DropShadow {
|
||||
visible: isOpenGL && !MoneroComponents.Style.blackTheme
|
||||
visible: !rowlayout.checkbox && (isOpenGL && !MoneroComponents.Style.blackTheme)
|
||||
anchors.fill: icon
|
||||
horizontalOffset: 3
|
||||
verticalOffset: 3
|
||||
|
|
|
@ -40,6 +40,18 @@ Rectangle {
|
|||
|
||||
property alias pageHeight: pageRoot.height
|
||||
property string viewName: "wizardModeSelection1"
|
||||
property bool portable: persistentSettings.portable
|
||||
|
||||
function applyWalletMode(mode, wizardState) {
|
||||
if (!persistentSettings.setPortable(portable)) {
|
||||
appWindow.showStatusMessage(qsTr("Failed to configure portable mode"), 3);
|
||||
return;
|
||||
}
|
||||
|
||||
appWindow.changeWalletMode(mode);
|
||||
wizardController.wizardStackView.backTransition = false;
|
||||
wizardController.wizardState = wizardState;
|
||||
}
|
||||
|
||||
ColumnLayout {
|
||||
id: pageRoot
|
||||
|
@ -78,9 +90,7 @@ Rectangle {
|
|||
|
||||
onMenuClicked: {
|
||||
if(appWindow.persistentSettings.nettype == 0){
|
||||
appWindow.changeWalletMode(0);
|
||||
wizardController.wizardStackView.backTransition = false;
|
||||
wizardController.wizardState = 'wizardModeRemoteNodeWarning';
|
||||
applyWalletMode(0, 'wizardModeRemoteNodeWarning');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -108,9 +118,7 @@ Rectangle {
|
|||
|
||||
onMenuClicked: {
|
||||
if(appWindow.persistentSettings.nettype == 0){
|
||||
appWindow.changeWalletMode(1);
|
||||
wizardController.wizardStackView.backTransition = false;
|
||||
wizardController.wizardState = 'wizardModeBootstrap';
|
||||
applyWalletMode(1, 'wizardModeBootstrap');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -130,12 +138,26 @@ Rectangle {
|
|||
imageIcon: "qrc:///images/local-node-full.png"
|
||||
|
||||
onMenuClicked: {
|
||||
wizardController.wizardStackView.backTransition = false;
|
||||
appWindow.changeWalletMode(2);
|
||||
wizardController.wizardState = 'wizardHome';
|
||||
applyWalletMode(2, 'wizardHome');
|
||||
}
|
||||
}
|
||||
|
||||
WizardHeader {
|
||||
Layout.topMargin: 20
|
||||
title: qsTr("Optional features") + translationManager.emptyString
|
||||
subtitle: qsTr("Select enhanced functionality you would like to enable.") + translationManager.emptyString
|
||||
}
|
||||
|
||||
WizardMenuItem {
|
||||
Layout.topMargin: 20
|
||||
headerText: qsTr("Portable mode") + translationManager.emptyString
|
||||
bodyText: qsTr("Create portable wallets and use them on any PC. Enable if you installed Monero on a USB stick, an external drive, or any other portable storage medium.") + translationManager.emptyString
|
||||
checkbox: true
|
||||
checked: wizardModeSelection1.portable
|
||||
|
||||
onMenuClicked: wizardModeSelection1.portable = !wizardModeSelection1.portable
|
||||
}
|
||||
|
||||
WizardNav {
|
||||
Layout.topMargin: 5
|
||||
btnPrevText: qsTr("Back to menu") + translationManager.emptyString
|
||||
|
@ -144,8 +166,12 @@ Rectangle {
|
|||
autoTransition: false
|
||||
|
||||
onPrevClicked: {
|
||||
wizardController.wizardStackView.backTransition = !wizardController.wizardStackView.backTransition;
|
||||
wizardController.wizardState = wizardController.wizardStackView.backTransition ? 'wizardLanguage' : 'wizardHome';
|
||||
if (wizardController.wizardStackView.backTransition) {
|
||||
applyWalletMode(persistentSettings.walletMode, 'wizardHome');
|
||||
} else {
|
||||
wizardController.wizardStackView.backTransition = true;
|
||||
wizardController.wizardState = 'wizardLanguage';
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue