diff options
| author | Kevin Smith <git@kismith.co.uk> | 2010-04-05 11:01:48 (GMT) | 
|---|---|---|
| committer | Kevin Smith <git@kismith.co.uk> | 2010-04-05 11:01:48 (GMT) | 
| commit | 348a4f13c5f00a27ad5c7e4f392948de7cc454e3 (patch) | |
| tree | 43392423f5939190075d62aaae1478f52571af5c /Swift | |
| parent | 326cd32e2c9e3ec9bac54f5bb952928680c93749 (diff) | |
| download | swift-348a4f13c5f00a27ad5c7e4f392948de7cc454e3.zip swift-348a4f13c5f00a27ad5c7e4f392948de7cc454e3.tar.bz2 | |
Persist Sound Toggleness.
Resolves: #192
Diffstat (limited to 'Swift')
| -rw-r--r-- | Swift/Controllers/MainController.cpp | 2 | ||||
| -rw-r--r-- | Swift/Controllers/SoundEventController.cpp | 17 | ||||
| -rw-r--r-- | Swift/Controllers/SoundEventController.h | 6 | ||||
| -rw-r--r-- | Swift/QtUI/QtLoginWindow.cpp | 22 | ||||
| -rw-r--r-- | Swift/QtUI/QtLoginWindow.h | 4 | 
5 files changed, 37 insertions, 14 deletions
| diff --git a/Swift/Controllers/MainController.cpp b/Swift/Controllers/MainController.cpp index ccce0bb..8aeca97 100644 --- a/Swift/Controllers/MainController.cpp +++ b/Swift/Controllers/MainController.cpp @@ -71,8 +71,8 @@ MainController::MainController(ChatWindowFactory* chatWindowFactory, MainWindowF  	eventController_->onEventQueueLengthChange.connect(boost::bind(&MainController::handleEventQueueLengthChange, this, _1));  	systemTrayController_ = new SystemTrayController(eventController_, systemTray); -	soundEventController_ = new SoundEventController(eventController_, soundPlayer, settings->getBoolSetting("playSounds", true), uiEventStream_);  	loginWindow_ = loginWindowFactory_->createLoginWindow(uiEventStream_); +	soundEventController_ = new SoundEventController(eventController_, soundPlayer, settings, uiEventStream_);  	foreach (String profile, settings->getAvailableProfiles()) {  		ProfileSettingsProvider* profileSettings = new ProfileSettingsProvider(profile, settings);  		loginWindow_->addAvailableAccount(profileSettings->getStringSetting("jid"), profileSettings->getStringSetting("pass"), profileSettings->getStringSetting("certificate")); diff --git a/Swift/Controllers/SoundEventController.cpp b/Swift/Controllers/SoundEventController.cpp index 29f7fbf..b1fa584 100644 --- a/Swift/Controllers/SoundEventController.cpp +++ b/Swift/Controllers/SoundEventController.cpp @@ -9,13 +9,17 @@  namespace Swift { -SoundEventController::SoundEventController(EventController* eventController, SoundPlayer* soundPlayer, bool playSounds, UIEventStream* uiEvents) { +SoundEventController::SoundEventController(EventController* eventController, SoundPlayer* soundPlayer, SettingsProvider* settings, UIEventStream* uiEvents) { +	uiEvents_ = uiEvents; +	settings_ = settings;  	eventController_ = eventController; -	eventController_->onEventQueueEventAdded.connect(boost::bind(&SoundEventController::handleEventQueueEventAdded, this, _1));  	soundPlayer_ = soundPlayer; -	playSounds_ = playSounds; -	uiEvents_ = uiEvents;  	uiEvents_->onUIEvent.connect(boost::bind(&SoundEventController::handleUIEvent, this, _1)); +	eventController_->onEventQueueEventAdded.connect(boost::bind(&SoundEventController::handleEventQueueEventAdded, this, _1)); + +	bool playSounds = settings->getBoolSetting("playSounds", true); +	playSounds_ = !playSounds; +	setPlaySounds(playSounds);	  }  void SoundEventController::handleEventQueueEventAdded(boost::shared_ptr<StanzaEvent>) { @@ -23,7 +27,12 @@ void SoundEventController::handleEventQueueEventAdded(boost::shared_ptr<StanzaEv  }  void SoundEventController::setPlaySounds(bool playSounds) { +	bool transmit = playSounds != playSounds_;  	playSounds_ = playSounds; +	settings_->storeBool("playSounds", playSounds); +	if (transmit) { +		uiEvents_->send(boost::shared_ptr<ToggleSoundsUIEvent>(new ToggleSoundsUIEvent(playSounds_))); +	}  }  void SoundEventController::handleUIEvent(boost::shared_ptr<UIEvent> event) { diff --git a/Swift/Controllers/SoundEventController.h b/Swift/Controllers/SoundEventController.h index 34499d4..e9a853f 100644 --- a/Swift/Controllers/SoundEventController.h +++ b/Swift/Controllers/SoundEventController.h @@ -3,7 +3,7 @@  #include <boost/shared_ptr.hpp>  #include "Swiften/Events/StanzaEvent.h" - +#include "Swiften/Settings/SettingsProvider.h"  #include "Swift/Controllers/UIEvents/UIEvent.h"  namespace Swift { @@ -12,8 +12,9 @@ namespace Swift {  	class UIEventStream;  	class SoundEventController {  		public: -			SoundEventController(EventController* eventController, SoundPlayer* soundPlayer, bool playSounds, UIEventStream* uiEvents); +			SoundEventController(EventController* eventController, SoundPlayer* soundPlayer, SettingsProvider* settings, UIEventStream* uiEvents);  			void setPlaySounds(bool playSounds); +			bool getSoundEnabled() {return playSounds_;};  		private:  			void handleUIEvent(boost::shared_ptr<UIEvent> event);  			void handleEventQueueEventAdded(boost::shared_ptr<StanzaEvent> event); @@ -21,5 +22,6 @@ namespace Swift {  			SoundPlayer* soundPlayer_;  			bool playSounds_;  			UIEventStream* uiEvents_; +			SettingsProvider* settings_;  	};  } diff --git a/Swift/QtUI/QtLoginWindow.cpp b/Swift/QtUI/QtLoginWindow.cpp index 4f6b423..ff2a50b 100644 --- a/Swift/QtUI/QtLoginWindow.cpp +++ b/Swift/QtUI/QtLoginWindow.cpp @@ -1,5 +1,7 @@  #include "QtLoginWindow.h" +#include <boost/bind.hpp> +  #include "Swift/Controllers/UIEvents/UIEventStream.h"  #include "Swift/Controllers/UIEvents/RequestXMLConsoleUIEvent.h"  #include "Swift/Controllers/UIEvents/ToggleSoundsUIEvent.h" @@ -117,21 +119,29 @@ QtLoginWindow::QtLoginWindow(UIEventStream* uiEventStream) : QMainWindow() {  	connect(xmlConsoleAction, SIGNAL(activated()), SLOT(handleShowXMLConsole()));  	toolsMenu_->addAction(xmlConsoleAction); -	QAction* toggleSoundsAction = new QAction(tr("Toggle Sounds"), this); -	toggleSoundsAction->setCheckable(true); -	toggleSoundsAction->setChecked(true); -	connect(toggleSoundsAction, SIGNAL(toggled(bool)), SLOT(handleToggleSounds(bool))); -	swiftMenu_->addAction(toggleSoundsAction); +	toggleSoundsAction_ = new QAction(tr("Toggle Sounds"), this); +	toggleSoundsAction_->setCheckable(true); +	toggleSoundsAction_->setChecked(true); +	connect(toggleSoundsAction_, SIGNAL(toggled(bool)), SLOT(handleToggleSounds(bool))); +	swiftMenu_->addAction(toggleSoundsAction_);  	QAction* quitAction = new QAction("Quit", this);  	connect(quitAction, SIGNAL(activated()), SLOT(handleQuit()));  	swiftMenu_->addAction(quitAction); -	 +  	setInitialMenus(); +	uiEventStream_->onUIEvent.connect(boost::bind(&QtLoginWindow::handleUIEvent, this, _1));  	this->show();  } +void QtLoginWindow::handleUIEvent(boost::shared_ptr<UIEvent> event) { +	boost::shared_ptr<ToggleSoundsUIEvent> soundEvent = boost::dynamic_pointer_cast<ToggleSoundsUIEvent>(event); +	if (soundEvent) { +		toggleSoundsAction_->setChecked(soundEvent->getEnabled()); +	} +} +  /**   * Move and resize the window, but respect minimum sizes.   * (Like QWidget::setGeometry, only that will truncate the window diff --git a/Swift/QtUI/QtLoginWindow.h b/Swift/QtUI/QtLoginWindow.h index 40ea4ec..69327e9 100644 --- a/Swift/QtUI/QtLoginWindow.h +++ b/Swift/QtUI/QtLoginWindow.h @@ -10,6 +10,7 @@  #include <QMenuBar>  #include "Swift/Controllers/UIInterfaces/LoginWindow.h" +#include "Swift/Controllers/UIEvents/UIEventStream.h"  #include "Swift/Controllers/MainWindow.h"  #include "QtAboutWidget.h" @@ -18,7 +19,6 @@ class QToolButton;  class QComboBox;  namespace Swift { -	class UIEventStream;  	class QtLoginWindow : public QMainWindow, public LoginWindow {  		Q_OBJECT  		public: @@ -45,6 +45,7 @@ namespace Swift {  			void handleUsernameTextChanged();  			void resizeEvent(QResizeEvent* event);  			void moveEvent(QMoveEvent* event); +			void handleUIEvent(boost::shared_ptr<UIEvent> event);  		private:  			void setInitialMenus(); @@ -62,6 +63,7 @@ namespace Swift {  			QMenuBar* menuBar_;  			QMenu* swiftMenu_;  			QMenu* toolsMenu_; +			QAction* toggleSoundsAction_;  			UIEventStream* uiEventStream_;  			QPointer<QtAboutWidget> aboutDialog_;  	}; | 
 Swift
 Swift