# include "config.h"
#endif
-#include <vlc_common.h>
-
#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 <QFileDialog>
#include <QDate>
+#include <QPushButton>
-
-HelpDialog *HelpDialog::instance = NULL;
+#include <assert.h>
HelpDialog::HelpDialog( intf_thread_t *_p_intf ) : QVLCFrame( _p_intf )
{
setWindowTitle( qtr( "Help" ) );
- setMinimumSize( 250, 300 );
+ setWindowRole( "vlc-help" );
+ setMinimumSize( 350, 300 );
- QGridLayout *layout = new QGridLayout( this );
+ QVBoxLayout *layout = new QVBoxLayout( 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) );
+ QDialogButtonBox *closeButtonBox = new QDialogButtonBox( Qt::Horizontal, this );
+ closeButtonBox->addButton(
+ new QPushButton( qtr("&Close"), this ), QDialogButtonBox::RejectRole );
+ closeButtonBox->setFocus();
- layout->addWidget( helpBrowser, 0, 0, 1, 0 );
- layout->addWidget( closeButton, 1, 3 );
+ layout->addWidget( helpBrowser );
+ layout->addWidget( closeButtonBox );
- BUTTONACT( closeButton, close() );
- readSettings( "Help", QSize( 400, 450 ) );
+ CONNECT( closeButtonBox, rejected(), this, close() );
+ readSettings( "Help", QSize( 500, 450 ) );
}
HelpDialog::~HelpDialog()
toggleVisible();
}
-AboutDialog *AboutDialog::instance = NULL;
-
-AboutDialog::AboutDialog( QWidget *parent, intf_thread_t *_p_intf)
- : QVLCDialog( parent, _p_intf )
+AboutDialog::AboutDialog( intf_thread_t *_p_intf)
+ : QVLCDialog( (QWidget*)_p_intf->p_sys->p_mi, _p_intf )
{
+ /* Build UI */
+ ui.setupUi( this );
+ ui.closeButtonBox->addButton(
+ new QPushButton( qtr("&Close"), this ), QDialogButtonBox::RejectRole );
+
setWindowTitle( qtr( "About" ) );
+ setWindowRole( "vlc-about" );
resize( 600, 500 );
setMinimumSize( 600, 500 );
+ setWindowModality( Qt::WindowModal );
- QGridLayout *layout = new QGridLayout( this );
- QTabWidget *tab = new QTabWidget( this );
+ CONNECT( ui.closeButtonBox, rejected(), this, close() );
+ ui.closeButtonBox->setFocus();
- QPushButton *closeButton = new QPushButton( qtr( "&Close" ) );
- closeButton->setSizePolicy( QSizePolicy::Minimum, QSizePolicy::Minimum );
- closeButton->setDefault( true );
+ ui.introduction->setText(
+ qtr( "VLC media player" ) + qfu( " " VERSION_MESSAGE ) );
- QLabel *introduction = new QLabel(
- qtr( "VLC media player" " " VERSION_MESSAGE ) );
- QLabel *iconVLC = new QLabel;
if( QDate::currentDate().dayOfYear() >= 354 )
- iconVLC->setPixmap( QPixmap( ":/vlc48-christmas.png" ) );
+ ui.iconVLC->setPixmap( QPixmap( ":/logo/vlc128-christmas.png" ) );
else
- 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 );
+ ui.iconVLC->setPixmap( QPixmap( ":/logo/vlc128.png" ) );
/* Main Introduction */
- QWidget *infoWidget = new QWidget( this );
- QHBoxLayout *infoLayout = new QHBoxLayout( infoWidget );
- QLabel *infoLabel = new QLabel(
+ ui.infoLabel->setText(
qtr( "VLC media player is a free media player, "
"encoder and streamer that can read from files, "
"CDs, DVDs, network streams, capture cards and even more!\n"
- "Also, VLC works on essentially every popular platform.\n\n" )
+ "VLC uses its internal codecs and works on essentially every "
+ "popular platform.\n\n" )
+ qtr( "This version of VLC was compiled by:\n " )
- + qfu( VLC_CompileBy() )+ "@" + qfu( VLC_CompileHost() ) + "."
- + qfu( VLC_CompileDomain() ) + ".\n"
- + "Compiler: " + qfu( VLC_Compiler() ) + ".\n"
- + qtr( "Based on Git commit: " ) + qfu( VLC_Changeset() ) + ".\n"
+ + qfu( VLC_CompileBy() )+ " on " + qfu( VLC_CompileHost() ) +
+ + " ("__DATE__" "__TIME__").\n"
+ + qtr( "Compiler: " ) + qfu( VLC_Compiler() ) + ".\n"
+ qtr( "You are using the Qt4 Interface.\n\n" )
- + qtr( "Copyright © " COPYRIGHT_YEARS " by the VideoLAN Team.\n" )
+ + qtr( "Copyright (C) " ) + COPYRIGHT_YEARS
+ + qtr( " by the VideoLAN Team.\n" )
+ "vlc@videolan.org, http://www.videolan.org" );
- infoLabel->setWordWrap( infoLabel );
-
- QLabel *iconVLC2 = new QLabel;
- if( QDate::currentDate().dayOfYear() >= 354 )
- iconVLC2->setPixmap( QPixmap( ":/vlc128-christmas.png" ) );
- else
- iconVLC2->setPixmap( QPixmap( ":/vlc128.png" ) );
- infoLayout->addWidget( iconVLC2 );
- infoLayout->addWidget( infoLabel );
/* GPL License */
- QTextEdit *licenseEdit = new QTextEdit( this );
- licenseEdit->setText( qfu( psz_license ) );
- licenseEdit->setReadOnly( true );
+ ui.licenseEdit->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.thanksEdit->setText( qfu( psz_thanks ) );
/* People who wrote the software */
- QTextEdit *authorsEdit = new QTextEdit( this );
- authorsEdit->setText( qfu( psz_authors ) );
- authorsEdit->setReadOnly( true );
-
- /* add the tabs to the Tabwidget */
- tab->addTab( infoWidget, qtr( "About" ) );
- tab->addTab( authorsEdit, qtr( "Authors" ) );
- tab->addTab( thanksWidget, qtr("Thanks") );
- tab->addTab( licenseEdit, qtr("License") );
-
- BUTTONACT( closeButton, close() );
+ ui.authorsEdit->setText( qfu( psz_authors ) );
}
AboutDialog::~AboutDialog()
QApplication::postEvent( UDialog, event );
}
-UpdateDialog *UpdateDialog::instance = NULL;
-
UpdateDialog::UpdateDialog( intf_thread_t *_p_intf ) : QVLCFrame( _p_intf )
{
- setWindowTitle( qtr( "Update" ) );
+ /* 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 );
- QGridLayout *layout = new QGridLayout( this );
+ ui.updateNotifyButtonBox->addButton( new QPushButton( qtr("&Yes"), this ),
+ QDialogButtonBox::AcceptRole );
+ ui.updateNotifyButtonBox->addButton( new QPushButton( qtr("&No"), this ),
+ QDialogButtonBox::RejectRole );
- QPushButton *closeButton = new QPushButton( qtr( "&Close" ) );
- 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 );
+ setWindowTitle( qtr( "VLC media player updates" ) );
+ setWindowRole( "vlc-update" );
- updateLabel = new QLabel( qtr( "Checking for an update..." ) );
- updateLabel->setWordWrap( true );
+ BUTTONACT( recheckButton, UpdateOrDownload() );
+ CONNECT( ui.updateDialogButtonBox, rejected(), this, close() );
- layout->addWidget( updateLabel, 0, 0 );
- layout->addWidget( buttonBox, 1, 0 );
-
- BUTTONACT( updateButton, UpdateOrDownload() );
- BUTTONACT( closeButton, 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;
- readSettings( "Update", QSize( 120, 80 ) );
+ setMinimumSize( 300, 300 );
+ setMaximumSize( 400, 300 );
+
+ readSettings( "Update", QSize( 300, 250 ) );
/* Check for updates */
UpdateOrDownload();
{
if( !b_checked )
{
- updateButton->setEnabled( false );
- msg_Dbg( p_intf, "Launching an update request" );
+ ui.stackedWidget->setCurrentWidget( ui.updateRequestPage );
update_Check( p_update, UpdateCallback, this );
}
else
{
- updateButton->setEnabled( false );
QString dest_dir = QFileDialog::getExistingDirectory( this,
- qtr( "Select a directory ..." ),
- qfu( config_GetHomeDir() ) );
+ qtr( I_OP_SEL_DIR ),
+ QVLCUserDir( VLC_DOWNLOAD_DIR ) );
- if( dest_dir != "" )
+ 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 ! */
}
- else
- updateButton->setEnabled( true );
}
}
{
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;
- updateButton->setText( "Download" );
- updateLabel->setText( qtr( "There is a new version of VLC :\n" )
- + qfu( p_release->psz_desc ) );
+ 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->extra )?QString( p_release->extra ):"" );
+
+ ui.updateNotifyLabel->setText( message );
+ ui.updateNotifyTextEdit->setText( qfu( p_release->psz_desc ) );
+
+ /* Force the dialog to be shown */
+ this->show();
}
else
- updateLabel->setText( qtr( "You have the latest version of VLC" ) );
+ {
+ ui.stackedWidget->setCurrentWidget( ui.updateDialogPage );
+ ui.updateDialogLabel->setText(
+ qtr( "You have the latest version of VLC media player." ) );
+ }
}
else
- updateLabel->setText(
- qtr( "An error occurred while checking for updates" ) );
-
- adjustSize();
- updateButton->setEnabled( true );
+ {
+ ui.stackedWidget->setCurrentWidget( ui.updateDialogPage );
+ ui.updateDialogLabel->setText(
+ qtr( "An error occurred while checking for updates..." ) );
+ }
}
#endif