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 <QMenu>
27
28class GitBase;
29
30/*!
31 \brief The StashesContextMenu shows the different options that can be performed to the stashes.
32
33*/
34class StashesContextMenu : public QMenu
35{
36 Q_OBJECT
37
38signals:
39 /*!
40 \brief Signal triggered if a stash was removed.
41
42 */
43 void signalContentRemoved();
44 /*!
45 \brief Signal triggered when the main GitQlient UI needs to be updated because of a change in the stashes.
46
47 */
48 void signalUpdateView();
49
50public:
51 /*!
52 \brief Default constructor.
53
54 \param git The git object to perform Git operations.
55 \param stashId The stash ID that will be used to perform operations into.
56 \param parent The parent widget if needed.
57 */
58 explicit StashesContextMenu(const QSharedPointer<GitBase> &git, const QString &stashId, QWidget *parent = nullptr);
59
60private:
61 QSharedPointer<GitBase> mGit;
62 QString mStashId;
63
64 /*!
65 \brief Drops a stash.
66
67 */
68 void drop();
69 /*!
70 \brief Clears the stash.
71
72 */
73 void clear();
74 /*!
75 \brief Creates a branch where the stash is located.
76
77 */
78 void branch();
79};
80