X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=76097b497d658837f13f759723533883ec7d719c;hp=58e4be454c105240d262b9331761d2b965388863;hb=HEAD;hpb=e6217df3a59b911d2c449d2a7b997a799d233ed4 diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index 58e4be45..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 * @@ -23,9 +23,9 @@ #include #ifdef HAVE_KF5 -# include +# include #else -# include +# include #endif #include "qtui.h" @@ -58,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 = nullptr); + 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) override; + 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 - QMenu *createPopupMenu() override; + 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(); void showMigrationWarning(bool show); - void onExitRequested(const QString &reason); + void onExitRequested(const QString& reason); protected: - void closeEvent(QCloseEvent *event) override; - void moveEvent(QMoveEvent *event) override; - void resizeEvent(QResizeEvent *event) override; + void closeEvent(QCloseEvent* event) override; + void moveEvent(QMoveEvent* event) override; + void resizeEvent(QResizeEvent* event) override; protected slots: void connectedToCore(); @@ -115,7 +117,7 @@ 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(); /** @@ -125,12 +127,11 @@ private slots: * @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 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(); @@ -138,18 +139,16 @@ private slots: void showIgnoreList(QString newRule = QString()); void showShortcutsDlg(); void showPasswordChangeDlg(); - void showNewTransferDlg(const QUuid &transferId); + void showNewTransferDlg(const QUuid& transferId); void onFullScreenToggled(); void doAutoConnect(); - 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 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(); @@ -190,6 +189,13 @@ private slots: */ 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 * @@ -227,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; @@ -259,32 +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{nullptr}; + QAction* _fullScreenAction{nullptr}; QMenu *_fileMenu, *_networksMenu, *_viewMenu, *_bufferViewsMenu, *_settingsMenu, *_helpMenu, *_helpDebugMenu; - QMenu *_toolbarMenu; + QMenu* _toolbarMenu; QToolBar *_mainToolBar, *_chatViewToolBar, *_nickToolBar; - QWidget *_awayLog{nullptr}; + QWidget* _awayLog{nullptr}; QMessageBox* _migrationWarning{nullptr}; 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{-1}; - bool _aboutToQuit{false}; //closeEvent can occur multiple times on OSX + bool _aboutToQuit{false}; // closeEvent can occur multiple times on OSX friend class QtUi; };