X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=94a2d4b470f9a8939dd5d52999a846448ff98c6b;hp=aa8aa94682d555e2307881bf410c7b5c34a0330b;hb=e8a39b4c3c92e193ab861a3fea84a261bb6fbd24;hpb=e9a02be2a4f3b8bb19d262b2b19f7dd0bfa10463 diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index aa8aa946..94a2d4b4 100644 --- a/src/qtui/mainwin.h +++ b/src/qtui/mainwin.h @@ -22,9 +22,7 @@ #include -#ifdef HAVE_KDE4 -# include -#elif defined HAVE_KF5 +#ifdef HAVE_KF5 # include #else # include @@ -50,8 +48,9 @@ class NickListWidget; class SystemTray; class TopicWidget; -class QMenu; class QLabel; +class QMenu; +class QMessageBox; class QToolBar; class KHelpMenu; @@ -66,8 +65,7 @@ class MainWin Q_OBJECT public: - MainWin(QWidget *parent = 0); - virtual ~MainWin(); + MainWin(QWidget *parent = nullptr); void init(); @@ -78,7 +76,7 @@ public: 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(); } @@ -87,7 +85,7 @@ public: 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); @@ -97,13 +95,14 @@ public slots: 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(); @@ -118,7 +117,17 @@ private slots: void currentBufferChanged(BufferId); 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 &); @@ -132,6 +141,8 @@ private slots: 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); @@ -193,6 +204,7 @@ private slots: void on_actionDebugMessageModel_triggered(); void on_actionDebugHotList_triggered(); void on_actionDebugLog_triggered(); + void on_actionShowResourceTree_triggered(); void bindJumpKey(); void onJumpKey(); @@ -261,6 +273,8 @@ private: QWidget *_awayLog; + QMessageBox* _migrationWarning{nullptr}; + bool _layoutLoaded; QSize _normalSize; //!< Size of the non-maximized window