diff --git a/src/tomahawkwindow.cpp b/src/tomahawkwindow.cpp index 62a442946..31499bd14 100644 --- a/src/tomahawkwindow.cpp +++ b/src/tomahawkwindow.cpp @@ -21,6 +21,8 @@ #include #include +#include +#include #include #include #include @@ -263,6 +265,13 @@ TomahawkWindow::setupSignals() connect( ui->actionCreate_New_Station, SIGNAL( triggered() ), SLOT( createStation() )); connect( ui->actionAboutTomahawk, SIGNAL( triggered() ), SLOT( showAboutTomahawk() ) ); connect( ui->actionExit, SIGNAL( triggered() ), APP, SLOT( quit() ) ); +#if defined( Q_OS_DARWIN ) + connect( ui->actionMinimize, SIGNAL( triggered() ), SLOT( minimize() ) ); + connect( ui->actionZoom, SIGNAL( triggered() ), SLOT( maximize() ) ); +#else + ui->menuWindow->clear(); + ui->menuWindow->menuAction()->setVisible( false ); +#endif // connect( APP->sipHandler(), SIGNAL( connected() ), SLOT( onSipConnected() ) ); @@ -290,7 +299,6 @@ TomahawkWindow::changeEvent( QEvent* e ) } } - void TomahawkWindow::closeEvent( QCloseEvent* e ) { @@ -306,6 +314,27 @@ TomahawkWindow::closeEvent( QCloseEvent* e ) e->accept(); } +void +TomahawkWindow::showEvent( QShowEvent* e ) +{ + QMainWindow::showEvent( e ); + +#if defined( Q_OS_DARWIN ) + ui->actionMinimize->setDisabled( false ); + ui->actionZoom->setDisabled( false ); +#endif +} + +void +TomahawkWindow::hideEvent( QHideEvent* e ) +{ + QMainWindow::hideEvent( e ); + +#if defined( Q_OS_DARWIN ) + ui->actionMinimize->setDisabled( true ); + ui->actionZoom->setDisabled( true ); +#endif +} void TomahawkWindow::showSettingsDialog() @@ -513,3 +542,23 @@ TomahawkWindow::checkForUpdates() Tomahawk::checkForUpdates(); #endif } + +void +TomahawkWindow::minimize() +{ + if (isMinimized()) { + showNormal(); + } else { + showMinimized(); + } +} + +void +TomahawkWindow::maximize() +{ + if (isMaximized()) { + showNormal(); + } else { + showMaximized(); + } +} diff --git a/src/tomahawkwindow.h b/src/tomahawkwindow.h index e8211fbb6..d09db919d 100644 --- a/src/tomahawkwindow.h +++ b/src/tomahawkwindow.h @@ -54,6 +54,8 @@ public: protected: void changeEvent( QEvent* e ); void closeEvent( QCloseEvent* e ); + void showEvent( QShowEvent* e ); + void hideEvent( QHideEvent* e ); public slots: void createAutomaticPlaylist(); @@ -79,6 +81,9 @@ private slots: void showAboutTomahawk(); void checkForUpdates(); + void minimize(); + void maximize(); + private: void loadSettings(); void saveSettings(); diff --git a/src/tomahawkwindow.ui b/src/tomahawkwindow.ui index 6b142c616..c4fee4d69 100644 --- a/src/tomahawkwindow.ui +++ b/src/tomahawkwindow.ui @@ -72,6 +72,13 @@ + + + &Window + + + + &Help @@ -82,6 +89,7 @@ + @@ -157,6 +165,22 @@ Hide Offline Sources + + + Minimize + + + Ctrl+M + + + + + Zoom + + + Meta+Ctrl+Z + +