2019-01-14 00:02:44 +00:00
|
|
|
// Copyright (c) 2014-2019, The Monero Project
|
|
|
|
//
|
|
|
|
// 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
|
2019-01-14 00:02:44 +00:00
|
|
|
import QtQuick.Layouts 1.2
|
|
|
|
import QtQuick.Controls 2.0
|
|
|
|
|
|
|
|
import "../js/Wizard.js" as Wizard
|
|
|
|
import "../components" as MoneroComponents
|
|
|
|
|
2020-04-22 04:32:55 +00:00
|
|
|
RowLayout {
|
2019-01-14 00:02:44 +00:00
|
|
|
id: menuNav
|
|
|
|
property alias progressEnabled: wizardProgress.visible
|
2021-07-05 20:03:12 +00:00
|
|
|
property var btnPrevKeyNavigationBackTab: btnNext
|
|
|
|
property var btnNextKeyNavigationTab: btnPrev
|
2019-01-14 00:02:44 +00:00
|
|
|
property int progressSteps: 0
|
|
|
|
property int progress: 0
|
2019-12-20 05:29:10 +00:00
|
|
|
property bool autoTransition: true
|
2019-01-14 00:02:44 +00:00
|
|
|
property alias btnPrev: btnPrev
|
|
|
|
property alias btnNext: btnNext
|
2021-08-23 16:09:22 +00:00
|
|
|
property alias wizardProgress: wizardProgress
|
2019-01-14 00:02:44 +00:00
|
|
|
property string btnPrevText: qsTr("Previous") + translationManager.emptyString
|
|
|
|
property string btnNextText: qsTr("Next") + translationManager.emptyString
|
2021-08-23 16:09:22 +00:00
|
|
|
Layout.topMargin: 0
|
2019-04-25 19:09:23 +00:00
|
|
|
Layout.preferredHeight: 70
|
2019-01-14 00:02:44 +00:00
|
|
|
Layout.preferredWidth: parent.width
|
|
|
|
|
|
|
|
signal nextClicked;
|
|
|
|
signal prevClicked;
|
|
|
|
|
2019-04-15 02:59:04 +00:00
|
|
|
// internal signals
|
|
|
|
signal m_nextClicked;
|
|
|
|
signal m_prevClicked;
|
|
|
|
|
|
|
|
onM_prevClicked: {
|
2019-12-20 05:29:10 +00:00
|
|
|
if (autoTransition) wizardController.wizardStackView.backTransition = true;
|
2019-04-15 02:59:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
onM_nextClicked: {
|
2019-12-20 05:29:10 +00:00
|
|
|
if (autoTransition) wizardController.wizardStackView.backTransition = false;
|
2019-04-15 02:59:04 +00:00
|
|
|
}
|
|
|
|
|
2019-01-14 00:02:44 +00:00
|
|
|
Rectangle {
|
|
|
|
Layout.preferredHeight: parent.height
|
|
|
|
color: "transparent"
|
|
|
|
|
|
|
|
MoneroComponents.StandardButton {
|
|
|
|
id: btnPrev
|
2021-08-23 16:09:22 +00:00
|
|
|
width: appWindow.width <= 506 ? 45 : appWindow.width <= 660 ? 120 : 180
|
2019-01-14 00:02:44 +00:00
|
|
|
small: true
|
2021-08-23 16:09:22 +00:00
|
|
|
primary: false
|
|
|
|
text: appWindow.width <= 506 ? "<" : menuNav.btnPrevText
|
|
|
|
|
2019-01-14 00:02:44 +00:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
|
|
|
onClicked: {
|
2019-04-15 02:59:04 +00:00
|
|
|
menuNav.m_prevClicked();
|
2019-01-14 00:02:44 +00:00
|
|
|
menuNav.prevClicked();
|
2021-07-05 20:03:12 +00:00
|
|
|
focus = false;
|
2019-01-14 00:02:44 +00:00
|
|
|
}
|
2021-07-05 20:03:12 +00:00
|
|
|
Accessible.role: Accessible.Button
|
|
|
|
Accessible.name: text
|
|
|
|
KeyNavigation.up: btnPrevKeyNavigationBackTab
|
|
|
|
KeyNavigation.backtab: btnPrevKeyNavigationBackTab
|
|
|
|
KeyNavigation.down: wizardProgress.visible ? wizardProgress
|
|
|
|
: btnNext.visible && btnNext.enabled ? btnNext
|
|
|
|
: btnNextKeyNavigationTab
|
|
|
|
KeyNavigation.tab: wizardProgress.visible ? wizardProgress
|
|
|
|
: btnNext.visible && btnNext.enabled ? btnNext
|
|
|
|
: btnNextKeyNavigationTab
|
2019-01-14 00:02:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
// progress dots
|
|
|
|
Layout.preferredHeight: parent.height
|
|
|
|
Layout.fillWidth: true
|
|
|
|
color: "transparent"
|
|
|
|
|
2020-04-22 04:32:55 +00:00
|
|
|
PageIndicator {
|
2019-01-14 00:02:44 +00:00
|
|
|
id: wizardProgress
|
2020-04-22 04:32:55 +00:00
|
|
|
currentIndex: menuNav.progress
|
|
|
|
count: menuNav.progressSteps
|
2019-01-14 00:02:44 +00:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2020-04-22 04:32:55 +00:00
|
|
|
spacing: 25
|
|
|
|
delegate: Rectangle {
|
|
|
|
implicitWidth: 10
|
|
|
|
implicitHeight: 10
|
|
|
|
radius: 10
|
|
|
|
// @TODO: Qt 5.10+ replace === with <=
|
|
|
|
color: index === menuNav.progress ? MoneroComponents.Style.defaultFontColor : MoneroComponents.Style.progressBarBackgroundColor
|
|
|
|
}
|
2021-07-05 20:03:12 +00:00
|
|
|
Accessible.role: Accessible.Indicator
|
|
|
|
Accessible.name: qsTr("Step (%1) of (%2)").arg(currentIndex + 1).arg(count) + translationManager.emptyString
|
|
|
|
KeyNavigation.up: btnPrev
|
|
|
|
KeyNavigation.backtab: btnPrev
|
|
|
|
KeyNavigation.down: btnNext
|
|
|
|
KeyNavigation.tab: btnNext
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
anchors.fill: parent
|
|
|
|
color: wizardProgress.focus ? MoneroComponents.Style.titleBarButtonHoverColor : "transparent"
|
|
|
|
}
|
2019-01-14 00:02:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
Layout.preferredHeight: parent.height
|
|
|
|
color: "transparent"
|
|
|
|
|
|
|
|
MoneroComponents.StandardButton {
|
|
|
|
id: btnNext
|
2021-08-23 16:09:22 +00:00
|
|
|
width: appWindow.width <= 506 ? 45 : appWindow.width <= 660 ? 120 : 180
|
2019-01-14 00:02:44 +00:00
|
|
|
small: true
|
2021-08-23 16:09:22 +00:00
|
|
|
text: appWindow.width <= 506 ? ">" : menuNav.btnNextText
|
2019-01-14 00:02:44 +00:00
|
|
|
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.right: parent.right
|
|
|
|
|
|
|
|
onClicked: {
|
2019-04-15 02:59:04 +00:00
|
|
|
menuNav.m_nextClicked();
|
2019-01-14 00:02:44 +00:00
|
|
|
menuNav.nextClicked();
|
2021-07-05 20:03:12 +00:00
|
|
|
focus = false;
|
2019-01-14 00:02:44 +00:00
|
|
|
}
|
2021-07-05 20:03:12 +00:00
|
|
|
Accessible.role: Accessible.Button
|
|
|
|
Accessible.name: text
|
|
|
|
KeyNavigation.up: wizardProgress.visible ? wizardProgress : btnPrev
|
|
|
|
KeyNavigation.backtab: wizardProgress.visible ? wizardProgress : btnPrev
|
|
|
|
KeyNavigation.down: btnNextKeyNavigationTab
|
|
|
|
KeyNavigation.tab: btnNextKeyNavigationTab
|
2019-01-14 00:02:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|