1 | #pragma once |
2 | |
3 | /**************************************************************************************** |
4 | ** GitQlient is an application to manage and operate one or several Git repositories. With |
5 | ** GitQlient you will be able to add commits, branches and manage all the options Git provides. |
6 | ** Copyright (C) 2021 Francesc Martinez |
7 | ** |
8 | ** LinkedIn: www.linkedin.com/in/cescmm/ |
9 | ** Web: www.francescmm.com |
10 | ** |
11 | ** This program is free software; you can redistribute it and/or |
12 | ** modify it under the terms of the GNU Lesser General Public |
13 | ** License as published by the Free Software Foundation; either |
14 | ** version 2 of the License, or (at your option) any later version. |
15 | ** |
16 | ** This program is distributed in the hope that it will be useful, |
17 | ** but WITHOUT ANY WARRANTY; without even the implied warranty of |
18 | ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
19 | ** Lesser General Public License for more details. |
20 | ** |
21 | ** You should have received a copy of the GNU Lesser General Public |
22 | ** License along with this library; if not, write to the Free Software |
23 | ** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
24 | ***************************************************************************************/ |
25 | |
26 | #include <QProgressDialog> |
27 | |
28 | /** |
29 | * @brief This is a re-implementation of the QProgressDialog to better suite styles and special behaviour flags. |
30 | * |
31 | * @class ProgressDlg ProgressDlg.h "ProgressDlg.h" |
32 | */ |
33 | class ProgressDlg : public QProgressDialog |
34 | { |
35 | public: |
36 | /** |
37 | * @brief Default constructor of the class. |
38 | * |
39 | * @param labelText The text that will be shown. |
40 | * @param cancelButtonText Cancel button text. |
41 | * @param minimum Minimum value. |
42 | * @param maximum Maximum value. |
43 | * @param autoReset Tells the progress dialog if it should automatically reset. |
44 | * @param autoClose Tells the progress dialog if it should automatically close. |
45 | */ |
46 | explicit ProgressDlg(const QString &labelText, const QString &cancelButtonText, int maximum, bool autoClose); |
47 | |
48 | /** |
49 | * @brief Detects the press event to avoid closing the dialog when the Esc key is pressed. |
50 | * |
51 | * @param e The press event |
52 | */ |
53 | void keyPressEvent(QKeyEvent *e) override; |
54 | /** |
55 | * @brief Detects the close event to filter the close event and only close the dialog if the user clicked on the |
56 | * button. |
57 | * |
58 | * @param e The close event |
59 | */ |
60 | void closeEvent(QCloseEvent *e) override; |
61 | /** |
62 | * @brief Closes the dialog by user's action. |
63 | */ |
64 | void close(); |
65 | |
66 | private: |
67 | bool mPrepareToClose = false; |
68 | }; |
69 | |