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
28namespace Ui
29{
30class AddSubtreeDlg;
31}
32
33class GitBase;
34
35/**
36 * @brief AddSubtreeDlg creates a dialog for the user to add a new remote in the current repository.
37 *
38 */
39class AddSubtreeDlg : public QDialog
40{
41 Q_OBJECT
42
43public:
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
81private:
82 Ui::AddSubtreeDlg *ui;
83 QSharedPointer<GitBase> mGit;
84
85 void proposeName();
86};
87