X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=9807550c2d7daff5b1c776b3c617742241ccab5a;hp=4d168253e2909db7eb141bc755a105ad05d0811e;hb=3efffa2c3f687b21c8040e9a7ee3830e8f539abf;hpb=ee7d56f3abdb6ee4ce6c79ddea0142407b4e9e74 diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index 4d168253..9807550c 100644 --- a/src/qtui/mainwin.h +++ b/src/qtui/mainwin.h @@ -27,22 +27,28 @@ # include #endif -#include +#ifdef Q_WS_WIN +# include +#endif #include "qtui.h" -#include "sessionsettings.h" #include "titlesetter.h" +#include "uisettings.h" class ActionCollection; +class BufferHotListFilter; class BufferView; class BufferViewConfig; class ClientBufferViewConfig; +class CoreAccount; +class CoreConnectionStatusWidget; class BufferViewDock; class BufferWidget; class InputWidget; class MsgProcessorStatusWidget; class NickListWidget; -class SystemTrayIcon; +class SystemTray; +class ChatMonitorView; class QMenu; class QLabel; @@ -68,51 +74,79 @@ class MainWin void addBufferView(ClientBufferViewConfig *config); BufferView *allBuffersView() const; - inline QSystemTrayIcon *systemTrayIcon() const; + inline BufferWidget *bufferWidget() const { return _bufferWidget; } + +#ifndef QT_NO_SYSTEMTRAYICON + inline SystemTray *systemTray() const { return _systemTray; } +#endif - virtual bool event(QEvent *event); + bool event(QEvent *event); static void flagRemoteCoreOnly(QObject *object) { object->setProperty("REMOTE_CORE_ONLY", true); } static bool isRemoteCoreOnly(QObject *object) { return object->property("REMOTE_CORE_ONLY").toBool(); } + void saveStateToSettings(UiSettings &); + void restoreStateFromSettings(UiSettings &); + public slots: - void saveStateToSession(const QString &sessionId); - void saveStateToSessionSettings(SessionSettings &s); void showStatusBarMessage(const QString &message); +#ifndef QT_NO_SYSTEMTRAYICON + void toggleMinimizedToTray(); +#endif + + //! Bring window to front and focus it + void forceActivated(); + + //! Quit application + void quit(); + protected: void closeEvent(QCloseEvent *event); - virtual void changeEvent(QEvent *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(); - void systrayActivated(QSystemTrayIcon::ActivationReason); private slots: void addBufferView(int bufferViewConfigId); void awayLogDestroyed(); void removeBufferView(int bufferViewConfigId); + void currentBufferChanged(BufferId); 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(); #endif + 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); + void on_jumpHotBuffer_triggered(); void on_actionDebugNetworkModel_triggered(); + void on_actionDebugBufferViewOverlay_triggered(); void on_actionDebugMessageModel_triggered(); + void on_actionDebugHotList_triggered(); void on_actionDebugLog_triggered(); void clientNetworkCreated(NetworkId); @@ -120,11 +154,14 @@ class MainWin void clientNetworkUpdated(); void connectOrDisconnectFromNet(); + void saveMenuBarStatus(bool enabled); void saveStatusBarStatus(bool enabled); void loadLayout(); void saveLayout(); + void bufferViewToggled(bool enabled); + signals: void connectToCore(const QVariantMap &connInfo); void disconnectFromCore(); @@ -134,10 +171,8 @@ class MainWin KHelpMenu *_kHelpMenu; #endif - QMenu *systrayMenu; - QLabel *coreLagLabel; - QLabel *sslLabel; - MsgProcessorStatusWidget *msgProcessorStatusWidget; + MsgProcessorStatusWidget *_msgProcessorStatusWidget; + CoreConnectionStatusWidget *_coreConnectionStatusWidget; TitleSetter _titleSetter; @@ -152,29 +187,40 @@ class MainWin void setupSystray(); void setupTitleSetter(); void setupToolBars(); + void setupHotList(); void updateIcon(); - void hideToTray(); - void toggleMinimizedToTray(); void enableMenus(); - QSystemTrayIcon *_trayIcon; +#ifndef QT_NO_SYSTEMTRAYICON + void hideToTray(); + SystemTray *_systemTray; +#endif QList _bufferViews; BufferWidget *_bufferWidget; NickListWidget *_nickListWidget; InputWidget *_inputWidget; + ChatMonitorView *_chatMonitorView; QMenu *_fileMenu, *_networksMenu, *_viewMenu, *_bufferViewsMenu, *_settingsMenu, *_helpMenu, *_helpDebugMenu; QMenu *_toolbarMenu; QToolBar *_mainToolBar, *_chatViewToolBar, *_nickToolBar; QWidget *_awayLog; + + bool _layoutLoaded; + + 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; + friend class QtUi; }; -QSystemTrayIcon *MainWin::systemTrayIcon() const { - return _trayIcon; -} - #endif