-
Notifications
You must be signed in to change notification settings - Fork 671
/
Copy pathnavigation.h
76 lines (62 loc) · 2.19 KB
/
navigation.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*
* Copyright (C) Fabian Müller <fmueller@owncloud.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* for more details.
*/
#pragma once
#include "enums.h"
#include "gui/qmlutils.h"
#include <QHBoxLayout>
#include <QMap>
#include <QRadioButton>
#include <QString>
#include <QWidget>
namespace OCC::Wizard {
/**
* Provides a radio button based quick navigation on the wizard's bottom side.
*/
class Navigation : public QmlUtils::OCQuickWidget
{
Q_OBJECT
Q_PROPERTY(QList<SetupWizardState> states READ states NOTIFY statesChanged)
Q_PROPERTY(SetupWizardState activeState READ activeState WRITE setActiveState NOTIFY activeStatesChanged)
QML_ELEMENT
QML_UNCREATABLE("C++")
public:
explicit Navigation(QWidget *parent = nullptr);
/**
* Set or replace entries in the navigation.
* This method creates the corresponding buttons.
* @param newEntries ordered list of wizard states to be rendered in the navigation
*/
void setStates(const QList<SetupWizardState> &newEntries);
QList<SetupWizardState> states() const;
/**
* Change to another state. Applies changes to hosted UI elements (e.g., disables buttons, )
*/
void setActiveState(SetupWizardState activeState);
SetupWizardState activeState() const;
Q_INVOKABLE QString stateDisplayName(SetupWizardState state) const;
Q_SIGNALS:
/**
* Emitted when a state is clicked.
* This event is only emitted for previous states.
* @param clickedState state the user wants to switch to
*/
void stateClicked(SetupWizardState clickedState);
void statesChanged();
void activeStatesChanged();
private:
QList<SetupWizardState> _states;
SetupWizardState _activeState = SetupWizardState::FirstState;
bool _enabled = true;
};
}