X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainwin.h;h=94a2d4b470f9a8939dd5d52999a846448ff98c6b;hp=900354b10d737716ae0f15ca5dc76a97340dbdc0;hb=e8a39b4c3c92e193ab861a3fea84a261bb6fbd24;hpb=921321156c2f1ceed0e02d519a1835e63e8c8b48 diff --git a/src/qtui/mainwin.h b/src/qtui/mainwin.h index 900354b1..94a2d4b4 100644 --- a/src/qtui/mainwin.h +++ b/src/qtui/mainwin.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2015 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 * @@ -20,9 +20,9 @@ #pragma once -#ifdef HAVE_KDE4 -# include -#elif defined HAVE_KF5 +#include + +#ifdef HAVE_KF5 # include #else # include @@ -36,8 +36,8 @@ class ActionCollection; class BufferHotListFilter; class BufferView; class BufferViewConfig; +class ChatMonitorView; class ClientBufferViewConfig; -class ClientTransfer; class CoreAccount; class CoreConnectionStatusWidget; class BufferViewDock; @@ -46,11 +46,11 @@ class InputWidget; class MsgProcessorStatusWidget; class NickListWidget; class SystemTray; -class ChatMonitorView; class TopicWidget; -class QMenu; class QLabel; +class QMenu; +class QMessageBox; class QToolBar; class KHelpMenu; @@ -65,8 +65,7 @@ class MainWin Q_OBJECT public: - MainWin(QWidget *parent = 0); - virtual ~MainWin(); + MainWin(QWidget *parent = nullptr); void init(); @@ -77,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(); } @@ -85,6 +84,9 @@ public: void saveStateToSettings(UiSettings &); void restoreStateFromSettings(UiSettings &); + // We need to override this to add the show/hide menu bar option + QMenu *createPopupMenu() override; + public slots: void showStatusBarMessage(const QString &message); void hideCurrentBuffer(); @@ -93,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(); @@ -114,9 +117,20 @@ 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 &); + void showCoreConfigWizard(const QVariantList &, const QVariantList &); void showCoreInfoDlg(); void showAwayLog(); void showSettingsDlg(); @@ -124,9 +138,11 @@ private slots: void showIgnoreList(QString newRule = QString()); void showShortcutsDlg(); void showPasswordChangeDlg(); - void showNewTransferDlg(const ClientTransfer *transfer); + 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); @@ -138,12 +154,57 @@ 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(); void on_actionDebugBufferViewOverlay_triggered(); void on_actionDebugMessageModel_triggered(); void on_actionDebugHotList_triggered(); void on_actionDebugLog_triggered(); + void on_actionShowResourceTree_triggered(); void bindJumpKey(); void onJumpKey(); @@ -187,6 +248,7 @@ private: void setupChatMonitor(); void setupInputWidget(); void setupTopicWidget(); + void setupTransferWidget(); void setupViewMenuTail(); void setupStatusBar(); void setupSystray(); @@ -211,6 +273,8 @@ private: QWidget *_awayLog; + QMessageBox* _migrationWarning{nullptr}; + bool _layoutLoaded; QSize _normalSize; //!< Size of the non-maximized window @@ -220,5 +284,7 @@ private: QHash _jumpKeyMap; int _activeBufferViewIndex; + bool _aboutToQuit; //closeEvent can occur multiple times on OSX + friend class QtUi; };