X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=efe91c65c157d61a9b178f090656218e3fddc8d6;hp=bdff05d12876bc671230b7a872f5b1bf2218435d;hb=89175f57858e885d23dac1401f6f14db20ba9002;hpb=56288a13972bf8466b57c9d5d1ec382fc7e287cc diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index bdff05d1..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(); @@ -83,26 +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); @@ -118,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); @@ -131,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(); @@ -147,6 +160,7 @@ class MainWin void saveMenuBarStatus(bool enabled); void saveStatusBarStatus(bool enabled); + void saveMainToolBarStatus(bool enabled); void loadLayout(); void saveLayout(); @@ -154,12 +168,13 @@ class MainWin 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 @@ -177,6 +192,7 @@ class MainWin void setupChatMonitor(); void setupInputWidget(); void setupTopicWidget(); + void setupViewMenuTail(); void setupStatusBar(); void setupSystray(); void setupTitleSetter(); @@ -193,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; @@ -208,7 +225,7 @@ class MainWin QHash _jumpKeyMap; int _activeBufferViewIndex; + bool _aboutToQuit; //closeEvent can occur multiple times on OSX + friend class QtUi; }; - -#endif