X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=49b49d70a5f33b1c4419aeea30e5e8ec37b0be5c;hp=bee2cd278b4ea59a09e41ebbabc13c0c1295d750;hb=9f33f6e471dedbefe7bbe336a40312894628afe1;hpb=39cf1e00fdc1108a393103433b3f5854b6df673e diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index bee2cd27..49b49d70 100644 --- a/src/qtui/mainwin.h +++ b/src/qtui/mainwin.h @@ -27,12 +27,6 @@ # include #endif -#ifdef Q_WS_WIN -# include -#endif - -#include - #include "qtui.h" #include "titlesetter.h" #include "uisettings.h" @@ -42,12 +36,16 @@ class BufferHotListFilter; class BufferView; class BufferViewConfig; class ClientBufferViewConfig; +class CoreAccount; +class CoreConnectionStatusWidget; class BufferViewDock; class BufferWidget; class InputWidget; class MsgProcessorStatusWidget; class NickListWidget; class SystemTray; +class ChatMonitorView; +class TopicWidget; class QMenu; class QLabel; @@ -72,10 +70,10 @@ class MainWin void addBufferView(ClientBufferViewConfig *config); BufferView *allBuffersView() const; + BufferView *activeBufferView() const; - BufferWidget *bufferWidget() const { return _bufferWidget; } - - inline SystemTray *systemTray() const; + inline BufferWidget *bufferWidget() const { return _bufferWidget; } + inline SystemTray *systemTray() const { return _systemTray; } bool event(QEvent *event); @@ -87,25 +85,23 @@ class MainWin public slots: void showStatusBarMessage(const QString &message); - - void toggleMinimizedToTray(); - - //! Bring window to front and focus it - void forceActivated(); + void hideCurrentBuffer(); + void nextBufferView(); //!< Activate the next bufferview + void previousBufferView(); //!< Activate the previous bufferview + void nextBuffer(); + void previousBuffer(); //! Quit application void quit(); protected: void closeEvent(QCloseEvent *event); - void changeEvent(QEvent *event); void moveEvent(QMoveEvent *event); void resizeEvent(QResizeEvent *event); protected slots: void connectedToCore(); void setConnectedState(); - void updateLagIndicator(int lag = -1); void disconnectedFromCore(); void setDisconnectedState(); @@ -117,16 +113,24 @@ class MainWin void messagesInserted(const QModelIndex &parent, int start, int end); void showAboutDlg(); void showChannelList(NetworkId netId = NetworkId()); - void startInternalCore(); - void showCoreConnectionDlg(bool autoConnect = false); + void showCoreConnectionDlg(); + void showCoreConfigWizard(const QVariantList &); void showCoreInfoDlg(); void showAwayLog(); void showSettingsDlg(); void showNotificationsDlg(); void showIgnoreList(QString newRule = QString()); -#ifdef HAVE_KDE void showShortcutsDlg(); + void toggleFullscreen(); + + void handleCoreConnectionError(const QString &errorMsg); + void userAuthenticationRequired(CoreAccount *, bool *valid, const QString &errorMessage); + void handleNoSslInClient(bool *accepted); + void handleNoSslInCore(bool *accepted); +#ifdef HAVE_SSL + void handleSslErrors(const QSslSocket *socket, bool *accepted, bool *permanently); #endif + void on_actionConfigureNetworks_triggered(); void on_actionConfigureViews_triggered(); void on_actionLockLayout_toggled(bool lock); @@ -137,6 +141,9 @@ class MainWin void on_actionDebugHotList_triggered(); void on_actionDebugLog_triggered(); + void bindJumpKey(); + void onJumpKey(); + void clientNetworkCreated(NetworkId); void clientNetworkRemoved(NetworkId); void clientNetworkUpdated(); @@ -149,6 +156,9 @@ class MainWin void saveLayout(); void bufferViewToggled(bool enabled); + void bufferViewVisibilityChanged(bool visible); + void changeActiveBufferView(bool backwards); + void changeActiveBufferView(int bufferViewId); signals: void connectToCore(const QVariantMap &connInfo); @@ -159,9 +169,9 @@ class MainWin KHelpMenu *_kHelpMenu; #endif - QLabel *coreLagLabel; - QLabel *sslLabel; - MsgProcessorStatusWidget *msgProcessorStatusWidget; + MsgProcessorStatusWidget *_msgProcessorStatusWidget; + CoreConnectionStatusWidget *_coreConnectionStatusWidget; + SystemTray *_systemTray; TitleSetter _titleSetter; @@ -172,6 +182,7 @@ class MainWin void setupChatMonitor(); void setupInputWidget(); void setupTopicWidget(); + void setupViewMenuTail(); void setupStatusBar(); void setupSystray(); void setupTitleSetter(); @@ -181,14 +192,12 @@ class MainWin void updateIcon(); void enableMenus(); - void hideToTray(); - - SystemTray *_systemTray; - QList _bufferViews; BufferWidget *_bufferWidget; NickListWidget *_nickListWidget; InputWidget *_inputWidget; + ChatMonitorView *_chatMonitorView; + TopicWidget *_topicWidget; QMenu *_fileMenu, *_networksMenu, *_viewMenu, *_bufferViewsMenu, *_settingsMenu, *_helpMenu, *_helpDebugMenu; QMenu *_toolbarMenu; @@ -201,17 +210,11 @@ class MainWin QSize _normalSize; //!< Size of the non-maximized window QPoint _normalPos; //!< Position of the non-maximized window -#ifdef Q_WS_WIN - DWORD dwTickCount; -#endif - BufferHotListFilter *_bufferHotList; + QHash _jumpKeyMap; + int _activeBufferViewIndex; friend class QtUi; }; -SystemTray *MainWin::systemTray() const { - return _systemTray; -} - #endif