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 | |
29 | class GitCache; |
30 | class GitBase; |
31 | class GitServerCache; |
32 | class IssueDetailedView; |
33 | class QPushButton; |
34 | class QStackedLayout; |
35 | //class CreateIssueDlg; |
36 | class CreatePullRequestDlg; |
37 | |
38 | namespace GitServer |
39 | { |
40 | class IRestApi; |
41 | struct Issue; |
42 | } |
43 | |
44 | class GitServerWidget : public QFrame |
45 | { |
46 | Q_OBJECT |
47 | |
48 | signals: |
49 | void openDiff(const QString &sha); |
50 | |
51 | public: |
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 | |
76 | private: |
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 | |