X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=efe91c65c157d61a9b178f090656218e3fddc8d6;hp=02b7ff58e0bbc9133984b50a940791499b624509;hb=89175f57858e885d23dac1401f6f14db20ba9002;hpb=017602cf14ad2fbfffed4a71a613d5eaa87e43c9 diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index 02b7ff58..efe91c65 100644 --- a/src/qtui/mainwin.h +++ b/src/qtui/mainwin.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-09 by the Quassel Project * + * Copyright (C) 2005-2016 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,14 +15,17 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#ifndef MAINWIN_H_ -#define MAINWIN_H_ +#pragma once -#ifdef HAVE_KDE +#include + +#ifdef HAVE_KDE4 # include +#elif defined HAVE_KF5 +# include #else # include #endif @@ -35,6 +38,7 @@ class ActionCollection; class BufferHotListFilter; class BufferView; class BufferViewConfig; +class ChatMonitorView; class ClientBufferViewConfig; class CoreAccount; class CoreConnectionStatusWidget; @@ -44,7 +48,6 @@ class InputWidget; class MsgProcessorStatusWidget; class NickListWidget; class SystemTray; -class ChatMonitorView; class TopicWidget; class QMenu; @@ -56,13 +59,13 @@ class KHelpMenu; //!\brief The main window of Quassel's QtUi. class MainWin #ifdef HAVE_KDE -: public KMainWindow { + : public KMainWindow { #else -: public QMainWindow { + : public QMainWindow { #endif - Q_OBJECT + Q_OBJECT - public: +public: MainWin(QWidget *parent = 0); virtual ~MainWin(); @@ -70,6 +73,7 @@ class MainWin void addBufferView(ClientBufferViewConfig *config); BufferView *allBuffersView() const; + BufferView *activeBufferView() const; inline BufferWidget *bufferWidget() const { return _bufferWidget; } inline SystemTray *systemTray() const { return _systemTray; } @@ -82,24 +86,32 @@ class MainWin void saveStateToSettings(UiSettings &); void restoreStateFromSettings(UiSettings &); - public slots: + // We need to override this to add the show/hide menu bar option + virtual QMenu *createPopupMenu(); + +public slots: void showStatusBarMessage(const QString &message); + void hideCurrentBuffer(); + void nextBufferView(); //!< Activate the next bufferview + void previousBufferView(); //!< Activate the previous bufferview + void nextBuffer(); + void previousBuffer(); //! Quit application void quit(); - protected: +protected: void closeEvent(QCloseEvent *event); void moveEvent(QMoveEvent *event); void resizeEvent(QResizeEvent *event); - protected slots: +protected slots: void connectedToCore(); void setConnectedState(); void disconnectedFromCore(); void setDisconnectedState(); - private slots: +private slots: void addBufferView(int bufferViewConfigId); void awayLogDestroyed(); void removeBufferView(int bufferViewConfigId); @@ -115,6 +127,9 @@ class MainWin void showNotificationsDlg(); void showIgnoreList(QString newRule = QString()); void showShortcutsDlg(); + void showPasswordChangeDlg(); + void showNewTransferDlg(const QUuid &transferId); + void onFullScreenToggled(); void handleCoreConnectionError(const QString &errorMsg); void userAuthenticationRequired(CoreAccount *, bool *valid, const QString &errorMessage); @@ -128,6 +143,7 @@ class MainWin void on_actionConfigureViews_triggered(); void on_actionLockLayout_toggled(bool lock); void on_jumpHotBuffer_triggered(); + void on_bufferSearch_triggered(); void on_actionDebugNetworkModel_triggered(); void on_actionDebugBufferViewOverlay_triggered(); void on_actionDebugMessageModel_triggered(); @@ -144,17 +160,21 @@ class MainWin void saveMenuBarStatus(bool enabled); void saveStatusBarStatus(bool enabled); + void saveMainToolBarStatus(bool enabled); void loadLayout(); void saveLayout(); void bufferViewToggled(bool enabled); + void bufferViewVisibilityChanged(bool visible); + void changeActiveBufferView(bool backwards); + void changeActiveBufferView(int bufferViewId); - signals: +signals: void connectToCore(const QVariantMap &connInfo); void disconnectFromCore(); - private: +private: #ifdef HAVE_KDE KHelpMenu *_kHelpMenu; #endif @@ -172,6 +192,7 @@ class MainWin void setupChatMonitor(); void setupInputWidget(); void setupTopicWidget(); + void setupViewMenuTail(); void setupStatusBar(); void setupSystray(); void setupTitleSetter(); @@ -188,6 +209,7 @@ class MainWin ChatMonitorView *_chatMonitorView; TopicWidget *_topicWidget; + QAction *_fullScreenAction; QMenu *_fileMenu, *_networksMenu, *_viewMenu, *_bufferViewsMenu, *_settingsMenu, *_helpMenu, *_helpDebugMenu; QMenu *_toolbarMenu; QToolBar *_mainToolBar, *_chatViewToolBar, *_nickToolBar; @@ -201,8 +223,9 @@ class MainWin BufferHotListFilter *_bufferHotList; QHash _jumpKeyMap; + int _activeBufferViewIndex; + + bool _aboutToQuit; //closeEvent can occur multiple times on OSX friend class QtUi; }; - -#endif