-
Notifications
You must be signed in to change notification settings - Fork 1
/
PomodoroStatistics.h
116 lines (94 loc) · 2.76 KB
/
PomodoroStatistics.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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
File: PomodoroStatistics.h
Created on: 23/02/2014
Author: Felix de las Pozas Alvarez
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 3 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.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef POMODORO_STATISTICS_H_
#define POMODORO_STATISTICS_H_
// Project
#include "Pomodoro.h"
#include "ui_PomodoroStatistics.h"
// Qt
#include <QDialog>
#include <QTimeLine>
#include <QTimer>
// C++
#include <memory>
class QObject;
class QEvent;
/** \class PomodoroStatistics
* \brief Pomodoro statistics and control dialog.
*
*/
class PomodoroStatistics
: public QDialog
, public Ui_PomodoroStatistics
{
Q_OBJECT
public:
/** \brief PomodoroStatistics class constructor.
* \param[in] pomodoro pomodoro smart pointer.
* \param[in] parent raw pointer of the parent of this object.
* \param[in] f Window flags.
*
*/
explicit PomodoroStatistics(std::shared_ptr<Pomodoro> pomodoro, QWidget *parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags());
/** \brief PomodoroStatistics class virtual destructor.
*
*/
virtual ~PomodoroStatistics();
enum class Result : char { None = 1, Stop = 2, Continue = 3};
/** \brief Returns the result of the dialog after closing.
*
*/
Result getResult() const;
private slots:
/** \brief Updates the dialog with the pomodoro values.
*
*/
void updateGUI();
/** \brief Invalidates current pomodoro unit.
*
*/
void invalidate();
/** \brief Stops the pomodoro and quits the dialog.
*
*/
void stop();
/** \brief Closes the dialog.
*
*/
void resume();
/** \brief Pauses the pomodoro.
*
*/
void pause();
/** \brief Updates the elapsed time in the dialog.
*
*/
void updateElapsedTime();
/** \brief Updates the pomodoro's task.
*
*/
void updateTask();
private:
/** \brief Updates the progress bar.
*
*/
void updateProgress();
std::shared_ptr<Pomodoro> m_pomodoro; /** pomodoro object. */
QTimer m_timer; /** update timer. */
bool m_paused; /** true if pomodoro is paused, false otherwise. */
Result m_result; /** */
};
#endif // POMODORO_STATISTICS_H_