diff options
Diffstat (limited to 'Swift/QtUI/QtMainWindow.cpp')
| -rw-r--r-- | Swift/QtUI/QtMainWindow.cpp | 33 | 
1 files changed, 31 insertions, 2 deletions
diff --git a/Swift/QtUI/QtMainWindow.cpp b/Swift/QtUI/QtMainWindow.cpp index 5d50c1e..572b06f 100644 --- a/Swift/QtUI/QtMainWindow.cpp +++ b/Swift/QtUI/QtMainWindow.cpp @@ -33,6 +33,7 @@  #include <Swift/Controllers/UIEvents/RequestProfileEditorUIEvent.h>  #include <Swift/Controllers/UIEvents/JoinMUCUIEvent.h>  #include <Swift/Controllers/UIEvents/RequestAdHocUIEvent.h> +#include <Swift/Controllers/UIEvents/RequestBlockListDialogUIEvent.h>  #include <Swift/QtUI/QtUISettingConstants.h>  #include <Swift/Controllers/SettingConstants.h>  #include <Swiften/Base/Platform.h> @@ -47,14 +48,14 @@  namespace Swift { -QtMainWindow::QtMainWindow(SettingsProvider* settings, UIEventStream* uiEventStream, QtLoginWindow::QtMenus loginMenus, bool emoticonsExist) : QWidget(), MainWindow(false), loginMenus_(loginMenus) { +QtMainWindow::QtMainWindow(SettingsProvider* settings, UIEventStream* uiEventStream, QtLoginWindow::QtMenus loginMenus, StatusCache* statusCache, bool emoticonsExist) : QWidget(), MainWindow(false), loginMenus_(loginMenus) {  	uiEventStream_ = uiEventStream;  	settings_ = settings;  	setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding));  	QBoxLayout *mainLayout = new QBoxLayout(QBoxLayout::TopToBottom, this);  	mainLayout->setContentsMargins(0,0,0,0);  	mainLayout->setSpacing(0); -	meView_ = new QtRosterHeader(settings, this); +	meView_ = new QtRosterHeader(settings, statusCache, this);  	mainLayout->addWidget(meView_);  	connect(meView_, SIGNAL(onChangeStatusRequest(StatusShow::Type, const QString&)), this, SLOT(handleStatusChanged(StatusShow::Type, const QString&)));  	connect(meView_, SIGNAL(onEditProfileRequest()), this, SLOT(handleEditProfileRequest())); @@ -95,6 +96,14 @@ QtMainWindow::QtMainWindow(SettingsProvider* settings, UIEventStream* uiEventStr  	QMenu* viewMenu = new QMenu(tr("&View"), this);  	menus_.push_back(viewMenu); + +	compactRosterAction_ = new QAction(tr("&Compact Roster"), this); +	compactRosterAction_->setCheckable(true); +	compactRosterAction_->setChecked(false); +	connect(compactRosterAction_, SIGNAL(toggled(bool)), SLOT(handleCompactRosterToggled(bool))); +	viewMenu->addAction(compactRosterAction_); +	handleCompactRosterToggled(settings_->getSetting(QtUISettingConstants::COMPACT_ROSTER)); +  	showOfflineAction_ = new QAction(tr("&Show offline contacts"), this);  	showOfflineAction_->setCheckable(true);  	showOfflineAction_->setChecked(false); @@ -130,6 +139,10 @@ QtMainWindow::QtMainWindow(SettingsProvider* settings, UIEventStream* uiEventStr  	connect(viewLogsAction, SIGNAL(triggered()), SLOT(handleViewLogsAction()));  	actionsMenu->addAction(viewLogsAction);  #endif +	openBlockingListEditor_ = new QAction(tr("Edit &Blocking List…"), this); +	connect(openBlockingListEditor_, SIGNAL(triggered()), SLOT(handleEditBlockingList())); +	actionsMenu->addAction(openBlockingListEditor_); +	openBlockingListEditor_->setVisible(false);  	addUserAction_ = new QAction(tr("&Add Contact…"), this);  	connect(addUserAction_, SIGNAL(triggered(bool)), this, SLOT(handleAddUserActionTriggered(bool)));  	actionsMenu->addAction(addUserAction_); @@ -182,6 +195,10 @@ void QtMainWindow::handleShowCertificateInfo() {  	onShowCertificateRequest();  } +void QtMainWindow::handleEditBlockingList() { +	uiEventStream_->send(boost::make_shared<RequestBlockListDialogUIEvent>()); +} +  QtEventWindow* QtMainWindow::getEventWindow() {  	return eventWindow_;  } @@ -261,6 +278,14 @@ void QtMainWindow::handleSettingChanged(const std::string& settingPath) {  	if (settingPath == SettingConstants::REQUEST_DELIVERYRECEIPTS.getKey()) {  		toggleRequestDeliveryReceipts_->setChecked(settings_->getSetting(SettingConstants::REQUEST_DELIVERYRECEIPTS));  	} +	if (settingPath == QtUISettingConstants::COMPACT_ROSTER.getKey()) { +		handleCompactRosterToggled(settings_->getSetting(QtUISettingConstants::COMPACT_ROSTER)); +	} +} + +void QtMainWindow::handleCompactRosterToggled(bool state) { +	settings_->storeSetting(QtUISettingConstants::COMPACT_ROSTER, state); +	compactRosterAction_->setChecked(settings_->getSetting(QtUISettingConstants::COMPACT_ROSTER));  }  void QtMainWindow::handleShowOfflineToggled(bool state) { @@ -343,5 +368,9 @@ void QtMainWindow::setAvailableAdHocCommands(const std::vector<DiscoItems::Item>  	}  } +void QtMainWindow::setBlockingCommandAvailable(bool isAvailable) { +	openBlockingListEditor_->setVisible(isAvailable); +} +  }  | 
 Swift