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 <QDialog> |
27 | |
28 | namespace Ui |
29 | { |
30 | class AddSubtreeDlg; |
31 | } |
32 | |
33 | class GitBase; |
34 | |
35 | /** |
36 | * @brief AddSubtreeDlg creates a dialog for the user to add a new remote in the current repository. |
37 | * |
38 | */ |
39 | class AddSubtreeDlg : public QDialog |
40 | { |
41 | Q_OBJECT |
42 | |
43 | public: |
44 | /** |
45 | * @brief Default constructor. |
46 | * |
47 | * @param git The git object to execute Git commands. |
48 | * @param parent The parent widget if needed. |
49 | */ |
50 | explicit AddSubtreeDlg(const QSharedPointer<GitBase> &git, QWidget *parent = nullptr); |
51 | |
52 | /** |
53 | * @brief AddSubtreeDlg Overloaded constructor used to configure an existing subtree. |
54 | * @param prefix The existing prefix. |
55 | * @param git The git object to execute Git commands. |
56 | * @param parent The parent widget if needed. |
57 | */ |
58 | explicit AddSubtreeDlg(const QString &prefix, const QSharedPointer<GitBase> &git, QWidget *parent = nullptr); |
59 | |
60 | /** |
61 | * @brief AddSubtreeDlg Overloaded constructor used to configure an existing subtree. |
62 | * @param prefix The existing prefix. |
63 | * @param git The git object to execute Git commands. |
64 | * @param parent The parent widget if needed. |
65 | */ |
66 | explicit AddSubtreeDlg(const QString &prefix, const QString &url, const QString &reference, |
67 | const QSharedPointer<GitBase> &git, QWidget *parent = nullptr); |
68 | /** |
69 | * @brief Destructor. |
70 | * |
71 | */ |
72 | ~AddSubtreeDlg() override; |
73 | |
74 | /** |
75 | * @brief When the user clicks the Ok/Accept button, it triggers the \ref accept method that validates the data and |
76 | * tries to perform the Git action. If it's successfully executed, it will close the dialog. |
77 | * |
78 | */ |
79 | void accept() override; |
80 | |
81 | private: |
82 | Ui::AddSubtreeDlg *ui; |
83 | QSharedPointer<GitBase> mGit; |
84 | |
85 | void proposeName(); |
86 | }; |
87 | |