X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=76097b497d658837f13f759723533883ec7d719c;hp=aa8aa94682d555e2307881bf410c7b5c34a0330b;hb=HEAD;hpb=e9a02be2a4f3b8bb19d262b2b19f7dd0bfa10463 diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index aa8aa946..8278a809 100644 --- a/src/qtui/mainwin.h +++ b/src/qtui/mainwin.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2022 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -22,12 +22,10 @@ #include -#ifdef HAVE_KDE4 -# include -#elif defined HAVE_KF5 -# include +#ifdef HAVE_KF5 +# include #else -# include +# include #endif #include "qtui.h" @@ -50,8 +48,9 @@ class NickListWidget; class SystemTray; class TopicWidget; -class QMenu; class QLabel; +class QMenu; +class QMessageBox; class QToolBar; class KHelpMenu; @@ -59,51 +58,53 @@ 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 public: - MainWin(QWidget *parent = 0); - virtual ~MainWin(); + MainWin(QWidget* parent = nullptr); void init(); - void addBufferView(ClientBufferViewConfig *config); - BufferView *allBuffersView() const; - BufferView *activeBufferView() const; + void addBufferView(ClientBufferViewConfig* config); + BufferView* allBuffersView() const; + BufferView* activeBufferView() const; - inline BufferWidget *bufferWidget() const { return _bufferWidget; } - inline SystemTray *systemTray() const { return _systemTray; } + inline BufferWidget* bufferWidget() const { return _bufferWidget; } + inline SystemTray* systemTray() const { return _systemTray; } - bool event(QEvent *event); + bool event(QEvent* event) override; - static void flagRemoteCoreOnly(QObject *object) { object->setProperty("REMOTE_CORE_ONLY", true); } - static bool isRemoteCoreOnly(QObject *object) { return object->property("REMOTE_CORE_ONLY").toBool(); } + 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 &); + void saveStateToSettings(UiSettings&); + void restoreStateFromSettings(UiSettings&); // We need to override this to add the show/hide menu bar option - virtual QMenu *createPopupMenu(); + QMenu* createPopupMenu() override; public slots: - void showStatusBarMessage(const QString &message); + void showStatusBarMessage(const QString& message); void hideCurrentBuffer(); - void nextBufferView(); //!< Activate the next bufferview - void previousBufferView(); //!< Activate the previous bufferview + void nextBufferView(); //!< Activate the next bufferview + void previousBufferView(); //!< Activate the previous bufferview void nextBuffer(); void previousBuffer(); - //! Quit application - void quit(); + void showMigrationWarning(bool show); + + void onExitRequested(const QString& reason); protected: - void closeEvent(QCloseEvent *event); - void moveEvent(QMoveEvent *event); - void resizeEvent(QResizeEvent *event); + void closeEvent(QCloseEvent* event) override; + void moveEvent(QMoveEvent* event) override; + void resizeEvent(QResizeEvent* event) override; protected slots: void connectedToCore(); @@ -116,12 +117,21 @@ private slots: void awayLogDestroyed(); void removeBufferView(int bufferViewConfigId); void currentBufferChanged(BufferId); - void messagesInserted(const QModelIndex &parent, int start, int end); + void messagesInserted(const QModelIndex& parent, int start, int end); void showAboutDlg(); - void showChannelList(NetworkId netId = NetworkId()); + + /** + * Show the channel list dialog for the network, optionally searching by channel name + * + * @param networkId Network ID for associated network + * @param channelFilters Partial channel name to search for, or empty to show all + * @param listImmediately If true, immediately list channels, otherwise just show dialog + */ + void showChannelList(NetworkId netId = {}, const QString& channelFilters = {}, bool listImmediately = false); + void showNetworkConfig(NetworkId netId = NetworkId()); void showCoreConnectionDlg(); - void showCoreConfigWizard(const QVariantList &, const QVariantList &); + void showCoreConfigWizard(const QVariantList&, const QVariantList&); void showCoreInfoDlg(); void showAwayLog(); void showSettingsDlg(); @@ -129,70 +139,78 @@ private slots: void showIgnoreList(QString newRule = QString()); void showShortcutsDlg(); void showPasswordChangeDlg(); - void showNewTransferDlg(const QUuid &transferId); + void showNewTransferDlg(const QUuid& transferId); void onFullScreenToggled(); - 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 doAutoConnect(); - void on_actionConfigureNetworks_triggered(); - void on_actionConfigureViews_triggered(); - void on_actionLockLayout_toggled(bool lock); + void handleCoreConnectionError(const QString& errorMsg); + void userAuthenticationRequired(CoreAccount*, bool* valid, const QString& errorMessage); + void handleNoSslInClient(bool* accepted); + void handleNoSslInCore(bool* accepted); + void handleSslErrors(const QSslSocket* socket, bool* accepted, bool* permanently); + + void onConfigureNetworksTriggered(); + void onConfigureViewsTriggered(); + void onLockLayoutToggled(bool lock); /** * Apply the active color to the input widget selected or typed text * * @seealso InputWidget::applyFormatActiveColor() */ - void on_inputFormatApplyColor_triggered(); + void onFormatApplyColorTriggered(); /** * Apply the active fill color to the input widget selected or typed text background * * @seealso InputWidget::applyFormatActiveColorFill() */ - void on_inputFormatApplyColorFill_triggered(); + void onFormatApplyColorFillTriggered(); /** * Toggle the boldness of the input widget selected or typed text * * @seealso InputWidget::toggleFormatBold() */ - void on_inputFormatBold_triggered(); + void onFormatBoldTriggered(); /** * Toggle the italicness of the input widget selected or typed text * * @seealso InputWidget::toggleFormatItalic() */ - void on_inputFormatItalic_triggered(); + void onFormatItalicTriggered(); /** * Toggle the underlining of the input widget selected or typed text * * @seealso InputWidget::toggleFormatUnderline() */ - void on_inputFormatUnderline_triggered(); + void onFormatUnderlineTriggered(); + + /** + * Toggle the strikethrough of the input widget selected or typed text + * + * @seealso InputWidget::toggleFormatStrikethrough() + */ + void onFormatStrikethroughTriggered(); /** * Clear the formatting of the input widget selected or typed text * * @seealso InputWidget::clearFormat() */ - void on_inputFormatClear_triggered(); + void onFormatClearTriggered(); - void on_jumpHotBuffer_triggered(); - void on_bufferSearch_triggered(); - void on_actionDebugNetworkModel_triggered(); - void on_actionDebugBufferViewOverlay_triggered(); - void on_actionDebugMessageModel_triggered(); - void on_actionDebugHotList_triggered(); - void on_actionDebugLog_triggered(); + void onJumpHotBufferTriggered(); + void onBufferSearchTriggered(); + void onDebugNetworkModelTriggered(); + void onDebugBufferViewOverlayTriggered(); + void onDebugMessageModelTriggered(); + void onDebugHotListTriggered(); + void onDebugLogTriggered(); + void onShowResourceTreeTriggered(); void bindJumpKey(); void onJumpKey(); @@ -215,17 +233,17 @@ private slots: void changeActiveBufferView(int bufferViewId); signals: - void connectToCore(const QVariantMap &connInfo); + void connectToCore(const QVariantMap& connInfo); void disconnectFromCore(); private: #ifdef HAVE_KDE - KHelpMenu *_kHelpMenu; + KHelpMenu* _kHelpMenu; #endif - MsgProcessorStatusWidget *_msgProcessorStatusWidget; - CoreConnectionStatusWidget *_coreConnectionStatusWidget; - SystemTray *_systemTray; + MsgProcessorStatusWidget* _msgProcessorStatusWidget; + CoreConnectionStatusWidget* _coreConnectionStatusWidget; + SystemTray* _systemTray; TitleSetter _titleSetter; @@ -247,30 +265,32 @@ private: void updateIcon(); void enableMenus(); - QList _bufferViews; - BufferWidget *_bufferWidget; - NickListWidget *_nickListWidget; - InputWidget *_inputWidget; - ChatMonitorView *_chatMonitorView; - TopicWidget *_topicWidget; + QList _bufferViews; + BufferWidget* _bufferWidget; + NickListWidget* _nickListWidget; + InputWidget* _inputWidget; + ChatMonitorView* _chatMonitorView; + TopicWidget* _topicWidget; - QAction *_fullScreenAction; + QAction* _fullScreenAction{nullptr}; QMenu *_fileMenu, *_networksMenu, *_viewMenu, *_bufferViewsMenu, *_settingsMenu, *_helpMenu, *_helpDebugMenu; - QMenu *_toolbarMenu; + QMenu* _toolbarMenu; QToolBar *_mainToolBar, *_chatViewToolBar, *_nickToolBar; - QWidget *_awayLog; + QWidget* _awayLog{nullptr}; + + QMessageBox* _migrationWarning{nullptr}; - bool _layoutLoaded; + bool _layoutLoaded{false}; - QSize _normalSize; //!< Size of the non-maximized window - QPoint _normalPos; //!< Position of the non-maximized window + QSize _normalSize; //!< Size of the non-maximized window + QPoint _normalPos; //!< Position of the non-maximized window - BufferHotListFilter *_bufferHotList; + BufferHotListFilter* _bufferHotList; QHash _jumpKeyMap; - int _activeBufferViewIndex; + int _activeBufferViewIndex{-1}; - bool _aboutToQuit; //closeEvent can occur multiple times on OSX + bool _aboutToQuit{false}; // closeEvent can occur multiple times on OSX friend class QtUi; };