/*****************************************************************************
- * Help.cpp : Help and About dialogs
+ * help.cpp : Help and About dialogs
****************************************************************************
* Copyright (C) 2007 the VideoLAN team
* $Id$
*
* Authors: Jean-Baptiste Kempf <jb (at) videolan.org>
- * Rémi Duraffort <ivoire (at) via.ecp.fr>
+ * Rémi Duraffort <ivoire (at) via.ecp.fr>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
-#include <vlc/vlc.h>
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+#include "qt4.hpp"
#include "dialogs/help.hpp"
+#include "util/qt_dirs.hpp"
+
#include <vlc_about.h>
+#include <vlc_intf_strings.h>
#ifdef UPDATE_CHECK
-#include <vlc_update.h>
+# include <vlc_update.h>
#endif
-#include "dialogs_provider.hpp"
-
-#include <vlc_intf_strings.h>
-
#include <QTextBrowser>
#include <QTabWidget>
-#include <QFile>
#include <QLabel>
#include <QString>
#include <QDialogButtonBox>
+#include <QEvent>
+#include <QDate>
+#include <QPushButton>
-
-HelpDialog *HelpDialog::instance = NULL;
+#include <assert.h>
HelpDialog::HelpDialog( intf_thread_t *_p_intf ) : QVLCFrame( _p_intf )
+
{
setWindowTitle( qtr( "Help" ) );
- resize( 600, 560 );
+ setWindowRole( "vlc-help" );
+ setMinimumSize( 350, 300 );
+
+ QVBoxLayout *layout = new QVBoxLayout( this );
- QGridLayout *layout = new QGridLayout( this );
QTextBrowser *helpBrowser = new QTextBrowser( this );
helpBrowser->setOpenExternalLinks( true );
- helpBrowser->setHtml( I_LONGHELP );
- QPushButton *closeButton = new QPushButton( qtr( "&Close" ) );
- closeButton->setDefault( true );
+ helpBrowser->setHtml( qtr(I_LONGHELP) );
- layout->addWidget( helpBrowser, 0, 0, 1, 0 );
- layout->addWidget( closeButton, 1, 3 );
+ QDialogButtonBox *closeButtonBox = new QDialogButtonBox( this );
+ closeButtonBox->addButton(
+ new QPushButton( qtr("&Close") ), QDialogButtonBox::RejectRole );
+ closeButtonBox->setFocus();
- BUTTONACT( closeButton, close() );
+ layout->addWidget( helpBrowser );
+ layout->addWidget( closeButtonBox );
+
+ CONNECT( closeButtonBox, rejected(), this, close() );
+ restoreWidgetPosition( "Help", QSize( 500, 450 ) );
}
HelpDialog::~HelpDialog()
{
+ saveWidgetPosition( "Help" );
}
-void HelpDialog::close()
-{
- this->toggleVisible();
-}
-
-AboutDialog *AboutDialog::instance = NULL;
-AboutDialog::AboutDialog( intf_thread_t *_p_intf) : QVLCFrame( _p_intf )
+AboutDialog::AboutDialog( intf_thread_t *_p_intf)
+ : QVLCDialog( (QWidget*)_p_intf->p_sys->p_mi, _p_intf ), b_advanced( false )
{
+ /* Build UI */
+ ui.setupUi( this );
setWindowTitle( qtr( "About" ) );
- resize( 600, 500 );
-
- QGridLayout *layout = new QGridLayout( this );
- QTabWidget *tab = new QTabWidget( this );
-
- QPushButton *closeButton = new QPushButton( qtr( "&Close" ) );
- closeButton->setSizePolicy( QSizePolicy::Minimum, QSizePolicy::Minimum );
- closeButton->setDefault( true );
-
- QLabel *introduction = new QLabel(
- qtr( "Information about VLC media player." ) );
- QLabel *iconVLC = new QLabel;
- iconVLC->setPixmap( QPixmap( ":/vlc48.png" ) );
- layout->addWidget( iconVLC, 0, 0, 1, 1 );
- layout->addWidget( introduction, 0, 1, 1, 7 );
- layout->addWidget( tab, 1, 0, 1, 8 );
- layout->addWidget( closeButton, 2, 6, 1, 2 );
-
- /* Main Introduction */
- QWidget *infoWidget = new QWidget( this );
- QHBoxLayout *infoLayout = new QHBoxLayout( infoWidget );
- QLabel *infoLabel = new QLabel( "VLC media player " PACKAGE_VERSION "\n\n"
- "(c) 1996-2007 - the VideoLAN Team\n\n" +
- qtr( "VLC media player is a free media player, made by the "
- "VideoLAN Team.\nIt is a standalone multimedia player, "
- "encoder and streamer, that can read from many supports "
- "(files, CDs, DVDs, networks, capture cards...) and that "
- "works on many platforms.\n\n" )
- + qtr( "You are using the new Qt4 Interface.\n" )
- + qtr( "Compiled by " ) + qfu( VLC_CompileBy() )+ "@"
- + qfu( VLC_CompileDomain() ) + ".\n"
- + "Compiler: " + qfu( VLC_Compiler() ) + ".\n"
- + qtr( "Based on SVN revision: " ) + qfu( VLC_Changeset() )
- + ".\n\n"
- + qtr( "This program comes with NO WARRANTY, to the extent "
- "permitted by the law; read the distribution tab.\n\n" )
- + "The VideoLAN team <videolan@videolan.org> \n"
- "http://www.videolan.org/\n" );
- infoLabel->setWordWrap( infoLabel );
-
- QLabel *iconVLC2 = new QLabel;
- iconVLC2->setPixmap( QPixmap( ":/vlc128.png" ) );
- infoLayout->addWidget( iconVLC2 );
- infoLayout->addWidget( infoLabel );
+ setWindowRole( "vlc-about" );
+ setWindowModality( Qt::WindowModal );
+
+ ui.version->setText(qfu( " " VERSION_MESSAGE ) );
+#if 0
+ if( QDate::currentDate().dayOfYear() >= QT_XMAS_JOKE_DAY && var_InheritBool( p_intf, "qt-icon-change" ) )
+ ui.iconVLC->setPixmap( QPixmap( ":/logo/vlc128-xmas.png" ) );
+ else
+ ui.iconVLC->setPixmap( QPixmap( ":/logo/vlc128.png" ) );
+#endif
+
+#if 0
+ ifdef UPDATE_CHECK
+#else
+ ui.update->hide();
+#endif
/* GPL License */
- QTextEdit *licenseEdit = new QTextEdit( this );
- licenseEdit->setFontFamily( "Monospace" );
- licenseEdit->setText( qfu( psz_license ) );
- licenseEdit->setReadOnly( true );
+ ui.licensePage->setText( qfu( psz_license ) );
/* People who helped */
- QWidget *thanksWidget = new QWidget( this );
- QVBoxLayout *thanksLayout = new QVBoxLayout( thanksWidget );
-
- QLabel *thanksLabel = new QLabel( qtr( "We would like to thank the whole "
- "community, the testers, our users and the following people "
- "(and the missing ones...) for their collaboration to "
- "provide the best software." ) );
- thanksLabel->setWordWrap( true );
- thanksLayout->addWidget( thanksLabel );
- QTextEdit *thanksEdit = new QTextEdit( this );
- thanksEdit->setText( qfu( psz_thanks ) );
- thanksEdit->setReadOnly( true );
- thanksLayout->addWidget( thanksEdit );
+ ui.creditPage->setText( qfu( psz_thanks ) );
/* People who wrote the software */
- QTextEdit *authorsEdit = new QTextEdit( this );
- authorsEdit->setText( qfu( psz_authors ) );
- authorsEdit->setReadOnly( true );
+ ui.authorsPage->setText( qfu( psz_authors ) );
+
+ ui.licenseButton->installEventFilter( this );
+ ui.authorsButton->installEventFilter( this );
+ ui.creditsButton->installEventFilter( this );
+
+ ui.version->installEventFilter( this );
+}
- /* add the tabs to the Tabwidget */
- tab->addTab( infoWidget, qtr( "General Info" ) );
- tab->addTab( authorsEdit, qtr( "Authors" ) );
- tab->addTab( thanksWidget, qtr("Thanks") );
- tab->addTab( licenseEdit, qtr("Distribution License") );
+void AboutDialog::showLicense()
+{
+ ui.stackedWidget->setCurrentWidget( ui.licensePage );
+}
- BUTTONACT( closeButton, close() );
+void AboutDialog::showAuthors()
+{
+ ui.stackedWidget->setCurrentWidget( ui.authorsPage );
}
-AboutDialog::~AboutDialog()
+void AboutDialog::showCredit()
{
+ ui.stackedWidget->setCurrentWidget( ui.creditPage );
+}
+
+bool AboutDialog::eventFilter(QObject *obj, QEvent *event)
+{
+ if (event->type() == QEvent::MouseButtonPress )
+ {
+ if( obj == ui.version )
+ {
+ if( !b_advanced )
+ {
+ ui.version->setText(qfu( VLC_CompileBy() )+ "@" + qfu( VLC_CompileHost() )
+ + __DATE__ + " " +__TIME__);
+ b_advanced = true;
+ }
+ else
+ {
+ ui.version->setText(qfu( " " VERSION_MESSAGE ) );
+ b_advanced = false;
+ }
+ return true;
+ }
+ else if( obj == ui.licenseButton )
+ showLicense();
+ else if( obj == ui.authorsButton )
+ showAuthors();
+ else if( obj == ui.creditsButton )
+ showCredit();
+
+ return false;
+ }
+
+ return QVLCDialog::eventFilter( obj, event);
}
-void AboutDialog::close()
+
+void AboutDialog::showEvent( QShowEvent *event )
{
- this->toggleVisible();
+ ui.stackedWidget->setCurrentWidget( ui.blablaPage );
+ QVLCDialog::showEvent( event );
}
#ifdef UPDATE_CHECK
-UpdateDialog *UpdateDialog::instance = NULL;
+
+/*****************************************************************************
+ * UpdateDialog
+ *****************************************************************************/
+/* callback to get information from the core */
+static void UpdateCallback( void *data, bool b_ret )
+{
+ UpdateDialog* UDialog = (UpdateDialog *)data;
+ QEvent* event;
+
+ if( b_ret )
+ event = new QEvent( UpdateDialog::UDOkEvent );
+ else
+ event = new QEvent( UpdateDialog::UDErrorEvent );
+
+ QApplication::postEvent( UDialog, event );
+}
+
+const QEvent::Type UpdateDialog::UDOkEvent =
+ (QEvent::Type)QEvent::registerEventType();
+const QEvent::Type UpdateDialog::UDErrorEvent =
+ (QEvent::Type)QEvent::registerEventType();
UpdateDialog::UpdateDialog( intf_thread_t *_p_intf ) : QVLCFrame( _p_intf )
{
- setWindowTitle( qtr( "Update" ) );
- resize( 320, 120 );
-
- QGridLayout *layout = new QGridLayout( this );
-
- updateBrowser = new QTextBrowser( this );
- updateBrowser->setOpenExternalLinks( true );
- updateBrowser->setHtml( qtr( "<html><head><meta http-equiv=\"Content-Type\" content=\"text/html; charset=\"utf-8\" /></head> \
- <body><center>Push the update button to get the updates</center></body></html>" ) );
-
- QPushButton *closeButton = new QPushButton( qtr( "&Close" ) );
- QPushButton *updateButton = new QPushButton( qtr( "&Update List" ) );
- updateButton->setDefault( true );
- QDialogButtonBox *buttonBox = new QDialogButtonBox( Qt::Horizontal );
- buttonBox->addButton( updateButton, QDialogButtonBox::ActionRole );
- buttonBox->addButton( closeButton, QDialogButtonBox::AcceptRole );
-
- layout->addWidget( updateBrowser, 0, 0 );
- layout->addWidget( buttonBox, 1, 0 );
-
- BUTTONACT( updateButton, updateOrUpload() );
- BUTTONACT( closeButton, close() );
-
- p_update = update_New( _p_intf );
+ /* build Ui */
+ ui.setupUi( this );
+ ui.updateDialogButtonBox->addButton( new QPushButton( qtr("&Close"), this ),
+ QDialogButtonBox::RejectRole );
+ QPushButton *recheckButton = new QPushButton( qtr("&Recheck version"), this );
+ ui.updateDialogButtonBox->addButton( recheckButton, QDialogButtonBox::ActionRole );
+
+ ui.updateNotifyButtonBox->addButton( new QPushButton( qtr("&Yes"), this ),
+ QDialogButtonBox::AcceptRole );
+ ui.updateNotifyButtonBox->addButton( new QPushButton( qtr("&No"), this ),
+ QDialogButtonBox::RejectRole );
+
+ setWindowTitle( qtr( "VLC media player updates" ) );
+ setWindowRole( "vlc-update" );
+
+ BUTTONACT( recheckButton, UpdateOrDownload() );
+ CONNECT( ui.updateDialogButtonBox, rejected(), this, close() );
+
+ CONNECT( ui.updateNotifyButtonBox, accepted(), this, UpdateOrDownload() );
+ CONNECT( ui.updateNotifyButtonBox, rejected(), this, close() );
+
+ /* Create the update structure */
+ p_update = update_New( p_intf );
+ b_checked = false;
+
+ setMinimumSize( 300, 300 );
+ setMaximumSize( 500, 300 );
+
+ restoreWidgetPosition( "Update", maximumSize() );
+
+ /* Check for updates */
+ UpdateOrDownload();
}
UpdateDialog::~UpdateDialog()
{
update_Delete( p_update );
+ saveWidgetPosition( "Update" );
}
-void UpdateDialog::close()
+/* Check for updates */
+void UpdateDialog::UpdateOrDownload()
{
- toggleVisible();
+ if( !b_checked )
+ {
+ ui.stackedWidget->setCurrentWidget( ui.updateRequestPage );
+ update_Check( p_update, UpdateCallback, this );
+ }
+ else
+ {
+ QString dest_dir = QDir::tempPath();
+ if( !dest_dir.isEmpty() )
+ {
+ dest_dir = toNativeSepNoSlash( dest_dir ) + DIR_SEP;
+ msg_Dbg( p_intf, "Downloading to folder: %s", qtu( dest_dir ) );
+ toggleVisible();
+ update_Download( p_update, qtu( dest_dir ) );
+ /* FIXME: We should trigger a change to another dialog here ! */
+ }
+ }
}
-void UpdateDialog::updateOrUpload()
+/* Handle the events */
+void UpdateDialog::customEvent( QEvent *event )
{
- update_Check( p_update );
+ if( event->type() == UDOkEvent )
+ updateNotify( true );
+ else
+ updateNotify( false );
+}
- if( update_CompareReleaseToCurrent( p_update ) == UpdateReleaseStatusNewer )
+/* Notify the end of the update_Check */
+void UpdateDialog::updateNotify( bool b_result )
+{
+ /* The update finish without errors */
+ if( b_result )
{
- updateBrowser->setHtml( qtr( "<html><head><meta http-equiv=\"Content-Type\" content=\"text/html; charset=\"utf-8\" /></head> \
- <body><center><p>" ) + qtu( (QString)p_update->release.psz_desc ) +
- qtr( "</p>You can download the latest version of VLC <a href=\"" ) +
- qtu( (QString)p_update->release.psz_url ) + qtr( "\">here</a></center></body></html>" ) );
+ if( update_NeedUpgrade( p_update ) )
+ {
+ ui.stackedWidget->setCurrentWidget( ui.updateNotifyPage );
+ update_release_t *p_release = update_GetRelease( p_update );
+ assert( p_release );
+ b_checked = true;
+ QString message = QString(
+ qtr( "A new version of VLC (%1.%2.%3%4) is available." ) )
+ .arg( QString::number( p_release->i_major ) )
+ .arg( QString::number( p_release->i_minor ) )
+ .arg( QString::number( p_release->i_revision ) )
+ .arg( p_release->i_extra == 0 ? "" : "." + QString::number( p_release->i_extra ) );
+
+ ui.updateNotifyLabel->setText( message );
+ message = qfu( p_release->psz_desc ).replace( "\n", "<br/>" );
+
+ /* Try to highlight releases featuring security changes */
+ int i_index = message.indexOf( "security", Qt::CaseInsensitive );
+ if ( i_index >= 0 )
+ {
+ message.insert( i_index + 8, "</font>" );
+ message.insert( i_index, "<font style=\"color:red\">" );
+ }
+ ui.updateNotifyTextEdit->setHtml( message );
+
+ /* Force the dialog to be shown */
+ this->show();
+ }
+ else
+ {
+ ui.stackedWidget->setCurrentWidget( ui.updateDialogPage );
+ ui.updateDialogLabel->setText(
+ qtr( "You have the latest version of VLC media player." ) );
+ }
}
else
{
- updateBrowser->setHtml( "<html><head><meta http-equiv=\"Content-Type\" content=\"text/html; charset=\"utf-8\" /></head> \
- <body><center>You have the latest version of VLC.</center></body></html>" );
+ ui.stackedWidget->setCurrentWidget( ui.updateDialogPage );
+ ui.updateDialogLabel->setText(
+ qtr( "An error occurred while checking for updates..." ) );
}
}