blob: 4d9072209fff616eac884eb043f8617d2dcef51c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
/****************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
****************************************************************************/
#pragma once
#include "core_global.h"
#include <utils/styledbar.h>
#include <functional>
QT_BEGIN_NAMESPACE
class QMenu;
QT_END_NAMESPACE
namespace Core {
class IEditor;
class IDocument;
struct EditorToolBarPrivate;
/**
* Fakes an IEditor-like toolbar for design mode widgets such as Qt Designer and Bauhaus.
* Creates a combobox for open files and lock and close buttons on the right.
*/
class CORE_EXPORT EditorToolBar : public Utils::StyledBar
{
Q_OBJECT
public:
explicit EditorToolBar(QWidget *parent = nullptr);
~EditorToolBar() override;
using MenuProvider = std::function<void(QMenu*)>;
enum ToolbarCreationFlags { FlagsNone = 0, FlagsStandalone = 1 };
/**
* Adds an editor whose state is listened to, so that the toolbar can be kept up to date
* with regards to locked status and tooltips.
*/
void addEditor(IEditor *editor);
/**
* Sets the editor and adds its custom toolbar to the widget.
*/
void setCurrentEditor(IEditor *editor);
void setToolbarCreationFlags(ToolbarCreationFlags flags);
void setMenuProvider(const MenuProvider &provider);
/**
* Adds a toolbar to the widget and sets invisible by default.
*/
void addCenterToolBar(QWidget *toolBar);
void setNavigationVisible(bool isVisible);
void setCanGoBack(bool canGoBack);
void setCanGoForward(bool canGoForward);
void removeToolbarForEditor(IEditor *editor);
void setCloseSplitEnabled(bool enable);
void setCloseSplitIcon(const QIcon &icon);
signals:
void closeClicked();
void goBackClicked();
void goForwardClicked();
void horizontalSplitClicked();
void verticalSplitClicked();
void splitNewWindowClicked();
void closeSplitClicked();
void listSelectionActivated(int row);
void currentDocumentMoved();
protected:
bool eventFilter(QObject *obj, QEvent *event) override;
private:
static void changeActiveEditor(int row);
static void makeEditorWritable();
void checkDocumentStatus(IDocument *document);
void closeEditor();
void updateActionShortcuts();
void updateDocumentStatus(IDocument *document);
void fillListContextMenu(QMenu *menu);
void updateToolBar(QWidget *toolBar);
EditorToolBarPrivate *d;
};
} // namespace Core
|