X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=bb2972db29ada35e2427b4ea607fb194a538d437;hp=5d77136bf25451007acef421b53b40f3a33a2781;hb=158443f71d48215eea8b47b836b61afd77654b78;hpb=61aac1868f15babb7086d8bc6bbcff530346f438 diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index 5d77136b..bb2972db 100644 --- a/src/qtui/mainwin.h +++ b/src/qtui/mainwin.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2016 by the Quassel Project * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -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,18 @@ 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 &); void showCoreInfoDlg(); @@ -131,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); @@ -142,6 +154,49 @@ private slots: void on_actionConfigureNetworks_triggered(); void on_actionConfigureViews_triggered(); void on_actionLockLayout_toggled(bool lock); + + /** + * Apply the active color to the input widget selected or typed text + * + * @seealso InputWidget::applyFormatActiveColor() + */ + void on_inputFormatApplyColor_triggered(); + + /** + * Apply the active fill color to the input widget selected or typed text background + * + * @seealso InputWidget::applyFormatActiveColorFill() + */ + void on_inputFormatApplyColorFill_triggered(); + + /** + * Toggle the boldness of the input widget selected or typed text + * + * @seealso InputWidget::toggleFormatBold() + */ + void on_inputFormatBold_triggered(); + + /** + * Toggle the italicness of the input widget selected or typed text + * + * @seealso InputWidget::toggleFormatItalic() + */ + void on_inputFormatItalic_triggered(); + + /** + * Toggle the underlining of the input widget selected or typed text + * + * @seealso InputWidget::toggleFormatUnderline() + */ + void on_inputFormatUnderline_triggered(); + + /** + * Clear the formatting of the input widget selected or typed text + * + * @seealso InputWidget::clearFormat() + */ + void on_inputFormatClear_triggered(); + void on_jumpHotBuffer_triggered(); void on_bufferSearch_triggered(); void on_actionDebugNetworkModel_triggered(); @@ -149,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(); @@ -215,18 +271,20 @@ private: 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 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; };