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 <QFrame>
27#include <ConfigData.h>
28
29class GitCache;
30class GitBase;
31class GitServerCache;
32class IssueDetailedView;
33class QPushButton;
34class QStackedLayout;
35//class CreateIssueDlg;
36class CreatePullRequestDlg;
37
38namespace GitServer
39{
40class IRestApi;
41struct Issue;
42}
43
44class GitServerWidget : public QFrame
45{
46 Q_OBJECT
47
48signals:
49 void openDiff(const QString &sha);
50
51public:
52 explicit GitServerWidget(const QSharedPointer<GitCache> &cache, const QSharedPointer<GitBase> &git,
53 const QSharedPointer<GitServerCache> &gitServerCache, QWidget *parent = nullptr);
54
55 ~GitServerWidget();
56
57 /**
58 * @brief configure Configures the widget by showing the config dialog or the full content if it was already
59 * configured.
60 * @return Returns true if configured, otherwise false.
61 */
62 bool configure(const GitServer::ConfigData &config = GitServer::ConfigData());
63
64 /**
65 * @brief isConfigured Returns the current state of the widget
66 * @return True if configured, otherwise false.
67 */
68 bool isConfigured() const { return mConfigured; }
69
70 /**
71 * @brief openPullRequest The method opens the PR view directly.
72 * @param prNumber The PR number.
73 */
74 void openPullRequest(int prNumber);
75
76private:
77 QSharedPointer<GitCache> mCache;
78 QSharedPointer<GitBase> mGit;
79 QSharedPointer<GitServerCache> mGitServerCache;
80 QStackedLayout *mStackedLayout = nullptr;
81 IssueDetailedView *mDetailedView = nullptr;
82 QFrame *mGeneralView = nullptr;
83// CreateIssueDlg *mCreateIssueView = nullptr;
84 CreatePullRequestDlg *mCreatePrView = nullptr;
85 QPushButton *mOldIssue = nullptr;
86 QPushButton *mOldPr = nullptr;
87 QPushButton *mRefresh = nullptr;
88 bool mConfigured = false;
89
90 /**
91 * @brief createWidget Creates all the contents of the GitServerWidget.
92 */
93 void createWidget();
94};
95